@collabchron/notiq 0.3.0 → 1.0.1

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 (282) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +230 -39
  3. package/dist/CodeActionMenuPlugin-EINOY4U4.mjs +15 -0
  4. package/dist/DynamicBlockComponent-NRQJ4WW4.mjs +161 -0
  5. package/dist/EquationComponent-CB6DFIHV.mjs +154 -0
  6. package/dist/ExcalidrawComponent-XW6646OH.mjs +528 -0
  7. package/dist/ExcalidrawPlugin-ZFHT62IF.mjs +14 -0
  8. package/dist/ExportPlugin-V2RLM63S.mjs +11 -0
  9. package/dist/FloatingLinkEditorPlugin-TRTCMSP4.mjs +12 -0
  10. package/dist/FloatingTextFormatToolbarPlugin-F2GY6LMI.mjs +30 -0
  11. package/dist/HintComponet-BRL6EAMS.mjs +217 -0
  12. package/dist/InlineImageComponent-UWIUWBHI.mjs +453 -0
  13. package/dist/MobileToolbar-BOOZAMQE.mjs +268 -0
  14. package/dist/SlashCommand-GMT5JI33.mjs +28 -0
  15. package/dist/StoryBuilderComponent-JGDBM5JU.mjs +562 -0
  16. package/{src/components/editor/plugins/TableCellActionMenuPlugin/index.tsx → dist/TableCellActionMenuPlugin-PGK2K3VG.mjs} +667 -759
  17. package/{src/components/editor/plugins/TableHoverActionsPlugin/index.tsx → dist/TableHoverActionsPlugin-GJVE6VRW.mjs} +258 -314
  18. package/dist/TemplatePlugin-ZD3QEVTI.mjs +9 -0
  19. package/dist/ToolbarPlugin-YKYA4NB4.mjs +1547 -0
  20. package/dist/babel-JZ2EV6AX.mjs +7233 -0
  21. package/dist/background-color-XZTYLGO2.mjs +362 -0
  22. package/dist/block-format-YJCV2DIY.mjs +15 -0
  23. package/dist/chunk-2FNEAMSP.mjs +127 -0
  24. package/dist/chunk-3CPBODXA.mjs +84 -0
  25. package/dist/chunk-3G37YKTV.mjs +83 -0
  26. package/dist/chunk-3JVFG7ER.mjs +184 -0
  27. package/dist/chunk-456TN7IM.mjs +110 -0
  28. package/dist/chunk-4EXYCTGJ.mjs +27 -0
  29. package/{src/utils/getSelectedNode.ts → dist/chunk-4HBCVSE6.mjs} +26 -27
  30. package/dist/chunk-4MEDW3T6.mjs +125 -0
  31. package/dist/chunk-4VWFVWYP.mjs +36 -0
  32. package/dist/chunk-5BAKY5KN.mjs +84 -0
  33. package/dist/chunk-5QSNIVIG.mjs +333 -0
  34. package/dist/chunk-64Z3FI7T.mjs +37 -0
  35. package/{src/components/editor/nodes/Stepper/index.tsx → dist/chunk-6RNZQOH2.mjs} +214 -260
  36. package/dist/chunk-77KXU36M.mjs +64 -0
  37. package/dist/chunk-77UA6HYR.mjs +165 -0
  38. package/dist/chunk-7NZAPJ4G.mjs +102 -0
  39. package/dist/chunk-7VUMHWWL.mjs +152 -0
  40. package/dist/chunk-AMMKBSST.mjs +1256 -0
  41. package/dist/chunk-BIU7WTLX.mjs +95 -0
  42. package/dist/chunk-EGMI62PP.mjs +83 -0
  43. package/dist/chunk-EHNQD5KO.mjs +88 -0
  44. package/dist/chunk-FSM26655.mjs +37 -0
  45. package/{src/components/editor/nodes/Hint/index.tsx → dist/chunk-G53GLEAY.mjs} +158 -190
  46. package/dist/chunk-GK35L7UY.mjs +28 -0
  47. package/dist/chunk-GXYD4VZM.mjs +193 -0
  48. package/dist/chunk-GYIOYVCN.mjs +538 -0
  49. package/dist/chunk-GZPNVR7L.mjs +157 -0
  50. package/dist/chunk-JXDPPUJI.mjs +52 -0
  51. package/dist/chunk-K36V4SIW.mjs +141 -0
  52. package/dist/chunk-KJ6AJ44Q.mjs +128 -0
  53. package/dist/chunk-KJV3FAZ7.mjs +142 -0
  54. package/{src/components/editor/plugins/ImagesPlugin/index.tsx → dist/chunk-LGG4IUIA.mjs} +189 -222
  55. package/dist/chunk-LQN3CMKV.mjs +1906 -0
  56. package/dist/chunk-N3WN46VL.mjs +236 -0
  57. package/dist/chunk-PBD6LMLC.mjs +366 -0
  58. package/dist/chunk-POGRR73N.mjs +33 -0
  59. package/{src/components/editor/utils/editorFormatting.ts → dist/chunk-PZSUSXQG.mjs} +238 -282
  60. package/dist/chunk-QEIFVK5M.mjs +29 -0
  61. package/dist/chunk-QHIQKMVN.mjs +427 -0
  62. package/dist/chunk-TCYK7DM7.mjs +36 -0
  63. package/dist/chunk-TTHQCW5F.mjs +47 -0
  64. package/dist/chunk-U47ABU5Z.mjs +53 -0
  65. package/dist/chunk-WDG7J2DY.mjs +116 -0
  66. package/dist/chunk-WJRHXI2C.mjs +733 -0
  67. package/dist/chunk-XLER2DHM.mjs +357 -0
  68. package/dist/chunk-XWC4TK2N.mjs +315 -0
  69. package/dist/chunk-YHPNOWFH.mjs +15 -0
  70. package/dist/chunk-YKC3SO4Z.mjs +32 -0
  71. package/dist/chunk-YMBXLRW5.mjs +374 -0
  72. package/dist/chunk-YPHOEJ46.mjs +64 -0
  73. package/dist/chunk-YUDCJRJM.mjs +25 -0
  74. package/dist/chunk-Z4EWP7BI.mjs +65 -0
  75. package/dist/chunk-ZB5LZQKC.mjs +191 -0
  76. package/dist/chunk-ZJRKATOJ.mjs +65 -0
  77. package/dist/color-BPKOPQKN.mjs +12 -0
  78. package/dist/estree-XC56IUFX.mjs +4414 -0
  79. package/dist/font-FEZ3GKSF.mjs +13 -0
  80. package/dist/font-size-EK775WRH.mjs +15 -0
  81. package/dist/html-S3ACX7NI.mjs +2738 -0
  82. package/dist/image-2PJIAYAT.mjs +993 -0
  83. package/dist/index.d.mts +145 -0
  84. package/dist/index.d.ts +145 -0
  85. package/dist/index.js +57855 -0
  86. package/dist/index.mjs +1790 -0
  87. package/dist/insert-gif-SAIDYURE.mjs +100 -0
  88. package/dist/insert-image-U3RJN3OW.mjs +259 -0
  89. package/dist/insert-node-5P2CRJ7S.mjs +201 -0
  90. package/dist/insert-poll-HCPM7MO6.mjs +33 -0
  91. package/dist/insert-table-24XYUS2W.mjs +66 -0
  92. package/dist/markdown-SNVBOSRA.mjs +3487 -0
  93. package/dist/poll-component-2R4MDLHS.mjs +303 -0
  94. package/dist/postcss-ONF3VDIM.mjs +5051 -0
  95. package/dist/standalone-EOIALU3M.mjs +2373 -0
  96. package/dist/stepper-FSARL6X6.mjs +304 -0
  97. package/dist/styles/notiq.css +1149 -0
  98. package/dist/text-align-VLECWO4H.mjs +118 -0
  99. package/dist/text-format-BG5WOOPZ.mjs +16 -0
  100. package/dist/typescript-AMPI6OVS.mjs +13135 -0
  101. package/package.json +67 -11
  102. package/src/styles/notiq.css +1149 -0
  103. package/src/styles/tailwind-plugin.ts +134 -0
  104. package/components.json +0 -21
  105. package/eslint.config.mjs +0 -16
  106. package/next.config.ts +0 -12
  107. package/postcss.config.mjs +0 -5
  108. package/public/file.svg +0 -1
  109. package/public/globe.svg +0 -1
  110. package/public/images/icons/plus.svg +0 -10
  111. package/public/next.svg +0 -1
  112. package/public/vercel.svg +0 -1
  113. package/public/window.svg +0 -1
  114. package/src/app/actions.ts +0 -2
  115. package/src/app/api/ai/route.ts +0 -175
  116. package/src/app/api/edgestore/[...edgestore]/route.ts +0 -28
  117. package/src/app/favicon.ico +0 -0
  118. package/src/app/globals.css +0 -205
  119. package/src/app/layout.tsx +0 -38
  120. package/src/app/page.tsx +0 -12
  121. package/src/components/editor/Core.tsx +0 -220
  122. package/src/components/editor/hooks/instructions-messages.ts +0 -300
  123. package/src/components/editor/hooks/use-mobile.ts +0 -19
  124. package/src/components/editor/hooks/useReport.ts +0 -67
  125. package/src/components/editor/hooks/useResizeObservert.ts +0 -22
  126. package/src/components/editor/index.tsx +0 -39
  127. package/src/components/editor/lexical-on-change.tsx +0 -28
  128. package/src/components/editor/nodes/CollapsibleNode/CollapsibleContainerNode.ts +0 -92
  129. package/src/components/editor/nodes/CollapsibleNode/CollapsibleContentNode.ts +0 -65
  130. package/src/components/editor/nodes/CollapsibleNode/CollapsibleTitleNode.ts +0 -105
  131. package/src/components/editor/nodes/EquationNode/EquationComponent.tsx +0 -143
  132. package/src/components/editor/nodes/EquationNode/EquationNode.tsx +0 -170
  133. package/src/components/editor/nodes/ExcalidrawNode/ExcalidrawComponent.tsx +0 -228
  134. package/src/components/editor/nodes/ExcalidrawNode/ExcalidrawImage.tsx +0 -137
  135. package/src/components/editor/nodes/ExcalidrawNode/ImageResizer.tsx +0 -317
  136. package/src/components/editor/nodes/ExcalidrawNode/index.tsx +0 -204
  137. package/src/components/editor/nodes/FigmaNode/FigmaNode.tsx +0 -134
  138. package/src/components/editor/nodes/Hint/HintComponet.tsx +0 -221
  139. package/src/components/editor/nodes/ImageNode/index.tsx +0 -328
  140. package/src/components/editor/nodes/InlineImageNode/InlineImageComponent.tsx +0 -383
  141. package/src/components/editor/nodes/InlineImageNode/InlineImageNode.css +0 -94
  142. package/src/components/editor/nodes/InlineImageNode/InlineImageNode.tsx +0 -309
  143. package/src/components/editor/nodes/LayoutNode/LayoutContainerNode.ts +0 -146
  144. package/src/components/editor/nodes/LayoutNode/LayoutItemNode.ts +0 -79
  145. package/src/components/editor/nodes/PollNode/index.tsx +0 -204
  146. package/src/components/editor/nodes/TweetNode/index.tsx +0 -214
  147. package/src/components/editor/nodes/index.ts +0 -81
  148. package/src/components/editor/plugins/AutoEmbedPlugin/index.tsx +0 -350
  149. package/src/components/editor/plugins/AutoLinkPlugin/index.tsx +0 -56
  150. package/src/components/editor/plugins/CodeActionMenuPlugin/components/CopyButton.tsx +0 -70
  151. package/src/components/editor/plugins/CodeActionMenuPlugin/components/PrettierButton.tsx +0 -192
  152. package/src/components/editor/plugins/CodeActionMenuPlugin/index.tsx +0 -217
  153. package/src/components/editor/plugins/CodeActionMenuPlugin/utils.ts +0 -26
  154. package/src/components/editor/plugins/CodeHighlightPlugin/index.ts +0 -21
  155. package/src/components/editor/plugins/CollapsiblePlugin/Collapsible.css +0 -76
  156. package/src/components/editor/plugins/CollapsiblePlugin/index.ts +0 -228
  157. package/src/components/editor/plugins/DragDropPastePlugin/index.tsx +0 -44
  158. package/src/components/editor/plugins/DraggableBlockPlugin/index.tsx +0 -52
  159. package/src/components/editor/plugins/EquationsPlugin/index.tsx +0 -85
  160. package/src/components/editor/plugins/ExcalidrawPlugin/index.tsx +0 -98
  161. package/src/components/editor/plugins/FigmaPlugin/index.tsx +0 -42
  162. package/src/components/editor/plugins/FloatingLinkEditorPlugin/index.tsx +0 -445
  163. package/src/components/editor/plugins/FloatingTextFormatToolbarPlugin/index.tsx +0 -275
  164. package/src/components/editor/plugins/InlineImagePlugin/index.tsx +0 -351
  165. package/src/components/editor/plugins/LayoutPlugin/index.tsx +0 -238
  166. package/src/components/editor/plugins/LinkPlugin/index.tsx +0 -36
  167. package/src/components/editor/plugins/LinkWithMetaData/index.tsx +0 -271
  168. package/src/components/editor/plugins/MarkdownShortcutPlugin/index.tsx +0 -11
  169. package/src/components/editor/plugins/MarkdownTransformers/index.tsx +0 -304
  170. package/src/components/editor/plugins/PollPlugin/index.tsx +0 -49
  171. package/src/components/editor/plugins/ShortcutsPlugin/index.tsx +0 -180
  172. package/src/components/editor/plugins/ShortcutsPlugin/shortcuts.ts +0 -253
  173. package/src/components/editor/plugins/SlashCommand/index.tsx +0 -621
  174. package/src/components/editor/plugins/SpeechToTextPlugin/index.ts +0 -127
  175. package/src/components/editor/plugins/TabFocusPlugin/index.ts +0 -58
  176. package/src/components/editor/plugins/TableCellResizer/index.tsx +0 -438
  177. package/src/components/editor/plugins/TablePlugin/index.tsx +0 -99
  178. package/src/components/editor/plugins/ToolbarPlugin/index.tsx +0 -522
  179. package/src/components/editor/plugins/TwitterPlugin/index.ts +0 -35
  180. package/src/components/editor/plugins/YouTubeNode/index.tsx +0 -179
  181. package/src/components/editor/plugins/YouTubePlugin/index.ts +0 -41
  182. package/src/components/editor/themes/editor-theme.ts +0 -113
  183. package/src/components/editor/themes/theme.css +0 -377
  184. package/src/components/editor/utils/ai.ts +0 -291
  185. package/src/components/editor/utils/canUseDOM.ts +0 -12
  186. package/src/components/editor/utils/environment.ts +0 -50
  187. package/src/components/editor/utils/extract-data.ts +0 -166
  188. package/src/components/editor/utils/getAllLexicalChildren.ts +0 -13
  189. package/src/components/editor/utils/getDOMRangeRect.ts +0 -27
  190. package/src/components/editor/utils/getSelectedNode.ts +0 -27
  191. package/src/components/editor/utils/gif.ts +0 -29
  192. package/src/components/editor/utils/invariant.ts +0 -15
  193. package/src/components/editor/utils/setFloatingElemPosition.ts +0 -51
  194. package/src/components/editor/utils/setFloatingElemPositionForLinkEditor.ts +0 -40
  195. package/src/components/editor/utils/setNodePlaceholderFromSelection/getNodePlaceholder.ts +0 -51
  196. package/src/components/editor/utils/setNodePlaceholderFromSelection/setNodePlaceholderFromSelection.ts +0 -15
  197. package/src/components/editor/utils/setNodePlaceholderFromSelection/setPlaceholderOnSelection.ts +0 -114
  198. package/src/components/editor/utils/setNodePlaceholderFromSelection/styles.css +0 -6
  199. package/src/components/editor/utils/url.ts +0 -109
  200. package/src/components/editor/utils/useLayoutEffect.ts +0 -13
  201. package/src/components/providers/QueryProvider.tsx +0 -15
  202. package/src/components/providers/SharedHistoryContext.tsx +0 -28
  203. package/src/components/providers/ToolbarContext.tsx +0 -123
  204. package/src/components/providers/theme-provider.tsx +0 -11
  205. package/src/components/theme/ModeToggle.tsx +0 -40
  206. package/src/components/ui/FileInput.tsx +0 -40
  207. package/src/components/ui/Input.css +0 -32
  208. package/src/components/ui/Select.css +0 -42
  209. package/src/components/ui/Select.tsx +0 -36
  210. package/src/components/ui/TextInput.tsx +0 -48
  211. package/src/components/ui/ai/ai-button.tsx +0 -574
  212. package/src/components/ui/ai/border.tsx +0 -99
  213. package/src/components/ui/ai/placeholder-input-vanish.tsx +0 -282
  214. package/src/components/ui/button.tsx +0 -89
  215. package/src/components/ui/card.tsx +0 -76
  216. package/src/components/ui/checkbox.tsx +0 -30
  217. package/src/components/ui/command.tsx +0 -153
  218. package/src/components/ui/dialog/Dialog.css +0 -25
  219. package/src/components/ui/dialog/Dialog.tsx +0 -34
  220. package/src/components/ui/dialog.tsx +0 -122
  221. package/src/components/ui/drop-downs/background-color.tsx +0 -183
  222. package/src/components/ui/drop-downs/block-format.tsx +0 -159
  223. package/src/components/ui/drop-downs/code.tsx +0 -42
  224. package/src/components/ui/drop-downs/color.tsx +0 -177
  225. package/src/components/ui/drop-downs/font-size.tsx +0 -138
  226. package/src/components/ui/drop-downs/font.tsx +0 -155
  227. package/src/components/ui/drop-downs/index.tsx +0 -122
  228. package/src/components/ui/drop-downs/insert-node.tsx +0 -213
  229. package/src/components/ui/drop-downs/text-align.tsx +0 -123
  230. package/src/components/ui/drop-downs/text-format.tsx +0 -104
  231. package/src/components/ui/dropdown-menu.tsx +0 -201
  232. package/src/components/ui/equation/EquationEditor.css +0 -38
  233. package/src/components/ui/equation/EquationEditor.tsx +0 -56
  234. package/src/components/ui/equation/KatexEquationAlterer.css +0 -41
  235. package/src/components/ui/equation/KatexEquationAlterer.tsx +0 -83
  236. package/src/components/ui/equation/KatexRenderer.tsx +0 -66
  237. package/src/components/ui/excalidraw/ExcalidrawModal.css +0 -64
  238. package/src/components/ui/excalidraw/ExcalidrawModal.tsx +0 -234
  239. package/src/components/ui/excalidraw/Modal.css +0 -62
  240. package/src/components/ui/excalidraw/Modal.tsx +0 -110
  241. package/src/components/ui/hover-card.tsx +0 -29
  242. package/src/components/ui/image/error-image.tsx +0 -17
  243. package/src/components/ui/image/file-upload.tsx +0 -240
  244. package/src/components/ui/image/image-resizer.tsx +0 -297
  245. package/src/components/ui/image/image-toolbar.tsx +0 -264
  246. package/src/components/ui/image/index.tsx +0 -408
  247. package/src/components/ui/image/lazy-image.tsx +0 -68
  248. package/src/components/ui/image/lazy-video.tsx +0 -71
  249. package/src/components/ui/input.tsx +0 -22
  250. package/src/components/ui/models/custom-dialog.tsx +0 -320
  251. package/src/components/ui/models/insert-gif.tsx +0 -90
  252. package/src/components/ui/models/insert-image.tsx +0 -52
  253. package/src/components/ui/models/insert-poll.tsx +0 -29
  254. package/src/components/ui/models/insert-table.tsx +0 -62
  255. package/src/components/ui/models/use-model.tsx +0 -91
  256. package/src/components/ui/poll/poll-component.tsx +0 -304
  257. package/src/components/ui/popover.tsx +0 -33
  258. package/src/components/ui/progress.tsx +0 -28
  259. package/src/components/ui/scroll-area.tsx +0 -48
  260. package/src/components/ui/separator.tsx +0 -31
  261. package/src/components/ui/skeleton.tsx +0 -15
  262. package/src/components/ui/sonner.tsx +0 -31
  263. package/src/components/ui/stepper/step.tsx +0 -179
  264. package/src/components/ui/stepper/stepper.tsx +0 -89
  265. package/src/components/ui/textarea.tsx +0 -22
  266. package/src/components/ui/toggle.tsx +0 -71
  267. package/src/components/ui/tooltip.tsx +0 -32
  268. package/src/components/ui/write/text-format-floting-toolbar.tsx +0 -346
  269. package/src/lib/edgestore.ts +0 -9
  270. package/src/lib/pinecone-client.ts +0 -0
  271. package/src/lib/utils.ts +0 -6
  272. package/src/utils/docSerialization.ts +0 -77
  273. package/src/utils/emoji-list.ts +0 -16615
  274. package/src/utils/getDOMRangeRect.ts +0 -27
  275. package/src/utils/getThemeSelector.ts +0 -25
  276. package/src/utils/isMobileWidth.ts +0 -7
  277. package/src/utils/joinClasses.ts +0 -13
  278. package/src/utils/setFloatingElemPosition.ts +0 -74
  279. package/src/utils/setFloatingElemPositionForLinkEditor.ts +0 -46
  280. package/src/utils/swipe.ts +0 -127
  281. package/src/utils/url.ts +0 -38
  282. package/tsconfig.json +0 -27
@@ -0,0 +1,333 @@
1
+ import {
2
+ cn
3
+ } from "./chunk-YHPNOWFH.mjs";
4
+ import {
5
+ React,
6
+ __spreadProps,
7
+ __spreadValues,
8
+ init_react_shim
9
+ } from "./chunk-77KXU36M.mjs";
10
+
11
+ // src/components/ui/models/use-model.tsx
12
+ init_react_shim();
13
+ import { useCallback, useMemo, useState } from "react";
14
+
15
+ // src/components/ui/models/custom-dialog.tsx
16
+ init_react_shim();
17
+ import { AnimatePresence, motion } from "framer-motion";
18
+ import React2, { createContext, useContext, useEffect, useRef } from "react";
19
+ import { useId } from "react";
20
+ import { createPortal } from "react-dom";
21
+ import { X } from "lucide-react";
22
+ var DialogContext = createContext(null);
23
+ var defaultVariants = {
24
+ initial: {
25
+ opacity: 0,
26
+ scale: 0.95,
27
+ y: 20
28
+ },
29
+ animate: {
30
+ opacity: 1,
31
+ scale: 1,
32
+ y: 0
33
+ },
34
+ exit: {
35
+ opacity: 0,
36
+ scale: 0.95,
37
+ y: 20
38
+ }
39
+ };
40
+ var defaultTransition = {
41
+ type: "spring",
42
+ stiffness: 300,
43
+ damping: 30
44
+ };
45
+ var backdropVariants = {
46
+ initial: { opacity: 0 },
47
+ animate: { opacity: 1 },
48
+ exit: { opacity: 0 }
49
+ };
50
+ function Dialog({
51
+ children,
52
+ variants = defaultVariants,
53
+ transition = defaultTransition,
54
+ defaultOpen,
55
+ onOpenChange,
56
+ open,
57
+ size = "md"
58
+ }) {
59
+ const [uncontrolledOpen, setUncontrolledOpen] = React2.useState(
60
+ defaultOpen || false
61
+ );
62
+ const dialogRef = useRef(null);
63
+ const isOpen = open !== void 0 ? open : uncontrolledOpen;
64
+ const setIsOpen = React2.useCallback(
65
+ (value) => {
66
+ if (open === void 0) {
67
+ setUncontrolledOpen(value);
68
+ }
69
+ onOpenChange == null ? void 0 : onOpenChange(value);
70
+ },
71
+ [open, onOpenChange]
72
+ );
73
+ useEffect(() => {
74
+ const dialog = dialogRef.current;
75
+ if (!dialog) return;
76
+ if (isOpen) {
77
+ document.body.style.overflow = "hidden";
78
+ dialog.showModal();
79
+ } else {
80
+ document.body.style.overflow = "";
81
+ dialog.close();
82
+ }
83
+ const handleCancel = (e) => {
84
+ e.preventDefault();
85
+ setIsOpen(false);
86
+ };
87
+ const handleKeyDown = (e) => {
88
+ if (e.key === "Escape" && isOpen) {
89
+ setIsOpen(false);
90
+ }
91
+ };
92
+ dialog.addEventListener("cancel", handleCancel);
93
+ document.addEventListener("keydown", handleKeyDown);
94
+ return () => {
95
+ dialog.removeEventListener("cancel", handleCancel);
96
+ document.removeEventListener("keydown", handleKeyDown);
97
+ document.body.style.overflow = "";
98
+ };
99
+ }, [isOpen, setIsOpen]);
100
+ const handleTrigger = () => {
101
+ setIsOpen(true);
102
+ };
103
+ const onAnimationComplete = (definition) => {
104
+ var _a;
105
+ if (definition === "exit" && !isOpen) {
106
+ (_a = dialogRef.current) == null ? void 0 : _a.close();
107
+ }
108
+ };
109
+ const baseId = useId();
110
+ const ids = {
111
+ dialog: `motion-ui-dialog-${baseId}`,
112
+ title: `motion-ui-dialog-title-${baseId}`,
113
+ description: `motion-ui-dialog-description-${baseId}`
114
+ };
115
+ return /* @__PURE__ */ React2.createElement(
116
+ DialogContext.Provider,
117
+ {
118
+ value: {
119
+ isOpen,
120
+ setIsOpen,
121
+ dialogRef,
122
+ variants,
123
+ transition,
124
+ ids,
125
+ onAnimationComplete,
126
+ handleTrigger,
127
+ size
128
+ }
129
+ },
130
+ children
131
+ );
132
+ }
133
+ function DialogPortal({ children }) {
134
+ if (typeof window !== "undefined") {
135
+ return createPortal(children, document.body);
136
+ }
137
+ return null;
138
+ }
139
+ function DialogContent({
140
+ children,
141
+ className,
142
+ container,
143
+ showClose = true
144
+ }) {
145
+ const context = useContext(DialogContext);
146
+ if (!context) throw new Error("DialogContent must be used within Dialog");
147
+ const {
148
+ isOpen,
149
+ setIsOpen,
150
+ dialogRef,
151
+ variants,
152
+ transition,
153
+ ids,
154
+ onAnimationComplete,
155
+ size
156
+ } = context;
157
+ const sizeStyles = {
158
+ sm: "max-w-sm",
159
+ md: "max-w-md",
160
+ lg: "max-w-lg",
161
+ xl: "max-w-xl",
162
+ full: "max-w-full mx-4"
163
+ };
164
+ const content = /* @__PURE__ */ React2.createElement(AnimatePresence, { mode: "wait" }, isOpen && /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement(
165
+ motion.div,
166
+ {
167
+ className: "fixed inset-0 z-50 bg-black/80 backdrop-blur-sm",
168
+ initial: "initial",
169
+ animate: "animate",
170
+ exit: "exit",
171
+ variants: backdropVariants,
172
+ transition: { duration: 0.2 },
173
+ onClick: () => setIsOpen(false)
174
+ }
175
+ ), /* @__PURE__ */ React2.createElement(
176
+ motion.dialog,
177
+ {
178
+ key: ids.dialog,
179
+ ref: dialogRef,
180
+ id: ids.dialog,
181
+ "aria-labelledby": ids.title,
182
+ "aria-describedby": ids.description,
183
+ "aria-modal": "true",
184
+ role: "dialog",
185
+ onClick: (e) => {
186
+ if (e.target === dialogRef.current) {
187
+ setIsOpen(false);
188
+ }
189
+ },
190
+ initial: "initial",
191
+ animate: "animate",
192
+ exit: "exit",
193
+ variants,
194
+ transition,
195
+ onAnimationComplete,
196
+ className: cn(
197
+ "fixed left-[50%] top-[50%] z-50 w-full translate-x-[-50%] translate-y-[-50%]",
198
+ "grid gap-4 border border-slate-200 bg-white p-6 shadow-lg",
199
+ "duration-200 sm:rounded-lg dark:border-slate-800 dark:bg-slate-950",
200
+ sizeStyles[size],
201
+ className
202
+ )
203
+ },
204
+ /* @__PURE__ */ React2.createElement("div", { className: "relative w-full" }, showClose && /* @__PURE__ */ React2.createElement(DialogClose, { className: "absolute right-0 top-0" }), children)
205
+ )));
206
+ return /* @__PURE__ */ React2.createElement(DialogPortal, { container }, content);
207
+ }
208
+ function DialogHeader({ children, className }) {
209
+ return /* @__PURE__ */ React2.createElement("div", { className: cn("flex flex-col space-y-1.5 text-center sm:text-left", className) }, children);
210
+ }
211
+ function DialogTitle({ children, className }) {
212
+ const context = useContext(DialogContext);
213
+ if (!context) throw new Error("DialogTitle must be used within Dialog");
214
+ return /* @__PURE__ */ React2.createElement(
215
+ "h2",
216
+ {
217
+ id: context.ids.title,
218
+ className: cn("text-lg font-semibold leading-none tracking-tight", className)
219
+ },
220
+ children
221
+ );
222
+ }
223
+ function DialogDescription({ children, className }) {
224
+ const context = useContext(DialogContext);
225
+ if (!context) throw new Error("DialogDescription must be used within Dialog");
226
+ return /* @__PURE__ */ React2.createElement(
227
+ "p",
228
+ {
229
+ id: context.ids.description,
230
+ className: cn("text-sm text-slate-500 dark:text-slate-400", className)
231
+ },
232
+ children
233
+ );
234
+ }
235
+ function DialogClose({
236
+ className,
237
+ children,
238
+ disabled,
239
+ variant = "outline",
240
+ size = "icon",
241
+ asChild = false
242
+ }) {
243
+ const context = useContext(DialogContext);
244
+ if (!context) throw new Error("DialogClose must be used within Dialog");
245
+ const baseStyles = "inline-flex items-center justify-center rounded-md text-sm font-medium ring-offset-white transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-slate-950 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 dark:ring-offset-slate-950 dark:focus-visible:ring-slate-300";
246
+ const variants = {
247
+ default: "bg-slate-900 text-slate-50 hover:bg-slate-900/90 dark:bg-slate-50 dark:text-slate-900 dark:hover:bg-slate-50/90",
248
+ destructive: "bg-red-500 text-slate-50 hover:bg-red-500/90 dark:bg-red-900 dark:text-slate-50 dark:hover:bg-red-900/90",
249
+ outline: "border border-slate-200 bg-white hover:bg-slate-100 hover:text-slate-900 dark:border-slate-800 dark:bg-slate-950 dark:hover:bg-slate-800 dark:hover:text-slate-50",
250
+ secondary: "bg-slate-100 text-slate-900 hover:bg-slate-100/80 dark:bg-slate-800 dark:text-slate-50 dark:hover:bg-slate-800/80",
251
+ ghost: "hover:bg-slate-100 hover:text-slate-900 dark:hover:bg-slate-800 dark:hover:text-slate-50"
252
+ };
253
+ const sizes = {
254
+ default: "h-10 px-4 py-2",
255
+ sm: "h-9 rounded-md px-3",
256
+ lg: "h-11 rounded-md px-8",
257
+ icon: "h-6 w-6"
258
+ };
259
+ if (asChild && React2.isValidElement(children)) {
260
+ return React2.cloneElement(children, __spreadProps(__spreadValues({}, children.props), {
261
+ onClick: () => context.setIsOpen(false)
262
+ }));
263
+ }
264
+ if (!children) {
265
+ return /* @__PURE__ */ React2.createElement(
266
+ "button",
267
+ {
268
+ onClick: () => context.setIsOpen(false),
269
+ type: "button",
270
+ "aria-label": "Close dialog",
271
+ className: cn(
272
+ "rounded-sm opacity-70 ring-offset-white transition-opacity hover:opacity-100",
273
+ "focus:outline-none focus:ring-2 focus:ring-slate-950 focus:ring-offset-2",
274
+ "disabled:pointer-events-none data-[state=open]:bg-slate-100",
275
+ "data-[state=open]:text-slate-500 dark:ring-offset-slate-950",
276
+ "dark:focus:ring-slate-300 dark:data-[state=open]:bg-slate-800",
277
+ "dark:data-[state=open]:text-slate-400",
278
+ className
279
+ ),
280
+ disabled
281
+ },
282
+ /* @__PURE__ */ React2.createElement(X, { className: "h-4 w-4" }),
283
+ /* @__PURE__ */ React2.createElement("span", { className: "sr-only" }, "Close")
284
+ );
285
+ }
286
+ return /* @__PURE__ */ React2.createElement(
287
+ "button",
288
+ {
289
+ onClick: () => context.setIsOpen(false),
290
+ type: "button",
291
+ className: cn(baseStyles, variants[variant], sizes[size], className),
292
+ disabled
293
+ },
294
+ children
295
+ );
296
+ }
297
+
298
+ // src/components/ui/models/use-model.tsx
299
+ function useModal() {
300
+ const [isOpen, setIsOpen] = useState(false);
301
+ const [modalContent, setModalContent] = useState(null);
302
+ const onClose = useCallback(() => {
303
+ setIsOpen(false);
304
+ setModalContent(null);
305
+ }, []);
306
+ const showModal = useCallback(
307
+ (title, description, getContent, isDilog) => {
308
+ setIsOpen(true);
309
+ setModalContent({
310
+ title,
311
+ description,
312
+ content: getContent ? getContent(onClose) : void 0,
313
+ isDilog
314
+ });
315
+ },
316
+ [onClose]
317
+ );
318
+ const modal = useMemo(() => {
319
+ if (!isOpen || !modalContent) {
320
+ return null;
321
+ }
322
+ const { title, description, content, isDilog } = modalContent;
323
+ if (!isDilog) {
324
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, content);
325
+ }
326
+ return /* @__PURE__ */ React.createElement(Dialog, { open: isOpen, onOpenChange: setIsOpen }, /* @__PURE__ */ React.createElement(DialogContent, { className: "w-full max-w-md bg-white p-6 dark:bg-zinc-900" }, (title || description) && /* @__PURE__ */ React.createElement(DialogHeader, null, title && /* @__PURE__ */ React.createElement(DialogTitle, { className: "text-zinc-900 dark:text-white" }, title), description && /* @__PURE__ */ React.createElement(DialogDescription, { className: "text-zinc-600 dark:text-zinc-400" }, description)), /* @__PURE__ */ React.createElement("div", { className: "mt-2" }, content), /* @__PURE__ */ React.createElement(DialogClose, null)));
327
+ }, [isOpen, modalContent]);
328
+ return [modal, showModal, isOpen];
329
+ }
330
+
331
+ export {
332
+ useModal
333
+ };
@@ -0,0 +1,37 @@
1
+ import {
2
+ cn
3
+ } from "./chunk-YHPNOWFH.mjs";
4
+ import {
5
+ __objRest,
6
+ __spreadValues,
7
+ init_react_shim
8
+ } from "./chunk-77KXU36M.mjs";
9
+
10
+ // src/components/ui/popover.tsx
11
+ init_react_shim();
12
+ import * as React from "react";
13
+ import * as PopoverPrimitive from "@radix-ui/react-popover";
14
+ var Popover = PopoverPrimitive.Root;
15
+ var PopoverTrigger = PopoverPrimitive.Trigger;
16
+ var PopoverContent = React.forwardRef((_a, ref) => {
17
+ var _b = _a, { className, align = "center", sideOffset = 4 } = _b, props = __objRest(_b, ["className", "align", "sideOffset"]);
18
+ return /* @__PURE__ */ React.createElement(PopoverPrimitive.Portal, null, /* @__PURE__ */ React.createElement(
19
+ PopoverPrimitive.Content,
20
+ __spreadValues({
21
+ ref,
22
+ align,
23
+ sideOffset,
24
+ className: cn(
25
+ "z-50 w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none 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",
26
+ className
27
+ )
28
+ }, props)
29
+ ));
30
+ });
31
+ PopoverContent.displayName = PopoverPrimitive.Content.displayName;
32
+
33
+ export {
34
+ Popover,
35
+ PopoverTrigger,
36
+ PopoverContent
37
+ };