@uex/web-extensions
Version:
Uex extensions for Angular 6+ web projects
195 lines • 13.7 kB
JavaScript
/**
* @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"]}