diff --git a/lib/mindwendel/brainstormings/brainstorming.ex b/lib/mindwendel/brainstormings/brainstorming.ex index 80ee5152..f8eab963 100644 --- a/lib/mindwendel/brainstormings/brainstorming.ex +++ b/lib/mindwendel/brainstormings/brainstorming.ex @@ -23,7 +23,7 @@ defmodule Mindwendel.Brainstormings.Brainstorming do belongs_to :creating_user, User has_many :ideas, Idea has_many :lanes, Lane, preload_order: [asc: :position_order] - has_many :labels, IdeaLabel + has_many :labels, IdeaLabel, on_replace: :delete many_to_many :users, User, join_through: BrainstormingUser many_to_many :moderating_users, User, join_through: BrainstormingModeratingUser @@ -40,11 +40,21 @@ defmodule Mindwendel.Brainstormings.Brainstorming do :filter_labels_ids ]) |> validate_required([:name]) - |> cast_assoc(:labels) + |> cast_assoc(:labels, + with: &child_label_changeset/3, + drop_param: :labels_drop, + sort_param: :labels_sort + ) |> shorten_name |> gen_admin_url_id(brainstorming) end + defp child_label_changeset(child, changes, position) do + child + |> change(position_order: position) + |> IdeaLabel.changeset(changes) + end + def changeset_with_upated_last_accessed_at(brainstorming) do brainstorming |> change(%{last_accessed_at: DateTime.truncate(DateTime.utc_now(), :second)}) diff --git a/lib/mindwendel/brainstormings/idea_label.ex b/lib/mindwendel/brainstormings/idea_label.ex index a62c9766..5106afea 100644 --- a/lib/mindwendel/brainstormings/idea_label.ex +++ b/lib/mindwendel/brainstormings/idea_label.ex @@ -21,17 +21,15 @@ defmodule Mindwendel.Brainstormings.IdeaLabel do timestamps() end - def changeset(idea_label, params \\ %{}) - - def changeset(idea_label, %{delete: true}) do - %{Ecto.Changeset.change(idea_label, delete: true) | action: :delete} - |> no_assoc_constraint(:idea_idea_labels, message: "idea label associated with idea") - end - def changeset(idea_label, params) do idea_label |> cast(params, [:name, :color]) |> validate_required([:name]) |> validate_format(:color, ~r/^#[0-9a-f]{6}$/) + |> foreign_key_constraint(:ideas, + name: "idea_idea_labels_idea_label_id_fkey", + message: "idea label associated with idea" + ) + |> no_assoc_constraint(:idea_idea_labels, message: "idea label associated with idea") end end diff --git a/lib/mindwendel/brainstormings/idea_label_factory.ex b/lib/mindwendel/brainstormings/idea_label_factory.ex deleted file mode 100644 index b0ed5dfc..00000000 --- a/lib/mindwendel/brainstormings/idea_label_factory.ex +++ /dev/null @@ -1,27 +0,0 @@ -defmodule Mindwendel.Brainstormings.IdeaLabelFactory do - alias Mindwendel.Brainstormings.Brainstorming - - def build_idea_label(list) when is_list(list) do - rem( - length(list), - length(idea_label_variants()) - ) - |> idea_label_variant() - end - - def build_idea_label(%Brainstorming{labels: brainstorming_labels}) do - build_idea_label(brainstorming_labels) - end - - def build_idea_label(nil) do - idea_label_variant(0) - end - - def idea_label_variant(variant_number) when is_integer(variant_number) do - Enum.at(idea_label_variants(), variant_number) - end - - def idea_label_variants do - Brainstorming.idea_label_factory() - end -end diff --git a/lib/mindwendel_web/live/admin/brainstorming_live/edit.ex b/lib/mindwendel_web/live/admin/brainstorming_live/edit.ex index 3f3f9bb3..495c3a05 100644 --- a/lib/mindwendel_web/live/admin/brainstorming_live/edit.ex +++ b/lib/mindwendel_web/live/admin/brainstorming_live/edit.ex @@ -3,7 +3,6 @@ defmodule MindwendelWeb.Admin.BrainstormingLive.Edit do alias Mindwendel.Brainstormings alias Mindwendel.Brainstormings.Brainstorming - alias Mindwendel.Brainstormings.IdeaLabelFactory alias Mindwendel.Brainstormings.IdeaLabel alias Mindwendel.Repo @@ -43,12 +42,14 @@ defmodule MindwendelWeb.Admin.BrainstormingLive.Edit do do: {:noreply, assign(socket, uri: URI.parse(uri))} def handle_event("save", %{"brainstorming" => brainstorming_params}, socket) do + # why aren't we taking this from the socket? brainstorming = Brainstormings.get_brainstorming_by!(%{ admin_url_id: socket.assigns.brainstorming.admin_url_id }) |> Repo.preload(labels: from(idea_label in IdeaLabel, order_by: idea_label.position_order)) + # this changeset is too much?! changeset = Brainstorming.changeset(brainstorming, brainstorming_params) case Brainstormings.update_brainstorming(brainstorming, brainstorming_params) do @@ -76,85 +77,6 @@ defmodule MindwendelWeb.Admin.BrainstormingLive.Edit do end end - def handle_event("add_idea_label", _params, socket) do - brainstorming = socket.assigns.brainstorming - - idea_label_new = IdeaLabelFactory.build_idea_label(brainstorming) - - brainstorming_labels = - (brainstorming.labels ++ - [ - %{ - idea_label_new - | position_order: length(brainstorming.labels) + 1 - } - ]) - |> Enum.map(&Map.from_struct/1) - - case Brainstormings.update_brainstorming(brainstorming, %{labels: brainstorming_labels}) do - {:ok, brainstorming} -> - reset_changeset_timer_ref = reset_changeset_timer(socket) - - { - :noreply, - socket - |> assign(:brainstorming, brainstorming) - |> assign(:form, to_form(Brainstorming.changeset(brainstorming, %{}))) - |> assign(:reset_changeset_timer_ref, reset_changeset_timer_ref) - |> clear_flash() - } - - {:error, changeset} -> - cancel_changeset_timer(socket) - - { - :noreply, - socket - |> assign(form: to_form(changeset)) - |> put_flash(:error, gettext("Your brainstorming was not saved.")) - } - end - end - - def handle_event("remove_idea_label", %{"value" => idea_label_id}, socket) do - brainstorming = socket.assigns.brainstorming - - brainstorming_labels = - brainstorming.labels - |> Enum.map(fn label -> - if label.id == idea_label_id do - %{label | delete: true} - else - label - end - end) - |> Enum.map(&Map.from_struct/1) - - case Brainstormings.update_brainstorming(brainstorming, %{labels: brainstorming_labels}) do - {:ok, brainstorming} -> - reset_changeset_timer_ref = reset_changeset_timer(socket) - - { - :noreply, - socket - |> assign(:brainstorming, brainstorming) - |> assign(:form, to_form(Brainstorming.changeset(brainstorming, %{}))) - |> assign(:reset_changeset_timer_ref, reset_changeset_timer_ref) - |> clear_flash() - } - - {:error, changeset} -> - cancel_changeset_timer(socket) - - { - :noreply, - socket - |> assign(form: to_form(changeset)) - |> put_flash(:error, gettext("Your brainstorming was not saved.")) - } - end - end - def handle_event("empty", %{"value" => brainstorming_admin_url_id}, socket) when brainstorming_admin_url_id == socket.assigns.brainstorming.admin_url_id do brainstorming = socket.assigns.brainstorming @@ -164,6 +86,7 @@ defmodule MindwendelWeb.Admin.BrainstormingLive.Edit do {:noreply, push_navigate(socket, to: ~p"/brainstormings/#{brainstorming.id}")} end + # what is this timer? Maybe this should be FE only? defp cancel_changeset_timer(socket) do if socket.assigns[:reset_changeset_timer_ref], do: Process.cancel_timer(socket.assigns.reset_changeset_timer_ref) diff --git a/lib/mindwendel_web/live/admin/brainstorming_live/edit.html.heex b/lib/mindwendel_web/live/admin/brainstorming_live/edit.html.heex index b2646fe8..2eecd910 100644 --- a/lib/mindwendel_web/live/admin/brainstorming_live/edit.html.heex +++ b/lib/mindwendel_web/live/admin/brainstorming_live/edit.html.heex @@ -95,6 +95,7 @@