import {Component, Input, OnDestroy, OnInit} from "@angular/core"; import {AbstractControl} from "@angular/forms"; import {HelperFunctions} from "../../../utils/HelperFunctions.class"; export interface Option { icon?: string, iconClass?: string, value: any, label: string } @Component({ selector: '[dashboard-input]', template: ` {{option.label}} {{label}} ` }) export class InputComponent implements OnInit, OnDestroy { @Input('formInput') formControl: AbstractControl; @Input('type') type: string = 'text'; @Input('label') label: string; @Input('rows') rows: number = 3; @Input('options') options: Option[]; private initValue: any; constructor() { } ngOnInit(): void { this.initValue = HelperFunctions.copy(this.formControl.value); this.formControl.valueChanges.subscribe(value => { value = (value === '')?null:value; if(this.initValue === value) { this.formControl.markAsPristine(); } }); } ngOnDestroy(): void { } public get required(): boolean { return this.formControl && this.formControl.validator && this.formControl.validator(this.formControl) && this.formControl.validator(this.formControl).required; } stopPropagation() { if(event) { event.stopPropagation(); } } }