mirror of
https://codeberg.org/rimu/pyfedi
synced 2025-01-23 19:36:56 -08:00
Fix - subscribed page topic filter handling
This commit is contained in:
parent
ad55fc510c
commit
f76b205f29
1 changed files with 68 additions and 71 deletions
|
@ -220,7 +220,7 @@ def list_communities():
|
||||||
next_url=next_url, prev_url=prev_url, current_user=current_user,
|
next_url=next_url, prev_url=prev_url, current_user=current_user,
|
||||||
topics=topics, languages=languages, topic_id=topic_id, language_id=language_id, sort_by=sort_by,
|
topics=topics, languages=languages, topic_id=topic_id, language_id=language_id, sort_by=sort_by,
|
||||||
low_bandwidth=low_bandwidth, moderating_communities=moderating_communities(current_user.get_id()),
|
low_bandwidth=low_bandwidth, moderating_communities=moderating_communities(current_user.get_id()),
|
||||||
joined_communities=joined_communities(current_user.get_id()),
|
# joined_communities=joined_communities(current_user.get_id()),
|
||||||
menu_topics=menu_topics(), site=g.site)
|
menu_topics=menu_topics(), site=g.site)
|
||||||
|
|
||||||
|
|
||||||
|
@ -272,11 +272,12 @@ def list_local_communities():
|
||||||
next_url=next_url, prev_url=prev_url, current_user=current_user,
|
next_url=next_url, prev_url=prev_url, current_user=current_user,
|
||||||
topics=topics, languages=languages, topic_id=topic_id, language_id=language_id, sort_by=sort_by,
|
topics=topics, languages=languages, topic_id=topic_id, language_id=language_id, sort_by=sort_by,
|
||||||
low_bandwidth=low_bandwidth, moderating_communities=moderating_communities(current_user.get_id()),
|
low_bandwidth=low_bandwidth, moderating_communities=moderating_communities(current_user.get_id()),
|
||||||
joined_communities=joined_communities(current_user.get_id()),
|
# joined_communities=joined_communities(current_user.get_id()),
|
||||||
menu_topics=menu_topics(), site=g.site)
|
menu_topics=menu_topics(), site=g.site)
|
||||||
|
|
||||||
|
|
||||||
@bp.route('/communities/subscribed', methods=['GET'])
|
@bp.route('/communities/subscribed', methods=['GET'])
|
||||||
|
@login_required
|
||||||
def list_subscribed_communities():
|
def list_subscribed_communities():
|
||||||
verification_warning()
|
verification_warning()
|
||||||
search_param = request.args.get('search', '')
|
search_param = request.args.get('search', '')
|
||||||
|
@ -287,36 +288,39 @@ def list_subscribed_communities():
|
||||||
sort_by = request.args.get('sort_by', 'post_reply_count desc')
|
sort_by = request.args.get('sort_by', 'post_reply_count desc')
|
||||||
topics = Topic.query.order_by(Topic.name).all()
|
topics = Topic.query.order_by(Topic.name).all()
|
||||||
languages = Language.query.order_by(Language.name).all()
|
languages = Language.query.order_by(Language.name).all()
|
||||||
if current_user.is_authenticated:
|
# get all the communities
|
||||||
communities = Community.query.filter_by(banned=False).join(CommunityMember).filter(CommunityMember.user_id == current_user.id)
|
all_communities = Community.query.filter_by(banned=False)
|
||||||
|
# get the user's joined communities
|
||||||
|
user_joined_communities = joined_communities(current_user.id)
|
||||||
|
# get the joined community ids list
|
||||||
|
joined_ids = []
|
||||||
|
for jc in user_joined_communities:
|
||||||
|
joined_ids.append(jc.id)
|
||||||
|
# filter down to just the joined communities
|
||||||
|
communities = all_communities.filter(Community.id.in_(joined_ids))
|
||||||
|
|
||||||
if search_param == '':
|
if search_param == '':
|
||||||
pass
|
pass
|
||||||
else:
|
|
||||||
communities = communities.filter(or_(Community.title.ilike(f"%{search_param}%"), Community.ap_id.ilike(f"%{search_param}%")))
|
|
||||||
|
|
||||||
if topic_id != 0:
|
|
||||||
communities = communities.filter_by(topic_id=topic_id)
|
|
||||||
|
|
||||||
if language_id != 0:
|
|
||||||
communities = communities.join(community_language).filter(community_language.c.language_id == language_id)
|
|
||||||
|
|
||||||
banned_from = communities_banned_from(current_user.id)
|
|
||||||
if banned_from:
|
|
||||||
communities = communities.filter(Community.id.not_in(banned_from))
|
|
||||||
|
|
||||||
communities = communities.order_by(text('community.' + sort_by))
|
|
||||||
|
|
||||||
# Pagination
|
|
||||||
communities = communities.paginate(page=page, per_page=250 if current_user.is_authenticated and not low_bandwidth else 50,
|
|
||||||
error_out=False)
|
|
||||||
next_url = url_for('main.list_subscribed_communities', page=communities.next_num, sort_by=sort_by, language_id=language_id) if communities.has_next else None
|
|
||||||
prev_url = url_for('main.list_subscribed_communities', page=communities.prev_num, sort_by=sort_by, language_id=language_id) if communities.has_prev and page != 1 else None
|
|
||||||
|
|
||||||
else:
|
else:
|
||||||
communities = []
|
communities = communities.filter(or_(Community.title.ilike(f"%{search_param}%"), Community.ap_id.ilike(f"%{search_param}%")))
|
||||||
next_url = None
|
|
||||||
prev_url = None
|
if topic_id != 0:
|
||||||
|
communities = communities.filter_by(topic_id=topic_id)
|
||||||
|
|
||||||
|
if language_id != 0:
|
||||||
|
communities = communities.join(community_language).filter(community_language.c.language_id == language_id)
|
||||||
|
|
||||||
|
banned_from = communities_banned_from(current_user.id)
|
||||||
|
if banned_from:
|
||||||
|
communities = communities.filter(Community.id.not_in(banned_from))
|
||||||
|
|
||||||
|
communities = communities.order_by(text('community.' + sort_by))
|
||||||
|
|
||||||
|
# Pagination
|
||||||
|
communities = communities.paginate(page=page, per_page=250 if current_user.is_authenticated and not low_bandwidth else 50,
|
||||||
|
error_out=False)
|
||||||
|
next_url = url_for('main.list_subscribed_communities', page=communities.next_num, sort_by=sort_by, language_id=language_id) if communities.has_next else None
|
||||||
|
prev_url = url_for('main.list_subscribed_communities', page=communities.prev_num, sort_by=sort_by, language_id=language_id) if communities.has_prev and page != 1 else None
|
||||||
|
|
||||||
return render_template('list_communities.html', communities=communities, search=search_param, title=_('Joined Communities'),
|
return render_template('list_communities.html', communities=communities, search=search_param, title=_('Joined Communities'),
|
||||||
SUBSCRIPTION_PENDING=SUBSCRIPTION_PENDING, SUBSCRIPTION_MEMBER=SUBSCRIPTION_MEMBER,
|
SUBSCRIPTION_PENDING=SUBSCRIPTION_PENDING, SUBSCRIPTION_MEMBER=SUBSCRIPTION_MEMBER,
|
||||||
|
@ -324,7 +328,6 @@ def list_subscribed_communities():
|
||||||
next_url=next_url, prev_url=prev_url, current_user=current_user,
|
next_url=next_url, prev_url=prev_url, current_user=current_user,
|
||||||
topics=topics, languages=languages, topic_id=topic_id, language_id=language_id, sort_by=sort_by,
|
topics=topics, languages=languages, topic_id=topic_id, language_id=language_id, sort_by=sort_by,
|
||||||
low_bandwidth=low_bandwidth, moderating_communities=moderating_communities(current_user.get_id()),
|
low_bandwidth=low_bandwidth, moderating_communities=moderating_communities(current_user.get_id()),
|
||||||
joined_communities=joined_communities(current_user.get_id()),
|
|
||||||
menu_topics=menu_topics(), site=g.site)
|
menu_topics=menu_topics(), site=g.site)
|
||||||
|
|
||||||
|
|
||||||
|
@ -339,49 +342,43 @@ def list_not_subscribed_communities():
|
||||||
sort_by = request.args.get('sort_by', 'post_reply_count desc')
|
sort_by = request.args.get('sort_by', 'post_reply_count desc')
|
||||||
topics = Topic.query.order_by(Topic.name).all()
|
topics = Topic.query.order_by(Topic.name).all()
|
||||||
languages = Language.query.order_by(Language.name).all()
|
languages = Language.query.order_by(Language.name).all()
|
||||||
if current_user.is_authenticated:
|
# get all communities
|
||||||
# get all communities
|
all_communities = Community.query.filter_by(banned=False)
|
||||||
all_communities = Community.query.filter_by(banned=False)
|
# get the user's joined communities
|
||||||
# get the user's joined communities
|
joined_communities = Community.query.filter_by(banned=False).join(CommunityMember).filter(CommunityMember.user_id == current_user.id)
|
||||||
joined_communities = Community.query.filter_by(banned=False).join(CommunityMember).filter(CommunityMember.user_id == current_user.id)
|
# get the joined community ids list
|
||||||
# get the joined community ids list
|
joined_ids = []
|
||||||
joined_ids = []
|
for jc in joined_communities:
|
||||||
for jc in joined_communities:
|
joined_ids.append(jc.id)
|
||||||
joined_ids.append(jc.id)
|
# filter out the joined communities from all communities
|
||||||
# filter out the joined communities from all communities
|
communities = all_communities.filter(Community.id.not_in(joined_ids))
|
||||||
communities = all_communities.filter(Community.id.not_in(joined_ids))
|
|
||||||
|
|
||||||
if search_param == '':
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
communities = communities.filter(or_(Community.title.ilike(f"%{search_param}%"), Community.ap_id.ilike(f"%{search_param}%")))
|
|
||||||
|
|
||||||
if topic_id != 0:
|
|
||||||
communities = communities.filter_by(topic_id=topic_id)
|
|
||||||
|
|
||||||
if language_id != 0:
|
|
||||||
communities = communities.join(community_language).filter(community_language.c.language_id == language_id)
|
|
||||||
|
|
||||||
banned_from = communities_banned_from(current_user.id)
|
|
||||||
if banned_from:
|
|
||||||
communities = communities.filter(Community.id.not_in(banned_from))
|
|
||||||
if current_user.hide_nsfw == 1:
|
|
||||||
communities = communities.filter(Community.nsfw == False)
|
|
||||||
if current_user.hide_nsfl == 1:
|
|
||||||
communities = communities.filter(Community.nsfl == False)
|
|
||||||
|
|
||||||
communities = communities.order_by(text('community.' + sort_by))
|
|
||||||
|
|
||||||
# Pagination
|
|
||||||
communities = communities.paginate(page=page, per_page=250 if current_user.is_authenticated and not low_bandwidth else 50,
|
|
||||||
error_out=False)
|
|
||||||
next_url = url_for('main.list_not_subscribed_communities', page=communities.next_num, sort_by=sort_by, language_id=language_id) if communities.has_next else None
|
|
||||||
prev_url = url_for('main.list_not_subscribed_communities', page=communities.prev_num, sort_by=sort_by, language_id=language_id) if communities.has_prev and page != 1 else None
|
|
||||||
|
|
||||||
|
if search_param == '':
|
||||||
|
pass
|
||||||
else:
|
else:
|
||||||
communities = []
|
communities = communities.filter(or_(Community.title.ilike(f"%{search_param}%"), Community.ap_id.ilike(f"%{search_param}%")))
|
||||||
next_url = None
|
|
||||||
prev_url = None
|
if topic_id != 0:
|
||||||
|
communities = communities.filter_by(topic_id=topic_id)
|
||||||
|
|
||||||
|
if language_id != 0:
|
||||||
|
communities = communities.join(community_language).filter(community_language.c.language_id == language_id)
|
||||||
|
|
||||||
|
banned_from = communities_banned_from(current_user.id)
|
||||||
|
if banned_from:
|
||||||
|
communities = communities.filter(Community.id.not_in(banned_from))
|
||||||
|
if current_user.hide_nsfw == 1:
|
||||||
|
communities = communities.filter(Community.nsfw == False)
|
||||||
|
if current_user.hide_nsfl == 1:
|
||||||
|
communities = communities.filter(Community.nsfl == False)
|
||||||
|
|
||||||
|
communities = communities.order_by(text('community.' + sort_by))
|
||||||
|
|
||||||
|
# Pagination
|
||||||
|
communities = communities.paginate(page=page, per_page=250 if current_user.is_authenticated and not low_bandwidth else 50,
|
||||||
|
error_out=False)
|
||||||
|
next_url = url_for('main.list_not_subscribed_communities', page=communities.next_num, sort_by=sort_by, language_id=language_id) if communities.has_next else None
|
||||||
|
prev_url = url_for('main.list_not_subscribed_communities', page=communities.prev_num, sort_by=sort_by, language_id=language_id) if communities.has_prev and page != 1 else None
|
||||||
|
|
||||||
return render_template('list_communities.html', communities=communities, search=search_param, title=_('Not Joined Communities'),
|
return render_template('list_communities.html', communities=communities, search=search_param, title=_('Not Joined Communities'),
|
||||||
SUBSCRIPTION_PENDING=SUBSCRIPTION_PENDING, SUBSCRIPTION_MEMBER=SUBSCRIPTION_MEMBER,
|
SUBSCRIPTION_PENDING=SUBSCRIPTION_PENDING, SUBSCRIPTION_MEMBER=SUBSCRIPTION_MEMBER,
|
||||||
|
|
Loading…
Add table
Reference in a new issue