44 lines
1.2 KiB
Plaintext
44 lines
1.2 KiB
Plaintext
|
<.header>
|
||
|
Listing Todos
|
||
|
<:actions>
|
||
|
<.link patch={~p"/todos/new"}>
|
||
|
<.button>New Todo</.button>
|
||
|
</.link>
|
||
|
</:actions>
|
||
|
</.header>
|
||
|
|
||
|
<.table
|
||
|
id="todos"
|
||
|
rows={@streams.todos}
|
||
|
row_click={fn {_id, todo} -> JS.navigate(~p"/todos/#{todo}") end}
|
||
|
>
|
||
|
<:col :let={{_id, todo}} label="Description"><%= todo.description %></:col>
|
||
|
<:col :let={{_id, todo}} label="Emoji"><%= todo.emoji %></:col>
|
||
|
<:col :let={{_id, todo}} label="Completed at"><%= todo.completed_at %></:col>
|
||
|
<:action :let={{_id, todo}}>
|
||
|
<div class="sr-only">
|
||
|
<.link navigate={~p"/todos/#{todo}"}>Show</.link>
|
||
|
</div>
|
||
|
<.link patch={~p"/todos/#{todo}/edit"}>Edit</.link>
|
||
|
</:action>
|
||
|
<:action :let={{id, todo}}>
|
||
|
<.link
|
||
|
phx-click={JS.push("delete", value: %{id: todo.id}) |> hide("##{id}")}
|
||
|
data-confirm="Are you sure?"
|
||
|
>
|
||
|
Delete
|
||
|
</.link>
|
||
|
</:action>
|
||
|
</.table>
|
||
|
|
||
|
<.modal :if={@live_action in [:new, :edit]} id="todo-modal" show on_cancel={JS.patch(~p"/todos")}>
|
||
|
<.live_component
|
||
|
module={HomemanWeb.TodoLive.FormComponent}
|
||
|
id={@todo.id || :new}
|
||
|
title={@page_title}
|
||
|
action={@live_action}
|
||
|
todo={@todo}
|
||
|
patch={~p"/todos"}
|
||
|
/>
|
||
|
</.modal>
|