@sitecore-jss/sitecore-jss-angular 21.2.3 → 21.2.4-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.
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,118 +1,118 @@
1
- import { Directive, Input, } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class LinkDirective {
4
- constructor(viewContainer, templateRef, renderer, elementRef) {
5
- this.viewContainer = viewContainer;
6
- this.templateRef = templateRef;
7
- this.renderer = renderer;
8
- this.elementRef = elementRef;
9
- this.editable = true;
10
- this.attrs = {};
11
- this.inlineRef = null;
12
- }
13
- ngOnChanges(changes) {
14
- if (changes.field || changes.editable || changes.attrs) {
15
- this.viewContainer.clear();
16
- if (this.inlineRef) {
17
- this.inlineRef.remove();
18
- this.inlineRef = null;
19
- }
20
- this.updateView();
21
- }
22
- }
23
- renderTemplate(props, linkText) {
24
- const viewRef = this.viewContainer.createEmbeddedView(this.templateRef);
25
- viewRef.rootNodes.forEach((node) => {
26
- Object.entries(props).forEach(([key, propValue]) => {
27
- this.updateAttribute(node, key, propValue);
28
- });
29
- if (node.childNodes && node.childNodes.length === 0 && linkText) {
30
- node.textContent = linkText;
31
- }
32
- });
33
- }
34
- updateAttribute(node, key, propValue) {
35
- if (typeof propValue !== 'string' || !propValue || propValue === '') {
36
- return;
37
- }
38
- if (key === 'href') {
39
- const isInvalidLink = !propValue || /^https?:\/\/$/.test(propValue);
40
- if (isInvalidLink) {
41
- if (!node.href) {
42
- return;
43
- }
44
- propValue = node.href;
45
- }
46
- this.renderer.setAttribute(node, key, propValue);
47
- }
48
- else if (key === 'class' && node.className !== '') {
49
- this.renderer.setAttribute(node, key, `${node.className} ${propValue}`);
50
- }
51
- else {
52
- this.renderer.setAttribute(node, key, propValue);
53
- }
54
- }
55
- updateView() {
56
- const field = this.field;
57
- if (this.editable && field && field.editableFirstPart && field.editableLastPart) {
58
- this.renderInlineWrapper(field.editableFirstPart, field.editableLastPart);
59
- }
60
- else if (field && (field.href || field.value)) {
61
- const props = field.href ? field : field.value;
62
- const linkText = field.text || field.value?.text || field.href || field.value?.href;
63
- const anchor = props?.anchor ? `#${props.anchor}` : '';
64
- const href = `${props?.href}${anchor}`;
65
- const mergedAttrs = { ...props, ...this.attrs, href };
66
- delete mergedAttrs.anchor;
67
- this.renderTemplate(mergedAttrs, linkText);
68
- }
69
- }
70
- renderInlineWrapper(editableFirstPart, editableLastPart) {
71
- const span = this.renderer.createElement('span');
72
- span.className = 'sc-link-wrapper';
73
- span.innerHTML = editableFirstPart + editableLastPart;
74
- // assign attributes from template to inline wrapper
75
- const attrs = {
76
- ...this.getElementAttrs(),
77
- ...this.attrs,
78
- };
79
- Object.entries(attrs).forEach(([key, attrValue]) => this.updateAttribute(span, key, attrValue));
80
- this.viewContainer.createEmbeddedView(this.templateRef);
81
- const parentNode = this.renderer.parentNode(this.elementRef.nativeElement);
82
- this.renderer.insertBefore(parentNode, span, this.elementRef.nativeElement);
83
- this.inlineRef = span;
84
- }
85
- getElementAttrs() {
86
- const view = this.templateRef.createEmbeddedView(null);
87
- const element = view.rootNodes[0];
88
- if (!element) {
89
- view.destroy();
90
- return {};
91
- }
92
- const attrs = {};
93
- for (let i = 0; i < element.attributes.length; i++) {
94
- const attr = element.attributes.item(i);
95
- if (attr) {
96
- attrs[attr.name] = attr.value;
97
- }
98
- }
99
- view.destroy();
100
- return attrs;
101
- }
102
- }
103
- LinkDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: LinkDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
104
- LinkDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: LinkDirective, selector: "[scLink]", inputs: { editable: ["scLinkEditable", "editable"], attrs: ["scLinkAttrs", "attrs"], field: ["scLink", "field"] }, usesOnChanges: true, ngImport: i0 });
105
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: LinkDirective, decorators: [{
106
- type: Directive,
107
- args: [{ selector: '[scLink]' }]
108
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { editable: [{
109
- type: Input,
110
- args: ['scLinkEditable']
111
- }], attrs: [{
112
- type: Input,
113
- args: ['scLinkAttrs']
114
- }], field: [{
115
- type: Input,
116
- args: ['scLink']
117
- }] } });
1
+ import { Directive, Input, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class LinkDirective {
4
+ constructor(viewContainer, templateRef, renderer, elementRef) {
5
+ this.viewContainer = viewContainer;
6
+ this.templateRef = templateRef;
7
+ this.renderer = renderer;
8
+ this.elementRef = elementRef;
9
+ this.editable = true;
10
+ this.attrs = {};
11
+ this.inlineRef = null;
12
+ }
13
+ ngOnChanges(changes) {
14
+ if (changes.field || changes.editable || changes.attrs) {
15
+ this.viewContainer.clear();
16
+ if (this.inlineRef) {
17
+ this.inlineRef.remove();
18
+ this.inlineRef = null;
19
+ }
20
+ this.updateView();
21
+ }
22
+ }
23
+ renderTemplate(props, linkText) {
24
+ const viewRef = this.viewContainer.createEmbeddedView(this.templateRef);
25
+ viewRef.rootNodes.forEach((node) => {
26
+ Object.entries(props).forEach(([key, propValue]) => {
27
+ this.updateAttribute(node, key, propValue);
28
+ });
29
+ if (node.childNodes && node.childNodes.length === 0 && linkText) {
30
+ node.textContent = linkText;
31
+ }
32
+ });
33
+ }
34
+ updateAttribute(node, key, propValue) {
35
+ if (typeof propValue !== 'string' || !propValue || propValue === '') {
36
+ return;
37
+ }
38
+ if (key === 'href') {
39
+ const isInvalidLink = !propValue || /^https?:\/\/$/.test(propValue);
40
+ if (isInvalidLink) {
41
+ if (!node.href) {
42
+ return;
43
+ }
44
+ propValue = node.href;
45
+ }
46
+ this.renderer.setAttribute(node, key, propValue);
47
+ }
48
+ else if (key === 'class' && node.className !== '') {
49
+ this.renderer.setAttribute(node, key, `${node.className} ${propValue}`);
50
+ }
51
+ else {
52
+ this.renderer.setAttribute(node, key, propValue);
53
+ }
54
+ }
55
+ updateView() {
56
+ const field = this.field;
57
+ if (this.editable && field && field.editableFirstPart && field.editableLastPart) {
58
+ this.renderInlineWrapper(field.editableFirstPart, field.editableLastPart);
59
+ }
60
+ else if (field && (field.href || field.value)) {
61
+ const props = field.href ? field : field.value;
62
+ const linkText = field.text || field.value?.text || field.href || field.value?.href;
63
+ const anchor = props?.anchor ? `#${props.anchor}` : '';
64
+ const href = `${props?.href}${anchor}`;
65
+ const mergedAttrs = { ...props, ...this.attrs, href };
66
+ delete mergedAttrs.anchor;
67
+ this.renderTemplate(mergedAttrs, linkText);
68
+ }
69
+ }
70
+ renderInlineWrapper(editableFirstPart, editableLastPart) {
71
+ const span = this.renderer.createElement('span');
72
+ span.className = 'sc-link-wrapper';
73
+ span.innerHTML = editableFirstPart + editableLastPart;
74
+ // assign attributes from template to inline wrapper
75
+ const attrs = {
76
+ ...this.getElementAttrs(),
77
+ ...this.attrs,
78
+ };
79
+ Object.entries(attrs).forEach(([key, attrValue]) => this.updateAttribute(span, key, attrValue));
80
+ this.viewContainer.createEmbeddedView(this.templateRef);
81
+ const parentNode = this.renderer.parentNode(this.elementRef.nativeElement);
82
+ this.renderer.insertBefore(parentNode, span, this.elementRef.nativeElement);
83
+ this.inlineRef = span;
84
+ }
85
+ getElementAttrs() {
86
+ const view = this.templateRef.createEmbeddedView(null);
87
+ const element = view.rootNodes[0];
88
+ if (!element) {
89
+ view.destroy();
90
+ return {};
91
+ }
92
+ const attrs = {};
93
+ for (let i = 0; i < element.attributes.length; i++) {
94
+ const attr = element.attributes.item(i);
95
+ if (attr) {
96
+ attrs[attr.name] = attr.value;
97
+ }
98
+ }
99
+ view.destroy();
100
+ return attrs;
101
+ }
102
+ }
103
+ LinkDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: LinkDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
104
+ LinkDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: LinkDirective, selector: "[scLink]", inputs: { editable: ["scLinkEditable", "editable"], attrs: ["scLinkAttrs", "attrs"], field: ["scLink", "field"] }, usesOnChanges: true, ngImport: i0 });
105
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: LinkDirective, decorators: [{
106
+ type: Directive,
107
+ args: [{ selector: '[scLink]' }]
108
+ }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }, { type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { editable: [{
109
+ type: Input,
110
+ args: ['scLinkEditable']
111
+ }], attrs: [{
112
+ type: Input,
113
+ args: ['scLinkAttrs']
114
+ }], field: [{
115
+ type: Input,
116
+ args: ['scLink']
117
+ }] } });
118
118
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.directive.js","sourceRoot":"","sources":["../../../src/components/link.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  Input,\r\n  OnChanges,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\nimport { LinkField } from './rendering-field';\r\n\r\n@Directive({ selector: '[scLink]' })\r\nexport class LinkDirective implements OnChanges {\r\n  @Input('scLinkEditable') editable = true;\r\n\r\n  @Input('scLinkAttrs') attrs: { [attr: string]: string } = {};\r\n\r\n  @Input('scLink') field: LinkField;\r\n\r\n  private inlineRef: HTMLSpanElement | null = null;\r\n\r\n  constructor(\r\n    protected viewContainer: ViewContainerRef,\r\n    protected templateRef: TemplateRef<unknown>,\r\n    protected renderer: Renderer2,\r\n    private elementRef: ElementRef\r\n  ) {}\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.field || changes.editable || changes.attrs) {\r\n      this.viewContainer.clear();\r\n      if (this.inlineRef) {\r\n        this.inlineRef.remove();\r\n        this.inlineRef = null;\r\n      }\r\n\r\n      this.updateView();\r\n    }\r\n  }\r\n\r\n  protected renderTemplate(props: { [prop: string]: unknown }, linkText?: string) {\r\n    const viewRef = this.viewContainer.createEmbeddedView(this.templateRef);\r\n\r\n    viewRef.rootNodes.forEach((node) => {\r\n      Object.entries(props).forEach(([key, propValue]) => {\r\n        this.updateAttribute(node, key, propValue);\r\n      });\r\n\r\n      if (node.childNodes && node.childNodes.length === 0 && linkText) {\r\n        node.textContent = linkText;\r\n      }\r\n    });\r\n  }\r\n\r\n  protected updateAttribute(node: HTMLElement, key: string, propValue?: unknown) {\r\n    if (typeof propValue !== 'string' || !propValue || propValue === '') {\r\n      return;\r\n    }\r\n\r\n    if (key === 'href') {\r\n      const isInvalidLink = !propValue || /^https?:\\/\\/$/.test(propValue);\r\n\r\n      if (isInvalidLink) {\r\n        if (!(node as HTMLLinkElement).href) {\r\n          return;\r\n        }\r\n\r\n        propValue = (node as HTMLLinkElement).href as string;\r\n      }\r\n      this.renderer.setAttribute(node, key, propValue as string);\r\n    } else if (key === 'class' && node.className !== '') {\r\n      this.renderer.setAttribute(node, key, `${node.className} ${propValue}`);\r\n    } else {\r\n      this.renderer.setAttribute(node, key, propValue);\r\n    }\r\n  }\r\n\r\n  private updateView() {\r\n    const field = this.field;\r\n    if (this.editable && field && field.editableFirstPart && field.editableLastPart) {\r\n      this.renderInlineWrapper(field.editableFirstPart, field.editableLastPart);\r\n    } else if (field && (field.href || field.value)) {\r\n      const props = field.href ? field : field.value;\r\n\r\n      const linkText = field.text || field.value?.text || field.href || field.value?.href;\r\n      const anchor = props?.anchor ? `#${props.anchor}` : '';\r\n      const href = `${props?.href}${anchor}`;\r\n\r\n      const mergedAttrs = { ...props, ...this.attrs, href };\r\n\r\n      delete mergedAttrs.anchor;\r\n\r\n      this.renderTemplate(mergedAttrs, linkText);\r\n    }\r\n  }\r\n\r\n  private renderInlineWrapper(editableFirstPart: string, editableLastPart: string) {\r\n    const span: HTMLSpanElement = this.renderer.createElement('span');\r\n    span.className = 'sc-link-wrapper';\r\n    span.innerHTML = editableFirstPart + editableLastPart;\r\n\r\n    // assign attributes from template to inline wrapper\r\n    const attrs = {\r\n      ...this.getElementAttrs(),\r\n      ...this.attrs,\r\n    };\r\n    Object.entries(attrs).forEach(([key, attrValue]) => this.updateAttribute(span, key, attrValue));\r\n\r\n    this.viewContainer.createEmbeddedView(this.templateRef);\r\n\r\n    const parentNode = this.renderer.parentNode(this.elementRef.nativeElement);\r\n    this.renderer.insertBefore(parentNode, span, this.elementRef.nativeElement);\r\n\r\n    this.inlineRef = span;\r\n  }\r\n\r\n  private getElementAttrs() {\r\n    const view = this.templateRef.createEmbeddedView(null);\r\n    const element: Element = view.rootNodes[0];\r\n    if (!element) {\r\n      view.destroy();\r\n      return {};\r\n    }\r\n    const attrs: { [key: string]: string } = {};\r\n    for (let i = 0; i < element.attributes.length; i++) {\r\n      const attr = element.attributes.item(i);\r\n      if (attr) {\r\n        attrs[attr.name] = attr.value;\r\n      }\r\n    }\r\n    view.destroy();\r\n    return attrs;\r\n  }\r\n}\r\n"]}
@@ -1,8 +1,8 @@
1
- import { Component, Input } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class MissingComponentComponent {
4
- }
5
- MissingComponentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: MissingComponentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1
+ import { Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class MissingComponentComponent {
4
+ }
5
+ MissingComponentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: MissingComponentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
6
  MissingComponentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: MissingComponentComponent, selector: "sc-missing-component", inputs: { rendering: "rendering" }, ngImport: i0, template: `
7
7
  <div
8
8
  style="background: darkorange; outline: 5px solid orange; padding: 10px; color: white; max-width: 500px;"
@@ -10,11 +10,11 @@ MissingComponentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.
10
10
  <h2>{{ rendering.componentName }}</h2>
11
11
  <p>JSS component is missing Angular component implementation.</p>
12
12
  </div>
13
- `, isInline: true });
14
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: MissingComponentComponent, decorators: [{
15
- type: Component,
16
- args: [{
17
- selector: 'sc-missing-component',
13
+ `, isInline: true });
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: MissingComponentComponent, decorators: [{
15
+ type: Component,
16
+ args: [{
17
+ selector: 'sc-missing-component',
18
18
  template: `
19
19
  <div
20
20
  style="background: darkorange; outline: 5px solid orange; padding: 10px; color: white; max-width: 500px;"
@@ -22,9 +22,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
22
22
  <h2>{{ rendering.componentName }}</h2>
23
23
  <p>JSS component is missing Angular component implementation.</p>
24
24
  </div>
25
- `,
26
- }]
27
- }], propDecorators: { rendering: [{
28
- type: Input
29
- }] } });
25
+ `,
26
+ }]
27
+ }], propDecorators: { rendering: [{
28
+ type: Input
29
+ }] } });
30
30
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWlzc2luZy1jb21wb25lbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvbWlzc2luZy1jb21wb25lbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQWNqRCxNQUFNLE9BQU8seUJBQXlCOzt1SEFBekIseUJBQXlCOzJHQUF6Qix5QkFBeUIsZ0dBVDFCOzs7Ozs7O0dBT1Q7NEZBRVUseUJBQXlCO2tCQVhyQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLFFBQVEsRUFBRTs7Ozs7OztHQU9UO2lCQUNGOzhCQUVVLFNBQVM7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbXBvbmVudFJlbmRlcmluZyB9IGZyb20gJ0BzaXRlY29yZS1qc3Mvc2l0ZWNvcmUtanNzL2xheW91dCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3NjLW1pc3NpbmctY29tcG9uZW50JyxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPGRpdlxyXG4gICAgICBzdHlsZT1cImJhY2tncm91bmQ6IGRhcmtvcmFuZ2U7IG91dGxpbmU6IDVweCBzb2xpZCBvcmFuZ2U7IHBhZGRpbmc6IDEwcHg7IGNvbG9yOiB3aGl0ZTsgbWF4LXdpZHRoOiA1MDBweDtcIlxyXG4gICAgPlxyXG4gICAgICA8aDI+e3sgcmVuZGVyaW5nLmNvbXBvbmVudE5hbWUgfX08L2gyPlxyXG4gICAgICA8cD5KU1MgY29tcG9uZW50IGlzIG1pc3NpbmcgQW5ndWxhciBjb21wb25lbnQgaW1wbGVtZW50YXRpb24uPC9wPlxyXG4gICAgPC9kaXY+XHJcbiAgYCxcclxufSlcclxuZXhwb3J0IGNsYXNzIE1pc3NpbmdDb21wb25lbnRDb21wb25lbnQge1xyXG4gIEBJbnB1dCgpIHJlbmRlcmluZzogQ29tcG9uZW50UmVuZGVyaW5nO1xyXG59XHJcbiJdfQ==
@@ -1,16 +1,16 @@
1
- import { Directive } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class PlaceholderLoadingDirective {
4
- constructor(templateRef) {
5
- this.templateRef = templateRef;
6
- }
7
- }
8
- PlaceholderLoadingDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PlaceholderLoadingDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
9
- PlaceholderLoadingDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: PlaceholderLoadingDirective, selector: "[scPlaceholderLoading]", ngImport: i0 });
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PlaceholderLoadingDirective, decorators: [{
11
- type: Directive,
12
- args: [{
13
- selector: '[scPlaceholderLoading]',
14
- }]
15
- }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
1
+ import { Directive } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class PlaceholderLoadingDirective {
4
+ constructor(templateRef) {
5
+ this.templateRef = templateRef;
6
+ }
7
+ }
8
+ PlaceholderLoadingDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PlaceholderLoadingDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
9
+ PlaceholderLoadingDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: PlaceholderLoadingDirective, selector: "[scPlaceholderLoading]", ngImport: i0 });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: PlaceholderLoadingDirective, decorators: [{
11
+ type: Directive,
12
+ args: [{
13
+ selector: '[scPlaceholderLoading]',
14
+ }]
15
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
16
16
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhY2Vob2xkZXItbG9hZGluZy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9wbGFjZWhvbGRlci1sb2FkaW5nLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFlLE1BQU0sZUFBZSxDQUFDOztBQUt2RCxNQUFNLE9BQU8sMkJBQTJCO0lBQ3RDLFlBQW1CLFdBQWlDO1FBQWpDLGdCQUFXLEdBQVgsV0FBVyxDQUFzQjtJQUFHLENBQUM7O3lIQUQ3QywyQkFBMkI7NkdBQTNCLDJCQUEyQjs0RkFBM0IsMkJBQTJCO2tCQUh2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx3QkFBd0I7aUJBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbc2NQbGFjZWhvbGRlckxvYWRpbmddJyxcclxufSlcclxuZXhwb3J0IGNsYXNzIFBsYWNlaG9sZGVyTG9hZGluZ0RpcmVjdGl2ZSB7XHJcbiAgY29uc3RydWN0b3IocHVibGljIHRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjx1bmtub3duPikge31cclxufVxyXG4iXX0=