Replace all 676 inline sexp() string calls across 7 services with render(component_name, **kwargs) calls backed by 46 external .sexpr component definition files (587 defcomps total). - Add render() function to shared/sexp/jinja_bridge.py - Add load_service_components() helper and update load_sexp_dir() for *.sexpr - Update parser keyword regex to support HTMX hx-on::event syntax - Convert remaining inline HTML in route files to render() calls - Add shared/sexp/templates/misc.sexp for cross-service utility components Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
64 lines
3.3 KiB
Plaintext
64 lines
3.3 KiB
Plaintext
;; Market navigation components
|
|
|
|
(defcomp ~market-category-link (&key href hx-select active select-colours label)
|
|
(div :class "relative nav-group"
|
|
(a :href href :hx-get href :hx-target "#main-panel"
|
|
:hx-select hx-select :hx-swap "outerHTML" :hx-push-url "true"
|
|
:aria-selected (if active "true" "false")
|
|
:class (str "block px-2 py-1 rounded text-center whitespace-normal break-words leading-snug bg-stone-200 text-black " select-colours)
|
|
label)))
|
|
|
|
(defcomp ~market-desktop-category-nav (&key links-html admin-html)
|
|
(nav :class "hidden md:flex gap-4 text-sm ml-2 w-full justify-end items-center"
|
|
(raw! links-html) (raw! admin-html)))
|
|
|
|
(defcomp ~market-mobile-nav-wrapper (&key items-html)
|
|
(div :class "px-4 py-2" (div :class "divide-y" (raw! items-html))))
|
|
|
|
(defcomp ~market-mobile-all-link (&key href hx-select active select-colours)
|
|
(a :role "option" :href href :hx-get href :hx-target "#main-panel"
|
|
:hx-select hx-select :hx-swap "outerHTML" :hx-push-url "true"
|
|
:aria-selected (if active "true" "false")
|
|
:class (str "block rounded-lg px-3 py-3 text-base hover:bg-stone-50 " select-colours)
|
|
(div :class "prose prose-stone max-w-none" "All")))
|
|
|
|
(defcomp ~market-mobile-chevron ()
|
|
(svg :class "w-4 h-4 shrink-0 transition-transform group-open/cat:rotate-180"
|
|
:viewBox "0 0 20 20" :fill "currentColor"
|
|
(path :fill-rule "evenodd" :clip-rule "evenodd"
|
|
:d "M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z")))
|
|
|
|
(defcomp ~market-mobile-cat-summary (&key bg-cls href hx-select select-colours cat-name count-label count-str chevron-html)
|
|
(summary :class (str "flex items-center justify-between cursor-pointer select-none block rounded-lg px-3 py-3 text-base hover:bg-stone-50" bg-cls)
|
|
(a :href href :hx-get href :hx-target "#main-panel"
|
|
:hx-select hx-select :hx-swap "outerHTML" :hx-push-url "true"
|
|
:class (str "font-medium " select-colours " flex flex-row gap-2")
|
|
(div cat-name)
|
|
(div :aria-label count-label count-str))
|
|
(raw! chevron-html)))
|
|
|
|
(defcomp ~market-mobile-sub-link (&key select-colours active href hx-select label count-label count-str)
|
|
(a :class (str "snap-start px-2 py-3 rounded " select-colours " flex flex-row gap-2")
|
|
:aria-selected (if active "true" "false")
|
|
:href href :hx-get href :hx-target "#main-panel"
|
|
:hx-select hx-select :hx-swap "outerHTML" :hx-push-url "true"
|
|
(div label)
|
|
(div :aria-label count-label count-str)))
|
|
|
|
(defcomp ~market-mobile-subs-panel (&key links-html)
|
|
(div :class "pb-3 pl-2"
|
|
(div :data-peek-viewport "" :data-peek-size-px "18" :data-peek-edge "bottom" :data-peek-mask "true" :class "m-2 bg-stone-100"
|
|
(div :data-peek-inner "" :class "grid grid-cols-1 gap-1 snap-y snap-mandatory pr-1" :aria-label "Subcategories"
|
|
(raw! links-html)))))
|
|
|
|
(defcomp ~market-mobile-view-all (&key href hx-select)
|
|
(div :class "pb-3 pl-2"
|
|
(a :class "px-2 py-1 rounded hover:bg-stone-100 block"
|
|
:href href :hx-get href :hx-target "#main-panel"
|
|
:hx-select hx-select :hx-swap "outerHTML" :hx-push-url "true"
|
|
"View all")))
|
|
|
|
(defcomp ~market-mobile-cat-details (&key open summary-html subs-html)
|
|
(details :class "group/cat py-1" :open open
|
|
(raw! summary-html) (raw! subs-html)))
|