import { Component, ViewChild, Injector, Output, EventEmitter, ViewEncapsulation} from '@angular/core'; import { ModalDirective } from 'ngx-bootstrap'; import {RouteStopsServiceProxy, RouteStopContactLookupTableDto } from '@shared/service-proxies/service-proxies'; import { AppComponentBase } from '@shared/common/app-component-base'; import { Table } from 'primeng/components/table/table'; import { Paginator } from 'primeng/components/paginator/paginator'; import { LazyLoadEvent } from 'primeng/components/common/lazyloadevent'; @Component({ selector: 'routeStopContactLookupTableModal', styleUrls: ['./routeStop-contact-lookup-table-modal.component.less'], encapsulation: ViewEncapsulation.None, templateUrl: './routeStop-contact-lookup-table-modal.component.html' }) export class RouteStopContactLookupTableModalComponent extends AppComponentBase { @ViewChild('createOrEditModal', { static: true }) modal: ModalDirective; @ViewChild('dataTable', { static: true }) dataTable: Table; @ViewChild('paginator', { static: true }) paginator: Paginator; filterText = ''; id: number; displayName: string; @Output() modalSave: EventEmitter = new EventEmitter(); active = false; saving = false; constructor( injector: Injector, private _routeStopsServiceProxy: RouteStopsServiceProxy ) { super(injector); } show(): void { this.active = true; this.paginator.rows = 5; this.getAll(); this.modal.show(); } getAll(event?: LazyLoadEvent) { if (!this.active) { return; } if (this.primengTableHelper.shouldResetPaging(event)) { this.paginator.changePage(0); return; } this.primengTableHelper.showLoadingIndicator(); this._routeStopsServiceProxy.getAllContactForLookupTable( this.filterText, this.primengTableHelper.getSorting(this.dataTable), this.primengTableHelper.getSkipCount(this.paginator, event), this.primengTableHelper.getMaxResultCount(this.paginator, event) ).subscribe(result => { this.primengTableHelper.totalRecordsCount = result.totalCount; this.primengTableHelper.records = result.items; this.primengTableHelper.hideLoadingIndicator(); console.log(result); }); } reloadPage(): void { this.paginator.changePage(this.paginator.getPage()); } setAndSave(contact: RouteStopContactLookupTableDto) { this.id = contact.id; this.displayName = contact.displayName; this.active = false; this.modal.hide(); this.modalSave.emit(null); } close(): void { this.active = false; this.modal.hide(); this.modalSave.emit(null); } }