improve email settings progressive enhancement and admin layout
Some checks failed
deploy / deploy (push) Has been cancelled

- semantic HTML: step numbers inside h2, strong provider names, details
  for adapter configs, strong error messages, fieldset drawer toggle hidden
- inline field errors via flash for no-JS controller fallback
- single form POST button for test email (works with and without JS)
- admin sidebar: remove brand/view-shop, move user email to footer nav
- replace inline style with .admin-setup-step-spaced class
- clean up unused CSS (.admin-brand, .admin-sidebar-header, etc.)

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
jamey
2026-03-05 15:29:05 +00:00
parent 5dee2ae0be
commit c6636cab65
8 changed files with 91 additions and 126 deletions

View File

@@ -33,14 +33,18 @@ defmodule BerrypodWeb.EmailSettingsControllerTest do
assert Settings.get_setting("email_adapter") == "brevo"
end
test "redirects with error on validation failure", %{conn: conn} do
test "redirects with field errors on validation failure", %{conn: conn} do
conn =
post(conn, ~p"/admin/settings/email", %{
email: %{adapter: "brevo", brevo: %{api_key: ""}}
})
assert redirected_to(conn) =~ ~p"/admin/settings/email"
assert Phoenix.Flash.get(conn.assigns.flash, :error) =~ "required"
field_errors = Phoenix.Flash.get(conn.assigns.flash, :field_errors)
assert is_map(field_errors)
assert field_errors |> Map.values() |> Enum.any?(&String.contains?(&1, "required"))
assert Phoenix.Flash.get(conn.assigns.flash, :error_adapter) == "brevo"
end
end

View File

@@ -252,7 +252,7 @@ defmodule BerrypodWeb.Admin.EmailSettingsTest do
assert html =~ "sr-only"
end
test "only selected adapter config is visible (hidden attribute)", %{conn: conn} do
test "only selected adapter config is open (details element)", %{conn: conn} do
{:ok, view, _html} = live(conn, ~p"/admin/settings/email")
# Select SMTP
@@ -260,12 +260,12 @@ defmodule BerrypodWeb.Admin.EmailSettingsTest do
|> form("form[phx-change=\"form_change\"]", %{email: %{adapter: "smtp"}})
|> render_change()
# SMTP should not be hidden
refute has_element?(view, ~s([data-adapter="smtp"][hidden]))
# Others should be hidden
assert has_element?(view, ~s([data-adapter="brevo"][hidden]))
assert has_element?(view, ~s([data-adapter="sendgrid"][hidden]))
assert has_element?(view, ~s([data-adapter="postal"][hidden]))
# SMTP details should be open
assert has_element?(view, ~s(details[data-adapter="smtp"][open]))
# Others should not be open
refute has_element?(view, ~s(details[data-adapter="brevo"][open]))
refute has_element?(view, ~s(details[data-adapter="sendgrid"][open]))
refute has_element?(view, ~s(details[data-adapter="postal"][open]))
end
end

View File

@@ -43,10 +43,10 @@ defmodule BerrypodWeb.Admin.LayoutTest do
assert html =~ user.email
end
test "shows view shop and log out links", %{conn: conn} do
test "shows shop and log out links", %{conn: conn} do
{:ok, view, _html} = live(conn, ~p"/admin/orders")
assert has_element?(view, ~s(a[href="/"]), "View shop")
assert has_element?(view, ~s(a[href="/"]), "Shop")
assert has_element?(view, ~s(a[href="/users/log-out"]), "Log out")
end
end