Replaces placeholder "Market admin" text with a functional admin panel that lists marketplaces for a page and supports create/delete via sx, mirroring the events calendar admin pattern. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
41 lines
2.3 KiB
Plaintext
41 lines
2.3 KiB
Plaintext
;; Market admin panel components (page-level admin for markets)
|
|
|
|
(defcomp ~market-admin-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. Suma, Craft Fair"))
|
|
(button :type "submit" :class "border rounded px-3 py-2" "Add market"))))
|
|
|
|
(defcomp ~market-admin-panel (&key form list)
|
|
(section :class "p-4"
|
|
form
|
|
(div :id "markets-list" :class "mt-6" list)))
|
|
|
|
(defcomp ~market-admin-empty ()
|
|
(p :class "text-gray-500 mt-4" "No markets yet. Create one above."))
|
|
|
|
(defcomp ~market-admin-item (&key href name 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
|
|
:sx-get href :sx-target "#main-panel" :sx-select "#main-panel" :sx-swap "outerHTML" :sx-push-url "true"
|
|
(h3 :class "font-semibold" name)
|
|
(h4 :class "text-gray-500" (str "/" 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")))))
|