@builder.io/sdk-solid 0.5.9 → 0.6.1

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 (166) hide show
  1. package/README.md +0 -4
  2. package/dist/index.d.ts +51 -0
  3. package/lib/browser/dev.js +4790 -0
  4. package/lib/browser/dev.jsx +4392 -0
  5. package/lib/browser/index.js +4767 -0
  6. package/lib/browser/index.jsx +4374 -0
  7. package/lib/edge/dev.js +7921 -0
  8. package/lib/edge/dev.jsx +7525 -0
  9. package/lib/edge/index.js +7898 -0
  10. package/lib/edge/index.jsx +7507 -0
  11. package/lib/node/dev.js +4790 -0
  12. package/lib/node/dev.jsx +4392 -0
  13. package/lib/node/index.js +4767 -0
  14. package/lib/node/index.jsx +4374 -0
  15. package/package.json +86 -14
  16. package/CHANGELOG.md +0 -102
  17. package/solid-index.jsx +0 -5
  18. package/src/blocks/BaseText.jsx +0 -11
  19. package/src/blocks/button/button.jsx +0 -41
  20. package/src/blocks/button/component-info.js +0 -34
  21. package/src/blocks/columns/columns.jsx +0 -174
  22. package/src/blocks/columns/component-info.js +0 -218
  23. package/src/blocks/custom-code/component-info.js +0 -24
  24. package/src/blocks/custom-code/custom-code.jsx +0 -62
  25. package/src/blocks/embed/component-info.js +0 -37
  26. package/src/blocks/embed/embed.jsx +0 -50
  27. package/src/blocks/embed/helpers.js +0 -3
  28. package/src/blocks/form/component-info.js +0 -223
  29. package/src/blocks/form/form.jsx +0 -5
  30. package/src/blocks/fragment/component-info.js +0 -8
  31. package/src/blocks/fragment/fragment.jsx +0 -5
  32. package/src/blocks/helpers.js +0 -27
  33. package/src/blocks/image/component-info.js +0 -122
  34. package/src/blocks/image/image.helpers.js +0 -46
  35. package/src/blocks/image/image.jsx +0 -122
  36. package/src/blocks/img/component-info.js +0 -15
  37. package/src/blocks/img/img.jsx +0 -20
  38. package/src/blocks/input/component-info.js +0 -45
  39. package/src/blocks/input/input.jsx +0 -22
  40. package/src/blocks/raw-text/component-info.js +0 -11
  41. package/src/blocks/raw-text/raw-text.jsx +0 -10
  42. package/src/blocks/section/component-info.js +0 -41
  43. package/src/blocks/section/section.jsx +0 -26
  44. package/src/blocks/select/component-info.js +0 -44
  45. package/src/blocks/select/select.jsx +0 -30
  46. package/src/blocks/submit-button/component-info.js +0 -23
  47. package/src/blocks/submit-button/submit-button.jsx +0 -11
  48. package/src/blocks/symbol/component-info.js +0 -35
  49. package/src/blocks/symbol/symbol.helpers.js +0 -60
  50. package/src/blocks/symbol/symbol.jsx +0 -64
  51. package/src/blocks/text/component-info.js +0 -20
  52. package/src/blocks/text/text.jsx +0 -14
  53. package/src/blocks/textarea/component-info.js +0 -38
  54. package/src/blocks/textarea/textarea.jsx +0 -16
  55. package/src/blocks/video/component-info.js +0 -83
  56. package/src/blocks/video/video.jsx +0 -61
  57. package/src/components/block/block.helpers.js +0 -99
  58. package/src/components/block/block.jsx +0 -167
  59. package/src/components/block/components/block-styles.jsx +0 -85
  60. package/src/components/block/components/block-wrapper.jsx +0 -50
  61. package/src/components/block/components/component-ref/component-ref.helpers.js +0 -41
  62. package/src/components/block/components/component-ref/component-ref.jsx +0 -59
  63. package/src/components/block/components/interactive-element.jsx +0 -30
  64. package/src/components/block/components/repeated-block.jsx +0 -20
  65. package/src/components/block/types.js +0 -0
  66. package/src/components/blocks/blocks-wrapper.jsx +0 -66
  67. package/src/components/blocks/blocks.jsx +0 -57
  68. package/src/components/content/components/enable-editor.jsx +0 -347
  69. package/src/components/content/components/styles.helpers.js +0 -56
  70. package/src/components/content/components/styles.jsx +0 -36
  71. package/src/components/content/content.helpers.js +0 -48
  72. package/src/components/content/content.jsx +0 -136
  73. package/src/components/content/content.types.js +0 -0
  74. package/src/components/content/index.js +0 -2
  75. package/src/components/content/wrap-component-ref.js +0 -2
  76. package/src/components/content-variants/content-variants.jsx +0 -115
  77. package/src/components/content-variants/content-variants.types.js +0 -0
  78. package/src/components/content-variants/helpers.js +0 -158
  79. package/src/components/inlined-script.jsx +0 -5
  80. package/src/components/inlined-styles.jsx +0 -5
  81. package/src/constants/builder-registered-components.js +0 -63
  82. package/src/constants/device-sizes.js +0 -48
  83. package/src/constants/sdk-version.js +0 -1
  84. package/src/constants/target.js +0 -4
  85. package/src/context/builder.context.js +0 -16
  86. package/src/context/components.context.js +0 -5
  87. package/src/context/types.js +0 -0
  88. package/src/functions/apply-patch-with-mutation.js +0 -66
  89. package/src/functions/camel-to-kebab-case.js +0 -2
  90. package/src/functions/evaluate/browser-runtime/browser.js +0 -40
  91. package/src/functions/evaluate/browser-runtime/index.js +0 -2
  92. package/src/functions/evaluate/evaluate.js +0 -49
  93. package/src/functions/evaluate/helpers.js +0 -15
  94. package/src/functions/evaluate/index.js +0 -2
  95. package/src/functions/evaluate/node-runtime/index.js +0 -2
  96. package/src/functions/evaluate/non-node-runtime/acorn-interpreter.js +0 -2876
  97. package/src/functions/evaluate/non-node-runtime/index.js +0 -18
  98. package/src/functions/evaluate/non-node-runtime/non-node-runtime.js +0 -91
  99. package/src/functions/event-handler-name.js +0 -5
  100. package/src/functions/extract-text-styles.js +0 -14
  101. package/src/functions/fast-clone.js +0 -2
  102. package/src/functions/fetch-builder-props.js +0 -60
  103. package/src/functions/get-block-actions-handler.js +0 -11
  104. package/src/functions/get-block-actions.js +0 -29
  105. package/src/functions/get-block-component-options.js +0 -27
  106. package/src/functions/get-block-properties.js +0 -63
  107. package/src/functions/get-builder-search-params/index.js +0 -33
  108. package/src/functions/get-content/generate-content-url.js +0 -59
  109. package/src/functions/get-content/index.js +0 -116
  110. package/src/functions/get-content/types.js +0 -0
  111. package/src/functions/get-fetch.js +0 -12
  112. package/src/functions/get-global-this.js +0 -16
  113. package/src/functions/get-processed-block.js +0 -74
  114. package/src/functions/get-react-native-block-styles.js +0 -32
  115. package/src/functions/is-browser.js +0 -4
  116. package/src/functions/is-editing.js +0 -6
  117. package/src/functions/is-iframe.js +0 -5
  118. package/src/functions/is-non-node-server.js +0 -9
  119. package/src/functions/is-previewing.js +0 -12
  120. package/src/functions/on-change.js +0 -24
  121. package/src/functions/register-component.js +0 -60
  122. package/src/functions/register.js +0 -27
  123. package/src/functions/sanitize-react-native-block-styles.js +0 -71
  124. package/src/functions/set-editor-settings.js +0 -13
  125. package/src/functions/set.js +0 -9
  126. package/src/functions/track/helpers.js +0 -48
  127. package/src/functions/track/index.js +0 -131
  128. package/src/functions/track/interaction.js +0 -57
  129. package/src/functions/transform-block-properties.js +0 -4
  130. package/src/functions/transform-block.js +0 -4
  131. package/src/helpers/ab-tests.js +0 -158
  132. package/src/helpers/canTrack.js +0 -3
  133. package/src/helpers/cookie.js +0 -77
  134. package/src/helpers/css.js +0 -30
  135. package/src/helpers/flatten.js +0 -31
  136. package/src/helpers/localStorage.js +0 -32
  137. package/src/helpers/logger.js +0 -8
  138. package/src/helpers/nullable.js +0 -2
  139. package/src/helpers/preview-lru-cache/get.js +0 -4
  140. package/src/helpers/preview-lru-cache/helpers.js +0 -0
  141. package/src/helpers/preview-lru-cache/init.js +0 -2
  142. package/src/helpers/preview-lru-cache/set.js +0 -31
  143. package/src/helpers/preview-lru-cache/types.js +0 -0
  144. package/src/helpers/sessionId.js +0 -55
  145. package/src/helpers/time.js +0 -3
  146. package/src/helpers/url.js +0 -11
  147. package/src/helpers/uuid.js +0 -11
  148. package/src/helpers/visitorId.js +0 -35
  149. package/src/index-helpers/blocks-exports.js +0 -13
  150. package/src/index-helpers/top-of-file.js +0 -2
  151. package/src/index.js +0 -3
  152. package/src/scripts/init-editing.js +0 -109
  153. package/src/server-index.js +0 -11
  154. package/src/types/api-version.js +0 -2
  155. package/src/types/builder-block.js +0 -0
  156. package/src/types/builder-content.js +0 -0
  157. package/src/types/builder-props.js +0 -0
  158. package/src/types/can-track.js +0 -0
  159. package/src/types/components.js +0 -0
  160. package/src/types/deep-partial.js +0 -0
  161. package/src/types/element.js +0 -0
  162. package/src/types/enforced-partials.js +0 -0
  163. package/src/types/input.js +0 -0
  164. package/src/types/targets.js +0 -0
  165. package/src/types/typescript.js +0 -0
  166. package/vite.config.ts +0 -18
@@ -1,218 +0,0 @@
1
- const componentInfo = {
2
- name: "Columns",
3
- isRSC: true,
4
- inputs: [{
5
- name: "columns",
6
- type: "array",
7
- broadcast: true,
8
- subFields: [{
9
- name: "blocks",
10
- type: "array",
11
- hideFromUI: true,
12
- defaultValue: [{
13
- "@type": "@builder.io/sdk:Element",
14
- responsiveStyles: {
15
- large: {
16
- display: "flex",
17
- flexDirection: "column",
18
- alignItems: "stretch",
19
- flexShrink: "0",
20
- position: "relative",
21
- marginTop: "30px",
22
- textAlign: "center",
23
- lineHeight: "normal",
24
- height: "auto",
25
- minHeight: "20px",
26
- minWidth: "20px",
27
- overflow: "hidden"
28
- }
29
- },
30
- component: {
31
- name: "Image",
32
- options: {
33
- image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
34
- backgroundPosition: "center",
35
- backgroundSize: "cover",
36
- aspectRatio: 0.7004048582995948
37
- }
38
- }
39
- }, {
40
- "@type": "@builder.io/sdk:Element",
41
- responsiveStyles: {
42
- large: {
43
- display: "flex",
44
- flexDirection: "column",
45
- alignItems: "stretch",
46
- flexShrink: "0",
47
- position: "relative",
48
- marginTop: "30px",
49
- textAlign: "center",
50
- lineHeight: "normal",
51
- height: "auto"
52
- }
53
- },
54
- component: {
55
- name: "Text",
56
- options: {
57
- text: "<p>Enter some text...</p>"
58
- }
59
- }
60
- }]
61
- }, {
62
- name: "width",
63
- type: "number",
64
- hideFromUI: true,
65
- helperText: "Width %, e.g. set to 50 to fill half of the space"
66
- }, {
67
- name: "link",
68
- type: "url",
69
- helperText: "Optionally set a url that clicking this column will link to"
70
- }],
71
- defaultValue: [{
72
- blocks: [{
73
- "@type": "@builder.io/sdk:Element",
74
- responsiveStyles: {
75
- large: {
76
- display: "flex",
77
- flexDirection: "column",
78
- alignItems: "stretch",
79
- flexShrink: "0",
80
- position: "relative",
81
- marginTop: "30px",
82
- textAlign: "center",
83
- lineHeight: "normal",
84
- height: "auto",
85
- minHeight: "20px",
86
- minWidth: "20px",
87
- overflow: "hidden"
88
- }
89
- },
90
- component: {
91
- name: "Image",
92
- options: {
93
- image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
94
- backgroundPosition: "center",
95
- backgroundSize: "cover",
96
- aspectRatio: 0.7004048582995948
97
- }
98
- }
99
- }, {
100
- "@type": "@builder.io/sdk:Element",
101
- responsiveStyles: {
102
- large: {
103
- display: "flex",
104
- flexDirection: "column",
105
- alignItems: "stretch",
106
- flexShrink: "0",
107
- position: "relative",
108
- marginTop: "30px",
109
- textAlign: "center",
110
- lineHeight: "normal",
111
- height: "auto"
112
- }
113
- },
114
- component: {
115
- name: "Text",
116
- options: {
117
- text: "<p>Enter some text...</p>"
118
- }
119
- }
120
- }]
121
- }, {
122
- blocks: [{
123
- "@type": "@builder.io/sdk:Element",
124
- responsiveStyles: {
125
- large: {
126
- display: "flex",
127
- flexDirection: "column",
128
- alignItems: "stretch",
129
- flexShrink: "0",
130
- position: "relative",
131
- marginTop: "30px",
132
- textAlign: "center",
133
- lineHeight: "normal",
134
- height: "auto",
135
- minHeight: "20px",
136
- minWidth: "20px",
137
- overflow: "hidden"
138
- }
139
- },
140
- component: {
141
- name: "Image",
142
- options: {
143
- image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
144
- backgroundPosition: "center",
145
- backgroundSize: "cover",
146
- aspectRatio: 0.7004048582995948
147
- }
148
- }
149
- }, {
150
- "@type": "@builder.io/sdk:Element",
151
- responsiveStyles: {
152
- large: {
153
- display: "flex",
154
- flexDirection: "column",
155
- alignItems: "stretch",
156
- flexShrink: "0",
157
- position: "relative",
158
- marginTop: "30px",
159
- textAlign: "center",
160
- lineHeight: "normal",
161
- height: "auto"
162
- }
163
- },
164
- component: {
165
- name: "Text",
166
- options: {
167
- text: "<p>Enter some text...</p>"
168
- }
169
- }
170
- }]
171
- }],
172
- onChange: options => {
173
- function clearWidths() {
174
- columns.forEach(col => {
175
- col.delete("width");
176
- });
177
- }
178
- const columns = options.get("columns");
179
- if (Array.isArray(columns)) {
180
- const containsColumnWithWidth = !!columns.find(col => col.get("width"));
181
- if (containsColumnWithWidth) {
182
- const containsColumnWithoutWidth = !!columns.find(col => !col.get("width"));
183
- if (containsColumnWithoutWidth) {
184
- clearWidths();
185
- } else {
186
- const sumWidths = columns.reduce((memo, col) => {
187
- return memo + col.get("width");
188
- }, 0);
189
- const widthsDontAddUp = sumWidths !== 100;
190
- if (widthsDontAddUp) {
191
- clearWidths();
192
- }
193
- }
194
- }
195
- }
196
- }
197
- }, {
198
- name: "space",
199
- type: "number",
200
- defaultValue: 20,
201
- helperText: "Size of gap between columns",
202
- advanced: true
203
- }, {
204
- name: "stackColumnsAt",
205
- type: "string",
206
- defaultValue: "tablet",
207
- helperText: "Convert horizontal columns to vertical at what device size",
208
- enum: ["tablet", "mobile", "never"],
209
- advanced: true
210
- }, {
211
- name: "reverseColumnsWhenStacked",
212
- type: "boolean",
213
- defaultValue: false,
214
- helperText: "When stacking columns for mobile devices, reverse the ordering",
215
- advanced: true
216
- }]
217
- };
218
- export { componentInfo }
@@ -1,24 +0,0 @@
1
- const componentInfo = {
2
- name: "Custom Code",
3
- static: true,
4
- requiredPermissions: ["editCode"],
5
- inputs: [{
6
- name: "code",
7
- type: "html",
8
- required: true,
9
- defaultValue: "<p>Hello there, I am custom HTML code!</p>",
10
- code: true
11
- }, {
12
- name: "replaceNodes",
13
- type: "boolean",
14
- helperText: "Preserve server rendered dom nodes",
15
- advanced: true
16
- }, {
17
- name: "scriptsClientOnly",
18
- type: "boolean",
19
- defaultValue: false,
20
- helperText: "Only print and run scripts on the client. Important when scripts influence DOM that could be replaced when client loads",
21
- advanced: true
22
- }]
23
- };
24
- export { componentInfo }
@@ -1,62 +0,0 @@
1
- import { onMount, createSignal } from "solid-js";
2
-
3
- function CustomCode(props) {
4
- const [scriptsInserted, setScriptsInserted] = createSignal([]);
5
-
6
- const [scriptsRun, setScriptsRun] = createSignal([]);
7
-
8
- function findAndRunScripts() {
9
- // TODO: Move this function to standalone one in '@builder.io/utils'
10
- if (elem && elem.getElementsByTagName && typeof window !== "undefined") {
11
- const scripts = elem.getElementsByTagName("script");
12
- for (let i = 0; i < scripts.length; i++) {
13
- const script = scripts[i];
14
- if (script.src) {
15
- if (scriptsInserted().includes(script.src)) {
16
- continue;
17
- }
18
- scriptsInserted().push(script.src);
19
- const newScript = document.createElement("script");
20
- newScript.async = true;
21
- newScript.src = script.src;
22
- document.head.appendChild(newScript);
23
- } else if (
24
- !script.type ||
25
- [
26
- "text/javascript",
27
- "application/javascript",
28
- "application/ecmascript",
29
- ].includes(script.type)
30
- ) {
31
- if (scriptsRun().includes(script.innerText)) {
32
- continue;
33
- }
34
- try {
35
- scriptsRun().push(script.innerText);
36
- new Function(script.innerText)();
37
- } catch (error) {
38
- console.warn("`CustomCode`: Error running script:", error);
39
- }
40
- }
41
- }
42
- }
43
- }
44
-
45
- let elem;
46
-
47
- onMount(() => {
48
- findAndRunScripts();
49
- });
50
-
51
- return (
52
- <div
53
- class={
54
- "builder-custom-code" + (props.replaceNodes ? " replace-nodes" : "")
55
- }
56
- ref={elem}
57
- innerHTML={props.code}
58
- ></div>
59
- );
60
- }
61
-
62
- export default CustomCode;
@@ -1,37 +0,0 @@
1
- const componentInfo = {
2
- name: "Embed",
3
- static: true,
4
- inputs: [{
5
- name: "url",
6
- type: "url",
7
- required: true,
8
- defaultValue: "",
9
- helperText: "e.g. enter a youtube url, google map, etc",
10
- onChange: options => {
11
- const url = options.get("url");
12
- if (url) {
13
- options.set("content", "Loading...");
14
- const apiKey = "ae0e60e78201a3f2b0de4b";
15
- return fetch(`https://iframe.ly/api/iframely?url=${url}&api_key=${apiKey}`).then(res => res.json()).then(data => {
16
- if (options.get("url") === url) {
17
- if (data.html) {
18
- options.set("content", data.html);
19
- } else {
20
- options.set("content", "Invalid url, please try another");
21
- }
22
- }
23
- }).catch(_err => {
24
- options.set("content", "There was an error embedding this URL, please try again or another URL");
25
- });
26
- } else {
27
- options.delete("content");
28
- }
29
- }
30
- }, {
31
- name: "content",
32
- type: "html",
33
- defaultValue: '<div style="padding: 20px; text-align: center">(Choose an embed URL)<div>',
34
- hideFromUI: true
35
- }]
36
- };
37
- export { componentInfo }
@@ -1,50 +0,0 @@
1
- import { on, createEffect, createSignal } from "solid-js";
2
-
3
- import { isJsScript } from "./helpers.js";
4
-
5
- function Embed(props) {
6
- const [scriptsInserted, setScriptsInserted] = createSignal([]);
7
-
8
- const [scriptsRun, setScriptsRun] = createSignal([]);
9
-
10
- const [ranInitFn, setRanInitFn] = createSignal(false);
11
-
12
- function findAndRunScripts() {
13
- if (!elem || !elem.getElementsByTagName) return;
14
- const scripts = elem.getElementsByTagName("script");
15
- for (let i = 0; i < scripts.length; i++) {
16
- const script = scripts[i];
17
- if (script.src && !scriptsInserted().includes(script.src)) {
18
- scriptsInserted().push(script.src);
19
- const newScript = document.createElement("script");
20
- newScript.async = true;
21
- newScript.src = script.src;
22
- document.head.appendChild(newScript);
23
- } else if (
24
- isJsScript(script) &&
25
- !scriptsRun().includes(script.innerText)
26
- ) {
27
- try {
28
- scriptsRun().push(script.innerText);
29
- new Function(script.innerText)();
30
- } catch (error) {
31
- console.warn("`Embed`: Error running script:", error);
32
- }
33
- }
34
- }
35
- }
36
-
37
- let elem;
38
-
39
- function onUpdateFn_0() {
40
- if (elem && !ranInitFn()) {
41
- setRanInitFn(true);
42
- findAndRunScripts();
43
- }
44
- }
45
- createEffect(on(() => [elem, ranInitFn()], onUpdateFn_0));
46
-
47
- return <div class="builder-embed" ref={elem} innerHTML={props.content}></div>;
48
- }
49
-
50
- export default Embed;
@@ -1,3 +0,0 @@
1
- const SCRIPT_MIME_TYPES = ["text/javascript", "application/javascript", "application/ecmascript"];
2
- const isJsScript = script => SCRIPT_MIME_TYPES.includes(script.type);
3
- export { isJsScript }
@@ -1,223 +0,0 @@
1
- const componentInfo = {
2
- name: "Form:Form",
3
- defaults: {
4
- responsiveStyles: {
5
- large: {
6
- marginTop: "15px",
7
- paddingBottom: "15px"
8
- }
9
- }
10
- },
11
- image: "https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2Fef36d2a846134910b64b88e6d18c5ca5",
12
- inputs: [{
13
- name: "sendSubmissionsTo",
14
- type: "string",
15
- enum: [{
16
- label: "Send to email",
17
- value: "email",
18
- helperText: "Send form submissions to the email address of your choosing"
19
- }, {
20
- label: "Custom",
21
- value: "custom",
22
- helperText: "Handle where the form requests go manually with a little code, e.g. to your own custom backend"
23
- }],
24
- defaultValue: "email"
25
- }, {
26
- name: "sendSubmissionsToEmail",
27
- type: "string",
28
- required: true,
29
- defaultValue: "your@email.com",
30
- showIf: 'options.get("sendSubmissionsTo") === "email"'
31
- }, {
32
- name: "sendWithJs",
33
- type: "boolean",
34
- helperText: "Set to false to use basic html form action",
35
- defaultValue: true,
36
- showIf: 'options.get("sendSubmissionsTo") === "custom"'
37
- }, {
38
- name: "name",
39
- type: "string",
40
- defaultValue: "My form"
41
- }, {
42
- name: "action",
43
- type: "string",
44
- helperText: "URL to send the form data to",
45
- showIf: 'options.get("sendSubmissionsTo") === "custom"'
46
- }, {
47
- name: "contentType",
48
- type: "string",
49
- defaultValue: "application/json",
50
- advanced: true,
51
- enum: ["application/json", "multipart/form-data", "application/x-www-form-urlencoded"],
52
- showIf: 'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'
53
- }, {
54
- name: "method",
55
- type: "string",
56
- showIf: 'options.get("sendSubmissionsTo") === "custom"',
57
- defaultValue: "POST",
58
- advanced: true
59
- }, {
60
- name: "previewState",
61
- type: "string",
62
- enum: ["unsubmitted", "sending", "success", "error"],
63
- defaultValue: "unsubmitted",
64
- helperText: 'Choose a state to edit, e.g. choose "success" to show what users see on success and edit the message',
65
- showIf: 'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'
66
- }, {
67
- name: "successUrl",
68
- type: "url",
69
- helperText: "Optional URL to redirect the user to on form submission success",
70
- showIf: 'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'
71
- }, {
72
- name: "resetFormOnSubmit",
73
- type: "boolean",
74
- showIf: "options.get('sendSubmissionsTo') === 'custom' && options.get('sendWithJs') === true",
75
- advanced: true
76
- }, {
77
- name: "successMessage",
78
- type: "uiBlocks",
79
- hideFromUI: true,
80
- defaultValue: [{
81
- "@type": "@builder.io/sdk:Element",
82
- responsiveStyles: {
83
- large: {
84
- marginTop: "10px"
85
- }
86
- },
87
- component: {
88
- name: "Text",
89
- options: {
90
- text: "<span>Thanks!</span>"
91
- }
92
- }
93
- }]
94
- }, {
95
- name: "validate",
96
- type: "boolean",
97
- defaultValue: true,
98
- advanced: true
99
- }, {
100
- name: "errorMessagePath",
101
- type: "text",
102
- advanced: true,
103
- helperText: 'Path to where to get the error message from in a JSON response to display to the user, e.g. "error.message" for a response like { "error": { "message": "this username is taken" }}'
104
- }, {
105
- name: "errorMessage",
106
- type: "uiBlocks",
107
- hideFromUI: true,
108
- defaultValue: [{
109
- "@type": "@builder.io/sdk:Element",
110
- responsiveStyles: {
111
- large: {
112
- marginTop: "10px"
113
- }
114
- },
115
- bindings: {
116
- "component.options.text": "state.formErrorMessage || block.component.options.text"
117
- },
118
- component: {
119
- name: "Text",
120
- options: {
121
- text: "<span>Form submission error :( Please check your answers and try again</span>"
122
- }
123
- }
124
- }]
125
- }, {
126
- name: "sendingMessage",
127
- type: "uiBlocks",
128
- hideFromUI: true,
129
- defaultValue: [{
130
- "@type": "@builder.io/sdk:Element",
131
- responsiveStyles: {
132
- large: {
133
- marginTop: "10px"
134
- }
135
- },
136
- component: {
137
- name: "Text",
138
- options: {
139
- text: "<span>Sending...</span>"
140
- }
141
- }
142
- }]
143
- }, {
144
- name: "customHeaders",
145
- type: "map",
146
- valueType: {
147
- type: "string"
148
- },
149
- advanced: true,
150
- showIf: 'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'
151
- }],
152
- noWrap: true,
153
- canHaveChildren: true,
154
- defaultChildren: [{
155
- "@type": "@builder.io/sdk:Element",
156
- responsiveStyles: {
157
- large: {
158
- marginTop: "10px"
159
- }
160
- },
161
- component: {
162
- name: "Text",
163
- options: {
164
- text: "<span>Enter your name</span>"
165
- }
166
- }
167
- }, {
168
- "@type": "@builder.io/sdk:Element",
169
- responsiveStyles: {
170
- large: {
171
- marginTop: "10px"
172
- }
173
- },
174
- component: {
175
- name: "Form:Input",
176
- options: {
177
- name: "name",
178
- placeholder: "Jane Doe"
179
- }
180
- }
181
- }, {
182
- "@type": "@builder.io/sdk:Element",
183
- responsiveStyles: {
184
- large: {
185
- marginTop: "10px"
186
- }
187
- },
188
- component: {
189
- name: "Text",
190
- options: {
191
- text: "<span>Enter your email</span>"
192
- }
193
- }
194
- }, {
195
- "@type": "@builder.io/sdk:Element",
196
- responsiveStyles: {
197
- large: {
198
- marginTop: "10px"
199
- }
200
- },
201
- component: {
202
- name: "Form:Input",
203
- options: {
204
- name: "email",
205
- placeholder: "jane@doe.com"
206
- }
207
- }
208
- }, {
209
- "@type": "@builder.io/sdk:Element",
210
- responsiveStyles: {
211
- large: {
212
- marginTop: "10px"
213
- }
214
- },
215
- component: {
216
- name: "Form:SubmitButton",
217
- options: {
218
- text: "Submit"
219
- }
220
- }
221
- }]
222
- };
223
- export { componentInfo }
@@ -1,5 +0,0 @@
1
- function FormComponent(props) {
2
- return <></>;
3
- }
4
-
5
- export default FormComponent;
@@ -1,8 +0,0 @@
1
- const componentInfo = {
2
- name: "Fragment",
3
- static: true,
4
- hidden: true,
5
- canHaveChildren: true,
6
- noWrap: true
7
- };
8
- export { componentInfo }
@@ -1,5 +0,0 @@
1
- function FragmentComponent(props) {
2
- return <span>{props.children}</span>;
3
- }
4
-
5
- export default FragmentComponent;
@@ -1,27 +0,0 @@
1
- function filterAttrs(attrs = {}, prefix, isEvent) {
2
- const result = {};
3
- for (const attr in attrs) {
4
- if (!attrs[attr]) continue;
5
- if (isEvent && !attr.startsWith(prefix)) continue;
6
- const eventName = isEvent ? attr.replace(prefix, "") : attr;
7
- result[eventName] = attrs[attr];
8
- }
9
- return result;
10
- }
11
- function setAttrs(node, attrs = {}) {
12
- const attrKeys = Object.keys(attrs);
13
- const setup = attr => node.addEventListener(attr, attrs[attr]);
14
- const teardown = attr => node.removeEventListener(attr, attrs[attr]);
15
- attrKeys.forEach(setup);
16
- return {
17
- update(attrs2 = {}) {
18
- const attrKeys2 = Object.keys(attrs2);
19
- attrKeys2.forEach(teardown);
20
- attrKeys2.forEach(setup);
21
- },
22
- destroy() {
23
- attrKeys.forEach(teardown);
24
- }
25
- };
26
- }
27
- export { filterAttrs, setAttrs }