@alfadocs/ui-kit 0.70.0 → 0.71.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (304) hide show
  1. package/dist/_chunks/address-fields-CPbFJ8e8.js +246 -0
  2. package/dist/_chunks/{ai-prompt-input-CuhTo9mh.js → ai-prompt-input-V4DdOeqv.js} +2 -2
  3. package/dist/_chunks/{alia-sidebar-B47qRQb5.js → alia-sidebar-DvIUzIX9.js} +107 -106
  4. package/dist/_chunks/{anatomy-scheme-CJB6dI6p.js → anatomy-scheme-CXSk11UJ.js} +2 -2
  5. package/dist/_chunks/{app-frame-BYx1gcV7.js → app-frame-DIEMIC5V.js} +67 -56
  6. package/dist/_chunks/{appointment-card-C06aZqA7.js → appointment-card-DVaeJNVB.js} +82 -98
  7. package/dist/_chunks/{appointment-timeline-BJM0S_Fg.js → appointment-timeline-PJgnrjFb.js} +159 -157
  8. package/dist/_chunks/{appointment-tray-DRRw5ROi.js → appointment-tray-B16QPGbm.js} +2 -2
  9. package/dist/_chunks/{audio-recorder-Cpdk5qpQ.js → audio-recorder-DNDsOLqO.js} +2 -2
  10. package/dist/_chunks/{autocomplete-DOeGouCL.js → autocomplete-BrONKN8l.js} +168 -146
  11. package/dist/_chunks/{bishop-score-DnYWtZa_.js → bishop-score-Cym_TeQY.js} +2 -2
  12. package/dist/_chunks/{booking-DUBI0oqt.js → booking-C7do4vaR.js} +4 -4
  13. package/dist/_chunks/{button-group-Ciq6J4IW.js → button-group-CvEnVzY7.js} +32 -35
  14. package/dist/_chunks/{care-plan-card-C5sTfY9G.js → care-plan-card-DzPDYgtK.js} +3 -3
  15. package/dist/_chunks/{care-plan-entry-card-CXnxGCWA.js → care-plan-entry-card-CEnQy7YP.js} +3 -3
  16. package/dist/_chunks/care-plan-header-DcXFXWit.js +198 -0
  17. package/dist/_chunks/{chat-message-3V54YipB.js → chat-message-DzpcJR-q.js} +25 -23
  18. package/dist/_chunks/city-input-Dkgaak7I.js +169 -0
  19. package/dist/_chunks/clipboard-list-S7s-MXQq.js +25 -0
  20. package/dist/_chunks/{combobox-Clum7gJ1.js → combobox-DnqSF0IH.js} +131 -114
  21. package/dist/_chunks/connection-status-CY1HV8Wg.js +108 -0
  22. package/dist/_chunks/control-room-rail-FAQZrGVL.js +333 -0
  23. package/dist/_chunks/country-select-BwUZQvTa.js +709 -0
  24. package/dist/_chunks/editable-currency-cell-renderer-CGELrkIj.js +410 -0
  25. package/dist/_chunks/{entity-card-9_62gY7l.js → entity-card-DmrgYSEX.js} +4 -4
  26. package/dist/_chunks/entity-summary-CaM1Y-xE.js +291 -0
  27. package/dist/_chunks/field-array-siUZzfYe.js +146 -0
  28. package/dist/_chunks/{field-value-NXYczdpO.js → field-value-3jMM0uDx.js} +2 -2
  29. package/dist/_chunks/{gestational-age-calculator-CF2ISaYQ.js → gestational-age-calculator-DKzEV5Qi.js} +2 -2
  30. package/dist/_chunks/iban-input-B0TWzR1R.js +436 -0
  31. package/dist/_chunks/icon-picker-0B7KhrF1.js +272 -0
  32. package/dist/_chunks/image-cropper-D9jqJy19.js +367 -0
  33. package/dist/_chunks/{link-cell-renderer-CTXqtXV-.js → link-cell-renderer-De_SLjSq.js} +262 -261
  34. package/dist/_chunks/list-checks-BUs75d_o.js +18 -0
  35. package/dist/_chunks/{marketplace-app-shell-Skhfp6vK.js → marketplace-app-shell-BGqkywsi.js} +3 -3
  36. package/dist/_chunks/message-card-DsHFFiL1.js +319 -0
  37. package/dist/_chunks/{message-tray-DwrBLJlf.js → message-tray-C0a6CL1_.js} +172 -135
  38. package/dist/_chunks/{multi-select-BdHHDrRN.js → multi-select-WE4S9FIF.js} +75 -63
  39. package/dist/_chunks/nav-grid-9xphY3FM.js +169 -0
  40. package/dist/_chunks/notes-panel-DXiMfuvp.js +320 -0
  41. package/dist/_chunks/notification-card-BMqNzCIt.js +290 -0
  42. package/dist/_chunks/{notification-tray-AEun6DN2.js → notification-tray-BmUlCx3g.js} +201 -166
  43. package/dist/_chunks/{operator-hero-CR0Rqh4-.js → operator-hero-BO8TqzX2.js} +2 -2
  44. package/dist/_chunks/panel-header-D313n_9-.js +105 -0
  45. package/dist/_chunks/{patient-details-Dlhqb5ig.js → patient-details-DgfTJimE.js} +280 -196
  46. package/dist/_chunks/{patient-search-Be6cLrHR.js → patient-search-CSWQKOSP.js} +2 -2
  47. package/dist/_chunks/{patient-shell-DV3XEtIB.js → patient-shell-BMwsIKlW.js} +3 -3
  48. package/dist/_chunks/{patient-summary-card-WySCMwwA.js → patient-summary-card-D4NdgYJB.js} +27 -12
  49. package/dist/_chunks/{patient-table-CHxf3Oqk.js → patient-table-CERknpd8.js} +3 -3
  50. package/dist/_chunks/{payment-request-card-BcZJwu9z.js → payment-request-card-Blf-MFNY.js} +2 -2
  51. package/dist/_chunks/permission-matrix-Bw5oexUt.js +174 -0
  52. package/dist/_chunks/position-grid-CcvqHaKN.js +169 -0
  53. package/dist/_chunks/postal-code-input-UCOYuRY2.js +192 -0
  54. package/dist/_chunks/{practice-results-C6qDfxos.js → practice-results-El5Z-oVp.js} +2 -2
  55. package/dist/_chunks/{pregnancy-dating-CRVWswD-.js → pregnancy-dating-CunHrOpO.js} +2 -2
  56. package/dist/_chunks/{product-hub-panel-e6pW220e.js → product-hub-panel-DtU7KXxm.js} +257 -217
  57. package/dist/_chunks/province-select-D_TZvix3.js +261 -0
  58. package/dist/_chunks/{public-header.agent-DqkqA-ca.js → public-header.agent-TxmC_x1I.js} +2 -2
  59. package/dist/_chunks/radiograph-panel.agent-tWjN2nHX.js +553 -0
  60. package/dist/_chunks/reviews-panel-DxkSrgMl.js +559 -0
  61. package/dist/_chunks/rich-text-editor-C8tyGjfb.js +2621 -0
  62. package/dist/_chunks/{scroll-area-5wNK0Cyz.js → scroll-area-BZOvUhwQ.js} +2 -2
  63. package/dist/_chunks/{select-DMLG44F5.js → select-KsyRr8WH.js} +114 -102
  64. package/dist/_chunks/{sheet-BxsE7eQm.js → sheet-umkfZjF6.js} +53 -42
  65. package/dist/_chunks/{sidebar-DY9jGjgt.js → sidebar-QCp9wHNP.js} +125 -113
  66. package/dist/_chunks/{tabs-BxcOziCo.js → tabs-CYZVKKDl.js} +2 -2
  67. package/dist/_chunks/task-card-DCdsI0ZT.js +189 -0
  68. package/dist/_chunks/{task-tray-qOEQflu4.js → task-tray-DNVejijD.js} +2 -2
  69. package/dist/_chunks/tasks-panel-C9odmawT.js +757 -0
  70. package/dist/_chunks/token-insert-menu-CFQqTe_n.js +147 -0
  71. package/dist/_chunks/{ai-tools-rail-B5NEghsp.js → tool-rail-BZx0-yIr.js} +152 -139
  72. package/dist/_chunks/{tooth-scheme-BhQoPNBD.js → tooth-scheme-DJZtzfeY.js} +470 -468
  73. package/dist/_chunks/{transcript-panel-3THQX6nJ.js → transcript-panel-CHGHHHdT.js} +95 -83
  74. package/dist/_chunks/{unit-converter-YEpD9evj.js → unit-converter-CwlZbfdn.js} +2 -2
  75. package/dist/_chunks/{workflow-map-Dy8mLCqF.js → workflow-map-M8MBBHQm.js} +106 -118
  76. package/dist/agent-catalog.json +2062 -226
  77. package/dist/agent-i18n/en.json +206 -8
  78. package/dist/components/_shared/option.d.ts +2 -0
  79. package/dist/components/_shared/patient-fields.d.ts +1 -1
  80. package/dist/components/address-fields/address-fields.agent.d.ts +9 -0
  81. package/dist/components/address-fields/address-fields.d.ts +29 -0
  82. package/dist/components/address-fields/index.d.ts +5 -0
  83. package/dist/components/address-fields/index.js +6 -0
  84. package/dist/components/ai-prompt-input/index.js +1 -1
  85. package/dist/components/anatomy-scheme/index.js +1 -1
  86. package/dist/components/app-frame/app-frame.d.ts +2 -2
  87. package/dist/components/app-frame/index.js +1 -1
  88. package/dist/components/appointment-card/index.js +2 -2
  89. package/dist/components/appointment-timeline/index.js +1 -1
  90. package/dist/components/audio-recorder/index.js +1 -1
  91. package/dist/components/autocomplete/autocomplete.d.ts +10 -0
  92. package/dist/components/autocomplete/index.js +1 -1
  93. package/dist/components/bishop-score/index.js +1 -1
  94. package/dist/components/booking/index.js +1 -1
  95. package/dist/components/button-group/index.js +1 -1
  96. package/dist/components/care-plan-card/index.js +1 -1
  97. package/dist/components/care-plan-entry-card/index.js +1 -1
  98. package/dist/components/care-plan-header/care-plan-header.d.ts +16 -5
  99. package/dist/components/care-plan-header/index.js +1 -1
  100. package/dist/components/chat-message/index.js +1 -1
  101. package/dist/components/city-input/city-input.agent.d.ts +8 -0
  102. package/dist/components/city-input/city-input.d.ts +57 -0
  103. package/dist/components/city-input/index.d.ts +5 -0
  104. package/dist/components/city-input/index.js +6 -0
  105. package/dist/components/combobox/combobox.d.ts +17 -0
  106. package/dist/components/combobox/index.js +1 -1
  107. package/dist/components/connection-status/connection-status.agent.d.ts +4 -0
  108. package/dist/components/connection-status/connection-status.d.ts +36 -0
  109. package/dist/components/connection-status/index.d.ts +4 -0
  110. package/dist/components/connection-status/index.js +6 -0
  111. package/dist/components/control-room-rail/control-room-context.d.ts +5 -5
  112. package/dist/components/control-room-rail/control-room-rail.agent.d.ts +4 -0
  113. package/dist/components/control-room-rail/control-room-rail.d.ts +5 -5
  114. package/dist/components/control-room-rail/index.d.ts +1 -0
  115. package/dist/components/control-room-rail/index.js +4 -3
  116. package/dist/components/counter/counter.d.ts +1 -1
  117. package/dist/components/country-select/country-select.agent.d.ts +8 -0
  118. package/dist/components/country-select/country-select.d.ts +51 -0
  119. package/dist/components/country-select/index.d.ts +6 -0
  120. package/dist/components/country-select/index.js +9 -0
  121. package/dist/components/country-select/iso-3166.d.ts +15 -0
  122. package/dist/components/data-table/cell-renderers/reorder-cell-renderer.d.ts +34 -0
  123. package/dist/components/data-table/index.d.ts +2 -0
  124. package/dist/components/data-table/index.js +13 -11
  125. package/dist/components/entity-summary/entity-summary.agent.d.ts +4 -0
  126. package/dist/components/entity-summary/entity-summary.d.ts +53 -4
  127. package/dist/components/entity-summary/index.js +1 -1
  128. package/dist/components/field-array/field-array.agent.d.ts +4 -0
  129. package/dist/components/field-array/field-array.d.ts +45 -0
  130. package/dist/components/field-array/index.d.ts +4 -0
  131. package/dist/components/field-array/index.js +6 -0
  132. package/dist/components/freemium-paywall/freemium-paywall.d.ts +1 -1
  133. package/dist/components/gestational-age-calculator/index.js +1 -1
  134. package/dist/components/iban-input/iban-input.agent.d.ts +4 -0
  135. package/dist/components/iban-input/iban-input.d.ts +51 -0
  136. package/dist/components/iban-input/index.d.ts +5 -0
  137. package/dist/components/iban-input/index.js +13 -0
  138. package/dist/components/iban-input/is-valid-iban.d.ts +31 -0
  139. package/dist/components/icon-picker/icon-picker.agent.d.ts +4 -0
  140. package/dist/components/icon-picker/icon-picker.d.ts +41 -0
  141. package/dist/components/icon-picker/index.d.ts +4 -0
  142. package/dist/components/icon-picker/index.js +6 -0
  143. package/dist/components/image-cropper/crop-geometry.d.ts +30 -0
  144. package/dist/components/image-cropper/image-cropper.agent.d.ts +4 -0
  145. package/dist/components/image-cropper/image-cropper.d.ts +32 -0
  146. package/dist/components/image-cropper/index.d.ts +5 -0
  147. package/dist/components/image-cropper/index.js +11 -0
  148. package/dist/components/index.d.ts +16 -1
  149. package/dist/components/message-card/index.js +1 -1
  150. package/dist/components/message-card/message-card.d.ts +14 -0
  151. package/dist/components/message-tray/index.js +1 -1
  152. package/dist/components/message-tray/message-tray.d.ts +4 -0
  153. package/dist/components/multi-select/index.js +1 -1
  154. package/dist/components/nav-grid/index.d.ts +4 -0
  155. package/dist/components/nav-grid/index.js +7 -0
  156. package/dist/components/nav-grid/nav-grid.agent.d.ts +4 -0
  157. package/dist/components/nav-grid/nav-grid.d.ts +41 -0
  158. package/dist/components/notes-panel/index.js +1 -1
  159. package/dist/components/notes-panel/notes-panel.agent.d.ts +4 -0
  160. package/dist/components/notes-panel/notes-panel.d.ts +30 -0
  161. package/dist/components/notification-card/index.js +1 -1
  162. package/dist/components/notification-card/notification-card.d.ts +15 -0
  163. package/dist/components/notification-tray/index.js +1 -1
  164. package/dist/components/notification-tray/notification-tray.d.ts +4 -0
  165. package/dist/components/operator-hero/index.js +1 -1
  166. package/dist/components/panel-header/index.d.ts +3 -0
  167. package/dist/components/panel-header/index.js +7 -0
  168. package/dist/components/panel-header/panel-header.d.ts +41 -0
  169. package/dist/components/patient-details/index.js +1 -1
  170. package/dist/components/patient-search/index.js +1 -1
  171. package/dist/components/patient-summary-card/index.js +1 -1
  172. package/dist/components/patient-table/index.js +1 -1
  173. package/dist/components/payment-card/index.js +1 -1
  174. package/dist/components/permission-matrix/index.d.ts +4 -0
  175. package/dist/components/permission-matrix/index.js +7 -0
  176. package/dist/components/permission-matrix/permission-matrix.agent.d.ts +4 -0
  177. package/dist/components/permission-matrix/permission-matrix.d.ts +47 -0
  178. package/dist/components/position-grid/index.d.ts +4 -0
  179. package/dist/components/position-grid/index.js +7 -0
  180. package/dist/components/position-grid/position-grid.agent.d.ts +4 -0
  181. package/dist/components/position-grid/position-grid.d.ts +39 -0
  182. package/dist/components/postal-code-input/index.d.ts +5 -0
  183. package/dist/components/postal-code-input/index.js +6 -0
  184. package/dist/components/postal-code-input/postal-code-input.agent.d.ts +8 -0
  185. package/dist/components/postal-code-input/postal-code-input.d.ts +27 -0
  186. package/dist/components/practice-results/index.js +1 -1
  187. package/dist/components/pregnancy-dating/index.js +1 -1
  188. package/dist/components/product-hub-tray/index.js +1 -1
  189. package/dist/components/product-hub-tray/product-hub-tray.d.ts +13 -1
  190. package/dist/components/province-select/index.d.ts +6 -0
  191. package/dist/components/province-select/index.js +7 -0
  192. package/dist/components/province-select/it-provinces.d.ts +8 -0
  193. package/dist/components/province-select/province-select.agent.d.ts +8 -0
  194. package/dist/components/province-select/province-select.d.ts +38 -0
  195. package/dist/components/public-footer/public-footer.d.ts +1 -1
  196. package/dist/components/public-header/index.js +1 -1
  197. package/dist/components/radiograph-panel/index.js +1 -1
  198. package/dist/components/reviews-panel/index.js +1 -1
  199. package/dist/components/rich-text-editor/editor-toolbar.d.ts +17 -0
  200. package/dist/components/rich-text-editor/index.js +1 -1
  201. package/dist/components/scroll-area/index.js +1 -1
  202. package/dist/components/select/index.js +1 -1
  203. package/dist/components/select/select.d.ts +8 -2
  204. package/dist/components/sheet/index.js +1 -1
  205. package/dist/components/sidebar/index.js +1 -1
  206. package/dist/components/skeleton/skeleton.d.ts +1 -1
  207. package/dist/components/tabs/index.js +1 -1
  208. package/dist/components/task-card/index.js +1 -1
  209. package/dist/components/task-card/task-card.d.ts +14 -6
  210. package/dist/components/task-tray/index.js +1 -1
  211. package/dist/components/tasks-panel/index.d.ts +4 -0
  212. package/dist/components/tasks-panel/index.js +6 -0
  213. package/dist/components/tasks-panel/tasks-panel.agent.d.ts +4 -0
  214. package/dist/components/tasks-panel/tasks-panel.d.ts +152 -0
  215. package/dist/components/token-insert-menu/index.d.ts +4 -0
  216. package/dist/components/token-insert-menu/index.js +6 -0
  217. package/dist/components/token-insert-menu/token-insert-menu.agent.d.ts +4 -0
  218. package/dist/components/token-insert-menu/token-insert-menu.d.ts +33 -0
  219. package/dist/components/tool-rail/index.d.ts +4 -0
  220. package/dist/components/tool-rail/index.js +6 -0
  221. package/dist/components/tool-rail/tool-rail.agent.d.ts +4 -0
  222. package/dist/components/{ai-tools-rail/ai-tools-rail.d.ts → tool-rail/tool-rail.d.ts} +29 -12
  223. package/dist/components/tooth-scheme/index.js +1 -1
  224. package/dist/components/tooth-scheme/tooth-scheme.d.ts +9 -0
  225. package/dist/components/transcript-panel/index.js +1 -1
  226. package/dist/components/transcript-panel/transcript-panel.d.ts +2 -2
  227. package/dist/components/unit-converter/index.js +1 -1
  228. package/dist/components/workflow/index.js +1 -1
  229. package/dist/hooks/use-edge-resize.d.ts +2 -2
  230. package/dist/i18n/locales/ar.d.ts +167 -2
  231. package/dist/i18n/locales/ar.js +157 -5
  232. package/dist/i18n/locales/de.d.ts +167 -2
  233. package/dist/i18n/locales/de.js +159 -5
  234. package/dist/i18n/locales/el.d.ts +167 -2
  235. package/dist/i18n/locales/el.js +164 -5
  236. package/dist/i18n/locales/en.d.ts +167 -2
  237. package/dist/i18n/locales/en.js +170 -5
  238. package/dist/i18n/locales/es.d.ts +167 -2
  239. package/dist/i18n/locales/es.js +156 -5
  240. package/dist/i18n/locales/fr.d.ts +167 -2
  241. package/dist/i18n/locales/fr.js +159 -5
  242. package/dist/i18n/locales/hi.d.ts +167 -2
  243. package/dist/i18n/locales/hi.js +155 -5
  244. package/dist/i18n/locales/it.d.ts +167 -2
  245. package/dist/i18n/locales/it.js +159 -5
  246. package/dist/i18n/locales/ja.d.ts +167 -2
  247. package/dist/i18n/locales/ja.js +160 -5
  248. package/dist/i18n/locales/nl.d.ts +167 -2
  249. package/dist/i18n/locales/nl.js +152 -5
  250. package/dist/i18n/locales/pl.d.ts +167 -2
  251. package/dist/i18n/locales/pl.js +160 -5
  252. package/dist/i18n/locales/pt.d.ts +167 -2
  253. package/dist/i18n/locales/pt.js +164 -5
  254. package/dist/i18n/locales/ro.d.ts +167 -2
  255. package/dist/i18n/locales/ro.js +164 -5
  256. package/dist/i18n/locales/ru.d.ts +167 -2
  257. package/dist/i18n/locales/ru.js +157 -5
  258. package/dist/i18n/locales/sq.d.ts +167 -2
  259. package/dist/i18n/locales/sq.js +161 -5
  260. package/dist/i18n/locales/sv.d.ts +167 -2
  261. package/dist/i18n/locales/sv.js +159 -5
  262. package/dist/i18n/locales/tr.d.ts +167 -2
  263. package/dist/i18n/locales/tr.js +157 -5
  264. package/dist/i18n/locales/zh.d.ts +167 -2
  265. package/dist/i18n/locales/zh.js +152 -5
  266. package/dist/index.js +823 -755
  267. package/dist/locales/ar.json +170 -5
  268. package/dist/locales/de.json +170 -5
  269. package/dist/locales/el.json +170 -5
  270. package/dist/locales/en.json +170 -5
  271. package/dist/locales/es.json +170 -5
  272. package/dist/locales/fr.json +170 -5
  273. package/dist/locales/hi.json +170 -5
  274. package/dist/locales/it.json +170 -5
  275. package/dist/locales/ja.json +170 -5
  276. package/dist/locales/nl.json +170 -5
  277. package/dist/locales/pl.json +170 -5
  278. package/dist/locales/pt.json +170 -5
  279. package/dist/locales/ro.json +170 -5
  280. package/dist/locales/ru.json +170 -5
  281. package/dist/locales/sq.json +170 -5
  282. package/dist/locales/sv.json +170 -5
  283. package/dist/locales/tr.json +170 -5
  284. package/dist/locales/zh.json +170 -5
  285. package/dist/patterns/alia-assistant/alia-types.d.ts +9 -0
  286. package/dist/patterns/alia-assistant/index.js +1 -1
  287. package/dist/patterns/marketplace-app-shell/index.js +1 -1
  288. package/dist/patterns/patient-shell/index.js +1 -1
  289. package/dist/tokens.css +9 -1
  290. package/package.json +65 -5
  291. package/dist/_chunks/care-plan-header-BUwqDTtz.js +0 -206
  292. package/dist/_chunks/control-room-rail-Y8ryLYsP.js +0 -229
  293. package/dist/_chunks/editable-currency-cell-renderer-C9twtALM.js +0 -328
  294. package/dist/_chunks/entity-summary-BxRjFh_4.js +0 -138
  295. package/dist/_chunks/message-card-Bx4GmLvf.js +0 -277
  296. package/dist/_chunks/notes-panel-ay8_lPrA.js +0 -158
  297. package/dist/_chunks/notification-card-D2jiKSJJ.js +0 -259
  298. package/dist/_chunks/radiograph-panel.agent-CAX-C3g3.js +0 -558
  299. package/dist/_chunks/reviews-panel-Dq7LMDcH.js +0 -555
  300. package/dist/_chunks/rich-text-editor-DlCqPixb.js +0 -2158
  301. package/dist/_chunks/task-card-BwY9jaV1.js +0 -124
  302. package/dist/components/ai-tools-rail/ai-tools-rail.agent.d.ts +0 -4
  303. package/dist/components/ai-tools-rail/index.d.ts +0 -4
  304. package/dist/components/ai-tools-rail/index.js +0 -6
@@ -0,0 +1,320 @@
1
+ import { jsxs as b, jsx as i } from "react/jsx-runtime";
2
+ import { forwardRef as ne, useRef as o, useState as A, useId as ie, useCallback as ae, useImperativeHandle as re, useMemo as se } from "react";
3
+ import { useTranslation as oe } from "react-i18next";
4
+ import { u as le } from "./registry-DvAUVLHh.js";
5
+ import { C as ce } from "./clinical-note-card-BUvNMNGL.js";
6
+ import { R as de } from "./rich-text-editor-C8tyGjfb.js";
7
+ import { T as pe } from "./text-area-Bt3p7Pt0.js";
8
+ import { B as ue } from "./button-DD_0Xdmr.js";
9
+ import { C as me } from "./checkbox-BuZ1u__2.js";
10
+ import { P as ge } from "./panel-header-D313n_9-.js";
11
+ import { c as fe } from "./createLucideIcon-CrFbzy84.js";
12
+ /**
13
+ * @license lucide-react v1.8.0 - ISC
14
+ *
15
+ * This source code is licensed under the ISC license.
16
+ * See the LICENSE file in the root directory of this source tree.
17
+ */
18
+ const he = [
19
+ [
20
+ "path",
21
+ {
22
+ d: "M21 9a2.4 2.4 0 0 0-.706-1.706l-3.588-3.588A2.4 2.4 0 0 0 15 3H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2z",
23
+ key: "1dfntj"
24
+ }
25
+ ],
26
+ ["path", { d: "M15 3v5a1 1 0 0 0 1 1h5", key: "6s6qgf" }]
27
+ ], ye = fe("sticky-note", he), be = {
28
+ id: "notes-panel",
29
+ // 'submit' backs add_note (compose + commit a note). pin / flag are toggles
30
+ // with no dedicated capability in the closed vocabulary.
31
+ capabilities: ["submit"],
32
+ state: {
33
+ notes: {
34
+ type: "Array<{ id?: string; pinned: boolean; flagged: boolean; clinical: boolean }>",
35
+ descriptionKey: "ui.agent.notesPanel.state.notes",
36
+ description: "Timeline note ids + pinned / flagged / clinical flags. Never the note body or author (both PHI).",
37
+ read: (n) => n.getNotes()
38
+ },
39
+ canAddClinical: {
40
+ type: "boolean",
41
+ descriptionKey: "ui.agent.notesPanel.state.canAddClinical",
42
+ description: "Whether the current user may write clinical notes (the practice_add_clinical_note permission gate).",
43
+ read: (n) => n.canAddClinical()
44
+ }
45
+ },
46
+ actions: {
47
+ add_note: {
48
+ // Writes a clinical/admin note body — patient-identifiable content. PHI.
49
+ safety: "phi",
50
+ argsType: "{ content: string; clinical: boolean }",
51
+ argsSchema: {
52
+ type: "object",
53
+ properties: {
54
+ content: {
55
+ type: "string",
56
+ description: "Note body. Rich HTML for the rich composer, else plain text."
57
+ },
58
+ clinical: {
59
+ type: "boolean",
60
+ description: "Whether the note is clinical. Requires the clinical-note permission; the submission is dropped when the gate is closed."
61
+ }
62
+ },
63
+ required: ["content", "clinical"]
64
+ },
65
+ openWorld: !0,
66
+ descriptionKey: "ui.agent.notesPanel.actions.addNote",
67
+ description: "Compose and commit a new note. A clinical note requires the clinical-note permission (read canAddClinical first).",
68
+ examples: [
69
+ {
70
+ args: { content: "Patient reported improvement.", clinical: !0 },
71
+ note: "Add a clinical note."
72
+ }
73
+ ],
74
+ invoke: (n, a) => {
75
+ n.addNote(a);
76
+ }
77
+ },
78
+ toggle_pin: {
79
+ // Re-orders the timeline (pinned notes lead) — reversible view write.
80
+ safety: "write",
81
+ argsType: "{ id: string }",
82
+ argsSchema: {
83
+ type: "object",
84
+ properties: { id: { type: "string" } },
85
+ required: ["id"]
86
+ },
87
+ idempotent: !1,
88
+ descriptionKey: "ui.agent.notesPanel.actions.togglePin",
89
+ description: "Toggle the pinned state of the note with the given id.",
90
+ invoke: (n, a) => {
91
+ n.togglePin(a.id);
92
+ }
93
+ },
94
+ toggle_flag: {
95
+ safety: "write",
96
+ argsType: "{ id: string }",
97
+ argsSchema: {
98
+ type: "object",
99
+ properties: { id: { type: "string" } },
100
+ required: ["id"]
101
+ },
102
+ idempotent: !1,
103
+ descriptionKey: "ui.agent.notesPanel.actions.toggleFlag",
104
+ description: "Toggle the flagged state of the note with the given id.",
105
+ invoke: (n, a) => {
106
+ n.toggleFlag(a.id);
107
+ }
108
+ }
109
+ },
110
+ domHooks: {
111
+ root: {
112
+ attr: "data-component",
113
+ value: "notes-panel",
114
+ description: "Marks the NotesPanel region."
115
+ },
116
+ instanceId: {
117
+ attr: "data-component-id",
118
+ sourceProp: "id",
119
+ description: "Sourced from the id prop. Required to address a specific notes panel from the agent."
120
+ }
121
+ }
122
+ };
123
+ function M(n) {
124
+ return n ? /<img\b/i.test(n) ? !0 : n.replace(/<[^>]*>/g, "").replace(/&nbsp;/gi, " ").trim().length > 0 : !1;
125
+ }
126
+ const qe = ne(
127
+ function({
128
+ id: a,
129
+ notes: v,
130
+ onAddNote: r,
131
+ composer: p = "rich",
132
+ editorToolbar: S = "standard",
133
+ redactor: T,
134
+ imageUploadUrl: K,
135
+ showClinicalToggle: R = !0,
136
+ canAddClinicalNote: u = !0,
137
+ clinicalGatedReason: z,
138
+ defaultClinical: x = !1,
139
+ onRequestAiDraft: L,
140
+ aiDraftFormat: B,
141
+ aiPrivacyNotice: W,
142
+ onDictate: D,
143
+ onProofread: E,
144
+ onAutoFormat: G,
145
+ onTogglePin: m,
146
+ onToggleFlag: g,
147
+ title: Y,
148
+ composerPlaceholder: F,
149
+ addNoteLabel: J,
150
+ emptyState: O,
151
+ className: Q,
152
+ "aria-label": P,
153
+ ...U
154
+ }, X) {
155
+ const { t: s } = oe(), N = o(null), [l, C] = A(""), [f, w] = A(x), Z = Y ?? s("notesPanel.title", { defaultValue: "Notes" }), j = ie(), H = F ?? s("notesPanel.placeholder", { defaultValue: "Add a note…" }), _ = s("notesPanel.composerLabel", {
156
+ defaultValue: "New note"
157
+ }), $ = p === "rich" ? M(l) : l.trim().length > 0, ee = ae(() => {
158
+ var e, t;
159
+ if (r) {
160
+ if (p === "rich") {
161
+ const d = ((e = N.current) == null ? void 0 : e.getHTML()) ?? l;
162
+ if (!M(d)) return;
163
+ r({ content: d, clinical: f }), (t = N.current) == null || t.clear();
164
+ } else {
165
+ const d = l.trim();
166
+ if (!d) return;
167
+ r({ content: d, clinical: f });
168
+ }
169
+ C(""), w(x);
170
+ }
171
+ }, [p, l, f, x, r]), q = [...v].sort(
172
+ (e, t) => Number(t.pinned ?? !1) - Number(e.pinned ?? !1)
173
+ ), I = o(v);
174
+ I.current = v;
175
+ const c = o(r);
176
+ c.current = r;
177
+ const h = o(m);
178
+ h.current = m;
179
+ const y = o(g);
180
+ y.current = g;
181
+ const k = o(u);
182
+ k.current = u;
183
+ const V = o(null);
184
+ re(X, () => V.current, []);
185
+ const te = se(
186
+ () => ({
187
+ // Ids + flags only — never the note body or author (both PHI).
188
+ getNotes: () => I.current.map((e) => ({
189
+ id: e.id,
190
+ pinned: !!e.pinned,
191
+ flagged: !!e.flagged,
192
+ clinical: !!e.clinical
193
+ })),
194
+ canAddNote: () => !!c.current,
195
+ canAddClinical: () => k.current,
196
+ addNote: (e) => {
197
+ var t;
198
+ e.clinical && !k.current || (t = c.current) == null || t.call(c, e);
199
+ },
200
+ togglePin: (e) => {
201
+ var t;
202
+ return (t = h.current) == null ? void 0 : t.call(h, e);
203
+ },
204
+ toggleFlag: (e) => {
205
+ var t;
206
+ return (t = y.current) == null ? void 0 : t.call(y, e);
207
+ }
208
+ }),
209
+ []
210
+ );
211
+ return le(be, te, a), /* @__PURE__ */ b(
212
+ "section",
213
+ {
214
+ ref: V,
215
+ "data-component": "notes-panel",
216
+ "data-component-id": a,
217
+ "aria-labelledby": P ? void 0 : j,
218
+ "aria-label": P,
219
+ className: ["ds:flex ds:flex-col", Q].filter(Boolean).join(" "),
220
+ ...U,
221
+ children: [
222
+ /* @__PURE__ */ i(
223
+ ge,
224
+ {
225
+ title: Z,
226
+ icon: /* @__PURE__ */ i(ye, { "aria-hidden": "true" }),
227
+ headingId: P ? void 0 : j,
228
+ sticky: !0,
229
+ divider: !0
230
+ }
231
+ ),
232
+ /* @__PURE__ */ b("div", { className: "ds:flex ds:flex-col ds:gap-[var(--spacing-md)] ds:p-[var(--spacing-md)]", children: [
233
+ r ? /* @__PURE__ */ b("div", { className: "ds:flex ds:flex-col ds:gap-[var(--spacing-sm)]", children: [
234
+ p === "rich" ? /* @__PURE__ */ i(
235
+ de,
236
+ {
237
+ ref: N,
238
+ ariaLabel: _,
239
+ placeholder: H,
240
+ toolbar: S,
241
+ minHeight: "sm",
242
+ redactor: T,
243
+ imageUploadUrl: K,
244
+ onChange: ({ html: e }) => C(e),
245
+ onRequestAiDraft: L,
246
+ aiDraftFormat: B,
247
+ aiPrivacyNotice: W,
248
+ onDictate: D,
249
+ onProofread: E,
250
+ onAutoFormat: G
251
+ }
252
+ ) : /* @__PURE__ */ i(
253
+ pe,
254
+ {
255
+ value: l,
256
+ onChange: (e) => C(e.target.value),
257
+ placeholder: H,
258
+ autoResize: !0,
259
+ minRows: 2,
260
+ maxRows: 6,
261
+ "aria-label": _
262
+ }
263
+ ),
264
+ /* @__PURE__ */ b(
265
+ "div",
266
+ {
267
+ className: [
268
+ "ds:flex ds:flex-wrap ds:items-center ds:gap-[var(--spacing-sm)]",
269
+ R ? "ds:justify-between" : "ds:justify-end"
270
+ ].join(" "),
271
+ children: [
272
+ R ? /* @__PURE__ */ i(
273
+ me,
274
+ {
275
+ size: "sm",
276
+ label: s("notesPanel.clinicalToggle", {
277
+ defaultValue: "Clinical note"
278
+ }),
279
+ checked: f,
280
+ onCheckedChange: (e) => w(e === !0),
281
+ disabled: !u,
282
+ disabledReason: u ? void 0 : z ?? s("notesPanel.clinicalGated", {
283
+ defaultValue: "You do not have permission to write clinical notes."
284
+ })
285
+ }
286
+ ) : null,
287
+ /* @__PURE__ */ i(
288
+ ue,
289
+ {
290
+ type: "button",
291
+ size: "sm",
292
+ onClick: ee,
293
+ disabled: !$,
294
+ children: J ?? s("notesPanel.add", { defaultValue: "Add note" })
295
+ }
296
+ )
297
+ ]
298
+ }
299
+ )
300
+ ] }) : null,
301
+ q.length > 0 ? /* @__PURE__ */ i("ul", { className: "ds:m-0 ds:flex ds:list-none ds:flex-col ds:gap-[var(--spacing-sm)] ds:p-0", children: q.map((e, t) => /* @__PURE__ */ i("li", { className: "ds:flex ds:flex-col", children: /* @__PURE__ */ i(
302
+ ce,
303
+ {
304
+ surface: "elevated",
305
+ truncate: !0,
306
+ ...e,
307
+ onTogglePin: m && e.id ? () => m(e.id) : void 0,
308
+ onToggleFlag: g && e.id ? () => g(e.id) : void 0
309
+ }
310
+ ) }, e.id ?? t)) }) : O ?? /* @__PURE__ */ i("p", { className: "ds:m-0 type-body-sm ds:text-[color:var(--muted-foreground)]", children: s("notesPanel.empty", { defaultValue: "No notes yet." }) })
311
+ ] })
312
+ ]
313
+ }
314
+ );
315
+ }
316
+ );
317
+ export {
318
+ qe as N
319
+ };
320
+ //# sourceMappingURL=notes-panel-DXiMfuvp.js.map
@@ -0,0 +1,290 @@
1
+ import { jsx as a, jsxs as l } from "react/jsx-runtime";
2
+ import { forwardRef as W, useMemo as E, useState as H, useRef as X, useCallback as q } from "react";
3
+ import { c as G } from "./index-D2ZczOXr.js";
4
+ import { useTranslation as J } from "react-i18next";
5
+ import { I as O } from "./icon-button-LqoiKcUN.js";
6
+ import { B as K } from "./button-DD_0Xdmr.js";
7
+ import { T as Q } from "./timestamp-BV2lC-wV.js";
8
+ import { X as Y } from "./x-CCcI3eJp.js";
9
+ const Z = G(
10
+ [
11
+ // `group` so the hover/focus-revealed close button can react to the whole
12
+ // row, not just itself.
13
+ "ds:group ds:relative ds:flex ds:gap-[var(--spacing-sm)]",
14
+ "ds:rounded-[var(--radius-sm)]",
15
+ "ds:transition-colors",
16
+ // Mount: fade + slide-down so a fresh notification reads as arriving.
17
+ // `data-leaving=true` plays the matching exit, driven by the owning
18
+ // tray's AnimatePresence loop.
19
+ "ds:motion-safe:animate-in ds:motion-safe:fade-in-0 ds:motion-safe:slide-in-from-top-2 ds:motion-safe:duration-[var(--animation-duration)]",
20
+ "ds:data-[leaving=true]:motion-safe:animate-out ds:data-[leaving=true]:motion-safe:fade-out-0 ds:data-[leaving=true]:motion-safe:slide-out-to-top-2",
21
+ // Pin the exit's end-state until React unmounts. Without `fill-mode-forwards`
22
+ // tw-animate-css leaves the element at opacity:1 for one paint frame after
23
+ // the animation ends — the "flicker before it animates away" bug.
24
+ "ds:data-[leaving=true]:motion-safe:fill-mode-forwards",
25
+ "ds:data-[leaving=true]:pointer-events-none",
26
+ "ds:motion-reduce:transition-none",
27
+ "ds:text-start",
28
+ // Compact rows are borderless (flat list — the tray panel is the frame);
29
+ // the dashboard variant adds its own card border below. Forced-colors keeps
30
+ // a border on both so rows stay separated in High Contrast Mode.
31
+ "ds:forced-colors:border ds:forced-colors:border-[CanvasText]"
32
+ ].join(" "),
33
+ {
34
+ variants: {
35
+ variant: {
36
+ // Flat rows by default; the accessible (AAA) theme restores a hairline
37
+ // row divider so consecutive rows keep a visible boundary.
38
+ compact: "ds:items-start ds:[.theme-accessible_&]:border-b ds:[.theme-accessible_&]:border-[color:var(--card-border)]",
39
+ dashboard: "ds:flex-col ds:sm:flex-row ds:items-stretch ds:sm:items-start ds:border ds:border-[color:var(--card-border)] ds:[.theme-accessible_&]:border-2 ds:shadow-[var(--shadow-card)] ds:bg-[color:var(--card)]"
40
+ },
41
+ size: {
42
+ sm: "ds:p-[var(--spacing-sm)]",
43
+ md: "ds:p-[var(--spacing-md)]"
44
+ },
45
+ state: {
46
+ unread: "",
47
+ read: "ds:bg-transparent"
48
+ },
49
+ // Compact-row chrome: flat (tray) vs elevated (own card on a rail).
50
+ // Mirrors AppointmentCard's `surface` so a rail feed of mixed cards
51
+ // reads consistently.
52
+ surface: {
53
+ flat: "",
54
+ elevated: "ds:border ds:border-[color:var(--card-border)] ds:[.theme-accessible_&]:border-2 ds:shadow-[var(--shadow-sm)]"
55
+ }
56
+ },
57
+ compoundVariants: [
58
+ // Compact rows no longer tint the background for unread — the read state
59
+ // is carried by the icon's corner status ball instead. Both states
60
+ // share the same neutral hover.
61
+ {
62
+ variant: "compact",
63
+ state: "unread",
64
+ class: "ds:hover:bg-[color:var(--muted)]/40"
65
+ },
66
+ {
67
+ variant: "compact",
68
+ state: "read",
69
+ class: "ds:hover:bg-[color:var(--muted)]/40"
70
+ },
71
+ {
72
+ variant: "dashboard",
73
+ state: "unread",
74
+ class: "ds:bg-[color:var(--accent)]/5"
75
+ }
76
+ ],
77
+ defaultVariants: {
78
+ variant: "compact",
79
+ size: "sm",
80
+ state: "read",
81
+ surface: "flat"
82
+ }
83
+ }
84
+ ), S = [
85
+ "ds:focus-visible:outline-none",
86
+ "ds:after:content-[''] ds:after:absolute ds:after:inset-0 ds:after:rounded-[var(--radius-sm)]",
87
+ "ds:after:pointer-events-auto",
88
+ "ds:focus-visible:after:outline-[length:var(--focus-ring-width)]",
89
+ "ds:focus-visible:after:outline-solid",
90
+ "ds:focus-visible:after:outline-[color:var(--ring)]",
91
+ "ds:focus-visible:after:outline-offset-[length:var(--focus-ring-offset)]",
92
+ "ds:forced-colors:focus-visible:after:outline-[CanvasText]"
93
+ ].join(" ");
94
+ function A(s) {
95
+ return /^(https?:\/\/(?!\/)|\/(?!\/)|#)/.test(s);
96
+ }
97
+ const ss = W(
98
+ ({
99
+ item: s,
100
+ variant: r = "compact",
101
+ surface: j = "flat",
102
+ size: v = "sm",
103
+ onActivate: o,
104
+ onToggleRead: b,
105
+ onDismiss: d,
106
+ ctaLabel: c,
107
+ dismissLabel: u,
108
+ leaving: g,
109
+ className: M,
110
+ ...V
111
+ }, _) => {
112
+ const { t: n, i18n: h } = J(), B = E(() => {
113
+ const e = new Date(s.createdAt);
114
+ return Number.isNaN(e.getTime()) ? "" : new Intl.DateTimeFormat(h.language, {
115
+ dateStyle: "medium",
116
+ timeStyle: "short"
117
+ }).format(e);
118
+ }, [s.createdAt, h.language]), f = g !== void 0, [I, P] = H(!1), m = X(null), x = f ? g : I, w = typeof window < "u" && typeof window.matchMedia == "function" && window.matchMedia("(prefers-reduced-motion: reduce)").matches, y = q(() => {
119
+ if (!d) return;
120
+ if (f || w) {
121
+ d(s);
122
+ return;
123
+ }
124
+ P(!0), m.current && clearTimeout(m.current);
125
+ const e = typeof window < "u" && window.getComputedStyle(document.documentElement).getPropertyValue("--animation-duration") || "200ms", T = e.trim().endsWith("ms") ? parseFloat(e) : parseFloat(e) * 1e3;
126
+ m.current = setTimeout(
127
+ () => d(s),
128
+ Number.isFinite(T) ? T : 200
129
+ );
130
+ }, [d, s, f, w]), R = s.read ? "read" : "unread", $ = s.read ? "" : n("notificationCard.unreadSuffix", ", unread"), N = n("notificationCard.itemLabel", {
131
+ title: s.title,
132
+ time: B,
133
+ unreadSuffix: $,
134
+ defaultValue: "{{title}}, {{time}}{{unreadSuffix}}"
135
+ }), p = !!s.url && A(s.url), F = v === "md" ? "ds:top-[var(--spacing-md)] ds:end-[var(--spacing-md)]" : "ds:top-[var(--spacing-sm)] ds:end-[var(--spacing-sm)]", C = "ds:absolute ds:top-[calc(var(--spacing-xs)*-1)] ds:end-[calc(var(--spacing-xs)*-1)] ds:z-[1]", D = "ds:block ds:size-[calc(var(--spacing-sm)+var(--spacing-xs))] ds:rounded-[var(--radius-full)] ds:bg-[color:var(--primary)] ds:ring-2 ds:ring-[color:var(--card)] ds:forced-colors:bg-[Highlight]", L = "ds:block ds:size-[calc(var(--spacing-sm)+var(--spacing-xs))] ds:rounded-[var(--radius-full)] ds:bg-[color:var(--card)] ds:border-2 ds:border-[color:color-mix(in_srgb,var(--muted-foreground)_55%,transparent)] ds:forced-colors:border-[CanvasText]", U = 'ds:cursor-pointer ds:outline-none ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid ds:focus-visible:outline-[color:var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)] ds:forced-colors:focus-visible:outline-[CanvasText] ds:before:absolute ds:before:inset-x-[calc((var(--min-target-size)-100%)/-2)] ds:before:inset-y-[calc((var(--min-target-size)-100%)/-2)] ds:before:content-[""] ds:sm:before:hidden', k = s.read ? L : D, z = r !== "compact" ? null : b ? /* @__PURE__ */ a(
136
+ "button",
137
+ {
138
+ type: "button",
139
+ onClick: () => b(s),
140
+ "aria-label": s.read ? n("notificationCard.markAsUnread", "Mark as unread") : n("notificationCard.markAsRead", "Mark as read"),
141
+ className: `${C} ${k} ${U}`
142
+ }
143
+ ) : /* @__PURE__ */ a("span", { "aria-hidden": "true", className: `${C} ${k}` }), i = /* @__PURE__ */ a(
144
+ "span",
145
+ {
146
+ className: [
147
+ "ds:flex-1 ds:min-w-0 ds:truncate",
148
+ s.read ? "ds:font-normal" : "ds:font-semibold"
149
+ ].join(" "),
150
+ children: s.title
151
+ }
152
+ );
153
+ let t;
154
+ return r === "compact" && p && o ? t = /* @__PURE__ */ a(
155
+ "a",
156
+ {
157
+ href: s.url,
158
+ "aria-label": N,
159
+ className: S + " ds:contents",
160
+ onClick: (e) => {
161
+ e.defaultPrevented || e.metaKey || e.ctrlKey || e.shiftKey || (e.preventDefault(), o(s));
162
+ },
163
+ children: i
164
+ }
165
+ ) : r === "compact" && o ? t = /* @__PURE__ */ a(
166
+ "button",
167
+ {
168
+ type: "button",
169
+ "aria-label": N,
170
+ className: S + " ds:contents ds:bg-transparent ds:border-0 ds:p-0",
171
+ onClick: () => o(s),
172
+ children: i
173
+ }
174
+ ) : r === "dashboard" && p && o ? t = /* @__PURE__ */ a(
175
+ "a",
176
+ {
177
+ href: s.url,
178
+ className: "ds:text-[color:var(--foreground)] ds:no-underline ds:hover:underline ds:focus-visible:outline-[length:var(--focus-ring-width)] ds:focus-visible:outline-solid ds:focus-visible:outline-[color:var(--ring)] ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]",
179
+ onClick: (e) => {
180
+ e.defaultPrevented || e.metaKey || e.ctrlKey || e.shiftKey || (e.preventDefault(), o(s));
181
+ },
182
+ children: i
183
+ }
184
+ ) : t = i, /* @__PURE__ */ l(
185
+ "div",
186
+ {
187
+ ref: _,
188
+ role: "listitem",
189
+ "data-component": "notification-card",
190
+ "data-component-id": s.id,
191
+ "data-read": s.read ? "true" : "false",
192
+ "data-leaving": x ? "true" : void 0,
193
+ "aria-hidden": x || void 0,
194
+ className: Z({
195
+ variant: r,
196
+ size: v,
197
+ state: R,
198
+ // Elevated chrome only applies to the compact row; the dashboard
199
+ // variant brings its own border + shadow.
200
+ surface: r === "compact" ? j : "flat",
201
+ className: M
202
+ }),
203
+ ...V,
204
+ children: [
205
+ s.icon || z ? /* @__PURE__ */ l("span", { className: "ds:relative ds:size-8 ds:shrink-0", children: [
206
+ s.icon ? /* @__PURE__ */ a(
207
+ "span",
208
+ {
209
+ "aria-hidden": "true",
210
+ className: "ds:inline-flex ds:size-8 ds:items-center ds:justify-center ds:rounded-[var(--radius-full)] ds:bg-[color:var(--accent)]/10 ds:text-[color:var(--accent)] ds:[&>svg]:size-4",
211
+ children: s.icon
212
+ }
213
+ ) : null,
214
+ z
215
+ ] }) : null,
216
+ /* @__PURE__ */ l("div", { className: "ds:flex-1 ds:min-w-0 ds:flex ds:flex-col ds:gap-[var(--spacing-xs)]", children: [
217
+ /* @__PURE__ */ a("div", { className: "ds:flex ds:items-center ds:gap-[var(--spacing-sm)]", children: r === "dashboard" ? (
218
+ // `h3` keeps the dashboard heading ladder continuous:
219
+ // h1 (page) → h2 (WarningStack + NotificationsPanel) → h3 (notification title).
220
+ /* @__PURE__ */ a("h3", { className: "ds:m-0 ds:flex-1 ds:min-w-0 type-title-item", children: t })
221
+ ) : /* @__PURE__ */ a("span", { className: "ds:flex-1 ds:min-w-0 type-title-item ds:text-[color:var(--foreground)]", children: t }) }),
222
+ s.description ? /* @__PURE__ */ a("p", { className: "ds:m-0 type-body-sm ds:text-[color:var(--muted-foreground)] ds:[overflow:hidden] ds:[display:-webkit-box] ds:[-webkit-box-orient:vertical] ds:[-webkit-line-clamp:2] ds:break-words", children: s.description }) : null,
223
+ /* @__PURE__ */ a(
224
+ Q,
225
+ {
226
+ value: s.createdAt,
227
+ shape: "chip",
228
+ size: "sm",
229
+ relativeWindow: 720 * 60 * 1e3
230
+ }
231
+ ),
232
+ r === "dashboard" && (c || u) ? /* @__PURE__ */ l("div", { className: "ds:flex ds:flex-wrap ds:items-center ds:gap-[var(--spacing-sm)]", children: [
233
+ c && p ? /* @__PURE__ */ a(
234
+ K,
235
+ {
236
+ intent: "outline",
237
+ size: "sm",
238
+ asChild: !0,
239
+ className: "ds:relative ds:z-[1]",
240
+ children: /* @__PURE__ */ a(
241
+ "a",
242
+ {
243
+ href: s.url,
244
+ onClick: (e) => {
245
+ e.defaultPrevented || e.metaKey || e.ctrlKey || e.shiftKey || (e.preventDefault(), o == null || o(s));
246
+ },
247
+ children: c
248
+ }
249
+ )
250
+ }
251
+ ) : null,
252
+ u && d ? /* @__PURE__ */ a(
253
+ K,
254
+ {
255
+ intent: "link",
256
+ size: "sm",
257
+ onClick: y,
258
+ className: "ds:relative ds:z-[1]",
259
+ children: u
260
+ }
261
+ ) : null
262
+ ] }) : null
263
+ ] }),
264
+ r === "compact" && d ? /* @__PURE__ */ a(
265
+ "span",
266
+ {
267
+ className: "ds:absolute ds:z-[2] ds:opacity-0 ds:pointer-events-none ds:transition-opacity ds:motion-reduce:transition-none ds:group-hover:opacity-100 ds:group-hover:pointer-events-auto ds:group-focus-within:opacity-100 ds:group-focus-within:pointer-events-auto " + F,
268
+ children: /* @__PURE__ */ a(
269
+ O,
270
+ {
271
+ icon: /* @__PURE__ */ a(Y, {}),
272
+ intent: "ghost",
273
+ size: "sm",
274
+ "aria-label": n("notificationCard.dismiss", "Dismiss notification"),
275
+ onClick: y
276
+ }
277
+ )
278
+ }
279
+ ) : null
280
+ ]
281
+ }
282
+ );
283
+ }
284
+ );
285
+ ss.displayName = "NotificationCard";
286
+ export {
287
+ ss as N,
288
+ A as i
289
+ };
290
+ //# sourceMappingURL=notification-card-BMqNzCIt.js.map