@wealthx/shadcn 1.4.1 → 1.5.1

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 +356 -176
  2. package/CHANGELOG.md +12 -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 +367 -3
  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,835 @@
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/borrowing-capacity-card.tsx
60
+ var borrowing_capacity_card_exports = {};
61
+ __export(borrowing_capacity_card_exports, {
62
+ BorrowingCapacityCard: () => BorrowingCapacityCard
63
+ });
64
+ module.exports = __toCommonJS(borrowing_capacity_card_exports);
65
+
66
+ // src/lib/utils.ts
67
+ var import_clsx = require("clsx");
68
+ var import_tailwind_merge = require("tailwind-merge");
69
+ var twMerge = (0, import_tailwind_merge.extendTailwindMerge)({
70
+ extend: {
71
+ classGroups: {
72
+ "font-size": [
73
+ {
74
+ text: [
75
+ "display-large",
76
+ "display-medium",
77
+ "display-small",
78
+ "h1",
79
+ "h2",
80
+ "h3",
81
+ "h4",
82
+ "h5",
83
+ "h6",
84
+ "body-large",
85
+ "body-medium",
86
+ "body-small",
87
+ "label-large",
88
+ "label-medium",
89
+ "label-small",
90
+ "button",
91
+ "button-xs",
92
+ "caption",
93
+ "overline",
94
+ "code"
95
+ ]
96
+ }
97
+ ]
98
+ }
99
+ }
100
+ });
101
+ function cn(...inputs) {
102
+ return twMerge((0, import_clsx.clsx)(inputs));
103
+ }
104
+
105
+ // src/components/ui/borrowing-capacity-atoms.tsx
106
+ var import_lucide_react2 = require("lucide-react");
107
+
108
+ // src/lib/format-currency.ts
109
+ function formatCurrency(value, options) {
110
+ const { decimals = 0, showSign = false } = options != null ? options : {};
111
+ const abs = Math.abs(value);
112
+ const formatted = new Intl.NumberFormat("en-AU", {
113
+ style: "currency",
114
+ currency: "AUD",
115
+ minimumFractionDigits: decimals,
116
+ maximumFractionDigits: decimals
117
+ }).format(abs);
118
+ if (!showSign) return value < 0 ? `-${formatted}` : formatted;
119
+ if (value > 0) return `+${formatted}`;
120
+ if (value < 0) return `-${formatted}`;
121
+ return formatted;
122
+ }
123
+ function formatCurrencyAbbrev(value) {
124
+ const abs = Math.abs(value);
125
+ const sign = value < 0 ? "-" : "";
126
+ if (abs >= 1e9)
127
+ return `${sign}$${(abs / 1e9).toFixed(1)}B`;
128
+ if (abs >= 1e6) return `${sign}$${(abs / 1e6).toFixed(1)}M`;
129
+ if (abs >= 1e3) return `${sign}$${(abs / 1e3).toFixed(0)}K`;
130
+ return `${sign}$${abs.toFixed(0)}`;
131
+ }
132
+
133
+ // src/components/ui/button.tsx
134
+ var import_react = require("react");
135
+ var import_class_variance_authority = require("class-variance-authority");
136
+ var import_lucide_react = require("lucide-react");
137
+
138
+ // src/lib/slot.tsx
139
+ var React = __toESM(require("react"));
140
+ function mergeRefs(...refs) {
141
+ return (value) => {
142
+ for (const ref of refs) {
143
+ if (typeof ref === "function") ref(value);
144
+ else if (ref !== null)
145
+ ref.current = value;
146
+ }
147
+ };
148
+ }
149
+ var Slot = React.forwardRef(
150
+ (_a, forwardedRef) => {
151
+ var _b = _a, { children } = _b, props = __objRest(_b, ["children"]);
152
+ const child = React.Children.only(children);
153
+ if (!React.isValidElement(child)) return null;
154
+ const childProps = child.props;
155
+ const merged = __spreadValues({}, props);
156
+ for (const key of Object.keys(childProps)) {
157
+ if (key === "className") {
158
+ merged.className = [props.className, childProps.className].filter(Boolean).join(" ");
159
+ } else if (key === "style") {
160
+ merged.style = __spreadValues(__spreadValues({}, props.style), childProps.style);
161
+ } else if (key.startsWith("on") && typeof childProps[key] === "function") {
162
+ const parentHandler = props[key];
163
+ if (typeof parentHandler === "function") {
164
+ merged[key] = (...args) => {
165
+ childProps[key](...args);
166
+ parentHandler(...args);
167
+ };
168
+ } else {
169
+ merged[key] = childProps[key];
170
+ }
171
+ } else {
172
+ merged[key] = childProps[key];
173
+ }
174
+ }
175
+ const childRef = child.ref;
176
+ merged.ref = forwardedRef ? mergeRefs(forwardedRef, childRef) : childRef;
177
+ return React.cloneElement(
178
+ child,
179
+ merged
180
+ );
181
+ }
182
+ );
183
+ Slot.displayName = "Slot";
184
+
185
+ // src/components/ui/button.tsx
186
+ var import_jsx_runtime = require("react/jsx-runtime");
187
+ var buttonVariants = (0, import_class_variance_authority.cva)(
188
+ "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",
189
+ {
190
+ variants: {
191
+ variant: {
192
+ default: "bg-primary text-primary-foreground shadow-xs hover:bg-primary/90",
193
+ secondary: "bg-brand-secondary text-brand-secondary-foreground shadow-xs hover:bg-brand-secondary/80 focus-visible:ring-brand-secondary/30",
194
+ 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",
195
+ 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",
196
+ "outline-primary": "border border-primary text-foreground bg-transparent shadow-xs hover:bg-primary/5 focus-visible:ring-primary/50",
197
+ "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",
198
+ ghost: "hover:bg-accent hover:text-accent-foreground hover:shadow-xs focus-visible:ring-border/50 dark:hover:bg-accent/50",
199
+ link: "text-primary underline-offset-4 hover:underline"
200
+ },
201
+ size: {
202
+ default: "h-9 px-4 py-2 has-[>svg]:px-3",
203
+ xs: "h-6 gap-1 px-2 text-button-xs has-[>svg]:px-1.5 [&_svg:not([class*='size-'])]:size-3",
204
+ sm: "h-8 gap-1.5 px-3 has-[>svg]:px-2.5",
205
+ lg: "h-10 px-6 has-[>svg]:px-4",
206
+ icon: "size-9",
207
+ "icon-xs": "size-6 [&_svg:not([class*='size-'])]:size-3",
208
+ "icon-sm": "size-8",
209
+ "icon-lg": "size-10"
210
+ }
211
+ },
212
+ defaultVariants: {
213
+ variant: "default",
214
+ size: "default"
215
+ }
216
+ }
217
+ );
218
+ var Button = (0, import_react.forwardRef)(function Button2(_a, ref) {
219
+ var _b = _a, {
220
+ className,
221
+ variant,
222
+ size,
223
+ asChild = false,
224
+ loading = false,
225
+ disabled,
226
+ type = "button",
227
+ children
228
+ } = _b, props = __objRest(_b, [
229
+ "className",
230
+ "variant",
231
+ "size",
232
+ "asChild",
233
+ "loading",
234
+ "disabled",
235
+ "type",
236
+ "children"
237
+ ]);
238
+ const Comp = asChild ? Slot : "button";
239
+ const isIconOnly = size === "icon" || size === "icon-xs" || size === "icon-sm" || size === "icon-lg";
240
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
241
+ Comp,
242
+ __spreadProps(__spreadValues({
243
+ className: cn(buttonVariants({ variant, size, className })),
244
+ "data-size": size,
245
+ "data-slot": "button",
246
+ "data-variant": variant,
247
+ disabled: loading || disabled,
248
+ ref,
249
+ type
250
+ }, props), {
251
+ children: loading ? /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_jsx_runtime.Fragment, { children: [
252
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_lucide_react.Loader2, { "aria-hidden": "true", className: "animate-spin" }),
253
+ !isIconOnly && children
254
+ ] }) : children
255
+ })
256
+ );
257
+ });
258
+
259
+ // src/components/ui/borrowing-capacity-atoms.tsx
260
+ var import_jsx_runtime2 = require("react/jsx-runtime");
261
+ function BorrowCapacityItem({
262
+ title,
263
+ subTitle,
264
+ value,
265
+ className
266
+ }) {
267
+ if (!title && !value) {
268
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { className: cn("min-h-[52px]", className), "aria-hidden": true });
269
+ }
270
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: cn("flex flex-col gap-1", className), children: [
271
+ title && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { className: "block min-h-[2.5rem] text-sm text-muted-foreground", children: title }),
272
+ value && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { className: "text-lg font-semibold text-foreground", children: value }),
273
+ subTitle && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { className: "text-sm italic text-muted-foreground/70", children: subTitle })
274
+ ] });
275
+ }
276
+ function StatisticItem({
277
+ loopBackMonths = 3,
278
+ amountChange = 0,
279
+ amountChangePercentage = 0,
280
+ className
281
+ }) {
282
+ const isPositive = amountChangePercentage > 0;
283
+ const isNegative = amountChangePercentage < 0;
284
+ const TrendIcon = isPositive ? import_lucide_react2.TrendingUp : isNegative ? import_lucide_react2.TrendingDown : import_lucide_react2.Minus;
285
+ const trendClassName = isPositive ? "text-primary" : "text-muted-foreground";
286
+ const amountPrefix = isPositive ? "+" : isNegative ? "\u2212" : "";
287
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
288
+ "div",
289
+ {
290
+ className: cn(
291
+ "flex flex-col justify-center gap-2 border border-border p-3",
292
+ className
293
+ ),
294
+ children: [
295
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("span", { className: "text-sm text-muted-foreground", children: [
296
+ "Last ",
297
+ loopBackMonths,
298
+ " month",
299
+ loopBackMonths !== 1 ? "s" : ""
300
+ ] }),
301
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: "flex items-center justify-between gap-2", children: [
302
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("span", { className: "text-xl font-semibold tabular-nums text-foreground", children: [
303
+ amountPrefix,
304
+ formatCurrencyAbbrev(Math.abs(amountChange), 2)
305
+ ] }),
306
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(
307
+ "span",
308
+ {
309
+ className: cn(
310
+ "flex items-center gap-1 text-sm font-medium tabular-nums",
311
+ trendClassName
312
+ ),
313
+ children: [
314
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(TrendIcon, { size: 14, className: "shrink-0" }),
315
+ Math.abs(amountChangePercentage).toFixed(1),
316
+ "%"
317
+ ]
318
+ }
319
+ )
320
+ ] })
321
+ ]
322
+ }
323
+ );
324
+ }
325
+ var LVR_TIER_STYLES = {
326
+ safe: { text: "text-success", bar: "bg-success" },
327
+ moderate: { text: "text-warning", bar: "bg-warning" },
328
+ high: { text: "text-destructive", bar: "bg-destructive" }
329
+ };
330
+ function LoanToValueRatio({
331
+ lvr,
332
+ debtAmount,
333
+ equityAmount,
334
+ className
335
+ }) {
336
+ const clamped = Math.min(100, Math.max(0, lvr));
337
+ const tier = clamped <= 60 ? "safe" : clamped <= 80 ? "moderate" : "high";
338
+ const { text: lvrTextColor, bar: lvrBarColor } = LVR_TIER_STYLES[tier];
339
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: cn("flex flex-col items-center gap-2", className), children: [
340
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: "flex flex-col items-center leading-none", children: [
341
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("span", { className: cn("text-3xl font-bold tabular-nums", lvrTextColor), children: [
342
+ clamped.toFixed(0),
343
+ "%"
344
+ ] }),
345
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("span", { className: "mt-1 text-sm font-semibold uppercase tracking-widest text-muted-foreground", children: "LVR" })
346
+ ] }),
347
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { className: "h-1.5 w-full overflow-hidden bg-muted", "aria-hidden": true, children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
348
+ "div",
349
+ {
350
+ className: cn("h-full transition-all", lvrBarColor),
351
+ style: { width: `${clamped}%` }
352
+ }
353
+ ) }),
354
+ (debtAmount !== void 0 || equityAmount !== void 0) && /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("div", { className: "flex w-full items-center justify-between text-sm text-muted-foreground", children: [
355
+ debtAmount !== void 0 && /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("span", { children: [
356
+ "Debt ",
357
+ formatCurrencyAbbrev(debtAmount, 1)
358
+ ] }),
359
+ equityAmount !== void 0 && /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)("span", { children: [
360
+ "Equity ",
361
+ formatCurrencyAbbrev(equityAmount, 1)
362
+ ] })
363
+ ] })
364
+ ] });
365
+ }
366
+
367
+ // src/components/ui/borrowing-capacity-line-chart.tsx
368
+ var import_react3 = require("react");
369
+ var import_chart = require("chart.js");
370
+ var import_react_chartjs_2 = require("react-chartjs-2");
371
+
372
+ // src/lib/theme-provider.tsx
373
+ var import_react2 = require("react");
374
+ var import_jsx_runtime3 = require("react/jsx-runtime");
375
+ var ThemeVarsContext = (0, import_react2.createContext)({});
376
+ function useThemeVars() {
377
+ return (0, import_react2.useContext)(ThemeVarsContext);
378
+ }
379
+
380
+ // src/components/ui/chart-shared.tsx
381
+ var import_jsx_runtime4 = require("react/jsx-runtime");
382
+ var FALLBACK_PRIMARY = "#33FF99";
383
+ var FALLBACK_BG = "#ffffff";
384
+ var FALLBACK_FOREGROUND = "#040D13";
385
+ var FALLBACK_TICK = "#9EAAB5";
386
+ function formatTooltipDate(iso, granularity) {
387
+ const d = new Date(iso);
388
+ return d.toLocaleDateString(
389
+ "en-US",
390
+ granularity === "daily" ? { month: "short", day: "numeric", year: "numeric" } : { month: "short", year: "numeric" }
391
+ );
392
+ }
393
+ function formatMonthLabel(iso) {
394
+ return new Date(iso).toLocaleDateString("en-US", {
395
+ month: "short",
396
+ year: "2-digit"
397
+ });
398
+ }
399
+ function ChartLegendItem({
400
+ label,
401
+ color,
402
+ lineStyle
403
+ }) {
404
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)("div", { className: "flex items-center gap-1.5", children: [
405
+ lineStyle ? /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
406
+ "svg",
407
+ {
408
+ width: "20",
409
+ height: "10",
410
+ viewBox: "0 0 20 10",
411
+ "aria-hidden": "true",
412
+ style: { flexShrink: 0 },
413
+ children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
414
+ "line",
415
+ {
416
+ x1: "0",
417
+ y1: "5",
418
+ x2: "20",
419
+ y2: "5",
420
+ stroke: color,
421
+ strokeWidth: "2",
422
+ strokeLinecap: "square",
423
+ strokeDasharray: lineStyle === "dashed" ? "5 3" : void 0
424
+ }
425
+ )
426
+ }
427
+ ) : /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
428
+ "div",
429
+ {
430
+ style: {
431
+ width: 10,
432
+ height: 10,
433
+ backgroundColor: color,
434
+ flexShrink: 0
435
+ }
436
+ }
437
+ ),
438
+ /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("span", { className: "text-[11px] text-muted-foreground leading-none", children: label })
439
+ ] });
440
+ }
441
+
442
+ // src/components/ui/card.tsx
443
+ var import_jsx_runtime5 = require("react/jsx-runtime");
444
+ function Card(_a) {
445
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
446
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
447
+ "div",
448
+ __spreadValues({
449
+ className: cn(
450
+ "flex flex-col gap-6 border bg-card py-6 text-card-foreground shadow-sm",
451
+ className
452
+ ),
453
+ "data-slot": "card"
454
+ }, props)
455
+ );
456
+ }
457
+ function CardHeader(_a) {
458
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
459
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
460
+ "div",
461
+ __spreadValues({
462
+ className: cn(
463
+ "@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",
464
+ className
465
+ ),
466
+ "data-slot": "card-header"
467
+ }, props)
468
+ );
469
+ }
470
+ function CardTitle(_a) {
471
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
472
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
473
+ "div",
474
+ __spreadValues({
475
+ className: cn("text-label-large", className),
476
+ "data-slot": "card-title"
477
+ }, props)
478
+ );
479
+ }
480
+ function CardContent(_a) {
481
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
482
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
483
+ "div",
484
+ __spreadValues({
485
+ className: cn("px-6", className),
486
+ "data-slot": "card-content"
487
+ }, props)
488
+ );
489
+ }
490
+
491
+ // src/components/ui/empty.tsx
492
+ var import_class_variance_authority2 = require("class-variance-authority");
493
+ var import_jsx_runtime6 = require("react/jsx-runtime");
494
+ function Empty(_a) {
495
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
496
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
497
+ "div",
498
+ __spreadValues({
499
+ className: cn(
500
+ "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",
501
+ className
502
+ ),
503
+ "data-slot": "empty"
504
+ }, props)
505
+ );
506
+ }
507
+ var emptyMediaVariants = (0, import_class_variance_authority2.cva)(
508
+ "mb-2 flex shrink-0 items-center justify-center [&_svg]:pointer-events-none [&_svg]:shrink-0",
509
+ {
510
+ variants: {
511
+ variant: {
512
+ default: "[&_svg:not([class*='size-'])]:size-10",
513
+ icon: "flex size-10 shrink-0 items-center justify-center text-muted-foreground [&_svg:not([class*='size-'])]:size-6"
514
+ }
515
+ },
516
+ defaultVariants: {
517
+ variant: "default"
518
+ }
519
+ }
520
+ );
521
+ function EmptyDescription(_a) {
522
+ var _b = _a, {
523
+ className
524
+ } = _b, props = __objRest(_b, [
525
+ "className"
526
+ ]);
527
+ return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
528
+ "div",
529
+ __spreadValues({
530
+ className: cn(
531
+ "text-body-small leading-relaxed text-muted-foreground [&>a]:underline [&>a]:underline-offset-4 [&>a:hover]:text-primary",
532
+ className
533
+ ),
534
+ "data-slot": "empty-description"
535
+ }, props)
536
+ );
537
+ }
538
+
539
+ // src/components/ui/skeleton.tsx
540
+ var import_jsx_runtime7 = require("react/jsx-runtime");
541
+ function Skeleton(_a) {
542
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
543
+ return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
544
+ "div",
545
+ __spreadValues({
546
+ className: cn("animate-pulse bg-muted", className),
547
+ "data-slot": "skeleton"
548
+ }, props)
549
+ );
550
+ }
551
+
552
+ // src/components/ui/borrowing-capacity-line-chart.tsx
553
+ var import_jsx_runtime8 = require("react/jsx-runtime");
554
+ import_chart.Chart.register(
555
+ import_chart.CategoryScale,
556
+ import_chart.LinearScale,
557
+ import_chart.LineController,
558
+ import_chart.LineElement,
559
+ import_chart.PointElement,
560
+ import_chart.Tooltip
561
+ );
562
+ var SERIES_LABELS = {
563
+ "current-expenses": "Based on Current Expenses",
564
+ "optimised-estimate": "Optimised Estimate",
565
+ "desired-loan-amount": "Desired Loan Amount"
566
+ };
567
+ var SERIES_LINE_STYLE = {
568
+ "current-expenses": "solid",
569
+ "optimised-estimate": "dashed",
570
+ "desired-loan-amount": "dashed"
571
+ };
572
+ var SERIES_BORDER_WIDTH = {
573
+ "current-expenses": 2,
574
+ "optimised-estimate": 1.5,
575
+ "desired-loan-amount": 2
576
+ };
577
+ var SERIES_RENDER_ORDER = [
578
+ "desired-loan-amount",
579
+ "optimised-estimate",
580
+ "current-expenses"
581
+ ];
582
+ var SERIES_LEGEND_ORDER = [
583
+ "current-expenses",
584
+ "optimised-estimate",
585
+ "desired-loan-amount"
586
+ ];
587
+ var DASH_PATTERN = [6, 4];
588
+ function formatDateLabel(iso) {
589
+ const normalized = `${iso.slice(0, 7)}-01T00:00:00`;
590
+ return formatMonthLabel(normalized);
591
+ }
592
+ function formatDateTooltip(iso) {
593
+ const normalized = `${iso.slice(0, 7)}-01T00:00:00`;
594
+ return formatTooltipDate(normalized, "monthly");
595
+ }
596
+ function BorrowingCapacityLineChart({
597
+ series,
598
+ title = "Borrowing Capacity",
599
+ kpiValue,
600
+ height = 280,
601
+ width = "100%",
602
+ className,
603
+ isLoading = false,
604
+ showXAxis = true,
605
+ showYAxis = true,
606
+ showLegend = true,
607
+ legendPosition = "bottom"
608
+ }) {
609
+ const themeVars = useThemeVars();
610
+ const brandPrimary = themeVars["--theme-primary"] || FALLBACK_PRIMARY;
611
+ const fontFamily = themeVars["--font-sans"] || "Figtree, sans-serif";
612
+ const seriesColor = (0, import_react3.useMemo)(
613
+ () => ({
614
+ "current-expenses": FALLBACK_FOREGROUND,
615
+ "optimised-estimate": FALLBACK_TICK,
616
+ // desired-loan-amount tracks tenant brand; no alpha conversion needed at 1.0
617
+ "desired-loan-amount": brandPrimary
618
+ }),
619
+ [brandPrimary]
620
+ );
621
+ const orderedSeries = (0, import_react3.useMemo)(() => {
622
+ if (!(series == null ? void 0 : series.length)) return [];
623
+ return SERIES_RENDER_ORDER.map(
624
+ (t) => series.find((s) => s.type === t)
625
+ ).filter((s) => !!s && s.data.length > 0);
626
+ }, [series]);
627
+ const hasData = orderedSeries.length > 0;
628
+ const labels = (0, import_react3.useMemo)(() => {
629
+ var _a;
630
+ if (!orderedSeries.length) return [];
631
+ const primary = (_a = orderedSeries.find((s) => s.type === "current-expenses")) != null ? _a : orderedSeries[0];
632
+ return primary.data.map((p) => p.date);
633
+ }, [orderedSeries]);
634
+ const chartData = (0, import_react3.useMemo)(() => {
635
+ if (!orderedSeries.length) return { labels: [], datasets: [] };
636
+ return {
637
+ labels,
638
+ datasets: orderedSeries.map((s) => {
639
+ const color = seriesColor[s.type];
640
+ const isDashed = SERIES_LINE_STYLE[s.type] === "dashed";
641
+ return {
642
+ label: SERIES_LABELS[s.type],
643
+ data: s.data.map((p) => p.amountCents / 100),
644
+ borderColor: color,
645
+ backgroundColor: "transparent",
646
+ borderWidth: SERIES_BORDER_WIDTH[s.type],
647
+ borderDash: isDashed ? DASH_PATTERN : [],
648
+ tension: s.type === "current-expenses" ? 0.4 : 0,
649
+ pointRadius: 0,
650
+ pointHoverRadius: s.type === "desired-loan-amount" ? 0 : 5,
651
+ pointHoverBackgroundColor: FALLBACK_BG,
652
+ pointHoverBorderColor: color,
653
+ pointHoverBorderWidth: 2,
654
+ pointHitRadius: 12
655
+ };
656
+ })
657
+ };
658
+ }, [labels, orderedSeries, seriesColor]);
659
+ const options = (0, import_react3.useMemo)(
660
+ () => ({
661
+ responsive: true,
662
+ maintainAspectRatio: false,
663
+ animation: { duration: 800, easing: "easeOutQuart" },
664
+ plugins: {
665
+ legend: { display: false },
666
+ tooltip: {
667
+ enabled: true,
668
+ mode: "index",
669
+ intersect: false,
670
+ filter: (item) => item.dataset.label !== SERIES_LABELS["desired-loan-amount"],
671
+ displayColors: true,
672
+ boxWidth: 10,
673
+ boxHeight: 2,
674
+ padding: 12,
675
+ cornerRadius: 0,
676
+ titleFont: { size: 11, weight: 600, family: fontFamily },
677
+ bodyFont: { size: 12, weight: 500, family: fontFamily },
678
+ callbacks: {
679
+ title: (items) => {
680
+ var _a;
681
+ const iso = (_a = items[0]) == null ? void 0 : _a.label;
682
+ return iso ? formatDateTooltip(iso) : "";
683
+ },
684
+ label: (ctx) => {
685
+ var _a;
686
+ const dollars = (_a = ctx.parsed.y) != null ? _a : 0;
687
+ return ` ${ctx.dataset.label}: ${formatCurrency(dollars)}`;
688
+ }
689
+ }
690
+ }
691
+ },
692
+ interaction: { mode: "index", intersect: false },
693
+ scales: {
694
+ x: {
695
+ type: "category",
696
+ display: showXAxis,
697
+ grid: { display: false },
698
+ border: { display: false },
699
+ ticks: {
700
+ autoSkip: true,
701
+ maxTicksLimit: 7,
702
+ maxRotation: 0,
703
+ minRotation: 0,
704
+ color: FALLBACK_TICK,
705
+ font: { size: 10, family: fontFamily },
706
+ callback: function(_, index) {
707
+ const iso = labels[index];
708
+ return iso ? formatDateLabel(iso) : "";
709
+ }
710
+ }
711
+ },
712
+ y: {
713
+ display: showYAxis,
714
+ position: "left",
715
+ grid: { display: false },
716
+ border: { display: false },
717
+ ticks: {
718
+ maxTicksLimit: 6,
719
+ padding: 8,
720
+ color: FALLBACK_TICK,
721
+ font: { size: 10, family: fontFamily },
722
+ callback: (v) => formatCurrencyAbbrev(Number(v))
723
+ }
724
+ }
725
+ }
726
+ }),
727
+ [showXAxis, showYAxis, labels, fontFamily]
728
+ );
729
+ const legendEl = (0, import_react3.useMemo)(() => {
730
+ if (!showLegend || !hasData) return null;
731
+ const items = SERIES_LEGEND_ORDER.map(
732
+ (t) => orderedSeries.find((s) => s.type === t)
733
+ ).filter((s) => !!s);
734
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { className: "flex flex-wrap items-center gap-x-4 gap-y-1.5", children: items.map((s) => /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
735
+ ChartLegendItem,
736
+ {
737
+ label: SERIES_LABELS[s.type],
738
+ color: seriesColor[s.type],
739
+ lineStyle: SERIES_LINE_STYLE[s.type]
740
+ },
741
+ s.type
742
+ )) });
743
+ }, [showLegend, hasData, orderedSeries, seriesColor]);
744
+ const legendWrapper = legendEl ? /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { className: legendPosition === "top" ? "mb-3" : "mt-3", children: legendEl }) : null;
745
+ return /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)(
746
+ Card,
747
+ {
748
+ className: cn("w-full py-4 sm:py-6 gap-2", className),
749
+ style: { maxWidth: width, fontFamily },
750
+ children: [
751
+ /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(CardHeader, { className: "px-3 sm:px-6", children: /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)("div", { className: "flex items-start justify-between gap-4", children: [
752
+ /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(CardTitle, { className: "text-xs font-semibold uppercase tracking-wide", children: title }),
753
+ kpiValue != null && /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("span", { className: "shrink-0 text-xl font-bold tabular-nums", children: formatCurrency(kpiValue / 100) })
754
+ ] }) }),
755
+ /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(CardContent, { className: "px-3 sm:px-6", children: isLoading ? /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(Skeleton, { style: { height, width: "100%" } }) : !hasData ? /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(Empty, { className: "flex-none p-4", style: { height }, children: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(EmptyDescription, { children: "No borrowing capacity data available" }) }) : /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)(import_jsx_runtime8.Fragment, { children: [
756
+ legendPosition === "top" && legendWrapper,
757
+ /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { style: { height, width: "100%", position: "relative" }, children: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
758
+ import_react_chartjs_2.Chart,
759
+ {
760
+ type: "line",
761
+ data: chartData,
762
+ options,
763
+ "aria-label": title
764
+ }
765
+ ) }),
766
+ legendPosition === "bottom" && legendWrapper
767
+ ] }) })
768
+ ]
769
+ }
770
+ );
771
+ }
772
+
773
+ // src/components/ui/borrowing-capacity-card.tsx
774
+ var import_jsx_runtime9 = require("react/jsx-runtime");
775
+ function BorrowingCapacityCard({
776
+ chartSeries,
777
+ kpiValueCents,
778
+ fields,
779
+ lvr,
780
+ debtAmount,
781
+ equityAmount,
782
+ statistics,
783
+ isLoading = false,
784
+ className
785
+ }) {
786
+ var _a, _b, _c, _d;
787
+ const hasFields = ((_a = fields == null ? void 0 : fields.length) != null ? _a : 0) > 0;
788
+ const hasLvr = lvr !== void 0;
789
+ const hasStats = ((_b = statistics == null ? void 0 : statistics.length) != null ? _b : 0) > 0;
790
+ const showMetricsRow = isLoading || hasFields || hasLvr;
791
+ const showStatsRow = isLoading || hasStats;
792
+ return /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)("div", { className: cn("flex flex-col border border-border", className), children: [
793
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
794
+ BorrowingCapacityLineChart,
795
+ {
796
+ series: chartSeries,
797
+ kpiValue: kpiValueCents,
798
+ isLoading,
799
+ className: "border-0 shadow-none"
800
+ }
801
+ ),
802
+ showMetricsRow && /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)("div", { className: "flex items-stretch border-t border-border", children: [
803
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)("div", { className: "grid flex-1 grid-cols-4 gap-x-6 gap-y-4 p-4", children: isLoading ? Array.from({ length: (_c = fields == null ? void 0 : fields.length) != null ? _c : 4 }).map((_, i) => /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)("div", { className: "flex flex-col gap-1.5", children: [
804
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Skeleton, { className: "h-10 w-full" }),
805
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Skeleton, { className: "h-6 w-28" })
806
+ ] }, i)) : fields == null ? void 0 : fields.map((field, i) => /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
807
+ BorrowCapacityItem,
808
+ {
809
+ title: field.label,
810
+ subTitle: field.subLabel,
811
+ value: field.value
812
+ },
813
+ i
814
+ )) }),
815
+ (isLoading || hasLvr) && /* @__PURE__ */ (0, import_jsx_runtime9.jsx)("div", { className: "flex w-48 shrink-0 items-center border-l border-border p-4", children: isLoading ? /* @__PURE__ */ (0, import_jsx_runtime9.jsxs)("div", { className: "flex w-full flex-col items-center gap-2", children: [
816
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Skeleton, { className: "h-10 w-14" }),
817
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Skeleton, { className: "h-2 w-full" }),
818
+ /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Skeleton, { className: "h-4 w-full" })
819
+ ] }) : /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(
820
+ LoanToValueRatio,
821
+ {
822
+ lvr,
823
+ debtAmount,
824
+ equityAmount,
825
+ className: "w-full"
826
+ }
827
+ ) })
828
+ ] }),
829
+ showStatsRow && /* @__PURE__ */ (0, import_jsx_runtime9.jsx)("div", { className: "flex gap-3 border-t border-border p-4", children: isLoading ? Array.from({ length: (_d = statistics == null ? void 0 : statistics.length) != null ? _d : 3 }).map((_, i) => /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(Skeleton, { className: "h-16 flex-1" }, i)) : statistics == null ? void 0 : statistics.map((stat, i) => /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(StatisticItem, __spreadProps(__spreadValues({}, stat), { className: "flex-1" }), i)) })
830
+ ] });
831
+ }
832
+ // Annotate the CommonJS export names for ESM import in node:
833
+ 0 && (module.exports = {
834
+ BorrowingCapacityCard
835
+ });