@builder.io/sdk-solid 0.0.8-4 → 0.0.8-5

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 (115) hide show
  1. package/package.json +4 -1
  2. package/entry-point/index.jsx +0 -5
  3. package/src/blocks/button/button.jsx +0 -13
  4. package/src/blocks/button/button.lite.tsx +0 -23
  5. package/src/blocks/button/component-info.js +0 -41
  6. package/src/blocks/columns/columns.jsx +0 -91
  7. package/src/blocks/columns/columns.lite.tsx +0 -102
  8. package/src/blocks/columns/component-info.js +0 -217
  9. package/src/blocks/custom-code/component-info.js +0 -31
  10. package/src/blocks/custom-code/custom-code.jsx +0 -52
  11. package/src/blocks/custom-code/custom-code.lite.tsx +0 -69
  12. package/src/blocks/embed/component-info.js +0 -24
  13. package/src/blocks/embed/embed.jsx +0 -52
  14. package/src/blocks/embed/embed.lite.tsx +0 -61
  15. package/src/blocks/form/component-info.js +0 -262
  16. package/src/blocks/form/form.jsx +0 -253
  17. package/src/blocks/form/form.lite.tsx +0 -293
  18. package/src/blocks/fragment/component-info.js +0 -11
  19. package/src/blocks/fragment/fragment.jsx +0 -5
  20. package/src/blocks/fragment/fragment.lite.tsx +0 -5
  21. package/src/blocks/image/component-info.js +0 -104
  22. package/src/blocks/image/image.jsx +0 -54
  23. package/src/blocks/image/image.lite.tsx +0 -83
  24. package/src/blocks/img/component-info.js +0 -20
  25. package/src/blocks/img/img.jsx +0 -10
  26. package/src/blocks/img/img.lite.tsx +0 -18
  27. package/src/blocks/input/component-info.js +0 -74
  28. package/src/blocks/input/input.jsx +0 -7
  29. package/src/blocks/input/input.lite.tsx +0 -20
  30. package/src/blocks/raw-text/component-info.js +0 -16
  31. package/src/blocks/raw-text/raw-text.jsx +0 -5
  32. package/src/blocks/raw-text/raw-text.lite.tsx +0 -10
  33. package/src/blocks/section/component-info.js +0 -49
  34. package/src/blocks/section/section.jsx +0 -9
  35. package/src/blocks/section/section.lite.tsx +0 -18
  36. package/src/blocks/select/component-info.js +0 -59
  37. package/src/blocks/select/select.jsx +0 -16
  38. package/src/blocks/select/select.lite.tsx +0 -28
  39. package/src/blocks/submit-button/component-info.js +0 -28
  40. package/src/blocks/submit-button/submit-button.jsx +0 -7
  41. package/src/blocks/submit-button/submit-button.lite.tsx +0 -9
  42. package/src/blocks/symbol/component-info.js +0 -42
  43. package/src/blocks/symbol/symbol.jsx +0 -25
  44. package/src/blocks/symbol/symbol.lite.tsx +0 -41
  45. package/src/blocks/text/component-info.js +0 -24
  46. package/src/blocks/text/text.jsx +0 -5
  47. package/src/blocks/text/text.lite.tsx +0 -5
  48. package/src/blocks/textarea/component-info.js +0 -47
  49. package/src/blocks/textarea/textarea.jsx +0 -5
  50. package/src/blocks/textarea/textarea.lite.tsx +0 -13
  51. package/src/blocks/video/component-info.js +0 -106
  52. package/src/blocks/video/video.jsx +0 -14
  53. package/src/blocks/video/video.lite.tsx +0 -26
  54. package/src/components/error-boundary.jsx +0 -5
  55. package/src/components/error-boundary.lite.tsx +0 -5
  56. package/src/components/render-block/block-styles.jsx +0 -36
  57. package/src/components/render-block/block-styles.lite.tsx +0 -38
  58. package/src/components/render-block/render-block.jsx +0 -125
  59. package/src/components/render-block/render-block.lite.tsx +0 -137
  60. package/src/components/render-blocks.jsx +0 -57
  61. package/src/components/render-blocks.lite.tsx +0 -75
  62. package/src/components/render-content/components/render-styles.jsx +0 -74
  63. package/src/components/render-content/components/render-styles.lite.tsx +0 -76
  64. package/src/components/render-content/index.js +0 -4
  65. package/src/components/render-content/render-content.jsx +0 -234
  66. package/src/components/render-content/render-content.lite.tsx +0 -260
  67. package/src/components/render-inlined-styles.jsx +0 -24
  68. package/src/components/render-inlined-styles.lite.tsx +0 -29
  69. package/src/constants/builder-registered-components.js +0 -29
  70. package/src/constants/device-sizes.js +0 -39
  71. package/src/constants/target.js +0 -4
  72. package/src/context/builder.context.js +0 -11
  73. package/src/functions/evaluate.js +0 -28
  74. package/src/functions/event-handler-name.js +0 -7
  75. package/src/functions/fast-clone.js +0 -4
  76. package/src/functions/get-block-actions.js +0 -23
  77. package/src/functions/get-block-component-options.js +0 -23
  78. package/src/functions/get-block-properties.js +0 -29
  79. package/src/functions/get-block-styles.js +0 -42
  80. package/src/functions/get-block-tag.js +0 -6
  81. package/src/functions/get-builder-search-params/fn.test.js +0 -13
  82. package/src/functions/get-builder-search-params/index.js +0 -22
  83. package/src/functions/get-content/fn.test.js +0 -31
  84. package/src/functions/get-content/index.js +0 -138
  85. package/src/functions/get-fetch.js +0 -34
  86. package/src/functions/get-global-this.js +0 -18
  87. package/src/functions/get-processed-block.js +0 -46
  88. package/src/functions/get-processed-block.test.js +0 -31
  89. package/src/functions/if-target.js +0 -15
  90. package/src/functions/is-browser.js +0 -6
  91. package/src/functions/is-editing.js +0 -7
  92. package/src/functions/is-iframe.js +0 -7
  93. package/src/functions/is-previewing.js +0 -14
  94. package/src/functions/macro-eval.js +0 -5
  95. package/src/functions/on-change.js +0 -27
  96. package/src/functions/on-change.test.js +0 -19
  97. package/src/functions/previewing-model-name.js +0 -11
  98. package/src/functions/register-component.js +0 -53
  99. package/src/functions/register.js +0 -29
  100. package/src/functions/set-editor-settings.js +0 -15
  101. package/src/functions/set.js +0 -11
  102. package/src/functions/set.test.js +0 -16
  103. package/src/functions/track.js +0 -22
  104. package/src/functions/transform-block.js +0 -6
  105. package/src/index-helpers/blocks-exports.js +0 -20
  106. package/src/index-helpers/top-of-file.js +0 -4
  107. package/src/index.js +0 -10
  108. package/src/scripts/init-editing.js +0 -80
  109. package/src/types/builder-block.js +0 -0
  110. package/src/types/builder-content.js +0 -0
  111. package/src/types/components.js +0 -0
  112. package/src/types/deep-partial.js +0 -0
  113. package/src/types/element.js +0 -0
  114. package/src/types/targets.js +0 -0
  115. package/src/types/typescript.js +0 -0
@@ -1,234 +0,0 @@
1
- import { Show, onMount } from "solid-js";
2
- import { Dynamic } from "solid-js/web";
3
- import { createMutable } from "solid-js/store";
4
- import { getDefaultRegisteredComponents } from "../../constants/builder-registered-components.js";
5
- import { TARGET } from "../../constants/target.js";
6
- import BuilderContext from "../../context/builder.context";
7
- import { evaluate } from "../../functions/evaluate.js";
8
- import { convertSearchParamsToQueryObject, getBuilderSearchParams } from "../../functions/get-builder-search-params/index.js";
9
- import { getContent } from "../../functions/get-content/index.js";
10
- import { getFetch } from "../../functions/get-fetch.js";
11
- import { isBrowser } from "../../functions/is-browser.js";
12
- import { isEditing } from "../../functions/is-editing.js";
13
- import { isPreviewing } from "../../functions/is-previewing.js";
14
- import { previewingModelName } from "../../functions/previewing-model-name.js";
15
- import { components, createRegisterComponentMessage } from "../../functions/register-component.js";
16
- import { track } from "../../functions/track.js";
17
- import RenderBlocks from "../render-blocks";
18
- import RenderContentStyles from "./components/render-styles";
19
-
20
- function RenderContent(props) {
21
- const state = createMutable({
22
- get useContent() {
23
- const mergedContent = { ...props.content,
24
- ...state.overrideContent,
25
- data: { ...props.content?.data,
26
- ...props.data,
27
- ...state.overrideContent?.data
28
- }
29
- };
30
- return mergedContent;
31
- },
32
-
33
- overrideContent: null,
34
- update: 0,
35
- overrideState: {},
36
-
37
- get contentState() {
38
- return { ...props.content?.data?.state,
39
- ...props.data,
40
- ...state.overrideState
41
- };
42
- },
43
-
44
- get context() {
45
- return {};
46
- },
47
-
48
- get allRegisteredComponents() {
49
- const allComponentsArray = [...getDefaultRegisteredComponents(), // While this `components` object is deprecated, we must maintain support for it.
50
- // Since users are able to override our default components, we need to make sure that we do not break such
51
- // existing usage.
52
- // This is why we spread `components` after the default Builder.io components, but before the `props.customComponents`,
53
- // which is the new standard way of providing custom components, and must therefore take precedence.
54
- ...components, ...(props.customComponents || [])];
55
- const allComponents = allComponentsArray.reduce((acc, curr) => ({ ...acc,
56
- [curr.info.name]: curr
57
- }), {});
58
- return allComponents;
59
- },
60
-
61
- processMessage(event) {
62
- const {
63
- data
64
- } = event;
65
-
66
- if (data) {
67
- switch (data.type) {
68
- case "builder.contentUpdate":
69
- {
70
- const messageContent = data.data;
71
- const key = messageContent.key || messageContent.alias || messageContent.entry || messageContent.modelName;
72
- const contentData = messageContent.data;
73
-
74
- if (key === props.model) {
75
- state.overrideContent = contentData;
76
- }
77
-
78
- break;
79
- }
80
-
81
- case "builder.patchUpdates":
82
- {
83
- // TODO
84
- break;
85
- }
86
- }
87
- }
88
- },
89
-
90
- evaluateJsCode() {
91
- // run any dynamic JS code attached to content
92
- const jsCode = state.useContent?.data?.jsCode;
93
-
94
- if (jsCode) {
95
- evaluate({
96
- code: jsCode,
97
- context: state.context,
98
- state: state.contentState
99
- });
100
- }
101
- },
102
-
103
- get httpReqsData() {
104
- return {};
105
- },
106
-
107
- evalExpression(expression) {
108
- return expression.replace(/{{([^}]+)}}/g, (_match, group) => evaluate({
109
- code: group,
110
- context: state.context,
111
- state: state.contentState
112
- }));
113
- },
114
-
115
- handleRequest({
116
- url,
117
- key
118
- }) {
119
- const fetchAndSetState = async () => {
120
- const fetch = await getFetch();
121
- const response = await fetch(url);
122
- const json = await response.json();
123
- const newOverrideState = { ...state.overrideState,
124
- [key]: json
125
- };
126
- state.overrideState = newOverrideState;
127
- };
128
-
129
- fetchAndSetState();
130
- },
131
-
132
- runHttpRequests() {
133
- const requests = state.useContent?.data?.httpRequests ?? {};
134
- Object.entries(requests).forEach(([key, url]) => {
135
- if (url && (!state.httpReqsData[key] || isEditing())) {
136
- const evaluatedUrl = state.evalExpression(url);
137
- state.handleRequest({
138
- url: evaluatedUrl,
139
- key
140
- });
141
- }
142
- });
143
- },
144
-
145
- emitStateUpdate() {
146
- window.dispatchEvent(new CustomEvent("builder:component:stateChange", {
147
- detail: {
148
- state: state.contentState,
149
- ref: {
150
- name: props.model
151
- }
152
- }
153
- }));
154
- }
155
-
156
- });
157
- onMount(() => {
158
- if (isBrowser()) {
159
- if (isEditing()) {
160
- Object.values(state.allRegisteredComponents).forEach(registeredComponent => {
161
- const message = createRegisterComponentMessage(registeredComponent);
162
- window.parent?.postMessage(message, "*");
163
- });
164
- window.addEventListener("message", state.processMessage);
165
- window.addEventListener("builder:component:stateChangeListenerActivated", state.emitStateUpdate);
166
- }
167
-
168
- if (state.useContent) {
169
- track("impression", {
170
- contentId: state.useContent.id
171
- });
172
- } // override normal content in preview mode
173
-
174
-
175
- if (isPreviewing()) {
176
- if (props.model && previewingModelName() === props.model) {
177
- const currentUrl = new URL(location.href);
178
- const previewApiKey = currentUrl.searchParams.get("apiKey");
179
-
180
- if (previewApiKey) {
181
- getContent({
182
- model: props.model,
183
- apiKey: previewApiKey,
184
- options: getBuilderSearchParams(convertSearchParamsToQueryObject(currentUrl.searchParams))
185
- }).then(content => {
186
- if (content) {
187
- state.overrideContent = content;
188
- }
189
- });
190
- }
191
- }
192
- }
193
-
194
- state.evaluateJsCode();
195
- state.runHttpRequests();
196
- state.emitStateUpdate();
197
- }
198
- });
199
- return <Dynamic value={{
200
- get content() {
201
- return state.useContent;
202
- },
203
-
204
- get state() {
205
- return state.contentState;
206
- },
207
-
208
- get context() {
209
- return state.context;
210
- },
211
-
212
- get apiKey() {
213
- return props.apiKey;
214
- },
215
-
216
- get registeredComponents() {
217
- return state.allRegisteredComponents;
218
- }
219
-
220
- }} component={BuilderContext.Provider}>
221
- <Show when={state.useContent}>
222
- <div onClick={event => track("click", {
223
- contentId: state.useContent.id
224
- })} data-builder-content-id={state.useContent?.id}>
225
- <Show when={(state.useContent?.data?.cssCode || state.useContent?.data?.customFonts?.length) && TARGET !== "reactNative"}>
226
- <RenderContentStyles cssCode={state.useContent.data.cssCode} customFonts={state.useContent.data.customFonts}></RenderContentStyles>
227
- </Show>
228
- <RenderBlocks blocks={state.useContent?.data?.blocks}></RenderBlocks>
229
- </div>
230
- </Show>
231
- </Dynamic>;
232
- }
233
-
234
- export default RenderContent;
@@ -1,260 +0,0 @@
1
- import { useContext, Show, onMount } from "solid-js";
2
- import { Dynamic } from "solid-js/web";
3
- import { createMutable } from "solid-js/store";
4
-
5
- import { getDefaultRegisteredComponents } from "../../constants/builder-registered-components.js";
6
- import { TARGET } from "../../constants/target.js";
7
- import BuilderContext from "../../context/builder.context";
8
- import { evaluate } from "../../functions/evaluate.js";
9
- import {
10
- convertSearchParamsToQueryObject,
11
- getBuilderSearchParams,
12
- } from "../../functions/get-builder-search-params/index.js";
13
- import { getContent } from "../../functions/get-content/index.js";
14
- import { getFetch } from "../../functions/get-fetch.js";
15
- import { isBrowser } from "../../functions/is-browser.js";
16
- import { isEditing } from "../../functions/is-editing.js";
17
- import { isPreviewing } from "../../functions/is-previewing.js";
18
- import { previewingModelName } from "../../functions/previewing-model-name.js";
19
- import {
20
- components,
21
- createRegisterComponentMessage,
22
- } from "../../functions/register-component.js";
23
- import { track } from "../../functions/track.js";
24
- import RenderBlocks from "../render-blocks.lite";
25
- import RenderContentStyles from "./components/render-styles.lite";
26
-
27
- function RenderContent(props) {
28
- const state = createMutable({
29
- get useContent() {
30
- const mergedContent: BuilderContent = {
31
- ...props.content,
32
- ...state.overrideContent,
33
- data: {
34
- ...props.content?.data,
35
- ...props.data,
36
- ...state.overrideContent?.data,
37
- },
38
- };
39
- return mergedContent;
40
- },
41
- overrideContent: null,
42
- update: 0,
43
- overrideState: {},
44
- get contentState() {
45
- return {
46
- ...props.content?.data?.state,
47
- ...props.data,
48
- ...state.overrideState,
49
- };
50
- },
51
- get context() {
52
- return {} as Dictionary<any>;
53
- },
54
- get allRegisteredComponents() {
55
- const allComponentsArray = [
56
- ...getDefaultRegisteredComponents(), // While this `components` object is deprecated, we must maintain support for it.
57
- // Since users are able to override our default components, we need to make sure that we do not break such
58
- // existing usage.
59
- // This is why we spread `components` after the default Builder.io components, but before the `props.customComponents`,
60
- // which is the new standard way of providing custom components, and must therefore take precedence.
61
- ...components,
62
- ...(props.customComponents || []),
63
- ];
64
- const allComponents = allComponentsArray.reduce(
65
- (acc, curr) => ({ ...acc, [curr.info.name]: curr }),
66
- {} as RegisteredComponents
67
- );
68
- return allComponents;
69
- },
70
- processMessage(event: MessageEvent) {
71
- const { data } = event;
72
-
73
- if (data) {
74
- switch (data.type) {
75
- case "builder.contentUpdate": {
76
- const messageContent = data.data;
77
- const key =
78
- messageContent.key ||
79
- messageContent.alias ||
80
- messageContent.entry ||
81
- messageContent.modelName;
82
- const contentData = messageContent.data;
83
-
84
- if (key === props.model) {
85
- state.overrideContent = contentData;
86
- }
87
-
88
- break;
89
- }
90
-
91
- case "builder.patchUpdates": {
92
- // TODO
93
- break;
94
- }
95
- }
96
- }
97
- },
98
- evaluateJsCode() {
99
- // run any dynamic JS code attached to content
100
- const jsCode = state.useContent?.data?.jsCode;
101
-
102
- if (jsCode) {
103
- evaluate({
104
- code: jsCode,
105
- context: state.context,
106
- state: state.contentState,
107
- });
108
- }
109
- },
110
- get httpReqsData() {
111
- return {};
112
- },
113
- evalExpression(expression: string) {
114
- return expression.replace(/{{([^}]+)}}/g, (_match, group) =>
115
- evaluate({
116
- code: group,
117
- context: state.context,
118
- state: state.contentState,
119
- })
120
- );
121
- },
122
- handleRequest({ url, key }: { key: string; url: string }) {
123
- const fetchAndSetState = async () => {
124
- const fetch = await getFetch();
125
- const response = await fetch(url);
126
- const json = await response.json();
127
- const newOverrideState = { ...state.overrideState, [key]: json };
128
- state.overrideState = newOverrideState;
129
- };
130
-
131
- fetchAndSetState();
132
- },
133
- runHttpRequests() {
134
- const requests = state.useContent?.data?.httpRequests ?? {};
135
- Object.entries(requests).forEach(([key, url]) => {
136
- if (url && (!state.httpReqsData[key] || isEditing())) {
137
- const evaluatedUrl = state.evalExpression(url);
138
- state.handleRequest({
139
- url: evaluatedUrl,
140
- key,
141
- });
142
- }
143
- });
144
- },
145
- emitStateUpdate() {
146
- window.dispatchEvent(
147
- new CustomEvent<BuilderComponentStateChange>(
148
- "builder:component:stateChange",
149
- {
150
- detail: {
151
- state: state.contentState,
152
- ref: {
153
- name: props.model,
154
- },
155
- },
156
- }
157
- )
158
- );
159
- },
160
- });
161
-
162
- onMount(() => {
163
- if (isBrowser()) {
164
- if (isEditing()) {
165
- Object.values(state.allRegisteredComponents).forEach(
166
- (registeredComponent) => {
167
- const message = createRegisterComponentMessage(registeredComponent);
168
- window.parent?.postMessage(message, "*");
169
- }
170
- );
171
- window.addEventListener("message", state.processMessage);
172
- window.addEventListener(
173
- "builder:component:stateChangeListenerActivated",
174
- state.emitStateUpdate
175
- );
176
- }
177
-
178
- if (state.useContent) {
179
- track("impression", {
180
- contentId: state.useContent.id,
181
- });
182
- } // override normal content in preview mode
183
-
184
- if (isPreviewing()) {
185
- if (props.model && previewingModelName() === props.model) {
186
- const currentUrl = new URL(location.href);
187
- const previewApiKey = currentUrl.searchParams.get("apiKey");
188
-
189
- if (previewApiKey) {
190
- getContent({
191
- model: props.model,
192
- apiKey: previewApiKey,
193
- options: getBuilderSearchParams(
194
- convertSearchParamsToQueryObject(currentUrl.searchParams)
195
- ),
196
- }).then((content) => {
197
- if (content) {
198
- state.overrideContent = content;
199
- }
200
- });
201
- }
202
- }
203
- }
204
-
205
- state.evaluateJsCode();
206
- state.runHttpRequests();
207
- state.emitStateUpdate();
208
- }
209
- });
210
-
211
- return (
212
- <Dynamic
213
- value={{
214
- get content() {
215
- return state.useContent;
216
- },
217
- get state() {
218
- return state.contentState;
219
- },
220
- get context() {
221
- return state.context;
222
- },
223
- get apiKey() {
224
- return props.apiKey;
225
- },
226
- get registeredComponents() {
227
- return state.allRegisteredComponents;
228
- },
229
- }}
230
- component={BuilderContext.Provider}
231
- >
232
- <Show when={state.useContent}>
233
- <div
234
- onClick={(event) =>
235
- track("click", {
236
- contentId: state.useContent.id,
237
- })
238
- }
239
- data-builder-content-id={state.useContent?.id}
240
- >
241
- <Show
242
- when={
243
- (state.useContent?.data?.cssCode ||
244
- state.useContent?.data?.customFonts?.length) &&
245
- TARGET !== "reactNative"
246
- }
247
- >
248
- <RenderContentStyles
249
- cssCode={state.useContent.data.cssCode}
250
- customFonts={state.useContent.data.customFonts}
251
- ></RenderContentStyles>
252
- </Show>
253
- <RenderBlocks blocks={state.useContent?.data?.blocks}></RenderBlocks>
254
- </div>
255
- </Show>
256
- </Dynamic>
257
- );
258
- }
259
-
260
- export default RenderContent;
@@ -1,24 +0,0 @@
1
- import { Show } from "solid-js";
2
- import { Dynamic } from "solid-js/web";
3
- import { createMutable } from "solid-js/store";
4
- import { TARGET } from "../constants/target.js";
5
-
6
- function RenderInlinedStyles(props) {
7
- const state = createMutable({
8
- get injectedStyleScript() {
9
- return `<${state.tagName}>${props.styles}</${state.tagName}>`;
10
- },
11
-
12
- get tagName() {
13
- // NOTE: we have to obfusctate the name of the tag due to a limitation in the svelte-preprocessor plugin.
14
- // https://github.com/sveltejs/vite-plugin-svelte/issues/315#issuecomment-1109000027
15
- return "sty" + "le";
16
- }
17
-
18
- });
19
- return <Show fallback={<Dynamic component={state.tagName}>{props.styles}</Dynamic>} when={TARGET === "svelte"}>
20
- <div innerHTML={state.injectedStyleScript}></div>
21
- </Show>;
22
- }
23
-
24
- export default RenderInlinedStyles;
@@ -1,29 +0,0 @@
1
- import { Show } from "solid-js";
2
- import { Dynamic } from "solid-js/web";
3
- import { createMutable } from "solid-js/store";
4
-
5
- import { TARGET } from "../constants/target.js";
6
-
7
- function RenderInlinedStyles(props) {
8
- const state = createMutable({
9
- get injectedStyleScript() {
10
- return `<${state.tagName}>${props.styles}</${state.tagName}>`;
11
- },
12
- get tagName() {
13
- // NOTE: we have to obfusctate the name of the tag due to a limitation in the svelte-preprocessor plugin.
14
- // https://github.com/sveltejs/vite-plugin-svelte/issues/315#issuecomment-1109000027
15
- return "sty" + "le";
16
- },
17
- });
18
-
19
- return (
20
- <Show
21
- fallback={<Dynamic component={state.tagName}>{props.styles}</Dynamic>}
22
- when={TARGET === "svelte"}
23
- >
24
- <div innerHTML={state.injectedStyleScript}></div>
25
- </Show>
26
- );
27
- }
28
-
29
- export default RenderInlinedStyles;
@@ -1,29 +0,0 @@
1
- import { default as Button } from "../blocks/button/button.jsx";
2
- import { componentInfo as buttonComponentInfo } from "../blocks/button/component-info";
3
- import { default as Columns } from "../blocks/columns/columns.jsx";
4
- import { componentInfo as columnsComponentInfo } from "../blocks/columns/component-info";
5
- import { componentInfo as fragmentComponentInfo } from "../blocks/fragment/component-info";
6
- import { default as Fragment } from "../blocks/fragment/fragment.jsx";
7
- import { componentInfo as imageComponentInfo } from "../blocks/image/component-info";
8
- import { default as Image } from "../blocks/image/image.jsx";
9
- import { componentInfo as sectionComponentInfo } from "../blocks/section/component-info";
10
- import { default as Section } from "../blocks/section/section.jsx";
11
- import { componentInfo as symbolComponentInfo } from "../blocks/symbol/component-info";
12
- import { default as Symbol } from "../blocks/symbol/symbol.jsx";
13
- import { componentInfo as textComponentInfo } from "../blocks/text/component-info";
14
- import { default as Text } from "../blocks/text/text.jsx";
15
- import { componentInfo as videoComponentInfo } from "../blocks/video/component-info";
16
- import { default as Video } from "../blocks/video/video.jsx";
17
- const getDefaultRegisteredComponents = () => [
18
- { component: Columns, info: columnsComponentInfo },
19
- { component: Image, info: imageComponentInfo },
20
- { component: Text, info: textComponentInfo },
21
- { component: Video, info: videoComponentInfo },
22
- { component: Symbol, info: symbolComponentInfo },
23
- { component: Button, info: buttonComponentInfo },
24
- { component: Section, info: sectionComponentInfo },
25
- { component: Fragment, info: fragmentComponentInfo }
26
- ];
27
- export {
28
- getDefaultRegisteredComponents
29
- };
@@ -1,39 +0,0 @@
1
- const sizeNames = ["xsmall", "small", "medium", "large"];
2
- const sizes = {
3
- xsmall: {
4
- min: 0,
5
- default: 0,
6
- max: 0
7
- },
8
- small: {
9
- min: 320,
10
- default: 321,
11
- max: 640
12
- },
13
- medium: {
14
- min: 641,
15
- default: 642,
16
- max: 991
17
- },
18
- large: {
19
- min: 990,
20
- default: 991,
21
- max: 1200
22
- },
23
- getWidthForSize(size) {
24
- return this[size].default;
25
- },
26
- getSizeForWidth(width) {
27
- for (const size of sizeNames) {
28
- const value = this[size];
29
- if (width <= value.max) {
30
- return size;
31
- }
32
- }
33
- return "large";
34
- }
35
- };
36
- export {
37
- sizeNames,
38
- sizes
39
- };
@@ -1,4 +0,0 @@
1
- const TARGET = "solid";
2
- export {
3
- TARGET
4
- };
@@ -1,11 +0,0 @@
1
- import { createContext } from "solid-js";
2
- var stdin_default = createContext({
3
- content: null,
4
- context: {},
5
- state: {},
6
- apiKey: null,
7
- registeredComponents: {}
8
- });
9
- export {
10
- stdin_default as default
11
- };
@@ -1,28 +0,0 @@
1
- import { isBrowser } from "./is-browser.js";
2
- import { isEditing } from "./is-editing.js";
3
- function evaluate({
4
- code,
5
- context,
6
- state,
7
- event
8
- }) {
9
- if (code === "") {
10
- console.warn("Skipping evaluation of empty code block.");
11
- return;
12
- }
13
- const builder = {
14
- isEditing: isEditing(),
15
- isBrowser: isBrowser(),
16
- isServer: !isBrowser()
17
- };
18
- const useReturn = !(code.includes(";") || code.includes(" return ") || code.trim().startsWith("return "));
19
- const useCode = useReturn ? `return (${code});` : code;
20
- try {
21
- return new Function("builder", "Builder", "state", "context", "event", useCode)(builder, builder, state, context, event);
22
- } catch (e) {
23
- console.warn("Builder custom code error: ", e);
24
- }
25
- }
26
- export {
27
- evaluate
28
- };
@@ -1,7 +0,0 @@
1
- function capitalizeFirstLetter(string) {
2
- return string.charAt(0).toUpperCase() + string.slice(1);
3
- }
4
- const getEventHandlerName = (key) => `on${capitalizeFirstLetter(key)}`;
5
- export {
6
- getEventHandlerName
7
- };
@@ -1,4 +0,0 @@
1
- const fastClone = (obj) => JSON.parse(JSON.stringify(obj));
2
- export {
3
- fastClone
4
- };