From 7def306ec640ca89ee5c857b91470c707dbfdd37 Mon Sep 17 00:00:00 2001
From: Alex ORLUC <alex.orluc@maarch.org>
Date: Thu, 6 Aug 2020 18:24:51 +0200
Subject: [PATCH] FEAT #14454 TIME 0:10 save filters param admin

---
 .../administration/administration.service.ts  |  6 ++++
 .../parameters-administration.component.html  |  5 ++--
 .../parameters-administration.component.ts    | 29 +++++--------------
 3 files changed, 15 insertions(+), 25 deletions(-)

diff --git a/src/frontend/app/administration/administration.service.ts b/src/frontend/app/administration/administration.service.ts
index 46e3cf30b2c..72daf820426 100644
--- a/src/frontend/app/administration/administration.service.ts
+++ b/src/frontend/app/administration/administration.service.ts
@@ -65,6 +65,12 @@ export class AdministrationService {
             page: 0,
             field: ''
         },
+        admin_parameters: {
+            sort: 'id',
+            sortDirection: 'asc',
+            page: 0,
+            field: ''
+        },
     };
     dataSource: MatTableDataSource<any>;
     filterColumns: string[];
diff --git a/src/frontend/app/administration/parameter/parameters-administration.component.html b/src/frontend/app/administration/parameter/parameters-administration.component.html
index da0cfc8c56e..f7c6d51e2b1 100755
--- a/src/frontend/app/administration/parameter/parameters-administration.component.html
+++ b/src/frontend/app/administration/parameter/parameters-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 [formControl]="adminService.getFilterField()" placeholder="{{lang.filterBy}}">
                             </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 matSortDisableClear>
                         <ng-container matColumnDef="id">
                             <mat-header-cell *matHeaderCellDef mat-sort-header>{{lang.id}}</mat-header-cell>
                             <mat-cell *matCellDef="let element">
diff --git a/src/frontend/app/administration/parameter/parameters-administration.component.ts b/src/frontend/app/administration/parameter/parameters-administration.component.ts
index 56c002f96ca..752f03281ef 100755
--- a/src/frontend/app/administration/parameter/parameters-administration.component.ts
+++ b/src/frontend/app/administration/parameter/parameters-administration.component.ts
@@ -5,9 +5,9 @@ import { NotificationService } from '../../../service/notification/notification.
 import { HeaderService } from '../../../service/header.service';
 import { MatPaginator } from '@angular/material/paginator';
 import { MatSort } from '@angular/material/sort';
-import { MatTableDataSource } from '@angular/material/table';
 import { AppService } from '../../../service/app.service';
 import { FunctionsService } from '../../../service/functions.service';
+import { AdministrationService } from '../administration.service';
 
 @Component({
     templateUrl: 'parameters-administration.component.html'
@@ -23,29 +23,21 @@ export class ParametersAdministrationComponent implements OnInit {
     loading: boolean = false;
 
     displayedColumns = ['id', 'description', 'value', 'actions'];
-    dataSource: any;
+    filterColumns = ['id', 'description', 'value'];
+
     @ViewChild(MatPaginator, { static: false }) paginator: MatPaginator;
     @ViewChild(MatSort, { static: false }) sort: MatSort;
 
-
     constructor(
         public http: HttpClient,
         private notify: NotificationService,
         private headerService: HeaderService,
         public appService: AppService,
         public functions: FunctionsService,
+        public adminService: AdministrationService,
         private viewContainerRef: ViewContainerRef
     ) { }
 
-    applyFilter(filterValue: string) {
-        filterValue = filterValue.trim(); // Remove whitespace
-        filterValue = filterValue.toLowerCase(); // MatTableDataSource defaults to lowercase matches
-        this.dataSource.filter = filterValue;
-        this.dataSource.filterPredicate = (template: any, filter: string) => {
-            return this.functions.filterUnSensitive(template, filter, ['id', 'description', 'value']);
-        };
-    }
-
     ngOnInit(): void {
         this.headerService.setHeader(this.lang.administration + ' ' + this.lang.parameters);
 
@@ -56,15 +48,10 @@ export class ParametersAdministrationComponent implements OnInit {
         this.http.get('../rest/parameters')
             .subscribe((data: any) => {
                 this.parameters = data.parameters;
-
+                this.loading = false;
                 setTimeout(() => {
-                    this.dataSource = new MatTableDataSource(this.parameters);
-                    this.dataSource.sortingDataAccessor = this.functions.listSortingDataAccessor;
-                    this.dataSource.paginator = this.paginator;
-                    this.dataSource.sort = this.sort;
+                    this.adminService.setDataSource('admin_parameters', this.parameters, this.sort, this.paginator, this.filterColumns);
                 }, 0);
-
-                this.loading = false;
             });
     }
 
@@ -75,9 +62,7 @@ export class ParametersAdministrationComponent implements OnInit {
             this.http.delete('../rest/parameters/' + paramId)
                 .subscribe((data: any) => {
                     this.parameters = data.parameters;
-                    this.dataSource = new MatTableDataSource(this.parameters);
-                    this.dataSource.paginator = this.paginator;
-                    this.dataSource.sort = this.sort;
+                    this.adminService.setDataSource('admin_parameters', this.parameters, this.sort, this.paginator, this.filterColumns);
                     this.notify.success(this.lang.parameterDeleted);
                 }, (err) => {
                     this.notify.error(err.error.errors);
-- 
GitLab