import { Component, Injector, OnInit, ViewChild, ViewEncapsulation, Input, ViewChildren } from '@angular/core'; import { ActivatedRoute } from '@angular/router'; import { AppConsts } from '@shared/AppConsts'; import { appModuleAnimation } from '@shared/animations/routerTransition'; import { AppComponentBase } from '@shared/common/app-component-base'; import { ControllerDriverListDto, ControllerDriverListServiceProxy } from '@shared/service-proxies/service-proxies'; import * as moment from 'moment'; import { LazyLoadEvent } from 'primeng/components/common/lazyloadevent'; import { Paginator } from 'primeng/components/paginator/paginator'; import { Table } from 'primeng/components/table/table'; import { HttpClient } from '@angular/common/http'; import { finalize } from 'rxjs/operators'; @Component({ selector: 'driver-tab', templateUrl: './driver-list.component.html', encapsulation: ViewEncapsulation.None, // styleUrls: ['./kpi-box.component.less'], animations: [appModuleAnimation()], providers: [ControllerDriverListServiceProxy] }) export class DriverListTabComponent extends AppComponentBase implements OnInit{ @ViewChild('dataTable', {static: true}) dataTable: Table; @ViewChild('paginator', {static: true}) paginator: Paginator; @Input() filters: { locationFilter : number; }; driverName: string; constructor( injector: Injector, private _driverListService: ControllerDriverListServiceProxy ) { super(injector); } ngOnInit(): void { console.log('FILTERS'); console.log(this.filters.locationFilter); // console.log($("#locationSelectInput").val($(this).val())); // $('#locationSelectInput').on('change', function(){ // // $("#locationSelectInput").val($(this).val()); // this.filters.locationFilter = $("#locationSelectInput").val(); // }); } // filterDriversByName(event : LazyLoadEvent): void // { // if (this.primengTableHelper.shouldResetPaging(event)) { // this.paginator.changePage(0); // return; // } // this.spinnerService.show(); // this._driverListService.getControllerDriverList( // undefined, // undefined, // undefined, // this.driverName, // undefined, // this.primengTableHelper.getSorting(this.dataTable), // this.primengTableHelper.getMaxResultCount(this.paginator, event), // this.primengTableHelper.getSkipCount(this.paginator, event) // ).pipe(finalize(() => this.spinnerService.hide())).subscribe(result => { // this.primengTableHelper.totalRecordsCount = result.totalCount; // this.primengTableHelper.records = result.items; // this.spinnerService.hide(); // }); // } getDriverList(event: LazyLoadEvent): void { if (this.primengTableHelper.shouldResetPaging(event)) { this.paginator.changePage(0); return; } this.spinnerService.show(); this._driverListService.getControllerDriverList( this.filters.locationFilter, undefined, undefined, this.driverName, undefined, this.primengTableHelper.getSorting(this.dataTable), this.primengTableHelper.getMaxResultCount(this.paginator, event), this.primengTableHelper.getSkipCount(this.paginator, event) ).pipe(finalize(() => this.spinnerService.hide())).subscribe(result => { this.primengTableHelper.totalRecordsCount = result.totalCount; this.primengTableHelper.records = result.items; this.spinnerService.hide(); }); } }