angular-bootstrap-md
Version:
<a href="http://mdbootstrap.com/docs/angular/getting-started/download/"><img src="https://mdbootstrap.com/img/Marketing/general/logo/medium/mdb-angular2.png"></a> # Angular Bootstrap with Material Design
330 lines • 47.9 kB
JavaScript
import { isPlatformBrowser } from '@angular/common';
import { Directive, ElementRef, Renderer2, Input, HostListener, PLATFORM_ID, Inject, } from '@angular/core';
import { DOWN_ARROW, UP_ARROW } from '../utils/keyboard-navigation';
export class MdbInputDirective {
constructor(_elRef, _renderer, platformId) {
this._elRef = _elRef;
this._renderer = _renderer;
this.el = null;
this.elLabel = null;
this.elIcon = null;
this.element = null;
this.mdbValidate = true;
this.validateSuccess = true;
this.validateError = true;
this.focusCheckbox = true;
this.focusRadio = true;
this.isBrowser = false;
this.isClicked = false;
this.isBrowser = isPlatformBrowser(platformId);
}
onfocus() {
try {
this._renderer.addClass(this.elLabel, 'active');
this.isClicked = true;
}
catch (error) { }
}
onblur() {
this.validationFunction();
try {
if (this.el.nativeElement.value === '') {
this._renderer.removeClass(this.elLabel, 'active');
}
this.isClicked = false;
}
catch (error) { }
}
onchange() {
try {
this.checkValue();
}
catch (error) { }
}
oniput() {
this.validationFunction();
}
onkeydown(event) {
try {
if (event.target.type === 'number') {
if (event.shiftKey) {
switch (event.keyCode) {
case UP_ARROW:
event.target.value = +event.target.value + 10;
break;
case DOWN_ARROW:
event.target.value = +event.target.value - 10;
break;
}
}
if (event.altKey) {
switch (event.keyCode) {
case UP_ARROW:
event.target.value = +event.target.value + 0.1;
break;
case DOWN_ARROW:
event.target.value = +event.target.value - 0.1;
break;
}
}
}
}
catch (error) { }
this.delayedResize();
}
oncut() {
try {
setTimeout(() => {
this.delayedResize();
}, 0);
}
catch (error) { }
}
onpaste() {
try {
setTimeout(() => {
this.delayedResize();
}, 0);
}
catch (error) { }
}
ondrop() {
try {
setTimeout(() => {
this.delayedResize();
}, 0);
}
catch (error) { }
}
updateErrorMsg(value) {
if (this.wrongTextContainer) {
this.wrongTextContainer.innerHTML = value;
}
}
updateSuccessMsg(value) {
if (this.rightTextContainer) {
this.rightTextContainer.innerHTML = value;
}
}
ngOnInit() {
try {
setTimeout(() => {
this.delayedResize();
}, 0);
}
catch (error) {
console.log(error);
}
// Inititalise a new <span> wrong/right elements and render it below the host component.
if (this.mdbValidate) {
this.wrongTextContainer = this._renderer.createElement('span');
this._renderer.addClass(this.wrongTextContainer, 'inputVal');
this._renderer.addClass(this.wrongTextContainer, 'text-danger');
this._renderer.appendChild(this._elRef.nativeElement.parentElement, this.wrongTextContainer);
const textWrong = this._elRef.nativeElement.getAttribute('data-error');
this.wrongTextContainer.innerHTML = textWrong ? textWrong : 'wrong';
if (!textWrong && this.errorMessage !== undefined) {
this.wrongTextContainer.innerHTML = this.errorMessage;
}
this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'hidden');
this.rightTextContainer = this._renderer.createElement('span');
this._renderer.addClass(this.rightTextContainer, 'inputVal');
this._renderer.addClass(this.rightTextContainer, 'text-success');
this._renderer.appendChild(this._elRef.nativeElement.parentElement, this.rightTextContainer);
const textSuccess = this._elRef.nativeElement.getAttribute('data-success');
this.rightTextContainer.innerHTML = textSuccess ? textSuccess : 'success';
if (!textSuccess && this.successMessage !== undefined) {
this.rightTextContainer.innerHTML = this.successMessage;
}
this._renderer.setStyle(this.rightTextContainer, 'visibility', 'hidden');
}
}
ngOnChanges(changes) {
if (changes.hasOwnProperty('errorMessage')) {
const newErrorMsg = changes.errorMessage.currentValue;
this.updateErrorMsg(newErrorMsg);
}
if (changes.hasOwnProperty('successMessage')) {
const newSuccessMsg = changes.successMessage.currentValue;
this.updateSuccessMsg(newSuccessMsg);
}
}
ngDoCheck() {
if (this.mdbValidate &&
this._elRef.nativeElement.classList.contains('ng-valid') &&
this._elRef.nativeElement.classList.contains('ng-dirty') &&
!this._elRef.nativeElement.classList.contains('counter-success')) {
this._renderer.addClass(this._elRef.nativeElement, 'counter-success');
this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'hidden');
this._renderer.setStyle(this.rightTextContainer, 'visibility', 'visible');
this._renderer.setStyle(this.rightTextContainer, 'top', this._elRef.nativeElement.offsetHeight + 'px');
this._renderer.setStyle(this.wrongTextContainer, 'top', this._elRef.nativeElement.offsetHeight + 'px');
}
if (this.mdbValidate &&
this._elRef.nativeElement.classList.contains('ng-invalid') &&
this._elRef.nativeElement.classList.contains('ng-dirty') &&
!this._elRef.nativeElement.classList.contains('counter-danger')) {
this._renderer.addClass(this._elRef.nativeElement, 'counter-danger');
this._renderer.setStyle(this.rightTextContainer, 'visibility', 'hidden');
this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'visible');
this._renderer.setStyle(this.rightTextContainer, 'top', this._elRef.nativeElement.offsetHeight + 'px');
this._renderer.setStyle(this.wrongTextContainer, 'top', this._elRef.nativeElement.offsetHeight + 'px');
}
if ((this._elRef.nativeElement.classList.contains('ng-invalid') &&
this._elRef.nativeElement.classList.contains('ng-pristine') &&
this._elRef.nativeElement.classList.contains('ng-untouched')) ||
this._elRef.nativeElement.disabled) {
if (this._elRef.nativeElement.classList.contains('counter-success')) {
this._renderer.removeClass(this._elRef.nativeElement, 'counter-success');
this._renderer.setStyle(this.rightTextContainer, 'visibility', 'hidden');
}
else if (this._elRef.nativeElement.classList.contains('counter-danger')) {
this._renderer.removeClass(this._elRef.nativeElement, 'counter-danger');
this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'hidden');
}
}
if (!this.validateSuccess) {
this._renderer.removeClass(this._elRef.nativeElement, 'counter-success');
this._renderer.setStyle(this.rightTextContainer, 'display', 'none');
if (this._elRef.nativeElement.classList.contains('ng-valid')) {
this._renderer.removeClass(this._elRef.nativeElement, 'counter-danger');
}
}
if (!this.validateError) {
this._renderer.removeClass(this._elRef.nativeElement, 'counter-danger');
this._renderer.setStyle(this.wrongTextContainer, 'display', 'none');
if (this._elRef.nativeElement.classList.contains('ng-invalid')) {
this._renderer.removeClass(this._elRef.nativeElement, 'counter-success');
}
}
}
validationFunction() {
setTimeout(() => {
if (this._elRef.nativeElement.classList.contains('ng-invalid')) {
this._renderer.removeClass(this._elRef.nativeElement, 'counter-success');
this._renderer.removeClass(this._elRef.nativeElement, 'counter-danger');
}
if (this._elRef.nativeElement.classList.contains('ng-touched') &&
this._elRef.nativeElement.classList.contains('ng-invalid')) {
if (this.mdbValidate) {
this._renderer.addClass(this._elRef.nativeElement, 'counter-danger');
this._renderer.setStyle(this.rightTextContainer, 'visibility', 'hidden');
this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'visible');
this._renderer.setStyle(this.rightTextContainer, 'top', this._elRef.nativeElement.offsetHeight + 'px');
this._renderer.setStyle(this.wrongTextContainer, 'top', this._elRef.nativeElement.offsetHeight + 'px');
}
}
else if (this._elRef.nativeElement.classList.contains('ng-touched') &&
this._elRef.nativeElement.classList.contains('ng-valid')) {
if (this.mdbValidate) {
this._renderer.addClass(this._elRef.nativeElement, 'counter-success');
this._renderer.setStyle(this.rightTextContainer, 'visibility', 'visible');
this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'hidden');
this._renderer.setStyle(this.rightTextContainer, 'top', this._elRef.nativeElement.offsetHeight + 'px');
this._renderer.setStyle(this.wrongTextContainer, 'top', this._elRef.nativeElement.offsetHeight + 'px');
}
}
}, 0);
}
ngAfterViewInit() {
if (this.isBrowser) {
try {
this.element = document.querySelector('.md-textarea-auto');
}
catch (error) { }
}
const type = this.el.nativeElement.type;
if (this.focusCheckbox && type === 'checkbox') {
this._renderer.addClass(this.el.nativeElement, 'onFocusSelect');
}
if (this.focusRadio && type === 'radio') {
this._renderer.addClass(this.el.nativeElement, 'onFocusSelect');
}
}
ngAfterViewChecked() {
this.initComponent();
this.checkValue();
}
resize() {
if (this.el.nativeElement.classList.contains('md-textarea-auto')) {
this._renderer.setStyle(this.el.nativeElement, 'height', 'auto');
this._renderer.setStyle(this.el.nativeElement, 'height', this.el.nativeElement.scrollHeight + 'px');
}
}
delayedResize() {
setTimeout(() => {
this.resize();
}, 0);
}
initComponent() {
let inputId;
let inputP;
if (this.isBrowser) {
try {
inputId = this.el.nativeElement.id;
}
catch (err) { }
try {
inputP = this.el.nativeElement.parentNode;
}
catch (err) { }
this.elLabel =
inputP.querySelector('label[for="' + inputId + '"]') || inputP.querySelector('label');
if (this.elLabel && this.el.nativeElement.value !== '') {
this._renderer.addClass(this.elLabel, 'active');
}
this.elIcon = inputP.querySelector('i') || false;
if (this.elIcon) {
this._renderer.addClass(this.elIcon, 'active');
}
}
}
checkValue() {
let value = '';
if (this.elLabel != null) {
value = this.el.nativeElement.value || '';
if (value === '') {
this._renderer.removeClass(this.elLabel, 'active');
if (this.elIcon) {
this._renderer.removeClass(this.elIcon, 'active');
}
// tslint:disable-next-line:max-line-length
}
if ((value === '' && this.isClicked) ||
(value === '' && this.el.nativeElement.placeholder) ||
(value === '' && this.el.nativeElement.attributes.placeholder)) {
this._renderer.addClass(this.elLabel, 'active');
}
}
}
}
MdbInputDirective.decorators = [
{ type: Directive, args: [{
selector: '[mdbInputDirective]',
},] }
];
MdbInputDirective.ctorParameters = () => [
{ type: ElementRef },
{ type: Renderer2 },
{ type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
];
MdbInputDirective.propDecorators = {
mdbInputDirective: [{ type: Input }],
customRegex: [{ type: Input }],
mdbValidate: [{ type: Input }],
validateSuccess: [{ type: Input }],
validateError: [{ type: Input }],
focusCheckbox: [{ type: Input }],
focusRadio: [{ type: Input }],
errorMessage: [{ type: Input }],
successMessage: [{ type: Input }],
onfocus: [{ type: HostListener, args: ['focus',] }],
onblur: [{ type: HostListener, args: ['blur',] }],
onchange: [{ type: HostListener, args: ['change',] }],
oniput: [{ type: HostListener, args: ['input',] }],
onkeydown: [{ type: HostListener, args: ['keydown', ['$event'],] }],
oncut: [{ type: HostListener, args: ['cut',] }],
onpaste: [{ type: HostListener, args: ['paste',] }],
ondrop: [{ type: HostListener, args: ['drop',] }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdb-input.directive.js","sourceRoot":"","sources":["../../../../../../projects/angular-bootstrap-md/src/lib/free/inputs/mdb-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport {\n  Directive,\n  ElementRef,\n  Renderer2,\n  Input,\n  AfterViewInit,\n  HostListener,\n  PLATFORM_ID,\n  Inject,\n  AfterViewChecked,\n  OnInit,\n  DoCheck,\n  OnChanges,\n  SimpleChanges,\n} from '@angular/core';\nimport { DOWN_ARROW, UP_ARROW } from '../utils/keyboard-navigation';\n\n@Directive({\n  selector: '[mdbInputDirective]',\n})\nexport class MdbInputDirective\n  implements AfterViewChecked, OnInit, AfterViewInit, DoCheck, OnChanges {\n  public wrongTextContainer: any;\n  public rightTextContainer: any;\n  public el: ElementRef | any = null;\n  public elLabel: ElementRef | any = null;\n  public elIcon: Element | any = null;\n\n  element: any = null;\n\n  @Input() mdbInputDirective: MdbInputDirective;\n  @Input() customRegex: any;\n  @Input() mdbValidate = true;\n  @Input() validateSuccess = true;\n  @Input() validateError = true;\n  @Input() focusCheckbox = true;\n  @Input() focusRadio = true;\n  @Input() errorMessage: string;\n  @Input() successMessage: string;\n\n  isBrowser: any = false;\n  isClicked = false;\n\n  constructor(\n    private _elRef: ElementRef,\n    private _renderer: Renderer2,\n    @Inject(PLATFORM_ID) platformId: string\n  ) {\n    this.isBrowser = isPlatformBrowser(platformId);\n  }\n\n  @HostListener('focus') onfocus() {\n    try {\n      this._renderer.addClass(this.elLabel, 'active');\n      this.isClicked = true;\n    } catch (error) {}\n  }\n\n  @HostListener('blur') onblur() {\n    this.validationFunction();\n    try {\n      if (this.el.nativeElement.value === '') {\n        this._renderer.removeClass(this.elLabel, 'active');\n      }\n      this.isClicked = false;\n    } catch (error) {}\n  }\n\n  @HostListener('change') onchange() {\n    try {\n      this.checkValue();\n    } catch (error) {}\n  }\n\n  @HostListener('input') oniput() {\n    this.validationFunction();\n  }\n\n  @HostListener('keydown', ['$event']) onkeydown(event: any) {\n    try {\n      if (event.target.type === 'number') {\n        if (event.shiftKey) {\n          switch (event.keyCode) {\n            case UP_ARROW:\n              event.target.value = +event.target.value + 10;\n              break;\n            case DOWN_ARROW:\n              event.target.value = +event.target.value - 10;\n              break;\n          }\n        }\n        if (event.altKey) {\n          switch (event.keyCode) {\n            case UP_ARROW:\n              event.target.value = +event.target.value + 0.1;\n              break;\n            case DOWN_ARROW:\n              event.target.value = +event.target.value - 0.1;\n              break;\n          }\n        }\n      }\n    } catch (error) {}\n    this.delayedResize();\n  }\n\n  @HostListener('cut') oncut() {\n    try {\n      setTimeout(() => {\n        this.delayedResize();\n      }, 0);\n    } catch (error) {}\n  }\n\n  @HostListener('paste') onpaste() {\n    try {\n      setTimeout(() => {\n        this.delayedResize();\n      }, 0);\n    } catch (error) {}\n  }\n\n  @HostListener('drop') ondrop() {\n    try {\n      setTimeout(() => {\n        this.delayedResize();\n      }, 0);\n    } catch (error) {}\n  }\n\n  updateErrorMsg(value: string) {\n    if (this.wrongTextContainer) {\n      this.wrongTextContainer.innerHTML = value;\n    }\n  }\n\n  updateSuccessMsg(value: string) {\n    if (this.rightTextContainer) {\n      this.rightTextContainer.innerHTML = value;\n    }\n  }\n\n  ngOnInit() {\n    try {\n      setTimeout(() => {\n        this.delayedResize();\n      }, 0);\n    } catch (error) {\n      console.log(error);\n    }\n\n    // Inititalise a new <span> wrong/right elements and render it below the host component.\n    if (this.mdbValidate) {\n      this.wrongTextContainer = this._renderer.createElement('span');\n      this._renderer.addClass(this.wrongTextContainer, 'inputVal');\n      this._renderer.addClass(this.wrongTextContainer, 'text-danger');\n      this._renderer.appendChild(this._elRef.nativeElement.parentElement, this.wrongTextContainer);\n      const textWrong = this._elRef.nativeElement.getAttribute('data-error');\n      this.wrongTextContainer.innerHTML = textWrong ? textWrong : 'wrong';\n      if (!textWrong && this.errorMessage !== undefined) {\n        this.wrongTextContainer.innerHTML = this.errorMessage;\n      }\n      this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'hidden');\n\n      this.rightTextContainer = this._renderer.createElement('span');\n      this._renderer.addClass(this.rightTextContainer, 'inputVal');\n      this._renderer.addClass(this.rightTextContainer, 'text-success');\n      this._renderer.appendChild(this._elRef.nativeElement.parentElement, this.rightTextContainer);\n      const textSuccess = this._elRef.nativeElement.getAttribute('data-success');\n      this.rightTextContainer.innerHTML = textSuccess ? textSuccess : 'success';\n      if (!textSuccess && this.successMessage !== undefined) {\n        this.rightTextContainer.innerHTML = this.successMessage;\n      }\n      this._renderer.setStyle(this.rightTextContainer, 'visibility', 'hidden');\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.hasOwnProperty('errorMessage')) {\n      const newErrorMsg = changes.errorMessage.currentValue;\n      this.updateErrorMsg(newErrorMsg);\n    }\n\n    if (changes.hasOwnProperty('successMessage')) {\n      const newSuccessMsg = changes.successMessage.currentValue;\n      this.updateSuccessMsg(newSuccessMsg);\n    }\n  }\n\n  ngDoCheck() {\n    if (\n      this.mdbValidate &&\n      this._elRef.nativeElement.classList.contains('ng-valid') &&\n      this._elRef.nativeElement.classList.contains('ng-dirty') &&\n      !this._elRef.nativeElement.classList.contains('counter-success')\n    ) {\n      this._renderer.addClass(this._elRef.nativeElement, 'counter-success');\n      this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'hidden');\n      this._renderer.setStyle(this.rightTextContainer, 'visibility', 'visible');\n      this._renderer.setStyle(\n        this.rightTextContainer,\n        'top',\n        this._elRef.nativeElement.offsetHeight + 'px'\n      );\n      this._renderer.setStyle(\n        this.wrongTextContainer,\n        'top',\n        this._elRef.nativeElement.offsetHeight + 'px'\n      );\n    }\n    if (\n      this.mdbValidate &&\n      this._elRef.nativeElement.classList.contains('ng-invalid') &&\n      this._elRef.nativeElement.classList.contains('ng-dirty') &&\n      !this._elRef.nativeElement.classList.contains('counter-danger')\n    ) {\n      this._renderer.addClass(this._elRef.nativeElement, 'counter-danger');\n      this._renderer.setStyle(this.rightTextContainer, 'visibility', 'hidden');\n      this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'visible');\n      this._renderer.setStyle(\n        this.rightTextContainer,\n        'top',\n        this._elRef.nativeElement.offsetHeight + 'px'\n      );\n      this._renderer.setStyle(\n        this.wrongTextContainer,\n        'top',\n        this._elRef.nativeElement.offsetHeight + 'px'\n      );\n    }\n    if (\n      (this._elRef.nativeElement.classList.contains('ng-invalid') &&\n        this._elRef.nativeElement.classList.contains('ng-pristine') &&\n        this._elRef.nativeElement.classList.contains('ng-untouched')) ||\n      this._elRef.nativeElement.disabled\n    ) {\n      if (this._elRef.nativeElement.classList.contains('counter-success')) {\n        this._renderer.removeClass(this._elRef.nativeElement, 'counter-success');\n        this._renderer.setStyle(this.rightTextContainer, 'visibility', 'hidden');\n      } else if (this._elRef.nativeElement.classList.contains('counter-danger')) {\n        this._renderer.removeClass(this._elRef.nativeElement, 'counter-danger');\n        this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'hidden');\n      }\n    }\n    if (!this.validateSuccess) {\n      this._renderer.removeClass(this._elRef.nativeElement, 'counter-success');\n      this._renderer.setStyle(this.rightTextContainer, 'display', 'none');\n      if (this._elRef.nativeElement.classList.contains('ng-valid')) {\n        this._renderer.removeClass(this._elRef.nativeElement, 'counter-danger');\n      }\n    }\n\n    if (!this.validateError) {\n      this._renderer.removeClass(this._elRef.nativeElement, 'counter-danger');\n      this._renderer.setStyle(this.wrongTextContainer, 'display', 'none');\n      if (this._elRef.nativeElement.classList.contains('ng-invalid')) {\n        this._renderer.removeClass(this._elRef.nativeElement, 'counter-success');\n      }\n    }\n  }\n\n  validationFunction() {\n    setTimeout(() => {\n      if (this._elRef.nativeElement.classList.contains('ng-invalid')) {\n        this._renderer.removeClass(this._elRef.nativeElement, 'counter-success');\n        this._renderer.removeClass(this._elRef.nativeElement, 'counter-danger');\n      }\n      if (\n        this._elRef.nativeElement.classList.contains('ng-touched') &&\n        this._elRef.nativeElement.classList.contains('ng-invalid')\n      ) {\n        if (this.mdbValidate) {\n          this._renderer.addClass(this._elRef.nativeElement, 'counter-danger');\n          this._renderer.setStyle(this.rightTextContainer, 'visibility', 'hidden');\n          this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'visible');\n          this._renderer.setStyle(\n            this.rightTextContainer,\n            'top',\n            this._elRef.nativeElement.offsetHeight + 'px'\n          );\n          this._renderer.setStyle(\n            this.wrongTextContainer,\n            'top',\n            this._elRef.nativeElement.offsetHeight + 'px'\n          );\n        }\n      } else if (\n        this._elRef.nativeElement.classList.contains('ng-touched') &&\n        this._elRef.nativeElement.classList.contains('ng-valid')\n      ) {\n        if (this.mdbValidate) {\n          this._renderer.addClass(this._elRef.nativeElement, 'counter-success');\n          this._renderer.setStyle(this.rightTextContainer, 'visibility', 'visible');\n          this._renderer.setStyle(this.wrongTextContainer, 'visibility', 'hidden');\n          this._renderer.setStyle(\n            this.rightTextContainer,\n            'top',\n            this._elRef.nativeElement.offsetHeight + 'px'\n          );\n          this._renderer.setStyle(\n            this.wrongTextContainer,\n            'top',\n            this._elRef.nativeElement.offsetHeight + 'px'\n          );\n        }\n      }\n    }, 0);\n  }\n\n  ngAfterViewInit() {\n    if (this.isBrowser) {\n      try {\n        this.element = document.querySelector('.md-textarea-auto');\n      } catch (error) {}\n    }\n    const type = this.el.nativeElement.type;\n    if (this.focusCheckbox && type === 'checkbox') {\n      this._renderer.addClass(this.el.nativeElement, 'onFocusSelect');\n    }\n    if (this.focusRadio && type === 'radio') {\n      this._renderer.addClass(this.el.nativeElement, 'onFocusSelect');\n    }\n  }\n\n  ngAfterViewChecked() {\n    this.initComponent();\n    this.checkValue();\n  }\n\n  resize() {\n    if (this.el.nativeElement.classList.contains('md-textarea-auto')) {\n      this._renderer.setStyle(this.el.nativeElement, 'height', 'auto');\n      this._renderer.setStyle(\n        this.el.nativeElement,\n        'height',\n        this.el.nativeElement.scrollHeight + 'px'\n      );\n    }\n  }\n\n  delayedResize() {\n    setTimeout(() => {\n      this.resize();\n    }, 0);\n  }\n\n  public initComponent(): void {\n    let inputId;\n    let inputP;\n    if (this.isBrowser) {\n      try {\n        inputId = this.el.nativeElement.id;\n      } catch (err) {}\n\n      try {\n        inputP = this.el.nativeElement.parentNode;\n      } catch (err) {}\n\n      this.elLabel =\n        inputP.querySelector('label[for=\"' + inputId + '\"]') || inputP.querySelector('label');\n      if (this.elLabel && this.el.nativeElement.value !== '') {\n        this._renderer.addClass(this.elLabel, 'active');\n      }\n      this.elIcon = inputP.querySelector('i') || false;\n\n      if (this.elIcon) {\n        this._renderer.addClass(this.elIcon, 'active');\n      }\n    }\n  }\n\n  private checkValue(): void {\n    let value = '';\n    if (this.elLabel != null) {\n      value = this.el.nativeElement.value || '';\n      if (value === '') {\n        this._renderer.removeClass(this.elLabel, 'active');\n        if (this.elIcon) {\n          this._renderer.removeClass(this.elIcon, 'active');\n        }\n        // tslint:disable-next-line:max-line-length\n      }\n      if (\n        (value === '' && this.isClicked) ||\n        (value === '' && this.el.nativeElement.placeholder) ||\n        (value === '' && this.el.nativeElement.attributes.placeholder)\n      ) {\n        this._renderer.addClass(this.elLabel, 'active');\n      }\n    }\n  }\n}\n"]}