Files
wish/lib/wish_web/live/home_live/index.html.heex

61 lines
1.4 KiB
Plaintext

<.header>
Listing Items
<:actions>
<.button phx-click="toggle">
Toggle Display
</.button>
</:actions>
</.header>
<div
class={
case @display do
:grid -> "grid grid-cols-3 gap-2"
:row -> ""
end
}
id="items-grid"
>
<div
:for={item <- @items}
phx-click={JS.navigate(~p"/details/#{item}")}
class={[
"p-2 rounded hover:bg-zinc-100 active:bg-zinc-200",
case @display do
:grid -> "h-72"
:row -> "flex flex-row h-24"
end
]}
>
<div class="aspect-square flex flex-col justify-center">
<img
:if={item.image_url}
src={item.image_url}
alt={item.title}
height="224"
width="224"
class="rounded"
/>
</div>
<%= if item.received do %>
<div class="bg-red-400 text-white">
<.icon name="hero-check-circle" />Received
</div>
<% end %>
<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 bg-white origin-top right-0 whitespace-nowrap"
phx-click={JS.push("toggle_received", value: %{"id" => item.id})}
hidden
>
Mark visible
</div>
</div>
</div>
</div>
</div>