@elderbyte/ngx-starter 13.6.0 → 13.7.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.
- package/esm2020/lib/common/utils/collection-util.mjs +4 -1
- package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +77 -0
- package/esm2020/lib/components/select/auto/elder-select-first-util.mjs +62 -0
- package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +14 -9
- package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +104 -0
- package/esm2020/lib/components/select/elder-select.module.mjs +11 -11
- package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +103 -39
- package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +13 -13
- package/fesm2015/elderbyte-ngx-starter.mjs +226 -144
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +226 -144
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/common/utils/collection-util.d.ts +1 -0
- package/lib/components/select/{auto-select-first.directive.d.ts → auto/elder-auto-select-first.directive.d.ts} +4 -13
- package/lib/components/select/auto/elder-select-first-util.d.ts +22 -0
- package/lib/components/select/elder-select/elder-select.component.d.ts +11 -1
- package/lib/components/select/{select-on-tab.directive.d.ts → elder-select-on-tab.directive.d.ts} +3 -3
- package/lib/components/select/elder-select.module.d.ts +5 -5
- package/lib/components/select/multi/elder-multi-select-base.d.ts +39 -15
- package/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.d.ts +11 -11
- package/package.json +1 -1
- package/esm2020/lib/components/select/auto-select-first.directive.mjs +0 -126
- package/esm2020/lib/components/select/select-on-tab.directive.mjs +0 -104
|
@@ -16,7 +16,7 @@ import * as i7 from "@angular/material/input";
|
|
|
16
16
|
import * as i8 from "@angular/material/autocomplete";
|
|
17
17
|
import * as i9 from "../../../input/autocomplete/elder-autocomplete.directive";
|
|
18
18
|
import * as i10 from "@ngx-translate/core";
|
|
19
|
-
class
|
|
19
|
+
class SelectChip {
|
|
20
20
|
constructor(value, displayText, color, removeable) {
|
|
21
21
|
this.value = value;
|
|
22
22
|
this.displayText = displayText;
|
|
@@ -41,13 +41,13 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
|
|
|
41
41
|
this.chipColorResolver$ = new BehaviorSubject((value) => undefined);
|
|
42
42
|
this.selectable = true;
|
|
43
43
|
this.allowRemove = true;
|
|
44
|
-
this.
|
|
45
|
-
this.
|
|
44
|
+
this.selectChips$ = combineLatest([
|
|
45
|
+
this.entities$,
|
|
46
46
|
this.displayPropertyResolver$,
|
|
47
47
|
this.chipColorResolver$
|
|
48
48
|
]).pipe(map(([values, dPR, cCR]) => {
|
|
49
49
|
if (values) {
|
|
50
|
-
return values.map(v => new
|
|
50
|
+
return values.map(v => new SelectChip(v, dPR(v), cCR(v), this.allowRemove));
|
|
51
51
|
}
|
|
52
52
|
else {
|
|
53
53
|
return [];
|
|
@@ -116,19 +116,19 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
|
|
|
116
116
|
}
|
|
117
117
|
}
|
|
118
118
|
addLabels(labels) {
|
|
119
|
-
const current = this.
|
|
119
|
+
const current = this.entities ? this.entities : [];
|
|
120
120
|
this.replaceWith([...current, ...labels]);
|
|
121
121
|
}
|
|
122
122
|
addLabel(label) {
|
|
123
123
|
this.addLabels([label]);
|
|
124
124
|
}
|
|
125
125
|
removeLabel(toRemove) {
|
|
126
|
-
const remaining = this.
|
|
126
|
+
const remaining = this.entities
|
|
127
127
|
.filter(l => !this.isEqual(l, toRemove));
|
|
128
128
|
this.replaceWith(remaining);
|
|
129
129
|
}
|
|
130
|
-
replaceWith(
|
|
131
|
-
this.
|
|
130
|
+
replaceWith(entities) {
|
|
131
|
+
this.updateValueByEntities(entities);
|
|
132
132
|
}
|
|
133
133
|
/***************************************************************************
|
|
134
134
|
* *
|
|
@@ -136,8 +136,8 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
|
|
|
136
136
|
* *
|
|
137
137
|
**************************************************************************/
|
|
138
138
|
isAlreadyPresent(queryValue) {
|
|
139
|
-
if (this.
|
|
140
|
-
return this.
|
|
139
|
+
if (this.entities) {
|
|
140
|
+
return this.entities.some(v => this.isEqual(v, queryValue));
|
|
141
141
|
}
|
|
142
142
|
else {
|
|
143
143
|
return false;
|
|
@@ -153,10 +153,10 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
|
|
|
153
153
|
}
|
|
154
154
|
}
|
|
155
155
|
ElderMultiSelectChipsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: ElderMultiSelectChipsComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
156
|
-
ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: ElderMultiSelectChipsComponent, selector: "elder-multi-select-chips", inputs: { allowRemove: "allowRemove", chipTemplate: "chipTemplate", chipColorResolver: "chipColorResolver" }, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), queries: [{ propertyName: "chipTemplateQuery", first: true, predicate: ElderSelectChipDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "inputControl", first: true, predicate: ["chipInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<mat-form-field *ngIf=\"(
|
|
156
|
+
ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: ElderMultiSelectChipsComponent, selector: "elder-multi-select-chips", inputs: { allowRemove: "allowRemove", chipTemplate: "chipTemplate", chipColorResolver: "chipColorResolver" }, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), queries: [{ propertyName: "chipTemplateQuery", first: true, predicate: ElderSelectChipDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "inputControl", first: true, predicate: ["chipInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n <mat-icon *ngIf=\"icon\" disabled\n class=\"leading-icon prefix-padding noselect\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\">\n {{icon}}\n </mat-icon>\n\n\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"leading-icon prefix-padding noselect\"\n color=\"warn\">\n warning\n </mat-icon>\n </ng-container>\n\n <!-- A dynamic input -->\n\n <mat-chip-list selectable #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect\"\n [color]=\"chipModel.color\" selectable selected\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeLabel(chipModel.value)\"\n >\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <input matInput type=\"text\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [name]=\"name + '-multi-chips-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matChipInputFor]=\"chips\"\n [matAutocomplete]\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n autocomplete=\"off\"\n #chipInput>\n </mat-chip-list>\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n {{chipModel.displayText}}\n</ng-template>\n\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}\n"], components: [{ type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.MatChipList, selector: "mat-chip-list", inputs: ["errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { type: i4.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "enabled", "valueTemplate", "suggestionsDc", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { type: i1.MatLabel, selector: "mat-label" }, { type: i1.MatPrefix, selector: "[matPrefix]" }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.MatChipRemove, selector: "[matChipRemove]" }, { 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"] }, { type: i3.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { type: i8.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i9.ElderAutocompleteDirective, selector: "[elderElderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderElderAutocomplete"] }, { type: i1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }], pipes: { "async": i5.AsyncPipe, "translate": i10.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
157
157
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: ElderMultiSelectChipsComponent, decorators: [{
|
|
158
158
|
type: Component,
|
|
159
|
-
args: [{ selector: 'elder-multi-select-chips', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), template: "<mat-form-field *ngIf=\"(
|
|
159
|
+
args: [{ selector: 'elder-multi-select-chips', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n <mat-icon *ngIf=\"icon\" disabled\n class=\"leading-icon prefix-padding noselect\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\">\n {{icon}}\n </mat-icon>\n\n\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"leading-icon prefix-padding noselect\"\n color=\"warn\">\n warning\n </mat-icon>\n </ng-container>\n\n <!-- A dynamic input -->\n\n <mat-chip-list selectable #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect\"\n [color]=\"chipModel.color\" selectable selected\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeLabel(chipModel.value)\"\n >\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <input matInput type=\"text\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [name]=\"name + '-multi-chips-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matChipInputFor]=\"chips\"\n [matAutocomplete]\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n autocomplete=\"off\"\n #chipInput>\n </mat-chip-list>\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n {{chipModel.displayText}}\n</ng-template>\n\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}\n"] }]
|
|
160
160
|
}], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { allowRemove: [{
|
|
161
161
|
type: Input
|
|
162
162
|
}], inputControl: [{
|
|
@@ -170,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
|
|
|
170
170
|
}], chipColorResolver: [{
|
|
171
171
|
type: Input
|
|
172
172
|
}] } });
|
|
173
|
-
//# 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 {Component, OnInit, ChangeDetectionStrategy, NgZone, ViewChild, ElementRef, Input, ContentChild, TemplateRef} from '@angular/core';\nimport {ElderMultiSelectBase} from '../elder-multi-select-base';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {ThemePalette} from '@angular/material/core/common-behaviors/color';\nimport {TextResolverFn} from '../../elder-select-base';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderSelectChipDirective} from '../../elder-select-chip.directive';\nimport {buildFormIntegrationProviders} from '../../../../common/forms/template-composite-control';\n\nclass ValueChip<T> {\n  constructor(\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly color: ThemePalette,\n    public readonly removeable: boolean\n  ) {\n  }\n}\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  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent)\n})\nexport class ElderMultiSelectChipsComponent<TId, T> extends ElderMultiSelectBase<TId, T> implements OnInit {\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly valuesWrapped$: Observable<ValueChip<T>[]>;\n\n  private readonly chipColorResolver$ = new BehaviorSubject<(o1: any) => ThemePalette>((value: T) => undefined);\n\n\n  public selectable = true;\n\n  @Input()\n  public allowRemove = true;\n\n\n  @ViewChild('chipInput', {static: false})\n  private inputControl: ElementRef<HTMLInputElement>;\n\n  @ContentChild(ElderSelectChipDirective, {read: TemplateRef, static: true})\n  public chipTemplateQuery: TemplateRef<any>;\n  private _chipTemplate: TemplateRef<any>;\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone\n  ) {\n    super(zone);\n    this.valuesWrapped$ = combineLatest(\n      [\n        this.value$,\n        this.displayPropertyResolver$,\n        this.chipColorResolver$\n      ]\n    ).pipe(\n      map(([values, dPR, cCR]) => {\n        if (values) {\n          return values.map(\n            v => new ValueChip<T>(\n              v,\n              dPR(v),\n              cCR(v),\n              this.allowRemove\n            )\n          );\n        } else {\n          return <ValueChip<T>[]>[];\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set chipTemplate(template: TemplateRef<any>) {\n    this._chipTemplate = template;\n  }\n\n  public get chipTemplate(): TemplateRef<any> {\n    return this._chipTemplate || this.chipTemplateQuery;\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 (typeof fn !== 'function') {\n      throw new Error('chipColorResolver must be a function!');\n    }\n    this.chipColorResolver$.next(fn);\n  }\n\n  public get isOptionDisabledInternalFn(): (option: T) => boolean {\n    return (option: T) => {\n      if (this.isOptionDisabledFn) {\n        return this.isOptionDisabledFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: T) => boolean {\n    return (option: T) => {\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 onOptionSelected(selectedValue: T): void {\n    if (selectedValue) {\n      this.resetInput();\n      this.addLabel(selectedValue);\n    }\n  }\n\n  public addLabels(labels: T[]) {\n    const current = this.value ? this.value : [];\n    this.replaceWith([...current, ...labels]);\n  }\n\n  public addLabel(label: any) {\n    this.addLabels([label]);\n  }\n\n  public removeLabel(toRemove: T): void {\n\n    const remaining = this.value\n      .filter(l => !this.isEqual(l, toRemove));\n\n    this.replaceWith(remaining);\n  }\n\n  public replaceWith(labels: T[]): void {\n    this.updateValue(labels);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private isAlreadyPresent(queryValue: T): boolean {\n    if (this.value) {\n      return this.value.some(v => this.isEqual(v, queryValue));\n    } else {\n      return false;\n    }\n  }\n\n  private resetInput(): void {\n    if (this.inputControl) {\n      this.inputControl.nativeElement.value = '';\n    } else {\n      this.log.error('Failed to reset inputControl since it was not found!');\n    }\n\n  }\n\n}\n","<mat-form-field *ngIf=\"(valuesWrapped$ | async) as chipValues\" fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [floatLabel]=\"floatLabel\"\n                [color]=\"color\"\n>\n\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n  <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n    <mat-icon *ngIf=\"icon\" disabled\n              class=\"leading-icon prefix-padding noselect\"\n              [class.loading]=\"state.loading\"\n              [color]=\"state?.error ? 'warn' : color\">\n      {{icon}}\n    </mat-icon>\n\n\n    <mat-icon *ngIf=\"!icon && state?.error\"\n              class=\"leading-icon prefix-padding noselect\"\n              color=\"warn\">\n      warning\n    </mat-icon>\n  </ng-container>\n\n  <!-- A dynamic input -->\n\n  <mat-chip-list selectable #chips>\n    <mat-chip *ngFor=\"let chipModel of chipValues\"\n              class=\"noselect\"\n              [color]=\"chipModel.color\" selectable selected\n              [removable]=\"chipModel.removeable\"\n              (removed)=\"removeLabel(chipModel.value)\"\n    >\n      <ng-container\n        *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n      </ng-container>\n      <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n    </mat-chip>\n\n    <input matInput type=\"text\"\n           [disabled]=\"disabled\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [name]=\"name + '-multi-chips-inner-input'\"\n           [placeholder]=\"placeholder | translate\"\n           [matChipInputFor]=\"chips\"\n           [matAutocomplete]\n           [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n           autocomplete=\"off\"\n           #chipInput>\n  </mat-chip-list>\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n  <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n  {{chipModel.displayText}}\n</ng-template>\n\n"]}
|
|
173
|
+
//# 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 {Component, OnInit, ChangeDetectionStrategy, NgZone, ViewChild, ElementRef, Input, ContentChild, TemplateRef} from '@angular/core';\nimport {ElderMultiSelectBase} from '../elder-multi-select-base';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {ThemePalette} from '@angular/material/core/common-behaviors/color';\nimport {TextResolverFn} from '../../elder-select-base';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderSelectChipDirective} from '../../elder-select-chip.directive';\nimport {buildFormIntegrationProviders} from '../../../../common/forms/template-composite-control';\n\nclass SelectChip<T> {\n  constructor(\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly color: ThemePalette,\n    public readonly removeable: boolean\n  ) {\n  }\n}\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  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent)\n})\nexport class ElderMultiSelectChipsComponent<TId = any, TEntity = any, TValue = any>\n  extends ElderMultiSelectBase<TId, TEntity, TValue>\n  implements OnInit {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly selectChips$: Observable<SelectChip<TEntity>[]>;\n\n  private readonly chipColorResolver$ = new BehaviorSubject<(o1: any) => ThemePalette>((value: TEntity) => undefined);\n\n\n  public selectable = true;\n\n  @Input()\n  public allowRemove = true;\n\n\n  @ViewChild('chipInput', {static: false})\n  private inputControl: ElementRef<HTMLInputElement>;\n\n  @ContentChild(ElderSelectChipDirective, {read: TemplateRef, static: true})\n  public chipTemplateQuery: TemplateRef<any>;\n  private _chipTemplate: TemplateRef<any>;\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone\n  ) {\n    super(zone);\n    this.selectChips$ = combineLatest(\n      [\n        this.entities$,\n        this.displayPropertyResolver$,\n        this.chipColorResolver$\n      ]\n    ).pipe(\n      map(([values, dPR, cCR]) => {\n        if (values) {\n          return values.map(\n            v => new SelectChip<TEntity>(\n              v,\n              dPR(v),\n              cCR(v),\n              this.allowRemove\n            )\n          );\n        } else {\n          return <SelectChip<TEntity>[]>[];\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set chipTemplate(template: TemplateRef<any>) {\n    this._chipTemplate = template;\n  }\n\n  public get chipTemplate(): TemplateRef<any> {\n    return this._chipTemplate || this.chipTemplateQuery;\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 (typeof fn !== 'function') {\n      throw new Error('chipColorResolver must be a function!');\n    }\n    this.chipColorResolver$.next(fn);\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 onOptionSelected(selectedValue: TEntity): void {\n    if (selectedValue) {\n      this.resetInput();\n      this.addLabel(selectedValue);\n    }\n  }\n\n  public addLabels(labels: TEntity[]) {\n    const current = this.entities ? this.entities : [];\n    this.replaceWith([...current, ...labels]);\n  }\n\n  public addLabel(label: any) {\n    this.addLabels([label]);\n  }\n\n  public removeLabel(toRemove: TEntity): void {\n\n    const remaining = this.entities\n      .filter(l => !this.isEqual(l, toRemove));\n\n    this.replaceWith(remaining);\n  }\n\n  public replaceWith(entities: TEntity[]): void {\n    this.updateValueByEntities(entities);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\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 resetInput(): void {\n    if (this.inputControl) {\n      this.inputControl.nativeElement.value = '';\n    } else {\n      this.log.error('Failed to reset inputControl since it was not found!');\n    }\n  }\n\n}\n","<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [floatLabel]=\"floatLabel\"\n                [color]=\"color\"\n>\n\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n  <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n    <mat-icon *ngIf=\"icon\" disabled\n              class=\"leading-icon prefix-padding noselect\"\n              [class.loading]=\"state.loading\"\n              [color]=\"state?.error ? 'warn' : color\">\n      {{icon}}\n    </mat-icon>\n\n\n    <mat-icon *ngIf=\"!icon && state?.error\"\n              class=\"leading-icon prefix-padding noselect\"\n              color=\"warn\">\n      warning\n    </mat-icon>\n  </ng-container>\n\n  <!-- A dynamic input -->\n\n  <mat-chip-list selectable #chips>\n    <mat-chip *ngFor=\"let chipModel of chipValues\"\n              class=\"noselect\"\n              [color]=\"chipModel.color\" selectable selected\n              [removable]=\"chipModel.removeable\"\n              (removed)=\"removeLabel(chipModel.value)\"\n    >\n      <ng-container\n        *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n      </ng-container>\n      <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n    </mat-chip>\n\n    <input matInput type=\"text\"\n           [disabled]=\"disabled\"\n           [required]=\"required\"\n           [readonly]=\"readonly\"\n           [name]=\"name + '-multi-chips-inner-input'\"\n           [placeholder]=\"placeholder | translate\"\n           [matChipInputFor]=\"chips\"\n           [matAutocomplete]\n           [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n           autocomplete=\"off\"\n           #chipInput>\n  </mat-chip-list>\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n  <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n  {{chipModel.displayText}}\n</ng-template>\n\n"]}
|