igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
325 lines • 23.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, HostBinding, Input, 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 appearence
* of the icon.
*
* Example:
* ```html
* <igx-icon color="#00ff00" isActive="true">home</igx-icon>
* ```
* @type {?}
*/
let NEXT_ID = 0;
export class IgxIconComponent {
/**
* @param {?} _el
* @param {?} iconService
*/
constructor(_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
* @return {?}
*/
ngOnInit() {
this.updateIconClass();
}
/**
* An accessor that returns the value of the font property.
* ```typescript
* \@ViewChild("MyIcon")
* public icon: IgxIconComponent;
* ngAfterViewInit() {
* let iconFont = this.icon.getFontSet;
* }
* ```
* @return {?}
*/
get getFontSet() {
return this.font;
}
/**
* An accessor that returns the value of the active property.
* ```typescript
* \@ViewChild("MyIcon")
* public icon: IgxIconComponent;
* ngAfterViewInit() {
* let iconActive = this.icon.getActive;
* }
* ```
* @return {?}
*/
get getActive() {
return this.active;
}
/**
* An accessor that returns inactive property.
* ```typescript
* \@ViewChild("MyIcon")
* public icon: IgxIconComponent;
* ngAfterViewInit() {
* let iconActive = this.icon.getInactive;
* }
* ```
* @return {?}
*/
get getInactive() {
return !this.active;
}
/**
* An accessor that returns the opposite value of the `iconColor` property.
* ```typescript
* \@ViewChild("MyIcon")
* public icon: IgxIconComponent;
* ngAfterViewInit() {
* let iconColor = this.icon.getIconColor;
* }
* ```
* @return {?}
*/
get getIconColor() {
return this.iconColor;
}
/**
* An accessor that returns the value of the iconName property.
* ```typescript
* \@ViewChild("MyIcon")
* public icon: IgxIconComponent;
* ngAfterViewInit() {
* let iconName = this.icon.getIconName;
* }
* ```
* @return {?}
*/
get getIconName() {
return this.iconName;
}
/**
* 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;
* }
* ```
* @return {?}
*/
get getSvgKey() {
if (this.iconService.isSvgIconCached(this.iconName, this.font)) {
return '#' + this.iconService.getSvgIconKey(this.iconName, this.font);
}
return null;
}
/**
* An accessor that returns a TemplateRef to explicit, svg or no ligature.
* ```typescript
* \@ViewChild("MyIcon")
* public icon: IgxIconComponent;
* ngAfterViewInit() {
* let iconTemplate = this.icon.template;
* }
* ```
* @return {?}
*/
get template() {
if (this.iconName) {
if (this.iconService.isSvgIconCached(this.iconName, this.font)) {
return this.svgImage;
}
return this.noLigature;
}
return this.explicitLigature;
}
/**
* @hidden
* @private
* @return {?}
*/
updateIconClass() {
/** @type {?} */
const 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.decorators = [
{ type: Component, args: [{
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"
}] }
];
/** @nocollapse */
IgxIconComponent.ctorParameters = () => [
{ type: ElementRef },
{ type: IgxIconService }
];
IgxIconComponent.propDecorators = {
noLigature: [{ type: ViewChild, args: ['noLigature', { read: TemplateRef },] }],
explicitLigature: [{ type: ViewChild, args: ['explicitLigature', { read: TemplateRef },] }],
svgImage: [{ type: ViewChild, args: ['svgImage', { read: TemplateRef },] }],
cssClass: [{ type: HostBinding, args: ['class.igx-icon',] }],
ariaHidden: [{ type: HostBinding, args: ['attr.aria-hidden',] }],
id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }],
font: [{ type: Input, args: ['fontSet',] }],
active: [{ type: Input, args: ['isActive',] }],
iconColor: [{ type: Input, args: ['color',] }],
iconName: [{ type: Input, args: ['name',] }],
getInactive: [{ type: HostBinding, args: ['class.igx-icon--inactive',] }],
getIconColor: [{ type: HostBinding, args: ['style.color',] }]
};
if (false) {
/**
* @type {?}
* @private
*/
IgxIconComponent.prototype.noLigature;
/**
* @type {?}
* @private
*/
IgxIconComponent.prototype.explicitLigature;
/**
* @type {?}
* @private
*/
IgxIconComponent.prototype.svgImage;
/**
* 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();
* }
* ```
* @type {?}
*/
IgxIconComponent.prototype.cssClass;
/**
* 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();
* }
* ```
* @type {?}
*/
IgxIconComponent.prototype.ariaHidden;
/**
* 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>
* ```
* @type {?}
*/
IgxIconComponent.prototype.id;
/**
* An \@Input property that sets the value of the `fontSet`. By default it's "material".
* ```html
* <igx-icon fontSet="material" color="blue" [isActive]="false">settings</igx-icon>
* ```
* @type {?}
*/
IgxIconComponent.prototype.font;
/**
* 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>
* ```
* @type {?}
*/
IgxIconComponent.prototype.active;
/**
* An \@Input property that allows you to change the `iconColor` of the icon.
* ```html
* <igx-icon color="blue" [isActive]="true" fontSet="material">settings</igx-icon>
* ```
* @type {?}
*/
IgxIconComponent.prototype.iconColor;
/**
* An \@Input property that allows you to set the `iconName` of the icon.
* The `iconName` can be set using the `name` property.
* ```html
* <igx-icon color="blue" [isActive]="true" fontSet="material">question_answer</igx-icon>
* ```
* @type {?}
*/
IgxIconComponent.prototype.iconName;
/**
* An ElementRef property of the `igx-icon` component.
* @type {?}
*/
IgxIconComponent.prototype.el;
/**
* @type {?}
* @private
*/
IgxIconComponent.prototype._el;
/**
* @type {?}
* @private
*/
IgxIconComponent.prototype.iconService;
}
//# 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 appearence\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 })\n    private noLigature: TemplateRef<HTMLElement>;\n\n    @ViewChild('explicitLigature', { read: TemplateRef })\n    private explicitLigature: TemplateRef<HTMLElement>;\n\n    @ViewChild('svgImage', { read: TemplateRef })\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"]}