@makeswift/runtime 0.27.1-canary.0 → 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.
- package/dist/cjs/api/react.js +256 -0
- package/dist/cjs/api/react.js.map +1 -0
- package/dist/cjs/api-handler/handlers/manifest.js +1 -1
- package/dist/cjs/builder/serialization/control-serialization.js +10 -7
- package/dist/cjs/builder/serialization/control-serialization.js.map +1 -1
- package/dist/cjs/client/index.js +35 -6
- package/dist/cjs/client/index.js.map +1 -1
- package/dist/cjs/controls/visitors/message-port-serializer/function-serialization.js.map +1 -1
- package/dist/cjs/next/api-handler/config/app-router.js +10 -1
- package/dist/cjs/next/api-handler/config/app-router.js.map +1 -1
- package/dist/cjs/runtimes/react/components/GoogleFontLink.js +56 -0
- package/dist/cjs/runtimes/react/components/GoogleFontLink.js.map +1 -0
- package/dist/cjs/runtimes/react/components/LiveProvider.js +50 -0
- package/dist/cjs/runtimes/react/components/LiveProvider.js.map +1 -0
- package/dist/cjs/runtimes/react/components/PreviewProvider.js +63 -0
- package/dist/cjs/runtimes/react/components/PreviewProvider.js.map +1 -0
- package/dist/cjs/runtimes/react/components/hooks/use-builder-connection-ping.js +62 -0
- package/dist/cjs/runtimes/react/components/hooks/use-builder-connection-ping.js.map +1 -0
- package/dist/cjs/runtimes/react/hooks/use-is-preview.js +33 -0
- package/dist/cjs/runtimes/react/hooks/use-is-preview.js.map +1 -0
- package/dist/cjs/runtimes/react/utils/google-fonts-url.js +49 -0
- package/dist/cjs/runtimes/react/utils/google-fonts-url.js.map +1 -0
- package/dist/cjs/state/actions/internal.js +205 -0
- package/dist/cjs/state/actions/internal.js.map +1 -0
- package/dist/cjs/state/builder-api/message-channel.js +33 -28
- package/dist/cjs/state/builder-api/message-channel.js.map +1 -1
- package/dist/cjs/state/builder-api/proxy.js +11 -9
- package/dist/cjs/state/builder-api/proxy.js.map +1 -1
- package/dist/cjs/state/mixins/setup-teardown.js +35 -0
- package/dist/cjs/state/mixins/setup-teardown.js.map +1 -0
- package/dist/cjs/state/modules/box-models.js +127 -0
- package/dist/cjs/state/modules/box-models.js.map +1 -0
- package/dist/cjs/state/modules/element-imperative-handles.js +60 -0
- package/dist/cjs/state/modules/element-imperative-handles.js.map +1 -0
- package/dist/cjs/state/modules/is-preview.js +47 -0
- package/dist/cjs/state/modules/is-preview.js.map +1 -0
- package/dist/cjs/state/modules/pointer.js +47 -0
- package/dist/cjs/state/modules/pointer.js.map +1 -0
- package/dist/cjs/state/modules/read-write-documents.js +98 -0
- package/dist/cjs/state/modules/read-write-documents.js.map +1 -0
- package/dist/cjs/state/react-builder-preview.js +586 -0
- package/dist/cjs/state/react-builder-preview.js.map +1 -0
- package/dist/cjs/state/react-page.js +313 -0
- package/dist/cjs/state/react-page.js.map +1 -0
- package/dist/cjs/state/read-write-state.js +1 -1
- package/dist/cjs/state/read-write-state.js.map +1 -1
- package/dist/cjs/state/store.js +2 -2
- package/dist/cjs/state/store.js.map +1 -1
- package/dist/cjs/state/translations/get.js +10 -9
- package/dist/cjs/state/translations/get.js.map +1 -1
- package/dist/cjs/state/translations/merge.js +10 -12
- package/dist/cjs/state/translations/merge.js.map +1 -1
- package/dist/cjs/translations/index.js +32 -0
- package/dist/cjs/translations/index.js.map +1 -0
- package/dist/cjs/unstable-framework-support/index.js +3 -0
- package/dist/cjs/unstable-framework-support/index.js.map +1 -1
- package/dist/esm/api/react.js +223 -0
- package/dist/esm/api/react.js.map +1 -0
- package/dist/esm/api-handler/handlers/manifest.js +1 -1
- package/dist/esm/builder/serialization/control-serialization.js +12 -8
- package/dist/esm/builder/serialization/control-serialization.js.map +1 -1
- package/dist/esm/client/index.js +37 -8
- package/dist/esm/client/index.js.map +1 -1
- package/dist/esm/controls/visitors/message-port-serializer/function-serialization.js.map +1 -1
- package/dist/esm/next/api-handler/config/app-router.js +10 -1
- package/dist/esm/next/api-handler/config/app-router.js.map +1 -1
- package/dist/esm/runtimes/react/components/GoogleFontLink.js +36 -0
- package/dist/esm/runtimes/react/components/GoogleFontLink.js.map +1 -0
- package/dist/esm/runtimes/react/components/LiveProvider.js +20 -0
- package/dist/esm/runtimes/react/components/LiveProvider.js.map +1 -0
- package/dist/esm/runtimes/react/components/PreviewProvider.js +33 -0
- package/dist/esm/runtimes/react/components/PreviewProvider.js.map +1 -0
- package/dist/esm/runtimes/react/components/hooks/use-builder-connection-ping.js +38 -0
- package/dist/esm/runtimes/react/components/hooks/use-builder-connection-ping.js.map +1 -0
- package/dist/esm/runtimes/react/hooks/use-is-preview.js +9 -0
- package/dist/esm/runtimes/react/hooks/use-is-preview.js.map +1 -0
- package/dist/esm/runtimes/react/utils/google-fonts-url.js +23 -0
- package/dist/esm/runtimes/react/utils/google-fonts-url.js.map +1 -0
- package/dist/esm/state/actions/internal.js +162 -0
- package/dist/esm/state/actions/internal.js.map +1 -0
- package/dist/esm/state/builder-api/message-channel.js +33 -28
- package/dist/esm/state/builder-api/message-channel.js.map +1 -1
- package/dist/esm/state/builder-api/proxy.js +11 -9
- package/dist/esm/state/builder-api/proxy.js.map +1 -1
- package/dist/esm/state/mixins/setup-teardown.js +11 -0
- package/dist/esm/state/mixins/setup-teardown.js.map +1 -0
- package/dist/esm/state/modules/box-models.js +98 -0
- package/dist/esm/state/modules/box-models.js.map +1 -0
- package/dist/esm/state/modules/element-imperative-handles.js +35 -0
- package/dist/esm/state/modules/element-imperative-handles.js.map +1 -0
- package/dist/esm/state/modules/is-preview.js +21 -0
- package/dist/esm/state/modules/is-preview.js.map +1 -0
- package/dist/esm/state/modules/pointer.js +22 -0
- package/dist/esm/state/modules/pointer.js.map +1 -0
- package/dist/esm/state/modules/read-write-documents.js +60 -0
- package/dist/esm/state/modules/read-write-documents.js.map +1 -0
- package/dist/esm/state/react-builder-preview.js +547 -0
- package/dist/esm/state/react-builder-preview.js.map +1 -0
- package/dist/esm/state/react-page.js +268 -0
- package/dist/esm/state/react-page.js.map +1 -0
- package/dist/esm/state/read-write-state.js +1 -1
- package/dist/esm/state/read-write-state.js.map +1 -1
- package/dist/esm/state/store.js +2 -2
- package/dist/esm/state/store.js.map +1 -1
- package/dist/esm/state/translations/get.js +9 -8
- package/dist/esm/state/translations/get.js.map +1 -1
- package/dist/esm/state/translations/merge.js +9 -11
- package/dist/esm/state/translations/merge.js.map +1 -1
- package/dist/esm/translations/index.js +7 -0
- package/dist/esm/translations/index.js.map +1 -0
- package/dist/esm/unstable-framework-support/index.js +2 -0
- package/dist/esm/unstable-framework-support/index.js.map +1 -1
- package/dist/types/api/react.d.ts +82 -0
- package/dist/types/api/react.d.ts.map +1 -0
- package/dist/types/builder/serialization/control-serialization.d.ts +10 -6
- package/dist/types/builder/serialization/control-serialization.d.ts.map +1 -1
- package/dist/types/client/index.d.ts +25 -1
- package/dist/types/client/index.d.ts.map +1 -1
- package/dist/types/client/tests/client.get-fonts.test.d.ts +2 -0
- package/dist/types/client/tests/client.get-fonts.test.d.ts.map +1 -0
- package/dist/types/next/api-handler/config/app-router.d.ts.map +1 -1
- package/dist/types/runtimes/react/components/GoogleFontLink.d.ts +14 -0
- package/dist/types/runtimes/react/components/GoogleFontLink.d.ts.map +1 -0
- package/dist/types/runtimes/react/components/LiveProvider.d.ts +3 -0
- package/dist/types/runtimes/react/components/LiveProvider.d.ts.map +1 -0
- package/dist/types/runtimes/react/components/PreviewProvider.d.ts +5 -0
- package/dist/types/runtimes/react/components/PreviewProvider.d.ts.map +1 -0
- package/dist/types/runtimes/react/components/hooks/use-builder-connection-ping.d.ts +4 -0
- package/dist/types/runtimes/react/components/hooks/use-builder-connection-ping.d.ts.map +1 -0
- package/dist/types/runtimes/react/hooks/use-is-preview.d.ts +2 -0
- package/dist/types/runtimes/react/hooks/use-is-preview.d.ts.map +1 -0
- package/dist/types/runtimes/react/utils/google-fonts-url.d.ts +6 -0
- package/dist/types/runtimes/react/utils/google-fonts-url.d.ts.map +1 -0
- package/dist/types/state/__tests__/fixtures/serialized-descriptors-from-builder.d.ts +5 -0
- package/dist/types/state/__tests__/fixtures/serialized-descriptors-from-builder.d.ts.map +1 -0
- package/dist/types/state/__tests__/fixtures/translatable-content-sample.d.ts +3 -0
- package/dist/types/state/__tests__/fixtures/translatable-content-sample.d.ts.map +1 -0
- package/dist/types/state/__tests__/get-translatable-content.test.d.ts +2 -0
- package/dist/types/state/__tests__/get-translatable-content.test.d.ts.map +1 -0
- package/dist/types/state/__tests__/react-page.test.d.ts +2 -0
- package/dist/types/state/__tests__/react-page.test.d.ts.map +1 -0
- package/dist/types/state/actions/internal.d.ts +181 -0
- package/dist/types/state/actions/internal.d.ts.map +1 -0
- package/dist/types/state/builder-api/message-channel.d.ts +3 -6
- package/dist/types/state/builder-api/message-channel.d.ts.map +1 -1
- package/dist/types/state/builder-api/proxy.d.ts +1 -2
- package/dist/types/state/builder-api/proxy.d.ts.map +1 -1
- package/dist/types/state/mixins/setup-teardown.d.ts +7 -0
- package/dist/types/state/mixins/setup-teardown.d.ts.map +1 -0
- package/dist/types/state/modules/box-models.d.ts +23 -0
- package/dist/types/state/modules/box-models.d.ts.map +1 -0
- package/dist/types/state/modules/element-imperative-handles.d.ts +7 -0
- package/dist/types/state/modules/element-imperative-handles.d.ts.map +1 -0
- package/dist/types/state/modules/is-preview.d.ts +6 -0
- package/dist/types/state/modules/is-preview.d.ts.map +1 -0
- package/dist/types/state/modules/pointer.d.ts +12 -0
- package/dist/types/state/modules/pointer.d.ts.map +1 -0
- package/dist/types/state/modules/read-write-documents.d.ts +14 -0
- package/dist/types/state/modules/read-write-documents.d.ts.map +1 -0
- package/dist/types/state/react-builder-preview.d.ts +108 -0
- package/dist/types/state/react-builder-preview.d.ts.map +1 -0
- package/dist/types/state/react-page.d.ts +149 -0
- package/dist/types/state/react-page.d.ts.map +1 -0
- package/dist/types/state/read-write-state.d.ts +1 -1
- package/dist/types/state/read-write-state.d.ts.map +1 -1
- package/dist/types/state/translations/get.d.ts +2 -2
- package/dist/types/state/translations/get.d.ts.map +1 -1
- package/dist/types/state/translations/merge.d.ts +2 -2
- package/dist/types/state/translations/merge.d.ts.map +1 -1
- package/dist/types/translations/index.d.ts +6 -0
- package/dist/types/translations/index.d.ts.map +1 -0
- package/dist/types/unstable-framework-support/index.d.ts +1 -0
- package/dist/types/unstable-framework-support/index.d.ts.map +1 -1
- package/package.json +9 -3
- package/translations/package.json +5 -0
|
@@ -0,0 +1,586 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
var react_builder_preview_exports = {};
|
|
30
|
+
__export(react_builder_preview_exports, {
|
|
31
|
+
builderAPIMiddleware: () => builderAPIMiddleware,
|
|
32
|
+
configureStore: () => configureStore,
|
|
33
|
+
createBox: () => import_box_models.createBox,
|
|
34
|
+
getBox: () => import_box_models.getBox,
|
|
35
|
+
initialize: () => initialize,
|
|
36
|
+
parse: () => import_box_models.parse,
|
|
37
|
+
propControllerHandlesMiddleware: () => propControllerHandlesMiddleware,
|
|
38
|
+
reducer: () => reducer,
|
|
39
|
+
startMeasuringElements: () => startMeasuringElements
|
|
40
|
+
});
|
|
41
|
+
module.exports = __toCommonJS(react_builder_preview_exports);
|
|
42
|
+
var import_toolkit = require("@reduxjs/toolkit");
|
|
43
|
+
var import_deepEqual = __toESM(require("../utils/deepEqual"));
|
|
44
|
+
var Documents = __toESM(require("./modules/read-write-documents"));
|
|
45
|
+
var ElementTrees = __toESM(require("./modules/element-trees"));
|
|
46
|
+
var ReactComponents = __toESM(require("./modules/react-components"));
|
|
47
|
+
var BoxModels = __toESM(require("./modules/box-models"));
|
|
48
|
+
var ComponentsMeta = __toESM(require("./modules/components-meta"));
|
|
49
|
+
var PropControllers = __toESM(require("./modules/prop-controllers"));
|
|
50
|
+
var PropControllerHandles = __toESM(require("./modules/prop-controller-handles"));
|
|
51
|
+
var IsInBuilder = __toESM(require("./modules/is-in-builder"));
|
|
52
|
+
var IsPreview = __toESM(require("./modules/is-preview"));
|
|
53
|
+
var BuilderEditMode = __toESM(require("./modules/builder-edit-mode"));
|
|
54
|
+
var Pointer = __toESM(require("./modules/pointer"));
|
|
55
|
+
var ElementImperativeHandles = __toESM(require("./modules/element-imperative-handles"));
|
|
56
|
+
var Breakpoints = __toESM(require("./modules/breakpoints"));
|
|
57
|
+
var import_setup_teardown = require("./mixins/setup-teardown");
|
|
58
|
+
var ReactPage = __toESM(require("./react-page"));
|
|
59
|
+
var Shared = __toESM(require("./shared-api"));
|
|
60
|
+
var import_actions2 = require("./builder-api/actions");
|
|
61
|
+
var Builder = __toESM(require("./builder-api/actions"));
|
|
62
|
+
var import_internal = require("./actions/internal");
|
|
63
|
+
var Internal = __toESM(require("./actions/internal"));
|
|
64
|
+
var import_toolkit2 = require("./toolkit");
|
|
65
|
+
var import_instances = require("../prop-controllers/instances");
|
|
66
|
+
var import_builder = require("../builder");
|
|
67
|
+
var import_host_api = require("./host-api");
|
|
68
|
+
var import_box_models = require("./modules/box-models");
|
|
69
|
+
const reducer = (0, import_toolkit.combineReducers)({
|
|
70
|
+
documents: Documents.reducer,
|
|
71
|
+
elementTrees: ElementTrees.reducer,
|
|
72
|
+
reactComponents: ReactComponents.reducer,
|
|
73
|
+
boxModels: BoxModels.reducer,
|
|
74
|
+
componentsMeta: ComponentsMeta.reducer,
|
|
75
|
+
propControllers: PropControllers.reducer,
|
|
76
|
+
propControllerHandles: PropControllerHandles.reducer,
|
|
77
|
+
isInBuilder: IsInBuilder.reducer,
|
|
78
|
+
isPreview: IsPreview.reducer,
|
|
79
|
+
builderEditMode: BuilderEditMode.reducer,
|
|
80
|
+
pointer: Pointer.reducer,
|
|
81
|
+
elementImperativeHandles: ElementImperativeHandles.reducer,
|
|
82
|
+
breakpoints: Breakpoints.reducer
|
|
83
|
+
});
|
|
84
|
+
function getDocumentsStateSlice(state) {
|
|
85
|
+
return state.documents;
|
|
86
|
+
}
|
|
87
|
+
function getBoxModelsStateSlice(state) {
|
|
88
|
+
return state.boxModels;
|
|
89
|
+
}
|
|
90
|
+
function getMeasurables(state) {
|
|
91
|
+
return BoxModels.getMeasurables(getBoxModelsStateSlice(state));
|
|
92
|
+
}
|
|
93
|
+
function getBoxModels(state) {
|
|
94
|
+
return BoxModels.getBoxModels(getBoxModelsStateSlice(state));
|
|
95
|
+
}
|
|
96
|
+
function getBoxModel(state, documentKey, elementKey) {
|
|
97
|
+
return BoxModels.getBoxModel(getBoxModelsStateSlice(state), documentKey, elementKey);
|
|
98
|
+
}
|
|
99
|
+
function getComponentsMetaStateSlice(state) {
|
|
100
|
+
return state.componentsMeta;
|
|
101
|
+
}
|
|
102
|
+
function getComponentsMeta(state) {
|
|
103
|
+
return ComponentsMeta.getComponentsMeta(getComponentsMetaStateSlice(state));
|
|
104
|
+
}
|
|
105
|
+
function getPropControllersStateSlice(state) {
|
|
106
|
+
return state.propControllers;
|
|
107
|
+
}
|
|
108
|
+
function getComponentPropControllerDescriptors(state, componentType) {
|
|
109
|
+
return PropControllers.getComponentPropControllerDescriptors(
|
|
110
|
+
getPropControllersStateSlice(state),
|
|
111
|
+
componentType
|
|
112
|
+
);
|
|
113
|
+
}
|
|
114
|
+
function getPropControllerHandlesStateSlice(state) {
|
|
115
|
+
return state.propControllerHandles;
|
|
116
|
+
}
|
|
117
|
+
function getPointer(state) {
|
|
118
|
+
return Pointer.getPointer(state.pointer);
|
|
119
|
+
}
|
|
120
|
+
function getElementImperativeHandles(state) {
|
|
121
|
+
return ElementImperativeHandles.getElementImperativeHandles(state.elementImperativeHandles);
|
|
122
|
+
}
|
|
123
|
+
function getElementImperativeHandlesContainingElement(state, element) {
|
|
124
|
+
const elementImperativeHandles = getElementImperativeHandles(state);
|
|
125
|
+
const filteredElementImperativeHandles = /* @__PURE__ */ new Map();
|
|
126
|
+
for (const [documentKey, byElementKey] of elementImperativeHandles) {
|
|
127
|
+
const filteredByElementKey = /* @__PURE__ */ new Map();
|
|
128
|
+
for (const [elementKey, elementImperativeHandle] of byElementKey) {
|
|
129
|
+
const handleElement = elementImperativeHandle.getDomNode();
|
|
130
|
+
if (handleElement?.contains(element)) {
|
|
131
|
+
filteredByElementKey.set(elementKey, elementImperativeHandle);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
if (filteredByElementKey.size > 0) {
|
|
135
|
+
filteredElementImperativeHandles.set(documentKey, filteredByElementKey);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
return filteredElementImperativeHandles;
|
|
139
|
+
}
|
|
140
|
+
function measureElements() {
|
|
141
|
+
return (dispatch, getState) => {
|
|
142
|
+
const measurables = getMeasurables(getState());
|
|
143
|
+
const currentBoxModels = getBoxModels(getState());
|
|
144
|
+
const measuredBoxModels = /* @__PURE__ */ new Map();
|
|
145
|
+
measurables.forEach((documentMeasurables, documentKey) => {
|
|
146
|
+
const measuredDocumentBoxModels = /* @__PURE__ */ new Map();
|
|
147
|
+
documentMeasurables.forEach((measurable, elementKey) => {
|
|
148
|
+
const boxModel = BoxModels.measure(measurable);
|
|
149
|
+
if (boxModel != null)
|
|
150
|
+
measuredDocumentBoxModels.set(elementKey, boxModel);
|
|
151
|
+
});
|
|
152
|
+
if (measuredDocumentBoxModels.size > 0) {
|
|
153
|
+
measuredBoxModels.set(documentKey, measuredDocumentBoxModels);
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
const changedBoxModels = /* @__PURE__ */ new Map();
|
|
157
|
+
currentBoxModels.forEach((currentDocumentBoxModels, documentKey) => {
|
|
158
|
+
const changedDocumentBoxModels = /* @__PURE__ */ new Map();
|
|
159
|
+
currentDocumentBoxModels.forEach((_boxModel, elementKey) => {
|
|
160
|
+
if (!measuredBoxModels.get(documentKey)?.has(elementKey)) {
|
|
161
|
+
changedDocumentBoxModels.set(elementKey, null);
|
|
162
|
+
}
|
|
163
|
+
if (changedDocumentBoxModels.size > 0) {
|
|
164
|
+
changedBoxModels.set(documentKey, changedDocumentBoxModels);
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
});
|
|
168
|
+
measuredBoxModels.forEach((measuredDocumentBoxModels, documentKey) => {
|
|
169
|
+
const changedDocumentBoxModels = /* @__PURE__ */ new Map();
|
|
170
|
+
measuredDocumentBoxModels.forEach((measuredBoxModel, elementKey) => {
|
|
171
|
+
const currentBoxModel = getBoxModel(getState(), documentKey, elementKey);
|
|
172
|
+
if (currentBoxModel == null || !(0, import_deepEqual.default)(currentBoxModel, measuredBoxModel)) {
|
|
173
|
+
changedDocumentBoxModels.set(elementKey, measuredBoxModel);
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
if (changedDocumentBoxModels.size > 0) {
|
|
177
|
+
changedBoxModels.set(documentKey, changedDocumentBoxModels);
|
|
178
|
+
}
|
|
179
|
+
});
|
|
180
|
+
if (changedBoxModels.size > 0)
|
|
181
|
+
dispatch(Builder.changeElementBoxModels(changedBoxModels));
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
function startMeasuringElements() {
|
|
185
|
+
return (dispatch) => {
|
|
186
|
+
let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
|
|
187
|
+
return () => {
|
|
188
|
+
cancelAnimationFrame(animationFrameHandle);
|
|
189
|
+
};
|
|
190
|
+
function handleAnimationFrameRequest() {
|
|
191
|
+
dispatch(measureElements());
|
|
192
|
+
animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
|
|
193
|
+
}
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
function getElementSize(element) {
|
|
197
|
+
return {
|
|
198
|
+
offsetWidth: element.offsetWidth,
|
|
199
|
+
offsetHeight: element.offsetHeight,
|
|
200
|
+
clientWidth: element.clientWidth,
|
|
201
|
+
clientHeight: element.clientHeight,
|
|
202
|
+
scrollWidth: element.scrollWidth,
|
|
203
|
+
scrollHeight: element.scrollHeight,
|
|
204
|
+
scrollTop: element.scrollTop,
|
|
205
|
+
scrollLeft: element.scrollLeft
|
|
206
|
+
};
|
|
207
|
+
}
|
|
208
|
+
function lockDocumentScroll() {
|
|
209
|
+
return (dispatch) => {
|
|
210
|
+
const lastDocumentOverflow = window.document.documentElement.style.overflow;
|
|
211
|
+
window.document.documentElement.style.overflow = "hidden";
|
|
212
|
+
window.document.documentElement.addEventListener("wheel", handleWheelEvent);
|
|
213
|
+
return () => {
|
|
214
|
+
window.document.documentElement.style.overflow = lastDocumentOverflow;
|
|
215
|
+
window.document.documentElement.removeEventListener("wheel", handleWheelEvent);
|
|
216
|
+
};
|
|
217
|
+
function handleWheelEvent({ deltaX, deltaY }) {
|
|
218
|
+
dispatch(Builder.handleWheel({ deltaX, deltaY }));
|
|
219
|
+
}
|
|
220
|
+
};
|
|
221
|
+
}
|
|
222
|
+
function startHandlingPointerMoveEvent() {
|
|
223
|
+
return (dispatch) => {
|
|
224
|
+
window.document.documentElement.addEventListener("pointermove", handlePointerMoveEvent);
|
|
225
|
+
return () => {
|
|
226
|
+
window.document.documentElement.removeEventListener("pointermove", handlePointerMoveEvent);
|
|
227
|
+
};
|
|
228
|
+
function handlePointerMoveEvent({ clientX, clientY }) {
|
|
229
|
+
dispatch(Builder.handlePointerMove({ clientX, clientY }));
|
|
230
|
+
}
|
|
231
|
+
};
|
|
232
|
+
}
|
|
233
|
+
function startHandlingFocusEvents() {
|
|
234
|
+
return (_dispatch, getState) => {
|
|
235
|
+
window.addEventListener("focusin", handleFocusIn);
|
|
236
|
+
window.addEventListener("focusout", handleFocusOut);
|
|
237
|
+
return () => {
|
|
238
|
+
window.removeEventListener("focusin", handleFocusIn);
|
|
239
|
+
window.removeEventListener("focusout", handleFocusOut);
|
|
240
|
+
};
|
|
241
|
+
function handleFocusIn(event) {
|
|
242
|
+
if (ReactPage.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT) {
|
|
243
|
+
return;
|
|
244
|
+
}
|
|
245
|
+
if (!(event.target instanceof window.HTMLElement) || !event.target.isContentEditable) {
|
|
246
|
+
window.parent.focus();
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
function handleFocusOut(event) {
|
|
250
|
+
if (ReactPage.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT) {
|
|
251
|
+
return;
|
|
252
|
+
}
|
|
253
|
+
if (!(event.relatedTarget instanceof window.HTMLElement) || !event.relatedTarget.isContentEditable) {
|
|
254
|
+
window.parent.focus();
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
};
|
|
258
|
+
}
|
|
259
|
+
function startMeasuringDocumentElement() {
|
|
260
|
+
return (dispatch) => {
|
|
261
|
+
let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
|
|
262
|
+
let lastSize;
|
|
263
|
+
return () => {
|
|
264
|
+
cancelAnimationFrame(animationFrameHandle);
|
|
265
|
+
};
|
|
266
|
+
function handleAnimationFrameRequest() {
|
|
267
|
+
const nextSize = getElementSize(window.document.documentElement);
|
|
268
|
+
if (!(0, import_deepEqual.default)(lastSize, nextSize)) {
|
|
269
|
+
lastSize = nextSize;
|
|
270
|
+
dispatch(Builder.changeDocumentElementSize(nextSize));
|
|
271
|
+
}
|
|
272
|
+
animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
|
|
273
|
+
}
|
|
274
|
+
};
|
|
275
|
+
}
|
|
276
|
+
function elementKeysFromElementFromPoint(elementFromPoint) {
|
|
277
|
+
return (_dispatch, getState) => {
|
|
278
|
+
if (elementFromPoint == null)
|
|
279
|
+
return null;
|
|
280
|
+
const elementImperativeHandles = getElementImperativeHandlesContainingElement(
|
|
281
|
+
getState(),
|
|
282
|
+
elementFromPoint
|
|
283
|
+
);
|
|
284
|
+
const ascendingDepthDocumentKeys = ReactPage.getDocumentKeysSortedByDepth(getState());
|
|
285
|
+
const descendingDepthDocumentKeys = ascendingDepthDocumentKeys.slice().reverse();
|
|
286
|
+
let currentElement = elementFromPoint;
|
|
287
|
+
let keys = null;
|
|
288
|
+
while (currentElement != null) {
|
|
289
|
+
for (const documentKey of descendingDepthDocumentKeys) {
|
|
290
|
+
const byElementKey = elementImperativeHandles.get(documentKey);
|
|
291
|
+
if (byElementKey == null)
|
|
292
|
+
continue;
|
|
293
|
+
for (const [elementKey, elementImperativeHandle] of byElementKey) {
|
|
294
|
+
if (elementImperativeHandle.getDomNode() === currentElement) {
|
|
295
|
+
return { documentKey, elementKey };
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
currentElement = currentElement.parentElement;
|
|
300
|
+
}
|
|
301
|
+
return keys;
|
|
302
|
+
};
|
|
303
|
+
}
|
|
304
|
+
function startPollingElementFromPoint() {
|
|
305
|
+
return (dispatch, getState) => {
|
|
306
|
+
let lastElementFromPoint = null;
|
|
307
|
+
let animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest);
|
|
308
|
+
return () => {
|
|
309
|
+
cancelAnimationFrame(animationFrameRequestId);
|
|
310
|
+
};
|
|
311
|
+
function handleAnimationFrameRequest() {
|
|
312
|
+
const pointer = getPointer(getState());
|
|
313
|
+
const elementFromPoint = pointer == null ? null : document.elementFromPoint(pointer.x, pointer.y);
|
|
314
|
+
if (elementFromPoint !== lastElementFromPoint) {
|
|
315
|
+
lastElementFromPoint = elementFromPoint;
|
|
316
|
+
const keys = dispatch(elementKeysFromElementFromPoint(elementFromPoint));
|
|
317
|
+
dispatch(Builder.elementFromPointChange(keys));
|
|
318
|
+
}
|
|
319
|
+
animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest);
|
|
320
|
+
}
|
|
321
|
+
};
|
|
322
|
+
}
|
|
323
|
+
function registerBuilderComponents() {
|
|
324
|
+
return (dispatch, getState) => {
|
|
325
|
+
const state = getState();
|
|
326
|
+
const componentsMeta = getComponentsMeta(state);
|
|
327
|
+
componentsMeta.forEach((meta, type) => {
|
|
328
|
+
const descriptors = getComponentPropControllerDescriptors(state, type);
|
|
329
|
+
if (descriptors != null) {
|
|
330
|
+
const [serializedControls, transferables] = (0, import_builder.serializeControls)(descriptors);
|
|
331
|
+
dispatch(
|
|
332
|
+
Builder.registerBuilderComponent({ type, meta, serializedControls }, transferables)
|
|
333
|
+
);
|
|
334
|
+
}
|
|
335
|
+
});
|
|
336
|
+
return () => {
|
|
337
|
+
componentsMeta.forEach((_, type) => {
|
|
338
|
+
dispatch(Builder.unregisterBuilderComponent({ type }));
|
|
339
|
+
});
|
|
340
|
+
};
|
|
341
|
+
};
|
|
342
|
+
}
|
|
343
|
+
function registerBuilderDocuments() {
|
|
344
|
+
return (dispatch, getState) => {
|
|
345
|
+
const documents = Documents.getDocuments(getDocumentsStateSlice(getState()));
|
|
346
|
+
documents.forEach((document2) => {
|
|
347
|
+
dispatch(Builder.registerBuilderDocument(document2));
|
|
348
|
+
});
|
|
349
|
+
return () => {
|
|
350
|
+
documents.forEach((_document, documentKey) => {
|
|
351
|
+
dispatch(Builder.unregisterBuilderDocument(documentKey));
|
|
352
|
+
});
|
|
353
|
+
};
|
|
354
|
+
};
|
|
355
|
+
}
|
|
356
|
+
function initialize(builderProxy) {
|
|
357
|
+
return (dispatch, getState) => {
|
|
358
|
+
const unregisterBuilderDocuments = dispatch(registerBuilderDocuments());
|
|
359
|
+
const stopMeasuringElements = dispatch(startMeasuringElements());
|
|
360
|
+
const stopMeasuringDocumentElement = dispatch(startMeasuringDocumentElement());
|
|
361
|
+
const stopHandlingFocusEvent = dispatch(startHandlingFocusEvents());
|
|
362
|
+
const unlockDocumentScroll = dispatch(lockDocumentScroll());
|
|
363
|
+
const stopHandlingPointerMoveEvent = dispatch(startHandlingPointerMoveEvent());
|
|
364
|
+
const stopPollingElementFromPoint = dispatch(startPollingElementFromPoint());
|
|
365
|
+
const unregisterBuilderComponents = dispatch(registerBuilderComponents());
|
|
366
|
+
const breakpoints = ReactPage.getBreakpoints(getState());
|
|
367
|
+
dispatch(Shared.setBreakpoints(breakpoints));
|
|
368
|
+
dispatch(Internal.setIsInBuilder(true));
|
|
369
|
+
builderProxy.dispatchBuffered();
|
|
370
|
+
return () => {
|
|
371
|
+
unregisterBuilderDocuments();
|
|
372
|
+
stopMeasuringElements();
|
|
373
|
+
stopMeasuringDocumentElement();
|
|
374
|
+
stopHandlingFocusEvent();
|
|
375
|
+
unlockDocumentScroll();
|
|
376
|
+
stopHandlingPointerMoveEvent();
|
|
377
|
+
stopPollingElementFromPoint();
|
|
378
|
+
unregisterBuilderComponents();
|
|
379
|
+
dispatch(Internal.setIsInBuilder(false));
|
|
380
|
+
};
|
|
381
|
+
};
|
|
382
|
+
}
|
|
383
|
+
function measureBoxModelsMiddleware() {
|
|
384
|
+
return (0, import_toolkit2.actionMiddleware)(({ dispatch }) => (next) => {
|
|
385
|
+
return (action) => {
|
|
386
|
+
switch (action.type) {
|
|
387
|
+
case import_internal.InternalActionTypes.REGISTER_COMPONENT_HANDLE: {
|
|
388
|
+
if (BoxModels.isMeasurable(action.payload.componentHandle)) {
|
|
389
|
+
dispatch(
|
|
390
|
+
Internal.registerMeasurable(
|
|
391
|
+
action.payload.documentKey,
|
|
392
|
+
action.payload.elementKey,
|
|
393
|
+
action.payload.componentHandle
|
|
394
|
+
)
|
|
395
|
+
);
|
|
396
|
+
}
|
|
397
|
+
break;
|
|
398
|
+
}
|
|
399
|
+
case import_internal.InternalActionTypes.UNREGISTER_COMPONENT_HANDLE:
|
|
400
|
+
dispatch(
|
|
401
|
+
Internal.unregisterMeasurable(action.payload.documentKey, action.payload.elementKey)
|
|
402
|
+
);
|
|
403
|
+
break;
|
|
404
|
+
}
|
|
405
|
+
return next(action);
|
|
406
|
+
};
|
|
407
|
+
});
|
|
408
|
+
}
|
|
409
|
+
function builderAPIMiddleware(builderProxy) {
|
|
410
|
+
return (0, import_toolkit2.actionMiddleware)(({ dispatch }) => (next) => {
|
|
411
|
+
if (typeof window === "undefined")
|
|
412
|
+
return (action) => next(action);
|
|
413
|
+
let cleanUp = () => {
|
|
414
|
+
};
|
|
415
|
+
return (action) => {
|
|
416
|
+
switch (action.type) {
|
|
417
|
+
case import_actions2.BuilderActionTypes.CHANGE_ELEMENT_BOX_MODELS:
|
|
418
|
+
case import_actions2.BuilderActionTypes.MOUNT_COMPONENT:
|
|
419
|
+
case import_actions2.BuilderActionTypes.UNMOUNT_COMPONENT:
|
|
420
|
+
case import_actions2.BuilderActionTypes.CHANGE_DOCUMENT_ELEMENT_SIZE:
|
|
421
|
+
case import_actions2.BuilderActionTypes.MESSAGE_BUILDER_PROP_CONTROLLER:
|
|
422
|
+
case import_actions2.BuilderActionTypes.HANDLE_WHEEL:
|
|
423
|
+
case import_actions2.BuilderActionTypes.HANDLE_POINTER_MOVE:
|
|
424
|
+
case import_actions2.BuilderActionTypes.ELEMENT_FROM_POINT_CHANGE:
|
|
425
|
+
case import_actions2.BuilderActionTypes.SET_LOCALE:
|
|
426
|
+
case import_actions2.BuilderActionTypes.SET_BREAKPOINTS:
|
|
427
|
+
case import_actions2.BuilderActionTypes.REGISTER_BUILDER_DOCUMENT:
|
|
428
|
+
case import_actions2.BuilderActionTypes.UNREGISTER_BUILDER_DOCUMENT:
|
|
429
|
+
case import_actions2.BuilderActionTypes.REGISTER_BUILDER_COMPONENT:
|
|
430
|
+
case import_actions2.BuilderActionTypes.UNREGISTER_BUILDER_COMPONENT:
|
|
431
|
+
builderProxy.execute(action);
|
|
432
|
+
break;
|
|
433
|
+
case import_host_api.HostActionTypes.CHANGE_DOCUMENT_ELEMENT_SCROLL_TOP:
|
|
434
|
+
window.document.documentElement.scrollTop = action.payload.scrollTop;
|
|
435
|
+
break;
|
|
436
|
+
case import_host_api.HostActionTypes.SCROLL_DOCUMENT_ELEMENT:
|
|
437
|
+
window.document.documentElement.scrollTop += action.payload.scrollTopDelta;
|
|
438
|
+
break;
|
|
439
|
+
case import_host_api.HostActionTypes.SET_BUILDER_EDIT_MODE:
|
|
440
|
+
window.getSelection()?.removeAllRanges();
|
|
441
|
+
break;
|
|
442
|
+
case import_host_api.HostActionTypes.INIT:
|
|
443
|
+
cleanUp = dispatch(initialize(builderProxy));
|
|
444
|
+
break;
|
|
445
|
+
case import_host_api.HostActionTypes.CLEAN_UP:
|
|
446
|
+
cleanUp();
|
|
447
|
+
break;
|
|
448
|
+
}
|
|
449
|
+
return next(action);
|
|
450
|
+
};
|
|
451
|
+
});
|
|
452
|
+
}
|
|
453
|
+
function createAndRegisterPropControllers(documentKey, elementKey) {
|
|
454
|
+
return (dispatch, getState) => {
|
|
455
|
+
const descriptors = ReactPage.getElementPropControllerDescriptors(
|
|
456
|
+
getState(),
|
|
457
|
+
documentKey,
|
|
458
|
+
elementKey
|
|
459
|
+
);
|
|
460
|
+
if (descriptors == null)
|
|
461
|
+
return null;
|
|
462
|
+
const propControllers = Object.entries(descriptors).reduce(
|
|
463
|
+
(acc, [propName, descriptor]) => {
|
|
464
|
+
const propController = (0, import_instances.createPropController)(
|
|
465
|
+
descriptor,
|
|
466
|
+
(message) => dispatch(
|
|
467
|
+
Builder.messageBuilderPropController(documentKey, elementKey, propName, message)
|
|
468
|
+
)
|
|
469
|
+
);
|
|
470
|
+
return { ...acc, [propName]: propController };
|
|
471
|
+
},
|
|
472
|
+
{}
|
|
473
|
+
);
|
|
474
|
+
dispatch(Internal.registerPropControllers(documentKey, elementKey, propControllers));
|
|
475
|
+
return propControllers;
|
|
476
|
+
};
|
|
477
|
+
}
|
|
478
|
+
function propControllerHandlesMiddleware() {
|
|
479
|
+
return (0, import_toolkit2.actionMiddleware)(({ dispatch, getState }) => (next) => {
|
|
480
|
+
return (action) => {
|
|
481
|
+
switch (action.type) {
|
|
482
|
+
case import_internal.InternalActionTypes.REGISTER_COMPONENT_HANDLE: {
|
|
483
|
+
const { documentKey, elementKey, componentHandle } = action.payload;
|
|
484
|
+
const element = ReactPage.getElement(getState(), documentKey, elementKey);
|
|
485
|
+
const propControllers = dispatch(
|
|
486
|
+
createAndRegisterPropControllers(documentKey, elementKey)
|
|
487
|
+
);
|
|
488
|
+
if (element != null && !ReactPage.isElementReference(element) && PropControllerHandles.isPropControllersHandle(componentHandle)) {
|
|
489
|
+
dispatch(
|
|
490
|
+
Internal.registerPropControllersHandle(documentKey, elementKey, componentHandle)
|
|
491
|
+
);
|
|
492
|
+
componentHandle.setPropControllers(propControllers);
|
|
493
|
+
}
|
|
494
|
+
break;
|
|
495
|
+
}
|
|
496
|
+
case import_internal.InternalActionTypes.UNREGISTER_COMPONENT_HANDLE: {
|
|
497
|
+
const { documentKey, elementKey } = action.payload;
|
|
498
|
+
const handle = PropControllerHandles.getPropControllersHandle(
|
|
499
|
+
getPropControllerHandlesStateSlice(getState()),
|
|
500
|
+
documentKey,
|
|
501
|
+
elementKey
|
|
502
|
+
);
|
|
503
|
+
handle?.setPropControllers(null);
|
|
504
|
+
dispatch(Internal.unregisterPropControllers(documentKey, elementKey));
|
|
505
|
+
break;
|
|
506
|
+
}
|
|
507
|
+
case import_host_api.HostActionTypes.MESSAGE_HOST_PROP_CONTROLLER: {
|
|
508
|
+
const propController = PropControllerHandles.getPropController(
|
|
509
|
+
getPropControllerHandlesStateSlice(getState()),
|
|
510
|
+
action.payload.documentKey,
|
|
511
|
+
action.payload.elementKey,
|
|
512
|
+
action.payload.propName
|
|
513
|
+
);
|
|
514
|
+
if (propController)
|
|
515
|
+
propController.recv(action.payload.message);
|
|
516
|
+
}
|
|
517
|
+
}
|
|
518
|
+
return next(action);
|
|
519
|
+
};
|
|
520
|
+
});
|
|
521
|
+
}
|
|
522
|
+
function makeswiftApiClientSyncMiddleware(client) {
|
|
523
|
+
return (0, import_toolkit2.actionMiddleware)(() => (next) => {
|
|
524
|
+
return (action) => {
|
|
525
|
+
client.makeswiftApiClient.dispatch(action);
|
|
526
|
+
return next(action);
|
|
527
|
+
};
|
|
528
|
+
});
|
|
529
|
+
}
|
|
530
|
+
function setupBuilderProxy(builderProxy) {
|
|
531
|
+
return (dispatch) => {
|
|
532
|
+
builderProxy.setup({ onHostAction: (action) => dispatch(action) });
|
|
533
|
+
};
|
|
534
|
+
}
|
|
535
|
+
function configureStore({
|
|
536
|
+
preloadedState,
|
|
537
|
+
client,
|
|
538
|
+
builderProxy
|
|
539
|
+
}) {
|
|
540
|
+
const initialState = {
|
|
541
|
+
...preloadedState,
|
|
542
|
+
isPreview: IsPreview.getInitialState(true)
|
|
543
|
+
};
|
|
544
|
+
const store = (0, import_toolkit.configureStore)({
|
|
545
|
+
reducer,
|
|
546
|
+
preloadedState: initialState,
|
|
547
|
+
middleware: (getDefaultMiddleware) => getDefaultMiddleware(import_toolkit2.middlewareOptions).concat(
|
|
548
|
+
ReactPage.elementTreeMiddleware(),
|
|
549
|
+
measureBoxModelsMiddleware(),
|
|
550
|
+
builderAPIMiddleware(builderProxy),
|
|
551
|
+
propControllerHandlesMiddleware(),
|
|
552
|
+
makeswiftApiClientSyncMiddleware(client)
|
|
553
|
+
),
|
|
554
|
+
enhancers: (getDefaultEnhancers) => getDefaultEnhancers().concat(
|
|
555
|
+
(0, import_setup_teardown.withSetupTeardown)(
|
|
556
|
+
() => {
|
|
557
|
+
const dispatch = store.dispatch;
|
|
558
|
+
dispatch(setupBuilderProxy(builderProxy));
|
|
559
|
+
},
|
|
560
|
+
() => builderProxy.teardown()
|
|
561
|
+
)
|
|
562
|
+
),
|
|
563
|
+
devTools: (0, import_toolkit2.devToolsConfig)({
|
|
564
|
+
name: `Host store (${(/* @__PURE__ */ new Date()).toISOString()})`,
|
|
565
|
+
actionsDenylist: [
|
|
566
|
+
import_host_api.HostActionTypes.BUILDER_POINTER_MOVE,
|
|
567
|
+
import_actions2.BuilderActionTypes.HANDLE_POINTER_MOVE,
|
|
568
|
+
import_actions2.BuilderActionTypes.ELEMENT_FROM_POINT_CHANGE
|
|
569
|
+
]
|
|
570
|
+
})
|
|
571
|
+
});
|
|
572
|
+
return store;
|
|
573
|
+
}
|
|
574
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
575
|
+
0 && (module.exports = {
|
|
576
|
+
builderAPIMiddleware,
|
|
577
|
+
configureStore,
|
|
578
|
+
createBox,
|
|
579
|
+
getBox,
|
|
580
|
+
initialize,
|
|
581
|
+
parse,
|
|
582
|
+
propControllerHandlesMiddleware,
|
|
583
|
+
reducer,
|
|
584
|
+
startMeasuringElements
|
|
585
|
+
});
|
|
586
|
+
//# sourceMappingURL=react-builder-preview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/state/react-builder-preview.ts"],"sourcesContent":["import {\n configureStore as configureReduxStore,\n combineReducers,\n type Middleware,\n type ThunkAction,\n type ThunkDispatch,\n} from '@reduxjs/toolkit'\n\nimport { ControlInstance } from '@makeswift/controls'\n\nimport deepEqual from '../utils/deepEqual'\n\nimport * as Documents from './modules/read-write-documents'\nimport * as ElementTrees from './modules/element-trees'\nimport * as ReactComponents from './modules/react-components'\nimport * as BoxModels from './modules/box-models'\nimport * as ComponentsMeta from './modules/components-meta'\nimport * as PropControllers from './modules/prop-controllers'\nimport * as PropControllerHandles from './modules/prop-controller-handles'\nimport * as IsInBuilder from './modules/is-in-builder'\nimport * as IsPreview from './modules/is-preview'\nimport * as BuilderEditMode from './modules/builder-edit-mode'\nimport * as Pointer from './modules/pointer'\nimport * as ElementImperativeHandles from './modules/element-imperative-handles'\nimport * as Breakpoints from './modules/breakpoints'\n\nimport { withSetupTeardown } from './mixins/setup-teardown'\n\nimport * as ReactPage from './react-page'\nimport { type Action } from './actions'\n\nimport * as Shared from './shared-api'\n\nimport { BuilderActionTypes } from './builder-api/actions'\nimport * as Builder from './builder-api/actions'\n\nimport { InternalActionTypes } from './actions/internal'\nimport * as Internal from './actions/internal'\n\nimport { actionMiddleware, middlewareOptions, devToolsConfig } from './toolkit'\n\nimport { createPropController } from '../prop-controllers/instances'\nimport { serializeControls } from '../builder'\nimport { MakeswiftHostApiClient } from '../api/react'\nimport { ElementImperativeHandle } from '../runtimes/react/element-imperative-handle'\nimport { type BuilderAPIProxy } from './builder-api/proxy'\nimport { HostActionTypes } from './host-api'\n\nexport type { Operation } from './modules/read-write-documents'\nexport type { BoxModelHandle } from './modules/box-models'\nexport { createBox, getBox, parse } from './modules/box-models'\n\nexport const reducer = combineReducers({\n documents: Documents.reducer,\n elementTrees: ElementTrees.reducer,\n reactComponents: ReactComponents.reducer,\n boxModels: BoxModels.reducer,\n componentsMeta: ComponentsMeta.reducer,\n propControllers: PropControllers.reducer,\n propControllerHandles: PropControllerHandles.reducer,\n isInBuilder: IsInBuilder.reducer,\n isPreview: IsPreview.reducer,\n builderEditMode: BuilderEditMode.reducer,\n pointer: Pointer.reducer,\n elementImperativeHandles: ElementImperativeHandles.reducer,\n breakpoints: Breakpoints.reducer,\n})\n\nexport type State = ReturnType<typeof reducer>\nexport type Dispatch = ThunkDispatch<State, unknown, Action>\n\nfunction getDocumentsStateSlice(state: State): Documents.State {\n return state.documents\n}\n\nfunction getBoxModelsStateSlice(state: State): BoxModels.State {\n return state.boxModels\n}\n\nfunction getMeasurables(state: State): Map<string, Map<string, BoxModels.Measurable>> {\n return BoxModels.getMeasurables(getBoxModelsStateSlice(state))\n}\n\nfunction getBoxModels(state: State): Map<string, Map<string, BoxModels.BoxModel>> {\n return BoxModels.getBoxModels(getBoxModelsStateSlice(state))\n}\n\nfunction getBoxModel(\n state: State,\n documentKey: string,\n elementKey: string,\n): BoxModels.BoxModel | null {\n return BoxModels.getBoxModel(getBoxModelsStateSlice(state), documentKey, elementKey)\n}\n\nfunction getComponentsMetaStateSlice(state: State): ComponentsMeta.State {\n return state.componentsMeta\n}\n\nfunction getComponentsMeta(state: State): Map<string, ComponentsMeta.ComponentMeta> {\n return ComponentsMeta.getComponentsMeta(getComponentsMetaStateSlice(state))\n}\n\nfunction getPropControllersStateSlice(state: State): PropControllers.State {\n return state.propControllers\n}\n\nfunction getComponentPropControllerDescriptors(\n state: State,\n componentType: string,\n): Record<string, PropControllers.PropControllerDescriptor> | null {\n return PropControllers.getComponentPropControllerDescriptors(\n getPropControllersStateSlice(state),\n componentType,\n )\n}\n\nfunction getPropControllerHandlesStateSlice(state: State): PropControllerHandles.State {\n return state.propControllerHandles\n}\n\nfunction getPointer(state: State): Pointer.Point | null {\n return Pointer.getPointer(state.pointer)\n}\n\nfunction getElementImperativeHandles(\n state: State,\n): Map<string, Map<string, ElementImperativeHandle>> {\n return ElementImperativeHandles.getElementImperativeHandles(state.elementImperativeHandles)\n}\n\nfunction getElementImperativeHandlesContainingElement(\n state: State,\n element: Element,\n): Map<string, Map<string, ElementImperativeHandle>> {\n const elementImperativeHandles = getElementImperativeHandles(state)\n const filteredElementImperativeHandles = new Map<string, Map<string, ElementImperativeHandle>>()\n\n for (const [documentKey, byElementKey] of elementImperativeHandles) {\n const filteredByElementKey = new Map<string, ElementImperativeHandle>()\n\n for (const [elementKey, elementImperativeHandle] of byElementKey) {\n const handleElement = elementImperativeHandle.getDomNode()\n\n if (handleElement?.contains(element)) {\n filteredByElementKey.set(elementKey, elementImperativeHandle)\n }\n }\n\n if (filteredByElementKey.size > 0) {\n filteredElementImperativeHandles.set(documentKey, filteredByElementKey)\n }\n }\n\n return filteredElementImperativeHandles\n}\n\nfunction measureElements(): ThunkAction<void, State, unknown, Action> {\n return (dispatch, getState) => {\n const measurables = getMeasurables(getState())\n const currentBoxModels = getBoxModels(getState())\n const measuredBoxModels = new Map<string, Map<string, BoxModels.BoxModel>>()\n\n measurables.forEach((documentMeasurables, documentKey) => {\n const measuredDocumentBoxModels = new Map<string, BoxModels.BoxModel>()\n\n documentMeasurables.forEach((measurable, elementKey) => {\n const boxModel = BoxModels.measure(measurable)\n\n if (boxModel != null) measuredDocumentBoxModels.set(elementKey, boxModel)\n })\n\n if (measuredDocumentBoxModels.size > 0) {\n measuredBoxModels.set(documentKey, measuredDocumentBoxModels)\n }\n })\n\n const changedBoxModels = new Map<string, Map<string, BoxModels.BoxModel | null>>()\n\n currentBoxModels.forEach((currentDocumentBoxModels, documentKey) => {\n const changedDocumentBoxModels = new Map<string, BoxModels.BoxModel | null>()\n\n currentDocumentBoxModels.forEach((_boxModel, elementKey) => {\n if (!measuredBoxModels.get(documentKey)?.has(elementKey)) {\n changedDocumentBoxModels.set(elementKey, null)\n }\n\n if (changedDocumentBoxModels.size > 0) {\n changedBoxModels.set(documentKey, changedDocumentBoxModels)\n }\n })\n })\n\n measuredBoxModels.forEach((measuredDocumentBoxModels, documentKey) => {\n const changedDocumentBoxModels = new Map<string, BoxModels.BoxModel | null>()\n\n measuredDocumentBoxModels.forEach((measuredBoxModel, elementKey) => {\n const currentBoxModel = getBoxModel(getState(), documentKey, elementKey)\n\n if (currentBoxModel == null || !deepEqual(currentBoxModel, measuredBoxModel)) {\n changedDocumentBoxModels.set(elementKey, measuredBoxModel)\n }\n })\n\n if (changedDocumentBoxModels.size > 0) {\n changedBoxModels.set(documentKey, changedDocumentBoxModels)\n }\n })\n\n if (changedBoxModels.size > 0) dispatch(Builder.changeElementBoxModels(changedBoxModels))\n }\n}\n\nexport function startMeasuringElements(): ThunkAction<() => void, State, unknown, Action> {\n return dispatch => {\n let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n\n return () => {\n cancelAnimationFrame(animationFrameHandle)\n }\n\n function handleAnimationFrameRequest() {\n dispatch(measureElements())\n\n animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n }\n }\n}\n\nexport type Size = {\n offsetWidth: number\n offsetHeight: number\n clientWidth: number\n clientHeight: number\n scrollWidth: number\n scrollHeight: number\n scrollTop: number\n scrollLeft: number\n}\n\nfunction getElementSize(element: HTMLElement): Size {\n return {\n offsetWidth: element.offsetWidth,\n offsetHeight: element.offsetHeight,\n clientWidth: element.clientWidth,\n clientHeight: element.clientHeight,\n scrollWidth: element.scrollWidth,\n scrollHeight: element.scrollHeight,\n scrollTop: element.scrollTop,\n scrollLeft: element.scrollLeft,\n }\n}\n\nfunction lockDocumentScroll(): ThunkAction<() => void, State, unknown, Action> {\n return dispatch => {\n const lastDocumentOverflow = window.document.documentElement.style.overflow\n window.document.documentElement.style.overflow = 'hidden'\n\n window.document.documentElement.addEventListener('wheel', handleWheelEvent)\n\n return () => {\n window.document.documentElement.style.overflow = lastDocumentOverflow\n window.document.documentElement.removeEventListener('wheel', handleWheelEvent)\n }\n\n function handleWheelEvent({ deltaX, deltaY }: WheelEvent) {\n dispatch(Builder.handleWheel({ deltaX, deltaY }))\n }\n }\n}\n\nfunction startHandlingPointerMoveEvent(): ThunkAction<() => void, State, unknown, Action> {\n return dispatch => {\n window.document.documentElement.addEventListener('pointermove', handlePointerMoveEvent)\n\n return () => {\n window.document.documentElement.removeEventListener('pointermove', handlePointerMoveEvent)\n }\n\n function handlePointerMoveEvent({ clientX, clientY }: PointerEvent) {\n dispatch(Builder.handlePointerMove({ clientX, clientY }))\n }\n }\n}\n\nfunction startHandlingFocusEvents(): ThunkAction<() => void, State, unknown, Action> {\n return (_dispatch, getState) => {\n window.addEventListener('focusin', handleFocusIn)\n window.addEventListener('focusout', handleFocusOut)\n\n return () => {\n window.removeEventListener('focusin', handleFocusIn)\n window.removeEventListener('focusout', handleFocusOut)\n }\n\n function handleFocusIn(event: FocusEvent) {\n if (ReactPage.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT) {\n return\n }\n\n if (!(event.target instanceof window.HTMLElement) || !event.target.isContentEditable) {\n window.parent.focus()\n }\n }\n\n function handleFocusOut(event: FocusEvent) {\n if (ReactPage.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT) {\n return\n }\n\n if (\n !(event.relatedTarget instanceof window.HTMLElement) ||\n !event.relatedTarget.isContentEditable\n ) {\n window.parent.focus()\n }\n }\n }\n}\n\nfunction startMeasuringDocumentElement(): ThunkAction<() => void, unknown, unknown, Action> {\n return dispatch => {\n let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n let lastSize: Size\n\n return () => {\n cancelAnimationFrame(animationFrameHandle)\n }\n\n function handleAnimationFrameRequest() {\n const nextSize = getElementSize(window.document.documentElement)\n\n if (!deepEqual(lastSize, nextSize)) {\n lastSize = nextSize\n\n dispatch(Builder.changeDocumentElementSize(nextSize))\n }\n\n animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n }\n }\n}\n\nfunction elementKeysFromElementFromPoint(\n elementFromPoint: Element | null,\n): ThunkAction<{ documentKey: string; elementKey: string } | null, State, unknown, Action> {\n return (_dispatch, getState) => {\n if (elementFromPoint == null) return null\n\n const elementImperativeHandles = getElementImperativeHandlesContainingElement(\n getState(),\n elementFromPoint,\n )\n const ascendingDepthDocumentKeys = ReactPage.getDocumentKeysSortedByDepth(getState())\n const descendingDepthDocumentKeys = ascendingDepthDocumentKeys.slice().reverse()\n\n let currentElement: Element | null = elementFromPoint\n let keys = null\n\n while (currentElement != null) {\n for (const documentKey of descendingDepthDocumentKeys) {\n const byElementKey = elementImperativeHandles.get(documentKey)\n\n if (byElementKey == null) continue\n\n for (const [elementKey, elementImperativeHandle] of byElementKey) {\n if (elementImperativeHandle.getDomNode() === currentElement) {\n return { documentKey, elementKey }\n }\n }\n }\n\n currentElement = currentElement.parentElement\n }\n\n return keys\n }\n}\n\nfunction startPollingElementFromPoint(): ThunkAction<() => void, State, unknown, Action> {\n return (dispatch, getState) => {\n let lastElementFromPoint: Element | null = null\n let animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest)\n\n return () => {\n cancelAnimationFrame(animationFrameRequestId)\n }\n\n function handleAnimationFrameRequest() {\n const pointer = getPointer(getState())\n const elementFromPoint =\n pointer == null ? null : document.elementFromPoint(pointer.x, pointer.y)\n\n if (elementFromPoint !== lastElementFromPoint) {\n lastElementFromPoint = elementFromPoint\n\n const keys = dispatch(elementKeysFromElementFromPoint(elementFromPoint))\n\n dispatch(Builder.elementFromPointChange(keys))\n }\n\n animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest)\n }\n }\n}\n\nfunction registerBuilderComponents(): ThunkAction<() => void, State, unknown, Action> {\n return (dispatch, getState) => {\n const state = getState()\n const componentsMeta = getComponentsMeta(state)\n\n componentsMeta.forEach((meta, type) => {\n const descriptors = getComponentPropControllerDescriptors(state, type)\n if (descriptors != null) {\n const [serializedControls, transferables] = serializeControls(descriptors)\n dispatch(\n Builder.registerBuilderComponent({ type, meta, serializedControls }, transferables),\n )\n }\n })\n\n return () => {\n componentsMeta.forEach((_, type) => {\n dispatch(Builder.unregisterBuilderComponent({ type }))\n })\n }\n }\n}\n\nfunction registerBuilderDocuments(): ThunkAction<() => void, State, unknown, Action> {\n return (dispatch, getState) => {\n const documents = Documents.getDocuments(getDocumentsStateSlice(getState()))\n\n documents.forEach(document => {\n dispatch(Builder.registerBuilderDocument(document))\n })\n\n return () => {\n documents.forEach((_document, documentKey) => {\n dispatch(Builder.unregisterBuilderDocument(documentKey))\n })\n }\n }\n}\n\nexport function initialize(\n builderProxy: BuilderAPIProxy,\n): ThunkAction<() => void, State, unknown, Action> {\n return (dispatch, getState) => {\n const unregisterBuilderDocuments = dispatch(registerBuilderDocuments())\n const stopMeasuringElements = dispatch(startMeasuringElements())\n const stopMeasuringDocumentElement = dispatch(startMeasuringDocumentElement())\n const stopHandlingFocusEvent = dispatch(startHandlingFocusEvents())\n const unlockDocumentScroll = dispatch(lockDocumentScroll())\n const stopHandlingPointerMoveEvent = dispatch(startHandlingPointerMoveEvent())\n const stopPollingElementFromPoint = dispatch(startPollingElementFromPoint())\n const unregisterBuilderComponents = dispatch(registerBuilderComponents())\n\n const breakpoints = ReactPage.getBreakpoints(getState())\n dispatch(Shared.setBreakpoints(breakpoints))\n dispatch(Internal.setIsInBuilder(true))\n builderProxy.dispatchBuffered()\n\n return () => {\n unregisterBuilderDocuments()\n stopMeasuringElements()\n stopMeasuringDocumentElement()\n stopHandlingFocusEvent()\n unlockDocumentScroll()\n stopHandlingPointerMoveEvent()\n stopPollingElementFromPoint()\n unregisterBuilderComponents()\n dispatch(Internal.setIsInBuilder(false))\n }\n }\n}\n\nfunction measureBoxModelsMiddleware(): Middleware<Dispatch, State, Dispatch> {\n return actionMiddleware(({ dispatch }) => next => {\n return (action: Action) => {\n switch (action.type) {\n case InternalActionTypes.REGISTER_COMPONENT_HANDLE: {\n if (BoxModels.isMeasurable(action.payload.componentHandle)) {\n dispatch(\n Internal.registerMeasurable(\n action.payload.documentKey,\n action.payload.elementKey,\n action.payload.componentHandle,\n ),\n )\n }\n\n break\n }\n\n case InternalActionTypes.UNREGISTER_COMPONENT_HANDLE:\n dispatch(\n Internal.unregisterMeasurable(action.payload.documentKey, action.payload.elementKey),\n )\n break\n }\n\n return next(action)\n }\n })\n}\n\nexport function builderAPIMiddleware(\n builderProxy: BuilderAPIProxy,\n): Middleware<Dispatch, State, Dispatch> {\n return actionMiddleware(({ dispatch }) => next => {\n if (typeof window === 'undefined') return (action: Action) => next(action)\n\n let cleanUp = () => {}\n return (action: Action) => {\n switch (action.type) {\n case BuilderActionTypes.CHANGE_ELEMENT_BOX_MODELS:\n case BuilderActionTypes.MOUNT_COMPONENT:\n case BuilderActionTypes.UNMOUNT_COMPONENT:\n case BuilderActionTypes.CHANGE_DOCUMENT_ELEMENT_SIZE:\n case BuilderActionTypes.MESSAGE_BUILDER_PROP_CONTROLLER:\n case BuilderActionTypes.HANDLE_WHEEL:\n case BuilderActionTypes.HANDLE_POINTER_MOVE:\n case BuilderActionTypes.ELEMENT_FROM_POINT_CHANGE:\n case BuilderActionTypes.SET_LOCALE:\n case BuilderActionTypes.SET_BREAKPOINTS:\n case BuilderActionTypes.REGISTER_BUILDER_DOCUMENT:\n case BuilderActionTypes.UNREGISTER_BUILDER_DOCUMENT:\n case BuilderActionTypes.REGISTER_BUILDER_COMPONENT:\n case BuilderActionTypes.UNREGISTER_BUILDER_COMPONENT:\n builderProxy.execute(action)\n break\n\n case HostActionTypes.CHANGE_DOCUMENT_ELEMENT_SCROLL_TOP:\n window.document.documentElement.scrollTop = action.payload.scrollTop\n break\n\n case HostActionTypes.SCROLL_DOCUMENT_ELEMENT:\n window.document.documentElement.scrollTop += action.payload.scrollTopDelta\n break\n\n case HostActionTypes.SET_BUILDER_EDIT_MODE:\n window.getSelection()?.removeAllRanges()\n break\n\n case HostActionTypes.INIT:\n // dispatched by the parent window after establishing the connection\n cleanUp = dispatch(initialize(builderProxy))\n break\n\n case HostActionTypes.CLEAN_UP:\n // dispatched by the parent window on disconnect\n cleanUp()\n break\n }\n\n return next(action)\n }\n })\n}\n\nfunction createAndRegisterPropControllers(\n documentKey: string,\n elementKey: string,\n): ThunkAction<Record<string, ControlInstance> | null, State, unknown, Action> {\n return (dispatch, getState) => {\n const descriptors = ReactPage.getElementPropControllerDescriptors(\n getState(),\n documentKey,\n elementKey,\n )\n\n if (descriptors == null) return null\n\n const propControllers = Object.entries(descriptors).reduce(\n (acc, [propName, descriptor]) => {\n const propController = createPropController(descriptor, message =>\n dispatch(\n Builder.messageBuilderPropController(documentKey, elementKey, propName, message),\n ),\n ) as ControlInstance\n\n return { ...acc, [propName]: propController }\n },\n {} as Record<string, ControlInstance>,\n )\n\n dispatch(Internal.registerPropControllers(documentKey, elementKey, propControllers))\n\n return propControllers\n }\n}\n\nexport function propControllerHandlesMiddleware(): Middleware<Dispatch, State, Dispatch> {\n return actionMiddleware(({ dispatch, getState }) => next => {\n return (action: Action) => {\n switch (action.type) {\n case InternalActionTypes.REGISTER_COMPONENT_HANDLE: {\n const { documentKey, elementKey, componentHandle } = action.payload\n const element = ReactPage.getElement(getState(), documentKey, elementKey)\n const propControllers = dispatch(\n createAndRegisterPropControllers(documentKey, elementKey),\n )\n\n if (\n element != null &&\n !ReactPage.isElementReference(element) &&\n PropControllerHandles.isPropControllersHandle(componentHandle)\n ) {\n dispatch(\n Internal.registerPropControllersHandle(documentKey, elementKey, componentHandle),\n )\n componentHandle.setPropControllers(propControllers)\n }\n\n break\n }\n\n case InternalActionTypes.UNREGISTER_COMPONENT_HANDLE: {\n const { documentKey, elementKey } = action.payload\n const handle = PropControllerHandles.getPropControllersHandle(\n getPropControllerHandlesStateSlice(getState()),\n documentKey,\n elementKey,\n )\n\n handle?.setPropControllers(null)\n\n dispatch(Internal.unregisterPropControllers(documentKey, elementKey))\n\n break\n }\n\n case HostActionTypes.MESSAGE_HOST_PROP_CONTROLLER: {\n const propController = PropControllerHandles.getPropController(\n getPropControllerHandlesStateSlice(getState()),\n action.payload.documentKey,\n action.payload.elementKey,\n action.payload.propName,\n )\n\n if (propController) propController.recv(action.payload.message)\n }\n }\n\n return next(action)\n }\n })\n}\n\nfunction makeswiftApiClientSyncMiddleware(\n client: MakeswiftHostApiClient,\n): Middleware<Dispatch, State, Dispatch> {\n return actionMiddleware(() => next => {\n return (action: Action) => {\n client.makeswiftApiClient.dispatch(action)\n\n return next(action)\n }\n })\n}\n\nfunction setupBuilderProxy(\n builderProxy: BuilderAPIProxy,\n): ThunkAction<void, State, unknown, Action> {\n return dispatch => {\n builderProxy.setup({ onHostAction: action => dispatch(action) })\n }\n}\n\nexport function configureStore({\n preloadedState,\n client,\n builderProxy,\n}: {\n preloadedState: Partial<State>\n client: MakeswiftHostApiClient\n builderProxy: BuilderAPIProxy\n}) {\n const initialState: Partial<State> = {\n ...preloadedState,\n isPreview: IsPreview.getInitialState(true),\n }\n\n const store = configureReduxStore({\n reducer,\n preloadedState: initialState,\n\n middleware: getDefaultMiddleware =>\n getDefaultMiddleware(middlewareOptions).concat(\n ReactPage.elementTreeMiddleware(),\n measureBoxModelsMiddleware(),\n builderAPIMiddleware(builderProxy),\n propControllerHandlesMiddleware(),\n makeswiftApiClientSyncMiddleware(client),\n ),\n\n enhancers: getDefaultEnhancers =>\n getDefaultEnhancers().concat(\n withSetupTeardown(\n () => {\n const dispatch = store.dispatch as Dispatch\n dispatch(setupBuilderProxy(builderProxy))\n },\n () => builderProxy.teardown(),\n ),\n ),\n\n devTools: devToolsConfig({\n name: `Host store (${new Date().toISOString()})`,\n actionsDenylist: [\n HostActionTypes.BUILDER_POINTER_MOVE,\n BuilderActionTypes.HANDLE_POINTER_MOVE,\n BuilderActionTypes.ELEMENT_FROM_POINT_CHANGE,\n ],\n }),\n })\n\n return store\n}\n\nexport type Store = ReturnType<typeof configureStore>\n"],"mappings":"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","names":["import_actions","import_toolkit","deepEqual","document","configureReduxStore"]}
|