Phase 1: Replace hex_to_hsl with hex_to_oklch in CSSGenerator, output --t-accent-l/c/h instead of --t-accent-h/s/l. All 46 HSL accent references across theme-semantic.css, theme-layer2-attributes.css, and shop/components.css replaced with oklch/color-mix equivalents. Dead style*= attribute selectors for button variants replaced with proper class-based selectors. Added color-scheme: light/dark to mood output. Phase 2: Add LoadTheme plug to admin pipeline, extend AdminLayoutHook with theme_settings and generated_css assigns, add font preloads and generated CSS injection to admin_root.html.heex. No visual changes to admin yet — .themed wrapper added in next phase. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
43 lines
1.3 KiB
Elixir
43 lines
1.3 KiB
Elixir
defmodule BerrypodWeb.AdminLayoutHook do
|
|
@moduledoc """
|
|
LiveView on_mount hook that assigns the current path for admin sidebar navigation
|
|
and loads theme settings for the admin layout.
|
|
"""
|
|
import Phoenix.Component
|
|
|
|
alias Berrypod.Settings
|
|
alias Berrypod.Theme.{CSSCache, CSSGenerator}
|
|
|
|
def on_mount(:assign_current_path, _params, _session, socket) do
|
|
theme_settings = Settings.get_theme_settings()
|
|
|
|
generated_css =
|
|
case CSSCache.get() do
|
|
{:ok, css} ->
|
|
css
|
|
|
|
:miss ->
|
|
css = CSSGenerator.generate(theme_settings, &BerrypodWeb.Endpoint.static_path/1)
|
|
CSSCache.put(css)
|
|
css
|
|
end
|
|
|
|
socket =
|
|
socket
|
|
|> assign(:current_path, "")
|
|
|> assign(:site_live, Settings.site_live?())
|
|
|> assign(:theme_settings, theme_settings)
|
|
|> assign(:generated_css, generated_css)
|
|
|> Phoenix.LiveView.attach_hook(:set_current_path, :handle_params, fn _params,
|
|
uri,
|
|
socket ->
|
|
{:cont,
|
|
socket
|
|
|> assign(:current_path, URI.parse(uri).path)
|
|
|> assign(:site_live, Settings.site_live?())}
|
|
end)
|
|
|
|
{:cont, socket}
|
|
end
|
|
end
|