truly-ui
Version:
Web Components for Desktop Applications.
268 lines (266 loc) • 41 kB
JavaScript
/*
MIT License
Copyright (c) 2019 Temainfo Software
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
*/
import { Component, Input, ViewChild, Output, Optional, Inject, EventEmitter, Self, } from '@angular/core';
import { InputMask } from './core/input-mask';
import { CdkOverlayOrigin } from '@angular/cdk/overlay';
import { ValueAccessorBase } from './core/value-accessor';
import { INPUT_CONFIG } from './core/input.config';
import { Subscription } from 'rxjs';
import * as i0 from "@angular/core";
import * as i1 from "@angular/forms";
import * as i2 from "@angular/common";
import * as i3 from "../icons/icons";
import * as i4 from "../internals/components/label/label";
import * as i5 from "@angular/cdk/overlay";
/**
* Input Component personalized with few features.
*
* import { InputModule } from 'truly-ui';
*
* @Component({
* selector: 'my-app-comp',
* template: '
* <tl-input
* [(ngModel)]="title"
* [iconBefore]="'ion-email'"
* [iconAfter]="'ion-email'"
* [textBefore]="'R$'"
* [textAfter]="'00,00'"
* [placeholder]="'Meu Input'"
* [clearButton]="true"
* [readonly]="true"
* [disabled]="true"
* [toUpperCase]="true">
* </tl-input>
* '
* })
*/
export class TlInput extends ValueAccessorBase {
constructor(inputConfig, ngControl, tlInput, renderer, change) {
super();
this.inputConfig = inputConfig;
this.ngControl = ngControl;
this.tlInput = tlInput;
this.renderer = renderer;
this.change = change;
this.textBefore = '';
this.textAfter = '';
this.labelPlacement = 'left';
this.labelSize = '100px';
this.name = '';
this.label = '';
this.color = 'basic';
this.iconBefore = '';
this.iconAfter = '';
this.clearButton = false;
this.readonly = null;
this.required = null;
this.disabled = null;
this.autocomplete = 'off';
this.maxlength = -1;
this.tabindex = 0;
this.textAlign = 'left';
this.mask = '';
this.placeholder = ' ';
this.type = 'text';
this.height = '23px';
this.withBorder = true;
this.flatBorder = false;
this.clear = new EventEmitter();
this.overlayOrigin = new EventEmitter();
this.clickAddon = new EventEmitter();
this.click = new EventEmitter();
this.focus = new EventEmitter();
this.blur = new EventEmitter();
this.valid = new EventEmitter();
this.completeMask = new EventEmitter();
this.isShowingMessages = false;
this.subscription = new Subscription();
this.setControl();
this.setOptions(this.inputConfig);
}
get control() {
return this.ngControl?.control;
}
setControl() {
if (this.ngControl) {
this.ngControl.valueAccessor = this;
}
}
ngOnInit() {
this.overlayOrigin.emit(this.cdkOverlayOrigin);
}
ngAfterViewInit() {
this.handleValidator();
this.handleRequiredValidator();
this.handleMask();
}
handleRequiredValidator() {
if (this.control && this.control.errors && this.control.errors.hasOwnProperty('required')) {
this.required = this.control.errors['required'];
this.change.detectChanges();
}
}
handleValidator() {
if (this.control) {
this.hasValidator = this.control.validator;
this.change.detectChanges();
}
}
handleMask() {
if (this.mask) {
this.fieldMask = new InputMask(this, this.renderer, this.mask);
this.subscription.add(this.fieldMask.complete.subscribe(() => {
this.completeMask.emit(true);
}));
}
}
onClickAddon($event, side) {
this.stopEvent($event);
this.clickAddon.emit({ $event, side });
}
onInputClick($event) {
this.stopEvent($event);
this.isShowingMessages = true;
this.click.emit($event);
}
setOptions(options) {
if (options) {
const self = this;
Object.keys(options).forEach(function (key) {
self[key] = options[key];
});
}
}
stopEvent($event) {
$event.preventDefault();
$event.stopPropagation();
}
setFocus() {
this.input.nativeElement.focus();
}
getNativeInput() {
return this.input.nativeElement;
}
onInputFocus($event) {
this.isShowingMessages = true;
this.focus.emit($event);
}
onInputBlur($event) {
this.isShowingMessages = false;
this.blur.emit($event);
this.propagateTouched();
}
clearInput($event) {
this.value = '';
this.input.nativeElement.focus();
this.clear.emit($event);
}
ngOnDestroy() {
this.subscription.unsubscribe();
}
}
/** @nocollapse */ TlInput.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TlInput, deps: [{ token: INPUT_CONFIG, optional: true }, { token: i1.NgControl, optional: true, self: true }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ TlInput.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TlInput, selector: "tl-input", inputs: { textBefore: "textBefore", textAfter: "textAfter", labelPlacement: "labelPlacement", labelSize: "labelSize", name: "name", label: "label", color: "color", iconBefore: "iconBefore", iconAfter: "iconAfter", clearButton: "clearButton", readonly: "readonly", required: "required", disabled: "disabled", autocomplete: "autocomplete", maxlength: "maxlength", tabindex: "tabindex", textAlign: "textAlign", mask: "mask", placeholder: "placeholder", type: "type", height: "height", withBorder: "withBorder", flatBorder: "flatBorder" }, outputs: { clear: "clear", overlayOrigin: "overlayOrigin", clickAddon: "clickAddon", click: "click", focus: "focus", blur: "blur", valid: "valid", completeMask: "completeMask" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true, static: true }, { propertyName: "inputBox", first: true, predicate: ["inputBox"], descendants: true, static: true }, { propertyName: "cdkOverlayOrigin", first: true, predicate: CdkOverlayOrigin, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div [class]=\"'tl-input-box ' + color\" #inputBox>\n\n <tl-label *ngIf=\"label\" [required]=\"required\" [labelTitle]=\"label\" [labelPlacement]=\"labelPlacement\" [labelSize]=\"labelSize\"></tl-label>\n\n <span *ngIf=\"iconBefore\" (click)=\"onClickAddon($event, 'before')\"\n [ngClass]=\"{ 'withoutBorder' : !withBorder, '-flatborders': flatBorder }\" class=\"addon -borderleft\">\n <tl-icon>{{ iconBefore }}</tl-icon>\n </span>\n\n <span *ngIf=\"textBefore\" (click)=\"onClickAddon($event, 'before')\" class=\"addon -borderleft\"\n [ngClass]=\"\n {\n 'predefined' : textBefore,\n 'withBorder': withBorder,\n 'withoutBorder' : !withBorder,\n '-flatborders': flatBorder\n }\">\n {{textBefore}}\n </span>\n\n <div class=\"ui-wrapper-input\" [ngClass]=\"{'-flatborders': flatBorder}\" [style.height]=\"height\">\n <input [style.padding-right]=\"clearButton ? '20px' : '12px'\"\n [style.height]=\"height\"\n #input\n [type]=\"type\"\n cdkOverlayOrigin\n [tabindex]=\"tabindex\"\n [style.text-align]=\"textAlign\"\n [disabled]=\"disabled || isDisabled\"\n class=\"field\"\n [ngClass]=\"{\n 'ng-invalid': control?.errors,\n 'ng-valid': !control?.errors,\n 'ng-touched': control?.touched,\n 'ng-untouched': control?.untouched,\n 'withValidators': hasValidator,\n 'withoutValidators': !hasValidator,\n 'withBorder': withBorder,\n 'withoutBorder' : !withBorder,\n '-borderleft': iconBefore || textBefore,\n '-flatborders': flatBorder,\n '-borderright': iconAfter || textAfter\n }\"\n [attr.readonly]=\"readonly ? true : null\"\n [attr.required]=\"required ? true : null\"\n [attr.autocomplete]=\"autocomplete\"\n [attr.maxlength]=\"maxlength\"\n [attr.name]=\"name\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (click)=\"onInputClick($event)\"\n (blur)=\"onInputBlur($event)\"\n (focus)=\"onInputFocus($event)\">\n <i *ngIf=\"clearButton && value\" (click)=\"clearInput($event)\"\n class=\"ion ion-ios-close-circle-outline clearButton\">\n </i>\n </div>\n\n <span #afterIcon *ngIf=\"iconAfter\"\n (click)=\"onClickAddon($event, 'after')\" class=\"addon -borderright\"\n [ngClass]=\"{ 'withoutBorder' : !withBorder, '-flatborders': flatBorder, '-borderright': iconAfter || textAfter }\">\n <tl-icon>{{ iconAfter }}</tl-icon>\n </span>\n\n <span *ngIf=\"textAfter\" (click)=\"onClickAddon($event, 'after')\" #afterText class=\"addon -borderright\"\n [ngClass]=\"{ '-predefined' : textAfter, '-flatborders': flatBorder, 'withoutBorder' : !withBorder }\">{{textAfter}}</span>\n</div>\n", styles: ["*{box-sizing:border-box}.tl-input-box{width:100%;position:relative;display:table;border-collapse:separate}.tl-input-box .addon{display:table-cell;padding:3px 12px;font-size:14px;font-weight:400;line-height:1;text-align:center;width:1%;white-space:nowrap;vertical-align:middle}.tl-input-box .addon.-borderleft{border-radius:3px 0 0 3px}.tl-input-box .addon.-borderright{border-radius:0 3px 3px 0}.tl-input-box .addon.-clearbutton{font-size:11px;position:absolute;border:0;top:3px;right:4px;cursor:pointer}.tl-input-box .addon.-flatborders{border-radius:0}.tl-input-box .addon.-predefined{font-family:Segoe UI,Lato,\"sans-serif\",Arial}.tl-input-box .addon:hover{cursor:pointer}.tl-input-box>.ui-wrapper-input{position:relative;display:flex;align-items:center;justify-content:center}.tl-input-box>.ui-wrapper-input>.field{display:table-cell;height:23px;padding:4px 20px 4px 6px;font-family:Segoe UI,Lato,\"sans-serif\",Arial;font-size:1em;width:100%;font-weight:400;border-radius:3px;transition:background-color .23s ease-in-out}.tl-input-box>.ui-wrapper-input>.field.-borderleft{border-top-left-radius:0;border-bottom-left-radius:0}.tl-input-box>.ui-wrapper-input>.field.-borderright{border-top-right-radius:0;border-bottom-right-radius:0}.tl-input-box>.ui-wrapper-input>.field.-flatborders{border-radius:0}.tl-input-box>.ui-wrapper-input>.field::placeholder{font-family:Segoe UI,Lato,\"sans-serif\",Arial;font-size:1em}.tl-input-box>.ui-wrapper-input>.field.-disabled{cursor:default!important}.tl-input-box>.ui-wrapper-input>.clearButton{position:absolute;font-size:22px;padding-right:5px;right:0;color:#ccc}.tl-input-box>.ui-wrapper-input>.clearButton:hover{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.TlIcons, selector: "tl-icon", inputs: ["icon", "lib", "style", "size", "animation", "color", "align"] }, { kind: "component", type: i4.TlLabel, selector: "tl-label", inputs: ["labelPlacement", "required", "labelSize", "labelTitle"] }, { kind: "directive", type: i5.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TlInput, decorators: [{
type: Component,
args: [{ selector: 'tl-input', template: "<div [class]=\"'tl-input-box ' + color\" #inputBox>\n\n <tl-label *ngIf=\"label\" [required]=\"required\" [labelTitle]=\"label\" [labelPlacement]=\"labelPlacement\" [labelSize]=\"labelSize\"></tl-label>\n\n <span *ngIf=\"iconBefore\" (click)=\"onClickAddon($event, 'before')\"\n [ngClass]=\"{ 'withoutBorder' : !withBorder, '-flatborders': flatBorder }\" class=\"addon -borderleft\">\n <tl-icon>{{ iconBefore }}</tl-icon>\n </span>\n\n <span *ngIf=\"textBefore\" (click)=\"onClickAddon($event, 'before')\" class=\"addon -borderleft\"\n [ngClass]=\"\n {\n 'predefined' : textBefore,\n 'withBorder': withBorder,\n 'withoutBorder' : !withBorder,\n '-flatborders': flatBorder\n }\">\n {{textBefore}}\n </span>\n\n <div class=\"ui-wrapper-input\" [ngClass]=\"{'-flatborders': flatBorder}\" [style.height]=\"height\">\n <input [style.padding-right]=\"clearButton ? '20px' : '12px'\"\n [style.height]=\"height\"\n #input\n [type]=\"type\"\n cdkOverlayOrigin\n [tabindex]=\"tabindex\"\n [style.text-align]=\"textAlign\"\n [disabled]=\"disabled || isDisabled\"\n class=\"field\"\n [ngClass]=\"{\n 'ng-invalid': control?.errors,\n 'ng-valid': !control?.errors,\n 'ng-touched': control?.touched,\n 'ng-untouched': control?.untouched,\n 'withValidators': hasValidator,\n 'withoutValidators': !hasValidator,\n 'withBorder': withBorder,\n 'withoutBorder' : !withBorder,\n '-borderleft': iconBefore || textBefore,\n '-flatborders': flatBorder,\n '-borderright': iconAfter || textAfter\n }\"\n [attr.readonly]=\"readonly ? true : null\"\n [attr.required]=\"required ? true : null\"\n [attr.autocomplete]=\"autocomplete\"\n [attr.maxlength]=\"maxlength\"\n [attr.name]=\"name\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (click)=\"onInputClick($event)\"\n (blur)=\"onInputBlur($event)\"\n (focus)=\"onInputFocus($event)\">\n <i *ngIf=\"clearButton && value\" (click)=\"clearInput($event)\"\n class=\"ion ion-ios-close-circle-outline clearButton\">\n </i>\n </div>\n\n <span #afterIcon *ngIf=\"iconAfter\"\n (click)=\"onClickAddon($event, 'after')\" class=\"addon -borderright\"\n [ngClass]=\"{ 'withoutBorder' : !withBorder, '-flatborders': flatBorder, '-borderright': iconAfter || textAfter }\">\n <tl-icon>{{ iconAfter }}</tl-icon>\n </span>\n\n <span *ngIf=\"textAfter\" (click)=\"onClickAddon($event, 'after')\" #afterText class=\"addon -borderright\"\n [ngClass]=\"{ '-predefined' : textAfter, '-flatborders': flatBorder, 'withoutBorder' : !withBorder }\">{{textAfter}}</span>\n</div>\n", styles: ["*{box-sizing:border-box}.tl-input-box{width:100%;position:relative;display:table;border-collapse:separate}.tl-input-box .addon{display:table-cell;padding:3px 12px;font-size:14px;font-weight:400;line-height:1;text-align:center;width:1%;white-space:nowrap;vertical-align:middle}.tl-input-box .addon.-borderleft{border-radius:3px 0 0 3px}.tl-input-box .addon.-borderright{border-radius:0 3px 3px 0}.tl-input-box .addon.-clearbutton{font-size:11px;position:absolute;border:0;top:3px;right:4px;cursor:pointer}.tl-input-box .addon.-flatborders{border-radius:0}.tl-input-box .addon.-predefined{font-family:Segoe UI,Lato,\"sans-serif\",Arial}.tl-input-box .addon:hover{cursor:pointer}.tl-input-box>.ui-wrapper-input{position:relative;display:flex;align-items:center;justify-content:center}.tl-input-box>.ui-wrapper-input>.field{display:table-cell;height:23px;padding:4px 20px 4px 6px;font-family:Segoe UI,Lato,\"sans-serif\",Arial;font-size:1em;width:100%;font-weight:400;border-radius:3px;transition:background-color .23s ease-in-out}.tl-input-box>.ui-wrapper-input>.field.-borderleft{border-top-left-radius:0;border-bottom-left-radius:0}.tl-input-box>.ui-wrapper-input>.field.-borderright{border-top-right-radius:0;border-bottom-right-radius:0}.tl-input-box>.ui-wrapper-input>.field.-flatborders{border-radius:0}.tl-input-box>.ui-wrapper-input>.field::placeholder{font-family:Segoe UI,Lato,\"sans-serif\",Arial;font-size:1em}.tl-input-box>.ui-wrapper-input>.field.-disabled{cursor:default!important}.tl-input-box>.ui-wrapper-input>.clearButton{position:absolute;font-size:22px;padding-right:5px;right:0;color:#ccc}.tl-input-box>.ui-wrapper-input>.clearButton:hover{cursor:pointer}\n"] }]
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [INPUT_CONFIG]
}] }, { type: i1.NgControl, decorators: [{
type: Optional
}, {
type: Self
}] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { textBefore: [{
type: Input
}], textAfter: [{
type: Input
}], labelPlacement: [{
type: Input
}], labelSize: [{
type: Input
}], name: [{
type: Input
}], label: [{
type: Input
}], color: [{
type: Input
}], iconBefore: [{
type: Input
}], iconAfter: [{
type: Input
}], clearButton: [{
type: Input
}], readonly: [{
type: Input
}], required: [{
type: Input
}], disabled: [{
type: Input
}], autocomplete: [{
type: Input
}], maxlength: [{
type: Input
}], tabindex: [{
type: Input
}], textAlign: [{
type: Input
}], mask: [{
type: Input
}], placeholder: [{
type: Input
}], type: [{
type: Input
}], height: [{
type: Input
}], withBorder: [{
type: Input
}], flatBorder: [{
type: Input
}], input: [{
type: ViewChild,
args: ['input', { static: true }]
}], inputBox: [{
type: ViewChild,
args: ['inputBox', { static: true }]
}], cdkOverlayOrigin: [{
type: ViewChild,
args: [CdkOverlayOrigin, { static: true }]
}], clear: [{
type: Output
}], overlayOrigin: [{
type: Output
}], clickAddon: [{
type: Output
}], click: [{
type: Output
}], focus: [{
type: Output
}], blur: [{
type: Output
}], valid: [{
type: Output
}], completeMask: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.js","sourceRoot":"","sources":["../../../../projects/truly-ui/src/components/input/input.ts","../../../../projects/truly-ui/src/components/input/input.html"],"names":[],"mappings":"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","sourcesContent":["/*\n MIT License\n\n Copyright (c) 2019 Temainfo Software\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n The above copyright notice and this permission notice shall be included in all\n copies or substantial portions of the Software.\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n SOFTWARE.\n */\nimport {\n  Component,\n  Input,\n  ViewChild,\n  AfterViewInit,\n  Output,\n  Optional,\n  Inject,\n  EventEmitter, Renderer2, ElementRef, OnInit, ContentChild, forwardRef, ChangeDetectorRef, OnDestroy, Self, Injector, AfterContentInit,\n} from '@angular/core';\nimport {InputMask} from './core/input-mask';\nimport {\n  AbstractControl, NgControl,\n} from '@angular/forms';\nimport {CdkOverlayOrigin} from '@angular/cdk/overlay';\nimport {ValueAccessorBase} from './core/value-accessor';\nimport {INPUT_CONFIG, InputConfig} from './core/input.config';\nimport {Subscription} from 'rxjs';\n\n/**\n * Input Component personalized with few features.\n *\n * import { InputModule } from 'truly-ui';\n *\n * @Component({\n *  selector: 'my-app-comp',\n *  template: '\n *  <tl-input\n *   [(ngModel)]=\"title\"\n *   [iconBefore]=\"'ion-email'\"\n *   [iconAfter]=\"'ion-email'\"\n *   [textBefore]=\"'R$'\"\n *   [textAfter]=\"'00,00'\"\n *   [placeholder]=\"'Meu Input'\"\n *   [clearButton]=\"true\"\n *   [readonly]=\"true\"\n *   [disabled]=\"true\"\n *   [toUpperCase]=\"true\">\n *  </tl-input>\n *  '\n * })\n */\n\n@Component({\n  selector: 'tl-input',\n  templateUrl: './input.html',\n  styleUrls: ['./input.scss']\n})\nexport class TlInput extends ValueAccessorBase<string> implements OnInit, OnDestroy, AfterViewInit {\n\n  @Input() textBefore = '';\n\n  @Input() textAfter = '';\n\n  @Input() labelPlacement = 'left';\n\n  @Input() labelSize = '100px';\n\n  @Input() name = '';\n\n  @Input() label = '';\n\n  @Input() color = 'basic';\n\n  @Input() iconBefore = '';\n\n  @Input() iconAfter = '';\n\n  @Input() clearButton = false;\n\n  @Input() readonly: boolean = null;\n\n  @Input() required: boolean = null;\n\n  @Input() disabled: boolean = null;\n\n  @Input() autocomplete = 'off';\n\n  @Input() maxlength = -1;\n\n  @Input() tabindex = 0;\n\n  @Input() textAlign: 'left' | 'right' | 'center' | 'justify' = 'left';\n\n  @Input() mask = '';\n\n  @Input() placeholder = ' ';\n\n  @Input() type = 'text';\n\n  @Input() height = '23px';\n\n  @Input() withBorder = true;\n\n  @Input() flatBorder = false;\n\n  @ViewChild('input', {static: true} ) input;\n\n  @ViewChild('inputBox', {static: true} ) inputBox;\n\n  @ViewChild(CdkOverlayOrigin, {static: true} ) cdkOverlayOrigin: CdkOverlayOrigin;\n\n  @Output() clear: EventEmitter<any> = new EventEmitter();\n\n  @Output() overlayOrigin: EventEmitter<any> = new EventEmitter();\n\n  @Output() clickAddon: EventEmitter<any> = new EventEmitter();\n\n  @Output() click: EventEmitter<MouseEvent> = new EventEmitter();\n\n  @Output() focus: EventEmitter<any> = new EventEmitter();\n\n  @Output() blur: EventEmitter<any> = new EventEmitter();\n\n  @Output() valid: EventEmitter<boolean> = new EventEmitter();\n\n  @Output() completeMask: EventEmitter<boolean> = new EventEmitter();\n\n  public isShowingMessages = false;\n\n  public fieldMask: InputMask;\n\n  public hasValidator;\n\n  private subscription = new Subscription();\n\n  constructor(@Optional() @Inject(INPUT_CONFIG) private inputConfig: InputConfig,\n              @Optional() @Self() public ngControl: NgControl,\n              private tlInput: ElementRef, private renderer: Renderer2,\n              private change: ChangeDetectorRef) {\n    super();\n    this.setControl();\n    this.setOptions(this.inputConfig);\n  }\n\n  get control() {\n    return this.ngControl?.control;\n  }\n\n  setControl() {\n    if ( this.ngControl ) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  ngOnInit() {\n    this.overlayOrigin.emit(this.cdkOverlayOrigin);\n  }\n\n  ngAfterViewInit() {\n    this.handleValidator();\n    this.handleRequiredValidator();\n    this.handleMask();\n  }\n\n  handleRequiredValidator() {\n    if (this.control && this.control.errors && this.control.errors.hasOwnProperty('required')) {\n      this.required = this.control.errors['required'];\n      this.change.detectChanges();\n    }\n  }\n\n  handleValidator() {\n    if (this.control) {\n      this.hasValidator = this.control.validator;\n      this.change.detectChanges();\n    }\n  }\n\n  handleMask() {\n    if (this.mask) {\n      this.fieldMask = new InputMask(this, this.renderer, this.mask);\n      this.subscription.add(this.fieldMask.complete.subscribe(() => {\n        this.completeMask.emit(true);\n      }));\n    }\n  }\n\n  onClickAddon($event, side) {\n    this.stopEvent($event);\n    this.clickAddon.emit({$event, side});\n  }\n\n  onInputClick($event: MouseEvent) {\n    this.stopEvent($event);\n    this.isShowingMessages = true;\n    this.click.emit($event);\n  }\n\n  setOptions(options: InputConfig) {\n    if (options) {\n      const self = this;\n      Object.keys(options).forEach(function (key) {\n        self[key] = options[key];\n      });\n    }\n  }\n\n  stopEvent($event) {\n    $event.preventDefault();\n    $event.stopPropagation();\n  }\n\n  setFocus() {\n    this.input.nativeElement.focus();\n  }\n\n  getNativeInput() {\n    return this.input.nativeElement;\n  }\n\n  onInputFocus($event) {\n    this.isShowingMessages = true;\n    this.focus.emit($event);\n  }\n\n  onInputBlur($event) {\n    this.isShowingMessages = false;\n    this.blur.emit($event);\n    this.propagateTouched();\n  }\n\n  clearInput($event?) {\n    this.value = '';\n    this.input.nativeElement.focus();\n    this.clear.emit($event);\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n  }\n\n}\n","<div [class]=\"'tl-input-box ' + color\" #inputBox>\n\n  <tl-label *ngIf=\"label\" [required]=\"required\" [labelTitle]=\"label\" [labelPlacement]=\"labelPlacement\" [labelSize]=\"labelSize\"></tl-label>\n\n  <span *ngIf=\"iconBefore\" (click)=\"onClickAddon($event, 'before')\"\n        [ngClass]=\"{ 'withoutBorder' : !withBorder, '-flatborders': flatBorder }\" class=\"addon -borderleft\">\n    <tl-icon>{{ iconBefore }}</tl-icon>\n  </span>\n\n  <span *ngIf=\"textBefore\" (click)=\"onClickAddon($event, 'before')\" class=\"addon -borderleft\"\n        [ngClass]=\"\n        {\n        'predefined' : textBefore,\n        'withBorder': withBorder,\n        'withoutBorder' : !withBorder,\n        '-flatborders': flatBorder\n        }\">\n    {{textBefore}}\n  </span>\n\n  <div class=\"ui-wrapper-input\" [ngClass]=\"{'-flatborders': flatBorder}\" [style.height]=\"height\">\n    <input [style.padding-right]=\"clearButton ? '20px' : '12px'\"\n           [style.height]=\"height\"\n           #input\n           [type]=\"type\"\n           cdkOverlayOrigin\n           [tabindex]=\"tabindex\"\n           [style.text-align]=\"textAlign\"\n           [disabled]=\"disabled || isDisabled\"\n           class=\"field\"\n           [ngClass]=\"{\n             'ng-invalid': control?.errors,\n             'ng-valid': !control?.errors,\n             'ng-touched': control?.touched,\n             'ng-untouched': control?.untouched,\n             'withValidators': hasValidator,\n             'withoutValidators': !hasValidator,\n             'withBorder': withBorder,\n             'withoutBorder' : !withBorder,\n             '-borderleft': iconBefore || textBefore,\n             '-flatborders': flatBorder,\n             '-borderright': iconAfter || textAfter\n             }\"\n           [attr.readonly]=\"readonly ? true : null\"\n           [attr.required]=\"required ? true : null\"\n           [attr.autocomplete]=\"autocomplete\"\n           [attr.maxlength]=\"maxlength\"\n           [attr.name]=\"name\"\n           [placeholder]=\"placeholder\"\n           [(ngModel)]=\"value\"\n           (click)=\"onInputClick($event)\"\n           (blur)=\"onInputBlur($event)\"\n           (focus)=\"onInputFocus($event)\">\n    <i *ngIf=\"clearButton && value\" (click)=\"clearInput($event)\"\n       class=\"ion ion-ios-close-circle-outline clearButton\">\n    </i>\n  </div>\n\n  <span #afterIcon *ngIf=\"iconAfter\"\n        (click)=\"onClickAddon($event, 'after')\" class=\"addon -borderright\"\n        [ngClass]=\"{ 'withoutBorder' : !withBorder, '-flatborders': flatBorder, '-borderright': iconAfter || textAfter }\">\n    <tl-icon>{{ iconAfter }}</tl-icon>\n  </span>\n\n  <span *ngIf=\"textAfter\" (click)=\"onClickAddon($event, 'after')\" #afterText class=\"addon -borderright\"\n        [ngClass]=\"{ '-predefined' : textAfter, '-flatborders': flatBorder, 'withoutBorder' : !withBorder }\">{{textAfter}}</span>\n</div>\n"]}