@wealthx/shadcn 1.5.9 → 1.5.11

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 (112) hide show
  1. package/.turbo/turbo-build.log +157 -157
  2. package/CHANGELOG.md +12 -0
  3. package/dist/{chunk-AANINK2B.mjs → chunk-2KNQZG5S.mjs} +1 -1
  4. package/dist/chunk-3KLJ4XRE.mjs +375 -0
  5. package/dist/{chunk-6U4NQGVM.mjs → chunk-4X4MGYHE.mjs} +2 -2
  6. package/dist/{chunk-CEEVYRQA.mjs → chunk-67DGIPQ4.mjs} +1 -1
  7. package/dist/{chunk-7UIL5UN3.mjs → chunk-7II6QRCZ.mjs} +1 -1
  8. package/dist/{chunk-W5QJ57PU.mjs → chunk-7LN5OGC2.mjs} +1 -1
  9. package/dist/{chunk-ZXEUBBHJ.mjs → chunk-7TMPOZDE.mjs} +1 -1
  10. package/dist/{chunk-AHSCWXYJ.mjs → chunk-AJUAJC5O.mjs} +1 -1
  11. package/dist/{chunk-3CGM3QXQ.mjs → chunk-AKWN5ZQG.mjs} +2 -2
  12. package/dist/{chunk-FRT3S72S.mjs → chunk-CQ7HKBEX.mjs} +1 -1
  13. package/dist/{chunk-E2BNCA6L.mjs → chunk-EHQL64B7.mjs} +1 -1
  14. package/dist/{chunk-2WCIORP7.mjs → chunk-EXI64H46.mjs} +1 -1
  15. package/dist/{chunk-BBXSNDS3.mjs → chunk-FQYFPHDO.mjs} +1 -1
  16. package/dist/{chunk-3VZ6CYY2.mjs → chunk-GAXNO4JB.mjs} +1 -1
  17. package/dist/{chunk-3WGFIFP6.mjs → chunk-I4P7RXAE.mjs} +1 -1
  18. package/dist/{chunk-TAFL4WDY.mjs → chunk-IODGRCQG.mjs} +17 -10
  19. package/dist/{chunk-GS47ZSSA.mjs → chunk-J7KQON2N.mjs} +20 -5
  20. package/dist/{chunk-IQGKOT7A.mjs → chunk-K35TFQUB.mjs} +1 -1
  21. package/dist/{chunk-4DO3WM7V.mjs → chunk-K4VWSDJJ.mjs} +1 -1
  22. package/dist/{chunk-KWD6GANL.mjs → chunk-MPA2HV5U.mjs} +1 -1
  23. package/dist/{chunk-5LZZYODG.mjs → chunk-QHAMVWDG.mjs} +19 -1
  24. package/dist/{chunk-XUCDPAVI.mjs → chunk-R6U246E4.mjs} +2 -2
  25. package/dist/{chunk-VCDGLN25.mjs → chunk-S6AYZJYO.mjs} +47 -21
  26. package/dist/{chunk-WL6WVV47.mjs → chunk-X6RC5UWB.mjs} +1 -1
  27. package/dist/{chunk-4BHDDLWK.mjs → chunk-XAS6KBIG.mjs} +2 -2
  28. package/dist/{chunk-VWZS32ZQ.mjs → chunk-XYWEGBAA.mjs} +1 -1
  29. package/dist/{chunk-54MTIKNC.mjs → chunk-YV7XF32X.mjs} +49 -24
  30. package/dist/{chunk-E5EDZQ5J.mjs → chunk-ZA44WICP.mjs} +1 -1
  31. package/dist/{chunk-54TRNCID.mjs → chunk-ZMTCMP2G.mjs} +8 -8
  32. package/dist/components/ui/advisor-card.js +144 -55
  33. package/dist/components/ui/advisor-card.mjs +5 -2
  34. package/dist/components/ui/agent-evaluation-toast.js +1 -1
  35. package/dist/components/ui/agent-evaluation-toast.mjs +2 -2
  36. package/dist/components/ui/ai-assistant-drawer.js +1 -1
  37. package/dist/components/ui/ai-assistant-drawer.mjs +2 -2
  38. package/dist/components/ui/ai-builder.js +1 -1
  39. package/dist/components/ui/ai-builder.mjs +2 -2
  40. package/dist/components/ui/ai-conversations.js +1 -1
  41. package/dist/components/ui/ai-conversations.mjs +3 -3
  42. package/dist/components/ui/appointment-action-dialogs.js +1 -1
  43. package/dist/components/ui/appointment-action-dialogs.mjs +3 -3
  44. package/dist/components/ui/appointment-book-dialog.js +19 -4
  45. package/dist/components/ui/appointment-book-dialog.mjs +3 -3
  46. package/dist/components/ui/appointment-calendar-view.js +17 -10
  47. package/dist/components/ui/appointment-calendar-view.mjs +2 -2
  48. package/dist/components/ui/appointment-detail-sheet.js +1 -1
  49. package/dist/components/ui/appointment-detail-sheet.mjs +4 -4
  50. package/dist/components/ui/appointment-gmail-connect.js +1 -1
  51. package/dist/components/ui/appointment-gmail-connect.mjs +2 -2
  52. package/dist/components/ui/appointment-time-slot-picker.js +1 -1
  53. package/dist/components/ui/appointment-time-slot-picker.mjs +2 -2
  54. package/dist/components/ui/appointment-upcoming-card.js +1 -1
  55. package/dist/components/ui/appointment-upcoming-card.mjs +3 -3
  56. package/dist/components/ui/badge.js +1 -1
  57. package/dist/components/ui/badge.mjs +1 -1
  58. package/dist/components/ui/chat-widget-primitives.js +1 -1
  59. package/dist/components/ui/chat-widget-primitives.mjs +2 -2
  60. package/dist/components/ui/chat-widget.js +1 -1
  61. package/dist/components/ui/chat-widget.mjs +3 -3
  62. package/dist/components/ui/chip.js +1 -1
  63. package/dist/components/ui/chip.mjs +2 -2
  64. package/dist/components/ui/contact-alert-dialog/index.js +19 -1
  65. package/dist/components/ui/contact-alert-dialog/index.mjs +1 -1
  66. package/dist/components/ui/dashboard-transactions-table.js +1 -1
  67. package/dist/components/ui/dashboard-transactions-table.mjs +2 -2
  68. package/dist/components/ui/financial-cards.js +1 -1
  69. package/dist/components/ui/financial-cards.mjs +2 -2
  70. package/dist/components/ui/financial-sections.js +1 -1
  71. package/dist/components/ui/financial-sections.mjs +3 -3
  72. package/dist/components/ui/income-summary-component.js +1 -1
  73. package/dist/components/ui/income-summary-component.mjs +1 -1
  74. package/dist/components/ui/integration-card.js +1 -1
  75. package/dist/components/ui/integration-card.mjs +2 -2
  76. package/dist/components/ui/kanban-column.js +46 -23
  77. package/dist/components/ui/kanban-column.mjs +4 -4
  78. package/dist/components/ui/loan-applicant-information.js +1 -1
  79. package/dist/components/ui/loan-applicant-information.mjs +1 -1
  80. package/dist/components/ui/loan-application-badge.js +1 -1
  81. package/dist/components/ui/loan-application-badge.mjs +2 -2
  82. package/dist/components/ui/opportunity-card.js +46 -23
  83. package/dist/components/ui/opportunity-card.mjs +3 -3
  84. package/dist/components/ui/opportunity-summary-tab.js +1 -1
  85. package/dist/components/ui/opportunity-summary-tab.mjs +3 -3
  86. package/dist/components/ui/pipeline-board.js +46 -23
  87. package/dist/components/ui/pipeline-board.mjs +5 -5
  88. package/dist/components/ui/pipeline-primitives.js +1 -1
  89. package/dist/components/ui/pipeline-primitives.mjs +2 -2
  90. package/dist/components/ui/property-asset-card.js +1 -1
  91. package/dist/components/ui/property-asset-card.mjs +1 -1
  92. package/dist/components/ui/resource-center.js +1 -1
  93. package/dist/components/ui/resource-center.mjs +2 -2
  94. package/dist/components/ui/share-details-dialog.js +326 -30
  95. package/dist/components/ui/share-details-dialog.mjs +4 -1
  96. package/dist/components/ui/stage-timeline.js +1 -1
  97. package/dist/components/ui/stage-timeline.mjs +3 -3
  98. package/dist/index.js +473 -197
  99. package/dist/index.mjs +44 -42
  100. package/dist/styles.css +1 -1
  101. package/package.json +1 -1
  102. package/src/components/index.tsx +4 -0
  103. package/src/components/ui/advisor-card.tsx +75 -25
  104. package/src/components/ui/appointment-book-dialog.tsx +26 -3
  105. package/src/components/ui/appointment-calendar-view.tsx +7 -6
  106. package/src/components/ui/appointment-time-slot-picker.tsx +1 -0
  107. package/src/components/ui/badge.tsx +1 -1
  108. package/src/components/ui/contact-alert-dialog/contact-alert-dialog.tsx +19 -1
  109. package/src/components/ui/opportunity-card.tsx +56 -20
  110. package/src/components/ui/share-details-dialog.tsx +251 -0
  111. package/src/styles/styles-css.ts +1 -1
  112. package/dist/chunk-OZ2R6ERP.mjs +0 -174
@@ -1,14 +1,14 @@
1
1
  import {
2
2
  AppointmentDetailSheet
3
- } from "../../chunk-XUCDPAVI.mjs";
4
- import "../../chunk-AANINK2B.mjs";
5
- import "../../chunk-FRT3S72S.mjs";
3
+ } from "../../chunk-R6U246E4.mjs";
4
+ import "../../chunk-2KNQZG5S.mjs";
5
+ import "../../chunk-CQ7HKBEX.mjs";
6
6
  import "../../chunk-NCMV3LTP.mjs";
7
7
  import "../../chunk-2GIYVERS.mjs";
8
8
  import "../../chunk-BS75ICOO.mjs";
9
9
  import "../../chunk-LI2CTS5O.mjs";
10
10
  import "../../chunk-H6NQTIF4.mjs";
11
- import "../../chunk-WL6WVV47.mjs";
11
+ import "../../chunk-X6RC5UWB.mjs";
12
12
  import "../../chunk-CEYEK3TI.mjs";
13
13
  import "../../chunk-FBNEIYSE.mjs";
14
14
  import "../../chunk-LHWJQNLG.mjs";
@@ -155,7 +155,7 @@ Slot.displayName = "Slot";
155
155
  // src/components/ui/badge.tsx
156
156
  var import_jsx_runtime = require("react/jsx-runtime");
157
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",
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-caption 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
159
  {
160
160
  variants: {
161
161
  variant: {
@@ -1,8 +1,8 @@
1
1
  import {
2
2
  AppointmentGmailConnect
3
- } from "../../chunk-ZXEUBBHJ.mjs";
3
+ } from "../../chunk-7TMPOZDE.mjs";
4
4
  import "../../chunk-2GIYVERS.mjs";
5
- import "../../chunk-WL6WVV47.mjs";
5
+ import "../../chunk-X6RC5UWB.mjs";
6
6
  import "../../chunk-LBTHZSBT.mjs";
7
7
  import "../../chunk-NOOEKOWY.mjs";
8
8
  import "../../chunk-R4HCRDU5.mjs";
@@ -153,7 +153,7 @@ Slot.displayName = "Slot";
153
153
  // src/components/ui/badge.tsx
154
154
  var import_jsx_runtime = require("react/jsx-runtime");
155
155
  var badgeVariants = (0, import_class_variance_authority.cva)(
156
- "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",
156
+ "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-caption 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",
157
157
  {
158
158
  variants: {
159
159
  variant: {
@@ -1,8 +1,8 @@
1
1
  import {
2
2
  AppointmentSlotSection,
3
3
  AppointmentTimeSlotPicker
4
- } from "../../chunk-FRT3S72S.mjs";
5
- import "../../chunk-WL6WVV47.mjs";
4
+ } from "../../chunk-CQ7HKBEX.mjs";
5
+ import "../../chunk-X6RC5UWB.mjs";
6
6
  import "../../chunk-6QAFGZC2.mjs";
7
7
  import "../../chunk-R4HCRDU5.mjs";
8
8
  import "../../chunk-AFML43VJ.mjs";
@@ -200,7 +200,7 @@ Slot.displayName = "Slot";
200
200
  // src/components/ui/badge.tsx
201
201
  var import_jsx_runtime2 = require("react/jsx-runtime");
202
202
  var badgeVariants = (0, import_class_variance_authority.cva)(
203
- "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",
203
+ "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-caption 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",
204
204
  {
205
205
  variants: {
206
206
  variant: {
@@ -1,12 +1,12 @@
1
1
  import {
2
2
  AppointmentUpcomingCard
3
- } from "../../chunk-4BHDDLWK.mjs";
4
- import "../../chunk-FRT3S72S.mjs";
3
+ } from "../../chunk-XAS6KBIG.mjs";
4
+ import "../../chunk-CQ7HKBEX.mjs";
5
5
  import "../../chunk-2GIYVERS.mjs";
6
6
  import "../../chunk-BS75ICOO.mjs";
7
7
  import "../../chunk-LI2CTS5O.mjs";
8
8
  import "../../chunk-H6NQTIF4.mjs";
9
- import "../../chunk-WL6WVV47.mjs";
9
+ import "../../chunk-X6RC5UWB.mjs";
10
10
  import "../../chunk-FBNEIYSE.mjs";
11
11
  import "../../chunk-LHWJQNLG.mjs";
12
12
  import "../../chunk-P7CEBZM6.mjs";
@@ -151,7 +151,7 @@ Slot.displayName = "Slot";
151
151
  // src/components/ui/badge.tsx
152
152
  var import_jsx_runtime = require("react/jsx-runtime");
153
153
  var badgeVariants = (0, import_class_variance_authority.cva)(
154
- "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",
154
+ "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-caption 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",
155
155
  {
156
156
  variants: {
157
157
  variant: {
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  Badge,
3
3
  badgeVariants
4
- } from "../../chunk-WL6WVV47.mjs";
4
+ } from "../../chunk-X6RC5UWB.mjs";
5
5
  import "../../chunk-R4HCRDU5.mjs";
6
6
  import "../../chunk-AFML43VJ.mjs";
7
7
  import "../../chunk-WNQUEZJF.mjs";
@@ -201,7 +201,7 @@ Slot.displayName = "Slot";
201
201
  // src/components/ui/badge.tsx
202
202
  var import_jsx_runtime2 = require("react/jsx-runtime");
203
203
  var badgeVariants = (0, import_class_variance_authority.cva)(
204
- "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",
204
+ "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-caption 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",
205
205
  {
206
206
  variants: {
207
207
  variant: {
@@ -4,9 +4,9 @@ import {
4
4
  ChatWidgetLauncher,
5
5
  ChatWidgetMessage,
6
6
  ChatWidgetTypingIndicator
7
- } from "../../chunk-BBXSNDS3.mjs";
7
+ } from "../../chunk-FQYFPHDO.mjs";
8
8
  import "../../chunk-H6NQTIF4.mjs";
9
- import "../../chunk-WL6WVV47.mjs";
9
+ import "../../chunk-X6RC5UWB.mjs";
10
10
  import "../../chunk-LBTHZSBT.mjs";
11
11
  import "../../chunk-NOOEKOWY.mjs";
12
12
  import "../../chunk-R4HCRDU5.mjs";
@@ -431,7 +431,7 @@ function AvatarFallback(_a) {
431
431
  var import_class_variance_authority3 = require("class-variance-authority");
432
432
  var import_jsx_runtime7 = require("react/jsx-runtime");
433
433
  var badgeVariants = (0, import_class_variance_authority3.cva)(
434
- "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",
434
+ "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-caption 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",
435
435
  {
436
436
  variants: {
437
437
  variant: {
@@ -6,12 +6,12 @@ import {
6
6
  ChatWidgetTopicGrid,
7
7
  ChatWidgetWindow,
8
8
  DEFAULT_CHAT_WIDGET_TOPICS
9
- } from "../../chunk-3WGFIFP6.mjs";
10
- import "../../chunk-BBXSNDS3.mjs";
9
+ } from "../../chunk-I4P7RXAE.mjs";
10
+ import "../../chunk-FQYFPHDO.mjs";
11
11
  import "../../chunk-MUV4EGDW.mjs";
12
12
  import "../../chunk-2GIYVERS.mjs";
13
13
  import "../../chunk-H6NQTIF4.mjs";
14
- import "../../chunk-WL6WVV47.mjs";
14
+ import "../../chunk-X6RC5UWB.mjs";
15
15
  import "../../chunk-P7CEBZM6.mjs";
16
16
  import "../../chunk-LBTHZSBT.mjs";
17
17
  import "../../chunk-NOOEKOWY.mjs";
@@ -233,7 +233,7 @@ var Button = (0, import_react.forwardRef)(function Button2(_a, ref) {
233
233
  var import_class_variance_authority2 = require("class-variance-authority");
234
234
  var import_jsx_runtime2 = require("react/jsx-runtime");
235
235
  var badgeVariants = (0, import_class_variance_authority2.cva)(
236
- "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",
236
+ "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-caption 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",
237
237
  {
238
238
  variants: {
239
239
  variant: {
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  Chip
3
- } from "../../chunk-KWD6GANL.mjs";
4
- import "../../chunk-WL6WVV47.mjs";
3
+ } from "../../chunk-MPA2HV5U.mjs";
4
+ import "../../chunk-X6RC5UWB.mjs";
5
5
  import "../../chunk-NOOEKOWY.mjs";
6
6
  import "../../chunk-R4HCRDU5.mjs";
7
7
  import "../../chunk-AFML43VJ.mjs";
@@ -69,6 +69,7 @@ module.exports = __toCommonJS(contact_alert_dialog_exports);
69
69
 
70
70
  // src/components/ui/contact-alert-dialog/contact-alert-dialog.tsx
71
71
  var React5 = __toESM(require("react"));
72
+ var import_lucide_react6 = require("lucide-react");
72
73
  var import_ui4 = require("@react-awesome-query-builder/ui");
73
74
 
74
75
  // src/components/ui/dialog.tsx
@@ -1718,7 +1719,24 @@ function ContactAlertDialog({
1718
1719
  size: "sm",
1719
1720
  value: severity,
1720
1721
  onValueChange: (v) => v && setSeverity(v),
1721
- children: ["NEED_ACTION", "WATCH", "HEALTHY"].map((s) => /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(ToggleGroupItem, { value: s, children: SEVERITY_LABELS[s] }, s))
1722
+ children: ["NEED_ACTION", "WATCH", "HEALTHY"].map((s) => /* @__PURE__ */ (0, import_jsx_runtime15.jsxs)(
1723
+ ToggleGroupItem,
1724
+ {
1725
+ value: s,
1726
+ className: cn(
1727
+ s === "NEED_ACTION" && "data-pressed:bg-destructive/10 data-pressed:inset-ring-destructive data-pressed:text-destructive-text data-pressed:hover:bg-destructive/10",
1728
+ s === "WATCH" && "data-pressed:bg-warning/10 data-pressed:inset-ring-warning data-pressed:text-warning-text data-pressed:hover:bg-warning/10",
1729
+ s === "HEALTHY" && "data-pressed:bg-info/10 data-pressed:inset-ring-info data-pressed:text-info-text data-pressed:hover:bg-info/10"
1730
+ ),
1731
+ children: [
1732
+ s === "NEED_ACTION" && /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(import_lucide_react6.AlertCircleIcon, { className: "size-3.5" }),
1733
+ s === "WATCH" && /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(import_lucide_react6.EyeIcon, { className: "size-3.5" }),
1734
+ s === "HEALTHY" && /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(import_lucide_react6.InfoIcon, { className: "size-3.5" }),
1735
+ SEVERITY_LABELS[s]
1736
+ ]
1737
+ },
1738
+ s
1739
+ ))
1722
1740
  }
1723
1741
  )
1724
1742
  ] }),
@@ -4,7 +4,7 @@ import {
4
4
  ContactAlertDialog,
5
5
  ContactAlertQueryBuilder,
6
6
  createAlertTree
7
- } from "../../../chunk-5LZZYODG.mjs";
7
+ } from "../../../chunk-QHAMVWDG.mjs";
8
8
  import "../../../chunk-7YI3HEBH.mjs";
9
9
  import "../../../chunk-MUV4EGDW.mjs";
10
10
  import "../../../chunk-IKXYTCSB.mjs";
@@ -312,7 +312,7 @@ function Spinner(_a) {
312
312
  var import_class_variance_authority3 = require("class-variance-authority");
313
313
  var import_jsx_runtime4 = require("react/jsx-runtime");
314
314
  var badgeVariants = (0, import_class_variance_authority3.cva)(
315
- "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",
315
+ "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-caption 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",
316
316
  {
317
317
  variants: {
318
318
  variant: {
@@ -3,7 +3,7 @@ import {
3
3
  } from "../../chunk-33VT74R4.mjs";
4
4
  import {
5
5
  Chip
6
- } from "../../chunk-KWD6GANL.mjs";
6
+ } from "../../chunk-MPA2HV5U.mjs";
7
7
  import {
8
8
  Spinner
9
9
  } from "../../chunk-JVMXMFBB.mjs";
@@ -17,7 +17,7 @@ import "../../chunk-PNSYFE3K.mjs";
17
17
  import "../../chunk-LI2CTS5O.mjs";
18
18
  import {
19
19
  Badge
20
- } from "../../chunk-WL6WVV47.mjs";
20
+ } from "../../chunk-X6RC5UWB.mjs";
21
21
  import {
22
22
  formatDateShort
23
23
  } from "../../chunk-LHWJQNLG.mjs";
@@ -177,7 +177,7 @@ Slot.displayName = "Slot";
177
177
  // src/components/ui/badge.tsx
178
178
  var import_jsx_runtime = require("react/jsx-runtime");
179
179
  var badgeVariants = (0, import_class_variance_authority.cva)(
180
- "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",
180
+ "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-caption 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",
181
181
  {
182
182
  variants: {
183
183
  variant: {
@@ -6,10 +6,10 @@ import {
6
6
  IncomeCard,
7
7
  OtherLiabilityCard,
8
8
  PropertyCard
9
- } from "../../chunk-W5QJ57PU.mjs";
9
+ } from "../../chunk-7LN5OGC2.mjs";
10
10
  import "../../chunk-DQB4EPIS.mjs";
11
11
  import "../../chunk-JTK6VJXY.mjs";
12
- import "../../chunk-WL6WVV47.mjs";
12
+ import "../../chunk-X6RC5UWB.mjs";
13
13
  import "../../chunk-LHWJQNLG.mjs";
14
14
  import "../../chunk-UNACI2YK.mjs";
15
15
  import "../../chunk-NOOEKOWY.mjs";
@@ -346,7 +346,7 @@ var import_date_fns = require("date-fns");
346
346
  var import_class_variance_authority2 = require("class-variance-authority");
347
347
  var import_jsx_runtime4 = require("react/jsx-runtime");
348
348
  var badgeVariants = (0, import_class_variance_authority2.cva)(
349
- "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",
349
+ "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-caption 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",
350
350
  {
351
351
  variants: {
352
352
  variant: {
@@ -7,12 +7,12 @@ import {
7
7
  LoanScenarioSection,
8
8
  OtherLiabilitiesSection,
9
9
  PropertyHoldingsSection
10
- } from "../../chunk-E2BNCA6L.mjs";
11
- import "../../chunk-W5QJ57PU.mjs";
10
+ } from "../../chunk-EHQL64B7.mjs";
11
+ import "../../chunk-7LN5OGC2.mjs";
12
12
  import "../../chunk-DQB4EPIS.mjs";
13
13
  import "../../chunk-JTK6VJXY.mjs";
14
14
  import "../../chunk-2GIYVERS.mjs";
15
- import "../../chunk-WL6WVV47.mjs";
15
+ import "../../chunk-X6RC5UWB.mjs";
16
16
  import "../../chunk-LHWJQNLG.mjs";
17
17
  import "../../chunk-UNACI2YK.mjs";
18
18
  import "../../chunk-NOOEKOWY.mjs";
@@ -248,7 +248,7 @@ var Button = (0, import_react.forwardRef)(function Button2(_a, ref) {
248
248
  var import_class_variance_authority2 = require("class-variance-authority");
249
249
  var import_jsx_runtime2 = require("react/jsx-runtime");
250
250
  var badgeVariants = (0, import_class_variance_authority2.cva)(
251
- "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",
251
+ "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-caption 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",
252
252
  {
253
253
  variants: {
254
254
  variant: {
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  Badge
3
- } from "../../chunk-WL6WVV47.mjs";
3
+ } from "../../chunk-X6RC5UWB.mjs";
4
4
  import {
5
5
  formatCurrency
6
6
  } from "../../chunk-MN5NYQCL.mjs";
@@ -156,7 +156,7 @@ Slot.displayName = "Slot";
156
156
  // src/components/ui/badge.tsx
157
157
  var import_jsx_runtime = require("react/jsx-runtime");
158
158
  var badgeVariants = (0, import_class_variance_authority.cva)(
159
- "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
+ "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-caption 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",
160
160
  {
161
161
  variants: {
162
162
  variant: {
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  IntegrationCard
3
- } from "../../chunk-CEEVYRQA.mjs";
4
- import "../../chunk-WL6WVV47.mjs";
3
+ } from "../../chunk-67DGIPQ4.mjs";
4
+ import "../../chunk-X6RC5UWB.mjs";
5
5
  import "../../chunk-NOOEKOWY.mjs";
6
6
  import "../../chunk-R4HCRDU5.mjs";
7
7
  import "../../chunk-AFML43VJ.mjs";
@@ -181,7 +181,7 @@ Slot.displayName = "Slot";
181
181
  // src/components/ui/badge.tsx
182
182
  var import_jsx_runtime2 = require("react/jsx-runtime");
183
183
  var badgeVariants = (0, import_class_variance_authority.cva)(
184
- "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",
184
+ "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-caption 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",
185
185
  {
186
186
  variants: {
187
187
  variant: {
@@ -1245,6 +1245,45 @@ function OpportunityCard({
1245
1245
  }
1246
1246
  );
1247
1247
  }
1248
+ function normalizeUrl(url) {
1249
+ return `https://${url.replace(/^https?:\/\//, "")}`;
1250
+ }
1251
+ function LoanApplicationLink({ url }) {
1252
+ const [copied, setCopied] = (0, import_react5.useState)(false);
1253
+ const href = normalizeUrl(url);
1254
+ function handleCopy() {
1255
+ navigator.clipboard.writeText(href).then(() => {
1256
+ setCopied(true);
1257
+ setTimeout(() => setCopied(false), 2e3);
1258
+ });
1259
+ }
1260
+ return /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("div", { className: "flex flex-col gap-1", children: [
1261
+ /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("p", { className: "text-caption text-muted-foreground", children: "Or the link below to fill out the loan application directly." }),
1262
+ /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("div", { className: "flex items-center gap-1.5", children: [
1263
+ /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_lucide_react6.Link2, { className: "size-4 shrink-0 text-muted-foreground" }),
1264
+ /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
1265
+ "a",
1266
+ {
1267
+ href,
1268
+ target: "_blank",
1269
+ rel: "noreferrer",
1270
+ className: "min-w-0 flex-1 truncate text-body-small text-primary underline-offset-2 hover:underline",
1271
+ children: url
1272
+ }
1273
+ ),
1274
+ /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
1275
+ "button",
1276
+ {
1277
+ type: "button",
1278
+ onClick: handleCopy,
1279
+ className: "shrink-0 rounded p-1 text-muted-foreground transition-colors hover:text-foreground",
1280
+ "aria-label": "Copy link",
1281
+ children: copied ? /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_lucide_react6.Check, { className: "size-4 text-success-text" }) : /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_lucide_react6.Copy, { className: "size-4" })
1282
+ }
1283
+ )
1284
+ ] })
1285
+ ] });
1286
+ }
1248
1287
  function LeadCard({
1249
1288
  customerName,
1250
1289
  customerPhone,
@@ -1267,13 +1306,13 @@ function LeadCard({
1267
1306
  children: [
1268
1307
  /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("div", { className: "flex items-start justify-between gap-2", children: [
1269
1308
  /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("div", { className: "flex min-w-0 flex-1 flex-col gap-1", children: [
1270
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("span", { className: "text-sm font-semibold text-foreground", children: customerName }),
1271
- customerPhone && /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("span", { className: "flex items-center gap-1.5 text-xs text-muted-foreground", children: [
1272
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_lucide_react6.Phone, { className: "size-3 shrink-0", "aria-hidden": "true" }),
1309
+ /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("span", { className: "text-label-medium text-foreground", children: customerName }),
1310
+ customerPhone && /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("span", { className: "flex items-center gap-1.5 text-caption text-muted-foreground", children: [
1311
+ /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_lucide_react6.Phone, { className: "size-3.5 shrink-0", "aria-hidden": "true" }),
1273
1312
  customerPhone
1274
1313
  ] }),
1275
- customerEmail && /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("span", { className: "flex items-center gap-1.5 text-xs text-muted-foreground", children: [
1276
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_lucide_react6.Mail, { className: "size-3 shrink-0", "aria-hidden": "true" }),
1314
+ customerEmail && /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("span", { className: "flex items-center gap-1.5 text-caption text-muted-foreground", children: [
1315
+ /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_lucide_react6.Mail, { className: "size-3.5 shrink-0", "aria-hidden": "true" }),
1277
1316
  /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("span", { className: "truncate", children: customerEmail })
1278
1317
  ] })
1279
1318
  ] }),
@@ -1312,23 +1351,7 @@ function LeadCard({
1312
1351
  children: "Send Loan Application Request"
1313
1352
  }
1314
1353
  ),
1315
- loanApplicationUrl && /* @__PURE__ */ (0, import_jsx_runtime12.jsxs)("p", { className: "text-xs text-muted-foreground", children: [
1316
- "Or the link below to fill out the loan application directly.",
1317
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)("br", {}),
1318
- /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(
1319
- "a",
1320
- {
1321
- href: `https://${loanApplicationUrl.replace(
1322
- /^https?:\/\//,
1323
- ""
1324
- )}`,
1325
- target: "_blank",
1326
- rel: "noreferrer",
1327
- className: "text-primary underline-offset-2 hover:underline",
1328
- children: loanApplicationUrl
1329
- }
1330
- )
1331
- ] })
1354
+ loanApplicationUrl && /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(LoanApplicationLink, { url: loanApplicationUrl })
1332
1355
  ] })
1333
1356
  ]
1334
1357
  }
@@ -1,15 +1,15 @@
1
1
  import {
2
2
  KanbanColumn
3
- } from "../../chunk-3CGM3QXQ.mjs";
4
- import "../../chunk-54MTIKNC.mjs";
5
- import "../../chunk-2WCIORP7.mjs";
3
+ } from "../../chunk-AKWN5ZQG.mjs";
4
+ import "../../chunk-YV7XF32X.mjs";
5
+ import "../../chunk-EXI64H46.mjs";
6
6
  import "../../chunk-JPGL36WQ.mjs";
7
7
  import "../../chunk-IKXYTCSB.mjs";
8
8
  import "../../chunk-JVMXMFBB.mjs";
9
9
  import "../../chunk-PNSYFE3K.mjs";
10
10
  import "../../chunk-H5DTKPJ2.mjs";
11
11
  import "../../chunk-2GIYVERS.mjs";
12
- import "../../chunk-WL6WVV47.mjs";
12
+ import "../../chunk-X6RC5UWB.mjs";
13
13
  import "../../chunk-LHWJQNLG.mjs";
14
14
  import "../../chunk-XYSRRDBH.mjs";
15
15
  import "../../chunk-FRCTOAKZ.mjs";
@@ -155,7 +155,7 @@ Slot.displayName = "Slot";
155
155
  // src/components/ui/badge.tsx
156
156
  var import_jsx_runtime = require("react/jsx-runtime");
157
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",
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-caption 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
159
  {
160
160
  variants: {
161
161
  variant: {
@@ -3,7 +3,7 @@ import {
3
3
  } from "../../chunk-3VDET466.mjs";
4
4
  import {
5
5
  Badge
6
- } from "../../chunk-WL6WVV47.mjs";
6
+ } from "../../chunk-X6RC5UWB.mjs";
7
7
  import {
8
8
  Button
9
9
  } from "../../chunk-NOOEKOWY.mjs";
@@ -153,7 +153,7 @@ Slot.displayName = "Slot";
153
153
  // src/components/ui/badge.tsx
154
154
  var import_jsx_runtime = require("react/jsx-runtime");
155
155
  var badgeVariants = (0, import_class_variance_authority.cva)(
156
- "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",
156
+ "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-caption 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",
157
157
  {
158
158
  variants: {
159
159
  variant: {
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  LoanApplicationBadge
3
- } from "../../chunk-4DO3WM7V.mjs";
4
- import "../../chunk-WL6WVV47.mjs";
3
+ } from "../../chunk-K4VWSDJJ.mjs";
4
+ import "../../chunk-X6RC5UWB.mjs";
5
5
  import "../../chunk-R4HCRDU5.mjs";
6
6
  import "../../chunk-AFML43VJ.mjs";
7
7
  import "../../chunk-WNQUEZJF.mjs";