@builder.io/sdk-qwik 0.0.8 → 0.0.9

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 +104 -7
  3. package/lib/index.qwik.mjs +104 -7
  4. package/package.json +1 -1
  5. package/src/blocks/button/button.jsx +197 -0
  6. package/src/blocks/button/component-info.js +41 -0
  7. package/src/blocks/columns/columns.jsx +267 -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 +130 -0
  11. package/src/blocks/embed/component-info.js +44 -0
  12. package/src/blocks/embed/embed.jsx +130 -0
  13. package/src/blocks/embed/helpers.js +9 -0
  14. package/src/blocks/form/builder-blocks.jsx +86 -0
  15. package/src/blocks/form/component-info.js +262 -0
  16. package/src/blocks/form/form.jsx +782 -0
  17. package/src/blocks/fragment/component-info.js +11 -0
  18. package/src/blocks/fragment/fragment.jsx +59 -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 +554 -0
  22. package/src/blocks/img/component-info.js +20 -0
  23. package/src/blocks/img/img.jsx +76 -0
  24. package/src/blocks/input/component-info.js +74 -0
  25. package/src/blocks/input/input.jsx +87 -0
  26. package/src/blocks/raw-text/component-info.js +16 -0
  27. package/src/blocks/raw-text/raw-text.jsx +53 -0
  28. package/src/blocks/section/component-info.js +49 -0
  29. package/src/blocks/section/section.jsx +97 -0
  30. package/src/blocks/select/component-info.js +59 -0
  31. package/src/blocks/select/select.jsx +149 -0
  32. package/src/blocks/submit-button/component-info.js +28 -0
  33. package/src/blocks/submit-button/submit-button.jsx +87 -0
  34. package/src/blocks/symbol/component-info.js +43 -0
  35. package/src/blocks/symbol/symbol.jsx +211 -0
  36. package/src/blocks/text/component-info.js +24 -0
  37. package/src/blocks/text/text.jsx +46 -0
  38. package/src/blocks/textarea/component-info.js +47 -0
  39. package/src/blocks/textarea/textarea.jsx +65 -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 +103 -0
  43. package/src/components/render-block/block-styles.jsx +174 -0
  44. package/src/components/render-block/render-block.helpers.js +23 -0
  45. package/src/components/render-block/render-block.jsx +733 -0
  46. package/src/components/render-block/render-component.jsx +245 -0
  47. package/src/components/render-block/render-repeated-block.jsx +104 -0
  48. package/src/components/render-block/types.js +0 -0
  49. package/src/components/render-blocks.jsx +387 -0
  50. package/src/components/render-content/components/render-styles.jsx +126 -0
  51. package/src/components/render-content/index.js +4 -0
  52. package/src/components/render-content/render-content.jsx +650 -0
  53. package/src/components/render-inlined-styles.jsx +141 -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,267 @@
1
+ // GENERATED BY MITOSIS
2
+
3
+ import RenderBlocks from "../../components/render-blocks";
4
+ import {
5
+ Fragment,
6
+ Host,
7
+ component$,
8
+ h,
9
+ useStylesScoped$,
10
+ } from "@builder.io/qwik";
11
+ export const getGutterSize = function getGutterSize(props, state) {
12
+ return typeof props.space === "number" ? props.space || 0 : 20;
13
+ };
14
+ export const getColumns = function getColumns(props, state) {
15
+ return props.columns || [];
16
+ };
17
+ export const getWidth = function getWidth(props, state, index) {
18
+ const columns = getColumns(props, state);
19
+ return columns[index]?.width || 100 / columns.length;
20
+ };
21
+ export const getColumnCssWidth = function getColumnCssWidth(
22
+ props,
23
+ state,
24
+ index
25
+ ) {
26
+ const columns = getColumns(props, state);
27
+ const gutterSize = getGutterSize(props, state);
28
+ const subtractWidth = (gutterSize * (columns.length - 1)) / columns.length;
29
+ return `calc(${getWidth(props, state, index)}% - ${subtractWidth}px)`;
30
+ };
31
+ export const maybeApplyForTablet = function maybeApplyForTablet(
32
+ props,
33
+ state,
34
+ prop
35
+ ) {
36
+ const _stackColumnsAt = props.stackColumnsAt || "tablet";
37
+
38
+ return _stackColumnsAt === "tablet" ? prop : "inherit";
39
+ };
40
+ export const columnsCssVars = function columnsCssVars(props, state) {
41
+ const flexDir =
42
+ props.stackColumnsAt === "never"
43
+ ? "inherit"
44
+ : props.reverseColumnsWhenStacked
45
+ ? "column-reverse"
46
+ : "column";
47
+ return {
48
+ "--flex-dir": flexDir,
49
+ "--flex-dir-tablet": maybeApplyForTablet(props, state, flexDir),
50
+ };
51
+ };
52
+ export const columnCssVars = function columnCssVars(props, state) {
53
+ const width = "100%";
54
+ const marginLeft = "0";
55
+ return {
56
+ "--column-width": width,
57
+ "--column-margin-left": marginLeft,
58
+ "--column-width-tablet": maybeApplyForTablet(props, state, width),
59
+ "--column-margin-left-tablet": maybeApplyForTablet(
60
+ props,
61
+ state,
62
+ marginLeft
63
+ ),
64
+ };
65
+ };
66
+ export const Columns = component$(
67
+ (props) => {
68
+ useStylesScoped$(STYLES);
69
+ const state = {};
70
+ return (
71
+ <Host
72
+ class="builder-columns div-Columns"
73
+ style={columnsCssVars(props, state)}
74
+ >
75
+ {(props.columns || []).map((column, index) => {
76
+ return (
77
+ <div
78
+ class="builder-column div-Columns-2"
79
+ style={{
80
+ width: getColumnCssWidth(props, state, index),
81
+ marginLeft: `${
82
+ index === 0 ? 0 : getGutterSize(props, state)
83
+ }px`,
84
+ ...columnCssVars(props, state),
85
+ }}
86
+ key={index}
87
+ >
88
+ <RenderBlocks blocks={column.blocks}></RenderBlocks>
89
+ </div>
90
+ );
91
+ })}
92
+ </Host>
93
+ );
94
+ },
95
+ { tagName: "div" }
96
+ );
97
+ export default Columns;
98
+ export const STYLES = `.div-Columns {
99
+ display: flex;
100
+ align-items: stretch;
101
+ line-height: normal; }@media (max-width: 999px) { .div-Columns {
102
+ flex-direction: var(--flex-dir-tablet); } }@media (max-width: 639px) { .div-Columns {
103
+ flex-direction: var(--flex-dir); } }.div-Columns-2 {
104
+ flex-grow: 1; }@media (max-width: 999px) { .div-Columns-2 {
105
+ width: var(--column-width-tablet) !important;
106
+ margin-left: var(--column-margin-left-tablet) !important; } }@media (max-width: 639px) { .div-Columns-2 {
107
+ width: var(--column-width) !important;
108
+ margin-left: var(--column-margin-left) !important; } }`;
109
+ export const COMPONENT = {
110
+ "@type": "@builder.io/mitosis/component",
111
+ imports: [
112
+ {
113
+ imports: {
114
+ RenderBlocks: "default",
115
+ },
116
+ path: "../../components/render-blocks.lite",
117
+ },
118
+ ],
119
+ exports: {},
120
+ inputs: [],
121
+ meta: {},
122
+ refs: {},
123
+ state: {
124
+ getGutterSize:
125
+ "@builder.io/mitosis/method:getGutterSize() {\n return typeof props.space === 'number' ? props.space || 0 : 20;\n}",
126
+ getColumns:
127
+ "@builder.io/mitosis/method:getColumns() {\n return props.columns || [];\n}",
128
+ getWidth:
129
+ "@builder.io/mitosis/method:getWidth(index: number) {\n const columns = getColumns(props,state,);\n return columns[index]?.width || 100 / columns.length;\n}",
130
+ getColumnCssWidth:
131
+ "@builder.io/mitosis/method:getColumnCssWidth(index: number) {\n const columns = getColumns(props,state,);\n const gutterSize = getGutterSize(props,state,);\n const subtractWidth = gutterSize * (columns.length - 1) / columns.length;\n return `calc(${getWidth(props,state,index)}% - ${subtractWidth}px)`;\n}",
132
+ maybeApplyForTablet:
133
+ "@builder.io/mitosis/method:maybeApplyForTablet(prop: JSX.CSS['flexDirection']) {\n const _stackColumnsAt = props.stackColumnsAt || 'tablet';\n\n return _stackColumnsAt === 'tablet' ? prop : 'inherit';\n}",
134
+ columnsCssVars:
135
+ "@builder.io/mitosis/method:get columnsCssVars() {\n const flexDir = props.stackColumnsAt === 'never' ? 'inherit' : props.reverseColumnsWhenStacked ? 'column-reverse' : 'column';\n return {\n '--flex-dir': flexDir,\n '--flex-dir-tablet': maybeApplyForTablet(props,state,flexDir)\n };\n}",
136
+ columnCssVars:
137
+ "@builder.io/mitosis/method:get columnCssVars() {\n const width = '100%';\n const marginLeft = '0';\n return {\n '--column-width': width,\n '--column-margin-left': marginLeft,\n '--column-width-tablet': maybeApplyForTablet(props,state,width),\n '--column-margin-left-tablet': maybeApplyForTablet(props,state,marginLeft)\n };\n}",
138
+ },
139
+ children: [
140
+ {
141
+ "@type": "@builder.io/mitosis/node",
142
+ name: "Host",
143
+ meta: {},
144
+ scope: {},
145
+ properties: {
146
+ class: "builder-columns div-Columns",
147
+ },
148
+ bindings: {
149
+ style: {
150
+ code: "columnsCssVars(props,state)",
151
+ },
152
+ },
153
+ children: [
154
+ {
155
+ "@type": "@builder.io/mitosis/node",
156
+ name: "div",
157
+ meta: {},
158
+ scope: {},
159
+ properties: {
160
+ _text: "\n ",
161
+ },
162
+ bindings: {},
163
+ children: [],
164
+ },
165
+ {
166
+ "@type": "@builder.io/mitosis/node",
167
+ name: "For",
168
+ meta: {},
169
+ scope: {
170
+ For: ["column", "index"],
171
+ },
172
+ properties: {
173
+ _forName: "column",
174
+ _indexName: "index",
175
+ },
176
+ bindings: {
177
+ each: {
178
+ code: "props.columns",
179
+ },
180
+ },
181
+ children: [
182
+ {
183
+ "@type": "@builder.io/mitosis/node",
184
+ name: "div",
185
+ meta: {},
186
+ scope: {},
187
+ properties: {
188
+ class: "builder-column div-Columns-2",
189
+ },
190
+ bindings: {
191
+ style: {
192
+ code: "{\n width: getColumnCssWidth(props,state,index),\n marginLeft: `${index === 0 ? 0 : getGutterSize(props,state,)}px`,\n ...columnCssVars(props,state)\n}",
193
+ },
194
+ key: {
195
+ code: "index",
196
+ },
197
+ },
198
+ children: [
199
+ {
200
+ "@type": "@builder.io/mitosis/node",
201
+ name: "div",
202
+ meta: {},
203
+ scope: {},
204
+ properties: {
205
+ _text: "\n ",
206
+ },
207
+ bindings: {},
208
+ children: [],
209
+ },
210
+ {
211
+ "@type": "@builder.io/mitosis/node",
212
+ name: "RenderBlocks",
213
+ meta: {},
214
+ scope: {},
215
+ properties: {},
216
+ bindings: {
217
+ blocks: {
218
+ code: "column.blocks",
219
+ },
220
+ },
221
+ children: [],
222
+ },
223
+ {
224
+ "@type": "@builder.io/mitosis/node",
225
+ name: "div",
226
+ meta: {},
227
+ scope: {},
228
+ properties: {
229
+ _text: "\n ",
230
+ },
231
+ bindings: {},
232
+ children: [],
233
+ },
234
+ ],
235
+ },
236
+ ],
237
+ },
238
+ {
239
+ "@type": "@builder.io/mitosis/node",
240
+ name: "div",
241
+ meta: {},
242
+ scope: {},
243
+ properties: {
244
+ _text: "\n ",
245
+ },
246
+ bindings: {},
247
+ children: [],
248
+ },
249
+ ],
250
+ },
251
+ ],
252
+ hooks: {},
253
+ context: {
254
+ get: {},
255
+ set: {},
256
+ },
257
+ name: "Columns",
258
+ subComponents: [],
259
+ types: [
260
+ "type Column = {\n blocks: any; // TODO: Implement this when support for dynamic CSS lands\n\n width?: number;\n};",
261
+ "type StackColumnsAt = 'tablet' | 'mobile' | 'never';",
262
+ ],
263
+ interfaces: [
264
+ "export interface ColumnProps {\n columns?: Column[]; // TODO: Implement this when support for dynamic CSS lands\n\n space?: number; // TODO: Implement this when support for dynamic CSS lands\n\n stackColumnsAt?: StackColumnsAt; // TODO: Implement this when support for dynamic CSS lands\n\n reverseColumnsWhenStacked?: boolean;\n}",
265
+ ],
266
+ propsTypeRef: "ColumnProps",
267
+ };
@@ -0,0 +1,242 @@
1
+ import { markSerializable } from "../util";
2
+ const componentInfo = {
3
+ name: "Columns",
4
+ builtIn: true,
5
+ inputs: [
6
+ {
7
+ name: "columns",
8
+ type: "array",
9
+ broadcast: true,
10
+ subFields: [
11
+ {
12
+ name: "blocks",
13
+ type: "array",
14
+ hideFromUI: true,
15
+ defaultValue: [
16
+ {
17
+ "@type": "@builder.io/sdk:Element",
18
+ responsiveStyles: {
19
+ large: {
20
+ display: "flex",
21
+ flexDirection: "column",
22
+ alignItems: "stretch",
23
+ flexShrink: "0",
24
+ position: "relative",
25
+ marginTop: "30px",
26
+ textAlign: "center",
27
+ lineHeight: "normal",
28
+ height: "auto",
29
+ minHeight: "20px",
30
+ minWidth: "20px",
31
+ overflow: "hidden"
32
+ }
33
+ },
34
+ component: {
35
+ name: "Image",
36
+ options: {
37
+ image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
38
+ backgroundPosition: "center",
39
+ backgroundSize: "cover",
40
+ aspectRatio: 0.7004048582995948
41
+ }
42
+ }
43
+ },
44
+ {
45
+ "@type": "@builder.io/sdk:Element",
46
+ responsiveStyles: {
47
+ large: {
48
+ display: "flex",
49
+ flexDirection: "column",
50
+ alignItems: "stretch",
51
+ flexShrink: "0",
52
+ position: "relative",
53
+ marginTop: "30px",
54
+ textAlign: "center",
55
+ lineHeight: "normal",
56
+ height: "auto"
57
+ }
58
+ },
59
+ component: {
60
+ name: "Text",
61
+ options: {
62
+ text: "<p>Enter some text...</p>"
63
+ }
64
+ }
65
+ }
66
+ ]
67
+ },
68
+ {
69
+ name: "width",
70
+ type: "number",
71
+ hideFromUI: true,
72
+ helperText: "Width %, e.g. set to 50 to fill half of the space"
73
+ },
74
+ {
75
+ name: "link",
76
+ type: "url",
77
+ helperText: "Optionally set a url that clicking this column will link to"
78
+ }
79
+ ],
80
+ defaultValue: [
81
+ {
82
+ blocks: [
83
+ {
84
+ "@type": "@builder.io/sdk:Element",
85
+ responsiveStyles: {
86
+ large: {
87
+ display: "flex",
88
+ flexDirection: "column",
89
+ alignItems: "stretch",
90
+ flexShrink: "0",
91
+ position: "relative",
92
+ marginTop: "30px",
93
+ textAlign: "center",
94
+ lineHeight: "normal",
95
+ height: "auto",
96
+ minHeight: "20px",
97
+ minWidth: "20px",
98
+ overflow: "hidden"
99
+ }
100
+ },
101
+ component: {
102
+ name: "Image",
103
+ options: {
104
+ image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
105
+ backgroundPosition: "center",
106
+ backgroundSize: "cover",
107
+ aspectRatio: 0.7004048582995948
108
+ }
109
+ }
110
+ },
111
+ {
112
+ "@type": "@builder.io/sdk:Element",
113
+ responsiveStyles: {
114
+ large: {
115
+ display: "flex",
116
+ flexDirection: "column",
117
+ alignItems: "stretch",
118
+ flexShrink: "0",
119
+ position: "relative",
120
+ marginTop: "30px",
121
+ textAlign: "center",
122
+ lineHeight: "normal",
123
+ height: "auto"
124
+ }
125
+ },
126
+ component: {
127
+ name: "Text",
128
+ options: {
129
+ text: "<p>Enter some text...</p>"
130
+ }
131
+ }
132
+ }
133
+ ]
134
+ },
135
+ {
136
+ blocks: [
137
+ {
138
+ "@type": "@builder.io/sdk:Element",
139
+ responsiveStyles: {
140
+ large: {
141
+ display: "flex",
142
+ flexDirection: "column",
143
+ alignItems: "stretch",
144
+ flexShrink: "0",
145
+ position: "relative",
146
+ marginTop: "30px",
147
+ textAlign: "center",
148
+ lineHeight: "normal",
149
+ height: "auto",
150
+ minHeight: "20px",
151
+ minWidth: "20px",
152
+ overflow: "hidden"
153
+ }
154
+ },
155
+ component: {
156
+ name: "Image",
157
+ options: {
158
+ image: "https://builder.io/api/v1/image/assets%2Fpwgjf0RoYWbdnJSbpBAjXNRMe9F2%2Ffb27a7c790324294af8be1c35fe30f4d",
159
+ backgroundPosition: "center",
160
+ backgroundSize: "cover",
161
+ aspectRatio: 0.7004048582995948
162
+ }
163
+ }
164
+ },
165
+ {
166
+ "@type": "@builder.io/sdk:Element",
167
+ responsiveStyles: {
168
+ large: {
169
+ display: "flex",
170
+ flexDirection: "column",
171
+ alignItems: "stretch",
172
+ flexShrink: "0",
173
+ position: "relative",
174
+ marginTop: "30px",
175
+ textAlign: "center",
176
+ lineHeight: "normal",
177
+ height: "auto"
178
+ }
179
+ },
180
+ component: {
181
+ name: "Text",
182
+ options: {
183
+ text: "<p>Enter some text...</p>"
184
+ }
185
+ }
186
+ }
187
+ ]
188
+ }
189
+ ],
190
+ onChange: markSerializable((options) => {
191
+ function clearWidths() {
192
+ columns.forEach((col) => {
193
+ col.delete("width");
194
+ });
195
+ }
196
+ const columns = options.get("columns");
197
+ if (Array.isArray(columns)) {
198
+ const containsColumnWithWidth = !!columns.find((col) => col.get("width"));
199
+ if (containsColumnWithWidth) {
200
+ const containsColumnWithoutWidth = !!columns.find((col) => !col.get("width"));
201
+ if (containsColumnWithoutWidth) {
202
+ clearWidths();
203
+ } else {
204
+ const sumWidths = columns.reduce((memo, col) => {
205
+ return memo + col.get("width");
206
+ }, 0);
207
+ const widthsDontAddUp = sumWidths !== 100;
208
+ if (widthsDontAddUp) {
209
+ clearWidths();
210
+ }
211
+ }
212
+ }
213
+ }
214
+ })
215
+ },
216
+ {
217
+ name: "space",
218
+ type: "number",
219
+ defaultValue: 20,
220
+ helperText: "Size of gap between columns",
221
+ advanced: true
222
+ },
223
+ {
224
+ name: "stackColumnsAt",
225
+ type: "string",
226
+ defaultValue: "tablet",
227
+ helperText: "Convert horizontal columns to vertical at what device size",
228
+ enum: ["tablet", "mobile", "never"],
229
+ advanced: true
230
+ },
231
+ {
232
+ name: "reverseColumnsWhenStacked",
233
+ type: "boolean",
234
+ defaultValue: false,
235
+ helperText: "When stacking columns for mobile devices, reverse the ordering",
236
+ advanced: true
237
+ }
238
+ ]
239
+ };
240
+ export {
241
+ componentInfo
242
+ };
@@ -0,0 +1,31 @@
1
+ const componentInfo = {
2
+ name: "Custom Code",
3
+ static: true,
4
+ builtIn: true,
5
+ requiredPermissions: ["editCode"],
6
+ inputs: [
7
+ {
8
+ name: "code",
9
+ type: "html",
10
+ required: true,
11
+ defaultValue: "<p>Hello there, I am custom HTML code!</p>",
12
+ code: true
13
+ },
14
+ {
15
+ name: "replaceNodes",
16
+ type: "boolean",
17
+ helperText: "Preserve server rendered dom nodes",
18
+ advanced: true
19
+ },
20
+ {
21
+ name: "scriptsClientOnly",
22
+ type: "boolean",
23
+ defaultValue: false,
24
+ helperText: "Only print and run scripts on the client. Important when scripts influence DOM that could be replaced when client loads",
25
+ advanced: true
26
+ }
27
+ ]
28
+ };
29
+ export {
30
+ componentInfo
31
+ };
@@ -0,0 +1,130 @@
1
+ // GENERATED BY MITOSIS
2
+
3
+ import {
4
+ Fragment,
5
+ Host,
6
+ component$,
7
+ h,
8
+ useClientEffect$,
9
+ useRef,
10
+ useStore,
11
+ } from "@builder.io/qwik";
12
+ export const findAndRunScripts = function findAndRunScripts(
13
+ props,
14
+ state,
15
+ elem
16
+ ) {
17
+ // TODO: Move this function to standalone one in '@builder.io/utils'
18
+ if (elem && typeof window !== "undefined") {
19
+ const scripts = elem.getElementsByTagName("script");
20
+
21
+ for (let i = 0; i < scripts.length; i++) {
22
+ const script = scripts[i];
23
+
24
+ if (script.src) {
25
+ if (state.scriptsInserted.includes(script.src)) {
26
+ continue;
27
+ }
28
+
29
+ state.scriptsInserted.push(script.src);
30
+ const newScript = document.createElement("script");
31
+ newScript.async = true;
32
+ newScript.src = script.src;
33
+ document.head.appendChild(newScript);
34
+ } else if (
35
+ !script.type ||
36
+ [
37
+ "text/javascript",
38
+ "application/javascript",
39
+ "application/ecmascript",
40
+ ].includes(script.type)
41
+ ) {
42
+ if (state.scriptsRun.includes(script.innerText)) {
43
+ continue;
44
+ }
45
+
46
+ try {
47
+ state.scriptsRun.push(script.innerText);
48
+ new Function(script.innerText)();
49
+ } catch (error) {
50
+ console.warn("`CustomCode`: Error running script:", error);
51
+ }
52
+ }
53
+ }
54
+ }
55
+ };
56
+ export const CustomCode = component$(
57
+ (props) => {
58
+ const elem = useRef();
59
+ const state = useStore({ scriptsInserted: [], scriptsRun: [] });
60
+ useClientEffect$(() => {
61
+ findAndRunScripts(props, state, elem);
62
+ });
63
+ return (
64
+ <Host
65
+ ref={elem}
66
+ class={
67
+ "builder-custom-code" + (props.replaceNodes ? " replace-nodes" : "")
68
+ }
69
+ dangerouslySetInnerHTML={props.code}
70
+ ></Host>
71
+ );
72
+ },
73
+ { tagName: "div" }
74
+ );
75
+ export default CustomCode;
76
+ export const COMPONENT = {
77
+ "@type": "@builder.io/mitosis/component",
78
+ imports: [],
79
+ exports: {},
80
+ inputs: [],
81
+ meta: {},
82
+ refs: {
83
+ elem: {
84
+ argument: "",
85
+ typeParameter: "HTMLDivElement",
86
+ },
87
+ },
88
+ state: {
89
+ scriptsInserted: [],
90
+ scriptsRun: [],
91
+ findAndRunScripts:
92
+ "@builder.io/mitosis/method:findAndRunScripts() {\n // TODO: Move this function to standalone one in '@builder.io/utils'\n if (elem && typeof window !== 'undefined') {\n const scripts = elem.getElementsByTagName('script');\n\n for (let i = 0; i < scripts.length; i++) {\n const script = scripts[i];\n\n if (script.src) {\n if (state.scriptsInserted.includes(script.src)) {\n continue;\n }\n\n state.scriptsInserted.push(script.src);\n const newScript = document.createElement('script');\n newScript.async = true;\n newScript.src = script.src;\n document.head.appendChild(newScript);\n } else if (!script.type || ['text/javascript', 'application/javascript', 'application/ecmascript'].includes(script.type)) {\n if (state.scriptsRun.includes(script.innerText)) {\n continue;\n }\n\n try {\n state.scriptsRun.push(script.innerText);\n new Function(script.innerText)();\n } catch (error) {\n console.warn('`CustomCode`: Error running script:', error);\n }\n }\n }\n }\n}",
93
+ },
94
+ children: [
95
+ {
96
+ "@type": "@builder.io/mitosis/node",
97
+ name: "Host",
98
+ meta: {},
99
+ scope: {},
100
+ properties: {},
101
+ bindings: {
102
+ ref: {
103
+ code: "elem",
104
+ },
105
+ class: {
106
+ code: "'builder-custom-code' + (props.replaceNodes ? ' replace-nodes' : '')",
107
+ },
108
+ innerHTML: {
109
+ code: "props.code",
110
+ },
111
+ },
112
+ children: [],
113
+ },
114
+ ],
115
+ hooks: {
116
+ onMount: {
117
+ code: "\n findAndRunScripts(props,state,elem,);\n",
118
+ },
119
+ },
120
+ context: {
121
+ get: {},
122
+ set: {},
123
+ },
124
+ name: "CustomCode",
125
+ subComponents: [],
126
+ interfaces: [
127
+ "export interface CustomCodeProps {\n code: string;\n replaceNodes?: boolean;\n}",
128
+ ],
129
+ propsTypeRef: "CustomCodeProps",
130
+ };