From 39a09c5d9248d48422b4e8773add3b912e364ed1 Mon Sep 17 00:00:00 2001 From: rubenwardy Date: Tue, 7 Apr 2020 18:23:06 +0100 Subject: [PATCH] Add ability to search by tag --- app/querybuilder.py | 13 ++++++++++++- app/templates/packages/view.html | 3 ++- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/app/querybuilder.py b/app/querybuilder.py index 4db67426..d811ce52 100644 --- a/app/querybuilder.py +++ b/app/querybuilder.py @@ -1,4 +1,5 @@ -from .models import db, PackageType, Package, ForumTopic, License, MinetestRelease, PackageRelease, User +from .models import db, PackageType, Package, ForumTopic, License, MinetestRelease, PackageRelease, User, Tag +from .models import tags as Tags from .utils import isNo, isYes from sqlalchemy.sql.expression import func from flask import abort @@ -19,10 +20,17 @@ class QueryBuilder: if len(types) > 0: title = ", ".join([type.value + "s" for type in types]) + # Get tags types + tags = args.getlist("tag") + tags = [Tag.query.filter_by(name=tname).first() for tname in tags] + tags = [tag for tag in tags if tag is not None] + + # Hid hide_flags = args.getlist("hide") self.title = title self.types = types + self.tags = tags self.random = "random" in args self.lucky = "lucky" in args @@ -96,6 +104,9 @@ class QueryBuilder: query = query.filter_by(author=author) + for tag in self.tags: + query = query.filter(Package.tags.any(Tag.id == tag.id)) + if self.hide_nonfree: query = query.filter(Package.license.has(License.is_foss == True)) query = query.filter(Package.media_license.has(License.is_foss == True)) diff --git a/app/templates/packages/view.html b/app/templates/packages/view.html index 77b84da2..cb5f04d7 100644 --- a/app/templates/packages/view.html +++ b/app/templates/packages/view.html @@ -38,7 +38,8 @@ {% endif %} {% for t in package.tags %} - {{ t.title }} + {{ t.title }} {% endfor %}