@builder.io/sdk-react-native 3.0.5 → 3.0.6
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/personalization-container/component-info.js +43 -0
- package/lib/browser/commonjs/blocks/personalization-container/component-info.js.map +1 -0
- package/lib/browser/commonjs/blocks/personalization-container/helpers/inlined-fns.js +94 -0
- package/lib/browser/commonjs/blocks/personalization-container/helpers/inlined-fns.js.map +1 -0
- package/lib/browser/commonjs/blocks/personalization-container/helpers.js +76 -0
- package/lib/browser/commonjs/blocks/personalization-container/helpers.js.map +1 -0
- package/lib/browser/commonjs/blocks/personalization-container/index.js +14 -0
- package/lib/browser/commonjs/blocks/personalization-container/index.js.map +1 -0
- package/lib/browser/commonjs/blocks/personalization-container/personalization-container.js +130 -0
- package/lib/browser/commonjs/blocks/personalization-container/personalization-container.js.map +1 -0
- package/lib/browser/commonjs/blocks/personalization-container/personalization-container.types.js +6 -0
- package/lib/browser/commonjs/blocks/personalization-container/personalization-container.types.js.map +1 -0
- package/lib/browser/commonjs/components/blocks/blocks-wrapper.js +2 -1
- package/lib/browser/commonjs/components/blocks/blocks-wrapper.js.map +1 -1
- package/lib/browser/commonjs/constants/builder-registered-components.js +21 -16
- package/lib/browser/commonjs/constants/builder-registered-components.js.map +1 -1
- package/lib/browser/commonjs/constants/sdk-version.js +1 -1
- package/lib/browser/commonjs/helpers/canTrack.js +6 -1
- package/lib/browser/commonjs/helpers/canTrack.js.map +1 -1
- package/lib/browser/commonjs/helpers/user-attributes.js +56 -0
- package/lib/browser/commonjs/helpers/user-attributes.js.map +1 -0
- package/lib/browser/commonjs/scripts/init-editing.js +2 -1
- package/lib/browser/commonjs/scripts/init-editing.js.map +1 -1
- package/lib/browser/module/blocks/personalization-container/component-info.js +37 -0
- package/lib/browser/module/blocks/personalization-container/component-info.js.map +1 -0
- package/lib/browser/module/blocks/personalization-container/helpers/inlined-fns.js +87 -0
- package/lib/browser/module/blocks/personalization-container/helpers/inlined-fns.js.map +1 -0
- package/lib/browser/module/blocks/personalization-container/helpers.js +62 -0
- package/lib/browser/module/blocks/personalization-container/helpers.js.map +1 -0
- package/lib/browser/module/blocks/personalization-container/index.js +2 -0
- package/lib/browser/module/blocks/personalization-container/index.js.map +1 -0
- package/lib/browser/module/blocks/personalization-container/personalization-container.js +121 -0
- package/lib/browser/module/blocks/personalization-container/personalization-container.js.map +1 -0
- package/lib/browser/module/blocks/personalization-container/personalization-container.types.js +2 -0
- package/lib/browser/module/blocks/personalization-container/personalization-container.types.js.map +1 -0
- package/lib/browser/module/components/blocks/blocks-wrapper.js +2 -1
- package/lib/browser/module/components/blocks/blocks-wrapper.js.map +1 -1
- package/lib/browser/module/constants/builder-registered-components.js +6 -1
- package/lib/browser/module/constants/builder-registered-components.js.map +1 -1
- package/lib/browser/module/constants/sdk-version.js +1 -1
- package/lib/browser/module/helpers/canTrack.js +6 -1
- package/lib/browser/module/helpers/canTrack.js.map +1 -1
- package/lib/browser/module/helpers/user-attributes.js +47 -0
- package/lib/browser/module/helpers/user-attributes.js.map +1 -0
- package/lib/browser/module/scripts/init-editing.js +2 -1
- package/lib/browser/module/scripts/init-editing.js.map +1 -1
- package/lib/browser/typescript/blocks/personalization-container/component-info.d.ts +3 -0
- package/lib/browser/typescript/blocks/personalization-container/component-info.d.ts.map +1 -0
- package/lib/browser/typescript/blocks/personalization-container/helpers/inlined-fns.d.ts +9 -0
- package/lib/browser/typescript/blocks/personalization-container/helpers/inlined-fns.d.ts.map +1 -0
- package/lib/browser/typescript/blocks/personalization-container/helpers.d.ts +28 -0
- package/lib/browser/typescript/blocks/personalization-container/helpers.d.ts.map +1 -0
- package/lib/browser/typescript/blocks/personalization-container/index.d.ts +2 -0
- package/lib/browser/typescript/blocks/personalization-container/index.d.ts.map +1 -0
- package/lib/browser/typescript/blocks/personalization-container/personalization-container.d.ts +5 -0
- package/lib/browser/typescript/blocks/personalization-container/personalization-container.d.ts.map +1 -0
- package/lib/browser/typescript/blocks/personalization-container/personalization-container.types.d.ts +15 -0
- package/lib/browser/typescript/blocks/personalization-container/personalization-container.types.d.ts.map +1 -0
- package/lib/browser/typescript/components/blocks/blocks-wrapper.d.ts.map +1 -1
- package/lib/browser/typescript/constants/builder-registered-components.d.ts.map +1 -1
- package/lib/browser/typescript/constants/sdk-version.d.ts +1 -1
- package/lib/browser/typescript/helpers/canTrack.d.ts.map +1 -1
- package/lib/browser/typescript/helpers/user-attributes.d.ts +18 -0
- package/lib/browser/typescript/helpers/user-attributes.d.ts.map +1 -0
- package/lib/browser/typescript/scripts/init-editing.d.ts.map +1 -1
- package/lib/browser/typescript/types/input.d.ts +1 -0
- package/lib/browser/typescript/types/input.d.ts.map +1 -1
- package/lib/edge/commonjs/blocks/personalization-container/component-info.js +43 -0
- package/lib/edge/commonjs/blocks/personalization-container/component-info.js.map +1 -0
- package/lib/edge/commonjs/blocks/personalization-container/helpers/inlined-fns.js +94 -0
- package/lib/edge/commonjs/blocks/personalization-container/helpers/inlined-fns.js.map +1 -0
- package/lib/edge/commonjs/blocks/personalization-container/helpers.js +76 -0
- package/lib/edge/commonjs/blocks/personalization-container/helpers.js.map +1 -0
- package/lib/edge/commonjs/blocks/personalization-container/index.js +14 -0
- package/lib/edge/commonjs/blocks/personalization-container/index.js.map +1 -0
- package/lib/edge/commonjs/blocks/personalization-container/personalization-container.js +130 -0
- package/lib/edge/commonjs/blocks/personalization-container/personalization-container.js.map +1 -0
- package/lib/edge/commonjs/blocks/personalization-container/personalization-container.types.js +6 -0
- package/lib/edge/commonjs/blocks/personalization-container/personalization-container.types.js.map +1 -0
- package/lib/edge/commonjs/components/blocks/blocks-wrapper.js +2 -1
- package/lib/edge/commonjs/components/blocks/blocks-wrapper.js.map +1 -1
- package/lib/edge/commonjs/constants/builder-registered-components.js +21 -16
- package/lib/edge/commonjs/constants/builder-registered-components.js.map +1 -1
- package/lib/edge/commonjs/constants/sdk-version.js +1 -1
- package/lib/edge/commonjs/helpers/canTrack.js +6 -1
- package/lib/edge/commonjs/helpers/canTrack.js.map +1 -1
- package/lib/edge/commonjs/helpers/user-attributes.js +56 -0
- package/lib/edge/commonjs/helpers/user-attributes.js.map +1 -0
- package/lib/edge/commonjs/scripts/init-editing.js +2 -1
- package/lib/edge/commonjs/scripts/init-editing.js.map +1 -1
- package/lib/edge/module/blocks/personalization-container/component-info.js +37 -0
- package/lib/edge/module/blocks/personalization-container/component-info.js.map +1 -0
- package/lib/edge/module/blocks/personalization-container/helpers/inlined-fns.js +87 -0
- package/lib/edge/module/blocks/personalization-container/helpers/inlined-fns.js.map +1 -0
- package/lib/edge/module/blocks/personalization-container/helpers.js +62 -0
- package/lib/edge/module/blocks/personalization-container/helpers.js.map +1 -0
- package/lib/edge/module/blocks/personalization-container/index.js +2 -0
- package/lib/edge/module/blocks/personalization-container/index.js.map +1 -0
- package/lib/edge/module/blocks/personalization-container/personalization-container.js +121 -0
- package/lib/edge/module/blocks/personalization-container/personalization-container.js.map +1 -0
- package/lib/edge/module/blocks/personalization-container/personalization-container.types.js +2 -0
- package/lib/edge/module/blocks/personalization-container/personalization-container.types.js.map +1 -0
- package/lib/edge/module/components/blocks/blocks-wrapper.js +2 -1
- package/lib/edge/module/components/blocks/blocks-wrapper.js.map +1 -1
- package/lib/edge/module/constants/builder-registered-components.js +6 -1
- package/lib/edge/module/constants/builder-registered-components.js.map +1 -1
- package/lib/edge/module/constants/sdk-version.js +1 -1
- package/lib/edge/module/helpers/canTrack.js +6 -1
- package/lib/edge/module/helpers/canTrack.js.map +1 -1
- package/lib/edge/module/helpers/user-attributes.js +47 -0
- package/lib/edge/module/helpers/user-attributes.js.map +1 -0
- package/lib/edge/module/scripts/init-editing.js +2 -1
- package/lib/edge/module/scripts/init-editing.js.map +1 -1
- package/lib/edge/typescript/blocks/personalization-container/component-info.d.ts +3 -0
- package/lib/edge/typescript/blocks/personalization-container/component-info.d.ts.map +1 -0
- package/lib/edge/typescript/blocks/personalization-container/helpers/inlined-fns.d.ts +9 -0
- package/lib/edge/typescript/blocks/personalization-container/helpers/inlined-fns.d.ts.map +1 -0
- package/lib/edge/typescript/blocks/personalization-container/helpers.d.ts +28 -0
- package/lib/edge/typescript/blocks/personalization-container/helpers.d.ts.map +1 -0
- package/lib/edge/typescript/blocks/personalization-container/index.d.ts +2 -0
- package/lib/edge/typescript/blocks/personalization-container/index.d.ts.map +1 -0
- package/lib/edge/typescript/blocks/personalization-container/personalization-container.d.ts +5 -0
- package/lib/edge/typescript/blocks/personalization-container/personalization-container.d.ts.map +1 -0
- package/lib/edge/typescript/blocks/personalization-container/personalization-container.types.d.ts +15 -0
- package/lib/edge/typescript/blocks/personalization-container/personalization-container.types.d.ts.map +1 -0
- package/lib/edge/typescript/components/blocks/blocks-wrapper.d.ts.map +1 -1
- package/lib/edge/typescript/constants/builder-registered-components.d.ts.map +1 -1
- package/lib/edge/typescript/constants/sdk-version.d.ts +1 -1
- package/lib/edge/typescript/helpers/canTrack.d.ts.map +1 -1
- package/lib/edge/typescript/helpers/user-attributes.d.ts +18 -0
- package/lib/edge/typescript/helpers/user-attributes.d.ts.map +1 -0
- package/lib/edge/typescript/scripts/init-editing.d.ts.map +1 -1
- package/lib/edge/typescript/types/input.d.ts +1 -0
- package/lib/edge/typescript/types/input.d.ts.map +1 -1
- package/lib/node/commonjs/blocks/personalization-container/component-info.js +43 -0
- package/lib/node/commonjs/blocks/personalization-container/component-info.js.map +1 -0
- package/lib/node/commonjs/blocks/personalization-container/helpers/inlined-fns.js +94 -0
- package/lib/node/commonjs/blocks/personalization-container/helpers/inlined-fns.js.map +1 -0
- package/lib/node/commonjs/blocks/personalization-container/helpers.js +76 -0
- package/lib/node/commonjs/blocks/personalization-container/helpers.js.map +1 -0
- package/lib/node/commonjs/blocks/personalization-container/index.js +14 -0
- package/lib/node/commonjs/blocks/personalization-container/index.js.map +1 -0
- package/lib/node/commonjs/blocks/personalization-container/personalization-container.js +130 -0
- package/lib/node/commonjs/blocks/personalization-container/personalization-container.js.map +1 -0
- package/lib/node/commonjs/blocks/personalization-container/personalization-container.types.js +6 -0
- package/lib/node/commonjs/blocks/personalization-container/personalization-container.types.js.map +1 -0
- package/lib/node/commonjs/components/blocks/blocks-wrapper.js +2 -1
- package/lib/node/commonjs/components/blocks/blocks-wrapper.js.map +1 -1
- package/lib/node/commonjs/constants/builder-registered-components.js +21 -16
- package/lib/node/commonjs/constants/builder-registered-components.js.map +1 -1
- package/lib/node/commonjs/constants/sdk-version.js +1 -1
- package/lib/node/commonjs/helpers/canTrack.js +6 -1
- package/lib/node/commonjs/helpers/canTrack.js.map +1 -1
- package/lib/node/commonjs/helpers/user-attributes.js +56 -0
- package/lib/node/commonjs/helpers/user-attributes.js.map +1 -0
- package/lib/node/commonjs/scripts/init-editing.js +2 -1
- package/lib/node/commonjs/scripts/init-editing.js.map +1 -1
- package/lib/node/module/blocks/personalization-container/component-info.js +37 -0
- package/lib/node/module/blocks/personalization-container/component-info.js.map +1 -0
- package/lib/node/module/blocks/personalization-container/helpers/inlined-fns.js +87 -0
- package/lib/node/module/blocks/personalization-container/helpers/inlined-fns.js.map +1 -0
- package/lib/node/module/blocks/personalization-container/helpers.js +62 -0
- package/lib/node/module/blocks/personalization-container/helpers.js.map +1 -0
- package/lib/node/module/blocks/personalization-container/index.js +2 -0
- package/lib/node/module/blocks/personalization-container/index.js.map +1 -0
- package/lib/node/module/blocks/personalization-container/personalization-container.js +121 -0
- package/lib/node/module/blocks/personalization-container/personalization-container.js.map +1 -0
- package/lib/node/module/blocks/personalization-container/personalization-container.types.js +2 -0
- package/lib/node/module/blocks/personalization-container/personalization-container.types.js.map +1 -0
- package/lib/node/module/components/blocks/blocks-wrapper.js +2 -1
- package/lib/node/module/components/blocks/blocks-wrapper.js.map +1 -1
- package/lib/node/module/constants/builder-registered-components.js +6 -1
- package/lib/node/module/constants/builder-registered-components.js.map +1 -1
- package/lib/node/module/constants/sdk-version.js +1 -1
- package/lib/node/module/helpers/canTrack.js +6 -1
- package/lib/node/module/helpers/canTrack.js.map +1 -1
- package/lib/node/module/helpers/user-attributes.js +47 -0
- package/lib/node/module/helpers/user-attributes.js.map +1 -0
- package/lib/node/module/scripts/init-editing.js +2 -1
- package/lib/node/module/scripts/init-editing.js.map +1 -1
- package/lib/node/typescript/blocks/personalization-container/component-info.d.ts +3 -0
- package/lib/node/typescript/blocks/personalization-container/component-info.d.ts.map +1 -0
- package/lib/node/typescript/blocks/personalization-container/helpers/inlined-fns.d.ts +9 -0
- package/lib/node/typescript/blocks/personalization-container/helpers/inlined-fns.d.ts.map +1 -0
- package/lib/node/typescript/blocks/personalization-container/helpers.d.ts +28 -0
- package/lib/node/typescript/blocks/personalization-container/helpers.d.ts.map +1 -0
- package/lib/node/typescript/blocks/personalization-container/index.d.ts +2 -0
- package/lib/node/typescript/blocks/personalization-container/index.d.ts.map +1 -0
- package/lib/node/typescript/blocks/personalization-container/personalization-container.d.ts +5 -0
- package/lib/node/typescript/blocks/personalization-container/personalization-container.d.ts.map +1 -0
- package/lib/node/typescript/blocks/personalization-container/personalization-container.types.d.ts +15 -0
- package/lib/node/typescript/blocks/personalization-container/personalization-container.types.d.ts.map +1 -0
- package/lib/node/typescript/components/blocks/blocks-wrapper.d.ts.map +1 -1
- package/lib/node/typescript/constants/builder-registered-components.d.ts.map +1 -1
- package/lib/node/typescript/constants/sdk-version.d.ts +1 -1
- package/lib/node/typescript/helpers/canTrack.d.ts.map +1 -1
- package/lib/node/typescript/helpers/user-attributes.d.ts +18 -0
- package/lib/node/typescript/helpers/user-attributes.d.ts.map +1 -0
- package/lib/node/typescript/scripts/init-editing.d.ts.map +1 -1
- package/lib/node/typescript/types/input.d.ts +1 -0
- package/lib/node/typescript/types/input.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/blocks/personalization-container/component-info.ts +37 -0
- package/src/blocks/personalization-container/helpers/inlined-fns.ts +88 -0
- package/src/blocks/personalization-container/helpers.ts +84 -0
- package/src/blocks/personalization-container/index.ts +1 -0
- package/src/blocks/personalization-container/personalization-container.tsx +176 -0
- package/src/blocks/personalization-container/personalization-container.types.ts +14 -0
- package/src/components/blocks/blocks-wrapper.tsx +4 -1
- package/src/constants/builder-registered-components.ts +6 -1
- package/src/constants/sdk-version.ts +1 -1
- package/src/helpers/canTrack.ts +6 -1
- package/src/helpers/user-attributes.ts +49 -0
- package/src/scripts/init-editing.ts +2 -1
- package/src/types/input.ts +1 -0
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { BuilderBlock } from '../../types/builder-block';
|
|
2
|
+
import type { PersonalizationContainerProps } from './personalization-container.types';
|
|
3
|
+
export type UserAttributes = {
|
|
4
|
+
date?: string | Date;
|
|
5
|
+
urlPath?: string;
|
|
6
|
+
[key: string]: any;
|
|
7
|
+
};
|
|
8
|
+
type QueryOperator = 'is' | 'isNot' | 'contains' | 'startsWith' | 'endsWith' | 'greaterThan' | 'lessThan' | 'greaterThanOrEqualTo' | 'lessThanOrEqualTo';
|
|
9
|
+
type QueryValue = string | number | boolean | Array<string | number | boolean>;
|
|
10
|
+
export type Query = {
|
|
11
|
+
property: string;
|
|
12
|
+
operator: QueryOperator;
|
|
13
|
+
value: QueryValue;
|
|
14
|
+
};
|
|
15
|
+
export declare function checkShouldRenderVariants(variants: PersonalizationContainerProps['variants'], canTrack: boolean): boolean;
|
|
16
|
+
export declare function getBlocksToRender({ variants, previewingIndex, isHydrated, filteredVariants, fallbackBlocks }: {
|
|
17
|
+
variants: PersonalizationContainerProps['variants'];
|
|
18
|
+
previewingIndex?: number | null;
|
|
19
|
+
isHydrated: boolean;
|
|
20
|
+
filteredVariants: PersonalizationContainerProps['variants'];
|
|
21
|
+
fallbackBlocks?: BuilderBlock[];
|
|
22
|
+
}): {
|
|
23
|
+
blocks: BuilderBlock[];
|
|
24
|
+
path: string | undefined;
|
|
25
|
+
};
|
|
26
|
+
export declare const getPersonalizationScript: (variants: PersonalizationContainerProps['variants'], blockId: string, locale?: string) => string;
|
|
27
|
+
export { filterWithCustomTargeting } from './helpers/inlined-fns';
|
|
28
|
+
//# sourceMappingURL=helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../../../src/blocks/personalization-container/helpers.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAE9D,OAAO,KAAK,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AACvF,MAAM,MAAM,cAAc,GAAG;IAC3B,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACpB,CAAC;AACF,KAAK,aAAa,GAAG,IAAI,GAAG,OAAO,GAAG,UAAU,GAAG,YAAY,GAAG,UAAU,GAAG,aAAa,GAAG,UAAU,GAAG,sBAAsB,GAAG,mBAAmB,CAAC;AACzJ,KAAK,UAAU,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,KAAK,CAAC,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC;AAC/E,MAAM,MAAM,KAAK,GAAG;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,aAAa,CAAC;IACxB,KAAK,EAAE,UAAU,CAAC;CACnB,CAAC;AACF,wBAAgB,yBAAyB,CAAC,QAAQ,EAAE,6BAA6B,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,OAAO,WAQ/G;AACD,wBAAgB,iBAAiB,CAAC,EAChC,QAAQ,EACR,eAAe,EACf,UAAU,EACV,gBAAgB,EAChB,cAAc,EACf,EAAE;IACD,QAAQ,EAAE,6BAA6B,CAAC,UAAU,CAAC,CAAC;IACpD,eAAe,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,UAAU,EAAE,OAAO,CAAC;IACpB,gBAAgB,EAAE,6BAA6B,CAAC,UAAU,CAAC,CAAC;IAC5D,cAAc,CAAC,EAAE,YAAY,EAAE,CAAC;CACjC,GAAG;IACF,MAAM,EAAE,YAAY,EAAE,CAAC;IACvB,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;CAC1B,CA+BA;AACD,eAAO,MAAM,wBAAwB,aAAc,6BAA6B,CAAC,UAAU,CAAC,WAAW,MAAM,WAAW,MAAM,WAQ7H,CAAC;AACF,OAAO,EAAE,yBAAyB,EAAE,MAAM,uBAAuB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/blocks/personalization-container/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,6BAA6B,CAAA"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import type { PersonalizationContainerProps } from "./personalization-container.types";
|
|
3
|
+
declare function PersonalizationContainer(props: PersonalizationContainerProps): React.JSX.Element;
|
|
4
|
+
export default PersonalizationContainer;
|
|
5
|
+
//# sourceMappingURL=personalization-container.d.ts.map
|
package/lib/node/typescript/blocks/personalization-container/personalization-container.d.ts.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"personalization-container.d.ts","sourceRoot":"","sources":["../../../../../src/blocks/personalization-container/personalization-container.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AA4B/B,OAAO,KAAK,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AAEvF,iBAAS,wBAAwB,CAAC,KAAK,EAAE,6BAA6B,qBA+IrE;AAED,eAAe,wBAAwB,CAAC"}
|
package/lib/node/typescript/blocks/personalization-container/personalization-container.types.d.ts
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { BuilderBlock } from '../../types/builder-block';
|
|
2
|
+
import type { BuilderDataProps } from '../../types/builder-props';
|
|
3
|
+
import type { Query } from './helpers';
|
|
4
|
+
export type PersonalizationContainerProps = {
|
|
5
|
+
children?: any;
|
|
6
|
+
attributes?: any;
|
|
7
|
+
previewingIndex?: number | null;
|
|
8
|
+
variants?: Array<{
|
|
9
|
+
blocks: BuilderBlock[];
|
|
10
|
+
query: Query[];
|
|
11
|
+
startDate?: string;
|
|
12
|
+
endDate?: string;
|
|
13
|
+
}>;
|
|
14
|
+
} & BuilderDataProps;
|
|
15
|
+
//# sourceMappingURL=personalization-container.types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"personalization-container.types.d.ts","sourceRoot":"","sources":["../../../../../src/blocks/personalization-container/personalization-container.types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AACvC,MAAM,MAAM,6BAA6B,GAAG;IAC1C,QAAQ,CAAC,EAAE,GAAG,CAAC;IACf,UAAU,CAAC,EAAE,GAAG,CAAC;IACjB,eAAe,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,QAAQ,CAAC,EAAE,KAAK,CAAC;QACf,MAAM,EAAE,YAAY,EAAE,CAAC;QACvB,KAAK,EAAE,KAAK,EAAE,CAAC;QACf,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,OAAO,CAAC,EAAE,MAAM,CAAC;KAClB,CAAC,CAAC;CACJ,GAAG,gBAAgB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blocks-wrapper.d.ts","sourceRoot":"","sources":["../../../../../src/components/blocks/blocks-wrapper.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAgB/B,MAAM,MAAM,kBAAkB,GAAG;IAC/B,MAAM,EAAE,YAAY,EAAE,GAAG,SAAS,CAAC;IACnC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3B,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,SAAS,CAAC;IAC3C;;OAEG;IACH,aAAa,EAAE,GAAG,CAAC;IACnB;;OAEG;IACH,kBAAkB,EAAE,GAAG,CAAC;IACxB,QAAQ,CAAC,EAAE,GAAG,CAAC;IACf,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAE9D,iBAAS,aAAa,CAAC,KAAK,EAAE,kBAAkB,
|
|
1
|
+
{"version":3,"file":"blocks-wrapper.d.ts","sourceRoot":"","sources":["../../../../../src/components/blocks/blocks-wrapper.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAgB/B,MAAM,MAAM,kBAAkB,GAAG;IAC/B,MAAM,EAAE,YAAY,EAAE,GAAG,SAAS,CAAC;IACnC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3B,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,SAAS,CAAC;IAC3C;;OAEG;IACH,aAAa,EAAE,GAAG,CAAC;IACnB;;OAEG;IACH,kBAAkB,EAAE,GAAG,CAAC;IACxB,QAAQ,CAAC,EAAE,GAAG,CAAC;IACf,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAE9D,iBAAS,aAAa,CAAC,KAAK,EAAE,kBAAkB,qBA+F/C;AAMD,eAAe,aAAa,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"builder-registered-components.d.ts","sourceRoot":"","sources":["../../../../src/constants/builder-registered-components.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"builder-registered-components.d.ts","sourceRoot":"","sources":["../../../../src/constants/builder-registered-components.ts"],"names":[],"mappings":"AAsBA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAI5D;;;GAGG;AACH,eAAO,MAAM,8BAA8B,EAAE,MAAM,mBAAmB,EAiCzC,CAAA"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export declare const SDK_VERSION = "3.0.
|
|
1
|
+
export declare const SDK_VERSION = "3.0.6";
|
|
2
2
|
//# sourceMappingURL=sdk-version.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"canTrack.d.ts","sourceRoot":"","sources":["../../../../src/helpers/canTrack.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"canTrack.d.ts","sourceRoot":"","sources":["../../../../src/helpers/canTrack.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,kBAAkB,cAAe,OAAO,YAIpD,CAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export interface UserAttributes {
|
|
2
|
+
[key: string]: any;
|
|
3
|
+
}
|
|
4
|
+
export declare const USER_ATTRIBUTES_COOKIE_NAME = "builder.userAttributes";
|
|
5
|
+
export declare function createUserAttributesService(): {
|
|
6
|
+
setUserAttributes(newAttrs: UserAttributes): void;
|
|
7
|
+
getUserAttributes(): any;
|
|
8
|
+
subscribeOnUserAttributesChange(callback: (attrs: UserAttributes) => void): () => void;
|
|
9
|
+
setCanTrack(value: boolean): void;
|
|
10
|
+
};
|
|
11
|
+
export declare const userAttributesService: {
|
|
12
|
+
setUserAttributes(newAttrs: UserAttributes): void;
|
|
13
|
+
getUserAttributes(): any;
|
|
14
|
+
subscribeOnUserAttributesChange(callback: (attrs: UserAttributes) => void): () => void;
|
|
15
|
+
setCanTrack(value: boolean): void;
|
|
16
|
+
};
|
|
17
|
+
export declare const setClientUserAttributes: (attributes: UserAttributes) => void;
|
|
18
|
+
//# sourceMappingURL=user-attributes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user-attributes.d.ts","sourceRoot":"","sources":["../../../../src/helpers/user-attributes.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,cAAc;IAC7B,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACpB;AACD,eAAO,MAAM,2BAA2B,2BAA2B,CAAC;AACpE,wBAAgB,2BAA2B;gCAIX,cAAc;;sDAwBQ,cAAc,KAAK,IAAI;uBAMtD,OAAO;EAI7B;AACD,eAAO,MAAM,qBAAqB;gCAnCF,cAAc;;sDAwBQ,cAAc,KAAK,IAAI;uBAMtD,OAAO;CAKoC,CAAC;AACnE,eAAO,MAAM,uBAAuB,eAAgB,cAAc,SAEjE,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init-editing.d.ts","sourceRoot":"","sources":["../../../../src/scripts/init-editing.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,kBAAkB,YAsB9B,CAAC;AAEF,eAAO,MAAM,sBAAsB,aAAa;IAC9C,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;CACzB,
|
|
1
|
+
{"version":3,"file":"init-editing.d.ts","sourceRoot":"","sources":["../../../../src/scripts/init-editing.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,kBAAkB,YAsB9B,CAAC;AAEF,eAAO,MAAM,sBAAsB,aAAa;IAC9C,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;CACzB,SAqFA,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"input.d.ts","sourceRoot":"","sources":["../../../../src/types/input.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"input.d.ts","sourceRoot":"","sources":["../../../../src/types/input.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@builder.io/sdk-react-native",
|
|
3
3
|
"description": "Builder.io SDK for React Native",
|
|
4
|
-
"version": "3.0.
|
|
4
|
+
"version": "3.0.6",
|
|
5
5
|
"homepage": "https://github.com/BuilderIO/builder/tree/main/packages/sdks/output/react-native",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type { ComponentInfo } from '../../types/components';
|
|
2
|
+
export const componentInfo: ComponentInfo = {
|
|
3
|
+
name: 'PersonalizationContainer',
|
|
4
|
+
shouldReceiveBuilderProps: {
|
|
5
|
+
builderBlock: true,
|
|
6
|
+
builderContext: true
|
|
7
|
+
},
|
|
8
|
+
noWrap: true,
|
|
9
|
+
image: 'https://cdn.builder.io/api/v1/image/assets%2FYJIGb4i01jvw0SRdL5Bt%2F37229ed30d8c41dfb10b8cca1992053a',
|
|
10
|
+
canHaveChildren: true,
|
|
11
|
+
inputs: [{
|
|
12
|
+
name: 'variants',
|
|
13
|
+
defaultValue: [],
|
|
14
|
+
behavior: 'personalizationVariantList',
|
|
15
|
+
type: 'list',
|
|
16
|
+
subFields: [{
|
|
17
|
+
name: 'name',
|
|
18
|
+
type: 'text'
|
|
19
|
+
}, {
|
|
20
|
+
name: 'query',
|
|
21
|
+
friendlyName: 'Targeting rules',
|
|
22
|
+
type: 'BuilderQuery',
|
|
23
|
+
defaultValue: []
|
|
24
|
+
}, {
|
|
25
|
+
name: 'startDate',
|
|
26
|
+
type: 'date'
|
|
27
|
+
}, {
|
|
28
|
+
name: 'endDate',
|
|
29
|
+
type: 'date'
|
|
30
|
+
}, {
|
|
31
|
+
name: 'blocks',
|
|
32
|
+
type: 'uiBlocks',
|
|
33
|
+
hideFromUI: true,
|
|
34
|
+
defaultValue: []
|
|
35
|
+
}]
|
|
36
|
+
}]
|
|
37
|
+
}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WARNING: This file contains functions that get stringified and inlined into the HTML at build-time.
|
|
3
|
+
* They cannot import anything.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import type { Query, UserAttributes } from '../helpers';
|
|
7
|
+
import { type PersonalizationContainerProps } from '../personalization-container.types';
|
|
8
|
+
export function filterWithCustomTargeting(userAttributes: UserAttributes, query: Query[], startDate?: string, endDate?: string) {
|
|
9
|
+
function isString(val: unknown): val is string {
|
|
10
|
+
return typeof val === 'string';
|
|
11
|
+
}
|
|
12
|
+
function isNumber(val: unknown): val is number {
|
|
13
|
+
return typeof val === 'number';
|
|
14
|
+
}
|
|
15
|
+
function objectMatchesQuery(userattr: UserAttributes, query: Query): boolean {
|
|
16
|
+
const result = (() => {
|
|
17
|
+
const property = query.property;
|
|
18
|
+
const operator = query.operator;
|
|
19
|
+
let testValue = query.value;
|
|
20
|
+
if (query && query.property === 'urlPath' && query.value && typeof query.value === 'string' && query.value !== '/' && query.value.endsWith('/')) {
|
|
21
|
+
testValue = query.value.slice(0, -1);
|
|
22
|
+
}
|
|
23
|
+
if (!(property && operator)) {
|
|
24
|
+
return true;
|
|
25
|
+
}
|
|
26
|
+
if (Array.isArray(testValue)) {
|
|
27
|
+
if (operator === 'isNot') {
|
|
28
|
+
return testValue.every(val => objectMatchesQuery(userattr, {
|
|
29
|
+
property,
|
|
30
|
+
operator,
|
|
31
|
+
value: val
|
|
32
|
+
}));
|
|
33
|
+
}
|
|
34
|
+
return !!testValue.find(val => objectMatchesQuery(userattr, {
|
|
35
|
+
property,
|
|
36
|
+
operator,
|
|
37
|
+
value: val
|
|
38
|
+
}));
|
|
39
|
+
}
|
|
40
|
+
const value = userattr[property];
|
|
41
|
+
if (Array.isArray(value)) {
|
|
42
|
+
return value.includes(testValue);
|
|
43
|
+
}
|
|
44
|
+
switch (operator) {
|
|
45
|
+
case 'is':
|
|
46
|
+
return value === testValue;
|
|
47
|
+
case 'isNot':
|
|
48
|
+
return value !== testValue;
|
|
49
|
+
case 'contains':
|
|
50
|
+
return (isString(value) || Array.isArray(value)) && value.includes(String(testValue));
|
|
51
|
+
case 'startsWith':
|
|
52
|
+
return isString(value) && value.startsWith(String(testValue));
|
|
53
|
+
case 'endsWith':
|
|
54
|
+
return isString(value) && value.endsWith(String(testValue));
|
|
55
|
+
case 'greaterThan':
|
|
56
|
+
return isNumber(value) && isNumber(testValue) && value > testValue;
|
|
57
|
+
case 'lessThan':
|
|
58
|
+
return isNumber(value) && isNumber(testValue) && value < testValue;
|
|
59
|
+
case 'greaterThanOrEqualTo':
|
|
60
|
+
return isNumber(value) && isNumber(testValue) && value >= testValue;
|
|
61
|
+
case 'lessThanOrEqualTo':
|
|
62
|
+
return isNumber(value) && isNumber(testValue) && value <= testValue;
|
|
63
|
+
default:
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
})();
|
|
67
|
+
return result;
|
|
68
|
+
}
|
|
69
|
+
const item = {
|
|
70
|
+
query,
|
|
71
|
+
startDate,
|
|
72
|
+
endDate
|
|
73
|
+
};
|
|
74
|
+
const now = userAttributes.date && new Date(userAttributes.date) || new Date();
|
|
75
|
+
if (item.startDate && new Date(item.startDate) > now) {
|
|
76
|
+
return false;
|
|
77
|
+
} else if (item.endDate && new Date(item.endDate) < now) {
|
|
78
|
+
return false;
|
|
79
|
+
}
|
|
80
|
+
if (!item.query || !item.query.length) {
|
|
81
|
+
return true;
|
|
82
|
+
}
|
|
83
|
+
return item.query.every((filter: Query) => {
|
|
84
|
+
return objectMatchesQuery(userAttributes, filter);
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
export const PERSONALIZATION_SCRIPT = "function getPersonalizedVariant(variants, blockId, locale) {\n if (!navigator.cookieEnabled) {\n return;\n }\n function getCookie(name) {\n const nameEQ = name + '=';\n const ca = document.cookie.split(';');\n for (let i = 0; i < ca.length; i++) {\n let c = ca[i];\n while (c.charAt(0) == ' ') c = c.substring(1, c.length);\n if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length, c.length);\n }\n return null;\n }\n function removeVariants() {\n variants?.forEach(function (_, index) {\n document.querySelector('template[data-variant-id=\"' + blockId + '-' + index + '\"]')?.remove();\n });\n document.querySelector('script[data-id=\"variants-script-' + blockId + '\"]')?.remove();\n document.querySelector('style[data-id=\"variants-styles-' + blockId + '\"]')?.remove();\n }\n const attributes = JSON.parse(getCookie('builder.userAttributes') || '{}');\n if (locale) {\n attributes.locale = locale;\n }\n const winningVariantIndex = variants?.findIndex(function (variant) {\n return filterWithCustomTargeting(attributes, variant.query, variant.startDate, variant.endDate);\n });\n const isDebug = location.href.includes('builder.debug=true');\n if (isDebug) {\n console.debug('PersonalizationContainer', {\n attributes,\n variants,\n winningVariantIndex\n });\n }\n if (winningVariantIndex !== -1) {\n const winningVariant = document.querySelector('template[data-variant-id=\"' + blockId + '-' + winningVariantIndex + '\"]');\n if (winningVariant) {\n const parentNode = winningVariant.parentNode;\n if (parentNode) {\n const newParent = parentNode.cloneNode(false);\n newParent.appendChild(winningVariant.content.firstChild);\n newParent.appendChild(winningVariant.content.lastChild);\n parentNode.parentNode?.replaceChild(newParent, parentNode);\n }\n if (isDebug) {\n console.debug('PersonalizationContainer', 'Winning variant Replaced:', winningVariant);\n }\n }\n } else if (variants && variants.length > 0) {\n removeVariants();\n }\n}";
|
|
88
|
+
export const FILTER_WITH_CUSTOM_TARGETING_SCRIPT = "function filterWithCustomTargeting(userAttributes, query, startDate, endDate) {\n function isString(val) {\n return typeof val === 'string';\n }\n function isNumber(val) {\n return typeof val === 'number';\n }\n function objectMatchesQuery(userattr, query) {\n const result = (() => {\n const property = query.property;\n const operator = query.operator;\n let testValue = query.value;\n if (query && query.property === 'urlPath' && query.value && typeof query.value === 'string' && query.value !== '/' && query.value.endsWith('/')) {\n testValue = query.value.slice(0, -1);\n }\n if (!(property && operator)) {\n return true;\n }\n if (Array.isArray(testValue)) {\n if (operator === 'isNot') {\n return testValue.every(val => objectMatchesQuery(userattr, {\n property,\n operator,\n value: val\n }));\n }\n return !!testValue.find(val => objectMatchesQuery(userattr, {\n property,\n operator,\n value: val\n }));\n }\n const value = userattr[property];\n if (Array.isArray(value)) {\n return value.includes(testValue);\n }\n switch (operator) {\n case 'is':\n return value === testValue;\n case 'isNot':\n return value !== testValue;\n case 'contains':\n return (isString(value) || Array.isArray(value)) && value.includes(String(testValue));\n case 'startsWith':\n return isString(value) && value.startsWith(String(testValue));\n case 'endsWith':\n return isString(value) && value.endsWith(String(testValue));\n case 'greaterThan':\n return isNumber(value) && isNumber(testValue) && value > testValue;\n case 'lessThan':\n return isNumber(value) && isNumber(testValue) && value < testValue;\n case 'greaterThanOrEqualTo':\n return isNumber(value) && isNumber(testValue) && value >= testValue;\n case 'lessThanOrEqualTo':\n return isNumber(value) && isNumber(testValue) && value <= testValue;\n default:\n return false;\n }\n })();\n return result;\n }\n const item = {\n query,\n startDate,\n endDate\n };\n const now = userAttributes.date && new Date(userAttributes.date) || new Date();\n if (item.startDate && new Date(item.startDate) > now) {\n return false;\n } else if (item.endDate && new Date(item.endDate) < now) {\n return false;\n }\n if (!item.query || !item.query.length) {\n return true;\n }\n return item.query.every(filter => {\n return objectMatchesQuery(userAttributes, filter);\n });\n}";
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { TARGET } from '../../constants/target';
|
|
2
|
+
import { isBrowser } from '../../functions/is-browser';
|
|
3
|
+
import { isEditing } from '../../functions/is-editing';
|
|
4
|
+
import type { BuilderBlock } from '../../types/builder-block';
|
|
5
|
+
import { FILTER_WITH_CUSTOM_TARGETING_SCRIPT, PERSONALIZATION_SCRIPT } from './helpers/inlined-fns';
|
|
6
|
+
import type { PersonalizationContainerProps } from './personalization-container.types';
|
|
7
|
+
export type UserAttributes = {
|
|
8
|
+
date?: string | Date;
|
|
9
|
+
urlPath?: string;
|
|
10
|
+
[key: string]: any;
|
|
11
|
+
};
|
|
12
|
+
type QueryOperator = 'is' | 'isNot' | 'contains' | 'startsWith' | 'endsWith' | 'greaterThan' | 'lessThan' | 'greaterThanOrEqualTo' | 'lessThanOrEqualTo';
|
|
13
|
+
type QueryValue = string | number | boolean | Array<string | number | boolean>;
|
|
14
|
+
export type Query = {
|
|
15
|
+
property: string;
|
|
16
|
+
operator: QueryOperator;
|
|
17
|
+
value: QueryValue;
|
|
18
|
+
};
|
|
19
|
+
export function checkShouldRenderVariants(variants: PersonalizationContainerProps['variants'], canTrack: boolean) {
|
|
20
|
+
const hasVariants = variants && variants.length > 0;
|
|
21
|
+
if (TARGET === 'reactNative') return false;
|
|
22
|
+
if (!hasVariants) return false;
|
|
23
|
+
if (!canTrack) return false;
|
|
24
|
+
if (TARGET === 'vue' || TARGET === 'svelte') return true;
|
|
25
|
+
if (isBrowser()) return false;
|
|
26
|
+
return true;
|
|
27
|
+
}
|
|
28
|
+
export function getBlocksToRender({
|
|
29
|
+
variants,
|
|
30
|
+
previewingIndex,
|
|
31
|
+
isHydrated,
|
|
32
|
+
filteredVariants,
|
|
33
|
+
fallbackBlocks
|
|
34
|
+
}: {
|
|
35
|
+
variants: PersonalizationContainerProps['variants'];
|
|
36
|
+
previewingIndex?: number | null;
|
|
37
|
+
isHydrated: boolean;
|
|
38
|
+
filteredVariants: PersonalizationContainerProps['variants'];
|
|
39
|
+
fallbackBlocks?: BuilderBlock[];
|
|
40
|
+
}): {
|
|
41
|
+
blocks: BuilderBlock[];
|
|
42
|
+
path: string | undefined;
|
|
43
|
+
} {
|
|
44
|
+
const fallback = {
|
|
45
|
+
blocks: fallbackBlocks ?? [],
|
|
46
|
+
path: 'this.children'
|
|
47
|
+
};
|
|
48
|
+
if (isHydrated && isEditing()) {
|
|
49
|
+
// If editing a specific variant
|
|
50
|
+
if (typeof previewingIndex === 'number' && previewingIndex < (variants?.length ?? 0)) {
|
|
51
|
+
const variant = variants![previewingIndex];
|
|
52
|
+
return {
|
|
53
|
+
blocks: variant.blocks,
|
|
54
|
+
path: `component.options.variants.${previewingIndex}.blocks`
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
// Otherwise we're editing the default variant
|
|
58
|
+
return fallback;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// If we're on the browser, check if there's a winning variant
|
|
62
|
+
if (isBrowser()) {
|
|
63
|
+
const winningVariant = filteredVariants?.[0];
|
|
64
|
+
if (winningVariant) {
|
|
65
|
+
return {
|
|
66
|
+
blocks: winningVariant.blocks,
|
|
67
|
+
path: `component.options.variants.${variants?.indexOf(winningVariant)}.blocks`
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// If no winning variant or we are on the server, return the default variant
|
|
73
|
+
return fallback;
|
|
74
|
+
}
|
|
75
|
+
export const getPersonalizationScript = (variants: PersonalizationContainerProps['variants'], blockId: string, locale?: string) => {
|
|
76
|
+
return `
|
|
77
|
+
(function() {
|
|
78
|
+
${FILTER_WITH_CUSTOM_TARGETING_SCRIPT}
|
|
79
|
+
${PERSONALIZATION_SCRIPT}
|
|
80
|
+
getPersonalizedVariant(${JSON.stringify(variants)}, "${blockId}"${locale ? `, "${locale}"` : ''})
|
|
81
|
+
})();
|
|
82
|
+
`;
|
|
83
|
+
};
|
|
84
|
+
export { filterWithCustomTargeting } from './helpers/inlined-fns'
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './personalization-container'
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import {
|
|
3
|
+
FlatList,
|
|
4
|
+
ScrollView,
|
|
5
|
+
View,
|
|
6
|
+
StyleSheet,
|
|
7
|
+
Image,
|
|
8
|
+
Text,
|
|
9
|
+
Pressable,
|
|
10
|
+
TextInput,
|
|
11
|
+
TouchableOpacity,
|
|
12
|
+
Button,
|
|
13
|
+
Linking,
|
|
14
|
+
} from "react-native";
|
|
15
|
+
import { useState, useRef, useEffect } from "react";
|
|
16
|
+
import Blocks from "../../components/blocks/blocks";
|
|
17
|
+
import InlinedScript from "../../components/inlined-script";
|
|
18
|
+
import InlinedStyles from "../../components/inlined-styles";
|
|
19
|
+
import { isEditing } from "../../functions/is-editing";
|
|
20
|
+
import { isPreviewing } from "../../functions/is-previewing";
|
|
21
|
+
import { getDefaultCanTrack } from "../../helpers/canTrack";
|
|
22
|
+
import { userAttributesService } from "../../helpers/user-attributes";
|
|
23
|
+
import {
|
|
24
|
+
checkShouldRenderVariants,
|
|
25
|
+
filterWithCustomTargeting,
|
|
26
|
+
getBlocksToRender,
|
|
27
|
+
getPersonalizationScript,
|
|
28
|
+
} from "./helpers";
|
|
29
|
+
import type { PersonalizationContainerProps } from "./personalization-container.types";
|
|
30
|
+
|
|
31
|
+
function PersonalizationContainer(props: PersonalizationContainerProps) {
|
|
32
|
+
const rootRef = useRef<HTMLDivElement>(null);
|
|
33
|
+
const [userAttributes, setUserAttributes] = useState(() =>
|
|
34
|
+
userAttributesService.getUserAttributes()
|
|
35
|
+
);
|
|
36
|
+
|
|
37
|
+
const [scriptStr, setScriptStr] = useState(() =>
|
|
38
|
+
getPersonalizationScript(
|
|
39
|
+
props.variants,
|
|
40
|
+
props.builderBlock?.id || "none",
|
|
41
|
+
props.builderContext?.rootState?.locale as string | undefined
|
|
42
|
+
)
|
|
43
|
+
);
|
|
44
|
+
|
|
45
|
+
const [unsubscribers, setUnsubscribers] = useState(() => []);
|
|
46
|
+
|
|
47
|
+
const [shouldRenderVariants, setShouldRenderVariants] = useState(() =>
|
|
48
|
+
checkShouldRenderVariants(
|
|
49
|
+
props.variants,
|
|
50
|
+
getDefaultCanTrack(props.builderContext?.canTrack)
|
|
51
|
+
)
|
|
52
|
+
);
|
|
53
|
+
|
|
54
|
+
const [isHydrated, setIsHydrated] = useState(() => false);
|
|
55
|
+
|
|
56
|
+
function filteredVariants() {
|
|
57
|
+
return (props.variants || []).filter((variant) => {
|
|
58
|
+
return filterWithCustomTargeting(
|
|
59
|
+
{
|
|
60
|
+
...(props.builderContext?.rootState?.locale
|
|
61
|
+
? {
|
|
62
|
+
locale: props.builderContext?.rootState?.locale,
|
|
63
|
+
}
|
|
64
|
+
: {}),
|
|
65
|
+
...(userAttributes as any),
|
|
66
|
+
},
|
|
67
|
+
variant.query,
|
|
68
|
+
variant.startDate,
|
|
69
|
+
variant.endDate
|
|
70
|
+
);
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
function blocksToRender() {
|
|
75
|
+
return getBlocksToRender({
|
|
76
|
+
variants: props.variants,
|
|
77
|
+
fallbackBlocks: props.builderBlock?.children,
|
|
78
|
+
isHydrated: isHydrated,
|
|
79
|
+
filteredVariants: filteredVariants(),
|
|
80
|
+
previewingIndex: props.previewingIndex,
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
function hideVariantsStyleString() {
|
|
85
|
+
return (props.variants || [])
|
|
86
|
+
.map(
|
|
87
|
+
(_, index) =>
|
|
88
|
+
`[data-variant-id="${props.builderBlock?.id}-${index}"] { display: none; } `
|
|
89
|
+
)
|
|
90
|
+
.join("");
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
useEffect(() => {
|
|
94
|
+
setIsHydrated(true);
|
|
95
|
+
const unsub = userAttributesService.subscribeOnUserAttributesChange(
|
|
96
|
+
(attrs) => {
|
|
97
|
+
setUserAttributes(attrs);
|
|
98
|
+
}
|
|
99
|
+
);
|
|
100
|
+
if (!(isEditing() || isPreviewing())) {
|
|
101
|
+
const variant = filteredVariants()[0];
|
|
102
|
+
if (rootRef.current) {
|
|
103
|
+
rootRef.current.dispatchEvent(
|
|
104
|
+
new CustomEvent("builder.variantLoaded", {
|
|
105
|
+
detail: {
|
|
106
|
+
variant: variant || "default",
|
|
107
|
+
content: props.builderContext?.content,
|
|
108
|
+
},
|
|
109
|
+
bubbles: true,
|
|
110
|
+
})
|
|
111
|
+
);
|
|
112
|
+
const observer = new IntersectionObserver((entries) => {
|
|
113
|
+
entries.forEach((entry) => {
|
|
114
|
+
if (entry.isIntersecting && rootRef.current) {
|
|
115
|
+
rootRef.current.dispatchEvent(
|
|
116
|
+
new CustomEvent("builder.variantDisplayed", {
|
|
117
|
+
detail: {
|
|
118
|
+
variant: variant || "default",
|
|
119
|
+
content: props.builderContext?.content,
|
|
120
|
+
},
|
|
121
|
+
bubbles: true,
|
|
122
|
+
})
|
|
123
|
+
);
|
|
124
|
+
}
|
|
125
|
+
});
|
|
126
|
+
});
|
|
127
|
+
observer.observe(rootRef.current);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
unsubscribers.push(unsub);
|
|
131
|
+
}, []);
|
|
132
|
+
|
|
133
|
+
useEffect(() => {
|
|
134
|
+
return () => {
|
|
135
|
+
unsubscribers.forEach((unsub) => unsub());
|
|
136
|
+
};
|
|
137
|
+
}, []);
|
|
138
|
+
|
|
139
|
+
return (
|
|
140
|
+
<View ref={rootRef} {...props.attributes}>
|
|
141
|
+
{shouldRenderVariants ? (
|
|
142
|
+
<>
|
|
143
|
+
{props.variants?.map((variant, index) => (
|
|
144
|
+
<View
|
|
145
|
+
key={index}
|
|
146
|
+
data-variant-id={`${props.builderBlock?.id}-${index}`}
|
|
147
|
+
>
|
|
148
|
+
<Blocks
|
|
149
|
+
blocks={variant.blocks}
|
|
150
|
+
parent={props.builderBlock?.id}
|
|
151
|
+
path={`component.options.variants.${index}.blocks`}
|
|
152
|
+
/>
|
|
153
|
+
</View>
|
|
154
|
+
))}
|
|
155
|
+
<InlinedStyles
|
|
156
|
+
nonce={props.builderContext?.nonce || ""}
|
|
157
|
+
styles={hideVariantsStyleString()}
|
|
158
|
+
id={`variants-styles-${props.builderBlock?.id}`}
|
|
159
|
+
/>
|
|
160
|
+
<InlinedScript
|
|
161
|
+
nonce={props.builderContext?.nonce || ""}
|
|
162
|
+
scriptStr={scriptStr}
|
|
163
|
+
id={`variants-script-${props.builderBlock?.id}`}
|
|
164
|
+
/>
|
|
165
|
+
</>
|
|
166
|
+
) : null}
|
|
167
|
+
<Blocks
|
|
168
|
+
blocks={blocksToRender().blocks}
|
|
169
|
+
parent={props.builderBlock?.id}
|
|
170
|
+
path={blocksToRender().path}
|
|
171
|
+
/>
|
|
172
|
+
</View>
|
|
173
|
+
);
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
export default PersonalizationContainer;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { BuilderBlock } from '../../types/builder-block';
|
|
2
|
+
import type { BuilderDataProps } from '../../types/builder-props';
|
|
3
|
+
import type { Query } from './helpers';
|
|
4
|
+
export type PersonalizationContainerProps = {
|
|
5
|
+
children?: any;
|
|
6
|
+
attributes?: any;
|
|
7
|
+
previewingIndex?: number | null;
|
|
8
|
+
variants?: Array<{
|
|
9
|
+
blocks: BuilderBlock[];
|
|
10
|
+
query: Query[];
|
|
11
|
+
startDate?: string;
|
|
12
|
+
endDate?: string;
|
|
13
|
+
}>;
|
|
14
|
+
} & BuilderDataProps
|
|
@@ -49,8 +49,11 @@ function BlocksWrapper(props: BlocksWrapperProps) {
|
|
|
49
49
|
if (!props.path) {
|
|
50
50
|
return undefined;
|
|
51
51
|
}
|
|
52
|
+
const thisPrefix = "this.";
|
|
52
53
|
const pathPrefix = "component.options.";
|
|
53
|
-
return props.path.startsWith(
|
|
54
|
+
return props.path.startsWith(thisPrefix)
|
|
55
|
+
? props.path.replace(thisPrefix, "")
|
|
56
|
+
: props.path.startsWith(pathPrefix)
|
|
54
57
|
? props.path
|
|
55
58
|
: `${pathPrefix}${props.path || ""}`;
|
|
56
59
|
}
|
|
@@ -8,6 +8,8 @@ import { componentInfo as fragmentComponentInfo } from '../blocks/fragment/compo
|
|
|
8
8
|
import { default as Fragment } from '../blocks/fragment/index';
|
|
9
9
|
import { componentInfo as imageComponentInfo } from '../blocks/image/component-info';
|
|
10
10
|
import { default as Image } from '../blocks/image/index';
|
|
11
|
+
import { componentInfo as personalizationContainerComponentInfo } from '../blocks/personalization-container/component-info';
|
|
12
|
+
import { default as PersonalizationContainer } from '../blocks/personalization-container/index';
|
|
11
13
|
import { componentInfo as sectionComponentInfo } from '../blocks/section/component-info';
|
|
12
14
|
import { default as Section } from '../blocks/section/index';
|
|
13
15
|
import { componentInfo as slotComponentInfo } from '../blocks/slot/component-info';
|
|
@@ -50,7 +52,10 @@ export const getDefaultRegisteredComponents: () => RegisteredComponent[] = () =>
|
|
|
50
52
|
}, {
|
|
51
53
|
component: Text,
|
|
52
54
|
...textComponentInfo
|
|
53
|
-
}, ...(TARGET === '
|
|
55
|
+
}, ...(TARGET === 'react' ? [{
|
|
56
|
+
component: PersonalizationContainer,
|
|
57
|
+
...personalizationContainerComponentInfo
|
|
58
|
+
}] : []), ...(TARGET === 'rsc' ? [] : [{
|
|
54
59
|
component: Tabs,
|
|
55
60
|
...tabsComponentInfo
|
|
56
61
|
}, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export const SDK_VERSION = "3.0.
|
|
1
|
+
export const SDK_VERSION = "3.0.6"
|
package/src/helpers/canTrack.ts
CHANGED
|
@@ -1,2 +1,7 @@
|
|
|
1
1
|
import { checkIsDefined } from './nullable';
|
|
2
|
-
|
|
2
|
+
import { userAttributesService } from './user-attributes';
|
|
3
|
+
export const getDefaultCanTrack = (canTrack?: boolean) => {
|
|
4
|
+
const result = checkIsDefined(canTrack) ? canTrack : true;
|
|
5
|
+
userAttributesService.setCanTrack(result);
|
|
6
|
+
return result;
|
|
7
|
+
}
|