@wealthx/shadcn 1.2.1 → 1.3.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 (247) hide show
  1. package/.turbo/turbo-build.log +203 -150
  2. package/CHANGELOG.md +29 -0
  3. package/dist/{chunk-4Y6R4WEC.mjs → chunk-2A5RRQGG.mjs} +9 -22
  4. package/dist/{chunk-TS2ZX2VS.mjs → chunk-2UM72RJ7.mjs} +11 -15
  5. package/dist/{chunk-A56YQQHG.mjs → chunk-3NCUZIFP.mjs} +2 -2
  6. package/dist/chunk-3OYFOX3X.mjs +79 -0
  7. package/dist/{chunk-RP3SQYA3.mjs → chunk-3TTACBDP.mjs} +9 -4
  8. package/dist/chunk-4GAWMKMI.mjs +710 -0
  9. package/dist/{chunk-SYOD63OZ.mjs → chunk-5FQIKDKP.mjs} +6 -6
  10. package/dist/{chunk-K3JYD4IU.mjs → chunk-5IS7G74I.mjs} +11 -4
  11. package/dist/chunk-6AW4KJHE.mjs +235 -0
  12. package/dist/chunk-6CR5N2JW.mjs +302 -0
  13. package/dist/{chunk-XIRTEFKH.mjs → chunk-6DZEXFNB.mjs} +36 -8
  14. package/dist/chunk-6O6KD7CE.mjs +271 -0
  15. package/dist/chunk-7PV3IWCN.mjs +33 -0
  16. package/dist/{chunk-SPJ5KXW7.mjs → chunk-7S5AESZO.mjs} +5 -5
  17. package/dist/{chunk-RYCLWMZ7.mjs → chunk-ABFDMHOR.mjs} +9 -7
  18. package/dist/{chunk-SWGT756Z.mjs → chunk-AMQZRHEZ.mjs} +10 -4
  19. package/dist/{chunk-WOEHFRGB.mjs → chunk-BDYZCBRT.mjs} +4 -4
  20. package/dist/{chunk-WAZD7NFU.mjs → chunk-BKNFWEH2.mjs} +6 -6
  21. package/dist/{chunk-CLIN5525.mjs → chunk-C7CQJNMR.mjs} +1 -1
  22. package/dist/{chunk-D4ILTPOG.mjs → chunk-CFMQP5QS.mjs} +5 -4
  23. package/dist/{chunk-VPBN3WOO.mjs → chunk-DGHAXJBN.mjs} +9 -7
  24. package/dist/chunk-DOEO3CDL.mjs +27 -0
  25. package/dist/{chunk-KUDCQ4FI.mjs → chunk-DUJTAXMH.mjs} +9 -4
  26. package/dist/{chunk-GGM2UYGG.mjs → chunk-EBXQWIYG.mjs} +10 -4
  27. package/dist/{chunk-PMB3A7V3.mjs → chunk-EI5F6FMT.mjs} +1 -1
  28. package/dist/chunk-EWRB4PAD.mjs +468 -0
  29. package/dist/chunk-FAKPBKLT.mjs +253 -0
  30. package/dist/chunk-FNQXOAYJ.mjs +169 -0
  31. package/dist/{chunk-4CX4SBRO.mjs → chunk-GHC7LLUX.mjs} +14 -5
  32. package/dist/chunk-HBZLGDIN.mjs +507 -0
  33. package/dist/{chunk-SIZMLSRU.mjs → chunk-HISNT2MG.mjs} +8 -6
  34. package/dist/{chunk-PR6V5XKM.mjs → chunk-HVY6KCCF.mjs} +7 -4
  35. package/dist/chunk-I3RZS7V2.mjs +136 -0
  36. package/dist/chunk-IAE3F7DR.mjs +1962 -0
  37. package/dist/{chunk-ZRO5JO3H.mjs → chunk-IHMFS7NZ.mjs} +81 -84
  38. package/dist/{chunk-PCPLO5HT.mjs → chunk-IOJRDS6V.mjs} +96 -14
  39. package/dist/{chunk-LHYCMLVA.mjs → chunk-JKGDCQTZ.mjs} +11 -4
  40. package/dist/{chunk-H45TKD34.mjs → chunk-JMHR3YGZ.mjs} +1 -1
  41. package/dist/{chunk-4MN6UQHG.mjs → chunk-K5A5L6T2.mjs} +17 -39
  42. package/dist/{chunk-CSDO6VBW.mjs → chunk-LBMRIB3G.mjs} +10 -10
  43. package/dist/chunk-LV35NGVG.mjs +272 -0
  44. package/dist/{chunk-FZIXGLMV.mjs → chunk-M3FV7LOK.mjs} +5 -12
  45. package/dist/{chunk-FMAXJ2SI.mjs → chunk-MBON7YRJ.mjs} +1 -1
  46. package/dist/chunk-MIZQHHUO.mjs +441 -0
  47. package/dist/chunk-MN5NYQCL.mjs +29 -0
  48. package/dist/chunk-NL3ZO62D.mjs +31 -0
  49. package/dist/{chunk-Q76O3RIQ.mjs → chunk-NMOI6CQD.mjs} +1 -1
  50. package/dist/{chunk-P6AM5V7O.mjs → chunk-OODBHKG7.mjs} +1 -1
  51. package/dist/chunk-PBL4OQV2.mjs +283 -0
  52. package/dist/{chunk-3WMX6KWS.mjs → chunk-PU4YZQXV.mjs} +11 -12
  53. package/dist/chunk-QMY3AZJH.mjs +80 -0
  54. package/dist/{chunk-BL3DXM2X.mjs → chunk-QZ4RE6NA.mjs} +11 -4
  55. package/dist/{chunk-VACKZOMY.mjs → chunk-R3VSPKNP.mjs} +3 -3
  56. package/dist/{chunk-OPNQAVVH.mjs → chunk-RJI6GKVF.mjs} +8 -6
  57. package/dist/{chunk-WG6JGJXB.mjs → chunk-T4BJLT57.mjs} +1 -1
  58. package/dist/chunk-U4NDAF2P.mjs +207 -0
  59. package/dist/{chunk-DOH3EHX7.mjs → chunk-U5X52X37.mjs} +1 -1
  60. package/dist/chunk-UMTOX62O.mjs +415 -0
  61. package/dist/{chunk-7MMXNK3C.mjs → chunk-VLARHE5V.mjs} +8 -6
  62. package/dist/{chunk-2I5S2AMY.mjs → chunk-XREGSKX3.mjs} +2 -2
  63. package/dist/{chunk-JNQORUPP.mjs → chunk-YJG55G2H.mjs} +14 -11
  64. package/dist/chunk-ZC45IGZO.mjs +388 -0
  65. package/dist/components/ui/add-column-modal.js +42 -14
  66. package/dist/components/ui/add-column-modal.mjs +4 -4
  67. package/dist/components/ui/add-lead-modal.js +42 -11
  68. package/dist/components/ui/add-lead-modal.mjs +3 -3
  69. package/dist/components/ui/advisor-card.js +497 -0
  70. package/dist/components/ui/advisor-card.mjs +13 -0
  71. package/dist/components/ui/ai-assistant-drawer.js +11 -10
  72. package/dist/components/ui/ai-assistant-drawer.mjs +3 -3
  73. package/dist/components/ui/alert-dialog.js +2 -2
  74. package/dist/components/ui/alert-dialog.mjs +2 -2
  75. package/dist/components/ui/appointment-action-dialogs.js +1160 -0
  76. package/dist/components/ui/appointment-action-dialogs.mjs +23 -0
  77. package/dist/components/ui/appointment-availability-settings.js +1590 -0
  78. package/dist/components/ui/appointment-availability-settings.mjs +23 -0
  79. package/dist/components/ui/appointment-book-dialog.js +1744 -0
  80. package/dist/components/ui/appointment-book-dialog.mjs +27 -0
  81. package/dist/components/ui/appointment-calendar-view.js +833 -0
  82. package/dist/components/ui/appointment-calendar-view.mjs +14 -0
  83. package/dist/components/ui/appointment-detail-sheet.js +1517 -0
  84. package/dist/components/ui/appointment-detail-sheet.mjs +24 -0
  85. package/dist/components/ui/appointment-gmail-connect.js +467 -0
  86. package/dist/components/ui/appointment-gmail-connect.mjs +14 -0
  87. package/dist/components/ui/appointment-mini-card.js +345 -0
  88. package/dist/components/ui/appointment-mini-card.mjs +11 -0
  89. package/dist/components/ui/appointment-time-slot-picker.js +311 -0
  90. package/dist/components/ui/appointment-time-slot-picker.mjs +13 -0
  91. package/dist/components/ui/appointment-upcoming-card.js +1268 -0
  92. package/dist/components/ui/appointment-upcoming-card.mjs +21 -0
  93. package/dist/components/ui/backoffice-alert-history-chart.js +11 -5
  94. package/dist/components/ui/backoffice-alert-history-chart.mjs +5 -4
  95. package/dist/components/ui/backoffice-alerts-chart.js +786 -0
  96. package/dist/components/ui/backoffice-alerts-chart.mjs +19 -0
  97. package/dist/components/ui/backoffice-connections-chart.js +817 -0
  98. package/dist/components/ui/backoffice-connections-chart.mjs +19 -0
  99. package/dist/components/ui/backoffice-contact-history-chart.js +11 -5
  100. package/dist/components/ui/backoffice-contact-history-chart.mjs +5 -4
  101. package/dist/components/ui/badge.js +6 -6
  102. package/dist/components/ui/badge.mjs +1 -1
  103. package/dist/components/ui/borrowing-capacity-line-chart.js +30 -21
  104. package/dist/components/ui/borrowing-capacity-line-chart.mjs +5 -4
  105. package/dist/components/ui/button.js +2 -2
  106. package/dist/components/ui/button.mjs +1 -1
  107. package/dist/components/ui/calendar.js +2 -2
  108. package/dist/components/ui/calendar.mjs +2 -2
  109. package/dist/components/ui/card.js +1 -1
  110. package/dist/components/ui/card.mjs +1 -1
  111. package/dist/components/ui/cash-balance-line-chart.js +31 -23
  112. package/dist/components/ui/cash-balance-line-chart.mjs +5 -4
  113. package/dist/components/ui/cashflow-bar-chart.js +12 -5
  114. package/dist/components/ui/cashflow-bar-chart.mjs +5 -4
  115. package/dist/components/ui/chip.js +97 -18
  116. package/dist/components/ui/chip.mjs +3 -2
  117. package/dist/components/ui/color-picker.js +547 -0
  118. package/dist/components/ui/color-picker.mjs +24 -0
  119. package/dist/components/ui/data-table.js +182 -129
  120. package/dist/components/ui/data-table.mjs +3 -2
  121. package/dist/components/ui/date-picker.js +48 -27
  122. package/dist/components/ui/date-picker.mjs +4 -3
  123. package/dist/components/ui/dialog.js +37 -9
  124. package/dist/components/ui/dialog.mjs +2 -2
  125. package/dist/components/ui/expense-bar-chart.js +12 -5
  126. package/dist/components/ui/expense-bar-chart.mjs +5 -4
  127. package/dist/components/ui/field.mjs +2 -2
  128. package/dist/components/ui/financial-cards.js +322 -155
  129. package/dist/components/ui/financial-cards.mjs +5 -3
  130. package/dist/components/ui/financial-drawers.js +2 -2
  131. package/dist/components/ui/financial-drawers.mjs +3 -3
  132. package/dist/components/ui/financial-sections.js +14 -10
  133. package/dist/components/ui/financial-sections.mjs +6 -5
  134. package/dist/components/ui/form-primitives.js +4 -4
  135. package/dist/components/ui/form-primitives.mjs +3 -3
  136. package/dist/components/ui/income-bar-chart.js +12 -5
  137. package/dist/components/ui/income-bar-chart.mjs +5 -4
  138. package/dist/components/ui/input-group.js +2 -2
  139. package/dist/components/ui/input-group.mjs +2 -2
  140. package/dist/components/ui/kanban-column.js +52 -44
  141. package/dist/components/ui/kanban-column.mjs +7 -5
  142. package/dist/components/ui/opportunity-card.js +52 -44
  143. package/dist/components/ui/opportunity-card.mjs +6 -4
  144. package/dist/components/ui/opportunity-edit-modals.js +1371 -1267
  145. package/dist/components/ui/opportunity-edit-modals.mjs +10 -10
  146. package/dist/components/ui/opportunity-summary-tab.js +2748 -2161
  147. package/dist/components/ui/opportunity-summary-tab.mjs +16 -16
  148. package/dist/components/ui/page-header.js +92 -0
  149. package/dist/components/ui/page-header.mjs +8 -0
  150. package/dist/components/ui/page-top-bar.js +88 -0
  151. package/dist/components/ui/page-top-bar.mjs +8 -0
  152. package/dist/components/ui/pagination.js +303 -19
  153. package/dist/components/ui/pagination.mjs +11 -4
  154. package/dist/components/ui/pipeline-board.js +209 -195
  155. package/dist/components/ui/pipeline-board.mjs +10 -8
  156. package/dist/components/ui/pipeline-dialogs.js +118 -69
  157. package/dist/components/ui/pipeline-dialogs.mjs +8 -7
  158. package/dist/components/ui/pipeline-primitives.js +6 -6
  159. package/dist/components/ui/pipeline-primitives.mjs +2 -2
  160. package/dist/components/ui/property-cashflow-doughnut-chart.js +14 -12
  161. package/dist/components/ui/property-cashflow-doughnut-chart.mjs +5 -4
  162. package/dist/components/ui/property-debt-equity-doughnut-chart.js +14 -12
  163. package/dist/components/ui/property-debt-equity-doughnut-chart.mjs +5 -4
  164. package/dist/components/ui/property-mobile-estimate-line-chart.js +16 -14
  165. package/dist/components/ui/property-mobile-estimate-line-chart.mjs +5 -4
  166. package/dist/components/ui/sidebar-nav.js +679 -0
  167. package/dist/components/ui/sidebar-nav.mjs +14 -0
  168. package/dist/components/ui/stage-timeline.js +6 -6
  169. package/dist/components/ui/stage-timeline.mjs +3 -3
  170. package/dist/components/ui/stepper.js +283 -0
  171. package/dist/components/ui/stepper.mjs +18 -0
  172. package/dist/components/ui/toggle-group.js +4 -4
  173. package/dist/components/ui/toggle-group.mjs +2 -2
  174. package/dist/components/ui/toggle.js +4 -4
  175. package/dist/components/ui/toggle.mjs +1 -1
  176. package/dist/components/ui/transactions-expense-categories-doughnut-chart.js +18 -16
  177. package/dist/components/ui/transactions-expense-categories-doughnut-chart.mjs +5 -4
  178. package/dist/components/ui/transactions-income-expense-bar-chart.js +28 -12
  179. package/dist/components/ui/transactions-income-expense-bar-chart.mjs +5 -4
  180. package/dist/components/ui/transactions-liabilities-breakdown-doughnut-chart.js +18 -16
  181. package/dist/components/ui/transactions-liabilities-breakdown-doughnut-chart.mjs +5 -4
  182. package/dist/index.js +12927 -8522
  183. package/dist/index.mjs +288 -190
  184. package/dist/lib/typography.js +10 -10
  185. package/dist/lib/typography.mjs +1 -1
  186. package/dist/styles.css +1 -1
  187. package/package.json +86 -1
  188. package/src/components/index.tsx +146 -0
  189. package/src/components/ui/add-column-modal.tsx +7 -7
  190. package/src/components/ui/add-lead-modal.tsx +6 -3
  191. package/src/components/ui/advisor-card.tsx +227 -0
  192. package/src/components/ui/ai-assistant-drawer.tsx +4 -3
  193. package/src/components/ui/appointment-action-dialogs.tsx +297 -0
  194. package/src/components/ui/appointment-availability-settings.tsx +645 -0
  195. package/src/components/ui/appointment-book-dialog.tsx +618 -0
  196. package/src/components/ui/appointment-calendar-view.tsx +510 -0
  197. package/src/components/ui/appointment-detail-sheet.tsx +415 -0
  198. package/src/components/ui/appointment-gmail-connect.tsx +188 -0
  199. package/src/components/ui/appointment-mini-card.tsx +104 -0
  200. package/src/components/ui/appointment-time-slot-picker.tsx +123 -0
  201. package/src/components/ui/appointment-upcoming-card.tsx +635 -0
  202. package/src/components/ui/backoffice-alert-history-chart.tsx +10 -2
  203. package/src/components/ui/backoffice-alerts-chart.tsx +312 -0
  204. package/src/components/ui/backoffice-connections-chart.tsx +339 -0
  205. package/src/components/ui/backoffice-contact-history-chart.tsx +10 -2
  206. package/src/components/ui/badge.tsx +12 -6
  207. package/src/components/ui/borrowing-capacity-line-chart.tsx +4 -11
  208. package/src/components/ui/button.tsx +2 -2
  209. package/src/components/ui/card.tsx +1 -1
  210. package/src/components/ui/cash-balance-line-chart.tsx +4 -23
  211. package/src/components/ui/cashflow-bar-chart.tsx +9 -2
  212. package/src/components/ui/chart-shared.tsx +4 -11
  213. package/src/components/ui/chip.tsx +23 -19
  214. package/src/components/ui/color-picker.tsx +309 -0
  215. package/src/components/ui/data-table.tsx +117 -83
  216. package/src/components/ui/date-picker.tsx +42 -37
  217. package/src/components/ui/dialog.tsx +72 -6
  218. package/src/components/ui/expense-bar-chart.tsx +11 -2
  219. package/src/components/ui/financial-cards.tsx +99 -10
  220. package/src/components/ui/income-bar-chart.tsx +11 -2
  221. package/src/components/ui/opportunity-card.tsx +10 -39
  222. package/src/components/ui/opportunity-edit-modals.tsx +98 -36
  223. package/src/components/ui/opportunity-summary-tab.tsx +548 -232
  224. package/src/components/ui/page-header.tsx +57 -0
  225. package/src/components/ui/page-top-bar.tsx +48 -0
  226. package/src/components/ui/pagination.tsx +171 -22
  227. package/src/components/ui/pipeline-board.tsx +12 -5
  228. package/src/components/ui/property-cashflow-doughnut-chart.tsx +3 -1
  229. package/src/components/ui/property-debt-equity-doughnut-chart.tsx +3 -1
  230. package/src/components/ui/property-mobile-estimate-line-chart.tsx +3 -1
  231. package/src/components/ui/sidebar-nav.tsx +516 -0
  232. package/src/components/ui/stepper.tsx +347 -0
  233. package/src/components/ui/toggle.tsx +4 -4
  234. package/src/components/ui/transactions-expense-categories-doughnut-chart.tsx +3 -1
  235. package/src/components/ui/transactions-income-expense-bar-chart.tsx +12 -9
  236. package/src/components/ui/transactions-liabilities-breakdown-doughnut-chart.tsx +3 -1
  237. package/src/lib/format-currency.ts +44 -0
  238. package/src/lib/format-date.ts +50 -0
  239. package/src/lib/opportunity-constants.ts +12 -0
  240. package/src/lib/typography.ts +11 -11
  241. package/src/styles/globals.css +36 -34
  242. package/src/styles/styles-css.ts +1 -1
  243. package/tsup.config.ts +17 -0
  244. package/dist/chunk-PG6K5XEC.mjs +0 -475
  245. package/dist/chunk-WA6O6EUR.mjs +0 -1885
  246. package/dist/chunk-WNGWBVLV.mjs +0 -148
  247. package/dist/{chunk-LLVQKSU3.mjs → chunk-GD4BJDJR.mjs} +3 -3
@@ -178,10 +178,10 @@ var buttonVariants = (0, import_class_variance_authority.cva)(
178
178
  default: "bg-primary text-primary-foreground shadow-xs hover:bg-primary/90",
179
179
  secondary: "bg-brand-secondary text-brand-secondary-foreground shadow-xs hover:bg-brand-secondary/80 focus-visible:ring-brand-secondary/30",
180
180
  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",
181
- outline: "border border-input bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50",
181
+ outline: "border border-input bg-background shadow-xs hover:bg-accent hover:text-accent-foreground focus-visible:ring-border/50 dark:bg-input/30 dark:border-input dark:hover:bg-input/50",
182
182
  "outline-primary": "border border-primary text-foreground bg-transparent shadow-xs hover:bg-primary/5 focus-visible:ring-primary/50",
183
183
  "outline-secondary": "border border-brand-secondary text-brand-secondary bg-transparent shadow-xs hover:bg-brand-secondary/10 focus-visible:ring-brand-secondary/30",
184
- ghost: "hover:bg-accent hover:text-accent-foreground hover:shadow-xs dark:hover:bg-accent/50",
184
+ ghost: "hover:bg-accent hover:text-accent-foreground hover:shadow-xs focus-visible:ring-border/50 dark:hover:bg-accent/50",
185
185
  link: "text-primary underline-offset-4 hover:underline"
186
186
  },
187
187
  size: {
@@ -270,38 +270,65 @@ function DialogOverlay(_a) {
270
270
  }, props)
271
271
  );
272
272
  }
273
+ var DIALOG_MAX_WIDTHS = {
274
+ sm: "24rem",
275
+ md: "28rem",
276
+ lg: "32rem",
277
+ xl: "36rem",
278
+ "2xl": "42rem",
279
+ "3xl": "48rem",
280
+ "4xl": "56rem",
281
+ full: "100%"
282
+ };
283
+ var DIALOG_AUTO_MIN_WIDTH = "20rem";
273
284
  function DialogContent(_a) {
274
285
  var _b = _a, {
275
286
  className,
276
287
  children,
277
288
  showCloseButton = true,
278
- style
289
+ style,
290
+ container,
291
+ align = "center",
292
+ size = "lg",
293
+ minWidth
279
294
  } = _b, props = __objRest(_b, [
280
295
  "className",
281
296
  "children",
282
297
  "showCloseButton",
283
- "style"
298
+ "style",
299
+ "container",
300
+ "align",
301
+ "size",
302
+ "minWidth"
284
303
  ]);
285
304
  const themeVars = useThemeVars();
286
- return /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(DialogPortal, { children: [
305
+ const isAuto = size === "auto";
306
+ const sizeStyle = isAuto ? { minWidth: minWidth != null ? minWidth : DIALOG_AUTO_MIN_WIDTH } : { maxWidth: DIALOG_MAX_WIDTHS[size] };
307
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(DialogPortal, { container: container != null ? container : void 0, children: [
287
308
  /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(DialogOverlay, { style: themeVars }),
288
309
  /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(
289
310
  import_dialog.Dialog.Popup,
290
311
  __spreadProps(__spreadValues({
291
312
  className: cn(
292
- // WealthX: removed rounded-lg (sharp corners), shadow-lg (flat panels), foreground/50 scrim via DialogOverlay
293
- "fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 duration-200 outline-none data-ending-style:animate-out data-ending-style:fade-out-0 data-ending-style:zoom-out-95 data-ending-style:fill-mode-forwards data-open:animate-in data-open:fade-in-0 data-open:zoom-in-95 sm:max-w-lg",
313
+ // WealthX: removed rounded-lg (sharp corners), shadow-lg (flat panels)
314
+ // max-w-[calc(100%-2rem)] acts as a viewport-edge guard on all sizes.
315
+ // Fixed max-width is applied via inline style (sizeStyle) to avoid
316
+ // Tailwind v4 class-scanning gaps with dynamic class lookups.
317
+ "fixed left-[50%] z-50 grid max-w-[calc(100%-2rem)] translate-x-[-50%] gap-4 border bg-background p-6 duration-200 outline-none data-ending-style:animate-out data-ending-style:fade-out-0 data-ending-style:zoom-out-95 data-ending-style:fill-mode-forwards data-open:animate-in data-open:fade-in-0 data-open:zoom-in-95",
318
+ // "auto" → hug content (with min-width floor); fixed sizes → fill to max-width
319
+ isAuto ? "w-auto" : "w-full",
320
+ align === "center" ? "top-[50%] translate-y-[-50%]" : "top-4 translate-y-0",
294
321
  className
295
322
  ),
296
323
  "data-slot": "dialog-content",
297
- style: __spreadValues(__spreadValues({}, themeVars), style)
324
+ style: __spreadValues(__spreadValues(__spreadValues({}, themeVars), sizeStyle), style)
298
325
  }, props), {
299
326
  children: [
300
327
  children,
301
328
  showCloseButton ? /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(
302
329
  import_dialog.Dialog.Close,
303
330
  {
304
- className: "absolute top-4 right-4 transition-colors hover:bg-foreground/5 focus:outline-hidden focus:ring-2 focus:ring-border focus:ring-offset-0 disabled:pointer-events-none [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
331
+ className: "absolute top-4 right-4 inline-flex size-7 items-center justify-center transition-colors hover:bg-foreground/5 focus-visible:outline-hidden focus-visible:ring-2 focus-visible:ring-border focus-visible:ring-offset-0 disabled:pointer-events-none [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
305
332
  "data-slot": "dialog-close",
306
333
  children: [
307
334
  /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_lucide_react2.XIcon, {}),
@@ -354,6 +381,7 @@ function DialogFooter(_a) {
354
381
  import_dialog.Dialog.Close,
355
382
  {
356
383
  className: cn(buttonVariants({ variant: "outline" })),
384
+ type: "button",
357
385
  children: "Close"
358
386
  }
359
387
  ) : null
@@ -520,10 +548,13 @@ function AddLeadModal({
520
548
  }
521
549
  ),
522
550
  searchValue && /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(
523
- "button",
551
+ Button,
524
552
  {
553
+ type: "button",
554
+ variant: "ghost",
555
+ size: "icon",
525
556
  onClick: () => onSearchChange == null ? void 0 : onSearchChange(""),
526
- className: "absolute right-2.5 top-1/2 -translate-y-1/2 text-muted-foreground hover:text-foreground",
557
+ className: "absolute right-2.5 top-1/2 size-6 -translate-y-1/2 text-muted-foreground hover:text-foreground",
527
558
  "aria-label": "Clear search",
528
559
  children: /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(import_lucide_react5.X, { className: "size-3.5" })
529
560
  }
@@ -1,11 +1,11 @@
1
1
  import {
2
2
  AddLeadModal
3
- } from "../../chunk-PR6V5XKM.mjs";
3
+ } from "../../chunk-HVY6KCCF.mjs";
4
4
  import "../../chunk-RGVKLTLH.mjs";
5
5
  import "../../chunk-7YAU5CY6.mjs";
6
6
  import "../../chunk-GYMYRIZP.mjs";
7
- import "../../chunk-XIRTEFKH.mjs";
8
- import "../../chunk-2I5S2AMY.mjs";
7
+ import "../../chunk-6DZEXFNB.mjs";
8
+ import "../../chunk-XREGSKX3.mjs";
9
9
  import "../../chunk-DBHJ5KC3.mjs";
10
10
  import "../../chunk-FEZKMUCF.mjs";
11
11
  import "../../chunk-QOJ2DQD6.mjs";
@@ -0,0 +1,497 @@
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/advisor-card.tsx
60
+ var advisor_card_exports = {};
61
+ __export(advisor_card_exports, {
62
+ AdvisorCard: () => AdvisorCard
63
+ });
64
+ module.exports = __toCommonJS(advisor_card_exports);
65
+
66
+ // src/components/ui/badge.tsx
67
+ var import_class_variance_authority = require("class-variance-authority");
68
+
69
+ // src/lib/utils.ts
70
+ var import_clsx = require("clsx");
71
+ var import_tailwind_merge = require("tailwind-merge");
72
+ var twMerge = (0, import_tailwind_merge.extendTailwindMerge)({
73
+ extend: {
74
+ classGroups: {
75
+ "font-size": [
76
+ {
77
+ text: [
78
+ "display-large",
79
+ "display-medium",
80
+ "display-small",
81
+ "h1",
82
+ "h2",
83
+ "h3",
84
+ "h4",
85
+ "h5",
86
+ "h6",
87
+ "body-large",
88
+ "body-medium",
89
+ "body-small",
90
+ "label-large",
91
+ "label-medium",
92
+ "label-small",
93
+ "button",
94
+ "button-xs",
95
+ "caption",
96
+ "overline",
97
+ "code"
98
+ ]
99
+ }
100
+ ]
101
+ }
102
+ }
103
+ });
104
+ function cn(...inputs) {
105
+ return twMerge((0, import_clsx.clsx)(inputs));
106
+ }
107
+
108
+ // src/lib/slot.tsx
109
+ var React = __toESM(require("react"));
110
+ function mergeRefs(...refs) {
111
+ return (value) => {
112
+ for (const ref of refs) {
113
+ if (typeof ref === "function") ref(value);
114
+ else if (ref !== null)
115
+ ref.current = value;
116
+ }
117
+ };
118
+ }
119
+ var Slot = React.forwardRef(
120
+ (_a, forwardedRef) => {
121
+ var _b = _a, { children } = _b, props = __objRest(_b, ["children"]);
122
+ const child = React.Children.only(children);
123
+ if (!React.isValidElement(child)) return null;
124
+ const childProps = child.props;
125
+ const merged = __spreadValues({}, props);
126
+ for (const key of Object.keys(childProps)) {
127
+ if (key === "className") {
128
+ merged.className = [props.className, childProps.className].filter(Boolean).join(" ");
129
+ } else if (key === "style") {
130
+ merged.style = __spreadValues(__spreadValues({}, props.style), childProps.style);
131
+ } else if (key.startsWith("on") && typeof childProps[key] === "function") {
132
+ const parentHandler = props[key];
133
+ if (typeof parentHandler === "function") {
134
+ merged[key] = (...args) => {
135
+ childProps[key](...args);
136
+ parentHandler(...args);
137
+ };
138
+ } else {
139
+ merged[key] = childProps[key];
140
+ }
141
+ } else {
142
+ merged[key] = childProps[key];
143
+ }
144
+ }
145
+ const childRef = child.ref;
146
+ merged.ref = forwardedRef ? mergeRefs(forwardedRef, childRef) : childRef;
147
+ return React.cloneElement(
148
+ child,
149
+ merged
150
+ );
151
+ }
152
+ );
153
+ Slot.displayName = "Slot";
154
+
155
+ // src/components/ui/badge.tsx
156
+ var import_jsx_runtime = require("react/jsx-runtime");
157
+ var badgeVariants = (0, import_class_variance_authority.cva)(
158
+ "inline-flex w-fit shrink-0 items-center justify-center gap-1 overflow-hidden rounded-full border border-transparent px-2.5 py-0.5 text-xs font-medium font-sans whitespace-nowrap transition-[color,box-shadow] focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 aria-invalid:border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 [&>svg]:pointer-events-none [&>svg]:size-3",
159
+ {
160
+ variants: {
161
+ variant: {
162
+ default: "border-primary/40 bg-primary/10 text-foreground [a&]:hover:bg-primary/15",
163
+ secondary: "border-border bg-muted text-muted-foreground [a&]:hover:bg-muted/80",
164
+ destructive: "border-destructive/40 bg-destructive/10 text-destructive-text focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 [a&]:hover:bg-destructive/15",
165
+ success: "border-success/40 bg-success/10 text-success-text [a&]:hover:bg-success/15",
166
+ warning: "border-warning/40 bg-warning/10 text-warning-text [a&]:hover:bg-warning/15",
167
+ info: "border-info/40 bg-info/10 text-info-text [a&]:hover:bg-info/15",
168
+ outline: "border-border text-foreground [a&]:hover:bg-accent [a&]:hover:text-accent-foreground",
169
+ ghost: "[a&]:hover:bg-accent [a&]:hover:text-accent-foreground",
170
+ link: "text-primary underline-offset-4 [a&]:hover:underline"
171
+ }
172
+ },
173
+ defaultVariants: {
174
+ variant: "default"
175
+ }
176
+ }
177
+ );
178
+ function Badge(_a) {
179
+ var _b = _a, {
180
+ className,
181
+ variant = "default",
182
+ asChild = false
183
+ } = _b, props = __objRest(_b, [
184
+ "className",
185
+ "variant",
186
+ "asChild"
187
+ ]);
188
+ const Comp = asChild ? Slot : "span";
189
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
190
+ Comp,
191
+ __spreadValues({
192
+ className: cn(badgeVariants({ variant }), className),
193
+ "data-slot": "badge",
194
+ "data-variant": variant
195
+ }, props)
196
+ );
197
+ }
198
+
199
+ // src/components/ui/button.tsx
200
+ var import_react = require("react");
201
+ var import_class_variance_authority2 = require("class-variance-authority");
202
+ var import_lucide_react = require("lucide-react");
203
+ var import_jsx_runtime2 = require("react/jsx-runtime");
204
+ var buttonVariants = (0, import_class_variance_authority2.cva)(
205
+ "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",
206
+ {
207
+ variants: {
208
+ variant: {
209
+ default: "bg-primary text-primary-foreground shadow-xs hover:bg-primary/90",
210
+ secondary: "bg-brand-secondary text-brand-secondary-foreground shadow-xs hover:bg-brand-secondary/80 focus-visible:ring-brand-secondary/30",
211
+ 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",
212
+ outline: "border border-input bg-background shadow-xs hover:bg-accent hover:text-accent-foreground focus-visible:ring-border/50 dark:bg-input/30 dark:border-input dark:hover:bg-input/50",
213
+ "outline-primary": "border border-primary text-foreground bg-transparent shadow-xs hover:bg-primary/5 focus-visible:ring-primary/50",
214
+ "outline-secondary": "border border-brand-secondary text-brand-secondary bg-transparent shadow-xs hover:bg-brand-secondary/10 focus-visible:ring-brand-secondary/30",
215
+ ghost: "hover:bg-accent hover:text-accent-foreground hover:shadow-xs focus-visible:ring-border/50 dark:hover:bg-accent/50",
216
+ link: "text-primary underline-offset-4 hover:underline"
217
+ },
218
+ size: {
219
+ default: "h-9 px-4 py-2 has-[>svg]:px-3",
220
+ xs: "h-6 gap-1 px-2 text-button-xs has-[>svg]:px-1.5 [&_svg:not([class*='size-'])]:size-3",
221
+ sm: "h-8 gap-1.5 px-3 has-[>svg]:px-2.5",
222
+ lg: "h-10 px-6 has-[>svg]:px-4",
223
+ icon: "size-9",
224
+ "icon-xs": "size-6 [&_svg:not([class*='size-'])]:size-3",
225
+ "icon-sm": "size-8",
226
+ "icon-lg": "size-10"
227
+ }
228
+ },
229
+ defaultVariants: {
230
+ variant: "default",
231
+ size: "default"
232
+ }
233
+ }
234
+ );
235
+ var Button = (0, import_react.forwardRef)(function Button2(_a, ref) {
236
+ var _b = _a, {
237
+ className,
238
+ variant,
239
+ size,
240
+ asChild = false,
241
+ loading = false,
242
+ disabled,
243
+ type = "button",
244
+ children
245
+ } = _b, props = __objRest(_b, [
246
+ "className",
247
+ "variant",
248
+ "size",
249
+ "asChild",
250
+ "loading",
251
+ "disabled",
252
+ "type",
253
+ "children"
254
+ ]);
255
+ const Comp = asChild ? Slot : "button";
256
+ const isIconOnly = size === "icon" || size === "icon-xs" || size === "icon-sm" || size === "icon-lg";
257
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
258
+ Comp,
259
+ __spreadProps(__spreadValues({
260
+ className: cn(buttonVariants({ variant, size, className })),
261
+ "data-size": size,
262
+ "data-slot": "button",
263
+ "data-variant": variant,
264
+ disabled: loading || disabled,
265
+ ref,
266
+ type
267
+ }, props), {
268
+ children: loading ? /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_jsx_runtime2.Fragment, { children: [
269
+ /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_lucide_react.Loader2, { "aria-hidden": "true", className: "animate-spin" }),
270
+ !isIconOnly && children
271
+ ] }) : children
272
+ })
273
+ );
274
+ });
275
+
276
+ // src/components/ui/avatar.tsx
277
+ var import_avatar = require("@base-ui/react/avatar");
278
+ var import_jsx_runtime3 = require("react/jsx-runtime");
279
+ function Avatar(_a) {
280
+ var _b = _a, {
281
+ className,
282
+ size = "default"
283
+ } = _b, props = __objRest(_b, [
284
+ "className",
285
+ "size"
286
+ ]);
287
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
288
+ import_avatar.Avatar.Root,
289
+ __spreadValues({
290
+ className: cn(
291
+ "group/avatar relative flex size-8 shrink-0 rounded-full select-none data-[size=lg]:size-10 data-[size=sm]:size-6",
292
+ className
293
+ ),
294
+ "data-size": size,
295
+ "data-slot": "avatar"
296
+ }, props)
297
+ );
298
+ }
299
+ function AvatarImage(_a) {
300
+ var _b = _a, { className } = _b, props = __objRest(_b, ["className"]);
301
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
302
+ import_avatar.Avatar.Image,
303
+ __spreadValues({
304
+ className: cn("aspect-square size-full rounded-full", className),
305
+ "data-slot": "avatar-image"
306
+ }, props)
307
+ );
308
+ }
309
+ function AvatarFallback(_a) {
310
+ var _b = _a, {
311
+ className
312
+ } = _b, props = __objRest(_b, [
313
+ "className"
314
+ ]);
315
+ return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
316
+ import_avatar.Avatar.Fallback,
317
+ __spreadValues({
318
+ className: cn(
319
+ "flex size-full items-center justify-center rounded-full overflow-hidden bg-muted text-body-small font-sans text-muted-foreground group-data-[size=sm]/avatar:text-caption",
320
+ className
321
+ ),
322
+ "data-slot": "avatar-fallback"
323
+ }, props)
324
+ );
325
+ }
326
+
327
+ // src/components/ui/separator.tsx
328
+ var import_separator = require("@base-ui/react/separator");
329
+ var import_jsx_runtime4 = require("react/jsx-runtime");
330
+ function Separator(_a) {
331
+ var _b = _a, {
332
+ className,
333
+ orientation = "horizontal"
334
+ } = _b, props = __objRest(_b, [
335
+ "className",
336
+ "orientation"
337
+ ]);
338
+ return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
339
+ import_separator.Separator,
340
+ __spreadValues({
341
+ className: cn(
342
+ "shrink-0 bg-border data-[orientation=horizontal]:h-px data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-px",
343
+ className
344
+ ),
345
+ "data-orientation": orientation,
346
+ "data-slot": "separator"
347
+ }, props)
348
+ );
349
+ }
350
+
351
+ // src/components/ui/advisor-card.tsx
352
+ var import_lucide_react2 = require("lucide-react");
353
+ var import_jsx_runtime5 = require("react/jsx-runtime");
354
+ var STATUS_VARIANT = {
355
+ pending: "warning",
356
+ confirmed: "success",
357
+ cancelled: "destructive",
358
+ rescheduled: "info"
359
+ };
360
+ var STATUS_LABEL = {
361
+ pending: "Pending",
362
+ confirmed: "Confirmed",
363
+ cancelled: "Cancelled",
364
+ rescheduled: "Rescheduled"
365
+ };
366
+ var STRIP_BG = {
367
+ pending: "bg-warning/5",
368
+ confirmed: "bg-success/5",
369
+ cancelled: "bg-destructive/5",
370
+ rescheduled: "bg-info/5"
371
+ };
372
+ function AdvisorCard({
373
+ name,
374
+ role,
375
+ phone,
376
+ email,
377
+ companyLogoUrl,
378
+ avatarInitials,
379
+ isPrimary = false,
380
+ appointment,
381
+ onRefer,
382
+ onMoreOptions,
383
+ onBookAppointment,
384
+ onViewAppointment
385
+ }) {
386
+ return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex flex-col border border-border bg-card", children: [
387
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex items-start gap-4 p-4", children: [
388
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(Avatar, { className: "h-10 w-10 shrink-0", children: [
389
+ companyLogoUrl && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(AvatarImage, { src: companyLogoUrl, alt: `${name} company logo` }),
390
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(AvatarFallback, { className: "text-sm", children: avatarInitials != null ? avatarInitials : name.slice(0, 2).toUpperCase() })
391
+ ] }),
392
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex min-w-0 flex-1 flex-col gap-0.5", children: [
393
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("p", { className: "text-sm font-semibold leading-tight", children: name }),
394
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("p", { className: "text-sm text-muted-foreground", children: role }),
395
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "mt-2 flex flex-col gap-1", children: [
396
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex items-center gap-1.5 text-xs text-muted-foreground", children: [
397
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_lucide_react2.Phone, { className: "h-3 w-3 shrink-0" }),
398
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { children: phone })
399
+ ] }),
400
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex items-center gap-1.5 text-xs text-muted-foreground", children: [
401
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_lucide_react2.Mail, { className: "h-3 w-3 shrink-0" }),
402
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { children: email })
403
+ ] })
404
+ ] })
405
+ ] }),
406
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex shrink-0 items-center gap-1.5", children: [
407
+ isPrimary && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(Badge, { variant: "success", children: "Primary" }),
408
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
409
+ Button,
410
+ {
411
+ variant: "ghost",
412
+ size: "icon",
413
+ className: "h-7 w-7",
414
+ onClick: onMoreOptions,
415
+ "aria-label": "More options",
416
+ children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_lucide_react2.MoreVertical, { className: "h-4 w-4" })
417
+ }
418
+ )
419
+ ] })
420
+ ] }),
421
+ appointment !== void 0 && /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_jsx_runtime5.Fragment, { children: [
422
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(Separator, {}),
423
+ appointment ? (
424
+ /* Has appointment */
425
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
426
+ "div",
427
+ {
428
+ className: `flex items-center gap-3 px-4 py-3 ${STRIP_BG[appointment.status]}`,
429
+ children: [
430
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_lucide_react2.CalendarCheck, { className: "h-4 w-4 shrink-0 text-muted-foreground" }),
431
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex min-w-0 flex-1 flex-col gap-0.5", children: [
432
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex items-center gap-2", children: [
433
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
434
+ Badge,
435
+ {
436
+ variant: STATUS_VARIANT[appointment.status],
437
+ className: "text-[10px]",
438
+ children: STATUS_LABEL[appointment.status]
439
+ }
440
+ ),
441
+ appointment.appointmentType && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("span", { className: "truncate text-xs text-muted-foreground", children: appointment.appointmentType })
442
+ ] }),
443
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("p", { className: "text-xs text-muted-foreground", children: [
444
+ appointment.date,
445
+ " \xB7 ",
446
+ appointment.timeStart,
447
+ "\u2013",
448
+ appointment.timeEnd
449
+ ] })
450
+ ] }),
451
+ onViewAppointment && /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(
452
+ Button,
453
+ {
454
+ variant: "ghost",
455
+ size: "sm",
456
+ className: "h-7 shrink-0 gap-1 px-2 text-xs",
457
+ onClick: onViewAppointment,
458
+ children: [
459
+ "View",
460
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_lucide_react2.ChevronRight, { className: "h-3 w-3" })
461
+ ]
462
+ }
463
+ )
464
+ ]
465
+ }
466
+ )
467
+ ) : (
468
+ /* No appointment */
469
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex items-center gap-3 px-4 py-3", children: [
470
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_lucide_react2.Calendar, { className: "h-4 w-4 shrink-0 text-muted-foreground" }),
471
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)("p", { className: "flex-1 text-xs text-muted-foreground", children: "No upcoming appointments" })
472
+ ] })
473
+ )
474
+ ] }),
475
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(Separator, {}),
476
+ /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)("div", { className: "flex items-center gap-2 px-4 py-3", children: [
477
+ onBookAppointment && /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(
478
+ Button,
479
+ {
480
+ variant: "outline-primary",
481
+ size: "sm",
482
+ onClick: onBookAppointment,
483
+ children: "Book Appointment"
484
+ }
485
+ ),
486
+ onRefer && /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(Button, { variant: "outline", size: "sm", onClick: onRefer, children: [
487
+ "Refer ",
488
+ name,
489
+ " to Others"
490
+ ] })
491
+ ] })
492
+ ] });
493
+ }
494
+ // Annotate the CommonJS export names for ESM import in node:
495
+ 0 && (module.exports = {
496
+ AdvisorCard
497
+ });
@@ -0,0 +1,13 @@
1
+ import {
2
+ AdvisorCard
3
+ } from "../../chunk-FNQXOAYJ.mjs";
4
+ import "../../chunk-24FUO7TD.mjs";
5
+ import "../../chunk-BKNFWEH2.mjs";
6
+ import "../../chunk-FH6QVUVZ.mjs";
7
+ import "../../chunk-XREGSKX3.mjs";
8
+ import "../../chunk-DBHJ5KC3.mjs";
9
+ import "../../chunk-VLQZANBF.mjs";
10
+ import "../../chunk-FWCSY2DS.mjs";
11
+ export {
12
+ AdvisorCard
13
+ };