@eui/ecl 18.0.0-next.39 → 18.0.0-next.40
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/assets/i18n-ecl/bg.json +1 -0
- package/assets/i18n-ecl/cs.json +1 -0
- package/assets/i18n-ecl/da.json +1 -0
- package/assets/i18n-ecl/de.json +1 -0
- package/assets/i18n-ecl/el.json +1 -0
- package/assets/i18n-ecl/en.json +1 -0
- package/assets/i18n-ecl/es.json +1 -0
- package/assets/i18n-ecl/et.json +1 -0
- package/assets/i18n-ecl/fi.json +1 -0
- package/assets/i18n-ecl/fr.json +1 -0
- package/assets/i18n-ecl/ga.json +1 -0
- package/assets/i18n-ecl/hr.json +1 -0
- package/assets/i18n-ecl/hu.json +1 -0
- package/assets/i18n-ecl/it.json +1 -0
- package/assets/i18n-ecl/lt.json +1 -0
- package/assets/i18n-ecl/lv.json +1 -0
- package/assets/i18n-ecl/mt.json +1 -0
- package/assets/i18n-ecl/nl.json +1 -0
- package/assets/i18n-ecl/pl.json +1 -0
- package/assets/i18n-ecl/pt.json +1 -0
- package/assets/i18n-ecl/ro.json +1 -0
- package/assets/i18n-ecl/sk.json +1 -0
- package/assets/i18n-ecl/sl.json +1 -0
- package/assets/i18n-ecl/sv.json +1 -0
- package/docs/components/EclMultiselectComponent.html +37 -1
- package/docs/components/EclMultiselectDropdownComponent.html +30 -1
- package/docs/components/EclMultiselectInputComponent.html +134 -2
- package/docs/components/EclMultiselectOptionComponent.html +32 -2
- package/docs/dependencies.html +1 -1
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-dropdown/ecl-multiselect-dropdown.component.mjs +21 -28
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-input/ecl-multiselect-input.component.mjs +35 -21
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-option/ecl-multiselect-option.component.mjs +11 -16
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect.component.mjs +20 -15
- package/fesm2022/eui-ecl.mjs +372 -307
- package/fesm2022/eui-ecl.mjs.map +3 -3
- package/lib/components/ecl-multiselect/ecl-multiselect-dropdown/ecl-multiselect-dropdown.component.d.ts +3 -0
- package/lib/components/ecl-multiselect/ecl-multiselect-dropdown/ecl-multiselect-dropdown.component.d.ts.map +1 -1
- package/lib/components/ecl-multiselect/ecl-multiselect-input/ecl-multiselect-input.component.d.ts +13 -3
- package/lib/components/ecl-multiselect/ecl-multiselect-input/ecl-multiselect-input.component.d.ts.map +1 -1
- package/lib/components/ecl-multiselect/ecl-multiselect-option/ecl-multiselect-option.component.d.ts +5 -3
- package/lib/components/ecl-multiselect/ecl-multiselect-option/ecl-multiselect-option.component.d.ts.map +1 -1
- package/lib/components/ecl-multiselect/ecl-multiselect.component.d.ts +8 -3
- package/lib/components/ecl-multiselect/ecl-multiselect.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -1,6 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Component, EventEmitter, HostBinding, Input, Output, ViewChild } from '@angular/core';
|
|
3
|
-
import { coerceBoolean } from '@eui/base';
|
|
1
|
+
import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, booleanAttribute } from '@angular/core';
|
|
4
2
|
import { Subject } from 'rxjs';
|
|
5
3
|
import { v4 as uuidgen } from 'uuid';
|
|
6
4
|
import { ECLBaseDirective } from '../../ecl-base.directive';
|
|
@@ -37,8 +35,9 @@ export class EclMultiselectOptionComponent extends ECLBaseDirective {
|
|
|
37
35
|
set isChecked(value) {
|
|
38
36
|
this._checked = value;
|
|
39
37
|
}
|
|
40
|
-
constructor() {
|
|
38
|
+
constructor(renderer) {
|
|
41
39
|
super();
|
|
40
|
+
this.renderer = renderer;
|
|
42
41
|
this.keyword = '';
|
|
43
42
|
this.changes = new Subject();
|
|
44
43
|
this.disabled = false;
|
|
@@ -72,7 +71,7 @@ export class EclMultiselectOptionComponent extends ECLBaseDirective {
|
|
|
72
71
|
this.optionKeydown.emit(new EclMultiselectOptionKeydownEvent(this, evt));
|
|
73
72
|
}
|
|
74
73
|
onFocus() {
|
|
75
|
-
this.eclCheckboxInput.nativeElement.focus();
|
|
74
|
+
this.renderer.selectRootElement(this.eclCheckboxInput.nativeElement, true).focus();
|
|
76
75
|
}
|
|
77
76
|
show() {
|
|
78
77
|
this.display = 'flex';
|
|
@@ -88,26 +87,22 @@ export class EclMultiselectOptionComponent extends ECLBaseDirective {
|
|
|
88
87
|
createId() {
|
|
89
88
|
return uuidgen();
|
|
90
89
|
}
|
|
91
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: EclMultiselectOptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
92
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
90
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: EclMultiselectOptionComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
91
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0-next.5", type: EclMultiselectOptionComponent, selector: "div[eclMultiselectOption]", inputs: { value: "value", label: "label", disabled: ["disabled", "disabled", booleanAttribute], isChecked: "isChecked" }, outputs: { optionClick: "optionClick", optionKeydown: "optionKeydown" }, host: { properties: { "class.ecl-checkbox--disabled": "this.disabled", "attr.disabled": "this.disabled", "style.display": "this.display", "class": "this.cssClasses" } }, viewQueries: [{ propertyName: "eclCheckboxInput", first: true, predicate: ["checkboxInput"], descendants: true }], usesInheritance: true, usesOnChanges: true, hostDirectives: [{ directive: i1.EclCheckboxDirective }], ngImport: i0, template: "<input\n eclCheckboxInput\n type=\"checkbox\"\n [id]=\"id\"\n [value]=\"value\"\n (click)=\"onOptionClick()\"\n (keydown)=\"onOptionKeydown($event)\"\n [checked]=\"isChecked\"\n [disabled]=\"disabled\"\n #checkboxInput />\n<label [for]=\"id\" eclCheckboxLabel><span [innerHTML]=\"label | boldText: keyword\"></span></label>\n", dependencies: [{ kind: "component", type: i2.EclCheckboxLabelComponent, selector: "label[eclCheckboxLabel]", inputs: ["isInvalid", "isDisabled", "isRequired"] }, { kind: "directive", type: i3.EclCheckboxInputDirective, selector: "input[eclCheckboxInput]" }, { kind: "pipe", type: i4.BoldTextPipe, name: "boldText" }] }); }
|
|
93
92
|
}
|
|
94
|
-
__decorate([
|
|
95
|
-
coerceBoolean
|
|
96
|
-
], EclMultiselectOptionComponent.prototype, "disabled", void 0);
|
|
97
93
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: EclMultiselectOptionComponent, decorators: [{
|
|
98
94
|
type: Component,
|
|
99
95
|
args: [{ selector: 'div[eclMultiselectOption]', hostDirectives: [EclCheckboxDirective], template: "<input\n eclCheckboxInput\n type=\"checkbox\"\n [id]=\"id\"\n [value]=\"value\"\n (click)=\"onOptionClick()\"\n (keydown)=\"onOptionKeydown($event)\"\n [checked]=\"isChecked\"\n [disabled]=\"disabled\"\n #checkboxInput />\n<label [for]=\"id\" eclCheckboxLabel><span [innerHTML]=\"label | boldText: keyword\"></span></label>\n" }]
|
|
100
|
-
}], ctorParameters: () => [], propDecorators: { eclCheckboxInput: [{
|
|
96
|
+
}], ctorParameters: () => [{ type: i0.Renderer2 }], propDecorators: { eclCheckboxInput: [{
|
|
101
97
|
type: ViewChild,
|
|
102
98
|
args: ['checkboxInput']
|
|
103
99
|
}], value: [{
|
|
104
100
|
type: Input
|
|
105
101
|
}], label: [{
|
|
106
102
|
type: Input
|
|
107
|
-
}],
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
type: Input
|
|
103
|
+
}], disabled: [{
|
|
104
|
+
type: Input,
|
|
105
|
+
args: [{ transform: booleanAttribute }]
|
|
111
106
|
}, {
|
|
112
107
|
type: HostBinding,
|
|
113
108
|
args: ['class.ecl-checkbox--disabled']
|
|
@@ -127,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5",
|
|
|
127
122
|
}], isChecked: [{
|
|
128
123
|
type: Input
|
|
129
124
|
}] } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-multiselect-option.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/ecl-multiselect/ecl-multiselect-option/ecl-multiselect-option.component.ts","../../../../../../src/lib/components/ecl-multiselect/ecl-multiselect-option/ecl-multiselect-option.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostBinding, Input, OnChanges, OnDestroy, OnInit, Output,\n    Renderer2, ViewChild, booleanAttribute } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { v4 as uuidgen } from 'uuid';\nimport { EclMultiselectOption } from '../../../model/ecl-multiselect-option.model';\nimport { ECLBaseDirective } from '../../ecl-base.directive';\nimport { EclCheckboxDirective } from '../../ecl-checkbox';\n\nexport class EclMultiselectOptionClickEvent {\n    constructor(public multiselectOption: EclMultiselectOption) {}\n}\n\nexport class EclMultiselectOptionKeydownEvent {\n    constructor(\n        public multiselectOption: EclMultiselectOption,\n        public keyboardEvent: KeyboardEvent,\n    ) {}\n}\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'div[eclMultiselectOption]',\n    templateUrl: './ecl-multiselect-option.component.html',\n    hostDirectives: [EclCheckboxDirective],\n})\nexport class EclMultiselectOptionComponent extends ECLBaseDirective implements EclMultiselectOption, OnChanges, OnDestroy, OnInit {\n    @ViewChild('checkboxInput') eclCheckboxInput: ElementRef;\n\n    keyword = '';\n    @Input()\n    set value(value: string) {\n        this._value = value;\n    }\n\n    get value(): string {\n        return this._value;\n    }\n\n    @Input() label: string;\n    changes = new Subject();\n\n    @Input({ transform: booleanAttribute })\n    @HostBinding('class.ecl-checkbox--disabled')\n    @HostBinding('attr.disabled')\n    disabled = false;\n\n    @Output() optionClick = new EventEmitter<EclMultiselectOptionClickEvent>();\n    @Output() optionKeydown = new EventEmitter<EclMultiselectOptionKeydownEvent>();\n\n    @HostBinding('style.display') private display = 'flex';\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [super.getCssClasses('ecl-checkbox')].join(' ').trim();\n    }\n\n    @Input()\n    get isChecked(): boolean {\n        return this._checked;\n    }\n\n    set isChecked(value: boolean) {\n        this._checked = value;\n    }\n\n    private _id = '';\n    private _checked = false;\n    private _value = '';\n\n    constructor( private renderer: Renderer2 ) {\n        super();\n    }\n\n    get id(): string {\n        return this._id;\n    }\n\n    get isActive(): boolean {\n        return this.display === 'flex' && !this.disabled;\n    }\n\n    ngOnChanges(): void {\n        this.changes.next(this.label);\n    }\n\n    ngOnInit(): void {\n        this._id = this.createId();\n    }\n\n    ngOnDestroy(): void {\n        this.changes.complete();\n    }\n\n    onOptionClick(): void {\n        this.isChecked = !this.isChecked;\n        this.optionClick.emit(new EclMultiselectOptionClickEvent(this));\n    }\n\n    onOptionKeydown(evt: KeyboardEvent): void {\n        this.optionKeydown.emit(new EclMultiselectOptionKeydownEvent(this, evt));\n    }\n\n    onFocus(): void {\n        this.renderer.selectRootElement(this.eclCheckboxInput.nativeElement, true).focus();\n    }\n\n    show(): void {\n        this.display = 'flex';\n    }\n\n    hide(): void {\n        this.display = 'none';\n    }\n\n    highlightSearchText(keyword: string): void {\n        this.keyword = keyword;\n        const re = new RegExp(keyword, 'gi');\n        const res = this.label.replace(re, '<b>$&</b>');\n    }\n\n    private createId(): string {\n        return uuidgen();\n    }\n}\n","<input\n    eclCheckboxInput\n    type=\"checkbox\"\n    [id]=\"id\"\n    [value]=\"value\"\n    (click)=\"onOptionClick()\"\n    (keydown)=\"onOptionKeydown($event)\"\n    [checked]=\"isChecked\"\n    [disabled]=\"disabled\"\n    #checkboxInput />\n<label [for]=\"id\" eclCheckboxLabel><span [innerHTML]=\"label | boldText: keyword\"></span></label>\n"]}
|
|
@@ -1,8 +1,6 @@
|
|
|
1
|
-
import { __decorate } from "tslib";
|
|
2
1
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
3
|
-
import { Component, ContentChildren, EventEmitter, forwardRef, HostBinding, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import { booleanAttribute, Component, ContentChildren, EventEmitter, forwardRef, HostBinding, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
4
3
|
import { NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';
|
|
5
|
-
import { coerceBoolean } from '@eui/base';
|
|
6
4
|
import { Subject, takeUntil } from 'rxjs';
|
|
7
5
|
import { ECLBaseDirective } from '../ecl-base.directive';
|
|
8
6
|
import { EclMultiselectDropdownComponent } from './ecl-multiselect-dropdown/ecl-multiselect-dropdown.component';
|
|
@@ -39,17 +37,21 @@ export class EclMultiselectComponent extends ECLBaseDirective {
|
|
|
39
37
|
get eclPlaceholder() {
|
|
40
38
|
return this._eclPlaceholder;
|
|
41
39
|
}
|
|
42
|
-
constructor(injector, el, viewContainerRef, differs) {
|
|
40
|
+
constructor(injector, el, viewContainerRef, differs, renderer) {
|
|
43
41
|
super();
|
|
44
42
|
this.injector = injector;
|
|
45
43
|
this.el = el;
|
|
46
44
|
this.viewContainerRef = viewContainerRef;
|
|
47
45
|
this.differs = differs;
|
|
46
|
+
this.renderer = renderer;
|
|
48
47
|
this.ariaDescribedby = undefined;
|
|
49
48
|
this.ariaLabeledby = undefined;
|
|
50
49
|
this.id = undefined;
|
|
50
|
+
this.toggleLabel = undefined;
|
|
51
51
|
this.eclChange = new EventEmitter();
|
|
52
52
|
this.eclSize = 'm';
|
|
53
|
+
this.SELECT_CONTAINER_CLASS = 'ecl-select__container';
|
|
54
|
+
this.SELECT_CONTAINER_HIDDEN_CLASS = 'ecl-select__container--hidden';
|
|
53
55
|
this._disabled = false;
|
|
54
56
|
this._isInvalid = false;
|
|
55
57
|
this._eclPlaceholder = 'Select item';
|
|
@@ -84,12 +86,12 @@ export class EclMultiselectComponent extends ECLBaseDirective {
|
|
|
84
86
|
hideOriginalSelectComponent() {
|
|
85
87
|
this.hostParentEl.replaceChild(this.hostWrapperEl, this.hostEl);
|
|
86
88
|
this.hostWrapperEl.appendChild(this.hostEl);
|
|
87
|
-
this.hostWrapperEl.
|
|
89
|
+
this.renderer.addClass(this.hostWrapperEl, this.SELECT_CONTAINER_HIDDEN_CLASS);
|
|
88
90
|
}
|
|
89
91
|
createHostWrapperContainer() {
|
|
90
92
|
const wrapperContainer = document.createElement('div');
|
|
91
|
-
|
|
92
|
-
|
|
93
|
+
this.renderer.addClass(wrapperContainer, this.SELECT_CONTAINER_CLASS);
|
|
94
|
+
this.renderer.addClass(wrapperContainer, `${this.SELECT_CONTAINER_CLASS}--${this.eclSize}`);
|
|
93
95
|
return wrapperContainer;
|
|
94
96
|
}
|
|
95
97
|
getHostElement() {
|
|
@@ -112,6 +114,9 @@ export class EclMultiselectComponent extends ECLBaseDirective {
|
|
|
112
114
|
if (this.ariaDescribedby !== undefined) {
|
|
113
115
|
this.multiselectComponent.ariaDescribedby = this.ariaDescribedby;
|
|
114
116
|
}
|
|
117
|
+
if (this.toggleLabel !== undefined) {
|
|
118
|
+
this.multiselectComponent.toggleLabel = this.toggleLabel;
|
|
119
|
+
}
|
|
115
120
|
if (this.id !== undefined) {
|
|
116
121
|
this.multiselectComponent.id = this.id;
|
|
117
122
|
}
|
|
@@ -128,8 +133,8 @@ export class EclMultiselectComponent extends ECLBaseDirective {
|
|
|
128
133
|
this.multiselectComponent.multiOptionDirectives = this.eclOptionItems.toArray();
|
|
129
134
|
});
|
|
130
135
|
}
|
|
131
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: EclMultiselectComponent, deps: [{ token: i0.Injector }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.IterableDiffers }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
132
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
136
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: EclMultiselectComponent, deps: [{ token: i0.Injector }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.IterableDiffers }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
137
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0-next.5", type: EclMultiselectComponent, selector: "select[eclMultiselect]", inputs: { ariaDescribedby: "ariaDescribedby", ariaLabeledby: "ariaLabeledby", id: "id", toggleLabel: "toggleLabel", isInvalid: ["isInvalid", "isInvalid", booleanAttribute], disabled: "disabled", eclPlaceholder: "eclPlaceholder", eclSize: "eclSize" }, outputs: { eclChange: "eclChange" }, host: { properties: { "attr.disabled": "this.disabled", "class": "this.cssClasses" } }, providers: [
|
|
133
138
|
{
|
|
134
139
|
provide: NG_VALUE_ACCESSOR,
|
|
135
140
|
useExisting: forwardRef(() => EclMultiselectComponent),
|
|
@@ -137,9 +142,6 @@ export class EclMultiselectComponent extends ECLBaseDirective {
|
|
|
137
142
|
},
|
|
138
143
|
], queries: [{ propertyName: "eclOptionItems", predicate: i0.forwardRef(() => EclMultiselectOptionDirective) }], usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>\n", encapsulation: i0.ViewEncapsulation.None }); }
|
|
139
144
|
}
|
|
140
|
-
__decorate([
|
|
141
|
-
coerceBoolean
|
|
142
|
-
], EclMultiselectComponent.prototype, "isInvalid", null);
|
|
143
145
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: EclMultiselectComponent, decorators: [{
|
|
144
146
|
type: Component,
|
|
145
147
|
args: [{ selector: 'select[eclMultiselect]', encapsulation: ViewEncapsulation.None, providers: [
|
|
@@ -149,7 +151,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5",
|
|
|
149
151
|
multi: true,
|
|
150
152
|
},
|
|
151
153
|
], template: "<ng-content></ng-content>\n" }]
|
|
152
|
-
}], ctorParameters: () => [{ type: i0.Injector }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.IterableDiffers }], propDecorators: { eclOptionItems: [{
|
|
154
|
+
}], ctorParameters: () => [{ type: i0.Injector }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.IterableDiffers }, { type: i0.Renderer2 }], propDecorators: { eclOptionItems: [{
|
|
153
155
|
type: ContentChildren,
|
|
154
156
|
args: [forwardRef(() => EclMultiselectOptionDirective)]
|
|
155
157
|
}], ariaDescribedby: [{
|
|
@@ -158,8 +160,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5",
|
|
|
158
160
|
type: Input
|
|
159
161
|
}], id: [{
|
|
160
162
|
type: Input
|
|
161
|
-
}],
|
|
163
|
+
}], toggleLabel: [{
|
|
162
164
|
type: Input
|
|
165
|
+
}], isInvalid: [{
|
|
166
|
+
type: Input,
|
|
167
|
+
args: [{ transform: booleanAttribute }]
|
|
163
168
|
}], disabled: [{
|
|
164
169
|
type: Input
|
|
165
170
|
}, {
|
|
@@ -175,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5",
|
|
|
175
180
|
}], eclSize: [{
|
|
176
181
|
type: Input
|
|
177
182
|
}] } });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-multiselect.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-multiselect/ecl-multiselect.component.ts","../../../../../src/lib/components/ecl-multiselect/ecl-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    AfterContentInit,\n    Component,\n    ContentChildren,\n    DoCheck,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Injector,\n    Input,\n    IterableDiffer,\n    IterableDiffers,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    ViewContainerRef,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\nimport { coerceBoolean } from '@eui/base';\nimport { Subject, takeUntil } from 'rxjs';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { EclMultiselectDropdownComponent } from './ecl-multiselect-dropdown/ecl-multiselect-dropdown.component';\nimport { EclMultiselectOptionDirective } from './ecl-multiselect-option.directive';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'select[eclMultiselect]',\n    templateUrl: 'ecl-multiselect.component.html',\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => EclMultiselectComponent),\n            multi: true,\n        },\n    ],\n})\nexport class EclMultiselectComponent extends ECLBaseDirective implements DoCheck, OnInit, OnDestroy, AfterContentInit {\n    @ContentChildren(forwardRef(() => EclMultiselectOptionDirective)) eclOptionItems: QueryList<EclMultiselectOptionDirective>;\n\n    @Input() ariaDescribedby: string | undefined = undefined;\n    @Input() ariaLabeledby: string | undefined = undefined;\n    @Input() id: string | undefined = undefined;\n    @coerceBoolean\n    @Input()\n    get isInvalid(): boolean | undefined {\n        return this._isInvalid;\n    }\n    set isInvalid(value: boolean | undefined) {\n        this._isInvalid = value;\n        if (this.multiselectComponent) {\n            this.multiselectComponent.isInvalid = value;\n        }\n    }\n    @Input()\n    @HostBinding('attr.disabled')\n    set disabled(value: BooleanInput) {\n        if (this.multiselectComponent) {\n            this.multiselectComponent.disabled = coerceBooleanProperty(value);\n        }\n        this._disabled = coerceBooleanProperty(value);\n    }\n    get disabled(): boolean | undefined {\n        return this._disabled || undefined;\n    }\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [super.getCssClasses('ecl-select')].join(' ').trim();\n    }\n    @Output() eclChange = new EventEmitter<string[]>();\n    @Input()\n    set eclPlaceholder(value: string) {\n        this._eclPlaceholder = value;\n        if (this.multiselectComponent) {\n            this.multiselectComponent.mainInputPlaceholder = value;\n        }\n    }\n    get eclPlaceholder(): string {\n        return this._eclPlaceholder;\n    }\n    @Input() eclSize = 'm';\n    private _disabled = false;\n    private _isInvalid = false;\n    private _eclPlaceholder = 'Select item';\n    private differ: IterableDiffer<EclMultiselectOptionDirective>;\n    private multiselectComponent: EclMultiselectDropdownComponent;\n    private hostEl: HTMLSelectElement;\n    private hostParentEl: HTMLElement;\n    private hostWrapperEl: HTMLElement;\n    private multiselectComponentHtml: HTMLDivElement;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        public injector: Injector,\n        private el: ElementRef,\n        private viewContainerRef: ViewContainerRef,\n        private differs: IterableDiffers,\n    ) {\n        super();\n        this.differ = this.differs.find([]).create();\n    }\n\n    ngDoCheck(): void {\n        const diff = this.differ.diff(this.eclOptionItems);\n\n        if (diff) {\n            if (this.multiselectComponent) {\n                this.multiselectComponent.multiOptionDirectives = this.eclOptionItems.toArray();\n            }\n        }\n    }\n\n    ngOnInit(): void {\n        this.hostEl = this.getHostElement();\n        this.hostParentEl = this.getHostParentElement(this.hostEl);\n        this.hostWrapperEl = this.createHostWrapperContainer();\n        this.multiselectComponentHtml = this.createMultiselectComponent();\n    }\n\n    ngAfterContentInit(): void {\n        this.attachOptions();\n        if (this.hostParentEl != null) {\n            this.hideOriginalSelectComponent();\n            this.hostParentEl.appendChild(this.multiselectComponentHtml);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    private hideOriginalSelectComponent(): void {\n        this.hostParentEl.replaceChild(this.hostWrapperEl, this.hostEl);\n        this.hostWrapperEl.appendChild(this.hostEl);\n        this.hostWrapperEl.classList.add('ecl-select__container--hidden');\n    }\n\n    private createHostWrapperContainer(): HTMLElement {\n        const wrapperContainer = document.createElement('div');\n        wrapperContainer.classList.add('ecl-select__container');\n        wrapperContainer.classList.add(`ecl-select__container--${this.eclSize}`);\n        return wrapperContainer;\n    }\n\n    private getHostElement(): HTMLSelectElement {\n        return this.el.nativeElement;\n    }\n\n    private getHostParentElement(hostEl: HTMLSelectElement): HTMLElement {\n        return hostEl.parentElement;\n    }\n\n    private createMultiselectComponent(): HTMLDivElement {\n        const ngControl = this.injector.get(NgControl, undefined, { optional: true });\n        const multiselect = this.viewContainerRef.createComponent(EclMultiselectDropdownComponent);\n        this.multiselectComponent = multiselect.instance;\n        this.multiselectComponent.eclChange.pipe(takeUntil(this.destroy$)).subscribe((evt) => {\n            this.eclChange.emit(evt);\n        });\n        this.multiselectComponent.mainInputPlaceholder = this.eclPlaceholder;\n\n        if (this.ariaLabeledby !== undefined) {\n            this.multiselectComponent.ariaLabeledby = this.ariaLabeledby;\n        }\n        if (this.ariaDescribedby !== undefined) {\n            this.multiselectComponent.ariaDescribedby = this.ariaDescribedby;\n        }\n        if (this.id !== undefined) {\n            this.multiselectComponent.id = this.id;\n        }\n        this.multiselectComponent.eclSize = this.eclSize;\n        if (ngControl) {\n            ngControl.valueAccessor = this.multiselectComponent;\n        }\n        multiselect.instance.disabled = this.disabled;\n        multiselect.instance.isInvalid = this.isInvalid;\n        return (multiselect.location as ElementRef<HTMLDivElement>).nativeElement;\n    }\n\n    private attachOptions(): void {\n        setTimeout(() => {\n            this.multiselectComponent.multiOptionDirectives = this.eclOptionItems.toArray();\n        });\n    }\n}\n","<ng-content></ng-content>\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-multiselect.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-multiselect/ecl-multiselect.component.ts","../../../../../src/lib/components/ecl-multiselect/ecl-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    AfterContentInit,\n    booleanAttribute,\n    Component,\n    ContentChildren,\n    DoCheck,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Injector,\n    Input,\n    IterableDiffer,\n    IterableDiffers,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    Renderer2,\n    ViewContainerRef,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\nimport { Subject, takeUntil } from 'rxjs';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { EclMultiselectDropdownComponent } from './ecl-multiselect-dropdown/ecl-multiselect-dropdown.component';\nimport { EclMultiselectOptionDirective } from './ecl-multiselect-option.directive';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'select[eclMultiselect]',\n    templateUrl: 'ecl-multiselect.component.html',\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => EclMultiselectComponent),\n            multi: true,\n        },\n    ],\n})\nexport class EclMultiselectComponent extends ECLBaseDirective implements DoCheck, OnInit, OnDestroy, AfterContentInit {\n    @ContentChildren(forwardRef(() => EclMultiselectOptionDirective)) eclOptionItems: QueryList<EclMultiselectOptionDirective>;\n\n    @Input() ariaDescribedby: string | undefined = undefined;\n    @Input() ariaLabeledby: string | undefined = undefined;\n    @Input() id: string | undefined = undefined;\n    @Input() toggleLabel: string | undefined = undefined;\n    @Input({ transform : booleanAttribute })\n    get isInvalid(): boolean | undefined {\n        return this._isInvalid;\n    }\n    set isInvalid(value: boolean | undefined) {\n        this._isInvalid = value;\n        if (this.multiselectComponent) {\n            this.multiselectComponent.isInvalid = value;\n        }\n    }\n    @Input()\n    @HostBinding('attr.disabled')\n    set disabled(value: BooleanInput) {\n        if (this.multiselectComponent) {\n            this.multiselectComponent.disabled = coerceBooleanProperty(value);\n        }\n        this._disabled = coerceBooleanProperty(value);\n    }\n    get disabled(): boolean | undefined {\n        return this._disabled || undefined;\n    }\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [super.getCssClasses('ecl-select')].join(' ').trim();\n    }\n    @Output() eclChange = new EventEmitter<string[]>();\n    @Input()\n    set eclPlaceholder(value: string) {\n        this._eclPlaceholder = value;\n        if (this.multiselectComponent) {\n            this.multiselectComponent.mainInputPlaceholder = value;\n        }\n    }\n    get eclPlaceholder(): string {\n        return this._eclPlaceholder;\n    }\n    @Input() eclSize = 'm';\n    private readonly SELECT_CONTAINER_CLASS = 'ecl-select__container';\n    private readonly SELECT_CONTAINER_HIDDEN_CLASS = 'ecl-select__container--hidden';\n    private _disabled = false;\n    private _isInvalid = false;\n    private _eclPlaceholder = 'Select item';\n    private differ: IterableDiffer<EclMultiselectOptionDirective>;\n    private multiselectComponent: EclMultiselectDropdownComponent;\n    private hostEl: HTMLSelectElement;\n    private hostParentEl: HTMLElement;\n    private hostWrapperEl: HTMLElement;\n    private multiselectComponentHtml: HTMLDivElement;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        public injector: Injector,\n        private el: ElementRef,\n        private viewContainerRef: ViewContainerRef,\n        private differs: IterableDiffers,\n        private renderer: Renderer2,\n    ) {\n        super();\n        this.differ = this.differs.find([]).create();\n    }\n\n    ngDoCheck(): void {\n        const diff = this.differ.diff(this.eclOptionItems);\n\n        if (diff) {\n            if (this.multiselectComponent) {\n                this.multiselectComponent.multiOptionDirectives = this.eclOptionItems.toArray();\n            }\n        }\n    }\n\n    ngOnInit(): void {\n        this.hostEl = this.getHostElement();\n        this.hostParentEl = this.getHostParentElement(this.hostEl);\n        this.hostWrapperEl = this.createHostWrapperContainer();\n        this.multiselectComponentHtml = this.createMultiselectComponent();\n    }\n\n    ngAfterContentInit(): void {\n        this.attachOptions();\n        if (this.hostParentEl != null) {\n            this.hideOriginalSelectComponent();\n            this.hostParentEl.appendChild(this.multiselectComponentHtml);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    private hideOriginalSelectComponent(): void {\n        this.hostParentEl.replaceChild(this.hostWrapperEl, this.hostEl);\n        this.hostWrapperEl.appendChild(this.hostEl);\n            this.renderer.addClass(this.hostWrapperEl, this.SELECT_CONTAINER_HIDDEN_CLASS);\n    }\n\n    private createHostWrapperContainer(): HTMLElement {\n        const wrapperContainer = document.createElement('div');\n        this.renderer.addClass(wrapperContainer,this.SELECT_CONTAINER_CLASS);\n        this.renderer.addClass(wrapperContainer,`${this.SELECT_CONTAINER_CLASS}--${this.eclSize}`);\n        return wrapperContainer;\n    }\n\n    private getHostElement(): HTMLSelectElement {\n        return this.el.nativeElement;\n    }\n\n    private getHostParentElement(hostEl: HTMLSelectElement): HTMLElement {\n        return hostEl.parentElement;\n    }\n\n    private createMultiselectComponent(): HTMLDivElement {\n        const ngControl = this.injector.get(NgControl, undefined, { optional: true });\n        const multiselect = this.viewContainerRef.createComponent(EclMultiselectDropdownComponent);\n        this.multiselectComponent = multiselect.instance;\n        this.multiselectComponent.eclChange.pipe(takeUntil(this.destroy$)).subscribe((evt) => {\n            this.eclChange.emit(evt);\n        });\n        this.multiselectComponent.mainInputPlaceholder = this.eclPlaceholder;\n\n        if (this.ariaLabeledby !== undefined) {\n            this.multiselectComponent.ariaLabeledby = this.ariaLabeledby;\n        }\n        if (this.ariaDescribedby !== undefined) {\n            this.multiselectComponent.ariaDescribedby = this.ariaDescribedby;\n        }\n        if (this.toggleLabel !== undefined) {\n            this.multiselectComponent.toggleLabel = this.toggleLabel;\n        }\n        if (this.id !== undefined) {\n            this.multiselectComponent.id = this.id;\n        }\n        this.multiselectComponent.eclSize = this.eclSize;\n        if (ngControl) {\n            ngControl.valueAccessor = this.multiselectComponent;\n        }\n        multiselect.instance.disabled = this.disabled;\n        multiselect.instance.isInvalid = this.isInvalid;\n        return (multiselect.location as ElementRef<HTMLDivElement>).nativeElement;\n    }\n\n    private attachOptions(): void {\n        setTimeout(() => {\n            this.multiselectComponent.multiOptionDirectives = this.eclOptionItems.toArray();\n        });\n    }\n}\n","<ng-content></ng-content>\n"]}
|