@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.
Files changed (45) hide show
  1. package/assets/i18n-ecl/bg.json +1 -0
  2. package/assets/i18n-ecl/cs.json +1 -0
  3. package/assets/i18n-ecl/da.json +1 -0
  4. package/assets/i18n-ecl/de.json +1 -0
  5. package/assets/i18n-ecl/el.json +1 -0
  6. package/assets/i18n-ecl/en.json +1 -0
  7. package/assets/i18n-ecl/es.json +1 -0
  8. package/assets/i18n-ecl/et.json +1 -0
  9. package/assets/i18n-ecl/fi.json +1 -0
  10. package/assets/i18n-ecl/fr.json +1 -0
  11. package/assets/i18n-ecl/ga.json +1 -0
  12. package/assets/i18n-ecl/hr.json +1 -0
  13. package/assets/i18n-ecl/hu.json +1 -0
  14. package/assets/i18n-ecl/it.json +1 -0
  15. package/assets/i18n-ecl/lt.json +1 -0
  16. package/assets/i18n-ecl/lv.json +1 -0
  17. package/assets/i18n-ecl/mt.json +1 -0
  18. package/assets/i18n-ecl/nl.json +1 -0
  19. package/assets/i18n-ecl/pl.json +1 -0
  20. package/assets/i18n-ecl/pt.json +1 -0
  21. package/assets/i18n-ecl/ro.json +1 -0
  22. package/assets/i18n-ecl/sk.json +1 -0
  23. package/assets/i18n-ecl/sl.json +1 -0
  24. package/assets/i18n-ecl/sv.json +1 -0
  25. package/docs/components/EclMultiselectComponent.html +37 -1
  26. package/docs/components/EclMultiselectDropdownComponent.html +30 -1
  27. package/docs/components/EclMultiselectInputComponent.html +134 -2
  28. package/docs/components/EclMultiselectOptionComponent.html +32 -2
  29. package/docs/dependencies.html +1 -1
  30. package/docs/js/search/search_index.js +2 -2
  31. package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-dropdown/ecl-multiselect-dropdown.component.mjs +21 -28
  32. package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-input/ecl-multiselect-input.component.mjs +35 -21
  33. package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-option/ecl-multiselect-option.component.mjs +11 -16
  34. package/esm2022/lib/components/ecl-multiselect/ecl-multiselect.component.mjs +20 -15
  35. package/fesm2022/eui-ecl.mjs +372 -307
  36. package/fesm2022/eui-ecl.mjs.map +3 -3
  37. package/lib/components/ecl-multiselect/ecl-multiselect-dropdown/ecl-multiselect-dropdown.component.d.ts +3 -0
  38. package/lib/components/ecl-multiselect/ecl-multiselect-dropdown/ecl-multiselect-dropdown.component.d.ts.map +1 -1
  39. package/lib/components/ecl-multiselect/ecl-multiselect-input/ecl-multiselect-input.component.d.ts +13 -3
  40. package/lib/components/ecl-multiselect/ecl-multiselect-input/ecl-multiselect-input.component.d.ts.map +1 -1
  41. package/lib/components/ecl-multiselect/ecl-multiselect-option/ecl-multiselect-option.component.d.ts +5 -3
  42. package/lib/components/ecl-multiselect/ecl-multiselect-option/ecl-multiselect-option.component.d.ts.map +1 -1
  43. package/lib/components/ecl-multiselect/ecl-multiselect.component.d.ts +8 -3
  44. package/lib/components/ecl-multiselect/ecl-multiselect.component.d.ts.map +1 -1
  45. package/package.json +1 -1
@@ -1,6 +1,4 @@
1
- import { __decorate } from "tslib";
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: "14.0.0", version: "18.0.0-next.5", type: EclMultiselectOptionComponent, selector: "div[eclMultiselectOption]", inputs: { value: "value", label: "label", disabled: "disabled", 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" }] }); }
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
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
109
- disabled: [{
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,{"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, ViewChild } from '@angular/core';\nimport { coerceBoolean } from '@eui/base';\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    @coerceBoolean\n    @Input()\n    @HostBinding('class.ecl-checkbox--disabled')\n    @HostBinding('attr.disabled')\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    disabled: boolean | any = 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() {\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.eclCheckboxInput.nativeElement.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"]}
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.classList.add('ecl-select__container--hidden');
89
+ this.renderer.addClass(this.hostWrapperEl, this.SELECT_CONTAINER_HIDDEN_CLASS);
88
90
  }
89
91
  createHostWrapperContainer() {
90
92
  const wrapperContainer = document.createElement('div');
91
- wrapperContainer.classList.add('ecl-select__container');
92
- wrapperContainer.classList.add(`ecl-select__container--${this.eclSize}`);
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: "14.0.0", version: "18.0.0-next.5", type: EclMultiselectComponent, selector: "select[eclMultiselect]", inputs: { ariaDescribedby: "ariaDescribedby", ariaLabeledby: "ariaLabeledby", id: "id", isInvalid: "isInvalid", disabled: "disabled", eclPlaceholder: "eclPlaceholder", eclSize: "eclSize" }, outputs: { eclChange: "eclChange" }, host: { properties: { "attr.disabled": "this.disabled", "class": "this.cssClasses" } }, providers: [
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
- }], isInvalid: [{
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"]}