@eui/mobile-core 16.9.0-snapshot-1711463915848 → 16.9.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.
@@ -6,8 +6,8 @@ export class EuimChipSelectorItemDirective {
6
6
  constructor(renderer, el) {
7
7
  this.renderer = renderer;
8
8
  this.el = el;
9
- this.clickEventAdded = false;
10
9
  this.euimChipSelectorAll = false;
10
+ this.clickEventAdded = false;
11
11
  this.className = 'euim-chip-selector__item';
12
12
  }
13
13
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EuimChipSelectorItemDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
@@ -29,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
29
29
  type: HostBinding,
30
30
  args: ['class']
31
31
  }] } });
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1jaGlwLXNlbGVjdG9yLWl0ZW0uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2V1aW0tY2hpcC1zZWxlY3Rvci9ldWltLWNoaXAtc2VsZWN0b3ItaXRlbS9ldWltLWNoaXAtc2VsZWN0b3ItaXRlbS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBeUIsTUFBTSxlQUFlLENBQUM7QUFFckYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7QUFLMUMsTUFBTSxPQUFPLDZCQUE2QjtJQVV0QyxZQUFtQixRQUFtQixFQUFTLEVBQWM7UUFBMUMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUFTLE9BQUUsR0FBRixFQUFFLENBQVk7UUFUN0Qsb0JBQWUsR0FBRyxLQUFLLENBQUM7UUFLeEIsd0JBQW1CLEdBQWlCLEtBQUssQ0FBQztRQUVwQixjQUFTLEdBQUcsMEJBQTBCLENBQUM7SUFFRyxDQUFDO2tJQVZ4RCw2QkFBNkI7c0hBQTdCLDZCQUE2Qjs7QUFNdEM7SUFEQyxhQUFhOzBFQUM0Qjs0RkFOakMsNkJBQTZCO2tCQUh6QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx3QkFBd0I7aUJBQ3JDO3lIQUlZLEVBQUU7c0JBQVYsS0FBSztnQkFHTixtQkFBbUI7c0JBRmxCLEtBQUs7Z0JBSWdCLFNBQVM7c0JBQTlCLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdEJpbmRpbmcsIElucHV0LCBFbGVtZW50UmVmLCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJvb2xlYW5JbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQgeyBjb2VyY2VCb29sZWFuIH0gZnJvbSAnQGV1aS9iYXNlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbZXVpbUNoaXBTZWxlY3Rvckl0ZW1dJyxcbn0pXG5leHBvcnQgY2xhc3MgRXVpbUNoaXBTZWxlY3Rvckl0ZW1EaXJlY3RpdmUge1xuICAgIGNsaWNrRXZlbnRBZGRlZCA9IGZhbHNlO1xuXG4gICAgQElucHV0KCkgaWQ6IG51bWJlcjtcbiAgICBASW5wdXQoKVxuICAgIEBjb2VyY2VCb29sZWFuXG4gICAgZXVpbUNoaXBTZWxlY3RvckFsbDogQm9vbGVhbklucHV0ID0gZmFsc2U7XG5cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJykgY2xhc3NOYW1lID0gJ2V1aW0tY2hpcC1zZWxlY3Rvcl9faXRlbSc7XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVuZGVyZXI6IFJlbmRlcmVyMiwgcHVibGljIGVsOiBFbGVtZW50UmVmKSB7fVxuXG59XG4iXX0=
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1jaGlwLXNlbGVjdG9yLWl0ZW0uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2V1aW0tY2hpcC1zZWxlY3Rvci9ldWltLWNoaXAtc2VsZWN0b3ItaXRlbS9ldWltLWNoaXAtc2VsZWN0b3ItaXRlbS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBeUIsTUFBTSxlQUFlLENBQUM7QUFFckYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7QUFLMUMsTUFBTSxPQUFPLDZCQUE2QjtJQVN0QyxZQUFtQixRQUFtQixFQUFTLEVBQWM7UUFBMUMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUFTLE9BQUUsR0FBRixFQUFFLENBQVk7UUFMN0Qsd0JBQW1CLEdBQWlCLEtBQUssQ0FBQztRQUMxQyxvQkFBZSxHQUFHLEtBQUssQ0FBQztRQUVGLGNBQVMsR0FBRywwQkFBMEIsQ0FBQztJQUVHLENBQUM7a0lBVHhELDZCQUE2QjtzSEFBN0IsNkJBQTZCOztBQUl0QztJQURDLGFBQWE7MEVBQzRCOzRGQUpqQyw2QkFBNkI7a0JBSHpDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHdCQUF3QjtpQkFDckM7eUhBRVksRUFBRTtzQkFBVixLQUFLO2dCQUdOLG1CQUFtQjtzQkFGbEIsS0FBSztnQkFLZ0IsU0FBUztzQkFBOUIsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0QmluZGluZywgSW5wdXQsIEVsZW1lbnRSZWYsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7IGNvZXJjZUJvb2xlYW4gfSBmcm9tICdAZXVpL2Jhc2UnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tldWltQ2hpcFNlbGVjdG9ySXRlbV0nLFxufSlcbmV4cG9ydCBjbGFzcyBFdWltQ2hpcFNlbGVjdG9ySXRlbURpcmVjdGl2ZSB7XG4gICAgQElucHV0KCkgaWQ6IG51bWJlcjtcbiAgICBASW5wdXQoKVxuICAgIEBjb2VyY2VCb29sZWFuXG4gICAgZXVpbUNoaXBTZWxlY3RvckFsbDogQm9vbGVhbklucHV0ID0gZmFsc2U7XG4gICAgY2xpY2tFdmVudEFkZGVkID0gZmFsc2U7XG5cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJykgY2xhc3NOYW1lID0gJ2V1aW0tY2hpcC1zZWxlY3Rvcl9faXRlbSc7XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVuZGVyZXI6IFJlbmRlcmVyMiwgcHVibGljIGVsOiBFbGVtZW50UmVmKSB7fVxuXG59XG4iXX0=
@@ -27,6 +27,7 @@ export class EuimChipSelectorComponent {
27
27
  this.filteredData = [...this.sourceData];
28
28
  this.filterConditions = [];
29
29
  this.searchInput = '';
30
+ this.isEmitEvent = true;
30
31
  this.clickEventHandled = false;
31
32
  }
32
33
  get cssClasses() {
@@ -50,8 +51,9 @@ export class EuimChipSelectorComponent {
50
51
  this.euimChipSelectorItemSubscription.unsubscribe();
51
52
  }
52
53
  this.euimChipSelectorItemSubscription = this.euimChipSelectorItemComponent.changes.subscribe(() => {
53
- this.updateChipsAndFilters();
54
54
  this.setCssItemClasses();
55
+ this.updateChipsAndFilterDataAfterInit(this.isEmitEvent = false);
56
+ this.updateChipsAndFilters();
55
57
  });
56
58
  }
57
59
  ngOnChanges(changes) {
@@ -59,6 +61,12 @@ export class EuimChipSelectorComponent {
59
61
  changes.selectedChips.currentValue && changes.selectedChips.currentValue.length === 1 &&
60
62
  changes.selectedChips.currentValue.every((value, index) => value === '0')) {
61
63
  this.clearFiltersAndSelectAll();
64
+ return;
65
+ }
66
+ if (this.euimChipSelectorItemComponent && this.euimChipSelectorItemComponent.length > 0 &&
67
+ changes.selectedChips.currentValue && !changes.selectedChips.currentValue.every((value, index) => value === '0')) {
68
+ this.updateChipsAndFilterDataAfterInit();
69
+ return;
62
70
  }
63
71
  }
64
72
  getCssClasses() {
@@ -113,21 +121,6 @@ export class EuimChipSelectorComponent {
113
121
  }
114
122
  });
115
123
  }
116
- clickEventHandler(chip) {
117
- if (!this.clickEventHandled) {
118
- this.clickEventHandled = true;
119
- this.euimChipSelectorItemComponent.forEach(innerChip => {
120
- if (!this.isMultiSelectionMode || (this.isMultiSelectionMode && innerChip.euimChipSelectorAll)) {
121
- this.removeSelectedStyles(innerChip.el.nativeElement);
122
- }
123
- });
124
- this.addSelectedStyles(chip.el.nativeElement);
125
- this.onFilterChange(chip.id?.toString(), chip.euimChipSelectorAll, chip.el.nativeElement);
126
- this.filterData.emit(this.filteredData);
127
- this.clickItems.emit(this.selectedChips);
128
- this.clickEventHandled = false;
129
- }
130
- }
131
124
  applyFilter(filterCondition, isAllFilter, multipleFilterConditions) {
132
125
  let filteredData = [...this.sourceData];
133
126
  if (isAllFilter) {
@@ -158,14 +151,14 @@ export class EuimChipSelectorComponent {
158
151
  this.filterData.emit(this.sourceData);
159
152
  this.clickItems.emit(this.selectedChips);
160
153
  }
161
- updateChipsAndFilterDataAfterInit() {
154
+ updateChipsAndFilterDataAfterInit(isEmitEvent) {
162
155
  this.euimChipSelectorItemComponent.forEach(chip => {
163
156
  this.removeSelectedStyles(chip.el.nativeElement);
164
157
  if (chip.id === undefined && chip.euimChipSelectorAll) {
165
158
  chip.id = 0;
166
159
  }
167
160
  const chipId = chip.id;
168
- if (chipId && this.selectedChips.includes(chipId)) {
161
+ if (chipId && this.selectedChips.includes(chipId.toString())) {
169
162
  this.addSelectedStyles(chip.el.nativeElement);
170
163
  this.applyFilter(null, chip.euimChipSelectorAll, this.selectedChips);
171
164
  this.filterData.emit(this.filteredData);
@@ -176,13 +169,10 @@ export class EuimChipSelectorComponent {
176
169
  this.filterData.emit(this.sourceData);
177
170
  }
178
171
  });
179
- if (this.selectedChips.length > 0) {
180
- this.emitEvents();
172
+ if (isEmitEvent !== false) {
173
+ this.clickItems.emit(this.selectedChips);
181
174
  }
182
175
  }
183
- emitEvents() {
184
- this.clickItems.emit(this.selectedChips);
185
- }
186
176
  onFilterChange(filterCondition, isFilterAll, item) {
187
177
  if (this.isMultiSelectionMode) {
188
178
  this.handleMultiSelectionMode(filterCondition, isFilterAll, item);
@@ -312,4 +302,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
312
302
  type: ContentChildren,
313
303
  args: [EuimChipSelectorItemDirective, { descendants: true }]
314
304
  }] } });
315
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-chip-selector.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-chip-selector/euim-chip-selector.component.ts","../../../../../src/lib/components/euim-chip-selector/euim-chip-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, QueryList, OnChanges, SimpleChanges, ChangeDetectionStrategy, ContentChildren, AfterContentInit, HostBinding, Input, ViewEncapsulation, AfterViewInit, Output, EventEmitter, OnDestroy } from '@angular/core';\nimport { BooleanInput } from '@angular/cdk/coercion';\nimport { coerceBoolean } from '@eui/base';\nimport { EuimChipSelectorItemDirective } from './euim-chip-selector-item/euim-chip-selector-item.directive';\nimport { Subscription } from 'rxjs';\n\n@Component({\n    selector: 'euim-chip-selector',\n    templateUrl: 'euim-chip-selector.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n\n})\nexport class EuimChipSelectorComponent implements AfterViewInit, AfterContentInit, OnChanges, OnDestroy {\n\n    @Input() backgroundColor: 'primary' |  'white' | '' = 'primary';\n    /**\n     * @deprecated Will be removed in v17.\n     * Please use {@link color} property instead\n     */\n    @Input() chipColor: 'default' | 'dark' | 'white' | 'primary' | 'info' | 'success' | 'warning' | 'danger' = 'white';\n    @Input() color: 'default' | 'dark' | 'white' | 'primary' | 'info' | 'success' | 'warning' | 'danger' = 'white';\n    @Input() chipSelectedColor: 'dark' | 'white' = 'white';\n    @Input() chipFill: 'default' | 'clear' | 'outline' | 'outline-solid' | 'solid' = 'default';\n    @Input() sourceData: FilteredData[] = [];\n    @Input() selectedChips = [];\n    @Input()\n    @coerceBoolean\n    isMultiSelectionMode: BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    euimKeepSelection: BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    hasSearchbar: BooleanInput = false;\n    @Output() filterData = new EventEmitter<FilteredData[]>();\n    @Output() clickItems = new EventEmitter<string[]>();\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return this.getCssClasses();\n    }\n\n    @ContentChildren(EuimChipSelectorItemDirective, { descendants: true })\n    euimChipSelectorItemComponent: QueryList<EuimChipSelectorItemDirective>;\n\n    filteredData = [...this.sourceData];\n    filterConditions = []\n    searchInput = '';\n    euimChipSelectorItemSubscription: Subscription;\n    clickEventHandled = false;\n\n    ngAfterViewInit(): void {\n        this.setCssItemClasses();\n    }\n\n    ngAfterContentInit(): void {\n        this.subscribeToChanges();\n        this.updateChipsAndFilterDataAfterInit();\n        this.updateChipsAndFilters();\n    }\n\n    ngOnDestroy(): void {\n        if (this.euimChipSelectorItemSubscription) {\n            this.euimChipSelectorItemSubscription.unsubscribe();\n        }\n    }\n\n    subscribeToChanges(): void {\n        if (this.euimChipSelectorItemSubscription) {\n            this.euimChipSelectorItemSubscription.unsubscribe();\n        }\n\n        this.euimChipSelectorItemSubscription = this.euimChipSelectorItemComponent.changes.subscribe(() => {\n            this.updateChipsAndFilters();\n            this.setCssItemClasses();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (this.euimChipSelectorItemComponent && this.euimChipSelectorItemComponent.length > 0 &&\n            changes.selectedChips.currentValue && changes.selectedChips.currentValue.length === 1 &&\n            changes.selectedChips.currentValue.every((value, index) => value === '0')) {\n            this.clearFiltersAndSelectAll();\n        }\n    }\n\n    getCssClasses(): string {\n        return [\n            'euim-chip-selector',\n            this.backgroundColor ? `euim-chip-selector--background-color-${this.backgroundColor}` : '',\n        ].join(' ').trim();\n    }\n\n    setCssItemClasses(): void {\n        const classes = this.getCssItemClasses();\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            classes.split(' ').forEach(className => {\n                chip.el.nativeElement.classList.add(className);\n            });\n        });\n    }\n\n    getCssItemClasses(): string {\n        let currentColor = 'white';\n        // if color property is different from default one (white) than use chip color\n        // means using the deprecated chipColor property,\n        // needed as in V18 will be removed chipColor\n        if (this.chipColor === 'white' && this.color != 'white') {\n            currentColor = this.color;\n        } else {\n            currentColor = this.chipColor;\n        }\n\n        return [\n            this.chipFill ? `euim-chip-selector__item--fill-${this.chipFill}` : '',\n            currentColor ? `euim-chip-selector__item--color-${currentColor}` : '',\n        ].join(' ');\n    }\n\n    updateChipsAndFilters(): void {\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            if (!chip.clickEventAdded) {\n                chip.el.nativeElement.addEventListener('click', () => {\n\n                    if (!this.clickEventHandled) {\n                        this.clickEventHandled = true;\n\n                        this.euimChipSelectorItemComponent.forEach(innerChip => {\n                            if (!this.isMultiSelectionMode || (this.isMultiSelectionMode && innerChip.euimChipSelectorAll)) {\n                                this.removeSelectedStyles(innerChip.el.nativeElement);\n                            }\n                        });\n\n                        this.addSelectedStyles(chip.el.nativeElement);\n\n                        this.onFilterChange(chip.id?.toString(), chip.euimChipSelectorAll, chip.el.nativeElement);\n                        this.filterData.emit(this.filteredData);\n                        this.clickItems.emit(this.selectedChips);\n\n                        this.clickEventHandled = false;\n                    }\n                });\n                chip.clickEventAdded = true;\n            }\n        });\n    }\n\n    clickEventHandler(chip): void {\n        if (!this.clickEventHandled) {\n            this.clickEventHandled = true;\n\n            this.euimChipSelectorItemComponent.forEach(innerChip => {\n                if (!this.isMultiSelectionMode || (this.isMultiSelectionMode && innerChip.euimChipSelectorAll)) {\n                    this.removeSelectedStyles(innerChip.el.nativeElement);\n                }\n            });\n\n            this.addSelectedStyles(chip.el.nativeElement);\n\n            this.onFilterChange(chip.id?.toString(), chip.euimChipSelectorAll, chip.el.nativeElement);\n            this.filterData.emit(this.filteredData);\n            this.clickItems.emit(this.selectedChips);\n\n            this.clickEventHandled = false;\n        }\n    }\n\n    applyFilter(filterCondition: string, isAllFilter: BooleanInput, multipleFilterConditions: string[]): void {\n        let filteredData = [...this.sourceData];\n\n        if (isAllFilter) {\n            filteredData = this.filterBySearch(filteredData, this.searchInput);\n        } else {\n            if (this.isMultiSelectionMode || multipleFilterConditions.length > 0) {\n                filteredData = this.filterByMultipleConditions(filteredData, multipleFilterConditions);\n            } else {\n                filteredData = this.filterByCondition(filteredData, filterCondition);\n            }\n            if (this.euimKeepSelection && this.searchInput !== '') {\n                filteredData = this.filterBySearch(filteredData, this.searchInput);\n            }\n        }\n\n        this.filteredData = filteredData;\n    }\n\n    clearFiltersAndSelectAll(): void {\n        this.clearAllSelections();\n        let isFirstElement = true;\n\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            if (isFirstElement) {\n                this.addSelectedStyles(chip.el.nativeElement);\n                isFirstElement = false;\n            }\n        });\n\n        this.filterData.emit(this.sourceData);\n        this.clickItems.emit(this.selectedChips);\n    }\n\n    updateChipsAndFilterDataAfterInit(): void {\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            this.removeSelectedStyles(chip.el.nativeElement);\n\n            if (chip.id === undefined && chip.euimChipSelectorAll) {\n                chip.id = 0;\n            }\n            const chipId = chip.id;\n\n            if (chipId && this.selectedChips.includes(chipId)) {\n                this.addSelectedStyles(chip.el.nativeElement);\n                this.applyFilter(null, chip.euimChipSelectorAll, this.selectedChips);\n                this.filterData.emit(this.filteredData);\n            }\n\n            if (this.selectedChips.length === 0 && chip.euimChipSelectorAll) {\n                this.addSelectedStyles(chip.el.nativeElement);\n                this.selectedChips = ['0'];\n                this.filterData.emit(this.sourceData);\n            }\n        });\n\n        if (this.selectedChips.length > 0) {\n            this.emitEvents();\n        }\n    }\n\n    emitEvents(): void {\n        this.clickItems.emit(this.selectedChips);\n    }\n\n    onFilterChange(filterCondition: string, isFilterAll: BooleanInput, item): void {\n        if (this.isMultiSelectionMode) {\n            this.handleMultiSelectionMode(filterCondition, isFilterAll, item);\n        } else {\n            this.handleSingleSelectionMode(filterCondition, isFilterAll);\n        }\n\n        this.applyFilter(filterCondition, isFilterAll, this.filterConditions);\n        this.filterData.emit(this.filteredData);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    handleChange(event: any): void {\n        this.searchInput = event.detail.value.toLowerCase();\n        let filteredData = [...this.sourceData];\n\n        if (this.euimKeepSelection) {\n            filteredData = this.filterByChips(filteredData, this.selectedChips);\n            filteredData = this.filterBySearch(filteredData, this.searchInput);\n        } else {\n            filteredData = this.filterBySearch(filteredData, this.searchInput);\n        }\n\n        this.filteredData = filteredData;\n        this.filterData.emit(this.filteredData);\n    }\n\n    addSelectedStyles(item): void {\n        item.classList.add(`euim-chip-selector__item-selected--color-${this.chipSelectedColor}`);\n        item.setAttribute('selected', 'true');\n    }\n\n    removeSelectedStyles(item): void {\n        item.classList.remove(`euim-chip-selector__item-selected--color-${this.chipSelectedColor}`);\n        item.removeAttribute('selected');\n    }\n\n    private handleMultiSelectionMode(filterCondition: string, isFilterAll: BooleanInput, item): void {\n        if (!isFilterAll) {\n            this.filterConditions = this.selectedChips;\n            if (!this.filterConditions.includes(filterCondition)) {\n                this.filterConditions.push(filterCondition);\n                this.addSelectedStyles(item);\n            } else if (this.filterConditions.length > 1) {\n                this.filterConditions = this.filterConditions.filter(chip => chip !== filterCondition);\n                this.removeSelectedStyles(item);\n            }\n            this.selectedChips = this.filterConditions.filter(el => el !== '0');\n        } else {\n            this.clearAllSelections();\n            this.addSelectedStyles(item);\n        }\n    }\n\n    private handleSingleSelectionMode(filterCondition: string, isFilterAll: BooleanInput): void {\n        if (isFilterAll) {\n            this.selectedChips = ['0'];\n        } else {\n            this.selectedChips = [filterCondition];\n        }\n    }\n\n    private clearAllSelections(): void {\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            this.removeSelectedStyles(chip.el.nativeElement);\n        });\n        this.filterConditions = [];\n        this.selectedChips = ['0'];\n    }\n\n    private filterBySearch(data: FilteredData[], searchInput: string): FilteredData[] {\n        if (!searchInput) return data;\n        return data.filter(obj => obj.title.toLowerCase().includes(searchInput));\n    }\n\n    private filterByChips(data: FilteredData[], selectedChips: string[]): FilteredData[] {\n        if (selectedChips[0] === '0') return data;\n        return data.filter(item => selectedChips.includes(item.filterId));\n    }\n\n    private filterByCondition(data: FilteredData[], filterCondition: string): FilteredData[] {\n        return data.filter(item => item.filterId === filterCondition);\n    }\n\n    private filterByMultipleConditions(data: FilteredData[], multipleFilterConditions: string[]): FilteredData[] {\n        if (multipleFilterConditions.length === 0) return data;\n        return data.filter(item => multipleFilterConditions.includes(item.filterId));\n    }\n}\n\ninterface FilteredData {\n    [key: string]: string;\n}\n","<ion-searchbar *ngIf=\"hasSearchbar\" (ionChange)=\"handleChange($event)\"\n               class=\"euim-chip-selector__searchbar\"></ion-searchbar>\n<euim-scroller-x>\n    <ng-content></ng-content>\n</euim-scroller-x>\n\n"]}
305
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-chip-selector.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/euim-chip-selector/euim-chip-selector.component.ts","../../../../../src/lib/components/euim-chip-selector/euim-chip-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, QueryList, OnChanges, SimpleChanges, ChangeDetectionStrategy, ContentChildren, AfterContentInit, HostBinding, Input, ViewEncapsulation, AfterViewInit, Output, EventEmitter, OnDestroy } from '@angular/core';\nimport { BooleanInput } from '@angular/cdk/coercion';\nimport { coerceBoolean } from '@eui/base';\nimport { EuimChipSelectorItemDirective } from './euim-chip-selector-item/euim-chip-selector-item.directive';\nimport { Subscription } from 'rxjs';\n\n@Component({\n    selector: 'euim-chip-selector',\n    templateUrl: 'euim-chip-selector.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n\n})\nexport class EuimChipSelectorComponent implements AfterViewInit, AfterContentInit, OnChanges, OnDestroy {\n\n    @Input() backgroundColor: 'primary' |  'white' | '' = 'primary';\n    /**\n     * @deprecated Will be removed in v17.\n     * Please use {@link color} property instead\n     */\n    @Input() chipColor: 'default' | 'dark' | 'white' | 'primary' | 'info' | 'success' | 'warning' | 'danger' = 'white';\n    @Input() color: 'default' | 'dark' | 'white' | 'primary' | 'info' | 'success' | 'warning' | 'danger' = 'white';\n    @Input() chipSelectedColor: 'dark' | 'white' = 'white';\n    @Input() chipFill: 'default' | 'clear' | 'outline' | 'outline-solid' | 'solid' = 'default';\n    @Input() sourceData: FilteredData[] = [];\n    @Input() selectedChips = [];\n    @Input()\n    @coerceBoolean\n    isMultiSelectionMode: BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    euimKeepSelection: BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    hasSearchbar: BooleanInput = false;\n    @Output() filterData = new EventEmitter<FilteredData[]>();\n    @Output() clickItems = new EventEmitter<string[]>();\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return this.getCssClasses();\n    }\n\n    @ContentChildren(EuimChipSelectorItemDirective, { descendants: true })\n    euimChipSelectorItemComponent: QueryList<EuimChipSelectorItemDirective>;\n\n    filteredData = [...this.sourceData];\n    filterConditions = []\n    searchInput = '';\n    isEmitEvent = true;\n    euimChipSelectorItemSubscription: Subscription;\n    clickEventHandled = false;\n\n    ngAfterViewInit(): void {\n        this.setCssItemClasses();\n    }\n\n    ngAfterContentInit(): void {\n        this.subscribeToChanges();\n        this.updateChipsAndFilterDataAfterInit();\n        this.updateChipsAndFilters();\n    }\n\n    ngOnDestroy(): void {\n        if (this.euimChipSelectorItemSubscription) {\n            this.euimChipSelectorItemSubscription.unsubscribe();\n        }\n    }\n\n    subscribeToChanges(): void {\n        if (this.euimChipSelectorItemSubscription) {\n            this.euimChipSelectorItemSubscription.unsubscribe();\n        }\n\n        this.euimChipSelectorItemSubscription = this.euimChipSelectorItemComponent.changes.subscribe(() => {\n            this.setCssItemClasses();\n            this.updateChipsAndFilterDataAfterInit(this.isEmitEvent = false);\n            this.updateChipsAndFilters();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (this.euimChipSelectorItemComponent && this.euimChipSelectorItemComponent.length > 0 &&\n            changes.selectedChips.currentValue && changes.selectedChips.currentValue.length === 1 &&\n            changes.selectedChips.currentValue.every((value, index) => value === '0')) {\n            this.clearFiltersAndSelectAll();\n            return;\n        }\n\n        if (this.euimChipSelectorItemComponent && this.euimChipSelectorItemComponent.length > 0 &&\n            changes.selectedChips.currentValue && !changes.selectedChips.currentValue.every((value, index) => value === '0')) {\n            this.updateChipsAndFilterDataAfterInit();\n            return;\n        }\n    }\n\n    getCssClasses(): string {\n        return [\n            'euim-chip-selector',\n            this.backgroundColor ? `euim-chip-selector--background-color-${this.backgroundColor}` : '',\n        ].join(' ').trim();\n    }\n\n    setCssItemClasses(): void {\n        const classes = this.getCssItemClasses();\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            classes.split(' ').forEach(className => {\n                chip.el.nativeElement.classList.add(className);\n            });\n        });\n    }\n\n    getCssItemClasses(): string {\n        let currentColor = 'white';\n        // if color property is different from default one (white) than use chip color\n        // means using the deprecated chipColor property,\n        // needed as in V18 will be removed chipColor\n        if (this.chipColor === 'white' && this.color != 'white') {\n            currentColor = this.color;\n        } else {\n            currentColor = this.chipColor;\n        }\n\n        return [\n            this.chipFill ? `euim-chip-selector__item--fill-${this.chipFill}` : '',\n            currentColor ? `euim-chip-selector__item--color-${currentColor}` : '',\n        ].join(' ');\n    }\n\n    updateChipsAndFilters(): void {\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            if (!chip.clickEventAdded) {\n                chip.el.nativeElement.addEventListener('click', () => {\n\n                    if (!this.clickEventHandled) {\n                        this.clickEventHandled = true;\n\n                        this.euimChipSelectorItemComponent.forEach(innerChip => {\n                            if (!this.isMultiSelectionMode || (this.isMultiSelectionMode && innerChip.euimChipSelectorAll)) {\n                                this.removeSelectedStyles(innerChip.el.nativeElement);\n                            }\n                        });\n\n                        this.addSelectedStyles(chip.el.nativeElement);\n\n                        this.onFilterChange(chip.id?.toString(), chip.euimChipSelectorAll, chip.el.nativeElement);\n                        this.filterData.emit(this.filteredData);\n                        this.clickItems.emit(this.selectedChips);\n\n                        this.clickEventHandled = false;\n                    }\n                });\n                chip.clickEventAdded = true;\n            }\n        });\n    }\n\n    applyFilter(filterCondition: string, isAllFilter: BooleanInput, multipleFilterConditions: string[]): void {\n        let filteredData = [...this.sourceData];\n\n        if (isAllFilter) {\n            filteredData = this.filterBySearch(filteredData, this.searchInput);\n        } else {\n            if (this.isMultiSelectionMode || multipleFilterConditions.length > 0) {\n                filteredData = this.filterByMultipleConditions(filteredData, multipleFilterConditions);\n            } else {\n                filteredData = this.filterByCondition(filteredData, filterCondition);\n            }\n            if (this.euimKeepSelection && this.searchInput !== '') {\n                filteredData = this.filterBySearch(filteredData, this.searchInput);\n            }\n        }\n\n        this.filteredData = filteredData;\n    }\n\n    clearFiltersAndSelectAll(): void {\n        this.clearAllSelections();\n        let isFirstElement = true;\n\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            if (isFirstElement) {\n                this.addSelectedStyles(chip.el.nativeElement);\n                isFirstElement = false;\n            }\n        });\n\n        this.filterData.emit(this.sourceData);\n        this.clickItems.emit(this.selectedChips);\n    }\n\n    updateChipsAndFilterDataAfterInit(isEmitEvent?: boolean): void {\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            this.removeSelectedStyles(chip.el.nativeElement);\n\n            if (chip.id === undefined && chip.euimChipSelectorAll) {\n                chip.id = 0;\n            }\n            const chipId = chip.id;\n\n            if (chipId && this.selectedChips.includes(chipId.toString())) {\n                this.addSelectedStyles(chip.el.nativeElement);\n                this.applyFilter(null, chip.euimChipSelectorAll, this.selectedChips);\n                this.filterData.emit(this.filteredData);\n            }\n\n            if (this.selectedChips.length === 0 && chip.euimChipSelectorAll) {\n                this.addSelectedStyles(chip.el.nativeElement);\n                this.selectedChips = ['0'];\n                this.filterData.emit(this.sourceData);\n            }\n        });\n\n        if (isEmitEvent !== false) {\n            this.clickItems.emit(this.selectedChips);\n        }\n    }\n\n    onFilterChange(filterCondition: string, isFilterAll: BooleanInput, item): void {\n        if (this.isMultiSelectionMode) {\n            this.handleMultiSelectionMode(filterCondition, isFilterAll, item);\n        } else {\n            this.handleSingleSelectionMode(filterCondition, isFilterAll);\n        }\n\n        this.applyFilter(filterCondition, isFilterAll, this.filterConditions);\n        this.filterData.emit(this.filteredData);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    handleChange(event: any): void {\n        this.searchInput = event.detail.value.toLowerCase();\n        let filteredData = [...this.sourceData];\n\n        if (this.euimKeepSelection) {\n            filteredData = this.filterByChips(filteredData, this.selectedChips);\n            filteredData = this.filterBySearch(filteredData, this.searchInput);\n        } else {\n            filteredData = this.filterBySearch(filteredData, this.searchInput);\n        }\n\n        this.filteredData = filteredData;\n        this.filterData.emit(this.filteredData);\n    }\n\n    addSelectedStyles(item): void {\n        item.classList.add(`euim-chip-selector__item-selected--color-${this.chipSelectedColor}`);\n        item.setAttribute('selected', 'true');\n    }\n\n    removeSelectedStyles(item): void {\n        item.classList.remove(`euim-chip-selector__item-selected--color-${this.chipSelectedColor}`);\n        item.removeAttribute('selected');\n    }\n\n    private handleMultiSelectionMode(filterCondition: string, isFilterAll: BooleanInput, item): void {\n        if (!isFilterAll) {\n            this.filterConditions = this.selectedChips;\n            if (!this.filterConditions.includes(filterCondition)) {\n                this.filterConditions.push(filterCondition);\n                this.addSelectedStyles(item);\n            } else if (this.filterConditions.length > 1) {\n                this.filterConditions = this.filterConditions.filter(chip => chip !== filterCondition);\n                this.removeSelectedStyles(item);\n            }\n            this.selectedChips = this.filterConditions.filter(el => el !== '0');\n        } else {\n            this.clearAllSelections();\n            this.addSelectedStyles(item);\n        }\n    }\n\n    private handleSingleSelectionMode(filterCondition: string, isFilterAll: BooleanInput): void {\n        if (isFilterAll) {\n            this.selectedChips = ['0'];\n        } else {\n            this.selectedChips = [filterCondition];\n        }\n    }\n\n    private clearAllSelections(): void {\n        this.euimChipSelectorItemComponent.forEach(chip => {\n            this.removeSelectedStyles(chip.el.nativeElement);\n        });\n        this.filterConditions = [];\n        this.selectedChips = ['0'];\n    }\n\n    private filterBySearch(data: FilteredData[], searchInput: string): FilteredData[] {\n        if (!searchInput) return data;\n        return data.filter(obj => obj.title.toLowerCase().includes(searchInput));\n    }\n\n    private filterByChips(data: FilteredData[], selectedChips: string[]): FilteredData[] {\n        if (selectedChips[0] === '0') return data;\n        return data.filter(item => selectedChips.includes(item.filterId));\n    }\n\n    private filterByCondition(data: FilteredData[], filterCondition: string): FilteredData[] {\n        return data.filter(item => item.filterId === filterCondition);\n    }\n\n    private filterByMultipleConditions(data: FilteredData[], multipleFilterConditions: string[]): FilteredData[] {\n        if (multipleFilterConditions.length === 0) return data;\n        return data.filter(item => multipleFilterConditions.includes(item.filterId));\n    }\n}\n\ninterface FilteredData {\n    [key: string]: string;\n}\n","<ion-searchbar *ngIf=\"hasSearchbar\" (ionChange)=\"handleChange($event)\"\n               class=\"euim-chip-selector__searchbar\"></ion-searchbar>\n<euim-scroller-x>\n    <ng-content></ng-content>\n</euim-scroller-x>\n\n"]}
@@ -3406,8 +3406,8 @@ class EuimChipSelectorItemDirective {
3406
3406
  constructor(renderer, el) {
3407
3407
  this.renderer = renderer;
3408
3408
  this.el = el;
3409
- this.clickEventAdded = false;
3410
3409
  this.euimChipSelectorAll = false;
3410
+ this.clickEventAdded = false;
3411
3411
  this.className = 'euim-chip-selector__item';
3412
3412
  }
3413
3413
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EuimChipSelectorItemDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
@@ -3451,6 +3451,7 @@ class EuimChipSelectorComponent {
3451
3451
  this.filteredData = [...this.sourceData];
3452
3452
  this.filterConditions = [];
3453
3453
  this.searchInput = '';
3454
+ this.isEmitEvent = true;
3454
3455
  this.clickEventHandled = false;
3455
3456
  }
3456
3457
  get cssClasses() {
@@ -3474,8 +3475,9 @@ class EuimChipSelectorComponent {
3474
3475
  this.euimChipSelectorItemSubscription.unsubscribe();
3475
3476
  }
3476
3477
  this.euimChipSelectorItemSubscription = this.euimChipSelectorItemComponent.changes.subscribe(() => {
3477
- this.updateChipsAndFilters();
3478
3478
  this.setCssItemClasses();
3479
+ this.updateChipsAndFilterDataAfterInit(this.isEmitEvent = false);
3480
+ this.updateChipsAndFilters();
3479
3481
  });
3480
3482
  }
3481
3483
  ngOnChanges(changes) {
@@ -3483,6 +3485,12 @@ class EuimChipSelectorComponent {
3483
3485
  changes.selectedChips.currentValue && changes.selectedChips.currentValue.length === 1 &&
3484
3486
  changes.selectedChips.currentValue.every((value, index) => value === '0')) {
3485
3487
  this.clearFiltersAndSelectAll();
3488
+ return;
3489
+ }
3490
+ if (this.euimChipSelectorItemComponent && this.euimChipSelectorItemComponent.length > 0 &&
3491
+ changes.selectedChips.currentValue && !changes.selectedChips.currentValue.every((value, index) => value === '0')) {
3492
+ this.updateChipsAndFilterDataAfterInit();
3493
+ return;
3486
3494
  }
3487
3495
  }
3488
3496
  getCssClasses() {
@@ -3537,21 +3545,6 @@ class EuimChipSelectorComponent {
3537
3545
  }
3538
3546
  });
3539
3547
  }
3540
- clickEventHandler(chip) {
3541
- if (!this.clickEventHandled) {
3542
- this.clickEventHandled = true;
3543
- this.euimChipSelectorItemComponent.forEach(innerChip => {
3544
- if (!this.isMultiSelectionMode || (this.isMultiSelectionMode && innerChip.euimChipSelectorAll)) {
3545
- this.removeSelectedStyles(innerChip.el.nativeElement);
3546
- }
3547
- });
3548
- this.addSelectedStyles(chip.el.nativeElement);
3549
- this.onFilterChange(chip.id?.toString(), chip.euimChipSelectorAll, chip.el.nativeElement);
3550
- this.filterData.emit(this.filteredData);
3551
- this.clickItems.emit(this.selectedChips);
3552
- this.clickEventHandled = false;
3553
- }
3554
- }
3555
3548
  applyFilter(filterCondition, isAllFilter, multipleFilterConditions) {
3556
3549
  let filteredData = [...this.sourceData];
3557
3550
  if (isAllFilter) {
@@ -3582,14 +3575,14 @@ class EuimChipSelectorComponent {
3582
3575
  this.filterData.emit(this.sourceData);
3583
3576
  this.clickItems.emit(this.selectedChips);
3584
3577
  }
3585
- updateChipsAndFilterDataAfterInit() {
3578
+ updateChipsAndFilterDataAfterInit(isEmitEvent) {
3586
3579
  this.euimChipSelectorItemComponent.forEach(chip => {
3587
3580
  this.removeSelectedStyles(chip.el.nativeElement);
3588
3581
  if (chip.id === undefined && chip.euimChipSelectorAll) {
3589
3582
  chip.id = 0;
3590
3583
  }
3591
3584
  const chipId = chip.id;
3592
- if (chipId && this.selectedChips.includes(chipId)) {
3585
+ if (chipId && this.selectedChips.includes(chipId.toString())) {
3593
3586
  this.addSelectedStyles(chip.el.nativeElement);
3594
3587
  this.applyFilter(null, chip.euimChipSelectorAll, this.selectedChips);
3595
3588
  this.filterData.emit(this.filteredData);
@@ -3600,13 +3593,10 @@ class EuimChipSelectorComponent {
3600
3593
  this.filterData.emit(this.sourceData);
3601
3594
  }
3602
3595
  });
3603
- if (this.selectedChips.length > 0) {
3604
- this.emitEvents();
3596
+ if (isEmitEvent !== false) {
3597
+ this.clickItems.emit(this.selectedChips);
3605
3598
  }
3606
3599
  }
3607
- emitEvents() {
3608
- this.clickItems.emit(this.selectedChips);
3609
- }
3610
3600
  onFilterChange(filterCondition, isFilterAll, item) {
3611
3601
  if (this.isMultiSelectionMode) {
3612
3602
  this.handleMultiSelectionMode(filterCondition, isFilterAll, item);