@sitecore-jss/sitecore-jss-angular 21.2.0-canary.9 → 21.2.0

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 (69) hide show
  1. package/LICENSE.txt +202 -202
  2. package/README.md +10 -10
  3. package/angular.json +48 -48
  4. package/dist/README.md +10 -10
  5. package/dist/components/data-resolver-factory.d.ts +13 -13
  6. package/dist/components/date.directive.d.ts +20 -20
  7. package/dist/components/editframe.component.d.ts +22 -22
  8. package/dist/components/file.directive.d.ts +17 -17
  9. package/dist/components/generic-link.directive.d.ts +20 -20
  10. package/dist/components/guard-resolver-factory.d.ts +11 -11
  11. package/dist/components/hidden-rendering.component.d.ts +7 -7
  12. package/dist/components/image.directive.d.ts +35 -35
  13. package/dist/components/link.directive.d.ts +26 -26
  14. package/dist/components/missing-component.component.d.ts +7 -7
  15. package/dist/components/placeholder-loading.directive.d.ts +8 -8
  16. package/dist/components/placeholder.component.d.ts +59 -59
  17. package/dist/components/placeholder.token.d.ts +64 -64
  18. package/dist/components/raw.component.d.ts +12 -12
  19. package/dist/components/render-component.component.d.ts +33 -33
  20. package/dist/components/render-each.directive.d.ts +8 -8
  21. package/dist/components/render-empty.directive.d.ts +8 -8
  22. package/dist/components/rendering-field.d.ts +41 -40
  23. package/dist/components/rendering.d.ts +5 -5
  24. package/dist/components/rich-text.directive.d.ts +18 -18
  25. package/dist/components/router-link.directive.d.ts +19 -19
  26. package/dist/components/text.directive.d.ts +16 -16
  27. package/dist/esm2020/components/data-resolver-factory.mjs +57 -57
  28. package/dist/esm2020/components/date.directive.mjs +59 -59
  29. package/dist/esm2020/components/editframe.component.mjs +65 -65
  30. package/dist/esm2020/components/file.directive.mjs +44 -44
  31. package/dist/esm2020/components/generic-link.directive.mjs +65 -53
  32. package/dist/esm2020/components/guard-resolver-factory.mjs +87 -87
  33. package/dist/esm2020/components/hidden-rendering.component.mjs +20 -20
  34. package/dist/esm2020/components/image.directive.mjs +137 -137
  35. package/dist/esm2020/components/link.directive.mjs +118 -115
  36. package/dist/esm2020/components/missing-component.component.mjs +15 -15
  37. package/dist/esm2020/components/placeholder-loading.directive.mjs +15 -15
  38. package/dist/esm2020/components/placeholder.component.mjs +250 -250
  39. package/dist/esm2020/components/placeholder.token.mjs +23 -23
  40. package/dist/esm2020/components/raw.component.mjs +35 -35
  41. package/dist/esm2020/components/render-component.component.mjs +90 -90
  42. package/dist/esm2020/components/render-each.directive.mjs +15 -15
  43. package/dist/esm2020/components/render-empty.directive.mjs +15 -15
  44. package/dist/esm2020/components/rendering-field.mjs +2 -2
  45. package/dist/esm2020/components/rendering.mjs +7 -7
  46. package/dist/esm2020/components/rich-text.directive.mjs +62 -62
  47. package/dist/esm2020/components/router-link.directive.mjs +48 -45
  48. package/dist/esm2020/components/text.directive.mjs +57 -57
  49. package/dist/esm2020/jss-component-factory.service.mjs +83 -83
  50. package/dist/esm2020/lib.module.mjs +167 -167
  51. package/dist/esm2020/public_api.mjs +24 -24
  52. package/dist/esm2020/sitecore-jss-sitecore-jss-angular.mjs +4 -4
  53. package/dist/esm2020/utils.mjs +16 -16
  54. package/dist/fesm2015/sitecore-jss-sitecore-jss-angular.mjs +1415 -1403
  55. package/dist/fesm2015/sitecore-jss-sitecore-jss-angular.mjs.map +1 -1
  56. package/dist/fesm2020/sitecore-jss-sitecore-jss-angular.mjs +1422 -1404
  57. package/dist/fesm2020/sitecore-jss-sitecore-jss-angular.mjs.map +1 -1
  58. package/dist/index.d.ts +5 -5
  59. package/dist/jss-component-factory.service.d.ts +25 -25
  60. package/dist/lib.module.d.ts +46 -46
  61. package/dist/package.json +2 -2
  62. package/dist/public_api.d.ts +25 -25
  63. package/dist/typings/README.md +2 -2
  64. package/dist/utils.d.ts +7 -7
  65. package/ng-package.json +13 -13
  66. package/package.json +3 -3
  67. package/tsconfig.json +9 -9
  68. package/tsconfig.spec.json +16 -16
  69. package/typings/README.md +2 -2
@@ -1,266 +1,266 @@
1
- /* eslint-disable @angular-eslint/no-conflicting-lifecycle */
2
- import { isPlatformServer } from '@angular/common';
3
- import { Component, ContentChild, EventEmitter, Inject, Input, Output, PLATFORM_ID, ViewChild, ViewContainerRef, } from '@angular/core';
4
- import { UrlTree } from '@angular/router';
5
- import { Observable } from 'rxjs';
6
- import { takeWhile } from 'rxjs/operators';
7
- import { HIDDEN_RENDERING_NAME } from './hidden-rendering.component';
8
- import { PlaceholderLoadingDirective } from './placeholder-loading.directive';
9
- import { DATA_RESOLVER, GUARD_RESOLVER, PLACEHOLDER_HIDDEN_RENDERING_COMPONENT, PLACEHOLDER_MISSING_COMPONENT_COMPONENT, } from './placeholder.token';
10
- import { RenderEachDirective } from './render-each.directive';
11
- import { RenderEmptyDirective } from './render-empty.directive';
12
- import { isRawRendering } from './rendering';
13
- import * as i0 from "@angular/core";
14
- import * as i1 from "../jss-component-factory.service";
15
- import * as i2 from "@angular/router";
16
- import * as i3 from "@angular/common";
17
- /**
18
- * @param {ComponentRendering} rendering
19
- * @param {string} name
20
- */
21
- function getPlaceholder(rendering, name) {
22
- if (rendering && rendering.placeholders && Object.keys(rendering.placeholders).length > 0) {
23
- return rendering.placeholders[name];
24
- }
25
- return null;
26
- }
27
- export class PlaceholderComponent {
28
- constructor(differs, componentFactory, changeDetectorRef, elementRef, renderer, router, missingComponentComponent, hiddenRenderingComponent, guardResolver, dataResolver,
29
- // eslint-disable-next-line @typescript-eslint/ban-types
30
- platformId) {
31
- this.differs = differs;
32
- this.componentFactory = componentFactory;
33
- this.changeDetectorRef = changeDetectorRef;
34
- this.elementRef = elementRef;
35
- this.renderer = renderer;
36
- this.router = router;
37
- this.missingComponentComponent = missingComponentComponent;
38
- this.hiddenRenderingComponent = hiddenRenderingComponent;
39
- this.guardResolver = guardResolver;
40
- this.dataResolver = dataResolver;
41
- this.platformId = platformId;
42
- this.clientOnly = false;
43
- this.loaded = new EventEmitter();
44
- this.isLoading = true;
45
- this._componentInstances = [];
46
- this.destroyed = false;
47
- this.parentStyleAttribute = '';
48
- }
49
- set inputs(value) {
50
- this._inputs = value;
51
- if (!this._differ && value) {
52
- this._differ = this.differs.find(value).create();
53
- }
54
- }
55
- ngOnInit() {
56
- // just to ensure the element exists
57
- const elem = this.elementRef.nativeElement;
58
- if (elem) {
59
- const attributes = elem.attributes;
60
- for (let i = 0; i < attributes.length; i++) {
61
- const attr = attributes.item(i);
62
- if (attr && attr.name.indexOf('_ngcontent') !== -1) {
63
- this.parentStyleAttribute = attr.name;
64
- }
65
- }
66
- }
67
- }
68
- ngOnDestroy() {
69
- this.destroyed = true;
70
- this._componentInstances = [];
71
- }
72
- ngOnChanges(changes) {
73
- if (changes.rendering || changes.renderings) {
74
- this._render();
75
- }
76
- }
77
- ngDoCheck() {
78
- if (!this._differ || !this._inputs || this._componentInstances.length === 0) {
79
- return;
80
- }
81
- const changes = this._differ.diff(this._inputs);
82
- if (!changes) {
83
- return;
84
- }
85
- const updates = {};
86
- changes.forEachRemovedItem((change) => (updates[change.key] = null));
87
- changes.forEachAddedItem((change) => (updates[change.key] = change.currentValue));
88
- changes.forEachChangedItem((change) => (updates[change.key] = change.currentValue));
89
- this._componentInstances.forEach((componentInstance) => this._setComponentInputs(componentInstance, updates));
90
- }
91
- _setComponentInputs(componentInstance, inputs) {
92
- Object.entries(inputs).forEach(([input, inputValue]) => (componentInstance[input] = inputValue));
93
- }
94
- _subscribeComponentOutputs(componentInstance, outputs) {
95
- Object.keys(outputs)
96
- .filter((output) => componentInstance[output] && componentInstance[output] instanceof Observable)
97
- .forEach((output) => componentInstance[output]
98
- .pipe(takeWhile(() => !this.destroyed))
99
- .subscribe(outputs[output]));
100
- }
101
- async _render() {
102
- if (this.clientOnly && isPlatformServer(this.platformId)) {
103
- return;
104
- }
105
- this._componentInstances = [];
106
- this.view.clear();
107
- if (!this.rendering && !this.renderings) {
108
- return;
109
- }
110
- if (!this.name && !this.renderings) {
111
- console.warn('Placeholder name was not specified, and explicit renderings array was not passed. Placeholder requires either name and rendering, or renderings.');
112
- this.isLoading = false;
113
- return;
114
- }
115
- const placeholder = this.renderings || getPlaceholder(this.rendering, this.name || '');
116
- if (!placeholder) {
117
- console.warn(`Placeholder '${this.name}' was not found in the current rendering data`, JSON.stringify(this.rendering, null, 2));
118
- this.isLoading = false;
119
- return;
120
- }
121
- // if the placeholder is empty (contains only raw renderings), then we may need to use the empty template if it's defined
122
- const placeholderIsEmpty = placeholder.every((rendering) => isRawRendering(rendering));
123
- if (this.renderEmptyTemplate && placeholderIsEmpty) {
124
- this.view.createEmbeddedView(this.renderEmptyTemplate.templateRef, {
125
- renderings: placeholder,
126
- });
127
- this.isLoading = false;
128
- }
129
- else {
130
- const factories = await this.componentFactory.getComponents(placeholder);
131
- try {
132
- const nonGuarded = await this.guardResolver(factories);
133
- const withData = await this.dataResolver(nonGuarded);
134
- withData.forEach((rendering, index) => {
135
- if (this.renderEachTemplate && !isRawRendering(rendering.factory.componentDefinition)) {
136
- this._renderTemplatedComponent(rendering.factory.componentDefinition, index);
137
- }
138
- else {
139
- this._renderEmbeddedComponent(rendering.factory, rendering.data, index);
140
- }
141
- });
142
- this.isLoading = false;
143
- this.changeDetectorRef.markForCheck();
144
- this.loaded.emit(this.name);
145
- }
146
- catch (e) {
147
- this.isLoading = false;
148
- if (e instanceof UrlTree) {
149
- this.router.navigateByUrl(e);
150
- }
151
- else if (typeof e === 'string') {
152
- this.router.navigate([e]);
153
- }
154
- else if (Array.isArray(e)) {
155
- this.router.navigate(e);
156
- }
157
- else {
158
- throw e;
159
- }
160
- }
161
- }
162
- }
163
- _renderTemplatedComponent(rendering, index) {
164
- // the render-each template takes care of all component mapping etc
165
- // generally using <sc-render-component> which is about like _renderEmbeddedComponent()
166
- // as a separate component
167
- this.view.createEmbeddedView(this.renderEachTemplate.templateRef, {
168
- rendering,
169
- index,
170
- });
171
- }
172
- _renderEmbeddedComponent(rendering, data, index) {
173
- if (rendering.componentDefinition.componentName === HIDDEN_RENDERING_NAME) {
174
- rendering.componentImplementation = this.hiddenRenderingComponent;
175
- }
176
- if (!rendering.componentImplementation) {
177
- const componentName = rendering.componentDefinition.componentName;
1
+ /* eslint-disable @angular-eslint/no-conflicting-lifecycle */
2
+ import { isPlatformServer } from '@angular/common';
3
+ import { Component, ContentChild, EventEmitter, Inject, Input, Output, PLATFORM_ID, ViewChild, ViewContainerRef, } from '@angular/core';
4
+ import { UrlTree } from '@angular/router';
5
+ import { Observable } from 'rxjs';
6
+ import { takeWhile } from 'rxjs/operators';
7
+ import { HIDDEN_RENDERING_NAME } from './hidden-rendering.component';
8
+ import { PlaceholderLoadingDirective } from './placeholder-loading.directive';
9
+ import { DATA_RESOLVER, GUARD_RESOLVER, PLACEHOLDER_HIDDEN_RENDERING_COMPONENT, PLACEHOLDER_MISSING_COMPONENT_COMPONENT, } from './placeholder.token';
10
+ import { RenderEachDirective } from './render-each.directive';
11
+ import { RenderEmptyDirective } from './render-empty.directive';
12
+ import { isRawRendering } from './rendering';
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "../jss-component-factory.service";
15
+ import * as i2 from "@angular/router";
16
+ import * as i3 from "@angular/common";
17
+ /**
18
+ * @param {ComponentRendering} rendering
19
+ * @param {string} name
20
+ */
21
+ function getPlaceholder(rendering, name) {
22
+ if (rendering && rendering.placeholders && Object.keys(rendering.placeholders).length > 0) {
23
+ return rendering.placeholders[name];
24
+ }
25
+ return null;
26
+ }
27
+ export class PlaceholderComponent {
28
+ constructor(differs, componentFactory, changeDetectorRef, elementRef, renderer, router, missingComponentComponent, hiddenRenderingComponent, guardResolver, dataResolver,
29
+ // eslint-disable-next-line @typescript-eslint/ban-types
30
+ platformId) {
31
+ this.differs = differs;
32
+ this.componentFactory = componentFactory;
33
+ this.changeDetectorRef = changeDetectorRef;
34
+ this.elementRef = elementRef;
35
+ this.renderer = renderer;
36
+ this.router = router;
37
+ this.missingComponentComponent = missingComponentComponent;
38
+ this.hiddenRenderingComponent = hiddenRenderingComponent;
39
+ this.guardResolver = guardResolver;
40
+ this.dataResolver = dataResolver;
41
+ this.platformId = platformId;
42
+ this.clientOnly = false;
43
+ this.loaded = new EventEmitter();
44
+ this.isLoading = true;
45
+ this._componentInstances = [];
46
+ this.destroyed = false;
47
+ this.parentStyleAttribute = '';
48
+ }
49
+ set inputs(value) {
50
+ this._inputs = value;
51
+ if (!this._differ && value) {
52
+ this._differ = this.differs.find(value).create();
53
+ }
54
+ }
55
+ ngOnInit() {
56
+ // just to ensure the element exists
57
+ const elem = this.elementRef.nativeElement;
58
+ if (elem) {
59
+ const attributes = elem.attributes;
60
+ for (let i = 0; i < attributes.length; i++) {
61
+ const attr = attributes.item(i);
62
+ if (attr && attr.name.indexOf('_ngcontent') !== -1) {
63
+ this.parentStyleAttribute = attr.name;
64
+ }
65
+ }
66
+ }
67
+ }
68
+ ngOnDestroy() {
69
+ this.destroyed = true;
70
+ this._componentInstances = [];
71
+ }
72
+ ngOnChanges(changes) {
73
+ if (changes.rendering || changes.renderings) {
74
+ this._render();
75
+ }
76
+ }
77
+ ngDoCheck() {
78
+ if (!this._differ || !this._inputs || this._componentInstances.length === 0) {
79
+ return;
80
+ }
81
+ const changes = this._differ.diff(this._inputs);
82
+ if (!changes) {
83
+ return;
84
+ }
85
+ const updates = {};
86
+ changes.forEachRemovedItem((change) => (updates[change.key] = null));
87
+ changes.forEachAddedItem((change) => (updates[change.key] = change.currentValue));
88
+ changes.forEachChangedItem((change) => (updates[change.key] = change.currentValue));
89
+ this._componentInstances.forEach((componentInstance) => this._setComponentInputs(componentInstance, updates));
90
+ }
91
+ _setComponentInputs(componentInstance, inputs) {
92
+ Object.entries(inputs).forEach(([input, inputValue]) => (componentInstance[input] = inputValue));
93
+ }
94
+ _subscribeComponentOutputs(componentInstance, outputs) {
95
+ Object.keys(outputs)
96
+ .filter((output) => componentInstance[output] && componentInstance[output] instanceof Observable)
97
+ .forEach((output) => componentInstance[output]
98
+ .pipe(takeWhile(() => !this.destroyed))
99
+ .subscribe(outputs[output]));
100
+ }
101
+ async _render() {
102
+ if (this.clientOnly && isPlatformServer(this.platformId)) {
103
+ return;
104
+ }
105
+ this._componentInstances = [];
106
+ this.view.clear();
107
+ if (!this.rendering && !this.renderings) {
108
+ return;
109
+ }
110
+ if (!this.name && !this.renderings) {
111
+ console.warn('Placeholder name was not specified, and explicit renderings array was not passed. Placeholder requires either name and rendering, or renderings.');
112
+ this.isLoading = false;
113
+ return;
114
+ }
115
+ const placeholder = this.renderings || getPlaceholder(this.rendering, this.name || '');
116
+ if (!placeholder) {
117
+ console.warn(`Placeholder '${this.name}' was not found in the current rendering data`, JSON.stringify(this.rendering, null, 2));
118
+ this.isLoading = false;
119
+ return;
120
+ }
121
+ // if the placeholder is empty (contains only raw renderings), then we may need to use the empty template if it's defined
122
+ const placeholderIsEmpty = placeholder.every((rendering) => isRawRendering(rendering));
123
+ if (this.renderEmptyTemplate && placeholderIsEmpty) {
124
+ this.view.createEmbeddedView(this.renderEmptyTemplate.templateRef, {
125
+ renderings: placeholder,
126
+ });
127
+ this.isLoading = false;
128
+ }
129
+ else {
130
+ const factories = await this.componentFactory.getComponents(placeholder);
131
+ try {
132
+ const nonGuarded = await this.guardResolver(factories);
133
+ const withData = await this.dataResolver(nonGuarded);
134
+ withData.forEach((rendering, index) => {
135
+ if (this.renderEachTemplate && !isRawRendering(rendering.factory.componentDefinition)) {
136
+ this._renderTemplatedComponent(rendering.factory.componentDefinition, index);
137
+ }
138
+ else {
139
+ this._renderEmbeddedComponent(rendering.factory, rendering.data, index);
140
+ }
141
+ });
142
+ this.isLoading = false;
143
+ this.changeDetectorRef.markForCheck();
144
+ this.loaded.emit(this.name);
145
+ }
146
+ catch (e) {
147
+ this.isLoading = false;
148
+ if (e instanceof UrlTree) {
149
+ this.router.navigateByUrl(e);
150
+ }
151
+ else if (typeof e === 'string') {
152
+ this.router.navigate([e]);
153
+ }
154
+ else if (Array.isArray(e)) {
155
+ this.router.navigate(e);
156
+ }
157
+ else {
158
+ throw e;
159
+ }
160
+ }
161
+ }
162
+ }
163
+ _renderTemplatedComponent(rendering, index) {
164
+ // the render-each template takes care of all component mapping etc
165
+ // generally using <sc-render-component> which is about like _renderEmbeddedComponent()
166
+ // as a separate component
167
+ this.view.createEmbeddedView(this.renderEachTemplate.templateRef, {
168
+ rendering,
169
+ index,
170
+ });
171
+ }
172
+ _renderEmbeddedComponent(rendering, data, index) {
173
+ if (rendering.componentDefinition.componentName === HIDDEN_RENDERING_NAME) {
174
+ rendering.componentImplementation = this.hiddenRenderingComponent;
175
+ }
176
+ if (!rendering.componentImplementation) {
177
+ const componentName = rendering.componentDefinition.componentName;
178
178
  console.error(`Placeholder ${this.name} contains unknown component ${componentName}.`, `Ensure component is mapped, like:
179
179
  JssModule.withComponents([
180
180
  { name: '${componentName}', type: ${componentName}Component }
181
- ])`);
182
- rendering.componentImplementation = this.missingComponentComponent;
183
- }
184
- // apply the parent style attribute _ngcontent
185
- // work-around for https://github.com/angular/angular/issues/12215
186
- const createdComponentRef = this.view.createComponent(rendering.componentImplementation, {
187
- index: index,
188
- });
189
- if (this.parentStyleAttribute) {
190
- this.renderer.setAttribute(createdComponentRef.location.nativeElement, this.parentStyleAttribute, '');
191
- }
192
- const componentInstance = createdComponentRef.instance;
193
- componentInstance.rendering = rendering.componentDefinition;
194
- componentInstance.data = data;
195
- if (this._inputs) {
196
- this._setComponentInputs(componentInstance, this._inputs);
197
- }
198
- if (this.outputs) {
199
- this._subscribeComponentOutputs(componentInstance, this.outputs);
200
- }
201
- this._componentInstances.push(componentInstance);
202
- }
203
- }
204
- PlaceholderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PlaceholderComponent, deps: [{ token: i0.KeyValueDiffers }, { token: i1.JssComponentFactoryService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i2.Router }, { token: PLACEHOLDER_MISSING_COMPONENT_COMPONENT }, { token: PLACEHOLDER_HIDDEN_RENDERING_COMPONENT }, { token: GUARD_RESOLVER }, { token: DATA_RESOLVER }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
181
+ ])`);
182
+ rendering.componentImplementation = this.missingComponentComponent;
183
+ }
184
+ // apply the parent style attribute _ngcontent
185
+ // work-around for https://github.com/angular/angular/issues/12215
186
+ const createdComponentRef = this.view.createComponent(rendering.componentImplementation, {
187
+ index: index,
188
+ });
189
+ if (this.parentStyleAttribute) {
190
+ this.renderer.setAttribute(createdComponentRef.location.nativeElement, this.parentStyleAttribute, '');
191
+ }
192
+ const componentInstance = createdComponentRef.instance;
193
+ componentInstance.rendering = rendering.componentDefinition;
194
+ componentInstance.data = data;
195
+ if (this._inputs) {
196
+ this._setComponentInputs(componentInstance, this._inputs);
197
+ }
198
+ if (this.outputs) {
199
+ this._subscribeComponentOutputs(componentInstance, this.outputs);
200
+ }
201
+ this._componentInstances.push(componentInstance);
202
+ }
203
+ }
204
+ PlaceholderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PlaceholderComponent, deps: [{ token: i0.KeyValueDiffers }, { token: i1.JssComponentFactoryService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i2.Router }, { token: PLACEHOLDER_MISSING_COMPONENT_COMPONENT }, { token: PLACEHOLDER_HIDDEN_RENDERING_COMPONENT }, { token: GUARD_RESOLVER }, { token: DATA_RESOLVER }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
205
205
  PlaceholderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: PlaceholderComponent, selector: "sc-placeholder,[sc-placeholder]", inputs: { name: "name", rendering: "rendering", renderings: "renderings", outputs: "outputs", clientOnly: "clientOnly", inputs: "inputs" }, outputs: { loaded: "loaded" }, queries: [{ propertyName: "renderEachTemplate", first: true, predicate: RenderEachDirective, descendants: true, static: true }, { propertyName: "renderEmptyTemplate", first: true, predicate: RenderEmptyDirective, descendants: true, static: true }, { propertyName: "placeholderLoading", first: true, predicate: PlaceholderLoadingDirective, descendants: true, static: true }], viewQueries: [{ propertyName: "view", first: true, predicate: ["view"], descendants: true, read: ViewContainerRef, static: true }], usesOnChanges: true, ngImport: i0, template: `
206
206
  <ng-template
207
207
  *ngIf="isLoading"
208
208
  [ngTemplateOutlet]="placeholderLoading?.templateRef"
209
209
  ></ng-template>
210
210
  <ng-template #view></ng-template>
211
- `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
212
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PlaceholderComponent, decorators: [{
213
- type: Component,
214
- args: [{
215
- selector: 'sc-placeholder,[sc-placeholder]',
211
+ `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
212
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PlaceholderComponent, decorators: [{
213
+ type: Component,
214
+ args: [{
215
+ selector: 'sc-placeholder,[sc-placeholder]',
216
216
  template: `
217
217
  <ng-template
218
218
  *ngIf="isLoading"
219
219
  [ngTemplateOutlet]="placeholderLoading?.templateRef"
220
220
  ></ng-template>
221
221
  <ng-template #view></ng-template>
222
- `,
223
- }]
224
- }], ctorParameters: function () { return [{ type: i0.KeyValueDiffers }, { type: i1.JssComponentFactoryService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.Router }, { type: i0.Type, decorators: [{
225
- type: Inject,
226
- args: [PLACEHOLDER_MISSING_COMPONENT_COMPONENT]
227
- }] }, { type: i0.Type, decorators: [{
228
- type: Inject,
229
- args: [PLACEHOLDER_HIDDEN_RENDERING_COMPONENT]
230
- }] }, { type: undefined, decorators: [{
231
- type: Inject,
232
- args: [GUARD_RESOLVER]
233
- }] }, { type: undefined, decorators: [{
234
- type: Inject,
235
- args: [DATA_RESOLVER]
236
- }] }, { type: Object, decorators: [{
237
- type: Inject,
238
- args: [PLATFORM_ID]
239
- }] }]; }, propDecorators: { name: [{
240
- type: Input
241
- }], rendering: [{
242
- type: Input
243
- }], renderings: [{
244
- type: Input
245
- }], outputs: [{
246
- type: Input
247
- }], clientOnly: [{
248
- type: Input
249
- }], loaded: [{
250
- type: Output
251
- }], renderEachTemplate: [{
252
- type: ContentChild,
253
- args: [RenderEachDirective, { static: true }]
254
- }], renderEmptyTemplate: [{
255
- type: ContentChild,
256
- args: [RenderEmptyDirective, { static: true }]
257
- }], placeholderLoading: [{
258
- type: ContentChild,
259
- args: [PlaceholderLoadingDirective, { static: true }]
260
- }], view: [{
261
- type: ViewChild,
262
- args: ['view', { read: ViewContainerRef, static: true }]
263
- }], inputs: [{
264
- type: Input
265
- }] } });
222
+ `,
223
+ }]
224
+ }], ctorParameters: function () { return [{ type: i0.KeyValueDiffers }, { type: i1.JssComponentFactoryService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i2.Router }, { type: i0.Type, decorators: [{
225
+ type: Inject,
226
+ args: [PLACEHOLDER_MISSING_COMPONENT_COMPONENT]
227
+ }] }, { type: i0.Type, decorators: [{
228
+ type: Inject,
229
+ args: [PLACEHOLDER_HIDDEN_RENDERING_COMPONENT]
230
+ }] }, { type: undefined, decorators: [{
231
+ type: Inject,
232
+ args: [GUARD_RESOLVER]
233
+ }] }, { type: undefined, decorators: [{
234
+ type: Inject,
235
+ args: [DATA_RESOLVER]
236
+ }] }, { type: Object, decorators: [{
237
+ type: Inject,
238
+ args: [PLATFORM_ID]
239
+ }] }]; }, propDecorators: { name: [{
240
+ type: Input
241
+ }], rendering: [{
242
+ type: Input
243
+ }], renderings: [{
244
+ type: Input
245
+ }], outputs: [{
246
+ type: Input
247
+ }], clientOnly: [{
248
+ type: Input
249
+ }], loaded: [{
250
+ type: Output
251
+ }], renderEachTemplate: [{
252
+ type: ContentChild,
253
+ args: [RenderEachDirective, { static: true }]
254
+ }], renderEmptyTemplate: [{
255
+ type: ContentChild,
256
+ args: [RenderEmptyDirective, { static: true }]
257
+ }], placeholderLoading: [{
258
+ type: ContentChild,
259
+ args: [PlaceholderLoadingDirective, { static: true }]
260
+ }], view: [{
261
+ type: ViewChild,
262
+ args: ['view', { read: ViewContainerRef, static: true }]
263
+ }], inputs: [{
264
+ type: Input
265
+ }] } });
266
266
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"placeholder.component.js","sourceRoot":"","sources":["../../../src/components/placeholder.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/no-conflicting-lifecycle */\r\nimport { isPlatformServer } from '@angular/common';\r\nimport {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ContentChild,\r\n  DoCheck,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  KeyValueDiffer,\r\n  KeyValueDiffers,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  PLATFORM_ID,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  Type,\r\n  ViewChild,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\nimport { Data, UrlTree, Router } from '@angular/router';\r\nimport { ComponentRendering, HtmlElementRendering } from '@sitecore-jss/sitecore-jss/layout';\r\nimport { Observable } from 'rxjs';\r\nimport { takeWhile } from 'rxjs/operators';\r\nimport {\r\n  ComponentFactoryResult,\r\n  JssComponentFactoryService,\r\n} from '../jss-component-factory.service';\r\nimport { HIDDEN_RENDERING_NAME } from './hidden-rendering.component';\r\nimport { PlaceholderLoadingDirective } from './placeholder-loading.directive';\r\nimport {\r\n  DataResolver,\r\n  DATA_RESOLVER,\r\n  GuardResolver,\r\n  GUARD_RESOLVER,\r\n  PLACEHOLDER_HIDDEN_RENDERING_COMPONENT,\r\n  PLACEHOLDER_MISSING_COMPONENT_COMPONENT,\r\n} from './placeholder.token';\r\nimport { RenderEachDirective } from './render-each.directive';\r\nimport { RenderEmptyDirective } from './render-empty.directive';\r\nimport { isRawRendering } from './rendering';\r\n\r\n/**\r\n * @param {ComponentRendering} rendering\r\n * @param {string} name\r\n */\r\nfunction getPlaceholder(rendering: ComponentRendering, name: string) {\r\n  if (rendering && rendering.placeholders && Object.keys(rendering.placeholders).length > 0) {\r\n    return rendering.placeholders[name];\r\n  }\r\n  return null;\r\n}\r\n\r\nexport interface FactoryWithData {\r\n  factory: ComponentFactoryResult;\r\n  data?: Data;\r\n}\r\n\r\n@Component({\r\n  selector: 'sc-placeholder,[sc-placeholder]',\r\n  template: `\r\n    <ng-template\r\n      *ngIf=\"isLoading\"\r\n      [ngTemplateOutlet]=\"placeholderLoading?.templateRef\"\r\n    ></ng-template>\r\n    <ng-template #view></ng-template>\r\n  `,\r\n})\r\nexport class PlaceholderComponent implements OnInit, OnChanges, DoCheck, OnDestroy {\r\n  @Input() name?: string;\r\n  @Input() rendering: ComponentRendering;\r\n  @Input() renderings?: Array<ComponentRendering | HtmlElementRendering>;\r\n  @Input() outputs: { [k: string]: (eventType: unknown) => void };\r\n  @Input() clientOnly = false;\r\n\r\n  @Output() loaded = new EventEmitter<string | undefined>();\r\n\r\n  @ContentChild(RenderEachDirective, { static: true }) renderEachTemplate: RenderEachDirective;\r\n  @ContentChild(RenderEmptyDirective, { static: true }) renderEmptyTemplate: RenderEmptyDirective;\r\n  @ContentChild(PlaceholderLoadingDirective, { static: true })\r\n  placeholderLoading?: PlaceholderLoadingDirective;\r\n\r\n  @ViewChild('view', { read: ViewContainerRef, static: true }) private view: ViewContainerRef;\r\n\r\n  public isLoading = true;\r\n\r\n  private _inputs: { [key: string]: unknown };\r\n  private _differ: KeyValueDiffer<string, unknown>;\r\n  private _componentInstances: { [prop: string]: unknown }[] = [];\r\n  private destroyed = false;\r\n  private parentStyleAttribute = '';\r\n\r\n  @Input()\r\n  set inputs(value: { [key: string]: unknown }) {\r\n    this._inputs = value;\r\n    if (!this._differ && value) {\r\n      this._differ = this.differs.find(value).create();\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private differs: KeyValueDiffers,\r\n    private componentFactory: JssComponentFactoryService,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private elementRef: ElementRef,\r\n    private renderer: Renderer2,\r\n    private router: Router,\r\n    @Inject(PLACEHOLDER_MISSING_COMPONENT_COMPONENT)\r\n    private missingComponentComponent: Type<unknown>,\r\n    @Inject(PLACEHOLDER_HIDDEN_RENDERING_COMPONENT) private hiddenRenderingComponent: Type<unknown>,\r\n    @Inject(GUARD_RESOLVER) private guardResolver: GuardResolver,\r\n    @Inject(DATA_RESOLVER) private dataResolver: DataResolver,\r\n    // eslint-disable-next-line @typescript-eslint/ban-types\r\n    @Inject(PLATFORM_ID) private platformId: Object\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    // just to ensure the element exists\r\n    const elem = this.elementRef.nativeElement;\r\n\r\n    if (elem) {\r\n      const attributes: NamedNodeMap = elem.attributes;\r\n      for (let i = 0; i < attributes.length; i++) {\r\n        const attr: Attr | null = attributes.item(i);\r\n        if (attr && attr.name.indexOf('_ngcontent') !== -1) {\r\n          this.parentStyleAttribute = attr.name;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroyed = true;\r\n    this._componentInstances = [];\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.rendering || changes.renderings) {\r\n      this._render();\r\n    }\r\n  }\r\n\r\n  ngDoCheck() {\r\n    if (!this._differ || !this._inputs || this._componentInstances.length === 0) {\r\n      return;\r\n    }\r\n\r\n    const changes = this._differ.diff(this._inputs);\r\n    if (!changes) {\r\n      return;\r\n    }\r\n    const updates: { [key: string]: unknown } = {};\r\n    changes.forEachRemovedItem((change) => (updates[change.key] = null));\r\n    changes.forEachAddedItem((change) => (updates[change.key] = change.currentValue));\r\n    changes.forEachChangedItem((change) => (updates[change.key] = change.currentValue));\r\n    this._componentInstances.forEach((componentInstance) =>\r\n      this._setComponentInputs(componentInstance, updates)\r\n    );\r\n  }\r\n\r\n  private _setComponentInputs(\r\n    componentInstance: { [key: string]: unknown },\r\n    inputs: { [key: string]: unknown }\r\n  ) {\r\n    Object.entries(inputs).forEach(\r\n      ([input, inputValue]) => (componentInstance[input] = inputValue)\r\n    );\r\n  }\r\n\r\n  private _subscribeComponentOutputs(\r\n    componentInstance: { [key: string]: unknown },\r\n    outputs: { [k: string]: (eventType: unknown) => void }\r\n  ) {\r\n    Object.keys(outputs)\r\n      .filter(\r\n        (output) => componentInstance[output] && componentInstance[output] instanceof Observable\r\n      )\r\n      .forEach((output) =>\r\n        (componentInstance[output] as Observable<unknown>)\r\n          .pipe(takeWhile(() => !this.destroyed))\r\n          .subscribe(outputs[output])\r\n      );\r\n  }\r\n\r\n  private async _render() {\r\n    if (this.clientOnly && isPlatformServer(this.platformId)) {\r\n      return;\r\n    }\r\n\r\n    this._componentInstances = [];\r\n    this.view.clear();\r\n\r\n    if (!this.rendering && !this.renderings) {\r\n      return;\r\n    }\r\n\r\n    if (!this.name && !this.renderings) {\r\n      console.warn(\r\n        'Placeholder name was not specified, and explicit renderings array was not passed. Placeholder requires either name and rendering, or renderings.'\r\n      );\r\n      this.isLoading = false;\r\n      return;\r\n    }\r\n\r\n    const placeholder = this.renderings || getPlaceholder(this.rendering, this.name || '');\r\n\r\n    if (!placeholder) {\r\n      console.warn(\r\n        `Placeholder '${this.name}' was not found in the current rendering data`,\r\n        JSON.stringify(this.rendering, null, 2)\r\n      );\r\n      this.isLoading = false;\r\n      return;\r\n    }\r\n\r\n    // if the placeholder is empty (contains only raw renderings), then we may need to use the empty template if it's defined\r\n    const placeholderIsEmpty = placeholder.every(\r\n      (rendering: ComponentRendering | HtmlElementRendering) => isRawRendering(rendering)\r\n    );\r\n\r\n    if (this.renderEmptyTemplate && placeholderIsEmpty) {\r\n      this.view.createEmbeddedView(this.renderEmptyTemplate.templateRef, {\r\n        renderings: placeholder,\r\n      });\r\n      this.isLoading = false;\r\n    } else {\r\n      const factories = await this.componentFactory.getComponents(placeholder);\r\n\r\n      try {\r\n        const nonGuarded = await this.guardResolver(factories);\r\n        const withData = await this.dataResolver(nonGuarded);\r\n\r\n        withData.forEach((rendering, index) => {\r\n          if (this.renderEachTemplate && !isRawRendering(rendering.factory.componentDefinition)) {\r\n            this._renderTemplatedComponent(rendering.factory.componentDefinition, index);\r\n          } else {\r\n            this._renderEmbeddedComponent(rendering.factory, rendering.data, index);\r\n          }\r\n        });\r\n\r\n        this.isLoading = false;\r\n        this.changeDetectorRef.markForCheck();\r\n        this.loaded.emit(this.name);\r\n      } catch (e) {\r\n        this.isLoading = false;\r\n        if (e instanceof UrlTree) {\r\n          this.router.navigateByUrl(e);\r\n        } else if (typeof e === 'string') {\r\n          this.router.navigate([e]);\r\n        } else if (Array.isArray(e)) {\r\n          this.router.navigate(e);\r\n        } else {\r\n          throw e;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _renderTemplatedComponent(\r\n    rendering: ComponentRendering | HtmlElementRendering,\r\n    index: number\r\n  ) {\r\n    // the render-each template takes care of all component mapping etc\r\n    // generally using <sc-render-component> which is about like _renderEmbeddedComponent()\r\n    // as a separate component\r\n    this.view.createEmbeddedView(this.renderEachTemplate.templateRef, {\r\n      rendering,\r\n      index,\r\n    });\r\n  }\r\n\r\n  private _renderEmbeddedComponent(rendering: ComponentFactoryResult, data: Data, index: number) {\r\n    if (\r\n      (rendering.componentDefinition as ComponentRendering).componentName === HIDDEN_RENDERING_NAME\r\n    ) {\r\n      rendering.componentImplementation = this.hiddenRenderingComponent;\r\n    }\r\n\r\n    if (!rendering.componentImplementation) {\r\n      const componentName = (rendering.componentDefinition as ComponentRendering).componentName;\r\n      console.error(\r\n        `Placeholder ${this.name} contains unknown component ${componentName}.`,\r\n        `Ensure component is mapped, like:\r\n        JssModule.withComponents([\r\n          { name: '${componentName}', type: ${componentName}Component }\r\n        ])`\r\n      );\r\n\r\n      rendering.componentImplementation = this.missingComponentComponent;\r\n    }\r\n    // apply the parent style attribute _ngcontent\r\n    // work-around for https://github.com/angular/angular/issues/12215\r\n    const createdComponentRef = this.view.createComponent(rendering.componentImplementation, {\r\n      index: index,\r\n    });\r\n    if (this.parentStyleAttribute) {\r\n      this.renderer.setAttribute(\r\n        createdComponentRef.location.nativeElement,\r\n        this.parentStyleAttribute,\r\n        ''\r\n      );\r\n    }\r\n\r\n    const componentInstance = createdComponentRef.instance;\r\n    componentInstance.rendering = rendering.componentDefinition;\r\n    componentInstance.data = data;\r\n\r\n    if (this._inputs) {\r\n      this._setComponentInputs(componentInstance, this._inputs);\r\n    }\r\n    if (this.outputs) {\r\n      this._subscribeComponentOutputs(componentInstance, this.outputs);\r\n    }\r\n    this._componentInstances.push(componentInstance);\r\n  }\r\n}\r\n"]}
@@ -1,24 +1,24 @@
1
- import { InjectionToken } from '@angular/core';
2
- /** Registers a statically loaded component */
3
- export class ComponentNameAndType {
4
- }
5
- /**
6
- * @param {unknown} object
7
- */
8
- export function instanceOfComponentNameAndType(object) {
9
- return typeof object === 'object' && object !== null && 'type' in object;
10
- }
11
- /**
12
- * @param {unknown} object
13
- */
14
- export function instanceOfComponentNameAndModule(object) {
15
- return typeof object === 'object' && object !== null && 'module' in object;
16
- }
17
- export const PLACEHOLDER_COMPONENTS = new InjectionToken('Sc.placeholder.components');
18
- export const PLACEHOLDER_LAZY_COMPONENTS = new InjectionToken('Sc.placeholder.lazyComponents');
19
- export const PLACEHOLDER_MISSING_COMPONENT_COMPONENT = new InjectionToken('Sc.placeholder.missingComponentComponent');
20
- export const PLACEHOLDER_HIDDEN_RENDERING_COMPONENT = new InjectionToken('Sc.placeholder.hiddenRenderingComponent');
21
- export const DYNAMIC_COMPONENT = new InjectionToken('Sc.placeholder.dynamicComponent');
22
- export const GUARD_RESOLVER = new InjectionToken('Sc.placeholder.guardResolver');
23
- export const DATA_RESOLVER = new InjectionToken('Sc.placeholder.dataResolver');
1
+ import { InjectionToken } from '@angular/core';
2
+ /** Registers a statically loaded component */
3
+ export class ComponentNameAndType {
4
+ }
5
+ /**
6
+ * @param {unknown} object
7
+ */
8
+ export function instanceOfComponentNameAndType(object) {
9
+ return typeof object === 'object' && object !== null && 'type' in object;
10
+ }
11
+ /**
12
+ * @param {unknown} object
13
+ */
14
+ export function instanceOfComponentNameAndModule(object) {
15
+ return typeof object === 'object' && object !== null && 'module' in object;
16
+ }
17
+ export const PLACEHOLDER_COMPONENTS = new InjectionToken('Sc.placeholder.components');
18
+ export const PLACEHOLDER_LAZY_COMPONENTS = new InjectionToken('Sc.placeholder.lazyComponents');
19
+ export const PLACEHOLDER_MISSING_COMPONENT_COMPONENT = new InjectionToken('Sc.placeholder.missingComponentComponent');
20
+ export const PLACEHOLDER_HIDDEN_RENDERING_COMPONENT = new InjectionToken('Sc.placeholder.hiddenRenderingComponent');
21
+ export const DYNAMIC_COMPONENT = new InjectionToken('Sc.placeholder.dynamicComponent');
22
+ export const GUARD_RESOLVER = new InjectionToken('Sc.placeholder.guardResolver');
23
+ export const DATA_RESOLVER = new InjectionToken('Sc.placeholder.dataResolver');
24
24
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhY2Vob2xkZXIudG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9wbGFjZWhvbGRlci50b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFRLE1BQU0sZUFBZSxDQUFDO0FBTXJELDhDQUE4QztBQUM5QyxNQUFNLE9BQU8sb0JBQW9CO0NBVWhDO0FBbUJEOztHQUVHO0FBQ0gsTUFBTSxVQUFVLDhCQUE4QixDQUFDLE1BQWU7SUFDNUQsT0FBTyxPQUFPLE1BQU0sS0FBSyxRQUFRLElBQUksTUFBTSxLQUFLLElBQUksSUFBSSxNQUFNLElBQUksTUFBTSxDQUFDO0FBQzNFLENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sVUFBVSxnQ0FBZ0MsQ0FDOUMsTUFBZTtJQUVmLE9BQU8sT0FBTyxNQUFNLEtBQUssUUFBUSxJQUFJLE1BQU0sS0FBSyxJQUFJLElBQUksUUFBUSxJQUFJLE1BQU0sQ0FBQztBQUM3RSxDQUFDO0FBRUQsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQ3RELDJCQUEyQixDQUM1QixDQUFDO0FBQ0YsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsSUFBSSxjQUFjLENBQzNELCtCQUErQixDQUNoQyxDQUFDO0FBQ0YsTUFBTSxDQUFDLE1BQU0sdUNBQXVDLEdBQUcsSUFBSSxjQUFjLENBQ3ZFLDBDQUEwQyxDQUMzQyxDQUFDO0FBQ0YsTUFBTSxDQUFDLE1BQU0sc0NBQXNDLEdBQUcsSUFBSSxjQUFjLENBQ3RFLHlDQUF5QyxDQUMxQyxDQUFDO0FBQ0YsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxjQUFjLENBQ2pELGlDQUFpQyxDQUNsQyxDQUFDO0FBSUYsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLElBQUksY0FBYyxDQUFnQiw4QkFBOEIsQ0FBQyxDQUFDO0FBTWhHLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxJQUFJLGNBQWMsQ0FBZSw2QkFBNkIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4sIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgRGF0YSwgUm91dGVyU3RhdGVTbmFwc2hvdCwgVXJsVHJlZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ29tcG9uZW50RmFjdG9yeVJlc3VsdCB9IGZyb20gJy4uL2pzcy1jb21wb25lbnQtZmFjdG9yeS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgQ29tcG9uZW50UmVuZGVyaW5nIH0gZnJvbSAnLi4vcHVibGljX2FwaSc7XHJcblxyXG4vKiogUmVnaXN0ZXJzIGEgc3RhdGljYWxseSBsb2FkZWQgY29tcG9uZW50ICovXHJcbmV4cG9ydCBjbGFzcyBDb21wb25lbnROYW1lQW5kVHlwZSB7XHJcbiAgbmFtZTogc3RyaW5nO1xyXG4gIHR5cGU6IFR5cGU8dW5rbm93bj47XHJcblxyXG4gIGNhbkFjdGl2YXRlPzpcclxuICAgIHwgSnNzQ2FuQWN0aXZhdGVcclxuICAgIHwgVHlwZTxKc3NDYW5BY3RpdmF0ZT5cclxuICAgIHwgSnNzQ2FuQWN0aXZhdGVGblxyXG4gICAgfCBBcnJheTxKc3NDYW5BY3RpdmF0ZSB8IEpzc0NhbkFjdGl2YXRlRm4gfCBUeXBlPEpzc0NhbkFjdGl2YXRlPj47XHJcbiAgcmVzb2x2ZT86IHsgW2tleTogc3RyaW5nXTogSnNzUmVzb2x2ZTx1bmtub3duPiB8IFR5cGU8SnNzUmVzb2x2ZTx1bmtub3duPj4gfTtcclxufVxyXG5cclxuLyoqIFJlZ2lzdGVycyBhIGxhemlseSBsb2FkZWQgY29tcG9uZW50IGJ5IG5hbWUgYW5kIG1vZHVsZSB0byBsYXp5IGxvYWQgd2hlbiBpdCdzIG5lZWRlZCAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIENvbXBvbmVudE5hbWVBbmRNb2R1bGUge1xyXG4gIC8qKiBOYW1lIG9mIHRoZSBjb21wb25lbnQgKi9cclxuICBwYXRoOiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogRHluYW1pYyBpbXBvcnQgb2YgdGhlIGNvbXBvbmVudCxcclxuICAgKiBlLmcuICgpID0+IGltcG9ydCgnLi9wYXRoL3RvL2xhenlsb2FkZWRjb21wb25lbnQubW9kdWxlJykudGhlbihtID0+IG0uTGF6eUxvYWRlZENvbXBvbmVudE1vZHVsZUV4cG9ydE5hbWUpXHJcbiAgICovXHJcbiAgbG9hZENoaWxkcmVuOiAoKSA9PiBQcm9taXNlPFR5cGU8dW5rbm93bj4+O1xyXG4gIGNhbkFjdGl2YXRlPzpcclxuICAgIHwgSnNzQ2FuQWN0aXZhdGVcclxuICAgIHwgSnNzQ2FuQWN0aXZhdGVGblxyXG4gICAgfCBUeXBlPEpzc0NhbkFjdGl2YXRlPlxyXG4gICAgfCBBcnJheTxKc3NDYW5BY3RpdmF0ZSB8IEpzc0NhbkFjdGl2YXRlRm4gfCBUeXBlPEpzc0NhbkFjdGl2YXRlPj47XHJcbiAgcmVzb2x2ZT86IHsgW2tleTogc3RyaW5nXTogSnNzUmVzb2x2ZTx1bmtub3duPiB8IFR5cGU8SnNzUmVzb2x2ZTx1bmtub3duPj4gfTtcclxufVxyXG5cclxuLyoqXHJcbiAqIEBwYXJhbSB7dW5rbm93bn0gb2JqZWN0XHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gaW5zdGFuY2VPZkNvbXBvbmVudE5hbWVBbmRUeXBlKG9iamVjdDogdW5rbm93bik6IG9iamVjdCBpcyBDb21wb25lbnROYW1lQW5kVHlwZSB7XHJcbiAgcmV0dXJuIHR5cGVvZiBvYmplY3QgPT09ICdvYmplY3QnICYmIG9iamVjdCAhPT0gbnVsbCAmJiAndHlwZScgaW4gb2JqZWN0O1xyXG59XHJcblxyXG4vKipcclxuICogQHBhcmFtIHt1bmtub3dufSBvYmplY3RcclxuICovXHJcbmV4cG9ydCBmdW5jdGlvbiBpbnN0YW5jZU9mQ29tcG9uZW50TmFtZUFuZE1vZHVsZShcclxuICBvYmplY3Q6IHVua25vd25cclxuKTogb2JqZWN0IGlzIENvbXBvbmVudE5hbWVBbmRNb2R1bGUge1xyXG4gIHJldHVybiB0eXBlb2Ygb2JqZWN0ID09PSAnb2JqZWN0JyAmJiBvYmplY3QgIT09IG51bGwgJiYgJ21vZHVsZScgaW4gb2JqZWN0O1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgUExBQ0VIT0xERVJfQ09NUE9ORU5UUyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxDb21wb25lbnROYW1lQW5kVHlwZVtdPihcclxuICAnU2MucGxhY2Vob2xkZXIuY29tcG9uZW50cydcclxuKTtcclxuZXhwb3J0IGNvbnN0IFBMQUNFSE9MREVSX0xBWllfQ09NUE9ORU5UUyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxDb21wb25lbnROYW1lQW5kVHlwZVtdPihcclxuICAnU2MucGxhY2Vob2xkZXIubGF6eUNvbXBvbmVudHMnXHJcbik7XHJcbmV4cG9ydCBjb25zdCBQTEFDRUhPTERFUl9NSVNTSU5HX0NPTVBPTkVOVF9DT01QT05FTlQgPSBuZXcgSW5qZWN0aW9uVG9rZW48VHlwZTx1bmtub3duPj4oXHJcbiAgJ1NjLnBsYWNlaG9sZGVyLm1pc3NpbmdDb21wb25lbnRDb21wb25lbnQnXHJcbik7XHJcbmV4cG9ydCBjb25zdCBQTEFDRUhPTERFUl9ISURERU5fUkVOREVSSU5HX0NPTVBPTkVOVCA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUeXBlPHVua25vd24+PihcclxuICAnU2MucGxhY2Vob2xkZXIuaGlkZGVuUmVuZGVyaW5nQ29tcG9uZW50J1xyXG4pO1xyXG5leHBvcnQgY29uc3QgRFlOQU1JQ19DT01QT05FTlQgPSBuZXcgSW5qZWN0aW9uVG9rZW48VHlwZTx1bmtub3duPiB8IHsgW3M6IHN0cmluZ106IHVua25vd24gfT4oXHJcbiAgJ1NjLnBsYWNlaG9sZGVyLmR5bmFtaWNDb21wb25lbnQnXHJcbik7XHJcblxyXG5leHBvcnQgdHlwZSBHdWFyZFJlc29sdmVyID0gKHJlc3VsdDogQ29tcG9uZW50RmFjdG9yeVJlc3VsdFtdKSA9PiBQcm9taXNlPENvbXBvbmVudEZhY3RvcnlSZXN1bHRbXT47XHJcblxyXG5leHBvcnQgY29uc3QgR1VBUkRfUkVTT0xWRVIgPSBuZXcgSW5qZWN0aW9uVG9rZW48R3VhcmRSZXNvbHZlcj4oJ1NjLnBsYWNlaG9sZGVyLmd1YXJkUmVzb2x2ZXInKTtcclxuXHJcbmV4cG9ydCB0eXBlIERhdGFSZXNvbHZlciA9IChcclxuICByZXN1bHQ6IENvbXBvbmVudEZhY3RvcnlSZXN1bHRbXVxyXG4pID0+IFByb21pc2U8QXJyYXk8eyBmYWN0b3J5OiBDb21wb25lbnRGYWN0b3J5UmVzdWx0OyBkYXRhOiBEYXRhIH0+PjtcclxuXHJcbmV4cG9ydCBjb25zdCBEQVRBX1JFU09MVkVSID0gbmV3IEluamVjdGlvblRva2VuPERhdGFSZXNvbHZlcj4oJ1NjLnBsYWNlaG9sZGVyLmRhdGFSZXNvbHZlcicpO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBHdWFyZElucHV0IHtcclxuICBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdDtcclxuICByb3V0ZXJTdGF0ZTogUm91dGVyU3RhdGVTbmFwc2hvdDtcclxuICByZW5kZXJpbmc6IENvbXBvbmVudFJlbmRlcmluZztcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBKc3NDYW5BY3RpdmF0ZUZuIHtcclxuICAoaW5wdXQ6IEd1YXJkSW5wdXQpOlxyXG4gICAgfCBPYnNlcnZhYmxlPGJvb2xlYW4gfCBVcmxUcmVlIHwgc3RyaW5nIHwgc3RyaW5nW10+XHJcbiAgICB8IFByb21pc2U8Ym9vbGVhbiB8IFVybFRyZWUgfCBzdHJpbmcgfCBzdHJpbmdbXT5cclxuICAgIHwgYm9vbGVhblxyXG4gICAgfCBVcmxUcmVlXHJcbiAgICB8IHN0cmluZ1xyXG4gICAgfCBzdHJpbmdbXTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBKc3NDYW5BY3RpdmF0ZSB7XHJcbiAgY2FuQWN0aXZhdGU6IEpzc0NhbkFjdGl2YXRlRm47XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSnNzUmVzb2x2ZTxUPiB7XHJcbiAgcmVzb2x2ZShpbnB1dDogR3VhcmRJbnB1dCk6IE9ic2VydmFibGU8VD4gfCBQcm9taXNlPFQ+IHwgVDtcclxufVxyXG4iXX0=