mirror of
https://github.com/fly-apps/live_beats.git
synced 2025-01-07 05:55:24 +00:00
45 lines
1.2 KiB
Elixir
45 lines
1.2 KiB
Elixir
|
defmodule LiveBeatsWeb.LayoutComponent do
|
||
|
@moduledoc """
|
||
|
Component for rendering content inside layout without full DOM patch.
|
||
|
"""
|
||
|
use LiveBeatsWeb, :live_component
|
||
|
|
||
|
def show_modal(module, attrs) do
|
||
|
send_update(__MODULE__, id: "layout", show: Enum.into(attrs, %{module: module}))
|
||
|
end
|
||
|
|
||
|
def hide_modal do
|
||
|
send_update(__MODULE__, id: "layout", show: nil)
|
||
|
end
|
||
|
|
||
|
def update(%{id: id} = assigns, socket) do
|
||
|
show =
|
||
|
case assigns[:show] do
|
||
|
%{module: _module, confirm: {text, attrs}} = show ->
|
||
|
show
|
||
|
|> Map.put_new(:patch_to, nil)
|
||
|
|> Map.put_new(:redirect_to, nil)
|
||
|
|> Map.merge(%{confirm_text: text, confirm_attrs: attrs})
|
||
|
|
||
|
nil ->
|
||
|
nil
|
||
|
end
|
||
|
|
||
|
{:ok, assign(socket, id: id, show: show)}
|
||
|
end
|
||
|
|
||
|
def render(assigns) do
|
||
|
~H"""
|
||
|
<div class={unless @show, do: "hidden"}>
|
||
|
<%= if @show do %>
|
||
|
<.modal show id={@id} redirect_to={@show.redirect_to} patch_to={@show.patch_to}>
|
||
|
<.live_component module={@show.module} {@show} />
|
||
|
<:cancel>Cancel</:cancel>
|
||
|
<:confirm {@show.confirm_attrs}><%= @show.confirm_text %></:confirm>
|
||
|
</.modal>
|
||
|
<% end %>
|
||
|
</div>
|
||
|
"""
|
||
|
end
|
||
|
end
|