@elderbyte/ngx-starter 13.7.5 → 13.7.6
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/esm2020/lib/common/data/data-context/mat-table-data-context-binding.mjs +14 -10
- package/esm2020/lib/common/utils/collection-util.mjs +2 -2
- package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +10 -4
- package/esm2020/lib/components/select/elder-select-base.mjs +2 -1
- package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +10 -4
- package/fesm2015/elderbyte-ngx-starter.mjs +29 -12
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +29 -12
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/common/utils/collection-util.d.ts +1 -1
- package/lib/components/select/elder-select/elder-select.component.d.ts +1 -0
- package/lib/components/select/elder-select-base.d.ts +1 -0
- package/lib/components/select/multi/elder-multi-select-base.d.ts +1 -0
- package/package.json +1 -1
|
@@ -72,7 +72,7 @@ export class MatTableDataContextBinding {
|
|
|
72
72
|
}
|
|
73
73
|
}
|
|
74
74
|
bindDataContextToMatSortsUntil(matSorts$, destroy$) {
|
|
75
|
-
const dcSorts$ = this._dataContext$.pipe(switchMap(dc => dc.sort.sorts));
|
|
75
|
+
const dcSorts$ = this._dataContext$.pipe(filter(dc => !!dc), switchMap(dc => dc.sort.sorts));
|
|
76
76
|
combineLatest([dcSorts$, matSorts$]).pipe(takeUntil(destroy$)).subscribe(([dcSorts, matSorts]) => {
|
|
77
77
|
if (dcSorts.length >= 1) {
|
|
78
78
|
// At least one sort active
|
|
@@ -109,19 +109,23 @@ export class MatTableDataContextBinding {
|
|
|
109
109
|
return new Sort(matSort.active, this.fromMatDirection(matSort.direction));
|
|
110
110
|
}));
|
|
111
111
|
combineLatest([this._dataContext$, sortChanges$]).pipe(takeUntil(destroy$)).subscribe(([dc, sortRequest]) => {
|
|
112
|
-
dc
|
|
112
|
+
if (dc) {
|
|
113
|
+
dc.sort.updateSort(sortRequest);
|
|
114
|
+
}
|
|
113
115
|
});
|
|
114
116
|
}
|
|
115
117
|
bindPaginatorUntil(paginator$, destroy$) {
|
|
116
118
|
const pageRequest$ = paginator$.pipe(filter(paginator => !!paginator), switchMap(paginator => paginator.page), map(pageEvent => new PageRequest(pageEvent.pageIndex, pageEvent.pageSize)));
|
|
117
119
|
combineLatest([this._dataContext$, pageRequest$]).pipe(takeUntil(destroy$)).subscribe(([dc, pageRequest]) => {
|
|
118
|
-
if (
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
'
|
|
120
|
+
if (dc) {
|
|
121
|
+
if (isActivePagedDataContext(dc)) {
|
|
122
|
+
const pagedDc = dc;
|
|
123
|
+
pagedDc.setActivePage(pageRequest);
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
this.logger.warn('Can not bind the given paginator to the given data-context,' +
|
|
127
|
+
' as the datacontext does not support pagination!', dc);
|
|
128
|
+
}
|
|
125
129
|
}
|
|
126
130
|
});
|
|
127
131
|
}
|
|
@@ -132,4 +136,4 @@ export class MatTableDataContextBinding {
|
|
|
132
136
|
return matSortDirection;
|
|
133
137
|
}
|
|
134
138
|
}
|
|
135
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mat-table-data-context-binding.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/mat-table-data-context-binding.ts"],"names":[],"mappings":"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","sourcesContent":["import { MatPaginator, PageEvent } from '@angular/material/paginator';\nimport { MatSort, SortDirection as MatSortDirection } from '@angular/material/sort';\nimport {IDataContext, IDataContextActivePage, isActivePagedDataContext} from './data-context';\nimport {combineLatest, merge, Observable, Subject, Unsubscribable} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {filter, map, mergeAll, mergeMap, switchMap, takeUntil} from 'rxjs/operators';\nimport {Sort, SortDirection} from '../sort';\nimport {PageRequest} from '../page';\n\n\nexport class MatTableDataContextBindingBuilder {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private _dataContext$: Observable<IDataContext<any>>;\n  private _sorts$: Observable<MatSort[]>;\n  private _matPaginator$: Observable<MatPaginator>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Static Builder                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  public static start(dataContext$: Observable<IDataContext<any>>): MatTableDataContextBindingBuilder {\n    return new MatTableDataContextBindingBuilder(dataContext$);\n  }\n\n  constructor(dataContext$: Observable<IDataContext<any>>) {\n    this._dataContext$ = dataContext$;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public withSorts(sorts$: Observable<MatSort[]>): this {\n    this._sorts$ = sorts$;\n    return this;\n  }\n\n  public withPaginator(paginator$: Observable<MatPaginator>): this {\n    this._matPaginator$ = paginator$;\n    return this;\n  }\n\n  public bindUntil(destroy$: Observable<any>): MatTableDataContextBinding {\n    return new MatTableDataContextBinding(\n      this._dataContext$,\n      this._sorts$,\n      this._matPaginator$,\n      destroy$\n    );\n  }\n\n}\n\nexport class MatTableDataContextBinding {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly _dataContext$: Observable<IDataContext<any>>,\n    private readonly _matSorts$: Observable<MatSort[]> | null,\n    private readonly _matPaginator$: Observable<MatPaginator> | null,\n    destroy$: Observable<any>\n  ) {\n    this.subscribeUntil(destroy$);\n  }\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private subscribeUntil(destroy$: Observable<any>): void {\n    if (this._matSorts$) {\n      this.bindMatSortsToDataContextUntil(this._matSorts$, destroy$);\n      this.bindDataContextToMatSortsUntil(this._matSorts$, destroy$);\n    }\n\n    if (this._matPaginator$) {\n      this.bindPaginatorUntil(this._matPaginator$, destroy$);\n    }\n  }\n\n  private bindDataContextToMatSortsUntil(matSorts$: Observable<MatSort[]>, destroy$: Observable<any>): void {\n\n    const dcSorts$ = this._dataContext$.pipe(\n      switchMap(dc => dc.sort.sorts)\n    );\n\n    combineLatest([dcSorts$, matSorts$]).pipe(\n      takeUntil(destroy$),\n    ).subscribe(([dcSorts, matSorts]) => {\n\n      if (dcSorts.length >= 1) {\n        // At least one sort active\n        const sort = dcSorts[0];\n        this.updateMatSorts(sort, matSorts);\n      } else {\n        // No sort active\n        this.updateMatSorts(Sort.NONE, matSorts);\n      }\n    });\n  }\n\n  private updateMatSorts(dcSort: Sort, matSorts: MatSort[]): void {\n    const active = dcSort.prop;\n    const direction = this.toMatDirection(dcSort.dir);\n    matSorts.forEach(matSort => this.updateMatSort(active, direction, matSort));\n  }\n\n  private updateMatSort(\n    activeProp: string,\n    direction: MatSortDirection,\n    matSort: MatSort\n  ): void {\n\n    if (activeProp) {\n      if (!matSort.sortables.has(activeProp)) {\n        // The current sort property is not part of this MatSort.\n        activeProp = Sort.NONE.prop; // Force no sort in this mat context\n      }\n    }\n\n    if (matSort.active !== activeProp || matSort.direction !== direction) {\n      // We do only update matSort when there was a real change\n      matSort.active = activeProp;\n      matSort.direction = direction;\n      matSort._stateChanges.next();\n    }\n  }\n\n\n\n  private bindMatSortsToDataContextUntil(sorts$: Observable<MatSort[]>, destroy$: Observable<any>): void {\n\n    const sortChanges$ = sorts$.pipe(\n      mergeMap(sorts => merge(...sorts.map(s => s.sortChange))),\n      map(matSort => {\n        return new Sort(\n          matSort.active,\n          this.fromMatDirection(matSort.direction)\n        );\n      })\n    );\n\n    combineLatest([this._dataContext$, sortChanges$]).pipe(\n      takeUntil(destroy$),\n    ).subscribe(([dc, sortRequest]) => {\n      dc.sort.updateSort(sortRequest);\n    });\n  }\n\n  private bindPaginatorUntil(paginator$: Observable<MatPaginator>, destroy$: Observable<any>): void {\n\n    const pageRequest$ = paginator$.pipe(\n      filter(paginator => !!paginator),\n      switchMap(paginator => paginator.page),\n      map(pageEvent => new PageRequest(pageEvent.pageIndex, pageEvent.pageSize))\n    );\n\n    combineLatest([this._dataContext$, pageRequest$]).pipe(\n      takeUntil(destroy$),\n    ).subscribe(([dc, pageRequest]) => {\n\n      if (isActivePagedDataContext(dc)) {\n        const pagedDc = dc as IDataContextActivePage<any>;\n        pagedDc.setActivePage(pageRequest);\n      } else {\n        this.logger.warn('Can not bind the given paginator to the given data-context,' +\n          ' as the datacontext does not support pagination!', dc);\n      }\n    });\n  }\n\n  private toMatDirection(direction: SortDirection): MatSortDirection {\n    return direction;\n  }\n\n  private fromMatDirection(matSortDirection: MatSortDirection): SortDirection {\n    return matSortDirection;\n  }\n}\n"]}
|
|
139
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mat-table-data-context-binding.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/mat-table-data-context-binding.ts"],"names":[],"mappings":"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","sourcesContent":["import { MatPaginator, PageEvent } from '@angular/material/paginator';\nimport { MatSort, SortDirection as MatSortDirection } from '@angular/material/sort';\nimport {IDataContext, IDataContextActivePage, isActivePagedDataContext} from './data-context';\nimport {combineLatest, merge, Observable, Subject, Unsubscribable} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {filter, map, mergeAll, mergeMap, switchMap, takeUntil} from 'rxjs/operators';\nimport {Sort, SortDirection} from '../sort';\nimport {PageRequest} from '../page';\n\n\nexport class MatTableDataContextBindingBuilder {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private _dataContext$: Observable<IDataContext<any>>;\n  private _sorts$: Observable<MatSort[]>;\n  private _matPaginator$: Observable<MatPaginator>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Static Builder                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  public static start(dataContext$: Observable<IDataContext<any>>): MatTableDataContextBindingBuilder {\n    return new MatTableDataContextBindingBuilder(dataContext$);\n  }\n\n  constructor(dataContext$: Observable<IDataContext<any>>) {\n    this._dataContext$ = dataContext$;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public withSorts(sorts$: Observable<MatSort[]>): this {\n    this._sorts$ = sorts$;\n    return this;\n  }\n\n  public withPaginator(paginator$: Observable<MatPaginator>): this {\n    this._matPaginator$ = paginator$;\n    return this;\n  }\n\n  public bindUntil(destroy$: Observable<any>): MatTableDataContextBinding {\n    return new MatTableDataContextBinding(\n      this._dataContext$,\n      this._sorts$,\n      this._matPaginator$,\n      destroy$\n    );\n  }\n\n}\n\nexport class MatTableDataContextBinding {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly _dataContext$: Observable<IDataContext<any>>,\n    private readonly _matSorts$: Observable<MatSort[]> | null,\n    private readonly _matPaginator$: Observable<MatPaginator> | null,\n    destroy$: Observable<any>\n  ) {\n    this.subscribeUntil(destroy$);\n  }\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private subscribeUntil(destroy$: Observable<any>): void {\n    if (this._matSorts$) {\n      this.bindMatSortsToDataContextUntil(this._matSorts$, destroy$);\n      this.bindDataContextToMatSortsUntil(this._matSorts$, destroy$);\n    }\n\n    if (this._matPaginator$) {\n      this.bindPaginatorUntil(this._matPaginator$, destroy$);\n    }\n  }\n\n  private bindDataContextToMatSortsUntil(matSorts$: Observable<MatSort[]>, destroy$: Observable<any>): void {\n\n    const dcSorts$ = this._dataContext$.pipe(\n      filter(dc => !!dc),\n      switchMap(dc => dc.sort.sorts)\n    );\n\n    combineLatest([dcSorts$, matSorts$]).pipe(\n      takeUntil(destroy$),\n    ).subscribe(([dcSorts, matSorts]) => {\n\n      if (dcSorts.length >= 1) {\n        // At least one sort active\n        const sort = dcSorts[0];\n        this.updateMatSorts(sort, matSorts);\n      } else {\n        // No sort active\n        this.updateMatSorts(Sort.NONE, matSorts);\n      }\n    });\n  }\n\n  private updateMatSorts(dcSort: Sort, matSorts: MatSort[]): void {\n    const active = dcSort.prop;\n    const direction = this.toMatDirection(dcSort.dir);\n    matSorts.forEach(matSort => this.updateMatSort(active, direction, matSort));\n  }\n\n  private updateMatSort(\n    activeProp: string,\n    direction: MatSortDirection,\n    matSort: MatSort\n  ): void {\n\n    if (activeProp) {\n      if (!matSort.sortables.has(activeProp)) {\n        // The current sort property is not part of this MatSort.\n        activeProp = Sort.NONE.prop; // Force no sort in this mat context\n      }\n    }\n\n    if (matSort.active !== activeProp || matSort.direction !== direction) {\n      // We do only update matSort when there was a real change\n      matSort.active = activeProp;\n      matSort.direction = direction;\n      matSort._stateChanges.next();\n    }\n  }\n\n\n\n  private bindMatSortsToDataContextUntil(sorts$: Observable<MatSort[]>, destroy$: Observable<any>): void {\n\n    const sortChanges$ = sorts$.pipe(\n      mergeMap(sorts => merge(...sorts.map(s => s.sortChange))),\n      map(matSort => {\n        return new Sort(\n          matSort.active,\n          this.fromMatDirection(matSort.direction)\n        );\n      })\n    );\n\n    combineLatest([this._dataContext$, sortChanges$]).pipe(\n      takeUntil(destroy$),\n    ).subscribe(([dc, sortRequest]) => {\n      if (dc) {\n        dc.sort.updateSort(sortRequest);\n      }\n    });\n  }\n\n  private bindPaginatorUntil(paginator$: Observable<MatPaginator>, destroy$: Observable<any>): void {\n\n    const pageRequest$ = paginator$.pipe(\n      filter(paginator => !!paginator),\n      switchMap(paginator => paginator.page),\n      map(pageEvent => new PageRequest(pageEvent.pageIndex, pageEvent.pageSize))\n    );\n\n    combineLatest([this._dataContext$, pageRequest$]).pipe(\n      takeUntil(destroy$),\n    ).subscribe(([dc, pageRequest]) => {\n      if (dc) {\n        if (isActivePagedDataContext(dc)) {\n          const pagedDc = dc as IDataContextActivePage<any>;\n          pagedDc.setActivePage(pageRequest);\n        } else {\n          this.logger.warn('Can not bind the given paginator to the given data-context,' +\n            ' as the datacontext does not support pagination!', dc);\n        }\n      }\n    });\n  }\n\n  private toMatDirection(direction: SortDirection): MatSortDirection {\n    return direction;\n  }\n\n  private fromMatDirection(matSortDirection: MatSortDirection): SortDirection {\n    return matSortDirection;\n  }\n}\n"]}
|
|
@@ -30,7 +30,7 @@ export class CollectionUtil {
|
|
|
30
30
|
return false;
|
|
31
31
|
}
|
|
32
32
|
/**
|
|
33
|
-
* Moves the given item up in the given array - if not already at the
|
|
33
|
+
* Moves the given item up in the given array - if not already at the top
|
|
34
34
|
* @param items
|
|
35
35
|
* @param toMove
|
|
36
36
|
*/
|
|
@@ -106,4 +106,4 @@ export class CollectionUtil {
|
|
|
106
106
|
}
|
|
107
107
|
}
|
|
108
108
|
CollectionUtil.logger = LoggerFactory.getLogger('CollectionUtil');
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi11dGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tbW9uL3V0aWxzL2NvbGxlY3Rpb24tdXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFFbkQsV0FBVztBQUNYLE1BQU0sT0FBTyxjQUFjO0lBS2xCLE1BQU0sQ0FBQyxPQUFPLENBQUksTUFBYTtRQUNwQyxPQUFPLE1BQU07YUFDVixNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLFFBQVEsQ0FBSSxLQUFVLEVBQUUsTUFBUztRQUU3QyxJQUFJLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQUUsT0FBTyxLQUFLLENBQUM7U0FBRTtRQUV2QyxNQUFNLFFBQVEsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRXZDLElBQUksUUFBUSxJQUFJLENBQUMsRUFBRTtZQUVqQixNQUFNLFdBQVcsR0FBRyxRQUFRLEdBQUcsQ0FBQyxDQUFDO1lBQ2pDLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1lBQ2hDLElBQUksQ0FBQyxDQUFDLE1BQU0sR0FBRyxXQUFXLENBQUMsRUFBRTtnQkFDM0IsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztnQkFDckMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxHQUFHLE1BQU0sQ0FBQztnQkFDNUIsT0FBTyxJQUFJLENBQUM7YUFDYjtpQkFBTTtnQkFDTCxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyw0Q0FBNEMsR0FBRyxXQUFXLEdBQUcsNkJBQTZCLEdBQUcsTUFBTSxDQUFDLENBQUM7YUFDeEg7U0FDRjtRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVEOzs7O09BSUc7SUFDSSxNQUFNLENBQUMsTUFBTSxDQUFJLEtBQVUsRUFBRSxNQUFTO1FBRTNDLElBQUksS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFBRSxPQUFPLEtBQUssQ0FBQztTQUFFO1FBRXZDLE1BQU0sUUFBUSxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFdkMsSUFBSSxRQUFRLElBQUksQ0FBQyxFQUFFO1lBRWpCLE1BQU0sV0FBVyxHQUFHLFFBQVEsR0FBRyxDQUFDLENBQUM7WUFFakMsSUFBSSxXQUFXLElBQUksQ0FBQyxFQUFFO2dCQUNwQixLQUFLLENBQUMsUUFBUSxDQUFDLEdBQUcsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO2dCQUNyQyxLQUFLLENBQUMsV0FBVyxDQUFDLEdBQUcsTUFBTSxDQUFDO2dCQUM1QixPQUFPLElBQUksQ0FBQzthQUNiO1NBQ0Y7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFFRDs7T0FFRztJQUNILFdBQVc7SUFDSixNQUFNLENBQUMsWUFBWSxDQUFPLEtBQVUsRUFBRSxLQUFhO1FBQ3hELE9BQU8sY0FBYyxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBRSxFQUFVLENBQUMsS0FBSyxDQUFNLENBQUMsQ0FBQztJQUN6RSxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsV0FBVztJQUNKLE1BQU0sQ0FBQyxVQUFVLENBQU8sS0FBVSxFQUFFLFNBQTJCO1FBRXBFLE9BQU8sS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUU3QixJQUFJLE1BQVcsQ0FBQztZQUVoQixNQUFNLEdBQUcsR0FBRyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFFekIsSUFBSSxHQUFHLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFO2dCQUNoQixNQUFNLEdBQUcsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUN2QjtpQkFBTTtnQkFDTCxNQUFNLEdBQUcsRUFBRSxDQUFDO2dCQUNaLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxDQUFDO2FBQ3RCO1lBQ0QsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNmLE9BQU8sR0FBRyxDQUFDO1FBQ2IsQ0FBQyxFQUFFLElBQUksR0FBRyxFQUFFLENBQUMsQ0FBQztJQUNoQixDQUFDO0lBRUQ7Ozs7Ozs7T0FPRztJQUNJLE1BQU0sQ0FBQyxZQUFZLENBQUksSUFBWSxFQUFFLElBQVk7UUFFdEQsSUFBSSxJQUFJLEtBQUssSUFBSSxFQUFFO1lBQUUsT0FBTyxJQUFJLENBQUM7U0FBRTtRQUVuQyxJQUFJLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQUUsT0FBTyxLQUFLLENBQUM7U0FBRTtRQUNyQyxJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssSUFBSSxDQUFDLElBQUksRUFBRTtZQUFFLE9BQU8sS0FBSyxDQUFDO1NBQUUsQ0FBQyx3QkFBd0I7UUFFdkUsS0FBSyxNQUFNLENBQUMsSUFBSSxJQUFJLEVBQUU7WUFDcEIsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUU7Z0JBQ2hCLE9BQU8sS0FBSyxDQUFDO2FBQ2Q7U0FDRjtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVNLE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBVztRQUNuQyxPQUFPLElBQUksS0FBSyxJQUFJLElBQUksSUFBSSxLQUFLLFNBQVMsSUFBSSxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztJQUNoRSxDQUFDOztBQW5IdUIscUJBQU0sR0FBRyxhQUFhLENBQUMsU0FBUyxDQUFDLGdCQUFnQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0xvZ2dlckZhY3Rvcnl9IGZyb20gJ0BlbGRlcmJ5dGUvdHMtbG9nZ2VyJztcblxuLy8gQGR5bmFtaWNcbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uVXRpbCB7XG5cbiAgcHJpdmF0ZSBzdGF0aWMgcmVhZG9ubHkgbG9nZ2VyID0gTG9nZ2VyRmFjdG9yeS5nZXRMb2dnZXIoJ0NvbGxlY3Rpb25VdGlsJyk7XG5cblxuICBwdWJsaWMgc3RhdGljIGZsYXR0ZW48VD4oZ3JvdXBzOiBUW11bXSk6IFRbXSB7XG4gICAgcmV0dXJuIGdyb3Vwc1xuICAgICAgLnJlZHVjZSgoYWNjLCB2YWwpID0+
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi11dGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tbW9uL3V0aWxzL2NvbGxlY3Rpb24tdXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFFbkQsV0FBVztBQUNYLE1BQU0sT0FBTyxjQUFjO0lBS2xCLE1BQU0sQ0FBQyxPQUFPLENBQUksTUFBYTtRQUNwQyxPQUFPLE1BQU07YUFDVixNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksTUFBTSxDQUFDLFFBQVEsQ0FBSSxLQUFVLEVBQUUsTUFBUztRQUU3QyxJQUFJLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQUUsT0FBTyxLQUFLLENBQUM7U0FBRTtRQUV2QyxNQUFNLFFBQVEsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRXZDLElBQUksUUFBUSxJQUFJLENBQUMsRUFBRTtZQUVqQixNQUFNLFdBQVcsR0FBRyxRQUFRLEdBQUcsQ0FBQyxDQUFDO1lBQ2pDLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1lBQ2hDLElBQUksQ0FBQyxDQUFDLE1BQU0sR0FBRyxXQUFXLENBQUMsRUFBRTtnQkFDM0IsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztnQkFDckMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxHQUFHLE1BQU0sQ0FBQztnQkFDNUIsT0FBTyxJQUFJLENBQUM7YUFDYjtpQkFBTTtnQkFDTCxJ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QUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0xvZ2dlckZhY3Rvcnl9IGZyb20gJ0BlbGRlcmJ5dGUvdHMtbG9nZ2VyJztcblxuLy8gQGR5bmFtaWNcbmV4cG9ydCBjbGFzcyBDb2xsZWN0aW9uVXRpbCB7XG5cbiAgcHJpdmF0ZSBzdGF0aWMgcmVhZG9ubHkgbG9nZ2VyID0gTG9nZ2VyRmFjdG9yeS5nZXRMb2dnZXIoJ0NvbGxlY3Rpb25VdGlsJyk7XG5cblxuICBwdWJsaWMgc3RhdGljIGZsYXR0ZW48VD4oZ3JvdXBzOiBUW11bXSk6IFRbXSB7XG4gICAgcmV0dXJuIGdyb3Vwc1xuICAgICAgLnJlZHVjZSgoYWNjLCB2YWwpID0+IGFjYy5jb25jYXQodmFsKSwgW10pO1xuICB9XG5cbiAgLyoqXG4gICAqIE1vdmVzIHRoZSBnaXZlbiBpdGVtIGRvd24gaW4gdGhlIGdpdmVuIGFycmF5IC0gaWYgbm90IGFscmVhZHkgYXQgdGhlIGJvdHRvbVxuICAgKiBAcGFyYW0gaXRlbXNcbiAgICogQHBhcmFtIHRvTW92ZVxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBtb3ZlRG93bjxUPihpdGVtczogVFtdLCB0b01vdmU6IFQpOiBib29sZWFuIHtcblxuICAgIGlmIChpdGVtcy5sZW5ndGggPCAyKSB7IHJldHVybiBmYWxzZTsgfVxuXG4gICAgY29uc3QgcG9zaXRpb24gPSBpdGVtcy5pbmRleE9mKHRvTW92ZSk7XG5cbiAgICBpZiAocG9zaXRpb24gPj0gMCkge1xuXG4gICAgICBjb25zdCB0YXJnZXRJbmRleCA9IHBvc2l0aW9uICsgMTtcbiAgICAgIGNvbnN0IGJvdHRvbSA9IGl0ZW1zLmxlbmd0aCAtIDE7XG4gICAgICBpZiAoIShib3R0b20gPCB0YXJnZXRJbmRleCkpIHtcbiAgICAgICAgaXRlbXNbcG9zaXRpb25dID0gaXRlbXNbdGFyZ2V0SW5kZXhdO1xuICAgICAgICBpdGVtc1t0YXJnZXRJbmRleF0gPSB0b01vdmU7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdGhpcy5sb2dnZXIuZGVidWcoJ0NhbiBub3QgbW92ZSBpdGVtIGRvd24gc2luY2UgdGFyZ2V0IGluZGV4ICcgKyB0YXJnZXRJbmRleCArICcgaXMgYWxyZWFkeSBhdCB0aGUgYm90dG9tOiAnICsgYm90dG9tKTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLyoqXG4gICAqIE1vdmVzIHRoZSBnaXZlbiBpdGVtIHVwIGluIHRoZSBnaXZlbiBhcnJheSAtIGlmIG5vdCBhbHJlYWR5IGF0IHRoZSB0b3BcbiAgICogQHBhcmFtIGl0ZW1zXG4gICAqIEBwYXJhbSB0b01vdmVcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgbW92ZVVwPFQ+KGl0ZW1zOiBUW10sIHRvTW92ZTogVCk6IGJvb2xlYW4ge1xuXG4gICAgaWYgKGl0ZW1zLmxlbmd0aCA8IDIpIHsgcmV0dXJuIGZhbHNlOyB9XG5cbiAgICBjb25zdCBwb3NpdGlvbiA9IGl0ZW1zLmluZGV4T2YodG9Nb3ZlKTtcblxuICAgIGlmIChwb3NpdGlvbiA+PSAwKSB7XG5cbiAgICAgIGNvbnN0IHRhcmdldEluZGV4ID0gcG9zaXRpb24gLSAxO1xuXG4gICAgICBpZiAodGFyZ2V0SW5kZXggPj0gMCkge1xuICAgICAgICBpdGVtc1twb3NpdGlvbl0gPSBpdGVtc1t0YXJnZXRJbmRleF07XG4gICAgICAgIGl0ZW1zW3RhcmdldEluZGV4XSA9IHRvTW92ZTtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHcm91cHMgdGhlIGdpdmVuIGl0ZW1zIGJ5IHRoZSBnaXZlbiBmaWVsZCBpbnRvIGEgTWFwXG4gICAqL1xuICAvLyBAZHluYW1pY1xuICBwdWJsaWMgc3RhdGljIGdyb3VwQnlGaWVsZDxHLCBUPihpdGVtczogVFtdLCBmaWVsZDogc3RyaW5nKTogTWFwPEcsIFRbXT4ge1xuICAgIHJldHVybiBDb2xsZWN0aW9uVXRpbC5ncm91cEJ5S2V5KGl0ZW1zLCBpdCA9PiAoaXQgYXMgYW55KVtmaWVsZF0gYXMgRyk7XG4gIH1cblxuICAvKipcbiAgICogR3JvdXBzIHRoZSBnaXZlbiBpdGVtcywgdXNpbmcgdGhlIGdyb3VwIGtleSBnZXR0ZXIsIGludG8gYSBNYXBcbiAgICogQGR5bmFtaWNcbiAgICovXG4gIC8vIEBkeW5hbWljXG4gIHB1YmxpYyBzdGF0aWMgZ3JvdXBCeUtleTxHLCBUPihpdGVtczogVFtdLCBrZXlHZXR0ZXI6ICgoaXRlbTogVCkgPT4gRykpOiBNYXA8RywgVFtdPiB7XG5cbiAgICByZXR1cm4gaXRlbXMucmVkdWNlKChtYXAsIHApID0+IHtcblxuICAgICAgbGV0IHN1YnNldDogVFtdO1xuXG4gICAgICBjb25zdCBrZXkgPSBrZXlHZXR0ZXIocCk7XG5cbiAgICAgIGlmIChtYXAuaGFzKGtleSkpIHtcbiAgICAgICAgc3Vic2V0ID0gbWFwLmdldChrZXkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgc3Vic2V0ID0gW107XG4gICAgICAgIG1hcC5zZXQoa2V5LCBzdWJzZXQpO1xuICAgICAgfVxuICAgICAgc3Vic2V0LnB1c2gocCk7XG4gICAgICByZXR1cm4gbWFwO1xuICAgIH0sIG5ldyBNYXAoKSk7XG4gIH1cblxuICAvKipcbiAgICogQ29tcGFyZXMgdHdvIHNldHMgdmFsdWVzIGRlZXAuXG4gICAqIElmIGJvdGggc2V0cyBoYXZlIHRoZSBzYW1lIGl0ZW1zLCB0aGV5IGFyZSBjb25zaWRlcmVkIGVxdWFsLlxuICAgKlxuICAgKiBXYXJuaW5nOiBEdXBsaWNhdGUgZWxlbWVudHMgYXJlIGlnbm9yZWQuXG4gICAqIEBwYXJhbSBhU2V0XG4gICAqIEBwYXJhbSBiU2V0XG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGVxdWFsU2V0RGVlcDxUPihhU2V0OiBTZXQ8VD4sIGJTZXQ6IFNldDxUPik6IGJvb2xlYW4ge1xuXG4gICAgaWYgKGFTZXQgPT09IGJTZXQpIHsgcmV0dXJuIHRydWU7IH1cblxuICAgIGlmICghYVNldCB8fCAhYlNldCkgeyByZXR1cm4gZmFsc2U7IH1cbiAgICBpZiAoYVNldC5zaXplICE9PSBiU2V0LnNpemUpIHsgcmV0dXJuIGZhbHNlOyB9IC8vIE11c3QgaGF2ZSBzYW1lIGxlbmd0aFxuXG4gICAgZm9yIChjb25zdCBhIG9mIGFTZXQpIHtcbiAgICAgIGlmICghYlNldC5oYXMoYSkpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgaGFzRWxlbWVudHMobGlzdDogYW55W10pOiBib29sZWFuIHtcbiAgICByZXR1cm4gbGlzdCAhPT0gbnVsbCAmJiBsaXN0ICE9PSB1bmRlZmluZWQgJiYgbGlzdC5sZW5ndGggPiAwO1xuICB9XG5cbn1cblxuXG4iXX0=
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, forwardRef, Input, Output, } from '@angular/core';
|
|
2
2
|
import { buildFormIntegrationProviders } from '../../../common/forms/template-composite-control';
|
|
3
3
|
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
4
|
-
import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
|
|
5
|
-
import { map, takeUntil, tap, skip, filter } from 'rxjs/operators';
|
|
4
|
+
import { BehaviorSubject, combineLatest, EMPTY, Subject } from 'rxjs';
|
|
5
|
+
import { map, takeUntil, tap, skip, filter, switchMap, take, timeout, catchError } from 'rxjs/operators';
|
|
6
6
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
7
7
|
import { ELDER_SELECT_BASE, ElderSelectBase, ElderSelectComponentState } from '../elder-select-base';
|
|
8
8
|
import { ElderSelectFirstUtil } from '../auto/elder-select-first-util';
|
|
@@ -64,7 +64,10 @@ export class ElderSelectComponent extends ElderSelectBase {
|
|
|
64
64
|
this.entityChange = this._entity$.pipe(skip(1) // Skip the initial or current value
|
|
65
65
|
);
|
|
66
66
|
this.entityIdUpdated = this.valueUpdated.pipe(map(value => this.entityIdFromValue(value)));
|
|
67
|
-
this.entityUpdated =
|
|
67
|
+
this.entityUpdated = this.entityIdUpdated.pipe(switchMap(entityId => this.awaitEntityWithId(entityId, this.timeoutAfterMs)), catchError(err => {
|
|
68
|
+
this.logger.warn(`awaitEntityWithId -> timed out after: ${this.timeoutAfterMs}`, err);
|
|
69
|
+
return EMPTY;
|
|
70
|
+
}));
|
|
68
71
|
this.entityWrapped$ = combineLatest([
|
|
69
72
|
this._entity$,
|
|
70
73
|
this.displayPropertyResolver$,
|
|
@@ -255,6 +258,9 @@ export class ElderSelectComponent extends ElderSelectBase {
|
|
|
255
258
|
valuesEquals(a, b) {
|
|
256
259
|
return this.entityIdFromValue(a) === this.entityIdFromValue(b);
|
|
257
260
|
}
|
|
261
|
+
awaitEntityWithId(entityId, timeoutMs) {
|
|
262
|
+
return this.entity$.pipe(filter(entity => this.getEntityId(entity) === entityId), take(1), timeout(timeoutMs));
|
|
263
|
+
}
|
|
258
264
|
isEntitySelected(entity) {
|
|
259
265
|
return this.getEntityId(entity) === this.entityId;
|
|
260
266
|
}
|
|
@@ -397,4 +403,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
|
|
|
397
403
|
}], hintPropertyResolver: [{
|
|
398
404
|
type: Input
|
|
399
405
|
}] } });
|
|
400
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component, forwardRef,\n  Input, NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {\n  map,\n  takeUntil,\n  tap, skip, filter, startWith\n} from 'rxjs/operators';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {ELDER_SELECT_BASE, ElderSelectBase, ElderSelectComponentState, TextResolverFn} from '../elder-select-base';\nimport {IElderEntityValueAccessor} from '../elder-entity-value-accessor';\nimport {ElderSelectFirstUtil} from '../auto/elder-select-first-util';\n\nclass EntityContext<T> {\n  constructor(\n    public readonly value: T,\n    public readonly hintText: string,\n    public readonly displayText: string\n  ) {\n  }\n}\n\n\n/**\n * The elder-select control allows to select a single\n * entity.\n *\n * Primary focus is on easy usage for common scenarios:\n *\n * - Integrated into angular forms and validation\n * - Support entity id handling, input / output is the entity id vs full value.\n *\n */\n@Component({\n  selector: 'elder-select',\n  templateUrl: './elder-select.component.html',\n  styleUrls: ['./elder-select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ELDER_SELECT_BASE,\n      useExisting: forwardRef(() => ElderSelectComponent)\n    },\n    ...buildFormIntegrationProviders(ElderSelectComponent)\n  ]\n})\nexport class ElderSelectComponent<TEntity = any, TId = any, TValue = TEntity | TId>\n  extends ElderSelectBase<TId, TEntity, TValue>\n  implements IElderEntityValueAccessor<TEntity, TId>, OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly hintPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: TEntity) => null);\n\n  private _allowNull = false;\n\n  /**\n   * String to display for the 'nothing' / null value.\n   */\n  @Input()\n  public nullDisplay = '-';\n\n  @Output()\n  public readonly entityIdChange: Observable<TId>;\n\n  /**\n   * Similar to entity-id change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityIdUpdated: Observable<TId>;\n\n  @Output()\n  public readonly entityChange: Observable<TEntity>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityUpdated: Observable<TEntity>;\n\n  private readonly _entity$ = new BehaviorSubject<TEntity>(undefined);\n\n  private _autocomplete = false;\n\n  public readonly entityWrapped$: Observable<EntityContext<TEntity>>;\n\n  private readonly unsubscribe$ = new Subject();\n\n  public readonly inputText$: Observable<string>;\n\n  private entityContext: EntityContext<TEntity>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone,\n  ) {\n    super(zone);\n\n    this.entityIdChange = this.valueChange.pipe(\n      map(v => this.entityIdFromValue(v))\n    );\n\n    this.entityChange = this._entity$.pipe(\n      skip(1) // Skip the initial or current value\n    );\n\n    this.entityIdUpdated = this.valueUpdated.pipe(\n      map(value => this.entityIdFromValue(value))\n    );\n\n    this.entityUpdated = combineLatest(\n      [this.entityIdUpdated, this._entity$]\n    ).pipe(\n       filter(([updatedId, entity]) => this.getEntityId(entity) === updatedId),\n        map(([updatedId, entity]) => entity)\n    );\n\n    this.entityWrapped$ = combineLatest(\n      [\n        this._entity$,\n        this.displayPropertyResolver$,\n        this.hintPropertyResolver$\n      ]\n    ).pipe(\n      map(([value, dPR, hPR]) => new EntityContext<TEntity>(value, hPR(value), dPR(value)))\n    );\n\n    this.inputText$ = this.entityWrapped$.pipe(\n      takeUntil(this.unsubscribe$),\n      tap(valueContext => this.entityContext = valueContext),\n      map(valueContext => {\n        if (valueContext.value) {\n          return valueContext.displayText;\n        } else {\n          return null;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n    this.autoCleanUp();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Behaviour Properties                                                    *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set autocomplete(value: boolean) {\n    this._autocomplete = coerceBooleanProperty(value);\n  }\n\n  public get autocomplete(): boolean {\n    return this._autocomplete;\n  }\n\n  /**\n   * Allows the user to select 'nothing' / null.\n   */\n  @Input()\n  public set allowNull(val: boolean) {\n    this._allowNull = coerceBooleanProperty(val);\n  }\n\n  public get allowNull(): boolean {\n    return this._allowNull;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set entity(entity: TEntity) {\n    this._entity$.next(entity);\n    this.writeValueInternal(\n      this.entityToValue(entity)\n    );\n  }\n\n  public get entity(): TEntity {\n    return this._entity$.getValue();\n  }\n\n  /**\n   * Gets the current entity as observable stream. (BehaviourSubject)\n   */\n  public get entity$(): Observable<TEntity> {\n    return this._entity$.asObservable();\n  }\n\n  @Input()\n  public set entityId(id: TId) {\n    if (this.valueAsId) {\n      this.writeValueInternal(<any>id as TValue);\n    } else {\n      this.selectEntityById(id);\n    }\n  }\n\n  public get entityId(): TId {\n    return this.entityIdFromValue(this.value);\n  }\n\n  @Input()\n  public set hintProperty(property: string) {\n    this.hintPropertyResolver = (value => this.propertyStringValue(value, property));\n  }\n\n  @Input()\n  public set hintPropertyResolver(resolver: TextResolverFn) {\n    this.hintPropertyResolver$.next(resolver);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onInputBlur(event: FocusEvent): void {\n    const input = event.target as HTMLInputElement;\n    if (this.entityContext.value) {\n      input.value = this.entityContext.displayText;\n    } else {\n      input.value = null;\n    }\n  }\n\n  public get isOptionDisabledInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (!this.isEntitySelected(option)) {\n        if (this.isOptionDisabledFn) {\n          return this.isOptionDisabledFn(option);\n        } else {\n          return false;\n        }\n      }\n      return true;\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isOptionHiddenFn) {\n        return this.isOptionHiddenFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n\n  public togglePanel(autoTrigger: MatAutocompleteTrigger): void {\n    if (autoTrigger.autocomplete.isOpen) {\n      autoTrigger.closePanel();\n    } else {\n      this.logger.debug('Requesting to open auto-complete panel...', autoTrigger);\n      if (this.suggestionsDc) {\n        try {\n          this.suggestionsDc.start(this.sorts, this.filters);\n        } catch (err) {\n          this.logger.error('Failed to start DC!', err);\n          this.updateState(ElderSelectComponentState.error(err));\n        }\n      }\n      autoTrigger.openPanel();\n    }\n  }\n\n  public onInputClicked(autoTrigger: MatAutocompleteTrigger): void {\n\n    // this.logger.debug('onInputClicked, locked: ' + this.isLocked + ', autocomplete: ' + this.autocomplete, autoTrigger);\n    if (this.isLocked || this.autocomplete) {\n      return;\n    }\n    this.togglePanel(autoTrigger);\n  }\n\n  public onOptionSelected(selectedValue: TEntity): void {\n    if (this.isEntitySelected(selectedValue)) {\n      this.writeValueInternal(null); // HACK: Ensure we trigger view redraw\n    }\n    this.updateValueByEntity(selectedValue);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        this.filters,\n        this.sorts\n      ).subscribe(\n        (selection: TEntity[]) => {\n          this.updateValueByEntity(selection[0]);\n        }\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  public clear(event: Event): void {\n    this.updateValue(null);\n  }\n\n  public forceReloadFirst() {\n    this.value = null; // valueId is set to null automatically\n    ElderSelectFirstUtil.trySelectFirst(this);\n  }\n\n  public updateValueByEntity(entity: TEntity): void {\n    this.updateValue(\n      this.entityToValue(entity)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract Implementation                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the suggestions data-context has changed\n   */\n  protected onSuggestionsDcChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntityById(this.entityId);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: TValue, b: TValue): boolean {\n    return this.entityIdFromValue(a) === this.entityIdFromValue(b);\n  }\n\n  private isEntitySelected(entity: TEntity): boolean {\n    return this.getEntityId(entity) === this.entityId;\n  }\n\n  private entityIdFromValue(value: TValue): TId {\n    if (this.valueAsId) {\n      return <any>value as TId;\n    } else {\n      const entity = (<any>value) as TEntity;\n      return this.getEntityId(entity);\n    }\n  }\n\n  private selectEntityById(id: TId): void {\n\n    const currentEntity = this.entity;\n    if (currentEntity && this.getEntityId(currentEntity) === id) {\n      return; // Entity already loaded\n    }\n\n    if (id === null || id === undefined) {\n      if (currentEntity !== null && currentEntity !== undefined) {\n        this.entity = null;\n      }\n    } else {\n      if (this.suggestionsDc) {\n        const existing = this.findInDataContext(id);\n        if (existing) {\n          this.entity = existing;\n        } else {\n          this.loadEntityById(id);\n        }\n      } else {\n        this.logger.warn('Failed to select value by Id: ' + id + ' - DataContext not available.');\n      }\n    }\n  }\n\n  private loadEntityById(id: TId): void {\n    this.suggestionsDc.dataSource.findById(<any>id)\n      .subscribe(\n        entity => {\n          this.logger.debug('Loaded missing entity by id ' + id + ':', entity);\n          this.entity = entity;\n        },\n        err => {\n          this.logger.error('Failed to load entity by id ' + id, err);\n          this.updateState(ElderSelectComponentState.error(err));\n        }\n      );\n  }\n\n  private findInDataContext(id: TId): TEntity | null {\n    return this.suggestionsDc.snapshot.data\n      .find(v => this.getEntityId(v) === id);\n  }\n\n  private entityToValue(entity: TEntity): TValue {\n    if (this.valueAsId) {\n      const id = this.getEntityId(entity);\n      return <any>id as TValue;\n    } else {\n      return <any>entity as TValue;\n    }\n  }\n\n  /**\n   * This method is invoked after a value has been written to this control.\n   *\n   */\n  protected writeToControl(value: TValue): void {\n    if (this.valueAsId) {\n      const entityId = <any>value as TId;\n      // Value was written as entity id, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as id: ' + entityId, value);\n      this.selectEntityById(entityId);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntity = this.entity;\n      const newEntity = <any>value as TEntity;\n      this.logger.debug('writeToControl: value was written as entity: ' + JSON.stringify(newEntity), value);\n      if (!this.isEqual(currentEntity, newEntity)) {\n        this._entity$.next(newEntity);\n      } else {\n        this.logger.warn('Ignored written entity as it is already set to entity$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n\n  /**\n   * @description\n   * Writes a new value to the element.\n   *\n   * This method is called by the forms API to write to the view when programmatic\n   * changes from model to view are requested.\n   *\n   * @param value The new value for the element\n   */\n  public writeValue(value: TValue): void {\n    // this.logger.debug('ElderSelectBase.writeValue(): Current value-id ' + this._valueId + ', new value: ', value);\n    super.writeValue(value);\n  }\n\n  private isNullOrEmpty(value: TValue): boolean {\n    return (value == null || (<any>value) === '');\n  }\n\n}\n","<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [floatLabel]=\"floatLabel\"\n                [color]=\"color\"\n>\n\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n  <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n    <mat-icon *ngIf=\"icon\" disabled\n              class=\"leading-icon prefix-padding noselect\"\n              [class.loading]=\"state.loading\"\n              [color]=\"state?.error ? 'warn' : color\">\n      {{icon}}\n    </mat-icon>\n\n\n    <mat-icon *ngIf=\"!icon && state?.error\"\n              class=\"leading-icon prefix-padding noselect\"\n              color=\"warn\">\n      warning\n    </mat-icon>\n  </ng-container>\n\n  <!-- A dynamic input -->\n  <input\n    matInput type=\"text\" fxFlex=\"grow\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    [readonly]=\"readonly || !autocomplete\"\n    [name]=\"name + '-inner-input'\"\n    [placeholder]=\"placeholder | translate\"\n    [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n    [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n    elderSelectOnTab\n    [class.select]=\"!autocomplete\" (click)=\"onInputClicked(autoTrigger)\"\n    [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n    (blur)=\"onInputBlur($event)\"\n  >\n\n  <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [enabled]=\"autocomplete\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n\n  <ng-container matSuffix>\n\n    <mat-icon\n      *ngIf=\"!autocomplete\" class=\"select-arrow noselect\"\n      (click)=\"onInputClicked(autoTrigger)\">\n      arrow_drop_down\n    </mat-icon>\n\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\n            [disabled]=\"isLocked\"\n            (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n            elderStopEventPropagation\n            tabIndex=\"-1\"\n    >\n      <mat-icon>search</mat-icon>\n    </button>\n\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"entityWrapper.value && allowNull\"\n            [disabled]=\"isLocked\"\n            (click)=\"clear($event)\" aria-label=\"Clear\"\n            elderStopEventPropagation\n            tabIndex=\"-1\"\n    >\n      <mat-icon>close</mat-icon>\n    </button>\n\n  </ng-container>\n\n  <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n"]}
|
|
406
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component, forwardRef,\n  Input, NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, combineLatest, EMPTY, Observable, Subject} from 'rxjs';\nimport {\n  map,\n  takeUntil,\n  tap, skip, filter, startWith, withLatestFrom, switchMap, take, timeout, catchError\n} from 'rxjs/operators';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {ELDER_SELECT_BASE, ElderSelectBase, ElderSelectComponentState, TextResolverFn} from '../elder-select-base';\nimport {IElderEntityValueAccessor} from '../elder-entity-value-accessor';\nimport {ElderSelectFirstUtil} from '../auto/elder-select-first-util';\n\nclass EntityContext<T> {\n  constructor(\n    public readonly value: T,\n    public readonly hintText: string,\n    public readonly displayText: string\n  ) {\n  }\n}\n\n\n/**\n * The elder-select control allows to select a single\n * entity.\n *\n * Primary focus is on easy usage for common scenarios:\n *\n * - Integrated into angular forms and validation\n * - Support entity id handling, input / output is the entity id vs full value.\n *\n */\n@Component({\n  selector: 'elder-select',\n  templateUrl: './elder-select.component.html',\n  styleUrls: ['./elder-select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ELDER_SELECT_BASE,\n      useExisting: forwardRef(() => ElderSelectComponent)\n    },\n    ...buildFormIntegrationProviders(ElderSelectComponent)\n  ]\n})\nexport class ElderSelectComponent<TEntity = any, TId = any, TValue = TEntity | TId>\n  extends ElderSelectBase<TId, TEntity, TValue>\n  implements IElderEntityValueAccessor<TEntity, TId>, OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly hintPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: TEntity) => null);\n\n  private _allowNull = false;\n\n  /**\n   * String to display for the 'nothing' / null value.\n   */\n  @Input()\n  public nullDisplay = '-';\n\n  @Output()\n  public readonly entityIdChange: Observable<TId>;\n\n  /**\n   * Similar to entity-id change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityIdUpdated: Observable<TId>;\n\n  @Output()\n  public readonly entityChange: Observable<TEntity>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityUpdated: Observable<TEntity>;\n\n  private readonly _entity$ = new BehaviorSubject<TEntity>(undefined);\n\n  private _autocomplete = false;\n\n  public readonly entityWrapped$: Observable<EntityContext<TEntity>>;\n\n  private readonly unsubscribe$ = new Subject();\n\n  public readonly inputText$: Observable<string>;\n\n  private entityContext: EntityContext<TEntity>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone,\n  ) {\n    super(zone);\n\n    this.entityIdChange = this.valueChange.pipe(\n      map(v => this.entityIdFromValue(v))\n    );\n\n    this.entityChange = this._entity$.pipe(\n      skip(1) // Skip the initial or current value\n    );\n\n    this.entityIdUpdated = this.valueUpdated.pipe(\n      map(value => this.entityIdFromValue(value))\n    );\n\n    this.entityUpdated = this.entityIdUpdated.pipe(\n      switchMap(entityId => this.awaitEntityWithId(entityId, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntityWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n\n    this.entityWrapped$ = combineLatest(\n      [\n        this._entity$,\n        this.displayPropertyResolver$,\n        this.hintPropertyResolver$\n      ]\n    ).pipe(\n      map(([value, dPR, hPR]) => new EntityContext<TEntity>(value, hPR(value), dPR(value)))\n    );\n\n    this.inputText$ = this.entityWrapped$.pipe(\n      takeUntil(this.unsubscribe$),\n      tap(valueContext => this.entityContext = valueContext),\n      map(valueContext => {\n        if (valueContext.value) {\n          return valueContext.displayText;\n        } else {\n          return null;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n    this.autoCleanUp();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Behaviour Properties                                                    *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set autocomplete(value: boolean) {\n    this._autocomplete = coerceBooleanProperty(value);\n  }\n\n  public get autocomplete(): boolean {\n    return this._autocomplete;\n  }\n\n  /**\n   * Allows the user to select 'nothing' / null.\n   */\n  @Input()\n  public set allowNull(val: boolean) {\n    this._allowNull = coerceBooleanProperty(val);\n  }\n\n  public get allowNull(): boolean {\n    return this._allowNull;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set entity(entity: TEntity) {\n    this._entity$.next(entity);\n    this.writeValueInternal(\n      this.entityToValue(entity)\n    );\n  }\n\n  public get entity(): TEntity {\n    return this._entity$.getValue();\n  }\n\n  /**\n   * Gets the current entity as observable stream. (BehaviourSubject)\n   */\n  public get entity$(): Observable<TEntity> {\n    return this._entity$.asObservable();\n  }\n\n  @Input()\n  public set entityId(id: TId) {\n    if (this.valueAsId) {\n      this.writeValueInternal(<any>id as TValue);\n    } else {\n      this.selectEntityById(id);\n    }\n  }\n\n  public get entityId(): TId {\n    return this.entityIdFromValue(this.value);\n  }\n\n  @Input()\n  public set hintProperty(property: string) {\n    this.hintPropertyResolver = (value => this.propertyStringValue(value, property));\n  }\n\n  @Input()\n  public set hintPropertyResolver(resolver: TextResolverFn) {\n    this.hintPropertyResolver$.next(resolver);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onInputBlur(event: FocusEvent): void {\n    const input = event.target as HTMLInputElement;\n    if (this.entityContext.value) {\n      input.value = this.entityContext.displayText;\n    } else {\n      input.value = null;\n    }\n  }\n\n  public get isOptionDisabledInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (!this.isEntitySelected(option)) {\n        if (this.isOptionDisabledFn) {\n          return this.isOptionDisabledFn(option);\n        } else {\n          return false;\n        }\n      }\n      return true;\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isOptionHiddenFn) {\n        return this.isOptionHiddenFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n\n  public togglePanel(autoTrigger: MatAutocompleteTrigger): void {\n    if (autoTrigger.autocomplete.isOpen) {\n      autoTrigger.closePanel();\n    } else {\n      this.logger.debug('Requesting to open auto-complete panel...', autoTrigger);\n      if (this.suggestionsDc) {\n        try {\n          this.suggestionsDc.start(this.sorts, this.filters);\n        } catch (err) {\n          this.logger.error('Failed to start DC!', err);\n          this.updateState(ElderSelectComponentState.error(err));\n        }\n      }\n      autoTrigger.openPanel();\n    }\n  }\n\n  public onInputClicked(autoTrigger: MatAutocompleteTrigger): void {\n\n    // this.logger.debug('onInputClicked, locked: ' + this.isLocked + ', autocomplete: ' + this.autocomplete, autoTrigger);\n    if (this.isLocked || this.autocomplete) {\n      return;\n    }\n    this.togglePanel(autoTrigger);\n  }\n\n  public onOptionSelected(selectedValue: TEntity): void {\n    if (this.isEntitySelected(selectedValue)) {\n      this.writeValueInternal(null); // HACK: Ensure we trigger view redraw\n    }\n    this.updateValueByEntity(selectedValue);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        this.filters,\n        this.sorts\n      ).subscribe(\n        (selection: TEntity[]) => {\n          this.updateValueByEntity(selection[0]);\n        }\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  public clear(event: Event): void {\n    this.updateValue(null);\n  }\n\n  public forceReloadFirst() {\n    this.value = null; // valueId is set to null automatically\n    ElderSelectFirstUtil.trySelectFirst(this);\n  }\n\n  public updateValueByEntity(entity: TEntity): void {\n    this.updateValue(\n      this.entityToValue(entity)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract Implementation                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the suggestions data-context has changed\n   */\n  protected onSuggestionsDcChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntityById(this.entityId);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: TValue, b: TValue): boolean {\n    return this.entityIdFromValue(a) === this.entityIdFromValue(b);\n  }\n\n  private awaitEntityWithId(entityId: TId, timeoutMs: number): Observable<TEntity> {\n    return this.entity$.pipe(\n      filter(entity => this.getEntityId(entity) === entityId),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  private isEntitySelected(entity: TEntity): boolean {\n    return this.getEntityId(entity) === this.entityId;\n  }\n\n  private entityIdFromValue(value: TValue): TId {\n    if (this.valueAsId) {\n      return <any>value as TId;\n    } else {\n      const entity = (<any>value) as TEntity;\n      return this.getEntityId(entity);\n    }\n  }\n\n  private selectEntityById(id: TId): void {\n\n    const currentEntity = this.entity;\n    if (currentEntity && this.getEntityId(currentEntity) === id) {\n      return; // Entity already loaded\n    }\n\n    if (id === null || id === undefined) {\n      if (currentEntity !== null && currentEntity !== undefined) {\n        this.entity = null;\n      }\n    } else {\n      if (this.suggestionsDc) {\n        const existing = this.findInDataContext(id);\n        if (existing) {\n          this.entity = existing;\n        } else {\n          this.loadEntityById(id);\n        }\n      } else {\n        this.logger.warn('Failed to select value by Id: ' + id + ' - DataContext not available.');\n      }\n    }\n  }\n\n  private loadEntityById(id: TId): void {\n    this.suggestionsDc.dataSource.findById(<any>id)\n      .subscribe(\n        entity => {\n          this.logger.debug('Loaded missing entity by id ' + id + ':', entity);\n          this.entity = entity;\n        },\n        err => {\n          this.logger.error('Failed to load entity by id ' + id, err);\n          this.updateState(ElderSelectComponentState.error(err));\n        }\n      );\n  }\n\n  private findInDataContext(id: TId): TEntity | null {\n    return this.suggestionsDc.snapshot.data\n      .find(v => this.getEntityId(v) === id);\n  }\n\n  private entityToValue(entity: TEntity): TValue {\n    if (this.valueAsId) {\n      const id = this.getEntityId(entity);\n      return <any>id as TValue;\n    } else {\n      return <any>entity as TValue;\n    }\n  }\n\n  /**\n   * This method is invoked after a value has been written to this control.\n   *\n   */\n  protected writeToControl(value: TValue): void {\n    if (this.valueAsId) {\n      const entityId = <any>value as TId;\n      // Value was written as entity id, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as id: ' + entityId, value);\n      this.selectEntityById(entityId);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntity = this.entity;\n      const newEntity = <any>value as TEntity;\n      this.logger.debug('writeToControl: value was written as entity: ' + JSON.stringify(newEntity), value);\n      if (!this.isEqual(currentEntity, newEntity)) {\n        this._entity$.next(newEntity);\n      } else {\n        this.logger.warn('Ignored written entity as it is already set to entity$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n\n  /**\n   * @description\n   * Writes a new value to the element.\n   *\n   * This method is called by the forms API to write to the view when programmatic\n   * changes from model to view are requested.\n   *\n   * @param value The new value for the element\n   */\n  public writeValue(value: TValue): void {\n    // this.logger.debug('ElderSelectBase.writeValue(): Current value-id ' + this._valueId + ', new value: ', value);\n    super.writeValue(value);\n  }\n\n  private isNullOrEmpty(value: TValue): boolean {\n    return (value == null || (<any>value) === '');\n  }\n\n}\n","<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [floatLabel]=\"floatLabel\"\n                [color]=\"color\"\n>\n\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n  <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n    <mat-icon *ngIf=\"icon\" disabled\n              class=\"leading-icon prefix-padding noselect\"\n              [class.loading]=\"state.loading\"\n              [color]=\"state?.error ? 'warn' : color\">\n      {{icon}}\n    </mat-icon>\n\n\n    <mat-icon *ngIf=\"!icon && state?.error\"\n              class=\"leading-icon prefix-padding noselect\"\n              color=\"warn\">\n      warning\n    </mat-icon>\n  </ng-container>\n\n  <!-- A dynamic input -->\n  <input\n    matInput type=\"text\" fxFlex=\"grow\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    [readonly]=\"readonly || !autocomplete\"\n    [name]=\"name + '-inner-input'\"\n    [placeholder]=\"placeholder | translate\"\n    [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n    [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n    elderSelectOnTab\n    [class.select]=\"!autocomplete\" (click)=\"onInputClicked(autoTrigger)\"\n    [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n    (blur)=\"onInputBlur($event)\"\n  >\n\n  <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [enabled]=\"autocomplete\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n\n  <ng-container matSuffix>\n\n    <mat-icon\n      *ngIf=\"!autocomplete\" class=\"select-arrow noselect\"\n      (click)=\"onInputClicked(autoTrigger)\">\n      arrow_drop_down\n    </mat-icon>\n\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\n            [disabled]=\"isLocked\"\n            (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n            elderStopEventPropagation\n            tabIndex=\"-1\"\n    >\n      <mat-icon>search</mat-icon>\n    </button>\n\n    <button mat-icon-button type=\"button\"\n            *ngIf=\"entityWrapper.value && allowNull\"\n            [disabled]=\"isLocked\"\n            (click)=\"clear($event)\" aria-label=\"Clear\"\n            elderStopEventPropagation\n            tabIndex=\"-1\"\n    >\n      <mat-icon>close</mat-icon>\n    </button>\n\n  </ng-container>\n\n  <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n"]}
|
|
@@ -66,6 +66,7 @@ export class ElderSelectBase extends FormFieldBaseComponent {
|
|
|
66
66
|
**************************************************************************/
|
|
67
67
|
this._logger = LoggerFactory.getLogger(this.constructor.name);
|
|
68
68
|
this._filterContext = new FilterContext();
|
|
69
|
+
this.timeoutAfterMs = 5000;
|
|
69
70
|
/**
|
|
70
71
|
* Define if elder-select should clean up the
|
|
71
72
|
* data-context resources for you.
|
|
@@ -253,4 +254,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
|
|
|
253
254
|
}], valueTemplate: [{
|
|
254
255
|
type: Input
|
|
255
256
|
}] } });
|
|
256
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select-base.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {ContentChild, Directive, InjectionToken, Input, NgZone, TemplateRef} from '@angular/core';\nimport {FormFieldBaseComponent} from '../../common/forms/form-field-base.component';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {IDataContext} from '../../common/data/data-context/data-context';\nimport {IDataSource} from '../../common/data/datasource/data-source';\nimport {DataContextBuilder} from '../../common/data/data-context/data-context-builder';\nimport {Filter} from '../../common/data/filter';\nimport {Sort} from '../../common/data/sort';\nimport {ElderSelectValueDirective} from './elder-select-value.directive';\nimport {SelectionModelPopupDirective} from './popup/selection-model-popup.directive';\nimport {DataContextStatus} from '../../common/data/data-context/data-context-status';\nimport {filter, map, switchMap} from 'rxjs/operators';\nimport {runInZone} from '../../common/utils/ng-zone-utils';\nimport {FilterContext} from '../../common/data/filter-context';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\nexport type TextResolverFn = (value: any) => string;\n\n\n\nexport class ElderSelectComponentState {\n\n  public static fromDataContext(dcState: DataContextStatus): ElderSelectComponentState {\n    if (dcState.loading) {\n      return ElderSelectComponentState.loading();\n    } else if (dcState.error) {\n      return ElderSelectComponentState.error(dcState.error);\n    } else {\n      return ElderSelectComponentState.idle();\n    }\n  }\n\n\n  public static idle(): ElderSelectComponentState {\n    return new ElderSelectComponentState(true, false, null);\n  }\n\n  public static loading(): ElderSelectComponentState {\n    return new ElderSelectComponentState(false, true, null);\n  }\n\n  public static error(error: string): ElderSelectComponentState {\n    return new ElderSelectComponentState(false, false, error);\n  }\n\n  constructor(\n    public readonly idle: boolean,\n    public readonly loading: boolean,\n    public readonly error: string\n  ) {\n  }\n}\n\nexport const ELDER_SELECT_BASE = new InjectionToken<ElderSelectBase<any, any, any>>('ElderSelectBase');\n\n\n/**\n * Base component for Elder Selection Controls.\n *\n *  Elder Selection has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n *\n * @param TID Entity Id Type\n * @param T Entity Type\n * @param TValue Value backing the control. Can be the entity, the id or something else.\n */\n@Directive()\n// tslint:disable-next-line:directive-class-suffix\nexport abstract class ElderSelectBase<TId, TEntity, TValue> extends FormFieldBaseComponent<TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _logger = LoggerFactory.getLogger(this.constructor.name);\n  private readonly _filterContext = new FilterContext();\n\n  private _valueAsId: boolean;\n\n  /**\n   * Define if elder-select 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  public readonly displayPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: TEntity) => this.propertyStringValue(value, null));\n\n  /** Underlying data context. */\n  public readonly suggestionsDc$ = new BehaviorSubject<IDataContext<TEntity>>(null);\n\n  /**\n   * Page size. (Used for infinite scrolling chunks)\n   */\n  @Input()\n  public pageSize = 10;\n\n  @Input()\n  public queryFilter = 'query';\n\n  @Input()\n  public sorts: Sort[] = [];\n\n  /**\n   * The option template to customize the ui look.\n   */\n  @ContentChild(ElderSelectValueDirective, {read: TemplateRef, static: true})\n  public valueTemplateQuery: TemplateRef<any>;\n  private _valueTemplate: TemplateRef<any>;\n\n  @ContentChild(SelectionModelPopupDirective)\n  public selectionPopup: SelectionModelPopupDirective;\n\n  @Input()\n  public isOptionDisabledFn: (option: TEntity) => boolean;\n\n  @Input()\n  public isOptionHiddenFn: (option: TEntity) => boolean;\n\n  public readonly state$ = new BehaviorSubject<ElderSelectComponentState>(ElderSelectComponentState.idle());\n  public readonly mergedState$: Observable<ElderSelectComponentState>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    private readonly zone: NgZone,\n  ) {\n    super();\n\n    this.mergedState$ = combineLatest([\n      this.suggestionsDc$.pipe(filter(dc => !!dc), switchMap(dc => dc.status)),\n      this.state$\n    ]).pipe(\n      map(([dcState, state]) => {\n        if (dcState.idle) {\n          return state;\n        } else {\n          return ElderSelectComponentState.fromDataContext(dcState);\n        }\n      }),\n      runInZone(this.zone)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set valueAsId(valueAsId: boolean) {\n    this._valueAsId = coerceBooleanProperty(valueAsId);\n  }\n\n  public get valueAsId(): boolean {\n    return this._valueAsId;\n  }\n\n  /**\n   * The property used to display the values.\n   */\n  @Input()\n  public set displayProperty(property: string) {\n    this.displayPropertyResolver = (value => this.propertyStringValue(value, property));\n  }\n\n  @Input()\n  public set displayPropertyResolver(resolver: TextResolverFn) {\n    this.displayPropertyResolver$.next(resolver);\n  }\n\n  @Input()\n  public set filters(filters: Filter[]) {\n    this.replaceFilters(filters);\n  }\n\n  public get filters(): Filter[] {\n    return this._filterContext.filtersSnapshot;\n  }\n\n  @Input()\n  public set dataSource(source: IDataSource<TEntity>) {\n    this.suggestionsDc = DataContextBuilder.start<TEntity>()\n      .pageSize(this.pageSize)\n      .build(source);\n  }\n\n  @Input()\n  public set data(data: Array<TEntity> | IDataContext<TEntity>) {\n\n    this.autoCleanUp();\n\n    if (data instanceof Array) {\n      this.suggestionsDc = DataContextBuilder.start<TEntity>()\n        .buildLocal(data); // Memory leak\n      this.suggestionsDc.start();\n    } else {\n      if (data) {\n        this.suggestionsDc = data;\n      } else {\n        this.suggestionsDc = DataContextBuilder.start<TEntity>().buildEmpty();\n      }\n    }\n  }\n\n  public set suggestionsDc(data: IDataContext<TEntity>) {\n    this.autoCleanUp();\n    this.suggestionsDc$.next(data);\n    this.onSuggestionsDcChanged(data);\n  }\n\n  public get suggestionsDc(): IDataContext<TEntity> {\n    return this.suggestionsDc$.getValue();\n  }\n\n  @Input()\n  public set valueTemplate(template: TemplateRef<any>) {\n    this._valueTemplate = template;\n  }\n\n  public get valueTemplate(): TemplateRef<any> {\n    return this._valueTemplate || this.valueTemplateQuery;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public updateFilter(updatedFilter?: Filter): void {\n    this._filterContext.updateFilter(updatedFilter);\n  }\n\n  public updateFilters(updatedFilters?: Filter[]): void {\n    this._filterContext.updateFilters(updatedFilters);\n  }\n\n  public replaceFilters(newFilters?: Filter[]) {\n    this._filterContext.replaceFilters(newFilters);\n  }\n\n  public clearFilters(): void {\n    this._filterContext.clear();\n  }\n\n  public updateState(state: ElderSelectComponentState): void {\n    this.state$.next(state);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the suggestions data-context has changed\n   */\n  protected abstract onSuggestionsDcChanged(data: IDataContext<TEntity>): void;\n\n  /***************************************************************************\n   *                                                                         *\n   * Internal API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  protected getEntityId(entity: TEntity): TId {\n    return this.suggestionsDc?.dataSource?.getId(entity) || entity;\n  }\n\n  protected isEqual(a: TEntity, b: TEntity): boolean {\n    if (a === b) {\n      return true;\n    }\n    if (this.isEmpty(a) && this.isEmpty(b)) { // HACK: Handle empty string as undefined.\n      return true;\n    }\n    return this.getEntityId(a) === this.getEntityId(b);\n  }\n\n  protected isEmpty(a: TEntity): boolean {\n    return (a === null || a === undefined || <any>a === '');\n  }\n\n  /**\n   * Performs clean up of the current data context if auto clean up is enabled.\n   */\n  protected autoCleanUp(): void {\n    if (this.cleanUp && this.suggestionsDc) {\n      this._logger.debug('Releasing DataContext resources to prevent memory leak. [cleanUp]=\"true\"');\n      this.suggestionsDc.close();\n    }\n  }\n\n  protected propertyStringValue(value: TEntity, property: string): string | null {\n    if (value === null || value === undefined) {\n      return null;\n    }\n\n    if (property) {\n      return (<any>value)[property];\n    }\n\n    return String(value);\n  }\n}\n"]}
|
|
257
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select-base.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {ContentChild, Directive, InjectionToken, Input, NgZone, TemplateRef} from '@angular/core';\nimport {FormFieldBaseComponent} from '../../common/forms/form-field-base.component';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {IDataContext} from '../../common/data/data-context/data-context';\nimport {IDataSource} from '../../common/data/datasource/data-source';\nimport {DataContextBuilder} from '../../common/data/data-context/data-context-builder';\nimport {Filter} from '../../common/data/filter';\nimport {Sort} from '../../common/data/sort';\nimport {ElderSelectValueDirective} from './elder-select-value.directive';\nimport {SelectionModelPopupDirective} from './popup/selection-model-popup.directive';\nimport {DataContextStatus} from '../../common/data/data-context/data-context-status';\nimport {filter, map, switchMap} from 'rxjs/operators';\nimport {runInZone} from '../../common/utils/ng-zone-utils';\nimport {FilterContext} from '../../common/data/filter-context';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\n\nexport type TextResolverFn = (value: any) => string;\n\n\n\nexport class ElderSelectComponentState {\n\n  public static fromDataContext(dcState: DataContextStatus): ElderSelectComponentState {\n    if (dcState.loading) {\n      return ElderSelectComponentState.loading();\n    } else if (dcState.error) {\n      return ElderSelectComponentState.error(dcState.error);\n    } else {\n      return ElderSelectComponentState.idle();\n    }\n  }\n\n\n  public static idle(): ElderSelectComponentState {\n    return new ElderSelectComponentState(true, false, null);\n  }\n\n  public static loading(): ElderSelectComponentState {\n    return new ElderSelectComponentState(false, true, null);\n  }\n\n  public static error(error: string): ElderSelectComponentState {\n    return new ElderSelectComponentState(false, false, error);\n  }\n\n  constructor(\n    public readonly idle: boolean,\n    public readonly loading: boolean,\n    public readonly error: string\n  ) {\n  }\n}\n\nexport const ELDER_SELECT_BASE = new InjectionToken<ElderSelectBase<any, any, any>>('ElderSelectBase');\n\n\n/**\n * Base component for Elder Selection Controls.\n *\n *  Elder Selection has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n *\n * @param TID Entity Id Type\n * @param T Entity Type\n * @param TValue Value backing the control. Can be the entity, the id or something else.\n */\n@Directive()\n// tslint:disable-next-line:directive-class-suffix\nexport abstract class ElderSelectBase<TId, TEntity, TValue> extends FormFieldBaseComponent<TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _logger = LoggerFactory.getLogger(this.constructor.name);\n  private readonly _filterContext = new FilterContext();\n\n  private _valueAsId: boolean;\n\n  protected timeoutAfterMs = 5000;\n\n  /**\n   * Define if elder-select 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  public readonly displayPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: TEntity) => this.propertyStringValue(value, null));\n\n  /** Underlying data context. */\n  public readonly suggestionsDc$ = new BehaviorSubject<IDataContext<TEntity>>(null);\n\n  /**\n   * Page size. (Used for infinite scrolling chunks)\n   */\n  @Input()\n  public pageSize = 10;\n\n  @Input()\n  public queryFilter = 'query';\n\n  @Input()\n  public sorts: Sort[] = [];\n\n  /**\n   * The option template to customize the ui look.\n   */\n  @ContentChild(ElderSelectValueDirective, {read: TemplateRef, static: true})\n  public valueTemplateQuery: TemplateRef<any>;\n  private _valueTemplate: TemplateRef<any>;\n\n  @ContentChild(SelectionModelPopupDirective)\n  public selectionPopup: SelectionModelPopupDirective;\n\n  @Input()\n  public isOptionDisabledFn: (option: TEntity) => boolean;\n\n  @Input()\n  public isOptionHiddenFn: (option: TEntity) => boolean;\n\n  public readonly state$ = new BehaviorSubject<ElderSelectComponentState>(ElderSelectComponentState.idle());\n  public readonly mergedState$: Observable<ElderSelectComponentState>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    private readonly zone: NgZone,\n  ) {\n    super();\n\n    this.mergedState$ = combineLatest([\n      this.suggestionsDc$.pipe(filter(dc => !!dc), switchMap(dc => dc.status)),\n      this.state$\n    ]).pipe(\n      map(([dcState, state]) => {\n        if (dcState.idle) {\n          return state;\n        } else {\n          return ElderSelectComponentState.fromDataContext(dcState);\n        }\n      }),\n      runInZone(this.zone)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set valueAsId(valueAsId: boolean) {\n    this._valueAsId = coerceBooleanProperty(valueAsId);\n  }\n\n  public get valueAsId(): boolean {\n    return this._valueAsId;\n  }\n\n  /**\n   * The property used to display the values.\n   */\n  @Input()\n  public set displayProperty(property: string) {\n    this.displayPropertyResolver = (value => this.propertyStringValue(value, property));\n  }\n\n  @Input()\n  public set displayPropertyResolver(resolver: TextResolverFn) {\n    this.displayPropertyResolver$.next(resolver);\n  }\n\n  @Input()\n  public set filters(filters: Filter[]) {\n    this.replaceFilters(filters);\n  }\n\n  public get filters(): Filter[] {\n    return this._filterContext.filtersSnapshot;\n  }\n\n  @Input()\n  public set dataSource(source: IDataSource<TEntity>) {\n    this.suggestionsDc = DataContextBuilder.start<TEntity>()\n      .pageSize(this.pageSize)\n      .build(source);\n  }\n\n  @Input()\n  public set data(data: Array<TEntity> | IDataContext<TEntity>) {\n\n    this.autoCleanUp();\n\n    if (data instanceof Array) {\n      this.suggestionsDc = DataContextBuilder.start<TEntity>()\n        .buildLocal(data); // Memory leak\n      this.suggestionsDc.start();\n    } else {\n      if (data) {\n        this.suggestionsDc = data;\n      } else {\n        this.suggestionsDc = DataContextBuilder.start<TEntity>().buildEmpty();\n      }\n    }\n  }\n\n  public set suggestionsDc(data: IDataContext<TEntity>) {\n    this.autoCleanUp();\n    this.suggestionsDc$.next(data);\n    this.onSuggestionsDcChanged(data);\n  }\n\n  public get suggestionsDc(): IDataContext<TEntity> {\n    return this.suggestionsDc$.getValue();\n  }\n\n  @Input()\n  public set valueTemplate(template: TemplateRef<any>) {\n    this._valueTemplate = template;\n  }\n\n  public get valueTemplate(): TemplateRef<any> {\n    return this._valueTemplate || this.valueTemplateQuery;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public updateFilter(updatedFilter?: Filter): void {\n    this._filterContext.updateFilter(updatedFilter);\n  }\n\n  public updateFilters(updatedFilters?: Filter[]): void {\n    this._filterContext.updateFilters(updatedFilters);\n  }\n\n  public replaceFilters(newFilters?: Filter[]) {\n    this._filterContext.replaceFilters(newFilters);\n  }\n\n  public clearFilters(): void {\n    this._filterContext.clear();\n  }\n\n  public updateState(state: ElderSelectComponentState): void {\n    this.state$.next(state);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the suggestions data-context has changed\n   */\n  protected abstract onSuggestionsDcChanged(data: IDataContext<TEntity>): void;\n\n  /***************************************************************************\n   *                                                                         *\n   * Internal API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  protected getEntityId(entity: TEntity): TId {\n    return this.suggestionsDc?.dataSource?.getId(entity) || entity;\n  }\n\n  protected isEqual(a: TEntity, b: TEntity): boolean {\n    if (a === b) {\n      return true;\n    }\n    if (this.isEmpty(a) && this.isEmpty(b)) { // HACK: Handle empty string as undefined.\n      return true;\n    }\n    return this.getEntityId(a) === this.getEntityId(b);\n  }\n\n  protected isEmpty(a: TEntity): boolean {\n    return (a === null || a === undefined || <any>a === '');\n  }\n\n  /**\n   * Performs clean up of the current data context if auto clean up is enabled.\n   */\n  protected autoCleanUp(): void {\n    if (this.cleanUp && this.suggestionsDc) {\n      this._logger.debug('Releasing DataContext resources to prevent memory leak. [cleanUp]=\"true\"');\n      this.suggestionsDc.close();\n    }\n  }\n\n  protected propertyStringValue(value: TEntity, property: string): string | null {\n    if (value === null || value === undefined) {\n      return null;\n    }\n\n    if (property) {\n      return (<any>value)[property];\n    }\n\n    return String(value);\n  }\n}\n"]}
|