use sidecar templates
This commit is contained in:
		| @@ -44,34 +44,6 @@ defmodule CanneryWeb.ContainerLive.AddTagComponent do | ||||
|     {:noreply, socket} | ||||
|   end | ||||
|  | ||||
|   @impl true | ||||
|   def render(assigns) do | ||||
|     ~H""" | ||||
|     <div> | ||||
|       <h2 class="mb-4 text-center title text-xl text-primary-500"> | ||||
|         <%= @title %> | ||||
|       </h2> | ||||
|  | ||||
|       <.form | ||||
|         let={f} | ||||
|         for={:tag} | ||||
|         id="add-tag-to-container-form" | ||||
|         class="grid grid-cols-3 justify-center items-center space-x-2" | ||||
|         phx-target={@myself} | ||||
|         phx-submit="save" | ||||
|       > | ||||
|         <%= select(f, :tag_id, tag_options(@tags), class: "text-center col-span-2 input input-primary") %> | ||||
|         <%= error_tag(f, :tag_id, "col-span-3 text-center") %> | ||||
|  | ||||
|         <%= submit(dgettext("actions", "Add"), | ||||
|           class: "mx-auto btn btn-primary", | ||||
|           phx_disable_with: dgettext("prompts", "Adding...") | ||||
|         ) %> | ||||
|       </.form> | ||||
|     </div> | ||||
|     """ | ||||
|   end | ||||
|  | ||||
|   @spec tag_options([Tag.t()]) :: [{String.t(), Tag.id()}] | ||||
|   defp tag_options(tags) do | ||||
|     tags |> Enum.map(fn %{id: id, name: name} -> {name, id} end) | ||||
|   | ||||
| @@ -0,0 +1,22 @@ | ||||
| <div> | ||||
|   <h2 class="mb-4 text-center title text-xl text-primary-500"> | ||||
|     <%= @title %> | ||||
|   </h2> | ||||
|  | ||||
|   <.form | ||||
|     let={f} | ||||
|     for={:tag} | ||||
|     id="add-tag-to-container-form" | ||||
|     class="grid grid-cols-3 justify-center items-center space-x-2" | ||||
|     phx-target={@myself} | ||||
|     phx-submit="save" | ||||
|   > | ||||
|     <%= select(f, :tag_id, tag_options(@tags), class: "text-center col-span-2 input input-primary") %> | ||||
|     <%= error_tag(f, :tag_id, "col-span-3 text-center") %> | ||||
|  | ||||
|     <%= submit(dgettext("actions", "Add"), | ||||
|       class: "mx-auto btn btn-primary", | ||||
|       phx_disable_with: dgettext("prompts", "Adding...") | ||||
|     ) %> | ||||
|   </.form> | ||||
| </div> | ||||
| @@ -35,67 +35,6 @@ defmodule CanneryWeb.ContainerLive.FormComponent do | ||||
|     save_container(socket, action, container_params) | ||||
|   end | ||||
|  | ||||
|   @impl true | ||||
|   def render(assigns) do | ||||
|     ~H""" | ||||
|     <div> | ||||
|       <h2 class="text-center title text-xl text-primary-500"> | ||||
|         <%= @title %> | ||||
|       </h2> | ||||
|       <.form | ||||
|         let={f} | ||||
|         for={@changeset} | ||||
|         id="container-form" | ||||
|         class="grid grid-cols-3 justify-center items-center space-y-4" | ||||
|         phx-target={@myself} | ||||
|         phx-change="validate" | ||||
|         phx-submit="save" | ||||
|       > | ||||
|         <%= if @changeset.action do %> | ||||
|           <div class="invalid-feedback col-span-3 text-center"> | ||||
|             <%= changeset_errors(@changeset) %> | ||||
|           </div> | ||||
|         <% end %> | ||||
|  | ||||
|         <%= label(f, :name, gettext("Name"), class: "title text-lg text-primary-500") %> | ||||
|         <%= text_input(f, :name, | ||||
|           class: "input input-primary col-span-2", | ||||
|           placeholder: gettext("My cool ammo can") | ||||
|         ) %> | ||||
|         <%= error_tag(f, :name, "col-span-3 text-center") %> | ||||
|  | ||||
|         <%= label(f, :desc, gettext("Description"), class: "title text-lg text-primary-500") %> | ||||
|         <%= textarea(f, :desc, | ||||
|           class: "input input-primary col-span-2", | ||||
|           phx_hook: "MaintainAttrs", | ||||
|           placeholder: gettext("Metal ammo can with the anime girl sticker") | ||||
|         ) %> | ||||
|         <%= error_tag(f, :desc, "col-span-3 text-center") %> | ||||
|  | ||||
|         <%= label(f, :type, gettext("Type"), class: "title text-lg text-primary-500") %> | ||||
|         <%= text_input(f, :type, | ||||
|           class: "input input-primary col-span-2", | ||||
|           placeholder: gettext("Magazine, Clip, Ammo Box, etc") | ||||
|         ) %> | ||||
|         <%= error_tag(f, :type, "col-span-3 text-center") %> | ||||
|  | ||||
|         <%= label(f, :location, gettext("Location"), class: "title text-lg text-primary-500") %> | ||||
|         <%= textarea(f, :location, | ||||
|           class: "input input-primary col-span-2", | ||||
|           phx_hook: "MaintainAttrs", | ||||
|           placeholder: gettext("On the bookshelf") | ||||
|         ) %> | ||||
|         <%= error_tag(f, :location, "col-span-3 text-center") %> | ||||
|  | ||||
|         <%= submit(dgettext("actions", "Save"), | ||||
|           class: "mx-auto btn btn-primary col-span-3", | ||||
|           phx_disable_with: dgettext("prompts", "Saving...") | ||||
|         ) %> | ||||
|       </.form> | ||||
|     </div> | ||||
|     """ | ||||
|   end | ||||
|  | ||||
|   defp save_container( | ||||
|          %{assigns: %{container: container, current_user: current_user, return_to: return_to}} = | ||||
|            socket, | ||||
|   | ||||
							
								
								
									
										55
									
								
								lib/cannery_web/live/container_live/form_component.html.heex
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								lib/cannery_web/live/container_live/form_component.html.heex
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | ||||
| <div> | ||||
|   <h2 class="text-center title text-xl text-primary-500"> | ||||
|     <%= @title %> | ||||
|   </h2> | ||||
|   <.form | ||||
|     let={f} | ||||
|     for={@changeset} | ||||
|     id="container-form" | ||||
|     class="grid grid-cols-3 justify-center items-center space-y-4" | ||||
|     phx-target={@myself} | ||||
|     phx-change="validate" | ||||
|     phx-submit="save" | ||||
|   > | ||||
|     <%= if @changeset.action do %> | ||||
|       <div class="invalid-feedback col-span-3 text-center"> | ||||
|         <%= changeset_errors(@changeset) %> | ||||
|       </div> | ||||
|     <% end %> | ||||
|  | ||||
|     <%= label(f, :name, gettext("Name"), class: "title text-lg text-primary-500") %> | ||||
|     <%= text_input(f, :name, | ||||
|       class: "input input-primary col-span-2", | ||||
|       placeholder: gettext("My cool ammo can") | ||||
|     ) %> | ||||
|     <%= error_tag(f, :name, "col-span-3 text-center") %> | ||||
|  | ||||
|     <%= label(f, :desc, gettext("Description"), class: "title text-lg text-primary-500") %> | ||||
|     <%= textarea(f, :desc, | ||||
|       class: "input input-primary col-span-2", | ||||
|       phx_hook: "MaintainAttrs", | ||||
|       placeholder: gettext("Metal ammo can with the anime girl sticker") | ||||
|     ) %> | ||||
|     <%= error_tag(f, :desc, "col-span-3 text-center") %> | ||||
|  | ||||
|     <%= label(f, :type, gettext("Type"), class: "title text-lg text-primary-500") %> | ||||
|     <%= text_input(f, :type, | ||||
|       class: "input input-primary col-span-2", | ||||
|       placeholder: gettext("Magazine, Clip, Ammo Box, etc") | ||||
|     ) %> | ||||
|     <%= error_tag(f, :type, "col-span-3 text-center") %> | ||||
|  | ||||
|     <%= label(f, :location, gettext("Location"), class: "title text-lg text-primary-500") %> | ||||
|     <%= textarea(f, :location, | ||||
|       class: "input input-primary col-span-2", | ||||
|       phx_hook: "MaintainAttrs", | ||||
|       placeholder: gettext("On the bookshelf") | ||||
|     ) %> | ||||
|     <%= error_tag(f, :location, "col-span-3 text-center") %> | ||||
|  | ||||
|     <%= submit(dgettext("actions", "Save"), | ||||
|       class: "mx-auto btn btn-primary col-span-3", | ||||
|       phx_disable_with: dgettext("prompts", "Saving...") | ||||
|     ) %> | ||||
|   </.form> | ||||
| </div> | ||||
		Reference in New Issue
	
	Block a user