@one-paragon/angular-utilities 1.1.2 → 1.1.4
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/components/generic-table/generic-table.component.mjs +3 -2
- package/esm2022/table-builder/ngrx/tableBuilderStateStore.mjs +2 -2
- package/esm2022/table-builder/services/table-template-service.mjs +8 -7
- package/fesm2022/one-paragon-angular-utilities.mjs +10 -8
- package/fesm2022/one-paragon-angular-utilities.mjs.map +1 -1
- package/package.json +1 -1
- package/table-builder/components/table-container/table-container-imports.d.ts +2 -2
- package/table-builder/services/table-template-service.d.ts +2 -2
|
@@ -111,7 +111,8 @@ export class GenericTableComponent {
|
|
|
111
111
|
});
|
|
112
112
|
this.state.on(this.state.props().dataSource.viewableData$, (data) => {
|
|
113
113
|
if (this.selection.selected.length) {
|
|
114
|
-
const
|
|
114
|
+
const trackByFunction = this.trackBy ? (s) => data.every(d => d[this.trackBy] !== s[this.trackBy]) : s => !data.includes(s);
|
|
115
|
+
const removed = this.selection.selected.filter(trackByFunction);
|
|
115
116
|
this.selection.deselect(...removed);
|
|
116
117
|
}
|
|
117
118
|
});
|
|
@@ -200,4 +201,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
|
200
201
|
}], selection$: [{
|
|
201
202
|
type: Output
|
|
202
203
|
}] } });
|
|
203
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-table.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  ChangeDetectionStrategy,\r\n  Output,\r\n  SimpleChanges,\r\n  OnInit,\r\n  QueryList,\r\n  ViewContainerRef,\r\n  Injector,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport { MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\r\nimport { Observable, combineLatest } from 'rxjs';\r\nimport { SelectionChange, SelectionModel } from '@angular/cdk/collections';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { map, distinctUntilChanged } from 'rxjs/operators';\r\nimport { ColumnBuilderComponent } from '../column-builder/column-builder.component';\r\nimport { Dictionary } from '../../interfaces/dictionary';\r\nimport { FieldType } from '../../interfaces/report-def';\r\nimport { previousAndCurrent } from '../../../rxjs/rxjs-operators';\r\nimport { ColumnInfo } from '../../interfaces/ColumnInfo';\r\nimport { CdkDragDrop, CdkDropList, DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { FunctionPipe } from '../../../utilities';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { AsyncPipe, NgTemplateOutlet } from '@angular/common';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { LetDirective } from '@ngrx/component';\r\nimport { TransformCreator } from '../../services/transform-creator';\r\nimport { initIndexSymbol } from '../table-container/table-container.helpers/sort-state.helpers';\r\n\r\n@Component({\r\n  selector: 'tb-generic-table',\r\n  templateUrl: './generic-table.component.html',\r\n  styleUrls: ['./generic-table.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    MatTableModule, DragDropModule, MatCheckboxModule, MatButtonModule, MatIconModule, NgTemplateOutlet,\r\n    MatTooltipModule, AsyncPipe, LetDirective, FunctionPipe,\r\n  ],\r\n})\r\nexport class GenericTableComponent implements OnInit {\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    this.state.setUserDefinedOrder({ newOrder:event.currentIndex, oldOrder:event.previousIndex })\r\n  }\r\n  @Input() set trackBy(trackBy: string){\r\n    if(trackBy){\r\n      this.trackByFunction = (index:number, item: any) => item[trackBy];\r\n    }\r\n    this.setUpSelections(trackBy);\r\n  }\r\n  @Input() displayData$!: Observable<any[]>;\r\n  @Input() data$!: Observable<any[]>;\r\n  @Input() rows!: QueryList<MatRowDef<any>>;\r\n  @Input() columnBuilders!: ColumnBuilderComponent[];\r\n  @Input() columnInfos!: Observable<ColumnInfo[]>;\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<any>;\r\n  @ViewChild(CdkDropList, { static: true }) dropList!: CdkDropList;\r\n\r\n  currentColumns!: string[];\r\n  keys: string [] = [];\r\n  injector: Injector;\r\n  rowDefArr :MatRowDef<any>[] = [];\r\n  columns:string [] = [];\r\n  myColumns: Dictionary<ColumnBuilderComponent> = {};\r\n  showHeader$!: Observable<boolean>;\r\n  offset$! : Observable<number>;\r\n  offsetIndex = 0;\r\n  dataView!: Observable<any[]>;\r\n\r\n  constructor(\r\n    public state: TableStore,\r\n    private viewContainer: ViewContainerRef,\r\n    private transformCreator: TransformCreator,\r\n    injector: Injector,\r\n    ) {\r\n    this.injector = Injector.create({\r\n      providers: [\r\n        {provide: MatTable, useFactory: ()=> this.table },\r\n        {provide: CdkDropList, useFactory: ()=> this.dropList },\r\n      ],\r\n      parent: injector\r\n    });\r\n\r\n    this.offset$ = this.state.select( s => s.virtualScrollOffset );\r\n\r\n    this.setUpSelections();\r\n  }\r\n\r\n  defaultTrackBy = (index:number, item: any) => item[initIndexSymbol];\r\n  trackByFunction = this.defaultTrackBy;\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.rows && this.rows && this.myColumns.length) {\r\n      this.initializeRowDefs([...this.rows]);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.state.props().selectionColumn) {\r\n      this.columns.push('select');\r\n    }\r\n\r\n    if (this.state.props().indexColumn) {\r\n     this.columns.push('index');\r\n    }\r\n\r\n    this.state.on(this.columnInfos, columns => {\r\n      columns.forEach(ci => this.addMetaData(ci))\r\n    });\r\n\r\n    this.initializeRowDefs([...this.rows]);\r\n\r\n    this.state.on(this.state.displayedColumns$, keys => {\r\n      this.keys = [...this.columns, ...keys];\r\n      this.rowDefArr?.forEach(row => row.columns = this.keys)\r\n    });\r\n\r\n    this.state.on(this.state.props().dataSource!.viewableData$, (data) => {\r\n      if(this.selection.selected.length){\r\n        const removed = this.selection.selected.filter(s => !data.includes(s));\r\n        this.selection.deselect(...removed);\r\n      }\r\n    })\r\n\r\n    this.showHeader$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeader)));\r\n\r\n    this.showFooterRow$ = combineLatest([\r\n      this.displayData$.pipe(map(d => !!d.length), distinctUntilChanged()),\r\n      this.state.metaDataArray$.pipe(map(metaData => metaData.some(md => !!md.additional?.footer)), distinctUntilChanged()),\r\n      this.columnInfos.pipe(map(columnInfos => columnInfos.some(ci => !!ci.customCell?.columnDef?.footerCell)), distinctUntilChanged()),\r\n    ]).pipe(map(([hasData, hasFooterDef, hasCustomFooter]) => {\r\n      const hasSelectionColumn = this.state.props().selectionColumn;\r\n      return hasCustomFooter || (hasData && (hasFooterDef || hasSelectionColumn)) ? 'regular-footer' : hasData ? 'no-footer' : 'small-footer';\r\n    }));\r\n\r\n    if(this.state.tableSettings().usePaginator || this.state.tableSettings().useVirtualScroll) {\r\n      this.state.on(this.state.state$, (state) => {\r\n        this.offsetIndex = state.virtualStart;\r\n        if(this.state.tableSettings().usePaginator) {\r\n          this.offsetIndex += (state.pageSize * state.currentPage);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  isGroupHeader(_: number, row: { isGroupHeader: boolean }) {\r\n    return row.isGroupHeader;\r\n  }\r\n\r\n  setExpanded(key: string, groupKey: string, isExpanded: boolean): void {\r\n    this.state.updateExpandedGroups({ key , isExpanded, groupKey });\r\n  }\r\n\r\n  addMetaData(column: ColumnInfo) {\r\n    const columnBuilder = this.myColumns[column.metaData.key];\r\n    if(columnBuilder) {\r\n      columnBuilder.metaData = column.metaData;\r\n    } else {\r\n      const component = this.viewContainer.createComponent(ColumnBuilderComponent, {\r\n        index: 0,\r\n        injector: this.injector\r\n      });\r\n      component.instance.customCell = column.customCell;\r\n      component.instance.metaData = column.metaData;\r\n      component.instance.data$ = this.data$;\r\n      this.myColumns[column.metaData.key] = component.instance;\r\n    }\r\n  }\r\n\r\n  initializeRowDefs = (defs:MatRowDef<any>[])=>{\r\n    this.rowDefArr.forEach(r=>this.table.removeRowDef(r));\r\n    this.rowDefArr = defs;\r\n    defs.forEach(r => {\r\n      r.columns = this.columns.concat(Object.values(this.myColumns).filter(c => c.metaData.fieldType !== FieldType.Hidden).map(c => c.metaData.key));\r\n      if (this.table) {\r\n        this.table.addRowDef(r);\r\n      }\r\n    });\r\n  }\r\n\r\n  selection! : SelectionModel<any>;\r\n  @Output() selection$ = new EventEmitter<SelectionChange<any>>();\r\n  masterToggleChecked$ = this.selection$.pipe(map(()=>this.selection.hasValue() && this.isAllSelected()));\r\n  masterToggleIndeterminate$ = this.selection$.pipe(map(()=>this.selection.hasValue() && !this.isAllSelected()));\r\n  setUpSelections(trackBy?: string){\r\n    this.selection = trackBy ? new SelectionModel<any>(true, [], true, (a, b) => a[trackBy] === b[trackBy]) : new SelectionModel<any>(true, []);\r\n    this.state.on(this.selection.changed, c => this.selection$.emit(c));\r\n  }\r\n\r\n  isAllSelected() {\r\n    const numSelected = this.selection.selected.length;\r\n    const numRows = this.state.props().dataSource?.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\r\n  masterToggle() {\r\n    this.isAllSelected() ?\r\n      this.selection.clear() :\r\n      this.selection.select(...this.state.props().dataSource!.data);\r\n  }\r\n\r\n  tableWidth = this.state.getUserDefinedTableSize$.pipe(\r\n    previousAndCurrent<number | undefined>(0),\r\n    map(([previousUserDefinedWidth, currentUserDefinedWidth]) => {\r\n      if( currentUserDefinedWidth){\r\n        return ({width:`${currentUserDefinedWidth}px`});\r\n      } if( wasReset() ){\r\n        return ({width:'initial'});\r\n      }\r\n      return ({});\r\n\r\n      function wasReset(){\r\n        return (previousUserDefinedWidth ?? 0) >=0 && currentUserDefinedWidth == null;\r\n      }\r\n    })\r\n  );\r\n\r\n  showFooterRow$!: Observable<'regular-footer' | 'no-footer' | 'small-footer'>;\r\n  getTransform = (key: string, val: string) => {\r\n    if(val == undefined || val === 'null') return '';\r\n    try {\r\n      return this.transformCreator.createTransformer(this.myColumns[key].metaData, true)({ [key]: val});\r\n    } catch (error) {\r\n      return val;\r\n    }\r\n  }\r\n}\r\n","<mat-table\r\n  cdkDropList\r\n  cdkDropListLockAxis='x'\r\n  cdkDropListOrientation=\"horizontal\"\r\n  (cdkDropListDropped)=\"drop($event)\"\r\n  class=\"table-drag-list\"\r\n  [class]=\"(showFooterRow$ | async)\"\r\n  #table\r\n  [dataSource]=\"state.props().dataSource!\"\r\n  [trackBy]=\"trackByFunction\"\r\n  [style]=\"tableWidth | async\"\r\n>\r\n\r\n  <!-- select column -->\r\n  <ng-container matColumnDef=\"select\">\r\n\r\n    <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\">\r\n      <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n                    [checked]=\"!!(masterToggleChecked$ | async)\"\r\n                    [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n      </mat-checkbox>\r\n    </mat-header-cell>\r\n\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <mat-checkbox\r\n      (click)=\"$event.stopPropagation()\"\r\n      (change)=\"$event ? selection.toggle(row) : null\"\r\n      [checked]=\"selection.isSelected(row)\"/>\r\n    </mat-cell>\r\n\r\n    <mat-footer-cell *matFooterCellDef>\r\n      {{ selection.selected.length }}\r\n    </mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- index column -->\r\n  <ng-container matColumnDef=\"index\">\r\n      <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" >#</mat-header-cell>\r\n      <mat-cell *matCellDef=\"let i = index;\">\r\n         {{ 1 + i + offsetIndex}}\r\n      </mat-cell>\r\n      <mat-footer-cell *matFooterCellDef></mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- Grouping -->\r\n  <ng-container matColumnDef=\"groupHeader\">\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <div [style.paddingLeft]=\"row.padding + 'px !important'\" *ngrxLet=\"(state.getIsExpanded | func : row.key : row.groupName ) as expanded\">\r\n        <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded);\">\r\n          @if(!expanded){\r\n            <mat-icon>chevron_right</mat-icon>\r\n          } @else {\r\n            <mat-icon>expand_more</mat-icon>\r\n          }\r\n        </button>\r\n        {{getTransform | func : row.key :  row.groupHeaderDisplay}} ({{row.length}})\r\n      </div>\r\n      <div style=\"flex-grow: 1\">\r\n        <ng-container *ngTemplateOutlet=\"state.props().groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n      </div>\r\n    </mat-cell>\r\n  </ng-container>\r\n\r\n  @if(showHeader$ | async){\r\n    <mat-header-row *matHeaderRowDef=\"keys; sticky: state.props().isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\"  />\r\n  }\r\n  <mat-row *matRowDef=\"let row; columns: keys; let i = index\" />\r\n  <mat-row *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\" />\r\n  <mat-footer-row *matFooterRowDef=\"(showFooterRow$ | async) === 'regular-footer' ? keys : []; sticky: state.props().stickyFooter \"  [style.bottom.px]=\"state.props().stickyFooter ? (offset$ | async) : undefined\"  />\r\n\r\n</mat-table>\r\n"]}
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"generic-table.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.ts","../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/generic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  ChangeDetectionStrategy,\r\n  Output,\r\n  SimpleChanges,\r\n  OnInit,\r\n  QueryList,\r\n  ViewContainerRef,\r\n  Injector,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport { MatRowDef, MatTable, MatTableModule } from '@angular/material/table';\r\nimport { Observable, combineLatest } from 'rxjs';\r\nimport { SelectionChange, SelectionModel } from '@angular/cdk/collections';\r\nimport { TableStore } from '../../classes/table-store';\r\nimport { map, distinctUntilChanged } from 'rxjs/operators';\r\nimport { ColumnBuilderComponent } from '../column-builder/column-builder.component';\r\nimport { Dictionary } from '../../interfaces/dictionary';\r\nimport { FieldType } from '../../interfaces/report-def';\r\nimport { previousAndCurrent } from '../../../rxjs/rxjs-operators';\r\nimport { ColumnInfo } from '../../interfaces/ColumnInfo';\r\nimport { CdkDragDrop, CdkDropList, DragDropModule } from '@angular/cdk/drag-drop';\r\nimport { FunctionPipe } from '../../../utilities';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { AsyncPipe, NgTemplateOutlet } from '@angular/common';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { LetDirective } from '@ngrx/component';\r\nimport { TransformCreator } from '../../services/transform-creator';\r\nimport { initIndexSymbol } from '../table-container/table-container.helpers/sort-state.helpers';\r\n\r\n@Component({\r\n  selector: 'tb-generic-table',\r\n  templateUrl: './generic-table.component.html',\r\n  styleUrls: ['./generic-table.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  imports: [\r\n    MatTableModule, DragDropModule, MatCheckboxModule, MatButtonModule, MatIconModule, NgTemplateOutlet,\r\n    MatTooltipModule, AsyncPipe, LetDirective, FunctionPipe,\r\n  ],\r\n})\r\nexport class GenericTableComponent implements OnInit {\r\n\r\n  drop(event: CdkDragDrop<string[]>) {\r\n    this.state.setUserDefinedOrder({ newOrder:event.currentIndex, oldOrder:event.previousIndex })\r\n  }\r\n  @Input() set trackBy(trackBy: string){\r\n    if(trackBy){\r\n      this.trackByFunction = (index:number, item: any) => item[trackBy];\r\n    }\r\n    this.setUpSelections(trackBy);\r\n  }\r\n  @Input() displayData$!: Observable<any[]>;\r\n  @Input() data$!: Observable<any[]>;\r\n  @Input() rows!: QueryList<MatRowDef<any>>;\r\n  @Input() columnBuilders!: ColumnBuilderComponent[];\r\n  @Input() columnInfos!: Observable<ColumnInfo[]>;\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<any>;\r\n  @ViewChild(CdkDropList, { static: true }) dropList!: CdkDropList;\r\n\r\n  currentColumns!: string[];\r\n  keys: string [] = [];\r\n  injector: Injector;\r\n  rowDefArr :MatRowDef<any>[] = [];\r\n  columns:string [] = [];\r\n  myColumns: Dictionary<ColumnBuilderComponent> = {};\r\n  showHeader$!: Observable<boolean>;\r\n  offset$! : Observable<number>;\r\n  offsetIndex = 0;\r\n  dataView!: Observable<any[]>;\r\n\r\n  constructor(\r\n    public state: TableStore,\r\n    private viewContainer: ViewContainerRef,\r\n    private transformCreator: TransformCreator,\r\n    injector: Injector,\r\n    ) {\r\n    this.injector = Injector.create({\r\n      providers: [\r\n        {provide: MatTable, useFactory: ()=> this.table },\r\n        {provide: CdkDropList, useFactory: ()=> this.dropList },\r\n      ],\r\n      parent: injector\r\n    });\r\n\r\n    this.offset$ = this.state.select( s => s.virtualScrollOffset );\r\n\r\n    this.setUpSelections();\r\n  }\r\n\r\n  defaultTrackBy = (index:number, item: any) => item[initIndexSymbol];\r\n  trackByFunction = this.defaultTrackBy;\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.rows && this.rows && this.myColumns.length) {\r\n      this.initializeRowDefs([...this.rows]);\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.state.props().selectionColumn) {\r\n      this.columns.push('select');\r\n    }\r\n\r\n    if (this.state.props().indexColumn) {\r\n     this.columns.push('index');\r\n    }\r\n\r\n    this.state.on(this.columnInfos, columns => {\r\n      columns.forEach(ci => this.addMetaData(ci))\r\n    });\r\n\r\n    this.initializeRowDefs([...this.rows]);\r\n\r\n    this.state.on(this.state.displayedColumns$, keys => {\r\n      this.keys = [...this.columns, ...keys];\r\n      this.rowDefArr?.forEach(row => row.columns = this.keys)\r\n    });\r\n\r\n    this.state.on(this.state.props().dataSource!.viewableData$, (data) => {\r\n      if(this.selection.selected.length){\r\n        const trackByFunction = this.trackBy ? (s) => data.every(d =>  d[this.trackBy] !== s[this.trackBy]) : s => !data.includes(s)\r\n        const removed = this.selection.selected.filter(trackByFunction);\r\n        this.selection.deselect(...removed);\r\n      }\r\n    })\r\n\r\n    this.showHeader$ = this.state.tableSettings$.pipe(map(settings => !(settings.hideColumnHeader)));\r\n\r\n    this.showFooterRow$ = combineLatest([\r\n      this.displayData$.pipe(map(d => !!d.length), distinctUntilChanged()),\r\n      this.state.metaDataArray$.pipe(map(metaData => metaData.some(md => !!md.additional?.footer)), distinctUntilChanged()),\r\n      this.columnInfos.pipe(map(columnInfos => columnInfos.some(ci => !!ci.customCell?.columnDef?.footerCell)), distinctUntilChanged()),\r\n    ]).pipe(map(([hasData, hasFooterDef, hasCustomFooter]) => {\r\n      const hasSelectionColumn = this.state.props().selectionColumn;\r\n      return hasCustomFooter || (hasData && (hasFooterDef || hasSelectionColumn)) ? 'regular-footer' : hasData ? 'no-footer' : 'small-footer';\r\n    }));\r\n\r\n    if(this.state.tableSettings().usePaginator || this.state.tableSettings().useVirtualScroll) {\r\n      this.state.on(this.state.state$, (state) => {\r\n        this.offsetIndex = state.virtualStart;\r\n        if(this.state.tableSettings().usePaginator) {\r\n          this.offsetIndex += (state.pageSize * state.currentPage);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  isGroupHeader(_: number, row: { isGroupHeader: boolean }) {\r\n    return row.isGroupHeader;\r\n  }\r\n\r\n  setExpanded(key: string, groupKey: string, isExpanded: boolean): void {\r\n    this.state.updateExpandedGroups({ key , isExpanded, groupKey });\r\n  }\r\n\r\n  addMetaData(column: ColumnInfo) {\r\n    const columnBuilder = this.myColumns[column.metaData.key];\r\n    if(columnBuilder) {\r\n      columnBuilder.metaData = column.metaData;\r\n    } else {\r\n      const component = this.viewContainer.createComponent(ColumnBuilderComponent, {\r\n        index: 0,\r\n        injector: this.injector\r\n      });\r\n      component.instance.customCell = column.customCell;\r\n      component.instance.metaData = column.metaData;\r\n      component.instance.data$ = this.data$;\r\n      this.myColumns[column.metaData.key] = component.instance;\r\n    }\r\n  }\r\n\r\n  initializeRowDefs = (defs:MatRowDef<any>[])=>{\r\n    this.rowDefArr.forEach(r=>this.table.removeRowDef(r));\r\n    this.rowDefArr = defs;\r\n    defs.forEach(r => {\r\n      r.columns = this.columns.concat(Object.values(this.myColumns).filter(c => c.metaData.fieldType !== FieldType.Hidden).map(c => c.metaData.key));\r\n      if (this.table) {\r\n        this.table.addRowDef(r);\r\n      }\r\n    });\r\n  }\r\n\r\n  selection! : SelectionModel<any>;\r\n  @Output() selection$ = new EventEmitter<SelectionChange<any>>();\r\n  masterToggleChecked$ = this.selection$.pipe(map(()=>this.selection.hasValue() && this.isAllSelected()));\r\n  masterToggleIndeterminate$ = this.selection$.pipe(map(()=>this.selection.hasValue() && !this.isAllSelected()));\r\n  setUpSelections(trackBy?: string){\r\n    this.selection = trackBy ? new SelectionModel<any>(true, [], true, (a, b) => a[trackBy] === b[trackBy]) : new SelectionModel<any>(true, []);\r\n    this.state.on(this.selection.changed, c => this.selection$.emit(c));\r\n  }\r\n\r\n  isAllSelected() {\r\n    const numSelected = this.selection.selected.length;\r\n    const numRows = this.state.props().dataSource?.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  /** Selects all rows if they are not all selected; otherwise clear selection. */\r\n  masterToggle() {\r\n    this.isAllSelected() ?\r\n      this.selection.clear() :\r\n      this.selection.select(...this.state.props().dataSource!.data);\r\n  }\r\n\r\n  tableWidth = this.state.getUserDefinedTableSize$.pipe(\r\n    previousAndCurrent<number | undefined>(0),\r\n    map(([previousUserDefinedWidth, currentUserDefinedWidth]) => {\r\n      if( currentUserDefinedWidth){\r\n        return ({width:`${currentUserDefinedWidth}px`});\r\n      } if( wasReset() ){\r\n        return ({width:'initial'});\r\n      }\r\n      return ({});\r\n\r\n      function wasReset(){\r\n        return (previousUserDefinedWidth ?? 0) >=0 && currentUserDefinedWidth == null;\r\n      }\r\n    })\r\n  );\r\n\r\n  showFooterRow$!: Observable<'regular-footer' | 'no-footer' | 'small-footer'>;\r\n  getTransform = (key: string, val: string) => {\r\n    if(val == undefined || val === 'null') return '';\r\n    try {\r\n      return this.transformCreator.createTransformer(this.myColumns[key].metaData, true)({ [key]: val});\r\n    } catch (error) {\r\n      return val;\r\n    }\r\n  }\r\n}\r\n","<mat-table\r\n  cdkDropList\r\n  cdkDropListLockAxis='x'\r\n  cdkDropListOrientation=\"horizontal\"\r\n  (cdkDropListDropped)=\"drop($event)\"\r\n  class=\"table-drag-list\"\r\n  [class]=\"(showFooterRow$ | async)\"\r\n  #table\r\n  [dataSource]=\"state.props().dataSource!\"\r\n  [trackBy]=\"trackByFunction\"\r\n  [style]=\"tableWidth | async\"\r\n>\r\n\r\n  <!-- select column -->\r\n  <ng-container matColumnDef=\"select\">\r\n\r\n    <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\">\r\n      <mat-checkbox (change)=\"$event ? masterToggle() : null\"\r\n                    [checked]=\"!!(masterToggleChecked$ | async)\"\r\n                    [indeterminate]=\"masterToggleIndeterminate$ | async\">\r\n      </mat-checkbox>\r\n    </mat-header-cell>\r\n\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <mat-checkbox\r\n      (click)=\"$event.stopPropagation()\"\r\n      (change)=\"$event ? selection.toggle(row) : null\"\r\n      [checked]=\"selection.isSelected(row)\"/>\r\n    </mat-cell>\r\n\r\n    <mat-footer-cell *matFooterCellDef>\r\n      {{ selection.selected.length }}\r\n    </mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- index column -->\r\n  <ng-container matColumnDef=\"index\">\r\n      <mat-header-cell *matHeaderCellDef class=\"f-mat-header-cell\" >#</mat-header-cell>\r\n      <mat-cell *matCellDef=\"let i = index;\">\r\n         {{ 1 + i + offsetIndex}}\r\n      </mat-cell>\r\n      <mat-footer-cell *matFooterCellDef></mat-footer-cell>\r\n  </ng-container>\r\n\r\n  <!-- Grouping -->\r\n  <ng-container matColumnDef=\"groupHeader\">\r\n    <mat-cell *matCellDef=\"let row\">\r\n      <div [style.paddingLeft]=\"row.padding + 'px !important'\" *ngrxLet=\"(state.getIsExpanded | func : row.key : row.groupName ) as expanded\">\r\n        <button mat-icon-button (click)=\"setExpanded(row.key, row.groupName, !expanded);\">\r\n          @if(!expanded){\r\n            <mat-icon>chevron_right</mat-icon>\r\n          } @else {\r\n            <mat-icon>expand_more</mat-icon>\r\n          }\r\n        </button>\r\n        {{getTransform | func : row.key :  row.groupHeaderDisplay}} ({{row.length}})\r\n      </div>\r\n      <div style=\"flex-grow: 1\">\r\n        <ng-container *ngTemplateOutlet=\"state.props().groupHeaderTemplate!; context: { element: row }\"></ng-container>\r\n      </div>\r\n    </mat-cell>\r\n  </ng-container>\r\n\r\n  @if(showHeader$ | async){\r\n    <mat-header-row *matHeaderRowDef=\"keys; sticky: state.props().isSticky\" [style.top.px]=\"((offset$ | async)! * -1)\"  />\r\n  }\r\n  <mat-row *matRowDef=\"let row; columns: keys; let i = index\" />\r\n  <mat-row *matRowDef=\"let row; columns: ['groupHeader']; when: isGroupHeader\" style=\"background-color: white;\" />\r\n  <mat-footer-row *matFooterRowDef=\"(showFooterRow$ | async) === 'regular-footer' ? keys : []; sticky: state.props().stickyFooter \"  [style.bottom.px]=\"state.props().stickyFooter ? (offset$ | async) : undefined\"  />\r\n\r\n</mat-table>\r\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { ComponentStore } from "@ngrx/component-store";
|
|
2
2
|
import { Injectable } from "@angular/core";
|
|
3
3
|
import { filter, tap } from "rxjs";
|
|
4
|
-
import { concatLatestFrom } from
|
|
4
|
+
import { concatLatestFrom } from '@ngrx/operators';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class TableBuilderStateStore extends ComponentStore {
|
|
7
7
|
constructor() {
|
|
@@ -112,4 +112,4 @@ export const defaultStorageState = {
|
|
|
112
112
|
globalProfiles: {},
|
|
113
113
|
localProfiles: {}
|
|
114
114
|
};
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tableBuilderStateStore.js","sourceRoot":"","sources":["../../../../../projects/angular-utilities/src/table-builder/ngrx/tableBuilderStateStore.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentStore } from \"@ngrx/component-store\";\r\nimport { Injectable } from \"@angular/core\";\r\nimport { Observable, filter, tap } from \"rxjs\";\r\nimport { concatLatestFrom } from \"@ngrx/effects\";\r\nimport { Dictionary } from \"../interfaces/dictionary\";\r\n\r\n@Injectable({ providedIn: 'root'})\r\nexport class TableBuilderStateStore extends ComponentStore<GlobalStorageState> {\r\n  constructor(){\r\n    super(loadGlobalStorageState())\r\n  }\r\n\r\n  //selectors\r\n  selectLocalProfile = (key:string) => this.select(state => \r\n    state.localProfiles[key]);\r\n  \r\n  selectLocalProfileState = (key:string) => this.select(\r\n    this.selectLocalProfile(key),\r\n    (profile: Profile) => {\r\n      if(profile) {\r\n        return  profile.states[profile.current ?? profile.default];\r\n      }\r\n      return null;\r\n  });\r\n\r\n  selectLocalProfileCurrentKey = (key:string) => this.select(\r\n    this.selectLocalProfile(key),\r\n    (profile: Profile) => {\r\n      if(profile) {\r\n        return  profile.current ?? profile.default;\r\n      }\r\n      return 'default';\r\n  });\r\n\r\n  selectLocalProfileKeys = <T>(key:string) =>  this.select(\r\n    this.selectLocalProfile(key),\r\n    (profile: Profile<T>) => {\r\n      if(profile) {\r\n        return  Object.keys(profile.states).filter( key => key);\r\n      }\r\n      return null;\r\n  });\r\n\r\n\r\n  // reducers\r\n  setLocalProfile = this.updater((state, props: { key: string, value: any }) => {\r\n    let profile = state.localProfiles[props.key];\r\n    if(!profile) {\r\n      profile =  {default: 'default', current: 'default', states : {\r\n        default: props.value\r\n      }};\r\n    } else {\r\n      profile = {...profile, states: {...profile.states, [profile.current ?? profile.default] : props.value} };\r\n    }\r\n    return {...state, localProfiles: {...state.localProfiles, [props.key]: profile} }\r\n  });\r\n\r\n  setLocalProfilesState = this.updater((state, props: { key: string, current: string }) => {\r\n    let profile = state.localProfiles[props.key];\r\n    if(!profile) {\r\n      profile =  {default: props.current, current: props.current , states : {[props.current]: null }};\r\n    } else {\r\n      const state = profile.states[props.current] ?? profile.states[profile.current ?? profile.default];\r\n      profile = {...profile, current: props.current, states: {...profile.states, [props.current] : state }};\r\n    }\r\n    return {...state, localProfiles: {...state.localProfiles, [props.key]: profile}};\r\n  });\r\n\r\n  deleteLocalProfilesState = this.updater((state, props: { key: string, stateKey: string }) => {\r\n    let profile = state.localProfiles[props.key];\r\n    if(profile) {\r\n      const current = profile.current === props.stateKey ? profile.default : profile.current;\r\n      profile = {...profile,current, states: { ...profile.states}};\r\n      delete profile.states[props.stateKey];\r\n      return {...state, localProfiles: {...state.localProfiles, [props.key]: profile} };\r\n    } else {\r\n      return state;\r\n    }\r\n  });\r\n\r\n  // effects\r\n  saveLocalProfile = this.effect((props$: Observable<{ key: string, value: any, persist?: boolean }>) => props$.pipe(\r\n    filter( action => !!action.persist),\r\n    concatLatestFrom((action) =>  this.selectLocalProfile(action.key)),\r\n    tap( ([action, profile]) => {\r\n      const globalSavedState: GlobalStorageState = JSON.parse(localStorage.getItem('global-state-storage') ?? JSON.stringify(defaultStorageState) );\r\n      if(!profile) {\r\n        profile =  {default: 'default', current: 'default', states : {default: action.value}};\r\n        globalSavedState.localProfiles[action.key] = profile;\r\n      } {\r\n        if(!globalSavedState.localProfiles[action.key]) {\r\n          globalSavedState.localProfiles[action.key] = {...profile,states: {[profile.current ?? profile.default]: action.value}};\r\n        } else {\r\n          globalSavedState.localProfiles[action.key].states[profile.current ?? profile.default] = action.value;\r\n        }\r\n\r\n      }\r\n      localStorage.setItem('global-state-storage', JSON.stringify( globalSavedState));\r\n      this.setLocalProfile(action);\r\n    })\r\n  ));\r\n\r\n  deleteLocalProfile = this.effect((props$: Observable<{ key: string, stateKey: string }>) => props$.pipe(\r\n    tap((props) => {\r\n      const globalSavedState: GlobalStorageState = JSON.parse(localStorage.getItem('global-state-storage') ?? JSON.stringify(defaultStorageState) );\r\n        if(!globalSavedState.localProfiles[props.key]) {\r\n          return;\r\n        } else {\r\n          delete globalSavedState.localProfiles[props.key].states[props.stateKey];\r\n        }\r\n      localStorage.setItem('global-state-storage', JSON.stringify( globalSavedState));\r\n      this.deleteLocalProfilesState(props)\r\n    })\r\n  ))\r\n}\r\n\r\nfunction loadGlobalStorageState() : GlobalStorageState {\r\n  const storage = localStorage.getItem('global-state-storage');\r\n  if(storage) {\r\n    return {...defaultStorageState, ...JSON.parse(storage)};\r\n  }\r\n  return defaultStorageState;\r\n}\r\n\r\nexport interface Profile<T = any> {\r\n  default: string;\r\n  current: string;\r\n  states: Dictionary<T>;\r\n}\r\n\r\nexport interface GlobalStorageState {\r\n  globalProfileKeys : string [];\r\n  currentGlobalProfile: string;\r\n  globalProfiles: Dictionary<Profile>;\r\n  localProfiles: Dictionary<Profile>;\r\n}\r\n\r\nexport const defaultStorageState: GlobalStorageState = {\r\n  globalProfileKeys: ['Default'],\r\n  currentGlobalProfile: 'Default',\r\n  globalProfiles: {},\r\n  localProfiles: {}\r\n}"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tableBuilderStateStore.js","sourceRoot":"","sources":["../../../../../projects/angular-utilities/src/table-builder/ngrx/tableBuilderStateStore.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentStore } from \"@ngrx/component-store\";\r\nimport { Injectable } from \"@angular/core\";\r\nimport { Observable, filter, tap } from \"rxjs\";\r\nimport { concatLatestFrom } from '@ngrx/operators';\r\nimport { Dictionary } from \"../interfaces/dictionary\";\r\n\r\n@Injectable({ providedIn: 'root'})\r\nexport class TableBuilderStateStore extends ComponentStore<GlobalStorageState> {\r\n  constructor(){\r\n    super(loadGlobalStorageState())\r\n  }\r\n\r\n  //selectors\r\n  selectLocalProfile = (key:string) => this.select(state => \r\n    state.localProfiles[key]);\r\n  \r\n  selectLocalProfileState = (key:string) => this.select(\r\n    this.selectLocalProfile(key),\r\n    (profile: Profile) => {\r\n      if(profile) {\r\n        return  profile.states[profile.current ?? profile.default];\r\n      }\r\n      return null;\r\n  });\r\n\r\n  selectLocalProfileCurrentKey = (key:string) => this.select(\r\n    this.selectLocalProfile(key),\r\n    (profile: Profile) => {\r\n      if(profile) {\r\n        return  profile.current ?? profile.default;\r\n      }\r\n      return 'default';\r\n  });\r\n\r\n  selectLocalProfileKeys = <T>(key:string) =>  this.select(\r\n    this.selectLocalProfile(key),\r\n    (profile: Profile<T>) => {\r\n      if(profile) {\r\n        return  Object.keys(profile.states).filter( key => key);\r\n      }\r\n      return null;\r\n  });\r\n\r\n\r\n  // reducers\r\n  setLocalProfile = this.updater((state, props: { key: string, value: any }) => {\r\n    let profile = state.localProfiles[props.key];\r\n    if(!profile) {\r\n      profile =  {default: 'default', current: 'default', states : {\r\n        default: props.value\r\n      }};\r\n    } else {\r\n      profile = {...profile, states: {...profile.states, [profile.current ?? profile.default] : props.value} };\r\n    }\r\n    return {...state, localProfiles: {...state.localProfiles, [props.key]: profile} }\r\n  });\r\n\r\n  setLocalProfilesState = this.updater((state, props: { key: string, current: string }) => {\r\n    let profile = state.localProfiles[props.key];\r\n    if(!profile) {\r\n      profile =  {default: props.current, current: props.current , states : {[props.current]: null }};\r\n    } else {\r\n      const state = profile.states[props.current] ?? profile.states[profile.current ?? profile.default];\r\n      profile = {...profile, current: props.current, states: {...profile.states, [props.current] : state }};\r\n    }\r\n    return {...state, localProfiles: {...state.localProfiles, [props.key]: profile}};\r\n  });\r\n\r\n  deleteLocalProfilesState = this.updater((state, props: { key: string, stateKey: string }) => {\r\n    let profile = state.localProfiles[props.key];\r\n    if(profile) {\r\n      const current = profile.current === props.stateKey ? profile.default : profile.current;\r\n      profile = {...profile,current, states: { ...profile.states}};\r\n      delete profile.states[props.stateKey];\r\n      return {...state, localProfiles: {...state.localProfiles, [props.key]: profile} };\r\n    } else {\r\n      return state;\r\n    }\r\n  });\r\n\r\n  // effects\r\n  saveLocalProfile = this.effect((props$: Observable<{ key: string, value: any, persist?: boolean }>) => props$.pipe(\r\n    filter( action => !!action.persist),\r\n    concatLatestFrom((action) =>  this.selectLocalProfile(action.key)),\r\n    tap( ([action, profile]) => {\r\n      const globalSavedState: GlobalStorageState = JSON.parse(localStorage.getItem('global-state-storage') ?? JSON.stringify(defaultStorageState) );\r\n      if(!profile) {\r\n        profile =  {default: 'default', current: 'default', states : {default: action.value}};\r\n        globalSavedState.localProfiles[action.key] = profile;\r\n      } {\r\n        if(!globalSavedState.localProfiles[action.key]) {\r\n          globalSavedState.localProfiles[action.key] = {...profile,states: {[profile.current ?? profile.default]: action.value}};\r\n        } else {\r\n          globalSavedState.localProfiles[action.key].states[profile.current ?? profile.default] = action.value;\r\n        }\r\n\r\n      }\r\n      localStorage.setItem('global-state-storage', JSON.stringify( globalSavedState));\r\n      this.setLocalProfile(action);\r\n    })\r\n  ));\r\n\r\n  deleteLocalProfile = this.effect((props$: Observable<{ key: string, stateKey: string }>) => props$.pipe(\r\n    tap((props) => {\r\n      const globalSavedState: GlobalStorageState = JSON.parse(localStorage.getItem('global-state-storage') ?? JSON.stringify(defaultStorageState) );\r\n        if(!globalSavedState.localProfiles[props.key]) {\r\n          return;\r\n        } else {\r\n          delete globalSavedState.localProfiles[props.key].states[props.stateKey];\r\n        }\r\n      localStorage.setItem('global-state-storage', JSON.stringify( globalSavedState));\r\n      this.deleteLocalProfilesState(props)\r\n    })\r\n  ))\r\n}\r\n\r\nfunction loadGlobalStorageState() : GlobalStorageState {\r\n  const storage = localStorage.getItem('global-state-storage');\r\n  if(storage) {\r\n    return {...defaultStorageState, ...JSON.parse(storage)};\r\n  }\r\n  return defaultStorageState;\r\n}\r\n\r\nexport interface Profile<T = any> {\r\n  default: string;\r\n  current: string;\r\n  states: Dictionary<T>;\r\n}\r\n\r\nexport interface GlobalStorageState {\r\n  globalProfileKeys : string [];\r\n  currentGlobalProfile: string;\r\n  globalProfiles: Dictionary<Profile>;\r\n  localProfiles: Dictionary<Profile>;\r\n}\r\n\r\nexport const defaultStorageState: GlobalStorageState = {\r\n  globalProfileKeys: ['Default'],\r\n  currentGlobalProfile: 'Default',\r\n  globalProfiles: {},\r\n  localProfiles: {}\r\n}"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { inject } from "@angular/core";
|
|
1
|
+
import { createComponent, inject } from "@angular/core";
|
|
2
2
|
import { Injectable } from "@angular/core";
|
|
3
3
|
import { ArrayStyle, FieldType } from "../interfaces/report-def";
|
|
4
4
|
import { InitializationComponent } from "../components/initialization-component/initialization-component";
|
|
@@ -39,18 +39,19 @@ export class TableTemplateService {
|
|
|
39
39
|
}
|
|
40
40
|
return tmp;
|
|
41
41
|
}
|
|
42
|
-
constructor(
|
|
42
|
+
constructor(ei) {
|
|
43
43
|
this.tableConfig = inject(TableBuilderConfigToken);
|
|
44
|
-
const
|
|
45
|
-
|
|
44
|
+
const c = createComponent(InitializationComponent, {
|
|
45
|
+
environmentInjector: ei,
|
|
46
|
+
});
|
|
46
47
|
this.instance = c.instance;
|
|
47
48
|
this.initTemplates();
|
|
48
49
|
}
|
|
49
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, deps: [{ token: i0.
|
|
50
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, deps: [{ token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
50
51
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, providedIn: 'root' }); }
|
|
51
52
|
}
|
|
52
53
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, decorators: [{
|
|
53
54
|
type: Injectable,
|
|
54
55
|
args: [{ providedIn: 'root' }]
|
|
55
|
-
}], ctorParameters: () => [{ type: i0.
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
}], ctorParameters: () => [{ type: i0.EnvironmentInjector }] });
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtdGVtcGxhdGUtc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy90YWJsZS1idWlsZGVyL3NlcnZpY2VzL3RhYmxlLXRlbXBsYXRlLXNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQyxlQUFlLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxVQUFVLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFDeEQsT0FBTyxFQUFtQixVQUFVLEVBQUUsU0FBUyxFQUFZLE1BQU0sMEJBQTBCLENBQUM7QUFDNUYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0saUVBQWlFLENBQUM7QUFDMUcsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sK0JBQStCLENBQUM7O0FBR3hFLE1BQU0sT0FBTyxvQkFBb0I7SUFJL0IsYUFBYTtRQUNYLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsb0JBQW9CLENBQUM7UUFDckUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsa0JBQWtCLENBQUM7UUFDeEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUM7UUFDbEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUM7UUFDbkUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFD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UUFDM0IsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ3ZCLENBQUM7OEdBOUNVLG9CQUFvQjtrSEFBcEIsb0JBQW9CLGNBRFIsTUFBTTs7MkZBQ2xCLG9CQUFvQjtrQkFEaEMsVUFBVTttQkFBQyxFQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbnZpcm9ubWVudEluamVjdG9yLCBJbmplY3RvciwgY3JlYXRlQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBJbmplY3RhYmxlLCBUZW1wbGF0ZVJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEFycmF5QWRkaXRpb25hbCwgQXJyYXlTdHlsZSwgRmllbGRUeXBlLCBNZXRhRGF0YSB9IGZyb20gXCIuLi9pbnRlcmZhY2VzL3JlcG9ydC1kZWZcIjtcclxuaW1wb3J0IHsgSW5pdGlhbGl6YXRpb25Db21wb25lbnQgfSBmcm9tIFwiLi4vY29tcG9uZW50cy9pbml0aWFsaXphdGlvbi1jb21wb25lbnQvaW5pdGlhbGl6YXRpb24tY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IFRhYmxlQnVpbGRlckNvbmZpZ1Rva2VuIH0gZnJvbSBcIi4uL2NsYXNzZXMvVGFibGVCdWlsZGVyQ29uZmlnXCI7XHJcblxyXG5ASW5qZWN0YWJsZSh7cHJvdmlkZWRJbjogJ3Jvb3QnfSlcclxuZXhwb3J0IGNsYXNzIFRhYmxlVGVtcGxhdGVTZXJ2aWNlIHtcclxuICBpbnN0YW5jZSE6IEluaXRpYWxpemF0aW9uQ29tcG9uZW50O1xyXG4gIHRlbXBsYXRlcztcclxuXHJcbiAgaW5pdFRlbXBsYXRlcygpIHtcclxuICAgIHRoaXMudGVtcGxhdGVzID0geyB9O1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkFycmF5XSA9IHRoaXMuaW5zdGFuY2UuYXJyYXlOZXdMaW5lVGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuQXJyYXkgKyAuNV0gPSB0aGlzLmluc3RhbmNlLmFycmF5Q29tbWFUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5Cb29sZWFuXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFdpdGhJY29uO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkN1cnJlbmN5XSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkRhdGVdID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuRGF0ZVRpbWVdID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuRXhwcmVzc2lvbl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5Ob3RNYXBwZWRdID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuSW1hZ2VVcmxdID0gdGhpcy5pbnN0YW5jZS5pbWFnZVVybFRlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkxpbmtdID0gdGhpcy5pbnN0YW5jZS5saW5rVGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuTGluayArIC41XSA9IHRoaXMuaW5zdGFuY2Uucm91dGVyTGlua1RlbXBsYXRlO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLk51bWJlcl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5QaG9uZU51bWJlcl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5TdHJpbmddID0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGU7XHJcbiAgICB0aGlzLnRlbXBsYXRlc1tGaWVsZFR5cGUuVW5rbm93bl0gPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRUZW1wbGF0ZTtcclxuICAgIHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5FbnVtXSA9IHRoaXMuaW5zdGFuY2UuZGVmYXVsdFRlbXBsYXRlO1xyXG4gIH1cclxuICBnZXRUZW1wbGF0ZShtZXRhRGF0YTogTWV0YURhdGEpIDogVGVtcGxhdGVSZWY8YW55PiB7XHJcblxyXG4gICAgbGV0IHRtcCA9IG1ldGFEYXRhLmZpZWxkVHlwZSA9PT0gRmllbGRUeXBlLkxpbmsgJiYgbWV0YURhdGEuYWRkaXRpb25hbD8ubGluaz8udXNlUm91dGVyTGlua1xyXG4gICAgICA/IHRoaXMudGVtcGxhdGVzW0ZpZWxkVHlwZS5MaW5rICsgLjVdIFxyXG4gICAgICA6IFxyXG4gICAgICBtZXRhRGF0YS5maWVsZFR5cGUgPT09IEZpZWxkVHlwZS5BcnJheSAmJiAoKG1ldGFEYXRhLmFkZGl0aW9uYWwgYXMgQXJyYXlBZGRpdGlvbmFsKT8uYXJyYXlTdHlsZSA9PT0gQXJyYXlTdHlsZS5Db21tYURlbGltaXRlZCB8fCB0aGlzLnRhYmxlQ29uZmlnPy5hcnJheUluZm8/LmFycmF5U3R5bGUgPT09IEFycmF5U3R5bGUuQ29tbWFEZWxpbWl0ZWQpXHJcbiAgICAgID8gdGhpcy50ZW1wbGF0ZXNbRmllbGRUeXBlLkFycmF5ICsgLjVdIFxyXG4gICAgICA6XHJcbiAgICAgIHRoaXMudGVtcGxhdGVzW21ldGFEYXRhLmZpZWxkVHlwZV07XHJcbiAgICBpZihtZXRhRGF0YS51c2VJY29uKSB7XHJcbiAgICAgIGlmKHRtcCA9PT0gdGhpcy5pbnN0YW5jZS5kZWZhdWx0VGVtcGxhdGUpIHtcclxuICAgICAgICB0bXAgPSB0aGlzLmluc3RhbmNlLmRlZmF1bHRXaXRoSWNvbjtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgcmV0dXJuIHRtcDtcclxuICB9XHJcblxyXG4gIGNvbnN0cnVjdG9yKGVpOiBFbnZpcm9ubWVudEluamVjdG9yICApIHtcclxuICAgIGNvbnN0IGMgPSBjcmVhdGVDb21wb25lbnQoSW5pdGlhbGl6YXRpb25Db21wb25lbnQsIHtcclxuICAgICAgZW52aXJvbm1lbnRJbmplY3RvcjogZWksXHJcbiAgICB9KTtcclxuICAgIHRoaXMuaW5zdGFuY2UgPSBjLmluc3RhbmNlO1xyXG4gICAgdGhpcy5pbml0VGVtcGxhdGVzKCk7XHJcbiAgfVxyXG5cclxuICB0YWJsZUNvbmZpZyA9IGluamVjdChUYWJsZUJ1aWxkZXJDb25maWdUb2tlbik7XHJcbn1cclxuIl19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Directive, Input, NgModule, Injectable, assertInInjectionContext, DestroyRef, inject, Pipe, Optional, Injector, booleanAttribute, InjectionToken, makeEnvironmentProviders, Inject, HostListener, Component, ChangeDetectionStrategy, EventEmitter, Output, ContentChildren, ViewChild, input, computed, forwardRef, ElementRef, ContentChild, APP_INITIALIZER } from '@angular/core';
|
|
2
|
+
import { Directive, Input, NgModule, Injectable, assertInInjectionContext, DestroyRef, inject, Pipe, Optional, Injector, booleanAttribute, InjectionToken, makeEnvironmentProviders, Inject, HostListener, Component, ChangeDetectionStrategy, EventEmitter, Output, ContentChildren, ViewChild, input, computed, createComponent, forwardRef, ElementRef, ContentChild, APP_INITIALIZER } from '@angular/core';
|
|
3
3
|
import { shareReplay, map, switchAll, filter, tap, catchError, startWith, switchMap, mergeMap, concatMap, takeUntil, distinctUntilChanged, last, first as first$1, distinctUntilKeyChanged, delay as delay$1, mergeAll as mergeAll$1, scan as scan$1, timestamp as timestamp$1, withLatestFrom } from 'rxjs/operators';
|
|
4
4
|
import * as i3$1 from 'rxjs';
|
|
5
5
|
import { isObservable, Subject, of, ReplaySubject, filter as filter$1, first, map as map$1, Observable, combineLatest, Subscription, startWith as startWith$1, pairwise, concatMap as concatMap$1, merge as merge$1, delay, fromEvent, tap as tap$1, BehaviorSubject, takeUntil as takeUntil$1, switchMap as switchMap$1, scan, asyncScheduler, distinctUntilChanged as distinctUntilChanged$1, timestamp, mergeAll, from } from 'rxjs';
|
|
@@ -52,7 +52,7 @@ import { MatChipsModule } from '@angular/material/chips';
|
|
|
52
52
|
import * as i3$3 from '@angular/material/table';
|
|
53
53
|
import { MatColumnDef, MatTableModule, MatTable, MatTableDataSource, MatRowDef } from '@angular/material/table';
|
|
54
54
|
import { SelectionModel } from '@angular/cdk/collections';
|
|
55
|
-
import { concatLatestFrom } from '@ngrx/
|
|
55
|
+
import { concatLatestFrom } from '@ngrx/operators';
|
|
56
56
|
import * as i2$1 from '@angular/material/paginator';
|
|
57
57
|
import { MatPaginator, MatPaginatorModule } from '@angular/material/paginator';
|
|
58
58
|
import * as i2$2 from '@angular/cdk/scrolling';
|
|
@@ -3497,20 +3497,21 @@ class TableTemplateService {
|
|
|
3497
3497
|
}
|
|
3498
3498
|
return tmp;
|
|
3499
3499
|
}
|
|
3500
|
-
constructor(
|
|
3500
|
+
constructor(ei) {
|
|
3501
3501
|
this.tableConfig = inject(TableBuilderConfigToken);
|
|
3502
|
-
const
|
|
3503
|
-
|
|
3502
|
+
const c = createComponent(InitializationComponent, {
|
|
3503
|
+
environmentInjector: ei,
|
|
3504
|
+
});
|
|
3504
3505
|
this.instance = c.instance;
|
|
3505
3506
|
this.initTemplates();
|
|
3506
3507
|
}
|
|
3507
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, deps: [{ token: i0.
|
|
3508
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, deps: [{ token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
3508
3509
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, providedIn: 'root' }); }
|
|
3509
3510
|
}
|
|
3510
3511
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: TableTemplateService, decorators: [{
|
|
3511
3512
|
type: Injectable,
|
|
3512
3513
|
args: [{ providedIn: 'root' }]
|
|
3513
|
-
}], ctorParameters: () => [{ type: i0.
|
|
3514
|
+
}], ctorParameters: () => [{ type: i0.EnvironmentInjector }] });
|
|
3514
3515
|
|
|
3515
3516
|
class ColumnBuilderComponent {
|
|
3516
3517
|
get metaData() {
|
|
@@ -3736,7 +3737,8 @@ class GenericTableComponent {
|
|
|
3736
3737
|
});
|
|
3737
3738
|
this.state.on(this.state.props().dataSource.viewableData$, (data) => {
|
|
3738
3739
|
if (this.selection.selected.length) {
|
|
3739
|
-
const
|
|
3740
|
+
const trackByFunction = this.trackBy ? (s) => data.every(d => d[this.trackBy] !== s[this.trackBy]) : s => !data.includes(s);
|
|
3741
|
+
const removed = this.selection.selected.filter(trackByFunction);
|
|
3740
3742
|
this.selection.deselect(...removed);
|
|
3741
3743
|
}
|
|
3742
3744
|
});
|