@builder.io/sdk-solid 0.0.7 → 0.0.8-10

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 (114) hide show
  1. package/package.json +16 -5
  2. package/src/blocks/button/button.jsx +13 -0
  3. package/src/blocks/button/button.lite.tsx +23 -0
  4. package/src/blocks/button/component-info.js +41 -0
  5. package/src/blocks/columns/columns.jsx +91 -0
  6. package/src/blocks/{columns.lite.tsx → columns/columns.lite.tsx} +34 -26
  7. package/src/blocks/columns/component-info.js +217 -0
  8. package/src/blocks/custom-code/component-info.js +31 -0
  9. package/src/blocks/{custom-code.jsx → custom-code/custom-code.jsx} +2 -2
  10. package/src/blocks/{custom-code.lite.tsx → custom-code/custom-code.lite.tsx} +2 -0
  11. package/src/blocks/embed/component-info.js +24 -0
  12. package/src/blocks/{embed.jsx → embed/embed.jsx} +3 -3
  13. package/src/blocks/{embed.lite.tsx → embed/embed.lite.tsx} +3 -1
  14. package/src/blocks/form/component-info.js +262 -0
  15. package/src/blocks/{form.jsx → form/form.jsx} +9 -9
  16. package/src/blocks/{form.lite.tsx → form/form.lite.tsx} +15 -11
  17. package/src/blocks/fragment/component-info.js +11 -0
  18. package/src/blocks/fragment/fragment.jsx +5 -0
  19. package/src/blocks/{fragment.lite.tsx → fragment/fragment.lite.tsx} +0 -0
  20. package/src/blocks/image/component-info.js +104 -0
  21. package/src/blocks/image/image.jsx +54 -0
  22. package/src/blocks/image/image.lite.tsx +86 -0
  23. package/src/blocks/img/component-info.js +20 -0
  24. package/src/blocks/img/img.jsx +10 -0
  25. package/src/blocks/{img.lite.tsx → img/img.lite.tsx} +1 -1
  26. package/src/blocks/input/component-info.js +74 -0
  27. package/src/blocks/input/input.jsx +7 -0
  28. package/src/blocks/{input.lite.tsx → input/input.lite.tsx} +1 -1
  29. package/src/blocks/raw-text/component-info.js +16 -0
  30. package/src/blocks/raw-text/raw-text.jsx +5 -0
  31. package/src/blocks/{raw-text.lite.tsx → raw-text/raw-text.lite.tsx} +0 -0
  32. package/src/blocks/section/component-info.js +49 -0
  33. package/src/blocks/section/section.jsx +9 -0
  34. package/src/blocks/{section.lite.tsx → section/section.lite.tsx} +0 -0
  35. package/src/blocks/select/component-info.js +59 -0
  36. package/src/blocks/select/select.jsx +16 -0
  37. package/src/blocks/{select.lite.tsx → select/select.lite.tsx} +1 -1
  38. package/src/blocks/submit-button/component-info.js +28 -0
  39. package/src/blocks/submit-button/submit-button.jsx +7 -0
  40. package/src/blocks/{submit-button.lite.tsx → submit-button/submit-button.lite.tsx} +0 -0
  41. package/src/blocks/symbol/component-info.js +43 -0
  42. package/src/blocks/symbol/symbol.jsx +25 -0
  43. package/src/blocks/{symbol.lite.tsx → symbol/symbol.lite.tsx} +6 -4
  44. package/src/blocks/text/component-info.js +24 -0
  45. package/src/blocks/text/text.jsx +5 -0
  46. package/src/blocks/text/text.lite.tsx +5 -0
  47. package/src/blocks/textarea/component-info.js +47 -0
  48. package/src/blocks/textarea/textarea.jsx +5 -0
  49. package/src/blocks/{textarea.lite.tsx → textarea/textarea.lite.tsx} +0 -0
  50. package/src/blocks/video/component-info.js +106 -0
  51. package/src/blocks/video/video.jsx +14 -0
  52. package/src/blocks/{video.lite.tsx → video/video.lite.tsx} +0 -0
  53. package/src/components/render-block/block-styles.jsx +36 -0
  54. package/src/components/render-block/block-styles.lite.tsx +38 -0
  55. package/src/components/render-block/render-block.helpers.js +23 -0
  56. package/src/components/{render-block.jsx → render-block/render-block.jsx} +40 -22
  57. package/src/components/{render-block.lite.tsx → render-block/render-block.lite.tsx} +57 -19
  58. package/src/components/render-blocks.jsx +2 -2
  59. package/src/components/render-blocks.lite.tsx +2 -2
  60. package/src/components/render-content/components/render-styles.jsx +6 -5
  61. package/src/components/render-content/components/render-styles.lite.tsx +9 -5
  62. package/src/components/render-content/index.js +4 -0
  63. package/src/components/render-content/render-content.jsx +50 -24
  64. package/src/components/render-content/render-content.lite.tsx +64 -33
  65. package/src/components/render-inlined-styles.jsx +24 -0
  66. package/src/components/render-inlined-styles.lite.tsx +29 -0
  67. package/src/constants/builder-registered-components.js +45 -0
  68. package/src/context/builder.context.js +2 -1
  69. package/src/functions/evaluate.js +2 -2
  70. package/src/functions/fast-clone.js +4 -0
  71. package/src/functions/get-block-actions.js +2 -2
  72. package/src/functions/get-block-styles.js +2 -2
  73. package/src/functions/get-builder-search-params/fn.test.js +1 -1
  74. package/src/functions/get-content/index.js +3 -2
  75. package/src/functions/get-fetch.js +29 -7
  76. package/src/functions/get-processed-block.js +3 -3
  77. package/src/functions/get-processed-block.test.js +1 -1
  78. package/src/functions/if-target.js +1 -1
  79. package/src/functions/is-editing.js +1 -1
  80. package/src/functions/is-iframe.js +1 -1
  81. package/src/functions/is-previewing.js +2 -2
  82. package/src/functions/on-change.test.js +1 -1
  83. package/src/functions/previewing-model-name.js +1 -1
  84. package/src/functions/register-component.js +30 -13
  85. package/src/functions/register.js +1 -1
  86. package/src/functions/set-editor-settings.js +1 -1
  87. package/src/functions/set.test.js +1 -1
  88. package/src/functions/track.js +3 -3
  89. package/src/index-helpers/blocks-exports.js +9 -9
  90. package/src/index.js +10 -13
  91. package/src/scripts/init-editing.js +72 -63
  92. package/src/solid-index.jsx +5 -0
  93. package/src/types/components.js +0 -0
  94. package/src/types/element.js +0 -0
  95. package/src/blocks/button.jsx +0 -8
  96. package/src/blocks/button.lite.tsx +0 -14
  97. package/src/blocks/columns.jsx +0 -96
  98. package/src/blocks/fragment.jsx +0 -6
  99. package/src/blocks/image.jsx +0 -120
  100. package/src/blocks/image.lite.tsx +0 -171
  101. package/src/blocks/img.jsx +0 -11
  102. package/src/blocks/input.jsx +0 -8
  103. package/src/blocks/raw-text.jsx +0 -6
  104. package/src/blocks/section.jsx +0 -10
  105. package/src/blocks/select.jsx +0 -17
  106. package/src/blocks/submit-button.jsx +0 -8
  107. package/src/blocks/symbol.jsx +0 -25
  108. package/src/blocks/text.jsx +0 -6
  109. package/src/blocks/text.lite.tsx +0 -5
  110. package/src/blocks/textarea.jsx +0 -6
  111. package/src/blocks/video.jsx +0 -15
  112. package/src/components/block-styles.jsx +0 -5
  113. package/src/components/block-styles.lite.tsx +0 -5
  114. package/src/functions/macro-eval.js +0 -5
@@ -0,0 +1,10 @@
1
+ import { isEditing } from "../../functions/is-editing.js";
2
+
3
+ function ImgComponent(props) {
4
+ return <img {...props.attributes} style={{
5
+ "object-fit": props.backgroundSize || "cover",
6
+ "object-position": props.backgroundPosition || "center"
7
+ }} key={isEditing() && props.imgSrc || "default-key"} alt={props.altText} src={props.imgSrc} />;
8
+ }
9
+
10
+ export default ImgComponent;
@@ -1,4 +1,4 @@
1
- import { isEditing } from "../functions/is-editing";
1
+ import { isEditing } from "../../functions/is-editing.js";
2
2
 
3
3
  function ImgComponent(props) {
4
4
  return (
@@ -0,0 +1,74 @@
1
+ const componentInfo = {
2
+ name: "Form:Input",
3
+ builtIn: true,
4
+ image: "https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2Fad6f37889d9e40bbbbc72cdb5875d6ca",
5
+ inputs: [
6
+ {
7
+ name: "type",
8
+ type: "text",
9
+ enum: [
10
+ "text",
11
+ "number",
12
+ "email",
13
+ "url",
14
+ "checkbox",
15
+ "radio",
16
+ "range",
17
+ "date",
18
+ "datetime-local",
19
+ "search",
20
+ "tel",
21
+ "time",
22
+ "file",
23
+ "month",
24
+ "week",
25
+ "password",
26
+ "color",
27
+ "hidden"
28
+ ],
29
+ defaultValue: "text"
30
+ },
31
+ {
32
+ name: "name",
33
+ type: "string",
34
+ required: true,
35
+ helperText: 'Every input in a form needs a unique name describing what it takes, e.g. "email"'
36
+ },
37
+ {
38
+ name: "placeholder",
39
+ type: "string",
40
+ defaultValue: "Hello there",
41
+ helperText: "Text to display when there is no value"
42
+ },
43
+ {
44
+ name: "defaultValue",
45
+ type: "string"
46
+ },
47
+ {
48
+ name: "value",
49
+ type: "string",
50
+ advanced: true
51
+ },
52
+ {
53
+ name: "required",
54
+ type: "boolean",
55
+ helperText: "Is this input required to be filled out to submit a form",
56
+ defaultValue: false
57
+ }
58
+ ],
59
+ noWrap: true,
60
+ static: true,
61
+ defaultStyles: {
62
+ paddingTop: "10px",
63
+ paddingBottom: "10px",
64
+ paddingLeft: "10px",
65
+ paddingRight: "10px",
66
+ borderRadius: "3px",
67
+ borderWidth: "1px",
68
+ borderStyle: "solid",
69
+ borderColor: "#ccc"
70
+ }
71
+ };
72
+ export {
73
+ componentInfo
74
+ };
@@ -0,0 +1,7 @@
1
+ import { isEditing } from "../../functions/is-editing.js";
2
+
3
+ function FormInputComponent(props) {
4
+ return <input {...props.attributes} key={isEditing() && props.defaultValue ? props.defaultValue : "default-key"} placeholder={props.placeholder} type={props.type} name={props.name} value={props.value} defaultValue={props.defaultValue} required={props.required} />;
5
+ }
6
+
7
+ export default FormInputComponent;
@@ -1,4 +1,4 @@
1
- import { isEditing } from "../functions/is-editing";
1
+ import { isEditing } from "../../functions/is-editing.js";
2
2
 
3
3
  function FormInputComponent(props) {
4
4
  return (
@@ -0,0 +1,16 @@
1
+ const componentInfo = {
2
+ name: "Builder:RawText",
3
+ hideFromInsertMenu: true,
4
+ builtIn: true,
5
+ inputs: [
6
+ {
7
+ name: "text",
8
+ bubble: true,
9
+ type: "longText",
10
+ required: true
11
+ }
12
+ ]
13
+ };
14
+ export {
15
+ componentInfo
16
+ };
@@ -0,0 +1,5 @@
1
+ function RawText(props) {
2
+ return <span class={props.attributes?.class || props.attributes?.className} innerHTML={props.text || ""}></span>;
3
+ }
4
+
5
+ export default RawText;
@@ -0,0 +1,49 @@
1
+ const componentInfo = {
2
+ name: "Core:Section",
3
+ static: true,
4
+ builtIn: true,
5
+ image: "https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2F682efef23ace49afac61748dd305c70a",
6
+ inputs: [
7
+ {
8
+ name: "maxWidth",
9
+ type: "number",
10
+ defaultValue: 1200
11
+ },
12
+ {
13
+ name: "lazyLoad",
14
+ type: "boolean",
15
+ defaultValue: false,
16
+ advanced: true,
17
+ description: "Only render this section when in view"
18
+ }
19
+ ],
20
+ defaultStyles: {
21
+ paddingLeft: "20px",
22
+ paddingRight: "20px",
23
+ paddingTop: "50px",
24
+ paddingBottom: "50px",
25
+ marginTop: "0px",
26
+ width: "100vw",
27
+ marginLeft: "calc(50% - 50vw)"
28
+ },
29
+ canHaveChildren: true,
30
+ defaultChildren: [
31
+ {
32
+ "@type": "@builder.io/sdk:Element",
33
+ responsiveStyles: {
34
+ large: {
35
+ textAlign: "center"
36
+ }
37
+ },
38
+ component: {
39
+ name: "Text",
40
+ options: {
41
+ text: "<p><b>I am a section! My content keeps from getting too wide, so that it's easy to read even on big screens.</b></p><p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur</p>"
42
+ }
43
+ }
44
+ }
45
+ ]
46
+ };
47
+ export {
48
+ componentInfo
49
+ };
@@ -0,0 +1,9 @@
1
+ function SectionComponent(props) {
2
+ return <section {...props.attributes} style={props.maxWidth && typeof props.maxWidth === "number" ? {
3
+ "max-width": props.maxWidth
4
+ } : undefined}>
5
+ {props.children}
6
+ </section>;
7
+ }
8
+
9
+ export default SectionComponent;
@@ -0,0 +1,59 @@
1
+ const componentInfo = {
2
+ name: "Form:Select",
3
+ builtIn: true,
4
+ image: "https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2F83acca093fb24aaf94dee136e9a4b045",
5
+ defaultStyles: {
6
+ alignSelf: "flex-start"
7
+ },
8
+ inputs: [
9
+ {
10
+ name: "options",
11
+ type: "list",
12
+ required: true,
13
+ subFields: [
14
+ {
15
+ name: "value",
16
+ type: "text",
17
+ required: true
18
+ },
19
+ {
20
+ name: "name",
21
+ type: "text"
22
+ }
23
+ ],
24
+ defaultValue: [
25
+ {
26
+ value: "option 1"
27
+ },
28
+ {
29
+ value: "option 2"
30
+ }
31
+ ]
32
+ },
33
+ {
34
+ name: "name",
35
+ type: "string",
36
+ required: true,
37
+ helperText: 'Every select in a form needs a unique name describing what it gets, e.g. "email"'
38
+ },
39
+ {
40
+ name: "defaultValue",
41
+ type: "string"
42
+ },
43
+ {
44
+ name: "value",
45
+ type: "string",
46
+ advanced: true
47
+ },
48
+ {
49
+ name: "required",
50
+ type: "boolean",
51
+ defaultValue: false
52
+ }
53
+ ],
54
+ static: true,
55
+ noWrap: true
56
+ };
57
+ export {
58
+ componentInfo
59
+ };
@@ -0,0 +1,16 @@
1
+ import { For } from "solid-js";
2
+ import { isEditing } from "../../functions/is-editing.js";
3
+
4
+ function SelectComponent(props) {
5
+ return <select {...props.attributes} value={props.value} key={isEditing() && props.defaultValue ? props.defaultValue : "default-key"} defaultValue={props.defaultValue} name={props.name}>
6
+ <For each={props.options}>
7
+ {(option, _index) => {
8
+ const index = _index();
9
+
10
+ return <option value={option.value}>{option.name || option.value}</option>;
11
+ }}
12
+ </For>
13
+ </select>;
14
+ }
15
+
16
+ export default SelectComponent;
@@ -1,6 +1,6 @@
1
1
  import { For } from "solid-js";
2
2
 
3
- import { isEditing } from "../functions/is-editing";
3
+ import { isEditing } from "../../functions/is-editing.js";
4
4
 
5
5
  function SelectComponent(props) {
6
6
  return (
@@ -0,0 +1,28 @@
1
+ const componentInfo = {
2
+ name: "Form:SubmitButton",
3
+ builtIn: true,
4
+ image: "https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2Fdf2820ffed1f4349a94c40b3221f5b98",
5
+ defaultStyles: {
6
+ appearance: "none",
7
+ paddingTop: "15px",
8
+ paddingBottom: "15px",
9
+ paddingLeft: "25px",
10
+ paddingRight: "25px",
11
+ backgroundColor: "#3898EC",
12
+ color: "white",
13
+ borderRadius: "4px",
14
+ cursor: "pointer"
15
+ },
16
+ inputs: [
17
+ {
18
+ name: "text",
19
+ type: "text",
20
+ defaultValue: "Click me"
21
+ }
22
+ ],
23
+ static: true,
24
+ noWrap: true
25
+ };
26
+ export {
27
+ componentInfo
28
+ };
@@ -0,0 +1,7 @@
1
+ function SubmitButton(props) {
2
+ return <button {...props.attributes} type="submit">
3
+ {props.text}
4
+ </button>;
5
+ }
6
+
7
+ export default SubmitButton;
@@ -0,0 +1,43 @@
1
+ const componentInfo = {
2
+ name: "Symbol",
3
+ noWrap: true,
4
+ static: true,
5
+ builtIn: true,
6
+ inputs: [
7
+ {
8
+ name: "symbol",
9
+ type: "uiSymbol"
10
+ },
11
+ {
12
+ name: "dataOnly",
13
+ helperText: "Make this a data symbol that doesn't display any UI",
14
+ type: "boolean",
15
+ defaultValue: false,
16
+ advanced: true,
17
+ hideFromUI: true
18
+ },
19
+ {
20
+ name: "inheritState",
21
+ helperText: "Inherit the parent component state and data",
22
+ type: "boolean",
23
+ defaultValue: false,
24
+ advanced: true
25
+ },
26
+ {
27
+ name: "renderToLiquid",
28
+ helperText: "Render this symbols contents to liquid. Turn off to fetch with javascript and use custom targeting",
29
+ type: "boolean",
30
+ defaultValue: false,
31
+ advanced: true,
32
+ hideFromUI: true
33
+ },
34
+ {
35
+ name: "useChildren",
36
+ hideFromUI: true,
37
+ type: "boolean"
38
+ }
39
+ ]
40
+ };
41
+ export {
42
+ componentInfo
43
+ };
@@ -0,0 +1,25 @@
1
+ import { useContext, onMount } from "solid-js";
2
+ import { createMutable } from "solid-js/store";
3
+ import RenderContent from "../../components/render-content/render-content";
4
+ import BuilderContext from "../../context/builder.context";
5
+
6
+ function Symbol(props) {
7
+ const state = createMutable({
8
+ className: "builder-symbol",
9
+ content: null
10
+ });
11
+ const builderContext = useContext(BuilderContext);
12
+ onMount(() => {
13
+ state.content = props.symbol?.content;
14
+ });
15
+ return <div class={state.className} {...props.attributes} dataSet={{
16
+ class: state.className
17
+ }}>
18
+ <RenderContent apiKey={builderContext.apiKey} context={builderContext.context} data={{ ...props.symbol?.data,
19
+ ...builderContext.state,
20
+ ...props.symbol?.content?.data?.state
21
+ }} model={props.symbol?.model} content={state.content}></RenderContent>
22
+ </div>;
23
+ }
24
+
25
+ export default Symbol;
@@ -1,8 +1,10 @@
1
+ import { useContext, onMount } from "solid-js";
2
+
1
3
  import { createMutable } from "solid-js/store";
2
4
 
3
- import RenderContent from "../components/render-content/render-content.lite";
4
- import BuilderContext from "../context/builder.context";
5
- import { getContent } from "../functions/get-content";
5
+ import RenderContent from "../../components/render-content/render-content.lite";
6
+ import BuilderContext from "../../context/builder.context";
7
+ import { getContent } from "../../functions/get-content/index.js";
6
8
 
7
9
  function Symbol(props) {
8
10
  const state = createMutable({ className: "builder-symbol", content: null });
@@ -27,7 +29,7 @@ function Symbol(props) {
27
29
  data={{
28
30
  ...props.symbol?.data,
29
31
  ...builderContext.state,
30
- ...props.symbol?.state.content?.data?.state,
32
+ ...props.symbol?.content?.data?.state,
31
33
  }}
32
34
  model={props.symbol?.model}
33
35
  content={state.content}
@@ -0,0 +1,24 @@
1
+ const componentInfo = {
2
+ name: "Text",
3
+ static: true,
4
+ builtIn: true,
5
+ image: "https://firebasestorage.googleapis.com/v0/b/builder-3b0a2.appspot.com/o/images%2Fbaseline-text_fields-24px%20(1).svg?alt=media&token=12177b73-0ee3-42ca-98c6-0dd003de1929",
6
+ inputs: [
7
+ {
8
+ name: "text",
9
+ type: "html",
10
+ required: true,
11
+ autoFocus: true,
12
+ bubble: true,
13
+ defaultValue: "Enter some text..."
14
+ }
15
+ ],
16
+ defaultStyles: {
17
+ lineHeight: "normal",
18
+ height: "auto",
19
+ textAlign: "center"
20
+ }
21
+ };
22
+ export {
23
+ componentInfo
24
+ };
@@ -0,0 +1,5 @@
1
+ function Text(props) {
2
+ return <div class="builder-text" innerHTML={props.text}></div>;
3
+ }
4
+
5
+ export default Text;
@@ -0,0 +1,5 @@
1
+ function Text(props) {
2
+ return <div class="builder-text" innerHTML={props.text}></div>;
3
+ }
4
+
5
+ export default Text;
@@ -0,0 +1,47 @@
1
+ const componentInfo = {
2
+ name: "Form:TextArea",
3
+ builtIn: true,
4
+ image: "https://cdn.builder.io/api/v1/image/assets%2FIsxPKMo2gPRRKeakUztj1D6uqed2%2Ff74a2f3de58c4c3e939204e5b6b8f6c3",
5
+ inputs: [
6
+ {
7
+ advanced: true,
8
+ name: "value",
9
+ type: "string"
10
+ },
11
+ {
12
+ name: "name",
13
+ type: "string",
14
+ required: true,
15
+ helperText: 'Every input in a form needs a unique name describing what it gets, e.g. "email"'
16
+ },
17
+ {
18
+ name: "defaultValue",
19
+ type: "string"
20
+ },
21
+ {
22
+ name: "placeholder",
23
+ type: "string",
24
+ defaultValue: "Hello there"
25
+ },
26
+ {
27
+ name: "required",
28
+ type: "boolean",
29
+ defaultValue: false
30
+ }
31
+ ],
32
+ defaultStyles: {
33
+ paddingTop: "10px",
34
+ paddingBottom: "10px",
35
+ paddingLeft: "10px",
36
+ paddingRight: "10px",
37
+ borderRadius: "3px",
38
+ borderWidth: "1px",
39
+ borderStyle: "solid",
40
+ borderColor: "#ccc"
41
+ },
42
+ static: true,
43
+ noWrap: true
44
+ };
45
+ export {
46
+ componentInfo
47
+ };
@@ -0,0 +1,5 @@
1
+ function Textarea(props) {
2
+ return <textarea {...props.attributes} placeholder={props.placeholder} name={props.name} value={props.value} defaultValue={props.defaultValue}></textarea>;
3
+ }
4
+
5
+ export default Textarea;
@@ -0,0 +1,106 @@
1
+ const componentInfo = {
2
+ name: "Video",
3
+ canHaveChildren: true,
4
+ builtIn: true,
5
+ defaultStyles: {
6
+ minHeight: "20px",
7
+ minWidth: "20px"
8
+ },
9
+ image: "https://firebasestorage.googleapis.com/v0/b/builder-3b0a2.appspot.com/o/images%2Fbaseline-videocam-24px%20(1).svg?alt=media&token=49a84e4a-b20e-4977-a650-047f986874bb",
10
+ inputs: [
11
+ {
12
+ name: "video",
13
+ type: "file",
14
+ allowedFileTypes: ["mp4"],
15
+ bubble: true,
16
+ defaultValue: "https://firebasestorage.googleapis.com/v0/b/builder-3b0a2.appspot.com/o/assets%2FKQlEmWDxA0coC3PK6UvkrjwkIGI2%2F28cb070609f546cdbe5efa20e931aa4b?alt=media&token=912e9551-7a7c-4dfb-86b6-3da1537d1a7f",
17
+ required: true
18
+ },
19
+ {
20
+ name: "posterImage",
21
+ type: "file",
22
+ allowedFileTypes: ["jpeg", "png"],
23
+ helperText: "Image to show before the video plays"
24
+ },
25
+ {
26
+ name: "autoPlay",
27
+ type: "boolean",
28
+ defaultValue: true
29
+ },
30
+ {
31
+ name: "controls",
32
+ type: "boolean",
33
+ defaultValue: false
34
+ },
35
+ {
36
+ name: "muted",
37
+ type: "boolean",
38
+ defaultValue: true
39
+ },
40
+ {
41
+ name: "loop",
42
+ type: "boolean",
43
+ defaultValue: true
44
+ },
45
+ {
46
+ name: "playsInline",
47
+ type: "boolean",
48
+ defaultValue: true
49
+ },
50
+ {
51
+ name: "fit",
52
+ type: "text",
53
+ defaultValue: "cover",
54
+ enum: ["contain", "cover", "fill", "auto"]
55
+ },
56
+ {
57
+ name: "fitContent",
58
+ type: "boolean",
59
+ helperText: "When child blocks are provided, fit to them instead of using the aspect ratio",
60
+ defaultValue: true,
61
+ advanced: true
62
+ },
63
+ {
64
+ name: "position",
65
+ type: "text",
66
+ defaultValue: "center",
67
+ enum: [
68
+ "center",
69
+ "top",
70
+ "left",
71
+ "right",
72
+ "bottom",
73
+ "top left",
74
+ "top right",
75
+ "bottom left",
76
+ "bottom right"
77
+ ]
78
+ },
79
+ {
80
+ name: "height",
81
+ type: "number",
82
+ advanced: true
83
+ },
84
+ {
85
+ name: "width",
86
+ type: "number",
87
+ advanced: true
88
+ },
89
+ {
90
+ name: "aspectRatio",
91
+ type: "number",
92
+ advanced: true,
93
+ defaultValue: 0.7004048582995948
94
+ },
95
+ {
96
+ name: "lazyLoad",
97
+ type: "boolean",
98
+ helperText: 'Load this video "lazily" - as in only when a user scrolls near the video. Recommended for optmized performance and bandwidth consumption',
99
+ defaultValue: true,
100
+ advanced: true
101
+ }
102
+ ]
103
+ };
104
+ export {
105
+ componentInfo
106
+ };
@@ -0,0 +1,14 @@
1
+ function Video(props) {
2
+ return <video {...props.attributes} preload="none" style={{
3
+ width: "100%",
4
+ height: "100%",
5
+ ...props.attributes?.style,
6
+ "object-fit": props.fit,
7
+ "object-position": props.position,
8
+ // Hack to get object fit to work as expected and
9
+ // not have the video overflow
10
+ "border-radius": 1
11
+ }} key={props.video || "no-src"} poster={props.posterImage} autoPlay={props.autoPlay} muted={props.muted} controls={props.controls} loop={props.loop}></video>;
12
+ }
13
+
14
+ export default Video;
@@ -0,0 +1,36 @@
1
+ import { createMutable } from "solid-js/store";
2
+ import RenderInlinedStyles from "../render-inlined-styles";
3
+
4
+ function BlockStyles(props) {
5
+ const state = createMutable({
6
+ camelToKebabCase(string) {
7
+ return string.replace(/([a-z0-9]|(?=[A-Z]))([A-Z])/g, "$1-$2").toLowerCase();
8
+ },
9
+
10
+ get css() {
11
+ // TODO: media queries
12
+ const styleObject = props.block.responsiveStyles?.large;
13
+
14
+ if (!styleObject) {
15
+ return "";
16
+ }
17
+
18
+ let str = `.${props.block.id} {`;
19
+
20
+ for (const key in styleObject) {
21
+ const value = styleObject[key];
22
+
23
+ if (typeof value === "string") {
24
+ str += `${state.camelToKebabCase(key)}: ${value};`;
25
+ }
26
+ }
27
+
28
+ str += "}";
29
+ return str;
30
+ }
31
+
32
+ });
33
+ return <RenderInlinedStyles styles={state.css}></RenderInlinedStyles>;
34
+ }
35
+
36
+ export default BlockStyles;