{"version":3,"sources":["../../src/app/components/inputtextarea/inputtextarea.ts"],"names":["InputTextarea","el","ngModel","control","cd","this","onResize","EventEmitter","prototype","ngOnInit","_this","ngModelSubscription","valueChanges","subscribe","updateState","ngControlSubscription","ngAfterViewInit","autoResize","resize","updateFilledState","detectChanges","onInput","e","filled","nativeElement","value","length","onFocus","onBlur","event","style","height","scrollHeight","parseFloat","maxHeight","overflowY","overflow","emit","ngOnDestroy","unsubscribe","Directive","args","selector","host","[class.p-inputtextarea]","[class.p-inputtext]","[class.p-component]","[class.p-filled]","[class.p-inputtextarea-resizable]","ElementRef","NgModel","decorators","type","Optional","NgControl","ChangeDetectorRef","Input","Output","HostListener","NgModule","imports","CommonModule","exports","declarations"],"mappings":"weA6BI,SAAAA,EAAmBC,EAAmCC,EAAqCC,EAA6BC,GAArGC,KAAAJ,GAAAA,EAAmCI,KAAAH,QAAAA,EAAqCG,KAAAF,QAAAA,EAA6BE,KAAAD,GAAAA,EAV9GC,KAAAC,SAA8B,IAAIC,EAAAA,oBAY5CP,EAAAQ,UAAAC,SAAA,WAAA,IAAAC,EAAAL,KACQA,KAAKH,UACLG,KAAKM,oBAAsBN,KAAKH,QAAQU,aAAaC,WAAU,WAC3DH,EAAKI,kBAITT,KAAKF,UACLE,KAAKU,sBAAwBV,KAAKF,QAAQS,aAAaC,WAAU,WAC7DH,EAAKI,mBAKjBd,EAAAQ,UAAAQ,gBAAA,WACQX,KAAKY,YACLZ,KAAKa,SAETb,KAAKc,oBACLd,KAAKD,GAAGgB,iBAIZpB,EAAAQ,UAAAa,QAAA,SAAQC,GACJjB,KAAKS,eAGTd,EAAAQ,UAAAW,kBAAA,WACId,KAAKkB,OAASlB,KAAKJ,GAAGuB,cAAcC,OAASpB,KAAKJ,GAAGuB,cAAcC,MAAMC,QAI7E1B,EAAAQ,UAAAmB,QAAA,SAAQL,GACAjB,KAAKY,YACLZ,KAAKa,OAAOI,IAKpBtB,EAAAQ,UAAAoB,OAAA,SAAON,GACCjB,KAAKY,YACLZ,KAAKa,OAAOI,IAIpBtB,EAAAQ,UAAAU,OAAA,SAAOW,GACHxB,KAAKJ,GAAGuB,cAAcM,MAAMC,OAAS,OACrC1B,KAAKJ,GAAGuB,cAAcM,MAAMC,OAAS1B,KAAKJ,GAAGuB,cAAcQ,aAAe,KAEtEC,WAAW5B,KAAKJ,GAAGuB,cAAcM,MAAMC,SAAWE,WAAW5B,KAAKJ,GAAGuB,cAAcM,MAAMI,YACzF7B,KAAKJ,GAAGuB,cAAcM,MAAMK,UAAY,SACxC9B,KAAKJ,GAAGuB,cAAcM,MAAMC,OAAS1B,KAAKJ,GAAGuB,cAAcM,MAAMI,WAGjE7B,KAAKJ,GAAGuB,cAAcM,MAAMM,SAAW,SAG3C/B,KAAKC,SAAS+B,KAAKR,GAAO,KAG9B7B,EAAAQ,UAAAM,YAAA,WACIT,KAAKc,oBAEDd,KAAKY,YACLZ,KAAKa,UAIblB,EAAAQ,UAAA8B,YAAA,WACQjC,KAAKM,qBACLN,KAAKM,oBAAoB4B,cAGzBlC,KAAKU,uBACLV,KAAKU,sBAAsBwB,wCApGtCC,EAAAA,UAASC,KAAA,CAAC,CACPC,SAAU,mBACVC,KAAM,CACFC,0BAA2B,OAC3BC,sBAAuB,OACvBC,sBAAuB,OACvBC,mBAAoB,SACpBC,oCAAqC,2DAZlBC,EAAAA,kBACnBC,EAAAA,QAAOC,WAAA,CAAA,CAAAC,KA4ByBC,EAAAA,kBA5BvBC,EAAAA,UAASH,WAAA,CAAA,CAAAC,KA4BmDC,EAAAA,kBA7B6CE,EAAAA,yDAiBrHC,EAAAA,wBAEAC,EAAAA,wBAkCAC,EAAAA,aAAYjB,KAAA,CAAC,QAAS,CAAC,4BASvBiB,EAAAA,aAAYjB,KAAA,CAAC,QAAS,CAAC,2BAOvBiB,EAAAA,aAAYjB,KAAA,CAAC,OAAQ,CAAC,oBA8C3B,iCALCkB,EAAAA,SAAQlB,KAAA,CAAC,CACNmB,QAAS,CAACC,EAAAA,cACVC,QAAS,CAAC9D,GACV+D,aAAc,CAAC/D","sourcesContent":["import {NgModule,Directive,ElementRef,HostListener,Input,Output, EventEmitter,Optional, AfterViewInit, OnInit, OnDestroy, ChangeDetectorRef} from '@angular/core';\nimport {NgModel, NgControl} from '@angular/forms';\nimport {CommonModule} from '@angular/common';\nimport { Subscription } from 'rxjs';\n\n@Directive({\n selector: '[pInputTextarea]',\n host: {\n '[class.p-inputtextarea]': 'true',\n '[class.p-inputtext]': 'true',\n '[class.p-component]': 'true',\n '[class.p-filled]': 'filled',\n '[class.p-inputtextarea-resizable]': 'autoResize'\n }\n})\nexport class InputTextarea implements OnInit, AfterViewInit, OnDestroy {\n \n @Input() autoResize: boolean;\n \n @Output() onResize: EventEmitter = new EventEmitter();\n \n filled: boolean;\n\n cachedScrollHeight:number;\n\n ngModelSubscription: Subscription;\n\n ngControlSubscription: Subscription;\n\n constructor(public el: ElementRef, @Optional() public ngModel: NgModel, @Optional() public control : NgControl, private cd: ChangeDetectorRef) {}\n \n ngOnInit() {\n if (this.ngModel) {\n this.ngModelSubscription = this.ngModel.valueChanges.subscribe(() =>{\n this.updateState();\n })\n }\n\n if (this.control) {\n this.ngControlSubscription = this.control.valueChanges.subscribe(() => {\n this.updateState();\n });\n }\n }\n\n ngAfterViewInit() {\n if (this.autoResize)\n this.resize();\n\n this.updateFilledState();\n this.cd.detectChanges();\n }\n\n @HostListener('input', ['$event'])\n onInput(e) {\n this.updateState();\n }\n \n updateFilledState() {\n this.filled = this.el.nativeElement.value && this.el.nativeElement.value.length;\n }\n \n @HostListener('focus', ['$event'])\n onFocus(e) {\n if (this.autoResize) {\n this.resize(e);\n }\n }\n \n @HostListener('blur', ['$event'])\n onBlur(e) {\n if (this.autoResize) {\n this.resize(e);\n }\n }\n \n resize(event?: Event) {\n this.el.nativeElement.style.height = 'auto';\n this.el.nativeElement.style.height = this.el.nativeElement.scrollHeight + 'px';\n\n if (parseFloat(this.el.nativeElement.style.height) >= parseFloat(this.el.nativeElement.style.maxHeight)) {\n this.el.nativeElement.style.overflowY = \"scroll\";\n this.el.nativeElement.style.height = this.el.nativeElement.style.maxHeight;\n }\n else {\n this.el.nativeElement.style.overflow = \"hidden\";\n }\n\n this.onResize.emit(event||{});\n }\n\n updateState() {\n this.updateFilledState();\n \n if (this.autoResize) {\n this.resize();\n }\n }\n\n ngOnDestroy() {\n if (this.ngModelSubscription) {\n this.ngModelSubscription.unsubscribe();\n }\n\n if (this.ngControlSubscription) {\n this.ngControlSubscription.unsubscribe();\n }\n }\n}\n\n@NgModule({\n imports: [CommonModule],\n exports: [InputTextarea],\n declarations: [InputTextarea]\n})\nexport class InputTextareaModule { }\n"]}