@builder.io/sdk-react-native 2.0.16 → 2.0.22
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/lib/browser/commonjs/components/awaiter.js +21 -0
- package/lib/browser/commonjs/components/awaiter.js.map +1 -0
- package/lib/browser/commonjs/components/block/components/interactive-element.js +9 -2
- package/lib/browser/commonjs/components/block/components/interactive-element.js.map +1 -1
- package/lib/browser/commonjs/components/content/components/enable-editor.js +17 -45
- package/lib/browser/commonjs/components/content/components/enable-editor.js.map +1 -1
- package/lib/browser/commonjs/components/content/content.js +37 -5
- package/lib/browser/commonjs/components/content/content.js.map +1 -1
- package/lib/browser/commonjs/constants/sdk-version.js +1 -1
- package/lib/browser/commonjs/context/component-reference-types.js +2 -0
- package/lib/browser/commonjs/context/component-reference-types.js.map +1 -0
- package/lib/browser/commonjs/functions/evaluate/browser-runtime/browser.js +1 -35
- package/lib/browser/commonjs/functions/evaluate/browser-runtime/browser.js.map +1 -1
- package/lib/browser/commonjs/functions/evaluate/edge-runtime/edge-runtime.js +71 -34
- package/lib/browser/commonjs/functions/evaluate/edge-runtime/edge-runtime.js.map +1 -1
- package/lib/browser/commonjs/functions/evaluate/helpers.js +34 -0
- package/lib/browser/commonjs/functions/evaluate/helpers.js.map +1 -1
- package/lib/browser/commonjs/functions/evaluate/node-runtime/node-runtime.js +1 -1
- package/lib/browser/commonjs/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
- package/lib/browser/module/components/awaiter.js +14 -0
- package/lib/browser/module/components/awaiter.js.map +1 -0
- package/lib/browser/module/components/block/components/interactive-element.js +8 -2
- package/lib/browser/module/components/block/components/interactive-element.js.map +1 -1
- package/lib/browser/module/components/content/components/enable-editor.js +16 -44
- package/lib/browser/module/components/content/components/enable-editor.js.map +1 -1
- package/lib/browser/module/components/content/content.js +38 -6
- package/lib/browser/module/components/content/content.js.map +1 -1
- package/lib/browser/module/constants/sdk-version.js +1 -1
- package/lib/browser/module/context/component-reference-types.js +2 -0
- package/lib/browser/module/context/component-reference-types.js.map +1 -0
- package/lib/browser/module/functions/evaluate/browser-runtime/browser.js +1 -34
- package/lib/browser/module/functions/evaluate/browser-runtime/browser.js.map +1 -1
- package/lib/browser/module/functions/evaluate/edge-runtime/edge-runtime.js +73 -35
- package/lib/browser/module/functions/evaluate/edge-runtime/edge-runtime.js.map +1 -1
- package/lib/browser/module/functions/evaluate/helpers.js +33 -0
- package/lib/browser/module/functions/evaluate/helpers.js.map +1 -1
- package/lib/browser/module/functions/evaluate/node-runtime/node-runtime.js +1 -1
- package/lib/browser/module/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
- package/lib/browser/typescript/components/awaiter.d.ts +15 -0
- package/lib/browser/typescript/components/awaiter.d.ts.map +1 -0
- package/lib/browser/typescript/components/block/components/interactive-element.d.ts.map +1 -1
- package/lib/browser/typescript/components/content/components/enable-editor.d.ts.map +1 -1
- package/lib/browser/typescript/components/content/content.d.ts.map +1 -1
- package/lib/browser/typescript/constants/sdk-version.d.ts +1 -1
- package/lib/browser/typescript/context/component-reference-types.d.ts +5 -0
- package/lib/browser/typescript/context/component-reference-types.d.ts.map +1 -0
- package/lib/browser/typescript/context/types.d.ts +2 -1
- package/lib/browser/typescript/context/types.d.ts.map +1 -1
- package/lib/browser/typescript/functions/evaluate/browser-runtime/browser.d.ts +0 -6
- package/lib/browser/typescript/functions/evaluate/browser-runtime/browser.d.ts.map +1 -1
- package/lib/browser/typescript/functions/evaluate/helpers.d.ts +5 -0
- package/lib/browser/typescript/functions/evaluate/helpers.d.ts.map +1 -1
- package/lib/browser/typescript/types/input.d.ts +1 -1
- package/lib/browser/typescript/types/input.d.ts.map +1 -1
- package/lib/edge/commonjs/components/awaiter.js +21 -0
- package/lib/edge/commonjs/components/awaiter.js.map +1 -0
- package/lib/edge/commonjs/components/block/components/interactive-element.js +9 -2
- package/lib/edge/commonjs/components/block/components/interactive-element.js.map +1 -1
- package/lib/edge/commonjs/components/content/components/enable-editor.js +17 -45
- package/lib/edge/commonjs/components/content/components/enable-editor.js.map +1 -1
- package/lib/edge/commonjs/components/content/content.js +37 -5
- package/lib/edge/commonjs/components/content/content.js.map +1 -1
- package/lib/edge/commonjs/constants/sdk-version.js +1 -1
- package/lib/edge/commonjs/context/component-reference-types.js +2 -0
- package/lib/edge/commonjs/context/component-reference-types.js.map +1 -0
- package/lib/edge/commonjs/functions/evaluate/browser-runtime/browser.js +1 -35
- package/lib/edge/commonjs/functions/evaluate/browser-runtime/browser.js.map +1 -1
- package/lib/edge/commonjs/functions/evaluate/edge-runtime/edge-runtime.js +71 -34
- package/lib/edge/commonjs/functions/evaluate/edge-runtime/edge-runtime.js.map +1 -1
- package/lib/edge/commonjs/functions/evaluate/helpers.js +34 -0
- package/lib/edge/commonjs/functions/evaluate/helpers.js.map +1 -1
- package/lib/edge/commonjs/functions/evaluate/node-runtime/node-runtime.js +1 -1
- package/lib/edge/commonjs/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
- package/lib/edge/module/components/awaiter.js +14 -0
- package/lib/edge/module/components/awaiter.js.map +1 -0
- package/lib/edge/module/components/block/components/interactive-element.js +8 -2
- package/lib/edge/module/components/block/components/interactive-element.js.map +1 -1
- package/lib/edge/module/components/content/components/enable-editor.js +16 -44
- package/lib/edge/module/components/content/components/enable-editor.js.map +1 -1
- package/lib/edge/module/components/content/content.js +38 -6
- package/lib/edge/module/components/content/content.js.map +1 -1
- package/lib/edge/module/constants/sdk-version.js +1 -1
- package/lib/edge/module/context/component-reference-types.js +2 -0
- package/lib/edge/module/context/component-reference-types.js.map +1 -0
- package/lib/edge/module/functions/evaluate/browser-runtime/browser.js +1 -34
- package/lib/edge/module/functions/evaluate/browser-runtime/browser.js.map +1 -1
- package/lib/edge/module/functions/evaluate/edge-runtime/edge-runtime.js +73 -35
- package/lib/edge/module/functions/evaluate/edge-runtime/edge-runtime.js.map +1 -1
- package/lib/edge/module/functions/evaluate/helpers.js +33 -0
- package/lib/edge/module/functions/evaluate/helpers.js.map +1 -1
- package/lib/edge/module/functions/evaluate/node-runtime/node-runtime.js +1 -1
- package/lib/edge/module/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
- package/lib/edge/typescript/components/awaiter.d.ts +15 -0
- package/lib/edge/typescript/components/awaiter.d.ts.map +1 -0
- package/lib/edge/typescript/components/block/components/interactive-element.d.ts.map +1 -1
- package/lib/edge/typescript/components/content/components/enable-editor.d.ts.map +1 -1
- package/lib/edge/typescript/components/content/content.d.ts.map +1 -1
- package/lib/edge/typescript/constants/sdk-version.d.ts +1 -1
- package/lib/edge/typescript/context/component-reference-types.d.ts +5 -0
- package/lib/edge/typescript/context/component-reference-types.d.ts.map +1 -0
- package/lib/edge/typescript/context/types.d.ts +2 -1
- package/lib/edge/typescript/context/types.d.ts.map +1 -1
- package/lib/edge/typescript/functions/evaluate/browser-runtime/browser.d.ts +0 -6
- package/lib/edge/typescript/functions/evaluate/browser-runtime/browser.d.ts.map +1 -1
- package/lib/edge/typescript/functions/evaluate/helpers.d.ts +5 -0
- package/lib/edge/typescript/functions/evaluate/helpers.d.ts.map +1 -1
- package/lib/edge/typescript/types/input.d.ts +1 -1
- package/lib/edge/typescript/types/input.d.ts.map +1 -1
- package/lib/node/commonjs/components/awaiter.js +21 -0
- package/lib/node/commonjs/components/awaiter.js.map +1 -0
- package/lib/node/commonjs/components/block/components/interactive-element.js +9 -2
- package/lib/node/commonjs/components/block/components/interactive-element.js.map +1 -1
- package/lib/node/commonjs/components/content/components/enable-editor.js +17 -45
- package/lib/node/commonjs/components/content/components/enable-editor.js.map +1 -1
- package/lib/node/commonjs/components/content/content.js +37 -5
- package/lib/node/commonjs/components/content/content.js.map +1 -1
- package/lib/node/commonjs/constants/sdk-version.js +1 -1
- package/lib/node/commonjs/context/component-reference-types.js +2 -0
- package/lib/node/commonjs/context/component-reference-types.js.map +1 -0
- package/lib/node/commonjs/functions/evaluate/browser-runtime/browser.js +1 -35
- package/lib/node/commonjs/functions/evaluate/browser-runtime/browser.js.map +1 -1
- package/lib/node/commonjs/functions/evaluate/edge-runtime/edge-runtime.js +71 -34
- package/lib/node/commonjs/functions/evaluate/edge-runtime/edge-runtime.js.map +1 -1
- package/lib/node/commonjs/functions/evaluate/helpers.js +34 -0
- package/lib/node/commonjs/functions/evaluate/helpers.js.map +1 -1
- package/lib/node/commonjs/functions/evaluate/node-runtime/node-runtime.js +1 -1
- package/lib/node/commonjs/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
- package/lib/node/module/components/awaiter.js +14 -0
- package/lib/node/module/components/awaiter.js.map +1 -0
- package/lib/node/module/components/block/components/interactive-element.js +8 -2
- package/lib/node/module/components/block/components/interactive-element.js.map +1 -1
- package/lib/node/module/components/content/components/enable-editor.js +16 -44
- package/lib/node/module/components/content/components/enable-editor.js.map +1 -1
- package/lib/node/module/components/content/content.js +38 -6
- package/lib/node/module/components/content/content.js.map +1 -1
- package/lib/node/module/constants/sdk-version.js +1 -1
- package/lib/node/module/context/component-reference-types.js +2 -0
- package/lib/node/module/context/component-reference-types.js.map +1 -0
- package/lib/node/module/functions/evaluate/browser-runtime/browser.js +1 -34
- package/lib/node/module/functions/evaluate/browser-runtime/browser.js.map +1 -1
- package/lib/node/module/functions/evaluate/edge-runtime/edge-runtime.js +73 -35
- package/lib/node/module/functions/evaluate/edge-runtime/edge-runtime.js.map +1 -1
- package/lib/node/module/functions/evaluate/helpers.js +33 -0
- package/lib/node/module/functions/evaluate/helpers.js.map +1 -1
- package/lib/node/module/functions/evaluate/node-runtime/node-runtime.js +1 -1
- package/lib/node/module/functions/evaluate/node-runtime/node-runtime.js.map +1 -1
- package/lib/node/typescript/components/awaiter.d.ts +15 -0
- package/lib/node/typescript/components/awaiter.d.ts.map +1 -0
- package/lib/node/typescript/components/block/components/interactive-element.d.ts.map +1 -1
- package/lib/node/typescript/components/content/components/enable-editor.d.ts.map +1 -1
- package/lib/node/typescript/components/content/content.d.ts.map +1 -1
- package/lib/node/typescript/constants/sdk-version.d.ts +1 -1
- package/lib/node/typescript/context/component-reference-types.d.ts +5 -0
- package/lib/node/typescript/context/component-reference-types.d.ts.map +1 -0
- package/lib/node/typescript/context/types.d.ts +2 -1
- package/lib/node/typescript/context/types.d.ts.map +1 -1
- package/lib/node/typescript/functions/evaluate/browser-runtime/browser.d.ts +0 -6
- package/lib/node/typescript/functions/evaluate/browser-runtime/browser.d.ts.map +1 -1
- package/lib/node/typescript/functions/evaluate/helpers.d.ts +5 -0
- package/lib/node/typescript/functions/evaluate/helpers.d.ts.map +1 -1
- package/lib/node/typescript/types/input.d.ts +1 -1
- package/lib/node/typescript/types/input.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/components/awaiter.tsx +36 -0
- package/src/components/block/components/interactive-element.tsx +19 -3
- package/src/components/content/components/enable-editor.tsx +7 -36
- package/src/components/content/content.tsx +71 -36
- package/src/constants/sdk-version.ts +1 -1
- package/src/context/component-reference-types.ts +4 -0
- package/src/context/types.ts +2 -1
- package/src/functions/evaluate/browser-runtime/browser.ts +1 -39
- package/src/functions/evaluate/edge-runtime/edge-runtime.ts +73 -35
- package/src/functions/evaluate/helpers.ts +37 -0
- package/src/functions/evaluate/node-runtime/node-runtime.ts +1 -1
- package/src/types/input.ts +1 -1
|
@@ -12,7 +12,7 @@ import {
|
|
|
12
12
|
Button,
|
|
13
13
|
Linking,
|
|
14
14
|
} from "react-native";
|
|
15
|
-
import { useState, useContext } from "react";
|
|
15
|
+
import { useState, useContext, useRef } from "react";
|
|
16
16
|
import { getDefaultRegisteredComponents } from "../../constants/builder-registered-components";
|
|
17
17
|
import { TARGET } from "../../constants/target";
|
|
18
18
|
import ComponentsContext from "../../context/components.context";
|
|
@@ -21,7 +21,9 @@ import type {
|
|
|
21
21
|
BuilderRenderState,
|
|
22
22
|
RegisteredComponents,
|
|
23
23
|
} from "../../context/types";
|
|
24
|
+
import { evaluate } from "../../functions/evaluate/evaluate";
|
|
24
25
|
import { serializeIncludingFunctions } from "../../functions/register-component";
|
|
26
|
+
import { logger } from "../../helpers/logger";
|
|
25
27
|
import type { ComponentInfo } from "../../types/components";
|
|
26
28
|
import type { Dictionary } from "../../types/typescript";
|
|
27
29
|
import Blocks from "../blocks/blocks";
|
|
@@ -74,42 +76,75 @@ function ContentComponent(props: ContentProps) {
|
|
|
74
76
|
)
|
|
75
77
|
);
|
|
76
78
|
|
|
77
|
-
const [builderContextSignal, setBuilderContextSignal] =
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
content:
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
localState: undefined,
|
|
84
|
-
rootState: getRootStateInitialValue({
|
|
85
|
-
content: props.content,
|
|
86
|
-
data: props.data,
|
|
87
|
-
locale: props.locale,
|
|
88
|
-
}),
|
|
89
|
-
rootSetState: contentSetState,
|
|
90
|
-
context: props.context || {},
|
|
91
|
-
canTrack: props.canTrack,
|
|
92
|
-
apiKey: props.apiKey,
|
|
93
|
-
apiVersion: props.apiVersion,
|
|
94
|
-
componentInfos: [
|
|
95
|
-
...getDefaultRegisteredComponents(),
|
|
96
|
-
...(props.customComponents?.filter(({ models }) => {
|
|
97
|
-
if (!models?.length) return true;
|
|
98
|
-
if (!props.model) return true;
|
|
99
|
-
return models.includes(props.model);
|
|
100
|
-
}) || []),
|
|
101
|
-
].reduce<Dictionary<ComponentInfo>>(
|
|
102
|
-
(acc, { component: _, ...info }) => ({
|
|
103
|
-
...acc,
|
|
104
|
-
[info.name]: serializeIncludingFunctions(info),
|
|
79
|
+
const [builderContextSignal, setBuilderContextSignal] =
|
|
80
|
+
useState<BuilderContextInterface>(() => ({
|
|
81
|
+
strictStyleMode: props.strictStyleMode,
|
|
82
|
+
content: getContentInitialValue({
|
|
83
|
+
content: props.content,
|
|
84
|
+
data: props.data,
|
|
105
85
|
}),
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
86
|
+
localState: undefined,
|
|
87
|
+
rootState: getRootStateInitialValue({
|
|
88
|
+
content: props.content,
|
|
89
|
+
data: props.data,
|
|
90
|
+
locale: props.locale,
|
|
91
|
+
}),
|
|
92
|
+
rootSetState: contentSetState,
|
|
93
|
+
context: props.context || {},
|
|
94
|
+
canTrack: props.canTrack,
|
|
95
|
+
apiKey: props.apiKey,
|
|
96
|
+
apiVersion: props.apiVersion,
|
|
97
|
+
componentInfos: [
|
|
98
|
+
...getDefaultRegisteredComponents(),
|
|
99
|
+
...(props.customComponents?.filter(({ models }) => {
|
|
100
|
+
if (!models?.length) return true;
|
|
101
|
+
if (!props.model) return true;
|
|
102
|
+
return models.includes(props.model);
|
|
103
|
+
}) || []),
|
|
104
|
+
].reduce<Dictionary<ComponentInfo>>(
|
|
105
|
+
(acc, { component: _, ...info }) => ({
|
|
106
|
+
...acc,
|
|
107
|
+
[info.name]: serializeIncludingFunctions(info),
|
|
108
|
+
}),
|
|
109
|
+
{}
|
|
110
|
+
),
|
|
111
|
+
inheritedStyles: {},
|
|
112
|
+
BlocksWrapper: props.blocksWrapper || ScrollView,
|
|
113
|
+
BlocksWrapperProps: props.blocksWrapperProps || {},
|
|
114
|
+
nonce: props.nonce || "",
|
|
115
|
+
}));
|
|
116
|
+
|
|
117
|
+
const hasInitialized = useRef(false);
|
|
118
|
+
if (!hasInitialized.current) {
|
|
119
|
+
if (!props.apiKey) {
|
|
120
|
+
logger.error(
|
|
121
|
+
"No API key provided to `Content` component. This can cause issues. Please provide an API key using the `apiKey` prop."
|
|
122
|
+
);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
// run any dynamic JS code attached to content
|
|
126
|
+
const jsCode = builderContextSignal.content?.data?.jsCode;
|
|
127
|
+
if (jsCode) {
|
|
128
|
+
evaluate({
|
|
129
|
+
code: jsCode,
|
|
130
|
+
context: props.context || {},
|
|
131
|
+
localState: undefined,
|
|
132
|
+
rootState: builderContextSignal.rootState,
|
|
133
|
+
rootSetState: (newState) => {
|
|
134
|
+
setBuilderContextSignal((PREVIOUS_VALUE) => ({
|
|
135
|
+
...PREVIOUS_VALUE,
|
|
136
|
+
rootState: newState,
|
|
137
|
+
}));
|
|
138
|
+
},
|
|
139
|
+
isExpression: false,
|
|
140
|
+
/**
|
|
141
|
+
* We don't want to cache the result of the JS code, since it's arbitrary side effect code.
|
|
142
|
+
*/
|
|
143
|
+
enableCache: false,
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
hasInitialized.current = true;
|
|
147
|
+
}
|
|
113
148
|
|
|
114
149
|
return (
|
|
115
150
|
<ComponentsContext.Provider
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export const SDK_VERSION = "2.0.
|
|
1
|
+
export const SDK_VERSION = "2.0.22"
|
package/src/context/types.ts
CHANGED
|
@@ -3,9 +3,10 @@ import type { ApiVersion } from '../types/api-version';
|
|
|
3
3
|
import type { BuilderContent } from '../types/builder-content';
|
|
4
4
|
import type { ComponentInfo } from '../types/components';
|
|
5
5
|
import type { Dictionary, Nullable } from '../types/typescript';
|
|
6
|
+
import type { ComponentReference } from './component-reference-types';
|
|
6
7
|
import type { ExtraContextTypes } from './extra-context-types';
|
|
7
8
|
export type RegisteredComponent = ComponentInfo & {
|
|
8
|
-
component:
|
|
9
|
+
component: ComponentReference;
|
|
9
10
|
};
|
|
10
11
|
export type RegisteredComponents = Dictionary<RegisteredComponent>;
|
|
11
12
|
export type BuilderRenderState = Record<string, unknown>;
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import type { BuilderRenderState } from '../../../context/types';
|
|
2
1
|
import type { ExecutorArgs } from '../helpers';
|
|
3
|
-
import { getFunctionArguments } from '../helpers';
|
|
2
|
+
import { flattenState, getFunctionArguments } from '../helpers';
|
|
4
3
|
export const runInBrowser = ({
|
|
5
4
|
code,
|
|
6
5
|
builder,
|
|
@@ -21,41 +20,4 @@ export const runInBrowser = ({
|
|
|
21
20
|
})
|
|
22
21
|
});
|
|
23
22
|
return new Function(...functionArgs.map(([name]) => name), code)(...functionArgs.map(([, value]) => value));
|
|
24
|
-
};
|
|
25
|
-
export function flattenState({
|
|
26
|
-
rootState,
|
|
27
|
-
localState,
|
|
28
|
-
rootSetState
|
|
29
|
-
}: {
|
|
30
|
-
rootState: Record<string | symbol, any>;
|
|
31
|
-
localState: Record<string | symbol, any> | undefined;
|
|
32
|
-
rootSetState: ((rootState: BuilderRenderState) => void) | undefined;
|
|
33
|
-
}): BuilderRenderState {
|
|
34
|
-
return new Proxy(rootState, {
|
|
35
|
-
get: (target, prop) => {
|
|
36
|
-
if (localState && prop in localState) {
|
|
37
|
-
return localState[prop];
|
|
38
|
-
}
|
|
39
|
-
const val = target[prop];
|
|
40
|
-
if (typeof val === 'object' && val !== null) {
|
|
41
|
-
return flattenState({
|
|
42
|
-
rootState: val,
|
|
43
|
-
localState: undefined,
|
|
44
|
-
rootSetState: rootSetState ? subState => {
|
|
45
|
-
target[prop] = subState;
|
|
46
|
-
rootSetState(target);
|
|
47
|
-
} : undefined
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
return val;
|
|
51
|
-
},
|
|
52
|
-
set: (target, prop, value) => {
|
|
53
|
-
if (localState && prop in localState) {
|
|
54
|
-
throw new Error('Writing to local state is not allowed as it is read-only.');
|
|
55
|
-
}
|
|
56
|
-
target[prop] = value;
|
|
57
|
-
rootSetState?.(target);
|
|
58
|
-
return true;
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
23
|
}
|
|
@@ -1,26 +1,66 @@
|
|
|
1
1
|
import { logger } from '../../../helpers/logger';
|
|
2
|
-
import { set } from '../../set';
|
|
3
2
|
import type { ExecutorArgs } from '../helpers';
|
|
4
|
-
import { getFunctionArguments } from '../helpers';
|
|
3
|
+
import { flattenState, getFunctionArguments } from '../helpers';
|
|
5
4
|
import Interpreter from './acorn-interpreter';
|
|
6
|
-
const processCode = (code: string) => {
|
|
7
|
-
return code.split('\n').map(line => {
|
|
8
|
-
const trimmed = line.trim();
|
|
9
|
-
|
|
10
|
-
// this async wrapper doesn't work in JS-interpreter, so we drop it.
|
|
11
|
-
if (line.includes('__awaiter')) return undefined;
|
|
12
5
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
6
|
+
/**
|
|
7
|
+
* https://stackoverflow.com/a/46503625
|
|
8
|
+
*/
|
|
9
|
+
function patchInterpreter() {
|
|
10
|
+
const originalGetProperty = Interpreter.prototype.getProperty;
|
|
11
|
+
const originalSetProperty = Interpreter.prototype.setProperty;
|
|
12
|
+
function newGetProperty(this: typeof Interpreter, obj: any, name: any) {
|
|
13
|
+
if (obj == null || !obj._connected) {
|
|
14
|
+
return originalGetProperty.call(this, obj, name);
|
|
15
|
+
}
|
|
16
|
+
const value = obj._connected[name];
|
|
17
|
+
if (Array.isArray(value)) {
|
|
18
|
+
return this.nativeToPseudo(value);
|
|
19
|
+
}
|
|
20
|
+
if (typeof value === 'object') {
|
|
21
|
+
// if the value is an object itself, create another connected object
|
|
22
|
+
return this.createConnectedObject(value);
|
|
23
|
+
}
|
|
24
|
+
return value;
|
|
25
|
+
}
|
|
26
|
+
function newSetProperty(this: typeof Interpreter, obj: any, name: any, value: any, opt_descriptor: any) {
|
|
27
|
+
if (obj == null || !obj._connected) {
|
|
28
|
+
return originalSetProperty.call(this, obj, name, value, opt_descriptor);
|
|
29
|
+
}
|
|
30
|
+
obj._connected[name] = this.pseudoToNative(value);
|
|
31
|
+
}
|
|
32
|
+
const getKeys: string[] = [];
|
|
33
|
+
const setKeys: string[] = [];
|
|
34
|
+
for (const key of Object.keys(Interpreter.prototype)) {
|
|
35
|
+
if (Interpreter.prototype[key] === originalGetProperty) {
|
|
36
|
+
getKeys.push(key);
|
|
37
|
+
}
|
|
38
|
+
if (Interpreter.prototype[key] === originalSetProperty) {
|
|
39
|
+
setKeys.push(key);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
for (const key of getKeys) {
|
|
43
|
+
Interpreter.prototype[key] = newGetProperty;
|
|
44
|
+
}
|
|
45
|
+
for (const key of setKeys) {
|
|
46
|
+
Interpreter.prototype[key] = newSetProperty;
|
|
47
|
+
}
|
|
48
|
+
Interpreter.prototype.createConnectedObject = function (obj: any) {
|
|
49
|
+
const connectedObject = this.createObject(this.OBJECT);
|
|
50
|
+
connectedObject._connected = obj;
|
|
51
|
+
return connectedObject;
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
patchInterpreter();
|
|
55
|
+
const processCode = (code: string) => {
|
|
56
|
+
return code
|
|
57
|
+
// strip async/await polyfill: remove anything before 'function main()'
|
|
58
|
+
.replace(/^.*?function main\(\)/, `
|
|
59
|
+
var __awaiter = function (e, t, n, r) {return r()},
|
|
60
|
+
__generator = function (e, t) { return t() };
|
|
61
|
+
function main()`)
|
|
62
|
+
// replace ?. with .
|
|
63
|
+
.replace(/\?\./g, '.');
|
|
24
64
|
};
|
|
25
65
|
const getJSONValName = (val: string) => val + 'JSON';
|
|
26
66
|
export const runInEdge = ({
|
|
@@ -32,10 +72,11 @@ export const runInEdge = ({
|
|
|
32
72
|
rootSetState,
|
|
33
73
|
code
|
|
34
74
|
}: ExecutorArgs) => {
|
|
35
|
-
const state = {
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
75
|
+
const state = flattenState({
|
|
76
|
+
rootState,
|
|
77
|
+
localState,
|
|
78
|
+
rootSetState
|
|
79
|
+
});
|
|
39
80
|
const properties = getFunctionArguments({
|
|
40
81
|
builder,
|
|
41
82
|
context,
|
|
@@ -48,6 +89,9 @@ export const runInEdge = ({
|
|
|
48
89
|
*/
|
|
49
90
|
const prependedCode = properties.map(([key]) => {
|
|
50
91
|
const jsonValName = getJSONValName(key);
|
|
92
|
+
if (key === 'state') {
|
|
93
|
+
return ``;
|
|
94
|
+
}
|
|
51
95
|
return `var ${key} = ${jsonValName} === undefined ? undefined : JSON.parse(${jsonValName});`;
|
|
52
96
|
}).join('\n');
|
|
53
97
|
const cleanedCode = processCode(code);
|
|
@@ -63,24 +107,18 @@ function theFunction() {
|
|
|
63
107
|
}
|
|
64
108
|
theFunction();
|
|
65
109
|
`;
|
|
66
|
-
const setRootState = (prop: string, value: any) => {
|
|
67
|
-
const newState = set(state, prop, value);
|
|
68
|
-
rootSetState?.(newState);
|
|
69
|
-
};
|
|
70
110
|
const initFunc = function (interpreter: any, globalObject: any) {
|
|
71
111
|
/**
|
|
72
112
|
* serialize all function args to JSON strings
|
|
73
113
|
*/
|
|
74
114
|
properties.forEach(([key, val]) => {
|
|
75
|
-
|
|
76
|
-
|
|
115
|
+
if (key === 'state') {
|
|
116
|
+
interpreter.setProperty(globalObject, key, interpreter.createConnectedObject(val), interpreter.READONLY_DESCRIPTOR);
|
|
117
|
+
} else {
|
|
118
|
+
const jsonVal = JSON.stringify(val);
|
|
119
|
+
interpreter.setProperty(globalObject, getJSONValName(key), jsonVal);
|
|
120
|
+
}
|
|
77
121
|
});
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Add a JavaScript function "setRootState" to the interpreter's global object, that will be called whenever a
|
|
81
|
-
* state property is set. This function will update the state object.
|
|
82
|
-
*/
|
|
83
|
-
interpreter.setProperty(globalObject, 'setRootState', interpreter.createNativeFunction(setRootState));
|
|
84
122
|
};
|
|
85
123
|
const myInterpreter = new Interpreter(transformed, initFunc);
|
|
86
124
|
myInterpreter.run();
|
|
@@ -53,4 +53,41 @@ export const parseCode = (code: string, {
|
|
|
53
53
|
isExpression && !(code.includes(';') || code.includes(' return ') || code.trim().startsWith('return '));
|
|
54
54
|
const useCode = useReturn ? `return (${code});` : code;
|
|
55
55
|
return useCode;
|
|
56
|
+
};
|
|
57
|
+
export function flattenState({
|
|
58
|
+
rootState,
|
|
59
|
+
localState,
|
|
60
|
+
rootSetState
|
|
61
|
+
}: {
|
|
62
|
+
rootState: Record<string | symbol, any>;
|
|
63
|
+
localState: Record<string | symbol, any> | undefined;
|
|
64
|
+
rootSetState: ((rootState: BuilderRenderState) => void) | undefined;
|
|
65
|
+
}): BuilderRenderState {
|
|
66
|
+
return new Proxy(rootState, {
|
|
67
|
+
get: (target, prop) => {
|
|
68
|
+
if (localState && prop in localState) {
|
|
69
|
+
return localState[prop];
|
|
70
|
+
}
|
|
71
|
+
const val = target[prop];
|
|
72
|
+
if (typeof val === 'object' && val !== null) {
|
|
73
|
+
return flattenState({
|
|
74
|
+
rootState: val,
|
|
75
|
+
localState: undefined,
|
|
76
|
+
rootSetState: rootSetState ? subState => {
|
|
77
|
+
target[prop] = subState;
|
|
78
|
+
rootSetState(target);
|
|
79
|
+
} : undefined
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
return val;
|
|
83
|
+
},
|
|
84
|
+
set: (target, prop, value) => {
|
|
85
|
+
if (localState && prop in localState) {
|
|
86
|
+
throw new Error('Writing to local state is not allowed as it is read-only.');
|
|
87
|
+
}
|
|
88
|
+
target[prop] = value;
|
|
89
|
+
rootSetState?.(target);
|
|
90
|
+
return true;
|
|
91
|
+
}
|
|
92
|
+
});
|
|
56
93
|
}
|
|
@@ -80,7 +80,7 @@ export const setIvm = (ivm: IsolatedVMImport, options: IsolateOptions = {}) => {
|
|
|
80
80
|
};
|
|
81
81
|
|
|
82
82
|
// only mention the script for SDKs that have it.
|
|
83
|
-
const SHOULD_MENTION_INITIALIZE_SCRIPT = SDK_NAME === '@builder.io/sdk-react-nextjs' || SDK_NAME === '@builder.io/sdk-react' || SDK_NAME === '@builder.io/sdk-qwik';
|
|
83
|
+
const SHOULD_MENTION_INITIALIZE_SCRIPT = SDK_NAME === '@builder.io/sdk-react-nextjs' || SDK_NAME === '@builder.io/sdk-react' || SDK_NAME === '@builder.io/sdk-qwik' || SDK_NAME === '@builder.io/sdk-vue';
|
|
84
84
|
const getIvm = (): IsolatedVMImport => {
|
|
85
85
|
try {
|
|
86
86
|
if (IVM_INSTANCE) return IVM_INSTANCE;
|
package/src/types/input.ts
CHANGED
|
@@ -118,6 +118,6 @@ export interface Input {
|
|
|
118
118
|
valueType?: {
|
|
119
119
|
type?: string;
|
|
120
120
|
};
|
|
121
|
-
onChange?: ((options: Map<string, any>) => void | Promise<void>) | string;
|
|
121
|
+
onChange?: ((options: Map<string, any>, previousOptions?: Map<string, any>) => void | Promise<void>) | string;
|
|
122
122
|
meta?: Record<string, any>;
|
|
123
123
|
}
|