@makeswift/runtime 0.27.1 → 0.27.2

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 (96) hide show
  1. package/dist/cjs/api/react.js +256 -0
  2. package/dist/cjs/api/react.js.map +1 -0
  3. package/dist/cjs/api-handler/handlers/manifest.js +1 -1
  4. package/dist/cjs/client/index.js +3 -3
  5. package/dist/cjs/next/api-handler/config/app-router.js +10 -1
  6. package/dist/cjs/next/api-handler/config/app-router.js.map +1 -1
  7. package/dist/cjs/runtimes/react/components/LiveProvider.js +50 -0
  8. package/dist/cjs/runtimes/react/components/LiveProvider.js.map +1 -0
  9. package/dist/cjs/runtimes/react/components/PreviewProvider.js +63 -0
  10. package/dist/cjs/runtimes/react/components/PreviewProvider.js.map +1 -0
  11. package/dist/cjs/runtimes/react/components/hooks/use-builder-connection-ping.js +62 -0
  12. package/dist/cjs/runtimes/react/components/hooks/use-builder-connection-ping.js.map +1 -0
  13. package/dist/cjs/runtimes/react/hooks/use-is-preview.js +33 -0
  14. package/dist/cjs/runtimes/react/hooks/use-is-preview.js.map +1 -0
  15. package/dist/cjs/state/actions/internal.js +205 -0
  16. package/dist/cjs/state/actions/internal.js.map +1 -0
  17. package/dist/cjs/state/mixins/setup-teardown.js +35 -0
  18. package/dist/cjs/state/mixins/setup-teardown.js.map +1 -0
  19. package/dist/cjs/state/modules/box-models.js +127 -0
  20. package/dist/cjs/state/modules/box-models.js.map +1 -0
  21. package/dist/cjs/state/modules/element-imperative-handles.js +60 -0
  22. package/dist/cjs/state/modules/element-imperative-handles.js.map +1 -0
  23. package/dist/cjs/state/modules/is-preview.js +47 -0
  24. package/dist/cjs/state/modules/is-preview.js.map +1 -0
  25. package/dist/cjs/state/modules/pointer.js +47 -0
  26. package/dist/cjs/state/modules/pointer.js.map +1 -0
  27. package/dist/cjs/state/modules/read-write-documents.js +98 -0
  28. package/dist/cjs/state/modules/read-write-documents.js.map +1 -0
  29. package/dist/cjs/state/react-builder-preview.js +586 -0
  30. package/dist/cjs/state/react-builder-preview.js.map +1 -0
  31. package/dist/cjs/state/react-page.js +313 -0
  32. package/dist/cjs/state/react-page.js.map +1 -0
  33. package/dist/esm/api/react.js +223 -0
  34. package/dist/esm/api/react.js.map +1 -0
  35. package/dist/esm/api-handler/handlers/manifest.js +1 -1
  36. package/dist/esm/client/index.js +3 -3
  37. package/dist/esm/next/api-handler/config/app-router.js +10 -1
  38. package/dist/esm/next/api-handler/config/app-router.js.map +1 -1
  39. package/dist/esm/runtimes/react/components/LiveProvider.js +20 -0
  40. package/dist/esm/runtimes/react/components/LiveProvider.js.map +1 -0
  41. package/dist/esm/runtimes/react/components/PreviewProvider.js +33 -0
  42. package/dist/esm/runtimes/react/components/PreviewProvider.js.map +1 -0
  43. package/dist/esm/runtimes/react/components/hooks/use-builder-connection-ping.js +38 -0
  44. package/dist/esm/runtimes/react/components/hooks/use-builder-connection-ping.js.map +1 -0
  45. package/dist/esm/runtimes/react/hooks/use-is-preview.js +9 -0
  46. package/dist/esm/runtimes/react/hooks/use-is-preview.js.map +1 -0
  47. package/dist/esm/state/actions/internal.js +162 -0
  48. package/dist/esm/state/actions/internal.js.map +1 -0
  49. package/dist/esm/state/mixins/setup-teardown.js +11 -0
  50. package/dist/esm/state/mixins/setup-teardown.js.map +1 -0
  51. package/dist/esm/state/modules/box-models.js +98 -0
  52. package/dist/esm/state/modules/box-models.js.map +1 -0
  53. package/dist/esm/state/modules/element-imperative-handles.js +35 -0
  54. package/dist/esm/state/modules/element-imperative-handles.js.map +1 -0
  55. package/dist/esm/state/modules/is-preview.js +21 -0
  56. package/dist/esm/state/modules/is-preview.js.map +1 -0
  57. package/dist/esm/state/modules/pointer.js +22 -0
  58. package/dist/esm/state/modules/pointer.js.map +1 -0
  59. package/dist/esm/state/modules/read-write-documents.js +60 -0
  60. package/dist/esm/state/modules/read-write-documents.js.map +1 -0
  61. package/dist/esm/state/react-builder-preview.js +547 -0
  62. package/dist/esm/state/react-builder-preview.js.map +1 -0
  63. package/dist/esm/state/react-page.js +268 -0
  64. package/dist/esm/state/react-page.js.map +1 -0
  65. package/dist/types/api/react.d.ts +82 -0
  66. package/dist/types/api/react.d.ts.map +1 -0
  67. package/dist/types/next/api-handler/config/app-router.d.ts.map +1 -1
  68. package/dist/types/runtimes/react/components/LiveProvider.d.ts +3 -0
  69. package/dist/types/runtimes/react/components/LiveProvider.d.ts.map +1 -0
  70. package/dist/types/runtimes/react/components/PreviewProvider.d.ts +5 -0
  71. package/dist/types/runtimes/react/components/PreviewProvider.d.ts.map +1 -0
  72. package/dist/types/runtimes/react/components/hooks/use-builder-connection-ping.d.ts +4 -0
  73. package/dist/types/runtimes/react/components/hooks/use-builder-connection-ping.d.ts.map +1 -0
  74. package/dist/types/runtimes/react/hooks/use-is-preview.d.ts +2 -0
  75. package/dist/types/runtimes/react/hooks/use-is-preview.d.ts.map +1 -0
  76. package/dist/types/state/__tests__/react-page.test.d.ts +2 -0
  77. package/dist/types/state/__tests__/react-page.test.d.ts.map +1 -0
  78. package/dist/types/state/actions/internal.d.ts +181 -0
  79. package/dist/types/state/actions/internal.d.ts.map +1 -0
  80. package/dist/types/state/mixins/setup-teardown.d.ts +7 -0
  81. package/dist/types/state/mixins/setup-teardown.d.ts.map +1 -0
  82. package/dist/types/state/modules/box-models.d.ts +23 -0
  83. package/dist/types/state/modules/box-models.d.ts.map +1 -0
  84. package/dist/types/state/modules/element-imperative-handles.d.ts +7 -0
  85. package/dist/types/state/modules/element-imperative-handles.d.ts.map +1 -0
  86. package/dist/types/state/modules/is-preview.d.ts +6 -0
  87. package/dist/types/state/modules/is-preview.d.ts.map +1 -0
  88. package/dist/types/state/modules/pointer.d.ts +12 -0
  89. package/dist/types/state/modules/pointer.d.ts.map +1 -0
  90. package/dist/types/state/modules/read-write-documents.d.ts +14 -0
  91. package/dist/types/state/modules/read-write-documents.d.ts.map +1 -0
  92. package/dist/types/state/react-builder-preview.d.ts +108 -0
  93. package/dist/types/state/react-builder-preview.d.ts.map +1 -0
  94. package/dist/types/state/react-page.d.ts +149 -0
  95. package/dist/types/state/react-page.d.ts.map +1 -0
  96. package/package.json +3 -3
@@ -0,0 +1,22 @@
1
+ import { ActionTypes, isKnownAction } from "../actions";
2
+ function getInitialState() {
3
+ return { pointer: null };
4
+ }
5
+ function getPointer(state) {
6
+ return state.pointer;
7
+ }
8
+ function reducer(state = getInitialState(), action) {
9
+ if (!isKnownAction(action))
10
+ return state;
11
+ switch (action.type) {
12
+ case ActionTypes.BUILDER_POINTER_MOVE:
13
+ return { ...state, pointer: action.payload.pointer };
14
+ default:
15
+ return state;
16
+ }
17
+ }
18
+ export {
19
+ getPointer,
20
+ reducer
21
+ };
22
+ //# sourceMappingURL=pointer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/state/modules/pointer.ts"],"sourcesContent":["import { type Action, type UnknownAction, ActionTypes, isKnownAction } from '../actions'\n\nexport type Point = { x: number; y: number }\n\ntype State = {\n pointer: Point | null\n}\n\nfunction getInitialState(): State {\n return { pointer: null }\n}\n\nexport function getPointer(state: State): Point | null {\n return state.pointer\n}\n\nexport function reducer(state: State = getInitialState(), action: Action | UnknownAction): State {\n if (!isKnownAction(action)) return state\n\n switch (action.type) {\n case ActionTypes.BUILDER_POINTER_MOVE:\n return { ...state, pointer: action.payload.pointer }\n\n default:\n return state\n }\n}\n"],"mappings":"AAAA,SAA0C,aAAa,qBAAqB;AAQ5E,SAAS,kBAAyB;AAChC,SAAO,EAAE,SAAS,KAAK;AACzB;AAEO,SAAS,WAAW,OAA4B;AACrD,SAAO,MAAM;AACf;AAEO,SAAS,QAAQ,QAAe,gBAAgB,GAAG,QAAuC;AAC/F,MAAI,CAAC,cAAc,MAAM;AAAG,WAAO;AAEnC,UAAQ,OAAO,MAAM;AAAA,IACnB,KAAK,YAAY;AACf,aAAO,EAAE,GAAG,OAAO,SAAS,OAAO,QAAQ,QAAQ;AAAA,IAErD;AACE,aAAO;AAAA,EACX;AACF;","names":[]}
@@ -0,0 +1,60 @@
1
+ import { removeIn, setIn } from "immutable";
2
+ import * as ReadOnlyDocuments from "./read-only-documents";
3
+ import { ActionTypes, isKnownAction } from "../actions";
4
+ import { isElementReference } from "./read-only-documents";
5
+ function apply(data, operation) {
6
+ let applied = data;
7
+ operation.forEach((component) => {
8
+ if (component.ld != null)
9
+ applied = removeIn(applied, component.p);
10
+ if (component.od != null)
11
+ applied = removeIn(applied, component.p);
12
+ if (component.li != null)
13
+ applied = setIn(applied, component.p, component.li);
14
+ if (component.oi != null)
15
+ applied = setIn(applied, component.p, component.oi);
16
+ });
17
+ return applied;
18
+ }
19
+ function getInitialState({
20
+ documents = []
21
+ } = {}) {
22
+ return ReadOnlyDocuments.getInitialState({ documents });
23
+ }
24
+ function getReadOnlyDocumentsStateSlice(state) {
25
+ return state;
26
+ }
27
+ function getDocument(state, documentKey) {
28
+ return ReadOnlyDocuments.getDocument(getReadOnlyDocumentsStateSlice(state), documentKey);
29
+ }
30
+ function getDocuments(state) {
31
+ return ReadOnlyDocuments.getDocuments(getReadOnlyDocumentsStateSlice(state));
32
+ }
33
+ function reducer(state = getInitialState(), action) {
34
+ const nextState = ReadOnlyDocuments.reducer(state, action);
35
+ if (!isKnownAction(action))
36
+ return state;
37
+ switch (action.type) {
38
+ case ActionTypes.CHANGE_DOCUMENT: {
39
+ const document = getDocument(nextState, action.payload.documentKey);
40
+ if (document == null)
41
+ return nextState;
42
+ const currentRootElement = ReadOnlyDocuments.getRootElement(document);
43
+ const nextRootElement = apply(currentRootElement, action.payload.operation);
44
+ return currentRootElement === nextRootElement ? nextState : new Map(nextState).set(action.payload.documentKey, {
45
+ ...document,
46
+ rootElement: nextRootElement
47
+ });
48
+ }
49
+ default:
50
+ return nextState;
51
+ }
52
+ }
53
+ export {
54
+ getDocument,
55
+ getDocuments,
56
+ getInitialState,
57
+ isElementReference,
58
+ reducer
59
+ };
60
+ //# sourceMappingURL=read-write-documents.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/state/modules/read-write-documents.ts"],"sourcesContent":["import { type Operation } from 'ot-json0'\nimport { removeIn, setIn } from 'immutable'\n\nimport * as ReadOnlyDocuments from './read-only-documents'\nimport { type Action, type UnknownAction, ActionTypes, isKnownAction } from '../actions'\n\nexport type { Document, Element, ElementData, ElementReference } from './read-only-documents'\nexport { isElementReference } from './read-only-documents'\nexport type { Operation }\n\nfunction apply(data: ReadOnlyDocuments.Element, operation: Operation): ReadOnlyDocuments.Element {\n let applied = data\n\n operation.forEach(component => {\n // @ts-expect-error: `ld` isn't in all possible values of `component`\n if (component.ld != null) applied = removeIn(applied, component.p)\n\n // @ts-expect-error: `od` isn't in all possible values of `component`\n if (component.od != null) applied = removeIn(applied, component.p)\n\n // @ts-expect-error: `li` isn't in all possible values of `component`\n if (component.li != null) applied = setIn(applied, component.p, component.li)\n\n // @ts-expect-error: `oi` isn't in all possible values of `component`\n if (component.oi != null) applied = setIn(applied, component.p, component.oi)\n })\n\n return applied\n}\n\nexport type State = ReadOnlyDocuments.State\n\nexport function getInitialState({\n documents = [],\n}: { documents?: ReadOnlyDocuments.Document[] } = {}): State {\n return ReadOnlyDocuments.getInitialState({ documents })\n}\n\nfunction getReadOnlyDocumentsStateSlice(state: State): ReadOnlyDocuments.State {\n return state\n}\n\nexport function getDocument(state: State, documentKey: string): ReadOnlyDocuments.Document | null {\n return ReadOnlyDocuments.getDocument(getReadOnlyDocumentsStateSlice(state), documentKey)\n}\n\nexport function getDocuments(state: State): ReadOnlyDocuments.State {\n return ReadOnlyDocuments.getDocuments(getReadOnlyDocumentsStateSlice(state))\n}\n\nexport function reducer(state: State = getInitialState(), action: Action | UnknownAction): State {\n const nextState = ReadOnlyDocuments.reducer(state, action)\n\n if (!isKnownAction(action)) return state\n\n switch (action.type) {\n case ActionTypes.CHANGE_DOCUMENT: {\n const document = getDocument(nextState, action.payload.documentKey)\n if (document == null) return nextState\n\n const currentRootElement = ReadOnlyDocuments.getRootElement(document)\n\n const nextRootElement = apply(currentRootElement, action.payload.operation)\n\n return currentRootElement === nextRootElement\n ? nextState\n : new Map(nextState).set(action.payload.documentKey, {\n ...document,\n rootElement: nextRootElement,\n })\n }\n\n default:\n return nextState\n }\n}\n"],"mappings":"AACA,SAAS,UAAU,aAAa;AAEhC,YAAY,uBAAuB;AACnC,SAA0C,aAAa,qBAAqB;AAG5E,SAAS,0BAA0B;AAGnC,SAAS,MAAM,MAAiC,WAAiD;AAC/F,MAAI,UAAU;AAEd,YAAU,QAAQ,eAAa;AAE7B,QAAI,UAAU,MAAM;AAAM,gBAAU,SAAS,SAAS,UAAU,CAAC;AAGjE,QAAI,UAAU,MAAM;AAAM,gBAAU,SAAS,SAAS,UAAU,CAAC;AAGjE,QAAI,UAAU,MAAM;AAAM,gBAAU,MAAM,SAAS,UAAU,GAAG,UAAU,EAAE;AAG5E,QAAI,UAAU,MAAM;AAAM,gBAAU,MAAM,SAAS,UAAU,GAAG,UAAU,EAAE;AAAA,EAC9E,CAAC;AAED,SAAO;AACT;AAIO,SAAS,gBAAgB;AAAA,EAC9B,YAAY,CAAC;AACf,IAAkD,CAAC,GAAU;AAC3D,SAAO,kBAAkB,gBAAgB,EAAE,UAAU,CAAC;AACxD;AAEA,SAAS,+BAA+B,OAAuC;AAC7E,SAAO;AACT;AAEO,SAAS,YAAY,OAAc,aAAwD;AAChG,SAAO,kBAAkB,YAAY,+BAA+B,KAAK,GAAG,WAAW;AACzF;AAEO,SAAS,aAAa,OAAuC;AAClE,SAAO,kBAAkB,aAAa,+BAA+B,KAAK,CAAC;AAC7E;AAEO,SAAS,QAAQ,QAAe,gBAAgB,GAAG,QAAuC;AAC/F,QAAM,YAAY,kBAAkB,QAAQ,OAAO,MAAM;AAEzD,MAAI,CAAC,cAAc,MAAM;AAAG,WAAO;AAEnC,UAAQ,OAAO,MAAM;AAAA,IACnB,KAAK,YAAY,iBAAiB;AAChC,YAAM,WAAW,YAAY,WAAW,OAAO,QAAQ,WAAW;AAClE,UAAI,YAAY;AAAM,eAAO;AAE7B,YAAM,qBAAqB,kBAAkB,eAAe,QAAQ;AAEpE,YAAM,kBAAkB,MAAM,oBAAoB,OAAO,QAAQ,SAAS;AAE1E,aAAO,uBAAuB,kBAC1B,YACA,IAAI,IAAI,SAAS,EAAE,IAAI,OAAO,QAAQ,aAAa;AAAA,QACjD,GAAG;AAAA,QACH,aAAa;AAAA,MACf,CAAC;AAAA,IACP;AAAA,IAEA;AACE,aAAO;AAAA,EACX;AACF;","names":[]}
@@ -0,0 +1,547 @@
1
+ import {
2
+ configureStore as configureReduxStore,
3
+ combineReducers
4
+ } from "@reduxjs/toolkit";
5
+ import deepEqual from "../utils/deepEqual";
6
+ import * as Documents from "./modules/read-write-documents";
7
+ import * as ElementTrees from "./modules/element-trees";
8
+ import * as ReactComponents from "./modules/react-components";
9
+ import * as BoxModels from "./modules/box-models";
10
+ import * as ComponentsMeta from "./modules/components-meta";
11
+ import * as PropControllers from "./modules/prop-controllers";
12
+ import * as PropControllerHandles from "./modules/prop-controller-handles";
13
+ import * as IsInBuilder from "./modules/is-in-builder";
14
+ import * as IsPreview from "./modules/is-preview";
15
+ import * as BuilderEditMode from "./modules/builder-edit-mode";
16
+ import * as Pointer from "./modules/pointer";
17
+ import * as ElementImperativeHandles from "./modules/element-imperative-handles";
18
+ import * as Breakpoints from "./modules/breakpoints";
19
+ import { withSetupTeardown } from "./mixins/setup-teardown";
20
+ import * as ReactPage from "./react-page";
21
+ import * as Shared from "./shared-api";
22
+ import { BuilderActionTypes } from "./builder-api/actions";
23
+ import * as Builder from "./builder-api/actions";
24
+ import { InternalActionTypes } from "./actions/internal";
25
+ import * as Internal from "./actions/internal";
26
+ import { actionMiddleware, middlewareOptions, devToolsConfig } from "./toolkit";
27
+ import { createPropController } from "../prop-controllers/instances";
28
+ import { serializeControls } from "../builder";
29
+ import { HostActionTypes } from "./host-api";
30
+ import { createBox, getBox, parse } from "./modules/box-models";
31
+ const reducer = combineReducers({
32
+ documents: Documents.reducer,
33
+ elementTrees: ElementTrees.reducer,
34
+ reactComponents: ReactComponents.reducer,
35
+ boxModels: BoxModels.reducer,
36
+ componentsMeta: ComponentsMeta.reducer,
37
+ propControllers: PropControllers.reducer,
38
+ propControllerHandles: PropControllerHandles.reducer,
39
+ isInBuilder: IsInBuilder.reducer,
40
+ isPreview: IsPreview.reducer,
41
+ builderEditMode: BuilderEditMode.reducer,
42
+ pointer: Pointer.reducer,
43
+ elementImperativeHandles: ElementImperativeHandles.reducer,
44
+ breakpoints: Breakpoints.reducer
45
+ });
46
+ function getDocumentsStateSlice(state) {
47
+ return state.documents;
48
+ }
49
+ function getBoxModelsStateSlice(state) {
50
+ return state.boxModels;
51
+ }
52
+ function getMeasurables(state) {
53
+ return BoxModels.getMeasurables(getBoxModelsStateSlice(state));
54
+ }
55
+ function getBoxModels(state) {
56
+ return BoxModels.getBoxModels(getBoxModelsStateSlice(state));
57
+ }
58
+ function getBoxModel(state, documentKey, elementKey) {
59
+ return BoxModels.getBoxModel(getBoxModelsStateSlice(state), documentKey, elementKey);
60
+ }
61
+ function getComponentsMetaStateSlice(state) {
62
+ return state.componentsMeta;
63
+ }
64
+ function getComponentsMeta(state) {
65
+ return ComponentsMeta.getComponentsMeta(getComponentsMetaStateSlice(state));
66
+ }
67
+ function getPropControllersStateSlice(state) {
68
+ return state.propControllers;
69
+ }
70
+ function getComponentPropControllerDescriptors(state, componentType) {
71
+ return PropControllers.getComponentPropControllerDescriptors(
72
+ getPropControllersStateSlice(state),
73
+ componentType
74
+ );
75
+ }
76
+ function getPropControllerHandlesStateSlice(state) {
77
+ return state.propControllerHandles;
78
+ }
79
+ function getPointer(state) {
80
+ return Pointer.getPointer(state.pointer);
81
+ }
82
+ function getElementImperativeHandles(state) {
83
+ return ElementImperativeHandles.getElementImperativeHandles(state.elementImperativeHandles);
84
+ }
85
+ function getElementImperativeHandlesContainingElement(state, element) {
86
+ const elementImperativeHandles = getElementImperativeHandles(state);
87
+ const filteredElementImperativeHandles = /* @__PURE__ */ new Map();
88
+ for (const [documentKey, byElementKey] of elementImperativeHandles) {
89
+ const filteredByElementKey = /* @__PURE__ */ new Map();
90
+ for (const [elementKey, elementImperativeHandle] of byElementKey) {
91
+ const handleElement = elementImperativeHandle.getDomNode();
92
+ if (handleElement?.contains(element)) {
93
+ filteredByElementKey.set(elementKey, elementImperativeHandle);
94
+ }
95
+ }
96
+ if (filteredByElementKey.size > 0) {
97
+ filteredElementImperativeHandles.set(documentKey, filteredByElementKey);
98
+ }
99
+ }
100
+ return filteredElementImperativeHandles;
101
+ }
102
+ function measureElements() {
103
+ return (dispatch, getState) => {
104
+ const measurables = getMeasurables(getState());
105
+ const currentBoxModels = getBoxModels(getState());
106
+ const measuredBoxModels = /* @__PURE__ */ new Map();
107
+ measurables.forEach((documentMeasurables, documentKey) => {
108
+ const measuredDocumentBoxModels = /* @__PURE__ */ new Map();
109
+ documentMeasurables.forEach((measurable, elementKey) => {
110
+ const boxModel = BoxModels.measure(measurable);
111
+ if (boxModel != null)
112
+ measuredDocumentBoxModels.set(elementKey, boxModel);
113
+ });
114
+ if (measuredDocumentBoxModels.size > 0) {
115
+ measuredBoxModels.set(documentKey, measuredDocumentBoxModels);
116
+ }
117
+ });
118
+ const changedBoxModels = /* @__PURE__ */ new Map();
119
+ currentBoxModels.forEach((currentDocumentBoxModels, documentKey) => {
120
+ const changedDocumentBoxModels = /* @__PURE__ */ new Map();
121
+ currentDocumentBoxModels.forEach((_boxModel, elementKey) => {
122
+ if (!measuredBoxModels.get(documentKey)?.has(elementKey)) {
123
+ changedDocumentBoxModels.set(elementKey, null);
124
+ }
125
+ if (changedDocumentBoxModels.size > 0) {
126
+ changedBoxModels.set(documentKey, changedDocumentBoxModels);
127
+ }
128
+ });
129
+ });
130
+ measuredBoxModels.forEach((measuredDocumentBoxModels, documentKey) => {
131
+ const changedDocumentBoxModels = /* @__PURE__ */ new Map();
132
+ measuredDocumentBoxModels.forEach((measuredBoxModel, elementKey) => {
133
+ const currentBoxModel = getBoxModel(getState(), documentKey, elementKey);
134
+ if (currentBoxModel == null || !deepEqual(currentBoxModel, measuredBoxModel)) {
135
+ changedDocumentBoxModels.set(elementKey, measuredBoxModel);
136
+ }
137
+ });
138
+ if (changedDocumentBoxModels.size > 0) {
139
+ changedBoxModels.set(documentKey, changedDocumentBoxModels);
140
+ }
141
+ });
142
+ if (changedBoxModels.size > 0)
143
+ dispatch(Builder.changeElementBoxModels(changedBoxModels));
144
+ };
145
+ }
146
+ function startMeasuringElements() {
147
+ return (dispatch) => {
148
+ let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
149
+ return () => {
150
+ cancelAnimationFrame(animationFrameHandle);
151
+ };
152
+ function handleAnimationFrameRequest() {
153
+ dispatch(measureElements());
154
+ animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
155
+ }
156
+ };
157
+ }
158
+ function getElementSize(element) {
159
+ return {
160
+ offsetWidth: element.offsetWidth,
161
+ offsetHeight: element.offsetHeight,
162
+ clientWidth: element.clientWidth,
163
+ clientHeight: element.clientHeight,
164
+ scrollWidth: element.scrollWidth,
165
+ scrollHeight: element.scrollHeight,
166
+ scrollTop: element.scrollTop,
167
+ scrollLeft: element.scrollLeft
168
+ };
169
+ }
170
+ function lockDocumentScroll() {
171
+ return (dispatch) => {
172
+ const lastDocumentOverflow = window.document.documentElement.style.overflow;
173
+ window.document.documentElement.style.overflow = "hidden";
174
+ window.document.documentElement.addEventListener("wheel", handleWheelEvent);
175
+ return () => {
176
+ window.document.documentElement.style.overflow = lastDocumentOverflow;
177
+ window.document.documentElement.removeEventListener("wheel", handleWheelEvent);
178
+ };
179
+ function handleWheelEvent({ deltaX, deltaY }) {
180
+ dispatch(Builder.handleWheel({ deltaX, deltaY }));
181
+ }
182
+ };
183
+ }
184
+ function startHandlingPointerMoveEvent() {
185
+ return (dispatch) => {
186
+ window.document.documentElement.addEventListener("pointermove", handlePointerMoveEvent);
187
+ return () => {
188
+ window.document.documentElement.removeEventListener("pointermove", handlePointerMoveEvent);
189
+ };
190
+ function handlePointerMoveEvent({ clientX, clientY }) {
191
+ dispatch(Builder.handlePointerMove({ clientX, clientY }));
192
+ }
193
+ };
194
+ }
195
+ function startHandlingFocusEvents() {
196
+ return (_dispatch, getState) => {
197
+ window.addEventListener("focusin", handleFocusIn);
198
+ window.addEventListener("focusout", handleFocusOut);
199
+ return () => {
200
+ window.removeEventListener("focusin", handleFocusIn);
201
+ window.removeEventListener("focusout", handleFocusOut);
202
+ };
203
+ function handleFocusIn(event) {
204
+ if (ReactPage.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT) {
205
+ return;
206
+ }
207
+ if (!(event.target instanceof window.HTMLElement) || !event.target.isContentEditable) {
208
+ window.parent.focus();
209
+ }
210
+ }
211
+ function handleFocusOut(event) {
212
+ if (ReactPage.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT) {
213
+ return;
214
+ }
215
+ if (!(event.relatedTarget instanceof window.HTMLElement) || !event.relatedTarget.isContentEditable) {
216
+ window.parent.focus();
217
+ }
218
+ }
219
+ };
220
+ }
221
+ function startMeasuringDocumentElement() {
222
+ return (dispatch) => {
223
+ let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
224
+ let lastSize;
225
+ return () => {
226
+ cancelAnimationFrame(animationFrameHandle);
227
+ };
228
+ function handleAnimationFrameRequest() {
229
+ const nextSize = getElementSize(window.document.documentElement);
230
+ if (!deepEqual(lastSize, nextSize)) {
231
+ lastSize = nextSize;
232
+ dispatch(Builder.changeDocumentElementSize(nextSize));
233
+ }
234
+ animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
235
+ }
236
+ };
237
+ }
238
+ function elementKeysFromElementFromPoint(elementFromPoint) {
239
+ return (_dispatch, getState) => {
240
+ if (elementFromPoint == null)
241
+ return null;
242
+ const elementImperativeHandles = getElementImperativeHandlesContainingElement(
243
+ getState(),
244
+ elementFromPoint
245
+ );
246
+ const ascendingDepthDocumentKeys = ReactPage.getDocumentKeysSortedByDepth(getState());
247
+ const descendingDepthDocumentKeys = ascendingDepthDocumentKeys.slice().reverse();
248
+ let currentElement = elementFromPoint;
249
+ let keys = null;
250
+ while (currentElement != null) {
251
+ for (const documentKey of descendingDepthDocumentKeys) {
252
+ const byElementKey = elementImperativeHandles.get(documentKey);
253
+ if (byElementKey == null)
254
+ continue;
255
+ for (const [elementKey, elementImperativeHandle] of byElementKey) {
256
+ if (elementImperativeHandle.getDomNode() === currentElement) {
257
+ return { documentKey, elementKey };
258
+ }
259
+ }
260
+ }
261
+ currentElement = currentElement.parentElement;
262
+ }
263
+ return keys;
264
+ };
265
+ }
266
+ function startPollingElementFromPoint() {
267
+ return (dispatch, getState) => {
268
+ let lastElementFromPoint = null;
269
+ let animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest);
270
+ return () => {
271
+ cancelAnimationFrame(animationFrameRequestId);
272
+ };
273
+ function handleAnimationFrameRequest() {
274
+ const pointer = getPointer(getState());
275
+ const elementFromPoint = pointer == null ? null : document.elementFromPoint(pointer.x, pointer.y);
276
+ if (elementFromPoint !== lastElementFromPoint) {
277
+ lastElementFromPoint = elementFromPoint;
278
+ const keys = dispatch(elementKeysFromElementFromPoint(elementFromPoint));
279
+ dispatch(Builder.elementFromPointChange(keys));
280
+ }
281
+ animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest);
282
+ }
283
+ };
284
+ }
285
+ function registerBuilderComponents() {
286
+ return (dispatch, getState) => {
287
+ const state = getState();
288
+ const componentsMeta = getComponentsMeta(state);
289
+ componentsMeta.forEach((meta, type) => {
290
+ const descriptors = getComponentPropControllerDescriptors(state, type);
291
+ if (descriptors != null) {
292
+ const [serializedControls, transferables] = serializeControls(descriptors);
293
+ dispatch(
294
+ Builder.registerBuilderComponent({ type, meta, serializedControls }, transferables)
295
+ );
296
+ }
297
+ });
298
+ return () => {
299
+ componentsMeta.forEach((_, type) => {
300
+ dispatch(Builder.unregisterBuilderComponent({ type }));
301
+ });
302
+ };
303
+ };
304
+ }
305
+ function registerBuilderDocuments() {
306
+ return (dispatch, getState) => {
307
+ const documents = Documents.getDocuments(getDocumentsStateSlice(getState()));
308
+ documents.forEach((document2) => {
309
+ dispatch(Builder.registerBuilderDocument(document2));
310
+ });
311
+ return () => {
312
+ documents.forEach((_document, documentKey) => {
313
+ dispatch(Builder.unregisterBuilderDocument(documentKey));
314
+ });
315
+ };
316
+ };
317
+ }
318
+ function initialize(builderProxy) {
319
+ return (dispatch, getState) => {
320
+ const unregisterBuilderDocuments = dispatch(registerBuilderDocuments());
321
+ const stopMeasuringElements = dispatch(startMeasuringElements());
322
+ const stopMeasuringDocumentElement = dispatch(startMeasuringDocumentElement());
323
+ const stopHandlingFocusEvent = dispatch(startHandlingFocusEvents());
324
+ const unlockDocumentScroll = dispatch(lockDocumentScroll());
325
+ const stopHandlingPointerMoveEvent = dispatch(startHandlingPointerMoveEvent());
326
+ const stopPollingElementFromPoint = dispatch(startPollingElementFromPoint());
327
+ const unregisterBuilderComponents = dispatch(registerBuilderComponents());
328
+ const breakpoints = ReactPage.getBreakpoints(getState());
329
+ dispatch(Shared.setBreakpoints(breakpoints));
330
+ dispatch(Internal.setIsInBuilder(true));
331
+ builderProxy.dispatchBuffered();
332
+ return () => {
333
+ unregisterBuilderDocuments();
334
+ stopMeasuringElements();
335
+ stopMeasuringDocumentElement();
336
+ stopHandlingFocusEvent();
337
+ unlockDocumentScroll();
338
+ stopHandlingPointerMoveEvent();
339
+ stopPollingElementFromPoint();
340
+ unregisterBuilderComponents();
341
+ dispatch(Internal.setIsInBuilder(false));
342
+ };
343
+ };
344
+ }
345
+ function measureBoxModelsMiddleware() {
346
+ return actionMiddleware(({ dispatch }) => (next) => {
347
+ return (action) => {
348
+ switch (action.type) {
349
+ case InternalActionTypes.REGISTER_COMPONENT_HANDLE: {
350
+ if (BoxModels.isMeasurable(action.payload.componentHandle)) {
351
+ dispatch(
352
+ Internal.registerMeasurable(
353
+ action.payload.documentKey,
354
+ action.payload.elementKey,
355
+ action.payload.componentHandle
356
+ )
357
+ );
358
+ }
359
+ break;
360
+ }
361
+ case InternalActionTypes.UNREGISTER_COMPONENT_HANDLE:
362
+ dispatch(
363
+ Internal.unregisterMeasurable(action.payload.documentKey, action.payload.elementKey)
364
+ );
365
+ break;
366
+ }
367
+ return next(action);
368
+ };
369
+ });
370
+ }
371
+ function builderAPIMiddleware(builderProxy) {
372
+ return actionMiddleware(({ dispatch }) => (next) => {
373
+ if (typeof window === "undefined")
374
+ return (action) => next(action);
375
+ let cleanUp = () => {
376
+ };
377
+ return (action) => {
378
+ switch (action.type) {
379
+ case BuilderActionTypes.CHANGE_ELEMENT_BOX_MODELS:
380
+ case BuilderActionTypes.MOUNT_COMPONENT:
381
+ case BuilderActionTypes.UNMOUNT_COMPONENT:
382
+ case BuilderActionTypes.CHANGE_DOCUMENT_ELEMENT_SIZE:
383
+ case BuilderActionTypes.MESSAGE_BUILDER_PROP_CONTROLLER:
384
+ case BuilderActionTypes.HANDLE_WHEEL:
385
+ case BuilderActionTypes.HANDLE_POINTER_MOVE:
386
+ case BuilderActionTypes.ELEMENT_FROM_POINT_CHANGE:
387
+ case BuilderActionTypes.SET_LOCALE:
388
+ case BuilderActionTypes.SET_BREAKPOINTS:
389
+ case BuilderActionTypes.REGISTER_BUILDER_DOCUMENT:
390
+ case BuilderActionTypes.UNREGISTER_BUILDER_DOCUMENT:
391
+ case BuilderActionTypes.REGISTER_BUILDER_COMPONENT:
392
+ case BuilderActionTypes.UNREGISTER_BUILDER_COMPONENT:
393
+ builderProxy.execute(action);
394
+ break;
395
+ case HostActionTypes.CHANGE_DOCUMENT_ELEMENT_SCROLL_TOP:
396
+ window.document.documentElement.scrollTop = action.payload.scrollTop;
397
+ break;
398
+ case HostActionTypes.SCROLL_DOCUMENT_ELEMENT:
399
+ window.document.documentElement.scrollTop += action.payload.scrollTopDelta;
400
+ break;
401
+ case HostActionTypes.SET_BUILDER_EDIT_MODE:
402
+ window.getSelection()?.removeAllRanges();
403
+ break;
404
+ case HostActionTypes.INIT:
405
+ cleanUp = dispatch(initialize(builderProxy));
406
+ break;
407
+ case HostActionTypes.CLEAN_UP:
408
+ cleanUp();
409
+ break;
410
+ }
411
+ return next(action);
412
+ };
413
+ });
414
+ }
415
+ function createAndRegisterPropControllers(documentKey, elementKey) {
416
+ return (dispatch, getState) => {
417
+ const descriptors = ReactPage.getElementPropControllerDescriptors(
418
+ getState(),
419
+ documentKey,
420
+ elementKey
421
+ );
422
+ if (descriptors == null)
423
+ return null;
424
+ const propControllers = Object.entries(descriptors).reduce(
425
+ (acc, [propName, descriptor]) => {
426
+ const propController = createPropController(
427
+ descriptor,
428
+ (message) => dispatch(
429
+ Builder.messageBuilderPropController(documentKey, elementKey, propName, message)
430
+ )
431
+ );
432
+ return { ...acc, [propName]: propController };
433
+ },
434
+ {}
435
+ );
436
+ dispatch(Internal.registerPropControllers(documentKey, elementKey, propControllers));
437
+ return propControllers;
438
+ };
439
+ }
440
+ function propControllerHandlesMiddleware() {
441
+ return actionMiddleware(({ dispatch, getState }) => (next) => {
442
+ return (action) => {
443
+ switch (action.type) {
444
+ case InternalActionTypes.REGISTER_COMPONENT_HANDLE: {
445
+ const { documentKey, elementKey, componentHandle } = action.payload;
446
+ const element = ReactPage.getElement(getState(), documentKey, elementKey);
447
+ const propControllers = dispatch(
448
+ createAndRegisterPropControllers(documentKey, elementKey)
449
+ );
450
+ if (element != null && !ReactPage.isElementReference(element) && PropControllerHandles.isPropControllersHandle(componentHandle)) {
451
+ dispatch(
452
+ Internal.registerPropControllersHandle(documentKey, elementKey, componentHandle)
453
+ );
454
+ componentHandle.setPropControllers(propControllers);
455
+ }
456
+ break;
457
+ }
458
+ case InternalActionTypes.UNREGISTER_COMPONENT_HANDLE: {
459
+ const { documentKey, elementKey } = action.payload;
460
+ const handle = PropControllerHandles.getPropControllersHandle(
461
+ getPropControllerHandlesStateSlice(getState()),
462
+ documentKey,
463
+ elementKey
464
+ );
465
+ handle?.setPropControllers(null);
466
+ dispatch(Internal.unregisterPropControllers(documentKey, elementKey));
467
+ break;
468
+ }
469
+ case HostActionTypes.MESSAGE_HOST_PROP_CONTROLLER: {
470
+ const propController = PropControllerHandles.getPropController(
471
+ getPropControllerHandlesStateSlice(getState()),
472
+ action.payload.documentKey,
473
+ action.payload.elementKey,
474
+ action.payload.propName
475
+ );
476
+ if (propController)
477
+ propController.recv(action.payload.message);
478
+ }
479
+ }
480
+ return next(action);
481
+ };
482
+ });
483
+ }
484
+ function makeswiftApiClientSyncMiddleware(client) {
485
+ return actionMiddleware(() => (next) => {
486
+ return (action) => {
487
+ client.makeswiftApiClient.dispatch(action);
488
+ return next(action);
489
+ };
490
+ });
491
+ }
492
+ function setupBuilderProxy(builderProxy) {
493
+ return (dispatch) => {
494
+ builderProxy.setup({ onHostAction: (action) => dispatch(action) });
495
+ };
496
+ }
497
+ function configureStore({
498
+ preloadedState,
499
+ client,
500
+ builderProxy
501
+ }) {
502
+ const initialState = {
503
+ ...preloadedState,
504
+ isPreview: IsPreview.getInitialState(true)
505
+ };
506
+ const store = configureReduxStore({
507
+ reducer,
508
+ preloadedState: initialState,
509
+ middleware: (getDefaultMiddleware) => getDefaultMiddleware(middlewareOptions).concat(
510
+ ReactPage.elementTreeMiddleware(),
511
+ measureBoxModelsMiddleware(),
512
+ builderAPIMiddleware(builderProxy),
513
+ propControllerHandlesMiddleware(),
514
+ makeswiftApiClientSyncMiddleware(client)
515
+ ),
516
+ enhancers: (getDefaultEnhancers) => getDefaultEnhancers().concat(
517
+ withSetupTeardown(
518
+ () => {
519
+ const dispatch = store.dispatch;
520
+ dispatch(setupBuilderProxy(builderProxy));
521
+ },
522
+ () => builderProxy.teardown()
523
+ )
524
+ ),
525
+ devTools: devToolsConfig({
526
+ name: `Host store (${(/* @__PURE__ */ new Date()).toISOString()})`,
527
+ actionsDenylist: [
528
+ HostActionTypes.BUILDER_POINTER_MOVE,
529
+ BuilderActionTypes.HANDLE_POINTER_MOVE,
530
+ BuilderActionTypes.ELEMENT_FROM_POINT_CHANGE
531
+ ]
532
+ })
533
+ });
534
+ return store;
535
+ }
536
+ export {
537
+ builderAPIMiddleware,
538
+ configureStore,
539
+ createBox,
540
+ getBox,
541
+ initialize,
542
+ parse,
543
+ propControllerHandlesMiddleware,
544
+ reducer,
545
+ startMeasuringElements
546
+ };
547
+ //# sourceMappingURL=react-builder-preview.js.map