@alfadocs/ui-kit 0.68.0 → 0.70.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 (440) hide show
  1. package/dist/_chunks/{accordion-9lJSMMsZ.js → accordion-DnIa7OHX.js} +69 -47
  2. package/dist/_chunks/address-autocomplete-BEX9PXty.js +496 -0
  3. package/dist/_chunks/{agenda-card-BxSFkqgY.js → agenda-card-BQ-IKAru.js} +2 -2
  4. package/dist/_chunks/{agenda-card.agent-B_R47-c9.js → agenda-card.agent-mTCrkKSZ.js} +6 -1
  5. package/dist/_chunks/{agenda-tray-T-BumlGZ.js → agenda-tray-CGXRk58j.js} +37 -25
  6. package/dist/_chunks/{ai-consent-banner-Dxtx_WAh.js → ai-consent-banner-Be-h9mRI.js} +5 -5
  7. package/dist/_chunks/{ai-prompt-input-BwEACCPm.js → ai-prompt-input-CuhTo9mh.js} +80 -61
  8. package/dist/_chunks/ai-tools-rail-B5NEghsp.js +511 -0
  9. package/dist/_chunks/{alert-_mUKLmwA.js → alert-CHYZ96tR.js} +150 -96
  10. package/dist/_chunks/{alia-sidebar-Ckv0yCKi.js → alia-sidebar-B47qRQb5.js} +5 -5
  11. package/dist/_chunks/{anamnesis-card-N8pIKWuS.js → anamnesis-card-DvYCa16e.js} +3 -3
  12. package/dist/_chunks/anatomy-scheme-CJB6dI6p.js +2445 -0
  13. package/dist/_chunks/annotation-marker-qt5R9WZX.js +120 -0
  14. package/dist/_chunks/{antenatal-schedule-timeline-35ebkcZT.js → antenatal-schedule-timeline-CwXrQRm1.js} +2 -2
  15. package/dist/_chunks/appointment-card-C06aZqA7.js +310 -0
  16. package/dist/_chunks/appointment-timeline-BJM0S_Fg.js +386 -0
  17. package/dist/_chunks/appointment-tray-DRRw5ROi.js +193 -0
  18. package/dist/_chunks/{audio-recorder-DjXLP4aF.js → audio-recorder-Cpdk5qpQ.js} +60 -57
  19. package/dist/_chunks/{autocomplete-CcCFlVf-.js → autocomplete-DOeGouCL.js} +157 -132
  20. package/dist/_chunks/{badge-CqGsX32l.js → badge-DCOqV9mI.js} +32 -27
  21. package/dist/_chunks/bishop-score-DnYWtZa_.js +304 -0
  22. package/dist/_chunks/bmi-calculator-zjeY4E7J.js +434 -0
  23. package/dist/_chunks/{booking-L8-YP8BJ.js → booking-DUBI0oqt.js} +422 -399
  24. package/dist/_chunks/{breadcrumb-OTbaY70e.js → breadcrumb-CchdeG7d.js} +42 -28
  25. package/dist/_chunks/{calculator-dialog-CFk4I91b.js → calculator-dialog-BR5iU0kf.js} +2 -2
  26. package/dist/_chunks/{calendar-oYWOCrnf.js → calendar-CZUjL8SZ.js} +258 -201
  27. package/dist/_chunks/{care-plan-card-BwVUyUBb.js → care-plan-card-C5sTfY9G.js} +13 -9
  28. package/dist/_chunks/{care-plan-entry-card-VzdQHcOL.js → care-plan-entry-card-CXnxGCWA.js} +20 -16
  29. package/dist/_chunks/care-plan-header-BUwqDTtz.js +206 -0
  30. package/dist/_chunks/{carousel.agent-vt21A_el.js → carousel.agent-4v8Emr9E.js} +219 -198
  31. package/dist/_chunks/{chart-Cg3e9EH9.js → chart-CMr3eW62.js} +150 -109
  32. package/dist/_chunks/{chat-container-ogB4OskO.js → chat-container-DWho5hPR.js} +47 -34
  33. package/dist/_chunks/{chat-input-B5zjNEUN.js → chat-input-BcXTetgM.js} +57 -41
  34. package/dist/_chunks/{checkbox-DRcOdmXv.js → checkbox-BuZ1u__2.js} +41 -27
  35. package/dist/_chunks/{checkbox-group-CpUwlHug.js → checkbox-group-PqNmQ-cE.js} +3 -3
  36. package/dist/_chunks/clinical-note-card-BUvNMNGL.js +436 -0
  37. package/dist/_chunks/{collapsible-X3oaLPU3.js → collapsible-BrnRiCC6.js} +26 -23
  38. package/dist/_chunks/{color-picker-FXpItIaF.js → color-picker-C_fZl6sA.js} +124 -112
  39. package/dist/_chunks/{combobox-BC-DFx8G.js → combobox-Clum7gJ1.js} +165 -128
  40. package/dist/_chunks/{command-palette-BiPAAno-.js → command-palette-CJzmc5pC.js} +87 -64
  41. package/dist/_chunks/{contact-profile-card-7BMB85T6.js → contact-profile-card-DDPwRFiP.js} +13 -11
  42. package/dist/_chunks/control-room-rail-Y8ryLYsP.js +229 -0
  43. package/dist/_chunks/{copy-field-CCq7j6Zc.js → copy-field-Bjw9u2cV.js} +42 -35
  44. package/dist/_chunks/counter-dRlTNC_y.js +55 -0
  45. package/dist/_chunks/{cycle-calculator-BF0ointe.js → cycle-calculator-CCmPwcBl.js} +4 -4
  46. package/dist/_chunks/{date-picker-oGg5BnXL.js → date-picker-Dl9RKxaV.js} +76 -57
  47. package/dist/_chunks/{date-range-picker-C5BWfH_T.js → date-range-picker-CTUeR6Bj.js} +73 -46
  48. package/dist/_chunks/{date-time-picker-Ze1My59T.js → date-time-picker-BhoogS5Q.js} +64 -40
  49. package/dist/_chunks/{dependent-selector-DpzGtr_J.js → dependent-selector-DUV4thxX.js} +45 -31
  50. package/dist/_chunks/{dialog-DMGnSelc.js → dialog-ZNuboNmy.js} +35 -28
  51. package/dist/_chunks/{document-scanner-D2qehl3-.js → document-scanner-C_AxLooF.js} +13 -5
  52. package/dist/_chunks/{dropdown-menu-DwwPovMZ.js → dropdown-menu-qrxjymfw.js} +94 -93
  53. package/dist/_chunks/{due-date-calculator-DU9AEWNy.js → due-date-calculator-Brdj-euS.js} +6 -6
  54. package/dist/_chunks/editable-currency-cell-renderer-C9twtALM.js +328 -0
  55. package/dist/_chunks/email-input-DJ7EXklP.js +397 -0
  56. package/dist/_chunks/{entity-card-COhmqHly.js → entity-card-9_62gY7l.js} +38 -20
  57. package/dist/_chunks/entity-summary-BxRjFh_4.js +138 -0
  58. package/dist/_chunks/{fetal-weight-BVSzOhuR.js → fetal-weight-DNCkyeVo.js} +3 -3
  59. package/dist/_chunks/field-value-NXYczdpO.js +415 -0
  60. package/dist/_chunks/{file-upload-BosbPDb1.js → file-upload-DwZcAK8D.js} +119 -100
  61. package/dist/_chunks/{fiscal-code-input-DPtqluVb.js → fiscal-code-input-Cf-8O4Fj.js} +76 -63
  62. package/dist/_chunks/{freemium-paywall-CkWjv3o6.js → freemium-paywall-WYlNO7yT.js} +78 -71
  63. package/dist/_chunks/{gestational-age-calculator-DBlFdoiP.js → gestational-age-calculator-CF2ISaYQ.js} +7 -7
  64. package/dist/_chunks/hash-CysBBS_N.js +17 -0
  65. package/dist/_chunks/{hcg-doubling-if4Q8aSX.js → hcg-doubling-C7bmuaU3.js} +4 -4
  66. package/dist/_chunks/{header-settings-CNOqIhoW.js → header-settings-DJqoAl5m.js} +86 -46
  67. package/dist/_chunks/{index.modern-D2LGACWg.js → index.modern-Zta-A4Jm.js} +3 -3
  68. package/dist/_chunks/link-cell-renderer-CTXqtXV-.js +2184 -0
  69. package/dist/_chunks/{list-BOwqwy03.js → list-DgE1xWBM.js} +99 -84
  70. package/dist/_chunks/{locale-picker-C9JmBht3.js → locale-picker-ChYYSX2N.js} +47 -35
  71. package/dist/_chunks/lock-CKOIn0IK.js +15 -0
  72. package/dist/_chunks/{map-view-Tb5VfK9Y.js → map-view-BkOoGoX2.js} +160 -115
  73. package/dist/_chunks/{marketplace-app-shell-D4-T9Qzz.js → marketplace-app-shell-Skhfp6vK.js} +6 -6
  74. package/dist/_chunks/{message-card.agent-4IeIgrnJ.js → message-card.agent-ZLhx3Bs5.js} +6 -1
  75. package/dist/_chunks/{message-tray-CVyJajVJ.js → message-tray-DwrBLJlf.js} +90 -48
  76. package/dist/_chunks/{multi-select-BcPylvHR.js → multi-select-BdHHDrRN.js} +196 -153
  77. package/dist/_chunks/{navigation-menu-C6lBYVv9.js → navigation-menu-DRUi6sSj.js} +75 -42
  78. package/dist/_chunks/notes-panel-ay8_lPrA.js +158 -0
  79. package/dist/_chunks/{notification-card-BiESdm8q.js → notification-card-D2jiKSJJ.js} +27 -23
  80. package/dist/_chunks/{notification-card.agent-Rqt3ofk9.js → notification-card.agent-DxGBZb8T.js} +5 -1
  81. package/dist/_chunks/{notification-tray-DlgenTEe.js → notification-tray-AEun6DN2.js} +112 -97
  82. package/dist/_chunks/{number-input-Dj5L3pXK.js → number-input-DxphVG_A.js} +36 -27
  83. package/dist/_chunks/{operator-hero-f_KaRhw5.js → operator-hero-CR0Rqh4-.js} +14 -10
  84. package/dist/_chunks/{otp-input-xQ4Ps5VY.js → otp-input-DzBQ-CpE.js} +52 -33
  85. package/dist/_chunks/{pagination-DQOgnxxw.js → pagination-D58kglCr.js} +181 -162
  86. package/dist/_chunks/patient-details-Dlhqb5ig.js +675 -0
  87. package/dist/_chunks/{patient-search-DR9XUYRQ.js → patient-search-Be6cLrHR.js} +70 -61
  88. package/dist/_chunks/{patient-shell-BfgufL_q.js → patient-shell-DV3XEtIB.js} +3 -3
  89. package/dist/_chunks/patient-summary-card-WySCMwwA.js +437 -0
  90. package/dist/_chunks/patient-table-CHxf3Oqk.js +1110 -0
  91. package/dist/_chunks/{payment-form-nXocS_MX.js → payment-form-CxqIXqw7.js} +57 -45
  92. package/dist/_chunks/{payment-request-card-CYE5vhZ0.js → payment-request-card-BcZJwu9z.js} +125 -136
  93. package/dist/_chunks/{pdf-viewer-GsfNqeeT.js → pdf-viewer-QfebdLOd.js} +317 -291
  94. package/dist/_chunks/{periodontal-chart-card-Dh3KgvYG.js → periodontal-chart-card-hRRJY1NN.js} +3 -3
  95. package/dist/_chunks/{phone-input-DVXhNlIl.js → phone-input-DjU-XmO_.js} +64 -47
  96. package/dist/_chunks/{popover-DTbfAuR0.js → popover-B2qCDhJC.js} +37 -32
  97. package/dist/_chunks/{practice-results-DND2SAt7.js → practice-results-C6qDfxos.js} +280 -244
  98. package/dist/_chunks/{pregnancy-dating-QY-sqpvj.js → pregnancy-dating-CRVWswD-.js} +8 -8
  99. package/dist/_chunks/{pregnancy-weight-gain-DOJXXNYP.js → pregnancy-weight-gain-BUNpTsH-.js} +4 -4
  100. package/dist/_chunks/{privacy-lock-C7JyMf0y.js → privacy-lock-BzMLQu-j.js} +32 -28
  101. package/dist/_chunks/{product-hub-panel-CAXDFeGP.js → product-hub-panel-e6pW220e.js} +45 -27
  102. package/dist/_chunks/{progress-kzIRcdaq.js → progress-DA413-zn.js} +2 -2
  103. package/dist/_chunks/{public-footer.agent-CfXuW1x6.js → public-footer.agent-D0cFbjWl.js} +151 -146
  104. package/dist/_chunks/{public-header.agent-BOhJgZEU.js → public-header.agent-DqkqA-ca.js} +107 -102
  105. package/dist/_chunks/{qr-code-DNXhi6se.js → qr-code-CPkEs5mG.js} +52 -46
  106. package/dist/_chunks/{radio-group-CLjK-SlK.js → radio-group-BPt7pKZW.js} +5 -5
  107. package/dist/_chunks/radiograph-panel.agent-CAX-C3g3.js +558 -0
  108. package/dist/_chunks/{recaptcha-widget-BCNHsgqt.js → recaptcha-widget-BC-4To9b.js} +9 -2
  109. package/dist/_chunks/registry-DvAUVLHh.js +51 -0
  110. package/dist/_chunks/{resizable-3vzqDlg6.js → resizable-DVGcfOrk.js} +193 -173
  111. package/dist/_chunks/{reviews-panel-DBktKm7i.js → reviews-panel-Dq7LMDcH.js} +87 -68
  112. package/dist/_chunks/{rich-text-editor-VawKN1FI.js → rich-text-editor-DlCqPixb.js} +833 -728
  113. package/dist/_chunks/{search-bar-SY2BcV2N.js → search-bar-C_T3pBJn.js} +105 -78
  114. package/dist/_chunks/{search-input-DbxrnHkW.js → search-input-DQvGxR74.js} +2 -2
  115. package/dist/_chunks/{search-input.agent-CfZvViOd.js → search-input.agent-DRH54coT.js} +19 -4
  116. package/dist/_chunks/{select-CEtRcon5.js → select-DMLG44F5.js} +72 -56
  117. package/dist/_chunks/{session-countdown-LPnhTHjn.js → session-countdown-X1Ki6i0M.js} +3 -3
  118. package/dist/_chunks/{sheet-taJer-Ha.js → sheet-BxsE7eQm.js} +59 -45
  119. package/dist/_chunks/{sidebar-DaB4ulxH.js → sidebar-DY9jGjgt.js} +254 -248
  120. package/dist/_chunks/{sign-document-CdAiHiCh.js → sign-document-By6hMOra.js} +75 -49
  121. package/dist/_chunks/{signature-capture-COi0Uiqu.js → signature-capture-Ct_4Md4e.js} +138 -104
  122. package/dist/_chunks/{slider-BHWzXdjt.js → slider-DN1CWkKB.js} +85 -65
  123. package/dist/_chunks/{sparkline-DGhCSw8M.js → sparkline-iOXYgvJe.js} +75 -53
  124. package/dist/_chunks/{stepper-accordion-Dki6r9ZE.js → stepper-accordion-DC-H-8v4.js} +38 -48
  125. package/dist/_chunks/{stepper-accordion.agent-C4quJ-MD.js → stepper-accordion.agent-cmEguIdx.js} +7 -1
  126. package/dist/_chunks/{stepper-progress-DDjq5nei.js → stepper-progress-Bv0njx4g.js} +30 -24
  127. package/dist/_chunks/{suggestion-chip.agent-6sNWFj7m.js → suggestion-chip.agent-Brn3CiFE.js} +9 -8
  128. package/dist/_chunks/{switch-BJ6HD3Mn.js → switch-OILsBLWo.js} +25 -19
  129. package/dist/_chunks/tab-bar-Bv9nGNdO.js +262 -0
  130. package/dist/_chunks/{tabs-BIQ0ew1T.js → tabs-BxcOziCo.js} +67 -58
  131. package/dist/_chunks/{task-card.agent-CUPKYd7w.js → task-card.agent-Bt14CzUd.js} +4 -1
  132. package/dist/_chunks/{task-tray-CAncV-QQ.js → task-tray-qOEQflu4.js} +74 -57
  133. package/dist/_chunks/{text-area-BIx0tZ05.js → text-area-Bt3p7Pt0.js} +41 -34
  134. package/dist/_chunks/{text-input-BaClJL8Y.js → text-input-B-OWQ1Je.js} +15 -8
  135. package/dist/_chunks/{theme-toggle-DETmSu_h.js → theme-toggle-XB6o_lgs.js} +38 -26
  136. package/dist/_chunks/{time-picker-B5umYwfv.js → time-picker-BPlJWm8w.js} +41 -31
  137. package/dist/_chunks/{timeline-DQa5Tyz4.js → timeline-CqA4nKTI.js} +33 -25
  138. package/dist/_chunks/{toast.agent-vuLRRn2a.js → toast.agent-57UzyR9U.js} +62 -45
  139. package/dist/_chunks/tooth-scheme-BhQoPNBD.js +2131 -0
  140. package/dist/_chunks/{transaction-chip-DK84XCBU.js → transaction-chip-CscoQbxF.js} +88 -61
  141. package/dist/_chunks/{transcript-panel-CLHmv83g.js → transcript-panel-3THQX6nJ.js} +47 -33
  142. package/dist/_chunks/unit-converter-YEpD9evj.js +337 -0
  143. package/dist/_chunks/use-clamp-overflow-DQE2kwZ9.js +20 -0
  144. package/dist/_chunks/use-overflow-collapse-BIOzKbni.js +32 -0
  145. package/dist/_chunks/{use-password-requirements-DsgduV1x.js → use-password-requirements-BXvS2MBS.js} +131 -117
  146. package/dist/_chunks/use-persistent-state-nZwZAnE9.js +24 -0
  147. package/dist/_chunks/users-MBVtUzwd.js +17 -0
  148. package/dist/_chunks/warning-stack--sTrrBDA.js +268 -0
  149. package/dist/_chunks/{whatsapp-button-DUjlWGKf.js → whatsapp-button-BIy6NaJK.js} +6 -3
  150. package/dist/_chunks/{workflow-map-JAZryZJr.js → workflow-map-Dy8mLCqF.js} +101 -90
  151. package/dist/_chunks/zoom-out-CgVtf2Wx.js +29 -0
  152. package/dist/agent/index.d.ts +4 -4
  153. package/dist/agent/index.js +37 -0
  154. package/dist/agent/registry.d.ts +33 -0
  155. package/dist/agent/types.d.ts +97 -4
  156. package/dist/agent-catalog.json +8081 -518
  157. package/dist/agent-i18n/en.json +1277 -0
  158. package/dist/components/_shared/entity-card/entity-card.d.ts +6 -0
  159. package/dist/components/_shared/entity-card/index.d.ts +1 -1
  160. package/dist/components/_shared/field-value.d.ts +21 -0
  161. package/dist/components/_shared/field-visibility-cog.d.ts +20 -0
  162. package/dist/components/_shared/field-visibility.d.ts +36 -0
  163. package/dist/components/_shared/patient-fields.d.ts +119 -0
  164. package/dist/components/accordion/index.js +1 -1
  165. package/dist/components/address-autocomplete/address-autocomplete.agent.d.ts +4 -0
  166. package/dist/components/address-autocomplete/address-autocomplete.d.ts +18 -0
  167. package/dist/components/address-autocomplete/index.d.ts +2 -1
  168. package/dist/components/address-autocomplete/index.js +3 -2
  169. package/dist/components/agenda-card/index.js +2 -2
  170. package/dist/components/agenda-tray/index.js +1 -1
  171. package/dist/components/ai-consent-banner/index.js +1 -1
  172. package/dist/components/ai-prompt-input/index.js +1 -1
  173. package/dist/components/ai-tools-rail/ai-tools-rail.d.ts +75 -0
  174. package/dist/components/ai-tools-rail/index.js +1 -1
  175. package/dist/components/alert/alert.d.ts +5 -0
  176. package/dist/components/alert/index.js +1 -1
  177. package/dist/components/anamnesis-card/index.js +1 -1
  178. package/dist/components/anatomy-scheme/anatomy-face-paths.d.ts +15 -0
  179. package/dist/components/anatomy-scheme/anatomy-muscle-paths.d.ts +20 -0
  180. package/dist/components/anatomy-scheme/anatomy-scheme-data.d.ts +121 -0
  181. package/dist/components/anatomy-scheme/anatomy-scheme.agent.d.ts +6 -0
  182. package/dist/components/anatomy-scheme/anatomy-scheme.d.ts +69 -0
  183. package/dist/components/anatomy-scheme/index.d.ts +6 -0
  184. package/dist/components/anatomy-scheme/index.js +17 -0
  185. package/dist/components/annotation-marker/annotation-marker.d.ts +33 -0
  186. package/dist/components/annotation-marker/index.d.ts +3 -0
  187. package/dist/components/annotation-marker/index.js +7 -0
  188. package/dist/components/appointment-card/appointment-card.d.ts +25 -1
  189. package/dist/components/appointment-card/index.js +6 -5
  190. package/dist/components/appointment-timeline/appointment-timeline.agent.d.ts +4 -0
  191. package/dist/components/appointment-timeline/appointment-timeline.d.ts +66 -0
  192. package/dist/components/appointment-timeline/index.d.ts +4 -0
  193. package/dist/components/appointment-timeline/index.js +6 -0
  194. package/dist/components/audio-recorder/index.js +1 -1
  195. package/dist/components/autocomplete/index.js +1 -1
  196. package/dist/components/badge/badge.d.ts +6 -2
  197. package/dist/components/badge/index.js +1 -1
  198. package/dist/components/bishop-score/bishop-score.agent.d.ts +4 -0
  199. package/dist/components/bishop-score/bishop-score.d.ts +17 -1
  200. package/dist/components/bishop-score/index.js +1 -1
  201. package/dist/components/bmi-calculator/bmi-calculator.agent.d.ts +4 -0
  202. package/dist/components/bmi-calculator/bmi-calculator.d.ts +26 -0
  203. package/dist/components/bmi-calculator/index.js +1 -1
  204. package/dist/components/booking/index.js +1 -1
  205. package/dist/components/breadcrumb/index.js +1 -1
  206. package/dist/components/calculator-dialog/index.js +1 -1
  207. package/dist/components/calendar/index.js +1 -1
  208. package/dist/components/care-plan-card/index.js +1 -1
  209. package/dist/components/care-plan-entry-card/index.js +1 -1
  210. package/dist/components/care-plan-header/care-plan-header.agent.d.ts +4 -0
  211. package/dist/components/care-plan-header/care-plan-header.d.ts +100 -0
  212. package/dist/components/care-plan-header/index.d.ts +4 -0
  213. package/dist/components/care-plan-header/index.js +6 -0
  214. package/dist/components/carousel/index.js +1 -1
  215. package/dist/components/chart/index.js +1 -1
  216. package/dist/components/chat-container/index.js +1 -1
  217. package/dist/components/chat-input/index.js +1 -1
  218. package/dist/components/checkbox/index.js +1 -1
  219. package/dist/components/checkbox-group/index.js +1 -1
  220. package/dist/components/clinical-note-card/clinical-note-card.d.ts +21 -1
  221. package/dist/components/clinical-note-card/index.js +1 -1
  222. package/dist/components/collapsible/index.js +1 -1
  223. package/dist/components/color-picker/index.js +1 -1
  224. package/dist/components/combobox/index.js +1 -1
  225. package/dist/components/command-palette/index.js +1 -1
  226. package/dist/components/contact-profile-card/index.js +1 -1
  227. package/dist/components/control-room-rail/control-room-context.d.ts +53 -0
  228. package/dist/components/control-room-rail/control-room-rail.d.ts +35 -0
  229. package/dist/components/control-room-rail/index.d.ts +5 -0
  230. package/dist/components/control-room-rail/index.js +9 -0
  231. package/dist/components/copy-field/index.js +1 -1
  232. package/dist/components/counter/counter.d.ts +22 -0
  233. package/dist/components/counter/index.d.ts +3 -0
  234. package/dist/components/counter/index.js +5 -0
  235. package/dist/components/cycle-calculator/index.js +1 -1
  236. package/dist/components/data-table/cell-renderers/actions-cell-renderer.d.ts +18 -0
  237. package/dist/components/data-table/index.d.ts +1 -1
  238. package/dist/components/data-table/index.js +32 -30
  239. package/dist/components/date-picker/index.js +1 -1
  240. package/dist/components/date-range-picker/index.js +1 -1
  241. package/dist/components/date-time-picker/index.js +1 -1
  242. package/dist/components/dependent-selector/index.js +1 -1
  243. package/dist/components/dialog/index.js +1 -1
  244. package/dist/components/document-scanner/index.js +1 -1
  245. package/dist/components/dropdown-menu/index.js +1 -1
  246. package/dist/components/due-date-calculator/index.js +2 -2
  247. package/dist/components/email-input/index.js +1 -1
  248. package/dist/components/entity-summary/entity-summary.d.ts +43 -0
  249. package/dist/components/entity-summary/index.d.ts +3 -0
  250. package/dist/components/entity-summary/index.js +5 -0
  251. package/dist/components/fetal-weight/index.js +1 -1
  252. package/dist/components/file-upload/index.js +1 -1
  253. package/dist/components/fiscal-code-input/index.js +1 -1
  254. package/dist/components/freemium-paywall/freemium-paywall.d.ts +6 -0
  255. package/dist/components/freemium-paywall/index.js +1 -1
  256. package/dist/components/gestational-age-calculator/index.js +1 -1
  257. package/dist/components/hcg-doubling/index.js +1 -1
  258. package/dist/components/header-settings/index.js +1 -1
  259. package/dist/components/index.d.ts +11 -0
  260. package/dist/components/list/index.js +1 -1
  261. package/dist/components/locale-picker/index.js +1 -1
  262. package/dist/components/map-view/index.js +1 -1
  263. package/dist/components/message-card/index.js +1 -1
  264. package/dist/components/message-tray/index.js +1 -1
  265. package/dist/components/multi-select/index.js +1 -1
  266. package/dist/components/navigation-menu/index.js +1 -1
  267. package/dist/components/notes-panel/index.d.ts +3 -0
  268. package/dist/components/notes-panel/index.js +5 -0
  269. package/dist/components/notes-panel/notes-panel.d.ts +64 -0
  270. package/dist/components/notification-card/index.js +2 -2
  271. package/dist/components/notification-tray/index.js +1 -1
  272. package/dist/components/number-input/index.js +1 -1
  273. package/dist/components/operator-hero/index.js +1 -1
  274. package/dist/components/otp-input/index.js +1 -1
  275. package/dist/components/pagination/index.js +1 -1
  276. package/dist/components/password-input/index.js +1 -1
  277. package/dist/components/patient-details/index.d.ts +5 -0
  278. package/dist/components/patient-details/index.js +6 -0
  279. package/dist/components/patient-details/patient-details.agent.d.ts +4 -0
  280. package/dist/components/patient-details/patient-details.d.ts +96 -0
  281. package/dist/components/patient-search/index.js +1 -1
  282. package/dist/components/patient-summary-card/index.js +1 -1
  283. package/dist/components/patient-summary-card/patient-summary-card.d.ts +40 -1
  284. package/dist/components/patient-table/cell-renderers/balance-badge-cell.d.ts +13 -0
  285. package/dist/components/patient-table/cell-renderers/care-plan-status-cell.d.ts +43 -0
  286. package/dist/components/patient-table/cell-renderers/next-appointment-cell.d.ts +24 -0
  287. package/dist/components/patient-table/columns.d.ts +131 -0
  288. package/dist/components/patient-table/index.d.ts +20 -0
  289. package/dist/components/patient-table/index.js +12 -0
  290. package/dist/components/patient-table/patient-table.d.ts +172 -0
  291. package/dist/components/patient-table/types.d.ts +222 -0
  292. package/dist/components/patient-table/use-responsive-columns.d.ts +111 -0
  293. package/dist/components/payment-card/index.js +1 -1
  294. package/dist/components/payment-form/index.js +1 -1
  295. package/dist/components/pdf-viewer/index.js +1 -1
  296. package/dist/components/periodontal-chart-card/index.js +1 -1
  297. package/dist/components/phone-input/index.js +1 -1
  298. package/dist/components/popover/index.js +1 -1
  299. package/dist/components/practice-results/index.js +1 -1
  300. package/dist/components/pregnancy-dating/index.js +1 -1
  301. package/dist/components/pregnancy-weight-gain/index.js +1 -1
  302. package/dist/components/privacy-lock/index.js +1 -1
  303. package/dist/components/product-hub-tray/index.js +1 -1
  304. package/dist/components/progress/index.js +1 -1
  305. package/dist/components/public-footer/index.js +1 -1
  306. package/dist/components/public-header/index.js +1 -1
  307. package/dist/components/qr-code/index.js +1 -1
  308. package/dist/components/radio-group/index.js +1 -1
  309. package/dist/components/radiograph-panel/index.d.ts +4 -0
  310. package/dist/components/radiograph-panel/index.js +7 -0
  311. package/dist/components/radiograph-panel/radiograph-panel.agent.d.ts +13 -0
  312. package/dist/components/radiograph-panel/radiograph-panel.d.ts +36 -0
  313. package/dist/components/recaptcha-widget/index.js +1 -1
  314. package/dist/components/resizable/index.js +1 -1
  315. package/dist/components/reviews-panel/index.js +1 -1
  316. package/dist/components/rich-text-editor/index.js +1 -1
  317. package/dist/components/search-bar/index.js +1 -1
  318. package/dist/components/search-input/index.js +2 -2
  319. package/dist/components/select/index.js +1 -1
  320. package/dist/components/session-countdown/index.js +1 -1
  321. package/dist/components/sheet/index.js +1 -1
  322. package/dist/components/sidebar/index.js +2 -2
  323. package/dist/components/sidebar/sidebar.d.ts +7 -0
  324. package/dist/components/sign-document/index.js +1 -1
  325. package/dist/components/signature-capture/index.js +1 -1
  326. package/dist/components/slider/index.js +1 -1
  327. package/dist/components/sparkline/index.js +1 -1
  328. package/dist/components/stepper-accordion/index.js +2 -2
  329. package/dist/components/stepper-progress/index.js +1 -1
  330. package/dist/components/suggestion-chip/index.js +1 -1
  331. package/dist/components/switch/index.js +1 -1
  332. package/dist/components/tab-bar/index.js +1 -1
  333. package/dist/components/tab-bar/tab-bar.d.ts +18 -1
  334. package/dist/components/tabs/index.js +1 -1
  335. package/dist/components/task-card/index.js +1 -1
  336. package/dist/components/task-tray/index.js +1 -1
  337. package/dist/components/text-area/index.js +1 -1
  338. package/dist/components/text-input/index.js +1 -1
  339. package/dist/components/theme-toggle/index.js +1 -1
  340. package/dist/components/time-picker/index.js +1 -1
  341. package/dist/components/timeline/index.js +1 -1
  342. package/dist/components/toast/index.js +1 -1
  343. package/dist/components/tooth-scheme/index.d.ts +2 -2
  344. package/dist/components/tooth-scheme/index.js +30 -23
  345. package/dist/components/tooth-scheme/tooth-data.d.ts +112 -1
  346. package/dist/components/tooth-scheme/tooth-scheme.agent.d.ts +2 -2
  347. package/dist/components/tooth-scheme/tooth-scheme.d.ts +75 -11
  348. package/dist/components/transaction-chip/index.js +1 -1
  349. package/dist/components/transaction-chip/transaction-chip.d.ts +2 -2
  350. package/dist/components/transcript-panel/index.js +1 -1
  351. package/dist/components/unit-converter/index.js +1 -1
  352. package/dist/components/unit-converter/unit-converter.agent.d.ts +4 -0
  353. package/dist/components/unit-converter/unit-converter.d.ts +27 -0
  354. package/dist/components/warning-stack/index.js +1 -1
  355. package/dist/components/warning-stack/warning-stack.d.ts +14 -2
  356. package/dist/components/whatsapp-button/index.d.ts +1 -1
  357. package/dist/components/whatsapp-button/index.js +3 -2
  358. package/dist/components/whatsapp-button/whatsapp-button.d.ts +3 -0
  359. package/dist/components/workflow/index.js +1 -1
  360. package/dist/hooks/index.d.ts +1 -0
  361. package/dist/hooks/index.js +24 -22
  362. package/dist/hooks/use-clamp-overflow.d.ts +19 -0
  363. package/dist/hooks/use-overflow-collapse.d.ts +46 -0
  364. package/dist/hooks/use-persistent-state.d.ts +7 -1
  365. package/dist/hooks/use-scroll-overflow.d.ts +36 -0
  366. package/dist/i18n/locales/ar.d.ts +356 -0
  367. package/dist/i18n/locales/ar.js +370 -3
  368. package/dist/i18n/locales/de.d.ts +356 -0
  369. package/dist/i18n/locales/de.js +370 -3
  370. package/dist/i18n/locales/el.d.ts +356 -0
  371. package/dist/i18n/locales/el.js +370 -3
  372. package/dist/i18n/locales/en.d.ts +367 -0
  373. package/dist/i18n/locales/en.js +381 -3
  374. package/dist/i18n/locales/es.d.ts +356 -0
  375. package/dist/i18n/locales/es.js +370 -3
  376. package/dist/i18n/locales/fr.d.ts +356 -0
  377. package/dist/i18n/locales/fr.js +370 -3
  378. package/dist/i18n/locales/hi.d.ts +356 -0
  379. package/dist/i18n/locales/hi.js +370 -3
  380. package/dist/i18n/locales/it.d.ts +356 -0
  381. package/dist/i18n/locales/it.js +370 -3
  382. package/dist/i18n/locales/ja.d.ts +356 -0
  383. package/dist/i18n/locales/ja.js +370 -3
  384. package/dist/i18n/locales/nl.d.ts +356 -0
  385. package/dist/i18n/locales/nl.js +370 -3
  386. package/dist/i18n/locales/pl.d.ts +356 -0
  387. package/dist/i18n/locales/pl.js +370 -3
  388. package/dist/i18n/locales/pt.d.ts +356 -0
  389. package/dist/i18n/locales/pt.js +370 -3
  390. package/dist/i18n/locales/ro.d.ts +356 -0
  391. package/dist/i18n/locales/ro.js +370 -3
  392. package/dist/i18n/locales/ru.d.ts +356 -0
  393. package/dist/i18n/locales/ru.js +370 -3
  394. package/dist/i18n/locales/sq.d.ts +356 -0
  395. package/dist/i18n/locales/sq.js +370 -3
  396. package/dist/i18n/locales/sv.d.ts +356 -0
  397. package/dist/i18n/locales/sv.js +370 -3
  398. package/dist/i18n/locales/tr.d.ts +356 -0
  399. package/dist/i18n/locales/tr.js +370 -3
  400. package/dist/i18n/locales/zh.d.ts +356 -0
  401. package/dist/i18n/locales/zh.js +370 -3
  402. package/dist/index.js +740 -676
  403. package/dist/locales/ar.json +359 -3
  404. package/dist/locales/de.json +359 -3
  405. package/dist/locales/el.json +359 -3
  406. package/dist/locales/en.json +359 -3
  407. package/dist/locales/es.json +359 -3
  408. package/dist/locales/fr.json +359 -3
  409. package/dist/locales/hi.json +359 -3
  410. package/dist/locales/it.json +359 -3
  411. package/dist/locales/ja.json +359 -3
  412. package/dist/locales/nl.json +359 -3
  413. package/dist/locales/pl.json +359 -3
  414. package/dist/locales/pt.json +359 -3
  415. package/dist/locales/ro.json +359 -3
  416. package/dist/locales/ru.json +359 -3
  417. package/dist/locales/sq.json +359 -3
  418. package/dist/locales/sv.json +359 -3
  419. package/dist/locales/tr.json +359 -3
  420. package/dist/locales/zh.json +359 -3
  421. package/dist/patterns/alia-assistant/index.js +1 -1
  422. package/dist/patterns/marketplace-app-shell/index.js +1 -1
  423. package/dist/patterns/patient-shell/index.js +1 -1
  424. package/dist/tokens.css +3 -2
  425. package/package.json +50 -1
  426. package/dist/_chunks/address-autocomplete-CT-9AOli.js +0 -358
  427. package/dist/_chunks/ai-tools-rail-CInA_1-E.js +0 -356
  428. package/dist/_chunks/appointment-tray-BMl89NPW.js +0 -419
  429. package/dist/_chunks/bishop-score-CjsB9bM-.js +0 -185
  430. package/dist/_chunks/bmi-calculator-n-823_1V.js +0 -258
  431. package/dist/_chunks/clinical-note-card-gtrxv6zn.js +0 -333
  432. package/dist/_chunks/editable-currency-cell-renderer-DHOspPee.js +0 -2409
  433. package/dist/_chunks/email-input-lQivsFrw.js +0 -396
  434. package/dist/_chunks/patient-summary-card-hEmr4eTW.js +0 -443
  435. package/dist/_chunks/registry-nPAVE19X.js +0 -21
  436. package/dist/_chunks/tab-bar-B1ovILzh.js +0 -105
  437. package/dist/_chunks/tooth-scheme-BIx1O2aJ.js +0 -1257
  438. package/dist/_chunks/unit-converter-C1V3ACM9.js +0 -196
  439. package/dist/_chunks/use-persistent-state-i23OWy6G.js +0 -24
  440. package/dist/_chunks/warning-stack-Cv4fr5zo.js +0 -220
@@ -1,5 +1,5 @@
1
1
  import { M as a } from "../../_chunks/message-card-Bx4GmLvf.js";
2
- import { m as o } from "../../_chunks/message-card.agent-4IeIgrnJ.js";
2
+ import { m as o } from "../../_chunks/message-card.agent-ZLhx3Bs5.js";
3
3
  import { i as f } from "../../_chunks/is-safe-url-DkETxeHz.js";
4
4
  export {
5
5
  a as MessageCard,
@@ -1,4 +1,4 @@
1
- import { M as s, m as r } from "../../_chunks/message-tray-CVyJajVJ.js";
1
+ import { M as s, m as r } from "../../_chunks/message-tray-DwrBLJlf.js";
2
2
  export {
3
3
  s as MessageTray,
4
4
  r as messageTrayAgent
@@ -1,4 +1,4 @@
1
- import { M as a, m as l, a as i } from "../../_chunks/multi-select-BcPylvHR.js";
1
+ import { M as a, m as l, a as i } from "../../_chunks/multi-select-BdHHDrRN.js";
2
2
  export {
3
3
  a as MultiSelect,
4
4
  l as multiSelectAgent,
@@ -1,4 +1,4 @@
1
- import { N as i, a as t, b as e, c as o, d as g, e as s, f as u, g as v, n as M } from "../../_chunks/navigation-menu-C6lBYVv9.js";
1
+ import { N as i, a as t, b as e, c as o, d as g, e as s, f as u, g as v, n as M } from "../../_chunks/navigation-menu-DRUi6sSj.js";
2
2
  import { S as r } from "../../_chunks/skip-link-BaSMtPwB.js";
3
3
  export {
4
4
  i as NavigationMenu,
@@ -0,0 +1,3 @@
1
+ export { NotesPanel } from './notes-panel';
2
+ export type { NotesPanelProps, NotesPanelNote } from './notes-panel';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,5 @@
1
+ import { N as a } from "../../_chunks/notes-panel-ay8_lPrA.js";
2
+ export {
3
+ a as NotesPanel
4
+ };
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,64 @@
1
+ import { type HTMLAttributes, type ReactNode } from 'react';
2
+ import type { ClinicalNoteCardProps } from '../clinical-note-card';
3
+ import type { RichTextEditorProps, RichTextEditorToolbar, RedactorFactory } from '../rich-text-editor';
4
+ /** One note in the panel — the data subset of `ClinicalNoteCard`. */
5
+ export type NotesPanelNote = Pick<ClinicalNoteCardProps, 'id' | 'dateIso' | 'createdAtIso' | 'author' | 'clinical' | 'attachedTo' | 'content' | 'contentFormat' | 'pinned' | 'flagged'>;
6
+ /** Payload handed to `onAddNote` when the composer commits. */
7
+ export interface NotesPanelSubmission {
8
+ /** The note body — rich HTML (`composer='rich'`) or plain text. */
9
+ content: string;
10
+ /** Whether the "clinical note" toggle was set. */
11
+ clinical: boolean;
12
+ }
13
+ export interface NotesPanelProps extends Omit<HTMLAttributes<HTMLElement>, 'title' | 'children'> {
14
+ /** Notes to render, newest-first by convention. Pinned notes lead. */
15
+ notes: NotesPanelNote[];
16
+ /** Commit a new note. Omit to hide the composer (read-only timeline). */
17
+ onAddNote?: (submission: NotesPanelSubmission) => void;
18
+ /**
19
+ * `'rich'` (default) mounts the kit `RichTextEditor` (Redactor; degrades to a
20
+ * textarea where Redactor is absent). `'plain'` keeps a simple `TextArea` for
21
+ * lightweight surfaces / deterministic tests.
22
+ */
23
+ composer?: 'rich' | 'plain';
24
+ /** Toolbar preset for the rich composer. Defaults to `'standard'`. */
25
+ editorToolbar?: RichTextEditorToolbar;
26
+ /** Inject the Redactor factory for the rich composer (else `window.$R`). */
27
+ redactor?: RedactorFactory;
28
+ /** Consumer image-upload endpoint for the rich composer. */
29
+ imageUploadUrl?: string;
30
+ /** Show the "clinical note" toggle in the composer. Default `true`. */
31
+ showClinicalToggle?: boolean;
32
+ /**
33
+ * Permission gate — when `false` the clinical toggle is disabled and shows
34
+ * `clinicalGatedReason` on hover/focus. Mirrors platform's
35
+ * `practice_add_clinical_note` permission. Default `true`.
36
+ */
37
+ canAddClinicalNote?: boolean;
38
+ /** Tooltip shown when the clinical toggle is gated off. */
39
+ clinicalGatedReason?: string;
40
+ /** Initial state of the clinical toggle. Default `false`. */
41
+ defaultClinical?: boolean;
42
+ onRequestAiDraft?: RichTextEditorProps['onRequestAiDraft'];
43
+ aiDraftFormat?: RichTextEditorProps['aiDraftFormat'];
44
+ aiPrivacyNotice?: RichTextEditorProps['aiPrivacyNotice'];
45
+ onDictate?: RichTextEditorProps['onDictate'];
46
+ onProofread?: RichTextEditorProps['onProofread'];
47
+ onAutoFormat?: RichTextEditorProps['onAutoFormat'];
48
+ /** Toggle a note's pinned state — renders an inline pin button per note. */
49
+ onTogglePin?: (id: string) => void;
50
+ /** Toggle a note's flagged state — renders an inline flag button per note. */
51
+ onToggleFlag?: (id: string) => void;
52
+ /** Panel heading. Defaults to the localised "Notes". */
53
+ title?: string;
54
+ /** Composer placeholder. */
55
+ composerPlaceholder?: string;
56
+ /** Save-button label. */
57
+ addNoteLabel?: string;
58
+ /** Rendered when there are no notes. */
59
+ emptyState?: ReactNode;
60
+ /** Accessible name for the panel region (defaults to `title`). */
61
+ 'aria-label'?: string;
62
+ }
63
+ export declare const NotesPanel: import("react").ForwardRefExoticComponent<NotesPanelProps & import("react").RefAttributes<HTMLElement>>;
64
+ //# sourceMappingURL=notes-panel.d.ts.map
@@ -1,5 +1,5 @@
1
- import { N as a, i as t } from "../../_chunks/notification-card-BiESdm8q.js";
2
- import { n as f } from "../../_chunks/notification-card.agent-Rqt3ofk9.js";
1
+ import { N as a, i as t } from "../../_chunks/notification-card-D2jiKSJJ.js";
2
+ import { n as f } from "../../_chunks/notification-card.agent-DxGBZb8T.js";
3
3
  export {
4
4
  a as NotificationCard,
5
5
  t as isSafeNotificationUrl,
@@ -1,4 +1,4 @@
1
- import { N as o, n as t } from "../../_chunks/notification-tray-DlgenTEe.js";
1
+ import { N as o, n as t } from "../../_chunks/notification-tray-AEun6DN2.js";
2
2
  export {
3
3
  o as NotificationTray,
4
4
  t as notificationTrayAgent
@@ -1,4 +1,4 @@
1
- import { N as r, u as a } from "../../_chunks/number-input-Dj5L3pXK.js";
1
+ import { N as r, u as a } from "../../_chunks/number-input-DxphVG_A.js";
2
2
  export {
3
3
  r as NumberInput,
4
4
  a as useLocaleNumber
@@ -1,4 +1,4 @@
1
- import { O as e, o as a } from "../../_chunks/operator-hero-f_KaRhw5.js";
1
+ import { O as e, o as a } from "../../_chunks/operator-hero-CR0Rqh4-.js";
2
2
  export {
3
3
  e as OperatorHero,
4
4
  a as operatorHeroAgent
@@ -1,4 +1,4 @@
1
- import { O as r } from "../../_chunks/otp-input-xQ4Ps5VY.js";
1
+ import { O as r } from "../../_chunks/otp-input-DzBQ-CpE.js";
2
2
  export {
3
3
  r as OTPInput
4
4
  };
@@ -1,4 +1,4 @@
1
- import { P as n, a as s, b as t, c as g, d as o, e as P, f as e, g as p, p as l } from "../../_chunks/pagination-DQOgnxxw.js";
1
+ import { P as n, a as s, b as t, c as g, d as o, e as P, f as e, g as p, p as l } from "../../_chunks/pagination-D58kglCr.js";
2
2
  export {
3
3
  n as Pagination,
4
4
  s as PaginationEllipsis,
@@ -1,4 +1,4 @@
1
- import { P as r, u as a } from "../../_chunks/use-password-requirements-DsgduV1x.js";
1
+ import { P as r, u as a } from "../../_chunks/use-password-requirements-BXvS2MBS.js";
2
2
  export {
3
3
  r as PasswordInput,
4
4
  a as usePasswordRequirements
@@ -0,0 +1,5 @@
1
+ export { PatientDetails } from './patient-details';
2
+ export type { PatientDetailsProps, PatientDetailsHandle, PatientDetailsField, PatientDetailsSection, PatientDetailsFieldOption, PatientDetailsEditType, PatientDetailsEditValue, PatientDetailsDensity, } from './patient-details';
3
+ export type { PatientField, PatientFieldSection, PatientFieldOption, PatientFieldEditType, PatientFieldEditValue, } from '../_shared/patient-fields';
4
+ export { patientDetailsAgent } from './patient-details.agent';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,6 @@
1
+ import { P as e, p as i } from "../../_chunks/patient-details-Dlhqb5ig.js";
2
+ export {
3
+ e as PatientDetails,
4
+ i as patientDetailsAgent
5
+ };
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,4 @@
1
+ import type { AgentAdapter } from '../../agent/types';
2
+ import type { PatientDetailsHandle } from './patient-details';
3
+ export declare const patientDetailsAgent: AgentAdapter<PatientDetailsHandle>;
4
+ //# sourceMappingURL=patient-details.agent.d.ts.map
@@ -0,0 +1,96 @@
1
+ import { type HTMLAttributes, type ReactNode } from 'react';
2
+ import { type VariantProps } from 'class-variance-authority';
3
+ import { type PatientField, type PatientFieldEditType, type PatientFieldEditValue, type PatientFieldOption, type PatientFieldSection } from '../_shared/patient-fields';
4
+ declare const rootVariants: (props?: ({
5
+ density?: "compact" | "comfortable" | null | undefined;
6
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
7
+ export type { PatientField, PatientFieldSection, PatientFieldOption, PatientFieldEditType, PatientFieldEditValue, } from '../_shared/patient-fields';
8
+ /** A label→value patient field. Alias of the shared {@link PatientField}. */
9
+ export type PatientDetailsField = PatientField;
10
+ /** A labelled, collapsible group of fields. Alias of {@link PatientFieldSection}. */
11
+ export type PatientDetailsSection = PatientFieldSection;
12
+ /** Alias of the shared {@link PatientFieldOption}. */
13
+ export type PatientDetailsFieldOption = PatientFieldOption;
14
+ /** Alias of the shared {@link PatientFieldEditType}. */
15
+ export type PatientDetailsEditType = PatientFieldEditType;
16
+ /** Alias of the shared {@link PatientFieldEditValue}. */
17
+ export type PatientDetailsEditValue = PatientFieldEditValue;
18
+ /**
19
+ * Imperative handle the agent adapter drives. Exposes only field KEYS and
20
+ * an opaque `patientId` for reads; `updateField` routes writes through the
21
+ * same `onFieldSave` path as a human inline edit (no second channel).
22
+ */
23
+ export interface PatientDetailsHandle {
24
+ /** The current ordered list of visible field ids. */
25
+ getVisibleFieldOrder: () => string[];
26
+ /** Opaque patient id (no PHI). */
27
+ getPatientId: () => string | undefined;
28
+ /** Replace the visible set, preserving the given order (filtered to known fields). */
29
+ setVisibleFields: (fieldIds: string[]) => void;
30
+ /** Replace the full ordered visible list (filtered to known fields). */
31
+ setFieldOrder: (orderedIds: string[]) => void;
32
+ /** Write a field value — delegates to `onFieldSave`. Rejects if no handler. */
33
+ updateField: (fieldId: string, value: unknown) => Promise<void>;
34
+ }
35
+ export interface PatientDetailsProps extends Omit<HTMLAttributes<HTMLElement>, 'title' | 'children'> {
36
+ /** Patient display name — the panel heading. */
37
+ title: ReactNode;
38
+ /** The sectioned field catalogue (consumer-mapped from DoctorPatient). */
39
+ sections: PatientDetailsSection[];
40
+ /**
41
+ * Header avatar photo / initials override. The panel always fronts the name
42
+ * with an Avatar — initials derive from a string `title` by default; pass
43
+ * `src` for a photo, or `name` to override the initials source.
44
+ */
45
+ avatar?: {
46
+ src?: string;
47
+ name?: string;
48
+ };
49
+ /** At-a-glance chips under the name (consumer-composed Badge/Tag/Chip row). */
50
+ headerChips?: ReactNode;
51
+ /**
52
+ * Frame the identity header and each section in its own elevated `Card`,
53
+ * for a "control-room" rail that reads as a stack of cards rather than one
54
+ * flat panel. Default `false` (the flat panel with a header rule + eyebrow
55
+ * section headings). When framed, the header rule is dropped — the cards
56
+ * provide the separation.
57
+ */
58
+ framed?: boolean;
59
+ /** Master switch — show edit affordances on `editable` fields. */
60
+ editable?: boolean;
61
+ /**
62
+ * Persist a field edit. Resolve ⇒ committed; reject(Error) ⇒ the message
63
+ * is shown inline and the row stays in edit mode. Also the single channel
64
+ * the agent's `update_field` uses.
65
+ */
66
+ onFieldSave?: (fieldId: string, value: unknown) => Promise<void>;
67
+ /** Domain validation — return an error message, or `null` when valid. */
68
+ validate?: (fieldId: string, value: unknown) => string | null;
69
+ /**
70
+ * Controlled ordered list of visible field ids. `undefined` ⇒ every field
71
+ * visible; an explicit `[]` ⇒ none (a panel that starts collapsed).
72
+ */
73
+ visibleFieldOrder?: string[];
74
+ /** Uncontrolled initial order. Omit both ⇒ every field visible, in declaration order. */
75
+ defaultVisibleFieldOrder?: string[];
76
+ /** Fired whenever the user shows/hides/reorders fields via the cog. */
77
+ onVisibleFieldsChange?: (orderedIds: string[]) => void;
78
+ /** Render the loading skeleton. */
79
+ loading?: boolean;
80
+ /** Shown when there are no sections / no patient. Defaults to a localised hint. */
81
+ emptyState?: ReactNode;
82
+ /** Opaque patient id — emitted as `data-patient-id` + agent stateRead. No PHI. */
83
+ patientId?: string;
84
+ /** Agent-readiness instance id, surfaced as `data-component-id`. */
85
+ id?: string;
86
+ /** BCP-47 locale override (currency / number editors). */
87
+ locale?: string;
88
+ /** Override the cog trigger's accessible name. */
89
+ cogLabel?: string;
90
+ /** Override the panel region's accessible name (defaults to the heading). */
91
+ 'aria-label'?: string;
92
+ }
93
+ export declare const PatientDetails: import("react").ForwardRefExoticComponent<PatientDetailsProps & import("react").RefAttributes<HTMLElement>>;
94
+ /** Density variant union re-exported for downstream typing. */
95
+ export type PatientDetailsDensity = NonNullable<VariantProps<typeof rootVariants>['density']>;
96
+ //# sourceMappingURL=patient-details.d.ts.map
@@ -1,4 +1,4 @@
1
- import { P as t, p as r } from "../../_chunks/patient-search-DR9XUYRQ.js";
1
+ import { P as t, p as r } from "../../_chunks/patient-search-Be6cLrHR.js";
2
2
  export {
3
3
  t as PatientSearch,
4
4
  r as patientSearchAgent
@@ -1,4 +1,4 @@
1
- import { P as t, p as m } from "../../_chunks/patient-summary-card-hEmr4eTW.js";
1
+ import { P as t, p as m } from "../../_chunks/patient-summary-card-WySCMwwA.js";
2
2
  export {
3
3
  t as PatientSummaryCard,
4
4
  m as patientSummaryCardAgent
@@ -1,5 +1,6 @@
1
1
  import { type ComponentPropsWithoutRef, type ReactNode } from 'react';
2
2
  import { type VariantProps } from 'class-variance-authority';
3
+ import { type PatientFieldSection } from '../_shared/patient-fields';
3
4
  declare const rootVariants: (props?: ({
4
5
  surface?: "flat" | "elevated" | null | undefined;
5
6
  density?: "compact" | "comfortable" | null | undefined;
@@ -75,7 +76,45 @@ export interface PatientSummaryCardProps extends Omit<ComponentPropsWithoutRef<'
75
76
  * dropped and the heading renders as plain text.
76
77
  */
77
78
  patientUrl?: string;
78
- /** Patient email. Compiled into a `mailto:` link when `emailEnabled`. */
79
+ /**
80
+ * Patient fields in the shared model — the SAME `sections` shape
81
+ * `PatientDetails` consumes (`@alfadocs/ui-kit` `PatientFieldSection`).
82
+ * When provided, the card renders these (honouring `visibleFieldOrder`)
83
+ * instead of the legacy contact props, so a consumer defines its patient-
84
+ * field registry once and reuses it across every patient surface.
85
+ *
86
+ * The card renders each field's `label`, `value`, and `icon` only — it is
87
+ * flat (section headings are not shown in the body) and never inline-edits;
88
+ * `sensitive` / `copyable` / `mono` / `editable` are honoured by
89
+ * `PatientDetails`, not the card (so the PHI lock glyph does not appear here).
90
+ *
91
+ * Pass `onVisibleFieldsChange` alongside `sections` to make THIS placement
92
+ * self-curating (a "Customize fields" cog appears — show/hide + drag-and-drop
93
+ * reorder).
94
+ */
95
+ sections?: PatientFieldSection[];
96
+ /**
97
+ * Ordered visible field ids for THIS placement. The order is a
98
+ * per-INSTANCE, per-CONTEXT preference the kit never persists — wire it to
99
+ * whatever scope the consumer wants (e.g. a global per-user setting, or a
100
+ * different config in the care-plan view vs the patient folder). The same
101
+ * field vocabulary can therefore display differently in different parts of
102
+ * the app. Omit (`undefined`) ⇒ show every field; an explicit empty array
103
+ * `[]` ⇒ show none (a card that starts collapsed to name + identity chips and
104
+ * reveals fields via the cog). Also applied to the legacy contact rows (ids
105
+ * `email` / `phone` / `cityProvince` / `marketingConsent` / `aiConsent` /
106
+ * `assignedTo`).
107
+ */
108
+ visibleFieldOrder?: string[];
109
+ /**
110
+ * Make this card's field set user-customizable. When provided alongside
111
+ * `sections`, a "Customize fields" cog renders in the header (show/hide +
112
+ * drag-and-drop / Alt+Arrow reorder), and this fires with the next ordered
113
+ * visible set. The consumer owns persistence + its scope — editing here
114
+ * writes only THIS context's preference, never a shared/global one.
115
+ */
116
+ onVisibleFieldsChange?: (orderedIds: string[]) => void;
117
+ /** @deprecated Pass via `sections`. Patient email — `mailto:` link when `emailEnabled`. */
79
118
  email?: string;
80
119
  /** Whether email contact is enabled — gates the `mailto:` link. */
81
120
  emailEnabled?: boolean;
@@ -0,0 +1,13 @@
1
+ import type { CustomCellRendererProps } from 'ag-grid-react';
2
+ import type { PatientRow } from '../types';
3
+ export interface BalanceBadgeCellParams {
4
+ /** ISO 4217 currency code used to format the balance. Default `'EUR'`. */
5
+ currency?: string;
6
+ /**
7
+ * `Intl.NumberFormat` escape hatch, merged on top of the currency defaults.
8
+ * E.g. `{ maximumFractionDigits: 0 }` for whole-currency display.
9
+ */
10
+ options?: Intl.NumberFormatOptions;
11
+ }
12
+ export declare function BalanceBadgeCell(props: CustomCellRendererProps<PatientRow> & BalanceBadgeCellParams): import("react/jsx-runtime").JSX.Element | null;
13
+ //# sourceMappingURL=balance-badge-cell.d.ts.map
@@ -0,0 +1,43 @@
1
+ /**
2
+ * care-plan-status-cell — patient-table cell renderer
3
+ * ----------------------------------------------------------------------------
4
+ * A thin domain preset over the data-table `StatusCellRenderer` / kit `Badge`:
5
+ * it bakes the patient care-plan lifecycle `variantMap` so consumers don't have
6
+ * to re-declare it on every column, and localises the label via the `ui`
7
+ * namespace (`ui.patientTable.carePlanStatus.*`).
8
+ *
9
+ * Reads `PatientRow.carePlanStatus` (preferring `data.carePlanStatus`, falling
10
+ * back to AG Grid's resolved `value`), maps it to a Badge variant:
11
+ *
12
+ * accepted → success estimate → info none → neutral (muted)
13
+ *
14
+ * GROUND-TRUTH NOTES (vs. the task brief):
15
+ * • `StatusCellRenderer` is not exported from a barrel and is a tiny wrapper
16
+ * around `Badge`; this preset composes `Badge` directly (same primitive,
17
+ * no extra indirection) rather than wrapping the wrapper.
18
+ * • The brand says the "muted" variant is `none`; `Badge`'s neutral variant is
19
+ * already the muted grey chip, so `none → 'neutral'`.
20
+ * • No event handling: a status badge is presentational, so there are no
21
+ * provided callbacks to wire.
22
+ */
23
+ import type { CustomCellRendererProps } from 'ag-grid-react';
24
+ import type { PatientCarePlanStatus, PatientRow } from '../types';
25
+ /**
26
+ * `cellRendererParams` for `CarePlanStatusCell`.
27
+ *
28
+ * The lifecycle status, label source and variant map are all baked in, so the
29
+ * only knob is the Badge size — defaults to the compact `sm` chip that fits the
30
+ * standard AG Grid row height.
31
+ */
32
+ export interface CarePlanStatusCellParams {
33
+ /** Badge size. Defaults to `'sm'` to fit the standard row height. */
34
+ size?: 'sm' | 'md' | 'lg';
35
+ }
36
+ /**
37
+ * Patient care-plan lifecycle badge cell.
38
+ *
39
+ * Pass as `cellRenderer` on the `carePlanStatus` column; the patient
40
+ * `variantMap` and localisation are handled internally.
41
+ */
42
+ export declare function CarePlanStatusCell(props: CustomCellRendererProps<PatientRow, PatientCarePlanStatus> & CarePlanStatusCellParams): import("react/jsx-runtime").JSX.Element | null;
43
+ //# sourceMappingURL=care-plan-status-cell.d.ts.map
@@ -0,0 +1,24 @@
1
+ import type { CustomCellRendererProps } from 'ag-grid-react';
2
+ import type { PatientRow } from '../types';
3
+ /**
4
+ * `cellRendererParams` for {@link NextAppointmentCell}.
5
+ *
6
+ * Localisation and the relative-date formatting are handled internally; the
7
+ * only knob is the imminence window.
8
+ */
9
+ export interface NextAppointmentCellParams {
10
+ /**
11
+ * Highlight the cell when the appointment is at most this many days away
12
+ * (and not in the past). Defaults to `7`. A value `<= 0` disables the
13
+ * highlight.
14
+ */
15
+ soonWithinDays?: number;
16
+ }
17
+ /**
18
+ * Smart upcoming-appointment cell.
19
+ *
20
+ * Pass as `cellRenderer` on the `nextAppointment` column; the relative
21
+ * formatting, imminence emphasis and empty state are handled internally.
22
+ */
23
+ export declare function NextAppointmentCell(props: CustomCellRendererProps<PatientRow, string> & NextAppointmentCellParams): import("react/jsx-runtime").JSX.Element;
24
+ //# sourceMappingURL=next-appointment-cell.d.ts.map
@@ -0,0 +1,131 @@
1
+ /**
2
+ * patient-table — column definitions
3
+ * ----------------------------------------------------------------------------
4
+ * `buildPatientColumns(t, opts)` returns the ordered `ColDef<PatientRow>[]` for
5
+ * the patient grid. Every patient field is its OWN column — sortable, filterable
6
+ * and individually hideable via ColumnToggle — rather than several fields jumbled
7
+ * into one composite cell. Each column wires the right kit cell renderer + the
8
+ * right kit filter + floatingFilter, a localised `headerName` (from
9
+ * `ui.patientTable.column.*`) and a stable `colId`.
10
+ *
11
+ * Identity is SPLIT across three pinned-start columns (the spec's
12
+ * "Avatar · First · Last"):
13
+ * • `avatar` — ImageCellRenderer (photo, initials fallback), sr-only header.
14
+ * • `firstName` — plain text.
15
+ * • `lastName` — LinkCellRenderer (the patient-detail link, `identityHref`).
16
+ * All three are pinned-start P0 anchors and never auto-hide.
17
+ *
18
+ * COLUMN VISIBILITY
19
+ * -----------------
20
+ * `●` default-visible columns carry a `responsiveTier`; the responsive hook hides
21
+ * them by tier as the grid narrows. Every other (grouped) column ships
22
+ * `hide: true` and NO tier, so the hook leaves it alone and a user ColumnToggle
23
+ * override wins. The anchors (avatar / firstName / lastName / actions) omit a
24
+ * tier so they are never auto-hidden.
25
+ *
26
+ * RESPONSIVE TIER MECHANISM
27
+ * -------------------------
28
+ * Each column may carry a custom `responsiveTier` (`P0`–`P3`) property. AG Grid's
29
+ * `ColDef` is an open/extensible shape — extra properties pass through untouched
30
+ * at runtime — but its TS type is closed, so we type each entry as
31
+ * `PatientColDefWithTier` and read the tier back via {@link getResponsiveTier}
32
+ * (no `any`, no reliance on AG Grid's loose `context`).
33
+ *
34
+ * CUSTOM FIELDS
35
+ * -------------
36
+ * `opts.customFields` appends one dynamic column per descriptor after the
37
+ * standard columns: `colId: \`custom:${fieldName}\``, a LITERAL `headerName`
38
+ * (the practice-defined label — never i18n-keyed), a `valueGetter` reading
39
+ * `row.customFields?.[fieldName]`, and a renderer + filter chosen by `type`
40
+ * (`text` → plain text · `checkbox` → ✓/— · `dropdown` → Tag chip). All ship
41
+ * `hide: true` and no tier.
42
+ *
43
+ * CONSTRAINTS:
44
+ * • No colour / spacing / radius / font literal in any `cellStyle`/`cellClass`
45
+ * here — only token-bound `ds:` utility classes — so the AG Grid theme bridge
46
+ * stays in control of theming.
47
+ * • CSS logical properties only.
48
+ * • PHI rule (PRS 26 §6): no `PatientRow` field other than `id` is ever placed
49
+ * in a DOM `data-*` attribute. Renderers surface name/contact/DOB as text
50
+ * content only; these defs pass values, not attributes.
51
+ */
52
+ import type { TFunction } from 'i18next';
53
+ import type { PatientColDef, PatientColumnDef, PatientCustomFieldDef, PatientRow, PatientRowAction, ResponsiveTier } from './types';
54
+ /**
55
+ * A patient leaf column carrying its responsive-priority tier. AG Grid passes
56
+ * the extra `responsiveTier` key through untouched; we keep it strongly typed
57
+ * (no `any`, no reliance on AG Grid's `context: any`) so the responsive hook can
58
+ * read it back via {@link getResponsiveTier}.
59
+ */
60
+ export type PatientColDefWithTier = PatientColDef & {
61
+ /**
62
+ * Responsive priority. Lower numbers survive longer as the grid narrows:
63
+ * `P0` always visible, `P3` first to hide. Consumed by `useResponsiveColumns`.
64
+ */
65
+ responsiveTier?: ResponsiveTier;
66
+ };
67
+ /**
68
+ * Read the responsive tier off a column definition. Returns `undefined` for
69
+ * columns that opt out of responsive toggling — the pinned anchors and every
70
+ * `hide: true` grouped column deliberately omit a tier so they are never
71
+ * auto-managed by the responsive hook.
72
+ */
73
+ export declare function getResponsiveTier(colDef: PatientColumnDef): ResponsiveTier | undefined;
74
+ /** Options threaded into {@link buildPatientColumns}. */
75
+ export interface BuildPatientColumnsOptions {
76
+ /**
77
+ * Mask sensitive contact details (email) — when `true` the `email` column
78
+ * ships hidden. Forwarded from `PatientTable`'s `hidePatientDetails`. Default
79
+ * `false`.
80
+ */
81
+ hideDetails?: boolean;
82
+ /**
83
+ * Live getter for the actions-column density. When it returns `true`, the
84
+ * `ActionsCellRenderer` collapses its inline buttons into a single "…" overflow
85
+ * menu (the spec's 180→88px compact density). Reading via a getter lets a
86
+ * density toggle flip without rebuilding column defs (preserves column state) —
87
+ * call `api.refreshCells({ force: true })` after flipping the backing value.
88
+ * Defaults to a getter that always returns `false`.
89
+ */
90
+ getActionsCompact?: () => boolean;
91
+ /**
92
+ * Invoked when a per-row action button is activated, with the resolved action
93
+ * descriptor and the patient row. Only `row.id` ever leaves this boundary into
94
+ * persistence / agent surfaces — never PHI.
95
+ */
96
+ onRowAction?: (action: PatientRowAction, patient: PatientRow) => void;
97
+ /**
98
+ * Derive the patient-detail href for the `lastName` link column, e.g.
99
+ * `(row) => \`/patients/${row.id}\``. When omitted the lastName cell renders a
100
+ * button that calls `onRowAction` with the `show` action instead.
101
+ */
102
+ identityHref?: string | ((row: PatientRow) => string | undefined);
103
+ /**
104
+ * Per-practice custom-field descriptors. Each appends one dynamic `custom:*`
105
+ * column (hidden by default) after the standard columns. See
106
+ * {@link PatientCustomFieldDef}.
107
+ */
108
+ customFields?: PatientCustomFieldDef[];
109
+ }
110
+ /**
111
+ * The fixed number of per-row actions the patient grid builds (show · edit ·
112
+ * email reminder · sms reminder · reassign · delete — see {@link buildRowActions}).
113
+ * Exposed so the component can size the actions column to its EXPANDED footprint
114
+ * (`actionsColumnWidth(PATIENT_ROW_ACTION_COUNT)`) when flipping the runtime
115
+ * compact-actions toggle off, without rebuilding the column defs. Keep in sync
116
+ * with the array {@link buildRowActions} returns.
117
+ */
118
+ export declare const PATIENT_ROW_ACTION_COUNT = 6;
119
+ /**
120
+ * Build the ordered patient-grid column definitions — one field per column.
121
+ *
122
+ * @param t `react-i18next` translation fn (default `ui` namespace).
123
+ * @param opts See {@link BuildPatientColumnsOptions} — density getter, row-action
124
+ * callback, detail masking, identity href, custom fields.
125
+ * @returns Ordered `PatientColumnDef[]`. Default-visible columns carry a
126
+ * `responsiveTier` (read via {@link getResponsiveTier}); the pinned
127
+ * anchors and every grouped (`hide: true`) column omit it so they are
128
+ * never auto-hidden.
129
+ */
130
+ export declare function buildPatientColumns(t: TFunction, opts?: BuildPatientColumnsOptions): PatientColumnDef[];
131
+ //# sourceMappingURL=columns.d.ts.map
@@ -0,0 +1,20 @@
1
+ /**
2
+ * patient-table — public barrel
3
+ * ----------------------------------------------------------------------------
4
+ * Re-exports the `PatientTable` component, its public type surface, the
5
+ * `buildPatientColumns` builder (so consumers can compose / extend columns)
6
+ * and every patient cell renderer + its params type (so consumers can reuse
7
+ * them when supplying a custom `columns` prop).
8
+ */
9
+ export { PatientTable } from './patient-table';
10
+ export type { PatientTableProps } from './patient-table';
11
+ export { buildPatientColumns, getResponsiveTier, PATIENT_ROW_ACTION_COUNT, type BuildPatientColumnsOptions, type PatientColDefWithTier, } from './columns';
12
+ export { useResponsiveColumns, type UseResponsiveColumnsOptions, type UseResponsiveColumnsResult, } from './use-responsive-columns';
13
+ export type { PatientRow, PatientPhoneNumber, PatientGender, PatientMarketingConsent, PatientCarePlanStatus, PatientCustomFieldDef, PatientColumnId, ResponsiveTier, PatientRowActionKey, PatientRowAction, PatientBulkActionKey, PatientBulkAction, PatientView, PatientTableHandle, PatientColDef, PatientColGroupDef, PatientColumnDef, } from './types';
14
+ export { NextAppointmentCell } from './cell-renderers/next-appointment-cell';
15
+ export type { NextAppointmentCellParams } from './cell-renderers/next-appointment-cell';
16
+ export { BalanceBadgeCell } from './cell-renderers/balance-badge-cell';
17
+ export type { BalanceBadgeCellParams } from './cell-renderers/balance-badge-cell';
18
+ export { CarePlanStatusCell } from './cell-renderers/care-plan-status-cell';
19
+ export type { CarePlanStatusCellParams } from './cell-renderers/care-plan-status-cell';
20
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,12 @@
1
+ import { B as s, C as l, N as t, P as n, a as C, b as i, g as o, u } from "../../_chunks/patient-table-CHxf3Oqk.js";
2
+ export {
3
+ s as BalanceBadgeCell,
4
+ l as CarePlanStatusCell,
5
+ t as NextAppointmentCell,
6
+ n as PATIENT_ROW_ACTION_COUNT,
7
+ C as PatientTable,
8
+ i as buildPatientColumns,
9
+ o as getResponsiveTier,
10
+ u as useResponsiveColumns
11
+ };
12
+ //# sourceMappingURL=index.js.map