@alfadocs/ui-kit-debug 0.37.0 → 0.39.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 (497) hide show
  1. package/dist/_chunks/Alfadocs_Logo_Mark-7o3L3WBI.js +56 -0
  2. package/dist/_chunks/Alfadocs_Logo_Mark-7o3L3WBI.js.map +1 -0
  3. package/dist/_chunks/{accordion-bSU21uTV.js → accordion-9lJSMMsZ.js} +6 -6
  4. package/dist/_chunks/accordion-9lJSMMsZ.js.map +1 -0
  5. package/dist/_chunks/{agenda-tray-By_asPN9.js → agenda-tray-Dyj9ChHC.js} +22 -21
  6. package/dist/_chunks/agenda-tray-Dyj9ChHC.js.map +1 -0
  7. package/dist/_chunks/{alia-sidebar-BEoMl6UL.js → alia-sidebar-DXsYPinm.js} +2 -2
  8. package/dist/_chunks/{alia-sidebar-BEoMl6UL.js.map → alia-sidebar-DXsYPinm.js.map} +1 -1
  9. package/dist/_chunks/{ar-D1RwVZFj.js → ar-Cn_NxqkN.js} +2 -2
  10. package/dist/_chunks/{ar-D1RwVZFj.js.map → ar-Cn_NxqkN.js.map} +1 -1
  11. package/dist/_chunks/bmi-BxD-tFzU.js +32 -0
  12. package/dist/_chunks/bmi-BxD-tFzU.js.map +1 -0
  13. package/dist/_chunks/bmi-calculator-DnEr513I.js +213 -0
  14. package/dist/_chunks/bmi-calculator-DnEr513I.js.map +1 -0
  15. package/dist/_chunks/{booking-DqXsd1Mv.js → booking-4mCw3Mpl.js} +5 -5
  16. package/dist/_chunks/{booking-DqXsd1Mv.js.map → booking-4mCw3Mpl.js.map} +1 -1
  17. package/dist/_chunks/calculator-dialog-B74fqpFZ.js +40 -0
  18. package/dist/_chunks/calculator-dialog-B74fqpFZ.js.map +1 -0
  19. package/dist/_chunks/{chart-DnHvmiDX.js → chart-Cbt0_sKv.js} +46 -37
  20. package/dist/_chunks/chart-Cbt0_sKv.js.map +1 -0
  21. package/dist/_chunks/{chat-message-D53_fH2w.js → chat-message-ASgGtj-L.js} +30 -39
  22. package/dist/_chunks/chat-message-ASgGtj-L.js.map +1 -0
  23. package/dist/_chunks/{collapsible-CERONory.js → collapsible-X3oaLPU3.js} +5 -5
  24. package/dist/_chunks/collapsible-X3oaLPU3.js.map +1 -0
  25. package/dist/_chunks/{contact-profile-card-BA6fgS45.js → contact-profile-card-DHyuAPXM.js} +14 -13
  26. package/dist/_chunks/{contact-profile-card-BA6fgS45.js.map → contact-profile-card-DHyuAPXM.js.map} +1 -1
  27. package/dist/_chunks/cycle-calculator-B5Uj9QeT.js +185 -0
  28. package/dist/_chunks/cycle-calculator-B5Uj9QeT.js.map +1 -0
  29. package/dist/_chunks/{date-picker-CXFpu-qY.js → date-picker-CvQfs6Xh.js} +2 -2
  30. package/dist/_chunks/{date-picker-CXFpu-qY.js.map → date-picker-CvQfs6Xh.js.map} +1 -1
  31. package/dist/_chunks/{date-range-picker-I-q5rifj.js → date-range-picker-U9fn1g9d.js} +3 -3
  32. package/dist/_chunks/{date-range-picker-I-q5rifj.js.map → date-range-picker-U9fn1g9d.js.map} +1 -1
  33. package/dist/_chunks/{date-time-picker-CqpGPlcH.js → date-time-picker-Cva0ZCWw.js} +2 -2
  34. package/dist/_chunks/{date-time-picker-CqpGPlcH.js.map → date-time-picker-Cva0ZCWw.js.map} +1 -1
  35. package/dist/_chunks/{de-HTQ4b4-J.js → de-BMM2H7Bs.js} +2 -2
  36. package/dist/_chunks/{de-HTQ4b4-J.js.map → de-BMM2H7Bs.js.map} +1 -1
  37. package/dist/_chunks/dependent-selector-CRWgieHm.js +324 -0
  38. package/dist/_chunks/dependent-selector-CRWgieHm.js.map +1 -0
  39. package/dist/_chunks/document-scanner-CqS_klIr.js +703 -0
  40. package/dist/_chunks/document-scanner-CqS_klIr.js.map +1 -0
  41. package/dist/_chunks/due-date-calculator-CUspKSTw.js +171 -0
  42. package/dist/_chunks/due-date-calculator-CUspKSTw.js.map +1 -0
  43. package/dist/_chunks/{editable-currency-cell-renderer-DnjwZNZP.js → editable-currency-cell-renderer-DgkCIIcO.js} +3 -3
  44. package/dist/_chunks/{editable-currency-cell-renderer-DnjwZNZP.js.map → editable-currency-cell-renderer-DgkCIIcO.js.map} +1 -1
  45. package/dist/_chunks/{el-Dr1pjuDq.js → el-BYPonAaK.js} +2 -2
  46. package/dist/_chunks/{el-Dr1pjuDq.js.map → el-BYPonAaK.js.map} +1 -1
  47. package/dist/_chunks/{es-CvyTjLS0.js → es-CMkVCQ4F.js} +2 -2
  48. package/dist/_chunks/{es-CvyTjLS0.js.map → es-CMkVCQ4F.js.map} +1 -1
  49. package/dist/_chunks/{file-upload-CdozCPct.js → file-upload-BosbPDb1.js} +3 -2
  50. package/dist/_chunks/file-upload-BosbPDb1.js.map +1 -0
  51. package/dist/_chunks/fiscal-code-input-BZ0FxwUl.js +540 -0
  52. package/dist/_chunks/fiscal-code-input-BZ0FxwUl.js.map +1 -0
  53. package/dist/_chunks/{fr-CS7aqaFR.js → fr-BcuWxqft.js} +2 -2
  54. package/dist/_chunks/{fr-CS7aqaFR.js.map → fr-BcuWxqft.js.map} +1 -1
  55. package/dist/_chunks/{freemium-paywall-D1N02Oam.js → freemium-paywall-BAk3a6er.js} +7 -7
  56. package/dist/_chunks/{freemium-paywall-D1N02Oam.js.map → freemium-paywall-BAk3a6er.js.map} +1 -1
  57. package/dist/_chunks/gestation-BXEgDGmP.js +50 -0
  58. package/dist/_chunks/gestation-BXEgDGmP.js.map +1 -0
  59. package/dist/_chunks/gestational-age-calculator-CsQ05qDy.js +165 -0
  60. package/dist/_chunks/gestational-age-calculator-CsQ05qDy.js.map +1 -0
  61. package/dist/_chunks/header-settings-CBLwUK6t.js +244 -0
  62. package/dist/_chunks/header-settings-CBLwUK6t.js.map +1 -0
  63. package/dist/_chunks/heart-C0faivFf.js +20 -0
  64. package/dist/_chunks/heart-C0faivFf.js.map +1 -0
  65. package/dist/_chunks/{hi-3uy8KpsH.js → hi-wkq_rQAh.js} +2 -2
  66. package/dist/_chunks/{hi-3uy8KpsH.js.map → hi-wkq_rQAh.js.map} +1 -1
  67. package/dist/_chunks/image-C6RM5hfF.js +16 -0
  68. package/dist/_chunks/image-C6RM5hfF.js.map +1 -0
  69. package/dist/_chunks/insert-result-yJ0QavoN.js +133 -0
  70. package/dist/_chunks/insert-result-yJ0QavoN.js.map +1 -0
  71. package/dist/_chunks/{isSameWeek-DRpMibi9.js → isSameWeek-Bim5ftRd.js} +2 -2
  72. package/dist/_chunks/{isSameWeek-DRpMibi9.js.map → isSameWeek-Bim5ftRd.js.map} +1 -1
  73. package/dist/_chunks/{it-B_RF5VSw.js → it-GiQrQ9p4.js} +3 -3
  74. package/dist/_chunks/{it-B_RF5VSw.js.map → it-GiQrQ9p4.js.map} +1 -1
  75. package/dist/_chunks/{ja-C1mEYy35.js → ja-qfYg3Rua.js} +2 -2
  76. package/dist/_chunks/{ja-C1mEYy35.js.map → ja-qfYg3Rua.js.map} +1 -1
  77. package/dist/_chunks/{logo-_Z-jLq80.js → logo-yituK7sE.js} +42 -91
  78. package/dist/_chunks/logo-yituK7sE.js.map +1 -0
  79. package/dist/_chunks/{map-view-vD5pvWs9.js → map-view-qJLybrmN.js} +2 -2
  80. package/dist/_chunks/{map-view-vD5pvWs9.js.map → map-view-qJLybrmN.js.map} +1 -1
  81. package/dist/_chunks/marketplace-app-shell-BlxVizU4.js +296 -0
  82. package/dist/_chunks/marketplace-app-shell-BlxVizU4.js.map +1 -0
  83. package/dist/_chunks/{message-card-BbRhZkDI.js → message-card-DSPw5ghw.js} +20 -19
  84. package/dist/_chunks/message-card-DSPw5ghw.js.map +1 -0
  85. package/dist/_chunks/{message-tray-B762TKuv.js → message-tray-hSQff9u4.js} +3 -3
  86. package/dist/_chunks/message-tray-hSQff9u4.js.map +1 -0
  87. package/dist/_chunks/{nl-Dl7lO2t3.js → nl-xOogO4sZ.js} +2 -2
  88. package/dist/_chunks/{nl-Dl7lO2t3.js.map → nl-xOogO4sZ.js.map} +1 -1
  89. package/dist/_chunks/{notification-card-DMdO4g54.js → notification-card-CObnGdJu.js} +22 -21
  90. package/dist/_chunks/notification-card-CObnGdJu.js.map +1 -0
  91. package/dist/_chunks/{notification-tray-Dl3FTleW.js → notification-tray-BWHDIjgd.js} +2 -2
  92. package/dist/_chunks/{notification-tray-Dl3FTleW.js.map → notification-tray-BWHDIjgd.js.map} +1 -1
  93. package/dist/_chunks/{otp-input-CDTWT5EK.js → otp-input-CMphfBxZ.js} +70 -71
  94. package/dist/_chunks/otp-input-CMphfBxZ.js.map +1 -0
  95. package/dist/_chunks/{patient-shell-CDvMw_Nk.js → patient-shell-DF81lALv.js} +37 -36
  96. package/dist/_chunks/{patient-shell-CDvMw_Nk.js.map → patient-shell-DF81lALv.js.map} +1 -1
  97. package/dist/_chunks/{payment-form-D5rgnZu7.js → payment-form-Dy3WIIsC.js} +18 -18
  98. package/dist/_chunks/payment-form-Dy3WIIsC.js.map +1 -0
  99. package/dist/_chunks/{pdf-viewer-DvtEHcEP.js → pdf-viewer-Cy6Ul3hZ.js} +2 -2
  100. package/dist/_chunks/pdf-viewer-Cy6Ul3hZ.js.map +1 -0
  101. package/dist/_chunks/{pl-Dgsogljx.js → pl-GnOW6eGK.js} +3 -3
  102. package/dist/_chunks/{pl-Dgsogljx.js.map → pl-GnOW6eGK.js.map} +1 -1
  103. package/dist/_chunks/{practice-results-BFM_lyUs.js → practice-results-C0d4IL5E.js} +4 -3
  104. package/dist/_chunks/{practice-results-BFM_lyUs.js.map → practice-results-C0d4IL5E.js.map} +1 -1
  105. package/dist/_chunks/pregnancy-weight-gain-BCdi-JSv.js +209 -0
  106. package/dist/_chunks/pregnancy-weight-gain-BCdi-JSv.js.map +1 -0
  107. package/dist/_chunks/{privacy-lock-DD-wHxBg.js → privacy-lock-BmX_gkvt.js} +2 -2
  108. package/dist/_chunks/{privacy-lock-DD-wHxBg.js.map → privacy-lock-BmX_gkvt.js.map} +1 -1
  109. package/dist/_chunks/{pt-Dm2JF4bc.js → pt-_bV5b5RW.js} +2 -2
  110. package/dist/_chunks/{pt-Dm2JF4bc.js.map → pt-_bV5b5RW.js.map} +1 -1
  111. package/dist/_chunks/{public-footer.agent-Cjfe5jus.js → public-footer.agent-okt8ZRc5.js} +3 -3
  112. package/dist/_chunks/{public-footer.agent-Cjfe5jus.js.map → public-footer.agent-okt8ZRc5.js.map} +1 -1
  113. package/dist/_chunks/qr-code-DNXhi6se.js +568 -0
  114. package/dist/_chunks/qr-code-DNXhi6se.js.map +1 -0
  115. package/dist/_chunks/{react-day-picker-DYDdR8Vv.js → react-day-picker-CdtIiKjx.js} +24 -24
  116. package/dist/_chunks/{react-day-picker-DYDdR8Vv.js.map → react-day-picker-CdtIiKjx.js.map} +1 -1
  117. package/dist/_chunks/{reviews-panel-Dow8Dzoa.js → reviews-panel-CPrXu5TX.js} +2 -2
  118. package/dist/_chunks/{reviews-panel-Dow8Dzoa.js.map → reviews-panel-CPrXu5TX.js.map} +1 -1
  119. package/dist/_chunks/{rich-text-editor-CHmr9Bz8.js → rich-text-editor-DLbg2852.js} +114 -124
  120. package/dist/_chunks/rich-text-editor-DLbg2852.js.map +1 -0
  121. package/dist/_chunks/{ro-BXFZ_xIX.js → ro-BEcyh5Nj.js} +2 -2
  122. package/dist/_chunks/{ro-BXFZ_xIX.js.map → ro-BEcyh5Nj.js.map} +1 -1
  123. package/dist/_chunks/rotate-ccw-BWANpitO.js +15 -0
  124. package/dist/_chunks/rotate-ccw-BWANpitO.js.map +1 -0
  125. package/dist/_chunks/{ru-BPQkNRRV.js → ru-Bi86hqMf.js} +3 -3
  126. package/dist/_chunks/{ru-BPQkNRRV.js.map → ru-Bi86hqMf.js.map} +1 -1
  127. package/dist/_chunks/session-countdown-LPnhTHjn.js +214 -0
  128. package/dist/_chunks/session-countdown-LPnhTHjn.js.map +1 -0
  129. package/dist/_chunks/{shield-check-BhHyReu8.js → shield-check-C73ma9Cs.js} +8 -24
  130. package/dist/_chunks/shield-check-C73ma9Cs.js.map +1 -0
  131. package/dist/_chunks/{sidebar-BbR8f6oe.js → sidebar-_vJXI9rB.js} +2 -2
  132. package/dist/_chunks/{sidebar-BbR8f6oe.js.map → sidebar-_vJXI9rB.js.map} +1 -1
  133. package/dist/_chunks/sign-document-DId1p-nn.js +315 -0
  134. package/dist/_chunks/sign-document-DId1p-nn.js.map +1 -0
  135. package/dist/_chunks/{sign-in-with-alfadocs-button-BI0fVonM.js → sign-in-with-alfadocs-button-DeHBFRNS.js} +2 -2
  136. package/dist/_chunks/{sign-in-with-alfadocs-button-BI0fVonM.js.map → sign-in-with-alfadocs-button-DeHBFRNS.js.map} +1 -1
  137. package/dist/_chunks/{signature-capture-C-fF71xI.js → signature-capture-BRzCklg4.js} +27 -24
  138. package/dist/_chunks/signature-capture-BRzCklg4.js.map +1 -0
  139. package/dist/_chunks/social-sign-in-button-X54ySJr1.js +243 -0
  140. package/dist/_chunks/social-sign-in-button-X54ySJr1.js.map +1 -0
  141. package/dist/_chunks/{sparkline-DEROcSl0.js → sparkline-DGhCSw8M.js} +55 -46
  142. package/dist/_chunks/sparkline-DGhCSw8M.js.map +1 -0
  143. package/dist/_chunks/{sq-ChTlGFcJ.js → sq-BujHSAWu.js} +2 -2
  144. package/dist/_chunks/{sq-ChTlGFcJ.js.map → sq-BujHSAWu.js.map} +1 -1
  145. package/dist/_chunks/{stepper-accordion-BfS6lUB9.js → stepper-accordion-Dki6r9ZE.js} +2 -2
  146. package/dist/_chunks/stepper-accordion-Dki6r9ZE.js.map +1 -0
  147. package/dist/_chunks/subDays-_T9YeKPX.js +8 -0
  148. package/dist/_chunks/{subDays-D-WYRpdW.js.map → subDays-_T9YeKPX.js.map} +1 -1
  149. package/dist/_chunks/{sv-Do_gs6ir.js → sv-C8AeDrTA.js} +2 -2
  150. package/dist/_chunks/{sv-Do_gs6ir.js.map → sv-C8AeDrTA.js.map} +1 -1
  151. package/dist/_chunks/{tag-CyoaEmf_.js → tag-CdA0s_VV.js} +16 -16
  152. package/dist/_chunks/tag-CdA0s_VV.js.map +1 -0
  153. package/dist/_chunks/{task-card-BUVMh6HN.js → task-card-CPyQ5AXC.js} +6 -5
  154. package/dist/_chunks/task-card-CPyQ5AXC.js.map +1 -0
  155. package/dist/_chunks/{task-tray-DRK0b0Qb.js → task-tray-B8jFv5FV.js} +36 -35
  156. package/dist/_chunks/task-tray-B8jFv5FV.js.map +1 -0
  157. package/dist/_chunks/{tr-da_UnkYH.js → tr-CMSs_Vgf.js} +2 -2
  158. package/dist/_chunks/{tr-da_UnkYH.js.map → tr-CMSs_Vgf.js.map} +1 -1
  159. package/dist/_chunks/{transcript-panel-DyhTpAP7.js → transcript-panel-CR7VY1uw.js} +8 -7
  160. package/dist/_chunks/transcript-panel-CR7VY1uw.js.map +1 -0
  161. package/dist/_chunks/unit-converter-EUwO6QYq.js +168 -0
  162. package/dist/_chunks/unit-converter-EUwO6QYq.js.map +1 -0
  163. package/dist/_chunks/wallet-pay-button-DK4ESYge.js +250 -0
  164. package/dist/_chunks/wallet-pay-button-DK4ESYge.js.map +1 -0
  165. package/dist/_chunks/{warning-stack-bDicCvxs.js → warning-stack-DNR3-IbP.js} +17 -16
  166. package/dist/_chunks/warning-stack-DNR3-IbP.js.map +1 -0
  167. package/dist/_chunks/{workflow-map-uSiHbOWQ.js → workflow-map-C3gB0FvB.js} +3 -2
  168. package/dist/_chunks/{workflow-map-uSiHbOWQ.js.map → workflow-map-C3gB0FvB.js.map} +1 -1
  169. package/dist/_chunks/{zh-CN-C9qi5oak.js → zh-CN-eXB-PFu4.js} +3 -3
  170. package/dist/_chunks/{zh-CN-C9qi5oak.js.map → zh-CN-eXB-PFu4.js.map} +1 -1
  171. package/dist/agent-catalog.json +241 -1
  172. package/dist/brand/product-lockup/product-lockup.d.ts.map +1 -1
  173. package/dist/brand/provider-marks/apple-pay.d.ts +12 -0
  174. package/dist/brand/provider-marks/apple-pay.d.ts.map +1 -0
  175. package/dist/brand/provider-marks/apple.d.ts +12 -0
  176. package/dist/brand/provider-marks/apple.d.ts.map +1 -0
  177. package/dist/brand/provider-marks/google-pay.d.ts +12 -0
  178. package/dist/brand/provider-marks/google-pay.d.ts.map +1 -0
  179. package/dist/brand/provider-marks/google.d.ts +13 -0
  180. package/dist/brand/provider-marks/google.d.ts.map +1 -0
  181. package/dist/components/_shared/insert-result.d.ts +47 -0
  182. package/dist/components/_shared/insert-result.d.ts.map +1 -0
  183. package/dist/components/accordion/index.js +1 -1
  184. package/dist/components/agenda-tray/agenda-tray.d.ts.map +1 -1
  185. package/dist/components/agenda-tray/index.js +1 -1
  186. package/dist/components/bmi-calculator/bmi-calculator.d.ts +3 -0
  187. package/dist/components/bmi-calculator/bmi-calculator.d.ts.map +1 -1
  188. package/dist/components/bmi-calculator/index.js +6 -5
  189. package/dist/components/bmi-calculator/index.js.map +1 -1
  190. package/dist/components/booking/index.js +1 -1
  191. package/dist/components/calculator-dialog/calculator-dialog.d.ts +26 -0
  192. package/dist/components/calculator-dialog/calculator-dialog.d.ts.map +1 -0
  193. package/dist/components/calculator-dialog/index.d.ts +3 -0
  194. package/dist/components/calculator-dialog/index.d.ts.map +1 -0
  195. package/dist/components/calculator-dialog/index.js +5 -0
  196. package/dist/components/calculator-dialog/index.js.map +1 -0
  197. package/dist/components/chart/chart.d.ts +1 -1
  198. package/dist/components/chart/chart.d.ts.map +1 -1
  199. package/dist/components/chart/index.js +1 -1
  200. package/dist/components/chat-message/index.js +1 -1
  201. package/dist/components/collapsible/index.js +1 -1
  202. package/dist/components/contact-profile-card/index.js +1 -1
  203. package/dist/components/cycle-calculator/cycle-calculator.d.ts +21 -0
  204. package/dist/components/cycle-calculator/cycle-calculator.d.ts.map +1 -0
  205. package/dist/components/cycle-calculator/cycle.d.ts +37 -0
  206. package/dist/components/cycle-calculator/cycle.d.ts.map +1 -0
  207. package/dist/components/cycle-calculator/index.d.ts +4 -0
  208. package/dist/components/cycle-calculator/index.d.ts.map +1 -0
  209. package/dist/components/cycle-calculator/index.js +7 -0
  210. package/dist/components/cycle-calculator/index.js.map +1 -0
  211. package/dist/components/data-table/index.js +1 -1
  212. package/dist/components/date-picker/index.js +1 -1
  213. package/dist/components/date-range-picker/index.js +1 -1
  214. package/dist/components/date-time-picker/index.js +1 -1
  215. package/dist/components/dependent-selector/dependent-selector.agent.d.ts +4 -0
  216. package/dist/components/dependent-selector/dependent-selector.agent.d.ts.map +1 -0
  217. package/dist/components/dependent-selector/dependent-selector.d.ts +72 -0
  218. package/dist/components/dependent-selector/dependent-selector.d.ts.map +1 -0
  219. package/dist/components/dependent-selector/index.d.ts +4 -0
  220. package/dist/components/dependent-selector/index.d.ts.map +1 -0
  221. package/dist/components/dependent-selector/index.js +6 -0
  222. package/dist/components/dependent-selector/index.js.map +1 -0
  223. package/dist/components/document-scanner/document-scanner.agent.d.ts +4 -0
  224. package/dist/components/document-scanner/document-scanner.agent.d.ts.map +1 -0
  225. package/dist/components/document-scanner/document-scanner.d.ts +93 -0
  226. package/dist/components/document-scanner/document-scanner.d.ts.map +1 -0
  227. package/dist/components/document-scanner/index.d.ts +4 -0
  228. package/dist/components/document-scanner/index.d.ts.map +1 -0
  229. package/dist/components/document-scanner/index.js +6 -0
  230. package/dist/components/document-scanner/index.js.map +1 -0
  231. package/dist/components/due-date-calculator/due-date-calculator.d.ts +3 -0
  232. package/dist/components/due-date-calculator/due-date-calculator.d.ts.map +1 -1
  233. package/dist/components/due-date-calculator/gestation.d.ts +16 -0
  234. package/dist/components/due-date-calculator/gestation.d.ts.map +1 -1
  235. package/dist/components/due-date-calculator/index.d.ts +1 -1
  236. package/dist/components/due-date-calculator/index.d.ts.map +1 -1
  237. package/dist/components/due-date-calculator/index.js +10 -7
  238. package/dist/components/due-date-calculator/index.js.map +1 -1
  239. package/dist/components/file-upload/index.js +1 -1
  240. package/dist/components/fiscal-code-input/calculate-codice-fiscale.d.ts +24 -0
  241. package/dist/components/fiscal-code-input/calculate-codice-fiscale.d.ts.map +1 -0
  242. package/dist/components/fiscal-code-input/fiscal-code-input.agent.d.ts +4 -0
  243. package/dist/components/fiscal-code-input/fiscal-code-input.agent.d.ts.map +1 -0
  244. package/dist/components/fiscal-code-input/fiscal-code-input.d.ts +61 -0
  245. package/dist/components/fiscal-code-input/fiscal-code-input.d.ts.map +1 -0
  246. package/dist/components/fiscal-code-input/index.d.ts +6 -0
  247. package/dist/components/fiscal-code-input/index.d.ts.map +1 -0
  248. package/dist/components/fiscal-code-input/index.js +11 -0
  249. package/dist/components/fiscal-code-input/index.js.map +1 -0
  250. package/dist/components/fiscal-code-input/is-valid-codice-fiscale.d.ts +21 -0
  251. package/dist/components/fiscal-code-input/is-valid-codice-fiscale.d.ts.map +1 -0
  252. package/dist/components/freemium-paywall/index.js +1 -1
  253. package/dist/components/gestational-age-calculator/gestational-age-calculator.d.ts +27 -0
  254. package/dist/components/gestational-age-calculator/gestational-age-calculator.d.ts.map +1 -0
  255. package/dist/components/gestational-age-calculator/index.d.ts +3 -0
  256. package/dist/components/gestational-age-calculator/index.d.ts.map +1 -0
  257. package/dist/components/gestational-age-calculator/index.js +5 -0
  258. package/dist/components/gestational-age-calculator/index.js.map +1 -0
  259. package/dist/components/header-settings/header-settings.agent.d.ts +4 -0
  260. package/dist/components/header-settings/header-settings.agent.d.ts.map +1 -0
  261. package/dist/components/header-settings/header-settings.d.ts +36 -0
  262. package/dist/components/header-settings/header-settings.d.ts.map +1 -0
  263. package/dist/components/header-settings/index.d.ts +2 -0
  264. package/dist/components/header-settings/index.d.ts.map +1 -0
  265. package/dist/components/header-settings/index.js +2 -241
  266. package/dist/components/header-settings/index.js.map +1 -1
  267. package/dist/components/index.d.ts +14 -0
  268. package/dist/components/index.d.ts.map +1 -1
  269. package/dist/components/locale-picker/locale-picker.agent.d.ts +4 -0
  270. package/dist/components/locale-picker/locale-picker.agent.d.ts.map +1 -0
  271. package/dist/components/locale-picker/locale-picker.d.ts +80 -0
  272. package/dist/components/locale-picker/locale-picker.d.ts.map +1 -0
  273. package/dist/components/logo/index.js +1 -1
  274. package/dist/components/map-view/index.js +1 -1
  275. package/dist/components/message-card/index.js +1 -1
  276. package/dist/components/message-card/message-card.d.ts.map +1 -1
  277. package/dist/components/message-tray/index.js +1 -1
  278. package/dist/components/notification-card/index.js +1 -1
  279. package/dist/components/notification-card/notification-card.d.ts.map +1 -1
  280. package/dist/components/notification-tray/index.js +1 -1
  281. package/dist/components/otp-input/index.d.ts +1 -1
  282. package/dist/components/otp-input/index.d.ts.map +1 -1
  283. package/dist/components/otp-input/index.js +1 -1
  284. package/dist/components/otp-input/otp-input.d.ts +1 -1
  285. package/dist/components/otp-input/otp-input.d.ts.map +1 -1
  286. package/dist/components/payment-form/index.js +1 -1
  287. package/dist/components/pdf-viewer/index.js +1 -1
  288. package/dist/components/practice-results/index.js +1 -1
  289. package/dist/components/pregnancy-weight-gain/index.d.ts +4 -0
  290. package/dist/components/pregnancy-weight-gain/index.d.ts.map +1 -0
  291. package/dist/components/pregnancy-weight-gain/index.js +9 -0
  292. package/dist/components/pregnancy-weight-gain/index.js.map +1 -0
  293. package/dist/components/pregnancy-weight-gain/pregnancy-weight-gain.d.ts +19 -0
  294. package/dist/components/pregnancy-weight-gain/pregnancy-weight-gain.d.ts.map +1 -0
  295. package/dist/components/pregnancy-weight-gain/weight-gain.d.ts +41 -0
  296. package/dist/components/pregnancy-weight-gain/weight-gain.d.ts.map +1 -0
  297. package/dist/components/privacy-lock/index.js +1 -1
  298. package/dist/components/public-footer/index.js +1 -1
  299. package/dist/components/qr-code/index.d.ts +5 -0
  300. package/dist/components/qr-code/index.d.ts.map +1 -0
  301. package/dist/components/qr-code/index.js +8 -0
  302. package/dist/components/qr-code/index.js.map +1 -0
  303. package/dist/components/qr-code/qr-code.agent.d.ts +3 -0
  304. package/dist/components/qr-code/qr-code.agent.d.ts.map +1 -0
  305. package/dist/components/qr-code/qr-code.d.ts +59 -0
  306. package/dist/components/qr-code/qr-code.d.ts.map +1 -0
  307. package/dist/components/qr-code/qr-encode.d.ts +46 -0
  308. package/dist/components/qr-code/qr-encode.d.ts.map +1 -0
  309. package/dist/components/reviews-panel/index.js +1 -1
  310. package/dist/components/rich-text-editor/index.js +1 -1
  311. package/dist/components/session-countdown/index.d.ts +4 -0
  312. package/dist/components/session-countdown/index.d.ts.map +1 -0
  313. package/dist/components/session-countdown/index.js +6 -0
  314. package/dist/components/session-countdown/index.js.map +1 -0
  315. package/dist/components/session-countdown/session-countdown.agent.d.ts +3 -0
  316. package/dist/components/session-countdown/session-countdown.agent.d.ts.map +1 -0
  317. package/dist/components/session-countdown/session-countdown.d.ts +38 -0
  318. package/dist/components/session-countdown/session-countdown.d.ts.map +1 -0
  319. package/dist/components/sidebar/index.js +1 -1
  320. package/dist/components/sign-document/index.d.ts +4 -0
  321. package/dist/components/sign-document/index.d.ts.map +1 -0
  322. package/dist/components/sign-document/index.js +6 -0
  323. package/dist/components/sign-document/index.js.map +1 -0
  324. package/dist/components/sign-document/sign-document.agent.d.ts +4 -0
  325. package/dist/components/sign-document/sign-document.agent.d.ts.map +1 -0
  326. package/dist/components/sign-document/sign-document.d.ts +47 -0
  327. package/dist/components/sign-document/sign-document.d.ts.map +1 -0
  328. package/dist/components/sign-in-with-alfadocs-button/index.js +1 -1
  329. package/dist/components/signature-capture/index.js +1 -1
  330. package/dist/components/signature-capture/signature-capture.d.ts.map +1 -1
  331. package/dist/components/social-sign-in-button/index.d.ts +3 -0
  332. package/dist/components/social-sign-in-button/index.d.ts.map +1 -0
  333. package/dist/components/social-sign-in-button/index.js +5 -0
  334. package/dist/components/social-sign-in-button/index.js.map +1 -0
  335. package/dist/components/social-sign-in-button/social-sign-in-button.d.ts +56 -0
  336. package/dist/components/social-sign-in-button/social-sign-in-button.d.ts.map +1 -0
  337. package/dist/components/sparkline/index.js +1 -1
  338. package/dist/components/sparkline/sparkline.d.ts +1 -1
  339. package/dist/components/sparkline/sparkline.d.ts.map +1 -1
  340. package/dist/components/stepper-accordion/index.js +1 -1
  341. package/dist/components/tag/index.js +1 -1
  342. package/dist/components/task-card/index.js +1 -1
  343. package/dist/components/task-card/task-card.d.ts.map +1 -1
  344. package/dist/components/task-tray/index.js +1 -1
  345. package/dist/components/task-tray/task-tray.d.ts.map +1 -1
  346. package/dist/components/transcript-panel/index.js +1 -1
  347. package/dist/components/transcript-panel/transcript-panel.d.ts.map +1 -1
  348. package/dist/components/unit-converter/index.d.ts +4 -0
  349. package/dist/components/unit-converter/index.d.ts.map +1 -0
  350. package/dist/components/unit-converter/index.js +9 -0
  351. package/dist/components/unit-converter/index.js.map +1 -0
  352. package/dist/components/unit-converter/unit-converter.d.ts +21 -0
  353. package/dist/components/unit-converter/unit-converter.d.ts.map +1 -0
  354. package/dist/components/unit-converter/units.d.ts +18 -0
  355. package/dist/components/unit-converter/units.d.ts.map +1 -0
  356. package/dist/components/wallet-pay-button/index.d.ts +3 -0
  357. package/dist/components/wallet-pay-button/index.d.ts.map +1 -0
  358. package/dist/components/wallet-pay-button/index.js +5 -0
  359. package/dist/components/wallet-pay-button/index.js.map +1 -0
  360. package/dist/components/wallet-pay-button/wallet-pay-button.d.ts +63 -0
  361. package/dist/components/wallet-pay-button/wallet-pay-button.d.ts.map +1 -0
  362. package/dist/components/warning-stack/index.js +1 -1
  363. package/dist/components/warning-stack/warning-stack.d.ts.map +1 -1
  364. package/dist/components/workflow/index.js +1 -1
  365. package/dist/components/workflow/workflow-map.d.ts.map +1 -1
  366. package/dist/i18n/locale-meta.d.ts +56 -0
  367. package/dist/i18n/locale-meta.d.ts.map +1 -0
  368. package/dist/i18n/locales/ar.d.ts +274 -0
  369. package/dist/i18n/locales/ar.d.ts.map +1 -1
  370. package/dist/i18n/locales/ar.js +271 -0
  371. package/dist/i18n/locales/ar.js.map +1 -1
  372. package/dist/i18n/locales/de.d.ts +274 -0
  373. package/dist/i18n/locales/de.d.ts.map +1 -1
  374. package/dist/i18n/locales/de.js +271 -0
  375. package/dist/i18n/locales/de.js.map +1 -1
  376. package/dist/i18n/locales/el.d.ts +274 -0
  377. package/dist/i18n/locales/el.d.ts.map +1 -1
  378. package/dist/i18n/locales/el.js +271 -0
  379. package/dist/i18n/locales/el.js.map +1 -1
  380. package/dist/i18n/locales/en.d.ts +274 -0
  381. package/dist/i18n/locales/en.d.ts.map +1 -1
  382. package/dist/i18n/locales/en.js +274 -0
  383. package/dist/i18n/locales/en.js.map +1 -1
  384. package/dist/i18n/locales/es.d.ts +274 -0
  385. package/dist/i18n/locales/es.d.ts.map +1 -1
  386. package/dist/i18n/locales/es.js +271 -0
  387. package/dist/i18n/locales/es.js.map +1 -1
  388. package/dist/i18n/locales/fr.d.ts +274 -0
  389. package/dist/i18n/locales/fr.d.ts.map +1 -1
  390. package/dist/i18n/locales/fr.js +271 -0
  391. package/dist/i18n/locales/fr.js.map +1 -1
  392. package/dist/i18n/locales/hi.d.ts +274 -0
  393. package/dist/i18n/locales/hi.d.ts.map +1 -1
  394. package/dist/i18n/locales/hi.js +271 -0
  395. package/dist/i18n/locales/hi.js.map +1 -1
  396. package/dist/i18n/locales/it.d.ts +274 -0
  397. package/dist/i18n/locales/it.d.ts.map +1 -1
  398. package/dist/i18n/locales/it.js +271 -0
  399. package/dist/i18n/locales/it.js.map +1 -1
  400. package/dist/i18n/locales/ja.d.ts +274 -0
  401. package/dist/i18n/locales/ja.d.ts.map +1 -1
  402. package/dist/i18n/locales/ja.js +267 -0
  403. package/dist/i18n/locales/ja.js.map +1 -1
  404. package/dist/i18n/locales/nl.d.ts +274 -0
  405. package/dist/i18n/locales/nl.d.ts.map +1 -1
  406. package/dist/i18n/locales/nl.js +271 -0
  407. package/dist/i18n/locales/nl.js.map +1 -1
  408. package/dist/i18n/locales/pl.d.ts +274 -0
  409. package/dist/i18n/locales/pl.d.ts.map +1 -1
  410. package/dist/i18n/locales/pl.js +271 -0
  411. package/dist/i18n/locales/pl.js.map +1 -1
  412. package/dist/i18n/locales/pt.d.ts +274 -0
  413. package/dist/i18n/locales/pt.d.ts.map +1 -1
  414. package/dist/i18n/locales/pt.js +274 -0
  415. package/dist/i18n/locales/pt.js.map +1 -1
  416. package/dist/i18n/locales/ro.d.ts +274 -0
  417. package/dist/i18n/locales/ro.d.ts.map +1 -1
  418. package/dist/i18n/locales/ro.js +271 -0
  419. package/dist/i18n/locales/ro.js.map +1 -1
  420. package/dist/i18n/locales/ru.d.ts +274 -0
  421. package/dist/i18n/locales/ru.d.ts.map +1 -1
  422. package/dist/i18n/locales/ru.js +271 -0
  423. package/dist/i18n/locales/ru.js.map +1 -1
  424. package/dist/i18n/locales/sq.d.ts +274 -0
  425. package/dist/i18n/locales/sq.d.ts.map +1 -1
  426. package/dist/i18n/locales/sq.js +271 -0
  427. package/dist/i18n/locales/sq.js.map +1 -1
  428. package/dist/i18n/locales/sv.d.ts +274 -0
  429. package/dist/i18n/locales/sv.d.ts.map +1 -1
  430. package/dist/i18n/locales/sv.js +271 -0
  431. package/dist/i18n/locales/sv.js.map +1 -1
  432. package/dist/i18n/locales/tr.d.ts +274 -0
  433. package/dist/i18n/locales/tr.d.ts.map +1 -1
  434. package/dist/i18n/locales/tr.js +271 -0
  435. package/dist/i18n/locales/tr.js.map +1 -1
  436. package/dist/i18n/locales/zh.d.ts +274 -0
  437. package/dist/i18n/locales/zh.d.ts.map +1 -1
  438. package/dist/i18n/locales/zh.js +267 -0
  439. package/dist/i18n/locales/zh.js.map +1 -1
  440. package/dist/index.js +590 -535
  441. package/dist/index.js.map +1 -1
  442. package/dist/locales/ar.json +274 -0
  443. package/dist/locales/de.json +274 -0
  444. package/dist/locales/el.json +274 -0
  445. package/dist/locales/en.json +274 -0
  446. package/dist/locales/es.json +274 -0
  447. package/dist/locales/fr.json +274 -0
  448. package/dist/locales/hi.json +274 -0
  449. package/dist/locales/it.json +274 -0
  450. package/dist/locales/ja.json +274 -0
  451. package/dist/locales/nl.json +274 -0
  452. package/dist/locales/pl.json +274 -0
  453. package/dist/locales/pt.json +274 -0
  454. package/dist/locales/ro.json +274 -0
  455. package/dist/locales/ru.json +274 -0
  456. package/dist/locales/sq.json +274 -0
  457. package/dist/locales/sv.json +274 -0
  458. package/dist/locales/tr.json +274 -0
  459. package/dist/locales/zh.json +274 -0
  460. package/dist/patterns/alia-assistant/index.js +1 -1
  461. package/dist/patterns/marketplace-app-shell/index.js +1 -1
  462. package/dist/patterns/marketplace-app-shell/marketplace-app-shell.d.ts +12 -8
  463. package/dist/patterns/marketplace-app-shell/marketplace-app-shell.d.ts.map +1 -1
  464. package/dist/patterns/patient-shell/index.js +1 -1
  465. package/dist/patterns/patient-shell/patient-shell.d.ts.map +1 -1
  466. package/dist/tokens.css +1 -1
  467. package/package.json +53 -1
  468. package/dist/_chunks/accordion-bSU21uTV.js.map +0 -1
  469. package/dist/_chunks/agenda-tray-By_asPN9.js.map +0 -1
  470. package/dist/_chunks/bmi-calculator-DQD5_nE-.js +0 -214
  471. package/dist/_chunks/bmi-calculator-DQD5_nE-.js.map +0 -1
  472. package/dist/_chunks/chart-DnHvmiDX.js.map +0 -1
  473. package/dist/_chunks/chat-message-D53_fH2w.js.map +0 -1
  474. package/dist/_chunks/collapsible-CERONory.js.map +0 -1
  475. package/dist/_chunks/due-date-calculator-kf9U_g7O.js +0 -173
  476. package/dist/_chunks/due-date-calculator-kf9U_g7O.js.map +0 -1
  477. package/dist/_chunks/file-upload-CdozCPct.js.map +0 -1
  478. package/dist/_chunks/logo-_Z-jLq80.js.map +0 -1
  479. package/dist/_chunks/marketplace-app-shell-DXHxy9dj.js +0 -295
  480. package/dist/_chunks/marketplace-app-shell-DXHxy9dj.js.map +0 -1
  481. package/dist/_chunks/message-card-BbRhZkDI.js.map +0 -1
  482. package/dist/_chunks/message-tray-B762TKuv.js.map +0 -1
  483. package/dist/_chunks/notification-card-DMdO4g54.js.map +0 -1
  484. package/dist/_chunks/otp-input-CDTWT5EK.js.map +0 -1
  485. package/dist/_chunks/payment-form-D5rgnZu7.js.map +0 -1
  486. package/dist/_chunks/pdf-viewer-DvtEHcEP.js.map +0 -1
  487. package/dist/_chunks/rich-text-editor-CHmr9Bz8.js.map +0 -1
  488. package/dist/_chunks/shield-check-BhHyReu8.js.map +0 -1
  489. package/dist/_chunks/signature-capture-C-fF71xI.js.map +0 -1
  490. package/dist/_chunks/sparkline-DEROcSl0.js.map +0 -1
  491. package/dist/_chunks/stepper-accordion-BfS6lUB9.js.map +0 -1
  492. package/dist/_chunks/subDays-D-WYRpdW.js +0 -8
  493. package/dist/_chunks/tag-CyoaEmf_.js.map +0 -1
  494. package/dist/_chunks/task-card-BUVMh6HN.js.map +0 -1
  495. package/dist/_chunks/task-tray-DRK0b0Qb.js.map +0 -1
  496. package/dist/_chunks/transcript-panel-DyhTpAP7.js.map +0 -1
  497. package/dist/_chunks/warning-stack-bDicCvxs.js.map +0 -1
@@ -0,0 +1,315 @@
1
+ import { jsxs as d, jsx as r } from "react/jsx-runtime";
2
+ import { forwardRef as ie, useId as oe, useMemo as M, useRef as k, useState as b, useEffect as L, useCallback as c, useImperativeHandle as de } from "react";
3
+ import { c as i } from "./index-D2ZczOXr.js";
4
+ import { useTranslation as ce } from "react-i18next";
5
+ import { P as le } from "./pdf-viewer-Cy6Ul3hZ.js";
6
+ import { S as ge } from "./signature-capture-BRzCklg4.js";
7
+ import { u as me } from "./registry-nPAVE19X.js";
8
+ import { C as O } from "./circle-check-9AeSgJD_.js";
9
+ const ue = {
10
+ id: "sign-document",
11
+ capabilities: ["submit"],
12
+ state: {
13
+ isReadComplete: {
14
+ type: "boolean",
15
+ descriptionKey: "signDocument.agent.state.isReadComplete",
16
+ description: "True when the reader has reached the last page (or read-gating is off).",
17
+ read: (n) => n.isReadComplete()
18
+ }
19
+ },
20
+ actions: {
21
+ submit: {
22
+ safety: "write",
23
+ descriptionKey: "signDocument.agent.actions.confirm",
24
+ description: "Confirm the current signature, emitting it via onSign. No-op if unsigned.",
25
+ invoke: (n) => n.confirm()
26
+ },
27
+ reset: {
28
+ safety: "destructive",
29
+ descriptionKey: "signDocument.agent.actions.reset",
30
+ description: "Clear the captured signature and return to unsigned.",
31
+ invoke: (n) => {
32
+ n.reset();
33
+ }
34
+ }
35
+ },
36
+ domHooks: {
37
+ root: {
38
+ attr: "data-component",
39
+ value: "sign-document",
40
+ description: "Marks the SignDocument wrapper."
41
+ },
42
+ instanceId: {
43
+ attr: "data-component-id",
44
+ sourceProp: "id",
45
+ description: "Sourced from the id prop."
46
+ }
47
+ }
48
+ }, pe = i(
49
+ [
50
+ "ds:flex ds:flex-col ds:gap-[var(--spacing-md)]",
51
+ "ds:rounded-[var(--radius-md)] ds:border ds:border-[color:var(--card-border)]",
52
+ "ds:shadow-[var(--shadow-card)] ds:[.theme-accessible_&]:border-2",
53
+ "ds:bg-[var(--background)] ds:text-[var(--foreground)]",
54
+ "ds:p-[var(--spacing-md)]",
55
+ "ds:aria-disabled:opacity-[var(--opacity-50)] ds:aria-disabled:cursor-not-allowed"
56
+ ].join(" ")
57
+ ), fe = i(
58
+ ["type-heading-sm ds:text-[var(--foreground)]"].join(" ")
59
+ ), ve = i(
60
+ ["ds:flex ds:flex-col ds:gap-[var(--spacing-sm)]"].join(" ")
61
+ ), be = i(
62
+ ["type-body-sm ds:font-medium ds:text-[var(--foreground)]"].join(" ")
63
+ ), he = i(
64
+ [
65
+ "ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)]",
66
+ "type-body-sm ds:text-[var(--muted-foreground)]"
67
+ ].join(" ")
68
+ ), ye = i(
69
+ [
70
+ "ds:flex ds:items-center ds:gap-[var(--spacing-xs)]",
71
+ "type-body-sm",
72
+ "ds:rounded-[var(--radius-sm)]",
73
+ "ds:ps-[var(--spacing-sm)] ds:pe-[var(--spacing-sm)]",
74
+ "ds:pt-[var(--spacing-xs)] ds:pb-[var(--spacing-xs)]",
75
+ "ds:bg-[color-mix(in_srgb,var(--info)_10%,transparent)]",
76
+ "ds:text-[var(--foreground)]",
77
+ "ds:border ds:border-[color:color-mix(in_srgb,var(--info)_40%,transparent)]"
78
+ ].join(" ")
79
+ ), xe = i(
80
+ [
81
+ "ds:inline-flex ds:items-center ds:justify-center ds:self-start",
82
+ "ds:min-block-size-[var(--min-target-size)]",
83
+ "ds:min-inline-size-[var(--min-target-size)]",
84
+ "ds:gap-[var(--spacing-xs)]",
85
+ "ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]",
86
+ "ds:rounded-[var(--radius-sm)]",
87
+ "ds:bg-[var(--primary)] ds:text-[var(--primary-foreground)]",
88
+ "ds:text-[length:var(--font-size-sm)] ds:font-medium",
89
+ "ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none",
90
+ "ds:hover:bg-[var(--primary-hover)]",
91
+ "ds:focus-visible:outline-[length:var(--focus-ring-width)]",
92
+ "ds:focus-visible:outline-solid",
93
+ "ds:focus-visible:outline-[var(--ring)]",
94
+ "ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]",
95
+ "ds:forced-colors:focus-visible:outline-[CanvasText]",
96
+ "ds:disabled:opacity-[var(--opacity-50)] ds:disabled:cursor-not-allowed",
97
+ "ds:disabled:hover:bg-[var(--primary)]"
98
+ ].join(" ")
99
+ ), De = i(
100
+ [
101
+ "ds:flex ds:items-center ds:gap-[var(--spacing-sm)]",
102
+ "ds:rounded-[var(--radius-sm)]",
103
+ "ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]",
104
+ "ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-sm)]",
105
+ "ds:bg-[color-mix(in_srgb,var(--success)_12%,transparent)]",
106
+ "ds:text-[var(--foreground)]",
107
+ "ds:border ds:border-[color:color-mix(in_srgb,var(--success)_45%,transparent)]"
108
+ ].join(" ")
109
+ );
110
+ function Z(n, m) {
111
+ const a = new Date(n);
112
+ if (Number.isNaN(a.getTime())) return n;
113
+ try {
114
+ return new Intl.DateTimeFormat(m, {
115
+ dateStyle: "long",
116
+ timeStyle: "short"
117
+ }).format(a);
118
+ } catch {
119
+ return a.toISOString();
120
+ }
121
+ }
122
+ const Se = ie(
123
+ ({
124
+ id: n,
125
+ src: m,
126
+ documentTitle: a,
127
+ requireReadToEnd: _ = !0,
128
+ onSign: h,
129
+ onError: y,
130
+ signedAt: x = null,
131
+ disabled: D = !1,
132
+ readOnly: S = !1,
133
+ ariaLabel: N,
134
+ className: G
135
+ }, J) => {
136
+ const { t: s, i18n: V } = ce(), z = oe(), u = M(
137
+ () => `sign-doc-${z.replace(/[^a-zA-Z0-9-_]/g, "")}`,
138
+ [z]
139
+ ), R = `${u}-doc-heading`, H = `${u}-sign-label`, Q = `${u}-live`, C = `${u}-gate-hint`, p = k(null), [E, w] = b(0), [U, $] = b(1), [W, j] = b(!1), [T, l] = b(!1), g = x != null, X = D || S || g, f = k(h), v = k(y);
140
+ L(() => {
141
+ f.current = h, v.current = y;
142
+ }, [h, y]), L(() => {
143
+ j(!1), w(0), $(1), l(!1);
144
+ }, [m]);
145
+ const Y = c(
146
+ (e) => {
147
+ w(e.numPages), e.numPages <= 1 && j(!0);
148
+ },
149
+ []
150
+ ), q = c((e) => {
151
+ $(e), w((t) => (t > 0 && e >= t && j(!0), t));
152
+ }, []), ee = c((e) => {
153
+ var t;
154
+ (t = v.current) == null || t.call(v, e);
155
+ }, []), B = !g && !S;
156
+ L(() => {
157
+ if (!B) return;
158
+ const e = () => {
159
+ const F = p.current;
160
+ F && l(!F.isEmpty());
161
+ };
162
+ e();
163
+ const t = window.setInterval(e, 200);
164
+ return () => window.clearInterval(t);
165
+ }, [B]);
166
+ const o = !_ || W, K = !(!X && o) || !T, se = c((e) => {
167
+ var t;
168
+ (t = f.current) == null || t.call(f, e);
169
+ }, []), I = c(async () => {
170
+ const e = p.current;
171
+ return e ? e.confirm() : null;
172
+ }, []), A = c(() => {
173
+ var e;
174
+ (e = p.current) == null || e.clear(), l(!1);
175
+ }, []), P = M(
176
+ () => ({
177
+ reset: A,
178
+ confirm: I,
179
+ isReadComplete: () => o
180
+ }),
181
+ [A, I, o]
182
+ );
183
+ de(J, () => P, [P]), me(ue, P, n);
184
+ const ne = N ?? (a ? s("signDocument.regionLabelNamed", { title: a }) : s("signDocument.regionLabel")), ae = a ?? s("signDocument.documentLabel"), te = g ? s("signDocument.signedOn", {
185
+ date: Z(x, V.language)
186
+ }) : o ? s("signDocument.readyToSign") : "", re = o ? T ? "" : s("signDocument.signToEnable") : s("signDocument.scrollToEnd");
187
+ return /* @__PURE__ */ d(
188
+ "div",
189
+ {
190
+ role: "group",
191
+ "aria-labelledby": !N && a ? R : void 0,
192
+ "aria-label": N || !a ? ne : void 0,
193
+ "aria-disabled": D || void 0,
194
+ className: [pe(), G].filter(Boolean).join(" "),
195
+ "data-component": "sign-document",
196
+ "data-component-id": n,
197
+ "data-signed": g || void 0,
198
+ children: [
199
+ /* @__PURE__ */ r(
200
+ "span",
201
+ {
202
+ role: "status",
203
+ "aria-live": "polite",
204
+ "aria-atomic": "true",
205
+ className: "ds:sr-only",
206
+ "data-testid": "sign-document-live",
207
+ id: Q,
208
+ children: te
209
+ }
210
+ ),
211
+ /* @__PURE__ */ r("span", { className: "ds:sr-only", id: C, children: re }),
212
+ a ? /* @__PURE__ */ r("h2", { id: R, className: fe(), children: a }) : null,
213
+ /* @__PURE__ */ r(
214
+ le,
215
+ {
216
+ src: m,
217
+ ariaLabel: ae,
218
+ onLoadComplete: Y,
219
+ onPageChange: q,
220
+ onError: ee
221
+ }
222
+ ),
223
+ g ? (
224
+ /* ---- Already-signed, read-only ---- */
225
+ /* @__PURE__ */ d(
226
+ "div",
227
+ {
228
+ className: De(),
229
+ "data-testid": "sign-document-signed",
230
+ children: [
231
+ /* @__PURE__ */ r(
232
+ O,
233
+ {
234
+ "aria-hidden": "true",
235
+ className: "ds:size-5 ds:text-[var(--success)] ds:shrink-0"
236
+ }
237
+ ),
238
+ /* @__PURE__ */ d("span", { className: "type-body-sm", children: [
239
+ /* @__PURE__ */ r("strong", { className: "ds:font-semibold", children: s("signDocument.signed") }),
240
+ " — ",
241
+ s("signDocument.signedOn", {
242
+ date: Z(x, V.language)
243
+ })
244
+ ] })
245
+ ]
246
+ }
247
+ )
248
+ ) : S ? null : (
249
+ /* ---- Sign surface ---- */
250
+ /* @__PURE__ */ d(
251
+ "div",
252
+ {
253
+ className: ve(),
254
+ role: "group",
255
+ "aria-labelledby": H,
256
+ "aria-describedby": C,
257
+ children: [
258
+ /* @__PURE__ */ d("div", { className: "ds:flex ds:flex-wrap ds:items-center ds:justify-between ds:gap-[var(--spacing-sm)]", children: [
259
+ /* @__PURE__ */ r("span", { id: H, className: be(), children: s("signDocument.signatureSection") }),
260
+ E > 0 ? /* @__PURE__ */ r(
261
+ "span",
262
+ {
263
+ className: he(),
264
+ "data-testid": "sign-document-progress",
265
+ children: s("signDocument.pageProgress", {
266
+ current: U,
267
+ total: E
268
+ })
269
+ }
270
+ ) : null
271
+ ] }),
272
+ _ && !o ? /* @__PURE__ */ r("p", { className: ye(), "data-testid": "sign-document-hint", children: s("signDocument.scrollToEnd") }) : null,
273
+ /* @__PURE__ */ r(
274
+ ge,
275
+ {
276
+ ref: p,
277
+ ariaLabel: s("signDocument.signatureSection"),
278
+ disabled: D || !o,
279
+ onStart: () => l(!0),
280
+ onClear: () => l(!1),
281
+ onConfirm: se
282
+ }
283
+ ),
284
+ /* @__PURE__ */ d(
285
+ "button",
286
+ {
287
+ type: "button",
288
+ onClick: () => {
289
+ K || I();
290
+ },
291
+ disabled: K,
292
+ "aria-describedby": C,
293
+ className: xe(),
294
+ "data-testid": "sign-document-confirm",
295
+ children: [
296
+ /* @__PURE__ */ r(O, { "aria-hidden": "true", className: "ds:size-4" }),
297
+ s("signDocument.confirm")
298
+ ]
299
+ }
300
+ )
301
+ ]
302
+ }
303
+ )
304
+ )
305
+ ]
306
+ }
307
+ );
308
+ }
309
+ );
310
+ Se.displayName = "SignDocument";
311
+ export {
312
+ Se as S,
313
+ ue as s
314
+ };
315
+ //# sourceMappingURL=sign-document-DId1p-nn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sign-document-DId1p-nn.js","sources":["../../src/components/sign-document/sign-document.agent.ts","../../src/components/sign-document/sign-document.tsx"],"sourcesContent":["/* -------------------------------------------------------------------- */\n/* Agent adapter — SignDocument. */\n/* */\n/* State exposes only structural lifecycle info — never the signature */\n/* bytes (the signed consent is sensitive; persistence is the consumer's */\n/* concern). The single write action confirms the captured signature. */\n/* */\n/* See `src/docs/26-agent-readiness.mdx` for the contract. */\n/* -------------------------------------------------------------------- */\n\nimport type { AgentAdapter } from '../../agent/types';\nimport type { SignDocumentHandle } from './sign-document';\n\nexport const signDocumentAgent: AgentAdapter<SignDocumentHandle> = {\n id: 'sign-document',\n capabilities: ['submit'],\n state: {\n isReadComplete: {\n type: 'boolean',\n descriptionKey: 'signDocument.agent.state.isReadComplete',\n description:\n 'True when the reader has reached the last page (or read-gating is off).',\n read: (handle) => handle.isReadComplete(),\n },\n },\n actions: {\n submit: {\n safety: 'write',\n descriptionKey: 'signDocument.agent.actions.confirm',\n description:\n 'Confirm the current signature, emitting it via onSign. No-op if unsigned.',\n invoke: (handle) => handle.confirm(),\n },\n reset: {\n safety: 'destructive',\n descriptionKey: 'signDocument.agent.actions.reset',\n description: 'Clear the captured signature and return to unsigned.',\n invoke: (handle) => {\n handle.reset();\n },\n },\n },\n domHooks: {\n root: {\n attr: 'data-component',\n value: 'sign-document',\n description: 'Marks the SignDocument wrapper.',\n },\n instanceId: {\n attr: 'data-component-id',\n sourceProp: 'id',\n description: 'Sourced from the id prop.',\n },\n },\n};\n","/* ------------------------------------------------------------------ */\n/* SignDocument — review a PDF document, then sign it. */\n/* */\n/* Fills the kit gap where consumers hand-composed PDFViewer + */\n/* SignatureCapture for consents (e.g. sign.alfadocs.com, HTP-4889). */\n/* This component owns the composition and the read-gate so the consent */\n/* flow is a single primitive: */\n/* */\n/* - PDFViewer (the document) renders above; the signing surface */\n/* renders below. */\n/* - When `requireReadToEnd` (default), the SignatureCapture pad and */\n/* the \"Confirm & sign\" button are gated until the reader reaches the */\n/* LAST page. We track this via PDFViewer's onLoadComplete (numPages) */\n/* + onPageChange (currentPage === numPages). NOTE: last-page-reached */\n/* is an APPROXIMATE read signal — a fit-page zoom can show the last */\n/* page without scrolling. That is acceptable for this gate; a */\n/* legal-grade \"read every page\" guarantee is the consumer's call. */\n/* - When `signedAt` is set the component renders an already-signed */\n/* read-only state (no pad) so re-sign-on-change consumers can show */\n/* signed status. */\n/* - Security: no fetch / XHR / storage / globals here. SignatureCapture */\n/* owns the export payload (PNG/SVG + sha256); the consumer owns */\n/* persistence via onSign. */\n/* - i18n: every authored string via `t('signDocument.*')` (bare keys */\n/* under the `ui` namespace). PDFViewer's `pdf.*` and */\n/* SignatureCapture's `signature.*` strings already exist. */\n/* ------------------------------------------------------------------ */\n\nimport {\n forwardRef,\n useCallback,\n useEffect,\n useId,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { cva } from 'class-variance-authority';\nimport { useTranslation } from 'react-i18next';\nimport { CheckCircle2 } from 'lucide-react';\nimport { PDFViewer } from '../pdf-viewer';\nimport {\n SignatureCapture,\n type SignatureCaptureHandle,\n type SignatureConfirmPayload,\n} from '../signature-capture';\nimport { useAgentRegistration } from '../../agent';\nimport { signDocumentAgent } from './sign-document.agent';\n\n/* ------------------------------------------------------------------ */\n/* Public types */\n/* ------------------------------------------------------------------ */\n\nexport interface SignDocumentProps {\n /** Opaque instance id — emitted as `data-component-id` for the agent registry. */\n id?: string;\n /** Document PDF — URL string, ArrayBuffer, or Uint8Array. Passed to PDFViewer. */\n src: string | ArrayBuffer | Uint8Array;\n /** Accessible name for the document region (also used as a heading). */\n documentTitle?: string;\n /**\n * Gate the signature + Confirm until the reader reaches the last page.\n * Default `true`. Last-page-reached is an approximate read signal (a\n * fit-page zoom can show the last page without scrolling) — adequate for\n * this gate; legal-grade read tracking is the consumer's concern.\n */\n requireReadToEnd?: boolean;\n /** Fired when the user captures a signature AND confirms. */\n onSign?: (payload: SignatureConfirmPayload) => void;\n /** Forwarded from PDFViewer on any load / render error. */\n onError?: (error: Error) => void;\n /**\n * When set, render the already-signed read-only state: shows \"Signed\" +\n * the signed date and hides the pad. Use for re-sign-on-change consumers\n * that surface signed status. `null` / `undefined` → unsigned.\n */\n signedAt?: string | null;\n /** Disable all controls (document still readable). */\n disabled?: boolean;\n /** Render read-only: the document is shown but the pad is suppressed. */\n readOnly?: boolean;\n /** Accessible label for the component's group region. */\n ariaLabel?: string;\n /** Extra class names merged onto the outermost wrapper. */\n className?: string;\n}\n\n/** Curated imperative handle for agent / external automation. */\nexport interface SignDocumentHandle {\n /** Clear the captured signature, returning to the unsigned state. */\n reset: () => void;\n /** Confirm the current signature; resolves the payload, or null if unsigned. */\n confirm: () => Promise<SignatureConfirmPayload | null>;\n /** True when the reader has reached the last page (or the gate is off). */\n isReadComplete: () => boolean;\n}\n\n/* ------------------------------------------------------------------ */\n/* CVA */\n/* ------------------------------------------------------------------ */\n\nconst rootVariants = cva(\n [\n 'ds:flex ds:flex-col ds:gap-[var(--spacing-md)]',\n 'ds:rounded-[var(--radius-md)] ds:border ds:border-[color:var(--card-border)]',\n 'ds:shadow-[var(--shadow-card)] ds:[.theme-accessible_&]:border-2',\n 'ds:bg-[var(--background)] ds:text-[var(--foreground)]',\n 'ds:p-[var(--spacing-md)]',\n 'ds:aria-disabled:opacity-[var(--opacity-50)] ds:aria-disabled:cursor-not-allowed',\n ].join(' '),\n);\n\nconst headingVariants = cva(\n ['type-heading-sm ds:text-[var(--foreground)]'].join(' '),\n);\n\nconst signSectionVariants = cva(\n ['ds:flex ds:flex-col ds:gap-[var(--spacing-sm)]'].join(' '),\n);\n\nconst sectionLabelVariants = cva(\n ['type-body-sm ds:font-medium ds:text-[var(--foreground)]'].join(' '),\n);\n\nconst progressVariants = cva(\n [\n 'ds:inline-flex ds:items-center ds:gap-[var(--spacing-xs)]',\n 'type-body-sm ds:text-[var(--muted-foreground)]',\n ].join(' '),\n);\n\n// The \"scroll to the end to sign\" hint uses --info as a low-emphasis\n// informational tint — tokenised, logical-property insets, no accent over\n// arbitrary content.\nconst hintVariants = cva(\n [\n 'ds:flex ds:items-center ds:gap-[var(--spacing-xs)]',\n 'type-body-sm',\n 'ds:rounded-[var(--radius-sm)]',\n 'ds:ps-[var(--spacing-sm)] ds:pe-[var(--spacing-sm)]',\n 'ds:pt-[var(--spacing-xs)] ds:pb-[var(--spacing-xs)]',\n 'ds:bg-[color-mix(in_srgb,var(--info)_10%,transparent)]',\n 'ds:text-[var(--foreground)]',\n 'ds:border ds:border-[color:color-mix(in_srgb,var(--info)_40%,transparent)]',\n ].join(' '),\n);\n\nconst confirmButtonVariants = cva(\n [\n 'ds:inline-flex ds:items-center ds:justify-center ds:self-start',\n 'ds:min-block-size-[var(--min-target-size)]',\n 'ds:min-inline-size-[var(--min-target-size)]',\n 'ds:gap-[var(--spacing-xs)]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:rounded-[var(--radius-sm)]',\n 'ds:bg-[var(--primary)] ds:text-[var(--primary-foreground)]',\n 'ds:text-[length:var(--font-size-sm)] ds:font-medium',\n 'ds:transition-colors ds:duration-[var(--animation-duration)] ds:motion-reduce:transition-none',\n 'ds:hover:bg-[var(--primary-hover)]',\n 'ds:focus-visible:outline-[length:var(--focus-ring-width)]',\n 'ds:focus-visible:outline-solid',\n 'ds:focus-visible:outline-[var(--ring)]',\n 'ds:focus-visible:outline-offset-[length:var(--focus-ring-offset)]',\n 'ds:forced-colors:focus-visible:outline-[CanvasText]',\n 'ds:disabled:opacity-[var(--opacity-50)] ds:disabled:cursor-not-allowed',\n 'ds:disabled:hover:bg-[var(--primary)]',\n ].join(' '),\n);\n\n// The signed banner uses the semantic --success alias for the confirmed\n// state — never the raw ramp step (constraint §11).\nconst signedBannerVariants = cva(\n [\n 'ds:flex ds:items-center ds:gap-[var(--spacing-sm)]',\n 'ds:rounded-[var(--radius-sm)]',\n 'ds:ps-[var(--spacing-md)] ds:pe-[var(--spacing-md)]',\n 'ds:pt-[var(--spacing-sm)] ds:pb-[var(--spacing-sm)]',\n 'ds:bg-[color-mix(in_srgb,var(--success)_12%,transparent)]',\n 'ds:text-[var(--foreground)]',\n 'ds:border ds:border-[color:color-mix(in_srgb,var(--success)_45%,transparent)]',\n ].join(' '),\n);\n\n/* ------------------------------------------------------------------ */\n/* Helpers */\n/* ------------------------------------------------------------------ */\n\n/**\n * Format an ISO timestamp using the active i18n locale. Falls back to the\n * raw string if it can't be parsed so a malformed `signedAt` never throws.\n */\nfunction formatSignedAt(iso: string, locale: string): string {\n const date = new Date(iso);\n if (Number.isNaN(date.getTime())) return iso;\n try {\n return new Intl.DateTimeFormat(locale, {\n dateStyle: 'long',\n timeStyle: 'short',\n }).format(date);\n } catch {\n return date.toISOString();\n }\n}\n\n/* ------------------------------------------------------------------ */\n/* SignDocument */\n/* ------------------------------------------------------------------ */\n\nexport const SignDocument = forwardRef<SignDocumentHandle, SignDocumentProps>(\n (\n {\n id,\n src,\n documentTitle,\n requireReadToEnd = true,\n onSign,\n onError,\n signedAt = null,\n disabled = false,\n readOnly = false,\n ariaLabel,\n className,\n },\n ref,\n ) => {\n const { t, i18n } = useTranslation();\n const rawId = useId();\n const idSafe = useMemo(\n () => `sign-doc-${rawId.replace(/[^a-zA-Z0-9-_]/g, '')}`,\n [rawId],\n );\n const docHeadingId = `${idSafe}-doc-heading`;\n const signLabelId = `${idSafe}-sign-label`;\n const liveRegionId = `${idSafe}-live`;\n // Stable, static describedby target for the sign section + Confirm —\n // kept separate from the polite live region so describedby points at\n // unchanging text, not the transition announcer (which only carries\n // gate-met / signed announcements).\n const gateHintId = `${idSafe}-gate-hint`;\n\n const signatureRef = useRef<SignatureCaptureHandle>(null);\n\n const [numPages, setNumPages] = useState(0);\n const [currentPage, setCurrentPage] = useState(1);\n // True once the reader has reached the last page at least once. Sticky:\n // scrolling back up does not re-lock the signature.\n const [reachedEnd, setReachedEnd] = useState(false);\n // Mirrors the pad's ink state so the Confirm button re-renders when a\n // signature lands. SignatureCapture's isEmpty() is a sync ref read (no\n // re-render) and its onStart only fires on a DRAWN stroke — not on the\n // typed fallback. We poll the handle so both paths gate Confirm\n // identically; onStart/onClear below are immediate-feedback hints.\n const [hasSignature, setHasSignature] = useState(false);\n\n const isSigned = signedAt != null;\n const inert = disabled || readOnly || isSigned;\n\n // Latest callbacks via refs so the async confirm path never closes over\n // a stale prop.\n const onSignRef = useRef(onSign);\n const onErrorRef = useRef(onError);\n useEffect(() => {\n onSignRef.current = onSign;\n onErrorRef.current = onError;\n }, [onSign, onError]);\n\n /* ---- Per-document reset -------------------------------------- */\n // When the consumer swaps `src` to a NEW document, the previous \"read\n // complete\" state must NOT carry over — otherwise the new document\n // could be signed without being read. Reset the per-document state;\n // PDFViewer's onLoadComplete re-sets reachedEnd for single-page docs.\n useEffect(() => {\n setReachedEnd(false);\n setNumPages(0);\n setCurrentPage(1);\n setHasSignature(false);\n }, [src]);\n\n /* ---- Read-gate tracking -------------------------------------- */\n const handleLoadComplete = useCallback(\n (info: { numPages: number; title?: string }) => {\n setNumPages(info.numPages);\n // A single-page document is \"read to the end\" the moment it loads.\n if (info.numPages <= 1) setReachedEnd(true);\n },\n [],\n );\n\n const handlePageChange = useCallback((page: number) => {\n setCurrentPage(page);\n setNumPages((total) => {\n if (total > 0 && page >= total) setReachedEnd(true);\n return total;\n });\n }, []);\n\n const handleError = useCallback((error: Error) => {\n onErrorRef.current?.(error);\n }, []);\n\n /* ---- Signature-presence polling ------------------------------ */\n // Poll the pad's isEmpty() while the signing surface is live so the\n // Confirm button reflects both drawn AND typed signatures. Cheap\n // (a single boolean ref read on an interval); torn down when signed,\n // read-only, or unmounted.\n const signLive = !isSigned && !readOnly;\n useEffect(() => {\n if (!signLive) return undefined;\n const tick = (): void => {\n const pad = signatureRef.current;\n if (!pad) return;\n setHasSignature(!pad.isEmpty());\n };\n tick();\n const interval = window.setInterval(tick, 200);\n return () => window.clearInterval(interval);\n }, [signLive]);\n\n // The gate is satisfied when reading isn't required, or the reader has\n // reached the last page at least once.\n const readComplete = !requireReadToEnd || reachedEnd;\n const canSign = !inert && readComplete;\n const confirmDisabled = !canSign || !hasSignature;\n\n /* ---- Confirm path -------------------------------------------- */\n // `onSign` fires from SignatureCapture's `onConfirm` (wired below) — the\n // single source of truth, so it fires once whether the user clicks the\n // pad's own Confirm or this component's \"Confirm & sign\". This handle\n // just proxies the pad's confirm() and returns its payload.\n const handleSigned = useCallback((payload: SignatureConfirmPayload) => {\n onSignRef.current?.(payload);\n }, []);\n\n const confirm =\n useCallback(async (): Promise<SignatureConfirmPayload | null> => {\n const pad = signatureRef.current;\n if (!pad) return null;\n return pad.confirm();\n }, []);\n\n const reset = useCallback(() => {\n signatureRef.current?.clear();\n setHasSignature(false);\n }, []);\n\n /* ---- Imperative handle + agent registration ------------------ */\n const agentHandle = useMemo<SignDocumentHandle>(\n () => ({\n reset,\n confirm,\n isReadComplete: () => readComplete,\n }),\n [reset, confirm, readComplete],\n );\n useImperativeHandle(ref, () => agentHandle, [agentHandle]);\n useAgentRegistration(signDocumentAgent, agentHandle, id);\n\n /* ---- Derived strings ----------------------------------------- */\n const regionLabel =\n ariaLabel ??\n (documentTitle\n ? t('signDocument.regionLabelNamed', { title: documentTitle })\n : t('signDocument.regionLabel'));\n const documentRegionLabel =\n documentTitle ?? t('signDocument.documentLabel');\n\n // Live region — ONLY transition announcements (gate met / signed).\n const liveText = isSigned\n ? t('signDocument.signedOn', {\n date: formatSignedAt(signedAt as string, i18n.language),\n })\n : readComplete\n ? t('signDocument.readyToSign')\n : '';\n\n // Static describedby target — always names WHY Confirm is unavailable\n // (or stays empty when it's actionable). Stable text, never live.\n const gateHintText = !readComplete\n ? t('signDocument.scrollToEnd')\n : !hasSignature\n ? t('signDocument.signToEnable')\n : '';\n\n return (\n <div\n role=\"group\"\n // Prefer labelling by the visible heading so the visible + accessible\n // names match; fall back to aria-label only when there's no heading.\n aria-labelledby={!ariaLabel && documentTitle ? docHeadingId : undefined}\n aria-label={ariaLabel || !documentTitle ? regionLabel : undefined}\n aria-disabled={disabled || undefined}\n className={[rootVariants(), className].filter(Boolean).join(' ')}\n data-component=\"sign-document\"\n data-component-id={id}\n data-signed={isSigned || undefined}\n >\n {/* Polite live region — ONLY transition announcements (gate met /\n signed). Static describedby text lives in the gate-hint span. */}\n <span\n role=\"status\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n className=\"ds:sr-only\"\n data-testid=\"sign-document-live\"\n id={liveRegionId}\n >\n {liveText}\n </span>\n\n {/* Static, non-live describedby target for the sign group + Confirm:\n names why Confirm is unavailable (or empty when actionable). */}\n <span className=\"ds:sr-only\" id={gateHintId}>\n {gateHintText}\n </span>\n\n {documentTitle ? (\n <h2 id={docHeadingId} className={headingVariants()}>\n {documentTitle}\n </h2>\n ) : null}\n\n {/* The document. PDFViewer owns its own toolbar, a11y, and zoom. */}\n <PDFViewer\n src={src}\n ariaLabel={documentRegionLabel}\n onLoadComplete={handleLoadComplete}\n onPageChange={handlePageChange}\n onError={handleError}\n />\n\n {isSigned ? (\n /* ---- Already-signed, read-only ---- */\n <div\n className={signedBannerVariants()}\n data-testid=\"sign-document-signed\"\n >\n <CheckCircle2\n aria-hidden=\"true\"\n className=\"ds:size-5 ds:text-[var(--success)] ds:shrink-0\"\n />\n <span className=\"type-body-sm\">\n <strong className=\"ds:font-semibold\">\n {t('signDocument.signed')}\n </strong>\n {' — '}\n {t('signDocument.signedOn', {\n date: formatSignedAt(signedAt as string, i18n.language),\n })}\n </span>\n </div>\n ) : readOnly ? null : (\n /* ---- Sign surface ---- */\n <div\n className={signSectionVariants()}\n role=\"group\"\n aria-labelledby={signLabelId}\n aria-describedby={gateHintId}\n >\n <div className=\"ds:flex ds:flex-wrap ds:items-center ds:justify-between ds:gap-[var(--spacing-sm)]\">\n <span id={signLabelId} className={sectionLabelVariants()}>\n {t('signDocument.signatureSection')}\n </span>\n {numPages > 0 ? (\n <span\n className={progressVariants()}\n data-testid=\"sign-document-progress\"\n >\n {t('signDocument.pageProgress', {\n current: currentPage,\n total: numPages,\n })}\n </span>\n ) : null}\n </div>\n\n {requireReadToEnd && !readComplete ? (\n <p className={hintVariants()} data-testid=\"sign-document-hint\">\n {t('signDocument.scrollToEnd')}\n </p>\n ) : null}\n\n {/* The pad is always mounted so a keyboard user can prepare a\n typed signature; the Confirm button is the gate. When the\n read-gate is unmet the pad is disabled so it can't accept\n ink prematurely. */}\n <SignatureCapture\n ref={signatureRef}\n ariaLabel={t('signDocument.signatureSection')}\n disabled={disabled || !readComplete}\n onStart={() => setHasSignature(true)}\n onClear={() => setHasSignature(false)}\n onConfirm={handleSigned}\n />\n\n {/* Native `disabled` (not aria-disabled) so a gated Confirm\n leaves the tab order entirely — mirrors how Button gates a\n primary action. describedby names WHY it's unavailable. */}\n <button\n type=\"button\"\n onClick={() => {\n if (confirmDisabled) return;\n void confirm();\n }}\n disabled={confirmDisabled}\n aria-describedby={gateHintId}\n className={confirmButtonVariants()}\n data-testid=\"sign-document-confirm\"\n >\n <CheckCircle2 aria-hidden=\"true\" className=\"ds:size-4\" />\n {t('signDocument.confirm')}\n </button>\n </div>\n )}\n </div>\n );\n },\n);\n\nSignDocument.displayName = 'SignDocument';\n\nexport { rootVariants as signDocumentRootVariants };\n"],"names":["signDocumentAgent","handle","rootVariants","cva","headingVariants","signSectionVariants","sectionLabelVariants","progressVariants","hintVariants","confirmButtonVariants","signedBannerVariants","formatSignedAt","iso","locale","date","SignDocument","forwardRef","id","src","documentTitle","requireReadToEnd","onSign","onError","signedAt","disabled","readOnly","ariaLabel","className","ref","t","i18n","useTranslation","rawId","useId","idSafe","useMemo","docHeadingId","signLabelId","liveRegionId","gateHintId","signatureRef","useRef","numPages","setNumPages","useState","currentPage","setCurrentPage","reachedEnd","setReachedEnd","hasSignature","setHasSignature","isSigned","inert","onSignRef","onErrorRef","useEffect","handleLoadComplete","useCallback","info","handlePageChange","page","total","handleError","error","_a","signLive","tick","pad","interval","readComplete","confirmDisabled","handleSigned","payload","confirm","reset","agentHandle","useImperativeHandle","useAgentRegistration","regionLabel","documentRegionLabel","liveText","gateHintText","jsxs","jsx","PDFViewer","CheckCircle2","SignatureCapture"],"mappings":"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"}
@@ -2,7 +2,7 @@ import { jsx as e } from "react/jsx-runtime";
2
2
  import { forwardRef as L, useRef as c, useEffect as b } from "react";
3
3
  import { useTranslation as y } from "react-i18next";
4
4
  import { B as E } from "./button-DD_0Xdmr.js";
5
- import { L as I } from "./logo-_Z-jLq80.js";
5
+ import { L as I } from "./logo-yituK7sE.js";
6
6
  import { S as g } from "./spinner-CCByyvcb.js";
7
7
  const A = /* @__PURE__ */ new Set([
8
8
  "primary",
@@ -46,4 +46,4 @@ B.displayName = "SignInWithAlfadocsButton";
46
46
  export {
47
47
  B as S
48
48
  };
49
- //# sourceMappingURL=sign-in-with-alfadocs-button-BI0fVonM.js.map
49
+ //# sourceMappingURL=sign-in-with-alfadocs-button-DeHBFRNS.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"sign-in-with-alfadocs-button-BI0fVonM.js","sources":["../../src/components/sign-in-with-alfadocs-button/sign-in-with-alfadocs-button.tsx"],"sourcesContent":["import { forwardRef, useEffect, useRef, type ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { Button, type ButtonProps } from '../button';\nimport { Logo } from '../logo';\nimport { Spinner } from '../spinner';\n\n// A provider-style button (\"Sign in with AlfaDocs\"). Wraps the Button\n// primitive so it inherits the full intent / size / asChild / endIcon /\n// forced-colors / focus-ring contract for free.\n//\n// The only differences from a plain Button are:\n// 1. A sensible default label resolved from the\n// `ui.auth.continueWithAlfadocs` translation key.\n// 2. The AlfaDocs brand mark rendered as the leading icon.\n// 3. Loading swaps the mark for the kit's `Spinner` (pulse variant)\n// rather than Button's hand-rolled SVG — visually consistent with\n// every other loading affordance in the kit.\n//\n// `destructive` is intentionally omitted — there is no \"delete the\n// user's account\" sign-in flow that this button represents.\n\ntype AllowedIntent = Exclude<NonNullable<ButtonProps['intent']>, 'destructive'>;\n\n// Intents that paint the button surface and use a foreground-tinted\n// text colour. The mark needs to inherit `currentColor` here so it\n// reads against the coloured surface; on transparent intents the\n// mark's own brand violet contrasts naturally with the foreground\n// text.\nconst FILLED_INTENTS = new Set<AllowedIntent>([\n 'primary',\n 'secondary',\n 'tonal',\n]);\n\nexport interface SignInWithAlfadocsButtonProps extends Omit<\n ButtonProps,\n 'startIcon' | 'children' | 'intent'\n> {\n /**\n * Visual intent. Inherits the Button intent set with `destructive`\n * omitted (no \"destroy account\" sign-in flow exists).\n */\n intent?: AllowedIntent;\n /**\n * Override the visible label. When omitted, the component reads\n * `ui.auth.continueWithAlfadocs` (English fallback: \"Continue with\n * AlfaDocs\"). Pass a node to render e.g. \"Sign in with AlfaDocs\" or a\n * fully-translated string.\n */\n label?: ReactNode;\n /**\n * Fired when the component detects the user has cancelled an\n * in-flight sign-in — typically by pressing the browser back button\n * after the OAuth redirect, which restores the page from bfcache\n * with `loading` still true. Wire this to your loading-state\n * setter so the button returns to idle:\n *\n * ```tsx\n * <SignInWithAlfadocsButton\n * loading={signingIn}\n * onLoadingCancelled={() => setSigningIn(false)}\n * onClick={() => { setSigningIn(true); window.location = oauthUrl }}\n * />\n * ```\n *\n * Without this, your `loading` state would survive the back\n * navigation and the button would appear permanently stuck. Only\n * fires when `loading` is currently true; never fires on first mount.\n */\n onLoadingCancelled?: () => void;\n}\n\nexport const SignInWithAlfadocsButton = forwardRef<\n HTMLButtonElement,\n SignInWithAlfadocsButtonProps\n>(\n (\n {\n intent = 'primary',\n size,\n loading = false,\n disabled,\n label,\n onLoadingCancelled,\n type = 'button',\n ...props\n },\n ref,\n ) => {\n const { t } = useTranslation();\n const resolvedLabel =\n label ?? t('auth.continueWithAlfadocs', 'Continue with AlfaDocs');\n const logoTone = FILLED_INTENTS.has(intent) ? 'inherit' : 'auto';\n const resolvedSize = size ?? 'md';\n\n // Stash the latest values in refs so the `pageshow` listener can\n // read them without re-binding on every render. Only one listener\n // attaches for the lifetime of the component.\n const loadingRef = useRef(loading);\n const onCancelRef = useRef(onLoadingCancelled);\n loadingRef.current = loading;\n onCancelRef.current = onLoadingCancelled;\n\n useEffect(() => {\n const onPageShow = (event: PageTransitionEvent) => {\n // `event.persisted` is true when the page was restored from\n // the back/forward cache — the canonical signal for \"user\n // navigated away and came back without a fresh load.\" If the\n // button thinks it's still loading, that means an OAuth\n // redirect was started but never completed.\n if (event.persisted && loadingRef.current && onCancelRef.current) {\n onCancelRef.current();\n }\n };\n window.addEventListener('pageshow', onPageShow);\n return () => window.removeEventListener('pageshow', onPageShow);\n }, []);\n\n // We don't forward `loading` to Button — Button would render its\n // own inline SVG and hide the label. Instead we keep the label\n // visible, swap the leading icon for the kit's Spinner, and\n // reproduce the disabled / aria-busy contract manually.\n return (\n <Button\n ref={ref}\n type={type}\n intent={intent}\n size={size}\n disabled={disabled || loading}\n aria-busy={loading || undefined}\n data-component=\"sign-in-with-alfadocs-button\"\n startIcon={\n loading ? (\n <Spinner size={resolvedSize} variant=\"pulse\" />\n ) : (\n <Logo variant=\"mark\" size=\"sm\" tone={logoTone} decorative />\n )\n }\n {...props}\n >\n {resolvedLabel}\n </Button>\n );\n },\n);\n\nSignInWithAlfadocsButton.displayName = 'SignInWithAlfadocsButton';\n"],"names":["FILLED_INTENTS","SignInWithAlfadocsButton","forwardRef","intent","size","loading","disabled","label","onLoadingCancelled","type","props","ref","t","useTranslation","resolvedLabel","logoTone","resolvedSize","loadingRef","useRef","onCancelRef","useEffect","onPageShow","event","jsx","Button","Spinner","Logo"],"mappings":";;;;;;AA4BA,MAAMA,wBAAqB,IAAmB;AAAA,EAC5C;AAAA,EACA;AAAA,EACA;AACF,CAAC,GAwCYC,IAA2BC;AAAA,EAItC,CACE;AAAA,IACE,QAAAC,IAAS;AAAA,IACT,MAAAC;AAAA,IACA,SAAAC,IAAU;AAAA,IACV,UAAAC;AAAA,IACA,OAAAC;AAAA,IACA,oBAAAC;AAAA,IACA,MAAAC,IAAO;AAAA,IACP,GAAGC;AAAA,EAAA,GAELC,MACG;AACH,UAAM,EAAE,GAAAC,EAAA,IAAMC,EAAA,GACRC,IACJP,KAASK,EAAE,6BAA6B,wBAAwB,GAC5DG,IAAWf,EAAe,IAAIG,CAAM,IAAI,YAAY,QACpDa,IAAeZ,KAAQ,MAKvBa,IAAaC,EAAOb,CAAO,GAC3Bc,IAAcD,EAAOV,CAAkB;AAC7C,WAAAS,EAAW,UAAUZ,GACrBc,EAAY,UAAUX,GAEtBY,EAAU,MAAM;AACd,YAAMC,IAAa,CAACC,MAA+B;AAMjD,QAAIA,EAAM,aAAaL,EAAW,WAAWE,EAAY,WACvDA,EAAY,QAAA;AAAA,MAEhB;AACA,oBAAO,iBAAiB,YAAYE,CAAU,GACvC,MAAM,OAAO,oBAAoB,YAAYA,CAAU;AAAA,IAChE,GAAG,CAAA,CAAE,GAOH,gBAAAE;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,KAAAb;AAAA,QACA,MAAAF;AAAA,QACA,QAAAN;AAAA,QACA,MAAAC;AAAA,QACA,UAAUE,KAAYD;AAAA,QACtB,aAAWA,KAAW;AAAA,QACtB,kBAAe;AAAA,QACf,WACEA,IACE,gBAAAkB,EAACE,KAAQ,MAAMT,GAAc,SAAQ,QAAA,CAAQ,IAE7C,gBAAAO,EAACG,GAAA,EAAK,SAAQ,QAAO,MAAK,MAAK,MAAMX,GAAU,YAAU,IAAC;AAAA,QAG7D,GAAGL;AAAA,QAEH,UAAAI;AAAA,MAAA;AAAA,IAAA;AAAA,EAGP;AACF;AAEAb,EAAyB,cAAc;"}
1
+ {"version":3,"file":"sign-in-with-alfadocs-button-DeHBFRNS.js","sources":["../../src/components/sign-in-with-alfadocs-button/sign-in-with-alfadocs-button.tsx"],"sourcesContent":["import { forwardRef, useEffect, useRef, type ReactNode } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { Button, type ButtonProps } from '../button';\nimport { Logo } from '../logo';\nimport { Spinner } from '../spinner';\n\n// A provider-style button (\"Sign in with AlfaDocs\"). Wraps the Button\n// primitive so it inherits the full intent / size / asChild / endIcon /\n// forced-colors / focus-ring contract for free.\n//\n// The only differences from a plain Button are:\n// 1. A sensible default label resolved from the\n// `ui.auth.continueWithAlfadocs` translation key.\n// 2. The AlfaDocs brand mark rendered as the leading icon.\n// 3. Loading swaps the mark for the kit's `Spinner` (pulse variant)\n// rather than Button's hand-rolled SVG — visually consistent with\n// every other loading affordance in the kit.\n//\n// `destructive` is intentionally omitted — there is no \"delete the\n// user's account\" sign-in flow that this button represents.\n\ntype AllowedIntent = Exclude<NonNullable<ButtonProps['intent']>, 'destructive'>;\n\n// Intents that paint the button surface and use a foreground-tinted\n// text colour. The mark needs to inherit `currentColor` here so it\n// reads against the coloured surface; on transparent intents the\n// mark's own brand violet contrasts naturally with the foreground\n// text.\nconst FILLED_INTENTS = new Set<AllowedIntent>([\n 'primary',\n 'secondary',\n 'tonal',\n]);\n\nexport interface SignInWithAlfadocsButtonProps extends Omit<\n ButtonProps,\n 'startIcon' | 'children' | 'intent'\n> {\n /**\n * Visual intent. Inherits the Button intent set with `destructive`\n * omitted (no \"destroy account\" sign-in flow exists).\n */\n intent?: AllowedIntent;\n /**\n * Override the visible label. When omitted, the component reads\n * `ui.auth.continueWithAlfadocs` (English fallback: \"Continue with\n * AlfaDocs\"). Pass a node to render e.g. \"Sign in with AlfaDocs\" or a\n * fully-translated string.\n */\n label?: ReactNode;\n /**\n * Fired when the component detects the user has cancelled an\n * in-flight sign-in — typically by pressing the browser back button\n * after the OAuth redirect, which restores the page from bfcache\n * with `loading` still true. Wire this to your loading-state\n * setter so the button returns to idle:\n *\n * ```tsx\n * <SignInWithAlfadocsButton\n * loading={signingIn}\n * onLoadingCancelled={() => setSigningIn(false)}\n * onClick={() => { setSigningIn(true); window.location = oauthUrl }}\n * />\n * ```\n *\n * Without this, your `loading` state would survive the back\n * navigation and the button would appear permanently stuck. Only\n * fires when `loading` is currently true; never fires on first mount.\n */\n onLoadingCancelled?: () => void;\n}\n\nexport const SignInWithAlfadocsButton = forwardRef<\n HTMLButtonElement,\n SignInWithAlfadocsButtonProps\n>(\n (\n {\n intent = 'primary',\n size,\n loading = false,\n disabled,\n label,\n onLoadingCancelled,\n type = 'button',\n ...props\n },\n ref,\n ) => {\n const { t } = useTranslation();\n const resolvedLabel =\n label ?? t('auth.continueWithAlfadocs', 'Continue with AlfaDocs');\n const logoTone = FILLED_INTENTS.has(intent) ? 'inherit' : 'auto';\n const resolvedSize = size ?? 'md';\n\n // Stash the latest values in refs so the `pageshow` listener can\n // read them without re-binding on every render. Only one listener\n // attaches for the lifetime of the component.\n const loadingRef = useRef(loading);\n const onCancelRef = useRef(onLoadingCancelled);\n loadingRef.current = loading;\n onCancelRef.current = onLoadingCancelled;\n\n useEffect(() => {\n const onPageShow = (event: PageTransitionEvent) => {\n // `event.persisted` is true when the page was restored from\n // the back/forward cache — the canonical signal for \"user\n // navigated away and came back without a fresh load.\" If the\n // button thinks it's still loading, that means an OAuth\n // redirect was started but never completed.\n if (event.persisted && loadingRef.current && onCancelRef.current) {\n onCancelRef.current();\n }\n };\n window.addEventListener('pageshow', onPageShow);\n return () => window.removeEventListener('pageshow', onPageShow);\n }, []);\n\n // We don't forward `loading` to Button — Button would render its\n // own inline SVG and hide the label. Instead we keep the label\n // visible, swap the leading icon for the kit's Spinner, and\n // reproduce the disabled / aria-busy contract manually.\n return (\n <Button\n ref={ref}\n type={type}\n intent={intent}\n size={size}\n disabled={disabled || loading}\n aria-busy={loading || undefined}\n data-component=\"sign-in-with-alfadocs-button\"\n startIcon={\n loading ? (\n <Spinner size={resolvedSize} variant=\"pulse\" />\n ) : (\n <Logo variant=\"mark\" size=\"sm\" tone={logoTone} decorative />\n )\n }\n {...props}\n >\n {resolvedLabel}\n </Button>\n );\n },\n);\n\nSignInWithAlfadocsButton.displayName = 'SignInWithAlfadocsButton';\n"],"names":["FILLED_INTENTS","SignInWithAlfadocsButton","forwardRef","intent","size","loading","disabled","label","onLoadingCancelled","type","props","ref","t","useTranslation","resolvedLabel","logoTone","resolvedSize","loadingRef","useRef","onCancelRef","useEffect","onPageShow","event","jsx","Button","Spinner","Logo"],"mappings":";;;;;;AA4BA,MAAMA,wBAAqB,IAAmB;AAAA,EAC5C;AAAA,EACA;AAAA,EACA;AACF,CAAC,GAwCYC,IAA2BC;AAAA,EAItC,CACE;AAAA,IACE,QAAAC,IAAS;AAAA,IACT,MAAAC;AAAA,IACA,SAAAC,IAAU;AAAA,IACV,UAAAC;AAAA,IACA,OAAAC;AAAA,IACA,oBAAAC;AAAA,IACA,MAAAC,IAAO;AAAA,IACP,GAAGC;AAAA,EAAA,GAELC,MACG;AACH,UAAM,EAAE,GAAAC,EAAA,IAAMC,EAAA,GACRC,IACJP,KAASK,EAAE,6BAA6B,wBAAwB,GAC5DG,IAAWf,EAAe,IAAIG,CAAM,IAAI,YAAY,QACpDa,IAAeZ,KAAQ,MAKvBa,IAAaC,EAAOb,CAAO,GAC3Bc,IAAcD,EAAOV,CAAkB;AAC7C,WAAAS,EAAW,UAAUZ,GACrBc,EAAY,UAAUX,GAEtBY,EAAU,MAAM;AACd,YAAMC,IAAa,CAACC,MAA+B;AAMjD,QAAIA,EAAM,aAAaL,EAAW,WAAWE,EAAY,WACvDA,EAAY,QAAA;AAAA,MAEhB;AACA,oBAAO,iBAAiB,YAAYE,CAAU,GACvC,MAAM,OAAO,oBAAoB,YAAYA,CAAU;AAAA,IAChE,GAAG,CAAA,CAAE,GAOH,gBAAAE;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,KAAAb;AAAA,QACA,MAAAF;AAAA,QACA,QAAAN;AAAA,QACA,MAAAC;AAAA,QACA,UAAUE,KAAYD;AAAA,QACtB,aAAWA,KAAW;AAAA,QACtB,kBAAe;AAAA,QACf,WACEA,IACE,gBAAAkB,EAACE,KAAQ,MAAMT,GAAc,SAAQ,QAAA,CAAQ,IAE7C,gBAAAO,EAACG,GAAA,EAAK,SAAQ,QAAO,MAAK,MAAK,MAAMX,GAAU,YAAU,IAAC;AAAA,QAG7D,GAAGL;AAAA,QAEH,UAAAI;AAAA,MAAA;AAAA,IAAA;AAAA,EAGP;AACF;AAEAb,EAAyB,cAAc;"}
@@ -48,7 +48,9 @@ const Pe = {
48
48
  "ds:signature-capture-alfadocs ds:flex ds:flex-col",
49
49
  "ds:gap-[var(--spacing-sm)]",
50
50
  "ds:bg-[var(--background)] ds:text-[var(--foreground)]",
51
- "ds:rounded-[var(--radius-md)] ds:border ds:border-[color:var(--border)]",
51
+ "ds:rounded-[var(--radius-md)] ds:border ds:border-[color:var(--card-border)]",
52
+ "ds:shadow-[var(--shadow-card)]",
53
+ "ds:[.theme-accessible_&]:border-2",
52
54
  "ds:p-[var(--spacing-sm)]",
53
55
  "ds:aria-disabled:opacity-[var(--opacity-50)] ds:aria-disabled:cursor-not-allowed"
54
56
  ].join(" ")
@@ -138,7 +140,8 @@ const Pe = {
138
140
  "ds:inline-size-[var(--signature-width)]",
139
141
  "ds:block-size-[var(--signature-height)]",
140
142
  "ds:rounded-[var(--radius-sm)]",
141
- "ds:border ds:border-[color:var(--border)]",
143
+ "ds:border ds:border-[color:var(--card-border)]",
144
+ "ds:[.theme-accessible_&]:border-2",
142
145
  "ds:bg-[var(--background)] ds:text-[var(--foreground)]",
143
146
  "ds:font-[family-name:var(--font-sans)]",
144
147
  "ds:italic",
@@ -187,13 +190,13 @@ async function Ie(t) {
187
190
  return "";
188
191
  }
189
192
  function He(t, n, s, i, a) {
190
- const m = Math.max(
193
+ const v = Math.max(
191
194
  1,
192
195
  typeof window < "u" ? window.devicePixelRatio : 1
193
196
  ), z = document.createElement("canvas");
194
- z.width = Math.floor(n * m), z.height = Math.floor(s * m);
197
+ z.width = Math.floor(n * v), z.height = Math.floor(s * v);
195
198
  const l = z.getContext("2d");
196
- return l && (l.setTransform(m, 0, 0, m, 0, 0), l.fillStyle = a, l.fillRect(0, 0, n, s), l.fillStyle = i, l.font = "32px italic sans-serif", l.textAlign = "center", l.textBaseline = "middle", l.fillText(t, n / 2, s / 2, n - 16)), z;
199
+ return l && (l.setTransform(v, 0, 0, v, 0, 0), l.fillStyle = a, l.fillRect(0, 0, n, s), l.fillStyle = i, l.font = "32px italic sans-serif", l.textAlign = "center", l.textBaseline = "middle", l.fillText(t, n / 2, s / 2, n - 16)), z;
197
200
  }
198
201
  const Ue = ze(
199
202
  ({
@@ -202,7 +205,7 @@ const Ue = ze(
202
205
  onClear: s,
203
206
  onStart: i,
204
207
  width: a = 400,
205
- height: m = 200,
208
+ height: v = 200,
206
209
  penColor: z,
207
210
  backgroundColor: l,
208
211
  allowTypedFallback: ce = !0,
@@ -213,13 +216,13 @@ const Ue = ze(
213
216
  const { t: o } = Me(), G = Se(), Z = `${ae(
214
217
  () => `sig-${G.replace(/[^a-zA-Z0-9-_]/g, "")}`,
215
218
  [G]
216
- )}-live`, F = C(null), J = C(null), V = C(null), K = C(null), y = C(null), [d, ge] = N("draw"), [S, L] = N(""), [pe, I] = N(!1), ve = C("empty"), [me, be] = N(""), [b, he] = N(""), [w, ye] = N(""), j = C(i), E = C(s), B = C(n);
219
+ )}-live`, F = C(null), J = C(null), V = C(null), K = C(null), y = C(null), [d, ge] = N("draw"), [S, L] = N(""), [pe, I] = N(!1), me = C("empty"), [ve, be] = N(""), [b, he] = N(""), [w, ye] = N(""), j = C(i), E = C(s), B = C(n);
217
220
  P(() => {
218
221
  j.current = i, E.current = s, B.current = n;
219
222
  }, [i, s, n]);
220
223
  const g = T(
221
224
  (e) => {
222
- ve.current = e, be(o(`signature.state.${e}`));
225
+ me.current = e, be(o(`signature.state.${e}`));
223
226
  },
224
227
  [o]
225
228
  );
@@ -272,10 +275,10 @@ const Ue = ze(
272
275
  ), p = Math.max(1, Math.floor(r.width * c)), x = Math.max(1, Math.floor(r.height * c)), A = Math.min(p, Q), k = Math.min(x, Q);
273
276
  if (e.width === A && e.height === k)
274
277
  return;
275
- const v = y.current, M = v ? v.toData() : null;
278
+ const m = y.current, M = m ? m.toData() : null;
276
279
  e.width = A, e.height = k;
277
280
  const D = e.getContext("2d");
278
- D && D.scale(c, c), v && (w && (v.backgroundColor = w), b && (v.penColor = b), v.clear(), M && M.length > 0 && v.fromData(M));
281
+ D && D.scale(c, c), m && (w && (m.backgroundColor = w), b && (m.penColor = b), m.clear(), M && M.length > 0 && m.fromData(M));
279
282
  },
280
283
  [w, b]
281
284
  );
@@ -304,18 +307,18 @@ const Ue = ze(
304
307
  if (d === "typed") return S.trim().length === 0;
305
308
  const e = y.current;
306
309
  return e ? e.isEmpty() : !0;
307
- }, [d, S]), O = T(async () => {
310
+ }, [d, S]), _ = T(async () => {
308
311
  var ne;
309
312
  const e = de(
310
313
  typeof a == "number" ? `${a}` : String(a)
311
314
  ), r = de(
312
- typeof m == "number" ? `${m}` : String(m)
315
+ typeof v == "number" ? `${v}` : String(v)
313
316
  ), c = d === "draw" ? V.current ?? J.current ?? F.current : K.current ?? F.current, p = c == null ? void 0 : c.getBoundingClientRect(), x = e ?? (p ? p.width : 400), A = r ?? (p ? p.height : 200);
314
- let k = "", v = "", M;
317
+ let k = "", m = "", M;
315
318
  if (d === "draw") {
316
319
  const u = y.current;
317
320
  if (!u || u.isEmpty()) return null;
318
- k = u.toDataURL("image/png"), v = u.toSVG(), M = u.toData();
321
+ k = u.toDataURL("image/png"), m = u.toSVG(), M = u.toData();
319
322
  } else {
320
323
  const u = S.trim();
321
324
  if (u.length === 0) return null;
@@ -327,7 +330,7 @@ const Ue = ze(
327
330
  w || "transparent"
328
331
  ).toDataURL("image/png");
329
332
  const W = u.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;").replace(/'/g, "&#39;");
330
- v = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 ${x} ${A}" width="${x}" height="${A}"><text x="50%" y="50%" dominant-baseline="middle" text-anchor="middle" font-family="sans-serif" font-style="italic" font-size="32" fill="${b || "currentColor"}" letter-spacing="3">${W}</text></svg>`;
333
+ m = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 ${x} ${A}" width="${x}" height="${A}"><text x="50%" y="50%" dominant-baseline="middle" text-anchor="middle" font-family="sans-serif" font-style="italic" font-size="32" fill="${b || "currentColor"}" letter-spacing="3">${W}</text></svg>`;
331
334
  }
332
335
  const D = x * 25.4 / 96, ke = A * 25.4 / 96, Ce = (/* @__PURE__ */ new Date()).toISOString();
333
336
  let te = "";
@@ -337,7 +340,7 @@ const Ue = ze(
337
340
  }
338
341
  const re = {
339
342
  png: k,
340
- svg: v,
343
+ svg: m,
341
344
  widthMm: D,
342
345
  heightMm: ke,
343
346
  capturedAt: Ce,
@@ -345,23 +348,23 @@ const Ue = ze(
345
348
  strokes: M
346
349
  };
347
350
  return g("captured"), (ne = B.current) == null || ne.call(B, re), re;
348
- }, [d, S, a, m, b, w, g]), _ = ae(
351
+ }, [d, S, a, v, b, w, g]), O = ae(
349
352
  () => ({
350
353
  clear: H,
351
354
  undo: U,
352
355
  isEmpty: Y,
353
- confirm: O
356
+ confirm: _
354
357
  }),
355
- [H, U, Y, O]
358
+ [H, U, Y, _]
356
359
  );
357
- Re(fe, () => _, [_]), Ne(Pe, _, t);
360
+ Re(fe, () => O, [O]), Ne(Pe, O, t);
358
361
  const we = d === "typed" ? S.trim().length > 0 : pe, ee = f || !we, xe = {
359
362
  "--signature-width": oe(
360
363
  a,
361
364
  "var(--signature-default-width)"
362
365
  ),
363
366
  "--signature-height": oe(
364
- m,
367
+ v,
365
368
  "var(--signature-default-height)"
366
369
  )
367
370
  };
@@ -421,7 +424,7 @@ const Ue = ze(
421
424
  "aria-atomic": "true",
422
425
  className: "ds:sr-only",
423
426
  "data-testid": "signature-live",
424
- children: me
427
+ children: ve
425
428
  }
426
429
  ),
427
430
  /* @__PURE__ */ X(
@@ -473,7 +476,7 @@ const Ue = ze(
473
476
  {
474
477
  type: "button",
475
478
  onClick: () => {
476
- ee || O();
479
+ ee || _();
477
480
  },
478
481
  "aria-disabled": ee || void 0,
479
482
  "aria-describedby": Z,
@@ -495,4 +498,4 @@ export {
495
498
  Ue as S,
496
499
  Pe as s
497
500
  };
498
- //# sourceMappingURL=signature-capture-C-fF71xI.js.map
501
+ //# sourceMappingURL=signature-capture-BRzCklg4.js.map