@elderbyte/ngx-starter 15.10.5 → 15.12.0

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.
Files changed (29) hide show
  1. package/esm2020/lib/common/arrays.mjs +29 -0
  2. package/esm2020/lib/common/public_api.mjs +5 -4
  3. package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +9 -21
  4. package/esm2020/lib/components/data-view/table/activation/elder-delete-active.directive.mjs +113 -0
  5. package/esm2020/lib/components/data-view/table/activation/elder-table-activation.directive.mjs +53 -39
  6. package/esm2020/lib/components/data-view/table/elder-table.module.mjs +11 -5
  7. package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +1 -1
  8. package/esm2020/lib/components/dialogs/elder-dialog.service.mjs +62 -28
  9. package/esm2020/lib/components/select/elder-select.module.mjs +19 -7
  10. package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +17 -23
  11. package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +24 -11
  12. package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +5 -5
  13. package/fesm2015/elderbyte-ngx-starter.mjs +418 -225
  14. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  15. package/fesm2020/elderbyte-ngx-starter.mjs +416 -225
  16. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  17. package/lib/common/arrays.d.ts +11 -0
  18. package/lib/common/public_api.d.ts +4 -3
  19. package/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.d.ts +1 -1
  20. package/lib/components/data-view/table/activation/elder-delete-active.directive.d.ts +53 -0
  21. package/lib/components/data-view/table/activation/elder-table-activation.directive.d.ts +8 -5
  22. package/lib/components/data-view/table/elder-table.module.d.ts +24 -22
  23. package/lib/components/dialogs/elder-dialog.module.d.ts +1 -1
  24. package/lib/components/dialogs/elder-dialog.service.d.ts +34 -12
  25. package/lib/components/select/elder-select.module.d.ts +12 -11
  26. package/lib/components/select/multi/elder-multi-select-base.d.ts +2 -0
  27. package/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.d.ts +5 -1
  28. package/package.json +1 -1
  29. package/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.scss +26 -0
@@ -5,6 +5,7 @@ import { LoggerFactory } from '@elderbyte/ts-logger';
5
5
  import { catchError, filter, map, skip, switchMap, take, tap, timeout } from 'rxjs/operators';
6
6
  import { Sets } from '../../../common/sets';
7
7
  import { SortUtil } from '../../../common/utils/sort-util';
8
+ import { Arrays } from '../../../common/arrays';
8
9
  import * as i0 from "@angular/core";
9
10
  import * as i1 from "@angular/cdk/a11y";
10
11
  import * as i2 from "@ngx-translate/core";
@@ -72,16 +73,15 @@ export class ElderMultiSelectBase extends ElderSelectBase {
72
73
  return this._entityIds$;
73
74
  }
74
75
  set entities(entities) {
75
- if (!this.equalEntities(this.entities, entities)) {
76
- entities = this.writeEntitiesSorted(entities);
77
- this.writeValueInternal(this.entitiesToValues(entities));
76
+ if (!this.equalEntitiesExactOrder(this.entities, entities)) {
77
+ this.writeValueInternal(this.entitiesToValues(this.writeEntitiesSorted(entities)));
78
78
  }
79
79
  }
80
80
  get entities() {
81
81
  return this._entities$.getValue();
82
82
  }
83
83
  set entityIds(ids) {
84
- if (!this.equalIds(this.entityIds, ids)) {
84
+ if (!this.equalIdsExactOrder(this.entityIds, ids)) {
85
85
  if (this.valueAsId) {
86
86
  this.writeValueInternal(ids);
87
87
  }
@@ -136,23 +136,11 @@ export class ElderMultiSelectBase extends ElderSelectBase {
136
136
  this.requestRemoveEntities([toRemove], skipConfirm);
137
137
  }
138
138
  requestRemoveEntities(toRemove, skipConfirm) {
139
- if (!skipConfirm && this.confirmRemoval) {
140
- this.dialogService
141
- .showConfirm({
142
- title: 'dialogs.confirm-deletion.title',
143
- message: 'dialogs.confirm-deletion.message',
144
- yesNo: true,
145
- interpolateParams: { numOfItems: toRemove.length },
146
- })
147
- .subscribe((confirmed) => {
148
- if (confirmed) {
149
- this.removeEntities(toRemove);
150
- }
151
- });
152
- }
153
- else {
154
- this.removeEntities(toRemove);
155
- }
139
+ this.dialogService.confirmDelete({
140
+ deletionCount: toRemove.length,
141
+ confirmRemoval: this.confirmRemoval,
142
+ skipConfirm: skipConfirm
143
+ }, () => this.removeEntities(toRemove));
156
144
  }
157
145
  removeEntities(toRemove) {
158
146
  toRemove.forEach(e => this.removeEntity(e));
@@ -185,7 +173,7 @@ export class ElderMultiSelectBase extends ElderSelectBase {
185
173
  * *
186
174
  **************************************************************************/
187
175
  valuesEquals(a, b) {
188
- return this.equalIds(this.entityIdsFromValues(a), this.entityIdsFromValues(b));
176
+ return this.equalIdsExactOrder(this.entityIdsFromValues(a), this.entityIdsFromValues(b));
189
177
  }
190
178
  onDataContextChanged(data) {
191
179
  if (this.valueAsId) {
@@ -260,9 +248,15 @@ export class ElderMultiSelectBase extends ElderSelectBase {
260
248
  equalIds(idsA, idsB) {
261
249
  return Sets.equalContent(idsA, idsB);
262
250
  }
251
+ equalIdsExactOrder(idsA, idsB) {
252
+ return Arrays.equalContentAndOrder(idsA, idsB);
253
+ }
263
254
  equalEntities(entitiesA, entitiesB) {
264
255
  return this.equalIds(this.getEntityIds(entitiesA), this.getEntityIds(entitiesB));
265
256
  }
257
+ equalEntitiesExactOrder(entitiesA, entitiesB) {
258
+ return this.equalIdsExactOrder(this.getEntityIds(entitiesA), this.getEntityIds(entitiesB));
259
+ }
266
260
  selectEntitiesByIds(ids) {
267
261
  const currentEntities = this.entities;
268
262
  this.logger.info('selectEntitiesByIds: ids: ' + ids + ', current entities:', currentEntities);
@@ -353,4 +347,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
353
347
  }], entityIds: [{
354
348
  type: Input
355
349
  }] } });
356
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-base.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, NgZone, Output} from '@angular/core';\nimport {ElderSelectBase, ElderSelectComponentState} from '../elder-select-base';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, EMPTY, Observable, of, throwError} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {catchError, filter, map, skip, switchMap, take, tap, timeout} from 'rxjs/operators';\nimport {Sets} from '../../../common/sets';\nimport {NgControl} from '@angular/forms';\nimport {FocusMonitor} from '@angular/cdk/a11y';\nimport {IElderMultiEntityValueAccessor} from '../../../common/forms/elder-multi-entity-value-accessor';\nimport {Sort} from '../../../common/data/sort';\nimport {SortUtil} from '../../../common/utils/sort-util';\nimport {ElderDialogService} from '../../dialogs/elder-dialog.service';\nimport {TranslateService} from '@ngx-translate/core';\n\n\n/**\n * Base component implementation of elder-multi-select.\n *\n * Multi Select has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n * - The backing Value is a list of the current selected entities. T[]\n *\n */\n@Directive()\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport abstract class ElderMultiSelectBase<TId, TEntity, TValue>\n  extends ElderSelectBase<TId, TEntity, TValue[]>\n  implements IElderMultiEntityValueAccessor<TEntity, TId, TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _entityIds$: Observable<TId[]>;\n  private readonly _entities$ = new BehaviorSubject<TEntity[]>([]);\n\n  /**\n   * Defines how the entities should be sorted locally.\n   * This affects how entities are displayed when more than\n   * one is selected, such as in a chip list.\n   */\n  @Input()\n  public entitiesSorts: Sort[] = [];\n\n  /**\n   * If enabled, before removing selected entities\n   * the user will be prompted to confirm.\n   */\n  @Input()\n  public confirmRemoval = false;\n\n  @Output()\n  public readonly entityIdsChange: Observable<TId[]>;\n\n  @Output()\n  public readonly entitiesChange: Observable<TEntity[]>;\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 entityIdsUpdated: Observable<TId[]>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entitiesUpdated: Observable<TEntity[]>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    zone: NgZone,\n    hostRef: ElementRef,\n    controlType: string,\n    focusMonitor: FocusMonitor,\n    translateService: TranslateService,\n    private readonly dialogService: ElderDialogService,\n    ngControl?: NgControl\n  ) {\n    super(zone, hostRef, controlType, focusMonitor, translateService, ngControl);\n\n    this.entityIdsChange = this.valueChange.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this._entityIds$ = this.value$.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entitiesChange = this._entities$.pipe(\n      skip(1) // Skip the initial or current value\n    );\n\n    this.entityIdsUpdated = this.valueUpdated.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entitiesUpdated = this.entityIdsUpdated.pipe(\n      tap(entityIds => this.logger.debug('Awaiting entities with ids', entityIds)),\n      switchMap(entityIds => this.awaitEntitiesWithId(entityIds, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntitiesWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n  }\n\n  private awaitEntitiesWithId(entityIds: TId[], timeoutMs: number): Observable<TEntity[]> {\n    return this._entities$.pipe(\n      tap(entities => this.logger.debug('Got entities for ids' + entityIds, entities)),\n      filter(entities => this.equalIds(this.getEntityIds(entities), entityIds)),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get entities$(): Observable<TEntity[]> {\n    return this._entities$.asObservable();\n  }\n\n  public get entityIds$(): Observable<TId[]> {\n    return this._entityIds$;\n  }\n\n  @Input()\n  public set entities(entities: TEntity[]) {\n    if(!this.equalEntities(this.entities, entities)) {\n      entities = this.writeEntitiesSorted(entities);\n      this.writeValueInternal(\n        this.entitiesToValues(entities)\n      );\n    }\n  }\n\n  public get entities(): TEntity[] {\n    return this._entities$.getValue();\n  }\n\n  @Input()\n  public set entityIds(ids: TId[]) {\n    if(!this.equalIds(this.entityIds, ids)) {\n      if (this.valueAsId) {\n        this.writeValueInternal(<any>ids as TValue[]);\n      } else {\n        this.selectEntitiesByIds(ids);\n      }\n    }\n  }\n\n  public get entityIds(): TId[] {\n    return this.entityIdsFromValues(this.value);\n  }\n\n  public get isOptionDisabledInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isOptionDisabledFn) {\n        return this.isOptionDisabledFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isAlreadyPresent(option)) {\n        return true;\n      }\n      if (this.isOptionHiddenFn) {\n        return this.isOptionHiddenFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public updateValueByEntities(entities: TEntity[]): void {\n    entities = this.writeEntitiesSorted(entities);\n    this.updateValue(\n      this.entitiesToValues(entities)\n    );\n  }\n\n  public appendEntities(newEntities: TEntity[]) {\n    const current = this.entities ? this.entities : [];\n    this.updateValueByEntities([...current, ...newEntities]);\n  }\n\n  public appendEntity(newEntity: any) {\n    this.appendEntities([newEntity]);\n  }\n\n  public requestRemoveEntity(toRemove: TEntity, skipConfirm?: boolean): void {\n    this.requestRemoveEntities([toRemove], skipConfirm);\n  }\n\n  public requestRemoveEntities(\n    toRemove: TEntity[],\n    skipConfirm?: boolean\n  ): void {\n    if (!skipConfirm && this.confirmRemoval) {\n      this.dialogService\n        .showConfirm({\n          title: 'dialogs.confirm-deletion.title',\n          message: 'dialogs.confirm-deletion.message',\n          yesNo: true,\n          interpolateParams: {numOfItems: toRemove.length},\n        })\n        .subscribe((confirmed) => {\n          if (confirmed) {\n            this.removeEntities(toRemove);\n          }\n        });\n    } else {\n      this.removeEntities(toRemove);\n    }\n  }\n\n  public removeEntities(toRemove: TEntity[]): void {\n    toRemove.forEach(e => this.removeEntity(e));\n  }\n\n  public removeEntity(toRemove: TEntity): void {\n    const remaining = this.entities\n      .filter(l => !this.isEqual(l, toRemove));\n    this.updateValueByEntities(remaining);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        (e: TEntity) => this.getEntityId(e),\n        this.entities,\n        this.filters,\n        this.sorts,\n        true\n      ).subscribe(\n        (selection: TEntity[]) => this.updateValueByEntities(selection)\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  public 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   *                                                                         *\n   * Internal Methods                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  protected override valuesEquals(a: TValue[], b: TValue[]): boolean {\n    return this.equalIds(this.entityIdsFromValues(a), this.entityIdsFromValues(b));\n  }\n\n  protected onDataContextChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntitiesByIds(this.entityIds);\n    }\n  }\n\n  /**\n   * This method is invoked after a value has been written to this control.\n   *\n   */\n  protected override writeToControl(value: TValue[]): void {\n    if (this.valueAsId) {\n      const entityIds = <any>value as TId[];\n      // Value was written as entity ids, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as ids: ' + entityIds, value);\n      this.selectEntitiesByIds(entityIds);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntities = this.entities;\n      const newEntities = <any>value as TEntity[];\n      this.logger.debug('writeToControl: value was written as entities (size): ' + newEntities?.length, value);\n      if (!this.equalEntities(currentEntities, newEntities)) {\n        this.writeEntitiesSorted(newEntities);\n      } else {\n        this.logger.warn('Ignored written entities as they are already set to entities$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n\n  private isAlreadyPresent(queryValue: TEntity): boolean {\n    if (this.entities) {\n      return this.entities.some(v => this.isEqual(v, queryValue));\n    } else {\n      return false;\n    }\n  }\n\n  private entityIdsFromValues(values: TValue[]): TId[] | null {\n    if (values) {\n      return values.map(v => this.entityIdFromValue(v));\n    }\n    return null;\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 entitiesToValues(entities: TEntity[]): TValue[] | null {\n    if (entities) {\n      return entities.map(e => this.entityToValue(e));\n    }\n    return null;\n  }\n\n  private getEntityIds(values: TEntity[] | null): TId[] {\n    if (values) {\n      return values.map(v => this.getEntityId(v));\n    }\n    return null;\n  }\n\n  private equalIds(idsA: TId[], idsB: TId[]): boolean {\n    return Sets.equalContent(idsA, idsB);\n  }\n\n  private equalEntities(entitiesA: TEntity[], entitiesB: TEntity[]) {\n    return this.equalIds(this.getEntityIds(entitiesA), this.getEntityIds(entitiesB));\n  }\n\n  private selectEntitiesByIds(ids: TId[]): void {\n    const currentEntities = this.entities;\n    this.logger.info('selectEntitiesByIds: ids: ' + ids + ', current entities:', currentEntities);\n    if (currentEntities && this.equalIds(this.getEntityIds(currentEntities), ids)) {\n      return; // Entities already loaded\n    }\n\n    this.findOrLoadEntitiesByIds(ids)\n      .subscribe({\n        next: entities => this.entities = entities,\n        error: err => this.updateState(ElderSelectComponentState.error(err))\n      });\n  }\n\n  private findOrLoadEntitiesByIds(ids: TId[]): Observable<TEntity[]> {\n    if (ids.length == 0) {\n      return of([]);\n    }\n    if (this.dataContext) {\n      const existing = this.findInDataContext(ids);\n      const missingIds = ids.filter(id => !existing.has(id));\n      const valueLoadRequest$ = missingIds.length > 0 ? this.loadEntitiesByIds(missingIds) : of(new Map());\n\n      return valueLoadRequest$.pipe(\n        map(loaded => {\n          loaded.forEach((v, k) => existing.set(k, v));\n          return existing;\n        }),\n        map(allValuesMap => Array.from(allValuesMap.values())) // TODO Sort?\n      );\n    } else {\n      this.logger.warn('Failed to select value by Ids: ' + ids + ' - DataContext not available.');\n      return EMPTY;\n    }\n  }\n\n  private loadEntitiesByIds(ids: TId[]): Observable<Map<TId, TEntity>> {\n    return this.dataContext.dataSource.findByIds(ids).pipe(\n      catchError(err => {\n        this.logger.error('Failed to load entities by ids: ' + ids, err);\n        return throwError(err);\n      }),\n      map(values => {\n        this.logger.debug('Loaded entities by id:', values);\n        const valueMap = new Map<TId, TEntity>();\n        values.forEach(v => valueMap.set(this.getEntityId(v), v));\n        return valueMap;\n      })\n    );\n  }\n\n  private findInDataContext(ids: TId[]): Map<TId, TEntity> {\n    const existingValues = new Map<TId, TEntity>();\n    if (ids?.length > 0) {\n      const data = this.dataContext.snapshot.data;\n      const requiredIds = new Set(ids);\n      data\n        .filter(d => requiredIds.has(this.getEntityId(d)))\n        .forEach(d => existingValues.set(this.getEntityId(d), d));\n    }\n    return existingValues;\n  }\n\n  private writeEntitiesSorted(entities: TEntity[]): TEntity[] {\n    const sorted = this.sortEntities(entities);\n    this._entities$.next(sorted);\n    return sorted;\n  }\n\n  private sortEntities(entities: TEntity[]): TEntity[] {\n    if (entities && this.entitiesSorts && this.entitiesSorts.length > 0) {\n      const sorted = SortUtil.sortData(entities, this.entitiesSorts);\n      if (!SortUtil.equalsExactRefs(entities, sorted)) {\n        // Only return a copy of the array if actually something changed\n        return sorted;\n      }\n    }\n    return entities;\n  }\n}\n"]}
350
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-base.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, ElementRef, Input, NgZone, Output} from '@angular/core';\nimport {ElderSelectBase, ElderSelectComponentState} from '../elder-select-base';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, EMPTY, Observable, of, throwError} from 'rxjs';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {catchError, filter, map, skip, switchMap, take, tap, timeout} from 'rxjs/operators';\nimport {Sets} from '../../../common/sets';\nimport {NgControl} from '@angular/forms';\nimport {FocusMonitor} from '@angular/cdk/a11y';\nimport {IElderMultiEntityValueAccessor} from '../../../common/forms/elder-multi-entity-value-accessor';\nimport {Sort} from '../../../common/data/sort';\nimport {SortUtil} from '../../../common/utils/sort-util';\nimport {ElderDialogService} from '../../dialogs/elder-dialog.service';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Arrays} from '../../../common/arrays';\n\n\n/**\n * Base component implementation of elder-multi-select.\n *\n * Multi Select has the following abstract concept:\n *\n * - Suggestion-Model: A DataSource and derived DataContext for the (auto-complete) suggestions.\n * - The backing Value is a list of the current selected entities. T[]\n *\n */\n@Directive()\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport abstract class ElderMultiSelectBase<TId, TEntity, TValue>\n  extends ElderSelectBase<TId, TEntity, TValue[]>\n  implements IElderMultiEntityValueAccessor<TEntity, TId, TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _entityIds$: Observable<TId[]>;\n  private readonly _entities$ = new BehaviorSubject<TEntity[]>([]);\n\n  /**\n   * Defines how the entities should be sorted locally.\n   * This affects how entities are displayed when more than\n   * one is selected, such as in a chip list.\n   */\n  @Input()\n  public entitiesSorts: Sort[] = [];\n\n  /**\n   * If enabled, before removing selected entities\n   * the user will be prompted to confirm.\n   */\n  @Input()\n  public confirmRemoval = false;\n\n  @Output()\n  public readonly entityIdsChange: Observable<TId[]>;\n\n  @Output()\n  public readonly entitiesChange: Observable<TEntity[]>;\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 entityIdsUpdated: Observable<TId[]>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entitiesUpdated: Observable<TEntity[]>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    zone: NgZone,\n    hostRef: ElementRef,\n    controlType: string,\n    focusMonitor: FocusMonitor,\n    translateService: TranslateService,\n    private readonly dialogService: ElderDialogService,\n    ngControl?: NgControl\n  ) {\n    super(zone, hostRef, controlType, focusMonitor, translateService, ngControl);\n\n    this.entityIdsChange = this.valueChange.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this._entityIds$ = this.value$.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entitiesChange = this._entities$.pipe(\n      skip(1) // Skip the initial or current value\n    );\n\n    this.entityIdsUpdated = this.valueUpdated.pipe(\n      map(values => this.entityIdsFromValues(values))\n    );\n\n    this.entitiesUpdated = this.entityIdsUpdated.pipe(\n      tap(entityIds => this.logger.debug('Awaiting entities with ids', entityIds)),\n      switchMap(entityIds => this.awaitEntitiesWithId(entityIds, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntitiesWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n  }\n\n  private awaitEntitiesWithId(entityIds: TId[], timeoutMs: number): Observable<TEntity[]> {\n    return this._entities$.pipe(\n      tap(entities => this.logger.debug('Got entities for ids' + entityIds, entities)),\n      filter(entities => this.equalIds(this.getEntityIds(entities), entityIds)),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get entities$(): Observable<TEntity[]> {\n    return this._entities$.asObservable();\n  }\n\n  public get entityIds$(): Observable<TId[]> {\n    return this._entityIds$;\n  }\n\n  @Input()\n  public set entities(entities: TEntity[]) {\n    if(!this.equalEntitiesExactOrder(this.entities, entities)) {\n      this.writeValueInternal(\n        this.entitiesToValues(\n          this.writeEntitiesSorted(entities)\n        )\n      );\n    }\n  }\n\n  public get entities(): TEntity[] {\n    return this._entities$.getValue();\n  }\n\n  @Input()\n  public set entityIds(ids: TId[]) {\n    if(!this.equalIdsExactOrder(this.entityIds, ids)) {\n      if (this.valueAsId) {\n        this.writeValueInternal(<any>ids as TValue[]);\n      } else {\n        this.selectEntitiesByIds(ids);\n      }\n    }\n  }\n\n  public get entityIds(): TId[] {\n    return this.entityIdsFromValues(this.value);\n  }\n\n  public get isOptionDisabledInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isOptionDisabledFn) {\n        return this.isOptionDisabledFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isAlreadyPresent(option)) {\n        return true;\n      }\n      if (this.isOptionHiddenFn) {\n        return this.isOptionHiddenFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public updateValueByEntities(entities: TEntity[]): void {\n    entities = this.writeEntitiesSorted(entities);\n    this.updateValue(\n      this.entitiesToValues(entities)\n    );\n  }\n\n  public appendEntities(newEntities: TEntity[]) {\n    const current = this.entities ? this.entities : [];\n    this.updateValueByEntities([...current, ...newEntities]);\n  }\n\n  public appendEntity(newEntity: any) {\n    this.appendEntities([newEntity]);\n  }\n\n  public requestRemoveEntity(toRemove: TEntity, skipConfirm?: boolean): void {\n    this.requestRemoveEntities([toRemove], skipConfirm);\n  }\n\n  public requestRemoveEntities(\n    toRemove: TEntity[],\n    skipConfirm?: boolean\n  ): void {\n    this.dialogService.confirmDelete(\n      {\n        deletionCount: toRemove.length,\n        confirmRemoval: this.confirmRemoval,\n        skipConfirm: skipConfirm\n      },\n      () => this.removeEntities(toRemove)\n    );\n  }\n\n  public removeEntities(toRemove: TEntity[]): void {\n    toRemove.forEach(e => this.removeEntity(e));\n  }\n\n  public removeEntity(toRemove: TEntity): void {\n    const remaining = this.entities\n      .filter(l => !this.isEqual(l, toRemove));\n    this.updateValueByEntities(remaining);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        (e: TEntity) => this.getEntityId(e),\n        this.entities,\n        this.filters,\n        this.sorts,\n        true\n      ).subscribe(\n        (selection: TEntity[]) => this.updateValueByEntities(selection)\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  public 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   *                                                                         *\n   * Internal Methods                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  protected override valuesEquals(a: TValue[], b: TValue[]): boolean {\n    return this.equalIdsExactOrder(this.entityIdsFromValues(a), this.entityIdsFromValues(b));\n  }\n\n  protected onDataContextChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntitiesByIds(this.entityIds);\n    }\n  }\n\n  /**\n   * This method is invoked after a value has been written to this control.\n   *\n   */\n  protected override writeToControl(value: TValue[]): void {\n    if (this.valueAsId) {\n      const entityIds = <any>value as TId[];\n      // Value was written as entity ids, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as ids: ' + entityIds, value);\n      this.selectEntitiesByIds(entityIds);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntities = this.entities;\n      const newEntities = <any>value as TEntity[];\n      this.logger.debug('writeToControl: value was written as entities (size): ' + newEntities?.length, value);\n      if (!this.equalEntities(currentEntities, newEntities)) {\n        this.writeEntitiesSorted(newEntities);\n      } else {\n        this.logger.warn('Ignored written entities as they are already set to entities$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n\n  private isAlreadyPresent(queryValue: TEntity): boolean {\n    if (this.entities) {\n      return this.entities.some(v => this.isEqual(v, queryValue));\n    } else {\n      return false;\n    }\n  }\n\n  private entityIdsFromValues(values: TValue[]): TId[] | null {\n    if (values) {\n      return values.map(v => this.entityIdFromValue(v));\n    }\n    return null;\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 entitiesToValues(entities: TEntity[]): TValue[] | null {\n    if (entities) {\n      return entities.map(e => this.entityToValue(e));\n    }\n    return null;\n  }\n\n  private getEntityIds(values: TEntity[] | null): TId[] {\n    if (values) {\n      return values.map(v => this.getEntityId(v));\n    }\n    return null;\n  }\n\n  private equalIds(idsA: TId[], idsB: TId[]): boolean {\n    return Sets.equalContent(idsA, idsB);\n  }\n\n  private equalIdsExactOrder(idsA: TId[], idsB: TId[]): boolean {\n    return Arrays.equalContentAndOrder(idsA, idsB);\n  }\n\n  private equalEntities(entitiesA: TEntity[], entitiesB: TEntity[]) {\n    return this.equalIds(this.getEntityIds(entitiesA), this.getEntityIds(entitiesB));\n  }\n\n  private equalEntitiesExactOrder(entitiesA: TEntity[], entitiesB: TEntity[]) {\n    return this.equalIdsExactOrder(this.getEntityIds(entitiesA), this.getEntityIds(entitiesB));\n  }\n\n  private selectEntitiesByIds(ids: TId[]): void {\n    const currentEntities = this.entities;\n    this.logger.info('selectEntitiesByIds: ids: ' + ids + ', current entities:', currentEntities);\n    if (currentEntities && this.equalIds(this.getEntityIds(currentEntities), ids)) {\n      return; // Entities already loaded\n    }\n\n    this.findOrLoadEntitiesByIds(ids)\n      .subscribe({\n        next: entities => this.entities = entities,\n        error: err => this.updateState(ElderSelectComponentState.error(err))\n      });\n  }\n\n  private findOrLoadEntitiesByIds(ids: TId[]): Observable<TEntity[]> {\n    if (ids.length == 0) {\n      return of([]);\n    }\n    if (this.dataContext) {\n      const existing = this.findInDataContext(ids);\n      const missingIds = ids.filter(id => !existing.has(id));\n      const valueLoadRequest$ = missingIds.length > 0 ? this.loadEntitiesByIds(missingIds) : of(new Map());\n\n      return valueLoadRequest$.pipe(\n        map(loaded => {\n          loaded.forEach((v, k) => existing.set(k, v));\n          return existing;\n        }),\n        map(allValuesMap => Array.from(allValuesMap.values())) // TODO Sort?\n      );\n    } else {\n      this.logger.warn('Failed to select value by Ids: ' + ids + ' - DataContext not available.');\n      return EMPTY;\n    }\n  }\n\n  private loadEntitiesByIds(ids: TId[]): Observable<Map<TId, TEntity>> {\n    return this.dataContext.dataSource.findByIds(ids).pipe(\n      catchError(err => {\n        this.logger.error('Failed to load entities by ids: ' + ids, err);\n        return throwError(err);\n      }),\n      map(values => {\n        this.logger.debug('Loaded entities by id:', values);\n        const valueMap = new Map<TId, TEntity>();\n        values.forEach(v => valueMap.set(this.getEntityId(v), v));\n        return valueMap;\n      })\n    );\n  }\n\n  private findInDataContext(ids: TId[]): Map<TId, TEntity> {\n    const existingValues = new Map<TId, TEntity>();\n    if (ids?.length > 0) {\n      const data = this.dataContext.snapshot.data;\n      const requiredIds = new Set(ids);\n      data\n        .filter(d => requiredIds.has(this.getEntityId(d)))\n        .forEach(d => existingValues.set(this.getEntityId(d), d));\n    }\n    return existingValues;\n  }\n\n  private writeEntitiesSorted(entities: TEntity[]): TEntity[] {\n    const sorted = this.sortEntities(entities);\n    this._entities$.next(sorted);\n    return sorted;\n  }\n\n  private sortEntities(entities: TEntity[]): TEntity[] {\n    if (entities && this.entitiesSorts && this.entitiesSorts.length > 0) {\n      const sorted = SortUtil.sortData(entities, this.entitiesSorts);\n      if (!SortUtil.equalsExactRefs(entities, sorted)) {\n        // Only return a copy of the array if actually something changed\n        return sorted;\n      }\n    }\n    return entities;\n  }\n}\n"]}
@@ -7,6 +7,7 @@ import { ElderSelectChipAvatarDirective, ElderSelectChipDirective, ElderSelectCu
7
7
  import { MatFormFieldControl } from '@angular/material/form-field';
8
8
  import { ELDER_SELECT_BASE } from '../../elder-select-base';
9
9
  import { ElderSelectComponent } from '../../single/elder-select/elder-select.component';
10
+ import { moveItemInArray } from '@angular/cdk/drag-drop';
10
11
  import * as i0 from "@angular/core";
11
12
  import * as i1 from "@angular/cdk/a11y";
12
13
  import * as i2 from "@ngx-translate/core";
@@ -15,13 +16,14 @@ import * as i4 from "@angular/forms";
15
16
  import * as i5 from "@angular/common";
16
17
  import * as i6 from "@angular/material/icon";
17
18
  import * as i7 from "@angular/material/button";
18
- import * as i8 from "../../../forms/directives/elder-stop-event-propagation.directive";
19
- import * as i9 from "@angular/material/chips";
20
- import * as i10 from "@angular/material/tooltip";
21
- import * as i11 from "../../../chips/elder-chip-label.directive";
22
- import * as i12 from "../../single/elder-select/elder-select.component";
23
- import * as i13 from "../../single/elder-clear-select.directive";
24
- import * as i14 from "../../../../pipes/elder-truncate.pipe";
19
+ import * as i8 from "@angular/material/chips";
20
+ import * as i9 from "@angular/material/tooltip";
21
+ import * as i10 from "@angular/cdk/drag-drop";
22
+ import * as i11 from "../../../forms/directives/elder-stop-event-propagation.directive";
23
+ import * as i12 from "../../../chips/elder-chip-label.directive";
24
+ import * as i13 from "../../single/elder-select/elder-select.component";
25
+ import * as i14 from "../../single/elder-clear-select.directive";
26
+ import * as i15 from "../../../../pipes/elder-truncate.pipe";
25
27
  class ChipModel {
26
28
  constructor(value, displayText, color, removeable, avatarSpec) {
27
29
  this.value = value;
@@ -49,6 +51,8 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
49
51
  this.avatarSpecFn = e => this.defaultAvatarSpec;
50
52
  this.selectable = true;
51
53
  this.allowRemove = true;
54
+ this.allowSorting = false;
55
+ this.stacked = false;
52
56
  this.chipTemplate$ = new BehaviorSubject(null);
53
57
  this.chipAvatarTemplate$ = new BehaviorSubject(null);
54
58
  this.customInputTemplate$ = new BehaviorSubject(null);
@@ -152,6 +156,11 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
152
156
  * Public API *
153
157
  * *
154
158
  **************************************************************************/
159
+ drop(event) {
160
+ const reordered = [...this.entities];
161
+ moveItemInArray(reordered, event.previousIndex, event.currentIndex);
162
+ this.entities = reordered;
163
+ }
155
164
  resolveChipValue(e1) {
156
165
  return this.getEntityId(e1);
157
166
  }
@@ -204,13 +213,13 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
204
213
  }
205
214
  }
206
215
  ElderMultiSelectChipsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMultiSelectChipsComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i1.FocusMonitor }, { token: i2.TranslateService }, { token: i3.ElderDialogService }, { token: i4.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
207
- ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderMultiSelectChipsComponent, selector: "elder-multi-select-chips", inputs: { defaultAvatarSpec: "defaultAvatarSpec", avatarSpecFn: "avatarSpecFn", allowRemove: "allowRemove", chipTemplate: "chipTemplate", chipAvatarTemplate: "chipAvatarTemplate", customInputTemplate: "customInputTemplate", chipColorEnabled: "chipColorEnabled", chipColorResolver: "chipColorResolver" }, host: { properties: { "class": "this.hostClass", "class.mat-select-disabled": "this.disabledClass", "class.mat-select-invalid": "this.errorStateClass", "class.mat-select-required": "this.requiredClass", "class.mat-select-empty": "this.emptyClass" } }, providers: [
216
+ ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: ElderMultiSelectChipsComponent, selector: "elder-multi-select-chips", inputs: { defaultAvatarSpec: "defaultAvatarSpec", avatarSpecFn: "avatarSpecFn", allowRemove: "allowRemove", allowSorting: "allowSorting", stacked: "stacked", chipTemplate: "chipTemplate", chipAvatarTemplate: "chipAvatarTemplate", customInputTemplate: "customInputTemplate", chipColorEnabled: "chipColorEnabled", chipColorResolver: "chipColorResolver" }, host: { properties: { "class": "this.hostClass", "class.mat-select-disabled": "this.disabledClass", "class.mat-select-invalid": "this.errorStateClass", "class.mat-select-required": "this.requiredClass", "class.mat-select-empty": "this.emptyClass" } }, providers: [
208
217
  { provide: MatFormFieldControl, useExisting: ElderMultiSelectChipsComponent },
209
218
  {
210
219
  provide: ELDER_SELECT_BASE,
211
220
  useExisting: forwardRef(() => ElderMultiSelectChipsComponent)
212
221
  }
213
- ], queries: [{ propertyName: "_customChipInput", first: true, predicate: MatFormFieldControl, descendants: true }, { propertyName: "chipTemplateQuery", first: true, predicate: ElderSelectChipDirective, descendants: true, read: TemplateRef }, { propertyName: "chipAvatarTemplateQuery", first: true, predicate: ElderSelectChipAvatarDirective, descendants: true, read: TemplateRef }, { propertyName: "customInputTemplateQuery", first: true, predicate: ElderSelectCustomInputDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "_chipInput", first: true, predicate: ElderSelectComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"(selectChips$ | async) as chipValues\"\n class=\"elder-flex-control\"\n [matTooltip]=\"(state$ | async)?.error\"\n>\n\n <mat-chip-set #chips>\n\n <ng-container *ngIf=\"(mergedState$ | async) as state\">\n <div *ngIf=\"icon\"\n class=\"elder-input-prefix-icon-container flex-none\"\n >\n <mat-icon *ngIf=\"icon\" disabled\n class=\"elder-prefix-icon elder-mdc-control-icon elder-icon-small noselect\"\n [class.loading]=\"state.loading\"\n >\n {{icon}}\n </mat-icon>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"templates$ | async as templates\">\n <mat-chip-row elderChipLabel *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\"\n [removable]=\"chipModel.removeable\"\n (keydown)=\"onChipKeyDown($event, chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <mat-chip-avatar\n *ngIf=\"templates.avatar && !chipModel.avatarSpec.hide\"\n [class.chip-avatar-xl]=\"chipModel.avatarSpec.large\"\n >\n <ng-container\n *ngTemplateOutlet=\"templates.avatar; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n\n <ng-container\n *ngTemplateOutlet=\"templates.chip || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove\n *ngIf=\"chipModel.removeable\"\n (click)=\"onClickRemoveChip($event, chipModel.value)\">\n cancel\n </mat-icon>\n </mat-chip-row>\n\n <div class=\"layout-row place-start-center elder-chip-input\">\n\n <!-- [matChipInputFor]=\"chips\" -->\n <ng-container\n *ngTemplateOutlet=\"templates.input || selectInput;\">\n </ng-container>\n\n <button mat-icon-button type=\"button\" class=\"elder-control-icon-button elder-browse-icon\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n </button>\n </div>\n </ng-container>\n </mat-chip-set>\n</div>\n\n<ng-template #selectInput>\n <!-- mat-mdc-chip-input -->\n <elder-select autocomplete elderClearSelect\n class=\"elder-chip-input-select flex\"\n [data]=\"dataContext$ | async\"\n [disabled]=\"!!disabled\"\n [required]=\"!!required\"\n [readonly]=\"!!readonly\"\n [placeholder]=\"placeholder\"\n (entityUpdated)=\"appendEntity($event)\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n ></elder-select>\n</ng-template>\n\n<ng-template #simpleChipTemplate let-chipModel>\n <span class=\"elder-chip-text\">{{chipModel.displayText | elderTruncate:20}}</span>\n</ng-template>\n\n", styles: [".elder-chip-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i8.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "directive", type: i9.MatChipAvatar, selector: "mat-chip-avatar, [matChipAvatar]" }, { kind: "directive", type: i9.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i9.MatChipRow, selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["color", "disabled", "disableRipple", "tabIndex", "editable"], outputs: ["edited"] }, { kind: "component", type: i9.MatChipSet, selector: "mat-chip-set", inputs: ["disabled", "role"] }, { kind: "directive", type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i11.ElderChipLabelDirective, selector: "[elderChipLabel]", inputs: ["appearance", "color", "stateColor", "levelColor"] }, { kind: "component", type: i12.ElderSelectComponent, selector: "elder-select", inputs: ["nullDisplay", "autocomplete", "allowNull", "entity", "entityId"], outputs: ["entityIdChange", "entityIdUpdated", "entityChange", "entityUpdated"] }, { kind: "directive", type: i13.ElderClearSelectDirective, selector: "[elderClearSelect]" }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i14.ElderTruncatePipe, name: "elderTruncate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
222
+ ], queries: [{ propertyName: "_customChipInput", first: true, predicate: MatFormFieldControl, descendants: true }, { propertyName: "chipTemplateQuery", first: true, predicate: ElderSelectChipDirective, descendants: true, read: TemplateRef }, { propertyName: "chipAvatarTemplateQuery", first: true, predicate: ElderSelectChipAvatarDirective, descendants: true, read: TemplateRef }, { propertyName: "customInputTemplateQuery", first: true, predicate: ElderSelectCustomInputDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "_chipInput", first: true, predicate: ElderSelectComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"(selectChips$ | async) as chipValues\"\n class=\"elder-flex-control\"\n [matTooltip]=\"(state$ | async)?.error\"\n>\n <mat-chip-set #chips\n [class.mat-mdc-chip-set-stacked]=\"stacked\"\n cdkDropList\n [cdkDropListOrientation]=\"stacked ? 'vertical' : 'horizontal'\"\n (cdkDropListDropped)=\"drop($event)\"\n [cdkDropListDisabled]=\"!allowSorting\"\n >\n\n <ng-container *ngIf=\"(mergedState$ | async) as state\">\n <div *ngIf=\"icon\"\n class=\"elder-input-prefix-icon-container flex-none\"\n >\n <mat-icon *ngIf=\"icon\" disabled\n class=\"elder-prefix-icon elder-mdc-control-icon elder-icon-small noselect\"\n [class.loading]=\"state.loading\"\n >\n {{icon}}\n </mat-icon>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"templates$ | async as templates\">\n <mat-chip-row elderChipLabel *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\"\n [removable]=\"chipModel.removeable\"\n (keydown)=\"onChipKeyDown($event, chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n cdkDrag [cdkDragData]=\"chipModel.value\" [cdkDragDisabled]=\"!allowSorting\"\n >\n <mat-chip-avatar\n *ngIf=\"templates.avatar && !chipModel.avatarSpec.hide\"\n [class.chip-avatar-xl]=\"chipModel.avatarSpec.large\"\n >\n <ng-container\n *ngTemplateOutlet=\"templates.avatar; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n\n <ng-container\n *ngTemplateOutlet=\"templates.chip || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove\n *ngIf=\"chipModel.removeable\"\n (click)=\"onClickRemoveChip($event, chipModel.value)\">\n cancel\n </mat-icon>\n </mat-chip-row>\n\n <div class=\"layout-row place-start-center elder-chip-input\">\n\n <!-- [matChipInputFor]=\"chips\" -->\n <ng-container\n *ngTemplateOutlet=\"templates.input || selectInput;\">\n </ng-container>\n\n <button mat-icon-button type=\"button\" class=\"elder-control-icon-button elder-browse-icon\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n </button>\n </div>\n </ng-container>\n </mat-chip-set>\n</div>\n\n<ng-template #selectInput>\n <!-- mat-mdc-chip-input -->\n <elder-select autocomplete elderClearSelect\n class=\"elder-chip-input-select flex\"\n [data]=\"dataContext$ | async\"\n [disabled]=\"!!disabled\"\n [required]=\"!!required\"\n [readonly]=\"!!readonly\"\n [placeholder]=\"placeholder\"\n (entityUpdated)=\"appendEntity($event)\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n ></elder-select>\n</ng-template>\n\n<ng-template #simpleChipTemplate let-chipModel>\n <span class=\"elder-chip-text\">{{chipModel.displayText | elderTruncate:20}}</span>\n</ng-template>\n\n", styles: [".elder-chip-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cdk-drag-preview{box-sizing:border-box;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i8.MatChipAvatar, selector: "mat-chip-avatar, [matChipAvatar]" }, { kind: "directive", type: i8.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i8.MatChipRow, selector: "mat-chip-row, [mat-chip-row], mat-basic-chip-row, [mat-basic-chip-row]", inputs: ["color", "disabled", "disableRipple", "tabIndex", "editable"], outputs: ["edited"] }, { kind: "component", type: i8.MatChipSet, selector: "mat-chip-set", inputs: ["disabled", "role"] }, { kind: "directive", type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i10.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i10.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i11.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "directive", type: i12.ElderChipLabelDirective, selector: "[elderChipLabel]", inputs: ["appearance", "color", "stateColor", "levelColor"] }, { kind: "component", type: i13.ElderSelectComponent, selector: "elder-select", inputs: ["nullDisplay", "autocomplete", "allowNull", "entity", "entityId"], outputs: ["entityIdChange", "entityIdUpdated", "entityChange", "entityUpdated"] }, { kind: "directive", type: i14.ElderClearSelectDirective, selector: "[elderClearSelect]" }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i15.ElderTruncatePipe, name: "elderTruncate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
214
223
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderMultiSelectChipsComponent, decorators: [{
215
224
  type: Component,
216
225
  args: [{ selector: 'elder-multi-select-chips', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
@@ -219,7 +228,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
219
228
  provide: ELDER_SELECT_BASE,
220
229
  useExisting: forwardRef(() => ElderMultiSelectChipsComponent)
221
230
  }
222
- ], template: "<div *ngIf=\"(selectChips$ | async) as chipValues\"\n class=\"elder-flex-control\"\n [matTooltip]=\"(state$ | async)?.error\"\n>\n\n <mat-chip-set #chips>\n\n <ng-container *ngIf=\"(mergedState$ | async) as state\">\n <div *ngIf=\"icon\"\n class=\"elder-input-prefix-icon-container flex-none\"\n >\n <mat-icon *ngIf=\"icon\" disabled\n class=\"elder-prefix-icon elder-mdc-control-icon elder-icon-small noselect\"\n [class.loading]=\"state.loading\"\n >\n {{icon}}\n </mat-icon>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"templates$ | async as templates\">\n <mat-chip-row elderChipLabel *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\"\n [removable]=\"chipModel.removeable\"\n (keydown)=\"onChipKeyDown($event, chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <mat-chip-avatar\n *ngIf=\"templates.avatar && !chipModel.avatarSpec.hide\"\n [class.chip-avatar-xl]=\"chipModel.avatarSpec.large\"\n >\n <ng-container\n *ngTemplateOutlet=\"templates.avatar; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n\n <ng-container\n *ngTemplateOutlet=\"templates.chip || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove\n *ngIf=\"chipModel.removeable\"\n (click)=\"onClickRemoveChip($event, chipModel.value)\">\n cancel\n </mat-icon>\n </mat-chip-row>\n\n <div class=\"layout-row place-start-center elder-chip-input\">\n\n <!-- [matChipInputFor]=\"chips\" -->\n <ng-container\n *ngTemplateOutlet=\"templates.input || selectInput;\">\n </ng-container>\n\n <button mat-icon-button type=\"button\" class=\"elder-control-icon-button elder-browse-icon\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n </button>\n </div>\n </ng-container>\n </mat-chip-set>\n</div>\n\n<ng-template #selectInput>\n <!-- mat-mdc-chip-input -->\n <elder-select autocomplete elderClearSelect\n class=\"elder-chip-input-select flex\"\n [data]=\"dataContext$ | async\"\n [disabled]=\"!!disabled\"\n [required]=\"!!required\"\n [readonly]=\"!!readonly\"\n [placeholder]=\"placeholder\"\n (entityUpdated)=\"appendEntity($event)\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n ></elder-select>\n</ng-template>\n\n<ng-template #simpleChipTemplate let-chipModel>\n <span class=\"elder-chip-text\">{{chipModel.displayText | elderTruncate:20}}</span>\n</ng-template>\n\n", styles: [".elder-chip-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"] }]
231
+ ], template: "<div *ngIf=\"(selectChips$ | async) as chipValues\"\n class=\"elder-flex-control\"\n [matTooltip]=\"(state$ | async)?.error\"\n>\n <mat-chip-set #chips\n [class.mat-mdc-chip-set-stacked]=\"stacked\"\n cdkDropList\n [cdkDropListOrientation]=\"stacked ? 'vertical' : 'horizontal'\"\n (cdkDropListDropped)=\"drop($event)\"\n [cdkDropListDisabled]=\"!allowSorting\"\n >\n\n <ng-container *ngIf=\"(mergedState$ | async) as state\">\n <div *ngIf=\"icon\"\n class=\"elder-input-prefix-icon-container flex-none\"\n >\n <mat-icon *ngIf=\"icon\" disabled\n class=\"elder-prefix-icon elder-mdc-control-icon elder-icon-small noselect\"\n [class.loading]=\"state.loading\"\n >\n {{icon}}\n </mat-icon>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"templates$ | async as templates\">\n <mat-chip-row elderChipLabel *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\"\n [removable]=\"chipModel.removeable\"\n (keydown)=\"onChipKeyDown($event, chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n cdkDrag [cdkDragData]=\"chipModel.value\" [cdkDragDisabled]=\"!allowSorting\"\n >\n <mat-chip-avatar\n *ngIf=\"templates.avatar && !chipModel.avatarSpec.hide\"\n [class.chip-avatar-xl]=\"chipModel.avatarSpec.large\"\n >\n <ng-container\n *ngTemplateOutlet=\"templates.avatar; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n\n <ng-container\n *ngTemplateOutlet=\"templates.chip || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove\n *ngIf=\"chipModel.removeable\"\n (click)=\"onClickRemoveChip($event, chipModel.value)\">\n cancel\n </mat-icon>\n </mat-chip-row>\n\n <div class=\"layout-row place-start-center elder-chip-input\">\n\n <!-- [matChipInputFor]=\"chips\" -->\n <ng-container\n *ngTemplateOutlet=\"templates.input || selectInput;\">\n </ng-container>\n\n <button mat-icon-button type=\"button\" class=\"elder-control-icon-button elder-browse-icon\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n </button>\n </div>\n </ng-container>\n </mat-chip-set>\n</div>\n\n<ng-template #selectInput>\n <!-- mat-mdc-chip-input -->\n <elder-select autocomplete elderClearSelect\n class=\"elder-chip-input-select flex\"\n [data]=\"dataContext$ | async\"\n [disabled]=\"!!disabled\"\n [required]=\"!!required\"\n [readonly]=\"!!readonly\"\n [placeholder]=\"placeholder\"\n (entityUpdated)=\"appendEntity($event)\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n ></elder-select>\n</ng-template>\n\n<ng-template #simpleChipTemplate let-chipModel>\n <span class=\"elder-chip-text\">{{chipModel.displayText | elderTruncate:20}}</span>\n</ng-template>\n\n", styles: [".elder-chip-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cdk-drag-preview{box-sizing:border-box;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}\n"] }]
223
232
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i1.FocusMonitor }, { type: i2.TranslateService }, { type: i3.ElderDialogService }, { type: i4.NgControl, decorators: [{
224
233
  type: Optional
225
234
  }, {
@@ -230,6 +239,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
230
239
  type: Input
231
240
  }], allowRemove: [{
232
241
  type: Input
242
+ }], allowSorting: [{
243
+ type: Input
244
+ }], stacked: [{
245
+ type: Input
233
246
  }], _customChipInput: [{
234
247
  type: ContentChild,
235
248
  args: [MatFormFieldControl]
@@ -271,4 +284,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
271
284
  }], chipColorResolver: [{
272
285
  type: Input
273
286
  }] } });
274
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-chips.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy, ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  forwardRef,\n  HostBinding,\n  Input,\n  NgZone,\n  Optional,\n  Self,\n  TemplateRef, ViewChild\n} from '@angular/core';\nimport {ElderMultiSelectBase} from '../elder-multi-select-base';\nimport {BehaviorSubject, combineLatest, Observable, tap} from 'rxjs';\nimport {map, share} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderSelectChipAvatarDirective, ElderSelectChipDirective, ElderSelectCustomInputDirective} from '../../elder-select-chip.directive';\nimport {ThemePalette} from '@angular/material/core';\nimport {NgControl} from '@angular/forms';\nimport {MatFormFieldControl} from '@angular/material/form-field';\nimport {ELDER_SELECT_BASE, ElderSelectComponentState, TextResolverFn} from '../../elder-select-base';\nimport {FocusMonitor} from '@angular/cdk/a11y';\nimport {ElderDialogService} from '../../../dialogs/elder-dialog.service';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ElderSelectComponent} from '../../single/elder-select/elder-select.component';\n\nclass ChipModel<T> {\n  constructor(\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly color: ThemePalette,\n    public readonly removeable: boolean,\n    public readonly avatarSpec: ChipAvatarSpec\n  ) {\n  }\n}\n\nexport interface ChipAvatarSpec {\n\n  /**\n   * Hides the avatar for this chip.\n   */\n  hide?: boolean;\n\n  /**\n   * Enables large styling of the avatar for this chip\n   */\n  large?: boolean;\n}\n\ninterface TemplateWrapper {\n  chip: TemplateRef<any>;\n  avatar: TemplateRef<any>;\n\n  input: TemplateRef<any>;\n}\n\n@Component({\n  selector: 'elder-multi-select-chips',\n  templateUrl: './elder-multi-select-chips.component.html',\n  styleUrls: ['./elder-multi-select-chips.component.scss'],\n  // encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {provide: MatFormFieldControl, useExisting: ElderMultiSelectChipsComponent},\n    {\n      provide: ELDER_SELECT_BASE,\n      useExisting: forwardRef(() => ElderMultiSelectChipsComponent)\n    }\n  ]\n})\nexport class ElderMultiSelectChipsComponent<TId = any, TEntity = any, TValue = any>\n  extends ElderMultiSelectBase<TId, TEntity, TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  public readonly selectChips$: Observable<ChipModel<TEntity>[]>;\n\n  @Input()\n  public defaultAvatarSpec: ChipAvatarSpec = {\n    hide: false,\n    large: false\n  };\n\n  /**\n   * Allows to customize each chip avatar individually.\n   */\n  @Input()\n  public avatarSpecFn: (e: TEntity) => ChipAvatarSpec = e => this.defaultAvatarSpec;\n\n  public selectable = true;\n\n  @Input()\n  public allowRemove = true;\n\n  @ContentChild(MatFormFieldControl) _customChipInput: MatFormFieldControl<any>;\n  @ViewChild(ElderSelectComponent) _chipInput: MatFormFieldControl<any>;\n\n  readonly templates$: Observable<TemplateWrapper>;\n\n  private readonly chipTemplate$ = new BehaviorSubject<TemplateRef<any>>(null);\n  private readonly chipAvatarTemplate$ = new BehaviorSubject<TemplateRef<any>>(null);\n  private readonly customInputTemplate$ = new BehaviorSubject<TemplateRef<any>>(null);\n\n  private readonly chipColorResolver$ = new BehaviorSubject<(o1: any) => ThemePalette>((value: TEntity) => undefined);\n  private _chipColorEnabled = false;\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    hostRef: ElementRef,\n    zone: NgZone,\n    focusMonitor: FocusMonitor,\n    translateService: TranslateService,\n    dialogService: ElderDialogService,\n    @Optional() @Self() ngControl: NgControl\n  ) {\n    super(zone, hostRef, 'multi-select-chips', focusMonitor, translateService, dialogService, ngControl);\n\n    this.placeholder = '...';\n\n    this.selectChips$ = combineLatest(\n      [\n        this.entities$,\n        this.entityIds$,\n        this.state$,\n        this.displayPropertyResolver$,\n        this.chipColorResolver$\n      ]\n    ).pipe(\n      map(([entities, entityIds, state, dPR, cCR]) =>\n        this.buildChipModelsOrFallback(entities, entityIds, state, dPR, cCR)\n      )\n    );\n\n    this.templates$ = combineLatest([\n      this.chipTemplate$,\n      this.chipAvatarTemplate$,\n      this.customInputTemplate$\n    ]).pipe(\n      map(([chip, avatar, input]) => {\n        return <TemplateWrapper>{\n          chip,\n          avatar,\n          input\n        };\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Host Bindings                                                           *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostBinding('class') get hostClass(): string {\n    return 'elder-select-base elder-multi-select';\n  }\n\n  @HostBinding('class.mat-select-disabled') get disabledClass(): boolean {\n    return this.disabled;\n  }\n\n  @HostBinding('class.mat-select-invalid') get errorStateClass(): boolean {\n    return this.errorState;\n  }\n\n  @HostBinding('class.mat-select-required') get requiredClass(): boolean {\n    return this.required;\n  }\n\n  @HostBinding('class.mat-select-empty') get emptyClass(): boolean {\n    return this.empty;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @ContentChild(ElderSelectChipDirective, {read: TemplateRef, static: false})\n  public set chipTemplateQuery(template: TemplateRef<any>){\n    this.chipTemplate = template;\n  }\n\n  @Input()\n  public set chipTemplate(template: TemplateRef<any>) {\n    this.chipTemplate$.next(template);\n  }\n\n  public get chipTemplate(): TemplateRef<any> {\n    return this.chipTemplate$.getValue();\n  }\n\n  @ContentChild(ElderSelectChipAvatarDirective, {read: TemplateRef, static: false})\n  public set chipAvatarTemplateQuery(template: TemplateRef<any>){\n    this.chipAvatarTemplate = template;\n  }\n\n  @Input()\n  public set chipAvatarTemplate(template: TemplateRef<any>) {\n    this.chipAvatarTemplate$.next(template);\n  }\n\n  public get chipAvatarTemplate(): TemplateRef<any> {\n    return this.chipAvatarTemplate$.getValue();\n  }\n\n  @ContentChild(ElderSelectCustomInputDirective, {read: TemplateRef, static: false})\n  public set customInputTemplateQuery(template: TemplateRef<any>){\n    this.customInputTemplate = template;\n  }\n\n  @Input()\n  public set customInputTemplate(template: TemplateRef<any>) {\n    this.customInputTemplate$.next(template);\n  }\n\n  public get customInputTemplate(): TemplateRef<any> {\n    return this.customInputTemplate$.getValue();\n  }\n\n  @Input()\n  public set chipColorEnabled(enabled: boolean) {\n    this._chipColorEnabled = enabled;\n  }\n\n  public get chipColorEnabled(): boolean {\n    return this.errorState || this._chipColorEnabled;\n  }\n\n  /**\n   * A function which returns the color of a given label object.\n   */\n  @Input()\n  public set chipColorResolver(fn: (o1: any) => ThemePalette) {\n    if (!fn) {\n      this.chipColorEnabled = false;\n      return;\n    }\n    if (typeof fn !== 'function') {\n      throw new Error('chipColorResolver must be a function!');\n    }\n    this.chipColorEnabled = true;\n    this.chipColorResolver$.next(fn);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public resolveChipValue(e1: TEntity): any {\n    return this.getEntityId(e1);\n  }\n\n  public onChipKeyDown(event: KeyboardEvent, toRemove: TEntity): void {\n    this.log.warn('onChipKeyDown', event);\n    if(event.key == 'Backspace' || event.key == 'Delete'){\n      this.requestRemoveEntity(toRemove, event.shiftKey);\n    }\n  }\n\n  public onClickRemoveChip(\n    event: MouseEvent,\n    toRemove: TEntity\n  ): void {\n    event.stopPropagation();\n    event.preventDefault();\n    this.requestRemoveEntity(toRemove, event.shiftKey);\n  }\n\n  public focus(options?: FocusOptions) {\n\n    const input = this._customChipInput ?? this._chipInput;\n\n    if(input){\n      input.onContainerClick(new MouseEvent(''));\n    }else{\n      this.log.warn('Cant focus since no chip-input-control found!')\n    }\n  }\n\n  public blur() {\n    this.log.warn('blur() not yet supported!')\n    // TODO this.inputControl?.blur();\n    // this.customInputTemplate.blur()\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private buildChipModelsOrFallback(\n    entities: TEntity[],\n    entityIds: TId[],\n    state: ElderSelectComponentState,\n    dPR: TextResolverFn,\n    cCR: (o1: any) => ThemePalette\n  ): ChipModel<TEntity>[] {\n\n    if (state.error) {\n      return this.buildChipFallbackModels(entityIds);\n    }\n    return this.buildChipModels(entities, dPR, cCR);\n  }\n\n\n  private buildChipFallbackModels(entityIds: TId[]): ChipModel<TEntity>[] {\n    return entityIds.map(\n      id => new ChipModel<TEntity>(\n        <any>{id: id},\n        String(id),\n        'warn',\n        this.allowRemove && !this.isLocked,\n        this.defaultAvatarSpec\n      )\n    );\n  }\n\n  private buildChipModels(\n    entities: TEntity[],\n    dPR: TextResolverFn,\n    cCR: (o1: any) => ThemePalette\n  ): ChipModel<TEntity>[] {\n    if (entities) {\n      return entities.map(\n        e => new ChipModel<TEntity>(\n          e,\n          dPR(e),\n          cCR(e),\n          this.allowRemove && !this.isLocked,\n          this.avatarSpecFn(e) ?? this.defaultAvatarSpec\n        )\n      );\n    } else {\n      return <ChipModel<TEntity>[]>[];\n    }\n  }\n\n}\n","<div *ngIf=\"(selectChips$ | async) as chipValues\"\n                class=\"elder-flex-control\"\n     [matTooltip]=\"(state$ | async)?.error\"\n>\n\n  <mat-chip-set #chips>\n\n    <ng-container *ngIf=\"(mergedState$ | async) as state\">\n      <div *ngIf=\"icon\"\n           class=\"elder-input-prefix-icon-container flex-none\"\n      >\n        <mat-icon *ngIf=\"icon\" disabled\n                  class=\"elder-prefix-icon elder-mdc-control-icon elder-icon-small noselect\"\n                  [class.loading]=\"state.loading\"\n        >\n          {{icon}}\n        </mat-icon>\n      </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"templates$ | async as templates\">\n      <mat-chip-row elderChipLabel *ngFor=\"let chipModel of chipValues\"\n                class=\"noselect clickable-chip\"\n                [value]=\"resolveChipValue(chipModel.value)\"\n                [color]=\"chipModel.color\"\n                [removable]=\"chipModel.removeable\"\n                (keydown)=\"onChipKeyDown($event, chipModel.value)\"\n                (click)=\"onCurrentClicked(chipModel.value)\"\n      >\n        <mat-chip-avatar\n          *ngIf=\"templates.avatar && !chipModel.avatarSpec.hide\"\n          [class.chip-avatar-xl]=\"chipModel.avatarSpec.large\"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"templates.avatar; context: {$implicit: chipModel}\">\n          </ng-container>\n        </mat-chip-avatar>\n\n        <ng-container\n          *ngTemplateOutlet=\"templates.chip || simpleChipTemplate; context: {$implicit: chipModel}\">\n        </ng-container>\n        <mat-icon matChipRemove\n                  *ngIf=\"chipModel.removeable\"\n                  (click)=\"onClickRemoveChip($event, chipModel.value)\">\n          cancel\n        </mat-icon>\n      </mat-chip-row>\n\n      <div class=\"layout-row place-start-center elder-chip-input\">\n\n        <!-- [matChipInputFor]=\"chips\" -->\n        <ng-container\n          *ngTemplateOutlet=\"templates.input || selectInput;\">\n        </ng-container>\n\n        <button mat-icon-button type=\"button\" class=\"elder-control-icon-button elder-browse-icon\"\n                *ngIf=\"selectionPopup\"\n                [disabled]=\"isLocked\"\n                (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n                elderStopEventPropagation\n                tabIndex=\"-1\"\n        >\n          <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n        </button>\n      </div>\n    </ng-container>\n  </mat-chip-set>\n</div>\n\n<ng-template #selectInput>\n  <!-- mat-mdc-chip-input -->\n  <elder-select autocomplete elderClearSelect\n                class=\"elder-chip-input-select flex\"\n                [data]=\"dataContext$ | async\"\n                [disabled]=\"!!disabled\"\n                [required]=\"!!required\"\n                [readonly]=\"!!readonly\"\n                [placeholder]=\"placeholder\"\n                (entityUpdated)=\"appendEntity($event)\"\n                [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n                [valueTemplate]=\"valueTemplate\"\n                [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n                [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n                [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n  ></elder-select>\n</ng-template>\n\n<ng-template #simpleChipTemplate let-chipModel>\n  <span class=\"elder-chip-text\">{{chipModel.displayText | elderTruncate:20}}</span>\n</ng-template>\n\n"]}
287
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-chips.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy, ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  forwardRef,\n  HostBinding,\n  Input,\n  NgZone,\n  Optional,\n  Self,\n  TemplateRef, ViewChild\n} from '@angular/core';\nimport {ElderMultiSelectBase} from '../elder-multi-select-base';\nimport {BehaviorSubject, combineLatest, Observable, tap} from 'rxjs';\nimport {map, share} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderSelectChipAvatarDirective, ElderSelectChipDirective, ElderSelectCustomInputDirective} from '../../elder-select-chip.directive';\nimport {ThemePalette} from '@angular/material/core';\nimport {NgControl} from '@angular/forms';\nimport {MatFormFieldControl} from '@angular/material/form-field';\nimport {ELDER_SELECT_BASE, ElderSelectComponentState, TextResolverFn} from '../../elder-select-base';\nimport {FocusMonitor} from '@angular/cdk/a11y';\nimport {ElderDialogService} from '../../../dialogs/elder-dialog.service';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ElderSelectComponent} from '../../single/elder-select/elder-select.component';\nimport {CdkDragDrop, moveItemInArray} from '@angular/cdk/drag-drop';\n\nclass ChipModel<T> {\n  constructor(\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly color: ThemePalette,\n    public readonly removeable: boolean,\n    public readonly avatarSpec: ChipAvatarSpec\n  ) {\n  }\n}\n\nexport interface ChipAvatarSpec {\n\n  /**\n   * Hides the avatar for this chip.\n   */\n  hide?: boolean;\n\n  /**\n   * Enables large styling of the avatar for this chip\n   */\n  large?: boolean;\n}\n\ninterface TemplateWrapper {\n  chip: TemplateRef<any>;\n  avatar: TemplateRef<any>;\n\n  input: TemplateRef<any>;\n}\n\n@Component({\n  selector: 'elder-multi-select-chips',\n  templateUrl: './elder-multi-select-chips.component.html',\n  styleUrls: ['./elder-multi-select-chips.component.scss'],\n  // encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {provide: MatFormFieldControl, useExisting: ElderMultiSelectChipsComponent},\n    {\n      provide: ELDER_SELECT_BASE,\n      useExisting: forwardRef(() => ElderMultiSelectChipsComponent)\n    }\n  ]\n})\nexport class ElderMultiSelectChipsComponent<TId = any, TEntity = any, TValue = any>\n  extends ElderMultiSelectBase<TId, TEntity, TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  public readonly selectChips$: Observable<ChipModel<TEntity>[]>;\n\n  @Input()\n  public defaultAvatarSpec: ChipAvatarSpec = {\n    hide: false,\n    large: false\n  };\n\n  /**\n   * Allows to customize each chip avatar individually.\n   */\n  @Input()\n  public avatarSpecFn: (e: TEntity) => ChipAvatarSpec = e => this.defaultAvatarSpec;\n\n  public selectable = true;\n\n  @Input()\n  public allowRemove = true;\n\n  @Input()\n  public allowSorting = false;\n\n  @Input()\n  public stacked = false;\n\n  @ContentChild(MatFormFieldControl) _customChipInput: MatFormFieldControl<any>;\n  @ViewChild(ElderSelectComponent) _chipInput: MatFormFieldControl<any>;\n\n  readonly templates$: Observable<TemplateWrapper>;\n\n  private readonly chipTemplate$ = new BehaviorSubject<TemplateRef<any>>(null);\n  private readonly chipAvatarTemplate$ = new BehaviorSubject<TemplateRef<any>>(null);\n  private readonly customInputTemplate$ = new BehaviorSubject<TemplateRef<any>>(null);\n\n  private readonly chipColorResolver$ = new BehaviorSubject<(o1: any) => ThemePalette>((value: TEntity) => undefined);\n  private _chipColorEnabled = false;\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    hostRef: ElementRef,\n    zone: NgZone,\n    focusMonitor: FocusMonitor,\n    translateService: TranslateService,\n    dialogService: ElderDialogService,\n    @Optional() @Self() ngControl: NgControl\n  ) {\n    super(zone, hostRef, 'multi-select-chips', focusMonitor, translateService, dialogService, ngControl);\n\n    this.placeholder = '...';\n\n    this.selectChips$ = combineLatest(\n      [\n        this.entities$,\n        this.entityIds$,\n        this.state$,\n        this.displayPropertyResolver$,\n        this.chipColorResolver$\n      ]\n    ).pipe(\n      map(([entities, entityIds, state, dPR, cCR]) =>\n        this.buildChipModelsOrFallback(entities, entityIds, state, dPR, cCR)\n      )\n    );\n\n    this.templates$ = combineLatest([\n      this.chipTemplate$,\n      this.chipAvatarTemplate$,\n      this.customInputTemplate$\n    ]).pipe(\n      map(([chip, avatar, input]) => {\n        return <TemplateWrapper>{\n          chip,\n          avatar,\n          input\n        };\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Host Bindings                                                           *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostBinding('class') get hostClass(): string {\n    return 'elder-select-base elder-multi-select';\n  }\n\n  @HostBinding('class.mat-select-disabled') get disabledClass(): boolean {\n    return this.disabled;\n  }\n\n  @HostBinding('class.mat-select-invalid') get errorStateClass(): boolean {\n    return this.errorState;\n  }\n\n  @HostBinding('class.mat-select-required') get requiredClass(): boolean {\n    return this.required;\n  }\n\n  @HostBinding('class.mat-select-empty') get emptyClass(): boolean {\n    return this.empty;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @ContentChild(ElderSelectChipDirective, {read: TemplateRef, static: false})\n  public set chipTemplateQuery(template: TemplateRef<any>){\n    this.chipTemplate = template;\n  }\n\n  @Input()\n  public set chipTemplate(template: TemplateRef<any>) {\n    this.chipTemplate$.next(template);\n  }\n\n  public get chipTemplate(): TemplateRef<any> {\n    return this.chipTemplate$.getValue();\n  }\n\n  @ContentChild(ElderSelectChipAvatarDirective, {read: TemplateRef, static: false})\n  public set chipAvatarTemplateQuery(template: TemplateRef<any>){\n    this.chipAvatarTemplate = template;\n  }\n\n  @Input()\n  public set chipAvatarTemplate(template: TemplateRef<any>) {\n    this.chipAvatarTemplate$.next(template);\n  }\n\n  public get chipAvatarTemplate(): TemplateRef<any> {\n    return this.chipAvatarTemplate$.getValue();\n  }\n\n  @ContentChild(ElderSelectCustomInputDirective, {read: TemplateRef, static: false})\n  public set customInputTemplateQuery(template: TemplateRef<any>){\n    this.customInputTemplate = template;\n  }\n\n  @Input()\n  public set customInputTemplate(template: TemplateRef<any>) {\n    this.customInputTemplate$.next(template);\n  }\n\n  public get customInputTemplate(): TemplateRef<any> {\n    return this.customInputTemplate$.getValue();\n  }\n\n  @Input()\n  public set chipColorEnabled(enabled: boolean) {\n    this._chipColorEnabled = enabled;\n  }\n\n  public get chipColorEnabled(): boolean {\n    return this.errorState || this._chipColorEnabled;\n  }\n\n  /**\n   * A function which returns the color of a given label object.\n   */\n  @Input()\n  public set chipColorResolver(fn: (o1: any) => ThemePalette) {\n    if (!fn) {\n      this.chipColorEnabled = false;\n      return;\n    }\n    if (typeof fn !== 'function') {\n      throw new Error('chipColorResolver must be a function!');\n    }\n    this.chipColorEnabled = true;\n    this.chipColorResolver$.next(fn);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public drop(event: CdkDragDrop<any>): void {\n    const reordered = [...this.entities];\n    moveItemInArray(reordered, event.previousIndex, event.currentIndex);\n    this.entities = reordered;\n  }\n\n  public resolveChipValue(e1: TEntity): any {\n    return this.getEntityId(e1);\n  }\n\n  public onChipKeyDown(event: KeyboardEvent, toRemove: TEntity): void {\n    this.log.warn('onChipKeyDown', event);\n    if(event.key == 'Backspace' || event.key == 'Delete'){\n      this.requestRemoveEntity(toRemove, event.shiftKey);\n    }\n  }\n\n  public onClickRemoveChip(\n    event: MouseEvent,\n    toRemove: TEntity\n  ): void {\n    event.stopPropagation();\n    event.preventDefault();\n    this.requestRemoveEntity(toRemove, event.shiftKey);\n  }\n\n  public focus(options?: FocusOptions) {\n\n    const input = this._customChipInput ?? this._chipInput;\n\n    if(input){\n      input.onContainerClick(new MouseEvent(''));\n    }else{\n      this.log.warn('Cant focus since no chip-input-control found!')\n    }\n  }\n\n  public blur() {\n    this.log.warn('blur() not yet supported!')\n    // TODO this.inputControl?.blur();\n    // this.customInputTemplate.blur()\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private buildChipModelsOrFallback(\n    entities: TEntity[],\n    entityIds: TId[],\n    state: ElderSelectComponentState,\n    dPR: TextResolverFn,\n    cCR: (o1: any) => ThemePalette\n  ): ChipModel<TEntity>[] {\n\n    if (state.error) {\n      return this.buildChipFallbackModels(entityIds);\n    }\n    return this.buildChipModels(entities, dPR, cCR);\n  }\n\n\n  private buildChipFallbackModels(entityIds: TId[]): ChipModel<TEntity>[] {\n    return entityIds.map(\n      id => new ChipModel<TEntity>(\n        <any>{id: id},\n        String(id),\n        'warn',\n        this.allowRemove && !this.isLocked,\n        this.defaultAvatarSpec\n      )\n    );\n  }\n\n  private buildChipModels(\n    entities: TEntity[],\n    dPR: TextResolverFn,\n    cCR: (o1: any) => ThemePalette\n  ): ChipModel<TEntity>[] {\n    if (entities) {\n      return entities.map(\n        e => new ChipModel<TEntity>(\n          e,\n          dPR(e),\n          cCR(e),\n          this.allowRemove && !this.isLocked,\n          this.avatarSpecFn(e) ?? this.defaultAvatarSpec\n        )\n      );\n    } else {\n      return <ChipModel<TEntity>[]>[];\n    }\n  }\n\n}\n","<div *ngIf=\"(selectChips$ | async) as chipValues\"\n                class=\"elder-flex-control\"\n     [matTooltip]=\"(state$ | async)?.error\"\n>\n  <mat-chip-set #chips\n                [class.mat-mdc-chip-set-stacked]=\"stacked\"\n                cdkDropList\n                [cdkDropListOrientation]=\"stacked ? 'vertical' : 'horizontal'\"\n                (cdkDropListDropped)=\"drop($event)\"\n                [cdkDropListDisabled]=\"!allowSorting\"\n  >\n\n    <ng-container *ngIf=\"(mergedState$ | async) as state\">\n      <div *ngIf=\"icon\"\n           class=\"elder-input-prefix-icon-container flex-none\"\n      >\n        <mat-icon *ngIf=\"icon\" disabled\n                  class=\"elder-prefix-icon elder-mdc-control-icon elder-icon-small noselect\"\n                  [class.loading]=\"state.loading\"\n        >\n          {{icon}}\n        </mat-icon>\n      </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"templates$ | async as templates\">\n      <mat-chip-row elderChipLabel *ngFor=\"let chipModel of chipValues\"\n                class=\"noselect clickable-chip\"\n                [value]=\"resolveChipValue(chipModel.value)\"\n                [color]=\"chipModel.color\"\n                [removable]=\"chipModel.removeable\"\n                (keydown)=\"onChipKeyDown($event, chipModel.value)\"\n                (click)=\"onCurrentClicked(chipModel.value)\"\n                cdkDrag [cdkDragData]=\"chipModel.value\" [cdkDragDisabled]=\"!allowSorting\"\n      >\n        <mat-chip-avatar\n          *ngIf=\"templates.avatar && !chipModel.avatarSpec.hide\"\n          [class.chip-avatar-xl]=\"chipModel.avatarSpec.large\"\n        >\n          <ng-container\n            *ngTemplateOutlet=\"templates.avatar; context: {$implicit: chipModel}\">\n          </ng-container>\n        </mat-chip-avatar>\n\n        <ng-container\n          *ngTemplateOutlet=\"templates.chip || simpleChipTemplate; context: {$implicit: chipModel}\">\n        </ng-container>\n        <mat-icon matChipRemove\n                  *ngIf=\"chipModel.removeable\"\n                  (click)=\"onClickRemoveChip($event, chipModel.value)\">\n          cancel\n        </mat-icon>\n      </mat-chip-row>\n\n      <div class=\"layout-row place-start-center elder-chip-input\">\n\n        <!-- [matChipInputFor]=\"chips\" -->\n        <ng-container\n          *ngTemplateOutlet=\"templates.input || selectInput;\">\n        </ng-container>\n\n        <button mat-icon-button type=\"button\" class=\"elder-control-icon-button elder-browse-icon\"\n                *ngIf=\"selectionPopup\"\n                [disabled]=\"isLocked\"\n                (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n                elderStopEventPropagation\n                tabIndex=\"-1\"\n        >\n          <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n        </button>\n      </div>\n    </ng-container>\n  </mat-chip-set>\n</div>\n\n<ng-template #selectInput>\n  <!-- mat-mdc-chip-input -->\n  <elder-select autocomplete elderClearSelect\n                class=\"elder-chip-input-select flex\"\n                [data]=\"dataContext$ | async\"\n                [disabled]=\"!!disabled\"\n                [required]=\"!!required\"\n                [readonly]=\"!!readonly\"\n                [placeholder]=\"placeholder\"\n                (entityUpdated)=\"appendEntity($event)\"\n                [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n                [valueTemplate]=\"valueTemplate\"\n                [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n                [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n                [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n  ></elder-select>\n</ng-template>\n\n<ng-template #simpleChipTemplate let-chipModel>\n  <span class=\"elder-chip-text\">{{chipModel.displayText | elderTruncate:20}}</span>\n</ng-template>\n\n"]}
@@ -15,10 +15,10 @@ import * as i5 from "@angular/material/icon";
15
15
  import * as i6 from "@angular/material/button";
16
16
  import * as i7 from "@angular/material/input";
17
17
  import * as i8 from "@angular/material/autocomplete";
18
- import * as i9 from "../../../forms/directives/elder-stop-event-propagation.directive";
19
- import * as i10 from "../../../input/autocomplete/elder-autocomplete/elder-autocomplete.component";
20
- import * as i11 from "../../../input/autocomplete/elder-autocomplete.directive";
21
- import * as i12 from "@angular/material/tooltip";
18
+ import * as i9 from "@angular/material/tooltip";
19
+ import * as i10 from "../../../forms/directives/elder-stop-event-propagation.directive";
20
+ import * as i11 from "../../../input/autocomplete/elder-autocomplete/elder-autocomplete.component";
21
+ import * as i12 from "../../../input/autocomplete/elder-autocomplete.directive";
22
22
  import * as i13 from "../../elder-select-on-tab.directive";
23
23
  class EntityContext {
24
24
  constructor(value, displayText, displayRemove) {
@@ -389,7 +389,7 @@ ElderSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", v
389
389
  provide: ELDER_SELECT_BASE,
390
390
  useExisting: forwardRef(() => ElderSelectComponent)
391
391
  }
392
- ], viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n *ngIf=\"(entityWrapped$ | async) as entityWrapper\"\n class=\"layout-row place-start-center elder-flex-control\"\n>\n <ng-container *ngIf=\"(mergedState$ | async) as state\">\n <div *ngIf=\"state?.error || icon\"\n class=\"elder-input-prefix-icon-container flex-none\"\n >\n <mat-icon *ngIf=\"icon\" disabled\n class=\"elder-mdc-control-icon elder-icon-small noselect clickable-icon\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : (focused ? 'primary' : undefined)\"\n (click)=\"onCurrentClicked(entity)\"\n >\n {{icon}}\n </mat-icon>\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"elder-mdc-control-icon elder-icon-small noselect\"\n color=\"warn\"\n [matTooltip]=\"state?.error\"\n >\n warning\n </mat-icon>\n </div>\n </ng-container>\n\n <!-- A dynamic input -->\n <input #input\n matInput type=\"text\" class=\"flex-grow elder-select-input mdc-text-field__input\"\n [disabled]=\"!!disabled\"\n [required]=\"!!required\"\n [readonly]=\"readonly || !autocomplete\"\n [name]=\"ngControl?.name + '-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n [elderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n elderSelectOnTab\n [class.elder-select-dropdown-input]=\"!autocomplete\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n (blur)=\"onInputBlur($event)\"\n (focus)=\"onInputFocus(autoTrigger)\"\n (click)=\"onInputClicked(autoTrigger)\"\n >\n\n <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [dataContext]=\"dataContext$ | 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 <div class=\"layout-row place-start-center flex-none\">\n\n <mat-icon\n *ngIf=\"!selectionPopup && !autocomplete && !entityWrapper.displayRemove\"\n class=\"elder-mdc-control-icon elder-select-arrow noselect\"\n (click)=\"onInputClicked(autoTrigger)\">\n arrow_drop_down\n </mat-icon>\n\n <button mat-icon-button type=\"button\" class=\"elder-control-icon-button\"\n *ngIf=\"selectionPopup && !entityWrapper.displayRemove\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n </button>\n\n <button mat-icon-button type=\"button\" class=\"elder-control-icon-button\"\n *ngIf=\"entityWrapper.displayRemove\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-mdc-control-icon\">close</mat-icon>\n </button>\n\n\n </div>\n</div>\n\n\n\n", styles: ["@keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}.loading{animation:shrink .3s ease-in-out infinite alternate;-webkit-animation:shrink .3s ease-in-out infinite alternate}.clickable-icon{cursor:pointer}.full-width{width:100%}.elder-select-dropdown-input{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i8.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i9.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "component", type: i10.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "optionValueConverterFn", "enabled", "valueTemplate", "dataContext", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }, { kind: "directive", type: i11.ElderAutocompleteDirective, selector: "[elderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderAutocomplete"] }, { kind: "directive", type: i12.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i13.ElderSelectOnTabDirective, selector: "[elderSelectOnTab]" }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
392
+ ], viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n *ngIf=\"(entityWrapped$ | async) as entityWrapper\"\n class=\"layout-row place-start-center elder-flex-control\"\n>\n <ng-container *ngIf=\"(mergedState$ | async) as state\">\n <div *ngIf=\"state?.error || icon\"\n class=\"elder-input-prefix-icon-container flex-none\"\n >\n <mat-icon *ngIf=\"icon\" disabled\n class=\"elder-mdc-control-icon elder-icon-small noselect clickable-icon\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : (focused ? 'primary' : undefined)\"\n (click)=\"onCurrentClicked(entity)\"\n >\n {{icon}}\n </mat-icon>\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"elder-mdc-control-icon elder-icon-small noselect\"\n color=\"warn\"\n [matTooltip]=\"state?.error\"\n >\n warning\n </mat-icon>\n </div>\n </ng-container>\n\n <!-- A dynamic input -->\n <input #input\n matInput type=\"text\" class=\"flex-grow elder-select-input mdc-text-field__input\"\n [disabled]=\"!!disabled\"\n [required]=\"!!required\"\n [readonly]=\"readonly || !autocomplete\"\n [name]=\"ngControl?.name + '-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n [elderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n elderSelectOnTab\n [class.elder-select-dropdown-input]=\"!autocomplete\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n (blur)=\"onInputBlur($event)\"\n (focus)=\"onInputFocus(autoTrigger)\"\n (click)=\"onInputClicked(autoTrigger)\"\n >\n\n <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [dataContext]=\"dataContext$ | 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 <div class=\"layout-row place-start-center flex-none\">\n\n <mat-icon\n *ngIf=\"!selectionPopup && !autocomplete && !entityWrapper.displayRemove\"\n class=\"elder-mdc-control-icon elder-select-arrow noselect\"\n (click)=\"onInputClicked(autoTrigger)\">\n arrow_drop_down\n </mat-icon>\n\n <button mat-icon-button type=\"button\" class=\"elder-control-icon-button\"\n *ngIf=\"selectionPopup && !entityWrapper.displayRemove\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n </button>\n\n <button mat-icon-button type=\"button\" class=\"elder-control-icon-button\"\n *ngIf=\"entityWrapper.displayRemove\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-mdc-control-icon\">close</mat-icon>\n </button>\n\n\n </div>\n</div>\n\n\n\n", styles: ["@keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}.loading{animation:shrink .3s ease-in-out infinite alternate;-webkit-animation:shrink .3s ease-in-out infinite alternate}.clickable-icon{cursor:pointer}.full-width{width:100%}.elder-select-dropdown-input{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i8.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i10.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "component", type: i11.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "optionValueConverterFn", "enabled", "valueTemplate", "dataContext", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }, { kind: "directive", type: i12.ElderAutocompleteDirective, selector: "[elderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderAutocomplete"] }, { kind: "directive", type: i13.ElderSelectOnTabDirective, selector: "[elderSelectOnTab]" }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
393
393
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ElderSelectComponent, decorators: [{
394
394
  type: Component,
395
395
  args: [{ selector: 'elder-select', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [