Files
mono/market/sx/handlers/link-card.sx
giles 278ae3e8f6 Make SxExpr a str subclass, sx_call/render functions return SxExpr
SxExpr is now a str subclass so it works everywhere a plain string
does (join, isinstance, f-strings) while serialize() still emits it
unquoted. sx_call() and all internal render functions (_render_to_sx,
async_eval_to_sx, etc.) return SxExpr, eliminating the "forgot to
wrap" bug class that caused the sx_content leak and list serialization
bugs.

- Phase 0: SxExpr(str) with .source property, __add__/__radd__
- Phase 1: sx_call returns SxExpr (drop-in, all 200+ sites unchanged)
- Phase 2: async_eval_to_sx, async_eval_slot_to_sx, _render_to_sx,
  mobile_menu_sx return SxExpr; remove isinstance(str) workaround
- Phase 3: Remove ~150 redundant SxExpr() wrappings across 45 files
- Phase 4: serialize() docstring, handler return docs, ;; returns: sx

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-04 21:47:00 +00:00

44 lines
2.0 KiB
Plaintext

;; Market link-card fragment handler
;; returns: sx
;;
;; Renders product preview card(s) by slug.
;; Supports single mode (?slug=x) and batch mode (?keys=x,y,z).
(defhandler link-card (&key slug keys)
(if keys
(let ((slugs (filter (fn (s) (not (empty? s)))
(map trim (split keys ",")))))
(<> (map (fn (s)
(let ((product (service "market" "product-by-slug" :slug s)))
(<> (str "<!-- fragment:" s " -->")
(when (not (nil? product))
(let ((link (app-url "market" (str "/product/" (get product "slug") "/")))
(subtitle (or (get product "brand") ""))
(detail (if (get product "special_price")
(str (get product "regular_price") " → " (get product "special_price"))
(if (get product "regular_price")
(str (get product "regular_price"))
""))))
(~link-card
:title (get product "title")
:image (get product "image")
:subtitle subtitle
:detail detail
:link link)))))) slugs)))
(when slug
(let ((product (service "market" "product-by-slug" :slug slug)))
(when (not (nil? product))
(let ((link (app-url "market" (str "/product/" (get product "slug") "/")))
(subtitle (or (get product "brand") ""))
(detail (if (get product "special_price")
(str (get product "regular_price") " → " (get product "special_price"))
(if (get product "regular_price")
(str (get product "regular_price"))
""))))
(~link-card
:title (get product "title")
:image (get product "image")
:subtitle subtitle
:detail detail
:link link)))))))