@eui/components 18.0.0-next.29 → 18.0.0-next.30

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 (178) hide show
  1. package/docs/classes/EuiMessageBoxConfig.html +1 -1
  2. package/docs/components/EuiAlertComponent.html +1 -1
  3. package/docs/components/EuiButtonComponent.html +1 -1
  4. package/docs/components/EuiDialogComponent.html +96 -687
  5. package/docs/components/EuiDialogContainerComponent.html +1 -1
  6. package/docs/components/EuiMenuItemComponent.html +1 -1
  7. package/docs/components/EuiMessageBoxComponent.html +123 -1227
  8. package/docs/components/EuiPopoverComponent.html +81 -995
  9. package/docs/components/EuiTabComponent.html +88 -1004
  10. package/docs/components/EuiTabContentComponent.html +5 -78
  11. package/docs/components/EuiTableComponent.html +586 -2166
  12. package/docs/components/EuiTableFilterComponent.html +122 -787
  13. package/docs/components/EuiTableSelectableHeaderComponent.html +11 -141
  14. package/docs/components/EuiTableSelectableRowComponent.html +11 -125
  15. package/docs/components/EuiTableSortableColComponent.html +23 -263
  16. package/docs/components/EuiTabsComponent.html +21 -265
  17. package/docs/dependencies.html +1 -1
  18. package/docs/interfaces/EuiDialogInterface.html +2 -2
  19. package/docs/js/menu-wc.js +6 -6
  20. package/docs/js/menu-wc_es5.js +1 -1
  21. package/docs/js/search/search_index.js +2 -2
  22. package/esm2022/directives/eui-tooltip/container/eui-tooltip-container.component.mjs +2 -2
  23. package/esm2022/eui-alert/eui-alert.component.mjs +4 -3
  24. package/esm2022/eui-avatar/eui-avatar.component.mjs +2 -2
  25. package/esm2022/eui-badge/eui-badge.component.mjs +2 -2
  26. package/esm2022/eui-block-content/eui-block-content.component.mjs +2 -2
  27. package/esm2022/eui-button/eui-button.component.mjs +4 -5
  28. package/esm2022/eui-button-group/eui-button-group.component.mjs +1 -1
  29. package/esm2022/eui-button-v2/eui-button-v2.component.mjs +2 -2
  30. package/esm2022/eui-card/eui-card.component.mjs +2 -2
  31. package/esm2022/eui-chip/eui-chip.component.mjs +2 -2
  32. package/esm2022/eui-chip-list/eui-chip-list.component.mjs +2 -6
  33. package/esm2022/eui-dialog/container/eui-dialog-container.component.mjs +10 -10
  34. package/esm2022/eui-dialog/eui-dialog.component.mjs +29 -33
  35. package/esm2022/eui-dialog/models/eui-dialog.config.mjs +1 -1
  36. package/esm2022/eui-discussion-thread/eui-discussion-thread.component.mjs +2 -2
  37. package/esm2022/eui-ecl-date-block/eui-ecl-date-block.component.mjs +2 -2
  38. package/esm2022/eui-ecl-label/eui-ecl-label.component.mjs +2 -2
  39. package/esm2022/eui-feedback-message/eui-feedback-message.component.mjs +2 -2
  40. package/esm2022/eui-fieldset/eui-fieldset.component.mjs +2 -2
  41. package/esm2022/eui-file-upload/eui-file-upload.component.mjs +2 -2
  42. package/esm2022/eui-growl/eui-growl.component.mjs +2 -2
  43. package/esm2022/eui-input-checkbox/eui-input-checkbox.component.mjs +2 -2
  44. package/esm2022/eui-label/eui-label.component.mjs +2 -2
  45. package/esm2022/eui-language-selector/language-selector.component.mjs +2 -2
  46. package/esm2022/eui-list/eui-list-item/eui-list-item.component.mjs +2 -2
  47. package/esm2022/eui-list/eui-list.component.mjs +2 -2
  48. package/esm2022/eui-menu/eui-menu-item.component.mjs +4 -4
  49. package/esm2022/eui-menu/eui-menu.component.mjs +2 -2
  50. package/esm2022/eui-message-box/eui-message-box.component.mjs +51 -110
  51. package/esm2022/eui-message-box/models/eui-message-box.config.mjs +1 -1
  52. package/esm2022/eui-page/eui-page.component.mjs +2 -2
  53. package/esm2022/eui-popover/eui-popover.component.mjs +50 -72
  54. package/esm2022/eui-progress-bar/eui-progress-bar.component.mjs +2 -2
  55. package/esm2022/eui-progress-circle/eui-progress-circle.component.mjs +2 -2
  56. package/esm2022/eui-table/eui-table.component.mjs +82 -160
  57. package/esm2022/eui-table/filter/eui-table-filter.component.mjs +28 -32
  58. package/esm2022/eui-table/selectable-header/eui-table-selectable-header.component.mjs +12 -25
  59. package/esm2022/eui-table/selectable-row/eui-table-selectable-row.component.mjs +12 -25
  60. package/esm2022/eui-table/sortable-col/eui-table-sortable-col.component.mjs +20 -43
  61. package/esm2022/eui-tabs/eui-tab/eui-tab.component.mjs +44 -59
  62. package/esm2022/eui-tabs/eui-tab-content/eui-tab-content.component.mjs +6 -12
  63. package/esm2022/eui-tabs/eui-tabs.component.mjs +22 -45
  64. package/esm2022/eui-timebar/eui-timebar.component.mjs +2 -2
  65. package/esm2022/eui-timepicker/eui-timepicker.component.mjs +2 -2
  66. package/esm2022/eui-tree-list/eui-tree-list.component.mjs +2 -2
  67. package/esm2022/eui-wizard/eui-wizard-step.component.mjs +2 -2
  68. package/esm2022/eui-wizard/eui-wizard.component.mjs +2 -2
  69. package/esm2022/externals/eui-editor/eui-editor.component.mjs +2 -2
  70. package/esm2022/layout/eui-app/eui-app-toolbar/toolbar.component.mjs +2 -2
  71. package/esm2022/layout/eui-app/eui-app-top-message/top-message.component.mjs +2 -2
  72. package/esm2022/layout/eui-footer/footer.component.mjs +2 -2
  73. package/esm2022/layout/eui-notifications/eui-notifications.component.mjs +2 -2
  74. package/esm2022/layout/eui-notifications-v2/eui-notifications.component.mjs +2 -2
  75. package/esm2022/layout/eui-search/search.component.mjs +2 -2
  76. package/esm2022/layout/eui-toolbar/toolbar.component.mjs +2 -2
  77. package/esm2022/layout/eui-user-profile/user-profile.component.mjs +2 -2
  78. package/esm2022/shared/base/base-states.directive.mjs +2 -1
  79. package/eui-alert/eui-alert.component.d.ts.map +1 -1
  80. package/eui-button/eui-button.component.d.ts.map +1 -1
  81. package/eui-button-group/eui-button-group.component.d.ts.map +1 -1
  82. package/eui-chip-list/eui-chip-list.component.d.ts.map +1 -1
  83. package/eui-dialog/eui-dialog.component.d.ts +11 -6
  84. package/eui-dialog/eui-dialog.component.d.ts.map +1 -1
  85. package/eui-dialog/models/eui-dialog.config.d.ts +1 -1
  86. package/eui-dialog/models/eui-dialog.config.d.ts.map +1 -1
  87. package/eui-menu/eui-menu-item.component.d.ts.map +1 -1
  88. package/eui-message-box/eui-message-box.component.d.ts +26 -42
  89. package/eui-message-box/eui-message-box.component.d.ts.map +1 -1
  90. package/eui-message-box/models/eui-message-box.config.d.ts +1 -1
  91. package/eui-message-box/models/eui-message-box.config.d.ts.map +1 -1
  92. package/eui-popover/eui-popover.component.d.ts +18 -21
  93. package/eui-popover/eui-popover.component.d.ts.map +1 -1
  94. package/eui-table/eui-table.component.d.ts +36 -51
  95. package/eui-table/eui-table.component.d.ts.map +1 -1
  96. package/eui-table/filter/eui-table-filter.component.d.ts +9 -9
  97. package/eui-table/filter/eui-table-filter.component.d.ts.map +1 -1
  98. package/eui-table/selectable-header/eui-table-selectable-header.component.d.ts +4 -7
  99. package/eui-table/selectable-header/eui-table-selectable-header.component.d.ts.map +1 -1
  100. package/eui-table/selectable-row/eui-table-selectable-row.component.d.ts +4 -7
  101. package/eui-table/selectable-row/eui-table-selectable-row.component.d.ts.map +1 -1
  102. package/eui-table/sortable-col/eui-table-sortable-col.component.d.ts +10 -16
  103. package/eui-table/sortable-col/eui-table-sortable-col.component.d.ts.map +1 -1
  104. package/eui-tabs/eui-tab/eui-tab.component.d.ts +18 -23
  105. package/eui-tabs/eui-tab/eui-tab.component.d.ts.map +1 -1
  106. package/eui-tabs/eui-tab-content/eui-tab-content.component.d.ts +2 -4
  107. package/eui-tabs/eui-tab-content/eui-tab-content.component.d.ts.map +1 -1
  108. package/eui-tabs/eui-tabs.component.d.ts +8 -13
  109. package/eui-tabs/eui-tabs.component.d.ts.map +1 -1
  110. package/fesm2022/eui-components-directives.mjs +2 -2
  111. package/fesm2022/eui-components-eui-alert.mjs +11 -10
  112. package/fesm2022/eui-components-eui-alert.mjs.map +2 -2
  113. package/fesm2022/eui-components-eui-avatar.mjs +2 -2
  114. package/fesm2022/eui-components-eui-badge.mjs +2 -2
  115. package/fesm2022/eui-components-eui-badge.mjs.map +1 -1
  116. package/fesm2022/eui-components-eui-block-content.mjs +2 -2
  117. package/fesm2022/eui-components-eui-block-content.mjs.map +1 -1
  118. package/fesm2022/eui-components-eui-button-group.mjs.map +1 -1
  119. package/fesm2022/eui-components-eui-button-v2.mjs +2 -2
  120. package/fesm2022/eui-components-eui-button.mjs +3 -4
  121. package/fesm2022/eui-components-eui-button.mjs.map +2 -2
  122. package/fesm2022/eui-components-eui-card.mjs +2 -2
  123. package/fesm2022/eui-components-eui-card.mjs.map +1 -1
  124. package/fesm2022/eui-components-eui-chip-list.mjs +1 -5
  125. package/fesm2022/eui-components-eui-chip-list.mjs.map +2 -2
  126. package/fesm2022/eui-components-eui-chip.mjs +2 -2
  127. package/fesm2022/eui-components-eui-chip.mjs.map +1 -1
  128. package/fesm2022/eui-components-eui-dialog.mjs +236 -212
  129. package/fesm2022/eui-components-eui-dialog.mjs.map +2 -2
  130. package/fesm2022/eui-components-eui-discussion-thread.mjs +2 -2
  131. package/fesm2022/eui-components-eui-discussion-thread.mjs.map +1 -1
  132. package/fesm2022/eui-components-eui-ecl-date-block.mjs +2 -2
  133. package/fesm2022/eui-components-eui-ecl-date-block.mjs.map +1 -1
  134. package/fesm2022/eui-components-eui-ecl-label.mjs +2 -2
  135. package/fesm2022/eui-components-eui-ecl-label.mjs.map +1 -1
  136. package/fesm2022/eui-components-eui-feedback-message.mjs +2 -2
  137. package/fesm2022/eui-components-eui-fieldset.mjs +2 -2
  138. package/fesm2022/eui-components-eui-file-upload.mjs +2 -2
  139. package/fesm2022/eui-components-eui-file-upload.mjs.map +1 -1
  140. package/fesm2022/eui-components-eui-growl.mjs +2 -2
  141. package/fesm2022/eui-components-eui-input-checkbox.mjs +2 -2
  142. package/fesm2022/eui-components-eui-input-checkbox.mjs.map +1 -1
  143. package/fesm2022/eui-components-eui-label.mjs +2 -2
  144. package/fesm2022/eui-components-eui-language-selector.mjs +2 -2
  145. package/fesm2022/eui-components-eui-language-selector.mjs.map +1 -1
  146. package/fesm2022/eui-components-eui-list.mjs +4 -4
  147. package/fesm2022/eui-components-eui-menu.mjs +23 -27
  148. package/fesm2022/eui-components-eui-menu.mjs.map +2 -2
  149. package/fesm2022/eui-components-eui-message-box.mjs +49 -105
  150. package/fesm2022/eui-components-eui-message-box.mjs.map +2 -2
  151. package/fesm2022/eui-components-eui-page.mjs +2 -2
  152. package/fesm2022/eui-components-eui-page.mjs.map +1 -1
  153. package/fesm2022/eui-components-eui-popover.mjs +49 -150
  154. package/fesm2022/eui-components-eui-popover.mjs.map +2 -2
  155. package/fesm2022/eui-components-eui-progress-bar.mjs +2 -2
  156. package/fesm2022/eui-components-eui-progress-bar.mjs.map +1 -1
  157. package/fesm2022/eui-components-eui-progress-circle.mjs +2 -2
  158. package/fesm2022/eui-components-eui-progress-circle.mjs.map +1 -1
  159. package/fesm2022/eui-components-eui-table.mjs +254 -418
  160. package/fesm2022/eui-components-eui-table.mjs.map +3 -3
  161. package/fesm2022/eui-components-eui-tabs.mjs +72 -116
  162. package/fesm2022/eui-components-eui-tabs.mjs.map +3 -3
  163. package/fesm2022/eui-components-eui-timebar.mjs +2 -2
  164. package/fesm2022/eui-components-eui-timebar.mjs.map +1 -1
  165. package/fesm2022/eui-components-eui-timepicker.mjs +2 -2
  166. package/fesm2022/eui-components-eui-timepicker.mjs.map +1 -1
  167. package/fesm2022/eui-components-eui-tree-list.mjs +2 -2
  168. package/fesm2022/eui-components-eui-tree-list.mjs.map +1 -1
  169. package/fesm2022/eui-components-eui-wizard.mjs +4 -4
  170. package/fesm2022/eui-components-eui-wizard.mjs.map +1 -1
  171. package/fesm2022/eui-components-externals-eui-editor.mjs +2 -2
  172. package/fesm2022/eui-components-externals-eui-editor.mjs.map +1 -1
  173. package/fesm2022/eui-components-layout.mjs +16 -16
  174. package/fesm2022/eui-components-layout.mjs.map +1 -1
  175. package/fesm2022/eui-components-shared.mjs +1 -1
  176. package/fesm2022/eui-components-shared.mjs.map +2 -2
  177. package/package.json +3 -3
  178. package/shared/base/base-states.directive.d.ts.map +1 -1
@@ -1,38 +1,28 @@
1
- import { Component, Input, Output, EventEmitter, HostBinding, ViewChild, ElementRef, ViewEncapsulation, } from '@angular/core';
1
+ import { Component, Input, Output, EventEmitter, HostBinding, ViewChild, ElementRef, ViewEncapsulation, booleanAttribute } from '@angular/core';
2
2
  import { FormGroup, FormControl } from '@angular/forms';
3
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
4
- import { Subject, BehaviorSubject } from 'rxjs';
5
- import { takeUntil, debounceTime, distinctUntilChanged } from 'rxjs/operators';
6
- import { BaseDirective } from '@eui/components/shared';
3
+ import { Subject, BehaviorSubject, takeUntil, debounceTime, distinctUntilChanged } from 'rxjs';
4
+ import { BaseStatesDirective } from '@eui/components/shared';
7
5
  import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/forms";
9
- import * as i2 from "@eui/components/eui-icon";
10
- import * as i3 from "@eui/components/eui-input-text";
11
- export class EuiTableFilterComponent extends BaseDirective {
12
- get autoSearch() {
13
- return this._autoSearch;
14
- }
15
- set autoSearch(value) {
16
- this._autoSearch = coerceBooleanProperty(value);
17
- }
6
+ import * as i1 from "@eui/components/shared";
7
+ import * as i2 from "@angular/forms";
8
+ import * as i3 from "@eui/components/eui-icon";
9
+ import * as i4 from "@eui/components/eui-input-text";
10
+ export class EuiTableFilterComponent {
18
11
  get cssClasses() {
19
- return [super.getCssClasses('eui-table__filter')].join(' ').trim();
12
+ return [this.baseStatesDirective.getCssClasses('eui-table__filter')].join(' ').trim();
20
13
  }
21
- constructor() {
22
- super();
14
+ constructor(baseStatesDirective) {
15
+ this.baseStatesDirective = baseStatesDirective;
23
16
  this.filterChange = new EventEmitter();
24
17
  this.filter$ = new BehaviorSubject(null);
25
- this._autoSearch = false;
18
+ this.autoSearch = false;
26
19
  this.destroy$ = new Subject();
27
20
  }
28
21
  ngOnInit() {
29
22
  this.form = new FormGroup({
30
23
  filter: new FormControl(null),
31
24
  });
32
- this.form
33
- .get('filter')
34
- .valueChanges.pipe(debounceTime(500), distinctUntilChanged(), takeUntil(this.destroy$))
35
- .subscribe((value) => {
25
+ this.form.get('filter').valueChanges.pipe(debounceTime(500), distinctUntilChanged(), takeUntil(this.destroy$)).subscribe((value) => {
36
26
  this.setFilter(value);
37
27
  });
38
28
  }
@@ -50,13 +40,21 @@ export class EuiTableFilterComponent extends BaseDirective {
50
40
  this.form.reset();
51
41
  this.filterInput.nativeElement.focus();
52
42
  }
53
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.4", ngImport: i0, type: EuiTableFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
54
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.4", type: EuiTableFilterComponent, selector: "eui-table-filter", inputs: { placeholder: "placeholder", autoSearch: "autoSearch" }, outputs: { filterChange: "filterChange" }, host: { properties: { "class": "this.cssClasses" } }, viewQueries: [{ propertyName: "filterInput", first: true, predicate: ["filterInput"], descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0, template: "<div class=\"eui-table__filter\">\n <form [formGroup]=\"form\">\n <input\n #filterInput\n euiClearable\n euiInputText\n class=\"eui-table__filter-input\"\n formControlName=\"filter\"\n [attr.aria-label]=\"placeholder ? placeholder : 'Filter Input Field'\"\n placeholder=\"{{ placeholder }}\" />\n <eui-icon-svg class=\"eui-table__filter-search-icon\" icon=\"eui-search\" set=\"eui\" size=\"m\" fillColor=\"grey-35\"></eui-icon-svg>\n </form>\n</div>\n", dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i2.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "size", "fillColor", "set", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.EuiInputTextComponent, selector: "input[euiInputText]", inputs: ["isInvalid"] }], encapsulation: i0.ViewEncapsulation.None }); }
43
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.4", ngImport: i0, type: EuiTableFilterComponent, deps: [{ token: i1.BaseStatesDirective }], target: i0.ɵɵFactoryTarget.Component }); }
44
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0-next.4", type: EuiTableFilterComponent, selector: "eui-table-filter", inputs: { placeholder: "placeholder", autoSearch: ["autoSearch", "autoSearch", booleanAttribute] }, outputs: { filterChange: "filterChange" }, host: { properties: { "class": "this.cssClasses" } }, viewQueries: [{ propertyName: "filterInput", first: true, predicate: ["filterInput"], descendants: true, read: ElementRef }], hostDirectives: [{ directive: i1.BaseStatesDirective }], ngImport: i0, template: "<div class=\"eui-table__filter\">\n <form [formGroup]=\"form\">\n <input\n #filterInput\n euiClearable\n euiInputText\n class=\"eui-table__filter-input\"\n formControlName=\"filter\"\n [attr.aria-label]=\"placeholder ? placeholder : 'Filter Input Field'\"\n placeholder=\"{{ placeholder }}\" />\n <eui-icon-svg class=\"eui-table__filter-search-icon\" icon=\"eui-search\" set=\"eui\" size=\"m\" fillColor=\"grey-35\"></eui-icon-svg>\n </form>\n</div>\n", dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i3.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "size", "fillColor", "set", "ariaLabelledby", "role", "style", "iconUrl", "transform", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i4.EuiInputTextComponent, selector: "input[euiInputText]", inputs: ["isInvalid"] }], encapsulation: i0.ViewEncapsulation.None }); }
55
45
  }
56
46
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.4", ngImport: i0, type: EuiTableFilterComponent, decorators: [{
57
47
  type: Component,
58
- args: [{ selector: 'eui-table-filter', encapsulation: ViewEncapsulation.None, template: "<div class=\"eui-table__filter\">\n <form [formGroup]=\"form\">\n <input\n #filterInput\n euiClearable\n euiInputText\n class=\"eui-table__filter-input\"\n formControlName=\"filter\"\n [attr.aria-label]=\"placeholder ? placeholder : 'Filter Input Field'\"\n placeholder=\"{{ placeholder }}\" />\n <eui-icon-svg class=\"eui-table__filter-search-icon\" icon=\"eui-search\" set=\"eui\" size=\"m\" fillColor=\"grey-35\"></eui-icon-svg>\n </form>\n</div>\n" }]
59
- }], ctorParameters: () => [], propDecorators: { placeholder: [{
48
+ args: [{ selector: 'eui-table-filter', encapsulation: ViewEncapsulation.None, hostDirectives: [
49
+ {
50
+ directive: BaseStatesDirective,
51
+ inputs: [],
52
+ },
53
+ ], template: "<div class=\"eui-table__filter\">\n <form [formGroup]=\"form\">\n <input\n #filterInput\n euiClearable\n euiInputText\n class=\"eui-table__filter-input\"\n formControlName=\"filter\"\n [attr.aria-label]=\"placeholder ? placeholder : 'Filter Input Field'\"\n placeholder=\"{{ placeholder }}\" />\n <eui-icon-svg class=\"eui-table__filter-search-icon\" icon=\"eui-search\" set=\"eui\" size=\"m\" fillColor=\"grey-35\"></eui-icon-svg>\n </form>\n</div>\n" }]
54
+ }], ctorParameters: () => [{ type: i1.BaseStatesDirective }], propDecorators: { cssClasses: [{
55
+ type: HostBinding,
56
+ args: ['class']
57
+ }], placeholder: [{
60
58
  type: Input
61
59
  }], filterChange: [{
62
60
  type: Output
@@ -64,9 +62,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.4",
64
62
  type: ViewChild,
65
63
  args: ['filterInput', { read: ElementRef }]
66
64
  }], autoSearch: [{
67
- type: Input
68
- }], cssClasses: [{
69
- type: HostBinding,
70
- args: ['class']
65
+ type: Input,
66
+ args: [{ transform: booleanAttribute }]
71
67
  }] } });
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLXRhYmxlLWZpbHRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9ldWktdGFibGUvZmlsdGVyL2V1aS10YWJsZS1maWx0ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vZXVpLXRhYmxlL2ZpbHRlci9ldWktdGFibGUtZmlsdGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxTQUFTLEVBRVQsS0FBSyxFQUNMLE1BQU0sRUFDTixZQUFZLEVBRVosV0FBVyxFQUNYLFNBQVMsRUFDVCxVQUFVLEVBQ1YsaUJBQWlCLEdBQ3BCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEQsT0FBTyxFQUFFLHFCQUFxQixFQUFnQixNQUFNLHVCQUF1QixDQUFDO0FBQzVFLE9BQU8sRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFL0UsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7OztBQU12RCxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsYUFBYTtJQVV0RCxJQUNJLFVBQVU7UUFDVixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDNUIsQ0FBQztJQUNELElBQUksVUFBVSxDQUFDLEtBQW1CO1FBQzlCLElBQUksQ0FBQyxXQUFXLEdBQUcscUJBQXFCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEQsQ0FBQztJQUtELElBQ0ksVUFBVTtRQUNWLE9BQU8sQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdkUsQ0FBQztJQUVEO1FBQ0ksS0FBSyxFQUFFLENBQUM7UUF4QkYsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBSTdDLFlBQU8sR0FBbUMsSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7UUFVbkUsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFFcEIsYUFBUSxHQUFxQixJQUFJLE9BQU8sRUFBVyxDQUFDO0lBUzVELENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLFNBQVMsQ0FBQztZQUN0QixNQUFNLEVBQUUsSUFBSSxXQUFXLENBQVMsSUFBSSxDQUFDO1NBQ3hDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxJQUFJO2FBQ0osR0FBRyxDQUFDLFFBQVEsQ0FBQzthQUNiLFlBQVksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxFQUFFLG9CQUFvQixFQUFFLEVBQUUsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUN0RixTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUNqQixJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzFCLENBQUMsQ0FBQyxDQUFDO0lBQ1gsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFTSxTQUFTLENBQUMsS0FBYTtRQUMxQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN6QixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM5QixJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUVNLFdBQVc7UUFDZCxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDbEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDM0MsQ0FBQztxSEExRFEsdUJBQXVCO3lHQUF2Qix1QkFBdUIsa1RBS0UsVUFBVSxvREM1QmhELHNpQkFhQTs7a0dEVWEsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNJLGtCQUFrQixpQkFFYixpQkFBaUIsQ0FBQyxJQUFJO3dEQUc1QixXQUFXO3NCQUFuQixLQUFLO2dCQUVJLFlBQVk7c0JBQXJCLE1BQU07Z0JBRXlDLFdBQVc7c0JBQTFELFNBQVM7dUJBQUMsYUFBYSxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRTtnQkFNMUMsVUFBVTtzQkFEYixLQUFLO2dCQVlGLFVBQVU7c0JBRGIsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDb21wb25lbnQsXG4gICAgT25Jbml0LFxuICAgIElucHV0LFxuICAgIE91dHB1dCxcbiAgICBFdmVudEVtaXR0ZXIsXG4gICAgT25EZXN0cm95LFxuICAgIEhvc3RCaW5kaW5nLFxuICAgIFZpZXdDaGlsZCxcbiAgICBFbGVtZW50UmVmLFxuICAgIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1Hcm91cCwgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBjb2VyY2VCb29sZWFuUHJvcGVydHksIEJvb2xlYW5JbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbic7XG5pbXBvcnQgeyBTdWJqZWN0LCBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IHRha2VVbnRpbCwgZGVib3VuY2VUaW1lLCBkaXN0aW5jdFVudGlsQ2hhbmdlZCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgQmFzZURpcmVjdGl2ZSB9IGZyb20gJ0BldWkvY29tcG9uZW50cy9zaGFyZWQnO1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldWktdGFibGUtZmlsdGVyJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZXVpLXRhYmxlLWZpbHRlci5jb21wb25lbnQuaHRtbCcsXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbn0pXG5leHBvcnQgY2xhc3MgRXVpVGFibGVGaWx0ZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICAgIEBJbnB1dCgpIHBsYWNlaG9sZGVyOiBzdHJpbmc7XG5cbiAgICBAT3V0cHV0KCkgZmlsdGVyQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgICBAVmlld0NoaWxkKCdmaWx0ZXJJbnB1dCcsIHsgcmVhZDogRWxlbWVudFJlZiB9KSBmaWx0ZXJJbnB1dDogRWxlbWVudFJlZjxIVE1MSW5wdXRFbGVtZW50PjtcblxuICAgIHB1YmxpYyBmaWx0ZXIkOiBCZWhhdmlvclN1YmplY3Q8c3RyaW5nIHwgbnVsbD4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0KG51bGwpO1xuICAgIHB1YmxpYyBmb3JtOiBGb3JtR3JvdXA7XG5cbiAgICBASW5wdXQoKVxuICAgIGdldCBhdXRvU2VhcmNoKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5fYXV0b1NlYXJjaDtcbiAgICB9XG4gICAgc2V0IGF1dG9TZWFyY2godmFsdWU6IEJvb2xlYW5JbnB1dCkge1xuICAgICAgICB0aGlzLl9hdXRvU2VhcmNoID0gY29lcmNlQm9vbGVhblByb3BlcnR5KHZhbHVlKTtcbiAgICB9XG4gICAgcHJpdmF0ZSBfYXV0b1NlYXJjaCA9IGZhbHNlO1xuXG4gICAgcHJpdmF0ZSBkZXN0cm95JDogU3ViamVjdDxib29sZWFuPiA9IG5ldyBTdWJqZWN0PGJvb2xlYW4+KCk7XG5cbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgICBnZXQgY3NzQ2xhc3NlcygpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gW3N1cGVyLmdldENzc0NsYXNzZXMoJ2V1aS10YWJsZV9fZmlsdGVyJyldLmpvaW4oJyAnKS50cmltKCk7XG4gICAgfVxuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZm9ybSA9IG5ldyBGb3JtR3JvdXAoe1xuICAgICAgICAgICAgZmlsdGVyOiBuZXcgRm9ybUNvbnRyb2w8c3RyaW5nPihudWxsKSxcbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGhpcy5mb3JtXG4gICAgICAgICAgICAuZ2V0KCdmaWx0ZXInKVxuICAgICAgICAgICAgLnZhbHVlQ2hhbmdlcy5waXBlKGRlYm91bmNlVGltZSg1MDApLCBkaXN0aW5jdFVudGlsQ2hhbmdlZCgpLCB0YWtlVW50aWwodGhpcy5kZXN0cm95JCkpXG4gICAgICAgICAgICAuc3Vic2NyaWJlKCh2YWx1ZSkgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMuc2V0RmlsdGVyKHZhbHVlKTtcbiAgICAgICAgICAgIH0pO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRlc3Ryb3kkLm5leHQodHJ1ZSk7XG4gICAgICAgIHRoaXMuZGVzdHJveSQudW5zdWJzY3JpYmUoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgc2V0RmlsdGVyKHZhbHVlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5maWx0ZXIkLm5leHQodmFsdWUpO1xuICAgICAgICB0aGlzLmZpbHRlckNoYW5nZS5lbWl0KHZhbHVlKTtcbiAgICAgICAgdGhpcy5mb3JtLmdldCgnZmlsdGVyJykuc2V0VmFsdWUodmFsdWUpO1xuICAgIH1cblxuICAgIHB1YmxpYyByZXNldEZpbHRlcigpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zZXRGaWx0ZXIobnVsbCk7XG4gICAgICAgIHRoaXMuZm9ybS5yZXNldCgpO1xuICAgICAgICB0aGlzLmZpbHRlcklucHV0Lm5hdGl2ZUVsZW1lbnQuZm9jdXMoKTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZXVpLXRhYmxlX19maWx0ZXJcIj5cbiAgICA8Zm9ybSBbZm9ybUdyb3VwXT1cImZvcm1cIj5cbiAgICAgICAgPGlucHV0XG4gICAgICAgICAgICAjZmlsdGVySW5wdXRcbiAgICAgICAgICAgIGV1aUNsZWFyYWJsZVxuICAgICAgICAgICAgZXVpSW5wdXRUZXh0XG4gICAgICAgICAgICBjbGFzcz1cImV1aS10YWJsZV9fZmlsdGVyLWlucHV0XCJcbiAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cImZpbHRlclwiXG4gICAgICAgICAgICBbYXR0ci5hcmlhLWxhYmVsXT1cInBsYWNlaG9sZGVyID8gcGxhY2Vob2xkZXIgOiAnRmlsdGVyIElucHV0IEZpZWxkJ1wiXG4gICAgICAgICAgICBwbGFjZWhvbGRlcj1cInt7IHBsYWNlaG9sZGVyIH19XCIgLz5cbiAgICAgICAgPGV1aS1pY29uLXN2ZyBjbGFzcz1cImV1aS10YWJsZV9fZmlsdGVyLXNlYXJjaC1pY29uXCIgaWNvbj1cImV1aS1zZWFyY2hcIiBzZXQ9XCJldWlcIiBzaXplPVwibVwiIGZpbGxDb2xvcj1cImdyZXktMzVcIj48L2V1aS1pY29uLXN2Zz5cbiAgICA8L2Zvcm0+XG48L2Rpdj5cbiJdfQ==
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLXRhYmxlLWZpbHRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9ldWktdGFibGUvZmlsdGVyL2V1aS10YWJsZS1maWx0ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vZXVpLXRhYmxlL2ZpbHRlci9ldWktdGFibGUtZmlsdGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQWEsV0FBVyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsaUJBQWlCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkssT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLG9CQUFvQixFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRS9GLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7Ozs7QUFhN0QsTUFBTSxPQUFPLHVCQUF1QjtJQUNoQyxJQUNJLFVBQVU7UUFDVixPQUFPLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGFBQWEsQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFGLENBQUM7SUFlRCxZQUFvQixtQkFBd0M7UUFBeEMsd0JBQW1CLEdBQW5CLG1CQUFtQixDQUFxQjtRQVhsRCxpQkFBWSxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFJN0MsWUFBTyxHQUFtQyxJQUFJLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUduQyxlQUFVLEdBQUcsS0FBSyxDQUFDO1FBRW5ELGFBQVEsR0FBcUIsSUFBSSxPQUFPLEVBQVcsQ0FBQztJQUc1RCxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxTQUFTLENBQUM7WUFDdEIsTUFBTSxFQUFFLElBQUksV0FBVyxDQUFTLElBQUksQ0FBQztTQUN4QyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsRUFBRSxvQkFBb0IsRUFBRSxFQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUMvSCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzFCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFTSxTQUFTLENBQUMsS0FBYTtRQUMxQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN6QixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM5QixJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDNUMsQ0FBQztJQUVNLFdBQVc7UUFDZCxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDbEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDM0MsQ0FBQztxSEEvQ1EsdUJBQXVCO3lHQUF2Qix1QkFBdUIsK0dBZVosZ0JBQWdCLHFOQUxGLFVBQVUsc0ZDM0JoRCxzaUJBYUE7O2tHRElhLHVCQUF1QjtrQkFYbkMsU0FBUzsrQkFDSSxrQkFBa0IsaUJBRWIsaUJBQWlCLENBQUMsSUFBSSxrQkFDckI7d0JBQ1o7NEJBQ0ksU0FBUyxFQUFFLG1CQUFtQjs0QkFDOUIsTUFBTSxFQUFFLEVBQUU7eUJBQ2I7cUJBQ0o7d0ZBSUcsVUFBVTtzQkFEYixXQUFXO3VCQUFDLE9BQU87Z0JBS1gsV0FBVztzQkFBbkIsS0FBSztnQkFFSSxZQUFZO3NCQUFyQixNQUFNO2dCQUV5QyxXQUFXO3NCQUExRCxTQUFTO3VCQUFDLGFBQWEsRUFBRSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUU7Z0JBS04sVUFBVTtzQkFBakQsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIsIE9uRGVzdHJveSwgSG9zdEJpbmRpbmcsIFZpZXdDaGlsZCwgRWxlbWVudFJlZiwgVmlld0VuY2Fwc3VsYXRpb24sIGJvb2xlYW5BdHRyaWJ1dGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1Hcm91cCwgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBTdWJqZWN0LCBCZWhhdmlvclN1YmplY3QsIHRha2VVbnRpbCwgZGVib3VuY2VUaW1lLCBkaXN0aW5jdFVudGlsQ2hhbmdlZCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBCYXNlU3RhdGVzRGlyZWN0aXZlIH0gZnJvbSAnQGV1aS9jb21wb25lbnRzL3NoYXJlZCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXVpLXRhYmxlLWZpbHRlcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2V1aS10YWJsZS1maWx0ZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgZGlyZWN0aXZlOiBCYXNlU3RhdGVzRGlyZWN0aXZlLFxuICAgICAgICAgICAgaW5wdXRzOiBbXSxcbiAgICAgICAgfSxcbiAgICBdLFxufSlcbmV4cG9ydCBjbGFzcyBFdWlUYWJsZUZpbHRlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgICBnZXQgY3NzQ2xhc3NlcygpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gW3RoaXMuYmFzZVN0YXRlc0RpcmVjdGl2ZS5nZXRDc3NDbGFzc2VzKCdldWktdGFibGVfX2ZpbHRlcicpXS5qb2luKCcgJykudHJpbSgpO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHBsYWNlaG9sZGVyOiBzdHJpbmc7XG5cbiAgICBAT3V0cHV0KCkgZmlsdGVyQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgICBAVmlld0NoaWxkKCdmaWx0ZXJJbnB1dCcsIHsgcmVhZDogRWxlbWVudFJlZiB9KSBmaWx0ZXJJbnB1dDogRWxlbWVudFJlZjxIVE1MSW5wdXRFbGVtZW50PjtcblxuICAgIHB1YmxpYyBmaWx0ZXIkOiBCZWhhdmlvclN1YmplY3Q8c3RyaW5nIHwgbnVsbD4gPSBuZXcgQmVoYXZpb3JTdWJqZWN0KG51bGwpO1xuICAgIHB1YmxpYyBmb3JtOiBGb3JtR3JvdXA7XG5cbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSkgYXV0b1NlYXJjaCA9IGZhbHNlO1xuXG4gICAgcHJpdmF0ZSBkZXN0cm95JDogU3ViamVjdDxib29sZWFuPiA9IG5ldyBTdWJqZWN0PGJvb2xlYW4+KCk7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGJhc2VTdGF0ZXNEaXJlY3RpdmU6IEJhc2VTdGF0ZXNEaXJlY3RpdmUpIHtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5mb3JtID0gbmV3IEZvcm1Hcm91cCh7XG4gICAgICAgICAgICBmaWx0ZXI6IG5ldyBGb3JtQ29udHJvbDxzdHJpbmc+KG51bGwpLFxuICAgICAgICB9KTtcblxuICAgICAgICB0aGlzLmZvcm0uZ2V0KCdmaWx0ZXInKS52YWx1ZUNoYW5nZXMucGlwZShkZWJvdW5jZVRpbWUoNTAwKSwgZGlzdGluY3RVbnRpbENoYW5nZWQoKSwgdGFrZVVudGlsKHRoaXMuZGVzdHJveSQpKS5zdWJzY3JpYmUoKHZhbHVlKSA9PiB7XG4gICAgICAgICAgICB0aGlzLnNldEZpbHRlcih2YWx1ZSk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRlc3Ryb3kkLm5leHQodHJ1ZSk7XG4gICAgICAgIHRoaXMuZGVzdHJveSQudW5zdWJzY3JpYmUoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgc2V0RmlsdGVyKHZhbHVlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5maWx0ZXIkLm5leHQodmFsdWUpO1xuICAgICAgICB0aGlzLmZpbHRlckNoYW5nZS5lbWl0KHZhbHVlKTtcbiAgICAgICAgdGhpcy5mb3JtLmdldCgnZmlsdGVyJykuc2V0VmFsdWUodmFsdWUpO1xuICAgIH1cblxuICAgIHB1YmxpYyByZXNldEZpbHRlcigpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zZXRGaWx0ZXIobnVsbCk7XG4gICAgICAgIHRoaXMuZm9ybS5yZXNldCgpO1xuICAgICAgICB0aGlzLmZpbHRlcklucHV0Lm5hdGl2ZUVsZW1lbnQuZm9jdXMoKTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZXVpLXRhYmxlX19maWx0ZXJcIj5cbiAgICA8Zm9ybSBbZm9ybUdyb3VwXT1cImZvcm1cIj5cbiAgICAgICAgPGlucHV0XG4gICAgICAgICAgICAjZmlsdGVySW5wdXRcbiAgICAgICAgICAgIGV1aUNsZWFyYWJsZVxuICAgICAgICAgICAgZXVpSW5wdXRUZXh0XG4gICAgICAgICAgICBjbGFzcz1cImV1aS10YWJsZV9fZmlsdGVyLWlucHV0XCJcbiAgICAgICAgICAgIGZvcm1Db250cm9sTmFtZT1cImZpbHRlclwiXG4gICAgICAgICAgICBbYXR0ci5hcmlhLWxhYmVsXT1cInBsYWNlaG9sZGVyID8gcGxhY2Vob2xkZXIgOiAnRmlsdGVyIElucHV0IEZpZWxkJ1wiXG4gICAgICAgICAgICBwbGFjZWhvbGRlcj1cInt7IHBsYWNlaG9sZGVyIH19XCIgLz5cbiAgICAgICAgPGV1aS1pY29uLXN2ZyBjbGFzcz1cImV1aS10YWJsZV9fZmlsdGVyLXNlYXJjaC1pY29uXCIgaWNvbj1cImV1aS1zZWFyY2hcIiBzZXQ9XCJldWlcIiBzaXplPVwibVwiIGZpbGxDb2xvcj1cImdyZXktMzVcIj48L2V1aS1pY29uLXN2Zz5cbiAgICA8L2Zvcm0+XG48L2Rpdj5cbiJdfQ==
@@ -1,29 +1,14 @@
1
- import { Component, Input, ViewChild } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import { takeUntil } from 'rxjs/operators';
4
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
1
+ import { Component, Input, ViewChild, booleanAttribute } from '@angular/core';
2
+ import { Subject, takeUntil } from 'rxjs';
5
3
  import * as i0 from "@angular/core";
6
4
  import * as i1 from "../services/eui-table-selectable-row.service";
7
- import * as i2 from "@angular/common";
8
- import * as i3 from "@eui/components/eui-input-checkbox";
5
+ import * as i2 from "@eui/components/eui-input-checkbox";
9
6
  export class EuiTableSelectableHeaderComponent {
10
- get isSelectableHeader() {
11
- return this._isSelectableHeader;
12
- }
13
- set isSelectableHeader(value) {
14
- this._isSelectableHeader = coerceBooleanProperty(value);
15
- }
16
- get isChecked() {
17
- return this._isChecked;
18
- }
19
- set isChecked(value) {
20
- this._isChecked = coerceBooleanProperty(value);
21
- }
22
7
  constructor(euiTableSelectableRowService) {
23
8
  this.euiTableSelectableRowService = euiTableSelectableRowService;
24
9
  this.isCheckedIndeterminate = false;
25
- this._isSelectableHeader = true;
26
- this._isChecked = false;
10
+ this.isSelectableHeader = true;
11
+ this.isChecked = false;
27
12
  this.destroy$ = new Subject();
28
13
  }
29
14
  ngOnInit() {
@@ -54,17 +39,19 @@ export class EuiTableSelectableHeaderComponent {
54
39
  }
55
40
  }
56
41
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.4", ngImport: i0, type: EuiTableSelectableHeaderComponent, deps: [{ token: i1.EuiTableSelectableRowService }], target: i0.ɵɵFactoryTarget.Component }); }
57
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.4", type: EuiTableSelectableHeaderComponent, selector: "tr[isSelectableHeader]", inputs: { isSelectableHeader: "isSelectableHeader", isChecked: "isChecked" }, viewQueries: [{ propertyName: "checkbox", first: true, predicate: ["checkbox"], descendants: true }], ngImport: i0, template: "<th *ngIf=\"isSelectableHeader\" class=\"eui-table__cell-select\">\n <div class=\"eui-table__cell-select-checkbox-container\">\n <input\n *ngIf=\"!isChecked && !isCheckedIndeterminate\"\n aria-label=\"Unchecked\"\n euiInputCheckBox\n checked=\"false\"\n (click)=\"toggleCheckedState(true)\" />\n <input\n *ngIf=\"isCheckedIndeterminate\"\n aria-label=\"Indeterminate\"\n euiInputCheckBox\n indeterminate\n (click)=\"toggleCheckedState(false)\" />\n <input\n *ngIf=\"isChecked && !isCheckedIndeterminate\"\n aria-label=\"Checked\"\n euiInputCheckBox\n checked=\"true\"\n (click)=\"toggleCheckedState(false)\" />\n </div>\n</th>\n<ng-content></ng-content>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.EuiInputCheckboxComponent, selector: "input[euiInputCheckBox]", inputs: ["indeterminate", "isInvalid", "styleClass", "checked", "id"], outputs: ["indeterminateChange"] }] }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-next.4", type: EuiTableSelectableHeaderComponent, selector: "tr[isSelectableHeader]", inputs: { isSelectableHeader: ["isSelectableHeader", "isSelectableHeader", booleanAttribute], isChecked: ["isChecked", "isChecked", booleanAttribute] }, viewQueries: [{ propertyName: "checkbox", first: true, predicate: ["checkbox"], descendants: true }], ngImport: i0, template: "@if (isSelectableHeader) {\n <th class=\"eui-table__cell-select\">\n <div class=\"eui-table__cell-select-checkbox-container\">\n @if (!isChecked && !isCheckedIndeterminate) {\n <input aria-label=\"Unchecked\" euiInputCheckBox checked=\"false\" (click)=\"toggleCheckedState(true)\" />\n }\n @if (isCheckedIndeterminate) {\n <input aria-label=\"Indeterminate\" euiInputCheckBox indeterminate (click)=\"toggleCheckedState(false)\" />\n }\n @if (isChecked && !isCheckedIndeterminate) {\n <input aria-label=\"Checked\" euiInputCheckBox checked=\"true\" (click)=\"toggleCheckedState(false)\" />\n }\n </div>\n </th>\n}\n\n<ng-content></ng-content>\n", dependencies: [{ kind: "component", type: i2.EuiInputCheckboxComponent, selector: "input[euiInputCheckBox]", inputs: ["indeterminate", "isInvalid", "styleClass", "checked", "id"], outputs: ["indeterminateChange"] }] }); }
58
43
  }
59
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.4", ngImport: i0, type: EuiTableSelectableHeaderComponent, decorators: [{
60
45
  type: Component,
61
- args: [{ selector: 'tr[isSelectableHeader]', template: "<th *ngIf=\"isSelectableHeader\" class=\"eui-table__cell-select\">\n <div class=\"eui-table__cell-select-checkbox-container\">\n <input\n *ngIf=\"!isChecked && !isCheckedIndeterminate\"\n aria-label=\"Unchecked\"\n euiInputCheckBox\n checked=\"false\"\n (click)=\"toggleCheckedState(true)\" />\n <input\n *ngIf=\"isCheckedIndeterminate\"\n aria-label=\"Indeterminate\"\n euiInputCheckBox\n indeterminate\n (click)=\"toggleCheckedState(false)\" />\n <input\n *ngIf=\"isChecked && !isCheckedIndeterminate\"\n aria-label=\"Checked\"\n euiInputCheckBox\n checked=\"true\"\n (click)=\"toggleCheckedState(false)\" />\n </div>\n</th>\n<ng-content></ng-content>\n" }]
46
+ args: [{ selector: 'tr[isSelectableHeader]', template: "@if (isSelectableHeader) {\n <th class=\"eui-table__cell-select\">\n <div class=\"eui-table__cell-select-checkbox-container\">\n @if (!isChecked && !isCheckedIndeterminate) {\n <input aria-label=\"Unchecked\" euiInputCheckBox checked=\"false\" (click)=\"toggleCheckedState(true)\" />\n }\n @if (isCheckedIndeterminate) {\n <input aria-label=\"Indeterminate\" euiInputCheckBox indeterminate (click)=\"toggleCheckedState(false)\" />\n }\n @if (isChecked && !isCheckedIndeterminate) {\n <input aria-label=\"Checked\" euiInputCheckBox checked=\"true\" (click)=\"toggleCheckedState(false)\" />\n }\n </div>\n </th>\n}\n\n<ng-content></ng-content>\n" }]
62
47
  }], ctorParameters: () => [{ type: i1.EuiTableSelectableRowService }], propDecorators: { checkbox: [{
63
48
  type: ViewChild,
64
49
  args: ['checkbox']
65
50
  }], isSelectableHeader: [{
66
- type: Input
51
+ type: Input,
52
+ args: [{ transform: booleanAttribute }]
67
53
  }], isChecked: [{
68
- type: Input
54
+ type: Input,
55
+ args: [{ transform: booleanAttribute }]
69
56
  }] } });
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLXRhYmxlLXNlbGVjdGFibGUtaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2V1aS10YWJsZS9zZWxlY3RhYmxlLWhlYWRlci9ldWktdGFibGUtc2VsZWN0YWJsZS1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vZXVpLXRhYmxlL3NlbGVjdGFibGUtaGVhZGVyL2V1aS10YWJsZS1zZWxlY3RhYmxlLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLEtBQUssRUFBYSxTQUFTLEVBQWMsTUFBTSxlQUFlLENBQUM7QUFDM0YsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMvQixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFHM0MsT0FBTyxFQUFFLHFCQUFxQixFQUFnQixNQUFNLHVCQUF1QixDQUFDOzs7OztBQU81RSxNQUFNLE9BQU8saUNBQWlDO0lBSzFDLElBQ0ksa0JBQWtCO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLG1CQUFtQixDQUFDO0lBQ3BDLENBQUM7SUFDRCxJQUFJLGtCQUFrQixDQUFDLEtBQW1CO1FBQ3RDLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxxQkFBcUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQsSUFDSSxTQUFTO1FBQ1QsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQzNCLENBQUM7SUFDRCxJQUFJLFNBQVMsQ0FBQyxLQUFtQjtRQUM3QixJQUFJLENBQUMsVUFBVSxHQUFHLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFLRCxZQUFvQiw0QkFBMEQ7UUFBMUQsaUNBQTRCLEdBQTVCLDRCQUE0QixDQUE4QjtRQXJCdkUsMkJBQXNCLEdBQUcsS0FBSyxDQUFDO1FBUzlCLHdCQUFtQixHQUFHLElBQUksQ0FBQztRQVEzQixlQUFVLEdBQUcsS0FBSyxDQUFDO1FBRW5CLGFBQVEsR0FBcUIsSUFBSSxPQUFPLEVBQVcsQ0FBQztJQUVxQixDQUFDO0lBRWxGLFFBQVE7UUFDSixJQUFJLENBQUMsNEJBQTRCLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUN2RyxJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztZQUMxQixJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztnQkFDaEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsT0FBTyxHQUFHLFFBQVEsQ0FBQztZQUNuRCxDQUFDO1lBRUQsSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsNEJBQTRCLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7Z0JBQ2hGLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxJQUFJLENBQUM7WUFDdkMsQ0FBQztpQkFBTSxDQUFDO2dCQUNKLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxLQUFLLENBQUM7WUFDeEMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFTSxrQkFBa0IsQ0FBQyxLQUFjO1FBQ3BDLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBRXZCLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ2pCLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUN0RCxDQUFDO2FBQU0sQ0FBQztZQUNKLElBQUksQ0FBQyw0QkFBNEIsQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN4RCxDQUFDO0lBQ0wsQ0FBQztxSEF0RFEsaUNBQWlDO3lHQUFqQyxpQ0FBaUMsa1BDWjlDLGkxQkF1QkE7O2tHRFhhLGlDQUFpQztrQkFMN0MsU0FBUzsrQkFFSSx3QkFBd0I7aUdBSVgsUUFBUTtzQkFBOUIsU0FBUzt1QkFBQyxVQUFVO2dCQUtqQixrQkFBa0I7c0JBRHJCLEtBQUs7Z0JBU0YsU0FBUztzQkFEWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIElucHV0LCBPbkRlc3Ryb3ksIFZpZXdDaGlsZCwgRWxlbWVudFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgdGFrZVVudGlsIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQgeyBFdWlUYWJsZVNlbGVjdGFibGVSb3dTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvZXVpLXRhYmxlLXNlbGVjdGFibGUtcm93LnNlcnZpY2UnO1xuaW1wb3J0IHsgY29lcmNlQm9vbGVhblByb3BlcnR5LCBCb29sZWFuSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBzZWxlY3RvcjogJ3RyW2lzU2VsZWN0YWJsZUhlYWRlcl0nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ldWktdGFibGUtc2VsZWN0YWJsZS1oZWFkZXIuY29tcG9uZW50Lmh0bWwnLFxufSlcbmV4cG9ydCBjbGFzcyBFdWlUYWJsZVNlbGVjdGFibGVIZWFkZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gICAgQFZpZXdDaGlsZCgnY2hlY2tib3gnKSBjaGVja2JveDogRWxlbWVudFJlZjxIVE1MSW5wdXRFbGVtZW50PjtcblxuICAgIHB1YmxpYyBpc0NoZWNrZWRJbmRldGVybWluYXRlID0gZmFsc2U7XG5cbiAgICBASW5wdXQoKVxuICAgIGdldCBpc1NlbGVjdGFibGVIZWFkZXIoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLl9pc1NlbGVjdGFibGVIZWFkZXI7XG4gICAgfVxuICAgIHNldCBpc1NlbGVjdGFibGVIZWFkZXIodmFsdWU6IEJvb2xlYW5JbnB1dCkge1xuICAgICAgICB0aGlzLl9pc1NlbGVjdGFibGVIZWFkZXIgPSBjb2VyY2VCb29sZWFuUHJvcGVydHkodmFsdWUpO1xuICAgIH1cbiAgICBwcml2YXRlIF9pc1NlbGVjdGFibGVIZWFkZXIgPSB0cnVlO1xuICAgIEBJbnB1dCgpXG4gICAgZ2V0IGlzQ2hlY2tlZCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2lzQ2hlY2tlZDtcbiAgICB9XG4gICAgc2V0IGlzQ2hlY2tlZCh2YWx1ZTogQm9vbGVhbklucHV0KSB7XG4gICAgICAgIHRoaXMuX2lzQ2hlY2tlZCA9IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSh2YWx1ZSk7XG4gICAgfVxuICAgIHByaXZhdGUgX2lzQ2hlY2tlZCA9IGZhbHNlO1xuXG4gICAgcHJpdmF0ZSBkZXN0cm95JDogU3ViamVjdDxib29sZWFuPiA9IG5ldyBTdWJqZWN0PGJvb2xlYW4+KCk7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGV1aVRhYmxlU2VsZWN0YWJsZVJvd1NlcnZpY2U6IEV1aVRhYmxlU2VsZWN0YWJsZVJvd1NlcnZpY2UpIHt9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5ldWlUYWJsZVNlbGVjdGFibGVSb3dTZXJ2aWNlLmlzQWxsUm93c1NlbGVjdGVkJC5waXBlKHRha2VVbnRpbCh0aGlzLmRlc3Ryb3kkKSkuc3Vic2NyaWJlKChzZWxlY3RlZCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5pc0NoZWNrZWQgPSBzZWxlY3RlZDtcbiAgICAgICAgICAgIGlmICh0aGlzLmNoZWNrYm94KSB7XG4gICAgICAgICAgICAgICAgdGhpcy5jaGVja2JveC5uYXRpdmVFbGVtZW50LmNoZWNrZWQgPSBzZWxlY3RlZDtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgaWYgKCFzZWxlY3RlZCAmJiB0aGlzLmV1aVRhYmxlU2VsZWN0YWJsZVJvd1NlcnZpY2Uuc2VsZWN0ZWRSb3dzJC52YWx1ZS5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5pc0NoZWNrZWRJbmRldGVybWluYXRlID0gdHJ1ZTtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgdGhpcy5pc0NoZWNrZWRJbmRldGVybWluYXRlID0gZmFsc2U7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRlc3Ryb3kkLm5leHQodHJ1ZSk7XG4gICAgICAgIHRoaXMuZGVzdHJveSQudW5zdWJzY3JpYmUoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgdG9nZ2xlQ2hlY2tlZFN0YXRlKHZhbHVlOiBib29sZWFuKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNDaGVja2VkID0gdmFsdWU7XG5cbiAgICAgICAgaWYgKHRoaXMuaXNDaGVja2VkKSB7XG4gICAgICAgICAgICB0aGlzLmV1aVRhYmxlU2VsZWN0YWJsZVJvd1NlcnZpY2Uuc2VsZWN0QWxsUm93cygpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5ldWlUYWJsZVNlbGVjdGFibGVSb3dTZXJ2aWNlLnVuc2VsZWN0QWxsUm93cygpO1xuICAgICAgICB9XG4gICAgfVxufVxuIiwiPHRoICpuZ0lmPVwiaXNTZWxlY3RhYmxlSGVhZGVyXCIgY2xhc3M9XCJldWktdGFibGVfX2NlbGwtc2VsZWN0XCI+XG4gICAgPGRpdiBjbGFzcz1cImV1aS10YWJsZV9fY2VsbC1zZWxlY3QtY2hlY2tib3gtY29udGFpbmVyXCI+XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgICAgKm5nSWY9XCIhaXNDaGVja2VkICYmICFpc0NoZWNrZWRJbmRldGVybWluYXRlXCJcbiAgICAgICAgICAgIGFyaWEtbGFiZWw9XCJVbmNoZWNrZWRcIlxuICAgICAgICAgICAgZXVpSW5wdXRDaGVja0JveFxuICAgICAgICAgICAgY2hlY2tlZD1cImZhbHNlXCJcbiAgICAgICAgICAgIChjbGljayk9XCJ0b2dnbGVDaGVja2VkU3RhdGUodHJ1ZSlcIiAvPlxuICAgICAgICA8aW5wdXRcbiAgICAgICAgICAgICpuZ0lmPVwiaXNDaGVja2VkSW5kZXRlcm1pbmF0ZVwiXG4gICAgICAgICAgICBhcmlhLWxhYmVsPVwiSW5kZXRlcm1pbmF0ZVwiXG4gICAgICAgICAgICBldWlJbnB1dENoZWNrQm94XG4gICAgICAgICAgICBpbmRldGVybWluYXRlXG4gICAgICAgICAgICAoY2xpY2spPVwidG9nZ2xlQ2hlY2tlZFN0YXRlKGZhbHNlKVwiIC8+XG4gICAgICAgIDxpbnB1dFxuICAgICAgICAgICAgKm5nSWY9XCJpc0NoZWNrZWQgJiYgIWlzQ2hlY2tlZEluZGV0ZXJtaW5hdGVcIlxuICAgICAgICAgICAgYXJpYS1sYWJlbD1cIkNoZWNrZWRcIlxuICAgICAgICAgICAgZXVpSW5wdXRDaGVja0JveFxuICAgICAgICAgICAgY2hlY2tlZD1cInRydWVcIlxuICAgICAgICAgICAgKGNsaWNrKT1cInRvZ2dsZUNoZWNrZWRTdGF0ZShmYWxzZSlcIiAvPlxuICAgIDwvZGl2PlxuPC90aD5cbjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpLXRhYmxlLXNlbGVjdGFibGUtaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2V1aS10YWJsZS9zZWxlY3RhYmxlLWhlYWRlci9ldWktdGFibGUtc2VsZWN0YWJsZS1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vZXVpLXRhYmxlL3NlbGVjdGFibGUtaGVhZGVyL2V1aS10YWJsZS1zZWxlY3RhYmxlLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLEtBQUssRUFBYSxTQUFTLEVBQWMsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0csT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7QUFTMUMsTUFBTSxPQUFPLGlDQUFpQztJQVUxQyxZQUFvQiw0QkFBMEQ7UUFBMUQsaUNBQTRCLEdBQTVCLDRCQUE0QixDQUE4QjtRQVB2RSwyQkFBc0IsR0FBRyxLQUFLLENBQUM7UUFFRSx1QkFBa0IsR0FBRyxJQUFJLENBQUM7UUFDMUIsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUVsRCxhQUFRLEdBQXFCLElBQUksT0FBTyxFQUFXLENBQUM7SUFFcUIsQ0FBQztJQUVsRixRQUFRO1FBQ0osSUFBSSxDQUFDLDRCQUE0QixDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUU7WUFDdkcsSUFBSSxDQUFDLFNBQVMsR0FBRyxRQUFRLENBQUM7WUFDMUIsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7Z0JBQ2hCLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLE9BQU8sR0FBRyxRQUFRLENBQUM7WUFDbkQsQ0FBQztZQUVELElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLDRCQUE0QixDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO2dCQUNoRixJQUFJLENBQUMsc0JBQXNCLEdBQUcsSUFBSSxDQUFDO1lBQ3ZDLENBQUM7aUJBQU0sQ0FBQztnQkFDSixJQUFJLENBQUMsc0JBQXNCLEdBQUcsS0FBSyxDQUFDO1lBQ3hDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDekIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNoQyxDQUFDO0lBRU0sa0JBQWtCLENBQUMsS0FBYztRQUNwQyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztRQUV2QixJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsNEJBQTRCLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDdEQsQ0FBQzthQUFNLENBQUM7WUFDSixJQUFJLENBQUMsNEJBQTRCLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDeEQsQ0FBQztJQUNMLENBQUM7cUhBeENRLGlDQUFpQzt5R0FBakMsaUNBQWlDLGlIQUt0QixnQkFBZ0IseUNBQ2hCLGdCQUFnQixtSUNoQnhDLHd3QkFpQkE7O2tHRFBhLGlDQUFpQztrQkFMN0MsU0FBUzsrQkFFSSx3QkFBd0I7aUdBSVgsUUFBUTtzQkFBOUIsU0FBUzt1QkFBQyxVQUFVO2dCQUltQixrQkFBa0I7c0JBQXpELEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBQ0UsU0FBUztzQkFBaEQsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCwgT25EZXN0cm95LCBWaWV3Q2hpbGQsIEVsZW1lbnRSZWYsIGJvb2xlYW5BdHRyaWJ1dGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBFdWlUYWJsZVNlbGVjdGFibGVSb3dTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvZXVpLXRhYmxlLXNlbGVjdGFibGUtcm93LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgICBzZWxlY3RvcjogJ3RyW2lzU2VsZWN0YWJsZUhlYWRlcl0nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ldWktdGFibGUtc2VsZWN0YWJsZS1oZWFkZXIuY29tcG9uZW50Lmh0bWwnLFxufSlcbmV4cG9ydCBjbGFzcyBFdWlUYWJsZVNlbGVjdGFibGVIZWFkZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gICAgQFZpZXdDaGlsZCgnY2hlY2tib3gnKSBjaGVja2JveDogRWxlbWVudFJlZjxIVE1MSW5wdXRFbGVtZW50PjtcblxuICAgIHB1YmxpYyBpc0NoZWNrZWRJbmRldGVybWluYXRlID0gZmFsc2U7XG5cbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSkgaXNTZWxlY3RhYmxlSGVhZGVyID0gdHJ1ZTtcbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSkgaXNDaGVja2VkID0gZmFsc2U7XG5cbiAgICBwcml2YXRlIGRlc3Ryb3kkOiBTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IFN1YmplY3Q8Ym9vbGVhbj4oKTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZXVpVGFibGVTZWxlY3RhYmxlUm93U2VydmljZTogRXVpVGFibGVTZWxlY3RhYmxlUm93U2VydmljZSkge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmV1aVRhYmxlU2VsZWN0YWJsZVJvd1NlcnZpY2UuaXNBbGxSb3dzU2VsZWN0ZWQkLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSQpKS5zdWJzY3JpYmUoKHNlbGVjdGVkKSA9PiB7XG4gICAgICAgICAgICB0aGlzLmlzQ2hlY2tlZCA9IHNlbGVjdGVkO1xuICAgICAgICAgICAgaWYgKHRoaXMuY2hlY2tib3gpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmNoZWNrYm94Lm5hdGl2ZUVsZW1lbnQuY2hlY2tlZCA9IHNlbGVjdGVkO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBpZiAoIXNlbGVjdGVkICYmIHRoaXMuZXVpVGFibGVTZWxlY3RhYmxlUm93U2VydmljZS5zZWxlY3RlZFJvd3MkLnZhbHVlLmxlbmd0aCA+IDApIHtcbiAgICAgICAgICAgICAgICB0aGlzLmlzQ2hlY2tlZEluZGV0ZXJtaW5hdGUgPSB0cnVlO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICB0aGlzLmlzQ2hlY2tlZEluZGV0ZXJtaW5hdGUgPSBmYWxzZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZGVzdHJveSQubmV4dCh0cnVlKTtcbiAgICAgICAgdGhpcy5kZXN0cm95JC51bnN1YnNjcmliZSgpO1xuICAgIH1cblxuICAgIHB1YmxpYyB0b2dnbGVDaGVja2VkU3RhdGUodmFsdWU6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5pc0NoZWNrZWQgPSB2YWx1ZTtcblxuICAgICAgICBpZiAodGhpcy5pc0NoZWNrZWQpIHtcbiAgICAgICAgICAgIHRoaXMuZXVpVGFibGVTZWxlY3RhYmxlUm93U2VydmljZS5zZWxlY3RBbGxSb3dzKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLmV1aVRhYmxlU2VsZWN0YWJsZVJvd1NlcnZpY2UudW5zZWxlY3RBbGxSb3dzKCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCJAaWYgKGlzU2VsZWN0YWJsZUhlYWRlcikge1xuICAgIDx0aCBjbGFzcz1cImV1aS10YWJsZV9fY2VsbC1zZWxlY3RcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImV1aS10YWJsZV9fY2VsbC1zZWxlY3QtY2hlY2tib3gtY29udGFpbmVyXCI+XG4gICAgICAgICAgICBAaWYgKCFpc0NoZWNrZWQgJiYgIWlzQ2hlY2tlZEluZGV0ZXJtaW5hdGUpIHtcbiAgICAgICAgICAgICAgICA8aW5wdXQgYXJpYS1sYWJlbD1cIlVuY2hlY2tlZFwiIGV1aUlucHV0Q2hlY2tCb3ggY2hlY2tlZD1cImZhbHNlXCIgKGNsaWNrKT1cInRvZ2dsZUNoZWNrZWRTdGF0ZSh0cnVlKVwiIC8+XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBAaWYgKGlzQ2hlY2tlZEluZGV0ZXJtaW5hdGUpIHtcbiAgICAgICAgICAgICAgICA8aW5wdXQgYXJpYS1sYWJlbD1cIkluZGV0ZXJtaW5hdGVcIiBldWlJbnB1dENoZWNrQm94IGluZGV0ZXJtaW5hdGUgKGNsaWNrKT1cInRvZ2dsZUNoZWNrZWRTdGF0ZShmYWxzZSlcIiAvPlxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgQGlmIChpc0NoZWNrZWQgJiYgIWlzQ2hlY2tlZEluZGV0ZXJtaW5hdGUpIHtcbiAgICAgICAgICAgICAgICA8aW5wdXQgYXJpYS1sYWJlbD1cIkNoZWNrZWRcIiBldWlJbnB1dENoZWNrQm94IGNoZWNrZWQ9XCJ0cnVlXCIgKGNsaWNrKT1cInRvZ2dsZUNoZWNrZWRTdGF0ZShmYWxzZSlcIiAvPlxuICAgICAgICAgICAgfVxuICAgICAgICA8L2Rpdj5cbiAgICA8L3RoPlxufVxuXG48bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4iXX0=
@@ -1,24 +1,9 @@
1
- import { Component, Input, HostBinding, HostListener } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import { takeUntil } from 'rxjs/operators';
4
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
1
+ import { Component, Input, HostBinding, HostListener, booleanAttribute } from '@angular/core';
2
+ import { Subject, takeUntil } from 'rxjs';
5
3
  import * as i0 from "@angular/core";
6
4
  import * as i1 from "../services/eui-table-selectable-row.service";
7
- import * as i2 from "@angular/common";
8
- import * as i3 from "@eui/components/eui-input-checkbox";
5
+ import * as i2 from "@eui/components/eui-input-checkbox";
9
6
  export class EuiTableSelectableRowComponent {
10
- get isChecked() {
11
- return this._isChecked;
12
- }
13
- set isChecked(value) {
14
- this._isChecked = coerceBooleanProperty(value);
15
- }
16
- get isKeyboardSelectable() {
17
- return this._isKeyboardSelectable;
18
- }
19
- set isKeyboardSelectable(value) {
20
- this._isKeyboardSelectable = coerceBooleanProperty(value);
21
- }
22
7
  get cssClasses() {
23
8
  return ['eui-table__row', this.isSelectable ? 'eui-table__row--selectable' : '', this.isChecked ? 'eui-table__row--selected' : '']
24
9
  .join(' ')
@@ -26,8 +11,8 @@ export class EuiTableSelectableRowComponent {
26
11
  }
27
12
  constructor(euiTableSelectableRowService) {
28
13
  this.euiTableSelectableRowService = euiTableSelectableRowService;
29
- this._isChecked = false;
30
- this._isKeyboardSelectable = false;
14
+ this.isChecked = false;
15
+ this.isKeyboardSelectable = false;
31
16
  this.propId = 'id';
32
17
  this.destroy$ = new Subject();
33
18
  }
@@ -87,17 +72,19 @@ export class EuiTableSelectableRowComponent {
87
72
  e.stopPropagation();
88
73
  }
89
74
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.4", ngImport: i0, type: EuiTableSelectableRowComponent, deps: [{ token: i1.EuiTableSelectableRowService }], target: i0.ɵɵFactoryTarget.Component }); }
90
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-next.4", type: EuiTableSelectableRowComponent, selector: "tr[isSelectable]", inputs: { isSelectable: "isSelectable", isChecked: "isChecked", isKeyboardSelectable: "isKeyboardSelectable" }, host: { listeners: { "click": "onClickRow($event)" }, properties: { "class": "this.cssClasses" } }, usesOnChanges: true, ngImport: i0, template: "<td *ngIf=\"isSelectable\" class=\"eui-table__cell-select\">\n <div class=\"eui-table__cell-select-checkbox-container\">\n <input\n *ngIf=\"isChecked\"\n aria-label=\"default checkbox checked\"\n euiInputCheckBox\n checked=\"true\"\n (click)=\"toggleCheckedState($event)\" />\n <input\n *ngIf=\"!isChecked\"\n aria-label=\"default checkbox unchecked\"\n euiInputCheckBox\n checked=\"false\"\n (click)=\"toggleCheckedState($event)\" />\n </div>\n</td>\n<ng-content></ng-content>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.EuiInputCheckboxComponent, selector: "input[euiInputCheckBox]", inputs: ["indeterminate", "isInvalid", "styleClass", "checked", "id"], outputs: ["indeterminateChange"] }] }); }
75
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-next.4", type: EuiTableSelectableRowComponent, selector: "tr[isSelectable]", inputs: { isSelectable: "isSelectable", isChecked: ["isChecked", "isChecked", booleanAttribute], isKeyboardSelectable: ["isKeyboardSelectable", "isKeyboardSelectable", booleanAttribute] }, host: { listeners: { "click": "onClickRow($event)" }, properties: { "class": "this.cssClasses" } }, usesOnChanges: true, ngImport: i0, template: "@if (isSelectable) {\n <td class=\"eui-table__cell-select\">\n <div class=\"eui-table__cell-select-checkbox-container\">\n @if (isChecked) {\n <input aria-label=\"default checkbox checked\" euiInputCheckBox checked=\"true\" (click)=\"toggleCheckedState($event)\" />\n }\n @if (!isChecked) {\n <input aria-label=\"default checkbox unchecked\" euiInputCheckBox checked=\"false\" (click)=\"toggleCheckedState($event)\" />\n }\n </div>\n </td>\n}\n<ng-content></ng-content>\n", dependencies: [{ kind: "component", type: i2.EuiInputCheckboxComponent, selector: "input[euiInputCheckBox]", inputs: ["indeterminate", "isInvalid", "styleClass", "checked", "id"], outputs: ["indeterminateChange"] }] }); }
91
76
  }
92
77
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.4", ngImport: i0, type: EuiTableSelectableRowComponent, decorators: [{
93
78
  type: Component,
94
- args: [{ selector: 'tr[isSelectable]', template: "<td *ngIf=\"isSelectable\" class=\"eui-table__cell-select\">\n <div class=\"eui-table__cell-select-checkbox-container\">\n <input\n *ngIf=\"isChecked\"\n aria-label=\"default checkbox checked\"\n euiInputCheckBox\n checked=\"true\"\n (click)=\"toggleCheckedState($event)\" />\n <input\n *ngIf=\"!isChecked\"\n aria-label=\"default checkbox unchecked\"\n euiInputCheckBox\n checked=\"false\"\n (click)=\"toggleCheckedState($event)\" />\n </div>\n</td>\n<ng-content></ng-content>\n" }]
79
+ args: [{ selector: 'tr[isSelectable]', template: "@if (isSelectable) {\n <td class=\"eui-table__cell-select\">\n <div class=\"eui-table__cell-select-checkbox-container\">\n @if (isChecked) {\n <input aria-label=\"default checkbox checked\" euiInputCheckBox checked=\"true\" (click)=\"toggleCheckedState($event)\" />\n }\n @if (!isChecked) {\n <input aria-label=\"default checkbox unchecked\" euiInputCheckBox checked=\"false\" (click)=\"toggleCheckedState($event)\" />\n }\n </div>\n </td>\n}\n<ng-content></ng-content>\n" }]
95
80
  }], ctorParameters: () => [{ type: i1.EuiTableSelectableRowService }], propDecorators: { isSelectable: [{
96
81
  type: Input
97
82
  }], isChecked: [{
98
- type: Input
83
+ type: Input,
84
+ args: [{ transform: booleanAttribute }]
99
85
  }], isKeyboardSelectable: [{
100
- type: Input
86
+ type: Input,
87
+ args: [{ transform: booleanAttribute }]
101
88
  }], cssClasses: [{
102
89
  type: HostBinding,
103
90
  args: ['class']
@@ -105,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.4",
105
92
  type: HostListener,
106
93
  args: ['click', ['$event']]
107
94
  }] } });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-table-selectable-row.component.js","sourceRoot":"","sources":["../../../../eui-table/selectable-row/eui-table-selectable-row.component.ts","../../../../eui-table/selectable-row/eui-table-selectable-row.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAwB,WAAW,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC1G,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,qBAAqB,EAAgB,MAAM,uBAAuB,CAAC;;;;;AAS5E,MAAM,OAAO,8BAA8B;IAIvC,IACI,SAAS;QACT,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IACD,IAAI,SAAS,CAAC,KAAmB;QAC7B,IAAI,CAAC,UAAU,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IAGD,IACI,oBAAoB;QACpB,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACtC,CAAC;IACD,IAAI,oBAAoB,CAAC,KAAmB;QACxC,IAAI,CAAC,qBAAqB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC9D,CAAC;IAMD,IACI,UAAU;QACV,OAAO,CAAC,gBAAgB,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE,CAAC;aAC7H,IAAI,CAAC,GAAG,CAAC;aACT,IAAI,EAAE,CAAC;IAChB,CAAC;IAED,YAAoB,4BAA0D;QAA1D,iCAA4B,GAA5B,4BAA4B,CAA8B;QArBtE,eAAU,GAAG,KAAK,CAAC;QASnB,0BAAqB,GAAG,KAAK,CAAC;QAE9B,WAAM,GAAG,IAAI,CAAC;QACd,aAAQ,GAAqB,IAAI,OAAO,EAAW,CAAC;IASqB,CAAC;IAE/C,UAAU,CAAC,KAAmB;QAC7D,IAAI,IAAI,CAAC,oBAAoB,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACjD,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;gBAChB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;oBAClB,IAAI,CAAC,4BAA4B,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACxE,CAAC;qBAAM,CAAC;oBACJ,IAAI,CAAC,4BAA4B,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBAC3E,CAAC;YACL,CAAC;iBAAM,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;gBACxB,MAAM,IAAI,GAAG,IAAI,CAAC,4BAA4B,CAAC,OAAO,EAAE,CAAC;gBACzD,MAAM,eAAe,GAAG,IAAI,CAAC,4BAA4B,CAAC,kBAAkB,EAAE,CAAC;gBAC/E,MAAM,uBAAuB,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;gBAC9D,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBAEjD,MAAM,KAAK,GACP,uBAAuB,GAAG,QAAQ;oBAC9B,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,uBAAuB,GAAG,CAAC,CAAC;oBACnD,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,uBAAuB,EAAE,QAAQ,GAAG,CAAC,CAAC,CAAC;gBAE5D,IAAI,CAAC,4BAA4B,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;gBAEzD,MAAM,CAAC,YAAY,EAAE,CAAC,KAAK,EAAE,CAAC;YAClC,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,4BAA4B,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YACtE,CAAC;QACL,CAAC;IACL,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,4BAA4B,CAAC,SAAS,EAAE,CAAC;YAC5D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,4BAA4B,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CACvE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAC3D;gBACG,CAAC,CAAC,IAAI;gBACN,CAAC,CAAC,KAAK,CAAC;QAChB,CAAC;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,4BAA4B,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YAClG,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;QAC1G,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAChC,CAAC;IAED,mHAAmH;IACnH,8DAA8D;IACvD,kBAAkB,CAAC,CAAM;QAC5B,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YAClB,IAAI,CAAC,4BAA4B,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACxE,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,4BAA4B,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC3E,CAAC;QAED,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;IACxB,CAAC;qHA/FQ,8BAA8B;yGAA9B,8BAA8B,iSCZ3C,mmBAiBA;;kGDLa,8BAA8B;kBAL1C,SAAS;+BAEI,kBAAkB;iGAMnB,YAAY;sBAApB,KAAK;gBAEF,SAAS;sBADZ,KAAK;gBAUF,oBAAoB;sBADvB,KAAK;gBAaF,UAAU;sBADb,WAAW;uBAAC,OAAO;gBASe,UAAU;sBAA5C,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, OnInit, Input, OnDestroy, OnChanges, HostBinding, HostListener } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { coerceBooleanProperty, BooleanInput } from '@angular/cdk/coercion';\n\nimport { EuiTableSelectableRowService } from '../services/eui-table-selectable-row.service';\n\n@Component({\n    // eslint-disable-next-line\n    selector: 'tr[isSelectable]',\n    templateUrl: './eui-table-selectable-row.component.html',\n})\nexport class EuiTableSelectableRowComponent implements OnInit, OnDestroy, OnChanges {\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() isSelectable: any;\n    @Input()\n    get isChecked(): boolean {\n        return this._isChecked;\n    }\n    set isChecked(value: BooleanInput) {\n        this._isChecked = coerceBooleanProperty(value);\n    }\n    private _isChecked = false;\n\n    @Input()\n    get isKeyboardSelectable(): boolean {\n        return this._isKeyboardSelectable;\n    }\n    set isKeyboardSelectable(value: BooleanInput) {\n        this._isKeyboardSelectable = coerceBooleanProperty(value);\n    }\n    private _isKeyboardSelectable = false;\n\n    private propId = 'id';\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return ['eui-table__row', this.isSelectable ? 'eui-table__row--selectable' : '', this.isChecked ? 'eui-table__row--selected' : '']\n            .join(' ')\n            .trim();\n    }\n\n    constructor(private euiTableSelectableRowService: EuiTableSelectableRowService) {}\n\n    @HostListener('click', ['$event']) onClickRow(event: PointerEvent): void {\n        if (this.isKeyboardSelectable && this.isSelectable) {\n            if (event.ctrlKey) {\n                if (!this.isChecked) {\n                    this.euiTableSelectableRowService.addSelectedRow(this.isSelectable);\n                } else {\n                    this.euiTableSelectableRowService.removeSelectedRow(this.isSelectable);\n                }\n            } else if (event.shiftKey) {\n                const rows = this.euiTableSelectableRowService.getRows();\n                const lastSelectedRow = this.euiTableSelectableRowService.getLastSelectedRow();\n                const lastSelectedRowPosition = rows.indexOf(lastSelectedRow);\n                const position = rows.indexOf(this.isSelectable);\n\n                const range =\n                    lastSelectedRowPosition > position\n                        ? rows.slice(position, lastSelectedRowPosition + 1)\n                        : rows.slice(lastSelectedRowPosition, position + 1);\n\n                this.euiTableSelectableRowService.addSelectedRows(range);\n\n                window.getSelection().empty();\n            } else {\n                this.euiTableSelectableRowService.selectRows([this.isSelectable]);\n            }\n        }\n    }\n\n    ngOnChanges(): void {\n        if (this.isSelectable) {\n            this.propId = this.euiTableSelectableRowService.getPropId();\n            this.isChecked = this.euiTableSelectableRowService.selectedRows$.value.find(\n                (s) => s[this.propId] === this.isSelectable[this.propId],\n            )\n                ? true\n                : false;\n        }\n    }\n\n    ngOnInit(): void {\n        this.euiTableSelectableRowService.selectedRows$.pipe(takeUntil(this.destroy$)).subscribe((selected) => {\n            this.isChecked = selected.filter((s) => s[this.propId] === this.isSelectable[this.propId]).length > 0;\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public toggleCheckedState(e: any): void {\n        if (!this.isChecked) {\n            this.euiTableSelectableRowService.addSelectedRow(this.isSelectable);\n        } else {\n            this.euiTableSelectableRowService.removeSelectedRow(this.isSelectable);\n        }\n\n        e.preventDefault();\n        e.stopPropagation();\n    }\n}\n","<td *ngIf=\"isSelectable\" class=\"eui-table__cell-select\">\n    <div class=\"eui-table__cell-select-checkbox-container\">\n        <input\n            *ngIf=\"isChecked\"\n            aria-label=\"default checkbox checked\"\n            euiInputCheckBox\n            checked=\"true\"\n            (click)=\"toggleCheckedState($event)\" />\n        <input\n            *ngIf=\"!isChecked\"\n            aria-label=\"default checkbox unchecked\"\n            euiInputCheckBox\n            checked=\"false\"\n            (click)=\"toggleCheckedState($event)\" />\n    </div>\n</td>\n<ng-content></ng-content>\n"]}
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-table-selectable-row.component.js","sourceRoot":"","sources":["../../../../eui-table/selectable-row/eui-table-selectable-row.component.ts","../../../../eui-table/selectable-row/eui-table-selectable-row.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, OnChanges, HostBinding, HostListener, booleanAttribute } from '@angular/core';\nimport { Subject, takeUntil } from 'rxjs';\n\nimport { EuiTableSelectableRowService } from '../services/eui-table-selectable-row.service';\n\n@Component({\n    // eslint-disable-next-line\n    selector: 'tr[isSelectable]',\n    templateUrl: './eui-table-selectable-row.component.html',\n})\nexport class EuiTableSelectableRowComponent implements OnInit, OnDestroy, OnChanges {\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() isSelectable: any;\n    @Input({ transform: booleanAttribute }) isChecked = false;\n    @Input({ transform: booleanAttribute }) isKeyboardSelectable = false;\n\n    private propId = 'id';\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return ['eui-table__row', this.isSelectable ? 'eui-table__row--selectable' : '', this.isChecked ? 'eui-table__row--selected' : '']\n            .join(' ')\n            .trim();\n    }\n\n    constructor(private euiTableSelectableRowService: EuiTableSelectableRowService) {}\n\n    @HostListener('click', ['$event']) onClickRow(event: PointerEvent): void {\n        if (this.isKeyboardSelectable && this.isSelectable) {\n            if (event.ctrlKey) {\n                if (!this.isChecked) {\n                    this.euiTableSelectableRowService.addSelectedRow(this.isSelectable);\n                } else {\n                    this.euiTableSelectableRowService.removeSelectedRow(this.isSelectable);\n                }\n            } else if (event.shiftKey) {\n                const rows = this.euiTableSelectableRowService.getRows();\n                const lastSelectedRow = this.euiTableSelectableRowService.getLastSelectedRow();\n                const lastSelectedRowPosition = rows.indexOf(lastSelectedRow);\n                const position = rows.indexOf(this.isSelectable);\n\n                const range =\n                    lastSelectedRowPosition > position\n                        ? rows.slice(position, lastSelectedRowPosition + 1)\n                        : rows.slice(lastSelectedRowPosition, position + 1);\n\n                this.euiTableSelectableRowService.addSelectedRows(range);\n\n                window.getSelection().empty();\n            } else {\n                this.euiTableSelectableRowService.selectRows([this.isSelectable]);\n            }\n        }\n    }\n\n    ngOnChanges(): void {\n        if (this.isSelectable) {\n            this.propId = this.euiTableSelectableRowService.getPropId();\n            this.isChecked = this.euiTableSelectableRowService.selectedRows$.value.find(\n                (s) => s[this.propId] === this.isSelectable[this.propId],\n            )\n                ? true\n                : false;\n        }\n    }\n\n    ngOnInit(): void {\n        this.euiTableSelectableRowService.selectedRows$.pipe(takeUntil(this.destroy$)).subscribe((selected) => {\n            this.isChecked = selected.filter((s) => s[this.propId] === this.isSelectable[this.propId]).length > 0;\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public toggleCheckedState(e: any): void {\n        if (!this.isChecked) {\n            this.euiTableSelectableRowService.addSelectedRow(this.isSelectable);\n        } else {\n            this.euiTableSelectableRowService.removeSelectedRow(this.isSelectable);\n        }\n\n        e.preventDefault();\n        e.stopPropagation();\n    }\n}\n","@if (isSelectable) {\n    <td class=\"eui-table__cell-select\">\n        <div class=\"eui-table__cell-select-checkbox-container\">\n            @if (isChecked) {\n                <input aria-label=\"default checkbox checked\" euiInputCheckBox checked=\"true\" (click)=\"toggleCheckedState($event)\" />\n            }\n            @if (!isChecked) {\n                <input aria-label=\"default checkbox unchecked\" euiInputCheckBox checked=\"false\" (click)=\"toggleCheckedState($event)\" />\n            }\n        </div>\n    </td>\n}\n<ng-content></ng-content>\n"]}