@lerianstudio/sindarian-ui 1.0.0-beta.2 → 1.0.0-beta.20

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 (158) hide show
  1. package/dist/components/breadcrumb/index.js +2 -2
  2. package/dist/components/card/account-card/index.d.ts +32 -0
  3. package/dist/components/card/account-card/index.d.ts.map +1 -0
  4. package/dist/components/card/account-card/index.js +69 -0
  5. package/dist/components/card/basic-card/index.d.ts +6 -0
  6. package/dist/components/card/basic-card/index.d.ts.map +1 -0
  7. package/dist/components/card/basic-card/index.js +20 -0
  8. package/dist/components/card/dashboard-card/index.d.ts +5 -0
  9. package/dist/components/card/dashboard-card/index.d.ts.map +1 -0
  10. package/dist/components/card/dashboard-card/index.js +20 -0
  11. package/dist/components/card/entity-card/index.d.ts +21 -0
  12. package/dist/components/card/entity-card/index.d.ts.map +1 -0
  13. package/dist/components/card/entity-card/index.js +60 -0
  14. package/dist/components/card/index.d.ts +5 -0
  15. package/dist/components/card/index.d.ts.map +1 -0
  16. package/dist/components/card/index.js +20 -0
  17. package/dist/components/dialog/confirmation-dialog/index.d.ts +15 -0
  18. package/dist/components/dialog/confirmation-dialog/index.d.ts.map +1 -0
  19. package/dist/components/dialog/confirmation-dialog/index.js +28 -0
  20. package/dist/components/dialog/confirmation-dialog/use-confirm-dialog.d.ts +31 -0
  21. package/dist/components/dialog/confirmation-dialog/use-confirm-dialog.d.ts.map +1 -0
  22. package/dist/components/dialog/confirmation-dialog/use-confirm-dialog.js +55 -0
  23. package/dist/components/dialog/index.d.ts +4 -0
  24. package/dist/components/dialog/index.d.ts.map +1 -0
  25. package/dist/components/dialog/index.js +19 -0
  26. package/dist/components/dialog/large-dialog/index.d.ts +11 -0
  27. package/dist/components/dialog/large-dialog/index.d.ts.map +1 -0
  28. package/dist/components/dialog/large-dialog/index.js +21 -0
  29. package/dist/components/form/input-field/index.d.ts +4 -1
  30. package/dist/components/form/input-field/index.d.ts.map +1 -1
  31. package/dist/components/form/input-field/index.js +3 -3
  32. package/dist/components/form/pagination-limit-field/index.d.ts +2 -1
  33. package/dist/components/form/pagination-limit-field/index.d.ts.map +1 -1
  34. package/dist/components/form/pagination-limit-field/index.js +2 -2
  35. package/dist/components/form/password-field/index.d.ts +5 -4
  36. package/dist/components/form/password-field/index.d.ts.map +1 -1
  37. package/dist/components/form/password-field/index.js +8 -7
  38. package/dist/components/form/select-field/index.d.ts +1 -0
  39. package/dist/components/form/select-field/index.d.ts.map +1 -1
  40. package/dist/components/form/select-field/index.js +1 -1
  41. package/dist/components/form/switch-field/index.d.ts +2 -1
  42. package/dist/components/form/switch-field/index.d.ts.map +1 -1
  43. package/dist/components/form/switch-field/index.js +2 -2
  44. package/dist/components/page/index.d.ts.map +1 -1
  45. package/dist/components/page/index.js +3 -3
  46. package/dist/components/page-header/index.js +1 -1
  47. package/dist/components/pagination/index.js +1 -1
  48. package/dist/components/table/id-table-cell.d.ts +3 -2
  49. package/dist/components/table/id-table-cell.d.ts.map +1 -1
  50. package/dist/components/table/id-table-cell.js +2 -2
  51. package/dist/components/table/locked-table-actions.js +1 -1
  52. package/dist/components/ui/alert/index.d.ts +5 -1
  53. package/dist/components/ui/alert/index.d.ts.map +1 -1
  54. package/dist/components/ui/alert/index.js +22 -8
  55. package/dist/components/ui/alert/styles.css +68 -0
  56. package/dist/components/ui/badge/index.d.ts +1 -1
  57. package/dist/components/ui/breadcrumb/index.d.ts.map +1 -1
  58. package/dist/components/ui/breadcrumb/index.js +5 -5
  59. package/dist/components/ui/breadcrumb/styles.css +27 -0
  60. package/dist/components/ui/button/index.d.ts +8 -3
  61. package/dist/components/ui/button/index.d.ts.map +1 -1
  62. package/dist/components/ui/button/index.js +21 -29
  63. package/dist/components/ui/button/styles.css +64 -0
  64. package/dist/components/ui/card/index.js +1 -1
  65. package/dist/components/ui/dialog/index.d.ts.map +1 -1
  66. package/dist/components/ui/dialog/index.js +6 -6
  67. package/dist/components/ui/dialog/styles.css +34 -0
  68. package/dist/components/ui/form.d.ts.map +1 -1
  69. package/dist/components/ui/form.js +1 -0
  70. package/dist/components/ui/icon-button/index.d.ts +13 -0
  71. package/dist/components/ui/icon-button/index.d.ts.map +1 -0
  72. package/dist/components/ui/icon-button/index.js +35 -0
  73. package/dist/components/ui/icon-button/styles.css +33 -0
  74. package/dist/components/ui/input/adornment.d.ts +9 -0
  75. package/dist/components/ui/input/adornment.d.ts.map +1 -0
  76. package/dist/components/ui/input/adornment.js +21 -0
  77. package/dist/components/ui/input/index.d.ts +16 -2
  78. package/dist/components/ui/input/index.d.ts.map +1 -1
  79. package/dist/components/ui/input/index.js +90 -2
  80. package/dist/components/ui/input/styles.css +68 -0
  81. package/dist/components/ui/multiple-select/index.d.ts +6 -6
  82. package/dist/components/ui/paper-collapsible/index.d.ts +9 -0
  83. package/dist/components/ui/paper-collapsible/index.d.ts.map +1 -0
  84. package/dist/components/ui/paper-collapsible/index.js +24 -0
  85. package/dist/components/ui/progress/index.d.ts +1 -1
  86. package/dist/components/ui/progress/index.d.ts.map +1 -1
  87. package/dist/components/ui/select/index.d.ts +1 -2
  88. package/dist/components/ui/select/index.d.ts.map +1 -1
  89. package/dist/components/ui/select/index.js +9 -18
  90. package/dist/components/ui/select/styles.css +57 -0
  91. package/dist/components/ui/sidebar/index.d.ts +9 -0
  92. package/dist/components/ui/sidebar/index.d.ts.map +1 -0
  93. package/dist/components/ui/sidebar/index.js +24 -0
  94. package/dist/components/ui/sidebar/sidebar-back-button.d.ts +3 -0
  95. package/dist/components/ui/sidebar/sidebar-back-button.d.ts.map +1 -0
  96. package/dist/components/ui/sidebar/sidebar-back-button.js +11 -0
  97. package/dist/components/ui/sidebar/sidebar-components.d.ts +23 -0
  98. package/dist/components/ui/sidebar/sidebar-components.d.ts.map +1 -0
  99. package/dist/components/ui/sidebar/sidebar-components.js +23 -0
  100. package/dist/components/ui/sidebar/sidebar-expand-button.d.ts +6 -0
  101. package/dist/components/ui/sidebar/sidebar-expand-button.d.ts.map +1 -0
  102. package/dist/components/ui/sidebar/sidebar-expand-button.js +19 -0
  103. package/dist/components/ui/sidebar/sidebar-item-button.d.ts +11 -0
  104. package/dist/components/ui/sidebar/sidebar-item-button.d.ts.map +1 -0
  105. package/dist/components/ui/sidebar/sidebar-item-button.js +23 -0
  106. package/dist/components/ui/sidebar/sidebar-item-icon-button.d.ts +11 -0
  107. package/dist/components/ui/sidebar/sidebar-item-icon-button.d.ts.map +1 -0
  108. package/dist/components/ui/sidebar/sidebar-item-icon-button.js +20 -0
  109. package/dist/components/ui/sidebar/sidebar-item.d.ts +12 -0
  110. package/dist/components/ui/sidebar/sidebar-item.d.ts.map +1 -0
  111. package/dist/components/ui/sidebar/sidebar-item.js +19 -0
  112. package/dist/components/ui/sidebar/sidebar-provider.d.ts +8 -0
  113. package/dist/components/ui/sidebar/sidebar-provider.d.ts.map +1 -0
  114. package/dist/components/ui/sidebar/sidebar-provider.js +28 -0
  115. package/dist/components/ui/sidebar/sidebar-root.d.ts +3 -0
  116. package/dist/components/ui/sidebar/sidebar-root.d.ts.map +1 -0
  117. package/dist/components/ui/sidebar/sidebar-root.js +24 -0
  118. package/dist/components/ui/stepper/index.d.ts.map +1 -1
  119. package/dist/components/ui/stepper/index.js +4 -4
  120. package/dist/components/ui/stepper/styles.css +41 -0
  121. package/dist/components/ui/tabs/index.d.ts.map +1 -1
  122. package/dist/components/ui/tabs/index.js +4 -4
  123. package/dist/components/ui/tabs/styles.css +31 -0
  124. package/dist/components/ui/toast/toaster.js +1 -1
  125. package/dist/globals.css +218 -0
  126. package/dist/hooks/use-time.d.ts +6 -0
  127. package/dist/hooks/use-time.d.ts.map +1 -0
  128. package/dist/hooks/use-time.js +20 -0
  129. package/dist/index.d.ts +6 -1
  130. package/dist/index.d.ts.map +1 -1
  131. package/dist/index.js +7 -1
  132. package/dist/lib/storage/get-storage-object.d.ts +2 -0
  133. package/dist/lib/storage/get-storage-object.d.ts.map +1 -0
  134. package/dist/lib/storage/get-storage-object.js +19 -0
  135. package/dist/lib/storage/get-storage.d.ts +2 -0
  136. package/dist/lib/storage/get-storage.d.ts.map +1 -0
  137. package/dist/lib/storage/get-storage.js +17 -0
  138. package/dist/lib/storage/index.d.ts +3 -0
  139. package/dist/lib/storage/index.d.ts.map +1 -0
  140. package/dist/lib/storage/index.js +18 -0
  141. package/dist/public/arm.gif +0 -0
  142. package/dist/public/clap.gif +0 -0
  143. package/dist/public/confetti-ball.gif +0 -0
  144. package/dist/public/countries.json +21200 -21200
  145. package/dist/public/dizzy.gif +0 -0
  146. package/dist/public/electricity.gif +0 -0
  147. package/dist/public/gear.gif +0 -0
  148. package/dist/public/gem.gif +0 -0
  149. package/dist/public/pencil.gif +0 -0
  150. package/dist/public/robot.gif +0 -0
  151. package/dist/public/rocket.gif +0 -0
  152. package/dist/public/software.gif +0 -0
  153. package/dist/public/solar-system.gif +0 -0
  154. package/dist/public/unicorn.gif +0 -0
  155. package/package.json +22 -19
  156. package/dist/components/ui/input-with-icon/index.d.ts +0 -12
  157. package/dist/components/ui/input-with-icon/index.d.ts.map +0 -1
  158. package/dist/components/ui/input-with-icon/index.js +0 -57
@@ -59,22 +59,14 @@ function SelectGroup({ ...props }) {
59
59
  function SelectValue({ ...props }) {
60
60
  return (0, jsx_runtime_1.jsx)(SelectPrimitive.Value, { "data-slot": "select-value", ...props });
61
61
  }
62
- function SelectTrigger({ className, size = 'default', children, ...props }) {
63
- return ((0, jsx_runtime_1.jsxs)(SelectPrimitive.Trigger, { "data-slot": "select-trigger", "data-size": size, className: (0, utils_1.cn)('bg-background ring-offset-background placeholder:text-shadcn-400 focus:ring-ring flex h-10 w-full items-center justify-between gap-3 rounded-md border border-[#C7C7C7] px-3 py-2 text-sm focus:ring-2 focus:ring-offset-0 focus:outline-hidden focus-visible:outline-hidden [&>span]:line-clamp-1', props.readOnly && [
64
- 'data-read-only:cursor-default',
65
- 'data-read-only:select-text',
66
- 'data-read-only:bg-zinc-100',
67
- 'data-read-only:opacity-50',
68
- 'data-read-only:pointer-events-none',
69
- 'data-read-only:focus:outline-hidden',
70
- 'data-read-only:focus:ring-0'
71
- ], 'disabled:cursor-not-allowed disabled:opacity-50', className), "data-read-only": props.readOnly ? '' : undefined, ...props, children: [children, !props.readOnly && ((0, jsx_runtime_1.jsx)(SelectPrimitive.Icon, { asChild: true, children: (0, jsx_runtime_1.jsx)(lucide_react_1.ChevronDown, { className: "size-4 opacity-50" }) }))] }));
62
+ function SelectTrigger({ className, readOnly, children, ...props }) {
63
+ return ((0, jsx_runtime_1.jsxs)(SelectPrimitive.Trigger, { "data-slot": "select-trigger", "data-size": "default", className: (0, utils_1.cn)('select-trigger select-read-only select-disabled', className), "aria-readonly": readOnly, "data-read-only": readOnly ? '' : undefined, ...props, children: [children, !readOnly && ((0, jsx_runtime_1.jsx)(SelectPrimitive.Icon, { asChild: true, children: (0, jsx_runtime_1.jsx)(lucide_react_1.ChevronDown, { className: "select-chevron" }) }))] }));
72
64
  }
73
65
  function SelectScrollUpButton({ className, ...props }) {
74
- return ((0, jsx_runtime_1.jsx)(SelectPrimitive.ScrollUpButton, { "data-slot": "select-scroll-up-button", className: (0, utils_1.cn)('flex cursor-default items-center justify-center py-1', className), ...props, children: (0, jsx_runtime_1.jsx)(lucide_react_1.ChevronUp, { className: "size-4" }) }));
66
+ return ((0, jsx_runtime_1.jsx)(SelectPrimitive.ScrollUpButton, { "data-slot": "select-scroll-up-button", className: (0, utils_1.cn)('select-scroll-button', className), ...props, children: (0, jsx_runtime_1.jsx)(lucide_react_1.ChevronUp, { className: "size-4" }) }));
75
67
  }
76
68
  function SelectScrollDownButton({ className, ...props }) {
77
- return ((0, jsx_runtime_1.jsx)(SelectPrimitive.ScrollDownButton, { "data-slot": "select-scroll-down-button", className: (0, utils_1.cn)('flex cursor-default items-center justify-center py-1', className), ...props, children: (0, jsx_runtime_1.jsx)(lucide_react_1.ChevronDown, { className: "size-4" }) }));
69
+ return ((0, jsx_runtime_1.jsx)(SelectPrimitive.ScrollDownButton, { "data-slot": "select-scroll-down-button", className: (0, utils_1.cn)('select-scroll-button', className), ...props, children: (0, jsx_runtime_1.jsx)(lucide_react_1.ChevronDown, { className: "size-4" }) }));
78
70
  }
79
71
  function SelectContent({ className, children, position = 'popper', ...props }) {
80
72
  const options = React.useMemo(() => React.Children.map(React.Children.toArray(children), (child) => {
@@ -83,19 +75,18 @@ function SelectContent({ className, children, position = 'popper', ...props }) {
83
75
  return child.props.value;
84
76
  }
85
77
  }), [children]);
86
- return ((0, jsx_runtime_1.jsx)(SelectPrimitive.Portal, { children: (0, jsx_runtime_1.jsxs)(SelectPrimitive.Content, { "data-slot": "select-content", "data-position": position, className: (0, utils_1.cn)('group/select bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 relative z-50 max-h-96 min-w-32 overflow-hidden rounded-md border shadow-md', position === 'popper' &&
87
- 'data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1', className), "data-empty": options.length === 0, position: position, ...props, children: [(0, jsx_runtime_1.jsx)(SelectScrollUpButton, {}), (0, jsx_runtime_1.jsx)(SelectPrimitive.Viewport, { className: (0, utils_1.cn)('p-1', position === 'popper' &&
78
+ return ((0, jsx_runtime_1.jsx)(SelectPrimitive.Portal, { children: (0, jsx_runtime_1.jsxs)(SelectPrimitive.Content, { "data-slot": "select-content", "data-position": position, className: (0, utils_1.cn)('group/select select-content', position === 'popper' && 'select-content-popper', className), "data-empty": options.length === 0, position: position, ...props, children: [(0, jsx_runtime_1.jsx)(SelectScrollUpButton, {}), (0, jsx_runtime_1.jsx)(SelectPrimitive.Viewport, { className: (0, utils_1.cn)('p-1', position === 'popper' &&
88
79
  'h-(--radix-select-trigger-height) w-full min-w-(--radix-select-trigger-width)'), children: children }), (0, jsx_runtime_1.jsx)(SelectScrollDownButton, {})] }) }));
89
80
  }
90
81
  function SelectEmpty({ className, ...props }) {
91
- return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "select-empty", className: (0, utils_1.cn)('text-muted-foreground hidden py-6 text-center text-sm group-data-[empty=true]/select:block', className), ...props }));
82
+ return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "select-empty", className: (0, utils_1.cn)('select-empty', className), ...props }));
92
83
  }
93
84
  function SelectLabel({ className, ...props }) {
94
- return ((0, jsx_runtime_1.jsx)(SelectPrimitive.Label, { "data-slot": "select-label", className: (0, utils_1.cn)('py-1.5 pr-8 pl-2 text-sm font-semibold', className), ...props }));
85
+ return ((0, jsx_runtime_1.jsx)(SelectPrimitive.Label, { "data-slot": "select-label", className: (0, utils_1.cn)('select-label', className), ...props }));
95
86
  }
96
87
  function SelectItem({ className, children, ...props }) {
97
- return ((0, jsx_runtime_1.jsxs)(SelectPrimitive.Item, { "data-slot": "select-item", className: (0, utils_1.cn)('focus:bg-accent focus:text-accent-foreground relative flex w-full cursor-default items-center rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-disabled:pointer-events-none data-disabled:opacity-50', className), ...props, children: [(0, jsx_runtime_1.jsx)("span", { className: "absolute right-2 flex h-3.5 w-3.5 items-center justify-center", children: (0, jsx_runtime_1.jsx)(SelectPrimitive.ItemIndicator, { children: (0, jsx_runtime_1.jsx)(lucide_react_1.Check, { className: "size-4" }) }) }), (0, jsx_runtime_1.jsx)(SelectPrimitive.ItemText, { children: children })] }));
88
+ return ((0, jsx_runtime_1.jsxs)(SelectPrimitive.Item, { "data-slot": "select-item", className: (0, utils_1.cn)('select-item', className), ...props, children: [(0, jsx_runtime_1.jsx)("span", { className: "absolute right-2 flex h-3.5 w-3.5 items-center justify-center", children: (0, jsx_runtime_1.jsx)(SelectPrimitive.ItemIndicator, { children: (0, jsx_runtime_1.jsx)(lucide_react_1.Check, { className: "size-4" }) }) }), (0, jsx_runtime_1.jsx)(SelectPrimitive.ItemText, { children: children })] }));
98
89
  }
99
90
  function SelectSeparator({ className, ...props }) {
100
- return ((0, jsx_runtime_1.jsx)(SelectPrimitive.Separator, { "data-slot": "select-separator", className: (0, utils_1.cn)('bg-muted -mx-1 my-1 h-px', className), ...props }));
91
+ return ((0, jsx_runtime_1.jsx)(SelectPrimitive.Separator, { "data-slot": "select-separator", className: (0, utils_1.cn)('select-separator', className), ...props }));
101
92
  }
@@ -0,0 +1,57 @@
1
+ @theme inline {
2
+ --spacing-select-h: calc(var(--spacing) * 10);
3
+ --spacing-select-px: calc(var(--spacing) * 3);
4
+ --spacing-select-py: calc(var(--spacing) * 2);
5
+
6
+ --color-select-foreground: var(--color-zinc-700);
7
+ --color-select-placeholder: var(--color-shadcn-400);
8
+ --color-select-border: var(--color-shadcn-300);
9
+ --color-select-chevron: var(--color-shadcn-400);
10
+ }
11
+
12
+ @layer components {
13
+ .select-trigger {
14
+ @apply flex items-center justify-between h-select-h w-full px-select-px py-select-py text-sm font-medium text-select-foreground border border-select-border rounded-md data-placeholder:text-select-placeholder focus:ring-2 focus:ring-offset-0 focus:outline-hidden focus-visible:outline-hidden;
15
+ }
16
+
17
+ .select-read-only {
18
+ @apply data-read-only:cursor-default data-read-only:select-text data-read-only:bg-zinc-100 data-read-only:opacity-50 data-read-only:pointer-events-none data-read-only:focus:outline-hidden data-read-only:focus:ring-0;
19
+ }
20
+
21
+ .select-disabled {
22
+ @apply disabled:cursor-not-allowed disabled:opacity-50;
23
+ }
24
+
25
+ .select-chevron {
26
+ @apply text-select-chevron size-4;
27
+ }
28
+
29
+ .select-scroll-button {
30
+ @apply flex cursor-default items-center justify-center py-1;
31
+ }
32
+
33
+ .select-content {
34
+ @apply bg-popover text-popover-foreground relative z-50 max-h-96 min-w-32 overflow-hidden rounded-md border shadow-md;
35
+ @apply data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2;
36
+ }
37
+
38
+ .select-content-popper {
39
+ @apply data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1;
40
+ }
41
+
42
+ .select-empty {
43
+ @apply text-muted-foreground hidden py-6 text-center text-sm group-data-[empty=true]/select:block;
44
+ }
45
+
46
+ .select-label {
47
+ @apply py-1.5 pr-8 pl-2 text-sm font-semibold;
48
+ }
49
+
50
+ .select-item {
51
+ @apply focus:bg-accent focus:text-accent-foreground relative flex w-full cursor-default items-center rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-disabled:pointer-events-none data-disabled:opacity-50;
52
+ }
53
+
54
+ .select-separator {
55
+ @apply bg-muted -mx-1 my-1 h-px;
56
+ }
57
+ }
@@ -0,0 +1,9 @@
1
+ export * from './sidebar-root';
2
+ export * from './sidebar-components';
3
+ export * from './sidebar-item-icon-button';
4
+ export * from './sidebar-item-button';
5
+ export * from './sidebar-item';
6
+ export * from './sidebar-expand-button';
7
+ export * from './sidebar-back-button';
8
+ export * from './sidebar-provider';
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/index.tsx"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA;AAC9B,cAAc,sBAAsB,CAAA;AACpC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,uBAAuB,CAAA;AACrC,cAAc,gBAAgB,CAAA;AAC9B,cAAc,yBAAyB,CAAA;AACvC,cAAc,uBAAuB,CAAA;AACrC,cAAc,oBAAoB,CAAA"}
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./sidebar-root"), exports);
18
+ __exportStar(require("./sidebar-components"), exports);
19
+ __exportStar(require("./sidebar-item-icon-button"), exports);
20
+ __exportStar(require("./sidebar-item-button"), exports);
21
+ __exportStar(require("./sidebar-item"), exports);
22
+ __exportStar(require("./sidebar-expand-button"), exports);
23
+ __exportStar(require("./sidebar-back-button"), exports);
24
+ __exportStar(require("./sidebar-provider"), exports);
@@ -0,0 +1,3 @@
1
+ import { SidebarItem } from './sidebar-item';
2
+ export declare function SidebarBackButton({ ...props }: React.ComponentProps<typeof SidebarItem>): import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=sidebar-back-button.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-back-button.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-back-button.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAI5C,wBAAgB,iBAAiB,CAAC,EAChC,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,WAAW,CAAC,2CAS1C"}
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SidebarBackButton = SidebarBackButton;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const sidebar_item_1 = require("./sidebar-item");
6
+ const separator_1 = require("../separator");
7
+ const sidebar_provider_1 = require("./sidebar-provider");
8
+ function SidebarBackButton({ ...props }) {
9
+ const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
10
+ return ((0, jsx_runtime_1.jsxs)("div", { className: "flex w-full flex-col gap-1.5 pt-1.5", children: [(0, jsx_runtime_1.jsx)(sidebar_item_1.SidebarItem, { ...props }), isCollapsed && (0, jsx_runtime_1.jsx)(separator_1.Separator, {})] }));
11
+ }
@@ -0,0 +1,23 @@
1
+ import React from 'react';
2
+ export type SidebarHeaderProps = React.ComponentProps<'div'> & {
3
+ className?: string;
4
+ collapsed?: boolean;
5
+ };
6
+ export declare const SidebarHeader: ({ className, collapsed, ...props }: SidebarHeaderProps) => import("react/jsx-runtime").JSX.Element;
7
+ export type SidebarContentProps = React.ComponentProps<'div'> & {
8
+ className?: string;
9
+ };
10
+ export declare const SidebarContent: ({ className, ...props }: SidebarContentProps) => import("react/jsx-runtime").JSX.Element;
11
+ export type SidebarGroupProps = {
12
+ className?: string;
13
+ } & React.ComponentProps<'nav'>;
14
+ export declare const SidebarGroup: ({ className, ...props }: SidebarGroupProps) => import("react/jsx-runtime").JSX.Element;
15
+ export type SidebarGroupTitleProps = React.PropsWithChildren & {
16
+ collapsed?: boolean;
17
+ };
18
+ export declare const SidebarGroupTitle: ({ children }: SidebarGroupTitleProps) => import("react/jsx-runtime").JSX.Element;
19
+ export type SidebarFooterProps = {
20
+ className?: string;
21
+ } & React.ComponentProps<'nav'>;
22
+ export declare const SidebarFooter: ({ className, ...props }: SidebarFooterProps) => import("react/jsx-runtime").JSX.Element;
23
+ //# sourceMappingURL=sidebar-components.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-components.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-components.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAKzB,MAAM,MAAM,kBAAkB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG;IAC7D,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,CAAA;AAED,eAAO,MAAM,aAAa,GAAI,oCAI3B,kBAAkB,4CAWpB,CAAA;AAED,MAAM,MAAM,mBAAmB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG;IAC9D,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,cAAc,GAAI,yBAG5B,mBAAmB,4CAUrB,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAA;AAE/B,eAAO,MAAM,YAAY,GAAI,yBAAyB,iBAAiB,4CAUtE,CAAA;AAED,MAAM,MAAM,sBAAsB,GAAG,KAAK,CAAC,iBAAiB,GAAG;IAC7D,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,CAAA;AAED,eAAO,MAAM,iBAAiB,GAAI,cAAc,sBAAsB,4CAcrE,CAAA;AAED,MAAM,MAAM,kBAAkB,GAAG;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAA;AAE/B,eAAO,MAAM,aAAa,GAAI,yBAAyB,kBAAkB,4CASxE,CAAA"}
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SidebarFooter = exports.SidebarGroupTitle = exports.SidebarGroup = exports.SidebarContent = exports.SidebarHeader = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const utils_1 = require("../../../lib/utils");
6
+ const sidebar_provider_1 = require("./sidebar-provider");
7
+ const separator_1 = require("../separator");
8
+ const SidebarHeader = ({ className, collapsed, ...props }) => ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-header", "data-collapsed": collapsed, className: (0, utils_1.cn)('dark:bg-cod-gray-950 flex h-[60px] w-full items-center bg-white px-4', collapsed && 'justify-center p-0', className), ...props }));
9
+ exports.SidebarHeader = SidebarHeader;
10
+ const SidebarContent = ({ className, ...props }) => ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-content", className: (0, utils_1.cn)('group flex flex-1 flex-col gap-4 overflow-hidden bg-white px-4 pt-4 transition-all duration-300 ease-in-out', 'group-data-[collapsed=true]/sidebar:items-center group-data-[collapsed=true]/sidebar:px-2', className), ...props }));
11
+ exports.SidebarContent = SidebarContent;
12
+ const SidebarGroup = ({ className, ...props }) => ((0, jsx_runtime_1.jsx)("nav", { "data-slot": "sidebar-group", className: (0, utils_1.cn)('grid gap-1', 'group-data[collapsed=true]/sidebar:justify-center', className), ...props }));
13
+ exports.SidebarGroup = SidebarGroup;
14
+ const SidebarGroupTitle = ({ children }) => {
15
+ const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
16
+ if (isCollapsed) {
17
+ return (0, jsx_runtime_1.jsx)(separator_1.Separator, {});
18
+ }
19
+ return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-group-title", className: "my-2 px-2", children: (0, jsx_runtime_1.jsx)("p", { className: "text-xs font-semibold tracking-[1.1px] text-zinc-500 uppercase", children: children }) }));
20
+ };
21
+ exports.SidebarGroupTitle = SidebarGroupTitle;
22
+ const SidebarFooter = ({ className, ...props }) => ((0, jsx_runtime_1.jsx)("nav", { "data-slot": "sidebar-footer", className: (0, utils_1.cn)('border-shadcn-200 flex w-full justify-center border-t bg-white p-4', className), ...props }));
23
+ exports.SidebarFooter = SidebarFooter;
@@ -0,0 +1,6 @@
1
+ type SidebarExpandButtonProps = {
2
+ tooltip?: string;
3
+ };
4
+ export declare const SidebarExpandButton: ({ tooltip }: SidebarExpandButtonProps) => import("react/jsx-runtime").JSX.Element;
5
+ export {};
6
+ //# sourceMappingURL=sidebar-expand-button.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-expand-button.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-expand-button.tsx"],"names":[],"mappings":"AAcA,KAAK,wBAAwB,GAAG;IAC9B,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,mBAAmB,GAAI,aAAa,wBAAwB,4CAqCxE,CAAA"}
@@ -0,0 +1,19 @@
1
+ 'use client';
2
+ "use strict";
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.SidebarExpandButton = void 0;
8
+ const jsx_runtime_1 = require("react/jsx-runtime");
9
+ const react_1 = __importDefault(require("react"));
10
+ const lucide_react_1 = require("lucide-react");
11
+ const sidebar_provider_1 = require("./sidebar-provider");
12
+ const sidebar_components_1 = require("./sidebar-components");
13
+ const tooltip_1 = require("../../ui/tooltip");
14
+ const icon_button_1 = require("../icon-button");
15
+ const SidebarExpandButton = ({ tooltip }) => {
16
+ const { isCollapsed, toggleSidebar } = (0, sidebar_provider_1.useSidebar)();
17
+ return ((0, jsx_runtime_1.jsxs)(react_1.default.Fragment, { children: [!isCollapsed && ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-expand-button", className: "border-shadcn-200 flex w-full bg-white", children: (0, jsx_runtime_1.jsx)("div", { className: "absolute right-[-20px] bottom-4", children: (0, jsx_runtime_1.jsx)(icon_button_1.IconButton, { variant: "secondary", rounded: true, onClick: toggleSidebar, children: (0, jsx_runtime_1.jsx)(lucide_react_1.PanelLeftClose, { className: "text-shadcn-400" }) }) }) })), isCollapsed && ((0, jsx_runtime_1.jsx)(sidebar_components_1.SidebarFooter, { children: (0, jsx_runtime_1.jsx)(tooltip_1.TooltipProvider, { children: (0, jsx_runtime_1.jsxs)(tooltip_1.Tooltip, { children: [(0, jsx_runtime_1.jsx)(tooltip_1.TooltipTrigger, { className: "group/expand-button text-shadcn-400 hover:bg-accent rounded-sm bg-transparent p-2", onClick: toggleSidebar, children: (0, jsx_runtime_1.jsx)(lucide_react_1.PanelRightClose, { className: "group-hover/expand-button:text-white dark:text-white" }) }), (0, jsx_runtime_1.jsx)(tooltip_1.TooltipContent, { side: "right", children: tooltip || 'Expand' })] }) }) }))] }));
18
+ };
19
+ exports.SidebarExpandButton = SidebarExpandButton;
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ import Link from 'next/link';
3
+ export type SidebarItemButtonProps = React.ComponentProps<typeof Link> & {
4
+ className?: string;
5
+ title: string;
6
+ icon?: React.ReactNode;
7
+ active?: boolean;
8
+ disabled?: boolean;
9
+ };
10
+ export declare function SidebarItemButton({ className, title, icon, href, active, disabled, ...props }: SidebarItemButtonProps): import("react/jsx-runtime").JSX.Element;
11
+ //# sourceMappingURL=sidebar-item-button.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-item-button.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-item-button.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,IAAI,MAAM,WAAW,CAAA;AAI5B,MAAM,MAAM,sBAAsB,GAAG,KAAK,CAAC,cAAc,CAAC,OAAO,IAAI,CAAC,GAAG;IACvE,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,CAAA;IACtB,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,wBAAgB,iBAAiB,CAAC,EAChC,SAAS,EACT,KAAK,EACL,IAAI,EACJ,IAAI,EACJ,MAAM,EACN,QAAgB,EAChB,GAAG,KAAK,EACT,EAAE,sBAAsB,2CA2CxB"}
@@ -0,0 +1,23 @@
1
+ 'use client';
2
+ "use strict";
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.SidebarItemButton = SidebarItemButton;
8
+ const jsx_runtime_1 = require("react/jsx-runtime");
9
+ const link_1 = __importDefault(require("next/link"));
10
+ const button_1 = require("../../ui/button");
11
+ const utils_1 = require("../../../lib/utils");
12
+ function SidebarItemButton({ className, title, icon, href, active, disabled = false, ...props }) {
13
+ const sharedClassName = (0, utils_1.cn)((0, button_1.buttonVariants)({
14
+ variant: active ? 'tertiary' : 'outline',
15
+ fullWidth: true,
16
+ size: 'small'
17
+ }), 'group/link flex items-center justify-start', disabled && 'cursor-default opacity-30', className);
18
+ const content = ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [icon && ((0, jsx_runtime_1.jsx)("span", { className: (0, utils_1.cn)((0, button_1.iconVariants)({ position: 'start', size: 'small' })), children: icon })), title] }));
19
+ if (disabled) {
20
+ return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-item-button", className: sharedClassName, children: content }));
21
+ }
22
+ return ((0, jsx_runtime_1.jsx)(link_1.default, { "data-slot": "sidebar-item-button", href: href, className: sharedClassName, ...props, children: content }));
23
+ }
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ import Link from 'next/link';
3
+ type SidebarItemIconButtonProps = React.ComponentProps<typeof Link> & {
4
+ title: string;
5
+ icon: React.ReactNode;
6
+ active?: boolean;
7
+ disabled?: boolean;
8
+ };
9
+ export declare const SidebarItemIconButton: ({ title, icon, href, active, disabled, ...props }: SidebarItemIconButtonProps) => import("react/jsx-runtime").JSX.Element;
10
+ export {};
11
+ //# sourceMappingURL=sidebar-item-icon-button.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-item-icon-button.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-item-icon-button.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,IAAI,MAAM,WAAW,CAAA;AAW5B,KAAK,0BAA0B,GAAG,KAAK,CAAC,cAAc,CAAC,OAAO,IAAI,CAAC,GAAG;IACpE,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,EAAE,KAAK,CAAC,SAAS,CAAA;IACrB,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,qBAAqB,GAAI,mDAOnC,0BAA0B,4CAmC5B,CAAA"}
@@ -0,0 +1,20 @@
1
+ 'use client';
2
+ "use strict";
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.SidebarItemIconButton = void 0;
8
+ const jsx_runtime_1 = require("react/jsx-runtime");
9
+ const link_1 = __importDefault(require("next/link"));
10
+ const button_1 = require("../../ui/button");
11
+ const tooltip_1 = require("../../ui/tooltip");
12
+ const utils_1 = require("../../../lib/utils");
13
+ const icon_button_1 = require("../icon-button");
14
+ const SidebarItemIconButton = ({ title, icon, href, active, disabled, ...props }) => {
15
+ const sharedClassName = (0, utils_1.cn)((0, button_1.buttonVariants)({
16
+ variant: active ? 'tertiary' : 'outline'
17
+ }), (0, icon_button_1.iconButtonVariants)(), disabled && 'cursor-default opacity-30');
18
+ return ((0, jsx_runtime_1.jsx)(tooltip_1.TooltipProvider, { children: (0, jsx_runtime_1.jsxs)(tooltip_1.Tooltip, { delayDuration: 0, children: [(0, jsx_runtime_1.jsx)(tooltip_1.TooltipTrigger, { asChild: true, children: disabled ? ((0, jsx_runtime_1.jsx)("div", { "data-slot": "sidebar-item-icon-button", className: sharedClassName, children: icon })) : ((0, jsx_runtime_1.jsx)(link_1.default, { "data-slot": "sidebar-item-icon-button", href: href, className: sharedClassName, ...props, children: icon })) }), (0, jsx_runtime_1.jsx)(tooltip_1.TooltipContent, { side: "right", children: title })] }) }));
19
+ };
20
+ exports.SidebarItemIconButton = SidebarItemIconButton;
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ import { SidebarItemButton } from './sidebar-item-button';
3
+ import { SidebarItemIconButton } from './sidebar-item-icon-button';
4
+ export type SidebarItemProps = React.ComponentProps<typeof SidebarItemButton> & React.ComponentProps<typeof SidebarItemIconButton> & {
5
+ title: string;
6
+ icon: React.ReactNode;
7
+ href: string;
8
+ active?: boolean;
9
+ disabled?: boolean;
10
+ };
11
+ export declare const SidebarItem: ({ active, disabled, href, ...props }: SidebarItemProps) => import("react/jsx-runtime").JSX.Element;
12
+ //# sourceMappingURL=sidebar-item.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-item.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-item.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAA;AAGlE,MAAM,MAAM,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC,OAAO,iBAAiB,CAAC,GAC3E,KAAK,CAAC,cAAc,CAAC,OAAO,qBAAqB,CAAC,GAAG;IACnD,KAAK,EAAE,MAAM,CAAA;IACb,IAAI,EAAE,KAAK,CAAC,SAAS,CAAA;IACrB,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAEH,eAAO,MAAM,WAAW,GAAI,sCAKzB,gBAAgB,4CA2BlB,CAAA"}
@@ -0,0 +1,19 @@
1
+ 'use client';
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.SidebarItem = void 0;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const navigation_1 = require("next/navigation");
7
+ const sidebar_item_button_1 = require("./sidebar-item-button");
8
+ const sidebar_item_icon_button_1 = require("./sidebar-item-icon-button");
9
+ const sidebar_provider_1 = require("./sidebar-provider");
10
+ const SidebarItem = ({ active, disabled, href, ...props }) => {
11
+ const pathname = (0, navigation_1.usePathname)();
12
+ const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
13
+ const isActive = (href) => pathname === href;
14
+ if (isCollapsed) {
15
+ return ((0, jsx_runtime_1.jsx)(sidebar_item_icon_button_1.SidebarItemIconButton, { "data-slot": "sidebar-item", href: href, active: isActive(href) || active, disabled: disabled, ...props }));
16
+ }
17
+ return ((0, jsx_runtime_1.jsx)(sidebar_item_button_1.SidebarItemButton, { "data-slot": "sidebar-item", href: href, active: isActive(href) || active, disabled: disabled, ...props }));
18
+ };
19
+ exports.SidebarItem = SidebarItem;
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ export type SidebarContextProps = {
3
+ isCollapsed: boolean;
4
+ toggleSidebar: () => void;
5
+ };
6
+ export declare const useSidebar: () => SidebarContextProps;
7
+ export declare const SidebarProvider: ({ children }: React.PropsWithChildren) => import("react/jsx-runtime").JSX.Element;
8
+ //# sourceMappingURL=sidebar-provider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-provider.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-provider.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,MAAM,mBAAmB,GAAG;IAChC,WAAW,EAAE,OAAO,CAAA;IACpB,aAAa,EAAE,MAAM,IAAI,CAAA;CAC1B,CAAA;AAMD,eAAO,MAAM,UAAU,2BAMtB,CAAA;AAED,eAAO,MAAM,eAAe,GAAI,cAAc,KAAK,CAAC,iBAAiB,4CAgBpE,CAAA"}
@@ -0,0 +1,28 @@
1
+ 'use client';
2
+ "use strict";
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.SidebarProvider = exports.useSidebar = void 0;
8
+ const jsx_runtime_1 = require("react/jsx-runtime");
9
+ const storage_1 = require("../../../lib/storage");
10
+ const react_1 = __importDefault(require("react"));
11
+ const SidebarContext = react_1.default.createContext(undefined);
12
+ const useSidebar = () => {
13
+ const context = react_1.default.useContext(SidebarContext);
14
+ if (!context) {
15
+ throw new Error('useSidebar must be used within a SidebarProvider');
16
+ }
17
+ return context;
18
+ };
19
+ exports.useSidebar = useSidebar;
20
+ const SidebarProvider = ({ children }) => {
21
+ const [collapsed, setCollapsed] = react_1.default.useState((0, storage_1.getStorage)('sidebar-collapsed', false) === 'true');
22
+ const toggleSidebar = () => setCollapsed((collapsed) => !collapsed);
23
+ react_1.default.useEffect(() => {
24
+ localStorage.setItem('sidebar-collapsed', JSON.stringify(collapsed));
25
+ }, [collapsed]);
26
+ return ((0, jsx_runtime_1.jsx)(SidebarContext.Provider, { value: { isCollapsed: collapsed, toggleSidebar }, children: children }));
27
+ };
28
+ exports.SidebarProvider = SidebarProvider;
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ export declare const SidebarRoot: ({ className, ...props }: React.ComponentProps<"nav">) => import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=sidebar-root.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-root.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/sidebar/sidebar-root.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AAoBzB,eAAO,MAAM,WAAW,GAAI,yBAGzB,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,4CAW7B,CAAA"}
@@ -0,0 +1,24 @@
1
+ 'use client';
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.SidebarRoot = void 0;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const class_variance_authority_1 = require("class-variance-authority");
7
+ const sidebar_provider_1 = require("./sidebar-provider");
8
+ const utils_1 = require("../../../lib/utils");
9
+ const sidebarVariants = (0, class_variance_authority_1.cva)('group/sidebar shadow-sidebar dark:bg-cod-gray-950 relative flex flex-col transition-[width] duration-300 ease-in-out', {
10
+ variants: {
11
+ collapsed: {
12
+ true: 'w-[72px]',
13
+ false: 'w-[244px]'
14
+ }
15
+ },
16
+ defaultVariants: {
17
+ collapsed: false
18
+ }
19
+ });
20
+ const SidebarRoot = ({ className, ...props }) => {
21
+ const { isCollapsed } = (0, sidebar_provider_1.useSidebar)();
22
+ return ((0, jsx_runtime_1.jsx)("nav", { "data-slot": "sidebar-root", className: (0, utils_1.cn)(sidebarVariants({ collapsed: isCollapsed }), className), "data-collapsed": isCollapsed, ...props }));
23
+ };
24
+ exports.SidebarRoot = SidebarRoot;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/stepper/index.tsx"],"names":[],"mappings":"AAIA,wBAAgB,OAAO,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,2CAQ3E;AAED,MAAM,MAAM,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG;IAC3D,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,wBAAgB,WAAW,CAAC,EAC1B,SAAS,EACT,MAAc,EACd,QAAgB,EAChB,GAAG,KAAK,EACT,EAAE,gBAAgB,2CAalB;AAED,wBAAgB,iBAAiB,CAAC,EAChC,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,2CAa7B;AAED,MAAM,MAAM,oBAAoB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG;IAC/D,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB,CAAA;AAED,wBAAgB,eAAe,CAAC,EAC9B,SAAS,EACT,KAAK,EACL,WAAW,EACX,GAAG,KAAK,EACT,EAAE,oBAAoB,2CA2BtB;AAED,MAAM,MAAM,mBAAmB,GAAG,KAAK,CAAC,iBAAiB,GAAG;IAC1D,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,cAAc,GAAI,sBAAsB,mBAAmB,mDAEvE,CAAA;AAED,eAAO,MAAM,mBAAmB,+CAK/B,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/stepper/index.tsx"],"names":[],"mappings":"AAIA,wBAAgB,OAAO,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,2CAI3E;AAED,MAAM,MAAM,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG;IAC3D,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,wBAAgB,WAAW,CAAC,EAC1B,SAAS,EACT,MAAc,EACd,QAAgB,EAChB,GAAG,KAAK,EACT,EAAE,gBAAgB,2CAUlB;AAED,wBAAgB,iBAAiB,CAAC,EAChC,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,2CAQ7B;AAED,MAAM,MAAM,oBAAoB,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG;IAC/D,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB,CAAA;AAED,wBAAgB,eAAe,CAAC,EAC9B,SAAS,EACT,KAAK,EACL,WAAW,EACX,GAAG,KAAK,EACT,EAAE,oBAAoB,2CActB;AAED,MAAM,MAAM,mBAAmB,GAAG,KAAK,CAAC,iBAAiB,GAAG;IAC1D,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,cAAc,GAAI,sBAAsB,mBAAmB,mDAEvE,CAAA;AAED,eAAO,MAAM,mBAAmB,+CAK/B,CAAA"}
@@ -10,16 +10,16 @@ const utils_1 = require("../../../lib/utils");
10
10
  const lucide_react_1 = require("lucide-react");
11
11
  const skeleton_1 = require("../skeleton");
12
12
  function Stepper({ className, ...props }) {
13
- return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "stepper", className: (0, utils_1.cn)('flex flex-col gap-4', className), ...props }));
13
+ return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "stepper", className: (0, utils_1.cn)('stepper', className), ...props }));
14
14
  }
15
15
  function StepperItem({ className, active = false, complete = false, ...props }) {
16
- return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "stepper-item", "data-active": active, "data-complete": complete, className: (0, utils_1.cn)('group flex flex-row gap-3 data-[complete=true]:cursor-pointer', className), ...props }));
16
+ return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "stepper-item", "data-active": active, "data-complete": complete, className: (0, utils_1.cn)('group stepper-item', className), ...props }));
17
17
  }
18
18
  function StepperItemNumber({ className, ...props }) {
19
- return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "stepper-item-number", className: (0, utils_1.cn)('border-shadcn-400 text-shadcn-400 flex h-8 w-8 shrink-0 items-center justify-center rounded-full border text-sm font-medium', 'group-data-[active=true]:border-none group-data-[active=true]:bg-zinc-700 group-data-[active=true]:text-white', 'group-data-[complete=true]:border-none group-data-[complete=true]:bg-white group-data-[complete=true]:text-zinc-700', className), ...props }));
19
+ return ((0, jsx_runtime_1.jsx)("div", { "data-slot": "stepper-item-number", className: (0, utils_1.cn)('stepper-item-number', className), ...props }));
20
20
  }
21
21
  function StepperItemText({ className, title, description, ...props }) {
22
- return ((0, jsx_runtime_1.jsxs)("div", { "data-slot": "stepper-item-text", className: (0, utils_1.cn)('text-shadcn-400 flex flex-col text-sm font-medium', 'group-data-[active=true]:text-zinc-700', 'group-data-[complete=true]:text-zinc-700 group-data-[complete=true]:underline', className), ...props, children: [(0, jsx_runtime_1.jsxs)("div", { className: "flex h-8 items-center gap-3", children: [(0, jsx_runtime_1.jsx)("p", { children: title }), (0, jsx_runtime_1.jsx)(lucide_react_1.CircleCheck, { className: "text-green-600 group-data-[complete=false]:hidden", width: 16, height: 16 })] }), description && ((0, jsx_runtime_1.jsx)("p", { className: "text-xs text-zinc-500 group-data-[active=false]:hidden", children: description }))] }));
22
+ return ((0, jsx_runtime_1.jsxs)("div", { "data-slot": "stepper-item-text", className: (0, utils_1.cn)('stepper-item-text', className), ...props, children: [(0, jsx_runtime_1.jsxs)("div", { className: "stepper-item-title", children: [(0, jsx_runtime_1.jsx)("p", { children: title }), (0, jsx_runtime_1.jsx)(lucide_react_1.CircleCheck, { className: "stepper-item-icon", width: 16, height: 16 })] }), description && (0, jsx_runtime_1.jsx)("p", { className: "stepper-item-description", children: description })] }));
23
23
  }
24
24
  const StepperContent = ({ active, children }) => {
25
25
  return active ? (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: children }) : null;
@@ -0,0 +1,41 @@
1
+ @theme inline {
2
+ --color-stepper-item-text: var(--color-shadcn-400);
3
+ --color-stepper-item-active: var(--color-zinc-700);
4
+ --color-stepper-item-number: var(--color-shadcn-400);
5
+ --color-stepper-item-icon: var(--color-green-600);
6
+ --color-stepper-item-description: var(--color-zinc-500);
7
+ }
8
+
9
+ @layer components {
10
+ .stepper {
11
+ @apply flex flex-col gap-4;
12
+ }
13
+
14
+ .stepper-item {
15
+ @apply flex flex-row gap-3 data-[complete=true]:cursor-pointer;
16
+ }
17
+
18
+ .stepper-item-number {
19
+ @apply border-stepper-item-number text-stepper-item-number flex h-8 w-8 shrink-0 items-center justify-center rounded-full border text-sm font-medium;
20
+ @apply group-data-[active=true]:border-none group-data-[active=true]:bg-stepper-item-active group-data-[active=true]:text-white;
21
+ @apply group-data-[complete=true]:border-none group-data-[complete=true]:bg-white group-data-[complete=true]:text-stepper-item-active;
22
+ }
23
+
24
+ .stepper-item-text {
25
+ @apply text-stepper-item-text flex flex-col text-sm font-medium;
26
+ @apply group-data-[active=true]:text-stepper-item-active;
27
+ @apply group-data-[complete=true]:text-stepper-item-active group-data-[complete=true]:underline;
28
+ }
29
+
30
+ .stepper-item-title {
31
+ @apply flex h-8 items-center gap-3;
32
+ }
33
+
34
+ .stepper-item-icon {
35
+ @apply text-stepper-item-icon group-data-[complete=false]:hidden;
36
+ }
37
+
38
+ .stepper-item-description {
39
+ @apply text-xs text-stepper-item-description group-data-[active=false]:hidden;
40
+ }
41
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/tabs/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,KAAK,aAAa,MAAM,sBAAsB,CAAA;AAIrD,iBAAS,IAAI,CAAC,EACZ,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,aAAa,CAAC,IAAI,CAAC,2CAQjD;AAED,iBAAS,QAAQ,CAAC,EAChB,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,aAAa,CAAC,IAAI,CAAC,2CAWjD;AAED,iBAAS,WAAW,CAAC,EACnB,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,aAAa,CAAC,OAAO,CAAC,2CAWpD;AAED,iBAAS,WAAW,CAAC,EACnB,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,aAAa,CAAC,OAAO,CAAC,2CAWpD;AAED,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/ui/tabs/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,KAAK,aAAa,MAAM,sBAAsB,CAAA;AAIrD,iBAAS,IAAI,CAAC,EACZ,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,aAAa,CAAC,IAAI,CAAC,2CAQjD;AAED,iBAAS,QAAQ,CAAC,EAChB,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,aAAa,CAAC,IAAI,CAAC,2CAQjD;AAED,iBAAS,WAAW,CAAC,EACnB,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,aAAa,CAAC,OAAO,CAAC,2CAWpD;AAED,iBAAS,WAAW,CAAC,EACnB,SAAS,EACT,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,aAAa,CAAC,OAAO,CAAC,2CAQpD;AAED,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,WAAW,EAAE,CAAA"}
@@ -42,14 +42,14 @@ const jsx_runtime_1 = require("react/jsx-runtime");
42
42
  const TabsPrimitive = __importStar(require("@radix-ui/react-tabs"));
43
43
  const utils_1 = require("../../../lib/utils");
44
44
  function Tabs({ className, ...props }) {
45
- return ((0, jsx_runtime_1.jsx)(TabsPrimitive.Root, { "data-slot": "tabs", className: (0, utils_1.cn)('mt-6 w-full', className), ...props }));
45
+ return ((0, jsx_runtime_1.jsx)(TabsPrimitive.Root, { "data-slot": "tabs", className: (0, utils_1.cn)('tabs', className), ...props }));
46
46
  }
47
47
  function TabsList({ className, ...props }) {
48
- return ((0, jsx_runtime_1.jsx)(TabsPrimitive.List, { "data-slot": "tabs-list", className: (0, utils_1.cn)('flex h-10 items-center justify-start gap-4 rounded-md p-1 text-slate-500', className), ...props }));
48
+ return ((0, jsx_runtime_1.jsx)(TabsPrimitive.List, { "data-slot": "tabs-list", className: (0, utils_1.cn)('tabs-list', className), ...props }));
49
49
  }
50
50
  function TabsTrigger({ className, ...props }) {
51
- return ((0, jsx_runtime_1.jsx)(TabsPrimitive.Trigger, { "data-slot": "tabs-trigger", className: (0, utils_1.cn)('!focus-visible:outline-none !focus-visible:ring-2 !focus-visible:ring-slate-950 !focus-visible:ring-offset-2 text-shadcn-400 hover:text-shadcn-500 data-[state=active]:bg-accent data-[state=active]:text-accent-foreground inline-flex items-center justify-center rounded-md px-4 py-[10px] text-sm font-medium whitespace-nowrap ring-offset-white transition-all hover:bg-white disabled:pointer-events-none disabled:opacity-50 data-[state=active]:shadow-xs', className), ...props }));
51
+ return ((0, jsx_runtime_1.jsx)(TabsPrimitive.Trigger, { "data-slot": "tabs-trigger", className: (0, utils_1.cn)('!focus-visible:outline-none !focus-visible:ring-2 !focus-visible:ring-slate-950 !focus-visible:ring-offset-2 tabs-trigger tabs-trigger-disabled', className), ...props }));
52
52
  }
53
53
  function TabsContent({ className, ...props }) {
54
- return ((0, jsx_runtime_1.jsx)(TabsPrimitive.Content, { "data-slot": "tabs-content", className: (0, utils_1.cn)('mt-4 ring-offset-white focus-visible:ring-2 focus-visible:ring-slate-950 focus-visible:ring-offset-2 focus-visible:outline-hidden', className), ...props }));
54
+ return ((0, jsx_runtime_1.jsx)(TabsPrimitive.Content, { "data-slot": "tabs-content", className: (0, utils_1.cn)('tabs-content', className), ...props }));
55
55
  }
@@ -0,0 +1,31 @@
1
+ @theme inline {
2
+ --color-tabs-trigger-text: var(--color-shadcn-400);
3
+ --color-tabs-trigger-hover: var(--color-white);
4
+ --color-tabs-trigger-text-hover: var(--color-shadcn-500);
5
+ --color-tabs-trigger-active: var(--color-accent);
6
+ --color-tabs-trigger-text-active: var(--color-zinc-700);
7
+ }
8
+
9
+ @layer components {
10
+ .tabs {
11
+ @apply mt-6 w-full;
12
+ }
13
+
14
+ .tabs-list {
15
+ @apply flex h-10 items-center justify-start gap-4 rounded-md p-1;
16
+ }
17
+
18
+ .tabs-trigger {
19
+ @apply text-tabs-trigger-text hover:text-tabs-trigger-text-hover cursor-pointer inline-flex items-center justify-center rounded-lg px-4 py-2.5 text-sm font-medium whitespace-nowrap ring-offset-white transition-all hover:bg-tabs-trigger-hover;
20
+ @apply focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-slate-950 focus-visible:ring-offset-2;
21
+ @apply data-[state=active]:bg-tabs-trigger-active data-[state=active]:text-tabs-trigger-text-active;
22
+ }
23
+
24
+ .tabs-trigger-disabled {
25
+ @apply disabled:pointer-events-none disabled:opacity-50;
26
+ }
27
+
28
+ .tabs-content {
29
+ @apply mt-4 ring-offset-white focus-visible:ring-2 focus-visible:ring-slate-950 focus-visible:ring-offset-2 focus-visible:outline-hidden;
30
+ }
31
+ }