@definable/ui 0.1.0 → 0.1.8
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/README.md +6 -6
- package/dist/alert-dialog.d.ts +18 -0
- package/dist/alert.d.ts +18 -0
- package/dist/avatar.d.ts +9 -0
- package/dist/badge.d.ts +15 -0
- package/dist/button.d.ts +16 -0
- package/dist/calendar.d.ts +21 -0
- package/dist/card.d.ts +15 -0
- package/dist/carousel.d.ts +18 -0
- package/dist/charts.d.ts +26 -0
- package/dist/checkbox.d.ts +6 -0
- package/dist/collapse.d.ts +15 -0
- package/dist/command-menu.d.ts +12 -0
- package/dist/command.d.ts +89 -0
- package/dist/components/alert-dialog.d.ts +15 -0
- package/dist/components/alert-dialog.esm.js +59 -0
- package/dist/components/alert-dialog.esm.js.map +1 -0
- package/dist/components/alert-dialog.js +2 -0
- package/dist/components/alert-dialog.js.map +1 -0
- package/dist/components/alert.d.ts +11 -0
- package/dist/components/alert.esm.js +51 -0
- package/dist/components/alert.esm.js.map +1 -0
- package/dist/components/alert.js +2 -0
- package/dist/components/alert.js.map +1 -0
- package/dist/components/avatar.d.ts +5 -0
- package/dist/components/avatar.esm.js +42 -0
- package/dist/components/avatar.esm.js.map +1 -0
- package/dist/components/avatar.js +2 -0
- package/dist/components/avatar.js.map +1 -0
- package/dist/components/badge.d.ts +9 -0
- package/dist/components/badge.esm.js +27 -0
- package/dist/components/badge.esm.js.map +1 -0
- package/dist/components/badge.js +2 -0
- package/dist/components/badge.js.map +1 -0
- package/dist/components/button.d.ts +13 -0
- package/dist/components/button.esm.js +48 -0
- package/dist/components/button.esm.js.map +1 -0
- package/dist/components/button.js +2 -0
- package/dist/components/button.js.map +1 -0
- package/dist/components/calendar.d.ts +18 -0
- package/dist/components/calendar.esm.js +5562 -0
- package/dist/components/calendar.esm.js.map +1 -0
- package/dist/components/calendar.js +2 -0
- package/dist/components/calendar.js.map +1 -0
- package/dist/components/card.d.ts +8 -0
- package/dist/components/card.esm.js +62 -0
- package/dist/components/card.esm.js.map +1 -0
- package/dist/components/card.js +2 -0
- package/dist/components/card.js.map +1 -0
- package/dist/components/carousel.d.ts +13 -0
- package/dist/components/carousel.esm.js +101 -0
- package/dist/components/carousel.esm.js.map +1 -0
- package/dist/components/carousel.js +2 -0
- package/dist/components/carousel.js.map +1 -0
- package/dist/components/charts.d.ts +17 -0
- package/dist/components/charts.esm.js +48 -0
- package/dist/components/charts.esm.js.map +1 -0
- package/dist/components/charts.js +2 -0
- package/dist/components/charts.js.map +1 -0
- package/dist/components/checkbox.d.ts +4 -0
- package/dist/components/checkbox.esm.js +32 -0
- package/dist/components/checkbox.esm.js.map +1 -0
- package/dist/components/checkbox.js +2 -0
- package/dist/components/checkbox.js.map +1 -0
- package/dist/components/collapse.d.ts +11 -0
- package/dist/components/collapse.esm.js +50 -0
- package/dist/components/collapse.esm.js.map +1 -0
- package/dist/components/collapse.js +2 -0
- package/dist/components/collapse.js.map +1 -0
- package/dist/components/command-menu.d.ts +7 -0
- package/dist/components/command-menu.esm.js +90 -0
- package/dist/components/command-menu.esm.js.map +1 -0
- package/dist/components/command-menu.js +2 -0
- package/dist/components/command-menu.js.map +1 -0
- package/dist/components/command.d.ts +79 -0
- package/dist/components/command.esm.js +425 -0
- package/dist/components/command.esm.js.map +1 -0
- package/dist/components/command.js +2 -0
- package/dist/components/command.js.map +1 -0
- package/dist/components/confirmation-modal.d.ts +12 -0
- package/dist/components/confirmation-modal.esm.js +46 -0
- package/dist/components/confirmation-modal.esm.js.map +1 -0
- package/dist/components/confirmation-modal.js +2 -0
- package/dist/components/confirmation-modal.js.map +1 -0
- package/dist/components/context-menu.d.ts +26 -0
- package/dist/components/context-menu.esm.js +186 -0
- package/dist/components/context-menu.esm.js.map +1 -0
- package/dist/components/context-menu.js +2 -0
- package/dist/components/context-menu.js.map +1 -0
- package/dist/components/dialog.d.ts +21 -0
- package/dist/components/dialog.esm.js +122 -0
- package/dist/components/dialog.esm.js.map +1 -0
- package/dist/components/dialog.js +2 -0
- package/dist/components/dialog.js.map +1 -0
- package/dist/components/dropdown-menu.d.ts +9 -0
- package/dist/components/dropdown-menu.esm.js +49 -0
- package/dist/components/dropdown-menu.esm.js.map +1 -0
- package/dist/components/dropdown-menu.js +2 -0
- package/dist/components/dropdown-menu.js.map +1 -0
- package/dist/components/dropzone.d.ts +12 -0
- package/dist/components/dropzone.esm.js +45 -0
- package/dist/components/dropzone.esm.js.map +1 -0
- package/dist/components/dropzone.js +2 -0
- package/dist/components/dropzone.js.map +1 -0
- package/dist/components/image-cropper-modal.d.ts +10 -0
- package/dist/components/image-cropper-modal.esm.js +251 -0
- package/dist/components/image-cropper-modal.esm.js.map +1 -0
- package/dist/components/image-cropper-modal.js +2 -0
- package/dist/components/image-cropper-modal.js.map +1 -0
- package/dist/components/image-cropper.d.ts +11 -0
- package/dist/components/image-cropper.esm.js +131 -0
- package/dist/components/image-cropper.esm.js.map +1 -0
- package/dist/components/image-cropper.js +2 -0
- package/dist/components/image-cropper.js.map +1 -0
- package/dist/components/input.d.ts +5 -0
- package/dist/components/input.esm.js +22 -0
- package/dist/components/input.esm.js.map +1 -0
- package/dist/components/input.js +2 -0
- package/dist/components/input.js.map +1 -0
- package/dist/components/label.d.ts +4 -0
- package/dist/components/label.esm.js +20 -0
- package/dist/components/label.esm.js.map +1 -0
- package/dist/components/label.js +2 -0
- package/dist/components/label.js.map +1 -0
- package/dist/components/loader.d.ts +10 -0
- package/dist/components/loader.esm.js +70 -0
- package/dist/components/loader.esm.js.map +1 -0
- package/dist/components/loader.js +2 -0
- package/dist/components/loader.js.map +1 -0
- package/dist/components/loading-placeholder.d.ts +8 -0
- package/dist/components/loading-placeholder.esm.js +25 -0
- package/dist/components/loading-placeholder.esm.js.map +1 -0
- package/dist/components/loading-placeholder.js +2 -0
- package/dist/components/loading-placeholder.js.map +1 -0
- package/dist/components/markdown.d.ts +2 -0
- package/dist/components/markdown.esm.js +12066 -0
- package/dist/components/markdown.esm.js.map +1 -0
- package/dist/components/markdown.js +18 -0
- package/dist/components/markdown.js.map +1 -0
- package/dist/components/mention.d.ts +25 -0
- package/dist/components/mention.esm.js +154 -0
- package/dist/components/mention.esm.js.map +1 -0
- package/dist/components/mention.js +2 -0
- package/dist/components/mention.js.map +1 -0
- package/dist/components/modal.d.ts +19 -0
- package/dist/components/modal.esm.js +92 -0
- package/dist/components/modal.esm.js.map +1 -0
- package/dist/components/modal.js +2 -0
- package/dist/components/modal.js.map +1 -0
- package/dist/components/monaco-editor.d.ts +2 -0
- package/dist/components/monaco-editor.esm.js +295 -0
- package/dist/components/monaco-editor.esm.js.map +1 -0
- package/dist/components/monaco-editor.js +8 -0
- package/dist/components/monaco-editor.js.map +1 -0
- package/dist/components/notification.d.ts +5 -0
- package/dist/components/notification.esm.js +26 -0
- package/dist/components/notification.esm.js.map +1 -0
- package/dist/components/notification.js +2 -0
- package/dist/components/notification.js.map +1 -0
- package/dist/components/popover.d.ts +6 -0
- package/dist/components/popover.esm.js +24 -0
- package/dist/components/popover.esm.js.map +1 -0
- package/dist/components/popover.js +2 -0
- package/dist/components/popover.js.map +1 -0
- package/dist/components/progress.d.ts +4 -0
- package/dist/components/progress.esm.js +35 -0
- package/dist/components/progress.esm.js.map +1 -0
- package/dist/components/progress.js +2 -0
- package/dist/components/progress.js.map +1 -0
- package/dist/components/radio-group.d.ts +5 -0
- package/dist/components/radio-group.esm.js +48 -0
- package/dist/components/radio-group.esm.js.map +1 -0
- package/dist/components/radio-group.js +2 -0
- package/dist/components/radio-group.js.map +1 -0
- package/dist/components/scroll-area.d.ts +5 -0
- package/dist/components/scroll-area.esm.js +47 -0
- package/dist/components/scroll-area.esm.js.map +1 -0
- package/dist/components/scroll-area.js +2 -0
- package/dist/components/scroll-area.js.map +1 -0
- package/dist/components/select.d.ts +20 -0
- package/dist/components/select.esm.js +131 -0
- package/dist/components/select.esm.js.map +1 -0
- package/dist/components/select.js +2 -0
- package/dist/components/select.js.map +1 -0
- package/dist/components/selection-bar.d.ts +11 -0
- package/dist/components/selection-bar.esm.js +54 -0
- package/dist/components/selection-bar.esm.js.map +1 -0
- package/dist/components/selection-bar.js +2 -0
- package/dist/components/selection-bar.js.map +1 -0
- package/dist/components/separator.d.ts +4 -0
- package/dist/components/separator.esm.js +25 -0
- package/dist/components/separator.esm.js.map +1 -0
- package/dist/components/separator.js +2 -0
- package/dist/components/separator.js.map +1 -0
- package/dist/components/sheet.d.ts +13 -0
- package/dist/components/sheet.esm.js +129 -0
- package/dist/components/sheet.esm.js.map +1 -0
- package/dist/components/sheet.js +2 -0
- package/dist/components/sheet.js.map +1 -0
- package/dist/components/skeleton.d.ts +2 -0
- package/dist/components/skeleton.esm.js +18 -0
- package/dist/components/skeleton.esm.js.map +1 -0
- package/dist/components/skeleton.js +2 -0
- package/dist/components/skeleton.js.map +1 -0
- package/dist/components/slider.d.ts +4 -0
- package/dist/components/slider.esm.js +33 -0
- package/dist/components/slider.esm.js.map +1 -0
- package/dist/components/slider.js +2 -0
- package/dist/components/slider.js.map +1 -0
- package/dist/components/stepper.d.ts +2 -0
- package/dist/components/stepper.esm.js +214 -0
- package/dist/components/stepper.esm.js.map +1 -0
- package/dist/components/stepper.js +2 -0
- package/dist/components/stepper.js.map +1 -0
- package/dist/components/switch.d.ts +4 -0
- package/dist/components/switch.esm.js +36 -0
- package/dist/components/switch.esm.js.map +1 -0
- package/dist/components/switch.js +2 -0
- package/dist/components/switch.js.map +1 -0
- package/dist/components/table-empty.d.ts +9 -0
- package/dist/components/table-empty.esm.js +23 -0
- package/dist/components/table-empty.esm.js.map +1 -0
- package/dist/components/table-empty.js +2 -0
- package/dist/components/table-empty.js.map +1 -0
- package/dist/components/table-mobile.d.ts +4 -0
- package/dist/components/table-mobile.esm.js +92 -0
- package/dist/components/table-mobile.esm.js.map +1 -0
- package/dist/components/table-mobile.js +2 -0
- package/dist/components/table-mobile.js.map +1 -0
- package/dist/components/table.d.ts +31 -0
- package/dist/components/table.esm.js +143 -0
- package/dist/components/table.esm.js.map +1 -0
- package/dist/components/table.js +2 -0
- package/dist/components/table.js.map +1 -0
- package/dist/components/tabs.d.ts +7 -0
- package/dist/components/tabs.esm.js +47 -0
- package/dist/components/tabs.esm.js.map +1 -0
- package/dist/components/tabs.js +2 -0
- package/dist/components/tabs.js.map +1 -0
- package/dist/components/terminal.d.ts +43 -0
- package/dist/components/terminal.esm.js +50 -0
- package/dist/components/terminal.esm.js.map +1 -0
- package/dist/components/terminal.js +2 -0
- package/dist/components/terminal.js.map +1 -0
- package/dist/components/textarea.d.ts +5 -0
- package/dist/components/textarea.esm.js +21 -0
- package/dist/components/textarea.esm.js.map +1 -0
- package/dist/components/textarea.js +2 -0
- package/dist/components/textarea.js.map +1 -0
- package/dist/components/tooltip.d.ts +8 -0
- package/dist/components/tooltip.esm.js +100 -0
- package/dist/components/tooltip.esm.js.map +1 -0
- package/dist/components/tooltip.js +2 -0
- package/dist/components/tooltip.js.map +1 -0
- package/dist/components/use-toast.d.ts +21 -0
- package/dist/components/use-toast.esm.js +65 -0
- package/dist/components/use-toast.esm.js.map +1 -0
- package/dist/components/use-toast.js +2 -0
- package/dist/components/use-toast.js.map +1 -0
- package/dist/confirmation-modal.d.ts +16 -0
- package/dist/context-menu.d.ts +41 -0
- package/dist/dialog.d.ts +33 -0
- package/dist/dropdown-menu.d.ts +16 -0
- package/dist/dropzone.d.ts +16 -0
- package/dist/image-cropper-modal.d.ts +14 -0
- package/dist/image-cropper.d.ts +15 -0
- package/dist/index-DACAHwoB.js +35 -0
- package/dist/index-DACAHwoB.js.map +1 -0
- package/dist/index-Deooizx8.cjs +2 -0
- package/dist/index-Deooizx8.cjs.map +1 -0
- package/dist/index.d.ts +8 -2
- package/dist/index.esm.js +111 -75430
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/input.d.ts +8 -0
- package/dist/jsx-runtime-BYECrxsp.cjs +31 -0
- package/dist/jsx-runtime-BYECrxsp.cjs.map +1 -0
- package/dist/jsx-runtime-DGlMoOmv.js +631 -0
- package/dist/jsx-runtime-DGlMoOmv.js.map +1 -0
- package/dist/label.d.ts +6 -0
- package/dist/lib/utils.d.ts +2 -0
- package/dist/lib/utils.esm.js +5 -0
- package/dist/lib/utils.esm.js.map +1 -0
- package/dist/lib/utils.js +2 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/loader.d.ts +14 -0
- package/dist/loading-placeholder.d.ts +12 -0
- package/dist/markdown.d.ts +122 -0
- package/dist/mention.d.ts +29 -0
- package/dist/modal.d.ts +24 -0
- package/dist/monaco-editor.d.ts +76 -0
- package/dist/notification.d.ts +9 -0
- package/dist/popover.d.ts +10 -0
- package/dist/progress.d.ts +6 -0
- package/dist/radio-group.d.ts +8 -0
- package/dist/scroll-area.d.ts +8 -0
- package/dist/select.d.ts +31 -0
- package/dist/selection-bar.d.ts +15 -0
- package/dist/separator.d.ts +6 -0
- package/dist/sheet.d.ts +17 -0
- package/dist/skeleton.d.ts +5 -0
- package/dist/slider.d.ts +6 -0
- package/dist/stepper.d.ts +71 -0
- package/dist/styles.css +1 -1
- package/dist/switch.d.ts +6 -0
- package/dist/table-empty.d.ts +13 -0
- package/dist/table-mobile.d.ts +37 -0
- package/dist/table.d.ts +37 -0
- package/dist/tabs.d.ts +12 -0
- package/dist/terminal.d.ts +47 -0
- package/dist/textarea.d.ts +8 -0
- package/dist/tooltip.d.ts +12 -0
- package/dist/use-toast.d.ts +28 -0
- package/dist/utils-DSKoFOjv.cjs +2 -0
- package/dist/utils-DSKoFOjv.cjs.map +1 -0
- package/dist/utils-qaFjX9_3.js +2279 -0
- package/dist/utils-qaFjX9_3.js.map +1 -0
- package/dist/utils.d.ts +5 -0
- package/package.json +259 -1
- package/dist/index.cjs.js +0 -315
- package/dist/index.cjs.js.map +0 -1
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { j as e } from "../jsx-runtime-DGlMoOmv.js";
|
|
2
|
+
import * as r from "react";
|
|
3
|
+
import * as o from "@radix-ui/react-dialog";
|
|
4
|
+
import { c as i } from "../utils-qaFjX9_3.js";
|
|
5
|
+
import { X as d } from "lucide-react";
|
|
6
|
+
import { motion as l, AnimatePresence as m } from "framer-motion";
|
|
7
|
+
const b = ({ ...a }) => /* @__PURE__ */ e.jsx(o.Root, { ...a }), v = o.Trigger, p = o.Portal, w = o.Close, n = r.forwardRef(({ className: a, ...t }, s) => /* @__PURE__ */ e.jsx(
|
|
8
|
+
o.Overlay,
|
|
9
|
+
{
|
|
10
|
+
ref: s,
|
|
11
|
+
asChild: !0,
|
|
12
|
+
...t,
|
|
13
|
+
children: /* @__PURE__ */ e.jsx(
|
|
14
|
+
l.div,
|
|
15
|
+
{
|
|
16
|
+
className: i(
|
|
17
|
+
"fixed inset-0 z-50 bg-background/80 backdrop-blur-sm",
|
|
18
|
+
a
|
|
19
|
+
),
|
|
20
|
+
initial: { opacity: 0 },
|
|
21
|
+
animate: { opacity: 1 },
|
|
22
|
+
exit: { opacity: 0 },
|
|
23
|
+
transition: { duration: 0.2 }
|
|
24
|
+
}
|
|
25
|
+
)
|
|
26
|
+
}
|
|
27
|
+
));
|
|
28
|
+
n.displayName = o.Overlay.displayName;
|
|
29
|
+
const g = r.forwardRef(({ className: a, children: t, ...s }, c) => /* @__PURE__ */ e.jsx(p, { children: /* @__PURE__ */ e.jsxs(m, { mode: "wait", children: [
|
|
30
|
+
/* @__PURE__ */ e.jsx(n, {}),
|
|
31
|
+
/* @__PURE__ */ e.jsx(
|
|
32
|
+
o.Content,
|
|
33
|
+
{
|
|
34
|
+
ref: c,
|
|
35
|
+
asChild: !0,
|
|
36
|
+
...s,
|
|
37
|
+
children: /* @__PURE__ */ e.jsxs(
|
|
38
|
+
l.div,
|
|
39
|
+
{
|
|
40
|
+
className: i(
|
|
41
|
+
"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg rounded-lg",
|
|
42
|
+
a
|
|
43
|
+
),
|
|
44
|
+
initial: { opacity: 0, scale: 0.95, y: "-48%", x: "-50%" },
|
|
45
|
+
animate: { opacity: 1, scale: 1, y: "-50%", x: "-50%" },
|
|
46
|
+
exit: { opacity: 0, scale: 0.95, y: "-48%", x: "-50%" },
|
|
47
|
+
transition: { duration: 0.2 },
|
|
48
|
+
children: [
|
|
49
|
+
t,
|
|
50
|
+
/* @__PURE__ */ e.jsxs(o.Close, { className: "absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground", children: [
|
|
51
|
+
/* @__PURE__ */ e.jsx(d, { className: "h-4 w-4" }),
|
|
52
|
+
/* @__PURE__ */ e.jsx("span", { className: "sr-only", children: "Close" })
|
|
53
|
+
] })
|
|
54
|
+
]
|
|
55
|
+
}
|
|
56
|
+
)
|
|
57
|
+
}
|
|
58
|
+
)
|
|
59
|
+
] }) }));
|
|
60
|
+
g.displayName = o.Content.displayName;
|
|
61
|
+
const x = ({
|
|
62
|
+
className: a,
|
|
63
|
+
...t
|
|
64
|
+
}) => /* @__PURE__ */ e.jsx(
|
|
65
|
+
"div",
|
|
66
|
+
{
|
|
67
|
+
className: i(
|
|
68
|
+
"flex flex-col space-y-1.5 text-center sm:text-left",
|
|
69
|
+
a
|
|
70
|
+
),
|
|
71
|
+
...t
|
|
72
|
+
}
|
|
73
|
+
);
|
|
74
|
+
x.displayName = "DialogHeader";
|
|
75
|
+
const f = ({
|
|
76
|
+
className: a,
|
|
77
|
+
...t
|
|
78
|
+
}) => /* @__PURE__ */ e.jsx(
|
|
79
|
+
"div",
|
|
80
|
+
{
|
|
81
|
+
className: i(
|
|
82
|
+
"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",
|
|
83
|
+
a
|
|
84
|
+
),
|
|
85
|
+
...t
|
|
86
|
+
}
|
|
87
|
+
);
|
|
88
|
+
f.displayName = "DialogFooter";
|
|
89
|
+
const y = r.forwardRef(({ className: a, ...t }, s) => /* @__PURE__ */ e.jsx(
|
|
90
|
+
o.Title,
|
|
91
|
+
{
|
|
92
|
+
ref: s,
|
|
93
|
+
className: i(
|
|
94
|
+
"text-lg font-semibold leading-none tracking-tight",
|
|
95
|
+
a
|
|
96
|
+
),
|
|
97
|
+
...t
|
|
98
|
+
}
|
|
99
|
+
));
|
|
100
|
+
y.displayName = o.Title.displayName;
|
|
101
|
+
const u = r.forwardRef(({ className: a, ...t }, s) => /* @__PURE__ */ e.jsx(
|
|
102
|
+
o.Description,
|
|
103
|
+
{
|
|
104
|
+
ref: s,
|
|
105
|
+
className: i("text-sm text-muted-foreground", a),
|
|
106
|
+
...t
|
|
107
|
+
}
|
|
108
|
+
));
|
|
109
|
+
u.displayName = o.Description.displayName;
|
|
110
|
+
export {
|
|
111
|
+
b as Dialog,
|
|
112
|
+
w as DialogClose,
|
|
113
|
+
g as DialogContent,
|
|
114
|
+
u as DialogDescription,
|
|
115
|
+
f as DialogFooter,
|
|
116
|
+
x as DialogHeader,
|
|
117
|
+
n as DialogOverlay,
|
|
118
|
+
p as DialogPortal,
|
|
119
|
+
y as DialogTitle,
|
|
120
|
+
v as DialogTrigger
|
|
121
|
+
};
|
|
122
|
+
//# sourceMappingURL=dialog.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dialog.esm.js","sources":["../../src/components/dialog.tsx"],"sourcesContent":["import * as React from \"react\"\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\"\nimport { cn } from \"@/lib/utils\"\nimport { X } from \"lucide-react\"\nimport { motion, AnimatePresence } from \"framer-motion\"\n\nconst Dialog = ({ ...props }) => (\n <DialogPrimitive.Root {...props} />\n)\n\nconst DialogTrigger = DialogPrimitive.Trigger\n\nconst DialogPortal = DialogPrimitive.Portal\n\nconst DialogClose = DialogPrimitive.Close\n\nconst DialogOverlay = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Overlay\n ref={ref}\n asChild\n {...props}\n >\n <motion.div\n className={cn(\n \"fixed inset-0 z-50 bg-background/80 backdrop-blur-sm\",\n className\n )}\n initial={{ opacity: 0 }}\n animate={{ opacity: 1 }}\n exit={{ opacity: 0 }}\n transition={{ duration: 0.2 }}\n />\n </DialogPrimitive.Overlay>\n))\nDialogOverlay.displayName = DialogPrimitive.Overlay.displayName\n\nconst DialogContent = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content>\n>(({ className, children, ...props }, ref) => (\n <DialogPortal>\n <AnimatePresence mode=\"wait\">\n <DialogOverlay />\n <DialogPrimitive.Content\n ref={ref}\n asChild\n {...props}\n >\n <motion.div\n className={cn(\n \"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg rounded-lg\",\n className\n )}\n initial={{ opacity: 0, scale: 0.95, y: '-48%', x: '-50%' }}\n animate={{ opacity: 1, scale: 1, y: '-50%', x: '-50%' }}\n exit={{ opacity: 0, scale: 0.95, y: '-48%', x: '-50%' }}\n transition={{ duration: 0.2 }}\n >\n {children}\n <DialogPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground\">\n <X className=\"h-4 w-4\" />\n <span className=\"sr-only\">Close</span>\n </DialogPrimitive.Close>\n </motion.div>\n </DialogPrimitive.Content>\n </AnimatePresence>\n </DialogPortal>\n))\nDialogContent.displayName = DialogPrimitive.Content.displayName\n\nconst DialogHeader = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col space-y-1.5 text-center sm:text-left\",\n className\n )}\n {...props}\n />\n)\nDialogHeader.displayName = \"DialogHeader\"\n\nconst DialogFooter = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2\",\n className\n )}\n {...props}\n />\n)\nDialogFooter.displayName = \"DialogFooter\"\n\nconst DialogTitle = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Title\n ref={ref}\n className={cn(\n \"text-lg font-semibold leading-none tracking-tight\",\n className\n )}\n {...props}\n />\n))\nDialogTitle.displayName = DialogPrimitive.Title.displayName\n\nconst DialogDescription = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Description\n ref={ref}\n className={cn(\"text-sm text-muted-foreground\", className)}\n {...props}\n />\n))\nDialogDescription.displayName = DialogPrimitive.Description.displayName\n\nexport {\n Dialog,\n DialogPortal,\n DialogOverlay,\n DialogTrigger,\n DialogClose,\n DialogContent,\n DialogHeader,\n DialogFooter,\n DialogTitle,\n DialogDescription,\n} "],"names":["Dialog","props","jsx","DialogPrimitive","DialogTrigger","DialogPortal","DialogClose","DialogOverlay","React","className","ref","motion","cn","DialogContent","children","jsxs","AnimatePresence","X","DialogHeader","DialogFooter","DialogTitle","DialogDescription"],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("../jsx-runtime-BYECrxsp.cjs"),j=require("react"),y=require("@radix-ui/react-dialog"),a=require("../utils-DSKoFOjv.cjs"),D=require("lucide-react"),l=require("framer-motion");function x(e){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const s in e)if(s!=="default"){const n=Object.getOwnPropertyDescriptor(e,s);Object.defineProperty(t,s,n.get?n:{enumerable:!0,get:()=>e[s]})}}return t.default=e,Object.freeze(t)}const r=x(j),i=x(y),R=({...e})=>o.jsxRuntimeExports.jsx(i.Root,{...e}),b=i.Trigger,d=i.Portal,N=i.Close,c=r.forwardRef(({className:e,...t},s)=>o.jsxRuntimeExports.jsx(i.Overlay,{ref:s,asChild:!0,...t,children:o.jsxRuntimeExports.jsx(l.motion.div,{className:a.cn("fixed inset-0 z-50 bg-background/80 backdrop-blur-sm",e),initial:{opacity:0},animate:{opacity:1},exit:{opacity:0},transition:{duration:.2}})}));c.displayName=i.Overlay.displayName;const m=r.forwardRef(({className:e,children:t,...s},n)=>o.jsxRuntimeExports.jsx(d,{children:o.jsxRuntimeExports.jsxs(l.AnimatePresence,{mode:"wait",children:[o.jsxRuntimeExports.jsx(c,{}),o.jsxRuntimeExports.jsx(i.Content,{ref:n,asChild:!0,...s,children:o.jsxRuntimeExports.jsxs(l.motion.div,{className:a.cn("fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg rounded-lg",e),initial:{opacity:0,scale:.95,y:"-48%",x:"-50%"},animate:{opacity:1,scale:1,y:"-50%",x:"-50%"},exit:{opacity:0,scale:.95,y:"-48%",x:"-50%"},transition:{duration:.2},children:[t,o.jsxRuntimeExports.jsxs(i.Close,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground",children:[o.jsxRuntimeExports.jsx(D.X,{className:"h-4 w-4"}),o.jsxRuntimeExports.jsx("span",{className:"sr-only",children:"Close"})]})]})})]})}));m.displayName=i.Content.displayName;const g=({className:e,...t})=>o.jsxRuntimeExports.jsx("div",{className:a.cn("flex flex-col space-y-1.5 text-center sm:text-left",e),...t});g.displayName="DialogHeader";const u=({className:e,...t})=>o.jsxRuntimeExports.jsx("div",{className:a.cn("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",e),...t});u.displayName="DialogFooter";const p=r.forwardRef(({className:e,...t},s)=>o.jsxRuntimeExports.jsx(i.Title,{ref:s,className:a.cn("text-lg font-semibold leading-none tracking-tight",e),...t}));p.displayName=i.Title.displayName;const f=r.forwardRef(({className:e,...t},s)=>o.jsxRuntimeExports.jsx(i.Description,{ref:s,className:a.cn("text-sm text-muted-foreground",e),...t}));f.displayName=i.Description.displayName;exports.Dialog=R;exports.DialogClose=N;exports.DialogContent=m;exports.DialogDescription=f;exports.DialogFooter=u;exports.DialogHeader=g;exports.DialogOverlay=c;exports.DialogPortal=d;exports.DialogTitle=p;exports.DialogTrigger=b;
|
|
2
|
+
//# sourceMappingURL=dialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dialog.js","sources":["../../src/components/dialog.tsx"],"sourcesContent":["import * as React from \"react\"\nimport * as DialogPrimitive from \"@radix-ui/react-dialog\"\nimport { cn } from \"@/lib/utils\"\nimport { X } from \"lucide-react\"\nimport { motion, AnimatePresence } from \"framer-motion\"\n\nconst Dialog = ({ ...props }) => (\n <DialogPrimitive.Root {...props} />\n)\n\nconst DialogTrigger = DialogPrimitive.Trigger\n\nconst DialogPortal = DialogPrimitive.Portal\n\nconst DialogClose = DialogPrimitive.Close\n\nconst DialogOverlay = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Overlay>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Overlay>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Overlay\n ref={ref}\n asChild\n {...props}\n >\n <motion.div\n className={cn(\n \"fixed inset-0 z-50 bg-background/80 backdrop-blur-sm\",\n className\n )}\n initial={{ opacity: 0 }}\n animate={{ opacity: 1 }}\n exit={{ opacity: 0 }}\n transition={{ duration: 0.2 }}\n />\n </DialogPrimitive.Overlay>\n))\nDialogOverlay.displayName = DialogPrimitive.Overlay.displayName\n\nconst DialogContent = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content>\n>(({ className, children, ...props }, ref) => (\n <DialogPortal>\n <AnimatePresence mode=\"wait\">\n <DialogOverlay />\n <DialogPrimitive.Content\n ref={ref}\n asChild\n {...props}\n >\n <motion.div\n className={cn(\n \"fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg rounded-lg\",\n className\n )}\n initial={{ opacity: 0, scale: 0.95, y: '-48%', x: '-50%' }}\n animate={{ opacity: 1, scale: 1, y: '-50%', x: '-50%' }}\n exit={{ opacity: 0, scale: 0.95, y: '-48%', x: '-50%' }}\n transition={{ duration: 0.2 }}\n >\n {children}\n <DialogPrimitive.Close className=\"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground\">\n <X className=\"h-4 w-4\" />\n <span className=\"sr-only\">Close</span>\n </DialogPrimitive.Close>\n </motion.div>\n </DialogPrimitive.Content>\n </AnimatePresence>\n </DialogPortal>\n))\nDialogContent.displayName = DialogPrimitive.Content.displayName\n\nconst DialogHeader = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col space-y-1.5 text-center sm:text-left\",\n className\n )}\n {...props}\n />\n)\nDialogHeader.displayName = \"DialogHeader\"\n\nconst DialogFooter = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLDivElement>) => (\n <div\n className={cn(\n \"flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2\",\n className\n )}\n {...props}\n />\n)\nDialogFooter.displayName = \"DialogFooter\"\n\nconst DialogTitle = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Title>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Title\n ref={ref}\n className={cn(\n \"text-lg font-semibold leading-none tracking-tight\",\n className\n )}\n {...props}\n />\n))\nDialogTitle.displayName = DialogPrimitive.Title.displayName\n\nconst DialogDescription = React.forwardRef<\n React.ElementRef<typeof DialogPrimitive.Description>,\n React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description>\n>(({ className, ...props }, ref) => (\n <DialogPrimitive.Description\n ref={ref}\n className={cn(\"text-sm text-muted-foreground\", className)}\n {...props}\n />\n))\nDialogDescription.displayName = DialogPrimitive.Description.displayName\n\nexport {\n Dialog,\n DialogPortal,\n DialogOverlay,\n DialogTrigger,\n DialogClose,\n DialogContent,\n DialogHeader,\n DialogFooter,\n DialogTitle,\n DialogDescription,\n} "],"names":["Dialog","props","jsx","DialogPrimitive","DialogTrigger","DialogPortal","DialogClose","DialogOverlay","React","className","ref","motion","cn","DialogContent","children","jsxs","AnimatePresence","X","DialogHeader","DialogFooter","DialogTitle","DialogDescription"],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import * as DropdownMenuPrimitive from "@radix-ui/react-dropdown-menu";
|
|
3
|
+
declare const DropdownMenu: React.FC<DropdownMenuPrimitive.DropdownMenuProps>;
|
|
4
|
+
declare const DropdownMenuTrigger: React.ForwardRefExoticComponent<DropdownMenuPrimitive.DropdownMenuTriggerProps & React.RefAttributes<HTMLButtonElement>>;
|
|
5
|
+
declare const DropdownMenuGroup: React.ForwardRefExoticComponent<DropdownMenuPrimitive.DropdownMenuGroupProps & React.RefAttributes<HTMLDivElement>>;
|
|
6
|
+
declare const DropdownMenuSeparator: React.ForwardRefExoticComponent<DropdownMenuPrimitive.DropdownMenuSeparatorProps & React.RefAttributes<HTMLDivElement>>;
|
|
7
|
+
declare const DropdownMenuContent: React.ForwardRefExoticComponent<Omit<DropdownMenuPrimitive.DropdownMenuContentProps & React.RefAttributes<HTMLDivElement>, "ref"> & React.RefAttributes<HTMLDivElement>>;
|
|
8
|
+
declare const DropdownMenuItem: React.ForwardRefExoticComponent<Omit<DropdownMenuPrimitive.DropdownMenuItemProps & React.RefAttributes<HTMLDivElement>, "ref"> & React.RefAttributes<HTMLDivElement>>;
|
|
9
|
+
export { DropdownMenu, DropdownMenuTrigger, DropdownMenuContent, DropdownMenuItem, DropdownMenuSeparator, DropdownMenuGroup, };
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { j as e } from "../jsx-runtime-DGlMoOmv.js";
|
|
2
|
+
import * as a from "react";
|
|
3
|
+
import * as o from "@radix-ui/react-dropdown-menu";
|
|
4
|
+
import { c as i } from "../utils-qaFjX9_3.js";
|
|
5
|
+
import { motion as p } from "framer-motion";
|
|
6
|
+
const x = o.Root, w = o.Trigger, y = o.Group, g = o.Separator, c = a.forwardRef(({ className: t, sideOffset: r = 4, children: n, ...s }, d) => /* @__PURE__ */ e.jsx(o.Portal, { children: /* @__PURE__ */ e.jsx(
|
|
7
|
+
o.Content,
|
|
8
|
+
{
|
|
9
|
+
ref: d,
|
|
10
|
+
sideOffset: r,
|
|
11
|
+
...s,
|
|
12
|
+
children: /* @__PURE__ */ e.jsx(
|
|
13
|
+
p.div,
|
|
14
|
+
{
|
|
15
|
+
initial: { opacity: 0, scale: 0.95 },
|
|
16
|
+
animate: { opacity: 1, scale: 1 },
|
|
17
|
+
exit: { opacity: 0, scale: 0.95 },
|
|
18
|
+
transition: { duration: 0.2 },
|
|
19
|
+
className: i(
|
|
20
|
+
"z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md",
|
|
21
|
+
t
|
|
22
|
+
),
|
|
23
|
+
children: n
|
|
24
|
+
}
|
|
25
|
+
)
|
|
26
|
+
}
|
|
27
|
+
) }));
|
|
28
|
+
c.displayName = o.Content.displayName;
|
|
29
|
+
const m = a.forwardRef(({ className: t, ...r }, n) => /* @__PURE__ */ e.jsx(
|
|
30
|
+
o.Item,
|
|
31
|
+
{
|
|
32
|
+
ref: n,
|
|
33
|
+
className: i(
|
|
34
|
+
"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
|
|
35
|
+
t
|
|
36
|
+
),
|
|
37
|
+
...r
|
|
38
|
+
}
|
|
39
|
+
));
|
|
40
|
+
m.displayName = o.Item.displayName;
|
|
41
|
+
export {
|
|
42
|
+
x as DropdownMenu,
|
|
43
|
+
c as DropdownMenuContent,
|
|
44
|
+
y as DropdownMenuGroup,
|
|
45
|
+
m as DropdownMenuItem,
|
|
46
|
+
g as DropdownMenuSeparator,
|
|
47
|
+
w as DropdownMenuTrigger
|
|
48
|
+
};
|
|
49
|
+
//# sourceMappingURL=dropdown-menu.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown-menu.esm.js","sources":["../../src/components/dropdown-menu.tsx"],"sourcesContent":["import * as React from \"react\"\nimport * as DropdownMenuPrimitive from \"@radix-ui/react-dropdown-menu\"\nimport { cn } from \"@/lib/utils\"\nimport { motion } from \"framer-motion\"\n\nconst DropdownMenu = DropdownMenuPrimitive.Root\nconst DropdownMenuTrigger = DropdownMenuPrimitive.Trigger\nconst DropdownMenuGroup = DropdownMenuPrimitive.Group\nconst DropdownMenuSeparator = DropdownMenuPrimitive.Separator\n\nconst DropdownMenuContent = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Content>\n>(({ className, sideOffset = 4, children, ...props }, ref) => (\n <DropdownMenuPrimitive.Portal>\n <DropdownMenuPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n {...props}\n >\n <motion.div\n initial={{ opacity: 0, scale: 0.95 }}\n animate={{ opacity: 1, scale: 1 }}\n exit={{ opacity: 0, scale: 0.95 }}\n transition={{ duration: 0.2 }}\n className={cn(\n \"z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md\",\n className\n )}\n >\n {children}\n </motion.div>\n </DropdownMenuPrimitive.Content>\n </DropdownMenuPrimitive.Portal>\n))\nDropdownMenuContent.displayName = DropdownMenuPrimitive.Content.displayName\n\nconst DropdownMenuItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Item>\n>(({ className, ...props }, ref) => (\n <DropdownMenuPrimitive.Item\n ref={ref}\n className={cn(\n \"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n className\n )}\n {...props}\n />\n))\nDropdownMenuItem.displayName = DropdownMenuPrimitive.Item.displayName\n\nexport {\n DropdownMenu,\n DropdownMenuTrigger,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuSeparator,\n DropdownMenuGroup,\n} "],"names":["DropdownMenu","DropdownMenuPrimitive","DropdownMenuTrigger","DropdownMenuGroup","DropdownMenuSeparator","DropdownMenuContent","React","className","sideOffset","children","props","ref","jsx","motion","cn","DropdownMenuItem"],"mappings":";;;;;AAKA,MAAMA,IAAeC,EAAsB,MACrCC,IAAsBD,EAAsB,SAC5CE,IAAoBF,EAAsB,OAC1CG,IAAwBH,EAAsB,WAE9CI,IAAsBC,EAAM,WAGhC,CAAC,EAAE,WAAAC,GAAW,YAAAC,IAAa,GAAG,UAAAC,GAAU,GAAGC,KAASC,MACpDC,gBAAAA,EAAAA,IAACX,EAAsB,QAAtB,EACC,UAAAW,gBAAAA,EAAAA;AAAAA,EAACX,EAAsB;AAAA,EAAtB;AAAA,IACC,KAAAU;AAAA,IACA,YAAAH;AAAA,IACC,GAAGE;AAAA,IAEJ,UAAAE,gBAAAA,EAAAA;AAAAA,MAACC,EAAO;AAAA,MAAP;AAAA,QACC,SAAS,EAAE,SAAS,GAAG,OAAO,KAAA;AAAA,QAC9B,SAAS,EAAE,SAAS,GAAG,OAAO,EAAA;AAAA,QAC9B,MAAM,EAAE,SAAS,GAAG,OAAO,KAAA;AAAA,QAC3B,YAAY,EAAE,UAAU,IAAA;AAAA,QACxB,WAAWC;AAAA,UACT;AAAA,UACAP;AAAA,QAAA;AAAA,QAGD,UAAAE;AAAA,MAAA;AAAA,IAAA;AAAA,EACH;AACF,GACF,CACD;AACDJ,EAAoB,cAAcJ,EAAsB,QAAQ;AAEhE,MAAMc,IAAmBT,EAAM,WAG7B,CAAC,EAAE,WAAAC,GAAW,GAAGG,EAAA,GAASC,MAC1BC,gBAAAA,EAAAA;AAAAA,EAACX,EAAsB;AAAA,EAAtB;AAAA,IACC,KAAAU;AAAA,IACA,WAAWG;AAAA,MACT;AAAA,MACAP;AAAA,IAAA;AAAA,IAED,GAAGG;AAAA,EAAA;AACN,CACD;AACDK,EAAiB,cAAcd,EAAsB,KAAK;"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("../jsx-runtime-BYECrxsp.cjs"),l=require("react"),m=require("@radix-ui/react-dropdown-menu"),i=require("../utils-DSKoFOjv.cjs"),f=require("framer-motion");function s(e){const n=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const t in e)if(t!=="default"){const r=Object.getOwnPropertyDescriptor(e,t);Object.defineProperty(n,t,r.get?r:{enumerable:!0,get:()=>e[t]})}}return n.default=e,Object.freeze(n)}const c=s(l),o=s(m),w=o.Root,x=o.Trigger,g=o.Group,M=o.Separator,u=c.forwardRef(({className:e,sideOffset:n=4,children:t,...r},p)=>a.jsxRuntimeExports.jsx(o.Portal,{children:a.jsxRuntimeExports.jsx(o.Content,{ref:p,sideOffset:n,...r,children:a.jsxRuntimeExports.jsx(f.motion.div,{initial:{opacity:0,scale:.95},animate:{opacity:1,scale:1},exit:{opacity:0,scale:.95},transition:{duration:.2},className:i.cn("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md",e),children:t})})}));u.displayName=o.Content.displayName;const d=c.forwardRef(({className:e,...n},t)=>a.jsxRuntimeExports.jsx(o.Item,{ref:t,className:i.cn("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...n}));d.displayName=o.Item.displayName;exports.DropdownMenu=w;exports.DropdownMenuContent=u;exports.DropdownMenuGroup=g;exports.DropdownMenuItem=d;exports.DropdownMenuSeparator=M;exports.DropdownMenuTrigger=x;
|
|
2
|
+
//# sourceMappingURL=dropdown-menu.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown-menu.js","sources":["../../src/components/dropdown-menu.tsx"],"sourcesContent":["import * as React from \"react\"\nimport * as DropdownMenuPrimitive from \"@radix-ui/react-dropdown-menu\"\nimport { cn } from \"@/lib/utils\"\nimport { motion } from \"framer-motion\"\n\nconst DropdownMenu = DropdownMenuPrimitive.Root\nconst DropdownMenuTrigger = DropdownMenuPrimitive.Trigger\nconst DropdownMenuGroup = DropdownMenuPrimitive.Group\nconst DropdownMenuSeparator = DropdownMenuPrimitive.Separator\n\nconst DropdownMenuContent = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Content>\n>(({ className, sideOffset = 4, children, ...props }, ref) => (\n <DropdownMenuPrimitive.Portal>\n <DropdownMenuPrimitive.Content\n ref={ref}\n sideOffset={sideOffset}\n {...props}\n >\n <motion.div\n initial={{ opacity: 0, scale: 0.95 }}\n animate={{ opacity: 1, scale: 1 }}\n exit={{ opacity: 0, scale: 0.95 }}\n transition={{ duration: 0.2 }}\n className={cn(\n \"z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md\",\n className\n )}\n >\n {children}\n </motion.div>\n </DropdownMenuPrimitive.Content>\n </DropdownMenuPrimitive.Portal>\n))\nDropdownMenuContent.displayName = DropdownMenuPrimitive.Content.displayName\n\nconst DropdownMenuItem = React.forwardRef<\n React.ElementRef<typeof DropdownMenuPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Item>\n>(({ className, ...props }, ref) => (\n <DropdownMenuPrimitive.Item\n ref={ref}\n className={cn(\n \"relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50\",\n className\n )}\n {...props}\n />\n))\nDropdownMenuItem.displayName = DropdownMenuPrimitive.Item.displayName\n\nexport {\n DropdownMenu,\n DropdownMenuTrigger,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuSeparator,\n DropdownMenuGroup,\n} "],"names":["DropdownMenu","DropdownMenuPrimitive","DropdownMenuTrigger","DropdownMenuGroup","DropdownMenuSeparator","DropdownMenuContent","React","className","sideOffset","children","props","ref","jsx","motion","cn","DropdownMenuItem"],"mappings":"4hBAKMA,EAAeC,EAAsB,KACrCC,EAAsBD,EAAsB,QAC5CE,EAAoBF,EAAsB,MAC1CG,EAAwBH,EAAsB,UAE9CI,EAAsBC,EAAM,WAGhC,CAAC,CAAE,UAAAC,EAAW,WAAAC,EAAa,EAAG,SAAAC,EAAU,GAAGC,GAASC,IACpDC,EAAAA,kBAAAA,IAACX,EAAsB,OAAtB,CACC,SAAAW,EAAAA,kBAAAA,IAACX,EAAsB,QAAtB,CACC,IAAAU,EACA,WAAAH,EACC,GAAGE,EAEJ,SAAAE,EAAAA,kBAAAA,IAACC,EAAAA,OAAO,IAAP,CACC,QAAS,CAAE,QAAS,EAAG,MAAO,GAAA,EAC9B,QAAS,CAAE,QAAS,EAAG,MAAO,CAAA,EAC9B,KAAM,CAAE,QAAS,EAAG,MAAO,GAAA,EAC3B,WAAY,CAAE,SAAU,EAAA,EACxB,UAAWC,EAAAA,GACT,uGACAP,CAAA,EAGD,SAAAE,CAAA,CAAA,CACH,CACF,EACF,CACD,EACDJ,EAAoB,YAAcJ,EAAsB,QAAQ,YAEhE,MAAMc,EAAmBT,EAAM,WAG7B,CAAC,CAAE,UAAAC,EAAW,GAAGG,CAAA,EAASC,IAC1BC,EAAAA,kBAAAA,IAACX,EAAsB,KAAtB,CACC,IAAAU,EACA,UAAWG,EAAAA,GACT,kOACAP,CAAA,EAED,GAAGG,CAAA,CACN,CACD,EACDK,EAAiB,YAAcd,EAAsB,KAAK"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { DropzoneOptions } from 'react-dropzone';
|
|
3
|
+
interface DropzoneProps {
|
|
4
|
+
onDrop: (acceptedFiles: File[]) => void;
|
|
5
|
+
children: ReactNode;
|
|
6
|
+
className?: string;
|
|
7
|
+
overlayClassName?: string;
|
|
8
|
+
dropzoneOptions?: Omit<DropzoneOptions, 'onDrop'>;
|
|
9
|
+
showOverlay?: boolean;
|
|
10
|
+
}
|
|
11
|
+
export declare function Dropzone({ onDrop, children, className, overlayClassName, dropzoneOptions, showOverlay, }: DropzoneProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export {};
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { j as e } from "../jsx-runtime-DGlMoOmv.js";
|
|
2
|
+
import { useCallback as l } from "react";
|
|
3
|
+
import { useDropzone as u } from "react-dropzone";
|
|
4
|
+
import { Upload as x } from "lucide-react";
|
|
5
|
+
function g({
|
|
6
|
+
onDrop: r,
|
|
7
|
+
children: o,
|
|
8
|
+
className: t = "",
|
|
9
|
+
overlayClassName: s = "",
|
|
10
|
+
dropzoneOptions: n,
|
|
11
|
+
showOverlay: i = !0
|
|
12
|
+
}) {
|
|
13
|
+
const a = l((c) => {
|
|
14
|
+
r(c);
|
|
15
|
+
}, [r]), {
|
|
16
|
+
getRootProps: m,
|
|
17
|
+
getInputProps: p,
|
|
18
|
+
isDragActive: d
|
|
19
|
+
} = u({
|
|
20
|
+
onDrop: a,
|
|
21
|
+
noClick: !0,
|
|
22
|
+
// Don't trigger on click since we're using the area for other purposes
|
|
23
|
+
noKeyboard: !0,
|
|
24
|
+
...n
|
|
25
|
+
});
|
|
26
|
+
return /* @__PURE__ */ e.jsxs(
|
|
27
|
+
"div",
|
|
28
|
+
{
|
|
29
|
+
...m(),
|
|
30
|
+
className: t,
|
|
31
|
+
children: [
|
|
32
|
+
/* @__PURE__ */ e.jsx("input", { ...p() }),
|
|
33
|
+
d && i && /* @__PURE__ */ e.jsx("div", { className: `absolute inset-0 bg-background/80 flex items-center justify-center z-10 pointer-events-none ${s}`, children: /* @__PURE__ */ e.jsxs("div", { className: "border-2 border-dashed border-primary rounded-lg p-8 text-center", children: [
|
|
34
|
+
/* @__PURE__ */ e.jsx(x, { className: "h-12 w-12 mb-2 text-primary mx-auto" }),
|
|
35
|
+
/* @__PURE__ */ e.jsx("p", { className: "text-base font-medium mb-1", children: "Drop files here" })
|
|
36
|
+
] }) }),
|
|
37
|
+
o
|
|
38
|
+
]
|
|
39
|
+
}
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
export {
|
|
43
|
+
g as Dropzone
|
|
44
|
+
};
|
|
45
|
+
//# sourceMappingURL=dropzone.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropzone.esm.js","sources":["../../src/components/dropzone.tsx"],"sourcesContent":["import React, { ReactNode, useCallback } from 'react';\nimport { useDropzone, DropzoneOptions } from 'react-dropzone';\nimport { Upload } from 'lucide-react';\n\ninterface DropzoneProps {\n onDrop: (acceptedFiles: File[]) => void;\n children: ReactNode;\n className?: string;\n overlayClassName?: string;\n dropzoneOptions?: Omit<DropzoneOptions, 'onDrop'>;\n showOverlay?: boolean;\n}\n\nexport function Dropzone({\n onDrop,\n children,\n className = \"\",\n overlayClassName = \"\",\n dropzoneOptions,\n showOverlay = true,\n}: DropzoneProps) {\n const handleDrop = useCallback((acceptedFiles: File[]) => {\n onDrop(acceptedFiles);\n }, [onDrop]);\n\n const { \n getRootProps, \n getInputProps, \n isDragActive \n } = useDropzone({\n onDrop: handleDrop,\n noClick: true, // Don't trigger on click since we're using the area for other purposes\n noKeyboard: true,\n ...dropzoneOptions\n });\n\n return (\n <div\n {...getRootProps()}\n className={className}\n >\n <input {...getInputProps()} />\n \n {isDragActive && showOverlay && (\n <div className={`absolute inset-0 bg-background/80 flex items-center justify-center z-10 pointer-events-none ${overlayClassName}`}>\n <div className=\"border-2 border-dashed border-primary rounded-lg p-8 text-center\">\n <Upload className=\"h-12 w-12 mb-2 text-primary mx-auto\" />\n <p className=\"text-base font-medium mb-1\">Drop files here</p>\n </div>\n </div>\n )}\n \n {children}\n </div>\n );\n} "],"names":["Dropzone","onDrop","children","className","overlayClassName","dropzoneOptions","showOverlay","handleDrop","useCallback","acceptedFiles","getRootProps","getInputProps","isDragActive","useDropzone","jsxs","jsx","Upload"],"mappings":";;;;AAaO,SAASA,EAAS;AAAA,EACvB,QAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC,IAAY;AAAA,EACZ,kBAAAC,IAAmB;AAAA,EACnB,iBAAAC;AAAA,EACA,aAAAC,IAAc;AAChB,GAAkB;AAChB,QAAMC,IAAaC,EAAY,CAACC,MAA0B;AACxD,IAAAR,EAAOQ,CAAa;AAAA,EACtB,GAAG,CAACR,CAAM,CAAC,GAEL;AAAA,IACJ,cAAAS;AAAA,IACA,eAAAC;AAAA,IACA,cAAAC;AAAA,EAAA,IACEC,EAAY;AAAA,IACd,QAAQN;AAAA,IACR,SAAS;AAAA;AAAA,IACT,YAAY;AAAA,IACZ,GAAGF;AAAA,EAAA,CACJ;AAED,SACES,gBAAAA,EAAAA;AAAAA,IAAC;AAAA,IAAA;AAAA,MACE,GAAGJ,EAAA;AAAA,MACJ,WAAAP;AAAA,MAEA,UAAA;AAAA,QAAAY,gBAAAA,EAAAA,IAAC,SAAA,EAAO,GAAGJ,EAAA,EAAc,CAAG;AAAA,QAE3BC,KAAgBN,KACfS,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAW,+FAA+FX,CAAgB,IAC7H,UAAAU,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,oEACb,UAAA;AAAA,UAAAC,gBAAAA,EAAAA,IAACC,GAAA,EAAO,WAAU,sCAAA,CAAsC;AAAA,UACxDD,gBAAAA,EAAAA,IAAC,KAAA,EAAE,WAAU,8BAA6B,UAAA,kBAAA,CAAe;AAAA,QAAA,EAAA,CAC3D,EAAA,CACF;AAAA,QAGDb;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGP;"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../jsx-runtime-BYECrxsp.cjs"),d=require("react"),l=require("react-dropzone"),m=require("lucide-react");function j({onDrop:t,children:r,className:s="",overlayClassName:o="",dropzoneOptions:n,showOverlay:i=!0}){const u=d.useCallback(p=>{t(p)},[t]),{getRootProps:c,getInputProps:a,isDragActive:x}=l.useDropzone({onDrop:u,noClick:!0,noKeyboard:!0,...n});return e.jsxRuntimeExports.jsxs("div",{...c(),className:s,children:[e.jsxRuntimeExports.jsx("input",{...a()}),x&&i&&e.jsxRuntimeExports.jsx("div",{className:`absolute inset-0 bg-background/80 flex items-center justify-center z-10 pointer-events-none ${o}`,children:e.jsxRuntimeExports.jsxs("div",{className:"border-2 border-dashed border-primary rounded-lg p-8 text-center",children:[e.jsxRuntimeExports.jsx(m.Upload,{className:"h-12 w-12 mb-2 text-primary mx-auto"}),e.jsxRuntimeExports.jsx("p",{className:"text-base font-medium mb-1",children:"Drop files here"})]})}),r]})}exports.Dropzone=j;
|
|
2
|
+
//# sourceMappingURL=dropzone.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropzone.js","sources":["../../src/components/dropzone.tsx"],"sourcesContent":["import React, { ReactNode, useCallback } from 'react';\nimport { useDropzone, DropzoneOptions } from 'react-dropzone';\nimport { Upload } from 'lucide-react';\n\ninterface DropzoneProps {\n onDrop: (acceptedFiles: File[]) => void;\n children: ReactNode;\n className?: string;\n overlayClassName?: string;\n dropzoneOptions?: Omit<DropzoneOptions, 'onDrop'>;\n showOverlay?: boolean;\n}\n\nexport function Dropzone({\n onDrop,\n children,\n className = \"\",\n overlayClassName = \"\",\n dropzoneOptions,\n showOverlay = true,\n}: DropzoneProps) {\n const handleDrop = useCallback((acceptedFiles: File[]) => {\n onDrop(acceptedFiles);\n }, [onDrop]);\n\n const { \n getRootProps, \n getInputProps, \n isDragActive \n } = useDropzone({\n onDrop: handleDrop,\n noClick: true, // Don't trigger on click since we're using the area for other purposes\n noKeyboard: true,\n ...dropzoneOptions\n });\n\n return (\n <div\n {...getRootProps()}\n className={className}\n >\n <input {...getInputProps()} />\n \n {isDragActive && showOverlay && (\n <div className={`absolute inset-0 bg-background/80 flex items-center justify-center z-10 pointer-events-none ${overlayClassName}`}>\n <div className=\"border-2 border-dashed border-primary rounded-lg p-8 text-center\">\n <Upload className=\"h-12 w-12 mb-2 text-primary mx-auto\" />\n <p className=\"text-base font-medium mb-1\">Drop files here</p>\n </div>\n </div>\n )}\n \n {children}\n </div>\n );\n} "],"names":["Dropzone","onDrop","children","className","overlayClassName","dropzoneOptions","showOverlay","handleDrop","useCallback","acceptedFiles","getRootProps","getInputProps","isDragActive","useDropzone","jsxs","jsx","Upload"],"mappings":"wMAaO,SAASA,EAAS,CACvB,OAAAC,EACA,SAAAC,EACA,UAAAC,EAAY,GACZ,iBAAAC,EAAmB,GACnB,gBAAAC,EACA,YAAAC,EAAc,EAChB,EAAkB,CAChB,MAAMC,EAAaC,cAAaC,GAA0B,CACxDR,EAAOQ,CAAa,CACtB,EAAG,CAACR,CAAM,CAAC,EAEL,CACJ,aAAAS,EACA,cAAAC,EACA,aAAAC,CAAA,EACEC,cAAY,CACd,OAAQN,EACR,QAAS,GACT,WAAY,GACZ,GAAGF,CAAA,CACJ,EAED,OACES,EAAAA,kBAAAA,KAAC,MAAA,CACE,GAAGJ,EAAA,EACJ,UAAAP,EAEA,SAAA,CAAAY,EAAAA,kBAAAA,IAAC,QAAA,CAAO,GAAGJ,EAAA,CAAc,CAAG,EAE3BC,GAAgBN,GACfS,EAAAA,kBAAAA,IAAC,MAAA,CAAI,UAAW,+FAA+FX,CAAgB,GAC7H,SAAAU,EAAAA,kBAAAA,KAAC,MAAA,CAAI,UAAU,mEACb,SAAA,CAAAC,EAAAA,kBAAAA,IAACC,EAAAA,OAAA,CAAO,UAAU,qCAAA,CAAsC,EACxDD,EAAAA,kBAAAA,IAAC,IAAA,CAAE,UAAU,6BAA6B,SAAA,iBAAA,CAAe,CAAA,CAAA,CAC3D,CAAA,CACF,EAGDb,CAAA,CAAA,CAAA,CAGP"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
interface ImageCropperModalProps {
|
|
2
|
+
isOpen: boolean;
|
|
3
|
+
onClose: () => void;
|
|
4
|
+
imageSrc: string | null;
|
|
5
|
+
onCrop: (croppedImage: string) => void;
|
|
6
|
+
title?: string;
|
|
7
|
+
outputSize?: number;
|
|
8
|
+
}
|
|
9
|
+
export declare function ImageCropperModal({ isOpen, onClose, imageSrc, onCrop, title, outputSize }: ImageCropperModalProps): import("react/jsx-runtime").JSX.Element | null;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,251 @@
|
|
|
1
|
+
import { j as s } from "../jsx-runtime-DGlMoOmv.js";
|
|
2
|
+
import { useState as p, useRef as $, useCallback as h, useEffect as L } from "react";
|
|
3
|
+
import { Button as R } from "./button.esm.js";
|
|
4
|
+
import { Modal as W } from "./modal.esm.js";
|
|
5
|
+
import { Label as q } from "./label.esm.js";
|
|
6
|
+
import { RotateCcw as T, X as K, Check as F } from "lucide-react";
|
|
7
|
+
function _({
|
|
8
|
+
isOpen: m,
|
|
9
|
+
onClose: b,
|
|
10
|
+
imageSrc: u,
|
|
11
|
+
onCrop: I,
|
|
12
|
+
title: E = "Crop Your Image",
|
|
13
|
+
outputSize: d = 200
|
|
14
|
+
}) {
|
|
15
|
+
const [t, x] = p({ x: 0, y: 0, size: 100 }), [z, v] = p(!1), [M, y] = p(!1), [N, P] = p({ x: 0, y: 0 }), [r, X] = p({ width: 0, height: 0 }), k = $(null), f = $(null), U = h(() => {
|
|
16
|
+
if (f.current) {
|
|
17
|
+
const e = f.current, i = 400, a = e.naturalWidth / e.naturalHeight;
|
|
18
|
+
let n, o;
|
|
19
|
+
a > 1 ? (n = i, o = i / a) : (o = i, n = i * a), X({ width: n, height: o });
|
|
20
|
+
const l = Math.min(n, o) * 0.6;
|
|
21
|
+
x({
|
|
22
|
+
x: (n - l) / 2,
|
|
23
|
+
y: (o - l) / 2,
|
|
24
|
+
size: l
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
}, []), w = h((e, i) => {
|
|
28
|
+
e.preventDefault();
|
|
29
|
+
const a = e.currentTarget.getBoundingClientRect(), n = e.clientX - a.left, o = e.clientY - a.top;
|
|
30
|
+
if (i === "resize") {
|
|
31
|
+
y(!0);
|
|
32
|
+
const l = t.x + t.size / 2, g = t.y + t.size / 2, c = Math.sqrt((n - l) ** 2 + (o - g) ** 2);
|
|
33
|
+
P({ x: c, y: 0 });
|
|
34
|
+
} else
|
|
35
|
+
v(!0), P({ x: n - t.x, y: o - t.y });
|
|
36
|
+
}, [t]), A = h((e) => {
|
|
37
|
+
if (!z && !M) return;
|
|
38
|
+
const i = e.currentTarget.getBoundingClientRect(), a = e.clientX - i.left, n = e.clientY - i.top;
|
|
39
|
+
if (M) {
|
|
40
|
+
const o = t.x + t.size / 2, l = t.y + t.size / 2, g = Math.sqrt((a - o) ** 2 + (n - l) ** 2), c = Math.max(50, Math.min(Math.min(r.width, r.height), g * 2));
|
|
41
|
+
x({
|
|
42
|
+
x: Math.max(0, Math.min(r.width - c, o - c / 2)),
|
|
43
|
+
y: Math.max(0, Math.min(r.height - c, l - c / 2)),
|
|
44
|
+
size: c
|
|
45
|
+
});
|
|
46
|
+
} else if (z) {
|
|
47
|
+
const o = a - N.x, l = n - N.y, g = r.width - t.size, c = r.height - t.size;
|
|
48
|
+
x((D) => ({
|
|
49
|
+
...D,
|
|
50
|
+
x: Math.max(0, Math.min(g, o)),
|
|
51
|
+
y: Math.max(0, Math.min(c, l))
|
|
52
|
+
}));
|
|
53
|
+
}
|
|
54
|
+
}, [z, M, N, r, t]), Y = h(() => {
|
|
55
|
+
v(!1), y(!1);
|
|
56
|
+
}, []), B = h(() => {
|
|
57
|
+
if (r.width && r.height) {
|
|
58
|
+
const e = Math.min(r.width, r.height) * 0.6;
|
|
59
|
+
x({
|
|
60
|
+
x: (r.width - e) / 2,
|
|
61
|
+
y: (r.height - e) / 2,
|
|
62
|
+
size: e
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
}, [r]), H = h(() => {
|
|
66
|
+
if (!k.current || !f.current) return;
|
|
67
|
+
const e = k.current, i = e.getContext("2d");
|
|
68
|
+
if (!i) return;
|
|
69
|
+
const a = f.current;
|
|
70
|
+
e.width = d, e.height = d;
|
|
71
|
+
const n = a.naturalWidth / r.width, o = a.naturalHeight / r.height, l = t.x * n, g = t.y * o, c = t.size * Math.min(n, o);
|
|
72
|
+
i.beginPath(), i.arc(d / 2, d / 2, d / 2, 0, Math.PI * 2), i.clip(), i.drawImage(
|
|
73
|
+
a,
|
|
74
|
+
l,
|
|
75
|
+
g,
|
|
76
|
+
c,
|
|
77
|
+
c,
|
|
78
|
+
0,
|
|
79
|
+
0,
|
|
80
|
+
d,
|
|
81
|
+
d
|
|
82
|
+
);
|
|
83
|
+
const D = e.toDataURL("image/png");
|
|
84
|
+
I(D), b();
|
|
85
|
+
}, [t, r, I, b, d]), j = h(() => {
|
|
86
|
+
v(!1), y(!1), x({ x: 0, y: 0, size: 100 }), b();
|
|
87
|
+
}, [b]), C = h((e) => {
|
|
88
|
+
e.key === "Escape" && m && (e.stopPropagation(), j());
|
|
89
|
+
}, [m, j]);
|
|
90
|
+
return L(() => {
|
|
91
|
+
if (m)
|
|
92
|
+
return document.addEventListener("keydown", C, !0), () => document.removeEventListener("keydown", C, !0);
|
|
93
|
+
}, [m, C]), L(() => {
|
|
94
|
+
m && u && (v(!1), y(!1), X({ width: 0, height: 0 }));
|
|
95
|
+
}, [m, u]), u ? /* @__PURE__ */ s.jsx(
|
|
96
|
+
W,
|
|
97
|
+
{
|
|
98
|
+
isOpen: m,
|
|
99
|
+
onClose: j,
|
|
100
|
+
title: E,
|
|
101
|
+
size: "2xl",
|
|
102
|
+
zIndexClassName: "z-[60]",
|
|
103
|
+
footer: /* @__PURE__ */ s.jsxs("div", { className: "flex items-center justify-between w-full", children: [
|
|
104
|
+
/* @__PURE__ */ s.jsxs(
|
|
105
|
+
R,
|
|
106
|
+
{
|
|
107
|
+
variant: "ghost",
|
|
108
|
+
size: "sm",
|
|
109
|
+
onClick: B,
|
|
110
|
+
className: "flex items-center gap-2",
|
|
111
|
+
children: [
|
|
112
|
+
/* @__PURE__ */ s.jsx(T, { className: "h-4 w-4" }),
|
|
113
|
+
"Reset"
|
|
114
|
+
]
|
|
115
|
+
}
|
|
116
|
+
),
|
|
117
|
+
/* @__PURE__ */ s.jsxs("div", { className: "flex gap-3", children: [
|
|
118
|
+
/* @__PURE__ */ s.jsxs(R, { variant: "outline", onClick: j, children: [
|
|
119
|
+
/* @__PURE__ */ s.jsx(K, { className: "h-4 w-4 mr-2" }),
|
|
120
|
+
"Cancel"
|
|
121
|
+
] }),
|
|
122
|
+
/* @__PURE__ */ s.jsxs(R, { onClick: H, children: [
|
|
123
|
+
/* @__PURE__ */ s.jsx(F, { className: "h-4 w-4 mr-2" }),
|
|
124
|
+
"Crop Image"
|
|
125
|
+
] })
|
|
126
|
+
] })
|
|
127
|
+
] }),
|
|
128
|
+
children: /* @__PURE__ */ s.jsxs("div", { className: "p-6", children: [
|
|
129
|
+
/* @__PURE__ */ s.jsxs("div", { className: "space-y-6", children: [
|
|
130
|
+
/* @__PURE__ */ s.jsx("div", { className: "text-center", children: /* @__PURE__ */ s.jsx("p", { className: "text-sm text-muted-foreground", children: "Drag the circle to move • Drag corners to resize • Click reset to center" }) }),
|
|
131
|
+
/* @__PURE__ */ s.jsx("div", { className: "flex justify-center", children: /* @__PURE__ */ s.jsxs(
|
|
132
|
+
"div",
|
|
133
|
+
{
|
|
134
|
+
className: "relative bg-gray-100 rounded-xl overflow-hidden select-none border",
|
|
135
|
+
style: { width: r.width, height: r.height },
|
|
136
|
+
onMouseMove: A,
|
|
137
|
+
onMouseUp: Y,
|
|
138
|
+
onMouseLeave: Y,
|
|
139
|
+
children: [
|
|
140
|
+
/* @__PURE__ */ s.jsx(
|
|
141
|
+
"img",
|
|
142
|
+
{
|
|
143
|
+
ref: f,
|
|
144
|
+
src: u,
|
|
145
|
+
alt: "Crop preview",
|
|
146
|
+
className: "block",
|
|
147
|
+
style: { width: r.width, height: r.height },
|
|
148
|
+
onLoad: U,
|
|
149
|
+
draggable: !1
|
|
150
|
+
}
|
|
151
|
+
),
|
|
152
|
+
/* @__PURE__ */ s.jsxs(
|
|
153
|
+
"div",
|
|
154
|
+
{
|
|
155
|
+
className: "absolute border-2 border-white rounded-full shadow-lg cursor-move",
|
|
156
|
+
style: {
|
|
157
|
+
left: t.x,
|
|
158
|
+
top: t.y,
|
|
159
|
+
width: t.size,
|
|
160
|
+
height: t.size
|
|
161
|
+
},
|
|
162
|
+
onMouseDown: (e) => w(e, "move"),
|
|
163
|
+
children: [
|
|
164
|
+
/* @__PURE__ */ s.jsx("div", { className: "w-full h-full rounded-full border-2 border-primary border-dashed" }),
|
|
165
|
+
/* @__PURE__ */ s.jsx(
|
|
166
|
+
"div",
|
|
167
|
+
{
|
|
168
|
+
className: "absolute w-5 h-5 bg-white border-2 border-primary rounded-full shadow-lg cursor-nw-resize -top-2.5 -right-2.5 hover:bg-primary hover:border-white transition-colors flex items-center justify-center",
|
|
169
|
+
onMouseDown: (e) => {
|
|
170
|
+
e.stopPropagation(), w(e, "resize");
|
|
171
|
+
},
|
|
172
|
+
children: /* @__PURE__ */ s.jsx("div", { className: "w-1.5 h-1.5 bg-primary rounded-full hover:bg-white transition-colors" })
|
|
173
|
+
}
|
|
174
|
+
),
|
|
175
|
+
/* @__PURE__ */ s.jsx(
|
|
176
|
+
"div",
|
|
177
|
+
{
|
|
178
|
+
className: "absolute w-5 h-5 bg-white border-2 border-primary rounded-full shadow-lg cursor-ne-resize -bottom-2.5 -right-2.5 hover:bg-primary hover:border-white transition-colors flex items-center justify-center",
|
|
179
|
+
onMouseDown: (e) => {
|
|
180
|
+
e.stopPropagation(), w(e, "resize");
|
|
181
|
+
},
|
|
182
|
+
children: /* @__PURE__ */ s.jsx("div", { className: "w-1.5 h-1.5 bg-primary rounded-full hover:bg-white transition-colors" })
|
|
183
|
+
}
|
|
184
|
+
),
|
|
185
|
+
/* @__PURE__ */ s.jsx(
|
|
186
|
+
"div",
|
|
187
|
+
{
|
|
188
|
+
className: "absolute w-5 h-5 bg-white border-2 border-primary rounded-full shadow-lg cursor-sw-resize -bottom-2.5 -left-2.5 hover:bg-primary hover:border-white transition-colors flex items-center justify-center",
|
|
189
|
+
onMouseDown: (e) => {
|
|
190
|
+
e.stopPropagation(), w(e, "resize");
|
|
191
|
+
},
|
|
192
|
+
children: /* @__PURE__ */ s.jsx("div", { className: "w-1.5 h-1.5 bg-primary rounded-full hover:bg-white transition-colors" })
|
|
193
|
+
}
|
|
194
|
+
),
|
|
195
|
+
/* @__PURE__ */ s.jsx(
|
|
196
|
+
"div",
|
|
197
|
+
{
|
|
198
|
+
className: "absolute w-5 h-5 bg-white border-2 border-primary rounded-full shadow-lg cursor-se-resize -top-2.5 -left-2.5 hover:bg-primary hover:border-white transition-colors flex items-center justify-center",
|
|
199
|
+
onMouseDown: (e) => {
|
|
200
|
+
e.stopPropagation(), w(e, "resize");
|
|
201
|
+
},
|
|
202
|
+
children: /* @__PURE__ */ s.jsx("div", { className: "w-1.5 h-1.5 bg-primary rounded-full hover:bg-white transition-colors" })
|
|
203
|
+
}
|
|
204
|
+
)
|
|
205
|
+
]
|
|
206
|
+
}
|
|
207
|
+
),
|
|
208
|
+
/* @__PURE__ */ s.jsx(
|
|
209
|
+
"div",
|
|
210
|
+
{
|
|
211
|
+
className: "absolute inset-0 bg-black/50 pointer-events-none",
|
|
212
|
+
style: {
|
|
213
|
+
clipPath: `circle(${t.size / 2}px at ${t.x + t.size / 2}px ${t.y + t.size / 2}px)`
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
)
|
|
217
|
+
]
|
|
218
|
+
}
|
|
219
|
+
) }),
|
|
220
|
+
/* @__PURE__ */ s.jsx("div", { className: "flex justify-center", children: /* @__PURE__ */ s.jsxs("div", { className: "text-center", children: [
|
|
221
|
+
/* @__PURE__ */ s.jsx(q, { className: "text-xs font-medium text-muted-foreground mb-2 block", children: "Preview" }),
|
|
222
|
+
/* @__PURE__ */ s.jsx(
|
|
223
|
+
"div",
|
|
224
|
+
{
|
|
225
|
+
className: "rounded-full border-2 border-border bg-background overflow-hidden mx-auto",
|
|
226
|
+
style: { width: 80, height: 80 },
|
|
227
|
+
children: /* @__PURE__ */ s.jsx(
|
|
228
|
+
"div",
|
|
229
|
+
{
|
|
230
|
+
className: "w-full h-full bg-gray-100",
|
|
231
|
+
style: {
|
|
232
|
+
backgroundImage: `url(${u})`,
|
|
233
|
+
backgroundSize: `${r.width / t.size * 80}px ${r.height / t.size * 80}px`,
|
|
234
|
+
backgroundPosition: `-${t.x / t.size * 80}px -${t.y / t.size * 80}px`,
|
|
235
|
+
backgroundRepeat: "no-repeat"
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
)
|
|
239
|
+
}
|
|
240
|
+
)
|
|
241
|
+
] }) })
|
|
242
|
+
] }),
|
|
243
|
+
/* @__PURE__ */ s.jsx("canvas", { ref: k, className: "hidden" })
|
|
244
|
+
] })
|
|
245
|
+
}
|
|
246
|
+
) : null;
|
|
247
|
+
}
|
|
248
|
+
export {
|
|
249
|
+
_ as ImageCropperModal
|
|
250
|
+
};
|
|
251
|
+
//# sourceMappingURL=image-cropper-modal.esm.js.map
|