Role CRUD LiveViews closes #325 #326

Merged
moritz merged 28 commits from feature/325_role_view into main 2026-01-08 16:21:42 +01:00
Showing only changes of commit d9dd936ae3 - Show all commits

View file

@ -27,10 +27,10 @@ defmodule MvWeb.RoleLive.Show do
domain: Mv.Authorization,
actor: socket.assigns[:current_user]
) do
{:ok, role} ->
user_count = load_user_count(role)
{:ok, role} ->
user_count = load_user_count(role, socket.assigns[:current_user])
{:ok,
{:ok,
socket
|> assign(:page_title, gettext("Show Role"))
|> assign(:role, role)
@ -99,7 +99,7 @@ defmodule MvWeb.RoleLive.Show do
gettext("System roles cannot be deleted.")
)}
else
user_count = recalculate_user_count(role)
user_count = recalculate_user_count(role, socket.assigns.current_user)
if user_count > 0 do
{:noreply,
@ -137,15 +137,20 @@ defmodule MvWeb.RoleLive.Show do
end
end
defp recalculate_user_count(role) do
case Ash.count(Accounts.User |> Ash.Query.filter(role_id == ^role.id)) do
# Recalculates user count for a specific role (used before deletion)
defp recalculate_user_count(role, actor) do
opts = [domain: Mv.Accounts]
opts = if actor, do: Keyword.put(opts, :actor, actor), else: opts
case Ash.count(Accounts.User |> Ash.Query.filter(role_id == ^role.id), opts) do
{:ok, count} -> count
_ -> 0
end
end
defp load_user_count(role) do
recalculate_user_count(role)
# Loads user count for initial display (uses same logic as recalculate)
defp load_user_count(role, actor) do
recalculate_user_count(role, actor)
end
@impl true