@elderbyte/ngx-starter 12.11.0 → 12.12.3
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/bundles/elderbyte-ngx-starter.umd.js +75 -60
- package/bundles/elderbyte-ngx-starter.umd.js.map +1 -1
- package/elderbyte-ngx-starter.metadata.json +1 -1
- package/esm2015/lib/components/auditing/audited-entity/elder-audited-entity.component.js +2 -2
- package/esm2015/lib/components/data-view/base/elder-data-view-base.js +46 -3
- package/esm2015/lib/components/data-view/grid/elder-grid/elder-grid.component.js +24 -6
- package/esm2015/lib/components/data-view/grid/elder-grid.module.js +3 -2
- package/esm2015/lib/components/data-view/table/elder-table/elder-table.component.js +5 -48
- package/fesm2015/elderbyte-ngx-starter.js +68 -53
- package/fesm2015/elderbyte-ngx-starter.js.map +1 -1
- package/lib/components/data-view/base/elder-data-view-base.d.ts +11 -1
- package/lib/components/data-view/grid/elder-grid/elder-grid.component.d.ts +9 -6
- package/lib/components/data-view/table/elder-table/elder-table.component.d.ts +5 -10
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, Directive, forwardRef, Input, NgZone, Optional,
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, Directive, forwardRef, Input, NgZone, Optional, SkipSelf, TemplateRef, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';
|
|
2
2
|
import { MatTableDataContextBindingBuilder } from '../../../../common/data/data-context/mat-table-data-context-binding';
|
|
3
3
|
import { MatPaginator } from '@angular/material/paginator';
|
|
4
4
|
import { MatSort } from '@angular/material/sort';
|
|
@@ -58,7 +58,6 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
58
58
|
**************************************************************************/
|
|
59
59
|
this.logger = LoggerFactory.getLogger(this.constructor.name);
|
|
60
60
|
this.destroy$ = new Subject();
|
|
61
|
-
this._itemClickSubject = new Subject();
|
|
62
61
|
/**
|
|
63
62
|
* Load next chunk after current is done
|
|
64
63
|
*/
|
|
@@ -89,7 +88,6 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
89
88
|
this.cleanUp = true;
|
|
90
89
|
this.keepSelection = true;
|
|
91
90
|
this.showFooter = false;
|
|
92
|
-
this.interactionMode = 'open';
|
|
93
91
|
this.toolbarRowTemplates$ = new BehaviorSubject([]);
|
|
94
92
|
/**
|
|
95
93
|
* Gets the current rows of this table.
|
|
@@ -168,7 +166,7 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
168
166
|
if (data instanceof Array) {
|
|
169
167
|
dc = DataContextBuilder.start()
|
|
170
168
|
.localSort()
|
|
171
|
-
.buildLocal(data); // Potential Memory leak (See autoCleanUp)
|
|
169
|
+
.buildLocal(data, this.idField); // Potential Memory leak (See autoCleanUp)
|
|
172
170
|
dc.start();
|
|
173
171
|
}
|
|
174
172
|
else if (isDataSource(data)) {
|
|
@@ -213,9 +211,6 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
213
211
|
get selectionVisible() {
|
|
214
212
|
return this.tableModel.selectionVisible;
|
|
215
213
|
}
|
|
216
|
-
get itemClick() {
|
|
217
|
-
return this._itemClickSubject;
|
|
218
|
-
}
|
|
219
214
|
/*
|
|
220
215
|
@Output()
|
|
221
216
|
public get activeItem(): Observable<any> {
|
|
@@ -250,42 +245,6 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
250
245
|
get trackByFn() {
|
|
251
246
|
return (index, entity) => this.getId(entity);
|
|
252
247
|
}
|
|
253
|
-
/**
|
|
254
|
-
* Occurs when the user clicks on a row
|
|
255
|
-
*/
|
|
256
|
-
onItemClick(entity) {
|
|
257
|
-
switch (this.interactionMode) {
|
|
258
|
-
case 'open':
|
|
259
|
-
if (this.selectionModel.hasValue) {
|
|
260
|
-
this.selectionModel.toggle(entity);
|
|
261
|
-
}
|
|
262
|
-
else {
|
|
263
|
-
this._itemClickSubject.next(entity);
|
|
264
|
-
}
|
|
265
|
-
break;
|
|
266
|
-
case 'selection':
|
|
267
|
-
this.selectionModel.toggle(entity);
|
|
268
|
-
break;
|
|
269
|
-
// TODO improve onItemDoubleClick behavior with Observable
|
|
270
|
-
/*
|
|
271
|
-
clickStream
|
|
272
|
-
.bufferTime(250)
|
|
273
|
-
.map(arr => arr.length)
|
|
274
|
-
.filter(len => len === 2);
|
|
275
|
-
*/
|
|
276
|
-
}
|
|
277
|
-
}
|
|
278
|
-
onItemDoubleClick(entity) {
|
|
279
|
-
switch (this.interactionMode) {
|
|
280
|
-
// double click in open mode not supported
|
|
281
|
-
case 'open':
|
|
282
|
-
break;
|
|
283
|
-
// double click in selection mode triggers normal item click
|
|
284
|
-
case 'selection':
|
|
285
|
-
this._itemClickSubject.next(entity);
|
|
286
|
-
break;
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
248
|
/***************************************************************************
|
|
290
249
|
* *
|
|
291
250
|
* Private Methods *
|
|
@@ -326,7 +285,7 @@ export class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
326
285
|
ElderTableComponent.decorators = [
|
|
327
286
|
{ type: Component, args: [{
|
|
328
287
|
selector: 'elder-table, ebs-table',
|
|
329
|
-
template: "\n<div fxLayout=\"column\" fxFlex\n class=\"elder-table\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n <!-- Toolbar Rows -->\n <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n </ng-template>\n </ng-container>\n\n <!-- Scrollable Table -->\n <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n infiniteScroll\n [eventThrottle]=\"150\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n (closeToEnd)=\"requestMoreDataZoned($event)\"\n >\n <table\n mat-table\n class=\"elder-mat-inner-table\"\n [trackBy]=\"trackByFn\"\n [dataSource]=\"dataContext$ | async\"\n [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- selection Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <elder-selection-master-checkbox></elder-selection-master-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selectionModel.toggle(entity) : null\"\n [checked]=\"selectionModel.observeSelection(entity) | async\"\n [disabled]=\"!selectionModel.isSelectable(entity)\"\n class=\"elder-table-checkbox\"\n [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n >\n </mat-checkbox>\n </td>\n <td mat-footer-cell *matFooterCellDef></td>\n </ng-container>\n\n <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n <tr mat-row class=\"elder-table-row\"\n *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n [elderTableRow]=\"entity\"\n [class.dense]=\"dense\"\n [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n [class.elder-row-removing]=\"removingField && entity[removingField]\"\n [class.elder-table-row-selected]=\"interactionMode == 'selection' && selectionModel.observeSelection(entity) | async\"\n (click)=\"
|
|
288
|
+
template: "\n<div fxLayout=\"column\" fxFlex\n class=\"elder-table\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n <!-- Toolbar Rows -->\n <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n </ng-template>\n </ng-container>\n\n <!-- Scrollable Table -->\n <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n infiniteScroll\n [eventThrottle]=\"150\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n (closeToEnd)=\"requestMoreDataZoned($event)\"\n >\n <table\n mat-table\n class=\"elder-mat-inner-table\"\n [trackBy]=\"trackByFn\"\n [dataSource]=\"dataContext$ | async\"\n [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- selection Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <elder-selection-master-checkbox></elder-selection-master-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selectionModel.toggle(entity) : null\"\n [checked]=\"selectionModel.observeSelection(entity) | async\"\n [disabled]=\"!selectionModel.isSelectable(entity)\"\n class=\"elder-table-checkbox\"\n [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n >\n </mat-checkbox>\n </td>\n <td mat-footer-cell *matFooterCellDef></td>\n </ng-container>\n\n <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n <tr mat-row class=\"elder-table-row\"\n *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n [elderTableRow]=\"entity\"\n [class.dense]=\"dense\"\n [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n [class.elder-row-removing]=\"removingField && entity[removingField]\"\n [class.elder-table-row-selected]=\"interactionMode == 'selection' && selectionModel.observeSelection(entity) | async\"\n (click)=\"onItemClick(entity)\"\n (dblclick)=\"onItemDoubleClick(entity)\"\n >\n </tr>\n <ng-container *ngIf=\"showFooter\">\n <tr mat-footer-row *matFooterRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n </ng-container>\n </ng-container>\n </table>\n </div>\n\n <div fxLayout=\"column\" fxFlex fxLayoutAlign=\"center center\">\n\n <span class=\"elder-table-hint mat-body-1\" *ngIf=\"(dataContext?.data | async)?.length === 0 && !(dataContext?.status | async)?.hasError\">\n {{'No data available' | translate}}\n </span>\n\n <div *ngIf=\"(dataContext?.status | async)?.hasError\"\n fxLayout=\"row\" fxLayoutAlign=\"center center\" fxLayoutGap=\"20px\">\n <mat-icon color=\"warn\">warning</mat-icon>\n <span class=\"hint mat-body-1\">{{'Error while loading data' | translate}}</span>\n </div>\n\n </div>\n\n <mat-progress-bar fxFlex=\"none\"\n [mode]=\"(dataContext?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"((dataContext?.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Optional Paginator Toolbar -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n fxFlex=\"none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Optional Continuation Footer -->\n <div *ngIf=\"isContinuable\" class=\"elder-table-footer\"\n fxLayout=\"row\" fxFlex=\"none\" fxLayoutAlign=\"end center\" fxLayoutGap=\"10px\"\n style=\"padding-right: 10px\" >\n\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataContext?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataContinuable.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </div>\n\n</div>\n",
|
|
330
289
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
331
290
|
providers: [
|
|
332
291
|
ElderTableProviders.ExistingOrNewTableModel,
|
|
@@ -360,13 +319,11 @@ ElderTableComponent.propDecorators = {
|
|
|
360
319
|
cleanUp: [{ type: Input }],
|
|
361
320
|
keepSelection: [{ type: Input }],
|
|
362
321
|
showFooter: [{ type: Input }],
|
|
363
|
-
interactionMode: [{ type: Input }],
|
|
364
322
|
toolbarRowTemplateQuery: [{ type: ContentChildren, args: [ElderTableToolbarDirective, { read: TemplateRef },] }],
|
|
365
323
|
rowsQuery: [{ type: ViewChildren, args: [ElderTableRowDirective,] }],
|
|
366
324
|
toolbarTemplate: [{ type: Input }],
|
|
367
325
|
data: [{ type: Input }],
|
|
368
326
|
displayedColumns: [{ type: Input }],
|
|
369
|
-
selectionVisible: [{ type: Input }]
|
|
370
|
-
itemClick: [{ type: Output }]
|
|
327
|
+
selectionVisible: [{ type: Input }]
|
|
371
328
|
};
|
|
372
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-table.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/elder-table/elder-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit, AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  forwardRef,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList, SkipSelf,\n  TemplateRef,\n  TrackByFunction,\n  ViewChild, ViewChildren,\n  ViewContainerRef\n} from '@angular/core';\nimport {\n  MatTableDataContextBindingBuilder\n} from '../../../../common/data/data-context/mat-table-data-context-binding';\nimport {MatPaginator} from '@angular/material/paginator';\nimport {MatSort} from '@angular/material/sort';\nimport {MatColumnDef, MatRowDef, MatTable} from '@angular/material/table';\nimport {\n  IDataContext,\n  isDataContext\n} from '../../../../common/data/data-context/data-context';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {BehaviorSubject, combineLatest, Observable, of, Subject, Subscription} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {CdkColumnDef, CdkRowDef, CdkTable} from '@angular/cdk/table';\nimport {DataContextBuilder} from '../../../../common/data/data-context/data-context-builder';\nimport {ELDER_DATA_VIEW, ElderDataViewInteractionMode} from '../../base/elder-data-view';\nimport {ElderDataViewSelectionMode} from '../../../select/popup/selection-model-popup.directive';\nimport {ElderTableRowDirective} from '../elder-table-row.directive';\nimport {IDataSource, isDataSource} from '../../../../common/data/datasource/data-source';\nimport {ElderDataViewBaseComponent} from '../../base/elder-data-view-base';\nimport {ElderTableModel} from '../model/elder-table-model';\nimport {ElderTableProviders} from '../model/elder-table-model-provider';\nimport {QueryListBinding} from '../../../../common/utils/query-list-binding';\nimport {ElderTableModelCdkTableBinding} from '../model/elder-table-model-cdk-table-binding';\nimport {ElderTableModelQueryGroup} from '../model/elder-table-model-query-group';\nimport {ElderTableExtensionDirective} from '../elder-table-extension.directive';\nimport {ElderTableColumnDirective} from '../elder-table-column.directive';\nimport {ColumnPositionSpec} from '../model/elder-column-layout';\n\n/**\n * This directive projects marked content into a toolbar.\n */\n@Directive({selector: '[elderTableToolbar]'})\nexport class ElderTableToolbarDirective {\n\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef\n  ) {\n  }\n}\n\n@Component({\n  selector: 'elder-table, ebs-table', // ebs-table is deprecated\n  templateUrl: './elder-table.component.html',\n  styleUrls: ['./elder-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    ElderTableProviders.ExistingOrNewTableModel,\n    {\n      provide: ELDER_DATA_VIEW,\n      useExisting: forwardRef(() => ElderTableComponent)\n    }\n  ]\n})\nexport class ElderTableComponent extends ElderDataViewBaseComponent implements OnInit, OnDestroy, AfterContentInit, AfterViewInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly destroy$ = new Subject();\n\n  private readonly _itemClickSubject = new Subject<any>();\n\n  /**\n   * Load next chunk after current is done\n   */\n  private loadNextQueued = false;\n\n  /// Table\n  @ViewChild(MatTable, {static: true})\n  public matTable: CdkTable<any>;\n\n  @ViewChild(MatPaginator)\n  public matPaginator: MatPaginator;\n\n  private readonly _matSort: MatSort;\n\n  @ContentChildren(MatColumnDef)\n  public columnDefs: QueryList<CdkColumnDef>;\n\n  @ContentChildren(ElderTableColumnDirective)\n  public elderColumns: QueryList<ElderTableColumnDirective>;\n\n  @ContentChildren(MatRowDef)\n  public rowDefs: QueryList<CdkRowDef<any>>;\n\n  /**\n   * @deprecated No longer required. Id is automatically picked from the DataSource.\n   */\n  @Input()\n  public idField: string;\n\n  /**\n   * When this field is present and true,\n   * the coresponding row is marked to be in the processed of being removed.\n   *\n   * I.e. 'removing'\n   */\n  @Input()\n  public removingField: string = null;\n\n  /**\n   * When this field is present and true,\n   * the corresponding row is hidden.\n   *\n   * I.e. 'deleted'\n   *\n   */\n  @Input()\n  public hiddenField: string = null;\n\n  @Input()\n  public pageSizeOptions = [30, 50, 100, 150, 200];\n\n  /**\n   * Define if elder-table should clean up the\n   * data-context resources for you.\n   *\n   * In more advanced scenarios where you plan to reuse the same data-context\n   * set this to false and release the resources yourself. (dataContext.close)\n   */\n  @Input()\n  public cleanUp = true;\n\n  @Input()\n  public keepSelection = true;\n\n  @Input()\n  public showFooter = false;\n\n  @Input()\n  public interactionMode: ElderDataViewInteractionMode = 'open';\n\n  public canLoadMore$: Observable<boolean>;\n  public total$: Observable<string>;\n\n  /**\n   * The table toolbar\n   */\n  @ContentChildren(ElderTableToolbarDirective, {read: TemplateRef})\n  public toolbarRowTemplateQuery: QueryList<TemplateRef<any>>;\n  public readonly toolbarRowTemplates$ = new BehaviorSubject<TemplateRef<any>[]>([]);\n\n  /**\n   * Selection model life cycle\n   */\n  private selectionLifeCycle: Subscription;\n\n  @ViewChildren(ElderTableRowDirective)\n  private rowsQuery: QueryList<ElderTableRowDirective<any>>;\n\n  /**\n   * Gets the current rows of this table.\n   */\n  public readonly rows$ = new BehaviorSubject<ElderTableRowDirective<any>[]>([]);\n\n  /**\n   * The index of this table group extension\n   * @private\n   */\n  private readonly _extensionGroupIndex: number;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly tableModel: ElderTableModel,\n    @Optional() selectionModel: SelectionModel<any>,\n    @Optional() @SkipSelf() dataViewSelection: ElderDataViewSelectionMode,\n    @Optional() matSort: MatSort,\n    @Optional() @SkipSelf() private readonly parentExtension: ElderTableExtensionDirective,\n    private cdr: ChangeDetectorRef,\n    private zone: NgZone\n  ) {\n    super(selectionModel, dataViewSelection);\n    this._matSort = matSort;\n    this._extensionGroupIndex = (parentExtension?.extensionGroupIndex ?? 0) + 1;\n    if (this._matSort) {\n      this._matSort.disableClear = true;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n    if (this.dataViewSelection) {\n      this.selectionVisible = true;\n      this.selectionMultiEnabled = false;\n      this.interactionMode = 'selection';\n      this.float = false;\n\n      if (this.dataContext) {\n        this.dataContext.filter.updateFilters(this.dataViewSelection.filters);\n        this.dataContext.sort.updateSorts(this.dataViewSelection.sorts);\n      }\n    }\n\n    ElderTableModelCdkTableBinding\n      .of(this.tableModel)\n      .table(this.matTable)\n      .bindUntil(this.destroy$);\n  }\n\n  public ngAfterContentInit(): void {\n\n    ElderTableModelQueryGroup\n      .start(this.tableModel, this._extensionGroupIndex)\n      .withColumnsPosition(ColumnPositionSpec.relativeToPrevGroup('start'))\n      .withColumnDefs(this.columnDefs, this.elderColumns)\n      .withRowDefs(this.rowDefs)\n      .withSort(this._matSort)\n      .bindUntil(this.destroy$);\n\n    QueryListBinding\n      .of(this.toolbarRowTemplateQuery)\n      .updated(toolbarRows => this.toolbarRowTemplates$.next(toolbarRows))\n      .bindUntil(this.destroy$);\n  }\n\n  public ngAfterViewInit(): void {\n\n    MatTableDataContextBindingBuilder\n      .start(this.dataContext$)\n      .withSorts(this.tableModel.sorts$)\n      .withPaginator(of(this.matPaginator))\n      .bindUntil(this.destroy$);\n\n    QueryListBinding\n      .of(this.rowsQuery)\n      .updated(rows => this.rows$.next(rows))\n      .bindUntil(this.destroy$);\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n    this.autoCleanUp();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * @deprecated\n   */\n  @Input()\n  public set toolbarTemplate(template: TemplateRef<any>) {\n    this.toolbarRowTemplates$.next([template]);\n  }\n\n  @Input()\n  public set data(data: Array<any> | IDataSource<any> | IDataContext<any>) {\n\n    this.autoCleanUp();\n\n    let dc: IDataContext<any>;\n\n    if (data instanceof Array) {\n      dc = DataContextBuilder.start()\n        .localSort()\n        .buildLocal(data); // Potential Memory leak (See autoCleanUp)\n      dc.start();\n    } else if (isDataSource(data)) {\n      dc = DataContextBuilder.start()\n        .localSort()\n        .reloadOnLocalChanges()\n        .build(data); // Potential Memory leak (See autoCleanUp)\n      dc.start();\n    } else if (isDataContext(data)) {\n      dc = data;\n    } else if (data === null || data === undefined) {\n      dc = DataContextBuilder.start().buildEmpty();\n    } else {\n      throw new Error('The data must either be an Array, IDataSource or IDataContext, but was: ' + (typeof data));\n    }\n    this.dataContext = dc;\n  }\n\n  protected onDataContextSet(data: IDataContext<any>): void {\n    this.total$ = data.total.pipe(\n      map(total => total ? total + '' : '∞')\n    );\n\n    this.setupSelectionLifeCycle(data);\n\n    // this.selectionModel.clear(); // TODO Support changeable data-context for static array use case\n\n    if (this.isContinuable) {\n      this.canLoadMore$ = combineLatest([data.loading, this.dataContinuable.hasMoreData]).pipe(\n        map(([loading, hasMoreData]) => !loading && hasMoreData)\n      );\n    } else {\n      this.canLoadMore$ = of(false);\n    }\n  }\n\n  @Input()\n  public set displayedColumns(displayedColumns: string[]) {\n    this.tableModel.displayedColumns = displayedColumns;\n  }\n\n  public get displayedColumns(): string[] {\n    return this.tableModel.displayedColumns;\n  }\n\n  /** Indicates if selection column is shown. */\n  @Input()\n  public set selectionVisible(visible: boolean) {\n    this.tableModel.selectionVisible = visible;\n  }\n\n  public get selectionVisible(): boolean {\n    return this.tableModel.selectionVisible;\n  }\n\n  @Output()\n  public get itemClick(): Observable<any> {\n    return this._itemClickSubject;\n  }\n\n  /*\n  @Output()\n  public get activeItem(): Observable<any> {\n    return this.elderTableActivation.activeItem$;\n  }*/\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public requestMoreDataZoned(event: any): void {\n\n    if (this.dataContinuable.hasMoreDataSnapshot) {\n\n      if (this.dataContinuable.snapshot.isLoading) {\n        this.loadNextQueued = true;\n      } else {\n        this.zone.run(() => {\n          this.dataContinuable.loadMore()\n            .subscribe(\n              loaded => {\n                if (this.loadNextQueued) {\n                  this.loadNextQueued = false;\n                  this.requestMoreDataZoned(event);\n                }\n              }\n            );\n        });\n      }\n    } else {\n      this.loadNextQueued = false;\n    }\n  }\n\n  public get trackByFn(): TrackByFunction<any> {\n    return (index: number, entity: any) => this.getId(entity);\n  }\n\n  /**\n   * Occurs when the user clicks on a row\n   */\n  public onItemClick(entity: any): void {\n\n    switch (this.interactionMode) {\n\n      case 'open':\n        if (this.selectionModel.hasValue) {\n          this.selectionModel.toggle(entity);\n        } else {\n          this._itemClickSubject.next(entity);\n        }\n        break;\n\n      case 'selection':\n        this.selectionModel.toggle(entity);\n        break;\n\n      // TODO improve onItemDoubleClick behavior with Observable\n      /*\n      clickStream\n      .bufferTime(250)\n      .map(arr => arr.length)\n      .filter(len => len === 2);\n      */\n\n    }\n\n  }\n\n  public onItemDoubleClick(entity: any): void {\n\n    switch (this.interactionMode) {\n\n      // double click in open mode not supported\n      case 'open':\n        break;\n\n      // double click in selection mode triggers normal item click\n      case 'selection':\n        this._itemClickSubject.next(entity);\n        break;\n\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private setupSelectionLifeCycle(data: IDataContext<any>): void {\n\n    if (this.selectionLifeCycle) {\n      this.selectionLifeCycle.unsubscribe(); // Clean up previous sub\n    }\n\n    this.selectionLifeCycle = data.data.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(newData => {\n\n      if (this.keepSelection) {\n        // If keep selection enabled\n        if (this.selectionModel.hasValue) {\n\n          // Check that all selected values are still present or remove them\n          const existingIds = new Set<any>(\n            newData\n              .map(d => this.getId(d))\n          );\n\n          const noLongerAvailableIds = this.selectionModel.selectionSnapshot\n            .map(selected => this.getId(selected))\n            .filter(selectedId => !existingIds.has(selectedId));\n\n          this.selectionModel.deselectIds(noLongerAvailableIds);\n        }\n      } else {\n        this.selectionModel.clear();\n      }\n    });\n  }\n\n  /**\n   * Performs clean up of the current data context if auto clean up is enabled.\n   */\n  private autoCleanUp(): void {\n    if (this.cleanUp && this.dataContext) {\n      this.logger.debug('Releasing DataContext resources to prevent memory leak. [cleanUp]=\"true\"');\n      this.dataContext.close();\n    }\n  }\n}\n"]}
|
|
329
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-table.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/table/elder-table/elder-table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  forwardRef,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n  QueryList,\n  SkipSelf,\n  TemplateRef,\n  TrackByFunction,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef\n} from '@angular/core';\nimport {MatTableDataContextBindingBuilder} from '../../../../common/data/data-context/mat-table-data-context-binding';\nimport {MatPaginator} from '@angular/material/paginator';\nimport {MatSort} from '@angular/material/sort';\nimport {MatColumnDef, MatRowDef, MatTable} from '@angular/material/table';\nimport {IDataContext, isDataContext} from '../../../../common/data/data-context/data-context';\nimport {SelectionModel} from '../../../../common/selection/selection-model';\nimport {BehaviorSubject, combineLatest, Observable, of, Subject, Subscription} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {CdkColumnDef, CdkRowDef, CdkTable} from '@angular/cdk/table';\nimport {DataContextBuilder} from '../../../../common/data/data-context/data-context-builder';\nimport {ELDER_DATA_VIEW} from '../../base/elder-data-view';\nimport {ElderDataViewSelectionMode} from '../../../select/popup/selection-model-popup.directive';\nimport {ElderTableRowDirective} from '../elder-table-row.directive';\nimport {IDataSource, isDataSource} from '../../../../common/data/datasource/data-source';\nimport {ElderDataViewBaseComponent} from '../../base/elder-data-view-base';\nimport {ElderTableModel} from '../model/elder-table-model';\nimport {ElderTableProviders} from '../model/elder-table-model-provider';\nimport {QueryListBinding} from '../../../../common/utils/query-list-binding';\nimport {ElderTableModelCdkTableBinding} from '../model/elder-table-model-cdk-table-binding';\nimport {ElderTableModelQueryGroup} from '../model/elder-table-model-query-group';\nimport {ElderTableExtensionDirective} from '../elder-table-extension.directive';\nimport {ElderTableColumnDirective} from '../elder-table-column.directive';\nimport {ColumnPositionSpec} from '../model/elder-column-layout';\n\n/**\n * This directive projects marked content into a toolbar.\n */\n@Directive({selector: '[elderTableToolbar]'})\nexport class ElderTableToolbarDirective {\n\n  constructor(\n    public templateRef: TemplateRef<any>,\n    public viewContainer: ViewContainerRef\n  ) {\n  }\n}\n\n@Component({\n  selector: 'elder-table, ebs-table', // ebs-table is deprecated\n  templateUrl: './elder-table.component.html',\n  styleUrls: ['./elder-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    ElderTableProviders.ExistingOrNewTableModel,\n    {\n      provide: ELDER_DATA_VIEW,\n      useExisting: forwardRef(() => ElderTableComponent)\n    }\n  ]\n})\nexport class ElderTableComponent extends ElderDataViewBaseComponent implements OnInit, OnDestroy, AfterContentInit, AfterViewInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly destroy$ = new Subject();\n\n  /**\n   * Load next chunk after current is done\n   */\n  private loadNextQueued = false;\n\n  /// Table\n  @ViewChild(MatTable, {static: true})\n  public matTable: CdkTable<any>;\n\n  @ViewChild(MatPaginator)\n  public matPaginator: MatPaginator;\n\n  private readonly _matSort: MatSort;\n\n  @ContentChildren(MatColumnDef)\n  public columnDefs: QueryList<CdkColumnDef>;\n\n  @ContentChildren(ElderTableColumnDirective)\n  public elderColumns: QueryList<ElderTableColumnDirective>;\n\n  @ContentChildren(MatRowDef)\n  public rowDefs: QueryList<CdkRowDef<any>>;\n\n  /**\n   * Field to identify the data records (ID field).\n   * Note: This property is only considered in case the\n   * underlying data is an Array.\n   * In case of DataContext, the ID field needs to be defined in the context.\n   * In case of DataSource, the ID field is automatically picked from the DataSource.\n   */\n  @Input()\n  public idField: string;\n\n  /**\n   * When this field is present and true,\n   * the coresponding row is marked to be in the processed of being removed.\n   *\n   * I.e. 'removing'\n   */\n  @Input()\n  public removingField: string = null;\n\n  /**\n   * When this field is present and true,\n   * the corresponding row is hidden.\n   *\n   * I.e. 'deleted'\n   *\n   */\n  @Input()\n  public hiddenField: string = null;\n\n  @Input()\n  public pageSizeOptions = [30, 50, 100, 150, 200];\n\n  /**\n   * Define if elder-table should clean up the\n   * data-context resources for you.\n   *\n   * In more advanced scenarios where you plan to reuse the same data-context\n   * set this to false and release the resources yourself. (dataContext.close)\n   */\n  @Input()\n  public cleanUp = true;\n\n  @Input()\n  public keepSelection = true;\n\n  @Input()\n  public showFooter = false;\n\n  public canLoadMore$: Observable<boolean>;\n  public total$: Observable<string>;\n\n  /**\n   * The table toolbar\n   */\n  @ContentChildren(ElderTableToolbarDirective, {read: TemplateRef})\n  public toolbarRowTemplateQuery: QueryList<TemplateRef<any>>;\n  public readonly toolbarRowTemplates$ = new BehaviorSubject<TemplateRef<any>[]>([]);\n\n  /**\n   * Selection model life cycle\n   */\n  private selectionLifeCycle: Subscription;\n\n  @ViewChildren(ElderTableRowDirective)\n  private rowsQuery: QueryList<ElderTableRowDirective<any>>;\n\n  /**\n   * Gets the current rows of this table.\n   */\n  public readonly rows$ = new BehaviorSubject<ElderTableRowDirective<any>[]>([]);\n\n  /**\n   * The index of this table group extension\n   * @private\n   */\n  private readonly _extensionGroupIndex: number;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly tableModel: ElderTableModel,\n    @Optional() selectionModel: SelectionModel<any>,\n    @Optional() @SkipSelf() dataViewSelection: ElderDataViewSelectionMode,\n    @Optional() matSort: MatSort,\n    @Optional() @SkipSelf() private readonly parentExtension: ElderTableExtensionDirective,\n    private cdr: ChangeDetectorRef,\n    private zone: NgZone\n  ) {\n    super(selectionModel, dataViewSelection);\n    this._matSort = matSort;\n    this._extensionGroupIndex = (parentExtension?.extensionGroupIndex ?? 0) + 1;\n    if (this._matSort) {\n      this._matSort.disableClear = true;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n    if (this.dataViewSelection) {\n      this.selectionVisible = true;\n      this.selectionMultiEnabled = false;\n      this.interactionMode = 'selection';\n      this.float = false;\n\n      if (this.dataContext) {\n        this.dataContext.filter.updateFilters(this.dataViewSelection.filters);\n        this.dataContext.sort.updateSorts(this.dataViewSelection.sorts);\n      }\n    }\n\n    ElderTableModelCdkTableBinding\n      .of(this.tableModel)\n      .table(this.matTable)\n      .bindUntil(this.destroy$);\n  }\n\n  public ngAfterContentInit(): void {\n\n    ElderTableModelQueryGroup\n      .start(this.tableModel, this._extensionGroupIndex)\n      .withColumnsPosition(ColumnPositionSpec.relativeToPrevGroup('start'))\n      .withColumnDefs(this.columnDefs, this.elderColumns)\n      .withRowDefs(this.rowDefs)\n      .withSort(this._matSort)\n      .bindUntil(this.destroy$);\n\n    QueryListBinding\n      .of(this.toolbarRowTemplateQuery)\n      .updated(toolbarRows => this.toolbarRowTemplates$.next(toolbarRows))\n      .bindUntil(this.destroy$);\n  }\n\n  public ngAfterViewInit(): void {\n\n    MatTableDataContextBindingBuilder\n      .start(this.dataContext$)\n      .withSorts(this.tableModel.sorts$)\n      .withPaginator(of(this.matPaginator))\n      .bindUntil(this.destroy$);\n\n    QueryListBinding\n      .of(this.rowsQuery)\n      .updated(rows => this.rows$.next(rows))\n      .bindUntil(this.destroy$);\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n    this.autoCleanUp();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * @deprecated\n   */\n  @Input()\n  public set toolbarTemplate(template: TemplateRef<any>) {\n    this.toolbarRowTemplates$.next([template]);\n  }\n\n  @Input()\n  public set data(data: Array<any> | IDataSource<any> | IDataContext<any>) {\n\n    this.autoCleanUp();\n\n    let dc: IDataContext<any>;\n\n    if (data instanceof Array) {\n      dc = DataContextBuilder.start()\n        .localSort()\n        .buildLocal(data, this.idField); // Potential Memory leak (See autoCleanUp)\n      dc.start();\n    } else if (isDataSource(data)) {\n      dc = DataContextBuilder.start()\n        .localSort()\n        .reloadOnLocalChanges()\n        .build(data); // Potential Memory leak (See autoCleanUp)\n      dc.start();\n    } else if (isDataContext(data)) {\n      dc = data;\n    } else if (data === null || data === undefined) {\n      dc = DataContextBuilder.start().buildEmpty();\n    } else {\n      throw new Error('The data must either be an Array, IDataSource or IDataContext, but was: ' + (typeof data));\n    }\n    this.dataContext = dc;\n  }\n\n  protected onDataContextSet(data: IDataContext<any>): void {\n    this.total$ = data.total.pipe(\n      map(total => total ? total + '' : '∞')\n    );\n\n    this.setupSelectionLifeCycle(data);\n\n    // this.selectionModel.clear(); // TODO Support changeable data-context for static array use case\n\n    if (this.isContinuable) {\n      this.canLoadMore$ = combineLatest([data.loading, this.dataContinuable.hasMoreData]).pipe(\n        map(([loading, hasMoreData]) => !loading && hasMoreData)\n      );\n    } else {\n      this.canLoadMore$ = of(false);\n    }\n  }\n\n  @Input()\n  public set displayedColumns(displayedColumns: string[]) {\n    this.tableModel.displayedColumns = displayedColumns;\n  }\n\n  public get displayedColumns(): string[] {\n    return this.tableModel.displayedColumns;\n  }\n\n  /** Indicates if selection column is shown. */\n  @Input()\n  public set selectionVisible(visible: boolean) {\n    this.tableModel.selectionVisible = visible;\n  }\n\n  public get selectionVisible(): boolean {\n    return this.tableModel.selectionVisible;\n  }\n\n  /*\n  @Output()\n  public get activeItem(): Observable<any> {\n    return this.elderTableActivation.activeItem$;\n  }*/\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public requestMoreDataZoned(event: any): void {\n\n    if (this.dataContinuable.hasMoreDataSnapshot) {\n\n      if (this.dataContinuable.snapshot.isLoading) {\n        this.loadNextQueued = true;\n      } else {\n        this.zone.run(() => {\n          this.dataContinuable.loadMore()\n            .subscribe(\n              loaded => {\n                if (this.loadNextQueued) {\n                  this.loadNextQueued = false;\n                  this.requestMoreDataZoned(event);\n                }\n              }\n            );\n        });\n      }\n    } else {\n      this.loadNextQueued = false;\n    }\n  }\n\n  public get trackByFn(): TrackByFunction<any> {\n    return (index: number, entity: any) => this.getId(entity);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private setupSelectionLifeCycle(data: IDataContext<any>): void {\n\n    if (this.selectionLifeCycle) {\n      this.selectionLifeCycle.unsubscribe(); // Clean up previous sub\n    }\n\n    this.selectionLifeCycle = data.data.pipe(\n      takeUntil(this.destroy$)\n    ).subscribe(newData => {\n\n      if (this.keepSelection) {\n        // If keep selection enabled\n        if (this.selectionModel.hasValue) {\n\n          // Check that all selected values are still present or remove them\n          const existingIds = new Set<any>(\n            newData\n              .map(d => this.getId(d))\n          );\n\n          const noLongerAvailableIds = this.selectionModel.selectionSnapshot\n            .map(selected => this.getId(selected))\n            .filter(selectedId => !existingIds.has(selectedId));\n\n          this.selectionModel.deselectIds(noLongerAvailableIds);\n        }\n      } else {\n        this.selectionModel.clear();\n      }\n    });\n  }\n\n  /**\n   * Performs clean up of the current data context if auto clean up is enabled.\n   */\n  private autoCleanUp(): void {\n    if (this.cleanUp && this.dataContext) {\n      this.logger.debug('Releasing DataContext resources to prevent memory leak. [cleanUp]=\"true\"');\n      this.dataContext.close();\n    }\n  }\n}\n"]}
|
|
@@ -10213,6 +10213,7 @@ class ElderDataViewBaseComponent {
|
|
|
10213
10213
|
* Underlying data context.
|
|
10214
10214
|
*/
|
|
10215
10215
|
this.dataContext$ = new BehaviorSubject(null);
|
|
10216
|
+
this.interactionMode = 'open';
|
|
10216
10217
|
/**
|
|
10217
10218
|
* If true, this table is in dense mode.
|
|
10218
10219
|
* Heights are generally reduced.
|
|
@@ -10228,6 +10229,7 @@ class ElderDataViewBaseComponent {
|
|
|
10228
10229
|
* No borders / floating visible so that the table can be embedded into another container
|
|
10229
10230
|
*/
|
|
10230
10231
|
this._embedded = false;
|
|
10232
|
+
this._itemClickSubject = new Subject();
|
|
10231
10233
|
if (!selectionModel) {
|
|
10232
10234
|
this.selectionModel = new SelectionModel(false, [], (entity) => entity ? this.getId(entity) : 0);
|
|
10233
10235
|
}
|
|
@@ -10294,6 +10296,14 @@ class ElderDataViewBaseComponent {
|
|
|
10294
10296
|
this.selectionModel.isMultipleSelection = enableMultiSelection;
|
|
10295
10297
|
}
|
|
10296
10298
|
}
|
|
10299
|
+
/***************************************************************************
|
|
10300
|
+
* *
|
|
10301
|
+
* On click properties *
|
|
10302
|
+
* *
|
|
10303
|
+
**************************************************************************/
|
|
10304
|
+
get itemClick() {
|
|
10305
|
+
return this._itemClickSubject;
|
|
10306
|
+
}
|
|
10297
10307
|
/***************************************************************************
|
|
10298
10308
|
* *
|
|
10299
10309
|
* Style Properties *
|
|
@@ -10328,7 +10338,38 @@ class ElderDataViewBaseComponent {
|
|
|
10328
10338
|
* @param data
|
|
10329
10339
|
* @protected
|
|
10330
10340
|
*/
|
|
10331
|
-
onDataContextSet(data) {
|
|
10341
|
+
onDataContextSet(data) {
|
|
10342
|
+
}
|
|
10343
|
+
onItemClick(entity) {
|
|
10344
|
+
if (entity) {
|
|
10345
|
+
switch (this.interactionMode) {
|
|
10346
|
+
case 'open':
|
|
10347
|
+
if (this.selectionModel.hasValue) {
|
|
10348
|
+
this.selectionModel.toggle(entity);
|
|
10349
|
+
}
|
|
10350
|
+
else {
|
|
10351
|
+
this._itemClickSubject.next(entity);
|
|
10352
|
+
}
|
|
10353
|
+
break;
|
|
10354
|
+
case 'selection':
|
|
10355
|
+
this.selectionModel.toggle(entity);
|
|
10356
|
+
break;
|
|
10357
|
+
}
|
|
10358
|
+
}
|
|
10359
|
+
}
|
|
10360
|
+
onItemDoubleClick(entity) {
|
|
10361
|
+
if (entity) {
|
|
10362
|
+
switch (this.interactionMode) {
|
|
10363
|
+
// double click in open mode not supported
|
|
10364
|
+
case 'open':
|
|
10365
|
+
break;
|
|
10366
|
+
// double click in selection mode triggers normal item click
|
|
10367
|
+
case 'selection':
|
|
10368
|
+
this._itemClickSubject.next(entity);
|
|
10369
|
+
break;
|
|
10370
|
+
}
|
|
10371
|
+
}
|
|
10372
|
+
}
|
|
10332
10373
|
/***************************************************************************
|
|
10333
10374
|
* *
|
|
10334
10375
|
* Private Methods *
|
|
@@ -10347,11 +10388,13 @@ ElderDataViewBaseComponent.ctorParameters = () => [
|
|
|
10347
10388
|
{ type: ElderDataViewSelectionMode }
|
|
10348
10389
|
];
|
|
10349
10390
|
ElderDataViewBaseComponent.propDecorators = {
|
|
10391
|
+
interactionMode: [{ type: Input }],
|
|
10350
10392
|
selectableEvaluatorFn: [{ type: Input }],
|
|
10351
10393
|
selection: [{ type: Input }],
|
|
10352
10394
|
selectionChange: [{ type: Output }],
|
|
10353
10395
|
selectionSingleChange: [{ type: Output }],
|
|
10354
10396
|
selectionMultiEnabled: [{ type: Input }],
|
|
10397
|
+
itemClick: [{ type: Output }],
|
|
10355
10398
|
dense: [{ type: Input }],
|
|
10356
10399
|
float: [{ type: Input }],
|
|
10357
10400
|
embedded: [{ type: Input }]
|
|
@@ -10780,7 +10823,6 @@ class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
10780
10823
|
**************************************************************************/
|
|
10781
10824
|
this.logger = LoggerFactory.getLogger(this.constructor.name);
|
|
10782
10825
|
this.destroy$ = new Subject();
|
|
10783
|
-
this._itemClickSubject = new Subject();
|
|
10784
10826
|
/**
|
|
10785
10827
|
* Load next chunk after current is done
|
|
10786
10828
|
*/
|
|
@@ -10811,7 +10853,6 @@ class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
10811
10853
|
this.cleanUp = true;
|
|
10812
10854
|
this.keepSelection = true;
|
|
10813
10855
|
this.showFooter = false;
|
|
10814
|
-
this.interactionMode = 'open';
|
|
10815
10856
|
this.toolbarRowTemplates$ = new BehaviorSubject([]);
|
|
10816
10857
|
/**
|
|
10817
10858
|
* Gets the current rows of this table.
|
|
@@ -10890,7 +10931,7 @@ class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
10890
10931
|
if (data instanceof Array) {
|
|
10891
10932
|
dc = DataContextBuilder.start()
|
|
10892
10933
|
.localSort()
|
|
10893
|
-
.buildLocal(data); // Potential Memory leak (See autoCleanUp)
|
|
10934
|
+
.buildLocal(data, this.idField); // Potential Memory leak (See autoCleanUp)
|
|
10894
10935
|
dc.start();
|
|
10895
10936
|
}
|
|
10896
10937
|
else if (isDataSource(data)) {
|
|
@@ -10935,9 +10976,6 @@ class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
10935
10976
|
get selectionVisible() {
|
|
10936
10977
|
return this.tableModel.selectionVisible;
|
|
10937
10978
|
}
|
|
10938
|
-
get itemClick() {
|
|
10939
|
-
return this._itemClickSubject;
|
|
10940
|
-
}
|
|
10941
10979
|
/*
|
|
10942
10980
|
@Output()
|
|
10943
10981
|
public get activeItem(): Observable<any> {
|
|
@@ -10972,42 +11010,6 @@ class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
10972
11010
|
get trackByFn() {
|
|
10973
11011
|
return (index, entity) => this.getId(entity);
|
|
10974
11012
|
}
|
|
10975
|
-
/**
|
|
10976
|
-
* Occurs when the user clicks on a row
|
|
10977
|
-
*/
|
|
10978
|
-
onItemClick(entity) {
|
|
10979
|
-
switch (this.interactionMode) {
|
|
10980
|
-
case 'open':
|
|
10981
|
-
if (this.selectionModel.hasValue) {
|
|
10982
|
-
this.selectionModel.toggle(entity);
|
|
10983
|
-
}
|
|
10984
|
-
else {
|
|
10985
|
-
this._itemClickSubject.next(entity);
|
|
10986
|
-
}
|
|
10987
|
-
break;
|
|
10988
|
-
case 'selection':
|
|
10989
|
-
this.selectionModel.toggle(entity);
|
|
10990
|
-
break;
|
|
10991
|
-
// TODO improve onItemDoubleClick behavior with Observable
|
|
10992
|
-
/*
|
|
10993
|
-
clickStream
|
|
10994
|
-
.bufferTime(250)
|
|
10995
|
-
.map(arr => arr.length)
|
|
10996
|
-
.filter(len => len === 2);
|
|
10997
|
-
*/
|
|
10998
|
-
}
|
|
10999
|
-
}
|
|
11000
|
-
onItemDoubleClick(entity) {
|
|
11001
|
-
switch (this.interactionMode) {
|
|
11002
|
-
// double click in open mode not supported
|
|
11003
|
-
case 'open':
|
|
11004
|
-
break;
|
|
11005
|
-
// double click in selection mode triggers normal item click
|
|
11006
|
-
case 'selection':
|
|
11007
|
-
this._itemClickSubject.next(entity);
|
|
11008
|
-
break;
|
|
11009
|
-
}
|
|
11010
|
-
}
|
|
11011
11013
|
/***************************************************************************
|
|
11012
11014
|
* *
|
|
11013
11015
|
* Private Methods *
|
|
@@ -11048,7 +11050,7 @@ class ElderTableComponent extends ElderDataViewBaseComponent {
|
|
|
11048
11050
|
ElderTableComponent.decorators = [
|
|
11049
11051
|
{ type: Component, args: [{
|
|
11050
11052
|
selector: 'elder-table, ebs-table',
|
|
11051
|
-
template: "\n<div fxLayout=\"column\" fxFlex\n class=\"elder-table\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n <!-- Toolbar Rows -->\n <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n </ng-template>\n </ng-container>\n\n <!-- Scrollable Table -->\n <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n infiniteScroll\n [eventThrottle]=\"150\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n (closeToEnd)=\"requestMoreDataZoned($event)\"\n >\n <table\n mat-table\n class=\"elder-mat-inner-table\"\n [trackBy]=\"trackByFn\"\n [dataSource]=\"dataContext$ | async\"\n [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- selection Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <elder-selection-master-checkbox></elder-selection-master-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selectionModel.toggle(entity) : null\"\n [checked]=\"selectionModel.observeSelection(entity) | async\"\n [disabled]=\"!selectionModel.isSelectable(entity)\"\n class=\"elder-table-checkbox\"\n [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n >\n </mat-checkbox>\n </td>\n <td mat-footer-cell *matFooterCellDef></td>\n </ng-container>\n\n <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n <tr mat-row class=\"elder-table-row\"\n *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n [elderTableRow]=\"entity\"\n [class.dense]=\"dense\"\n [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n [class.elder-row-removing]=\"removingField && entity[removingField]\"\n [class.elder-table-row-selected]=\"interactionMode == 'selection' && selectionModel.observeSelection(entity) | async\"\n (click)=\"
|
|
11053
|
+
template: "\n<div fxLayout=\"column\" fxFlex\n class=\"elder-table\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n>\n\n <!-- Toolbar Rows -->\n <ng-container *ngFor=\"let toolbarRowTemplate of toolbarRowTemplates$ | async\">\n <ng-template *ngTemplateOutlet=\"toolbarRowTemplate; context: {$implicit: this}\">\n </ng-template>\n </ng-container>\n\n <!-- Scrollable Table -->\n <div fxLayout=\"column\" class=\"scrollable elder-table-scroll\"\n infiniteScroll\n [eventThrottle]=\"150\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"!isContinuable || !(canLoadMore$ | async)\"\n (closeToEnd)=\"requestMoreDataZoned($event)\"\n >\n <table\n mat-table\n class=\"elder-mat-inner-table\"\n [trackBy]=\"trackByFn\"\n [dataSource]=\"dataContext$ | async\"\n [elderDataContextSelection]=\"dataContext$ | async\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- selection Column -->\n <ng-container matColumnDef=\"select\">\n <th mat-header-cell *matHeaderCellDef>\n <elder-selection-master-checkbox></elder-selection-master-checkbox>\n </th>\n <td mat-cell *matCellDef=\"let entity\">\n <mat-checkbox (click)=\"$event.stopPropagation()\"\n (change)=\"$event ? selectionModel.toggle(entity) : null\"\n [checked]=\"selectionModel.observeSelection(entity) | async\"\n [disabled]=\"!selectionModel.isSelectable(entity)\"\n class=\"elder-table-checkbox\"\n [class.elder-table-checkbox-visible]=\"(dataSelection.selectionState$ | async).anySelected\"\n >\n </mat-checkbox>\n </td>\n <td mat-footer-cell *matFooterCellDef></td>\n </ng-container>\n\n <ng-container *ngIf=\"(tableModel.displayedColumnsInner$ | async) as displayedColumnsInner\">\n <tr mat-header-row *matHeaderRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n <tr mat-row class=\"elder-table-row\"\n *matRowDef=\"let entity; columns: displayedColumnsInner;\"\n [elderTableRow]=\"entity\"\n [class.dense]=\"dense\"\n [class.elder-row-hidden]=\"hiddenField && entity[hiddenField]\"\n [class.elder-row-removing]=\"removingField && entity[removingField]\"\n [class.elder-table-row-selected]=\"interactionMode == 'selection' && selectionModel.observeSelection(entity) | async\"\n (click)=\"onItemClick(entity)\"\n (dblclick)=\"onItemDoubleClick(entity)\"\n >\n </tr>\n <ng-container *ngIf=\"showFooter\">\n <tr mat-footer-row *matFooterRowDef=\"displayedColumnsInner; sticky: true\"></tr>\n </ng-container>\n </ng-container>\n </table>\n </div>\n\n <div fxLayout=\"column\" fxFlex fxLayoutAlign=\"center center\">\n\n <span class=\"elder-table-hint mat-body-1\" *ngIf=\"(dataContext?.data | async)?.length === 0 && !(dataContext?.status | async)?.hasError\">\n {{'No data available' | translate}}\n </span>\n\n <div *ngIf=\"(dataContext?.status | async)?.hasError\"\n fxLayout=\"row\" fxLayoutAlign=\"center center\" fxLayoutGap=\"20px\">\n <mat-icon color=\"warn\">warning</mat-icon>\n <span class=\"hint mat-body-1\">{{'Error while loading data' | translate}}</span>\n </div>\n\n </div>\n\n <mat-progress-bar fxFlex=\"none\"\n [mode]=\"(dataContext?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"((dataContext?.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Optional Paginator Toolbar -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n fxFlex=\"none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Optional Continuation Footer -->\n <div *ngIf=\"isContinuable\" class=\"elder-table-footer\"\n fxLayout=\"row\" fxFlex=\"none\" fxLayoutAlign=\"end center\" fxLayoutGap=\"10px\"\n style=\"padding-right: 10px\" >\n\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataContext?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\" color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataContinuable.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </div>\n\n</div>\n",
|
|
11052
11054
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
11053
11055
|
providers: [
|
|
11054
11056
|
ElderTableProviders.ExistingOrNewTableModel,
|
|
@@ -11082,14 +11084,12 @@ ElderTableComponent.propDecorators = {
|
|
|
11082
11084
|
cleanUp: [{ type: Input }],
|
|
11083
11085
|
keepSelection: [{ type: Input }],
|
|
11084
11086
|
showFooter: [{ type: Input }],
|
|
11085
|
-
interactionMode: [{ type: Input }],
|
|
11086
11087
|
toolbarRowTemplateQuery: [{ type: ContentChildren, args: [ElderTableToolbarDirective, { read: TemplateRef },] }],
|
|
11087
11088
|
rowsQuery: [{ type: ViewChildren, args: [ElderTableRowDirective,] }],
|
|
11088
11089
|
toolbarTemplate: [{ type: Input }],
|
|
11089
11090
|
data: [{ type: Input }],
|
|
11090
11091
|
displayedColumns: [{ type: Input }],
|
|
11091
|
-
selectionVisible: [{ type: Input }]
|
|
11092
|
-
itemClick: [{ type: Output }]
|
|
11092
|
+
selectionVisible: [{ type: Input }]
|
|
11093
11093
|
};
|
|
11094
11094
|
|
|
11095
11095
|
class ElderInfiniteScrollDirective {
|
|
@@ -12889,7 +12889,8 @@ class ElderGridComponent extends ElderDataViewBaseComponent {
|
|
|
12889
12889
|
*/
|
|
12890
12890
|
this.idField = 'id';
|
|
12891
12891
|
this.selectionVisible = true;
|
|
12892
|
-
this.
|
|
12892
|
+
this.pageSizeOptions = [30, 50, 100, 150, 200];
|
|
12893
|
+
this.destroy$ = new Subject();
|
|
12893
12894
|
}
|
|
12894
12895
|
/***************************************************************************
|
|
12895
12896
|
* *
|
|
@@ -12915,7 +12916,15 @@ class ElderGridComponent extends ElderDataViewBaseComponent {
|
|
|
12915
12916
|
}
|
|
12916
12917
|
}
|
|
12917
12918
|
}
|
|
12919
|
+
ngAfterViewInit() {
|
|
12920
|
+
MatTableDataContextBindingBuilder
|
|
12921
|
+
.start(this.dataContext$)
|
|
12922
|
+
.withPaginator(of(this.matPaginator))
|
|
12923
|
+
.bindUntil(this.destroy$);
|
|
12924
|
+
}
|
|
12918
12925
|
ngOnDestroy() {
|
|
12926
|
+
this.destroy$.next();
|
|
12927
|
+
this.destroy$.complete();
|
|
12919
12928
|
}
|
|
12920
12929
|
/***************************************************************************
|
|
12921
12930
|
* *
|
|
@@ -12937,7 +12946,12 @@ class ElderGridComponent extends ElderDataViewBaseComponent {
|
|
|
12937
12946
|
set data(data) {
|
|
12938
12947
|
this.dataContext$.next(data);
|
|
12939
12948
|
this.total$ = data.total.pipe(map(total => total ? total + '' : '∞'));
|
|
12940
|
-
|
|
12949
|
+
if (isContinuableDataContext(data)) {
|
|
12950
|
+
this.canLoadMore$ = combineLatest([data.loading, data.hasMoreData]).pipe(map(([loading, hasMoreData]) => !loading && hasMoreData));
|
|
12951
|
+
}
|
|
12952
|
+
else {
|
|
12953
|
+
this.canLoadMore$ = of(false);
|
|
12954
|
+
}
|
|
12941
12955
|
}
|
|
12942
12956
|
get dataSnapshot() {
|
|
12943
12957
|
return this.dataContinuable;
|
|
@@ -13029,7 +13043,7 @@ class ElderGridComponent extends ElderDataViewBaseComponent {
|
|
|
13029
13043
|
ElderGridComponent.decorators = [
|
|
13030
13044
|
{ type: Component, args: [{
|
|
13031
13045
|
selector: 'elder-grid',
|
|
13032
|
-
template: "<div fxLayout=\"column\" class=\"scroll-fix\" fxFill>\n\n <!-- Grid Browser -->\n <div fxLayout=\"column\" fxFlex\n class=\"scroll-fix elder-grid-container\"\n *ngIf=\"dataContext$ | async as data\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n\n [elderDataContextSelection]=\"data\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- Toolbar Row -->\n <div *ngIf=\"toolbarVisible\"\n fxLayout=\"row\" fxLayoutAlign=\"start center\" fxFlex=\"none\" class=\"elder-grid-toolbar\">\n\n <div fxLayout=\"column\" fxFlex=\"none\" style=\"padding-left: 8px; padding-right: 8px\" *ngIf=\"selectionVisible\">\n <elder-selection-master-checkbox fxFlex=\"none\" style=\"padding-left: 12px\"></elder-selection-master-checkbox>\n </div>\n\n <!-- Toolbar -->\n <ng-container *ngIf=\"toolbarTemplate\">\n <ng-template *ngTemplateOutlet=\"toolbarTemplate; context: {$implicit: this}\"></ng-template>\n </ng-container>\n\n <elder-single-sort *ngIf=\"availableSorts && availableSorts.length > 0 && data.sort.sorts | async as sorts\"\n fxFlex=\"none\"\n [availableSorts]=\"availableSorts\"\n [translationPrefix]=\"sortTranslationPrefix\"\n [sort]=\"sorts[0]\"\n (sortChange)=\"updateSort($event)\">\n </elder-single-sort>\n\n </div>\n\n <mat-divider *ngIf=\"toolbarVisible\"></mat-divider>\n\n <!-- [cdkDropListSortingDisabled]=\"true\" -->\n <!-- cdkDropList -->\n <cdk-virtual-scroll-viewport\n class=\"elder-grid-browser\" fxLayout=\"column\" fxFlex\n id=\"documents-container\"\n [itemSize]=\"itemHeight\"\n [minBufferPx]=\"itemHeight * 2\"\n [maxBufferPx]=\"itemHeight * 3\"\n #virtualScrollViewPort\n infiniteScroll\n [eventThrottle]=\"200\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"data.loading | async\"\n [containerId]=\"'documents-container'\" [listenToHost]=\"false\"\n (closeToEnd)=\"requestMoreDataZoned($event)\"
|
|
13046
|
+
template: "<div fxLayout=\"column\" class=\"scroll-fix\" fxFill>\n\n <!-- Grid Browser -->\n <div fxLayout=\"column\" fxFlex\n class=\"scroll-fix elder-grid-container\"\n *ngIf=\"dataContext$ | async as data\"\n [class.elder-mat-table-container]=\"!embedded\"\n [class.mat-elevation-z5]=\"float\"\n [class.elder-mat-table-flat]=\"!embedded && !float\"\n\n [elderDataContextSelection]=\"data\" #dataSelection=\"elderDataContextSelection\"\n [elderDataContextSelectionModel]=\"selectionModel\"\n >\n\n <!-- Toolbar Row -->\n <div *ngIf=\"toolbarVisible\"\n fxLayout=\"row\" fxLayoutAlign=\"start center\" fxFlex=\"none\" class=\"elder-grid-toolbar\">\n\n <div fxLayout=\"column\" fxFlex=\"none\" style=\"padding-left: 8px; padding-right: 8px\" *ngIf=\"selectionVisible\">\n <elder-selection-master-checkbox fxFlex=\"none\" style=\"padding-left: 12px\"></elder-selection-master-checkbox>\n </div>\n\n <!-- Toolbar -->\n <ng-container *ngIf=\"toolbarTemplate\">\n <ng-template *ngTemplateOutlet=\"toolbarTemplate; context: {$implicit: this}\"></ng-template>\n </ng-container>\n\n <elder-single-sort *ngIf=\"availableSorts && availableSorts.length > 0 && data.sort.sorts | async as sorts\"\n fxFlex=\"none\"\n [availableSorts]=\"availableSorts\"\n [translationPrefix]=\"sortTranslationPrefix\"\n [sort]=\"sorts[0]\"\n (sortChange)=\"updateSort($event)\">\n </elder-single-sort>\n\n </div>\n\n <mat-divider *ngIf=\"toolbarVisible\"></mat-divider>\n\n <span class=\"elder-table-hint mat-body-1\" fxFlex fxLayoutAlign=\"center center\"\n *ngIf=\"!dataContext?.isStarted\">\n {{'Datacontext not started' | translate}}\n </span>\n\n <div *ngIf=\"(dataContext?.data | async)?.isStarted\" fxFlex fxLayoutAlign=\"center center\">\n\n <span class=\"elder-table-hint mat-body-1\"\n *ngIf=\"(dataContext?.data | async)?.length === 0 && !(dataContext?.status | async)?.hasError\">\n {{'No data available' | translate}}\n </span>\n\n <div *ngIf=\"(dataContext?.status | async)?.hasError\"\n fxLayout=\"row\" fxLayoutAlign=\"center center\" fxLayoutGap=\"20px\">\n <mat-icon color=\"warn\">warning</mat-icon>\n <span class=\"hint mat-body-1\">{{'Error while loading data' | translate}}</span>\n </div>\n\n </div>\n\n <!-- [cdkDropListSortingDisabled]=\"true\" -->\n <!-- cdkDropList -->\n <cdk-virtual-scroll-viewport\n class=\"elder-grid-browser\" fxLayout=\"column\" fxFlex\n id=\"documents-container\"\n [itemSize]=\"itemHeight\"\n [minBufferPx]=\"itemHeight * 2\"\n [maxBufferPx]=\"itemHeight * 3\"\n #virtualScrollViewPort\n infiniteScroll\n [eventThrottle]=\"200\"\n [offsetFactor]=\"2\"\n [ignoreScrollEvent]=\"data.loading | async\"\n [containerId]=\"'documents-container'\" [listenToHost]=\"false\"\n (closeToEnd)=\"requestMoreDataZoned($event)\">\n\n <!-- (scrolling)=\"onScrolling($event)\" -->\n\n <div\n *cdkVirtualFor=\"let row of dataRows$; trackBy: trackByIndex; templateCacheSize: 50\"\n class=\"elder-grid-tile-row\"\n [style.height]=\"itemHeight + 'px'\">\n\n <ng-container *ngFor=\"let tile of row; trackBy: trackByFn\">\n\n <!-- Tile Cell -->\n <div *ngIf=\"showTile(tile)\" class=\"elder-grid-tile\">\n <!-- cdkDrag [cdkDragDisabled]=\"true\" [cdkDragData]=\"tile\" -->\n <!-- <div class=\"tile-placeholder\" *cdkDragPlaceholder></div> -->\n <div class=\"elder-grid-tile-content\"\n (click)=\"onItemClick(tile)\"\n (dblclick)=\"onItemDoubleClick(tile)\">\n <ng-container\n *ngTemplateOutlet=\"tileTemplate || simpleTileTemplate; context: {$implicit: tile}\">\n </ng-container>\n\n <!-- Overlay (Selection) -->\n <ng-container *ngIf=\"selectionVisible\">\n <div *ngIf=\"selectionModel.selection | async as selection\"\n class=\"elder-grid-tile-overlay\"\n [class.elder-grid-tile-overlay-hidden]=\"!inSelectionMode(selection)\"\n [class.elder-grid-tile-overlay-visible]=\"inSelectionMode(selection)\"\n [class.elder-click-through]=\"true\"\n >\n <button mat-icon-button type=\"button\"\n (click)=\"selectionModel.toggle(tile)\" elderStopEventPropagation\n class=\"elder-grid-tile-check\">\n <mat-icon\n [class.elder-selected]=\"(selectionModel.observeSelection(tile) | async)\"\n >\n {{(selectionModel.observeSelection(tile) | async) ? 'check_circle' : 'radio_button_unchecked'}}\n </mat-icon>\n </button>\n </div>\n </ng-container>\n\n </div>\n </div>\n\n <div *ngIf=\"!showTile(tile)\" class=\"elder-grid-tile-hidden\"></div>\n </ng-container>\n\n </div>\n\n </cdk-virtual-scroll-viewport>\n\n\n <mat-progress-bar fxFlex=\"none\"\n [mode]=\"(data?.loading | async) ? 'indeterminate' : 'determinate'\"\n [color]=\"(data && (data.status | async)?.hasError) ? 'warn' : 'primary'\">\n </mat-progress-bar>\n\n <!-- Footer -->\n <div class=\"elder-grid-footer\" *ngIf=\"footerVisible\"\n fxLayout=\"row\" fxFlex=\"none\" fxLayoutAlign=\"end center\" fxLayoutGap=\"10px\"\n style=\"padding-right: 10px\">\n\n <!-- Continuable -->\n <ng-container *ngIf=\"isContinuable\">\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataSnapshot?.data | async)?.length}} / {{total$ | async}}\n </span>\n\n <button mat-icon-button type=\"button\"\n color=\"primary\"\n [disabled]=\"!(canLoadMore$ | async)\"\n (click)=\"dataSnapshot.loadMore()\">\n <mat-icon>keyboard_arrow_down</mat-icon>\n </button>\n </ng-container>\n\n <!-- Paged -->\n <mat-paginator #matPaginator *ngIf=\"isActivePaged && (dataActivePaged.page | async) as page\"\n fxFlex=\"none\"\n [length]=\"dataContext?.total | async\"\n [pageIndex]=\"page?.index\"\n [pageSize]=\"page?.size\"\n [pageSizeOptions]=\"pageSizeOptions\">\n </mat-paginator>\n\n <!-- Local Source -->\n <ng-container *ngIf=\"!isActivePaged && !isContinuable\">\n <span class=\"mat-caption noselect\" style=\"color: gray\">\n {{(dataSnapshot?.data | async)?.length}}\n </span>\n </ng-container>\n\n </div>\n\n\n </div>\n</div>\n\n<ng-template #simpleTileTemplate let-tile>\n <div *ngIf=\"tile\" fxLayout=\"column\" fxFlex fxLayoutAlign=\"center center\" style=\"background-color: lightblue\">\n <p class=\"noselect\">Tile: {{tile}}</p>\n </div>\n</ng-template>\n",
|
|
13033
13047
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
13034
13048
|
providers: [
|
|
13035
13049
|
{
|
|
@@ -13057,7 +13071,8 @@ ElderGridComponent.propDecorators = {
|
|
|
13057
13071
|
hiddenField: [{ type: Input }],
|
|
13058
13072
|
idField: [{ type: Input }],
|
|
13059
13073
|
selectionVisible: [{ type: Input }],
|
|
13060
|
-
|
|
13074
|
+
pageSizeOptions: [{ type: Input }],
|
|
13075
|
+
matPaginator: [{ type: ViewChild, args: [MatPaginator,] }],
|
|
13061
13076
|
toolbarTemplateQuery: [{ type: ContentChild, args: [ElderGridToolbarDirective, { read: TemplateRef, static: true },] }],
|
|
13062
13077
|
tileTemplate: [{ type: Input }],
|
|
13063
13078
|
toolbarTemplate: [{ type: Input }],
|
|
@@ -13082,7 +13097,7 @@ ElderGridModule.decorators = [
|
|
|
13082
13097
|
TranslateModule,
|
|
13083
13098
|
ElderDataCommonModule,
|
|
13084
13099
|
ElderInfiniteScrollModule,
|
|
13085
|
-
ElderFormsDirectivesModule
|
|
13100
|
+
ElderFormsDirectivesModule, MatPaginatorModule
|
|
13086
13101
|
],
|
|
13087
13102
|
declarations: [
|
|
13088
13103
|
ElderGridComponent,
|
|
@@ -21761,7 +21776,7 @@ class ElderAuditedEntityComponent {
|
|
|
21761
21776
|
ElderAuditedEntityComponent.decorators = [
|
|
21762
21777
|
{ type: Component, args: [{
|
|
21763
21778
|
selector: 'elder-audited-entity',
|
|
21764
|
-
template: "<section [fxLayout]=\"layout\" fxLayoutGap=\"8px\" *ngIf=\"auditedCtx$ | async as ctx\">\n\n <mat-form-field class=\"elder-std-form-field\" [appearance]=\"appearance\">\n <mat-icon class=\"decent noselect\"
|
|
21779
|
+
template: "<section [fxLayout]=\"layout\" fxLayoutGap=\"8px\" *ngIf=\"auditedCtx$ | async as ctx\">\n\n <mat-form-field class=\"elder-std-form-field\" [appearance]=\"appearance\">\n <mat-label fxLayoutAlign=\"start center\" fxLayoutGap=\"4px\">\n <mat-icon class=\"decent noselect\" inline>add_circle_outline</mat-icon>\n <span>{{'context.createdAt' | translate}} {{ctx.audited?.createdAt | timeAgo}}</span>\n </mat-label>\n <input matInput name=\"created\"\n [value]=\"ctx.audited?.createdAt | date:'dd.MM.yyyy hh:mm'\"\n readonly>\n <mat-hint>{{ctx.audited?.createdBy}}</mat-hint>\n </mat-form-field>\n\n <mat-form-field class=\"elder-std-form-field\" [appearance]=\"appearance\">\n <mat-label fxLayoutAlign=\"start center\" fxLayoutGap=\"4px\">\n <mat-icon class=\"decent noselect\">mode_edit_outline</mat-icon>\n <span>{{'context.modifiedAt' | translate}} {{ctx.audited?.modifiedAt | timeAgo}}</span>\n </mat-label>\n <input matInput name=\"modified\"\n [value]=\"ctx.audited?.modifiedAt | date:'dd.MM.yyyy hh:mm'\"\n readonly>\n <mat-hint>{{ctx.audited?.modifiedBy}}</mat-hint>\n </mat-form-field>\n\n</section>\n",
|
|
21765
21780
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
21766
21781
|
styles: [".decent{opacity:.5}\n"]
|
|
21767
21782
|
},] }
|