convex-cms 0.0.2 → 0.0.3

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 (265) hide show
  1. package/admin-dist/nitro.json +15 -0
  2. package/admin-dist/public/assets/CmsEmptyState-CRswfTzk.js +5 -0
  3. package/admin-dist/public/assets/CmsPageHeader-CirpXndm.js +1 -0
  4. package/admin-dist/public/assets/CmsStatusBadge-CbEUpQu-.js +1 -0
  5. package/admin-dist/public/assets/CmsToolbar-BI2nZOXp.js +1 -0
  6. package/admin-dist/public/assets/ContentEntryEditor-CBeCyK_m.js +4 -0
  7. package/admin-dist/public/assets/ErrorState-BIVaWmom.js +1 -0
  8. package/admin-dist/public/assets/TaxonomyFilter-ChaY6Y_x.js +1 -0
  9. package/admin-dist/public/assets/_contentTypeId-DQ8k_Rvw.js +1 -0
  10. package/admin-dist/public/assets/_entryId-CKU_glsK.js +1 -0
  11. package/admin-dist/public/assets/alert-BXjTqrwQ.js +1 -0
  12. package/admin-dist/public/assets/badge-hvUOzpVZ.js +1 -0
  13. package/admin-dist/public/assets/circle-check-big-CF_pR17r.js +1 -0
  14. package/admin-dist/public/assets/command-DU82cJlt.js +1 -0
  15. package/admin-dist/public/assets/content-_LXl3pp7.js +1 -0
  16. package/admin-dist/public/assets/content-types-KjxaXGxY.js +2 -0
  17. package/admin-dist/public/assets/globals-CS6BZ0zp.css +1 -0
  18. package/admin-dist/public/assets/index-DNGIZHL-.js +1 -0
  19. package/admin-dist/public/assets/label-KNtpL71g.js +1 -0
  20. package/admin-dist/public/assets/link-2-Bw2aI4V4.js +1 -0
  21. package/admin-dist/public/assets/list-sYepHjt_.js +1 -0
  22. package/admin-dist/public/assets/main-CKj5yfEi.js +97 -0
  23. package/admin-dist/public/assets/media-Bkrkffm7.js +1 -0
  24. package/admin-dist/public/assets/new._contentTypeId-C3LstjNs.js +1 -0
  25. package/admin-dist/public/assets/plus-DUn8v_Xf.js +1 -0
  26. package/admin-dist/public/assets/rotate-ccw-DJEoHcRI.js +1 -0
  27. package/admin-dist/public/assets/scroll-area-DfIlT0in.js +1 -0
  28. package/admin-dist/public/assets/search-MuAUDJKR.js +1 -0
  29. package/admin-dist/public/assets/select-BD29IXCI.js +1 -0
  30. package/admin-dist/public/assets/settings-DmMyn_6A.js +1 -0
  31. package/admin-dist/public/assets/switch-h3Rrnl5i.js +1 -0
  32. package/admin-dist/public/assets/tabs-imc8h-Dp.js +1 -0
  33. package/admin-dist/public/assets/taxonomies-dAsrT65H.js +1 -0
  34. package/admin-dist/public/assets/textarea-BTy7nwzR.js +1 -0
  35. package/admin-dist/public/assets/trash-SAWKZZHv.js +1 -0
  36. package/admin-dist/public/assets/triangle-alert-E52Vfeuh.js +1 -0
  37. package/admin-dist/public/assets/useBreadcrumbLabel-BECBMCzM.js +1 -0
  38. package/admin-dist/public/assets/usePermissions-Basjs9BT.js +1 -0
  39. package/admin-dist/public/favicon.ico +0 -0
  40. package/admin-dist/server/_chunks/_libs/@date-fns/tz.mjs +217 -0
  41. package/admin-dist/server/_chunks/_libs/@floating-ui/core.mjs +719 -0
  42. package/admin-dist/server/_chunks/_libs/@floating-ui/dom.mjs +622 -0
  43. package/admin-dist/server/_chunks/_libs/@floating-ui/react-dom.mjs +292 -0
  44. package/admin-dist/server/_chunks/_libs/@floating-ui/utils.mjs +320 -0
  45. package/admin-dist/server/_chunks/_libs/@radix-ui/number.mjs +6 -0
  46. package/admin-dist/server/_chunks/_libs/@radix-ui/primitive.mjs +11 -0
  47. package/admin-dist/server/_chunks/_libs/@radix-ui/react-arrow.mjs +23 -0
  48. package/admin-dist/server/_chunks/_libs/@radix-ui/react-avatar.mjs +119 -0
  49. package/admin-dist/server/_chunks/_libs/@radix-ui/react-checkbox.mjs +270 -0
  50. package/admin-dist/server/_chunks/_libs/@radix-ui/react-collection.mjs +69 -0
  51. package/admin-dist/server/_chunks/_libs/@radix-ui/react-compose-refs.mjs +39 -0
  52. package/admin-dist/server/_chunks/_libs/@radix-ui/react-context.mjs +137 -0
  53. package/admin-dist/server/_chunks/_libs/@radix-ui/react-dialog.mjs +325 -0
  54. package/admin-dist/server/_chunks/_libs/@radix-ui/react-direction.mjs +9 -0
  55. package/admin-dist/server/_chunks/_libs/@radix-ui/react-dismissable-layer.mjs +210 -0
  56. package/admin-dist/server/_chunks/_libs/@radix-ui/react-dropdown-menu.mjs +253 -0
  57. package/admin-dist/server/_chunks/_libs/@radix-ui/react-focus-guards.mjs +29 -0
  58. package/admin-dist/server/_chunks/_libs/@radix-ui/react-focus-scope.mjs +206 -0
  59. package/admin-dist/server/_chunks/_libs/@radix-ui/react-id.mjs +14 -0
  60. package/admin-dist/server/_chunks/_libs/@radix-ui/react-label.mjs +23 -0
  61. package/admin-dist/server/_chunks/_libs/@radix-ui/react-menu.mjs +812 -0
  62. package/admin-dist/server/_chunks/_libs/@radix-ui/react-popover.mjs +300 -0
  63. package/admin-dist/server/_chunks/_libs/@radix-ui/react-popper.mjs +286 -0
  64. package/admin-dist/server/_chunks/_libs/@radix-ui/react-portal.mjs +16 -0
  65. package/admin-dist/server/_chunks/_libs/@radix-ui/react-presence.mjs +128 -0
  66. package/admin-dist/server/_chunks/_libs/@radix-ui/react-primitive.mjs +141 -0
  67. package/admin-dist/server/_chunks/_libs/@radix-ui/react-roving-focus.mjs +224 -0
  68. package/admin-dist/server/_chunks/_libs/@radix-ui/react-scroll-area.mjs +721 -0
  69. package/admin-dist/server/_chunks/_libs/@radix-ui/react-select.mjs +1163 -0
  70. package/admin-dist/server/_chunks/_libs/@radix-ui/react-separator.mjs +28 -0
  71. package/admin-dist/server/_chunks/_libs/@radix-ui/react-slot.mjs +601 -0
  72. package/admin-dist/server/_chunks/_libs/@radix-ui/react-switch.mjs +152 -0
  73. package/admin-dist/server/_chunks/_libs/@radix-ui/react-tabs.mjs +189 -0
  74. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-callback-ref.mjs +11 -0
  75. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-controllable-state.mjs +69 -0
  76. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-effect-event.mjs +1 -0
  77. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-escape-keydown.mjs +17 -0
  78. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-is-hydrated.mjs +15 -0
  79. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-layout-effect.mjs +6 -0
  80. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-previous.mjs +14 -0
  81. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-size.mjs +39 -0
  82. package/admin-dist/server/_chunks/_libs/@radix-ui/react-visually-hidden.mjs +33 -0
  83. package/admin-dist/server/_chunks/_libs/@tanstack/history.mjs +409 -0
  84. package/admin-dist/server/_chunks/_libs/@tanstack/react-router.mjs +1711 -0
  85. package/admin-dist/server/_chunks/_libs/@tanstack/react-store.mjs +56 -0
  86. package/admin-dist/server/_chunks/_libs/@tanstack/router-core.mjs +4829 -0
  87. package/admin-dist/server/_chunks/_libs/@tanstack/store.mjs +134 -0
  88. package/admin-dist/server/_chunks/_libs/react-dom.mjs +10781 -0
  89. package/admin-dist/server/_chunks/_libs/react.mjs +513 -0
  90. package/admin-dist/server/_libs/aria-hidden.mjs +122 -0
  91. package/admin-dist/server/_libs/class-variance-authority.mjs +44 -0
  92. package/admin-dist/server/_libs/clsx.mjs +16 -0
  93. package/admin-dist/server/_libs/cmdk.mjs +315 -0
  94. package/admin-dist/server/_libs/convex.mjs +4841 -0
  95. package/admin-dist/server/_libs/cookie-es.mjs +58 -0
  96. package/admin-dist/server/_libs/croner.mjs +1 -0
  97. package/admin-dist/server/_libs/crossws.mjs +1 -0
  98. package/admin-dist/server/_libs/date-fns.mjs +1716 -0
  99. package/admin-dist/server/_libs/detect-node-es.mjs +1 -0
  100. package/admin-dist/server/_libs/get-nonce.mjs +9 -0
  101. package/admin-dist/server/_libs/h3-v2.mjs +277 -0
  102. package/admin-dist/server/_libs/h3.mjs +401 -0
  103. package/admin-dist/server/_libs/hookable.mjs +1 -0
  104. package/admin-dist/server/_libs/isbot.mjs +20 -0
  105. package/admin-dist/server/_libs/lucide-react.mjs +850 -0
  106. package/admin-dist/server/_libs/ohash.mjs +1 -0
  107. package/admin-dist/server/_libs/react-day-picker.mjs +2201 -0
  108. package/admin-dist/server/_libs/react-remove-scroll-bar.mjs +82 -0
  109. package/admin-dist/server/_libs/react-remove-scroll.mjs +328 -0
  110. package/admin-dist/server/_libs/react-style-singleton.mjs +69 -0
  111. package/admin-dist/server/_libs/rou3.mjs +8 -0
  112. package/admin-dist/server/_libs/seroval-plugins.mjs +58 -0
  113. package/admin-dist/server/_libs/seroval.mjs +1765 -0
  114. package/admin-dist/server/_libs/srvx.mjs +719 -0
  115. package/admin-dist/server/_libs/tailwind-merge.mjs +3010 -0
  116. package/admin-dist/server/_libs/tiny-invariant.mjs +12 -0
  117. package/admin-dist/server/_libs/tiny-warning.mjs +5 -0
  118. package/admin-dist/server/_libs/tslib.mjs +39 -0
  119. package/admin-dist/server/_libs/ufo.mjs +54 -0
  120. package/admin-dist/server/_libs/unctx.mjs +1 -0
  121. package/admin-dist/server/_libs/unstorage.mjs +1 -0
  122. package/admin-dist/server/_libs/use-callback-ref.mjs +66 -0
  123. package/admin-dist/server/_libs/use-sidecar.mjs +106 -0
  124. package/admin-dist/server/_libs/use-sync-external-store.mjs +139 -0
  125. package/admin-dist/server/_libs/zod.mjs +4223 -0
  126. package/admin-dist/server/_ssr/CmsEmptyState-DU7-7-mV.mjs +290 -0
  127. package/admin-dist/server/_ssr/CmsPageHeader-CseW0AHm.mjs +24 -0
  128. package/admin-dist/server/_ssr/CmsStatusBadge-B_pi4KCp.mjs +127 -0
  129. package/admin-dist/server/_ssr/CmsToolbar-X75ex6ek.mjs +49 -0
  130. package/admin-dist/server/_ssr/ContentEntryEditor-CepusRsA.mjs +3720 -0
  131. package/admin-dist/server/_ssr/ErrorState-cI-bKLez.mjs +89 -0
  132. package/admin-dist/server/_ssr/TaxonomyFilter-Bwrq0-cz.mjs +188 -0
  133. package/admin-dist/server/_ssr/_contentTypeId-BqYKEcLr.mjs +379 -0
  134. package/admin-dist/server/_ssr/_entryId-CRfnqeDf.mjs +161 -0
  135. package/admin-dist/server/_ssr/_tanstack-start-manifest_v-BwDlABVk.mjs +4 -0
  136. package/admin-dist/server/_ssr/alert-CVt45UUP.mjs +92 -0
  137. package/admin-dist/server/_ssr/badge-6BsP37vG.mjs +125 -0
  138. package/admin-dist/server/_ssr/command-fy8epIKf.mjs +128 -0
  139. package/admin-dist/server/_ssr/config.server-D7JHDcDv.mjs +117 -0
  140. package/admin-dist/server/_ssr/content-B5RhL7uW.mjs +532 -0
  141. package/admin-dist/server/_ssr/content-types-BIOqCQYN.mjs +1166 -0
  142. package/admin-dist/server/_ssr/index-DHSHDPt1.mjs +193 -0
  143. package/admin-dist/server/_ssr/index.mjs +1275 -0
  144. package/admin-dist/server/_ssr/label-C8Dko1j7.mjs +22 -0
  145. package/admin-dist/server/_ssr/media-CSx3XttC.mjs +1832 -0
  146. package/admin-dist/server/_ssr/new._contentTypeId-DzanEZQM.mjs +144 -0
  147. package/admin-dist/server/_ssr/router-DDWcF-kt.mjs +1556 -0
  148. package/admin-dist/server/_ssr/scroll-area-bjPYwhXN.mjs +59 -0
  149. package/admin-dist/server/_ssr/select-BUhDDf4T.mjs +142 -0
  150. package/admin-dist/server/_ssr/settings-DAsxnw2q.mjs +348 -0
  151. package/admin-dist/server/_ssr/start-HYkvq4Ni.mjs +4 -0
  152. package/admin-dist/server/_ssr/switch-BgyRtQ1Z.mjs +31 -0
  153. package/admin-dist/server/_ssr/tabs-DzMdRB1A.mjs +628 -0
  154. package/admin-dist/server/_ssr/taxonomies-C8j8g5Q5.mjs +915 -0
  155. package/admin-dist/server/_ssr/textarea-9jNeYJSc.mjs +18 -0
  156. package/admin-dist/server/_ssr/trash-DYMxwhZB.mjs +291 -0
  157. package/admin-dist/server/_ssr/useBreadcrumbLabel-FNSAr2Ha.mjs +16 -0
  158. package/admin-dist/server/_ssr/usePermissions-BJGGahrJ.mjs +68 -0
  159. package/admin-dist/server/favicon.ico +0 -0
  160. package/admin-dist/server/index.mjs +627 -0
  161. package/dist/cli/index.js +0 -0
  162. package/dist/client/admin-config.d.ts +0 -1
  163. package/dist/client/admin-config.d.ts.map +1 -1
  164. package/dist/client/admin-config.js +0 -1
  165. package/dist/client/admin-config.js.map +1 -1
  166. package/dist/client/adminApi.d.ts.map +1 -1
  167. package/dist/client/agentTools.d.ts +1237 -135
  168. package/dist/client/agentTools.d.ts.map +1 -1
  169. package/dist/client/agentTools.js +33 -9
  170. package/dist/client/agentTools.js.map +1 -1
  171. package/dist/client/index.d.ts +1 -1
  172. package/dist/client/index.d.ts.map +1 -1
  173. package/dist/client/index.js.map +1 -1
  174. package/dist/component/_generated/component.d.ts +9 -0
  175. package/dist/component/_generated/component.d.ts.map +1 -1
  176. package/dist/component/mediaAssets.d.ts +35 -0
  177. package/dist/component/mediaAssets.d.ts.map +1 -1
  178. package/dist/component/mediaAssets.js +81 -0
  179. package/dist/component/mediaAssets.js.map +1 -1
  180. package/dist/test.d.ts.map +1 -1
  181. package/dist/test.js +2 -1
  182. package/dist/test.js.map +1 -1
  183. package/package.json +9 -5
  184. package/dist/component/auditLog.d.ts +0 -410
  185. package/dist/component/auditLog.d.ts.map +0 -1
  186. package/dist/component/auditLog.js +0 -607
  187. package/dist/component/auditLog.js.map +0 -1
  188. package/dist/component/types.d.ts +0 -4
  189. package/dist/component/types.d.ts.map +0 -1
  190. package/dist/component/types.js +0 -2
  191. package/dist/component/types.js.map +0 -1
  192. package/src/cli/commands/admin.ts +0 -104
  193. package/src/cli/index.ts +0 -21
  194. package/src/cli/utils/detectConvexUrl.ts +0 -54
  195. package/src/cli/utils/openBrowser.ts +0 -16
  196. package/src/client/admin-config.ts +0 -138
  197. package/src/client/adminApi.ts +0 -942
  198. package/src/client/agentTools.ts +0 -1311
  199. package/src/client/argTypes.ts +0 -316
  200. package/src/client/field-types.ts +0 -187
  201. package/src/client/index.ts +0 -1301
  202. package/src/client/queryBuilder.ts +0 -1100
  203. package/src/client/schema/codegen.ts +0 -500
  204. package/src/client/schema/defineContentType.ts +0 -501
  205. package/src/client/schema/index.ts +0 -169
  206. package/src/client/schema/schemaDrift.ts +0 -574
  207. package/src/client/schema/typedClient.ts +0 -688
  208. package/src/client/schema/types.ts +0 -666
  209. package/src/client/types.ts +0 -723
  210. package/src/client/workflows.ts +0 -141
  211. package/src/client/wrapper.ts +0 -4304
  212. package/src/component/_generated/api.ts +0 -140
  213. package/src/component/_generated/component.ts +0 -5029
  214. package/src/component/_generated/dataModel.ts +0 -60
  215. package/src/component/_generated/server.ts +0 -156
  216. package/src/component/authorization.ts +0 -647
  217. package/src/component/authorizationHooks.ts +0 -668
  218. package/src/component/bulkOperations.ts +0 -687
  219. package/src/component/contentEntries.ts +0 -1976
  220. package/src/component/contentEntryMutations.ts +0 -1223
  221. package/src/component/contentEntryValidation.ts +0 -707
  222. package/src/component/contentLock.ts +0 -550
  223. package/src/component/contentTypeMigration.ts +0 -1064
  224. package/src/component/contentTypeMutations.ts +0 -969
  225. package/src/component/contentTypes.ts +0 -346
  226. package/src/component/convex.config.ts +0 -44
  227. package/src/component/documentTypes.ts +0 -240
  228. package/src/component/eventEmitter.ts +0 -485
  229. package/src/component/exportImport.ts +0 -1169
  230. package/src/component/index.ts +0 -491
  231. package/src/component/lib/deepReferenceResolver.ts +0 -999
  232. package/src/component/lib/errors.ts +0 -816
  233. package/src/component/lib/index.ts +0 -145
  234. package/src/component/lib/mediaReferenceResolver.ts +0 -495
  235. package/src/component/lib/metadataExtractor.ts +0 -792
  236. package/src/component/lib/mutationAuth.ts +0 -199
  237. package/src/component/lib/queries.ts +0 -79
  238. package/src/component/lib/ragContentChunker.ts +0 -1371
  239. package/src/component/lib/referenceResolver.ts +0 -430
  240. package/src/component/lib/slugGenerator.ts +0 -262
  241. package/src/component/lib/slugUniqueness.ts +0 -333
  242. package/src/component/lib/softDelete.ts +0 -44
  243. package/src/component/localeFallbackChain.ts +0 -673
  244. package/src/component/localeFields.ts +0 -896
  245. package/src/component/mediaAssetMutations.ts +0 -725
  246. package/src/component/mediaAssets.ts +0 -932
  247. package/src/component/mediaFolderMutations.ts +0 -1046
  248. package/src/component/mediaUploadMutations.ts +0 -224
  249. package/src/component/mediaVariantMutations.ts +0 -900
  250. package/src/component/mediaVariants.ts +0 -793
  251. package/src/component/ragContentIndexer.ts +0 -1067
  252. package/src/component/rateLimitHooks.ts +0 -572
  253. package/src/component/roles.ts +0 -1360
  254. package/src/component/scheduledPublish.ts +0 -358
  255. package/src/component/schema.ts +0 -617
  256. package/src/component/taxonomies.ts +0 -949
  257. package/src/component/taxonomyMutations.ts +0 -1210
  258. package/src/component/trash.ts +0 -724
  259. package/src/component/userContext.ts +0 -898
  260. package/src/component/validation.ts +0 -1388
  261. package/src/component/validators.ts +0 -949
  262. package/src/component/versionMutations.ts +0 -392
  263. package/src/component/webhookTrigger.ts +0 -1922
  264. package/src/react/index.ts +0 -898
  265. package/src/test.ts +0 -1580
@@ -0,0 +1,253 @@
1
+ import { r as reactExports, j as jsxRuntimeExports } from "../react.mjs";
2
+ import { c as composeEventHandlers } from "./primitive.mjs";
3
+ import { c as composeRefs } from "./react-compose-refs.mjs";
4
+ import { c as createContextScope } from "./react-context.mjs";
5
+ import { u as useControllableState } from "./react-use-controllable-state.mjs";
6
+ import { P as Primitive } from "./react-primitive.mjs";
7
+ import { R as Root3, A as Anchor2, P as Portal, C as Content2$1, L as Label, S as Separator, I as Item2$1, c as createMenuScope, G as Group, a as CheckboxItem, b as RadioGroup, d as RadioItem, e as ItemIndicator, f as Arrow2, g as SubTrigger, h as SubContent } from "./react-menu.mjs";
8
+ import { u as useId } from "./react-id.mjs";
9
+ var DROPDOWN_MENU_NAME = "DropdownMenu";
10
+ var [createDropdownMenuContext] = createContextScope(
11
+ DROPDOWN_MENU_NAME,
12
+ [createMenuScope]
13
+ );
14
+ var useMenuScope = createMenuScope();
15
+ var [DropdownMenuProvider, useDropdownMenuContext] = createDropdownMenuContext(DROPDOWN_MENU_NAME);
16
+ var DropdownMenu = (props) => {
17
+ const {
18
+ __scopeDropdownMenu,
19
+ children,
20
+ dir,
21
+ open: openProp,
22
+ defaultOpen,
23
+ onOpenChange,
24
+ modal = true
25
+ } = props;
26
+ const menuScope = useMenuScope(__scopeDropdownMenu);
27
+ const triggerRef = reactExports.useRef(null);
28
+ const [open, setOpen] = useControllableState({
29
+ prop: openProp,
30
+ defaultProp: defaultOpen ?? false,
31
+ onChange: onOpenChange,
32
+ caller: DROPDOWN_MENU_NAME
33
+ });
34
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(
35
+ DropdownMenuProvider,
36
+ {
37
+ scope: __scopeDropdownMenu,
38
+ triggerId: useId(),
39
+ triggerRef,
40
+ contentId: useId(),
41
+ open,
42
+ onOpenChange: setOpen,
43
+ onOpenToggle: reactExports.useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen]),
44
+ modal,
45
+ children: /* @__PURE__ */ jsxRuntimeExports.jsx(Root3, { ...menuScope, open, onOpenChange: setOpen, dir, modal, children })
46
+ }
47
+ );
48
+ };
49
+ DropdownMenu.displayName = DROPDOWN_MENU_NAME;
50
+ var TRIGGER_NAME = "DropdownMenuTrigger";
51
+ var DropdownMenuTrigger = reactExports.forwardRef(
52
+ (props, forwardedRef) => {
53
+ const { __scopeDropdownMenu, disabled = false, ...triggerProps } = props;
54
+ const context = useDropdownMenuContext(TRIGGER_NAME, __scopeDropdownMenu);
55
+ const menuScope = useMenuScope(__scopeDropdownMenu);
56
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(Anchor2, { asChild: true, ...menuScope, children: /* @__PURE__ */ jsxRuntimeExports.jsx(
57
+ Primitive.button,
58
+ {
59
+ type: "button",
60
+ id: context.triggerId,
61
+ "aria-haspopup": "menu",
62
+ "aria-expanded": context.open,
63
+ "aria-controls": context.open ? context.contentId : void 0,
64
+ "data-state": context.open ? "open" : "closed",
65
+ "data-disabled": disabled ? "" : void 0,
66
+ disabled,
67
+ ...triggerProps,
68
+ ref: composeRefs(forwardedRef, context.triggerRef),
69
+ onPointerDown: composeEventHandlers(props.onPointerDown, (event) => {
70
+ if (!disabled && event.button === 0 && event.ctrlKey === false) {
71
+ context.onOpenToggle();
72
+ if (!context.open) event.preventDefault();
73
+ }
74
+ }),
75
+ onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {
76
+ if (disabled) return;
77
+ if (["Enter", " "].includes(event.key)) context.onOpenToggle();
78
+ if (event.key === "ArrowDown") context.onOpenChange(true);
79
+ if (["Enter", " ", "ArrowDown"].includes(event.key)) event.preventDefault();
80
+ })
81
+ }
82
+ ) });
83
+ }
84
+ );
85
+ DropdownMenuTrigger.displayName = TRIGGER_NAME;
86
+ var PORTAL_NAME = "DropdownMenuPortal";
87
+ var DropdownMenuPortal = (props) => {
88
+ const { __scopeDropdownMenu, ...portalProps } = props;
89
+ const menuScope = useMenuScope(__scopeDropdownMenu);
90
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(Portal, { ...menuScope, ...portalProps });
91
+ };
92
+ DropdownMenuPortal.displayName = PORTAL_NAME;
93
+ var CONTENT_NAME = "DropdownMenuContent";
94
+ var DropdownMenuContent = reactExports.forwardRef(
95
+ (props, forwardedRef) => {
96
+ const { __scopeDropdownMenu, ...contentProps } = props;
97
+ const context = useDropdownMenuContext(CONTENT_NAME, __scopeDropdownMenu);
98
+ const menuScope = useMenuScope(__scopeDropdownMenu);
99
+ const hasInteractedOutsideRef = reactExports.useRef(false);
100
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(
101
+ Content2$1,
102
+ {
103
+ id: context.contentId,
104
+ "aria-labelledby": context.triggerId,
105
+ ...menuScope,
106
+ ...contentProps,
107
+ ref: forwardedRef,
108
+ onCloseAutoFocus: composeEventHandlers(props.onCloseAutoFocus, (event) => {
109
+ if (!hasInteractedOutsideRef.current) context.triggerRef.current?.focus();
110
+ hasInteractedOutsideRef.current = false;
111
+ event.preventDefault();
112
+ }),
113
+ onInteractOutside: composeEventHandlers(props.onInteractOutside, (event) => {
114
+ const originalEvent = event.detail.originalEvent;
115
+ const ctrlLeftClick = originalEvent.button === 0 && originalEvent.ctrlKey === true;
116
+ const isRightClick = originalEvent.button === 2 || ctrlLeftClick;
117
+ if (!context.modal || isRightClick) hasInteractedOutsideRef.current = true;
118
+ }),
119
+ style: {
120
+ ...props.style,
121
+ // re-namespace exposed content custom properties
122
+ ...{
123
+ "--radix-dropdown-menu-content-transform-origin": "var(--radix-popper-transform-origin)",
124
+ "--radix-dropdown-menu-content-available-width": "var(--radix-popper-available-width)",
125
+ "--radix-dropdown-menu-content-available-height": "var(--radix-popper-available-height)",
126
+ "--radix-dropdown-menu-trigger-width": "var(--radix-popper-anchor-width)",
127
+ "--radix-dropdown-menu-trigger-height": "var(--radix-popper-anchor-height)"
128
+ }
129
+ }
130
+ }
131
+ );
132
+ }
133
+ );
134
+ DropdownMenuContent.displayName = CONTENT_NAME;
135
+ var GROUP_NAME = "DropdownMenuGroup";
136
+ var DropdownMenuGroup = reactExports.forwardRef(
137
+ (props, forwardedRef) => {
138
+ const { __scopeDropdownMenu, ...groupProps } = props;
139
+ const menuScope = useMenuScope(__scopeDropdownMenu);
140
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(Group, { ...menuScope, ...groupProps, ref: forwardedRef });
141
+ }
142
+ );
143
+ DropdownMenuGroup.displayName = GROUP_NAME;
144
+ var LABEL_NAME = "DropdownMenuLabel";
145
+ var DropdownMenuLabel = reactExports.forwardRef(
146
+ (props, forwardedRef) => {
147
+ const { __scopeDropdownMenu, ...labelProps } = props;
148
+ const menuScope = useMenuScope(__scopeDropdownMenu);
149
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(Label, { ...menuScope, ...labelProps, ref: forwardedRef });
150
+ }
151
+ );
152
+ DropdownMenuLabel.displayName = LABEL_NAME;
153
+ var ITEM_NAME = "DropdownMenuItem";
154
+ var DropdownMenuItem = reactExports.forwardRef(
155
+ (props, forwardedRef) => {
156
+ const { __scopeDropdownMenu, ...itemProps } = props;
157
+ const menuScope = useMenuScope(__scopeDropdownMenu);
158
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(Item2$1, { ...menuScope, ...itemProps, ref: forwardedRef });
159
+ }
160
+ );
161
+ DropdownMenuItem.displayName = ITEM_NAME;
162
+ var CHECKBOX_ITEM_NAME = "DropdownMenuCheckboxItem";
163
+ var DropdownMenuCheckboxItem = reactExports.forwardRef((props, forwardedRef) => {
164
+ const { __scopeDropdownMenu, ...checkboxItemProps } = props;
165
+ const menuScope = useMenuScope(__scopeDropdownMenu);
166
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(CheckboxItem, { ...menuScope, ...checkboxItemProps, ref: forwardedRef });
167
+ });
168
+ DropdownMenuCheckboxItem.displayName = CHECKBOX_ITEM_NAME;
169
+ var RADIO_GROUP_NAME = "DropdownMenuRadioGroup";
170
+ var DropdownMenuRadioGroup = reactExports.forwardRef((props, forwardedRef) => {
171
+ const { __scopeDropdownMenu, ...radioGroupProps } = props;
172
+ const menuScope = useMenuScope(__scopeDropdownMenu);
173
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(RadioGroup, { ...menuScope, ...radioGroupProps, ref: forwardedRef });
174
+ });
175
+ DropdownMenuRadioGroup.displayName = RADIO_GROUP_NAME;
176
+ var RADIO_ITEM_NAME = "DropdownMenuRadioItem";
177
+ var DropdownMenuRadioItem = reactExports.forwardRef((props, forwardedRef) => {
178
+ const { __scopeDropdownMenu, ...radioItemProps } = props;
179
+ const menuScope = useMenuScope(__scopeDropdownMenu);
180
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(RadioItem, { ...menuScope, ...radioItemProps, ref: forwardedRef });
181
+ });
182
+ DropdownMenuRadioItem.displayName = RADIO_ITEM_NAME;
183
+ var INDICATOR_NAME = "DropdownMenuItemIndicator";
184
+ var DropdownMenuItemIndicator = reactExports.forwardRef((props, forwardedRef) => {
185
+ const { __scopeDropdownMenu, ...itemIndicatorProps } = props;
186
+ const menuScope = useMenuScope(__scopeDropdownMenu);
187
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(ItemIndicator, { ...menuScope, ...itemIndicatorProps, ref: forwardedRef });
188
+ });
189
+ DropdownMenuItemIndicator.displayName = INDICATOR_NAME;
190
+ var SEPARATOR_NAME = "DropdownMenuSeparator";
191
+ var DropdownMenuSeparator = reactExports.forwardRef((props, forwardedRef) => {
192
+ const { __scopeDropdownMenu, ...separatorProps } = props;
193
+ const menuScope = useMenuScope(__scopeDropdownMenu);
194
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(Separator, { ...menuScope, ...separatorProps, ref: forwardedRef });
195
+ });
196
+ DropdownMenuSeparator.displayName = SEPARATOR_NAME;
197
+ var ARROW_NAME = "DropdownMenuArrow";
198
+ var DropdownMenuArrow = reactExports.forwardRef(
199
+ (props, forwardedRef) => {
200
+ const { __scopeDropdownMenu, ...arrowProps } = props;
201
+ const menuScope = useMenuScope(__scopeDropdownMenu);
202
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(Arrow2, { ...menuScope, ...arrowProps, ref: forwardedRef });
203
+ }
204
+ );
205
+ DropdownMenuArrow.displayName = ARROW_NAME;
206
+ var SUB_TRIGGER_NAME = "DropdownMenuSubTrigger";
207
+ var DropdownMenuSubTrigger = reactExports.forwardRef((props, forwardedRef) => {
208
+ const { __scopeDropdownMenu, ...subTriggerProps } = props;
209
+ const menuScope = useMenuScope(__scopeDropdownMenu);
210
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(SubTrigger, { ...menuScope, ...subTriggerProps, ref: forwardedRef });
211
+ });
212
+ DropdownMenuSubTrigger.displayName = SUB_TRIGGER_NAME;
213
+ var SUB_CONTENT_NAME = "DropdownMenuSubContent";
214
+ var DropdownMenuSubContent = reactExports.forwardRef((props, forwardedRef) => {
215
+ const { __scopeDropdownMenu, ...subContentProps } = props;
216
+ const menuScope = useMenuScope(__scopeDropdownMenu);
217
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(
218
+ SubContent,
219
+ {
220
+ ...menuScope,
221
+ ...subContentProps,
222
+ ref: forwardedRef,
223
+ style: {
224
+ ...props.style,
225
+ // re-namespace exposed content custom properties
226
+ ...{
227
+ "--radix-dropdown-menu-content-transform-origin": "var(--radix-popper-transform-origin)",
228
+ "--radix-dropdown-menu-content-available-width": "var(--radix-popper-available-width)",
229
+ "--radix-dropdown-menu-content-available-height": "var(--radix-popper-available-height)",
230
+ "--radix-dropdown-menu-trigger-width": "var(--radix-popper-anchor-width)",
231
+ "--radix-dropdown-menu-trigger-height": "var(--radix-popper-anchor-height)"
232
+ }
233
+ }
234
+ }
235
+ );
236
+ });
237
+ DropdownMenuSubContent.displayName = SUB_CONTENT_NAME;
238
+ var Root2 = DropdownMenu;
239
+ var Trigger = DropdownMenuTrigger;
240
+ var Portal2 = DropdownMenuPortal;
241
+ var Content2 = DropdownMenuContent;
242
+ var Label2 = DropdownMenuLabel;
243
+ var Item2 = DropdownMenuItem;
244
+ var Separator2 = DropdownMenuSeparator;
245
+ export {
246
+ Content2 as C,
247
+ Item2 as I,
248
+ Label2 as L,
249
+ Portal2 as P,
250
+ Root2 as R,
251
+ Separator2 as S,
252
+ Trigger as T
253
+ };
@@ -0,0 +1,29 @@
1
+ import { r as reactExports } from "../react.mjs";
2
+ var count = 0;
3
+ function useFocusGuards() {
4
+ reactExports.useEffect(() => {
5
+ const edgeGuards = document.querySelectorAll("[data-radix-focus-guard]");
6
+ document.body.insertAdjacentElement("afterbegin", edgeGuards[0] ?? createFocusGuard());
7
+ document.body.insertAdjacentElement("beforeend", edgeGuards[1] ?? createFocusGuard());
8
+ count++;
9
+ return () => {
10
+ if (count === 1) {
11
+ document.querySelectorAll("[data-radix-focus-guard]").forEach((node) => node.remove());
12
+ }
13
+ count--;
14
+ };
15
+ }, []);
16
+ }
17
+ function createFocusGuard() {
18
+ const element = document.createElement("span");
19
+ element.setAttribute("data-radix-focus-guard", "");
20
+ element.tabIndex = 0;
21
+ element.style.outline = "none";
22
+ element.style.opacity = "0";
23
+ element.style.position = "fixed";
24
+ element.style.pointerEvents = "none";
25
+ return element;
26
+ }
27
+ export {
28
+ useFocusGuards as u
29
+ };
@@ -0,0 +1,206 @@
1
+ import { r as reactExports, j as jsxRuntimeExports } from "../react.mjs";
2
+ import { u as useComposedRefs } from "./react-compose-refs.mjs";
3
+ import { P as Primitive } from "./react-primitive.mjs";
4
+ import { u as useCallbackRef } from "./react-use-callback-ref.mjs";
5
+ var AUTOFOCUS_ON_MOUNT = "focusScope.autoFocusOnMount";
6
+ var AUTOFOCUS_ON_UNMOUNT = "focusScope.autoFocusOnUnmount";
7
+ var EVENT_OPTIONS = { bubbles: false, cancelable: true };
8
+ var FOCUS_SCOPE_NAME = "FocusScope";
9
+ var FocusScope = reactExports.forwardRef((props, forwardedRef) => {
10
+ const {
11
+ loop = false,
12
+ trapped = false,
13
+ onMountAutoFocus: onMountAutoFocusProp,
14
+ onUnmountAutoFocus: onUnmountAutoFocusProp,
15
+ ...scopeProps
16
+ } = props;
17
+ const [container, setContainer] = reactExports.useState(null);
18
+ const onMountAutoFocus = useCallbackRef(onMountAutoFocusProp);
19
+ const onUnmountAutoFocus = useCallbackRef(onUnmountAutoFocusProp);
20
+ const lastFocusedElementRef = reactExports.useRef(null);
21
+ const composedRefs = useComposedRefs(forwardedRef, (node) => setContainer(node));
22
+ const focusScope = reactExports.useRef({
23
+ paused: false,
24
+ pause() {
25
+ this.paused = true;
26
+ },
27
+ resume() {
28
+ this.paused = false;
29
+ }
30
+ }).current;
31
+ reactExports.useEffect(() => {
32
+ if (trapped) {
33
+ let handleFocusIn2 = function(event) {
34
+ if (focusScope.paused || !container) return;
35
+ const target = event.target;
36
+ if (container.contains(target)) {
37
+ lastFocusedElementRef.current = target;
38
+ } else {
39
+ focus(lastFocusedElementRef.current, { select: true });
40
+ }
41
+ }, handleFocusOut2 = function(event) {
42
+ if (focusScope.paused || !container) return;
43
+ const relatedTarget = event.relatedTarget;
44
+ if (relatedTarget === null) return;
45
+ if (!container.contains(relatedTarget)) {
46
+ focus(lastFocusedElementRef.current, { select: true });
47
+ }
48
+ }, handleMutations2 = function(mutations) {
49
+ const focusedElement = document.activeElement;
50
+ if (focusedElement !== document.body) return;
51
+ for (const mutation of mutations) {
52
+ if (mutation.removedNodes.length > 0) focus(container);
53
+ }
54
+ };
55
+ document.addEventListener("focusin", handleFocusIn2);
56
+ document.addEventListener("focusout", handleFocusOut2);
57
+ const mutationObserver = new MutationObserver(handleMutations2);
58
+ if (container) mutationObserver.observe(container, { childList: true, subtree: true });
59
+ return () => {
60
+ document.removeEventListener("focusin", handleFocusIn2);
61
+ document.removeEventListener("focusout", handleFocusOut2);
62
+ mutationObserver.disconnect();
63
+ };
64
+ }
65
+ }, [trapped, container, focusScope.paused]);
66
+ reactExports.useEffect(() => {
67
+ if (container) {
68
+ focusScopesStack.add(focusScope);
69
+ const previouslyFocusedElement = document.activeElement;
70
+ const hasFocusedCandidate = container.contains(previouslyFocusedElement);
71
+ if (!hasFocusedCandidate) {
72
+ const mountEvent = new CustomEvent(AUTOFOCUS_ON_MOUNT, EVENT_OPTIONS);
73
+ container.addEventListener(AUTOFOCUS_ON_MOUNT, onMountAutoFocus);
74
+ container.dispatchEvent(mountEvent);
75
+ if (!mountEvent.defaultPrevented) {
76
+ focusFirst(removeLinks(getTabbableCandidates(container)), { select: true });
77
+ if (document.activeElement === previouslyFocusedElement) {
78
+ focus(container);
79
+ }
80
+ }
81
+ }
82
+ return () => {
83
+ container.removeEventListener(AUTOFOCUS_ON_MOUNT, onMountAutoFocus);
84
+ setTimeout(() => {
85
+ const unmountEvent = new CustomEvent(AUTOFOCUS_ON_UNMOUNT, EVENT_OPTIONS);
86
+ container.addEventListener(AUTOFOCUS_ON_UNMOUNT, onUnmountAutoFocus);
87
+ container.dispatchEvent(unmountEvent);
88
+ if (!unmountEvent.defaultPrevented) {
89
+ focus(previouslyFocusedElement ?? document.body, { select: true });
90
+ }
91
+ container.removeEventListener(AUTOFOCUS_ON_UNMOUNT, onUnmountAutoFocus);
92
+ focusScopesStack.remove(focusScope);
93
+ }, 0);
94
+ };
95
+ }
96
+ }, [container, onMountAutoFocus, onUnmountAutoFocus, focusScope]);
97
+ const handleKeyDown = reactExports.useCallback(
98
+ (event) => {
99
+ if (!loop && !trapped) return;
100
+ if (focusScope.paused) return;
101
+ const isTabKey = event.key === "Tab" && !event.altKey && !event.ctrlKey && !event.metaKey;
102
+ const focusedElement = document.activeElement;
103
+ if (isTabKey && focusedElement) {
104
+ const container2 = event.currentTarget;
105
+ const [first, last] = getTabbableEdges(container2);
106
+ const hasTabbableElementsInside = first && last;
107
+ if (!hasTabbableElementsInside) {
108
+ if (focusedElement === container2) event.preventDefault();
109
+ } else {
110
+ if (!event.shiftKey && focusedElement === last) {
111
+ event.preventDefault();
112
+ if (loop) focus(first, { select: true });
113
+ } else if (event.shiftKey && focusedElement === first) {
114
+ event.preventDefault();
115
+ if (loop) focus(last, { select: true });
116
+ }
117
+ }
118
+ }
119
+ },
120
+ [loop, trapped, focusScope.paused]
121
+ );
122
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(Primitive.div, { tabIndex: -1, ...scopeProps, ref: composedRefs, onKeyDown: handleKeyDown });
123
+ });
124
+ FocusScope.displayName = FOCUS_SCOPE_NAME;
125
+ function focusFirst(candidates, { select = false } = {}) {
126
+ const previouslyFocusedElement = document.activeElement;
127
+ for (const candidate of candidates) {
128
+ focus(candidate, { select });
129
+ if (document.activeElement !== previouslyFocusedElement) return;
130
+ }
131
+ }
132
+ function getTabbableEdges(container) {
133
+ const candidates = getTabbableCandidates(container);
134
+ const first = findVisible(candidates, container);
135
+ const last = findVisible(candidates.reverse(), container);
136
+ return [first, last];
137
+ }
138
+ function getTabbableCandidates(container) {
139
+ const nodes = [];
140
+ const walker = document.createTreeWalker(container, NodeFilter.SHOW_ELEMENT, {
141
+ acceptNode: (node) => {
142
+ const isHiddenInput = node.tagName === "INPUT" && node.type === "hidden";
143
+ if (node.disabled || node.hidden || isHiddenInput) return NodeFilter.FILTER_SKIP;
144
+ return node.tabIndex >= 0 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;
145
+ }
146
+ });
147
+ while (walker.nextNode()) nodes.push(walker.currentNode);
148
+ return nodes;
149
+ }
150
+ function findVisible(elements, container) {
151
+ for (const element of elements) {
152
+ if (!isHidden(element, { upTo: container })) return element;
153
+ }
154
+ }
155
+ function isHidden(node, { upTo }) {
156
+ if (getComputedStyle(node).visibility === "hidden") return true;
157
+ while (node) {
158
+ if (upTo !== void 0 && node === upTo) return false;
159
+ if (getComputedStyle(node).display === "none") return true;
160
+ node = node.parentElement;
161
+ }
162
+ return false;
163
+ }
164
+ function isSelectableInput(element) {
165
+ return element instanceof HTMLInputElement && "select" in element;
166
+ }
167
+ function focus(element, { select = false } = {}) {
168
+ if (element && element.focus) {
169
+ const previouslyFocusedElement = document.activeElement;
170
+ element.focus({ preventScroll: true });
171
+ if (element !== previouslyFocusedElement && isSelectableInput(element) && select)
172
+ element.select();
173
+ }
174
+ }
175
+ var focusScopesStack = createFocusScopesStack();
176
+ function createFocusScopesStack() {
177
+ let stack = [];
178
+ return {
179
+ add(focusScope) {
180
+ const activeFocusScope = stack[0];
181
+ if (focusScope !== activeFocusScope) {
182
+ activeFocusScope?.pause();
183
+ }
184
+ stack = arrayRemove(stack, focusScope);
185
+ stack.unshift(focusScope);
186
+ },
187
+ remove(focusScope) {
188
+ stack = arrayRemove(stack, focusScope);
189
+ stack[0]?.resume();
190
+ }
191
+ };
192
+ }
193
+ function arrayRemove(array, item) {
194
+ const updatedArray = [...array];
195
+ const index = updatedArray.indexOf(item);
196
+ if (index !== -1) {
197
+ updatedArray.splice(index, 1);
198
+ }
199
+ return updatedArray;
200
+ }
201
+ function removeLinks(items) {
202
+ return items.filter((item) => item.tagName !== "A");
203
+ }
204
+ export {
205
+ FocusScope as F
206
+ };
@@ -0,0 +1,14 @@
1
+ import { r as reactExports, R as React } from "../react.mjs";
2
+ import { u as useLayoutEffect2 } from "./react-use-layout-effect.mjs";
3
+ var useReactId = React[" useId ".trim().toString()] || (() => void 0);
4
+ var count = 0;
5
+ function useId(deterministicId) {
6
+ const [id, setId] = reactExports.useState(useReactId());
7
+ useLayoutEffect2(() => {
8
+ setId((reactId) => reactId ?? String(count++));
9
+ }, [deterministicId]);
10
+ return deterministicId || (id ? `radix-${id}` : "");
11
+ }
12
+ export {
13
+ useId as u
14
+ };
@@ -0,0 +1,23 @@
1
+ import { r as reactExports, j as jsxRuntimeExports } from "../react.mjs";
2
+ import { b as Primitive } from "./react-primitive.mjs";
3
+ var NAME = "Label";
4
+ var Label = reactExports.forwardRef((props, forwardedRef) => {
5
+ return /* @__PURE__ */ jsxRuntimeExports.jsx(
6
+ Primitive.label,
7
+ {
8
+ ...props,
9
+ ref: forwardedRef,
10
+ onMouseDown: (event) => {
11
+ const target = event.target;
12
+ if (target.closest("button, input, select, textarea")) return;
13
+ props.onMouseDown?.(event);
14
+ if (!event.defaultPrevented && event.detail > 1) event.preventDefault();
15
+ }
16
+ }
17
+ );
18
+ });
19
+ Label.displayName = NAME;
20
+ var Root = Label;
21
+ export {
22
+ Root as R
23
+ };