2021-07-21 01:12:26 +00:00
{% macro single_comment(c, level=1) %}
<!-- - beginning of comment {{c.id}} - -->
< script >
var date = new Date('{{c.created_datetime}}');
document.getElementById('timestamp-{{c.id}}').title = date.toString();
< / script >
{% set ups=c.upvotes %}
{% set downs=c.downvotes %}
{% set score=ups-downs %}
{% include "emoji_modal.html" %}
<!-- conditions under which a comment might be hidden -->
2021-07-26 01:26:04 +00:00
{% if (c.is_banned or c.deleted_utc > 0 or c.is_blocking or c.is_blocked) and not (v and v.admin_level>0) and not (v and v.id==c.author_id) %}
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< div id = "comment-{{c.id}}" class = "comment" >
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< span class = "comment-collapse-desktop d-none d-md-block" style = "border-left: 2px solid #{{c.author.namecolor}};" onclick = "collapse_comment('{{c.id}}')" > < / span >
2021-07-21 01:12:26 +00:00
< div class = "comment-body" >
2021-07-30 05:31:38 +00:00
< div id = "comment-{{c.id}}-only" class = "" >
2021-07-21 01:12:26 +00:00
< div class = "user-info" >
2021-07-30 05:31:38 +00:00
< span class = "comment-collapse d-md-none" onclick = "collapse_comment('{{c.id}}')" > < / span >
2021-07-21 01:12:26 +00:00
{% if standalone and c.over_18 %}< span class = "badge badge-danger" > +18< / span > {% endif %}
[{% if c.is_banned %}Removed by admins{% elif c.deleted_utc > 0 %}Deleted by author{% elif c.is_blocking %}You are blocking @{{c.author.username}}{% elif c.is_blocked %}This user has blocked you{% endif %}]
< / div >
< div id = "comment-banned-warning" class = "comment-text text-danger text-small" >
{% if c.is_banned and c.ban_reason %}Reason: {{c.ban_reason}}{% endif %}
< / div >
< / div >
{% if render_replies %}
{% if level< 6 % }
2021-07-30 05:31:38 +00:00
< div id = "replies-of-{{c.id}}" class = "" >
2021-07-21 01:12:26 +00:00
{% set standalone=False %}
{% for reply in c.children(v) %}
{{single_comment(reply, level=level+1)}}
{% endfor %}
< / div >
{% elif c.children(v) %}
2021-07-30 05:31:38 +00:00
< div id = "replies-of-{{c.id}}" class = "d-none d-md-block" >
2021-07-21 01:12:26 +00:00
{% set standalone=False %}
{% for reply in c.children(v) %}
{{single_comment(reply, level=level+1)}}
{% endfor %}
< / div >
2021-07-30 05:31:38 +00:00
< div id = "morecomment-{{c.id}}" class = "d-block d-md-none mt-2 more-comments text-small" >
2021-07-21 01:12:26 +00:00
< a href = "{{c.permalink}}" { % if c . author . is_private % } rel = "nofollow" { % endif % } > More comments < i class = "fas fa-long-arrow-right ml-1" > < / i > < / a >
< / div >
{% endif %}
{% endif %}
< / div >
< / div >
{% else %}
{% set score=c.score %}
{% if v %}
2021-08-06 12:44:24 +00:00
{% set voted=c.voted %}
2021-07-21 01:12:26 +00:00
{% else %}
{% set voted=-2 %}
{% endif %}
{% if standalone and level==1 %}
< div class = "post-info mt-5 mb-1 mr-2" >
{% if c.post and c.post.over_18 %}< span class = "badge badge-danger text-small-extra mr-1" > +18< / span > {% endif %}
< span class = "align-top" >
{% if c.parent_submission %}
{% if c.author_id==v.id and c.child_comments and is_notification_page%}
< span class = "font-weight-bold" > Comment {{'Replies' if (c.child_comments | length)>1 else 'Reply'}}: < a href = "{{c.post.permalink}}" > {{c.post.title | safe}}< / a > < / span >
2021-07-25 21:59:20 +00:00
{% elif c.post.author_id==v.id and c.level == 1 and is_notification_page%}
2021-07-21 01:12:26 +00:00
< span class = "font-weight-bold" > Post Reply: < a href = "{{c.post.permalink}}" > {{c.post.title | safe}}< / a > < / span >
{% elif is_notification_page and c.parent_submission in v.subscribed_idlist() %}
< span class = "font-weight-bold" > Subscribed Thread: < a href = "{{c.post.permalink}}" > {{c.post.title | safe}}< / a > < / span >
{% elif is_notification_page %}
< span class = "font-weight-bold" > Username Mention: < a href = "{{c.post.permalink}}" > {{c.post.title | safe}}< / a > < / span >
{% else %}
< span class = "font-weight-bold" > < a href = "{{c.post.permalink}}" > {{c.post.title | safe}}< / a > < / span >
{% endif %}
{% elif c.author_id==1046 or c.author_id==2360 %}
2021-08-03 06:17:48 +00:00
< span class = "font-weight-bold" > {{"SITE_NAME" | app_config}} Notification< / span >
2021-07-21 01:12:26 +00:00
{% else %}
< span class = "font-weight-bold" > Private Message< / span >
{% endif %}
< / span >
< / div >
{% endif %}
2021-07-30 05:31:38 +00:00
< div id = "comment-{{c.id}}" class = "comment {% if standalone and level==1 %} mt-0{% endif %}{% if c.collapse_for_user(v) or (standalone and c.over_18 and not (v and v.over_18)) %} collapsed{% endif %}" style = "border-left: 2px solid #{{c.author.namecolor}};" >
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< span class = "comment-collapse-desktop d-none d-md-block" style = "border-left: 2px solid #{{c.author.namecolor}};" onclick = "collapse_comment('{{c.id}}')" > < / span >
2021-07-21 01:12:26 +00:00
< div class = "comment-body" >
2021-07-30 05:31:38 +00:00
< div id = "{% if comment_info and comment_info.id == c.id %}context{%else%}comment-{{c.id}}-only{% endif %}" class = "{% if comment_info and comment_info.id == c.id %}context{%endif%}{% if c.is_banned %} banned{% endif %}{% if c.deleted_utc %} deleted{% endif %}" >
2021-07-21 01:12:26 +00:00
2021-07-29 07:29:23 +00:00
< div class = "user-info" >
2021-07-30 05:31:38 +00:00
< span class = "comment-collapse d-md-none" onclick = "collapse_comment('{{c.id}}')" > < / span >
2021-08-03 10:39:09 +00:00
{% if c.awards %}
{% for a in c.awards[:5] %}
< i class = "{{a.class_list}} px-1" data-toggle = "tooltip" data-placement = "bottom" title = "{{a.title}} Award given by @{{a.user.username}}" > < / i >
{% endfor %}
{% endif %}
2021-07-31 13:58:11 +00:00
{% if c.active_flags %} < a class = "btn btn-primary" style = "padding:1px 5px; font-size:10px;" href = "javascript:void(0)" onclick = "document.getElementById('flaggers-{{c.id}}').classList.toggle('d-none')" > {{c.active_flags}} Reports< / a > {% endif %}
2021-07-21 01:12:26 +00:00
{% if c.over_18 %}< span class = "badge badge-danger text-small-extra mr-1" > +18< / span > {% endif %}
{% if v and v.admin_level==6 and c.author.shadowbanned %}< i class = "fas fa-user-times text-admin" data-toggle = "tooltip" data-placement = "bottom" title = "Shadowbanned user" > < / i > {% endif %}
{% if c.is_pinned %}< i class = "text-admin fas fa-thumbtack fa-rotate--45" data-toggle = "tooltip" data-placement = "bottom" title = "" data-original-title = "Pinned comment" > < / i > {% endif %}
2021-08-03 06:17:48 +00:00
{% if c.distinguish_level %}< i class = "fas fa-broom text-admin" data-toggle = "tooltip" data-placement = "bottom" title = "" data-original-title = "{{" SITE_NAME " | app_config } } Badmin , speaking officially " > < / i > {% endif %}
2021-07-21 01:12:26 +00:00
{% if c.is_op %}< i class = "fas fa-microphone-stand text-info" data-toggle = "tooltip" data-placement = "bottom" title = "" data-original-title = "OP" > < / i > {% endif %}
{% if c.is_bot %}< i class = "fad fa-robot text-info" data-toggle = "tooltip" data-placement = "bottom" title = "" data-original-title = "Bot" > < / i > {% endif %}
2021-07-28 21:45:32 +00:00
{% if c.is_blocking %}< i class = "fas fa-user-minus text-warning" data-toggle = "tooltip" data-placement = "bottom" title = "" data-original-title = "{% if v and v.admin_level >= 2 %}You're blocking this user, but you can see this comment because {{'it\'s an admin comment' if c.distinguish_level else 'you\'re an admin'}}.{% else %}Comment author is banned{% endif %}" > < / i > {% endif %}
2021-07-21 10:58:23 +00:00
{% if c.is_blocked %}< i class = "fas fa-user-minus text-danger" data-toggle = "tooltip" data-placement = "bottom" title = "" data-original-title = "This user is blocking you, but you can see this comment because {{'it\'s an admin comment' if c.distinguish_level else 'you\'re an admin'}}." > < / i > {% endif %}
2021-07-21 01:12:26 +00:00
2021-07-28 02:46:49 +00:00
< a { % if c . author . animatedname % } class = "{% if c.author.patron %}patron{% else %}leaderboard{% endif %}" { % endif % } style = "color:#{{c.author.namecolor}}; font-size:12px; font-weight:bold;" href = "/@{{c.author.username}}" > < img src = "{{c.author.profile_url}}" class = "profile-pic-25 mr-2" / > {{c.author.username}}< / a > {% if c.author.customtitle %} < bdi style = "color: #{{c.author.titlecolor}}" > {{c.author.customtitle | safe}}< / bdi > {% endif %}
2021-07-21 01:12:26 +00:00
< span id = "timestamp-{{c.id}}" data-toggle = "tooltip" data-placement = "bottom" title = "" class = "time-stamp" > {{c.age_string}}< / span >
{% if c.edited_utc %}
< span class = "time-edited" > < span > · < / span > < span class = "font-italic" > Edited {{c.edited_string}}< / span > < / span >
{% endif %}
< / div >
{% if c.is_banned and c.ban_reason %}
< div id = "comment-banned-warning" class = "comment-text text-danger text-small mb-0" > Reason: {{c.ban_reason}}< / div >
{% endif %}
2021-07-30 05:31:38 +00:00
< div id = "comment-text-{{c.id}}" class = "comment-text mb-0" >
2021-07-21 01:12:26 +00:00
{{c.realbody(v) | safe}}
{% if not c.parent_submission and c.author_id!=1046 and c.author_id!=2360 and c.author_id!=v.id %}
2021-07-30 05:31:38 +00:00
< a class = "btn btn-primary" href = "javascript:void(0)" onclick = "document.getElementById('reply-to-{{c.id}}').classList.toggle('d-none')" > Reply< / a >
2021-07-21 01:12:26 +00:00
< pre > < / pre >
2021-07-30 05:31:38 +00:00
< form class = "d-none" id = "reply-to-{{c.id}}" action = "/@{{c.author.username}}/reply/{{c.id}}" method = "post" >
< textarea id = "input-message-{{c.id}}" form = "reply-to-{{c.id}}" name = "message" rows = "3" class = "form-control" required > < / textarea >
2021-07-21 01:12:26 +00:00
< pre > < / pre >
2021-07-30 05:31:38 +00:00
< pre class = "btn btn-secondary format d-inline-block m-0 fas fa-bold" aria-hidden = "true" onclick = "makeBold('input-message-{{c.id}}')" data-toggle = "tooltip" data-placement = "bottom" title = "Bold" > < / pre >
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< pre class = "btn btn-secondary format d-inline-block m-0 fas fa-italic" aria-hidden = "true" onclick = "makeItalics('input-message-{{c.id}}')" data-toggle = "tooltip" data-placement = "bottom" title = "Italicize" > < / pre >
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< pre class = "btn btn-secondary format d-inline-block m-0 fas fa-quote-right" aria-hidden = "true" onclick = "makeQuote('input-message-{{c.id}}')" data-toggle = "tooltip" data-placement = "bottom" title = "Quote" > < / pre >
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< pre style = "line-height:1;" class = "btn btn-secondary format d-inline-block m-0 font-weight-bolder text-uppercase" onclick = "commentForm('input-message-{{c.id}}');getGif()" aria-hidden = "true" data-toggle = "modal" data-target = "#gifModal" data-toggle = "tooltip" data-placement = "bottom" title = "Add GIF" > GIF< / pre >
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< pre class = "btn btn-secondary format d-inline-block m-0 fas fa-smile-beam" onclick = "loadEmojis('input-message-{{c.id}}')" aria-hidden = "true" data-toggle = "modal" data-target = "#emojiModal" data-toggle = "tooltip" data-placement = "bottom" title = "Add Emoji" > < / pre >
2021-07-21 01:12:26 +00:00
< input type = "submit" value = "Submit" class = "btn btn-primary mt-3" >
< / form >
{% endif %}
< / div >
{% if c.parent_submission %}
2021-07-25 21:59:20 +00:00
{% if v and v.id==c.author_id %}
2021-07-30 05:31:38 +00:00
< div id = "comment-edit-{{c.id}}" class = "d-none comment-write collapsed child" >
< form id = "comment-edit-form-{{c.id}}" action = "/edit_comment/{{c.id}}" method = "post" class = "input-group" enctype = "multipart/form-data" >
2021-07-21 01:12:26 +00:00
< input type = "hidden" name = "formkey" value = "{{v.formkey}}" >
2021-07-30 05:31:38 +00:00
< textarea id = "comment-edit-body-{{c.id}}" name = "body" form = "comment-edit-form-{{c.id}}" class = "comment-box form-control rounded" id = "edit-box-comment-{{c.id}}" aria-label = "With textarea" placeholder = "Add your comment..." rows = "3" > {{c.body}}< / textarea >
2021-07-21 01:12:26 +00:00
< div class = "comment-format" >
2021-07-30 05:31:38 +00:00
< small class = "btn btn-secondary format d-inline-block m-0" > < span class = "font-weight-bolder text-uppercase" aria-hidden = "true" onclick = "commentForm('comment-edit-body-{{c.id}}');getGif()" data-toggle = "modal" data-target = "#gifModal" data-toggle = "tooltip" data-placement = "bottom" title = "Add GIF" > GIF< / span > < / small >
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< small class = "btn btn-secondary format d-inline-block m-0" > < i class = "fas fa-smile-beam" aria-hidden = "true" onclick = "loadEmojis('comment-edit-body-{{c.id}}')" data-toggle = "modal" data-target = "#emojiModal" data-toggle = "tooltip" data-placement = "bottom" title = "Add Emoji" > < / i > < / small >
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< label class = "btn btn-secondary format d-inline-block m-0" for = "file-edit-reply-{{c.id}}" >
< div id = "filename-edit-reply-{{c.id}}" > < i class = "far fa-image" > < / i > < / div >
< input id = "file-edit-reply-{{c.id}}" type = "file" name = "file" accept = "image/*" onchange = "document.getElementById('filename-edit-reply-{{c.id}}').innerHTML='image';" hidden >
2021-07-21 01:12:26 +00:00
< / label >
2021-07-30 05:31:38 +00:00
< a id = "cancel-edit-{{c.id}}" href = "javascript:void(0)" onclick = "toggleEdit('{{c.id}}')" class = "d-none d-md-block btn btn-link text-muted ml-auto cancel-form" > Cancel< / a >
< a href = "javascript:void(0)" form = "comment-edit-form-{{c.id}}" class = "d-none d-md-block btn btn-primary ml-2" onclick = "comment_edit('{{c.id}}')" > Save Edit< / a >
2021-07-21 01:12:26 +00:00
< / div >
2021-07-30 05:31:38 +00:00
< a id = "cancel-edit-{{c.id}}" href = "javascript:void(0)" onclick = "toggleEdit('{{c.id}}')" class = "d-block d-md-none btn btn-link text-muted ml-auto cancel-form" > Cancel< / a >
< a href = "javascript:void(0)" form = "comment-edit-form-{{c.id}}" class = "d-block d-md-none btn btn-primary ml-2" onclick = "comment_edit('{{c.id}}')" > Save Edit< / a >
2021-07-21 01:12:26 +00:00
< / form >
< / div >
{% endif %}
2021-07-31 14:14:30 +00:00
{% if c.active_flags %}
2021-07-28 04:06:34 +00:00
< div id = "flaggers-{{c.id}}" class = "flaggers d-none" >
2021-07-28 02:46:49 +00:00
< strong > < i class = "far fa-fw fa-flag" > < / i > Reported by:< / strong >
2021-07-28 03:29:06 +00:00
< pre > < / pre >
2021-07-28 02:46:49 +00:00
< ul style = "padding-left:20px; margin-bottom: 0;" >
2021-07-31 13:56:17 +00:00
{% for f in c.ordered_flags %}
2021-08-01 15:25:31 +00:00
< li > < a style = "font-weight:bold" href = "{{f.user.url}}" > @{{f.user.username}}< / a > {% if f.reason %}: {{f.reason}}{% endif %}< / li >
2021-07-28 02:46:49 +00:00
{% endfor %}
< / ul >
< / div >
{% endif %}
2021-07-30 05:31:38 +00:00
< div id = "comment-{{c.id}}-actions" class = "comment-actions{% if voted==1 %} upvoted{% elif voted==-1 %} downvoted{% endif %}" >
2021-07-21 01:12:26 +00:00
< ul class = "list-inline text-right text-md-left" >
{% if v and request.path.startswith('/@') and v.admin_level == 0%}
{% if voted==1 %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item arrow-up d-none d-md-inline-block mr-2 comment-{{c.id}}-up active" > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
{% elif v %}
2021-07-30 05:31:38 +00:00
< li id = "comment-{{c.id}}-up" tabindex = "0" class = "list-inline-item arrow-up upvote-button d-none d-md-inline-block mr-2 comment-{{c.id}}-up {% if voted==1 %}active{% endif %}" data-id-up = "{{c.id}}" data-content-type = "comment" >
2021-07-21 01:12:26 +00:00
< / li >
{% else %}
2021-07-30 05:31:38 +00:00
< li id = "comment-{{c.id}}-up" tabindex = "0" class = "list-inline-item arrow-up d-none d-md-inline-block mr-2" onclick = "location.href='/login';" >
2021-07-21 01:12:26 +00:00
< / li >
{% endif %}
< li class = "list-inline-item d-none d-md-inline-block mr-2" >
2021-07-30 05:31:38 +00:00
< span class = "points" data-toggle = "tooltip" data-placement = "top" data-original-title = "+{{ups}} | -{{downs}}" > < span id = "comment-score-{{c.id}}" class = "score comment-score-{{c.id}} {% if voted==1 %}score-up{% elif voted==-1%}score-down{% endif %}" > {{score}}< / span > < / span >
2021-07-21 01:12:26 +00:00
< / li >
{% if v and request.path.startswith('/@') and v.admin_level == 0 %}
{% if voted==-1 %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item arrow-down d-none d-md-inline-block mr-2 comment-{{c.id}}-down active" > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
{% elif v %}
2021-07-30 05:31:38 +00:00
< li id = "comment-{{c.id}}-down" tabindex = "0" class = "list-inline-item arrow-down downvote-button d-none d-md-inline-block mr-2 comment-{{c.id}}-down {% if voted==-1 %}active{% endif %}" data-id-down = "{{c.id}}" data-content-type = "comment" >
2021-07-21 01:12:26 +00:00
< / li >
{% else %}
2021-07-30 05:31:38 +00:00
< li id = "comment-{{c.id}}-down" tabindex = "0" class = "list-inline-item arrow-down d-none d-md-inline-block" onclick = "location.href='/login';" >
2021-07-21 01:12:26 +00:00
< / li >
{% endif %}
2021-08-02 14:27:20 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "/votes?link={{c.fullname}}" > < i class = "fas fa-arrows-v" > < / i > Votes< / a > < / li >
2021-07-21 01:12:26 +00:00
{% if v and c.id in v.saved_comment_idlist() %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "javascript:void(0)" onclick = "post('/unsave_comment/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-save" > < / i > Unsave< / a > < / li >
2021-07-21 01:12:26 +00:00
{% else %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "javascript:void(0)" onclick = "post('/save_comment/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-save" > < / i > Save< / a > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
{% if v %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item text-muted" > < a href = "javascript:void(0)" onclick = "document.getElementById('reply-to-{{c.id}}').classList.remove('d-none')" > < i class = "fas fa-reply"
2021-07-21 01:12:26 +00:00
aria-hidden="true">< / i > < span class = "d-none d-md-inline-block" > Reply< / span > < / a > < / li >
2021-07-27 11:07:09 +00:00
{% if v.id!=c.author_id %}
2021-07-31 04:48:47 +00:00
< li class = "list-inline-item text-muted" > < a href = "javascript:void(0)" data-toggle = "modal" data-target = "#awardModal" onclick = "awardModal('/comment/{{c.id}}/awards')" > < i class = "fas fa-gift"
2021-07-27 11:07:09 +00:00
aria-hidden="true">< / i > < span class = "d-none d-md-inline-block" > Give Award< / span > < / a > < / li >
{% endif %}
2021-07-21 01:12:26 +00:00
{% endif %}
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "{{c.permalink}}?context=99#context" { % if c . author . is_private % } rel = "nofollow" { % endif % } > < i class = "fas fa-book-open" > < / i > Context< / a > < / li >
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "javascript:void(0);" role = "button" class = "copy-link" data-clipboard-text = "{{c.permalink | full_link}}?context=99#context" > < i class = "fas fa-copy" > < / i > Copy link< / a > < / li >
2021-07-29 07:29:23 +00:00
{% if v %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "javascript:void(0)" data-toggle = "modal" data-target = "#reportCommentModal" onclick = "report_commentModal('{{c.id}}','{{c.author.username}}',)" > < i class = "fas fa-flag fa-fw" > < / i > Report< / a > < / li >
2021-07-29 07:29:23 +00:00
{% else %}
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "javascript:void(0)" data-toggle = "modal" data-target = "#reportCommentModal" onclick = "" > < i class = "fas fa-flag fa-fw" > < / i > Flag< / a > < / li >
{% endif %}
2021-07-21 01:12:26 +00:00
2021-07-29 07:29:23 +00:00
{% if v and c.parent_submission and c.author_id==v.id %}
2021-07-21 01:12:26 +00:00
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "javascript:void(0)" onclick = "toggleEdit('{{c.id}}')" > < i class = "fas fa-edit fa-fw" > < / i > Edit< / a > < / li >
2021-07-21 01:12:26 +00:00
2021-07-29 07:29:23 +00:00
{% if c.deleted_utc > 0 %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "javascript:void(0)" onclick = "post('/undelete/comment/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-trash-alt fa-fw" > < / i > Undelete< / a > < / li >
2021-07-29 07:29:23 +00:00
{% else %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "javascript:void(0)" data-toggle = "modal" data-target = "#deleteCommentModal" onclick = "delete_commentModal('{{c.id}}')" > < i class = "fas fa-trash-alt fa-fw" > < / i > Delete< / a > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
2021-07-29 07:29:23 +00:00
{% endif %}
2021-07-28 21:31:50 +00:00
2021-07-29 07:33:27 +00:00
{% if v and v.admin_level==6 and v.id==c.author_id %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a id = "distinguish-{{c.id}}" href = "javascript:void(0)" onclick = "admin_comment('{{c.id}}')" > < i class = "fas fa-id-badge fa-fw" > < / i > {{'Undistinguish' if c.distinguish_level else 'Distinguish'}}< / a > < / li >
2021-07-29 07:33:27 +00:00
{% endif %}
2021-07-29 13:58:01 +00:00
{% if v and not v.id==c.author_id and v.admin_level == 0 %}
2021-07-29 07:33:27 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "javascript:void(0)" onclick = "post_toast('/settings/block?username={{c.author.username}}')" > < i class = "fas fa-eye-slash fa-fw" > < / i > Block user< / a > < / li >
{% endif %}
2021-07-31 11:14:11 +00:00
{% if v and c.post and (v.admin_level >= 1 or v.id == c.post.author_id) and c.level == 1 %}
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a class = "text-info" id = "pin-comment-{{c.id}}" href = "javascript:void(0)" data-dismiss = "modal" data-target = "#actionsModal-{{c.id}}" onclick = "post('/comment_pin/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-thumbtack fa-rotate--45 text-info fa-fw" > < / i > {{'Unpin' if c.is_pinned else 'Pin'}}< / a > < / li >
< / li >
{% endif %}
2021-07-29 07:33:27 +00:00
{% if v and v.admin_level>=3 %}
2021-07-31 11:07:00 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a class = "text-success" href = "javascript:void(0)" onclick = "approveComment('{{c.id}}')" > < i class = "fas fa-check text-success fa-fw" > < / i > Approve< / a > < / li >
2021-07-31 11:14:11 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a class = "text-danger" href = "javascript:void(0)" onclick = "removeComment('{{c.id}}')" > < i class = "fas fa-ban text-danger fa-fw" > < / i > Remove< / a > < / li >
{% endif %}
{% if v and c.parent_submission and (c.author_id==v.id or v.admin_level > 0) %}
< li class = "list-inline-item d-none d-md-inline-block" > < a class = "text-danger" href = "javascript:void(0)" onclick = "post('/toggle_comment_nsfw/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-eye-evil text-danger fa-fw" > < / i > Toggle +18< / a > < / li >
2021-07-29 07:33:27 +00:00
{% endif %}
2021-07-29 23:17:24 +00:00
{% if v and v.admin_level==6 and v.id != c.author_id %}
{% if c.author.is_banned %}
2021-07-31 11:07:00 +00:00
< li class = "list-inline-item d-none d-md-inline-block" > < a class = "text-success" id = "unexile-comment-{{c.id}}" href = "javascript:void(0)" onclick = "post_toast('/unban_user/{{c.author_id}}?toast=1')" > < i class = "fas fa-user-slash text-success fa-fw" > < / i > Unban user< / a > < / li >
2021-07-29 07:29:23 +00:00
{% else %}
2021-07-31 11:07:00 +00:00
< li class = "list-inline-item d-none d-md-inline-block" > < a class = "text-danger" id = "exile-comment-{{c.id}}" href = "javascript:void(0)" onclick = "post_toast('/ban_user/{{c.author_id}}?toast=1')" > < i class = "fas fa-user-slash text-danger fa-fw" > < / i > Ban user< / a > < / li >
2021-07-29 07:29:23 +00:00
{% endif %}
2021-07-29 23:17:24 +00:00
{% endif %}
2021-07-21 01:12:26 +00:00
2021-07-29 07:38:56 +00:00
{% if v and v.admin_level >=4 and c.oauth_app %}
2021-07-31 06:35:24 +00:00
< li class = "list-inline-item text-muted d-none d-md-inline-block" > < a href = "{{c.oauth_app.permalink}}/comments" > < i class = "fas fa-code fa-fw" > < / i > API App< / a > < / li >
2021-07-29 07:29:23 +00:00
{% endif %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item d-inline-block d-md-none" > < a href = "#" data-toggle = "modal" data-target = "#actionsModal-{{c.id}}" data-focus = "false" > < i class = "fas fa-ellipsis-h" > < / i > < / a > < / li >
2021-07-29 07:29:23 +00:00
{% if v and request.path.startswith('/@') and v.admin_level == 0 %}
2021-07-30 05:31:38 +00:00
{% if voted==1 %}< li class = "list-inline-item arrow-up d-inline-block d-md-none mr-2 comment-{{c.id}}-up active" > < / li > {% endif %}
2021-07-29 07:29:23 +00:00
{% elif v %}
2021-07-30 05:31:38 +00:00
< li id = "comment-{{c.id}}-up" tabindex = "0" class = "list-inline-item arrow-up upvote-button d-inline-block d-md-none mr-2 comment-{{c.id}}-up {% if voted==1 %}active{% endif %}" data-id-up = "{{c.id}}" data-content-type = "comment" > < / li >
2021-07-29 07:29:23 +00:00
{% else %}
2021-07-30 05:31:38 +00:00
< li id = "comment-{{c.id}}-up" tabindex = "0" class = "list-inline-item arrow-up d-inline-block d-md-none mr-2" onclick = "location.href='/login';" > < / li >
2021-07-29 07:29:23 +00:00
{% endif %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item d-inline-block d-md-none mr-2" > < span class = "points" data-toggle = "tooltip" data-placement = "top" data-original-title = "+{{ups}} | -{{downs}}" > < span id = "comment-score-{{c.id}}" class = "score comment-score-{{c.id}} {% if voted==1 %}score-up{% elif voted==-1%}score-down{% endif %}" > {{score}}< / span > < / span > < / li >
2021-07-29 07:29:23 +00:00
{% if v and request.path.startswith('/@') and v.admin_level == 0 %}
{% if voted==-1 %}
2021-07-30 05:31:38 +00:00
< li class = "list-inline-item arrow-down d-inline-block d-md-none mr-2 comment-{{c.id}}-up active" > < / li >
2021-07-29 07:29:23 +00:00
{% endif %}
{% elif v %}
2021-07-30 05:31:38 +00:00
< li id = "comment-{{c.id}}-down" tabindex = "0" class = "list-inline-item arrow-down downvote-button d-inline-block d-md-none mr-2 comment-{{c.id}}-down {% if voted==-1 %}active{% endif %}" data-id-down = "{{c.id}}" data-content-type = "comment" > < / li >
2021-07-29 07:29:23 +00:00
{% else %}
2021-07-30 05:31:38 +00:00
< li id = "comment-{{c.id}}-down" tabindex = "0" class = "list-inline-item arrow-down d-inline-block d-md-none" onclick = "location.href='/login';" > < / li >
2021-07-29 07:29:23 +00:00
{% endif %}
< / ul >
< / div >
{% endif %}
2021-07-21 01:12:26 +00:00
< / div >
2021-07-30 05:31:38 +00:00
< div id = "reply-to-{{c.id}}" class = "d-none" >
2021-07-29 07:29:23 +00:00
< div id = "comment-form-space-{{c.fullname}}" class = "comment-write collapsed child" >
2021-07-31 06:56:19 +00:00
< form id = "reply-to-t3_{{c.id}}" action = "/comment" method = "post" class = "input-group" enctype = "multipart/form-data" >
2021-07-29 07:29:23 +00:00
< input type = "hidden" name = "formkey" value = "{{v.formkey}}" >
< input type = "hidden" name = "parent_fullname" value = "{{c.fullname}}" >
2021-07-30 05:31:38 +00:00
< input id = "reply-form-submission-{{c.fullname}}" type = "hidden" name = "submission" value = "{{c.post.id}}" >
< textarea name = "body" form = "reply-to-t3_{{c.id}}" class = "comment-box form-control rounded" id = "reply-form-body-{{c.fullname}}" aria-label = "With textarea" placeholder = "Add your comment..." rows = "3" > < / textarea >
< div class = "comment-format" id = "comment-format-bar-{{c.id}}" >
2021-07-29 07:29:23 +00:00
< label class = "btn btn-secondary format d-inline-block m-0" for = "gif-reply-btn-{{c.fullname}}" >
< span id = "gif-reply-btn-{{c.fullname}}" class = "font-weight-bolder text-uppercase" onclick = "commentForm('reply-form-body-{{c.fullname}}');getGif()" aria-hidden = "true" data-toggle = "modal" data-target = "#gifModal" data-toggle = "tooltip" data-placement = "bottom" title = "Add GIF" > GIF< / span >
< / label >
< label class = "btn btn-secondary format d-inline-block m-0" for = "gif-reply-btn-{{c.fullname}}" >
< i id = "emoji-reply-btn-{{c.fullname}}" class = "fas fa-smile-beam" onclick = "loadEmojis('reply-form-body-{{c.fullname}}')" aria-hidden = "true" data-toggle = "modal" data-target = "#emojiModal" data-toggle = "tooltip" data-placement = "bottom" title = "Add Emoji" > < / i >
< / label >
< label class = "btn btn-secondary format d-inline-block m-0" for = "file-upload-reply-{{c.fullname}}" >
2021-07-30 05:31:38 +00:00
< div id = "filename-show-reply-{{c.id}}" > < i class = "far fa-image" > < / i > < / div >
< input id = "file-upload-reply-{{c.fullname}}" type = "file" name = "file" accept = "image/*" onchange = "document.getElementById('filename-show-reply-{{c.id}}').innerHTML='image';" hidden >
2021-07-29 07:29:23 +00:00
< / label >
2021-07-30 05:31:38 +00:00
< a href = "javascript:void(0)" onclick = "document.getElementById('reply-to-{{c.id}}').classList.add('d-none')" class = "d-none d-md-block btn btn-link text-muted ml-auto cancel-form" > Cancel< / a >
2021-07-29 07:29:23 +00:00
< a id = "save-reply-to-{{c.fullname}}" class = "d-none d-md-block btn btn-primary text-white ml-2" onclick = "post_comment('{{c.fullname}}');" href = "javascript:void(0)" > Comment< / a >
< / div >
2021-07-30 05:31:38 +00:00
< a href = "javascript:void(0)" onclick = "document.getElementById('reply-to-{{c.id}}').classList.add('d-none')" class = "d-block d-md-none btn btn-link text-muted ml-auto cancel-form" > Cancel< / a >
2021-07-29 07:29:23 +00:00
< a id = "save-reply-to-{{c.fullname}}" class = "d-block d-md-none btn btn-primary text-white ml-2" onclick = "post_comment('{{c.fullname}}');" href = "javascript:void(0)" > Comment< / a >
< / form >
< / div >
< / div >
2021-07-21 01:12:26 +00:00
2021-07-29 07:29:23 +00:00
{% if render_replies %}
2021-07-21 01:12:26 +00:00
{% if level< 6 % }
2021-07-30 05:31:38 +00:00
< div id = "replies-of-{{c.id}}" >
2021-07-21 01:12:26 +00:00
{% for reply in c.children(v) %}
{{single_comment(reply, level=level+1)}}
{% endfor %}
< / div >
{% elif c.children(v) %}
2021-07-30 05:31:38 +00:00
< div id = "replies-of-{{c.id}}" class = "d-none d-md-block" >
2021-07-21 01:12:26 +00:00
{% for reply in c.children(v) %}
{{single_comment(reply, level=level+1)}}
{% endfor %}
< / div >
2021-07-30 05:31:38 +00:00
< div id = "morecomment-{{c.id}}" class = "d-block d-md-none mt-2 more-comments text-small" >
2021-07-21 01:12:26 +00:00
< a href = "{{c.permalink}}" { % if c . author . is_private % } rel = "nofollow" { % endif % } > More comments < i class = "fas fa-long-arrow-right ml-1" > < / i > < / a >
< / div >
{% endif %}
2021-07-29 07:29:23 +00:00
{% endif %}
2021-07-21 01:12:26 +00:00
2021-07-29 07:29:23 +00:00
< / div >
2021-07-21 01:12:26 +00:00
<!-- Comment Actions Modal -->
2021-07-30 05:31:38 +00:00
< div class = "modal fade d-md-none" id = "actionsModal-{{c.id}}" tabindex = "-1" role = "dialog" aria-labelledby = "actionsModalTitle" aria-hidden = "true" >
2021-07-21 01:12:26 +00:00
< div class = "modal-dialog modal-dialog-centered" role = "document" >
< div class = "modal-content" >
< div class = "modal-header" >
< h5 class = "modal-title h6" > More options< / h5 >
< button type = "button" class = "close" data-dismiss = "modal" aria-label = "Close" >
< span aria-hidden = "true" > < i class = "far fa-times" > < / i > < / span >
< / button >
< / div >
< div class = "modal-body" >
< ul class = "list-group comment-actions" >
2021-08-02 14:27:20 +00:00
< li class = "list-group-item" > < a href = "/votes?link={{c.fullname}}" > < i class = "fas fa-arrows-v" > < / i > Votes< / a > < / li >
2021-07-21 01:12:26 +00:00
{% if v and c.id in v.saved_comment_idlist() %}
2021-07-30 05:31:38 +00:00
< li class = "list-group-item" > < a href = "javascript:void(0)" onclick = "post('/unsave_comment/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-save" > < / i > Unsave< / a > < / li >
2021-07-21 01:12:26 +00:00
{% else %}
2021-07-30 05:31:38 +00:00
< li class = "list-group-item" > < a href = "javascript:void(0)" onclick = "post('/save_comment/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-save" > < / i > Save< / a > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
< li class = "list-group-item" > < a href = "javascript:void(0);" role = "button" class = "d-block copy-link" data-dismiss = "modal" data-clipboard-text = "{{c.permalink | full_link}}?context=5#context" > < i class = "fas fa-copy" > < / i > < span > Copy link< / span > < / a > < / li >
< li class = "list-group-item" > < a href = "{{c.permalink}}?context=5#context" { % if c . author . is_private % } rel = "nofollow" { % endif % } > < i class = "fas fa-dna" > < / i > Context< / a > < / li >
2021-07-30 05:31:38 +00:00
< li class = "list-group-item" > < a href = "javascript:void(0)" data-toggle = "modal" data-dismiss = "modal" data-target = "#reportCommentModal" onclick = "report_commentModal('{{c.id}}','{{c.author.username}}')" class = "d-block" > < i class = "fas fa-flag" > < / i > Report< / a > < / li >
2021-07-21 01:12:26 +00:00
{% if v and c.parent_submission and c.author_id==v.id %}
2021-07-30 05:31:38 +00:00
< li class = "list-group-item" > < a href = "javascript:void(0)" data-dismiss = "modal" onclick = "toggleEdit('{{c.id}}')" class = "d-block" > < i class = "fas fa-edit" > < / i > Edit< / a > < / li >
2021-07-21 01:12:26 +00:00
{% if c.deleted_utc > 0 %}
2021-07-30 05:31:38 +00:00
< li class = "list-group-item" > < a class = "d-block" href = "javascript:void(0)" onclick = "post('/undelete/comment/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-trash-alt" > < / i > Undelete< / a > < / li >
2021-07-21 01:12:26 +00:00
{% else %}
2021-07-30 05:31:38 +00:00
< li class = "list-group-item" > < a class = "d-block" href = "javascript:void(0)" data-toggle = "modal" data-target = "#deleteCommentModal" onclick = "delete_commentModal('{{c.id}}')" > < i class = "fas fa-trash-alt" > < / i > Delete< / a > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
{% endif %}
2021-07-31 11:18:34 +00:00
{% if v and c.post and (v.admin_level >= 1 or v.id == c.post.author_id) and c.level == 1 %}
< li class = "list-group-item" > < a class = "d-block text-info" id = "pin-comment-{{c.id}}" href = "javascript:void(0)" data-dismiss = "modal" data-target = "#actionsModal-{{c.id}}" onclick = "post('/comment_pin/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-thumbtack fa-rotate--45 text-info" > < / i > {{'Unpin' if c.is_pinned else 'Pin'}}< / a >
< / li >
2021-07-21 01:12:26 +00:00
{% endif %}
{% if v %}
{% if v.admin_level>=1 and v.id==c.author_id %}
2021-07-31 10:40:11 +00:00
< li class = "list-group-item" > < a class = "d-block" id = "distinguish-{{c.id}}" href = "javascript:void(0)" onclick = "admin_comment('{{c.id}}')" > < i class = "fas fa-id-badge" > < / i > {{'Undistinguish' if c.distinguish_level else 'Distinguish'}}< / a > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
{% if v.admin_level>=3 %}
2021-07-31 11:03:17 +00:00
< li class = "list-group-item" > < a class = "text-success d-block" href = "javascript:void(0)" onclick = "approveComment('{{c.id}}')" > < i class = "fas fa-check text-success" > < / i > Approve< / a > < / li >
2021-07-31 11:18:34 +00:00
< li class = "list-group-item" > < a class = "text-danger d-block" href = "javascript:void(0)" onclick = "removeComment('{{c.id}}')" > < i class = "fas fa-ban text-danger" > < / i > Remove< / a > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
{% if v.admin_level >=4 and c.oauth_app %}
2021-07-31 11:03:17 +00:00
< li class = "list-group-item" > < a class = "d-block text-info" href = "{{c.oauth_app.permalink}}/comments" > < i class = "fas fa-code text-info" > < / i > API App< / a > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
2021-07-28 03:36:50 +00:00
{% if not v.id==c.author_id and v.admin_level == 0 %}
< li class = "list-group-item" >
2021-07-29 05:42:08 +00:00
< a class = "d-block" href = "javascript:void(0)" onclick = "post_toast('/settings/block?username={{c.author.username}}')" > < i class = "fas fa-eye-slash" > < / i > Block user< / a >
2021-07-28 03:36:50 +00:00
< / li >
2021-07-21 01:12:26 +00:00
{% endif %}
{% endif %}
2021-07-31 11:18:34 +00:00
{% if v and c.parent_submission and (c.author_id==v.id or v.admin_level > 0) %}
< li class = "list-group-item" > < a class = "text-danger d-block" href = "javascript:void(0)" onclick = "post('/toggle_comment_nsfw/{{c.id}}', function(){window.location.reload(true);})" > < i class = "fas fa-eye-evil text-danger" > < / i > Toggle +18< / a > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
2021-07-31 11:18:34 +00:00
2021-07-29 23:17:24 +00:00
{% if v and (c.post and v.admin_level == 6) %}
2021-07-25 22:21:24 +00:00
{% if c.author_id != v.id %}
2021-07-21 01:12:26 +00:00
{% if c.author.is_banned %}
2021-07-31 11:03:17 +00:00
< li class = "list-group-item" > < a class = "text-success d-block" id = "unexile-comment2-{{c.id}}" href = "javascript:void(0)" onclick = "post_toast('/unban_user/{{c.author_id}}?toast=1')" > < i class = "fas fa-user-minus fa-fw text-success" > < / i > Unban user< / a > < / li >
2021-07-21 01:12:26 +00:00
{% else %}
2021-07-31 11:03:17 +00:00
< li class = "list-group-item" > < a class = "text-danger d-block" id = "exile-comment2-{{c.id}}" href = "javascript:void(0)" onclick = "post_toast('/ban_user/{{c.author_id}}?toast=1')" > < i class = "fas fa-user-minus fa-fw text-danger" > < / i > Ban user< / a > < / li >
2021-07-21 01:12:26 +00:00
{% endif %}
{% endif %}
{% endif %}
< / ul >
< / div >
< / div >
< / div >
< / div >
< / div >
{% endif %}
{% endmacro %}
{% for comment in comments %}
{{single_comment(comment)}}
{% endfor %}
< div class = "toast" id = "toast-comment-success" style = "position: fixed; bottom: 1.5rem; margin: 0 auto; left: 0; right: 0; width: 275px; z-index: 1000" role = "alert" aria-live = "assertive" aria-atomic = "true" data-animation = "true" data-autohide = "true" data-delay = "5000" >
< div class = "toast-body bg-success text-center text-white" >
< i class = "fas fa-comment-alt-smile mr-2" > < / i > Comment posted!
< / div >
< / div >
< div class = "toast" id = "toast-comment-error" style = "position: fixed; bottom: 1.5rem; margin: 0 auto; left: 0; right: 0; width: 275px; z-index: 1000" role = "alert" aria-live = "assertive" aria-atomic = "true" data-animation = "true" data-autohide = "true" data-delay = "5000" >
< div class = "toast-body bg-danger text-center text-white" >
< i class = "fas fa-exclamation-circle mr-2" > < / i > < span id = "comment-error-text" > < / span >
< / div >
< / div >
< pre >
< / pre >
< / body >