@ng-icons/core 26.2.1 → 26.3.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.
- package/README.md +67 -0
- package/esm2022/index.mjs +7 -4
- package/esm2022/lib/components/glyph/glyph.component.mjs +105 -0
- package/esm2022/lib/components/icon/icon-name.mjs +2 -0
- package/esm2022/lib/components/icon/icon.component.mjs +116 -0
- package/esm2022/lib/icon.module.mjs +2 -2
- package/esm2022/lib/providers/glyph-config.provider.mjs +30 -0
- package/esm2022/lib/providers/glyph.provider.mjs +21 -0
- package/esm2022/lib/utils/coercion.mjs +4 -0
- package/fesm2022/ng-icons-core.mjs +157 -7
- package/fesm2022/ng-icons-core.mjs.map +1 -1
- package/index.d.ts +6 -3
- package/lib/components/glyph/glyph.component.d.ts +58 -0
- package/lib/{icon.component.d.ts → components/icon/icon.component.d.ts} +1 -1
- package/lib/icon.module.d.ts +2 -2
- package/lib/providers/glyph-config.provider.d.ts +27 -0
- package/lib/providers/glyph.provider.d.ts +12 -0
- package/lib/utils/coercion.d.ts +1 -0
- package/package.json +1 -1
- package/esm2022/lib/icon-name.mjs +0 -2
- package/esm2022/lib/icon.component.mjs +0 -118
- /package/lib/{icon-name.d.ts → components/icon/icon-name.d.ts} +0 -0
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ElementRef, HostBinding, inject, Injector, Input, runInInjectionContext, } from '@angular/core';
|
|
2
|
-
import { injectNgIconConfig } from './providers/icon-config.provider';
|
|
3
|
-
import { injectNgIconLoader, injectNgIconLoaderCache, } from './providers/icon-loader.provider';
|
|
4
|
-
import { injectNgIcons } from './providers/icon.provider';
|
|
5
|
-
import { coerceLoaderResult } from './utils/async';
|
|
6
|
-
import { toPropertyName } from './utils/format';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export class NgIcon {
|
|
9
|
-
constructor() {
|
|
10
|
-
/** Access the global icon config */
|
|
11
|
-
this.config = injectNgIconConfig();
|
|
12
|
-
/** Access the icons */
|
|
13
|
-
this.icons = injectNgIcons();
|
|
14
|
-
/** Access the icon loader if defined */
|
|
15
|
-
this.loader = injectNgIconLoader();
|
|
16
|
-
/** Access the icon cache if defined */
|
|
17
|
-
this.cache = injectNgIconLoaderCache();
|
|
18
|
-
/** Access the injector */
|
|
19
|
-
this.injector = inject(Injector);
|
|
20
|
-
/** Access the element ref */
|
|
21
|
-
this.elementRef = inject(ElementRef);
|
|
22
|
-
/** Define the size of the icon */
|
|
23
|
-
this.size = this.config.size;
|
|
24
|
-
/** Define the color of the icon */
|
|
25
|
-
this.color = this.config.color;
|
|
26
|
-
}
|
|
27
|
-
/** Define the name of the icon to display */
|
|
28
|
-
set name(name) {
|
|
29
|
-
this.setIcon(name);
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* Load the icon with the given name and insert it into the template.
|
|
33
|
-
* @param name The name of the icon to load.
|
|
34
|
-
*/
|
|
35
|
-
async setIcon(name) {
|
|
36
|
-
const propertyName = toPropertyName(name);
|
|
37
|
-
for (const icons of [...this.icons].reverse()) {
|
|
38
|
-
if (icons[propertyName]) {
|
|
39
|
-
// insert the SVG into the template
|
|
40
|
-
this.elementRef.nativeElement.innerHTML = icons[propertyName];
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
// if there is a loader defined, use it to load the icon
|
|
45
|
-
if (this.loader) {
|
|
46
|
-
const result = await this.requestIconFromLoader(name);
|
|
47
|
-
// if the result is a string, insert the SVG into the template
|
|
48
|
-
if (result !== null) {
|
|
49
|
-
this.elementRef.nativeElement.innerHTML = result;
|
|
50
|
-
return;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
// if there is no icon with this name warn the user as they probably forgot to import it
|
|
54
|
-
console.warn(`No icon named ${name} was found. You may need to import it using the withIcons function.`);
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Request the icon from the loader.
|
|
58
|
-
* @param name The name of the icon to load.
|
|
59
|
-
* @returns The SVG content for a given icon name.
|
|
60
|
-
*/
|
|
61
|
-
requestIconFromLoader(name) {
|
|
62
|
-
return new Promise(resolve => {
|
|
63
|
-
runInInjectionContext(this.injector, async () => {
|
|
64
|
-
// if we have a cache, check if the icon is already loaded (i.e, it is a string)
|
|
65
|
-
if (this.cache) {
|
|
66
|
-
const cachedResult = this.cache.get(name);
|
|
67
|
-
if (typeof cachedResult === 'string') {
|
|
68
|
-
resolve(cachedResult);
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
// it may be a promise, so we need to await it
|
|
72
|
-
if (cachedResult instanceof Promise) {
|
|
73
|
-
const result = await cachedResult;
|
|
74
|
-
resolve(result);
|
|
75
|
-
return;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
const promise = coerceLoaderResult(this.loader(name));
|
|
79
|
-
// store the promise in the cache so if we get repeated calls (e.g. in a loop) before the loader has resolved
|
|
80
|
-
// then don't call the loader function multiple times
|
|
81
|
-
this.cache?.set(name, promise);
|
|
82
|
-
// await the result of the promise
|
|
83
|
-
const result = await promise;
|
|
84
|
-
// if we have a cache, store the result
|
|
85
|
-
this.cache?.set(name, result);
|
|
86
|
-
resolve(result);
|
|
87
|
-
});
|
|
88
|
-
});
|
|
89
|
-
}
|
|
90
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: NgIcon, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
91
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.0.1", type: NgIcon, isStandalone: true, selector: "ng-icon", inputs: { name: "name", size: ["size", "size", coerceCssPixelValue], strokeWidth: "strokeWidth", color: "color" }, host: { properties: { "style.--ng-icon__size": "this.size", "style.--ng-icon__stroke-width": "this.strokeWidth", "style.color": "this.color" } }, ngImport: i0, template: '', isInline: true, styles: [":host{display:inline-block;width:var(--ng-icon__size);height:var(--ng-icon__size)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
92
|
-
}
|
|
93
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: NgIcon, decorators: [{
|
|
94
|
-
type: Component,
|
|
95
|
-
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)}\n"] }]
|
|
96
|
-
}], propDecorators: { name: [{
|
|
97
|
-
type: Input
|
|
98
|
-
}], size: [{
|
|
99
|
-
type: HostBinding,
|
|
100
|
-
args: ['style.--ng-icon__size']
|
|
101
|
-
}, {
|
|
102
|
-
type: Input,
|
|
103
|
-
args: [{ transform: coerceCssPixelValue }]
|
|
104
|
-
}], strokeWidth: [{
|
|
105
|
-
type: HostBinding,
|
|
106
|
-
args: ['style.--ng-icon__stroke-width']
|
|
107
|
-
}, {
|
|
108
|
-
type: Input
|
|
109
|
-
}], color: [{
|
|
110
|
-
type: HostBinding,
|
|
111
|
-
args: ['style.color']
|
|
112
|
-
}, {
|
|
113
|
-
type: Input
|
|
114
|
-
}] } });
|
|
115
|
-
function coerceCssPixelValue(value) {
|
|
116
|
-
return value == null ? '' : /^\d+$/.test(value) ? `${value}px` : value;
|
|
117
|
-
}
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../packages/core/src/lib/icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  HostBinding,\n  inject,\n  Injector,\n  Input,\n  runInInjectionContext,\n} from '@angular/core';\nimport type { IconName } from './icon-name';\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 { 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})\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 injector */\n  private readonly injector = inject(Injector);\n\n  /** Access the element ref */\n  private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\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 size of the icon */\n  @HostBinding('style.--ng-icon__size')\n  @Input({ transform: coerceCssPixelValue })\n  size?: string | number = this.config.size;\n\n  /** Define the stroke-width of the icon */\n  @HostBinding('style.--ng-icon__stroke-width')\n  @Input()\n  strokeWidth?: string | number;\n\n  /** Define the color of the icon */\n  @HostBinding('style.color')\n  @Input()\n  color?: string = this.config.color;\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.elementRef.nativeElement.innerHTML = 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.elementRef.nativeElement.innerHTML = 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    console.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\nfunction coerceCssPixelValue(value: string): string {\n  return value == null ? '' : /^\\d+$/.test(value) ? `${value}px` : value;\n}\n"]}
|
|
File without changes
|