- Extract shared components (empty-state, delete-btn, sentinel, crud-*, view-toggle, img-or-placeholder, avatar, sumup-settings-form, auth forms, order tables/detail/checkout) - Migrate all Python sx_call() callers to use shared components directly - Remove 55+ thin wrapper defcomps from domain .sx files - Remove trivial passthrough wrappers (blog-header-label, market-card-text, etc) - Unify duplicate auth flows (account + federation) into shared/sx/templates/auth.sx - Unify duplicate order views (cart + orders) into shared/sx/templates/orders.sx - Disable static file caching in dev (SEND_FILE_MAX_AGE_DEFAULT=0) - Add SX response validation and debug headers Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
46 lines
2.6 KiB
Plaintext
46 lines
2.6 KiB
Plaintext
;; Events payments components
|
|
|
|
(defcomp ~events-payments-panel (&key update-url csrf merchant-code placeholder input-cls sumup-configured checkout-prefix)
|
|
(section :class "p-4 max-w-lg mx-auto"
|
|
(~sumup-settings-form :update-url update-url :csrf csrf :merchant-code merchant-code
|
|
:placeholder placeholder :input-cls input-cls :sumup-configured sumup-configured
|
|
:checkout-prefix checkout-prefix :sx-select "#payments-panel")))
|
|
|
|
(defcomp ~events-markets-create-form (&key create-url csrf)
|
|
(<>
|
|
(div :id "market-create-errors" :class "mt-2 text-sm text-red-600")
|
|
(form :class "mt-4 flex gap-2 items-end" :sx-post create-url
|
|
:sx-target "#markets-list" :sx-select "#markets-list" :sx-swap "outerHTML"
|
|
:sx-on:beforeRequest "document.querySelector('#market-create-errors').textContent='';"
|
|
:sx-on:responseError "document.querySelector('#market-create-errors').textContent='Error'; if(event.detail.response){event.detail.response.clone().text().then(function(t){event.target.closest('form').querySelector('[id$=errors]').innerHTML=t})}"
|
|
(input :type "hidden" :name "csrf_token" :value csrf)
|
|
(div :class "flex-1"
|
|
(label :class "block text-sm text-gray-600" "Name")
|
|
(input :name "name" :type "text" :required true :class "w-full border rounded px-3 py-2"
|
|
:placeholder "e.g. Farm Shop, Bakery"))
|
|
(button :type "submit" :class "border rounded px-3 py-2" "Add market"))))
|
|
|
|
(defcomp ~events-markets-panel (&key form list)
|
|
(section :class "p-4"
|
|
form
|
|
(div :id "markets-list" :class "mt-6" list)))
|
|
|
|
(defcomp ~events-markets-empty ()
|
|
(p :class "text-gray-500 mt-4" "No markets yet. Create one above."))
|
|
|
|
(defcomp ~events-markets-item (&key href market-name market-slug del-url csrf-hdr)
|
|
(div :class "mt-6 border rounded-lg p-4"
|
|
(div :class "flex items-center justify-between gap-3"
|
|
(a :class "flex items-baseline gap-3" :href href
|
|
(h3 :class "font-semibold" market-name)
|
|
(h4 :class "text-gray-500" (str "/" market-slug "/")))
|
|
(button :class "text-sm border rounded px-3 py-1 hover:bg-red-50 hover:border-red-400"
|
|
:data-confirm true :data-confirm-title "Delete market?"
|
|
:data-confirm-text "Products will be hidden (soft delete)"
|
|
:data-confirm-icon "warning" :data-confirm-confirm-text "Yes, delete it"
|
|
:data-confirm-cancel-text "Cancel" :data-confirm-event "confirmed"
|
|
:sx-delete del-url :sx-trigger "confirmed"
|
|
:sx-target "#markets-list" :sx-select "#markets-list" :sx-swap "outerHTML"
|
|
:sx-headers csrf-hdr
|
|
(i :class "fa-solid fa-trash")))))
|