105 lines
3.2 KiB
Plaintext
105 lines
3.2 KiB
Plaintext
<.header>
|
|
Listing Items
|
|
<:actions>
|
|
<.button phx-click={
|
|
JS.push("toggle_view_state")
|
|
|> JS.dispatch("toggle_view_state", detail: %{"grid" => !@grid})
|
|
}>
|
|
Toggle Display
|
|
</.button>
|
|
</:actions>
|
|
</.header>
|
|
|
|
<%= if @grid do %>
|
|
<div class="grid grid-cols-3 gap-2" id="items-grid">
|
|
<div
|
|
:for={item <- @items}
|
|
phx-click={JS.navigate(~p"/details/#{item}")}
|
|
class="h-72 p-2 rounded hover:bg-zinc-100 active:bg-zinc-200"
|
|
,
|
|
>
|
|
<div class="aspect-square relative flex flex-col justify-center">
|
|
<img
|
|
:if={item.image_url}
|
|
src={item.image_url}
|
|
alt={item.title}
|
|
height="224"
|
|
width="224"
|
|
class="rounded"
|
|
/>
|
|
<%= if item.received do %>
|
|
<div class="bg-red-400 text-white absolute w-full h-7 bottom-0">
|
|
<.icon name="hero-check-circle" />Received
|
|
</div>
|
|
<% end %>
|
|
</div>
|
|
<div class="flex flex-row justify-between">
|
|
<%= item.title %>
|
|
<div phx-click={JS.toggle(to: "#dropdown-#{item.id}")} class="relative">
|
|
<.icon name="hero-ellipsis-vertical" class="w-7 h-7" />
|
|
<div
|
|
id={"dropdown-#{item.id}"}
|
|
class="absolute z-10 w-40 bg-white origin-top right-0 whitespace-nowrap p-1 border rounded"
|
|
phx-click-away={JS.hide()}
|
|
hidden
|
|
>
|
|
<div
|
|
class="p-1 border border-white hover:bg-slate-100 hover:border-black select-none"
|
|
phx-click={
|
|
JS.push("toggle_received", value: %{"id" => item.id})
|
|
|> JS.hide(to: "#dropdown-#{item.id}")
|
|
}
|
|
>
|
|
Mark received
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<% else %>
|
|
<div class="flex flex-col space-y-4">
|
|
<div
|
|
:for={item <- @items}
|
|
class="grid grid-cols-8 grid-rows-4 h-24 p-1 border rounded"
|
|
phx-click={JS.navigate(~p"/details/#{item}")}
|
|
>
|
|
<div class="relative flex flex-col justify-center max-h-full h-full row-span-4">
|
|
<img
|
|
:if={item.image_url}
|
|
src={item.image_url}
|
|
alt={item.title}
|
|
class="max-h-full rounded"
|
|
/>
|
|
<%= if item.received do %>
|
|
<div class="absolute bg-red-400 text-xs text-white w-full h-7 bottom-0">
|
|
<.icon name="hero-check-circle" />Received
|
|
</div>
|
|
<% end %>
|
|
</div>
|
|
<div class="col-span-6 row-span-4 px-2">
|
|
<%= item.title %>
|
|
</div>
|
|
<div phx-click={JS.toggle(to: "#dropdown-#{item.id}")} class="relative">
|
|
<.icon name="hero-ellipsis-vertical" class="w-7 h-7" />
|
|
<div
|
|
id={"dropdown-#{item.id}"}
|
|
class="absolute z-10 w-40 bg-white origin-top right-0 whitespace-nowrap p-1 border rounded"
|
|
phx-click-away={JS.hide()}
|
|
hidden
|
|
>
|
|
<div
|
|
class="p-1 border border-white hover:bg-slate-100 hover:border-black select-none"
|
|
phx-click={
|
|
JS.push("toggle_received", value: %{"id" => item.id})
|
|
|> JS.hide(to: "#dropdown-#{item.id}")
|
|
}
|
|
>
|
|
Mark received
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<% end %>
|