@cloudflare/kumo 1.8.0 → 1.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (872) hide show
  1. package/CHANGELOG.md +141 -0
  2. package/ai/component-registry.json +156 -53
  3. package/ai/component-registry.md +337 -40
  4. package/ai/schemas.ts +9 -7
  5. package/dist/.build-complete +1 -1
  6. package/dist/Legend-AE5XCSyU.js +388 -0
  7. package/dist/Legend-AE5XCSyU.js.map +1 -0
  8. package/dist/abap-DBQ6eW1v.js +8 -0
  9. package/dist/abap-DBQ6eW1v.js.map +1 -0
  10. package/dist/actionscript-3-DiEsS-FW.js +8 -0
  11. package/dist/actionscript-3-DiEsS-FW.js.map +1 -0
  12. package/dist/ada-DGQ_5PSJ.js +8 -0
  13. package/dist/ada-DGQ_5PSJ.js.map +1 -0
  14. package/dist/ai/schemas.d.ts +59 -43
  15. package/dist/ai/schemas.d.ts.map +1 -1
  16. package/dist/{schemas-DKFFjjzb.js → ai/schemas.js} +128 -126
  17. package/dist/ai/schemas.js.map +1 -0
  18. package/dist/andromeeda-0OVEHq5k.js +6 -0
  19. package/dist/andromeeda-0OVEHq5k.js.map +1 -0
  20. package/dist/angular-html-C3bwzvDd.js +34 -0
  21. package/dist/angular-html-C3bwzvDd.js.map +1 -0
  22. package/dist/angular-ts-fBH42fxp.js +23 -0
  23. package/dist/angular-ts-fBH42fxp.js.map +1 -0
  24. package/dist/apache-Bbrn7pkv.js +8 -0
  25. package/dist/apache-Bbrn7pkv.js.map +1 -0
  26. package/dist/apex-D7jlLUJl.js +8 -0
  27. package/dist/apex-D7jlLUJl.js.map +1 -0
  28. package/dist/apl-Cal58rzR.js +18 -0
  29. package/dist/apl-Cal58rzR.js.map +1 -0
  30. package/dist/applescript-AZMDCVmb.js +8 -0
  31. package/dist/applescript-AZMDCVmb.js.map +1 -0
  32. package/dist/ara-D7lI3smf.js +8 -0
  33. package/dist/ara-D7lI3smf.js.map +1 -0
  34. package/dist/asciidoc-B_JWnvj-.js +8 -0
  35. package/dist/asciidoc-B_JWnvj-.js.map +1 -0
  36. package/dist/asm-CF39_jeh.js +8 -0
  37. package/dist/asm-CF39_jeh.js.map +1 -0
  38. package/dist/astro-DvJenNvt.js +20 -0
  39. package/dist/astro-DvJenNvt.js.map +1 -0
  40. package/dist/aurora-x-lzSm_5DI.js +6 -0
  41. package/dist/aurora-x-lzSm_5DI.js.map +1 -0
  42. package/dist/awk-D1dwqHUl.js +8 -0
  43. package/dist/awk-D1dwqHUl.js.map +1 -0
  44. package/dist/ayu-dark-C_pOwMAx.js +6 -0
  45. package/dist/ayu-dark-C_pOwMAx.js.map +1 -0
  46. package/dist/ayu-light-C25DTeWu.js +6 -0
  47. package/dist/ayu-light-C25DTeWu.js.map +1 -0
  48. package/dist/ayu-mirage-9IoMPoai.js +6 -0
  49. package/dist/ayu-mirage-9IoMPoai.js.map +1 -0
  50. package/dist/{badge-Dc99vsfo.js → badge-DUfmrhhZ.js} +23 -18
  51. package/dist/badge-DUfmrhhZ.js.map +1 -0
  52. package/dist/ballerina-0aHuYbBL.js +8 -0
  53. package/dist/ballerina-0aHuYbBL.js.map +1 -0
  54. package/dist/bat-hp8TkMW_.js +8 -0
  55. package/dist/bat-hp8TkMW_.js.map +1 -0
  56. package/dist/beancount-DhXwArMG.js +8 -0
  57. package/dist/beancount-DhXwArMG.js.map +1 -0
  58. package/dist/berry-SKcQ_bn6.js +8 -0
  59. package/dist/berry-SKcQ_bn6.js.map +1 -0
  60. package/dist/bibtex-CKeuI1gX.js +8 -0
  61. package/dist/bibtex-CKeuI1gX.js.map +1 -0
  62. package/dist/bicep-Bb1Z8c8o.js +8 -0
  63. package/dist/bicep-Bb1Z8c8o.js.map +1 -0
  64. package/dist/bird2-C3rWbj4Z.js +8 -0
  65. package/dist/bird2-C3rWbj4Z.js.map +1 -0
  66. package/dist/blade-THHHddQO.js +22 -0
  67. package/dist/blade-THHHddQO.js.map +1 -0
  68. package/dist/breadcrumbs-BPtbCStQ.js +166 -0
  69. package/dist/breadcrumbs-BPtbCStQ.js.map +1 -0
  70. package/dist/bsl-CflI2mMp.js +10 -0
  71. package/dist/bsl-CflI2mMp.js.map +1 -0
  72. package/dist/c-D5qA7m19.js +8 -0
  73. package/dist/c-D5qA7m19.js.map +1 -0
  74. package/dist/c3-COOn93H9.js +8 -0
  75. package/dist/c3-COOn93H9.js.map +1 -0
  76. package/dist/cadence-Dxfo-G8_.js +8 -0
  77. package/dist/cadence-Dxfo-G8_.js.map +1 -0
  78. package/dist/cairo-CY6szQm5.js +10 -0
  79. package/dist/cairo-CY6szQm5.js.map +1 -0
  80. package/dist/catalog.js +1 -1
  81. package/dist/catalog.js.map +1 -1
  82. package/dist/catppuccin-frappe-CpIXPvSU.js +6 -0
  83. package/dist/catppuccin-frappe-CpIXPvSU.js.map +1 -0
  84. package/dist/catppuccin-latte-xiJp113n.js +6 -0
  85. package/dist/catppuccin-latte-xiJp113n.js.map +1 -0
  86. package/dist/catppuccin-macchiato-CUb8G_sh.js +6 -0
  87. package/dist/catppuccin-macchiato-CUb8G_sh.js.map +1 -0
  88. package/dist/catppuccin-mocha-_pSbIuk3.js +6 -0
  89. package/dist/catppuccin-mocha-_pSbIuk3.js.map +1 -0
  90. package/dist/{checkbox-BUV90tNU.js → checkbox-z5gO1lL8.js} +52 -52
  91. package/dist/checkbox-z5gO1lL8.js.map +1 -0
  92. package/dist/clarity-S9WX3mE2.js +8 -0
  93. package/dist/clarity-S9WX3mE2.js.map +1 -0
  94. package/dist/{clipboard-text-BVKGunue.js → clipboard-text-DbvIaZ3g.js} +25 -25
  95. package/dist/clipboard-text-DbvIaZ3g.js.map +1 -0
  96. package/dist/clojure-CMSQ2cRZ.js +8 -0
  97. package/dist/clojure-CMSQ2cRZ.js.map +1 -0
  98. package/dist/cmake-BjGOmuDM.js +8 -0
  99. package/dist/cmake-BjGOmuDM.js.map +1 -0
  100. package/dist/cobol-CdczAIkZ.js +12 -0
  101. package/dist/cobol-CdczAIkZ.js.map +1 -0
  102. package/dist/code/server.js +58 -0
  103. package/dist/code/server.js.map +1 -0
  104. package/dist/code-T2wPDiM0.js.map +1 -1
  105. package/dist/code.js +205 -0
  106. package/dist/code.js.map +1 -0
  107. package/dist/codeowners-CJleX2EU.js +8 -0
  108. package/dist/codeowners-CJleX2EU.js.map +1 -0
  109. package/dist/codeql-C_xiqGOC.js +8 -0
  110. package/dist/codeql-C_xiqGOC.js.map +1 -0
  111. package/dist/coffee-DbwFrMGw.js +10 -0
  112. package/dist/coffee-DbwFrMGw.js.map +1 -0
  113. package/dist/combobox-CJqgoue6.js +336 -0
  114. package/dist/combobox-CJqgoue6.js.map +1 -0
  115. package/dist/command-line/cli.js +4 -0
  116. package/dist/command-line/commands/add.js +4 -0
  117. package/dist/{command-palette-B2hkPSQm.js → command-palette-xctZ--ZT.js} +55 -55
  118. package/dist/command-palette-xctZ--ZT.js.map +1 -0
  119. package/dist/common-lisp-bZFDzkJA.js +8 -0
  120. package/dist/common-lisp-bZFDzkJA.js.map +1 -0
  121. package/dist/components/badge.js +1 -1
  122. package/dist/components/breadcrumbs.js +1 -1
  123. package/dist/components/chart.js +9 -0
  124. package/dist/components/chart.js.map +1 -0
  125. package/dist/components/checkbox.js +1 -1
  126. package/dist/components/clipboard-text.js +1 -1
  127. package/dist/components/combobox.js +1 -1
  128. package/dist/components/command-palette.js +1 -1
  129. package/dist/components/dialog.js +1 -1
  130. package/dist/components/dropdown.js +1 -1
  131. package/dist/components/field.js +1 -1
  132. package/dist/components/flow.js +1798 -1718
  133. package/dist/components/flow.js.map +1 -1
  134. package/dist/components/input.js +3 -3
  135. package/dist/components/label.js +1 -1
  136. package/dist/components/link.js +1 -1
  137. package/dist/components/menubar.js +1 -1
  138. package/dist/components/meter.js +1 -1
  139. package/dist/components/pagination.js +1 -1
  140. package/dist/components/popover.js +1 -1
  141. package/dist/components/radio.js +1 -1
  142. package/dist/components/select.js +1 -1
  143. package/dist/components/sensitive-input.js +1 -1
  144. package/dist/components/switch.js +1 -1
  145. package/dist/components/table.js +1 -1
  146. package/dist/components/tabs.js +1 -1
  147. package/dist/components/toast.js +2 -2
  148. package/dist/components/tooltip.js +1 -1
  149. package/dist/coq-BHwvPA1n.js +8 -0
  150. package/dist/coq-BHwvPA1n.js.map +1 -0
  151. package/dist/cpp-8X-mPrPy.js +20 -0
  152. package/dist/cpp-8X-mPrPy.js.map +1 -0
  153. package/dist/crystal-ClltT4Pm.js +20 -0
  154. package/dist/crystal-ClltT4Pm.js.map +1 -0
  155. package/dist/csharp-Byem5RBI.js +8 -0
  156. package/dist/csharp-Byem5RBI.js.map +1 -0
  157. package/dist/css-qd-96f_M.js +8 -0
  158. package/dist/css-qd-96f_M.js.map +1 -0
  159. package/dist/csv-CF_FKHnB.js +8 -0
  160. package/dist/csv-CF_FKHnB.js.map +1 -0
  161. package/dist/cue-I1Agx594.js +8 -0
  162. package/dist/cue-I1Agx594.js.map +1 -0
  163. package/dist/cypher-plLNBUt5.js +8 -0
  164. package/dist/cypher-plLNBUt5.js.map +1 -0
  165. package/dist/d-CEuq9VFi.js +8 -0
  166. package/dist/d-CEuq9VFi.js.map +1 -0
  167. package/dist/dark-plus-BoH9QJRG.js +6 -0
  168. package/dist/dark-plus-BoH9QJRG.js.map +1 -0
  169. package/dist/dart-BW14f2cB.js +8 -0
  170. package/dist/dart-BW14f2cB.js.map +1 -0
  171. package/dist/dax-3tjM9tVE.js +8 -0
  172. package/dist/dax-3tjM9tVE.js.map +1 -0
  173. package/dist/desktop-C_s7lQ2C.js +8 -0
  174. package/dist/desktop-C_s7lQ2C.js.map +1 -0
  175. package/dist/dialog-1pa-ezdL.js +112 -0
  176. package/dist/dialog-1pa-ezdL.js.map +1 -0
  177. package/dist/diff-B9PHDIQg.js +8 -0
  178. package/dist/diff-B9PHDIQg.js.map +1 -0
  179. package/dist/docker-rmWVNdXq.js +8 -0
  180. package/dist/docker-rmWVNdXq.js.map +1 -0
  181. package/dist/dotenv-DZArZ0py.js +8 -0
  182. package/dist/dotenv-DZArZ0py.js.map +1 -0
  183. package/dist/dracula-CdWPhGUA.js +6 -0
  184. package/dist/dracula-CdWPhGUA.js.map +1 -0
  185. package/dist/dracula-soft-DRgtS4KI.js +6 -0
  186. package/dist/dracula-soft-DRgtS4KI.js.map +1 -0
  187. package/dist/dream-maker-DNRMl5wX.js +8 -0
  188. package/dist/dream-maker-DNRMl5wX.js.map +1 -0
  189. package/dist/dropdown-BXg01-8j.js +295 -0
  190. package/dist/dropdown-BXg01-8j.js.map +1 -0
  191. package/dist/edge-CQUaQiBB.js +14 -0
  192. package/dist/edge-CQUaQiBB.js.map +1 -0
  193. package/dist/elixir-BIX3y1uJ.js +10 -0
  194. package/dist/elixir-BIX3y1uJ.js.map +1 -0
  195. package/dist/elm-DNVN4B4L.js +10 -0
  196. package/dist/elm-DNVN4B4L.js.map +1 -0
  197. package/dist/emacs-lisp-C3TqDViv.js +8 -0
  198. package/dist/emacs-lisp-C3TqDViv.js.map +1 -0
  199. package/dist/engine-compile-D-n7xALU.js +2621 -0
  200. package/dist/engine-compile-D-n7xALU.js.map +1 -0
  201. package/dist/engine-javascript-BGkeRc0U.js +26 -0
  202. package/dist/engine-javascript-BGkeRc0U.js.map +1 -0
  203. package/dist/engine-oniguruma-T2xha06Q.js +304 -0
  204. package/dist/engine-oniguruma-T2xha06Q.js.map +1 -0
  205. package/dist/erb-CPJOs_gM.js +12 -0
  206. package/dist/erb-CPJOs_gM.js.map +1 -0
  207. package/dist/erlang-X97pCGTS.js +10 -0
  208. package/dist/erlang-X97pCGTS.js.map +1 -0
  209. package/dist/everforest-dark-C9JXzteI.js +6 -0
  210. package/dist/everforest-dark-C9JXzteI.js.map +1 -0
  211. package/dist/everforest-light-xBi4ZMR7.js +6 -0
  212. package/dist/everforest-light-xBi4ZMR7.js.map +1 -0
  213. package/dist/fennel-fKVJGO8V.js +8 -0
  214. package/dist/fennel-fKVJGO8V.js.map +1 -0
  215. package/dist/{field-Bkh5pJay.js → field-BYaOyOtJ.js} +5 -5
  216. package/dist/{field-Bkh5pJay.js.map → field-BYaOyOtJ.js.map} +1 -1
  217. package/dist/fish-BB5DT4M2.js +8 -0
  218. package/dist/fish-BB5DT4M2.js.map +1 -0
  219. package/dist/fluent-AMVPEbdR.js +8 -0
  220. package/dist/fluent-AMVPEbdR.js.map +1 -0
  221. package/dist/fortran-fixed-form-J4xKprxx.js +10 -0
  222. package/dist/fortran-fixed-form-J4xKprxx.js.map +1 -0
  223. package/dist/fortran-free-form-89VVYcvD.js +8 -0
  224. package/dist/fortran-free-form-89VVYcvD.js.map +1 -0
  225. package/dist/fsharp-BnRQMxrz.js +10 -0
  226. package/dist/fsharp-BnRQMxrz.js.map +1 -0
  227. package/dist/gdresource-DGR3GPIj.js +12 -0
  228. package/dist/gdresource-DGR3GPIj.js.map +1 -0
  229. package/dist/gdscript-8-4n2AaI.js +8 -0
  230. package/dist/gdscript-8-4n2AaI.js.map +1 -0
  231. package/dist/gdshader-BCM6bIM_.js +8 -0
  232. package/dist/gdshader-BCM6bIM_.js.map +1 -0
  233. package/dist/genie-CxR2u3hD.js +8 -0
  234. package/dist/genie-CxR2u3hD.js.map +1 -0
  235. package/dist/gherkin-BhW6oAYW.js +8 -0
  236. package/dist/gherkin-BhW6oAYW.js.map +1 -0
  237. package/dist/git-commit-DSzkYnqf.js +10 -0
  238. package/dist/git-commit-DSzkYnqf.js.map +1 -0
  239. package/dist/git-rebase-CY0sqDHH.js +10 -0
  240. package/dist/git-rebase-CY0sqDHH.js.map +1 -0
  241. package/dist/github-dark-EGgK0P1m.js +6 -0
  242. package/dist/github-dark-EGgK0P1m.js.map +1 -0
  243. package/dist/github-dark-default-69UGLTaR.js +6 -0
  244. package/dist/github-dark-default-69UGLTaR.js.map +1 -0
  245. package/dist/github-dark-dimmed-CnBHruXC.js +6 -0
  246. package/dist/github-dark-dimmed-CnBHruXC.js.map +1 -0
  247. package/dist/github-dark-high-contrast-Dz2ZsuOt.js +6 -0
  248. package/dist/github-dark-high-contrast-Dz2ZsuOt.js.map +1 -0
  249. package/dist/github-light-C7TbDuh5.js +6 -0
  250. package/dist/github-light-C7TbDuh5.js.map +1 -0
  251. package/dist/github-light-default-C1fruPEw.js +6 -0
  252. package/dist/github-light-default-C1fruPEw.js.map +1 -0
  253. package/dist/github-light-high-contrast-SmWFD2B-.js +6 -0
  254. package/dist/github-light-high-contrast-SmWFD2B-.js.map +1 -0
  255. package/dist/gleam-PNso-9g-.js +8 -0
  256. package/dist/gleam-PNso-9g-.js.map +1 -0
  257. package/dist/glimmer-js-DY9OBWW6.js +16 -0
  258. package/dist/glimmer-js-DY9OBWW6.js.map +1 -0
  259. package/dist/glimmer-ts-CKjdlzG3.js +16 -0
  260. package/dist/glimmer-ts-CKjdlzG3.js.map +1 -0
  261. package/dist/glsl-Bo9QfxI7.js +10 -0
  262. package/dist/glsl-Bo9QfxI7.js.map +1 -0
  263. package/dist/gn-B8imrxEe.js +8 -0
  264. package/dist/gn-B8imrxEe.js.map +1 -0
  265. package/dist/gnuplot-z48QnpzZ.js +8 -0
  266. package/dist/gnuplot-z48QnpzZ.js.map +1 -0
  267. package/dist/go-BUI2a86a.js +8 -0
  268. package/dist/go-BUI2a86a.js.map +1 -0
  269. package/dist/graphql-CYUl2j62.js +16 -0
  270. package/dist/graphql-CYUl2j62.js.map +1 -0
  271. package/dist/groovy-BZajDB1h.js +8 -0
  272. package/dist/groovy-BZajDB1h.js.map +1 -0
  273. package/dist/gruvbox-dark-hard-DEp4fn0U.js +6 -0
  274. package/dist/gruvbox-dark-hard-DEp4fn0U.js.map +1 -0
  275. package/dist/gruvbox-dark-medium-D3l-n4N3.js +6 -0
  276. package/dist/gruvbox-dark-medium-D3l-n4N3.js.map +1 -0
  277. package/dist/gruvbox-dark-soft-Ca_lMr1K.js +6 -0
  278. package/dist/gruvbox-dark-soft-Ca_lMr1K.js.map +1 -0
  279. package/dist/gruvbox-light-hard-D5BcqPys.js +6 -0
  280. package/dist/gruvbox-light-hard-D5BcqPys.js.map +1 -0
  281. package/dist/gruvbox-light-medium-C_7vC_ep.js +6 -0
  282. package/dist/gruvbox-light-medium-C_7vC_ep.js.map +1 -0
  283. package/dist/gruvbox-light-soft-YeHuiVT9.js +6 -0
  284. package/dist/gruvbox-light-soft-YeHuiVT9.js.map +1 -0
  285. package/dist/hack-Bo7_3XMo.js +12 -0
  286. package/dist/hack-Bo7_3XMo.js.map +1 -0
  287. package/dist/haml-lAa-UgZq.js +12 -0
  288. package/dist/haml-lAa-UgZq.js.map +1 -0
  289. package/dist/handlebars-C-lypSbJ.js +16 -0
  290. package/dist/handlebars-C-lypSbJ.js.map +1 -0
  291. package/dist/haskell-CyfJi0Qi.js +8 -0
  292. package/dist/haskell-CyfJi0Qi.js.map +1 -0
  293. package/dist/haxe-DHpItfCt.js +8 -0
  294. package/dist/haxe-DHpItfCt.js.map +1 -0
  295. package/dist/hcl-C-f84Y9W.js +8 -0
  296. package/dist/hcl-C-f84Y9W.js.map +1 -0
  297. package/dist/hjson-8VYQauSm.js +8 -0
  298. package/dist/hjson-8VYQauSm.js.map +1 -0
  299. package/dist/hlsl-Bi2Lb4au.js +8 -0
  300. package/dist/hlsl-Bi2Lb4au.js.map +1 -0
  301. package/dist/horizon-DyGYchkb.js +6 -0
  302. package/dist/horizon-DyGYchkb.js.map +1 -0
  303. package/dist/horizon-bright-DatYugLo.js +6 -0
  304. package/dist/horizon-bright-DatYugLo.js.map +1 -0
  305. package/dist/houston-DaTAsj92.js +6 -0
  306. package/dist/houston-DaTAsj92.js.map +1 -0
  307. package/dist/html-BXZx6WkT.js +12 -0
  308. package/dist/html-BXZx6WkT.js.map +1 -0
  309. package/dist/html-derivative-CaPNhXFu.js +10 -0
  310. package/dist/html-derivative-CaPNhXFu.js.map +1 -0
  311. package/dist/http-BJ0BMq9T.js +16 -0
  312. package/dist/http-BJ0BMq9T.js.map +1 -0
  313. package/dist/hurl-D_d_bmYM.js +14 -0
  314. package/dist/hurl-D_d_bmYM.js.map +1 -0
  315. package/dist/hxml-C8H9PCaB.js +10 -0
  316. package/dist/hxml-C8H9PCaB.js.map +1 -0
  317. package/dist/hy-Cf7WyqnA.js +8 -0
  318. package/dist/hy-Cf7WyqnA.js.map +1 -0
  319. package/dist/imba-4cu8YWL6.js +8 -0
  320. package/dist/imba-4cu8YWL6.js.map +1 -0
  321. package/dist/index-yfbAkHut.js +7313 -0
  322. package/dist/index-yfbAkHut.js.map +1 -0
  323. package/dist/index.js +72 -67
  324. package/dist/index.js.map +1 -1
  325. package/dist/ini-DdlAq5Sk.js +8 -0
  326. package/dist/ini-DdlAq5Sk.js.map +1 -0
  327. package/dist/{input-DjItb3_k.js → input-BXn3ElmF.js} +3 -3
  328. package/dist/{input-DjItb3_k.js.map → input-BXn3ElmF.js.map} +1 -1
  329. package/dist/{input-area-BcidmGaO.js → input-area-C3ddZhEo.js} +3 -3
  330. package/dist/{input-area-BcidmGaO.js.map → input-area-C3ddZhEo.js.map} +1 -1
  331. package/dist/{input-group-CMAvOKIV.js → input-group-BiUKE2TR.js} +5 -5
  332. package/dist/input-group-BiUKE2TR.js.map +1 -0
  333. package/dist/java-DZX_qz_V.js +8 -0
  334. package/dist/java-DZX_qz_V.js.map +1 -0
  335. package/dist/javascript-Dcop9YgO.js +8 -0
  336. package/dist/javascript-Dcop9YgO.js.map +1 -0
  337. package/dist/jinja-CYDaN8cn.js +13 -0
  338. package/dist/jinja-CYDaN8cn.js.map +1 -0
  339. package/dist/jison-B8TKZKc6.js +10 -0
  340. package/dist/jison-B8TKZKc6.js.map +1 -0
  341. package/dist/json-BONZstWZ.js +8 -0
  342. package/dist/json-BONZstWZ.js.map +1 -0
  343. package/dist/json5-C-4cnXW0.js +8 -0
  344. package/dist/json5-C-4cnXW0.js.map +1 -0
  345. package/dist/jsonc-CIx6BVP6.js +8 -0
  346. package/dist/jsonc-CIx6BVP6.js.map +1 -0
  347. package/dist/jsonl-DFezC0c-.js +8 -0
  348. package/dist/jsonl-DFezC0c-.js.map +1 -0
  349. package/dist/jsonnet-CrYiLnuZ.js +8 -0
  350. package/dist/jsonnet-CrYiLnuZ.js.map +1 -0
  351. package/dist/jssm-DPqP_6Yy.js +8 -0
  352. package/dist/jssm-DPqP_6Yy.js.map +1 -0
  353. package/dist/jsx-Buo8VY2N.js +8 -0
  354. package/dist/jsx-Buo8VY2N.js.map +1 -0
  355. package/dist/julia-BGc-upw8.js +18 -0
  356. package/dist/julia-BGc-upw8.js.map +1 -0
  357. package/dist/just-Btim_Xbp.js +20 -0
  358. package/dist/just-Btim_Xbp.js.map +1 -0
  359. package/dist/kanagawa-dragon-CrRYMC-y.js +6 -0
  360. package/dist/kanagawa-dragon-CrRYMC-y.js.map +1 -0
  361. package/dist/kanagawa-lotus-CpAeLZo_.js +6 -0
  362. package/dist/kanagawa-lotus-CpAeLZo_.js.map +1 -0
  363. package/dist/kanagawa-wave-DgLnfzgl.js +6 -0
  364. package/dist/kanagawa-wave-DgLnfzgl.js.map +1 -0
  365. package/dist/kdl-D5mP0US-.js +8 -0
  366. package/dist/kdl-D5mP0US-.js.map +1 -0
  367. package/dist/kotlin-Bj4GXgal.js +8 -0
  368. package/dist/kotlin-Bj4GXgal.js.map +1 -0
  369. package/dist/kusto-xKgi3EM3.js +8 -0
  370. package/dist/kusto-xKgi3EM3.js.map +1 -0
  371. package/dist/{label-Cjpb7l1F.js → label-ByOtGj7z.js} +2 -2
  372. package/dist/{label-Cjpb7l1F.js.map → label-ByOtGj7z.js.map} +1 -1
  373. package/dist/laserwave-DwIE46bX.js +6 -0
  374. package/dist/laserwave-DwIE46bX.js.map +1 -0
  375. package/dist/latex-Ba_x0_mo.js +10 -0
  376. package/dist/latex-Ba_x0_mo.js.map +1 -0
  377. package/dist/lean-CFZjFqaI.js +8 -0
  378. package/dist/lean-CFZjFqaI.js.map +1 -0
  379. package/dist/less-Cah4u9hl.js +8 -0
  380. package/dist/less-Cah4u9hl.js.map +1 -0
  381. package/dist/light-plus-uDz5yXau.js +6 -0
  382. package/dist/light-plus-uDz5yXau.js.map +1 -0
  383. package/dist/{link-DUqZGMVk.js → link-CfCaX9Ks.js} +11 -11
  384. package/dist/{link-DUqZGMVk.js.map → link-CfCaX9Ks.js.map} +1 -1
  385. package/dist/liquid-DUwftMLD.js +16 -0
  386. package/dist/liquid-DUwftMLD.js.map +1 -0
  387. package/dist/llvm-p6MskI4D.js +8 -0
  388. package/dist/llvm-p6MskI4D.js.map +1 -0
  389. package/dist/log-B-eGB3gN.js +8 -0
  390. package/dist/log-B-eGB3gN.js.map +1 -0
  391. package/dist/logo-_QhIaHqR.js +8 -0
  392. package/dist/logo-_QhIaHqR.js.map +1 -0
  393. package/dist/lua-DXBtl-xZ.js +10 -0
  394. package/dist/lua-DXBtl-xZ.js.map +1 -0
  395. package/dist/luau-cNt0OAd4.js +8 -0
  396. package/dist/luau-cNt0OAd4.js.map +1 -0
  397. package/dist/make-LOzELzzn.js +8 -0
  398. package/dist/make-LOzELzzn.js.map +1 -0
  399. package/dist/markdown-CPiFXKuQ.js +8 -0
  400. package/dist/markdown-CPiFXKuQ.js.map +1 -0
  401. package/dist/marko-B5j5W6dr.js +16 -0
  402. package/dist/marko-B5j5W6dr.js.map +1 -0
  403. package/dist/material-theme-BNmHEIvm.js +6 -0
  404. package/dist/material-theme-BNmHEIvm.js.map +1 -0
  405. package/dist/material-theme-darker-DSlFkdBn.js +6 -0
  406. package/dist/material-theme-darker-DSlFkdBn.js.map +1 -0
  407. package/dist/material-theme-lighter-DMthFo49.js +6 -0
  408. package/dist/material-theme-lighter-DMthFo49.js.map +1 -0
  409. package/dist/material-theme-ocean-Bza3srwZ.js +6 -0
  410. package/dist/material-theme-ocean-Bza3srwZ.js.map +1 -0
  411. package/dist/material-theme-palenight-cC7823m_.js +6 -0
  412. package/dist/material-theme-palenight-cC7823m_.js.map +1 -0
  413. package/dist/matlab-BXc70sGh.js +8 -0
  414. package/dist/matlab-BXc70sGh.js.map +1 -0
  415. package/dist/mdc-DIfFG4VK.js +14 -0
  416. package/dist/mdc-DIfFG4VK.js.map +1 -0
  417. package/dist/mdx-DDEEGmMw.js +8 -0
  418. package/dist/mdx-DDEEGmMw.js.map +1 -0
  419. package/dist/{menubar-bgBP3EJi.js → menubar-be9R8bE-.js} +14 -14
  420. package/dist/menubar-be9R8bE-.js.map +1 -0
  421. package/dist/mermaid-BbhKaiym.js +8 -0
  422. package/dist/mermaid-BbhKaiym.js.map +1 -0
  423. package/dist/{meter-BziPAH9D.js → meter-CCpXrH8B.js} +4 -4
  424. package/dist/{meter-BziPAH9D.js.map → meter-CCpXrH8B.js.map} +1 -1
  425. package/dist/min-dark-B2RGEXlR.js +6 -0
  426. package/dist/min-dark-B2RGEXlR.js.map +1 -0
  427. package/dist/min-light-CdvDdehu.js +6 -0
  428. package/dist/min-light-CdvDdehu.js.map +1 -0
  429. package/dist/mipsasm-A-azREv6.js +8 -0
  430. package/dist/mipsasm-A-azREv6.js.map +1 -0
  431. package/dist/mojo-eENZKkWN.js +8 -0
  432. package/dist/mojo-eENZKkWN.js.map +1 -0
  433. package/dist/monokai-DfGcBwbw.js +6 -0
  434. package/dist/monokai-DfGcBwbw.js.map +1 -0
  435. package/dist/moonbit-OY9Cnyv0.js +8 -0
  436. package/dist/moonbit-OY9Cnyv0.js.map +1 -0
  437. package/dist/move-DQ3SUBHm.js +8 -0
  438. package/dist/move-DQ3SUBHm.js.map +1 -0
  439. package/dist/narrat-DEs1QMww.js +8 -0
  440. package/dist/narrat-DEs1QMww.js.map +1 -0
  441. package/dist/nextflow-BLqoZa2U.js +10 -0
  442. package/dist/nextflow-BLqoZa2U.js.map +1 -0
  443. package/dist/nextflow-groovy-sn5GPI4S.js +8 -0
  444. package/dist/nextflow-groovy-sn5GPI4S.js.map +1 -0
  445. package/dist/nginx-DV2C2lFg.js +10 -0
  446. package/dist/nginx-DV2C2lFg.js.map +1 -0
  447. package/dist/night-owl-Cx4f311z.js +6 -0
  448. package/dist/night-owl-Cx4f311z.js.map +1 -0
  449. package/dist/night-owl-light-CFIwPg_e.js +6 -0
  450. package/dist/night-owl-light-CFIwPg_e.js.map +1 -0
  451. package/dist/nim-DX5HB9SQ.js +22 -0
  452. package/dist/nim-DX5HB9SQ.js.map +1 -0
  453. package/dist/nix-BbTJzn8W.js +11 -0
  454. package/dist/nix-BbTJzn8W.js.map +1 -0
  455. package/dist/nord-N4OTOgI2.js +6 -0
  456. package/dist/nord-N4OTOgI2.js.map +1 -0
  457. package/dist/nushell-CRsPhsIw.js +8 -0
  458. package/dist/nushell-CRsPhsIw.js.map +1 -0
  459. package/dist/objective-c-7VQzYTNs.js +8 -0
  460. package/dist/objective-c-7VQzYTNs.js.map +1 -0
  461. package/dist/objective-cpp-C_AHgfC8.js +8 -0
  462. package/dist/objective-cpp-C_AHgfC8.js.map +1 -0
  463. package/dist/ocaml-N0gcbB8P.js +8 -0
  464. package/dist/ocaml-N0gcbB8P.js.map +1 -0
  465. package/dist/odin-CbArZjV2.js +8 -0
  466. package/dist/odin-CbArZjV2.js.map +1 -0
  467. package/dist/one-dark-pro-CFjKUJ8l.js +6 -0
  468. package/dist/one-dark-pro-CFjKUJ8l.js.map +1 -0
  469. package/dist/one-light-cHFZvryT.js +6 -0
  470. package/dist/one-light-cHFZvryT.js.map +1 -0
  471. package/dist/openscad-9QYZdZML.js +8 -0
  472. package/dist/openscad-9QYZdZML.js.map +1 -0
  473. package/dist/pagination-CaHm6TKa.js +220 -0
  474. package/dist/pagination-CaHm6TKa.js.map +1 -0
  475. package/dist/pascal-Chee6n3j.js +8 -0
  476. package/dist/pascal-Chee6n3j.js.map +1 -0
  477. package/dist/perl-Bo9cWF9y.js +18 -0
  478. package/dist/perl-Bo9cWF9y.js.map +1 -0
  479. package/dist/php-Cbqedh5-.js +20 -0
  480. package/dist/php-Cbqedh5-.js.map +1 -0
  481. package/dist/pkl-DmRpyJfO.js +8 -0
  482. package/dist/pkl-DmRpyJfO.js.map +1 -0
  483. package/dist/plastic-BWaSpRpp.js +6 -0
  484. package/dist/plastic-BWaSpRpp.js.map +1 -0
  485. package/dist/plsql-DXyBT3AN.js +8 -0
  486. package/dist/plsql-DXyBT3AN.js.map +1 -0
  487. package/dist/po-Duw5KTH-.js +8 -0
  488. package/dist/po-Duw5KTH-.js.map +1 -0
  489. package/dist/poimandres-DtrtfOBO.js +6 -0
  490. package/dist/poimandres-DtrtfOBO.js.map +1 -0
  491. package/dist/polar-C9ZZjIU6.js +8 -0
  492. package/dist/polar-C9ZZjIU6.js.map +1 -0
  493. package/dist/{popover-C2w2uRlu.js → popover-CHafAVT6.js} +22 -20
  494. package/dist/{popover-C2w2uRlu.js.map → popover-CHafAVT6.js.map} +1 -1
  495. package/dist/postcss-D9nF9Ns4.js +8 -0
  496. package/dist/postcss-D9nF9Ns4.js.map +1 -0
  497. package/dist/powerquery-Bf1siwRH.js +8 -0
  498. package/dist/powerquery-Bf1siwRH.js.map +1 -0
  499. package/dist/powershell-DbLFMYnO.js +8 -0
  500. package/dist/powershell-DbLFMYnO.js.map +1 -0
  501. package/dist/primitives/accordion.js +1 -1
  502. package/dist/primitives/alert-dialog.js +1 -1
  503. package/dist/primitives/autocomplete.js +1 -1
  504. package/dist/primitives/avatar.js +1 -1
  505. package/dist/primitives/button.js +1 -1
  506. package/dist/primitives/checkbox-group.js +1 -1
  507. package/dist/primitives/checkbox.js +1 -1
  508. package/dist/primitives/collapsible.js +1 -1
  509. package/dist/primitives/combobox.js +1 -1
  510. package/dist/primitives/context-menu.js +1 -1
  511. package/dist/primitives/csp-provider.js +6 -0
  512. package/dist/primitives/csp-provider.js.map +1 -0
  513. package/dist/primitives/dialog.js +1 -1
  514. package/dist/primitives/direction-provider.js +1 -1
  515. package/dist/primitives/drawer.js +6 -0
  516. package/dist/primitives/drawer.js.map +1 -0
  517. package/dist/primitives/field.js +1 -1
  518. package/dist/primitives/fieldset.js +2 -2
  519. package/dist/primitives/form.js +1 -1
  520. package/dist/primitives/input.js +1 -1
  521. package/dist/primitives/menu.js +1 -1
  522. package/dist/primitives/menubar.js +1 -1
  523. package/dist/primitives/meter.js +1 -1
  524. package/dist/primitives/navigation-menu.js +2 -2
  525. package/dist/primitives/number-field.js +1 -1
  526. package/dist/primitives/popover.js +1 -1
  527. package/dist/primitives/preview-card.js +2 -2
  528. package/dist/primitives/progress.js +2 -2
  529. package/dist/primitives/radio-group.js +1 -1
  530. package/dist/primitives/radio.js +2 -2
  531. package/dist/primitives/scroll-area.js +1 -1
  532. package/dist/primitives/select.js +1 -1
  533. package/dist/primitives/separator.js +1 -1
  534. package/dist/primitives/slider.js +1 -1
  535. package/dist/primitives/switch.js +1 -1
  536. package/dist/primitives/tabs.js +1 -1
  537. package/dist/primitives/toast.js +1 -1
  538. package/dist/primitives/toggle-group.js +1 -1
  539. package/dist/primitives/toggle.js +1 -1
  540. package/dist/primitives/toolbar.js +1 -1
  541. package/dist/primitives/tooltip.js +1 -1
  542. package/dist/primitives.js +31 -29
  543. package/dist/prisma-DQmdODpM.js +8 -0
  544. package/dist/prisma-DQmdODpM.js.map +1 -0
  545. package/dist/prolog-BhDhfNq2.js +8 -0
  546. package/dist/prolog-BhDhfNq2.js.map +1 -0
  547. package/dist/proto-8YBPwIZV.js +8 -0
  548. package/dist/proto-8YBPwIZV.js.map +1 -0
  549. package/dist/pug-Cd1k_DIC.js +14 -0
  550. package/dist/pug-Cd1k_DIC.js.map +1 -0
  551. package/dist/puppet-DWeotfji.js +8 -0
  552. package/dist/puppet-DWeotfji.js.map +1 -0
  553. package/dist/purescript-BlRfpTfS.js +8 -0
  554. package/dist/purescript-BlRfpTfS.js.map +1 -0
  555. package/dist/python--QhWBEuB.js +8 -0
  556. package/dist/python--QhWBEuB.js.map +1 -0
  557. package/dist/qml-D5YeakZo.js +10 -0
  558. package/dist/qml-D5YeakZo.js.map +1 -0
  559. package/dist/qmldir-Cvb9I9Hu.js +8 -0
  560. package/dist/qmldir-Cvb9I9Hu.js.map +1 -0
  561. package/dist/qss-MOxpdvNy.js +8 -0
  562. package/dist/qss-MOxpdvNy.js.map +1 -0
  563. package/dist/r-CPa3sP0i.js +8 -0
  564. package/dist/r-CPa3sP0i.js.map +1 -0
  565. package/dist/racket-u4Z5W-hW.js +8 -0
  566. package/dist/racket-u4Z5W-hW.js.map +1 -0
  567. package/dist/{radio-B8Jk1PFe.js → radio-DZ1uS-zK.js} +29 -29
  568. package/dist/{radio-B8Jk1PFe.js.map → radio-DZ1uS-zK.js.map} +1 -1
  569. package/dist/raku-DD1-d8EI.js +8 -0
  570. package/dist/raku-DD1-d8EI.js.map +1 -0
  571. package/dist/razor-CvgW6g5F.js +12 -0
  572. package/dist/razor-CvgW6g5F.js.map +1 -0
  573. package/dist/red-nqtx3ZzA.js +6 -0
  574. package/dist/red-nqtx3ZzA.js.map +1 -0
  575. package/dist/reg-D39ozI4Z.js +8 -0
  576. package/dist/reg-D39ozI4Z.js.map +1 -0
  577. package/dist/regexp-C-mTs3Xt.js +8 -0
  578. package/dist/regexp-C-mTs3Xt.js.map +1 -0
  579. package/dist/rel-CvIujmyu.js +8 -0
  580. package/dist/rel-CvIujmyu.js.map +1 -0
  581. package/dist/riscv-BDw_rTFU.js +8 -0
  582. package/dist/riscv-BDw_rTFU.js.map +1 -0
  583. package/dist/ron-Dr-HoCkP.js +8 -0
  584. package/dist/ron-Dr-HoCkP.js.map +1 -0
  585. package/dist/rose-pine-Ca6P34ai.js +6 -0
  586. package/dist/rose-pine-Ca6P34ai.js.map +1 -0
  587. package/dist/rose-pine-dawn-CSsyidmk.js +6 -0
  588. package/dist/rose-pine-dawn-CSsyidmk.js.map +1 -0
  589. package/dist/rose-pine-moon-DFcWGQ4j.js +6 -0
  590. package/dist/rose-pine-moon-DFcWGQ4j.js.map +1 -0
  591. package/dist/rosmsg-D3QLmOd5.js +8 -0
  592. package/dist/rosmsg-D3QLmOd5.js.map +1 -0
  593. package/dist/rst-BVJfTGcR.js +24 -0
  594. package/dist/rst-BVJfTGcR.js.map +1 -0
  595. package/dist/ruby-0gZcrdnG.js +32 -0
  596. package/dist/ruby-0gZcrdnG.js.map +1 -0
  597. package/dist/rust-CiVdiDo-.js +8 -0
  598. package/dist/rust-CiVdiDo-.js.map +1 -0
  599. package/dist/sas-Df_jutC7.js +10 -0
  600. package/dist/sas-Df_jutC7.js.map +1 -0
  601. package/dist/sass-CnN1LcIf.js +8 -0
  602. package/dist/sass-CnN1LcIf.js.map +1 -0
  603. package/dist/scala-D_7p1-Ff.js +8 -0
  604. package/dist/scala-D_7p1-Ff.js.map +1 -0
  605. package/dist/scheme-kuKKlndT.js +8 -0
  606. package/dist/scheme-kuKKlndT.js.map +1 -0
  607. package/dist/scripts/theme-generator/config.d.ts +6 -0
  608. package/dist/scripts/theme-generator/config.d.ts.map +1 -0
  609. package/dist/scripts/theme-generator/config.js +394 -0
  610. package/dist/scripts/theme-generator/config.js.map +1 -0
  611. package/dist/scripts/theme-generator/generate-css.d.ts +31 -0
  612. package/dist/scripts/theme-generator/generate-css.d.ts.map +1 -0
  613. package/dist/scripts/theme-generator/index.d.ts +13 -0
  614. package/dist/scripts/theme-generator/index.d.ts.map +1 -0
  615. package/dist/scripts/theme-generator/migrate.d.ts +56 -0
  616. package/dist/scripts/theme-generator/migrate.d.ts.map +1 -0
  617. package/dist/scripts/theme-generator/types.d.ts +76 -0
  618. package/dist/scripts/theme-generator/types.d.ts.map +1 -0
  619. package/dist/scripts/theme-generator/types.js +2 -0
  620. package/dist/scripts/theme-generator/types.js.map +1 -0
  621. package/dist/scss-Cnx3ZIbn.js +10 -0
  622. package/dist/scss-Cnx3ZIbn.js.map +1 -0
  623. package/dist/sdbl-C99B6EXT.js +8 -0
  624. package/dist/sdbl-C99B6EXT.js.map +1 -0
  625. package/dist/select-BXZAlFAV.js +113 -0
  626. package/dist/select-BXZAlFAV.js.map +1 -0
  627. package/dist/{sensitive-input-CgjTfZLO.js → sensitive-input-CI-gtdfw.js} +4 -4
  628. package/dist/{sensitive-input-CgjTfZLO.js.map → sensitive-input-CI-gtdfw.js.map} +1 -1
  629. package/dist/shaderlab-r5kupfNY.js +10 -0
  630. package/dist/shaderlab-r5kupfNY.js.map +1 -0
  631. package/dist/shellscript-C9yrawww.js +8 -0
  632. package/dist/shellscript-C9yrawww.js.map +1 -0
  633. package/dist/shellsession-Vfxwd5pt.js +10 -0
  634. package/dist/shellsession-Vfxwd5pt.js.map +1 -0
  635. package/dist/slack-dark-DPwE-fTd.js +6 -0
  636. package/dist/slack-dark-DPwE-fTd.js.map +1 -0
  637. package/dist/slack-ochin-XQpb-bu3.js +6 -0
  638. package/dist/slack-ochin-XQpb-bu3.js.map +1 -0
  639. package/dist/smalltalk-DBHjpWnU.js +8 -0
  640. package/dist/smalltalk-DBHjpWnU.js.map +1 -0
  641. package/dist/snazzy-light-B301-rZ_.js +6 -0
  642. package/dist/snazzy-light-B301-rZ_.js.map +1 -0
  643. package/dist/solarized-dark-Bmasqmd6.js +6 -0
  644. package/dist/solarized-dark-Bmasqmd6.js.map +1 -0
  645. package/dist/solarized-light-D79sTVew.js +6 -0
  646. package/dist/solarized-light-D79sTVew.js.map +1 -0
  647. package/dist/solidity-DiELThdT.js +8 -0
  648. package/dist/solidity-DiELThdT.js.map +1 -0
  649. package/dist/soy-JFzJcdvc.js +10 -0
  650. package/dist/soy-JFzJcdvc.js.map +1 -0
  651. package/dist/sparql-DFkbfk9m.js +10 -0
  652. package/dist/sparql-DFkbfk9m.js.map +1 -0
  653. package/dist/splunk-D_3lOa0g.js +8 -0
  654. package/dist/splunk-D_3lOa0g.js.map +1 -0
  655. package/dist/sql-BUQKMpen.js +8 -0
  656. package/dist/sql-BUQKMpen.js.map +1 -0
  657. package/dist/src/code/code-highlighted.d.ts +32 -0
  658. package/dist/src/code/code-highlighted.d.ts.map +1 -0
  659. package/dist/src/code/context.d.ts +16 -0
  660. package/dist/src/code/context.d.ts.map +1 -0
  661. package/dist/src/code/index.d.ts +31 -0
  662. package/dist/src/code/index.d.ts.map +1 -0
  663. package/dist/src/code/provider.d.ts +7 -0
  664. package/dist/src/code/provider.d.ts.map +1 -0
  665. package/dist/src/code/server.d.ts +96 -0
  666. package/dist/src/code/server.d.ts.map +1 -0
  667. package/dist/src/code/types.d.ts +89 -0
  668. package/dist/src/code/types.d.ts.map +1 -0
  669. package/dist/src/code/use-shiki-highlighter.d.ts +36 -0
  670. package/dist/src/code/use-shiki-highlighter.d.ts.map +1 -0
  671. package/dist/src/command-line/commands/add.d.ts.map +1 -1
  672. package/dist/src/components/badge/badge.d.ts +4 -0
  673. package/dist/src/components/badge/badge.d.ts.map +1 -1
  674. package/dist/src/components/breadcrumbs/breadcrumbs.d.ts.map +1 -1
  675. package/dist/src/components/chart/Color.d.ts +96 -0
  676. package/dist/src/components/chart/Color.d.ts.map +1 -0
  677. package/dist/src/components/chart/EChart.d.ts +130 -0
  678. package/dist/src/components/chart/EChart.d.ts.map +1 -0
  679. package/dist/src/components/chart/Legend.d.ts +42 -0
  680. package/dist/src/components/chart/Legend.d.ts.map +1 -0
  681. package/dist/src/components/chart/TimeseriesChart.d.ts +94 -0
  682. package/dist/src/components/chart/TimeseriesChart.d.ts.map +1 -0
  683. package/dist/src/components/chart/index.d.ts +5 -0
  684. package/dist/src/components/chart/index.d.ts.map +1 -0
  685. package/dist/src/components/code/code.d.ts +19 -0
  686. package/dist/src/components/code/code.d.ts.map +1 -1
  687. package/dist/src/components/combobox/combobox.d.ts +33 -2
  688. package/dist/src/components/combobox/combobox.d.ts.map +1 -1
  689. package/dist/src/components/dialog/dialog.d.ts +41 -2
  690. package/dist/src/components/dialog/dialog.d.ts.map +1 -1
  691. package/dist/src/components/dropdown/dropdown.d.ts +26 -16
  692. package/dist/src/components/dropdown/dropdown.d.ts.map +1 -1
  693. package/dist/src/components/flow/connectors.d.ts +3 -1
  694. package/dist/src/components/flow/connectors.d.ts.map +1 -1
  695. package/dist/src/components/flow/diagram.d.ts +9 -0
  696. package/dist/src/components/flow/diagram.d.ts.map +1 -1
  697. package/dist/src/components/flow/node.d.ts +5 -1
  698. package/dist/src/components/flow/node.d.ts.map +1 -1
  699. package/dist/src/components/flow/parallel.d.ts +10 -2
  700. package/dist/src/components/flow/parallel.d.ts.map +1 -1
  701. package/dist/src/components/flow/use-children.d.ts +8 -1
  702. package/dist/src/components/flow/use-children.d.ts.map +1 -1
  703. package/dist/src/components/pagination/pagination.d.ts +134 -13
  704. package/dist/src/components/pagination/pagination.d.ts.map +1 -1
  705. package/dist/src/components/popover/popover.d.ts +7 -1
  706. package/dist/src/components/popover/popover.d.ts.map +1 -1
  707. package/dist/src/components/select/select.d.ts.map +1 -1
  708. package/dist/src/components/table/table.d.ts +3 -1
  709. package/dist/src/components/table/table.d.ts.map +1 -1
  710. package/dist/src/components/toast/toast.d.ts +4 -4
  711. package/dist/src/components/toast/toast.d.ts.map +1 -1
  712. package/dist/src/components/tooltip/tooltip.d.ts +1 -1
  713. package/dist/src/components/tooltip/tooltip.d.ts.map +1 -1
  714. package/dist/src/index.d.ts +1 -0
  715. package/dist/src/index.d.ts.map +1 -1
  716. package/dist/src/primitives/csp-provider.d.ts +13 -0
  717. package/dist/src/primitives/csp-provider.d.ts.map +1 -0
  718. package/dist/src/primitives/drawer.d.ts +13 -0
  719. package/dist/src/primitives/drawer.d.ts.map +1 -0
  720. package/dist/src/primitives/index.d.ts +2 -0
  721. package/dist/src/primitives/index.d.ts.map +1 -1
  722. package/dist/ssh-config-DNaBVjVu.js +8 -0
  723. package/dist/ssh-config-DNaBVjVu.js.map +1 -0
  724. package/dist/stata-DLB0gsgJ.js +10 -0
  725. package/dist/stata-DLB0gsgJ.js.map +1 -0
  726. package/dist/styles/kumo-binding.css +12 -0
  727. package/dist/styles/kumo-standalone.css +1 -1
  728. package/dist/styles/kumo.css +67 -0
  729. package/dist/styles/theme-kumo.css +11 -1
  730. package/dist/stylus-D51fN9sH.js +8 -0
  731. package/dist/stylus-D51fN9sH.js.map +1 -0
  732. package/dist/surrealql-sFzY-ODM.js +10 -0
  733. package/dist/surrealql-sFzY-ODM.js.map +1 -0
  734. package/dist/svelte-CvDgWedh.js +16 -0
  735. package/dist/svelte-CvDgWedh.js.map +1 -0
  736. package/dist/swift-DwwnjRI-.js +8 -0
  737. package/dist/swift-DwwnjRI-.js.map +1 -0
  738. package/dist/{switch-DdjM7eh6.js → switch-BxnAwAse.js} +15 -15
  739. package/dist/{switch-DdjM7eh6.js.map → switch-BxnAwAse.js.map} +1 -1
  740. package/dist/synthwave-84-H0OiUA6S.js +6 -0
  741. package/dist/synthwave-84-H0OiUA6S.js.map +1 -0
  742. package/dist/system-verilog-Crpmwi64.js +8 -0
  743. package/dist/system-verilog-Crpmwi64.js.map +1 -0
  744. package/dist/systemd-DpPksTVO.js +8 -0
  745. package/dist/systemd-DpPksTVO.js.map +1 -0
  746. package/dist/{table-D1EXUDHL.js → table-CdcsAm5X.js} +39 -33
  747. package/dist/table-CdcsAm5X.js.map +1 -0
  748. package/dist/{tabs-Bs43O3E4.js → tabs-Cf12PXHz.js} +6 -6
  749. package/dist/tabs-Cf12PXHz.js.map +1 -0
  750. package/dist/talonscript-C0B9tdh0.js +8 -0
  751. package/dist/talonscript-C0B9tdh0.js.map +1 -0
  752. package/dist/tasl-De-6_1ux.js +8 -0
  753. package/dist/tasl-De-6_1ux.js.map +1 -0
  754. package/dist/tcl-tdOXVFhT.js +8 -0
  755. package/dist/tcl-tdOXVFhT.js.map +1 -0
  756. package/dist/templ-D3k0ETqq.js +14 -0
  757. package/dist/templ-D3k0ETqq.js.map +1 -0
  758. package/dist/terraform-C65cvXJK.js +8 -0
  759. package/dist/terraform-C65cvXJK.js.map +1 -0
  760. package/dist/tex-4pYKQzZ9.js +10 -0
  761. package/dist/tex-4pYKQzZ9.js.map +1 -0
  762. package/dist/{toast-BqZw7a2p.js → toast-BzvG5cpW.js} +10 -10
  763. package/dist/{toast-BqZw7a2p.js.map → toast-BzvG5cpW.js.map} +1 -1
  764. package/dist/tokyo-night-BcIcd5FP.js +6 -0
  765. package/dist/tokyo-night-BcIcd5FP.js.map +1 -0
  766. package/dist/toml-BTLaxjFB.js +8 -0
  767. package/dist/toml-BTLaxjFB.js.map +1 -0
  768. package/dist/{tooltip-BwOFPK5h.js → tooltip-2KqOpTj0.js} +2 -2
  769. package/dist/{tooltip-BwOFPK5h.js.map → tooltip-2KqOpTj0.js.map} +1 -1
  770. package/dist/ts-tags-DeeA5bAv.js +43 -0
  771. package/dist/ts-tags-DeeA5bAv.js.map +1 -0
  772. package/dist/tsv-BSiNlNds.js +8 -0
  773. package/dist/tsv-BSiNlNds.js.map +1 -0
  774. package/dist/tsx-1QZ5GNk-.js +8 -0
  775. package/dist/tsx-1QZ5GNk-.js.map +1 -0
  776. package/dist/turtle-B1Pzn5av.js +8 -0
  777. package/dist/turtle-B1Pzn5av.js.map +1 -0
  778. package/dist/twig-C2HueQmu.js +20 -0
  779. package/dist/twig-C2HueQmu.js.map +1 -0
  780. package/dist/typescript-CLMZXfG9.js +8 -0
  781. package/dist/typescript-CLMZXfG9.js.map +1 -0
  782. package/dist/typespec-C5gqdlO4.js +8 -0
  783. package/dist/typespec-C5gqdlO4.js.map +1 -0
  784. package/dist/typst-pX4dU_Sd.js +8 -0
  785. package/dist/typst-pX4dU_Sd.js.map +1 -0
  786. package/dist/v-C_UlMRpP.js +8 -0
  787. package/dist/v-C_UlMRpP.js.map +1 -0
  788. package/dist/vala-B0RfnRiT.js +8 -0
  789. package/dist/vala-B0RfnRiT.js.map +1 -0
  790. package/dist/vb-DYbmUkLw.js +8 -0
  791. package/dist/vb-DYbmUkLw.js.map +1 -0
  792. package/dist/vendor-base-ui-DvXlzG7n.js +22807 -0
  793. package/dist/vendor-base-ui-DvXlzG7n.js.map +1 -0
  794. package/dist/{vendor-utils-DD8jNJwD.js → vendor-utils-DKXfkDYu.js} +100 -101
  795. package/dist/vendor-utils-DKXfkDYu.js.map +1 -0
  796. package/dist/verilog-BUqLwf8h.js +8 -0
  797. package/dist/verilog-BUqLwf8h.js.map +1 -0
  798. package/dist/vesper-BW8Q9P3p.js +6 -0
  799. package/dist/vesper-BW8Q9P3p.js.map +1 -0
  800. package/dist/vhdl-e6zXgkQJ.js +8 -0
  801. package/dist/vhdl-e6zXgkQJ.js.map +1 -0
  802. package/dist/viml-Bw7DMabC.js +8 -0
  803. package/dist/viml-Bw7DMabC.js.map +1 -0
  804. package/dist/vitesse-black-BBGvp4RB.js +6 -0
  805. package/dist/vitesse-black-BBGvp4RB.js.map +1 -0
  806. package/dist/vitesse-dark-qcbI9VBy.js +6 -0
  807. package/dist/vitesse-dark-qcbI9VBy.js.map +1 -0
  808. package/dist/vitesse-light-BL2wQDaR.js +6 -0
  809. package/dist/vitesse-light-BL2wQDaR.js.map +1 -0
  810. package/dist/vue-DKeMdoTK.js +33 -0
  811. package/dist/vue-DKeMdoTK.js.map +1 -0
  812. package/dist/vue-html-CEfeAKp2.js +10 -0
  813. package/dist/vue-html-CEfeAKp2.js.map +1 -0
  814. package/dist/vue-vine-CjuPBhXu.js +20 -0
  815. package/dist/vue-vine-CjuPBhXu.js.map +1 -0
  816. package/dist/vyper-Dc9KcbZ_.js +8 -0
  817. package/dist/vyper-Dc9KcbZ_.js.map +1 -0
  818. package/dist/wasm-Bae8j78o.js +8 -0
  819. package/dist/wasm-Bae8j78o.js.map +1 -0
  820. package/dist/wasm-D5B682Xt.js +9 -0
  821. package/dist/wasm-D5B682Xt.js.map +1 -0
  822. package/dist/wenyan-j7Mu9-Zf.js +8 -0
  823. package/dist/wenyan-j7Mu9-Zf.js.map +1 -0
  824. package/dist/wgsl-DEgz941F.js +8 -0
  825. package/dist/wgsl-DEgz941F.js.map +1 -0
  826. package/dist/wikitext-CFdiH6zG.js +8 -0
  827. package/dist/wikitext-CFdiH6zG.js.map +1 -0
  828. package/dist/wit-CQDxIROw.js +8 -0
  829. package/dist/wit-CQDxIROw.js.map +1 -0
  830. package/dist/wolfram-BkETUL8d.js +8 -0
  831. package/dist/wolfram-BkETUL8d.js.map +1 -0
  832. package/dist/xml-CKSarKBc.js +10 -0
  833. package/dist/xml-CKSarKBc.js.map +1 -0
  834. package/dist/xsl-oImqe_65.js +10 -0
  835. package/dist/xsl-oImqe_65.js.map +1 -0
  836. package/dist/yaml-CqFcuW2H.js +8 -0
  837. package/dist/yaml-CqFcuW2H.js.map +1 -0
  838. package/dist/zenscript-DfbVeZ74.js +8 -0
  839. package/dist/zenscript-DfbVeZ74.js.map +1 -0
  840. package/dist/zig--LeFnMpj.js +8 -0
  841. package/dist/zig--LeFnMpj.js.map +1 -0
  842. package/package.json +42 -11
  843. package/scripts/css-build.ts +5 -1
  844. package/scripts/theme-generator/config.ts +19 -1
  845. package/dist/badge-Dc99vsfo.js.map +0 -1
  846. package/dist/breadcrumbs-DyKi7BcP.js +0 -132
  847. package/dist/breadcrumbs-DyKi7BcP.js.map +0 -1
  848. package/dist/checkbox-BUV90tNU.js.map +0 -1
  849. package/dist/clipboard-text-BVKGunue.js.map +0 -1
  850. package/dist/combobox-DyTgHki4.js +0 -250
  851. package/dist/combobox-DyTgHki4.js.map +0 -1
  852. package/dist/command-palette-B2hkPSQm.js.map +0 -1
  853. package/dist/dialog-B2EHaSoL.js +0 -97
  854. package/dist/dialog-B2EHaSoL.js.map +0 -1
  855. package/dist/dropdown-mGDt95gv.js +0 -263
  856. package/dist/dropdown-mGDt95gv.js.map +0 -1
  857. package/dist/input-group-CMAvOKIV.js.map +0 -1
  858. package/dist/menubar-bgBP3EJi.js.map +0 -1
  859. package/dist/pagination-dNzgZRjV.js +0 -100
  860. package/dist/pagination-dNzgZRjV.js.map +0 -1
  861. package/dist/schemas-DKFFjjzb.js.map +0 -1
  862. package/dist/select-BWTULnCR.js +0 -122
  863. package/dist/select-BWTULnCR.js.map +0 -1
  864. package/dist/table-D1EXUDHL.js.map +0 -1
  865. package/dist/tabs-Bs43O3E4.js.map +0 -1
  866. package/dist/vendor-base-ui-B61LL9jT.js +0 -20448
  867. package/dist/vendor-base-ui-B61LL9jT.js.map +0 -1
  868. package/dist/vendor-utils-DD8jNJwD.js.map +0 -1
  869. /package/dist/{src/blocks → blocks-source}/delete-resource/delete-resource.tsx +0 -0
  870. /package/dist/{src/blocks → blocks-source}/page-header/page-header.tsx +0 -0
  871. /package/dist/{src/blocks → blocks-source}/resource-list/resource-list.test.tsx +0 -0
  872. /package/dist/{src/blocks → blocks-source}/resource-list/resource-list.tsx +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"file":"checkbox-BUV90tNU.js","sources":["../src/components/checkbox/checkbox.tsx"],"sourcesContent":["import { forwardRef, createContext, useContext, type ReactNode } from \"react\";\nimport { CheckIcon, MinusIcon } from \"@phosphor-icons/react\";\nimport { cn } from \"../../utils/cn\";\nimport { Label } from \"../label\";\nimport { Fieldset } from \"@base-ui/react/fieldset\";\nimport { Field as FieldBase } from \"@base-ui/react/field\";\nimport { CheckboxGroup as BaseCheckboxGroup } from \"@base-ui/react/checkbox-group\";\nimport {\n Checkbox as BaseCheckbox,\n type CheckboxRootChangeEventDetails,\n} from \"@base-ui/react/checkbox\";\n\n/** Checkbox variant definitions mapping variant names to their Tailwind classes. */\nexport const KUMO_CHECKBOX_VARIANTS = {\n variant: {\n default: {\n classes:\n \"[&:focus-within>span]:ring-kumo-ring [&:hover>span]:ring-kumo-ring\",\n description: \"Default checkbox appearance\",\n },\n error: {\n classes: \"[&>span]:ring-kumo-danger\",\n description: \"Error state for validation failures\",\n },\n },\n} as const;\n\nexport const KUMO_CHECKBOX_DEFAULT_VARIANTS = {\n variant: \"default\",\n} as const;\n\n// Derived types from KUMO_CHECKBOX_VARIANTS\nexport type KumoCheckboxVariant = keyof typeof KUMO_CHECKBOX_VARIANTS.variant;\n\nexport interface KumoCheckboxVariantsProps {\n /**\n * Visual variant.\n * - `\"default\"` — Standard checkbox appearance\n * - `\"error\"` — Error state for validation failures\n * @default \"default\"\n */\n variant?: KumoCheckboxVariant;\n}\n\nexport function checkboxVariants({\n variant = KUMO_CHECKBOX_DEFAULT_VARIANTS.variant,\n}: KumoCheckboxVariantsProps = {}) {\n return cn(KUMO_CHECKBOX_VARIANTS.variant[variant].classes);\n}\n\n// Legacy type alias for backwards compatibility\nexport type CheckboxVariant = KumoCheckboxVariant;\n\n// Context for passing controlFirst from Group to Items\nconst CheckboxGroupContext = createContext<{ controlFirst: boolean }>({\n controlFirst: true,\n});\n\n/**\n * Single checkbox component props with accessibility guidance.\n *\n * **Accessible Name Required:** Checkbox should have one of:\n * 1. `label` prop (recommended) - built-in Field wrapper with horizontal layout\n * 2. `aria-label` - for checkboxes without visible label\n * 3. `aria-labelledby` - for custom label association\n *\n * **Note:** When used inside Checkbox.Group or Dropdown, label is optional (parent provides context).\n *\n * Missing accessible names will trigger console warnings in development (unless inside a group).\n *\n * @example\n * // Recommended: Built-in Field wrapper with label\n * <Checkbox label=\"Accept terms and conditions\" />\n *\n * @example\n * // Control-first layout (checkbox before label)\n * <Checkbox label=\"Remember me\" controlFirst={true} />\n *\n * @example\n * // Label-first layout (label before checkbox)\n * <Checkbox label=\"Enable notifications\" controlFirst={false} />\n *\n * @example\n * // Error variant (visual only, no error text for single checkboxes)\n * <Checkbox label=\"Required field\" variant=\"error\" />\n *\n * @example\n * // Without visible label (aria-label required)\n * <Checkbox aria-label=\"Select all items\" />\n *\n * @example\n * // Custom label association\n * <label id=\"terms-label\">I accept the terms</label>\n * <Checkbox aria-labelledby=\"terms-label\" />\n *\n * @example\n * // Inside Checkbox.Group (label optional)\n * <Checkbox.Group legend=\"Preferences\">\n * <Checkbox.Item value=\"email\" label=\"Email notifications\" />\n * <Checkbox.Item value=\"sms\" label=\"SMS notifications\" />\n * </Checkbox.Group>\n */\nexport type CheckboxProps = {\n /** Visual variant: \"default\" or \"error\" for validation failures (visual only, no error text) */\n variant?: CheckboxVariant;\n /** Label content for the checkbox (enables built-in Field wrapper) - can be a string or any React node */\n label?: ReactNode;\n /** Tooltip content to display next to the label via an info icon */\n labelTooltip?: ReactNode;\n /** When true (default), checkbox appears before label. When false, label appears before checkbox. */\n controlFirst?: boolean;\n /** Whether the checkbox is checked (controlled) */\n checked?: boolean;\n /** Whether the checkbox is in indeterminate state */\n indeterminate?: boolean;\n /** Whether the checkbox is disabled */\n disabled?: boolean;\n /** Callback when the checked state changes */\n onCheckedChange?: (checked: boolean) => void;\n /** @deprecated Use onCheckedChange instead */\n onValueChange?: (checked: boolean) => void;\n /** @deprecated Use onCheckedChange instead */\n onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void;\n /** Click handler */\n onClick?: (event: React.MouseEvent) => void;\n /** Name for form submission */\n name?: string;\n /** Whether the field is required */\n required?: boolean;\n /** Additional class name */\n className?: string;\n /** Accessible label when no visible label is provided */\n \"aria-label\"?: string;\n /** ID of element that labels this checkbox */\n \"aria-labelledby\"?: string;\n};\n\n/**\n * Checkbox group component props (with built-in Fieldset and CheckboxGroup)\n *\n * Usage:\n * ```tsx\n * <Checkbox.Group\n * legend=\"Choose preferences\"\n * defaultValue={['email']}\n * error=\"You must select at least one option\"\n * >\n * <Checkbox.Item label=\"Email notifications\" value=\"email\" />\n * <Checkbox.Item label=\"SMS notifications\" value=\"sms\" />\n * </Checkbox.Group>\n * ```\n */\nexport interface CheckboxGroupProps {\n /** Legend text for the group */\n legend: string;\n /** Child Checkbox.Item components */\n children: ReactNode;\n /** Error message for the group (only appears in groups, not single checkboxes) */\n error?: string;\n /** Helper text for the group */\n description?: ReactNode;\n /** Values of checkboxes that should be initially checked (uncontrolled) */\n defaultValue?: string[];\n /** Values of checkboxes that should be checked (controlled) */\n value?: string[];\n /** Event handler called when checkbox values change */\n onValueChange?: (value: string[]) => void;\n /** All possible checkbox values (required for parent checkbox pattern) */\n allValues?: string[];\n /** Whether all checkboxes in the group are disabled */\n disabled?: boolean;\n /** When true (default), checkbox appears before label. When false, label appears before checkbox. */\n controlFirst?: boolean;\n /** Additional CSS classes */\n className?: string;\n}\n\n/**\n * Individual checkbox item within a group\n */\nexport type CheckboxItemProps = {\n /** Visual variant: \"default\" or \"error\" for validation failures */\n variant?: CheckboxVariant;\n /** Label text displayed next to checkbox */\n label: string;\n /** Value of the checkbox (required when used in Checkbox.Group) */\n value?: string;\n /** Additional CSS classes for the label wrapper */\n className?: string;\n checked?: boolean;\n indeterminate?: boolean;\n disabled?: boolean;\n /** Callback when the checked state changes */\n onCheckedChange?: (checked: boolean) => void;\n /** @deprecated Use onCheckedChange instead */\n onValueChange?: (checked: boolean) => void;\n name?: string;\n};\n\n// Single checkbox with built-in Field\nconst CheckboxBase = forwardRef<HTMLButtonElement, CheckboxProps>(\n (\n {\n className,\n checked,\n indeterminate,\n disabled,\n variant = \"default\",\n label,\n labelTooltip,\n controlFirst = true,\n onCheckedChange,\n onValueChange,\n onChange,\n required,\n name,\n ...props\n },\n ref,\n ) => {\n // A11y enforcement: warn in dev if no accessible name provided\n if (process.env.NODE_ENV !== \"production\") {\n const hasLabel = Boolean(label);\n const hasAriaLabel = Boolean(props[\"aria-label\"]);\n const hasAriaLabelledBy = Boolean(props[\"aria-labelledby\"]);\n\n if (!hasLabel && !hasAriaLabel && !hasAriaLabelledBy) {\n console.warn(\n \"[Kumo Checkbox]: Checkbox must have an accessible name. Provide either:\\n\" +\n \" - label prop: <Checkbox label='Accept terms' />\\n\" +\n \" - aria-label: <Checkbox aria-label='Select item' />\\n\" +\n \" - aria-labelledby for custom label association\\n\" +\n \" Note: When used inside Checkbox.Group, label is optional\",\n );\n }\n }\n\n // Handle onCheckedChange (preferred) and deprecated onValueChange/onChange\n const handleCheckedChange = (\n newChecked: boolean,\n eventDetails: CheckboxRootChangeEventDetails,\n ) => {\n onCheckedChange?.(newChecked);\n onValueChange?.(newChecked);\n if (onChange) {\n // Backwards compatibility: extend native event with target.checked\n // so existing code using `e.target.checked` continues to work\n const event = Object.assign(eventDetails.event, {\n target: { checked: newChecked },\n });\n onChange(event as never);\n }\n };\n\n const checkboxControl = (\n <BaseCheckbox.Root\n ref={ref}\n name={name}\n checked={checked}\n indeterminate={indeterminate}\n disabled={disabled}\n onCheckedChange={handleCheckedChange}\n className={cn(\n \"flex h-4 w-4 items-center justify-center rounded-sm border-0 bg-kumo-base ring\",\n variant === \"error\" ? \"ring-kumo-danger\" : \"ring-kumo-line\",\n !disabled && \"hover:ring-kumo-ring focus-visible:ring-kumo-ring\",\n \"data-[checked]:bg-kumo-contrast data-[checked]:ring-kumo-contrast data-[indeterminate]:bg-kumo-contrast data-[indeterminate]:ring-kumo-contrast\",\n disabled && \"cursor-not-allowed opacity-50\",\n className,\n )}\n {...props}\n >\n <BaseCheckbox.Indicator\n className=\"flex items-center justify-center text-kumo-inverse\"\n render={(renderProps, state) => {\n const Icon = state.indeterminate ? MinusIcon : CheckIcon;\n return (\n <span {...renderProps}>\n {(state.checked || state.indeterminate) && (\n <Icon weight=\"bold\" size={12} />\n )}\n </span>\n );\n }}\n />\n </BaseCheckbox.Root>\n );\n\n // If no label provided, return bare checkbox (for use in other components like Dropdown)\n if (!label) {\n return checkboxControl;\n }\n\n // Use Field.Root + Field.Label enclosing pattern for proper a11y association\n // See: https://base-ui.com/react/components/field\n return (\n <FieldBase.Root className=\"inline-flex\">\n <FieldBase.Label\n className={cn(\n \"inline-flex items-center gap-2\",\n controlFirst ? \"flex-row\" : \"flex-row-reverse justify-end\",\n disabled ? \"cursor-not-allowed\" : \"cursor-pointer\",\n )}\n >\n {checkboxControl}\n <Label\n showOptional={required === false}\n tooltip={labelTooltip}\n asContent\n >\n {label}\n </Label>\n </FieldBase.Label>\n </FieldBase.Root>\n );\n },\n);\n\nCheckboxBase.displayName = \"Checkbox\";\n\n// Checkbox.Item for use within Checkbox.Group\nconst CheckboxItem = forwardRef<HTMLButtonElement, CheckboxItemProps>(\n (\n {\n className,\n checked,\n indeterminate,\n disabled,\n variant = \"default\",\n label,\n value,\n onCheckedChange,\n onValueChange,\n name,\n },\n ref,\n ) => {\n const { controlFirst } = useContext(CheckboxGroupContext);\n\n // Handle onCheckedChange (preferred) and deprecated onValueChange\n const handleCheckedChange = (newChecked: boolean) => {\n onCheckedChange?.(newChecked);\n onValueChange?.(newChecked);\n };\n\n return (\n <label\n className={cn(\n \"relative inline-flex items-center gap-2\",\n // Control first (default): checkbox before label\n // Label first: label before checkbox using flex-row-reverse\n !controlFirst && \"flex-row-reverse justify-end\",\n disabled ? \"cursor-not-allowed opacity-50\" : \"cursor-pointer\",\n className,\n )}\n >\n <BaseCheckbox.Root\n ref={ref}\n value={value}\n name={name}\n checked={checked}\n indeterminate={indeterminate}\n disabled={disabled}\n onCheckedChange={handleCheckedChange}\n className={cn(\n \"peer flex h-4 w-4 items-center justify-center rounded-sm border-0 bg-kumo-base ring\",\n variant === \"error\" ? \"ring-kumo-danger\" : \"ring-kumo-line\",\n !disabled &&\n \"group-hover:ring-kumo-ring hover:ring-kumo-ring focus-visible:ring-kumo-ring\",\n \"data-[checked]:bg-kumo-contrast data-[checked]:ring-kumo-contrast data-[indeterminate]:bg-kumo-contrast data-[indeterminate]:ring-kumo-contrast\",\n )}\n >\n <BaseCheckbox.Indicator\n className=\"flex items-center justify-center text-kumo-inverse\"\n render={(props, state) => {\n const Icon = state.indeterminate ? MinusIcon : CheckIcon;\n return (\n <span {...props}>\n {(state.checked || state.indeterminate) && (\n <Icon weight=\"bold\" size={12} />\n )}\n </span>\n );\n }}\n />\n </BaseCheckbox.Root>\n <span className=\"text-base font-medium text-kumo-default\">{label}</span>\n </label>\n );\n },\n);\n\nCheckboxItem.displayName = \"Checkbox.Item\";\n\n// Checkbox.Group with built-in Fieldset and CheckboxGroup\nfunction CheckboxGroup({\n legend,\n children,\n error,\n description,\n defaultValue,\n value,\n onValueChange,\n allValues,\n disabled,\n controlFirst = true,\n className,\n}: CheckboxGroupProps) {\n return (\n <CheckboxGroupContext.Provider value={{ controlFirst }}>\n <BaseCheckboxGroup\n defaultValue={defaultValue}\n value={value}\n onValueChange={onValueChange}\n allValues={allValues}\n disabled={disabled}\n >\n <Fieldset.Root\n className={cn(\n \"flex flex-col gap-4 rounded-lg border border-kumo-line p-4\",\n className,\n )}\n >\n <Fieldset.Legend className=\"text-lg font-medium text-kumo-default\">\n {legend}\n </Fieldset.Legend>\n <div className=\"flex flex-col gap-2\">{children}</div>\n {error && <p className=\"text-sm text-kumo-danger\">{error}</p>}\n {description && (\n <p className=\"text-sm text-kumo-subtle\">{description}</p>\n )}\n </Fieldset.Root>\n </BaseCheckboxGroup>\n </CheckboxGroupContext.Provider>\n );\n}\n\n// Compound component\nexport const Checkbox = Object.assign(CheckboxBase, {\n Item: CheckboxItem,\n Group: CheckboxGroup,\n});\n\nCheckbox.displayName = \"Checkbox\";\n"],"names":["KUMO_CHECKBOX_VARIANTS","KUMO_CHECKBOX_DEFAULT_VARIANTS","CheckboxGroupContext","createContext","CheckboxBase","forwardRef","className","checked","indeterminate","disabled","variant","label","labelTooltip","controlFirst","onCheckedChange","onValueChange","onChange","required","name","props","ref","hasLabel","hasAriaLabel","hasAriaLabelledBy","checkboxControl","jsx","BaseCheckbox.Root","newChecked","eventDetails","event","cn","BaseCheckbox.Indicator","renderProps","state","Icon","MinusIcon","CheckIcon","FieldBase.Root","jsxs","FieldBase.Label","Label","CheckboxItem","value","useContext","handleCheckedChange","CheckboxGroup","legend","children","error","description","defaultValue","allValues","BaseCheckboxGroup","Fieldset.Root","Fieldset.Legend","Checkbox"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"clipboard-text-BVKGunue.js","sources":["../src/components/clipboard-text/clipboard-text.tsx"],"sourcesContent":["import { CheckIcon, CopyIcon } from \"@phosphor-icons/react\";\nimport { forwardRef, useCallback, useRef, useState } from \"react\";\nimport { Toast } from \"@base-ui/react/toast\";\nimport { Tooltip } from \"@base-ui/react/tooltip\";\nimport { Button } from \"../button\";\nimport { inputVariants } from \"../input\";\nimport { cn } from \"../../utils/cn\";\n\n// Create a toast manager for anchored \"Copied\" toasts\nconst clipboardToastManager = Toast.createToastManager();\n\n/** ClipboardText size variant definitions mapping sizes to their Tailwind classes. */\nexport const KUMO_CLIPBOARD_TEXT_VARIANTS = {\n size: {\n sm: {\n classes: \"text-xs\",\n buttonSize: \"sm\" as const,\n description: \"Small clipboard text for compact UIs\",\n },\n base: {\n classes: \"text-sm\",\n buttonSize: \"base\" as const,\n description: \"Default clipboard text size\",\n },\n lg: {\n classes: \"text-sm\",\n buttonSize: \"lg\" as const,\n description: \"Large clipboard text for prominent display\",\n },\n },\n} as const;\n\nexport const KUMO_CLIPBOARD_TEXT_DEFAULT_VARIANTS = {\n size: \"lg\",\n} as const;\n\nconst clipboardTextAnimations = {\n slide: {\n initial:\n \"pointer-events-none absolute inset-0 flex items-center justify-center opacity-0 translate-y-full\",\n animate: \"translate-y-0 opacity-100\",\n end: \"pointer-events-none absolute inset-0 flex items-center justify-center opacity-0 -translate-y-full\",\n },\n} as const;\n\n// Derived types from KUMO_CLIPBOARD_TEXT_VARIANTS\nexport type KumoClipboardTextSize =\n keyof typeof KUMO_CLIPBOARD_TEXT_VARIANTS.size;\n\nexport interface KumoClipboardTextVariantsProps {\n /**\n * Size of the clipboard text field.\n * - `\"sm\"` — Small clipboard text for compact UIs\n * - `\"base\"` — Default clipboard text size\n * - `\"lg\"` — Large clipboard text for prominent display\n * @default \"lg\"\n */\n size?: KumoClipboardTextSize;\n}\n\nexport function clipboardTextVariants({\n size = KUMO_CLIPBOARD_TEXT_DEFAULT_VARIANTS.size,\n}: KumoClipboardTextVariantsProps = {}) {\n return cn(\n // Base styles\n \"flex items-center overflow-hidden bg-kumo-base px-0 font-mono\",\n // Apply size styles from KUMO_CLIPBOARD_TEXT_VARIANTS\n KUMO_CLIPBOARD_TEXT_VARIANTS.size[size].classes,\n );\n}\n\n// Legacy type alias for backwards compatibility\nexport type ClipboardTextSize = KumoClipboardTextSize;\n\n/**\n * ClipboardText component props.\n *\n * @example\n * ```tsx\n * <ClipboardText text=\"sk_live_abc123\" />\n * <ClipboardText text=\"npm install @cloudflare/kumo\" size=\"sm\" />\n * ```\n */\nexport interface ClipboardTextProps extends KumoClipboardTextVariantsProps {\n /** The text to display and copy to clipboard. */\n text: string;\n /** Additional CSS classes merged via `cn()`. */\n className?: string;\n /** Callback fired after text is copied to clipboard. */\n onCopy?: () => void;\n /**\n * Tooltip config. Shows tooltip on hover, anchored toast on click.\n * @example\n * ```tsx\n * <ClipboardText\n * text=\"abc123\"\n * tooltip={{ text: \"Copy\", copiedText: \"Copied!\", side: \"top\" }}\n * />\n * ```\n */\n tooltip?: {\n /** Text shown in tooltip on hover. @default \"Copy\" */\n text?: string;\n /** Text shown in toast after copying. @default \"Copied\" */\n copiedText?: string;\n /** Tooltip/toast placement. @default \"top\" */\n side?: \"top\" | \"bottom\" | \"left\" | \"right\";\n };\n /** Accessible labels for i18n. */\n labels?: {\n /** @default \"Copy to clipboard\" */\n copyAction?: string;\n };\n}\n\n/**\n * Anchored toasts viewport - renders \"Copied\" toasts anchored to buttons\n */\nfunction AnchoredToasts() {\n const { toasts } = Toast.useToastManager();\n return (\n <Toast.Viewport className=\"pointer-events-none fixed inset-0 z-50\">\n {toasts.map((toast) => (\n <Toast.Positioner key={toast.id} toast={toast} className=\"absolute\">\n <Toast.Root\n toast={toast}\n className={cn(\n \"flex origin-[var(--transform-origin)] flex-col rounded-md bg-kumo-base px-3 py-1.5 text-xs text-kumo-default font-sans\",\n \"shadow-lg shadow-kumo-tip-shadow outline outline-kumo-fill\",\n )}\n >\n <Toast.Description />\n </Toast.Root>\n </Toast.Positioner>\n ))}\n </Toast.Viewport>\n );\n}\n\n/**\n * Internal wrapper that provides Toast context when tooltip is enabled.\n */\nfunction TooltipWrapper({ children }: { children: React.ReactNode }) {\n return (\n <Tooltip.Provider>\n <Toast.Provider toastManager={clipboardToastManager}>\n <AnchoredToasts />\n {children}\n </Toast.Provider>\n </Tooltip.Provider>\n );\n}\n\n/**\n * Read-only text field with a one-click copy-to-clipboard button.\n *\n * @example\n * ```tsx\n * <ClipboardText text=\"0c239dd2\" />\n * ```\n */\nexport const ClipboardText = forwardRef<HTMLDivElement, ClipboardTextProps>(\n (\n {\n text,\n className,\n size = KUMO_CLIPBOARD_TEXT_DEFAULT_VARIANTS.size,\n onCopy,\n tooltip,\n labels: { copyAction = \"Copy to clipboard\" } = {},\n },\n ref,\n ) => {\n const [copied, setCopied] = useState(false);\n const buttonRef = useRef<HTMLButtonElement | null>(null);\n const sizeConfig = KUMO_CLIPBOARD_TEXT_VARIANTS.size[size];\n\n // Destructure tooltip config with defaults\n const {\n text: tooltipText = \"Copy\",\n copiedText = \"Copied\",\n side: tooltipSide = \"top\",\n } = tooltip ?? {};\n\n const copyToClipboard = useCallback(async () => {\n try {\n if (\n typeof navigator !== \"undefined\" &&\n navigator.clipboard &&\n typeof navigator.clipboard.writeText === \"function\"\n ) {\n await navigator.clipboard.writeText(text);\n } else if (typeof document !== \"undefined\") {\n // Fallback for older browsers\n const textarea = document.createElement(\"textarea\");\n textarea.value = text;\n textarea.setAttribute(\"readonly\", \"\");\n textarea.style.position = \"absolute\";\n textarea.style.left = \"-9999px\";\n document.body.appendChild(textarea);\n const selection = document.getSelection();\n const previousRange = selection?.rangeCount\n ? selection.getRangeAt(0)\n : null;\n textarea.select();\n try {\n document.execCommand(\"copy\");\n } finally {\n document.body.removeChild(textarea);\n if (previousRange) {\n selection?.removeAllRanges();\n selection?.addRange(previousRange);\n }\n }\n }\n\n setCopied(true);\n\n // Show anchored toast if tooltip mode is enabled\n if (tooltip) {\n clipboardToastManager.add({\n description: copiedText,\n positionerProps: {\n anchor: buttonRef.current,\n side: tooltipSide,\n sideOffset: 8,\n },\n timeout: 1500,\n onClose() {\n setCopied(false);\n },\n });\n } else {\n // Reset copied state after delay when no tooltip\n setTimeout(() => setCopied(false), 1500);\n }\n\n onCopy?.();\n } catch (error) {\n console.warn(\"Clipboard copy failed\", error);\n }\n }, [text, onCopy, tooltip, copiedText, tooltipSide]);\n\n const copyButton = (\n <Button\n ref={buttonRef}\n size={sizeConfig.buttonSize}\n variant=\"ghost\"\n className=\"rounded-none border-l! border-kumo-line! px-3 relative overflow-hidden transition-all duration-200\"\n onClick={copyToClipboard}\n aria-label={copyAction}\n >\n <span\n className={cn(\n \"flex items-center gap-1 transition-all duration-200\",\n copied\n ? clipboardTextAnimations.slide.animate\n : clipboardTextAnimations.slide.initial,\n )}\n >\n <CheckIcon />\n </span>\n <span\n className={cn(\n \"flex items-center justify-center transition-all duration-200\",\n copied\n ? clipboardTextAnimations.slide.end\n : clipboardTextAnimations.slide.animate,\n )}\n >\n <CopyIcon />\n </span>\n </Button>\n );\n\n return (\n <div\n ref={ref}\n className={cn(\n inputVariants({ size: sizeConfig.buttonSize }),\n clipboardTextVariants({ size }),\n className,\n )}\n >\n <span className=\"grow truncate ps-4 pe-2\">{text}</span>\n {tooltip ? (\n <TooltipWrapper>\n <Tooltip.Root\n disabled={copied}\n onOpenChange={(open, eventDetails) => {\n // Prevent tooltip from closing when button is clicked\n if (eventDetails.reason === \"trigger-press\") {\n eventDetails.cancel();\n }\n }}\n >\n <Tooltip.Trigger render={copyButton} />\n <Tooltip.Portal>\n <Tooltip.Positioner side={tooltipSide} sideOffset={8}>\n <Tooltip.Popup\n className={cn(\n \"flex origin-[var(--transform-origin)] flex-col rounded-md bg-kumo-base px-3 py-1.5 text-xs text-kumo-default\",\n \"shadow-lg shadow-kumo-tip-shadow outline outline-kumo-fill\",\n )}\n >\n {tooltipText}\n </Tooltip.Popup>\n </Tooltip.Positioner>\n </Tooltip.Portal>\n </Tooltip.Root>\n </TooltipWrapper>\n ) : (\n copyButton\n )}\n <span className=\"sr-only\" aria-live=\"polite\">\n {copied ? copiedText : \"\"}\n </span>\n </div>\n );\n },\n);\n\nClipboardText.displayName = \"ClipboardText\";\n"],"names":["clipboardToastManager","Toast.createToastManager","KUMO_CLIPBOARD_TEXT_VARIANTS","KUMO_CLIPBOARD_TEXT_DEFAULT_VARIANTS","clipboardTextAnimations","clipboardTextVariants","size","cn","AnchoredToasts","toasts","Toast.useToastManager","Toast.Viewport","toast","Toast.Positioner","jsx","Toast.Root","Toast.Description","TooltipWrapper","children","Tooltip.Provider","Toast.Provider","ClipboardText","forwardRef","text","className","onCopy","tooltip","copyAction","ref","copied","setCopied","useState","buttonRef","useRef","sizeConfig","tooltipText","copiedText","tooltipSide","copyToClipboard","useCallback","textarea","selection","previousRange","error","copyButton","jsxs","Button","CheckIcon","CopyIcon","inputVariants","Tooltip.Root","open","eventDetails","Tooltip.Trigger","Tooltip.Portal","Tooltip.Positioner","Tooltip.Popup"],"mappings":"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"}
@@ -1,250 +0,0 @@
1
- "use client";
2
- import { jsx as e, jsxs as i } from "react/jsx-runtime";
3
- import { CheckIcon as I, XIcon as p, CaretDownIcon as x } from "@phosphor-icons/react";
4
- import { Fragment as T } from "react";
5
- import { i as b } from "./input-DjItb3_k.js";
6
- import { c as t } from "./cn-Bhsu1vx2.js";
7
- import { F as R } from "./field-Bkh5pJay.js";
8
- import { a3 as j, a4 as G, a5 as L, a6 as V, a7 as F, a8 as P, a9 as u, aa as E, ab as M, ac as W, ad as z, ae as D, af as d, ag as O, ah as h, ai as f, aj as X, ak as _, al as q } from "./vendor-base-ui-B61LL9jT.js";
9
- function g({
10
- label: o,
11
- required: a,
12
- labelTooltip: s,
13
- description: n,
14
- error: r,
15
- children: l,
16
- ...m
17
- }) {
18
- const c = /* @__PURE__ */ e(G, { ...m, children: l });
19
- return o ? /* @__PURE__ */ e(
20
- R,
21
- {
22
- label: o,
23
- required: a,
24
- labelTooltip: s,
25
- description: n,
26
- error: r ? typeof r == "string" ? { message: r, match: !0 } : r : void 0,
27
- children: c
28
- }
29
- ) : c;
30
- }
31
- function C({
32
- children: o,
33
- className: a,
34
- align: s = "start",
35
- sideOffset: n = 4,
36
- alignOffset: r,
37
- side: l
38
- }) {
39
- return /* @__PURE__ */ e(X, { children: /* @__PURE__ */ e(
40
- _,
41
- {
42
- className: "outline-none",
43
- align: s,
44
- sideOffset: n,
45
- alignOffset: r,
46
- side: l,
47
- children: /* @__PURE__ */ e(
48
- q,
49
- {
50
- className: t(
51
- "flex flex-col",
52
- // flexbox layout for sticky input + scrollable list
53
- "max-h-[min(var(--available-height),24rem)] max-w-(--available-width) min-w-(--anchor-width) py-1.5",
54
- "bg-kumo-control text-kumo-default",
55
- // background
56
- "rounded-lg shadow-lg ring ring-kumo-line",
57
- // border part
58
- a
59
- ),
60
- children: o
61
- }
62
- )
63
- }
64
- ) });
65
- }
66
- function N({
67
- className: o,
68
- ...a
69
- }) {
70
- return /* @__PURE__ */ i(
71
- h,
72
- {
73
- className: t(
74
- b(),
75
- "relative flex items-center pr-8",
76
- o
77
- ),
78
- children: [
79
- /* @__PURE__ */ e(d, { children: a.children }),
80
- /* @__PURE__ */ e(f, { className: "absolute top-1/2 right-2 -translate-y-1/2", children: /* @__PURE__ */ e(x, { className: "fill-kumo-ring" }) })
81
- ]
82
- }
83
- );
84
- }
85
- function y(o) {
86
- return /* @__PURE__ */ i(
87
- "div",
88
- {
89
- className: t("relative inline-block w-full max-w-xs", o.className),
90
- children: [
91
- /* @__PURE__ */ e(
92
- u,
93
- {
94
- ...o,
95
- className: t(b(), "w-full pr-12")
96
- }
97
- ),
98
- /* @__PURE__ */ e(O, { className: "absolute top-1/2 right-8 flex -translate-y-1/2 cursor-pointer bg-transparent p-0", children: /* @__PURE__ */ e(p, {}) }),
99
- /* @__PURE__ */ e(h, { className: "p-0", children: /* @__PURE__ */ e(f, { className: "absolute top-1/2 right-2 flex -translate-y-1/2 cursor-pointer", children: /* @__PURE__ */ e(x, { className: "fill-kumo-ring" }) }) })
100
- ]
101
- }
102
- );
103
- }
104
- function v({ children: o, ...a }) {
105
- return /* @__PURE__ */ i(
106
- E,
107
- {
108
- ...a,
109
- className: "group mx-1.5 grid cursor-pointer grid-cols-[1fr_16px] gap-2 rounded px-2 py-1.5 text-base data-highlighted:bg-kumo-overlay",
110
- children: [
111
- /* @__PURE__ */ e("div", { className: "col-start-1", children: o }),
112
- /* @__PURE__ */ e(M, { className: "col-start-2 flex items-center", children: /* @__PURE__ */ e(I, {}) })
113
- ]
114
- }
115
- );
116
- }
117
- function A(o) {
118
- return /* @__PURE__ */ e(
119
- P,
120
- {
121
- ...o,
122
- className: t(
123
- "mx-1.5 shrink-0 px-4 py-2 text-[0.925rem] leading-4 text-kumo-subtle empty:m-0 empty:p-0"
124
- ),
125
- children: o.children ?? "No labels found."
126
- }
127
- );
128
- }
129
- function B(o) {
130
- return /* @__PURE__ */ e(
131
- u,
132
- {
133
- ...o,
134
- className: t(
135
- b(),
136
- "mx-1.5 w-[calc(100%-0.75rem)] shrink-0 first:mb-2",
137
- o.className
138
- )
139
- }
140
- );
141
- }
142
- function H({
143
- className: o,
144
- ...a
145
- }) {
146
- return /* @__PURE__ */ e(
147
- L,
148
- {
149
- ...a,
150
- className: t(
151
- "min-h-0 flex-1 overflow-y-auto overscroll-contain scroll-pt-2 scroll-pb-2",
152
- o
153
- )
154
- }
155
- );
156
- }
157
- function J(o) {
158
- return /* @__PURE__ */ e(
159
- F,
160
- {
161
- ...o,
162
- className: "mx-1.5 px-4 py-1.5 text-sm font-medium"
163
- }
164
- );
165
- }
166
- function K(o) {
167
- return /* @__PURE__ */ e(V, { ...o, className: "mt-2 first:mt-0" });
168
- }
169
- function w(o) {
170
- return /* @__PURE__ */ i(
171
- W,
172
- {
173
- ...o,
174
- className: "flex items-center gap-1 rounded-md bg-kumo-overlay px-2 py-1",
175
- children: [
176
- o.children,
177
- /* @__PURE__ */ e(z, { className: "cursor-pointer rounded-md p-1 hover:bg-kumo-fill-hover", children: /* @__PURE__ */ e(p, { size: 12, weight: "bold" }) })
178
- ]
179
- }
180
- );
181
- }
182
- function k({
183
- placeholder: o,
184
- renderItem: a,
185
- className: s,
186
- inputSide: n = "right",
187
- value: r
188
- }) {
189
- const l = r;
190
- return /* @__PURE__ */ i(
191
- D,
192
- {
193
- className: t(
194
- b(),
195
- t("flex flex-col", "gap-1 p-1", "min-h-9", "h-auto"),
196
- s
197
- ),
198
- children: [
199
- n === "top" && /* @__PURE__ */ e(
200
- u,
201
- {
202
- placeholder: o,
203
- className: "w-full px-2 py-1 outline-none"
204
- }
205
- ),
206
- /* @__PURE__ */ i("div", { className: "flex flex-wrap gap-1", children: [
207
- l !== void 0 && l.length > 0 && l.map((m) => a(m)),
208
- /* @__PURE__ */ e(d, { children: (m) => l !== void 0 ? null : /* @__PURE__ */ e(T, { children: m.map((c) => a(c)) }) }),
209
- n === "right" && /* @__PURE__ */ e(
210
- u,
211
- {
212
- placeholder: o,
213
- className: "min-w-[100px] flex-1 px-2 py-1 outline-none"
214
- }
215
- )
216
- ] })
217
- ]
218
- }
219
- );
220
- }
221
- g.displayName = "Combobox.Root";
222
- C.displayName = "Combobox.Content";
223
- N.displayName = "Combobox.TriggerValue";
224
- y.displayName = "Combobox.TriggerInput";
225
- v.displayName = "Combobox.Item";
226
- w.displayName = "Combobox.Chip";
227
- k.displayName = "Combobox.TriggerMultipleWithInput";
228
- const eo = Object.assign(g, {
229
- // Helper components
230
- Content: C,
231
- TriggerValue: N,
232
- TriggerInput: y,
233
- TriggerMultipleWithInput: k,
234
- // Slightly modified BaseUI
235
- Chip: w,
236
- Item: v,
237
- // Styled BaseUI
238
- Input: B,
239
- Empty: A,
240
- GroupLabel: J,
241
- Group: K,
242
- // Styled BaseUI
243
- List: H,
244
- // BaseUI
245
- Collection: j
246
- });
247
- export {
248
- eo as C
249
- };
250
- //# sourceMappingURL=combobox-DyTgHki4.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"combobox-DyTgHki4.js","sources":["../src/components/combobox/combobox.tsx"],"sourcesContent":["import { Combobox as ComboboxBase } from \"@base-ui/react/combobox\";\nimport { CaretDownIcon, CheckIcon, XIcon } from \"@phosphor-icons/react\";\nimport { Fragment, type PropsWithChildren, type ReactNode } from \"react\";\nimport { inputVariants } from \"../input/input\";\nimport { cn } from \"../../utils/cn\";\nimport { Field, type FieldErrorMatch } from \"../field/field\";\n\n/** Combobox input position variant definitions. */\nexport const KUMO_COMBOBOX_VARIANTS = {\n inputSide: {\n right: {\n classes: \"\",\n description: \"Input positioned inline to the right of chips\",\n },\n top: {\n classes: \"\",\n description: \"Input positioned above chips\",\n },\n },\n} as const;\n\nexport const KUMO_COMBOBOX_DEFAULT_VARIANTS = {\n inputSide: \"right\",\n} as const;\n\n// Derived types from KUMO_COMBOBOX_VARIANTS\nexport type KumoComboboxInputSide =\n keyof typeof KUMO_COMBOBOX_VARIANTS.inputSide;\n\nexport interface KumoComboboxVariantsProps {\n /**\n * Position of the text input relative to chips in multi-select mode.\n * - `\"right\"` — Input inline to the right of chips\n * - `\"top\"` — Input above chips\n * @default \"right\"\n */\n inputSide?: KumoComboboxInputSide;\n}\n\nexport function comboboxVariants({\n inputSide = KUMO_COMBOBOX_DEFAULT_VARIANTS.inputSide,\n}: KumoComboboxVariantsProps = {}) {\n return cn(KUMO_COMBOBOX_VARIANTS.inputSide[inputSide].classes);\n}\n\n// Legacy type alias for backwards compatibility\nexport type ComboboxInputSide = KumoComboboxInputSide;\n\nexport type ComboboxRootProps<\n Value = unknown,\n Multiple extends boolean | undefined = false,\n> = ComboboxBase.Root.Props<Value, Multiple>;\n\n/**\n * Combobox component props (simplified for documentation; the actual Root is generic).\n *\n * Combobox provides an autocomplete/typeahead input with a filterable dropdown.\n * Supports single-select, multi-select with chips, grouped items, and Field wrapper integration.\n *\n * @example\n * ```tsx\n * // Single-select with search input\n * <Combobox value={value} onValueChange={setValue} items={options}>\n * <Combobox.TriggerInput placeholder=\"Search…\" />\n * <Combobox.Content>\n * <Combobox.List>\n * {(item) => <Combobox.Item value={item}>{item.label}</Combobox.Item>}\n * </Combobox.List>\n * <Combobox.Empty>No results</Combobox.Empty>\n * </Combobox.Content>\n * </Combobox>\n *\n * // Multi-select with chips\n * <Combobox multiple items={options} label=\"Tags\">\n * <Combobox.TriggerMultipleWithInput\n * placeholder=\"Add tag…\"\n * renderItem={(item) => <Combobox.Chip value={item}>{item.label}</Combobox.Chip>}\n * />\n * <Combobox.Content>\n * <Combobox.List>\n * {(item) => <Combobox.Item value={item}>{item.label}</Combobox.Item>}\n * </Combobox.List>\n * </Combobox.Content>\n * </Combobox>\n * ```\n */\nexport interface ComboboxProps extends KumoComboboxVariantsProps {\n /** Array of items to display in the dropdown */\n items: unknown[];\n /** Currently selected value(s) */\n value?: unknown;\n /** Callback when selection changes */\n onValueChange?: (value: unknown) => void;\n /** Enable multi-select mode */\n multiple?: boolean;\n /** Combobox content (trigger, content, items) */\n children: ReactNode;\n /** Additional CSS classes */\n className?: string;\n /** Label content for the combobox (enables Field wrapper) - can be a string or any React node */\n label?: ReactNode;\n /** Whether the combobox is required */\n required?: boolean;\n /** Tooltip content to display next to the label via an info icon */\n labelTooltip?: ReactNode;\n /** Helper text displayed below the combobox */\n description?: ReactNode;\n /** Error message or validation error object */\n error?: string | { message: ReactNode; match: FieldErrorMatch };\n}\n\nfunction Root<Value, Multiple extends boolean | undefined = false>({\n label,\n required,\n labelTooltip,\n description,\n error,\n children,\n ...props\n}: ComboboxBase.Root.Props<Value, Multiple> & {\n label?: ReactNode;\n required?: boolean;\n labelTooltip?: ReactNode;\n description?: ReactNode;\n error?: string | { message: ReactNode; match: FieldErrorMatch };\n}) {\n const comboboxControl = (\n <ComboboxBase.Root {...props}>{children}</ComboboxBase.Root>\n );\n\n // Render with Field wrapper if label, description, or error are provided\n if (label) {\n return (\n <Field\n label={label}\n required={required}\n labelTooltip={labelTooltip}\n description={description}\n error={\n error\n ? typeof error === \"string\"\n ? { message: error, match: true }\n : error\n : undefined\n }\n >\n {comboboxControl}\n </Field>\n );\n }\n\n // Render bare combobox without Field wrapper\n return comboboxControl;\n}\n\nfunction Content({\n children,\n className,\n align = \"start\",\n sideOffset = 4,\n alignOffset,\n side,\n}: PropsWithChildren<{\n className?: string;\n align?: ComboboxBase.Positioner.Props[\"align\"];\n alignOffset?: ComboboxBase.Positioner.Props[\"alignOffset\"];\n side?: ComboboxBase.Positioner.Props[\"side\"];\n sideOffset?: ComboboxBase.Positioner.Props[\"sideOffset\"];\n}>) {\n return (\n <ComboboxBase.Portal>\n <ComboboxBase.Positioner\n className=\"outline-none\"\n align={align}\n sideOffset={sideOffset}\n alignOffset={alignOffset}\n side={side}\n >\n <ComboboxBase.Popup\n className={cn(\n \"flex flex-col\", // flexbox layout for sticky input + scrollable list\n \"max-h-[min(var(--available-height),24rem)] max-w-(--available-width) min-w-(--anchor-width) py-1.5\",\n \"bg-kumo-control text-kumo-default\", // background\n \"rounded-lg shadow-lg ring ring-kumo-line\", // border part\n className,\n )}\n >\n {children}\n </ComboboxBase.Popup>\n </ComboboxBase.Positioner>\n </ComboboxBase.Portal>\n );\n}\n\nfunction TriggerValue({\n className,\n ...props\n}: ComboboxBase.Value.Props & { className?: string }) {\n return (\n <ComboboxBase.Trigger\n className={cn(\n inputVariants(),\n \"relative flex items-center pr-8\",\n className,\n )}\n >\n <ComboboxBase.Value>{props.children}</ComboboxBase.Value>\n <ComboboxBase.Icon className=\"absolute top-1/2 right-2 -translate-y-1/2\">\n <CaretDownIcon className=\"fill-kumo-ring\" />\n </ComboboxBase.Icon>\n </ComboboxBase.Trigger>\n );\n}\n\nfunction TriggerInput(props: ComboboxBase.Input.Props) {\n return (\n <div\n className={cn(\"relative inline-block w-full max-w-xs\", props.className)}\n >\n <ComboboxBase.Input\n {...props}\n className={cn(inputVariants(), \"w-full pr-12\")}\n />\n\n <ComboboxBase.Clear className=\"absolute top-1/2 right-8 flex -translate-y-1/2 cursor-pointer bg-transparent p-0\">\n <XIcon />\n </ComboboxBase.Clear>\n\n <ComboboxBase.Trigger className=\"p-0\">\n <ComboboxBase.Icon className=\"absolute top-1/2 right-2 flex -translate-y-1/2 cursor-pointer\">\n <CaretDownIcon className=\"fill-kumo-ring\" />\n </ComboboxBase.Icon>\n </ComboboxBase.Trigger>\n </div>\n );\n}\n\nfunction Item({ children, ...props }: ComboboxBase.Item.Props) {\n return (\n <ComboboxBase.Item\n {...props}\n className=\"group mx-1.5 grid cursor-pointer grid-cols-[1fr_16px] gap-2 rounded px-2 py-1.5 text-base data-highlighted:bg-kumo-overlay\"\n >\n <div className=\"col-start-1\">{children}</div>\n <ComboboxBase.ItemIndicator className=\"col-start-2 flex items-center\">\n <CheckIcon />\n </ComboboxBase.ItemIndicator>\n </ComboboxBase.Item>\n );\n}\n\nfunction Empty(props: ComboboxBase.Empty.Props) {\n return (\n <ComboboxBase.Empty\n {...props}\n className={cn(\n \"mx-1.5 shrink-0 px-4 py-2 text-[0.925rem] leading-4 text-kumo-subtle empty:m-0 empty:p-0\",\n )}\n children={props.children ?? \"No labels found.\"}\n />\n );\n}\n\nfunction Input(props: ComboboxBase.Input.Props) {\n return (\n <ComboboxBase.Input\n {...props}\n className={cn(\n inputVariants(),\n \"mx-1.5 w-[calc(100%-0.75rem)] shrink-0 first:mb-2\",\n props.className,\n )}\n />\n );\n}\n\nfunction List({\n className,\n ...props\n}: ComboboxBase.List.Props & { className?: string }) {\n return (\n <ComboboxBase.List\n {...props}\n className={cn(\n \"min-h-0 flex-1 overflow-y-auto overscroll-contain scroll-pt-2 scroll-pb-2\",\n className,\n )}\n />\n );\n}\n\nfunction GroupLabel(props: ComboboxBase.GroupLabel.Props) {\n return (\n <ComboboxBase.GroupLabel\n {...props}\n className=\"mx-1.5 px-4 py-1.5 text-sm font-medium\"\n />\n );\n}\n\nfunction Group(props: ComboboxBase.Group.Props) {\n return <ComboboxBase.Group {...props} className=\"mt-2 first:mt-0\" />;\n}\n\nfunction Chip(props: ComboboxBase.Chip.Props) {\n return (\n <ComboboxBase.Chip\n {...props}\n className=\"flex items-center gap-1 rounded-md bg-kumo-overlay px-2 py-1\"\n >\n {props.children}\n <ComboboxBase.ChipRemove className=\"cursor-pointer rounded-md p-1 hover:bg-kumo-fill-hover\">\n <XIcon size={12} weight=\"bold\" />\n </ComboboxBase.ChipRemove>\n </ComboboxBase.Chip>\n );\n}\n\nfunction TriggerMultipleWithInput<ValueType>({\n placeholder,\n renderItem,\n className,\n inputSide = \"right\",\n value: controlledValue,\n}: {\n placeholder?: string;\n renderItem: (value: ValueType) => React.ReactNode;\n className?: string;\n inputSide?: \"right\" | \"top\";\n /** Optional controlled value for rendering chips (use when pre-selecting values) */\n value?: ValueType[];\n}) {\n // Determine which value to use for rendering chips\n const chipsToRender = controlledValue;\n\n return (\n <ComboboxBase.Chips\n className={cn(\n inputVariants(),\n cn(\"flex flex-col\", \"gap-1 p-1\", \"min-h-9\", \"h-auto\"),\n className,\n )}\n >\n {inputSide === \"top\" && (\n <ComboboxBase.Input\n placeholder={placeholder}\n className=\"w-full px-2 py-1 outline-none\"\n />\n )}\n {/* Chips container */}\n <div className=\"flex flex-wrap gap-1\">\n {/* Render chips from controlled value if provided */}\n {chipsToRender !== undefined &&\n chipsToRender.length > 0 &&\n chipsToRender.map((item) => renderItem(item))}\n {/* Also render from BaseUI's internal value for user selections */}\n <ComboboxBase.Value>\n {(internalValue: ValueType[]) => {\n // Skip rendering if using controlled value (to avoid duplicates)\n if (chipsToRender !== undefined) return null;\n return (\n <Fragment>\n {internalValue.map((item) => renderItem(item))}\n </Fragment>\n );\n }}\n </ComboboxBase.Value>\n {inputSide === \"right\" && (\n <ComboboxBase.Input\n placeholder={placeholder}\n className=\"min-w-[100px] flex-1 px-2 py-1 outline-none\"\n />\n )}\n </div>\n </ComboboxBase.Chips>\n );\n}\n\nRoot.displayName = \"Combobox.Root\";\nContent.displayName = \"Combobox.Content\";\nTriggerValue.displayName = \"Combobox.TriggerValue\";\nTriggerInput.displayName = \"Combobox.TriggerInput\";\nItem.displayName = \"Combobox.Item\";\nChip.displayName = \"Combobox.Chip\";\nTriggerMultipleWithInput.displayName = \"Combobox.TriggerMultipleWithInput\";\n\n/**\n * Combobox — autocomplete input with filterable dropdown list.\n *\n * Compound component: `Combobox` (Root), `.TriggerInput`, `.TriggerValue`,\n * `.TriggerMultipleWithInput`, `.Content`, `.Item`, `.Chip`, `.Input`,\n * `.Empty`, `.GroupLabel`, `.Group`, `.List`, `.Collection`.\n *\n * @example\n * ```tsx\n * <Combobox items={fruits} label=\"Fruit\">\n * <Combobox.TriggerInput placeholder=\"Pick a fruit…\" />\n * <Combobox.Content>\n * <Combobox.List>\n * {(item) => <Combobox.Item value={item}>{item}</Combobox.Item>}\n * </Combobox.List>\n * </Combobox.Content>\n * </Combobox>\n * ```\n *\n * @see https://base-ui.com/react/components/combobox\n */\nexport const Combobox = Object.assign(Root, {\n // Helper components\n Content,\n TriggerValue,\n TriggerInput,\n TriggerMultipleWithInput,\n\n // Slightly modified BaseUI\n Chip,\n Item,\n\n // Styled BaseUI\n Input,\n Empty,\n GroupLabel,\n Group,\n\n // Styled BaseUI\n List,\n\n // BaseUI\n Collection: ComboboxBase.Collection,\n});\n"],"names":["Root","label","required","labelTooltip","description","error","children","props","comboboxControl","jsx","ComboboxBase.Root","Field","Content","className","align","sideOffset","alignOffset","side","ComboboxBase.Portal","ComboboxBase.Positioner","ComboboxBase.Popup","cn","TriggerValue","jsxs","ComboboxBase.Trigger","inputVariants","ComboboxBase.Value","ComboboxBase.Icon","CaretDownIcon","TriggerInput","ComboboxBase.Input","ComboboxBase.Clear","XIcon","Item","ComboboxBase.Item","ComboboxBase.ItemIndicator","CheckIcon","Empty","ComboboxBase.Empty","Input","List","ComboboxBase.List","GroupLabel","ComboboxBase.GroupLabel","Group","ComboboxBase.Group","Chip","ComboboxBase.Chip","ComboboxBase.ChipRemove","TriggerMultipleWithInput","placeholder","renderItem","inputSide","controlledValue","chipsToRender","ComboboxBase.Chips","item","internalValue","Fragment","Combobox","ComboboxBase.Collection"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"command-palette-B2hkPSQm.js","sources":["../src/components/command-palette/command-palette.tsx"],"sourcesContent":["import {\n useRef,\n useCallback,\n createContext,\n useContext,\n forwardRef,\n type CSSProperties,\n} from \"react\";\nimport { Autocomplete } from \"@base-ui/react/autocomplete\";\nimport { Dialog as DialogBase } from \"@base-ui/react/dialog\";\nimport {\n MagnifyingGlassIcon,\n ArrowRightIcon,\n ArrowSquareOutIcon,\n CaretRightIcon,\n} from \"@phosphor-icons/react\";\n\nimport { Surface } from \"../surface\";\nimport { Loader } from \"../loader\";\nimport { cn } from \"../../utils\";\nimport type {\n HighlightRange,\n CommandPaletteRootProps,\n CommandPaletteListProps,\n CommandPaletteGroupProps,\n CommandPaletteGroupLabelProps,\n CommandPaletteItemProps,\n CommandPaletteEmptyProps,\n CommandPaletteLoadingProps,\n CommandPaletteFooterProps,\n CommandPaletteResultItemProps,\n} from \"./types\";\n\n/**\n * CommandPalette - A composable command palette component for Kumo\n *\n * Uses @base-ui/react/autocomplete primitives for accessible command palette functionality.\n *\n * Keyboard navigation is built-in:\n * - Arrow keys (up/down) move highlight between items\n * - Enter selects the highlighted item (calls onSelect with newTab: false)\n * - Cmd+Enter (Mac) / Ctrl+Enter (Windows/Linux) selects with newTab: true\n * - First item is auto-highlighted when results change\n * - Escape closes the dialog\n *\n * Usage:\n * ```tsx\n * <CommandPalette.Root\n * open={open}\n * onOpenChange={setOpen}\n * items={results}\n * value={searchTerm}\n * onValueChange={setSearchTerm}\n * itemToStringValue={(group) => group.label}\n * onSelect={(item, { newTab }) => handleSelect(item, newTab)}\n * getSelectableItems={(groups) => groups.flatMap(g => g.items)}\n * >\n * <CommandPalette.Input placeholder=\"Search...\" />\n * <CommandPalette.List>\n * <Autocomplete.List>\n * {(group) => (\n * <CommandPalette.Group items={group.items}>\n * <CommandPalette.GroupLabel>{group.label}</CommandPalette.GroupLabel>\n * <Autocomplete.Collection>\n * {(item) => (\n * <CommandPalette.Item value={item} onClick={(e) => handleSelect(item, e.metaKey || e.ctrlKey)}>\n * {item.title}\n * </CommandPalette.Item>\n * )}\n * </Autocomplete.Collection>\n * </CommandPalette.Group>\n * )}\n * </Autocomplete.List>\n * <CommandPalette.Empty>No results found</CommandPalette.Empty>\n * </CommandPalette.List>\n * <CommandPalette.Footer />\n * </CommandPalette.Root>\n * ```\n */\n\n/**\n * Dialog context for passing close handler to children\n */\ninterface DialogContextValue {\n onClose?: () => void;\n}\n\nconst DialogContext = createContext<DialogContextValue>({});\n\n/**\n * Props for the Dialog component\n */\ninterface DialogProps {\n /** Whether the dialog is open */\n open: boolean;\n /** Callback when the open state changes */\n onOpenChange: (open: boolean) => void;\n /**\n * Optional callback when backdrop is clicked.\n * Receives the mouse event for position tracking (e.g., for ripple effects).\n * If not provided, backdrop click calls onOpenChange(false).\n */\n onBackdropClick?: (e: React.MouseEvent) => void;\n /** Child content - typically one or more Panel components */\n children: React.ReactNode;\n}\n\n/**\n * Dialog component - Modal wrapper for command palette content.\n *\n * Use this when you need a dialog that can swap between different Panel contents\n * without re-mounting (e.g., drill-down navigation).\n *\n * @example\n * ```tsx\n * <CommandPalette.Dialog open={open} onOpenChange={setOpen}>\n * {showDrillDown ? (\n * <ZonePicker />\n * ) : (\n * <CommandPalette.Panel items={results} ...>\n * ...\n * </CommandPalette.Panel>\n * )}\n * </CommandPalette.Dialog>\n * ```\n */\nfunction Dialog({\n open,\n onOpenChange,\n onBackdropClick,\n children,\n}: DialogProps) {\n const handleBackdropClick = (e: React.MouseEvent) => {\n if (onBackdropClick) {\n onBackdropClick(e);\n } else {\n onOpenChange(false);\n }\n };\n\n const handleClose = useCallback(() => {\n onOpenChange(false);\n }, [onOpenChange]);\n\n return (\n <DialogBase.Root open={open} onOpenChange={onOpenChange} modal>\n <DialogBase.Portal>\n <DialogBase.Backdrop\n className=\"fixed inset-0 bg-kumo-overlay opacity-80 transition-all duration-150 data-[ending-style]:opacity-0 data-[starting-style]:opacity-0\"\n onClick={handleBackdropClick}\n />\n <Surface\n as={DialogBase.Popup}\n className={cn(\n \"fixed top-[10vh] left-1/2 w-full max-w-2xl -translate-x-1/2\",\n \"overflow-hidden rounded-lg\",\n \"duration-150 data-[ending-style]:scale-90 data-[ending-style]:opacity-0 data-[starting-style]:scale-90 data-[starting-style]:opacity-0\",\n )}\n style={\n {\n transitionProperty: \"scale, opacity\",\n transitionTimingFunction:\n \"var(--default-transition-timing-function)\",\n } as CSSProperties\n }\n >\n <DialogContext.Provider value={{ onClose: handleClose }}>\n {children}\n </DialogContext.Provider>\n </Surface>\n </DialogBase.Portal>\n </DialogBase.Root>\n );\n}\n\n/**\n * Root component - Dialog + Panel combined for simple use cases.\n *\n * For cases where you need to swap content inside the dialog without\n * re-mounting (e.g., drill-down navigation), use Dialog + Panel separately.\n *\n * Keyboard navigation is always enabled:\n * - Arrow keys (up/down) move highlight\n * - Enter selects highlighted item\n * - Cmd/Ctrl+Enter selects with newTab: true\n * - First item is auto-highlighted when results change\n */\nfunction Root<TGroup, TItem = TGroup>({\n open,\n onOpenChange,\n onBackdropClick,\n children,\n items,\n value,\n onValueChange,\n onItemHighlighted,\n itemToStringValue,\n filter,\n onSelect,\n getSelectableItems,\n}: CommandPaletteRootProps<TGroup, TItem>) {\n return (\n <Dialog\n open={open}\n onOpenChange={onOpenChange}\n onBackdropClick={onBackdropClick}\n >\n <Panel\n items={items}\n value={value}\n onValueChange={onValueChange}\n onItemHighlighted={onItemHighlighted}\n itemToStringValue={itemToStringValue}\n filter={filter}\n open={open}\n onSelect={onSelect}\n getSelectableItems={getSelectableItems}\n >\n {children}\n </Panel>\n </Dialog>\n );\n}\n\n/**\n * InputHeader component - Internal styled container for search input.\n */\nfunction InputHeader({\n children,\n leading,\n trailing,\n}: {\n children: React.ReactNode;\n leading?: React.ReactNode;\n trailing?: React.ReactNode;\n}) {\n return (\n <div className=\"flex items-center gap-3 bg-kumo-base px-4 py-3\">\n {leading ?? (\n <MagnifyingGlassIcon\n className=\"h-4 w-4 text-kumo-subtle\"\n weight=\"bold\"\n />\n )}\n {children}\n {trailing}\n </div>\n );\n}\n\n/**\n * List component - Scrollable results container\n *\n * Wrapper div with proper styling, contains Autocomplete.List internally.\n * Supports ref forwarding for scroll control.\n */\nconst List = forwardRef<\n HTMLDivElement,\n CommandPaletteListProps & { className?: string }\n>(function List({ children, className }, ref) {\n return (\n <div\n ref={ref}\n className={cn(\n \"z-10 min-h-0 flex-1 overflow-y-auto rounded-b-lg bg-kumo-base px-2 py-2 ring-1 ring-kumo-line\",\n className,\n )}\n >\n {children}\n </div>\n );\n});\n\nList.displayName = \"CommandPalette.List\";\n\n/**\n * Group component - Category grouping\n *\n * Re-export of Autocomplete.Group with default styling.\n */\nfunction Group({\n children,\n className,\n ...props\n}: CommandPaletteGroupProps & {\n className?: string;\n items?: unknown[];\n}) {\n return (\n <Autocomplete.Group className={cn(\"space-y-0.5\", className)} {...props}>\n {children}\n </Autocomplete.Group>\n );\n}\n\n/**\n * GroupLabel component - Section header text\n *\n * Re-export of Autocomplete.GroupLabel with styling matching SectionHeader.\n */\nfunction GroupLabel({\n children,\n className,\n}: CommandPaletteGroupLabelProps & { className?: string }) {\n return (\n <Autocomplete.GroupLabel\n className={cn(\n \"mb-2 px-2 pt-1 text-xs font-semibold text-kumo-strong\",\n className,\n )}\n >\n {children}\n </Autocomplete.GroupLabel>\n );\n}\n\n/**\n * Item component - Individual result item\n *\n * Re-export of Autocomplete.Item with styling matching SearchResultItem.\n * Note: Use onClick for selection handling, matching the existing CommandPalette pattern.\n */\nfunction Item<T>({\n value,\n disabled,\n children,\n className,\n onClick,\n}: CommandPaletteItemProps<T> & {\n className?: string;\n}) {\n return (\n <Autocomplete.Item\n value={value}\n disabled={disabled}\n onClick={onClick}\n className={cn(\n \"group flex w-full items-center gap-3 px-2 py-1.5 text-left transition-colors\",\n \"cursor-pointer data-[highlighted]:bg-kumo-overlay\",\n \"rounded-lg\",\n disabled && \"cursor-default opacity-50\",\n className,\n )}\n >\n {children}\n </Autocomplete.Item>\n );\n}\n\n/**\n * Empty component - Empty state when no results\n *\n * Re-export of Autocomplete.Empty with default styling.\n */\nfunction Empty({ children }: CommandPaletteEmptyProps) {\n return (\n <Autocomplete.Empty>\n <div className=\"p-8 text-center\">\n <p className=\"text-kumo-strong\">{children ?? \"No results found\"}</p>\n </div>\n </Autocomplete.Empty>\n );\n}\n\n/**\n * Loading component - Loading spinner state\n *\n * Centered loading spinner using Kumo Loader.\n */\nfunction Loading({ children }: CommandPaletteLoadingProps) {\n return (\n <div className=\"flex items-center justify-center p-8\">\n {children ?? <Loader size={24} />}\n </div>\n );\n}\n\n/**\n * Footer component - Styled container for keyboard hints or other footer content.\n *\n * Children are required - this is just a styled container.\n * Consumers should provide their own keyboard hints with proper i18n.\n */\nfunction Footer({ children }: CommandPaletteFooterProps) {\n return (\n <div className=\"flex items-center justify-between rounded-b-lg bg-kumo-elevated px-4 py-3 text-xs text-kumo-strong\">\n {children}\n </div>\n );\n}\n\n/**\n * HighlightedText - Renders text with highlighted portions based on match indices.\n * Highlighted text is shown with a background color to indicate matches.\n */\nfunction HighlightedText({\n text,\n highlights,\n className,\n}: {\n text: string;\n highlights?: HighlightRange[];\n className?: string;\n}) {\n if (!highlights || highlights.length === 0) {\n return <span className={className}>{text}</span>;\n }\n\n // Sort highlights by start index and merge overlapping ranges\n const sortedHighlights = [...highlights].sort((a, b) => a[0] - b[0]);\n const mergedHighlights: HighlightRange[] = [];\n\n for (const range of sortedHighlights) {\n const last = mergedHighlights[mergedHighlights.length - 1];\n if (last && range[0] <= last[1] + 1) {\n // Merge overlapping or adjacent ranges\n last[1] = Math.max(last[1], range[1]);\n } else {\n mergedHighlights.push([...range]);\n }\n }\n\n const parts: React.ReactNode[] = [];\n let lastIndex = 0;\n\n mergedHighlights.forEach((range, i) => {\n const [start, end] = range;\n\n // Add non-highlighted text before this match\n if (start > lastIndex) {\n parts.push(<span key={`text-${i}`}>{text.slice(lastIndex, start)}</span>);\n }\n\n // Add highlighted text (end index is inclusive)\n parts.push(\n <mark\n key={`highlight-${i}`}\n className=\"rounded-sm bg-kumo-warning/50 text-kumo-default\"\n >\n {text.slice(start, end + 1)}\n </mark>,\n );\n\n lastIndex = end + 1;\n });\n\n // Add remaining non-highlighted text\n if (lastIndex < text.length) {\n parts.push(<span key=\"text-end\">{text.slice(lastIndex)}</span>);\n }\n\n return <span className={className}>{parts}</span>;\n}\n\n/**\n * ResultItem - Rich item component with breadcrumbs, highlights, icons, and external indicators.\n *\n * Use this for search result items that need breadcrumb navigation, text highlighting,\n * or external link indicators. For simple items, use Item instead.\n */\nfunction ResultItem<T>({\n title,\n breadcrumbs,\n titleHighlights,\n breadcrumbHighlights,\n description,\n icon,\n value,\n onClick,\n showArrow = true,\n external = false,\n nonInteractive = false,\n}: CommandPaletteResultItemProps<T>) {\n return (\n <Autocomplete.Item\n value={value}\n onClick={nonInteractive ? undefined : (e: React.MouseEvent) => onClick(e)}\n className={cn(\n \"group flex w-full items-center gap-3 rounded-lg px-2 py-1.5 text-left transition-colors\",\n nonInteractive\n ? \"cursor-default\"\n : \"cursor-pointer data-[highlighted]:bg-kumo-overlay\",\n )}\n >\n {icon && (\n <div className=\"flex flex-shrink-0 items-center text-kumo-subtle\">\n {icon}\n </div>\n )}\n <div className=\"min-w-0 flex-1\">\n <div className=\"flex items-center gap-2 truncate\">\n {breadcrumbs?.map((crumb, index) => (\n <span key={index} className=\"flex items-center gap-2\">\n <HighlightedText\n text={crumb}\n highlights={breadcrumbHighlights?.[index]}\n className=\"text-base text-kumo-default\"\n />\n <CaretRightIcon\n className=\"h-3 w-3 flex-shrink-0 text-kumo-subtle\"\n weight=\"bold\"\n />\n </span>\n ))}\n <HighlightedText\n text={title}\n highlights={titleHighlights}\n className=\"text-base text-kumo-default\"\n />\n {external && (\n <ArrowSquareOutIcon className=\"h-3.5 w-3.5 flex-shrink-0 text-kumo-subtle\" />\n )}\n {description && (\n <>\n <span className=\"text-kumo-strong\">—</span>\n <span className=\"truncate text-sm text-kumo-strong\">\n {description}\n </span>\n </>\n )}\n </div>\n </div>\n {showArrow && !external && !nonInteractive && (\n <ArrowRightIcon className=\"h-4 w-4 flex-shrink-0 text-kumo-subtle opacity-0 transition-opacity group-data-[highlighted]:opacity-100\" />\n )}\n </Autocomplete.Item>\n );\n}\n\n/**\n * Container component - Internal styled wrapper.\n */\nfunction Container({\n children,\n className,\n}: {\n children: React.ReactNode;\n className?: string;\n}) {\n return (\n <div\n className={cn(\n \"flex max-h-[60vh] flex-col overflow-hidden rounded-lg bg-kumo-elevated\",\n className,\n )}\n >\n {children}\n </div>\n );\n}\n\n/**\n * Panel context for passing handlers from Panel to children\n */\ninterface PanelContextValue {\n onInputKeyDown?: (e: React.KeyboardEvent) => void;\n}\n\nconst PanelContext = createContext<PanelContextValue>({});\n\n/**\n * Props for the Panel component\n */\ninterface PanelProps<TGroup, TItem = TGroup> {\n /** Child components (Input, List, Footer, etc.) */\n children: React.ReactNode;\n /** Items for the autocomplete */\n items: TGroup[];\n /** Controlled input value */\n value?: string;\n /** Callback when input value changes */\n onValueChange?: (value: string) => void;\n /** Callback when an item is highlighted */\n onItemHighlighted?: (\n item: TGroup | undefined,\n details: { reason: string; event: Event; index: number },\n ) => void;\n /** Convert item to string for accessibility */\n itemToStringValue?: (item: TGroup) => string;\n /** Custom filter function */\n filter?: (item: TGroup, query: string) => boolean;\n /** Whether the panel is active/open (for autocomplete state) */\n open?: boolean;\n /** Optional className for the container */\n className?: string;\n /**\n * Callback when an item is selected via Cmd/Ctrl+Enter.\n * Requires getSelectableItems to be provided.\n */\n onSelect?: (item: TItem, options: { newTab: boolean }) => void;\n /**\n * Function to get flat list of selectable items from groups.\n * Required when items are grouped and onSelect is used.\n */\n getSelectableItems?: (items: TGroup[]) => TItem[];\n}\n\n/**\n * Panel component - Command palette without dialog wrapper.\n *\n * Use this when you need to render command palette content inside an existing dialog\n * (e.g., for drill-down navigation where the dialog stays open but content changes).\n *\n * Combines Container + Autocomplete functionality with a clean API.\n *\n * @example\n * ```tsx\n * <DialogRoot open={open} onOpenChange={setOpen}>\n * <Dialog>\n * <CommandPalette.Panel\n * items={results}\n * value={searchTerm}\n * onValueChange={setSearchTerm}\n * itemToStringValue={(group) => group.label}\n * >\n * <CommandPalette.Input placeholder=\"Search...\" />\n * <CommandPalette.List>\n * <CommandPalette.Results>\n * {(group) => (\n * <CommandPalette.Group items={group.items}>\n * <CommandPalette.GroupLabel>{group.label}</CommandPalette.GroupLabel>\n * <CommandPalette.Items>\n * {(item) => <CommandPalette.ResultItem ... />}\n * </CommandPalette.Items>\n * </CommandPalette.Group>\n * )}\n * </CommandPalette.Results>\n * <CommandPalette.Empty>No results</CommandPalette.Empty>\n * </CommandPalette.List>\n * <CommandPalette.Footer>...</CommandPalette.Footer>\n * </CommandPalette.Panel>\n * </Dialog>\n * </DialogRoot>\n * ```\n */\nconst defaultFilter = () => true;\n\nfunction Panel<TGroup, TItem = TGroup>({\n children,\n items,\n value,\n onValueChange,\n onItemHighlighted,\n itemToStringValue,\n filter = defaultFilter,\n open = true,\n className,\n onSelect,\n getSelectableItems,\n}: PanelProps<TGroup, TItem>) {\n const highlightedIndexRef = useRef<number>(-1);\n\n const handleItemHighlighted = useCallback(\n (\n item: TGroup | undefined,\n details: { reason: string; event: Event; index: number },\n ) => {\n highlightedIndexRef.current = details.index;\n onItemHighlighted?.(item, details);\n },\n [onItemHighlighted],\n );\n\n // Handle Cmd/Ctrl+Enter for new tab selection\n const handleInputKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n const isEnter = e.key === \"Enter\";\n const withModifier = e.metaKey || e.ctrlKey;\n\n if (isEnter && withModifier && onSelect && getSelectableItems) {\n const selectableItems = getSelectableItems(items);\n const highlightedItem = selectableItems[highlightedIndexRef.current];\n\n if (highlightedItem !== undefined) {\n e.preventDefault();\n onSelect(highlightedItem, { newTab: true });\n }\n }\n },\n [items, onSelect, getSelectableItems],\n );\n\n return (\n <Container className={className}>\n <Autocomplete.Root\n items={items}\n value={value}\n onValueChange={onValueChange}\n onItemHighlighted={handleItemHighlighted}\n itemToStringValue={itemToStringValue}\n filter={filter}\n autoHighlight=\"always\"\n keepHighlight\n open={open}\n >\n <PanelContext.Provider value={{ onInputKeyDown: handleInputKeyDown }}>\n {children}\n </PanelContext.Provider>\n </Autocomplete.Root>\n </Container>\n );\n}\n\n/**\n * PanelInput component - Input that works inside Panel.\n *\n * Similar to Input but designed for use with Panel instead of Root.\n * Automatically wires up Cmd/Ctrl+Enter handling from Panel.\n */\nfunction PanelInput({\n autoFocus = true,\n placeholder,\n className,\n onKeyDown: onKeyDownProp,\n leading,\n trailing,\n ...props\n}: {\n autoFocus?: boolean;\n placeholder?: string;\n className?: string;\n onKeyDown?: (e: React.KeyboardEvent) => void;\n /** Optional leading content (e.g., back button) */\n leading?: React.ReactNode;\n /** Optional trailing content (e.g., Esc button) */\n trailing?: React.ReactNode;\n}) {\n const { onInputKeyDown } = useContext(PanelContext);\n const { onClose } = useContext(DialogContext);\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent) => {\n // Let consumer handle first (e.g., for custom Escape/Backspace behavior)\n onKeyDownProp?.(e);\n if (e.defaultPrevented) return;\n\n // Handle Escape to close the dialog\n if (e.key === \"Escape\" && onClose) {\n e.preventDefault();\n onClose();\n return;\n }\n onInputKeyDown?.(e);\n },\n [onInputKeyDown, onKeyDownProp, onClose],\n );\n\n return (\n <InputHeader leading={leading} trailing={trailing}>\n <Autocomplete.Input\n placeholder={placeholder}\n className={cn(\n \"flex-1 border-none bg-transparent text-base placeholder:text-kumo-subtle\",\n \"outline-none focus-visible:outline-none\",\n className,\n )}\n onKeyDown={handleKeyDown}\n // oxlint-disable-next-line no-autofocus -- Command palette input should autofocus for keyboard-driven UX\n autoFocus={autoFocus}\n {...props}\n />\n </InputHeader>\n );\n}\n\n/**\n * Render prop iterators - wrap base-ui primitives with cleaner names.\n */\n\n/**\n * Results component - Render prop iterator for groups.\n *\n * Wraps Autocomplete.List with default spacing between groups.\n */\nfunction Results({\n children,\n className,\n}: React.ComponentProps<typeof Autocomplete.List> & { className?: string }) {\n return (\n <Autocomplete.List className={cn(\"space-y-3\", className)}>\n {children}\n </Autocomplete.List>\n );\n}\n\nconst Items = Autocomplete.Collection;\n\n/** CommandPalette variant definitions (no user-facing variants; structure reserved for future use). */\nexport const KUMO_COMMAND_PALETTE_VARIANTS = {} as const;\n\nexport const KUMO_COMMAND_PALETTE_DEFAULT_VARIANTS = {} as const;\n\n/**\n * CommandPalette — accessible command palette / spotlight search overlay.\n *\n * Compound component: `CommandPalette.Root` (or `.Dialog` + `.Panel`),\n * `.Input`, `.List`, `.Results`, `.Items`, `.Group`, `.GroupLabel`,\n * `.Item`, `.ResultItem`, `.HighlightedText`, `.Empty`, `.Loading`, `.Footer`.\n *\n * Built on `@base-ui/react/autocomplete` + `@base-ui/react/dialog`.\n *\n * @example\n * ```tsx\n * <CommandPalette.Root\n * open={open}\n * onOpenChange={setOpen}\n * items={results}\n * value={query}\n * onValueChange={setQuery}\n * itemToStringValue={(g) => g.label}\n * onSelect={(item, { newTab }) => navigate(item, newTab)}\n * getSelectableItems={(groups) => groups.flatMap((g) => g.items)}\n * >\n * <CommandPalette.Input placeholder=\"Search…\" />\n * <CommandPalette.List>\n * <CommandPalette.Results>\n * {(group) => (\n * <CommandPalette.Group items={group.items}>\n * <CommandPalette.GroupLabel>{group.label}</CommandPalette.GroupLabel>\n * <CommandPalette.Items>\n * {(item) => (\n * <CommandPalette.ResultItem title={item.title} value={item} onClick={…} />\n * )}\n * </CommandPalette.Items>\n * </CommandPalette.Group>\n * )}\n * </CommandPalette.Results>\n * <CommandPalette.Empty>No results found</CommandPalette.Empty>\n * </CommandPalette.List>\n * <CommandPalette.Footer>…keyboard hints…</CommandPalette.Footer>\n * </CommandPalette.Root>\n * ```\n */\nexport const CommandPalette = {\n /** Modal dialog wrapper - use with Panel for content that can swap */\n Dialog,\n /** Dialog + Panel combined - for simple single-view command palettes */\n Root,\n /** Autocomplete panel without dialog - use inside Dialog for swappable content */\n Panel,\n /** Input for use inside Panel */\n Input: PanelInput,\n /** Scrollable results container */\n List,\n /** Category grouping */\n Group,\n /** Section header text */\n GroupLabel,\n /** Basic item */\n Item,\n /** Rich item with breadcrumbs, highlights, icons */\n ResultItem,\n /** Text with highlighted portions */\n HighlightedText,\n /** Empty state */\n Empty,\n /** Loading state */\n Loading,\n /** Footer for keyboard hints */\n Footer,\n /** Render prop iterator for groups */\n Results,\n /** Render prop iterator for items within a group */\n Items,\n};\n"],"names":["DialogContext","createContext","Dialog","open","onOpenChange","onBackdropClick","children","handleBackdropClick","e","handleClose","useCallback","jsx","DialogBase.Root","jsxs","DialogBase.Portal","DialogBase.Backdrop","Surface","DialogBase.Popup","cn","Root","items","value","onValueChange","onItemHighlighted","itemToStringValue","filter","onSelect","getSelectableItems","Panel","InputHeader","leading","trailing","MagnifyingGlassIcon","List","forwardRef","className","ref","Group","props","Autocomplete.Group","GroupLabel","Autocomplete.GroupLabel","Item","disabled","onClick","Autocomplete.Item","Empty","Autocomplete.Empty","Loading","Loader","Footer","HighlightedText","text","highlights","sortedHighlights","a","b","mergedHighlights","range","last","parts","lastIndex","i","start","end","ResultItem","title","breadcrumbs","titleHighlights","breadcrumbHighlights","description","icon","showArrow","external","nonInteractive","crumb","index","CaretRightIcon","ArrowSquareOutIcon","Fragment","ArrowRightIcon","Container","PanelContext","defaultFilter","highlightedIndexRef","useRef","handleItemHighlighted","item","details","handleInputKeyDown","isEnter","withModifier","highlightedItem","Autocomplete.Root","PanelInput","autoFocus","placeholder","onKeyDownProp","onInputKeyDown","useContext","onClose","handleKeyDown","Autocomplete.Input","Results","Autocomplete.List","Items","Autocomplete.Collection","KUMO_COMMAND_PALETTE_VARIANTS","KUMO_COMMAND_PALETTE_DEFAULT_VARIANTS","CommandPalette"],"mappings":"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"}
@@ -1,97 +0,0 @@
1
- "use client";
2
- import { jsx as t, jsxs as m } from "react/jsx-runtime";
3
- import { S as p } from "./surface-BIC6CXiz.js";
4
- import { c as o } from "./cn-Bhsu1vx2.js";
5
- import { am as u, an as D, ao as f, ap as y, aq as x, ar as w, as as T, at as b } from "./vendor-base-ui-B61LL9jT.js";
6
- const N = {
7
- size: {
8
- base: {
9
- classes: "sm:min-w-96",
10
- description: "Default dialog width"
11
- },
12
- sm: {
13
- classes: "min-w-72",
14
- description: "Small dialog for simple confirmations"
15
- },
16
- lg: {
17
- classes: "min-w-[32rem]",
18
- description: "Large dialog for complex content"
19
- },
20
- xl: {
21
- classes: "min-w-[48rem]",
22
- description: "Extra large dialog for detailed views"
23
- }
24
- }
25
- }, s = {
26
- size: "base"
27
- };
28
- function A({
29
- size: a = s.size
30
- } = {}) {
31
- return o(
32
- // Base styles
33
- "shadow-m fixed top-1/2 left-1/2 w-full sm:w-auto max-w-[calc(100vw-2rem)] sm:max-w-[calc(100vw-3rem)] -translate-x-1/2 -translate-y-1/2 overflow-hidden rounded-xl bg-kumo-base text-kumo-default duration-150 data-ending-style:scale-90 data-ending-style:opacity-0 data-starting-style:scale-90 data-starting-style:opacity-0",
34
- // Apply size from KUMO_DIALOG_VARIANTS
35
- N.size[a].classes
36
- );
37
- }
38
- function v({
39
- className: a,
40
- children: i,
41
- style: g,
42
- size: d = s.size
43
- }) {
44
- return /* @__PURE__ */ m(w, { children: [
45
- /* @__PURE__ */ t(T, { className: "fixed inset-0 bg-kumo-overlay opacity-80 transition-all duration-150 data-ending-style:opacity-0 data-starting-style:opacity-0" }),
46
- /* @__PURE__ */ t(
47
- p,
48
- {
49
- as: b,
50
- className: o(A({ size: d }), a),
51
- style: {
52
- transitionProperty: "scale, opacity",
53
- transitionTimingFunction: "var(--default-transition-timing-function)",
54
- "--tw-shadow": "0 20px 25px -5px rgb(0 0 0 / 0.03), 0 8px 10px -6px rgb(0 0 0 / 0.03)",
55
- ...g
56
- },
57
- children: i
58
- }
59
- )
60
- ] });
61
- }
62
- function e({ children: a, ...i }) {
63
- return /* @__PURE__ */ t(u, { ...i, children: a });
64
- }
65
- e.displayName = "Dialog.Root";
66
- function l({ children: a, ...i }) {
67
- return /* @__PURE__ */ t(D, { ...i, children: a });
68
- }
69
- l.displayName = "Dialog.Trigger";
70
- function n({ className: a, ...i }) {
71
- return /* @__PURE__ */ t(f, { className: a, ...i });
72
- }
73
- n.displayName = "Dialog.Title";
74
- function r({ className: a, ...i }) {
75
- return /* @__PURE__ */ t(y, { className: a, ...i });
76
- }
77
- r.displayName = "Dialog.Description";
78
- function c({ children: a, ...i }) {
79
- return /* @__PURE__ */ t(x, { ...i, children: a });
80
- }
81
- c.displayName = "Dialog.Close";
82
- const O = Object.assign(v, {
83
- Root: e,
84
- Trigger: l,
85
- Title: n,
86
- Description: r,
87
- Close: c
88
- });
89
- export {
90
- O as D,
91
- e as a,
92
- l as b,
93
- n as c,
94
- r as d,
95
- c as e
96
- };
97
- //# sourceMappingURL=dialog-B2EHaSoL.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dialog-B2EHaSoL.js","sources":["../src/components/dialog/dialog.tsx"],"sourcesContent":["import type { ComponentPropsWithoutRef, CSSProperties, ReactNode } from \"react\";\nimport { Dialog as DialogBase } from \"@base-ui/react/dialog\";\nimport { Surface } from \"../surface\";\nimport { cn } from \"../../utils/cn\";\n\n/** Dialog size variant definitions mapping sizes to their minimum widths. */\nexport const KUMO_DIALOG_VARIANTS = {\n size: {\n base: {\n classes: \"sm:min-w-96\",\n description: \"Default dialog width\",\n },\n sm: {\n classes: \"min-w-72\",\n description: \"Small dialog for simple confirmations\",\n },\n lg: {\n classes: \"min-w-[32rem]\",\n description: \"Large dialog for complex content\",\n },\n xl: {\n classes: \"min-w-[48rem]\",\n description: \"Extra large dialog for detailed views\",\n },\n },\n} as const;\n\nexport const KUMO_DIALOG_DEFAULT_VARIANTS = {\n size: \"base\",\n} as const;\n\nexport const KUMO_DIALOG_STYLING = {\n dimensions: {\n sm: {\n width: 350,\n titleSize: 20,\n descSize: 16,\n padding: 16,\n gap: 8,\n buttonSize: \"sm\",\n },\n base: {\n width: 384,\n titleSize: 20,\n descSize: 16,\n padding: 24,\n gap: 16,\n buttonSize: \"base\",\n },\n lg: {\n width: 512,\n titleSize: 20,\n descSize: 16,\n padding: 24,\n gap: 16,\n buttonSize: \"base\",\n },\n xl: {\n width: 768,\n titleSize: 20,\n descSize: 16,\n padding: 24,\n gap: 16,\n buttonSize: \"base\",\n },\n },\n baseTokens: {\n background: \"color-surface\",\n text: \"text-color-surface\",\n borderRadius: 12,\n shadow: \"shadow-m\",\n },\n backdrop: {\n background: \"color-surface-secondary\",\n opacity: 0.8,\n },\n header: {\n title: { fontWeight: 600, color: \"text-color-surface\" },\n closeIcon: { name: \"ph-x\", size: 20, color: \"text-color-muted\" },\n },\n description: {\n fontWeight: 400,\n color: \"text-color-muted\",\n },\n buttons: {\n primary: { background: \"color-primary\", text: \"white\" },\n secondary: { ring: \"color-border\", text: \"text-color-surface\" },\n },\n} as const;\n\n// Derived types from KUMO_DIALOG_VARIANTS\nexport type KumoDialogSize = keyof typeof KUMO_DIALOG_VARIANTS.size;\n\nexport interface KumoDialogVariantsProps {\n /**\n * Dialog width.\n * - `\"sm\"` — Small (min 288px) for simple confirmations\n * - `\"base\"` — Default (min 384px)\n * - `\"lg\"` — Large (min 512px) for complex content\n * - `\"xl\"` — Extra large (min 768px) for detailed views\n * @default \"base\"\n */\n size?: KumoDialogSize;\n}\n\nexport function dialogVariants({\n size = KUMO_DIALOG_DEFAULT_VARIANTS.size,\n}: KumoDialogVariantsProps = {}) {\n return cn(\n // Base styles\n \"shadow-m fixed top-1/2 left-1/2 w-full sm:w-auto max-w-[calc(100vw-2rem)] sm:max-w-[calc(100vw-3rem)] -translate-x-1/2 -translate-y-1/2 overflow-hidden rounded-xl bg-kumo-base text-kumo-default duration-150 data-ending-style:scale-90 data-ending-style:opacity-0 data-starting-style:scale-90 data-starting-style:opacity-0\",\n // Apply size from KUMO_DIALOG_VARIANTS\n KUMO_DIALOG_VARIANTS.size[size].classes,\n );\n}\n\n/**\n * Dialog component props — the modal content panel.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger render={(p) => <Button {...p}>Open</Button>} />\n * <Dialog className=\"p-8\">\n * <Dialog.Title>Confirm Action</Dialog.Title>\n * <Dialog.Description>Are you sure?</Dialog.Description>\n * <Dialog.Close render={(p) => <Button {...p}>Cancel</Button>} />\n * </Dialog>\n * </Dialog.Root>\n * ```\n */\nexport type DialogProps = KumoDialogVariantsProps & {\n /** Additional CSS classes merged via `cn()`. */\n className?: string;\n /** Dialog content (typically Title, Description, Close, and action buttons). */\n children: ReactNode;\n /** Inline styles. */\n style?: CSSProperties;\n};\n\n/**\n * Modal dialog overlay with backdrop. Compound component with `Dialog.Root`,\n * `Dialog.Trigger`, `Dialog.Title`, `Dialog.Description`, and `Dialog.Close`.\n *\n * @example\n * ```tsx\n * <Dialog.Root>\n * <Dialog.Trigger render={(p) => <Button {...p}>Delete</Button>} />\n * <Dialog className=\"p-8\">\n * <Dialog.Title>Delete Item</Dialog.Title>\n * <Dialog.Description>This action cannot be undone.</Dialog.Description>\n * <Dialog.Close render={(p) => <Button variant=\"destructive\" {...p}>Delete</Button>} />\n * </Dialog>\n * </Dialog.Root>\n * ```\n */\nfunction DialogContent({\n className,\n children,\n style,\n size = KUMO_DIALOG_DEFAULT_VARIANTS.size,\n}: DialogProps) {\n return (\n <DialogBase.Portal>\n <DialogBase.Backdrop className=\"fixed inset-0 bg-kumo-overlay opacity-80 transition-all duration-150 data-ending-style:opacity-0 data-starting-style:opacity-0\" />\n <Surface\n as={DialogBase.Popup}\n className={cn(dialogVariants({ size }), className)}\n style={\n {\n transitionProperty: \"scale, opacity\",\n transitionTimingFunction:\n \"var(--default-transition-timing-function)\",\n \"--tw-shadow\":\n \"0 20px 25px -5px rgb(0 0 0 / 0.03), 0 8px 10px -6px rgb(0 0 0 / 0.03)\",\n ...style,\n } as CSSProperties\n }\n >\n {children}\n </Surface>\n </DialogBase.Portal>\n );\n}\n\n// ============================================================================\n// Dialog Root\n// ============================================================================\n\ntype BaseDialogRootProps = ComponentPropsWithoutRef<typeof DialogBase.Root>;\n\nexport type DialogRootProps = BaseDialogRootProps;\n\nfunction DialogRoot({ children, ...props }: DialogRootProps) {\n return <DialogBase.Root {...props}>{children}</DialogBase.Root>;\n}\n\nDialogRoot.displayName = \"Dialog.Root\";\n\n// ============================================================================\n// Dialog Trigger\n// ============================================================================\n\ntype BaseDialogTriggerProps = ComponentPropsWithoutRef<\n typeof DialogBase.Trigger\n>;\n\nexport type DialogTriggerProps = BaseDialogTriggerProps;\n\nfunction DialogTrigger({ children, ...props }: DialogTriggerProps) {\n return <DialogBase.Trigger {...props}>{children}</DialogBase.Trigger>;\n}\n\nDialogTrigger.displayName = \"Dialog.Trigger\";\n\n// ============================================================================\n// Dialog Title\n// ============================================================================\n\ntype BaseDialogTitleProps = ComponentPropsWithoutRef<typeof DialogBase.Title>;\n\nexport type DialogTitleProps = BaseDialogTitleProps;\n\nfunction DialogTitle({ className, ...props }: DialogTitleProps) {\n return <DialogBase.Title className={className} {...props} />;\n}\n\nDialogTitle.displayName = \"Dialog.Title\";\n\n// ============================================================================\n// Dialog Description\n// ============================================================================\n\ntype BaseDialogDescriptionProps = ComponentPropsWithoutRef<\n typeof DialogBase.Description\n>;\n\nexport type DialogDescriptionProps = BaseDialogDescriptionProps;\n\nfunction DialogDescription({ className, ...props }: DialogDescriptionProps) {\n return <DialogBase.Description className={className} {...props} />;\n}\n\nDialogDescription.displayName = \"Dialog.Description\";\n\n// ============================================================================\n// Dialog Close\n// ============================================================================\n\ntype BaseDialogCloseProps = ComponentPropsWithoutRef<typeof DialogBase.Close>;\n\nexport type DialogCloseProps = BaseDialogCloseProps;\n\nfunction DialogClose({ children, ...props }: DialogCloseProps) {\n return <DialogBase.Close {...props}>{children}</DialogBase.Close>;\n}\n\nDialogClose.displayName = \"Dialog.Close\";\n\n// ============================================================================\n// Compound Component Export\n// ============================================================================\n\nconst Dialog = Object.assign(DialogContent, {\n Root: DialogRoot,\n Trigger: DialogTrigger,\n Title: DialogTitle,\n Description: DialogDescription,\n Close: DialogClose,\n});\n\nexport {\n Dialog,\n DialogRoot,\n DialogTrigger,\n DialogTitle,\n DialogDescription,\n DialogClose,\n};\n"],"names":["KUMO_DIALOG_VARIANTS","KUMO_DIALOG_DEFAULT_VARIANTS","dialogVariants","size","cn","DialogContent","className","children","style","jsxs","DialogBase.Portal","jsx","DialogBase.Backdrop","Surface","DialogBase.Popup","DialogRoot","props","DialogBase.Root","DialogTrigger","DialogBase.Trigger","DialogTitle","DialogBase.Title","DialogDescription","DialogBase.Description","DialogClose","DialogBase.Close","Dialog"],"mappings":";;;;;AAMO,MAAMA,IAAuB;AAAA,EAClC,MAAM;AAAA,IACJ,MAAM;AAAA,MACJ,SAAS;AAAA,MACT,aAAa;AAAA,IAAA;AAAA,IAEf,IAAI;AAAA,MACF,SAAS;AAAA,MACT,aAAa;AAAA,IAAA;AAAA,IAEf,IAAI;AAAA,MACF,SAAS;AAAA,MACT,aAAa;AAAA,IAAA;AAAA,IAEf,IAAI;AAAA,MACF,SAAS;AAAA,MACT,aAAa;AAAA,IAAA;AAAA,EACf;AAEJ,GAEaC,IAA+B;AAAA,EAC1C,MAAM;AACR;AA4EO,SAASC,EAAe;AAAA,EAC7B,MAAAC,IAAOF,EAA6B;AACtC,IAA6B,IAAI;AAC/B,SAAOG;AAAA;AAAA,IAEL;AAAA;AAAA,IAEAJ,EAAqB,KAAKG,CAAI,EAAE;AAAA,EAAA;AAEpC;AA0CA,SAASE,EAAc;AAAA,EACrB,WAAAC;AAAA,EACA,UAAAC;AAAA,EACA,OAAAC;AAAA,EACA,MAAAL,IAAOF,EAA6B;AACtC,GAAgB;AACd,SACE,gBAAAQ,EAACC,GAAA,EACC,UAAA;AAAA,IAAA,gBAAAC,EAACC,GAAA,EAAoB,WAAU,iIAAA,CAAiI;AAAA,IAChK,gBAAAD;AAAA,MAACE;AAAA,MAAA;AAAA,QACC,IAAIC;AAAAA,QACJ,WAAWV,EAAGF,EAAe,EAAE,MAAAC,EAAA,CAAM,GAAGG,CAAS;AAAA,QACjD,OACE;AAAA,UACE,oBAAoB;AAAA,UACpB,0BACE;AAAA,UACF,eACE;AAAA,UACF,GAAGE;AAAA,QAAA;AAAA,QAIN,UAAAD;AAAA,MAAA;AAAA,IAAA;AAAA,EACH,GACF;AAEJ;AAUA,SAASQ,EAAW,EAAE,UAAAR,GAAU,GAAGS,KAA0B;AAC3D,2BAAQC,GAAA,EAAiB,GAAGD,GAAQ,UAAAT,EAAA,CAAS;AAC/C;AAEAQ,EAAW,cAAc;AAYzB,SAASG,EAAc,EAAE,UAAAX,GAAU,GAAGS,KAA6B;AACjE,2BAAQG,GAAA,EAAoB,GAAGH,GAAQ,UAAAT,EAAA,CAAS;AAClD;AAEAW,EAAc,cAAc;AAU5B,SAASE,EAAY,EAAE,WAAAd,GAAW,GAAGU,KAA2B;AAC9D,2BAAQK,GAAA,EAAiB,WAAAf,GAAuB,GAAGU,EAAA,CAAO;AAC5D;AAEAI,EAAY,cAAc;AAY1B,SAASE,EAAkB,EAAE,WAAAhB,GAAW,GAAGU,KAAiC;AAC1E,2BAAQO,GAAA,EAAuB,WAAAjB,GAAuB,GAAGU,EAAA,CAAO;AAClE;AAEAM,EAAkB,cAAc;AAUhC,SAASE,EAAY,EAAE,UAAAjB,GAAU,GAAGS,KAA2B;AAC7D,2BAAQS,GAAA,EAAkB,GAAGT,GAAQ,UAAAT,EAAA,CAAS;AAChD;AAEAiB,EAAY,cAAc;AAM1B,MAAME,IAAS,OAAO,OAAOrB,GAAe;AAAA,EAC1C,MAAMU;AAAA,EACN,SAASG;AAAA,EACT,OAAOE;AAAA,EACP,aAAaE;AAAA,EACb,OAAOE;AACT,CAAC;"}