convex-cms 0.0.1 → 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 (267) hide show
  1. package/LICENSE +190 -0
  2. package/README.md +99 -0
  3. package/admin-dist/nitro.json +15 -0
  4. package/admin-dist/public/assets/CmsEmptyState-CRswfTzk.js +5 -0
  5. package/admin-dist/public/assets/CmsPageHeader-CirpXndm.js +1 -0
  6. package/admin-dist/public/assets/CmsStatusBadge-CbEUpQu-.js +1 -0
  7. package/admin-dist/public/assets/CmsToolbar-BI2nZOXp.js +1 -0
  8. package/admin-dist/public/assets/ContentEntryEditor-CBeCyK_m.js +4 -0
  9. package/admin-dist/public/assets/ErrorState-BIVaWmom.js +1 -0
  10. package/admin-dist/public/assets/TaxonomyFilter-ChaY6Y_x.js +1 -0
  11. package/admin-dist/public/assets/_contentTypeId-DQ8k_Rvw.js +1 -0
  12. package/admin-dist/public/assets/_entryId-CKU_glsK.js +1 -0
  13. package/admin-dist/public/assets/alert-BXjTqrwQ.js +1 -0
  14. package/admin-dist/public/assets/badge-hvUOzpVZ.js +1 -0
  15. package/admin-dist/public/assets/circle-check-big-CF_pR17r.js +1 -0
  16. package/admin-dist/public/assets/command-DU82cJlt.js +1 -0
  17. package/admin-dist/public/assets/content-_LXl3pp7.js +1 -0
  18. package/admin-dist/public/assets/content-types-KjxaXGxY.js +2 -0
  19. package/admin-dist/public/assets/globals-CS6BZ0zp.css +1 -0
  20. package/admin-dist/public/assets/index-DNGIZHL-.js +1 -0
  21. package/admin-dist/public/assets/label-KNtpL71g.js +1 -0
  22. package/admin-dist/public/assets/link-2-Bw2aI4V4.js +1 -0
  23. package/admin-dist/public/assets/list-sYepHjt_.js +1 -0
  24. package/admin-dist/public/assets/main-CKj5yfEi.js +97 -0
  25. package/admin-dist/public/assets/media-Bkrkffm7.js +1 -0
  26. package/admin-dist/public/assets/new._contentTypeId-C3LstjNs.js +1 -0
  27. package/admin-dist/public/assets/plus-DUn8v_Xf.js +1 -0
  28. package/admin-dist/public/assets/rotate-ccw-DJEoHcRI.js +1 -0
  29. package/admin-dist/public/assets/scroll-area-DfIlT0in.js +1 -0
  30. package/admin-dist/public/assets/search-MuAUDJKR.js +1 -0
  31. package/admin-dist/public/assets/select-BD29IXCI.js +1 -0
  32. package/admin-dist/public/assets/settings-DmMyn_6A.js +1 -0
  33. package/admin-dist/public/assets/switch-h3Rrnl5i.js +1 -0
  34. package/admin-dist/public/assets/tabs-imc8h-Dp.js +1 -0
  35. package/admin-dist/public/assets/taxonomies-dAsrT65H.js +1 -0
  36. package/admin-dist/public/assets/textarea-BTy7nwzR.js +1 -0
  37. package/admin-dist/public/assets/trash-SAWKZZHv.js +1 -0
  38. package/admin-dist/public/assets/triangle-alert-E52Vfeuh.js +1 -0
  39. package/admin-dist/public/assets/useBreadcrumbLabel-BECBMCzM.js +1 -0
  40. package/admin-dist/public/assets/usePermissions-Basjs9BT.js +1 -0
  41. package/admin-dist/public/favicon.ico +0 -0
  42. package/admin-dist/server/_chunks/_libs/@date-fns/tz.mjs +217 -0
  43. package/admin-dist/server/_chunks/_libs/@floating-ui/core.mjs +719 -0
  44. package/admin-dist/server/_chunks/_libs/@floating-ui/dom.mjs +622 -0
  45. package/admin-dist/server/_chunks/_libs/@floating-ui/react-dom.mjs +292 -0
  46. package/admin-dist/server/_chunks/_libs/@floating-ui/utils.mjs +320 -0
  47. package/admin-dist/server/_chunks/_libs/@radix-ui/number.mjs +6 -0
  48. package/admin-dist/server/_chunks/_libs/@radix-ui/primitive.mjs +11 -0
  49. package/admin-dist/server/_chunks/_libs/@radix-ui/react-arrow.mjs +23 -0
  50. package/admin-dist/server/_chunks/_libs/@radix-ui/react-avatar.mjs +119 -0
  51. package/admin-dist/server/_chunks/_libs/@radix-ui/react-checkbox.mjs +270 -0
  52. package/admin-dist/server/_chunks/_libs/@radix-ui/react-collection.mjs +69 -0
  53. package/admin-dist/server/_chunks/_libs/@radix-ui/react-compose-refs.mjs +39 -0
  54. package/admin-dist/server/_chunks/_libs/@radix-ui/react-context.mjs +137 -0
  55. package/admin-dist/server/_chunks/_libs/@radix-ui/react-dialog.mjs +325 -0
  56. package/admin-dist/server/_chunks/_libs/@radix-ui/react-direction.mjs +9 -0
  57. package/admin-dist/server/_chunks/_libs/@radix-ui/react-dismissable-layer.mjs +210 -0
  58. package/admin-dist/server/_chunks/_libs/@radix-ui/react-dropdown-menu.mjs +253 -0
  59. package/admin-dist/server/_chunks/_libs/@radix-ui/react-focus-guards.mjs +29 -0
  60. package/admin-dist/server/_chunks/_libs/@radix-ui/react-focus-scope.mjs +206 -0
  61. package/admin-dist/server/_chunks/_libs/@radix-ui/react-id.mjs +14 -0
  62. package/admin-dist/server/_chunks/_libs/@radix-ui/react-label.mjs +23 -0
  63. package/admin-dist/server/_chunks/_libs/@radix-ui/react-menu.mjs +812 -0
  64. package/admin-dist/server/_chunks/_libs/@radix-ui/react-popover.mjs +300 -0
  65. package/admin-dist/server/_chunks/_libs/@radix-ui/react-popper.mjs +286 -0
  66. package/admin-dist/server/_chunks/_libs/@radix-ui/react-portal.mjs +16 -0
  67. package/admin-dist/server/_chunks/_libs/@radix-ui/react-presence.mjs +128 -0
  68. package/admin-dist/server/_chunks/_libs/@radix-ui/react-primitive.mjs +141 -0
  69. package/admin-dist/server/_chunks/_libs/@radix-ui/react-roving-focus.mjs +224 -0
  70. package/admin-dist/server/_chunks/_libs/@radix-ui/react-scroll-area.mjs +721 -0
  71. package/admin-dist/server/_chunks/_libs/@radix-ui/react-select.mjs +1163 -0
  72. package/admin-dist/server/_chunks/_libs/@radix-ui/react-separator.mjs +28 -0
  73. package/admin-dist/server/_chunks/_libs/@radix-ui/react-slot.mjs +601 -0
  74. package/admin-dist/server/_chunks/_libs/@radix-ui/react-switch.mjs +152 -0
  75. package/admin-dist/server/_chunks/_libs/@radix-ui/react-tabs.mjs +189 -0
  76. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-callback-ref.mjs +11 -0
  77. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-controllable-state.mjs +69 -0
  78. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-effect-event.mjs +1 -0
  79. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-escape-keydown.mjs +17 -0
  80. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-is-hydrated.mjs +15 -0
  81. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-layout-effect.mjs +6 -0
  82. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-previous.mjs +14 -0
  83. package/admin-dist/server/_chunks/_libs/@radix-ui/react-use-size.mjs +39 -0
  84. package/admin-dist/server/_chunks/_libs/@radix-ui/react-visually-hidden.mjs +33 -0
  85. package/admin-dist/server/_chunks/_libs/@tanstack/history.mjs +409 -0
  86. package/admin-dist/server/_chunks/_libs/@tanstack/react-router.mjs +1711 -0
  87. package/admin-dist/server/_chunks/_libs/@tanstack/react-store.mjs +56 -0
  88. package/admin-dist/server/_chunks/_libs/@tanstack/router-core.mjs +4829 -0
  89. package/admin-dist/server/_chunks/_libs/@tanstack/store.mjs +134 -0
  90. package/admin-dist/server/_chunks/_libs/react-dom.mjs +10781 -0
  91. package/admin-dist/server/_chunks/_libs/react.mjs +513 -0
  92. package/admin-dist/server/_libs/aria-hidden.mjs +122 -0
  93. package/admin-dist/server/_libs/class-variance-authority.mjs +44 -0
  94. package/admin-dist/server/_libs/clsx.mjs +16 -0
  95. package/admin-dist/server/_libs/cmdk.mjs +315 -0
  96. package/admin-dist/server/_libs/convex.mjs +4841 -0
  97. package/admin-dist/server/_libs/cookie-es.mjs +58 -0
  98. package/admin-dist/server/_libs/croner.mjs +1 -0
  99. package/admin-dist/server/_libs/crossws.mjs +1 -0
  100. package/admin-dist/server/_libs/date-fns.mjs +1716 -0
  101. package/admin-dist/server/_libs/detect-node-es.mjs +1 -0
  102. package/admin-dist/server/_libs/get-nonce.mjs +9 -0
  103. package/admin-dist/server/_libs/h3-v2.mjs +277 -0
  104. package/admin-dist/server/_libs/h3.mjs +401 -0
  105. package/admin-dist/server/_libs/hookable.mjs +1 -0
  106. package/admin-dist/server/_libs/isbot.mjs +20 -0
  107. package/admin-dist/server/_libs/lucide-react.mjs +850 -0
  108. package/admin-dist/server/_libs/ohash.mjs +1 -0
  109. package/admin-dist/server/_libs/react-day-picker.mjs +2201 -0
  110. package/admin-dist/server/_libs/react-remove-scroll-bar.mjs +82 -0
  111. package/admin-dist/server/_libs/react-remove-scroll.mjs +328 -0
  112. package/admin-dist/server/_libs/react-style-singleton.mjs +69 -0
  113. package/admin-dist/server/_libs/rou3.mjs +8 -0
  114. package/admin-dist/server/_libs/seroval-plugins.mjs +58 -0
  115. package/admin-dist/server/_libs/seroval.mjs +1765 -0
  116. package/admin-dist/server/_libs/srvx.mjs +719 -0
  117. package/admin-dist/server/_libs/tailwind-merge.mjs +3010 -0
  118. package/admin-dist/server/_libs/tiny-invariant.mjs +12 -0
  119. package/admin-dist/server/_libs/tiny-warning.mjs +5 -0
  120. package/admin-dist/server/_libs/tslib.mjs +39 -0
  121. package/admin-dist/server/_libs/ufo.mjs +54 -0
  122. package/admin-dist/server/_libs/unctx.mjs +1 -0
  123. package/admin-dist/server/_libs/unstorage.mjs +1 -0
  124. package/admin-dist/server/_libs/use-callback-ref.mjs +66 -0
  125. package/admin-dist/server/_libs/use-sidecar.mjs +106 -0
  126. package/admin-dist/server/_libs/use-sync-external-store.mjs +139 -0
  127. package/admin-dist/server/_libs/zod.mjs +4223 -0
  128. package/admin-dist/server/_ssr/CmsEmptyState-DU7-7-mV.mjs +290 -0
  129. package/admin-dist/server/_ssr/CmsPageHeader-CseW0AHm.mjs +24 -0
  130. package/admin-dist/server/_ssr/CmsStatusBadge-B_pi4KCp.mjs +127 -0
  131. package/admin-dist/server/_ssr/CmsToolbar-X75ex6ek.mjs +49 -0
  132. package/admin-dist/server/_ssr/ContentEntryEditor-CepusRsA.mjs +3720 -0
  133. package/admin-dist/server/_ssr/ErrorState-cI-bKLez.mjs +89 -0
  134. package/admin-dist/server/_ssr/TaxonomyFilter-Bwrq0-cz.mjs +188 -0
  135. package/admin-dist/server/_ssr/_contentTypeId-BqYKEcLr.mjs +379 -0
  136. package/admin-dist/server/_ssr/_entryId-CRfnqeDf.mjs +161 -0
  137. package/admin-dist/server/_ssr/_tanstack-start-manifest_v-BwDlABVk.mjs +4 -0
  138. package/admin-dist/server/_ssr/alert-CVt45UUP.mjs +92 -0
  139. package/admin-dist/server/_ssr/badge-6BsP37vG.mjs +125 -0
  140. package/admin-dist/server/_ssr/command-fy8epIKf.mjs +128 -0
  141. package/admin-dist/server/_ssr/config.server-D7JHDcDv.mjs +117 -0
  142. package/admin-dist/server/_ssr/content-B5RhL7uW.mjs +532 -0
  143. package/admin-dist/server/_ssr/content-types-BIOqCQYN.mjs +1166 -0
  144. package/admin-dist/server/_ssr/index-DHSHDPt1.mjs +193 -0
  145. package/admin-dist/server/_ssr/index.mjs +1275 -0
  146. package/admin-dist/server/_ssr/label-C8Dko1j7.mjs +22 -0
  147. package/admin-dist/server/_ssr/media-CSx3XttC.mjs +1832 -0
  148. package/admin-dist/server/_ssr/new._contentTypeId-DzanEZQM.mjs +144 -0
  149. package/admin-dist/server/_ssr/router-DDWcF-kt.mjs +1556 -0
  150. package/admin-dist/server/_ssr/scroll-area-bjPYwhXN.mjs +59 -0
  151. package/admin-dist/server/_ssr/select-BUhDDf4T.mjs +142 -0
  152. package/admin-dist/server/_ssr/settings-DAsxnw2q.mjs +348 -0
  153. package/admin-dist/server/_ssr/start-HYkvq4Ni.mjs +4 -0
  154. package/admin-dist/server/_ssr/switch-BgyRtQ1Z.mjs +31 -0
  155. package/admin-dist/server/_ssr/tabs-DzMdRB1A.mjs +628 -0
  156. package/admin-dist/server/_ssr/taxonomies-C8j8g5Q5.mjs +915 -0
  157. package/admin-dist/server/_ssr/textarea-9jNeYJSc.mjs +18 -0
  158. package/admin-dist/server/_ssr/trash-DYMxwhZB.mjs +291 -0
  159. package/admin-dist/server/_ssr/useBreadcrumbLabel-FNSAr2Ha.mjs +16 -0
  160. package/admin-dist/server/_ssr/usePermissions-BJGGahrJ.mjs +68 -0
  161. package/admin-dist/server/favicon.ico +0 -0
  162. package/admin-dist/server/index.mjs +627 -0
  163. package/dist/cli/index.js +0 -0
  164. package/dist/client/admin-config.d.ts +0 -1
  165. package/dist/client/admin-config.d.ts.map +1 -1
  166. package/dist/client/admin-config.js +0 -1
  167. package/dist/client/admin-config.js.map +1 -1
  168. package/dist/client/adminApi.d.ts.map +1 -1
  169. package/dist/client/agentTools.d.ts +1237 -135
  170. package/dist/client/agentTools.d.ts.map +1 -1
  171. package/dist/client/agentTools.js +33 -9
  172. package/dist/client/agentTools.js.map +1 -1
  173. package/dist/client/index.d.ts +1 -1
  174. package/dist/client/index.d.ts.map +1 -1
  175. package/dist/client/index.js.map +1 -1
  176. package/dist/component/_generated/component.d.ts +9 -0
  177. package/dist/component/_generated/component.d.ts.map +1 -1
  178. package/dist/component/mediaAssets.d.ts +35 -0
  179. package/dist/component/mediaAssets.d.ts.map +1 -1
  180. package/dist/component/mediaAssets.js +81 -0
  181. package/dist/component/mediaAssets.js.map +1 -1
  182. package/dist/test.d.ts.map +1 -1
  183. package/dist/test.js +2 -1
  184. package/dist/test.js.map +1 -1
  185. package/package.json +24 -9
  186. package/dist/component/auditLog.d.ts +0 -410
  187. package/dist/component/auditLog.d.ts.map +0 -1
  188. package/dist/component/auditLog.js +0 -607
  189. package/dist/component/auditLog.js.map +0 -1
  190. package/dist/component/types.d.ts +0 -4
  191. package/dist/component/types.d.ts.map +0 -1
  192. package/dist/component/types.js +0 -2
  193. package/dist/component/types.js.map +0 -1
  194. package/src/cli/commands/admin.ts +0 -104
  195. package/src/cli/index.ts +0 -21
  196. package/src/cli/utils/detectConvexUrl.ts +0 -54
  197. package/src/cli/utils/openBrowser.ts +0 -16
  198. package/src/client/admin-config.ts +0 -138
  199. package/src/client/adminApi.ts +0 -942
  200. package/src/client/agentTools.ts +0 -1311
  201. package/src/client/argTypes.ts +0 -316
  202. package/src/client/field-types.ts +0 -187
  203. package/src/client/index.ts +0 -1301
  204. package/src/client/queryBuilder.ts +0 -1100
  205. package/src/client/schema/codegen.ts +0 -500
  206. package/src/client/schema/defineContentType.ts +0 -501
  207. package/src/client/schema/index.ts +0 -169
  208. package/src/client/schema/schemaDrift.ts +0 -574
  209. package/src/client/schema/typedClient.ts +0 -688
  210. package/src/client/schema/types.ts +0 -666
  211. package/src/client/types.ts +0 -723
  212. package/src/client/workflows.ts +0 -141
  213. package/src/client/wrapper.ts +0 -4304
  214. package/src/component/_generated/api.ts +0 -140
  215. package/src/component/_generated/component.ts +0 -5029
  216. package/src/component/_generated/dataModel.ts +0 -60
  217. package/src/component/_generated/server.ts +0 -156
  218. package/src/component/authorization.ts +0 -647
  219. package/src/component/authorizationHooks.ts +0 -668
  220. package/src/component/bulkOperations.ts +0 -687
  221. package/src/component/contentEntries.ts +0 -1976
  222. package/src/component/contentEntryMutations.ts +0 -1223
  223. package/src/component/contentEntryValidation.ts +0 -707
  224. package/src/component/contentLock.ts +0 -550
  225. package/src/component/contentTypeMigration.ts +0 -1064
  226. package/src/component/contentTypeMutations.ts +0 -969
  227. package/src/component/contentTypes.ts +0 -346
  228. package/src/component/convex.config.ts +0 -44
  229. package/src/component/documentTypes.ts +0 -240
  230. package/src/component/eventEmitter.ts +0 -485
  231. package/src/component/exportImport.ts +0 -1169
  232. package/src/component/index.ts +0 -491
  233. package/src/component/lib/deepReferenceResolver.ts +0 -999
  234. package/src/component/lib/errors.ts +0 -816
  235. package/src/component/lib/index.ts +0 -145
  236. package/src/component/lib/mediaReferenceResolver.ts +0 -495
  237. package/src/component/lib/metadataExtractor.ts +0 -792
  238. package/src/component/lib/mutationAuth.ts +0 -199
  239. package/src/component/lib/queries.ts +0 -79
  240. package/src/component/lib/ragContentChunker.ts +0 -1371
  241. package/src/component/lib/referenceResolver.ts +0 -430
  242. package/src/component/lib/slugGenerator.ts +0 -262
  243. package/src/component/lib/slugUniqueness.ts +0 -333
  244. package/src/component/lib/softDelete.ts +0 -44
  245. package/src/component/localeFallbackChain.ts +0 -673
  246. package/src/component/localeFields.ts +0 -896
  247. package/src/component/mediaAssetMutations.ts +0 -725
  248. package/src/component/mediaAssets.ts +0 -932
  249. package/src/component/mediaFolderMutations.ts +0 -1046
  250. package/src/component/mediaUploadMutations.ts +0 -224
  251. package/src/component/mediaVariantMutations.ts +0 -900
  252. package/src/component/mediaVariants.ts +0 -793
  253. package/src/component/ragContentIndexer.ts +0 -1067
  254. package/src/component/rateLimitHooks.ts +0 -572
  255. package/src/component/roles.ts +0 -1360
  256. package/src/component/scheduledPublish.ts +0 -358
  257. package/src/component/schema.ts +0 -617
  258. package/src/component/taxonomies.ts +0 -949
  259. package/src/component/taxonomyMutations.ts +0 -1210
  260. package/src/component/trash.ts +0 -724
  261. package/src/component/userContext.ts +0 -898
  262. package/src/component/validation.ts +0 -1388
  263. package/src/component/validators.ts +0 -949
  264. package/src/component/versionMutations.ts +0 -392
  265. package/src/component/webhookTrigger.ts +0 -1922
  266. package/src/react/index.ts +0 -898
  267. package/src/test.ts +0 -1580
@@ -0,0 +1,719 @@
1
+ import { g as getSideAxis, a as getAlignmentAxis, b as getSide, c as getAlignment, e as evaluate, d as clamp, f as getOppositePlacement, h as getExpandedPlacements, i as getOppositeAxisPlacements, j as getAlignmentSides, m as min, k as max, l as getAxisLength, n as getPaddingObject, r as rectToClientRect, o as getOppositeAxis, s as sides } from "./utils.mjs";
2
+ function computeCoordsFromPlacement(_ref, placement, rtl) {
3
+ let {
4
+ reference,
5
+ floating
6
+ } = _ref;
7
+ const sideAxis = getSideAxis(placement);
8
+ const alignmentAxis = getAlignmentAxis(placement);
9
+ const alignLength = getAxisLength(alignmentAxis);
10
+ const side = getSide(placement);
11
+ const isVertical = sideAxis === "y";
12
+ const commonX = reference.x + reference.width / 2 - floating.width / 2;
13
+ const commonY = reference.y + reference.height / 2 - floating.height / 2;
14
+ const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;
15
+ let coords;
16
+ switch (side) {
17
+ case "top":
18
+ coords = {
19
+ x: commonX,
20
+ y: reference.y - floating.height
21
+ };
22
+ break;
23
+ case "bottom":
24
+ coords = {
25
+ x: commonX,
26
+ y: reference.y + reference.height
27
+ };
28
+ break;
29
+ case "right":
30
+ coords = {
31
+ x: reference.x + reference.width,
32
+ y: commonY
33
+ };
34
+ break;
35
+ case "left":
36
+ coords = {
37
+ x: reference.x - floating.width,
38
+ y: commonY
39
+ };
40
+ break;
41
+ default:
42
+ coords = {
43
+ x: reference.x,
44
+ y: reference.y
45
+ };
46
+ }
47
+ switch (getAlignment(placement)) {
48
+ case "start":
49
+ coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);
50
+ break;
51
+ case "end":
52
+ coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);
53
+ break;
54
+ }
55
+ return coords;
56
+ }
57
+ const computePosition = async (reference, floating, config) => {
58
+ const {
59
+ placement = "bottom",
60
+ strategy = "absolute",
61
+ middleware = [],
62
+ platform
63
+ } = config;
64
+ const validMiddleware = middleware.filter(Boolean);
65
+ const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));
66
+ let rects = await platform.getElementRects({
67
+ reference,
68
+ floating,
69
+ strategy
70
+ });
71
+ let {
72
+ x,
73
+ y
74
+ } = computeCoordsFromPlacement(rects, placement, rtl);
75
+ let statefulPlacement = placement;
76
+ let middlewareData = {};
77
+ let resetCount = 0;
78
+ for (let i = 0; i < validMiddleware.length; i++) {
79
+ const {
80
+ name,
81
+ fn
82
+ } = validMiddleware[i];
83
+ const {
84
+ x: nextX,
85
+ y: nextY,
86
+ data,
87
+ reset
88
+ } = await fn({
89
+ x,
90
+ y,
91
+ initialPlacement: placement,
92
+ placement: statefulPlacement,
93
+ strategy,
94
+ middlewareData,
95
+ rects,
96
+ platform,
97
+ elements: {
98
+ reference,
99
+ floating
100
+ }
101
+ });
102
+ x = nextX != null ? nextX : x;
103
+ y = nextY != null ? nextY : y;
104
+ middlewareData = {
105
+ ...middlewareData,
106
+ [name]: {
107
+ ...middlewareData[name],
108
+ ...data
109
+ }
110
+ };
111
+ if (reset && resetCount <= 50) {
112
+ resetCount++;
113
+ if (typeof reset === "object") {
114
+ if (reset.placement) {
115
+ statefulPlacement = reset.placement;
116
+ }
117
+ if (reset.rects) {
118
+ rects = reset.rects === true ? await platform.getElementRects({
119
+ reference,
120
+ floating,
121
+ strategy
122
+ }) : reset.rects;
123
+ }
124
+ ({
125
+ x,
126
+ y
127
+ } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));
128
+ }
129
+ i = -1;
130
+ }
131
+ }
132
+ return {
133
+ x,
134
+ y,
135
+ placement: statefulPlacement,
136
+ strategy,
137
+ middlewareData
138
+ };
139
+ };
140
+ async function detectOverflow(state, options) {
141
+ var _await$platform$isEle;
142
+ if (options === void 0) {
143
+ options = {};
144
+ }
145
+ const {
146
+ x,
147
+ y,
148
+ platform,
149
+ rects,
150
+ elements,
151
+ strategy
152
+ } = state;
153
+ const {
154
+ boundary = "clippingAncestors",
155
+ rootBoundary = "viewport",
156
+ elementContext = "floating",
157
+ altBoundary = false,
158
+ padding = 0
159
+ } = evaluate(options, state);
160
+ const paddingObject = getPaddingObject(padding);
161
+ const altContext = elementContext === "floating" ? "reference" : "floating";
162
+ const element = elements[altBoundary ? altContext : elementContext];
163
+ const clippingClientRect = rectToClientRect(await platform.getClippingRect({
164
+ element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating)),
165
+ boundary,
166
+ rootBoundary,
167
+ strategy
168
+ }));
169
+ const rect = elementContext === "floating" ? {
170
+ x,
171
+ y,
172
+ width: rects.floating.width,
173
+ height: rects.floating.height
174
+ } : rects.reference;
175
+ const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));
176
+ const offsetScale = await (platform.isElement == null ? void 0 : platform.isElement(offsetParent)) ? await (platform.getScale == null ? void 0 : platform.getScale(offsetParent)) || {
177
+ x: 1,
178
+ y: 1
179
+ } : {
180
+ x: 1,
181
+ y: 1
182
+ };
183
+ const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({
184
+ elements,
185
+ rect,
186
+ offsetParent,
187
+ strategy
188
+ }) : rect);
189
+ return {
190
+ top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,
191
+ bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,
192
+ left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,
193
+ right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x
194
+ };
195
+ }
196
+ const arrow = (options) => ({
197
+ name: "arrow",
198
+ options,
199
+ async fn(state) {
200
+ const {
201
+ x,
202
+ y,
203
+ placement,
204
+ rects,
205
+ platform,
206
+ elements,
207
+ middlewareData
208
+ } = state;
209
+ const {
210
+ element,
211
+ padding = 0
212
+ } = evaluate(options, state) || {};
213
+ if (element == null) {
214
+ return {};
215
+ }
216
+ const paddingObject = getPaddingObject(padding);
217
+ const coords = {
218
+ x,
219
+ y
220
+ };
221
+ const axis = getAlignmentAxis(placement);
222
+ const length = getAxisLength(axis);
223
+ const arrowDimensions = await platform.getDimensions(element);
224
+ const isYAxis = axis === "y";
225
+ const minProp = isYAxis ? "top" : "left";
226
+ const maxProp = isYAxis ? "bottom" : "right";
227
+ const clientProp = isYAxis ? "clientHeight" : "clientWidth";
228
+ const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];
229
+ const startDiff = coords[axis] - rects.reference[axis];
230
+ const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));
231
+ let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;
232
+ if (!clientSize || !await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent))) {
233
+ clientSize = elements.floating[clientProp] || rects.floating[length];
234
+ }
235
+ const centerToReference = endDiff / 2 - startDiff / 2;
236
+ const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;
237
+ const minPadding = min(paddingObject[minProp], largestPossiblePadding);
238
+ const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);
239
+ const min$1 = minPadding;
240
+ const max2 = clientSize - arrowDimensions[length] - maxPadding;
241
+ const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;
242
+ const offset2 = clamp(min$1, center, max2);
243
+ const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center !== offset2 && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;
244
+ const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max2 : 0;
245
+ return {
246
+ [axis]: coords[axis] + alignmentOffset,
247
+ data: {
248
+ [axis]: offset2,
249
+ centerOffset: center - offset2 - alignmentOffset,
250
+ ...shouldAddOffset && {
251
+ alignmentOffset
252
+ }
253
+ },
254
+ reset: shouldAddOffset
255
+ };
256
+ }
257
+ });
258
+ const flip = function(options) {
259
+ if (options === void 0) {
260
+ options = {};
261
+ }
262
+ return {
263
+ name: "flip",
264
+ options,
265
+ async fn(state) {
266
+ var _middlewareData$arrow, _middlewareData$flip;
267
+ const {
268
+ placement,
269
+ middlewareData,
270
+ rects,
271
+ initialPlacement,
272
+ platform,
273
+ elements
274
+ } = state;
275
+ const {
276
+ mainAxis: checkMainAxis = true,
277
+ crossAxis: checkCrossAxis = true,
278
+ fallbackPlacements: specifiedFallbackPlacements,
279
+ fallbackStrategy = "bestFit",
280
+ fallbackAxisSideDirection = "none",
281
+ flipAlignment = true,
282
+ ...detectOverflowOptions
283
+ } = evaluate(options, state);
284
+ if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {
285
+ return {};
286
+ }
287
+ const side = getSide(placement);
288
+ const initialSideAxis = getSideAxis(initialPlacement);
289
+ const isBasePlacement = getSide(initialPlacement) === initialPlacement;
290
+ const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));
291
+ const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));
292
+ const hasFallbackAxisSideDirection = fallbackAxisSideDirection !== "none";
293
+ if (!specifiedFallbackPlacements && hasFallbackAxisSideDirection) {
294
+ fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));
295
+ }
296
+ const placements = [initialPlacement, ...fallbackPlacements];
297
+ const overflow = await detectOverflow(state, detectOverflowOptions);
298
+ const overflows = [];
299
+ let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];
300
+ if (checkMainAxis) {
301
+ overflows.push(overflow[side]);
302
+ }
303
+ if (checkCrossAxis) {
304
+ const sides2 = getAlignmentSides(placement, rects, rtl);
305
+ overflows.push(overflow[sides2[0]], overflow[sides2[1]]);
306
+ }
307
+ overflowsData = [...overflowsData, {
308
+ placement,
309
+ overflows
310
+ }];
311
+ if (!overflows.every((side2) => side2 <= 0)) {
312
+ var _middlewareData$flip2, _overflowsData$filter;
313
+ const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;
314
+ const nextPlacement = placements[nextIndex];
315
+ if (nextPlacement) {
316
+ const ignoreCrossAxisOverflow = checkCrossAxis === "alignment" ? initialSideAxis !== getSideAxis(nextPlacement) : false;
317
+ if (!ignoreCrossAxisOverflow || // We leave the current main axis only if every placement on that axis
318
+ // overflows the main axis.
319
+ overflowsData.every((d) => getSideAxis(d.placement) === initialSideAxis ? d.overflows[0] > 0 : true)) {
320
+ return {
321
+ data: {
322
+ index: nextIndex,
323
+ overflows: overflowsData
324
+ },
325
+ reset: {
326
+ placement: nextPlacement
327
+ }
328
+ };
329
+ }
330
+ }
331
+ let resetPlacement = (_overflowsData$filter = overflowsData.filter((d) => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;
332
+ if (!resetPlacement) {
333
+ switch (fallbackStrategy) {
334
+ case "bestFit": {
335
+ var _overflowsData$filter2;
336
+ const placement2 = (_overflowsData$filter2 = overflowsData.filter((d) => {
337
+ if (hasFallbackAxisSideDirection) {
338
+ const currentSideAxis = getSideAxis(d.placement);
339
+ return currentSideAxis === initialSideAxis || // Create a bias to the `y` side axis due to horizontal
340
+ // reading directions favoring greater width.
341
+ currentSideAxis === "y";
342
+ }
343
+ return true;
344
+ }).map((d) => [d.placement, d.overflows.filter((overflow2) => overflow2 > 0).reduce((acc, overflow2) => acc + overflow2, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$filter2[0];
345
+ if (placement2) {
346
+ resetPlacement = placement2;
347
+ }
348
+ break;
349
+ }
350
+ case "initialPlacement":
351
+ resetPlacement = initialPlacement;
352
+ break;
353
+ }
354
+ }
355
+ if (placement !== resetPlacement) {
356
+ return {
357
+ reset: {
358
+ placement: resetPlacement
359
+ }
360
+ };
361
+ }
362
+ }
363
+ return {};
364
+ }
365
+ };
366
+ };
367
+ function getSideOffsets(overflow, rect) {
368
+ return {
369
+ top: overflow.top - rect.height,
370
+ right: overflow.right - rect.width,
371
+ bottom: overflow.bottom - rect.height,
372
+ left: overflow.left - rect.width
373
+ };
374
+ }
375
+ function isAnySideFullyClipped(overflow) {
376
+ return sides.some((side) => overflow[side] >= 0);
377
+ }
378
+ const hide = function(options) {
379
+ if (options === void 0) {
380
+ options = {};
381
+ }
382
+ return {
383
+ name: "hide",
384
+ options,
385
+ async fn(state) {
386
+ const {
387
+ rects
388
+ } = state;
389
+ const {
390
+ strategy = "referenceHidden",
391
+ ...detectOverflowOptions
392
+ } = evaluate(options, state);
393
+ switch (strategy) {
394
+ case "referenceHidden": {
395
+ const overflow = await detectOverflow(state, {
396
+ ...detectOverflowOptions,
397
+ elementContext: "reference"
398
+ });
399
+ const offsets = getSideOffsets(overflow, rects.reference);
400
+ return {
401
+ data: {
402
+ referenceHiddenOffsets: offsets,
403
+ referenceHidden: isAnySideFullyClipped(offsets)
404
+ }
405
+ };
406
+ }
407
+ case "escaped": {
408
+ const overflow = await detectOverflow(state, {
409
+ ...detectOverflowOptions,
410
+ altBoundary: true
411
+ });
412
+ const offsets = getSideOffsets(overflow, rects.floating);
413
+ return {
414
+ data: {
415
+ escapedOffsets: offsets,
416
+ escaped: isAnySideFullyClipped(offsets)
417
+ }
418
+ };
419
+ }
420
+ default: {
421
+ return {};
422
+ }
423
+ }
424
+ }
425
+ };
426
+ };
427
+ const originSides = /* @__PURE__ */ new Set(["left", "top"]);
428
+ async function convertValueToCoords(state, options) {
429
+ const {
430
+ placement,
431
+ platform,
432
+ elements
433
+ } = state;
434
+ const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));
435
+ const side = getSide(placement);
436
+ const alignment = getAlignment(placement);
437
+ const isVertical = getSideAxis(placement) === "y";
438
+ const mainAxisMulti = originSides.has(side) ? -1 : 1;
439
+ const crossAxisMulti = rtl && isVertical ? -1 : 1;
440
+ const rawValue = evaluate(options, state);
441
+ let {
442
+ mainAxis,
443
+ crossAxis,
444
+ alignmentAxis
445
+ } = typeof rawValue === "number" ? {
446
+ mainAxis: rawValue,
447
+ crossAxis: 0,
448
+ alignmentAxis: null
449
+ } : {
450
+ mainAxis: rawValue.mainAxis || 0,
451
+ crossAxis: rawValue.crossAxis || 0,
452
+ alignmentAxis: rawValue.alignmentAxis
453
+ };
454
+ if (alignment && typeof alignmentAxis === "number") {
455
+ crossAxis = alignment === "end" ? alignmentAxis * -1 : alignmentAxis;
456
+ }
457
+ return isVertical ? {
458
+ x: crossAxis * crossAxisMulti,
459
+ y: mainAxis * mainAxisMulti
460
+ } : {
461
+ x: mainAxis * mainAxisMulti,
462
+ y: crossAxis * crossAxisMulti
463
+ };
464
+ }
465
+ const offset = function(options) {
466
+ if (options === void 0) {
467
+ options = 0;
468
+ }
469
+ return {
470
+ name: "offset",
471
+ options,
472
+ async fn(state) {
473
+ var _middlewareData$offse, _middlewareData$arrow;
474
+ const {
475
+ x,
476
+ y,
477
+ placement,
478
+ middlewareData
479
+ } = state;
480
+ const diffCoords = await convertValueToCoords(state, options);
481
+ if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {
482
+ return {};
483
+ }
484
+ return {
485
+ x: x + diffCoords.x,
486
+ y: y + diffCoords.y,
487
+ data: {
488
+ ...diffCoords,
489
+ placement
490
+ }
491
+ };
492
+ }
493
+ };
494
+ };
495
+ const shift = function(options) {
496
+ if (options === void 0) {
497
+ options = {};
498
+ }
499
+ return {
500
+ name: "shift",
501
+ options,
502
+ async fn(state) {
503
+ const {
504
+ x,
505
+ y,
506
+ placement
507
+ } = state;
508
+ const {
509
+ mainAxis: checkMainAxis = true,
510
+ crossAxis: checkCrossAxis = false,
511
+ limiter = {
512
+ fn: (_ref) => {
513
+ let {
514
+ x: x2,
515
+ y: y2
516
+ } = _ref;
517
+ return {
518
+ x: x2,
519
+ y: y2
520
+ };
521
+ }
522
+ },
523
+ ...detectOverflowOptions
524
+ } = evaluate(options, state);
525
+ const coords = {
526
+ x,
527
+ y
528
+ };
529
+ const overflow = await detectOverflow(state, detectOverflowOptions);
530
+ const crossAxis = getSideAxis(getSide(placement));
531
+ const mainAxis = getOppositeAxis(crossAxis);
532
+ let mainAxisCoord = coords[mainAxis];
533
+ let crossAxisCoord = coords[crossAxis];
534
+ if (checkMainAxis) {
535
+ const minSide = mainAxis === "y" ? "top" : "left";
536
+ const maxSide = mainAxis === "y" ? "bottom" : "right";
537
+ const min2 = mainAxisCoord + overflow[minSide];
538
+ const max2 = mainAxisCoord - overflow[maxSide];
539
+ mainAxisCoord = clamp(min2, mainAxisCoord, max2);
540
+ }
541
+ if (checkCrossAxis) {
542
+ const minSide = crossAxis === "y" ? "top" : "left";
543
+ const maxSide = crossAxis === "y" ? "bottom" : "right";
544
+ const min2 = crossAxisCoord + overflow[minSide];
545
+ const max2 = crossAxisCoord - overflow[maxSide];
546
+ crossAxisCoord = clamp(min2, crossAxisCoord, max2);
547
+ }
548
+ const limitedCoords = limiter.fn({
549
+ ...state,
550
+ [mainAxis]: mainAxisCoord,
551
+ [crossAxis]: crossAxisCoord
552
+ });
553
+ return {
554
+ ...limitedCoords,
555
+ data: {
556
+ x: limitedCoords.x - x,
557
+ y: limitedCoords.y - y,
558
+ enabled: {
559
+ [mainAxis]: checkMainAxis,
560
+ [crossAxis]: checkCrossAxis
561
+ }
562
+ }
563
+ };
564
+ }
565
+ };
566
+ };
567
+ const limitShift = function(options) {
568
+ if (options === void 0) {
569
+ options = {};
570
+ }
571
+ return {
572
+ options,
573
+ fn(state) {
574
+ const {
575
+ x,
576
+ y,
577
+ placement,
578
+ rects,
579
+ middlewareData
580
+ } = state;
581
+ const {
582
+ offset: offset2 = 0,
583
+ mainAxis: checkMainAxis = true,
584
+ crossAxis: checkCrossAxis = true
585
+ } = evaluate(options, state);
586
+ const coords = {
587
+ x,
588
+ y
589
+ };
590
+ const crossAxis = getSideAxis(placement);
591
+ const mainAxis = getOppositeAxis(crossAxis);
592
+ let mainAxisCoord = coords[mainAxis];
593
+ let crossAxisCoord = coords[crossAxis];
594
+ const rawOffset = evaluate(offset2, state);
595
+ const computedOffset = typeof rawOffset === "number" ? {
596
+ mainAxis: rawOffset,
597
+ crossAxis: 0
598
+ } : {
599
+ mainAxis: 0,
600
+ crossAxis: 0,
601
+ ...rawOffset
602
+ };
603
+ if (checkMainAxis) {
604
+ const len = mainAxis === "y" ? "height" : "width";
605
+ const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;
606
+ const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;
607
+ if (mainAxisCoord < limitMin) {
608
+ mainAxisCoord = limitMin;
609
+ } else if (mainAxisCoord > limitMax) {
610
+ mainAxisCoord = limitMax;
611
+ }
612
+ }
613
+ if (checkCrossAxis) {
614
+ var _middlewareData$offse, _middlewareData$offse2;
615
+ const len = mainAxis === "y" ? "width" : "height";
616
+ const isOriginSide = originSides.has(getSide(placement));
617
+ const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);
618
+ const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);
619
+ if (crossAxisCoord < limitMin) {
620
+ crossAxisCoord = limitMin;
621
+ } else if (crossAxisCoord > limitMax) {
622
+ crossAxisCoord = limitMax;
623
+ }
624
+ }
625
+ return {
626
+ [mainAxis]: mainAxisCoord,
627
+ [crossAxis]: crossAxisCoord
628
+ };
629
+ }
630
+ };
631
+ };
632
+ const size = function(options) {
633
+ if (options === void 0) {
634
+ options = {};
635
+ }
636
+ return {
637
+ name: "size",
638
+ options,
639
+ async fn(state) {
640
+ var _state$middlewareData, _state$middlewareData2;
641
+ const {
642
+ placement,
643
+ rects,
644
+ platform,
645
+ elements
646
+ } = state;
647
+ const {
648
+ apply = () => {
649
+ },
650
+ ...detectOverflowOptions
651
+ } = evaluate(options, state);
652
+ const overflow = await detectOverflow(state, detectOverflowOptions);
653
+ const side = getSide(placement);
654
+ const alignment = getAlignment(placement);
655
+ const isYAxis = getSideAxis(placement) === "y";
656
+ const {
657
+ width,
658
+ height
659
+ } = rects.floating;
660
+ let heightSide;
661
+ let widthSide;
662
+ if (side === "top" || side === "bottom") {
663
+ heightSide = side;
664
+ widthSide = alignment === (await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)) ? "start" : "end") ? "left" : "right";
665
+ } else {
666
+ widthSide = side;
667
+ heightSide = alignment === "end" ? "top" : "bottom";
668
+ }
669
+ const maximumClippingHeight = height - overflow.top - overflow.bottom;
670
+ const maximumClippingWidth = width - overflow.left - overflow.right;
671
+ const overflowAvailableHeight = min(height - overflow[heightSide], maximumClippingHeight);
672
+ const overflowAvailableWidth = min(width - overflow[widthSide], maximumClippingWidth);
673
+ const noShift = !state.middlewareData.shift;
674
+ let availableHeight = overflowAvailableHeight;
675
+ let availableWidth = overflowAvailableWidth;
676
+ if ((_state$middlewareData = state.middlewareData.shift) != null && _state$middlewareData.enabled.x) {
677
+ availableWidth = maximumClippingWidth;
678
+ }
679
+ if ((_state$middlewareData2 = state.middlewareData.shift) != null && _state$middlewareData2.enabled.y) {
680
+ availableHeight = maximumClippingHeight;
681
+ }
682
+ if (noShift && !alignment) {
683
+ const xMin = max(overflow.left, 0);
684
+ const xMax = max(overflow.right, 0);
685
+ const yMin = max(overflow.top, 0);
686
+ const yMax = max(overflow.bottom, 0);
687
+ if (isYAxis) {
688
+ availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));
689
+ } else {
690
+ availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));
691
+ }
692
+ }
693
+ await apply({
694
+ ...state,
695
+ availableWidth,
696
+ availableHeight
697
+ });
698
+ const nextDimensions = await platform.getDimensions(elements.floating);
699
+ if (width !== nextDimensions.width || height !== nextDimensions.height) {
700
+ return {
701
+ reset: {
702
+ rects: true
703
+ }
704
+ };
705
+ }
706
+ return {};
707
+ }
708
+ };
709
+ };
710
+ export {
711
+ size as a,
712
+ arrow as b,
713
+ computePosition as c,
714
+ flip as f,
715
+ hide as h,
716
+ limitShift as l,
717
+ offset as o,
718
+ shift as s
719
+ };