@builder.io/sdk-qwik 0.0.8 → 0.0.11

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 (106) hide show
  1. package/README.md +65 -2
  2. package/lib/index.qwik.cjs +259 -216
  3. package/lib/index.qwik.mjs +260 -217
  4. package/package.json +4 -4
  5. package/src/blocks/button/button.jsx +22 -0
  6. package/src/blocks/button/component-info.js +41 -0
  7. package/src/blocks/columns/columns.jsx +97 -0
  8. package/src/blocks/columns/component-info.js +242 -0
  9. package/src/blocks/custom-code/component-info.js +31 -0
  10. package/src/blocks/custom-code/custom-code.jsx +71 -0
  11. package/src/blocks/embed/component-info.js +44 -0
  12. package/src/blocks/embed/embed.jsx +63 -0
  13. package/src/blocks/embed/helpers.js +9 -0
  14. package/src/blocks/form/builder-blocks.jsx +11 -0
  15. package/src/blocks/form/component-info.js +262 -0
  16. package/src/blocks/form/form.jsx +303 -0
  17. package/src/blocks/fragment/component-info.js +11 -0
  18. package/src/blocks/fragment/fragment.jsx +11 -0
  19. package/src/blocks/image/component-info.js +151 -0
  20. package/src/blocks/image/image.helpers.js +48 -0
  21. package/src/blocks/image/image.jsx +110 -0
  22. package/src/blocks/img/component-info.js +20 -0
  23. package/src/blocks/img/img.jsx +19 -0
  24. package/src/blocks/input/component-info.js +74 -0
  25. package/src/blocks/input/input.jsx +21 -0
  26. package/src/blocks/raw-text/component-info.js +16 -0
  27. package/src/blocks/raw-text/raw-text.jsx +12 -0
  28. package/src/blocks/section/component-info.js +49 -0
  29. package/src/blocks/section/section.jsx +20 -0
  30. package/src/blocks/select/component-info.js +59 -0
  31. package/src/blocks/select/select.jsx +24 -0
  32. package/src/blocks/submit-button/component-info.js +28 -0
  33. package/src/blocks/submit-button/submit-button.jsx +11 -0
  34. package/src/blocks/symbol/component-info.js +43 -0
  35. package/src/blocks/symbol/symbol.jsx +77 -0
  36. package/src/blocks/text/component-info.js +24 -0
  37. package/src/blocks/text/text.jsx +7 -0
  38. package/src/blocks/textarea/component-info.js +47 -0
  39. package/src/blocks/textarea/textarea.jsx +15 -0
  40. package/src/blocks/util.js +7 -0
  41. package/src/blocks/video/component-info.js +106 -0
  42. package/src/blocks/video/video.jsx +53 -0
  43. package/src/components/render-block/block-styles.jsx +60 -0
  44. package/src/components/render-block/render-block.helpers.js +23 -0
  45. package/src/components/render-block/render-block.jsx +221 -0
  46. package/src/components/render-block/render-component.jsx +34 -0
  47. package/src/components/render-block/render-repeated-block.jsx +37 -0
  48. package/src/components/render-block/types.js +0 -0
  49. package/src/components/render-blocks.jsx +93 -0
  50. package/src/components/render-content/components/render-styles.jsx +76 -0
  51. package/src/components/render-content/index.js +4 -0
  52. package/src/components/render-content/render-content.jsx +351 -0
  53. package/src/components/render-inlined-styles.jsx +25 -0
  54. package/src/constants/builder-registered-components.js +48 -0
  55. package/src/constants/device-sizes.js +21 -0
  56. package/src/constants/target.js +4 -0
  57. package/src/context/builder.context.js +5 -0
  58. package/src/functions/camel-to-kebab-case.js +4 -0
  59. package/src/functions/convert-style-object.js +6 -0
  60. package/src/functions/evaluate.js +28 -0
  61. package/src/functions/event-handler-name.js +7 -0
  62. package/src/functions/get-block-actions.js +23 -0
  63. package/src/functions/get-block-component-options.js +28 -0
  64. package/src/functions/get-block-properties.js +29 -0
  65. package/src/functions/get-block-styles.js +34 -0
  66. package/src/functions/get-block-tag.js +6 -0
  67. package/src/functions/get-builder-search-params/fn.test.js +13 -0
  68. package/src/functions/get-builder-search-params/index.js +33 -0
  69. package/src/functions/get-content/ab-testing.js +38 -0
  70. package/src/functions/get-content/fn.test.js +31 -0
  71. package/src/functions/get-content/index.js +96 -0
  72. package/src/functions/get-content/types.js +0 -0
  73. package/src/functions/get-fetch.js +34 -0
  74. package/src/functions/get-global-this.js +18 -0
  75. package/src/functions/get-processed-block.js +53 -0
  76. package/src/functions/get-processed-block.test.js +32 -0
  77. package/src/functions/if-target.js +15 -0
  78. package/src/functions/is-browser.js +6 -0
  79. package/src/functions/is-editing.js +7 -0
  80. package/src/functions/is-iframe.js +7 -0
  81. package/src/functions/is-previewing.js +14 -0
  82. package/src/functions/on-change.js +27 -0
  83. package/src/functions/on-change.test.js +19 -0
  84. package/src/functions/register-component.js +72 -0
  85. package/src/functions/register.js +29 -0
  86. package/src/functions/sanitize-styles.js +5 -0
  87. package/src/functions/set-editor-settings.js +15 -0
  88. package/src/functions/set.js +11 -0
  89. package/src/functions/set.test.js +16 -0
  90. package/src/functions/track.js +22 -0
  91. package/src/functions/transform-block.js +6 -0
  92. package/src/helpers/css.js +12 -0
  93. package/src/helpers/flatten.js +34 -0
  94. package/src/index-helpers/blocks-exports.js +22 -0
  95. package/src/index-helpers/top-of-file.js +4 -0
  96. package/src/index.js +10 -0
  97. package/src/scripts/init-editing.js +79 -0
  98. package/src/types/builder-block.js +0 -0
  99. package/src/types/builder-content.js +0 -0
  100. package/src/types/components.js +0 -0
  101. package/src/types/deep-partial.js +0 -0
  102. package/src/types/element.js +0 -0
  103. package/src/types/targets.js +0 -0
  104. package/src/types/typescript.js +0 -0
  105. package/types.d.ts +7 -12
  106. package/root.json +0 -1176
@@ -0,0 +1,262 @@
1
+ const componentInfo = {
2
+ name: "Form:Form",
3
+ builtIn: true,
4
+ defaults: {
5
+ responsiveStyles: {
6
+ large: {
7
+ marginTop: "15px",
8
+ paddingBottom: "15px"
9
+ }
10
+ }
11
+ },
12
+ image: "https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2Fef36d2a846134910b64b88e6d18c5ca5",
13
+ inputs: [
14
+ {
15
+ name: "sendSubmissionsTo",
16
+ type: "string",
17
+ enum: [
18
+ {
19
+ label: "Send to email",
20
+ value: "email",
21
+ helperText: "Send form submissions to the email address of your choosing"
22
+ },
23
+ {
24
+ label: "Custom",
25
+ value: "custom",
26
+ helperText: "Handle where the form requests go manually with a little code, e.g. to your own custom backend"
27
+ }
28
+ ],
29
+ defaultValue: "email"
30
+ },
31
+ {
32
+ name: "sendSubmissionsToEmail",
33
+ type: "string",
34
+ required: true,
35
+ defaultValue: "your@email.com",
36
+ showIf: 'options.get("sendSubmissionsTo") === "email"'
37
+ },
38
+ {
39
+ name: "sendWithJs",
40
+ type: "boolean",
41
+ helperText: "Set to false to use basic html form action",
42
+ defaultValue: true,
43
+ showIf: 'options.get("sendSubmissionsTo") === "custom"'
44
+ },
45
+ {
46
+ name: "name",
47
+ type: "string",
48
+ defaultValue: "My form"
49
+ },
50
+ {
51
+ name: "action",
52
+ type: "string",
53
+ helperText: "URL to send the form data to",
54
+ showIf: 'options.get("sendSubmissionsTo") === "custom"'
55
+ },
56
+ {
57
+ name: "contentType",
58
+ type: "string",
59
+ defaultValue: "application/json",
60
+ advanced: true,
61
+ enum: [
62
+ "application/json",
63
+ "multipart/form-data",
64
+ "application/x-www-form-urlencoded"
65
+ ],
66
+ showIf: 'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'
67
+ },
68
+ {
69
+ name: "method",
70
+ type: "string",
71
+ showIf: 'options.get("sendSubmissionsTo") === "custom"',
72
+ defaultValue: "POST",
73
+ advanced: true
74
+ },
75
+ {
76
+ name: "previewState",
77
+ type: "string",
78
+ enum: ["unsubmitted", "sending", "success", "error"],
79
+ defaultValue: "unsubmitted",
80
+ helperText: 'Choose a state to edit, e.g. choose "success" to show what users see on success and edit the message',
81
+ showIf: 'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'
82
+ },
83
+ {
84
+ name: "successUrl",
85
+ type: "url",
86
+ helperText: "Optional URL to redirect the user to on form submission success",
87
+ showIf: 'options.get("sendSubmissionsTo") !== "zapier" && options.get("sendWithJs") === true'
88
+ },
89
+ {
90
+ name: "resetFormOnSubmit",
91
+ type: "boolean",
92
+ showIf: "options.get('sendSubmissionsTo') === 'custom' && options.get('sendWithJs') === true",
93
+ advanced: true
94
+ },
95
+ {
96
+ name: "successMessage",
97
+ type: "uiBlocks",
98
+ hideFromUI: true,
99
+ defaultValue: [
100
+ {
101
+ "@type": "@builder.io/sdk:Element",
102
+ responsiveStyles: {
103
+ large: {
104
+ marginTop: "10px"
105
+ }
106
+ },
107
+ component: {
108
+ name: "Text",
109
+ options: {
110
+ text: "<span>Thanks!</span>"
111
+ }
112
+ }
113
+ }
114
+ ]
115
+ },
116
+ {
117
+ name: "validate",
118
+ type: "boolean",
119
+ defaultValue: true,
120
+ advanced: true
121
+ },
122
+ {
123
+ name: "errorMessagePath",
124
+ type: "text",
125
+ advanced: true,
126
+ 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" }}'
127
+ },
128
+ {
129
+ name: "errorMessage",
130
+ type: "uiBlocks",
131
+ hideFromUI: true,
132
+ defaultValue: [
133
+ {
134
+ "@type": "@builder.io/sdk:Element",
135
+ responsiveStyles: {
136
+ large: {
137
+ marginTop: "10px"
138
+ }
139
+ },
140
+ bindings: {
141
+ "component.options.text": "state.formErrorMessage || block.component.options.text"
142
+ },
143
+ component: {
144
+ name: "Text",
145
+ options: {
146
+ text: "<span>Form submission error :( Please check your answers and try again</span>"
147
+ }
148
+ }
149
+ }
150
+ ]
151
+ },
152
+ {
153
+ name: "sendingMessage",
154
+ type: "uiBlocks",
155
+ hideFromUI: true,
156
+ defaultValue: [
157
+ {
158
+ "@type": "@builder.io/sdk:Element",
159
+ responsiveStyles: {
160
+ large: {
161
+ marginTop: "10px"
162
+ }
163
+ },
164
+ component: {
165
+ name: "Text",
166
+ options: {
167
+ text: "<span>Sending...</span>"
168
+ }
169
+ }
170
+ }
171
+ ]
172
+ },
173
+ {
174
+ name: "customHeaders",
175
+ type: "map",
176
+ valueType: {
177
+ type: "string"
178
+ },
179
+ advanced: true,
180
+ showIf: 'options.get("sendSubmissionsTo") === "custom" && options.get("sendWithJs") === true'
181
+ }
182
+ ],
183
+ noWrap: true,
184
+ canHaveChildren: true,
185
+ defaultChildren: [
186
+ {
187
+ "@type": "@builder.io/sdk:Element",
188
+ responsiveStyles: {
189
+ large: {
190
+ marginTop: "10px"
191
+ }
192
+ },
193
+ component: {
194
+ name: "Text",
195
+ options: {
196
+ text: "<span>Enter your name</span>"
197
+ }
198
+ }
199
+ },
200
+ {
201
+ "@type": "@builder.io/sdk:Element",
202
+ responsiveStyles: {
203
+ large: {
204
+ marginTop: "10px"
205
+ }
206
+ },
207
+ component: {
208
+ name: "Form:Input",
209
+ options: {
210
+ name: "name",
211
+ placeholder: "Jane Doe"
212
+ }
213
+ }
214
+ },
215
+ {
216
+ "@type": "@builder.io/sdk:Element",
217
+ responsiveStyles: {
218
+ large: {
219
+ marginTop: "10px"
220
+ }
221
+ },
222
+ component: {
223
+ name: "Text",
224
+ options: {
225
+ text: "<span>Enter your email</span>"
226
+ }
227
+ }
228
+ },
229
+ {
230
+ "@type": "@builder.io/sdk:Element",
231
+ responsiveStyles: {
232
+ large: {
233
+ marginTop: "10px"
234
+ }
235
+ },
236
+ component: {
237
+ name: "Form:Input",
238
+ options: {
239
+ name: "email",
240
+ placeholder: "jane@doe.com"
241
+ }
242
+ }
243
+ },
244
+ {
245
+ "@type": "@builder.io/sdk:Element",
246
+ responsiveStyles: {
247
+ large: {
248
+ marginTop: "10px"
249
+ }
250
+ },
251
+ component: {
252
+ name: "Form:SubmitButton",
253
+ options: {
254
+ text: "Submit"
255
+ }
256
+ }
257
+ }
258
+ ]
259
+ };
260
+ export {
261
+ componentInfo
262
+ };
@@ -0,0 +1,303 @@
1
+ // GENERATED BY MITOSIS
2
+
3
+ import RenderBlock from "../../components/render-block/render-block";
4
+ import { isEditing } from "../../functions/is-editing.js";
5
+ import BuilderBlocks from "./builder-blocks";
6
+ import {
7
+ Fragment,
8
+ component$,
9
+ h,
10
+ useContext,
11
+ useRef,
12
+ useStore,
13
+ useStylesScoped$,
14
+ } from "@builder.io/qwik";
15
+ export const submissionState = function submissionState(
16
+ props,
17
+ state,
18
+ formRef,
19
+ builderContext
20
+ ) {
21
+ return (isEditing() && props.previewState) || state.formState;
22
+ };
23
+ export const onSubmit = function onSubmit(
24
+ props,
25
+ state,
26
+ formRef,
27
+ builderContext,
28
+ event
29
+ ) {
30
+ const sendWithJs = props.sendWithJs || props.sendSubmissionsTo === "email";
31
+
32
+ if (props.sendSubmissionsTo === "zapier") {
33
+ event.preventDefault();
34
+ } else if (sendWithJs) {
35
+ if (!(props.action || props.sendSubmissionsTo === "email")) {
36
+ event.preventDefault();
37
+ return;
38
+ }
39
+
40
+ event.preventDefault();
41
+ const el = event.currentTarget;
42
+ const headers = props.customHeaders || {};
43
+ let body;
44
+ const formData = new FormData(el); // TODO: maybe support null
45
+
46
+ const formPairs = Array.from(
47
+ event.currentTarget.querySelectorAll("input,select,textarea")
48
+ )
49
+ .filter((el) => !!el.name)
50
+ .map((el) => {
51
+ let value;
52
+ const key = el.name;
53
+
54
+ if (el instanceof HTMLInputElement) {
55
+ if (el.type === "radio") {
56
+ if (el.checked) {
57
+ value = el.name;
58
+ return {
59
+ key,
60
+ value,
61
+ };
62
+ }
63
+ } else if (el.type === "checkbox") {
64
+ value = el.checked;
65
+ } else if (el.type === "number" || el.type === "range") {
66
+ const num = el.valueAsNumber;
67
+
68
+ if (!isNaN(num)) {
69
+ value = num;
70
+ }
71
+ } else if (el.type === "file") {
72
+ // TODO: one vs multiple files
73
+ value = el.files;
74
+ } else {
75
+ value = el.value;
76
+ }
77
+ } else {
78
+ value = el.value;
79
+ }
80
+
81
+ return {
82
+ key,
83
+ value,
84
+ };
85
+ });
86
+ let contentType = props.contentType;
87
+
88
+ if (props.sendSubmissionsTo === "email") {
89
+ contentType = "multipart/form-data";
90
+ }
91
+
92
+ Array.from(formPairs).forEach(({ value }) => {
93
+ if (
94
+ value instanceof File ||
95
+ (Array.isArray(value) && value[0] instanceof File) ||
96
+ value instanceof FileList
97
+ ) {
98
+ contentType = "multipart/form-data";
99
+ }
100
+ }); // TODO: send as urlEncoded or multipart by default
101
+ // because of ease of use and reliability in browser API
102
+ // for encoding the form?
103
+
104
+ if (contentType !== "application/json") {
105
+ body = formData;
106
+ } else {
107
+ // Json
108
+ const json = {};
109
+ Array.from(formPairs).forEach(({ value, key }) => {
110
+ set(json, key, value);
111
+ });
112
+ body = JSON.stringify(json);
113
+ }
114
+
115
+ if (contentType && contentType !== "multipart/form-data") {
116
+ if (
117
+ /* Zapier doesn't allow content-type header to be sent from browsers */
118
+ !(sendWithJs && props.action?.includes("zapier.com"))
119
+ ) {
120
+ headers["content-type"] = contentType;
121
+ }
122
+ }
123
+
124
+ const presubmitEvent = new CustomEvent("presubmit", {
125
+ detail: {
126
+ body,
127
+ },
128
+ });
129
+
130
+ if (formRef) {
131
+ formRef.dispatchEvent(presubmitEvent);
132
+
133
+ if (presubmitEvent.defaultPrevented) {
134
+ return;
135
+ }
136
+ }
137
+
138
+ state.formState = "sending";
139
+ const formUrl = `${
140
+ builder.env === "dev" ? "http://localhost:5000" : "https://builder.io"
141
+ }/api/v1/form-submit?apiKey=${builder.apiKey}&to=${btoa(
142
+ props.sendSubmissionsToEmail || ""
143
+ )}&name=${encodeURIComponent(props.name || "")}`;
144
+ fetch(
145
+ props.sendSubmissionsTo === "email" ? formUrl : props.action,
146
+ /* TODO: throw error if no action URL */
147
+ {
148
+ body,
149
+ headers,
150
+ method: props.method || "post",
151
+ }
152
+ ).then(
153
+ async (res) => {
154
+ let body;
155
+ const contentType = res.headers.get("content-type");
156
+
157
+ if (contentType && contentType.indexOf("application/json") !== -1) {
158
+ body = await res.json();
159
+ } else {
160
+ body = await res.text();
161
+ }
162
+
163
+ if (!res.ok && props.errorMessagePath) {
164
+ /* TODO: allow supplying an error formatter function */
165
+ let message = get(body, props.errorMessagePath);
166
+
167
+ if (message) {
168
+ if (typeof message !== "string") {
169
+ /* TODO: ideally convert json to yaml so it woul dbe like
170
+ error: - email has been taken */
171
+ message = JSON.stringify(message);
172
+ }
173
+
174
+ state.formErrorMessage = message;
175
+ }
176
+ }
177
+
178
+ state.responseData = body;
179
+ state.formState = res.ok ? "success" : "error";
180
+
181
+ if (res.ok) {
182
+ const submitSuccessEvent = new CustomEvent("submit:success", {
183
+ detail: {
184
+ res,
185
+ body,
186
+ },
187
+ });
188
+
189
+ if (formRef) {
190
+ formRef.dispatchEvent(submitSuccessEvent);
191
+
192
+ if (submitSuccessEvent.defaultPrevented) {
193
+ return;
194
+ }
195
+ /* TODO: option to turn this on/off? */
196
+
197
+ if (props.resetFormOnSubmit !== false) {
198
+ formRef.reset();
199
+ }
200
+ }
201
+ /* TODO: client side route event first that can be preventDefaulted */
202
+
203
+ if (props.successUrl) {
204
+ if (formRef) {
205
+ const event = new CustomEvent("route", {
206
+ detail: {
207
+ url: props.successUrl,
208
+ },
209
+ });
210
+ formRef.dispatchEvent(event);
211
+
212
+ if (!event.defaultPrevented) {
213
+ location.href = props.successUrl;
214
+ }
215
+ } else {
216
+ location.href = props.successUrl;
217
+ }
218
+ }
219
+ }
220
+ },
221
+ (err) => {
222
+ const submitErrorEvent = new CustomEvent("submit:error", {
223
+ detail: {
224
+ error: err,
225
+ },
226
+ });
227
+
228
+ if (formRef) {
229
+ formRef.dispatchEvent(submitErrorEvent);
230
+
231
+ if (submitErrorEvent.defaultPrevented) {
232
+ return;
233
+ }
234
+ }
235
+
236
+ state.responseData = err;
237
+ state.formState = "error";
238
+ }
239
+ );
240
+ }
241
+ };
242
+ export const FormComponent = component$((props) => {
243
+ useStylesScoped$(STYLES);
244
+ const builderContext = useContext(BuilderContext);
245
+ const formRef = useRef();
246
+ const state = useStore({
247
+ formState: "unsubmitted",
248
+ responseData: null,
249
+ formErrorMessage: "",
250
+ });
251
+ return (
252
+ <form
253
+ validate={props.validate}
254
+ ref={formRef}
255
+ action={(() => {
256
+ !props.sendWithJs && props.action;
257
+ })()}
258
+ method={props.method}
259
+ name={props.name}
260
+ onSubmit$={(event) =>
261
+ onSubmit(props, state, formRef, builderContext, event)
262
+ }
263
+ {...props.attributes}
264
+ >
265
+ {props.builderBlock && props.builderBlock.children
266
+ ? (props.builderBlock?.children || []).map((block) => {
267
+ return (
268
+ <RenderBlock block={block} context={builderContext}></RenderBlock>
269
+ );
270
+ })
271
+ : null}
272
+ {submissionState(props, state, formRef, builderContext) === "error" ? (
273
+ <BuilderBlocks
274
+ dataPath="errorMessage"
275
+ blocks={props.errorMessage}
276
+ ></BuilderBlocks>
277
+ ) : null}
278
+ {submissionState(props, state, formRef, builderContext) === "sending" ? (
279
+ <BuilderBlocks
280
+ dataPath="sendingMessage"
281
+ blocks={props.sendingMessage}
282
+ ></BuilderBlocks>
283
+ ) : null}
284
+ {submissionState(props, state, formRef, builderContext) === "error" &&
285
+ state.responseData ? (
286
+ <pre class="builder-form-error-text pre-FormComponent">
287
+ {JSON.stringify(state.responseData, null, 2)}
288
+ </pre>
289
+ ) : null}
290
+ {submissionState(props, state, formRef, builderContext) === "success" ? (
291
+ <BuilderBlocks
292
+ dataPath="successMessage"
293
+ blocks={props.successMessage}
294
+ ></BuilderBlocks>
295
+ ) : null}
296
+ </form>
297
+ );
298
+ });
299
+ export default FormComponent;
300
+ export const STYLES = `.pre-FormComponent {
301
+ padding: 10px;
302
+ color: red;
303
+ text-align: center; }`;
@@ -0,0 +1,11 @@
1
+ const componentInfo = {
2
+ name: "Fragment",
3
+ static: true,
4
+ hidden: true,
5
+ builtIn: true,
6
+ canHaveChildren: true,
7
+ noWrap: true
8
+ };
9
+ export {
10
+ componentInfo
11
+ };
@@ -0,0 +1,11 @@
1
+ // GENERATED BY MITOSIS
2
+
3
+ import { Fragment, Slot, component$, h } from "@builder.io/qwik";
4
+ export const FragmentComponent = component$((props) => {
5
+ return (
6
+ <span>
7
+ <Slot></Slot>
8
+ </span>
9
+ );
10
+ });
11
+ export default FragmentComponent;