@builder.io/sdk-react-native 2.0.31 → 3.0.1-1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/browser/commonjs/blocks/image/component-info.js +2 -1
- package/lib/browser/commonjs/blocks/image/component-info.js.map +1 -1
- package/lib/browser/commonjs/blocks/img/component-info.js +2 -1
- package/lib/browser/commonjs/blocks/img/component-info.js.map +1 -1
- package/lib/browser/commonjs/blocks/video/component-info.js +3 -2
- package/lib/browser/commonjs/blocks/video/component-info.js.map +1 -1
- package/lib/browser/commonjs/components/block/block.helpers.js +17 -6
- package/lib/browser/commonjs/components/block/block.helpers.js.map +1 -1
- package/lib/browser/commonjs/components/block/block.js +3 -2
- package/lib/browser/commonjs/components/block/block.js.map +1 -1
- package/lib/browser/commonjs/components/blocks/blocks.js +46 -11
- package/lib/browser/commonjs/components/blocks/blocks.js.map +1 -1
- package/lib/browser/commonjs/components/content/components/enable-editor.helpers.js +24 -0
- package/lib/browser/commonjs/components/content/components/enable-editor.helpers.js.map +1 -0
- package/lib/browser/commonjs/components/content/components/enable-editor.js +17 -7
- package/lib/browser/commonjs/components/content/components/enable-editor.js.map +1 -1
- package/lib/browser/commonjs/components/content/content.js +37 -54
- package/lib/browser/commonjs/components/content/content.js.map +1 -1
- package/lib/browser/commonjs/constants/file-types.js +9 -0
- package/lib/browser/commonjs/constants/file-types.js.map +1 -0
- package/lib/browser/commonjs/constants/sdk-version.js +1 -1
- package/lib/browser/commonjs/constants/sdk-version.js.map +1 -1
- package/lib/browser/commonjs/context/builder.context.js +2 -1
- package/lib/browser/commonjs/context/builder.context.js.map +1 -1
- package/lib/browser/commonjs/functions/extract-localized-values.js +45 -0
- package/lib/browser/commonjs/functions/extract-localized-values.js.map +1 -0
- package/lib/browser/commonjs/functions/get-content/index.js +10 -15
- package/lib/browser/commonjs/functions/get-content/index.js.map +1 -1
- package/lib/browser/commonjs/functions/get-processed-block.js +3 -1
- package/lib/browser/commonjs/functions/get-processed-block.js.map +1 -1
- package/lib/browser/commonjs/functions/register-component.js +4 -1
- package/lib/browser/commonjs/functions/register-component.js.map +1 -1
- package/lib/browser/commonjs/functions/traverse.js +69 -0
- package/lib/browser/commonjs/functions/traverse.js.map +1 -0
- package/lib/browser/module/blocks/image/component-info.js +2 -1
- package/lib/browser/module/blocks/image/component-info.js.map +1 -1
- package/lib/browser/module/blocks/img/component-info.js +2 -1
- package/lib/browser/module/blocks/img/component-info.js.map +1 -1
- package/lib/browser/module/blocks/video/component-info.js +3 -2
- package/lib/browser/module/blocks/video/component-info.js.map +1 -1
- package/lib/browser/module/components/block/block.helpers.js +17 -6
- package/lib/browser/module/components/block/block.helpers.js.map +1 -1
- package/lib/browser/module/components/block/block.js +3 -2
- package/lib/browser/module/components/block/block.js.map +1 -1
- package/lib/browser/module/components/blocks/blocks.js +46 -11
- package/lib/browser/module/components/blocks/blocks.js.map +1 -1
- package/lib/browser/module/components/content/components/enable-editor.helpers.js +17 -0
- package/lib/browser/module/components/content/components/enable-editor.helpers.js.map +1 -0
- package/lib/browser/module/components/content/components/enable-editor.js +17 -7
- package/lib/browser/module/components/content/components/enable-editor.js.map +1 -1
- package/lib/browser/module/components/content/content.js +37 -54
- package/lib/browser/module/components/content/content.js.map +1 -1
- package/lib/browser/module/constants/file-types.js +3 -0
- package/lib/browser/module/constants/file-types.js.map +1 -0
- package/lib/browser/module/constants/sdk-version.js +1 -1
- package/lib/browser/module/constants/sdk-version.js.map +1 -1
- package/lib/browser/module/context/builder.context.js +2 -1
- package/lib/browser/module/context/builder.context.js.map +1 -1
- package/lib/browser/module/functions/extract-localized-values.js +39 -0
- package/lib/browser/module/functions/extract-localized-values.js.map +1 -0
- package/lib/browser/module/functions/get-content/index.js +10 -15
- package/lib/browser/module/functions/get-content/index.js.map +1 -1
- package/lib/browser/module/functions/get-processed-block.js +3 -1
- package/lib/browser/module/functions/get-processed-block.js.map +1 -1
- package/lib/browser/module/functions/register-component.js +4 -1
- package/lib/browser/module/functions/register-component.js.map +1 -1
- package/lib/browser/module/functions/traverse.js +63 -0
- package/lib/browser/module/functions/traverse.js.map +1 -0
- package/lib/browser/typescript/blocks/image/component-info.d.ts.map +1 -1
- package/lib/browser/typescript/components/block/block.d.ts.map +1 -1
- package/lib/browser/typescript/components/block/block.helpers.d.ts +6 -3
- package/lib/browser/typescript/components/block/block.helpers.d.ts.map +1 -1
- package/lib/browser/typescript/components/blocks/blocks.d.ts +3 -2
- package/lib/browser/typescript/components/blocks/blocks.d.ts.map +1 -1
- package/lib/browser/typescript/components/content/components/enable-editor.d.ts.map +1 -1
- package/lib/browser/typescript/components/content/components/enable-editor.helpers.d.ts +12 -0
- package/lib/browser/typescript/components/content/components/enable-editor.helpers.d.ts.map +1 -0
- package/lib/browser/typescript/components/content/content.d.ts.map +1 -1
- package/lib/browser/typescript/constants/file-types.d.ts +3 -0
- package/lib/browser/typescript/constants/file-types.d.ts.map +1 -0
- package/lib/browser/typescript/constants/sdk-version.d.ts +1 -1
- package/lib/browser/typescript/constants/sdk-version.d.ts.map +1 -1
- package/lib/browser/typescript/context/builder.context.d.ts.map +1 -1
- package/lib/browser/typescript/context/types.d.ts +1 -0
- package/lib/browser/typescript/context/types.d.ts.map +1 -1
- package/lib/browser/typescript/functions/extract-localized-values.d.ts +3 -0
- package/lib/browser/typescript/functions/extract-localized-values.d.ts.map +1 -0
- package/lib/browser/typescript/functions/get-content/index.d.ts.map +1 -1
- package/lib/browser/typescript/functions/get-processed-block.d.ts.map +1 -1
- package/lib/browser/typescript/functions/register-component.d.ts.map +1 -1
- package/lib/browser/typescript/functions/traverse.d.ts +35 -0
- package/lib/browser/typescript/functions/traverse.d.ts.map +1 -0
- package/lib/browser/typescript/types/components.d.ts +3 -0
- package/lib/browser/typescript/types/components.d.ts.map +1 -1
- package/lib/edge/commonjs/blocks/image/component-info.js +2 -1
- package/lib/edge/commonjs/blocks/image/component-info.js.map +1 -1
- package/lib/edge/commonjs/blocks/img/component-info.js +2 -1
- package/lib/edge/commonjs/blocks/img/component-info.js.map +1 -1
- package/lib/edge/commonjs/blocks/video/component-info.js +3 -2
- package/lib/edge/commonjs/blocks/video/component-info.js.map +1 -1
- package/lib/edge/commonjs/components/block/block.helpers.js +17 -6
- package/lib/edge/commonjs/components/block/block.helpers.js.map +1 -1
- package/lib/edge/commonjs/components/block/block.js +3 -2
- package/lib/edge/commonjs/components/block/block.js.map +1 -1
- package/lib/edge/commonjs/components/blocks/blocks.js +46 -11
- package/lib/edge/commonjs/components/blocks/blocks.js.map +1 -1
- package/lib/edge/commonjs/components/content/components/enable-editor.helpers.js +24 -0
- package/lib/edge/commonjs/components/content/components/enable-editor.helpers.js.map +1 -0
- package/lib/edge/commonjs/components/content/components/enable-editor.js +17 -7
- package/lib/edge/commonjs/components/content/components/enable-editor.js.map +1 -1
- package/lib/edge/commonjs/components/content/content.js +37 -54
- package/lib/edge/commonjs/components/content/content.js.map +1 -1
- package/lib/edge/commonjs/constants/file-types.js +9 -0
- package/lib/edge/commonjs/constants/file-types.js.map +1 -0
- package/lib/edge/commonjs/constants/sdk-version.js +1 -1
- package/lib/edge/commonjs/constants/sdk-version.js.map +1 -1
- package/lib/edge/commonjs/context/builder.context.js +2 -1
- package/lib/edge/commonjs/context/builder.context.js.map +1 -1
- package/lib/edge/commonjs/functions/extract-localized-values.js +45 -0
- package/lib/edge/commonjs/functions/extract-localized-values.js.map +1 -0
- package/lib/edge/commonjs/functions/get-content/index.js +10 -15
- package/lib/edge/commonjs/functions/get-content/index.js.map +1 -1
- package/lib/edge/commonjs/functions/get-processed-block.js +3 -1
- package/lib/edge/commonjs/functions/get-processed-block.js.map +1 -1
- package/lib/edge/commonjs/functions/register-component.js +4 -1
- package/lib/edge/commonjs/functions/register-component.js.map +1 -1
- package/lib/edge/commonjs/functions/traverse.js +69 -0
- package/lib/edge/commonjs/functions/traverse.js.map +1 -0
- package/lib/edge/module/blocks/image/component-info.js +2 -1
- package/lib/edge/module/blocks/image/component-info.js.map +1 -1
- package/lib/edge/module/blocks/img/component-info.js +2 -1
- package/lib/edge/module/blocks/img/component-info.js.map +1 -1
- package/lib/edge/module/blocks/video/component-info.js +3 -2
- package/lib/edge/module/blocks/video/component-info.js.map +1 -1
- package/lib/edge/module/components/block/block.helpers.js +17 -6
- package/lib/edge/module/components/block/block.helpers.js.map +1 -1
- package/lib/edge/module/components/block/block.js +3 -2
- package/lib/edge/module/components/block/block.js.map +1 -1
- package/lib/edge/module/components/blocks/blocks.js +46 -11
- package/lib/edge/module/components/blocks/blocks.js.map +1 -1
- package/lib/edge/module/components/content/components/enable-editor.helpers.js +17 -0
- package/lib/edge/module/components/content/components/enable-editor.helpers.js.map +1 -0
- package/lib/edge/module/components/content/components/enable-editor.js +17 -7
- package/lib/edge/module/components/content/components/enable-editor.js.map +1 -1
- package/lib/edge/module/components/content/content.js +37 -54
- package/lib/edge/module/components/content/content.js.map +1 -1
- package/lib/edge/module/constants/file-types.js +3 -0
- package/lib/edge/module/constants/file-types.js.map +1 -0
- package/lib/edge/module/constants/sdk-version.js +1 -1
- package/lib/edge/module/constants/sdk-version.js.map +1 -1
- package/lib/edge/module/context/builder.context.js +2 -1
- package/lib/edge/module/context/builder.context.js.map +1 -1
- package/lib/edge/module/functions/extract-localized-values.js +39 -0
- package/lib/edge/module/functions/extract-localized-values.js.map +1 -0
- package/lib/edge/module/functions/get-content/index.js +10 -15
- package/lib/edge/module/functions/get-content/index.js.map +1 -1
- package/lib/edge/module/functions/get-processed-block.js +3 -1
- package/lib/edge/module/functions/get-processed-block.js.map +1 -1
- package/lib/edge/module/functions/register-component.js +4 -1
- package/lib/edge/module/functions/register-component.js.map +1 -1
- package/lib/edge/module/functions/traverse.js +63 -0
- package/lib/edge/module/functions/traverse.js.map +1 -0
- package/lib/edge/typescript/blocks/image/component-info.d.ts.map +1 -1
- package/lib/edge/typescript/components/block/block.d.ts.map +1 -1
- package/lib/edge/typescript/components/block/block.helpers.d.ts +6 -3
- package/lib/edge/typescript/components/block/block.helpers.d.ts.map +1 -1
- package/lib/edge/typescript/components/blocks/blocks.d.ts +3 -2
- package/lib/edge/typescript/components/blocks/blocks.d.ts.map +1 -1
- package/lib/edge/typescript/components/content/components/enable-editor.d.ts.map +1 -1
- package/lib/edge/typescript/components/content/components/enable-editor.helpers.d.ts +12 -0
- package/lib/edge/typescript/components/content/components/enable-editor.helpers.d.ts.map +1 -0
- package/lib/edge/typescript/components/content/content.d.ts.map +1 -1
- package/lib/edge/typescript/constants/file-types.d.ts +3 -0
- package/lib/edge/typescript/constants/file-types.d.ts.map +1 -0
- package/lib/edge/typescript/constants/sdk-version.d.ts +1 -1
- package/lib/edge/typescript/constants/sdk-version.d.ts.map +1 -1
- package/lib/edge/typescript/context/builder.context.d.ts.map +1 -1
- package/lib/edge/typescript/context/types.d.ts +1 -0
- package/lib/edge/typescript/context/types.d.ts.map +1 -1
- package/lib/edge/typescript/functions/extract-localized-values.d.ts +3 -0
- package/lib/edge/typescript/functions/extract-localized-values.d.ts.map +1 -0
- package/lib/edge/typescript/functions/get-content/index.d.ts.map +1 -1
- package/lib/edge/typescript/functions/get-processed-block.d.ts.map +1 -1
- package/lib/edge/typescript/functions/register-component.d.ts.map +1 -1
- package/lib/edge/typescript/functions/traverse.d.ts +35 -0
- package/lib/edge/typescript/functions/traverse.d.ts.map +1 -0
- package/lib/edge/typescript/types/components.d.ts +3 -0
- package/lib/edge/typescript/types/components.d.ts.map +1 -1
- package/lib/node/commonjs/blocks/image/component-info.js +2 -1
- package/lib/node/commonjs/blocks/image/component-info.js.map +1 -1
- package/lib/node/commonjs/blocks/img/component-info.js +2 -1
- package/lib/node/commonjs/blocks/img/component-info.js.map +1 -1
- package/lib/node/commonjs/blocks/video/component-info.js +3 -2
- package/lib/node/commonjs/blocks/video/component-info.js.map +1 -1
- package/lib/node/commonjs/components/block/block.helpers.js +17 -6
- package/lib/node/commonjs/components/block/block.helpers.js.map +1 -1
- package/lib/node/commonjs/components/block/block.js +3 -2
- package/lib/node/commonjs/components/block/block.js.map +1 -1
- package/lib/node/commonjs/components/blocks/blocks.js +46 -11
- package/lib/node/commonjs/components/blocks/blocks.js.map +1 -1
- package/lib/node/commonjs/components/content/components/enable-editor.helpers.js +24 -0
- package/lib/node/commonjs/components/content/components/enable-editor.helpers.js.map +1 -0
- package/lib/node/commonjs/components/content/components/enable-editor.js +17 -7
- package/lib/node/commonjs/components/content/components/enable-editor.js.map +1 -1
- package/lib/node/commonjs/components/content/content.js +37 -54
- package/lib/node/commonjs/components/content/content.js.map +1 -1
- package/lib/node/commonjs/constants/file-types.js +9 -0
- package/lib/node/commonjs/constants/file-types.js.map +1 -0
- package/lib/node/commonjs/constants/sdk-version.js +1 -1
- package/lib/node/commonjs/constants/sdk-version.js.map +1 -1
- package/lib/node/commonjs/context/builder.context.js +2 -1
- package/lib/node/commonjs/context/builder.context.js.map +1 -1
- package/lib/node/commonjs/functions/extract-localized-values.js +45 -0
- package/lib/node/commonjs/functions/extract-localized-values.js.map +1 -0
- package/lib/node/commonjs/functions/get-content/index.js +10 -15
- package/lib/node/commonjs/functions/get-content/index.js.map +1 -1
- package/lib/node/commonjs/functions/get-processed-block.js +3 -1
- package/lib/node/commonjs/functions/get-processed-block.js.map +1 -1
- package/lib/node/commonjs/functions/register-component.js +4 -1
- package/lib/node/commonjs/functions/register-component.js.map +1 -1
- package/lib/node/commonjs/functions/traverse.js +69 -0
- package/lib/node/commonjs/functions/traverse.js.map +1 -0
- package/lib/node/module/blocks/image/component-info.js +2 -1
- package/lib/node/module/blocks/image/component-info.js.map +1 -1
- package/lib/node/module/blocks/img/component-info.js +2 -1
- package/lib/node/module/blocks/img/component-info.js.map +1 -1
- package/lib/node/module/blocks/video/component-info.js +3 -2
- package/lib/node/module/blocks/video/component-info.js.map +1 -1
- package/lib/node/module/components/block/block.helpers.js +17 -6
- package/lib/node/module/components/block/block.helpers.js.map +1 -1
- package/lib/node/module/components/block/block.js +3 -2
- package/lib/node/module/components/block/block.js.map +1 -1
- package/lib/node/module/components/blocks/blocks.js +46 -11
- package/lib/node/module/components/blocks/blocks.js.map +1 -1
- package/lib/node/module/components/content/components/enable-editor.helpers.js +17 -0
- package/lib/node/module/components/content/components/enable-editor.helpers.js.map +1 -0
- package/lib/node/module/components/content/components/enable-editor.js +17 -7
- package/lib/node/module/components/content/components/enable-editor.js.map +1 -1
- package/lib/node/module/components/content/content.js +37 -54
- package/lib/node/module/components/content/content.js.map +1 -1
- package/lib/node/module/constants/file-types.js +3 -0
- package/lib/node/module/constants/file-types.js.map +1 -0
- package/lib/node/module/constants/sdk-version.js +1 -1
- package/lib/node/module/constants/sdk-version.js.map +1 -1
- package/lib/node/module/context/builder.context.js +2 -1
- package/lib/node/module/context/builder.context.js.map +1 -1
- package/lib/node/module/functions/extract-localized-values.js +39 -0
- package/lib/node/module/functions/extract-localized-values.js.map +1 -0
- package/lib/node/module/functions/get-content/index.js +10 -15
- package/lib/node/module/functions/get-content/index.js.map +1 -1
- package/lib/node/module/functions/get-processed-block.js +3 -1
- package/lib/node/module/functions/get-processed-block.js.map +1 -1
- package/lib/node/module/functions/register-component.js +4 -1
- package/lib/node/module/functions/register-component.js.map +1 -1
- package/lib/node/module/functions/traverse.js +63 -0
- package/lib/node/module/functions/traverse.js.map +1 -0
- package/lib/node/typescript/blocks/image/component-info.d.ts.map +1 -1
- package/lib/node/typescript/components/block/block.d.ts.map +1 -1
- package/lib/node/typescript/components/block/block.helpers.d.ts +6 -3
- package/lib/node/typescript/components/block/block.helpers.d.ts.map +1 -1
- package/lib/node/typescript/components/blocks/blocks.d.ts +3 -2
- package/lib/node/typescript/components/blocks/blocks.d.ts.map +1 -1
- package/lib/node/typescript/components/content/components/enable-editor.d.ts.map +1 -1
- package/lib/node/typescript/components/content/components/enable-editor.helpers.d.ts +12 -0
- package/lib/node/typescript/components/content/components/enable-editor.helpers.d.ts.map +1 -0
- package/lib/node/typescript/components/content/content.d.ts.map +1 -1
- package/lib/node/typescript/constants/file-types.d.ts +3 -0
- package/lib/node/typescript/constants/file-types.d.ts.map +1 -0
- package/lib/node/typescript/constants/sdk-version.d.ts +1 -1
- package/lib/node/typescript/constants/sdk-version.d.ts.map +1 -1
- package/lib/node/typescript/context/builder.context.d.ts.map +1 -1
- package/lib/node/typescript/context/types.d.ts +1 -0
- package/lib/node/typescript/context/types.d.ts.map +1 -1
- package/lib/node/typescript/functions/extract-localized-values.d.ts +3 -0
- package/lib/node/typescript/functions/extract-localized-values.d.ts.map +1 -0
- package/lib/node/typescript/functions/get-content/index.d.ts.map +1 -1
- package/lib/node/typescript/functions/get-processed-block.d.ts.map +1 -1
- package/lib/node/typescript/functions/register-component.d.ts.map +1 -1
- package/lib/node/typescript/functions/traverse.d.ts +35 -0
- package/lib/node/typescript/functions/traverse.d.ts.map +1 -0
- package/lib/node/typescript/types/components.d.ts +3 -0
- package/lib/node/typescript/types/components.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/blocks/image/component-info.ts +2 -1
- package/src/blocks/img/component-info.ts +2 -1
- package/src/blocks/video/component-info.ts +3 -2
- package/src/components/block/block.helpers.ts +18 -6
- package/src/components/block/block.tsx +3 -1
- package/src/components/blocks/blocks.tsx +89 -54
- package/src/components/content/components/enable-editor.helpers.ts +18 -0
- package/src/components/content/components/enable-editor.tsx +25 -5
- package/src/components/content/content.tsx +3 -10
- package/src/constants/file-types.ts +2 -0
- package/src/constants/sdk-version.ts +1 -1
- package/src/context/builder.context.ts +1 -0
- package/src/context/types.ts +1 -0
- package/src/functions/extract-localized-values.ts +38 -0
- package/src/functions/get-content/index.ts +10 -15
- package/src/functions/get-processed-block.ts +3 -1
- package/src/functions/register-component.ts +4 -1
- package/src/functions/traverse.ts +64 -0
- package/src/types/components.ts +3 -0
|
@@ -1,61 +1,96 @@
|
|
|
1
|
-
import
|
|
1
|
+
import React, {memo, useContext} from 'react';
|
|
2
2
|
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
StyleSheet,
|
|
7
|
-
Image,
|
|
8
|
-
Text,
|
|
9
|
-
Pressable,
|
|
10
|
-
TextInput,
|
|
11
|
-
TouchableOpacity,
|
|
12
|
-
Button,
|
|
13
|
-
Linking,
|
|
14
|
-
} from "react-native";
|
|
15
|
-
import { useContext } from "react";
|
|
3
|
+
FlatList
|
|
4
|
+
} from "react-native";
|
|
5
|
+
|
|
16
6
|
import BuilderContext from "../../context/builder.context";
|
|
17
7
|
import ComponentsContext from "../../context/components.context";
|
|
18
8
|
import Block from "../block/block";
|
|
19
9
|
import BlocksWrapper from "./blocks-wrapper";
|
|
20
10
|
import type { BlocksProps } from "./blocks.types";
|
|
21
11
|
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
{
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
12
|
+
type RenderBlockProps = {
|
|
13
|
+
item: any; // Replace 'any' with your block type
|
|
14
|
+
linkComponent?: React.ComponentType<any>;
|
|
15
|
+
context?: any; // Replace with your context type
|
|
16
|
+
registeredComponents?: any; // Replace with your components type
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
// Moved outside and memoized
|
|
20
|
+
const RenderBlock = memo(({
|
|
21
|
+
item: block,
|
|
22
|
+
linkComponent,
|
|
23
|
+
context,
|
|
24
|
+
registeredComponents
|
|
25
|
+
}: RenderBlockProps) => (
|
|
26
|
+
<Block
|
|
27
|
+
key={block.id}
|
|
28
|
+
block={block}
|
|
29
|
+
linkComponent={linkComponent}
|
|
30
|
+
context={context}
|
|
31
|
+
registeredComponents={registeredComponents}
|
|
32
|
+
/>
|
|
33
|
+
));
|
|
34
|
+
|
|
35
|
+
// Optional: Give the component a display name for better debugging
|
|
36
|
+
RenderBlock.displayName = 'RenderBlock';
|
|
37
|
+
|
|
38
|
+
function Blocks(props: BlocksProps) {
|
|
39
|
+
const builderContext = useContext(BuilderContext);
|
|
40
|
+
const componentsContext = useContext(ComponentsContext);
|
|
41
|
+
|
|
42
|
+
// Memoize renderItem function to prevent unnecessary recreations
|
|
43
|
+
const renderItem = React.useCallback(({ item }: { item: any }) => (
|
|
44
|
+
<RenderBlock
|
|
45
|
+
item={item}
|
|
46
|
+
linkComponent={props.linkComponent}
|
|
47
|
+
context={props.context || builderContext}
|
|
48
|
+
registeredComponents={
|
|
49
|
+
props.registeredComponents || componentsContext?.registeredComponents
|
|
50
|
+
}
|
|
51
|
+
/>
|
|
52
|
+
), [
|
|
53
|
+
props.linkComponent,
|
|
54
|
+
props.context,
|
|
55
|
+
props.registeredComponents,
|
|
56
|
+
builderContext,
|
|
57
|
+
componentsContext?.registeredComponents
|
|
58
|
+
]);
|
|
59
|
+
|
|
60
|
+
// Memoize keyExtractor
|
|
61
|
+
const keyExtractor = React.useCallback((item: any) =>
|
|
62
|
+
item.id.toString()
|
|
63
|
+
, []);
|
|
64
|
+
|
|
65
|
+
return (
|
|
66
|
+
<BlocksWrapper
|
|
67
|
+
blocks={props.blocks}
|
|
68
|
+
parent={props.parent}
|
|
69
|
+
path={props.path}
|
|
70
|
+
styleProp={props.styleProp}
|
|
71
|
+
classNameProp={props.className}
|
|
72
|
+
BlocksWrapper={
|
|
73
|
+
props.context?.BlocksWrapper || builderContext?.BlocksWrapper
|
|
74
|
+
}
|
|
75
|
+
BlocksWrapperProps={
|
|
76
|
+
props.context?.BlocksWrapperProps || builderContext?.BlocksWrapperProps
|
|
77
|
+
}
|
|
78
|
+
>
|
|
79
|
+
{props.blocks ? (
|
|
80
|
+
<FlatList
|
|
81
|
+
data={props.blocks}
|
|
82
|
+
renderItem={renderItem}
|
|
83
|
+
keyExtractor={keyExtractor}
|
|
84
|
+
// Optional: Add these props for better performance
|
|
85
|
+
removeClippedSubviews={true}
|
|
86
|
+
maxToRenderPerBatch={10}
|
|
87
|
+
windowSize={5}
|
|
88
|
+
initialNumToRender={5}
|
|
89
|
+
/>
|
|
90
|
+
) : null}
|
|
91
|
+
</BlocksWrapper>
|
|
92
|
+
);
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
// Memoize the entire Blocks component
|
|
96
|
+
export default memo(Blocks);
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { TARGET } from '../../../constants/target';
|
|
2
|
+
import { isEditing } from '../../../functions/is-editing';
|
|
3
|
+
import { isPreviewing } from '../../../functions/is-previewing';
|
|
4
|
+
import type { Target } from '../../../types/targets';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* SDKS that use the elementRef approach to enable visual editing.
|
|
8
|
+
* We don't need to render the div for other SDKs as they attach event listeners to the window.
|
|
9
|
+
*/
|
|
10
|
+
export const SDKS_USING_ELEMENT_REF_APPROACH = (['svelte', 'qwik', 'vue'] as Target[]);
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* We need to attach this div only when content exists or isPreviewing/isEditing even when content is null,
|
|
14
|
+
* as we need to set the elementRef and allow previewing and visual editing
|
|
15
|
+
*/
|
|
16
|
+
export const needsElementRefDivForEditing = () => {
|
|
17
|
+
return SDKS_USING_ELEMENT_REF_APPROACH.includes(TARGET) && (isEditing() || isPreviewing());
|
|
18
|
+
}
|
|
@@ -55,6 +55,7 @@ import type {
|
|
|
55
55
|
BuilderComponentStateChange,
|
|
56
56
|
ContentProps,
|
|
57
57
|
} from "../content.types";
|
|
58
|
+
import { needsElementRefDivForEditing } from "./enable-editor.helpers";
|
|
58
59
|
import { getWrapperClassName } from "./styles.helpers";
|
|
59
60
|
|
|
60
61
|
function EnableEditor(props: BuilderEditorProps) {
|
|
@@ -249,8 +250,14 @@ function EnableEditor(props: BuilderEditorProps) {
|
|
|
249
250
|
Object.values<ComponentInfo>(
|
|
250
251
|
props.builderContextSignal.componentInfos
|
|
251
252
|
).forEach((registeredComponent) => {
|
|
252
|
-
|
|
253
|
-
|
|
253
|
+
if (
|
|
254
|
+
!props.model ||
|
|
255
|
+
!registeredComponent.models?.length ||
|
|
256
|
+
registeredComponent.models.includes(props.model)
|
|
257
|
+
) {
|
|
258
|
+
const message = createRegisterComponentMessage(registeredComponent);
|
|
259
|
+
window.parent?.postMessage(message, "*");
|
|
260
|
+
}
|
|
254
261
|
});
|
|
255
262
|
window.addEventListener(
|
|
256
263
|
"builder:component:stateChangeListenerActivated",
|
|
@@ -323,8 +330,14 @@ function EnableEditor(props: BuilderEditorProps) {
|
|
|
323
330
|
Object.values<ComponentInfo>(
|
|
324
331
|
props.builderContextSignal.componentInfos
|
|
325
332
|
).forEach((registeredComponent) => {
|
|
326
|
-
|
|
327
|
-
|
|
333
|
+
if (
|
|
334
|
+
!props.model ||
|
|
335
|
+
!registeredComponent.models?.length ||
|
|
336
|
+
registeredComponent.models.includes(props.model)
|
|
337
|
+
) {
|
|
338
|
+
const message = createRegisterComponentMessage(registeredComponent);
|
|
339
|
+
window.parent?.postMessage(message, "*");
|
|
340
|
+
}
|
|
328
341
|
});
|
|
329
342
|
window.addEventListener(
|
|
330
343
|
"builder:component:stateChangeListenerActivated",
|
|
@@ -422,13 +435,20 @@ function EnableEditor(props: BuilderEditorProps) {
|
|
|
422
435
|
|
|
423
436
|
return (
|
|
424
437
|
<builderContext.Provider value={props.builderContextSignal}>
|
|
425
|
-
{props.builderContextSignal.content ? (
|
|
438
|
+
{props.builderContextSignal.content || needsElementRefDivForEditing() ? (
|
|
426
439
|
<ContentWrapper
|
|
427
440
|
{...{}}
|
|
428
441
|
ref={elementRef}
|
|
429
442
|
onClick={(event) => onClick(event)}
|
|
430
443
|
builder-content-id={props.builderContextSignal.content?.id}
|
|
431
444
|
builder-model={props.model}
|
|
445
|
+
style={{
|
|
446
|
+
display:
|
|
447
|
+
!props.builderContextSignal.content &&
|
|
448
|
+
needsElementRefDivForEditing()
|
|
449
|
+
? "none"
|
|
450
|
+
: undefined,
|
|
451
|
+
}}
|
|
432
452
|
{...{
|
|
433
453
|
// currently, we can't set the actual ID here. // we don't need it right now, we just need to identify content divs for testing.
|
|
434
454
|
dataSet: {
|
|
@@ -59,11 +59,7 @@ function ContentComponent(props: ContentProps) {
|
|
|
59
59
|
const [registeredComponents, setRegisteredComponents] = useState(() =>
|
|
60
60
|
[
|
|
61
61
|
...getDefaultRegisteredComponents(),
|
|
62
|
-
...(props.customComponents
|
|
63
|
-
if (!models?.length) return true;
|
|
64
|
-
if (!props.model) return true;
|
|
65
|
-
return models.includes(props.model);
|
|
66
|
-
}) || []),
|
|
62
|
+
...(props.customComponents || []),
|
|
67
63
|
].reduce<RegisteredComponents>(
|
|
68
64
|
(acc, { component, ...info }) => ({
|
|
69
65
|
...acc,
|
|
@@ -96,11 +92,7 @@ function ContentComponent(props: ContentProps) {
|
|
|
96
92
|
apiVersion: props.apiVersion,
|
|
97
93
|
componentInfos: [
|
|
98
94
|
...getDefaultRegisteredComponents(),
|
|
99
|
-
...(props.customComponents
|
|
100
|
-
if (!models?.length) return true;
|
|
101
|
-
if (!props.model) return true;
|
|
102
|
-
return models.includes(props.model);
|
|
103
|
-
}) || []),
|
|
95
|
+
...(props.customComponents || []),
|
|
104
96
|
].reduce<Dictionary<ComponentInfo>>(
|
|
105
97
|
(acc, { component: _, ...info }) => ({
|
|
106
98
|
...acc,
|
|
@@ -112,6 +104,7 @@ function ContentComponent(props: ContentProps) {
|
|
|
112
104
|
BlocksWrapper: props.blocksWrapper || ScrollView,
|
|
113
105
|
BlocksWrapperProps: props.blocksWrapperProps || {},
|
|
114
106
|
nonce: props.nonce || "",
|
|
107
|
+
model: props.model || "",
|
|
115
108
|
}));
|
|
116
109
|
|
|
117
110
|
const hasInitialized = useRef(false);
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export const IMAGE_FILE_TYPES = ['jpeg', 'jpg', 'png', 'svg', 'webp', 'gif', 'jfif', 'pjpeg', 'pjp', 'apng', 'avif', 'tif', 'tiff', 'heif', 'bmp', 'eps', 'raw', 'cr2', 'nef', 'orf', 'sr2', 'psd', 'heic', 'dib', 'ai'];
|
|
2
|
+
export const VIDEO_FILE_TYPES = ['mp4', 'webm', 'mkv', 'flv', 'vob', 'ogv', 'ogg', 'drc', 'gif', 'gifv', 'mng', 'avi', 'mov', 'qt', 'mts', 'm2ts', 'ts', 'wmv', 'yuv', 'rm', 'rmvb', 'viv', 'asf', 'amv', 'm4p', 'mpeg', 'mpe', 'm2v', 'm4v', 'svi', '3gp', '3g2', 'mxf', 'roq', 'nsv', 'f4v', 'f4p', 'f4a', 'f4b']
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export const SDK_VERSION = "
|
|
1
|
+
export const SDK_VERSION = "3.0.1"
|
package/src/context/types.ts
CHANGED
|
@@ -37,5 +37,6 @@ export interface BuilderContextInterface extends Pick<BlocksWrapperProps, 'Block
|
|
|
37
37
|
// Used to recursively store all CSS coming from a parent that would apply to a Text block
|
|
38
38
|
inheritedStyles: Record<string, unknown>;
|
|
39
39
|
nonce: string;
|
|
40
|
+
model: string;
|
|
40
41
|
canTrack?: boolean;
|
|
41
42
|
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { BuilderBlock } from '../types/builder-block';
|
|
2
|
+
import { traverse } from './traverse';
|
|
3
|
+
function isLocalizedField(value: any) {
|
|
4
|
+
return value && typeof value === 'object' && value['@type'] === '@builder.io/core:LocalizedValue';
|
|
5
|
+
}
|
|
6
|
+
function containsLocalizedValues(data: Record<string, any>) {
|
|
7
|
+
if (!data || !Object.getOwnPropertyNames(data).length) {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
10
|
+
let hasLocalizedValues = false;
|
|
11
|
+
traverse(data, value => {
|
|
12
|
+
if (isLocalizedField(value)) {
|
|
13
|
+
hasLocalizedValues = true;
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
return hasLocalizedValues;
|
|
18
|
+
}
|
|
19
|
+
function extractLocalizedValues(data: Record<string, any>, locale: string) {
|
|
20
|
+
if (!data || !Object.getOwnPropertyNames(data).length) {
|
|
21
|
+
return {};
|
|
22
|
+
}
|
|
23
|
+
traverse(data, (value, update) => {
|
|
24
|
+
if (isLocalizedField(value)) {
|
|
25
|
+
update(value[locale] ?? undefined);
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
return data;
|
|
29
|
+
}
|
|
30
|
+
export function resolveLocalizedValues(block: BuilderBlock, locale: string | undefined) {
|
|
31
|
+
if (block.component?.options && containsLocalizedValues(block.component?.options)) {
|
|
32
|
+
if (!locale) {
|
|
33
|
+
console.warn('[Builder.io] In order to use localized fields in Builder, you must pass a locale prop to the BuilderComponent or to options object while fetching the content to resolve localized fields. Learn more: https://www.builder.io/c/docs/localization-inline#targeting-and-inline-localization');
|
|
34
|
+
}
|
|
35
|
+
block.component.options = extractLocalizedValues(block.component.options, locale ?? 'Default');
|
|
36
|
+
}
|
|
37
|
+
return block;
|
|
38
|
+
}
|
|
@@ -88,20 +88,15 @@ export const _processContentResult = async (options: GetContentOptions, content:
|
|
|
88
88
|
* Returns a paginated array of entries that match the given options.
|
|
89
89
|
*/
|
|
90
90
|
export async function fetchEntries(options: GetContentOptions) {
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
return null;
|
|
101
|
-
}
|
|
102
|
-
return _processContentResult(options, content);
|
|
103
|
-
} catch (error) {
|
|
104
|
-
logger.error('Error fetching data. ', error);
|
|
105
|
-
return null;
|
|
91
|
+
const url = generateContentUrl(options);
|
|
92
|
+
const content = await _fetchContent(options);
|
|
93
|
+
if (!checkContentHasResults(content)) {
|
|
94
|
+
logger.error('Error fetching data. ', {
|
|
95
|
+
url,
|
|
96
|
+
content,
|
|
97
|
+
options
|
|
98
|
+
});
|
|
99
|
+
throw content;
|
|
106
100
|
}
|
|
101
|
+
return _processContentResult(options, content);
|
|
107
102
|
}
|
|
@@ -3,6 +3,7 @@ import type { BuilderContextInterface } from '../context/types';
|
|
|
3
3
|
import { omit } from '../helpers/omit';
|
|
4
4
|
import type { BuilderBlock } from '../types/builder-block';
|
|
5
5
|
import { evaluate } from './evaluate/index';
|
|
6
|
+
import { resolveLocalizedValues } from './extract-localized-values';
|
|
6
7
|
import { fastClone } from './fast-clone';
|
|
7
8
|
import { set } from './set';
|
|
8
9
|
import { transformBlock } from './transform-block';
|
|
@@ -96,7 +97,8 @@ export function getProcessedBlock({
|
|
|
96
97
|
*/
|
|
97
98
|
shouldEvaluateBindings: boolean;
|
|
98
99
|
} & Pick<BuilderContextInterface, 'localState' | 'context' | 'rootState' | 'rootSetState'>): BuilderBlock {
|
|
99
|
-
|
|
100
|
+
let transformedBlock = resolveLocalizedValues(block, (rootState.locale as string | undefined));
|
|
101
|
+
transformedBlock = transformBlock(transformedBlock);
|
|
100
102
|
if (shouldEvaluateBindings) {
|
|
101
103
|
return evaluateBindings({
|
|
102
104
|
block: transformedBlock,
|
|
@@ -13,8 +13,11 @@ const serializeFn = (fnValue: Function) => {
|
|
|
13
13
|
// 2. `name(args) => {code}`
|
|
14
14
|
// 3. `(args) => {}`
|
|
15
15
|
// 4. `args => {}`
|
|
16
|
+
// 5. `async function(args) {code}`
|
|
17
|
+
// 6. `async (args) => {}`
|
|
18
|
+
// 7. `async args => {}`
|
|
16
19
|
const isArrowWithoutParens = /^[a-zA-Z0-9_]+\s*=>/i.test(fnStr);
|
|
17
|
-
const appendFunction = !fnStr.startsWith('function') && !fnStr.startsWith('(') && !isArrowWithoutParens;
|
|
20
|
+
const appendFunction = !fnStr.startsWith('function') && !fnStr.startsWith('async') && !fnStr.startsWith('(') && !isArrowWithoutParens;
|
|
18
21
|
return `return (${appendFunction ? 'function ' : ''}${fnStr}).apply(this, arguments)`;
|
|
19
22
|
};
|
|
20
23
|
export function serializeIncludingFunctions(info: ComponentInfo) {
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
type TraverseCallback = (value: any, update: (newValue: any) => void) => void;
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Recursively traverses an object or array, invoking a callback on each value.
|
|
5
|
+
*
|
|
6
|
+
* @param {any} obj - The object or array to traverse. Can also handle primitives, null, or undefined.
|
|
7
|
+
* @param {TraverseCallback} callback - The function to invoke on each value. Receives the current value
|
|
8
|
+
* and an `update` function to modify the value in its parent container.
|
|
9
|
+
* @param {any} [parent=null] - The parent object or array of the current value. Used internally.
|
|
10
|
+
* @param {any} [key=null] - The key or index of the current value in its parent. Used internally.
|
|
11
|
+
* @param {WeakSet} [visited=new WeakSet()] - Tracks visited objects to handle circular references. Used internally.
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* // Example: Doubling all numbers in an object
|
|
15
|
+
* const obj = { a: 1, b: [2, 3, { c: 4 }] };
|
|
16
|
+
* traverse(obj, (value, update) => {
|
|
17
|
+
* if (typeof value === 'number') {
|
|
18
|
+
* update(value * 2);
|
|
19
|
+
* }
|
|
20
|
+
* });
|
|
21
|
+
* console.log(obj); // { a: 2, b: [4, 6, { c: 8 }] }
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* // Example: Handling circular references
|
|
25
|
+
* const obj = { a: 1 };
|
|
26
|
+
* obj.self = obj;
|
|
27
|
+
* traverse(obj, (value, update) => {
|
|
28
|
+
* if (typeof value === 'number') {
|
|
29
|
+
* update(value * 2);
|
|
30
|
+
* }
|
|
31
|
+
* });
|
|
32
|
+
* console.log(obj.a); // 2
|
|
33
|
+
*/
|
|
34
|
+
export function traverse(obj: any, callback: TraverseCallback, parent: any = null, key: any = null, visited = new WeakSet()): void {
|
|
35
|
+
if (obj == null || typeof obj !== 'object') {
|
|
36
|
+
callback(obj, (newValue: any) => {
|
|
37
|
+
if (parent !== null && key !== null) {
|
|
38
|
+
parent[key] = newValue;
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
if (visited.has(obj)) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
visited.add(obj);
|
|
47
|
+
if (Array.isArray(obj)) {
|
|
48
|
+
obj.forEach((item, index) => {
|
|
49
|
+
const update = (newValue: any) => {
|
|
50
|
+
obj[index] = newValue;
|
|
51
|
+
};
|
|
52
|
+
callback(item, update);
|
|
53
|
+
traverse(item, callback, obj, index, visited);
|
|
54
|
+
});
|
|
55
|
+
} else {
|
|
56
|
+
Object.entries(obj).forEach(([key, value]) => {
|
|
57
|
+
const update = (newValue: any) => {
|
|
58
|
+
obj[key] = newValue;
|
|
59
|
+
};
|
|
60
|
+
callback(value, update);
|
|
61
|
+
traverse(value, callback, obj, key, visited);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
}
|
package/src/types/components.ts
CHANGED