open-law/app/views/search.py

182 lines
5.8 KiB
Python
Raw Normal View History

2023-05-23 12:52:49 +00:00
from flask import Blueprint, render_template, request
2023-05-24 11:44:04 +00:00
from sqlalchemy import func, and_, or_
2023-05-23 12:52:49 +00:00
2023-05-24 11:44:04 +00:00
from app import models as m, db
from app.controllers import create_pagination
2023-05-23 12:52:49 +00:00
bp = Blueprint("search", __name__)
@bp.route("/search_interpretations", methods=["GET"])
def search_interpretations():
q = request.args.get("q", type=str, default="").lower()
2023-05-24 11:44:04 +00:00
interpretations = m.Interpretation.query.order_by(m.Interpretation.id).filter(
(func.lower(m.Interpretation.plain_text).like(f"%{q}%"))
)
2023-05-23 12:52:49 +00:00
count = interpretations.count()
2023-05-24 11:44:04 +00:00
pagination = create_pagination(total=interpretations.count())
2023-05-23 12:52:49 +00:00
return render_template(
"searchResultsInterpretations.html",
query=q,
2023-05-24 11:44:04 +00:00
interpretations=interpretations.paginate(
page=pagination.page, per_page=pagination.per_page
),
page=pagination,
2023-05-23 12:52:49 +00:00
count=count,
)
@bp.route("/search_books", methods=["GET"])
def search_books():
q = request.args.get("q", type=str, default="")
2023-05-24 11:44:04 +00:00
books = (
db.session.query(m.Book)
.filter(
or_(
and_(
func.lower(m.Book.label).like(f"%{q}%"),
m.Book.is_deleted == False, # noqa: E712
),
and_(
func.lower(m.Collection.label).like(f"%{q}%"),
m.Collection.is_deleted == False, # noqa: E712
m.Collection.is_root == False, # noqa: E712
m.BookVersion.id == m.Collection.version_id,
m.Book.id == m.BookVersion.book_id,
m.Book.is_deleted == False, # noqa: E712
),
and_(
func.lower(m.Section.label).like(f"%{q}%"),
m.Section.is_deleted == False, # noqa: E712
m.BookVersion.id == m.Section.version_id,
m.Book.id == m.BookVersion.book_id,
m.Book.is_deleted == False, # noqa: E712
),
and_(
func.lower(m.Interpretation.plain_text).like(f"%{q}%"),
m.Interpretation.is_deleted == False, # noqa: E712
m.Interpretation.section_id == m.Section.id,
m.Section.is_deleted == False, # noqa: E712
m.BookVersion.id == m.Section.version_id,
m.Book.id == m.BookVersion.book_id,
m.Book.is_deleted == False, # noqa: E712
),
),
)
.order_by(m.Book.created_at.asc())
.group_by(m.Book.id)
)
2023-05-23 12:52:49 +00:00
count = books.count()
2023-05-24 11:44:04 +00:00
pagination = create_pagination(total=books.count())
2023-05-23 12:52:49 +00:00
return render_template(
"searchResultsBooks.html",
query=q,
2023-05-24 11:44:04 +00:00
books=books.paginate(page=pagination.page, per_page=pagination.per_page),
page=pagination,
2023-05-23 12:52:49 +00:00
count=count,
)
@bp.route("/search_users", methods=["GET"])
def search_users():
q = request.args.get("q", type=str, default="")
2023-05-24 11:44:04 +00:00
users = (
m.User.query.order_by(m.User.id)
.filter(
or_(
func.lower(m.User.username).like(f"%{q}%"),
func.lower(m.User.wallet_id).like(f"%{q}%"),
)
)
.order_by(m.User.id.asc())
.group_by(m.User.id)
)
2023-05-23 12:52:49 +00:00
count = users.count()
2023-05-24 11:44:04 +00:00
pagination = create_pagination(total=users.count())
2023-05-23 12:52:49 +00:00
return render_template(
"searchResultsUsers.html",
query=q,
2023-05-24 11:44:04 +00:00
users=users.paginate(page=pagination.page, per_page=pagination.per_page),
page=pagination,
2023-05-23 12:52:49 +00:00
count=count,
)
@bp.route("/search_tags", methods=["GET"])
def search_tags():
q = request.args.get("q", type=str, default="")
2023-05-24 13:45:38 +00:00
tags = m.Tag.query.order_by(m.Tag.id).filter(func.lower(m.Tag.name).like(f"%{q}%"))
2023-05-23 12:52:49 +00:00
count = tags.count()
2023-05-24 11:44:04 +00:00
pagination = create_pagination(total=tags.count())
2023-05-23 12:52:49 +00:00
return render_template(
2023-05-24 11:44:04 +00:00
"searchResultsTags.html",
2023-05-23 12:52:49 +00:00
query=q,
2023-05-24 11:44:04 +00:00
tags=tags.paginate(page=pagination.page, per_page=pagination.per_page),
page=pagination,
2023-05-23 12:52:49 +00:00
count=count,
)
2023-05-24 13:45:38 +00:00
@bp.route("/tag_search_interpretations", methods=["GET"])
def tag_search_interpretations():
tag_name = request.args.get("tag_name", type=str, default="")
interpretations = (
db.session.query(m.Interpretation)
.filter(
and_(
func.lower(m.Tag.name) == (tag_name),
m.InterpretationTag.tag_id == m.Tag.id,
m.Interpretation.id == m.InterpretationTag.interpretation_id,
m.Interpretation.is_deleted == False, # noqa: E712
)
)
.order_by(m.Interpretation.created_at.asc())
.group_by(m.Interpretation.id)
)
pagination = create_pagination(total=interpretations.count())
return render_template(
"tagSearchResultsInterpretations.html",
tag_name=tag_name,
interpretations=interpretations.paginate(
page=pagination.page, per_page=pagination.per_page
),
page=pagination,
count=interpretations.count(),
)
@bp.route("/tag_search_books", methods=["GET"])
def tag_search_books():
tag_name = request.args.get("tag_name", type=str, default="")
books = (
db.session.query(m.Book)
.filter(
and_(
func.lower(m.Tag.name) == (tag_name),
m.BookTags.tag_id == m.Tag.id,
m.Book.id == m.BookTags.book_id,
m.Book.is_deleted == False, # noqa: E712
)
)
.order_by(m.Book.created_at.asc())
.group_by(m.Book.id)
)
pagination = create_pagination(total=books.count())
return render_template(
"tagSearchResultsBooks.html",
tag_name=tag_name,
books=books.paginate(page=pagination.page, per_page=pagination.per_page),
page=pagination,
count=books.count(),
)