mirror of
https://github.com/minetest/contentdb.git
synced 2025-01-10 06:57:34 +01:00
Add random feature
This commit is contained in:
parent
08434300d8
commit
63969529ad
@ -49,10 +49,10 @@
|
|||||||
{% if type %}<input type="hidden" name="type" value="{{ type }}" />{% endif %}
|
{% if type %}<input type="hidden" name="type" value="{{ type }}" />{% endif %}
|
||||||
<input class="form-control mr-sm-2" name="q" type="text" placeholder="Search {{ title | lower or 'all packages' }}" value="{{ query or ''}}">
|
<input class="form-control mr-sm-2" name="q" type="text" placeholder="Search {{ title | lower or 'all packages' }}" value="{{ query or ''}}">
|
||||||
<input class="btn btn-secondary my-2 my-sm-0 mr-sm-2" type="submit" value="Search" />
|
<input class="btn btn-secondary my-2 my-sm-0 mr-sm-2" type="submit" value="Search" />
|
||||||
<input class="btn btn-secondary my-2 my-sm-0"
|
<!-- <input class="btn btn-secondary my-2 my-sm-0"
|
||||||
data-toggle="tooltip" data-placement="bottom"
|
data-toggle="tooltip" data-placement="bottom"
|
||||||
title="Go to the first found result for this query."
|
title="Go to the first found result for this query."
|
||||||
type="submit" name="lucky" value="First" />
|
type="submit" name="lucky" value="First" /> -->
|
||||||
</form>
|
</form>
|
||||||
<ul class="navbar-nav ml-auto">
|
<ul class="navbar-nav ml-auto">
|
||||||
{% if current_user.is_authenticated %}
|
{% if current_user.is_authenticated %}
|
||||||
|
@ -30,6 +30,7 @@ from wtforms import *
|
|||||||
from wtforms.validators import *
|
from wtforms.validators import *
|
||||||
from wtforms.ext.sqlalchemy.fields import QuerySelectField, QuerySelectMultipleField
|
from wtforms.ext.sqlalchemy.fields import QuerySelectField, QuerySelectMultipleField
|
||||||
from sqlalchemy import or_, any_
|
from sqlalchemy import or_, any_
|
||||||
|
from sqlalchemy.sql.expression import func
|
||||||
|
|
||||||
|
|
||||||
class QueryBuilder:
|
class QueryBuilder:
|
||||||
@ -50,7 +51,8 @@ class QueryBuilder:
|
|||||||
self.title = title
|
self.title = title
|
||||||
self.types = types
|
self.types = types
|
||||||
self.search = request.args.get("q")
|
self.search = request.args.get("q")
|
||||||
self.lucky = "lucky" in request.args
|
self.random = "random" in request.args
|
||||||
|
self.lucky = self.random or "lucky" in request.args
|
||||||
self.hide_nonfree = isNo(request.args.get("nonfree"))
|
self.hide_nonfree = isNo(request.args.get("nonfree"))
|
||||||
self.limit = 1 if self.lucky else None
|
self.limit = 1 if self.lucky else None
|
||||||
self.order_by = request.args.get("sort") or "score"
|
self.order_by = request.args.get("sort") or "score"
|
||||||
@ -65,6 +67,9 @@ class QueryBuilder:
|
|||||||
if self.search is not None and self.search.strip() != "":
|
if self.search is not None and self.search.strip() != "":
|
||||||
query = query.filter(Package.title.ilike('%' + self.search + '%'))
|
query = query.filter(Package.title.ilike('%' + self.search + '%'))
|
||||||
|
|
||||||
|
if self.random:
|
||||||
|
query = query.order_by(func.random())
|
||||||
|
else:
|
||||||
to_order = None
|
to_order = None
|
||||||
if self.order_by == "score":
|
if self.order_by == "score":
|
||||||
to_order = Package.score
|
to_order = Package.score
|
||||||
@ -112,6 +117,7 @@ class QueryBuilder:
|
|||||||
@menu.register_menu(app, ".mods", "Mods", order=11, endpoint_arguments_constructor=lambda: { 'type': 'mod' })
|
@menu.register_menu(app, ".mods", "Mods", order=11, endpoint_arguments_constructor=lambda: { 'type': 'mod' })
|
||||||
@menu.register_menu(app, ".games", "Games", order=12, endpoint_arguments_constructor=lambda: { 'type': 'game' })
|
@menu.register_menu(app, ".games", "Games", order=12, endpoint_arguments_constructor=lambda: { 'type': 'game' })
|
||||||
@menu.register_menu(app, ".txp", "Texture Packs", order=13, endpoint_arguments_constructor=lambda: { 'type': 'txp' })
|
@menu.register_menu(app, ".txp", "Texture Packs", order=13, endpoint_arguments_constructor=lambda: { 'type': 'txp' })
|
||||||
|
@menu.register_menu(app, ".random", "Random", order=14, endpoint_arguments_constructor=lambda: { 'random': '1' })
|
||||||
@app.route("/packages/")
|
@app.route("/packages/")
|
||||||
def packages_page():
|
def packages_page():
|
||||||
if shouldReturnJson():
|
if shouldReturnJson():
|
||||||
@ -127,7 +133,7 @@ def packages_page():
|
|||||||
return redirect(package.getDetailsURL())
|
return redirect(package.getDetailsURL())
|
||||||
|
|
||||||
topic = qb.buildTopicQuery().first()
|
topic = qb.buildTopicQuery().first()
|
||||||
if topic:
|
if qb.search and topic:
|
||||||
return redirect("https://forum.minetest.net/viewtopic.php?t=" + str(topic.topic_id))
|
return redirect("https://forum.minetest.net/viewtopic.php?t=" + str(topic.topic_id))
|
||||||
|
|
||||||
page = int(request.args.get("page") or 1)
|
page = int(request.args.get("page") or 1)
|
||||||
|
Loading…
Reference in New Issue
Block a user