@comet/site-react 7.21.0-canary-20250522145352
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/LICENSE +24 -0
- package/lib/blockLoader/blockLoader.d.ts +32 -0
- package/lib/blockLoader/blockLoader.d.ts.map +1 -0
- package/lib/blockLoader/blockLoader.js +57 -0
- package/lib/blocks/PropsWithData.d.ts +4 -0
- package/lib/blocks/PropsWithData.d.ts.map +1 -0
- package/lib/blocks/SvgImageBlock.d.ts +9 -0
- package/lib/blocks/SvgImageBlock.d.ts.map +1 -0
- package/lib/blocks/SvgImageBlock.js +23 -0
- package/lib/blocks/factories/BlocksBlock.d.ts +15 -0
- package/lib/blocks/factories/BlocksBlock.d.ts.map +1 -0
- package/lib/blocks/factories/BlocksBlock.js +30 -0
- package/lib/blocks/factories/ListBlock.d.ts +14 -0
- package/lib/blocks/factories/ListBlock.d.ts.map +1 -0
- package/lib/blocks/factories/ListBlock.js +13 -0
- package/lib/blocks/factories/OneOfBlock.d.ts +15 -0
- package/lib/blocks/factories/OneOfBlock.d.ts.map +1 -0
- package/lib/blocks/factories/OneOfBlock.js +26 -0
- package/lib/blocks/factories/OptionalBlock.d.ts +11 -0
- package/lib/blocks/factories/OptionalBlock.d.ts.map +1 -0
- package/lib/blocks/factories/OptionalBlock.js +10 -0
- package/lib/blocks/factories/types.d.ts +5 -0
- package/lib/blocks/factories/types.d.ts.map +1 -0
- package/lib/blocks/helpers/RichTextBlockHelper.d.ts +3 -0
- package/lib/blocks/helpers/RichTextBlockHelper.d.ts.map +1 -0
- package/lib/blocks/helpers/RichTextBlockHelper.js +7 -0
- package/lib/blocks/helpers/useIsElementInViewport.d.ts +2 -0
- package/lib/blocks/helpers/useIsElementInViewport.d.ts.map +1 -0
- package/lib/blocks/helpers/useIsElementInViewport.js +21 -0
- package/lib/blocks.generated.d.ts +176 -0
- package/lib/blocks.generated.d.ts.map +1 -0
- package/lib/cookies/CookieApiContext.d.ts +14 -0
- package/lib/cookies/CookieApiContext.d.ts.map +1 -0
- package/lib/cookies/CookieApiContext.js +19 -0
- package/lib/cookies/CookieSafe.d.ts +9 -0
- package/lib/cookies/CookieSafe.d.ts.map +1 -0
- package/lib/cookies/CookieSafe.js +19 -0
- package/lib/cookies/useCookieBotCookieApi.d.ts +3 -0
- package/lib/cookies/useCookieBotCookieApi.d.ts.map +1 -0
- package/lib/cookies/useCookieBotCookieApi.js +34 -0
- package/lib/cookies/useLocalStorageCookieApi.d.ts +11 -0
- package/lib/cookies/useLocalStorageCookieApi.d.ts.map +1 -0
- package/lib/cookies/useLocalStorageCookieApi.js +41 -0
- package/lib/cookies/useOneTrustCookieApi.d.ts +3 -0
- package/lib/cookies/useOneTrustCookieApi.d.ts.map +1 -0
- package/lib/cookies/useOneTrustCookieApi.js +49 -0
- package/lib/errorHandler/ErrorHandlerBoundary.d.ts +3 -0
- package/lib/errorHandler/ErrorHandlerBoundary.d.ts.map +1 -0
- package/lib/errorHandler/ErrorHandlerBoundary.js +10 -0
- package/lib/errorHandler/ErrorHandlerBoundaryInternal.d.ts +17 -0
- package/lib/errorHandler/ErrorHandlerBoundaryInternal.d.ts.map +1 -0
- package/lib/errorHandler/ErrorHandlerBoundaryInternal.js +27 -0
- package/lib/errorHandler/ErrorHandlerProvider.d.ts +9 -0
- package/lib/errorHandler/ErrorHandlerProvider.d.ts.map +1 -0
- package/lib/errorHandler/ErrorHandlerProvider.js +22 -0
- package/lib/graphQLFetch/fetchInMemoryCache.d.ts +4 -0
- package/lib/graphQLFetch/fetchInMemoryCache.d.ts.map +1 -0
- package/lib/graphQLFetch/fetchInMemoryCache.js +38 -0
- package/lib/graphQLFetch/graphQLFetch.d.ts +12 -0
- package/lib/graphQLFetch/graphQLFetch.d.ts.map +1 -0
- package/lib/graphQLFetch/graphQLFetch.js +111 -0
- package/lib/iframebridge/IFrameBridge.d.ts +40 -0
- package/lib/iframebridge/IFrameBridge.d.ts.map +1 -0
- package/lib/iframebridge/IFrameBridge.js +239 -0
- package/lib/iframebridge/IFrameBridge.module.scss.js +8 -0
- package/lib/iframebridge/IFrameMessage.d.ts +118 -0
- package/lib/iframebridge/IFrameMessage.d.ts.map +1 -0
- package/lib/iframebridge/IFrameMessage.js +21 -0
- package/lib/iframebridge/Preview.d.ts +9 -0
- package/lib/iframebridge/Preview.d.ts.map +1 -0
- package/lib/iframebridge/Preview.js +57 -0
- package/lib/iframebridge/Preview.module.scss.js +8 -0
- package/lib/iframebridge/PreviewOverlay.d.ts +2 -0
- package/lib/iframebridge/PreviewOverlay.d.ts.map +1 -0
- package/lib/iframebridge/PreviewOverlay.js +27 -0
- package/lib/iframebridge/PreviewOverlay.module.scss.js +8 -0
- package/lib/iframebridge/PreviewOverlayElement.d.ts +7 -0
- package/lib/iframebridge/PreviewOverlayElement.d.ts.map +1 -0
- package/lib/iframebridge/PreviewOverlayElement.js +36 -0
- package/lib/iframebridge/PreviewOverlayElement.module.scss.js +20 -0
- package/lib/iframebridge/useBlockPreviewFetch.d.ts +16 -0
- package/lib/iframebridge/useBlockPreviewFetch.d.ts.map +1 -0
- package/lib/iframebridge/useBlockPreviewFetch.js +29 -0
- package/lib/iframebridge/useIFrameBridge.d.ts +3 -0
- package/lib/iframebridge/useIFrameBridge.d.ts.map +1 -0
- package/lib/iframebridge/useIFrameBridge.js +8 -0
- package/lib/iframebridge/utils.d.ts +10 -0
- package/lib/iframebridge/utils.d.ts.map +1 -0
- package/lib/iframebridge/utils.js +45 -0
- package/lib/iframebridge/withPreview.d.ts +18 -0
- package/lib/iframebridge/withPreview.d.ts.map +1 -0
- package/lib/iframebridge/withPreview.js +34 -0
- package/lib/image/Image.d.ts +8 -0
- package/lib/image/Image.d.ts.map +1 -0
- package/lib/image/Image.js +10 -0
- package/lib/image/image.utils.d.ts +18 -0
- package/lib/image/image.utils.d.ts.map +1 -0
- package/lib/image/image.utils.js +53 -0
- package/lib/index.d.ts +32 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +69 -0
- package/lib/preview/BlockPreviewProvider.d.ts +3 -0
- package/lib/preview/BlockPreviewProvider.d.ts.map +1 -0
- package/lib/preview/BlockPreviewProvider.js +18 -0
- package/lib/preview/PreviewContext.d.ts +9 -0
- package/lib/preview/PreviewContext.d.ts.map +1 -0
- package/lib/preview/PreviewContext.js +11 -0
- package/lib/preview/usePreview.d.ts +11 -0
- package/lib/preview/usePreview.d.ts.map +1 -0
- package/lib/preview/usePreview.js +41 -0
- package/lib/previewskeleton/PreviewSkeleton.d.ts +14 -0
- package/lib/previewskeleton/PreviewSkeleton.d.ts.map +1 -0
- package/lib/previewskeleton/PreviewSkeleton.js +64 -0
- package/lib/previewskeleton/PreviewSkeleton.module.scss.js +17 -0
- package/lib/style.css +1 -0
- package/package.json +84 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
BSD 2-Clause License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2023, Vivid Planet Software GmbH
|
|
4
|
+
|
|
5
|
+
Redistribution and use in source and binary forms, with or without
|
|
6
|
+
modification, are permitted provided that the following conditions are met:
|
|
7
|
+
|
|
8
|
+
1. Redistributions of source code must retain the above copyright notice, this
|
|
9
|
+
list of conditions and the following disclaimer.
|
|
10
|
+
|
|
11
|
+
2. Redistributions in binary form must reproduce the above copyright notice,
|
|
12
|
+
this list of conditions and the following disclaimer in the documentation
|
|
13
|
+
and/or other materials provided with the distribution.
|
|
14
|
+
|
|
15
|
+
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
16
|
+
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
17
|
+
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
18
|
+
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
|
19
|
+
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
20
|
+
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
21
|
+
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
22
|
+
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
23
|
+
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
24
|
+
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { GraphQLFetch } from '../graphQLFetch/graphQLFetch';
|
|
2
|
+
type BlockMetaField = {
|
|
3
|
+
name: string;
|
|
4
|
+
kind: string;
|
|
5
|
+
nullable: boolean;
|
|
6
|
+
enum?: string[];
|
|
7
|
+
block?: string;
|
|
8
|
+
blocks?: Record<string, string>;
|
|
9
|
+
object?: {
|
|
10
|
+
fields: BlockMetaField[];
|
|
11
|
+
};
|
|
12
|
+
};
|
|
13
|
+
interface BlockMeta {
|
|
14
|
+
name: string;
|
|
15
|
+
fields: BlockMetaField[];
|
|
16
|
+
inputFields: BlockMetaField[];
|
|
17
|
+
}
|
|
18
|
+
export type BlockLoader<BlockData = any> = (options: {
|
|
19
|
+
blockData: BlockData;
|
|
20
|
+
} & BlockLoaderDependencies) => Promise<any> | any;
|
|
21
|
+
export interface BlockLoaderDependencies {
|
|
22
|
+
graphQLFetch: GraphQLFetch;
|
|
23
|
+
fetch: typeof fetch;
|
|
24
|
+
}
|
|
25
|
+
export declare function recursivelyLoadBlockData({ blockType, blockData, blocksMeta, loaders, ...dependencies }: {
|
|
26
|
+
blockType: string;
|
|
27
|
+
blockData: unknown;
|
|
28
|
+
blocksMeta: BlockMeta[];
|
|
29
|
+
loaders: Record<string, BlockLoader>;
|
|
30
|
+
} & BlockLoaderDependencies): Promise<any>;
|
|
31
|
+
export {};
|
|
32
|
+
//# sourceMappingURL=blockLoader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"blockLoader.d.ts","sourceRoot":"","sources":["../../src/blockLoader/blockLoader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAEjE,KAAK,cAAc,GAAG;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,MAAM,CAAC,EAAE;QAAE,MAAM,EAAE,cAAc,EAAE,CAAA;KAAE,CAAC;CACzC,CAAC;AAEF,UAAU,SAAS;IACf,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,cAAc,EAAE,CAAC;IACzB,WAAW,EAAE,cAAc,EAAE,CAAC;CACjC;AA+CD,MAAM,MAAM,WAAW,CAAC,SAAS,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE;IAAE,SAAS,EAAE,SAAS,CAAA;CAAE,GAAG,uBAAuB,KAAK,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;AAE/H,MAAM,WAAW,uBAAuB;IACpC,YAAY,EAAE,YAAY,CAAC;IAC3B,KAAK,EAAE,OAAO,KAAK,CAAC;CACvB;AAED,wBAAsB,wBAAwB,CAAC,EAC3C,SAAS,EACT,SAAS,EACT,UAAU,EACV,OAAO,EACP,GAAG,YAAY,EAClB,EAAE;IACC,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,SAAS,EAAE,CAAC;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;CACxC,GAAG,uBAAuB,gBAyD1B"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
async function recursivelyLoadBlockData({
|
|
2
|
+
blockType,
|
|
3
|
+
blockData,
|
|
4
|
+
blocksMeta,
|
|
5
|
+
loaders,
|
|
6
|
+
...dependencies
|
|
7
|
+
}) {
|
|
8
|
+
function iterateField(block, passedBlockData) {
|
|
9
|
+
const blockData2 = { ...passedBlockData };
|
|
10
|
+
for (const field of block.fields) {
|
|
11
|
+
if (!blockData2[field.name]) {
|
|
12
|
+
continue;
|
|
13
|
+
} else if (field.kind == "NestedObjectList") {
|
|
14
|
+
blockData2[field.name] = blockData2[field.name].map((i) => {
|
|
15
|
+
return iterateField(field.object, i);
|
|
16
|
+
});
|
|
17
|
+
} else if (field.kind == "NestedObject") {
|
|
18
|
+
blockData2[field.name] = iterateField(field.object, blockData2[field.name]);
|
|
19
|
+
} else if (field.kind == "OneOfBlocks") {
|
|
20
|
+
const oneOfBlockType = field.blocks[blockData2.type];
|
|
21
|
+
if (!oneOfBlockType)
|
|
22
|
+
throw new Error("invalid blockType");
|
|
23
|
+
blockData2[field.name] = iterateBlock({
|
|
24
|
+
blockType: oneOfBlockType,
|
|
25
|
+
blockData: blockData2[field.name]
|
|
26
|
+
});
|
|
27
|
+
} else if (field.kind == "Block") {
|
|
28
|
+
blockData2[field.name] = iterateBlock({
|
|
29
|
+
blockType: field.block,
|
|
30
|
+
blockData: blockData2[field.name]
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
return blockData2;
|
|
35
|
+
}
|
|
36
|
+
const loadedBlockData = [];
|
|
37
|
+
function iterateBlock({ blockType: blockType2, blockData: blockData2 }) {
|
|
38
|
+
const block = blocksMeta.find((block2) => block2.name === blockType2);
|
|
39
|
+
if (!block)
|
|
40
|
+
throw new Error("invalid blockType");
|
|
41
|
+
const newBlockData = iterateField(block, blockData2);
|
|
42
|
+
if (loaders[blockType2]) {
|
|
43
|
+
newBlockData.loaded = loaders[blockType2]({ blockData: blockData2, ...dependencies });
|
|
44
|
+
loadedBlockData.push(newBlockData);
|
|
45
|
+
}
|
|
46
|
+
return newBlockData;
|
|
47
|
+
}
|
|
48
|
+
const ret = iterateBlock({ blockType, blockData });
|
|
49
|
+
await Promise.all(loadedBlockData.map((blockData2) => blockData2.loaded));
|
|
50
|
+
for (const blockData2 of loadedBlockData) {
|
|
51
|
+
blockData2.loaded = await blockData2.loaded;
|
|
52
|
+
}
|
|
53
|
+
return ret;
|
|
54
|
+
}
|
|
55
|
+
export {
|
|
56
|
+
recursivelyLoadBlockData
|
|
57
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PropsWithData.d.ts","sourceRoot":"","sources":["../../src/blocks/PropsWithData.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa,CAAC,IAAI,GAAG,OAAO;IACzC,IAAI,EAAE,IAAI,CAAC;CACd"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { SvgImageBlockData } from '../blocks.generated';
|
|
2
|
+
import { PropsWithData } from './PropsWithData';
|
|
3
|
+
interface SvgImageBlockProps extends PropsWithData<SvgImageBlockData> {
|
|
4
|
+
width?: string | number | "auto";
|
|
5
|
+
height?: string | number | "auto";
|
|
6
|
+
}
|
|
7
|
+
export declare const SvgImageBlock: ({ ...componentProps }: import('../iframebridge/withPreview').WithPreviewProps & SvgImageBlockProps) => import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=SvgImageBlock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SvgImageBlock.d.ts","sourceRoot":"","sources":["../../src/blocks/SvgImageBlock.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAErD,UAAU,kBAAmB,SAAQ,aAAa,CAAC,iBAAiB,CAAC;IACjE,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;IACjC,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC;CACrC;AAED,eAAO,MAAM,aAAa,iJAazB,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from "react/jsx-runtime";
|
|
3
|
+
import { withPreview } from "../iframebridge/withPreview.js";
|
|
4
|
+
import { PreviewSkeleton } from "../previewskeleton/PreviewSkeleton.js";
|
|
5
|
+
const SvgImageBlock = withPreview(
|
|
6
|
+
({ data: { damFile }, width = "100%", height = "auto" }) => {
|
|
7
|
+
if (!damFile)
|
|
8
|
+
return /* @__PURE__ */ jsx(PreviewSkeleton, { type: "media", hasContent: false, height: height === "auto" ? void 0 : height });
|
|
9
|
+
return /* @__PURE__ */ jsx(
|
|
10
|
+
"img",
|
|
11
|
+
{
|
|
12
|
+
src: damFile.fileUrl,
|
|
13
|
+
width: width === "auto" ? void 0 : width,
|
|
14
|
+
height: height === "auto" ? void 0 : height,
|
|
15
|
+
alt: damFile.altText ?? ""
|
|
16
|
+
}
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
{ label: "SvgImage" }
|
|
20
|
+
);
|
|
21
|
+
export {
|
|
22
|
+
SvgImageBlock
|
|
23
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { SupportedBlocks } from './types';
|
|
2
|
+
interface Props {
|
|
3
|
+
supportedBlocks: SupportedBlocks;
|
|
4
|
+
data: {
|
|
5
|
+
blocks: Array<{
|
|
6
|
+
key: string;
|
|
7
|
+
type: string;
|
|
8
|
+
visible: boolean;
|
|
9
|
+
props: unknown;
|
|
10
|
+
}>;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export declare const BlocksBlock: ({ supportedBlocks, data: { blocks } }: Props) => import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=BlocksBlock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BlocksBlock.d.ts","sourceRoot":"","sources":["../../../src/blocks/factories/BlocksBlock.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,SAAS,CAAC;AAE/C,UAAU,KAAK;IACX,eAAe,EAAE,eAAe,CAAC;IACjC,IAAI,EAAE;QACF,MAAM,EAAE,KAAK,CAAC;YAAE,GAAG,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAC;YAAC,OAAO,EAAE,OAAO,CAAC;YAAC,KAAK,EAAE,OAAO,CAAA;SAAE,CAAC,CAAC;KAClF,CAAC;CACL;AAED,eAAO,MAAM,WAAW,0CAA2C,KAAK,4CA+BvE,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { jsx, Fragment, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Fragment as Fragment$1 } from "react";
|
|
3
|
+
import { ErrorHandlerBoundary } from "../../errorHandler/ErrorHandlerBoundary.js";
|
|
4
|
+
import { PreviewSkeleton } from "../../previewskeleton/PreviewSkeleton.js";
|
|
5
|
+
const BlocksBlock = ({ supportedBlocks, data: { blocks } }) => {
|
|
6
|
+
if (blocks.length === 0) {
|
|
7
|
+
return /* @__PURE__ */ jsx(PreviewSkeleton, { hasContent: false });
|
|
8
|
+
}
|
|
9
|
+
return /* @__PURE__ */ jsx(Fragment, { children: blocks.map((block) => {
|
|
10
|
+
const blockFunction = supportedBlocks[block.type];
|
|
11
|
+
if (!blockFunction) {
|
|
12
|
+
if (process.env.NODE_ENV === "development") {
|
|
13
|
+
return (
|
|
14
|
+
// eslint-disable-next-line @calm/react-intl/missing-formatted-message
|
|
15
|
+
/* @__PURE__ */ jsxs("pre", { children: [
|
|
16
|
+
"Unknown type (",
|
|
17
|
+
block.type,
|
|
18
|
+
"): ",
|
|
19
|
+
JSON.stringify(block.props)
|
|
20
|
+
] }, block.key)
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
return null;
|
|
24
|
+
}
|
|
25
|
+
return /* @__PURE__ */ jsx(Fragment$1, { children: /* @__PURE__ */ jsx(ErrorHandlerBoundary, { children: blockFunction(block.props) }) }, block.key);
|
|
26
|
+
}) });
|
|
27
|
+
};
|
|
28
|
+
export {
|
|
29
|
+
BlocksBlock
|
|
30
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
interface Props {
|
|
3
|
+
block: (props: any) => ReactNode;
|
|
4
|
+
data: {
|
|
5
|
+
blocks: Array<{
|
|
6
|
+
key: string;
|
|
7
|
+
visible: boolean;
|
|
8
|
+
props: unknown;
|
|
9
|
+
}>;
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
export declare const ListBlock: ({ block: blockFunction, data: { blocks } }: Props) => import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=ListBlock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ListBlock.d.ts","sourceRoot":"","sources":["../../../src/blocks/factories/ListBlock.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAY,MAAM,OAAO,CAAC;AAKjD,UAAU,KAAK;IAEX,KAAK,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,SAAS,CAAC;IACjC,IAAI,EAAE;QACF,MAAM,EAAE,KAAK,CAAC;YAAE,GAAG,EAAE,MAAM,CAAC;YAAC,OAAO,EAAE,OAAO,CAAC;YAAC,KAAK,EAAE,OAAO,CAAA;SAAE,CAAC,CAAC;KACpE,CAAC;CACL;AAED,eAAO,MAAM,SAAS,+CAAgD,KAAK,4CAc1E,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx, Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { Fragment as Fragment$1 } from "react";
|
|
3
|
+
import { ErrorHandlerBoundary } from "../../errorHandler/ErrorHandlerBoundary.js";
|
|
4
|
+
import { PreviewSkeleton } from "../../previewskeleton/PreviewSkeleton.js";
|
|
5
|
+
const ListBlock = ({ block: blockFunction, data: { blocks } }) => {
|
|
6
|
+
if (blocks.length === 0) {
|
|
7
|
+
return /* @__PURE__ */ jsx(PreviewSkeleton, { hasContent: false });
|
|
8
|
+
}
|
|
9
|
+
return /* @__PURE__ */ jsx(Fragment, { children: blocks.map((block) => /* @__PURE__ */ jsx(Fragment$1, { children: /* @__PURE__ */ jsx(ErrorHandlerBoundary, { children: blockFunction(block.props) }) }, block.key)) });
|
|
10
|
+
};
|
|
11
|
+
export {
|
|
12
|
+
ListBlock
|
|
13
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { PropsWithChildren } from 'react';
|
|
2
|
+
import { SupportedBlocks } from './types';
|
|
3
|
+
interface Props extends PropsWithChildren {
|
|
4
|
+
data: {
|
|
5
|
+
block?: {
|
|
6
|
+
type: string;
|
|
7
|
+
props: any;
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
supportedBlocks: SupportedBlocks;
|
|
11
|
+
className?: string;
|
|
12
|
+
}
|
|
13
|
+
export declare const OneOfBlock: ({ data: { block, ...additionalProps }, supportedBlocks, children, className }: Props) => import("react/jsx-runtime").JSX.Element | null;
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=OneOfBlock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OneOfBlock.d.ts","sourceRoot":"","sources":["../../../src/blocks/factories/OneOfBlock.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAG/C,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,SAAS,CAAC;AAE/C,UAAU,KAAM,SAAQ,iBAAiB;IACrC,IAAI,EAAE;QACF,KAAK,CAAC,EAAE;YACJ,IAAI,EAAE,MAAM,CAAC;YAEb,KAAK,EAAE,GAAG,CAAC;SACd,CAAC;KACL,CAAC;IACF,eAAe,EAAE,eAAe,CAAC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,UAAU,kFAAmF,KAAK,mDAqB9G,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { jsxs, jsx } from "react/jsx-runtime";
|
|
2
|
+
import { ErrorHandlerBoundary } from "../../errorHandler/ErrorHandlerBoundary.js";
|
|
3
|
+
const OneOfBlock = ({ data: { block, ...additionalProps }, supportedBlocks, children, className }) => {
|
|
4
|
+
if (!block) {
|
|
5
|
+
return null;
|
|
6
|
+
}
|
|
7
|
+
const blockFunction = supportedBlocks[block.type];
|
|
8
|
+
if (!blockFunction) {
|
|
9
|
+
if (process.env.NODE_ENV === "development") {
|
|
10
|
+
return (
|
|
11
|
+
// eslint-disable-next-line @calm/react-intl/missing-formatted-message
|
|
12
|
+
/* @__PURE__ */ jsxs("pre", { children: [
|
|
13
|
+
"Unknown type (",
|
|
14
|
+
block.type,
|
|
15
|
+
"): ",
|
|
16
|
+
JSON.stringify(block.props)
|
|
17
|
+
] })
|
|
18
|
+
);
|
|
19
|
+
}
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
return /* @__PURE__ */ jsx(ErrorHandlerBoundary, { children: blockFunction({ ...block.props, ...additionalProps, children, className }) });
|
|
23
|
+
};
|
|
24
|
+
export {
|
|
25
|
+
OneOfBlock
|
|
26
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { PropsWithChildren, ReactNode } from 'react';
|
|
2
|
+
interface Props extends PropsWithChildren {
|
|
3
|
+
block: (props: any) => ReactNode;
|
|
4
|
+
data: {
|
|
5
|
+
visible: boolean;
|
|
6
|
+
block?: any;
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
export declare const OptionalBlock: ({ block: blockFunction, data: { visible, block }, children }: Props) => import("react/jsx-runtime").JSX.Element | null;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=OptionalBlock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OptionalBlock.d.ts","sourceRoot":"","sources":["../../../src/blocks/factories/OptionalBlock.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,iBAAiB,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAE/D,UAAU,KAAM,SAAQ,iBAAiB;IAErC,KAAK,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,SAAS,CAAC;IACjC,IAAI,EAAE;QACF,OAAO,EAAE,OAAO,CAAC;QAEjB,KAAK,CAAC,EAAE,GAAG,CAAC;KACf,CAAC;CACL;AAED,eAAO,MAAM,aAAa,iEAAkE,KAAK,mDAMhG,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { jsx, Fragment } from "react/jsx-runtime";
|
|
2
|
+
const OptionalBlock = ({ block: blockFunction, data: { visible, block }, children }) => {
|
|
3
|
+
if (!visible || !block) {
|
|
4
|
+
return null;
|
|
5
|
+
}
|
|
6
|
+
return /* @__PURE__ */ jsx(Fragment, { children: blockFunction({ ...block, children }) });
|
|
7
|
+
};
|
|
8
|
+
export {
|
|
9
|
+
OptionalBlock
|
|
10
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/blocks/factories/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,MAAM,WAAW,eAAe;IAE5B,CAAC,GAAG,EAAE,MAAM,GAAG,CAAC,KAAK,EAAE,GAAG,KAAK,SAAS,GAAG,SAAS,CAAC;CACxD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RichTextBlockHelper.d.ts","sourceRoot":"","sources":["../../../src/blocks/helpers/RichTextBlockHelper.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAEhE,eAAO,MAAM,uBAAuB,SAAU,iBAAiB,YAG9D,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useIsElementInViewport.d.ts","sourceRoot":"","sources":["../../../src/blocks/helpers/useIsElementInViewport.tsx"],"names":[],"mappings":"AAIA,eAAO,MAAM,sBAAsB,QAAS,MAAM,SAAS,CAAC,OAAO,CAAC,qBAAqB,OAAO,KAAK,IAAI,SAiBxG,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { useEffect } from "react";
|
|
3
|
+
const useIsElementInViewport = (ref, callback) => {
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
if (!ref.current)
|
|
6
|
+
return;
|
|
7
|
+
const observer = new IntersectionObserver(
|
|
8
|
+
([entry]) => {
|
|
9
|
+
callback(entry.isIntersecting);
|
|
10
|
+
},
|
|
11
|
+
{ threshold: 0.5 }
|
|
12
|
+
);
|
|
13
|
+
observer.observe(ref.current);
|
|
14
|
+
return () => {
|
|
15
|
+
observer.disconnect();
|
|
16
|
+
};
|
|
17
|
+
}, [ref, callback]);
|
|
18
|
+
};
|
|
19
|
+
export {
|
|
20
|
+
useIsElementInViewport
|
|
21
|
+
};
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
export interface AnchorBlockData {
|
|
2
|
+
name?: string;
|
|
3
|
+
}
|
|
4
|
+
export interface DamFileDownloadLinkBlockData {
|
|
5
|
+
file?: {
|
|
6
|
+
id: string;
|
|
7
|
+
name: string;
|
|
8
|
+
fileUrl: string;
|
|
9
|
+
size: number;
|
|
10
|
+
mimetype: string;
|
|
11
|
+
scope?: unknown;
|
|
12
|
+
altText?: string;
|
|
13
|
+
title?: string;
|
|
14
|
+
};
|
|
15
|
+
openFileType: "NewTab" | "Download";
|
|
16
|
+
}
|
|
17
|
+
export interface DamImageBlockData {
|
|
18
|
+
attachedBlocks: Array<{
|
|
19
|
+
type: string;
|
|
20
|
+
props: PixelImageBlockData | SvgImageBlockData;
|
|
21
|
+
}>;
|
|
22
|
+
activeType?: string;
|
|
23
|
+
block?: {
|
|
24
|
+
type: string;
|
|
25
|
+
props: PixelImageBlockData | SvgImageBlockData;
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
export interface DamVideoBlockData {
|
|
29
|
+
autoplay?: boolean;
|
|
30
|
+
showControls?: boolean;
|
|
31
|
+
loop?: boolean;
|
|
32
|
+
previewImage: PixelImageBlockData;
|
|
33
|
+
damFile?: {
|
|
34
|
+
id: string;
|
|
35
|
+
name: string;
|
|
36
|
+
size: number;
|
|
37
|
+
mimetype: string;
|
|
38
|
+
contentHash: string;
|
|
39
|
+
title?: string;
|
|
40
|
+
altText?: string;
|
|
41
|
+
archived: boolean;
|
|
42
|
+
scope?: unknown;
|
|
43
|
+
fileUrl: string;
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
export interface EmailLinkBlockData {
|
|
47
|
+
email?: string;
|
|
48
|
+
}
|
|
49
|
+
export interface ExternalLinkBlockData {
|
|
50
|
+
targetUrl?: string;
|
|
51
|
+
openInNewWindow: boolean;
|
|
52
|
+
}
|
|
53
|
+
export interface InternalLinkBlockData {
|
|
54
|
+
targetPageAnchor?: string;
|
|
55
|
+
targetPage?: {
|
|
56
|
+
id: string;
|
|
57
|
+
name: string;
|
|
58
|
+
path: string;
|
|
59
|
+
scope?: unknown;
|
|
60
|
+
documentType: string;
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
export interface LinkBlockData {
|
|
64
|
+
title?: string;
|
|
65
|
+
attachedBlocks: Array<{
|
|
66
|
+
type: string;
|
|
67
|
+
props: InternalLinkBlockData | ExternalLinkBlockData | EmailLinkBlockData | PhoneLinkBlockData;
|
|
68
|
+
}>;
|
|
69
|
+
activeType?: string;
|
|
70
|
+
block?: {
|
|
71
|
+
type: string;
|
|
72
|
+
props: InternalLinkBlockData | ExternalLinkBlockData | EmailLinkBlockData | PhoneLinkBlockData;
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
export interface OptionalPixelImageBlockData {
|
|
76
|
+
block?: PixelImageBlockData;
|
|
77
|
+
visible: boolean;
|
|
78
|
+
}
|
|
79
|
+
export interface PhoneLinkBlockData {
|
|
80
|
+
phone?: string;
|
|
81
|
+
}
|
|
82
|
+
export interface PixelImageBlockData {
|
|
83
|
+
damFile?: {
|
|
84
|
+
id: string;
|
|
85
|
+
name: string;
|
|
86
|
+
size: number;
|
|
87
|
+
mimetype: string;
|
|
88
|
+
contentHash: string;
|
|
89
|
+
title?: string;
|
|
90
|
+
altText?: string;
|
|
91
|
+
archived: boolean;
|
|
92
|
+
scope?: unknown;
|
|
93
|
+
image?: {
|
|
94
|
+
width: number;
|
|
95
|
+
height: number;
|
|
96
|
+
cropArea: {
|
|
97
|
+
focalPoint: "SMART" | "CENTER" | "NORTHWEST" | "NORTHEAST" | "SOUTHWEST" | "SOUTHEAST";
|
|
98
|
+
width?: number;
|
|
99
|
+
height?: number;
|
|
100
|
+
x?: number;
|
|
101
|
+
y?: number;
|
|
102
|
+
};
|
|
103
|
+
dominantColor?: string;
|
|
104
|
+
};
|
|
105
|
+
fileUrl: string;
|
|
106
|
+
};
|
|
107
|
+
cropArea?: {
|
|
108
|
+
focalPoint: "SMART" | "CENTER" | "NORTHWEST" | "NORTHEAST" | "SOUTHWEST" | "SOUTHEAST";
|
|
109
|
+
width?: number;
|
|
110
|
+
height?: number;
|
|
111
|
+
x?: number;
|
|
112
|
+
y?: number;
|
|
113
|
+
};
|
|
114
|
+
urlTemplate: string;
|
|
115
|
+
}
|
|
116
|
+
export interface RichTextBlockData {
|
|
117
|
+
draftContent: unknown;
|
|
118
|
+
}
|
|
119
|
+
export interface SeoBlockData {
|
|
120
|
+
htmlTitle?: string;
|
|
121
|
+
metaDescription?: string;
|
|
122
|
+
openGraphTitle?: string;
|
|
123
|
+
openGraphDescription?: string;
|
|
124
|
+
openGraphImage: OptionalPixelImageBlockData;
|
|
125
|
+
structuredData?: string;
|
|
126
|
+
noIndex: boolean;
|
|
127
|
+
priority: "0_0" | "0_1" | "0_2" | "0_3" | "0_4" | "0_5" | "0_6" | "0_7" | "0_8" | "0_9" | "1_0";
|
|
128
|
+
changeFrequency: "always" | "hourly" | "daily" | "weekly" | "monthly" | "yearly" | "never";
|
|
129
|
+
canonicalUrl?: string;
|
|
130
|
+
alternativeLinks: Array<{
|
|
131
|
+
code?: string;
|
|
132
|
+
url?: string;
|
|
133
|
+
}>;
|
|
134
|
+
}
|
|
135
|
+
export interface SpaceBlockData {
|
|
136
|
+
height: number;
|
|
137
|
+
}
|
|
138
|
+
export interface SvgImageBlockData {
|
|
139
|
+
damFile?: {
|
|
140
|
+
id: string;
|
|
141
|
+
name: string;
|
|
142
|
+
size: number;
|
|
143
|
+
mimetype: string;
|
|
144
|
+
contentHash: string;
|
|
145
|
+
title?: string;
|
|
146
|
+
altText?: string;
|
|
147
|
+
archived: boolean;
|
|
148
|
+
scope?: unknown;
|
|
149
|
+
fileUrl: string;
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
export interface TextImageBlockData {
|
|
153
|
+
text: RichTextBlockData;
|
|
154
|
+
image: PixelImageBlockData;
|
|
155
|
+
imagePosition: "left" | "right";
|
|
156
|
+
imageAspectRatio: string;
|
|
157
|
+
}
|
|
158
|
+
export interface TextLinkBlockData {
|
|
159
|
+
text: string;
|
|
160
|
+
link: LinkBlockData;
|
|
161
|
+
}
|
|
162
|
+
export interface VimeoVideoBlockData {
|
|
163
|
+
autoplay?: boolean;
|
|
164
|
+
showControls?: boolean;
|
|
165
|
+
loop?: boolean;
|
|
166
|
+
previewImage: PixelImageBlockData;
|
|
167
|
+
vimeoIdentifier?: string;
|
|
168
|
+
}
|
|
169
|
+
export interface YouTubeVideoBlockData {
|
|
170
|
+
autoplay?: boolean;
|
|
171
|
+
showControls?: boolean;
|
|
172
|
+
loop?: boolean;
|
|
173
|
+
previewImage: PixelImageBlockData;
|
|
174
|
+
youtubeIdentifier?: string;
|
|
175
|
+
}
|
|
176
|
+
//# sourceMappingURL=blocks.generated.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"blocks.generated.d.ts","sourceRoot":"","sources":["../src/blocks.generated.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
export type CookieApi = {
|
|
3
|
+
initialized: boolean;
|
|
4
|
+
consentedCookies: string[];
|
|
5
|
+
openCookieSettings: () => void;
|
|
6
|
+
};
|
|
7
|
+
export type CookieApiHook = () => CookieApi;
|
|
8
|
+
type CookieApiProviderProps = React.PropsWithChildren<{
|
|
9
|
+
api: CookieApiHook;
|
|
10
|
+
}>;
|
|
11
|
+
export declare const CookieApiProvider: ({ api: useCookieApi, children }: CookieApiProviderProps) => import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export declare const useCookieApi: CookieApiHook;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=CookieApiContext.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CookieApiContext.d.ts","sourceRoot":"","sources":["../../src/cookies/CookieApiContext.tsx"],"names":[],"mappings":";AAIA,MAAM,MAAM,SAAS,GAAG;IACpB,WAAW,EAAE,OAAO,CAAC;IACrB,gBAAgB,EAAE,MAAM,EAAE,CAAC;IAC3B,kBAAkB,EAAE,MAAM,IAAI,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,MAAM,SAAS,CAAC;AAI5C,KAAK,sBAAsB,GAAG,KAAK,CAAC,iBAAiB,CAAC;IAClD,GAAG,EAAE,aAAa,CAAC;CACtB,CAAC,CAAC;AAEH,eAAO,MAAM,iBAAiB,oCAAqC,sBAAsB,4CAGxF,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,aAM1B,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx } from "react/jsx-runtime";
|
|
3
|
+
import { createContext, useContext } from "react";
|
|
4
|
+
const CookieApiContext = createContext(void 0);
|
|
5
|
+
const CookieApiProvider = ({ api: useCookieApi2, children }) => {
|
|
6
|
+
const api = useCookieApi2();
|
|
7
|
+
return /* @__PURE__ */ jsx(CookieApiContext.Provider, { value: api, children });
|
|
8
|
+
};
|
|
9
|
+
const useCookieApi = () => {
|
|
10
|
+
const cookieApi = useContext(CookieApiContext);
|
|
11
|
+
if (!cookieApi) {
|
|
12
|
+
throw new Error("Can only be used inside CookieApiProvider.");
|
|
13
|
+
}
|
|
14
|
+
return cookieApi;
|
|
15
|
+
};
|
|
16
|
+
export {
|
|
17
|
+
CookieApiProvider,
|
|
18
|
+
useCookieApi
|
|
19
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
type Props = React.PropsWithChildren<{
|
|
3
|
+
consented: boolean;
|
|
4
|
+
fallback: React.ReactNode;
|
|
5
|
+
loading: React.ReactNode;
|
|
6
|
+
}>;
|
|
7
|
+
export declare const CookieSafe: ({ consented, fallback, loading, children }: Props) => import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=CookieSafe.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CookieSafe.d.ts","sourceRoot":"","sources":["../../src/cookies/CookieSafe.tsx"],"names":[],"mappings":";AAKA,KAAK,KAAK,GAAG,KAAK,CAAC,iBAAiB,CAAC;IACjC,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;CAC5B,CAAC,CAAC;AAEH,eAAO,MAAM,UAAU,+CAAgD,KAAK,4CAc3E,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx, Fragment } from "react/jsx-runtime";
|
|
3
|
+
import { usePreview } from "../preview/usePreview.js";
|
|
4
|
+
import { useCookieApi } from "./CookieApiContext.js";
|
|
5
|
+
const CookieSafe = ({ consented, fallback, loading, children }) => {
|
|
6
|
+
const { initialized } = useCookieApi();
|
|
7
|
+
const { previewType } = usePreview();
|
|
8
|
+
const isInPreview = previewType !== "NoPreview";
|
|
9
|
+
if (initialized && consented || isInPreview) {
|
|
10
|
+
return /* @__PURE__ */ jsx(Fragment, { children });
|
|
11
|
+
}
|
|
12
|
+
if (!initialized) {
|
|
13
|
+
return /* @__PURE__ */ jsx(Fragment, { children: loading });
|
|
14
|
+
}
|
|
15
|
+
return /* @__PURE__ */ jsx(Fragment, { children: fallback });
|
|
16
|
+
};
|
|
17
|
+
export {
|
|
18
|
+
CookieSafe
|
|
19
|
+
};
|