UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

274 lines 23.8 kB
import { __decorate, __metadata } from "tslib"; import { Component, ElementRef, HostBinding, Input, OnInit, TemplateRef, ViewChild } from '@angular/core'; import { IgxIconService } from './icon.service'; /** * **Ignite UI for Angular Icon** - * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/icon.html) * * The Ignite UI Icon makes it easy for developers to include material design icons directly in their markup. The icons * support custom colors and can be marked as active or disabled using the `isActive` property. This will change the appearance * of the icon. * * Example: * ```html * <igx-icon color="#00ff00" isActive="true">home</igx-icon> * ``` */ var NEXT_ID = 0; var IgxIconComponent = /** @class */ (function () { function IgxIconComponent(_el, iconService) { this._el = _el; this.iconService = iconService; /** * This allows you to change the value of `class.igx-icon`. By default it's `igx-icon`. *```typescript *@ViewChild("MyIcon") public icon: IgxIconComponent; *constructor(private cdRef:ChangeDetectorRef) {} *ngAfterViewInit() { * this.icon.cssClass = ""; * this.cdRef.detectChanges(); *} * ``` */ this.cssClass = 'igx-icon'; /** * This allows you to disable the `aria-hidden` attribute. By default it's applied. *```typescript *@ViewChild("MyIcon") public icon: IgxIconComponent; *constructor(private cdRef:ChangeDetectorRef) {} *ngAfterViewInit() { * this.icon.ariaHidden = false; * this.cdRef.detectChanges(); *} * ``` */ this.ariaHidden = true; /** * An @Input property that sets the value of the `id` attribute. *```html *<igx-icon id="igx-icon-1" fontSet="material" color="blue" [isActive]="false">settings</igx-icon> *``` */ this.id = "igx-icon-" + NEXT_ID++; /** * An @Input property that allows you to disable the `active` property. By default it's applied. *```html *<igx-icon [isActive]="false" fontSet="material" color="blue">settings</igx-icon> *``` */ this.active = true; this.el = _el; this.font = this.iconService.defaultFontSet; this.iconService.registerFontSetAlias('material', 'material-icons'); } /** * @hidden */ IgxIconComponent.prototype.ngOnInit = function () { this.updateIconClass(); }; Object.defineProperty(IgxIconComponent.prototype, "getFontSet", { /** * An accessor that returns the value of the font property. *```typescript *@ViewChild("MyIcon") *public icon: IgxIconComponent; *ngAfterViewInit() { * let iconFont = this.icon.getFontSet; * } * ``` */ get: function () { return this.font; }, enumerable: true, configurable: true }); Object.defineProperty(IgxIconComponent.prototype, "getActive", { /** * An accessor that returns the value of the active property. *```typescript *@ViewChild("MyIcon") *public icon: IgxIconComponent; *ngAfterViewInit() { * let iconActive = this.icon.getActive; * } * ``` */ get: function () { return this.active; }, enumerable: true, configurable: true }); Object.defineProperty(IgxIconComponent.prototype, "getInactive", { /** * An accessor that returns inactive property. *```typescript *@ViewChild("MyIcon") *public icon: IgxIconComponent; *ngAfterViewInit() { * let iconActive = this.icon.getInactive; * } * ``` */ get: function () { return !this.active; }, enumerable: true, configurable: true }); Object.defineProperty(IgxIconComponent.prototype, "getIconColor", { /** * An accessor that returns the opposite value of the `iconColor` property. *```typescript *@ViewChild("MyIcon") *public icon: IgxIconComponent; *ngAfterViewInit() { * let iconColor = this.icon.getIconColor; * } * ``` */ get: function () { return this.iconColor; }, enumerable: true, configurable: true }); Object.defineProperty(IgxIconComponent.prototype, "getIconName", { /** * An accessor that returns the value of the iconName property. *```typescript *@ViewChild("MyIcon") *public icon: IgxIconComponent; *ngAfterViewInit() { * let iconName = this.icon.getIconName; * } * ``` */ get: function () { return this.iconName; }, enumerable: true, configurable: true }); Object.defineProperty(IgxIconComponent.prototype, "getSvgKey", { /** * An accessor that returns the key of the SVG image. * The key consists of the fontSet and the iconName separated by underscore. *```typescript *@ViewChild("MyIcon") *public icon: IgxIconComponent; *ngAfterViewInit() { * let svgKey = this.icon.getSvgKey; * } * ``` */ get: function () { if (this.iconService.isSvgIconCached(this.iconName, this.font)) { return '#' + this.iconService.getSvgIconKey(this.iconName, this.font); } return null; }, enumerable: true, configurable: true }); Object.defineProperty(IgxIconComponent.prototype, "template", { /** * An accessor that returns a TemplateRef to explicit, svg or no ligature. *```typescript *@ViewChild("MyIcon") *public icon: IgxIconComponent; *ngAfterViewInit() { * let iconTemplate = this.icon.template; * } * ``` */ get: function () { if (this.iconName) { if (this.iconService.isSvgIconCached(this.iconName, this.font)) { return this.svgImage; } return this.noLigature; } return this.explicitLigature; }, enumerable: true, configurable: true }); /** * @hidden */ IgxIconComponent.prototype.updateIconClass = function () { var className = this.iconService.fontSetClassName(this.font); this.el.nativeElement.classList.add(className); if (this.iconName && !this.iconService.isSvgIconCached(this.iconName, this.font)) { this.el.nativeElement.classList.add(this.iconName); } }; IgxIconComponent.ctorParameters = function () { return [ { type: ElementRef }, { type: IgxIconService } ]; }; __decorate([ ViewChild('noLigature', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxIconComponent.prototype, "noLigature", void 0); __decorate([ ViewChild('explicitLigature', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxIconComponent.prototype, "explicitLigature", void 0); __decorate([ ViewChild('svgImage', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxIconComponent.prototype, "svgImage", void 0); __decorate([ HostBinding('class.igx-icon'), __metadata("design:type", Object) ], IgxIconComponent.prototype, "cssClass", void 0); __decorate([ HostBinding('attr.aria-hidden'), __metadata("design:type", Object) ], IgxIconComponent.prototype, "ariaHidden", void 0); __decorate([ HostBinding('attr.id'), Input(), __metadata("design:type", Object) ], IgxIconComponent.prototype, "id", void 0); __decorate([ Input('fontSet'), __metadata("design:type", String) ], IgxIconComponent.prototype, "font", void 0); __decorate([ Input('isActive'), __metadata("design:type", Object) ], IgxIconComponent.prototype, "active", void 0); __decorate([ Input('color'), __metadata("design:type", String) ], IgxIconComponent.prototype, "iconColor", void 0); __decorate([ Input('name'), __metadata("design:type", String) ], IgxIconComponent.prototype, "iconName", void 0); __decorate([ HostBinding('class.igx-icon--inactive'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxIconComponent.prototype, "getInactive", null); __decorate([ HostBinding('style.color'), __metadata("design:type", String), __metadata("design:paramtypes", []) ], IgxIconComponent.prototype, "getIconColor", null); IgxIconComponent = __decorate([ Component({ selector: 'igx-icon', template: "<ng-template #noLigature></ng-template>\n\n<ng-template #explicitLigature>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #svgImage>\n <svg>\n <use [attr.href]=\"getSvgKey\"></use>\n </svg>\n</ng-template>\n\n<ng-container *ngTemplateOutlet=\"template\"></ng-container>\n" }), __metadata("design:paramtypes", [ElementRef, IgxIconService]) ], IgxIconComponent); return IgxIconComponent; }()); export { IgxIconComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/icon/icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, Input, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { IgxIconService } from './icon.service';\n\n/**\n * **Ignite UI for Angular Icon** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/icon.html)\n *\n * The Ignite UI Icon makes it easy for developers to include material design icons directly in their markup. The icons\n * support custom colors and can be marked as active or disabled using the `isActive` property. This will change the appearance\n * of the icon.\n *\n * Example:\n * ```html\n * <igx-icon color=\"#00ff00\" isActive=\"true\">home</igx-icon>\n * ```\n */\nlet NEXT_ID = 0;\n\n@Component({\n    selector: 'igx-icon',\n    templateUrl: 'icon.component.html'\n})\n\nexport class IgxIconComponent implements OnInit {\n    @ViewChild('noLigature', { read: TemplateRef, static: true })\n    private noLigature: TemplateRef<HTMLElement>;\n\n    @ViewChild('explicitLigature', { read: TemplateRef, static: true })\n    private explicitLigature: TemplateRef<HTMLElement>;\n\n    @ViewChild('svgImage', { read: TemplateRef, static: true })\n    private svgImage: TemplateRef<HTMLElement>;\n\n    /**\n     *  This allows you to change the value of `class.igx-icon`. By default it's `igx-icon`.\n     *```typescript\n     *@ViewChild(\"MyIcon\") public icon: IgxIconComponent;\n     *constructor(private cdRef:ChangeDetectorRef) {}\n     *ngAfterViewInit() {\n     *    this.icon.cssClass = \"\";\n     *    this.cdRef.detectChanges();\n     *}\n     * ```\n     */\n    @HostBinding('class.igx-icon')\n    public cssClass = 'igx-icon';\n\n    /**\n     *  This allows you to disable the `aria-hidden` attribute. By default it's applied.\n     *```typescript\n     *@ViewChild(\"MyIcon\") public icon: IgxIconComponent;\n     *constructor(private cdRef:ChangeDetectorRef) {}\n     *ngAfterViewInit() {\n     *    this.icon.ariaHidden = false;\n     *    this.cdRef.detectChanges();\n     *}\n     * ```\n     */\n    @HostBinding('attr.aria-hidden')\n    public ariaHidden = true;\n\n    /**\n    *  An @Input property that sets the value of the `id` attribute.\n    *```html\n    *<igx-icon id=\"igx-icon-1\" fontSet=\"material\" color=\"blue\" [isActive]=\"false\">settings</igx-icon>\n    *```\n    */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-icon-${NEXT_ID++}`;\n\n    /**\n    *  An @Input property that sets the value of the `fontSet`. By default it's \"material\".\n    *```html\n    *<igx-icon fontSet=\"material\" color=\"blue\" [isActive]=\"false\">settings</igx-icon>\n    *```\n    */\n    @Input('fontSet')\n    public font: string;\n\n    /**\n    *  An @Input property that allows you to disable the `active` property. By default it's applied.\n    *```html\n    *<igx-icon [isActive]=\"false\" fontSet=\"material\" color=\"blue\">settings</igx-icon>\n    *```\n    */\n    @Input('isActive')\n    public active = true;\n\n    /**\n    *  An @Input property that allows you to change the `iconColor` of the icon.\n    *```html\n    *<igx-icon color=\"blue\" [isActive]=\"true\" fontSet=\"material\">settings</igx-icon>\n    *```\n    */\n    @Input('color')\n    public iconColor: string;\n\n    /**\n    *  An @Input property that allows you to set the `iconName` of the icon.\n    *  The `iconName` can be set using the `name` property.\n    *```html\n    *<igx-icon color=\"blue\" [isActive]=\"true\" fontSet=\"material\">question_answer</igx-icon>\n    *```\n    */\n    @Input('name')\n    public iconName: string;\n\n    /**\n     * An ElementRef property of the `igx-icon` component.\n     */\n    public el: ElementRef;\n\n    constructor(private _el: ElementRef, private iconService: IgxIconService) {\n        this.el = _el;\n        this.font = this.iconService.defaultFontSet;\n        this.iconService.registerFontSetAlias('material', 'material-icons');\n    }\n\n    /**\n     * @hidden\n     */\n    ngOnInit() {\n        this.updateIconClass();\n    }\n\n    /**\n     *  An accessor that returns the value of the font property.\n     *```typescript\n     *@ViewChild(\"MyIcon\")\n     *public icon: IgxIconComponent;\n     *ngAfterViewInit() {\n     *    let iconFont = this.icon.getFontSet;\n     * }\n     * ```\n     */\n    get getFontSet(): string {\n        return this.font;\n    }\n\n    /**\n     *  An accessor that returns the value of the active property.\n     *```typescript\n     *@ViewChild(\"MyIcon\")\n     *public icon: IgxIconComponent;\n     *ngAfterViewInit() {\n     *    let iconActive = this.icon.getActive;\n     * }\n     * ```\n     */\n    get getActive(): boolean {\n        return this.active;\n    }\n\n    /**\n     *  An accessor that returns inactive property.\n     *```typescript\n     *@ViewChild(\"MyIcon\")\n     *public icon: IgxIconComponent;\n     *ngAfterViewInit() {\n     *    let iconActive = this.icon.getInactive;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-icon--inactive')\n    get getInactive(): boolean {\n        return !this.active;\n    }\n\n    /**\n     *  An accessor that returns the opposite value of the `iconColor` property.\n     *```typescript\n     *@ViewChild(\"MyIcon\")\n     *public icon: IgxIconComponent;\n     *ngAfterViewInit() {\n     *    let iconColor = this.icon.getIconColor;\n     * }\n     * ```\n     */\n    @HostBinding('style.color')\n    get getIconColor(): string {\n        return this.iconColor;\n    }\n\n    /**\n     *  An accessor that returns the value of the iconName property.\n     *```typescript\n     *@ViewChild(\"MyIcon\")\n     *public icon: IgxIconComponent;\n     *ngAfterViewInit() {\n     *    let iconName = this.icon.getIconName;\n     * }\n     * ```\n     */\n    get getIconName(): string {\n        return this.iconName;\n    }\n\n    /**\n     *  An accessor that returns the key of the SVG image.\n     *  The key consists of the fontSet and the iconName separated by underscore.\n     *```typescript\n     *@ViewChild(\"MyIcon\")\n     *public icon: IgxIconComponent;\n     *ngAfterViewInit() {\n     *    let svgKey = this.icon.getSvgKey;\n     * }\n     * ```\n     */\n    get getSvgKey(): string {\n        if (this.iconService.isSvgIconCached(this.iconName, this.font)) {\n            return '#' + this.iconService.getSvgIconKey(this.iconName, this.font);\n        }\n\n        return null;\n    }\n\n    /**\n     *   An accessor that returns a TemplateRef to explicit, svg or no ligature.\n     *```typescript\n     *@ViewChild(\"MyIcon\")\n     *public icon: IgxIconComponent;\n     *ngAfterViewInit() {\n     *    let iconTemplate = this.icon.template;\n     * }\n     * ```\n     */\n    get template(): TemplateRef<HTMLElement> {\n        if (this.iconName) {\n            if (this.iconService.isSvgIconCached(this.iconName, this.font)) {\n                return this.svgImage;\n            }\n\n            return this.noLigature;\n        }\n\n        return this.explicitLigature;\n    }\n\n    /**\n     * @hidden\n     */\n    private updateIconClass() {\n        const className = this.iconService.fontSetClassName(this.font);\n        this.el.nativeElement.classList.add(className);\n\n        if (this.iconName && !this.iconService.isSvgIconCached(this.iconName, this.font)) {\n            this.el.nativeElement.classList.add(this.iconName);\n        }\n    }\n}\n"]}