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>
44 lines
2.0 KiB
Plaintext
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)))))))
|