@sitecore-jss/sitecore-jss-angular 21.2.3-canary.0 → 21.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/dist/components/data-resolver-factory.d.ts +13 -13
  2. package/dist/components/date.directive.d.ts +20 -20
  3. package/dist/components/editframe.component.d.ts +22 -22
  4. package/dist/components/file.directive.d.ts +17 -17
  5. package/dist/components/generic-link.directive.d.ts +20 -20
  6. package/dist/components/guard-resolver-factory.d.ts +11 -11
  7. package/dist/components/hidden-rendering.component.d.ts +7 -7
  8. package/dist/components/image.directive.d.ts +35 -35
  9. package/dist/components/link.directive.d.ts +26 -26
  10. package/dist/components/missing-component.component.d.ts +7 -7
  11. package/dist/components/placeholder-loading.directive.d.ts +8 -8
  12. package/dist/components/placeholder.component.d.ts +59 -59
  13. package/dist/components/placeholder.token.d.ts +64 -64
  14. package/dist/components/raw.component.d.ts +12 -12
  15. package/dist/components/render-component.component.d.ts +33 -33
  16. package/dist/components/render-each.directive.d.ts +8 -8
  17. package/dist/components/render-empty.directive.d.ts +8 -8
  18. package/dist/components/rendering-field.d.ts +41 -41
  19. package/dist/components/rendering.d.ts +5 -5
  20. package/dist/components/rich-text.directive.d.ts +18 -18
  21. package/dist/components/router-link.directive.d.ts +19 -19
  22. package/dist/components/text.directive.d.ts +16 -16
  23. package/dist/esm2020/components/data-resolver-factory.mjs +57 -57
  24. package/dist/esm2020/components/date.directive.mjs +59 -59
  25. package/dist/esm2020/components/editframe.component.mjs +65 -65
  26. package/dist/esm2020/components/file.directive.mjs +44 -44
  27. package/dist/esm2020/components/generic-link.directive.mjs +64 -64
  28. package/dist/esm2020/components/guard-resolver-factory.mjs +87 -87
  29. package/dist/esm2020/components/hidden-rendering.component.mjs +20 -20
  30. package/dist/esm2020/components/image.directive.mjs +137 -137
  31. package/dist/esm2020/components/link.directive.mjs +117 -117
  32. package/dist/esm2020/components/missing-component.component.mjs +15 -15
  33. package/dist/esm2020/components/placeholder-loading.directive.mjs +15 -15
  34. package/dist/esm2020/components/placeholder.component.mjs +250 -250
  35. package/dist/esm2020/components/placeholder.token.mjs +23 -23
  36. package/dist/esm2020/components/raw.component.mjs +35 -35
  37. package/dist/esm2020/components/render-component.component.mjs +90 -90
  38. package/dist/esm2020/components/render-each.directive.mjs +15 -15
  39. package/dist/esm2020/components/render-empty.directive.mjs +15 -15
  40. package/dist/esm2020/components/rendering-field.mjs +1 -1
  41. package/dist/esm2020/components/rendering.mjs +7 -7
  42. package/dist/esm2020/components/rich-text.directive.mjs +62 -62
  43. package/dist/esm2020/components/router-link.directive.mjs +47 -47
  44. package/dist/esm2020/components/text.directive.mjs +57 -57
  45. package/dist/esm2020/jss-component-factory.service.mjs +83 -83
  46. package/dist/esm2020/lib.module.mjs +167 -167
  47. package/dist/esm2020/public_api.mjs +24 -24
  48. package/dist/esm2020/sitecore-jss-sitecore-jss-angular.mjs +4 -4
  49. package/dist/esm2020/utils.mjs +16 -16
  50. package/dist/fesm2015/sitecore-jss-sitecore-jss-angular.mjs +1415 -1415
  51. package/dist/fesm2020/sitecore-jss-sitecore-jss-angular.mjs +1422 -1422
  52. package/dist/index.d.ts +5 -5
  53. package/dist/jss-component-factory.service.d.ts +25 -25
  54. package/dist/lib.module.d.ts +46 -46
  55. package/dist/package.json +2 -2
  56. package/dist/public_api.d.ts +25 -25
  57. package/dist/utils.d.ts +7 -7
  58. package/package.json +3 -3
@@ -1,58 +1,58 @@
1
- import { Directive, Input, } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class TextDirective {
4
- constructor(viewContainer, templateRef) {
5
- this.viewContainer = viewContainer;
6
- this.templateRef = templateRef;
7
- this.editable = true;
8
- this.encode = true;
9
- }
10
- ngOnChanges(changes) {
11
- if (changes.field || changes.editable || changes.encode) {
12
- if (!this.viewRef) {
13
- this.viewContainer.clear();
14
- this.viewRef = this.viewContainer.createEmbeddedView(this.templateRef);
15
- }
16
- this.updateView();
17
- }
18
- }
19
- updateView() {
20
- const field = this.field;
21
- let editable = this.editable;
22
- if (!field || (!field.editable && (field.value === undefined || field.value === ''))) {
23
- return;
24
- }
25
- // can't use editable value if we want to output unencoded
26
- if (!this.encode) {
27
- editable = false;
28
- }
29
- const html = field.editable && editable ? field.editable : field.value;
30
- const setDangerously = (field.editable && editable) || !this.encode;
31
- this.viewRef.rootNodes.forEach((node) => {
32
- if (setDangerously) {
33
- node.innerHTML = html;
34
- }
35
- else {
36
- node.textContent = html;
37
- }
38
- });
39
- }
40
- }
41
- TextDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TextDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
42
- TextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: TextDirective, selector: "[scText]", inputs: { editable: ["scTextEditable", "editable"], encode: ["scTextEncode", "encode"], field: ["scText", "field"] }, usesOnChanges: true, ngImport: i0 });
43
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TextDirective, decorators: [{
44
- type: Directive,
45
- args: [{
46
- selector: '[scText]',
47
- }]
48
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }]; }, propDecorators: { editable: [{
49
- type: Input,
50
- args: ['scTextEditable']
51
- }], encode: [{
52
- type: Input,
53
- args: ['scTextEncode']
54
- }], field: [{
55
- type: Input,
56
- args: ['scText']
57
- }] } });
1
+ import { Directive, Input, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class TextDirective {
4
+ constructor(viewContainer, templateRef) {
5
+ this.viewContainer = viewContainer;
6
+ this.templateRef = templateRef;
7
+ this.editable = true;
8
+ this.encode = true;
9
+ }
10
+ ngOnChanges(changes) {
11
+ if (changes.field || changes.editable || changes.encode) {
12
+ if (!this.viewRef) {
13
+ this.viewContainer.clear();
14
+ this.viewRef = this.viewContainer.createEmbeddedView(this.templateRef);
15
+ }
16
+ this.updateView();
17
+ }
18
+ }
19
+ updateView() {
20
+ const field = this.field;
21
+ let editable = this.editable;
22
+ if (!field || (!field.editable && (field.value === undefined || field.value === ''))) {
23
+ return;
24
+ }
25
+ // can't use editable value if we want to output unencoded
26
+ if (!this.encode) {
27
+ editable = false;
28
+ }
29
+ const html = field.editable && editable ? field.editable : field.value;
30
+ const setDangerously = (field.editable && editable) || !this.encode;
31
+ this.viewRef.rootNodes.forEach((node) => {
32
+ if (setDangerously) {
33
+ node.innerHTML = html;
34
+ }
35
+ else {
36
+ node.textContent = html;
37
+ }
38
+ });
39
+ }
40
+ }
41
+ TextDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TextDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
42
+ TextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: TextDirective, selector: "[scText]", inputs: { editable: ["scTextEditable", "editable"], encode: ["scTextEncode", "encode"], field: ["scText", "field"] }, usesOnChanges: true, ngImport: i0 });
43
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TextDirective, decorators: [{
44
+ type: Directive,
45
+ args: [{
46
+ selector: '[scText]',
47
+ }]
48
+ }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }]; }, propDecorators: { editable: [{
49
+ type: Input,
50
+ args: ['scTextEditable']
51
+ }], encode: [{
52
+ type: Input,
53
+ args: ['scTextEncode']
54
+ }], field: [{
55
+ type: Input,
56
+ args: ['scText']
57
+ }] } });
58
58
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy90ZXh0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUVULEtBQUssR0FLTixNQUFNLGVBQWUsQ0FBQzs7QUFNdkIsTUFBTSxPQUFPLGFBQWE7SUFTeEIsWUFBb0IsYUFBK0IsRUFBVSxXQUFpQztRQUExRSxrQkFBYSxHQUFiLGFBQWEsQ0FBa0I7UUFBVSxnQkFBVyxHQUFYLFdBQVcsQ0FBc0I7UUFSckUsYUFBUSxHQUFHLElBQUksQ0FBQztRQUVsQixXQUFNLEdBQUcsSUFBSSxDQUFDO0lBTTRELENBQUM7SUFFbEcsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLElBQUksT0FBTyxDQUFDLEtBQUssSUFBSSxPQUFPLENBQUMsUUFBUSxJQUFJLE9BQU8sQ0FBQyxNQUFNLEVBQUU7WUFDdkQsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUU7Z0JBQ2pCLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7Z0JBQzNCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7YUFDeEU7WUFFRCxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7U0FDbkI7SUFDSCxDQUFDO0lBRU8sVUFBVTtRQUNoQixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1FBQ3pCLElBQUksUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7UUFFN0IsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEtBQUssU0FBUyxJQUFJLEtBQUssQ0FBQyxLQUFLLEtBQUssRUFBRSxDQUFDLENBQUMsRUFBRTtZQUNwRixPQUFPO1NBQ1I7UUFFRCwwREFBMEQ7UUFDMUQsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDaEIsUUFBUSxHQUFHLEtBQUssQ0FBQztTQUNsQjtRQUVELE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxRQUFRLElBQUksUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDO1FBQ3ZFLE1BQU0sY0FBYyxHQUFHLENBQUMsS0FBSyxDQUFDLFFBQVEsSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7UUFFcEUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDdEMsSUFBSSxjQUFjLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO2FBQ3ZCO2lCQUFNO2dCQUNMLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO2FBQ3pCO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOzsyR0E3Q1UsYUFBYTsrRkFBYixhQUFhOzRGQUFiLGFBQWE7a0JBSHpCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFVBQVU7aUJBQ3JCO2lJQUUwQixRQUFRO3NCQUFoQyxLQUFLO3VCQUFDLGdCQUFnQjtnQkFFQSxNQUFNO3NCQUE1QixLQUFLO3VCQUFDLGNBQWM7Z0JBRUosS0FBSztzQkFBckIsS0FBSzt1QkFBQyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBEaXJlY3RpdmUsXHJcbiAgRW1iZWRkZWRWaWV3UmVmLFxyXG4gIElucHV0LFxyXG4gIE9uQ2hhbmdlcyxcclxuICBTaW1wbGVDaGFuZ2VzLFxyXG4gIFRlbXBsYXRlUmVmLFxyXG4gIFZpZXdDb250YWluZXJSZWYsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFRleHRGaWVsZCB9IGZyb20gJy4vcmVuZGVyaW5nLWZpZWxkJztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnW3NjVGV4dF0nLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVGV4dERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XHJcbiAgQElucHV0KCdzY1RleHRFZGl0YWJsZScpIGVkaXRhYmxlID0gdHJ1ZTtcclxuXHJcbiAgQElucHV0KCdzY1RleHRFbmNvZGUnKSBlbmNvZGUgPSB0cnVlO1xyXG5cclxuICBASW5wdXQoJ3NjVGV4dCcpIGZpZWxkOiBUZXh0RmllbGQ7XHJcblxyXG4gIHByaXZhdGUgdmlld1JlZjogRW1iZWRkZWRWaWV3UmVmPHVua25vd24+O1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHZpZXdDb250YWluZXI6IFZpZXdDb250YWluZXJSZWYsIHByaXZhdGUgdGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPHVua25vd24+KSB7fVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XHJcbiAgICBpZiAoY2hhbmdlcy5maWVsZCB8fCBjaGFuZ2VzLmVkaXRhYmxlIHx8IGNoYW5nZXMuZW5jb2RlKSB7XHJcbiAgICAgIGlmICghdGhpcy52aWV3UmVmKSB7XHJcbiAgICAgICAgdGhpcy52aWV3Q29udGFpbmVyLmNsZWFyKCk7XHJcbiAgICAgICAgdGhpcy52aWV3UmVmID0gdGhpcy52aWV3Q29udGFpbmVyLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLnRlbXBsYXRlUmVmKTtcclxuICAgICAgfVxyXG5cclxuICAgICAgdGhpcy51cGRhdGVWaWV3KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHVwZGF0ZVZpZXcoKSB7XHJcbiAgICBjb25zdCBmaWVsZCA9IHRoaXMuZmllbGQ7XHJcbiAgICBsZXQgZWRpdGFibGUgPSB0aGlzLmVkaXRhYmxlO1xyXG5cclxuICAgIGlmICghZmllbGQgfHwgKCFmaWVsZC5lZGl0YWJsZSAmJiAoZmllbGQudmFsdWUgPT09IHVuZGVmaW5lZCB8fCBmaWVsZC52YWx1ZSA9PT0gJycpKSkge1xyXG4gICAgICByZXR1cm47XHJcbiAgICB9XHJcblxyXG4gICAgLy8gY2FuJ3QgdXNlIGVkaXRhYmxlIHZhbHVlIGlmIHdlIHdhbnQgdG8gb3V0cHV0IHVuZW5jb2RlZFxyXG4gICAgaWYgKCF0aGlzLmVuY29kZSkge1xyXG4gICAgICBlZGl0YWJsZSA9IGZhbHNlO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IGh0bWwgPSBmaWVsZC5lZGl0YWJsZSAmJiBlZGl0YWJsZSA/IGZpZWxkLmVkaXRhYmxlIDogZmllbGQudmFsdWU7XHJcbiAgICBjb25zdCBzZXREYW5nZXJvdXNseSA9IChmaWVsZC5lZGl0YWJsZSAmJiBlZGl0YWJsZSkgfHwgIXRoaXMuZW5jb2RlO1xyXG5cclxuICAgIHRoaXMudmlld1JlZi5yb290Tm9kZXMuZm9yRWFjaCgobm9kZSkgPT4ge1xyXG4gICAgICBpZiAoc2V0RGFuZ2Vyb3VzbHkpIHtcclxuICAgICAgICBub2RlLmlubmVySFRNTCA9IGh0bWw7XHJcbiAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgbm9kZS50ZXh0Q29udGVudCA9IGh0bWw7XHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,84 +1,84 @@
1
- import { Inject, Injectable, createNgModule } from '@angular/core';
2
- import { DYNAMIC_COMPONENT, PLACEHOLDER_COMPONENTS, PLACEHOLDER_LAZY_COMPONENTS, } from './components/placeholder.token';
3
- import { RawComponent } from './components/raw.component';
4
- import { isRawRendering } from './components/rendering';
5
- import * as i0 from "@angular/core";
6
- export class JssComponentFactoryService {
7
- constructor(injector, components, lazyComponents) {
8
- this.injector = injector;
9
- this.components = components;
10
- this.lazyComponents = lazyComponents;
11
- this.componentMap = new Map();
12
- this.lazyComponentMap = new Map();
13
- this.components.forEach((c) => this.componentMap.set(c.name, c));
14
- if (this.lazyComponents) {
15
- this.lazyComponents.forEach((c) => this.lazyComponentMap.set(c.path, c));
16
- }
17
- }
18
- getComponent(component) {
19
- const loadedComponent = this.componentMap.get(component.componentName);
20
- if (loadedComponent) {
21
- return Promise.resolve({
22
- componentDefinition: component,
23
- componentImplementation: loadedComponent.type,
24
- canActivate: loadedComponent.canActivate,
25
- resolve: loadedComponent.resolve,
26
- });
27
- }
28
- const lazyComponent = this.lazyComponentMap.get(component.componentName);
29
- if (lazyComponent) {
30
- return lazyComponent.loadChildren().then((lazyChild) => {
31
- let componentType = null;
32
- const moduleRef = createNgModule(lazyChild, this.injector);
33
- const dynamicComponentType = moduleRef.injector.get(DYNAMIC_COMPONENT);
34
- if (!dynamicComponentType) {
35
- throw new Error(`JssComponentFactoryService: Lazy load module for component "${lazyComponent.path}" missing DYNAMIC_COMPONENT provider. Missing JssModule.forChild()?`);
36
- }
37
- if (component.componentName in dynamicComponentType) {
38
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
39
- componentType = dynamicComponentType[component.componentName];
40
- }
41
- else {
42
- if (typeof dynamicComponentType === 'function') {
43
- componentType = dynamicComponentType;
44
- }
45
- else {
46
- throw new Error(`JssComponentFactoryService: Lazy load module for component "${lazyComponent.path}" missing DYNAMIC_COMPONENT provider. Missing JssModule.forChild()?`);
47
- }
48
- }
49
- return {
50
- componentDefinition: component,
51
- componentImplementation: componentType,
52
- componentFactory: moduleRef.componentFactoryResolver.resolveComponentFactory(componentType),
53
- canActivate: lazyComponent.canActivate,
54
- resolve: lazyComponent.resolve,
55
- };
56
- });
57
- }
58
- return Promise.resolve({
59
- componentDefinition: component,
60
- });
61
- }
62
- getComponents(components) {
63
- // acquire all components and keep them in order while handling their potential async-ness
64
- return Promise.all(components.map((component) => isRawRendering(component) ? this.getRawComponent(component) : this.getComponent(component)));
65
- }
66
- getRawComponent(component) {
67
- return Promise.resolve({
68
- componentImplementation: RawComponent,
69
- componentDefinition: component,
70
- });
71
- }
72
- }
73
- JssComponentFactoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: JssComponentFactoryService, deps: [{ token: i0.Injector }, { token: PLACEHOLDER_COMPONENTS }, { token: PLACEHOLDER_LAZY_COMPONENTS }], target: i0.ɵɵFactoryTarget.Injectable });
74
- JssComponentFactoryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: JssComponentFactoryService });
75
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: JssComponentFactoryService, decorators: [{
76
- type: Injectable
77
- }], ctorParameters: function () { return [{ type: i0.Injector }, { type: undefined, decorators: [{
78
- type: Inject,
79
- args: [PLACEHOLDER_COMPONENTS]
80
- }] }, { type: undefined, decorators: [{
81
- type: Inject,
82
- args: [PLACEHOLDER_LAZY_COMPONENTS]
83
- }] }]; } });
1
+ import { Inject, Injectable, createNgModule } from '@angular/core';
2
+ import { DYNAMIC_COMPONENT, PLACEHOLDER_COMPONENTS, PLACEHOLDER_LAZY_COMPONENTS, } from './components/placeholder.token';
3
+ import { RawComponent } from './components/raw.component';
4
+ import { isRawRendering } from './components/rendering';
5
+ import * as i0 from "@angular/core";
6
+ export class JssComponentFactoryService {
7
+ constructor(injector, components, lazyComponents) {
8
+ this.injector = injector;
9
+ this.components = components;
10
+ this.lazyComponents = lazyComponents;
11
+ this.componentMap = new Map();
12
+ this.lazyComponentMap = new Map();
13
+ this.components.forEach((c) => this.componentMap.set(c.name, c));
14
+ if (this.lazyComponents) {
15
+ this.lazyComponents.forEach((c) => this.lazyComponentMap.set(c.path, c));
16
+ }
17
+ }
18
+ getComponent(component) {
19
+ const loadedComponent = this.componentMap.get(component.componentName);
20
+ if (loadedComponent) {
21
+ return Promise.resolve({
22
+ componentDefinition: component,
23
+ componentImplementation: loadedComponent.type,
24
+ canActivate: loadedComponent.canActivate,
25
+ resolve: loadedComponent.resolve,
26
+ });
27
+ }
28
+ const lazyComponent = this.lazyComponentMap.get(component.componentName);
29
+ if (lazyComponent) {
30
+ return lazyComponent.loadChildren().then((lazyChild) => {
31
+ let componentType = null;
32
+ const moduleRef = createNgModule(lazyChild, this.injector);
33
+ const dynamicComponentType = moduleRef.injector.get(DYNAMIC_COMPONENT);
34
+ if (!dynamicComponentType) {
35
+ throw new Error(`JssComponentFactoryService: Lazy load module for component "${lazyComponent.path}" missing DYNAMIC_COMPONENT provider. Missing JssModule.forChild()?`);
36
+ }
37
+ if (component.componentName in dynamicComponentType) {
38
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
39
+ componentType = dynamicComponentType[component.componentName];
40
+ }
41
+ else {
42
+ if (typeof dynamicComponentType === 'function') {
43
+ componentType = dynamicComponentType;
44
+ }
45
+ else {
46
+ throw new Error(`JssComponentFactoryService: Lazy load module for component "${lazyComponent.path}" missing DYNAMIC_COMPONENT provider. Missing JssModule.forChild()?`);
47
+ }
48
+ }
49
+ return {
50
+ componentDefinition: component,
51
+ componentImplementation: componentType,
52
+ componentFactory: moduleRef.componentFactoryResolver.resolveComponentFactory(componentType),
53
+ canActivate: lazyComponent.canActivate,
54
+ resolve: lazyComponent.resolve,
55
+ };
56
+ });
57
+ }
58
+ return Promise.resolve({
59
+ componentDefinition: component,
60
+ });
61
+ }
62
+ getComponents(components) {
63
+ // acquire all components and keep them in order while handling their potential async-ness
64
+ return Promise.all(components.map((component) => isRawRendering(component) ? this.getRawComponent(component) : this.getComponent(component)));
65
+ }
66
+ getRawComponent(component) {
67
+ return Promise.resolve({
68
+ componentImplementation: RawComponent,
69
+ componentDefinition: component,
70
+ });
71
+ }
72
+ }
73
+ JssComponentFactoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: JssComponentFactoryService, deps: [{ token: i0.Injector }, { token: PLACEHOLDER_COMPONENTS }, { token: PLACEHOLDER_LAZY_COMPONENTS }], target: i0.ɵɵFactoryTarget.Injectable });
74
+ JssComponentFactoryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: JssComponentFactoryService });
75
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: JssComponentFactoryService, decorators: [{
76
+ type: Injectable
77
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: undefined, decorators: [{
78
+ type: Inject,
79
+ args: [PLACEHOLDER_COMPONENTS]
80
+ }] }, { type: undefined, decorators: [{
81
+ type: Inject,
82
+ args: [PLACEHOLDER_LAZY_COMPONENTS]
83
+ }] }]; } });
84
84
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jss-component-factory.service.js","sourceRoot":"","sources":["../../src/jss-component-factory.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAkB,cAAc,EAAE,MAAM,eAAe,CAAC;AAEnF,OAAO,EAGL,iBAAiB,EAIjB,sBAAsB,EACtB,2BAA2B,GAC5B,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;;AAexD,MAAM,OAAO,0BAA0B;IAIrC,YACU,QAAkB,EACc,UAAkC,EAC7B,cAAwC;QAF7E,aAAQ,GAAR,QAAQ,CAAU;QACc,eAAU,GAAV,UAAU,CAAwB;QAC7B,mBAAc,GAAd,cAAc,CAA0B;QAErF,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,EAAE,CAAC;QAC9B,IAAI,CAAC,gBAAgB,GAAG,IAAI,GAAG,EAAE,CAAC;QAElC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAEjE,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;SAC1E;IACH,CAAC;IAED,YAAY,CAAC,SAA6B;QACxC,MAAM,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QAEvE,IAAI,eAAe,EAAE;YACnB,OAAO,OAAO,CAAC,OAAO,CAAC;gBACrB,mBAAmB,EAAE,SAAS;gBAC9B,uBAAuB,EAAE,eAAe,CAAC,IAAI;gBAC7C,WAAW,EAAE,eAAe,CAAC,WAAW;gBACxC,OAAO,EAAE,eAAe,CAAC,OAAO;aACjC,CAAC,CAAC;SACJ;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QAEzE,IAAI,aAAa,EAAE;YACjB,OAAO,aAAa,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE;gBACrD,IAAI,aAAa,GAAG,IAAI,CAAC;gBACzB,MAAM,SAAS,GAAG,cAAc,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC3D,MAAM,oBAAoB,GAAG,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;gBACvE,IAAI,CAAC,oBAAoB,EAAE;oBACzB,MAAM,IAAI,KAAK,CACb,+DAA+D,aAAa,CAAC,IAAI,qEAAqE,CACvJ,CAAC;iBACH;gBAED,IAAI,SAAS,CAAC,aAAa,IAAI,oBAAoB,EAAE;oBACnD,8DAA8D;oBAC9D,aAAa,GAAI,oBAA6C,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;iBACzF;qBAAM;oBACL,IAAI,OAAO,oBAAoB,KAAK,UAAU,EAAE;wBAC9C,aAAa,GAAG,oBAAoB,CAAC;qBACtC;yBAAM;wBACL,MAAM,IAAI,KAAK,CACb,+DAA+D,aAAa,CAAC,IAAI,qEAAqE,CACvJ,CAAC;qBACH;iBACF;gBAED,OAAO;oBACL,mBAAmB,EAAE,SAAS;oBAC9B,uBAAuB,EAAE,aAAa;oBACtC,gBAAgB,EAAE,SAAS,CAAC,wBAAwB,CAAC,uBAAuB,CAC1E,aAAa,CACd;oBACD,WAAW,EAAE,aAAa,CAAC,WAAW;oBACtC,OAAO,EAAE,aAAa,CAAC,OAAO;iBAC/B,CAAC;YACJ,CAAC,CAAC,CAAC;SACJ;QAED,OAAO,OAAO,CAAC,OAAO,CAAC;YACrB,mBAAmB,EAAE,SAAS;SAC/B,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CACX,UAA4D;QAE5D,0FAA0F;QAC1F,OAAO,OAAO,CAAC,GAAG,CAChB,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAC3B,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAC3F,CACF,CAAC;IACJ,CAAC;IAEO,eAAe,CAAC,SAA+B;QACrD,OAAO,OAAO,CAAC,OAAO,CAAC;YACrB,uBAAuB,EAAE,YAAY;YACrC,mBAAmB,EAAE,SAAS;SAC/B,CAAC,CAAC;IACL,CAAC;;wHA1FU,0BAA0B,0CAM3B,sBAAsB,aACtB,2BAA2B;4HAP1B,0BAA0B;4FAA1B,0BAA0B;kBADtC,UAAU;;0BAON,MAAM;2BAAC,sBAAsB;;0BAC7B,MAAM;2BAAC,2BAA2B","sourcesContent":["import { Inject, Injectable, Injector, Type, createNgModule } from '@angular/core';\r\nimport { ComponentRendering, HtmlElementRendering } from '@sitecore-jss/sitecore-jss/layout';\r\nimport {\r\n  ComponentNameAndModule,\r\n  ComponentNameAndType,\r\n  DYNAMIC_COMPONENT,\r\n  JssCanActivate,\r\n  JssCanActivateFn,\r\n  JssResolve,\r\n  PLACEHOLDER_COMPONENTS,\r\n  PLACEHOLDER_LAZY_COMPONENTS,\r\n} from './components/placeholder.token';\r\nimport { RawComponent } from './components/raw.component';\r\nimport { isRawRendering } from './components/rendering';\r\n\r\nexport interface ComponentFactoryResult {\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  componentImplementation?: Type<any>;\r\n  componentDefinition: ComponentRendering | HtmlElementRendering;\r\n  canActivate?:\r\n    | JssCanActivate\r\n    | Type<JssCanActivate>\r\n    | JssCanActivateFn\r\n    | Array<JssCanActivate | JssCanActivateFn | Type<JssCanActivate>>;\r\n  resolve?: { [key: string]: JssResolve<any> | Type<JssResolve<any>> };\r\n}\r\n\r\n@Injectable()\r\nexport class JssComponentFactoryService {\r\n  private componentMap: Map<string, ComponentNameAndType>;\r\n  private lazyComponentMap: Map<string, ComponentNameAndModule>;\r\n\r\n  constructor(\r\n    private injector: Injector,\r\n    @Inject(PLACEHOLDER_COMPONENTS) private components: ComponentNameAndType[],\r\n    @Inject(PLACEHOLDER_LAZY_COMPONENTS) private lazyComponents: ComponentNameAndModule[]\r\n  ) {\r\n    this.componentMap = new Map();\r\n    this.lazyComponentMap = new Map();\r\n\r\n    this.components.forEach((c) => this.componentMap.set(c.name, c));\r\n\r\n    if (this.lazyComponents) {\r\n      this.lazyComponents.forEach((c) => this.lazyComponentMap.set(c.path, c));\r\n    }\r\n  }\r\n\r\n  getComponent(component: ComponentRendering): Promise<ComponentFactoryResult> {\r\n    const loadedComponent = this.componentMap.get(component.componentName);\r\n\r\n    if (loadedComponent) {\r\n      return Promise.resolve({\r\n        componentDefinition: component,\r\n        componentImplementation: loadedComponent.type,\r\n        canActivate: loadedComponent.canActivate,\r\n        resolve: loadedComponent.resolve,\r\n      });\r\n    }\r\n\r\n    const lazyComponent = this.lazyComponentMap.get(component.componentName);\r\n\r\n    if (lazyComponent) {\r\n      return lazyComponent.loadChildren().then((lazyChild) => {\r\n        let componentType = null;\r\n        const moduleRef = createNgModule(lazyChild, this.injector);\r\n        const dynamicComponentType = moduleRef.injector.get(DYNAMIC_COMPONENT);\r\n        if (!dynamicComponentType) {\r\n          throw new Error(\r\n            `JssComponentFactoryService: Lazy load module for component \"${lazyComponent.path}\" missing DYNAMIC_COMPONENT provider. Missing JssModule.forChild()?`\r\n          );\r\n        }\r\n\r\n        if (component.componentName in dynamicComponentType) {\r\n          // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n          componentType = (dynamicComponentType as { [s: string]: any })[component.componentName];\r\n        } else {\r\n          if (typeof dynamicComponentType === 'function') {\r\n            componentType = dynamicComponentType;\r\n          } else {\r\n            throw new Error(\r\n              `JssComponentFactoryService: Lazy load module for component \"${lazyComponent.path}\" missing DYNAMIC_COMPONENT provider. Missing JssModule.forChild()?`\r\n            );\r\n          }\r\n        }\r\n\r\n        return {\r\n          componentDefinition: component,\r\n          componentImplementation: componentType,\r\n          componentFactory: moduleRef.componentFactoryResolver.resolveComponentFactory(\r\n            componentType\r\n          ),\r\n          canActivate: lazyComponent.canActivate,\r\n          resolve: lazyComponent.resolve,\r\n        };\r\n      });\r\n    }\r\n\r\n    return Promise.resolve({\r\n      componentDefinition: component,\r\n    });\r\n  }\r\n\r\n  getComponents(\r\n    components: Array<ComponentRendering | HtmlElementRendering>\r\n  ): Promise<ComponentFactoryResult[]> {\r\n    // acquire all components and keep them in order while handling their potential async-ness\r\n    return Promise.all(\r\n      components.map((component) =>\r\n        isRawRendering(component) ? this.getRawComponent(component) : this.getComponent(component)\r\n      )\r\n    );\r\n  }\r\n\r\n  private getRawComponent(component: HtmlElementRendering): Promise<ComponentFactoryResult> {\r\n    return Promise.resolve({\r\n      componentImplementation: RawComponent,\r\n      componentDefinition: component,\r\n    });\r\n  }\r\n}\r\n"]}