@algorithm-shift/design-system 1.2.44 → 1.2.46
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.
- package/dist/chunk-QZ2QO7MJ.mjs +24 -0
- package/dist/chunk-QZ2QO7MJ.mjs.map +1 -0
- package/dist/client.d.mts +21 -8
- package/dist/client.d.ts +21 -8
- package/dist/client.js +100 -334
- package/dist/client.js.map +1 -1
- package/dist/client.mjs +292 -4
- package/dist/client.mjs.map +1 -1
- package/dist/index.d.mts +3 -18
- package/dist/index.d.ts +3 -18
- package/dist/index.js +6 -301
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +2785 -51
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
- package/dist/chunk-JFDQZCMW.mjs +0 -3130
- package/dist/chunk-JFDQZCMW.mjs.map +0 -1
package/dist/index.mjs
CHANGED
|
@@ -1,50 +1,2761 @@
|
|
|
1
|
+
'use client';
|
|
1
2
|
import {
|
|
2
|
-
BarChart_default,
|
|
3
|
-
Breadcrumb_default,
|
|
4
|
-
Button_default,
|
|
5
|
-
Checkbox_default,
|
|
6
|
-
Container_default,
|
|
7
|
-
DatePicker,
|
|
8
|
-
DateRange_default,
|
|
9
|
-
Dropdown_default,
|
|
10
|
-
EmailComposer,
|
|
11
|
-
EmailInput_default,
|
|
12
|
-
FileInput_default,
|
|
13
|
-
Flex_default,
|
|
14
|
-
Form_default,
|
|
15
|
-
Grid_default,
|
|
16
|
-
Image_default,
|
|
17
|
-
Modal_default,
|
|
18
|
-
MultiCheckbox_default,
|
|
19
|
-
Navbar,
|
|
20
|
-
NumberInput_default,
|
|
21
|
-
Pagination_default,
|
|
22
|
-
PasswordInput_default,
|
|
23
|
-
PhoneInput_default,
|
|
24
|
-
PieChart_default,
|
|
25
|
-
RadioInput_default,
|
|
26
|
-
RichText,
|
|
27
|
-
SearchInput_default,
|
|
28
|
-
Shape_default,
|
|
29
|
-
Spacer_default,
|
|
30
|
-
SplitButton,
|
|
31
|
-
Stages_default,
|
|
32
|
-
StateProvider,
|
|
33
|
-
SwitchToggle_default,
|
|
34
|
-
Table_default,
|
|
35
|
-
Tabs_default,
|
|
36
|
-
TextInputGroup_default,
|
|
37
|
-
TextInput_default,
|
|
38
|
-
Textarea_default,
|
|
39
|
-
Typography_default,
|
|
40
|
-
UrlInput_default,
|
|
41
|
-
Wrapper_default,
|
|
42
3
|
cn,
|
|
43
|
-
getInitials
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
} from "
|
|
4
|
+
getInitials
|
|
5
|
+
} from "./chunk-QZ2QO7MJ.mjs";
|
|
6
|
+
|
|
7
|
+
// src/components/Layout/Modal.tsx
|
|
8
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
9
|
+
var Modal = ({
|
|
10
|
+
children,
|
|
11
|
+
onClose,
|
|
12
|
+
label,
|
|
13
|
+
className,
|
|
14
|
+
style
|
|
15
|
+
}) => {
|
|
16
|
+
return /* @__PURE__ */ jsx("div", { className, style, children: /* @__PURE__ */ jsxs("div", { className: "min-h-80", children: [
|
|
17
|
+
/* @__PURE__ */ jsxs("div", { className: "flex justify-between items-center p-4 border-b border-gray-300 bg-gray-100", children: [
|
|
18
|
+
/* @__PURE__ */ jsx("h4", { className: "text-[#000]", children: label || "Modal Title" }),
|
|
19
|
+
/* @__PURE__ */ jsx(
|
|
20
|
+
"span",
|
|
21
|
+
{
|
|
22
|
+
className: "cursor-pointer text-[#000]",
|
|
23
|
+
role: "presentation",
|
|
24
|
+
onClick: onClose,
|
|
25
|
+
children: "X"
|
|
26
|
+
}
|
|
27
|
+
)
|
|
28
|
+
] }),
|
|
29
|
+
/* @__PURE__ */ jsx("div", { className: "h-90 overflow-y-auto p-4 custom-scroll", children })
|
|
30
|
+
] }) });
|
|
31
|
+
};
|
|
32
|
+
var Modal_default = Modal;
|
|
33
|
+
|
|
34
|
+
// src/components/Layout/Flex.tsx
|
|
35
|
+
import { jsx as jsx2 } from "react/jsx-runtime";
|
|
36
|
+
var Flex = ({
|
|
37
|
+
children,
|
|
38
|
+
className,
|
|
39
|
+
style,
|
|
40
|
+
...props
|
|
41
|
+
}) => {
|
|
42
|
+
return /* @__PURE__ */ jsx2("div", { ...props, className, style, children });
|
|
43
|
+
};
|
|
44
|
+
var Flex_default = Flex;
|
|
45
|
+
|
|
46
|
+
// src/components/Layout/Grid.tsx
|
|
47
|
+
import { jsx as jsx3 } from "react/jsx-runtime";
|
|
48
|
+
var Grid = ({
|
|
49
|
+
children,
|
|
50
|
+
className,
|
|
51
|
+
style,
|
|
52
|
+
...props
|
|
53
|
+
}) => {
|
|
54
|
+
return /* @__PURE__ */ jsx3("div", { ...props, className, style, children });
|
|
55
|
+
};
|
|
56
|
+
var Grid_default = Grid;
|
|
57
|
+
|
|
58
|
+
// src/components/Layout/Container.tsx
|
|
59
|
+
import { jsx as jsx4 } from "react/jsx-runtime";
|
|
60
|
+
var Container = ({
|
|
61
|
+
children,
|
|
62
|
+
className,
|
|
63
|
+
style,
|
|
64
|
+
...props
|
|
65
|
+
}) => {
|
|
66
|
+
return /* @__PURE__ */ jsx4("div", { ...props, className, style, children });
|
|
67
|
+
};
|
|
68
|
+
var Container_default = Container;
|
|
69
|
+
|
|
70
|
+
// src/components/ui/button.tsx
|
|
71
|
+
import { Slot } from "@radix-ui/react-slot";
|
|
72
|
+
import { cva } from "class-variance-authority";
|
|
73
|
+
import { jsx as jsx5 } from "react/jsx-runtime";
|
|
74
|
+
var buttonVariants = cva(
|
|
75
|
+
"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive",
|
|
76
|
+
{
|
|
77
|
+
variants: {
|
|
78
|
+
variant: {
|
|
79
|
+
default: "bg-primary text-primary-foreground shadow-xs hover:bg-primary/90",
|
|
80
|
+
destructive: "bg-destructive text-white shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",
|
|
81
|
+
outline: "border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50",
|
|
82
|
+
secondary: "bg-secondary text-secondary-foreground shadow-xs hover:bg-secondary/80",
|
|
83
|
+
ghost: "hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",
|
|
84
|
+
link: "text-primary underline-offset-4 hover:underline"
|
|
85
|
+
},
|
|
86
|
+
size: {
|
|
87
|
+
default: "h-9 px-4 py-2 has-[>svg]:px-3",
|
|
88
|
+
sm: "h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5",
|
|
89
|
+
lg: "h-10 rounded-md px-6 has-[>svg]:px-4",
|
|
90
|
+
icon: "size-9"
|
|
91
|
+
}
|
|
92
|
+
},
|
|
93
|
+
defaultVariants: {
|
|
94
|
+
variant: "default",
|
|
95
|
+
size: "default"
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
);
|
|
99
|
+
function Button({
|
|
100
|
+
className,
|
|
101
|
+
variant,
|
|
102
|
+
size,
|
|
103
|
+
asChild = false,
|
|
104
|
+
...props
|
|
105
|
+
}) {
|
|
106
|
+
const Comp = asChild ? Slot : "button";
|
|
107
|
+
return /* @__PURE__ */ jsx5(
|
|
108
|
+
Comp,
|
|
109
|
+
{
|
|
110
|
+
"data-slot": "button",
|
|
111
|
+
className: cn(buttonVariants({ variant, size, className })),
|
|
112
|
+
...props
|
|
113
|
+
}
|
|
114
|
+
);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
// src/components/Basic/Button/Button.tsx
|
|
118
|
+
import { jsx as jsx6 } from "react/jsx-runtime";
|
|
119
|
+
var ButtonWrapper = ({
|
|
120
|
+
className,
|
|
121
|
+
style,
|
|
122
|
+
textContent = "Button",
|
|
123
|
+
...props
|
|
124
|
+
}) => {
|
|
125
|
+
return /* @__PURE__ */ jsx6(
|
|
126
|
+
Button,
|
|
127
|
+
{
|
|
128
|
+
...props,
|
|
129
|
+
className,
|
|
130
|
+
style,
|
|
131
|
+
children: textContent
|
|
132
|
+
}
|
|
133
|
+
);
|
|
134
|
+
};
|
|
135
|
+
var Button_default = ButtonWrapper;
|
|
136
|
+
|
|
137
|
+
// src/assets/image-placeholder.png
|
|
138
|
+
var image_placeholder_default = "";
|
|
139
|
+
|
|
140
|
+
// src/components/Basic/Image/Image.tsx
|
|
141
|
+
import { jsx as jsx7 } from "react/jsx-runtime";
|
|
142
|
+
var ImageControl = ({
|
|
143
|
+
className,
|
|
144
|
+
style,
|
|
145
|
+
imageUrl,
|
|
146
|
+
imageUrlExternal,
|
|
147
|
+
altText = "Preview"
|
|
148
|
+
}) => {
|
|
149
|
+
const imageClass = cn(
|
|
150
|
+
"h-[200px] w-[200px] border-1",
|
|
151
|
+
"border-2 border-dashed border-gray-400 flex items-center justify-center cursor-pointer hover:border-blue-500 transition"
|
|
152
|
+
);
|
|
153
|
+
const defaultImgClass = cn(
|
|
154
|
+
"w-full h-full",
|
|
155
|
+
className
|
|
156
|
+
);
|
|
157
|
+
if (!imageUrl && !imageUrlExternal) {
|
|
158
|
+
return /* @__PURE__ */ jsx7("div", { className: imageClass, children: /* @__PURE__ */ jsx7("img", { src: image_placeholder_default, alt: altText, className: "opacity-50", width: 50, height: 50 }) });
|
|
159
|
+
}
|
|
160
|
+
const url = imageUrlExternal || imageUrl;
|
|
161
|
+
return /* @__PURE__ */ jsx7("img", { src: url, alt: altText, className: defaultImgClass, style });
|
|
162
|
+
};
|
|
163
|
+
var Image_default = ImageControl;
|
|
164
|
+
|
|
165
|
+
// src/components/Basic/Shape/Shape.tsx
|
|
166
|
+
import { jsx as jsx8 } from "react/jsx-runtime";
|
|
167
|
+
var Shape = ({
|
|
168
|
+
children,
|
|
169
|
+
className,
|
|
170
|
+
style
|
|
171
|
+
}) => {
|
|
172
|
+
return /* @__PURE__ */ jsx8("div", { className, style, children });
|
|
173
|
+
};
|
|
174
|
+
var Shape_default = Shape;
|
|
175
|
+
|
|
176
|
+
// src/components/Basic/Typography/Typography.tsx
|
|
177
|
+
import React from "react";
|
|
178
|
+
var Typography = ({
|
|
179
|
+
className,
|
|
180
|
+
style,
|
|
181
|
+
tagName,
|
|
182
|
+
textContent
|
|
183
|
+
}) => {
|
|
184
|
+
const Tag = tagName || "h1";
|
|
185
|
+
return React.createElement(
|
|
186
|
+
Tag,
|
|
187
|
+
{
|
|
188
|
+
style,
|
|
189
|
+
className: cn(className, "pointer-events-auto")
|
|
190
|
+
},
|
|
191
|
+
[
|
|
192
|
+
React.createElement("span", {
|
|
193
|
+
key: "html",
|
|
194
|
+
className: "pointer-events-none",
|
|
195
|
+
dangerouslySetInnerHTML: { __html: textContent }
|
|
196
|
+
})
|
|
197
|
+
]
|
|
198
|
+
);
|
|
199
|
+
};
|
|
200
|
+
var Typography_default = Typography;
|
|
201
|
+
|
|
202
|
+
// node_modules/lucide-react/dist/esm/createLucideIcon.js
|
|
203
|
+
import { forwardRef as forwardRef2, createElement as createElement2 } from "react";
|
|
204
|
+
|
|
205
|
+
// node_modules/lucide-react/dist/esm/shared/src/utils.js
|
|
206
|
+
var toKebabCase = (string) => string.replace(/([a-z0-9])([A-Z])/g, "$1-$2").toLowerCase();
|
|
207
|
+
var toCamelCase = (string) => string.replace(
|
|
208
|
+
/^([A-Z])|[\s-_]+(\w)/g,
|
|
209
|
+
(match, p1, p2) => p2 ? p2.toUpperCase() : p1.toLowerCase()
|
|
210
|
+
);
|
|
211
|
+
var toPascalCase = (string) => {
|
|
212
|
+
const camelCase = toCamelCase(string);
|
|
213
|
+
return camelCase.charAt(0).toUpperCase() + camelCase.slice(1);
|
|
214
|
+
};
|
|
215
|
+
var mergeClasses = (...classes) => classes.filter((className, index, array) => {
|
|
216
|
+
return Boolean(className) && className.trim() !== "" && array.indexOf(className) === index;
|
|
217
|
+
}).join(" ").trim();
|
|
218
|
+
var hasA11yProp = (props) => {
|
|
219
|
+
for (const prop in props) {
|
|
220
|
+
if (prop.startsWith("aria-") || prop === "role" || prop === "title") {
|
|
221
|
+
return true;
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
};
|
|
225
|
+
|
|
226
|
+
// node_modules/lucide-react/dist/esm/Icon.js
|
|
227
|
+
import { forwardRef, createElement } from "react";
|
|
228
|
+
|
|
229
|
+
// node_modules/lucide-react/dist/esm/defaultAttributes.js
|
|
230
|
+
var defaultAttributes = {
|
|
231
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
232
|
+
width: 24,
|
|
233
|
+
height: 24,
|
|
234
|
+
viewBox: "0 0 24 24",
|
|
235
|
+
fill: "none",
|
|
236
|
+
stroke: "currentColor",
|
|
237
|
+
strokeWidth: 2,
|
|
238
|
+
strokeLinecap: "round",
|
|
239
|
+
strokeLinejoin: "round"
|
|
240
|
+
};
|
|
241
|
+
|
|
242
|
+
// node_modules/lucide-react/dist/esm/Icon.js
|
|
243
|
+
var Icon = forwardRef(
|
|
244
|
+
({
|
|
245
|
+
color = "currentColor",
|
|
246
|
+
size = 24,
|
|
247
|
+
strokeWidth = 2,
|
|
248
|
+
absoluteStrokeWidth,
|
|
249
|
+
className = "",
|
|
250
|
+
children,
|
|
251
|
+
iconNode,
|
|
252
|
+
...rest
|
|
253
|
+
}, ref) => createElement(
|
|
254
|
+
"svg",
|
|
255
|
+
{
|
|
256
|
+
ref,
|
|
257
|
+
...defaultAttributes,
|
|
258
|
+
width: size,
|
|
259
|
+
height: size,
|
|
260
|
+
stroke: color,
|
|
261
|
+
strokeWidth: absoluteStrokeWidth ? Number(strokeWidth) * 24 / Number(size) : strokeWidth,
|
|
262
|
+
className: mergeClasses("lucide", className),
|
|
263
|
+
...!children && !hasA11yProp(rest) && { "aria-hidden": "true" },
|
|
264
|
+
...rest
|
|
265
|
+
},
|
|
266
|
+
[
|
|
267
|
+
...iconNode.map(([tag, attrs]) => createElement(tag, attrs)),
|
|
268
|
+
...Array.isArray(children) ? children : [children]
|
|
269
|
+
]
|
|
270
|
+
)
|
|
271
|
+
);
|
|
272
|
+
|
|
273
|
+
// node_modules/lucide-react/dist/esm/createLucideIcon.js
|
|
274
|
+
var createLucideIcon = (iconName, iconNode) => {
|
|
275
|
+
const Component = forwardRef2(
|
|
276
|
+
({ className, ...props }, ref) => createElement2(Icon, {
|
|
277
|
+
ref,
|
|
278
|
+
iconNode,
|
|
279
|
+
className: mergeClasses(
|
|
280
|
+
`lucide-${toKebabCase(toPascalCase(iconName))}`,
|
|
281
|
+
`lucide-${iconName}`,
|
|
282
|
+
className
|
|
283
|
+
),
|
|
284
|
+
...props
|
|
285
|
+
})
|
|
286
|
+
);
|
|
287
|
+
Component.displayName = toPascalCase(iconName);
|
|
288
|
+
return Component;
|
|
289
|
+
};
|
|
290
|
+
|
|
291
|
+
// node_modules/lucide-react/dist/esm/icons/bell.js
|
|
292
|
+
var __iconNode = [
|
|
293
|
+
["path", { d: "M10.268 21a2 2 0 0 0 3.464 0", key: "vwvbt9" }],
|
|
294
|
+
[
|
|
295
|
+
"path",
|
|
296
|
+
{
|
|
297
|
+
d: "M3.262 15.326A1 1 0 0 0 4 17h16a1 1 0 0 0 .74-1.673C19.41 13.956 18 12.499 18 8A6 6 0 0 0 6 8c0 4.499-1.411 5.956-2.738 7.326",
|
|
298
|
+
key: "11g9vi"
|
|
299
|
+
}
|
|
300
|
+
]
|
|
301
|
+
];
|
|
302
|
+
var Bell = createLucideIcon("bell", __iconNode);
|
|
303
|
+
|
|
304
|
+
// node_modules/lucide-react/dist/esm/icons/calculator.js
|
|
305
|
+
var __iconNode2 = [
|
|
306
|
+
["rect", { width: "16", height: "20", x: "4", y: "2", rx: "2", key: "1nb95v" }],
|
|
307
|
+
["line", { x1: "8", x2: "16", y1: "6", y2: "6", key: "x4nwl0" }],
|
|
308
|
+
["line", { x1: "16", x2: "16", y1: "14", y2: "18", key: "wjye3r" }],
|
|
309
|
+
["path", { d: "M16 10h.01", key: "1m94wz" }],
|
|
310
|
+
["path", { d: "M12 10h.01", key: "1nrarc" }],
|
|
311
|
+
["path", { d: "M8 10h.01", key: "19clt8" }],
|
|
312
|
+
["path", { d: "M12 14h.01", key: "1etili" }],
|
|
313
|
+
["path", { d: "M8 14h.01", key: "6423bh" }],
|
|
314
|
+
["path", { d: "M12 18h.01", key: "mhygvu" }],
|
|
315
|
+
["path", { d: "M8 18h.01", key: "lrp35t" }]
|
|
316
|
+
];
|
|
317
|
+
var Calculator = createLucideIcon("calculator", __iconNode2);
|
|
318
|
+
|
|
319
|
+
// node_modules/lucide-react/dist/esm/icons/calendar.js
|
|
320
|
+
var __iconNode3 = [
|
|
321
|
+
["path", { d: "M8 2v4", key: "1cmpym" }],
|
|
322
|
+
["path", { d: "M16 2v4", key: "4m81vk" }],
|
|
323
|
+
["rect", { width: "18", height: "18", x: "3", y: "4", rx: "2", key: "1hopcy" }],
|
|
324
|
+
["path", { d: "M3 10h18", key: "8toen8" }]
|
|
325
|
+
];
|
|
326
|
+
var Calendar = createLucideIcon("calendar", __iconNode3);
|
|
327
|
+
|
|
328
|
+
// node_modules/lucide-react/dist/esm/icons/check.js
|
|
329
|
+
var __iconNode4 = [["path", { d: "M20 6 9 17l-5-5", key: "1gmf2c" }]];
|
|
330
|
+
var Check = createLucideIcon("check", __iconNode4);
|
|
331
|
+
|
|
332
|
+
// node_modules/lucide-react/dist/esm/icons/chevron-down.js
|
|
333
|
+
var __iconNode5 = [["path", { d: "m6 9 6 6 6-6", key: "qrunsl" }]];
|
|
334
|
+
var ChevronDown = createLucideIcon("chevron-down", __iconNode5);
|
|
335
|
+
|
|
336
|
+
// node_modules/lucide-react/dist/esm/icons/chevron-left.js
|
|
337
|
+
var __iconNode6 = [["path", { d: "m15 18-6-6 6-6", key: "1wnfg3" }]];
|
|
338
|
+
var ChevronLeft = createLucideIcon("chevron-left", __iconNode6);
|
|
339
|
+
|
|
340
|
+
// node_modules/lucide-react/dist/esm/icons/chevron-right.js
|
|
341
|
+
var __iconNode7 = [["path", { d: "m9 18 6-6-6-6", key: "mthhwq" }]];
|
|
342
|
+
var ChevronRight = createLucideIcon("chevron-right", __iconNode7);
|
|
343
|
+
|
|
344
|
+
// node_modules/lucide-react/dist/esm/icons/chevron-up.js
|
|
345
|
+
var __iconNode8 = [["path", { d: "m18 15-6-6-6 6", key: "153udz" }]];
|
|
346
|
+
var ChevronUp = createLucideIcon("chevron-up", __iconNode8);
|
|
347
|
+
|
|
348
|
+
// node_modules/lucide-react/dist/esm/icons/circle.js
|
|
349
|
+
var __iconNode9 = [["circle", { cx: "12", cy: "12", r: "10", key: "1mglay" }]];
|
|
350
|
+
var Circle = createLucideIcon("circle", __iconNode9);
|
|
351
|
+
|
|
352
|
+
// node_modules/lucide-react/dist/esm/icons/ellipsis.js
|
|
353
|
+
var __iconNode10 = [
|
|
354
|
+
["circle", { cx: "12", cy: "12", r: "1", key: "41hilf" }],
|
|
355
|
+
["circle", { cx: "19", cy: "12", r: "1", key: "1wjl8i" }],
|
|
356
|
+
["circle", { cx: "5", cy: "12", r: "1", key: "1pcz8c" }]
|
|
357
|
+
];
|
|
358
|
+
var Ellipsis = createLucideIcon("ellipsis", __iconNode10);
|
|
359
|
+
|
|
360
|
+
// node_modules/lucide-react/dist/esm/icons/mail.js
|
|
361
|
+
var __iconNode11 = [
|
|
362
|
+
["path", { d: "m22 7-8.991 5.727a2 2 0 0 1-2.009 0L2 7", key: "132q7q" }],
|
|
363
|
+
["rect", { x: "2", y: "4", width: "20", height: "16", rx: "2", key: "izxlao" }]
|
|
364
|
+
];
|
|
365
|
+
var Mail = createLucideIcon("mail", __iconNode11);
|
|
366
|
+
|
|
367
|
+
// node_modules/lucide-react/dist/esm/icons/menu.js
|
|
368
|
+
var __iconNode12 = [
|
|
369
|
+
["path", { d: "M4 12h16", key: "1lakjw" }],
|
|
370
|
+
["path", { d: "M4 18h16", key: "19g7jn" }],
|
|
371
|
+
["path", { d: "M4 6h16", key: "1o0s65" }]
|
|
372
|
+
];
|
|
373
|
+
var Menu = createLucideIcon("menu", __iconNode12);
|
|
374
|
+
|
|
375
|
+
// node_modules/lucide-react/dist/esm/icons/scan-eye.js
|
|
376
|
+
var __iconNode13 = [
|
|
377
|
+
["path", { d: "M3 7V5a2 2 0 0 1 2-2h2", key: "aa7l1z" }],
|
|
378
|
+
["path", { d: "M17 3h2a2 2 0 0 1 2 2v2", key: "4qcy5o" }],
|
|
379
|
+
["path", { d: "M21 17v2a2 2 0 0 1-2 2h-2", key: "6vwrx8" }],
|
|
380
|
+
["path", { d: "M7 21H5a2 2 0 0 1-2-2v-2", key: "ioqczr" }],
|
|
381
|
+
["circle", { cx: "12", cy: "12", r: "1", key: "41hilf" }],
|
|
382
|
+
[
|
|
383
|
+
"path",
|
|
384
|
+
{
|
|
385
|
+
d: "M18.944 12.33a1 1 0 0 0 0-.66 7.5 7.5 0 0 0-13.888 0 1 1 0 0 0 0 .66 7.5 7.5 0 0 0 13.888 0",
|
|
386
|
+
key: "11ak4c"
|
|
387
|
+
}
|
|
388
|
+
]
|
|
389
|
+
];
|
|
390
|
+
var ScanEye = createLucideIcon("scan-eye", __iconNode13);
|
|
391
|
+
|
|
392
|
+
// node_modules/lucide-react/dist/esm/icons/search.js
|
|
393
|
+
var __iconNode14 = [
|
|
394
|
+
["path", { d: "m21 21-4.34-4.34", key: "14j7rj" }],
|
|
395
|
+
["circle", { cx: "11", cy: "11", r: "8", key: "4ej97u" }]
|
|
396
|
+
];
|
|
397
|
+
var Search = createLucideIcon("search", __iconNode14);
|
|
398
|
+
|
|
399
|
+
// src/components/Basic/Breadcrumb/Breadcrumb.tsx
|
|
400
|
+
import { jsx as jsx9, jsxs as jsxs2 } from "react/jsx-runtime";
|
|
401
|
+
var Breadcrumb = ({ list = [], className, style, LinkComponent }) => {
|
|
402
|
+
return /* @__PURE__ */ jsx9(
|
|
403
|
+
"nav",
|
|
404
|
+
{
|
|
405
|
+
"aria-label": "breadcrumb",
|
|
406
|
+
className: cn("flex items-center text-sm text-muted-foreground", className),
|
|
407
|
+
style,
|
|
408
|
+
children: list.map((item, index) => {
|
|
409
|
+
const isLast = index === list.length - 1;
|
|
410
|
+
return /* @__PURE__ */ jsxs2("div", { className: "flex items-center", children: [
|
|
411
|
+
item.url && !isLast && LinkComponent ? /* @__PURE__ */ jsx9(
|
|
412
|
+
LinkComponent,
|
|
413
|
+
{
|
|
414
|
+
href: item.url,
|
|
415
|
+
className: "hover:text-foreground transition-colors",
|
|
416
|
+
children: item.header
|
|
417
|
+
}
|
|
418
|
+
) : /* @__PURE__ */ jsx9("span", { className: "text-foreground font-medium", children: item.header }),
|
|
419
|
+
!isLast && /* @__PURE__ */ jsx9(ChevronRight, { className: "mx-2 h-4 w-4 text-muted-foreground" })
|
|
420
|
+
] }, item.id);
|
|
421
|
+
})
|
|
422
|
+
}
|
|
423
|
+
);
|
|
424
|
+
};
|
|
425
|
+
var Breadcrumb_default = Breadcrumb;
|
|
426
|
+
|
|
427
|
+
// src/components/ui/dropdown-menu.tsx
|
|
428
|
+
import * as DropdownMenuPrimitive from "@radix-ui/react-dropdown-menu";
|
|
429
|
+
import { jsx as jsx10, jsxs as jsxs3 } from "react/jsx-runtime";
|
|
430
|
+
function DropdownMenu({
|
|
431
|
+
...props
|
|
432
|
+
}) {
|
|
433
|
+
return /* @__PURE__ */ jsx10(DropdownMenuPrimitive.Root, { "data-slot": "dropdown-menu", ...props });
|
|
434
|
+
}
|
|
435
|
+
function DropdownMenuTrigger({
|
|
436
|
+
...props
|
|
437
|
+
}) {
|
|
438
|
+
return /* @__PURE__ */ jsx10(
|
|
439
|
+
DropdownMenuPrimitive.Trigger,
|
|
440
|
+
{
|
|
441
|
+
"data-slot": "dropdown-menu-trigger",
|
|
442
|
+
...props
|
|
443
|
+
}
|
|
444
|
+
);
|
|
445
|
+
}
|
|
446
|
+
function DropdownMenuContent({
|
|
447
|
+
className,
|
|
448
|
+
sideOffset = 4,
|
|
449
|
+
...props
|
|
450
|
+
}) {
|
|
451
|
+
return /* @__PURE__ */ jsx10(DropdownMenuPrimitive.Portal, { children: /* @__PURE__ */ jsx10(
|
|
452
|
+
DropdownMenuPrimitive.Content,
|
|
453
|
+
{
|
|
454
|
+
"data-slot": "dropdown-menu-content",
|
|
455
|
+
sideOffset,
|
|
456
|
+
className: cn(
|
|
457
|
+
"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 z-50 max-h-(--radix-dropdown-menu-content-available-height) min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border p-1 shadow-md",
|
|
458
|
+
className
|
|
459
|
+
),
|
|
460
|
+
...props
|
|
461
|
+
}
|
|
462
|
+
) });
|
|
463
|
+
}
|
|
464
|
+
function DropdownMenuItem({
|
|
465
|
+
className,
|
|
466
|
+
inset,
|
|
467
|
+
variant = "default",
|
|
468
|
+
...props
|
|
469
|
+
}) {
|
|
470
|
+
return /* @__PURE__ */ jsx10(
|
|
471
|
+
DropdownMenuPrimitive.Item,
|
|
472
|
+
{
|
|
473
|
+
"data-slot": "dropdown-menu-item",
|
|
474
|
+
"data-inset": inset,
|
|
475
|
+
"data-variant": variant,
|
|
476
|
+
className: cn(
|
|
477
|
+
"focus:bg-accent focus:text-accent-foreground data-[variant=destructive]:text-destructive data-[variant=destructive]:focus:bg-destructive/10 dark:data-[variant=destructive]:focus:bg-destructive/20 data-[variant=destructive]:focus:text-destructive data-[variant=destructive]:*:[svg]:!text-destructive [&_svg:not([class*='text-'])]:text-muted-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
|
|
478
|
+
className
|
|
479
|
+
),
|
|
480
|
+
...props
|
|
481
|
+
}
|
|
482
|
+
);
|
|
483
|
+
}
|
|
484
|
+
function DropdownMenuLabel({
|
|
485
|
+
className,
|
|
486
|
+
inset,
|
|
487
|
+
...props
|
|
488
|
+
}) {
|
|
489
|
+
return /* @__PURE__ */ jsx10(
|
|
490
|
+
DropdownMenuPrimitive.Label,
|
|
491
|
+
{
|
|
492
|
+
"data-slot": "dropdown-menu-label",
|
|
493
|
+
"data-inset": inset,
|
|
494
|
+
className: cn(
|
|
495
|
+
"px-2 py-1.5 text-sm font-medium data-[inset]:pl-8",
|
|
496
|
+
className
|
|
497
|
+
),
|
|
498
|
+
...props
|
|
499
|
+
}
|
|
500
|
+
);
|
|
501
|
+
}
|
|
502
|
+
function DropdownMenuSeparator({
|
|
503
|
+
className,
|
|
504
|
+
...props
|
|
505
|
+
}) {
|
|
506
|
+
return /* @__PURE__ */ jsx10(
|
|
507
|
+
DropdownMenuPrimitive.Separator,
|
|
508
|
+
{
|
|
509
|
+
"data-slot": "dropdown-menu-separator",
|
|
510
|
+
className: cn("bg-border -mx-1 my-1 h-px", className),
|
|
511
|
+
...props
|
|
512
|
+
}
|
|
513
|
+
);
|
|
514
|
+
}
|
|
515
|
+
function DropdownMenuSub({
|
|
516
|
+
...props
|
|
517
|
+
}) {
|
|
518
|
+
return /* @__PURE__ */ jsx10(DropdownMenuPrimitive.Sub, { "data-slot": "dropdown-menu-sub", ...props });
|
|
519
|
+
}
|
|
520
|
+
function DropdownMenuSubTrigger({
|
|
521
|
+
className,
|
|
522
|
+
inset,
|
|
523
|
+
children,
|
|
524
|
+
...props
|
|
525
|
+
}) {
|
|
526
|
+
return /* @__PURE__ */ jsxs3(
|
|
527
|
+
DropdownMenuPrimitive.SubTrigger,
|
|
528
|
+
{
|
|
529
|
+
"data-slot": "dropdown-menu-sub-trigger",
|
|
530
|
+
"data-inset": inset,
|
|
531
|
+
className: cn(
|
|
532
|
+
"focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground flex cursor-default items-center rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[inset]:pl-8",
|
|
533
|
+
className
|
|
534
|
+
),
|
|
535
|
+
...props,
|
|
536
|
+
children: [
|
|
537
|
+
children,
|
|
538
|
+
/* @__PURE__ */ jsx10(ChevronRight, { className: "ml-auto size-4" })
|
|
539
|
+
]
|
|
540
|
+
}
|
|
541
|
+
);
|
|
542
|
+
}
|
|
543
|
+
function DropdownMenuSubContent({
|
|
544
|
+
className,
|
|
545
|
+
...props
|
|
546
|
+
}) {
|
|
547
|
+
return /* @__PURE__ */ jsx10(
|
|
548
|
+
DropdownMenuPrimitive.SubContent,
|
|
549
|
+
{
|
|
550
|
+
"data-slot": "dropdown-menu-sub-content",
|
|
551
|
+
className: cn(
|
|
552
|
+
"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 z-50 min-w-[8rem] origin-(--radix-dropdown-menu-content-transform-origin) overflow-hidden rounded-md border p-1 shadow-lg",
|
|
553
|
+
className
|
|
554
|
+
),
|
|
555
|
+
...props
|
|
556
|
+
}
|
|
557
|
+
);
|
|
558
|
+
}
|
|
559
|
+
|
|
560
|
+
// src/components/Basic/ButtonGroup/ButtonGroup.tsx
|
|
561
|
+
import { jsx as jsx11, jsxs as jsxs4 } from "react/jsx-runtime";
|
|
562
|
+
function SplitButton({ style, textContent, className, list = [], LinkComponent }) {
|
|
563
|
+
const bgColor = style?.backgroundColor || "";
|
|
564
|
+
return /* @__PURE__ */ jsxs4("div", { className: "inline-flex rounded-md overflow-hidden border border-teal-200 bg-teal-700 items-center focus:ring-0", style: { backgroundColor: bgColor }, children: [
|
|
565
|
+
/* @__PURE__ */ jsx11(
|
|
566
|
+
Button,
|
|
567
|
+
{
|
|
568
|
+
className: `rounded-none border-r px-4 py-2 text-whit focus:ring-0 ${className || ""}`,
|
|
569
|
+
style: { backgroundColor: bgColor },
|
|
570
|
+
children: textContent || "Button"
|
|
571
|
+
}
|
|
572
|
+
),
|
|
573
|
+
/* @__PURE__ */ jsxs4(DropdownMenu, { children: [
|
|
574
|
+
/* @__PURE__ */ jsx11(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ jsx11(
|
|
575
|
+
Button,
|
|
576
|
+
{
|
|
577
|
+
className: "rounded-none bg-teal-700 px-4 py-2 text-white ring-0 shadow-none hover:bg-teal-600 focus:ring-0",
|
|
578
|
+
"aria-label": "Open Dropdown",
|
|
579
|
+
style: { backgroundColor: bgColor },
|
|
580
|
+
children: /* @__PURE__ */ jsx11(ChevronDown, { className: "w-4 h-4" })
|
|
581
|
+
}
|
|
582
|
+
) }),
|
|
583
|
+
/* @__PURE__ */ jsx11(DropdownMenuContent, { align: "end", className: "bg-white min-w-[120px]", children: list.map((item) => /* @__PURE__ */ jsx11(DropdownMenuItem, { className: "text-black", children: LinkComponent ? /* @__PURE__ */ jsx11(LinkComponent, { href: item.url || "#", children: item.header }) : item.header }, item.id)) })
|
|
584
|
+
] })
|
|
585
|
+
] });
|
|
586
|
+
}
|
|
587
|
+
|
|
588
|
+
// src/components/ui/input.tsx
|
|
589
|
+
import { jsx as jsx12 } from "react/jsx-runtime";
|
|
590
|
+
function Input({ className, type, ...props }) {
|
|
591
|
+
return /* @__PURE__ */ jsx12(
|
|
592
|
+
"input",
|
|
593
|
+
{
|
|
594
|
+
type,
|
|
595
|
+
"data-slot": "input",
|
|
596
|
+
className: cn(
|
|
597
|
+
"file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input flex h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm",
|
|
598
|
+
"focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]",
|
|
599
|
+
"aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive",
|
|
600
|
+
className
|
|
601
|
+
),
|
|
602
|
+
...props
|
|
603
|
+
}
|
|
604
|
+
);
|
|
605
|
+
}
|
|
606
|
+
|
|
607
|
+
// src/components/Inputs/TextInput/TextInput.tsx
|
|
608
|
+
import { Fragment, jsx as jsx13, jsxs as jsxs5 } from "react/jsx-runtime";
|
|
609
|
+
var TextInput = ({ className, style, ...props }) => {
|
|
610
|
+
const placeholder = props.placeholder || "Placeholder text";
|
|
611
|
+
const isEditable = props.isEditable ?? true;
|
|
612
|
+
const isDisabled = props.isDisabled ?? false;
|
|
613
|
+
const isReadonly = props.isReadonly ?? false;
|
|
614
|
+
const isAutocomplete = props.isAutocomplete ?? false;
|
|
615
|
+
const handleChange = (e) => {
|
|
616
|
+
props.onChange?.(e);
|
|
617
|
+
};
|
|
618
|
+
return /* @__PURE__ */ jsxs5(Fragment, { children: [
|
|
619
|
+
/* @__PURE__ */ jsx13(
|
|
620
|
+
Input,
|
|
621
|
+
{
|
|
622
|
+
type: "text",
|
|
623
|
+
name: props.name,
|
|
624
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
625
|
+
style: {
|
|
626
|
+
...style,
|
|
627
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
628
|
+
},
|
|
629
|
+
value: props.value,
|
|
630
|
+
autoComplete: isAutocomplete ? "on" : "off",
|
|
631
|
+
placeholder,
|
|
632
|
+
onChange: handleChange,
|
|
633
|
+
disabled: isDisabled || !isEditable,
|
|
634
|
+
readOnly: isReadonly
|
|
635
|
+
}
|
|
636
|
+
),
|
|
637
|
+
props.errorMessage && /* @__PURE__ */ jsx13("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
638
|
+
] });
|
|
639
|
+
};
|
|
640
|
+
var TextInput_default = TextInput;
|
|
641
|
+
|
|
642
|
+
// src/components/Inputs/NumberInput/NumberInput.tsx
|
|
643
|
+
import { Fragment as Fragment2, jsx as jsx14, jsxs as jsxs6 } from "react/jsx-runtime";
|
|
644
|
+
var NumberInput = ({ className, style, ...props }) => {
|
|
645
|
+
const placeholder = props.placeholder ?? "Placeholder text";
|
|
646
|
+
const isEditable = props.isEditable ?? true;
|
|
647
|
+
const isDisabled = props.isDisabled ?? false;
|
|
648
|
+
const isReadonly = props.isReadonly ?? false;
|
|
649
|
+
const isAutocomplete = props.isAutocomplete ?? false;
|
|
650
|
+
const handleChange = (e) => {
|
|
651
|
+
props.onChange?.(e);
|
|
652
|
+
};
|
|
653
|
+
return /* @__PURE__ */ jsxs6(Fragment2, { children: [
|
|
654
|
+
/* @__PURE__ */ jsxs6("div", { className: "flex justify-start items-center relative", children: [
|
|
655
|
+
/* @__PURE__ */ jsx14(Calculator, { className: "absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[#BDBDBD]" }),
|
|
656
|
+
/* @__PURE__ */ jsx14(
|
|
657
|
+
Input,
|
|
658
|
+
{
|
|
659
|
+
type: "number",
|
|
660
|
+
id: props.name || "number-field",
|
|
661
|
+
name: props.name,
|
|
662
|
+
value: props.value,
|
|
663
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
664
|
+
style: {
|
|
665
|
+
...style,
|
|
666
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
667
|
+
},
|
|
668
|
+
autoComplete: isAutocomplete ? "on" : "off",
|
|
669
|
+
placeholder,
|
|
670
|
+
onChange: handleChange,
|
|
671
|
+
disabled: isDisabled || !isEditable,
|
|
672
|
+
readOnly: isReadonly
|
|
673
|
+
}
|
|
674
|
+
)
|
|
675
|
+
] }),
|
|
676
|
+
props.errorMessage && /* @__PURE__ */ jsx14("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
677
|
+
] });
|
|
678
|
+
};
|
|
679
|
+
var NumberInput_default = NumberInput;
|
|
680
|
+
|
|
681
|
+
// src/components/Inputs/EmailInput/EmailInput.tsx
|
|
682
|
+
import { Fragment as Fragment3, jsx as jsx15, jsxs as jsxs7 } from "react/jsx-runtime";
|
|
683
|
+
var EmailInput = ({ className, style, ...props }) => {
|
|
684
|
+
const placeholder = props.placeholder ?? "Placeholder text";
|
|
685
|
+
const isEditable = props.isEditable ?? true;
|
|
686
|
+
const isDisabled = props.isDisabled ?? false;
|
|
687
|
+
const isReadonly = props.isReadonly ?? false;
|
|
688
|
+
const isAutocomplete = props.isAutocomplete ?? false;
|
|
689
|
+
const handleChange = (e) => {
|
|
690
|
+
props.onChange?.(e);
|
|
691
|
+
};
|
|
692
|
+
return /* @__PURE__ */ jsxs7(Fragment3, { children: [
|
|
693
|
+
/* @__PURE__ */ jsxs7("div", { className: "flex justify-start items-center relative", children: [
|
|
694
|
+
/* @__PURE__ */ jsx15(Mail, { className: "absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[#BDBDBD]" }),
|
|
695
|
+
/* @__PURE__ */ jsx15(
|
|
696
|
+
Input,
|
|
697
|
+
{
|
|
698
|
+
type: "email",
|
|
699
|
+
name: props.name,
|
|
700
|
+
value: props.value,
|
|
701
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
702
|
+
style: {
|
|
703
|
+
...style,
|
|
704
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
705
|
+
},
|
|
706
|
+
autoComplete: isAutocomplete ? "on" : "off",
|
|
707
|
+
placeholder,
|
|
708
|
+
onChange: handleChange,
|
|
709
|
+
disabled: isDisabled || !isEditable,
|
|
710
|
+
readOnly: isReadonly
|
|
711
|
+
}
|
|
712
|
+
)
|
|
713
|
+
] }),
|
|
714
|
+
props.errorMessage && /* @__PURE__ */ jsx15("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
715
|
+
] });
|
|
716
|
+
};
|
|
717
|
+
var EmailInput_default = EmailInput;
|
|
718
|
+
|
|
719
|
+
// src/components/Inputs/PasswordInput/PasswordInput.tsx
|
|
720
|
+
import { Fragment as Fragment4, jsx as jsx16, jsxs as jsxs8 } from "react/jsx-runtime";
|
|
721
|
+
var PasswordInput = ({ className, style, ...props }) => {
|
|
722
|
+
const placeholder = props.placeholder ?? "Placeholder text";
|
|
723
|
+
const isEditable = props.isEditable ?? true;
|
|
724
|
+
const isDisabled = props.isDisabled ?? false;
|
|
725
|
+
const isReadonly = props.isReadonly ?? false;
|
|
726
|
+
const isAutocomplete = props.isAutocomplete ?? false;
|
|
727
|
+
const handleChange = (e) => {
|
|
728
|
+
props.onChange?.(e);
|
|
729
|
+
};
|
|
730
|
+
return /* @__PURE__ */ jsxs8(Fragment4, { children: [
|
|
731
|
+
/* @__PURE__ */ jsxs8("div", { className: "flex justify-start items-center relative", children: [
|
|
732
|
+
/* @__PURE__ */ jsx16(ScanEye, { className: "absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[#BDBDBD]" }),
|
|
733
|
+
/* @__PURE__ */ jsx16(
|
|
734
|
+
Input,
|
|
735
|
+
{
|
|
736
|
+
type: "password",
|
|
737
|
+
id: props.name || "password-field",
|
|
738
|
+
name: props.name,
|
|
739
|
+
value: props.value,
|
|
740
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
741
|
+
style: {
|
|
742
|
+
...style,
|
|
743
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
744
|
+
},
|
|
745
|
+
autoComplete: isAutocomplete ? "on" : "off",
|
|
746
|
+
placeholder,
|
|
747
|
+
onChange: handleChange,
|
|
748
|
+
disabled: isDisabled || !isEditable,
|
|
749
|
+
readOnly: isReadonly
|
|
750
|
+
}
|
|
751
|
+
)
|
|
752
|
+
] }),
|
|
753
|
+
props.errorMessage && /* @__PURE__ */ jsx16("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
754
|
+
] });
|
|
755
|
+
};
|
|
756
|
+
var PasswordInput_default = PasswordInput;
|
|
757
|
+
|
|
758
|
+
// src/components/ui/textarea.tsx
|
|
759
|
+
import { jsx as jsx17 } from "react/jsx-runtime";
|
|
760
|
+
function Textarea({ className, ...props }) {
|
|
761
|
+
return /* @__PURE__ */ jsx17(
|
|
762
|
+
"textarea",
|
|
763
|
+
{
|
|
764
|
+
"data-slot": "textarea",
|
|
765
|
+
className: cn(
|
|
766
|
+
"border-input placeholder:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 flex field-sizing-content min-h-16 w-full rounded-md border bg-transparent px-3 py-2 text-base shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 md:text-sm",
|
|
767
|
+
className
|
|
768
|
+
),
|
|
769
|
+
...props
|
|
770
|
+
}
|
|
771
|
+
);
|
|
772
|
+
}
|
|
773
|
+
|
|
774
|
+
// src/components/Inputs/Textarea/Textarea.tsx
|
|
775
|
+
import { Fragment as Fragment5, jsx as jsx18, jsxs as jsxs9 } from "react/jsx-runtime";
|
|
776
|
+
var Textarea2 = ({ className, style, ...props }) => {
|
|
777
|
+
const placeholder = props.placeholder ?? "Placeholder text";
|
|
778
|
+
const isEditable = props.isEditable ?? true;
|
|
779
|
+
const isDisabled = props.isDisabled ?? false;
|
|
780
|
+
const isReadonly = props.isReadonly ?? false;
|
|
781
|
+
const isAutocomplete = props.isAutocomplete ?? false;
|
|
782
|
+
const handleChange = (e) => {
|
|
783
|
+
props.onChange?.(e);
|
|
784
|
+
};
|
|
785
|
+
return /* @__PURE__ */ jsxs9(Fragment5, { children: [
|
|
786
|
+
/* @__PURE__ */ jsx18(
|
|
787
|
+
Textarea,
|
|
788
|
+
{
|
|
789
|
+
id: "textarea-field",
|
|
790
|
+
name: props.name,
|
|
791
|
+
value: props.value,
|
|
792
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
793
|
+
style: {
|
|
794
|
+
...style,
|
|
795
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
796
|
+
},
|
|
797
|
+
autoComplete: isAutocomplete ? "on" : "off",
|
|
798
|
+
placeholder,
|
|
799
|
+
onChange: handleChange,
|
|
800
|
+
disabled: isDisabled || !isEditable,
|
|
801
|
+
readOnly: isReadonly
|
|
802
|
+
}
|
|
803
|
+
),
|
|
804
|
+
props.errorMessage && /* @__PURE__ */ jsx18("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
805
|
+
] });
|
|
806
|
+
};
|
|
807
|
+
var Textarea_default = Textarea2;
|
|
808
|
+
|
|
809
|
+
// src/components/Inputs/UrlInput/UrlInput.tsx
|
|
810
|
+
import { Fragment as Fragment6, jsx as jsx19, jsxs as jsxs10 } from "react/jsx-runtime";
|
|
811
|
+
var UrlInput = ({ className, style, ...props }) => {
|
|
812
|
+
const placeholder = props.placeholder ?? "Placeholder text";
|
|
813
|
+
const isEditable = props.isEditable ?? true;
|
|
814
|
+
const isDisabled = props.isDisabled ?? false;
|
|
815
|
+
const isReadonly = props.isReadonly ?? false;
|
|
816
|
+
const isAutocomplete = props.isAutocomplete ?? false;
|
|
817
|
+
const handleChange = (e) => {
|
|
818
|
+
props.onChange?.(e);
|
|
819
|
+
};
|
|
820
|
+
return /* @__PURE__ */ jsxs10(Fragment6, { children: [
|
|
821
|
+
/* @__PURE__ */ jsxs10("div", { className: "flex justify-start items-center relative", children: [
|
|
822
|
+
/* @__PURE__ */ jsx19("div", { className: "bg-[#E9E9E9] absolute px-10 text-center top-1/2 h-full justify-center items-center flex w-10 -translate-y-1/2 text-[#383838] font-[500] text-[12px]", children: "https://" }),
|
|
823
|
+
/* @__PURE__ */ jsx19(
|
|
824
|
+
Input,
|
|
825
|
+
{
|
|
826
|
+
id: "url-field",
|
|
827
|
+
type: "url",
|
|
828
|
+
name: props.name,
|
|
829
|
+
value: props.value,
|
|
830
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
831
|
+
style: {
|
|
832
|
+
...style,
|
|
833
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
834
|
+
},
|
|
835
|
+
autoComplete: isAutocomplete ? "on" : "off",
|
|
836
|
+
placeholder,
|
|
837
|
+
onChange: handleChange,
|
|
838
|
+
disabled: isDisabled || !isEditable,
|
|
839
|
+
readOnly: isReadonly
|
|
840
|
+
}
|
|
841
|
+
)
|
|
842
|
+
] }),
|
|
843
|
+
props.errorMessage && /* @__PURE__ */ jsx19("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
844
|
+
] });
|
|
845
|
+
};
|
|
846
|
+
var UrlInput_default = UrlInput;
|
|
847
|
+
|
|
848
|
+
// src/components/ui/checkbox.tsx
|
|
849
|
+
import * as CheckboxPrimitive from "@radix-ui/react-checkbox";
|
|
850
|
+
import { jsx as jsx20 } from "react/jsx-runtime";
|
|
851
|
+
function Checkbox({
|
|
852
|
+
className,
|
|
853
|
+
...props
|
|
854
|
+
}) {
|
|
855
|
+
return /* @__PURE__ */ jsx20(
|
|
856
|
+
CheckboxPrimitive.Root,
|
|
857
|
+
{
|
|
858
|
+
"data-slot": "checkbox",
|
|
859
|
+
className: cn(
|
|
860
|
+
"peer border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50",
|
|
861
|
+
className
|
|
862
|
+
),
|
|
863
|
+
...props,
|
|
864
|
+
children: /* @__PURE__ */ jsx20(
|
|
865
|
+
CheckboxPrimitive.Indicator,
|
|
866
|
+
{
|
|
867
|
+
"data-slot": "checkbox-indicator",
|
|
868
|
+
className: "flex items-center justify-center text-current transition-none",
|
|
869
|
+
children: /* @__PURE__ */ jsx20(Check, { className: "size-3.5" })
|
|
870
|
+
}
|
|
871
|
+
)
|
|
872
|
+
}
|
|
873
|
+
);
|
|
874
|
+
}
|
|
875
|
+
|
|
876
|
+
// src/components/ui/label.tsx
|
|
877
|
+
import * as LabelPrimitive from "@radix-ui/react-label";
|
|
878
|
+
import { jsx as jsx21 } from "react/jsx-runtime";
|
|
879
|
+
function Label2({
|
|
880
|
+
className,
|
|
881
|
+
...props
|
|
882
|
+
}) {
|
|
883
|
+
return /* @__PURE__ */ jsx21(
|
|
884
|
+
LabelPrimitive.Root,
|
|
885
|
+
{
|
|
886
|
+
"data-slot": "label",
|
|
887
|
+
className: cn(
|
|
888
|
+
"flex items-center gap-2 text-sm leading-none font-medium select-none group-data-[disabled=true]:pointer-events-none group-data-[disabled=true]:opacity-50 peer-disabled:cursor-not-allowed peer-disabled:opacity-50",
|
|
889
|
+
className
|
|
890
|
+
),
|
|
891
|
+
...props
|
|
892
|
+
}
|
|
893
|
+
);
|
|
894
|
+
}
|
|
895
|
+
|
|
896
|
+
// src/components/Inputs/Checkbox/Checkbox.tsx
|
|
897
|
+
import { Fragment as Fragment7, jsx as jsx22, jsxs as jsxs11 } from "react/jsx-runtime";
|
|
898
|
+
var CheckboxInput = ({ className, style, ...props }) => {
|
|
899
|
+
const isEditable = props.isEditable ?? true;
|
|
900
|
+
const isDisabled = props.isDisabled ?? false;
|
|
901
|
+
const text = props.text ? props.text : "Subscribe";
|
|
902
|
+
const handleChange = (value) => {
|
|
903
|
+
props.onChange?.(value);
|
|
904
|
+
};
|
|
905
|
+
return /* @__PURE__ */ jsxs11(Fragment7, { children: [
|
|
906
|
+
/* @__PURE__ */ jsx22("div", { className, style, children: /* @__PURE__ */ jsxs11("div", { className: "flex items-center space-x-2", children: [
|
|
907
|
+
/* @__PURE__ */ jsx22(
|
|
908
|
+
Checkbox,
|
|
909
|
+
{
|
|
910
|
+
id: props.name || "checkbox",
|
|
911
|
+
checked: !!props.value,
|
|
912
|
+
onCheckedChange: handleChange,
|
|
913
|
+
disabled: !isEditable || isDisabled
|
|
914
|
+
}
|
|
915
|
+
),
|
|
916
|
+
/* @__PURE__ */ jsx22(Label2, { htmlFor: props.name || "checkbox", children: text })
|
|
917
|
+
] }) }),
|
|
918
|
+
props.errorMessage && /* @__PURE__ */ jsx22("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
919
|
+
] });
|
|
920
|
+
};
|
|
921
|
+
var Checkbox_default = CheckboxInput;
|
|
922
|
+
|
|
923
|
+
// src/components/ui/radio-group.tsx
|
|
924
|
+
import * as RadioGroupPrimitive from "@radix-ui/react-radio-group";
|
|
925
|
+
import { jsx as jsx23 } from "react/jsx-runtime";
|
|
926
|
+
function RadioGroup2({
|
|
927
|
+
className,
|
|
928
|
+
...props
|
|
929
|
+
}) {
|
|
930
|
+
return /* @__PURE__ */ jsx23(
|
|
931
|
+
RadioGroupPrimitive.Root,
|
|
932
|
+
{
|
|
933
|
+
"data-slot": "radio-group",
|
|
934
|
+
className: cn("grid gap-3", className),
|
|
935
|
+
...props
|
|
936
|
+
}
|
|
937
|
+
);
|
|
938
|
+
}
|
|
939
|
+
function RadioGroupItem({
|
|
940
|
+
className,
|
|
941
|
+
...props
|
|
942
|
+
}) {
|
|
943
|
+
return /* @__PURE__ */ jsx23(
|
|
944
|
+
RadioGroupPrimitive.Item,
|
|
945
|
+
{
|
|
946
|
+
"data-slot": "radio-group-item",
|
|
947
|
+
className: cn(
|
|
948
|
+
"border-input text-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 aspect-square size-4 shrink-0 rounded-full border shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50",
|
|
949
|
+
className
|
|
950
|
+
),
|
|
951
|
+
...props,
|
|
952
|
+
children: /* @__PURE__ */ jsx23(
|
|
953
|
+
RadioGroupPrimitive.Indicator,
|
|
954
|
+
{
|
|
955
|
+
"data-slot": "radio-group-indicator",
|
|
956
|
+
className: "relative flex items-center justify-center",
|
|
957
|
+
children: /* @__PURE__ */ jsx23(Circle, { className: "fill-primary absolute top-1/2 left-1/2 size-2 -translate-x-1/2 -translate-y-1/2" })
|
|
958
|
+
}
|
|
959
|
+
)
|
|
960
|
+
}
|
|
961
|
+
);
|
|
962
|
+
}
|
|
963
|
+
|
|
964
|
+
// src/components/Inputs/RadioInput/RadioInput.tsx
|
|
965
|
+
import { Fragment as Fragment8, jsx as jsx24, jsxs as jsxs12 } from "react/jsx-runtime";
|
|
966
|
+
var RadioInput = ({
|
|
967
|
+
className,
|
|
968
|
+
style,
|
|
969
|
+
defaultValue,
|
|
970
|
+
onChange,
|
|
971
|
+
data = [],
|
|
972
|
+
dataKey,
|
|
973
|
+
dataLabel,
|
|
974
|
+
...props
|
|
975
|
+
}) => {
|
|
976
|
+
const options = (data || []).map((item) => ({
|
|
977
|
+
value: item[dataKey || "value"],
|
|
978
|
+
label: item[dataLabel || "label"]
|
|
979
|
+
}));
|
|
980
|
+
const handleChange = (value) => {
|
|
981
|
+
onChange?.(value);
|
|
982
|
+
};
|
|
983
|
+
const resolvedDefaultValue = (typeof defaultValue === "string" ? defaultValue : void 0) ?? options[0]?.value;
|
|
984
|
+
return /* @__PURE__ */ jsxs12(Fragment8, { children: [
|
|
985
|
+
/* @__PURE__ */ jsx24("div", { className, style, children: /* @__PURE__ */ jsxs12(
|
|
986
|
+
RadioGroup2,
|
|
987
|
+
{
|
|
988
|
+
defaultValue: resolvedDefaultValue,
|
|
989
|
+
onValueChange: handleChange,
|
|
990
|
+
children: [
|
|
991
|
+
options.length === 0 && /* @__PURE__ */ jsx24("div", { className: "text-sm text-gray-500", children: "No options available" }),
|
|
992
|
+
options.map((item) => /* @__PURE__ */ jsxs12("div", { className: "flex items-center space-x-2", children: [
|
|
993
|
+
/* @__PURE__ */ jsx24(RadioGroupItem, { value: item.value, id: `radio-${item.value}` }),
|
|
994
|
+
/* @__PURE__ */ jsx24(Label2, { htmlFor: `radio-${item.value}`, children: item.label })
|
|
995
|
+
] }, item.value))
|
|
996
|
+
]
|
|
997
|
+
}
|
|
998
|
+
) }),
|
|
999
|
+
props.errorMessage && /* @__PURE__ */ jsx24("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1000
|
+
] });
|
|
1001
|
+
};
|
|
1002
|
+
var RadioInput_default = RadioInput;
|
|
1003
|
+
|
|
1004
|
+
// src/components/Inputs/MultiCheckbox/MultiCheckbox.tsx
|
|
1005
|
+
import { useCallback, useState } from "react";
|
|
1006
|
+
import { jsx as jsx25, jsxs as jsxs13 } from "react/jsx-runtime";
|
|
1007
|
+
var MultiCheckbox = ({
|
|
1008
|
+
className,
|
|
1009
|
+
style,
|
|
1010
|
+
data = [],
|
|
1011
|
+
dataKey = "value",
|
|
1012
|
+
dataLabel = "label",
|
|
1013
|
+
value: propValue = {},
|
|
1014
|
+
onChange,
|
|
1015
|
+
isEditable = true,
|
|
1016
|
+
isDisabled = false
|
|
1017
|
+
}) => {
|
|
1018
|
+
const [value, setValue] = useState(propValue);
|
|
1019
|
+
const options = (data || []).map((item) => ({
|
|
1020
|
+
value: item[dataKey || "value"],
|
|
1021
|
+
label: item[dataLabel || "label"]
|
|
1022
|
+
}));
|
|
1023
|
+
const handleChange = useCallback(
|
|
1024
|
+
(key, checked) => {
|
|
1025
|
+
setValue((prev) => {
|
|
1026
|
+
const newValue = { ...prev, [key]: checked };
|
|
1027
|
+
onChange?.(newValue);
|
|
1028
|
+
return newValue;
|
|
1029
|
+
});
|
|
1030
|
+
},
|
|
1031
|
+
[onChange]
|
|
1032
|
+
);
|
|
1033
|
+
return /* @__PURE__ */ jsxs13(
|
|
1034
|
+
"div",
|
|
1035
|
+
{
|
|
1036
|
+
className: cn("flex flex-col gap-3", className),
|
|
1037
|
+
style,
|
|
1038
|
+
children: [
|
|
1039
|
+
options.length === 0 && /* @__PURE__ */ jsx25("p", { className: "text-sm text-gray-500", children: "No options available." }),
|
|
1040
|
+
options.map((opt) => /* @__PURE__ */ jsxs13("div", { className: "flex items-center space-x-2", children: [
|
|
1041
|
+
/* @__PURE__ */ jsx25(
|
|
1042
|
+
Checkbox,
|
|
1043
|
+
{
|
|
1044
|
+
id: opt.value,
|
|
1045
|
+
checked: !!value[opt.value],
|
|
1046
|
+
onCheckedChange: (checked) => handleChange(opt.value, checked === true),
|
|
1047
|
+
disabled: !isEditable || isDisabled
|
|
1048
|
+
}
|
|
1049
|
+
),
|
|
1050
|
+
/* @__PURE__ */ jsx25(Label2, { htmlFor: opt.value, children: opt.label })
|
|
1051
|
+
] }, opt.value))
|
|
1052
|
+
]
|
|
1053
|
+
}
|
|
1054
|
+
);
|
|
1055
|
+
};
|
|
1056
|
+
var MultiCheckbox_default = MultiCheckbox;
|
|
1057
|
+
|
|
1058
|
+
// src/components/Global/TinyMceEditor.tsx
|
|
1059
|
+
import { useMemo, useRef } from "react";
|
|
1060
|
+
import { Editor } from "@tinymce/tinymce-react";
|
|
1061
|
+
import { jsx as jsx26 } from "react/jsx-runtime";
|
|
1062
|
+
function MyEditor({
|
|
1063
|
+
value,
|
|
1064
|
+
onChange,
|
|
1065
|
+
isDefault
|
|
1066
|
+
}) {
|
|
1067
|
+
const editorRef = useRef(null);
|
|
1068
|
+
function stripOuterP(html) {
|
|
1069
|
+
const trimmedHtml = html.trim();
|
|
1070
|
+
if (!trimmedHtml) return "";
|
|
1071
|
+
const div = document.createElement("div");
|
|
1072
|
+
div.innerHTML = trimmedHtml;
|
|
1073
|
+
const firstChild = div.firstElementChild;
|
|
1074
|
+
if (div.childElementCount === 1 && firstChild?.tagName === "P") {
|
|
1075
|
+
return firstChild.innerHTML;
|
|
1076
|
+
}
|
|
1077
|
+
return trimmedHtml;
|
|
1078
|
+
}
|
|
1079
|
+
const isDefaultToolbar = useMemo(() => {
|
|
1080
|
+
let toolbar = "undo redo | formatselect | bold italic forecolor";
|
|
1081
|
+
if (isDefault) {
|
|
1082
|
+
toolbar = "undo redo | blocks | bold italic forecolor | alignleft aligncenter alignright alignjustify | bullist numlist outdent indent | removeformat | help";
|
|
1083
|
+
}
|
|
1084
|
+
return toolbar;
|
|
1085
|
+
}, [isDefault]);
|
|
1086
|
+
return /* @__PURE__ */ jsx26(
|
|
1087
|
+
Editor,
|
|
1088
|
+
{
|
|
1089
|
+
apiKey: process.env.NEXT_PUBLIC_TINYMCE_API_KEY,
|
|
1090
|
+
tinymceScriptSrc: process.env.NEXT_PUBLIC_TINYMCE_SCRIPT_SRC,
|
|
1091
|
+
onInit: (_evt, editor) => editorRef.current = editor,
|
|
1092
|
+
value,
|
|
1093
|
+
licenseKey: "gpl",
|
|
1094
|
+
init: {
|
|
1095
|
+
height: 300,
|
|
1096
|
+
menubar: false,
|
|
1097
|
+
forced_root_block: false,
|
|
1098
|
+
plugins: [
|
|
1099
|
+
"advlist",
|
|
1100
|
+
"autolink",
|
|
1101
|
+
"lists",
|
|
1102
|
+
"link",
|
|
1103
|
+
"image",
|
|
1104
|
+
"charmap",
|
|
1105
|
+
"preview",
|
|
1106
|
+
"anchor",
|
|
1107
|
+
"searchreplace",
|
|
1108
|
+
"visualblocks",
|
|
1109
|
+
"code",
|
|
1110
|
+
"fullscreen",
|
|
1111
|
+
"insertdatetime",
|
|
1112
|
+
"media",
|
|
1113
|
+
"table",
|
|
1114
|
+
"help",
|
|
1115
|
+
"wordcount"
|
|
1116
|
+
],
|
|
1117
|
+
toolbar: isDefaultToolbar,
|
|
1118
|
+
content_style: `
|
|
1119
|
+
body {
|
|
1120
|
+
outline: none;
|
|
1121
|
+
}
|
|
1122
|
+
`
|
|
1123
|
+
},
|
|
1124
|
+
onEditorChange: (content) => onChange?.(stripOuterP(content))
|
|
1125
|
+
}
|
|
1126
|
+
);
|
|
1127
|
+
}
|
|
1128
|
+
|
|
1129
|
+
// src/components/Inputs/RichText/RichText.tsx
|
|
1130
|
+
import { jsx as jsx27, jsxs as jsxs14 } from "react/jsx-runtime";
|
|
1131
|
+
function RichText({ className, style, ...props }) {
|
|
1132
|
+
return /* @__PURE__ */ jsxs14(
|
|
1133
|
+
"div",
|
|
1134
|
+
{
|
|
1135
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
1136
|
+
style: {
|
|
1137
|
+
...style,
|
|
1138
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
1139
|
+
},
|
|
1140
|
+
children: [
|
|
1141
|
+
/* @__PURE__ */ jsx27(MyEditor, { onChange: (content) => props.onChange?.(content), value: props.value, isDefault: true }),
|
|
1142
|
+
props.errorMessage && /* @__PURE__ */ jsx27("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1143
|
+
]
|
|
1144
|
+
}
|
|
1145
|
+
);
|
|
1146
|
+
}
|
|
1147
|
+
|
|
1148
|
+
// src/components/ui/select.tsx
|
|
1149
|
+
import * as SelectPrimitive from "@radix-ui/react-select";
|
|
1150
|
+
import { jsx as jsx28, jsxs as jsxs15 } from "react/jsx-runtime";
|
|
1151
|
+
function Select({
|
|
1152
|
+
...props
|
|
1153
|
+
}) {
|
|
1154
|
+
return /* @__PURE__ */ jsx28(SelectPrimitive.Root, { "data-slot": "select", ...props });
|
|
1155
|
+
}
|
|
1156
|
+
function SelectValue({
|
|
1157
|
+
...props
|
|
1158
|
+
}) {
|
|
1159
|
+
return /* @__PURE__ */ jsx28(SelectPrimitive.Value, { "data-slot": "select-value", ...props });
|
|
1160
|
+
}
|
|
1161
|
+
function SelectTrigger({
|
|
1162
|
+
className,
|
|
1163
|
+
size = "default",
|
|
1164
|
+
children,
|
|
1165
|
+
...props
|
|
1166
|
+
}) {
|
|
1167
|
+
return /* @__PURE__ */ jsxs15(
|
|
1168
|
+
SelectPrimitive.Trigger,
|
|
1169
|
+
{
|
|
1170
|
+
"data-slot": "select-trigger",
|
|
1171
|
+
"data-size": size,
|
|
1172
|
+
className: cn(
|
|
1173
|
+
"border-input data-[placeholder]:text-muted-foreground [&_svg:not([class*='text-'])]:text-muted-foreground focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive dark:bg-input/30 dark:hover:bg-input/50 flex w-fit items-center justify-between gap-2 rounded-md border bg-transparent px-3 py-2 text-sm whitespace-nowrap shadow-xs transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 data-[size=default]:h-9 data-[size=sm]:h-8 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
|
|
1174
|
+
className
|
|
1175
|
+
),
|
|
1176
|
+
...props,
|
|
1177
|
+
children: [
|
|
1178
|
+
children,
|
|
1179
|
+
/* @__PURE__ */ jsx28(SelectPrimitive.Icon, { asChild: true, children: /* @__PURE__ */ jsx28(ChevronDown, { className: "size-4 opacity-50" }) })
|
|
1180
|
+
]
|
|
1181
|
+
}
|
|
1182
|
+
);
|
|
1183
|
+
}
|
|
1184
|
+
function SelectContent({
|
|
1185
|
+
className,
|
|
1186
|
+
children,
|
|
1187
|
+
position = "popper",
|
|
1188
|
+
...props
|
|
1189
|
+
}) {
|
|
1190
|
+
return /* @__PURE__ */ jsx28(SelectPrimitive.Portal, { children: /* @__PURE__ */ jsxs15(
|
|
1191
|
+
SelectPrimitive.Content,
|
|
1192
|
+
{
|
|
1193
|
+
"data-slot": "select-content",
|
|
1194
|
+
className: cn(
|
|
1195
|
+
"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-(--radix-select-content-available-height) min-w-[8rem] origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border shadow-md",
|
|
1196
|
+
position === "popper" && "data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1",
|
|
1197
|
+
className
|
|
1198
|
+
),
|
|
1199
|
+
position,
|
|
1200
|
+
...props,
|
|
1201
|
+
children: [
|
|
1202
|
+
/* @__PURE__ */ jsx28(SelectScrollUpButton, {}),
|
|
1203
|
+
/* @__PURE__ */ jsx28(
|
|
1204
|
+
SelectPrimitive.Viewport,
|
|
1205
|
+
{
|
|
1206
|
+
className: cn(
|
|
1207
|
+
"p-1",
|
|
1208
|
+
position === "popper" && "h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)] scroll-my-1"
|
|
1209
|
+
),
|
|
1210
|
+
children
|
|
1211
|
+
}
|
|
1212
|
+
),
|
|
1213
|
+
/* @__PURE__ */ jsx28(SelectScrollDownButton, {})
|
|
1214
|
+
]
|
|
1215
|
+
}
|
|
1216
|
+
) });
|
|
1217
|
+
}
|
|
1218
|
+
function SelectItem({
|
|
1219
|
+
className,
|
|
1220
|
+
children,
|
|
1221
|
+
...props
|
|
1222
|
+
}) {
|
|
1223
|
+
return /* @__PURE__ */ jsxs15(
|
|
1224
|
+
SelectPrimitive.Item,
|
|
1225
|
+
{
|
|
1226
|
+
"data-slot": "select-item",
|
|
1227
|
+
className: cn(
|
|
1228
|
+
"focus:bg-accent focus:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex w-full cursor-default items-center gap-2 rounded-sm py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2",
|
|
1229
|
+
className
|
|
1230
|
+
),
|
|
1231
|
+
...props,
|
|
1232
|
+
children: [
|
|
1233
|
+
/* @__PURE__ */ jsx28("span", { className: "absolute right-2 flex size-3.5 items-center justify-center", children: /* @__PURE__ */ jsx28(SelectPrimitive.ItemIndicator, { children: /* @__PURE__ */ jsx28(Check, { className: "size-4" }) }) }),
|
|
1234
|
+
/* @__PURE__ */ jsx28(SelectPrimitive.ItemText, { children })
|
|
1235
|
+
]
|
|
1236
|
+
}
|
|
1237
|
+
);
|
|
1238
|
+
}
|
|
1239
|
+
function SelectScrollUpButton({
|
|
1240
|
+
className,
|
|
1241
|
+
...props
|
|
1242
|
+
}) {
|
|
1243
|
+
return /* @__PURE__ */ jsx28(
|
|
1244
|
+
SelectPrimitive.ScrollUpButton,
|
|
1245
|
+
{
|
|
1246
|
+
"data-slot": "select-scroll-up-button",
|
|
1247
|
+
className: cn(
|
|
1248
|
+
"flex cursor-default items-center justify-center py-1",
|
|
1249
|
+
className
|
|
1250
|
+
),
|
|
1251
|
+
...props,
|
|
1252
|
+
children: /* @__PURE__ */ jsx28(ChevronUp, { className: "size-4" })
|
|
1253
|
+
}
|
|
1254
|
+
);
|
|
1255
|
+
}
|
|
1256
|
+
function SelectScrollDownButton({
|
|
1257
|
+
className,
|
|
1258
|
+
...props
|
|
1259
|
+
}) {
|
|
1260
|
+
return /* @__PURE__ */ jsx28(
|
|
1261
|
+
SelectPrimitive.ScrollDownButton,
|
|
1262
|
+
{
|
|
1263
|
+
"data-slot": "select-scroll-down-button",
|
|
1264
|
+
className: cn(
|
|
1265
|
+
"flex cursor-default items-center justify-center py-1",
|
|
1266
|
+
className
|
|
1267
|
+
),
|
|
1268
|
+
...props,
|
|
1269
|
+
children: /* @__PURE__ */ jsx28(ChevronDown, { className: "size-4" })
|
|
1270
|
+
}
|
|
1271
|
+
);
|
|
1272
|
+
}
|
|
1273
|
+
|
|
1274
|
+
// src/components/Inputs/Dropdown/Dropdown.tsx
|
|
1275
|
+
import { Fragment as Fragment9, jsx as jsx29, jsxs as jsxs16 } from "react/jsx-runtime";
|
|
1276
|
+
var Dropdown = ({ className, style, ...props }) => {
|
|
1277
|
+
const list = props.data || [];
|
|
1278
|
+
const placeholder = props.placeholder ? props.placeholder : "Placeholder text";
|
|
1279
|
+
const isEditable = props.isEditable ?? true;
|
|
1280
|
+
const isDisabled = props.isDisabled ?? false;
|
|
1281
|
+
const isReadonly = props.isReadonly ?? false;
|
|
1282
|
+
const handleChange = (value) => {
|
|
1283
|
+
props.onChange?.(value);
|
|
1284
|
+
};
|
|
1285
|
+
const dataKey = props.dataKey || "value";
|
|
1286
|
+
const dataLabel = props.dataLabel || "label";
|
|
1287
|
+
const options = list.map((item) => ({
|
|
1288
|
+
value: item[dataKey],
|
|
1289
|
+
label: item[dataLabel]
|
|
1290
|
+
}));
|
|
1291
|
+
return /* @__PURE__ */ jsxs16(Fragment9, { children: [
|
|
1292
|
+
/* @__PURE__ */ jsxs16(Select, { name: props.name, value: props.value, onValueChange: handleChange, disabled: isDisabled || !isEditable, children: [
|
|
1293
|
+
/* @__PURE__ */ jsx29(
|
|
1294
|
+
SelectTrigger,
|
|
1295
|
+
{
|
|
1296
|
+
id: props.name || "select-field",
|
|
1297
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
1298
|
+
style: {
|
|
1299
|
+
...style,
|
|
1300
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
1301
|
+
},
|
|
1302
|
+
"aria-readonly": isReadonly,
|
|
1303
|
+
children: /* @__PURE__ */ jsx29(SelectValue, { placeholder })
|
|
1304
|
+
}
|
|
1305
|
+
),
|
|
1306
|
+
/* @__PURE__ */ jsx29(SelectContent, { children: options.map((opt) => /* @__PURE__ */ jsx29(SelectItem, { value: opt.value, children: opt.label }, opt.value)) })
|
|
1307
|
+
] }),
|
|
1308
|
+
props.errorMessage && /* @__PURE__ */ jsx29("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1309
|
+
] });
|
|
1310
|
+
};
|
|
1311
|
+
var Dropdown_default = Dropdown;
|
|
1312
|
+
|
|
1313
|
+
// src/components/ui/switch.tsx
|
|
1314
|
+
import * as SwitchPrimitive from "@radix-ui/react-switch";
|
|
1315
|
+
import { jsx as jsx30 } from "react/jsx-runtime";
|
|
1316
|
+
function Switch({
|
|
1317
|
+
className,
|
|
1318
|
+
...props
|
|
1319
|
+
}) {
|
|
1320
|
+
return /* @__PURE__ */ jsx30(
|
|
1321
|
+
SwitchPrimitive.Root,
|
|
1322
|
+
{
|
|
1323
|
+
"data-slot": "switch",
|
|
1324
|
+
className: cn(
|
|
1325
|
+
"peer data-[state=checked]:bg-primary data-[state=unchecked]:bg-input focus-visible:border-ring focus-visible:ring-ring/50 dark:data-[state=unchecked]:bg-input/80 inline-flex h-[1.15rem] w-8 shrink-0 items-center rounded-full border border-transparent shadow-xs transition-all outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50",
|
|
1326
|
+
className
|
|
1327
|
+
),
|
|
1328
|
+
...props,
|
|
1329
|
+
children: /* @__PURE__ */ jsx30(
|
|
1330
|
+
SwitchPrimitive.Thumb,
|
|
1331
|
+
{
|
|
1332
|
+
"data-slot": "switch-thumb",
|
|
1333
|
+
className: cn(
|
|
1334
|
+
"bg-background dark:data-[state=unchecked]:bg-foreground dark:data-[state=checked]:bg-primary-foreground pointer-events-none block size-4 rounded-full ring-0 transition-transform data-[state=checked]:translate-x-[calc(100%-2px)] data-[state=unchecked]:translate-x-0"
|
|
1335
|
+
)
|
|
1336
|
+
}
|
|
1337
|
+
)
|
|
1338
|
+
}
|
|
1339
|
+
);
|
|
1340
|
+
}
|
|
1341
|
+
|
|
1342
|
+
// src/components/Inputs/SwitchToggle/SwitchToggle.tsx
|
|
1343
|
+
import { Fragment as Fragment10, jsx as jsx31, jsxs as jsxs17 } from "react/jsx-runtime";
|
|
1344
|
+
var SwitchToggle = ({ className, style, ...props }) => {
|
|
1345
|
+
const isEditable = props.isEditable ?? true;
|
|
1346
|
+
const isDisabled = props.isDisabled ?? false;
|
|
1347
|
+
const handleChange = (value) => {
|
|
1348
|
+
props.onChange?.(value);
|
|
1349
|
+
};
|
|
1350
|
+
return /* @__PURE__ */ jsxs17(Fragment10, { children: [
|
|
1351
|
+
/* @__PURE__ */ jsx31("div", { className, style, children: /* @__PURE__ */ jsxs17("div", { className: "flex items-center space-x-2 mb-2", children: [
|
|
1352
|
+
/* @__PURE__ */ jsx31(
|
|
1353
|
+
Switch,
|
|
1354
|
+
{
|
|
1355
|
+
id: props.name || "switch",
|
|
1356
|
+
checked: !!props.value,
|
|
1357
|
+
onCheckedChange: handleChange,
|
|
1358
|
+
disabled: isDisabled || !isEditable
|
|
1359
|
+
}
|
|
1360
|
+
),
|
|
1361
|
+
/* @__PURE__ */ jsx31(Label2, { htmlFor: props.name || "switch", children: props.text })
|
|
1362
|
+
] }) }),
|
|
1363
|
+
props.errorMessage && /* @__PURE__ */ jsx31("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1364
|
+
] });
|
|
1365
|
+
};
|
|
1366
|
+
var SwitchToggle_default = SwitchToggle;
|
|
1367
|
+
|
|
1368
|
+
// src/components/Inputs/PhoneInput/PhoneInput.tsx
|
|
1369
|
+
import { PhoneInput as PhoneInputField } from "react-international-phone";
|
|
1370
|
+
import "react-international-phone/style.css";
|
|
1371
|
+
import { Fragment as Fragment11, jsx as jsx32, jsxs as jsxs18 } from "react/jsx-runtime";
|
|
1372
|
+
var PhoneInput = ({ className, style, ...props }) => {
|
|
1373
|
+
const placeholder = props.placeholder ?? "Enter phone number";
|
|
1374
|
+
const isEditable = props.isEditable ?? true;
|
|
1375
|
+
const isDisabled = props.isDisabled ?? false;
|
|
1376
|
+
const handleChange = (val) => {
|
|
1377
|
+
props.onChange?.(val);
|
|
1378
|
+
};
|
|
1379
|
+
return /* @__PURE__ */ jsxs18(Fragment11, { children: [
|
|
1380
|
+
/* @__PURE__ */ jsx32(
|
|
1381
|
+
PhoneInputField,
|
|
1382
|
+
{
|
|
1383
|
+
defaultCountry: "in",
|
|
1384
|
+
name: props.name,
|
|
1385
|
+
value: props.value,
|
|
1386
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
1387
|
+
style: {
|
|
1388
|
+
...style,
|
|
1389
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
1390
|
+
},
|
|
1391
|
+
onChange: (phone) => handleChange(phone),
|
|
1392
|
+
inputProps: {
|
|
1393
|
+
id: "phone-field"
|
|
1394
|
+
},
|
|
1395
|
+
placeholder,
|
|
1396
|
+
disabled: isDisabled || !isEditable
|
|
1397
|
+
}
|
|
1398
|
+
),
|
|
1399
|
+
props.errorMessage && /* @__PURE__ */ jsx32("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1400
|
+
] });
|
|
1401
|
+
};
|
|
1402
|
+
var PhoneInput_default = PhoneInput;
|
|
1403
|
+
|
|
1404
|
+
// src/components/Inputs/SearchInput/SearchInput.tsx
|
|
1405
|
+
import { Fragment as Fragment12, jsx as jsx33, jsxs as jsxs19 } from "react/jsx-runtime";
|
|
1406
|
+
var SearchInput = ({ className, style, ...props }) => {
|
|
1407
|
+
const placeholder = props.placeholder ?? "Placeholder text";
|
|
1408
|
+
const isEditable = props.isEditable ?? true;
|
|
1409
|
+
const isDisabled = props.isDisabled ?? false;
|
|
1410
|
+
const isReadonly = props.isReadonly ?? false;
|
|
1411
|
+
const isAutocomplete = props.isAutocomplete ?? false;
|
|
1412
|
+
const handleChange = (e) => {
|
|
1413
|
+
props.onChange?.(e);
|
|
1414
|
+
};
|
|
1415
|
+
return /* @__PURE__ */ jsxs19(Fragment12, { children: [
|
|
1416
|
+
/* @__PURE__ */ jsxs19("div", { className: "flex justify-start items-center relative", children: [
|
|
1417
|
+
/* @__PURE__ */ jsx33(Search, { className: "absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[#BDBDBD]" }),
|
|
1418
|
+
/* @__PURE__ */ jsx33(
|
|
1419
|
+
Input,
|
|
1420
|
+
{
|
|
1421
|
+
type: "text",
|
|
1422
|
+
id: props.name || "text-field",
|
|
1423
|
+
name: props.name,
|
|
1424
|
+
value: props.value,
|
|
1425
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
1426
|
+
style: {
|
|
1427
|
+
...style,
|
|
1428
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
1429
|
+
},
|
|
1430
|
+
autoComplete: isAutocomplete ? "on" : "off",
|
|
1431
|
+
placeholder,
|
|
1432
|
+
onChange: handleChange,
|
|
1433
|
+
disabled: isDisabled || !isEditable,
|
|
1434
|
+
readOnly: isReadonly
|
|
1435
|
+
}
|
|
1436
|
+
)
|
|
1437
|
+
] }),
|
|
1438
|
+
props.errorMessage && /* @__PURE__ */ jsx33("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1439
|
+
] });
|
|
1440
|
+
};
|
|
1441
|
+
var SearchInput_default = SearchInput;
|
|
1442
|
+
|
|
1443
|
+
// src/components/Inputs/FileInput/FileInput.tsx
|
|
1444
|
+
import { jsx as jsx34, jsxs as jsxs20 } from "react/jsx-runtime";
|
|
1445
|
+
var FileInput = ({ className, style, ...props }) => {
|
|
1446
|
+
const placeholder = props.placeholder ?? "Placeholder text";
|
|
1447
|
+
return /* @__PURE__ */ jsxs20("div", { className: "d-flex items-center relative align-middle", children: [
|
|
1448
|
+
/* @__PURE__ */ jsx34(
|
|
1449
|
+
Input,
|
|
1450
|
+
{
|
|
1451
|
+
type: "file",
|
|
1452
|
+
id: "file",
|
|
1453
|
+
name: props.name,
|
|
1454
|
+
value: props.value,
|
|
1455
|
+
className: cn(className, props.errorMessage ? "border-red-500" : ""),
|
|
1456
|
+
style: {
|
|
1457
|
+
...style,
|
|
1458
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
1459
|
+
},
|
|
1460
|
+
autoComplete: "off",
|
|
1461
|
+
placeholder,
|
|
1462
|
+
onChange: (e) => {
|
|
1463
|
+
props.onChange?.(e);
|
|
1464
|
+
}
|
|
1465
|
+
}
|
|
1466
|
+
),
|
|
1467
|
+
props.errorMessage && /* @__PURE__ */ jsx34("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1468
|
+
] });
|
|
1469
|
+
};
|
|
1470
|
+
var FileInput_default = FileInput;
|
|
1471
|
+
|
|
1472
|
+
// src/components/Inputs/DatePicker/DatePicker.tsx
|
|
1473
|
+
import { Fragment as Fragment13, jsx as jsx35, jsxs as jsxs21 } from "react/jsx-runtime";
|
|
1474
|
+
function DatePicker({ className, style, ...props }) {
|
|
1475
|
+
const placeholder = props.placeholder ?? "Placeholder text";
|
|
1476
|
+
const minimumDate = props.minimumDate ?? "none";
|
|
1477
|
+
const customMinimumDate = props.customMinimumDate ?? "";
|
|
1478
|
+
const maximumDate = props.maximumDate ?? "none";
|
|
1479
|
+
const customMaximumDate = props.customMaximumDate ?? "";
|
|
1480
|
+
const isEditable = props.isEditable ?? true;
|
|
1481
|
+
const isDisabled = props.isDisabled ?? false;
|
|
1482
|
+
const isReadonly = props.isReadonly ?? false;
|
|
1483
|
+
const isAutocomplete = props.isAutocomplete ?? false;
|
|
1484
|
+
const resolveDate = (option, customOption) => {
|
|
1485
|
+
if (!option) return void 0;
|
|
1486
|
+
switch (option) {
|
|
1487
|
+
case "today":
|
|
1488
|
+
return (/* @__PURE__ */ new Date()).toISOString().split("T")[0];
|
|
1489
|
+
case "custom":
|
|
1490
|
+
return customOption ?? void 0;
|
|
1491
|
+
case "none":
|
|
1492
|
+
default:
|
|
1493
|
+
return void 0;
|
|
1494
|
+
}
|
|
1495
|
+
};
|
|
1496
|
+
const minDate = resolveDate(minimumDate, customMinimumDate);
|
|
1497
|
+
const maxDate = resolveDate(maximumDate, customMaximumDate);
|
|
1498
|
+
const handleChange = (e) => {
|
|
1499
|
+
props.onChange?.(e);
|
|
1500
|
+
};
|
|
1501
|
+
return /* @__PURE__ */ jsxs21(Fragment13, { children: [
|
|
1502
|
+
/* @__PURE__ */ jsxs21("div", { className: "flex justify-start items-center relative", children: [
|
|
1503
|
+
/* @__PURE__ */ jsx35(Calendar, { className: "absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-[#BDBDBD]" }),
|
|
1504
|
+
/* @__PURE__ */ jsx35(
|
|
1505
|
+
Input,
|
|
1506
|
+
{
|
|
1507
|
+
type: "date",
|
|
1508
|
+
id: "date",
|
|
1509
|
+
autoComplete: isAutocomplete ? "on" : "off",
|
|
1510
|
+
onChange: handleChange,
|
|
1511
|
+
disabled: isDisabled || !isEditable,
|
|
1512
|
+
name: props.name,
|
|
1513
|
+
value: props.value,
|
|
1514
|
+
className: cn(
|
|
1515
|
+
className,
|
|
1516
|
+
props.errorMessage ? "border-red-500" : "",
|
|
1517
|
+
"appearance-auto"
|
|
1518
|
+
),
|
|
1519
|
+
style: {
|
|
1520
|
+
...style,
|
|
1521
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
1522
|
+
},
|
|
1523
|
+
readOnly: isReadonly,
|
|
1524
|
+
placeholder,
|
|
1525
|
+
min: minDate,
|
|
1526
|
+
max: maxDate
|
|
1527
|
+
}
|
|
1528
|
+
)
|
|
1529
|
+
] }),
|
|
1530
|
+
props.errorMessage && /* @__PURE__ */ jsx35("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1531
|
+
] });
|
|
1532
|
+
}
|
|
1533
|
+
|
|
1534
|
+
// src/components/Inputs/DateRange/DateRange.tsx
|
|
1535
|
+
import * as React3 from "react";
|
|
1536
|
+
import { addDays, format } from "date-fns";
|
|
1537
|
+
|
|
1538
|
+
// src/components/ui/calendar.tsx
|
|
1539
|
+
import * as React2 from "react";
|
|
1540
|
+
import { DayPicker, getDefaultClassNames } from "react-day-picker";
|
|
1541
|
+
import { jsx as jsx36 } from "react/jsx-runtime";
|
|
1542
|
+
function Calendar2({
|
|
1543
|
+
className,
|
|
1544
|
+
classNames,
|
|
1545
|
+
showOutsideDays = true,
|
|
1546
|
+
captionLayout = "label",
|
|
1547
|
+
buttonVariant = "ghost",
|
|
1548
|
+
formatters,
|
|
1549
|
+
components,
|
|
1550
|
+
...props
|
|
1551
|
+
}) {
|
|
1552
|
+
const defaultClassNames = getDefaultClassNames();
|
|
1553
|
+
return /* @__PURE__ */ jsx36(
|
|
1554
|
+
DayPicker,
|
|
1555
|
+
{
|
|
1556
|
+
showOutsideDays,
|
|
1557
|
+
className: cn(
|
|
1558
|
+
"bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent",
|
|
1559
|
+
String.raw`rtl:**:[.rdp-button\_next>svg]:rotate-180`,
|
|
1560
|
+
String.raw`rtl:**:[.rdp-button\_previous>svg]:rotate-180`,
|
|
1561
|
+
className
|
|
1562
|
+
),
|
|
1563
|
+
captionLayout,
|
|
1564
|
+
formatters: {
|
|
1565
|
+
formatMonthDropdown: (date) => date.toLocaleString("default", { month: "short" }),
|
|
1566
|
+
...formatters
|
|
1567
|
+
},
|
|
1568
|
+
classNames: {
|
|
1569
|
+
root: cn("w-fit", defaultClassNames.root),
|
|
1570
|
+
months: cn(
|
|
1571
|
+
"flex gap-4 flex-col md:flex-row relative",
|
|
1572
|
+
defaultClassNames.months
|
|
1573
|
+
),
|
|
1574
|
+
month: cn("flex flex-col w-full gap-4", defaultClassNames.month),
|
|
1575
|
+
nav: cn(
|
|
1576
|
+
"flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between",
|
|
1577
|
+
defaultClassNames.nav
|
|
1578
|
+
),
|
|
1579
|
+
button_previous: cn(
|
|
1580
|
+
buttonVariants({ variant: buttonVariant }),
|
|
1581
|
+
"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",
|
|
1582
|
+
defaultClassNames.button_previous
|
|
1583
|
+
),
|
|
1584
|
+
button_next: cn(
|
|
1585
|
+
buttonVariants({ variant: buttonVariant }),
|
|
1586
|
+
"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",
|
|
1587
|
+
defaultClassNames.button_next
|
|
1588
|
+
),
|
|
1589
|
+
month_caption: cn(
|
|
1590
|
+
"flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)",
|
|
1591
|
+
defaultClassNames.month_caption
|
|
1592
|
+
),
|
|
1593
|
+
dropdowns: cn(
|
|
1594
|
+
"w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5",
|
|
1595
|
+
defaultClassNames.dropdowns
|
|
1596
|
+
),
|
|
1597
|
+
dropdown_root: cn(
|
|
1598
|
+
"relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md",
|
|
1599
|
+
defaultClassNames.dropdown_root
|
|
1600
|
+
),
|
|
1601
|
+
dropdown: cn(
|
|
1602
|
+
"absolute bg-popover inset-0 opacity-0",
|
|
1603
|
+
defaultClassNames.dropdown
|
|
1604
|
+
),
|
|
1605
|
+
caption_label: cn(
|
|
1606
|
+
"select-none font-medium",
|
|
1607
|
+
captionLayout === "label" ? "text-sm" : "rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5",
|
|
1608
|
+
defaultClassNames.caption_label
|
|
1609
|
+
),
|
|
1610
|
+
table: "w-full border-collapse",
|
|
1611
|
+
weekdays: cn("flex", defaultClassNames.weekdays),
|
|
1612
|
+
weekday: cn(
|
|
1613
|
+
"text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none",
|
|
1614
|
+
defaultClassNames.weekday
|
|
1615
|
+
),
|
|
1616
|
+
week: cn("flex w-full mt-2", defaultClassNames.week),
|
|
1617
|
+
week_number_header: cn(
|
|
1618
|
+
"select-none w-(--cell-size)",
|
|
1619
|
+
defaultClassNames.week_number_header
|
|
1620
|
+
),
|
|
1621
|
+
week_number: cn(
|
|
1622
|
+
"text-[0.8rem] select-none text-muted-foreground",
|
|
1623
|
+
defaultClassNames.week_number
|
|
1624
|
+
),
|
|
1625
|
+
day: cn(
|
|
1626
|
+
"relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none",
|
|
1627
|
+
defaultClassNames.day
|
|
1628
|
+
),
|
|
1629
|
+
range_start: cn(
|
|
1630
|
+
"rounded-l-md bg-accent",
|
|
1631
|
+
defaultClassNames.range_start
|
|
1632
|
+
),
|
|
1633
|
+
range_middle: cn("rounded-none", defaultClassNames.range_middle),
|
|
1634
|
+
range_end: cn("rounded-r-md bg-accent", defaultClassNames.range_end),
|
|
1635
|
+
today: cn(
|
|
1636
|
+
"bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none",
|
|
1637
|
+
defaultClassNames.today
|
|
1638
|
+
),
|
|
1639
|
+
outside: cn(
|
|
1640
|
+
"text-muted-foreground aria-selected:text-muted-foreground",
|
|
1641
|
+
defaultClassNames.outside
|
|
1642
|
+
),
|
|
1643
|
+
disabled: cn(
|
|
1644
|
+
"text-muted-foreground opacity-50",
|
|
1645
|
+
defaultClassNames.disabled
|
|
1646
|
+
),
|
|
1647
|
+
hidden: cn("invisible", defaultClassNames.hidden),
|
|
1648
|
+
...classNames
|
|
1649
|
+
},
|
|
1650
|
+
components: {
|
|
1651
|
+
Root: ({ className: className2, rootRef, ...props2 }) => {
|
|
1652
|
+
return /* @__PURE__ */ jsx36(
|
|
1653
|
+
"div",
|
|
1654
|
+
{
|
|
1655
|
+
"data-slot": "calendar",
|
|
1656
|
+
ref: rootRef,
|
|
1657
|
+
className: cn(className2),
|
|
1658
|
+
...props2
|
|
1659
|
+
}
|
|
1660
|
+
);
|
|
1661
|
+
},
|
|
1662
|
+
Chevron: ({ className: className2, orientation, ...props2 }) => {
|
|
1663
|
+
if (orientation === "left") {
|
|
1664
|
+
return /* @__PURE__ */ jsx36(ChevronLeft, { className: cn("size-4", className2), ...props2 });
|
|
1665
|
+
}
|
|
1666
|
+
if (orientation === "right") {
|
|
1667
|
+
return /* @__PURE__ */ jsx36(
|
|
1668
|
+
ChevronRight,
|
|
1669
|
+
{
|
|
1670
|
+
className: cn("size-4", className2),
|
|
1671
|
+
...props2
|
|
1672
|
+
}
|
|
1673
|
+
);
|
|
1674
|
+
}
|
|
1675
|
+
return /* @__PURE__ */ jsx36(ChevronDown, { className: cn("size-4", className2), ...props2 });
|
|
1676
|
+
},
|
|
1677
|
+
DayButton: CalendarDayButton,
|
|
1678
|
+
WeekNumber: ({ children, ...props2 }) => {
|
|
1679
|
+
return /* @__PURE__ */ jsx36("td", { ...props2, children: /* @__PURE__ */ jsx36("div", { className: "flex size-(--cell-size) items-center justify-center text-center", children }) });
|
|
1680
|
+
},
|
|
1681
|
+
...components
|
|
1682
|
+
},
|
|
1683
|
+
...props
|
|
1684
|
+
}
|
|
1685
|
+
);
|
|
1686
|
+
}
|
|
1687
|
+
function CalendarDayButton({
|
|
1688
|
+
className,
|
|
1689
|
+
day,
|
|
1690
|
+
modifiers,
|
|
1691
|
+
...props
|
|
1692
|
+
}) {
|
|
1693
|
+
const defaultClassNames = getDefaultClassNames();
|
|
1694
|
+
const ref = React2.useRef(null);
|
|
1695
|
+
React2.useEffect(() => {
|
|
1696
|
+
if (modifiers.focused) ref.current?.focus();
|
|
1697
|
+
}, [modifiers.focused]);
|
|
1698
|
+
return /* @__PURE__ */ jsx36(
|
|
1699
|
+
Button,
|
|
1700
|
+
{
|
|
1701
|
+
ref,
|
|
1702
|
+
variant: "ghost",
|
|
1703
|
+
size: "icon",
|
|
1704
|
+
"data-day": day.date.toLocaleDateString(),
|
|
1705
|
+
"data-selected-single": modifiers.selected && !modifiers.range_start && !modifiers.range_end && !modifiers.range_middle,
|
|
1706
|
+
"data-range-start": modifiers.range_start,
|
|
1707
|
+
"data-range-end": modifiers.range_end,
|
|
1708
|
+
"data-range-middle": modifiers.range_middle,
|
|
1709
|
+
className: cn(
|
|
1710
|
+
"data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70",
|
|
1711
|
+
defaultClassNames.day,
|
|
1712
|
+
className
|
|
1713
|
+
),
|
|
1714
|
+
...props
|
|
1715
|
+
}
|
|
1716
|
+
);
|
|
1717
|
+
}
|
|
1718
|
+
|
|
1719
|
+
// src/components/ui/popover.tsx
|
|
1720
|
+
import * as PopoverPrimitive from "@radix-ui/react-popover";
|
|
1721
|
+
import { jsx as jsx37 } from "react/jsx-runtime";
|
|
1722
|
+
function Popover({
|
|
1723
|
+
...props
|
|
1724
|
+
}) {
|
|
1725
|
+
return /* @__PURE__ */ jsx37(PopoverPrimitive.Root, { "data-slot": "popover", ...props });
|
|
1726
|
+
}
|
|
1727
|
+
function PopoverTrigger({
|
|
1728
|
+
...props
|
|
1729
|
+
}) {
|
|
1730
|
+
return /* @__PURE__ */ jsx37(PopoverPrimitive.Trigger, { "data-slot": "popover-trigger", ...props });
|
|
1731
|
+
}
|
|
1732
|
+
function PopoverContent({
|
|
1733
|
+
className,
|
|
1734
|
+
align = "center",
|
|
1735
|
+
sideOffset = 4,
|
|
1736
|
+
...props
|
|
1737
|
+
}) {
|
|
1738
|
+
return /* @__PURE__ */ jsx37(PopoverPrimitive.Portal, { children: /* @__PURE__ */ jsx37(
|
|
1739
|
+
PopoverPrimitive.Content,
|
|
1740
|
+
{
|
|
1741
|
+
"data-slot": "popover-content",
|
|
1742
|
+
align,
|
|
1743
|
+
sideOffset,
|
|
1744
|
+
className: cn(
|
|
1745
|
+
"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 z-50 w-72 origin-(--radix-popover-content-transform-origin) rounded-md border p-4 shadow-md outline-hidden",
|
|
1746
|
+
className
|
|
1747
|
+
),
|
|
1748
|
+
...props
|
|
1749
|
+
}
|
|
1750
|
+
) });
|
|
1751
|
+
}
|
|
1752
|
+
|
|
1753
|
+
// src/components/Inputs/DateRange/DateRange.tsx
|
|
1754
|
+
import { Fragment as Fragment14, jsx as jsx38, jsxs as jsxs22 } from "react/jsx-runtime";
|
|
1755
|
+
var DateRange = ({ className, style, ...props }) => {
|
|
1756
|
+
const isDateRange = (val) => !!val && val.from instanceof Date;
|
|
1757
|
+
const [date, setDate] = React3.useState(
|
|
1758
|
+
isDateRange(props.value) ? props.value : {
|
|
1759
|
+
from: /* @__PURE__ */ new Date(),
|
|
1760
|
+
to: addDays(/* @__PURE__ */ new Date(), 7)
|
|
1761
|
+
}
|
|
1762
|
+
);
|
|
1763
|
+
const handleChange = (value) => {
|
|
1764
|
+
setDate(value);
|
|
1765
|
+
if (value) {
|
|
1766
|
+
props.onChange?.(value);
|
|
1767
|
+
}
|
|
1768
|
+
};
|
|
1769
|
+
return /* @__PURE__ */ jsxs22(Fragment14, { children: [
|
|
1770
|
+
/* @__PURE__ */ jsx38("div", { className, style, children: /* @__PURE__ */ jsxs22(Popover, { children: [
|
|
1771
|
+
/* @__PURE__ */ jsx38(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsx38(
|
|
1772
|
+
Button,
|
|
1773
|
+
{
|
|
1774
|
+
id: "date",
|
|
1775
|
+
variant: "outline",
|
|
1776
|
+
className: cn(
|
|
1777
|
+
"w-[300px] justify-start text-left font-normal text-[11px]",
|
|
1778
|
+
!date && "text-muted-foreground"
|
|
1779
|
+
),
|
|
1780
|
+
children: date?.from ? date.to ? /* @__PURE__ */ jsxs22(Fragment14, { children: [
|
|
1781
|
+
format(date.from, "LLL dd, y"),
|
|
1782
|
+
" -",
|
|
1783
|
+
" ",
|
|
1784
|
+
format(date.to, "LLL dd, y")
|
|
1785
|
+
] }) : format(date.from, "LLL dd, y") : /* @__PURE__ */ jsx38("span", { children: "Pick a date range" })
|
|
1786
|
+
}
|
|
1787
|
+
) }),
|
|
1788
|
+
/* @__PURE__ */ jsx38(PopoverContent, { className: "w-auto p-0", align: "start", children: /* @__PURE__ */ jsx38(
|
|
1789
|
+
Calendar2,
|
|
1790
|
+
{
|
|
1791
|
+
mode: "range",
|
|
1792
|
+
defaultMonth: date?.from,
|
|
1793
|
+
selected: date,
|
|
1794
|
+
onSelect: handleChange,
|
|
1795
|
+
numberOfMonths: 2
|
|
1796
|
+
}
|
|
1797
|
+
) })
|
|
1798
|
+
] }) }),
|
|
1799
|
+
props.errorMessage && /* @__PURE__ */ jsx38("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1800
|
+
] });
|
|
1801
|
+
};
|
|
1802
|
+
var DateRange_default = DateRange;
|
|
1803
|
+
|
|
1804
|
+
// src/components/Inputs/TextInputGroup/TextInputGroup.tsx
|
|
1805
|
+
import { Fragment as Fragment15, jsx as jsx39, jsxs as jsxs23 } from "react/jsx-runtime";
|
|
1806
|
+
var TextInputGroup = ({ className, style, prepend, append, ...props }) => {
|
|
1807
|
+
const placeholder = props.placeholder ?? "Placeholder text";
|
|
1808
|
+
const isEditable = props.isEditable ?? true;
|
|
1809
|
+
const isDisabled = props.isDisabled ?? false;
|
|
1810
|
+
const isReadonly = props.isReadonly ?? false;
|
|
1811
|
+
const isAutocomplete = props.isAutocomplete ?? false;
|
|
1812
|
+
const handleChange = (e) => {
|
|
1813
|
+
props.onChange?.(e);
|
|
1814
|
+
};
|
|
1815
|
+
return /* @__PURE__ */ jsxs23(Fragment15, { children: [
|
|
1816
|
+
/* @__PURE__ */ jsxs23(
|
|
1817
|
+
"div",
|
|
1818
|
+
{
|
|
1819
|
+
className: cn(
|
|
1820
|
+
"flex justify-start items-center relative border border-input rounded-md bg-transparent focus-within:ring-2 focus-within:ring-ring focus-within:border-primary",
|
|
1821
|
+
className,
|
|
1822
|
+
"p-0 m-0",
|
|
1823
|
+
props.errorMessage ? "border-red-500" : ""
|
|
1824
|
+
),
|
|
1825
|
+
children: [
|
|
1826
|
+
prepend && /* @__PURE__ */ jsx39("div", { className: "px-3 flex items-center bg-gray-500 text-white h-10 rounded-l-md", children: prepend }),
|
|
1827
|
+
/* @__PURE__ */ jsx39(
|
|
1828
|
+
Input,
|
|
1829
|
+
{
|
|
1830
|
+
id: props.name || "prepend-input",
|
|
1831
|
+
type: "url",
|
|
1832
|
+
name: props.name,
|
|
1833
|
+
value: props.value,
|
|
1834
|
+
className: cn(
|
|
1835
|
+
className,
|
|
1836
|
+
"rounded-none flex-1 border-none focus:ring-0"
|
|
1837
|
+
),
|
|
1838
|
+
style: {
|
|
1839
|
+
...style,
|
|
1840
|
+
borderColor: props.errorMessage ? "#f87171" : style?.borderColor
|
|
1841
|
+
},
|
|
1842
|
+
autoComplete: isAutocomplete ? "on" : "off",
|
|
1843
|
+
placeholder,
|
|
1844
|
+
onChange: handleChange,
|
|
1845
|
+
disabled: isDisabled || !isEditable,
|
|
1846
|
+
readOnly: isReadonly
|
|
1847
|
+
}
|
|
1848
|
+
),
|
|
1849
|
+
append && /* @__PURE__ */ jsx39("div", { className: "px-3 flex items-center bg-gray-500 text-white h-10 rounded-r-md", children: append })
|
|
1850
|
+
]
|
|
1851
|
+
}
|
|
1852
|
+
),
|
|
1853
|
+
props.errorMessage && /* @__PURE__ */ jsx39("p", { className: "mt-1 text-xs text-red-500", children: props.errorMessage })
|
|
1854
|
+
] });
|
|
1855
|
+
};
|
|
1856
|
+
var TextInputGroup_default = TextInputGroup;
|
|
1857
|
+
|
|
1858
|
+
// src/components/ui/data-table.tsx
|
|
1859
|
+
import {
|
|
1860
|
+
flexRender,
|
|
1861
|
+
getCoreRowModel,
|
|
1862
|
+
useReactTable
|
|
1863
|
+
} from "@tanstack/react-table";
|
|
1864
|
+
|
|
1865
|
+
// src/components/ui/table.tsx
|
|
1866
|
+
import { jsx as jsx40 } from "react/jsx-runtime";
|
|
1867
|
+
function Table({ className, ...props }) {
|
|
1868
|
+
return /* @__PURE__ */ jsx40(
|
|
1869
|
+
"div",
|
|
1870
|
+
{
|
|
1871
|
+
"data-slot": "table-container",
|
|
1872
|
+
className: "relative w-full overflow-x-auto rounded-md border border-gray-200 bg-white",
|
|
1873
|
+
children: /* @__PURE__ */ jsx40(
|
|
1874
|
+
"table",
|
|
1875
|
+
{
|
|
1876
|
+
"data-slot": "table",
|
|
1877
|
+
className: cn("w-full text-sm", className),
|
|
1878
|
+
...props
|
|
1879
|
+
}
|
|
1880
|
+
)
|
|
1881
|
+
}
|
|
1882
|
+
);
|
|
1883
|
+
}
|
|
1884
|
+
function TableHeader({ className, ...props }) {
|
|
1885
|
+
return /* @__PURE__ */ jsx40(
|
|
1886
|
+
"thead",
|
|
1887
|
+
{
|
|
1888
|
+
"data-slot": "table-header",
|
|
1889
|
+
className: cn(
|
|
1890
|
+
"bg-gray-100 text-gray-700 [&>tr]:border-b [&>tr]:border-gray-200 [&>tr>th]:border-r [&>tr>th]:border-gray-200 [&>tr>th]:last:border-r-0",
|
|
1891
|
+
className
|
|
1892
|
+
),
|
|
1893
|
+
...props
|
|
1894
|
+
}
|
|
1895
|
+
);
|
|
1896
|
+
}
|
|
1897
|
+
function TableBody({ className, ...props }) {
|
|
1898
|
+
return /* @__PURE__ */ jsx40(
|
|
1899
|
+
"tbody",
|
|
1900
|
+
{
|
|
1901
|
+
"data-slot": "table-body",
|
|
1902
|
+
className: cn(
|
|
1903
|
+
"[&>tr]:border-b [&>tr]:border-gray-200 [&>tr:last-child]:border-0 [&>tr>td]:border-r [&>tr>td]:border-gray-200 [&>tr>td]:last:border-r-0",
|
|
1904
|
+
className
|
|
1905
|
+
),
|
|
1906
|
+
...props
|
|
1907
|
+
}
|
|
1908
|
+
);
|
|
1909
|
+
}
|
|
1910
|
+
function TableRow({ className, ...props }) {
|
|
1911
|
+
return /* @__PURE__ */ jsx40(
|
|
1912
|
+
"tr",
|
|
1913
|
+
{
|
|
1914
|
+
"data-slot": "table-row",
|
|
1915
|
+
className: cn(
|
|
1916
|
+
"border-b border-gray-200 hover:bg-gray-50 transition-colors",
|
|
1917
|
+
className
|
|
1918
|
+
),
|
|
1919
|
+
...props
|
|
1920
|
+
}
|
|
1921
|
+
);
|
|
1922
|
+
}
|
|
1923
|
+
function TableHead({ className, ...props }) {
|
|
1924
|
+
return /* @__PURE__ */ jsx40(
|
|
1925
|
+
"th",
|
|
1926
|
+
{
|
|
1927
|
+
"data-slot": "table-head",
|
|
1928
|
+
className: cn(
|
|
1929
|
+
"h-12 px-6 text-left align-middle font-semibold whitespace-nowrap",
|
|
1930
|
+
className
|
|
1931
|
+
),
|
|
1932
|
+
...props
|
|
1933
|
+
}
|
|
1934
|
+
);
|
|
1935
|
+
}
|
|
1936
|
+
function TableCell({ className, ...props }) {
|
|
1937
|
+
return /* @__PURE__ */ jsx40(
|
|
1938
|
+
"td",
|
|
1939
|
+
{
|
|
1940
|
+
"data-slot": "table-cell",
|
|
1941
|
+
className: cn(
|
|
1942
|
+
"px-6 py-4 align-middle text-gray-700",
|
|
1943
|
+
className
|
|
1944
|
+
),
|
|
1945
|
+
...props
|
|
1946
|
+
}
|
|
1947
|
+
);
|
|
1948
|
+
}
|
|
1949
|
+
|
|
1950
|
+
// src/components/ui/data-table.tsx
|
|
1951
|
+
import { Fragment as Fragment16, jsx as jsx41, jsxs as jsxs24 } from "react/jsx-runtime";
|
|
1952
|
+
function DataTable({
|
|
1953
|
+
columns,
|
|
1954
|
+
rowActions,
|
|
1955
|
+
data,
|
|
1956
|
+
loading,
|
|
1957
|
+
getRowSelection,
|
|
1958
|
+
onCellClick,
|
|
1959
|
+
cellClickEnabled = () => false
|
|
1960
|
+
}) {
|
|
1961
|
+
const table = useReactTable({
|
|
1962
|
+
data,
|
|
1963
|
+
columns,
|
|
1964
|
+
enableRowSelection: true,
|
|
1965
|
+
onRowSelectionChange: getRowSelection ? (updaterOrValue) => {
|
|
1966
|
+
const value = typeof updaterOrValue === "function" ? updaterOrValue(table.getState().rowSelection) : updaterOrValue;
|
|
1967
|
+
getRowSelection(value);
|
|
1968
|
+
} : void 0,
|
|
1969
|
+
getCoreRowModel: getCoreRowModel()
|
|
1970
|
+
});
|
|
1971
|
+
const handleCellClick = (rowData, columnId) => {
|
|
1972
|
+
if (onCellClick) {
|
|
1973
|
+
onCellClick(rowData, columnId);
|
|
1974
|
+
}
|
|
1975
|
+
};
|
|
1976
|
+
return /* @__PURE__ */ jsx41("div", { className: "overflow-hidden rounded-md border w-full", children: /* @__PURE__ */ jsxs24(Table, { children: [
|
|
1977
|
+
/* @__PURE__ */ jsx41(TableHeader, { children: table.getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx41(TableRow, { children: headerGroup.headers.map((header) => {
|
|
1978
|
+
return /* @__PURE__ */ jsx41(TableHead, { children: header.isPlaceholder ? null : flexRender(
|
|
1979
|
+
header.column.columnDef.header,
|
|
1980
|
+
header.getContext()
|
|
1981
|
+
) }, header.id);
|
|
1982
|
+
}) }, headerGroup.id)) }),
|
|
1983
|
+
/* @__PURE__ */ jsx41(TableBody, { children: loading ? /* @__PURE__ */ jsx41(TableRow, { children: /* @__PURE__ */ jsx41(TableCell, { colSpan: columns.length, className: "h-24 text-center", children: "Loading..." }) }) : /* @__PURE__ */ jsx41(Fragment16, { children: table.getRowModel().rows?.length ? table.getRowModel().rows.map((row) => /* @__PURE__ */ jsxs24(
|
|
1984
|
+
TableRow,
|
|
1985
|
+
{
|
|
1986
|
+
"data-state": row.getIsSelected() && "selected",
|
|
1987
|
+
className: "relative group",
|
|
1988
|
+
children: [
|
|
1989
|
+
row.getVisibleCells().map((cell) => {
|
|
1990
|
+
const isCellClickable = cellClickEnabled(row.original, cell.column.id);
|
|
1991
|
+
const dynamicClass = cell.column.columnDef.meta?.cellClass || "";
|
|
1992
|
+
const dynamicStyle = cell.column.columnDef.meta?.cellStyle || {};
|
|
1993
|
+
return /* @__PURE__ */ jsx41(
|
|
1994
|
+
TableCell,
|
|
1995
|
+
{
|
|
1996
|
+
className: `${dynamicClass} ${isCellClickable ? "underline cursor-pointer" : ""}`,
|
|
1997
|
+
style: dynamicStyle,
|
|
1998
|
+
onClick: () => {
|
|
1999
|
+
if (isCellClickable) {
|
|
2000
|
+
handleCellClick(row.original, cell.column.id);
|
|
2001
|
+
}
|
|
2002
|
+
},
|
|
2003
|
+
children: flexRender(cell.column.columnDef.cell, cell.getContext())
|
|
2004
|
+
},
|
|
2005
|
+
cell.id
|
|
2006
|
+
);
|
|
2007
|
+
}),
|
|
2008
|
+
rowActions.length > 0 && /* @__PURE__ */ jsx41("div", { className: "absolute top-0 right-0 bg-white py-3 min-w-[100px] z-50 shadow-md flex items-center justify-center gap-3 p-2 opacity-0 group-hover:opacity-100 duration-300 h-full", children: rowActions.map((action, index) => /* @__PURE__ */ jsx41("p", { className: "text-[#383838] text-[12px] cursor-pointer font-[400]", children: action.header }, index)) })
|
|
2009
|
+
]
|
|
2010
|
+
},
|
|
2011
|
+
row.id
|
|
2012
|
+
)) : /* @__PURE__ */ jsx41(TableRow, { children: /* @__PURE__ */ jsx41(TableCell, { colSpan: columns.length, className: "h-24 text-center", children: "No results." }) }) }) })
|
|
2013
|
+
] }) });
|
|
2014
|
+
}
|
|
2015
|
+
|
|
2016
|
+
// src/components/ui/pagination.tsx
|
|
2017
|
+
import { jsx as jsx42, jsxs as jsxs25 } from "react/jsx-runtime";
|
|
2018
|
+
function Pagination({ className, ...props }) {
|
|
2019
|
+
return /* @__PURE__ */ jsx42(
|
|
2020
|
+
"nav",
|
|
2021
|
+
{
|
|
2022
|
+
role: "navigation",
|
|
2023
|
+
"aria-label": "pagination",
|
|
2024
|
+
"data-slot": "pagination",
|
|
2025
|
+
className: cn("mx-auto flex w-full justify-center", className),
|
|
2026
|
+
...props
|
|
2027
|
+
}
|
|
2028
|
+
);
|
|
2029
|
+
}
|
|
2030
|
+
function PaginationContent({
|
|
2031
|
+
className,
|
|
2032
|
+
...props
|
|
2033
|
+
}) {
|
|
2034
|
+
return /* @__PURE__ */ jsx42(
|
|
2035
|
+
"ul",
|
|
2036
|
+
{
|
|
2037
|
+
"data-slot": "pagination-content",
|
|
2038
|
+
className: cn("flex flex-row items-center gap-1", className),
|
|
2039
|
+
...props
|
|
2040
|
+
}
|
|
2041
|
+
);
|
|
2042
|
+
}
|
|
2043
|
+
function PaginationItem({ ...props }) {
|
|
2044
|
+
return /* @__PURE__ */ jsx42("li", { "data-slot": "pagination-item", ...props });
|
|
2045
|
+
}
|
|
2046
|
+
function PaginationLink({
|
|
2047
|
+
className,
|
|
2048
|
+
isActive,
|
|
2049
|
+
size = "icon",
|
|
2050
|
+
...props
|
|
2051
|
+
}) {
|
|
2052
|
+
return /* @__PURE__ */ jsx42(
|
|
2053
|
+
"a",
|
|
2054
|
+
{
|
|
2055
|
+
"aria-current": isActive ? "page" : void 0,
|
|
2056
|
+
"data-slot": "pagination-link",
|
|
2057
|
+
"data-active": isActive,
|
|
2058
|
+
className: cn(
|
|
2059
|
+
buttonVariants({
|
|
2060
|
+
variant: isActive ? "outline" : "ghost",
|
|
2061
|
+
size
|
|
2062
|
+
}),
|
|
2063
|
+
className
|
|
2064
|
+
),
|
|
2065
|
+
...props
|
|
2066
|
+
}
|
|
2067
|
+
);
|
|
2068
|
+
}
|
|
2069
|
+
function PaginationPrevious({
|
|
2070
|
+
className,
|
|
2071
|
+
...props
|
|
2072
|
+
}) {
|
|
2073
|
+
return /* @__PURE__ */ jsxs25(
|
|
2074
|
+
PaginationLink,
|
|
2075
|
+
{
|
|
2076
|
+
"aria-label": "Go to previous page",
|
|
2077
|
+
size: "default",
|
|
2078
|
+
className: cn("gap-1 px-2.5 sm:pl-2.5", className),
|
|
2079
|
+
...props,
|
|
2080
|
+
children: [
|
|
2081
|
+
/* @__PURE__ */ jsx42(ChevronLeft, {}),
|
|
2082
|
+
/* @__PURE__ */ jsx42("span", { className: "hidden sm:block", children: "Previous" })
|
|
2083
|
+
]
|
|
2084
|
+
}
|
|
2085
|
+
);
|
|
2086
|
+
}
|
|
2087
|
+
function PaginationNext({
|
|
2088
|
+
className,
|
|
2089
|
+
...props
|
|
2090
|
+
}) {
|
|
2091
|
+
return /* @__PURE__ */ jsxs25(
|
|
2092
|
+
PaginationLink,
|
|
2093
|
+
{
|
|
2094
|
+
"aria-label": "Go to next page",
|
|
2095
|
+
size: "default",
|
|
2096
|
+
className: cn("gap-1 px-2.5 sm:pr-2.5", className),
|
|
2097
|
+
...props,
|
|
2098
|
+
children: [
|
|
2099
|
+
/* @__PURE__ */ jsx42("span", { className: "hidden sm:block", children: "Next" }),
|
|
2100
|
+
/* @__PURE__ */ jsx42(ChevronRight, {})
|
|
2101
|
+
]
|
|
2102
|
+
}
|
|
2103
|
+
);
|
|
2104
|
+
}
|
|
2105
|
+
function PaginationEllipsis({
|
|
2106
|
+
className,
|
|
2107
|
+
...props
|
|
2108
|
+
}) {
|
|
2109
|
+
return /* @__PURE__ */ jsxs25(
|
|
2110
|
+
"span",
|
|
2111
|
+
{
|
|
2112
|
+
"aria-hidden": true,
|
|
2113
|
+
"data-slot": "pagination-ellipsis",
|
|
2114
|
+
className: cn("flex size-9 items-center justify-center", className),
|
|
2115
|
+
...props,
|
|
2116
|
+
children: [
|
|
2117
|
+
/* @__PURE__ */ jsx42(Ellipsis, { className: "size-4" }),
|
|
2118
|
+
/* @__PURE__ */ jsx42("span", { className: "sr-only", children: "More pages" })
|
|
2119
|
+
]
|
|
2120
|
+
}
|
|
2121
|
+
);
|
|
2122
|
+
}
|
|
2123
|
+
|
|
2124
|
+
// src/components/DataDisplay/Pagination/Pagination.tsx
|
|
2125
|
+
import { jsx as jsx43, jsxs as jsxs26 } from "react/jsx-runtime";
|
|
2126
|
+
var CustomPagination = ({
|
|
2127
|
+
totalPages,
|
|
2128
|
+
currentPage,
|
|
2129
|
+
onPageChange,
|
|
2130
|
+
maxVisiblePages = 5
|
|
2131
|
+
}) => {
|
|
2132
|
+
const getPageNumbers = () => {
|
|
2133
|
+
const pages = [];
|
|
2134
|
+
if (totalPages <= maxVisiblePages) {
|
|
2135
|
+
return Array.from({ length: totalPages }, (_, i) => i + 1);
|
|
2136
|
+
}
|
|
2137
|
+
const leftSiblingIndex = Math.max(currentPage - 1, 1);
|
|
2138
|
+
const rightSiblingIndex = Math.min(currentPage + 1, totalPages);
|
|
2139
|
+
const shouldShowLeftDots = leftSiblingIndex > 2;
|
|
2140
|
+
const shouldShowRightDots = rightSiblingIndex < totalPages - 1;
|
|
2141
|
+
if (!shouldShowLeftDots && shouldShowRightDots) {
|
|
2142
|
+
const leftRange = Array.from({ length: 3 }, (_, i) => i + 1);
|
|
2143
|
+
return [...leftRange, "...", totalPages];
|
|
2144
|
+
}
|
|
2145
|
+
if (shouldShowLeftDots && !shouldShowRightDots) {
|
|
2146
|
+
const rightRange = Array.from(
|
|
2147
|
+
{ length: 3 },
|
|
2148
|
+
(_, i) => totalPages - 2 + i
|
|
2149
|
+
);
|
|
2150
|
+
return [1, "...", ...rightRange];
|
|
2151
|
+
}
|
|
2152
|
+
if (shouldShowLeftDots && shouldShowRightDots) {
|
|
2153
|
+
const middleRange = Array.from(
|
|
2154
|
+
{ length: 3 },
|
|
2155
|
+
(_, i) => leftSiblingIndex + i
|
|
2156
|
+
);
|
|
2157
|
+
return [1, "...", ...middleRange, "...", totalPages];
|
|
2158
|
+
}
|
|
2159
|
+
return pages;
|
|
2160
|
+
};
|
|
2161
|
+
const handlePageChange = (page) => {
|
|
2162
|
+
if (page >= 1 && page <= totalPages && page !== currentPage) {
|
|
2163
|
+
onPageChange(page);
|
|
2164
|
+
}
|
|
2165
|
+
};
|
|
2166
|
+
const pageNumbers = getPageNumbers();
|
|
2167
|
+
return /* @__PURE__ */ jsx43(Pagination, { children: /* @__PURE__ */ jsxs26(PaginationContent, { children: [
|
|
2168
|
+
/* @__PURE__ */ jsx43(PaginationItem, { children: /* @__PURE__ */ jsx43(
|
|
2169
|
+
PaginationPrevious,
|
|
2170
|
+
{
|
|
2171
|
+
onClick: () => handlePageChange(currentPage - 1),
|
|
2172
|
+
className: currentPage === 1 ? "pointer-events-none opacity-50" : "cursor-pointer"
|
|
2173
|
+
}
|
|
2174
|
+
) }),
|
|
2175
|
+
pageNumbers.map((pageNumber, index) => /* @__PURE__ */ jsx43(PaginationItem, { children: pageNumber === "..." ? /* @__PURE__ */ jsx43(PaginationEllipsis, {}) : /* @__PURE__ */ jsx43(
|
|
2176
|
+
PaginationLink,
|
|
2177
|
+
{
|
|
2178
|
+
onClick: () => handlePageChange(pageNumber),
|
|
2179
|
+
isActive: currentPage === pageNumber,
|
|
2180
|
+
className: "cursor-pointer",
|
|
2181
|
+
children: pageNumber
|
|
2182
|
+
}
|
|
2183
|
+
) }, index)),
|
|
2184
|
+
/* @__PURE__ */ jsx43(PaginationItem, { children: /* @__PURE__ */ jsx43(
|
|
2185
|
+
PaginationNext,
|
|
2186
|
+
{
|
|
2187
|
+
onClick: () => handlePageChange(currentPage + 1),
|
|
2188
|
+
className: currentPage === totalPages ? "pointer-events-none opacity-50" : "cursor-pointer"
|
|
2189
|
+
}
|
|
2190
|
+
) })
|
|
2191
|
+
] }) });
|
|
2192
|
+
};
|
|
2193
|
+
var Pagination_default = CustomPagination;
|
|
2194
|
+
|
|
2195
|
+
// src/components/DataDisplay/Table/Table.tsx
|
|
2196
|
+
import { useState as useState3 } from "react";
|
|
2197
|
+
import { jsx as jsx44, jsxs as jsxs27 } from "react/jsx-runtime";
|
|
2198
|
+
var Table2 = ({
|
|
2199
|
+
columns,
|
|
2200
|
+
data,
|
|
2201
|
+
rowActions,
|
|
2202
|
+
className,
|
|
2203
|
+
style,
|
|
2204
|
+
pagination = false,
|
|
2205
|
+
itemsPerPage = 10,
|
|
2206
|
+
onPageChange,
|
|
2207
|
+
loading = false,
|
|
2208
|
+
totalRecords = 0,
|
|
2209
|
+
...props
|
|
2210
|
+
}) => {
|
|
2211
|
+
const rawColumns = Array.isArray(columns) ? columns : [];
|
|
2212
|
+
const rawData = Array.isArray(data) ? data : [];
|
|
2213
|
+
const rawRowActions = Array.isArray(rowActions) ? rowActions : [];
|
|
2214
|
+
const [currentPage, setCurrentPage] = useState3(1);
|
|
2215
|
+
const enablePagination = pagination && totalRecords > itemsPerPage;
|
|
2216
|
+
const handlePageChange = (page) => {
|
|
2217
|
+
setCurrentPage(page);
|
|
2218
|
+
onPageChange?.(page);
|
|
2219
|
+
};
|
|
2220
|
+
const paginatedData = enablePagination ? rawData.slice((currentPage - 1) * itemsPerPage, currentPage * itemsPerPage) : rawData;
|
|
2221
|
+
return /* @__PURE__ */ jsxs27("div", { className: `${className} space-y-3`, style, children: [
|
|
2222
|
+
/* @__PURE__ */ jsx44(
|
|
2223
|
+
DataTable,
|
|
2224
|
+
{
|
|
2225
|
+
...props,
|
|
2226
|
+
columns: rawColumns,
|
|
2227
|
+
data: paginatedData,
|
|
2228
|
+
rowActions: rawRowActions,
|
|
2229
|
+
loading
|
|
2230
|
+
}
|
|
2231
|
+
),
|
|
2232
|
+
enablePagination && /* @__PURE__ */ jsx44(
|
|
2233
|
+
Pagination_default,
|
|
2234
|
+
{
|
|
2235
|
+
totalPages: Math.ceil(totalRecords / itemsPerPage),
|
|
2236
|
+
currentPage,
|
|
2237
|
+
onPageChange: handlePageChange
|
|
2238
|
+
}
|
|
2239
|
+
)
|
|
2240
|
+
] });
|
|
2241
|
+
};
|
|
2242
|
+
var Table_default = Table2;
|
|
2243
|
+
|
|
2244
|
+
// src/components/Navigation/Tabs/Tabs.tsx
|
|
2245
|
+
import { jsx as jsx45, jsxs as jsxs28 } from "react/jsx-runtime";
|
|
2246
|
+
var Tabs = ({ className, style, tabs, verticalMenu, LinkComponent, pathname, canvasMode }) => {
|
|
2247
|
+
const rawTabs = Array.isArray(tabs) ? tabs : [];
|
|
2248
|
+
const baseClasses = "text-[12px] text-foreground p-2 text-center rounded-md transition-colors";
|
|
2249
|
+
const activeClasses = "bg-white/10 text-white";
|
|
2250
|
+
const hoverClasses = "hover:bg-white/5";
|
|
2251
|
+
const isActive = (path) => {
|
|
2252
|
+
if (!path) return false;
|
|
2253
|
+
return pathname === path || path !== "/" && pathname?.startsWith(path);
|
|
2254
|
+
};
|
|
2255
|
+
const renderDesktopTab = (tab, index) => {
|
|
2256
|
+
const finalClasses = [baseClasses, isActive(tab.url) ? activeClasses : hoverClasses, tab.className || ""].join(" ");
|
|
2257
|
+
if (Array.isArray(tab.children) && tab.children.length > 0 && tab.isDropDown) {
|
|
2258
|
+
return /* @__PURE__ */ jsxs28(DropdownMenu, { children: [
|
|
2259
|
+
/* @__PURE__ */ jsxs28(DropdownMenuTrigger, { className: `${finalClasses} inline-flex items-center gap-1`, children: [
|
|
2260
|
+
tab.header,
|
|
2261
|
+
/* @__PURE__ */ jsx45(ChevronDown, { className: "h-4 w-4 opacity-80" })
|
|
2262
|
+
] }),
|
|
2263
|
+
/* @__PURE__ */ jsx45(
|
|
2264
|
+
DropdownMenuContent,
|
|
2265
|
+
{
|
|
2266
|
+
align: "start",
|
|
2267
|
+
sideOffset: 6,
|
|
2268
|
+
className: "z-50 min-w-[160px] rounded-md border border-gray-200 bg-white p-1 shadow-lg",
|
|
2269
|
+
children: tab.children.map((item) => /* @__PURE__ */ jsx45(
|
|
2270
|
+
DropdownMenuItem,
|
|
2271
|
+
{
|
|
2272
|
+
asChild: true,
|
|
2273
|
+
className: "cursor-pointer rounded-sm px-3 py-2 text-[12px] text-gray-800 hover:bg-gray-100 focus:bg-gray-100",
|
|
2274
|
+
children: LinkComponent ? /* @__PURE__ */ jsx45(LinkComponent, { href: item.url || "#", children: item.header }) : item.header
|
|
2275
|
+
},
|
|
2276
|
+
item.id
|
|
2277
|
+
))
|
|
2278
|
+
}
|
|
2279
|
+
)
|
|
2280
|
+
] }, index);
|
|
2281
|
+
}
|
|
2282
|
+
return tab.url && LinkComponent ? /* @__PURE__ */ jsx45(LinkComponent, { href: tab.url, className: finalClasses, style: tab.style, children: tab.header }, index) : /* @__PURE__ */ jsx45("div", { className: finalClasses, style: tab.style, role: "button", tabIndex: 0, children: tab.header }, index);
|
|
2283
|
+
};
|
|
2284
|
+
const renderMobileMenu = () => /* @__PURE__ */ jsxs28(DropdownMenu, { children: [
|
|
2285
|
+
/* @__PURE__ */ jsxs28(DropdownMenuTrigger, { className: "flex items-center gap-2 px-3 py-2 rounded-md bg-white/10 text-white text-sm", children: [
|
|
2286
|
+
/* @__PURE__ */ jsx45(Menu, { className: "h-4 w-4" }),
|
|
2287
|
+
"Menu"
|
|
2288
|
+
] }),
|
|
2289
|
+
/* @__PURE__ */ jsx45(
|
|
2290
|
+
DropdownMenuContent,
|
|
2291
|
+
{
|
|
2292
|
+
align: "start",
|
|
2293
|
+
sideOffset: 6,
|
|
2294
|
+
className: "z-50 w-56 rounded-md border border-gray-200 bg-white p-1 shadow-lg",
|
|
2295
|
+
children: rawTabs.map((tab, i) => {
|
|
2296
|
+
const hasChildren = Array.isArray(tab.children) && tab.children.length > 0 && tab.isDropDown;
|
|
2297
|
+
if (hasChildren) {
|
|
2298
|
+
return /* @__PURE__ */ jsxs28(DropdownMenuSub, { children: [
|
|
2299
|
+
/* @__PURE__ */ jsx45(DropdownMenuSubTrigger, { className: "flex items-center justify-between cursor-pointer rounded-sm px-3 py-2 text-[13px] text-foreground hover:text-foreground", children: tab.header }),
|
|
2300
|
+
/* @__PURE__ */ jsx45(DropdownMenuSubContent, { className: "bg-white border shadow-lg rounded-md p-1", children: tab.children.map((item) => /* @__PURE__ */ jsx45(
|
|
2301
|
+
DropdownMenuItem,
|
|
2302
|
+
{
|
|
2303
|
+
asChild: true,
|
|
2304
|
+
className: "cursor-pointer rounded-sm px-3 py-2 text-[12px] text-gray-800 hover:bg-gray-100",
|
|
2305
|
+
children: LinkComponent && item.url ? /* @__PURE__ */ jsx45(LinkComponent, { href: item.url || "#", children: item.header }) : item.header
|
|
2306
|
+
},
|
|
2307
|
+
item.id
|
|
2308
|
+
)) })
|
|
2309
|
+
] }, i);
|
|
2310
|
+
}
|
|
2311
|
+
return /* @__PURE__ */ jsx45(
|
|
2312
|
+
DropdownMenuItem,
|
|
2313
|
+
{
|
|
2314
|
+
asChild: true,
|
|
2315
|
+
className: "cursor-pointer rounded-sm px-3 py-2 text-[13px] text-gray-800 hover:bg-gray-100",
|
|
2316
|
+
children: LinkComponent && tab.url ? /* @__PURE__ */ jsx45(LinkComponent, { href: tab.url || "#", children: tab.header }) : tab.header
|
|
2317
|
+
},
|
|
2318
|
+
i
|
|
2319
|
+
);
|
|
2320
|
+
})
|
|
2321
|
+
}
|
|
2322
|
+
)
|
|
2323
|
+
] });
|
|
2324
|
+
const forceMobile = canvasMode === "mobile" || canvasMode === "tablet";
|
|
2325
|
+
const forceDesktop = canvasMode === "desktop";
|
|
2326
|
+
return /* @__PURE__ */ jsxs28("div", { className, style, children: [
|
|
2327
|
+
forceDesktop && /* @__PURE__ */ jsx45("div", { className: "hidden md:flex", children: /* @__PURE__ */ jsx45("div", { className: `flex gap-2 ${verticalMenu ? "flex-col items-start" : "flex-row"}`, children: rawTabs.map(renderDesktopTab) }) }),
|
|
2328
|
+
forceMobile && /* @__PURE__ */ jsx45("div", { children: renderMobileMenu() }),
|
|
2329
|
+
/* @__PURE__ */ jsx45("div", { className: "md:hidden", children: renderMobileMenu() })
|
|
2330
|
+
] });
|
|
2331
|
+
};
|
|
2332
|
+
var Tabs_default = Tabs;
|
|
2333
|
+
|
|
2334
|
+
// src/components/Navigation/Stages/Stages.tsx
|
|
2335
|
+
import React4 from "react";
|
|
2336
|
+
import { jsx as jsx46, jsxs as jsxs29 } from "react/jsx-runtime";
|
|
2337
|
+
var StagesComponent = ({ stages, isShowBtn, buttonText, className, style }) => {
|
|
2338
|
+
return /* @__PURE__ */ jsx46("div", { className, style, children: /* @__PURE__ */ jsxs29("div", { className: "flex items-center justify-between bg-gray-50 p-2 rounded-lg border border-gray-200 w-full", children: [
|
|
2339
|
+
/* @__PURE__ */ jsx46("div", { className: "flex items-center", children: /* @__PURE__ */ jsx46("button", { className: "p-2 hover:bg-gray-100 rounded", children: /* @__PURE__ */ jsx46("svg", { className: "w-4 h-4 text-gray-600", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24", children: /* @__PURE__ */ jsx46("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M19 9l-7 7-7-7" }) }) }) }),
|
|
2340
|
+
/* @__PURE__ */ jsx46("div", { className: "flex items-center flex-1 px-2", children: stages?.length > 0 && stages?.map((stage, index) => /* @__PURE__ */ jsxs29(React4.Fragment, { children: [
|
|
2341
|
+
/* @__PURE__ */ jsx46(
|
|
2342
|
+
"button",
|
|
2343
|
+
{
|
|
2344
|
+
className: `
|
|
2345
|
+
min-w-[120px] px-4 py-2 rounded-full text-sm font-medium transition-colors duration-200 whitespace-nowrap ${stage.isActive ? "bg-[#034486] text-white shadow-md" : "bg-white text-gray-700 hover:bg-gray-100 border border-gray-200"}`,
|
|
2346
|
+
children: stage.header
|
|
2347
|
+
}
|
|
2348
|
+
),
|
|
2349
|
+
index < stages.length - 1 && /* @__PURE__ */ jsx46("div", { className: "flex-shrink-0 w-3 h-px bg-gray-300" })
|
|
2350
|
+
] }, stage.id)) }),
|
|
2351
|
+
isShowBtn && /* @__PURE__ */ jsx46("div", { className: "flex items-center", children: /* @__PURE__ */ jsx46("button", { className: "bg-[#034486] text-white px-6 py-2 rounded-lg text-sm font-medium transition-colors duration-200 shadow-sm", children: buttonText }) })
|
|
2352
|
+
] }) });
|
|
2353
|
+
};
|
|
2354
|
+
var Stages_default = StagesComponent;
|
|
2355
|
+
|
|
2356
|
+
// src/components/Navigation/Spacer/Spacer.tsx
|
|
2357
|
+
import { jsx as jsx47 } from "react/jsx-runtime";
|
|
2358
|
+
var Spacer = ({ className, style }) => {
|
|
2359
|
+
return /* @__PURE__ */ jsx47("div", { className: `${className}`, style });
|
|
2360
|
+
};
|
|
2361
|
+
var Spacer_default = Spacer;
|
|
2362
|
+
|
|
2363
|
+
// src/components/Navigation/Profile/Profile.tsx
|
|
2364
|
+
import { jsx as jsx48, jsxs as jsxs30 } from "react/jsx-runtime";
|
|
2365
|
+
|
|
2366
|
+
// src/components/Navigation/Notification/Notification.tsx
|
|
2367
|
+
import { jsx as jsx49, jsxs as jsxs31 } from "react/jsx-runtime";
|
|
2368
|
+
|
|
2369
|
+
// src/components/Navigation/Logo/Logo.tsx
|
|
2370
|
+
import { jsx as jsx50 } from "react/jsx-runtime";
|
|
2371
|
+
|
|
2372
|
+
// src/components/ui/avatar.tsx
|
|
2373
|
+
import * as React5 from "react";
|
|
2374
|
+
import * as AvatarPrimitive from "@radix-ui/react-avatar";
|
|
2375
|
+
import { jsx as jsx51 } from "react/jsx-runtime";
|
|
2376
|
+
var Avatar = React5.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx51(
|
|
2377
|
+
AvatarPrimitive.Root,
|
|
2378
|
+
{
|
|
2379
|
+
ref,
|
|
2380
|
+
className: cn(
|
|
2381
|
+
"relative flex h-10 w-10 shrink-0 overflow-hidden rounded-full",
|
|
2382
|
+
className
|
|
2383
|
+
),
|
|
2384
|
+
...props
|
|
2385
|
+
}
|
|
2386
|
+
));
|
|
2387
|
+
Avatar.displayName = AvatarPrimitive.Root.displayName;
|
|
2388
|
+
var AvatarImage = React5.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx51(
|
|
2389
|
+
AvatarPrimitive.Image,
|
|
2390
|
+
{
|
|
2391
|
+
ref,
|
|
2392
|
+
className: cn("aspect-square h-full w-full", className),
|
|
2393
|
+
...props
|
|
2394
|
+
}
|
|
2395
|
+
));
|
|
2396
|
+
AvatarImage.displayName = AvatarPrimitive.Image.displayName;
|
|
2397
|
+
var AvatarFallback = React5.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx51(
|
|
2398
|
+
AvatarPrimitive.Fallback,
|
|
2399
|
+
{
|
|
2400
|
+
ref,
|
|
2401
|
+
className: cn(
|
|
2402
|
+
"flex h-full w-full items-center justify-center rounded-full bg-muted",
|
|
2403
|
+
className
|
|
2404
|
+
),
|
|
2405
|
+
...props
|
|
2406
|
+
}
|
|
2407
|
+
));
|
|
2408
|
+
AvatarFallback.displayName = AvatarPrimitive.Fallback.displayName;
|
|
2409
|
+
|
|
2410
|
+
// src/components/Navigation/Navbar/Navbar.tsx
|
|
2411
|
+
import { Fragment as Fragment17, jsx as jsx52, jsxs as jsxs32 } from "react/jsx-runtime";
|
|
2412
|
+
function Navbar({
|
|
2413
|
+
style,
|
|
2414
|
+
badgeType,
|
|
2415
|
+
badgeCount = 0,
|
|
2416
|
+
hideBadgeWhenZero,
|
|
2417
|
+
profileType,
|
|
2418
|
+
showName,
|
|
2419
|
+
imageUrl,
|
|
2420
|
+
altText = "Logo",
|
|
2421
|
+
canvasMode = "desktop",
|
|
2422
|
+
LinkComponent,
|
|
2423
|
+
ImageComponent,
|
|
2424
|
+
list = [],
|
|
2425
|
+
userName = "Guest User"
|
|
2426
|
+
}) {
|
|
2427
|
+
const isMobileView = canvasMode === "mobile" || canvasMode === "tablet";
|
|
2428
|
+
return /* @__PURE__ */ jsx52("nav", { className: "w-full border-b bg-white shadow-sm", style, children: /* @__PURE__ */ jsxs32("div", { className: "mx-auto flex max-w-7xl items-center justify-between px-4 py-2", children: [
|
|
2429
|
+
LinkComponent && ImageComponent ? /* @__PURE__ */ jsx52(LinkComponent, { href: "/", className: "flex items-center space-x-2", children: imageUrl ? /* @__PURE__ */ jsx52(ImageComponent, { src: imageUrl, alt: altText, width: 200, height: 200 }) : /* @__PURE__ */ jsx52("span", { className: "font-semibold text-blue-700", children: "Logo" }) }) : /* @__PURE__ */ jsx52("span", { className: "font-semibold text-blue-700", children: "Logo" }),
|
|
2430
|
+
!isMobileView && LinkComponent && /* @__PURE__ */ jsx52("div", { className: "flex items-center space-x-6 sm:hidden md:flex", children: list.map((item) => /* @__PURE__ */ jsx52(
|
|
2431
|
+
LinkComponent,
|
|
2432
|
+
{
|
|
2433
|
+
href: item.url || "#",
|
|
2434
|
+
className: "text-sm font-medium text-gray-600 hover:text-gray-900 transition-colors",
|
|
2435
|
+
children: item.header
|
|
2436
|
+
},
|
|
2437
|
+
item.id
|
|
2438
|
+
)) }),
|
|
2439
|
+
/* @__PURE__ */ jsxs32("div", { className: "flex items-center space-x-3", children: [
|
|
2440
|
+
!isMobileView ? /* @__PURE__ */ jsx52("div", { className: "flex-1 px-6", children: /* @__PURE__ */ jsxs32("div", { className: "relative w-full max-w-md border border-gray-300 rounded-md", children: [
|
|
2441
|
+
/* @__PURE__ */ jsx52(Search, { className: "absolute left-3 top-1/2 -translate-y-1/2 h-4 w-4 text-gray-400" }),
|
|
2442
|
+
/* @__PURE__ */ jsx52(Input, { placeholder: "Search", className: "pl-9 text-gray-400" })
|
|
2443
|
+
] }) }) : /* @__PURE__ */ jsx52(
|
|
2444
|
+
Button,
|
|
2445
|
+
{
|
|
2446
|
+
variant: "ghost",
|
|
2447
|
+
size: "icon",
|
|
2448
|
+
className: "border border-gray-400",
|
|
2449
|
+
children: /* @__PURE__ */ jsx52(Search, { className: "h-5 w-5 text-gray-400" })
|
|
2450
|
+
}
|
|
2451
|
+
),
|
|
2452
|
+
/* @__PURE__ */ jsxs32("div", { className: "relative bg-[#E9E9E9] rounded-md", children: [
|
|
2453
|
+
/* @__PURE__ */ jsx52(Button, { variant: "ghost", size: "icon", children: /* @__PURE__ */ jsx52(Bell, { className: "h-5 w-5 text-[#1C1B1F]" }) }),
|
|
2454
|
+
badgeType === "number" && !(hideBadgeWhenZero && badgeCount === 0) && badgeCount > 0 ? /* @__PURE__ */ jsx52("span", { className: "absolute -top-1 -right-1 flex h-4 w-4 items-center justify-center rounded-full bg-red-500 text-[10px] text-white leading-8", children: badgeCount }) : /* @__PURE__ */ jsx52("span", { className: "absolute -top-1 -right-1 flex h-2 w-2 items-center justify-center rounded-full bg-red-500" })
|
|
2455
|
+
] }),
|
|
2456
|
+
/* @__PURE__ */ jsxs32(DropdownMenu, { children: [
|
|
2457
|
+
/* @__PURE__ */ jsx52(DropdownMenuTrigger, { asChild: true, children: /* @__PURE__ */ jsxs32("div", { className: "flex items-center space-x-2", children: [
|
|
2458
|
+
!isMobileView && showName && /* @__PURE__ */ jsx52("h4", { className: "text-[#000000] text-[13px] font-[500] mb-0", children: userName }),
|
|
2459
|
+
!isMobileView ? /* @__PURE__ */ jsxs32(Fragment17, { children: [
|
|
2460
|
+
/* @__PURE__ */ jsx52(Avatar, { className: "cursor-pointer h-8 w-8 text-gray-900", children: profileType === "avatar" ? /* @__PURE__ */ jsx52(
|
|
2461
|
+
AvatarImage,
|
|
2462
|
+
{
|
|
2463
|
+
src: "/images/appbuilder/toolset/profile.svg",
|
|
2464
|
+
alt: "Profile"
|
|
2465
|
+
}
|
|
2466
|
+
) : /* @__PURE__ */ jsx52("div", { className: "w-8 h-8 bg-[#12715b] rounded-full text-[#fff] text-center text-[11px] flex items-center justify-center", children: userName && getInitials(userName) }) }),
|
|
2467
|
+
/* @__PURE__ */ jsx52(
|
|
2468
|
+
Button,
|
|
2469
|
+
{
|
|
2470
|
+
variant: "ghost",
|
|
2471
|
+
size: "icon",
|
|
2472
|
+
className: "text-gray-900 md:hidden",
|
|
2473
|
+
children: /* @__PURE__ */ jsx52(Menu, { className: "h-6 w-6" })
|
|
2474
|
+
}
|
|
2475
|
+
)
|
|
2476
|
+
] }) : /* @__PURE__ */ jsx52(
|
|
2477
|
+
Button,
|
|
2478
|
+
{
|
|
2479
|
+
variant: "ghost",
|
|
2480
|
+
size: "icon",
|
|
2481
|
+
className: "text-gray-900",
|
|
2482
|
+
children: /* @__PURE__ */ jsx52(Menu, { className: "h-6 w-6" })
|
|
2483
|
+
}
|
|
2484
|
+
)
|
|
2485
|
+
] }) }),
|
|
2486
|
+
/* @__PURE__ */ jsxs32(DropdownMenuContent, { align: "end", className: "bg-white", children: [
|
|
2487
|
+
/* @__PURE__ */ jsx52(DropdownMenuLabel, { className: "text-black", children: "My Account" }),
|
|
2488
|
+
/* @__PURE__ */ jsx52(DropdownMenuSeparator, {}),
|
|
2489
|
+
LinkComponent && /* @__PURE__ */ jsxs32(Fragment17, { children: [
|
|
2490
|
+
/* @__PURE__ */ jsx52(DropdownMenuItem, { className: "text-black", children: /* @__PURE__ */ jsx52(LinkComponent, { href: "/profile", children: "Profile" }) }),
|
|
2491
|
+
/* @__PURE__ */ jsx52(DropdownMenuItem, { className: "text-black", children: /* @__PURE__ */ jsx52(LinkComponent, { href: "/settings", children: "Settings" }) }),
|
|
2492
|
+
/* @__PURE__ */ jsx52(DropdownMenuItem, { className: "text-black", children: /* @__PURE__ */ jsx52(LinkComponent, { href: "/logout", children: "Logout" }) }),
|
|
2493
|
+
list && list.length > 0 && /* @__PURE__ */ jsxs32(Fragment17, { children: [
|
|
2494
|
+
/* @__PURE__ */ jsx52("div", { className: "w-full bg-[#656565] opacity-30 h-[1px] my-2" }),
|
|
2495
|
+
/* @__PURE__ */ jsx52(DropdownMenuLabel, { className: "text-black", children: "Main Menu" }),
|
|
2496
|
+
list.map((item) => /* @__PURE__ */ jsx52(DropdownMenuItem, { className: "text-black", children: /* @__PURE__ */ jsx52(LinkComponent, { href: item.url || "#", children: item.header }) }, item.id))
|
|
2497
|
+
] })
|
|
2498
|
+
] })
|
|
2499
|
+
] })
|
|
2500
|
+
] })
|
|
2501
|
+
] })
|
|
2502
|
+
] }) });
|
|
2503
|
+
}
|
|
2504
|
+
|
|
2505
|
+
// src/components/Chart/BarChart.tsx
|
|
2506
|
+
import { BarChart, Bar, Area, AreaChart, XAxis, YAxis, CartesianGrid, Tooltip, ResponsiveContainer, Legend } from "recharts";
|
|
2507
|
+
import { jsx as jsx53, jsxs as jsxs33 } from "react/jsx-runtime";
|
|
2508
|
+
var ChartComponent = ({ className, style, ...props }) => {
|
|
2509
|
+
const data = Array.isArray(props?.data) ? props.data : [];
|
|
2510
|
+
const chartType = props.chartType || "bar";
|
|
2511
|
+
const legendsPosition = props.legendsPosition === "middle" || props.legendsPosition === "bottom" ? props.legendsPosition : "top";
|
|
2512
|
+
return /* @__PURE__ */ jsx53("div", { className: `${className} h-[400px]`, style, children: data.length > 0 && /* @__PURE__ */ jsx53(ResponsiveContainer, { width: "100%", height: "100%", children: chartType === "bar" ? /* @__PURE__ */ jsxs33(BarChart, { data, children: [
|
|
2513
|
+
/* @__PURE__ */ jsx53(CartesianGrid, { strokeDasharray: "3 3" }),
|
|
2514
|
+
/* @__PURE__ */ jsx53(XAxis, { dataKey: "name" }),
|
|
2515
|
+
/* @__PURE__ */ jsx53(YAxis, {}),
|
|
2516
|
+
/* @__PURE__ */ jsx53(Tooltip, {}),
|
|
2517
|
+
/* @__PURE__ */ jsx53(Legend, { verticalAlign: legendsPosition, align: "center" }),
|
|
2518
|
+
/* @__PURE__ */ jsx53(Bar, { dataKey: "value", fill: "#00695C" })
|
|
2519
|
+
] }) : /* @__PURE__ */ jsxs33(AreaChart, { data, children: [
|
|
2520
|
+
/* @__PURE__ */ jsx53("defs", { children: /* @__PURE__ */ jsxs33("linearGradient", { id: "colorCount", x1: "0", y1: "0", x2: "0", y2: "1", children: [
|
|
2521
|
+
/* @__PURE__ */ jsx53("stop", { offset: "5%", stopColor: "#00695C", stopOpacity: 0.8 }),
|
|
2522
|
+
/* @__PURE__ */ jsx53("stop", { offset: "95%", stopColor: "#00695C", stopOpacity: 0 })
|
|
2523
|
+
] }) }),
|
|
2524
|
+
/* @__PURE__ */ jsx53(CartesianGrid, { strokeDasharray: "3 3" }),
|
|
2525
|
+
/* @__PURE__ */ jsx53(XAxis, { dataKey: "name" }),
|
|
2526
|
+
/* @__PURE__ */ jsx53(YAxis, {}),
|
|
2527
|
+
/* @__PURE__ */ jsx53(Tooltip, {}),
|
|
2528
|
+
/* @__PURE__ */ jsx53(
|
|
2529
|
+
Area,
|
|
2530
|
+
{
|
|
2531
|
+
type: "monotone",
|
|
2532
|
+
dataKey: "value",
|
|
2533
|
+
stroke: "#00695C",
|
|
2534
|
+
fillOpacity: 1,
|
|
2535
|
+
fill: "url(#colorCount)"
|
|
2536
|
+
}
|
|
2537
|
+
)
|
|
2538
|
+
] }) }) });
|
|
2539
|
+
};
|
|
2540
|
+
var BarChart_default = ChartComponent;
|
|
2541
|
+
|
|
2542
|
+
// src/components/Chart/PieChart.tsx
|
|
2543
|
+
import { PieChart, Pie, Cell, ResponsiveContainer as ResponsiveContainer2, Tooltip as Tooltip2, LabelList } from "recharts";
|
|
2544
|
+
import { Fragment as Fragment18, jsx as jsx54, jsxs as jsxs34 } from "react/jsx-runtime";
|
|
2545
|
+
var DonutChart = ({ className, style, ...props }) => {
|
|
2546
|
+
const data = Array.isArray(props?.data) ? props.data : [];
|
|
2547
|
+
const total = data.reduce((sum, d) => sum + d.value, 0);
|
|
2548
|
+
const showPercentage = props.showPercentage ?? true;
|
|
2549
|
+
const showLegends = props.showLegends ?? true;
|
|
2550
|
+
const labelType = props.labelType || "inside";
|
|
2551
|
+
const canvasMode = props.canvasMode;
|
|
2552
|
+
const renderLabel = ({ value, x, y }) => {
|
|
2553
|
+
if (value == null) return null;
|
|
2554
|
+
const percentage = (Number(value) / total * 100).toFixed(0);
|
|
2555
|
+
return /* @__PURE__ */ jsxs34(
|
|
2556
|
+
"text",
|
|
2557
|
+
{
|
|
2558
|
+
x,
|
|
2559
|
+
y,
|
|
2560
|
+
textAnchor: "middle",
|
|
2561
|
+
dominantBaseline: "central",
|
|
2562
|
+
className: "text-[10px] font-semibold",
|
|
2563
|
+
fill: labelType === "inside" ? "#fff" : "#000",
|
|
2564
|
+
children: [
|
|
2565
|
+
value,
|
|
2566
|
+
"k ",
|
|
2567
|
+
showPercentage ? `(${percentage}%)` : ""
|
|
2568
|
+
]
|
|
2569
|
+
}
|
|
2570
|
+
);
|
|
2571
|
+
};
|
|
2572
|
+
const forceMobile = canvasMode === "mobile" || canvasMode === "tablet";
|
|
2573
|
+
const forceDesktop = canvasMode === "desktop";
|
|
2574
|
+
const wrapperClass = canvasMode ? forceDesktop ? "flex-row" : "flex-col" : "flex-col md:flex-row";
|
|
2575
|
+
const renderLegends = () => {
|
|
2576
|
+
if (!showLegends) return null;
|
|
2577
|
+
return /* @__PURE__ */ jsx54(Fragment18, { children: data.map((d) => /* @__PURE__ */ jsxs34(
|
|
2578
|
+
"div",
|
|
2579
|
+
{
|
|
2580
|
+
className: "flex items-center space-x-2 rounded-md border border-gray-200 px-3 py-2 w-[48%] md:w-auto",
|
|
2581
|
+
children: [
|
|
2582
|
+
/* @__PURE__ */ jsx54(
|
|
2583
|
+
"span",
|
|
2584
|
+
{
|
|
2585
|
+
className: "inline-block w-[16px] h-[16px] rounded",
|
|
2586
|
+
style: { backgroundColor: d.color }
|
|
2587
|
+
}
|
|
2588
|
+
),
|
|
2589
|
+
/* @__PURE__ */ jsx54("span", { className: "text-[#000000] text-[12px] md:text-[13px] font-[500]", children: d.name })
|
|
2590
|
+
]
|
|
2591
|
+
},
|
|
2592
|
+
d.name
|
|
2593
|
+
)) });
|
|
2594
|
+
};
|
|
2595
|
+
return /* @__PURE__ */ jsxs34(
|
|
2596
|
+
"div",
|
|
2597
|
+
{
|
|
2598
|
+
className: `relative flex items-center ${wrapperClass} ${className}`,
|
|
2599
|
+
style,
|
|
2600
|
+
children: [
|
|
2601
|
+
/* @__PURE__ */ jsxs34("div", { className: "relative w-full md:w-[70%] h-[300px] md:h-[400px] flex items-center justify-center", children: [
|
|
2602
|
+
data.length > 0 && /* @__PURE__ */ jsx54(ResponsiveContainer2, { width: "100%", height: "100%", children: /* @__PURE__ */ jsxs34(PieChart, { children: [
|
|
2603
|
+
/* @__PURE__ */ jsxs34(
|
|
2604
|
+
Pie,
|
|
2605
|
+
{
|
|
2606
|
+
data,
|
|
2607
|
+
cx: "50%",
|
|
2608
|
+
cy: "50%",
|
|
2609
|
+
innerRadius: 70,
|
|
2610
|
+
outerRadius: 120,
|
|
2611
|
+
dataKey: "value",
|
|
2612
|
+
labelLine: false,
|
|
2613
|
+
isAnimationActive: false,
|
|
2614
|
+
children: [
|
|
2615
|
+
data.map((entry, index) => /* @__PURE__ */ jsx54(Cell, { fill: entry.color }, `cell-${index}`)),
|
|
2616
|
+
/* @__PURE__ */ jsx54(
|
|
2617
|
+
LabelList,
|
|
2618
|
+
{
|
|
2619
|
+
dataKey: "value",
|
|
2620
|
+
position: labelType === "inside" ? "inside" : "outside",
|
|
2621
|
+
content: renderLabel
|
|
2622
|
+
}
|
|
2623
|
+
)
|
|
2624
|
+
]
|
|
2625
|
+
}
|
|
2626
|
+
),
|
|
2627
|
+
/* @__PURE__ */ jsx54(Tooltip2, { formatter: (value, name) => [`${value}k`, name] })
|
|
2628
|
+
] }) }),
|
|
2629
|
+
/* @__PURE__ */ jsxs34("div", { className: "absolute left-1/2 top-1/2 -translate-x-1/2 -translate-y-1/2 text-2xl md:text-4xl font-bold text-[#000]", children: [
|
|
2630
|
+
total,
|
|
2631
|
+
"k"
|
|
2632
|
+
] })
|
|
2633
|
+
] }),
|
|
2634
|
+
/* @__PURE__ */ jsx54("div", { className: `flex ${forceDesktop ? "flex-col ml-auto space-y-3" : "flex-wrap justify-center gap-2 mt-4"}
|
|
2635
|
+
w-full md:w-auto`, children: renderLegends() })
|
|
2636
|
+
]
|
|
2637
|
+
}
|
|
2638
|
+
);
|
|
2639
|
+
};
|
|
2640
|
+
var PieChart_default = DonutChart;
|
|
2641
|
+
|
|
2642
|
+
// src/components/Blocks/EmailComposer.tsx
|
|
2643
|
+
import { jsx as jsx55, jsxs as jsxs35 } from "react/jsx-runtime";
|
|
2644
|
+
function EmailComposer({ className, style, to, setTo, showCc, setShowCc, showBcc, setShowBcc, cc, setCc, bcc, setBcc, subject, setSubject, body, setBody }) {
|
|
2645
|
+
return /* @__PURE__ */ jsx55("div", { className, style, children: /* @__PURE__ */ jsxs35("div", { className: "border rounded-md shadow bg-[#fff] p-4 mx-auto z-[50] relative", children: [
|
|
2646
|
+
/* @__PURE__ */ jsx55("div", { className: "mb-3", children: /* @__PURE__ */ jsx55(
|
|
2647
|
+
"input",
|
|
2648
|
+
{
|
|
2649
|
+
type: "email",
|
|
2650
|
+
placeholder: "From",
|
|
2651
|
+
className: "w-full flex-1 border-2 rounded-md h-[40px] px-3 focus:outline-none border-[#E9E9E9] text-[#383838]",
|
|
2652
|
+
required: true
|
|
2653
|
+
}
|
|
2654
|
+
) }),
|
|
2655
|
+
/* @__PURE__ */ jsx55("div", { className: "mb-3", children: /* @__PURE__ */ jsxs35("div", { className: "flex items-center gap-2", children: [
|
|
2656
|
+
/* @__PURE__ */ jsx55(
|
|
2657
|
+
"input",
|
|
2658
|
+
{
|
|
2659
|
+
type: "email",
|
|
2660
|
+
value: to,
|
|
2661
|
+
onChange: (e) => setTo?.(e.target.value),
|
|
2662
|
+
placeholder: "To",
|
|
2663
|
+
className: "w-full flex-1 border-2 rounded-md h-[40px] px-3 focus:outline-none border-[#E9E9E9] text-[#383838]",
|
|
2664
|
+
required: true
|
|
2665
|
+
}
|
|
2666
|
+
),
|
|
2667
|
+
!showCc && /* @__PURE__ */ jsx55(
|
|
2668
|
+
"button",
|
|
2669
|
+
{
|
|
2670
|
+
onClick: () => setShowCc?.(true),
|
|
2671
|
+
className: "px-3 py-1 border rounded-md text-sm hover:bg-gray-100 bg-[#E9E9E9] text-[#383838]",
|
|
2672
|
+
children: "Cc"
|
|
2673
|
+
}
|
|
2674
|
+
),
|
|
2675
|
+
!showBcc && /* @__PURE__ */ jsx55(
|
|
2676
|
+
"button",
|
|
2677
|
+
{
|
|
2678
|
+
onClick: () => setShowBcc?.(true),
|
|
2679
|
+
className: "px-3 py-1 border rounded-md text-sm hover:bg-gray-100 bg-[#E9E9E9] text-[#383838]",
|
|
2680
|
+
children: "Bcc"
|
|
2681
|
+
}
|
|
2682
|
+
)
|
|
2683
|
+
] }) }),
|
|
2684
|
+
showCc && /* @__PURE__ */ jsx55("div", { className: "mb-3", children: /* @__PURE__ */ jsx55(
|
|
2685
|
+
"input",
|
|
2686
|
+
{
|
|
2687
|
+
type: "text",
|
|
2688
|
+
value: cc,
|
|
2689
|
+
onChange: (e) => setCc?.(e.target.value),
|
|
2690
|
+
placeholder: "Cc",
|
|
2691
|
+
className: "w-full flex-1 border-2 rounded-md h-[40px] px-3 focus:outline-none border-[#E9E9E9] text-[#383838]"
|
|
2692
|
+
}
|
|
2693
|
+
) }),
|
|
2694
|
+
showBcc && /* @__PURE__ */ jsx55("div", { className: "mb-3", children: /* @__PURE__ */ jsx55(
|
|
2695
|
+
"input",
|
|
2696
|
+
{
|
|
2697
|
+
type: "text",
|
|
2698
|
+
value: bcc,
|
|
2699
|
+
onChange: (e) => setBcc?.(e.target.value),
|
|
2700
|
+
placeholder: "Bcc",
|
|
2701
|
+
className: "w-full flex-1 border-2 rounded-md h-[40px] px-3 focus:outline-none border-[#E9E9E9] text-[#383838]"
|
|
2702
|
+
}
|
|
2703
|
+
) }),
|
|
2704
|
+
/* @__PURE__ */ jsx55("div", { className: "mb-3", children: /* @__PURE__ */ jsx55(
|
|
2705
|
+
"input",
|
|
2706
|
+
{
|
|
2707
|
+
type: "text",
|
|
2708
|
+
value: subject,
|
|
2709
|
+
onChange: (e) => setSubject?.(e.target.value),
|
|
2710
|
+
placeholder: "Subject",
|
|
2711
|
+
className: "w-full flex-1 border-2 rounded-md h-[40px] px-3 focus:outline-none border-[#E9E9E9] text-[#383838]"
|
|
2712
|
+
}
|
|
2713
|
+
) }),
|
|
2714
|
+
/* @__PURE__ */ jsx55("div", { className: "mb-4", children: /* @__PURE__ */ jsx55(MyEditor, { value: body, onChange: setBody }) }),
|
|
2715
|
+
/* @__PURE__ */ jsxs35("div", { className: "flex justify-end gap-2", children: [
|
|
2716
|
+
/* @__PURE__ */ jsx55("button", { className: "px-4 py-2 rounded-md text-gray-600 hover:bg-gray-100", children: "Discard" }),
|
|
2717
|
+
/* @__PURE__ */ jsx55("button", { className: "px-4 py-2 rounded-md border text-[#12715B] border-[#12715B]", children: "Reset" }),
|
|
2718
|
+
/* @__PURE__ */ jsx55("button", { className: "px-4 py-2 rounded-md bg-[#12715B] text-white", children: "Send" })
|
|
2719
|
+
] })
|
|
2720
|
+
] }) });
|
|
2721
|
+
}
|
|
2722
|
+
|
|
2723
|
+
// src/components/ui/sonner-toast.tsx
|
|
2724
|
+
import { toast } from "sonner";
|
|
2725
|
+
function showSonnerToast({
|
|
2726
|
+
title,
|
|
2727
|
+
description,
|
|
2728
|
+
variant = "default",
|
|
2729
|
+
duration = 3e3,
|
|
2730
|
+
actionLabel,
|
|
2731
|
+
onAction
|
|
2732
|
+
}) {
|
|
2733
|
+
const options = {
|
|
2734
|
+
description,
|
|
2735
|
+
duration,
|
|
2736
|
+
action: actionLabel ? {
|
|
2737
|
+
label: actionLabel,
|
|
2738
|
+
onClick: onAction || (() => {
|
|
2739
|
+
})
|
|
2740
|
+
} : void 0
|
|
2741
|
+
};
|
|
2742
|
+
switch (variant) {
|
|
2743
|
+
case "success":
|
|
2744
|
+
toast.success(title, options);
|
|
2745
|
+
break;
|
|
2746
|
+
case "error":
|
|
2747
|
+
toast.error(title, options);
|
|
2748
|
+
break;
|
|
2749
|
+
case "info":
|
|
2750
|
+
toast.info(title, options);
|
|
2751
|
+
break;
|
|
2752
|
+
case "warning":
|
|
2753
|
+
toast.warning(title, options);
|
|
2754
|
+
break;
|
|
2755
|
+
default:
|
|
2756
|
+
toast(title, options);
|
|
2757
|
+
}
|
|
2758
|
+
}
|
|
48
2759
|
export {
|
|
49
2760
|
BarChart_default as BarChart,
|
|
50
2761
|
Breadcrumb_default as Breadcrumb,
|
|
@@ -59,8 +2770,6 @@ export {
|
|
|
59
2770
|
EmailComposer,
|
|
60
2771
|
FileInput_default as FileInput,
|
|
61
2772
|
Flex_default as FlexLayout,
|
|
62
|
-
Form_default as Form,
|
|
63
|
-
Wrapper_default as FormWrapper,
|
|
64
2773
|
Grid_default as GridLayout,
|
|
65
2774
|
Image_default as Image,
|
|
66
2775
|
Modal_default as Modal,
|
|
@@ -77,7 +2786,6 @@ export {
|
|
|
77
2786
|
Shape_default as Shape,
|
|
78
2787
|
Spacer_default as Spacer,
|
|
79
2788
|
Stages_default as Stages,
|
|
80
|
-
StateProvider,
|
|
81
2789
|
SwitchToggle_default as SwitchToggle,
|
|
82
2790
|
Table_default as Table,
|
|
83
2791
|
Tabs_default as Tabs,
|
|
@@ -88,8 +2796,34 @@ export {
|
|
|
88
2796
|
UrlInput_default as URL,
|
|
89
2797
|
cn,
|
|
90
2798
|
getInitials,
|
|
91
|
-
showSonnerToast
|
|
92
|
-
stateReducer,
|
|
93
|
-
useAppState
|
|
2799
|
+
showSonnerToast
|
|
94
2800
|
};
|
|
2801
|
+
/*! Bundled license information:
|
|
2802
|
+
|
|
2803
|
+
lucide-react/dist/esm/shared/src/utils.js:
|
|
2804
|
+
lucide-react/dist/esm/defaultAttributes.js:
|
|
2805
|
+
lucide-react/dist/esm/Icon.js:
|
|
2806
|
+
lucide-react/dist/esm/createLucideIcon.js:
|
|
2807
|
+
lucide-react/dist/esm/icons/bell.js:
|
|
2808
|
+
lucide-react/dist/esm/icons/calculator.js:
|
|
2809
|
+
lucide-react/dist/esm/icons/calendar.js:
|
|
2810
|
+
lucide-react/dist/esm/icons/check.js:
|
|
2811
|
+
lucide-react/dist/esm/icons/chevron-down.js:
|
|
2812
|
+
lucide-react/dist/esm/icons/chevron-left.js:
|
|
2813
|
+
lucide-react/dist/esm/icons/chevron-right.js:
|
|
2814
|
+
lucide-react/dist/esm/icons/chevron-up.js:
|
|
2815
|
+
lucide-react/dist/esm/icons/circle.js:
|
|
2816
|
+
lucide-react/dist/esm/icons/ellipsis.js:
|
|
2817
|
+
lucide-react/dist/esm/icons/mail.js:
|
|
2818
|
+
lucide-react/dist/esm/icons/menu.js:
|
|
2819
|
+
lucide-react/dist/esm/icons/scan-eye.js:
|
|
2820
|
+
lucide-react/dist/esm/icons/search.js:
|
|
2821
|
+
lucide-react/dist/esm/lucide-react.js:
|
|
2822
|
+
(**
|
|
2823
|
+
* @license lucide-react v0.542.0 - ISC
|
|
2824
|
+
*
|
|
2825
|
+
* This source code is licensed under the ISC license.
|
|
2826
|
+
* See the LICENSE file in the root directory of this source tree.
|
|
2827
|
+
*)
|
|
2828
|
+
*/
|
|
95
2829
|
//# sourceMappingURL=index.mjs.map
|