Add permalinks to the static-fe notice rendering.
This commit is contained in:
parent
d1320160f4
commit
c1fc139986
|
@ -7,18 +7,21 @@ defmodule Pleroma.Web.StaticFE.ActivityRepresenter do
|
||||||
alias Pleroma.Object
|
alias Pleroma.Object
|
||||||
alias Pleroma.User
|
alias Pleroma.User
|
||||||
alias Pleroma.Web.ActivityPub.Visibility
|
alias Pleroma.Web.ActivityPub.Visibility
|
||||||
|
alias Pleroma.Web.Router.Helpers
|
||||||
|
|
||||||
def prepare_activity(%User{} = user, %Object{} = object) do
|
def prepare_activity(%User{} = user, %Object{} = object, activity_id) do
|
||||||
%{}
|
%{}
|
||||||
|> set_user(user)
|
|> set_user(user)
|
||||||
|> set_object(object)
|
|> set_object(object)
|
||||||
|> set_title(object)
|
|> set_title(object)
|
||||||
|> set_content(object)
|
|> set_content(object)
|
||||||
|
|> set_link(activity_id)
|
||||||
|
|> set_published(object)
|
||||||
|> set_attachments(object)
|
|> set_attachments(object)
|
||||||
end
|
end
|
||||||
|
|
||||||
def prepare_activity(%User{} = user, %Activity{} = activity),
|
def prepare_activity(%User{} = user, %Activity{} = activity),
|
||||||
do: prepare_activity(user, Object.normalize(activity.data["object"]))
|
do: prepare_activity(user, Object.normalize(activity.data["object"]), activity.id)
|
||||||
|
|
||||||
defp set_user(data, %User{} = user), do: Map.put(data, :user, user)
|
defp set_user(data, %User{} = user), do: Map.put(data, :user, user)
|
||||||
|
|
||||||
|
@ -37,6 +40,12 @@ defp set_content(data, %Object{data: %{"content" => content}}) when is_binary(co
|
||||||
|
|
||||||
defp set_content(data, _), do: Map.put(data, :content, nil)
|
defp set_content(data, _), do: Map.put(data, :content, nil)
|
||||||
|
|
||||||
|
defp set_link(data, activity_id),
|
||||||
|
do: Map.put(data, :link, Helpers.o_status_url(Pleroma.Web.Endpoint, :notice, activity_id))
|
||||||
|
|
||||||
|
defp set_published(data, %Object{data: %{"published" => published}}),
|
||||||
|
do: Map.put(data, :published, published)
|
||||||
|
|
||||||
# TODO: attachments
|
# TODO: attachments
|
||||||
defp set_attachments(data, _), do: Map.put(data, :attachments, [])
|
defp set_attachments(data, _), do: Map.put(data, :attachments, [])
|
||||||
|
|
||||||
|
@ -45,7 +54,7 @@ def represent(activity_id) do
|
||||||
true <- Visibility.is_public?(activity),
|
true <- Visibility.is_public?(activity),
|
||||||
%Object{} = object <- Object.normalize(activity.data["object"]),
|
%Object{} = object <- Object.normalize(activity.data["object"]),
|
||||||
%User{} = user <- User.get_or_fetch(activity.data["actor"]),
|
%User{} = user <- User.get_or_fetch(activity.data["actor"]),
|
||||||
data <- prepare_activity(user, object) do
|
data <- prepare_activity(user, object, activity_id) do
|
||||||
{:ok, data}
|
{:ok, data}
|
||||||
else
|
else
|
||||||
e ->
|
e ->
|
||||||
|
|
|
@ -1,13 +1,15 @@
|
||||||
<div class="activity">
|
<div class="activity">
|
||||||
<%= render("user_card.html", %{user: @data.user}) %>
|
<%= render("user_card.html", %{user: @data.user}) %>
|
||||||
<div class="activity-content">
|
<div class="activity-content">
|
||||||
<%= if @data.title do %>
|
<%= if @data.title != "" do %>
|
||||||
<details>
|
<details>
|
||||||
<summary><%= raw @data.title %></summary>
|
<summary><%= raw @data.title %></summary>
|
||||||
<% end %>
|
<% end %>
|
||||||
<div class="e-content"><%= raw @data.content %></div>
|
<div class="e-content"><%= raw @data.content %></div>
|
||||||
<%= if @data.title do %>
|
<%= if @data.title != "" do %>
|
||||||
</details>
|
</details>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
<p class="pull-right">
|
||||||
|
<a href="<%= @data.link %>" class="activity-link"><%= @data.published %></a></p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue