UNPKG

@uex/web-extensions

Version:

Uex extensions for Angular 6+ web projects

195 lines 13.7 kB
/** * @fileoverview added by tsickle * Generated from: lib/modules/icon/icon.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, Input } from '@angular/core'; import * as _ from 'lodash'; export class IconComponent { /** * @param {?} elementRef */ constructor(elementRef) { this.elementRef = elementRef; this.mode = 'md'; this._classes = []; } /** * @return {?} */ ngOnInit() { this._updateClasses(); } /** * @return {?} */ ngOnChanges() { this._updateClasses(); } /** * @return {?} */ get offsetTop() { return this.elementRef.nativeElement.offsetTop; } /** * @return {?} */ getValue() { switch (this.mode) { case 'fa': case 'fas': case 'far': case 'fab': case 'uex': return null; default: return this.name; } } /** * @private * @return {?} */ _updateClasses() { this._clearClasses(); switch (this.mode) { case 'fa': case 'fas': case 'far': case 'fab': this._classes.push(this.mode); this._classes.push('fa-fw'); this._classes.push(`fa-${this.name}`); break; case 'uex': this._classes.push(`uex-custom-icons`); this._classes.push(`uex-custom-icon-${this.name}`); break; default: this._classes.push('material-icons'); } /** @type {?} */ const size_class = this._getSizeClass(); if (size_class) { this._classes.push(size_class); } /** @type {?} */ const color_class = this._getColorClass(); if (color_class) { this._classes.push(color_class); } this._setClasses(); } /** * @private * @return {?} */ _clearClasses() { if (this._classes) { /** @type {?} */ const current_classes = this.elementRef.nativeElement.className.split(' '); this._classes.forEach((/** * @param {?} _class * @return {?} */ (_class) => { /** @type {?} */ const index = current_classes.indexOf(_class); if (index > -1) { current_classes.splice(index, 1); } })); this._classes = []; this.elementRef.nativeElement.className = current_classes.join(' '); } } /** * @private * @return {?} */ _setClasses() { /** @type {?} */ const current_classes = this.elementRef.nativeElement.className.split(' ').filter((/** * @param {?} i * @return {?} */ (i) => !!i)); this.elementRef.nativeElement.className = _.concat(current_classes, this._classes).join(' '); } /** * @private * @return {?} */ _getSizeClass() { switch (this.size) { case '2x': case 'large': case 'lg': return 'size-2x'; case '3x': case 'xlarge': case 'xl': return 'size-3x'; case '4x': case 'xxlarge': case 'xxl': return 'size-4x'; case '5x': case 'xxxlarge': case 'xxxl': return 'size-5x'; default: return null; } } /** * @private * @return {?} */ _getColorClass() { if (!this.color) { return; } return `text-${this.color}`; } } IconComponent.decorators = [ { type: Component, args: [{ selector: 'uex-icon', template: '{{getValue()}}', host: { class: 'uex-icon' } }] } ]; /** @nocollapse */ IconComponent.ctorParameters = () => [ { type: ElementRef } ]; IconComponent.propDecorators = { mode: [{ type: Input }], color: [{ type: Input }], size: [{ type: Input }], name: [{ type: Input }] }; if (false) { /** @type {?} */ IconComponent.prototype.mode; /** @type {?} */ IconComponent.prototype.color; /** @type {?} */ IconComponent.prototype.size; /** @type {?} */ IconComponent.prototype.name; /** * @type {?} * @private */ IconComponent.prototype._classes; /** * @type {?} * @private */ IconComponent.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"ng://@uex/web-extensions/","sources":["lib/modules/icon/icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, OnChanges } from '@angular/core';\r\n\r\nimport * as _ from 'lodash';\r\n\r\n@Component({\r\n  selector: 'uex-icon',\r\n  template: '{{getValue()}}',\r\n  host: {\r\n    class: 'uex-icon'\r\n  }\r\n})\r\nexport class IconComponent implements OnInit, OnChanges {\r\n  @Input() mode: IconMode = 'md';\r\n  @Input() color: string;\r\n  @Input() size: string;\r\n  @Input() name: string;\r\n\r\n  constructor(\r\n    private elementRef: ElementRef\r\n  ) { }\r\n\r\n  private _classes: Array<string> = [];\r\n\r\n  public ngOnInit() {\r\n    this._updateClasses();\r\n  }\r\n\r\n  public ngOnChanges() {\r\n    this._updateClasses();\r\n  }\r\n\r\n  public get offsetTop(): number {\r\n    return this.elementRef.nativeElement.offsetTop;\r\n  }\r\n\r\n  public getValue(): string {\r\n    switch (this.mode) {\r\n      case 'fa':\r\n      case 'fas':\r\n      case 'far':\r\n      case 'fab':\r\n      case 'uex':\r\n        return null;\r\n      default:\r\n        return this.name;\r\n    }\r\n  }\r\n\r\n  private _updateClasses() {\r\n    this._clearClasses();\r\n\r\n    switch (this.mode) {\r\n      case 'fa':\r\n      case 'fas':\r\n      case 'far':\r\n      case 'fab':\r\n        this._classes.push(this.mode);\r\n        this._classes.push('fa-fw');\r\n        this._classes.push(`fa-${this.name}`);\r\n        break;\r\n      case 'uex':\r\n        this._classes.push(`uex-custom-icons`);\r\n        this._classes.push(`uex-custom-icon-${this.name}`);\r\n        break;\r\n      default:\r\n        this._classes.push('material-icons');\r\n    }\r\n\r\n    const size_class = this._getSizeClass();\r\n    if (size_class) { this._classes.push(size_class); }\r\n\r\n    const color_class = this._getColorClass();\r\n    if (color_class) { this._classes.push(color_class); }\r\n\r\n    this._setClasses();\r\n  }\r\n\r\n  private _clearClasses() {\r\n    if (this._classes) {\r\n      const current_classes = this.elementRef.nativeElement.className.split(' ');\r\n      this._classes.forEach((_class) => {\r\n        const index = current_classes.indexOf(_class);\r\n        if (index > -1) { current_classes.splice(index, 1); }\r\n      });\r\n      this._classes = [];\r\n      this.elementRef.nativeElement.className = current_classes.join(' ');\r\n    }\r\n  }\r\n\r\n  private _setClasses() {\r\n    const current_classes = this.elementRef.nativeElement.className.split(' ').filter((i) => !!i);\r\n    this.elementRef.nativeElement.className = _.concat(current_classes, this._classes).join(' ');\r\n  }\r\n\r\n  private _getSizeClass(): string {\r\n    switch (this.size) {\r\n      case '2x':\r\n      case 'large':\r\n      case 'lg':\r\n        return 'size-2x';\r\n      case '3x':\r\n      case 'xlarge':\r\n      case 'xl':\r\n        return 'size-3x';\r\n      case '4x':\r\n      case 'xxlarge':\r\n      case 'xxl':\r\n        return 'size-4x';\r\n      case '5x':\r\n      case 'xxxlarge':\r\n      case 'xxxl':\r\n        return 'size-5x';\r\n      default: return null;\r\n    }\r\n  }\r\n\r\n  private _getColorClass(): string {\r\n    if (!this.color) { return; }\r\n    return `text-${this.color}`;\r\n  }\r\n}\r\n\r\nexport type IconMode = 'md' | 'fa' | 'fas' | 'far' | 'fab' | 'uex';\r\n"]}