@makeswift/runtime 0.24.0-canary.0 → 0.24.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 (484) hide show
  1. package/dist/cjs/api/react.js +28 -7
  2. package/dist/cjs/api/react.js.map +1 -1
  3. package/dist/cjs/api/site-version.js +36 -0
  4. package/dist/cjs/api/site-version.js.map +1 -0
  5. package/dist/cjs/components/builtin/Box/register.js +3 -3
  6. package/dist/cjs/components/builtin/Box/register.js.map +1 -1
  7. package/dist/cjs/components/builtin/Button/register.js +2 -2
  8. package/dist/cjs/components/builtin/Button/register.js.map +1 -1
  9. package/dist/cjs/components/builtin/Carousel/Carousel.js +6 -5
  10. package/dist/cjs/components/builtin/Carousel/Carousel.js.map +1 -1
  11. package/dist/cjs/components/builtin/Carousel/register.js +2 -2
  12. package/dist/cjs/components/builtin/Carousel/register.js.map +1 -1
  13. package/dist/cjs/components/builtin/Countdown/register.js +2 -2
  14. package/dist/cjs/components/builtin/Countdown/register.js.map +1 -1
  15. package/dist/cjs/components/builtin/Form/register.js +4 -4
  16. package/dist/cjs/components/builtin/Form/register.js.map +1 -1
  17. package/dist/cjs/components/builtin/Image/Image.js +3 -3
  18. package/dist/cjs/components/builtin/Image/Image.js.map +1 -1
  19. package/dist/cjs/components/builtin/Navigation/register.js +4 -4
  20. package/dist/cjs/components/builtin/Navigation/register.js.map +1 -1
  21. package/dist/cjs/components/builtin/SocialLinks/register.js +3 -3
  22. package/dist/cjs/components/builtin/SocialLinks/register.js.map +1 -1
  23. package/dist/cjs/components/builtin/Text/register.js +3 -3
  24. package/dist/cjs/components/builtin/Text/register.js.map +1 -1
  25. package/dist/cjs/components/hooks/useMediaQuery.js +5 -5
  26. package/dist/cjs/components/hooks/useMediaQuery.js.map +1 -1
  27. package/dist/cjs/components/page/Page.js +7 -4
  28. package/dist/cjs/components/page/Page.js.map +1 -1
  29. package/dist/cjs/components/page/PageHead.js +17 -8
  30. package/dist/cjs/components/page/PageHead.js.map +1 -1
  31. package/dist/cjs/components/page/page-seo-settings.js +43 -0
  32. package/dist/cjs/components/page/page-seo-settings.js.map +1 -0
  33. package/dist/cjs/components/shared/Link/index.js +3 -1
  34. package/dist/cjs/components/shared/Link/index.js.map +1 -1
  35. package/dist/cjs/components/utils/responsive-style.js +2 -3
  36. package/dist/cjs/components/utils/responsive-style.js.map +1 -1
  37. package/dist/cjs/core/index.js +18 -2
  38. package/dist/cjs/core/index.js.map +1 -1
  39. package/dist/cjs/jest-setup.js +3 -0
  40. package/dist/cjs/jest-setup.js.map +1 -1
  41. package/dist/cjs/locale.js +79 -0
  42. package/dist/cjs/locale.js.map +1 -1
  43. package/dist/cjs/next/api-handler/handlers/clear-draft.js +64 -0
  44. package/dist/cjs/next/api-handler/handlers/clear-draft.js.map +1 -0
  45. package/dist/cjs/next/api-handler/handlers/manifest.js +3 -2
  46. package/dist/cjs/next/api-handler/handlers/manifest.js.map +1 -1
  47. package/dist/cjs/next/api-handler/handlers/redirect-draft.js +77 -0
  48. package/dist/cjs/next/api-handler/handlers/redirect-draft.js.map +1 -0
  49. package/dist/cjs/next/api-handler/handlers/redirect-preview.js +67 -0
  50. package/dist/cjs/next/api-handler/handlers/redirect-preview.js.map +1 -0
  51. package/dist/cjs/next/api-handler/handlers/utils/draft.js +53 -0
  52. package/dist/cjs/next/api-handler/handlers/utils/draft.js.map +1 -0
  53. package/dist/cjs/next/api-handler/handlers/webhook/index.js +3 -3
  54. package/dist/cjs/next/api-handler/handlers/webhook/index.js.map +1 -1
  55. package/dist/cjs/next/api-handler/handlers/webhook/site-published.js +8 -5
  56. package/dist/cjs/next/api-handler/handlers/webhook/site-published.js.map +1 -1
  57. package/dist/cjs/next/api-handler/handlers/webhook/types.js.map +1 -1
  58. package/dist/cjs/next/api-handler/index.js +24 -9
  59. package/dist/cjs/next/api-handler/index.js.map +1 -1
  60. package/dist/cjs/next/cache.js +29 -0
  61. package/dist/cjs/next/cache.js.map +1 -0
  62. package/dist/cjs/next/client.js +135 -60
  63. package/dist/cjs/next/client.js.map +1 -1
  64. package/dist/cjs/next/components/page.js +3 -2
  65. package/dist/cjs/next/components/page.js.map +1 -1
  66. package/dist/cjs/next/components/tests/controls/color-control/fixtures.js +51 -0
  67. package/dist/cjs/next/components/tests/controls/color-control/fixtures.js.map +1 -0
  68. package/dist/cjs/next/components/tests/controls/page-control-prop-rendering.js +91 -35
  69. package/dist/cjs/next/components/tests/controls/page-control-prop-rendering.js.map +1 -1
  70. package/dist/cjs/next/components/tests/controls/rich-text-v2-control/fixtures.js +91 -0
  71. package/dist/cjs/next/components/tests/controls/rich-text-v2-control/fixtures.js.map +1 -0
  72. package/dist/cjs/next/components/tests/controls/style-control/fixtures.js +60 -0
  73. package/dist/cjs/next/components/tests/controls/style-control/fixtures.js.map +1 -0
  74. package/dist/cjs/next/components/tests/prop-controllers/page-prop-controller.js +20 -11
  75. package/dist/cjs/next/components/tests/prop-controllers/page-prop-controller.js.map +1 -1
  76. package/dist/cjs/next/document.js +1 -3
  77. package/dist/cjs/next/document.js.map +1 -1
  78. package/dist/cjs/next/draft-mode/index.js +3 -3
  79. package/dist/cjs/next/draft-mode/index.js.map +1 -1
  80. package/dist/cjs/next/hooks/use-is-pages-router.js.map +1 -1
  81. package/dist/cjs/next/index.js +0 -3
  82. package/dist/cjs/next/index.js.map +1 -1
  83. package/dist/cjs/next/middleware/index.js +29 -0
  84. package/dist/cjs/next/middleware/index.js.map +1 -0
  85. package/dist/cjs/next/middleware/request-utils.js +49 -0
  86. package/dist/cjs/next/middleware/request-utils.js.map +1 -0
  87. package/dist/cjs/next/preview-mode.js +4 -110
  88. package/dist/cjs/next/preview-mode.js.map +1 -1
  89. package/dist/cjs/next/root-style-registry.js +24 -20
  90. package/dist/cjs/next/root-style-registry.js.map +1 -1
  91. package/dist/cjs/next/server.js +0 -3
  92. package/dist/cjs/next/server.js.map +1 -1
  93. package/dist/cjs/next/tests/test-utils.js +61 -0
  94. package/dist/cjs/next/tests/test-utils.js.map +1 -0
  95. package/dist/cjs/runtimes/react/components/Document.js +1 -1
  96. package/dist/cjs/runtimes/react/components/Document.js.map +1 -1
  97. package/dist/cjs/runtimes/react/components/ElementData.js +1 -0
  98. package/dist/cjs/runtimes/react/components/ElementData.js.map +1 -1
  99. package/dist/cjs/runtimes/react/components/RuntimeProvider.js +14 -3
  100. package/dist/cjs/runtimes/react/components/RuntimeProvider.js.map +1 -1
  101. package/dist/cjs/runtimes/react/components/draft-switcher/draft-switcher.js +72 -0
  102. package/dist/cjs/runtimes/react/components/draft-switcher/draft-switcher.js.map +1 -0
  103. package/dist/cjs/runtimes/react/components/draft-switcher/draft-toolbar.js +79 -0
  104. package/dist/cjs/runtimes/react/components/draft-switcher/draft-toolbar.js.map +1 -0
  105. package/dist/cjs/runtimes/react/components/hooks/use-builder-connection-ping.js +67 -0
  106. package/dist/cjs/runtimes/react/components/hooks/use-builder-connection-ping.js.map +1 -0
  107. package/dist/cjs/runtimes/react/components/hooks/use-builder-handshake.js +45 -0
  108. package/dist/cjs/runtimes/react/components/hooks/use-builder-handshake.js.map +1 -0
  109. package/dist/cjs/runtimes/react/controls/rich-text-v2/EditableTextV2/usePresetValue.js +1 -1
  110. package/dist/cjs/runtimes/react/controls/rich-text-v2/EditableTextV2/usePresetValue.js.map +1 -1
  111. package/dist/cjs/runtimes/react/hooks/use-cache-data.js +2 -2
  112. package/dist/cjs/runtimes/react/hooks/use-cache-data.js.map +1 -1
  113. package/dist/cjs/runtimes/react/hooks/use-document-context.js +8 -13
  114. package/dist/cjs/runtimes/react/hooks/use-document-context.js.map +1 -1
  115. package/dist/cjs/runtimes/react/hooks/use-register-document.js +8 -1
  116. package/dist/cjs/runtimes/react/hooks/use-register-document.js.map +1 -1
  117. package/dist/cjs/runtimes/react/hooks/use-resolvable-record.js +68 -0
  118. package/dist/cjs/runtimes/react/hooks/use-resolvable-record.js.map +1 -0
  119. package/dist/cjs/runtimes/react/hooks/use-resolved-props.js +6 -5
  120. package/dist/cjs/runtimes/react/hooks/use-resolved-props.js.map +1 -1
  121. package/dist/cjs/runtimes/react/hooks/use-resolved-value.js +1 -1
  122. package/dist/cjs/runtimes/react/hooks/use-resolved-value.js.map +1 -1
  123. package/dist/cjs/runtimes/react/hooks/use-resource-resolver.js +2 -1
  124. package/dist/cjs/runtimes/react/hooks/use-resource-resolver.js.map +1 -1
  125. package/dist/cjs/runtimes/react/hooks/use-stylesheet-factory.js +1 -2
  126. package/dist/cjs/runtimes/react/hooks/use-stylesheet-factory.js.map +1 -1
  127. package/dist/cjs/runtimes/react/host-api-client.js +5 -1
  128. package/dist/cjs/runtimes/react/host-api-client.js.map +1 -1
  129. package/dist/cjs/{utils/tests/breakpoint-test-util.js → runtimes/react/testing/breakpoints.js} +4 -4
  130. package/dist/cjs/runtimes/react/testing/breakpoints.js.map +1 -0
  131. package/dist/cjs/{utils/tests/element-data-test-test.js → runtimes/react/testing/element-data.js} +33 -7
  132. package/dist/cjs/runtimes/react/testing/element-data.js.map +1 -0
  133. package/dist/cjs/runtimes/react/testing/index.js +27 -0
  134. package/dist/cjs/runtimes/react/testing/index.js.map +1 -0
  135. package/dist/cjs/runtimes/react/testing/react-provider.js +38 -0
  136. package/dist/cjs/runtimes/react/testing/react-provider.js.map +1 -0
  137. package/dist/cjs/runtimes/react/use-style.js +2 -2
  138. package/dist/cjs/runtimes/react/use-style.js.map +1 -1
  139. package/dist/cjs/slate/BlockPlugin/setBlockKeyForDevice.js +1 -2
  140. package/dist/cjs/slate/BlockPlugin/setBlockKeyForDevice.js.map +1 -1
  141. package/dist/cjs/slate/TypographyPlugin/setActiveTypographyStyle.js +2 -2
  142. package/dist/cjs/slate/TypographyPlugin/setActiveTypographyStyle.js.map +1 -1
  143. package/dist/cjs/slate/selectors.js +2 -3
  144. package/dist/cjs/slate/selectors.js.map +1 -1
  145. package/dist/cjs/state/makeswift-api-client.js +23 -12
  146. package/dist/cjs/state/makeswift-api-client.js.map +1 -1
  147. package/dist/cjs/state/modules/breakpoints.js +1 -44
  148. package/dist/cjs/state/modules/breakpoints.js.map +1 -1
  149. package/dist/cjs/state/modules/element-trees.js +10 -7
  150. package/dist/cjs/state/modules/element-trees.js.map +1 -1
  151. package/dist/esm/api/react.js +28 -7
  152. package/dist/esm/api/react.js.map +1 -1
  153. package/dist/esm/api/site-version.js +10 -0
  154. package/dist/esm/api/site-version.js.map +1 -0
  155. package/dist/esm/components/builtin/Box/register.js +1 -1
  156. package/dist/esm/components/builtin/Box/register.js.map +1 -1
  157. package/dist/esm/components/builtin/Button/register.js +1 -1
  158. package/dist/esm/components/builtin/Button/register.js.map +1 -1
  159. package/dist/esm/components/builtin/Carousel/Carousel.js +5 -4
  160. package/dist/esm/components/builtin/Carousel/Carousel.js.map +1 -1
  161. package/dist/esm/components/builtin/Carousel/register.js +1 -1
  162. package/dist/esm/components/builtin/Carousel/register.js.map +1 -1
  163. package/dist/esm/components/builtin/Countdown/register.js +1 -1
  164. package/dist/esm/components/builtin/Countdown/register.js.map +1 -1
  165. package/dist/esm/components/builtin/Form/register.js +1 -1
  166. package/dist/esm/components/builtin/Form/register.js.map +1 -1
  167. package/dist/esm/components/builtin/Image/Image.js +1 -1
  168. package/dist/esm/components/builtin/Image/Image.js.map +1 -1
  169. package/dist/esm/components/builtin/Navigation/register.js +1 -1
  170. package/dist/esm/components/builtin/Navigation/register.js.map +1 -1
  171. package/dist/esm/components/builtin/SocialLinks/register.js +1 -1
  172. package/dist/esm/components/builtin/SocialLinks/register.js.map +1 -1
  173. package/dist/esm/components/builtin/Text/register.js +1 -1
  174. package/dist/esm/components/builtin/Text/register.js.map +1 -1
  175. package/dist/esm/components/hooks/useMediaQuery.js +1 -1
  176. package/dist/esm/components/hooks/useMediaQuery.js.map +1 -1
  177. package/dist/esm/components/page/Page.js +5 -2
  178. package/dist/esm/components/page/Page.js.map +1 -1
  179. package/dist/esm/components/page/PageHead.js +17 -8
  180. package/dist/esm/components/page/PageHead.js.map +1 -1
  181. package/dist/esm/components/page/page-seo-settings.js +19 -0
  182. package/dist/esm/components/page/page-seo-settings.js.map +1 -0
  183. package/dist/esm/components/shared/Link/index.js +3 -1
  184. package/dist/esm/components/shared/Link/index.js.map +1 -1
  185. package/dist/esm/components/utils/responsive-style.js +3 -2
  186. package/dist/esm/components/utils/responsive-style.js.map +1 -1
  187. package/dist/esm/core/index.js +18 -2
  188. package/dist/esm/core/index.js.map +1 -1
  189. package/dist/esm/jest-setup.js +4 -1
  190. package/dist/esm/jest-setup.js.map +1 -1
  191. package/dist/esm/locale.js +79 -0
  192. package/dist/esm/locale.js.map +1 -1
  193. package/dist/esm/next/api-handler/handlers/clear-draft.js +50 -0
  194. package/dist/esm/next/api-handler/handlers/clear-draft.js.map +1 -0
  195. package/dist/esm/next/api-handler/handlers/manifest.js +3 -2
  196. package/dist/esm/next/api-handler/handlers/manifest.js.map +1 -1
  197. package/dist/esm/next/api-handler/handlers/redirect-draft.js +63 -0
  198. package/dist/esm/next/api-handler/handlers/redirect-draft.js.map +1 -0
  199. package/dist/esm/next/api-handler/handlers/redirect-preview.js +53 -0
  200. package/dist/esm/next/api-handler/handlers/redirect-preview.js.map +1 -0
  201. package/dist/esm/next/api-handler/handlers/utils/draft.js +24 -0
  202. package/dist/esm/next/api-handler/handlers/utils/draft.js.map +1 -0
  203. package/dist/esm/next/api-handler/handlers/webhook/index.js +3 -3
  204. package/dist/esm/next/api-handler/handlers/webhook/index.js.map +1 -1
  205. package/dist/esm/next/api-handler/handlers/webhook/site-published.js +7 -3
  206. package/dist/esm/next/api-handler/handlers/webhook/site-published.js.map +1 -1
  207. package/dist/esm/next/api-handler/handlers/webhook/types.js.map +1 -1
  208. package/dist/esm/next/api-handler/index.js +28 -9
  209. package/dist/esm/next/api-handler/index.js.map +1 -1
  210. package/dist/esm/next/cache.js +5 -0
  211. package/dist/esm/next/cache.js.map +1 -0
  212. package/dist/esm/next/client.js +128 -54
  213. package/dist/esm/next/client.js.map +1 -1
  214. package/dist/esm/next/components/page.js +3 -2
  215. package/dist/esm/next/components/page.js.map +1 -1
  216. package/dist/esm/next/components/tests/controls/color-control/fixtures.js +24 -0
  217. package/dist/esm/next/components/tests/controls/color-control/fixtures.js.map +1 -0
  218. package/dist/esm/next/components/tests/controls/page-control-prop-rendering.js +82 -39
  219. package/dist/esm/next/components/tests/controls/page-control-prop-rendering.js.map +1 -1
  220. package/dist/esm/next/components/tests/controls/rich-text-v2-control/fixtures.js +56 -0
  221. package/dist/esm/next/components/tests/controls/rich-text-v2-control/fixtures.js.map +1 -0
  222. package/dist/esm/next/components/tests/controls/style-control/fixtures.js +35 -0
  223. package/dist/esm/next/components/tests/controls/style-control/fixtures.js.map +1 -0
  224. package/dist/esm/next/components/tests/prop-controllers/page-prop-controller.js +7 -11
  225. package/dist/esm/next/components/tests/prop-controllers/page-prop-controller.js.map +1 -1
  226. package/dist/esm/next/document.js +1 -3
  227. package/dist/esm/next/document.js.map +1 -1
  228. package/dist/esm/next/draft-mode/index.js +1 -1
  229. package/dist/esm/next/draft-mode/index.js.map +1 -1
  230. package/dist/esm/next/hooks/use-is-pages-router.js.map +1 -1
  231. package/dist/esm/next/index.js +0 -2
  232. package/dist/esm/next/index.js.map +1 -1
  233. package/dist/esm/next/middleware/index.js +5 -0
  234. package/dist/esm/next/middleware/index.js.map +1 -0
  235. package/dist/esm/next/middleware/request-utils.js +28 -0
  236. package/dist/esm/next/middleware/request-utils.js.map +1 -0
  237. package/dist/esm/next/preview-mode.js +2 -105
  238. package/dist/esm/next/preview-mode.js.map +1 -1
  239. package/dist/esm/next/root-style-registry.js +24 -20
  240. package/dist/esm/next/root-style-registry.js.map +1 -1
  241. package/dist/esm/next/server.js +0 -2
  242. package/dist/esm/next/server.js.map +1 -1
  243. package/dist/esm/next/tests/test-utils.js +37 -0
  244. package/dist/esm/next/tests/test-utils.js.map +1 -0
  245. package/dist/esm/runtimes/react/components/Document.js +2 -2
  246. package/dist/esm/runtimes/react/components/Document.js.map +1 -1
  247. package/dist/esm/runtimes/react/components/ElementData.js +1 -0
  248. package/dist/esm/runtimes/react/components/ElementData.js.map +1 -1
  249. package/dist/esm/runtimes/react/components/RuntimeProvider.js +15 -4
  250. package/dist/esm/runtimes/react/components/RuntimeProvider.js.map +1 -1
  251. package/dist/esm/runtimes/react/components/draft-switcher/draft-switcher.js +48 -0
  252. package/dist/esm/runtimes/react/components/draft-switcher/draft-switcher.js.map +1 -0
  253. package/dist/esm/runtimes/react/components/draft-switcher/draft-toolbar.js +55 -0
  254. package/dist/esm/runtimes/react/components/draft-switcher/draft-toolbar.js.map +1 -0
  255. package/dist/esm/runtimes/react/components/hooks/use-builder-connection-ping.js +43 -0
  256. package/dist/esm/runtimes/react/components/hooks/use-builder-connection-ping.js.map +1 -0
  257. package/dist/esm/runtimes/react/components/hooks/use-builder-handshake.js +21 -0
  258. package/dist/esm/runtimes/react/components/hooks/use-builder-handshake.js.map +1 -0
  259. package/dist/esm/runtimes/react/controls/rich-text-v2/EditableTextV2/usePresetValue.js +2 -2
  260. package/dist/esm/runtimes/react/controls/rich-text-v2/EditableTextV2/usePresetValue.js.map +1 -1
  261. package/dist/esm/runtimes/react/hooks/use-cache-data.js +2 -2
  262. package/dist/esm/runtimes/react/hooks/use-cache-data.js.map +1 -1
  263. package/dist/esm/runtimes/react/hooks/use-document-context.js +6 -11
  264. package/dist/esm/runtimes/react/hooks/use-document-context.js.map +1 -1
  265. package/dist/esm/runtimes/react/hooks/use-register-document.js +9 -2
  266. package/dist/esm/runtimes/react/hooks/use-register-document.js.map +1 -1
  267. package/dist/esm/runtimes/react/hooks/use-resolvable-record.js +44 -0
  268. package/dist/esm/runtimes/react/hooks/use-resolvable-record.js.map +1 -0
  269. package/dist/esm/runtimes/react/hooks/use-resolved-props.js +6 -5
  270. package/dist/esm/runtimes/react/hooks/use-resolved-props.js.map +1 -1
  271. package/dist/esm/runtimes/react/hooks/use-resolved-value.js +1 -1
  272. package/dist/esm/runtimes/react/hooks/use-resolved-value.js.map +1 -1
  273. package/dist/esm/runtimes/react/hooks/use-resource-resolver.js +3 -2
  274. package/dist/esm/runtimes/react/hooks/use-resource-resolver.js.map +1 -1
  275. package/dist/esm/runtimes/react/hooks/use-stylesheet-factory.js +2 -2
  276. package/dist/esm/runtimes/react/hooks/use-stylesheet-factory.js.map +1 -1
  277. package/dist/esm/runtimes/react/host-api-client.js +5 -1
  278. package/dist/esm/runtimes/react/host-api-client.js.map +1 -1
  279. package/dist/esm/{utils/tests/breakpoint-test-util.js → runtimes/react/testing/breakpoints.js} +1 -1
  280. package/dist/esm/runtimes/react/testing/breakpoints.js.map +1 -0
  281. package/dist/esm/{utils/tests/element-data-test-test.js → runtimes/react/testing/element-data.js} +29 -4
  282. package/dist/esm/runtimes/react/testing/element-data.js.map +1 -0
  283. package/dist/esm/runtimes/react/testing/index.js +4 -0
  284. package/dist/esm/runtimes/react/testing/index.js.map +1 -0
  285. package/dist/esm/runtimes/react/testing/react-provider.js +14 -0
  286. package/dist/esm/runtimes/react/testing/react-provider.js.map +1 -0
  287. package/dist/esm/runtimes/react/use-style.js +2 -2
  288. package/dist/esm/runtimes/react/use-style.js.map +1 -1
  289. package/dist/esm/slate/BlockPlugin/setBlockKeyForDevice.js +4 -2
  290. package/dist/esm/slate/BlockPlugin/setBlockKeyForDevice.js.map +1 -1
  291. package/dist/esm/slate/TypographyPlugin/setActiveTypographyStyle.js +3 -1
  292. package/dist/esm/slate/TypographyPlugin/setActiveTypographyStyle.js.map +1 -1
  293. package/dist/esm/slate/selectors.js +4 -2
  294. package/dist/esm/slate/selectors.js.map +1 -1
  295. package/dist/esm/state/makeswift-api-client.js +22 -11
  296. package/dist/esm/state/makeswift-api-client.js.map +1 -1
  297. package/dist/esm/state/modules/breakpoints.js +1 -42
  298. package/dist/esm/state/modules/breakpoints.js.map +1 -1
  299. package/dist/esm/state/modules/element-trees.js +10 -7
  300. package/dist/esm/state/modules/element-trees.js.map +1 -1
  301. package/dist/types/api/react.d.ts +4 -1
  302. package/dist/types/api/react.d.ts.map +1 -1
  303. package/dist/types/api/site-version.d.ts +6 -0
  304. package/dist/types/api/site-version.d.ts.map +1 -0
  305. package/dist/types/components/builtin/Box/register.d.ts.map +1 -1
  306. package/dist/types/components/builtin/Button/register.d.ts.map +1 -1
  307. package/dist/types/components/builtin/Carousel/Carousel.d.ts.map +1 -1
  308. package/dist/types/components/builtin/Image/Image.d.ts.map +1 -1
  309. package/dist/types/components/hooks/useMediaQuery.d.ts +1 -1
  310. package/dist/types/components/hooks/useMediaQuery.d.ts.map +1 -1
  311. package/dist/types/components/page/Page.d.ts +3 -1
  312. package/dist/types/components/page/Page.d.ts.map +1 -1
  313. package/dist/types/components/page/PageHead.d.ts +3 -1
  314. package/dist/types/components/page/PageHead.d.ts.map +1 -1
  315. package/dist/types/components/page/page-seo-settings.d.ts +11 -0
  316. package/dist/types/components/page/page-seo-settings.d.ts.map +1 -0
  317. package/dist/types/components/shared/Link/index.d.ts.map +1 -1
  318. package/dist/types/components/utils/responsive-style.d.ts +1 -1
  319. package/dist/types/components/utils/responsive-style.d.ts.map +1 -1
  320. package/dist/types/controls/link.d.ts +1 -1
  321. package/dist/types/core/index.d.ts +1 -1
  322. package/dist/types/core/index.d.ts.map +1 -1
  323. package/dist/types/locale.d.ts +3 -3
  324. package/dist/types/locale.d.ts.map +1 -1
  325. package/dist/types/next/api-handler/handlers/clear-draft.d.ts +20 -0
  326. package/dist/types/next/api-handler/handlers/clear-draft.d.ts.map +1 -0
  327. package/dist/types/next/api-handler/handlers/manifest.d.ts +1 -0
  328. package/dist/types/next/api-handler/handlers/manifest.d.ts.map +1 -1
  329. package/dist/types/next/api-handler/handlers/redirect-draft.d.ts +18 -0
  330. package/dist/types/next/api-handler/handlers/redirect-draft.d.ts.map +1 -0
  331. package/dist/types/next/api-handler/handlers/redirect-preview.d.ts +18 -0
  332. package/dist/types/next/api-handler/handlers/redirect-preview.d.ts.map +1 -0
  333. package/dist/types/next/api-handler/handlers/utils/draft.d.ts +16 -0
  334. package/dist/types/next/api-handler/handlers/utils/draft.d.ts.map +1 -0
  335. package/dist/types/next/api-handler/handlers/webhook/index.d.ts +9 -11
  336. package/dist/types/next/api-handler/handlers/webhook/index.d.ts.map +1 -1
  337. package/dist/types/next/api-handler/handlers/webhook/site-published.d.ts +6 -3
  338. package/dist/types/next/api-handler/handlers/webhook/site-published.d.ts.map +1 -1
  339. package/dist/types/next/api-handler/handlers/webhook/types.d.ts +13 -12
  340. package/dist/types/next/api-handler/handlers/webhook/types.d.ts.map +1 -1
  341. package/dist/types/next/api-handler/index.d.ts +10 -5
  342. package/dist/types/next/api-handler/index.d.ts.map +1 -1
  343. package/dist/types/next/cache.d.ts +2 -0
  344. package/dist/types/next/cache.d.ts.map +1 -0
  345. package/dist/types/next/client.d.ts +14 -12
  346. package/dist/types/next/client.d.ts.map +1 -1
  347. package/dist/types/next/components/page.d.ts +21 -1
  348. package/dist/types/next/components/page.d.ts.map +1 -1
  349. package/dist/types/next/components/tests/controls/color-control/client.test.d.ts +3 -0
  350. package/dist/types/next/components/tests/controls/color-control/client.test.d.ts.map +1 -0
  351. package/dist/types/next/components/tests/controls/color-control/fixtures.d.ts +11 -0
  352. package/dist/types/next/components/tests/controls/color-control/fixtures.d.ts.map +1 -0
  353. package/dist/types/next/components/tests/controls/color-control/server.test.d.ts +2 -0
  354. package/dist/types/next/components/tests/controls/color-control/server.test.d.ts.map +1 -0
  355. package/dist/types/next/components/tests/controls/page-control-prop-rendering.d.ts +2 -3
  356. package/dist/types/next/components/tests/controls/page-control-prop-rendering.d.ts.map +1 -1
  357. package/dist/types/next/components/tests/controls/rich-text-v2-control/client.test.d.ts +2 -0
  358. package/dist/types/next/components/tests/controls/rich-text-v2-control/client.test.d.ts.map +1 -0
  359. package/dist/types/next/components/tests/controls/rich-text-v2-control/fixtures.d.ts +42 -0
  360. package/dist/types/next/components/tests/controls/rich-text-v2-control/fixtures.d.ts.map +1 -0
  361. package/dist/types/next/components/tests/controls/rich-text-v2-control/server.test.d.ts +2 -0
  362. package/dist/types/next/components/tests/controls/rich-text-v2-control/server.test.d.ts.map +1 -0
  363. package/dist/types/next/components/tests/controls/style-control/client.test.d.ts +2 -0
  364. package/dist/types/next/components/tests/controls/style-control/client.test.d.ts.map +1 -0
  365. package/dist/types/next/components/tests/controls/style-control/fixtures.d.ts +6 -0
  366. package/dist/types/next/components/tests/controls/style-control/fixtures.d.ts.map +1 -0
  367. package/dist/types/next/components/tests/controls/style-control/server.test.d.ts +2 -0
  368. package/dist/types/next/components/tests/controls/style-control/server.test.d.ts.map +1 -0
  369. package/dist/types/next/components/tests/makeswift-page-metadata-rendering.test.d.ts +3 -0
  370. package/dist/types/next/components/tests/makeswift-page-metadata-rendering.test.d.ts.map +1 -0
  371. package/dist/types/next/components/tests/prop-controllers/page-prop-controller.d.ts.map +1 -1
  372. package/dist/types/next/document.d.ts +1 -5
  373. package/dist/types/next/document.d.ts.map +1 -1
  374. package/dist/types/next/draft-mode/index.d.ts +2 -2
  375. package/dist/types/next/hooks/use-is-pages-router.d.ts.map +1 -1
  376. package/dist/types/next/index.d.ts +0 -1
  377. package/dist/types/next/index.d.ts.map +1 -1
  378. package/dist/types/next/middleware/index.d.ts +2 -0
  379. package/dist/types/next/middleware/index.d.ts.map +1 -0
  380. package/dist/types/next/middleware/request-utils.d.ts +3 -0
  381. package/dist/types/next/middleware/request-utils.d.ts.map +1 -0
  382. package/dist/types/next/middleware/request-utils.test.d.ts +2 -0
  383. package/dist/types/next/middleware/request-utils.test.d.ts.map +1 -0
  384. package/dist/types/next/preview-mode.d.ts +3 -10
  385. package/dist/types/next/preview-mode.d.ts.map +1 -1
  386. package/dist/types/next/root-style-registry.d.ts +2 -1
  387. package/dist/types/next/root-style-registry.d.ts.map +1 -1
  388. package/dist/types/next/server.d.ts +0 -1
  389. package/dist/types/next/server.d.ts.map +1 -1
  390. package/dist/types/next/tests/client.error-handling.test.d.ts +2 -0
  391. package/dist/types/next/tests/client.error-handling.test.d.ts.map +1 -0
  392. package/dist/types/next/tests/client.get-page-snapshot.test.d.ts +2 -0
  393. package/dist/types/next/tests/client.get-page-snapshot.test.d.ts.map +1 -0
  394. package/dist/types/next/tests/client.get-resources.test.d.ts +2 -0
  395. package/dist/types/next/tests/client.get-resources.test.d.ts.map +1 -0
  396. package/dist/types/next/tests/server.makeswift-api-handler.test.d.ts +2 -0
  397. package/dist/types/next/tests/server.makeswift-api-handler.test.d.ts.map +1 -0
  398. package/dist/types/next/tests/test-utils.d.ts +8 -0
  399. package/dist/types/next/tests/test-utils.d.ts.map +1 -0
  400. package/dist/types/runtimes/react/components/Document.d.ts.map +1 -1
  401. package/dist/types/runtimes/react/components/ElementData.d.ts.map +1 -1
  402. package/dist/types/runtimes/react/components/RuntimeProvider.d.ts +2 -1
  403. package/dist/types/runtimes/react/components/RuntimeProvider.d.ts.map +1 -1
  404. package/dist/types/runtimes/react/components/draft-switcher/draft-switcher.d.ts +4 -0
  405. package/dist/types/runtimes/react/components/draft-switcher/draft-switcher.d.ts.map +1 -0
  406. package/dist/types/runtimes/react/components/draft-switcher/draft-toolbar.d.ts +6 -0
  407. package/dist/types/runtimes/react/components/draft-switcher/draft-toolbar.d.ts.map +1 -0
  408. package/dist/types/runtimes/react/components/hooks/use-builder-connection-ping.d.ts +4 -0
  409. package/dist/types/runtimes/react/components/hooks/use-builder-connection-ping.d.ts.map +1 -0
  410. package/dist/types/runtimes/react/components/hooks/use-builder-handshake.d.ts +4 -0
  411. package/dist/types/runtimes/react/components/hooks/use-builder-handshake.d.ts.map +1 -0
  412. package/dist/types/runtimes/react/hooks/use-cache-data.d.ts.map +1 -1
  413. package/dist/types/runtimes/react/hooks/use-document-context.d.ts +2 -7
  414. package/dist/types/runtimes/react/hooks/use-document-context.d.ts.map +1 -1
  415. package/dist/types/runtimes/react/hooks/use-register-document.d.ts.map +1 -1
  416. package/dist/types/runtimes/react/hooks/use-resolvable-record.d.ts +3 -0
  417. package/dist/types/runtimes/react/hooks/use-resolvable-record.d.ts.map +1 -0
  418. package/dist/types/runtimes/react/hooks/use-resolved-props.d.ts.map +1 -1
  419. package/dist/types/runtimes/react/hooks/use-resource-resolver.d.ts.map +1 -1
  420. package/dist/types/runtimes/react/hooks/use-stylesheet-factory.d.ts.map +1 -1
  421. package/dist/types/runtimes/react/host-api-client.d.ts.map +1 -1
  422. package/dist/types/{utils/tests/breakpoint-test-util.d.ts → runtimes/react/testing/breakpoints.d.ts} +1 -1
  423. package/dist/types/runtimes/react/testing/breakpoints.d.ts.map +1 -0
  424. package/dist/types/{utils/tests/element-data-test-test.d.ts → runtimes/react/testing/element-data.d.ts} +7 -3
  425. package/dist/types/runtimes/react/testing/element-data.d.ts.map +1 -0
  426. package/dist/types/runtimes/react/testing/index.d.ts +4 -0
  427. package/dist/types/runtimes/react/testing/index.d.ts.map +1 -0
  428. package/dist/types/runtimes/react/testing/react-provider.d.ts +8 -0
  429. package/dist/types/runtimes/react/testing/react-provider.d.ts.map +1 -0
  430. package/dist/types/slate/BlockPlugin/setBlockKeyForDevice.d.ts +1 -1
  431. package/dist/types/slate/BlockPlugin/setBlockKeyForDevice.d.ts.map +1 -1
  432. package/dist/types/slate/TypographyPlugin/setActiveTypographyStyle.d.ts +1 -1
  433. package/dist/types/slate/TypographyPlugin/setActiveTypographyStyle.d.ts.map +1 -1
  434. package/dist/types/slate/selectors.d.ts +1 -2
  435. package/dist/types/slate/selectors.d.ts.map +1 -1
  436. package/dist/types/state/makeswift-api-client.d.ts +2 -1
  437. package/dist/types/state/makeswift-api-client.d.ts.map +1 -1
  438. package/dist/types/state/modules/__tests__/fixtures/element-trees-demo-component.d.ts +7 -0
  439. package/dist/types/state/modules/__tests__/fixtures/element-trees-demo-component.d.ts.map +1 -0
  440. package/dist/types/state/modules/__tests__/fixtures/element-trees.d.ts +239 -0
  441. package/dist/types/state/modules/__tests__/fixtures/element-trees.d.ts.map +1 -1
  442. package/dist/types/state/modules/breakpoints.d.ts +2 -7
  443. package/dist/types/state/modules/breakpoints.d.ts.map +1 -1
  444. package/dist/types/state/modules/element-trees.d.ts +1 -1
  445. package/dist/types/state/modules/element-trees.d.ts.map +1 -1
  446. package/package.json +17 -5
  447. package/dist/cjs/next/api-handler/handlers/proxy-draft-mode.js +0 -80
  448. package/dist/cjs/next/api-handler/handlers/proxy-draft-mode.js.map +0 -1
  449. package/dist/cjs/next/api-handler/handlers/proxy-preview-mode.js +0 -100
  450. package/dist/cjs/next/api-handler/handlers/proxy-preview-mode.js.map +0 -1
  451. package/dist/cjs/next/draft-mode/draft-mode-script.js +0 -137
  452. package/dist/cjs/next/draft-mode/draft-mode-script.js.map +0 -1
  453. package/dist/cjs/runtimes/react/resolvable-record.js +0 -67
  454. package/dist/cjs/runtimes/react/resolvable-record.js.map +0 -1
  455. package/dist/cjs/utils/tests/breakpoint-test-util.js.map +0 -1
  456. package/dist/cjs/utils/tests/element-data-test-test.js.map +0 -1
  457. package/dist/esm/next/api-handler/handlers/proxy-draft-mode.js +0 -60
  458. package/dist/esm/next/api-handler/handlers/proxy-draft-mode.js.map +0 -1
  459. package/dist/esm/next/api-handler/handlers/proxy-preview-mode.js +0 -80
  460. package/dist/esm/next/api-handler/handlers/proxy-preview-mode.js.map +0 -1
  461. package/dist/esm/next/draft-mode/draft-mode-script.js +0 -103
  462. package/dist/esm/next/draft-mode/draft-mode-script.js.map +0 -1
  463. package/dist/esm/runtimes/react/resolvable-record.js +0 -43
  464. package/dist/esm/runtimes/react/resolvable-record.js.map +0 -1
  465. package/dist/esm/utils/tests/breakpoint-test-util.js.map +0 -1
  466. package/dist/esm/utils/tests/element-data-test-test.js.map +0 -1
  467. package/dist/types/next/api-handler/handlers/proxy-draft-mode.d.ts +0 -20
  468. package/dist/types/next/api-handler/handlers/proxy-draft-mode.d.ts.map +0 -1
  469. package/dist/types/next/api-handler/handlers/proxy-draft-mode.test.d.ts +0 -2
  470. package/dist/types/next/api-handler/handlers/proxy-draft-mode.test.d.ts.map +0 -1
  471. package/dist/types/next/api-handler/handlers/proxy-preview-mode.d.ts +0 -20
  472. package/dist/types/next/api-handler/handlers/proxy-preview-mode.d.ts.map +0 -1
  473. package/dist/types/next/components/tests/controls/color-control.test.d.ts +0 -3
  474. package/dist/types/next/components/tests/controls/color-control.test.d.ts.map +0 -1
  475. package/dist/types/next/components/tests/controls/rich-text-v2-control.test.d.ts +0 -2
  476. package/dist/types/next/components/tests/controls/rich-text-v2-control.test.d.ts.map +0 -1
  477. package/dist/types/next/components/tests/controls/style-control.test.d.ts +0 -2
  478. package/dist/types/next/components/tests/controls/style-control.test.d.ts.map +0 -1
  479. package/dist/types/next/draft-mode/draft-mode-script.d.ts +0 -6
  480. package/dist/types/next/draft-mode/draft-mode-script.d.ts.map +0 -1
  481. package/dist/types/runtimes/react/resolvable-record.d.ts +0 -3
  482. package/dist/types/runtimes/react/resolvable-record.d.ts.map +0 -1
  483. package/dist/types/utils/tests/breakpoint-test-util.d.ts.map +0 -1
  484. package/dist/types/utils/tests/element-data-test-test.d.ts.map +0 -1
@@ -1,8 +1,5 @@
1
- import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
1
  import { z } from "zod";
3
- import { ActionTypes } from "../react";
4
- const makeswiftSiteVersionSchema = z.enum(["Live", "Working"]);
5
- const MakeswiftSiteVersion = makeswiftSiteVersionSchema.Enum;
2
+ import { makeswiftSiteVersionSchema } from "../api/site-version";
6
3
  const makeswiftPreviewDataSchema = z.object({
7
4
  makeswift: z.literal(true),
8
5
  siteVersion: makeswiftSiteVersionSchema
@@ -13,107 +10,7 @@ function getMakeswiftSiteVersion(previewData) {
13
10
  return result.data.siteVersion;
14
11
  return null;
15
12
  }
16
- function PreviewModeScript({
17
- isPreview = false,
18
- appOrigin = "https://app.makeswift.com"
19
- }) {
20
- const previewModeScript = `
21
- const isPreview = ${isPreview}
22
- const appOrigin = '${appOrigin.replace("'", "\\'")}'
23
- const searchParamName = 'x-makeswift-preview-mode'
24
- const headerName = 'X-Makeswift-Preview-Mode'
25
- const originalUrl = new URL(window.location.href)
26
-
27
- if (window.parent !== window) {
28
- window.addEventListener('message', event => {
29
- if (event.origin === appOrigin && event.data.type === 'makeswift_preview_mode') {
30
- const { secret } = event.data
31
-
32
- if (!isPreview && !originalUrl.searchParams.has(searchParamName)) {
33
- const url = new URL(originalUrl)
34
-
35
- url.searchParams.set(searchParamName, secret)
36
-
37
- window.location.replace(url)
38
- } else {
39
- const originalFetch = window.fetch
40
-
41
- window.fetch = function patchedFetch(resource, options) {
42
- const request = new Request(resource, options)
43
-
44
- if (new URL(request.url).origin !== window.location.origin) {
45
- return originalFetch.call(this, resource, options)
46
- }
47
-
48
- const newHeaders = new Headers(request.headers)
49
- newHeaders.set(headerName, secret)
50
-
51
- return originalFetch.call(
52
- this,
53
- new Request(request, { headers: newHeaders })
54
- )
55
- }
56
- }
57
- }
58
- })
59
-
60
- window.parent.postMessage({ type: 'makeswift_preview_mode' }, appOrigin)
61
- }
62
-
63
- if (originalUrl.searchParams.has(searchParamName)) {
64
- const url = new URL(originalUrl)
65
-
66
- url.searchParams.delete(searchParamName)
67
-
68
- window.history.replaceState(null, '', url)
69
- }
70
- `;
71
- const makeswiftConnectionCheckScript = `
72
- const appOrigin = '${appOrigin.replace("'", "\\'")}'
73
-
74
- if (window.parent !== window) {
75
- window.addEventListener('message', event => {
76
- if (
77
- event.origin === appOrigin &&
78
- event.data.type === '${ActionTypes.MAKESWIFT_CONNECTION_INIT}'
79
- ) {
80
- setInterval(() => {
81
- window.parent.postMessage({
82
- type: '${ActionTypes.MAKESWIFT_CONNECTION_CHECK}',
83
- payload: {
84
- currentUrl: window.location.href
85
- }
86
- }, appOrigin)
87
- }, 20)
88
- }
89
- })
90
-
91
- window.parent.postMessage({ type: '${ActionTypes.MAKESWIFT_CONNECTION_INIT}' }, appOrigin)
92
- }
93
- `;
94
- return /* @__PURE__ */ jsxs(Fragment, { children: [
95
- /* @__PURE__ */ jsx(
96
- "script",
97
- {
98
- id: "makeswift-preview-mode",
99
- type: "module",
100
- dangerouslySetInnerHTML: { __html: previewModeScript }
101
- }
102
- ),
103
- /* @__PURE__ */ jsx(
104
- "script",
105
- {
106
- id: "makeswift-connection-check",
107
- type: "module",
108
- dangerouslySetInnerHTML: { __html: makeswiftConnectionCheckScript }
109
- }
110
- )
111
- ] });
112
- }
113
13
  export {
114
- MakeswiftSiteVersion,
115
- PreviewModeScript,
116
- getMakeswiftSiteVersion,
117
- makeswiftSiteVersionSchema
14
+ getMakeswiftSiteVersion
118
15
  };
119
16
  //# sourceMappingURL=preview-mode.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/next/preview-mode.tsx"],"sourcesContent":["import { PreviewData } from 'next'\nimport { z } from 'zod'\nimport { ActionTypes } from '../react'\n\nexport const makeswiftSiteVersionSchema = z.enum(['Live', 'Working'])\nexport const MakeswiftSiteVersion = makeswiftSiteVersionSchema.Enum\nexport type MakeswiftSiteVersion = z.infer<typeof makeswiftSiteVersionSchema>\n\nconst makeswiftPreviewDataSchema = z.object({\n makeswift: z.literal(true),\n siteVersion: makeswiftSiteVersionSchema,\n})\nexport type MakeswiftPreviewData = z.infer<typeof makeswiftPreviewDataSchema>\n\nexport function getMakeswiftSiteVersion(previewData: PreviewData): MakeswiftSiteVersion | null {\n const result = makeswiftPreviewDataSchema.safeParse(previewData)\n\n if (result.success) return result.data.siteVersion\n\n return null\n}\n\ntype Props = {\n isPreview?: boolean\n appOrigin?: string\n}\n\nexport function PreviewModeScript({\n isPreview = false,\n appOrigin = 'https://app.makeswift.com',\n}: Props) {\n const previewModeScript = `\nconst isPreview = ${isPreview}\nconst appOrigin = '${appOrigin.replace(\"'\", \"\\\\'\")}'\nconst searchParamName = 'x-makeswift-preview-mode'\nconst headerName = 'X-Makeswift-Preview-Mode'\nconst originalUrl = new URL(window.location.href)\n\nif (window.parent !== window) {\n window.addEventListener('message', event => {\n if (event.origin === appOrigin && event.data.type === 'makeswift_preview_mode') {\n const { secret } = event.data\n\n if (!isPreview && !originalUrl.searchParams.has(searchParamName)) {\n const url = new URL(originalUrl)\n\n url.searchParams.set(searchParamName, secret)\n\n window.location.replace(url)\n } else {\n const originalFetch = window.fetch\n\n window.fetch = function patchedFetch(resource, options) {\n const request = new Request(resource, options)\n\n if (new URL(request.url).origin !== window.location.origin) {\n return originalFetch.call(this, resource, options)\n }\n \n const newHeaders = new Headers(request.headers)\n newHeaders.set(headerName, secret)\n\n return originalFetch.call(\n this,\n new Request(request, { headers: newHeaders })\n )\n }\n }\n }\n })\n\n window.parent.postMessage({ type: 'makeswift_preview_mode' }, appOrigin)\n}\n\nif (originalUrl.searchParams.has(searchParamName)) {\n const url = new URL(originalUrl)\n\n url.searchParams.delete(searchParamName)\n\n window.history.replaceState(null, '', url)\n}\n`\n\n const makeswiftConnectionCheckScript = `\nconst appOrigin = '${appOrigin.replace(\"'\", \"\\\\'\")}'\n\nif (window.parent !== window) {\n window.addEventListener('message', event => {\n if (\n event.origin === appOrigin && \n event.data.type === '${ActionTypes.MAKESWIFT_CONNECTION_INIT}'\n ) {\n setInterval(() => {\n window.parent.postMessage({ \n type: '${ActionTypes.MAKESWIFT_CONNECTION_CHECK}',\n payload: { \n currentUrl: window.location.href \n }\n }, appOrigin)\n }, 20)\n }\n })\n\n window.parent.postMessage({ type: '${ActionTypes.MAKESWIFT_CONNECTION_INIT}' }, appOrigin)\n}\n`\n\n return (\n <>\n <script\n id=\"makeswift-preview-mode\"\n type=\"module\"\n dangerouslySetInnerHTML={{ __html: previewModeScript }}\n />\n <script\n id=\"makeswift-connection-check\"\n type=\"module\"\n dangerouslySetInnerHTML={{ __html: makeswiftConnectionCheckScript }}\n />\n </>\n )\n}\n"],"mappings":"AA4GI,mBACE,KADF;AA3GJ,SAAS,SAAS;AAClB,SAAS,mBAAmB;AAErB,MAAM,6BAA6B,EAAE,KAAK,CAAC,QAAQ,SAAS,CAAC;AAC7D,MAAM,uBAAuB,2BAA2B;AAG/D,MAAM,6BAA6B,EAAE,OAAO;AAAA,EAC1C,WAAW,EAAE,QAAQ,IAAI;AAAA,EACzB,aAAa;AACf,CAAC;AAGM,SAAS,wBAAwB,aAAuD;AAC7F,QAAM,SAAS,2BAA2B,UAAU,WAAW;AAE/D,MAAI,OAAO;AAAS,WAAO,OAAO,KAAK;AAEvC,SAAO;AACT;AAOO,SAAS,kBAAkB;AAAA,EAChC,YAAY;AAAA,EACZ,YAAY;AACd,GAAU;AACR,QAAM,oBAAoB;AAAA,oBACR,SAAS;AAAA,qBACR,UAAU,QAAQ,KAAK,KAAK,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAkDhD,QAAM,iCAAiC;AAAA,qBACpB,UAAU,QAAQ,KAAK,KAAK,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,6BAMrB,YAAY,yBAAyB;AAAA;AAAA;AAAA;AAAA,mBAI/C,YAAY,0BAA0B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,uCASlB,YAAY,yBAAyB;AAAA;AAAA;AAI1E,SACE,iCACE;AAAA;AAAA,MAAC;AAAA;AAAA,QACC,IAAG;AAAA,QACH,MAAK;AAAA,QACL,yBAAyB,EAAE,QAAQ,kBAAkB;AAAA;AAAA,IACvD;AAAA,IACA;AAAA,MAAC;AAAA;AAAA,QACC,IAAG;AAAA,QACH,MAAK;AAAA,QACL,yBAAyB,EAAE,QAAQ,+BAA+B;AAAA;AAAA,IACpE;AAAA,KACF;AAEJ;","names":[]}
1
+ {"version":3,"sources":["../../../src/next/preview-mode.tsx"],"sourcesContent":["import { PreviewData } from 'next'\nimport { z } from 'zod'\nimport { type MakeswiftSiteVersion, makeswiftSiteVersionSchema } from '../api/site-version'\n\nconst makeswiftPreviewDataSchema = z.object({\n makeswift: z.literal(true),\n siteVersion: makeswiftSiteVersionSchema,\n})\nexport type MakeswiftPreviewData = z.infer<typeof makeswiftPreviewDataSchema>\n\nexport function getMakeswiftSiteVersion(previewData: PreviewData): MakeswiftSiteVersion | null {\n const result = makeswiftPreviewDataSchema.safeParse(previewData)\n\n if (result.success) return result.data.siteVersion\n\n return null\n}\n"],"mappings":"AACA,SAAS,SAAS;AAClB,SAAoC,kCAAkC;AAEtE,MAAM,6BAA6B,EAAE,OAAO;AAAA,EAC1C,WAAW,EAAE,QAAQ,IAAI;AAAA,EACzB,aAAa;AACf,CAAC;AAGM,SAAS,wBAAwB,aAAuD;AAC7F,QAAM,SAAS,2BAA2B,UAAU,WAAW;AAE/D,MAAI,OAAO;AAAS,WAAO,OAAO,KAAK;AAEvC,SAAO;AACT;","names":[]}
@@ -5,26 +5,30 @@ import { cache } from "@emotion/css";
5
5
  import { useServerInsertedHTML } from "next/navigation";
6
6
  import { createContext, useContext, useState } from "react";
7
7
  const CacheContext = createContext(cache);
8
- function RootStyleRegistry({ children }) {
9
- const [{ cache: cache2, flush }] = useState(() => {
10
- const cache3 = createCache({ key: "css" });
11
- cache3.compat = true;
12
- const prevInsert = cache3.insert;
13
- let inserted = [];
14
- cache3.insert = (...args) => {
15
- const serialized = args[1];
16
- if (cache3.inserted[serialized.name] === void 0) {
17
- inserted.push(serialized.name);
18
- }
19
- return prevInsert(...args);
20
- };
21
- const flush2 = () => {
22
- const prevInserted = inserted;
23
- inserted = [];
24
- return prevInserted;
25
- };
26
- return { cache: cache3, flush: flush2 };
27
- });
8
+ const createRootStyleCache = ({ key }) => {
9
+ const cache2 = createCache({ key });
10
+ cache2.compat = true;
11
+ const prevInsert = cache2.insert;
12
+ let inserted = [];
13
+ cache2.insert = (...args) => {
14
+ const serialized = args[1];
15
+ if (cache2.inserted[serialized.name] === void 0) {
16
+ inserted.push(serialized.name);
17
+ }
18
+ return prevInsert(...args);
19
+ };
20
+ const flush = () => {
21
+ const prevInserted = inserted;
22
+ inserted = [];
23
+ return prevInserted;
24
+ };
25
+ return { cache: cache2, flush };
26
+ };
27
+ function RootStyleRegistry({
28
+ children,
29
+ cacheKey
30
+ }) {
31
+ const [{ cache: cache2, flush }] = useState(() => createRootStyleCache({ key: cacheKey ?? "mswft" }));
28
32
  useServerInsertedHTML(() => {
29
33
  const names = flush();
30
34
  if (names.length === 0)
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/next/root-style-registry.tsx"],"sourcesContent":["'use client'\n\nimport createCache, { EmotionCache } from '@emotion/cache'\nimport { cache } from '@emotion/css'\nimport { useServerInsertedHTML } from 'next/navigation'\nimport { ReactNode, createContext, useContext, useState } from 'react'\n\nconst CacheContext = createContext(cache)\n\nexport function RootStyleRegistry({ children }: { children: ReactNode }) {\n const [{ cache, flush }] = useState(() => {\n const cache = createCache({ key: 'css' })\n cache.compat = true\n const prevInsert = cache.insert\n let inserted: string[] = []\n cache.insert = (...args) => {\n const serialized = args[1]\n if (cache.inserted[serialized.name] === undefined) {\n inserted.push(serialized.name)\n }\n return prevInsert(...args)\n }\n const flush = () => {\n const prevInserted = inserted\n inserted = []\n return prevInserted\n }\n return { cache, flush }\n })\n\n useServerInsertedHTML(() => {\n const names = flush()\n if (names.length === 0) return null\n let styles = ''\n for (const name of names) {\n styles += cache.inserted[name]\n }\n return (\n <style\n data-emotion={`${cache.key} ${names.join(' ')}`}\n dangerouslySetInnerHTML={{\n __html: styles,\n }}\n />\n )\n })\n\n return <CacheContext.Provider value={cache}>{children}</CacheContext.Provider>\n}\n\nexport function useCache(): EmotionCache {\n return useContext(CacheContext)\n}\n"],"mappings":";AAsCM;AApCN,OAAO,iBAAmC;AAC1C,SAAS,aAAa;AACtB,SAAS,6BAA6B;AACtC,SAAoB,eAAe,YAAY,gBAAgB;AAE/D,MAAM,eAAe,cAAc,KAAK;AAEjC,SAAS,kBAAkB,EAAE,SAAS,GAA4B;AACvE,QAAM,CAAC,EAAE,OAAAA,QAAO,MAAM,CAAC,IAAI,SAAS,MAAM;AACxC,UAAMA,SAAQ,YAAY,EAAE,KAAK,MAAM,CAAC;AACxC,IAAAA,OAAM,SAAS;AACf,UAAM,aAAaA,OAAM;AACzB,QAAI,WAAqB,CAAC;AAC1B,IAAAA,OAAM,SAAS,IAAI,SAAS;AAC1B,YAAM,aAAa,KAAK,CAAC;AACzB,UAAIA,OAAM,SAAS,WAAW,IAAI,MAAM,QAAW;AACjD,iBAAS,KAAK,WAAW,IAAI;AAAA,MAC/B;AACA,aAAO,WAAW,GAAG,IAAI;AAAA,IAC3B;AACA,UAAMC,SAAQ,MAAM;AAClB,YAAM,eAAe;AACrB,iBAAW,CAAC;AACZ,aAAO;AAAA,IACT;AACA,WAAO,EAAE,OAAAD,QAAO,OAAAC,OAAM;AAAA,EACxB,CAAC;AAED,wBAAsB,MAAM;AAC1B,UAAM,QAAQ,MAAM;AACpB,QAAI,MAAM,WAAW;AAAG,aAAO;AAC/B,QAAI,SAAS;AACb,eAAW,QAAQ,OAAO;AACxB,gBAAUD,OAAM,SAAS,IAAI;AAAA,IAC/B;AACA,WACE;AAAA,MAAC;AAAA;AAAA,QACC,gBAAc,GAAGA,OAAM,GAAG,IAAI,MAAM,KAAK,GAAG,CAAC;AAAA,QAC7C,yBAAyB;AAAA,UACvB,QAAQ;AAAA,QACV;AAAA;AAAA,IACF;AAAA,EAEJ,CAAC;AAED,SAAO,oBAAC,aAAa,UAAb,EAAsB,OAAOA,QAAQ,UAAS;AACxD;AAEO,SAAS,WAAyB;AACvC,SAAO,WAAW,YAAY;AAChC;","names":["cache","flush"]}
1
+ {"version":3,"sources":["../../../src/next/root-style-registry.tsx"],"sourcesContent":["'use client'\n\nimport createCache, { EmotionCache } from '@emotion/cache'\nimport { cache } from '@emotion/css'\nimport { useServerInsertedHTML } from 'next/navigation'\nimport { ReactNode, createContext, useContext, useState } from 'react'\n\nconst CacheContext = createContext(cache)\n\nconst createRootStyleCache = ({ key }: { key: string }) => {\n const cache = createCache({ key })\n cache.compat = true\n\n const prevInsert = cache.insert\n let inserted: string[] = []\n\n cache.insert = (...args) => {\n const serialized = args[1]\n if (cache.inserted[serialized.name] === undefined) {\n inserted.push(serialized.name)\n }\n return prevInsert(...args)\n }\n\n const flush = () => {\n const prevInserted = inserted\n inserted = []\n return prevInserted\n }\n\n return { cache, flush }\n}\n\nexport function RootStyleRegistry({\n children,\n cacheKey,\n}: {\n children: ReactNode\n cacheKey?: string\n}) {\n const [{ cache, flush }] = useState(() => createRootStyleCache({ key: cacheKey ?? 'mswft' }))\n\n useServerInsertedHTML(() => {\n const names = flush()\n if (names.length === 0) return null\n let styles = ''\n for (const name of names) {\n styles += cache.inserted[name]\n }\n\n return (\n <style\n data-emotion={`${cache.key} ${names.join(' ')}`}\n dangerouslySetInnerHTML={{\n __html: styles,\n }}\n />\n )\n })\n\n return <CacheContext.Provider value={cache}>{children}</CacheContext.Provider>\n}\n\nexport function useCache(): EmotionCache {\n return useContext(CacheContext)\n}\n"],"mappings":";AAmDM;AAjDN,OAAO,iBAAmC;AAC1C,SAAS,aAAa;AACtB,SAAS,6BAA6B;AACtC,SAAoB,eAAe,YAAY,gBAAgB;AAE/D,MAAM,eAAe,cAAc,KAAK;AAExC,MAAM,uBAAuB,CAAC,EAAE,IAAI,MAAuB;AACzD,QAAMA,SAAQ,YAAY,EAAE,IAAI,CAAC;AACjC,EAAAA,OAAM,SAAS;AAEf,QAAM,aAAaA,OAAM;AACzB,MAAI,WAAqB,CAAC;AAE1B,EAAAA,OAAM,SAAS,IAAI,SAAS;AAC1B,UAAM,aAAa,KAAK,CAAC;AACzB,QAAIA,OAAM,SAAS,WAAW,IAAI,MAAM,QAAW;AACjD,eAAS,KAAK,WAAW,IAAI;AAAA,IAC/B;AACA,WAAO,WAAW,GAAG,IAAI;AAAA,EAC3B;AAEA,QAAM,QAAQ,MAAM;AAClB,UAAM,eAAe;AACrB,eAAW,CAAC;AACZ,WAAO;AAAA,EACT;AAEA,SAAO,EAAE,OAAAA,QAAO,MAAM;AACxB;AAEO,SAAS,kBAAkB;AAAA,EAChC;AAAA,EACA;AACF,GAGG;AACD,QAAM,CAAC,EAAE,OAAAA,QAAO,MAAM,CAAC,IAAI,SAAS,MAAM,qBAAqB,EAAE,KAAK,YAAY,QAAQ,CAAC,CAAC;AAE5F,wBAAsB,MAAM;AAC1B,UAAM,QAAQ,MAAM;AACpB,QAAI,MAAM,WAAW;AAAG,aAAO;AAC/B,QAAI,SAAS;AACb,eAAW,QAAQ,OAAO;AACxB,gBAAUA,OAAM,SAAS,IAAI;AAAA,IAC/B;AAEA,WACE;AAAA,MAAC;AAAA;AAAA,QACC,gBAAc,GAAGA,OAAM,GAAG,IAAI,MAAM,KAAK,GAAG,CAAC;AAAA,QAC7C,yBAAyB;AAAA,UACvB,QAAQ;AAAA,QACV;AAAA;AAAA,IACF;AAAA,EAEJ,CAAC;AAED,SAAO,oBAAC,aAAa,UAAb,EAAsB,OAAOA,QAAQ,UAAS;AACxD;AAEO,SAAS,WAAyB;AACvC,SAAO,WAAW,YAAY;AAChC;","names":["cache"]}
@@ -1,8 +1,6 @@
1
1
  import { MakeswiftApiHandler } from "./api-handler";
2
2
  import { getSiteVersion } from "./draft-mode";
3
- import { DraftModeScript } from "./draft-mode/draft-mode-script";
4
3
  export {
5
- DraftModeScript,
6
4
  MakeswiftApiHandler,
7
5
  getSiteVersion
8
6
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/next/server.ts"],"sourcesContent":["export { MakeswiftApiHandler } from './api-handler'\nexport type { Manifest, Font, MakeswiftApiHandlerResponse } from './api-handler'\nexport { getSiteVersion } from './draft-mode'\nexport { DraftModeScript } from './draft-mode/draft-mode-script'\n"],"mappings":"AAAA,SAAS,2BAA2B;AAEpC,SAAS,sBAAsB;AAC/B,SAAS,uBAAuB;","names":[]}
1
+ {"version":3,"sources":["../../../src/next/server.ts"],"sourcesContent":["export { MakeswiftApiHandler } from './api-handler'\nexport type { Manifest, Font, MakeswiftApiHandlerResponse } from './api-handler'\nexport { getSiteVersion } from './draft-mode'\n"],"mappings":"AAAA,SAAS,2BAA2B;AAEpC,SAAS,sBAAsB;","names":[]}
@@ -0,0 +1,37 @@
1
+ import { createRequest } from "node-mocks-http";
2
+ function urlToQuery(url) {
3
+ const segments = url.pathname.split("/").filter(Boolean);
4
+ if (segments.length === 0)
5
+ return {};
6
+ if (segments.length === 1)
7
+ return [segments[0]];
8
+ let structure = {};
9
+ let current = structure;
10
+ for (let i = 0; i < segments.length - 2; i++) {
11
+ current[segments[i]] = {};
12
+ current = current[segments[i]];
13
+ }
14
+ current[segments[segments.length - 2]] = [segments[segments.length - 1]];
15
+ return {
16
+ ...structure,
17
+ ...Object.fromEntries(
18
+ url.searchParams.entries()
19
+ )
20
+ };
21
+ }
22
+ function createNextApiRequest({
23
+ method,
24
+ path,
25
+ body
26
+ }) {
27
+ return createRequest({
28
+ method,
29
+ url: path,
30
+ query: urlToQuery(new URL(path, "http://localhost")),
31
+ body
32
+ });
33
+ }
34
+ export {
35
+ createNextApiRequest
36
+ };
37
+ //# sourceMappingURL=test-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/next/tests/test-utils.ts"],"sourcesContent":["import { NextApiRequest } from \"next\"\nimport { createRequest, RequestMethod } from \"node-mocks-http\"\n\ntype Query = { [key: string]: Query } | string[]\n\nfunction urlToQuery(url: URL): Query {\n const segments = url.pathname.split('/').filter(Boolean)\n\n if (segments.length === 0) return {}\n if (segments.length === 1) return [segments[0]]\n\n let structure: { [key: string]: any } = {}\n let current = structure\n\n for (let i = 0; i < segments.length - 2; i++) {\n current[segments[i]] = {}\n current = current[segments[i]]\n }\n\n current[segments[segments.length - 2]] = [segments[segments.length - 1]]\n\n return {\n ...structure,\n ...Object.fromEntries(\n url.searchParams.entries(),\n ),\n }\n}\n\nexport function createNextApiRequest({\n method,\n path,\n body\n}: {\n method: RequestMethod\n path: string\n body?: Record<string, unknown>\n}): NextApiRequest {\n return createRequest<NextApiRequest>({\n method,\n url: path,\n query: urlToQuery(new URL(path, 'http://localhost')),\n body\n })\n}\n"],"mappings":"AACA,SAAS,qBAAoC;AAI7C,SAAS,WAAW,KAAiB;AACnC,QAAM,WAAW,IAAI,SAAS,MAAM,GAAG,EAAE,OAAO,OAAO;AAEvD,MAAI,SAAS,WAAW;AAAG,WAAO,CAAC;AACnC,MAAI,SAAS,WAAW;AAAG,WAAO,CAAC,SAAS,CAAC,CAAC;AAE9C,MAAI,YAAoC,CAAC;AACzC,MAAI,UAAU;AAEd,WAAS,IAAI,GAAG,IAAI,SAAS,SAAS,GAAG,KAAK;AAC5C,YAAQ,SAAS,CAAC,CAAC,IAAI,CAAC;AACxB,cAAU,QAAQ,SAAS,CAAC,CAAC;AAAA,EAC/B;AAEA,UAAQ,SAAS,SAAS,SAAS,CAAC,CAAC,IAAI,CAAC,SAAS,SAAS,SAAS,CAAC,CAAC;AAEvE,SAAO;AAAA,IACL,GAAG;AAAA,IACH,GAAG,OAAO;AAAA,MACR,IAAI,aAAa,QAAQ;AAAA,IAC3B;AAAA,EACF;AACF;AAEO,SAAS,qBAAqB;AAAA,EACnC;AAAA,EACA;AAAA,EACA;AACF,GAImB;AACjB,SAAO,cAA8B;AAAA,IACnC;AAAA,IACA,KAAK;AAAA,IACL,OAAO,WAAW,IAAI,IAAI,MAAM,kBAAkB,CAAC;AAAA,IACnD;AAAA,EACF,CAAC;AACH;","names":[]}
@@ -1,11 +1,11 @@
1
1
  import { jsx } from "react/jsx-runtime";
2
2
  import { forwardRef, memo } from "react";
3
3
  import { getRootElement } from "../../../state/react-page";
4
- import { DocumentContext } from "../hooks/use-document-context";
4
+ import { DocumentKeyContext, DocumentLocaleContext } from "../hooks/use-document-context";
5
5
  import { Element } from "./Element";
6
6
  const Document = memo(
7
7
  forwardRef(function Document2({ document }, ref) {
8
- return /* @__PURE__ */ jsx(DocumentContext.Provider, { value: document, children: /* @__PURE__ */ jsx(Element, { ref, element: getRootElement(document) }) });
8
+ return /* @__PURE__ */ jsx(DocumentKeyContext.Provider, { value: document.key, children: /* @__PURE__ */ jsx(DocumentLocaleContext.Provider, { value: document.locale, children: /* @__PURE__ */ jsx(Element, { ref, element: getRootElement(document) }) }) });
9
9
  })
10
10
  );
11
11
  export {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/runtimes/react/components/Document.tsx"],"sourcesContent":["import { Ref, forwardRef, memo } from 'react'\nimport { type Document as ReactPageDocument, getRootElement } from '../../../state/react-page'\nimport { ElementImperativeHandle } from '../element-imperative-handle'\nimport { DocumentContext } from '../hooks/use-document-context'\nimport { Element } from './Element'\n\ntype DocumentProps = {\n document: ReactPageDocument\n}\n\nexport const Document = memo(\n forwardRef(function Document(\n { document }: DocumentProps,\n ref: Ref<ElementImperativeHandle>,\n ): JSX.Element {\n return (\n <DocumentContext.Provider value={document}>\n <Element ref={ref} element={getRootElement(document)} />\n </DocumentContext.Provider>\n )\n }),\n)\n"],"mappings":"AAiBQ;AAjBR,SAAc,YAAY,YAAY;AACtC,SAA6C,sBAAsB;AAEnE,SAAS,uBAAuB;AAChC,SAAS,eAAe;AAMjB,MAAM,WAAW;AAAA,EACtB,WAAW,SAASA,UAClB,EAAE,SAAS,GACX,KACa;AACb,WACE,oBAAC,gBAAgB,UAAhB,EAAyB,OAAO,UAC/B,8BAAC,WAAQ,KAAU,SAAS,eAAe,QAAQ,GAAG,GACxD;AAAA,EAEJ,CAAC;AACH;","names":["Document"]}
1
+ {"version":3,"sources":["../../../../../src/runtimes/react/components/Document.tsx"],"sourcesContent":["import { Ref, forwardRef, memo } from 'react'\nimport { type Document as ReactPageDocument, getRootElement } from '../../../state/react-page'\nimport { ElementImperativeHandle } from '../element-imperative-handle'\nimport { DocumentKeyContext, DocumentLocaleContext } from '../hooks/use-document-context'\nimport { Element } from './Element'\n\ntype DocumentProps = {\n document: ReactPageDocument\n}\n\nexport const Document = memo(\n forwardRef(function Document(\n { document }: DocumentProps,\n ref: Ref<ElementImperativeHandle>,\n ): JSX.Element {\n return (\n <DocumentKeyContext.Provider value={document.key}>\n <DocumentLocaleContext.Provider value={document.locale}>\n <Element ref={ref} element={getRootElement(document)} />\n </DocumentLocaleContext.Provider>\n </DocumentKeyContext.Provider>\n )\n }),\n)\n"],"mappings":"AAkBU;AAlBV,SAAc,YAAY,YAAY;AACtC,SAA6C,sBAAsB;AAEnE,SAAS,oBAAoB,6BAA6B;AAC1D,SAAS,eAAe;AAMjB,MAAM,WAAW;AAAA,EACtB,WAAW,SAASA,UAClB,EAAE,SAAS,GACX,KACa;AACb,WACE,oBAAC,mBAAmB,UAAnB,EAA4B,OAAO,SAAS,KAC3C,8BAAC,sBAAsB,UAAtB,EAA+B,OAAO,SAAS,QAC9C,8BAAC,WAAQ,KAAU,SAAS,eAAe,QAAQ,GAAG,GACxD,GACF;AAAA,EAEJ,CAAC;AACH;","names":["Document"]}
@@ -9,6 +9,7 @@ const ElementData = memo(
9
9
  forwardRef(function ElementData2({ elementData }, ref) {
10
10
  const Component = useComponent(elementData.type);
11
11
  if (Component == null) {
12
+ console.warn(`Unknown component '${elementData.type}'`, { elementData });
12
13
  return /* @__PURE__ */ jsx(FallbackComponent, { ref, text: "Component not found" });
13
14
  }
14
15
  const forwardRef2 = canAcceptRef(Component);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/runtimes/react/components/ElementData.tsx"],"sourcesContent":["import { Ref, Suspense, forwardRef, memo } from 'react'\nimport { ElementData as ReactPageElementData } from '../../../state/react-page'\nimport { useComponent } from '../hooks/use-component'\nimport { canAcceptRef } from '../utils/can-accept-ref'\nimport { FallbackComponent } from '../../../components/shared/FallbackComponent'\nimport { ResolveProps } from '../controls'\n\ntype ElementDataProps = {\n elementData: ReactPageElementData\n}\n\nexport const ElementData = memo(\n forwardRef(function ElementData(\n { elementData }: ElementDataProps,\n ref: Ref<unknown>,\n ): JSX.Element {\n const Component = useComponent(elementData.type)\n\n if (Component == null) {\n return <FallbackComponent ref={ref as Ref<HTMLDivElement>} text=\"Component not found\" />\n }\n\n const forwardRef = canAcceptRef(Component)\n\n return (\n <Suspense>\n <ResolveProps element={elementData}>\n {props =>\n forwardRef ? (\n <Component {...props} key={elementData.key} ref={ref} />\n ) : (\n <Component {...props} key={elementData.key} />\n )\n }\n </ResolveProps>\n </Suspense>\n )\n }),\n)\n"],"mappings":"AAmBa;AAUC;AA7Bd,SAAc,UAAU,YAAY,YAAY;AAEhD,SAAS,oBAAoB;AAC7B,SAAS,oBAAoB;AAC7B,SAAS,yBAAyB;AAClC,SAAS,oBAAoB;AAMtB,MAAM,cAAc;AAAA,EACzB,WAAW,SAASA,aAClB,EAAE,YAAY,GACd,KACa;AACb,UAAM,YAAY,aAAa,YAAY,IAAI;AAE/C,QAAI,aAAa,MAAM;AACrB,aAAO,oBAAC,qBAAkB,KAAiC,MAAK,uBAAsB;AAAA,IACxF;AAEA,UAAMC,cAAa,aAAa,SAAS;AAEzC,WACE,oBAAC,YACC,8BAAC,gBAAa,SAAS,aACpB,qBACCA,cACE,8BAAC,aAAW,GAAG,OAAO,KAAK,YAAY,KAAK,KAAU,IAEtD,8BAAC,aAAW,GAAG,OAAO,KAAK,YAAY,KAAK,GAGlD,GACF;AAAA,EAEJ,CAAC;AACH;","names":["ElementData","forwardRef"]}
1
+ {"version":3,"sources":["../../../../../src/runtimes/react/components/ElementData.tsx"],"sourcesContent":["import { Ref, Suspense, forwardRef, memo } from 'react'\nimport { ElementData as ReactPageElementData } from '../../../state/react-page'\nimport { useComponent } from '../hooks/use-component'\nimport { canAcceptRef } from '../utils/can-accept-ref'\nimport { FallbackComponent } from '../../../components/shared/FallbackComponent'\nimport { ResolveProps } from '../controls'\n\ntype ElementDataProps = {\n elementData: ReactPageElementData\n}\n\nexport const ElementData = memo(\n forwardRef(function ElementData(\n { elementData }: ElementDataProps,\n ref: Ref<unknown>,\n ): JSX.Element {\n const Component = useComponent(elementData.type)\n\n if (Component == null) {\n console.warn(`Unknown component '${elementData.type}'`, { elementData })\n return <FallbackComponent ref={ref as Ref<HTMLDivElement>} text=\"Component not found\" />\n }\n\n const forwardRef = canAcceptRef(Component)\n\n return (\n <Suspense>\n <ResolveProps element={elementData}>\n {props =>\n forwardRef ? (\n <Component {...props} key={elementData.key} ref={ref} />\n ) : (\n <Component {...props} key={elementData.key} />\n )\n }\n </ResolveProps>\n </Suspense>\n )\n }),\n)\n"],"mappings":"AAoBa;AAUC;AA9Bd,SAAc,UAAU,YAAY,YAAY;AAEhD,SAAS,oBAAoB;AAC7B,SAAS,oBAAoB;AAC7B,SAAS,yBAAyB;AAClC,SAAS,oBAAoB;AAMtB,MAAM,cAAc;AAAA,EACzB,WAAW,SAASA,aAClB,EAAE,YAAY,GACd,KACa;AACb,UAAM,YAAY,aAAa,YAAY,IAAI;AAE/C,QAAI,aAAa,MAAM;AACrB,cAAQ,KAAK,sBAAsB,YAAY,IAAI,KAAK,EAAE,YAAY,CAAC;AACvE,aAAO,oBAAC,qBAAkB,KAAiC,MAAK,uBAAsB;AAAA,IACxF;AAEA,UAAMC,cAAa,aAAa,SAAS;AAEzC,WACE,oBAAC,YACC,8BAAC,gBAAa,SAAS,aACpB,qBACCA,cACE,8BAAC,aAAW,GAAG,OAAO,KAAK,YAAY,KAAK,KAAU,IAEtD,8BAAC,aAAW,GAAG,OAAO,KAAK,YAAY,KAAK,GAGlD,GACF;AAAA,EAEJ,CAAC;AACH;","names":["ElementData","forwardRef"]}
@@ -1,27 +1,38 @@
1
1
  "use client";
2
- import { jsx } from "react/jsx-runtime";
2
+ import { jsx, jsxs } from "react/jsx-runtime";
3
3
  import { useMemo, lazy } from "react";
4
4
  import { MakeswiftHostApiClient } from "../../../api/react";
5
5
  import { ReactRuntimeContext } from "../hooks/use-react-runtime";
6
6
  import { MakeswiftHostApiClientProvider } from "../host-api-client";
7
+ import { MakeswiftSiteVersion } from "../../../api/site-version";
8
+ import { DraftSwitcher } from "./draft-switcher/draft-switcher";
9
+ import { useBuilderHandshake } from "./hooks/use-builder-handshake";
10
+ import { useBuilderConnectionPing } from "./hooks/use-builder-connection-ping";
7
11
  const LiveProvider = lazy(() => import("./LiveProvider"));
8
12
  const PreviewProvider = lazy(() => import("./PreviewProvider"));
9
13
  function ReactRuntimeProvider({
10
14
  children,
11
15
  runtime,
12
16
  previewMode,
17
+ appOrigin = "https://app.makeswift.com",
13
18
  apiOrigin = "https://api.makeswift.com",
14
19
  locale = void 0
15
20
  }) {
16
21
  const client = useMemo(
17
22
  () => new MakeswiftHostApiClient({
18
23
  uri: new URL("graphql", apiOrigin).href,
19
- locale
24
+ locale,
25
+ siteVersion: previewMode ? MakeswiftSiteVersion.Working : MakeswiftSiteVersion.Live
20
26
  }),
21
- [apiOrigin, locale]
27
+ [apiOrigin, locale, previewMode]
22
28
  );
23
29
  const StoreProvider = previewMode ? PreviewProvider : LiveProvider;
24
- return /* @__PURE__ */ jsx(ReactRuntimeContext.Provider, { value: runtime, children: /* @__PURE__ */ jsx(MakeswiftHostApiClientProvider, { client, children: /* @__PURE__ */ jsx(StoreProvider, { children }) }) });
30
+ useBuilderHandshake({ appOrigin });
31
+ useBuilderConnectionPing({ appOrigin });
32
+ return /* @__PURE__ */ jsx(ReactRuntimeContext.Provider, { value: runtime, children: /* @__PURE__ */ jsx(MakeswiftHostApiClientProvider, { client, children: /* @__PURE__ */ jsxs(StoreProvider, { children: [
33
+ children,
34
+ /* @__PURE__ */ jsx(DraftSwitcher, { isDraft: previewMode })
35
+ ] }) }) });
25
36
  }
26
37
  export {
27
38
  ReactRuntimeProvider
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/runtimes/react/components/RuntimeProvider.tsx"],"sourcesContent":["'use client'\n\nimport { ReactNode, useMemo, lazy } from 'react'\n\nimport { MakeswiftHostApiClient } from '../../../api/react'\nimport { ReactRuntimeContext } from '../hooks/use-react-runtime'\nimport { ReactRuntime } from '../react-runtime'\nimport { MakeswiftHostApiClientProvider } from '../host-api-client'\n\nconst LiveProvider = lazy(() => import('./LiveProvider'))\nconst PreviewProvider = lazy(() => import('./PreviewProvider'))\n\nexport function ReactRuntimeProvider({\n children,\n runtime,\n previewMode,\n apiOrigin = 'https://api.makeswift.com',\n locale = undefined,\n}: {\n children: ReactNode\n runtime: ReactRuntime\n previewMode: boolean\n apiOrigin?: string\n locale?: string\n}) {\n const client = useMemo(\n () =>\n new MakeswiftHostApiClient({\n uri: new URL('graphql', apiOrigin).href,\n locale,\n }),\n [apiOrigin, locale],\n )\n\n const StoreProvider = previewMode ? PreviewProvider : LiveProvider\n\n return (\n <ReactRuntimeContext.Provider value={runtime}>\n <MakeswiftHostApiClientProvider client={client}>\n <StoreProvider>{children}</StoreProvider>\n </MakeswiftHostApiClientProvider>\n </ReactRuntimeContext.Provider>\n )\n}\n"],"mappings":";AAuCQ;AArCR,SAAoB,SAAS,YAAY;AAEzC,SAAS,8BAA8B;AACvC,SAAS,2BAA2B;AAEpC,SAAS,sCAAsC;AAE/C,MAAM,eAAe,KAAK,MAAM,OAAO,gBAAgB,CAAC;AACxD,MAAM,kBAAkB,KAAK,MAAM,OAAO,mBAAmB,CAAC;AAEvD,SAAS,qBAAqB;AAAA,EACnC;AAAA,EACA;AAAA,EACA;AAAA,EACA,YAAY;AAAA,EACZ,SAAS;AACX,GAMG;AACD,QAAM,SAAS;AAAA,IACb,MACE,IAAI,uBAAuB;AAAA,MACzB,KAAK,IAAI,IAAI,WAAW,SAAS,EAAE;AAAA,MACnC;AAAA,IACF,CAAC;AAAA,IACH,CAAC,WAAW,MAAM;AAAA,EACpB;AAEA,QAAM,gBAAgB,cAAc,kBAAkB;AAEtD,SACE,oBAAC,oBAAoB,UAApB,EAA6B,OAAO,SACnC,8BAAC,kCAA+B,QAC9B,8BAAC,iBAAe,UAAS,GAC3B,GACF;AAEJ;","names":[]}
1
+ {"version":3,"sources":["../../../../../src/runtimes/react/components/RuntimeProvider.tsx"],"sourcesContent":["'use client'\n\nimport { ReactNode, useMemo, lazy } from 'react'\n\nimport { MakeswiftHostApiClient } from '../../../api/react'\nimport { ReactRuntimeContext } from '../hooks/use-react-runtime'\nimport { ReactRuntime } from '../react-runtime'\nimport { MakeswiftHostApiClientProvider } from '../host-api-client'\nimport { MakeswiftSiteVersion } from '../../../api/site-version'\nimport { DraftSwitcher } from './draft-switcher/draft-switcher'\nimport { useBuilderHandshake } from './hooks/use-builder-handshake'\nimport { useBuilderConnectionPing } from './hooks/use-builder-connection-ping'\n\nconst LiveProvider = lazy(() => import('./LiveProvider'))\nconst PreviewProvider = lazy(() => import('./PreviewProvider'))\n\nexport function ReactRuntimeProvider({\n children,\n runtime,\n previewMode,\n appOrigin = 'https://app.makeswift.com',\n apiOrigin = 'https://api.makeswift.com',\n locale = undefined,\n}: {\n children: ReactNode\n runtime: ReactRuntime\n previewMode: boolean\n apiOrigin?: string\n appOrigin?: string\n locale?: string\n}) {\n const client = useMemo(\n () =>\n new MakeswiftHostApiClient({\n uri: new URL('graphql', apiOrigin).href,\n locale,\n siteVersion: previewMode ? MakeswiftSiteVersion.Working : MakeswiftSiteVersion.Live,\n }),\n [apiOrigin, locale, previewMode],\n )\n\n const StoreProvider = previewMode ? PreviewProvider : LiveProvider\n\n useBuilderHandshake({ appOrigin })\n useBuilderConnectionPing({ appOrigin })\n\n return (\n <ReactRuntimeContext.Provider value={runtime}>\n <MakeswiftHostApiClientProvider client={client}>\n <StoreProvider>\n {children}\n <DraftSwitcher isDraft={previewMode} />\n </StoreProvider>\n </MakeswiftHostApiClientProvider>\n </ReactRuntimeContext.Provider>\n )\n}\n"],"mappings":";AAiDQ,SAEE,KAFF;AA/CR,SAAoB,SAAS,YAAY;AAEzC,SAAS,8BAA8B;AACvC,SAAS,2BAA2B;AAEpC,SAAS,sCAAsC;AAC/C,SAAS,4BAA4B;AACrC,SAAS,qBAAqB;AAC9B,SAAS,2BAA2B;AACpC,SAAS,gCAAgC;AAEzC,MAAM,eAAe,KAAK,MAAM,OAAO,gBAAgB,CAAC;AACxD,MAAM,kBAAkB,KAAK,MAAM,OAAO,mBAAmB,CAAC;AAEvD,SAAS,qBAAqB;AAAA,EACnC;AAAA,EACA;AAAA,EACA;AAAA,EACA,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,SAAS;AACX,GAOG;AACD,QAAM,SAAS;AAAA,IACb,MACE,IAAI,uBAAuB;AAAA,MACzB,KAAK,IAAI,IAAI,WAAW,SAAS,EAAE;AAAA,MACnC;AAAA,MACA,aAAa,cAAc,qBAAqB,UAAU,qBAAqB;AAAA,IACjF,CAAC;AAAA,IACH,CAAC,WAAW,QAAQ,WAAW;AAAA,EACjC;AAEA,QAAM,gBAAgB,cAAc,kBAAkB;AAEtD,sBAAoB,EAAE,UAAU,CAAC;AACjC,2BAAyB,EAAE,UAAU,CAAC;AAEtC,SACE,oBAAC,oBAAoB,UAApB,EAA6B,OAAO,SACnC,8BAAC,kCAA+B,QAC9B,+BAAC,iBACE;AAAA;AAAA,IACD,oBAAC,iBAAc,SAAS,aAAa;AAAA,KACvC,GACF,GACF;AAEJ;","names":[]}
@@ -0,0 +1,48 @@
1
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
+ import { useEffect, useRef, useState } from "react";
3
+ import { createPortal } from "react-dom";
4
+ import { useIsInBuilder } from "../../hooks/use-is-in-builder";
5
+ import { DraftToolbar } from "./draft-toolbar";
6
+ const ClearDraftModeRequestPath = "/api/makeswift/clear-draft";
7
+ async function exitDraftMode() {
8
+ try {
9
+ await fetch(ClearDraftModeRequestPath);
10
+ window.location.reload();
11
+ } catch (err) {
12
+ console.error("Could not clear Makeswift cookies. Please report this error to your developer.");
13
+ console.error(err);
14
+ }
15
+ }
16
+ function DraftSwitcher({ isDraft }) {
17
+ const shadowContainerRef = useRef(null);
18
+ const [shadowRoot, setShadowRoot] = useState(null);
19
+ const isInBuilder = useIsInBuilder();
20
+ const showToolbar = !isInBuilder && isDraft;
21
+ useEffect(() => {
22
+ if (!showToolbar)
23
+ return;
24
+ if (shadowContainerRef.current && shadowContainerRef.current.shadowRoot == null && shadowRoot == null) {
25
+ const root = shadowContainerRef.current.attachShadow({ mode: "open" });
26
+ setShadowRoot(root);
27
+ }
28
+ }, [showToolbar, shadowRoot, setShadowRoot]);
29
+ if (!showToolbar)
30
+ return null;
31
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
32
+ showToolbar && /* @__PURE__ */ jsx("span", { id: "makeswift-draft-switcher", ref: shadowContainerRef, children: shadowRoot ? createPortal(/* @__PURE__ */ jsx(DraftToolbar, { onExitDraft: exitDraftMode }), shadowRoot) : null }),
33
+ /* @__PURE__ */ jsx(
34
+ "script",
35
+ {
36
+ type: "application/json",
37
+ id: "makeswift-draft-info",
38
+ dangerouslySetInnerHTML: {
39
+ __html: JSON.stringify({ draft: isDraft, inBuilder: isInBuilder })
40
+ }
41
+ }
42
+ )
43
+ ] });
44
+ }
45
+ export {
46
+ DraftSwitcher
47
+ };
48
+ //# sourceMappingURL=draft-switcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../../src/runtimes/react/components/draft-switcher/draft-switcher.tsx"],"sourcesContent":["import { useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\n\nimport { useIsInBuilder } from '../../hooks/use-is-in-builder'\nimport { DraftToolbar } from './draft-toolbar'\n\nconst ClearDraftModeRequestPath = '/api/makeswift/clear-draft'\n\nasync function exitDraftMode() {\n try {\n await fetch(ClearDraftModeRequestPath)\n window.location.reload()\n } catch (err) {\n console.error('Could not clear Makeswift cookies. Please report this error to your developer.')\n console.error(err)\n }\n}\n\nexport function DraftSwitcher({ isDraft }: { isDraft: boolean }) {\n const shadowContainerRef = useRef<HTMLSpanElement | null>(null)\n const [shadowRoot, setShadowRoot] = useState<ShadowRoot | null>(null)\n const isInBuilder = useIsInBuilder()\n\n const showToolbar = !isInBuilder && isDraft\n\n useEffect(() => {\n if (!showToolbar) return\n if (\n shadowContainerRef.current &&\n shadowContainerRef.current.shadowRoot == null &&\n shadowRoot == null\n ) {\n const root = shadowContainerRef.current.attachShadow({ mode: 'open' })\n setShadowRoot(root)\n }\n }, [showToolbar, shadowRoot, setShadowRoot])\n\n if (!showToolbar) return null\n\n return (\n <>\n {showToolbar && (\n <span id=\"makeswift-draft-switcher\" ref={shadowContainerRef}>\n {shadowRoot\n ? createPortal(<DraftToolbar onExitDraft={exitDraftMode} />, shadowRoot)\n : null}\n </span>\n )}\n <script\n type=\"application/json\"\n id=\"makeswift-draft-info\"\n dangerouslySetInnerHTML={{\n __html: JSON.stringify({ draft: isDraft, inBuilder: isInBuilder }),\n }}\n />\n </>\n )\n}\n"],"mappings":"AAwCI,mBAIuB,KAJvB;AAxCJ,SAAS,WAAW,QAAQ,gBAAgB;AAC5C,SAAS,oBAAoB;AAE7B,SAAS,sBAAsB;AAC/B,SAAS,oBAAoB;AAE7B,MAAM,4BAA4B;AAElC,eAAe,gBAAgB;AAC7B,MAAI;AACF,UAAM,MAAM,yBAAyB;AACrC,WAAO,SAAS,OAAO;AAAA,EACzB,SAAS,KAAK;AACZ,YAAQ,MAAM,gFAAgF;AAC9F,YAAQ,MAAM,GAAG;AAAA,EACnB;AACF;AAEO,SAAS,cAAc,EAAE,QAAQ,GAAyB;AAC/D,QAAM,qBAAqB,OAA+B,IAAI;AAC9D,QAAM,CAAC,YAAY,aAAa,IAAI,SAA4B,IAAI;AACpE,QAAM,cAAc,eAAe;AAEnC,QAAM,cAAc,CAAC,eAAe;AAEpC,YAAU,MAAM;AACd,QAAI,CAAC;AAAa;AAClB,QACE,mBAAmB,WACnB,mBAAmB,QAAQ,cAAc,QACzC,cAAc,MACd;AACA,YAAM,OAAO,mBAAmB,QAAQ,aAAa,EAAE,MAAM,OAAO,CAAC;AACrE,oBAAc,IAAI;AAAA,IACpB;AAAA,EACF,GAAG,CAAC,aAAa,YAAY,aAAa,CAAC;AAE3C,MAAI,CAAC;AAAa,WAAO;AAEzB,SACE,iCACG;AAAA,mBACC,oBAAC,UAAK,IAAG,4BAA2B,KAAK,oBACtC,uBACG,aAAa,oBAAC,gBAAa,aAAa,eAAe,GAAI,UAAU,IACrE,MACN;AAAA,IAEF;AAAA,MAAC;AAAA;AAAA,QACC,MAAK;AAAA,QACL,IAAG;AAAA,QACH,yBAAyB;AAAA,UACvB,QAAQ,KAAK,UAAU,EAAE,OAAO,SAAS,WAAW,YAAY,CAAC;AAAA,QACnE;AAAA;AAAA,IACF;AAAA,KACF;AAEJ;","names":[]}
@@ -0,0 +1,55 @@
1
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
+ const makeswiftIcon = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACIAAAAiCAYAAAA6RwvCAAAACXBIWXMAABcRAAAXEQHKJvM/AAABjElEQVRYhc2XzU3EMBCFB8TddAAXn6EE6GCpgNABZ1/IXnymBOgAOmA7YM8+ABVsXEHQQFaKQryeN3Yk3ilKJtEnv/nLUd/3pFG0riGi88yrnQn+UfJ5FUi0riWiB2H4nQn+KRd0DFP8agXEfkqCYJBoHdtxIQxfm+DfFgEhoith3NYE30o/qgGR2BJB+xY7kdYEL8oNFUi0jiFMJuxVWrJqEMFxsyUNCsE6AeNztvBp7aJ143vXksoRnwhYtmNdSoIQa6RlO9YXEWW7KgoCleOgxgTf1QZBT+RZ2lXFING6UxCCq+ceeUE8fYdknY599v9sJvzGBP+yCEgC7GPmETc0OJ+0awAlkhe2pAbIXAeFZ8xe2g2Nk3c3ub0xwWt6zY9qbmiqGVMbZK21ZC/YmhlbeBMTzZNDQqcvDb1kM1x32iqZSt1HaqukfKvq34BAOTLsrH+ETNmUkKHHA+428RgeclPVWozeSyAI2EdWB34jtqXNTAySOY3i/KgFIlqOa4GkFmBegorzg4joG07he/M7zl6jAAAAAElFTkSuQmCC";
3
+ const styles = `
4
+ .exit-preview-container {
5
+ position: fixed;
6
+ bottom: 16px;
7
+ right: 16px;
8
+ z-index: 2147483647;
9
+ }
10
+
11
+ .exit-preview-button {
12
+ background: #2e2e2e;
13
+ padding: 10px 18px 10px 14px;
14
+ border: 0px;
15
+ border-radius: 32px;
16
+ color: #efefef;
17
+ box-shadow:
18
+ 0 11px 40px 0 rgba(0, 0, 0, 0.25),
19
+ 0 2px 10px 0 rgba(0, 0, 0, 0.12);
20
+ transition: 150ms;
21
+
22
+ font-family: system-ui, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji',
23
+ 'Segoe UI Emoji';
24
+ font-size: 14px;
25
+ cursor: pointer;
26
+
27
+ display: flex;
28
+ align-items: center;
29
+ gap: 6px;
30
+ }
31
+
32
+ .exit-preview-button > .label {
33
+ transform: translateY(-1px);
34
+ }
35
+
36
+ .exit-preview-container:hover > .exit-preview-button {
37
+ transform: translateY(-2px);
38
+ box-shadow:
39
+ 0 15px 40px 0 rgba(0, 0, 0, 0.3),
40
+ 0 6px 10px 0 rgba(0, 0, 0, 0.15);
41
+ }
42
+ `;
43
+ function DraftToolbar({ onExitDraft }) {
44
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
45
+ /* @__PURE__ */ jsx("style", { dangerouslySetInnerHTML: { __html: styles } }),
46
+ /* @__PURE__ */ jsx("div", { className: "exit-preview-container", children: /* @__PURE__ */ jsxs("button", { className: "exit-preview-button", onClick: onExitDraft, children: [
47
+ /* @__PURE__ */ jsx("img", { src: makeswiftIcon, alt: "Makeswift Logo", width: 18, height: 18 }),
48
+ /* @__PURE__ */ jsx("span", { className: "label", children: "Exit Preview" })
49
+ ] }) })
50
+ ] });
51
+ }
52
+ export {
53
+ DraftToolbar
54
+ };
55
+ //# sourceMappingURL=draft-toolbar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../../src/runtimes/react/components/draft-switcher/draft-toolbar.tsx"],"sourcesContent":["const makeswiftIcon =\n 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACIAAAAiCAYAAAA6RwvCAAAACXBIWXMAABcRAAAXEQHKJvM/AAABjElEQVRYhc2XzU3EMBCFB8TddAAXn6EE6GCpgNABZ1/IXnymBOgAOmA7YM8+ABVsXEHQQFaKQryeN3Yk3ilKJtEnv/nLUd/3pFG0riGi88yrnQn+UfJ5FUi0riWiB2H4nQn+KRd0DFP8agXEfkqCYJBoHdtxIQxfm+DfFgEhoith3NYE30o/qgGR2BJB+xY7kdYEL8oNFUi0jiFMJuxVWrJqEMFxsyUNCsE6AeNztvBp7aJ143vXksoRnwhYtmNdSoIQa6RlO9YXEWW7KgoCleOgxgTf1QZBT+RZ2lXFING6UxCCq+ceeUE8fYdknY599v9sJvzGBP+yCEgC7GPmETc0OJ+0awAlkhe2pAbIXAeFZ8xe2g2Nk3c3ub0xwWt6zY9qbmiqGVMbZK21ZC/YmhlbeBMTzZNDQqcvDb1kM1x32iqZSt1HaqukfKvq34BAOTLsrH+ETNmUkKHHA+428RgeclPVWozeSyAI2EdWB34jtqXNTAySOY3i/KgFIlqOa4GkFmBegorzg4joG07he/M7zl6jAAAAAElFTkSuQmCC'\n\nconst styles = `\n.exit-preview-container {\n position: fixed;\n bottom: 16px;\n right: 16px;\n z-index: 2147483647;\n}\n\n.exit-preview-button {\n background: #2e2e2e;\n padding: 10px 18px 10px 14px;\n border: 0px;\n border-radius: 32px;\n color: #efefef;\n box-shadow:\n 0 11px 40px 0 rgba(0, 0, 0, 0.25),\n 0 2px 10px 0 rgba(0, 0, 0, 0.12);\n transition: 150ms;\n\n font-family: system-ui, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif, 'Apple Color Emoji',\n 'Segoe UI Emoji';\n font-size: 14px;\n cursor: pointer;\n\n display: flex;\n align-items: center;\n gap: 6px;\n}\n\n.exit-preview-button > .label {\n transform: translateY(-1px);\n}\n\n.exit-preview-container:hover > .exit-preview-button {\n transform: translateY(-2px);\n box-shadow:\n 0 15px 40px 0 rgba(0, 0, 0, 0.3),\n 0 6px 10px 0 rgba(0, 0, 0, 0.15);\n}\n`\n\ntype Props = {\n onExitDraft: () => void\n}\n\nexport function DraftToolbar({ onExitDraft }: Props) {\n return (\n <>\n <style dangerouslySetInnerHTML={{ __html: styles }} />\n <div className=\"exit-preview-container\">\n <button className=\"exit-preview-button\" onClick={onExitDraft}>\n <img src={makeswiftIcon} alt=\"Makeswift Logo\" width={18} height={18} />\n <span className=\"label\">Exit Preview</span>\n </button>\n </div>\n </>\n )\n}\n"],"mappings":"AAkDI,mBACE,KAEE,YAHJ;AAlDJ,MAAM,gBACJ;AAEF,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA6CR,SAAS,aAAa,EAAE,YAAY,GAAU;AACnD,SACE,iCACE;AAAA,wBAAC,WAAM,yBAAyB,EAAE,QAAQ,OAAO,GAAG;AAAA,IACpD,oBAAC,SAAI,WAAU,0BACb,+BAAC,YAAO,WAAU,uBAAsB,SAAS,aAC/C;AAAA,0BAAC,SAAI,KAAK,eAAe,KAAI,kBAAiB,OAAO,IAAI,QAAQ,IAAI;AAAA,MACrE,oBAAC,UAAK,WAAU,SAAQ,0BAAY;AAAA,OACtC,GACF;AAAA,KACF;AAEJ;","names":[]}
@@ -0,0 +1,43 @@
1
+ import { useEffect } from "react";
2
+ import { ActionTypes } from "../../../../react";
3
+ const CONNECTION_PING_INTERVAL_MS = 20;
4
+ function useBuilderConnectionPing({ appOrigin }) {
5
+ useEffect(() => {
6
+ let connectionInterval;
7
+ if (window.parent !== window) {
8
+ window.addEventListener("message", messageHandler);
9
+ window.parent.postMessage(
10
+ { type: ActionTypes.MAKESWIFT_CONNECTION_INIT },
11
+ { targetOrigin: appOrigin }
12
+ );
13
+ }
14
+ return () => {
15
+ window.removeEventListener("message", messageHandler);
16
+ if (connectionInterval != null) {
17
+ window.clearInterval(connectionInterval);
18
+ connectionInterval = null;
19
+ }
20
+ };
21
+ function messageHandler(event) {
22
+ if (event.origin === appOrigin && event.data.type === ActionTypes.MAKESWIFT_CONNECTION_INIT) {
23
+ if (connectionInterval != null) {
24
+ window.clearInterval(connectionInterval);
25
+ connectionInterval = null;
26
+ }
27
+ connectionInterval = window.setInterval(() => {
28
+ window.parent.postMessage(
29
+ {
30
+ type: ActionTypes.MAKESWIFT_CONNECTION_CHECK,
31
+ payload: { currentUrl: window.location.href }
32
+ },
33
+ { targetOrigin: appOrigin }
34
+ );
35
+ }, CONNECTION_PING_INTERVAL_MS);
36
+ }
37
+ }
38
+ }, [appOrigin]);
39
+ }
40
+ export {
41
+ useBuilderConnectionPing
42
+ };
43
+ //# sourceMappingURL=use-builder-connection-ping.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../../src/runtimes/react/components/hooks/use-builder-connection-ping.ts"],"sourcesContent":["import { useEffect } from 'react'\nimport { ActionTypes } from '../../../../react'\n\nconst CONNECTION_PING_INTERVAL_MS = 20\n\nexport function useBuilderConnectionPing({ appOrigin }: { appOrigin: string }) {\n useEffect(() => {\n let connectionInterval: number | null\n\n if (window.parent !== window) {\n window.addEventListener('message', messageHandler)\n window.parent.postMessage(\n { type: ActionTypes.MAKESWIFT_CONNECTION_INIT },\n { targetOrigin: appOrigin },\n )\n }\n\n return () => {\n window.removeEventListener('message', messageHandler)\n if (connectionInterval != null) {\n window.clearInterval(connectionInterval)\n connectionInterval = null\n }\n }\n\n function messageHandler(event: MessageEvent): void {\n if (event.origin === appOrigin && event.data.type === ActionTypes.MAKESWIFT_CONNECTION_INIT) {\n if (connectionInterval != null) {\n window.clearInterval(connectionInterval)\n connectionInterval = null\n }\n\n connectionInterval = window.setInterval(() => {\n window.parent.postMessage(\n {\n type: ActionTypes.MAKESWIFT_CONNECTION_CHECK,\n payload: { currentUrl: window.location.href },\n },\n { targetOrigin: appOrigin },\n )\n }, CONNECTION_PING_INTERVAL_MS)\n }\n }\n }, [appOrigin])\n}\n"],"mappings":"AAAA,SAAS,iBAAiB;AAC1B,SAAS,mBAAmB;AAE5B,MAAM,8BAA8B;AAE7B,SAAS,yBAAyB,EAAE,UAAU,GAA0B;AAC7E,YAAU,MAAM;AACd,QAAI;AAEJ,QAAI,OAAO,WAAW,QAAQ;AAC5B,aAAO,iBAAiB,WAAW,cAAc;AACjD,aAAO,OAAO;AAAA,QACZ,EAAE,MAAM,YAAY,0BAA0B;AAAA,QAC9C,EAAE,cAAc,UAAU;AAAA,MAC5B;AAAA,IACF;AAEA,WAAO,MAAM;AACX,aAAO,oBAAoB,WAAW,cAAc;AACpD,UAAI,sBAAsB,MAAM;AAC9B,eAAO,cAAc,kBAAkB;AACvC,6BAAqB;AAAA,MACvB;AAAA,IACF;AAEA,aAAS,eAAe,OAA2B;AACjD,UAAI,MAAM,WAAW,aAAa,MAAM,KAAK,SAAS,YAAY,2BAA2B;AAC3F,YAAI,sBAAsB,MAAM;AAC9B,iBAAO,cAAc,kBAAkB;AACvC,+BAAqB;AAAA,QACvB;AAEA,6BAAqB,OAAO,YAAY,MAAM;AAC5C,iBAAO,OAAO;AAAA,YACZ;AAAA,cACE,MAAM,YAAY;AAAA,cAClB,SAAS,EAAE,YAAY,OAAO,SAAS,KAAK;AAAA,YAC9C;AAAA,YACA,EAAE,cAAc,UAAU;AAAA,UAC5B;AAAA,QACF,GAAG,2BAA2B;AAAA,MAChC;AAAA,IACF;AAAA,EACF,GAAG,CAAC,SAAS,CAAC;AAChB;","names":[]}
@@ -0,0 +1,21 @@
1
+ import { useEffect, useMemo } from "react";
2
+ import { useIsPagesRouter } from "../../../../next/hooks/use-is-pages-router";
3
+ const PAGES_ROUTER_HANDSHAKE_MESSAGE = "makeswift_preview_mode";
4
+ const APP_ROUTER_HANDSHAKE_MESSAGE = "makeswift_draft_mode";
5
+ function useBuilderHandshake({ appOrigin }) {
6
+ const isPagesRouter = useIsPagesRouter();
7
+ const handshakeInitiationMessage = useMemo(() => {
8
+ if (isPagesRouter)
9
+ return PAGES_ROUTER_HANDSHAKE_MESSAGE;
10
+ return APP_ROUTER_HANDSHAKE_MESSAGE;
11
+ }, [isPagesRouter]);
12
+ useEffect(() => {
13
+ if (window.parent !== window) {
14
+ window.parent.postMessage({ type: handshakeInitiationMessage }, { targetOrigin: appOrigin });
15
+ }
16
+ }, [appOrigin, handshakeInitiationMessage]);
17
+ }
18
+ export {
19
+ useBuilderHandshake
20
+ };
21
+ //# sourceMappingURL=use-builder-handshake.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../../../src/runtimes/react/components/hooks/use-builder-handshake.ts"],"sourcesContent":["import { useEffect, useMemo } from 'react'\nimport { useIsPagesRouter } from '../../../../next/hooks/use-is-pages-router'\n\nconst PAGES_ROUTER_HANDSHAKE_MESSAGE = 'makeswift_preview_mode'\nconst APP_ROUTER_HANDSHAKE_MESSAGE = 'makeswift_draft_mode'\n\nexport function useBuilderHandshake({ appOrigin }: { appOrigin: string }) {\n const isPagesRouter = useIsPagesRouter()\n\n const handshakeInitiationMessage = useMemo(() => {\n if (isPagesRouter) return PAGES_ROUTER_HANDSHAKE_MESSAGE\n return APP_ROUTER_HANDSHAKE_MESSAGE\n }, [isPagesRouter])\n\n useEffect(() => {\n if (window.parent !== window) {\n window.parent.postMessage({ type: handshakeInitiationMessage }, { targetOrigin: appOrigin })\n }\n }, [appOrigin, handshakeInitiationMessage])\n}\n"],"mappings":"AAAA,SAAS,WAAW,eAAe;AACnC,SAAS,wBAAwB;AAEjC,MAAM,iCAAiC;AACvC,MAAM,+BAA+B;AAE9B,SAAS,oBAAoB,EAAE,UAAU,GAA0B;AACxE,QAAM,gBAAgB,iBAAiB;AAEvC,QAAM,6BAA6B,QAAQ,MAAM;AAC/C,QAAI;AAAe,aAAO;AAC1B,WAAO;AAAA,EACT,GAAG,CAAC,aAAa,CAAC;AAElB,YAAU,MAAM;AACd,QAAI,OAAO,WAAW,QAAQ;AAC5B,aAAO,OAAO,YAAY,EAAE,MAAM,2BAA2B,GAAG,EAAE,cAAc,UAAU,CAAC;AAAA,IAC7F;AAAA,EACF,GAAG,CAAC,WAAW,0BAA0B,CAAC;AAC5C;","names":[]}
@@ -1,6 +1,6 @@
1
1
  import { useMemo } from "react";
2
- import { Slate } from "@makeswift/controls";
3
- import { getBaseBreakpoint, DefaultBreakpointID } from "../../../../../state/modules/breakpoints";
2
+ import { Slate, getBaseBreakpoint } from "@makeswift/controls";
3
+ import { DefaultBreakpointID } from "../../../../../state/modules/breakpoints";
4
4
  import { useBreakpoints } from "../../../hooks/use-breakpoints";
5
5
  import { RichText } from "../../../../../controls";
6
6
  function usePresetValue(definition) {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../../src/runtimes/react/controls/rich-text-v2/EditableTextV2/usePresetValue.tsx"],"sourcesContent":["import { useMemo } from 'react'\nimport { Descendant } from 'slate'\nimport { Slate } from '@makeswift/controls'\n\nimport { getBaseBreakpoint, DefaultBreakpointID } from '../../../../../state/modules/breakpoints'\nimport { useBreakpoints } from '../../../hooks/use-breakpoints'\nimport { RichTextV2Definition, RichText } from '../../../../../controls'\n\nexport function usePresetValue(definition: RichTextV2Definition): Descendant[] {\n const breakpoints = useBreakpoints()\n return useMemo(\n () => [\n {\n type: Slate.BlockType.Default,\n children: [\n {\n text: definition.config.defaultValue ?? '',\n ...(definition.config.mode === RichText.Mode.Inline\n ? {}\n : {\n typography: {\n style: [\n {\n deviceId: getBaseBreakpoint(breakpoints).id,\n value: {\n fontWeight: 400,\n fontSize: { value: 18, unit: 'px' },\n lineHeight: 1.5,\n },\n },\n ...(breakpoints.some(({ id }) => id === DefaultBreakpointID.Mobile)\n ? [\n {\n deviceId: DefaultBreakpointID.Mobile,\n value: { fontSize: { value: 16, unit: 'px' } },\n },\n ]\n : []),\n ],\n },\n }),\n },\n ],\n },\n ],\n [definition.config.mode, definition.config.defaultValue, breakpoints],\n )\n}\n\nexport const defaultValue = [\n {\n type: Slate.BlockType.Default,\n children: [\n {\n text: '',\n },\n ],\n },\n]\n"],"mappings":"AAAA,SAAS,eAAe;AAExB,SAAS,aAAa;AAEtB,SAAS,mBAAmB,2BAA2B;AACvD,SAAS,sBAAsB;AAC/B,SAA+B,gBAAgB;AAExC,SAAS,eAAe,YAAgD;AAC7E,QAAM,cAAc,eAAe;AACnC,SAAO;AAAA,IACL,MAAM;AAAA,MACJ;AAAA,QACE,MAAM,MAAM,UAAU;AAAA,QACtB,UAAU;AAAA,UACR;AAAA,YACE,MAAM,WAAW,OAAO,gBAAgB;AAAA,YACxC,GAAI,WAAW,OAAO,SAAS,SAAS,KAAK,SACzC,CAAC,IACD;AAAA,cACE,YAAY;AAAA,gBACV,OAAO;AAAA,kBACL;AAAA,oBACE,UAAU,kBAAkB,WAAW,EAAE;AAAA,oBACzC,OAAO;AAAA,sBACL,YAAY;AAAA,sBACZ,UAAU,EAAE,OAAO,IAAI,MAAM,KAAK;AAAA,sBAClC,YAAY;AAAA,oBACd;AAAA,kBACF;AAAA,kBACA,GAAI,YAAY,KAAK,CAAC,EAAE,GAAG,MAAM,OAAO,oBAAoB,MAAM,IAC9D;AAAA,oBACE;AAAA,sBACE,UAAU,oBAAoB;AAAA,sBAC9B,OAAO,EAAE,UAAU,EAAE,OAAO,IAAI,MAAM,KAAK,EAAE;AAAA,oBAC/C;AAAA,kBACF,IACA,CAAC;AAAA,gBACP;AAAA,cACF;AAAA,YACF;AAAA,UACN;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,IACA,CAAC,WAAW,OAAO,MAAM,WAAW,OAAO,cAAc,WAAW;AAAA,EACtE;AACF;AAEO,MAAM,eAAe;AAAA,EAC1B;AAAA,IACE,MAAM,MAAM,UAAU;AAAA,IACtB,UAAU;AAAA,MACR;AAAA,QACE,MAAM;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACF;","names":[]}
1
+ {"version":3,"sources":["../../../../../../../src/runtimes/react/controls/rich-text-v2/EditableTextV2/usePresetValue.tsx"],"sourcesContent":["import { useMemo } from 'react'\nimport { Descendant } from 'slate'\nimport { Slate, getBaseBreakpoint } from '@makeswift/controls'\n\nimport { DefaultBreakpointID } from '../../../../../state/modules/breakpoints'\nimport { useBreakpoints } from '../../../hooks/use-breakpoints'\nimport { RichTextV2Definition, RichText } from '../../../../../controls'\n\nexport function usePresetValue(definition: RichTextV2Definition): Descendant[] {\n const breakpoints = useBreakpoints()\n return useMemo(\n () => [\n {\n type: Slate.BlockType.Default,\n children: [\n {\n text: definition.config.defaultValue ?? '',\n ...(definition.config.mode === RichText.Mode.Inline\n ? {}\n : {\n typography: {\n style: [\n {\n deviceId: getBaseBreakpoint(breakpoints).id,\n value: {\n fontWeight: 400,\n fontSize: { value: 18, unit: 'px' },\n lineHeight: 1.5,\n },\n },\n ...(breakpoints.some(({ id }) => id === DefaultBreakpointID.Mobile)\n ? [\n {\n deviceId: DefaultBreakpointID.Mobile,\n value: { fontSize: { value: 16, unit: 'px' } },\n },\n ]\n : []),\n ],\n },\n }),\n },\n ],\n },\n ],\n [definition.config.mode, definition.config.defaultValue, breakpoints],\n )\n}\n\nexport const defaultValue = [\n {\n type: Slate.BlockType.Default,\n children: [\n {\n text: '',\n },\n ],\n },\n]\n"],"mappings":"AAAA,SAAS,eAAe;AAExB,SAAS,OAAO,yBAAyB;AAEzC,SAAS,2BAA2B;AACpC,SAAS,sBAAsB;AAC/B,SAA+B,gBAAgB;AAExC,SAAS,eAAe,YAAgD;AAC7E,QAAM,cAAc,eAAe;AACnC,SAAO;AAAA,IACL,MAAM;AAAA,MACJ;AAAA,QACE,MAAM,MAAM,UAAU;AAAA,QACtB,UAAU;AAAA,UACR;AAAA,YACE,MAAM,WAAW,OAAO,gBAAgB;AAAA,YACxC,GAAI,WAAW,OAAO,SAAS,SAAS,KAAK,SACzC,CAAC,IACD;AAAA,cACE,YAAY;AAAA,gBACV,OAAO;AAAA,kBACL;AAAA,oBACE,UAAU,kBAAkB,WAAW,EAAE;AAAA,oBACzC,OAAO;AAAA,sBACL,YAAY;AAAA,sBACZ,UAAU,EAAE,OAAO,IAAI,MAAM,KAAK;AAAA,sBAClC,YAAY;AAAA,oBACd;AAAA,kBACF;AAAA,kBACA,GAAI,YAAY,KAAK,CAAC,EAAE,GAAG,MAAM,OAAO,oBAAoB,MAAM,IAC9D;AAAA,oBACE;AAAA,sBACE,UAAU,oBAAoB;AAAA,sBAC9B,OAAO,EAAE,UAAU,EAAE,OAAO,IAAI,MAAM,KAAK,EAAE;AAAA,oBAC/C;AAAA,kBACF,IACA,CAAC;AAAA,gBACP;AAAA,cACF;AAAA,YACF;AAAA,UACN;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,IACA,CAAC,WAAW,OAAO,MAAM,WAAW,OAAO,cAAc,WAAW;AAAA,EACtE;AACF;AAEO,MAAM,eAAe;AAAA,EAC1B;AAAA,IACE,MAAM,MAAM,UAAU;AAAA,IACtB,UAAU;AAAA,MACR;AAAA,QACE,MAAM;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACF;","names":[]}
@@ -1,9 +1,9 @@
1
+ import { useMemo } from "react";
1
2
  import { updateAPIClientCache } from "../../../state/actions";
2
3
  import { useMakeswiftHostApiClient } from "../host-api-client";
3
- import { useUniversalDispatch } from "./use-universal-dispatch";
4
4
  function useCacheData(cacheData) {
5
5
  const { makeswiftApiClient: apiStore } = useMakeswiftHostApiClient();
6
- useUniversalDispatch(apiStore.dispatch, updateAPIClientCache, [cacheData]);
6
+ useMemo(() => apiStore.dispatch(updateAPIClientCache(cacheData)), [cacheData]);
7
7
  }
8
8
  export {
9
9
  useCacheData
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../src/runtimes/react/hooks/use-cache-data.ts"],"sourcesContent":["import { type CacheData } from '../../../api/react'\nimport { updateAPIClientCache } from '../../../state/actions'\n\nimport { useMakeswiftHostApiClient } from '../host-api-client'\nimport { useUniversalDispatch } from './use-universal-dispatch'\n\nexport function useCacheData(cacheData: CacheData) {\n const { makeswiftApiClient: apiStore } = useMakeswiftHostApiClient()\n useUniversalDispatch(apiStore.dispatch, updateAPIClientCache, [cacheData])\n}\n"],"mappings":"AACA,SAAS,4BAA4B;AAErC,SAAS,iCAAiC;AAC1C,SAAS,4BAA4B;AAE9B,SAAS,aAAa,WAAsB;AACjD,QAAM,EAAE,oBAAoB,SAAS,IAAI,0BAA0B;AACnE,uBAAqB,SAAS,UAAU,sBAAsB,CAAC,SAAS,CAAC;AAC3E;","names":[]}
1
+ {"version":3,"sources":["../../../../../src/runtimes/react/hooks/use-cache-data.ts"],"sourcesContent":["import { useMemo } from 'react'\nimport { type CacheData } from '../../../api/react'\nimport { updateAPIClientCache } from '../../../state/actions'\n\nimport { useMakeswiftHostApiClient } from '../host-api-client'\n\nexport function useCacheData(cacheData: CacheData) {\n const { makeswiftApiClient: apiStore } = useMakeswiftHostApiClient()\n\n // We perform cache hydration immediately on render - this is safe to do per\n // render because updating the API cache is idempotent. For precedence, see:\n //\n // https://github.com/TanStack/query/blob/8f9f183f11df3709a1a38c4efce1452788041f88/packages/react-query/src/HydrationBoundary.tsx#L41\n useMemo(() => apiStore.dispatch(updateAPIClientCache(cacheData)), [cacheData])\n}\n"],"mappings":"AAAA,SAAS,eAAe;AAExB,SAAS,4BAA4B;AAErC,SAAS,iCAAiC;AAEnC,SAAS,aAAa,WAAsB;AACjD,QAAM,EAAE,oBAAoB,SAAS,IAAI,0BAA0B;AAMnE,UAAQ,MAAM,SAAS,SAAS,qBAAqB,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC;AAC/E;","names":[]}