@builder.io/sdk-solid 0.0.5 → 0.0.8-0
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/package.json +9 -2
- package/src/blocks/button/button.jsx +13 -0
- package/src/blocks/button/button.lite.tsx +20 -0
- package/src/blocks/button/component-info.js +41 -0
- package/src/blocks/button/index.js +7 -0
- package/src/blocks/columns/columns.jsx +91 -0
- package/src/blocks/{columns.lite.tsx → columns/columns.lite.tsx} +32 -26
- package/src/blocks/columns/component-info.js +217 -0
- package/src/blocks/columns/index.js +7 -0
- package/src/blocks/custom-code/component-info.js +31 -0
- package/src/blocks/{custom-code.js → custom-code/custom-code.jsx} +5 -26
- package/src/blocks/{custom-code.lite.tsx → custom-code/custom-code.lite.tsx} +3 -1
- package/src/blocks/custom-code/index.js +7 -0
- package/src/blocks/embed/component-info.js +24 -0
- package/src/blocks/embed/embed.jsx +51 -0
- package/src/blocks/{embed.lite.tsx → embed/embed.lite.tsx} +3 -1
- package/src/blocks/embed/index.js +7 -0
- package/src/blocks/form/component-info.js +262 -0
- package/src/blocks/form/form.jsx +253 -0
- package/src/blocks/{form.lite.tsx → form/form.lite.tsx} +14 -8
- package/src/blocks/form/index.js +7 -0
- package/src/blocks/fragment/component-info.js +11 -0
- package/src/blocks/fragment/fragment.jsx +5 -0
- package/src/blocks/fragment/fragment.lite.tsx +5 -0
- package/src/blocks/fragment/index.js +7 -0
- package/src/blocks/image/component-info.js +104 -0
- package/src/blocks/image/image.jsx +54 -0
- package/src/blocks/image/image.lite.tsx +83 -0
- package/src/blocks/image/index.js +7 -0
- package/src/blocks/img/component-info.js +20 -0
- package/src/blocks/img/img.jsx +10 -0
- package/src/blocks/{img.lite.tsx → img/img.lite.tsx} +4 -2
- package/src/blocks/img/index.js +7 -0
- package/src/blocks/input/component-info.js +74 -0
- package/src/blocks/input/index.js +7 -0
- package/src/blocks/input/input.jsx +7 -0
- package/src/blocks/{input.lite.tsx → input/input.lite.tsx} +4 -2
- package/src/blocks/raw-text/component-info.js +16 -0
- package/src/blocks/raw-text/index.js +7 -0
- package/src/blocks/raw-text/raw-text.jsx +5 -0
- package/src/blocks/{raw-text.lite.tsx → raw-text/raw-text.lite.tsx} +3 -1
- package/src/blocks/section/component-info.js +49 -0
- package/src/blocks/section/index.js +7 -0
- package/src/blocks/section/section.jsx +9 -0
- package/src/blocks/{section.lite.tsx → section/section.lite.tsx} +3 -1
- package/src/blocks/select/component-info.js +59 -0
- package/src/blocks/select/index.js +7 -0
- package/src/blocks/select/select.jsx +16 -0
- package/src/blocks/{select.lite.tsx → select/select.lite.tsx} +10 -5
- package/src/blocks/submit-button/component-info.js +28 -0
- package/src/blocks/submit-button/index.js +7 -0
- package/src/blocks/submit-button/submit-button.jsx +7 -0
- package/src/blocks/{submit-button.lite.tsx → submit-button/submit-button.lite.tsx} +3 -1
- package/src/blocks/symbol/component-info.js +42 -0
- package/src/blocks/symbol/index.js +7 -0
- package/src/blocks/symbol/symbol.jsx +24 -0
- package/src/blocks/{symbol.lite.tsx → symbol/symbol.lite.tsx} +6 -4
- package/src/blocks/text/component-info.js +24 -0
- package/src/blocks/text/index.js +7 -0
- package/src/blocks/{text.lite.tsx → text/text.jsx} +3 -1
- package/src/blocks/text/text.lite.tsx +5 -0
- package/src/blocks/textarea/component-info.js +47 -0
- package/src/blocks/textarea/index.js +7 -0
- package/src/blocks/textarea/textarea.jsx +5 -0
- package/src/blocks/{textarea.lite.tsx → textarea/textarea.lite.tsx} +3 -1
- package/src/blocks/video/component-info.js +106 -0
- package/src/blocks/video/index.js +7 -0
- package/src/blocks/video/video.jsx +14 -0
- package/src/blocks/{video.lite.tsx → video/video.lite.tsx} +3 -1
- package/src/components/error-boundary.jsx +5 -0
- package/src/components/error-boundary.lite.tsx +3 -1
- package/src/components/render-block/block-styles.jsx +36 -0
- package/src/components/render-block/block-styles.lite.tsx +38 -0
- package/src/components/render-block/render-block.jsx +117 -0
- package/src/components/{render-block.lite.tsx → render-block/render-block.lite.tsx} +24 -13
- package/src/components/render-blocks.jsx +57 -0
- package/src/components/render-blocks.lite.tsx +9 -6
- package/src/components/render-content/components/{render-styles.js → render-styles.jsx} +8 -15
- package/src/components/render-content/components/render-styles.lite.tsx +10 -4
- package/src/components/render-content/{render-content.js → render-content.jsx} +42 -94
- package/src/components/render-content/render-content.lite.tsx +23 -20
- package/src/components/render-inlined-styles.jsx +23 -0
- package/src/components/render-inlined-styles.lite.tsx +26 -0
- package/src/functions/evaluate.js +2 -2
- package/src/functions/get-block-actions.js +2 -2
- package/src/functions/get-builder-search-params/fn.test.js +1 -1
- package/src/functions/get-content/index.js +3 -2
- package/src/functions/get-fetch.js +29 -7
- package/src/functions/get-processed-block.js +3 -3
- package/src/functions/get-processed-block.test.js +1 -1
- package/src/functions/if-target.js +1 -1
- package/src/functions/is-editing.js +1 -1
- package/src/functions/is-iframe.js +1 -1
- package/src/functions/is-previewing.js +2 -2
- package/src/functions/on-change.test.js +1 -1
- package/src/functions/previewing-model-name.js +1 -1
- package/src/functions/register-component.js +1 -1
- package/src/functions/register.js +1 -1
- package/src/functions/set-editor-settings.js +1 -1
- package/src/functions/set.test.js +1 -1
- package/src/functions/track.js +3 -3
- package/src/index-helpers/blocks-exports.js +8 -8
- package/src/index.js +10 -13
- package/src/scripts/init-editing.js +72 -63
- package/src/blocks/button.js +0 -32
- package/src/blocks/button.lite.tsx +0 -12
- package/src/blocks/columns.js +0 -133
- package/src/blocks/embed.js +0 -62
- package/src/blocks/form.js +0 -355
- package/src/blocks/fragment.js +0 -15
- package/src/blocks/fragment.lite.tsx +0 -3
- package/src/blocks/image.js +0 -211
- package/src/blocks/image.lite.tsx +0 -169
- package/src/blocks/img.js +0 -39
- package/src/blocks/input.js +0 -45
- package/src/blocks/raw-text.js +0 -25
- package/src/blocks/section.js +0 -24
- package/src/blocks/select.js +0 -57
- package/src/blocks/submit-button.js +0 -18
- package/src/blocks/symbol.js +0 -69
- package/src/blocks/text.js +0 -15
- package/src/blocks/textarea.js +0 -34
- package/src/blocks/video.js +0 -54
- package/src/components/block-styles.js +0 -3
- package/src/components/block-styles.lite.tsx +0 -3
- package/src/components/error-boundary.js +0 -3
- package/src/components/render-block.js +0 -154
- package/src/components/render-blocks.js +0 -104
package/src/blocks/form.js
DELETED
|
@@ -1,355 +0,0 @@
|
|
|
1
|
-
import { template as _$template } from "solid-js/web";
|
|
2
|
-
import { setAttribute as _$setAttribute } from "solid-js/web";
|
|
3
|
-
import { effect as _$effect } from "solid-js/web";
|
|
4
|
-
import { insert as _$insert } from "solid-js/web";
|
|
5
|
-
import { createComponent as _$createComponent } from "solid-js/web";
|
|
6
|
-
import { memo as _$memo } from "solid-js/web";
|
|
7
|
-
import { spread as _$spread } from "solid-js/web";
|
|
8
|
-
|
|
9
|
-
const _tmpl$ = /*#__PURE__*/_$template(`<pre></pre>`, 2),
|
|
10
|
-
_tmpl$2 = /*#__PURE__*/_$template(`<form></form>`, 2);
|
|
11
|
-
|
|
12
|
-
import { Show, For } from "solid-js";
|
|
13
|
-
import { createMutable } from "solid-js/store";
|
|
14
|
-
import { css } from "solid-styled-components";
|
|
15
|
-
import RenderBlock from "../components/render-block";
|
|
16
|
-
export default function FormComponent(props) {
|
|
17
|
-
const state = createMutable({
|
|
18
|
-
state: "unsubmitted",
|
|
19
|
-
responseData: null,
|
|
20
|
-
formErrorMessage: "",
|
|
21
|
-
|
|
22
|
-
get submissionState() {
|
|
23
|
-
return Builder.isEditing && props.previewState || state.state;
|
|
24
|
-
},
|
|
25
|
-
|
|
26
|
-
onSubmit(event) {
|
|
27
|
-
const sendWithJs = props.sendWithJs || props.sendSubmissionsTo === "email";
|
|
28
|
-
|
|
29
|
-
if (props.sendSubmissionsTo === "zapier") {
|
|
30
|
-
event.preventDefault();
|
|
31
|
-
} else if (sendWithJs) {
|
|
32
|
-
if (!(props.action || props.sendSubmissionsTo === "email")) {
|
|
33
|
-
event.preventDefault();
|
|
34
|
-
return;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
event.preventDefault();
|
|
38
|
-
const el = event.currentTarget;
|
|
39
|
-
const headers = props.customHeaders || {};
|
|
40
|
-
let body;
|
|
41
|
-
const formData = new FormData(el); // TODO: maybe support null
|
|
42
|
-
|
|
43
|
-
const formPairs = Array.from(event.currentTarget.querySelectorAll("input,select,textarea")).filter(el => !!el.name).map(el => {
|
|
44
|
-
let value;
|
|
45
|
-
const key = el.name;
|
|
46
|
-
|
|
47
|
-
if (el instanceof HTMLInputElement) {
|
|
48
|
-
if (el.type === "radio") {
|
|
49
|
-
if (el.checked) {
|
|
50
|
-
value = el.name;
|
|
51
|
-
return {
|
|
52
|
-
key,
|
|
53
|
-
value
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
} else if (el.type === "checkbox") {
|
|
57
|
-
value = el.checked;
|
|
58
|
-
} else if (el.type === "number" || el.type === "range") {
|
|
59
|
-
const num = el.valueAsNumber;
|
|
60
|
-
|
|
61
|
-
if (!isNaN(num)) {
|
|
62
|
-
value = num;
|
|
63
|
-
}
|
|
64
|
-
} else if (el.type === "file") {
|
|
65
|
-
// TODO: one vs multiple files
|
|
66
|
-
value = el.files;
|
|
67
|
-
} else {
|
|
68
|
-
value = el.value;
|
|
69
|
-
}
|
|
70
|
-
} else {
|
|
71
|
-
value = el.value;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
return {
|
|
75
|
-
key,
|
|
76
|
-
value
|
|
77
|
-
};
|
|
78
|
-
});
|
|
79
|
-
let contentType = props.contentType;
|
|
80
|
-
|
|
81
|
-
if (props.sendSubmissionsTo === "email") {
|
|
82
|
-
contentType = "multipart/form-data";
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
Array.from(formPairs).forEach(({
|
|
86
|
-
value
|
|
87
|
-
}) => {
|
|
88
|
-
if (value instanceof File || Array.isArray(value) && value[0] instanceof File || value instanceof FileList) {
|
|
89
|
-
contentType = "multipart/form-data";
|
|
90
|
-
}
|
|
91
|
-
}); // TODO: send as urlEncoded or multipart by default
|
|
92
|
-
// because of ease of use and reliability in browser API
|
|
93
|
-
// for encoding the form?
|
|
94
|
-
|
|
95
|
-
if (contentType !== "application/json") {
|
|
96
|
-
body = formData;
|
|
97
|
-
} else {
|
|
98
|
-
// Json
|
|
99
|
-
const json = {};
|
|
100
|
-
Array.from(formPairs).forEach(({
|
|
101
|
-
value,
|
|
102
|
-
key
|
|
103
|
-
}) => {
|
|
104
|
-
set(json, key, value);
|
|
105
|
-
});
|
|
106
|
-
body = JSON.stringify(json);
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
if (contentType && contentType !== "multipart/form-data") {
|
|
110
|
-
if (
|
|
111
|
-
/* Zapier doesn't allow content-type header to be sent from browsers */
|
|
112
|
-
!(sendWithJs && props.action?.includes("zapier.com"))) {
|
|
113
|
-
headers["content-type"] = contentType;
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
const presubmitEvent = new CustomEvent("presubmit", {
|
|
118
|
-
detail: {
|
|
119
|
-
body
|
|
120
|
-
}
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
if (formRef) {
|
|
124
|
-
formRef.dispatchEvent(presubmitEvent);
|
|
125
|
-
|
|
126
|
-
if (presubmitEvent.defaultPrevented) {
|
|
127
|
-
return;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
state.state = "sending";
|
|
132
|
-
const formUrl = `${builder.env === "dev" ? "http://localhost:5000" : "https://builder.io"}/api/v1/form-submit?apiKey=${builder.apiKey}&to=${btoa(props.sendSubmissionsToEmail || "")}&name=${encodeURIComponent(props.name || "")}`;
|
|
133
|
-
fetch(props.sendSubmissionsTo === "email" ? formUrl : props.action,
|
|
134
|
-
/* TODO: throw error if no action URL */
|
|
135
|
-
{
|
|
136
|
-
body,
|
|
137
|
-
headers,
|
|
138
|
-
method: props.method || "post"
|
|
139
|
-
}).then(async res => {
|
|
140
|
-
let body;
|
|
141
|
-
const contentType = res.headers.get("content-type");
|
|
142
|
-
|
|
143
|
-
if (contentType && contentType.indexOf("application/json") !== -1) {
|
|
144
|
-
body = await res.json();
|
|
145
|
-
} else {
|
|
146
|
-
body = await res.text();
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
if (!res.ok && props.errorMessagePath) {
|
|
150
|
-
/* TODO: allow supplying an error formatter function */
|
|
151
|
-
let message = get(body, props.errorMessagePath);
|
|
152
|
-
|
|
153
|
-
if (message) {
|
|
154
|
-
if (typeof message !== "string") {
|
|
155
|
-
/* TODO: ideally convert json to yaml so it woul dbe like
|
|
156
|
-
error: - email has been taken */
|
|
157
|
-
message = JSON.stringify(message);
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
state.formErrorMessage = message;
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
state.responseData = body;
|
|
165
|
-
state.state = res.ok ? "success" : "error";
|
|
166
|
-
|
|
167
|
-
if (res.ok) {
|
|
168
|
-
const submitSuccessEvent = new CustomEvent("submit:success", {
|
|
169
|
-
detail: {
|
|
170
|
-
res,
|
|
171
|
-
body
|
|
172
|
-
}
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
if (formRef) {
|
|
176
|
-
formRef.dispatchEvent(submitSuccessEvent);
|
|
177
|
-
|
|
178
|
-
if (submitSuccessEvent.defaultPrevented) {
|
|
179
|
-
return;
|
|
180
|
-
}
|
|
181
|
-
/* TODO: option to turn this on/off? */
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
if (props.resetFormOnSubmit !== false) {
|
|
185
|
-
formRef.reset();
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
/* TODO: client side route event first that can be preventDefaulted */
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
if (props.successUrl) {
|
|
192
|
-
if (formRef) {
|
|
193
|
-
const event = new CustomEvent("route", {
|
|
194
|
-
detail: {
|
|
195
|
-
url: props.successUrl
|
|
196
|
-
}
|
|
197
|
-
});
|
|
198
|
-
formRef.dispatchEvent(event);
|
|
199
|
-
|
|
200
|
-
if (!event.defaultPrevented) {
|
|
201
|
-
location.href = props.successUrl;
|
|
202
|
-
}
|
|
203
|
-
} else {
|
|
204
|
-
location.href = props.successUrl;
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
}, err => {
|
|
209
|
-
const submitErrorEvent = new CustomEvent("submit:error", {
|
|
210
|
-
detail: {
|
|
211
|
-
error: err
|
|
212
|
-
}
|
|
213
|
-
});
|
|
214
|
-
|
|
215
|
-
if (formRef) {
|
|
216
|
-
formRef.dispatchEvent(submitErrorEvent);
|
|
217
|
-
|
|
218
|
-
if (submitErrorEvent.defaultPrevented) {
|
|
219
|
-
return;
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
|
|
223
|
-
state.responseData = err;
|
|
224
|
-
state.state = "error";
|
|
225
|
-
});
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
});
|
|
230
|
-
const formRef = useRef();
|
|
231
|
-
return (() => {
|
|
232
|
-
const _el$ = _tmpl$2.cloneNode(true);
|
|
233
|
-
|
|
234
|
-
_el$.addEventListener("submit", event => state.onSubmit(event));
|
|
235
|
-
|
|
236
|
-
formRef(_el$);
|
|
237
|
-
|
|
238
|
-
_$spread(_el$, () => props.attributes, false, true);
|
|
239
|
-
|
|
240
|
-
_$insert(_el$, _$createComponent(Show, {
|
|
241
|
-
get when() {
|
|
242
|
-
return props.builderBlock && props.builderBlock.children;
|
|
243
|
-
},
|
|
244
|
-
|
|
245
|
-
get children() {
|
|
246
|
-
return _$createComponent(For, {
|
|
247
|
-
get each() {
|
|
248
|
-
return props.builderBlock?.children;
|
|
249
|
-
},
|
|
250
|
-
|
|
251
|
-
children: (block, index) => _$createComponent(RenderBlock, {
|
|
252
|
-
block: block
|
|
253
|
-
})
|
|
254
|
-
});
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
}), null);
|
|
258
|
-
|
|
259
|
-
_$insert(_el$, _$createComponent(Show, {
|
|
260
|
-
get when() {
|
|
261
|
-
return state.submissionState === "error";
|
|
262
|
-
},
|
|
263
|
-
|
|
264
|
-
get children() {
|
|
265
|
-
return _$createComponent(BuilderBlocks, {
|
|
266
|
-
dataPath: "errorMessage",
|
|
267
|
-
|
|
268
|
-
get blocks() {
|
|
269
|
-
return props.errorMessage;
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
});
|
|
273
|
-
}
|
|
274
|
-
|
|
275
|
-
}), null);
|
|
276
|
-
|
|
277
|
-
_$insert(_el$, _$createComponent(Show, {
|
|
278
|
-
get when() {
|
|
279
|
-
return state.submissionState === "sending";
|
|
280
|
-
},
|
|
281
|
-
|
|
282
|
-
get children() {
|
|
283
|
-
return _$createComponent(BuilderBlocks, {
|
|
284
|
-
dataPath: "sendingMessage",
|
|
285
|
-
|
|
286
|
-
get blocks() {
|
|
287
|
-
return props.sendingMessage;
|
|
288
|
-
}
|
|
289
|
-
|
|
290
|
-
});
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
}), null);
|
|
294
|
-
|
|
295
|
-
_$insert(_el$, _$createComponent(Show, {
|
|
296
|
-
get when() {
|
|
297
|
-
return state.submissionState === "error" && state.responseData;
|
|
298
|
-
},
|
|
299
|
-
|
|
300
|
-
get children() {
|
|
301
|
-
const _el$2 = _tmpl$.cloneNode(true);
|
|
302
|
-
|
|
303
|
-
_$insert(_el$2, () => JSON.stringify(state.responseData, null, 2));
|
|
304
|
-
|
|
305
|
-
_$effect(() => _el$2.className = css({
|
|
306
|
-
padding: "10px",
|
|
307
|
-
color: "red",
|
|
308
|
-
textAlign: "center"
|
|
309
|
-
}));
|
|
310
|
-
|
|
311
|
-
return _el$2;
|
|
312
|
-
}
|
|
313
|
-
|
|
314
|
-
}), null);
|
|
315
|
-
|
|
316
|
-
_$insert(_el$, _$createComponent(Show, {
|
|
317
|
-
get when() {
|
|
318
|
-
return state.submissionState === "success";
|
|
319
|
-
},
|
|
320
|
-
|
|
321
|
-
get children() {
|
|
322
|
-
return _$createComponent(BuilderBlocks, {
|
|
323
|
-
dataPath: "successMessage",
|
|
324
|
-
|
|
325
|
-
get blocks() {
|
|
326
|
-
return props.successMessage;
|
|
327
|
-
}
|
|
328
|
-
|
|
329
|
-
});
|
|
330
|
-
}
|
|
331
|
-
|
|
332
|
-
}), null);
|
|
333
|
-
|
|
334
|
-
_$effect(_p$ => {
|
|
335
|
-
const _v$ = props.validate,
|
|
336
|
-
_v$2 = !props.sendWithJs && props.action,
|
|
337
|
-
_v$3 = props.method,
|
|
338
|
-
_v$4 = props.name;
|
|
339
|
-
|
|
340
|
-
_v$ !== _p$._v$ && _$setAttribute(_el$, "validate", _p$._v$ = _v$);
|
|
341
|
-
_v$2 !== _p$._v$2 && _$setAttribute(_el$, "action", _p$._v$2 = _v$2);
|
|
342
|
-
_v$3 !== _p$._v$3 && _$setAttribute(_el$, "method", _p$._v$3 = _v$3);
|
|
343
|
-
_v$4 !== _p$._v$4 && _$setAttribute(_el$, "name", _p$._v$4 = _v$4);
|
|
344
|
-
return _p$;
|
|
345
|
-
}, {
|
|
346
|
-
_v$: undefined,
|
|
347
|
-
_v$2: undefined,
|
|
348
|
-
_v$3: undefined,
|
|
349
|
-
_v$4: undefined
|
|
350
|
-
});
|
|
351
|
-
|
|
352
|
-
return _el$;
|
|
353
|
-
})();
|
|
354
|
-
}import { registerComponent } from '../functions/register-component';
|
|
355
|
-
registerComponent(FormComponent, {name:'Form:Form',builtIn:true,defaults:{responsiveStyles:{large:{marginTop:'15px',paddingBottom:'15px'}}},image:'https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2Fef36d2a846134910b64b88e6d18c5ca5',inputs:[{name:'sendSubmissionsTo',type:'string',enum:[{label:'Send to email',value:'email',helperText:'Send form submissions to the email address of your choosing'},{label:'Custom',value:'custom',helperText:'Handle where the form requests go manually with a little code, e.g. to your own custom backend'}],defaultValue:'email'},{name:'sendSubmissionsToEmail',type:'string',required:true,defaultValue:'your@email.com',showIf:'options.get("sendSubmissionsTo") === "email"'},{name:'sendWithJs',type:'boolean',helperText:'Set to false to use basic html form action',defaultValue:true,showIf:'options.get("sendSubmissionsTo") === "custom"'},{name:'name',type:'string',defaultValue:'My form'},{name:'action',type:'string',helperText:'URL to send the form data to',showIf:'options.get("sendSubmissionsTo") === "custom"'},{name:'contentType',type:'string',defaultValue:'application/json',advanced:true,enum:['application/json','multipart/form-data','application/x-www-form-urlencoded'],showIf:'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'},{name:'method',type:'string',showIf:'options.get("sendSubmissionsTo") === "custom"',defaultValue:'POST',advanced:true},{name:'previewState',type:'string',enum:['unsubmitted','sending','success','error'],defaultValue:'unsubmitted',helperText:'Choose a state to edit, e.g. choose "success" to show what users see on success and edit the message',showIf:'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'},{name:'successUrl',type:'url',helperText:'Optional URL to redirect the user to on form submission success',showIf:'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'},{name:'resetFormOnSubmit',type:'boolean',showIf:"options.get('sendSubmissionsTo') === 'custom' && options.get('sendWithJs') === true",advanced:true},{name:'successMessage',type:'uiBlocks',hideFromUI:true,defaultValue:[{'@type':'@builder.io/sdk:Element',responsiveStyles:{large:{marginTop:'10px'}},component:{name:'Text',options:{text:'<span>Thanks!</span>'}}}]},{name:'validate',type:'boolean',defaultValue:true,advanced:true},{name:'errorMessagePath',type:'text',advanced:true,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" }}'},{name:'errorMessage',type:'uiBlocks',hideFromUI:true,defaultValue:[{'@type':'@builder.io/sdk:Element',responsiveStyles:{large:{marginTop:'10px'}},bindings:{'component.options.text':'state.formErrorMessage || block.component.options.text'},component:{name:'Text',options:{text:'<span>Form submission error :( Please check your answers and try again</span>'}}}]},{name:'sendingMessage',type:'uiBlocks',hideFromUI:true,defaultValue:[{'@type':'@builder.io/sdk:Element',responsiveStyles:{large:{marginTop:'10px'}},component:{name:'Text',options:{text:'<span>Sending...</span>'}}}]},{name:'customHeaders',type:'map',valueType:{type:'string'},advanced:true,showIf:'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'}],noWrap:true,canHaveChildren:true,defaultChildren:[{'@type':'@builder.io/sdk:Element',responsiveStyles:{large:{marginTop:'10px'}},component:{name:'Text',options:{text:'<span>Enter your name</span>'}}},{'@type':'@builder.io/sdk:Element',responsiveStyles:{large:{marginTop:'10px'}},component:{name:'Form:Input',options:{name:'name',placeholder:'Jane Doe'}}},{'@type':'@builder.io/sdk:Element',responsiveStyles:{large:{marginTop:'10px'}},component:{name:'Text',options:{text:'<span>Enter your email</span>'}}},{'@type':'@builder.io/sdk:Element',responsiveStyles:{large:{marginTop:'10px'}},component:{name:'Form:Input',options:{name:'email',placeholder:'jane@doe.com'}}},{'@type':'@builder.io/sdk:Element',responsiveStyles:{large:{marginTop:'10px'}},component:{name:'Form:SubmitButton',options:{text:'Submit'}}}]});
|
package/src/blocks/fragment.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { template as _$template } from "solid-js/web";
|
|
2
|
-
import { insert as _$insert } from "solid-js/web";
|
|
3
|
-
|
|
4
|
-
const _tmpl$ = /*#__PURE__*/_$template(`<span></span>`, 2);
|
|
5
|
-
|
|
6
|
-
export default function FragmentComponent(props) {
|
|
7
|
-
return (() => {
|
|
8
|
-
const _el$ = _tmpl$.cloneNode(true);
|
|
9
|
-
|
|
10
|
-
_$insert(_el$, () => props.children);
|
|
11
|
-
|
|
12
|
-
return _el$;
|
|
13
|
-
})();
|
|
14
|
-
}import { registerComponent } from '../functions/register-component';
|
|
15
|
-
registerComponent(FragmentComponent, {name:'Fragment',static:true,hidden:true,builtIn:true,canHaveChildren:true,noWrap:true});
|
package/src/blocks/image.js
DELETED
|
@@ -1,211 +0,0 @@
|
|
|
1
|
-
import { template as _$template } from "solid-js/web";
|
|
2
|
-
import { insert as _$insert } from "solid-js/web";
|
|
3
|
-
import { createComponent as _$createComponent } from "solid-js/web";
|
|
4
|
-
import { setAttribute as _$setAttribute } from "solid-js/web";
|
|
5
|
-
import { effect as _$effect } from "solid-js/web";
|
|
6
|
-
import { memo as _$memo } from "solid-js/web";
|
|
7
|
-
|
|
8
|
-
const _tmpl$ = /*#__PURE__*/_$template(`<source type="image/webp">`, 1),
|
|
9
|
-
_tmpl$2 = /*#__PURE__*/_$template(`<div> </div>`, 2),
|
|
10
|
-
_tmpl$3 = /*#__PURE__*/_$template(`<div></div>`, 2),
|
|
11
|
-
_tmpl$4 = /*#__PURE__*/_$template(`<div><picture><img loading="lazy"></picture></div>`, 5);
|
|
12
|
-
|
|
13
|
-
import { Show } from "solid-js";
|
|
14
|
-
import { createMutable } from "solid-js/store";
|
|
15
|
-
import { css } from "solid-styled-components";
|
|
16
|
-
export default function Image(props) {
|
|
17
|
-
const state = createMutable({
|
|
18
|
-
updateQueryParam: function updateQueryParam(uri = "", key, value) {
|
|
19
|
-
const re = new RegExp("([?&])" + key + "=.*?(&|$)", "i");
|
|
20
|
-
const separator = uri.indexOf("?") !== -1 ? "&" : "?";
|
|
21
|
-
|
|
22
|
-
if (uri.match(re)) {
|
|
23
|
-
return uri.replace(re, "$1" + key + "=" + encodeURIComponent(value) + "$2");
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
return uri + separator + key + "=" + encodeURIComponent(value);
|
|
27
|
-
},
|
|
28
|
-
removeProtocol: function removeProtocol(path) {
|
|
29
|
-
return path.replace(/http(s)?:/, "");
|
|
30
|
-
},
|
|
31
|
-
getShopifyImageUrl: function getShopifyImageUrl(src, size) {
|
|
32
|
-
if (!src || !src?.match(/cdn\.shopify\.com/) || !size) {
|
|
33
|
-
return src;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
if (size === "master") {
|
|
37
|
-
return state.removeProtocol(src);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
const match = src.match(/(_\d+x(\d+)?)?(\.(jpg|jpeg|gif|png|bmp|bitmap|tiff|tif)(\?v=\d+)?)/i);
|
|
41
|
-
|
|
42
|
-
if (match) {
|
|
43
|
-
const prefix = src.split(match[0]);
|
|
44
|
-
const suffix = match[3];
|
|
45
|
-
const useSize = size.match("x") ? size : `${size}x`;
|
|
46
|
-
return state.removeProtocol(`${prefix[0]}_${useSize}${suffix}`);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
return null;
|
|
50
|
-
},
|
|
51
|
-
getSrcSet: function getSrcSet(url) {
|
|
52
|
-
if (!url) {
|
|
53
|
-
return url;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
const sizes = [100, 200, 400, 800, 1200, 1600, 2000];
|
|
57
|
-
|
|
58
|
-
if (url.match(/builder\.io/)) {
|
|
59
|
-
let srcUrl = url;
|
|
60
|
-
const widthInSrc = Number(url.split("?width=")[1]);
|
|
61
|
-
|
|
62
|
-
if (!isNaN(widthInSrc)) {
|
|
63
|
-
srcUrl = `${srcUrl} ${widthInSrc}w`;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
return sizes.filter(size => size !== widthInSrc).map(size => `${state.updateQueryParam(url, "width", size)} ${size}w`).concat([srcUrl]).join(", ");
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
if (url.match(/cdn\.shopify\.com/)) {
|
|
70
|
-
return sizes.map(size => [state.getShopifyImageUrl(url, `${size}x${size}`), size]).filter(([sizeUrl]) => !!sizeUrl).map(([sizeUrl, size]) => `${sizeUrl} ${size}w`).concat([url]).join(", ");
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
return url;
|
|
74
|
-
},
|
|
75
|
-
useSrcSet: function useSrcSet() {
|
|
76
|
-
return props.srcset || state.getSrcSet(props.image) || "";
|
|
77
|
-
}
|
|
78
|
-
});
|
|
79
|
-
return (() => {
|
|
80
|
-
const _el$ = _tmpl$4.cloneNode(true),
|
|
81
|
-
_el$2 = _el$.firstChild,
|
|
82
|
-
_el$3 = _el$2.firstChild;
|
|
83
|
-
|
|
84
|
-
_$insert(_el$2, _$createComponent(Show, {
|
|
85
|
-
get when() {
|
|
86
|
-
return _$memo(() => !!!props.noWebp, true)() && state.useSrcSet().includes("builder.io");
|
|
87
|
-
},
|
|
88
|
-
|
|
89
|
-
get children() {
|
|
90
|
-
const _el$4 = _tmpl$.cloneNode(true);
|
|
91
|
-
|
|
92
|
-
_$effect(() => _$setAttribute(_el$4, "srcset", state.useSrcSet().replace(/\?/g, "?format=webp&")));
|
|
93
|
-
|
|
94
|
-
return _el$4;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
}), null);
|
|
98
|
-
|
|
99
|
-
_$insert(_el$, _$createComponent(Show, {
|
|
100
|
-
get when() {
|
|
101
|
-
return props.aspectRatio && !(props.fitContent && props.builderBlock?.children?.length);
|
|
102
|
-
},
|
|
103
|
-
|
|
104
|
-
get children() {
|
|
105
|
-
const _el$5 = _tmpl$2.cloneNode(true);
|
|
106
|
-
|
|
107
|
-
_$effect(_p$ => {
|
|
108
|
-
const _v$ = css({
|
|
109
|
-
width: "100%",
|
|
110
|
-
pointerEvents: "none",
|
|
111
|
-
fontSize: "0"
|
|
112
|
-
}),
|
|
113
|
-
_v$2 = props.aspectRatio * 100 + "%";
|
|
114
|
-
|
|
115
|
-
_v$ !== _p$._v$ && (_el$5.className = _p$._v$ = _v$);
|
|
116
|
-
_v$2 !== _p$._v$2 && _el$5.style.setProperty("padding-top", _p$._v$2 = _v$2);
|
|
117
|
-
return _p$;
|
|
118
|
-
}, {
|
|
119
|
-
_v$: undefined,
|
|
120
|
-
_v$2: undefined
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
return _el$5;
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
}), null);
|
|
127
|
-
|
|
128
|
-
_$insert(_el$, _$createComponent(Show, {
|
|
129
|
-
get when() {
|
|
130
|
-
return props.builderBlock?.children?.length && props.fitContent;
|
|
131
|
-
},
|
|
132
|
-
|
|
133
|
-
get children() {
|
|
134
|
-
return props.children;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
}), null);
|
|
138
|
-
|
|
139
|
-
_$insert(_el$, _$createComponent(Show, {
|
|
140
|
-
get when() {
|
|
141
|
-
return !props.fitContent;
|
|
142
|
-
},
|
|
143
|
-
|
|
144
|
-
get children() {
|
|
145
|
-
const _el$6 = _tmpl$3.cloneNode(true);
|
|
146
|
-
|
|
147
|
-
_$insert(_el$6, () => props.children);
|
|
148
|
-
|
|
149
|
-
_$effect(() => _el$6.className = css({
|
|
150
|
-
display: "flex",
|
|
151
|
-
flexDirection: "column",
|
|
152
|
-
alignItems: "stretch",
|
|
153
|
-
position: "absolute",
|
|
154
|
-
top: "0",
|
|
155
|
-
left: "0",
|
|
156
|
-
width: "100%",
|
|
157
|
-
height: "100%"
|
|
158
|
-
}));
|
|
159
|
-
|
|
160
|
-
return _el$6;
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
}), null);
|
|
164
|
-
|
|
165
|
-
_$effect(_p$ => {
|
|
166
|
-
const _v$3 = css({
|
|
167
|
-
position: "relative"
|
|
168
|
-
}),
|
|
169
|
-
_v$4 = "builder-image" + (props.class ? " " + props.class : "") + " " + css({
|
|
170
|
-
opacity: "1",
|
|
171
|
-
transition: "opacity 0.2s ease-in-out",
|
|
172
|
-
position: "absolute",
|
|
173
|
-
height: "100%",
|
|
174
|
-
width: "100%",
|
|
175
|
-
top: "0px",
|
|
176
|
-
left: "0px"
|
|
177
|
-
}),
|
|
178
|
-
_v$5 = props.altText,
|
|
179
|
-
_v$6 = props.altText ? "presentation" : undefined,
|
|
180
|
-
_v$7 = props.backgroundSize || "center",
|
|
181
|
-
_v$8 = props.backgroundSize || "cover",
|
|
182
|
-
_v$9 = props.image,
|
|
183
|
-
_v$10 = props.srcset || state.getSrcSet(props.image),
|
|
184
|
-
_v$11 = props.sizes;
|
|
185
|
-
|
|
186
|
-
_v$3 !== _p$._v$3 && (_el$.className = _p$._v$3 = _v$3);
|
|
187
|
-
_v$4 !== _p$._v$4 && (_el$3.className = _p$._v$4 = _v$4);
|
|
188
|
-
_v$5 !== _p$._v$5 && _$setAttribute(_el$3, "alt", _p$._v$5 = _v$5);
|
|
189
|
-
_v$6 !== _p$._v$6 && _$setAttribute(_el$3, "aria-role", _p$._v$6 = _v$6);
|
|
190
|
-
_v$7 !== _p$._v$7 && _el$3.style.setProperty("object-position", _p$._v$7 = _v$7);
|
|
191
|
-
_v$8 !== _p$._v$8 && _el$3.style.setProperty("object-fit", _p$._v$8 = _v$8);
|
|
192
|
-
_v$9 !== _p$._v$9 && _$setAttribute(_el$3, "src", _p$._v$9 = _v$9);
|
|
193
|
-
_v$10 !== _p$._v$10 && _$setAttribute(_el$3, "srcset", _p$._v$10 = _v$10);
|
|
194
|
-
_v$11 !== _p$._v$11 && _$setAttribute(_el$3, "sizes", _p$._v$11 = _v$11);
|
|
195
|
-
return _p$;
|
|
196
|
-
}, {
|
|
197
|
-
_v$3: undefined,
|
|
198
|
-
_v$4: undefined,
|
|
199
|
-
_v$5: undefined,
|
|
200
|
-
_v$6: undefined,
|
|
201
|
-
_v$7: undefined,
|
|
202
|
-
_v$8: undefined,
|
|
203
|
-
_v$9: undefined,
|
|
204
|
-
_v$10: undefined,
|
|
205
|
-
_v$11: undefined
|
|
206
|
-
});
|
|
207
|
-
|
|
208
|
-
return _el$;
|
|
209
|
-
})();
|
|
210
|
-
}import { registerComponent } from '../functions/register-component';
|
|
211
|
-
registerComponent(Image, {name:'Image',static:true,builtIn:true,image:'https://firebasestorage.googleapis.com/v0/b/builder-3b0a2.appspot.com/o/images%2Fbaseline-insert_photo-24px.svg?alt=media&token=4e5d0ef4-f5e8-4e57-b3a9-38d63a9b9dc4',defaultStyles:{position:'relative',minHeight:'20px',minWidth:'20px',overflow:'hidden'},canHaveChildren:true,inputs:[{name:'image',type:'file',bubble:true,allowedFileTypes:['jpeg','jpg','png','svg'],required:true,defaultValue:'https://cdn.builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d',onChange:" const DEFAULT_ASPECT_RATIO = 0.7041; options.delete('srcset'); options.delete('noWebp'); function loadImage(url, timeout) { return new Promise((resolve, reject) => { const img = document.createElement('img'); let loaded = false; img.onload = () => { loaded = true; resolve(img); }; img.addEventListener('error', event => { console.warn('Image load failed', event.error); reject(event.error); }); img.src = url; setTimeout(() => { if (!loaded) { reject(new Error('Image load timed out')); } }, timeout); }); } function round(num) { return Math.round(num * 1000) / 1000; } const value = options.get('image'); const aspectRatio = options.get('aspectRatio'); // For SVG images - don't render as webp, keep them as SVG fetch(value) .then(res => res.blob()) .then(blob => { if (blob.type.includes('svg')) { options.set('noWebp', true); } }); if (value && (!aspectRatio || aspectRatio === DEFAULT_ASPECT_RATIO)) { return loadImage(value).then(img => { const possiblyUpdatedAspectRatio = options.get('aspectRatio'); if ( options.get('image') === value && (!possiblyUpdatedAspectRatio || possiblyUpdatedAspectRatio === DEFAULT_ASPECT_RATIO) ) { if (img.width && img.height) { options.set('aspectRatio', round(img.height / img.width)); options.set('height', img.height); options.set('width', img.width); } } }); }"},{name:'backgroundSize',type:'text',defaultValue:'cover',enum:[{label:'contain',value:'contain',helperText:'The image should never get cropped'},{label:'cover',value:'cover',helperText:"The image should fill it's box, cropping when needed"}]},{name:'backgroundPosition',type:'text',defaultValue:'center',enum:['center','top','left','right','bottom','top left','top right','bottom left','bottom right']},{name:'altText',type:'string',helperText:'Text to display when the user has images off'},{name:'height',type:'number',hideFromUI:true},{name:'width',type:'number',hideFromUI:true},{name:'sizes',type:'string',hideFromUI:true},{name:'srcset',type:'string',hideFromUI:true},{name:'lazy',type:'boolean',defaultValue:true,hideFromUI:true},{name:'fitContent',type:'boolean',helperText:"When child blocks are provided, fit to them instead of using the image's aspect ratio",defaultValue:true},{name:'aspectRatio',type:'number',helperText:"This is the ratio of height/width, e.g. set to 1.5 for a 300px wide and 200px tall photo. Set to 0 to not force the image to maintain it's aspect ratio",advanced:true,defaultValue:0.7041}]});
|