add comment display

This commit is contained in:
byte[] 2019-10-04 20:51:56 -04:00
parent 4f0b549469
commit 0d74aa9ab0
5 changed files with 99 additions and 3 deletions

View file

@ -1,7 +1,8 @@
defmodule PhilomenaWeb.ImageController do
use PhilomenaWeb, :controller
alias Philomena.{Images.Image}
alias Philomena.{Images.Image, Comments.Comment}
alias Philomena.Repo
import Ecto.Query
plug ImageFilter
@ -23,6 +24,14 @@ defmodule PhilomenaWeb.ImageController do
end
def show(conn, %{"id" => _id}) do
render(conn, "show.html", image: conn.assigns.image)
comments =
Comment
|> where(image_id: ^conn.assigns.image.id)
|> preload([:user, :image])
|> order_by(desc: :created_at)
|> limit(25)
|> Repo.all()
render(conn, "show.html", image: conn.assigns.image, comments: comments)
end
end

View file

@ -0,0 +1,48 @@
article.block.communication id="comment_#{@comment.id}"
.block__content.flex.flex--no-wrap
.flex__fixed.spacing-right
/=<> user_avatar((comment.user if comment.user_visible?), 'avatar--100px', comment.author)
.flex__grow.communication__body
span.communication__body__sender-name = render PhilomenaWeb.UserAttributionView, "_anon_user.html", object: @comment
.communication__body__text
/- if comment.hidden_from_users
/ strong.comment_deleted
/ | Deletion reason:
/ =<> comment.deletion_reason
/ - if can?(:read, comment)
/ | (
/ = comment.deleted_by.try(:name) || 'Orbital Friendship Cannon'
/ | )
/ br
/ - if comment.destroyed_content
/ | This comment's contents have been destroyed.
/ br
/= if can?(:read, @comment)
= if !@comment.hidden_from_users do
=<> @comment.body
.block__content.communication__options
.flex.flex--wrap.flex--spaced-out
= render PhilomenaWeb.CommentView, "_comment_options.html", comment: @comment
/- if can?(:hide, Comment)
/ .js-staff-action
/ - if !comment.hidden_from_users && !comment.destroyed_content
/ =<> link_to '#', class: 'communication__interaction togglable-delete-form-link', 'data-click-toggle': "#inline-del-form-comment-#{comment.id}" do
/ i.fa.fa-times
/ =<> 'Delete'
/ - elsif comment.hidden_from_users && !comment.destroyed_content
/ =<> link_to image_comment_hide_path(comment.image, comment), data: { confirm: t('are_you_sure') }, method: :delete, class: 'communication__interaction' do
/ i.fa.fa-check
/ =<> 'Restore'
/ - if can?(:manage, Comment)
/ =<> link_to image_comment_path(comment.image, comment), method: :delete, data: { confirm: t('are_you_sure') }, class: 'communication__interaction' do
/ i.fa.fa-times
/ =<> 'Delete Contents'
/ - if can?(:manage, Comment)
/ .communication__info
/ =<> link_to_ip(comment.ip)
/ .communication__info
/ =<> link_to_fingerprint(comment.fingerprint, comment.user_agent)
/ = form_tag image_comment_hide_path(comment.image, comment), class: 'togglable-delete-form hidden flex', id: "inline-del-form-comment-#{comment.id}"
/ = text_field_tag :deletion_reason, nil, class: 'input input--wide', placeholder: 'Deletion Reason', id: "inline-del-reason-comment-#{comment.id}", required: true
/ = submit_tag 'Delete', class: 'button'

View file

@ -0,0 +1,31 @@
div
' Posted
=> pretty_time(@comment.created_at)
/=<> link_to new_report_path(reportable_class: 'Comment', reportable_id: comment.id), class: 'communication__interaction' do
/ i.fa.fa-flag
/ =<> 'Report'
/- if comment.edited_at && can?(:read, comment)
/ br
/ a href=image_comment_history_path(comment.image, comment)
/ | Edited
/ =<> friendly_time(comment.edited_at)
/ - if comment.edit_reason.present?
/ | because:
/ =<> comment.edit_reason
div
- link_path = "/images/#{@comment.image.id}#comment_#{@comment.id}"
a.communication__interaction title="Link to comment" href=link_path
i.fa.fa-link>
' Link
/=<> link_to link_path, 'data-author': safe_author(comment), 'data-reply-url': link_path, 'data-post': (comment.hidden_from_users ? '' : comment.body), class: 'communication__interaction post-reply post-reply-quote' do
a.communication__interaction.post-reply.post-reply-quote href=link_path data-reply-url=link_path data-author="" data-post=""
i.fa.fa-quote-right>
' Quote
/=<> link_to link_path, 'data-author': safe_author(comment), 'data-reply-url': link_path, class: 'communication__interaction post-reply' do
a.communication__interaction.post-reply href=link_path data-reply-url=link_path data-author=""
i.fa.fa-reply
' Reply
/span.owner-options.hidden
/ strong =<> link_to edit_image_comment_path(comment.image, comment), class: 'communication__interaction' do
/ i.fas.fa-edit
/ ' Edit

View file

@ -20,3 +20,8 @@
a href=@image.source_url = @image.source_url
- else
em> not provided yet
h4 Comments
#comments data-current-url="" data-loaded="true"
= for comment <- @comments do
= render PhilomenaWeb.CommentView, "_comment.html", comment: comment

View file

@ -0,0 +1,3 @@
defmodule PhilomenaWeb.CommentView do
use PhilomenaWeb, :view
end