mirror of
https://github.com/minetest/contentdb.git
synced 2025-01-24 23:11:33 +01:00
Add ability to edit comments
This commit is contained in:
parent
08f6bd8bef
commit
dfbcbbbb47
@ -141,6 +141,50 @@ def delete_reply(id):
|
|||||||
return redirect(thread.getViewURL())
|
return redirect(thread.getViewURL())
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class CommentForm(FlaskForm):
|
||||||
|
comment = TextAreaField("Comment", [InputRequired(), Length(10, 500)])
|
||||||
|
submit = SubmitField("Comment")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@bp.route("/threads/<int:id>/edit/", methods=["GET", "POST"])
|
||||||
|
@login_required
|
||||||
|
def edit_reply(id):
|
||||||
|
thread = Thread.query.get(id)
|
||||||
|
if thread is None:
|
||||||
|
abort(404)
|
||||||
|
|
||||||
|
reply_id = request.args.get("reply")
|
||||||
|
if reply_id is None:
|
||||||
|
abort(404)
|
||||||
|
|
||||||
|
reply = ThreadReply.query.get(reply_id)
|
||||||
|
if reply is None or reply.thread != thread:
|
||||||
|
abort(404)
|
||||||
|
|
||||||
|
if not reply.checkPerm(current_user, Permission.EDIT_REPLY):
|
||||||
|
abort(403)
|
||||||
|
|
||||||
|
form = CommentForm(formdata=request.form, obj=reply)
|
||||||
|
if request.method == "POST" and form.validate():
|
||||||
|
comment = form.comment.data
|
||||||
|
|
||||||
|
msg = "Edited reply by {}".format(reply.author.display_name)
|
||||||
|
severity = AuditSeverity.NORMAL if current_user == reply.author else AuditSeverity.MODERATION
|
||||||
|
addNotification(reply.author, current_user, msg, thread.getViewURL(), thread.package)
|
||||||
|
addAuditLog(severity, current_user, msg, thread.getViewURL(), thread.package, reply.comment)
|
||||||
|
|
||||||
|
reply.comment = comment
|
||||||
|
|
||||||
|
db.session.commit()
|
||||||
|
|
||||||
|
return redirect(thread.getViewURL())
|
||||||
|
|
||||||
|
return render_template("threads/edit_reply.html", thread=thread, reply=reply, form=form)
|
||||||
|
|
||||||
|
|
||||||
@bp.route("/threads/<int:id>/", methods=["GET", "POST"])
|
@bp.route("/threads/<int:id>/", methods=["GET", "POST"])
|
||||||
def view(id):
|
def view(id):
|
||||||
thread = Thread.query.get(id)
|
thread = Thread.query.get(id)
|
||||||
|
@ -204,6 +204,21 @@ title: Ranks and Permissions
|
|||||||
<th>✓</th> <!-- admin -->
|
<th>✓</th> <!-- admin -->
|
||||||
<th>✓</th>
|
<th>✓</th>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td>Edit Comments</td>
|
||||||
|
<th>✓</th> <!-- new -->
|
||||||
|
<th></th>
|
||||||
|
<th>✓</th> <!-- member -->
|
||||||
|
<th></th>
|
||||||
|
<th>✓</th> <!-- trusted member -->
|
||||||
|
<th></th>
|
||||||
|
<th>✓</th> <!-- editor -->
|
||||||
|
<th></th>
|
||||||
|
<th>✓</th> <!-- moderator -->
|
||||||
|
<th></th>
|
||||||
|
<th>✓</th> <!-- admin -->
|
||||||
|
<th>✓</th>
|
||||||
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Set Email</td>
|
<td>Set Email</td>
|
||||||
<th>✓</th> <!-- new -->
|
<th>✓</th> <!-- new -->
|
||||||
|
@ -93,6 +93,7 @@ class Permission(enum.Enum):
|
|||||||
COMMENT_THREAD = "COMMENT_THREAD"
|
COMMENT_THREAD = "COMMENT_THREAD"
|
||||||
LOCK_THREAD = "LOCK_THREAD"
|
LOCK_THREAD = "LOCK_THREAD"
|
||||||
DELETE_REPLY = "DELETE_REPLY"
|
DELETE_REPLY = "DELETE_REPLY"
|
||||||
|
EDIT_REPLY = "EDIT_REPLY"
|
||||||
UNAPPROVE_PACKAGE = "UNAPPROVE_PACKAGE"
|
UNAPPROVE_PACKAGE = "UNAPPROVE_PACKAGE"
|
||||||
TOPIC_DISCARD = "TOPIC_DISCARD"
|
TOPIC_DISCARD = "TOPIC_DISCARD"
|
||||||
CREATE_TOKEN = "CREATE_TOKEN"
|
CREATE_TOKEN = "CREATE_TOKEN"
|
||||||
@ -1146,7 +1147,11 @@ class ThreadReply(db.Model):
|
|||||||
elif type(perm) != Permission:
|
elif type(perm) != Permission:
|
||||||
raise Exception("Unknown permission given to ThreadReply.checkPerm()")
|
raise Exception("Unknown permission given to ThreadReply.checkPerm()")
|
||||||
|
|
||||||
if perm == Permission.DELETE_REPLY:
|
if perm == Permission.EDIT_REPLY:
|
||||||
|
return (user == self.author and user.rank.atLeast(UserRank.MEMBER) and not self.thread.locked) or \
|
||||||
|
user.rank.atLeast(UserRank.ADMIN)
|
||||||
|
|
||||||
|
elif perm == Permission.DELETE_REPLY:
|
||||||
return user.rank.atLeast(UserRank.MODERATOR) and self.thread.replies[0] != self
|
return user.rank.atLeast(UserRank.MODERATOR) and self.thread.replies[0] != self
|
||||||
|
|
||||||
else:
|
else:
|
||||||
|
@ -22,8 +22,20 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
|
{% if current_user == thread.author and thread.review and thread.replies[0] == r %}
|
||||||
|
<a class="float-right btn btn-primary btn-sm ml-2"
|
||||||
|
href="{{ thread.review.package.getReviewURL() }}">
|
||||||
|
<i class="fas fa-edit"></i>
|
||||||
|
</a>
|
||||||
|
{% elif r.checkPerm(current_user, "EDIT_REPLY") %}
|
||||||
|
<a class="float-right btn btn-primary btn-sm ml-2"
|
||||||
|
href="{{ url_for('threads.edit_reply', id=thread.id, reply=r.id) }}">
|
||||||
|
<i class="fas fa-edit"></i>
|
||||||
|
</a>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
{% if r.checkPerm(current_user, "DELETE_REPLY") %}
|
{% if r.checkPerm(current_user, "DELETE_REPLY") %}
|
||||||
<a class="float-right btn btn-secondary btn-sm"
|
<a class="float-right btn btn-secondary btn-sm ml-2"
|
||||||
href="{{ url_for('threads.delete_reply', id=thread.id, reply=r.id) }}">
|
href="{{ url_for('threads.delete_reply', id=thread.id, reply=r.id) }}">
|
||||||
<i class="fas fa-trash"></i>
|
<i class="fas fa-trash"></i>
|
||||||
</a>
|
</a>
|
||||||
|
17
app/templates/threads/edit_reply.html
Normal file
17
app/templates/threads/edit_reply.html
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
{% extends "base.html" %}
|
||||||
|
|
||||||
|
{% block title %}
|
||||||
|
{{ _("Edit reply") }} - {{ thread.title }}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
|
{% block content %}
|
||||||
|
<h1>{{ _("Edit reply") }}</h1>
|
||||||
|
|
||||||
|
{% from "macros/forms.html" import render_field, render_submit_field %}
|
||||||
|
<form method="POST" action="" enctype="multipart/form-data">
|
||||||
|
{{ form.hidden_tag() }}
|
||||||
|
|
||||||
|
{{ render_field(form.comment, label="", class_="m-0", fieldclass="form-control markdown") }} <br />
|
||||||
|
{{ render_submit_field(form.submit) }}
|
||||||
|
</form>
|
||||||
|
{% endblock %}
|
Loading…
Reference in New Issue
Block a user