From f1b5610f53e3bfb5cf4e813c2f886c96d77a5cb9 Mon Sep 17 00:00:00 2001
From: Alex ORLUC <alex.orluc@maarch.org>
Date: Thu, 6 Aug 2020 09:46:22 +0200
Subject: [PATCH] FEAT #14454 TIME 0:20 save filter baskets admin

---
 .../administration/administration.service.ts  |  7 ++-
 .../baskets-administration.component.html     |  6 +--
 .../baskets-administration.component.ts       | 53 ++++++++-----------
 3 files changed, 30 insertions(+), 36 deletions(-)

diff --git a/src/frontend/app/administration/administration.service.ts b/src/frontend/app/administration/administration.service.ts
index fafbdc4d7a8..a4a44d4d414 100644
--- a/src/frontend/app/administration/administration.service.ts
+++ b/src/frontend/app/administration/administration.service.ts
@@ -12,7 +12,6 @@ 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 {
@@ -30,6 +29,12 @@ export class AdministrationService {
             page: 0,
             field: ''
         },
+        admin_baskets: {
+            sort: 'basket_id',
+            sortDirection: 'asc',
+            page: 0,
+            field: ''
+        },
     };
     dataSource: MatTableDataSource<any>;
     filterColumns: string[];
diff --git a/src/frontend/app/administration/basket/baskets-administration.component.html b/src/frontend/app/administration/basket/baskets-administration.component.html
index d8df5fccf05..f07b15cf52f 100755
--- a/src/frontend/app/administration/basket/baskets-administration.component.html
+++ b/src/frontend/app/administration/basket/baskets-administration.component.html
@@ -38,8 +38,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">
@@ -47,8 +46,7 @@
                             </mat-paginator>
                         </div>
                     </div>
-                    <mat-table #table [dataSource]="dataSource" matSort matSortActive="basket_id"
-                        matSortDirection="asc">
+                    <mat-table #table [dataSource]="adminService.getDataSource()" [matSortActive]="adminService.getFilter('sort')" [matSortDirection]="adminService.getFilter('sortDirection')" matSort>
                         <ng-container matColumnDef="basket_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/basket/baskets-administration.component.ts b/src/frontend/app/administration/basket/baskets-administration.component.ts
index 139989ca939..a5f8e7409a3 100755
--- a/src/frontend/app/administration/basket/baskets-administration.component.ts
+++ b/src/frontend/app/administration/basket/baskets-administration.component.ts
@@ -4,11 +4,13 @@ import { LANG } from '../../translate.component';
 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 { NotificationService } from '../../../service/notification/notification.service';
 import { HeaderService } from '../../../service/header.service';
 import { AppService } from '../../../service/app.service';
 import { FunctionsService } from '../../../service/functions.service';
+import { AdministrationService } from '../administration.service';
+import { catchError, tap, finalize } from 'rxjs/operators';
+import { of } from 'rxjs/internal/observable/of';
 
 @Component({
     templateUrl: 'baskets-administration.component.html'
@@ -25,18 +27,10 @@ export class BasketsAdministrationComponent implements OnInit {
     basketsOrder: any[] = [];
 
     displayedColumns = ['basket_id', 'basket_name', 'basket_desc', 'actions'];
-    dataSource: any;
+    filterColumns = ['basket_id', 'basket_name', 'basket_desc'];
 
     @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: any, filter: string) => {
-            return this.functions.filterUnSensitive(template, filter, ['basket_id', 'basket_name', 'basket_desc']);
-        };
-    }
 
     constructor(
         public http: HttpClient,
@@ -44,6 +38,7 @@ export class BasketsAdministrationComponent implements OnInit {
         private headerService: HeaderService,
         public appService: AppService,
         public functions: FunctionsService,
+        public adminService: AdministrationService,
         private viewContainerRef: ViewContainerRef
     ) { }
 
@@ -53,29 +48,32 @@ export class BasketsAdministrationComponent implements OnInit {
 
         this.loading = true;
 
+        this.getSortedBasket();
+
         this.http.get('../rest/baskets')
             .subscribe((data: any) => {
                 this.baskets = data['baskets'];
                 this.loading = false;
                 setTimeout(() => {
-                    this.http.get('../rest/sortedBaskets')
-                        .subscribe((dataSort: any) => {
-                            this.basketsOrder = dataSort['baskets'];
-                        }, (err) => {
-                            this.notify.handleErrors(err);
-                        });
-                    this.dataSource = new MatTableDataSource(this.baskets);
-                    this.dataSource.paginator = this.paginator;
-                    this.dataSource.sortingDataAccessor = this.functions.listSortingDataAccessor;
-                    this.sort.active = 'basket_id';
-                    this.sort.direction = 'asc';
-                    this.dataSource.sort = this.sort;
+                    this.adminService.setDataSource('admin_baskets', this.baskets, this.sort, this.paginator, this.filterColumns);
                 }, 0);
             }, (err) => {
                 this.notify.handleErrors(err);
             });
     }
 
+    getSortedBasket() {
+        this.http.get('../rest/sortedBaskets').pipe(
+            tap((dataSort: any) => {
+                this.basketsOrder = dataSort['baskets'];
+            }),
+            catchError((err: any) => {
+                this.notify.handleSoftErrors(err);
+                return of(false);
+            })
+        ).subscribe();
+    }
+
     delete(basket: any) {
         const r = confirm(this.lang.confirmAction + ' ' + this.lang.delete + ' « ' + basket['basket_name'] + ' »');
 
@@ -84,15 +82,8 @@ export class BasketsAdministrationComponent implements OnInit {
                 .subscribe((data: any) => {
                     this.notify.success(this.lang.basketDeleted);
                     this.baskets = data['baskets'];
-                    this.dataSource = new MatTableDataSource(this.baskets);
-                    this.dataSource.paginator = this.paginator;
-                    this.dataSource.sort = this.sort;
-                    this.http.get('../rest/sortedBaskets')
-                        .subscribe((dataSort: any) => {
-                            this.basketsOrder = dataSort['baskets'];
-                        }, (err) => {
-                            this.notify.handleErrors(err);
-                        });
+                    this.adminService.setDataSource('admin_baskets', this.baskets, this.sort, this.paginator, this.filterColumns);
+                    this.getSortedBasket();
                 }, (err: any) => {
                     this.notify.error(err.error.errors);
                 });
-- 
GitLab