@ng-icons/core 28.0.0 → 29.0.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.
@@ -1,12 +1,12 @@
1
- import { ChangeDetectionStrategy, Component, ElementRef, inject, Injector, Input, runInInjectionContext, } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, effect, ElementRef, inject, Injector, input, runInInjectionContext, } from '@angular/core';
2
2
  import { injectNgIconPostProcessor, injectNgIconPreProcessor, } from '../../providers/features/csp';
3
+ import { injectLogger } from '../../providers/features/logger';
3
4
  import { injectNgIconConfig } from '../../providers/icon-config.provider';
4
5
  import { injectNgIconLoader, injectNgIconLoaderCache, } from '../../providers/icon-loader.provider';
5
6
  import { injectNgIcons } from '../../providers/icon.provider';
6
7
  import { coerceLoaderResult } from '../../utils/async';
7
8
  import { coerceCssPixelValue } from '../../utils/coercion';
8
9
  import { toPropertyName } from '../../utils/format';
9
- import { injectLogger } from '../../providers/features/logger';
10
10
  import * as i0 from "@angular/core";
11
11
  export class NgIcon {
12
12
  constructor() {
@@ -28,69 +28,30 @@ export class NgIcon {
28
28
  this.elementRef = inject(ElementRef);
29
29
  /** Access the logger */
30
30
  this.logger = injectLogger();
31
+ /** Define the name of the icon to display */
32
+ this.name = input();
33
+ /** Define the svg of the icon to display */
34
+ this.svg = input();
31
35
  /** Define the size of the icon */
32
- this.size = this.config.size;
36
+ this.size = input(this.config.size, { transform: coerceCssPixelValue });
37
+ /** Define the stroke-width of the icon */
38
+ this.strokeWidth = input();
33
39
  /** Define the color of the icon */
34
- this.color = this.config.color;
35
- }
36
- /** Define the name of the icon to display */
37
- set name(name) {
38
- this.setIcon(name);
39
- }
40
- /** Define the svg of the icon to display */
41
- set svg(svg) {
42
- this.setSvg(svg);
43
- }
44
- ngOnChanges(changes) {
45
- if (changes.size) {
46
- this.setIconSize();
47
- }
48
- if (changes.color) {
49
- this.setIconColor();
50
- }
51
- if (changes.strokeWidth) {
52
- this.setIconStrokeWidth();
53
- }
54
- }
55
- ngOnInit() {
56
- this.setIconStyles();
40
+ this.color = input(this.config.color);
41
+ // update the icon anytime the name or svg changes
42
+ effect(() => this.updateIcon());
57
43
  }
58
- setIconColor() {
59
- this.elementRef.nativeElement.style.removeProperty('color');
60
- if (this.color !== undefined) {
61
- this.elementRef.nativeElement.style.setProperty('color', this.color);
44
+ async updateIcon() {
45
+ const name = this.name();
46
+ const svg = this.svg();
47
+ // if the svg is defined, insert it into the template
48
+ if (svg !== undefined) {
49
+ this.setSvg(svg);
50
+ return;
62
51
  }
63
- }
64
- setIconSize() {
65
- this.elementRef.nativeElement.style.removeProperty('--ng-icon__size');
66
- if (this.size !== undefined) {
67
- this.elementRef.nativeElement.style.setProperty('--ng-icon__size', this.size.toString());
52
+ if (name === undefined) {
53
+ return;
68
54
  }
69
- }
70
- setIconStrokeWidth() {
71
- this.elementRef.nativeElement.style.removeProperty('--ng-icon__stroke-width');
72
- if (this.strokeWidth !== undefined) {
73
- this.elementRef.nativeElement.style.setProperty('--ng-icon__stroke-width', this.strokeWidth.toString());
74
- }
75
- }
76
- /**
77
- * Set the styles for the icon. We use the style property to set the styles
78
- * rather than the host binding as it works with CSP.
79
- */
80
- setIconStyles() {
81
- this.setIconColor();
82
- this.setIconSize();
83
- this.setIconStrokeWidth();
84
- }
85
- setSvg(svg) {
86
- this.elementRef.nativeElement.innerHTML = this.preProcessor(svg);
87
- this.postProcessor(this.elementRef.nativeElement);
88
- }
89
- /**
90
- * Load the icon with the given name and insert it into the template.
91
- * @param name The name of the icon to load.
92
- */
93
- async setIcon(name) {
94
55
  const propertyName = toPropertyName(name);
95
56
  for (const icons of [...this.icons].reverse()) {
96
57
  if (icons[propertyName]) {
@@ -111,6 +72,10 @@ export class NgIcon {
111
72
  // if there is no icon with this name warn the user as they probably forgot to import it
112
73
  this.logger.warn(`No icon named ${name} was found. You may need to import it using the withIcons function.`);
113
74
  }
75
+ setSvg(svg) {
76
+ this.elementRef.nativeElement.innerHTML = this.preProcessor(svg);
77
+ this.postProcessor(this.elementRef.nativeElement);
78
+ }
114
79
  /**
115
80
  * Request the icon from the loader.
116
81
  * @param name The name of the icon to load.
@@ -145,22 +110,15 @@ export class NgIcon {
145
110
  });
146
111
  });
147
112
  }
148
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgIcon, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
149
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: NgIcon, isStandalone: true, selector: "ng-icon", inputs: { name: "name", svg: "svg", size: ["size", "size", coerceCssPixelValue], strokeWidth: "strokeWidth", color: "color" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true, styles: [":host{display:inline-block;width:var(--ng-icon__size);height:var(--ng-icon__size);overflow:hidden}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
113
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgIcon, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
114
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.0", type: NgIcon, isStandalone: true, selector: "ng-icon", inputs: { name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, svg: { classPropertyName: "svg", publicName: "svg", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, strokeWidth: { classPropertyName: "strokeWidth", publicName: "strokeWidth", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "style.--ng-icon__stroke-width": "strokeWidth()", "style.--ng-icon__size": "size()", "style.color": "color()" } }, ngImport: i0, template: '', isInline: true, styles: [":host{display:inline-block;width:var(--ng-icon__size, 1em);height:var(--ng-icon__size, 1em);line-height:initial;vertical-align:initial;overflow:hidden}:host ::ng-deep svg{width:inherit;height:inherit;vertical-align:inherit}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
150
115
  }
151
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgIcon, decorators: [{
116
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgIcon, decorators: [{
152
117
  type: Component,
153
- args: [{ selector: 'ng-icon', template: '', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:inline-block;width:var(--ng-icon__size);height:var(--ng-icon__size);overflow:hidden}\n"] }]
154
- }], propDecorators: { name: [{
155
- type: Input
156
- }], svg: [{
157
- type: Input
158
- }], size: [{
159
- type: Input,
160
- args: [{ transform: coerceCssPixelValue }]
161
- }], strokeWidth: [{
162
- type: Input
163
- }], color: [{
164
- type: Input
165
- }] } });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/lib/components/icon/icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  inject,\n  Injector,\n  Input,\n  OnChanges,\n  OnInit,\n  runInInjectionContext,\n  SimpleChanges,\n} from '@angular/core';\nimport type { IconName } from '../../components/icon/icon-name';\nimport {\n  injectNgIconPostProcessor,\n  injectNgIconPreProcessor,\n} from '../../providers/features/csp';\nimport { injectNgIconConfig } from '../../providers/icon-config.provider';\nimport {\n  injectNgIconLoader,\n  injectNgIconLoaderCache,\n} from '../../providers/icon-loader.provider';\nimport { injectNgIcons } from '../../providers/icon.provider';\nimport { coerceLoaderResult } from '../../utils/async';\nimport { coerceCssPixelValue } from '../../utils/coercion';\nimport { toPropertyName } from '../../utils/format';\nimport { injectLogger } from '../../providers/features/logger';\n\n// This is a typescript type to prevent inference from collapsing the union type to a string to improve type safety\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport type IconType = IconName | (string & {});\n\n@Component({\n  selector: 'ng-icon',\n  template: '',\n  standalone: true,\n  styleUrls: ['./icon.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgIcon implements OnInit, OnChanges {\n  /** Access the global icon config */\n  private readonly config = injectNgIconConfig();\n\n  /** Access the icons */\n  private readonly icons = injectNgIcons();\n\n  /** Access the icon loader if defined */\n  private readonly loader = injectNgIconLoader();\n\n  /** Access the icon cache if defined */\n  private readonly cache = injectNgIconLoaderCache();\n\n  /** Access the pre-processor */\n  private readonly preProcessor = injectNgIconPreProcessor();\n\n  /** Access the post-processor */\n  private readonly postProcessor = injectNgIconPostProcessor();\n\n  /** Access the injector */\n  private readonly injector = inject(Injector);\n\n  /** Access the element ref */\n  private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  /** Access the logger */\n  private readonly logger = injectLogger();\n\n  /** Define the name of the icon to display */\n  @Input() set name(name: IconType) {\n    this.setIcon(name);\n  }\n\n  /** Define the svg of the icon to display */\n  @Input() set svg(svg: string) {\n    this.setSvg(svg);\n  }\n\n  /** Define the size of the icon */\n  @Input({ transform: coerceCssPixelValue })\n  size?: string | number = this.config.size;\n\n  /** Define the stroke-width of the icon */\n  @Input()\n  strokeWidth?: string | number;\n\n  /** Define the color of the icon */\n  @Input()\n  color?: string = this.config.color;\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.size) {\n      this.setIconSize();\n    }\n    if (changes.color) {\n      this.setIconColor();\n    }\n    if (changes.strokeWidth) {\n      this.setIconStrokeWidth();\n    }\n  }\n\n  ngOnInit(): void {\n    this.setIconStyles();\n  }\n\n  private setIconColor(): void {\n    this.elementRef.nativeElement.style.removeProperty('color');\n\n    if (this.color !== undefined) {\n      this.elementRef.nativeElement.style.setProperty('color', this.color);\n    }\n  }\n\n  private setIconSize(): void {\n    this.elementRef.nativeElement.style.removeProperty('--ng-icon__size');\n\n    if (this.size !== undefined) {\n      this.elementRef.nativeElement.style.setProperty(\n        '--ng-icon__size',\n        this.size.toString(),\n      );\n    }\n  }\n\n  private setIconStrokeWidth(): void {\n    this.elementRef.nativeElement.style.removeProperty(\n      '--ng-icon__stroke-width',\n    );\n    if (this.strokeWidth !== undefined) {\n      this.elementRef.nativeElement.style.setProperty(\n        '--ng-icon__stroke-width',\n        this.strokeWidth.toString(),\n      );\n    }\n  }\n\n  /**\n   * Set the styles for the icon. We use the style property to set the styles\n   * rather than the host binding as it works with CSP.\n   */\n  private setIconStyles(): void {\n    this.setIconColor();\n    this.setIconSize();\n    this.setIconStrokeWidth();\n  }\n\n  private setSvg(svg: string): void {\n    this.elementRef.nativeElement.innerHTML = this.preProcessor(svg);\n    this.postProcessor(this.elementRef.nativeElement);\n  }\n\n  /**\n   * Load the icon with the given name and insert it into the template.\n   * @param name The name of the icon to load.\n   */\n  private async setIcon(name: IconType): Promise<void> {\n    const propertyName = toPropertyName(name);\n\n    for (const icons of [...this.icons].reverse()) {\n      if (icons[propertyName]) {\n        // insert the SVG into the template\n        this.setSvg(icons[propertyName]);\n        return;\n      }\n    }\n\n    // if there is a loader defined, use it to load the icon\n    if (this.loader) {\n      const result = await this.requestIconFromLoader(name);\n\n      // if the result is a string, insert the SVG into the template\n      if (result !== null) {\n        this.setSvg(result);\n        return;\n      }\n    }\n\n    // if there is no icon with this name warn the user as they probably forgot to import it\n    this.logger.warn(\n      `No icon named ${name} was found. You may need to import it using the withIcons function.`,\n    );\n  }\n\n  /**\n   * Request the icon from the loader.\n   * @param name The name of the icon to load.\n   * @returns The SVG content for a given icon name.\n   */\n  private requestIconFromLoader(name: string): Promise<string> {\n    return new Promise(resolve => {\n      runInInjectionContext(this.injector, async () => {\n        // if we have a cache, check if the icon is already loaded (i.e, it is a string)\n        if (this.cache) {\n          const cachedResult = this.cache.get(name);\n\n          if (typeof cachedResult === 'string') {\n            resolve(cachedResult);\n            return;\n          }\n\n          // it may be a promise, so we need to await it\n          if (cachedResult instanceof Promise) {\n            const result = await cachedResult;\n            resolve(result);\n            return;\n          }\n        }\n\n        const promise = coerceLoaderResult(this.loader!(name));\n\n        // store the promise in the cache so if we get repeated calls (e.g. in a loop) before the loader has resolved\n        // then don't call the loader function multiple times\n        this.cache?.set(name, promise);\n\n        // await the result of the promise\n        const result = await promise;\n\n        // if we have a cache, store the result\n        this.cache?.set(name, result);\n\n        resolve(result);\n      });\n    });\n  }\n}\n"]}
118
+ args: [{ selector: 'ng-icon', template: '', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, host: {
119
+ '[style.--ng-icon__stroke-width]': 'strokeWidth()',
120
+ '[style.--ng-icon__size]': 'size()',
121
+ '[style.color]': 'color()',
122
+ }, styles: [":host{display:inline-block;width:var(--ng-icon__size, 1em);height:var(--ng-icon__size, 1em);line-height:initial;vertical-align:initial;overflow:hidden}:host ::ng-deep svg{width:inherit;height:inherit;vertical-align:inherit}\n"] }]
123
+ }], ctorParameters: () => [] });
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/lib/components/icon/icon.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,MAAM,EACN,UAAU,EACV,MAAM,EACN,QAAQ,EACR,KAAK,EACL,qBAAqB,GACtB,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,yBAAyB,EACzB,wBAAwB,GACzB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EACL,kBAAkB,EAClB,uBAAuB,GACxB,MAAM,sCAAsC,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;;AAkBpD,MAAM,OAAO,MAAM;IA2CjB;QA1CA,oCAAoC;QACnB,WAAM,GAAG,kBAAkB,EAAE,CAAC;QAE/C,uBAAuB;QACN,UAAK,GAAG,aAAa,EAAE,CAAC;QAEzC,wCAAwC;QACvB,WAAM,GAAG,kBAAkB,EAAE,CAAC;QAE/C,uCAAuC;QACtB,UAAK,GAAG,uBAAuB,EAAE,CAAC;QAEnD,+BAA+B;QACd,iBAAY,GAAG,wBAAwB,EAAE,CAAC;QAE3D,gCAAgC;QACf,kBAAa,GAAG,yBAAyB,EAAE,CAAC;QAE7D,0BAA0B;QACT,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAE7C,6BAA6B;QACZ,eAAU,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;QAE1E,wBAAwB;QACP,WAAM,GAAG,YAAY,EAAE,CAAC;QAEzC,6CAA6C;QACpC,SAAI,GAAG,KAAK,EAAY,CAAC;QAElC,4CAA4C;QACnC,QAAG,GAAG,KAAK,EAAU,CAAC;QAE/B,kCAAkC;QACzB,SAAI,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,mBAAmB,EAAE,CAAC,CAAC;QAE5E,0CAA0C;QACjC,gBAAW,GAAG,KAAK,EAAmB,CAAC;QAEhD,mCAAmC;QAC1B,UAAK,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAGxC,kDAAkD;QAClD,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;IAClC,CAAC;IAEO,KAAK,CAAC,UAAU;QACtB,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QACzB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEvB,qDAAqD;QACrD,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;YACtB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACjB,OAAO;QACT,CAAC;QAED,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;YACvB,OAAO;QACT,CAAC;QAED,MAAM,YAAY,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;QAE1C,KAAK,MAAM,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC;YAC9C,IAAI,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC;gBACxB,mCAAmC;gBACnC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC;gBACjC,OAAO;YACT,CAAC;QACH,CAAC;QAED,wDAAwD;QACxD,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;YAEtD,8DAA8D;YAC9D,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;gBACpB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACpB,OAAO;YACT,CAAC;QACH,CAAC;QAED,wFAAwF;QACxF,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,iBAAiB,IAAI,qEAAqE,CAC3F,CAAC;IACJ,CAAC;IAEO,MAAM,CAAC,GAAW;QACxB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;QACjE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IACpD,CAAC;IAED;;;;OAIG;IACK,qBAAqB,CAAC,IAAY;QACxC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;YAC3B,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,IAAI,EAAE;gBAC9C,gFAAgF;gBAChF,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;oBACf,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBAE1C,IAAI,OAAO,YAAY,KAAK,QAAQ,EAAE,CAAC;wBACrC,OAAO,CAAC,YAAY,CAAC,CAAC;wBACtB,OAAO;oBACT,CAAC;oBAED,8CAA8C;oBAC9C,IAAI,YAAY,YAAY,OAAO,EAAE,CAAC;wBACpC,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC;wBAClC,OAAO,CAAC,MAAM,CAAC,CAAC;wBAChB,OAAO;oBACT,CAAC;gBACH,CAAC;gBAED,MAAM,OAAO,GAAG,kBAAkB,CAAC,IAAI,CAAC,MAAO,CAAC,IAAI,CAAC,CAAC,CAAC;gBAEvD,6GAA6G;gBAC7G,qDAAqD;gBACrD,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;gBAE/B,kCAAkC;gBAClC,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC;gBAE7B,uCAAuC;gBACvC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;gBAE9B,OAAO,CAAC,MAAM,CAAC,CAAC;YAClB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;8GAtIU,MAAM;kGAAN,MAAM,szBAVP,EAAE;;2FAUD,MAAM;kBAZlB,SAAS;+BACE,SAAS,YACT,EAAE,cACA,IAAI,mBAEC,uBAAuB,CAAC,MAAM,QACzC;wBACJ,iCAAiC,EAAE,eAAe;wBAClD,yBAAyB,EAAE,QAAQ;wBACnC,eAAe,EAAE,SAAS;qBAC3B","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  effect,\n  ElementRef,\n  inject,\n  Injector,\n  input,\n  runInInjectionContext,\n} from '@angular/core';\nimport type { IconName } from '../../components/icon/icon-name';\nimport {\n  injectNgIconPostProcessor,\n  injectNgIconPreProcessor,\n} from '../../providers/features/csp';\nimport { injectLogger } from '../../providers/features/logger';\nimport { injectNgIconConfig } from '../../providers/icon-config.provider';\nimport {\n  injectNgIconLoader,\n  injectNgIconLoaderCache,\n} from '../../providers/icon-loader.provider';\nimport { injectNgIcons } from '../../providers/icon.provider';\nimport { coerceLoaderResult } from '../../utils/async';\nimport { coerceCssPixelValue } from '../../utils/coercion';\nimport { toPropertyName } from '../../utils/format';\n\n// This is a typescript type to prevent inference from collapsing the union type to a string to improve type safety\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport type IconType = IconName | (string & {});\n\n@Component({\n  selector: 'ng-icon',\n  template: '',\n  standalone: true,\n  styleUrls: ['./icon.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[style.--ng-icon__stroke-width]': 'strokeWidth()',\n    '[style.--ng-icon__size]': 'size()',\n    '[style.color]': 'color()',\n  },\n})\nexport class NgIcon {\n  /** Access the global icon config */\n  private readonly config = injectNgIconConfig();\n\n  /** Access the icons */\n  private readonly icons = injectNgIcons();\n\n  /** Access the icon loader if defined */\n  private readonly loader = injectNgIconLoader();\n\n  /** Access the icon cache if defined */\n  private readonly cache = injectNgIconLoaderCache();\n\n  /** Access the pre-processor */\n  private readonly preProcessor = injectNgIconPreProcessor();\n\n  /** Access the post-processor */\n  private readonly postProcessor = injectNgIconPostProcessor();\n\n  /** Access the injector */\n  private readonly injector = inject(Injector);\n\n  /** Access the element ref */\n  private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  /** Access the logger */\n  private readonly logger = injectLogger();\n\n  /** Define the name of the icon to display */\n  readonly name = input<IconType>();\n\n  /** Define the svg of the icon to display */\n  readonly svg = input<string>();\n\n  /** Define the size of the icon */\n  readonly size = input(this.config.size, { transform: coerceCssPixelValue });\n\n  /** Define the stroke-width of the icon */\n  readonly strokeWidth = input<string | number>();\n\n  /** Define the color of the icon */\n  readonly color = input(this.config.color);\n\n  constructor() {\n    // update the icon anytime the name or svg changes\n    effect(() => this.updateIcon());\n  }\n\n  private async updateIcon(): Promise<void> {\n    const name = this.name();\n    const svg = this.svg();\n\n    // if the svg is defined, insert it into the template\n    if (svg !== undefined) {\n      this.setSvg(svg);\n      return;\n    }\n\n    if (name === undefined) {\n      return;\n    }\n\n    const propertyName = toPropertyName(name);\n\n    for (const icons of [...this.icons].reverse()) {\n      if (icons[propertyName]) {\n        // insert the SVG into the template\n        this.setSvg(icons[propertyName]);\n        return;\n      }\n    }\n\n    // if there is a loader defined, use it to load the icon\n    if (this.loader) {\n      const result = await this.requestIconFromLoader(name);\n\n      // if the result is a string, insert the SVG into the template\n      if (result !== null) {\n        this.setSvg(result);\n        return;\n      }\n    }\n\n    // if there is no icon with this name warn the user as they probably forgot to import it\n    this.logger.warn(\n      `No icon named ${name} was found. You may need to import it using the withIcons function.`,\n    );\n  }\n\n  private setSvg(svg: string): void {\n    this.elementRef.nativeElement.innerHTML = this.preProcessor(svg);\n    this.postProcessor(this.elementRef.nativeElement);\n  }\n\n  /**\n   * Request the icon from the loader.\n   * @param name The name of the icon to load.\n   * @returns The SVG content for a given icon name.\n   */\n  private requestIconFromLoader(name: string): Promise<string> {\n    return new Promise(resolve => {\n      runInInjectionContext(this.injector, async () => {\n        // if we have a cache, check if the icon is already loaded (i.e, it is a string)\n        if (this.cache) {\n          const cachedResult = this.cache.get(name);\n\n          if (typeof cachedResult === 'string') {\n            resolve(cachedResult);\n            return;\n          }\n\n          // it may be a promise, so we need to await it\n          if (cachedResult instanceof Promise) {\n            const result = await cachedResult;\n            resolve(result);\n            return;\n          }\n        }\n\n        const promise = coerceLoaderResult(this.loader!(name));\n\n        // store the promise in the cache so if we get repeated calls (e.g. in a loop) before the loader has resolved\n        // then don't call the loader function multiple times\n        this.cache?.set(name, promise);\n\n        // await the result of the promise\n        const result = await promise;\n\n        // if we have a cache, store the result\n        this.cache?.set(name, result);\n\n        resolve(result);\n      });\n    });\n  }\n}\n"]}
@@ -16,11 +16,11 @@ export class NgIconsModule {
16
16
  static withIcons(icons) {
17
17
  return { ngModule: NgIconsModule, providers: provideIcons(icons) };
18
18
  }
19
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgIconsModule, deps: [{ token: NgIconsToken }], target: i0.ɵɵFactoryTarget.NgModule }); }
20
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0", ngImport: i0, type: NgIconsModule, imports: [NgIcon], exports: [NgIcon] }); }
21
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgIconsModule }); }
19
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgIconsModule, deps: [{ token: NgIconsToken }], target: i0.ɵɵFactoryTarget.NgModule }); }
20
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.0", ngImport: i0, type: NgIconsModule, imports: [NgIcon], exports: [NgIcon] }); }
21
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgIconsModule }); }
22
22
  }
23
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: NgIconsModule, decorators: [{
23
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgIconsModule, decorators: [{
24
24
  type: NgModule,
25
25
  args: [{
26
26
  imports: [NgIcon],
@@ -1,4 +1,4 @@
1
- import { InjectionToken, Optional, SkipSelf, inject, } from '@angular/core';
1
+ import { InjectionToken, inject } from '@angular/core';
2
2
  /**
3
3
  * Define the icons to use
4
4
  * @param icons The icons to provide
@@ -7,11 +7,13 @@ export function provideIcons(icons) {
7
7
  return [
8
8
  {
9
9
  provide: NgIconsToken,
10
- useFactory: (parentIcons) => ({
10
+ useFactory: (parentIcons = inject(NgIconsToken, {
11
+ optional: true,
12
+ skipSelf: true,
13
+ })) => ({
11
14
  ...parentIcons?.reduce((acc, icons) => ({ ...acc, ...icons }), {}),
12
15
  ...icons,
13
16
  }),
14
- deps: [[NgIconsToken, new Optional(), new SkipSelf()]],
15
17
  multi: true,
16
18
  },
17
19
  ];
@@ -25,4 +27,4 @@ export const NgIconsToken = new InjectionToken('Icons Token');
25
27
  export function injectNgIcons() {
26
28
  return inject(NgIconsToken, { optional: true }) ?? [];
27
29
  }
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5wcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL2xpYi9wcm92aWRlcnMvaWNvbi5wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsY0FBYyxFQUNkLFFBQVEsRUFFUixRQUFRLEVBQ1IsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBRXZCOzs7R0FHRztBQUNILE1BQU0sVUFBVSxZQUFZLENBQUMsS0FBNkI7SUFDeEQsT0FBTztRQUNMO1lBQ0UsT0FBTyxFQUFFLFlBQVk7WUFDckIsVUFBVSxFQUFFLENBQUMsV0FBc0MsRUFBRSxFQUFFLENBQUMsQ0FBQztnQkFDdkQsR0FBRyxXQUFXLEVBQUUsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsR0FBRyxFQUFFLEdBQUcsS0FBSyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7Z0JBQ2xFLEdBQUcsS0FBSzthQUNULENBQUM7WUFDRixJQUFJLEVBQUUsQ0FBQyxDQUFDLFlBQVksRUFBRSxJQUFJLFFBQVEsRUFBRSxFQUFFLElBQUksUUFBUSxFQUFFLENBQUMsQ0FBQztZQUN0RCxLQUFLLEVBQUUsSUFBSTtTQUNaO0tBQ0YsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsSUFBSSxjQUFjLENBQzVDLGFBQWEsQ0FDZCxDQUFDO0FBRUY7Ozs7R0FJRztBQUNILE1BQU0sVUFBVSxhQUFhO0lBQzNCLE9BQU8sTUFBTSxDQUFDLFlBQVksRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztBQUN4RCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgSW5qZWN0aW9uVG9rZW4sXG4gIE9wdGlvbmFsLFxuICBQcm92aWRlcixcbiAgU2tpcFNlbGYsXG4gIGluamVjdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogRGVmaW5lIHRoZSBpY29ucyB0byB1c2VcbiAqIEBwYXJhbSBpY29ucyBUaGUgaWNvbnMgdG8gcHJvdmlkZVxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZUljb25zKGljb25zOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTogUHJvdmlkZXJbXSB7XG4gIHJldHVybiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTmdJY29uc1Rva2VuLFxuICAgICAgdXNlRmFjdG9yeTogKHBhcmVudEljb25zPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPltdKSA9PiAoe1xuICAgICAgICAuLi5wYXJlbnRJY29ucz8ucmVkdWNlKChhY2MsIGljb25zKSA9PiAoeyAuLi5hY2MsIC4uLmljb25zIH0pLCB7fSksXG4gICAgICAgIC4uLmljb25zLFxuICAgICAgfSksXG4gICAgICBkZXBzOiBbW05nSWNvbnNUb2tlbiwgbmV3IE9wdGlvbmFsKCksIG5ldyBTa2lwU2VsZigpXV0sXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdO1xufVxuXG5leHBvcnQgY29uc3QgTmdJY29uc1Rva2VuID0gbmV3IEluamVjdGlvblRva2VuPFJlY29yZDxzdHJpbmcsIHN0cmluZz5bXT4oXG4gICdJY29ucyBUb2tlbicsXG4pO1xuXG4vKipcbiAqIEluamVjdCB0aGUgaWNvbnMgdG8gdXNlXG4gKiBAcmV0dXJucyBUaGUgaWNvbnMgdG8gdXNlXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGluamVjdE5nSWNvbnMoKTogUmVjb3JkPHN0cmluZywgc3RyaW5nPltdIHtcbiAgcmV0dXJuIGluamVjdChOZ0ljb25zVG9rZW4sIHsgb3B0aW9uYWw6IHRydWUgfSkgPz8gW107XG59XG4iXX0=
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5wcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvc3JjL2xpYi9wcm92aWRlcnMvaWNvbi5wcm92aWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFZLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRTs7O0dBR0c7QUFDSCxNQUFNLFVBQVUsWUFBWSxDQUFDLEtBQTZCO0lBQ3hELE9BQU87UUFDTDtZQUNFLE9BQU8sRUFBRSxZQUFZO1lBQ3JCLFVBQVUsRUFBRSxDQUNWLGNBQWMsTUFBTSxDQUEyQixZQUFZLEVBQUU7Z0JBQzNELFFBQVEsRUFBRSxJQUFJO2dCQUNkLFFBQVEsRUFBRSxJQUFJO2FBQ2YsQ0FBQyxFQUNGLEVBQUUsQ0FBQyxDQUFDO2dCQUNKLEdBQUcsV0FBVyxFQUFFLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLEdBQUcsRUFBRSxHQUFHLEtBQUssRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO2dCQUNsRSxHQUFHLEtBQUs7YUFDVCxDQUFDO1lBQ0YsS0FBSyxFQUFFLElBQUk7U0FDWjtLQUNGLENBQUM7QUFDSixDQUFDO0FBRUQsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLElBQUksY0FBYyxDQUM1QyxhQUFhLENBQ2QsQ0FBQztBQUVGOzs7O0dBSUc7QUFDSCxNQUFNLFVBQVUsYUFBYTtJQUMzQixPQUFPLE1BQU0sQ0FBQyxZQUFZLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsSUFBSSxFQUFFLENBQUM7QUFDeEQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuLCBQcm92aWRlciwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogRGVmaW5lIHRoZSBpY29ucyB0byB1c2VcbiAqIEBwYXJhbSBpY29ucyBUaGUgaWNvbnMgdG8gcHJvdmlkZVxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZUljb25zKGljb25zOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTogUHJvdmlkZXJbXSB7XG4gIHJldHVybiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTmdJY29uc1Rva2VuLFxuICAgICAgdXNlRmFjdG9yeTogKFxuICAgICAgICBwYXJlbnRJY29ucyA9IGluamVjdDxSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+W10+KE5nSWNvbnNUb2tlbiwge1xuICAgICAgICAgIG9wdGlvbmFsOiB0cnVlLFxuICAgICAgICAgIHNraXBTZWxmOiB0cnVlLFxuICAgICAgICB9KSxcbiAgICAgICkgPT4gKHtcbiAgICAgICAgLi4ucGFyZW50SWNvbnM/LnJlZHVjZSgoYWNjLCBpY29ucykgPT4gKHsgLi4uYWNjLCAuLi5pY29ucyB9KSwge30pLFxuICAgICAgICAuLi5pY29ucyxcbiAgICAgIH0pLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgfSxcbiAgXTtcbn1cblxuZXhwb3J0IGNvbnN0IE5nSWNvbnNUb2tlbiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+W10+KFxuICAnSWNvbnMgVG9rZW4nLFxuKTtcblxuLyoqXG4gKiBJbmplY3QgdGhlIGljb25zIHRvIHVzZVxuICogQHJldHVybnMgVGhlIGljb25zIHRvIHVzZVxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpbmplY3ROZ0ljb25zKCk6IFJlY29yZDxzdHJpbmcsIHN0cmluZz5bXSB7XG4gIHJldHVybiBpbmplY3QoTmdJY29uc1Rva2VuLCB7IG9wdGlvbmFsOiB0cnVlIH0pID8/IFtdO1xufVxuIl19
@@ -1,4 +1,4 @@
1
- import { firstValueFrom, isObservable } from 'rxjs';
1
+ import { isObservable } from 'rxjs';
2
2
  /**
3
3
  * A loader may return a promise, an observable or a string. This function will coerce the result into a promise.
4
4
  * @returns
@@ -8,8 +8,10 @@ export function coerceLoaderResult(result) {
8
8
  return Promise.resolve(result);
9
9
  }
10
10
  if (isObservable(result)) {
11
- return firstValueFrom(result);
11
+ // toPromise is deprecated, but we can't use lastValueFrom because it's not available in RxJS 6
12
+ // so for now we'll just use toPromise
13
+ return result.toPromise();
12
14
  }
13
15
  return result;
14
16
  }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXN5bmMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9saWIvdXRpbHMvYXN5bmMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFjLGNBQWMsRUFBRSxZQUFZLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFaEU7OztHQUdHO0FBQ0gsTUFBTSxVQUFVLGtCQUFrQixDQUNoQyxNQUFxRDtJQUVyRCxJQUFJLE9BQU8sTUFBTSxLQUFLLFFBQVEsRUFBRSxDQUFDO1FBQy9CLE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsSUFBSSxZQUFZLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztRQUN6QixPQUFPLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBRUQsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9ic2VydmFibGUsIGZpcnN0VmFsdWVGcm9tLCBpc09ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuLyoqXG4gKiBBIGxvYWRlciBtYXkgcmV0dXJuIGEgcHJvbWlzZSwgYW4gb2JzZXJ2YWJsZSBvciBhIHN0cmluZy4gVGhpcyBmdW5jdGlvbiB3aWxsIGNvZXJjZSB0aGUgcmVzdWx0IGludG8gYSBwcm9taXNlLlxuICogQHJldHVybnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvZXJjZUxvYWRlclJlc3VsdChcbiAgcmVzdWx0OiBQcm9taXNlPHN0cmluZz4gfCBPYnNlcnZhYmxlPHN0cmluZz4gfCBzdHJpbmcsXG4pOiBQcm9taXNlPHN0cmluZz4ge1xuICBpZiAodHlwZW9mIHJlc3VsdCA9PT0gJ3N0cmluZycpIHtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHJlc3VsdCk7XG4gIH1cblxuICBpZiAoaXNPYnNlcnZhYmxlKHJlc3VsdCkpIHtcbiAgICByZXR1cm4gZmlyc3RWYWx1ZUZyb20ocmVzdWx0KTtcbiAgfVxuXG4gIHJldHVybiByZXN1bHQ7XG59XG4iXX0=
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXN5bmMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9saWIvdXRpbHMvYXN5bmMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFjLFlBQVksRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUVoRDs7O0dBR0c7QUFDSCxNQUFNLFVBQVUsa0JBQWtCLENBQ2hDLE1BQXFEO0lBRXJELElBQUksT0FBTyxNQUFNLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDL0IsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFFRCxJQUFJLFlBQVksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQ3pCLCtGQUErRjtRQUMvRixzQ0FBc0M7UUFDdEMsT0FBTyxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDNUIsQ0FBQztJQUVELE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPYnNlcnZhYmxlLCBpc09ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuLyoqXG4gKiBBIGxvYWRlciBtYXkgcmV0dXJuIGEgcHJvbWlzZSwgYW4gb2JzZXJ2YWJsZSBvciBhIHN0cmluZy4gVGhpcyBmdW5jdGlvbiB3aWxsIGNvZXJjZSB0aGUgcmVzdWx0IGludG8gYSBwcm9taXNlLlxuICogQHJldHVybnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvZXJjZUxvYWRlclJlc3VsdChcbiAgcmVzdWx0OiBQcm9taXNlPHN0cmluZz4gfCBPYnNlcnZhYmxlPHN0cmluZz4gfCBzdHJpbmcsXG4pOiBQcm9taXNlPHN0cmluZz4ge1xuICBpZiAodHlwZW9mIHJlc3VsdCA9PT0gJ3N0cmluZycpIHtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHJlc3VsdCk7XG4gIH1cblxuICBpZiAoaXNPYnNlcnZhYmxlKHJlc3VsdCkpIHtcbiAgICAvLyB0b1Byb21pc2UgaXMgZGVwcmVjYXRlZCwgYnV0IHdlIGNhbid0IHVzZSBsYXN0VmFsdWVGcm9tIGJlY2F1c2UgaXQncyBub3QgYXZhaWxhYmxlIGluIFJ4SlMgNlxuICAgIC8vIHNvIGZvciBub3cgd2UnbGwganVzdCB1c2UgdG9Qcm9taXNlXG4gICAgcmV0dXJuIHJlc3VsdC50b1Byb21pc2UoKTtcbiAgfVxuXG4gIHJldHVybiByZXN1bHQ7XG59XG4iXX0=