@eui/mobile-core 16.8.0-snapshot-1710761952573 → 16.8.0-snapshot-1711018751488
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/docs/components/EuimChipSelectorComponent.html +142 -0
- package/docs/dependencies.html +2 -2
- package/docs/directives/EuimChipSelectorItemDirective.html +23 -0
- package/docs/js/menu-wc_es5.js +3 -4
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.mjs +2 -1
- package/esm2022/lib/components/euim-chip-selector/euim-chip-selector.component.mjs +50 -11
- package/fesm2022/eui-mobile-core.mjs +50 -10
- package/fesm2022/eui-mobile-core.mjs.map +1 -1
- package/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.d.ts +1 -0
- package/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.d.ts.map +1 -1
- package/lib/components/euim-chip-selector/euim-chip-selector.component.d.ts +8 -2
- package/lib/components/euim-chip-selector/euim-chip-selector.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -6,6 +6,7 @@ export class EuimChipSelectorItemDirective {
|
|
|
6
6
|
constructor(renderer, el) {
|
|
7
7
|
this.renderer = renderer;
|
|
8
8
|
this.el = el;
|
|
9
|
+
this.clickEventAdded = false;
|
|
9
10
|
this.euimChipSelectorAll = false;
|
|
10
11
|
this.className = 'euim-chip-selector__item';
|
|
11
12
|
}
|
|
@@ -28,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
28
29
|
type: HostBinding,
|
|
29
30
|
args: ['class']
|
|
30
31
|
}] } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1jaGlwLXNlbGVjdG9yLWl0ZW0uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2V1aW0tY2hpcC1zZWxlY3Rvci9ldWltLWNoaXAtc2VsZWN0b3ItaXRlbS9ldWltLWNoaXAtc2VsZWN0b3ItaXRlbS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBeUIsTUFBTSxlQUFlLENBQUM7QUFFckYsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFdBQVcsQ0FBQzs7QUFLMUMsTUFBTSxPQUFPLDZCQUE2QjtJQVV0QyxZQUFtQixRQUFtQixFQUFTLEVBQWM7UUFBMUMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUFTLE9BQUUsR0FBRixFQUFFLENBQVk7UUFUN0Qsb0JBQWUsR0FBRyxLQUFLLENBQUM7UUFLeEIsd0JBQW1CLEdBQWlCLEtBQUssQ0FBQztRQUVwQixjQUFTLEdBQUcsMEJBQTBCLENBQUM7SUFFRyxDQUFDO2tJQVZ4RCw2QkFBNkI7c0hBQTdCLDZCQUE2Qjs7QUFNdEM7SUFEQyxhQUFhOzBFQUM0Qjs0RkFOakMsNkJBQTZCO2tCQUh6QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx3QkFBd0I7aUJBQ3JDO3lIQUlZLEVBQUU7c0JBQVYsS0FBSztnQkFHTixtQkFBbUI7c0JBRmxCLEtBQUs7Z0JBSWdCLFNBQVM7c0JBQTlCLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdEJpbmRpbmcsIElucHV0LCBFbGVtZW50UmVmLCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJvb2xlYW5JbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQgeyBjb2VyY2VCb29sZWFuIH0gZnJvbSAnQGV1aS9iYXNlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbZXVpbUNoaXBTZWxlY3Rvckl0ZW1dJyxcbn0pXG5leHBvcnQgY2xhc3MgRXVpbUNoaXBTZWxlY3Rvckl0ZW1EaXJlY3RpdmUge1xuICAgIGNsaWNrRXZlbnRBZGRlZCA9IGZhbHNlO1xuXG4gICAgQElucHV0KCkgaWQ6IG51bWJlcjtcbiAgICBASW5wdXQoKVxuICAgIEBjb2VyY2VCb29sZWFuXG4gICAgZXVpbUNoaXBTZWxlY3RvckFsbDogQm9vbGVhbklucHV0ID0gZmFsc2U7XG5cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJykgY2xhc3NOYW1lID0gJ2V1aW0tY2hpcC1zZWxlY3Rvcl9faXRlbSc7XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVuZGVyZXI6IFJlbmRlcmVyMiwgcHVibGljIGVsOiBFbGVtZW50UmVmKSB7fVxuXG59XG4iXX0=
|
|
@@ -8,6 +8,7 @@ import * as i2 from "@ionic/angular";
|
|
|
8
8
|
import * as i3 from "../euim-scroller-x/euim-scroller-x.component";
|
|
9
9
|
export class EuimChipSelectorComponent {
|
|
10
10
|
constructor() {
|
|
11
|
+
this.clickEventHandled = false;
|
|
11
12
|
this.backgroundColor = 'primary';
|
|
12
13
|
/**
|
|
13
14
|
* @deprecated Will be removed in v17.
|
|
@@ -32,12 +33,28 @@ export class EuimChipSelectorComponent {
|
|
|
32
33
|
return this.getCssClasses();
|
|
33
34
|
}
|
|
34
35
|
ngAfterViewInit() {
|
|
36
|
+
this.subscribeToChanges();
|
|
35
37
|
this.setCssItemClasses();
|
|
36
38
|
}
|
|
37
39
|
ngAfterContentInit() {
|
|
40
|
+
this.subscribeToChanges();
|
|
38
41
|
this.updateChipsAndFilterDataAfterInit();
|
|
39
42
|
this.updateChipsAndFilters();
|
|
40
43
|
}
|
|
44
|
+
ngOnDestroy() {
|
|
45
|
+
if (this.euimChipSelectorItemSubscription) {
|
|
46
|
+
this.euimChipSelectorItemSubscription.unsubscribe();
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
subscribeToChanges() {
|
|
50
|
+
if (this.euimChipSelectorItemSubscription) {
|
|
51
|
+
this.euimChipSelectorItemSubscription.unsubscribe();
|
|
52
|
+
}
|
|
53
|
+
this.euimChipSelectorItemSubscription = this.euimChipSelectorItemComponent.changes.subscribe(() => {
|
|
54
|
+
this.updateChipsAndFilters();
|
|
55
|
+
this.setCssItemClasses();
|
|
56
|
+
});
|
|
57
|
+
}
|
|
41
58
|
ngOnChanges(changes) {
|
|
42
59
|
if (this.euimChipSelectorItemComponent && this.euimChipSelectorItemComponent.length > 0 &&
|
|
43
60
|
changes.selectedChips.currentValue && changes.selectedChips.currentValue.length === 1 &&
|
|
@@ -77,19 +94,41 @@ export class EuimChipSelectorComponent {
|
|
|
77
94
|
}
|
|
78
95
|
updateChipsAndFilters() {
|
|
79
96
|
this.euimChipSelectorItemComponent.forEach(chip => {
|
|
80
|
-
chip.
|
|
81
|
-
|
|
82
|
-
if (!this.
|
|
83
|
-
this.
|
|
97
|
+
if (!chip.clickEventAdded) {
|
|
98
|
+
chip.el.nativeElement.addEventListener('click', () => {
|
|
99
|
+
if (!this.clickEventHandled) {
|
|
100
|
+
this.clickEventHandled = true;
|
|
101
|
+
this.euimChipSelectorItemComponent.forEach(innerChip => {
|
|
102
|
+
if (!this.isMultiSelectionMode || (this.isMultiSelectionMode && innerChip.euimChipSelectorAll)) {
|
|
103
|
+
this.removeSelectedStyles(innerChip.el.nativeElement);
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
this.addSelectedStyles(chip.el.nativeElement);
|
|
107
|
+
this.onFilterChange(chip.id?.toString(), chip.euimChipSelectorAll, chip.el.nativeElement);
|
|
108
|
+
this.filterData.emit(this.filteredData);
|
|
109
|
+
this.clickItems.emit(this.selectedChips);
|
|
110
|
+
this.clickEventHandled = false;
|
|
84
111
|
}
|
|
85
112
|
});
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
this.filterData.emit(this.filteredData);
|
|
89
|
-
this.clickItems.emit(this.selectedChips);
|
|
90
|
-
});
|
|
113
|
+
chip.clickEventAdded = true;
|
|
114
|
+
}
|
|
91
115
|
});
|
|
92
116
|
}
|
|
117
|
+
clickEventHandler(chip) {
|
|
118
|
+
if (!this.clickEventHandled) {
|
|
119
|
+
this.clickEventHandled = true;
|
|
120
|
+
this.euimChipSelectorItemComponent.forEach(innerChip => {
|
|
121
|
+
if (!this.isMultiSelectionMode || (this.isMultiSelectionMode && innerChip.euimChipSelectorAll)) {
|
|
122
|
+
this.removeSelectedStyles(innerChip.el.nativeElement);
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
this.addSelectedStyles(chip.el.nativeElement);
|
|
126
|
+
this.onFilterChange(chip.id?.toString(), chip.euimChipSelectorAll, chip.el.nativeElement);
|
|
127
|
+
this.filterData.emit(this.filteredData);
|
|
128
|
+
this.clickItems.emit(this.selectedChips);
|
|
129
|
+
this.clickEventHandled = false;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
93
132
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
94
133
|
handleChange(event) {
|
|
95
134
|
this.searchInput = event.detail.value.toLowerCase();
|
|
@@ -130,6 +169,7 @@ export class EuimChipSelectorComponent {
|
|
|
130
169
|
this.addSelectedStyles(chip.el.nativeElement);
|
|
131
170
|
this.applyFilter(null, chip.euimChipSelectorAll, this.selectedChips);
|
|
132
171
|
this.filterData.emit(this.filteredData);
|
|
172
|
+
this.clickItems.emit(this.selectedChips);
|
|
133
173
|
}
|
|
134
174
|
if (this.selectedChips.length === 0 && chip.euimChipSelectorAll) {
|
|
135
175
|
this.addSelectedStyles(chip.el.nativeElement);
|
|
@@ -138,7 +178,6 @@ export class EuimChipSelectorComponent {
|
|
|
138
178
|
this.clickItems.emit(this.selectedChips);
|
|
139
179
|
}
|
|
140
180
|
});
|
|
141
|
-
this.clickItems.emit(this.selectedChips);
|
|
142
181
|
}
|
|
143
182
|
onFilterChange(filterCondition, isFilterAll, item) {
|
|
144
183
|
if (this.isMultiSelectionMode) {
|
|
@@ -250,4 +289,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
250
289
|
type: ContentChildren,
|
|
251
290
|
args: [EuimChipSelectorItemDirective, { descendants: true }]
|
|
252
291
|
}] } });
|
|
253
|
-
//# 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 } 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';\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 {\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    @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\n    ngAfterViewInit(): void {\n        this.setCssItemClasses();\n    }\n\n    ngAfterContentInit(): void {\n        this.updateChipsAndFilterDataAfterInit();\n        this.updateChipsAndFilters();\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            chip.el.nativeElement.addEventListener('click', () => {\n\n                this.euimChipSelectorItemComponent.forEach(chip => {\n                    if (!this.isMultiSelectionMode || this.isMultiSelectionMode && chip.euimChipSelectorAll) {\n                        this.removeSelectedStyles(chip.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            });\n        });\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\n        if (!this.euimKeepSelection) return;\n\n        let filteredDataWithSearch = [];\n        if (this.searchInput !== '') {\n            filteredDataWithSearch = (this.selectedChips[0] !== '0') ? this.filteredData : this.sourceData;\n            filteredDataWithSearch = filteredDataWithSearch.filter(obj => obj.title.toLowerCase().includes(this.searchInput));\n        } else {\n            filteredDataWithSearch = (this.selectedChips[0] !== '0') ? this.filteredData : this.sourceData;\n        }\n\n        this.filterData.emit(filteredDataWithSearch);\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\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        });\n\n        this.euimChipSelectorItemComponent.forEach((chip) => {\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                this.clickItems.emit(this.selectedChips);\n            }\n        });\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    applyFilter(filterCondition: string, isAllFilter: BooleanInput, multipleFilterConditions: string[]): void {\n\n        if (isAllFilter && multipleFilterConditions.length === 0) {\n            this.filteredData = [...this.sourceData];\n            return;\n        }\n\n        if (this.isMultiSelectionMode || multipleFilterConditions.length > 0) {\n            this.filteredData = [...this.sourceData].filter(item => multipleFilterConditions.includes(item.filterId));\n            return;\n        }\n\n        this.filteredData = [...this.sourceData].filter(item => {\n            return item.filterId === filterCondition;\n        });\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\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"]}
|
|
292
|
+
//# 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, ElementRef, 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    euimChipSelectorItemSubscription: Subscription;\n    clickEventHandled = false;\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\n    ngAfterViewInit(): void {\n        this.subscribeToChanges();\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                    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    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    handleChange(event: any): void {\n        this.searchInput = event.detail.value.toLowerCase();\n\n        if (!this.euimKeepSelection) return;\n\n        let filteredDataWithSearch = [];\n        if (this.searchInput !== '') {\n            filteredDataWithSearch = (this.selectedChips[0] !== '0') ? this.filteredData : this.sourceData;\n            filteredDataWithSearch = filteredDataWithSearch.filter(obj => obj.title.toLowerCase().includes(this.searchInput));\n        } else {\n            filteredDataWithSearch = (this.selectedChips[0] !== '0') ? this.filteredData : this.sourceData;\n        }\n\n        this.filterData.emit(filteredDataWithSearch);\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\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        });\n\n        this.euimChipSelectorItemComponent.forEach((chip) => {\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                this.clickItems.emit(this.selectedChips);\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                this.clickItems.emit(this.selectedChips);\n            }\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    applyFilter(filterCondition: string, isAllFilter: BooleanInput, multipleFilterConditions: string[]): void {\n\n        if (isAllFilter && multipleFilterConditions.length === 0) {\n            this.filteredData = [...this.sourceData];\n            return;\n        }\n\n        if (this.isMultiSelectionMode || multipleFilterConditions.length > 0) {\n            this.filteredData = [...this.sourceData].filter(item => multipleFilterConditions.includes(item.filterId));\n            return;\n        }\n\n        this.filteredData = [...this.sourceData].filter(item => {\n            return item.filterId === filterCondition;\n        });\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\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"]}
|
|
@@ -3403,6 +3403,7 @@ class EuimChipSelectorItemDirective {
|
|
|
3403
3403
|
constructor(renderer, el) {
|
|
3404
3404
|
this.renderer = renderer;
|
|
3405
3405
|
this.el = el;
|
|
3406
|
+
this.clickEventAdded = false;
|
|
3406
3407
|
this.euimChipSelectorAll = false;
|
|
3407
3408
|
this.className = 'euim-chip-selector__item';
|
|
3408
3409
|
}
|
|
@@ -3428,6 +3429,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
3428
3429
|
|
|
3429
3430
|
class EuimChipSelectorComponent {
|
|
3430
3431
|
constructor() {
|
|
3432
|
+
this.clickEventHandled = false;
|
|
3431
3433
|
this.backgroundColor = 'primary';
|
|
3432
3434
|
/**
|
|
3433
3435
|
* @deprecated Will be removed in v17.
|
|
@@ -3452,12 +3454,28 @@ class EuimChipSelectorComponent {
|
|
|
3452
3454
|
return this.getCssClasses();
|
|
3453
3455
|
}
|
|
3454
3456
|
ngAfterViewInit() {
|
|
3457
|
+
this.subscribeToChanges();
|
|
3455
3458
|
this.setCssItemClasses();
|
|
3456
3459
|
}
|
|
3457
3460
|
ngAfterContentInit() {
|
|
3461
|
+
this.subscribeToChanges();
|
|
3458
3462
|
this.updateChipsAndFilterDataAfterInit();
|
|
3459
3463
|
this.updateChipsAndFilters();
|
|
3460
3464
|
}
|
|
3465
|
+
ngOnDestroy() {
|
|
3466
|
+
if (this.euimChipSelectorItemSubscription) {
|
|
3467
|
+
this.euimChipSelectorItemSubscription.unsubscribe();
|
|
3468
|
+
}
|
|
3469
|
+
}
|
|
3470
|
+
subscribeToChanges() {
|
|
3471
|
+
if (this.euimChipSelectorItemSubscription) {
|
|
3472
|
+
this.euimChipSelectorItemSubscription.unsubscribe();
|
|
3473
|
+
}
|
|
3474
|
+
this.euimChipSelectorItemSubscription = this.euimChipSelectorItemComponent.changes.subscribe(() => {
|
|
3475
|
+
this.updateChipsAndFilters();
|
|
3476
|
+
this.setCssItemClasses();
|
|
3477
|
+
});
|
|
3478
|
+
}
|
|
3461
3479
|
ngOnChanges(changes) {
|
|
3462
3480
|
if (this.euimChipSelectorItemComponent && this.euimChipSelectorItemComponent.length > 0 &&
|
|
3463
3481
|
changes.selectedChips.currentValue && changes.selectedChips.currentValue.length === 1 &&
|
|
@@ -3497,19 +3515,41 @@ class EuimChipSelectorComponent {
|
|
|
3497
3515
|
}
|
|
3498
3516
|
updateChipsAndFilters() {
|
|
3499
3517
|
this.euimChipSelectorItemComponent.forEach(chip => {
|
|
3500
|
-
chip.
|
|
3501
|
-
|
|
3502
|
-
if (!this.
|
|
3503
|
-
this.
|
|
3518
|
+
if (!chip.clickEventAdded) {
|
|
3519
|
+
chip.el.nativeElement.addEventListener('click', () => {
|
|
3520
|
+
if (!this.clickEventHandled) {
|
|
3521
|
+
this.clickEventHandled = true;
|
|
3522
|
+
this.euimChipSelectorItemComponent.forEach(innerChip => {
|
|
3523
|
+
if (!this.isMultiSelectionMode || (this.isMultiSelectionMode && innerChip.euimChipSelectorAll)) {
|
|
3524
|
+
this.removeSelectedStyles(innerChip.el.nativeElement);
|
|
3525
|
+
}
|
|
3526
|
+
});
|
|
3527
|
+
this.addSelectedStyles(chip.el.nativeElement);
|
|
3528
|
+
this.onFilterChange(chip.id?.toString(), chip.euimChipSelectorAll, chip.el.nativeElement);
|
|
3529
|
+
this.filterData.emit(this.filteredData);
|
|
3530
|
+
this.clickItems.emit(this.selectedChips);
|
|
3531
|
+
this.clickEventHandled = false;
|
|
3504
3532
|
}
|
|
3505
3533
|
});
|
|
3506
|
-
|
|
3507
|
-
|
|
3508
|
-
this.filterData.emit(this.filteredData);
|
|
3509
|
-
this.clickItems.emit(this.selectedChips);
|
|
3510
|
-
});
|
|
3534
|
+
chip.clickEventAdded = true;
|
|
3535
|
+
}
|
|
3511
3536
|
});
|
|
3512
3537
|
}
|
|
3538
|
+
clickEventHandler(chip) {
|
|
3539
|
+
if (!this.clickEventHandled) {
|
|
3540
|
+
this.clickEventHandled = true;
|
|
3541
|
+
this.euimChipSelectorItemComponent.forEach(innerChip => {
|
|
3542
|
+
if (!this.isMultiSelectionMode || (this.isMultiSelectionMode && innerChip.euimChipSelectorAll)) {
|
|
3543
|
+
this.removeSelectedStyles(innerChip.el.nativeElement);
|
|
3544
|
+
}
|
|
3545
|
+
});
|
|
3546
|
+
this.addSelectedStyles(chip.el.nativeElement);
|
|
3547
|
+
this.onFilterChange(chip.id?.toString(), chip.euimChipSelectorAll, chip.el.nativeElement);
|
|
3548
|
+
this.filterData.emit(this.filteredData);
|
|
3549
|
+
this.clickItems.emit(this.selectedChips);
|
|
3550
|
+
this.clickEventHandled = false;
|
|
3551
|
+
}
|
|
3552
|
+
}
|
|
3513
3553
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
3514
3554
|
handleChange(event) {
|
|
3515
3555
|
this.searchInput = event.detail.value.toLowerCase();
|
|
@@ -3550,6 +3590,7 @@ class EuimChipSelectorComponent {
|
|
|
3550
3590
|
this.addSelectedStyles(chip.el.nativeElement);
|
|
3551
3591
|
this.applyFilter(null, chip.euimChipSelectorAll, this.selectedChips);
|
|
3552
3592
|
this.filterData.emit(this.filteredData);
|
|
3593
|
+
this.clickItems.emit(this.selectedChips);
|
|
3553
3594
|
}
|
|
3554
3595
|
if (this.selectedChips.length === 0 && chip.euimChipSelectorAll) {
|
|
3555
3596
|
this.addSelectedStyles(chip.el.nativeElement);
|
|
@@ -3558,7 +3599,6 @@ class EuimChipSelectorComponent {
|
|
|
3558
3599
|
this.clickItems.emit(this.selectedChips);
|
|
3559
3600
|
}
|
|
3560
3601
|
});
|
|
3561
|
-
this.clickItems.emit(this.selectedChips);
|
|
3562
3602
|
}
|
|
3563
3603
|
onFilterChange(filterCondition, isFilterAll, item) {
|
|
3564
3604
|
if (this.isMultiSelectionMode) {
|