All checks were successful
deploy / deploy (push) Successful in 1m27s
Replace individual shop LiveViews with a single Shop.Page that dispatches to page modules based on live_action. This enables patch navigation between pages, preserving socket state (including editor state) across transitions. Changes: - Add Shop.Page unified LiveView with handle_params dispatch - Extract page logic into Shop.Pages.* modules (Home, Product, Collection, etc.) - Update router to use Shop.Page with live_action for all shop routes - Change navigate= to patch= in shop component links - Add maybe_sync_editing_blocks to reload editor state when page changes - Track editor_page_slug to detect cross-page navigation while editing - Fix picture element height when hover image disabled - Extract ThemeEditor components for shared use Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
45 lines
1009 B
Elixir
45 lines
1009 B
Elixir
defmodule BerrypodWeb.Shop.Pages.Home do
|
|
@moduledoc """
|
|
Home page handler for the unified Shop.Page LiveView.
|
|
"""
|
|
|
|
import Phoenix.Component, only: [assign: 2, assign: 3]
|
|
|
|
alias Berrypod.Pages
|
|
|
|
def init(socket, _params, _uri) do
|
|
page = Pages.get_page("home")
|
|
extra = Pages.load_block_data(page.blocks, socket.assigns)
|
|
|
|
base = BerrypodWeb.Endpoint.url()
|
|
site_name = socket.assigns.site_name
|
|
|
|
org_ld =
|
|
Jason.encode!(
|
|
%{
|
|
"@context" => "https://schema.org",
|
|
"@type" => "Organization",
|
|
"name" => site_name,
|
|
"url" => base <> "/"
|
|
},
|
|
escape: :html_safe
|
|
)
|
|
|
|
socket =
|
|
socket
|
|
|> assign(:page_title, "Home")
|
|
|> assign(:og_url, base <> "/")
|
|
|> assign(:json_ld, org_ld)
|
|
|> assign(:page, page)
|
|
|> assign(extra)
|
|
|
|
{:noreply, socket}
|
|
end
|
|
|
|
def handle_params(_params, _uri, socket) do
|
|
{:noreply, socket}
|
|
end
|
|
|
|
def handle_event(_event, _params, _socket), do: :cont
|
|
end
|