@alfadocs/ui-kit-debug 0.1.8 → 0.1.9

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 (742) hide show
  1. package/dist/_chunks/{accordion-B6fyINUk.js → accordion-BEnrZmAn.js} +34 -32
  2. package/dist/_chunks/accordion-BEnrZmAn.js.map +1 -0
  3. package/dist/_chunks/accordion.agent-BTjeO1Sx.js +52 -0
  4. package/dist/_chunks/accordion.agent-BTjeO1Sx.js.map +1 -0
  5. package/dist/_chunks/{agenda-card-DIWDvWum.js → agenda-card-DwLIxgi7.js} +2 -1
  6. package/dist/_chunks/{agenda-card-DIWDvWum.js.map → agenda-card-DwLIxgi7.js.map} +1 -1
  7. package/dist/_chunks/agenda-card.agent-B_R47-c9.js +22 -0
  8. package/dist/_chunks/agenda-card.agent-B_R47-c9.js.map +1 -0
  9. package/dist/_chunks/agenda-tray-DUvengGQ.js +178 -0
  10. package/dist/_chunks/agenda-tray-DUvengGQ.js.map +1 -0
  11. package/dist/_chunks/ai-prompt-input.agent-0NHYLTWD.js +476 -0
  12. package/dist/_chunks/ai-prompt-input.agent-0NHYLTWD.js.map +1 -0
  13. package/dist/_chunks/{aspect-ratio-CxsdG8vk.js → aspect-ratio-DeSNzASA.js} +12 -12
  14. package/dist/_chunks/aspect-ratio-DeSNzASA.js.map +1 -0
  15. package/dist/_chunks/audio-recorder.agent--VKeykUp.js +458 -0
  16. package/dist/_chunks/audio-recorder.agent--VKeykUp.js.map +1 -0
  17. package/dist/_chunks/autocomplete.agent-Dh7KioS6.js +432 -0
  18. package/dist/_chunks/autocomplete.agent-Dh7KioS6.js.map +1 -0
  19. package/dist/_chunks/{balance-cell-renderer-BWm3knY9.js → balance-cell-renderer-5CA7zpAi.js} +3 -3
  20. package/dist/_chunks/{balance-cell-renderer-BWm3knY9.js.map → balance-cell-renderer-5CA7zpAi.js.map} +1 -1
  21. package/dist/_chunks/breadcrumb.agent-GM2hAKFX.js +371 -0
  22. package/dist/_chunks/breadcrumb.agent-GM2hAKFX.js.map +1 -0
  23. package/dist/_chunks/{chart.agent-BdS-_8MO.js → chart.agent-_pRYS17d.js} +112 -105
  24. package/dist/_chunks/chart.agent-_pRYS17d.js.map +1 -0
  25. package/dist/_chunks/{chat-container-Cm3SlR2p.js → chat-container-Dl0Kfy5a.js} +33 -32
  26. package/dist/_chunks/chat-container-Dl0Kfy5a.js.map +1 -0
  27. package/dist/_chunks/{chat-container.agent-Dhw9xCJt.js → chat-container.agent-CM4WModE.js} +9 -4
  28. package/dist/_chunks/{chat-container.agent-Dhw9xCJt.js.map → chat-container.agent-CM4WModE.js.map} +1 -1
  29. package/dist/_chunks/{chat-input-DreOPP8A.js → chat-input-C_tMQv92.js} +108 -82
  30. package/dist/_chunks/chat-input-C_tMQv92.js.map +1 -0
  31. package/dist/_chunks/chat-input.agent-Bsz3ckGa.js +69 -0
  32. package/dist/_chunks/chat-input.agent-Bsz3ckGa.js.map +1 -0
  33. package/dist/_chunks/checkbox-CtPM6Rup.js +196 -0
  34. package/dist/_chunks/checkbox-CtPM6Rup.js.map +1 -0
  35. package/dist/_chunks/checkbox-group-BTdEB6Yo.js +208 -0
  36. package/dist/_chunks/checkbox-group-BTdEB6Yo.js.map +1 -0
  37. package/dist/_chunks/collapsible.agent-DkS1jVyn.js +149 -0
  38. package/dist/_chunks/collapsible.agent-DkS1jVyn.js.map +1 -0
  39. package/dist/_chunks/{color-picker-e9PmpaGH.js → color-picker-94qcBZqZ.js} +234 -184
  40. package/dist/_chunks/color-picker-94qcBZqZ.js.map +1 -0
  41. package/dist/_chunks/combobox.agent-CAvUkkIe.js +410 -0
  42. package/dist/_chunks/combobox.agent-CAvUkkIe.js.map +1 -0
  43. package/dist/_chunks/{command-palette.agent-js2rxgeR.js → command-palette.agent-HatEt_EM.js} +161 -121
  44. package/dist/_chunks/command-palette.agent-HatEt_EM.js.map +1 -0
  45. package/dist/_chunks/date-picker-BqPTn7bO.js +1813 -0
  46. package/dist/_chunks/date-picker-BqPTn7bO.js.map +1 -0
  47. package/dist/_chunks/date-range-picker-B2hGsffw.js +274 -0
  48. package/dist/_chunks/date-range-picker-B2hGsffw.js.map +1 -0
  49. package/dist/_chunks/date-time-picker-Bzt0S8yO.js +293 -0
  50. package/dist/_chunks/date-time-picker-Bzt0S8yO.js.map +1 -0
  51. package/dist/_chunks/dialog.agent-Daf1TTko.js +179 -0
  52. package/dist/_chunks/dialog.agent-Daf1TTko.js.map +1 -0
  53. package/dist/_chunks/{dropdown-menu-Cw3EyPZv.js → dropdown-menu-C7AZipNz.js} +75 -71
  54. package/dist/_chunks/dropdown-menu-C7AZipNz.js.map +1 -0
  55. package/dist/_chunks/dropdown-menu.agent-BcxIKOjK.js +43 -0
  56. package/dist/_chunks/dropdown-menu.agent-BcxIKOjK.js.map +1 -0
  57. package/dist/_chunks/{file-upload.agent-B9AN82LA.js → file-upload.agent-DJaH2dHg.js} +275 -243
  58. package/dist/_chunks/file-upload.agent-DJaH2dHg.js.map +1 -0
  59. package/dist/_chunks/freemium-paywall.agent-_nQqLyRF.js +260 -0
  60. package/dist/_chunks/freemium-paywall.agent-_nQqLyRF.js.map +1 -0
  61. package/dist/_chunks/{leo-sidebar-nbHib2D-.js → leo-sidebar-BwINPdix.js} +6 -6
  62. package/dist/_chunks/{leo-sidebar-nbHib2D-.js.map → leo-sidebar-BwINPdix.js.map} +1 -1
  63. package/dist/_chunks/link-QheANk74.js +121 -0
  64. package/dist/_chunks/link-QheANk74.js.map +1 -0
  65. package/dist/_chunks/list.agent-D0iWt4VI.js +420 -0
  66. package/dist/_chunks/list.agent-D0iWt4VI.js.map +1 -0
  67. package/dist/_chunks/{message-card-qAp2-WQK.js → message-card-qhoGv947.js} +2 -1
  68. package/dist/_chunks/message-card-qhoGv947.js.map +1 -0
  69. package/dist/_chunks/message-card.agent-4IeIgrnJ.js +22 -0
  70. package/dist/_chunks/message-card.agent-4IeIgrnJ.js.map +1 -0
  71. package/dist/_chunks/message-tray-xHUCra-Y.js +419 -0
  72. package/dist/_chunks/message-tray-xHUCra-Y.js.map +1 -0
  73. package/dist/_chunks/{multi-select.agent-CNsyW3n9.js → multi-select.agent-Do6CeQUT.js} +239 -179
  74. package/dist/_chunks/multi-select.agent-Do6CeQUT.js.map +1 -0
  75. package/dist/_chunks/navigation-menu.agent-D69ND6Qq.js +266 -0
  76. package/dist/_chunks/navigation-menu.agent-D69ND6Qq.js.map +1 -0
  77. package/dist/_chunks/{notification-card-BF2_veHy.js → notification-card-CsVEYJE-.js} +13 -12
  78. package/dist/_chunks/{notification-card-BF2_veHy.js.map → notification-card-CsVEYJE-.js.map} +1 -1
  79. package/dist/_chunks/notification-card.agent-Rqt3ofk9.js +22 -0
  80. package/dist/_chunks/notification-card.agent-Rqt3ofk9.js.map +1 -0
  81. package/dist/_chunks/notification-tray-DTXMq42J.js +444 -0
  82. package/dist/_chunks/notification-tray-DTXMq42J.js.map +1 -0
  83. package/dist/_chunks/number-input-fvGmnRy9.js +333 -0
  84. package/dist/_chunks/number-input-fvGmnRy9.js.map +1 -0
  85. package/dist/_chunks/otp-input-EglXOUue.js +257 -0
  86. package/dist/_chunks/otp-input-EglXOUue.js.map +1 -0
  87. package/dist/_chunks/pagination.agent-BkZQl45y.js +422 -0
  88. package/dist/_chunks/pagination.agent-BkZQl45y.js.map +1 -0
  89. package/dist/_chunks/password-input-D6kuYXmr.js +304 -0
  90. package/dist/_chunks/password-input-D6kuYXmr.js.map +1 -0
  91. package/dist/_chunks/{patient-shell-7cXqIMFg.js → patient-shell-BRmrrUUW.js} +3 -3
  92. package/dist/_chunks/{patient-shell-7cXqIMFg.js.map → patient-shell-BRmrrUUW.js.map} +1 -1
  93. package/dist/_chunks/{payment-form-hcl-gGrp.js → payment-form-BWaXas8z.js} +120 -118
  94. package/dist/_chunks/payment-form-BWaXas8z.js.map +1 -0
  95. package/dist/_chunks/{payment-form.agent-BkEnRerR.js → payment-form.agent-kuIfodCj.js} +7 -2
  96. package/dist/_chunks/payment-form.agent-kuIfodCj.js.map +1 -0
  97. package/dist/_chunks/{pdf-viewer.agent-CfIHhcHx.js → pdf-viewer.agent-BaGEDheA.js} +358 -351
  98. package/dist/_chunks/pdf-viewer.agent-BaGEDheA.js.map +1 -0
  99. package/dist/_chunks/phone-input-C8Op4sEc.js +513 -0
  100. package/dist/_chunks/phone-input-C8Op4sEc.js.map +1 -0
  101. package/dist/_chunks/popover-kFN8s84V.js +229 -0
  102. package/dist/_chunks/popover-kFN8s84V.js.map +1 -0
  103. package/dist/_chunks/popover.agent-K_d1cfbj.js +39 -0
  104. package/dist/_chunks/popover.agent-K_d1cfbj.js.map +1 -0
  105. package/dist/_chunks/privacy-lock.agent-C1i1-T58.js +185 -0
  106. package/dist/_chunks/privacy-lock.agent-C1i1-T58.js.map +1 -0
  107. package/dist/_chunks/progress-wNsqkw8I.js +253 -0
  108. package/dist/_chunks/progress-wNsqkw8I.js.map +1 -0
  109. package/dist/_chunks/progress.agent-C68rDOXL.js +27 -0
  110. package/dist/_chunks/progress.agent-C68rDOXL.js.map +1 -0
  111. package/dist/_chunks/{radio-cs8N1wJi.js → radio-DvF59ThA.js} +14 -13
  112. package/dist/_chunks/radio-DvF59ThA.js.map +1 -0
  113. package/dist/_chunks/radio-group-Cz1a4QCA.js +152 -0
  114. package/dist/_chunks/radio-group-Cz1a4QCA.js.map +1 -0
  115. package/dist/_chunks/recaptcha-widget.agent-BGHpU5zD.js +183 -0
  116. package/dist/_chunks/recaptcha-widget.agent-BGHpU5zD.js.map +1 -0
  117. package/dist/_chunks/resizable.agent-CMwZzvsi.js +456 -0
  118. package/dist/_chunks/resizable.agent-CMwZzvsi.js.map +1 -0
  119. package/dist/_chunks/{rich-text-editor.agent-COSb5_2D.js → rich-text-editor.agent-DnE125Tz.js} +221 -214
  120. package/dist/_chunks/rich-text-editor.agent-DnE125Tz.js.map +1 -0
  121. package/dist/_chunks/search-bar.agent-DxFAxctc.js +562 -0
  122. package/dist/_chunks/search-bar.agent-DxFAxctc.js.map +1 -0
  123. package/dist/_chunks/search-input-Xw3cdWXW.js +227 -0
  124. package/dist/_chunks/search-input-Xw3cdWXW.js.map +1 -0
  125. package/dist/_chunks/search-input.agent-CfZvViOd.js +69 -0
  126. package/dist/_chunks/search-input.agent-CfZvViOd.js.map +1 -0
  127. package/dist/_chunks/select-DY1Cb2Tg.js +410 -0
  128. package/dist/_chunks/select-DY1Cb2Tg.js.map +1 -0
  129. package/dist/_chunks/{sheet-BhNpLHc9.js → sheet-B9kH9pcI.js} +55 -54
  130. package/dist/_chunks/sheet-B9kH9pcI.js.map +1 -0
  131. package/dist/_chunks/sheet.agent-QAyTOxgk.js +46 -0
  132. package/dist/_chunks/sheet.agent-QAyTOxgk.js.map +1 -0
  133. package/dist/_chunks/{sidebar-OVzwN3jE.js → sidebar-CHF5xr_P.js} +188 -185
  134. package/dist/_chunks/sidebar-CHF5xr_P.js.map +1 -0
  135. package/dist/_chunks/sidebar.agent-C9TM_ZDZ.js +49 -0
  136. package/dist/_chunks/sidebar.agent-C9TM_ZDZ.js.map +1 -0
  137. package/dist/_chunks/{signature-capture.agent-C38VPXxg.js → signature-capture.agent-BpeDwFht.js} +127 -120
  138. package/dist/_chunks/signature-capture.agent-BpeDwFht.js.map +1 -0
  139. package/dist/_chunks/slider-CcsQTZTA.js +322 -0
  140. package/dist/_chunks/slider-CcsQTZTA.js.map +1 -0
  141. package/dist/_chunks/sparkline.agent-56Sj7nOP.js +245 -0
  142. package/dist/_chunks/sparkline.agent-56Sj7nOP.js.map +1 -0
  143. package/dist/_chunks/stepper-accordion.agent-ckKYZCIP.js +322 -0
  144. package/dist/_chunks/stepper-accordion.agent-ckKYZCIP.js.map +1 -0
  145. package/dist/_chunks/stepper-calendar.agent-9iT3ClIB.js +646 -0
  146. package/dist/_chunks/stepper-calendar.agent-9iT3ClIB.js.map +1 -0
  147. package/dist/_chunks/stepper-progress-Bmen-YXB.js +149 -0
  148. package/dist/_chunks/stepper-progress-Bmen-YXB.js.map +1 -0
  149. package/dist/_chunks/stepper-progress.agent-q9InWca4.js +61 -0
  150. package/dist/_chunks/stepper-progress.agent-q9InWca4.js.map +1 -0
  151. package/dist/_chunks/suggestion-chip-DhFrkRPj.js +169 -0
  152. package/dist/_chunks/suggestion-chip-DhFrkRPj.js.map +1 -0
  153. package/dist/_chunks/suggestion-chip.agent-6sNWFj7m.js +46 -0
  154. package/dist/_chunks/suggestion-chip.agent-6sNWFj7m.js.map +1 -0
  155. package/dist/_chunks/switch-BYEH8I53.js +196 -0
  156. package/dist/_chunks/switch-BYEH8I53.js.map +1 -0
  157. package/dist/_chunks/{tabs.agent-BpbVA-Zh.js → tabs.agent-h7NvsTR1.js} +146 -123
  158. package/dist/_chunks/tabs.agent-h7NvsTR1.js.map +1 -0
  159. package/dist/_chunks/{task-card-yW7tKlG4.js → task-card-CY5ztNkU.js} +2 -1
  160. package/dist/_chunks/{task-card-yW7tKlG4.js.map → task-card-CY5ztNkU.js.map} +1 -1
  161. package/dist/_chunks/task-card.agent-CUPKYd7w.js +22 -0
  162. package/dist/_chunks/task-card.agent-CUPKYd7w.js.map +1 -0
  163. package/dist/_chunks/task-tray-CCoUdorl.js +194 -0
  164. package/dist/_chunks/task-tray-CCoUdorl.js.map +1 -0
  165. package/dist/_chunks/text-area-C_M8wliK.js +239 -0
  166. package/dist/_chunks/text-area-C_M8wliK.js.map +1 -0
  167. package/dist/_chunks/text-input-BX39e6T6.js +272 -0
  168. package/dist/_chunks/text-input-BX39e6T6.js.map +1 -0
  169. package/dist/_chunks/theme-toggle.agent-btmXTWdW.js +394 -0
  170. package/dist/_chunks/theme-toggle.agent-btmXTWdW.js.map +1 -0
  171. package/dist/_chunks/time-picker-B8AMIrX7.js +410 -0
  172. package/dist/_chunks/time-picker-B8AMIrX7.js.map +1 -0
  173. package/dist/_chunks/timeline.agent-CRPza9wc.js +279 -0
  174. package/dist/_chunks/timeline.agent-CRPza9wc.js.map +1 -0
  175. package/dist/_chunks/{toast-lOhJDKOH.js → toast.agent-BjEGuq1Z.js} +403 -342
  176. package/dist/_chunks/toast.agent-BjEGuq1Z.js.map +1 -0
  177. package/dist/_chunks/{tooth-scheme.agent-BlDyu-Gx.js → tooth-scheme.agent-CWrQBjJM.js} +218 -211
  178. package/dist/_chunks/tooth-scheme.agent-CWrQBjJM.js.map +1 -0
  179. package/dist/_chunks/transcript-panel.agent-BXEYP6w-.js +337 -0
  180. package/dist/_chunks/transcript-panel.agent-BXEYP6w-.js.map +1 -0
  181. package/dist/_chunks/{workflow-map-XeqHDFvp.js → workflow-map-D2A7rTEG.js} +465 -368
  182. package/dist/_chunks/workflow-map-D2A7rTEG.js.map +1 -0
  183. package/dist/agent-catalog.json +2929 -268
  184. package/dist/components/accordion/accordion.agent.d.ts +2 -1
  185. package/dist/components/accordion/accordion.agent.d.ts.map +1 -1
  186. package/dist/components/accordion/accordion.d.ts +6 -0
  187. package/dist/components/accordion/accordion.d.ts.map +1 -1
  188. package/dist/components/accordion/index.js +2 -2
  189. package/dist/components/agenda-card/agenda-card.agent.d.ts +3 -0
  190. package/dist/components/agenda-card/agenda-card.agent.d.ts.map +1 -0
  191. package/dist/components/agenda-card/agenda-card.d.ts.map +1 -1
  192. package/dist/components/agenda-card/index.d.ts +1 -0
  193. package/dist/components/agenda-card/index.d.ts.map +1 -1
  194. package/dist/components/agenda-card/index.js +3 -1
  195. package/dist/components/agenda-card/index.js.map +1 -1
  196. package/dist/components/agenda-tray/agenda-tray.agent.d.ts +4 -0
  197. package/dist/components/agenda-tray/agenda-tray.agent.d.ts.map +1 -0
  198. package/dist/components/agenda-tray/agenda-tray.d.ts +19 -2
  199. package/dist/components/agenda-tray/agenda-tray.d.ts.map +1 -1
  200. package/dist/components/agenda-tray/index.d.ts +2 -1
  201. package/dist/components/agenda-tray/index.d.ts.map +1 -1
  202. package/dist/components/agenda-tray/index.js +3 -2
  203. package/dist/components/ai-prompt-input/ai-prompt-input.agent.d.ts +4 -0
  204. package/dist/components/ai-prompt-input/ai-prompt-input.agent.d.ts.map +1 -0
  205. package/dist/components/ai-prompt-input/ai-prompt-input.d.ts +18 -1
  206. package/dist/components/ai-prompt-input/ai-prompt-input.d.ts.map +1 -1
  207. package/dist/components/ai-prompt-input/index.d.ts +2 -1
  208. package/dist/components/ai-prompt-input/index.d.ts.map +1 -1
  209. package/dist/components/ai-prompt-input/index.js +3 -2
  210. package/dist/components/aspect-ratio/aspect-ratio.d.ts.map +1 -1
  211. package/dist/components/aspect-ratio/index.js +1 -1
  212. package/dist/components/audio-recorder/audio-recorder.agent.d.ts +4 -0
  213. package/dist/components/audio-recorder/audio-recorder.agent.d.ts.map +1 -0
  214. package/dist/components/audio-recorder/audio-recorder.d.ts +10 -1
  215. package/dist/components/audio-recorder/audio-recorder.d.ts.map +1 -1
  216. package/dist/components/audio-recorder/index.d.ts +2 -1
  217. package/dist/components/audio-recorder/index.d.ts.map +1 -1
  218. package/dist/components/audio-recorder/index.js +3 -2
  219. package/dist/components/autocomplete/autocomplete.agent.d.ts +2 -1
  220. package/dist/components/autocomplete/autocomplete.agent.d.ts.map +1 -1
  221. package/dist/components/autocomplete/autocomplete.d.ts +10 -0
  222. package/dist/components/autocomplete/autocomplete.d.ts.map +1 -1
  223. package/dist/components/autocomplete/index.js +1 -1
  224. package/dist/components/breadcrumb/breadcrumb.agent.d.ts +8 -0
  225. package/dist/components/breadcrumb/breadcrumb.agent.d.ts.map +1 -0
  226. package/dist/components/breadcrumb/breadcrumb.d.ts +21 -2
  227. package/dist/components/breadcrumb/breadcrumb.d.ts.map +1 -1
  228. package/dist/components/breadcrumb/index.d.ts +2 -1
  229. package/dist/components/breadcrumb/index.d.ts.map +1 -1
  230. package/dist/components/breadcrumb/index.js +5 -4
  231. package/dist/components/button/button.d.ts +1 -1
  232. package/dist/components/chart/chart.agent.d.ts.map +1 -1
  233. package/dist/components/chart/chart.d.ts +2 -0
  234. package/dist/components/chart/chart.d.ts.map +1 -1
  235. package/dist/components/chart/index.js +1 -1
  236. package/dist/components/chat-container/chat-container.agent.d.ts.map +1 -1
  237. package/dist/components/chat-container/chat-container.d.ts +3 -1
  238. package/dist/components/chat-container/chat-container.d.ts.map +1 -1
  239. package/dist/components/chat-container/index.js +2 -2
  240. package/dist/components/chat-input/chat-input.agent.d.ts +4 -0
  241. package/dist/components/chat-input/chat-input.agent.d.ts.map +1 -0
  242. package/dist/components/chat-input/chat-input.d.ts +10 -1
  243. package/dist/components/chat-input/chat-input.d.ts.map +1 -1
  244. package/dist/components/chat-input/index.d.ts +2 -1
  245. package/dist/components/chat-input/index.d.ts.map +1 -1
  246. package/dist/components/chat-input/index.js +4 -2
  247. package/dist/components/chat-input/index.js.map +1 -1
  248. package/dist/components/checkbox/checkbox.agent.d.ts +4 -0
  249. package/dist/components/checkbox/checkbox.agent.d.ts.map +1 -0
  250. package/dist/components/checkbox/checkbox.d.ts +6 -0
  251. package/dist/components/checkbox/checkbox.d.ts.map +1 -1
  252. package/dist/components/checkbox/index.js +1 -1
  253. package/dist/components/checkbox-group/checkbox-group.agent.d.ts +4 -0
  254. package/dist/components/checkbox-group/checkbox-group.agent.d.ts.map +1 -0
  255. package/dist/components/checkbox-group/checkbox-group.d.ts +8 -0
  256. package/dist/components/checkbox-group/checkbox-group.d.ts.map +1 -1
  257. package/dist/components/checkbox-group/index.js +1 -1
  258. package/dist/components/collapsible/collapsible.agent.d.ts +4 -0
  259. package/dist/components/collapsible/collapsible.agent.d.ts.map +1 -0
  260. package/dist/components/collapsible/collapsible.d.ts +8 -1
  261. package/dist/components/collapsible/collapsible.d.ts.map +1 -1
  262. package/dist/components/collapsible/index.d.ts +2 -1
  263. package/dist/components/collapsible/index.d.ts.map +1 -1
  264. package/dist/components/collapsible/index.js +4 -3
  265. package/dist/components/color-picker/color-picker.agent.d.ts +4 -0
  266. package/dist/components/color-picker/color-picker.agent.d.ts.map +1 -0
  267. package/dist/components/color-picker/color-picker.d.ts +5 -0
  268. package/dist/components/color-picker/color-picker.d.ts.map +1 -1
  269. package/dist/components/color-picker/index.js +1 -1
  270. package/dist/components/combobox/combobox.agent.d.ts +2 -1
  271. package/dist/components/combobox/combobox.agent.d.ts.map +1 -1
  272. package/dist/components/combobox/combobox.d.ts +10 -0
  273. package/dist/components/combobox/combobox.d.ts.map +1 -1
  274. package/dist/components/combobox/index.js +1 -1
  275. package/dist/components/command-palette/command-palette.agent.d.ts +2 -1
  276. package/dist/components/command-palette/command-palette.agent.d.ts.map +1 -1
  277. package/dist/components/command-palette/command-palette.d.ts +7 -0
  278. package/dist/components/command-palette/command-palette.d.ts.map +1 -1
  279. package/dist/components/command-palette/index.js +1 -1
  280. package/dist/components/data-table/index.js +1 -1
  281. package/dist/components/date-picker/date-picker.agent.d.ts +4 -0
  282. package/dist/components/date-picker/date-picker.agent.d.ts.map +1 -0
  283. package/dist/components/date-picker/date-picker.d.ts +16 -1
  284. package/dist/components/date-picker/date-picker.d.ts.map +1 -1
  285. package/dist/components/date-picker/index.d.ts +2 -1
  286. package/dist/components/date-picker/index.d.ts.map +1 -1
  287. package/dist/components/date-picker/index.js +3 -2
  288. package/dist/components/date-range-picker/date-range-picker.agent.d.ts +4 -0
  289. package/dist/components/date-range-picker/date-range-picker.agent.d.ts.map +1 -0
  290. package/dist/components/date-range-picker/date-range-picker.d.ts +16 -1
  291. package/dist/components/date-range-picker/date-range-picker.d.ts.map +1 -1
  292. package/dist/components/date-range-picker/index.d.ts +2 -1
  293. package/dist/components/date-range-picker/index.d.ts.map +1 -1
  294. package/dist/components/date-range-picker/index.js +3 -2
  295. package/dist/components/date-time-picker/date-time-picker.agent.d.ts +4 -0
  296. package/dist/components/date-time-picker/date-time-picker.agent.d.ts.map +1 -0
  297. package/dist/components/date-time-picker/date-time-picker.d.ts +16 -1
  298. package/dist/components/date-time-picker/date-time-picker.d.ts.map +1 -1
  299. package/dist/components/date-time-picker/index.d.ts +2 -1
  300. package/dist/components/date-time-picker/index.d.ts.map +1 -1
  301. package/dist/components/date-time-picker/index.js +3 -2
  302. package/dist/components/dialog/dialog.agent.d.ts +5 -6
  303. package/dist/components/dialog/dialog.agent.d.ts.map +1 -1
  304. package/dist/components/dialog/dialog.d.ts +11 -2
  305. package/dist/components/dialog/dialog.d.ts.map +1 -1
  306. package/dist/components/dialog/index.js +1 -1
  307. package/dist/components/dropdown-menu/dropdown-menu.agent.d.ts +2 -1
  308. package/dist/components/dropdown-menu/dropdown-menu.agent.d.ts.map +1 -1
  309. package/dist/components/dropdown-menu/dropdown-menu.d.ts +10 -2
  310. package/dist/components/dropdown-menu/dropdown-menu.d.ts.map +1 -1
  311. package/dist/components/dropdown-menu/index.js +2 -2
  312. package/dist/components/file-upload/file-upload.agent.d.ts +2 -1
  313. package/dist/components/file-upload/file-upload.agent.d.ts.map +1 -1
  314. package/dist/components/file-upload/file-upload.d.ts +12 -0
  315. package/dist/components/file-upload/file-upload.d.ts.map +1 -1
  316. package/dist/components/file-upload/index.js +1 -1
  317. package/dist/components/freemium-paywall/freemium-paywall.agent.d.ts +4 -0
  318. package/dist/components/freemium-paywall/freemium-paywall.agent.d.ts.map +1 -0
  319. package/dist/components/freemium-paywall/freemium-paywall.d.ts +8 -1
  320. package/dist/components/freemium-paywall/freemium-paywall.d.ts.map +1 -1
  321. package/dist/components/freemium-paywall/index.d.ts +2 -1
  322. package/dist/components/freemium-paywall/index.d.ts.map +1 -1
  323. package/dist/components/freemium-paywall/index.js +3 -2
  324. package/dist/components/index.d.ts +2 -0
  325. package/dist/components/index.d.ts.map +1 -1
  326. package/dist/components/link/index.d.ts +2 -0
  327. package/dist/components/link/index.d.ts.map +1 -0
  328. package/dist/components/link/index.js +5 -0
  329. package/dist/components/link/index.js.map +1 -0
  330. package/dist/components/link/link.d.ts +39 -0
  331. package/dist/components/link/link.d.ts.map +1 -0
  332. package/dist/components/list/index.d.ts +2 -1
  333. package/dist/components/list/index.d.ts.map +1 -1
  334. package/dist/components/list/index.js +3 -2
  335. package/dist/components/list/list.agent.d.ts +4 -0
  336. package/dist/components/list/list.agent.d.ts.map +1 -0
  337. package/dist/components/list/list.d.ts +8 -2
  338. package/dist/components/list/list.d.ts.map +1 -1
  339. package/dist/components/message-card/index.d.ts +1 -0
  340. package/dist/components/message-card/index.d.ts.map +1 -1
  341. package/dist/components/message-card/index.js +5 -3
  342. package/dist/components/message-card/index.js.map +1 -1
  343. package/dist/components/message-card/message-card.agent.d.ts +3 -0
  344. package/dist/components/message-card/message-card.agent.d.ts.map +1 -0
  345. package/dist/components/message-card/message-card.d.ts.map +1 -1
  346. package/dist/components/message-tray/index.d.ts +2 -1
  347. package/dist/components/message-tray/index.d.ts.map +1 -1
  348. package/dist/components/message-tray/index.js +3 -2
  349. package/dist/components/message-tray/message-tray.agent.d.ts +4 -0
  350. package/dist/components/message-tray/message-tray.agent.d.ts.map +1 -0
  351. package/dist/components/message-tray/message-tray.d.ts +27 -2
  352. package/dist/components/message-tray/message-tray.d.ts.map +1 -1
  353. package/dist/components/multi-select/index.js +1 -1
  354. package/dist/components/multi-select/multi-select.agent.d.ts +2 -1
  355. package/dist/components/multi-select/multi-select.agent.d.ts.map +1 -1
  356. package/dist/components/multi-select/multi-select.d.ts +10 -0
  357. package/dist/components/multi-select/multi-select.d.ts.map +1 -1
  358. package/dist/components/navigation-menu/index.d.ts +2 -1
  359. package/dist/components/navigation-menu/index.d.ts.map +1 -1
  360. package/dist/components/navigation-menu/index.js +7 -6
  361. package/dist/components/navigation-menu/navigation-menu.agent.d.ts +4 -0
  362. package/dist/components/navigation-menu/navigation-menu.agent.d.ts.map +1 -0
  363. package/dist/components/navigation-menu/navigation-menu.d.ts +28 -2
  364. package/dist/components/navigation-menu/navigation-menu.d.ts.map +1 -1
  365. package/dist/components/notification-card/index.d.ts +1 -0
  366. package/dist/components/notification-card/index.d.ts.map +1 -1
  367. package/dist/components/notification-card/index.js +5 -3
  368. package/dist/components/notification-card/index.js.map +1 -1
  369. package/dist/components/notification-card/notification-card.agent.d.ts +3 -0
  370. package/dist/components/notification-card/notification-card.agent.d.ts.map +1 -0
  371. package/dist/components/notification-card/notification-card.d.ts.map +1 -1
  372. package/dist/components/notification-tray/index.d.ts +2 -1
  373. package/dist/components/notification-tray/index.d.ts.map +1 -1
  374. package/dist/components/notification-tray/index.js +3 -2
  375. package/dist/components/notification-tray/notification-tray.agent.d.ts +4 -0
  376. package/dist/components/notification-tray/notification-tray.agent.d.ts.map +1 -0
  377. package/dist/components/notification-tray/notification-tray.d.ts +27 -2
  378. package/dist/components/notification-tray/notification-tray.d.ts.map +1 -1
  379. package/dist/components/number-input/index.js +1 -1
  380. package/dist/components/number-input/number-input.agent.d.ts +4 -0
  381. package/dist/components/number-input/number-input.agent.d.ts.map +1 -0
  382. package/dist/components/number-input/number-input.d.ts +7 -0
  383. package/dist/components/number-input/number-input.d.ts.map +1 -1
  384. package/dist/components/otp-input/index.js +1 -1
  385. package/dist/components/otp-input/otp-input.agent.d.ts +4 -0
  386. package/dist/components/otp-input/otp-input.agent.d.ts.map +1 -0
  387. package/dist/components/otp-input/otp-input.d.ts +10 -0
  388. package/dist/components/otp-input/otp-input.d.ts.map +1 -1
  389. package/dist/components/pagination/index.js +1 -1
  390. package/dist/components/pagination/pagination.agent.d.ts +2 -1
  391. package/dist/components/pagination/pagination.agent.d.ts.map +1 -1
  392. package/dist/components/pagination/pagination.d.ts +7 -0
  393. package/dist/components/pagination/pagination.d.ts.map +1 -1
  394. package/dist/components/password-input/index.js +1 -1
  395. package/dist/components/password-input/password-input.agent.d.ts +4 -0
  396. package/dist/components/password-input/password-input.agent.d.ts.map +1 -0
  397. package/dist/components/password-input/password-input.d.ts +9 -0
  398. package/dist/components/password-input/password-input.d.ts.map +1 -1
  399. package/dist/components/payment-form/index.js +2 -2
  400. package/dist/components/payment-form/payment-form.agent.d.ts.map +1 -1
  401. package/dist/components/payment-form/payment-form.d.ts +2 -0
  402. package/dist/components/payment-form/payment-form.d.ts.map +1 -1
  403. package/dist/components/pdf-viewer/index.js +1 -1
  404. package/dist/components/pdf-viewer/pdf-viewer.agent.d.ts.map +1 -1
  405. package/dist/components/pdf-viewer/pdf-viewer.d.ts +2 -0
  406. package/dist/components/pdf-viewer/pdf-viewer.d.ts.map +1 -1
  407. package/dist/components/phone-input/index.js +1 -1
  408. package/dist/components/phone-input/phone-input.agent.d.ts +4 -0
  409. package/dist/components/phone-input/phone-input.agent.d.ts.map +1 -0
  410. package/dist/components/phone-input/phone-input.d.ts +7 -0
  411. package/dist/components/phone-input/phone-input.d.ts.map +1 -1
  412. package/dist/components/popover/index.js +2 -2
  413. package/dist/components/popover/popover.agent.d.ts +2 -1
  414. package/dist/components/popover/popover.agent.d.ts.map +1 -1
  415. package/dist/components/popover/popover.d.ts +8 -1
  416. package/dist/components/popover/popover.d.ts.map +1 -1
  417. package/dist/components/privacy-lock/index.d.ts +2 -1
  418. package/dist/components/privacy-lock/index.d.ts.map +1 -1
  419. package/dist/components/privacy-lock/index.js +3 -2
  420. package/dist/components/privacy-lock/privacy-lock.agent.d.ts +4 -0
  421. package/dist/components/privacy-lock/privacy-lock.agent.d.ts.map +1 -0
  422. package/dist/components/privacy-lock/privacy-lock.d.ts +7 -1
  423. package/dist/components/privacy-lock/privacy-lock.d.ts.map +1 -1
  424. package/dist/components/progress/index.js +2 -2
  425. package/dist/components/progress/progress.agent.d.ts.map +1 -1
  426. package/dist/components/progress/progress.d.ts.map +1 -1
  427. package/dist/components/radio/index.js +1 -1
  428. package/dist/components/radio-group/index.js +2 -2
  429. package/dist/components/radio-group/radio-group.agent.d.ts +4 -0
  430. package/dist/components/radio-group/radio-group.agent.d.ts.map +1 -0
  431. package/dist/components/radio-group/radio-group.d.ts +5 -0
  432. package/dist/components/radio-group/radio-group.d.ts.map +1 -1
  433. package/dist/components/radio-group/radio.d.ts.map +1 -1
  434. package/dist/components/recaptcha-widget/index.d.ts +3 -0
  435. package/dist/components/recaptcha-widget/index.d.ts.map +1 -0
  436. package/dist/components/recaptcha-widget/index.js +6 -0
  437. package/dist/components/recaptcha-widget/index.js.map +1 -0
  438. package/dist/components/recaptcha-widget/recaptcha-widget.agent.d.ts +4 -0
  439. package/dist/components/recaptcha-widget/recaptcha-widget.agent.d.ts.map +1 -0
  440. package/dist/components/recaptcha-widget/recaptcha-widget.d.ts +56 -0
  441. package/dist/components/recaptcha-widget/recaptcha-widget.d.ts.map +1 -0
  442. package/dist/components/resizable/index.js +1 -1
  443. package/dist/components/resizable/resizable.agent.d.ts +2 -1
  444. package/dist/components/resizable/resizable.agent.d.ts.map +1 -1
  445. package/dist/components/resizable/resizable.d.ts +6 -0
  446. package/dist/components/resizable/resizable.d.ts.map +1 -1
  447. package/dist/components/rich-text-editor/index.js +1 -1
  448. package/dist/components/rich-text-editor/rich-text-editor.agent.d.ts.map +1 -1
  449. package/dist/components/rich-text-editor/rich-text-editor.d.ts +2 -0
  450. package/dist/components/rich-text-editor/rich-text-editor.d.ts.map +1 -1
  451. package/dist/components/search-bar/index.d.ts +2 -1
  452. package/dist/components/search-bar/index.d.ts.map +1 -1
  453. package/dist/components/search-bar/index.js +3 -2
  454. package/dist/components/search-bar/search-bar.agent.d.ts +4 -0
  455. package/dist/components/search-bar/search-bar.agent.d.ts.map +1 -0
  456. package/dist/components/search-bar/search-bar.d.ts +27 -1
  457. package/dist/components/search-bar/search-bar.d.ts.map +1 -1
  458. package/dist/components/search-input/index.d.ts +2 -1
  459. package/dist/components/search-input/index.d.ts.map +1 -1
  460. package/dist/components/search-input/index.js +4 -2
  461. package/dist/components/search-input/index.js.map +1 -1
  462. package/dist/components/search-input/search-input.agent.d.ts +4 -0
  463. package/dist/components/search-input/search-input.agent.d.ts.map +1 -0
  464. package/dist/components/search-input/search-input.d.ts +27 -0
  465. package/dist/components/search-input/search-input.d.ts.map +1 -1
  466. package/dist/components/select/index.js +1 -1
  467. package/dist/components/select/select.agent.d.ts +4 -0
  468. package/dist/components/select/select.agent.d.ts.map +1 -0
  469. package/dist/components/select/select.d.ts +9 -0
  470. package/dist/components/select/select.d.ts.map +1 -1
  471. package/dist/components/sheet/index.js +2 -2
  472. package/dist/components/sheet/sheet.agent.d.ts +2 -1
  473. package/dist/components/sheet/sheet.agent.d.ts.map +1 -1
  474. package/dist/components/sheet/sheet.d.ts +11 -2
  475. package/dist/components/sheet/sheet.d.ts.map +1 -1
  476. package/dist/components/sidebar/index.js +2 -2
  477. package/dist/components/sidebar/sidebar.agent.d.ts +2 -1
  478. package/dist/components/sidebar/sidebar.agent.d.ts.map +1 -1
  479. package/dist/components/sidebar/sidebar.d.ts +6 -0
  480. package/dist/components/sidebar/sidebar.d.ts.map +1 -1
  481. package/dist/components/signature-capture/index.js +1 -1
  482. package/dist/components/signature-capture/signature-capture.agent.d.ts.map +1 -1
  483. package/dist/components/signature-capture/signature-capture.d.ts +2 -0
  484. package/dist/components/signature-capture/signature-capture.d.ts.map +1 -1
  485. package/dist/components/slider/index.js +1 -1
  486. package/dist/components/slider/slider.agent.d.ts +4 -0
  487. package/dist/components/slider/slider.agent.d.ts.map +1 -0
  488. package/dist/components/slider/slider.d.ts +5 -0
  489. package/dist/components/slider/slider.d.ts.map +1 -1
  490. package/dist/components/sparkline/index.js +1 -1
  491. package/dist/components/sparkline/sparkline.agent.d.ts.map +1 -1
  492. package/dist/components/sparkline/sparkline.d.ts.map +1 -1
  493. package/dist/components/stepper-accordion/index.d.ts +2 -1
  494. package/dist/components/stepper-accordion/index.d.ts.map +1 -1
  495. package/dist/components/stepper-accordion/index.js +3 -2
  496. package/dist/components/stepper-accordion/stepper-accordion.agent.d.ts +4 -0
  497. package/dist/components/stepper-accordion/stepper-accordion.agent.d.ts.map +1 -0
  498. package/dist/components/stepper-accordion/stepper-accordion.d.ts +19 -1
  499. package/dist/components/stepper-accordion/stepper-accordion.d.ts.map +1 -1
  500. package/dist/components/stepper-calendar/index.d.ts +2 -1
  501. package/dist/components/stepper-calendar/index.d.ts.map +1 -1
  502. package/dist/components/stepper-calendar/index.js +3 -2
  503. package/dist/components/stepper-calendar/stepper-calendar.agent.d.ts +4 -0
  504. package/dist/components/stepper-calendar/stepper-calendar.agent.d.ts.map +1 -0
  505. package/dist/components/stepper-calendar/stepper-calendar.d.ts +19 -1
  506. package/dist/components/stepper-calendar/stepper-calendar.d.ts.map +1 -1
  507. package/dist/components/stepper-progress/index.d.ts +2 -1
  508. package/dist/components/stepper-progress/index.d.ts.map +1 -1
  509. package/dist/components/stepper-progress/index.js +4 -2
  510. package/dist/components/stepper-progress/index.js.map +1 -1
  511. package/dist/components/stepper-progress/stepper-progress.agent.d.ts +4 -0
  512. package/dist/components/stepper-progress/stepper-progress.agent.d.ts.map +1 -0
  513. package/dist/components/stepper-progress/stepper-progress.d.ts +26 -1
  514. package/dist/components/stepper-progress/stepper-progress.d.ts.map +1 -1
  515. package/dist/components/suggestion-chip/index.d.ts +2 -1
  516. package/dist/components/suggestion-chip/index.d.ts.map +1 -1
  517. package/dist/components/suggestion-chip/index.js +5 -3
  518. package/dist/components/suggestion-chip/index.js.map +1 -1
  519. package/dist/components/suggestion-chip/suggestion-chip.agent.d.ts +4 -0
  520. package/dist/components/suggestion-chip/suggestion-chip.agent.d.ts.map +1 -0
  521. package/dist/components/suggestion-chip/suggestion-chip.d.ts +7 -1
  522. package/dist/components/suggestion-chip/suggestion-chip.d.ts.map +1 -1
  523. package/dist/components/switch/index.js +1 -1
  524. package/dist/components/switch/switch.agent.d.ts +4 -0
  525. package/dist/components/switch/switch.agent.d.ts.map +1 -0
  526. package/dist/components/switch/switch.d.ts +6 -0
  527. package/dist/components/switch/switch.d.ts.map +1 -1
  528. package/dist/components/tabs/index.js +1 -1
  529. package/dist/components/tabs/tabs.agent.d.ts +2 -1
  530. package/dist/components/tabs/tabs.agent.d.ts.map +1 -1
  531. package/dist/components/tabs/tabs.d.ts +4 -0
  532. package/dist/components/tabs/tabs.d.ts.map +1 -1
  533. package/dist/components/task-card/index.d.ts +1 -0
  534. package/dist/components/task-card/index.d.ts.map +1 -1
  535. package/dist/components/task-card/index.js +5 -3
  536. package/dist/components/task-card/index.js.map +1 -1
  537. package/dist/components/task-card/task-card.agent.d.ts +3 -0
  538. package/dist/components/task-card/task-card.agent.d.ts.map +1 -0
  539. package/dist/components/task-card/task-card.d.ts.map +1 -1
  540. package/dist/components/task-tray/index.d.ts +2 -1
  541. package/dist/components/task-tray/index.d.ts.map +1 -1
  542. package/dist/components/task-tray/index.js +3 -2
  543. package/dist/components/task-tray/task-tray.agent.d.ts +4 -0
  544. package/dist/components/task-tray/task-tray.agent.d.ts.map +1 -0
  545. package/dist/components/task-tray/task-tray.d.ts +25 -2
  546. package/dist/components/task-tray/task-tray.d.ts.map +1 -1
  547. package/dist/components/text-area/index.js +1 -1
  548. package/dist/components/text-area/text-area.agent.d.ts +4 -0
  549. package/dist/components/text-area/text-area.agent.d.ts.map +1 -0
  550. package/dist/components/text-area/text-area.d.ts +7 -0
  551. package/dist/components/text-area/text-area.d.ts.map +1 -1
  552. package/dist/components/text-input/index.js +1 -1
  553. package/dist/components/text-input/text-input.agent.d.ts +4 -0
  554. package/dist/components/text-input/text-input.agent.d.ts.map +1 -0
  555. package/dist/components/text-input/text-input.d.ts +10 -0
  556. package/dist/components/text-input/text-input.d.ts.map +1 -1
  557. package/dist/components/theme-toggle/index.d.ts +2 -1
  558. package/dist/components/theme-toggle/index.d.ts.map +1 -1
  559. package/dist/components/theme-toggle/index.js +3 -2
  560. package/dist/components/theme-toggle/theme-toggle.agent.d.ts +4 -0
  561. package/dist/components/theme-toggle/theme-toggle.agent.d.ts.map +1 -0
  562. package/dist/components/theme-toggle/theme-toggle.d.ts +9 -2
  563. package/dist/components/theme-toggle/theme-toggle.d.ts.map +1 -1
  564. package/dist/components/time-picker/index.d.ts +2 -1
  565. package/dist/components/time-picker/index.d.ts.map +1 -1
  566. package/dist/components/time-picker/index.js +3 -2
  567. package/dist/components/time-picker/time-picker.agent.d.ts +4 -0
  568. package/dist/components/time-picker/time-picker.agent.d.ts.map +1 -0
  569. package/dist/components/time-picker/time-picker.d.ts +16 -1
  570. package/dist/components/time-picker/time-picker.d.ts.map +1 -1
  571. package/dist/components/timeline/index.d.ts +2 -1
  572. package/dist/components/timeline/index.d.ts.map +1 -1
  573. package/dist/components/timeline/index.js +3 -2
  574. package/dist/components/timeline/timeline.agent.d.ts +4 -0
  575. package/dist/components/timeline/timeline.agent.d.ts.map +1 -0
  576. package/dist/components/timeline/timeline.d.ts +8 -1
  577. package/dist/components/timeline/timeline.d.ts.map +1 -1
  578. package/dist/components/toast/index.d.ts +3 -2
  579. package/dist/components/toast/index.d.ts.map +1 -1
  580. package/dist/components/toast/index.js +7 -5
  581. package/dist/components/toast/toast.agent.d.ts +4 -0
  582. package/dist/components/toast/toast.agent.d.ts.map +1 -0
  583. package/dist/components/toast/toast.d.ts +8 -0
  584. package/dist/components/toast/toast.d.ts.map +1 -1
  585. package/dist/components/tooth-scheme/index.js +1 -1
  586. package/dist/components/tooth-scheme/tooth-scheme.agent.d.ts.map +1 -1
  587. package/dist/components/tooth-scheme/tooth-scheme.d.ts +2 -0
  588. package/dist/components/tooth-scheme/tooth-scheme.d.ts.map +1 -1
  589. package/dist/components/transcript-panel/index.d.ts +2 -1
  590. package/dist/components/transcript-panel/index.d.ts.map +1 -1
  591. package/dist/components/transcript-panel/index.js +3 -2
  592. package/dist/components/transcript-panel/transcript-panel.agent.d.ts +4 -0
  593. package/dist/components/transcript-panel/transcript-panel.agent.d.ts.map +1 -0
  594. package/dist/components/transcript-panel/transcript-panel.d.ts +10 -1
  595. package/dist/components/transcript-panel/transcript-panel.d.ts.map +1 -1
  596. package/dist/components/workflow/index.d.ts +2 -1
  597. package/dist/components/workflow/index.d.ts.map +1 -1
  598. package/dist/components/workflow/index.js +10 -7
  599. package/dist/components/workflow/workflow-card.d.ts.map +1 -1
  600. package/dist/components/workflow/workflow-editor.d.ts +7 -1
  601. package/dist/components/workflow/workflow-editor.d.ts.map +1 -1
  602. package/dist/components/workflow/workflow-map.d.ts +2 -0
  603. package/dist/components/workflow/workflow-map.d.ts.map +1 -1
  604. package/dist/components/workflow/workflow.agent.d.ts +6 -0
  605. package/dist/components/workflow/workflow.agent.d.ts.map +1 -0
  606. package/dist/i18n/config.d.ts.map +1 -1
  607. package/dist/i18n/config.js +24 -11
  608. package/dist/i18n/config.js.map +1 -1
  609. package/dist/i18n/resources.d.ts +7 -0
  610. package/dist/i18n/resources.d.ts.map +1 -1
  611. package/dist/index.js +471 -423
  612. package/dist/index.js.map +1 -1
  613. package/dist/locales/en.json +7 -0
  614. package/dist/patterns/leo-assistant/index.js +1 -1
  615. package/dist/patterns/patient-shell/index.js +1 -1
  616. package/dist/tokens.css +1 -1
  617. package/package.json +18 -2
  618. package/dist/_chunks/accordion-B6fyINUk.js.map +0 -1
  619. package/dist/_chunks/accordion.agent-Cz-yglRa.js +0 -17
  620. package/dist/_chunks/accordion.agent-Cz-yglRa.js.map +0 -1
  621. package/dist/_chunks/agenda-tray-BqQZwiHc.js +0 -120
  622. package/dist/_chunks/agenda-tray-BqQZwiHc.js.map +0 -1
  623. package/dist/_chunks/ai-prompt-input-CI27KmZ1.js +0 -380
  624. package/dist/_chunks/ai-prompt-input-CI27KmZ1.js.map +0 -1
  625. package/dist/_chunks/aspect-ratio-CxsdG8vk.js.map +0 -1
  626. package/dist/_chunks/audio-recorder-B-8SKgKn.js +0 -376
  627. package/dist/_chunks/audio-recorder-B-8SKgKn.js.map +0 -1
  628. package/dist/_chunks/autocomplete.agent-DqOy0_1P.js +0 -372
  629. package/dist/_chunks/autocomplete.agent-DqOy0_1P.js.map +0 -1
  630. package/dist/_chunks/breadcrumb-D6xpsP7n.js +0 -293
  631. package/dist/_chunks/breadcrumb-D6xpsP7n.js.map +0 -1
  632. package/dist/_chunks/chart.agent-BdS-_8MO.js.map +0 -1
  633. package/dist/_chunks/chat-container-Cm3SlR2p.js.map +0 -1
  634. package/dist/_chunks/chat-input-DreOPP8A.js.map +0 -1
  635. package/dist/_chunks/checkbox-DNK4qS2_.js +0 -116
  636. package/dist/_chunks/checkbox-DNK4qS2_.js.map +0 -1
  637. package/dist/_chunks/checkbox-group-CWpGZEF6.js +0 -146
  638. package/dist/_chunks/checkbox-group-CWpGZEF6.js.map +0 -1
  639. package/dist/_chunks/collapsible-D4LOdLxp.js +0 -67
  640. package/dist/_chunks/collapsible-D4LOdLxp.js.map +0 -1
  641. package/dist/_chunks/color-picker-e9PmpaGH.js.map +0 -1
  642. package/dist/_chunks/combobox.agent-ByobCLJ_.js +0 -350
  643. package/dist/_chunks/combobox.agent-ByobCLJ_.js.map +0 -1
  644. package/dist/_chunks/command-palette.agent-js2rxgeR.js.map +0 -1
  645. package/dist/_chunks/date-picker-DYXNsWmM.js +0 -1726
  646. package/dist/_chunks/date-picker-DYXNsWmM.js.map +0 -1
  647. package/dist/_chunks/date-range-picker-BcNDJI7m.js +0 -183
  648. package/dist/_chunks/date-range-picker-BcNDJI7m.js.map +0 -1
  649. package/dist/_chunks/date-time-picker-CmGiTU__.js +0 -202
  650. package/dist/_chunks/date-time-picker-CmGiTU__.js.map +0 -1
  651. package/dist/_chunks/dialog.agent-DEG_fVzG.js +0 -147
  652. package/dist/_chunks/dialog.agent-DEG_fVzG.js.map +0 -1
  653. package/dist/_chunks/dropdown-menu-Cw3EyPZv.js.map +0 -1
  654. package/dist/_chunks/dropdown-menu.agent-Cry4Nmes.js +0 -17
  655. package/dist/_chunks/dropdown-menu.agent-Cry4Nmes.js.map +0 -1
  656. package/dist/_chunks/file-upload.agent-B9AN82LA.js.map +0 -1
  657. package/dist/_chunks/freemium-paywall-CkefGLM_.js +0 -198
  658. package/dist/_chunks/freemium-paywall-CkefGLM_.js.map +0 -1
  659. package/dist/_chunks/list-B1ozIjQe.js +0 -359
  660. package/dist/_chunks/list-B1ozIjQe.js.map +0 -1
  661. package/dist/_chunks/message-card-qAp2-WQK.js.map +0 -1
  662. package/dist/_chunks/message-tray-VaLpQU5t.js +0 -303
  663. package/dist/_chunks/message-tray-VaLpQU5t.js.map +0 -1
  664. package/dist/_chunks/multi-select.agent-CNsyW3n9.js.map +0 -1
  665. package/dist/_chunks/navigation-menu-EVFau1O2.js +0 -180
  666. package/dist/_chunks/navigation-menu-EVFau1O2.js.map +0 -1
  667. package/dist/_chunks/notification-tray-B7U5YZYg.js +0 -328
  668. package/dist/_chunks/notification-tray-B7U5YZYg.js.map +0 -1
  669. package/dist/_chunks/number-input-DjpT_RXJ.js +0 -249
  670. package/dist/_chunks/number-input-DjpT_RXJ.js.map +0 -1
  671. package/dist/_chunks/otp-input-De5_Ih7B.js +0 -189
  672. package/dist/_chunks/otp-input-De5_Ih7B.js.map +0 -1
  673. package/dist/_chunks/pagination.agent-oEaqmtx5.js +0 -380
  674. package/dist/_chunks/pagination.agent-oEaqmtx5.js.map +0 -1
  675. package/dist/_chunks/password-input-DJDVznWH.js +0 -193
  676. package/dist/_chunks/password-input-DJDVznWH.js.map +0 -1
  677. package/dist/_chunks/payment-form-hcl-gGrp.js.map +0 -1
  678. package/dist/_chunks/payment-form.agent-BkEnRerR.js.map +0 -1
  679. package/dist/_chunks/pdf-viewer.agent-CfIHhcHx.js.map +0 -1
  680. package/dist/_chunks/phone-input-DE_39q65.js +0 -428
  681. package/dist/_chunks/phone-input-DE_39q65.js.map +0 -1
  682. package/dist/_chunks/popover-C3CTUsqh.js +0 -227
  683. package/dist/_chunks/popover-C3CTUsqh.js.map +0 -1
  684. package/dist/_chunks/popover.agent-C0qOx9WT.js +0 -13
  685. package/dist/_chunks/popover.agent-C0qOx9WT.js.map +0 -1
  686. package/dist/_chunks/privacy-lock-CQpgkLec.js +0 -132
  687. package/dist/_chunks/privacy-lock-CQpgkLec.js.map +0 -1
  688. package/dist/_chunks/progress-B4Of_pzz.js +0 -252
  689. package/dist/_chunks/progress-B4Of_pzz.js.map +0 -1
  690. package/dist/_chunks/progress.agent-CXkHURjX.js +0 -22
  691. package/dist/_chunks/progress.agent-CXkHURjX.js.map +0 -1
  692. package/dist/_chunks/radio-cs8N1wJi.js.map +0 -1
  693. package/dist/_chunks/radio-group-BIUbpWml.js +0 -89
  694. package/dist/_chunks/radio-group-BIUbpWml.js.map +0 -1
  695. package/dist/_chunks/resizable.agent-DBpPGNdy.js +0 -435
  696. package/dist/_chunks/resizable.agent-DBpPGNdy.js.map +0 -1
  697. package/dist/_chunks/rich-text-editor.agent-COSb5_2D.js.map +0 -1
  698. package/dist/_chunks/search-bar-fcGqDFW3.js +0 -397
  699. package/dist/_chunks/search-bar-fcGqDFW3.js.map +0 -1
  700. package/dist/_chunks/search-input-BVMCONyN.js +0 -197
  701. package/dist/_chunks/search-input-BVMCONyN.js.map +0 -1
  702. package/dist/_chunks/select-IY_JQa-F.js +0 -321
  703. package/dist/_chunks/select-IY_JQa-F.js.map +0 -1
  704. package/dist/_chunks/sheet-BhNpLHc9.js.map +0 -1
  705. package/dist/_chunks/sheet.agent-DwQlBqK9.js +0 -13
  706. package/dist/_chunks/sheet.agent-DwQlBqK9.js.map +0 -1
  707. package/dist/_chunks/sidebar-OVzwN3jE.js.map +0 -1
  708. package/dist/_chunks/sidebar.agent-B0fnH9CC.js +0 -17
  709. package/dist/_chunks/sidebar.agent-B0fnH9CC.js.map +0 -1
  710. package/dist/_chunks/signature-capture.agent-C38VPXxg.js.map +0 -1
  711. package/dist/_chunks/slider-DjyRt3Mp.js +0 -274
  712. package/dist/_chunks/slider-DjyRt3Mp.js.map +0 -1
  713. package/dist/_chunks/sparkline.agent-C_xp3NRB.js +0 -238
  714. package/dist/_chunks/sparkline.agent-C_xp3NRB.js.map +0 -1
  715. package/dist/_chunks/stepper-accordion-CGog0JSF.js +0 -233
  716. package/dist/_chunks/stepper-accordion-CGog0JSF.js.map +0 -1
  717. package/dist/_chunks/stepper-calendar-_fLOAjus.js +0 -570
  718. package/dist/_chunks/stepper-calendar-_fLOAjus.js.map +0 -1
  719. package/dist/_chunks/stepper-progress-rE7tn7WY.js +0 -129
  720. package/dist/_chunks/stepper-progress-rE7tn7WY.js.map +0 -1
  721. package/dist/_chunks/suggestion-chip-BNJ2M8Os.js +0 -158
  722. package/dist/_chunks/suggestion-chip-BNJ2M8Os.js.map +0 -1
  723. package/dist/_chunks/switch-aN2EYxHh.js +0 -138
  724. package/dist/_chunks/switch-aN2EYxHh.js.map +0 -1
  725. package/dist/_chunks/tabs.agent-BpbVA-Zh.js.map +0 -1
  726. package/dist/_chunks/task-tray-BzahI5FQ.js +0 -100
  727. package/dist/_chunks/task-tray-BzahI5FQ.js.map +0 -1
  728. package/dist/_chunks/text-area-DmKSd2DG.js +0 -152
  729. package/dist/_chunks/text-area-DmKSd2DG.js.map +0 -1
  730. package/dist/_chunks/text-input-CRHvl5zk.js +0 -188
  731. package/dist/_chunks/text-input-CRHvl5zk.js.map +0 -1
  732. package/dist/_chunks/theme-toggle-BHiMMEQN.js +0 -329
  733. package/dist/_chunks/theme-toggle-BHiMMEQN.js.map +0 -1
  734. package/dist/_chunks/time-picker-D-EueWUG.js +0 -322
  735. package/dist/_chunks/time-picker-D-EueWUG.js.map +0 -1
  736. package/dist/_chunks/timeline-RgAIzpMd.js +0 -220
  737. package/dist/_chunks/timeline-RgAIzpMd.js.map +0 -1
  738. package/dist/_chunks/toast-lOhJDKOH.js.map +0 -1
  739. package/dist/_chunks/tooth-scheme.agent-BlDyu-Gx.js.map +0 -1
  740. package/dist/_chunks/transcript-panel-CNbVGG9L.js +0 -266
  741. package/dist/_chunks/transcript-panel-CNbVGG9L.js.map +0 -1
  742. package/dist/_chunks/workflow-map-XeqHDFvp.js.map +0 -1
@@ -1,293 +0,0 @@
1
- import { jsx as s, jsxs as k } from "react/jsx-runtime";
2
- import { forwardRef as v, Children as j, isValidElement as B, cloneElement as I, useContext as T, createContext as V } from "react";
3
- import * as g from "@radix-ui/react-dropdown-menu";
4
- import { Slot as D } from "@radix-ui/react-slot";
5
- import { c as G } from "./index-D2ZczOXr.js";
6
- import { useTranslation as y } from "react-i18next";
7
- import { E as H } from "./ellipsis-rgGdiK_9.js";
8
- import { C as M } from "./chevron-right-BrpYejk0.js";
9
- const L = V({
10
- separator: "chevron"
11
- }), O = v(
12
- ({
13
- children: o,
14
- className: i,
15
- "aria-label": t,
16
- separator: n = "chevron",
17
- maxItems: r = 4,
18
- itemsBeforeCollapse: e = 1,
19
- itemsAfterCollapse: a = 1,
20
- disableCollapse: m = !1,
21
- ...c
22
- }, p) => {
23
- const { t: x } = y();
24
- return /* @__PURE__ */ s(L.Provider, { value: { separator: n }, children: /* @__PURE__ */ s(
25
- "nav",
26
- {
27
- ref: p,
28
- "aria-label": t ?? x("ui.navigation.breadcrumb.label"),
29
- "data-component": "breadcrumb",
30
- className: i,
31
- ...c,
32
- children: /* @__PURE__ */ s(
33
- $,
34
- {
35
- maxItems: r,
36
- itemsBeforeCollapse: e,
37
- itemsAfterCollapse: a,
38
- disableCollapse: m,
39
- children: o
40
- }
41
- )
42
- }
43
- ) });
44
- }
45
- );
46
- O.displayName = "Breadcrumb";
47
- const _ = [
48
- "ds:flex ds:flex-wrap ds:items-center",
49
- "ds:gap-[var(--spacing-xs)]",
50
- "ds:text-[var(--font-size-sm)] ds:text-[var(--muted-foreground)]",
51
- "ds:ps-0 ds:m-0",
52
- "ds:list-none"
53
- ].join(" "), $ = v(
54
- ({
55
- children: o,
56
- className: i,
57
- maxItems: t = 4,
58
- itemsBeforeCollapse: n = 1,
59
- itemsAfterCollapse: r = 1,
60
- disableCollapse: e = !1,
61
- ...a
62
- }, m) => {
63
- const c = j.toArray(o).filter((d) => B(d)), p = c.length, x = !e && p > t && n + r < p, w = (d, l, f) => I(d, {
64
- isCurrent: d.props.isCurrent ?? l,
65
- key: f
66
- }), b = (d, l) => d ? /* @__PURE__ */ s(R, {}, l) : null;
67
- let u = [];
68
- if (!x)
69
- c.forEach((d, l) => {
70
- const f = l === p - 1;
71
- u.push(w(d, f, `item-${l}`)), u.push(b(!f, `sep-${l}`));
72
- });
73
- else {
74
- const d = c.slice(0, n), l = c.slice(p - r), f = c.slice(n, p - r);
75
- d.forEach((C, h) => {
76
- u.push(w(C, !1, `b-${h}`)), u.push(b(!0, `b-sep-${h}`));
77
- }), u.push(
78
- /* @__PURE__ */ s(P, { children: /* @__PURE__ */ s(S, { hiddenItems: f }) }, "ellipsis")
79
- ), u.push(b(!0, "ellipsis-sep")), l.forEach((C, h) => {
80
- const z = h === l.length - 1;
81
- u.push(w(C, z, `a-${h}`)), u.push(b(!z, `a-sep-${h}`));
82
- });
83
- }
84
- return /* @__PURE__ */ s("ol", { ref: m, className: [_, i].filter(Boolean).join(" "), ...a, children: u });
85
- }
86
- );
87
- $.displayName = "BreadcrumbList";
88
- const q = [
89
- "ds:inline-flex ds:items-center",
90
- "ds:max-inline-size-[16rem]",
91
- "ds:min-h-[var(--min-target-size)]",
92
- "ds:py-[var(--spacing-xs)]"
93
- ].join(" "), P = v(
94
- ({ children: o, className: i, isCurrent: t = !1, ...n }, r) => /* @__PURE__ */ s(
95
- "li",
96
- {
97
- ref: r,
98
- className: [q, i].filter(Boolean).join(" "),
99
- ...n,
100
- children: j.map(
101
- o,
102
- (e) => {
103
- var a;
104
- return B(e) && (e.type === N || (a = e.props) != null && a._link) ? I(e, {
105
- isCurrent: t
106
- }) : e;
107
- }
108
- )
109
- }
110
- )
111
- );
112
- P.displayName = "BreadcrumbItem";
113
- const E = [
114
- "ds:inline-flex ds:items-center",
115
- "ds:max-inline-size-[16rem]",
116
- "ds:overflow-hidden ds:text-ellipsis ds:whitespace-nowrap",
117
- "ds:break-normal",
118
- "ds:text-[var(--muted-foreground)] ds:no-underline",
119
- "ds:hover:text-[var(--foreground)] ds:hover:underline",
120
- "ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid",
121
- "ds:focus-visible:outline-[var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]",
122
- "ds:rounded-[var(--radius-sm)]",
123
- "ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none",
124
- "ds:min-h-[var(--min-target-size)] ds:ps-[var(--spacing-xs)] ds:pe-[var(--spacing-xs)]"
125
- ].join(" "), F = [
126
- "ds:inline-flex ds:items-center",
127
- "ds:max-inline-size-[16rem]",
128
- "ds:overflow-hidden ds:text-ellipsis ds:whitespace-nowrap",
129
- "ds:break-normal",
130
- "ds:text-[var(--foreground)] ds:font-[var(--font-weight-semibold)]",
131
- "ds:min-h-[var(--min-target-size)] ds:ps-[var(--spacing-xs)] ds:pe-[var(--spacing-xs)]"
132
- ].join(" "), N = v(
133
- ({ asChild: o = !1, isCurrent: i = !1, className: t, children: n, ...r }, e) => {
134
- const { t: a } = y();
135
- return i ? /* @__PURE__ */ s(
136
- "span",
137
- {
138
- "aria-current": "page",
139
- "aria-label": r["aria-label"] ?? a("ui.navigation.breadcrumb.current"),
140
- className: [F, t].filter(Boolean).join(" "),
141
- children: n
142
- }
143
- ) : o ? /* @__PURE__ */ s(
144
- D,
145
- {
146
- ref: e,
147
- className: [E, t].filter(Boolean).join(" "),
148
- ...r,
149
- children: n
150
- }
151
- ) : /* @__PURE__ */ s(
152
- "a",
153
- {
154
- ref: e,
155
- className: [E, t].filter(Boolean).join(" "),
156
- ...r,
157
- children: n
158
- }
159
- );
160
- }
161
- );
162
- N.displayName = "BreadcrumbLink";
163
- const J = G(
164
- [
165
- "ds:inline-flex ds:items-center ds:justify-center",
166
- "ds:text-[var(--muted-foreground)]",
167
- "ds:ms-[var(--spacing-xs)] ds:me-[var(--spacing-xs)]",
168
- "ds:select-none"
169
- ].join(" "),
170
- {
171
- variants: {
172
- variant: {
173
- chevron: "",
174
- slash: ""
175
- }
176
- },
177
- defaultVariants: { variant: "chevron" }
178
- }
179
- ), R = v(
180
- ({ className: o, variant: i, children: t, ...n }, r) => {
181
- const e = T(L), a = i ?? e.separator, m = a === "slash" ? /* @__PURE__ */ s("span", { "aria-hidden": "true", children: "/" }) : /* @__PURE__ */ s(
182
- M,
183
- {
184
- "aria-hidden": "true",
185
- className: "ds:size-4 ds:rtl:-scale-x-100"
186
- }
187
- );
188
- return /* @__PURE__ */ s(
189
- "li",
190
- {
191
- ref: r,
192
- "aria-hidden": "true",
193
- role: "presentation",
194
- className: J({ variant: a, className: o }),
195
- ...n,
196
- children: t ?? m
197
- }
198
- );
199
- }
200
- );
201
- R.displayName = "BreadcrumbSeparator";
202
- const K = [
203
- "ds:inline-flex ds:items-center ds:justify-center",
204
- "ds:min-w-[var(--min-target-size)] ds:min-h-[var(--min-target-size)]",
205
- "ds:rounded-[var(--radius-sm)]",
206
- "ds:text-[var(--muted-foreground)]",
207
- "ds:hover:text-[var(--foreground)]",
208
- "ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid",
209
- "ds:focus-visible:outline-[var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]",
210
- "ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none"
211
- ].join(" "), Q = [
212
- "ds:z-[var(--z-dropdown)] ds:min-w-[12rem] ds:overflow-hidden",
213
- "ds:rounded-[var(--radius-md)] ds:border ds:border-[var(--border)]",
214
- "ds:bg-[var(--background)] ds:text-[var(--foreground)]",
215
- "ds:shadow-[var(--shadow-lg)]",
216
- "ds:p-[var(--spacing-xs)]",
217
- "ds:animate-in ds:fade-in ds:zoom-in-95 ds:motion-reduce:animate-none"
218
- ].join(" "), U = [
219
- "ds:flex ds:items-center",
220
- "ds:min-h-[var(--min-target-size)]",
221
- "ds:ps-[var(--spacing-sm)] ds:pe-[var(--spacing-sm)]",
222
- "ds:rounded-[var(--radius-sm)]",
223
- "ds:text-[var(--foreground)] ds:cursor-pointer ds:select-none",
224
- "ds:data-[highlighted]:bg-[var(--muted)] ds:data-[highlighted]:text-[var(--foreground)]",
225
- "ds:outline-none"
226
- ].join(" "), S = v(
227
- ({ className: o, hiddenItems: i = [], ...t }, n) => {
228
- const { t: r } = y(), e = r("ui.navigation.breadcrumb.showPath");
229
- return /* @__PURE__ */ k(g.Root, { children: [
230
- /* @__PURE__ */ s(g.Trigger, { asChild: !0, children: /* @__PURE__ */ k(
231
- "button",
232
- {
233
- ref: n,
234
- type: "button",
235
- "aria-label": e,
236
- className: [K, o].filter(Boolean).join(" "),
237
- ...t,
238
- children: [
239
- /* @__PURE__ */ s(H, { "aria-hidden": "true", className: "ds:size-4" }),
240
- /* @__PURE__ */ s("span", { className: "ds:sr-only", children: e })
241
- ]
242
- }
243
- ) }),
244
- /* @__PURE__ */ s(g.Portal, { children: /* @__PURE__ */ s(
245
- g.Content,
246
- {
247
- className: Q,
248
- align: "start",
249
- sideOffset: 6,
250
- children: i.map((a, m) => {
251
- const c = W(a);
252
- return /* @__PURE__ */ s(
253
- g.Item,
254
- {
255
- asChild: !0,
256
- className: U,
257
- children: c ?? /* @__PURE__ */ s("span", { children: a })
258
- },
259
- `hidden-${m}`
260
- );
261
- })
262
- }
263
- ) })
264
- ] });
265
- }
266
- );
267
- S.displayName = "BreadcrumbEllipsis";
268
- function W(o) {
269
- let i = null;
270
- const t = o.props.children;
271
- return j.forEach(t, (n) => {
272
- if (!i && B(n) && n.type === N) {
273
- const r = n.props, e = typeof r.href == "string" ? r.href : void 0, a = e && /^\s*javascript:/i.test(e) ? void 0 : e;
274
- i = /* @__PURE__ */ s(
275
- "a",
276
- {
277
- href: a,
278
- onClick: r.onClick,
279
- children: r.children
280
- }
281
- );
282
- }
283
- }), i;
284
- }
285
- export {
286
- O as B,
287
- S as a,
288
- P as b,
289
- N as c,
290
- $ as d,
291
- R as e
292
- };
293
- //# sourceMappingURL=breadcrumb-D6xpsP7n.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"breadcrumb-D6xpsP7n.js","sources":["../../src/components/breadcrumb/breadcrumb.tsx"],"sourcesContent":["import {\n Children,\n cloneElement,\n createContext,\n forwardRef,\n isValidElement,\n useContext,\n type AnchorHTMLAttributes,\n type ComponentPropsWithoutRef,\n type ReactElement,\n type ReactNode,\n} from 'react';\nimport * as DropdownMenu from '@radix-ui/react-dropdown-menu';\nimport { Slot } from '@radix-ui/react-slot';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport { ChevronRight, MoreHorizontal } from 'lucide-react';\n\n/* -------------------------------------------------------------------- */\n/* Context — shares separator variant between siblings */\n/* -------------------------------------------------------------------- */\n\ntype SeparatorVariant = 'chevron' | 'slash';\n\ninterface BreadcrumbContextValue {\n separator: SeparatorVariant;\n}\n\nconst BreadcrumbContext = createContext<BreadcrumbContextValue>({\n separator: 'chevron',\n});\n\n/* -------------------------------------------------------------------- */\n/* Root — <nav aria-label> wrapper + truncation engine */\n/* -------------------------------------------------------------------- */\n\nexport interface BreadcrumbProps extends ComponentPropsWithoutRef<'nav'> {\n /** Override the default `aria-label` (falls back to translated `ui.navigation.breadcrumb.label`). */\n 'aria-label'?: string;\n /** Separator glyph between items. @default 'chevron' */\n separator?: SeparatorVariant;\n /** Maximum number of visible crumbs before collapsing. @default 4 */\n maxItems?: number;\n /** Items kept visible at the start. @default 1 */\n itemsBeforeCollapse?: number;\n /** Items kept visible at the end. @default 1 */\n itemsAfterCollapse?: number;\n /** If true, disables collapse behaviour. */\n disableCollapse?: boolean;\n}\n\nconst Breadcrumb = forwardRef<HTMLElement, BreadcrumbProps>(\n (\n {\n children,\n className,\n 'aria-label': ariaLabel,\n separator = 'chevron',\n maxItems = 4,\n itemsBeforeCollapse = 1,\n itemsAfterCollapse = 1,\n disableCollapse = false,\n ...rest\n },\n ref,\n ) => {\n const { t } = useTranslation();\n return (\n <BreadcrumbContext.Provider value={{ separator }}>\n <nav\n ref={ref}\n aria-label={ariaLabel ?? t('ui.navigation.breadcrumb.label')}\n data-component=\"breadcrumb\"\n className={className}\n {...rest}\n >\n <BreadcrumbList\n maxItems={maxItems}\n itemsBeforeCollapse={itemsBeforeCollapse}\n itemsAfterCollapse={itemsAfterCollapse}\n disableCollapse={disableCollapse}\n >\n {children}\n </BreadcrumbList>\n </nav>\n </BreadcrumbContext.Provider>\n );\n },\n);\nBreadcrumb.displayName = 'Breadcrumb';\n\n/* -------------------------------------------------------------------- */\n/* List — walks its children, injects separators & ellipsis */\n/* -------------------------------------------------------------------- */\n\nconst listClasses = [\n 'ds:flex ds:flex-wrap ds:items-center',\n 'ds:gap-[var(--spacing-xs)]',\n 'ds:text-[var(--font-size-sm)] ds:text-[var(--muted-foreground)]',\n 'ds:ps-0 ds:m-0',\n 'ds:list-none',\n].join(' ');\n\nexport interface BreadcrumbListProps extends ComponentPropsWithoutRef<'ol'> {\n maxItems?: number;\n itemsBeforeCollapse?: number;\n itemsAfterCollapse?: number;\n disableCollapse?: boolean;\n}\n\nconst BreadcrumbList = forwardRef<HTMLOListElement, BreadcrumbListProps>(\n (\n {\n children,\n className,\n maxItems = 4,\n itemsBeforeCollapse = 1,\n itemsAfterCollapse = 1,\n disableCollapse = false,\n ...rest\n },\n ref,\n ) => {\n const arr = Children.toArray(children).filter((c) => isValidElement(c)) as ReactElement[];\n const total = arr.length;\n\n const shouldCollapse =\n !disableCollapse &&\n total > maxItems &&\n itemsBeforeCollapse + itemsAfterCollapse < total;\n\n const renderItem = (child: ReactElement, isLast: boolean, key: string) =>\n cloneElement(child, {\n isCurrent: (child.props as BreadcrumbItemProps).isCurrent ?? isLast,\n key,\n } as Partial<BreadcrumbItemProps>);\n\n const renderSeparatorIf = (condition: boolean, key: string) =>\n condition ? <BreadcrumbSeparator key={key} /> : null;\n\n let nodes: ReactNode[] = [];\n if (!shouldCollapse) {\n arr.forEach((child, i) => {\n const isLast = i === total - 1;\n nodes.push(renderItem(child, isLast, `item-${i}`));\n nodes.push(renderSeparatorIf(!isLast, `sep-${i}`));\n });\n } else {\n const before = arr.slice(0, itemsBeforeCollapse);\n const after = arr.slice(total - itemsAfterCollapse);\n const hidden = arr.slice(itemsBeforeCollapse, total - itemsAfterCollapse);\n\n before.forEach((child, i) => {\n nodes.push(renderItem(child, false, `b-${i}`));\n nodes.push(renderSeparatorIf(true, `b-sep-${i}`));\n });\n\n nodes.push(\n <BreadcrumbItem key=\"ellipsis\">\n <BreadcrumbEllipsis hiddenItems={hidden} />\n </BreadcrumbItem>,\n );\n nodes.push(renderSeparatorIf(true, 'ellipsis-sep'));\n\n after.forEach((child, i) => {\n const isLast = i === after.length - 1;\n nodes.push(renderItem(child, isLast, `a-${i}`));\n nodes.push(renderSeparatorIf(!isLast, `a-sep-${i}`));\n });\n }\n\n return (\n <ol ref={ref} className={[listClasses, className].filter(Boolean).join(' ')} {...rest}>\n {nodes}\n </ol>\n );\n },\n);\nBreadcrumbList.displayName = 'BreadcrumbList';\n\n/* -------------------------------------------------------------------- */\n/* Item — <li> marks current when `isCurrent` */\n/* -------------------------------------------------------------------- */\n\nconst itemClasses = [\n 'ds:inline-flex ds:items-center',\n 'ds:max-inline-size-[16rem]',\n 'ds:min-h-[var(--min-target-size)]',\n 'ds:py-[var(--spacing-xs)]',\n].join(' ');\n\nexport interface BreadcrumbItemProps extends ComponentPropsWithoutRef<'li'> {\n /** Set automatically by `BreadcrumbList` on the final item. */\n isCurrent?: boolean;\n}\n\nconst BreadcrumbItem = forwardRef<HTMLLIElement, BreadcrumbItemProps>(\n ({ children, className, isCurrent = false, ...rest }, ref) => (\n <li\n ref={ref}\n className={[itemClasses, className].filter(Boolean).join(' ')}\n {...rest}\n >\n {Children.map(children, (child) =>\n isValidElement(child) &&\n (child.type === BreadcrumbLink || (child.props as { _link?: boolean })?._link)\n ? cloneElement(child as ReactElement<BreadcrumbLinkProps>, {\n isCurrent,\n })\n : child,\n )}\n </li>\n ),\n);\nBreadcrumbItem.displayName = 'BreadcrumbItem';\n\n/* -------------------------------------------------------------------- */\n/* Link — renders <a>, or plain text when current */\n/* -------------------------------------------------------------------- */\n\nconst linkClasses = [\n 'ds:inline-flex ds:items-center',\n 'ds:max-inline-size-[16rem]',\n 'ds:overflow-hidden ds:text-ellipsis ds:whitespace-nowrap',\n 'ds:break-normal',\n 'ds:text-[var(--muted-foreground)] ds:no-underline',\n 'ds:hover:text-[var(--foreground)] ds:hover:underline',\n 'ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid',\n 'ds:focus-visible:outline-[var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]',\n 'ds:rounded-[var(--radius-sm)]',\n 'ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none',\n 'ds:min-h-[var(--min-target-size)] ds:ps-[var(--spacing-xs)] ds:pe-[var(--spacing-xs)]',\n].join(' ');\n\nconst currentClasses = [\n 'ds:inline-flex ds:items-center',\n 'ds:max-inline-size-[16rem]',\n 'ds:overflow-hidden ds:text-ellipsis ds:whitespace-nowrap',\n 'ds:break-normal',\n 'ds:text-[var(--foreground)] ds:font-[var(--font-weight-semibold)]',\n 'ds:min-h-[var(--min-target-size)] ds:ps-[var(--spacing-xs)] ds:pe-[var(--spacing-xs)]',\n].join(' ');\n\nexport interface BreadcrumbLinkProps\n extends AnchorHTMLAttributes<HTMLAnchorElement> {\n /** Use Radix `Slot` so consumers can pass a router link. */\n asChild?: boolean;\n /** Set by the parent Item when this is the current page. */\n isCurrent?: boolean;\n}\n\nconst BreadcrumbLink = forwardRef<HTMLAnchorElement, BreadcrumbLinkProps>(\n ({ asChild = false, isCurrent = false, className, children, ...rest }, ref) => {\n const { t } = useTranslation();\n\n if (isCurrent) {\n return (\n <span\n aria-current=\"page\"\n aria-label={\n (rest['aria-label'] as string | undefined) ??\n t('ui.navigation.breadcrumb.current')\n }\n className={[currentClasses, className].filter(Boolean).join(' ')}\n >\n {children}\n </span>\n );\n }\n\n if (asChild) {\n return (\n <Slot\n ref={ref}\n className={[linkClasses, className].filter(Boolean).join(' ')}\n {...rest}\n >\n {children}\n </Slot>\n );\n }\n\n return (\n <a\n ref={ref}\n className={[linkClasses, className].filter(Boolean).join(' ')}\n {...rest}\n >\n {children}\n </a>\n );\n },\n);\nBreadcrumbLink.displayName = 'BreadcrumbLink';\n\n/* -------------------------------------------------------------------- */\n/* Separator */\n/* -------------------------------------------------------------------- */\n\nconst separatorVariants = cva(\n [\n 'ds:inline-flex ds:items-center ds:justify-center',\n 'ds:text-[var(--muted-foreground)]',\n 'ds:ms-[var(--spacing-xs)] ds:me-[var(--spacing-xs)]',\n 'ds:select-none',\n ].join(' '),\n {\n variants: {\n variant: {\n chevron: '',\n slash: '',\n },\n },\n defaultVariants: { variant: 'chevron' },\n },\n);\n\nexport interface BreadcrumbSeparatorProps\n extends Omit<ComponentPropsWithoutRef<'li'>, 'children'>,\n VariantProps<typeof separatorVariants> {\n children?: ReactNode;\n}\n\nconst BreadcrumbSeparator = forwardRef<HTMLLIElement, BreadcrumbSeparatorProps>(\n ({ className, variant, children, ...rest }, ref) => {\n const ctx = useContext(BreadcrumbContext);\n const resolved = variant ?? ctx.separator;\n const defaultGlyph =\n resolved === 'slash' ? (\n <span aria-hidden=\"true\">/</span>\n ) : (\n <ChevronRight\n aria-hidden=\"true\"\n className=\"ds:size-4 ds:rtl:-scale-x-100\"\n />\n );\n return (\n <li\n ref={ref}\n aria-hidden=\"true\"\n role=\"presentation\"\n className={separatorVariants({ variant: resolved, className })}\n {...rest}\n >\n {children ?? defaultGlyph}\n </li>\n );\n },\n);\nBreadcrumbSeparator.displayName = 'BreadcrumbSeparator';\n\n/* -------------------------------------------------------------------- */\n/* Ellipsis — opens a Radix DropdownMenu with hidden crumbs */\n/* -------------------------------------------------------------------- */\n\nconst ellipsisTriggerClasses = [\n 'ds:inline-flex ds:items-center ds:justify-center',\n 'ds:min-w-[var(--min-target-size)] ds:min-h-[var(--min-target-size)]',\n 'ds:rounded-[var(--radius-sm)]',\n 'ds:text-[var(--muted-foreground)]',\n 'ds:hover:text-[var(--foreground)]',\n 'ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid',\n 'ds:focus-visible:outline-[var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]',\n 'ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none',\n].join(' ');\n\nconst ellipsisContentClasses = [\n 'ds:z-[var(--z-dropdown)] ds:min-w-[12rem] ds:overflow-hidden',\n 'ds:rounded-[var(--radius-md)] ds:border ds:border-[var(--border)]',\n 'ds:bg-[var(--background)] ds:text-[var(--foreground)]',\n 'ds:shadow-[var(--shadow-lg)]',\n 'ds:p-[var(--spacing-xs)]',\n 'ds:animate-in ds:fade-in ds:zoom-in-95 ds:motion-reduce:animate-none',\n].join(' ');\n\nconst ellipsisItemClasses = [\n 'ds:flex ds:items-center',\n 'ds:min-h-[var(--min-target-size)]',\n 'ds:ps-[var(--spacing-sm)] ds:pe-[var(--spacing-sm)]',\n 'ds:rounded-[var(--radius-sm)]',\n 'ds:text-[var(--foreground)] ds:cursor-pointer ds:select-none',\n 'ds:data-[highlighted]:bg-[var(--muted)] ds:data-[highlighted]:text-[var(--foreground)]',\n 'ds:outline-none',\n].join(' ');\n\nexport interface BreadcrumbEllipsisProps extends ComponentPropsWithoutRef<'button'> {\n /** Hidden crumb elements rendered inside the dropdown menu. */\n hiddenItems?: ReactElement[];\n}\n\nconst BreadcrumbEllipsis = forwardRef<HTMLButtonElement, BreadcrumbEllipsisProps>(\n ({ className, hiddenItems = [], ...rest }, ref) => {\n const { t } = useTranslation();\n const showPath = t('ui.navigation.breadcrumb.showPath');\n return (\n <DropdownMenu.Root>\n <DropdownMenu.Trigger asChild>\n <button\n ref={ref}\n type=\"button\"\n aria-label={showPath}\n className={[ellipsisTriggerClasses, className].filter(Boolean).join(' ')}\n {...rest}\n >\n <MoreHorizontal aria-hidden=\"true\" className=\"ds:size-4\" />\n <span className=\"ds:sr-only\">{showPath}</span>\n </button>\n </DropdownMenu.Trigger>\n <DropdownMenu.Portal>\n <DropdownMenu.Content\n className={ellipsisContentClasses}\n align=\"start\"\n sideOffset={6}\n >\n {hiddenItems.map((item, i) => {\n // Extract the anchor inside the hidden BreadcrumbItem (if any)\n const linkChild = extractLink(item);\n return (\n <DropdownMenu.Item\n key={`hidden-${i}`}\n asChild\n className={ellipsisItemClasses}\n >\n {linkChild ?? <span>{item}</span>}\n </DropdownMenu.Item>\n );\n })}\n </DropdownMenu.Content>\n </DropdownMenu.Portal>\n </DropdownMenu.Root>\n );\n },\n);\nBreadcrumbEllipsis.displayName = 'BreadcrumbEllipsis';\n\n/**\n * Walks a `BreadcrumbItem` to find the first child whose type is\n * `BreadcrumbLink` and returns the link rendered as a plain `<a>` so the\n * dropdown item can adopt its navigational behaviour.\n */\nfunction extractLink(item: ReactElement): ReactElement | null {\n let found: ReactElement | null = null;\n const itemChildren = (item.props as { children?: ReactNode }).children;\n Children.forEach(itemChildren, (child) => {\n if (found) return;\n if (!isValidElement(child)) return;\n if (child.type === BreadcrumbLink) {\n const linkProps = child.props as BreadcrumbLinkProps & { children?: ReactNode };\n const href = typeof linkProps.href === 'string' ? linkProps.href : undefined;\n const safeHref =\n href && /^\\s*javascript:/i.test(href) ? undefined : href;\n found = (\n <a\n href={safeHref}\n onClick={linkProps.onClick as AnchorHTMLAttributes<HTMLAnchorElement>['onClick']}\n >\n {linkProps.children}\n </a>\n );\n }\n });\n return found;\n}\n\nexport {\n Breadcrumb,\n BreadcrumbList,\n BreadcrumbItem,\n BreadcrumbLink,\n BreadcrumbSeparator,\n BreadcrumbEllipsis,\n};\n"],"names":["BreadcrumbContext","createContext","Breadcrumb","forwardRef","children","className","ariaLabel","separator","maxItems","itemsBeforeCollapse","itemsAfterCollapse","disableCollapse","rest","ref","t","useTranslation","jsx","BreadcrumbList","listClasses","arr","Children","c","isValidElement","total","shouldCollapse","renderItem","child","isLast","key","cloneElement","renderSeparatorIf","condition","BreadcrumbSeparator","nodes","i","before","after","hidden","BreadcrumbItem","BreadcrumbEllipsis","itemClasses","isCurrent","BreadcrumbLink","_a","linkClasses","currentClasses","asChild","Slot","separatorVariants","cva","variant","ctx","useContext","resolved","defaultGlyph","ChevronRight","ellipsisTriggerClasses","ellipsisContentClasses","ellipsisItemClasses","hiddenItems","showPath","jsxs","DropdownMenu","MoreHorizontal","item","linkChild","extractLink","found","itemChildren","linkProps","href","safeHref"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"chart.agent-BdS-_8MO.js","sources":["../../src/components/chart/chart.tsx","../../src/components/chart/chart.agent.ts"],"sourcesContent":["/* ------------------------------------------------------------------ */\n/* Chart — thin, typed wrapper over ApexCharts (react-apexcharts). */\n/* */\n/* - All chrome, colours, and fonts flow from */\n/* `src/tokens/apexcharts-theme.ts` — never hex literals in user */\n/* code. A MutationObserver on `<html class>` re-reads the bridge so */\n/* theme changes repaint without remount. */\n/* - A ResizeObserver on the wrapper keeps the chart responsive */\n/* without listening on `window.resize`. */\n/* - Accessibility: the wrapper carries `role=\"img\"` + `aria-label` */\n/* (required `title` prop) + `aria-describedby` pointing at a */\n/* visually-hidden `<table>` that mirrors series × categories. */\n/* - Colour-blind users: `patterns` prop flips `fill.type` to pattern */\n/* using ApexCharts' built-in pattern presets. */\n/* - Numbers format via `Intl.NumberFormat(locale)` — no hand-rolled */\n/* `toFixed()`. */\n/* ------------------------------------------------------------------ */\n\nimport {\n forwardRef,\n useEffect,\n useId,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport ReactApexChart from 'react-apexcharts';\nimport ApexCharts from 'apexcharts';\nimport { getApexChartsTheme } from '../../tokens/apexcharts-theme';\nimport { usePrefersReducedMotion } from '../../hooks';\nimport { useNeutraliseHiddenFocus } from '../_shared/use-neutralize-hidden-focus';\n\n/* ------------------------------------------------------------------ */\n/* CVA */\n/* ------------------------------------------------------------------ */\n\nconst chartVariants = cva('ds:relative ds:block ds:w-full', {\n variants: {\n density: {\n compact: 'ds:min-h-[var(--chart-min-height-compact)]',\n comfortable: 'ds:min-h-[var(--chart-min-height-comfortable)]',\n },\n },\n defaultVariants: { density: 'comfortable' },\n});\n\n/* ------------------------------------------------------------------ */\n/* Public types */\n/* ------------------------------------------------------------------ */\n\nexport type ChartType = 'line' | 'bar' | 'pie' | 'donut' | 'area' | 'radialBar';\n\nexport interface ChartSeries {\n name: string;\n data: number[];\n}\n\nexport interface ChartProps extends VariantProps<typeof chartVariants> {\n /** Required — drives aria-label and sr-only table caption. */\n title: string;\n /** Chart visual type. */\n type: ChartType;\n /**\n * For `line` / `bar` / `area`: an array of `ChartSeries`.\n * For `pie` / `donut` / `radialBar`: an array of numbers matched to `labels`.\n */\n series: ChartSeries[] | number[];\n /** Category axis labels (line / bar / area). */\n categories?: string[];\n /** Slice labels (pie / donut / radialBar). */\n labels?: string[];\n /** Height override. Defaults to 320px. */\n height?: number | string;\n /** Width override. Defaults to 100% of container. */\n width?: number | string;\n /** Opt-in pattern fills for colour-blind users. */\n patterns?: boolean;\n /** Show the ApexCharts toolbar. Defaults to false. */\n toolbar?: boolean;\n /** Locale override — defaults to the active i18next language. */\n locale?: string;\n /** Extra class names on the wrapper. */\n className?: string;\n}\n\nexport interface ChartHandle {\n /** Returns a PNG data URI for the chart. */\n dataURI: () => Promise<string>;\n /** Updates series without remounting. */\n updateSeries: (next: ChartProps['series']) => void;\n}\n\n/* ------------------------------------------------------------------ */\n/* Constants */\n/* ------------------------------------------------------------------ */\n\nconst PATTERN_STYLES = [\n 'verticalLines',\n 'horizontalLines',\n 'slantedLines',\n 'squares',\n 'circles',\n] as const;\n\n/** Types where `categories` belong on an x-axis. */\nconst CATEGORICAL_TYPES: ReadonlyArray<ChartType> = ['line', 'bar', 'area'];\n\n/** Types where `series` is a flat `number[]` paired with `labels`. */\nconst SLICE_TYPES: ReadonlyArray<ChartType> = ['pie', 'donut', 'radialBar'];\n\n/* ------------------------------------------------------------------ */\n/* Helpers */\n/* ------------------------------------------------------------------ */\n\nfunction isSliceType(type: ChartType): boolean {\n return SLICE_TYPES.includes(type);\n}\n\nfunction isCategoricalType(type: ChartType): boolean {\n return CATEGORICAL_TYPES.includes(type);\n}\n\n/** Coerce `series` into `ChartSeries[]` for shared logic (table, aria). */\nfunction normaliseSeries(\n series: ChartSeries[] | number[],\n type: ChartType,\n): ChartSeries[] {\n if (isSliceType(type)) {\n const nums = series as number[];\n return [\n {\n name: '',\n data: nums,\n },\n ];\n }\n return series as ChartSeries[];\n}\n\n/* ------------------------------------------------------------------ */\n/* Chart component */\n/* ------------------------------------------------------------------ */\n\nexport const Chart = forwardRef<ChartHandle, ChartProps>(\n (\n {\n title,\n type,\n series,\n categories,\n labels,\n height,\n width,\n patterns = false,\n toolbar = false,\n locale: localeProp,\n density,\n className,\n },\n ref,\n ) => {\n const { t, i18n } = useTranslation();\n const rawId = useId();\n const chartId = useMemo(\n () => `chart-${rawId.replace(/[^a-zA-Z0-9-_]/g, '')}`,\n [rawId],\n );\n const summaryId = `${chartId}-summary`;\n\n const wrapperRef = useRef<HTMLDivElement>(null);\n const [containerWidth, setContainerWidth] = useState(0);\n\n /* ApexCharts injects focusable canvases inside the `aria-hidden` */\n /* chart wrapper. Neutralise their tabindex so axe's */\n /* `aria-hidden-focus` rule passes. Same hook used in Sparkline. */\n useNeutraliseHiddenFocus(wrapperRef);\n\n const locale = localeProp ?? i18n.language ?? 'en';\n\n /* ---- dev warning if title missing ------------------------------ */\n if (import.meta.env.DEV && !title) {\n // eslint-disable-next-line no-console\n console.warn(\n 'Chart: `title` prop is required. It drives aria-label and the screen-reader summary table.',\n );\n }\n\n /* ---- theme-reactive state -------------------------------------- */\n const [themeOptions, setThemeOptions] = useState<ApexCharts.ApexOptions>(() => {\n try {\n return getApexChartsTheme();\n } catch {\n return {};\n }\n });\n\n /* ---- MutationObserver: re-read theme on class change ------------ */\n useEffect(() => {\n if (typeof document === 'undefined') return undefined;\n let timer: ReturnType<typeof setTimeout>;\n const observer = new MutationObserver(() => {\n clearTimeout(timer);\n timer = setTimeout(() => {\n try {\n setThemeOptions(getApexChartsTheme());\n } catch {\n /* no-op in non-browser environments */\n }\n }, 50);\n });\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: ['class'],\n });\n return () => {\n clearTimeout(timer);\n observer.disconnect();\n };\n }, []);\n\n /* ---- ResizeObserver: track container width --------------------- */\n useEffect(() => {\n const el = wrapperRef.current;\n if (!el || typeof ResizeObserver === 'undefined') return undefined;\n const ro = new ResizeObserver((entries) => {\n const entry = entries[0];\n if (entry) setContainerWidth(Math.floor(entry.contentRect.width));\n });\n ro.observe(el);\n return () => ro.disconnect();\n }, []);\n\n /* ---- imperative handle ----------------------------------------- */\n useImperativeHandle(ref, () => ({\n async dataURI(): Promise<string> {\n const instance = ApexCharts.getChartByID(chartId);\n if (!instance) return '';\n const result = await instance.dataURI();\n return (result as { imgURI: string }).imgURI;\n },\n updateSeries(next) {\n const instance = ApexCharts.getChartByID(chartId);\n if (!instance) return;\n if (isSliceType(type)) {\n instance.updateSeries(next as number[]);\n } else {\n instance.updateSeries(next as ChartSeries[]);\n }\n },\n }));\n\n /* ---- RTL detection --------------------------------------------- */\n const isRtl =\n typeof document !== 'undefined' && document.documentElement.dir === 'rtl';\n\n /* ---- normalised series for sr-only table ----------------------- */\n const tableSeries = useMemo(\n () => normaliseSeries(series, type),\n [series, type],\n );\n\n /* ---- Intl formatter -------------------------------------------- */\n const numberFormatter = useMemo(\n () => new Intl.NumberFormat(locale),\n [locale],\n );\n\n /* ---- toolbar localisation -------------------------------------- */\n const toolbarLocale = useMemo(\n () => ({\n name: locale,\n options: {\n toolbar: {\n download: t('chart.toolbar.download'),\n selection: t('chart.toolbar.selection'),\n selectionZoom: t('chart.toolbar.selectionZoom'),\n zoomIn: t('chart.toolbar.zoomIn'),\n zoomOut: t('chart.toolbar.zoomOut'),\n pan: t('chart.toolbar.pan'),\n reset: t('chart.toolbar.reset'),\n exportToSVG: t('chart.toolbar.exportToSVG'),\n exportToPNG: t('chart.toolbar.exportToPNG'),\n exportToCSV: t('chart.toolbar.exportToCSV'),\n },\n },\n }),\n [locale, t],\n );\n\n /* ---- build ApexOptions ----------------------------------------- */\n const reducedMotion = usePrefersReducedMotion();\n\n const chartOptions: ApexCharts.ApexOptions = useMemo(() => {\n const base = themeOptions;\n\n const options: ApexCharts.ApexOptions = {\n ...base,\n chart: {\n ...base.chart,\n id: chartId,\n toolbar: { show: toolbar },\n zoom: { enabled: toolbar },\n animations: {\n enabled: !reducedMotion,\n dynamicAnimation: { enabled: !reducedMotion },\n },\n locales: [toolbarLocale],\n defaultLocale: locale,\n parentHeightOffset: 0,\n },\n labels: labels,\n legend: {\n ...base.legend,\n position: 'bottom',\n // ApexCharts legend.horizontalAlign is a physical prop mapped internally\n // to the chart's own text flow. For RTL we flip via `yaxis.opposite`\n // and ApexCharts' own `direction: 'rtl'` handling; legend stays anchored\n // to the inline-start by asking for 'left' on LTR and 'right' on RTL.\n horizontalAlign: isRtl ? 'right' : 'left',\n fontFamily: 'inherit',\n },\n tooltip: {\n ...base.tooltip,\n y: {\n formatter: (value: number) => numberFormatter.format(value),\n },\n },\n noData: {\n text: t('chart.noData'),\n },\n };\n\n if (isCategoricalType(type)) {\n options.xaxis = {\n ...base.xaxis,\n categories: categories ?? [],\n };\n options.yaxis = {\n ...base.yaxis,\n opposite: isRtl,\n labels: {\n formatter: (value: number) => numberFormatter.format(value),\n },\n };\n options.stroke = {\n curve: 'smooth',\n width: type === 'bar' ? 0 : 2,\n };\n options.dataLabels = { enabled: false };\n }\n\n if (patterns) {\n options.fill = {\n type: 'pattern',\n opacity: type === 'area' ? 0.3 : 1,\n pattern: {\n style: [...PATTERN_STYLES],\n strokeWidth: 2,\n },\n };\n } else if (type === 'area') {\n options.fill = {\n type: 'gradient',\n opacity: 0.3,\n };\n }\n\n return options;\n }, [\n themeOptions,\n chartId,\n toolbar,\n reducedMotion,\n toolbarLocale,\n locale,\n labels,\n numberFormatter,\n t,\n type,\n categories,\n isRtl,\n patterns,\n ]);\n\n /* ---- resolved dimensions --------------------------------------- */\n const resolvedWidth = width ?? (containerWidth > 0 ? containerWidth : '100%');\n const resolvedHeight = height ?? 320;\n\n /* ---- sr-only data table --------------------------------------- */\n const srTable = useMemo(() => {\n const columnLabels = isSliceType(type)\n ? (labels ?? [])\n : (categories ?? []);\n const rows = tableSeries;\n return (\n <table id={summaryId} className=\"ds:sr-only\">\n <caption>{title}</caption>\n <thead>\n <tr>\n <th scope=\"col\">{t('chart.table.series')}</th>\n {columnLabels.map((col, i) => (\n <th key={`${col}-${i}`} scope=\"col\">\n {col}\n </th>\n ))}\n </tr>\n </thead>\n <tbody>\n {rows.map((row, rowIndex) => (\n <tr key={`${row.name}-${rowIndex}`}>\n <th scope=\"row\">{row.name || t('chart.table.value')}</th>\n {row.data.map((value, colIndex) => (\n <td key={`${rowIndex}-${colIndex}`}>\n {numberFormatter.format(value)}\n </td>\n ))}\n </tr>\n ))}\n </tbody>\n </table>\n );\n }, [type, tableSeries, labels, categories, summaryId, title, t, numberFormatter]);\n\n /* ---- ApexCharts `series` prop shape ----------------------------- */\n const apexSeries = useMemo(() => {\n if (isSliceType(type)) {\n return series as number[];\n }\n return series as ChartSeries[];\n }, [series, type]);\n\n return (\n <div\n ref={wrapperRef}\n role=\"img\"\n aria-label={title}\n aria-describedby={summaryId}\n className={chartVariants({ density, className })}\n data-component=\"chart\"\n >\n {srTable}\n <ReactApexChart\n type={type}\n series={apexSeries as ApexCharts.ApexOptions['series']}\n options={chartOptions}\n width={resolvedWidth}\n height={resolvedHeight}\n aria-hidden=\"true\"\n />\n </div>\n );\n },\n);\n\nChart.displayName = 'Chart';\n\n/* ------------------------------------------------------------------ */\n/* Re-export internal helper for downstream theming (kept narrow). */\n/* ------------------------------------------------------------------ */\n\nexport { chartVariants };\n","import type { AgentAdapter } from '../../agent/types';\nimport type { ChartHandle } from './chart';\n\nexport const chartAgent: AgentAdapter<ChartHandle> = {\n id: 'chart',\n capabilities: [],\n state: {},\n actions: {\n update_series: {\n safety: 'read',\n argsType: 'series',\n description: 'Replace the chart series without remounting.',\n invoke: (handle, args: { series: Parameters<ChartHandle['updateSeries']>[0] }) => {\n handle.updateSeries(args.series);\n },\n },\n export_png: {\n safety: 'read',\n description: 'Return a PNG data URI of the chart for export or screenshotting.',\n invoke: (handle) => handle.dataURI(),\n },\n },\n domHooks: {\n root: { attr: 'data-component', value: 'chart' },\n },\n};\n"],"names":["chartVariants","cva","PATTERN_STYLES","CATEGORICAL_TYPES","SLICE_TYPES","isSliceType","type","isCategoricalType","normaliseSeries","series","Chart","forwardRef","title","categories","labels","height","width","patterns","toolbar","localeProp","density","className","ref","t","i18n","useTranslation","rawId","useId","chartId","useMemo","summaryId","wrapperRef","useRef","containerWidth","setContainerWidth","useState","useNeutraliseHiddenFocus","locale","themeOptions","setThemeOptions","getApexChartsTheme","useEffect","timer","observer","el","ro","entries","entry","useImperativeHandle","instance","ApexCharts","next","isRtl","tableSeries","numberFormatter","toolbarLocale","reducedMotion","usePrefersReducedMotion","chartOptions","base","options","value","resolvedWidth","resolvedHeight","srTable","columnLabels","rows","jsx","jsxs","col","row","rowIndex","colIndex","apexSeries","ReactApexChart","chartAgent","handle","args"],"mappings":";;;;;;;;AAuCA,MAAMA,KAAgBC,EAAI,kCAAkC;AAAA,EAC1D,UAAU;AAAA,IACR,SAAS;AAAA,MACP,SAAS;AAAA,MACT,aAAa;AAAA,IAAA;AAAA,EACf;AAAA,EAEF,iBAAiB,EAAE,SAAS,cAAA;AAC9B,CAAC,GAoDKC,KAAiB;AAAA,EACrB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAGMC,KAA8C,CAAC,QAAQ,OAAO,MAAM,GAGpEC,KAAwC,CAAC,OAAO,SAAS,WAAW;AAM1E,SAASC,EAAYC,GAA0B;AAC7C,SAAOF,GAAY,SAASE,CAAI;AAClC;AAEA,SAASC,GAAkBD,GAA0B;AACnD,SAAOH,GAAkB,SAASG,CAAI;AACxC;AAGA,SAASE,GACPC,GACAH,GACe;AACf,SAAID,EAAYC,CAAI,IAEX;AAAA,IACL;AAAA,MACE,MAAM;AAAA,MACN,MAJSG;AAAA,IAIH;AAAA,EACR,IAGGA;AACT;AAMO,MAAMC,KAAQC;AAAA,EACnB,CACE;AAAA,IACE,OAAAC;AAAA,IACA,MAAAN;AAAA,IACA,QAAAG;AAAA,IACA,YAAAI;AAAA,IACA,QAAAC;AAAA,IACA,QAAAC;AAAA,IACA,OAAAC;AAAA,IACA,UAAAC,IAAW;AAAA,IACX,SAAAC,IAAU;AAAA,IACV,QAAQC;AAAA,IACR,SAAAC;AAAA,IACA,WAAAC;AAAA,EAAA,GAEFC,MACG;AACH,UAAM,EAAE,GAAAC,GAAG,MAAAC,EAAA,IAASC,EAAA,GACdC,IAAQC,EAAA,GACRC,IAAUC;AAAA,MACd,MAAM,SAASH,EAAM,QAAQ,mBAAmB,EAAE,CAAC;AAAA,MACnD,CAACA,CAAK;AAAA,IAAA,GAEFI,IAAY,GAAGF,CAAO,YAEtBG,IAAaC,EAAuB,IAAI,GACxC,CAACC,GAAgBC,CAAiB,IAAIC,EAAS,CAAC;AAKtD,IAAAC,GAAyBL,CAAU;AAEnC,UAAMM,IAASlB,KAAcK,EAAK,YAAY,MAWxC,CAACc,GAAcC,CAAe,IAAIJ,EAAiC,MAAM;AAC7E,UAAI;AACF,eAAOK,EAAA;AAAA,MACT,QAAQ;AACN,eAAO,CAAA;AAAA,MACT;AAAA,IACF,CAAC;AAGD,IAAAC,EAAU,MAAM;AACd,UAAI,OAAO,WAAa,IAAa;AACrC,UAAIC;AACJ,YAAMC,IAAW,IAAI,iBAAiB,MAAM;AAC1C,qBAAaD,CAAK,GAClBA,IAAQ,WAAW,MAAM;AACvB,cAAI;AACF,YAAAH,EAAgBC,GAAoB;AAAA,UACtC,QAAQ;AAAA,UAER;AAAA,QACF,GAAG,EAAE;AAAA,MACP,CAAC;AACD,aAAAG,EAAS,QAAQ,SAAS,iBAAiB;AAAA,QACzC,YAAY;AAAA,QACZ,iBAAiB,CAAC,OAAO;AAAA,MAAA,CAC1B,GACM,MAAM;AACX,qBAAaD,CAAK,GAClBC,EAAS,WAAA;AAAA,MACX;AAAA,IACF,GAAG,CAAA,CAAE,GAGLF,EAAU,MAAM;AACd,YAAMG,IAAKb,EAAW;AACtB,UAAI,CAACa,KAAM,OAAO,iBAAmB,IAAa;AAClD,YAAMC,IAAK,IAAI,eAAe,CAACC,MAAY;AACzC,cAAMC,IAAQD,EAAQ,CAAC;AACvB,QAAIC,KAAOb,EAAkB,KAAK,MAAMa,EAAM,YAAY,KAAK,CAAC;AAAA,MAClE,CAAC;AACD,aAAAF,EAAG,QAAQD,CAAE,GACN,MAAMC,EAAG,WAAA;AAAA,IAClB,GAAG,CAAA,CAAE,GAGLG,EAAoB1B,GAAK,OAAO;AAAA,MAC9B,MAAM,UAA2B;AAC/B,cAAM2B,IAAWC,EAAW,aAAatB,CAAO;AAChD,eAAKqB,KACU,MAAMA,EAAS,QAAA,GACQ,SAFhB;AAAA,MAGxB;AAAA,MACA,aAAaE,GAAM;AACjB,cAAMF,IAAWC,EAAW,aAAatB,CAAO;AAChD,QAAKqB,MACD5C,EAAYC,CAAI,GAClB2C,EAAS,aAAaE,CAAgB;AAAA,MAI1C;AAAA,IAAA,EACA;AAGF,UAAMC,IACJ,OAAO,WAAa,OAAe,SAAS,gBAAgB,QAAQ,OAGhEC,IAAcxB;AAAA,MAClB,MAAMrB,GAAgBC,GAAQH,CAAI;AAAA,MAClC,CAACG,GAAQH,CAAI;AAAA,IAAA,GAITgD,IAAkBzB;AAAA,MACtB,MAAM,IAAI,KAAK,aAAaQ,CAAM;AAAA,MAClC,CAACA,CAAM;AAAA,IAAA,GAIHkB,IAAgB1B;AAAA,MACpB,OAAO;AAAA,QACL,MAAMQ;AAAA,QACN,SAAS;AAAA,UACP,SAAS;AAAA,YACP,UAAUd,EAAE,wBAAwB;AAAA,YACpC,WAAWA,EAAE,yBAAyB;AAAA,YACtC,eAAeA,EAAE,6BAA6B;AAAA,YAC9C,QAAQA,EAAE,sBAAsB;AAAA,YAChC,SAASA,EAAE,uBAAuB;AAAA,YAClC,KAAKA,EAAE,mBAAmB;AAAA,YAC1B,OAAOA,EAAE,qBAAqB;AAAA,YAC9B,aAAaA,EAAE,2BAA2B;AAAA,YAC1C,aAAaA,EAAE,2BAA2B;AAAA,YAC1C,aAAaA,EAAE,2BAA2B;AAAA,UAAA;AAAA,QAC5C;AAAA,MACF;AAAA,MAEF,CAACc,GAAQd,CAAC;AAAA,IAAA,GAINiC,IAAgBC,GAAA,GAEhBC,IAAuC7B,EAAQ,MAAM;AACzD,YAAM8B,IAAOrB,GAEPsB,IAAkC;AAAA,QACtC,GAAGD;AAAA,QACH,OAAO;AAAA,UACL,GAAGA,EAAK;AAAA,UACR,IAAI/B;AAAA,UACJ,SAAS,EAAE,MAAMV,EAAA;AAAA,UACjB,MAAM,EAAE,SAASA,EAAA;AAAA,UACjB,YAAY;AAAA,YACV,SAAS,CAACsC;AAAA,YACV,kBAAkB,EAAE,SAAS,CAACA,EAAA;AAAA,UAAc;AAAA,UAE9C,SAAS,CAACD,CAAa;AAAA,UACvB,eAAelB;AAAA,UACf,oBAAoB;AAAA,QAAA;AAAA,QAEtB,QAAAvB;AAAA,QACA,QAAQ;AAAA,UACN,GAAG6C,EAAK;AAAA,UACR,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA,UAKV,iBAAiBP,IAAQ,UAAU;AAAA,UACnC,YAAY;AAAA,QAAA;AAAA,QAEd,SAAS;AAAA,UACP,GAAGO,EAAK;AAAA,UACR,GAAG;AAAA,YACD,WAAW,CAACE,MAAkBP,EAAgB,OAAOO,CAAK;AAAA,UAAA;AAAA,QAC5D;AAAA,QAEF,QAAQ;AAAA,UACN,MAAMtC,EAAE,cAAc;AAAA,QAAA;AAAA,MACxB;AAGF,aAAIhB,GAAkBD,CAAI,MACxBsD,EAAQ,QAAQ;AAAA,QACd,GAAGD,EAAK;AAAA,QACR,YAAY9C,KAAc,CAAA;AAAA,MAAC,GAE7B+C,EAAQ,QAAQ;AAAA,QACd,GAAGD,EAAK;AAAA,QACR,UAAUP;AAAA,QACV,QAAQ;AAAA,UACN,WAAW,CAACS,MAAkBP,EAAgB,OAAOO,CAAK;AAAA,QAAA;AAAA,MAC5D,GAEFD,EAAQ,SAAS;AAAA,QACf,OAAO;AAAA,QACP,OAAOtD,MAAS,QAAQ,IAAI;AAAA,MAAA,GAE9BsD,EAAQ,aAAa,EAAE,SAAS,GAAA,IAG9B3C,IACF2C,EAAQ,OAAO;AAAA,QACb,MAAM;AAAA,QACN,SAAStD,MAAS,SAAS,MAAM;AAAA,QACjC,SAAS;AAAA,UACP,OAAO,CAAC,GAAGJ,EAAc;AAAA,UACzB,aAAa;AAAA,QAAA;AAAA,MACf,IAEOI,MAAS,WAClBsD,EAAQ,OAAO;AAAA,QACb,MAAM;AAAA,QACN,SAAS;AAAA,MAAA,IAINA;AAAA,IACT,GAAG;AAAA,MACDtB;AAAA,MACAV;AAAA,MACAV;AAAA,MACAsC;AAAA,MACAD;AAAA,MACAlB;AAAA,MACAvB;AAAA,MACAwC;AAAA,MACA/B;AAAA,MACAjB;AAAA,MACAO;AAAA,MACAuC;AAAA,MACAnC;AAAA,IAAA,CACD,GAGK6C,IAAgB9C,MAAUiB,IAAiB,IAAIA,IAAiB,SAChE8B,IAAiBhD,KAAU,KAG3BiD,IAAUnC,EAAQ,MAAM;AAC5B,YAAMoC,IAAe5D,EAAYC,CAAI,IAChCQ,KAAU,CAAA,IACVD,KAAc,CAAA,GACbqD,IAAOb;AACb,+BACG,SAAA,EAAM,IAAIvB,GAAW,WAAU,cAC9B,UAAA;AAAA,QAAA,gBAAAqC,EAAC,aAAS,UAAAvD,GAAM;AAAA,0BACf,SAAA,EACC,UAAA,gBAAAwD,EAAC,MAAA,EACC,UAAA;AAAA,UAAA,gBAAAD,EAAC,MAAA,EAAG,OAAM,OAAO,UAAA5C,EAAE,oBAAoB,GAAE;AAAA,UACxC0C,EAAa,IAAI,CAACI,GAAK,MACtB,gBAAAF,EAAC,MAAA,EAAuB,OAAM,OAC3B,eADM,GAAGE,CAAG,IAAI,CAAC,EAEpB,CACD;AAAA,QAAA,EAAA,CACH,EAAA,CACF;AAAA,QACA,gBAAAF,EAAC,WACE,UAAAD,EAAK,IAAI,CAACI,GAAKC,wBACb,MAAA,EACC,UAAA;AAAA,UAAA,gBAAAJ,EAAC,QAAG,OAAM,OAAO,YAAI,QAAQ5C,EAAE,mBAAmB,GAAE;AAAA,UACnD+C,EAAI,KAAK,IAAI,CAACT,GAAOW,MACpB,gBAAAL,EAAC,MAAA,EACE,UAAAb,EAAgB,OAAOO,CAAK,KADtB,GAAGU,CAAQ,IAAIC,CAAQ,EAEhC,CACD;AAAA,QAAA,EAAA,GANM,GAAGF,EAAI,IAAI,IAAIC,CAAQ,EAOhC,CACD,EAAA,CACH;AAAA,MAAA,GACF;AAAA,IAEJ,GAAG,CAACjE,GAAM+C,GAAavC,GAAQD,GAAYiB,GAAWlB,GAAOW,GAAG+B,CAAe,CAAC,GAG1EmB,IAAa5C,EAAQ,OACrBxB,EAAYC,CAAI,GACXG,IAGR,CAACA,GAAQH,CAAI,CAAC;AAEjB,WACE,gBAAA8D;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,KAAKrC;AAAA,QACL,MAAK;AAAA,QACL,cAAYnB;AAAA,QACZ,oBAAkBkB;AAAA,QAClB,WAAW9B,GAAc,EAAE,SAAAoB,GAAS,WAAAC,GAAW;AAAA,QAC/C,kBAAe;AAAA,QAEd,UAAA;AAAA,UAAA2C;AAAA,UACD,gBAAAG;AAAA,YAACO;AAAA,YAAA;AAAA,cACC,MAAApE;AAAA,cACA,QAAQmE;AAAA,cACR,SAASf;AAAA,cACT,OAAOI;AAAA,cACP,QAAQC;AAAA,cACR,eAAY;AAAA,YAAA;AAAA,UAAA;AAAA,QACd;AAAA,MAAA;AAAA,IAAA;AAAA,EAGN;AACF;AAEArD,GAAM,cAAc;ACtcb,MAAMiE,KAAwC;AAAA,EACnD,IAAI;AAAA,EACJ,cAAc,CAAA;AAAA,EACd,OAAO,CAAA;AAAA,EACP,SAAS;AAAA,IACP,eAAe;AAAA,MACb,QAAQ;AAAA,MACR,UAAU;AAAA,MACV,aAAa;AAAA,MACb,QAAQ,CAACC,GAAQC,MAAiE;AAChF,QAAAD,EAAO,aAAaC,EAAK,MAAM;AAAA,MACjC;AAAA,IAAA;AAAA,IAEF,YAAY;AAAA,MACV,QAAQ;AAAA,MACR,aAAa;AAAA,MACb,QAAQ,CAACD,MAAWA,EAAO,QAAA;AAAA,IAAQ;AAAA,EACrC;AAAA,EAEF,UAAU;AAAA,IACR,MAAM,EAAE,MAAM,kBAAkB,OAAO,QAAA;AAAA,EAAQ;AAEnD;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"chat-container-Cm3SlR2p.js","sources":["../../src/components/chat-container/chat-container.tsx"],"sourcesContent":["import {\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useLayoutEffect,\n useRef,\n useState,\n type HTMLAttributes,\n type ReactNode,\n} from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport { ChevronDown } from 'lucide-react';\nimport { useVirtualizer } from '@tanstack/react-virtual';\nimport { FloatingActionButton } from '../floating-action-button/floating-action-button';\nimport { usePrefersReducedMotion } from '../../hooks';\n\nconst rootVariants = cva(\n 'ds:relative ds:flex ds:w-full ds:flex-col ds:overflow-hidden ds:bg-background',\n {\n variants: {\n density: {\n default: 'ds:gap-[var(--spacing-md)]',\n compact: 'ds:gap-[var(--spacing-sm)]',\n },\n },\n defaultVariants: { density: 'default' },\n },\n);\n\nconst scrollViewportVariants = cva(\n [\n 'ds:flex-1 ds:min-h-0 ds:overflow-y-auto ds:overflow-x-hidden',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:pt-[var(--spacing-md)] ds:pb-[var(--spacing-md)]',\n 'ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid',\n 'ds:focus-visible:outline-[color:var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]',\n 'ds:scroll-smooth ds:motion-reduce:scroll-auto ds:[.theme-accessible_&]:scroll-auto',\n // Edge fade — content near the scroll boundaries fades into the\n // container surface instead of clipping abruptly against the header\n // or composer, so avatars / bubbles don't look \"cut in half\" as they\n // pass the viewport edge. Fade width matches the viewport padding so\n // a row can slide fully behind the mask before disappearing.\n // Disabled under HCM (mask strips content), reduced motion (less\n // decoration when motion is off), and the accessible theme.\n 'ds:[mask-image:linear-gradient(to_bottom,transparent_0,black_var(--spacing-md),black_calc(100%-var(--spacing-md)),transparent_100%)]',\n 'ds:motion-reduce:[mask-image:none]',\n 'ds:[.theme-accessible_&]:[mask-image:none]',\n 'ds:forced-colors:[mask-image:none]',\n ].join(' '),\n);\n\nconst VIRTUALIZATION_THRESHOLD = 100;\n/** Pixel slack against the bottom edge that still counts as \"at bottom\". */\nconst BOTTOM_SLACK_PX = 48;\n\nexport interface ChatContainerHandle {\n scrollToBottom: (opts?: { smooth?: boolean }) => void;\n getScrollViewport: () => HTMLDivElement | null;\n}\n\nexport interface ChatContainerProps\n extends Omit<HTMLAttributes<HTMLDivElement>, 'children'>,\n VariantProps<typeof rootVariants> {\n /** Array of messages to render. When the array exceeds 100 items the\n * list is virtualised via @tanstack/react-virtual. */\n messages: Array<{ id: string; node: ReactNode }>;\n /** Composer slot pinned to the block-end. */\n composer?: ReactNode;\n /** Fires when the user's auto-scroll preference flips. */\n onAutoScrollChange?: (isAtBottom: boolean) => void;\n /**\n * When true, renders a \"scroll to latest\" FloatingActionButton in the\n * bottom-end of the scroll column whenever the user has scrolled\n * away from the newest message. Defaults to `false` because the\n * affordance is only useful in long-form chat surfaces (fullscreen\n * assistants, dedicated messaging views); in compact docks — e.g. the\n * Leo side-panel — conversations rarely exceed one screen and the FAB\n * just adds visual noise. Turn on for fullscreen chat surfaces.\n */\n showScrollToLatest?: boolean;\n}\n\nexport const ChatContainer = forwardRef<ChatContainerHandle, ChatContainerProps>(\n (\n {\n messages,\n composer,\n density = 'default',\n className,\n onAutoScrollChange,\n showScrollToLatest = false,\n ...rest\n },\n ref,\n ) => {\n const { t } = useTranslation();\n const viewportRef = useRef<HTMLDivElement | null>(null);\n const sentinelRef = useRef<HTMLDivElement | null>(null);\n const [isAtBottom, setIsAtBottom] = useState(true);\n\n const prefersReducedMotion = usePrefersReducedMotion();\n\n const scrollToBottom = useCallback(\n (opts?: { smooth?: boolean }) => {\n const el = viewportRef.current;\n if (!el) return;\n const smooth = (opts?.smooth ?? true) && !prefersReducedMotion;\n el.scrollTo({ top: el.scrollHeight, behavior: smooth ? 'smooth' : 'auto' });\n },\n [prefersReducedMotion],\n );\n\n useImperativeHandle(\n ref,\n () => ({\n scrollToBottom,\n getScrollViewport: () => viewportRef.current,\n }),\n [scrollToBottom],\n );\n\n /* ── Intersection observer: track \"at bottom\" via a sentinel ── */\n useEffect(() => {\n const root = viewportRef.current;\n const sentinel = sentinelRef.current;\n if (!root || !sentinel) return;\n const observer = new IntersectionObserver(\n (entries) => {\n const entry = entries[0];\n setIsAtBottom(entry.isIntersecting);\n onAutoScrollChange?.(entry.isIntersecting);\n },\n {\n root,\n // Fire when the sentinel is within BOTTOM_SLACK_PX of being visible.\n rootMargin: `0px 0px ${BOTTOM_SLACK_PX}px 0px`,\n threshold: 0,\n },\n );\n observer.observe(sentinel);\n return () => observer.disconnect();\n }, [onAutoScrollChange]);\n\n /* ── Auto-scroll on new messages when at bottom ── */\n const messagesLength = messages.length;\n useLayoutEffect(() => {\n // `smooth: false` — when we're already pinned to the bottom and a\n // new message appends, the user doesn't perceive any scroll motion\n // (the sentinel just slides a few px). But a smooth animation DOES\n // give the IntersectionObserver a window in which the sentinel is\n // temporarily outside the rootMargin zone — that's what causes the\n // scroll-to-latest FAB to flicker in and out on every new message.\n // Instant scroll settles in one frame; FAB state stays stable.\n // The user-initiated FAB click below still uses smooth because the\n // jump is large and the motion communicates the travel.\n if (isAtBottom) scrollToBottom({ smooth: false });\n // Intentionally watching only length — individual node updates (streaming)\n // are driven by their own scroll decisions.\n }, [messagesLength, isAtBottom, scrollToBottom]);\n\n const virtualized = messages.length > VIRTUALIZATION_THRESHOLD;\n\n const virtualizer = useVirtualizer({\n count: virtualized ? messages.length : 0,\n getScrollElement: () => viewportRef.current,\n estimateSize: () => 80,\n overscan: 6,\n getItemKey: (i) => messages[i]?.id ?? i,\n });\n\n return (\n <div className={rootVariants({ density, className })} data-component=\"chat-container\" {...rest}>\n {/* Scroll column wraps the viewport AND the FAB together so the\n FAB's absolute `bottom` is measured from the top of the\n composer (this wrapper's end edge), not from the root — which\n would drop the FAB inside the composer/suggestion-chip area. */}\n <div className=\"ds:relative ds:flex-1 ds:min-h-0 ds:flex ds:flex-col\">\n <div\n ref={viewportRef}\n role=\"log\"\n aria-live=\"polite\"\n aria-relevant=\"additions\"\n aria-label={t('ui.chat.container')}\n tabIndex={0}\n className={scrollViewportVariants()}\n >\n {virtualized ? (\n <ol\n className=\"ds:relative ds:list-none ds:ps-0 ds:m-0\"\n // Inline style — permitted per 23-constraints\n // §Runtime-computed dimensions (virtualizer total size).\n style={{ blockSize: `${virtualizer.getTotalSize()}px` }}\n >\n {virtualizer.getVirtualItems().map((vi) => {\n const msg = messages[vi.index];\n if (!msg) return null;\n return (\n <li\n key={msg.id}\n data-index={vi.index}\n ref={virtualizer.measureElement}\n className=\"ds:absolute ds:start-0 ds:end-0 ds:top-0 ds:w-full\"\n // Inline style — permitted per 23-constraints\n // §Runtime-computed dimensions (virtualizer translateY).\n style={{ transform: `translateY(${vi.start}px)` }}\n >\n <div className=\"ds:pt-[var(--spacing-xs)] ds:pb-[var(--spacing-xs)]\">\n {msg.node}\n </div>\n </li>\n );\n })}\n </ol>\n ) : (\n <ol className=\"ds:flex ds:flex-col ds:gap-[var(--spacing-sm)] ds:list-none ds:ps-0 ds:m-0\">\n {messages.map((m) => (\n <li key={m.id}>{m.node}</li>\n ))}\n </ol>\n )}\n <div ref={sentinelRef} aria-hidden=\"true\" className=\"ds:h-1 ds:w-full\" />\n </div>\n\n {showScrollToLatest && !isAtBottom ? (\n <div\n className={[\n 'ds:pointer-events-none ds:absolute ds:inset-inline-end-0',\n // `bottom` is measured from the bottom of the scroll\n // column (i.e. the top edge of the composer slot). A\n // small spacing-md gap keeps the FAB clear of the\n // divider border above the composer.\n 'ds:bottom-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n // Enter animation — fade + scale in from 95%. The FAB only\n // unmounts when the user returns to bottom, so an exit\n // animation isn't justified (abrupt disappearance reads as\n // \"task complete\" when they've scrolled back).\n 'ds:motion-safe:animate-in ds:motion-safe:fade-in-0 ds:motion-safe:zoom-in-95',\n 'ds:duration-[var(--animation-duration)] ds:ease-[var(--ease-out)]',\n ].join(' ')}\n >\n <div className=\"ds:pointer-events-auto\">\n <FloatingActionButton\n icon={<ChevronDown />}\n aria-label={t('ui.chat.scrollToLatest')}\n size=\"sm\"\n variant=\"secondary\"\n // `position=\"static\"` — the wrapper is already\n // absolutely-positioned. Without this, FAB's default\n // `bottom-end` variant applies `position: fixed` and\n // pins the button to the browser viewport corner,\n // escaping the container and appearing as an orphan\n // circle that stays put while the chat scrolls.\n position=\"static\"\n onClick={() => scrollToBottom({ smooth: true })}\n />\n </div>\n </div>\n ) : null}\n </div>\n\n {composer ? (\n <div className=\"ds:shrink-0 ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)] ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-sm)] ds:bg-background\">\n {composer}\n </div>\n ) : null}\n </div>\n );\n },\n);\n\nChatContainer.displayName = 'ChatContainer';\n"],"names":["rootVariants","cva","scrollViewportVariants","VIRTUALIZATION_THRESHOLD","BOTTOM_SLACK_PX","ChatContainer","forwardRef","messages","composer","density","className","onAutoScrollChange","showScrollToLatest","rest","ref","t","useTranslation","viewportRef","useRef","sentinelRef","isAtBottom","setIsAtBottom","useState","prefersReducedMotion","usePrefersReducedMotion","scrollToBottom","useCallback","opts","el","smooth","useImperativeHandle","useEffect","root","sentinel","observer","entries","entry","messagesLength","useLayoutEffect","virtualized","virtualizer","useVirtualizer","i","_a","jsxs","jsx","vi","msg","m","FloatingActionButton","ChevronDown"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"chat-input-DreOPP8A.js","sources":["../../node_modules/lucide-react/dist/esm/icons/paperclip.js","../../src/components/chat-input/chat-input.tsx"],"sourcesContent":["/**\n * @license lucide-react v1.8.0 - ISC\n *\n * This source code is licensed under the ISC license.\n * See the LICENSE file in the root directory of this source tree.\n */\n\nimport createLucideIcon from '../createLucideIcon.js';\n\nconst __iconNode = [\n [\n \"path\",\n {\n d: \"m16 6-8.414 8.586a2 2 0 0 0 2.829 2.829l8.414-8.586a4 4 0 1 0-5.657-5.657l-8.379 8.551a6 6 0 1 0 8.485 8.485l8.379-8.551\",\n key: \"1miecu\"\n }\n ]\n];\nconst Paperclip = createLucideIcon(\"paperclip\", __iconNode);\n\nexport { __iconNode, Paperclip as default };\n//# sourceMappingURL=paperclip.js.map\n","import {\n forwardRef,\n useCallback,\n useId,\n useLayoutEffect,\n useRef,\n useState,\n type ChangeEvent,\n type CompositionEvent,\n type KeyboardEvent,\n type ReactNode,\n type TextareaHTMLAttributes,\n} from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport { AlertCircle, Paperclip, Send } from 'lucide-react';\nimport { IconButton } from '../button';\n\nconst rootVariants = cva(\n [\n 'ds:flex ds:flex-col ds:gap-[var(--spacing-xs)] ds:w-full',\n // Soft drop-shadow + transparent border replaces a flat\n // `border-border` (grey-800 since the WCAG 1.4.11 bump). Border kept\n // at 1px so the focus-within color override + forced-colors\n // fallback still paint a visible edge.\n 'ds:rounded-[var(--radius-md)] ds:shadow-[var(--shadow-sm)] ds:border ds:border-transparent',\n 'ds:bg-background ds:focus-within:border-[color:var(--primary)]',\n 'ds:transition-[border-color] ds:duration-[var(--animation-duration)]',\n 'ds:motion-reduce:transition-none',\n 'ds:forced-colors:border-[CanvasText]',\n ].join(' '),\n {\n variants: {\n size: {\n sm: 'ds:text-[length:var(--font-size-sm)]',\n md: 'ds:text-[length:var(--font-size-base)]',\n lg: 'ds:text-[length:var(--font-size-lg)]',\n },\n },\n defaultVariants: { size: 'md' },\n },\n);\n\ntype NativeTextareaProps = Omit<\n TextareaHTMLAttributes<HTMLTextAreaElement>,\n 'size' | 'onSubmit' | 'children'\n>;\n\nexport interface ChatInputProps\n extends NativeTextareaProps,\n VariantProps<typeof rootVariants> {\n /** Invoked when the user submits (Cmd/Ctrl+Enter, or send button). */\n onSubmit?: (text: string) => void;\n /** Maximum allowed characters (grapheme clusters via Intl.Segmenter when available). */\n maxLength?: number;\n /** When true, plain Enter submits and Shift+Enter inserts a newline.\n * Default false (Enter inserts newline; Cmd/Ctrl+Enter submits). */\n submitOnEnter?: boolean;\n /** Minimum visible rows. Default 1. */\n minRows?: number;\n /** Maximum visible rows before the field scrolls. Default 8. */\n maxRows?: number;\n /** Optional attachment handler — when provided, renders the attachment button. */\n onAttach?: (files: FileList) => void;\n /** `accept` forwarded to the hidden file input. */\n accept?: string;\n /** Controls whether the textarea is disabled and submit is blocked. */\n disabled?: boolean;\n /** Optional slot placed between the textarea and the send button. */\n toolbar?: ReactNode;\n /** Visible label above the textarea. When omitted, a visually-hidden label is used. */\n label?: string;\n}\n\nfunction graphemeCount(value: string, locale: string): number {\n if (typeof Intl !== 'undefined' && typeof Intl.Segmenter === 'function') {\n try {\n const seg = new Intl.Segmenter(locale, { granularity: 'grapheme' });\n let n = 0;\n for (const _s of seg.segment(value)) n += 1;\n return n;\n } catch {\n /* fall through to Array.from */\n }\n }\n return Array.from(value).length;\n}\n\nexport const ChatInput = forwardRef<HTMLTextAreaElement, ChatInputProps>(\n (\n {\n size = 'md',\n value,\n defaultValue,\n maxLength,\n submitOnEnter = false,\n minRows = 1,\n maxRows = 8,\n onSubmit,\n onAttach,\n accept,\n disabled,\n toolbar,\n label,\n placeholder,\n className,\n onChange,\n onKeyDown,\n onCompositionStart,\n onCompositionEnd,\n id,\n ...rest\n },\n ref,\n ) => {\n const { t, i18n } = useTranslation();\n const textareaId = useId();\n const composingRef = useRef(false);\n const fileInputRef = useRef<HTMLInputElement>(null);\n const innerRef = useRef<HTMLTextAreaElement | null>(null);\n\n const setRefs = useCallback(\n (node: HTMLTextAreaElement | null) => {\n innerRef.current = node;\n if (typeof ref === 'function') ref(node);\n else if (ref) ref.current = node;\n },\n [ref],\n );\n\n const isControlled = value !== undefined;\n const [internalValue, setInternalValue] = useState<string>(\n String(defaultValue ?? ''),\n );\n const currentValue = isControlled ? String(value) : internalValue;\n\n const count = graphemeCount(currentValue, i18n.language);\n const hasMaxLength = typeof maxLength === 'number' && maxLength > 0;\n const remaining = hasMaxLength ? Math.max(0, maxLength - count) : 0;\n const showCounter = hasMaxLength && count > (maxLength as number) * 0.9;\n const atLimit = hasMaxLength && count >= maxLength;\n\n /* Auto-grow — compute height from scrollHeight, clamped to [minRows, maxRows].\n Imperative `.style` write is permitted per 23-constraints\n §Runtime-computed dimensions (textarea scrollHeight measurement). */\n const resize = useCallback(() => {\n const el = innerRef.current;\n if (!el) return;\n const styles = window.getComputedStyle(el);\n const lineHeight = parseFloat(styles.lineHeight) || 24;\n const padTop = parseFloat(styles.paddingTop) || 0;\n const padBot = parseFloat(styles.paddingBottom) || 0;\n const borderTop = parseFloat(styles.borderTopWidth) || 0;\n const borderBot = parseFloat(styles.borderBottomWidth) || 0;\n const chrome = padTop + padBot + borderTop + borderBot;\n const minH = lineHeight * minRows + chrome;\n const maxH = lineHeight * maxRows + chrome;\n el.style.height = 'auto';\n const next = Math.max(minH, Math.min(el.scrollHeight, maxH));\n el.style.height = `${next}px`;\n el.style.overflowY = el.scrollHeight > maxH ? 'auto' : 'hidden';\n }, [minRows, maxRows]);\n\n useLayoutEffect(() => {\n resize();\n }, [resize, currentValue]);\n\n const handleChange = (e: ChangeEvent<HTMLTextAreaElement>) => {\n if (!isControlled) setInternalValue(e.target.value);\n if (composingRef.current) return;\n onChange?.(e);\n };\n\n const handleCompositionStart = (e: CompositionEvent<HTMLTextAreaElement>) => {\n composingRef.current = true;\n onCompositionStart?.(e);\n };\n const handleCompositionEnd = (e: CompositionEvent<HTMLTextAreaElement>) => {\n composingRef.current = false;\n onCompositionEnd?.(e);\n };\n\n const isIMEKey = (e: KeyboardEvent<HTMLTextAreaElement>) =>\n e.nativeEvent.isComposing || e.keyCode === 229 || composingRef.current;\n\n const submit = () => {\n const text = currentValue.trim();\n if (!text || disabled || atLimit) return;\n onSubmit?.(currentValue);\n if (!isControlled) setInternalValue('');\n };\n\n const handleKeyDown = (e: KeyboardEvent<HTMLTextAreaElement>) => {\n onKeyDown?.(e);\n if (e.defaultPrevented) return;\n if (isIMEKey(e)) return;\n\n if (e.key === 'Enter') {\n const explicitSubmit = e.metaKey || e.ctrlKey;\n const plainEnterSubmits = submitOnEnter && !e.shiftKey;\n if (explicitSubmit || plainEnterSubmits) {\n e.preventDefault();\n submit();\n }\n }\n };\n\n const handleAttach = () => {\n fileInputRef.current?.click();\n };\n\n const handleFilePick = (e: ChangeEvent<HTMLInputElement>) => {\n if (e.target.files && e.target.files.length > 0) {\n onAttach?.(e.target.files);\n }\n // Reset so picking the same file twice still fires change.\n e.target.value = '';\n };\n\n const effectiveId = id ?? textareaId;\n const labelId = `${effectiveId}-label`;\n const counterId = hasMaxLength ? `${effectiveId}-counter` : undefined;\n const hintId = `${effectiveId}-hint`;\n\n const resolvedPlaceholder =\n placeholder ?? t('chat.input.placeholder');\n const resolvedLabel = label ?? t('chat.prompt');\n\n return (\n <div data-component=\"chat-input\" className={rootVariants({ size, className })}>\n <label id={labelId} htmlFor={effectiveId} className={label ? 'type-label ds:ps-[var(--spacing-sm)] ds:pt-[var(--spacing-sm)]' : 'ds:sr-only'}>\n {resolvedLabel}\n </label>\n <textarea\n ref={setRefs}\n id={effectiveId}\n value={isControlled ? currentValue : undefined}\n defaultValue={!isControlled ? defaultValue : undefined}\n disabled={disabled}\n rows={minRows}\n maxLength={maxLength}\n placeholder={resolvedPlaceholder}\n aria-labelledby={labelId}\n aria-describedby={[counterId, hintId].filter(Boolean).join(' ') || undefined}\n aria-invalid={atLimit || undefined}\n onChange={handleChange}\n onKeyDown={handleKeyDown}\n onCompositionStart={handleCompositionStart}\n onCompositionEnd={handleCompositionEnd}\n className={[\n 'ds:w-full ds:resize-none ds:bg-transparent',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)] ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-xs)]',\n 'ds:placeholder:text-[color:var(--muted-foreground)]',\n 'ds:leading-[var(--line-height-base)]',\n 'ds:disabled:opacity-50 ds:disabled:cursor-not-allowed',\n // Tokenised focus ring on the textarea itself — the 1px border\n // shift on the wrapper alone fails the 3px accessible-theme\n // requirement. See a11y-critical-fixes.mdx.\n 'ds:outline-none',\n 'ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid',\n 'ds:focus-visible:outline-[color:var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]',\n 'ds:rounded-[var(--radius-sm)]',\n 'ds:forced-colors:focus-visible:outline-[CanvasText]',\n ].join(' ')}\n {...rest}\n />\n <div className=\"ds:flex ds:items-center ds:gap-[var(--spacing-xs)] ds:ps-[var(--spacing-xs)] ds:pe-[var(--spacing-xs)] ds:pb-[var(--spacing-xs)]\">\n {onAttach ? (\n <>\n <input\n ref={fileInputRef}\n type=\"file\"\n className=\"ds:sr-only\"\n multiple\n accept={accept}\n onChange={handleFilePick}\n />\n <IconButton\n icon={<Paperclip />}\n aria-label={t('chat.input.attach')}\n intent=\"ghost\"\n size=\"sm\"\n onClick={handleAttach}\n disabled={disabled}\n />\n </>\n ) : null}\n {toolbar}\n <div className=\"ds:ms-auto ds:inline-flex ds:items-center ds:gap-[var(--spacing-sm)]\">\n {showCounter ? (\n <span\n id={counterId}\n aria-live=\"polite\"\n className={[\n 'ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)]',\n 'type-meta ds:tabular-nums',\n atLimit\n ? 'ds:text-[color:var(--destructive)]'\n : 'ds:text-[color:var(--muted-foreground)]',\n ].join(' ')}\n >\n {atLimit ? (\n // Icon pairs with --destructive colour so the at-limit\n // state is not conveyed by hue alone (WCAG 1.4.1).\n <AlertCircle aria-hidden=\"true\" className=\"ds:size-3.5\" />\n ) : null}\n {t('chat.input.remaining', { count: remaining })}\n </span>\n ) : null}\n <span id={hintId} className=\"ds:sr-only\">\n {t('chat.input.sendHint')}\n </span>\n <IconButton\n icon={<Send />}\n aria-label={t('chat.send')}\n intent=\"primary\"\n size=\"sm\"\n disabled={disabled || !currentValue.trim() || atLimit}\n onClick={submit}\n aria-keyshortcuts=\"Meta+Enter Control+Enter\"\n />\n </div>\n </div>\n </div>\n );\n },\n);\n\nChatInput.displayName = 'ChatInput';\n"],"names":["__iconNode","Paperclip","createLucideIcon","rootVariants","cva","graphemeCount","value","locale","seg","n","_s","ChatInput","forwardRef","size","defaultValue","maxLength","submitOnEnter","minRows","maxRows","onSubmit","onAttach","accept","disabled","toolbar","label","placeholder","className","onChange","onKeyDown","onCompositionStart","onCompositionEnd","id","rest","ref","t","i18n","useTranslation","textareaId","useId","composingRef","useRef","fileInputRef","innerRef","setRefs","useCallback","node","isControlled","internalValue","setInternalValue","useState","currentValue","count","hasMaxLength","remaining","showCounter","atLimit","resize","el","styles","lineHeight","padTop","padBot","borderTop","borderBot","chrome","minH","maxH","next","useLayoutEffect","handleChange","handleCompositionStart","handleCompositionEnd","isIMEKey","submit","handleKeyDown","explicitSubmit","plainEnterSubmits","handleAttach","_a","handleFilePick","effectiveId","labelId","counterId","hintId","resolvedPlaceholder","resolvedLabel","jsxs","jsx","Fragment","IconButton","AlertCircle","Send"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1,116 +0,0 @@
1
- import { jsxs as j, jsx as e } from "react/jsx-runtime";
2
- import { createContext as I, useContext as L, forwardRef as G, useId as _ } from "react";
3
- import * as h from "@radix-ui/react-checkbox";
4
- import { c as B } from "./index-D2ZczOXr.js";
5
- import { T as M } from "./tooltip-DHik5yRI.js";
6
- const R = I(null);
7
- function T() {
8
- return L(R);
9
- }
10
- const u = [
11
- "ds:[stroke-dasharray:1] ds:[stroke-dashoffset:1]",
12
- "ds:animate-[checkbox-indicator-draw_var(--animation-duration)_ease-out_forwards]"
13
- ].join(" ");
14
- function V({ className: t }) {
15
- return /* @__PURE__ */ e(
16
- "svg",
17
- {
18
- viewBox: "0 0 24 24",
19
- fill: "none",
20
- stroke: "currentColor",
21
- strokeWidth: "3",
22
- strokeLinecap: "round",
23
- strokeLinejoin: "round",
24
- "aria-hidden": "true",
25
- "data-slot": "checkbox-check-icon",
26
- className: t,
27
- children: /* @__PURE__ */ e("path", { pathLength: "1", d: "M5 12l5 5L20 7", className: u })
28
- }
29
- );
30
- }
31
- function W({ className: t }) {
32
- return /* @__PURE__ */ e(
33
- "svg",
34
- {
35
- viewBox: "0 0 24 24",
36
- fill: "none",
37
- stroke: "currentColor",
38
- strokeWidth: "3",
39
- strokeLinecap: "round",
40
- "aria-hidden": "true",
41
- "data-slot": "checkbox-indeterminate-icon",
42
- className: t,
43
- children: /* @__PURE__ */ e("path", { pathLength: "1", d: "M5 12h14", className: u })
44
- }
45
- );
46
- }
47
- const D = B(
48
- [
49
- "ds:inline-flex ds:items-center ds:justify-center ds:shrink-0",
50
- "ds:border ds:border-border ds:rounded-[var(--radius-sm)] ds:bg-background",
51
- "ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none",
52
- "ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid",
53
- "ds:focus-visible:outline-ring ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]",
54
- "ds:disabled:cursor-not-allowed ds:disabled:opacity-50",
55
- "ds:data-[state=checked]:bg-primary ds:data-[state=checked]:border-primary ds:data-[state=checked]:text-primary-foreground",
56
- "ds:data-[state=indeterminate]:bg-primary ds:data-[state=indeterminate]:border-primary ds:data-[state=indeterminate]:text-primary-foreground",
57
- 'ds:relative ds:before:absolute ds:before:inset-[calc((var(--min-target-size)-100%)/-2)] ds:before:content-[""]'
58
- ].join(" "),
59
- {
60
- variants: {
61
- size: {
62
- sm: "ds:size-3.5",
63
- md: "ds:size-4",
64
- lg: "ds:size-5"
65
- }
66
- },
67
- defaultVariants: {
68
- size: "md"
69
- }
70
- }
71
- ), F = G(
72
- ({
73
- label: t,
74
- checked: f,
75
- onCheckedChange: b,
76
- size: n = "md",
77
- disabled: k,
78
- disabledReason: r,
79
- name: p,
80
- value: o,
81
- id: x,
82
- className: g,
83
- ...v
84
- }, C) => {
85
- const y = _(), d = x ?? y, s = T(), i = s !== null && o !== void 0, c = i ? s.value.has(o) : f, w = i ? () => s.toggle(o) : b, N = (s == null ? void 0 : s.name) ?? p, a = (s == null ? void 0 : s.disabled) || k, l = n === "sm" ? "ds:size-3" : n === "lg" ? "ds:size-4" : "ds:size-3.5", z = [
86
- "type-label ds:text-foreground ds:select-none",
87
- a ? "ds:cursor-not-allowed ds:opacity-50" : "ds:cursor-pointer"
88
- ].join(" "), m = /* @__PURE__ */ j("div", { "data-component": "checkbox", className: "ds:inline-flex ds:items-center ds:gap-[var(--spacing-sm)]", children: [
89
- /* @__PURE__ */ e(
90
- h.Root,
91
- {
92
- ref: C,
93
- id: d,
94
- checked: c,
95
- onCheckedChange: w,
96
- disabled: a,
97
- "aria-disabled": a || void 0,
98
- name: N,
99
- value: o,
100
- className: D({ size: n, className: g }),
101
- ...v,
102
- children: /* @__PURE__ */ e(h.Indicator, { children: c === "indeterminate" ? /* @__PURE__ */ e(W, { className: l }) : /* @__PURE__ */ e(V, { className: l }) })
103
- }
104
- ),
105
- /* @__PURE__ */ e("label", { htmlFor: d, className: z, children: t })
106
- ] });
107
- return a && r ? /* @__PURE__ */ e(M, { label: r, children: m }) : m;
108
- }
109
- );
110
- F.displayName = "Checkbox";
111
- export {
112
- F as C,
113
- R as a,
114
- T as u
115
- };
116
- //# sourceMappingURL=checkbox-DNK4qS2_.js.map