@eui/components 18.0.0-rc.24 → 18.0.0-rc.26
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/docs/components/ChartComponent.html +10 -124
- package/docs/components/EuiEditorCountersComponent.html +15 -202
- package/docs/components/EuiNotificationItemComponent.html +5 -62
- package/docs/components/EuiNotificationItemV2Component.html +5 -62
- package/docs/components/EuiNotificationsComponent.html +40 -512
- package/docs/components/EuiNotificationsV2Component.html +40 -507
- package/docs/components/EuiPageBreadcrumbComponent.html +8 -0
- package/docs/components/EuiPageColumnComponent.html +19 -113
- package/docs/components/EuiPageColumnsComponent.html +8 -0
- package/docs/components/EuiPageComponent.html +8 -0
- package/docs/components/EuiPageContentComponent.html +8 -0
- package/docs/components/EuiPageFooterComponent.html +8 -0
- package/docs/components/EuiPageHeaderActionItemsComponent.html +8 -0
- package/docs/components/EuiPageHeaderBodyComponent.html +8 -0
- package/docs/components/EuiPageHeaderComponent.html +15 -2
- package/docs/components/EuiPageHeaderSubLabelComponent.html +8 -0
- package/docs/components/EuiPageHeroHeaderComponent.html +8 -0
- package/docs/components/EuiPageTopContentComponent.html +8 -0
- package/docs/components/EuiPaginatorComponent.html +15 -209
- package/docs/components/EuiSelectComponent.html +0 -62
- package/docs/components/EuiTreeComponent.html +45 -558
- package/docs/components/EuiWizardComponent.html +15 -202
- package/docs/components/EuiWizardStepComponent.html +30 -388
- package/docs/components/QuillEditorComponent.html +20 -326
- package/docs/dependencies.html +3 -1
- package/docs/directives/AutoResizeDirective.html +5 -62
- package/docs/directives/EuiNgSelectOptionDirective.html +0 -62
- package/docs/directives/EuiPageColumnBodyContentDirective.html +4 -0
- package/docs/directives/EuiPageColumnFooterContentDirective.html +4 -0
- package/docs/directives/EuiPageColumnHeaderBodyContentDirective.html +4 -0
- package/docs/directives/EuiPageColumnHeaderCollapsedContentDirective.html +4 -0
- package/docs/directives/EuiPageColumnHeaderLeftContentDirective.html +4 -0
- package/docs/directives/EuiPageColumnHeaderRightContentDirective.html +4 -0
- package/docs/js/menu-wc.js +90 -20
- package/docs/js/menu-wc_es5.js +1 -1
- package/docs/js/search/search_index.js +2 -2
- package/docs/miscellaneous/variables.html +51 -51
- package/docs/modules/EuiHeaderModule.html +68 -20
- package/docs/modules/EuiPageModule.html +95 -17
- package/docs/modules/EuiToolbarModule.html +68 -20
- package/esm2022/eui-page/components/eui-page-breadcrumb/eui-page-breadcrumb.component.mjs +5 -3
- package/esm2022/eui-page/components/eui-page-column/eui-page-column.component.mjs +29 -42
- package/esm2022/eui-page/components/eui-page-columns/eui-page-columns.component.mjs +5 -3
- package/esm2022/eui-page/components/eui-page-content/eui-page-content.component.mjs +5 -3
- package/esm2022/eui-page/components/eui-page-footer/eui-page-footer.component.mjs +5 -3
- package/esm2022/eui-page/components/eui-page-header/components/eui-page-header-action-items.component.mjs +5 -3
- package/esm2022/eui-page/components/eui-page-header/components/eui-page-header-body.component.mjs +5 -3
- package/esm2022/eui-page/components/eui-page-header/components/eui-page-header-sub-label.component.mjs +5 -3
- package/esm2022/eui-page/components/eui-page-header/eui-page-header.component.mjs +14 -6
- package/esm2022/eui-page/components/eui-page-hero-header/eui-page-hero-header.component.mjs +4 -4
- package/esm2022/eui-page/components/eui-page-top-content/eui-page-top-content.component.mjs +5 -3
- package/esm2022/eui-page/eui-page.component.mjs +4 -4
- package/esm2022/eui-page/eui-page.module.mjs +9 -28
- package/esm2022/eui-paginator/eui-paginator.component.mjs +12 -28
- package/esm2022/eui-select/eui-select-option.directive.mjs +6 -12
- package/esm2022/eui-select/eui-select.component.mjs +5 -10
- package/esm2022/eui-sidebar-menu/eui-sidebar-menu.component.mjs +2 -2
- package/esm2022/eui-textarea/auto-resize.directive.mjs +7 -12
- package/esm2022/eui-tree/eui-tree.component.mjs +31 -78
- package/esm2022/eui-wizard/eui-wizard-step.component.mjs +21 -52
- package/esm2022/eui-wizard/eui-wizard.component.mjs +12 -28
- package/esm2022/externals/charts/chart/chart.component.mjs +9 -12
- package/esm2022/externals/eui-editor/counters/eui-editor-counters.component.mjs +12 -28
- package/esm2022/externals/quill/quill-editor.component.mjs +17 -43
- package/esm2022/layout/eui-notifications/eui-notification-item.component.mjs +6 -12
- package/esm2022/layout/eui-notifications/eui-notifications.component.mjs +27 -68
- package/esm2022/layout/eui-notifications-v2/eui-notification-item.component.mjs +6 -12
- package/esm2022/layout/eui-notifications-v2/eui-notifications.component.mjs +30 -77
- package/eui-page/components/eui-page-breadcrumb/eui-page-breadcrumb.component.d.ts +1 -1
- package/eui-page/components/eui-page-breadcrumb/eui-page-breadcrumb.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-column/eui-page-column.component.d.ts +7 -8
- package/eui-page/components/eui-page-column/eui-page-column.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-columns/eui-page-columns.component.d.ts +1 -1
- package/eui-page/components/eui-page-columns/eui-page-columns.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-content/eui-page-content.component.d.ts +1 -1
- package/eui-page/components/eui-page-content/eui-page-content.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-footer/eui-page-footer.component.d.ts +1 -1
- package/eui-page/components/eui-page-footer/eui-page-footer.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-header/components/eui-page-header-action-items.component.d.ts +1 -1
- package/eui-page/components/eui-page-header/components/eui-page-header-action-items.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-header/components/eui-page-header-body.component.d.ts +1 -1
- package/eui-page/components/eui-page-header/components/eui-page-header-body.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-header/components/eui-page-header-sub-label.component.d.ts +1 -1
- package/eui-page/components/eui-page-header/components/eui-page-header-sub-label.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-header/eui-page-header.component.d.ts +1 -1
- package/eui-page/components/eui-page-header/eui-page-header.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-hero-header/eui-page-hero-header.component.d.ts +1 -1
- package/eui-page/components/eui-page-hero-header/eui-page-hero-header.component.d.ts.map +1 -1
- package/eui-page/components/eui-page-top-content/eui-page-top-content.component.d.ts +1 -1
- package/eui-page/components/eui-page-top-content/eui-page-top-content.component.d.ts.map +1 -1
- package/eui-page/eui-page.component.d.ts +1 -1
- package/eui-page/eui-page.component.d.ts.map +1 -1
- package/eui-page/eui-page.module.d.ts +1 -6
- package/eui-page/eui-page.module.d.ts.map +1 -1
- package/eui-paginator/eui-paginator.component.d.ts +6 -10
- package/eui-paginator/eui-paginator.component.d.ts.map +1 -1
- package/eui-select/eui-select-option.directive.d.ts +2 -4
- package/eui-select/eui-select-option.directive.d.ts.map +1 -1
- package/eui-select/eui-select.component.d.ts +2 -3
- package/eui-select/eui-select.component.d.ts.map +1 -1
- package/eui-textarea/auto-resize.directive.d.ts +3 -5
- package/eui-textarea/auto-resize.directive.d.ts.map +1 -1
- package/eui-tree/eui-tree.component.d.ts +18 -28
- package/eui-tree/eui-tree.component.d.ts.map +1 -1
- package/eui-wizard/eui-wizard-step.component.d.ts +12 -19
- package/eui-wizard/eui-wizard-step.component.d.ts.map +1 -1
- package/eui-wizard/eui-wizard.component.d.ts +6 -10
- package/eui-wizard/eui-wizard.component.d.ts.map +1 -1
- package/externals/charts/chart/chart.component.d.ts +4 -7
- package/externals/charts/chart/chart.component.d.ts.map +1 -1
- package/externals/eui-editor/counters/eui-editor-counters.component.d.ts +6 -10
- package/externals/eui-editor/counters/eui-editor-counters.component.d.ts.map +1 -1
- package/externals/quill/quill-editor.component.d.ts +10 -16
- package/externals/quill/quill-editor.component.d.ts.map +1 -1
- package/fesm2022/eui-components-eui-page.mjs +73 -83
- package/fesm2022/eui-components-eui-page.mjs.map +1 -1
- package/fesm2022/eui-components-eui-paginator.mjs +11 -27
- package/fesm2022/eui-components-eui-paginator.mjs.map +1 -1
- package/fesm2022/eui-components-eui-select.mjs +8 -18
- package/fesm2022/eui-components-eui-select.mjs.map +1 -1
- package/fesm2022/eui-components-eui-sidebar-menu.mjs +2 -2
- package/fesm2022/eui-components-eui-textarea.mjs +4 -9
- package/fesm2022/eui-components-eui-textarea.mjs.map +1 -1
- package/fesm2022/eui-components-eui-tree.mjs +30 -77
- package/fesm2022/eui-components-eui-tree.mjs.map +1 -1
- package/fesm2022/eui-components-eui-wizard.mjs +30 -76
- package/fesm2022/eui-components-eui-wizard.mjs.map +1 -1
- package/fesm2022/eui-components-externals-charts.mjs +8 -11
- package/fesm2022/eui-components-externals-charts.mjs.map +1 -1
- package/fesm2022/eui-components-externals-eui-editor.mjs +11 -26
- package/fesm2022/eui-components-externals-eui-editor.mjs.map +1 -1
- package/fesm2022/eui-components-externals-quill.mjs +16 -42
- package/fesm2022/eui-components-externals-quill.mjs.map +1 -1
- package/fesm2022/eui-components-layout.mjs +61 -157
- package/fesm2022/eui-components-layout.mjs.map +1 -1
- package/layout/eui-notifications/eui-notification-item.component.d.ts +2 -4
- package/layout/eui-notifications/eui-notification-item.component.d.ts.map +1 -1
- package/layout/eui-notifications/eui-notifications.component.d.ts +16 -25
- package/layout/eui-notifications/eui-notifications.component.d.ts.map +1 -1
- package/layout/eui-notifications-v2/eui-notification-item.component.d.ts +2 -4
- package/layout/eui-notifications-v2/eui-notification-item.component.d.ts.map +1 -1
- package/layout/eui-notifications-v2/eui-notifications.component.d.ts +16 -25
- package/layout/eui-notifications-v2/eui-notifications.component.d.ts.map +1 -1
- package/package.json +3 -3
@@ -1,7 +1,6 @@
|
|
1
|
-
import { Component, Input, EventEmitter, Output, HostBinding, ViewEncapsulation, } from '@angular/core';
|
1
|
+
import { Component, Input, EventEmitter, Output, HostBinding, booleanAttribute, ViewEncapsulation, } from '@angular/core';
|
2
2
|
import { Subject, BehaviorSubject } from 'rxjs';
|
3
3
|
import { takeUntil, distinctUntilChanged } from 'rxjs/operators';
|
4
|
-
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
5
4
|
import { DecimalPipe } from '@angular/common';
|
6
5
|
import * as i0 from "@angular/core";
|
7
6
|
import * as i1 from "@eui/core";
|
@@ -18,24 +17,6 @@ export class EuiPaginatorComponent {
|
|
18
17
|
this.isHidden ? 'eui-paginator--hidden' : '',
|
19
18
|
].join(' ').trim();
|
20
19
|
}
|
21
|
-
get isHidden() {
|
22
|
-
return this._isHidden;
|
23
|
-
}
|
24
|
-
set isHidden(value) {
|
25
|
-
this._isHidden = coerceBooleanProperty(value);
|
26
|
-
}
|
27
|
-
get hasPageNumberNavigation() {
|
28
|
-
return this._hasPageNumberNavigation;
|
29
|
-
}
|
30
|
-
set hasPageNumberNavigation(value) {
|
31
|
-
this._hasPageNumberNavigation = coerceBooleanProperty(value);
|
32
|
-
}
|
33
|
-
get hasDynamicLength() {
|
34
|
-
return this._hasDynamicLength;
|
35
|
-
}
|
36
|
-
set hasDynamicLength(value) {
|
37
|
-
this._hasDynamicLength = coerceBooleanProperty(value);
|
38
|
-
}
|
39
20
|
constructor(EuiAppShellService, decimal) {
|
40
21
|
this.EuiAppShellService = EuiAppShellService;
|
41
22
|
this.decimal = decimal;
|
@@ -45,12 +26,12 @@ export class EuiPaginatorComponent {
|
|
45
26
|
this.page = 0;
|
46
27
|
this.length = 0;
|
47
28
|
this.nbPageNumberNavigation = 5;
|
48
|
-
this.
|
29
|
+
this.isHidden = false;
|
49
30
|
this.pageChange = new EventEmitter();
|
50
31
|
this.page$ = new BehaviorSubject(null);
|
51
32
|
this.length$ = new BehaviorSubject(0);
|
52
|
-
this.
|
53
|
-
this.
|
33
|
+
this.hasPageNumberNavigation = false;
|
34
|
+
this.hasDynamicLength = false;
|
54
35
|
this.destroy$ = new Subject();
|
55
36
|
}
|
56
37
|
ngOnChanges(c) {
|
@@ -184,7 +165,7 @@ export class EuiPaginatorComponent {
|
|
184
165
|
});
|
185
166
|
}
|
186
167
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiPaginatorComponent, deps: [{ token: i1.EuiAppShellService }, { token: i2.DecimalPipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
187
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
168
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: EuiPaginatorComponent, selector: "eui-paginator", inputs: { e2eAttr: "e2eAttr", pageSizeOptions: "pageSizeOptions", pageSize: "pageSize", page: "page", length: "length", nbPageNumberNavigation: "nbPageNumberNavigation", isHidden: ["isHidden", "isHidden", booleanAttribute], hasPageNumberNavigation: ["hasPageNumberNavigation", "hasPageNumberNavigation", booleanAttribute], hasDynamicLength: ["hasDynamicLength", "hasDynamicLength", booleanAttribute] }, outputs: { pageChange: "pageChange" }, host: { properties: { "attr.data-e2e": "this.e2eAttr", "class": "this.cssClasses" } }, providers: [DecimalPipe], usesOnChanges: true, ngImport: i0, template: "<div class=\"eui-paginator__page\">\n <div class=\"eui-paginator__page-selector\">\n <div>{{ 'eui.euitable.ITEMS-PER-PAGE' | translate }}:</div>\n <div class=\"eui-u-pl-xs eui-u-pb-2xs\">\n <select euiSelect class=\"page-size__select\" aria-label=\"Page size selected\" [(ngModel)]=\"pageSize\" (ngModelChange)=\"changePageSize($event)\">\n <option *ngFor=\"let pageSizeOption of pageSizeOptions\" value=\"{{ pageSizeOption }}\">{{ pageSizeOption }}</option>\n </select>\n </div>\n </div>\n <div *ngIf=\"(length$ | async) > 0\" class=\"eui-paginator__page-range\">\n {{ 'eui.euitable.SHOWING-RANGE' | translate: { range: range } }} {{ 'eui.euitable.RANGE-LABEL' | translate }}\n {{ rangeLength | number }}\n </div>\n</div>\n\n<div class=\"eui-paginator__page-navigation\">\n <div class=\"eui-paginator__page-navigation-item\">\n <button\n type=\"button\"\n euiSizeS\n euiButton\n euiIconButton\n euiBasicButton\n euiRounded\n [euiDisabled]=\"page === 0 || length === 0\"\n (click)=\"goFirstPage()\">\n <eui-icon-svg icon=\"play-skip-back:sharp\" fillColor=\"primary\" aria-label=\"Go to first page\"></eui-icon-svg>\n </button>\n </div>\n <div class=\"eui-paginator__page-navigation-item\">\n <button\n type=\"button\"\n euiSizeS\n euiButton\n euiIconButton\n euiBasicButton\n euiRounded\n [euiDisabled]=\"page === 0 || length === 0\"\n (click)=\"goPreviousPage()\">\n <!-- to be compliant with DS as play-back is not existing in ionicons -->\n <eui-icon-svg icon=\"play:sharp\" fillColor=\"primary\" transform=\"rotate-180\" aria-label=\"Go to previous page\"></eui-icon-svg>\n </button>\n </div>\n <div\n class=\"eui-paginator__page-navigation-numbers\"\n *ngIf=\"hasPageNumberNavigation\">\n <button\n type=\"button\"\n euiSizeS\n *ngFor=\"let pageNumber of pageNumberNavigation\"\n euiButton\n euiBasicButton\n euiRounded\n euiIconButton\n [euiOutline]=\"pageNumber === page\"\n (click)=\"goToPage(pageNumber)\">\n {{ pageNumber + 1 | number }}\n </button>\n </div>\n <div *ngIf=\"(length$ | async) > 0\" class=\"eui-paginator__page-range\">\n {{ range }} {{ 'eui.euitable.RANGE-LABEL' | translate }} {{ rangeLength }}\n </div>\n <div class=\"eui-paginator__page-navigation-item\">\n <button\n type=\"button\"\n euiSizeS\n euiButton\n euiIconButton\n euiBasicButton\n euiRounded\n [euiDisabled]=\"page + 1 === nbPage || length === 0\"\n (click)=\"goNextPage()\">\n <eui-icon-svg icon=\"play:sharp\" fillColor=\"primary\" aria-label=\"Go to next page\"></eui-icon-svg>\n </button>\n </div>\n <div class=\"eui-paginator__page-navigation-item\">\n <button\n type=\"button\"\n euiSizeS\n euiButton\n euiIconButton\n euiBasicButton\n euiRounded\n [euiDisabled]=\"page + 1 === nbPage || length === 0\"\n (click)=\"goLastPage()\">\n <eui-icon-svg icon=\"play-skip-forward:sharp\" fillColor=\"primary\" aria-label=\"Go to last page\"></eui-icon-svg>\n </button>\n </div>\n</div>\n", styles: [".eui-paginator{align-items:center;display:flex;flex-direction:row;justify-content:space-between;padding:var(--eui-s-s) 0;position:relative;width:100%}.eui-paginator--hidden{display:none}.eui-paginator__page{display:flex;flex-direction:column;font:var(--eui-f-l)}.eui-paginator__page-selector{align-items:center;display:inline-flex;flex-wrap:wrap;font:var(--eui-f-s)}.eui-paginator__page-selector .page-size__select{font-size:100%;min-height:var(--eui-s-xl);padding-bottom:0;padding-top:0}.eui-paginator__page-range{align-items:center;font:var(--eui-f-s);display:none}.eui-paginator__page-navigation{align-items:center;display:flex}.eui-paginator__page-navigation-item,.eui-paginator__page-navigation-numbers{align-items:center;display:inline-flex}.eui-card.eui-card--no-content-padding .eui-card-content .eui-paginator{padding:var(--eui-s-s)}@media screen and (max-width: 767px){.eui-paginator{align-items:center;display:flex;justify-content:center;margin:var(--eui-s-s) 0;width:100%}.eui-paginator__page{display:none}.eui-paginator__page-range{display:inline-flex;margin:0 var(--eui-s-m)}.eui-paginator__page-navigation-numbers{display:none}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "style", "iconUrl", "transform", "euiVariant", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "component", type: i4.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "euiIconButton", "euiLineWrap", "isChecked", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "directive", type: i5.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i5.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.EuiSelectComponent, selector: "select[euiSelect]", inputs: ["placeholder", "readonly", "isInvalid"] }, { kind: "directive", type: i6.EuiNgSelectOptionDirective, selector: "option:not([eclSelectOption]):not([eclMultiselectOption]), option[euiOption]", inputs: ["selected", "label", "ngValue"] }, { kind: "directive", type: i6.EuiSelectControlValueAccessor, selector: "select:not([multiple])[formControlName][euiSelect],select:not([multiple])[formControl][euiSelect],select:not([multiple])[ngModel][euiSelect]", inputs: ["placeholder"] }, { kind: "directive", type: i6.EuiSelectMultipleOption, selector: "option, option[euiOption]", inputs: ["ngValue", "value"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.DecimalPipe, name: "number" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
|
188
169
|
}
|
189
170
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiPaginatorComponent, decorators: [{
|
190
171
|
type: Component,
|
@@ -208,12 +189,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
208
189
|
}], nbPageNumberNavigation: [{
|
209
190
|
type: Input
|
210
191
|
}], isHidden: [{
|
211
|
-
type: Input
|
192
|
+
type: Input,
|
193
|
+
args: [{ transform: booleanAttribute }]
|
212
194
|
}], pageChange: [{
|
213
195
|
type: Output
|
214
196
|
}], hasPageNumberNavigation: [{
|
215
|
-
type: Input
|
197
|
+
type: Input,
|
198
|
+
args: [{ transform: booleanAttribute }]
|
216
199
|
}], hasDynamicLength: [{
|
217
|
-
type: Input
|
200
|
+
type: Input,
|
201
|
+
args: [{ transform: booleanAttribute }]
|
218
202
|
}] } });
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-paginator.component.js","sourceRoot":"","sources":["../../../eui-paginator/eui-paginator.component.ts","../../../eui-paginator/eui-paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    OnInit,\n    Input,\n    OnDestroy,\n    EventEmitter,\n    Output,\n    OnChanges,\n    SimpleChanges,\n    HostBinding,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { Subject, BehaviorSubject } from 'rxjs';\nimport { takeUntil, distinctUntilChanged } from 'rxjs/operators';\nimport { coerceBooleanProperty, BooleanInput } from '@angular/cdk/coercion';\nimport { EuiAppShellService } from '@eui/core';\n\nimport { EuiPaginationEvent } from './models/pagination-event.model';\nimport { DecimalPipe } from '@angular/common';\n\n@Component({\n    selector: 'eui-paginator',\n    templateUrl: './eui-paginator.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n    providers: [DecimalPipe],\n})\nexport class EuiPaginatorComponent implements OnInit, OnDestroy, OnChanges {\n    @HostBinding('attr.data-e2e') @Input() e2eAttr = 'eui-paginator';\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            'eui-paginator',\n            this.isHidden ? 'eui-paginator--hidden' : '',\n        ].join(' ').trim();\n    }\n    @Input() pageSizeOptions: number[] = [5, 10, 25, 50, 100];\n    @Input() pageSize = 10;\n    @Input() page = 0;\n    @Input() length = 0;\n    @Input() nbPageNumberNavigation = 5;\n    @Input()\n    get isHidden(): boolean {\n        return this._isHidden;\n    }\n    set isHidden(value: BooleanInput) {\n        this._isHidden = coerceBooleanProperty(value);\n    }\n    _isHidden = false;\n\n    @Output() pageChange = new EventEmitter<EuiPaginationEvent>();\n\n    public page$: BehaviorSubject<EuiPaginationEvent> = new BehaviorSubject(null);\n    public length$: BehaviorSubject<number> = new BehaviorSubject(0);\n    public range: string;\n    public rangeLength: string;\n    public nbPage: number;\n\n    @Input()\n    get hasPageNumberNavigation(): boolean {\n        return this._hasPageNumberNavigation;\n    }\n    set hasPageNumberNavigation(value: BooleanInput) {\n        this._hasPageNumberNavigation = coerceBooleanProperty(value);\n    }\n    private _hasPageNumberNavigation = false;\n    @Input()\n    get hasDynamicLength(): boolean {\n        return this._hasDynamicLength;\n    }\n    set hasDynamicLength(value: BooleanInput) {\n        this._hasDynamicLength = coerceBooleanProperty(value);\n    }\n    private _hasDynamicLength = false;\n\n    private nbPageNumberNav: number;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        public EuiAppShellService: EuiAppShellService,\n        private decimal: DecimalPipe,\n    ) {}\n\n    ngOnChanges(c: SimpleChanges): void {\n        if (c && c.length) {\n            this.length$.next(c.length.currentValue);\n            this.getRange();\n        }\n        if (c && c.page) {\n            this.page$.next({ page: c.page.currentValue, pageSize: this.pageSize, nbPage: this.nbPage });\n            this.getRange();\n        }\n        if (c && c.pageSize) {\n            this.page$.next({ page: this.page, pageSize: c.pageSize.currentValue, nbPage: this.nbPage });\n            this.changePageSize(c.pageSize.currentValue);\n            this.getRange();\n        }\n    }\n\n    ngOnInit(): void {\n        if (this.length) {\n            this.length$.next(this.length);\n        }\n\n        this.nbPageNumberNav = this.nbPageNumberNavigation;\n\n        this.length$.pipe(takeUntil(this.destroy$), distinctUntilChanged()).subscribe((length) => {\n            this.length = length;\n            this.nbPage = Math.ceil(this.length / this.pageSize);\n            if (!this.hasDynamicLength) {\n                this.page = 0;\n            }\n            this.getRange();\n\n            if (this.nbPage < this.nbPageNumberNavigation) {\n                this.nbPageNumberNav = this.nbPage;\n            } else {\n                this.nbPageNumberNav = this.nbPageNumberNavigation;\n            }\n\n            this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        });\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    get pageNumberNavigation(): number[] {\n        const pages = [];\n        for (let i = 0; i < this.nbPage; i++) {\n            pages.push(i);\n        }\n\n        const delta = Math.floor(this.nbPageNumberNav / 2);\n        let start = 0;\n        if (this.page - delta > 0) {\n            start = this.page - delta;\n        } else {\n            start = 0;\n        }\n\n        if (this.nbPage - this.page <= this.nbPageNumberNav - (delta + 1)) {\n            start = this.nbPage - this.nbPageNumberNav;\n        }\n\n        if (start < 0) {\n            start = 0;\n        }\n\n        const end = start + this.nbPageNumberNav;\n        return pages.slice(start, end);\n    }\n\n    public changePageSize(size: string): void {\n        this.pageSize = parseInt(size, 10);\n        this.nbPage = Math.ceil(this.length / this.pageSize);\n        this.page = 0;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n\n        if (this.nbPage < this.nbPageNumberNavigation) {\n            this.nbPageNumberNav = this.nbPage;\n        } else {\n            this.nbPageNumberNav = this.nbPageNumberNavigation;\n        }\n\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goToPage(page: number): void {\n        this.page = page;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goFirstPage(): void {\n        this.page = 0;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goPreviousPage(): void {\n        this.page--;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goNextPage(): void {\n        this.page++;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goLastPage(): void {\n        this.page = this.nbPage - 1;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public setPage(page: EuiPaginationEvent): void {\n        this.page$.next(page);\n    }\n\n    public setLength(length: number): void {\n        this.length$.next(length);\n    }\n\n    public getRange(): void {\n        const from = this.length > 0 ? this.page * this.pageSize + 1 : 0;\n        const limit = this.page * this.pageSize + this.pageSize;\n        const to = limit <= this.length ? limit : this.length;\n        this.range = from && to && this.length ? this.decimal.transform(from) + '–' + this.decimal.transform(to) : '';\n        this.rangeLength = this.length ? this.length.toString() : '';\n    }\n\n    /**\n     * Change the pagination to the given page number\n     *\n     * @param page 0-based page number to be displayed\n     */\n    public getPage(page: number): void {\n        setTimeout(() => {\n            this.goToPage(page);\n        });\n    }\n}\n","<div class=\"eui-paginator__page\">\n    <div class=\"eui-paginator__page-selector\">\n        <div>{{ 'eui.euitable.ITEMS-PER-PAGE' | translate }}:</div>\n        <div class=\"eui-u-pl-xs eui-u-pb-2xs\">\n            <select euiSelect class=\"page-size__select\" aria-label=\"Page size selected\" [(ngModel)]=\"pageSize\" (ngModelChange)=\"changePageSize($event)\">\n                <option *ngFor=\"let pageSizeOption of pageSizeOptions\" value=\"{{ pageSizeOption }}\">{{ pageSizeOption }}</option>\n            </select>\n        </div>\n    </div>\n    <div *ngIf=\"(length$ | async) > 0\" class=\"eui-paginator__page-range\">\n        {{ 'eui.euitable.SHOWING-RANGE' | translate: { range: range } }} {{ 'eui.euitable.RANGE-LABEL' | translate }}\n        {{ rangeLength | number }}\n    </div>\n</div>\n\n<div class=\"eui-paginator__page-navigation\">\n    <div class=\"eui-paginator__page-navigation-item\">\n        <button\n            type=\"button\"\n            euiSizeS\n            euiButton\n            euiIconButton\n            euiBasicButton\n            euiRounded\n            [euiDisabled]=\"page === 0 || length === 0\"\n            (click)=\"goFirstPage()\">\n            <eui-icon-svg icon=\"play-skip-back:sharp\" fillColor=\"primary\" aria-label=\"Go to first page\"></eui-icon-svg>\n        </button>\n    </div>\n    <div class=\"eui-paginator__page-navigation-item\">\n        <button\n            type=\"button\"\n            euiSizeS\n            euiButton\n            euiIconButton\n            euiBasicButton\n            euiRounded\n            [euiDisabled]=\"page === 0 || length === 0\"\n            (click)=\"goPreviousPage()\">\n            <!-- to be compliant with DS as play-back is not existing in ionicons -->\n            <eui-icon-svg icon=\"play:sharp\" fillColor=\"primary\" transform=\"rotate-180\" aria-label=\"Go to previous page\"></eui-icon-svg>\n        </button>\n    </div>\n    <div\n        class=\"eui-paginator__page-navigation-numbers\"\n        *ngIf=\"hasPageNumberNavigation\">\n        <button\n            type=\"button\"\n            euiSizeS\n            *ngFor=\"let pageNumber of pageNumberNavigation\"\n            euiButton\n            euiBasicButton\n            euiRounded\n            euiIconButton\n            [euiOutline]=\"pageNumber === page\"\n            (click)=\"goToPage(pageNumber)\">\n            {{ pageNumber + 1 | number }}\n        </button>\n    </div>\n    <div *ngIf=\"(length$ | async) > 0\" class=\"eui-paginator__page-range\">\n        {{ range }} {{ 'eui.euitable.RANGE-LABEL' | translate }} {{ rangeLength }}\n    </div>\n    <div class=\"eui-paginator__page-navigation-item\">\n        <button\n            type=\"button\"\n            euiSizeS\n            euiButton\n            euiIconButton\n            euiBasicButton\n            euiRounded\n            [euiDisabled]=\"page + 1 === nbPage || length === 0\"\n            (click)=\"goNextPage()\">\n            <eui-icon-svg icon=\"play:sharp\" fillColor=\"primary\" aria-label=\"Go to next page\"></eui-icon-svg>\n        </button>\n    </div>\n    <div class=\"eui-paginator__page-navigation-item\">\n        <button\n            type=\"button\"\n            euiSizeS\n            euiButton\n            euiIconButton\n            euiBasicButton\n            euiRounded\n            [euiDisabled]=\"page + 1 === nbPage || length === 0\"\n            (click)=\"goLastPage()\">\n            <eui-icon-svg icon=\"play-skip-forward:sharp\" fillColor=\"primary\" aria-label=\"Go to last page\"></eui-icon-svg>\n        </button>\n    </div>\n</div>\n"]}
|
203
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-paginator.component.js","sourceRoot":"","sources":["../../../eui-paginator/eui-paginator.component.ts","../../../eui-paginator/eui-paginator.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EAET,KAAK,EAEL,YAAY,EACZ,MAAM,EAGN,WAAW,EACX,gBAAgB,EAChB,iBAAiB,GACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAIjE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;;;;;;;;;AAS9C,MAAM,OAAO,qBAAqB;IAE9B,IACI,UAAU;QACV,OAAO;YACH,eAAe;YACf,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,CAAC,EAAE;SAC/C,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;IAsBD,YACW,kBAAsC,EACrC,OAAoB;QADrB,uBAAkB,GAAlB,kBAAkB,CAAoB;QACrC,YAAO,GAAP,OAAO,CAAa;QA/BO,YAAO,GAAG,eAAe,CAAC;QAQxD,oBAAe,GAAa,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;QACjD,aAAQ,GAAG,EAAE,CAAC;QACd,SAAI,GAAG,CAAC,CAAC;QACT,WAAM,GAAG,CAAC,CAAC;QACX,2BAAsB,GAAG,CAAC,CAAC;QACI,aAAQ,GAAG,KAAK,CAAC;QAE/C,eAAU,GAAG,IAAI,YAAY,EAAsB,CAAC;QAEvD,UAAK,GAAwC,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC;QACvE,YAAO,GAA4B,IAAI,eAAe,CAAC,CAAC,CAAC,CAAC;QAKzB,4BAAuB,GAAG,KAAK,CAAC;QAChC,qBAAgB,GAAG,KAAK,CAAC;QAGzD,aAAQ,GAAqB,IAAI,OAAO,EAAW,CAAC;IAKzD,CAAC;IAEJ,WAAW,CAAC,CAAgB;QACxB,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;YACzC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpB,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;YAC7F,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpB,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,YAAY,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;YAC7F,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;YAC7C,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpB,CAAC;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACd,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACnC,CAAC;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,sBAAsB,CAAC;QAEnD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,oBAAoB,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACrF,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;YACrB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;YACrD,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACzB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;YAClB,CAAC;YACD,IAAI,CAAC,QAAQ,EAAE,CAAC;YAEhB,IAAI,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBAC5C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC;YACvC,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,sBAAsB,CAAC;YACvD,CAAC;YAED,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACvF,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACvF,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAChC,CAAC;IAED,IAAI,oBAAoB;QACpB,MAAM,KAAK,GAAG,EAAE,CAAC;QACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACnC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC;QACnD,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,IAAI,CAAC,IAAI,GAAG,KAAK,GAAG,CAAC,EAAE,CAAC;YACxB,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAC9B,CAAC;aAAM,CAAC;YACJ,KAAK,GAAG,CAAC,CAAC;QACd,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,eAAe,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC;YAChE,KAAK,GAAG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,eAAe,CAAC;QAC/C,CAAC;QAED,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;YACZ,KAAK,GAAG,CAAC,CAAC;QACd,CAAC;QAED,MAAM,GAAG,GAAG,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC;QACzC,OAAO,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACnC,CAAC;IAEM,cAAc,CAAC,IAAY;QAC9B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACnC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrD,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACnF,IAAI,CAAC,QAAQ,EAAE,CAAC;QAEhB,IAAI,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC5C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC;QACvC,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,sBAAsB,CAAC;QACvD,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5F,CAAC;IAEM,QAAQ,CAAC,IAAY;QACxB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACnF,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5F,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACnF,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5F,CAAC;IAEM,cAAc;QACjB,IAAI,CAAC,IAAI,EAAE,CAAC;QACZ,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACnF,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5F,CAAC;IAEM,UAAU;QACb,IAAI,CAAC,IAAI,EAAE,CAAC;QACZ,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACnF,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5F,CAAC;IAEM,UAAU;QACb,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACnF,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5F,CAAC;IAEM,OAAO,CAAC,IAAwB;QACnC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAEM,SAAS,CAAC,MAAc;QAC3B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;IAEM,QAAQ;QACX,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACjE,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QACxD,MAAM,EAAE,GAAG,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;QACtD,IAAI,CAAC,KAAK,GAAG,IAAI,IAAI,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9G,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IACjE,CAAC;IAED;;;;OAIG;IACI,OAAO,CAAC,IAAY;QACvB,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;IACP,CAAC;8GAxLQ,qBAAqB;kGAArB,qBAAqB,0OAcV,gBAAgB,mFAUhB,gBAAgB,8DAChB,gBAAgB,8IA3BzB,CAAC,WAAW,CAAC,+CCzB5B,shHAyFA;;2FD9Da,qBAAqB;kBAPjC,SAAS;+BACI,eAAe,iBAGV,iBAAiB,CAAC,IAAI,aAC1B,CAAC,WAAW,CAAC;iHAGe,OAAO;sBAA7C,WAAW;uBAAC,eAAe;;sBAAG,KAAK;gBAEhC,UAAU;sBADb,WAAW;uBAAC,OAAO;gBAOX,eAAe;sBAAvB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACkC,QAAQ;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAE5B,UAAU;sBAAnB,MAAM;gBAQiC,uBAAuB;sBAA9D,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBACE,gBAAgB;sBAAvD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import {\n    Component,\n    OnInit,\n    Input,\n    OnDestroy,\n    EventEmitter,\n    Output,\n    OnChanges,\n    SimpleChanges,\n    HostBinding,\n    booleanAttribute,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { Subject, BehaviorSubject } from 'rxjs';\nimport { takeUntil, distinctUntilChanged } from 'rxjs/operators';\nimport { EuiAppShellService } from '@eui/core';\n\nimport { EuiPaginationEvent } from './models/pagination-event.model';\nimport { DecimalPipe } from '@angular/common';\n\n@Component({\n    selector: 'eui-paginator',\n    templateUrl: './eui-paginator.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n    providers: [DecimalPipe],\n})\nexport class EuiPaginatorComponent implements OnInit, OnDestroy, OnChanges {\n    @HostBinding('attr.data-e2e') @Input() e2eAttr = 'eui-paginator';\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            'eui-paginator',\n            this.isHidden ? 'eui-paginator--hidden' : '',\n        ].join(' ').trim();\n    }\n    @Input() pageSizeOptions: number[] = [5, 10, 25, 50, 100];\n    @Input() pageSize = 10;\n    @Input() page = 0;\n    @Input() length = 0;\n    @Input() nbPageNumberNavigation = 5;\n    @Input({ transform: booleanAttribute }) isHidden = false;\n\n    @Output() pageChange = new EventEmitter<EuiPaginationEvent>();\n\n    public page$: BehaviorSubject<EuiPaginationEvent> = new BehaviorSubject(null);\n    public length$: BehaviorSubject<number> = new BehaviorSubject(0);\n    public range: string;\n    public rangeLength: string;\n    public nbPage: number;\n\n    @Input({ transform: booleanAttribute }) hasPageNumberNavigation = false;\n    @Input({ transform: booleanAttribute }) hasDynamicLength = false;\n\n    private nbPageNumberNav: number;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        public EuiAppShellService: EuiAppShellService,\n        private decimal: DecimalPipe,\n    ) {}\n\n    ngOnChanges(c: SimpleChanges): void {\n        if (c && c.length) {\n            this.length$.next(c.length.currentValue);\n            this.getRange();\n        }\n        if (c && c.page) {\n            this.page$.next({ page: c.page.currentValue, pageSize: this.pageSize, nbPage: this.nbPage });\n            this.getRange();\n        }\n        if (c && c.pageSize) {\n            this.page$.next({ page: this.page, pageSize: c.pageSize.currentValue, nbPage: this.nbPage });\n            this.changePageSize(c.pageSize.currentValue);\n            this.getRange();\n        }\n    }\n\n    ngOnInit(): void {\n        if (this.length) {\n            this.length$.next(this.length);\n        }\n\n        this.nbPageNumberNav = this.nbPageNumberNavigation;\n\n        this.length$.pipe(takeUntil(this.destroy$), distinctUntilChanged()).subscribe((length) => {\n            this.length = length;\n            this.nbPage = Math.ceil(this.length / this.pageSize);\n            if (!this.hasDynamicLength) {\n                this.page = 0;\n            }\n            this.getRange();\n\n            if (this.nbPage < this.nbPageNumberNavigation) {\n                this.nbPageNumberNav = this.nbPage;\n            } else {\n                this.nbPageNumberNav = this.nbPageNumberNavigation;\n            }\n\n            this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        });\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    get pageNumberNavigation(): number[] {\n        const pages = [];\n        for (let i = 0; i < this.nbPage; i++) {\n            pages.push(i);\n        }\n\n        const delta = Math.floor(this.nbPageNumberNav / 2);\n        let start = 0;\n        if (this.page - delta > 0) {\n            start = this.page - delta;\n        } else {\n            start = 0;\n        }\n\n        if (this.nbPage - this.page <= this.nbPageNumberNav - (delta + 1)) {\n            start = this.nbPage - this.nbPageNumberNav;\n        }\n\n        if (start < 0) {\n            start = 0;\n        }\n\n        const end = start + this.nbPageNumberNav;\n        return pages.slice(start, end);\n    }\n\n    public changePageSize(size: string): void {\n        this.pageSize = parseInt(size, 10);\n        this.nbPage = Math.ceil(this.length / this.pageSize);\n        this.page = 0;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n\n        if (this.nbPage < this.nbPageNumberNavigation) {\n            this.nbPageNumberNav = this.nbPage;\n        } else {\n            this.nbPageNumberNav = this.nbPageNumberNavigation;\n        }\n\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goToPage(page: number): void {\n        this.page = page;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goFirstPage(): void {\n        this.page = 0;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goPreviousPage(): void {\n        this.page--;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goNextPage(): void {\n        this.page++;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public goLastPage(): void {\n        this.page = this.nbPage - 1;\n        this.page$.next({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n        this.getRange();\n        this.pageChange.emit({ page: this.page, pageSize: this.pageSize, nbPage: this.nbPage });\n    }\n\n    public setPage(page: EuiPaginationEvent): void {\n        this.page$.next(page);\n    }\n\n    public setLength(length: number): void {\n        this.length$.next(length);\n    }\n\n    public getRange(): void {\n        const from = this.length > 0 ? this.page * this.pageSize + 1 : 0;\n        const limit = this.page * this.pageSize + this.pageSize;\n        const to = limit <= this.length ? limit : this.length;\n        this.range = from && to && this.length ? this.decimal.transform(from) + '–' + this.decimal.transform(to) : '';\n        this.rangeLength = this.length ? this.length.toString() : '';\n    }\n\n    /**\n     * Change the pagination to the given page number\n     *\n     * @param page 0-based page number to be displayed\n     */\n    public getPage(page: number): void {\n        setTimeout(() => {\n            this.goToPage(page);\n        });\n    }\n}\n","<div class=\"eui-paginator__page\">\n    <div class=\"eui-paginator__page-selector\">\n        <div>{{ 'eui.euitable.ITEMS-PER-PAGE' | translate }}:</div>\n        <div class=\"eui-u-pl-xs eui-u-pb-2xs\">\n            <select euiSelect class=\"page-size__select\" aria-label=\"Page size selected\" [(ngModel)]=\"pageSize\" (ngModelChange)=\"changePageSize($event)\">\n                <option *ngFor=\"let pageSizeOption of pageSizeOptions\" value=\"{{ pageSizeOption }}\">{{ pageSizeOption }}</option>\n            </select>\n        </div>\n    </div>\n    <div *ngIf=\"(length$ | async) > 0\" class=\"eui-paginator__page-range\">\n        {{ 'eui.euitable.SHOWING-RANGE' | translate: { range: range } }} {{ 'eui.euitable.RANGE-LABEL' | translate }}\n        {{ rangeLength | number }}\n    </div>\n</div>\n\n<div class=\"eui-paginator__page-navigation\">\n    <div class=\"eui-paginator__page-navigation-item\">\n        <button\n            type=\"button\"\n            euiSizeS\n            euiButton\n            euiIconButton\n            euiBasicButton\n            euiRounded\n            [euiDisabled]=\"page === 0 || length === 0\"\n            (click)=\"goFirstPage()\">\n            <eui-icon-svg icon=\"play-skip-back:sharp\" fillColor=\"primary\" aria-label=\"Go to first page\"></eui-icon-svg>\n        </button>\n    </div>\n    <div class=\"eui-paginator__page-navigation-item\">\n        <button\n            type=\"button\"\n            euiSizeS\n            euiButton\n            euiIconButton\n            euiBasicButton\n            euiRounded\n            [euiDisabled]=\"page === 0 || length === 0\"\n            (click)=\"goPreviousPage()\">\n            <!-- to be compliant with DS as play-back is not existing in ionicons -->\n            <eui-icon-svg icon=\"play:sharp\" fillColor=\"primary\" transform=\"rotate-180\" aria-label=\"Go to previous page\"></eui-icon-svg>\n        </button>\n    </div>\n    <div\n        class=\"eui-paginator__page-navigation-numbers\"\n        *ngIf=\"hasPageNumberNavigation\">\n        <button\n            type=\"button\"\n            euiSizeS\n            *ngFor=\"let pageNumber of pageNumberNavigation\"\n            euiButton\n            euiBasicButton\n            euiRounded\n            euiIconButton\n            [euiOutline]=\"pageNumber === page\"\n            (click)=\"goToPage(pageNumber)\">\n            {{ pageNumber + 1 | number }}\n        </button>\n    </div>\n    <div *ngIf=\"(length$ | async) > 0\" class=\"eui-paginator__page-range\">\n        {{ range }} {{ 'eui.euitable.RANGE-LABEL' | translate }} {{ rangeLength }}\n    </div>\n    <div class=\"eui-paginator__page-navigation-item\">\n        <button\n            type=\"button\"\n            euiSizeS\n            euiButton\n            euiIconButton\n            euiBasicButton\n            euiRounded\n            [euiDisabled]=\"page + 1 === nbPage || length === 0\"\n            (click)=\"goNextPage()\">\n            <eui-icon-svg icon=\"play:sharp\" fillColor=\"primary\" aria-label=\"Go to next page\"></eui-icon-svg>\n        </button>\n    </div>\n    <div class=\"eui-paginator__page-navigation-item\">\n        <button\n            type=\"button\"\n            euiSizeS\n            euiButton\n            euiIconButton\n            euiBasicButton\n            euiRounded\n            [euiDisabled]=\"page + 1 === nbPage || length === 0\"\n            (click)=\"goLastPage()\">\n            <eui-icon-svg icon=\"play-skip-forward:sharp\" fillColor=\"primary\" aria-label=\"Go to last page\"></eui-icon-svg>\n        </button>\n    </div>\n</div>\n"]}
|
@@ -1,6 +1,5 @@
|
|
1
|
-
import { Directive, Host, Input, Optional } from '@angular/core';
|
1
|
+
import { booleanAttribute, Directive, Host, Input, Optional, } from '@angular/core';
|
2
2
|
import { NgSelectOption } from '@angular/forms';
|
3
|
-
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
4
3
|
import * as i0 from "@angular/core";
|
5
4
|
import * as i1 from "./eui-select-control.directive";
|
6
5
|
import * as i2 from "@angular/forms";
|
@@ -28,12 +27,6 @@ function _buildValueString(id, value) {
|
|
28
27
|
// TODO: remove that selector in eUI 17.x and replace it with `option[euiOption]` (this will be a breaking change)
|
29
28
|
// eslint-disable-next-line @angular-eslint/directive-selector
|
30
29
|
export class EuiNgSelectOptionDirective extends NgSelectOption {
|
31
|
-
get selected() {
|
32
|
-
return this._selected;
|
33
|
-
}
|
34
|
-
set selected(value) {
|
35
|
-
this._selected = coerceBooleanProperty(value);
|
36
|
-
}
|
37
30
|
constructor(_element, _renderer, _select, _selectNative, _selectComponent) {
|
38
31
|
super(_element, _renderer, _select);
|
39
32
|
this.select = _select;
|
@@ -73,7 +66,7 @@ export class EuiNgSelectOptionDirective extends NgSelectOption {
|
|
73
66
|
* in case there's a selected value, readonly attribute is true, sync it to the readonly input. The reason is
|
74
67
|
* that the readonly input is not aware of the selected value until the render of the view completes.
|
75
68
|
*/
|
76
|
-
switch (this.
|
69
|
+
switch (this.selected) {
|
77
70
|
case true:
|
78
71
|
this.renderer.setAttribute(this.element.nativeElement, 'selected', '');
|
79
72
|
break;
|
@@ -88,7 +81,7 @@ export class EuiNgSelectOptionDirective extends NgSelectOption {
|
|
88
81
|
}
|
89
82
|
}
|
90
83
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiNgSelectOptionDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.EuiSelectControlValueAccessor, host: true, optional: true }, { token: i2.SelectControlValueAccessor, host: true, optional: true }, { token: i3.EuiSelectComponent, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
91
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
84
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0", type: EuiNgSelectOptionDirective, selector: "option:not([eclSelectOption]):not([eclMultiselectOption]), option[euiOption]", inputs: { selected: ["selected", "selected", booleanAttribute], label: "label", ngValue: "ngValue" }, usesInheritance: true, usesOnChanges: true, ngImport: i0 }); }
|
92
85
|
}
|
93
86
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiNgSelectOptionDirective, decorators: [{
|
94
87
|
type: Directive,
|
@@ -106,10 +99,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
106
99
|
}, {
|
107
100
|
type: Host
|
108
101
|
}] }], propDecorators: { selected: [{
|
109
|
-
type: Input
|
102
|
+
type: Input,
|
103
|
+
args: [{ transform: booleanAttribute }]
|
110
104
|
}], label: [{
|
111
105
|
type: Input
|
112
106
|
}], ngValue: [{
|
113
107
|
type: Input
|
114
108
|
}] } });
|
115
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-select-option.directive.js","sourceRoot":"","sources":["../../../eui-select/eui-select-option.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, Host, Input, OnChanges, OnDestroy, Optional, Renderer2, SimpleChanges } from '@angular/core';\nimport { NgSelectOption, SelectControlValueAccessor } from '@angular/forms';\nimport { EuiSelectControlValueAccessor } from './eui-select-control.directive';\nimport { EuiSelectComponent } from './eui-select.component';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\n\n// eslint-disable-next-line prefer-arrow/prefer-arrow-functions, @typescript-eslint/no-explicit-any\nfunction _buildValueString(id: string, value: any): string {\n    if (id == null) {\n        return `${value}`;\n    }\n    if (value && typeof value === 'object') {\n        value = 'Object';\n    }\n    return `${id}: ${value}`.slice(0, 50);\n}\n\n/**\n * @description\n * Marks `<option>` as dynamic, so Angular can be notified when options change.\n *\n * @see `EuiSelectControlValueAccessor`\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n// TODO: remove that selector in eUI 17.x and replace it with `option[euiOption]` (this will be a breaking change)\n// eslint-disable-next-line @angular-eslint/directive-selector\n@Directive({ selector: 'option:not([eclSelectOption]):not([eclMultiselectOption]), option[euiOption]' })\nexport class EuiNgSelectOptionDirective extends NgSelectOption implements OnDestroy, OnChanges, AfterViewInit {\n    @Input()\n    get selected(): boolean {\n        return this._selected;\n    }\n    set selected(value: BooleanInput) {\n        this._selected = coerceBooleanProperty(value);\n    }\n\n    @Input() label: string;\n\n    private _selected: boolean;\n    private readonly select: EuiSelectControlValueAccessor;\n    private readonly selectNative: SelectControlValueAccessor;\n    private readonly selectComponent: EuiSelectComponent;\n    private element: ElementRef<HTMLOptionElement>;\n    private renderer: Renderer2;\n\n    constructor(\n        _element: ElementRef,\n        _renderer: Renderer2,\n        @Optional() @Host() _select: EuiSelectControlValueAccessor,\n        @Optional() @Host() _selectNative: SelectControlValueAccessor,\n        @Optional() @Host() _selectComponent: EuiSelectComponent,\n    ) {\n        super(_element, _renderer, _select);\n        this.select = _select;\n        this.selectNative = _selectNative;\n        this.selectComponent = _selectComponent;\n        this.element = _element;\n        this.renderer = _renderer;\n    }\n\n    ngAfterViewInit(): void {\n        this.selectComponent?.syncReadOnlyValue();\n        if (this.selectNative && this.select && this.selectNative.value !== this.select.value) {\n            // TODO: This causes issues when options array change from N to 1 and the option 1 is set through setValue()\n            //       Investigate what are the regressions from the removal of this line. Issue is that the Native\n            //       control value accessor holds a mapper not in sync with the EuiSelectControlValueAccessor.\n            //\n            // this.selectNative.writeValue(this.select.value);\n        }\n    }\n\n    /**\n     * @description\n     * Tracks the value bound to the option element. Unlike the value binding,\n     * ngValue supports binding to objects.\n     */\n    @Input()\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    override set ngValue(value: any) {\n        if (this.select == null) return;\n        this.selectNative['_idCounter'] = this.select['_idCounter'];\n        this.select['_optionMap'].set(this.id, value);\n        this.selectNative['_optionMap'] = this.select['_optionMap']; //.set(this.id, value);\n        super['_setElementValue'](_buildValueString(this.id, value));\n        this.select.writeValue(this.select.value);\n        this.selectNative.writeValue(this.select.value);\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.selected) {\n            /**\n             * in case there's a selected value, readonly attribute is true, sync it to the readonly input. The reason is\n             * that the readonly input is not aware of the selected value until the render of the view completes.\n             */\n            switch (this._selected) {\n                case true:\n                    this.renderer.setAttribute(this.element.nativeElement, 'selected', '');\n                    break;\n                default:\n                    this.renderer.removeAttribute(this.element.nativeElement, 'selected');\n            }\n            this.selectComponent?.syncReadOnlyValue();\n        }\n\n        if (changes.label) {\n            this.renderer.setProperty(this.element.nativeElement, 'innerText', changes.label.currentValue);\n            this.selectComponent?.syncReadOnlyValue();\n        }\n    }\n}\n"]}
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-select-option.directive.js","sourceRoot":"","sources":["../../../eui-select/eui-select-option.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,gBAAgB,EAChB,SAAS,EAET,IAAI,EACJ,KAAK,EAGL,QAAQ,GAGX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,cAAc,EAA8B,MAAM,gBAAgB,CAAC;;;;;AAI5E,mGAAmG;AACnG,SAAS,iBAAiB,CAAC,EAAU,EAAE,KAAU;IAC7C,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC;QACb,OAAO,GAAG,KAAK,EAAE,CAAC;IACtB,CAAC;IACD,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QACrC,KAAK,GAAG,QAAQ,CAAC;IACrB,CAAC;IACD,OAAO,GAAG,EAAE,KAAK,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AAC1C,CAAC;AAED;;;;;;;;;GASG;AACH,kHAAkH;AAClH,8DAA8D;AAE9D,MAAM,OAAO,0BAA2B,SAAQ,cAAc;IAW1D,YACI,QAAoB,EACpB,SAAoB,EACA,OAAsC,EACtC,aAAyC,EACzC,gBAAoC;QAExD,KAAK,CAAC,QAAQ,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QACpC,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC;QACtB,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC;QAClC,IAAI,CAAC,eAAe,GAAG,gBAAgB,CAAC;QACxC,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;QACxB,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC;IAC9B,CAAC;IAED,eAAe;QACX,IAAI,CAAC,eAAe,EAAE,iBAAiB,EAAE,CAAC;QAC1C,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;YACpF,4GAA4G;YAC5G,qGAAqG;YACrG,kGAAkG;YAClG,EAAE;YACF,mDAAmD;QACvD,CAAC;IACL,CAAC;IAED;;;;OAIG;IACH,IAGa,OAAO,CAAC,KAAU;QAC3B,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI;YAAE,OAAO;QAChC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QAC5D,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,uBAAuB;QACpF,KAAK,CAAC,kBAAkB,CAAC,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC,CAAC;QAC7D,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC1C,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACpD,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACnB;;;eAGG;YACH,QAAQ,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACpB,KAAK,IAAI;oBACL,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;oBACvE,MAAM;gBACV;oBACI,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;YAC9E,CAAC;YACD,IAAI,CAAC,eAAe,EAAE,iBAAiB,EAAE,CAAC;QAC9C,CAAC;QAED,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YAC/F,IAAI,CAAC,eAAe,EAAE,iBAAiB,EAAE,CAAC;QAC9C,CAAC;IACL,CAAC;8GA3EQ,0BAA0B;kGAA1B,0BAA0B,yIACf,gBAAgB;;2FAD3B,0BAA0B;kBADtC,SAAS;mBAAC,EAAE,QAAQ,EAAE,8EAA8E,EAAE;;0BAe9F,QAAQ;;0BAAI,IAAI;;0BAChB,QAAQ;;0BAAI,IAAI;;0BAChB,QAAQ;;0BAAI,IAAI;yCAfmB,QAAQ;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAE7B,KAAK;sBAAb,KAAK;gBA0CO,OAAO;sBAHnB,KAAK","sourcesContent":["import {\n    AfterViewInit,\n    booleanAttribute,\n    Directive,\n    ElementRef,\n    Host,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Optional,\n    Renderer2,\n    SimpleChanges,\n} from '@angular/core';\nimport { NgSelectOption, SelectControlValueAccessor } from '@angular/forms';\nimport { EuiSelectControlValueAccessor } from './eui-select-control.directive';\nimport { EuiSelectComponent } from './eui-select.component';\n\n// eslint-disable-next-line prefer-arrow/prefer-arrow-functions, @typescript-eslint/no-explicit-any\nfunction _buildValueString(id: string, value: any): string {\n    if (id == null) {\n        return `${value}`;\n    }\n    if (value && typeof value === 'object') {\n        value = 'Object';\n    }\n    return `${id}: ${value}`.slice(0, 50);\n}\n\n/**\n * @description\n * Marks `<option>` as dynamic, so Angular can be notified when options change.\n *\n * @see `EuiSelectControlValueAccessor`\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n// TODO: remove that selector in eUI 17.x and replace it with `option[euiOption]` (this will be a breaking change)\n// eslint-disable-next-line @angular-eslint/directive-selector\n@Directive({ selector: 'option:not([eclSelectOption]):not([eclMultiselectOption]), option[euiOption]' })\nexport class EuiNgSelectOptionDirective extends NgSelectOption implements OnDestroy, OnChanges, AfterViewInit {\n    @Input({ transform: booleanAttribute }) selected: boolean;\n\n    @Input() label: string;\n\n    private readonly select: EuiSelectControlValueAccessor;\n    private readonly selectNative: SelectControlValueAccessor;\n    private readonly selectComponent: EuiSelectComponent;\n    private element: ElementRef<HTMLOptionElement>;\n    private renderer: Renderer2;\n\n    constructor(\n        _element: ElementRef,\n        _renderer: Renderer2,\n        @Optional() @Host() _select: EuiSelectControlValueAccessor,\n        @Optional() @Host() _selectNative: SelectControlValueAccessor,\n        @Optional() @Host() _selectComponent: EuiSelectComponent,\n    ) {\n        super(_element, _renderer, _select);\n        this.select = _select;\n        this.selectNative = _selectNative;\n        this.selectComponent = _selectComponent;\n        this.element = _element;\n        this.renderer = _renderer;\n    }\n\n    ngAfterViewInit(): void {\n        this.selectComponent?.syncReadOnlyValue();\n        if (this.selectNative && this.select && this.selectNative.value !== this.select.value) {\n            // TODO: This causes issues when options array change from N to 1 and the option 1 is set through setValue()\n            //       Investigate what are the regressions from the removal of this line. Issue is that the Native\n            //       control value accessor holds a mapper not in sync with the EuiSelectControlValueAccessor.\n            //\n            // this.selectNative.writeValue(this.select.value);\n        }\n    }\n\n    /**\n     * @description\n     * Tracks the value bound to the option element. Unlike the value binding,\n     * ngValue supports binding to objects.\n     */\n    @Input()\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    override set ngValue(value: any) {\n        if (this.select == null) return;\n        this.selectNative['_idCounter'] = this.select['_idCounter'];\n        this.select['_optionMap'].set(this.id, value);\n        this.selectNative['_optionMap'] = this.select['_optionMap']; //.set(this.id, value);\n        super['_setElementValue'](_buildValueString(this.id, value));\n        this.select.writeValue(this.select.value);\n        this.selectNative.writeValue(this.select.value);\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.selected) {\n            /**\n             * in case there's a selected value, readonly attribute is true, sync it to the readonly input. The reason is\n             * that the readonly input is not aware of the selected value until the render of the view completes.\n             */\n            switch (this.selected) {\n                case true:\n                    this.renderer.setAttribute(this.element.nativeElement, 'selected', '');\n                    break;\n                default:\n                    this.renderer.removeAttribute(this.element.nativeElement, 'selected');\n            }\n            this.selectComponent?.syncReadOnlyValue();\n        }\n\n        if (changes.label) {\n            this.renderer.setProperty(this.element.nativeElement, 'innerText', changes.label.currentValue);\n            this.selectComponent?.syncReadOnlyValue();\n        }\n    }\n}\n"]}
|
@@ -1,15 +1,9 @@
|
|
1
|
-
import { Component, HostListener, Input, ViewEncapsulation, } from '@angular/core';
|
1
|
+
import { booleanAttribute, Component, HostListener, Input, ViewEncapsulation, } from '@angular/core';
|
2
2
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
3
3
|
import { EuiInputTextComponent } from '@eui/components/eui-input-text';
|
4
4
|
import { NgControl } from '@angular/forms';
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
export class EuiSelectComponent {
|
7
|
-
get readonly() {
|
8
|
-
return this._readonly;
|
9
|
-
}
|
10
|
-
set readonly(value) {
|
11
|
-
this._readonly = coerceBooleanProperty(value);
|
12
|
-
}
|
13
7
|
get isInvalid() {
|
14
8
|
return this._isInvalid || null;
|
15
9
|
}
|
@@ -145,7 +139,7 @@ export class EuiSelectComponent {
|
|
145
139
|
}
|
146
140
|
}
|
147
141
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiSelectComponent, deps: [{ token: i0.Renderer2 }, { token: i0.Injector }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
148
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
142
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: EuiSelectComponent, selector: "select[euiSelect]", inputs: { placeholder: "placeholder", readonly: ["readonly", "readonly", booleanAttribute], isInvalid: "isInvalid" }, host: { listeners: { "change": "onChange($event.target.value)" } }, usesOnChanges: true, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, styles: [".eui-select{font:var(--eui-f-m);appearance:none;background-color:var(--eui-c-white);border:1px solid var(--eui-c-neutral-lighter);border-radius:var(--eui-br-m);box-shadow:none;color:var(--eui-c-text);padding:calc(var(--eui-s-xs) - 1px) calc(var(--eui-s-m) - 1px);width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--eui-c-neutral);overflow-y:auto}.eui-select:not([hidden]){display:block}.eui-select::placeholder{color:var(--eui-c-neutral-lighter)!important;opacity:1}.eui-select[readonly]{background-color:transparent;border-color:transparent!important;box-shadow:none;height:inherit;pointer-events:none}.eui-select[readonly]+.eui-feedback-message,.eui-select[readonly]+.eui-input-maxlength{appearance:none;display:none}.eui-select[disabled]:not([readonly]),.eui-select--disabled:not([readonly]){background-color:var(--eui-c-neutral-bg-light)!important;border:1px solid var(--eui-c-neutral-lightest)!important;color:var(--eui-c-neutral-light);pointer-events:none}.eui-select--invalid,.eui-select--danger{border:1px solid var(--eui-c-danger)}.eui-select--clearable{padding-right:var(--eui-s-2xl)}.eui-select--clearable-icon{cursor:pointer;position:absolute;right:var(--eui-s-s);-webkit-user-select:none;user-select:none;visibility:visible}.eui-select--clearable-icon:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-select--clearable-icon:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-select--clearable-icon [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-select--clearable-icon>svg{fill:var(--eui-c-neutral-lighter)}.eui-select--clearable-icon>svg:hover{fill:var(--eui-c-danger)}.eui-select--loading{padding-right:var(--eui-s-2xl)}.eui-select--loading-icon{align-items:center;display:flex}.eui-select--loading-icon:after,.eui-select--loading-icon:before{content:\"\";height:var(--eui-s-l);position:absolute;right:var(--eui-s-s);width:var(--eui-s-l)}.eui-select--loading-icon:before{border:var(--eui-s-2xs) solid rgba(0,0,0,.35);border-radius:100%}.eui-select--loading-icon:after{animation:eui-loading .6s linear;animation-iteration-count:infinite;border-color:var(--eui-c-white) transparent transparent;border-radius:100%;border-style:solid;border-width:var(--eui-s-2xs);box-shadow:0 0 0 1px transparent}.eui-select--loading-icon--sm:after,.eui-select--loading-icon--sm:before{height:var(--eui-s-m);width:var(--eui-s-m)}@keyframes eui-loading{to{transform:rotate(360deg)}}.eui-icon-input--start .eui-select{padding-left:var(--eui-s-3xl)}.eui-icon-input--end .eui-select{padding-right:var(--eui-s-3xl)}.eui-select::-webkit-scrollbar{display:inherit;height:10px;width:10px;background-color:var(--eui-c-neutral-bg-light)}.eui-select::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-select::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-select::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.eui-select:focus:not([readonly]){outline:2px solid var(--eui-c-focus)!important;outline-offset:-2px!important;transition:none}.eui-select:focus-visible:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-select [tabindex=\"0\"]:focus:not([readonly]){outline:2px solid var(--eui-c-focus-visible)!important;outline-offset:-2px!important;transition:none}.eui-select[readonly][multiple=true] option:checked{background:none}.eui-select[hidden],.eui-select[readonly][multiple=true] :not(option:checked){display:none}.eui-select[multiple=true],.eui-select[size]:not([size=\"1\"]):not([size=\"0\"]){background-image:none;height:auto;overflow:auto;padding:var(--eui-s-2xs) 0}.eui-select__placeholder{color:var(--eui-c-neutral-lighter)!important}.eui-select__item{color:var(--eui-c-neutral)}.eui-select optgroup{font:var(--eui-f-m-bold)}.eui-select optgroup,.eui-select option{appearance:none;color:var(--eui-c-neutral);display:block;padding:var(--eui-s-2xs);white-space:pre}.eui-select optgroup:disabled,.eui-select option:disabled{color:var(--eui-c-neutral-lightest)}.eui-select:not([readonly]):not([multiple]),.eui-select[size=\"1\"],.eui-select[size=\"0\"]{appearance:none;background-color:var(--eui-c-white);background-image:var(--eui-internal-icon-chevron-down-path);background-position:calc(100% - var(--eui-s-s)) center;background-repeat:no-repeat;background-size:var(--eui-s-m);padding-right:var(--eui-s-2xl)}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
149
143
|
}
|
150
144
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiSelectComponent, decorators: [{
|
151
145
|
type: Component,
|
@@ -153,11 +147,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
|
|
153
147
|
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.Injector }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }], propDecorators: { placeholder: [{
|
154
148
|
type: Input
|
155
149
|
}], readonly: [{
|
156
|
-
type: Input
|
150
|
+
type: Input,
|
151
|
+
args: [{ transform: booleanAttribute }]
|
157
152
|
}], isInvalid: [{
|
158
153
|
type: Input
|
159
154
|
}], onChange: [{
|
160
155
|
type: HostListener,
|
161
156
|
args: ['change', ['$event.target.value']]
|
162
157
|
}] } });
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-select.component.js","sourceRoot":"","sources":["../../../eui-select/eui-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ComponentRef,\n    DoCheck,\n    ElementRef,\n    HostListener,\n    Injector,\n    Input,\n    OnChanges,\n    OnInit,\n    Renderer2,\n    SimpleChanges,\n    ViewContainerRef,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { EuiInputTextComponent } from '@eui/components/eui-input-text';\nimport { NgControl } from '@angular/forms';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'select[euiSelect]',\n    styleUrls: ['./styles/_index.scss'],\n    template: '<ng-content></ng-content>',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiSelectComponent implements OnChanges, OnInit, DoCheck {\n    @Input() placeholder: string;\n\n    @Input()\n    public get readonly(): boolean {\n        return this._readonly;\n    }\n\n    public set readonly(value: BooleanInput) {\n        this._readonly = coerceBooleanProperty(value);\n    }\n\n    @Input()\n    public get isInvalid(): boolean {\n        return this._isInvalid || null;\n    }\n    public set isInvalid(state: BooleanInput) {\n        this._isInvalid = coerceBooleanProperty(state);\n        if (this._isInvalid) {\n            this.renderer.addClass(this.elementRef.nativeElement, 'eui-select--invalid');\n        } else {\n            this.renderer.removeClass(this.elementRef.nativeElement, 'eui-select--invalid');\n        }\n    }\n\n    protected _isInvalid: boolean;\n    private _readonly: boolean;\n    private control: NgControl;\n    private readonlyInput: ComponentRef<EuiInputTextComponent>;\n    private placeholderOption: HTMLOptionElement;\n\n    constructor(\n        private renderer: Renderer2,\n        private injector: Injector,\n        private elementRef: ElementRef<HTMLSelectElement>,\n        private viewContainerRef: ViewContainerRef,\n    ) {}\n\n    ngOnInit(): void {\n        this.renderer.addClass(this.elementRef.nativeElement, 'eui-select');\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['readonly']) {\n            if (this.readonly) {\n                // hide select element\n                this.renderer.setAttribute(this.elementRef.nativeElement, 'readonly', 'true');\n                this.renderer.setAttribute(this.elementRef.nativeElement, 'hidden', '');\n\n                // create an euiInputComponent to hold the value (for accessibility reasons)\n                this.readonlyInput = this.createReadonlyElement();\n                this.renderer.insertBefore(\n                    this.elementRef.nativeElement.parentElement,\n                    this.elementRef.nativeElement,\n                    this.readonlyInput.location.nativeElement,\n                );\n                this.setReadonlyValue(this.readonlyInput);\n            } else {\n                this.readonlyInput?.destroy();\n                this.renderer.removeAttribute(this.elementRef.nativeElement, 'readonly');\n                this.renderer.removeAttribute(this.elementRef.nativeElement, 'hidden');\n            }\n        }\n\n        if (changes['placeholder']) {\n            this.control = this.injector.get(NgControl, undefined, { optional: true });\n            if (!this.control) {\n                // in case option Element already created update the value\n                if (changes['placeholder'].currentValue === undefined) {\n                    this.renderer.removeClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n                    // remove option element\n                    if (this.placeholderOption) {\n                        this.renderer.removeChild(this.elementRef.nativeElement, this.placeholderOption);\n                        this.placeholderOption = undefined;\n                    }\n                } else if (this.placeholderOption) {\n                    this.renderer.setProperty(this.placeholderOption, 'innerText', changes['placeholder'].currentValue);\n                } else {\n                    // create option Element\n                    this.placeholderOption = this.renderer.createElement('option');\n\n                    this.renderer.addClass(this.placeholderOption, 'eui-select__placeholder');\n                    this.renderer.setProperty(this.placeholderOption, 'innerText', changes['placeholder'].currentValue);\n                    // set attributes to act as a placeholder\n                    if (!this.elementRef.nativeElement.value) {\n                        this.renderer.setAttribute(this.placeholderOption, 'selected', '');\n                    }\n                    // append option element as the first of the select children\n                    this.elementRef.nativeElement.insertBefore(this.placeholderOption, this.elementRef.nativeElement.firstChild);\n\n                    if (this.elementRef.nativeElement.value === changes['placeholder'].currentValue) {\n                        this.renderer.addClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n                    }\n                }\n            }\n        }\n    }\n\n    ngDoCheck(): void {\n        if (!this.control) {\n            this.control = this.injector.get(NgControl, undefined, { optional: true });\n        }\n        this.isInvalid = this.control ? this.control.invalid && this.control.touched : this._isInvalid;\n        /** while the optionList changes but there's no selected option and there's a placeholder, add the placeholder\n         *  class. Otherwise, the placeholder will look selected but the color will be black. */\n        if (this.placeholder && this.elementRef.nativeElement.selectedIndex === 0) {\n            this.renderer.addClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n        }\n    }\n\n    @HostListener('change', ['$event.target.value'])\n    onChange(value): void {\n        this.control = this.injector.get(NgControl, undefined, { optional: true });\n        if (!this.control) {\n            this.setPlaceholderClass(this.placeholder === value ? undefined : value);\n        }\n        this.syncReadOnlyValue();\n    }\n\n    syncReadOnlyValue(): void {\n        this.setReadonlyValue(this.readonlyInput);\n    }\n\n    /**\n     * set readonly value from selected options presented as comma separated string\n     *\n     * @param readonlyRef the input element to set the value\n     * @private\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    private setReadonlyValue(readonlyRef: ComponentRef<EuiInputTextComponent>): any {\n        if (readonlyRef) {\n            // eslint-disable-next-line prefer-spread\n            const selectedOptions = Array.apply(null, this.elementRef.nativeElement.selectedOptions)\n                .map((i) => i.text)\n                .filter((i) => i !== this.placeholder)\n                .join(', ');\n            this.renderer.setProperty(readonlyRef.location.nativeElement, 'value', selectedOptions);\n            this.renderer.setAttribute(readonlyRef.location.nativeElement, 'aria-label', selectedOptions);\n        }\n    }\n\n    /**\n     * create readonly element\n     *\n     * @private\n     */\n    private createReadonlyElement(): ComponentRef<EuiInputTextComponent> {\n        const componentRef = this.viewContainerRef.createComponent(EuiInputTextComponent);\n        componentRef.instance.readonly = true;\n        return componentRef;\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    private setPlaceholderClass(value: any): void {\n        const placeholderOption = this.elementRef.nativeElement.options[0];\n        if (!!this.placeholder && (value === undefined || value === null || value === '')) {\n            this.renderer.setAttribute(placeholderOption, 'selected', '');\n            this.renderer.addClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n        } else {\n            this.renderer.removeClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n            this.renderer.removeAttribute(placeholderOption, 'selected');\n        }\n    }\n}\n"]}
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-select.component.js","sourceRoot":"","sources":["../../../eui-select/eui-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    booleanAttribute,\n    Component,\n    ComponentRef,\n    DoCheck,\n    ElementRef,\n    HostListener,\n    Injector,\n    Input,\n    OnChanges,\n    OnInit,\n    Renderer2,\n    SimpleChanges,\n    ViewContainerRef,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { EuiInputTextComponent } from '@eui/components/eui-input-text';\nimport { NgControl } from '@angular/forms';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'select[euiSelect]',\n    styleUrls: ['./styles/_index.scss'],\n    template: '<ng-content></ng-content>',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiSelectComponent implements OnChanges, OnInit, DoCheck {\n    @Input() placeholder: string;\n\n    @Input({ transform: booleanAttribute }) readonly: boolean;\n\n    @Input()\n    public get isInvalid(): boolean {\n        return this._isInvalid || null;\n    }\n    public set isInvalid(state: BooleanInput) {\n        this._isInvalid = coerceBooleanProperty(state);\n        if (this._isInvalid) {\n            this.renderer.addClass(this.elementRef.nativeElement, 'eui-select--invalid');\n        } else {\n            this.renderer.removeClass(this.elementRef.nativeElement, 'eui-select--invalid');\n        }\n    }\n\n    protected _isInvalid: boolean;\n    private control: NgControl;\n    private readonlyInput: ComponentRef<EuiInputTextComponent>;\n    private placeholderOption: HTMLOptionElement;\n\n    constructor(\n        private renderer: Renderer2,\n        private injector: Injector,\n        private elementRef: ElementRef<HTMLSelectElement>,\n        private viewContainerRef: ViewContainerRef,\n    ) {}\n\n    ngOnInit(): void {\n        this.renderer.addClass(this.elementRef.nativeElement, 'eui-select');\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['readonly']) {\n            if (this.readonly) {\n                // hide select element\n                this.renderer.setAttribute(this.elementRef.nativeElement, 'readonly', 'true');\n                this.renderer.setAttribute(this.elementRef.nativeElement, 'hidden', '');\n\n                // create an euiInputComponent to hold the value (for accessibility reasons)\n                this.readonlyInput = this.createReadonlyElement();\n                this.renderer.insertBefore(\n                    this.elementRef.nativeElement.parentElement,\n                    this.elementRef.nativeElement,\n                    this.readonlyInput.location.nativeElement,\n                );\n                this.setReadonlyValue(this.readonlyInput);\n            } else {\n                this.readonlyInput?.destroy();\n                this.renderer.removeAttribute(this.elementRef.nativeElement, 'readonly');\n                this.renderer.removeAttribute(this.elementRef.nativeElement, 'hidden');\n            }\n        }\n\n        if (changes['placeholder']) {\n            this.control = this.injector.get(NgControl, undefined, { optional: true });\n            if (!this.control) {\n                // in case option Element already created update the value\n                if (changes['placeholder'].currentValue === undefined) {\n                    this.renderer.removeClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n                    // remove option element\n                    if (this.placeholderOption) {\n                        this.renderer.removeChild(this.elementRef.nativeElement, this.placeholderOption);\n                        this.placeholderOption = undefined;\n                    }\n                } else if (this.placeholderOption) {\n                    this.renderer.setProperty(this.placeholderOption, 'innerText', changes['placeholder'].currentValue);\n                } else {\n                    // create option Element\n                    this.placeholderOption = this.renderer.createElement('option');\n\n                    this.renderer.addClass(this.placeholderOption, 'eui-select__placeholder');\n                    this.renderer.setProperty(this.placeholderOption, 'innerText', changes['placeholder'].currentValue);\n                    // set attributes to act as a placeholder\n                    if (!this.elementRef.nativeElement.value) {\n                        this.renderer.setAttribute(this.placeholderOption, 'selected', '');\n                    }\n                    // append option element as the first of the select children\n                    this.elementRef.nativeElement.insertBefore(this.placeholderOption, this.elementRef.nativeElement.firstChild);\n\n                    if (this.elementRef.nativeElement.value === changes['placeholder'].currentValue) {\n                        this.renderer.addClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n                    }\n                }\n            }\n        }\n    }\n\n    ngDoCheck(): void {\n        if (!this.control) {\n            this.control = this.injector.get(NgControl, undefined, { optional: true });\n        }\n        this.isInvalid = this.control ? this.control.invalid && this.control.touched : this._isInvalid;\n        /** while the optionList changes but there's no selected option and there's a placeholder, add the placeholder\n         *  class. Otherwise, the placeholder will look selected but the color will be black. */\n        if (this.placeholder && this.elementRef.nativeElement.selectedIndex === 0) {\n            this.renderer.addClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n        }\n    }\n\n    @HostListener('change', ['$event.target.value'])\n    onChange(value): void {\n        this.control = this.injector.get(NgControl, undefined, { optional: true });\n        if (!this.control) {\n            this.setPlaceholderClass(this.placeholder === value ? undefined : value);\n        }\n        this.syncReadOnlyValue();\n    }\n\n    syncReadOnlyValue(): void {\n        this.setReadonlyValue(this.readonlyInput);\n    }\n\n    /**\n     * set readonly value from selected options presented as comma separated string\n     *\n     * @param readonlyRef the input element to set the value\n     * @private\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    private setReadonlyValue(readonlyRef: ComponentRef<EuiInputTextComponent>): any {\n        if (readonlyRef) {\n            // eslint-disable-next-line prefer-spread\n            const selectedOptions = Array.apply(null, this.elementRef.nativeElement.selectedOptions)\n                .map((i) => i.text)\n                .filter((i) => i !== this.placeholder)\n                .join(', ');\n            this.renderer.setProperty(readonlyRef.location.nativeElement, 'value', selectedOptions);\n            this.renderer.setAttribute(readonlyRef.location.nativeElement, 'aria-label', selectedOptions);\n        }\n    }\n\n    /**\n     * create readonly element\n     *\n     * @private\n     */\n    private createReadonlyElement(): ComponentRef<EuiInputTextComponent> {\n        const componentRef = this.viewContainerRef.createComponent(EuiInputTextComponent);\n        componentRef.instance.readonly = true;\n        return componentRef;\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    private setPlaceholderClass(value: any): void {\n        const placeholderOption = this.elementRef.nativeElement.options[0];\n        if (!!this.placeholder && (value === undefined || value === null || value === '')) {\n            this.renderer.setAttribute(placeholderOption, 'selected', '');\n            this.renderer.addClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n        } else {\n            this.renderer.removeClass(this.elementRef.nativeElement, 'eui-select__placeholder');\n            this.renderer.removeAttribute(placeholderOption, 'selected');\n        }\n    }\n}\n"]}
|
@@ -25,11 +25,11 @@ export class EuiSidebarMenuComponent {
|
|
25
25
|
this.menuClick.emit(event);
|
26
26
|
}
|
27
27
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiSidebarMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
28
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: EuiSidebarMenuComponent, isStandalone: true, selector: "eui-sidebar-menu", inputs: { items: "items", hasCollapsedInitials: ["hasCollapsedInitials", "hasCollapsedInitials", booleanAttribute], isCollapsed: ["isCollapsed", "isCollapsed", booleanAttribute], hasFilter: ["hasFilter", "hasFilter", booleanAttribute], hasIcons: ["hasIcons", "hasIcons", booleanAttribute], hasTooltip: ["hasTooltip", "hasTooltip", booleanAttribute], expandAllItems: ["expandAllItems", "expandAllItems", booleanAttribute], hasBoldRootLevel: ["hasBoldRootLevel", "hasBoldRootLevel", booleanAttribute], style: "style", fragmentId: "fragmentId", searchFilterLabel: "searchFilterLabel", externalTarget: "externalTarget", filterValue: "filterValue" }, outputs: { menuClick: "menuClick", itemClick: "itemClick" }, host: { properties: { "class": "this.string" } }, ngImport: i0, template: "<!--TODO: set the classes into one div container instead of two-->\n<div class=\"eui-sidebar-menu__container\" [class.eui-sidebar-menu__container--collapsed]=\"isCollapsed\" [style]=\"style\">\n <div class=\"eui-sidebar-menu__content\">\n <eui-menu\n [items]=\"items\"\n [hasFilter]=\"hasFilter\"\n [hasIcons]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n [expandAllItems]=\"expandAllItems\"\n [fragmentId]=\"fragmentId\"\n [searchFilterLabel]=\"searchFilterLabel\"\n [filterValue]=\"filterValue\"\n [hasBoldRootLevel]=\"hasBoldRootLevel\"\n (isClick)=\"onMenuClicked($event)\"\n (itemClick)=\"onMenuItemClicked($event)\">\n </eui-menu>\n </div>\n</div>\n", styles: [".eui-sidebar-menu{display:flex;height:100%;width:100%}.eui-sidebar-menu .eui-sidebar-menu__container{background-color:var(--eui-c-bg);height:100%;transition:all .1s ease;width:100%}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content{box-shadow:0 8px 8px #b7c0ce33;display:flex;flex-direction:column;height:100%;overflow-x:hidden;overflow-y:auto;position:relative}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar{display:inherit;height:
|
28
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: EuiSidebarMenuComponent, isStandalone: true, selector: "eui-sidebar-menu", inputs: { items: "items", hasCollapsedInitials: ["hasCollapsedInitials", "hasCollapsedInitials", booleanAttribute], isCollapsed: ["isCollapsed", "isCollapsed", booleanAttribute], hasFilter: ["hasFilter", "hasFilter", booleanAttribute], hasIcons: ["hasIcons", "hasIcons", booleanAttribute], hasTooltip: ["hasTooltip", "hasTooltip", booleanAttribute], expandAllItems: ["expandAllItems", "expandAllItems", booleanAttribute], hasBoldRootLevel: ["hasBoldRootLevel", "hasBoldRootLevel", booleanAttribute], style: "style", fragmentId: "fragmentId", searchFilterLabel: "searchFilterLabel", externalTarget: "externalTarget", filterValue: "filterValue" }, outputs: { menuClick: "menuClick", itemClick: "itemClick" }, host: { properties: { "class": "this.string" } }, ngImport: i0, template: "<!--TODO: set the classes into one div container instead of two-->\n<div class=\"eui-sidebar-menu__container\" [class.eui-sidebar-menu__container--collapsed]=\"isCollapsed\" [style]=\"style\">\n <div class=\"eui-sidebar-menu__content\">\n <eui-menu\n [items]=\"items\"\n [hasFilter]=\"hasFilter\"\n [hasIcons]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n [expandAllItems]=\"expandAllItems\"\n [fragmentId]=\"fragmentId\"\n [searchFilterLabel]=\"searchFilterLabel\"\n [filterValue]=\"filterValue\"\n [hasBoldRootLevel]=\"hasBoldRootLevel\"\n (isClick)=\"onMenuClicked($event)\"\n (itemClick)=\"onMenuItemClicked($event)\">\n </eui-menu>\n </div>\n</div>\n", styles: [".eui-sidebar-menu{display:flex;height:100%;width:100%}.eui-sidebar-menu .eui-sidebar-menu__container{background-color:var(--eui-c-bg);height:100%;transition:all .1s ease;width:100%}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content{box-shadow:0 8px 8px #b7c0ce33;display:flex;flex-direction:column;height:100%;overflow-x:hidden;overflow-y:auto;position:relative}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-c-neutral-bg-light)}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.eui-page-column__body .eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content{box-shadow:inherit}.eui-sidebar-menu .eui-sidebar-menu__container--collapsed{position:relative;width:var(--eui-app-sidebar-width-close-active)}\n"], dependencies: [{ kind: "ngmodule", type: EuiMenuModule }, { kind: "component", type: i1.EuiMenuComponent, selector: "eui-menu", inputs: ["items", "searchFilterLabel", "externalLinkLabel", "fragmentId", "filterValue", "isCollapsed", "hasCollapsedInitials", "hasFilter", "hasIcons", "hasTooltip", "expandAllItems", "isFlat", "hasScrollToItem", "hasBoldRootLevel"], outputs: ["isClick", "itemClick"] }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
|
29
29
|
}
|
30
30
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiSidebarMenuComponent, decorators: [{
|
31
31
|
type: Component,
|
32
|
-
args: [{ selector: 'eui-sidebar-menu', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, standalone: true, imports: [EuiMenuModule], template: "<!--TODO: set the classes into one div container instead of two-->\n<div class=\"eui-sidebar-menu__container\" [class.eui-sidebar-menu__container--collapsed]=\"isCollapsed\" [style]=\"style\">\n <div class=\"eui-sidebar-menu__content\">\n <eui-menu\n [items]=\"items\"\n [hasFilter]=\"hasFilter\"\n [hasIcons]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n [expandAllItems]=\"expandAllItems\"\n [fragmentId]=\"fragmentId\"\n [searchFilterLabel]=\"searchFilterLabel\"\n [filterValue]=\"filterValue\"\n [hasBoldRootLevel]=\"hasBoldRootLevel\"\n (isClick)=\"onMenuClicked($event)\"\n (itemClick)=\"onMenuItemClicked($event)\">\n </eui-menu>\n </div>\n</div>\n", styles: [".eui-sidebar-menu{display:flex;height:100%;width:100%}.eui-sidebar-menu .eui-sidebar-menu__container{background-color:var(--eui-c-bg);height:100%;transition:all .1s ease;width:100%}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content{box-shadow:0 8px 8px #b7c0ce33;display:flex;flex-direction:column;height:100%;overflow-x:hidden;overflow-y:auto;position:relative}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar{display:inherit;height:
|
32
|
+
args: [{ selector: 'eui-sidebar-menu', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, standalone: true, imports: [EuiMenuModule], template: "<!--TODO: set the classes into one div container instead of two-->\n<div class=\"eui-sidebar-menu__container\" [class.eui-sidebar-menu__container--collapsed]=\"isCollapsed\" [style]=\"style\">\n <div class=\"eui-sidebar-menu__content\">\n <eui-menu\n [items]=\"items\"\n [hasFilter]=\"hasFilter\"\n [hasIcons]=\"hasIcons\"\n [hasTooltip]=\"hasTooltip\"\n [isCollapsed]=\"isCollapsed\"\n [hasCollapsedInitials]=\"hasCollapsedInitials\"\n [expandAllItems]=\"expandAllItems\"\n [fragmentId]=\"fragmentId\"\n [searchFilterLabel]=\"searchFilterLabel\"\n [filterValue]=\"filterValue\"\n [hasBoldRootLevel]=\"hasBoldRootLevel\"\n (isClick)=\"onMenuClicked($event)\"\n (itemClick)=\"onMenuItemClicked($event)\">\n </eui-menu>\n </div>\n</div>\n", styles: [".eui-sidebar-menu{display:flex;height:100%;width:100%}.eui-sidebar-menu .eui-sidebar-menu__container{background-color:var(--eui-c-bg);height:100%;transition:all .1s ease;width:100%}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content{box-shadow:0 8px 8px #b7c0ce33;display:flex;flex-direction:column;height:100%;overflow-x:hidden;overflow-y:auto;position:relative}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-c-neutral-bg-light)}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar-thumb{background-color:var(--eui-c-neutral-lightest);border-radius:5rem}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar-thumb:hover{background-color:var(--eui-c-neutral-lighter)}.eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content::-webkit-scrollbar-track{background-color:var(--eui-c-neutral-bg-light);border-radius:0}.eui-page-column__body .eui-sidebar-menu .eui-sidebar-menu__container .eui-sidebar-menu__content{box-shadow:inherit}.eui-sidebar-menu .eui-sidebar-menu__container--collapsed{position:relative;width:var(--eui-app-sidebar-width-close-active)}\n"] }]
|
33
33
|
}], propDecorators: { string: [{
|
34
34
|
type: HostBinding,
|
35
35
|
args: ['class']
|