@sitecore-content-sdk/core 1.3.0-canary.9 → 1.4.0-canary.2
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/README.md +7 -7
- package/dist/cjs/cache-client.js +55 -54
- package/dist/cjs/client/constants.js +7 -7
- package/dist/cjs/client/edge-proxy.js +24 -22
- package/dist/cjs/client/index.js +15 -15
- package/dist/cjs/client/models.js +2 -2
- package/dist/cjs/client/sitecore-client.js +421 -419
- package/dist/cjs/client/utils.js +47 -46
- package/dist/cjs/config/define-config.js +194 -193
- package/dist/cjs/config/index.js +7 -7
- package/dist/cjs/config/models.js +12 -11
- package/dist/cjs/config-cli/define-cli-config.js +23 -22
- package/dist/cjs/config-cli/index.js +7 -7
- package/dist/cjs/config-cli/models.js +8 -7
- package/dist/cjs/constants.js +49 -17
- package/dist/cjs/debug.js +48 -46
- package/dist/cjs/editing/codegen/index.js +14 -9
- package/dist/cjs/editing/codegen/preview.js +277 -193
- package/dist/cjs/editing/component-layout-service.js +62 -61
- package/dist/cjs/editing/design-library.js +183 -126
- package/dist/cjs/editing/editing-service.js +75 -74
- package/dist/cjs/editing/index.js +33 -27
- package/dist/cjs/editing/metadata.js +42 -42
- package/dist/cjs/editing/models.js +44 -38
- package/dist/cjs/editing/utils.js +108 -90
- package/dist/cjs/form/form.js +81 -78
- package/dist/cjs/form/index.js +7 -7
- package/dist/cjs/graphql-request-client.js +108 -107
- package/dist/cjs/i18n/dictionary-service.js +122 -121
- package/dist/cjs/i18n/index.js +7 -7
- package/dist/cjs/i18n/utils.js +16 -15
- package/dist/cjs/index.js +60 -60
- package/dist/cjs/layout/content-styles.js +72 -71
- package/dist/cjs/layout/index.js +24 -24
- package/dist/cjs/layout/layout-service.js +62 -57
- package/dist/cjs/layout/models.js +39 -34
- package/dist/cjs/layout/themes.js +76 -75
- package/dist/cjs/layout/utils.js +117 -110
- package/dist/cjs/media/index.js +38 -38
- package/dist/cjs/media/media-api.js +100 -96
- package/dist/cjs/models.js +2 -2
- package/dist/cjs/native-fetcher.js +194 -179
- package/dist/cjs/personalize/index.js +15 -15
- package/dist/cjs/personalize/layout-personalizer.js +98 -97
- package/dist/cjs/personalize/personalize-service.js +98 -94
- package/dist/cjs/personalize/utils.js +143 -136
- package/dist/cjs/retries.js +43 -42
- package/dist/cjs/site/error-pages-service.js +65 -64
- package/dist/cjs/site/index.js +26 -26
- package/dist/cjs/site/models.js +2 -2
- package/dist/cjs/site/redirects-service.js +94 -81
- package/dist/cjs/site/robots-service.js +66 -65
- package/dist/cjs/site/site-resolver.js +73 -72
- package/dist/cjs/site/siteinfo-service.js +84 -80
- package/dist/cjs/site/sitemap-xml-service.js +84 -83
- package/dist/cjs/site/sitepath-service.js +165 -164
- package/dist/cjs/site/utils.js +55 -47
- package/dist/cjs/sitecore-service-base.js +36 -36
- package/dist/cjs/tools/auth/flow.js +65 -64
- package/dist/cjs/tools/auth/index.js +5 -5
- package/dist/cjs/tools/auth/models.js +2 -2
- package/dist/cjs/tools/auth/tenant-store.js +38 -38
- package/dist/cjs/tools/codegen/component-generation.js +52 -50
- package/dist/cjs/tools/codegen/extract-files.js +105 -107
- package/dist/cjs/tools/codegen/import-map.js +401 -349
- package/dist/cjs/tools/codegen/utils.js +418 -418
- package/dist/cjs/tools/generate-map.js +2 -2
- package/dist/cjs/tools/generateMetadata.js +36 -35
- package/dist/cjs/tools/generateSites.js +59 -58
- package/dist/cjs/tools/index.js +75 -73
- package/dist/cjs/tools/scaffold.js +60 -59
- package/dist/cjs/tools/templating/components.js +96 -266
- package/dist/cjs/tools/templating/index.js +11 -14
- package/dist/cjs/tools/templating/plugins.js +80 -78
- package/dist/cjs/tools/templating/utils.js +67 -66
- package/dist/cjs/utils/ensurePath.js +20 -20
- package/dist/cjs/utils/env.js +28 -27
- package/dist/cjs/utils/globalCache.js +55 -0
- package/dist/cjs/utils/index.js +26 -21
- package/dist/cjs/utils/is-server.js +11 -10
- package/dist/cjs/utils/normalize-url.js +5 -5
- package/dist/cjs/utils/timeout-promise.js +31 -31
- package/dist/cjs/utils/utils.js +254 -229
- package/dist/esm/cache-client.js +51 -50
- package/dist/esm/client/constants.js +4 -4
- package/dist/esm/client/edge-proxy.js +19 -17
- package/dist/esm/client/index.js +5 -5
- package/dist/esm/client/models.js +1 -1
- package/dist/esm/client/sitecore-client.js +414 -412
- package/dist/esm/client/utils.js +43 -42
- package/dist/esm/config/define-config.js +188 -187
- package/dist/esm/config/index.js +2 -2
- package/dist/esm/config/models.js +9 -8
- package/dist/esm/config-cli/define-cli-config.js +19 -18
- package/dist/esm/config-cli/index.js +2 -2
- package/dist/esm/config-cli/models.js +5 -4
- package/dist/esm/constants.js +46 -14
- package/dist/esm/debug.js +41 -39
- package/dist/esm/editing/codegen/index.js +1 -1
- package/dist/esm/editing/codegen/preview.js +263 -185
- package/dist/esm/editing/component-layout-service.js +55 -54
- package/dist/esm/editing/design-library.js +171 -117
- package/dist/esm/editing/editing-service.js +68 -67
- package/dist/esm/editing/index.js +6 -5
- package/dist/esm/editing/metadata.js +39 -39
- package/dist/esm/editing/models.js +41 -35
- package/dist/esm/editing/utils.js +98 -80
- package/dist/esm/form/form.js +72 -69
- package/dist/esm/form/index.js +1 -1
- package/dist/esm/graphql-request-client.js +101 -100
- package/dist/esm/i18n/dictionary-service.js +115 -114
- package/dist/esm/i18n/index.js +2 -2
- package/dist/esm/i18n/utils.js +13 -12
- package/dist/esm/index.js +13 -13
- package/dist/esm/layout/content-styles.js +64 -63
- package/dist/esm/layout/index.js +6 -6
- package/dist/esm/layout/layout-service.js +55 -50
- package/dist/esm/layout/models.js +36 -31
- package/dist/esm/layout/themes.js +71 -70
- package/dist/esm/layout/utils.js +109 -102
- package/dist/esm/media/index.js +2 -2
- package/dist/esm/media/media-api.js +90 -86
- package/dist/esm/models.js +1 -1
- package/dist/esm/native-fetcher.js +187 -172
- package/dist/esm/personalize/index.js +3 -3
- package/dist/esm/personalize/layout-personalizer.js +93 -92
- package/dist/esm/personalize/personalize-service.js +91 -87
- package/dist/esm/personalize/utils.js +135 -128
- package/dist/esm/retries.js +39 -38
- package/dist/esm/site/error-pages-service.js +58 -57
- package/dist/esm/site/index.js +8 -8
- package/dist/esm/site/models.js +1 -1
- package/dist/esm/site/redirects-service.js +87 -74
- package/dist/esm/site/robots-service.js +59 -58
- package/dist/esm/site/site-resolver.js +69 -68
- package/dist/esm/site/siteinfo-service.js +77 -73
- package/dist/esm/site/sitemap-xml-service.js +77 -76
- package/dist/esm/site/sitepath-service.js +157 -156
- package/dist/esm/site/utils.js +49 -41
- package/dist/esm/sitecore-service-base.js +29 -29
- package/dist/esm/tools/auth/flow.js +62 -61
- package/dist/esm/tools/auth/index.js +1 -1
- package/dist/esm/tools/auth/models.js +1 -1
- package/dist/esm/tools/auth/tenant-store.js +35 -35
- package/dist/esm/tools/codegen/component-generation.js +44 -42
- package/dist/esm/tools/codegen/extract-files.js +99 -101
- package/dist/esm/tools/codegen/import-map.js +358 -306
- package/dist/esm/tools/codegen/utils.js +373 -373
- package/dist/esm/tools/generate-map.js +1 -1
- package/dist/esm/tools/generateMetadata.js +29 -28
- package/dist/esm/tools/generateSites.js +52 -51
- package/dist/esm/tools/index.js +28 -27
- package/dist/esm/tools/scaffold.js +52 -51
- package/dist/esm/tools/templating/components.js +59 -223
- package/dist/esm/tools/templating/index.js +3 -3
- package/dist/esm/tools/templating/plugins.js +72 -70
- package/dist/esm/tools/templating/utils.js +59 -58
- package/dist/esm/utils/ensurePath.js +13 -13
- package/dist/esm/utils/env.js +24 -23
- package/dist/esm/utils/globalCache.js +49 -0
- package/dist/esm/utils/index.js +4 -3
- package/dist/esm/utils/is-server.js +9 -8
- package/dist/esm/utils/normalize-url.js +1 -1
- package/dist/esm/utils/timeout-promise.js +28 -28
- package/dist/esm/utils/utils.js +238 -213
- package/package.json +73 -5
- package/types/cache-client.d.ts +68 -64
- package/types/cache-client.d.ts.map +1 -0
- package/types/client/constants.d.ts +5 -4
- package/types/client/constants.d.ts.map +1 -0
- package/types/client/edge-proxy.d.ts +18 -15
- package/types/client/edge-proxy.d.ts.map +1 -0
- package/types/client/index.d.ts +8 -7
- package/types/client/index.d.ts.map +1 -0
- package/types/client/models.d.ts +21 -19
- package/types/client/models.d.ts.map +1 -0
- package/types/client/sitecore-client.d.ts +338 -327
- package/types/client/sitecore-client.d.ts.map +1 -0
- package/types/client/utils.d.ts +15 -9
- package/types/client/utils.d.ts.map +1 -0
- package/types/config/define-config.d.ts +20 -18
- package/types/config/define-config.d.ts.map +1 -0
- package/types/config/index.d.ts +3 -2
- package/types/config/index.d.ts.map +1 -0
- package/types/config/models.d.ts +287 -268
- package/types/config/models.d.ts.map +1 -0
- package/types/config-cli/define-cli-config.d.ts +9 -7
- package/types/config-cli/define-cli-config.d.ts.map +1 -0
- package/types/config-cli/index.d.ts +3 -2
- package/types/config-cli/index.d.ts.map +1 -0
- package/types/config-cli/models.d.ts +6 -4
- package/types/config-cli/models.d.ts.map +1 -0
- package/types/constants.d.ts +44 -11
- package/types/constants.d.ts.map +1 -0
- package/types/debug.d.ts +35 -28
- package/types/debug.d.ts.map +1 -0
- package/types/editing/codegen/index.d.ts +2 -1
- package/types/editing/codegen/index.d.ts.map +1 -0
- package/types/editing/codegen/preview.d.ts +256 -195
- package/types/editing/codegen/preview.d.ts.map +1 -0
- package/types/editing/component-layout-service.d.ts +84 -80
- package/types/editing/component-layout-service.d.ts.map +1 -0
- package/types/editing/design-library.d.ts +111 -63
- package/types/editing/design-library.d.ts.map +1 -0
- package/types/editing/editing-service.d.ts +72 -62
- package/types/editing/editing-service.d.ts.map +1 -0
- package/types/editing/index.d.ts +7 -6
- package/types/editing/index.d.ts.map +1 -0
- package/types/editing/metadata.d.ts +8 -7
- package/types/editing/metadata.d.ts.map +1 -0
- package/types/editing/models.d.ts +103 -92
- package/types/editing/models.d.ts.map +1 -0
- package/types/editing/utils.d.ts +91 -74
- package/types/editing/utils.d.ts.map +1 -0
- package/types/form/form.d.ts +25 -21
- package/types/form/form.d.ts.map +1 -0
- package/types/form/index.d.ts +2 -1
- package/types/form/index.d.ts.map +1 -0
- package/types/graphql-request-client.d.ts +112 -105
- package/types/graphql-request-client.d.ts.map +1 -0
- package/types/i18n/dictionary-service.d.ts +135 -131
- package/types/i18n/dictionary-service.d.ts.map +1 -0
- package/types/i18n/index.d.ts +3 -2
- package/types/i18n/index.d.ts.map +1 -0
- package/types/i18n/utils.d.ts +9 -7
- package/types/i18n/utils.d.ts.map +1 -0
- package/types/index.d.ts +13 -12
- package/types/index.d.ts.map +1 -0
- package/types/layout/content-styles.d.ts +20 -18
- package/types/layout/content-styles.d.ts.map +1 -0
- package/types/layout/index.d.ts +6 -5
- package/types/layout/index.d.ts.map +1 -0
- package/types/layout/layout-service.d.ts +45 -35
- package/types/layout/layout-service.d.ts.map +1 -0
- package/types/layout/models.d.ts +174 -151
- package/types/layout/models.d.ts.map +1 -0
- package/types/layout/themes.d.ts +13 -11
- package/types/layout/themes.d.ts.map +1 -0
- package/types/layout/utils.d.ts +56 -41
- package/types/layout/utils.d.ts.map +1 -0
- package/types/media/index.d.ts +3 -2
- package/types/media/index.d.ts.map +1 -0
- package/types/media/media-api.d.ts +60 -55
- package/types/media/media-api.d.ts.map +1 -0
- package/types/models.d.ts +94 -84
- package/types/models.d.ts.map +1 -0
- package/types/native-fetcher.d.ts +124 -114
- package/types/native-fetcher.d.ts.map +1 -0
- package/types/personalize/index.d.ts +4 -3
- package/types/personalize/index.d.ts.map +1 -0
- package/types/personalize/layout-personalizer.d.ts +29 -27
- package/types/personalize/layout-personalizer.d.ts.map +1 -0
- package/types/personalize/personalize-service.d.ts +90 -80
- package/types/personalize/personalize-service.d.ts.map +1 -0
- package/types/personalize/utils.d.ts +78 -69
- package/types/personalize/utils.d.ts.map +1 -0
- package/types/retries.d.ts +26 -24
- package/types/retries.d.ts.map +1 -0
- package/types/site/error-pages-service.d.ts +64 -57
- package/types/site/error-pages-service.d.ts.map +1 -0
- package/types/site/index.d.ts +10 -9
- package/types/site/index.d.ts.map +1 -0
- package/types/site/models.d.ts +23 -18
- package/types/site/models.d.ts.map +1 -0
- package/types/site/redirects-service.d.ts +92 -69
- package/types/site/redirects-service.d.ts.map +1 -0
- package/types/site/robots-service.d.ts +57 -50
- package/types/site/robots-service.d.ts.map +1 -0
- package/types/site/site-resolver.d.ts +28 -26
- package/types/site/site-resolver.d.ts.map +1 -0
- package/types/site/siteinfo-service.d.ts +65 -52
- package/types/site/siteinfo-service.d.ts.map +1 -0
- package/types/site/sitemap-xml-service.d.ts +63 -56
- package/types/site/sitemap-xml-service.d.ts.map +1 -0
- package/types/site/sitepath-service.d.ts +137 -134
- package/types/site/sitepath-service.d.ts.map +1 -0
- package/types/site/utils.d.ts +41 -28
- package/types/site/utils.d.ts.map +1 -0
- package/types/sitecore-service-base.d.ts +31 -30
- package/types/sitecore-service-base.d.ts.map +1 -0
- package/types/tools/auth/flow.d.ts +29 -27
- package/types/tools/auth/flow.d.ts.map +1 -0
- package/types/tools/auth/index.d.ts +2 -1
- package/types/tools/auth/index.d.ts.map +1 -0
- package/types/tools/auth/models.d.ts +35 -33
- package/types/tools/auth/models.d.ts.map +1 -0
- package/types/tools/auth/tenant-store.d.ts +12 -11
- package/types/tools/auth/tenant-store.d.ts.map +1 -0
- package/types/tools/codegen/component-generation.d.ts +50 -47
- package/types/tools/codegen/component-generation.d.ts.map +1 -0
- package/types/tools/codegen/extract-files.d.ts +24 -22
- package/types/tools/codegen/extract-files.d.ts.map +1 -0
- package/types/tools/codegen/import-map.d.ts +103 -70
- package/types/tools/codegen/import-map.d.ts.map +1 -0
- package/types/tools/codegen/utils.d.ts +76 -75
- package/types/tools/codegen/utils.d.ts.map +1 -0
- package/types/tools/generate-map.d.ts +36 -26
- package/types/tools/generate-map.d.ts.map +1 -0
- package/types/tools/generateMetadata.d.ts +24 -22
- package/types/tools/generateMetadata.d.ts.map +1 -0
- package/types/tools/generateSites.d.ts +25 -22
- package/types/tools/generateSites.d.ts.map +1 -0
- package/types/tools/index.d.ts +22 -20
- package/types/tools/index.d.ts.map +1 -0
- package/types/tools/scaffold.d.ts +27 -25
- package/types/tools/scaffold.d.ts.map +1 -0
- package/types/tools/templating/components.d.ts +104 -103
- package/types/tools/templating/components.d.ts.map +1 -0
- package/types/tools/templating/index.d.ts +4 -3
- package/types/tools/templating/index.d.ts.map +1 -0
- package/types/tools/templating/plugins.d.ts +71 -67
- package/types/tools/templating/plugins.d.ts.map +1 -0
- package/types/tools/templating/utils.d.ts +42 -40
- package/types/tools/templating/utils.d.ts.map +1 -0
- package/types/utils/ensurePath.d.ts +7 -6
- package/types/utils/ensurePath.d.ts.map +1 -0
- package/types/utils/env.d.ts +9 -7
- package/types/utils/env.d.ts.map +1 -0
- package/types/utils/globalCache.d.ts +37 -0
- package/types/utils/globalCache.d.ts.map +1 -0
- package/types/utils/index.d.ts +5 -3
- package/types/utils/index.d.ts.map +1 -0
- package/types/utils/is-server.d.ts +8 -6
- package/types/utils/is-server.d.ts.map +1 -0
- package/types/utils/normalize-url.d.ts +2 -1
- package/types/utils/normalize-url.d.ts.map +1 -0
- package/types/utils/timeout-promise.d.ts +18 -17
- package/types/utils/timeout-promise.d.ts.map +1 -0
- package/types/utils/utils.d.ts +104 -79
- package/types/utils/utils.d.ts.map +1 -0
- package/client.js +0 -1
- package/codegen.js +0 -1
- package/config-cli.js +0 -1
- package/config.js +0 -1
- package/editing.js +0 -1
- package/i18n.js +0 -1
- package/layout.js +0 -1
- package/media.js +0 -1
- package/personalize.js +0 -1
- package/site.js +0 -1
- package/tools.js +0 -1
- package/utils.js +0 -1
package/dist/esm/debug.js
CHANGED
|
@@ -1,39 +1,41 @@
|
|
|
1
|
-
var _a;
|
|
2
|
-
/* eslint-disable import/no-anonymous-default-export */
|
|
3
|
-
import debug from 'debug';
|
|
4
|
-
import isServer from './utils/is-server';
|
|
5
|
-
const rootNamespace = 'content-sdk';
|
|
6
|
-
// On server/node side, allow switching from the built-in
|
|
7
|
-
// `%o` (pretty-print single line) and `%O` (pretty-print multiple line)
|
|
8
|
-
// with a `DEBUG_MULTILINE` environment variable.
|
|
9
|
-
if (isServer() &&
|
|
10
|
-
((_a = process === null || process === void 0 ? void 0 : process.env) === null || _a === void 0 ? void 0 : _a.DEBUG_MULTILINE) === 'true' &&
|
|
11
|
-
debug.formatters.o &&
|
|
12
|
-
debug.formatters.O) {
|
|
13
|
-
debug.formatters.o = debug.formatters.O;
|
|
14
|
-
}
|
|
15
|
-
/**
|
|
16
|
-
* Enable debug logging dynamically
|
|
17
|
-
* @param {string} namespaces space-separated list of namespaces to enable
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
*
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
1
|
+
var _a;
|
|
2
|
+
/* eslint-disable import/no-anonymous-default-export */
|
|
3
|
+
import debug from 'debug';
|
|
4
|
+
import isServer from './utils/is-server';
|
|
5
|
+
const rootNamespace = 'content-sdk';
|
|
6
|
+
// On server/node side, allow switching from the built-in
|
|
7
|
+
// `%o` (pretty-print single line) and `%O` (pretty-print multiple line)
|
|
8
|
+
// with a `DEBUG_MULTILINE` environment variable.
|
|
9
|
+
if (isServer() &&
|
|
10
|
+
((_a = process === null || process === void 0 ? void 0 : process.env) === null || _a === void 0 ? void 0 : _a.DEBUG_MULTILINE) === 'true' &&
|
|
11
|
+
debug.formatters.o &&
|
|
12
|
+
debug.formatters.O) {
|
|
13
|
+
debug.formatters.o = debug.formatters.O;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Enable debug logging dynamically
|
|
17
|
+
* @param {string} namespaces space-separated list of namespaces to enable
|
|
18
|
+
* @public
|
|
19
|
+
*/
|
|
20
|
+
export const enableDebug = (namespaces) => debug.enable(namespaces);
|
|
21
|
+
/**
|
|
22
|
+
* Default Sitecore Content SDK 'debug' module debuggers. Uses namespace prefix 'content-sdk:'.
|
|
23
|
+
* See {@link https://www.npmjs.com/package/debug} for details.
|
|
24
|
+
*/
|
|
25
|
+
export default {
|
|
26
|
+
search: debug(`${rootNamespace}:search`),
|
|
27
|
+
common: debug(`${rootNamespace}:common`),
|
|
28
|
+
form: debug(`${rootNamespace}:form`),
|
|
29
|
+
http: debug(`${rootNamespace}:http`),
|
|
30
|
+
layout: debug(`${rootNamespace}:layout`),
|
|
31
|
+
dictionary: debug(`${rootNamespace}:dictionary`),
|
|
32
|
+
editing: debug(`${rootNamespace}:editing`),
|
|
33
|
+
sitemap: debug(`${rootNamespace}:sitemap`),
|
|
34
|
+
multisite: debug(`${rootNamespace}:multisite`),
|
|
35
|
+
robots: debug(`${rootNamespace}:robots`),
|
|
36
|
+
redirects: debug(`${rootNamespace}:redirects`),
|
|
37
|
+
personalize: debug(`${rootNamespace}:personalize`),
|
|
38
|
+
locale: debug(`${rootNamespace}:locale`),
|
|
39
|
+
errorpages: debug(`${rootNamespace}:errorpages`),
|
|
40
|
+
proxy: debug(`${rootNamespace}:proxy`),
|
|
41
|
+
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export { addComponentPreviewHandler, getDesignLibraryComponentPreviewErrorEvent, getDesignLibraryComponentPropsEvent, getDesignLibraryImportMapEvent, DesignLibraryPreviewError, } from './preview';
|
|
1
|
+
export { addComponentPreviewHandler, addServerComponentPreviewHandler, getDesignLibraryComponentPreviewErrorEvent, getDesignLibraryComponentPropsEvent, getDesignLibraryImportMapEvent, getImportMapInfo, addStyleElement, createComponentInstance, sendErrorEvent, DesignLibraryPreviewError, } from './preview';
|
|
@@ -1,185 +1,263 @@
|
|
|
1
|
-
import {
|
|
2
|
-
/**
|
|
3
|
-
* Event to send import map to design library
|
|
4
|
-
*/
|
|
5
|
-
const DESIGN_LIBRARY_IMPORT_MAP_EVENT_NAME = 'component:generation:import-map';
|
|
6
|
-
/**
|
|
7
|
-
* Event to send component props to design library
|
|
8
|
-
*/
|
|
9
|
-
const DESIGN_LIBRARY_COMPONENT_PROPS_EVENT_NAME = 'component:generation:component-props';
|
|
10
|
-
/**
|
|
11
|
-
* Event to receive component data from design library
|
|
12
|
-
*/
|
|
13
|
-
const DESIGN_LIBRARY_COMPONENT_PREVIEW_EVENT_NAME = 'component:generation:component-preview';
|
|
14
|
-
/**
|
|
15
|
-
* Event to send component error to design library
|
|
16
|
-
*/
|
|
17
|
-
const DESIGN_LIBRARY_COMPONENT_PREVIEW_ERROR_EVENT_NAME = 'component:generation:component-preview-error';
|
|
18
|
-
/**
|
|
19
|
-
* Enumeration of error types for the design library preview.
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
*
|
|
35
|
-
* @param {
|
|
36
|
-
* @
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
const
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
*
|
|
75
|
-
*
|
|
76
|
-
* @param {
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
*
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
1
|
+
import { validateEvent } from '../design-library';
|
|
2
|
+
/**
|
|
3
|
+
* Event to send import map to design library
|
|
4
|
+
*/
|
|
5
|
+
const DESIGN_LIBRARY_IMPORT_MAP_EVENT_NAME = 'component:generation:import-map';
|
|
6
|
+
/**
|
|
7
|
+
* Event to send component props to design library
|
|
8
|
+
*/
|
|
9
|
+
const DESIGN_LIBRARY_COMPONENT_PROPS_EVENT_NAME = 'component:generation:component-props';
|
|
10
|
+
/**
|
|
11
|
+
* Event to receive component data from design library
|
|
12
|
+
*/
|
|
13
|
+
const DESIGN_LIBRARY_COMPONENT_PREVIEW_EVENT_NAME = 'component:generation:component-preview';
|
|
14
|
+
/**
|
|
15
|
+
* Event to send component error to design library
|
|
16
|
+
*/
|
|
17
|
+
const DESIGN_LIBRARY_COMPONENT_PREVIEW_ERROR_EVENT_NAME = 'component:generation:component-preview-error';
|
|
18
|
+
/**
|
|
19
|
+
* Enumeration of error types for the design library preview.
|
|
20
|
+
* @internal
|
|
21
|
+
*/
|
|
22
|
+
export var DesignLibraryPreviewError;
|
|
23
|
+
(function (DesignLibraryPreviewError) {
|
|
24
|
+
/**
|
|
25
|
+
* Error occurred during component rendering.
|
|
26
|
+
*/
|
|
27
|
+
DesignLibraryPreviewError["Render"] = "render";
|
|
28
|
+
/**
|
|
29
|
+
* Error occurred during component and event handlers initialization.
|
|
30
|
+
*/
|
|
31
|
+
DesignLibraryPreviewError["RenderInit"] = "render-init";
|
|
32
|
+
})(DesignLibraryPreviewError || (DesignLibraryPreviewError = {}));
|
|
33
|
+
/**
|
|
34
|
+
* Builds the component dependencies from the component imports and the import map.
|
|
35
|
+
* @param {ComponentImport[]} componentImports - The component imports.
|
|
36
|
+
* @param {ImportEntry[]} importMap - The import map to be used for the component.
|
|
37
|
+
* @returns {Array<{ name: string; value: unknown }>} The component dependencies.
|
|
38
|
+
*/
|
|
39
|
+
export function buildComponentDependencies(componentImports, importMap) {
|
|
40
|
+
const successful = [];
|
|
41
|
+
const missing = {
|
|
42
|
+
modules: [],
|
|
43
|
+
exports: [],
|
|
44
|
+
};
|
|
45
|
+
componentImports.forEach((componentImport) => {
|
|
46
|
+
const moduleEntry = importMap.find((entry) => entry.module === componentImport.module);
|
|
47
|
+
if (!moduleEntry) {
|
|
48
|
+
missing.modules.push({
|
|
49
|
+
module: componentImport.module,
|
|
50
|
+
alias: componentImport.alias,
|
|
51
|
+
});
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
const exportEntry = moduleEntry.exports.find((exp) => exp.name === componentImport.export);
|
|
55
|
+
if (!exportEntry) {
|
|
56
|
+
missing.exports.push({
|
|
57
|
+
alias: componentImport.alias,
|
|
58
|
+
export: componentImport.export,
|
|
59
|
+
module: componentImport.module,
|
|
60
|
+
});
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
return successful.push({
|
|
64
|
+
name: componentImport.alias,
|
|
65
|
+
value: exportEntry.value,
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
return {
|
|
69
|
+
successful,
|
|
70
|
+
missing,
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Adds the browser-side event handler for 'component:generation:component-preview' message used in Design Library
|
|
75
|
+
* The event should contain the component code, styles and imports.
|
|
76
|
+
* @param {ImportEntry[]} importMap - The import map to be used for the component.
|
|
77
|
+
* @param {Function} callback callback to be called after component is received
|
|
78
|
+
* @internal
|
|
79
|
+
*/
|
|
80
|
+
export const addComponentPreviewHandler = (importMap, callback) => {
|
|
81
|
+
if (!window)
|
|
82
|
+
return;
|
|
83
|
+
const handler = (e) => {
|
|
84
|
+
const eventArgs = e.data;
|
|
85
|
+
try {
|
|
86
|
+
if (!validateEvent(e, DESIGN_LIBRARY_COMPONENT_PREVIEW_EVENT_NAME)) {
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
console.debug('Component Library: message received', eventArgs);
|
|
90
|
+
const Component = createComponentInstance(importMap, eventArgs);
|
|
91
|
+
addStyleElement(eventArgs.message.styles.content);
|
|
92
|
+
callback(null, Component);
|
|
93
|
+
}
|
|
94
|
+
catch (error) {
|
|
95
|
+
sendErrorEvent(eventArgs.message.uid, error, DesignLibraryPreviewError.RenderInit);
|
|
96
|
+
callback(error, null);
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
window.addEventListener('message', handler);
|
|
100
|
+
const unsubscribe = () => {
|
|
101
|
+
window.removeEventListener('message', handler);
|
|
102
|
+
};
|
|
103
|
+
return unsubscribe;
|
|
104
|
+
};
|
|
105
|
+
/**
|
|
106
|
+
* Adds the browser-side event handler for 'component:generation:component-preview' message used in Design Library for server components
|
|
107
|
+
* The event should contain the component code, styles and imports.
|
|
108
|
+
* @param {Function} callback callback to be called after component is received
|
|
109
|
+
* @internal
|
|
110
|
+
*/
|
|
111
|
+
export const addServerComponentPreviewHandler = (callback) => {
|
|
112
|
+
const handler = (e) => {
|
|
113
|
+
if (!validateEvent(e, DESIGN_LIBRARY_COMPONENT_PREVIEW_EVENT_NAME)) {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
console.debug('Component Library: message received', e.data);
|
|
117
|
+
callback(e.data);
|
|
118
|
+
};
|
|
119
|
+
window.addEventListener('message', handler);
|
|
120
|
+
const unsubscribe = () => {
|
|
121
|
+
window.removeEventListener('message', handler);
|
|
122
|
+
};
|
|
123
|
+
return unsubscribe;
|
|
124
|
+
};
|
|
125
|
+
/**
|
|
126
|
+
* Adds <style> element in the document head with the provided CSS.
|
|
127
|
+
* If an existing style element with the id "content-sdk-style-preview" is found, it is removed
|
|
128
|
+
* to prevent duplicates
|
|
129
|
+
* @param {string} stylesContent - The raw CSS text to inject into the style element.
|
|
130
|
+
* @internal
|
|
131
|
+
*/
|
|
132
|
+
export function addStyleElement(stylesContent) {
|
|
133
|
+
const styleId = 'content-sdk-style-preview';
|
|
134
|
+
const styleElement = document.getElementById(styleId);
|
|
135
|
+
// remove existing style element if it exists to avoid duplicates
|
|
136
|
+
if (styleElement) {
|
|
137
|
+
styleElement.remove();
|
|
138
|
+
}
|
|
139
|
+
// create new style element and attach it to DOM
|
|
140
|
+
const style = document.createElement('style');
|
|
141
|
+
style.setAttribute('id', styleId);
|
|
142
|
+
style.innerHTML = stylesContent;
|
|
143
|
+
document.head.appendChild(style);
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Dynamically creates a React component instance from provided importMap and from code, styles, and dependencies provided in the preview event.
|
|
147
|
+
* @param {ImportEntry[]} importMap - The import map containing module and export references that might be injected as dependencies in the provided code.
|
|
148
|
+
* @param {ComponentPreviewEventArgs} previewEventArgs - The event arguments containing the component code, styles, and import definitions.
|
|
149
|
+
* @returns The dynamically created React component instance.
|
|
150
|
+
* @throws If any required modules or exports are missing from the import map, an error is thrown describing the missing dependencies.
|
|
151
|
+
* @internal
|
|
152
|
+
*/
|
|
153
|
+
export const createComponentInstance = (importMap, previewEventArgs) => {
|
|
154
|
+
const { message } = previewEventArgs;
|
|
155
|
+
const dependencies = buildComponentDependencies(message.imports, importMap);
|
|
156
|
+
if (dependencies.missing.modules.length > 0 || dependencies.missing.exports.length > 0) {
|
|
157
|
+
let errorMessage = '';
|
|
158
|
+
dependencies.missing.modules.forEach((mod) => {
|
|
159
|
+
errorMessage += `Missing module: '${mod.module}' with alias: '${mod.alias}'\n`;
|
|
160
|
+
});
|
|
161
|
+
dependencies.missing.exports.forEach((exp) => {
|
|
162
|
+
const alias = exp.export !== exp.alias ? ` with alias: '${exp.alias}'` : '';
|
|
163
|
+
errorMessage += `Missing export: '${exp.export}' from module: '${exp.module}'${alias}\n`;
|
|
164
|
+
});
|
|
165
|
+
throw errorMessage;
|
|
166
|
+
}
|
|
167
|
+
const importNames = dependencies.successful.map((entry) => entry.name);
|
|
168
|
+
const importInstances = dependencies.successful.map((entry) => entry.value);
|
|
169
|
+
const exports = { Component: null };
|
|
170
|
+
const componentFn = new Function('exports', message.styles.styleImport.name, ...importNames, message.code.content);
|
|
171
|
+
// Function will set exports.Component
|
|
172
|
+
componentFn(exports, message.styles.styleImport.content, ...importInstances);
|
|
173
|
+
return exports.Component;
|
|
174
|
+
};
|
|
175
|
+
/**
|
|
176
|
+
* Generates a DesignLibraryComponentPreviewErrorEvent with the given uid and error.
|
|
177
|
+
* @param {string} uid - The unique identifier for the event.
|
|
178
|
+
* @param {unknown} error - The error to be sent.
|
|
179
|
+
* @param {DesignLibraryPreviewError} type - The type of error.
|
|
180
|
+
* @returns An object representing the DesignLibraryComponentPreviewErrorEvent.
|
|
181
|
+
* @internal
|
|
182
|
+
*/
|
|
183
|
+
export function getDesignLibraryComponentPreviewErrorEvent(uid, error, type) {
|
|
184
|
+
return {
|
|
185
|
+
name: DESIGN_LIBRARY_COMPONENT_PREVIEW_ERROR_EVENT_NAME,
|
|
186
|
+
message: { uid, error, type },
|
|
187
|
+
};
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Generates a DesignLibraryComponentPropsEvent with the given uid, fields and parameters.
|
|
191
|
+
* @param {string} uid - The unique identifier for the event.
|
|
192
|
+
* @param {ComponentFields} fields - The fields of the component.
|
|
193
|
+
* @param {ComponentParams} parameters - The parameters of the component.
|
|
194
|
+
* @returns An object representing the DesignLibraryComponentPropsEvent.
|
|
195
|
+
* @internal
|
|
196
|
+
*/
|
|
197
|
+
export function getDesignLibraryComponentPropsEvent(uid, fields = {}, parameters = {}) {
|
|
198
|
+
return {
|
|
199
|
+
name: DESIGN_LIBRARY_COMPONENT_PROPS_EVENT_NAME,
|
|
200
|
+
message: {
|
|
201
|
+
uid,
|
|
202
|
+
fields,
|
|
203
|
+
parameters,
|
|
204
|
+
},
|
|
205
|
+
};
|
|
206
|
+
}
|
|
207
|
+
/**
|
|
208
|
+
* Generates a DesignLibraryImportMapEvent with the given uid and importMap.
|
|
209
|
+
* @param {string} uid - The unique identifier for the event.
|
|
210
|
+
* @param {ImportEntry[]} importMap - The imports map to be sent.
|
|
211
|
+
* @returns An object representing the DesignLibraryImportMapEvent.
|
|
212
|
+
* @internal
|
|
213
|
+
*/
|
|
214
|
+
export function getDesignLibraryImportMapEvent(uid, importMap) {
|
|
215
|
+
const importMapPayload = isImportEntryInfoArray(importMap)
|
|
216
|
+
? importMap
|
|
217
|
+
: getImportMapInfo(importMap);
|
|
218
|
+
return {
|
|
219
|
+
name: DESIGN_LIBRARY_IMPORT_MAP_EVENT_NAME,
|
|
220
|
+
message: {
|
|
221
|
+
uid,
|
|
222
|
+
importMap: importMapPayload,
|
|
223
|
+
},
|
|
224
|
+
};
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* Generates the payload for the import map to be sent to design library.
|
|
228
|
+
* @param {ImportEntry[]} importMap - The imports map to be sent.
|
|
229
|
+
* @internal
|
|
230
|
+
*/
|
|
231
|
+
export function getImportMapInfo(importMap) {
|
|
232
|
+
return importMap.map((entry) => ({
|
|
233
|
+
module: entry.module,
|
|
234
|
+
exports: entry.exports.map((exp) => exp.name),
|
|
235
|
+
}));
|
|
236
|
+
}
|
|
237
|
+
/**
|
|
238
|
+
* Type guard for ImportEntryInfo[]
|
|
239
|
+
* @param {unknown} data import entry data to check
|
|
240
|
+
* @returns true if the data is ImportEntryInfo array
|
|
241
|
+
*/
|
|
242
|
+
export function isImportEntryInfoArray(data) {
|
|
243
|
+
return (Array.isArray(data) &&
|
|
244
|
+
data.length > 0 &&
|
|
245
|
+
typeof data[0].module === 'string' &&
|
|
246
|
+
Array.isArray(data[0].exports) &&
|
|
247
|
+
typeof data[0].exports[0] === 'string');
|
|
248
|
+
}
|
|
249
|
+
/**
|
|
250
|
+
* Sends a component preview error event to the design library
|
|
251
|
+
* @param {string} uid - The unique identifier of the component that's being edited.
|
|
252
|
+
* @param {unknown} error - The error object or message to be sent.
|
|
253
|
+
* @param {DesignLibraryPreviewError} type - The type of error, as defined in DesignLibraryPreviewError.
|
|
254
|
+
* @internal
|
|
255
|
+
*/
|
|
256
|
+
export const sendErrorEvent = (uid, error, type) => {
|
|
257
|
+
const errorEvent = getDesignLibraryComponentPreviewErrorEvent(uid, error, type);
|
|
258
|
+
console.error('Component Library: sending error event', errorEvent);
|
|
259
|
+
if (typeof window !== 'undefined') {
|
|
260
|
+
const target = window.parent && window.parent !== window ? window.parent : window;
|
|
261
|
+
target.postMessage(errorEvent, '*');
|
|
262
|
+
}
|
|
263
|
+
};
|