@makeswift/runtime 0.10.15 → 0.11.0

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 (152) hide show
  1. package/dist/Box.cjs.js +1 -0
  2. package/dist/Box.cjs.js.map +1 -1
  3. package/dist/Box.es.js +2 -1
  4. package/dist/Box.es.js.map +1 -1
  5. package/dist/Button.cjs.js +1 -0
  6. package/dist/Button.cjs.js.map +1 -1
  7. package/dist/Button.es.js +2 -1
  8. package/dist/Button.es.js.map +1 -1
  9. package/dist/Carousel.cjs.js +1 -0
  10. package/dist/Carousel.cjs.js.map +1 -1
  11. package/dist/Carousel.es.js +2 -1
  12. package/dist/Carousel.es.js.map +1 -1
  13. package/dist/Countdown.cjs.js +1 -0
  14. package/dist/Countdown.cjs.js.map +1 -1
  15. package/dist/Countdown.es.js +2 -1
  16. package/dist/Countdown.es.js.map +1 -1
  17. package/dist/Divider.cjs.js +1 -0
  18. package/dist/Divider.cjs.js.map +1 -1
  19. package/dist/Divider.es.js +2 -1
  20. package/dist/Divider.es.js.map +1 -1
  21. package/dist/Embed.cjs.js +1 -0
  22. package/dist/Embed.cjs.js.map +1 -1
  23. package/dist/Embed.es.js +2 -1
  24. package/dist/Embed.es.js.map +1 -1
  25. package/dist/Form.cjs.js +1 -0
  26. package/dist/Form.cjs.js.map +1 -1
  27. package/dist/Form.es.js +2 -1
  28. package/dist/Form.es.js.map +1 -1
  29. package/dist/Image.cjs.js +1 -0
  30. package/dist/Image.cjs.js.map +1 -1
  31. package/dist/Image.es.js +2 -1
  32. package/dist/Image.es.js.map +1 -1
  33. package/dist/LiveProvider.cjs.js +1 -0
  34. package/dist/LiveProvider.cjs.js.map +1 -1
  35. package/dist/LiveProvider.es.js +2 -1
  36. package/dist/LiveProvider.es.js.map +1 -1
  37. package/dist/Navigation.cjs.js +1 -0
  38. package/dist/Navigation.cjs.js.map +1 -1
  39. package/dist/Navigation.es.js +2 -1
  40. package/dist/Navigation.es.js.map +1 -1
  41. package/dist/PreviewProvider.cjs.js +9 -11
  42. package/dist/PreviewProvider.cjs.js.map +1 -1
  43. package/dist/PreviewProvider.es.js +11 -13
  44. package/dist/PreviewProvider.es.js.map +1 -1
  45. package/dist/ReadOnlyText.cjs.js +1 -0
  46. package/dist/ReadOnlyText.cjs.js.map +1 -1
  47. package/dist/ReadOnlyText.es.js +2 -1
  48. package/dist/ReadOnlyText.es.js.map +1 -1
  49. package/dist/ReadOnlyTextV2.cjs.js +1 -0
  50. package/dist/ReadOnlyTextV2.cjs.js.map +1 -1
  51. package/dist/ReadOnlyTextV2.es.js +2 -1
  52. package/dist/ReadOnlyTextV2.es.js.map +1 -1
  53. package/dist/Root.cjs.js +1 -0
  54. package/dist/Root.cjs.js.map +1 -1
  55. package/dist/Root.es.js +2 -1
  56. package/dist/Root.es.js.map +1 -1
  57. package/dist/SocialLinks.cjs.js +1 -0
  58. package/dist/SocialLinks.cjs.js.map +1 -1
  59. package/dist/SocialLinks.es.js +2 -1
  60. package/dist/SocialLinks.es.js.map +1 -1
  61. package/dist/Video.cjs.js +1 -0
  62. package/dist/Video.cjs.js.map +1 -1
  63. package/dist/Video.es.js +2 -1
  64. package/dist/Video.es.js.map +1 -1
  65. package/dist/actions.cjs.js +8 -14
  66. package/dist/actions.cjs.js.map +1 -1
  67. package/dist/actions.es.js +8 -12
  68. package/dist/actions.es.js.map +1 -1
  69. package/dist/builder.cjs.js +1 -0
  70. package/dist/builder.cjs.js.map +1 -1
  71. package/dist/builder.es.js +1 -0
  72. package/dist/builder.es.js.map +1 -1
  73. package/dist/components.cjs.js +1 -0
  74. package/dist/components.cjs.js.map +1 -1
  75. package/dist/components.es.js +1 -0
  76. package/dist/components.es.js.map +1 -1
  77. package/dist/control-serialization.cjs.js +1 -0
  78. package/dist/control-serialization.cjs.js.map +1 -1
  79. package/dist/control-serialization.es.js +2 -1
  80. package/dist/control-serialization.es.js.map +1 -1
  81. package/dist/controls.cjs.js +1 -0
  82. package/dist/controls.cjs.js.map +1 -1
  83. package/dist/controls.es.js +2 -1
  84. package/dist/controls.es.js.map +1 -1
  85. package/dist/index.cjs.js +19 -19
  86. package/dist/index.cjs.js.map +1 -1
  87. package/dist/index.cjs2.js +1 -0
  88. package/dist/index.cjs2.js.map +1 -1
  89. package/dist/index.cjs8.js +1 -0
  90. package/dist/index.cjs8.js.map +1 -1
  91. package/dist/index.cjs9.js +1 -0
  92. package/dist/index.cjs9.js.map +1 -1
  93. package/dist/index.es.js +21 -21
  94. package/dist/index.es.js.map +1 -1
  95. package/dist/index.es2.js +2 -1
  96. package/dist/index.es2.js.map +1 -1
  97. package/dist/index.es4.js +1 -1
  98. package/dist/index.es5.js +1 -1
  99. package/dist/index.es6.js +1 -1
  100. package/dist/index.es8.js +2 -1
  101. package/dist/index.es8.js.map +1 -1
  102. package/dist/index.es9.js +2 -1
  103. package/dist/index.es9.js.map +1 -1
  104. package/dist/main.cjs.js +2 -1
  105. package/dist/main.cjs.js.map +1 -1
  106. package/dist/main.es.js +2 -1
  107. package/dist/main.es.js.map +1 -1
  108. package/dist/next.cjs.js +1 -0
  109. package/dist/next.cjs.js.map +1 -1
  110. package/dist/next.es.js +1 -0
  111. package/dist/next.es.js.map +1 -1
  112. package/dist/prop-controllers.cjs.js +1 -0
  113. package/dist/prop-controllers.cjs.js.map +1 -1
  114. package/dist/prop-controllers.es.js +1 -0
  115. package/dist/prop-controllers.es.js.map +1 -1
  116. package/dist/react-page.cjs.js +77 -92
  117. package/dist/react-page.cjs.js.map +1 -1
  118. package/dist/react-page.es.js +69 -81
  119. package/dist/react-page.es.js.map +1 -1
  120. package/dist/react.cjs.js +1 -0
  121. package/dist/react.cjs.js.map +1 -1
  122. package/dist/react.es.js +1 -0
  123. package/dist/react.es.js.map +1 -1
  124. package/dist/slate.cjs.js +1 -0
  125. package/dist/slate.cjs.js.map +1 -1
  126. package/dist/slate.es.js +2 -1
  127. package/dist/slate.es.js.map +1 -1
  128. package/dist/toText.cjs.js +1 -0
  129. package/dist/toText.cjs.js.map +1 -1
  130. package/dist/toText.es.js +2 -1
  131. package/dist/toText.es.js.map +1 -1
  132. package/dist/types/src/api/react.d.ts +4 -1
  133. package/dist/types/src/api/react.d.ts.map +1 -1
  134. package/dist/types/src/controls/control.d.ts.map +1 -1
  135. package/dist/types/src/controls/rich-text-v2/translatableData.d.ts +3 -0
  136. package/dist/types/src/controls/rich-text-v2/translatableData.d.ts.map +1 -0
  137. package/dist/types/src/index.d.ts +1 -1
  138. package/dist/types/src/index.d.ts.map +1 -1
  139. package/dist/types/src/next/client.d.ts +3 -2
  140. package/dist/types/src/next/client.d.ts.map +1 -1
  141. package/dist/types/src/runtimes/react/index.d.ts +1 -3
  142. package/dist/types/src/runtimes/react/index.d.ts.map +1 -1
  143. package/dist/types/src/state/actions.d.ts +10 -14
  144. package/dist/types/src/state/actions.d.ts.map +1 -1
  145. package/dist/types/src/state/react-builder-preview.d.ts +1 -3
  146. package/dist/types/src/state/react-builder-preview.d.ts.map +1 -1
  147. package/dist/types/src/state/react-page.d.ts +1 -7
  148. package/dist/types/src/state/react-page.d.ts.map +1 -1
  149. package/dist/types/types/locale.d.ts +1 -1
  150. package/package.json +3 -1
  151. package/dist/types/src/state/modules/locales.d.ts +0 -15
  152. package/dist/types/src/state/modules/locales.d.ts.map +0 -1
package/dist/index.es.js CHANGED
@@ -38,14 +38,15 @@ import * as React from "react";
38
38
  import { useEffect, createContext, useContext, useState, useMemo, useRef, Children, createElement, forwardRef, memo, useId, useCallback, useImperativeHandle, Component, Suspense } from "react";
39
39
  import { useSyncExternalStoreWithSelector } from "use-sync-external-store/shim/with-selector";
40
40
  import dynamic from "next/dynamic";
41
- import { f as deepEqual, g as createDocumentReference, h as getPropControllerDescriptors, j as isElementReference, k as getDefaultLocale, l as getLocales, m as getSwatchIds, n as getFileIds, o as getTypographyIds, p as getTableIds, q as getPageIds, r as getElementChildren, E as ElementID, B as Backgrounds, W as Width, s as ResponsiveIconRadioGroup, M as Margin, P as Padding, t as Border, u as BorderRadius, S as Shadows, G as GapY, v as GapX, w as ResponsiveSelect, x as ResponsiveNumber, y as Checkbox, z as Grid, A as TextInput, L as Link, D as ResponsiveColor, F as TextStyle, C as ComponentIcon, I as Images, N as Number$1, H as Date$1, J as Font, K as ResponsiveLength, O as TextArea, Q as Table, U as TableFormFields, V as Image, X as ResponsiveOpacity, Y as NavigationLinks, Z as SocialLinks, _ as RichText, $ as Video, a0 as useStyle, a1 as getBorderSwatchIds, a2 as getBoxShadowsSwatchIds, a3 as getResponsiveColorSwatchIds, a4 as StyleControlProperty, a5 as ImageControlValueFormat, a6 as isPropControllersHandle, a7 as isRichTextV1Data, a8 as isNonNullable$1, a9 as TypographyControlType, aa as StyleControlType, ab as RichTextV2ControlType, ac as RichTextControlType, ad as SlotControlType, ae as StyleV2ControlType, af as ListControlType, ag as ShapeControlType, ah as LinkControlType, ai as ImageControlType, aj as IconRadioGroupControlType, ak as ColorControlType, al as SelectControlType, am as TextAreaControlType, an as TextInputControlType, ao as getComponentPropControllerDescriptors, ap as getPropControllers, aq as Types, ar as BorderPropControllerFormat, as as ShadowsPropControllerFormat, at as BorderRadiusPropControllerFormat, au as MarginPropControllerFormat, av as PaddingPropControllerFormat, aw as WidthPropControllerFormat, ax as configureStore$1, ay as copyElementTree, az as getBreakpoints, aA as getElementTreeTranslatableData, aB as parseLocalesInput, aC as getDocument, aD as getElementId, aE as getIsInBuilder, aF as getReactComponent, aG as getBuilderEditMode, aH as getIsPreview } from "./react-page.es.js";
42
- import { A as ActionTypes, o as apiResourceFulfilled, p as registerComponentEffect, q as registerReactComponentEffect, t as registerComponentHandleEffect, v as mountComponentEffect } from "./actions.es.js";
41
+ import { f as deepEqual, g as createDocumentReference, h as getPropControllerDescriptors, j as isElementReference, k as getSwatchIds, l as getFileIds, m as getTypographyIds, n as getTableIds, o as getPageIds, p as getElementChildren, E as ElementID, B as Backgrounds, W as Width, q as ResponsiveIconRadioGroup, M as Margin, P as Padding, r as Border, s as BorderRadius, S as Shadows, G as GapY, t as GapX, u as ResponsiveSelect, v as ResponsiveNumber, w as Checkbox, x as Grid, y as TextInput, L as Link, z as ResponsiveColor, A as TextStyle, C as ComponentIcon, I as Images, N as Number$1, D as Date$1, F as Font, H as ResponsiveLength, J as TextArea, K as Table, O as TableFormFields, Q as Image, U as ResponsiveOpacity, V as NavigationLinks, X as SocialLinks, Y as RichText, Z as Video, _ as useStyle, $ as getBorderSwatchIds, a0 as getBoxShadowsSwatchIds, a1 as getResponsiveColorSwatchIds, a2 as StyleControlProperty, a3 as ImageControlValueFormat, a4 as isPropControllersHandle, a5 as isRichTextV1Data, a6 as isNonNullable$1, a7 as TypographyControlType, a8 as StyleControlType, a9 as RichTextV2ControlType, aa as RichTextControlType, ab as SlotControlType, ac as StyleV2ControlType, ad as ListControlType, ae as ShapeControlType, af as LinkControlType, ag as ImageControlType, ah as IconRadioGroupControlType, ai as ColorControlType, aj as SelectControlType, ak as TextAreaControlType, al as TextInputControlType, am as getComponentPropControllerDescriptors, an as getPropControllers, ao as Types, ap as BorderPropControllerFormat, aq as ShadowsPropControllerFormat, ar as BorderRadiusPropControllerFormat, as as MarginPropControllerFormat, at as PaddingPropControllerFormat, au as WidthPropControllerFormat, av as configureStore$1, aw as copyElementTree, ax as getBreakpoints, ay as getElementTreeTranslatableData, az as getDocument, aA as getElementId, aB as getIsInBuilder, aC as getReactComponent, aD as getBuilderEditMode, aE as getIsPreview } from "./react-page.es.js";
42
+ import { A as ActionTypes, n as apiResourceFulfilled, o as registerComponentEffect, p as registerReactComponentEffect, q as registerComponentHandleEffect, t as mountComponentEffect } from "./actions.es.js";
43
43
  import { jsx, jsxs, Fragment } from "react/jsx-runtime";
44
44
  import { N as NumberControlType, C as CheckboxControlType } from "./number.es.js";
45
45
  import { C as ComboboxControlType } from "./combobox.es.js";
46
46
  import { match as match$1, P } from "ts-pattern";
47
47
  import { v4 } from "uuid";
48
48
  import "slate";
49
+ import "escape-html";
49
50
  import { useSyncExternalStore } from "use-sync-external-store/shim";
50
51
  import { createStore, applyMiddleware } from "redux";
51
52
  import thunk from "redux-thunk";
@@ -409,7 +410,10 @@ class MakeswiftClient {
409
410
  if (cacheResult)
410
411
  return cacheResult;
411
412
  const result = await this.makeswiftApiClient.dispatch(fetchAPIResource(APIResourceType.LocalizedGlobalElement, globalElementId, locale));
412
- this.setLocalizedResourceId(globalElementId, (_a = result == null ? void 0 : result.id) != null ? _a : null);
413
+ this.setLocalizedResourceId({
414
+ resourceId: globalElementId,
415
+ localizedResourceId: (_a = result == null ? void 0 : result.id) != null ? _a : null
416
+ });
413
417
  return result;
414
418
  }
415
419
  readPagePathnameSlice(pageId) {
@@ -447,7 +451,10 @@ class MakeswiftClient {
447
451
  var _a;
448
452
  return (_a = this.localizedResourcesMap) == null ? void 0 : _a.get(resourceId);
449
453
  }
450
- setLocalizedResourceId(resourceId, localizedResourceId) {
454
+ setLocalizedResourceId({
455
+ resourceId,
456
+ localizedResourceId
457
+ }) {
451
458
  this.localizedResourcesMap.set(resourceId, localizedResourceId);
452
459
  }
453
460
  }
@@ -992,19 +999,13 @@ Received "${apiKey}" instead.`);
992
999
  }
993
1000
  async getPageSnapshot(pathname, {
994
1001
  preview: previewOverride = false,
995
- unstable_locale
1002
+ locale: localeInput
996
1003
  } = {}) {
997
- var _a, _b, _c;
1004
+ var _a, _b;
998
1005
  const siteVersion = (_a = this.siteVersion) != null ? _a : previewOverride ? MakeswiftSiteVersion.Working : MakeswiftSiteVersion.Live;
999
- const defaultLocale = (_b = getDefaultLocale(this.runtime.store.getState())) == null ? void 0 : _b.toString();
1000
- const locale = unstable_locale === defaultLocale ? null : unstable_locale;
1001
1006
  const searchParams = new URLSearchParams();
1002
- if (locale) {
1003
- const locales = getLocales(this.runtime.store.getState()).map((locale2) => locale2.toString());
1004
- if (!locales.includes(locale)) {
1005
- throw new Error(`Locale "${locale}" is not included in the locales: ${locales}. Please add the locale to the locales on the ReactRuntime.`);
1006
- }
1007
- searchParams.set("locale", locale);
1007
+ if (localeInput) {
1008
+ searchParams.set("locale", localeInput);
1008
1009
  }
1009
1010
  const response = await this.fetch(`/${this.siteVersion == null ? "v2" : "v3"}/pages/${encodeURIComponent(pathname)}/document?${searchParams.toString()}`, {
1010
1011
  headers: { "Makeswift-Site-Version": siteVersion }
@@ -1017,7 +1018,8 @@ Received "${apiKey}" instead.`);
1017
1018
  }
1018
1019
  const document2 = await response.json();
1019
1020
  const baseLocalizedPage = document2.localizedPages.find(({ parentId }) => parentId == null);
1020
- const { cacheData, localizedResourcesMap } = await this.introspect((_c = baseLocalizedPage == null ? void 0 : baseLocalizedPage.data) != null ? _c : document2.data, previewOverride, locale != null ? locale : void 0);
1021
+ const locale = document2.locale;
1022
+ const { cacheData, localizedResourcesMap } = await this.introspect((_b = baseLocalizedPage == null ? void 0 : baseLocalizedPage.data) != null ? _b : document2.data, previewOverride, locale != null ? locale : void 0);
1021
1023
  const apiOrigin = this.apiOrigin.href;
1022
1024
  const preview = siteVersion === MakeswiftSiteVersion.Working;
1023
1025
  return {
@@ -1026,7 +1028,7 @@ Received "${apiKey}" instead.`);
1026
1028
  apiOrigin,
1027
1029
  preview,
1028
1030
  localizedResourcesMap,
1029
- locale: locale != null ? locale : null
1031
+ locale
1030
1032
  };
1031
1033
  }
1032
1034
  async getSwatch(swatchId) {
@@ -1159,7 +1161,7 @@ async function fonts(_req, res, { getFonts } = {}) {
1159
1161
  const fonts2 = (_a = await (getFonts == null ? void 0 : getFonts())) != null ? _a : [];
1160
1162
  return res.json(fonts2);
1161
1163
  }
1162
- const version = "0.10.15";
1164
+ const version = "0.11.0";
1163
1165
  async function handler(req, res, { apiKey, siteVersions }) {
1164
1166
  if (req.query.secret !== apiKey) {
1165
1167
  return res.status(401).json({ message: "Unauthorized" });
@@ -3901,13 +3903,11 @@ function isDomNodeHandle(value) {
3901
3903
  }
3902
3904
  class ReactRuntime {
3903
3905
  constructor({
3904
- breakpoints,
3905
- unstable_i18n
3906
+ breakpoints
3906
3907
  } = {}) {
3907
3908
  __publicField(this, "store");
3908
3909
  this.store = configureStore$1({
3909
- breakpoints: breakpoints ? parseBreakpointsInput(breakpoints) : void 0,
3910
- locales: unstable_i18n ? parseLocalesInput(unstable_i18n) : void 0
3910
+ breakpoints: breakpoints ? parseBreakpointsInput(breakpoints) : void 0
3911
3911
  });
3912
3912
  registerBuiltinComponents(this);
3913
3913
  }