Filter tags by available packages in package search

This commit is contained in:
rubenwardy 2020-07-18 03:14:56 +01:00
parent dd7146205a
commit 64dab0c4b6
2 changed files with 46 additions and 38 deletions

@ -96,8 +96,9 @@ def list_all():
qb.show_discarded = True qb.show_discarded = True
topics = qb.buildTopicQuery().all() topics = qb.buildTopicQuery().all()
tags = db.session.query(func.count(Tags.c.tag_id), Tag) \ tags_query = db.session.query(func.count(Tags.c.tag_id), Tag) \
.select_from(Tag).outerjoin(Tags).group_by(Tag.id).order_by(db.asc(Tag.title)).all() .select_from(Tag).join(Tags).join(Package).group_by(Tag.id).order_by(db.asc(Tag.title))
tags = qb.filterPackageQuery(tags_query).all()
selected_tags = set(qb.tags) selected_tags = set(qb.tags)

@ -76,45 +76,12 @@ class QueryBuilder:
else: else:
query = Package.query.filter_by(soft_deleted=False, approved=True) query = Package.query.filter_by(soft_deleted=False, approved=True)
return self.filterPackageQuery(self.orderPackageQuery(query))
def filterPackageQuery(self, query):
if len(self.types) > 0: if len(self.types) > 0:
query = query.filter(Package.type.in_(self.types)) query = query.filter(Package.type.in_(self.types))
if self.search:
query = query.search(self.search, sort=self.order_by is None)
if self.random:
query = query.order_by(func.random())
else:
to_order = None
if self.order_by is None and self.search:
pass
elif self.order_by is None or self.order_by == "score":
to_order = Package.score
elif self.order_by == "name":
to_order = Package.name
elif self.order_by == "title":
to_order = Package.title
elif self.order_by == "downloads":
to_order = Package.downloads
elif self.order_by == "created_at" or self.order_by == "date":
to_order = Package.created_at
elif self.order_by == "approved_at" or self.order_by == "date":
to_order = Package.approved_at
elif self.order_by == "last_release":
to_order = PackageRelease.releaseDate
else:
abort(400)
if to_order:
if self.order_dir == "asc":
to_order = db.asc(to_order)
elif self.order_dir == "desc":
to_order = db.desc(to_order)
else:
abort(400)
query = query.order_by(to_order)
if self.author: if self.author:
author = User.query.filter_by(username=self.author).first() author = User.query.filter_by(username=self.author).first()
if not author: if not author:
@ -150,6 +117,46 @@ class QueryBuilder:
return query return query
def orderPackageQuery(self, query):
if self.search:
query = query.search(self.search, sort=self.order_by is None)
if self.random:
query = query.order_by(func.random())
return query
to_order = None
if self.order_by is None and self.search:
pass
elif self.order_by is None or self.order_by == "score":
to_order = Package.score
elif self.order_by == "name":
to_order = Package.name
elif self.order_by == "title":
to_order = Package.title
elif self.order_by == "downloads":
to_order = Package.downloads
elif self.order_by == "created_at" or self.order_by == "date":
to_order = Package.created_at
elif self.order_by == "approved_at" or self.order_by == "date":
to_order = Package.approved_at
elif self.order_by == "last_release":
to_order = PackageRelease.releaseDate
else:
abort(400)
if to_order:
if self.order_dir == "asc":
to_order = db.asc(to_order)
elif self.order_dir == "desc":
to_order = db.desc(to_order)
else:
abort(400)
query = query.order_by(to_order)
return query
def buildTopicQuery(self, show_added=False): def buildTopicQuery(self, show_added=False):
query = ForumTopic.query query = ForumTopic.query