@elderbyte/ngx-starter 18.15.1 → 18.15.2
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.
|
@@ -63,7 +63,9 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
|
|
|
63
63
|
toObservable(this.readonlyS),
|
|
64
64
|
toObservable(this.disabledS),
|
|
65
65
|
this.refresh$,
|
|
66
|
-
]).pipe(map(([entities, entityIds, state, dPR]) => this.buildChipModelsOrFallback(entities, entityIds, state, dPR)), map((models) => this.maxDisplayCount
|
|
66
|
+
]).pipe(map(([entities, entityIds, state, dPR]) => this.buildChipModelsOrFallback(entities, entityIds, state, dPR)), map((models) => this.maxDisplayCount !== undefined
|
|
67
|
+
? this.reduceDisplayedChips(models, this.maxDisplayCount)
|
|
68
|
+
: models)));
|
|
67
69
|
this.templates = toSignal(combineLatest([this.chipTemplate$, this.chipAvatarTemplate$, this.customInputTemplate$]).pipe(map(([chip, avatar, input]) => {
|
|
68
70
|
return {
|
|
69
71
|
chip,
|
|
@@ -269,4 +271,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
269
271
|
}], customInputTemplate: [{
|
|
270
272
|
type: Input
|
|
271
273
|
}] } });
|
|
272
|
-
//# 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,\n  Component,\n  ContentChild,\n  ElementRef,\n  forwardRef,\n  Input,\n  NgZone,\n  Optional,\n  Self,\n  Signal,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { ElderMultiSelectBase } from '../elder-multi-select-base'\nimport { BehaviorSubject, combineLatest, Observable } from 'rxjs'\nimport { map } from 'rxjs/operators'\nimport { LoggerFactory } from '@elderbyte/ts-logger'\nimport {\n  ElderSelectChipAvatarDirective,\n  ElderSelectChipDirective,\n  ElderSelectCustomInputDirective,\n} from '../../elder-select-chip.directive'\nimport { NgControl } from '@angular/forms'\nimport { MatFormFieldControl } from '@angular/material/form-field'\nimport {\n  ELDER_SELECT_BASE,\n  ElderSelectComponentState,\n  TextResolverFn,\n} 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, CdkDropList, CdkDrag } from '@angular/cdk/drag-drop'\nimport {\n  ChipAvatarSpec,\n  ChipColorSpec,\n  SelectChipSpec,\n  SelectChipSpecUtil,\n  TrailingSpec,\n} from './select-chip-spec'\nimport { ElderTruncatePipe } from '../../../../pipes/elder-truncate.pipe'\nimport { ElderClearSelectDirective } from '../../single/elder-clear-select.directive'\nimport { ElderStopEventPropagationDirective } from '../../../forms/directives/elder-stop-event-propagation.directive'\nimport { MatIconButton } from '@angular/material/button'\nimport { ElderChipLabelDirective } from '../../../chips/elder-chip-label.directive'\nimport { MatIcon } from '@angular/material/icon'\nimport {\n  MatChipSet,\n  MatChipRow,\n  MatChipAvatar,\n  MatChipTrailingIcon,\n  MatChipRemove,\n} from '@angular/material/chips'\nimport { MatTooltip } from '@angular/material/tooltip'\nimport { NgIf, NgFor, NgTemplateOutlet, AsyncPipe } from '@angular/common'\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop'\n\nclass ChipModel<T> {\n  constructor(\n    public readonly id: any,\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly colorSpec: ChipColorSpec,\n    public readonly removable: boolean,\n    public readonly avatarSpec: ChipAvatarSpec,\n    public readonly trailingSpec: TrailingSpec\n  ) {}\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  standalone: true,\n  imports: [\n    MatTooltip,\n    MatChipSet,\n    CdkDropList,\n    MatIcon,\n    MatChipRow,\n    ElderChipLabelDirective,\n    CdkDrag,\n    MatChipAvatar,\n    NgTemplateOutlet,\n    MatChipTrailingIcon,\n    MatChipRemove,\n    MatIconButton,\n    ElderStopEventPropagationDirective,\n    ElderSelectComponent,\n    ElderClearSelectDirective,\n    ElderTruncatePipe,\n  ],\n})\nexport class ElderMultiSelectChipsComponent<\n  TId = any,\n  TEntity = any,\n  TValue = any,\n> extends ElderMultiSelectBase<TId, TEntity, TValue> {\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  public readonly selectChips: Signal<ChipModel<TEntity>[]>\n\n  @Input()\n  public defaultChipSpec: SelectChipSpec = SelectChipSpecUtil.DefaultChipSpec\n\n  /**\n   * Allows to customize each chip individually (Color, Removable, Avatar).\n   *\n   */\n  @Input()\n  public chipSpecFn: (e: TEntity) => SelectChipSpec = (e) => this.defaultChipSpec\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  @Input()\n  public maxDisplayCount: number\n\n  @ContentChild(MatFormFieldControl) _customChipInput: MatFormFieldControl<any>\n  @ViewChild(ElderSelectComponent) _chipInput: MatFormFieldControl<any>\n\n  readonly templates: Signal<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 refresh$ = new BehaviorSubject<boolean>(true)\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name)\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    super('multi-select-chips')\n\n    this.placeholder = '...'\n\n    this.selectChips = toSignal(\n      combineLatest([\n        this.entities$,\n        this.entityIds$,\n        toObservable(this.state),\n        toObservable(this.displayPropertyResolverS),\n        toObservable(this.readonlyS),\n        toObservable(this.disabledS),\n        this.refresh$,\n      ]).pipe(\n        map(([entities, entityIds, state, dPR]) =>\n          this.buildChipModelsOrFallback(entities, entityIds, state, dPR)\n        ),\n        map((models) =>\n          this.maxDisplayCount ? this.reduceDisplayedChips(models, this.maxDisplayCount) : models\n        )\n      )\n    )\n\n    this.templates = toSignal(\n      combineLatest([this.chipTemplate$, this.chipAvatarTemplate$, this.customInputTemplate$]).pipe(\n        map(([chip, avatar, input]) => {\n          return <TemplateWrapper>{\n            chip,\n            avatar,\n            input,\n          }\n        })\n      )\n    )\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    if (template) {\n      this.chipAvatarTemplate = template\n    }\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    if (template) {\n      this.customInputTemplate = template\n    }\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  /***************************************************************************\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(event: MouseEvent, toRemove: TEntity): void {\n    event.stopPropagation()\n    event.preventDefault()\n    this.requestRemoveEntity(toRemove, event.shiftKey)\n  }\n\n  public focus(options?: FocusOptions) {\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  public refresh(): void {\n    this.refresh$.next(true)\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  ): ChipModel<TEntity>[] {\n    if (state.error) {\n      return this.buildChipFallbackModels(entityIds)\n    }\n    return this.buildChipModels(entities, dPR)\n  }\n\n  private buildChipFallbackModels(entityIds: TId[]): ChipModel<TEntity>[] {\n    return entityIds.map((id) =>\n      this.buildChipBySpec(<any>{ id: id }, () => String(id), {\n        colorSpec: {\n          themeColor: 'warn',\n        },\n        avatarSpec: {\n          hide: false,\n          large: false,\n        },\n      })\n    )\n  }\n\n  private buildChipModels(entities: TEntity[], dPR: TextResolverFn): ChipModel<TEntity>[] {\n    if (entities) {\n      return entities.map((e) =>\n        this.buildChipBySpec(e, dPR, this.chipSpecFn(e) ?? this.defaultChipSpec)\n      )\n    } else {\n      return <ChipModel<TEntity>[]>[]\n    }\n  }\n\n  private buildChipBySpec(\n    e: TEntity,\n    dPR: TextResolverFn,\n    chipSpec: SelectChipSpec\n  ): ChipModel<TEntity> {\n    let removable = false\n    if (this.allowRemove && !this.isLocked) {\n      if (chipSpec.removable !== false) {\n        removable = true\n      }\n    }\n    return new ChipModel<TEntity>(\n      this.getEntityId(e),\n      e,\n      dPR(e),\n      chipSpec?.colorSpec,\n      removable,\n      chipSpec.avatarSpec,\n      chipSpec.trailingSpec\n    )\n  }\n\n  private reduceDisplayedChips(models: ChipModel<TEntity>[], count: number): ChipModel<TEntity>[] {\n    const reducedChips = models.slice(0, count)\n    const deltaCount = models.length - reducedChips.length\n    if (deltaCount > 0) {\n      const indicatorChip = this.buildIndicatorChip(deltaCount)\n      reducedChips.push(indicatorChip)\n    }\n    return reducedChips\n  }\n\n  private buildIndicatorChip(deltaCount: number): ChipModel<TEntity> {\n    return new ChipModel(\n      'overflow-indicator',\n      undefined,\n      '+' + deltaCount,\n      {},\n      false,\n      { hide: true },\n      {}\n    )\n  }\n}\n","<div class=\"elder-flex-control\" [matTooltip]=\"state()?.error\">\n  <mat-chip-set\n    #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    @if (icon) {\n      <div class=\"elder-input-prefix-icon-container flex-none\">\n        <mat-icon\n          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    }\n\n    @for (chipModel of selectChips(); track chipModel.id) {\n      <mat-chip-row\n        elderChipLabel\n        class=\"noselect clickable-chip\"\n        [value]=\"resolveChipValue(chipModel.value)\"\n        [color]=\"chipModel.colorSpec?.themeColor\"\n        [levelColor]=\"chipModel.colorSpec?.levelColor\"\n        [stateColor]=\"chipModel.colorSpec?.stateColor\"\n        [removable]=\"chipModel.removable\"\n        (keydown)=\"onChipKeyDown($event, chipModel.value)\"\n        (click)=\"onCurrentClicked(chipModel.value)\"\n        cdkDrag\n        [cdkDragData]=\"chipModel.value\"\n        [cdkDragDisabled]=\"!allowSorting\"\n      >\n        @if (templates()?.avatar && !chipModel.avatarSpec?.hide) {\n          <mat-chip-avatar [class.chip-avatar-xl]=\"chipModel.avatarSpec?.large\">\n            <ng-container *ngTemplateOutlet=\"templates().avatar; context: { $implicit: chipModel }\">\n            </ng-container>\n          </mat-chip-avatar>\n        }\n\n        <ng-container\n          *ngTemplateOutlet=\"\n            templates()?.chip || simpleChipTemplate;\n            context: { $implicit: chipModel }\n          \"\n        >\n        </ng-container>\n\n        @if (chipModel.trailingSpec?.icon; as trailingIcon) {\n          <mat-icon\n            matChipTrailingIcon\n            class=\"elder-trailing-icon\"\n            [fontSet]=\"chipModel.trailingSpec?.iconFontSet\"\n            >{{ trailingIcon }}</mat-icon\n          >\n        }\n\n        @if (chipModel.removable) {\n          <mat-icon matChipRemove (click)=\"onClickRemoveChip($event, chipModel.value)\">\n            cancel\n          </mat-icon>\n        }\n      </mat-chip-row>\n    }\n\n    <div class=\"layout-row place-start-center elder-chip-input\">\n      <!-- [matChipInputFor]=\"chips\" -->\n      <ng-container *ngTemplateOutlet=\"templates()?.input || selectInput\"> </ng-container>\n\n      @if (selectionPopup) {\n        <button\n          mat-icon-button\n          type=\"button\"\n          class=\"elder-control-icon-button elder-browse-icon\"\n          [disabled]=\"isLocked\"\n          (click)=\"openSelectionPopup($event)\"\n          aria-label=\"Search\"\n          elderStopEventPropagation\n          tabIndex=\"-1\"\n        >\n          <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n        </button>\n      }\n    </div>\n  </mat-chip-set>\n</div>\n\n<ng-template #selectInput>\n  <!-- mat-mdc-chip-input -->\n  <elder-select\n    autocomplete\n    elderClearSelect\n    class=\"elder-chip-input-select flex\"\n    [data]=\"dataContextS()\"\n    [disabled]=\"!!disabled\"\n    [required]=\"!!required\"\n    [readonly]=\"!!readonly\"\n    [placeholder]=\"placeholderS()\"\n    (entityUpdated)=\"appendEntity($event)\"\n    [displayPropertyResolver]=\"displayPropertyResolverS()\"\n    [valueTemplate]=\"valueTemplate\"\n    [queryFilter]=\"queryFilter\"\n    [filters]=\"filters\"\n    [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"]}
|
|
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,\n  Component,\n  ContentChild,\n  ElementRef,\n  forwardRef,\n  Input,\n  NgZone,\n  Optional,\n  Self,\n  Signal,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { ElderMultiSelectBase } from '../elder-multi-select-base'\nimport { BehaviorSubject, combineLatest, Observable } from 'rxjs'\nimport { map } from 'rxjs/operators'\nimport { LoggerFactory } from '@elderbyte/ts-logger'\nimport {\n  ElderSelectChipAvatarDirective,\n  ElderSelectChipDirective,\n  ElderSelectCustomInputDirective,\n} from '../../elder-select-chip.directive'\nimport { NgControl } from '@angular/forms'\nimport { MatFormFieldControl } from '@angular/material/form-field'\nimport {\n  ELDER_SELECT_BASE,\n  ElderSelectComponentState,\n  TextResolverFn,\n} 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, CdkDropList, CdkDrag } from '@angular/cdk/drag-drop'\nimport {\n  ChipAvatarSpec,\n  ChipColorSpec,\n  SelectChipSpec,\n  SelectChipSpecUtil,\n  TrailingSpec,\n} from './select-chip-spec'\nimport { ElderTruncatePipe } from '../../../../pipes/elder-truncate.pipe'\nimport { ElderClearSelectDirective } from '../../single/elder-clear-select.directive'\nimport { ElderStopEventPropagationDirective } from '../../../forms/directives/elder-stop-event-propagation.directive'\nimport { MatIconButton } from '@angular/material/button'\nimport { ElderChipLabelDirective } from '../../../chips/elder-chip-label.directive'\nimport { MatIcon } from '@angular/material/icon'\nimport {\n  MatChipSet,\n  MatChipRow,\n  MatChipAvatar,\n  MatChipTrailingIcon,\n  MatChipRemove,\n} from '@angular/material/chips'\nimport { MatTooltip } from '@angular/material/tooltip'\nimport { NgIf, NgFor, NgTemplateOutlet, AsyncPipe } from '@angular/common'\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop'\n\nclass ChipModel<T> {\n  constructor(\n    public readonly id: any,\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly colorSpec: ChipColorSpec,\n    public readonly removable: boolean,\n    public readonly avatarSpec: ChipAvatarSpec,\n    public readonly trailingSpec: TrailingSpec\n  ) {}\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  standalone: true,\n  imports: [\n    MatTooltip,\n    MatChipSet,\n    CdkDropList,\n    MatIcon,\n    MatChipRow,\n    ElderChipLabelDirective,\n    CdkDrag,\n    MatChipAvatar,\n    NgTemplateOutlet,\n    MatChipTrailingIcon,\n    MatChipRemove,\n    MatIconButton,\n    ElderStopEventPropagationDirective,\n    ElderSelectComponent,\n    ElderClearSelectDirective,\n    ElderTruncatePipe,\n  ],\n})\nexport class ElderMultiSelectChipsComponent<\n  TId = any,\n  TEntity = any,\n  TValue = any,\n> extends ElderMultiSelectBase<TId, TEntity, TValue> {\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  public readonly selectChips: Signal<ChipModel<TEntity>[]>\n\n  @Input()\n  public defaultChipSpec: SelectChipSpec = SelectChipSpecUtil.DefaultChipSpec\n\n  /**\n   * Allows to customize each chip individually (Color, Removable, Avatar).\n   *\n   */\n  @Input()\n  public chipSpecFn: (e: TEntity) => SelectChipSpec = (e) => this.defaultChipSpec\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  @Input()\n  public maxDisplayCount: number\n\n  @ContentChild(MatFormFieldControl) _customChipInput: MatFormFieldControl<any>\n  @ViewChild(ElderSelectComponent) _chipInput: MatFormFieldControl<any>\n\n  readonly templates: Signal<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 refresh$ = new BehaviorSubject<boolean>(true)\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name)\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {\n    super('multi-select-chips')\n\n    this.placeholder = '...'\n\n    this.selectChips = toSignal(\n      combineLatest([\n        this.entities$,\n        this.entityIds$,\n        toObservable(this.state),\n        toObservable(this.displayPropertyResolverS),\n        toObservable(this.readonlyS),\n        toObservable(this.disabledS),\n        this.refresh$,\n      ]).pipe(\n        map(([entities, entityIds, state, dPR]) =>\n          this.buildChipModelsOrFallback(entities, entityIds, state, dPR)\n        ),\n        map((models) =>\n          this.maxDisplayCount !== undefined\n            ? this.reduceDisplayedChips(models, this.maxDisplayCount)\n            : models\n        )\n      )\n    )\n\n    this.templates = toSignal(\n      combineLatest([this.chipTemplate$, this.chipAvatarTemplate$, this.customInputTemplate$]).pipe(\n        map(([chip, avatar, input]) => {\n          return <TemplateWrapper>{\n            chip,\n            avatar,\n            input,\n          }\n        })\n      )\n    )\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    if (template) {\n      this.chipAvatarTemplate = template\n    }\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    if (template) {\n      this.customInputTemplate = template\n    }\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  /***************************************************************************\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(event: MouseEvent, toRemove: TEntity): void {\n    event.stopPropagation()\n    event.preventDefault()\n    this.requestRemoveEntity(toRemove, event.shiftKey)\n  }\n\n  public focus(options?: FocusOptions) {\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  public refresh(): void {\n    this.refresh$.next(true)\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  ): ChipModel<TEntity>[] {\n    if (state.error) {\n      return this.buildChipFallbackModels(entityIds)\n    }\n    return this.buildChipModels(entities, dPR)\n  }\n\n  private buildChipFallbackModels(entityIds: TId[]): ChipModel<TEntity>[] {\n    return entityIds.map((id) =>\n      this.buildChipBySpec(<any>{ id: id }, () => String(id), {\n        colorSpec: {\n          themeColor: 'warn',\n        },\n        avatarSpec: {\n          hide: false,\n          large: false,\n        },\n      })\n    )\n  }\n\n  private buildChipModels(entities: TEntity[], dPR: TextResolverFn): ChipModel<TEntity>[] {\n    if (entities) {\n      return entities.map((e) =>\n        this.buildChipBySpec(e, dPR, this.chipSpecFn(e) ?? this.defaultChipSpec)\n      )\n    } else {\n      return <ChipModel<TEntity>[]>[]\n    }\n  }\n\n  private buildChipBySpec(\n    e: TEntity,\n    dPR: TextResolverFn,\n    chipSpec: SelectChipSpec\n  ): ChipModel<TEntity> {\n    let removable = false\n    if (this.allowRemove && !this.isLocked) {\n      if (chipSpec.removable !== false) {\n        removable = true\n      }\n    }\n    return new ChipModel<TEntity>(\n      this.getEntityId(e),\n      e,\n      dPR(e),\n      chipSpec?.colorSpec,\n      removable,\n      chipSpec.avatarSpec,\n      chipSpec.trailingSpec\n    )\n  }\n\n  private reduceDisplayedChips(models: ChipModel<TEntity>[], count: number): ChipModel<TEntity>[] {\n    const reducedChips = models.slice(0, count)\n    const deltaCount = models.length - reducedChips.length\n    if (deltaCount > 0) {\n      const indicatorChip = this.buildIndicatorChip(deltaCount)\n      reducedChips.push(indicatorChip)\n    }\n    return reducedChips\n  }\n\n  private buildIndicatorChip(deltaCount: number): ChipModel<TEntity> {\n    return new ChipModel(\n      'overflow-indicator',\n      undefined,\n      '+' + deltaCount,\n      {},\n      false,\n      { hide: true },\n      {}\n    )\n  }\n}\n","<div class=\"elder-flex-control\" [matTooltip]=\"state()?.error\">\n  <mat-chip-set\n    #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    @if (icon) {\n      <div class=\"elder-input-prefix-icon-container flex-none\">\n        <mat-icon\n          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    }\n\n    @for (chipModel of selectChips(); track chipModel.id) {\n      <mat-chip-row\n        elderChipLabel\n        class=\"noselect clickable-chip\"\n        [value]=\"resolveChipValue(chipModel.value)\"\n        [color]=\"chipModel.colorSpec?.themeColor\"\n        [levelColor]=\"chipModel.colorSpec?.levelColor\"\n        [stateColor]=\"chipModel.colorSpec?.stateColor\"\n        [removable]=\"chipModel.removable\"\n        (keydown)=\"onChipKeyDown($event, chipModel.value)\"\n        (click)=\"onCurrentClicked(chipModel.value)\"\n        cdkDrag\n        [cdkDragData]=\"chipModel.value\"\n        [cdkDragDisabled]=\"!allowSorting\"\n      >\n        @if (templates()?.avatar && !chipModel.avatarSpec?.hide) {\n          <mat-chip-avatar [class.chip-avatar-xl]=\"chipModel.avatarSpec?.large\">\n            <ng-container *ngTemplateOutlet=\"templates().avatar; context: { $implicit: chipModel }\">\n            </ng-container>\n          </mat-chip-avatar>\n        }\n\n        <ng-container\n          *ngTemplateOutlet=\"\n            templates()?.chip || simpleChipTemplate;\n            context: { $implicit: chipModel }\n          \"\n        >\n        </ng-container>\n\n        @if (chipModel.trailingSpec?.icon; as trailingIcon) {\n          <mat-icon\n            matChipTrailingIcon\n            class=\"elder-trailing-icon\"\n            [fontSet]=\"chipModel.trailingSpec?.iconFontSet\"\n            >{{ trailingIcon }}</mat-icon\n          >\n        }\n\n        @if (chipModel.removable) {\n          <mat-icon matChipRemove (click)=\"onClickRemoveChip($event, chipModel.value)\">\n            cancel\n          </mat-icon>\n        }\n      </mat-chip-row>\n    }\n\n    <div class=\"layout-row place-start-center elder-chip-input\">\n      <!-- [matChipInputFor]=\"chips\" -->\n      <ng-container *ngTemplateOutlet=\"templates()?.input || selectInput\"> </ng-container>\n\n      @if (selectionPopup) {\n        <button\n          mat-icon-button\n          type=\"button\"\n          class=\"elder-control-icon-button elder-browse-icon\"\n          [disabled]=\"isLocked\"\n          (click)=\"openSelectionPopup($event)\"\n          aria-label=\"Search\"\n          elderStopEventPropagation\n          tabIndex=\"-1\"\n        >\n          <mat-icon class=\"elder-mdc-control-icon\">search</mat-icon>\n        </button>\n      }\n    </div>\n  </mat-chip-set>\n</div>\n\n<ng-template #selectInput>\n  <!-- mat-mdc-chip-input -->\n  <elder-select\n    autocomplete\n    elderClearSelect\n    class=\"elder-chip-input-select flex\"\n    [data]=\"dataContextS()\"\n    [disabled]=\"!!disabled\"\n    [required]=\"!!required\"\n    [readonly]=\"!!readonly\"\n    [placeholder]=\"placeholderS()\"\n    (entityUpdated)=\"appendEntity($event)\"\n    [displayPropertyResolver]=\"displayPropertyResolverS()\"\n    [valueTemplate]=\"valueTemplate\"\n    [queryFilter]=\"queryFilter\"\n    [filters]=\"filters\"\n    [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"]}
|
|
@@ -24044,7 +24044,9 @@ class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
|
|
|
24044
24044
|
toObservable(this.readonlyS),
|
|
24045
24045
|
toObservable(this.disabledS),
|
|
24046
24046
|
this.refresh$,
|
|
24047
|
-
]).pipe(map(([entities, entityIds, state, dPR]) => this.buildChipModelsOrFallback(entities, entityIds, state, dPR)), map((models) => this.maxDisplayCount
|
|
24047
|
+
]).pipe(map(([entities, entityIds, state, dPR]) => this.buildChipModelsOrFallback(entities, entityIds, state, dPR)), map((models) => this.maxDisplayCount !== undefined
|
|
24048
|
+
? this.reduceDisplayedChips(models, this.maxDisplayCount)
|
|
24049
|
+
: models)));
|
|
24048
24050
|
this.templates = toSignal(combineLatest([this.chipTemplate$, this.chipAvatarTemplate$, this.customInputTemplate$]).pipe(map(([chip, avatar, input]) => {
|
|
24049
24051
|
return {
|
|
24050
24052
|
chip,
|