@alfadocs/ui-kit 0.1.7 → 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 (991) hide show
  1. package/README.md +18 -0
  2. package/dist/_chunks/{accordion-B6fyINUk.js → accordion-BEnrZmAn.js} +34 -32
  3. package/dist/_chunks/accordion.agent-BTjeO1Sx.js +52 -0
  4. package/dist/_chunks/{agenda-card-DIWDvWum.js → agenda-card-DwLIxgi7.js} +2 -1
  5. package/dist/_chunks/agenda-card.agent-B_R47-c9.js +22 -0
  6. package/dist/_chunks/agenda-tray-DUvengGQ.js +178 -0
  7. package/dist/_chunks/ai-prompt-input.agent-0NHYLTWD.js +476 -0
  8. package/dist/_chunks/{aspect-ratio-CxsdG8vk.js → aspect-ratio-DeSNzASA.js} +12 -12
  9. package/dist/_chunks/audio-recorder.agent--VKeykUp.js +458 -0
  10. package/dist/_chunks/autocomplete.agent-Dh7KioS6.js +432 -0
  11. package/dist/_chunks/{balance-cell-renderer-BWm3knY9.js → balance-cell-renderer-5CA7zpAi.js} +3 -3
  12. package/dist/_chunks/breadcrumb.agent-GM2hAKFX.js +371 -0
  13. package/dist/_chunks/{chart.agent-BdS-_8MO.js → chart.agent-_pRYS17d.js} +112 -105
  14. package/dist/_chunks/{chat-container-Cm3SlR2p.js → chat-container-Dl0Kfy5a.js} +33 -32
  15. package/dist/_chunks/{chat-container.agent-Dhw9xCJt.js → chat-container.agent-CM4WModE.js} +9 -4
  16. package/dist/_chunks/{chat-input-DreOPP8A.js → chat-input-C_tMQv92.js} +108 -82
  17. package/dist/_chunks/chat-input.agent-Bsz3ckGa.js +69 -0
  18. package/dist/_chunks/checkbox-CtPM6Rup.js +196 -0
  19. package/dist/_chunks/checkbox-group-BTdEB6Yo.js +208 -0
  20. package/dist/_chunks/collapsible.agent-DkS1jVyn.js +149 -0
  21. package/dist/_chunks/{color-picker-e9PmpaGH.js → color-picker-94qcBZqZ.js} +234 -184
  22. package/dist/_chunks/combobox.agent-CAvUkkIe.js +410 -0
  23. package/dist/_chunks/{command-palette.agent-js2rxgeR.js → command-palette.agent-HatEt_EM.js} +161 -121
  24. package/dist/_chunks/date-picker-BqPTn7bO.js +1813 -0
  25. package/dist/_chunks/date-range-picker-B2hGsffw.js +274 -0
  26. package/dist/_chunks/date-time-picker-Bzt0S8yO.js +293 -0
  27. package/dist/_chunks/dialog.agent-Daf1TTko.js +179 -0
  28. package/dist/_chunks/{dropdown-menu-Cw3EyPZv.js → dropdown-menu-C7AZipNz.js} +75 -71
  29. package/dist/_chunks/dropdown-menu.agent-BcxIKOjK.js +43 -0
  30. package/dist/_chunks/{file-upload.agent-B9AN82LA.js → file-upload.agent-DJaH2dHg.js} +275 -243
  31. package/dist/_chunks/freemium-paywall.agent-_nQqLyRF.js +260 -0
  32. package/dist/_chunks/{leo-sidebar-nbHib2D-.js → leo-sidebar-BwINPdix.js} +6 -6
  33. package/dist/_chunks/link-QheANk74.js +121 -0
  34. package/dist/_chunks/list.agent-D0iWt4VI.js +420 -0
  35. package/dist/_chunks/{message-card-qAp2-WQK.js → message-card-qhoGv947.js} +2 -1
  36. package/dist/_chunks/message-card.agent-4IeIgrnJ.js +22 -0
  37. package/dist/_chunks/message-tray-xHUCra-Y.js +419 -0
  38. package/dist/_chunks/{multi-select.agent-CNsyW3n9.js → multi-select.agent-Do6CeQUT.js} +239 -179
  39. package/dist/_chunks/navigation-menu.agent-D69ND6Qq.js +266 -0
  40. package/dist/_chunks/{notification-card-BF2_veHy.js → notification-card-CsVEYJE-.js} +13 -12
  41. package/dist/_chunks/notification-card.agent-Rqt3ofk9.js +22 -0
  42. package/dist/_chunks/notification-tray-DTXMq42J.js +444 -0
  43. package/dist/_chunks/number-input-fvGmnRy9.js +333 -0
  44. package/dist/_chunks/otp-input-EglXOUue.js +257 -0
  45. package/dist/_chunks/pagination.agent-BkZQl45y.js +422 -0
  46. package/dist/_chunks/password-input-D6kuYXmr.js +304 -0
  47. package/dist/_chunks/{patient-shell-7cXqIMFg.js → patient-shell-BRmrrUUW.js} +3 -3
  48. package/dist/_chunks/{payment-form-hcl-gGrp.js → payment-form-BWaXas8z.js} +120 -118
  49. package/dist/_chunks/{payment-form.agent-BkEnRerR.js → payment-form.agent-kuIfodCj.js} +7 -2
  50. package/dist/_chunks/{pdf-viewer.agent-CfIHhcHx.js → pdf-viewer.agent-BaGEDheA.js} +358 -351
  51. package/dist/_chunks/phone-input-C8Op4sEc.js +513 -0
  52. package/dist/_chunks/popover-kFN8s84V.js +229 -0
  53. package/dist/_chunks/popover.agent-K_d1cfbj.js +39 -0
  54. package/dist/_chunks/privacy-lock.agent-C1i1-T58.js +185 -0
  55. package/dist/_chunks/progress-wNsqkw8I.js +253 -0
  56. package/dist/_chunks/progress.agent-C68rDOXL.js +27 -0
  57. package/dist/_chunks/{radio-cs8N1wJi.js → radio-DvF59ThA.js} +14 -13
  58. package/dist/_chunks/radio-group-Cz1a4QCA.js +152 -0
  59. package/dist/_chunks/recaptcha-widget.agent-BGHpU5zD.js +183 -0
  60. package/dist/_chunks/resizable.agent-CMwZzvsi.js +456 -0
  61. package/dist/_chunks/{rich-text-editor.agent-COSb5_2D.js → rich-text-editor.agent-DnE125Tz.js} +221 -214
  62. package/dist/_chunks/search-bar.agent-DxFAxctc.js +562 -0
  63. package/dist/_chunks/search-input-Xw3cdWXW.js +227 -0
  64. package/dist/_chunks/search-input.agent-CfZvViOd.js +69 -0
  65. package/dist/_chunks/select-DY1Cb2Tg.js +410 -0
  66. package/dist/_chunks/{sheet-BhNpLHc9.js → sheet-B9kH9pcI.js} +55 -54
  67. package/dist/_chunks/sheet.agent-QAyTOxgk.js +46 -0
  68. package/dist/_chunks/{sidebar-OVzwN3jE.js → sidebar-CHF5xr_P.js} +188 -185
  69. package/dist/_chunks/sidebar.agent-C9TM_ZDZ.js +49 -0
  70. package/dist/_chunks/{signature-capture.agent-C38VPXxg.js → signature-capture.agent-BpeDwFht.js} +127 -120
  71. package/dist/_chunks/slider-CcsQTZTA.js +322 -0
  72. package/dist/_chunks/sparkline.agent-56Sj7nOP.js +245 -0
  73. package/dist/_chunks/stepper-accordion.agent-ckKYZCIP.js +322 -0
  74. package/dist/_chunks/stepper-calendar.agent-9iT3ClIB.js +646 -0
  75. package/dist/_chunks/stepper-progress-Bmen-YXB.js +149 -0
  76. package/dist/_chunks/stepper-progress.agent-q9InWca4.js +61 -0
  77. package/dist/_chunks/suggestion-chip-DhFrkRPj.js +169 -0
  78. package/dist/_chunks/suggestion-chip.agent-6sNWFj7m.js +46 -0
  79. package/dist/_chunks/switch-BYEH8I53.js +196 -0
  80. package/dist/_chunks/{tabs.agent-BpbVA-Zh.js → tabs.agent-h7NvsTR1.js} +146 -123
  81. package/dist/_chunks/{task-card-yW7tKlG4.js → task-card-CY5ztNkU.js} +2 -1
  82. package/dist/_chunks/task-card.agent-CUPKYd7w.js +22 -0
  83. package/dist/_chunks/task-tray-CCoUdorl.js +194 -0
  84. package/dist/_chunks/text-area-C_M8wliK.js +239 -0
  85. package/dist/_chunks/text-input-BX39e6T6.js +272 -0
  86. package/dist/_chunks/theme-toggle.agent-btmXTWdW.js +394 -0
  87. package/dist/_chunks/time-picker-B8AMIrX7.js +410 -0
  88. package/dist/_chunks/timeline.agent-CRPza9wc.js +279 -0
  89. package/dist/_chunks/{toast-lOhJDKOH.js → toast.agent-BjEGuq1Z.js} +403 -342
  90. package/dist/_chunks/{tooth-scheme.agent-BlDyu-Gx.js → tooth-scheme.agent-CWrQBjJM.js} +218 -211
  91. package/dist/_chunks/transcript-panel.agent-BXEYP6w-.js +337 -0
  92. package/dist/_chunks/{workflow-map-XeqHDFvp.js → workflow-map-D2A7rTEG.js} +465 -368
  93. package/dist/agent-catalog.json +2929 -268
  94. package/dist/components/accordion/accordion.agent.d.ts +2 -1
  95. package/dist/components/accordion/accordion.d.ts +6 -0
  96. package/dist/components/accordion/index.js +2 -2
  97. package/dist/components/agenda-card/agenda-card.agent.d.ts +3 -0
  98. package/dist/components/agenda-card/index.d.ts +1 -0
  99. package/dist/components/agenda-card/index.js +3 -1
  100. package/dist/components/agenda-tray/agenda-tray.agent.d.ts +4 -0
  101. package/dist/components/agenda-tray/agenda-tray.d.ts +19 -2
  102. package/dist/components/agenda-tray/index.d.ts +2 -1
  103. package/dist/components/agenda-tray/index.js +3 -2
  104. package/dist/components/ai-prompt-input/ai-prompt-input.agent.d.ts +4 -0
  105. package/dist/components/ai-prompt-input/ai-prompt-input.d.ts +18 -1
  106. package/dist/components/ai-prompt-input/index.d.ts +2 -1
  107. package/dist/components/ai-prompt-input/index.js +3 -2
  108. package/dist/components/aspect-ratio/index.js +1 -1
  109. package/dist/components/audio-recorder/audio-recorder.agent.d.ts +4 -0
  110. package/dist/components/audio-recorder/audio-recorder.d.ts +10 -1
  111. package/dist/components/audio-recorder/index.d.ts +2 -1
  112. package/dist/components/audio-recorder/index.js +3 -2
  113. package/dist/components/autocomplete/autocomplete.agent.d.ts +2 -1
  114. package/dist/components/autocomplete/autocomplete.d.ts +10 -0
  115. package/dist/components/autocomplete/index.js +1 -1
  116. package/dist/components/breadcrumb/breadcrumb.agent.d.ts +8 -0
  117. package/dist/components/breadcrumb/breadcrumb.d.ts +21 -2
  118. package/dist/components/breadcrumb/index.d.ts +2 -1
  119. package/dist/components/breadcrumb/index.js +5 -4
  120. package/dist/components/button/button.d.ts +1 -1
  121. package/dist/components/chart/chart.d.ts +2 -0
  122. package/dist/components/chart/index.js +1 -1
  123. package/dist/components/chat-container/chat-container.d.ts +3 -1
  124. package/dist/components/chat-container/index.js +2 -2
  125. package/dist/components/chat-input/chat-input.agent.d.ts +4 -0
  126. package/dist/components/chat-input/chat-input.d.ts +10 -1
  127. package/dist/components/chat-input/index.d.ts +2 -1
  128. package/dist/components/chat-input/index.js +4 -2
  129. package/dist/components/checkbox/checkbox.agent.d.ts +4 -0
  130. package/dist/components/checkbox/checkbox.d.ts +6 -0
  131. package/dist/components/checkbox/index.js +1 -1
  132. package/dist/components/checkbox-group/checkbox-group.agent.d.ts +4 -0
  133. package/dist/components/checkbox-group/checkbox-group.d.ts +8 -0
  134. package/dist/components/checkbox-group/index.js +1 -1
  135. package/dist/components/collapsible/collapsible.agent.d.ts +4 -0
  136. package/dist/components/collapsible/collapsible.d.ts +8 -1
  137. package/dist/components/collapsible/index.d.ts +2 -1
  138. package/dist/components/collapsible/index.js +4 -3
  139. package/dist/components/color-picker/color-picker.agent.d.ts +4 -0
  140. package/dist/components/color-picker/color-picker.d.ts +5 -0
  141. package/dist/components/color-picker/index.js +1 -1
  142. package/dist/components/combobox/combobox.agent.d.ts +2 -1
  143. package/dist/components/combobox/combobox.d.ts +10 -0
  144. package/dist/components/combobox/index.js +1 -1
  145. package/dist/components/command-palette/command-palette.agent.d.ts +2 -1
  146. package/dist/components/command-palette/command-palette.d.ts +7 -0
  147. package/dist/components/command-palette/index.js +1 -1
  148. package/dist/components/data-table/index.js +1 -1
  149. package/dist/components/date-picker/date-picker.agent.d.ts +4 -0
  150. package/dist/components/date-picker/date-picker.d.ts +16 -1
  151. package/dist/components/date-picker/index.d.ts +2 -1
  152. package/dist/components/date-picker/index.js +3 -2
  153. package/dist/components/date-range-picker/date-range-picker.agent.d.ts +4 -0
  154. package/dist/components/date-range-picker/date-range-picker.d.ts +16 -1
  155. package/dist/components/date-range-picker/index.d.ts +2 -1
  156. package/dist/components/date-range-picker/index.js +3 -2
  157. package/dist/components/date-time-picker/date-time-picker.agent.d.ts +4 -0
  158. package/dist/components/date-time-picker/date-time-picker.d.ts +16 -1
  159. package/dist/components/date-time-picker/index.d.ts +2 -1
  160. package/dist/components/date-time-picker/index.js +3 -2
  161. package/dist/components/dialog/dialog.agent.d.ts +5 -6
  162. package/dist/components/dialog/dialog.d.ts +11 -2
  163. package/dist/components/dialog/index.js +1 -1
  164. package/dist/components/dropdown-menu/dropdown-menu.agent.d.ts +2 -1
  165. package/dist/components/dropdown-menu/dropdown-menu.d.ts +10 -2
  166. package/dist/components/dropdown-menu/index.js +2 -2
  167. package/dist/components/file-upload/file-upload.agent.d.ts +2 -1
  168. package/dist/components/file-upload/file-upload.d.ts +12 -0
  169. package/dist/components/file-upload/index.js +1 -1
  170. package/dist/components/freemium-paywall/freemium-paywall.agent.d.ts +4 -0
  171. package/dist/components/freemium-paywall/freemium-paywall.d.ts +8 -1
  172. package/dist/components/freemium-paywall/index.d.ts +2 -1
  173. package/dist/components/freemium-paywall/index.js +3 -2
  174. package/dist/components/index.d.ts +2 -0
  175. package/dist/components/link/index.d.ts +2 -0
  176. package/dist/components/link/index.js +5 -0
  177. package/dist/components/link/link.d.ts +39 -0
  178. package/dist/components/list/index.d.ts +2 -1
  179. package/dist/components/list/index.js +3 -2
  180. package/dist/components/list/list.agent.d.ts +4 -0
  181. package/dist/components/list/list.d.ts +8 -2
  182. package/dist/components/message-card/index.d.ts +1 -0
  183. package/dist/components/message-card/index.js +5 -3
  184. package/dist/components/message-card/message-card.agent.d.ts +3 -0
  185. package/dist/components/message-tray/index.d.ts +2 -1
  186. package/dist/components/message-tray/index.js +3 -2
  187. package/dist/components/message-tray/message-tray.agent.d.ts +4 -0
  188. package/dist/components/message-tray/message-tray.d.ts +27 -2
  189. package/dist/components/multi-select/index.js +1 -1
  190. package/dist/components/multi-select/multi-select.agent.d.ts +2 -1
  191. package/dist/components/multi-select/multi-select.d.ts +10 -0
  192. package/dist/components/navigation-menu/index.d.ts +2 -1
  193. package/dist/components/navigation-menu/index.js +7 -6
  194. package/dist/components/navigation-menu/navigation-menu.agent.d.ts +4 -0
  195. package/dist/components/navigation-menu/navigation-menu.d.ts +28 -2
  196. package/dist/components/notification-card/index.d.ts +1 -0
  197. package/dist/components/notification-card/index.js +5 -3
  198. package/dist/components/notification-card/notification-card.agent.d.ts +3 -0
  199. package/dist/components/notification-tray/index.d.ts +2 -1
  200. package/dist/components/notification-tray/index.js +3 -2
  201. package/dist/components/notification-tray/notification-tray.agent.d.ts +4 -0
  202. package/dist/components/notification-tray/notification-tray.d.ts +27 -2
  203. package/dist/components/number-input/index.js +1 -1
  204. package/dist/components/number-input/number-input.agent.d.ts +4 -0
  205. package/dist/components/number-input/number-input.d.ts +7 -0
  206. package/dist/components/otp-input/index.js +1 -1
  207. package/dist/components/otp-input/otp-input.agent.d.ts +4 -0
  208. package/dist/components/otp-input/otp-input.d.ts +10 -0
  209. package/dist/components/pagination/index.js +1 -1
  210. package/dist/components/pagination/pagination.agent.d.ts +2 -1
  211. package/dist/components/pagination/pagination.d.ts +7 -0
  212. package/dist/components/password-input/index.js +1 -1
  213. package/dist/components/password-input/password-input.agent.d.ts +4 -0
  214. package/dist/components/password-input/password-input.d.ts +9 -0
  215. package/dist/components/payment-form/index.js +2 -2
  216. package/dist/components/payment-form/payment-form.d.ts +2 -0
  217. package/dist/components/pdf-viewer/index.js +1 -1
  218. package/dist/components/pdf-viewer/pdf-viewer.d.ts +2 -0
  219. package/dist/components/phone-input/index.js +1 -1
  220. package/dist/components/phone-input/phone-input.agent.d.ts +4 -0
  221. package/dist/components/phone-input/phone-input.d.ts +7 -0
  222. package/dist/components/popover/index.js +2 -2
  223. package/dist/components/popover/popover.agent.d.ts +2 -1
  224. package/dist/components/popover/popover.d.ts +8 -1
  225. package/dist/components/privacy-lock/index.d.ts +2 -1
  226. package/dist/components/privacy-lock/index.js +3 -2
  227. package/dist/components/privacy-lock/privacy-lock.agent.d.ts +4 -0
  228. package/dist/components/privacy-lock/privacy-lock.d.ts +7 -1
  229. package/dist/components/progress/index.js +2 -2
  230. package/dist/components/radio/index.js +1 -1
  231. package/dist/components/radio-group/index.js +2 -2
  232. package/dist/components/radio-group/radio-group.agent.d.ts +4 -0
  233. package/dist/components/radio-group/radio-group.d.ts +5 -0
  234. package/dist/components/recaptcha-widget/index.d.ts +3 -0
  235. package/dist/components/recaptcha-widget/index.js +6 -0
  236. package/dist/components/recaptcha-widget/recaptcha-widget.agent.d.ts +4 -0
  237. package/dist/components/recaptcha-widget/recaptcha-widget.d.ts +56 -0
  238. package/dist/components/resizable/index.js +1 -1
  239. package/dist/components/resizable/resizable.agent.d.ts +2 -1
  240. package/dist/components/resizable/resizable.d.ts +6 -0
  241. package/dist/components/rich-text-editor/index.js +1 -1
  242. package/dist/components/rich-text-editor/rich-text-editor.d.ts +2 -0
  243. package/dist/components/search-bar/index.d.ts +2 -1
  244. package/dist/components/search-bar/index.js +3 -2
  245. package/dist/components/search-bar/search-bar.agent.d.ts +4 -0
  246. package/dist/components/search-bar/search-bar.d.ts +27 -1
  247. package/dist/components/search-input/index.d.ts +2 -1
  248. package/dist/components/search-input/index.js +4 -2
  249. package/dist/components/search-input/search-input.agent.d.ts +4 -0
  250. package/dist/components/search-input/search-input.d.ts +27 -0
  251. package/dist/components/select/index.js +1 -1
  252. package/dist/components/select/select.agent.d.ts +4 -0
  253. package/dist/components/select/select.d.ts +9 -0
  254. package/dist/components/sheet/index.js +2 -2
  255. package/dist/components/sheet/sheet.agent.d.ts +2 -1
  256. package/dist/components/sheet/sheet.d.ts +11 -2
  257. package/dist/components/sidebar/index.js +2 -2
  258. package/dist/components/sidebar/sidebar.agent.d.ts +2 -1
  259. package/dist/components/sidebar/sidebar.d.ts +6 -0
  260. package/dist/components/signature-capture/index.js +1 -1
  261. package/dist/components/signature-capture/signature-capture.d.ts +2 -0
  262. package/dist/components/slider/index.js +1 -1
  263. package/dist/components/slider/slider.agent.d.ts +4 -0
  264. package/dist/components/slider/slider.d.ts +5 -0
  265. package/dist/components/sparkline/index.js +1 -1
  266. package/dist/components/stepper-accordion/index.d.ts +2 -1
  267. package/dist/components/stepper-accordion/index.js +3 -2
  268. package/dist/components/stepper-accordion/stepper-accordion.agent.d.ts +4 -0
  269. package/dist/components/stepper-accordion/stepper-accordion.d.ts +19 -1
  270. package/dist/components/stepper-calendar/index.d.ts +2 -1
  271. package/dist/components/stepper-calendar/index.js +3 -2
  272. package/dist/components/stepper-calendar/stepper-calendar.agent.d.ts +4 -0
  273. package/dist/components/stepper-calendar/stepper-calendar.d.ts +19 -1
  274. package/dist/components/stepper-progress/index.d.ts +2 -1
  275. package/dist/components/stepper-progress/index.js +4 -2
  276. package/dist/components/stepper-progress/stepper-progress.agent.d.ts +4 -0
  277. package/dist/components/stepper-progress/stepper-progress.d.ts +26 -1
  278. package/dist/components/suggestion-chip/index.d.ts +2 -1
  279. package/dist/components/suggestion-chip/index.js +5 -3
  280. package/dist/components/suggestion-chip/suggestion-chip.agent.d.ts +4 -0
  281. package/dist/components/suggestion-chip/suggestion-chip.d.ts +7 -1
  282. package/dist/components/switch/index.js +1 -1
  283. package/dist/components/switch/switch.agent.d.ts +4 -0
  284. package/dist/components/switch/switch.d.ts +6 -0
  285. package/dist/components/tabs/index.js +1 -1
  286. package/dist/components/tabs/tabs.agent.d.ts +2 -1
  287. package/dist/components/tabs/tabs.d.ts +4 -0
  288. package/dist/components/task-card/index.d.ts +1 -0
  289. package/dist/components/task-card/index.js +5 -3
  290. package/dist/components/task-card/task-card.agent.d.ts +3 -0
  291. package/dist/components/task-tray/index.d.ts +2 -1
  292. package/dist/components/task-tray/index.js +3 -2
  293. package/dist/components/task-tray/task-tray.agent.d.ts +4 -0
  294. package/dist/components/task-tray/task-tray.d.ts +25 -2
  295. package/dist/components/text-area/index.js +1 -1
  296. package/dist/components/text-area/text-area.agent.d.ts +4 -0
  297. package/dist/components/text-area/text-area.d.ts +7 -0
  298. package/dist/components/text-input/index.js +1 -1
  299. package/dist/components/text-input/text-input.agent.d.ts +4 -0
  300. package/dist/components/text-input/text-input.d.ts +10 -0
  301. package/dist/components/theme-toggle/index.d.ts +2 -1
  302. package/dist/components/theme-toggle/index.js +3 -2
  303. package/dist/components/theme-toggle/theme-toggle.agent.d.ts +4 -0
  304. package/dist/components/theme-toggle/theme-toggle.d.ts +9 -2
  305. package/dist/components/time-picker/index.d.ts +2 -1
  306. package/dist/components/time-picker/index.js +3 -2
  307. package/dist/components/time-picker/time-picker.agent.d.ts +4 -0
  308. package/dist/components/time-picker/time-picker.d.ts +16 -1
  309. package/dist/components/timeline/index.d.ts +2 -1
  310. package/dist/components/timeline/index.js +3 -2
  311. package/dist/components/timeline/timeline.agent.d.ts +4 -0
  312. package/dist/components/timeline/timeline.d.ts +8 -1
  313. package/dist/components/toast/index.d.ts +3 -2
  314. package/dist/components/toast/index.js +7 -5
  315. package/dist/components/toast/toast.agent.d.ts +4 -0
  316. package/dist/components/toast/toast.d.ts +8 -0
  317. package/dist/components/tooth-scheme/index.js +1 -1
  318. package/dist/components/tooth-scheme/tooth-scheme.d.ts +2 -0
  319. package/dist/components/transcript-panel/index.d.ts +2 -1
  320. package/dist/components/transcript-panel/index.js +3 -2
  321. package/dist/components/transcript-panel/transcript-panel.agent.d.ts +4 -0
  322. package/dist/components/transcript-panel/transcript-panel.d.ts +10 -1
  323. package/dist/components/workflow/index.d.ts +2 -1
  324. package/dist/components/workflow/index.js +10 -7
  325. package/dist/components/workflow/workflow-editor.d.ts +7 -1
  326. package/dist/components/workflow/workflow-map.d.ts +2 -0
  327. package/dist/components/workflow/workflow.agent.d.ts +6 -0
  328. package/dist/i18n/config.js +24 -11
  329. package/dist/i18n/resources.d.ts +7 -0
  330. package/dist/index.js +471 -423
  331. package/dist/locales/en.json +7 -0
  332. package/dist/patterns/leo-assistant/index.js +1 -1
  333. package/dist/patterns/patient-shell/index.js +1 -1
  334. package/dist/tokens.css +1 -1
  335. package/package.json +18 -2
  336. package/dist/_chunks/accordion-B6fyINUk.js.map +0 -1
  337. package/dist/_chunks/accordion.agent-Cz-yglRa.js +0 -17
  338. package/dist/_chunks/accordion.agent-Cz-yglRa.js.map +0 -1
  339. package/dist/_chunks/agenda-card-DIWDvWum.js.map +0 -1
  340. package/dist/_chunks/agenda-tray-BqQZwiHc.js +0 -120
  341. package/dist/_chunks/agenda-tray-BqQZwiHc.js.map +0 -1
  342. package/dist/_chunks/ai-prompt-input-CI27KmZ1.js +0 -380
  343. package/dist/_chunks/ai-prompt-input-CI27KmZ1.js.map +0 -1
  344. package/dist/_chunks/alert-BlOUMkXj.js.map +0 -1
  345. package/dist/_chunks/apexcharts-theme-BkSShpEy.js.map +0 -1
  346. package/dist/_chunks/app-frame-6d7Lu4ea.js.map +0 -1
  347. package/dist/_chunks/aspect-ratio-CxsdG8vk.js.map +0 -1
  348. package/dist/_chunks/audio-recorder-B-8SKgKn.js +0 -376
  349. package/dist/_chunks/audio-recorder-B-8SKgKn.js.map +0 -1
  350. package/dist/_chunks/audio-visualiser-CeMPCZkd.js.map +0 -1
  351. package/dist/_chunks/autocomplete.agent-DqOy0_1P.js +0 -372
  352. package/dist/_chunks/autocomplete.agent-DqOy0_1P.js.map +0 -1
  353. package/dist/_chunks/avatar-Dcr6XuDQ.js.map +0 -1
  354. package/dist/_chunks/badge-mrstWxve.js.map +0 -1
  355. package/dist/_chunks/balance-cell-renderer-BWm3knY9.js.map +0 -1
  356. package/dist/_chunks/breadcrumb-D6xpsP7n.js +0 -293
  357. package/dist/_chunks/breadcrumb-D6xpsP7n.js.map +0 -1
  358. package/dist/_chunks/button-7mLWcMp_.js.map +0 -1
  359. package/dist/_chunks/button-group-CONver7M.js.map +0 -1
  360. package/dist/_chunks/button.agent-BuGZBktn.js.map +0 -1
  361. package/dist/_chunks/calendar-nGEgelJs.js.map +0 -1
  362. package/dist/_chunks/card-BEy58ZKp.js.map +0 -1
  363. package/dist/_chunks/chart.agent-BdS-_8MO.js.map +0 -1
  364. package/dist/_chunks/chat-container-Cm3SlR2p.js.map +0 -1
  365. package/dist/_chunks/chat-container.agent-Dhw9xCJt.js.map +0 -1
  366. package/dist/_chunks/chat-input-DreOPP8A.js.map +0 -1
  367. package/dist/_chunks/chat-message-ByouZpPP.js.map +0 -1
  368. package/dist/_chunks/check-DPdL_Sm7.js.map +0 -1
  369. package/dist/_chunks/checkbox-DNK4qS2_.js +0 -116
  370. package/dist/_chunks/checkbox-DNK4qS2_.js.map +0 -1
  371. package/dist/_chunks/checkbox-group-CWpGZEF6.js +0 -146
  372. package/dist/_chunks/checkbox-group-CWpGZEF6.js.map +0 -1
  373. package/dist/_chunks/chevron-down-BX_NP2Yh.js.map +0 -1
  374. package/dist/_chunks/chevron-left-CX1jqD2M.js.map +0 -1
  375. package/dist/_chunks/chevron-right-BrpYejk0.js.map +0 -1
  376. package/dist/_chunks/chevron-up-zOEDrmBB.js.map +0 -1
  377. package/dist/_chunks/chevrons-right-d9MwesPG.js.map +0 -1
  378. package/dist/_chunks/circle-BkqTgYmt.js.map +0 -1
  379. package/dist/_chunks/circle-alert-ChA9opNA.js.map +0 -1
  380. package/dist/_chunks/circle-check-9AeSgJD_.js.map +0 -1
  381. package/dist/_chunks/circle-x-Du2CmjaU.js.map +0 -1
  382. package/dist/_chunks/clock-21AGPWJ5.js.map +0 -1
  383. package/dist/_chunks/collapsible-D4LOdLxp.js +0 -67
  384. package/dist/_chunks/collapsible-D4LOdLxp.js.map +0 -1
  385. package/dist/_chunks/color-picker-e9PmpaGH.js.map +0 -1
  386. package/dist/_chunks/combobox.agent-ByobCLJ_.js +0 -350
  387. package/dist/_chunks/combobox.agent-ByobCLJ_.js.map +0 -1
  388. package/dist/_chunks/command-palette.agent-js2rxgeR.js.map +0 -1
  389. package/dist/_chunks/compose-refs-C0k0tdqF.js.map +0 -1
  390. package/dist/_chunks/copy-B00HK7tj.js.map +0 -1
  391. package/dist/_chunks/createLucideIcon-CrFbzy84.js.map +0 -1
  392. package/dist/_chunks/date-picker-DYXNsWmM.js +0 -1726
  393. package/dist/_chunks/date-picker-DYXNsWmM.js.map +0 -1
  394. package/dist/_chunks/date-range-picker-BcNDJI7m.js +0 -183
  395. package/dist/_chunks/date-range-picker-BcNDJI7m.js.map +0 -1
  396. package/dist/_chunks/date-time-picker-CmGiTU__.js +0 -202
  397. package/dist/_chunks/date-time-picker-CmGiTU__.js.map +0 -1
  398. package/dist/_chunks/description-list-DvJbp6Yg.js.map +0 -1
  399. package/dist/_chunks/dialog.agent-DEG_fVzG.js +0 -147
  400. package/dist/_chunks/dialog.agent-DEG_fVzG.js.map +0 -1
  401. package/dist/_chunks/dropdown-menu-Cw3EyPZv.js.map +0 -1
  402. package/dist/_chunks/dropdown-menu.agent-Cry4Nmes.js +0 -17
  403. package/dist/_chunks/dropdown-menu.agent-Cry4Nmes.js.map +0 -1
  404. package/dist/_chunks/ellipsis-rgGdiK_9.js.map +0 -1
  405. package/dist/_chunks/empty-state-DQPtRp2b.js.map +0 -1
  406. package/dist/_chunks/eye-off-xEXDAh5z.js.map +0 -1
  407. package/dist/_chunks/file-text-DSNuv2B8.js.map +0 -1
  408. package/dist/_chunks/file-upload.agent-B9AN82LA.js.map +0 -1
  409. package/dist/_chunks/flag-DZ6V7-hU.js.map +0 -1
  410. package/dist/_chunks/floating-action-button-Cnw-f6AG.js.map +0 -1
  411. package/dist/_chunks/form-field-BfsPLTSc.js.map +0 -1
  412. package/dist/_chunks/form-field-context-94LwgYTQ.js.map +0 -1
  413. package/dist/_chunks/freemium-paywall-CkefGLM_.js +0 -198
  414. package/dist/_chunks/freemium-paywall-CkefGLM_.js.map +0 -1
  415. package/dist/_chunks/globe-BkEFMNSg.js.map +0 -1
  416. package/dist/_chunks/group-options-BvKhQ3xb.js.map +0 -1
  417. package/dist/_chunks/header-BGn1mRp8.js.map +0 -1
  418. package/dist/_chunks/icon-button-Wnnde5lc.js.map +0 -1
  419. package/dist/_chunks/icon-button-group-DeV3FpNY.js.map +0 -1
  420. package/dist/_chunks/index-4xgbg-sn.js.map +0 -1
  421. package/dist/_chunks/index-CJE9uQmb.js.map +0 -1
  422. package/dist/_chunks/index-CeY1nNvd.js.map +0 -1
  423. package/dist/_chunks/index-D2ZczOXr.js.map +0 -1
  424. package/dist/_chunks/info-B9XNKn05.js.map +0 -1
  425. package/dist/_chunks/input-surface-u4QB0lxe.js.map +0 -1
  426. package/dist/_chunks/isSameDay-ecuM8PBB.js.map +0 -1
  427. package/dist/_chunks/isSameMonth-5wNF2f4I.js.map +0 -1
  428. package/dist/_chunks/kbd-8baVw3KU.js.map +0 -1
  429. package/dist/_chunks/key-value-pair-JRFS9Xrh.js.map +0 -1
  430. package/dist/_chunks/leo-sidebar-nbHib2D-.js.map +0 -1
  431. package/dist/_chunks/list-B1ozIjQe.js +0 -359
  432. package/dist/_chunks/list-B1ozIjQe.js.map +0 -1
  433. package/dist/_chunks/live-region-C41SO3cA.js.map +0 -1
  434. package/dist/_chunks/log-out-616hnn2-.js.map +0 -1
  435. package/dist/_chunks/logo-BpFoCL-s.js.map +0 -1
  436. package/dist/_chunks/mail-C8irm52s.js.map +0 -1
  437. package/dist/_chunks/matrix-rain-BEkvux64.js.map +0 -1
  438. package/dist/_chunks/message-card-qAp2-WQK.js.map +0 -1
  439. package/dist/_chunks/message-tray-VaLpQU5t.js +0 -303
  440. package/dist/_chunks/message-tray-VaLpQU5t.js.map +0 -1
  441. package/dist/_chunks/multi-select.agent-CNsyW3n9.js.map +0 -1
  442. package/dist/_chunks/navigation-menu-EVFau1O2.js +0 -180
  443. package/dist/_chunks/navigation-menu-EVFau1O2.js.map +0 -1
  444. package/dist/_chunks/normalize-diacritics-BNGbFNlJ.js.map +0 -1
  445. package/dist/_chunks/notification-card-BF2_veHy.js.map +0 -1
  446. package/dist/_chunks/notification-tray-B7U5YZYg.js +0 -328
  447. package/dist/_chunks/notification-tray-B7U5YZYg.js.map +0 -1
  448. package/dist/_chunks/number-input-DjpT_RXJ.js +0 -249
  449. package/dist/_chunks/number-input-DjpT_RXJ.js.map +0 -1
  450. package/dist/_chunks/otp-input-De5_Ih7B.js +0 -189
  451. package/dist/_chunks/otp-input-De5_Ih7B.js.map +0 -1
  452. package/dist/_chunks/pagination.agent-oEaqmtx5.js +0 -380
  453. package/dist/_chunks/pagination.agent-oEaqmtx5.js.map +0 -1
  454. package/dist/_chunks/password-input-DJDVznWH.js +0 -193
  455. package/dist/_chunks/password-input-DJDVznWH.js.map +0 -1
  456. package/dist/_chunks/patient-shell-7cXqIMFg.js.map +0 -1
  457. package/dist/_chunks/payment-form-hcl-gGrp.js.map +0 -1
  458. package/dist/_chunks/payment-form.agent-BkEnRerR.js.map +0 -1
  459. package/dist/_chunks/pdf-viewer.agent-CfIHhcHx.js.map +0 -1
  460. package/dist/_chunks/phone-input-DE_39q65.js +0 -428
  461. package/dist/_chunks/phone-input-DE_39q65.js.map +0 -1
  462. package/dist/_chunks/plus-CYKNmfuA.js.map +0 -1
  463. package/dist/_chunks/popover-C3CTUsqh.js +0 -227
  464. package/dist/_chunks/popover-C3CTUsqh.js.map +0 -1
  465. package/dist/_chunks/popover.agent-C0qOx9WT.js +0 -13
  466. package/dist/_chunks/popover.agent-C0qOx9WT.js.map +0 -1
  467. package/dist/_chunks/printer-CeVEWfQq.js.map +0 -1
  468. package/dist/_chunks/privacy-lock-CQpgkLec.js +0 -132
  469. package/dist/_chunks/privacy-lock-CQpgkLec.js.map +0 -1
  470. package/dist/_chunks/progress-B4Of_pzz.js +0 -252
  471. package/dist/_chunks/progress-B4Of_pzz.js.map +0 -1
  472. package/dist/_chunks/progress.agent-CXkHURjX.js +0 -22
  473. package/dist/_chunks/progress.agent-CXkHURjX.js.map +0 -1
  474. package/dist/_chunks/purify.es-DpIUMBYC.js.map +0 -1
  475. package/dist/_chunks/radio-cs8N1wJi.js.map +0 -1
  476. package/dist/_chunks/radio-group-BIUbpWml.js +0 -89
  477. package/dist/_chunks/radio-group-BIUbpWml.js.map +0 -1
  478. package/dist/_chunks/react-day-picker-C04L_28V.js.map +0 -1
  479. package/dist/_chunks/registry-C9nwlNyL.js.map +0 -1
  480. package/dist/_chunks/resizable.agent-DBpPGNdy.js +0 -435
  481. package/dist/_chunks/resizable.agent-DBpPGNdy.js.map +0 -1
  482. package/dist/_chunks/rich-text-editor.agent-COSb5_2D.js.map +0 -1
  483. package/dist/_chunks/safe-image-src-DstKgCo7.js.map +0 -1
  484. package/dist/_chunks/scroll-area-DLr5w9Dd.js.map +0 -1
  485. package/dist/_chunks/search-BonnQsHv.js.map +0 -1
  486. package/dist/_chunks/search-bar-fcGqDFW3.js +0 -397
  487. package/dist/_chunks/search-bar-fcGqDFW3.js.map +0 -1
  488. package/dist/_chunks/search-input-BVMCONyN.js +0 -197
  489. package/dist/_chunks/search-input-BVMCONyN.js.map +0 -1
  490. package/dist/_chunks/select-IY_JQa-F.js +0 -321
  491. package/dist/_chunks/select-IY_JQa-F.js.map +0 -1
  492. package/dist/_chunks/send-CySZIRPJ.js.map +0 -1
  493. package/dist/_chunks/separator-B4wXDLNC.js.map +0 -1
  494. package/dist/_chunks/sheet-BhNpLHc9.js.map +0 -1
  495. package/dist/_chunks/sheet.agent-DwQlBqK9.js +0 -13
  496. package/dist/_chunks/sheet.agent-DwQlBqK9.js.map +0 -1
  497. package/dist/_chunks/sidebar-OVzwN3jE.js.map +0 -1
  498. package/dist/_chunks/sidebar.agent-B0fnH9CC.js +0 -17
  499. package/dist/_chunks/sidebar.agent-B0fnH9CC.js.map +0 -1
  500. package/dist/_chunks/sign-in-with-alfadocs-button-BN_FPGHT.js.map +0 -1
  501. package/dist/_chunks/signature-capture.agent-C38VPXxg.js.map +0 -1
  502. package/dist/_chunks/skeleton-dtqyF09N.js.map +0 -1
  503. package/dist/_chunks/skip-link-DmZ3c6cb.js.map +0 -1
  504. package/dist/_chunks/slider-DjyRt3Mp.js +0 -274
  505. package/dist/_chunks/slider-DjyRt3Mp.js.map +0 -1
  506. package/dist/_chunks/slot-grid-D_l5VsHG.js.map +0 -1
  507. package/dist/_chunks/sparkline.agent-C_xp3NRB.js +0 -238
  508. package/dist/_chunks/sparkline.agent-C_xp3NRB.js.map +0 -1
  509. package/dist/_chunks/spinner-GCcv67vh.js.map +0 -1
  510. package/dist/_chunks/square-CZoGU14v.js.map +0 -1
  511. package/dist/_chunks/square-check-big-Jr-0202D.js.map +0 -1
  512. package/dist/_chunks/stat-DUB6g90R.js.map +0 -1
  513. package/dist/_chunks/stepper-C-sIpRRU.js.map +0 -1
  514. package/dist/_chunks/stepper-accordion-CGog0JSF.js +0 -233
  515. package/dist/_chunks/stepper-accordion-CGog0JSF.js.map +0 -1
  516. package/dist/_chunks/stepper-calendar-_fLOAjus.js +0 -570
  517. package/dist/_chunks/stepper-calendar-_fLOAjus.js.map +0 -1
  518. package/dist/_chunks/stepper-progress-rE7tn7WY.js +0 -129
  519. package/dist/_chunks/stepper-progress-rE7tn7WY.js.map +0 -1
  520. package/dist/_chunks/streaming-text-BgjCTVOw.js.map +0 -1
  521. package/dist/_chunks/suggestion-chip-BNJ2M8Os.js +0 -158
  522. package/dist/_chunks/suggestion-chip-BNJ2M8Os.js.map +0 -1
  523. package/dist/_chunks/switch-aN2EYxHh.js +0 -138
  524. package/dist/_chunks/switch-aN2EYxHh.js.map +0 -1
  525. package/dist/_chunks/tabs.agent-BpbVA-Zh.js.map +0 -1
  526. package/dist/_chunks/tag-BqidXKo3.js.map +0 -1
  527. package/dist/_chunks/task-card-yW7tKlG4.js.map +0 -1
  528. package/dist/_chunks/task-tray-BzahI5FQ.js +0 -100
  529. package/dist/_chunks/task-tray-BzahI5FQ.js.map +0 -1
  530. package/dist/_chunks/text-area-DmKSd2DG.js +0 -152
  531. package/dist/_chunks/text-area-DmKSd2DG.js.map +0 -1
  532. package/dist/_chunks/text-input-CRHvl5zk.js +0 -188
  533. package/dist/_chunks/text-input-CRHvl5zk.js.map +0 -1
  534. package/dist/_chunks/theme-root-DDb0TJjd.js.map +0 -1
  535. package/dist/_chunks/theme-toggle-BHiMMEQN.js +0 -329
  536. package/dist/_chunks/theme-toggle-BHiMMEQN.js.map +0 -1
  537. package/dist/_chunks/time-picker-D-EueWUG.js +0 -322
  538. package/dist/_chunks/time-picker-D-EueWUG.js.map +0 -1
  539. package/dist/_chunks/timeline-RgAIzpMd.js +0 -220
  540. package/dist/_chunks/timeline-RgAIzpMd.js.map +0 -1
  541. package/dist/_chunks/timestamp-BV2lC-wV.js.map +0 -1
  542. package/dist/_chunks/toast-lOhJDKOH.js.map +0 -1
  543. package/dist/_chunks/tooltip-DHik5yRI.js.map +0 -1
  544. package/dist/_chunks/tooth-scheme.agent-BlDyu-Gx.js.map +0 -1
  545. package/dist/_chunks/transcript-panel-CNbVGG9L.js +0 -266
  546. package/dist/_chunks/transcript-panel-CNbVGG9L.js.map +0 -1
  547. package/dist/_chunks/triangle-alert-CBPUIzQo.js.map +0 -1
  548. package/dist/_chunks/typing-indicator-CbUBf-Dx.js.map +0 -1
  549. package/dist/_chunks/use-debounced-callback-BisrB-Fq.js.map +0 -1
  550. package/dist/_chunks/use-direction-D6rvvG9G.js.map +0 -1
  551. package/dist/_chunks/use-locale-BuXR_Zl9.js.map +0 -1
  552. package/dist/_chunks/use-prefers-reduced-motion-BMwIQRjB.js.map +0 -1
  553. package/dist/_chunks/use-theme-BMUhembX.js.map +0 -1
  554. package/dist/_chunks/user-CPxpqFjJ.js.map +0 -1
  555. package/dist/_chunks/visually-hidden-Bw7vBHLm.js.map +0 -1
  556. package/dist/_chunks/warning-stack-8Pa3pekh.js.map +0 -1
  557. package/dist/_chunks/workflow-map-XeqHDFvp.js.map +0 -1
  558. package/dist/_chunks/x-CCcI3eJp.js.map +0 -1
  559. package/dist/agent/index.d.ts.map +0 -1
  560. package/dist/agent/registry.d.ts.map +0 -1
  561. package/dist/agent/types.d.ts.map +0 -1
  562. package/dist/brand/logo-asset/Alfadocs_Logo_BW.d.ts.map +0 -1
  563. package/dist/brand/logo-asset/Alfadocs_Logo_Main.d.ts.map +0 -1
  564. package/dist/brand/logo-asset/Alfadocs_Logo_Mark.d.ts.map +0 -1
  565. package/dist/brand/logo-asset/Alfadocs_Logo_Neg.d.ts.map +0 -1
  566. package/dist/brand/logo-asset/Alfadocs_Logo_Purple.d.ts.map +0 -1
  567. package/dist/brand/logo-asset/index.d.ts.map +0 -1
  568. package/dist/components/_shared/calendar-chevron.d.ts.map +0 -1
  569. package/dist/components/_shared/compose-refs.d.ts.map +0 -1
  570. package/dist/components/_shared/date-locale.d.ts.map +0 -1
  571. package/dist/components/_shared/date-picker-variants.d.ts.map +0 -1
  572. package/dist/components/_shared/date-utils.d.ts.map +0 -1
  573. package/dist/components/_shared/group-options.d.ts.map +0 -1
  574. package/dist/components/_shared/index.d.ts.map +0 -1
  575. package/dist/components/_shared/input-surface.d.ts.map +0 -1
  576. package/dist/components/_shared/normalize-diacritics.d.ts.map +0 -1
  577. package/dist/components/_shared/option.d.ts.map +0 -1
  578. package/dist/components/_shared/safe-html.d.ts.map +0 -1
  579. package/dist/components/_shared/safe-image-src.d.ts.map +0 -1
  580. package/dist/components/_shared/stepper.d.ts.map +0 -1
  581. package/dist/components/_shared/time.d.ts.map +0 -1
  582. package/dist/components/_shared/use-debounced-callback.d.ts.map +0 -1
  583. package/dist/components/_shared/use-direction.d.ts.map +0 -1
  584. package/dist/components/_shared/use-focus-trap.d.ts.map +0 -1
  585. package/dist/components/_shared/use-neutralize-hidden-focus.d.ts.map +0 -1
  586. package/dist/components/accordion/accordion.agent.d.ts.map +0 -1
  587. package/dist/components/accordion/accordion.d.ts.map +0 -1
  588. package/dist/components/accordion/index.d.ts.map +0 -1
  589. package/dist/components/accordion/index.js.map +0 -1
  590. package/dist/components/agenda-card/agenda-card.d.ts.map +0 -1
  591. package/dist/components/agenda-card/index.d.ts.map +0 -1
  592. package/dist/components/agenda-card/index.js.map +0 -1
  593. package/dist/components/agenda-tray/agenda-tray.d.ts.map +0 -1
  594. package/dist/components/agenda-tray/index.d.ts.map +0 -1
  595. package/dist/components/agenda-tray/index.js.map +0 -1
  596. package/dist/components/ai-prompt-input/ai-prompt-input.d.ts.map +0 -1
  597. package/dist/components/ai-prompt-input/index.d.ts.map +0 -1
  598. package/dist/components/ai-prompt-input/index.js.map +0 -1
  599. package/dist/components/alert/alert.d.ts.map +0 -1
  600. package/dist/components/alert/index.d.ts.map +0 -1
  601. package/dist/components/alert/index.js.map +0 -1
  602. package/dist/components/app-frame/app-frame.d.ts.map +0 -1
  603. package/dist/components/app-frame/index.d.ts.map +0 -1
  604. package/dist/components/app-frame/index.js.map +0 -1
  605. package/dist/components/aspect-ratio/aspect-ratio.d.ts.map +0 -1
  606. package/dist/components/aspect-ratio/index.d.ts.map +0 -1
  607. package/dist/components/aspect-ratio/index.js.map +0 -1
  608. package/dist/components/audio-recorder/audio-recorder.d.ts.map +0 -1
  609. package/dist/components/audio-recorder/index.d.ts.map +0 -1
  610. package/dist/components/audio-recorder/index.js.map +0 -1
  611. package/dist/components/audio-visualiser/audio-visualiser.d.ts.map +0 -1
  612. package/dist/components/audio-visualiser/index.d.ts.map +0 -1
  613. package/dist/components/audio-visualiser/index.js.map +0 -1
  614. package/dist/components/autocomplete/autocomplete.agent.d.ts.map +0 -1
  615. package/dist/components/autocomplete/autocomplete.d.ts.map +0 -1
  616. package/dist/components/autocomplete/index.d.ts.map +0 -1
  617. package/dist/components/autocomplete/index.js.map +0 -1
  618. package/dist/components/avatar/avatar.d.ts.map +0 -1
  619. package/dist/components/avatar/index.d.ts.map +0 -1
  620. package/dist/components/avatar/index.js.map +0 -1
  621. package/dist/components/badge/badge.d.ts.map +0 -1
  622. package/dist/components/badge/index.d.ts.map +0 -1
  623. package/dist/components/badge/index.js.map +0 -1
  624. package/dist/components/breadcrumb/breadcrumb.d.ts.map +0 -1
  625. package/dist/components/breadcrumb/index.d.ts.map +0 -1
  626. package/dist/components/breadcrumb/index.js.map +0 -1
  627. package/dist/components/button/button.agent.d.ts.map +0 -1
  628. package/dist/components/button/button.d.ts.map +0 -1
  629. package/dist/components/button/icon-button.d.ts.map +0 -1
  630. package/dist/components/button/index.d.ts.map +0 -1
  631. package/dist/components/button/index.js.map +0 -1
  632. package/dist/components/button-group/button-group.d.ts.map +0 -1
  633. package/dist/components/button-group/index.d.ts.map +0 -1
  634. package/dist/components/button-group/index.js.map +0 -1
  635. package/dist/components/calendar/calendar.agent.d.ts.map +0 -1
  636. package/dist/components/calendar/calendar.d.ts.map +0 -1
  637. package/dist/components/calendar/contrast-warning.d.ts.map +0 -1
  638. package/dist/components/calendar/index.d.ts.map +0 -1
  639. package/dist/components/calendar/index.js.map +0 -1
  640. package/dist/components/card/card.d.ts.map +0 -1
  641. package/dist/components/card/index.d.ts.map +0 -1
  642. package/dist/components/card/index.js.map +0 -1
  643. package/dist/components/chart/chart.agent.d.ts.map +0 -1
  644. package/dist/components/chart/chart.d.ts.map +0 -1
  645. package/dist/components/chart/index.d.ts.map +0 -1
  646. package/dist/components/chart/index.js.map +0 -1
  647. package/dist/components/chat-container/chat-container.agent.d.ts.map +0 -1
  648. package/dist/components/chat-container/chat-container.d.ts.map +0 -1
  649. package/dist/components/chat-container/index.d.ts.map +0 -1
  650. package/dist/components/chat-container/index.js.map +0 -1
  651. package/dist/components/chat-input/chat-input.d.ts.map +0 -1
  652. package/dist/components/chat-input/index.d.ts.map +0 -1
  653. package/dist/components/chat-input/index.js.map +0 -1
  654. package/dist/components/chat-message/chat-message.d.ts.map +0 -1
  655. package/dist/components/chat-message/index.d.ts.map +0 -1
  656. package/dist/components/chat-message/index.js.map +0 -1
  657. package/dist/components/checkbox/checkbox-group-context.d.ts.map +0 -1
  658. package/dist/components/checkbox/checkbox.d.ts.map +0 -1
  659. package/dist/components/checkbox/index.d.ts.map +0 -1
  660. package/dist/components/checkbox/index.js.map +0 -1
  661. package/dist/components/checkbox-group/checkbox-group.d.ts.map +0 -1
  662. package/dist/components/checkbox-group/index.d.ts.map +0 -1
  663. package/dist/components/checkbox-group/index.js.map +0 -1
  664. package/dist/components/collapsible/collapsible.d.ts.map +0 -1
  665. package/dist/components/collapsible/index.d.ts.map +0 -1
  666. package/dist/components/collapsible/index.js.map +0 -1
  667. package/dist/components/color-picker/color-picker.d.ts.map +0 -1
  668. package/dist/components/color-picker/color-utils.d.ts.map +0 -1
  669. package/dist/components/color-picker/index.d.ts.map +0 -1
  670. package/dist/components/color-picker/index.js.map +0 -1
  671. package/dist/components/color-picker/palettes.d.ts.map +0 -1
  672. package/dist/components/combobox/combobox.agent.d.ts.map +0 -1
  673. package/dist/components/combobox/combobox.d.ts.map +0 -1
  674. package/dist/components/combobox/index.d.ts.map +0 -1
  675. package/dist/components/combobox/index.js.map +0 -1
  676. package/dist/components/command-palette/command-palette.agent.d.ts.map +0 -1
  677. package/dist/components/command-palette/command-palette.d.ts.map +0 -1
  678. package/dist/components/command-palette/index.d.ts.map +0 -1
  679. package/dist/components/command-palette/index.js.map +0 -1
  680. package/dist/components/data-table/cell-renderers/actions-cell-renderer.d.ts.map +0 -1
  681. package/dist/components/data-table/cell-renderers/balance-cell-renderer.d.ts.map +0 -1
  682. package/dist/components/data-table/cell-renderers/color-dot-cell-renderer.d.ts.map +0 -1
  683. package/dist/components/data-table/cell-renderers/currency-cell-renderer.d.ts.map +0 -1
  684. package/dist/components/data-table/cell-renderers/date-cell-renderer.d.ts.map +0 -1
  685. package/dist/components/data-table/cell-renderers/link-cell-renderer.d.ts.map +0 -1
  686. package/dist/components/data-table/cell-renderers/status-cell-renderer.d.ts.map +0 -1
  687. package/dist/components/data-table/cell-renderers/tag-list-cell-renderer.d.ts.map +0 -1
  688. package/dist/components/data-table/cell-renderers/toggle-cell-renderer.d.ts.map +0 -1
  689. package/dist/components/data-table/cell-renderers/user-cell-renderer.d.ts.map +0 -1
  690. package/dist/components/data-table/data-table.agent.d.ts.map +0 -1
  691. package/dist/components/data-table/data-table.d.ts.map +0 -1
  692. package/dist/components/data-table/hooks/use-total-row.d.ts.map +0 -1
  693. package/dist/components/data-table/index.d.ts.map +0 -1
  694. package/dist/components/data-table/index.js.map +0 -1
  695. package/dist/components/data-table/toolbar.d.ts.map +0 -1
  696. package/dist/components/date-picker/date-picker.d.ts.map +0 -1
  697. package/dist/components/date-picker/index.d.ts.map +0 -1
  698. package/dist/components/date-picker/index.js.map +0 -1
  699. package/dist/components/date-range-picker/date-range-picker.d.ts.map +0 -1
  700. package/dist/components/date-range-picker/index.d.ts.map +0 -1
  701. package/dist/components/date-range-picker/index.js.map +0 -1
  702. package/dist/components/date-time-picker/date-time-picker.d.ts.map +0 -1
  703. package/dist/components/date-time-picker/index.d.ts.map +0 -1
  704. package/dist/components/date-time-picker/index.js.map +0 -1
  705. package/dist/components/description-list/description-list.d.ts.map +0 -1
  706. package/dist/components/description-list/index.d.ts.map +0 -1
  707. package/dist/components/description-list/index.js.map +0 -1
  708. package/dist/components/dialog/dialog.agent.d.ts.map +0 -1
  709. package/dist/components/dialog/dialog.d.ts.map +0 -1
  710. package/dist/components/dialog/index.d.ts.map +0 -1
  711. package/dist/components/dialog/index.js.map +0 -1
  712. package/dist/components/dropdown-menu/dropdown-menu.agent.d.ts.map +0 -1
  713. package/dist/components/dropdown-menu/dropdown-menu.d.ts.map +0 -1
  714. package/dist/components/dropdown-menu/index.d.ts.map +0 -1
  715. package/dist/components/dropdown-menu/index.js.map +0 -1
  716. package/dist/components/empty-state/empty-state.d.ts.map +0 -1
  717. package/dist/components/empty-state/index.d.ts.map +0 -1
  718. package/dist/components/empty-state/index.js.map +0 -1
  719. package/dist/components/file-upload/file-upload.agent.d.ts.map +0 -1
  720. package/dist/components/file-upload/file-upload.d.ts.map +0 -1
  721. package/dist/components/file-upload/index.d.ts.map +0 -1
  722. package/dist/components/file-upload/index.js.map +0 -1
  723. package/dist/components/flag/flag.d.ts.map +0 -1
  724. package/dist/components/flag/index.d.ts.map +0 -1
  725. package/dist/components/flag/index.js.map +0 -1
  726. package/dist/components/floating-action-button/floating-action-button.d.ts.map +0 -1
  727. package/dist/components/floating-action-button/index.d.ts.map +0 -1
  728. package/dist/components/floating-action-button/index.js.map +0 -1
  729. package/dist/components/form-field/form-field-context.d.ts.map +0 -1
  730. package/dist/components/form-field/form-field.d.ts.map +0 -1
  731. package/dist/components/form-field/index.d.ts.map +0 -1
  732. package/dist/components/form-field/index.js.map +0 -1
  733. package/dist/components/freemium-paywall/freemium-paywall.d.ts.map +0 -1
  734. package/dist/components/freemium-paywall/index.d.ts.map +0 -1
  735. package/dist/components/freemium-paywall/index.js.map +0 -1
  736. package/dist/components/header/header.d.ts.map +0 -1
  737. package/dist/components/header/index.d.ts.map +0 -1
  738. package/dist/components/header/index.js.map +0 -1
  739. package/dist/components/icon-button/index.d.ts.map +0 -1
  740. package/dist/components/icon-button/index.js.map +0 -1
  741. package/dist/components/icon-button-group/icon-button-group.d.ts.map +0 -1
  742. package/dist/components/icon-button-group/index.d.ts.map +0 -1
  743. package/dist/components/icon-button-group/index.js.map +0 -1
  744. package/dist/components/index.d.ts.map +0 -1
  745. package/dist/components/kbd/index.d.ts.map +0 -1
  746. package/dist/components/kbd/index.js.map +0 -1
  747. package/dist/components/kbd/kbd.d.ts.map +0 -1
  748. package/dist/components/key-value-pair/index.d.ts.map +0 -1
  749. package/dist/components/key-value-pair/index.js.map +0 -1
  750. package/dist/components/key-value-pair/key-value-pair.d.ts.map +0 -1
  751. package/dist/components/list/index.d.ts.map +0 -1
  752. package/dist/components/list/index.js.map +0 -1
  753. package/dist/components/list/list.d.ts.map +0 -1
  754. package/dist/components/live-region/index.d.ts.map +0 -1
  755. package/dist/components/live-region/index.js.map +0 -1
  756. package/dist/components/live-region/live-region.d.ts.map +0 -1
  757. package/dist/components/logo/index.d.ts.map +0 -1
  758. package/dist/components/logo/index.js.map +0 -1
  759. package/dist/components/logo/logo.d.ts.map +0 -1
  760. package/dist/components/matrix-rain/index.d.ts.map +0 -1
  761. package/dist/components/matrix-rain/index.js.map +0 -1
  762. package/dist/components/matrix-rain/matrix-rain.d.ts.map +0 -1
  763. package/dist/components/message-card/index.d.ts.map +0 -1
  764. package/dist/components/message-card/index.js.map +0 -1
  765. package/dist/components/message-card/message-card.d.ts.map +0 -1
  766. package/dist/components/message-tray/index.d.ts.map +0 -1
  767. package/dist/components/message-tray/index.js.map +0 -1
  768. package/dist/components/message-tray/message-tray.d.ts.map +0 -1
  769. package/dist/components/multi-select/index.d.ts.map +0 -1
  770. package/dist/components/multi-select/index.js.map +0 -1
  771. package/dist/components/multi-select/multi-select.agent.d.ts.map +0 -1
  772. package/dist/components/multi-select/multi-select.d.ts.map +0 -1
  773. package/dist/components/navigation-menu/index.d.ts.map +0 -1
  774. package/dist/components/navigation-menu/index.js.map +0 -1
  775. package/dist/components/navigation-menu/navigation-menu.d.ts.map +0 -1
  776. package/dist/components/notification-card/index.d.ts.map +0 -1
  777. package/dist/components/notification-card/index.js.map +0 -1
  778. package/dist/components/notification-card/notification-card.d.ts.map +0 -1
  779. package/dist/components/notification-tray/index.d.ts.map +0 -1
  780. package/dist/components/notification-tray/index.js.map +0 -1
  781. package/dist/components/notification-tray/notification-tray.d.ts.map +0 -1
  782. package/dist/components/number-input/index.d.ts.map +0 -1
  783. package/dist/components/number-input/index.js.map +0 -1
  784. package/dist/components/number-input/number-input.d.ts.map +0 -1
  785. package/dist/components/number-input/use-locale-number.d.ts.map +0 -1
  786. package/dist/components/otp-input/index.d.ts.map +0 -1
  787. package/dist/components/otp-input/index.js.map +0 -1
  788. package/dist/components/otp-input/otp-input.d.ts.map +0 -1
  789. package/dist/components/pagination/index.d.ts.map +0 -1
  790. package/dist/components/pagination/index.js.map +0 -1
  791. package/dist/components/pagination/pagination.agent.d.ts.map +0 -1
  792. package/dist/components/pagination/pagination.d.ts.map +0 -1
  793. package/dist/components/password-input/index.d.ts.map +0 -1
  794. package/dist/components/password-input/index.js.map +0 -1
  795. package/dist/components/password-input/password-input.d.ts.map +0 -1
  796. package/dist/components/payment-form/index.d.ts.map +0 -1
  797. package/dist/components/payment-form/index.js.map +0 -1
  798. package/dist/components/payment-form/payment-form.agent.d.ts.map +0 -1
  799. package/dist/components/payment-form/payment-form.d.ts.map +0 -1
  800. package/dist/components/pdf-viewer/index.d.ts.map +0 -1
  801. package/dist/components/pdf-viewer/index.js.map +0 -1
  802. package/dist/components/pdf-viewer/pdf-viewer.agent.d.ts.map +0 -1
  803. package/dist/components/pdf-viewer/pdf-viewer.d.ts.map +0 -1
  804. package/dist/components/phone-input/index.d.ts.map +0 -1
  805. package/dist/components/phone-input/index.js.map +0 -1
  806. package/dist/components/phone-input/phone-input.d.ts.map +0 -1
  807. package/dist/components/popover/index.d.ts.map +0 -1
  808. package/dist/components/popover/index.js.map +0 -1
  809. package/dist/components/popover/popover.agent.d.ts.map +0 -1
  810. package/dist/components/popover/popover.d.ts.map +0 -1
  811. package/dist/components/privacy-lock/index.d.ts.map +0 -1
  812. package/dist/components/privacy-lock/index.js.map +0 -1
  813. package/dist/components/privacy-lock/privacy-lock.d.ts.map +0 -1
  814. package/dist/components/progress/index.d.ts.map +0 -1
  815. package/dist/components/progress/index.js.map +0 -1
  816. package/dist/components/progress/progress.agent.d.ts.map +0 -1
  817. package/dist/components/progress/progress.d.ts.map +0 -1
  818. package/dist/components/radio/index.d.ts.map +0 -1
  819. package/dist/components/radio/index.js.map +0 -1
  820. package/dist/components/radio-group/index.d.ts.map +0 -1
  821. package/dist/components/radio-group/index.js.map +0 -1
  822. package/dist/components/radio-group/radio-group-context.d.ts.map +0 -1
  823. package/dist/components/radio-group/radio-group.d.ts.map +0 -1
  824. package/dist/components/radio-group/radio.d.ts.map +0 -1
  825. package/dist/components/resizable/index.d.ts.map +0 -1
  826. package/dist/components/resizable/index.js.map +0 -1
  827. package/dist/components/resizable/resizable-context.d.ts.map +0 -1
  828. package/dist/components/resizable/resizable.agent.d.ts.map +0 -1
  829. package/dist/components/resizable/resizable.d.ts.map +0 -1
  830. package/dist/components/rich-text-editor/index.d.ts.map +0 -1
  831. package/dist/components/rich-text-editor/index.js.map +0 -1
  832. package/dist/components/rich-text-editor/rich-text-editor.agent.d.ts.map +0 -1
  833. package/dist/components/rich-text-editor/rich-text-editor.d.ts.map +0 -1
  834. package/dist/components/scroll-area/index.d.ts.map +0 -1
  835. package/dist/components/scroll-area/index.js.map +0 -1
  836. package/dist/components/scroll-area/scroll-area.d.ts.map +0 -1
  837. package/dist/components/search-bar/index.d.ts.map +0 -1
  838. package/dist/components/search-bar/index.js.map +0 -1
  839. package/dist/components/search-bar/search-bar.d.ts.map +0 -1
  840. package/dist/components/search-input/index.d.ts.map +0 -1
  841. package/dist/components/search-input/index.js.map +0 -1
  842. package/dist/components/search-input/search-input.d.ts.map +0 -1
  843. package/dist/components/select/index.d.ts.map +0 -1
  844. package/dist/components/select/index.js.map +0 -1
  845. package/dist/components/select/select.d.ts.map +0 -1
  846. package/dist/components/separator/index.d.ts.map +0 -1
  847. package/dist/components/separator/index.js.map +0 -1
  848. package/dist/components/separator/separator.d.ts.map +0 -1
  849. package/dist/components/sheet/index.d.ts.map +0 -1
  850. package/dist/components/sheet/index.js.map +0 -1
  851. package/dist/components/sheet/sheet.agent.d.ts.map +0 -1
  852. package/dist/components/sheet/sheet.d.ts.map +0 -1
  853. package/dist/components/sidebar/index.d.ts.map +0 -1
  854. package/dist/components/sidebar/index.js.map +0 -1
  855. package/dist/components/sidebar/sidebar.agent.d.ts.map +0 -1
  856. package/dist/components/sidebar/sidebar.d.ts.map +0 -1
  857. package/dist/components/sign-in-with-alfadocs-button/index.d.ts.map +0 -1
  858. package/dist/components/sign-in-with-alfadocs-button/index.js.map +0 -1
  859. package/dist/components/sign-in-with-alfadocs-button/sign-in-with-alfadocs-button.d.ts.map +0 -1
  860. package/dist/components/signature-capture/index.d.ts.map +0 -1
  861. package/dist/components/signature-capture/index.js.map +0 -1
  862. package/dist/components/signature-capture/signature-capture.agent.d.ts.map +0 -1
  863. package/dist/components/signature-capture/signature-capture.d.ts.map +0 -1
  864. package/dist/components/skeleton/index.d.ts.map +0 -1
  865. package/dist/components/skeleton/index.js.map +0 -1
  866. package/dist/components/skeleton/skeleton.d.ts.map +0 -1
  867. package/dist/components/skip-link/index.d.ts.map +0 -1
  868. package/dist/components/skip-link/index.js.map +0 -1
  869. package/dist/components/skip-link/skip-link.d.ts.map +0 -1
  870. package/dist/components/slider/index.d.ts.map +0 -1
  871. package/dist/components/slider/index.js.map +0 -1
  872. package/dist/components/slider/slider.d.ts.map +0 -1
  873. package/dist/components/slot-grid/index.d.ts.map +0 -1
  874. package/dist/components/slot-grid/index.js.map +0 -1
  875. package/dist/components/slot-grid/slot-grid.d.ts.map +0 -1
  876. package/dist/components/sparkline/index.d.ts.map +0 -1
  877. package/dist/components/sparkline/index.js.map +0 -1
  878. package/dist/components/sparkline/sparkline.agent.d.ts.map +0 -1
  879. package/dist/components/sparkline/sparkline.d.ts.map +0 -1
  880. package/dist/components/sparkline/use-linear-trend.d.ts.map +0 -1
  881. package/dist/components/spinner/index.d.ts.map +0 -1
  882. package/dist/components/spinner/index.js.map +0 -1
  883. package/dist/components/spinner/spinner.d.ts.map +0 -1
  884. package/dist/components/stat/index.d.ts.map +0 -1
  885. package/dist/components/stat/index.js.map +0 -1
  886. package/dist/components/stat/stat.d.ts.map +0 -1
  887. package/dist/components/stepper-accordion/index.d.ts.map +0 -1
  888. package/dist/components/stepper-accordion/index.js.map +0 -1
  889. package/dist/components/stepper-accordion/stepper-accordion.d.ts.map +0 -1
  890. package/dist/components/stepper-calendar/index.d.ts.map +0 -1
  891. package/dist/components/stepper-calendar/index.js.map +0 -1
  892. package/dist/components/stepper-calendar/stepper-calendar.d.ts.map +0 -1
  893. package/dist/components/stepper-progress/index.d.ts.map +0 -1
  894. package/dist/components/stepper-progress/index.js.map +0 -1
  895. package/dist/components/stepper-progress/stepper-progress.d.ts.map +0 -1
  896. package/dist/components/streaming-text/index.d.ts.map +0 -1
  897. package/dist/components/streaming-text/index.js.map +0 -1
  898. package/dist/components/streaming-text/streaming-text.d.ts.map +0 -1
  899. package/dist/components/suggestion-chip/index.d.ts.map +0 -1
  900. package/dist/components/suggestion-chip/index.js.map +0 -1
  901. package/dist/components/suggestion-chip/suggestion-chip.d.ts.map +0 -1
  902. package/dist/components/switch/index.d.ts.map +0 -1
  903. package/dist/components/switch/index.js.map +0 -1
  904. package/dist/components/switch/switch.d.ts.map +0 -1
  905. package/dist/components/tabs/index.d.ts.map +0 -1
  906. package/dist/components/tabs/index.js.map +0 -1
  907. package/dist/components/tabs/tabs.agent.d.ts.map +0 -1
  908. package/dist/components/tabs/tabs.d.ts.map +0 -1
  909. package/dist/components/tag/index.d.ts.map +0 -1
  910. package/dist/components/tag/index.js.map +0 -1
  911. package/dist/components/tag/tag.d.ts.map +0 -1
  912. package/dist/components/task-card/index.d.ts.map +0 -1
  913. package/dist/components/task-card/index.js.map +0 -1
  914. package/dist/components/task-card/task-card.d.ts.map +0 -1
  915. package/dist/components/task-tray/index.d.ts.map +0 -1
  916. package/dist/components/task-tray/index.js.map +0 -1
  917. package/dist/components/task-tray/task-tray.d.ts.map +0 -1
  918. package/dist/components/text-area/index.d.ts.map +0 -1
  919. package/dist/components/text-area/index.js.map +0 -1
  920. package/dist/components/text-area/text-area.d.ts.map +0 -1
  921. package/dist/components/text-input/index.d.ts.map +0 -1
  922. package/dist/components/text-input/index.js.map +0 -1
  923. package/dist/components/text-input/text-input.d.ts.map +0 -1
  924. package/dist/components/theme-root/index.d.ts.map +0 -1
  925. package/dist/components/theme-root/index.js.map +0 -1
  926. package/dist/components/theme-root/theme-root.d.ts.map +0 -1
  927. package/dist/components/theme-toggle/index.d.ts.map +0 -1
  928. package/dist/components/theme-toggle/index.js.map +0 -1
  929. package/dist/components/theme-toggle/theme-toggle.d.ts.map +0 -1
  930. package/dist/components/time-picker/index.d.ts.map +0 -1
  931. package/dist/components/time-picker/index.js.map +0 -1
  932. package/dist/components/time-picker/time-picker.d.ts.map +0 -1
  933. package/dist/components/timeline/index.d.ts.map +0 -1
  934. package/dist/components/timeline/index.js.map +0 -1
  935. package/dist/components/timeline/timeline.d.ts.map +0 -1
  936. package/dist/components/timestamp/index.d.ts.map +0 -1
  937. package/dist/components/timestamp/index.js.map +0 -1
  938. package/dist/components/timestamp/timestamp.d.ts.map +0 -1
  939. package/dist/components/toast/index.d.ts.map +0 -1
  940. package/dist/components/toast/index.js.map +0 -1
  941. package/dist/components/toast/toast.d.ts.map +0 -1
  942. package/dist/components/tooltip/index.d.ts.map +0 -1
  943. package/dist/components/tooltip/index.js.map +0 -1
  944. package/dist/components/tooltip/tooltip.d.ts.map +0 -1
  945. package/dist/components/tooth-scheme/index.d.ts.map +0 -1
  946. package/dist/components/tooth-scheme/index.js.map +0 -1
  947. package/dist/components/tooth-scheme/tooth-data.d.ts.map +0 -1
  948. package/dist/components/tooth-scheme/tooth-scheme.agent.d.ts.map +0 -1
  949. package/dist/components/tooth-scheme/tooth-scheme.d.ts.map +0 -1
  950. package/dist/components/transcript-panel/index.d.ts.map +0 -1
  951. package/dist/components/transcript-panel/index.js.map +0 -1
  952. package/dist/components/transcript-panel/transcript-panel.d.ts.map +0 -1
  953. package/dist/components/typing-indicator/index.d.ts.map +0 -1
  954. package/dist/components/typing-indicator/index.js.map +0 -1
  955. package/dist/components/typing-indicator/typing-indicator.d.ts.map +0 -1
  956. package/dist/components/visually-hidden/index.d.ts.map +0 -1
  957. package/dist/components/visually-hidden/index.js.map +0 -1
  958. package/dist/components/visually-hidden/visually-hidden.d.ts.map +0 -1
  959. package/dist/components/warning-stack/index.d.ts.map +0 -1
  960. package/dist/components/warning-stack/index.js.map +0 -1
  961. package/dist/components/warning-stack/warning-stack.d.ts.map +0 -1
  962. package/dist/components/workflow/index.d.ts.map +0 -1
  963. package/dist/components/workflow/index.js.map +0 -1
  964. package/dist/components/workflow/workflow-card.d.ts.map +0 -1
  965. package/dist/components/workflow/workflow-editor.d.ts.map +0 -1
  966. package/dist/components/workflow/workflow-map.d.ts.map +0 -1
  967. package/dist/components/workflow/workflow-types.d.ts.map +0 -1
  968. package/dist/hooks/index.d.ts.map +0 -1
  969. package/dist/hooks/index.js.map +0 -1
  970. package/dist/hooks/use-locale.d.ts.map +0 -1
  971. package/dist/hooks/use-media-query.d.ts.map +0 -1
  972. package/dist/hooks/use-prefers-reduced-motion.d.ts.map +0 -1
  973. package/dist/hooks/use-theme.d.ts.map +0 -1
  974. package/dist/i18n/config.d.ts.map +0 -1
  975. package/dist/i18n/config.js.map +0 -1
  976. package/dist/i18n/resources.d.ts.map +0 -1
  977. package/dist/index.js.map +0 -1
  978. package/dist/option/index.js.map +0 -1
  979. package/dist/patterns/leo-assistant/index.d.ts.map +0 -1
  980. package/dist/patterns/leo-assistant/index.js.map +0 -1
  981. package/dist/patterns/leo-assistant/leo-chat-surface.d.ts.map +0 -1
  982. package/dist/patterns/leo-assistant/leo-embedded.d.ts.map +0 -1
  983. package/dist/patterns/leo-assistant/leo-popout.d.ts.map +0 -1
  984. package/dist/patterns/leo-assistant/leo-sidebar.d.ts.map +0 -1
  985. package/dist/patterns/leo-assistant/leo-types.d.ts.map +0 -1
  986. package/dist/patterns/patient-shell/index.d.ts.map +0 -1
  987. package/dist/patterns/patient-shell/index.js.map +0 -1
  988. package/dist/patterns/patient-shell/patient-shell.d.ts.map +0 -1
  989. package/dist/safe-html/index.js.map +0 -1
  990. package/dist/tokens/apexcharts-theme.d.ts.map +0 -1
  991. package/dist/tokens/themes/bridges/stripe-appearance.d.ts.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"button-group-CONver7M.js","sources":["../../src/components/button-group/button-group.tsx"],"sourcesContent":["import {\n Children,\n cloneElement,\n forwardRef,\n isValidElement,\n useCallback,\n useLayoutEffect,\n useRef,\n useState,\n type HTMLAttributes,\n type KeyboardEvent as ReactKeyboardEvent,\n type ReactElement,\n} from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport type { ButtonProps } from '../button/button';\n\ntype ButtonIntent = NonNullable<ButtonProps['intent']>;\n\nconst buttonGroupVariants = cva(\n 'ds:inline-flex ds:isolate ds:[&>*]:relative ds:[&>*:focus-visible]:z-10',\n {\n variants: {\n orientation: {\n horizontal: [\n 'ds:flex-row',\n 'ds:[&>*:not(:first-child)]:rounded-s-none',\n 'ds:[&>*:not(:last-child)]:rounded-e-none',\n 'ds:[&>*:not(:first-child)]:-ms-px',\n ].join(' '),\n vertical: [\n 'ds:flex-col',\n 'ds:[&>*:not(:first-child)]:rounded-t-none',\n 'ds:[&>*:not(:last-child)]:rounded-b-none',\n 'ds:[&>*:not(:first-child)]:-mt-px',\n ].join(' '),\n },\n separator: {\n true: '',\n false: '',\n },\n },\n compoundVariants: [\n {\n orientation: 'horizontal',\n separator: true,\n class:\n 'ds:[&>*:not(:last-child)]:border-e ds:[&>*:not(:last-child)]:border-border',\n },\n {\n orientation: 'vertical',\n separator: true,\n class:\n 'ds:[&>*:not(:last-child)]:border-b ds:[&>*:not(:last-child)]:border-border',\n },\n ],\n defaultVariants: {\n orientation: 'horizontal',\n separator: false,\n },\n },\n);\n\nexport interface ButtonGroupProps\n extends HTMLAttributes<HTMLDivElement>,\n VariantProps<typeof buttonGroupVariants> {\n /**\n * Accessible label for the group. Falls back to the translated\n * `ui.buttonGroup.label` string when not provided.\n */\n label?: string;\n /**\n * When the children are interactive toolbar-style controls (e.g. toggles),\n * set this to render `role=\"toolbar\"` instead of `role=\"group\"`.\n */\n toolbar?: boolean;\n /**\n * Intent applied to every Button / IconButton child that does not set\n * its own `intent`. Defaults to `outline` — grouped buttons are peers,\n * not three solid-primary CTAs.\n */\n intent?: ButtonIntent;\n}\n\nexport const ButtonGroup = forwardRef<HTMLDivElement, ButtonGroupProps>(\n (\n {\n className,\n orientation = 'horizontal',\n separator = false,\n toolbar = false,\n intent = 'outline',\n label,\n children,\n ...props\n },\n ref,\n ) => {\n const { t } = useTranslation();\n const accessibleLabel = label ?? t('ui.buttonGroup.label', 'Button group');\n\n // Roving tabindex — required by the WAI-ARIA toolbar pattern.\n // When `toolbar` is true, one child owns `tabIndex=0` and the rest are\n // `-1`. Arrow keys / Home / End move focus between children, respecting\n // orientation and RTL. Plain `group` mode keeps every child natively\n // tabbable.\n const rovingTabindex = toolbar;\n const buttonsRef = useRef<Array<HTMLButtonElement | null>>([]);\n const [focusIndex, setFocusIndex] = useState(0);\n\n const rootRef = useRef<HTMLDivElement | null>(null);\n const [isRTL, setIsRTL] = useState(false);\n useLayoutEffect(() => {\n if (typeof window === 'undefined') return;\n const node = rootRef.current;\n if (!node) return;\n setIsRTL(window.getComputedStyle(node).direction === 'rtl');\n }, []);\n\n const handleRootKeyDown = useCallback(\n (event: ReactKeyboardEvent<HTMLDivElement>) => {\n if (!rovingTabindex) return;\n const count = buttonsRef.current.filter(Boolean).length;\n if (count === 0) return;\n\n const forwardKey =\n orientation === 'vertical'\n ? 'ArrowDown'\n : isRTL\n ? 'ArrowLeft'\n : 'ArrowRight';\n const backwardKey =\n orientation === 'vertical'\n ? 'ArrowUp'\n : isRTL\n ? 'ArrowRight'\n : 'ArrowLeft';\n\n let next: number | null = null;\n if (event.key === forwardKey) next = (focusIndex + 1) % count;\n else if (event.key === backwardKey)\n next = (focusIndex - 1 + count) % count;\n else if (event.key === 'Home') next = 0;\n else if (event.key === 'End') next = count - 1;\n if (next === null) return;\n\n // Skip over disabled children.\n const maxAttempts = count;\n let attempts = 0;\n let candidate = next;\n while (attempts < maxAttempts) {\n const el = buttonsRef.current[candidate];\n if (el && el.getAttribute('aria-disabled') !== 'true' && !el.disabled) {\n break;\n }\n candidate =\n event.key === backwardKey || event.key === 'End'\n ? (candidate - 1 + count) % count\n : (candidate + 1) % count;\n attempts += 1;\n }\n event.preventDefault();\n setFocusIndex(candidate);\n buttonsRef.current[candidate]?.focus();\n },\n [rovingTabindex, orientation, isRTL, focusIndex],\n );\n\n const enhanced = Children.map(children, (child, index) => {\n if (!isValidElement(child)) return child;\n const childEl = child as ReactElement<{\n intent?: ButtonIntent;\n tabIndex?: number;\n onFocus?: React.FocusEventHandler<HTMLButtonElement>;\n ref?: React.Ref<HTMLButtonElement>;\n }>;\n\n const setMergedRef = (node: HTMLButtonElement | null) => {\n buttonsRef.current[index] = node;\n const originalRef = (\n childEl as unknown as { ref?: React.Ref<HTMLButtonElement> }\n ).ref;\n if (typeof originalRef === 'function') originalRef(node);\n else if (\n originalRef !== null &&\n originalRef !== undefined &&\n typeof originalRef === 'object'\n ) {\n (\n originalRef as React.MutableRefObject<HTMLButtonElement | null>\n ).current = node;\n }\n };\n\n const overrides = {\n intent: childEl.props.intent ?? intent,\n tabIndex: rovingTabindex\n ? index === focusIndex\n ? 0\n : -1\n : childEl.props.tabIndex,\n onFocus: (ev: React.FocusEvent<HTMLButtonElement>) => {\n if (rovingTabindex) setFocusIndex(index);\n childEl.props.onFocus?.(ev);\n },\n ref: setMergedRef,\n } as unknown as Partial<{ intent?: ButtonIntent }>;\n\n return cloneElement(childEl, overrides);\n });\n\n const mergedRootRef = (node: HTMLDivElement | null) => {\n rootRef.current = node;\n if (typeof ref === 'function') ref(node);\n else if (ref && typeof ref === 'object') {\n (ref as React.MutableRefObject<HTMLDivElement | null>).current = node;\n }\n };\n\n return (\n <div\n ref={mergedRootRef}\n role={toolbar ? 'toolbar' : 'group'}\n aria-label={accessibleLabel}\n aria-orientation={toolbar ? (orientation ?? 'horizontal') : undefined}\n data-component=\"button-group\"\n onKeyDown={handleRootKeyDown}\n className={buttonGroupVariants({ orientation, separator, className })}\n {...props}\n >\n {enhanced}\n </div>\n );\n },\n);\n\nButtonGroup.displayName = 'ButtonGroup';\n"],"names":["buttonGroupVariants","cva","ButtonGroup","forwardRef","className","orientation","separator","toolbar","intent","label","children","props","ref","t","useTranslation","accessibleLabel","rovingTabindex","buttonsRef","useRef","focusIndex","setFocusIndex","useState","rootRef","isRTL","setIsRTL","useLayoutEffect","node","handleRootKeyDown","useCallback","event","count","forwardKey","backwardKey","next","maxAttempts","attempts","candidate","el","_a","enhanced","Children","child","index","isValidElement","childEl","setMergedRef","originalRef","overrides","ev","_b","cloneElement","jsx"],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"button.agent-BuGZBktn.js","sources":["../../src/components/button/button.agent.ts"],"sourcesContent":["/* -------------------------------------------------------------------- */\n/* Agent adapter — Button. */\n/* */\n/* Button is stateless and context-dependent: a button used to submit a */\n/* form has safety `write`; one used to navigate has safety `read`; one */\n/* used to delete has safety `destructive`. The kit cannot decide that */\n/* in advance, so this adapter declares NO actions and NO state — it */\n/* exists solely to register the canonical `data-component=\"button\"` DOM */\n/* hook in the build catalog. */\n/* */\n/* Pattern adapters that compose Button declare the workflow's safety, */\n/* not the button itself. */\n/* -------------------------------------------------------------------- */\n\nimport type { AgentAdapter } from '../../agent/types';\n\nexport const buttonAgent: AgentAdapter = {\n id: 'button',\n capabilities: [],\n state: {},\n actions: {},\n domHooks: {\n root: {\n attr: 'data-component',\n value: 'button',\n description: 'Marks the element as a kit Button. Safety is declared by the host pattern, not the button. Buttons inherit native `id` from props, which is what agents address them by.',\n },\n },\n};\n"],"names":["buttonAgent"],"mappings":"AAgBO,MAAMA,IAA4B;AAAA,EACvC,IAAI;AAAA,EACJ,cAAc,CAAA;AAAA,EACd,OAAO,CAAA;AAAA,EACP,SAAS,CAAA;AAAA,EACT,UAAU;AAAA,IACR,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,OAAO;AAAA,MACP,aAAa;AAAA,IAAA;AAAA,EACf;AAEJ;"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"calendar-nGEgelJs.js","sources":["../../node_modules/lucide-react/dist/esm/icons/ban.js","../../node_modules/lucide-react/dist/esm/icons/euro.js","../../node_modules/lucide-react/dist/esm/icons/heart-pulse.js","../../node_modules/lucide-react/dist/esm/icons/stethoscope.js","../../node_modules/lucide-react/dist/esm/icons/thumbs-up.js","../../node_modules/lucide-react/dist/esm/icons/video.js","../../node_modules/lucide-react/dist/esm/icons/zap.js","../../src/components/calendar/calendar.agent.ts","../../src/components/calendar/calendar.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 [\"circle\", { cx: \"12\", cy: \"12\", r: \"10\", key: \"1mglay\" }],\n [\"path\", { d: \"M4.929 4.929 19.07 19.071\", key: \"196cmz\" }]\n];\nconst Ban = createLucideIcon(\"ban\", __iconNode);\n\nexport { __iconNode, Ban as default };\n//# sourceMappingURL=ban.js.map\n","/**\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 [\"path\", { d: \"M4 10h12\", key: \"1y6xl8\" }],\n [\"path\", { d: \"M4 14h9\", key: \"1loblj\" }],\n [\n \"path\",\n {\n d: \"M19 6a7.7 7.7 0 0 0-5.2-2A7.9 7.9 0 0 0 6 12c0 4.4 3.5 8 7.8 8 2 0 3.8-.8 5.2-2\",\n key: \"1j6lzo\"\n }\n ]\n];\nconst Euro = createLucideIcon(\"euro\", __iconNode);\n\nexport { __iconNode, Euro as default };\n//# sourceMappingURL=euro.js.map\n","/**\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: \"M2 9.5a5.5 5.5 0 0 1 9.591-3.676.56.56 0 0 0 .818 0A5.49 5.49 0 0 1 22 9.5c0 2.29-1.5 4-3 5.5l-5.492 5.313a2 2 0 0 1-3 .019L5 15c-1.5-1.5-3-3.2-3-5.5\",\n key: \"mvr1a0\"\n }\n ],\n [\"path\", { d: \"M3.22 13H9.5l.5-1 2 4.5 2-7 1.5 3.5h5.27\", key: \"auskq0\" }]\n];\nconst HeartPulse = createLucideIcon(\"heart-pulse\", __iconNode);\n\nexport { __iconNode, HeartPulse as default };\n//# sourceMappingURL=heart-pulse.js.map\n","/**\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 [\"path\", { d: \"M11 2v2\", key: \"1539x4\" }],\n [\"path\", { d: \"M5 2v2\", key: \"1yf1q8\" }],\n [\"path\", { d: \"M5 3H4a2 2 0 0 0-2 2v4a6 6 0 0 0 12 0V5a2 2 0 0 0-2-2h-1\", key: \"rb5t3r\" }],\n [\"path\", { d: \"M8 15a6 6 0 0 0 12 0v-3\", key: \"x18d4x\" }],\n [\"circle\", { cx: \"20\", cy: \"10\", r: \"2\", key: \"ts1r5v\" }]\n];\nconst Stethoscope = createLucideIcon(\"stethoscope\", __iconNode);\n\nexport { __iconNode, Stethoscope as default };\n//# sourceMappingURL=stethoscope.js.map\n","/**\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: \"M15 5.88 14 10h5.83a2 2 0 0 1 1.92 2.56l-2.33 8A2 2 0 0 1 17.5 22H4a2 2 0 0 1-2-2v-8a2 2 0 0 1 2-2h2.76a2 2 0 0 0 1.79-1.11L12 2a3.13 3.13 0 0 1 3 3.88Z\",\n key: \"emmmcr\"\n }\n ],\n [\"path\", { d: \"M7 10v12\", key: \"1qc93n\" }]\n];\nconst ThumbsUp = createLucideIcon(\"thumbs-up\", __iconNode);\n\nexport { __iconNode, ThumbsUp as default };\n//# sourceMappingURL=thumbs-up.js.map\n","/**\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 13 5.223 3.482a.5.5 0 0 0 .777-.416V7.87a.5.5 0 0 0-.752-.432L16 10.5\",\n key: \"ftymec\"\n }\n ],\n [\"rect\", { x: \"2\", y: \"6\", width: \"14\", height: \"12\", rx: \"2\", key: \"158x01\" }]\n];\nconst Video = createLucideIcon(\"video\", __iconNode);\n\nexport { __iconNode, Video as default };\n//# sourceMappingURL=video.js.map\n","/**\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: \"M4 14a1 1 0 0 1-.78-1.63l9.9-10.2a.5.5 0 0 1 .86.46l-1.92 6.02A1 1 0 0 0 13 10h7a1 1 0 0 1 .78 1.63l-9.9 10.2a.5.5 0 0 1-.86-.46l1.92-6.02A1 1 0 0 0 11 14z\",\n key: \"1xq2db\"\n }\n ]\n];\nconst Zap = createLucideIcon(\"zap\", __iconNode);\n\nexport { __iconNode, Zap as default };\n//# sourceMappingURL=zap.js.map\n","/* -------------------------------------------------------------------- */\n/* Agent adapter — Calendar. */\n/* */\n/* Calendar's existing `CalendarHandle` is the canonical shape for an */\n/* agent-friendly third-party wrapper — see `26-agent-readiness.mdx` */\n/* §15. The handle methods translate directly into adapter actions. */\n/* -------------------------------------------------------------------- */\n\nimport type { AgentAdapter } from '../../agent/types';\nimport type { CalendarHandle, CalendarView } from './calendar';\n\nexport const calendarAgent: AgentAdapter<CalendarHandle> = {\n id: 'calendar',\n capabilities: ['view_change', 'range_navigate', 'pick'],\n state: {\n currentView: {\n type: 'CalendarView',\n descriptionKey: 'ui.agent.calendar.state.currentView',\n description: 'Active view name (e.g. dayGridMonth, timeGridWeek).',\n read: (handle) => handle.getCurrentView() ?? null,\n },\n currentDate: {\n type: 'iso-date',\n descriptionKey: 'ui.agent.calendar.state.currentDate',\n description: 'ISO date anchor of the visible range.',\n read: (handle) => handle.getCurrentDate()?.toISOString() ?? null,\n },\n currentTitle: {\n type: 'string',\n descriptionKey: 'ui.agent.calendar.state.currentTitle',\n description: 'Human title of the current range (e.g. \"April 2026\").',\n read: (handle) => handle.getTitle(),\n },\n },\n actions: {\n today: {\n safety: 'read',\n descriptionKey: 'ui.agent.calendar.actions.today',\n description: 'Jump to the current day.',\n invoke: (handle) => {\n handle.today();\n },\n },\n prev: {\n safety: 'read',\n descriptionKey: 'ui.agent.calendar.actions.prev',\n description: 'Move to the previous range.',\n invoke: (handle) => {\n handle.prev();\n },\n },\n next: {\n safety: 'read',\n descriptionKey: 'ui.agent.calendar.actions.next',\n description: 'Move to the next range.',\n invoke: (handle) => {\n handle.next();\n },\n },\n goto_date: {\n safety: 'read',\n argsType: '{ date: string | Date }',\n descriptionKey: 'ui.agent.calendar.actions.gotoDate',\n description: 'Navigate to a specific date.',\n invoke: (handle, args: { date: string | Date }) => {\n handle.gotoDate(args.date);\n },\n },\n change_view: {\n safety: 'read',\n argsType: '{ view: CalendarView }',\n descriptionKey: 'ui.agent.calendar.actions.changeView',\n description: 'Switch the calendar to the given view.',\n invoke: (handle, args: { view: CalendarView }) => {\n handle.changeView(args.view);\n },\n },\n focus_event: {\n safety: 'read',\n argsType: '{ eventId: string }',\n descriptionKey: 'ui.agent.calendar.actions.focusEvent',\n description: 'Scroll an event into view and briefly highlight it.',\n invoke: (handle, args: { eventId: string }) => {\n handle.focusEvent(args.eventId);\n },\n },\n },\n domHooks: {\n root: {\n attr: 'data-component',\n value: 'calendar',\n description: 'Marks the Calendar wrapper.',\n },\n instanceId: {\n attr: 'data-component-id',\n sourceProp: 'id',\n description: 'Sourced from the id prop.',\n },\n item: {\n attr: 'data-event-id',\n description: 'Emitted on every rendered FullCalendar event by the kit event renderer. Used by focusEvent.',\n },\n },\n};\n","/* ------------------------------------------------------------------ */\n/* Calendar — a thin, typed wrapper over FullCalendar. */\n/* */\n/* - Plugins are registered once internally so consumers never import */\n/* `@fullcalendar/core` / plugins directly (08-third-party §Calendar).*/\n/* - Chrome is styled entirely from `fullcalendar-theme.css` via the */\n/* `.fc-theme-alfadocs` root class — no inline styles anywhere. */\n/* - Locale, week-start, date formats, and direction all flow from the */\n/* active i18next language (06-i18n.mdx). */\n/* */\n/* TODO (deferred, per implementation plan): */\n/* - Virtualised resource timeline with @tanstack/react-virtual for */\n/* > 50 resources (performance user story). */\n/* - Protanopia screenshot stories (colour-blind story acceptance). */\n/* - Playwright performance trace for 1000 events / 50 resources. */\n/* ------------------------------------------------------------------ */\n\nimport {\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n type CSSProperties,\n type ReactElement,\n type ReactNode,\n} from 'react';\nimport { cva } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport FullCalendar from '@fullcalendar/react';\nimport dayGridPlugin from '@fullcalendar/daygrid';\nimport timeGridPlugin from '@fullcalendar/timegrid';\nimport listPlugin from '@fullcalendar/list';\nimport resourcePlugin from '@fullcalendar/resource';\nimport type { ResourceLabelContentArg } from '@fullcalendar/resource';\nimport resourceTimeGridPlugin from '@fullcalendar/resource-timegrid';\nimport resourceTimelinePlugin from '@fullcalendar/resource-timeline';\nimport timelinePlugin from '@fullcalendar/timeline';\nimport interactionPlugin from '@fullcalendar/interaction';\nimport type { EventResizeDoneArg } from '@fullcalendar/interaction';\nimport type {\n DatesSetArg,\n EventClickArg,\n EventContentArg,\n EventDropArg,\n DateSelectArg,\n EventInput,\n} from '@fullcalendar/core';\nimport {\n ThumbsUp,\n Clock,\n Stethoscope,\n Check,\n Ban,\n Zap,\n Globe,\n AlertTriangle,\n HeartPulse,\n Euro,\n Video,\n ChevronLeft,\n ChevronRight,\n type LucideIcon,\n} from 'lucide-react';\nimport '../../tokens/themes/bridges/fullcalendar-theme.css';\n\nimport { usePrefersReducedMotion } from '../../hooks';\nimport { useAgentRegistration } from '../../agent';\nimport { warnLowContrast } from './contrast-warning';\nimport { calendarAgent } from './calendar.agent';\n\n/* ------------------------------------------------------------------ */\n/* Public types */\n/* ------------------------------------------------------------------ */\n\nexport type CalendarView =\n // Standard views\n | 'dayGridMonth'\n | 'timeGridWeek'\n | 'timeGridDay'\n | 'listWeek'\n // Chair resource views\n | 'resourceTimeGridDayChair'\n | 'resourceTimeGridThreeDaysChair'\n | 'resourceTimeGridWeekChair'\n // Operator resource views\n | 'resourceTimeGridDayOperator'\n | 'resourceTimeGridThreeDaysOperator'\n | 'resourceTimeGridWeekOperator';\n\n/**\n * View-name mapping table — maps the DS public view name (with the\n * Chair/Operator semantic suffix stripped) onto the internal FullCalendar\n * view name for each `resourceLayout` orientation. The table is exported\n * via `resolveFullCalendarView`; invalid combinations are caught at\n * compile time because the `CalendarView` union is exhaustive.\n */\nconst RESOURCE_VIEW_MAP = {\n vertical: {\n Day: 'resourceTimeGridDay',\n ThreeDays: 'resourceTimeGridThreeDays',\n Week: 'resourceTimeGridWeek',\n },\n horizontal: {\n Day: 'resourceTimelineDay',\n ThreeDays: 'resourceTimelineThreeDays',\n Week: 'resourceTimelineWeek',\n },\n} as const satisfies Record<\n 'vertical' | 'horizontal',\n Record<'Day' | 'ThreeDays' | 'Week', string>\n>;\n\ntype ResourceViewStem = keyof (typeof RESOURCE_VIEW_MAP)['vertical'];\n\nconst STANDARD_VIEWS = new Set<CalendarView>([\n 'dayGridMonth',\n 'timeGridWeek',\n 'timeGridDay',\n 'listWeek',\n]);\n\n/**\n * Maps a public `CalendarView` name to the internal FullCalendar view\n * name. `resourceLayout` selects between `resourceTimeGrid*` (vertical)\n * and `resourceTimeline*` (horizontal) for the 6 resource views; the\n * 4 standard views are returned as-is.\n */\nexport function resolveFullCalendarView(\n view: CalendarView,\n resourceLayout: 'vertical' | 'horizontal' = 'vertical',\n): string {\n if (STANDARD_VIEWS.has(view)) {\n return view;\n }\n // Strip the trailing Chair / Operator suffix — the DS maps both to the\n // same internal FC view name. The suffix is semantic only.\n const withoutPrefix = view.replace(/^resourceTimeGrid/, '');\n const stem = withoutPrefix.replace(/(Chair|Operator)$/, '') as ResourceViewStem;\n return RESOURCE_VIEW_MAP[resourceLayout][stem];\n}\n\n/**\n * Registered custom FC view shapes — the two 3-day views are defined as\n * durations over the base `resourceTimeGrid` / `resourceTimeline` types.\n * Kept at module scope because the object is a compile-time constant.\n * Typed loosely to match FC's `ViewConfigInputHash` ( `[viewType: string]:\n * ViewConfigInput` ).\n */\nconst CALENDAR_CUSTOM_VIEWS: Record<\n string,\n { type: string; duration: { days: number } }\n> = {\n resourceTimeGridThreeDays: {\n type: 'resourceTimeGrid',\n duration: { days: 3 },\n },\n resourceTimelineThreeDays: {\n type: 'resourceTimeline',\n duration: { days: 3 },\n },\n};\n\nexport type CalendarEventStatus =\n | 'confirmed'\n | 'waiting'\n | 'in_care'\n | 'done'\n | 'cancelled'\n | 'absent';\n\nexport type CalendarMode = 'default' | 'create' | 'move' | 'copy';\n\nexport interface CalendarEvent {\n id: string;\n title: string;\n start: string | Date;\n end?: string | Date;\n resourceId?: string;\n allDay?: boolean;\n\n /* Appointment-specific (all optional) */\n status?: CalendarEventStatus;\n /** Hex colour from a DoctorColor palette — overrides CVA bg. */\n backgroundColor?: string;\n /** Hex colour from a DoctorColor palette — overrides CVA text. */\n textColor?: string;\n /** Extra description rendered after the title in normal weight. */\n suffix?: string;\n /** Masked title shown when `privacyMode` is true. */\n privacyModeTitle?: string;\n /** Shows a Globe icon + zebra overlay. */\n isBookedOnline?: boolean;\n /** Shows an AlertTriangle icon. */\n hasUnassignedPatient?: boolean;\n /** Shows a HeartPulse icon. */\n hasHighlightedAnamnesis?: boolean;\n /** Shows a Euro icon. */\n hasBillableAmount?: boolean;\n /** Shows a Video icon. */\n isTelehealth?: boolean;\n isRecurrenceParent?: boolean;\n /** Rendered as a background event; not clickable. */\n isInternal?: boolean;\n patientId?: string | number;\n operatorId?: string | number;\n}\n\nexport interface CalendarResource {\n id: string;\n title: string;\n /** Initials for the compact \"avatar\" label (e.g. \"MR\"). */\n shortTitle?: string;\n /** Hex background colour for the dot or initials circle. */\n color?: string;\n /** Hex text colour for the initials circle. */\n shortTitleTextColor?: string;\n /** Numeric ordering — passed to FullCalendar's `resourceOrder`. */\n sequenceNumber?: number;\n}\n\nexport interface CalendarEventDropInfo {\n event: CalendarEvent;\n oldStart: Date;\n newStart: Date;\n}\n\nexport interface CalendarEventResizeInfo {\n event: CalendarEvent;\n oldEnd: Date;\n newEnd: Date;\n}\n\nexport interface CalendarDateSelectInfo {\n start: Date;\n end: Date;\n allDay: boolean;\n resourceId?: string;\n}\n\nexport interface CalendarProps {\n /**\n * Stable identifier for this calendar instance. Used for the agent-readiness\n * `data-component-id` attribute and the agent registry. Required only when\n * the consuming app expects an MCP / agent integration to address this\n * specific calendar.\n */\n id?: string;\n /** Events to render on the calendar. */\n events: CalendarEvent[];\n /** Resources for `resourceTimeline` view. */\n resources?: CalendarResource[];\n /** Active view. */\n view?: CalendarView;\n /** Initial date (string or Date). */\n initialDate?: string | Date;\n /** Locale override — defaults to the active i18next language. */\n locale?: string;\n /** Fires when an event is dragged to a new slot. */\n onEventDrop?: (info: CalendarEventDropInfo) => void;\n /** Fires when an event is resized. */\n onEventResize?: (info: CalendarEventResizeInfo) => void;\n /** Fires when an event resize gesture begins. */\n onEventResizeStart?: () => void;\n /** Fires when an event is clicked. */\n onEventClick?: (event: CalendarEvent) => void;\n /** Fires when the user click-drags a range to create a new event. */\n onDateSelect?: (range: CalendarDateSelectInfo) => void;\n /** Allow drag-drop rescheduling. */\n editable?: boolean;\n /** Allow resize gestures on events. Defaults to `editable`. */\n eventDurationEditable?: boolean;\n /** Allow click-drag to create. */\n selectable?: boolean;\n /** Height of the calendar. */\n height?: number | string;\n /** Extra class names on the wrapper. */\n className?: string;\n /** Mask patient titles — announces state changes via aria-live. */\n privacyMode?: boolean;\n /** Interaction mode — renders a sticky banner when not `'default'`. */\n mode?: CalendarMode;\n /** Override text for the mode banner. */\n modeLabel?: string;\n /** Hex background colour for the mode banner (consuming-app supplied). */\n modeBannerColor?: string;\n /** Hex text colour for the mode banner. */\n modeBannerTextColor?: string;\n /** Cancel handler wired to the mode banner button. */\n onModeCancel?: () => void;\n /** Optional alert banner rendered above the mode banner. */\n alertBanner?: ReactNode;\n /** Lower bound of the time axis (e.g. '07:00'). */\n slotMinTime?: string;\n /** Upper bound of the time axis (e.g. '23:00'). */\n slotMaxTime?: string;\n /** Slot duration (e.g. '00:15'). */\n slotDuration?: string;\n /** When false, hides the inline time pill on events. */\n showTime?: boolean;\n /** Place date headers above the resource axis. */\n datesAboveResources?: boolean;\n /** Allow overlapping events in the same slot. */\n slotEventOverlap?: boolean;\n /** Keep date headers pinned during scroll. */\n stickyHeaderDates?: boolean;\n /** Show a now-indicator line on time-grid views. */\n nowIndicator?: boolean;\n /** Collapse overflow events into \"+N more\" links. */\n dayMaxEvents?: boolean | number;\n /**\n * FullCalendar Scheduler premium license key. Required for the\n * `resourceTimeline` view. Defaults to `VITE_FULLCALENDAR_LICENSE_KEY`\n * from the environment; consumers can override per-instance.\n */\n schedulerLicenseKey?: string;\n /**\n * Show the built-in toolbar. Default true. Pass false to hide it\n * entirely (e.g. when the consuming app renders its own\n * `<Calendar.Toolbar ... />` elsewhere on the page).\n */\n toolbar?: boolean;\n /**\n * Extra controls rendered at the inline-end of the default toolbar —\n * commonly a view switcher, a privacy toggle, or an \"add appointment\"\n * button. Ignored when `toolbar` is false.\n */\n toolbarEnd?: ReactNode;\n /**\n * Orientation for resource views. `vertical` (default) uses\n * `resourceTimeGrid` — resources as columns, time as rows.\n * `horizontal` uses `resourceTimeline` — resources as rows, time as columns.\n * Ignored for non-resource views.\n */\n resourceLayout?: 'vertical' | 'horizontal';\n /**\n * When true, render a round initials avatar (using\n * `resource.shortTitle` + `resource.color` + `resource.shortTitleTextColor`)\n * in the resource label. When false (default), a small coloured dot\n * prefixes the title when `resource.color` is set.\n */\n showResourceInitials?: boolean;\n}\n\nexport interface CalendarHandle {\n /** Returns the internal FullCalendar instance for advanced use. */\n getApi: () => unknown;\n /** Jump to today. */\n today: () => void;\n /** Navigate to the previous period. */\n prev: () => void;\n /** Navigate to the next period. */\n next: () => void;\n /** Navigate to an arbitrary date. */\n gotoDate: (date: Date | string) => void;\n /** Switch the active view. */\n changeView: (view: CalendarView) => void;\n /** Current view title (e.g. \"April 2026\") — reflects the FC API getter. */\n getTitle: () => string;\n /** Currently active view name. */\n getCurrentView: () => CalendarView | undefined;\n /** Currently focused date — the anchor of the visible range. */\n getCurrentDate: () => Date | undefined;\n /** Scroll to an event by id and briefly highlight it. */\n focusEvent: (eventId: string) => void;\n}\n\n/* Narrow structural interface for the subset of the FullCalendar API\n we actually invoke. Keeps the handle methods typed without pulling\n `@fullcalendar/core` types across the public boundary. */\ninterface FcApi {\n today: () => void;\n prev: () => void;\n next: () => void;\n gotoDate: (date: Date | string) => void;\n changeView: (view: string) => void;\n render: () => void;\n getDate: () => Date;\n view: { title: string; type: string };\n}\n\n/* ------------------------------------------------------------------ */\n/* CVA — status → event card classes */\n/* ------------------------------------------------------------------ */\n\nconst eventCardVariants = cva(\n [\n 'ds:flex ds:flex-col ds:gap-[var(--spacing-xs)]',\n 'ds:w-full ds:h-full',\n 'ds:ps-[var(--spacing-xs)] ds:pe-[var(--spacing-xs)]',\n 'ds:rounded-[var(--radius-sm)]',\n 'ds:text-[length:var(--font-size-sm)]',\n 'ds:font-[var(--font-weight-medium)]',\n 'ds:overflow-hidden',\n 'ds:focus-visible:outline-[length:var(--focus-ring-width)]',\n 'ds:focus-visible:outline-[var(--ring)]',\n 'ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]',\n ].join(' '),\n {\n variants: {\n status: {\n // Note: every text-[…] uses the explicit `color:` prefix so\n // Tailwind interprets it as a colour, not a length. Without the\n // prefix, `text-[var(--X)]` resolves to font-size and the text\n // colour falls through to the inherited `--foreground` — which\n // produced 2.07:1 axe failures on saturated backgrounds.\n confirmed:\n 'ds:bg-[color:var(--success)] ds:text-[color:var(--success-solid-foreground)] ds:border ds:border-[color:var(--success)]',\n waiting:\n 'ds:bg-[color:var(--info)] ds:text-[color:var(--info-solid-foreground)] ds:border ds:border-[color:var(--info)]',\n in_care:\n 'ds:bg-[color:var(--primary)] ds:text-[color:var(--primary-foreground)] ds:border ds:border-[color:var(--primary)]',\n // `done` reads as \"completed, fading out\". Previously\n // `bg-color-mix(--success 70%, transparent) text-success-solid-foreground`,\n // composited to ~#65a586 with white text → 2.88:1 fail.\n // Now uses a low-saturation tint background with dark\n // `--foreground` text + a left accent bar carrying the status\n // hue.\n done:\n 'ds:bg-[color:color-mix(in_srgb,var(--success)_18%,var(--background))] ds:text-[color:var(--foreground)] ds:border-s-[3px] ds:border-s-[color:var(--success)] ds:border-y ds:border-e ds:border-y-[color:color-mix(in_srgb,var(--success)_25%,var(--border))] ds:border-e-[color:color-mix(in_srgb,var(--success)_25%,var(--border))]',\n cancelled:\n 'ds:bg-[color:var(--destructive)] ds:text-[color:var(--destructive-foreground)] ds:border ds:border-[color:var(--destructive)] ds:line-through',\n absent:\n 'ds:bg-[color:var(--warning)] ds:text-[color:var(--warning-solid-foreground)] ds:border ds:border-[color:var(--warning)]',\n default:\n 'ds:bg-[color:var(--primary)] ds:text-[color:var(--primary-foreground)] ds:border ds:border-[color:var(--primary)]',\n },\n },\n defaultVariants: { status: 'default' },\n },\n);\n\nconst STATUS_ICON: Record<CalendarEventStatus, LucideIcon> = {\n confirmed: ThumbsUp,\n waiting: Clock,\n in_care: Stethoscope,\n done: Check,\n cancelled: Ban,\n absent: Zap,\n};\n\n/* Mode banner → i18n key lookup. Kept as a literal object (not a\n template) so static-analysis extractors can find every key. */\nconst MODE_BANNER_KEYS: Record<Exclude<CalendarMode, 'default'>, string> = {\n create: 'calendar.modeBanner.create',\n move: 'calendar.modeBanner.move',\n copy: 'calendar.modeBanner.copy',\n};\n\n/* ------------------------------------------------------------------ */\n/* Helpers */\n/* ------------------------------------------------------------------ */\n\ninterface LocaleWeekInfo {\n firstDay?: number;\n}\n\ninterface LocaleWithWeekInfo {\n getWeekInfo?: () => LocaleWeekInfo;\n weekInfo?: LocaleWeekInfo;\n}\n\n/**\n * Resolve the first day of the week for a locale using the modern\n * `Intl.Locale.getWeekInfo()` API when available, falling back to Monday\n * for EU-leaning locales and Sunday for en-US / he-IL / ar-SA.\n */\nexport function resolveFirstDay(locale: string): number {\n try {\n const intlLocale = new Intl.Locale(locale) as unknown as LocaleWithWeekInfo;\n const info =\n typeof intlLocale.getWeekInfo === 'function'\n ? intlLocale.getWeekInfo()\n : intlLocale.weekInfo;\n if (info && typeof info.firstDay === 'number') {\n return info.firstDay % 7;\n }\n } catch {\n /* no-op — fall through to heuristic */\n }\n if (\n locale.startsWith('en-US') ||\n locale.startsWith('he') ||\n locale.startsWith('ar-SA')\n ) {\n return 0;\n }\n return 1;\n}\n\n/**\n * Small hook that mirrors the parent Calendar's document-dir observer\n * so sub-components can swap physical icons for logical direction\n * without threading a prop through. Returns true when the effective\n * document direction is RTL.\n */\nfunction useIsRtl(): boolean {\n const { i18n } = useTranslation();\n const [isRtl, setIsRtl] = useState<boolean>(() => {\n if (typeof document === 'undefined') return false;\n const docDir = document.documentElement.getAttribute('dir');\n const i18nDir = typeof i18n.dir === 'function' ? i18n.dir() : 'ltr';\n return docDir === 'rtl' || i18nDir === 'rtl';\n });\n\n useEffect(() => {\n if (typeof document === 'undefined') return undefined;\n const observer = new MutationObserver(() => {\n const docDir = document.documentElement.getAttribute('dir');\n const i18nDir = typeof i18n.dir === 'function' ? i18n.dir() : 'ltr';\n setIsRtl(docDir === 'rtl' || i18nDir === 'rtl');\n });\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: ['dir', 'lang'],\n });\n return () => observer.disconnect();\n }, [i18n]);\n\n return isRtl;\n}\n\n/* ------------------------------------------------------------------ */\n/* Event content render-prop */\n/* */\n/* Renders the event card with: */\n/* - a status icon (aria-hidden) coloured by status token */\n/* - indicator icons (online, unassigned, anamnesis, billable, tele) */\n/* - a time range pill (when !allDay && showTime) */\n/* - the event title (bold, masked in privacy mode) */\n/* - an optional suffix (regular weight) */\n/* - an aria-label built from title + range + resource + status */\n/* ------------------------------------------------------------------ */\n\ninterface RenderEventContentParams {\n arg: EventContentArg;\n locale: string;\n resources: CalendarResource[];\n statusLabels: Record<CalendarEventStatus, string>;\n privacyMode: boolean;\n showTime: boolean;\n}\n\ntype EventExtendedProps = Omit<CalendarEvent, 'id' | 'title' | 'start' | 'end' | 'allDay'>;\n\nfunction renderEventContent({\n arg,\n locale,\n resources,\n statusLabels,\n privacyMode,\n showTime,\n}: RenderEventContentParams): ReactElement {\n const extended = (arg.event.extendedProps ?? {}) as EventExtendedProps;\n const {\n status,\n backgroundColor,\n textColor,\n suffix,\n privacyModeTitle,\n isBookedOnline,\n hasUnassignedPatient,\n hasHighlightedAnamnesis,\n hasBillableAmount,\n isTelehealth,\n resourceId,\n } = extended;\n\n const StatusIcon = status ? STATUS_ICON[status] : null;\n\n const start = arg.event.start;\n const end = arg.event.end ?? arg.event.start;\n const allDay = arg.event.allDay;\n\n let rangeText = '';\n if (start && end) {\n try {\n const fmt = new Intl.DateTimeFormat(locale, {\n hour: '2-digit',\n minute: '2-digit',\n hour12: false,\n });\n rangeText =\n typeof fmt.formatRange === 'function'\n ? fmt.formatRange(start, end)\n : `${fmt.format(start)} – ${fmt.format(end)}`;\n } catch {\n rangeText = '';\n }\n }\n\n const resourceTitle = resourceId\n ? resources.find((r) => r.id === resourceId)?.title\n : undefined;\n const statusLabel = status ? statusLabels[status] : undefined;\n\n const displayTitle = privacyMode\n ? (privacyModeTitle ?? '•••')\n : arg.event.title;\n\n const ariaLabel = [displayTitle, rangeText, resourceTitle, statusLabel]\n .filter(Boolean)\n .join(', ');\n\n /* Per-event colour override: the consuming app passes a runtime hex\n from a DoctorColor (Material-Design style) palette. 23-constraints\n permits inline `style` only as a CSS custom property setter for\n runtime values that can't be enumerated at build time — the\n consuming `background-color` / `color` references live in the\n className as Tailwind arbitrary values. */\n const colourOverrides: CSSProperties | undefined =\n backgroundColor || textColor\n ? {\n ...(backgroundColor\n ? ({ '--calendar-event-bg': backgroundColor } as CSSProperties)\n : {}),\n ...(textColor\n ? ({ '--calendar-event-text': textColor } as CSSProperties)\n : {}),\n }\n : undefined;\n\n /* DEV-only guardrail: warn when caller-supplied bg/fg hex pair falls\n below WCAG AA. No-op when either half is missing (fg missing falls\n back to the DS foreground token, which isn't a hex we can check). */\n if (backgroundColor || textColor) {\n warnLowContrast(backgroundColor, textColor, `event ${arg.event.id}`);\n }\n\n const className = [\n eventCardVariants({ status: status ?? 'default' }),\n isBookedOnline ? 'event-booked-online' : null,\n backgroundColor ? 'ds:[background-color:var(--calendar-event-bg)]' : null,\n textColor ? 'ds:[color:var(--calendar-event-text)]' : null,\n ]\n .filter(Boolean)\n .join(' ');\n\n return (\n <div\n className={className}\n style={colourOverrides}\n aria-label={ariaLabel}\n data-event-id={arg.event.id}\n >\n <div className=\"ds:flex ds:items-center ds:gap-[var(--spacing-xs)] ds:self-end\">\n {StatusIcon ? (\n <StatusIcon size={14} aria-hidden=\"true\" />\n ) : null}\n {isBookedOnline ? <Globe size={12} aria-hidden=\"true\" /> : null}\n {hasUnassignedPatient ? (\n <AlertTriangle size={12} aria-hidden=\"true\" />\n ) : null}\n {hasHighlightedAnamnesis ? (\n <HeartPulse size={12} aria-hidden=\"true\" />\n ) : null}\n {hasBillableAmount ? <Euro size={12} aria-hidden=\"true\" /> : null}\n {isTelehealth ? <Video size={12} aria-hidden=\"true\" /> : null}\n </div>\n {showTime && !allDay && rangeText ? (\n // No opacity here — composing 70% over saturated bgs (success /\n // destructive / primary) drops effective contrast below WCAG AA\n // (≤ 3.82:1 measured). The smaller font-size-xs vs the title's\n // font-weight-semibold provides sufficient visual hierarchy.\n <span className=\"ds:text-[length:var(--font-size-xs)]\">\n {rangeText}\n </span>\n ) : null}\n <span className=\"ds:font-[var(--font-weight-semibold)] ds:truncate ds:text-start\">\n {displayTitle}\n </span>\n {suffix ? (\n <span className=\"ds:truncate ds:text-start ds:text-[length:var(--font-size-xs)]\">\n {suffix}\n </span>\n ) : null}\n </div>\n );\n}\n\n/* ------------------------------------------------------------------ */\n/* CalendarToolbar — compound sub-component */\n/* */\n/* Renders the DS-styled prev/today/next controls + a centered <h2> */\n/* title (aria-live so navigation updates announce politely) plus an */\n/* optional inline-end slot. Logical properties only; physical icons */\n/* (ChevronLeft / ChevronRight) are swapped in RTL so the pair always */\n/* points in the expected reading direction. */\n/* ------------------------------------------------------------------ */\n\nexport interface CalendarToolbarProps {\n /** Title shown in the toolbar (e.g. \"April 2026\"). Typically\n * produced by `calendarHandle.getTitle()`. */\n title?: string;\n /** Jump to today. */\n onToday: () => void;\n /** Navigate to the previous period. */\n onPrev: () => void;\n /** Navigate to the next period. */\n onNext: () => void;\n /** Extra controls rendered at the inline-end. */\n end?: ReactNode;\n /** Additional className. */\n className?: string;\n}\n\nconst toolbarButtonBaseClass = [\n 'ds:inline-flex ds:items-center ds:justify-center',\n 'ds:min-h-[var(--min-target-size)]',\n 'ds:bg-[var(--background)] ds:text-[var(--foreground)]',\n 'ds:border ds:border-[var(--border)]',\n 'ds:rounded-[var(--radius-full)]',\n 'ds:font-[var(--font-weight-medium)] ds:text-[length:var(--font-size-sm)]',\n 'ds:transition-colors ds:duration-[var(--animation-duration)] ds:ease-[var(--ease-out)]',\n 'ds:hover:bg-[var(--muted)]',\n 'ds:focus-visible:outline-[length:var(--focus-ring-width)]',\n 'ds:focus-visible:outline-[var(--ring)]',\n 'ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]',\n 'ds:motion-reduce:transition-none',\n].join(' ');\n\nconst toolbarTextButtonClass = [\n toolbarButtonBaseClass,\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n].join(' ');\n\nconst toolbarIconButtonClass = [\n toolbarButtonBaseClass,\n 'ds:min-w-[var(--min-target-size)]',\n].join(' ');\n\nexport const CalendarToolbar = forwardRef<HTMLDivElement, CalendarToolbarProps>(\n ({ title, onToday, onPrev, onNext, end, className }, ref) => {\n const { t } = useTranslation();\n const isRtl = useIsRtl();\n const PrevIcon = isRtl ? ChevronRight : ChevronLeft;\n const NextIcon = isRtl ? ChevronLeft : ChevronRight;\n\n const rootClassName = [\n 'ds:calendar-toolbar',\n 'ds:sticky ds:top-0 ds:z-20',\n 'ds:flex ds:items-center ds:gap-[var(--spacing-sm)]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:py-[var(--spacing-sm)]',\n 'ds:bg-[var(--background)]',\n 'ds:border-b ds:border-[var(--border)]',\n className,\n ]\n .filter(Boolean)\n .join(' ');\n\n return (\n <div ref={ref} className={rootClassName}>\n <div className=\"ds:flex ds:items-center ds:gap-[var(--spacing-xs)]\">\n <button\n type=\"button\"\n onClick={onToday}\n className={toolbarTextButtonClass}\n >\n {t('calendar.today')}\n </button>\n <button\n type=\"button\"\n onClick={onPrev}\n aria-label={t('calendar.previousPeriod')}\n className={toolbarIconButtonClass}\n >\n <PrevIcon size={16} aria-hidden=\"true\" />\n </button>\n <button\n type=\"button\"\n onClick={onNext}\n aria-label={t('calendar.nextPeriod')}\n className={toolbarIconButtonClass}\n >\n <NextIcon size={16} aria-hidden=\"true\" />\n </button>\n </div>\n {title ? (\n <h2\n aria-live=\"polite\"\n className=\"ds:flex-1 ds:text-center ds:truncate type-title-card\"\n >\n {title}\n </h2>\n ) : (\n /* Keep the centering slot stable even before the first\n `datesSet` populates the title — an empty <h2> would trip\n axe's `empty-heading` rule, so we substitute a decorative\n spacer that matches the h2's flex sizing. Once `title` is\n non-empty the h2 renders in the same slot. */\n <div\n aria-hidden=\"true\"\n className=\"ds:flex-1 ds:text-center\"\n />\n )}\n {end ? (\n <div className=\"ds:flex ds:items-center ds:gap-[var(--spacing-xs)]\">{end}</div>\n ) : null}\n </div>\n );\n },\n);\nCalendarToolbar.displayName = 'Calendar.Toolbar';\n\n/* ------------------------------------------------------------------ */\n/* Calendar component */\n/* ------------------------------------------------------------------ */\n\nconst CalendarInner = forwardRef<CalendarHandle, CalendarProps>(\n (\n {\n id,\n events,\n resources,\n view = 'dayGridMonth',\n initialDate,\n locale: localeProp,\n onEventDrop,\n onEventResize,\n onEventResizeStart,\n onEventClick,\n onDateSelect,\n editable = false,\n eventDurationEditable,\n selectable = false,\n height,\n className,\n privacyMode = false,\n mode = 'default',\n modeLabel,\n modeBannerColor,\n modeBannerTextColor,\n onModeCancel,\n alertBanner,\n slotMinTime,\n slotMaxTime,\n slotDuration,\n showTime = true,\n datesAboveResources = true,\n slotEventOverlap = false,\n stickyHeaderDates = true,\n nowIndicator = true,\n dayMaxEvents = true,\n schedulerLicenseKey = import.meta.env.VITE_FULLCALENDAR_LICENSE_KEY,\n toolbar = true,\n toolbarEnd,\n resourceLayout = 'vertical',\n showResourceInitials = false,\n },\n ref,\n ) => {\n const { t, i18n } = useTranslation();\n const fcRef = useRef<FullCalendar | null>(null);\n const rootRef = useRef<HTMLDivElement>(null);\n const liveRegionRef = useRef<HTMLDivElement>(null);\n const focusTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null);\n const focusedElRef = useRef<HTMLElement | null>(null);\n\n const locale = localeProp ?? i18n.language ?? 'en';\n\n /* ---- direction reacts to dir attribute changes ----------------- */\n const [direction, setDirection] = useState<'ltr' | 'rtl'>(() => {\n if (typeof document === 'undefined') return 'ltr';\n const docDir = document.documentElement.getAttribute('dir');\n const i18nDir = typeof i18n.dir === 'function' ? i18n.dir() : 'ltr';\n return docDir === 'rtl' || i18nDir === 'rtl' ? 'rtl' : 'ltr';\n });\n\n useEffect(() => {\n if (typeof document === 'undefined') return undefined;\n const observer = new MutationObserver(() => {\n const docDir = document.documentElement.getAttribute('dir');\n const i18nDir = typeof i18n.dir === 'function' ? i18n.dir() : 'ltr';\n setDirection(docDir === 'rtl' || i18nDir === 'rtl' ? 'rtl' : 'ltr');\n });\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: ['dir', 'lang'],\n });\n return () => observer.disconnect();\n }, [i18n]);\n\n /* ---- theme class-change observer → forces FullCalendar repaint - */\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 const api = fcRef.current?.getApi() as unknown;\n if (\n api &&\n typeof (api as { render?: () => void }).render === 'function'\n ) {\n (api as { render: () => void }).render();\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 /* ---- FullCalendar markup a11y patches --------------------------- */\n /* */\n /* FullCalendar emits a few markup patterns that axe (correctly) */\n /* flags but we cannot fix without forking FC. Patching at */\n /* render-time via MutationObserver keeps the fix scoped: */\n /* */\n /* 1. `<a aria-expanded aria-controls>` for the daygrid \"+N more\" */\n /* trigger has no `role` — `aria-expanded` is not allowed on a */\n /* bare anchor. Add `role=\"button\"`. */\n /* 2. `.fc-scroller` is a scrollable region with no keyboard */\n /* access — give it `tabindex=\"0\"` and `role=\"region\"` so */\n /* keyboard users can scroll it. */\n /* 3. `.fc-bg-event` (background events used for highlight ranges) */\n /* is rendered with `aria-hidden=\"true\"` ancestor + an inner */\n /* `<a tabindex=\"0\">` — strip the focusability when */\n /* `aria-hidden` is in effect. */\n useEffect(() => {\n if (typeof document === 'undefined') return undefined;\n const root = rootRef.current;\n if (!root) return undefined;\n\n const patchMarkup = () => {\n root\n .querySelectorAll<HTMLAnchorElement>('.fc-daygrid-more-link')\n .forEach((link) => {\n if (!link.getAttribute('role')) {\n link.setAttribute('role', 'button');\n }\n });\n // `.fc-scroller` cannot be patched — adding `tabindex=\"0\"`\n // makes it a focusable direct child of FC's `<table\n // role=\"grid\">`, which axe (correctly) flags as a violation of\n // `aria-required-children` (a grid expects only `role=\"row\"`\n // children). The `scrollable-region-focusable` rule will need\n // an upstream FC fix or per-story override; for now we accept\n // it. (Tracked: deferred.)\n // Inside any aria-hidden subtree, force focusable descendants to\n // tabindex=\"-1\" so they leave the tab sequence (axe\n // aria-hidden-focus). FC marks decorative rows / mirror events\n // aria-hidden but leaves the inner anchors focusable.\n root.querySelectorAll<HTMLElement>('[aria-hidden=\"true\"]').forEach(\n (hidden) => {\n hidden\n .querySelectorAll<HTMLElement>(\n 'a[href], button, [tabindex]:not([tabindex=\"-1\"])',\n )\n .forEach((el) => {\n el.setAttribute('tabindex', '-1');\n });\n },\n );\n };\n\n patchMarkup();\n const observer = new MutationObserver(patchMarkup);\n observer.observe(root, {\n childList: true,\n subtree: true,\n attributes: true,\n attributeFilter: ['aria-hidden'],\n });\n return () => observer.disconnect();\n }, [t]);\n\n /* ---- reduced-motion gate --------------------------------------- */\n const reducedMotion = usePrefersReducedMotion();\n\n /* ---- current title (synced from FC via datesSet) --------------- */\n const [currentTitle, setCurrentTitle] = useState('');\n\n /* ---- imperative handle ----------------------------------------- */\n const handle = useMemo<CalendarHandle>(() => {\n const getRawApi = (): FcApi | undefined =>\n fcRef.current?.getApi() as FcApi | undefined;\n\n return {\n getApi: () => fcRef.current?.getApi(),\n today: () => {\n getRawApi()?.today();\n },\n prev: () => {\n getRawApi()?.prev();\n },\n next: () => {\n getRawApi()?.next();\n },\n gotoDate: (date: Date | string) => {\n getRawApi()?.gotoDate(date);\n },\n changeView: (nextView: CalendarView) => {\n getRawApi()?.changeView(\n resolveFullCalendarView(nextView, resourceLayout),\n );\n },\n getTitle: () => getRawApi()?.view.title ?? '',\n getCurrentView: () => {\n const type = getRawApi()?.view.type;\n return type as CalendarView | undefined;\n },\n getCurrentDate: () => getRawApi()?.getDate(),\n focusEvent: (eventId: string) => {\n const root = rootRef.current;\n if (!root) return;\n const selector = `[data-event-id=\"${CSS.escape(eventId)}\"]`;\n const element = root.querySelector<HTMLElement>(selector);\n if (!element) {\n if (import.meta.env.DEV) {\n console.warn(\n `[Calendar] focusEvent: no DOM node matches event id \"${eventId}\".`,\n );\n }\n return;\n }\n /* Clear any previous highlight still in-flight before\n starting a new one — prevents overlapping timers from\n removing the className mid-animation. */\n if (focusTimerRef.current) {\n clearTimeout(focusTimerRef.current);\n focusTimerRef.current = null;\n }\n if (\n focusedElRef.current &&\n focusedElRef.current !== element\n ) {\n focusedElRef.current.classList.remove('calendar-event-focused');\n }\n \n element.scrollIntoView({\n behavior: reducedMotion ? 'auto' : 'smooth',\n block: 'center',\n });\n element.classList.add('calendar-event-focused');\n focusedElRef.current = element;\n \n /* Announce via aria-live, masking the title under privacy\n mode the same way drop/resize do. */\n if (liveRegionRef.current) {\n const titleAttr =\n element.getAttribute('aria-label') ?? eventId;\n const announcedTitle = privacyMode ? '•••' : titleAttr;\n liveRegionRef.current.textContent = t('calendar.focusedEvent', {\n title: announcedTitle,\n });\n }\n \n focusTimerRef.current = setTimeout(() => {\n element.classList.remove('calendar-event-focused');\n if (focusedElRef.current === element) {\n focusedElRef.current = null;\n }\n focusTimerRef.current = null;\n }, 3000);\n },\n };\n }, [reducedMotion, privacyMode, t, resourceLayout]);\n\n useImperativeHandle(ref, () => handle, [handle]);\n useAgentRegistration(calendarAgent, handle, id);\n\n /* Clean up any pending focus timer on unmount. */\n useEffect(\n () => () => {\n if (focusTimerRef.current) {\n clearTimeout(focusTimerRef.current);\n focusTimerRef.current = null;\n }\n },\n [],\n );\n\n /* ---- translated toolbar button labels (used by FC internal when\n we opt in to its toolbar — currently always off in the default\n path; retained for noEventsText / allDayText completeness) ---- */\n const statusLabels = useMemo<Record<CalendarEventStatus, string>>(\n () => ({\n confirmed: t('calendar.status.confirmed'),\n waiting: t('calendar.status.waiting'),\n in_care: t('calendar.status.inCare'),\n done: t('calendar.status.done'),\n cancelled: t('calendar.status.cancelled'),\n absent: t('calendar.status.absent'),\n }),\n [t],\n );\n\n /* ---- privacy-mode announcer (skip initial render) --------------- */\n const privacyFirstRun = useRef(true);\n useEffect(() => {\n if (privacyFirstRun.current) {\n privacyFirstRun.current = false;\n return;\n }\n if (liveRegionRef.current) {\n liveRegionRef.current.textContent = privacyMode\n ? t('calendar.privacyModeOn')\n : t('calendar.privacyModeOff');\n }\n }, [privacyMode, t]);\n\n /* ---- adapt events for FullCalendar ----------------------------- */\n const fcEvents = useMemo<EventInput[]>(\n () =>\n events.map((event) => ({\n id: event.id,\n title: event.title,\n start: event.start,\n end: event.end,\n allDay: event.allDay,\n resourceId: event.resourceId,\n display: event.isInternal ? 'background' : undefined,\n extendedProps: {\n status: event.status,\n resourceId: event.resourceId,\n backgroundColor: event.backgroundColor,\n textColor: event.textColor,\n suffix: event.suffix,\n privacyModeTitle: event.privacyModeTitle,\n isBookedOnline: event.isBookedOnline ?? false,\n hasUnassignedPatient: event.hasUnassignedPatient ?? false,\n hasHighlightedAnamnesis: event.hasHighlightedAnamnesis ?? false,\n hasBillableAmount: event.hasBillableAmount ?? false,\n isTelehealth: event.isTelehealth ?? false,\n isRecurrenceParent: event.isRecurrenceParent ?? false,\n isInternal: event.isInternal ?? false,\n patientId: event.patientId,\n operatorId: event.operatorId,\n },\n })),\n [events],\n );\n\n /* ---- formatters (Intl, never literal format strings) ----------- */\n const titleFormat = useMemo(\n () => ({\n year: 'numeric' as const,\n month: 'long' as const,\n }),\n [],\n );\n const dayHeaderFormat = useMemo(\n () => ({\n weekday: 'short' as const,\n }),\n [],\n );\n const eventTimeFormat = useMemo(\n () => ({\n hour: 'numeric' as const,\n minute: '2-digit' as const,\n }),\n [],\n );\n const slotLabelFormat = useMemo(\n () => ({\n hour: 'numeric' as const,\n minute: '2-digit' as const,\n }),\n [],\n );\n\n /* ---- helper: adapt FC event to CalendarEvent -------------------- */\n const adaptEvent = (\n fcEvent: EventDropArg['event'] | EventClickArg['event'],\n ): CalendarEvent => {\n const ext = (fcEvent.extendedProps ?? {}) as EventExtendedProps;\n return {\n id: fcEvent.id,\n title: fcEvent.title,\n start: fcEvent.start ?? new Date(),\n end: fcEvent.end ?? undefined,\n resourceId: ext.resourceId,\n status: ext.status,\n allDay: fcEvent.allDay,\n backgroundColor: ext.backgroundColor,\n textColor: ext.textColor,\n suffix: ext.suffix,\n privacyModeTitle: ext.privacyModeTitle,\n isBookedOnline: ext.isBookedOnline,\n hasUnassignedPatient: ext.hasUnassignedPatient,\n hasHighlightedAnamnesis: ext.hasHighlightedAnamnesis,\n hasBillableAmount: ext.hasBillableAmount,\n isTelehealth: ext.isTelehealth,\n isRecurrenceParent: ext.isRecurrenceParent,\n isInternal: ext.isInternal,\n patientId: ext.patientId,\n operatorId: ext.operatorId,\n };\n };\n\n /* ---- callbacks ------------------------------------------------- */\n const handleEventDrop = useMemo(() => {\n if (!onEventDrop) return undefined;\n return (info: EventDropArg) => {\n if (!info.event.start) return;\n // `info.oldEvent.start` is the only reliable source for the pre-drag\n // time — FullCalendar guarantees it is non-null for a drop on an\n // event that had a start. The `delta` field is unsafe to subtract\n // because it reports calendrical components (years/months/days +\n // sub-day ms), not a single ms offset, and month/year reconstruction\n // is ambiguous across boundaries. If oldStart is somehow missing we\n // bail rather than produce a silently-wrong value.\n const oldStart = info.oldEvent.start;\n if (!oldStart) {\n if (import.meta.env.DEV) {\n console.warn(\n '[Calendar] handleEventDrop: oldEvent.start was null — dropping the event-drop callback rather than emitting wrong oldStart data.',\n );\n }\n return;\n }\n onEventDrop({\n event: adaptEvent(info.event),\n oldStart,\n newStart: info.event.start,\n });\n /* Announce via aria-live. The announced title must honour\n privacyMode — the event card's aria-label already masks, but\n the live-region text is a separate codepath that would leak\n the raw name on drop if not masked here too. */\n if (liveRegionRef.current) {\n const ext = (info.event.extendedProps ?? {}) as EventExtendedProps;\n const announcedTitle = privacyMode\n ? (ext.privacyModeTitle ?? '•••')\n : info.event.title;\n liveRegionRef.current.textContent = t('calendar.eventMoved', {\n title: announcedTitle,\n });\n }\n };\n }, [onEventDrop, privacyMode, t]);\n\n const handleEventResize = useMemo(() => {\n if (!onEventResize) return undefined;\n return (info: EventResizeDoneArg) => {\n if (!info.event.end) return;\n // Mirror the drop path: rely on `info.oldEvent.end` for the pre-resize\n // boundary. Bail on null rather than fabricating a value from deltas.\n const oldEnd = info.oldEvent.end;\n if (!oldEnd) {\n if (import.meta.env.DEV) {\n console.warn(\n '[Calendar] handleEventResize: oldEvent.end was null — dropping the resize callback rather than emitting wrong oldEnd data.',\n );\n }\n return;\n }\n const newEnd = info.event.end;\n const newStart = info.event.start ?? oldEnd;\n onEventResize({\n event: adaptEvent(info.event),\n oldEnd,\n newEnd,\n });\n if (liveRegionRef.current) {\n const duration = Math.round(\n (newEnd.getTime() - newStart.getTime()) / 60000,\n );\n /* Mirror the drop path: mask the title when privacyMode is on. */\n const ext = (info.event.extendedProps ?? {}) as EventExtendedProps;\n const announcedTitle = privacyMode\n ? (ext.privacyModeTitle ?? '•••')\n : info.event.title;\n liveRegionRef.current.textContent = t('calendar.eventResized', {\n title: announcedTitle,\n duration,\n });\n }\n };\n }, [onEventResize, privacyMode, t]);\n\n const handleEventClick = useMemo(() => {\n if (!onEventClick) return undefined;\n return (info: EventClickArg) => {\n if (!info.event.start) return;\n onEventClick(adaptEvent(info.event));\n };\n }, [onEventClick]);\n\n const handleDateSelect = useMemo(() => {\n if (!onDateSelect) return undefined;\n return (info: DateSelectArg) => {\n onDateSelect({\n start: info.start,\n end: info.end,\n allDay: info.allDay,\n resourceId: info.resource?.id,\n });\n };\n }, [onDateSelect]);\n\n const handleDatesSet = useCallback((info: DatesSetArg) => {\n setCurrentTitle(info.view.title);\n }, []);\n\n /* ---- firstDay from locale -------------------------------------- */\n const firstDay = useMemo(() => resolveFirstDay(locale), [locale]);\n\n /* ---- plugins --------------------------------------------------- */\n const plugins = useMemo(\n () => [\n dayGridPlugin,\n timeGridPlugin,\n listPlugin,\n interactionPlugin,\n resourcePlugin,\n resourceTimeGridPlugin,\n resourceTimelinePlugin,\n timelinePlugin,\n ],\n [],\n );\n\n /* ---- resolved internal FC view name ---------------------------- */\n const resolvedView = useMemo(\n () => resolveFullCalendarView(view, resourceLayout),\n [view, resourceLayout],\n );\n\n /* ---- resource label render prop -------------------------------- */\n /* FC's `resourceLabelContent` supplies a `ResourceApi` whose\n `extendedProps` is typed as `{ [k: string]: any }`. We narrow to\n just the fields we pushed through `fcResources` via a local\n interface reached by an `unknown` pivot — keeps the DS body free\n of `any` while accepting FC's runtime shape. */\n interface ResourceExtendedProps {\n shortTitle?: string;\n color?: string;\n shortTitleTextColor?: string;\n }\n\n const renderResourceLabel = useCallback(\n (arg: ResourceLabelContentArg): ReactElement => {\n const ext = arg.resource.extendedProps as unknown as ResourceExtendedProps;\n const title = arg.resource.title;\n const shortTitle = ext.shortTitle;\n const color = ext.color;\n const textColor = ext.shortTitleTextColor;\n\n /* Runtime caller-supplied hex values flow through inline CSS\n custom properties only; the consuming `background-color` /\n `color` references live in the className as Tailwind arbitrary\n values, matching the event/mode-banner pattern (see\n 23-constraints §Runtime-computed dimensions).\n\n Inline style — permitted per 23-constraints §Runtime-computed\n dimensions (CSS custom property setters for --resource-color /\n --resource-initials-text-color). */\n const swatchStyle: CSSProperties | undefined =\n color || textColor\n ? {\n ...(color\n ? ({ '--resource-color': color } as CSSProperties)\n : {}),\n ...(textColor\n ? ({\n '--resource-initials-text-color': textColor,\n } as CSSProperties)\n : {}),\n }\n : undefined;\n\n if (showResourceInitials && shortTitle && color) {\n /* DEV-only guardrail: the initials circle is the one resource\n branch that actually paints text over the caller-supplied\n colour. Warn when the pair falls below WCAG AA. */\n warnLowContrast(color, textColor, `resource ${arg.resource.id}`);\n const initialsClass = [\n 'resource-initials',\n 'ds:[background-color:var(--resource-color)]',\n textColor ? 'ds:[color:var(--resource-initials-text-color)]' : null,\n ]\n .filter(Boolean)\n .join(' ');\n return (\n <span className=\"ds:flex ds:items-center ds:gap-[var(--spacing-xs)]\">\n <span\n className={initialsClass}\n style={swatchStyle}\n aria-hidden=\"true\"\n >\n {shortTitle}\n </span>\n <span className=\"ds:truncate ds:text-start\">{title}</span>\n </span>\n );\n }\n\n if (color) {\n /* Dot branch has no text, but callers may still pass both halves\n of the pair in anticipation of flipping `showResourceInitials`.\n Only warn when both are defined — otherwise we'd noisily\n suggest a textColor that the dot renderer ignores. */\n if (color && textColor) {\n warnLowContrast(color, textColor, `resource ${arg.resource.id}`);\n }\n return (\n <span className=\"ds:flex ds:items-center ds:gap-[var(--spacing-xs)]\">\n <span\n className=\"resource-dot ds:[background-color:var(--resource-color)]\"\n style={swatchStyle}\n aria-hidden=\"true\"\n />\n <span className=\"ds:truncate ds:text-start\">{title}</span>\n </span>\n );\n }\n\n return (\n <span className=\"ds:flex ds:items-center ds:gap-[var(--spacing-xs)]\">\n <span className=\"ds:truncate ds:text-start\">{title}</span>\n </span>\n );\n },\n [showResourceInitials],\n );\n\n /* ---- resources adapted for FC with extendedProps --------------- */\n const fcResources = useMemo(\n () =>\n resources?.map((resource) => ({\n id: resource.id,\n title: resource.title,\n sequenceNumber: resource.sequenceNumber,\n extendedProps: {\n shortTitle: resource.shortTitle,\n color: resource.color,\n shortTitleTextColor: resource.shortTitleTextColor,\n sequenceNumber: resource.sequenceNumber,\n },\n })),\n [resources],\n );\n\n /* ---- default-toolbar button handlers --------------------------- */\n const handleToolbarToday = useCallback(() => {\n (fcRef.current?.getApi() as FcApi | undefined)?.today();\n }, []);\n const handleToolbarPrev = useCallback(() => {\n (fcRef.current?.getApi() as FcApi | undefined)?.prev();\n }, []);\n const handleToolbarNext = useCallback(() => {\n (fcRef.current?.getApi() as FcApi | undefined)?.next();\n }, []);\n\n const wrapperClassName = [\n 'fc-theme-alfadocs',\n 'ds:bg-background ds:text-foreground',\n 'ds:rounded-[var(--radius-md)]',\n className,\n ]\n .filter(Boolean)\n .join(' ');\n\n /* Mode banner style — runtime caller-supplied hex values flow through\n inline CSS-variable assignments only. The consuming\n `background-color` / `color` references live in the className as\n Tailwind arbitrary values, same justification as the event\n colour overrides above. */\n const modeBannerStyle: CSSProperties | undefined =\n modeBannerColor || modeBannerTextColor\n ? {\n ...(modeBannerColor\n ? ({ '--calendar-mode-bg': modeBannerColor } as CSSProperties)\n : {}),\n ...(modeBannerTextColor\n ? ({ '--calendar-mode-fg': modeBannerTextColor } as CSSProperties)\n : {}),\n }\n : undefined;\n\n /* DEV-only guardrail: warn when the caller-supplied mode-banner\n bg/fg hex pair falls below WCAG AA. No-op when either half is\n missing — the component falls back to --muted / --muted-foreground\n which are already calibrated to AA. */\n if (mode !== 'default' && (modeBannerColor || modeBannerTextColor)) {\n warnLowContrast(modeBannerColor, modeBannerTextColor, 'mode banner');\n }\n\n /* Static key map — keeps i18n-extraction tools (i18next-parser, etc.)\n happy, since they can't resolve template-literal keys. */\n const resolvedModeLabel =\n mode !== 'default' ? (modeLabel ?? t(MODE_BANNER_KEYS[mode])) : '';\n\n const modeBannerClassName = [\n 'ds:sticky ds:top-0 ds:z-10',\n 'ds:flex ds:items-center ds:gap-[var(--spacing-sm)]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:py-[var(--spacing-sm)]',\n /* Caller-supplied colours flow through CSS custom properties set\n in `modeBannerStyle`; fallback tokens apply when the caller\n doesn't supply a hex. */\n modeBannerColor\n ? 'ds:[background-color:var(--calendar-mode-bg)]'\n : 'ds:bg-[var(--muted)]',\n modeBannerTextColor\n ? 'ds:[color:var(--calendar-mode-fg)]'\n : 'ds:text-[var(--muted-foreground)]',\n ]\n .filter(Boolean)\n .join(' ');\n\n const modeCancelClassName = [\n 'ds:inline-flex ds:items-center ds:justify-center',\n 'ds:min-h-[var(--min-target-size)]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:rounded-[var(--radius-full)]',\n 'ds:bg-[var(--background)] ds:text-[var(--foreground)]',\n 'ds:border ds:border-[var(--border)]',\n 'ds:font-[var(--font-weight-medium)] ds:text-[length:var(--font-size-sm)]',\n 'ds:transition-colors ds:duration-[var(--animation-duration)] ds:ease-[var(--ease-out)]',\n 'ds:hover:bg-[var(--muted)]',\n 'ds:focus-visible:outline-[length:var(--focus-ring-width)]',\n 'ds:focus-visible:outline-[var(--ring)]',\n 'ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]',\n 'ds:motion-reduce:transition-none',\n ].join(' ');\n\n return (\n <div\n ref={rootRef}\n className={wrapperClassName}\n role=\"region\"\n aria-label={t('calendar.ariaLabel')}\n data-component=\"calendar\"\n data-component-id={id}\n data-mode={mode}\n >\n <div\n ref={liveRegionRef}\n aria-live=\"polite\"\n aria-atomic=\"true\"\n className=\"ds:sr-only\"\n />\n {alertBanner}\n {/* role=\"status\" already implies aria-live=\"polite\" +\n aria-atomic=\"true\"; setting the live attributes explicitly\n causes double announcements in some AT combinations. */}\n {mode !== 'default' ? (\n <div\n className={modeBannerClassName}\n style={modeBannerStyle}\n role=\"status\"\n >\n <span className=\"ds:flex-1 ds:text-start\">{resolvedModeLabel}</span>\n {onModeCancel ? (\n <button\n type=\"button\"\n onClick={onModeCancel}\n className={modeCancelClassName}\n >\n {t('calendar.modeBanner.cancel')}\n </button>\n ) : null}\n </div>\n ) : null}\n {toolbar !== false ? (\n <CalendarToolbar\n title={currentTitle}\n onToday={handleToolbarToday}\n onPrev={handleToolbarPrev}\n onNext={handleToolbarNext}\n end={toolbarEnd}\n />\n ) : null}\n <FullCalendar\n ref={fcRef}\n plugins={plugins}\n schedulerLicenseKey={schedulerLicenseKey}\n initialView={resolvedView}\n views={CALENDAR_CUSTOM_VIEWS}\n initialDate={initialDate}\n locale={locale}\n direction={direction}\n firstDay={firstDay}\n editable={editable}\n eventDurationEditable={eventDurationEditable ?? editable}\n selectable={selectable}\n droppable={editable}\n dayMaxEvents={dayMaxEvents}\n height={height}\n events={fcEvents}\n resources={fcResources}\n resourceOrder=\"sequenceNumber\"\n resourceLabelContent={renderResourceLabel}\n headerToolbar={false}\n allDayText={t('calendar.allDay')}\n noEventsText={t('calendar.noEvents')}\n titleFormat={titleFormat}\n dayHeaderFormat={dayHeaderFormat}\n eventTimeFormat={eventTimeFormat}\n slotLabelFormat={slotLabelFormat}\n slotMinTime={slotMinTime ?? '00:00:00'}\n slotMaxTime={slotMaxTime ?? '24:00:00'}\n slotDuration={slotDuration ?? '00:30:00'}\n // Explicit `slotLabelInterval` — FullCalendar 6.1.x crashes\n // inside `wholeDivideDurations` / `addDurations` when its\n // internal default computation produces an undefined Duration\n // (`Cannot read properties of undefined (reading 'years')`).\n // Passing all three slot props as explicit strings bypasses\n // the fragile default-resolution path. 1h matches FC's\n // documented default for day/week views.\n slotLabelInterval=\"01:00:00\"\n datesAboveResources={datesAboveResources}\n slotEventOverlap={slotEventOverlap}\n stickyHeaderDates={stickyHeaderDates}\n nowIndicator={nowIndicator}\n eventLongPressDelay={reducedMotion ? 0 : 1000}\n eventDragMinDistance={reducedMotion ? 0 : 5}\n eventContent={(arg) =>\n renderEventContent({\n arg,\n locale,\n resources: resources ?? [],\n statusLabels,\n privacyMode,\n showTime,\n })\n }\n eventClick={handleEventClick}\n eventDrop={handleEventDrop}\n eventResize={handleEventResize}\n eventResizeStart={onEventResizeStart}\n select={handleDateSelect}\n datesSet={handleDatesSet}\n />\n </div>\n );\n },\n);\nCalendarInner.displayName = 'Calendar';\n\n/* Compound attachment — exposes `<Calendar.Toolbar />` so consumers can\n render a standalone toolbar bound to their own handle-driven handlers\n when they hide the built-in toolbar via `toolbar={false}`. The\n `typeof CalendarInner & { Toolbar }` widening is the single acceptable\n cast called out in the implementation plan. */\ntype CalendarComponent = typeof CalendarInner & {\n Toolbar: typeof CalendarToolbar;\n};\nexport const Calendar = CalendarInner as CalendarComponent;\nCalendar.Toolbar = CalendarToolbar;\n"],"names":["__iconNode","Ban","createLucideIcon","Euro","HeartPulse","Stethoscope","ThumbsUp","Video","Zap","calendarAgent","handle","_a","args","RESOURCE_VIEW_MAP","STANDARD_VIEWS","resolveFullCalendarView","view","resourceLayout","stem","CALENDAR_CUSTOM_VIEWS","eventCardVariants","cva","STATUS_ICON","Clock","Check","MODE_BANNER_KEYS","resolveFirstDay","locale","intlLocale","info","useIsRtl","i18n","useTranslation","isRtl","setIsRtl","useState","docDir","i18nDir","useEffect","observer","renderEventContent","arg","resources","statusLabels","privacyMode","showTime","extended","status","backgroundColor","textColor","suffix","privacyModeTitle","isBookedOnline","hasUnassignedPatient","hasHighlightedAnamnesis","hasBillableAmount","isTelehealth","resourceId","StatusIcon","start","end","allDay","rangeText","fmt","resourceTitle","r","statusLabel","displayTitle","ariaLabel","colourOverrides","className","jsxs","Globe","AlertTriangle","toolbarButtonBaseClass","toolbarTextButtonClass","toolbarIconButtonClass","CalendarToolbar","forwardRef","title","onToday","onPrev","onNext","ref","t","PrevIcon","ChevronRight","ChevronLeft","NextIcon","rootClassName","jsx","CalendarInner","id","events","initialDate","localeProp","onEventDrop","onEventResize","onEventResizeStart","onEventClick","onDateSelect","editable","eventDurationEditable","selectable","height","mode","modeLabel","modeBannerColor","modeBannerTextColor","onModeCancel","alertBanner","slotMinTime","slotMaxTime","slotDuration","datesAboveResources","slotEventOverlap","stickyHeaderDates","nowIndicator","dayMaxEvents","schedulerLicenseKey","toolbar","toolbarEnd","showResourceInitials","fcRef","useRef","rootRef","liveRegionRef","focusTimerRef","focusedElRef","direction","setDirection","timer","api","root","patchMarkup","link","hidden","el","reducedMotion","usePrefersReducedMotion","currentTitle","setCurrentTitle","useMemo","getRawApi","date","nextView","eventId","selector","element","titleAttr","announcedTitle","useImperativeHandle","useAgentRegistration","privacyFirstRun","fcEvents","event","titleFormat","dayHeaderFormat","eventTimeFormat","slotLabelFormat","adaptEvent","fcEvent","ext","handleEventDrop","oldStart","handleEventResize","oldEnd","newEnd","newStart","duration","handleEventClick","handleDateSelect","handleDatesSet","useCallback","firstDay","plugins","dayGridPlugin","timeGridPlugin","listPlugin","interactionPlugin","resourcePlugin","resourceTimeGridPlugin","resourceTimelinePlugin","timelinePlugin","resolvedView","renderResourceLabel","shortTitle","color","swatchStyle","initialsClass","fcResources","resource","handleToolbarToday","_b","handleToolbarPrev","handleToolbarNext","wrapperClassName","modeBannerStyle","resolvedModeLabel","modeBannerClassName","modeCancelClassName","FullCalendar","Calendar"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"card-BEy58ZKp.js","sources":["../../src/components/card/card.tsx"],"sourcesContent":["import {\n createContext,\n forwardRef,\n useCallback,\n useContext,\n useId,\n useState,\n type HTMLAttributes,\n type KeyboardEvent,\n type ReactNode,\n} from 'react';\nimport { Slot } from '@radix-ui/react-slot';\nimport { cva, type VariantProps } from 'class-variance-authority';\n\n/* ------------------------------------------------------------------ */\n/* Context */\n/* ------------------------------------------------------------------ */\n\ninterface CardContextValue {\n headerId: string;\n interactive: boolean;\n registerHeader: () => void;\n}\n\nconst CardContext = createContext<CardContextValue>({\n headerId: '',\n interactive: false,\n registerHeader: () => {},\n});\n\n/* ------------------------------------------------------------------ */\n/* Variants */\n/* ------------------------------------------------------------------ */\n\nconst cardVariants = cva(\n [\n 'ds:rounded-[var(--radius-lg)] ds:text-[var(--card-foreground)]',\n 'ds:overflow-hidden',\n 'ds:flex ds:flex-col',\n ].join(' '),\n {\n variants: {\n variant: {\n default: 'ds:bg-[var(--card)] ds:border ds:border-[color:var(--card-border)]',\n outlined: 'ds:bg-[var(--card)] ds:border ds:border-[color:var(--border)]',\n elevated: 'ds:bg-[var(--card)] ds:shadow-[var(--shadow-card)]',\n },\n interactive: {\n true: [\n 'ds:cursor-pointer',\n 'ds:transition-shadow ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none',\n 'ds:hover:shadow-[var(--shadow-hover)]',\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:min-h-[var(--min-target-size)]',\n ].join(' '),\n false: '',\n },\n // `stretch: true` fills the parent layout cell (grid / flex) so a\n // row of Cards ends up with matching heights. Combined with the\n // `flex-1` on `Card.Body`, the footer naturally pins to the bottom.\n stretch: {\n true: 'ds:h-full ds:self-stretch',\n false: '',\n },\n },\n defaultVariants: {\n variant: 'default',\n interactive: false,\n stretch: false,\n },\n },\n);\n\n/* ------------------------------------------------------------------ */\n/* Types */\n/* ------------------------------------------------------------------ */\n\nexport interface CardProps\n extends Omit<HTMLAttributes<HTMLElement>, 'role'>,\n VariantProps<typeof cardVariants> {\n variant?: 'default' | 'outlined' | 'elevated';\n interactive?: boolean;\n /**\n * Stretch the Card to fill its parent layout cell. Use on every Card in\n * a dashboard row so siblings end up with matching heights, and the\n * `Card.Body` + `Card.Footer` flex naturally pin the footer to the\n * bottom. Grid cells already `align-items: stretch` by default, but an\n * explicit `h-full` keeps the behaviour robust under flex parents too.\n */\n stretch?: boolean;\n asChild?: boolean;\n children: ReactNode;\n}\n\n/* ------------------------------------------------------------------ */\n/* Root */\n/* ------------------------------------------------------------------ */\n\nconst CardRoot = forwardRef<HTMLElement, CardProps>(\n (\n {\n variant = 'default',\n interactive = false,\n stretch = false,\n asChild = false,\n className,\n children,\n onClick,\n onKeyDown,\n ...props\n },\n ref,\n ) => {\n const headerId = useId();\n const [hasHeader, setHasHeader] = useState(false);\n const registerHeader = useCallback(() => setHasHeader(true), []);\n\n const handleKeyDown = (e: KeyboardEvent<HTMLElement>) => {\n if (interactive && (e.key === 'Enter' || e.key === ' ')) {\n e.preventDefault();\n (e.currentTarget as HTMLElement).click();\n }\n onKeyDown?.(e);\n };\n\n // When asChild=true the consumer provides its own element (<a>, <button>)\n // which already carries the correct role and tabIndex — don't override them.\n const interactiveProps = interactive\n ? {\n ...(asChild ? {} : { role: 'button' as const, tabIndex: 0 }),\n onKeyDown: handleKeyDown,\n onClick,\n }\n : { onClick };\n\n const Comp = asChild ? Slot : 'article';\n\n return (\n <CardContext.Provider value={{ headerId, interactive: interactive ?? false, registerHeader }}>\n <Comp\n ref={ref as React.Ref<HTMLElement>}\n aria-labelledby={hasHeader ? headerId : undefined}\n data-component=\"card\"\n className={cardVariants({\n variant,\n interactive: interactive ?? false,\n stretch: stretch ?? false,\n className,\n })}\n {...interactiveProps}\n {...props}\n >\n {children}\n </Comp>\n </CardContext.Provider>\n );\n },\n);\nCardRoot.displayName = 'Card';\n\n/* ------------------------------------------------------------------ */\n/* Header */\n/* ------------------------------------------------------------------ */\n\nconst CardHeader = forwardRef<HTMLDivElement, HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => {\n const { headerId, registerHeader } = useContext(CardContext);\n\n // Notify root that a header is present so aria-labelledby is applied.\n const callbackRef = useCallback(\n (node: HTMLDivElement | null) => {\n if (node) registerHeader();\n if (typeof ref === 'function') ref(node);\n else if (ref) (ref as React.MutableRefObject<HTMLDivElement | null>).current = node;\n },\n [ref, registerHeader],\n );\n\n return (\n <div\n ref={callbackRef}\n id={headerId}\n className={[\n 'ds:flex ds:flex-col ds:gap-[var(--spacing-xs)] ds:p-[var(--spacing-md)] ds:pb-0',\n 'ds:[&_*]:break-normal ds:[&_*]:[overflow-wrap:anywhere]',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n {...props}\n />\n );\n },\n);\nCardHeader.displayName = 'Card.Header';\n\n/* ------------------------------------------------------------------ */\n/* Media */\n/* ------------------------------------------------------------------ */\n\nconst CardMedia = forwardRef<HTMLDivElement, HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={[\n 'ds:overflow-hidden ds:[&_img]:w-full ds:[&_img]:h-auto ds:[&_img]:[object-fit:cover] ds:[&_video]:w-full',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n {...props}\n />\n ),\n);\nCardMedia.displayName = 'Card.Media';\n\n/* ------------------------------------------------------------------ */\n/* Body */\n/* ------------------------------------------------------------------ */\n\nconst CardBody = forwardRef<HTMLDivElement, HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={['ds:p-[var(--spacing-md)] ds:flex-1 ds:text-start', className]\n .filter(Boolean)\n .join(' ')}\n {...props}\n />\n ),\n);\nCardBody.displayName = 'Card.Body';\n\n/* ------------------------------------------------------------------ */\n/* Footer */\n/* ------------------------------------------------------------------ */\n\nconst CardFooter = forwardRef<HTMLDivElement, HTMLAttributes<HTMLDivElement>>(\n ({ className, ...props }, ref) => (\n <div\n ref={ref}\n className={[\n 'ds:flex ds:items-center ds:gap-[var(--spacing-sm)] ds:p-[var(--spacing-md)] ds:pt-0',\n className,\n ]\n .filter(Boolean)\n .join(' ')}\n {...props}\n />\n ),\n);\nCardFooter.displayName = 'Card.Footer';\n\n/* ------------------------------------------------------------------ */\n/* Compound export */\n/* ------------------------------------------------------------------ */\n\nexport const Card = Object.assign(CardRoot, {\n Header: CardHeader,\n Media: CardMedia,\n Body: CardBody,\n Footer: CardFooter,\n});\n\nexport type { VariantProps as CardVariantProps };\n"],"names":["CardContext","createContext","cardVariants","cva","CardRoot","forwardRef","variant","interactive","stretch","asChild","className","children","onClick","onKeyDown","props","ref","headerId","useId","hasHeader","setHasHeader","useState","registerHeader","useCallback","interactiveProps","e","Comp","Slot","jsx","CardHeader","useContext","callbackRef","node","CardMedia","CardBody","CardFooter","Card"],"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":"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"}
@@ -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-container.agent-Dhw9xCJt.js","sources":["../../src/components/chat-container/chat-container.agent.ts"],"sourcesContent":["import type { AgentAdapter } from '../../agent/types';\nimport type { ChatContainerHandle } from './chat-container';\n\nexport const chatContainerAgent: AgentAdapter<ChatContainerHandle> = {\n id: 'chat-container',\n capabilities: ['navigate'],\n state: {},\n actions: {\n scroll_to_bottom: {\n safety: 'read',\n argsType: '{ smooth?: boolean }',\n description: 'Scroll the conversation viewport to the latest message.',\n invoke: (handle, args: { smooth?: boolean }) => {\n handle.scrollToBottom(args);\n },\n },\n },\n domHooks: {\n root: { attr: 'data-component', value: 'chat-container' },\n },\n};\n"],"names":["chatContainerAgent","handle","args"],"mappings":"AAGO,MAAMA,IAAwD;AAAA,EACnE,IAAI;AAAA,EACJ,cAAc,CAAC,UAAU;AAAA,EACzB,OAAO,CAAA;AAAA,EACP,SAAS;AAAA,IACP,kBAAkB;AAAA,MAChB,QAAQ;AAAA,MACR,UAAU;AAAA,MACV,aAAa;AAAA,MACb,QAAQ,CAACC,GAAQC,MAA+B;AAC9C,QAAAD,EAAO,eAAeC,CAAI;AAAA,MAC5B;AAAA,IAAA;AAAA,EACF;AAAA,EAEF,UAAU;AAAA,IACR,MAAM,EAAE,MAAM,kBAAkB,OAAO,iBAAA;AAAA,EAAiB;AAE5D;"}
@@ -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 +0,0 @@
1
- {"version":3,"file":"chat-message-ByouZpPP.js","sources":["../../node_modules/lucide-react/dist/esm/icons/rotate-ccw.js","../../src/components/chat-message/chat-message.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 [\"path\", { d: \"M3 12a9 9 0 1 0 9-9 9.75 9.75 0 0 0-6.74 2.74L3 8\", key: \"1357e3\" }],\n [\"path\", { d: \"M3 3v5h5\", key: \"1xhq8a\" }]\n];\nconst RotateCcw = createLucideIcon(\"rotate-ccw\", __iconNode);\n\nexport { __iconNode, RotateCcw as default };\n//# sourceMappingURL=rotate-ccw.js.map\n","import {\n forwardRef,\n Fragment,\n useMemo,\n type HTMLAttributes,\n type ReactNode,\n} from 'react';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport { AlertCircle, Check, Clock, RotateCcw } from 'lucide-react';\nimport { Button } from '../button';\nimport { Avatar } from '../avatar';\nimport { Timestamp } from '../timestamp';\nimport { safeImageSrc } from '../_shared';\n\n/* ------------------------------------------------------------------ */\n/* Types */\n/* ------------------------------------------------------------------ */\n\nexport type ChatMessageRole = 'user' | 'assistant' | 'system';\nexport type ChatMessageStatus = 'sending' | 'sent' | 'error' | 'edited';\n\nexport interface ChatMessageAvatar {\n name?: string;\n src?: string;\n /**\n * Optional custom avatar node. When provided, it REPLACES the built-in\n * `<Avatar>` (initials / image) for this message. Used by the Leo\n * pattern to render a Sparkles identity tile instead of an avatar, and\n * by consumers that want to swap in a user-icon chip, brand glyph, etc.\n * The caller is responsible for accessible labelling on the custom node\n * — ChatMessage's own `aria-label` already announces the role/time, so\n * purely decorative nodes can be `aria-hidden`.\n */\n slot?: ReactNode;\n}\n\n/* ------------------------------------------------------------------ */\n/* CVA */\n/* ------------------------------------------------------------------ */\n\nconst rowVariants = cva('ds:flex ds:w-full ds:items-start ds:gap-[var(--spacing-sm)]', {\n variants: {\n role: {\n user: 'ds:flex-row-reverse',\n assistant: 'ds:flex-row',\n system: 'ds:flex-col ds:items-center ds:text-center',\n },\n },\n defaultVariants: { role: 'assistant' },\n});\n\nconst bubbleVariants = cva(\n [\n // Cap at 42rem on wide surfaces; on narrow docks (Leo sidebar ≈22rem)\n // leave room for the avatar column (size-8 = 32px = --spacing-xl) +\n // `gap-sm` (8px = --spacing-sm) so avatars don't clip off the inline\n // edge when the row is width-constrained.\n 'ds:relative ds:max-w-[min(42rem,calc(100%-var(--spacing-xl)-var(--spacing-sm)))]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-sm)]',\n 'type-body',\n 'ds:break-words',\n ].join(' '),\n {\n variants: {\n role: {\n user: 'ds:bg-[color:var(--primary)] ds:text-[color:var(--primary-foreground)] ds:rounded-[var(--radius-md)] ds:rounded-ee-[var(--radius-sm)]',\n assistant:\n 'ds:bg-muted/40 ds:text-foreground ds:rounded-[var(--radius-md)] ds:rounded-es-[var(--radius-sm)]',\n system:\n 'ds:bg-transparent ds:text-[color:var(--muted-foreground)] type-body-sm ds:italic',\n },\n },\n defaultVariants: { role: 'assistant' },\n },\n);\n\n/* ------------------------------------------------------------------ */\n/* Safe markdown-ish (bold, inline code, line-breaks, links as text) */\n/* No dangerouslySetInnerHTML. */\n/* ------------------------------------------------------------------ */\n\ntype Token =\n | { type: 'text'; value: string }\n | { type: 'bold'; value: string }\n | { type: 'code'; value: string }\n | { type: 'br' }\n | { type: 'link'; label: string; href: string };\n\nconst SAFE_SCHEMES = /^(https?:|mailto:)/i;\n\nfunction tokenize(input: string): Token[] {\n const tokens: Token[] = [];\n let remaining = input;\n const pattern = /\\*\\*([^*]+)\\*\\*|`([^`]+)`|\\[([^\\]]+)\\]\\(([^)]+)\\)|\\n/;\n while (remaining.length > 0) {\n const match = pattern.exec(remaining);\n if (!match) {\n tokens.push({ type: 'text', value: remaining });\n break;\n }\n if (match.index > 0) {\n tokens.push({ type: 'text', value: remaining.slice(0, match.index) });\n }\n if (match[1] !== undefined) {\n tokens.push({ type: 'bold', value: match[1] });\n } else if (match[2] !== undefined) {\n tokens.push({ type: 'code', value: match[2] });\n } else if (match[3] !== undefined && match[4] !== undefined) {\n tokens.push({ type: 'link', label: match[3], href: match[4] });\n } else {\n tokens.push({ type: 'br' });\n }\n remaining = remaining.slice(match.index + match[0].length);\n }\n return tokens;\n}\n\nfunction renderBody(input: string): ReactNode {\n return tokenize(input).map((tok, i) => {\n if (tok.type === 'bold') return <strong key={i}>{tok.value}</strong>;\n if (tok.type === 'code') {\n return (\n <code\n key={i}\n dir=\"ltr\"\n className=\"ds:rounded-[var(--radius-sm)] ds:bg-muted/30 ds:ps-[var(--spacing-xs)] ds:pe-[var(--spacing-xs)] ds:font-[family-name:var(--font-mono)]\"\n >\n {tok.value}\n </code>\n );\n }\n if (tok.type === 'br') return <br key={i} />;\n if (tok.type === 'link') {\n if (!SAFE_SCHEMES.test(tok.href)) {\n // Unsafe scheme (javascript:, data:) — render as inert text.\n return <Fragment key={i}>{tok.label}</Fragment>;\n }\n return (\n <a\n key={i}\n href={tok.href}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n className=\"ds:underline ds:underline-offset-2 ds:hover:opacity-80\"\n >\n {tok.label}\n </a>\n );\n }\n return <Fragment key={i}>{tok.value}</Fragment>;\n });\n}\n\n/* ------------------------------------------------------------------ */\n/* ChatMessage */\n/* ------------------------------------------------------------------ */\n\ntype NativeProps = Omit<HTMLAttributes<HTMLElement>, 'content' | 'role'>;\n\nexport interface ChatMessageProps\n extends NativeProps,\n VariantProps<typeof bubbleVariants> {\n role: ChatMessageRole;\n content: string;\n avatar?: ChatMessageAvatar;\n timestamp?: Date | number | string;\n status?: ChatMessageStatus;\n /** Parse a small, safe subset of markdown. Never renders raw HTML. */\n renderMarkdown?: boolean;\n /** Invoked when the retry button is activated (error status only). */\n onRetry?: () => void;\n}\n\nexport const ChatMessage = forwardRef<HTMLElement, ChatMessageProps>(\n (\n {\n role,\n content,\n avatar,\n timestamp,\n status,\n renderMarkdown = false,\n onRetry,\n className,\n ...rest\n },\n ref,\n ) => {\n const { t, i18n } = useTranslation();\n\n // Local format — used for the aria-label interpolation only. Visible\n // label is rendered by `<Timestamp>` below, which computes the same\n // locale-aware HH:MM internally.\n const formattedTime = useMemo(() => {\n if (!timestamp) return null;\n const date =\n timestamp instanceof Date ? timestamp : new Date(timestamp);\n if (Number.isNaN(date.getTime())) return null;\n return new Intl.DateTimeFormat(i18n.language, {\n hour: '2-digit',\n minute: '2-digit',\n }).format(date);\n }, [timestamp, i18n.language]);\n\n const roleLabel = t(`chat.message.role.${role}`);\n const messageLabel = formattedTime\n ? t('chat.message.label', { role: roleLabel, time: formattedTime })\n : t('chat.message.labelNoTime', { role: roleLabel });\n\n const body = renderMarkdown ? renderBody(content) : content;\n\n const statusIcon = (() => {\n if (!status || status === 'edited') return null;\n if (status === 'sending')\n return <Clock aria-hidden=\"true\" className=\"ds:size-3.5\" />;\n if (status === 'sent')\n return <Check aria-hidden=\"true\" className=\"ds:size-3.5\" />;\n return (\n <AlertCircle\n aria-hidden=\"true\"\n className=\"ds:size-3.5 ds:text-[color:var(--destructive)]\"\n />\n );\n })();\n\n const statusText = status ? t(`chat.message.status.${status}`) : null;\n\n return (\n <article\n ref={ref}\n aria-label={messageLabel}\n data-component=\"chat-message\"\n className={[\n rowVariants({ role, className }),\n // Entrance: fade + slide up on mount. `--animation-duration` is 0ms\n // under `prefers-reduced-motion` and `.theme-accessible`, so both\n // collapse the animation to an instant state change automatically.\n 'ds:motion-safe:animate-in ds:motion-safe:fade-in-0 ds:motion-safe:slide-in-from-bottom-2',\n 'ds:duration-[var(--animation-duration)] ds:ease-[var(--ease-out)]',\n ].join(' ')}\n {...rest}\n >\n {role !== 'system' && avatar ? (\n avatar.slot ? (\n // Consumer-supplied avatar node (e.g. Leo's Sparkles tile).\n avatar.slot\n ) : (\n // Allow-list the src: LLM-supplied values can carry\n // `javascript:` / `data:text/html` / `data:image/svg+xml` and so\n // are scrubbed here before reaching <Avatar>. Fallback to initials.\n <Avatar name={avatar.name} src={safeImageSrc(avatar.src)} size=\"sm\" />\n )\n ) : null}\n\n <div\n className={[\n // min-w-0 allows this flex item to shrink below its content's\n // natural width — without it, a single unbreakable token (URL,\n // CJK run, hash) can force the bubble wider than the parent\n // and spill outside narrow containers like the Leo sidebar.\n 'ds:flex ds:flex-col ds:min-w-0',\n role === 'user' ? 'ds:items-end' : role === 'assistant' ? 'ds:items-start' : 'ds:items-center',\n ].join(' ')}\n >\n <div\n dir=\"auto\"\n className={[\n bubbleVariants({ role }),\n // `break-words` (from bubbleVariants) handles soft hyphens;\n // `overflow-wrap: anywhere` is the last-resort break for\n // URLs, hashes, or CJK runs that would otherwise push the\n // bubble wider than its parent in narrow docks like Leo.\n 'ds:[overflow-wrap:anywhere]',\n ].join(' ')}\n >\n {body}\n </div>\n\n {(formattedTime || statusText) && role !== 'system' ? (\n <div\n className={[\n 'ds:mt-[var(--spacing-xs)] ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)]',\n 'type-meta ds:text-[color:var(--muted-foreground)]',\n ].join(' ')}\n >\n {timestamp ? (\n <Timestamp\n value={timestamp}\n format=\"absolute\"\n absoluteFormat={{ hour: '2-digit', minute: '2-digit' }}\n dir=\"ltr\"\n />\n ) : null}\n {statusIcon ? (\n // `key={status}` re-mounts the span on every status change so\n // `animate-in` re-runs — gives the sending → sent → error\n // swap a subtle cross-fade instead of an abrupt pop.\n <span\n key={status}\n className={[\n 'ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)]',\n 'ds:motion-safe:animate-in ds:motion-safe:fade-in-0',\n 'ds:duration-[var(--animation-duration)] ds:ease-[var(--ease-out)]',\n ].join(' ')}\n >\n {statusIcon}\n <span className=\"ds:sr-only\">{statusText}</span>\n </span>\n ) : null}\n {status === 'error' && onRetry ? (\n <Button\n intent=\"ghost\"\n size=\"sm\"\n onClick={onRetry}\n startIcon={<RotateCcw />}\n >\n {t('chat.message.retry')}\n </Button>\n ) : null}\n </div>\n ) : null}\n </div>\n </article>\n );\n },\n);\n\nChatMessage.displayName = 'ChatMessage';\n"],"names":["__iconNode","RotateCcw","createLucideIcon","rowVariants","cva","bubbleVariants","SAFE_SCHEMES","tokenize","input","tokens","remaining","pattern","match","renderBody","tok","i","jsx","Fragment","ChatMessage","forwardRef","role","content","avatar","timestamp","status","renderMarkdown","onRetry","className","rest","ref","t","i18n","useTranslation","formattedTime","useMemo","date","roleLabel","messageLabel","body","statusIcon","Clock","Check","AlertCircle","statusText","jsxs","Avatar","safeImageSrc","Timestamp","Button"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"check-DPdL_Sm7.js","sources":["../../node_modules/lucide-react/dist/esm/icons/check.js"],"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 = [[\"path\", { d: \"M20 6 9 17l-5-5\", key: \"1gmf2c\" }]];\nconst Check = createLucideIcon(\"check\", __iconNode);\n\nexport { __iconNode, Check as default };\n//# sourceMappingURL=check.js.map\n"],"names":["__iconNode","Check","createLucideIcon"],"mappings":";AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AASA,MAAMA,IAAa,CAAC,CAAC,QAAQ,EAAE,GAAG,mBAAmB,KAAK,SAAQ,CAAE,CAAC,GAC/DC,IAAQC,EAAiB,SAASF,CAAU;","x_google_ignoreList":[0]}