cannery/lib/cannery_web/live/container_live/form_component.ex

136 lines
4.4 KiB
Elixir
Raw Normal View History

2021-09-02 23:31:14 -04:00
defmodule CanneryWeb.ContainerLive.FormComponent do
2022-01-22 21:40:29 -05:00
@moduledoc """
Livecomponent that can update or create an Cannery.Containers.Container
"""
2021-09-02 23:31:14 -04:00
use CanneryWeb, :live_component
2022-02-10 23:36:31 -05:00
alias Cannery.{Accounts.User, Containers, Containers.Container}
2022-02-01 00:22:44 -05:00
alias Ecto.Changeset
2022-02-10 23:36:31 -05:00
alias Phoenix.LiveView.Socket
2021-09-02 23:31:14 -04:00
@impl true
2022-02-10 23:36:31 -05:00
@spec update(
%{:container => Container.t(), :current_user => User.t(), optional(any) => any},
Socket.t()
) :: {:ok, Socket.t()}
2021-09-02 23:31:14 -04:00
def update(%{container: container} = assigns, socket) do
2022-02-11 00:33:51 -05:00
{:ok, socket |> assign(assigns) |> assign(:changeset, Containers.change_container(container))}
2021-09-02 23:31:14 -04:00
end
@impl true
2022-02-11 00:33:51 -05:00
def handle_event(
"validate",
%{"container" => container_params},
%{assigns: %{container: container}} = socket
) do
changeset = container |> Containers.change_container(container_params)
2021-09-02 23:31:14 -04:00
{:noreply, socket |> assign(:changeset, changeset)}
end
2022-02-11 00:33:51 -05:00
def handle_event(
"save",
%{"container" => container_params},
%{assigns: %{action: action}} = socket
) do
save_container(socket, action, container_params)
2021-09-02 23:31:14 -04:00
end
@impl true
def render(assigns) do
~H"""
<div>
2022-02-05 00:09:22 -05:00
<h2 class="text-center title text-xl text-primary-500">
2022-01-22 17:21:10 -05:00
<%= @title %>
</h2>
<.form
let={f}
for={@changeset}
id="container-form"
2022-01-31 21:42:24 -05:00
class="grid grid-cols-3 justify-center items-center space-y-4"
phx-target={@myself}
phx-change="validate"
2022-01-31 21:42:24 -05:00
phx-submit="save"
>
<%= if @changeset.action do %>
<div class="invalid-feedback col-span-3 text-center">
<%= changeset_errors(@changeset) %>
</div>
<% end %>
2022-02-09 00:49:47 -05:00
<%= label(f, :name, gettext("Name"), class: "title text-lg text-primary-500") %>
2022-01-31 21:42:24 -05:00
<%= text_input(f, :name,
class: "input input-primary col-span-2",
2022-02-09 00:49:47 -05:00
placeholder: gettext("My cool ammo can")
2022-01-31 21:42:24 -05:00
) %>
<%= error_tag(f, :name, "col-span-3 text-center") %>
2022-02-09 00:49:47 -05:00
<%= label(f, :desc, gettext("Description"), class: "title text-lg text-primary-500") %>
2022-01-31 21:42:24 -05:00
<%= textarea(f, :desc,
class: "input input-primary col-span-2",
phx_hook: "MaintainAttrs",
2022-02-09 00:49:47 -05:00
placeholder: gettext("Metal ammo can with the anime girl sticker")
2022-01-31 21:42:24 -05:00
) %>
<%= error_tag(f, :desc, "col-span-3 text-center") %>
2022-02-09 00:49:47 -05:00
<%= label(f, :type, gettext("Type"), class: "title text-lg text-primary-500") %>
2022-01-31 21:42:24 -05:00
<%= text_input(f, :type,
class: "input input-primary col-span-2",
2022-02-09 00:49:47 -05:00
placeholder: gettext("Magazine, Clip, Ammo Box, etc")
2022-01-31 21:42:24 -05:00
) %>
<%= error_tag(f, :type, "col-span-3 text-center") %>
2022-02-09 00:49:47 -05:00
<%= label(f, :location, gettext("Location"), class: "title text-lg text-primary-500") %>
2022-01-31 21:42:24 -05:00
<%= textarea(f, :location,
class: "input input-primary col-span-2",
phx_hook: "MaintainAttrs",
2022-02-09 00:49:47 -05:00
placeholder: gettext("On the bookshelf")
2022-01-31 21:42:24 -05:00
) %>
<%= error_tag(f, :location, "col-span-3 text-center") %>
2022-02-09 00:49:47 -05:00
<%= submit(dgettext("actions", "Save"),
2022-01-31 21:42:24 -05:00
class: "mx-auto btn btn-primary col-span-3",
2022-02-09 00:49:47 -05:00
phx_disable_with: dgettext("prompts", "Saving...")
2022-01-31 21:42:24 -05:00
) %>
</.form>
</div>
"""
end
2022-02-11 00:33:51 -05:00
defp save_container(
%{assigns: %{container: container, current_user: current_user, return_to: return_to}} =
socket,
:edit,
container_params
) do
socket =
case Containers.update_container(container, current_user, container_params) do
{:ok, %{name: container_name}} ->
prompt = dgettext("prompts", "%{name} updated successfully", name: container_name)
socket |> put_flash(:info, prompt) |> push_redirect(to: return_to)
{:error, %Changeset{} = changeset} ->
socket |> assign(:changeset, changeset)
end
{:noreply, socket}
2021-09-02 23:31:14 -04:00
end
2022-02-11 00:33:51 -05:00
defp save_container(
%{assigns: %{current_user: current_user, return_to: return_to}} = socket,
:new,
container_params
) do
socket =
case Containers.create_container(container_params, current_user) do
{:ok, %{name: container_name}} ->
prompt = dgettext("prompts", "%{name} created successfully", name: container_name)
socket |> put_flash(:info, prompt) |> push_redirect(to: return_to)
{:error, %Changeset{} = changeset} ->
socket |> assign(changeset: changeset)
end
{:noreply, socket}
2021-09-02 23:31:14 -04:00
end
end