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

107 lines
3.0 KiB
Elixir
Raw Normal View History

2021-09-02 23:31:14 -04:00
defmodule CanneryWeb.TagLive.FormComponent do
2022-01-22 21:40:29 -05:00
@moduledoc """
Livecomponent that can update or create an Cannery.Tags.Tag
"""
2021-09-02 23:31:14 -04:00
use CanneryWeb, :live_component
alias Cannery.Tags
@impl true
def update(%{tag: tag} = assigns, socket) do
changeset = Tags.change_tag(tag)
{:ok,
socket
|> assign(assigns)
|> assign(:changeset, changeset)}
end
@impl true
def handle_event("validate", %{"tag" => tag_params}, socket) do
2021-09-10 22:43:12 -04:00
tag_params = tag_params |> Map.put("user_id", socket.assigns.current_user.id)
2021-09-02 23:31:14 -04:00
changeset =
socket.assigns.tag
|> Tags.change_tag(tag_params)
|> Map.put(:action, :validate)
{:noreply, socket |> assign(:changeset, changeset)}
end
def handle_event("save", %{"tag" => tag_params}, socket) do
2021-09-10 22:43:12 -04:00
tag_params = tag_params |> Map.put("user_id", socket.assigns.current_user.id)
2021-09-02 23:31:14 -04:00
save_tag(socket, socket.assigns.action, tag_params)
end
@impl true
def render(assigns) do
~H"""
<div>
2022-01-28 21:05:54 -05:00
<h2 class="text-center title text-xl text-primary-500">
<%= @title %>
</h2>
2022-01-22 17:21:10 -05:00
<.form
let={f}
for={@changeset}
id="tag-form"
class="grid grid-cols-3 justify-center items-center space-y-4"
phx-target={@myself}
phx-change="validate"
2022-01-28 21:05:54 -05:00
phx-submit="save"
>
<%= label(f, :name, class: "title text-lg text-primary-500") %>
<%= text_input(f, :name, class: "input input-primary col-span-2") %>
<span class="col-span-3">
2022-01-22 17:21:10 -05:00
<%= error_tag(f, :name) %>
</span>
2022-01-22 17:21:10 -05:00
<%= label(f, :bg_color, class: "title text-lg text-primary-500") %>
<span class="mx-auto col-span-2" phx-update="ignore">
2022-01-28 21:05:54 -05:00
<%= color_input(f, :bg_color) %>
</span>
<span class="col-span-3">
2022-01-22 17:21:10 -05:00
<%= error_tag(f, :bg_color) %>
</span>
2022-01-22 17:21:10 -05:00
<%= label(f, :text_color, class: "title text-lg text-primary-500") %>
<span class="mx-auto col-span-2" phx-update="ignore">
2022-01-28 21:05:54 -05:00
<%= color_input(f, :text_color) %>
</span>
<span class="col-span-3">
2022-01-22 17:21:10 -05:00
<%= error_tag(f, :text_color) %>
</span>
2022-01-22 17:21:10 -05:00
<%= submit("Save",
class: "mx-auto btn btn-primary col-span-3",
phx_disable_with: "Saving..."
) %>
</.form>
</div>
"""
end
2021-09-02 23:31:14 -04:00
defp save_tag(socket, :edit, tag_params) do
case Tags.update_tag(socket.assigns.tag, tag_params) do
{:ok, _tag} ->
{:noreply,
socket
|> put_flash(:info, "Tag updated successfully")
|> push_redirect(to: socket.assigns.return_to)}
{:error, %Ecto.Changeset{} = changeset} ->
{:noreply, socket |> assign(:changeset, changeset)}
end
end
defp save_tag(socket, :new, tag_params) do
case Tags.create_tag(tag_params) do
{:ok, _tag} ->
{:noreply,
socket
|> put_flash(:info, "Tag created successfully")
|> push_redirect(to: socket.assigns.return_to)}
{:error, %Ecto.Changeset{} = changeset} ->
{:noreply, socket |> assign(changeset: changeset)}
end
2021-09-12 18:16:24 -04:00
end
2021-09-02 23:31:14 -04:00
end