@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.
Files changed (322) hide show
  1. package/README.md +6 -6
  2. package/dist/alert-dialog.d.ts +18 -0
  3. package/dist/alert.d.ts +18 -0
  4. package/dist/avatar.d.ts +9 -0
  5. package/dist/badge.d.ts +15 -0
  6. package/dist/button.d.ts +16 -0
  7. package/dist/calendar.d.ts +21 -0
  8. package/dist/card.d.ts +15 -0
  9. package/dist/carousel.d.ts +18 -0
  10. package/dist/charts.d.ts +26 -0
  11. package/dist/checkbox.d.ts +6 -0
  12. package/dist/collapse.d.ts +15 -0
  13. package/dist/command-menu.d.ts +12 -0
  14. package/dist/command.d.ts +89 -0
  15. package/dist/components/alert-dialog.d.ts +15 -0
  16. package/dist/components/alert-dialog.esm.js +59 -0
  17. package/dist/components/alert-dialog.esm.js.map +1 -0
  18. package/dist/components/alert-dialog.js +2 -0
  19. package/dist/components/alert-dialog.js.map +1 -0
  20. package/dist/components/alert.d.ts +11 -0
  21. package/dist/components/alert.esm.js +51 -0
  22. package/dist/components/alert.esm.js.map +1 -0
  23. package/dist/components/alert.js +2 -0
  24. package/dist/components/alert.js.map +1 -0
  25. package/dist/components/avatar.d.ts +5 -0
  26. package/dist/components/avatar.esm.js +42 -0
  27. package/dist/components/avatar.esm.js.map +1 -0
  28. package/dist/components/avatar.js +2 -0
  29. package/dist/components/avatar.js.map +1 -0
  30. package/dist/components/badge.d.ts +9 -0
  31. package/dist/components/badge.esm.js +27 -0
  32. package/dist/components/badge.esm.js.map +1 -0
  33. package/dist/components/badge.js +2 -0
  34. package/dist/components/badge.js.map +1 -0
  35. package/dist/components/button.d.ts +13 -0
  36. package/dist/components/button.esm.js +48 -0
  37. package/dist/components/button.esm.js.map +1 -0
  38. package/dist/components/button.js +2 -0
  39. package/dist/components/button.js.map +1 -0
  40. package/dist/components/calendar.d.ts +18 -0
  41. package/dist/components/calendar.esm.js +5562 -0
  42. package/dist/components/calendar.esm.js.map +1 -0
  43. package/dist/components/calendar.js +2 -0
  44. package/dist/components/calendar.js.map +1 -0
  45. package/dist/components/card.d.ts +8 -0
  46. package/dist/components/card.esm.js +62 -0
  47. package/dist/components/card.esm.js.map +1 -0
  48. package/dist/components/card.js +2 -0
  49. package/dist/components/card.js.map +1 -0
  50. package/dist/components/carousel.d.ts +13 -0
  51. package/dist/components/carousel.esm.js +101 -0
  52. package/dist/components/carousel.esm.js.map +1 -0
  53. package/dist/components/carousel.js +2 -0
  54. package/dist/components/carousel.js.map +1 -0
  55. package/dist/components/charts.d.ts +17 -0
  56. package/dist/components/charts.esm.js +48 -0
  57. package/dist/components/charts.esm.js.map +1 -0
  58. package/dist/components/charts.js +2 -0
  59. package/dist/components/charts.js.map +1 -0
  60. package/dist/components/checkbox.d.ts +4 -0
  61. package/dist/components/checkbox.esm.js +32 -0
  62. package/dist/components/checkbox.esm.js.map +1 -0
  63. package/dist/components/checkbox.js +2 -0
  64. package/dist/components/checkbox.js.map +1 -0
  65. package/dist/components/collapse.d.ts +11 -0
  66. package/dist/components/collapse.esm.js +50 -0
  67. package/dist/components/collapse.esm.js.map +1 -0
  68. package/dist/components/collapse.js +2 -0
  69. package/dist/components/collapse.js.map +1 -0
  70. package/dist/components/command-menu.d.ts +7 -0
  71. package/dist/components/command-menu.esm.js +90 -0
  72. package/dist/components/command-menu.esm.js.map +1 -0
  73. package/dist/components/command-menu.js +2 -0
  74. package/dist/components/command-menu.js.map +1 -0
  75. package/dist/components/command.d.ts +79 -0
  76. package/dist/components/command.esm.js +425 -0
  77. package/dist/components/command.esm.js.map +1 -0
  78. package/dist/components/command.js +2 -0
  79. package/dist/components/command.js.map +1 -0
  80. package/dist/components/confirmation-modal.d.ts +12 -0
  81. package/dist/components/confirmation-modal.esm.js +46 -0
  82. package/dist/components/confirmation-modal.esm.js.map +1 -0
  83. package/dist/components/confirmation-modal.js +2 -0
  84. package/dist/components/confirmation-modal.js.map +1 -0
  85. package/dist/components/context-menu.d.ts +26 -0
  86. package/dist/components/context-menu.esm.js +186 -0
  87. package/dist/components/context-menu.esm.js.map +1 -0
  88. package/dist/components/context-menu.js +2 -0
  89. package/dist/components/context-menu.js.map +1 -0
  90. package/dist/components/dialog.d.ts +21 -0
  91. package/dist/components/dialog.esm.js +122 -0
  92. package/dist/components/dialog.esm.js.map +1 -0
  93. package/dist/components/dialog.js +2 -0
  94. package/dist/components/dialog.js.map +1 -0
  95. package/dist/components/dropdown-menu.d.ts +9 -0
  96. package/dist/components/dropdown-menu.esm.js +49 -0
  97. package/dist/components/dropdown-menu.esm.js.map +1 -0
  98. package/dist/components/dropdown-menu.js +2 -0
  99. package/dist/components/dropdown-menu.js.map +1 -0
  100. package/dist/components/dropzone.d.ts +12 -0
  101. package/dist/components/dropzone.esm.js +45 -0
  102. package/dist/components/dropzone.esm.js.map +1 -0
  103. package/dist/components/dropzone.js +2 -0
  104. package/dist/components/dropzone.js.map +1 -0
  105. package/dist/components/image-cropper-modal.d.ts +10 -0
  106. package/dist/components/image-cropper-modal.esm.js +251 -0
  107. package/dist/components/image-cropper-modal.esm.js.map +1 -0
  108. package/dist/components/image-cropper-modal.js +2 -0
  109. package/dist/components/image-cropper-modal.js.map +1 -0
  110. package/dist/components/image-cropper.d.ts +11 -0
  111. package/dist/components/image-cropper.esm.js +131 -0
  112. package/dist/components/image-cropper.esm.js.map +1 -0
  113. package/dist/components/image-cropper.js +2 -0
  114. package/dist/components/image-cropper.js.map +1 -0
  115. package/dist/components/input.d.ts +5 -0
  116. package/dist/components/input.esm.js +22 -0
  117. package/dist/components/input.esm.js.map +1 -0
  118. package/dist/components/input.js +2 -0
  119. package/dist/components/input.js.map +1 -0
  120. package/dist/components/label.d.ts +4 -0
  121. package/dist/components/label.esm.js +20 -0
  122. package/dist/components/label.esm.js.map +1 -0
  123. package/dist/components/label.js +2 -0
  124. package/dist/components/label.js.map +1 -0
  125. package/dist/components/loader.d.ts +10 -0
  126. package/dist/components/loader.esm.js +70 -0
  127. package/dist/components/loader.esm.js.map +1 -0
  128. package/dist/components/loader.js +2 -0
  129. package/dist/components/loader.js.map +1 -0
  130. package/dist/components/loading-placeholder.d.ts +8 -0
  131. package/dist/components/loading-placeholder.esm.js +25 -0
  132. package/dist/components/loading-placeholder.esm.js.map +1 -0
  133. package/dist/components/loading-placeholder.js +2 -0
  134. package/dist/components/loading-placeholder.js.map +1 -0
  135. package/dist/components/markdown.d.ts +2 -0
  136. package/dist/components/markdown.esm.js +12066 -0
  137. package/dist/components/markdown.esm.js.map +1 -0
  138. package/dist/components/markdown.js +18 -0
  139. package/dist/components/markdown.js.map +1 -0
  140. package/dist/components/mention.d.ts +25 -0
  141. package/dist/components/mention.esm.js +154 -0
  142. package/dist/components/mention.esm.js.map +1 -0
  143. package/dist/components/mention.js +2 -0
  144. package/dist/components/mention.js.map +1 -0
  145. package/dist/components/modal.d.ts +19 -0
  146. package/dist/components/modal.esm.js +92 -0
  147. package/dist/components/modal.esm.js.map +1 -0
  148. package/dist/components/modal.js +2 -0
  149. package/dist/components/modal.js.map +1 -0
  150. package/dist/components/monaco-editor.d.ts +2 -0
  151. package/dist/components/monaco-editor.esm.js +295 -0
  152. package/dist/components/monaco-editor.esm.js.map +1 -0
  153. package/dist/components/monaco-editor.js +8 -0
  154. package/dist/components/monaco-editor.js.map +1 -0
  155. package/dist/components/notification.d.ts +5 -0
  156. package/dist/components/notification.esm.js +26 -0
  157. package/dist/components/notification.esm.js.map +1 -0
  158. package/dist/components/notification.js +2 -0
  159. package/dist/components/notification.js.map +1 -0
  160. package/dist/components/popover.d.ts +6 -0
  161. package/dist/components/popover.esm.js +24 -0
  162. package/dist/components/popover.esm.js.map +1 -0
  163. package/dist/components/popover.js +2 -0
  164. package/dist/components/popover.js.map +1 -0
  165. package/dist/components/progress.d.ts +4 -0
  166. package/dist/components/progress.esm.js +35 -0
  167. package/dist/components/progress.esm.js.map +1 -0
  168. package/dist/components/progress.js +2 -0
  169. package/dist/components/progress.js.map +1 -0
  170. package/dist/components/radio-group.d.ts +5 -0
  171. package/dist/components/radio-group.esm.js +48 -0
  172. package/dist/components/radio-group.esm.js.map +1 -0
  173. package/dist/components/radio-group.js +2 -0
  174. package/dist/components/radio-group.js.map +1 -0
  175. package/dist/components/scroll-area.d.ts +5 -0
  176. package/dist/components/scroll-area.esm.js +47 -0
  177. package/dist/components/scroll-area.esm.js.map +1 -0
  178. package/dist/components/scroll-area.js +2 -0
  179. package/dist/components/scroll-area.js.map +1 -0
  180. package/dist/components/select.d.ts +20 -0
  181. package/dist/components/select.esm.js +131 -0
  182. package/dist/components/select.esm.js.map +1 -0
  183. package/dist/components/select.js +2 -0
  184. package/dist/components/select.js.map +1 -0
  185. package/dist/components/selection-bar.d.ts +11 -0
  186. package/dist/components/selection-bar.esm.js +54 -0
  187. package/dist/components/selection-bar.esm.js.map +1 -0
  188. package/dist/components/selection-bar.js +2 -0
  189. package/dist/components/selection-bar.js.map +1 -0
  190. package/dist/components/separator.d.ts +4 -0
  191. package/dist/components/separator.esm.js +25 -0
  192. package/dist/components/separator.esm.js.map +1 -0
  193. package/dist/components/separator.js +2 -0
  194. package/dist/components/separator.js.map +1 -0
  195. package/dist/components/sheet.d.ts +13 -0
  196. package/dist/components/sheet.esm.js +129 -0
  197. package/dist/components/sheet.esm.js.map +1 -0
  198. package/dist/components/sheet.js +2 -0
  199. package/dist/components/sheet.js.map +1 -0
  200. package/dist/components/skeleton.d.ts +2 -0
  201. package/dist/components/skeleton.esm.js +18 -0
  202. package/dist/components/skeleton.esm.js.map +1 -0
  203. package/dist/components/skeleton.js +2 -0
  204. package/dist/components/skeleton.js.map +1 -0
  205. package/dist/components/slider.d.ts +4 -0
  206. package/dist/components/slider.esm.js +33 -0
  207. package/dist/components/slider.esm.js.map +1 -0
  208. package/dist/components/slider.js +2 -0
  209. package/dist/components/slider.js.map +1 -0
  210. package/dist/components/stepper.d.ts +2 -0
  211. package/dist/components/stepper.esm.js +214 -0
  212. package/dist/components/stepper.esm.js.map +1 -0
  213. package/dist/components/stepper.js +2 -0
  214. package/dist/components/stepper.js.map +1 -0
  215. package/dist/components/switch.d.ts +4 -0
  216. package/dist/components/switch.esm.js +36 -0
  217. package/dist/components/switch.esm.js.map +1 -0
  218. package/dist/components/switch.js +2 -0
  219. package/dist/components/switch.js.map +1 -0
  220. package/dist/components/table-empty.d.ts +9 -0
  221. package/dist/components/table-empty.esm.js +23 -0
  222. package/dist/components/table-empty.esm.js.map +1 -0
  223. package/dist/components/table-empty.js +2 -0
  224. package/dist/components/table-empty.js.map +1 -0
  225. package/dist/components/table-mobile.d.ts +4 -0
  226. package/dist/components/table-mobile.esm.js +92 -0
  227. package/dist/components/table-mobile.esm.js.map +1 -0
  228. package/dist/components/table-mobile.js +2 -0
  229. package/dist/components/table-mobile.js.map +1 -0
  230. package/dist/components/table.d.ts +31 -0
  231. package/dist/components/table.esm.js +143 -0
  232. package/dist/components/table.esm.js.map +1 -0
  233. package/dist/components/table.js +2 -0
  234. package/dist/components/table.js.map +1 -0
  235. package/dist/components/tabs.d.ts +7 -0
  236. package/dist/components/tabs.esm.js +47 -0
  237. package/dist/components/tabs.esm.js.map +1 -0
  238. package/dist/components/tabs.js +2 -0
  239. package/dist/components/tabs.js.map +1 -0
  240. package/dist/components/terminal.d.ts +43 -0
  241. package/dist/components/terminal.esm.js +50 -0
  242. package/dist/components/terminal.esm.js.map +1 -0
  243. package/dist/components/terminal.js +2 -0
  244. package/dist/components/terminal.js.map +1 -0
  245. package/dist/components/textarea.d.ts +5 -0
  246. package/dist/components/textarea.esm.js +21 -0
  247. package/dist/components/textarea.esm.js.map +1 -0
  248. package/dist/components/textarea.js +2 -0
  249. package/dist/components/textarea.js.map +1 -0
  250. package/dist/components/tooltip.d.ts +8 -0
  251. package/dist/components/tooltip.esm.js +100 -0
  252. package/dist/components/tooltip.esm.js.map +1 -0
  253. package/dist/components/tooltip.js +2 -0
  254. package/dist/components/tooltip.js.map +1 -0
  255. package/dist/components/use-toast.d.ts +21 -0
  256. package/dist/components/use-toast.esm.js +65 -0
  257. package/dist/components/use-toast.esm.js.map +1 -0
  258. package/dist/components/use-toast.js +2 -0
  259. package/dist/components/use-toast.js.map +1 -0
  260. package/dist/confirmation-modal.d.ts +16 -0
  261. package/dist/context-menu.d.ts +41 -0
  262. package/dist/dialog.d.ts +33 -0
  263. package/dist/dropdown-menu.d.ts +16 -0
  264. package/dist/dropzone.d.ts +16 -0
  265. package/dist/image-cropper-modal.d.ts +14 -0
  266. package/dist/image-cropper.d.ts +15 -0
  267. package/dist/index-DACAHwoB.js +35 -0
  268. package/dist/index-DACAHwoB.js.map +1 -0
  269. package/dist/index-Deooizx8.cjs +2 -0
  270. package/dist/index-Deooizx8.cjs.map +1 -0
  271. package/dist/index.d.ts +8 -2
  272. package/dist/index.esm.js +111 -75430
  273. package/dist/index.esm.js.map +1 -1
  274. package/dist/index.js +2 -0
  275. package/dist/index.js.map +1 -0
  276. package/dist/input.d.ts +8 -0
  277. package/dist/jsx-runtime-BYECrxsp.cjs +31 -0
  278. package/dist/jsx-runtime-BYECrxsp.cjs.map +1 -0
  279. package/dist/jsx-runtime-DGlMoOmv.js +631 -0
  280. package/dist/jsx-runtime-DGlMoOmv.js.map +1 -0
  281. package/dist/label.d.ts +6 -0
  282. package/dist/lib/utils.d.ts +2 -0
  283. package/dist/lib/utils.esm.js +5 -0
  284. package/dist/lib/utils.esm.js.map +1 -0
  285. package/dist/lib/utils.js +2 -0
  286. package/dist/lib/utils.js.map +1 -0
  287. package/dist/loader.d.ts +14 -0
  288. package/dist/loading-placeholder.d.ts +12 -0
  289. package/dist/markdown.d.ts +122 -0
  290. package/dist/mention.d.ts +29 -0
  291. package/dist/modal.d.ts +24 -0
  292. package/dist/monaco-editor.d.ts +76 -0
  293. package/dist/notification.d.ts +9 -0
  294. package/dist/popover.d.ts +10 -0
  295. package/dist/progress.d.ts +6 -0
  296. package/dist/radio-group.d.ts +8 -0
  297. package/dist/scroll-area.d.ts +8 -0
  298. package/dist/select.d.ts +31 -0
  299. package/dist/selection-bar.d.ts +15 -0
  300. package/dist/separator.d.ts +6 -0
  301. package/dist/sheet.d.ts +17 -0
  302. package/dist/skeleton.d.ts +5 -0
  303. package/dist/slider.d.ts +6 -0
  304. package/dist/stepper.d.ts +71 -0
  305. package/dist/styles.css +1 -1
  306. package/dist/switch.d.ts +6 -0
  307. package/dist/table-empty.d.ts +13 -0
  308. package/dist/table-mobile.d.ts +37 -0
  309. package/dist/table.d.ts +37 -0
  310. package/dist/tabs.d.ts +12 -0
  311. package/dist/terminal.d.ts +47 -0
  312. package/dist/textarea.d.ts +8 -0
  313. package/dist/tooltip.d.ts +12 -0
  314. package/dist/use-toast.d.ts +28 -0
  315. package/dist/utils-DSKoFOjv.cjs +2 -0
  316. package/dist/utils-DSKoFOjv.cjs.map +1 -0
  317. package/dist/utils-qaFjX9_3.js +2279 -0
  318. package/dist/utils-qaFjX9_3.js.map +1 -0
  319. package/dist/utils.d.ts +5 -0
  320. package/package.json +259 -1
  321. package/dist/index.cjs.js +0 -315
  322. 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