2022-11-17 22:38:52 -05:00
|
|
|
<div class="mx-auto flex flex-col justify-center items-stretch space-y-4 max-w-3xl">
|
|
|
|
<h1 class="text-xl">
|
2022-11-26 14:51:18 -05:00
|
|
|
<%= @note.slug %>
|
2022-11-17 22:38:52 -05:00
|
|
|
</h1>
|
|
|
|
|
2022-12-15 22:33:10 -05:00
|
|
|
<div class="flex flex-wrap space-x-1">
|
2023-02-04 11:29:06 -05:00
|
|
|
<.link
|
|
|
|
:for={tag <- @note.tags}
|
|
|
|
navigate={Routes.note_index_path(Endpoint, :search, tag)}
|
|
|
|
class="link"
|
|
|
|
>
|
|
|
|
<%= tag %>
|
|
|
|
</.link>
|
2022-12-15 22:33:10 -05:00
|
|
|
</div>
|
2022-11-17 22:38:52 -05:00
|
|
|
|
2022-12-15 22:43:18 -05:00
|
|
|
<.note_content note={@note} />
|
2022-11-17 22:38:52 -05:00
|
|
|
|
|
|
|
<p class="self-end">
|
|
|
|
<%= gettext("Visibility: %{visibility}", visibility: @note.visibility) %>
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<div class="self-end flex space-x-4">
|
2022-11-24 17:15:10 -05:00
|
|
|
<.link class="btn btn-primary" navigate={Routes.note_index_path(@socket, :index)}>
|
2022-11-24 12:43:34 -05:00
|
|
|
<%= dgettext("actions", "back") %>
|
2022-11-17 22:38:52 -05:00
|
|
|
</.link>
|
2023-02-04 11:29:06 -05:00
|
|
|
<.link
|
|
|
|
:if={is_owner?(@note, @current_user)}
|
|
|
|
class="btn btn-primary"
|
|
|
|
patch={Routes.note_show_path(@socket, :edit, @note.slug)}
|
|
|
|
>
|
|
|
|
<%= dgettext("actions", "edit") %>
|
|
|
|
</.link>
|
|
|
|
<button
|
|
|
|
:if={is_owner_or_admin?(@note, @current_user)}
|
|
|
|
type="button"
|
|
|
|
class="btn btn-primary"
|
|
|
|
phx-click="delete"
|
|
|
|
data-confirm={dgettext("prompts", "are you sure?")}
|
2023-03-14 23:51:50 -04:00
|
|
|
aria-label={gettext("delete %{note_slug}", note_slug: @note.slug)}
|
2023-02-04 11:29:06 -05:00
|
|
|
>
|
|
|
|
<%= dgettext("actions", "delete") %>
|
|
|
|
</button>
|
2022-11-17 22:38:52 -05:00
|
|
|
</div>
|
|
|
|
</div>
|
2022-07-25 20:08:40 -04:00
|
|
|
|
2023-02-04 11:29:06 -05:00
|
|
|
<.modal :if={@live_action == :edit} return_to={Routes.note_show_path(@socket, :show, @note.slug)}>
|
|
|
|
<.live_component
|
|
|
|
module={MemexWeb.NoteLive.FormComponent}
|
|
|
|
id={@note.id}
|
|
|
|
current_user={@current_user}
|
|
|
|
title={@page_title}
|
|
|
|
action={@live_action}
|
|
|
|
note={@note}
|
|
|
|
return_to={Routes.note_show_path(@socket, :show, @note.slug)}
|
|
|
|
/>
|
|
|
|
</.modal>
|