@one-paragon/angular-utilities 0.1.37 → 0.1.38
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/table-builder/classes/GenericTableDataSource.mjs +3 -5
- package/esm2022/table-builder/classes/TableState.mjs +5 -5
- package/esm2022/table-builder/classes/table-builder-general-settings.mjs +3 -3
- package/esm2022/table-builder/classes/table-store.mjs +12 -7
- package/esm2022/table-builder/components/column-builder/column-builder.component.mjs +3 -3
- package/esm2022/table-builder/components/sort-menu/sort-menu.component-store.mjs +3 -2
- package/esm2022/table-builder/components/sort-menu/sort-menu.component.mjs +1 -1
- package/esm2022/table-builder/directives/custom-cell-directive.mjs +1 -1
- package/esm2022/table-builder/directives/multi-sort.directive.mjs +15 -3
- package/esm2022/table-builder/interfaces/report-def.mjs +1 -1
- package/fesm2022/one-paragon-angular-utilities.mjs +71 -56
- package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -1
- package/package.json +1 -1
- package/table-builder/classes/GenericTableDataSource.d.ts +0 -3
- package/table-builder/classes/TableState.d.ts +3 -3
- package/table-builder/classes/table-builder-general-settings.d.ts +3 -3
- package/table-builder/classes/table-store.d.ts +3 -3
- package/table-builder/components/sort-menu/sort-menu.component-store.d.ts +2 -2
- package/table-builder/interfaces/report-def.d.ts +5 -0
|
@@ -73,4 +73,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
73
73
|
type: Component,
|
|
74
74
|
args: [{ selector: 'tb-sort-menu', providers: [SortMenuComponentStore], template: "<ng-container *ngrxLet=\"dirty$ as dirty\">\n<ng-container *ngIf=\"sorted$ | async as sorted\">\n <ng-container *ngIf=\"notSorted$ | async as notSorted\">\n <!-- Menu Trigger -->\n <span matTooltip=\"Sort\">\n <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n <mat-icon color=\"primary\">swap_vert</mat-icon>\n </button>\n </span>\n\n <!-- Menu -->\n <mat-menu #menu=\"matMenu\" class=\"my-mat-menu\" (closed)=\"reset()\">\n <div mat-menu-item class=\"menu-button\">\n <div class=\"close-button-wrapper\">\n <span matTooltip=\"Close\">\n <mat-icon>close</mat-icon>\n </span>\n <span *ngIf=\"dirty\" matTooltip=\"Undo\" stop-propagation (click)=\"reset()\">\n <mat-icon>undo</mat-icon>\n </span>\n </div>\n </div>\n\n <!-- Apply Button -->\n <div class=\"apply-button-wrapper\">\n <button mat-button color=\"primary\" (click)=\"apply(null)\"\n stop-propagation [class.apply-border]=\"dirty\"\n [disabled]=\"!dirty\">\n Apply\n <ng-container *ngIf=\"dirty\">Unsaved Changes</ng-container>\n </button>\n </div>\n\n <!-- Default Sorting Text -->\n <div *ngIf=\"!sorted.length\" class=\"tip\" >\n Sorting List\n </div>\n\n <!-- Sorted Menu List -->\n <div class=\"list\"\n cdkDropList\n #sortedGroup=\"cdkDropList\"\n [cdkDropListConnectedTo]=\"[notSortedGroup]\"\n [cdkDropListData]=\"sorted\"\n (cdkDropListDropped)=\"dropIntoSorted($event)\">\n\n <!-- Menu Item Wrapper -->\n <ng-container *ngFor=\"let sort of sorted;let i=index\">\n\n <!-- Menu Item Headers -->\n <span *ngIf=\"sorted.length > 1 && i === 0 \" class=\"description\" class=\"sort-header\">First By</span>\n <span *ngIf=\"sorted.length > 1 && i !== 0 \" class=\"description\" class=\"sort-header\">Then By</span>\n\n <!-- Menu Item -->\n <div mat-menu-item cdkDrag class=\"menu-item\">\n <div class=\"sort-item\">\n <span class=\"sorted-name\">\n {{sort.displayName || (sort.active | spaceCase)}}\n <span class=\"direction-text\">{{sort.direction}}</span>\n </span>\n\n <!-- Sort Direction Buttons -->\n <div class=\"up-down-buttons-wrapper\">\n <button class=\"up-down-button up-button\" stop-propagation\n (click)=\"setDirection({active:sort.active,direction:SortDirection.asc,displayName:sort.displayName})\">\n <mat-icon [ngClass]=\"sort.direction !== SortDirection.asc ? 'light-arrow' : 'dark-arrow'\" class=\"up-down-icon\">\n arrow_upward\n </mat-icon>\n </button>\n\n <button class=\"up-down-button\" stop-propagation\n (click)=\"setDirection({active:sort.active,direction:SortDirection.desc,displayName:sort.displayName})\">\n <mat-icon [ngClass]=\"sort.direction === SortDirection.asc ? 'light-arrow' : 'dark-arrow'\" class=\"up-down-icon\">\n arrow_downward\n </mat-icon>\n </button>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n\n <!-- Default Not Sorted Text -->\n <div *ngIf=\"!notSorted.length\" class=\"tip\" >\n Not Sorted List\n </div>\n <!-- Not Sorted Menu List -->\n <div class=\"list\"\n cdkDropList\n #notSortedGroup=\"cdkDropList\"\n [cdkDropListConnectedTo]=\"[sortedGroup]\"\n [cdkDropListData]=\"notSorted\"\n (cdkDropListDropped)=\"dropIntoNotSorted($event)\">\n <div mat-menu-item *ngFor=\"let sort of notSorted\" class=\"menu-item\" cdkDrag>\n <span class=\"not-sorted-name\">{{sort.displayName || (sort.active | spaceCase)}}</span>\n </div>\n </div>\n </mat-menu>\n </ng-container>\n</ng-container>\n</ng-container>\n", styles: [".cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.list{padding:5px 2px;border-bottom:solid 1px #ccc;color:#000000de;background:white}.light-arrow{color:#93b1ea78}.dark-arrow{color:#224e9c}.up-down-button{background-color:#fff;border-radius:30%;border-color:#0ff;padding:1px 1px 0;border-width:.5px;cursor:pointer;height:27px}.mat-icon.up-down-icon{margin-right:0;font-size:20px;font-weight:lighter}.sort-item{display:flex;align-items:center;justify-content:space-between}.up-down-buttons-wrapper{margin-left:2rem}.up-button{margin-right:.3rem}.mat-mdc-menu-item.menu-item,.mat-mdc-menu-item.menu-button{min-height:initial;padding:0 3px;line-height:25px;height:30px}.mat-mdc-menu-item.menu-item{cursor:move}.sorted-name{color:#224e9c;font-size:17px;font-weight:700}.not-sorted-name{color:#93b1ea;font-size:17px;font-weight:700}.apply-border{border:#224e9c solid .5px}.apply-border:hover{background-color:#faebd7}.apply-button-wrapper{display:grid;justify-content:center}.sort-header{font-size:10px;font-style:italic}.tip{padding:0 3px;color:#d3d3d3}.direction-text{font-size:small;font-weight:400}.close-button-wrapper{display:flex;flex-direction:row-reverse}\n"] }]
|
|
75
75
|
}], ctorParameters: function () { return [{ type: i1.TableStore }, { type: i2.SortMenuComponentStore }]; } });
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/sort-menu/sort-menu.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/sort-menu/sort-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\r\nimport { Component, OnInit } from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { Observable } from 'rxjs';\r\nimport { first, map, tap } from 'rxjs/operators';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { SortDirection } from '../../interfaces/report-def';\r\nimport { SortMenuComponentStore, SortWithName } from './sort-menu.component-store'\r\n\r\n@Component({\r\n  selector: 'tb-sort-menu',\r\n  templateUrl: './sort-menu.component.html',\r\n  styleUrls: ['./sort-menu.component.scss'],\r\n  providers:[SortMenuComponentStore]\r\n})\r\nexport class SortMenuComponent implements OnInit{\r\n\r\n  sorted$:Observable<SortWithName[]>;\r\n  notSorted$:Observable<SortWithName[]>;\r\n  SortDirection = SortDirection;\r\n  dirty$ = new BehaviorSubject(false);\r\n  constructor(private tableState: TableStore, public store: SortMenuComponentStore) {\r\n    this.sorted$=this.store.sorted$.pipe(map(data=>[...data]));\r\n    this.notSorted$=this.store.notSorted$.pipe(map(data=>[...data]));\r\n  }\r\n\r\n  reset(){\r\n    this.dirty$.next(false);\r\n    this.store.reset();\r\n  }\r\n\r\n  ngOnInit(){\r\n    this.store.reset();\r\n  }\r\n\r\n  dropIntoSorted(event: CdkDragDrop<SortWithName[]>) {\r\n    this.dirty$.next(true);\r\n    if (event.previousContainer === event.container) {\r\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\r\n      this.store.setSorted(event.container.data);\r\n    } else {\r\n\r\n      transferArrayItem(event.previousContainer.data,\r\n                        event.container.data,\r\n                        event.previousIndex,\r\n                        event.currentIndex);\r\n      event.container.data[event.currentIndex] = {...event.container.data[event.currentIndex],direction:SortDirection.asc};\r\n      this.store.setSorted(event.container.data);\r\n      this.store.setNotSorted(event.previousContainer.data);\r\n    }\r\n  }\r\n\r\n  dropIntoNotSorted(event: CdkDragDrop<SortWithName[]>){\r\n    if (event.previousContainer === event.container) {\r\n      return;\r\n    } else {\r\n      this.dirty$.next(true);\r\n      transferArrayItem(event.previousContainer.data,\r\n                        event.container.data,\r\n                        event.previousIndex,\r\n                        event.currentIndex);\r\n      event.container.data[event.currentIndex] = {...event.container.data[event.currentIndex]};\r\n\r\n      this.store.setNotSorted(event.container.data);\r\n      this.store.setSorted(event.previousContainer.data);\r\n    }\r\n  }\r\n\r\n  apply = this.store.effect((obs:Observable<null>)=>\r\n    obs.pipe(tap(()=>{\r\n      this.dirty$.next(false);\r\n      this.tableState.setAllSort(this.store.sorted$.pipe(first()))\r\n  })));\r\n\r\n  setDirection(sort:SortWithName){\r\n    this.dirty$.next(true);\r\n    this.store.setDirection(sort);\r\n  }\r\n\r\n}\r\n\r\n\r\n","<ng-container *ngrxLet=\"dirty$ as dirty\">\n<ng-container  *ngIf=\"sorted$ | async as sorted\">\n  <ng-container *ngIf=\"notSorted$ | async as notSorted\">\n    <!-- Menu Trigger -->\n    <span matTooltip=\"Sort\">\n      <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n        <mat-icon color=\"primary\">swap_vert</mat-icon>\n      </button>\n    </span>\n\n    <!-- Menu -->\n    <mat-menu #menu=\"matMenu\"  class=\"my-mat-menu\" (closed)=\"reset()\">\n      <div mat-menu-item class=\"menu-button\">\n        <div class=\"close-button-wrapper\">\n          <span matTooltip=\"Close\">\n            <mat-icon>close</mat-icon>\n          </span>\n          <span *ngIf=\"dirty\" matTooltip=\"Undo\" stop-propagation (click)=\"reset()\">\n            <mat-icon>undo</mat-icon>\n          </span>\n        </div>\n      </div>\n\n      <!-- Apply Button -->\n      <div class=\"apply-button-wrapper\">\n        <button mat-button color=\"primary\" (click)=\"apply(null)\"\n          stop-propagation [class.apply-border]=\"dirty\"\n          [disabled]=\"!dirty\">\n            Apply\n            <ng-container *ngIf=\"dirty\">Unsaved Changes</ng-container>\n        </button>\n      </div>\n\n      <!-- Default Sorting Text -->\n      <div *ngIf=\"!sorted.length\" class=\"tip\" >\n        Sorting List\n      </div>\n\n      <!-- Sorted Menu List -->\n      <div class=\"list\"\n        cdkDropList\n        #sortedGroup=\"cdkDropList\"\n        [cdkDropListConnectedTo]=\"[notSortedGroup]\"\n        [cdkDropListData]=\"sorted\"\n        (cdkDropListDropped)=\"dropIntoSorted($event)\">\n\n        <!-- Menu Item Wrapper -->\n        <ng-container *ngFor=\"let sort of sorted;let i=index\">\n\n          <!-- Menu Item Headers -->\n          <span *ngIf=\"sorted.length > 1 && i === 0 \" class=\"description\" class=\"sort-header\">First By</span>\n          <span *ngIf=\"sorted.length > 1 && i !== 0 \" class=\"description\"  class=\"sort-header\">Then By</span>\n\n          <!-- Menu Item -->\n          <div mat-menu-item   cdkDrag class=\"menu-item\">\n            <div class=\"sort-item\">\n              <span class=\"sorted-name\">\n                {{sort.displayName || (sort.active | spaceCase)}}\n                <span class=\"direction-text\">{{sort.direction}}</span>\n              </span>\n\n              <!-- Sort Direction Buttons -->\n              <div class=\"up-down-buttons-wrapper\">\n                <button  class=\"up-down-button up-button\" stop-propagation\n                (click)=\"setDirection({active:sort.active,direction:SortDirection.asc,displayName:sort.displayName})\">\n                  <mat-icon [ngClass]=\"sort.direction !== SortDirection.asc ? 'light-arrow' : 'dark-arrow'\" class=\"up-down-icon\">\n                  arrow_upward\n                  </mat-icon>\n                </button>\n\n                <button class=\"up-down-button\" stop-propagation\n                (click)=\"setDirection({active:sort.active,direction:SortDirection.desc,displayName:sort.displayName})\">\n                  <mat-icon [ngClass]=\"sort.direction === SortDirection.asc ? 'light-arrow' : 'dark-arrow'\" class=\"up-down-icon\">\n                    arrow_downward\n                  </mat-icon>\n                </button>\n              </div>\n            </div>\n          </div>\n        </ng-container>\n      </div>\n\n      <!-- Default Not Sorted Text -->\n      <div *ngIf=\"!notSorted.length\" class=\"tip\" >\n        Not Sorted List\n      </div>\n      <!-- Not Sorted Menu List -->\n      <div class=\"list\"\n        cdkDropList\n        #notSortedGroup=\"cdkDropList\"\n        [cdkDropListConnectedTo]=\"[sortedGroup]\"\n        [cdkDropListData]=\"notSorted\"\n        (cdkDropListDropped)=\"dropIntoNotSorted($event)\">\n        <div mat-menu-item *ngFor=\"let sort of notSorted\"  class=\"menu-item\" cdkDrag>\n          <span class=\"not-sorted-name\">{{sort.displayName || (sort.active | spaceCase)}}</span>\n        </div>\n      </div>\n    </mat-menu>\n  </ng-container>\n</ng-container>\n</ng-container>\n"]}
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/sort-menu/sort-menu.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/sort-menu/sort-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\r\nimport { Component, OnInit } from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { Observable } from 'rxjs';\r\nimport { first, map, tap } from 'rxjs/operators';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { SortDirection } from '../../interfaces/report-def';\r\nimport { SortMenuComponentStore, SortWithName } from './sort-menu.component-store'\r\n\r\n@Component({\r\n  selector: 'tb-sort-menu',\r\n  templateUrl: './sort-menu.component.html',\r\n  styleUrls: ['./sort-menu.component.scss'],\r\n  providers:[SortMenuComponentStore]\r\n})\r\nexport class SortMenuComponent implements OnInit{\r\n\r\n  sorted$:Observable<SortWithName[]>;\r\n  notSorted$:Observable<SortWithName[]>;\r\n  SortDirection = SortDirection;\r\n  dirty$ = new BehaviorSubject(false);\r\n  constructor(private tableState: TableStore, public store: SortMenuComponentStore) {\r\n    this.sorted$ = this.store.sorted$.pipe(map(data=>[...data]));\r\n    this.notSorted$ = this.store.notSorted$.pipe(map(data=>[...data]));\r\n  }\r\n\r\n  reset(){\r\n    this.dirty$.next(false);\r\n    this.store.reset();\r\n  }\r\n\r\n  ngOnInit(){\r\n    this.store.reset();\r\n  }\r\n\r\n  dropIntoSorted(event: CdkDragDrop<SortWithName[]>) {\r\n    this.dirty$.next(true);\r\n    if (event.previousContainer === event.container) {\r\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\r\n      this.store.setSorted(event.container.data);\r\n    } else {\r\n\r\n      transferArrayItem(event.previousContainer.data,\r\n                        event.container.data,\r\n                        event.previousIndex,\r\n                        event.currentIndex);\r\n      event.container.data[event.currentIndex] = {...event.container.data[event.currentIndex],direction:SortDirection.asc};\r\n      this.store.setSorted(event.container.data);\r\n      this.store.setNotSorted(event.previousContainer.data);\r\n    }\r\n  }\r\n\r\n  dropIntoNotSorted(event: CdkDragDrop<SortWithName[]>){\r\n    if (event.previousContainer === event.container) {\r\n      return;\r\n    } else {\r\n      this.dirty$.next(true);\r\n      transferArrayItem(event.previousContainer.data,\r\n                        event.container.data,\r\n                        event.previousIndex,\r\n                        event.currentIndex);\r\n      event.container.data[event.currentIndex] = {...event.container.data[event.currentIndex]};\r\n\r\n      this.store.setNotSorted(event.container.data);\r\n      this.store.setSorted(event.previousContainer.data);\r\n    }\r\n  }\r\n\r\n  apply = this.store.effect((obs:Observable<null>)=>\r\n    obs.pipe(tap(()=>{\r\n      this.dirty$.next(false);\r\n      this.tableState.setAllSort(this.store.sorted$.pipe(first()))\r\n  })));\r\n\r\n  setDirection(sort:SortWithName){\r\n    this.dirty$.next(true);\r\n    this.store.setDirection(sort);\r\n  }\r\n\r\n}\r\n\r\n\r\n","<ng-container *ngrxLet=\"dirty$ as dirty\">\n<ng-container  *ngIf=\"sorted$ | async as sorted\">\n  <ng-container *ngIf=\"notSorted$ | async as notSorted\">\n    <!-- Menu Trigger -->\n    <span matTooltip=\"Sort\">\n      <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n        <mat-icon color=\"primary\">swap_vert</mat-icon>\n      </button>\n    </span>\n\n    <!-- Menu -->\n    <mat-menu #menu=\"matMenu\"  class=\"my-mat-menu\" (closed)=\"reset()\">\n      <div mat-menu-item class=\"menu-button\">\n        <div class=\"close-button-wrapper\">\n          <span matTooltip=\"Close\">\n            <mat-icon>close</mat-icon>\n          </span>\n          <span *ngIf=\"dirty\" matTooltip=\"Undo\" stop-propagation (click)=\"reset()\">\n            <mat-icon>undo</mat-icon>\n          </span>\n        </div>\n      </div>\n\n      <!-- Apply Button -->\n      <div class=\"apply-button-wrapper\">\n        <button mat-button color=\"primary\" (click)=\"apply(null)\"\n          stop-propagation [class.apply-border]=\"dirty\"\n          [disabled]=\"!dirty\">\n            Apply\n            <ng-container *ngIf=\"dirty\">Unsaved Changes</ng-container>\n        </button>\n      </div>\n\n      <!-- Default Sorting Text -->\n      <div *ngIf=\"!sorted.length\" class=\"tip\" >\n        Sorting List\n      </div>\n\n      <!-- Sorted Menu List -->\n      <div class=\"list\"\n        cdkDropList\n        #sortedGroup=\"cdkDropList\"\n        [cdkDropListConnectedTo]=\"[notSortedGroup]\"\n        [cdkDropListData]=\"sorted\"\n        (cdkDropListDropped)=\"dropIntoSorted($event)\">\n\n        <!-- Menu Item Wrapper -->\n        <ng-container *ngFor=\"let sort of sorted;let i=index\">\n\n          <!-- Menu Item Headers -->\n          <span *ngIf=\"sorted.length > 1 && i === 0 \" class=\"description\" class=\"sort-header\">First By</span>\n          <span *ngIf=\"sorted.length > 1 && i !== 0 \" class=\"description\"  class=\"sort-header\">Then By</span>\n\n          <!-- Menu Item -->\n          <div mat-menu-item   cdkDrag class=\"menu-item\">\n            <div class=\"sort-item\">\n              <span class=\"sorted-name\">\n                {{sort.displayName || (sort.active | spaceCase)}}\n                <span class=\"direction-text\">{{sort.direction}}</span>\n              </span>\n\n              <!-- Sort Direction Buttons -->\n              <div class=\"up-down-buttons-wrapper\">\n                <button  class=\"up-down-button up-button\" stop-propagation\n                (click)=\"setDirection({active:sort.active,direction:SortDirection.asc,displayName:sort.displayName})\">\n                  <mat-icon [ngClass]=\"sort.direction !== SortDirection.asc ? 'light-arrow' : 'dark-arrow'\" class=\"up-down-icon\">\n                  arrow_upward\n                  </mat-icon>\n                </button>\n\n                <button class=\"up-down-button\" stop-propagation\n                (click)=\"setDirection({active:sort.active,direction:SortDirection.desc,displayName:sort.displayName})\">\n                  <mat-icon [ngClass]=\"sort.direction === SortDirection.asc ? 'light-arrow' : 'dark-arrow'\" class=\"up-down-icon\">\n                    arrow_downward\n                  </mat-icon>\n                </button>\n              </div>\n            </div>\n          </div>\n        </ng-container>\n      </div>\n\n      <!-- Default Not Sorted Text -->\n      <div *ngIf=\"!notSorted.length\" class=\"tip\" >\n        Not Sorted List\n      </div>\n      <!-- Not Sorted Menu List -->\n      <div class=\"list\"\n        cdkDropList\n        #notSortedGroup=\"cdkDropList\"\n        [cdkDropListConnectedTo]=\"[sortedGroup]\"\n        [cdkDropListData]=\"notSorted\"\n        (cdkDropListDropped)=\"dropIntoNotSorted($event)\">\n        <div mat-menu-item *ngFor=\"let sort of notSorted\"  class=\"menu-item\" cdkDrag>\n          <span class=\"not-sorted-name\">{{sort.displayName || (sort.active | spaceCase)}}</span>\n        </div>\n      </div>\n    </mat-menu>\n  </ng-container>\n</ng-container>\n</ng-container>\n"]}
|
|
@@ -57,4 +57,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
57
57
|
}], customCellWidth: [{
|
|
58
58
|
type: Input
|
|
59
59
|
}] } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWNlbGwtZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5ndWxhci11dGlsaXRpZXMvc3JjL3RhYmxlLWJ1aWxkZXIvZGlyZWN0aXZlcy9jdXN0b20tY2VsbC1kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBZSxLQUFLLEVBQW9CLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUxRixPQUFPLEVBQXFCLFNBQVMsRUFBRSxNQUFNLDBCQUEwQixDQUFDOzs7QUFFeEUsd0JBQXdCO0FBQ3hCLG9DQUFvQztBQUNwQyxxSEFBcUg7QUFDckgsMkRBQTJEO0FBQzNELG1CQUFtQjtBQUNuQixNQUdhLG1CQUFtQjtJQU81QixZQUN1QixXQUE2QixFQUMvQixTQUF1QjtRQURyQixnQkFBVyxHQUFYLFdBQVcsQ0FBa0I7UUFDL0IsY0FBUyxHQUFULFNBQVMsQ0FBYztRQUV4QyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDdkMsQ0FBQztJQUNELGtCQUFrQjtRQUNqQixJQUFJLElBQUksQ0FBQyxXQUFXLEtBQUssSUFBSSxFQUFFO1lBQzdCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQztTQUNyQztJQUNILENBQUM7SUFFRCxXQUFXLENBQUMsUUFBb0I7UUFDOUIsT0FBTztZQUNMLEdBQUcsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUNwQixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVcsSUFBSSxRQUFRLEVBQUUsV0FBVztZQUN0RCxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sSUFBSSxRQUFRLEVBQUUsT0FBTztZQUMxQyxTQUFTLEVBQUUsUUFBUSxFQUFFLFNBQVMsSUFBSyxTQUFTLENBQUMsT0FBTztZQUNwRCxLQUFLLEVBQUUsSUFBSSxDQUFDLGVBQWUsSUFBSSxRQUFRLEVBQUUsS0FBSztZQUM5Qyx1QkFBdUIsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQztZQUN0QyxLQUFLLEVBQUUsSUFBSSxDQUFDLGVBQWUsSUFBSSxRQUFRLEVBQUUsS0FBSztZQUM5QyxVQUFVLEVBQUUsSUFBSTtZQUNoQixRQUFRLEVBQUUsQ0FBQyxRQUFRO1NBQ3BCLENBQUM7SUFDSixDQUFDOzhHQS9CUSxtQkFBbUI7a0dBQW5CLG1CQUFtQjs7U0FBbkIsbUJBQW1COzJGQUFuQixtQkFBbUI7a0JBSC9CLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGNBQWM7aUJBQzNCOzswQkFTTSxRQUFROzswQkFDUixRQUFROzRDQVJGLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFRlbXBsYXRlUmVmLCBJbnB1dCwgQWZ0ZXJDb250ZW50SW5pdCwgT3B0aW9uYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2RrQ29sdW1uRGVmIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3RhYmxlJztcclxuaW1wb3J0IHsgU29ydERlZiwgTWV0YURhdGEsIEZpZWxkVHlwZSB9IGZyb20gJy4uL2ludGVyZmFjZXMvcmVwb3J0LWRlZic7XHJcblxyXG4vLyBoZXJlIGlzIGhvdyB0byB1c2UgaXRcclxuLy8gPGdlbmVyaWMtdGFibGUgW3JlcG9ydF09XCJyZXBvcnRcIj5cclxuLy8gICAgIDxwICpjdXN0b21DZWxsPVwiJ2NvbHVtbjEnOyBsZXQgZWxlbWVudCA9IGVsZW1lbnRcIiBbY2xhc3MubWFrZU1lUmVkXT1cImVsZW1lbnQ/LnBvcnRcIj5JZiBQb3J0LCBpIHdpbGwgYmUgcmVkPC9wPlxyXG4vLyAgICAgPHAgKmN1c3RvbUNlbGw9XCInY29sdW1uMidcIj5JIGFtIGN1c3RvbSBjZWxsIHR3byA8L3A+XHJcbi8vIDwvZ2VuZXJpYy10YWJsZT5cclxuQERpcmVjdGl2ZSh7XHJcbiAgICBzZWxlY3RvcjogJ1tjdXN0b21DZWxsXScsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDdXN0b21DZWxsRGlyZWN0aXZlIGltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdCB7XHJcbiAgICBASW5wdXQoKSBjdXN0b21DZWxsITogc3RyaW5nO1xyXG4gICAgQElucHV0KCkgZGlzcGxheU5hbWU/OiBzdHJpbmc7XHJcbiAgICBASW5wdXQoKSBwcmVTb3J0PzogU29ydERlZjtcclxuICAgIEBJbnB1dCgpIFRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG4gICAgQElucHV0KCkgY3VzdG9tQ2VsbE9yZGVyPzogbnVtYmVyO1xyXG4gICAgQElucHV0KCkgY3VzdG9tQ2VsbFdpZHRoPzogc3RyaW5nO1xyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgIEBPcHRpb25hbCgpICBwcml2YXRlIHRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+LFxyXG4gICAgICBAT3B0aW9uYWwoKSBwdWJsaWMgY29sdW1uRGVmOiBDZGtDb2x1bW5EZWZcclxuICAgICAgKSB7XHJcbiAgICAgICAgdGhpcy5UZW1wbGF0ZVJlZiA9IHRoaXMudGVtcGxhdGVSZWY7XHJcbiAgICAgfVxyXG4gICAgIG5nQWZ0ZXJDb250ZW50SW5pdCgpIHtcclxuICAgICAgaWYgKHRoaXMuVGVtcGxhdGVSZWYgPT09IG51bGwpIHtcclxuICAgICAgICB0aGlzLlRlbXBsYXRlUmVmID0gdGhpcy50ZW1wbGF0ZVJlZjtcclxuICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIGdldE1ldGFEYXRhKG1ldGFEYXRhPyA6IE1ldGFEYXRhKTogTWV0YURhdGEge1xyXG4gICAgICByZXR1cm4ge1xyXG4gICAgICAgIGtleTogdGhpcy5jdXN0b21DZWxsLFxyXG4gICAgICAgIGRpc3BsYXlOYW1lOiB0aGlzLmRpc3BsYXlOYW1lID8/IG1ldGFEYXRhPy5kaXNwbGF5TmFtZSxcclxuICAgICAgICBwcmVTb3J0OiB0aGlzLnByZVNvcnQgPz8gbWV0YURhdGE/LnByZVNvcnQsXHJcbiAgICAgICAgZmllbGRUeXBlOiBtZXRhRGF0YT8uZmllbGRUeXBlID8/ICBGaWVsZFR5cGUuVW5rbm93bixcclxuICAgICAgICBvcmRlcjogdGhpcy5jdXN0b21DZWxsT3JkZXIgPz8gbWV0YURhdGE/Lm9yZGVyLFxyXG4gICAgICAgIF9pbnRlcm5hbE5vdFVzZXJEZWZpbmVkOiAhKCEhbWV0YURhdGEpLFxyXG4gICAgICAgIHdpZHRoOiB0aGlzLmN1c3RvbUNlbGxXaWR0aCA/PyBtZXRhRGF0YT8ud2lkdGgsXHJcbiAgICAgICAgY3VzdG9tQ2VsbDogdHJ1ZSxcclxuICAgICAgICBub0V4cG9ydDogIW1ldGFEYXRhXHJcbiAgICAgIH07XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -9,14 +9,15 @@ class MultiSortDirective extends MatSort {
|
|
|
9
9
|
this.state = state;
|
|
10
10
|
this.rules = [];
|
|
11
11
|
this.state.setSort(this.sortChange.pipe(map(sc => ({ key: sc.active, direction: sc.direction }))));
|
|
12
|
-
this.state.on(this.state.sorted$, rules => {
|
|
12
|
+
this.state.on(this.state.sorted$, (rules) => {
|
|
13
|
+
const oldRules = this.rules;
|
|
13
14
|
this.rules = rules;
|
|
14
15
|
if (this.active && rules.length === 0) {
|
|
15
16
|
this.active = '';
|
|
16
17
|
this.direction = '';
|
|
17
18
|
this.sortChange.emit({ active: '', direction: '' });
|
|
18
19
|
}
|
|
19
|
-
if (rules.length
|
|
20
|
+
else if (!!rules.length && isDifferent(oldRules, rules)) {
|
|
20
21
|
this.active = rules[0].active;
|
|
21
22
|
this.direction = rules[0].direction;
|
|
22
23
|
this.sortChange.emit(rules[0]);
|
|
@@ -40,4 +41,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
40
41
|
]
|
|
41
42
|
}]
|
|
42
43
|
}], ctorParameters: function () { return [{ type: i1.TableStore }]; } });
|
|
43
|
-
|
|
44
|
+
function isDifferent(a, b) {
|
|
45
|
+
if (a.length !== b.length) {
|
|
46
|
+
return true;
|
|
47
|
+
}
|
|
48
|
+
for (let i = 0; i < a.length; i++) {
|
|
49
|
+
if (a[i].active !== b[i].active || a[i].direction !== b[i].direction) {
|
|
50
|
+
return true;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return false;
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXVsdGktc29ydC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdGFibGUtYnVpbGRlci9kaXJlY3RpdmVzL211bHRpLXNvcnQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXFCLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBRSxPQUFPLEVBQVEsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQUdyQyxNQVFhLGtCQUFtQixTQUFRLE9BQU87SUFHN0MsWUFBb0IsS0FBaUI7UUFDbkMsS0FBSyxFQUFFLENBQUM7UUFEVSxVQUFLLEdBQUwsS0FBSyxDQUFZO1FBRnJDLFVBQUssR0FBVyxFQUFFLENBQUM7UUFJakIsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsTUFBTSxFQUFFLFNBQVMsRUFBRSxFQUFFLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNuRyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FDWCxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFDbEIsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUNSLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUM7WUFDNUIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7WUFDbkIsSUFBSSxJQUFJLENBQUMsTUFBTSxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO2dCQUNyQyxJQUFJLENBQUMsTUFBTSxHQUFHLEVBQUUsQ0FBQztnQkFDakIsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7Z0JBQ3BCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxTQUFTLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQzthQUNyRDtpQkFFSSxJQUFHLENBQUMsQ0FBQyxLQUFLLENBQUMsTUFBTSxJQUFJLFdBQVcsQ0FBQyxRQUFRLEVBQUUsS0FBSyxDQUFDLEVBQUU7Z0JBQ3RELElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQztnQkFDOUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO2dCQUNwQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNoQztRQUNILENBQUMsQ0FDRixDQUFDO0lBQ0osQ0FBQzs4R0F4QlUsa0JBQWtCO2tHQUFsQixrQkFBa0IsNkZBSmxCO1lBQ1QsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxrQkFBa0IsRUFBRTtTQUN0RDs7U0FFVSxrQkFBa0I7MkZBQWxCLGtCQUFrQjtrQkFSOUIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsYUFBYTtvQkFDdkIsUUFBUSxFQUFFLFdBQVc7b0JBQ3JCLE1BQU0sRUFBRSxDQUFDLDJCQUEyQixDQUFDO29CQUNyQyxTQUFTLEVBQUU7d0JBQ1QsRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLFdBQVcsb0JBQW9CLEVBQUU7cUJBQ3REO2lCQUNGOztBQTZCRCxTQUFTLFdBQVcsQ0FBQyxDQUFTLEVBQUUsQ0FBUztJQUN2QyxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLE1BQU0sRUFBRTtRQUN6QixPQUFPLElBQUksQ0FBQztLQUNiO0lBQ0QsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7UUFDakMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxFQUFFO1lBQ3BFLE9BQU8sSUFBSSxDQUFDO1NBQ2I7S0FDRjtJQUNELE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgT25Jbml0LCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0U29ydCwgU29ydCB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NvcnQnO1xyXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcbmltcG9ydCB7IFRhYmxlU3RvcmUgfSBmcm9tICcuLi9jbGFzc2VzL3RhYmxlLXN0b3JlJztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnW211bHRpU29ydF0nLFxyXG4gIGV4cG9ydEFzOiAnbXVsdGlTb3J0JyxcclxuICBpbnB1dHM6IFsnZGlzYWJsZWQ6IG1hdFNvcnREaXNhYmxlZCddLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAgeyBwcm92aWRlOiBNYXRTb3J0LCB1c2VFeGlzdGluZzogTXVsdGlTb3J0RGlyZWN0aXZlIH1cclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNdWx0aVNvcnREaXJlY3RpdmUgZXh0ZW5kcyBNYXRTb3J0IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xyXG4gIHJ1bGVzOiBTb3J0W10gPSBbXTtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdGF0ZTogVGFibGVTdG9yZSkge1xyXG4gICAgc3VwZXIoKTtcclxuICAgIHRoaXMuc3RhdGUuc2V0U29ydCh0aGlzLnNvcnRDaGFuZ2UucGlwZShtYXAoc2MgPT4gKHsga2V5OiBzYy5hY3RpdmUsIGRpcmVjdGlvbjogc2MuZGlyZWN0aW9uIH0pKSkpO1xyXG4gICAgdGhpcy5zdGF0ZS5vbihcclxuICAgICAgdGhpcy5zdGF0ZS5zb3J0ZWQkLFxyXG4gICAgICAocnVsZXMpID0+IHtcclxuICAgICAgICBjb25zdCBvbGRSdWxlcyA9IHRoaXMucnVsZXM7XHJcbiAgICAgICAgdGhpcy5ydWxlcyA9IHJ1bGVzO1xyXG4gICAgICAgIGlmICh0aGlzLmFjdGl2ZSAmJiBydWxlcy5sZW5ndGggPT09IDApIHtcclxuICAgICAgICAgIHRoaXMuYWN0aXZlID0gJyc7XHJcbiAgICAgICAgICB0aGlzLmRpcmVjdGlvbiA9ICcnO1xyXG4gICAgICAgICAgdGhpcy5zb3J0Q2hhbmdlLmVtaXQoeyBhY3RpdmU6ICcnLCBkaXJlY3Rpb246ICcnIH0pO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgZWxzZSBpZighIXJ1bGVzLmxlbmd0aCAmJiBpc0RpZmZlcmVudChvbGRSdWxlcywgcnVsZXMpKSB7XHJcbiAgICAgICAgICB0aGlzLmFjdGl2ZSA9IHJ1bGVzWzBdLmFjdGl2ZTtcclxuICAgICAgICAgIHRoaXMuZGlyZWN0aW9uID0gcnVsZXNbMF0uZGlyZWN0aW9uO1xyXG4gICAgICAgICAgdGhpcy5zb3J0Q2hhbmdlLmVtaXQocnVsZXNbMF0pO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgKTtcclxuICB9XHJcblxyXG59XHJcblxyXG5mdW5jdGlvbiBpc0RpZmZlcmVudChhOiBTb3J0W10sIGI6IFNvcnRbXSkge1xyXG4gIGlmIChhLmxlbmd0aCAhPT0gYi5sZW5ndGgpIHtcclxuICAgIHJldHVybiB0cnVlO1xyXG4gIH1cclxuICBmb3IgKGxldCBpID0gMDsgaSA8IGEubGVuZ3RoOyBpKyspIHtcclxuICAgIGlmIChhW2ldLmFjdGl2ZSAhPT0gYltpXS5hY3RpdmUgfHwgYVtpXS5kaXJlY3Rpb24gIT09IGJbaV0uZGlyZWN0aW9uKSB7XHJcbiAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgfSBcclxuICB9XHJcbiAgcmV0dXJuIGZhbHNlO1xyXG59XHJcbiJdfQ==
|
|
@@ -32,4 +32,4 @@ export var ArrayStyle;
|
|
|
32
32
|
ArrayStyle[ArrayStyle["CommaDelimited"] = 0] = "CommaDelimited";
|
|
33
33
|
ArrayStyle[ArrayStyle["NewLine"] = 1] = "NewLine";
|
|
34
34
|
})(ArrayStyle || (ArrayStyle = {}));
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0LWRlZi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL2ludGVyZmFjZXMvcmVwb3J0LWRlZi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNQSxNQUFNLENBQU4sSUFBWSxTQWVYO0FBZkQsV0FBWSxTQUFTO0lBQ2pCLCtDQUFXLENBQUE7SUFDWCx5Q0FBUSxDQUFBO0lBQ1IseUNBQVEsQ0FBQTtJQUNSLGlEQUFZLENBQUE7SUFDWixpREFBWSxDQUFBO0lBQ1osMkNBQVMsQ0FBQTtJQUNULDZDQUFVLENBQUE7SUFDViw2Q0FBVSxDQUFBO0lBQ1YsNkNBQVUsQ0FBQTtJQUNWLCtDQUFXLENBQUE7SUFDWCx3REFBZ0IsQ0FBQTtJQUNoQixzREFBZSxDQUFBO0lBQ2YsMENBQVMsQ0FBQTtJQUNULGtEQUFhLENBQUE7QUFDakIsQ0FBQyxFQWZXLFNBQVMsS0FBVCxTQUFTLFFBZXBCO0FBRUQsTUFBTSxDQUFOLElBQVksYUFHWDtBQUhELFdBQVksYUFBYTtJQUNyQiw0QkFBVSxDQUFBO0lBQ1YsOEJBQVksQ0FBQTtBQUNoQixDQUFDLEVBSFcsYUFBYSxLQUFiLGFBQWEsUUFHeEI7QUFFRCxNQUFNLENBQU4sSUFBWSxNQUtYO0FBTEQsV0FBWSxNQUFNO0lBQ2hCLDBCQUFnQixDQUFBO0lBQ2hCLHdCQUFjLENBQUE7SUFDZCw0QkFBa0IsQ0FBQTtJQUNsQixzQkFBWSxDQUFBO0FBQ2QsQ0FBQyxFQUxXLE1BQU0sS0FBTixNQUFNLFFBS2pCO0FBb0dELE1BQU0sQ0FBTixJQUFZLFVBR1g7QUFIRCxXQUFZLFVBQVU7SUFDcEIsK0RBQWMsQ0FBQTtJQUNkLGlEQUFPLENBQUE7QUFDVCxDQUFDLEVBSFcsVUFBVSxLQUFWLFVBQVUsUUFHckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaWN0aW9uYXJ5IH0gZnJvbSAnLi9kaWN0aW9uYXJ5JztcclxuaW1wb3J0IHsgUGlwZVRyYW5zZm9ybSwgUHJlZGljYXRlLCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUYWJsZUJ1aWxkZXJFeHBvcnQgfSBmcm9tICcuLi9jbGFzc2VzL1RhYmxlQnVpbGRlckNvbmZpZyc7XHJcbmltcG9ydCB7IFF1ZXJ5UGFyYW1zSGFuZGxpbmcgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5cclxuXHJcbmV4cG9ydCBlbnVtIEZpZWxkVHlwZSB7XHJcbiAgICBVbmtub3duID0gMCxcclxuICAgIERhdGUgPSAxLFxyXG4gICAgTGluayA9IDIsXHJcbiAgICBJbWFnZVVybCA9IDMsXHJcbiAgICBDdXJyZW5jeSA9IDQsXHJcbiAgICBBcnJheSA9IDUsXHJcbiAgICBIaWRkZW4gPSA2LFxyXG4gICAgTnVtYmVyID0gNyxcclxuICAgIFN0cmluZyA9IDgsXHJcbiAgICBCb29sZWFuID0gOSxcclxuICAgIFBob25lTnVtYmVyID0gMTAsXHJcbiAgICBFeHByZXNzaW9uID0gMTEsXHJcbiAgICBFbnVtID0gMTIsXHJcbiAgICBEYXRlVGltZSA9IDEzLFxyXG59XHJcblxyXG5leHBvcnQgZW51bSBTb3J0RGlyZWN0aW9uIHtcclxuICAgIGFzYz0gJ2FzYycsXHJcbiAgICBkZXNjPSAnZGVzYydcclxufVxyXG5cclxuZXhwb3J0IGVudW0gVGFyZ2V0IHtcclxuICBCbGFuayA9ICdfYmxhbmsnLFxyXG4gIFNlbGYgPSAnX3NlbGYnLFxyXG4gIFBhcmVudCA9ICdfcGFyZW50JyxcclxuICBUb3AgPSAnX3RvcCdcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBNZXRhRGF0YTxUID0gYW55LCBBZGRpdGlvbmFsRmllbGRzIGV4dGVuZHMgc3RyaW5nW10gPSBbXT4ge1xyXG4gIGtleTogKGtleW9mIFQgfCBBZGRpdGlvbmFsRmllbGRzW251bWJlcl0pICYgc3RyaW5nO1xyXG4gIGRpc3BsYXlOYW1lPzogc3RyaW5nO1xyXG4gIGZpZWxkVHlwZTogRmllbGRUeXBlO1xyXG4gIGFkZGl0aW9uYWw/OiBBZGRpdGlvbmFsPFQ+O1xyXG4gIG9yZGVyPzogbnVtYmVyO1xyXG4gIHByZVNvcnQ/OiBTb3J0RGVmO1xyXG4gIF9pbnRlcm5hbE5vdFVzZXJEZWZpbmVkPzogYm9vbGVhbjtcclxuICB3aWR0aD86IHN0cmluZztcclxuICBub0V4cG9ydD86IGJvb2xlYW47XHJcbiAgbm9GaWx0ZXI/OiBib29sZWFuO1xyXG4gIG5vU29ydD86IGJvb2xlYW47XHJcbiAgY3VzdG9tQ2VsbD86IGJvb2xlYW47XHJcbiAgdHJhbnNmb3JtPzogKChvOiBULCAuLi5hcmdzOiBhbnlbXSk9PiBhbnkpIHwgKChvOiBzdHJpbmcsIC4uLmFyZ3M6IGFueVtdKT0+IGFueSkgfCBQaXBlVHJhbnNmb3JtO1xyXG4gIGNsaWNrPzogKGVsZW1lbnQ6IFQsIGtleTogc3RyaW5nICkgPT4gdm9pZDtcclxuICB0ZW1wbGF0ZT86IFRlbXBsYXRlUmVmPGFueT47XHJcbiAgY2xhc3Nlcz86IERpY3Rpb25hcnk8UHJlZGljYXRlPFQ+PjtcclxuICB0b29sVGlwPzogc3RyaW5nO1xyXG4gIHVzZUljb24/OiBib29sZWFuO1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgIFJlcG9ydERlZjxEYXRhVHlwZSA9IGFueT4ge1xyXG4gICAgZGF0YTogRGF0YVR5cGVbXTtcclxuICAgIG1ldGFEYXRhOiBNZXRhRGF0YSBbXTtcclxuICAgIHRvdGFsUmVjb3Jkcz86IG51bWJlcjtcclxuICAgIGNvdW50OiBudW1iZXI7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgU29ydERlZiB7XHJcbiAgICBkaXJlY3Rpb246IFNvcnREaXJlY3Rpb247XHJcbiAgICBwcmVjZWRlbmNlPzogbnVtYmVyO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEZpbHRlck9wdGlvbnMge1xyXG4gIGZpbHRlcmFibGVWYWx1ZXMgOiBzdHJpbmdbXVxyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgRGF0ZVRpbWVPcHRpb25zIHtcclxuICBmb3JtYXQ/OiBzdHJpbmc7XHJcbiAgaW5jbHVkZVNlY29uZHM/OiBib29sZWFuO1xyXG4gIGluY2x1ZGVNaWxsaXNlY29uZHM6IGJvb2xlYW47XHJcbn1cclxudHlwZSBpbnRlcnBvbGF0ZWRSb3V0ZSA9IHN0cmluZztcclxuZXhwb3J0IGludGVyZmFjZSBBZGRpdGlvbmFsPFQgPSBhbnk+IHtcclxuICBsaW5rPyA6IHtcclxuICAgIGJhc2U/OiBzdHJpbmc7XHJcbiAgICB1cmxLZXk/OiBzdHJpbmc7XHJcbiAgICB0YXJnZXQ/OiBUYXJnZXQ7XHJcbiAgICB1c2VSb3V0ZXJMaW5rPzogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogSWYgeW91IHdhbnQgdG8gdXNlIGEgcm91dGUgd2l0aCBpbnRlcnBvbGF0ZWQgcGFyYW1zLCB5b3UgY2FuIHVzZSB0aGlzLiBXcmFwIHRoZSBwcm9wZXJ0eSBuYW1lIGluIGN1cmx5IGJyYWNlcy5cclxuICAgICAqIEZvciBleGFtcGxlLCBpZiBpbnRlcnBvbGF0ZWRSb3V0ZSA9IC91c2Vycy97aWR9L2VkaXQsIHtpZH0gd2lsbCBiZSByZXBsYWNlZCB3aXRoIHRoZSB2YWx1ZSBvZiB0aGUgZWxlbWVudCdzIGlkIHByb3BlcnR5LlxyXG4gICAgICovXHJcbiAgICBpbnRlcnBvbGF0ZWRSb3V0ZT86IGludGVycG9sYXRlZFJvdXRlO1xyXG4gICAgcm91dGVyTGlua09wdGlvbnM/OntcclxuICAgICAgcXVlcnlQYXJhbXM/OiBbc3RyaW5nLCBpbnRlcnBvbGF0ZWRSb3V0ZV1bXTtcclxuICAgICAgZnJhZ21lbnQ/OiBzdHJpbmc7XHJcbiAgICAgIHByZXNlcnZlRnJhZ21lbnQ/OiBib29sZWFuO1xyXG4gICAgICBxdWVyeVBhcmFtc0hhbmRsaW5nPzogUXVlcnlQYXJhbXNIYW5kbGluZztcclxuICAgIH1cclxuICB9XHJcbiAgLyoqXHJcbiAgICogQGRlcHJlY2F0ZWQgUGxlYXNlIHVzZSBsaW5rLmJhc2VcclxuICAgKi9cclxuICBiYXNlPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEBkZXByZWNhdGVkIFBsZWFzZSB1c2UgbGluay51cmxLZXlcclxuICAgKi9cclxuICB1cmxLZXk/OiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogQGRlcHJlY2F0ZWQgUGxlYXNlIHVzZSBsaW5rLnRhcmdldFxyXG4gICAqL1xyXG4gIHRhcmdldD86IFRhcmdldDtcclxuICAvKipcclxuICAgKiBAZGVwcmVjYXRlZCBQbGVhc2UgdXNlIGxpbmsudXNlUm91dGVyTGlua1xyXG4gICAqL1xyXG4gIHVzZVJvdXRlckxpbms/OiBib29sZWFuO1xyXG4gIGZvb3Rlcj86IHsgdHlwZTogJ3N1bScgfTtcclxuICBncm91cGluZz86IHsgZ3JvdXBCeT86IGJvb2xlYW4sIHN1bT86IGJvb2xlYW47IGdyb3VwVGl0bGVGbj86ICh2YWw6IGFueSkgPT4gc3RyaW5nIH1cclxuICBleHBvcnQ/OiBUYWJsZUJ1aWxkZXJFeHBvcnQ7XHJcbiAgZGF0ZUZvcm1hdD86IHN0cmluZztcclxuICBkYXRlVGltZU9wdGlvbnM/OiAgRGF0ZVRpbWVPcHRpb25zO1xyXG4gIGZpbHRlck9wdGlvbnM/OiBGaWx0ZXJPcHRpb25zO1xyXG4gIHN0eWxlcz86IERpY3Rpb25hcnk8c3RyaW5nPjtcclxuICBjb2x1bW5QYXJ0U3R5bGVzPzoge1xyXG4gICAgaGVhZGVyPzogRGljdGlvbmFyeTxzdHJpbmc+LFxyXG4gICAgYm9keT86IERpY3Rpb25hcnk8c3RyaW5nPixcclxuICAgIGZvb3Rlcj86IERpY3Rpb25hcnk8c3RyaW5nPixcclxuICB9XHJcbiAgY29sdW1uUGFydENsYXNzZXM/OiB7XHJcbiAgICBoZWFkZXI/OiBEaWN0aW9uYXJ5PFByZWRpY2F0ZTxUPj4sXHJcbiAgICBmb290ZXI/OiBEaWN0aW9uYXJ5PFByZWRpY2F0ZTxUPj4sXHJcbiAgfVxyXG4gIGVudW1NYXA/OiB7W2tleTpudW1iZXJdOnN0cmluZ307XHJcbiAgYm9vbGVhbj8gOiB7XHJcbiAgICBzaG93Rm9yRmFsc2U/IDogdHJ1ZSB8IHsgaWNvbiA6IHN0cmluZyB9LFxyXG4gICAgZm9yVHJ1ZT8gOiB7IGljb24gOiBzdHJpbmcgfVxyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGVudW0gQXJyYXlTdHlsZSB7XHJcbiAgQ29tbWFEZWxpbWl0ZWQsXHJcbiAgTmV3TGluZVxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFycmF5QWRkaXRpb25hbCBleHRlbmRzIEFkZGl0aW9uYWwge1xyXG4gICAgbWV0YURhdGE/OiBNZXRhRGF0YTtcclxuICAgIGxpbWl0PzogbnVtYmVyO1xyXG4gICAgYXJyYXlTdHlsZT86IEFycmF5U3R5bGU7XHJcbn1cclxuIl19
|
|
@@ -27,7 +27,7 @@ import { LetModule } from '@ngrx/component';
|
|
|
27
27
|
import * as i5 from '@angular/material/tooltip';
|
|
28
28
|
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
29
29
|
import * as i1$1 from '@angular/material/sort';
|
|
30
|
-
import {
|
|
30
|
+
import { MatSort, MatSortModule } from '@angular/material/sort';
|
|
31
31
|
import * as i6$1 from '@angular/material/menu';
|
|
32
32
|
import { MatMenuTrigger, MatMenuModule } from '@angular/material/menu';
|
|
33
33
|
import * as i3$1 from '@angular/material/form-field';
|
|
@@ -1275,7 +1275,7 @@ class TableColumnHeaderSettings {
|
|
|
1275
1275
|
this.noHeader = false;
|
|
1276
1276
|
}
|
|
1277
1277
|
}
|
|
1278
|
-
class
|
|
1278
|
+
class PersistedTableSettings {
|
|
1279
1279
|
constructor(tableSettings) {
|
|
1280
1280
|
this.collapseHeader = false;
|
|
1281
1281
|
this.collapseFooter = false;
|
|
@@ -1285,7 +1285,7 @@ class PesrsistedTableSettings {
|
|
|
1285
1285
|
}
|
|
1286
1286
|
}
|
|
1287
1287
|
}
|
|
1288
|
-
class
|
|
1288
|
+
class NotPersistedTableSettings {
|
|
1289
1289
|
constructor(tableSettings) {
|
|
1290
1290
|
this.hideExport = true;
|
|
1291
1291
|
this.hideFilter = true;
|
|
@@ -1312,7 +1312,7 @@ class KeysToDelete {
|
|
|
1312
1312
|
constructor() {
|
|
1313
1313
|
this.initializationState = null;
|
|
1314
1314
|
this.metaData = null;
|
|
1315
|
-
this.
|
|
1315
|
+
this.notPersistedTableSettings = null;
|
|
1316
1316
|
this.linkMaps = null;
|
|
1317
1317
|
}
|
|
1318
1318
|
}
|
|
@@ -1331,8 +1331,8 @@ const defaultTableState = {
|
|
|
1331
1331
|
hiddenKeys: [],
|
|
1332
1332
|
sorted: [],
|
|
1333
1333
|
userDefined: { order: {}, widths: {}, table: {} },
|
|
1334
|
-
persistedTableSettings: new
|
|
1335
|
-
|
|
1334
|
+
persistedTableSettings: new PersistedTableSettings(),
|
|
1335
|
+
notPersistedTableSettings: new NotPersistedTableSettings(),
|
|
1336
1336
|
pageSize: 10,
|
|
1337
1337
|
linkMaps: {},
|
|
1338
1338
|
groupByKeys: [],
|
|
@@ -1770,6 +1770,11 @@ class TableStore extends ComponentStore {
|
|
|
1770
1770
|
customCell: merge.customCell ?? orig.customCell,
|
|
1771
1771
|
transform: merge.transform ?? orig.transform,
|
|
1772
1772
|
click: merge.click ?? orig.click,
|
|
1773
|
+
classes: merge.classes ?? orig.classes,
|
|
1774
|
+
noSort: merge.noSort ?? orig.noSort,
|
|
1775
|
+
template: merge.template ?? orig.template,
|
|
1776
|
+
toolTip: merge.toolTip ?? orig.toolTip,
|
|
1777
|
+
useIcon: merge.useIcon ?? orig.useIcon,
|
|
1773
1778
|
};
|
|
1774
1779
|
};
|
|
1775
1780
|
this.setIntializationState = this.updater((state, initializationState) => {
|
|
@@ -1805,12 +1810,12 @@ class TableStore extends ComponentStore {
|
|
|
1805
1810
|
this.toggleCollapseHeader = this.updater((state) => {
|
|
1806
1811
|
const tableSettings = { ...state.persistedTableSettings };
|
|
1807
1812
|
tableSettings.collapseHeader = !tableSettings.collapseHeader;
|
|
1808
|
-
return ({ ...state, persistedTableSettings: new
|
|
1813
|
+
return ({ ...state, persistedTableSettings: new PersistedTableSettings(tableSettings) });
|
|
1809
1814
|
});
|
|
1810
1815
|
this.toggleCollapseFooter = this.updater((state) => {
|
|
1811
1816
|
const tableSettings = { ...state.persistedTableSettings };
|
|
1812
1817
|
tableSettings.collapseFooter = !tableSettings.collapseFooter;
|
|
1813
|
-
return ({ ...state, persistedTableSettings: new
|
|
1818
|
+
return ({ ...state, persistedTableSettings: new PersistedTableSettings(tableSettings) });
|
|
1814
1819
|
});
|
|
1815
1820
|
this.addGroupByKey = this.updater((state, groupByKey) => ({
|
|
1816
1821
|
...state,
|
|
@@ -1829,13 +1834,13 @@ class TableStore extends ComponentStore {
|
|
|
1829
1834
|
this.setTableSettings = this.updater((state, settings) => {
|
|
1830
1835
|
const s = {
|
|
1831
1836
|
...state,
|
|
1832
|
-
persistedTableSettings: new
|
|
1833
|
-
|
|
1837
|
+
persistedTableSettings: new PersistedTableSettings(settings),
|
|
1838
|
+
notPersistedTableSettings: new NotPersistedTableSettings(settings)
|
|
1834
1839
|
};
|
|
1835
1840
|
return s;
|
|
1836
1841
|
});
|
|
1837
1842
|
this.tableSettings$ = this.select(state => {
|
|
1838
|
-
const ts = { ...state.persistedTableSettings, ...state.
|
|
1843
|
+
const ts = { ...state.persistedTableSettings, ...state.notPersistedTableSettings };
|
|
1839
1844
|
return ts;
|
|
1840
1845
|
});
|
|
1841
1846
|
this.setLinkMaps = this.updater((state, maps) => {
|
|
@@ -2406,7 +2411,7 @@ class ColumnBuilderComponent {
|
|
|
2406
2411
|
}
|
|
2407
2412
|
}
|
|
2408
2413
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: ColumnBuilderComponent, deps: [{ token: TransformCreator }, { token: i4$3.MatTable }, { token: TableStore }, { token: TableTemplateService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2409
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ColumnBuilderComponent, selector: "tb-column-builder", inputs: { metaData: "metaData", customCell: "customCell", data$: "data$" }, viewQueries: [{ propertyName: "columnDef", first: true, predicate: MatColumnDef, descendants: true }, { propertyName: "bodyTemplate", first: true, predicate: ["body"], descendants: true }], ngImport: i0, template: "<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\" >\r\n\r\n
|
|
2414
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.1", type: ColumnBuilderComponent, selector: "tb-column-builder", inputs: { metaData: "metaData", customCell: "customCell", data$: "data$" }, viewQueries: [{ propertyName: "columnDef", first: true, predicate: MatColumnDef, descendants: true }, { propertyName: "bodyTemplate", first: true, predicate: ["body"], descendants: true }], ngImport: i0, template: "<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\" >\r\n\r\n <!-- header -->\r\n <ng-template matHeaderCellDef #myHeader>\r\n <ng-container *ngIf=\"customCell?.columnDef?.headerCell;else header;\">\r\n <ng-container *ngTemplateOutlet=\"customCell.columnDef.headerCell.template; context: {metaData: metaData, styles: styles.header} \"/>\r\n </ng-container>\r\n\r\n <ng-template #header>\r\n <mat-header-cell cdkDrag [styler]='styles.header' [resizeColumn]=\"true\" [key]=\"metaData.key\" class=\"column-head drag-header\" #headref \r\n [conditionalClasses]='metaData.additional?.columnPartClasses?.header' >\r\n <div class=\"header-container\" cdkDragHandle>\r\n <div *ngIf=\"!metaData._internalNotUserDefined || !customCell?.columnDef?.cell ; else headerWithoutMenu\" mat-sort-header [disabled]=\"metaData.noSort\" style=\"width: 100%\">\r\n {{ metaData.displayName ? metaData.displayName : ( metaData.key | spaceCase ) }}\r\n </div>\r\n <ng-template #headerWithoutMenu >\r\n <div *ngIf=\"metaData._internalNotUserDefined;\" style=\"width: 100%\">\r\n {{ metaData.displayName ? metaData.displayName : ( metaData.key | spaceCase ) }}\r\n </div>\r\n </ng-template>\r\n <tb-header-menu\r\n *ngIf=\"(!metaData._internalNotUserDefined || !customCell?.columnDef?.cell) && (showfilters$ | async);\" #menu [metaData]='metaData' [filter]='filter' >\r\n </tb-header-menu>\r\n </div>\r\n </mat-header-cell>\r\n </ng-template>\r\n </ng-template>\r\n\r\n <!-- body -->\r\n <ng-container *matCellDef=\"let element;\">\r\n <ng-container *ngTemplateOutlet=\"outerTemplate; context: {metaData: metaData, element: element , styles: styles.body }\"/>\r\n </ng-container>\r\n <ng-template #body let-element='element' >\r\n <mat-cell [matTooltip]=\"metaData.toolTip ?? ''\" [conditionalClasses]='metaData.classes' [element]='element' [styler]='styles.body' [class.group-footer]=\"element.isGroupFooter\" (click)='cellClicked(element, metaData.key)' >\r\n <ng-container *ngTemplateOutlet=\"innerTemplate;context: {metaData: metaData, element: element, transform: transform }; Injector: injector\" />\r\n </mat-cell>\r\n </ng-template>\r\n \r\n <!-- footer -->\r\n <ng-template matFooterCellDef>\r\n <ng-container *ngIf=\"customCell?.columnDef?.footerCell;else footer\">\r\n <ng-container\r\n *ngTemplateOutlet=\"customCell.columnDef.footerCell.template;context: {metaData: metaData, data: data$, styles : styles.footer }\"/>\r\n </ng-container>\r\n\r\n <ng-template #footer>\r\n <mat-footer-cell [styler]='styles.footer' *ngrxLet=\"data$ as data\" [conditionalClasses]='metaData.additional?.columnPartClasses?.footer'>\r\n <span *ngIf=\"!!data?.length && metaData.additional?.footer\" [ngSwitch]=\"metaData.fieldType\" class=\"bold\">\r\n <span *ngSwitchCase=\"FieldType.Currency\">\r\n {{ data | columnTotal: metaData | currency }}\r\n </span>\r\n <span *ngSwitchCase=\"FieldType.Number\">\r\n {{ data | columnTotal: metaData | number }}\r\n </span>\r\n </span>\r\n </mat-footer-cell>\r\n </ng-template>\r\n </ng-template>\r\n</ng-container>\r\n", styles: [".header-container{display:flex;flex-direction:row;width:100%;align-items:center}.negative-currency{color:red}.column-head{position:relative}.bold,.group-footer{font-weight:900}.cdk-drag-preview{background:white;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:33%;border-right-width:0px}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.drag-handle{color:#add8e6;cursor:move;margin-right:9px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4$3.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4$3.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i4$3.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4$3.MatFooterCellDef, selector: "[matFooterCellDef]" }, { kind: "directive", type: i4$3.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4$3.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "directive", type: i4$3.MatFooterCell, selector: "mat-footer-cell, td[mat-footer-cell]" }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i1$1.MatSortHeader, selector: "[mat-sort-header]", inputs: ["disabled", "mat-sort-header", "arrowPosition", "start", "sortActionDescription", "disableClear"], exportAs: ["matSortHeader"] }, { kind: "directive", type: i8.LetDirective, selector: "[ngrxLet]", inputs: ["ngrxLet", "ngrxLetSuspenseTpl"] }, { kind: "directive", type: i9.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i9.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "directive", type: StylerDirective, selector: "[styler]", inputs: ["styler"] }, { kind: "directive", type: ConditionalClassesDirective, selector: "[conditionalClasses]", inputs: ["element", "conditionalClasses"] }, { kind: "component", type: HeaderMenuComponent, selector: "tb-header-menu", inputs: ["filter", "metaData"] }, { kind: "directive", type: ResizeColumnDirective, selector: "[resizeColumn]", inputs: ["resizeColumn", "key"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.DecimalPipe, name: "number" }, { kind: "pipe", type: i2.CurrencyPipe, name: "currency" }, { kind: "pipe", type: SpaceCasePipe, name: "spaceCase" }, { kind: "pipe", type: ColumnTotalPipe, name: "columnTotal" }], viewProviders: [
|
|
2410
2415
|
{ provide: CDK_DROP_LIST, useExisting: CdkDropList },
|
|
2411
2416
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
2412
2417
|
}
|
|
@@ -2414,7 +2419,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
2414
2419
|
type: Component,
|
|
2415
2420
|
args: [{ selector: 'tb-column-builder', changeDetection: ChangeDetectionStrategy.OnPush, viewProviders: [
|
|
2416
2421
|
{ provide: CDK_DROP_LIST, useExisting: CdkDropList },
|
|
2417
|
-
], template: "<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\" >\r\n\r\n
|
|
2422
|
+
], template: "<ng-container [matColumnDef]=\"metaData.key\" *ngrxLet=\"styles$ as styles\" >\r\n\r\n <!-- header -->\r\n <ng-template matHeaderCellDef #myHeader>\r\n <ng-container *ngIf=\"customCell?.columnDef?.headerCell;else header;\">\r\n <ng-container *ngTemplateOutlet=\"customCell.columnDef.headerCell.template; context: {metaData: metaData, styles: styles.header} \"/>\r\n </ng-container>\r\n\r\n <ng-template #header>\r\n <mat-header-cell cdkDrag [styler]='styles.header' [resizeColumn]=\"true\" [key]=\"metaData.key\" class=\"column-head drag-header\" #headref \r\n [conditionalClasses]='metaData.additional?.columnPartClasses?.header' >\r\n <div class=\"header-container\" cdkDragHandle>\r\n <div *ngIf=\"!metaData._internalNotUserDefined || !customCell?.columnDef?.cell ; else headerWithoutMenu\" mat-sort-header [disabled]=\"metaData.noSort\" style=\"width: 100%\">\r\n {{ metaData.displayName ? metaData.displayName : ( metaData.key | spaceCase ) }}\r\n </div>\r\n <ng-template #headerWithoutMenu >\r\n <div *ngIf=\"metaData._internalNotUserDefined;\" style=\"width: 100%\">\r\n {{ metaData.displayName ? metaData.displayName : ( metaData.key | spaceCase ) }}\r\n </div>\r\n </ng-template>\r\n <tb-header-menu\r\n *ngIf=\"(!metaData._internalNotUserDefined || !customCell?.columnDef?.cell) && (showfilters$ | async);\" #menu [metaData]='metaData' [filter]='filter' >\r\n </tb-header-menu>\r\n </div>\r\n </mat-header-cell>\r\n </ng-template>\r\n </ng-template>\r\n\r\n <!-- body -->\r\n <ng-container *matCellDef=\"let element;\">\r\n <ng-container *ngTemplateOutlet=\"outerTemplate; context: {metaData: metaData, element: element , styles: styles.body }\"/>\r\n </ng-container>\r\n <ng-template #body let-element='element' >\r\n <mat-cell [matTooltip]=\"metaData.toolTip ?? ''\" [conditionalClasses]='metaData.classes' [element]='element' [styler]='styles.body' [class.group-footer]=\"element.isGroupFooter\" (click)='cellClicked(element, metaData.key)' >\r\n <ng-container *ngTemplateOutlet=\"innerTemplate;context: {metaData: metaData, element: element, transform: transform }; Injector: injector\" />\r\n </mat-cell>\r\n </ng-template>\r\n \r\n <!-- footer -->\r\n <ng-template matFooterCellDef>\r\n <ng-container *ngIf=\"customCell?.columnDef?.footerCell;else footer\">\r\n <ng-container\r\n *ngTemplateOutlet=\"customCell.columnDef.footerCell.template;context: {metaData: metaData, data: data$, styles : styles.footer }\"/>\r\n </ng-container>\r\n\r\n <ng-template #footer>\r\n <mat-footer-cell [styler]='styles.footer' *ngrxLet=\"data$ as data\" [conditionalClasses]='metaData.additional?.columnPartClasses?.footer'>\r\n <span *ngIf=\"!!data?.length && metaData.additional?.footer\" [ngSwitch]=\"metaData.fieldType\" class=\"bold\">\r\n <span *ngSwitchCase=\"FieldType.Currency\">\r\n {{ data | columnTotal: metaData | currency }}\r\n </span>\r\n <span *ngSwitchCase=\"FieldType.Number\">\r\n {{ data | columnTotal: metaData | number }}\r\n </span>\r\n </span>\r\n </mat-footer-cell>\r\n </ng-template>\r\n </ng-template>\r\n</ng-container>\r\n", styles: [".header-container{display:flex;flex-direction:row;width:100%;align-items:center}.negative-currency{color:red}.column-head{position:relative}.bold,.group-footer{font-weight:900}.cdk-drag-preview{background:white;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:33%;border-right-width:0px}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.drag-handle{color:#add8e6;cursor:move;margin-right:9px}\n"] }]
|
|
2418
2423
|
}], ctorParameters: function () { return [{ type: TransformCreator }, { type: i4$3.MatTable }, { type: TableStore }, { type: TableTemplateService }, { type: i0.Injector }]; }, propDecorators: { metaData: [{
|
|
2419
2424
|
type: Input
|
|
2420
2425
|
}], customCell: [{
|
|
@@ -2429,6 +2434,55 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
2429
2434
|
args: ['body']
|
|
2430
2435
|
}] } });
|
|
2431
2436
|
|
|
2437
|
+
class MultiSortDirective extends MatSort {
|
|
2438
|
+
constructor(state) {
|
|
2439
|
+
super();
|
|
2440
|
+
this.state = state;
|
|
2441
|
+
this.rules = [];
|
|
2442
|
+
this.state.setSort(this.sortChange.pipe(map(sc => ({ key: sc.active, direction: sc.direction }))));
|
|
2443
|
+
this.state.on(this.state.sorted$, (rules) => {
|
|
2444
|
+
const oldRules = this.rules;
|
|
2445
|
+
this.rules = rules;
|
|
2446
|
+
if (this.active && rules.length === 0) {
|
|
2447
|
+
this.active = '';
|
|
2448
|
+
this.direction = '';
|
|
2449
|
+
this.sortChange.emit({ active: '', direction: '' });
|
|
2450
|
+
}
|
|
2451
|
+
else if (!!rules.length && isDifferent(oldRules, rules)) {
|
|
2452
|
+
this.active = rules[0].active;
|
|
2453
|
+
this.direction = rules[0].direction;
|
|
2454
|
+
this.sortChange.emit(rules[0]);
|
|
2455
|
+
}
|
|
2456
|
+
});
|
|
2457
|
+
}
|
|
2458
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MultiSortDirective, deps: [{ token: TableStore }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
2459
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.1", type: MultiSortDirective, selector: "[multiSort]", inputs: { disabled: ["matSortDisabled", "disabled"] }, providers: [
|
|
2460
|
+
{ provide: MatSort, useExisting: MultiSortDirective }
|
|
2461
|
+
], exportAs: ["multiSort"], usesInheritance: true, ngImport: i0 }); }
|
|
2462
|
+
}
|
|
2463
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MultiSortDirective, decorators: [{
|
|
2464
|
+
type: Directive,
|
|
2465
|
+
args: [{
|
|
2466
|
+
selector: '[multiSort]',
|
|
2467
|
+
exportAs: 'multiSort',
|
|
2468
|
+
inputs: ['disabled: matSortDisabled'],
|
|
2469
|
+
providers: [
|
|
2470
|
+
{ provide: MatSort, useExisting: MultiSortDirective }
|
|
2471
|
+
]
|
|
2472
|
+
}]
|
|
2473
|
+
}], ctorParameters: function () { return [{ type: TableStore }]; } });
|
|
2474
|
+
function isDifferent(a, b) {
|
|
2475
|
+
if (a.length !== b.length) {
|
|
2476
|
+
return true;
|
|
2477
|
+
}
|
|
2478
|
+
for (let i = 0; i < a.length; i++) {
|
|
2479
|
+
if (a[i].active !== b[i].active || a[i].direction !== b[i].direction) {
|
|
2480
|
+
return true;
|
|
2481
|
+
}
|
|
2482
|
+
}
|
|
2483
|
+
return false;
|
|
2484
|
+
}
|
|
2485
|
+
|
|
2432
2486
|
class MatTableObservableDataSource extends MatTableDataSource {
|
|
2433
2487
|
constructor(dataSrc) {
|
|
2434
2488
|
super([]);
|
|
@@ -2453,14 +2507,11 @@ function sortData(data, sorted) {
|
|
|
2453
2507
|
return orderBy(data, sorted.map(r => r.active), sorted.map(r => r.direction));
|
|
2454
2508
|
}
|
|
2455
2509
|
|
|
2456
|
-
function isMultiSort(sort) {
|
|
2457
|
-
return Array.isArray(sort.rules);
|
|
2458
|
-
}
|
|
2459
2510
|
class GenericTableDataSource extends MatTableObservableDataSource {
|
|
2460
2511
|
constructor(dataSrc) {
|
|
2461
2512
|
super(dataSrc);
|
|
2462
2513
|
const baseSort = this.sortData;
|
|
2463
|
-
this.sortData = ((data, sort) =>
|
|
2514
|
+
this.sortData = ((data, sort) => sort instanceof MultiSortDirective ? sortData(data, sort.rules) : baseSort(data, sort));
|
|
2464
2515
|
}
|
|
2465
2516
|
}
|
|
2466
2517
|
|
|
@@ -3158,43 +3209,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImpor
|
|
|
3158
3209
|
}]
|
|
3159
3210
|
}] });
|
|
3160
3211
|
|
|
3161
|
-
class MultiSortDirective extends MatSort {
|
|
3162
|
-
constructor(state) {
|
|
3163
|
-
super();
|
|
3164
|
-
this.state = state;
|
|
3165
|
-
this.rules = [];
|
|
3166
|
-
this.state.setSort(this.sortChange.pipe(map(sc => ({ key: sc.active, direction: sc.direction }))));
|
|
3167
|
-
this.state.on(this.state.sorted$, rules => {
|
|
3168
|
-
this.rules = rules;
|
|
3169
|
-
if (this.active && rules.length === 0) {
|
|
3170
|
-
this.active = '';
|
|
3171
|
-
this.direction = '';
|
|
3172
|
-
this.sortChange.emit({ active: '', direction: '' });
|
|
3173
|
-
}
|
|
3174
|
-
if (rules.length > 0 && (this.active !== rules[0].active || this.direction !== rules[0].direction)) {
|
|
3175
|
-
this.active = rules[0].active;
|
|
3176
|
-
this.direction = rules[0].direction;
|
|
3177
|
-
this.sortChange.emit(rules[0]);
|
|
3178
|
-
}
|
|
3179
|
-
});
|
|
3180
|
-
}
|
|
3181
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MultiSortDirective, deps: [{ token: TableStore }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
3182
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.1", type: MultiSortDirective, selector: "[multiSort]", inputs: { disabled: ["matSortDisabled", "disabled"] }, providers: [
|
|
3183
|
-
{ provide: MatSort, useExisting: MultiSortDirective }
|
|
3184
|
-
], exportAs: ["multiSort"], usesInheritance: true, ngImport: i0 }); }
|
|
3185
|
-
}
|
|
3186
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: MultiSortDirective, decorators: [{
|
|
3187
|
-
type: Directive,
|
|
3188
|
-
args: [{
|
|
3189
|
-
selector: '[multiSort]',
|
|
3190
|
-
exportAs: 'multiSort',
|
|
3191
|
-
inputs: ['disabled: matSortDisabled'],
|
|
3192
|
-
providers: [
|
|
3193
|
-
{ provide: MatSort, useExisting: MultiSortDirective }
|
|
3194
|
-
]
|
|
3195
|
-
}]
|
|
3196
|
-
}], ctorParameters: function () { return [{ type: TableStore }]; } });
|
|
3197
|
-
|
|
3198
3212
|
const inputs = [
|
|
3199
3213
|
'predicate: tbCustomFilter',
|
|
3200
3214
|
'filterId: filterId',
|
|
@@ -3808,7 +3822,8 @@ class SortMenuComponentStore extends ComponentStore {
|
|
|
3808
3822
|
const sorted = this.tableState.sorted$.pipe(mergeMap(sort => this.tableState.metaData$.pipe(notNull(), map(meta => sort.map(s => {
|
|
3809
3823
|
return { ...s, displayName: meta[s.active]?.displayName };
|
|
3810
3824
|
})))));
|
|
3811
|
-
const notSorted = this.tableState.metaDataArray$.pipe(mergeMap(metas => this.tableState.sorted$.pipe(map(s => metas
|
|
3825
|
+
const notSorted = this.tableState.metaDataArray$.pipe(mergeMap(metas => this.tableState.sorted$.pipe(map(s => metas
|
|
3826
|
+
.filter(meta => !s.some(s => s.active === meta.key) && !meta.noSort)
|
|
3812
3827
|
.map(meta => ({ active: meta.key, displayName: meta.displayName }))))));
|
|
3813
3828
|
this.set(combineLatest([
|
|
3814
3829
|
sorted.pipe(distinctSortArray), notSorted.pipe(distinctSortArray)
|
|
@@ -4761,5 +4776,5 @@ const shallowEquals = (first, second) => {
|
|
|
4761
4776
|
* Generated bundle index. Do not edit.
|
|
4762
4777
|
*/
|
|
4763
4778
|
|
|
4764
|
-
export { ActionStateSpinnerComponent, ActionStateUiModule, ActionStatus, AppStatusState, ArrayStyle, AutoFocusDirective, CancellationToken, ClickEmitterDirective, ClickSubjectDirective, ConditionalClassesDirective, CreateTableBuilder, CustomCellDirective, DateFilterComponent, DialogDirective, DialogService, DialogWrapper, FieldType, FilterChipsComponent, FilterComponent, FilterType, FunctionPipe, GenColDisplayerComponent, GenFilterDisplayerComponent, GeneralTableSettings, GenericTableComponent, GroupByListComponent, HttpErrorStateDirective, HttpInProgressStateDirective, HttpNotStartedStateDirective, HttpRequestModule, HttpRequestStateDirective, HttpRequestStateFactory, HttpRequestStateStore, HttpRequestStatus, HttpRequestStrategy, HttpSuccessStateDirective, MatButtonToggleFilterDirective, MatCheckboxTbFilterDirective, MatOptionTbFilterDirective, MatRadioButtonTbFilterDirective, MatSlideToggleGroupDirective, MatSlideToggleTbFilterDirective, MatTableObservableDataSource, MultiSortDirective, NgrxExtModule,
|
|
4779
|
+
export { ActionStateSpinnerComponent, ActionStateUiModule, ActionStatus, AppStatusState, ArrayStyle, AutoFocusDirective, CancellationToken, ClickEmitterDirective, ClickSubjectDirective, ConditionalClassesDirective, CreateTableBuilder, CustomCellDirective, DateFilterComponent, DialogDirective, DialogService, DialogWrapper, FieldType, FilterChipsComponent, FilterComponent, FilterType, FunctionPipe, GenColDisplayerComponent, GenFilterDisplayerComponent, GeneralTableSettings, GenericTableComponent, GroupByListComponent, HttpErrorStateDirective, HttpInProgressStateDirective, HttpNotStartedStateDirective, HttpRequestModule, HttpRequestStateDirective, HttpRequestStateFactory, HttpRequestStateStore, HttpRequestStatus, HttpRequestStrategy, HttpSuccessStateDirective, MatButtonToggleFilterDirective, MatCheckboxTbFilterDirective, MatOptionTbFilterDirective, MatRadioButtonTbFilterDirective, MatSlideToggleGroupDirective, MatSlideToggleTbFilterDirective, MatTableObservableDataSource, MultiSortDirective, NgrxExtModule, NotPersistedTableSettings, PaginatorComponent, PersistedTableSettings, PhoneNumberPipe, PreventEnterDirective, ResizeColumnDirective, SortDirection, SpaceCasePipe, StopPropagationDirective, StylerDirective, Subjectifier, TableBuilder, TableBuilderModule, TableColumnHeaderSettings, TableContainerComponent, TableCustomFilterDirective, TableCustomFilterDirectiveBase, TableFilterDirective, TableFilterStringContainsDirective, TableWrapperDirective, TableWrapperFooterSettings, TableWrapperHeaderSettings, Target, TbSelectedFilterDirective, TrimWhitespaceDirective, UtilitiesModule, actionStatusReducer, chainRequest, combineArrays, createActionableSelector, createFailure, createSuccess, defaultFilter, defaultShareReplay, delayOn, filterArray, getRequestorBody, getRequestorStatus, getStatusState, httpRequest, httpRequestor, inProgress, initialState, isErrorState, isSuccessOrErrorState, isSuccessState, mapArray, mapError, notNull, notStarted, onWait, onceWhen, previousAndCurrent, selectAll, selectEntities, selectEntity, selectIds, selectTotal, serverStatusTypes, setUpStoreFactory, skipOneWhen, spaceCase, statusAdapter, statusIsSuccessOrInProgress, switchOff, tapError, tapSuccess };
|
|
4765
4780
|
//# sourceMappingURL=one-paragon-angular-utilities.mjs.map
|