mirror of
https://github.com/minetest/contentdb.git
synced 2024-12-22 22:12:24 +01:00
parent
30722020c8
commit
459eb02112
@ -16,7 +16,8 @@
|
||||
|
||||
from flask import Blueprint, request, render_template, abort, flash, redirect, url_for
|
||||
from flask_babel import gettext, lazy_gettext
|
||||
from sqlalchemy.orm import selectinload
|
||||
from sqlalchemy import or_
|
||||
from sqlalchemy.orm import selectinload, joinedload
|
||||
|
||||
from app.markdown import get_user_mentions, render_markdown
|
||||
from app.tasks.webhooktasks import post_discord_webhook
|
||||
@ -391,12 +392,18 @@ def user_comments(username):
|
||||
if user is None:
|
||||
abort(404)
|
||||
|
||||
all_replies = ThreadReply.query.options(selectinload(ThreadReply.thread)).filter_by(author=user)
|
||||
page = get_int_or_abort(request.args.get("page"), 1)
|
||||
num = min(40, get_int_or_abort(request.args.get("n"), 40))
|
||||
|
||||
visible_replies = [
|
||||
reply
|
||||
for reply in all_replies
|
||||
if reply.thread.check_perm(current_user, Permission.SEE_THREAD)
|
||||
]
|
||||
# Filter replies the current user can see
|
||||
query = ThreadReply.query.options(selectinload(ThreadReply.thread)).filter_by(author=user)
|
||||
if current_user != user and not (current_user.is_authenticated and current_user.rank.at_least(UserRank.APPROVER)):
|
||||
if user.username == "ContentDB":
|
||||
# The ContentDB user simply has too many comments, don't bother checking more than thread privacy
|
||||
query = query.filter(ThreadReply.thread.has(private=False))
|
||||
else:
|
||||
query = query.filter(or_(ThreadReply.thread.has(private=False), Thread.watchers.contains(current_user)))
|
||||
|
||||
return render_template("threads/user_comments.html", user=user, replies=visible_replies)
|
||||
pagination = query.order_by(db.desc(ThreadReply.created_at)).paginate(page=page, per_page=num)
|
||||
|
||||
return render_template("threads/user_comments.html", user=user, pagination=pagination)
|
||||
|
@ -12,9 +12,12 @@
|
||||
{% block content %}
|
||||
<h1>{{ _("Comments by %(user)s", user=self.link()) }}</h1>
|
||||
|
||||
{% if pagination.total %}
|
||||
{% from "macros/pagination.html" import render_pagination %}
|
||||
{{ render_pagination(pagination, url_set_query) }}
|
||||
|
||||
<ul class="comments mt-5 mb-0">
|
||||
{% for r in replies %}
|
||||
{% for r in pagination.items %}
|
||||
<li class="row my-2 mx-0">
|
||||
<div class="col-md-1 p-1">
|
||||
<a href="{{ url_for('users.profile', username=r.author.username) }}">
|
||||
@ -63,4 +66,13 @@
|
||||
{% endfor %}
|
||||
</ul>
|
||||
|
||||
{{ render_pagination(pagination, url_set_query) }}
|
||||
{% else %}
|
||||
<p>
|
||||
<i>
|
||||
{{ _("No results") }}
|
||||
</i>
|
||||
</p>
|
||||
{% endif %}
|
||||
|
||||
{% endblock %}
|
||||
|
Loading…
Reference in New Issue
Block a user