@definable/ui 0.1.13 → 0.1.15

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 (300) hide show
  1. package/README.md +0 -7
  2. package/dist/components/alert-dialog.js +55 -2
  3. package/dist/components/alert.js +63 -2
  4. package/dist/components/avatar.js +41 -2
  5. package/dist/components/badge.js +26 -2
  6. package/dist/components/button.d.ts +2 -2
  7. package/dist/components/button.js +49 -2
  8. package/dist/components/calendar.js +86 -2
  9. package/dist/components/card.js +61 -2
  10. package/dist/components/carousel.js +100 -2
  11. package/dist/components/checkbox.js +31 -2
  12. package/dist/components/collapse.js +49 -2
  13. package/dist/components/command-menu.js +89 -2
  14. package/dist/components/command.js +115 -2
  15. package/dist/components/confirmation-modal.js +44 -2
  16. package/dist/components/context-menu.js +185 -2
  17. package/dist/components/dialog.js +121 -2
  18. package/dist/components/dropdown-menu.js +48 -2
  19. package/dist/components/dropzone.js +44 -2
  20. package/dist/components/image-cropper-modal.js +250 -2
  21. package/dist/components/image-cropper.js +130 -2
  22. package/dist/components/input.js +21 -2
  23. package/dist/components/label.js +19 -2
  24. package/dist/components/loader.js +69 -2
  25. package/dist/components/loading-placeholder.js +24 -2
  26. package/dist/components/mention.js +153 -2
  27. package/dist/components/modal.js +135 -2
  28. package/dist/components/notification.js +25 -2
  29. package/dist/components/popover.js +23 -2
  30. package/dist/components/progress.js +34 -2
  31. package/dist/components/radio-group.js +47 -2
  32. package/dist/components/scroll-area.js +46 -2
  33. package/dist/components/select.js +130 -2
  34. package/dist/components/selection-bar.js +53 -2
  35. package/dist/components/separator.js +24 -2
  36. package/dist/components/sheet.js +128 -2
  37. package/dist/components/skeleton.js +17 -2
  38. package/dist/components/slider.js +32 -2
  39. package/dist/components/stepper/index.d.ts +4 -0
  40. package/dist/components/stepper/step-layout.d.ts +8 -0
  41. package/dist/components/stepper/stepper-modal.d.ts +26 -0
  42. package/dist/components/stepper/stepper.d.ts +7 -0
  43. package/dist/components/stepper/types.d.ts +6 -0
  44. package/dist/components/stepper.js +6 -2
  45. package/dist/components/switch.js +35 -2
  46. package/dist/components/table-empty.js +22 -2
  47. package/dist/components/table-mobile.js +91 -2
  48. package/dist/components/table.js +156 -2
  49. package/dist/components/tabs.js +46 -2
  50. package/dist/components/terminal.js +49 -2
  51. package/dist/components/textarea.js +20 -2
  52. package/dist/components/tooltip.js +75 -2
  53. package/dist/components/use-toast.js +64 -2
  54. package/dist/icons/icons.d.ts +8 -0
  55. package/dist/icons/index.d.ts +1 -0
  56. package/dist/icons/providers/anthropic.d.ts +2 -0
  57. package/dist/icons/providers/claude.d.ts +2 -0
  58. package/dist/icons/providers/deepseek.d.ts +2 -0
  59. package/dist/icons/providers/gemini.d.ts +2 -0
  60. package/dist/icons/providers/grok.d.ts +2 -0
  61. package/dist/icons/providers/index.d.ts +6 -0
  62. package/dist/icons/providers/openai.d.ts +2 -0
  63. package/dist/icons/providers/types.d.ts +4 -0
  64. package/dist/index.d.ts +48 -962
  65. package/dist/index.js +444 -2
  66. package/dist/lib/icons.d.ts +14 -0
  67. package/dist/lib/index.d.ts +2 -0
  68. package/dist/lib/utils.js +8 -2
  69. package/dist/{stepper-modal-SYU9mbXs.js → stepper-modal-JXpOXOV2.js} +90 -91
  70. package/dist/styles.css +1 -1
  71. package/package.json +180 -134
  72. package/dist/MonacoEditor-COZcVMEj.cjs +0 -8
  73. package/dist/MonacoEditor-COZcVMEj.cjs.map +0 -1
  74. package/dist/MonacoEditor-D3QSSKa4.js +0 -295
  75. package/dist/MonacoEditor-D3QSSKa4.js.map +0 -1
  76. package/dist/alert-dialog.d.ts +0 -18
  77. package/dist/alert.d.ts +0 -25
  78. package/dist/avatar.d.ts +0 -9
  79. package/dist/badge.d.ts +0 -15
  80. package/dist/button.d.ts +0 -16
  81. package/dist/calendar.d.ts +0 -21
  82. package/dist/card.d.ts +0 -15
  83. package/dist/carousel.d.ts +0 -18
  84. package/dist/charts.d.ts +0 -26
  85. package/dist/checkbox.d.ts +0 -6
  86. package/dist/collapse.d.ts +0 -15
  87. package/dist/command-menu.d.ts +0 -12
  88. package/dist/command.d.ts +0 -89
  89. package/dist/components/alert-dialog.esm.js +0 -59
  90. package/dist/components/alert-dialog.esm.js.map +0 -1
  91. package/dist/components/alert-dialog.js.map +0 -1
  92. package/dist/components/alert.esm.js +0 -64
  93. package/dist/components/alert.esm.js.map +0 -1
  94. package/dist/components/alert.js.map +0 -1
  95. package/dist/components/avatar.esm.js +0 -42
  96. package/dist/components/avatar.esm.js.map +0 -1
  97. package/dist/components/avatar.js.map +0 -1
  98. package/dist/components/badge.esm.js +0 -27
  99. package/dist/components/badge.esm.js.map +0 -1
  100. package/dist/components/badge.js.map +0 -1
  101. package/dist/components/button.esm.js +0 -48
  102. package/dist/components/button.esm.js.map +0 -1
  103. package/dist/components/button.js.map +0 -1
  104. package/dist/components/calendar.esm.js +0 -5562
  105. package/dist/components/calendar.esm.js.map +0 -1
  106. package/dist/components/calendar.js.map +0 -1
  107. package/dist/components/card.esm.js +0 -62
  108. package/dist/components/card.esm.js.map +0 -1
  109. package/dist/components/card.js.map +0 -1
  110. package/dist/components/carousel.esm.js +0 -101
  111. package/dist/components/carousel.esm.js.map +0 -1
  112. package/dist/components/carousel.js.map +0 -1
  113. package/dist/components/charts.d.ts +0 -17
  114. package/dist/components/charts.esm.js +0 -48
  115. package/dist/components/charts.esm.js.map +0 -1
  116. package/dist/components/charts.js +0 -2
  117. package/dist/components/charts.js.map +0 -1
  118. package/dist/components/checkbox.esm.js +0 -32
  119. package/dist/components/checkbox.esm.js.map +0 -1
  120. package/dist/components/checkbox.js.map +0 -1
  121. package/dist/components/collapse.esm.js +0 -50
  122. package/dist/components/collapse.esm.js.map +0 -1
  123. package/dist/components/collapse.js.map +0 -1
  124. package/dist/components/command-menu.esm.js +0 -90
  125. package/dist/components/command-menu.esm.js.map +0 -1
  126. package/dist/components/command-menu.js.map +0 -1
  127. package/dist/components/command.esm.js +0 -425
  128. package/dist/components/command.esm.js.map +0 -1
  129. package/dist/components/command.js.map +0 -1
  130. package/dist/components/confirmation-modal.esm.js +0 -46
  131. package/dist/components/confirmation-modal.esm.js.map +0 -1
  132. package/dist/components/confirmation-modal.js.map +0 -1
  133. package/dist/components/context-menu.esm.js +0 -186
  134. package/dist/components/context-menu.esm.js.map +0 -1
  135. package/dist/components/context-menu.js.map +0 -1
  136. package/dist/components/dialog.esm.js +0 -122
  137. package/dist/components/dialog.esm.js.map +0 -1
  138. package/dist/components/dialog.js.map +0 -1
  139. package/dist/components/dropdown-menu.esm.js +0 -49
  140. package/dist/components/dropdown-menu.esm.js.map +0 -1
  141. package/dist/components/dropdown-menu.js.map +0 -1
  142. package/dist/components/dropzone.esm.js +0 -45
  143. package/dist/components/dropzone.esm.js.map +0 -1
  144. package/dist/components/dropzone.js.map +0 -1
  145. package/dist/components/image-cropper-modal.esm.js +0 -251
  146. package/dist/components/image-cropper-modal.esm.js.map +0 -1
  147. package/dist/components/image-cropper-modal.js.map +0 -1
  148. package/dist/components/image-cropper.esm.js +0 -131
  149. package/dist/components/image-cropper.esm.js.map +0 -1
  150. package/dist/components/image-cropper.js.map +0 -1
  151. package/dist/components/input.esm.js +0 -22
  152. package/dist/components/input.esm.js.map +0 -1
  153. package/dist/components/input.js.map +0 -1
  154. package/dist/components/label.esm.js +0 -20
  155. package/dist/components/label.esm.js.map +0 -1
  156. package/dist/components/label.js.map +0 -1
  157. package/dist/components/loader.esm.js +0 -70
  158. package/dist/components/loader.esm.js.map +0 -1
  159. package/dist/components/loader.js.map +0 -1
  160. package/dist/components/loading-placeholder.esm.js +0 -25
  161. package/dist/components/loading-placeholder.esm.js.map +0 -1
  162. package/dist/components/loading-placeholder.js.map +0 -1
  163. package/dist/components/markdown.d.ts +0 -2
  164. package/dist/components/markdown.esm.js +0 -12066
  165. package/dist/components/markdown.esm.js.map +0 -1
  166. package/dist/components/markdown.js +0 -18
  167. package/dist/components/markdown.js.map +0 -1
  168. package/dist/components/mention.esm.js +0 -154
  169. package/dist/components/mention.esm.js.map +0 -1
  170. package/dist/components/mention.js.map +0 -1
  171. package/dist/components/modal.esm.js +0 -136
  172. package/dist/components/modal.esm.js.map +0 -1
  173. package/dist/components/modal.js.map +0 -1
  174. package/dist/components/monaco-editor.d.ts +0 -2
  175. package/dist/components/monaco-editor.esm.js +0 -9
  176. package/dist/components/monaco-editor.esm.js.map +0 -1
  177. package/dist/components/monaco-editor.js +0 -2
  178. package/dist/components/monaco-editor.js.map +0 -1
  179. package/dist/components/notification.esm.js +0 -26
  180. package/dist/components/notification.esm.js.map +0 -1
  181. package/dist/components/notification.js.map +0 -1
  182. package/dist/components/popover.esm.js +0 -24
  183. package/dist/components/popover.esm.js.map +0 -1
  184. package/dist/components/popover.js.map +0 -1
  185. package/dist/components/progress.esm.js +0 -35
  186. package/dist/components/progress.esm.js.map +0 -1
  187. package/dist/components/progress.js.map +0 -1
  188. package/dist/components/radio-group.esm.js +0 -48
  189. package/dist/components/radio-group.esm.js.map +0 -1
  190. package/dist/components/radio-group.js.map +0 -1
  191. package/dist/components/scroll-area.esm.js +0 -47
  192. package/dist/components/scroll-area.esm.js.map +0 -1
  193. package/dist/components/scroll-area.js.map +0 -1
  194. package/dist/components/select.esm.js +0 -131
  195. package/dist/components/select.esm.js.map +0 -1
  196. package/dist/components/select.js.map +0 -1
  197. package/dist/components/selection-bar.esm.js +0 -54
  198. package/dist/components/selection-bar.esm.js.map +0 -1
  199. package/dist/components/selection-bar.js.map +0 -1
  200. package/dist/components/separator.esm.js +0 -25
  201. package/dist/components/separator.esm.js.map +0 -1
  202. package/dist/components/separator.js.map +0 -1
  203. package/dist/components/sheet.esm.js +0 -129
  204. package/dist/components/sheet.esm.js.map +0 -1
  205. package/dist/components/sheet.js.map +0 -1
  206. package/dist/components/skeleton.esm.js +0 -18
  207. package/dist/components/skeleton.esm.js.map +0 -1
  208. package/dist/components/skeleton.js.map +0 -1
  209. package/dist/components/slider.esm.js +0 -33
  210. package/dist/components/slider.esm.js.map +0 -1
  211. package/dist/components/slider.js.map +0 -1
  212. package/dist/components/stepper.d.ts +0 -2
  213. package/dist/components/stepper.esm.js +0 -7
  214. package/dist/components/stepper.esm.js.map +0 -1
  215. package/dist/components/stepper.js.map +0 -1
  216. package/dist/components/switch.esm.js +0 -36
  217. package/dist/components/switch.esm.js.map +0 -1
  218. package/dist/components/switch.js.map +0 -1
  219. package/dist/components/table-empty.esm.js +0 -23
  220. package/dist/components/table-empty.esm.js.map +0 -1
  221. package/dist/components/table-empty.js.map +0 -1
  222. package/dist/components/table-mobile.esm.js +0 -92
  223. package/dist/components/table-mobile.esm.js.map +0 -1
  224. package/dist/components/table-mobile.js.map +0 -1
  225. package/dist/components/table.esm.js +0 -157
  226. package/dist/components/table.esm.js.map +0 -1
  227. package/dist/components/table.js.map +0 -1
  228. package/dist/components/tabs.esm.js +0 -47
  229. package/dist/components/tabs.esm.js.map +0 -1
  230. package/dist/components/tabs.js.map +0 -1
  231. package/dist/components/terminal.esm.js +0 -50
  232. package/dist/components/terminal.esm.js.map +0 -1
  233. package/dist/components/terminal.js.map +0 -1
  234. package/dist/components/textarea.esm.js +0 -21
  235. package/dist/components/textarea.esm.js.map +0 -1
  236. package/dist/components/textarea.js.map +0 -1
  237. package/dist/components/tooltip.esm.js +0 -76
  238. package/dist/components/tooltip.esm.js.map +0 -1
  239. package/dist/components/tooltip.js.map +0 -1
  240. package/dist/components/use-toast.esm.js +0 -65
  241. package/dist/components/use-toast.esm.js.map +0 -1
  242. package/dist/components/use-toast.js.map +0 -1
  243. package/dist/confirmation-modal.d.ts +0 -16
  244. package/dist/context-menu.d.ts +0 -41
  245. package/dist/dialog.d.ts +0 -33
  246. package/dist/dropdown-menu.d.ts +0 -16
  247. package/dist/dropzone.d.ts +0 -16
  248. package/dist/image-cropper-modal.d.ts +0 -14
  249. package/dist/image-cropper.d.ts +0 -15
  250. package/dist/index-DACAHwoB.js +0 -35
  251. package/dist/index-DACAHwoB.js.map +0 -1
  252. package/dist/index-Deooizx8.cjs +0 -2
  253. package/dist/index-Deooizx8.cjs.map +0 -1
  254. package/dist/index.esm.js +0 -458
  255. package/dist/index.esm.js.map +0 -1
  256. package/dist/index.js.map +0 -1
  257. package/dist/input.d.ts +0 -8
  258. package/dist/jsx-runtime-BYECrxsp.cjs +0 -31
  259. package/dist/jsx-runtime-BYECrxsp.cjs.map +0 -1
  260. package/dist/jsx-runtime-DGlMoOmv.js +0 -631
  261. package/dist/jsx-runtime-DGlMoOmv.js.map +0 -1
  262. package/dist/label.d.ts +0 -6
  263. package/dist/lib/utils.esm.js +0 -5
  264. package/dist/lib/utils.esm.js.map +0 -1
  265. package/dist/lib/utils.js.map +0 -1
  266. package/dist/loader.d.ts +0 -14
  267. package/dist/loading-placeholder.d.ts +0 -12
  268. package/dist/markdown.d.ts +0 -122
  269. package/dist/mention.d.ts +0 -29
  270. package/dist/modal.d.ts +0 -28
  271. package/dist/monaco-editor.d.ts +0 -76
  272. package/dist/notification.d.ts +0 -9
  273. package/dist/popover.d.ts +0 -10
  274. package/dist/progress.d.ts +0 -6
  275. package/dist/radio-group.d.ts +0 -8
  276. package/dist/scroll-area.d.ts +0 -8
  277. package/dist/select.d.ts +0 -31
  278. package/dist/selection-bar.d.ts +0 -15
  279. package/dist/separator.d.ts +0 -6
  280. package/dist/sheet.d.ts +0 -17
  281. package/dist/skeleton.d.ts +0 -5
  282. package/dist/slider.d.ts +0 -6
  283. package/dist/stepper-modal-CPlBpxWy.cjs +0 -2
  284. package/dist/stepper-modal-CPlBpxWy.cjs.map +0 -1
  285. package/dist/stepper-modal-SYU9mbXs.js.map +0 -1
  286. package/dist/stepper.d.ts +0 -75
  287. package/dist/switch.d.ts +0 -6
  288. package/dist/table-empty.d.ts +0 -13
  289. package/dist/table-mobile.d.ts +0 -37
  290. package/dist/table.d.ts +0 -37
  291. package/dist/tabs.d.ts +0 -12
  292. package/dist/terminal.d.ts +0 -47
  293. package/dist/textarea.d.ts +0 -8
  294. package/dist/tooltip.d.ts +0 -12
  295. package/dist/use-toast.d.ts +0 -28
  296. package/dist/utils-DSKoFOjv.cjs +0 -2
  297. package/dist/utils-DSKoFOjv.cjs.map +0 -1
  298. package/dist/utils-qaFjX9_3.js +0 -2279
  299. package/dist/utils-qaFjX9_3.js.map +0 -1
  300. package/dist/utils.d.ts +0 -5
@@ -1,2 +1,185 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../jsx-runtime-BYECrxsp.cjs"),d=require("react"),h=require("@radix-ui/react-context-menu"),r=require("../utils-DSKoFOjv.cjs");function g(t){const n=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(t){for(const o in t)if(o!=="default"){const a=Object.getOwnPropertyDescriptor(t,o);Object.defineProperty(n,o,a.get?a:{enumerable:!0,get:()=>t[o]})}}return n.default=t,Object.freeze(n)}const s=g(h);function R({children:t,menuContent:n,className:o="",disabled:a=!1,onContextMenuOpen:i,onContextMenuClose:c}){return e.jsxRuntimeExports.jsxs(s.Root,{onOpenChange:b=>{b?i==null||i():c==null||c()},children:[e.jsxRuntimeExports.jsx(s.Trigger,{disabled:a,asChild:!0,className:r.cn("block",o),children:e.jsxRuntimeExports.jsx("div",{children:t})}),e.jsxRuntimeExports.jsx(s.Portal,{children:e.jsxRuntimeExports.jsx(s.Content,{className:"min-w-[220px] overflow-hidden rounded-md border bg-popover p-1 shadow-md animate-in fade-in-80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50",children:n})})]})}const u=d.forwardRef(({className:t,...n},o)=>e.jsxRuntimeExports.jsx(s.Item,{ref:o,className:r.cn("relative cursor-pointer flex select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),...n}));u.displayName="ContextMenuItem";const l=d.forwardRef(({className:t,...n},o)=>e.jsxRuntimeExports.jsx(s.Separator,{ref:o,className:r.cn("-mx-1 my-1 h-px bg-border",t),...n}));l.displayName="ContextMenuSeparator";const w=s.Sub,x=d.forwardRef(({className:t,inset:n,children:o,...a},i)=>e.jsxRuntimeExports.jsxs(s.SubTrigger,{ref:i,className:r.cn("flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground",n&&"pl-8",t),...a,children:[o,e.jsxRuntimeExports.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"ml-auto h-4 w-4",children:e.jsxRuntimeExports.jsx("path",{d:"m9 18 6-6-6-6"})})]}));x.displayName="ContextMenuSubTrigger";const m=d.forwardRef(({className:t,...n},o)=>e.jsxRuntimeExports.jsx(s.SubContent,{ref:o,className:r.cn("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 shadow-md animate-in data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",t),...n}));m.displayName="ContextMenuSubContent";const C=s.Group,y=s.RadioGroup,p=d.forwardRef(({className:t,children:n,...o},a)=>e.jsxRuntimeExports.jsxs(s.RadioItem,{ref:a,className:r.cn("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),...o,children:[e.jsxRuntimeExports.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:e.jsxRuntimeExports.jsx(s.ItemIndicator,{children:e.jsxRuntimeExports.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"h-2 w-2 fill-current",children:e.jsxRuntimeExports.jsx("circle",{cx:"12",cy:"12",r:"10"})})})}),n]}));p.displayName="ContextMenuRadioItem";const f=d.forwardRef(({className:t,inset:n,...o},a)=>e.jsxRuntimeExports.jsx(s.Label,{ref:a,className:r.cn("px-2 py-1.5 text-sm font-semibold text-foreground",n&&"pl-8",t),...o}));f.displayName="ContextMenuLabel";const j=d.forwardRef(({className:t,children:n,checked:o,...a},i)=>e.jsxRuntimeExports.jsxs(s.CheckboxItem,{ref:i,className:r.cn("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t),checked:o,...a,children:[e.jsxRuntimeExports.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:e.jsxRuntimeExports.jsx(s.ItemIndicator,{children:e.jsxRuntimeExports.jsx("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"h-4 w-4",children:e.jsxRuntimeExports.jsx("polyline",{points:"20 6 9 17 4 12"})})})}),n]}));j.displayName="ContextMenuCheckboxItem";exports.ContextMenu=R;exports.ContextMenuCheckboxItem=j;exports.ContextMenuGroup=C;exports.ContextMenuItem=u;exports.ContextMenuLabel=f;exports.ContextMenuRadioGroup=y;exports.ContextMenuRadioItem=p;exports.ContextMenuSeparator=l;exports.ContextMenuSub=w;exports.ContextMenuSubContent=m;exports.ContextMenuSubTrigger=x;
2
- //# sourceMappingURL=context-menu.js.map
1
+ import { jsx as e, jsxs as l } from "react/jsx-runtime";
2
+ import i from "react";
3
+ import * as t from "@radix-ui/react-context-menu";
4
+ import { cn as s } from "../lib/utils.js";
5
+ function y({
6
+ children: o,
7
+ menuContent: a,
8
+ className: n = "",
9
+ disabled: r = !1,
10
+ onContextMenuOpen: d,
11
+ onContextMenuClose: c
12
+ }) {
13
+ return /* @__PURE__ */ l(
14
+ t.Root,
15
+ {
16
+ onOpenChange: (m) => {
17
+ m ? d == null || d() : c == null || c();
18
+ },
19
+ children: [
20
+ /* @__PURE__ */ e(t.Trigger, { disabled: r, asChild: !0, className: s("block", n), children: /* @__PURE__ */ e("div", { children: o }) }),
21
+ /* @__PURE__ */ e(t.Portal, { children: /* @__PURE__ */ e(
22
+ t.Content,
23
+ {
24
+ className: "min-w-[220px] overflow-hidden rounded-md border bg-popover p-1 shadow-md animate-in fade-in-80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50",
25
+ children: a
26
+ }
27
+ ) })
28
+ ]
29
+ }
30
+ );
31
+ }
32
+ const u = i.forwardRef(({ className: o, ...a }, n) => /* @__PURE__ */ e(
33
+ t.Item,
34
+ {
35
+ ref: n,
36
+ className: s(
37
+ "relative cursor-pointer flex select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
38
+ o
39
+ ),
40
+ ...a
41
+ }
42
+ ));
43
+ u.displayName = "ContextMenuItem";
44
+ const f = i.forwardRef(({ className: o, ...a }, n) => /* @__PURE__ */ e(
45
+ t.Separator,
46
+ {
47
+ ref: n,
48
+ className: s("-mx-1 my-1 h-px bg-border", o),
49
+ ...a
50
+ }
51
+ ));
52
+ f.displayName = "ContextMenuSeparator";
53
+ const C = t.Sub, p = i.forwardRef(({ className: o, inset: a, children: n, ...r }, d) => /* @__PURE__ */ l(
54
+ t.SubTrigger,
55
+ {
56
+ ref: d,
57
+ className: s(
58
+ "flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground",
59
+ a && "pl-8",
60
+ o
61
+ ),
62
+ ...r,
63
+ children: [
64
+ n,
65
+ /* @__PURE__ */ e(
66
+ "svg",
67
+ {
68
+ xmlns: "http://www.w3.org/2000/svg",
69
+ width: "24",
70
+ height: "24",
71
+ viewBox: "0 0 24 24",
72
+ fill: "none",
73
+ stroke: "currentColor",
74
+ strokeWidth: "2",
75
+ strokeLinecap: "round",
76
+ strokeLinejoin: "round",
77
+ className: "ml-auto h-4 w-4",
78
+ children: /* @__PURE__ */ e("path", { d: "m9 18 6-6-6-6" })
79
+ }
80
+ )
81
+ ]
82
+ }
83
+ ));
84
+ p.displayName = "ContextMenuSubTrigger";
85
+ const h = i.forwardRef(({ className: o, ...a }, n) => /* @__PURE__ */ e(
86
+ t.SubContent,
87
+ {
88
+ ref: n,
89
+ className: s(
90
+ "z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 shadow-md animate-in data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",
91
+ o
92
+ ),
93
+ ...a
94
+ }
95
+ ));
96
+ h.displayName = "ContextMenuSubContent";
97
+ const k = t.Group, R = t.RadioGroup, x = i.forwardRef(({ className: o, children: a, ...n }, r) => /* @__PURE__ */ l(
98
+ t.RadioItem,
99
+ {
100
+ ref: r,
101
+ className: s(
102
+ "relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
103
+ o
104
+ ),
105
+ ...n,
106
+ children: [
107
+ /* @__PURE__ */ e("span", { className: "absolute left-2 flex h-3.5 w-3.5 items-center justify-center", children: /* @__PURE__ */ e(t.ItemIndicator, { children: /* @__PURE__ */ e(
108
+ "svg",
109
+ {
110
+ xmlns: "http://www.w3.org/2000/svg",
111
+ width: "24",
112
+ height: "24",
113
+ viewBox: "0 0 24 24",
114
+ fill: "none",
115
+ stroke: "currentColor",
116
+ strokeWidth: "2",
117
+ strokeLinecap: "round",
118
+ strokeLinejoin: "round",
119
+ className: "h-2 w-2 fill-current",
120
+ children: /* @__PURE__ */ e("circle", { cx: "12", cy: "12", r: "10" })
121
+ }
122
+ ) }) }),
123
+ a
124
+ ]
125
+ }
126
+ ));
127
+ x.displayName = "ContextMenuRadioItem";
128
+ const b = i.forwardRef(({ className: o, inset: a, ...n }, r) => /* @__PURE__ */ e(
129
+ t.Label,
130
+ {
131
+ ref: r,
132
+ className: s(
133
+ "px-2 py-1.5 text-sm font-semibold text-foreground",
134
+ a && "pl-8",
135
+ o
136
+ ),
137
+ ...n
138
+ }
139
+ ));
140
+ b.displayName = "ContextMenuLabel";
141
+ const g = i.forwardRef(({ className: o, children: a, checked: n, ...r }, d) => /* @__PURE__ */ l(
142
+ t.CheckboxItem,
143
+ {
144
+ ref: d,
145
+ className: s(
146
+ "relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
147
+ o
148
+ ),
149
+ checked: n,
150
+ ...r,
151
+ children: [
152
+ /* @__PURE__ */ e("span", { className: "absolute left-2 flex h-3.5 w-3.5 items-center justify-center", children: /* @__PURE__ */ e(t.ItemIndicator, { children: /* @__PURE__ */ e(
153
+ "svg",
154
+ {
155
+ xmlns: "http://www.w3.org/2000/svg",
156
+ width: "24",
157
+ height: "24",
158
+ viewBox: "0 0 24 24",
159
+ fill: "none",
160
+ stroke: "currentColor",
161
+ strokeWidth: "2",
162
+ strokeLinecap: "round",
163
+ strokeLinejoin: "round",
164
+ className: "h-4 w-4",
165
+ children: /* @__PURE__ */ e("polyline", { points: "20 6 9 17 4 12" })
166
+ }
167
+ ) }) }),
168
+ a
169
+ ]
170
+ }
171
+ ));
172
+ g.displayName = "ContextMenuCheckboxItem";
173
+ export {
174
+ y as ContextMenu,
175
+ g as ContextMenuCheckboxItem,
176
+ k as ContextMenuGroup,
177
+ u as ContextMenuItem,
178
+ b as ContextMenuLabel,
179
+ R as ContextMenuRadioGroup,
180
+ x as ContextMenuRadioItem,
181
+ f as ContextMenuSeparator,
182
+ C as ContextMenuSub,
183
+ h as ContextMenuSubContent,
184
+ p as ContextMenuSubTrigger
185
+ };
@@ -1,2 +1,121 @@
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 d(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=d(j),i=d(y),R=({...e})=>o.jsxRuntimeExports.jsx(i.Root,{...e}),b=i.Trigger,x=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(x,{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-1/2 top-1/2 z-50 grid w-full max-w-lg gap-4 border-border/50 bg-background p-6 shadow-lg rounded-lg",e),initial:{opacity:0,scale:.95,x:"-50%",y:"-50%"},animate:{opacity:1,scale:1,x:"-50%",y:"-50%"},exit:{opacity:0,scale:.95,x:"-50%",y:"-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=x;exports.DialogTitle=p;exports.DialogTrigger=b;
2
- //# sourceMappingURL=dialog.js.map
1
+ import { jsx as o, jsxs as l } from "react/jsx-runtime";
2
+ import * as r from "react";
3
+ import * as a from "@radix-ui/react-dialog";
4
+ import { cn as s } from "../lib/utils.js";
5
+ import { X as m } from "lucide-react";
6
+ import { motion as n, AnimatePresence as g } from "framer-motion";
7
+ const w = ({ ...e }) => /* @__PURE__ */ o(a.Root, { ...e }), C = a.Trigger, p = a.Portal, R = a.Close, c = r.forwardRef(({ className: e, ...i }, t) => /* @__PURE__ */ o(
8
+ a.Overlay,
9
+ {
10
+ ref: t,
11
+ asChild: !0,
12
+ ...i,
13
+ children: /* @__PURE__ */ o(
14
+ n.div,
15
+ {
16
+ className: s(
17
+ "fixed inset-0 z-50 bg-background/80 backdrop-blur-sm",
18
+ e
19
+ ),
20
+ initial: { opacity: 0 },
21
+ animate: { opacity: 1 },
22
+ exit: { opacity: 0 },
23
+ transition: { duration: 0.2 }
24
+ }
25
+ )
26
+ }
27
+ ));
28
+ c.displayName = a.Overlay.displayName;
29
+ const f = r.forwardRef(({ className: e, children: i, ...t }, d) => /* @__PURE__ */ o(p, { children: /* @__PURE__ */ l(g, { mode: "wait", children: [
30
+ /* @__PURE__ */ o(c, {}),
31
+ /* @__PURE__ */ o(
32
+ a.Content,
33
+ {
34
+ ref: d,
35
+ asChild: !0,
36
+ ...t,
37
+ children: /* @__PURE__ */ l(
38
+ n.div,
39
+ {
40
+ className: s(
41
+ "fixed left-1/2 top-1/2 z-50 grid w-full max-w-lg gap-4 border-border/50 bg-background p-6 shadow-lg rounded-lg",
42
+ e
43
+ ),
44
+ initial: { opacity: 0, scale: 0.95, x: "-50%", y: "-50%" },
45
+ animate: { opacity: 1, scale: 1, x: "-50%", y: "-50%" },
46
+ exit: { opacity: 0, scale: 0.95, x: "-50%", y: "-50%" },
47
+ transition: { duration: 0.2 },
48
+ children: [
49
+ i,
50
+ /* @__PURE__ */ l(a.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__ */ o(m, { className: "h-4 w-4" }),
52
+ /* @__PURE__ */ o("span", { className: "sr-only", children: "Close" })
53
+ ] })
54
+ ]
55
+ }
56
+ )
57
+ }
58
+ )
59
+ ] }) }));
60
+ f.displayName = a.Content.displayName;
61
+ const y = ({
62
+ className: e,
63
+ ...i
64
+ }) => /* @__PURE__ */ o(
65
+ "div",
66
+ {
67
+ className: s(
68
+ "flex flex-col space-y-1.5 text-center sm:text-left",
69
+ e
70
+ ),
71
+ ...i
72
+ }
73
+ );
74
+ y.displayName = "DialogHeader";
75
+ const x = ({
76
+ className: e,
77
+ ...i
78
+ }) => /* @__PURE__ */ o(
79
+ "div",
80
+ {
81
+ className: s(
82
+ "flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",
83
+ e
84
+ ),
85
+ ...i
86
+ }
87
+ );
88
+ x.displayName = "DialogFooter";
89
+ const u = r.forwardRef(({ className: e, ...i }, t) => /* @__PURE__ */ o(
90
+ a.Title,
91
+ {
92
+ ref: t,
93
+ className: s(
94
+ "text-lg font-semibold leading-none tracking-tight",
95
+ e
96
+ ),
97
+ ...i
98
+ }
99
+ ));
100
+ u.displayName = a.Title.displayName;
101
+ const N = r.forwardRef(({ className: e, ...i }, t) => /* @__PURE__ */ o(
102
+ a.Description,
103
+ {
104
+ ref: t,
105
+ className: s("text-sm text-muted-foreground", e),
106
+ ...i
107
+ }
108
+ ));
109
+ N.displayName = a.Description.displayName;
110
+ export {
111
+ w as Dialog,
112
+ R as DialogClose,
113
+ f as DialogContent,
114
+ N as DialogDescription,
115
+ x as DialogFooter,
116
+ y as DialogHeader,
117
+ c as DialogOverlay,
118
+ p as DialogPortal,
119
+ u as DialogTitle,
120
+ C as DialogTrigger
121
+ };
@@ -1,2 +1,48 @@
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
1
+ import { jsx as e } from "react/jsx-runtime";
2
+ import * as a from "react";
3
+ import * as o from "@radix-ui/react-dropdown-menu";
4
+ import { cn as i } from "../lib/utils.js";
5
+ import { motion as p } from "framer-motion";
6
+ const w = o.Root, y = o.Trigger, g = o.Group, x = o.Separator, c = a.forwardRef(({ className: t, sideOffset: r = 4, children: n, ...d }, s) => /* @__PURE__ */ e(o.Portal, { children: /* @__PURE__ */ e(
7
+ o.Content,
8
+ {
9
+ ref: s,
10
+ sideOffset: r,
11
+ ...d,
12
+ children: /* @__PURE__ */ e(
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(
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
+ w as DropdownMenu,
43
+ c as DropdownMenuContent,
44
+ g as DropdownMenuGroup,
45
+ m as DropdownMenuItem,
46
+ x as DropdownMenuSeparator,
47
+ y as DropdownMenuTrigger
48
+ };
@@ -1,2 +1,44 @@
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
1
+ import { jsxs as o, jsx as e } from "react/jsx-runtime";
2
+ import { useCallback as u } from "react";
3
+ import { useDropzone as b } from "react-dropzone";
4
+ import { Upload as f } from "lucide-react";
5
+ function D({
6
+ onDrop: r,
7
+ children: t,
8
+ className: n = "",
9
+ overlayClassName: s = "",
10
+ dropzoneOptions: i,
11
+ showOverlay: a = !0
12
+ }) {
13
+ const m = u((l) => {
14
+ r(l);
15
+ }, [r]), {
16
+ getRootProps: d,
17
+ getInputProps: p,
18
+ isDragActive: c
19
+ } = b({
20
+ onDrop: m,
21
+ noClick: !0,
22
+ // Don't trigger on click since we're using the area for other purposes
23
+ noKeyboard: !0,
24
+ ...i
25
+ });
26
+ return /* @__PURE__ */ o(
27
+ "div",
28
+ {
29
+ ...d(),
30
+ className: n,
31
+ children: [
32
+ /* @__PURE__ */ e("input", { ...p() }),
33
+ c && a && /* @__PURE__ */ e("div", { className: `absolute inset-0 bg-background/80 flex items-center justify-center z-10 pointer-events-none ${s}`, children: /* @__PURE__ */ o("div", { className: "border-2 border-dashed border-primary rounded-lg p-8 text-center", children: [
34
+ /* @__PURE__ */ e(f, { className: "h-12 w-12 mb-2 text-primary mx-auto" }),
35
+ /* @__PURE__ */ e("p", { className: "text-base font-medium mb-1", children: "Drop files here" })
36
+ ] }) }),
37
+ t
38
+ ]
39
+ }
40
+ );
41
+ }
42
+ export {
43
+ D as Dropzone
44
+ };