@powerhousedao/connect 4.1.0-dev.105 → 4.1.0-dev.107

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 (270) hide show
  1. package/dist/assets/AddDriveModal-C2fZqOQI.js +1 -0
  2. package/dist/assets/ClearStorageModal-DjjEBXBS.js +1 -0
  3. package/dist/assets/CookiesPolicyModal-BrOPPvzy.js +1 -0
  4. package/dist/assets/CreateDocumentModal-C09c_nGK.js +1 -0
  5. package/dist/assets/DebugSettingsModal-PbDxwRkN.js +1 -0
  6. package/dist/assets/DeleteDriveModal-x5WgUnZq.js +1 -0
  7. package/dist/assets/DeleteItemModal-BBYKOKsF.js +1 -0
  8. package/dist/assets/DisclaimerModal-CteySYvG.js +1 -0
  9. package/dist/assets/DriveSettingsModal-B18X9rkK.js +1 -0
  10. package/dist/assets/ExportDocumentWithErrorsModal-B7IfIoUE.js +1 -0
  11. package/dist/assets/SettingsModal-BrdAtrxz.js +1 -0
  12. package/dist/assets/UpgradeDriveModal-fqiiEuOr.js +1 -0
  13. package/dist/assets/common-8r_LaZs4.css +1 -0
  14. package/dist/assets/common-n2B-GsjO.js +1 -0
  15. package/dist/assets/config-CU-aFfVJ.js +1 -0
  16. package/dist/assets/design_system-CZfmC8Ij.js +45 -0
  17. package/dist/assets/design_system_connect-DHQbQvgv.js +53 -0
  18. package/dist/assets/document_drive-CP6paqKN.js +305 -0
  19. package/dist/assets/document_engineering-DojqH50p.js +1 -0
  20. package/dist/assets/document_model-DLxR7ZLO.js +230 -0
  21. package/dist/assets/document_model_editor-ButtI7kP.js +2 -0
  22. package/dist/assets/drive_explorer-IB_BS5Au.js +2 -0
  23. package/dist/assets/editor-CgH7LMsL.js +105 -0
  24. package/dist/assets/editor-ClAkqmdQ.js +1 -0
  25. package/dist/assets/graphql-BS4Brs_E.js +75 -0
  26. package/dist/assets/graphql_request-9RNJ00DB.js +3 -0
  27. package/dist/assets/hmr-LMNkvzP7.js +1 -0
  28. package/dist/assets/index-BSTajiPh.js +18 -0
  29. package/dist/assets/index-Br7E7qjt.css +1 -0
  30. package/dist/assets/reactor_browser-BbZdm6Aa.js +25 -0
  31. package/dist/assets/sentry_browser-BFJlXALZ.js +498 -0
  32. package/dist/assets/sentry_react-C4W8xEsl.js +3 -0
  33. package/dist/assets/virtual_ph_external-packages-CM1tCR4L.js +1 -0
  34. package/dist/assets/zod-C6yxFxyo.js +1 -0
  35. package/dist/index.html +17 -2
  36. package/heroku/config/nginx.conf.template +7 -18
  37. package/lib/package.copy.json +27 -57
  38. package/lib/src/components/analytics.js +1 -1
  39. package/lib/src/components/analytics.js.map +1 -1
  40. package/lib/src/components/app-loader.d.ts +1 -1
  41. package/lib/src/components/app-loader.d.ts.map +1 -1
  42. package/lib/src/components/app-loader.js +2 -5
  43. package/lib/src/components/app-loader.js.map +1 -1
  44. package/lib/src/components/app-skeleton.d.ts.map +1 -1
  45. package/lib/src/components/app-skeleton.js +1 -1
  46. package/lib/src/components/app-skeleton.js.map +1 -1
  47. package/lib/src/components/app.d.ts.map +1 -1
  48. package/lib/src/components/app.js +3 -4
  49. package/lib/src/components/app.js.map +1 -1
  50. package/lib/src/components/cookie-banner.d.ts.map +1 -1
  51. package/lib/src/components/cookie-banner.js +3 -4
  52. package/lib/src/components/cookie-banner.js.map +1 -1
  53. package/lib/src/components/document-editor-container.js +2 -2
  54. package/lib/src/components/document-editor-container.js.map +1 -1
  55. package/lib/src/components/drive-editor-container.js +2 -2
  56. package/lib/src/components/drive-editor-container.js.map +1 -1
  57. package/lib/src/components/editor-loader.d.ts +1 -1
  58. package/lib/src/components/editor-loader.d.ts.map +1 -1
  59. package/lib/src/components/editor-loader.js +1 -1
  60. package/lib/src/components/editor-loader.js.map +1 -1
  61. package/lib/src/components/editors.js +2 -2
  62. package/lib/src/components/editors.js.map +1 -1
  63. package/lib/src/components/footer.js +3 -2
  64. package/lib/src/components/footer.js.map +1 -1
  65. package/lib/src/components/index.d.ts +1 -2
  66. package/lib/src/components/index.d.ts.map +1 -1
  67. package/lib/src/components/index.js +1 -2
  68. package/lib/src/components/index.js.map +1 -1
  69. package/lib/src/components/login.js +1 -1
  70. package/lib/src/components/login.js.map +1 -1
  71. package/lib/src/components/modal/index.d.ts +17 -1
  72. package/lib/src/components/modal/index.d.ts.map +1 -1
  73. package/lib/src/components/modal/index.js +17 -1
  74. package/lib/src/components/modal/index.js.map +1 -1
  75. package/lib/src/components/modal/modals/AddDriveModal.d.ts.map +1 -1
  76. package/lib/src/components/modal/modals/AddDriveModal.js +2 -1
  77. package/lib/src/components/modal/modals/AddDriveModal.js.map +1 -1
  78. package/lib/src/components/modal/modals/ClearStorageModal.js +2 -2
  79. package/lib/src/components/modal/modals/ClearStorageModal.js.map +1 -1
  80. package/lib/src/components/modal/modals/CookiesPolicyModal.js +1 -1
  81. package/lib/src/components/modal/modals/CookiesPolicyModal.js.map +1 -1
  82. package/lib/src/components/modal/modals/CreateDocumentModal.js +1 -1
  83. package/lib/src/components/modal/modals/CreateDocumentModal.js.map +1 -1
  84. package/lib/src/components/modal/modals/DebugSettingsModal.d.ts.map +1 -1
  85. package/lib/src/components/modal/modals/DebugSettingsModal.js +3 -2
  86. package/lib/src/components/modal/modals/DebugSettingsModal.js.map +1 -1
  87. package/lib/src/components/modal/modals/DeleteDriveModal.d.ts.map +1 -1
  88. package/lib/src/components/modal/modals/DeleteDriveModal.js +2 -1
  89. package/lib/src/components/modal/modals/DeleteDriveModal.js.map +1 -1
  90. package/lib/src/components/modal/modals/DeleteItemModal.d.ts.map +1 -1
  91. package/lib/src/components/modal/modals/DeleteItemModal.js +2 -1
  92. package/lib/src/components/modal/modals/DeleteItemModal.js.map +1 -1
  93. package/lib/src/components/modal/modals/DisclaimerModal.js +1 -1
  94. package/lib/src/components/modal/modals/DisclaimerModal.js.map +1 -1
  95. package/lib/src/components/modal/modals/DriveSettingsModal.js +2 -2
  96. package/lib/src/components/modal/modals/DriveSettingsModal.js.map +1 -1
  97. package/lib/src/components/modal/modals/ExportDocumentWithErrorsModal.js +1 -1
  98. package/lib/src/components/modal/modals/ExportDocumentWithErrorsModal.js.map +1 -1
  99. package/lib/src/components/modal/modals/SettingsModal.d.ts.map +1 -1
  100. package/lib/src/components/modal/modals/SettingsModal.js +4 -6
  101. package/lib/src/components/modal/modals/SettingsModal.js.map +1 -1
  102. package/lib/src/components/modal/modals/UpgradeDriveModal.js +1 -1
  103. package/lib/src/components/modal/modals/UpgradeDriveModal.js.map +1 -1
  104. package/lib/src/components/modal/modals/settings/about.js +1 -1
  105. package/lib/src/components/modal/modals/settings/about.js.map +1 -1
  106. package/lib/src/components/modal/modals/settings/danger-zone.js +1 -1
  107. package/lib/src/components/modal/modals/settings/danger-zone.js.map +1 -1
  108. package/lib/src/components/modal/modals/settings/default-editor.js +1 -1
  109. package/lib/src/components/modal/modals/settings/default-editor.js.map +1 -1
  110. package/lib/src/components/modal/modals/settings/package-manager.d.ts +1 -1
  111. package/lib/src/components/modal/modals/settings/package-manager.d.ts.map +1 -1
  112. package/lib/src/components/modal/modals/settings/package-manager.js +4 -5
  113. package/lib/src/components/modal/modals/settings/package-manager.js.map +1 -1
  114. package/lib/src/components/ph-logo.js +1 -1
  115. package/lib/src/components/ph-logo.js.map +1 -1
  116. package/lib/src/components/reload-connect-toast.d.ts.map +1 -0
  117. package/lib/src/components/reload-connect-toast.js.map +1 -0
  118. package/lib/src/components/root.d.ts.map +1 -1
  119. package/lib/src/components/root.js +3 -4
  120. package/lib/src/components/root.js.map +1 -1
  121. package/lib/src/components/router.js +1 -1
  122. package/lib/src/components/router.js.map +1 -1
  123. package/lib/src/components/search-bar.d.ts.map +1 -1
  124. package/lib/src/components/search-bar.js +2 -1
  125. package/lib/src/components/search-bar.js.map +1 -1
  126. package/lib/src/components/sidebar.d.ts.map +1 -1
  127. package/lib/src/components/sidebar.js +3 -2
  128. package/lib/src/components/sidebar.js.map +1 -1
  129. package/lib/src/context/sentry-provider.js +1 -1
  130. package/lib/src/context/sentry-provider.js.map +1 -1
  131. package/lib/src/feature-flags.d.ts.map +1 -0
  132. package/lib/src/feature-flags.js.map +1 -0
  133. package/lib/src/globals.d.ts +1 -1
  134. package/lib/src/globals.d.ts.map +1 -1
  135. package/lib/src/hooks/useCheckLatestVersion.js +3 -3
  136. package/lib/src/hooks/useCheckLatestVersion.js.map +1 -1
  137. package/lib/src/index.d.ts +1 -8
  138. package/lib/src/index.d.ts.map +1 -1
  139. package/lib/src/index.js +1 -8
  140. package/lib/src/index.js.map +1 -1
  141. package/lib/src/main.js +1 -1
  142. package/lib/src/main.js.map +1 -1
  143. package/lib/src/pages/content.d.ts.map +1 -1
  144. package/lib/src/pages/content.js +2 -3
  145. package/lib/src/pages/content.js.map +1 -1
  146. package/lib/src/pages/index.d.ts +2 -1
  147. package/lib/src/pages/index.d.ts.map +1 -1
  148. package/lib/src/pages/index.js +2 -1
  149. package/lib/src/pages/index.js.map +1 -1
  150. package/lib/src/services/index.d.ts +6 -2
  151. package/lib/src/services/index.d.ts.map +1 -1
  152. package/lib/src/services/index.js +5 -2
  153. package/lib/src/services/index.js.map +1 -1
  154. package/lib/src/services/toast.d.ts +2 -2
  155. package/lib/src/services/toast.d.ts.map +1 -1
  156. package/lib/src/services/toast.js +1 -1
  157. package/lib/src/services/toast.js.map +1 -1
  158. package/lib/src/store/document-model.d.ts.map +1 -1
  159. package/lib/src/store/document-model.js +3 -3
  160. package/lib/src/store/document-model.js.map +1 -1
  161. package/lib/src/store/editor.d.ts +2 -2
  162. package/lib/src/store/editor.d.ts.map +1 -1
  163. package/lib/src/store/editor.js +6 -6
  164. package/lib/src/store/editor.js.map +1 -1
  165. package/lib/src/store/reactor.d.ts.map +1 -1
  166. package/lib/src/store/reactor.js +6 -21
  167. package/lib/src/store/reactor.js.map +1 -1
  168. package/lib/src/utils/drive-sections.d.ts +1 -1
  169. package/lib/src/utils/drive-sections.d.ts.map +1 -1
  170. package/lib/src/utils/drive-sections.js +1 -1
  171. package/lib/src/utils/drive-sections.js.map +1 -1
  172. package/lib/tsconfig.tsbuildinfo +1 -1
  173. package/lib/vite.config.d.ts.map +1 -1
  174. package/lib/vite.config.js +23 -0
  175. package/lib/vite.config.js.map +1 -1
  176. package/package.copy.json +27 -57
  177. package/package.json +34 -64
  178. package/dist/assets/AddDriveModal-07mDwuqC.js +0 -248
  179. package/dist/assets/AddDriveModal-07mDwuqC.js.map +0 -1
  180. package/dist/assets/ClearStorageModal-NS7l69ap.js +0 -46
  181. package/dist/assets/ClearStorageModal-NS7l69ap.js.map +0 -1
  182. package/dist/assets/CookiesPolicyModal-C6dI4RKZ.js +0 -34
  183. package/dist/assets/CookiesPolicyModal-C6dI4RKZ.js.map +0 -1
  184. package/dist/assets/CreateDocumentModal-KKbJcBSL.js +0 -65
  185. package/dist/assets/CreateDocumentModal-KKbJcBSL.js.map +0 -1
  186. package/dist/assets/DebugSettingsModal-DXtCp24I.js +0 -5134
  187. package/dist/assets/DebugSettingsModal-DXtCp24I.js.map +0 -1
  188. package/dist/assets/DeleteDriveModal-MSDNucFy.js +0 -55
  189. package/dist/assets/DeleteDriveModal-MSDNucFy.js.map +0 -1
  190. package/dist/assets/DeleteItemModal-DW8_baau.js +0 -47
  191. package/dist/assets/DeleteItemModal-DW8_baau.js.map +0 -1
  192. package/dist/assets/DisclaimerModal-C6UyAzGM.js +0 -21
  193. package/dist/assets/DisclaimerModal-C6UyAzGM.js.map +0 -1
  194. package/dist/assets/DriveSettingsModal-DfM8Gfc9.js +0 -103
  195. package/dist/assets/DriveSettingsModal-DfM8Gfc9.js.map +0 -1
  196. package/dist/assets/ExportDocumentWithErrorsModal-cWlxN3T_.js +0 -44
  197. package/dist/assets/ExportDocumentWithErrorsModal-cWlxN3T_.js.map +0 -1
  198. package/dist/assets/SettingsModal-BlWJfQsu.js +0 -1723
  199. package/dist/assets/SettingsModal-BlWJfQsu.js.map +0 -1
  200. package/dist/assets/UpgradeDriveModal-BL7i2apX.js +0 -40
  201. package/dist/assets/UpgradeDriveModal-BL7i2apX.js.map +0 -1
  202. package/dist/assets/ccip-DhNdZlh7.js +0 -168
  203. package/dist/assets/ccip-DhNdZlh7.js.map +0 -1
  204. package/dist/assets/confirmation-modal-DM5tMFeL.js +0 -16
  205. package/dist/assets/confirmation-modal-DM5tMFeL.js.map +0 -1
  206. package/dist/assets/disclosure-iERpR3s0.js +0 -9
  207. package/dist/assets/disclosure-iERpR3s0.js.map +0 -1
  208. package/dist/assets/drive-by-id-BanyjI1t.js +0 -14
  209. package/dist/assets/drive-by-id-BanyjI1t.js.map +0 -1
  210. package/dist/assets/dropdown-menu-CXmhaaui.js +0 -1026
  211. package/dist/assets/dropdown-menu-CXmhaaui.js.map +0 -1
  212. package/dist/assets/editor-BKLE2wdL.js +0 -416
  213. package/dist/assets/editor-BKLE2wdL.js.map +0 -1
  214. package/dist/assets/editor-DO3KuTx4.js +0 -47585
  215. package/dist/assets/editor-DO3KuTx4.js.map +0 -1
  216. package/dist/assets/form-input-DTWcBXOv.js +0 -11
  217. package/dist/assets/form-input-DTWcBXOv.js.map +0 -1
  218. package/dist/assets/hmr-DO4QUuY_.js +0 -5
  219. package/dist/assets/hmr-DO4QUuY_.js.map +0 -1
  220. package/dist/assets/hoist-non-react-statics.cjs-BXLrPRPo.js +0 -224
  221. package/dist/assets/hoist-non-react-statics.cjs-BXLrPRPo.js.map +0 -1
  222. package/dist/assets/index-BRK2SPwe.js +0 -92924
  223. package/dist/assets/index-BRK2SPwe.js.map +0 -1
  224. package/dist/assets/index-CwYYkw3b.js +0 -183
  225. package/dist/assets/index-CwYYkw3b.js.map +0 -1
  226. package/dist/assets/index-D9xz2aln.js +0 -25570
  227. package/dist/assets/index-D9xz2aln.js.map +0 -1
  228. package/dist/assets/index-DOrl22sv.css +0 -6263
  229. package/dist/assets/index-DrtoT5He.js +0 -45
  230. package/dist/assets/index-DrtoT5He.js.map +0 -1
  231. package/dist/assets/index-ZC6AHfIK.js +0 -285
  232. package/dist/assets/index-ZC6AHfIK.js.map +0 -1
  233. package/dist/assets/index.esm-BaENpqse.js +0 -1801
  234. package/dist/assets/index.esm-BaENpqse.js.map +0 -1
  235. package/dist/assets/options-x29vXcTw.js +0 -81
  236. package/dist/assets/options-x29vXcTw.js.map +0 -1
  237. package/dist/assets/read-required-modal-CywEDaia.js +0 -44
  238. package/dist/assets/read-required-modal-CywEDaia.js.map +0 -1
  239. package/dist/assets/toggle-CFuMlRt5.js +0 -33
  240. package/dist/assets/toggle-CFuMlRt5.js.map +0 -1
  241. package/dist/assets/virtual_ph_external-packages-DawtJ3DU.js +0 -8
  242. package/dist/assets/virtual_ph_external-packages-DawtJ3DU.js.map +0 -1
  243. package/lib/feature-flags.d.ts.map +0 -1
  244. package/lib/feature-flags.js.map +0 -1
  245. package/lib/src/components/modal/modals/settings/index.d.ts +0 -5
  246. package/lib/src/components/modal/modals/settings/index.d.ts.map +0 -1
  247. package/lib/src/components/modal/modals/settings/index.js +0 -5
  248. package/lib/src/components/modal/modals/settings/index.js.map +0 -1
  249. package/lib/src/components/toast/index.d.ts +0 -2
  250. package/lib/src/components/toast/index.d.ts.map +0 -1
  251. package/lib/src/components/toast/index.js +0 -2
  252. package/lib/src/components/toast/index.js.map +0 -1
  253. package/lib/src/components/toast/reload-connect-toast.d.ts.map +0 -1
  254. package/lib/src/components/toast/reload-connect-toast.js.map +0 -1
  255. package/lib/src/pages/demo/index.d.ts +0 -2
  256. package/lib/src/pages/demo/index.d.ts.map +0 -1
  257. package/lib/src/pages/demo/index.js +0 -2
  258. package/lib/src/pages/demo/index.js.map +0 -1
  259. package/lib/src/services/renown/index.d.ts +0 -4
  260. package/lib/src/services/renown/index.d.ts.map +0 -1
  261. package/lib/src/services/renown/index.js +0 -4
  262. package/lib/src/services/renown/index.js.map +0 -1
  263. package/lib/src/services/storage/index.d.ts +0 -4
  264. package/lib/src/services/storage/index.d.ts.map +0 -1
  265. package/lib/src/services/storage/index.js +0 -4
  266. package/lib/src/services/storage/index.js.map +0 -1
  267. /package/lib/src/components/{toast/reload-connect-toast.d.ts → reload-connect-toast.d.ts} +0 -0
  268. /package/lib/src/components/{toast/reload-connect-toast.js → reload-connect-toast.js} +0 -0
  269. /package/lib/{feature-flags.d.ts → src/feature-flags.d.ts} +0 -0
  270. /package/lib/{feature-flags.js → src/feature-flags.js} +0 -0
@@ -1,45 +0,0 @@
1
- import { aj as clsx } from "./index-BRK2SPwe.js";
2
- const falsyToString = (value) => typeof value === "boolean" ? `${value}` : value === 0 ? "0" : value;
3
- const cx = clsx;
4
- const cva = (base, config) => (props) => {
5
- var _config_compoundVariants;
6
- if ((config === null || config === void 0 ? void 0 : config.variants) == null) return cx(base, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);
7
- const { variants, defaultVariants } = config;
8
- const getVariantClassNames = Object.keys(variants).map((variant) => {
9
- const variantProp = props === null || props === void 0 ? void 0 : props[variant];
10
- const defaultVariantProp = defaultVariants === null || defaultVariants === void 0 ? void 0 : defaultVariants[variant];
11
- if (variantProp === null) return null;
12
- const variantKey = falsyToString(variantProp) || falsyToString(defaultVariantProp);
13
- return variants[variant][variantKey];
14
- });
15
- const propsWithoutUndefined = props && Object.entries(props).reduce((acc, param) => {
16
- let [key, value] = param;
17
- if (value === void 0) {
18
- return acc;
19
- }
20
- acc[key] = value;
21
- return acc;
22
- }, {});
23
- const getCompoundVariantClassNames = config === null || config === void 0 ? void 0 : (_config_compoundVariants = config.compoundVariants) === null || _config_compoundVariants === void 0 ? void 0 : _config_compoundVariants.reduce((acc, param) => {
24
- let { class: cvClass, className: cvClassName, ...compoundVariantOptions } = param;
25
- return Object.entries(compoundVariantOptions).every((param2) => {
26
- let [key, value] = param2;
27
- return Array.isArray(value) ? value.includes({
28
- ...defaultVariants,
29
- ...propsWithoutUndefined
30
- }[key]) : {
31
- ...defaultVariants,
32
- ...propsWithoutUndefined
33
- }[key] === value;
34
- }) ? [
35
- ...acc,
36
- cvClass,
37
- cvClassName
38
- ] : acc;
39
- }, []);
40
- return cx(base, getVariantClassNames, getCompoundVariantClassNames, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);
41
- };
42
- export {
43
- cva as c
44
- };
45
- //# sourceMappingURL=index-DrtoT5He.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-DrtoT5He.js","sources":["../../../../node_modules/.pnpm/class-variance-authority@0.7.1/node_modules/class-variance-authority/dist/index.mjs"],"sourcesContent":["/**\n * Copyright 2022 Joe Bell. All rights reserved.\n *\n * This file is licensed to you under the Apache License, Version 2.0\n * (the \"License\"); you may not use this file except in compliance with the\n * License. You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\n * WARRANTIES OR REPRESENTATIONS OF ANY KIND, either express or implied. See the\n * License for the specific language governing permissions and limitations under\n * the License.\n */ import { clsx } from \"clsx\";\nconst falsyToString = (value)=>typeof value === \"boolean\" ? `${value}` : value === 0 ? \"0\" : value;\nexport const cx = clsx;\nexport const cva = (base, config)=>(props)=>{\n var _config_compoundVariants;\n if ((config === null || config === void 0 ? void 0 : config.variants) == null) return cx(base, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n const { variants, defaultVariants } = config;\n const getVariantClassNames = Object.keys(variants).map((variant)=>{\n const variantProp = props === null || props === void 0 ? void 0 : props[variant];\n const defaultVariantProp = defaultVariants === null || defaultVariants === void 0 ? void 0 : defaultVariants[variant];\n if (variantProp === null) return null;\n const variantKey = falsyToString(variantProp) || falsyToString(defaultVariantProp);\n return variants[variant][variantKey];\n });\n const propsWithoutUndefined = props && Object.entries(props).reduce((acc, param)=>{\n let [key, value] = param;\n if (value === undefined) {\n return acc;\n }\n acc[key] = value;\n return acc;\n }, {});\n const getCompoundVariantClassNames = config === null || config === void 0 ? void 0 : (_config_compoundVariants = config.compoundVariants) === null || _config_compoundVariants === void 0 ? void 0 : _config_compoundVariants.reduce((acc, param)=>{\n let { class: cvClass, className: cvClassName, ...compoundVariantOptions } = param;\n return Object.entries(compoundVariantOptions).every((param)=>{\n let [key, value] = param;\n return Array.isArray(value) ? value.includes({\n ...defaultVariants,\n ...propsWithoutUndefined\n }[key]) : ({\n ...defaultVariants,\n ...propsWithoutUndefined\n })[key] === value;\n }) ? [\n ...acc,\n cvClass,\n cvClassName\n ] : acc;\n }, []);\n return cx(base, getVariantClassNames, getCompoundVariantClassNames, props === null || props === void 0 ? void 0 : props.class, props === null || props === void 0 ? void 0 : props.className);\n };\n\n"],"names":["param"],"mappings":";AAeA,MAAM,gBAAgB,CAAC,UAAQ,OAAO,UAAU,YAAY,GAAG,KAAK,KAAK,UAAU,IAAI,MAAM;AACtF,MAAM,KAAK;AACN,MAAC,MAAM,CAAC,MAAM,WAAS,CAAC,UAAQ;AACpC,MAAI;AACJ,OAAK,WAAW,QAAQ,WAAW,SAAS,SAAS,OAAO,aAAa,KAAM,QAAO,GAAG,MAAM,UAAU,QAAQ,UAAU,SAAS,SAAS,MAAM,OAAO,UAAU,QAAQ,UAAU,SAAS,SAAS,MAAM,SAAS;AACvN,QAAM,EAAE,UAAU,gBAAe,IAAK;AACtC,QAAM,uBAAuB,OAAO,KAAK,QAAQ,EAAE,IAAI,CAAC,YAAU;AAC9D,UAAM,cAAc,UAAU,QAAQ,UAAU,SAAS,SAAS,MAAM,OAAO;AAC/E,UAAM,qBAAqB,oBAAoB,QAAQ,oBAAoB,SAAS,SAAS,gBAAgB,OAAO;AACpH,QAAI,gBAAgB,KAAM,QAAO;AACjC,UAAM,aAAa,cAAc,WAAW,KAAK,cAAc,kBAAkB;AACjF,WAAO,SAAS,OAAO,EAAE,UAAU;AAAA,EACvC,CAAC;AACD,QAAM,wBAAwB,SAAS,OAAO,QAAQ,KAAK,EAAE,OAAO,CAAC,KAAK,UAAQ;AAC9E,QAAI,CAAC,KAAK,KAAK,IAAI;AACnB,QAAI,UAAU,QAAW;AACrB,aAAO;AAAA,IACX;AACA,QAAI,GAAG,IAAI;AACX,WAAO;AAAA,EACX,GAAG,CAAA,CAAE;AACL,QAAM,+BAA+B,WAAW,QAAQ,WAAW,SAAS,UAAU,2BAA2B,OAAO,sBAAsB,QAAQ,6BAA6B,SAAS,SAAS,yBAAyB,OAAO,CAAC,KAAK,UAAQ;AAC/O,QAAI,EAAE,OAAO,SAAS,WAAW,aAAa,GAAG,uBAAsB,IAAK;AAC5E,WAAO,OAAO,QAAQ,sBAAsB,EAAE,MAAM,CAACA,WAAQ;AACzD,UAAI,CAAC,KAAK,KAAK,IAAIA;AACnB,aAAO,MAAM,QAAQ,KAAK,IAAI,MAAM,SAAS;AAAA,QACzC,GAAG;AAAA,QACH,GAAG;AAAA,MACvB,EAAkB,GAAG,CAAC,IAAK;AAAA,QACP,GAAG;AAAA,QACH,GAAG;AAAA,MACvB,EAAmB,GAAG,MAAM;AAAA,IAChB,CAAC,IAAI;AAAA,MACD,GAAG;AAAA,MACH;AAAA,MACA;AAAA,IAChB,IAAgB;AAAA,EACR,GAAG,CAAA,CAAE;AACL,SAAO,GAAG,MAAM,sBAAsB,8BAA8B,UAAU,QAAQ,UAAU,SAAS,SAAS,MAAM,OAAO,UAAU,QAAQ,UAAU,SAAS,SAAS,MAAM,SAAS;AAChM;","x_google_ignoreList":[0]}
@@ -1,285 +0,0 @@
1
- import { eC as createContextScope, R as React, e$ as useComposedRefs, j as jsxRuntimeExports, f5 as createSlot, r as reactExports, a7 as useId, eD as Primitive, eE as composeEventHandlers, eB as useControllableState, eY as useCallbackRef } from "./index-BRK2SPwe.js";
2
- function createCollection(name) {
3
- const PROVIDER_NAME = name + "CollectionProvider";
4
- const [createCollectionContext, createCollectionScope2] = createContextScope(PROVIDER_NAME);
5
- const [CollectionProviderImpl, useCollectionContext] = createCollectionContext(
6
- PROVIDER_NAME,
7
- { collectionRef: { current: null }, itemMap: /* @__PURE__ */ new Map() }
8
- );
9
- const CollectionProvider = (props) => {
10
- const { scope, children } = props;
11
- const ref = React.useRef(null);
12
- const itemMap = React.useRef(/* @__PURE__ */ new Map()).current;
13
- return /* @__PURE__ */ jsxRuntimeExports.jsx(CollectionProviderImpl, { scope, itemMap, collectionRef: ref, children });
14
- };
15
- CollectionProvider.displayName = PROVIDER_NAME;
16
- const COLLECTION_SLOT_NAME = name + "CollectionSlot";
17
- const CollectionSlotImpl = createSlot(COLLECTION_SLOT_NAME);
18
- const CollectionSlot = React.forwardRef(
19
- (props, forwardedRef) => {
20
- const { scope, children } = props;
21
- const context = useCollectionContext(COLLECTION_SLOT_NAME, scope);
22
- const composedRefs = useComposedRefs(forwardedRef, context.collectionRef);
23
- return /* @__PURE__ */ jsxRuntimeExports.jsx(CollectionSlotImpl, { ref: composedRefs, children });
24
- }
25
- );
26
- CollectionSlot.displayName = COLLECTION_SLOT_NAME;
27
- const ITEM_SLOT_NAME = name + "CollectionItemSlot";
28
- const ITEM_DATA_ATTR = "data-radix-collection-item";
29
- const CollectionItemSlotImpl = createSlot(ITEM_SLOT_NAME);
30
- const CollectionItemSlot = React.forwardRef(
31
- (props, forwardedRef) => {
32
- const { scope, children, ...itemData } = props;
33
- const ref = React.useRef(null);
34
- const composedRefs = useComposedRefs(forwardedRef, ref);
35
- const context = useCollectionContext(ITEM_SLOT_NAME, scope);
36
- React.useEffect(() => {
37
- context.itemMap.set(ref, { ref, ...itemData });
38
- return () => void context.itemMap.delete(ref);
39
- });
40
- return /* @__PURE__ */ jsxRuntimeExports.jsx(CollectionItemSlotImpl, { ...{ [ITEM_DATA_ATTR]: "" }, ref: composedRefs, children });
41
- }
42
- );
43
- CollectionItemSlot.displayName = ITEM_SLOT_NAME;
44
- function useCollection2(scope) {
45
- const context = useCollectionContext(name + "CollectionConsumer", scope);
46
- const getItems = React.useCallback(() => {
47
- const collectionNode = context.collectionRef.current;
48
- if (!collectionNode) return [];
49
- const orderedNodes = Array.from(collectionNode.querySelectorAll(`[${ITEM_DATA_ATTR}]`));
50
- const items = Array.from(context.itemMap.values());
51
- const orderedItems = items.sort(
52
- (a, b) => orderedNodes.indexOf(a.ref.current) - orderedNodes.indexOf(b.ref.current)
53
- );
54
- return orderedItems;
55
- }, [context.collectionRef, context.itemMap]);
56
- return getItems;
57
- }
58
- return [
59
- { Provider: CollectionProvider, Slot: CollectionSlot, ItemSlot: CollectionItemSlot },
60
- useCollection2,
61
- createCollectionScope2
62
- ];
63
- }
64
- var DirectionContext = reactExports.createContext(void 0);
65
- function useDirection(localDir) {
66
- const globalDir = reactExports.useContext(DirectionContext);
67
- return localDir || globalDir || "ltr";
68
- }
69
- var ENTRY_FOCUS = "rovingFocusGroup.onEntryFocus";
70
- var EVENT_OPTIONS = { bubbles: false, cancelable: true };
71
- var GROUP_NAME = "RovingFocusGroup";
72
- var [Collection, useCollection, createCollectionScope] = createCollection(GROUP_NAME);
73
- var [createRovingFocusGroupContext, createRovingFocusGroupScope] = createContextScope(
74
- GROUP_NAME,
75
- [createCollectionScope]
76
- );
77
- var [RovingFocusProvider, useRovingFocusContext] = createRovingFocusGroupContext(GROUP_NAME);
78
- var RovingFocusGroup = reactExports.forwardRef(
79
- (props, forwardedRef) => {
80
- return /* @__PURE__ */ jsxRuntimeExports.jsx(Collection.Provider, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ jsxRuntimeExports.jsx(Collection.Slot, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ jsxRuntimeExports.jsx(RovingFocusGroupImpl, { ...props, ref: forwardedRef }) }) });
81
- }
82
- );
83
- RovingFocusGroup.displayName = GROUP_NAME;
84
- var RovingFocusGroupImpl = reactExports.forwardRef((props, forwardedRef) => {
85
- const {
86
- __scopeRovingFocusGroup,
87
- orientation,
88
- loop = false,
89
- dir,
90
- currentTabStopId: currentTabStopIdProp,
91
- defaultCurrentTabStopId,
92
- onCurrentTabStopIdChange,
93
- onEntryFocus,
94
- preventScrollOnEntryFocus = false,
95
- ...groupProps
96
- } = props;
97
- const ref = reactExports.useRef(null);
98
- const composedRefs = useComposedRefs(forwardedRef, ref);
99
- const direction = useDirection(dir);
100
- const [currentTabStopId, setCurrentTabStopId] = useControllableState({
101
- prop: currentTabStopIdProp,
102
- defaultProp: defaultCurrentTabStopId ?? null,
103
- onChange: onCurrentTabStopIdChange,
104
- caller: GROUP_NAME
105
- });
106
- const [isTabbingBackOut, setIsTabbingBackOut] = reactExports.useState(false);
107
- const handleEntryFocus = useCallbackRef(onEntryFocus);
108
- const getItems = useCollection(__scopeRovingFocusGroup);
109
- const isClickFocusRef = reactExports.useRef(false);
110
- const [focusableItemsCount, setFocusableItemsCount] = reactExports.useState(0);
111
- reactExports.useEffect(() => {
112
- const node = ref.current;
113
- if (node) {
114
- node.addEventListener(ENTRY_FOCUS, handleEntryFocus);
115
- return () => node.removeEventListener(ENTRY_FOCUS, handleEntryFocus);
116
- }
117
- }, [handleEntryFocus]);
118
- return /* @__PURE__ */ jsxRuntimeExports.jsx(
119
- RovingFocusProvider,
120
- {
121
- scope: __scopeRovingFocusGroup,
122
- orientation,
123
- dir: direction,
124
- loop,
125
- currentTabStopId,
126
- onItemFocus: reactExports.useCallback(
127
- (tabStopId) => setCurrentTabStopId(tabStopId),
128
- [setCurrentTabStopId]
129
- ),
130
- onItemShiftTab: reactExports.useCallback(() => setIsTabbingBackOut(true), []),
131
- onFocusableItemAdd: reactExports.useCallback(
132
- () => setFocusableItemsCount((prevCount) => prevCount + 1),
133
- []
134
- ),
135
- onFocusableItemRemove: reactExports.useCallback(
136
- () => setFocusableItemsCount((prevCount) => prevCount - 1),
137
- []
138
- ),
139
- children: /* @__PURE__ */ jsxRuntimeExports.jsx(
140
- Primitive.div,
141
- {
142
- tabIndex: isTabbingBackOut || focusableItemsCount === 0 ? -1 : 0,
143
- "data-orientation": orientation,
144
- ...groupProps,
145
- ref: composedRefs,
146
- style: { outline: "none", ...props.style },
147
- onMouseDown: composeEventHandlers(props.onMouseDown, () => {
148
- isClickFocusRef.current = true;
149
- }),
150
- onFocus: composeEventHandlers(props.onFocus, (event) => {
151
- const isKeyboardFocus = !isClickFocusRef.current;
152
- if (event.target === event.currentTarget && isKeyboardFocus && !isTabbingBackOut) {
153
- const entryFocusEvent = new CustomEvent(ENTRY_FOCUS, EVENT_OPTIONS);
154
- event.currentTarget.dispatchEvent(entryFocusEvent);
155
- if (!entryFocusEvent.defaultPrevented) {
156
- const items = getItems().filter((item) => item.focusable);
157
- const activeItem = items.find((item) => item.active);
158
- const currentItem = items.find((item) => item.id === currentTabStopId);
159
- const candidateItems = [activeItem, currentItem, ...items].filter(
160
- Boolean
161
- );
162
- const candidateNodes = candidateItems.map((item) => item.ref.current);
163
- focusFirst(candidateNodes, preventScrollOnEntryFocus);
164
- }
165
- }
166
- isClickFocusRef.current = false;
167
- }),
168
- onBlur: composeEventHandlers(props.onBlur, () => setIsTabbingBackOut(false))
169
- }
170
- )
171
- }
172
- );
173
- });
174
- var ITEM_NAME = "RovingFocusGroupItem";
175
- var RovingFocusGroupItem = reactExports.forwardRef(
176
- (props, forwardedRef) => {
177
- const {
178
- __scopeRovingFocusGroup,
179
- focusable = true,
180
- active = false,
181
- tabStopId,
182
- children,
183
- ...itemProps
184
- } = props;
185
- const autoId = useId();
186
- const id = tabStopId || autoId;
187
- const context = useRovingFocusContext(ITEM_NAME, __scopeRovingFocusGroup);
188
- const isCurrentTabStop = context.currentTabStopId === id;
189
- const getItems = useCollection(__scopeRovingFocusGroup);
190
- const { onFocusableItemAdd, onFocusableItemRemove, currentTabStopId } = context;
191
- reactExports.useEffect(() => {
192
- if (focusable) {
193
- onFocusableItemAdd();
194
- return () => onFocusableItemRemove();
195
- }
196
- }, [focusable, onFocusableItemAdd, onFocusableItemRemove]);
197
- return /* @__PURE__ */ jsxRuntimeExports.jsx(
198
- Collection.ItemSlot,
199
- {
200
- scope: __scopeRovingFocusGroup,
201
- id,
202
- focusable,
203
- active,
204
- children: /* @__PURE__ */ jsxRuntimeExports.jsx(
205
- Primitive.span,
206
- {
207
- tabIndex: isCurrentTabStop ? 0 : -1,
208
- "data-orientation": context.orientation,
209
- ...itemProps,
210
- ref: forwardedRef,
211
- onMouseDown: composeEventHandlers(props.onMouseDown, (event) => {
212
- if (!focusable) event.preventDefault();
213
- else context.onItemFocus(id);
214
- }),
215
- onFocus: composeEventHandlers(props.onFocus, () => context.onItemFocus(id)),
216
- onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {
217
- if (event.key === "Tab" && event.shiftKey) {
218
- context.onItemShiftTab();
219
- return;
220
- }
221
- if (event.target !== event.currentTarget) return;
222
- const focusIntent = getFocusIntent(event, context.orientation, context.dir);
223
- if (focusIntent !== void 0) {
224
- if (event.metaKey || event.ctrlKey || event.altKey || event.shiftKey) return;
225
- event.preventDefault();
226
- const items = getItems().filter((item) => item.focusable);
227
- let candidateNodes = items.map((item) => item.ref.current);
228
- if (focusIntent === "last") candidateNodes.reverse();
229
- else if (focusIntent === "prev" || focusIntent === "next") {
230
- if (focusIntent === "prev") candidateNodes.reverse();
231
- const currentIndex = candidateNodes.indexOf(event.currentTarget);
232
- candidateNodes = context.loop ? wrapArray(candidateNodes, currentIndex + 1) : candidateNodes.slice(currentIndex + 1);
233
- }
234
- setTimeout(() => focusFirst(candidateNodes));
235
- }
236
- }),
237
- children: typeof children === "function" ? children({ isCurrentTabStop, hasTabStop: currentTabStopId != null }) : children
238
- }
239
- )
240
- }
241
- );
242
- }
243
- );
244
- RovingFocusGroupItem.displayName = ITEM_NAME;
245
- var MAP_KEY_TO_FOCUS_INTENT = {
246
- ArrowLeft: "prev",
247
- ArrowUp: "prev",
248
- ArrowRight: "next",
249
- ArrowDown: "next",
250
- PageUp: "first",
251
- Home: "first",
252
- PageDown: "last",
253
- End: "last"
254
- };
255
- function getDirectionAwareKey(key, dir) {
256
- if (dir !== "rtl") return key;
257
- return key === "ArrowLeft" ? "ArrowRight" : key === "ArrowRight" ? "ArrowLeft" : key;
258
- }
259
- function getFocusIntent(event, orientation, dir) {
260
- const key = getDirectionAwareKey(event.key, dir);
261
- if (orientation === "vertical" && ["ArrowLeft", "ArrowRight"].includes(key)) return void 0;
262
- if (orientation === "horizontal" && ["ArrowUp", "ArrowDown"].includes(key)) return void 0;
263
- return MAP_KEY_TO_FOCUS_INTENT[key];
264
- }
265
- function focusFirst(candidates, preventScroll = false) {
266
- const PREVIOUSLY_FOCUSED_ELEMENT = document.activeElement;
267
- for (const candidate of candidates) {
268
- if (candidate === PREVIOUSLY_FOCUSED_ELEMENT) return;
269
- candidate.focus({ preventScroll });
270
- if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT) return;
271
- }
272
- }
273
- function wrapArray(array, startIndex) {
274
- return array.map((_, index) => array[(startIndex + index) % array.length]);
275
- }
276
- var Root = RovingFocusGroup;
277
- var Item = RovingFocusGroupItem;
278
- export {
279
- Item as I,
280
- Root as R,
281
- createCollection as a,
282
- createRovingFocusGroupScope as c,
283
- useDirection as u
284
- };
285
- //# sourceMappingURL=index-ZC6AHfIK.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-ZC6AHfIK.js","sources":["../../../../node_modules/.pnpm/@radix-ui+react-collection@1.1.7_@types+react-dom@19.2.2_@types+react@19.2.2__@types+re_6d7c277722b3619c9ee7e64e9a822c45/node_modules/@radix-ui/react-collection/dist/index.mjs","../../../../node_modules/.pnpm/@radix-ui+react-direction@1.1.1_@types+react@19.2.2_react@19.2.0/node_modules/@radix-ui/react-direction/dist/index.mjs","../../../../node_modules/.pnpm/@radix-ui+react-roving-focus@1.1.11_@types+react-dom@19.2.2_@types+react@19.2.2__@types_24c13f548d57f1c7139d1bdbb746f4d3/node_modules/@radix-ui/react-roving-focus/dist/index.mjs"],"sourcesContent":["\"use client\";\n\n// src/collection-legacy.tsx\nimport React from \"react\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createCollection(name) {\n const PROVIDER_NAME = name + \"CollectionProvider\";\n const [createCollectionContext, createCollectionScope] = createContextScope(PROVIDER_NAME);\n const [CollectionProviderImpl, useCollectionContext] = createCollectionContext(\n PROVIDER_NAME,\n { collectionRef: { current: null }, itemMap: /* @__PURE__ */ new Map() }\n );\n const CollectionProvider = (props) => {\n const { scope, children } = props;\n const ref = React.useRef(null);\n const itemMap = React.useRef(/* @__PURE__ */ new Map()).current;\n return /* @__PURE__ */ jsx(CollectionProviderImpl, { scope, itemMap, collectionRef: ref, children });\n };\n CollectionProvider.displayName = PROVIDER_NAME;\n const COLLECTION_SLOT_NAME = name + \"CollectionSlot\";\n const CollectionSlotImpl = createSlot(COLLECTION_SLOT_NAME);\n const CollectionSlot = React.forwardRef(\n (props, forwardedRef) => {\n const { scope, children } = props;\n const context = useCollectionContext(COLLECTION_SLOT_NAME, scope);\n const composedRefs = useComposedRefs(forwardedRef, context.collectionRef);\n return /* @__PURE__ */ jsx(CollectionSlotImpl, { ref: composedRefs, children });\n }\n );\n CollectionSlot.displayName = COLLECTION_SLOT_NAME;\n const ITEM_SLOT_NAME = name + \"CollectionItemSlot\";\n const ITEM_DATA_ATTR = \"data-radix-collection-item\";\n const CollectionItemSlotImpl = createSlot(ITEM_SLOT_NAME);\n const CollectionItemSlot = React.forwardRef(\n (props, forwardedRef) => {\n const { scope, children, ...itemData } = props;\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const context = useCollectionContext(ITEM_SLOT_NAME, scope);\n React.useEffect(() => {\n context.itemMap.set(ref, { ref, ...itemData });\n return () => void context.itemMap.delete(ref);\n });\n return /* @__PURE__ */ jsx(CollectionItemSlotImpl, { ...{ [ITEM_DATA_ATTR]: \"\" }, ref: composedRefs, children });\n }\n );\n CollectionItemSlot.displayName = ITEM_SLOT_NAME;\n function useCollection(scope) {\n const context = useCollectionContext(name + \"CollectionConsumer\", scope);\n const getItems = React.useCallback(() => {\n const collectionNode = context.collectionRef.current;\n if (!collectionNode) return [];\n const orderedNodes = Array.from(collectionNode.querySelectorAll(`[${ITEM_DATA_ATTR}]`));\n const items = Array.from(context.itemMap.values());\n const orderedItems = items.sort(\n (a, b) => orderedNodes.indexOf(a.ref.current) - orderedNodes.indexOf(b.ref.current)\n );\n return orderedItems;\n }, [context.collectionRef, context.itemMap]);\n return getItems;\n }\n return [\n { Provider: CollectionProvider, Slot: CollectionSlot, ItemSlot: CollectionItemSlot },\n useCollection,\n createCollectionScope\n ];\n}\n\n// src/collection.tsx\nimport React2 from \"react\";\nimport { createContextScope as createContextScope2 } from \"@radix-ui/react-context\";\nimport { useComposedRefs as useComposedRefs2 } from \"@radix-ui/react-compose-refs\";\nimport { createSlot as createSlot2 } from \"@radix-ui/react-slot\";\n\n// src/ordered-dictionary.ts\nvar __instanciated = /* @__PURE__ */ new WeakMap();\nvar OrderedDict = class _OrderedDict extends Map {\n #keys;\n constructor(entries) {\n super(entries);\n this.#keys = [...super.keys()];\n __instanciated.set(this, true);\n }\n set(key, value) {\n if (__instanciated.get(this)) {\n if (this.has(key)) {\n this.#keys[this.#keys.indexOf(key)] = key;\n } else {\n this.#keys.push(key);\n }\n }\n super.set(key, value);\n return this;\n }\n insert(index, key, value) {\n const has = this.has(key);\n const length = this.#keys.length;\n const relativeIndex = toSafeInteger(index);\n let actualIndex = relativeIndex >= 0 ? relativeIndex : length + relativeIndex;\n const safeIndex = actualIndex < 0 || actualIndex >= length ? -1 : actualIndex;\n if (safeIndex === this.size || has && safeIndex === this.size - 1 || safeIndex === -1) {\n this.set(key, value);\n return this;\n }\n const size = this.size + (has ? 0 : 1);\n if (relativeIndex < 0) {\n actualIndex++;\n }\n const keys = [...this.#keys];\n let nextValue;\n let shouldSkip = false;\n for (let i = actualIndex; i < size; i++) {\n if (actualIndex === i) {\n let nextKey = keys[i];\n if (keys[i] === key) {\n nextKey = keys[i + 1];\n }\n if (has) {\n this.delete(key);\n }\n nextValue = this.get(nextKey);\n this.set(key, value);\n } else {\n if (!shouldSkip && keys[i - 1] === key) {\n shouldSkip = true;\n }\n const currentKey = keys[shouldSkip ? i : i - 1];\n const currentValue = nextValue;\n nextValue = this.get(currentKey);\n this.delete(currentKey);\n this.set(currentKey, currentValue);\n }\n }\n return this;\n }\n with(index, key, value) {\n const copy = new _OrderedDict(this);\n copy.insert(index, key, value);\n return copy;\n }\n before(key) {\n const index = this.#keys.indexOf(key) - 1;\n if (index < 0) {\n return void 0;\n }\n return this.entryAt(index);\n }\n /**\n * Sets a new key-value pair at the position before the given key.\n */\n setBefore(key, newKey, value) {\n const index = this.#keys.indexOf(key);\n if (index === -1) {\n return this;\n }\n return this.insert(index, newKey, value);\n }\n after(key) {\n let index = this.#keys.indexOf(key);\n index = index === -1 || index === this.size - 1 ? -1 : index + 1;\n if (index === -1) {\n return void 0;\n }\n return this.entryAt(index);\n }\n /**\n * Sets a new key-value pair at the position after the given key.\n */\n setAfter(key, newKey, value) {\n const index = this.#keys.indexOf(key);\n if (index === -1) {\n return this;\n }\n return this.insert(index + 1, newKey, value);\n }\n first() {\n return this.entryAt(0);\n }\n last() {\n return this.entryAt(-1);\n }\n clear() {\n this.#keys = [];\n return super.clear();\n }\n delete(key) {\n const deleted = super.delete(key);\n if (deleted) {\n this.#keys.splice(this.#keys.indexOf(key), 1);\n }\n return deleted;\n }\n deleteAt(index) {\n const key = this.keyAt(index);\n if (key !== void 0) {\n return this.delete(key);\n }\n return false;\n }\n at(index) {\n const key = at(this.#keys, index);\n if (key !== void 0) {\n return this.get(key);\n }\n }\n entryAt(index) {\n const key = at(this.#keys, index);\n if (key !== void 0) {\n return [key, this.get(key)];\n }\n }\n indexOf(key) {\n return this.#keys.indexOf(key);\n }\n keyAt(index) {\n return at(this.#keys, index);\n }\n from(key, offset) {\n const index = this.indexOf(key);\n if (index === -1) {\n return void 0;\n }\n let dest = index + offset;\n if (dest < 0) dest = 0;\n if (dest >= this.size) dest = this.size - 1;\n return this.at(dest);\n }\n keyFrom(key, offset) {\n const index = this.indexOf(key);\n if (index === -1) {\n return void 0;\n }\n let dest = index + offset;\n if (dest < 0) dest = 0;\n if (dest >= this.size) dest = this.size - 1;\n return this.keyAt(dest);\n }\n find(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return entry;\n }\n index++;\n }\n return void 0;\n }\n findIndex(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return index;\n }\n index++;\n }\n return -1;\n }\n filter(predicate, thisArg) {\n const entries = [];\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n entries.push(entry);\n }\n index++;\n }\n return new _OrderedDict(entries);\n }\n map(callbackfn, thisArg) {\n const entries = [];\n let index = 0;\n for (const entry of this) {\n entries.push([entry[0], Reflect.apply(callbackfn, thisArg, [entry, index, this])]);\n index++;\n }\n return new _OrderedDict(entries);\n }\n reduce(...args) {\n const [callbackfn, initialValue] = args;\n let index = 0;\n let accumulator = initialValue ?? this.at(0);\n for (const entry of this) {\n if (index === 0 && args.length === 1) {\n accumulator = entry;\n } else {\n accumulator = Reflect.apply(callbackfn, this, [accumulator, entry, index, this]);\n }\n index++;\n }\n return accumulator;\n }\n reduceRight(...args) {\n const [callbackfn, initialValue] = args;\n let accumulator = initialValue ?? this.at(-1);\n for (let index = this.size - 1; index >= 0; index--) {\n const entry = this.at(index);\n if (index === this.size - 1 && args.length === 1) {\n accumulator = entry;\n } else {\n accumulator = Reflect.apply(callbackfn, this, [accumulator, entry, index, this]);\n }\n }\n return accumulator;\n }\n toSorted(compareFn) {\n const entries = [...this.entries()].sort(compareFn);\n return new _OrderedDict(entries);\n }\n toReversed() {\n const reversed = new _OrderedDict();\n for (let index = this.size - 1; index >= 0; index--) {\n const key = this.keyAt(index);\n const element = this.get(key);\n reversed.set(key, element);\n }\n return reversed;\n }\n toSpliced(...args) {\n const entries = [...this.entries()];\n entries.splice(...args);\n return new _OrderedDict(entries);\n }\n slice(start, end) {\n const result = new _OrderedDict();\n let stop = this.size - 1;\n if (start === void 0) {\n return result;\n }\n if (start < 0) {\n start = start + this.size;\n }\n if (end !== void 0 && end > 0) {\n stop = end - 1;\n }\n for (let index = start; index <= stop; index++) {\n const key = this.keyAt(index);\n const element = this.get(key);\n result.set(key, element);\n }\n return result;\n }\n every(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (!Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return false;\n }\n index++;\n }\n return true;\n }\n some(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return true;\n }\n index++;\n }\n return false;\n }\n};\nfunction at(array, index) {\n if (\"at\" in Array.prototype) {\n return Array.prototype.at.call(array, index);\n }\n const actualIndex = toSafeIndex(array, index);\n return actualIndex === -1 ? void 0 : array[actualIndex];\n}\nfunction toSafeIndex(array, index) {\n const length = array.length;\n const relativeIndex = toSafeInteger(index);\n const actualIndex = relativeIndex >= 0 ? relativeIndex : length + relativeIndex;\n return actualIndex < 0 || actualIndex >= length ? -1 : actualIndex;\n}\nfunction toSafeInteger(number) {\n return number !== number || number === 0 ? 0 : Math.trunc(number);\n}\n\n// src/collection.tsx\nimport { jsx as jsx2 } from \"react/jsx-runtime\";\nfunction createCollection2(name) {\n const PROVIDER_NAME = name + \"CollectionProvider\";\n const [createCollectionContext, createCollectionScope] = createContextScope2(PROVIDER_NAME);\n const [CollectionContextProvider, useCollectionContext] = createCollectionContext(\n PROVIDER_NAME,\n {\n collectionElement: null,\n collectionRef: { current: null },\n collectionRefObject: { current: null },\n itemMap: new OrderedDict(),\n setItemMap: () => void 0\n }\n );\n const CollectionProvider = ({ state, ...props }) => {\n return state ? /* @__PURE__ */ jsx2(CollectionProviderImpl, { ...props, state }) : /* @__PURE__ */ jsx2(CollectionInit, { ...props });\n };\n CollectionProvider.displayName = PROVIDER_NAME;\n const CollectionInit = (props) => {\n const state = useInitCollection();\n return /* @__PURE__ */ jsx2(CollectionProviderImpl, { ...props, state });\n };\n CollectionInit.displayName = PROVIDER_NAME + \"Init\";\n const CollectionProviderImpl = (props) => {\n const { scope, children, state } = props;\n const ref = React2.useRef(null);\n const [collectionElement, setCollectionElement] = React2.useState(\n null\n );\n const composeRefs = useComposedRefs2(ref, setCollectionElement);\n const [itemMap, setItemMap] = state;\n React2.useEffect(() => {\n if (!collectionElement) return;\n const observer = getChildListObserver(() => {\n });\n observer.observe(collectionElement, {\n childList: true,\n subtree: true\n });\n return () => {\n observer.disconnect();\n };\n }, [collectionElement]);\n return /* @__PURE__ */ jsx2(\n CollectionContextProvider,\n {\n scope,\n itemMap,\n setItemMap,\n collectionRef: composeRefs,\n collectionRefObject: ref,\n collectionElement,\n children\n }\n );\n };\n CollectionProviderImpl.displayName = PROVIDER_NAME + \"Impl\";\n const COLLECTION_SLOT_NAME = name + \"CollectionSlot\";\n const CollectionSlotImpl = createSlot2(COLLECTION_SLOT_NAME);\n const CollectionSlot = React2.forwardRef(\n (props, forwardedRef) => {\n const { scope, children } = props;\n const context = useCollectionContext(COLLECTION_SLOT_NAME, scope);\n const composedRefs = useComposedRefs2(forwardedRef, context.collectionRef);\n return /* @__PURE__ */ jsx2(CollectionSlotImpl, { ref: composedRefs, children });\n }\n );\n CollectionSlot.displayName = COLLECTION_SLOT_NAME;\n const ITEM_SLOT_NAME = name + \"CollectionItemSlot\";\n const ITEM_DATA_ATTR = \"data-radix-collection-item\";\n const CollectionItemSlotImpl = createSlot2(ITEM_SLOT_NAME);\n const CollectionItemSlot = React2.forwardRef(\n (props, forwardedRef) => {\n const { scope, children, ...itemData } = props;\n const ref = React2.useRef(null);\n const [element, setElement] = React2.useState(null);\n const composedRefs = useComposedRefs2(forwardedRef, ref, setElement);\n const context = useCollectionContext(ITEM_SLOT_NAME, scope);\n const { setItemMap } = context;\n const itemDataRef = React2.useRef(itemData);\n if (!shallowEqual(itemDataRef.current, itemData)) {\n itemDataRef.current = itemData;\n }\n const memoizedItemData = itemDataRef.current;\n React2.useEffect(() => {\n const itemData2 = memoizedItemData;\n setItemMap((map) => {\n if (!element) {\n return map;\n }\n if (!map.has(element)) {\n map.set(element, { ...itemData2, element });\n return map.toSorted(sortByDocumentPosition);\n }\n return map.set(element, { ...itemData2, element }).toSorted(sortByDocumentPosition);\n });\n return () => {\n setItemMap((map) => {\n if (!element || !map.has(element)) {\n return map;\n }\n map.delete(element);\n return new OrderedDict(map);\n });\n };\n }, [element, memoizedItemData, setItemMap]);\n return /* @__PURE__ */ jsx2(CollectionItemSlotImpl, { ...{ [ITEM_DATA_ATTR]: \"\" }, ref: composedRefs, children });\n }\n );\n CollectionItemSlot.displayName = ITEM_SLOT_NAME;\n function useInitCollection() {\n return React2.useState(new OrderedDict());\n }\n function useCollection(scope) {\n const { itemMap } = useCollectionContext(name + \"CollectionConsumer\", scope);\n return itemMap;\n }\n const functions = {\n createCollectionScope,\n useCollection,\n useInitCollection\n };\n return [\n { Provider: CollectionProvider, Slot: CollectionSlot, ItemSlot: CollectionItemSlot },\n functions\n ];\n}\nfunction shallowEqual(a, b) {\n if (a === b) return true;\n if (typeof a !== \"object\" || typeof b !== \"object\") return false;\n if (a == null || b == null) return false;\n const keysA = Object.keys(a);\n const keysB = Object.keys(b);\n if (keysA.length !== keysB.length) return false;\n for (const key of keysA) {\n if (!Object.prototype.hasOwnProperty.call(b, key)) return false;\n if (a[key] !== b[key]) return false;\n }\n return true;\n}\nfunction isElementPreceding(a, b) {\n return !!(b.compareDocumentPosition(a) & Node.DOCUMENT_POSITION_PRECEDING);\n}\nfunction sortByDocumentPosition(a, b) {\n return !a[1].element || !b[1].element ? 0 : isElementPreceding(a[1].element, b[1].element) ? -1 : 1;\n}\nfunction getChildListObserver(callback) {\n const observer = new MutationObserver((mutationsList) => {\n for (const mutation of mutationsList) {\n if (mutation.type === \"childList\") {\n callback();\n return;\n }\n }\n });\n return observer;\n}\nexport {\n createCollection,\n createCollection2 as unstable_createCollection\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/direction/src/direction.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nvar DirectionContext = React.createContext(void 0);\nvar DirectionProvider = (props) => {\n const { dir, children } = props;\n return /* @__PURE__ */ jsx(DirectionContext.Provider, { value: dir, children });\n};\nfunction useDirection(localDir) {\n const globalDir = React.useContext(DirectionContext);\n return localDir || globalDir || \"ltr\";\n}\nvar Provider = DirectionProvider;\nexport {\n DirectionProvider,\n Provider,\n useDirection\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/roving-focus-group.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { createCollection } from \"@radix-ui/react-collection\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useDirection } from \"@radix-ui/react-direction\";\nimport { jsx } from \"react/jsx-runtime\";\nvar ENTRY_FOCUS = \"rovingFocusGroup.onEntryFocus\";\nvar EVENT_OPTIONS = { bubbles: false, cancelable: true };\nvar GROUP_NAME = \"RovingFocusGroup\";\nvar [Collection, useCollection, createCollectionScope] = createCollection(GROUP_NAME);\nvar [createRovingFocusGroupContext, createRovingFocusGroupScope] = createContextScope(\n GROUP_NAME,\n [createCollectionScope]\n);\nvar [RovingFocusProvider, useRovingFocusContext] = createRovingFocusGroupContext(GROUP_NAME);\nvar RovingFocusGroup = React.forwardRef(\n (props, forwardedRef) => {\n return /* @__PURE__ */ jsx(Collection.Provider, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ jsx(Collection.Slot, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ jsx(RovingFocusGroupImpl, { ...props, ref: forwardedRef }) }) });\n }\n);\nRovingFocusGroup.displayName = GROUP_NAME;\nvar RovingFocusGroupImpl = React.forwardRef((props, forwardedRef) => {\n const {\n __scopeRovingFocusGroup,\n orientation,\n loop = false,\n dir,\n currentTabStopId: currentTabStopIdProp,\n defaultCurrentTabStopId,\n onCurrentTabStopIdChange,\n onEntryFocus,\n preventScrollOnEntryFocus = false,\n ...groupProps\n } = props;\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const direction = useDirection(dir);\n const [currentTabStopId, setCurrentTabStopId] = useControllableState({\n prop: currentTabStopIdProp,\n defaultProp: defaultCurrentTabStopId ?? null,\n onChange: onCurrentTabStopIdChange,\n caller: GROUP_NAME\n });\n const [isTabbingBackOut, setIsTabbingBackOut] = React.useState(false);\n const handleEntryFocus = useCallbackRef(onEntryFocus);\n const getItems = useCollection(__scopeRovingFocusGroup);\n const isClickFocusRef = React.useRef(false);\n const [focusableItemsCount, setFocusableItemsCount] = React.useState(0);\n React.useEffect(() => {\n const node = ref.current;\n if (node) {\n node.addEventListener(ENTRY_FOCUS, handleEntryFocus);\n return () => node.removeEventListener(ENTRY_FOCUS, handleEntryFocus);\n }\n }, [handleEntryFocus]);\n return /* @__PURE__ */ jsx(\n RovingFocusProvider,\n {\n scope: __scopeRovingFocusGroup,\n orientation,\n dir: direction,\n loop,\n currentTabStopId,\n onItemFocus: React.useCallback(\n (tabStopId) => setCurrentTabStopId(tabStopId),\n [setCurrentTabStopId]\n ),\n onItemShiftTab: React.useCallback(() => setIsTabbingBackOut(true), []),\n onFocusableItemAdd: React.useCallback(\n () => setFocusableItemsCount((prevCount) => prevCount + 1),\n []\n ),\n onFocusableItemRemove: React.useCallback(\n () => setFocusableItemsCount((prevCount) => prevCount - 1),\n []\n ),\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n tabIndex: isTabbingBackOut || focusableItemsCount === 0 ? -1 : 0,\n \"data-orientation\": orientation,\n ...groupProps,\n ref: composedRefs,\n style: { outline: \"none\", ...props.style },\n onMouseDown: composeEventHandlers(props.onMouseDown, () => {\n isClickFocusRef.current = true;\n }),\n onFocus: composeEventHandlers(props.onFocus, (event) => {\n const isKeyboardFocus = !isClickFocusRef.current;\n if (event.target === event.currentTarget && isKeyboardFocus && !isTabbingBackOut) {\n const entryFocusEvent = new CustomEvent(ENTRY_FOCUS, EVENT_OPTIONS);\n event.currentTarget.dispatchEvent(entryFocusEvent);\n if (!entryFocusEvent.defaultPrevented) {\n const items = getItems().filter((item) => item.focusable);\n const activeItem = items.find((item) => item.active);\n const currentItem = items.find((item) => item.id === currentTabStopId);\n const candidateItems = [activeItem, currentItem, ...items].filter(\n Boolean\n );\n const candidateNodes = candidateItems.map((item) => item.ref.current);\n focusFirst(candidateNodes, preventScrollOnEntryFocus);\n }\n }\n isClickFocusRef.current = false;\n }),\n onBlur: composeEventHandlers(props.onBlur, () => setIsTabbingBackOut(false))\n }\n )\n }\n );\n});\nvar ITEM_NAME = \"RovingFocusGroupItem\";\nvar RovingFocusGroupItem = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeRovingFocusGroup,\n focusable = true,\n active = false,\n tabStopId,\n children,\n ...itemProps\n } = props;\n const autoId = useId();\n const id = tabStopId || autoId;\n const context = useRovingFocusContext(ITEM_NAME, __scopeRovingFocusGroup);\n const isCurrentTabStop = context.currentTabStopId === id;\n const getItems = useCollection(__scopeRovingFocusGroup);\n const { onFocusableItemAdd, onFocusableItemRemove, currentTabStopId } = context;\n React.useEffect(() => {\n if (focusable) {\n onFocusableItemAdd();\n return () => onFocusableItemRemove();\n }\n }, [focusable, onFocusableItemAdd, onFocusableItemRemove]);\n return /* @__PURE__ */ jsx(\n Collection.ItemSlot,\n {\n scope: __scopeRovingFocusGroup,\n id,\n focusable,\n active,\n children: /* @__PURE__ */ jsx(\n Primitive.span,\n {\n tabIndex: isCurrentTabStop ? 0 : -1,\n \"data-orientation\": context.orientation,\n ...itemProps,\n ref: forwardedRef,\n onMouseDown: composeEventHandlers(props.onMouseDown, (event) => {\n if (!focusable) event.preventDefault();\n else context.onItemFocus(id);\n }),\n onFocus: composeEventHandlers(props.onFocus, () => context.onItemFocus(id)),\n onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {\n if (event.key === \"Tab\" && event.shiftKey) {\n context.onItemShiftTab();\n return;\n }\n if (event.target !== event.currentTarget) return;\n const focusIntent = getFocusIntent(event, context.orientation, context.dir);\n if (focusIntent !== void 0) {\n if (event.metaKey || event.ctrlKey || event.altKey || event.shiftKey) return;\n event.preventDefault();\n const items = getItems().filter((item) => item.focusable);\n let candidateNodes = items.map((item) => item.ref.current);\n if (focusIntent === \"last\") candidateNodes.reverse();\n else if (focusIntent === \"prev\" || focusIntent === \"next\") {\n if (focusIntent === \"prev\") candidateNodes.reverse();\n const currentIndex = candidateNodes.indexOf(event.currentTarget);\n candidateNodes = context.loop ? wrapArray(candidateNodes, currentIndex + 1) : candidateNodes.slice(currentIndex + 1);\n }\n setTimeout(() => focusFirst(candidateNodes));\n }\n }),\n children: typeof children === \"function\" ? children({ isCurrentTabStop, hasTabStop: currentTabStopId != null }) : children\n }\n )\n }\n );\n }\n);\nRovingFocusGroupItem.displayName = ITEM_NAME;\nvar MAP_KEY_TO_FOCUS_INTENT = {\n ArrowLeft: \"prev\",\n ArrowUp: \"prev\",\n ArrowRight: \"next\",\n ArrowDown: \"next\",\n PageUp: \"first\",\n Home: \"first\",\n PageDown: \"last\",\n End: \"last\"\n};\nfunction getDirectionAwareKey(key, dir) {\n if (dir !== \"rtl\") return key;\n return key === \"ArrowLeft\" ? \"ArrowRight\" : key === \"ArrowRight\" ? \"ArrowLeft\" : key;\n}\nfunction getFocusIntent(event, orientation, dir) {\n const key = getDirectionAwareKey(event.key, dir);\n if (orientation === \"vertical\" && [\"ArrowLeft\", \"ArrowRight\"].includes(key)) return void 0;\n if (orientation === \"horizontal\" && [\"ArrowUp\", \"ArrowDown\"].includes(key)) return void 0;\n return MAP_KEY_TO_FOCUS_INTENT[key];\n}\nfunction focusFirst(candidates, preventScroll = false) {\n const PREVIOUSLY_FOCUSED_ELEMENT = document.activeElement;\n for (const candidate of candidates) {\n if (candidate === PREVIOUSLY_FOCUSED_ELEMENT) return;\n candidate.focus({ preventScroll });\n if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT) return;\n }\n}\nfunction wrapArray(array, startIndex) {\n return array.map((_, index) => array[(startIndex + index) % array.length]);\n}\nvar Root = RovingFocusGroup;\nvar Item = RovingFocusGroupItem;\nexport {\n Item,\n Root,\n RovingFocusGroup,\n RovingFocusGroupItem,\n createRovingFocusGroupScope\n};\n//# sourceMappingURL=index.mjs.map\n"],"names":["createCollectionScope","jsx","useCollection","React.createContext","React.useContext","React.forwardRef","React.useRef","React.useState","React.useEffect","React.useCallback"],"mappings":"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","x_google_ignoreList":[0,1,2]}