diff --git a/src/frontend/app/administration/action/actions-administration.component.html b/src/frontend/app/administration/action/actions-administration.component.html index c9604ddd0c9b6327db9e7d8a288dee369e70f245..5a5e62ed5c60565017697ad27361ca4e7765604e 100755 --- a/src/frontend/app/administration/action/actions-administration.component.html +++ b/src/frontend/app/administration/action/actions-administration.component.html @@ -32,8 +32,7 @@ <div class="row"> <div class="col-md-6 col-xs-6"> <mat-form-field> - <input matInput (keyup)="applyFilter($event.target.value)" - placeholder="{{lang.filterBy}}"> + <input matInput placeholder="{{lang.filterBy}}" [formControl]="adminService.getFilterField()"> </mat-form-field> </div> <div class="col-md-6 col-xs-6"> @@ -41,7 +40,7 @@ </mat-paginator> </div> </div> - <mat-table #table [dataSource]="dataSource" matSort matSortActive="id" matSortDirection="asc"> + <mat-table #table [dataSource]="adminService.getDataSource()" matSort [matSortActive]="adminService.getFilter('admin_actions', 'sort')" [matSortDirection]="adminService.getFilter('admin_actions', 'sortDirection')"> <ng-container matColumnDef="id"> <mat-header-cell *matHeaderCellDef mat-sort-header [class.hide-for-mobile]="appService.getViewMode()">{{lang.id}}</mat-header-cell> diff --git a/src/frontend/app/administration/action/actions-administration.component.ts b/src/frontend/app/administration/action/actions-administration.component.ts index 142f30ee412a2a509c91c6150c09878d163fbea5..5b340526ab39816715f0de146c65031a3419f108 100755 --- a/src/frontend/app/administration/action/actions-administration.component.ts +++ b/src/frontend/app/administration/action/actions-administration.component.ts @@ -5,10 +5,10 @@ import { NotificationService } from '../../../service/notification/notification. import { MatPaginator } from '@angular/material/paginator'; import { MatSidenav } from '@angular/material/sidenav'; import { MatSort } from '@angular/material/sort'; -import { MatTableDataSource } from '@angular/material/table'; import { HeaderService } from '../../../service/header.service'; import { AppService } from '../../../service/app.service'; import { FunctionsService } from '../../../service/functions.service'; +import { AdministrationService } from '../administration.service'; @Component({ templateUrl: 'actions-administration.component.html' @@ -28,24 +28,17 @@ export class ActionsAdministrationComponent implements OnInit { loading: boolean = false; displayedColumns = ['id', 'label_action', 'history', 'actions']; - dataSource = new MatTableDataSource(this.actions); + filterColumns = ['id', 'label_action']; + @ViewChild(MatPaginator, { static: false }) paginator: MatPaginator; @ViewChild(MatSort, { static: false }) sort: MatSort; - applyFilter(filterValue: string) { - filterValue = filterValue.trim(); // Remove whitespace - filterValue = filterValue.toLowerCase(); // MatTableDataSource defaults to lowercase matches - this.dataSource.filter = filterValue; - this.dataSource.filterPredicate = (template, filter: string) => { - return this.functions.filterUnSensitive(template, filter, ['id', 'label_action']); - }; - } - constructor( public http: HttpClient, private notify: NotificationService, private headerService: HeaderService, public appService: AppService, + public adminService: AdministrationService, public functions: FunctionsService, private viewContainerRef: ViewContainerRef ) { } @@ -61,12 +54,7 @@ export class ActionsAdministrationComponent implements OnInit { this.headerService.setHeader(this.lang.administration + ' ' + this.lang.actions); this.loading = false; setTimeout(() => { - this.dataSource = new MatTableDataSource(this.actions); - this.dataSource.paginator = this.paginator; - this.dataSource.sortingDataAccessor = this.functions.listSortingDataAccessor; - this.sort.active = 'id'; - this.sort.direction = 'asc'; - this.dataSource.sort = this.sort; + this.adminService.setDataSource('admin_actions', this.actions, this.sort, this.paginator, this.filterColumns); }, 0); }, (err) => { this.notify.handleErrors(err); @@ -80,11 +68,8 @@ export class ActionsAdministrationComponent implements OnInit { this.http.delete('../rest/actions/' + action.id) .subscribe((data: any) => { this.actions = data.actions; - this.dataSource = new MatTableDataSource(this.actions); - this.dataSource.paginator = this.paginator; - this.dataSource.sort = this.sort; + this.adminService.setDataSource('admin_actions', this.actions, this.sort, this.paginator, this.filterColumns); this.notify.success(this.lang.actionDeleted); - }, (err) => { this.notify.error(err.error.errors); }); diff --git a/src/frontend/app/administration/administration.service.ts b/src/frontend/app/administration/administration.service.ts index 690cef276f2cc4bbd8a493796514fcc2ce16cac0..d9b6f4690109ddb2b0cbd6585c6e4074e169e7bf 100644 --- a/src/frontend/app/administration/administration.service.ts +++ b/src/frontend/app/administration/administration.service.ts @@ -11,6 +11,8 @@ import { tap } from 'rxjs/internal/operators/tap'; import { catchError } from 'rxjs/internal/operators/catchError'; import { of } from 'rxjs/internal/observable/of'; import { NotificationService } from '../../service/notification/notification.service'; +import { FormControl } from '@angular/forms'; +import { debounceTime } from 'rxjs/operators'; @Injectable() export class AdministrationService { @@ -20,11 +22,18 @@ export class AdministrationService { sort: 'user_id', sortDirection: 'asc', page: 0, - field : '' + field: '' + }, + admin_actions: { + sort: 'id', + sortDirection: 'asc', + page: 0, + field: '' }, }; dataSource: MatTableDataSource<any>; filterColumns: string[]; + searchTerm: FormControl = new FormControl(''); constructor( private notify: NotificationService, @@ -42,12 +51,34 @@ export class AdministrationService { this.localStorage.save(`filtersAdmin_${this.headerService.user.id}`, JSON.stringify(this.filters)); } + getFilterField() { + return this.searchTerm; + } + getDataSource() { return this.dataSource; } setDataSource(adminId: string, data: any, sort: MatSort, paginator: MatPaginator, filterColumns: string[]) { + this.searchTerm = new FormControl(''); + this.searchTerm.valueChanges + .pipe( + // debounceTime(300), + // filter(value => value.length > 2), + tap((filterValue: any) => { + this.filters[adminId]['field'] = filterValue; + this.setFilter(adminId, this.filters[adminId]); + filterValue = filterValue.trim(); // Remove whitespace + filterValue = filterValue.toLowerCase(); // MatTableDataSource defaults to lowercase matches + setTimeout(() => { + this.dataSource.filter = filterValue; + }, 0); + this.dataSource.filterPredicate = (template, filter: string) => { + return this.functionsService.filterUnSensitive(template, filter, this.filterColumns); + }; + }), + ).subscribe(); this.filterColumns = filterColumns; this.dataSource = new MatTableDataSource(data); @@ -67,7 +98,7 @@ export class AdministrationService { this.dataSource.sort = sort; - this.applyFilter(adminId, this.getFilter(adminId, 'field')); + this.searchTerm.setValue(this.getFilter(adminId, 'field')); merge(sort.sortChange, paginator.page) .pipe( @@ -101,15 +132,4 @@ export class AdministrationService { return null; } } - - applyFilter(adminId: string, filterValue: string) { - this.filters[adminId]['field'] = filterValue; - this.setFilter(adminId, this.filters[adminId]); - filterValue = filterValue.trim(); // Remove whitespace - filterValue = filterValue.toLowerCase(); // MatTableDataSource defaults to lowercase matches - this.dataSource.filter = filterValue; - this.dataSource.filterPredicate = (template, filter: string) => { - return this.functionsService.filterUnSensitive(template, filter, this.filterColumns); - }; - } } diff --git a/src/frontend/app/administration/user/users-administration.component.html b/src/frontend/app/administration/user/users-administration.component.html index 8354cd380ab584ba348cb37aac7d9e3db6e9774f..9fde9b75a0ba6d7d52f69988097e0f2dd18fa745 100755 --- a/src/frontend/app/administration/user/users-administration.component.html +++ b/src/frontend/app/administration/user/users-administration.component.html @@ -52,8 +52,7 @@ <div class="row"> <div class="col-md-6 col-xs-6"> <mat-form-field> - <input matInput (keyup)="adminService.applyFilter('admin_users', $event.target.value)" - placeholder="{{lang.filterBy}}" [value]="adminService.getFilter('admin_users', 'field')"> + <input matInput [formControl]="adminService.getFilterField()" placeholder="{{lang.filterBy}}"> <mat-button-toggle class="webserviceAccount" matSuffix (click)="$event.stopPropagation();toggleWebserviceAccount()" [checked]="this.withWebserviceAccount" title="{{lang.displayWebserviceAccount}}">