Files
wish/lib/wish_web/live/home_live/index.ex

68 lines
1.7 KiB
Elixir

defmodule WishWeb.HomeLive.Index do
use WishWeb, :live_view
alias Wish.Wishlist
use Phoenix.Component
@impl true
def mount(_params, session, socket) do
grid? =
case Map.get(session, "user_display", "grid") do
"grid" -> true
_ -> false
end
{:ok, assign(socket, :items, Wishlist.list_items()) |> assign(:grid, grid?)}
end
@impl true
def handle_event("toggle_view_state", _, socket) do
{:noreply, assign(socket, :grid, !socket.assigns.grid)}
end
@impl true
def handle_event("toggle_received", %{"id" => id}, socket) do
item = Wishlist.get_item!(id)
case Wishlist.toggle_received(item) do
{:ok, updated_item} ->
index = Enum.find_index(socket.assigns.items, &(&1.id == updated_item.id))
updated_list = List.update_at(socket.assigns.items, index, fn _ -> updated_item end)
{:noreply, assign(socket, :items, updated_list)}
{:error, _} ->
{:noreply, socket}
end
end
attr :item, :any
def dropdown(assigns) do
~H"""
<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
>
<.link
href={@item.url}
class="block p-1 w-full border border-white hover:bg-slate-100 hover:border-black select-none"
target="_blank"
>
Go to URL
</.link>
<div
class="block p-1 w-full border border-white hover:bg-slate-100 hover:border-black select-none cursor-pointer"
phx-click={
JS.push("toggle_received", value: %{"id" => @item.id})
|> JS.hide(to: "#dropdown-#{@item.id}")
}
>
Mark received
</div>
</div>
"""
end
end