@customafk/lunas-ui 0.0.2 → 0.0.3-b

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 (68) hide show
  1. package/dist/Atoms/AspectRatio/index.js +2 -0
  2. package/dist/Atoms/Avatar/index.js +3 -3
  3. package/dist/Atoms/Badge/index.js +2 -0
  4. package/dist/Atoms/Breadcrumb/index.js +7 -23
  5. package/dist/Atoms/Button/index.d.ts +2 -2
  6. package/dist/Atoms/Button/index.js +2 -0
  7. package/dist/Atoms/Card/index.js +2 -0
  8. package/dist/Atoms/Checkbox/index.d.ts +6 -0
  9. package/dist/Atoms/Checkbox/index.js +276 -0
  10. package/dist/Atoms/Command/index.d.ts +7 -7
  11. package/dist/Atoms/Command/index.js +39 -50
  12. package/dist/Atoms/Dialog/index.js +16 -31
  13. package/dist/Atoms/DropdownMenu/index.js +2 -0
  14. package/dist/Atoms/Form/index.js +32 -21
  15. package/dist/Atoms/Input/index.d.ts +5 -1
  16. package/dist/Atoms/Input/index.js +45 -543
  17. package/dist/Atoms/Label/index.js +2 -0
  18. package/dist/Atoms/MenuItem/index.d.ts +14 -0
  19. package/dist/Atoms/MenuItem/index.js +287 -0
  20. package/dist/Atoms/Money/index.js +2 -0
  21. package/dist/Atoms/Navbar/index.js +2 -0
  22. package/dist/Atoms/NavigationMenu/index.js +2 -0
  23. package/dist/Atoms/NumberInput/index.d.ts +7 -0
  24. package/dist/Atoms/NumberInput/index.js +321 -0
  25. package/dist/Atoms/Popover/index.d.ts +8 -0
  26. package/dist/Atoms/Popover/index.js +286 -0
  27. package/dist/Atoms/Progress/index.js +2 -0
  28. package/dist/Atoms/QuantityBtn/index.js +2 -0
  29. package/dist/Atoms/RadioGroup/index.d.ts +7 -0
  30. package/dist/Atoms/RadioGroup/index.js +285 -0
  31. package/dist/Atoms/ScrollBar/index.js +4 -2
  32. package/dist/Atoms/Select/index.js +2 -0
  33. package/dist/Atoms/Sheet/index.d.ts +29 -0
  34. package/dist/Atoms/Sheet/index.js +422 -0
  35. package/dist/Atoms/Slider/index.d.ts +6 -0
  36. package/dist/Atoms/Slider/index.js +286 -0
  37. package/dist/Atoms/SmallQuantityBtn/index.d.ts +9 -0
  38. package/dist/Atoms/SmallQuantityBtn/index.js +110 -0
  39. package/dist/Atoms/Switch/index.d.ts +6 -0
  40. package/dist/Atoms/Switch/index.js +293 -0
  41. package/dist/Atoms/Tabs/index.d.ts +9 -0
  42. package/dist/Atoms/Tabs/index.js +304 -0
  43. package/dist/Atoms/Textarea/index.d.ts +5 -0
  44. package/dist/Atoms/Textarea/index.js +283 -0
  45. package/dist/Atoms/Tooltip/index.d.ts +10 -0
  46. package/dist/Atoms/Tooltip/index.js +289 -0
  47. package/dist/Atoms/UserAvatar/index.d.ts +2 -2
  48. package/dist/Atoms/UserAvatar/index.js +24 -28
  49. package/dist/Atoms/XButton/index.d.ts +10 -0
  50. package/dist/Atoms/XButton/index.js +309 -0
  51. package/dist/Authentication/SignIn/index.d.ts +1 -1
  52. package/dist/Authentication/SignIn/index.js +129 -74
  53. package/dist/Authentication/SignUp/index.d.ts +5 -5
  54. package/dist/Authentication/SignUp/index.js +181 -110
  55. package/dist/Authentication/ThankYou/index.js +13 -4
  56. package/dist/Ecommerce/Categories/index.d.ts +33 -0
  57. package/dist/Ecommerce/Categories/index.js +1426 -0
  58. package/dist/Icons/index.d.ts +5 -3
  59. package/dist/Icons/index.js +126 -97
  60. package/dist/Molecules/AuthenForm/index.js +30 -21
  61. package/dist/Molecules/Search/index.js +46 -57
  62. package/dist/Molecules/UserDropdown/index.js +42 -33
  63. package/dist/Organisms/Header/index.d.ts +25 -3
  64. package/dist/Organisms/Header/index.js +585 -324
  65. package/dist/hooks/index.d.ts +1 -54
  66. package/dist/hooks/index.js +3 -127
  67. package/dist/{types-BgHhiNa-.d.ts → types-BlE003QY.d.ts} +1 -1
  68. package/package.json +85 -41
@@ -0,0 +1,287 @@
1
+ "use client";
2
+
3
+ // packages/Atoms/MenuItem/index.tsx
4
+ import { memo } from "react";
5
+
6
+ // packages/tailwindTheme.ts
7
+ var themes = {
8
+ spacing: {
9
+ 30: "7.5rem",
10
+ // 120px
11
+ 33: "8.25rem"
12
+ // 132px
13
+ },
14
+ colors: {
15
+ ui: {
16
+ white: "#ffffff",
17
+ "white-primary": "#ffffff",
18
+ "black-primary": "#111315",
19
+ "bg-white": "#FAFAFA",
20
+ primary: {
21
+ default: "#6C70F0",
22
+ 50: "#EEF2FF",
23
+ 100: "#E0E7FF",
24
+ 200: "#C8D2FD",
25
+ 300: "#A6B6FB",
26
+ 400: "#828EF7",
27
+ 500: "#6C70F0",
28
+ 600: "#5048E3",
29
+ 700: "#443AC8",
30
+ 800: "#3731A2",
31
+ 900: "#312F80",
32
+ 950: "#1F1C4A"
33
+ },
34
+ secondary: {
35
+ default: "#C170FF",
36
+ 50: "#F9F1FF",
37
+ 100: "#F3E2FF",
38
+ 200: "#ECD4FF",
39
+ 300: "#E0B8FF",
40
+ 400: "#D49BFF",
41
+ 500: "#C170FF",
42
+ 600: "#AE65E6",
43
+ 700: "#9A5ACC",
44
+ 800: "#874EB3",
45
+ 900: "#613880",
46
+ 950: "#3A224C"
47
+ },
48
+ tertiary: {
49
+ default: "#5B8CFF",
50
+ 50: "#EFF4FF",
51
+ 100: "#DEE8FF",
52
+ 200: "#CEDDFF",
53
+ 300: "#BDD1FF",
54
+ 400: "#7CA3FF",
55
+ 500: "#5B8CFF",
56
+ 600: "#527EE6",
57
+ 700: "#4062B3",
58
+ 800: "#2E4680",
59
+ 900: "#243866",
60
+ 950: "#1B2A4C"
61
+ },
62
+ destructive: {
63
+ default: "#EF4444",
64
+ 50: "#FEF2F2",
65
+ 100: "#FEE2E2",
66
+ 200: "#FECACA",
67
+ 300: "#FCA5A5",
68
+ 400: "#F87171",
69
+ 500: "#EF4444",
70
+ 600: "#DC2626",
71
+ 700: "#B91C1C",
72
+ 800: "#991B1B",
73
+ 900: "#7F1D1D",
74
+ 950: "#450A0A"
75
+ },
76
+ success: {
77
+ default: "#22c55e",
78
+ 50: "#f0fdf4",
79
+ 100: "#dcfce7",
80
+ 200: "#bbf7d0",
81
+ 300: "#86efac",
82
+ 400: "#4ade80",
83
+ 500: "#22c55e",
84
+ 600: "#16a34a",
85
+ 700: "#15803d",
86
+ 800: "#166534",
87
+ 900: "#14532d",
88
+ 950: "#052e16"
89
+ },
90
+ warn: {
91
+ default: "#f59e0b",
92
+ 50: "#fffbeb",
93
+ 100: "#fef3c7",
94
+ 200: "#fde68a",
95
+ 300: "#fcd34d",
96
+ 400: "#fbbf24",
97
+ 500: "#f59e0b",
98
+ 600: "#d97706",
99
+ 700: "#b45309",
100
+ 800: "#92400e",
101
+ 900: "#78350f",
102
+ 950: "#451a03"
103
+ },
104
+ text: {
105
+ black: "#09090b",
106
+ white: "#fafafa",
107
+ 50: "#fafafa",
108
+ 100: "#f4f4f5",
109
+ 200: "#e4e4e7",
110
+ 300: "#d4d4d8",
111
+ 400: "#a1a1aa",
112
+ 500: "#71717a",
113
+ 600: "#52525b",
114
+ 700: "#3f3f46",
115
+ 800: "#27272a",
116
+ 900: "#18181b",
117
+ 950: "#09090b"
118
+ },
119
+ surface: {
120
+ default: "#ffffff",
121
+ 50: "#ffffff",
122
+ 100: "#f5f5f5",
123
+ 200: "#e5e5e5",
124
+ 300: "#d4d4d4",
125
+ 400: "#a3a3a3",
126
+ 500: "#737373",
127
+ 600: "#525252",
128
+ 700: "#404040",
129
+ 800: "#262626",
130
+ 900: "#171717",
131
+ 950: "#0a0a0a"
132
+ },
133
+ border: {
134
+ default: "#64748B",
135
+ 50: "#f9fafb",
136
+ 100: "#f3f4f6",
137
+ 200: "#e5e7eb",
138
+ 300: "#d1d5db",
139
+ 400: "#9ca3af",
140
+ 500: "#64748B",
141
+ 600: "#475569",
142
+ 700: "#334155",
143
+ 800: "#1E293B",
144
+ 900: "#0F172A",
145
+ 950: "#020817"
146
+ },
147
+ // TEXT COLOR
148
+ "text-primary": "#111315",
149
+ "text-secondary": "#30353C",
150
+ "text-third": "#30353CCC",
151
+ "text-placeholder": "#11131566",
152
+ "text-white-placeholder": "#FDFDFD99",
153
+ "text-black": {
154
+ primary: "#19191B",
155
+ secondary: "#222325",
156
+ third: "#292A2E",
157
+ fourth: "#5F606A",
158
+ placeholder: "#B2B3BD"
159
+ },
160
+ "text-white": {
161
+ primary: "#FCFCFC",
162
+ secondary: "#F9F9F9",
163
+ third: "#D9D9D9"
164
+ },
165
+ // COLOR SPECIAL
166
+ "positive-flat": "#4ADE80",
167
+ "destruction-flat": "#EF4444",
168
+ "neutral-flat": "#BFDBFE",
169
+ rating: "#FDE047",
170
+ input: {
171
+ border: {
172
+ active: "#71717A",
173
+ disabled: "#D4D4D8"
174
+ },
175
+ bg: {
176
+ default: "#FDFDFD",
177
+ error: "#FEF2F2"
178
+ }
179
+ }
180
+ }
181
+ },
182
+ backgroundImage: {
183
+ "ui-bg-color": "linear-gradient(110deg, #9CD5F5 3.09%, #B1B8E6 33.47%, rgba(185, 155, 215, 0.90) 62.82%, #A293DF 84.45%, #878AEA 106.08%)",
184
+ "ui-bg-page": "radial-gradient(70.47% 70.47% at 50% 50%, #FDFDFD 0%, #F3F1FF 50%, #F1FCFF 100%)",
185
+ "ui-btn-primary": "linear-gradient(180deg, #828EF7 0%, #6C70F0 100%)",
186
+ "ui-btn-secondary": "linear-gradient(180deg, #4277EF 0%, #669BF4 100%)",
187
+ "ui-btn-accept": "linear-gradient(282deg, #30C36D 6.81%, #6BCD8A 93.19%)",
188
+ "ui-btn-destructive": "linear-gradient(282deg, #FF384A 7.07%, #FF5463 92.93%)",
189
+ "ui-status-bg-positive": "linear-gradient(0deg, #C4FFD8 0%, #68FF9D 100%)",
190
+ "ui-status-bg-negative": "linear-gradient(0deg, #FECACA 0%, #FF8F8F 100%)",
191
+ "ui-status-bg-neutral": "linear-gradient(0deg, #E1EBFF 0%, #C7E8FF 100%)",
192
+ "ui-status-order": "linear-gradient(282deg, #30C36D 6.81%, #6BCD8A 93.19%)",
193
+ "ui-status-out-of-stock": "linear-gradient(282deg, #FF384A 7.07%, #FF5463 92.93%)",
194
+ "ui-status-in-stock": "linear-gradient(282deg, #30A8FF 6.81%, #73BAED 93.19%)",
195
+ "ui-line": "linear-gradient(90deg, #D3D4FF 0%, #7587EA 50%, #AEC0FF 100%)"
196
+ },
197
+ boxShadow: {
198
+ "ui-sd-primary": "0 4px 20px 0 rgba(104, 109, 224, 0.5)",
199
+ "ui-sd-base": "0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06)",
200
+ "ui-sd-destructive": "0 10px 10px 0 rgba(255, 56, 74, 0.15)",
201
+ "ui-sd-accept": "0 10px 10px 0 rgba(46, 213, 115, 0.15)",
202
+ "ui-xl": "0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)",
203
+ "ui-soft": "0px 5px 12px 0px rgba(0, 67, 101, 0.08)",
204
+ "ui-muli": "0px 5px 50px 0px rgba(0, 67, 101, 0.08), 0px 2px 6px 0px rgba(130, 169, 188, 0.08)",
205
+ "ui-category-effect": "0px 4px 50px 0px rgba(0, 67, 101, 0.08)",
206
+ "ui-flat": "0px 0.25rem 0.625rem 0px rgba(99, 102, 241, 0.07)",
207
+ "ui-overlay": "0px 4px 4px 1px rgba(99, 102, 241, 0.04)",
208
+ "ui-sticky-nav": "0px 3px 12px -1px rgba(151, 71, 255, 0.07)",
209
+ "ui-dialog": "0px 8px 12px 0px rgba(99, 102, 241, 0.15)"
210
+ },
211
+ fontSize: {
212
+ "ui-h1": ["1.5rem", "2rem"],
213
+ "ui-h2": ["1.25rem", "1.75rem"],
214
+ "ui-h3": ["1.125rem", "1.75rem"],
215
+ "ui-p": ["1rem", "1.5rem"],
216
+ "ui-note": ["0.875rem", "1.25rem"],
217
+ "ui-small-note": ["0.75rem", "1rem"]
218
+ },
219
+ keyframes: {
220
+ "accordion-down": {
221
+ from: { height: "0" },
222
+ to: { height: "var(--radix-accordion-content-height)" }
223
+ },
224
+ "accordion-up": {
225
+ from: { height: "var(--radix-accordion-content-height)" },
226
+ to: { height: "0" }
227
+ }
228
+ },
229
+ animation: {
230
+ "accordion-down": "accordion-down 0.2s ease-out",
231
+ "accordion-up": "accordion-up 0.2s ease-out"
232
+ }
233
+ };
234
+ var tailwindTheme_default = themes;
235
+
236
+ // packages/libs/utils.ts
237
+ import clsx from "clsx";
238
+ import { extendTailwindMerge } from "tailwind-merge";
239
+ var customTailwindMerge = () => {
240
+ return extendTailwindMerge({
241
+ ...tailwindTheme_default,
242
+ prefix: ""
243
+ });
244
+ };
245
+ var cn = (...inputs) => {
246
+ const customTwMerge = customTailwindMerge();
247
+ return customTwMerge(clsx(inputs));
248
+ };
249
+
250
+ // packages/Atoms/MenuItem/index.tsx
251
+ import { jsx, jsxs } from "react/jsx-runtime";
252
+ var MenuItem = ({
253
+ isActive = false,
254
+ isDisabled = false,
255
+ name,
256
+ leftIcon,
257
+ rightIcon,
258
+ onClick
259
+ }) => {
260
+ return /* @__PURE__ */ jsx("li", { className: "w-full list-none", children: /* @__PURE__ */ jsxs(
261
+ "button",
262
+ {
263
+ "data-active": isActive,
264
+ disabled: isDisabled,
265
+ className: cn(
266
+ "flex w-full items-center justify-start gap-x-1 rounded-lg bg-ui-surface-50 px-3 py-2 !text-ui-note text-ui-text-700",
267
+ "disabled:opacity-30",
268
+ "disabled:cursor-not-allowed",
269
+ "enabled:hover:bg-ui-primary-50",
270
+ "enabled:data-[active=true]:font-semibold",
271
+ "enabled:data-[active=true]:text-ui-text-50",
272
+ "enabled:data-[active=true]:bg-ui-primary-500",
273
+ "transition duration-200"
274
+ ),
275
+ onClick,
276
+ children: [
277
+ leftIcon,
278
+ name,
279
+ rightIcon
280
+ ]
281
+ }
282
+ ) });
283
+ };
284
+ var MenuItem_default = memo(MenuItem);
285
+ export {
286
+ MenuItem_default as default
287
+ };
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  // packages/Atoms/Money/index.tsx
2
4
  import { useMemo } from "react";
3
5
 
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  // packages/Atoms/Navbar/index.tsx
2
4
  import { forwardRef, memo } from "react";
3
5
 
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  // packages/Atoms/NavigationMenu/index.tsx
2
4
  import { forwardRef } from "react";
3
5
 
@@ -0,0 +1,7 @@
1
+ import * as React from 'react';
2
+
3
+ declare const NumberInput: React.ForwardRefExoticComponent<Omit<React.ClassAttributes<HTMLInputElement> & React.InputHTMLAttributes<HTMLInputElement> & {
4
+ onValueChange?: (value: number) => void;
5
+ }, "ref"> & React.RefAttributes<HTMLInputElement>>;
6
+
7
+ export { NumberInput as default };
@@ -0,0 +1,321 @@
1
+ "use client";
2
+
3
+ // packages/Atoms/NumberInput/index.tsx
4
+ import {
5
+ forwardRef,
6
+ useCallback,
7
+ useMemo,
8
+ useRef,
9
+ useState
10
+ } from "react";
11
+
12
+ // packages/tailwindTheme.ts
13
+ var themes = {
14
+ spacing: {
15
+ 30: "7.5rem",
16
+ // 120px
17
+ 33: "8.25rem"
18
+ // 132px
19
+ },
20
+ colors: {
21
+ ui: {
22
+ white: "#ffffff",
23
+ "white-primary": "#ffffff",
24
+ "black-primary": "#111315",
25
+ "bg-white": "#FAFAFA",
26
+ primary: {
27
+ default: "#6C70F0",
28
+ 50: "#EEF2FF",
29
+ 100: "#E0E7FF",
30
+ 200: "#C8D2FD",
31
+ 300: "#A6B6FB",
32
+ 400: "#828EF7",
33
+ 500: "#6C70F0",
34
+ 600: "#5048E3",
35
+ 700: "#443AC8",
36
+ 800: "#3731A2",
37
+ 900: "#312F80",
38
+ 950: "#1F1C4A"
39
+ },
40
+ secondary: {
41
+ default: "#C170FF",
42
+ 50: "#F9F1FF",
43
+ 100: "#F3E2FF",
44
+ 200: "#ECD4FF",
45
+ 300: "#E0B8FF",
46
+ 400: "#D49BFF",
47
+ 500: "#C170FF",
48
+ 600: "#AE65E6",
49
+ 700: "#9A5ACC",
50
+ 800: "#874EB3",
51
+ 900: "#613880",
52
+ 950: "#3A224C"
53
+ },
54
+ tertiary: {
55
+ default: "#5B8CFF",
56
+ 50: "#EFF4FF",
57
+ 100: "#DEE8FF",
58
+ 200: "#CEDDFF",
59
+ 300: "#BDD1FF",
60
+ 400: "#7CA3FF",
61
+ 500: "#5B8CFF",
62
+ 600: "#527EE6",
63
+ 700: "#4062B3",
64
+ 800: "#2E4680",
65
+ 900: "#243866",
66
+ 950: "#1B2A4C"
67
+ },
68
+ destructive: {
69
+ default: "#EF4444",
70
+ 50: "#FEF2F2",
71
+ 100: "#FEE2E2",
72
+ 200: "#FECACA",
73
+ 300: "#FCA5A5",
74
+ 400: "#F87171",
75
+ 500: "#EF4444",
76
+ 600: "#DC2626",
77
+ 700: "#B91C1C",
78
+ 800: "#991B1B",
79
+ 900: "#7F1D1D",
80
+ 950: "#450A0A"
81
+ },
82
+ success: {
83
+ default: "#22c55e",
84
+ 50: "#f0fdf4",
85
+ 100: "#dcfce7",
86
+ 200: "#bbf7d0",
87
+ 300: "#86efac",
88
+ 400: "#4ade80",
89
+ 500: "#22c55e",
90
+ 600: "#16a34a",
91
+ 700: "#15803d",
92
+ 800: "#166534",
93
+ 900: "#14532d",
94
+ 950: "#052e16"
95
+ },
96
+ warn: {
97
+ default: "#f59e0b",
98
+ 50: "#fffbeb",
99
+ 100: "#fef3c7",
100
+ 200: "#fde68a",
101
+ 300: "#fcd34d",
102
+ 400: "#fbbf24",
103
+ 500: "#f59e0b",
104
+ 600: "#d97706",
105
+ 700: "#b45309",
106
+ 800: "#92400e",
107
+ 900: "#78350f",
108
+ 950: "#451a03"
109
+ },
110
+ text: {
111
+ black: "#09090b",
112
+ white: "#fafafa",
113
+ 50: "#fafafa",
114
+ 100: "#f4f4f5",
115
+ 200: "#e4e4e7",
116
+ 300: "#d4d4d8",
117
+ 400: "#a1a1aa",
118
+ 500: "#71717a",
119
+ 600: "#52525b",
120
+ 700: "#3f3f46",
121
+ 800: "#27272a",
122
+ 900: "#18181b",
123
+ 950: "#09090b"
124
+ },
125
+ surface: {
126
+ default: "#ffffff",
127
+ 50: "#ffffff",
128
+ 100: "#f5f5f5",
129
+ 200: "#e5e5e5",
130
+ 300: "#d4d4d4",
131
+ 400: "#a3a3a3",
132
+ 500: "#737373",
133
+ 600: "#525252",
134
+ 700: "#404040",
135
+ 800: "#262626",
136
+ 900: "#171717",
137
+ 950: "#0a0a0a"
138
+ },
139
+ border: {
140
+ default: "#64748B",
141
+ 50: "#f9fafb",
142
+ 100: "#f3f4f6",
143
+ 200: "#e5e7eb",
144
+ 300: "#d1d5db",
145
+ 400: "#9ca3af",
146
+ 500: "#64748B",
147
+ 600: "#475569",
148
+ 700: "#334155",
149
+ 800: "#1E293B",
150
+ 900: "#0F172A",
151
+ 950: "#020817"
152
+ },
153
+ // TEXT COLOR
154
+ "text-primary": "#111315",
155
+ "text-secondary": "#30353C",
156
+ "text-third": "#30353CCC",
157
+ "text-placeholder": "#11131566",
158
+ "text-white-placeholder": "#FDFDFD99",
159
+ "text-black": {
160
+ primary: "#19191B",
161
+ secondary: "#222325",
162
+ third: "#292A2E",
163
+ fourth: "#5F606A",
164
+ placeholder: "#B2B3BD"
165
+ },
166
+ "text-white": {
167
+ primary: "#FCFCFC",
168
+ secondary: "#F9F9F9",
169
+ third: "#D9D9D9"
170
+ },
171
+ // COLOR SPECIAL
172
+ "positive-flat": "#4ADE80",
173
+ "destruction-flat": "#EF4444",
174
+ "neutral-flat": "#BFDBFE",
175
+ rating: "#FDE047",
176
+ input: {
177
+ border: {
178
+ active: "#71717A",
179
+ disabled: "#D4D4D8"
180
+ },
181
+ bg: {
182
+ default: "#FDFDFD",
183
+ error: "#FEF2F2"
184
+ }
185
+ }
186
+ }
187
+ },
188
+ backgroundImage: {
189
+ "ui-bg-color": "linear-gradient(110deg, #9CD5F5 3.09%, #B1B8E6 33.47%, rgba(185, 155, 215, 0.90) 62.82%, #A293DF 84.45%, #878AEA 106.08%)",
190
+ "ui-bg-page": "radial-gradient(70.47% 70.47% at 50% 50%, #FDFDFD 0%, #F3F1FF 50%, #F1FCFF 100%)",
191
+ "ui-btn-primary": "linear-gradient(180deg, #828EF7 0%, #6C70F0 100%)",
192
+ "ui-btn-secondary": "linear-gradient(180deg, #4277EF 0%, #669BF4 100%)",
193
+ "ui-btn-accept": "linear-gradient(282deg, #30C36D 6.81%, #6BCD8A 93.19%)",
194
+ "ui-btn-destructive": "linear-gradient(282deg, #FF384A 7.07%, #FF5463 92.93%)",
195
+ "ui-status-bg-positive": "linear-gradient(0deg, #C4FFD8 0%, #68FF9D 100%)",
196
+ "ui-status-bg-negative": "linear-gradient(0deg, #FECACA 0%, #FF8F8F 100%)",
197
+ "ui-status-bg-neutral": "linear-gradient(0deg, #E1EBFF 0%, #C7E8FF 100%)",
198
+ "ui-status-order": "linear-gradient(282deg, #30C36D 6.81%, #6BCD8A 93.19%)",
199
+ "ui-status-out-of-stock": "linear-gradient(282deg, #FF384A 7.07%, #FF5463 92.93%)",
200
+ "ui-status-in-stock": "linear-gradient(282deg, #30A8FF 6.81%, #73BAED 93.19%)",
201
+ "ui-line": "linear-gradient(90deg, #D3D4FF 0%, #7587EA 50%, #AEC0FF 100%)"
202
+ },
203
+ boxShadow: {
204
+ "ui-sd-primary": "0 4px 20px 0 rgba(104, 109, 224, 0.5)",
205
+ "ui-sd-base": "0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06)",
206
+ "ui-sd-destructive": "0 10px 10px 0 rgba(255, 56, 74, 0.15)",
207
+ "ui-sd-accept": "0 10px 10px 0 rgba(46, 213, 115, 0.15)",
208
+ "ui-xl": "0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04)",
209
+ "ui-soft": "0px 5px 12px 0px rgba(0, 67, 101, 0.08)",
210
+ "ui-muli": "0px 5px 50px 0px rgba(0, 67, 101, 0.08), 0px 2px 6px 0px rgba(130, 169, 188, 0.08)",
211
+ "ui-category-effect": "0px 4px 50px 0px rgba(0, 67, 101, 0.08)",
212
+ "ui-flat": "0px 0.25rem 0.625rem 0px rgba(99, 102, 241, 0.07)",
213
+ "ui-overlay": "0px 4px 4px 1px rgba(99, 102, 241, 0.04)",
214
+ "ui-sticky-nav": "0px 3px 12px -1px rgba(151, 71, 255, 0.07)",
215
+ "ui-dialog": "0px 8px 12px 0px rgba(99, 102, 241, 0.15)"
216
+ },
217
+ fontSize: {
218
+ "ui-h1": ["1.5rem", "2rem"],
219
+ "ui-h2": ["1.25rem", "1.75rem"],
220
+ "ui-h3": ["1.125rem", "1.75rem"],
221
+ "ui-p": ["1rem", "1.5rem"],
222
+ "ui-note": ["0.875rem", "1.25rem"],
223
+ "ui-small-note": ["0.75rem", "1rem"]
224
+ },
225
+ keyframes: {
226
+ "accordion-down": {
227
+ from: { height: "0" },
228
+ to: { height: "var(--radix-accordion-content-height)" }
229
+ },
230
+ "accordion-up": {
231
+ from: { height: "var(--radix-accordion-content-height)" },
232
+ to: { height: "0" }
233
+ }
234
+ },
235
+ animation: {
236
+ "accordion-down": "accordion-down 0.2s ease-out",
237
+ "accordion-up": "accordion-up 0.2s ease-out"
238
+ }
239
+ };
240
+ var tailwindTheme_default = themes;
241
+
242
+ // packages/libs/utils.ts
243
+ import clsx from "clsx";
244
+ import { extendTailwindMerge } from "tailwind-merge";
245
+ var customTailwindMerge = () => {
246
+ return extendTailwindMerge({
247
+ ...tailwindTheme_default,
248
+ prefix: ""
249
+ });
250
+ };
251
+ var cn = (...inputs) => {
252
+ const customTwMerge = customTailwindMerge();
253
+ return customTwMerge(clsx(inputs));
254
+ };
255
+
256
+ // packages/Atoms/NumberInput/index.tsx
257
+ import { jsx } from "react/jsx-runtime";
258
+ var NumberInput = forwardRef(({ className, value: initialValue, onChange, onValueChange, ...props }, ref) => {
259
+ const isFocused = useRef(false);
260
+ const [value, setValue] = useState(void 0);
261
+ const formattedValue = useMemo(() => {
262
+ const regex = /\B(?=(?:\d{3})+(?!\d))/g;
263
+ const focused = isFocused.current;
264
+ if (initialValue) {
265
+ return focused ? initialValue : initialValue.toString().replaceAll(regex, ",");
266
+ }
267
+ if (!value) return "";
268
+ if (focused) return value.toString().replaceAll(regex, "");
269
+ return value.toString().replaceAll(regex, ",");
270
+ }, [initialValue, value]);
271
+ const handleChange = useCallback(
272
+ (e) => {
273
+ const { value: value2 } = e.target;
274
+ if (/[^\d,]/.test(value2)) return;
275
+ setValue(value2.replaceAll(",", ""));
276
+ onChange?.(e);
277
+ onValueChange?.(Number(value2));
278
+ },
279
+ [onChange, onValueChange]
280
+ );
281
+ const handleFocus = useCallback(() => {
282
+ isFocused.current = true;
283
+ if (initialValue) {
284
+ setValue((initialValue ?? "").toString().replaceAll(",", ""));
285
+ return;
286
+ }
287
+ setValue((value ?? "").toString().replaceAll(",", ""));
288
+ }, [initialValue, value]);
289
+ const handleBlur = useCallback(() => {
290
+ isFocused.current = false;
291
+ setValue((value ?? "").toString().replaceAll(/\B(?=(?:\d{3})+(?!\d))/g, ","));
292
+ }, [value]);
293
+ return /* @__PURE__ */ jsx(
294
+ "input",
295
+ {
296
+ ref,
297
+ value: formattedValue,
298
+ className: cn(
299
+ "relative",
300
+ "outline-none",
301
+ "px-2 py-1",
302
+ "!text-ui-note text-ui-text-600",
303
+ "rounded border border-ui-border-300",
304
+ "placeholder:!text-ui-note placeholder:text-ui-text-400",
305
+ "focus-within:border-ui-primary-500",
306
+ "focus-within:ring-4",
307
+ "focus-within:ring-ui-primary-50",
308
+ "transition-all duration-300 ease-in-out",
309
+ className
310
+ ),
311
+ ...props,
312
+ onChange: handleChange,
313
+ onFocus: handleFocus,
314
+ onBlur: handleBlur
315
+ }
316
+ );
317
+ });
318
+ var NumberInput_default = NumberInput;
319
+ export {
320
+ NumberInput_default as default
321
+ };
@@ -0,0 +1,8 @@
1
+ import * as React from 'react';
2
+ import * as PopoverPrimitive from '@radix-ui/react-popover';
3
+
4
+ declare const Popover: React.FC<PopoverPrimitive.PopoverProps>;
5
+ declare const PopoverTrigger: React.ForwardRefExoticComponent<PopoverPrimitive.PopoverTriggerProps & React.RefAttributes<HTMLButtonElement>>;
6
+ declare const PopoverContent: React.ForwardRefExoticComponent<Omit<PopoverPrimitive.PopoverContentProps & React.RefAttributes<HTMLDivElement>, "ref"> & React.RefAttributes<HTMLDivElement>>;
7
+
8
+ export { Popover, PopoverContent, PopoverTrigger };