@wealthx/shadcn 1.4.1 → 1.5.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 (430) hide show
  1. package/.turbo/turbo-build.log +360 -180
  2. package/CHANGELOG.md +6 -0
  3. package/dist/chunk-2A53WPEC.mjs +182 -0
  4. package/dist/{chunk-SIVYAI3M.mjs → chunk-2LLFNGJZ.mjs} +15 -15
  5. package/dist/chunk-2QNOPXMQ.mjs +360 -0
  6. package/dist/{chunk-K5QV4TT6.mjs → chunk-2WCIORP7.mjs} +29 -4
  7. package/dist/{chunk-5NF6T2RS.mjs → chunk-3AREQTZU.mjs} +8 -8
  8. package/dist/{chunk-2EM2FRU6.mjs → chunk-3WGFIFP6.mjs} +5 -5
  9. package/dist/{chunk-K4KOD3KR.mjs → chunk-42NEC57Y.mjs} +44 -25
  10. package/dist/{chunk-FL6DZFJK.mjs → chunk-46Q4335I.mjs} +121 -39
  11. package/dist/chunk-4DO3WM7V.mjs +48 -0
  12. package/dist/chunk-5FHBC6DY.mjs +68 -0
  13. package/dist/chunk-5SAYZ4CI.mjs +40 -0
  14. package/dist/chunk-5WMFKQZ6.mjs +180 -0
  15. package/dist/chunk-623YVI5O.mjs +43 -0
  16. package/dist/{chunk-SFH2NJEJ.mjs → chunk-6OSULDEO.mjs} +3 -3
  17. package/dist/{chunk-UALR6JGV.mjs → chunk-6SR4K5T5.mjs} +1 -1
  18. package/dist/{chunk-D2NSIIXG.mjs → chunk-7KT5HPYM.mjs} +11 -11
  19. package/dist/chunk-A6ER36CW.mjs +456 -0
  20. package/dist/{chunk-QX7IFQSF.mjs → chunk-AHKHVBWR.mjs} +4 -4
  21. package/dist/chunk-AHSCWXYJ.mjs +113 -0
  22. package/dist/{chunk-7GWRPXHD.mjs → chunk-AL6GOL2Y.mjs} +1 -1
  23. package/dist/{chunk-OIKBW2QD.mjs → chunk-AUEUTZIC.mjs} +13 -13
  24. package/dist/{chunk-FYPSTTEJ.mjs → chunk-B7DD3ODQ.mjs} +1 -1
  25. package/dist/{chunk-TLAWKTSA.mjs → chunk-BD3DWDT4.mjs} +3 -3
  26. package/dist/{chunk-S2FKV4M5.mjs → chunk-BDESHD25.mjs} +4 -4
  27. package/dist/{chunk-OKTJFDPN.mjs → chunk-BFB3UH7V.mjs} +2 -2
  28. package/dist/{chunk-DGNHGNYH.mjs → chunk-C6SWS7OW.mjs} +1 -1
  29. package/dist/chunk-CDVG7SFT.mjs +271 -0
  30. package/dist/chunk-CUSHAIUL.mjs +109 -0
  31. package/dist/{chunk-QXKGOMUX.mjs → chunk-CW32WTZU.mjs} +4 -4
  32. package/dist/{chunk-SET2ANTY.mjs → chunk-D447W45Z.mjs} +3 -3
  33. package/dist/{chunk-RCAOCHWA.mjs → chunk-DFL5CV75.mjs} +18 -18
  34. package/dist/chunk-DYSVJ473.mjs +162 -0
  35. package/dist/chunk-E3PQDBYI.mjs +288 -0
  36. package/dist/chunk-EMYBNPIA.mjs +83 -0
  37. package/dist/chunk-EUYPMDQG.mjs +348 -0
  38. package/dist/{chunk-XYPW2XA5.mjs → chunk-EW72FINW.mjs} +11 -11
  39. package/dist/chunk-F24U4QQQ.mjs +234 -0
  40. package/dist/{chunk-VB5M6OZQ.mjs → chunk-F4O2YPXJ.mjs} +1 -1
  41. package/dist/chunk-FFXTQTB4.mjs +84 -0
  42. package/dist/{chunk-ZOWL2L5J.mjs → chunk-FYUSF5KO.mjs} +5 -1
  43. package/dist/{chunk-FTPBQVQ6.mjs → chunk-GNER6MCO.mjs} +1 -1
  44. package/dist/{chunk-2D3HQPFN.mjs → chunk-HF4FUBCY.mjs} +5 -5
  45. package/dist/{chunk-RSUIPKGX.mjs → chunk-HNDTLT5X.mjs} +1 -1
  46. package/dist/{chunk-N6Q5IPKT.mjs → chunk-HO6S3ECM.mjs} +46 -18
  47. package/dist/{chunk-L4NSRQ3T.mjs → chunk-HROG643K.mjs} +1 -1
  48. package/dist/chunk-I2EKKSEF.mjs +148 -0
  49. package/dist/{chunk-QTRSCVQ3.mjs → chunk-I3UDLWQ7.mjs} +1 -1
  50. package/dist/{chunk-AE7MASLF.mjs → chunk-IQGKOT7A.mjs} +9 -6
  51. package/dist/chunk-IXR4BQSQ.mjs +290 -0
  52. package/dist/{chunk-4MM7LHM5.mjs → chunk-J5NW5NCT.mjs} +1 -1
  53. package/dist/{chunk-OLKMCXAR.mjs → chunk-JTG5R5YV.mjs} +24 -24
  54. package/dist/chunk-JUBUN65Q.mjs +106 -0
  55. package/dist/chunk-K7TWMLLW.mjs +520 -0
  56. package/dist/{chunk-BOW7U26Y.mjs → chunk-K7WSRWOU.mjs} +4 -4
  57. package/dist/{chunk-NTYQWVLI.mjs → chunk-KAD26MCC.mjs} +1 -1
  58. package/dist/{chunk-KCWNDYPZ.mjs → chunk-KB7MZMED.mjs} +4 -4
  59. package/dist/chunk-KCKYGQVQ.mjs +61 -0
  60. package/dist/{chunk-VY5NEUP7.mjs → chunk-KLJLDNCA.mjs} +1 -1
  61. package/dist/chunk-LLAGF6BA.mjs +49 -0
  62. package/dist/{chunk-G27TSQLQ.mjs → chunk-M4LTX3MH.mjs} +1 -1
  63. package/dist/{chunk-YIZHS72Z.mjs → chunk-MHHA7QGO.mjs} +94 -54
  64. package/dist/{chunk-P2N2PEFY.mjs → chunk-NCUH54IZ.mjs} +4 -4
  65. package/dist/{chunk-PNRUH7JY.mjs → chunk-OECGKCVF.mjs} +5 -5
  66. package/dist/{chunk-YE67AALL.mjs → chunk-OL65UQHQ.mjs} +10 -10
  67. package/dist/{chunk-LQULK2E3.mjs → chunk-OYBIUEGE.mjs} +1 -1
  68. package/dist/{chunk-LR6LHDP3.mjs → chunk-PGR53HMH.mjs} +7 -7
  69. package/dist/chunk-PUJ42INK.mjs +141 -0
  70. package/dist/{chunk-M4VYX2PV.mjs → chunk-PV3Y7QGK.mjs} +2 -2
  71. package/dist/{chunk-UJZ4UHWI.mjs → chunk-PV7PNA6K.mjs} +4 -4
  72. package/dist/{chunk-6HIOM2HL.mjs → chunk-Q35PNFJ7.mjs} +1 -1
  73. package/dist/{chunk-JZY6TNIS.mjs → chunk-Q5SGEIJV.mjs} +27 -27
  74. package/dist/{chunk-ZFCDYW6N.mjs → chunk-QAX6HCUH.mjs} +1 -1
  75. package/dist/chunk-QHJDGB54.mjs +135 -0
  76. package/dist/chunk-QQSOZQOC.mjs +27 -0
  77. package/dist/chunk-RUX3OLVZ.mjs +59 -0
  78. package/dist/{chunk-QOJ2DQD6.mjs → chunk-S4CTM3UE.mjs} +5 -0
  79. package/dist/{chunk-ZEDMKQK2.mjs → chunk-TAX3KL66.mjs} +1 -1
  80. package/dist/chunk-TC43SMIN.mjs +133 -0
  81. package/dist/chunk-TGVXRD53.mjs +174 -0
  82. package/dist/{chunk-K5VHK7CM.mjs → chunk-TLYSVRSK.mjs} +12 -12
  83. package/dist/{chunk-YCWLFG27.mjs → chunk-TOIVHWNC.mjs} +1 -1
  84. package/dist/chunk-TXUBGKB7.mjs +160 -0
  85. package/dist/chunk-UEREFDAE.mjs +75 -0
  86. package/dist/chunk-UTCQN6XU.mjs +123 -0
  87. package/dist/{chunk-37AE3OM5.mjs → chunk-V4CUTCHS.mjs} +4 -4
  88. package/dist/{chunk-THVO2N47.mjs → chunk-VFH632TB.mjs} +9 -9
  89. package/dist/{chunk-3ERBUVHC.mjs → chunk-VJ3GC7W3.mjs} +95 -49
  90. package/dist/{chunk-V6XGXYCJ.mjs → chunk-VLELWBEW.mjs} +4 -4
  91. package/dist/{chunk-FEZKMUCF.mjs → chunk-WDTXHLYM.mjs} +1 -1
  92. package/dist/chunk-WUA546RX.mjs +129 -0
  93. package/dist/chunk-XHGISOX5.mjs +257 -0
  94. package/dist/chunk-XIY5DJXI.mjs +168 -0
  95. package/dist/{chunk-TOWTPLRC.mjs → chunk-XN37434W.mjs} +8 -8
  96. package/dist/{chunk-KLTACJ2G.mjs → chunk-XTWAJWCQ.mjs} +1 -1
  97. package/dist/chunk-Y24TXIFJ.mjs +518 -0
  98. package/dist/{chunk-DMXYRCHM.mjs → chunk-Y6UM3VTN.mjs} +4 -4
  99. package/dist/components/ui/about-you-form.js +1120 -0
  100. package/dist/components/ui/about-you-form.mjs +323 -0
  101. package/dist/components/ui/account-list-carousel.js +304 -0
  102. package/dist/components/ui/account-list-carousel.mjs +11 -0
  103. package/dist/components/ui/add-column-modal.js +1 -1
  104. package/dist/components/ui/add-column-modal.mjs +6 -6
  105. package/dist/components/ui/add-lead-modal.js +2 -2
  106. package/dist/components/ui/add-lead-modal.mjs +6 -6
  107. package/dist/components/ui/advisor-card.mjs +2 -2
  108. package/dist/components/ui/agent-evaluation-toast.js +299 -0
  109. package/dist/components/ui/agent-evaluation-toast.mjs +12 -0
  110. package/dist/components/ui/ai-assistant-drawer.mjs +5 -5
  111. package/dist/components/ui/ai-builder.js +3 -3
  112. package/dist/components/ui/ai-builder.mjs +5 -5
  113. package/dist/components/ui/ai-conversations.js +2 -2
  114. package/dist/components/ui/ai-conversations.mjs +11 -11
  115. package/dist/components/ui/alert-dialog.mjs +3 -3
  116. package/dist/components/ui/applicant-document-checklist.js +346 -0
  117. package/dist/components/ui/applicant-document-checklist.mjs +10 -0
  118. package/dist/components/ui/applicant-expenses-section.js +455 -0
  119. package/dist/components/ui/applicant-expenses-section.mjs +220 -0
  120. package/dist/components/ui/applicant-navigation-bar.js +309 -0
  121. package/dist/components/ui/applicant-navigation-bar.mjs +87 -0
  122. package/dist/components/ui/applicant-switcher.js +268 -0
  123. package/dist/components/ui/applicant-switcher.mjs +46 -0
  124. package/dist/components/ui/application-mobile-layout.js +88 -0
  125. package/dist/components/ui/application-mobile-layout.mjs +8 -0
  126. package/dist/components/ui/appointment-action-dialogs.js +1 -1
  127. package/dist/components/ui/appointment-action-dialogs.mjs +10 -10
  128. package/dist/components/ui/appointment-availability-settings.js +78 -31
  129. package/dist/components/ui/appointment-availability-settings.mjs +12 -10
  130. package/dist/components/ui/appointment-book-dialog.js +137 -58
  131. package/dist/components/ui/appointment-book-dialog.mjs +14 -14
  132. package/dist/components/ui/appointment-calendar-view.js +1 -1
  133. package/dist/components/ui/appointment-calendar-view.mjs +4 -4
  134. package/dist/components/ui/appointment-detail-sheet.js +38 -11
  135. package/dist/components/ui/appointment-detail-sheet.mjs +13 -13
  136. package/dist/components/ui/appointment-gmail-connect.mjs +2 -2
  137. package/dist/components/ui/appointment-time-slot-picker.mjs +2 -2
  138. package/dist/components/ui/appointment-upcoming-card.js +1 -1
  139. package/dist/components/ui/appointment-upcoming-card.mjs +10 -10
  140. package/dist/components/ui/asset-accordion.js +506 -0
  141. package/dist/components/ui/asset-accordion.mjs +202 -0
  142. package/dist/components/ui/assets-liabilities-side-card.js +328 -0
  143. package/dist/components/ui/assets-liabilities-side-card.mjs +127 -0
  144. package/dist/components/ui/auth-page-layout.js +3 -3
  145. package/dist/components/ui/auth-page-layout.mjs +1 -1
  146. package/dist/components/ui/backoffice-alert-history-chart.mjs +4 -4
  147. package/dist/components/ui/backoffice-alert-matching-chart.js +786 -0
  148. package/dist/components/ui/backoffice-alert-matching-chart.mjs +19 -0
  149. package/dist/components/ui/backoffice-alerts-chart.mjs +4 -4
  150. package/dist/components/ui/backoffice-connections-chart.mjs +4 -4
  151. package/dist/components/ui/backoffice-contact-history-chart.mjs +4 -4
  152. package/dist/components/ui/backoffice-contact-matching-chart.js +803 -0
  153. package/dist/components/ui/backoffice-contact-matching-chart.mjs +19 -0
  154. package/dist/components/ui/backoffice-signup-steps.js +1673 -0
  155. package/dist/components/ui/backoffice-signup-steps.mjs +36 -0
  156. package/dist/components/ui/bank-statement-document-table.js +467 -0
  157. package/dist/components/ui/bank-statement-document-table.mjs +12 -0
  158. package/dist/components/ui/bank-statement-generate-dialog.js +1517 -0
  159. package/dist/components/ui/bank-statement-generate-dialog.mjs +27 -0
  160. package/dist/components/ui/bank-statement-pdf-viewer.js +525 -0
  161. package/dist/components/ui/bank-statement-pdf-viewer.mjs +14 -0
  162. package/dist/components/ui/banking-accounts-connect.js +336 -0
  163. package/dist/components/ui/banking-accounts-connect.mjs +114 -0
  164. package/dist/components/ui/borrowing-capacity-atoms.js +382 -0
  165. package/dist/components/ui/borrowing-capacity-atoms.mjs +17 -0
  166. package/dist/components/ui/borrowing-capacity-card.js +835 -0
  167. package/dist/components/ui/borrowing-capacity-card.mjs +89 -0
  168. package/dist/components/ui/borrowing-capacity-line-chart.mjs +4 -4
  169. package/dist/components/ui/broker-info-panel.js +281 -0
  170. package/dist/components/ui/broker-info-panel.mjs +59 -0
  171. package/dist/components/ui/calculator-input-item.js +101 -0
  172. package/dist/components/ui/calculator-input-item.mjs +8 -0
  173. package/dist/components/ui/calculator-section.js +743 -0
  174. package/dist/components/ui/calculator-section.mjs +220 -0
  175. package/dist/components/ui/calendar.mjs +2 -2
  176. package/dist/components/ui/cash-balance-line-chart.mjs +5 -5
  177. package/dist/components/ui/cashflow-bar-chart.mjs +4 -4
  178. package/dist/components/ui/category-edit-dialog.js +737 -0
  179. package/dist/components/ui/category-edit-dialog.mjs +16 -0
  180. package/dist/components/ui/chat-widget.mjs +3 -3
  181. package/dist/components/ui/color-picker.mjs +4 -4
  182. package/dist/components/ui/connect-bank-step.js +511 -0
  183. package/dist/components/ui/connect-bank-step.mjs +287 -0
  184. package/dist/components/ui/contact-alert-dialog.js +1405 -0
  185. package/dist/components/ui/contact-alert-dialog.mjs +27 -0
  186. package/dist/components/ui/create-contact-modal.js +1028 -0
  187. package/dist/components/ui/create-contact-modal.mjs +21 -0
  188. package/dist/components/ui/csv-import-modal.js +583 -0
  189. package/dist/components/ui/csv-import-modal.mjs +14 -0
  190. package/dist/components/ui/currency-input.js +439 -0
  191. package/dist/components/ui/currency-input.mjs +13 -0
  192. package/dist/components/ui/dashboard-expense-categories.js +355 -0
  193. package/dist/components/ui/dashboard-expense-categories.mjs +186 -0
  194. package/dist/components/ui/dashboard-transactions-table.js +1083 -0
  195. package/dist/components/ui/dashboard-transactions-table.mjs +177 -0
  196. package/dist/components/ui/data-table.mjs +6 -6
  197. package/dist/components/ui/date-picker.mjs +6 -6
  198. package/dist/components/ui/debt-accordion.js +523 -0
  199. package/dist/components/ui/debt-accordion.mjs +219 -0
  200. package/dist/components/ui/delete-contact-component.js +479 -0
  201. package/dist/components/ui/delete-contact-component.mjs +14 -0
  202. package/dist/components/ui/dialog.js +1 -1
  203. package/dist/components/ui/dialog.mjs +3 -3
  204. package/dist/components/ui/document-checklist-template.mjs +4 -4
  205. package/dist/components/ui/drawer.mjs +3 -3
  206. package/dist/components/ui/dropdown-menu.mjs +3 -3
  207. package/dist/components/ui/dynamic-tabs.js +274 -0
  208. package/dist/components/ui/dynamic-tabs.mjs +116 -0
  209. package/dist/components/ui/editable-money-item.js +306 -0
  210. package/dist/components/ui/editable-money-item.mjs +12 -0
  211. package/dist/components/ui/expense-bar-chart.mjs +4 -4
  212. package/dist/components/ui/expense-detail-item.js +506 -0
  213. package/dist/components/ui/expense-detail-item.mjs +15 -0
  214. package/dist/components/ui/expense-work-details.js +1259 -0
  215. package/dist/components/ui/expense-work-details.mjs +175 -0
  216. package/dist/components/ui/field.mjs +2 -2
  217. package/dist/components/ui/file-preview-dialog.js +704 -0
  218. package/dist/components/ui/file-preview-dialog.mjs +17 -0
  219. package/dist/components/ui/financial-cards.mjs +2 -2
  220. package/dist/components/ui/financial-drawers.js +1 -1
  221. package/dist/components/ui/financial-drawers.mjs +5 -5
  222. package/dist/components/ui/financial-sections.mjs +4 -4
  223. package/dist/components/ui/form-primitives.mjs +2 -2
  224. package/dist/components/ui/frontend-signup-steps.js +1239 -0
  225. package/dist/components/ui/frontend-signup-steps.mjs +38 -0
  226. package/dist/components/ui/income-bar-chart.mjs +4 -4
  227. package/dist/components/ui/income-sources-card.js +269 -0
  228. package/dist/components/ui/income-sources-card.mjs +100 -0
  229. package/dist/components/ui/income-summary-component.js +361 -0
  230. package/dist/components/ui/income-summary-component.mjs +84 -0
  231. package/dist/components/ui/income-work-details.js +1663 -0
  232. package/dist/components/ui/income-work-details.mjs +28 -0
  233. package/dist/components/ui/incoming-outgoings-card.js +218 -0
  234. package/dist/components/ui/incoming-outgoings-card.mjs +82 -0
  235. package/dist/components/ui/interest-rate-input.js +442 -0
  236. package/dist/components/ui/interest-rate-input.mjs +90 -0
  237. package/dist/components/ui/interest-rate-section.js +337 -0
  238. package/dist/components/ui/interest-rate-section.mjs +84 -0
  239. package/dist/components/ui/interest-rate-used.js +202 -0
  240. package/dist/components/ui/interest-rate-used.mjs +62 -0
  241. package/dist/components/ui/kanban-column.js +338 -160
  242. package/dist/components/ui/kanban-column.mjs +13 -11
  243. package/dist/components/ui/loan-applicant-information.js +336 -0
  244. package/dist/components/ui/loan-applicant-information.mjs +59 -0
  245. package/dist/components/ui/loan-applicant-invite.js +319 -0
  246. package/dist/components/ui/loan-applicant-invite.mjs +68 -0
  247. package/dist/components/ui/loan-application-badge.js +236 -0
  248. package/dist/components/ui/loan-application-badge.mjs +10 -0
  249. package/dist/components/ui/loan-application-cards.js +356 -0
  250. package/dist/components/ui/loan-application-cards.mjs +110 -0
  251. package/dist/components/ui/loan-entry-shell.js +104 -0
  252. package/dist/components/ui/loan-entry-shell.mjs +8 -0
  253. package/dist/components/ui/loan-financials.js +410 -0
  254. package/dist/components/ui/loan-financials.mjs +76 -0
  255. package/dist/components/ui/loan-option-card.js +102 -0
  256. package/dist/components/ui/loan-option-card.mjs +41 -0
  257. package/dist/components/ui/loan-option-group.js +288 -0
  258. package/dist/components/ui/loan-option-group.mjs +10 -0
  259. package/dist/components/ui/loan-steps.js +1121 -0
  260. package/dist/components/ui/loan-steps.mjs +509 -0
  261. package/dist/components/ui/loan-wizard-shell.js +452 -0
  262. package/dist/components/ui/loan-wizard-shell.mjs +11 -0
  263. package/dist/components/ui/money-input-with-slider.js +210 -0
  264. package/dist/components/ui/money-input-with-slider.mjs +10 -0
  265. package/dist/components/ui/money-item-with-color-indicator.js +314 -0
  266. package/dist/components/ui/money-item-with-color-indicator.mjs +20 -0
  267. package/dist/components/ui/opportunity-card.js +235 -97
  268. package/dist/components/ui/opportunity-card.mjs +11 -9
  269. package/dist/components/ui/opportunity-edit-modals.js +1 -1
  270. package/dist/components/ui/opportunity-edit-modals.mjs +15 -15
  271. package/dist/components/ui/opportunity-summary-tab.js +1 -1
  272. package/dist/components/ui/opportunity-summary-tab.mjs +19 -19
  273. package/dist/components/ui/pagination.mjs +4 -4
  274. package/dist/components/ui/password-strength-tooltip.mjs +4 -4
  275. package/dist/components/ui/pipeline-board.js +358 -176
  276. package/dist/components/ui/pipeline-board.mjs +16 -14
  277. package/dist/components/ui/pipeline-chart.mjs +3 -3
  278. package/dist/components/ui/pipeline-dialogs.js +1 -1
  279. package/dist/components/ui/pipeline-dialogs.mjs +9 -9
  280. package/dist/components/ui/pipeline-primitives.js +75 -8
  281. package/dist/components/ui/pipeline-primitives.mjs +3 -2
  282. package/dist/components/ui/popover.mjs +3 -3
  283. package/dist/components/ui/property-asset-card.js +428 -0
  284. package/dist/components/ui/property-asset-card.mjs +156 -0
  285. package/dist/components/ui/property-cashflow-doughnut-chart.mjs +4 -4
  286. package/dist/components/ui/property-debt-equity-doughnut-chart.mjs +4 -4
  287. package/dist/components/ui/property-list-carousel.js +295 -0
  288. package/dist/components/ui/property-list-carousel.mjs +11 -0
  289. package/dist/components/ui/property-mobile-estimate-line-chart.mjs +4 -4
  290. package/dist/components/ui/property-report-dialog.js +1148 -0
  291. package/dist/components/ui/property-report-dialog.mjs +25 -0
  292. package/dist/components/ui/resource-center.js +748 -0
  293. package/dist/components/ui/resource-center.mjs +24 -0
  294. package/dist/components/ui/review-alerts-dialog.js +569 -0
  295. package/dist/components/ui/review-alerts-dialog.mjs +15 -0
  296. package/dist/components/ui/savings-goal-modal.js +1148 -0
  297. package/dist/components/ui/savings-goal-modal.mjs +160 -0
  298. package/dist/components/ui/scenario-drawer.js +791 -0
  299. package/dist/components/ui/scenario-drawer.mjs +294 -0
  300. package/dist/components/ui/scenario-item.js +256 -0
  301. package/dist/components/ui/scenario-item.mjs +11 -0
  302. package/dist/components/ui/scenario-list.js +507 -0
  303. package/dist/components/ui/scenario-list.mjs +100 -0
  304. package/dist/components/ui/select.mjs +3 -3
  305. package/dist/components/ui/share-details-dialog.js +636 -0
  306. package/dist/components/ui/share-details-dialog.mjs +19 -0
  307. package/dist/components/ui/sheet.mjs +3 -3
  308. package/dist/components/ui/sidebar-nav.mjs +5 -5
  309. package/dist/components/ui/signup-form-primitives.js +770 -0
  310. package/dist/components/ui/signup-form-primitives.mjs +25 -0
  311. package/dist/components/ui/signup-shell.js +338 -0
  312. package/dist/components/ui/signup-shell.mjs +13 -0
  313. package/dist/components/ui/stage-timeline.js +103 -33
  314. package/dist/components/ui/stage-timeline.mjs +5 -4
  315. package/dist/components/ui/submission-confirmation-card.js +284 -0
  316. package/dist/components/ui/submission-confirmation-card.mjs +62 -0
  317. package/dist/components/ui/tooltip.mjs +3 -3
  318. package/dist/components/ui/top-three-product.js +374 -0
  319. package/dist/components/ui/top-three-product.mjs +129 -0
  320. package/dist/components/ui/transactions-expense-categories-doughnut-chart.mjs +4 -4
  321. package/dist/components/ui/transactions-income-expense-bar-chart.mjs +5 -5
  322. package/dist/components/ui/transactions-liabilities-breakdown-doughnut-chart.mjs +4 -4
  323. package/dist/components/ui/transactions-summary-block.js +95 -0
  324. package/dist/components/ui/transactions-summary-block.mjs +34 -0
  325. package/dist/components/ui/two-fa-setup-form.mjs +3 -3
  326. package/dist/index.js +9430 -4573
  327. package/dist/index.mjs +404 -251
  328. package/dist/lib/colors.js +6 -0
  329. package/dist/lib/colors.mjs +3 -1
  330. package/dist/lib/theme-provider.mjs +2 -2
  331. package/dist/styles.css +1 -1
  332. package/package.json +366 -2
  333. package/src/components/index.tsx +223 -0
  334. package/src/components/ui/about-you-form.tsx +397 -0
  335. package/src/components/ui/account-list-carousel.tsx +87 -0
  336. package/src/components/ui/add-lead-modal.tsx +1 -1
  337. package/src/components/ui/agent-evaluation-toast.tsx +191 -0
  338. package/src/components/ui/ai-builder.tsx +3 -5
  339. package/src/components/ui/ai-conversations.tsx +1 -1
  340. package/src/components/ui/applicant-document-checklist.tsx +175 -0
  341. package/src/components/ui/applicant-expenses-section.tsx +260 -0
  342. package/src/components/ui/applicant-navigation-bar.tsx +104 -0
  343. package/src/components/ui/applicant-switcher.tsx +54 -0
  344. package/src/components/ui/application-mobile-layout.tsx +34 -0
  345. package/src/components/ui/appointment-availability-settings.tsx +115 -23
  346. package/src/components/ui/appointment-book-dialog.tsx +406 -259
  347. package/src/components/ui/appointment-calendar-view.tsx +4 -1
  348. package/src/components/ui/appointment-detail-sheet.tsx +59 -24
  349. package/src/components/ui/appointment-time-slot-picker.tsx +5 -1
  350. package/src/components/ui/asset-accordion.tsx +241 -0
  351. package/src/components/ui/assets-liabilities-side-card.tsx +157 -0
  352. package/src/components/ui/auth-page-layout.tsx +3 -3
  353. package/src/components/ui/backoffice-alert-matching-chart.tsx +320 -0
  354. package/src/components/ui/backoffice-contact-matching-chart.tsx +341 -0
  355. package/src/components/ui/backoffice-signup-steps.tsx +615 -0
  356. package/src/components/ui/bank-statement-document-table.tsx +222 -0
  357. package/src/components/ui/bank-statement-generate-dialog.tsx +435 -0
  358. package/src/components/ui/bank-statement-pdf-viewer.tsx +241 -0
  359. package/src/components/ui/banking-accounts-connect.tsx +187 -0
  360. package/src/components/ui/borrowing-capacity-atoms.tsx +228 -0
  361. package/src/components/ui/borrowing-capacity-card.tsx +155 -0
  362. package/src/components/ui/broker-info-panel.tsx +94 -0
  363. package/src/components/ui/calculator-input-item.tsx +49 -0
  364. package/src/components/ui/calculator-section.tsx +275 -0
  365. package/src/components/ui/category-edit-dialog.tsx +300 -0
  366. package/src/components/ui/connect-bank-step.tsx +379 -0
  367. package/src/components/ui/contact-alert-dialog.tsx +710 -0
  368. package/src/components/ui/create-contact-modal.tsx +237 -0
  369. package/src/components/ui/csv-import-modal.tsx +153 -0
  370. package/src/components/ui/currency-input.tsx +104 -0
  371. package/src/components/ui/dashboard-expense-categories.tsx +262 -0
  372. package/src/components/ui/dashboard-transactions-table.tsx +241 -0
  373. package/src/components/ui/debt-accordion.tsx +254 -0
  374. package/src/components/ui/delete-contact-component.tsx +87 -0
  375. package/src/components/ui/dialog.tsx +2 -2
  376. package/src/components/ui/dynamic-tabs.tsx +149 -0
  377. package/src/components/ui/editable-money-item.tsx +176 -0
  378. package/src/components/ui/expense-detail-item.tsx +216 -0
  379. package/src/components/ui/expense-work-details.tsx +229 -0
  380. package/src/components/ui/file-preview-dialog.tsx +292 -0
  381. package/src/components/ui/financial-drawers.tsx +1 -1
  382. package/src/components/ui/frontend-signup-steps.tsx +548 -0
  383. package/src/components/ui/income-sources-card.tsx +143 -0
  384. package/src/components/ui/income-summary-component.tsx +120 -0
  385. package/src/components/ui/income-work-details.tsx +429 -0
  386. package/src/components/ui/incoming-outgoings-card.tsx +111 -0
  387. package/src/components/ui/interest-rate-input.tsx +111 -0
  388. package/src/components/ui/interest-rate-section.tsx +158 -0
  389. package/src/components/ui/interest-rate-used.tsx +82 -0
  390. package/src/components/ui/kanban-column.tsx +53 -2
  391. package/src/components/ui/loan-applicant-information.tsx +64 -0
  392. package/src/components/ui/loan-applicant-invite.tsx +67 -0
  393. package/src/components/ui/loan-application-badge.tsx +70 -0
  394. package/src/components/ui/loan-application-cards.tsx +152 -0
  395. package/src/components/ui/loan-entry-shell.tsx +86 -0
  396. package/src/components/ui/loan-financials.tsx +77 -0
  397. package/src/components/ui/loan-option-card.tsx +62 -0
  398. package/src/components/ui/loan-option-group.tsx +106 -0
  399. package/src/components/ui/loan-steps.tsx +630 -0
  400. package/src/components/ui/loan-wizard-shell.tsx +235 -0
  401. package/src/components/ui/money-input-with-slider.tsx +77 -0
  402. package/src/components/ui/money-item-with-color-indicator.tsx +30 -0
  403. package/src/components/ui/opportunity-card.tsx +46 -18
  404. package/src/components/ui/pipeline-board.tsx +13 -0
  405. package/src/components/ui/pipeline-primitives.tsx +28 -0
  406. package/src/components/ui/property-asset-card.tsx +221 -0
  407. package/src/components/ui/property-list-carousel.tsx +73 -0
  408. package/src/components/ui/property-report-dialog.tsx +355 -0
  409. package/src/components/ui/resource-center.tsx +539 -0
  410. package/src/components/ui/review-alerts-dialog.tsx +163 -0
  411. package/src/components/ui/savings-goal-modal.tsx +169 -0
  412. package/src/components/ui/scenario-drawer.tsx +358 -0
  413. package/src/components/ui/scenario-item.tsx +141 -0
  414. package/src/components/ui/scenario-list.tsx +150 -0
  415. package/src/components/ui/share-details-dialog.tsx +238 -0
  416. package/src/components/ui/signup-form-primitives.tsx +212 -0
  417. package/src/components/ui/signup-shell.tsx +180 -0
  418. package/src/components/ui/stage-timeline.tsx +11 -0
  419. package/src/components/ui/submission-confirmation-card.tsx +68 -0
  420. package/src/components/ui/top-three-product.tsx +207 -0
  421. package/src/components/ui/transactions-summary-block.tsx +59 -0
  422. package/src/lib/colors.ts +12 -0
  423. package/src/lib/format-date.ts +2 -2
  424. package/src/styles/styles-css.ts +1 -1
  425. package/tsup.config.ts +77 -1
  426. package/dist/{chunk-5VOTTIXF.mjs → chunk-FRT3S72S.mjs} +3 -3
  427. package/dist/{chunk-7BTFGCFC.mjs → chunk-MUV4EGDW.mjs} +3 -3
  428. package/dist/{chunk-57ZXILTS.mjs → chunk-MXP2RX2V.mjs} +3 -3
  429. package/dist/{chunk-ZKWXDQDG.mjs → chunk-VCDGLN25.mjs} +3 -3
  430. package/dist/{chunk-FLL633WS.mjs → chunk-ZXEUBBHJ.mjs} +3 -3
@@ -0,0 +1,786 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __defProps = Object.defineProperties;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
7
+ var __getOwnPropNames = Object.getOwnPropertyNames;
8
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
9
+ var __getProtoOf = Object.getPrototypeOf;
10
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
11
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
12
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
13
+ var __spreadValues = (a, b) => {
14
+ for (var prop in b || (b = {}))
15
+ if (__hasOwnProp.call(b, prop))
16
+ __defNormalProp(a, prop, b[prop]);
17
+ if (__getOwnPropSymbols)
18
+ for (var prop of __getOwnPropSymbols(b)) {
19
+ if (__propIsEnum.call(b, prop))
20
+ __defNormalProp(a, prop, b[prop]);
21
+ }
22
+ return a;
23
+ };
24
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
25
+ var __objRest = (source, exclude) => {
26
+ var target = {};
27
+ for (var prop in source)
28
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
29
+ target[prop] = source[prop];
30
+ if (source != null && __getOwnPropSymbols)
31
+ for (var prop of __getOwnPropSymbols(source)) {
32
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
33
+ target[prop] = source[prop];
34
+ }
35
+ return target;
36
+ };
37
+ var __export = (target, all) => {
38
+ for (var name in all)
39
+ __defProp(target, name, { get: all[name], enumerable: true });
40
+ };
41
+ var __copyProps = (to, from, except, desc) => {
42
+ if (from && typeof from === "object" || typeof from === "function") {
43
+ for (let key of __getOwnPropNames(from))
44
+ if (!__hasOwnProp.call(to, key) && key !== except)
45
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
46
+ }
47
+ return to;
48
+ };
49
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
50
+ // If the importer is in node compatibility mode or this is not an ESM
51
+ // file that has been converted to a CommonJS file using a Babel-
52
+ // compatible transform (i.e. "__esModule" has not been set), then set
53
+ // "default" to the CommonJS "module.exports" for node compatibility.
54
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
55
+ mod
56
+ ));
57
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
58
+
59
+ // src/components/ui/backoffice-alert-matching-chart.tsx
60
+ var backoffice_alert_matching_chart_exports = {};
61
+ __export(backoffice_alert_matching_chart_exports, {
62
+ BackofficeAlertMatchingChart: () => BackofficeAlertMatchingChart
63
+ });
64
+ module.exports = __toCommonJS(backoffice_alert_matching_chart_exports);
65
+ var import_react3 = require("react");
66
+ var import_chart = require("chart.js");
67
+ var import_react_chartjs_2 = require("react-chartjs-2");
68
+ var import_lucide_react2 = require("lucide-react");
69
+
70
+ // src/lib/theme-provider.tsx
71
+ var import_react = require("react");
72
+ var import_jsx_runtime = require("react/jsx-runtime");
73
+ var ThemeVarsContext = (0, import_react.createContext)({});
74
+ function useThemeVars() {
75
+ return (0, import_react.useContext)(ThemeVarsContext);
76
+ }
77
+
78
+ // src/lib/utils.ts
79
+ var import_clsx = require("clsx");
80
+ var import_tailwind_merge = require("tailwind-merge");
81
+ var twMerge = (0, import_tailwind_merge.extendTailwindMerge)({
82
+ extend: {
83
+ classGroups: {
84
+ "font-size": [
85
+ {
86
+ text: [
87
+ "display-large",
88
+ "display-medium",
89
+ "display-small",
90
+ "h1",
91
+ "h2",
92
+ "h3",
93
+ "h4",
94
+ "h5",
95
+ "h6",
96
+ "body-large",
97
+ "body-medium",
98
+ "body-small",
99
+ "label-large",
100
+ "label-medium",
101
+ "label-small",
102
+ "button",
103
+ "button-xs",
104
+ "caption",
105
+ "overline",
106
+ "code"
107
+ ]
108
+ }
109
+ ]
110
+ }
111
+ }
112
+ });
113
+ function cn(...inputs) {
114
+ return twMerge((0, import_clsx.clsx)(inputs));
115
+ }
116
+
117
+ // src/components/ui/card.tsx
118
+ var import_jsx_runtime2 = require("react/jsx-runtime");
119
+ function Card(_a) {
120
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
121
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
122
+ "div",
123
+ __spreadValues({
124
+ className: cn(
125
+ "flex flex-col gap-6 border bg-card py-6 text-card-foreground shadow-sm",
126
+ className
127
+ ),
128
+ "data-slot": "card"
129
+ }, props)
130
+ );
131
+ }
132
+ function CardHeader(_a) {
133
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
134
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
135
+ "div",
136
+ __spreadValues({
137
+ className: cn(
138
+ "@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-center gap-2 px-6 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6",
139
+ className
140
+ ),
141
+ "data-slot": "card-header"
142
+ }, props)
143
+ );
144
+ }
145
+ function CardTitle(_a) {
146
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
147
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
148
+ "div",
149
+ __spreadValues({
150
+ className: cn("text-label-large", className),
151
+ "data-slot": "card-title"
152
+ }, props)
153
+ );
154
+ }
155
+ function CardAction(_a) {
156
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
157
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
158
+ "div",
159
+ __spreadValues({
160
+ className: cn(
161
+ "col-start-2 row-span-2 row-start-1 self-start justify-self-end",
162
+ className
163
+ ),
164
+ "data-slot": "card-action"
165
+ }, props)
166
+ );
167
+ }
168
+ function CardContent(_a) {
169
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
170
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
171
+ "div",
172
+ __spreadValues({
173
+ className: cn("px-6", className),
174
+ "data-slot": "card-content"
175
+ }, props)
176
+ );
177
+ }
178
+
179
+ // src/components/ui/empty.tsx
180
+ var import_class_variance_authority = require("class-variance-authority");
181
+ var import_jsx_runtime3 = require("react/jsx-runtime");
182
+ function Empty(_a) {
183
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
184
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
185
+ "div",
186
+ __spreadValues({
187
+ className: cn(
188
+ "flex min-w-0 flex-1 flex-col items-center justify-center gap-6 border border-dashed p-6 text-center text-balance md:p-12",
189
+ className
190
+ ),
191
+ "data-slot": "empty"
192
+ }, props)
193
+ );
194
+ }
195
+ var emptyMediaVariants = (0, import_class_variance_authority.cva)(
196
+ "mb-2 flex shrink-0 items-center justify-center [&_svg]:pointer-events-none [&_svg]:shrink-0",
197
+ {
198
+ variants: {
199
+ variant: {
200
+ default: "[&_svg:not([class*='size-'])]:size-10",
201
+ icon: "flex size-10 shrink-0 items-center justify-center text-muted-foreground [&_svg:not([class*='size-'])]:size-6"
202
+ }
203
+ },
204
+ defaultVariants: {
205
+ variant: "default"
206
+ }
207
+ }
208
+ );
209
+ function EmptyDescription(_a) {
210
+ var _b = _a, {
211
+ className
212
+ } = _b, props = __objRest(_b, [
213
+ "className"
214
+ ]);
215
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
216
+ "div",
217
+ __spreadValues({
218
+ className: cn(
219
+ "text-body-small leading-relaxed text-muted-foreground [&>a]:underline [&>a]:underline-offset-4 [&>a:hover]:text-primary",
220
+ className
221
+ ),
222
+ "data-slot": "empty-description"
223
+ }, props)
224
+ );
225
+ }
226
+
227
+ // src/components/ui/skeleton.tsx
228
+ var import_jsx_runtime4 = require("react/jsx-runtime");
229
+ function Skeleton(_a) {
230
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
231
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
232
+ "div",
233
+ __spreadValues({
234
+ className: cn("animate-pulse bg-muted", className),
235
+ "data-slot": "skeleton"
236
+ }, props)
237
+ );
238
+ }
239
+
240
+ // src/components/ui/button.tsx
241
+ var import_react2 = require("react");
242
+ var import_class_variance_authority2 = require("class-variance-authority");
243
+ var import_lucide_react = require("lucide-react");
244
+
245
+ // src/lib/slot.tsx
246
+ var React2 = __toESM(require("react"));
247
+ function mergeRefs(...refs) {
248
+ return (value) => {
249
+ for (const ref of refs) {
250
+ if (typeof ref === "function") ref(value);
251
+ else if (ref !== null)
252
+ ref.current = value;
253
+ }
254
+ };
255
+ }
256
+ var Slot = React2.forwardRef(
257
+ (_a, forwardedRef) => {
258
+ var _b = _a, { children } = _b, props = __objRest(_b, ["children"]);
259
+ const child = React2.Children.only(children);
260
+ if (!React2.isValidElement(child)) return null;
261
+ const childProps = child.props;
262
+ const merged = __spreadValues({}, props);
263
+ for (const key of Object.keys(childProps)) {
264
+ if (key === "className") {
265
+ merged.className = [props.className, childProps.className].filter(Boolean).join(" ");
266
+ } else if (key === "style") {
267
+ merged.style = __spreadValues(__spreadValues({}, props.style), childProps.style);
268
+ } else if (key.startsWith("on") && typeof childProps[key] === "function") {
269
+ const parentHandler = props[key];
270
+ if (typeof parentHandler === "function") {
271
+ merged[key] = (...args) => {
272
+ childProps[key](...args);
273
+ parentHandler(...args);
274
+ };
275
+ } else {
276
+ merged[key] = childProps[key];
277
+ }
278
+ } else {
279
+ merged[key] = childProps[key];
280
+ }
281
+ }
282
+ const childRef = child.ref;
283
+ merged.ref = forwardedRef ? mergeRefs(forwardedRef, childRef) : childRef;
284
+ return React2.cloneElement(
285
+ child,
286
+ merged
287
+ );
288
+ }
289
+ );
290
+ Slot.displayName = "Slot";
291
+
292
+ // src/components/ui/button.tsx
293
+ var import_jsx_runtime5 = require("react/jsx-runtime");
294
+ var buttonVariants = (0, import_class_variance_authority2.cva)(
295
+ "inline-flex shrink-0 cursor-pointer items-center justify-center gap-2 font-sans text-button whitespace-nowrap transition-all active:scale-[0.98] outline-none focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 aria-invalid:border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
296
+ {
297
+ variants: {
298
+ variant: {
299
+ default: "bg-primary text-primary-foreground shadow-xs hover:bg-primary/90",
300
+ secondary: "bg-brand-secondary text-brand-secondary-foreground shadow-xs hover:bg-brand-secondary/80 focus-visible:ring-brand-secondary/30",
301
+ destructive: "bg-destructive text-destructive-foreground shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:bg-destructive/60 dark:focus-visible:ring-destructive/40",
302
+ outline: "border border-input bg-background shadow-xs hover:bg-accent hover:text-accent-foreground focus-visible:border-border focus-visible:ring-border/50 dark:bg-input/30 dark:border-input dark:hover:bg-input/50",
303
+ "outline-primary": "border border-primary text-foreground bg-transparent shadow-xs hover:bg-primary/5 focus-visible:ring-primary/50",
304
+ "outline-secondary": "border border-brand-secondary text-brand-secondary bg-transparent shadow-xs hover:bg-brand-secondary/10 focus-visible:border-brand-secondary focus-visible:ring-brand-secondary/30",
305
+ ghost: "hover:bg-accent hover:text-accent-foreground hover:shadow-xs focus-visible:ring-border/50 dark:hover:bg-accent/50",
306
+ link: "text-primary underline-offset-4 hover:underline"
307
+ },
308
+ size: {
309
+ default: "h-9 px-4 py-2 has-[>svg]:px-3",
310
+ xs: "h-6 gap-1 px-2 text-button-xs has-[>svg]:px-1.5 [&_svg:not([class*='size-'])]:size-3",
311
+ sm: "h-8 gap-1.5 px-3 has-[>svg]:px-2.5",
312
+ lg: "h-10 px-6 has-[>svg]:px-4",
313
+ icon: "size-9",
314
+ "icon-xs": "size-6 [&_svg:not([class*='size-'])]:size-3",
315
+ "icon-sm": "size-8",
316
+ "icon-lg": "size-10"
317
+ }
318
+ },
319
+ defaultVariants: {
320
+ variant: "default",
321
+ size: "default"
322
+ }
323
+ }
324
+ );
325
+ var Button = (0, import_react2.forwardRef)(function Button2(_a, ref) {
326
+ var _b = _a, {
327
+ className,
328
+ variant,
329
+ size,
330
+ asChild = false,
331
+ loading = false,
332
+ disabled,
333
+ type = "button",
334
+ children
335
+ } = _b, props = __objRest(_b, [
336
+ "className",
337
+ "variant",
338
+ "size",
339
+ "asChild",
340
+ "loading",
341
+ "disabled",
342
+ "type",
343
+ "children"
344
+ ]);
345
+ const Comp = asChild ? Slot : "button";
346
+ const isIconOnly = size === "icon" || size === "icon-xs" || size === "icon-sm" || size === "icon-lg";
347
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
348
+ Comp,
349
+ __spreadProps(__spreadValues({
350
+ className: cn(buttonVariants({ variant, size, className })),
351
+ "data-size": size,
352
+ "data-slot": "button",
353
+ "data-variant": variant,
354
+ disabled: loading || disabled,
355
+ ref,
356
+ type
357
+ }, props), {
358
+ children: loading ? /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_jsx_runtime5.Fragment, { children: [
359
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_lucide_react.Loader2, { "aria-hidden": "true", className: "animate-spin" }),
360
+ !isIconOnly && children
361
+ ] }) : children
362
+ })
363
+ );
364
+ });
365
+
366
+ // src/components/ui/chart-shared.tsx
367
+ var import_jsx_runtime6 = require("react/jsx-runtime");
368
+ function hexToRgba(hex, alpha) {
369
+ const clean = hex.replace("#", "");
370
+ const full = clean.length === 3 ? clean.split("").map((c) => c + c).join("") : clean;
371
+ const r = parseInt(full.slice(0, 2), 16);
372
+ const g = parseInt(full.slice(2, 4), 16);
373
+ const b = parseInt(full.slice(4, 6), 16);
374
+ return `rgba(${r},${g},${b},${alpha})`;
375
+ }
376
+ var FALLBACK_TICK = "#9EAAB5";
377
+ function formatTooltipDate(iso, granularity) {
378
+ const d = new Date(iso);
379
+ return d.toLocaleDateString(
380
+ "en-US",
381
+ granularity === "daily" ? { month: "short", day: "numeric", year: "numeric" } : { month: "short", year: "numeric" }
382
+ );
383
+ }
384
+ function formatMonthLabel(iso) {
385
+ return new Date(iso).toLocaleDateString("en-US", {
386
+ month: "short",
387
+ year: "2-digit"
388
+ });
389
+ }
390
+ function formatCount(n) {
391
+ if (n >= 1e3) return `${(n / 1e3).toFixed(1)}k`;
392
+ return String(Math.round(n));
393
+ }
394
+ function ChartLegendItem({
395
+ label,
396
+ color,
397
+ lineStyle
398
+ }) {
399
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)("div", { className: "flex items-center gap-1.5", children: [
400
+ lineStyle ? /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
401
+ "svg",
402
+ {
403
+ width: "20",
404
+ height: "10",
405
+ viewBox: "0 0 20 10",
406
+ "aria-hidden": "true",
407
+ style: { flexShrink: 0 },
408
+ children: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
409
+ "line",
410
+ {
411
+ x1: "0",
412
+ y1: "5",
413
+ x2: "20",
414
+ y2: "5",
415
+ stroke: color,
416
+ strokeWidth: "2",
417
+ strokeLinecap: "square",
418
+ strokeDasharray: lineStyle === "dashed" ? "5 3" : void 0
419
+ }
420
+ )
421
+ }
422
+ ) : /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
423
+ "div",
424
+ {
425
+ style: {
426
+ width: 10,
427
+ height: 10,
428
+ backgroundColor: color,
429
+ flexShrink: 0
430
+ }
431
+ }
432
+ ),
433
+ /* @__PURE__ */ (0, import_jsx_runtime6.jsx)("span", { className: "text-[11px] text-muted-foreground leading-none", children: label })
434
+ ] });
435
+ }
436
+ function ChartPeriodButton({
437
+ period,
438
+ active,
439
+ onClick,
440
+ unit = "M"
441
+ }) {
442
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsxs)(
443
+ Button,
444
+ {
445
+ variant: active ? "default" : "outline",
446
+ size: "xs",
447
+ onClick,
448
+ children: [
449
+ period,
450
+ unit
451
+ ]
452
+ }
453
+ );
454
+ }
455
+
456
+ // src/components/ui/toggle-group.tsx
457
+ var React3 = __toESM(require("react"));
458
+ var import_toggle_group = require("@base-ui/react/toggle-group");
459
+ var import_toggle2 = require("@base-ui/react/toggle");
460
+
461
+ // src/components/ui/toggle.tsx
462
+ var import_class_variance_authority3 = require("class-variance-authority");
463
+ var import_toggle = require("@base-ui/react/toggle");
464
+ var import_jsx_runtime7 = require("react/jsx-runtime");
465
+ var toggleVariants = (0, import_class_variance_authority3.cva)(
466
+ "inline-flex items-center justify-center gap-2 whitespace-nowrap transition-[color,box-shadow] outline-none focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 disabled:pointer-events-none disabled:opacity-50 aria-invalid:border-destructive aria-invalid:ring-destructive/20 data-pressed:bg-primary/10 data-pressed:inset-ring data-pressed:inset-ring-primary data-pressed:text-foreground data-pressed:hover:bg-primary/10 data-pressed:hover:text-foreground dark:aria-invalid:ring-destructive/40 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
467
+ {
468
+ variants: {
469
+ variant: {
470
+ default: "bg-transparent hover:bg-muted hover:text-muted-foreground",
471
+ outline: "border border-input bg-transparent hover:bg-accent hover:text-accent-foreground"
472
+ },
473
+ size: {
474
+ default: "h-9 min-w-9 px-2 text-label-large",
475
+ sm: "h-8 min-w-8 px-1.5 text-label-medium",
476
+ lg: "h-10 min-w-10 px-2.5 text-h5"
477
+ }
478
+ },
479
+ defaultVariants: {
480
+ variant: "default",
481
+ size: "default"
482
+ }
483
+ }
484
+ );
485
+
486
+ // src/components/ui/toggle-group.tsx
487
+ var import_jsx_runtime8 = require("react/jsx-runtime");
488
+ var ToggleGroupContext = React3.createContext({
489
+ size: "default",
490
+ variant: "default",
491
+ spacing: 0
492
+ });
493
+ function ToggleGroup(_a) {
494
+ var _b = _a, {
495
+ className,
496
+ variant,
497
+ size,
498
+ spacing = 0,
499
+ type,
500
+ children
501
+ } = _b, props = __objRest(_b, [
502
+ "className",
503
+ "variant",
504
+ "size",
505
+ "spacing",
506
+ "type",
507
+ "children"
508
+ ]);
509
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
510
+ import_toggle_group.ToggleGroup,
511
+ __spreadProps(__spreadValues({
512
+ className: cn(
513
+ // WealthX: removed rounded-md (sharp corners) and shadow-xs (flat panels)
514
+ "group/toggle-group flex w-fit items-center gap-[--spacing(var(--gap))]",
515
+ className
516
+ ),
517
+ "data-size": size,
518
+ "data-slot": "toggle-group",
519
+ "data-spacing": spacing,
520
+ "data-variant": variant,
521
+ multiple: type === "multiple",
522
+ style: { "--gap": spacing }
523
+ }, props), {
524
+ children: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(ToggleGroupContext.Provider, { value: { variant, size, spacing }, children })
525
+ })
526
+ );
527
+ }
528
+ function ToggleGroupItem(_a) {
529
+ var _b = _a, {
530
+ className,
531
+ children,
532
+ variant,
533
+ size
534
+ } = _b, props = __objRest(_b, [
535
+ "className",
536
+ "children",
537
+ "variant",
538
+ "size"
539
+ ]);
540
+ const context = React3.useContext(ToggleGroupContext);
541
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
542
+ import_toggle2.Toggle,
543
+ __spreadProps(__spreadValues({
544
+ className: cn(
545
+ toggleVariants({
546
+ variant: context.variant || variant,
547
+ size: context.size || size
548
+ }),
549
+ "w-auto min-w-0 shrink-0 focus:z-10 focus-visible:z-10",
550
+ // WealthX: no rounded corners on grouped items
551
+ "data-[spacing=0]:rounded-none data-[spacing=0]:shadow-none data-[spacing=0]:data-[variant=outline]:border-l-0 data-[spacing=0]:data-[variant=outline]:first:border-l",
552
+ className
553
+ ),
554
+ "data-size": context.size || size,
555
+ "data-slot": "toggle-group-item",
556
+ "data-spacing": context.spacing,
557
+ "data-variant": context.variant || variant
558
+ }, props), {
559
+ children
560
+ })
561
+ );
562
+ }
563
+
564
+ // src/components/ui/backoffice-alert-matching-chart.tsx
565
+ var import_jsx_runtime9 = require("react/jsx-runtime");
566
+ import_chart.Chart.register(
567
+ import_chart.CategoryScale,
568
+ import_chart.LinearScale,
569
+ import_chart.LineController,
570
+ import_chart.LineElement,
571
+ import_chart.PointElement,
572
+ import_chart.BarController,
573
+ import_chart.BarElement,
574
+ import_chart.Tooltip
575
+ );
576
+ var PERIODS = [3, 6, 12];
577
+ var SLICE_COUNT = { 3: 3, 6: 6, 12: 12 };
578
+ var HEALTHY_COLOR = "#166d42";
579
+ var WATCH_COLOR = "#EF6C00";
580
+ var NEED_ACTION_COLOR = "#F44336";
581
+ function AlertMatchingLegend() {
582
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)("div", { className: "flex flex-wrap gap-x-3 gap-y-1.5 pb-2", children: [
583
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
584
+ ChartLegendItem,
585
+ {
586
+ label: "Healthy",
587
+ color: HEALTHY_COLOR,
588
+ lineStyle: "solid"
589
+ }
590
+ ),
591
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(ChartLegendItem, { label: "Watch", color: WATCH_COLOR, lineStyle: "solid" }),
592
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
593
+ ChartLegendItem,
594
+ {
595
+ label: "Need Action",
596
+ color: NEED_ACTION_COLOR,
597
+ lineStyle: "solid"
598
+ }
599
+ )
600
+ ] });
601
+ }
602
+ function BackofficeAlertMatchingChart({
603
+ chartData,
604
+ title = "Alert Matching History",
605
+ showLegend = true,
606
+ legendPosition = "top",
607
+ showXAxis = true,
608
+ showYAxis = false,
609
+ defaultPeriod = 6,
610
+ height = 200,
611
+ width = "100%",
612
+ className,
613
+ isLoading = false
614
+ }) {
615
+ const [period, setPeriod] = (0, import_react3.useState)(defaultPeriod);
616
+ const [chartType, setChartType] = (0, import_react3.useState)("line");
617
+ const themeVars = useThemeVars();
618
+ const fontFamily = themeVars["--font-sans"] || "Figtree, sans-serif";
619
+ const sliced = (0, import_react3.useMemo)(() => {
620
+ if (!(chartData == null ? void 0 : chartData.length)) return null;
621
+ const count = Math.min(SLICE_COUNT[period], chartData.length);
622
+ return chartData.slice(chartData.length - count);
623
+ }, [chartData, period]);
624
+ const labels = (0, import_react3.useMemo)(
625
+ () => {
626
+ var _a;
627
+ return (_a = sliced == null ? void 0 : sliced.map((p) => formatMonthLabel(p.date))) != null ? _a : [];
628
+ },
629
+ [sliced]
630
+ );
631
+ const isBar = chartType === "bar";
632
+ const datasets = (0, import_react3.useMemo)(() => {
633
+ if (!sliced) return [];
634
+ return [
635
+ {
636
+ type: chartType,
637
+ label: "Healthy",
638
+ data: sliced.map((p) => p.healthy),
639
+ borderColor: HEALTHY_COLOR,
640
+ backgroundColor: isBar ? HEALTHY_COLOR : hexToRgba(HEALTHY_COLOR, 0.08),
641
+ fill: !isBar,
642
+ tension: 0.3,
643
+ pointRadius: 0,
644
+ borderWidth: 2
645
+ },
646
+ {
647
+ type: chartType,
648
+ label: "Watch",
649
+ data: sliced.map((p) => p.watch),
650
+ borderColor: WATCH_COLOR,
651
+ backgroundColor: isBar ? WATCH_COLOR : hexToRgba(WATCH_COLOR, 0.08),
652
+ fill: !isBar,
653
+ tension: 0.3,
654
+ pointRadius: 0,
655
+ borderWidth: 2
656
+ },
657
+ {
658
+ type: chartType,
659
+ label: "Need Action",
660
+ data: sliced.map((p) => p.needAction),
661
+ borderColor: NEED_ACTION_COLOR,
662
+ backgroundColor: isBar ? NEED_ACTION_COLOR : hexToRgba(NEED_ACTION_COLOR, 0.08),
663
+ fill: !isBar,
664
+ tension: 0.3,
665
+ pointRadius: 0,
666
+ borderWidth: 2
667
+ }
668
+ ];
669
+ }, [sliced, chartType, isBar]);
670
+ const options = (0, import_react3.useMemo)(
671
+ () => ({
672
+ responsive: true,
673
+ maintainAspectRatio: false,
674
+ animation: { duration: 300 },
675
+ layout: { padding: 0 },
676
+ plugins: {
677
+ legend: { display: false },
678
+ tooltip: {
679
+ mode: "index",
680
+ intersect: false,
681
+ padding: 12,
682
+ cornerRadius: 0,
683
+ titleFont: { size: 11, weight: 600 },
684
+ bodyFont: { size: 12, weight: 500 },
685
+ callbacks: {
686
+ title: (tooltipItems) => {
687
+ var _a, _b, _c, _d;
688
+ const idx = (_a = tooltipItems[0]) == null ? void 0 : _a.dataIndex;
689
+ if (idx != null && ((_b = sliced == null ? void 0 : sliced[idx]) == null ? void 0 : _b.date)) {
690
+ return formatTooltipDate(sliced[idx].date, "monthly");
691
+ }
692
+ return (_d = (_c = tooltipItems[0]) == null ? void 0 : _c.label) != null ? _d : "";
693
+ },
694
+ label: (ctx) => {
695
+ const val = ctx.raw;
696
+ if (val === 0) return;
697
+ return ` ${ctx.dataset.label}: ${formatCount(val)}`;
698
+ }
699
+ }
700
+ }
701
+ },
702
+ scales: {
703
+ x: {
704
+ display: showXAxis,
705
+ grid: { display: false },
706
+ border: { display: false },
707
+ ticks: {
708
+ maxRotation: 0,
709
+ minRotation: 0,
710
+ color: FALLBACK_TICK,
711
+ font: { size: 10 }
712
+ }
713
+ },
714
+ y: {
715
+ display: showYAxis,
716
+ grid: { display: false },
717
+ border: { display: false },
718
+ beginAtZero: true,
719
+ ticks: {
720
+ padding: 8,
721
+ maxTicksLimit: 5,
722
+ color: FALLBACK_TICK,
723
+ font: { size: 10 },
724
+ callback: (v) => formatCount(Number(v))
725
+ }
726
+ }
727
+ }
728
+ }),
729
+ [showXAxis, showYAxis, sliced]
730
+ );
731
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(
732
+ Card,
733
+ {
734
+ className: cn("w-full py-4 sm:py-6 gap-2", className),
735
+ style: { maxWidth: width, fontFamily },
736
+ children: [
737
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(CardHeader, { className: "px-3 sm:px-6", children: [
738
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(CardTitle, { className: "text-xs font-semibold uppercase tracking-wide", children: title }),
739
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(CardAction, { children: /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)("div", { className: "flex items-center gap-2", children: [
740
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)(
741
+ ToggleGroup,
742
+ {
743
+ type: "single",
744
+ variant: "outline",
745
+ size: "sm",
746
+ value: chartType,
747
+ onValueChange: (v) => v && setChartType(v),
748
+ children: [
749
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(ToggleGroupItem, { value: "line", "aria-label": "Line chart", children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_lucide_react2.LineChart, { className: "size-3.5" }) }),
750
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(ToggleGroupItem, { value: "bar", "aria-label": "Bar chart", children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_lucide_react2.BarChart2, { className: "size-3.5" }) })
751
+ ]
752
+ }
753
+ ),
754
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)("div", { className: "flex gap-0.5 sm:gap-1", children: PERIODS.map((p) => /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
755
+ ChartPeriodButton,
756
+ {
757
+ period: p,
758
+ active: period === p,
759
+ onClick: () => setPeriod(p)
760
+ },
761
+ p
762
+ )) })
763
+ ] }) })
764
+ ] }),
765
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(CardContent, { className: "px-3 sm:px-6", children: isLoading ? /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Skeleton, { style: { height, width: "100%" } }) : !sliced ? /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Empty, { className: "flex-none p-4", style: { height }, children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(EmptyDescription, { children: "No data available" }) }) : /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)("div", { className: "flex flex-col gap-2", children: [
766
+ showLegend && legendPosition === "top" && /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(AlertMatchingLegend, {}),
767
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)("div", { style: { height, width: "100%", position: "relative" }, children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
768
+ import_react_chartjs_2.Chart,
769
+ {
770
+ type: chartType,
771
+ data: { labels, datasets },
772
+ options,
773
+ "aria-label": title
774
+ },
775
+ chartType
776
+ ) }),
777
+ showLegend && legendPosition === "bottom" && /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(AlertMatchingLegend, {})
778
+ ] }) })
779
+ ]
780
+ }
781
+ );
782
+ }
783
+ // Annotate the CommonJS export names for ESM import in node:
784
+ 0 && (module.exports = {
785
+ BackofficeAlertMatchingChart
786
+ });