Add permalinks to the static-fe notice rendering.

This commit is contained in:
Phil Hagelberg 2019-10-27 16:37:57 -07:00
parent d1320160f4
commit c1fc139986
2 changed files with 16 additions and 5 deletions

View file

@ -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 ->

View file

@ -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>