@eui/components 17.2.1-snapshot-1707877313882 → 17.2.1-snapshot-1708395642178
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/EuiNotificationsV2Component.html +21 -1
- package/docs/components/EuiToolbarMenuComponent.html +1 -1
- package/docs/dependencies.html +2 -2
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/eui-dialog/container/eui-dialog-container.component.mjs +2 -2
- package/esm2022/eui-dropdown/eui-dropdown.component.mjs +2 -2
- package/esm2022/eui-table/eui-table.component.mjs +2 -2
- package/esm2022/externals/eui-editor/eui-editor.component.mjs +2 -2
- package/esm2022/layout/eui-notifications-v2/eui-notifications.component.mjs +6 -3
- package/esm2022/layout/eui-toolbar/toolbar-menu/toolbar-menu.component.mjs +3 -3
- package/fesm2022/eui-components-eui-dialog.mjs +1 -1
- package/fesm2022/eui-components-eui-dialog.mjs.map +1 -1
- package/fesm2022/eui-components-eui-dropdown.mjs +1 -1
- package/fesm2022/eui-components-eui-dropdown.mjs.map +1 -1
- package/fesm2022/eui-components-eui-table.mjs +2 -2
- package/fesm2022/eui-components-eui-table.mjs.map +1 -1
- package/fesm2022/eui-components-externals-eui-editor.mjs +1 -1
- package/fesm2022/eui-components-externals-eui-editor.mjs.map +1 -1
- package/fesm2022/eui-components-layout.mjs +7 -4
- package/fesm2022/eui-components-layout.mjs.map +1 -1
- package/layout/eui-notifications-v2/eui-notifications.component.d.ts +1 -0
- package/layout/eui-notifications-v2/eui-notifications.component.d.ts.map +1 -1
- package/package.json +7 -7
@@ -80,7 +80,7 @@ export class EuiDialogContainerComponent {
|
|
80
80
|
if (this.dialogContainerConfig[component].config) {
|
81
81
|
Object.keys(this.dialogContainerConfig[component].config).forEach((c) => {
|
82
82
|
if (typeof this.dialogContainerConfig[component].config[c] === 'function') {
|
83
|
-
if (componentRef.instance[c]) {
|
83
|
+
if (componentRef.instance[c] && typeof componentRef.instance[c] !== 'function') {
|
84
84
|
// TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
|
85
85
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
86
86
|
componentRef.instance[c].pipe(takeUntil(this.destroy$)).subscribe((args) => {
|
@@ -177,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
177
177
|
type: HostBinding,
|
178
178
|
args: ['attr.aria-modal']
|
179
179
|
}] } });
|
180
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-dialog-container.component.js","sourceRoot":"","sources":["../../../../eui-dialog/container/eui-dialog-container.component.ts","../../../../eui-dialog/container/eui-dialog-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ChangeDetectionStrategy,\n    ViewEncapsulation,\n    OnInit,\n    ComponentRef,\n    Inject,\n    Injector,\n    StaticProvider,\n    OnDestroy,\n    HostBinding,\n    ChangeDetectorRef,\n} from '@angular/core';\nimport { CdkPortalOutletAttachedRef, ComponentPortal, ComponentType, TemplatePortal } from '@angular/cdk/portal';\nimport { BehaviorSubject, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { DIALOG_CONTAINER_CONFIG } from '../services/eui-dialog.token';\nimport { EuiDialogInterface, EuiDialogComponentInstances } from '../models/eui-dialog.config';\nimport { DIALOG_COMPONENT_CONFIG } from '../services/eui-dialog.token';\n\n@Component({\n    selector: 'eui-dialog-container',\n    templateUrl: './eui-dialog-container.component.html',\n    styleUrls: ['../styles/_index.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiDialogContainerComponent<HC, HCC, BC, BCC, FC, FCC> implements OnInit, OnDestroy {\n    public isHeaderTemplatePortal = false;\n    public isBodyTemplatePortal = false;\n    public isFooterTemplatePortal = false;\n\n    public isHeaderComponentPortal = false;\n    public isBodyComponentPortal = false;\n    public isFooterComponentPortal = false;\n\n    public headerComponentPortal: ComponentPortal<HC>;\n    public bodyComponentPortal: ComponentPortal<BC>;\n    public footerComponentPortal: ComponentPortal<FC>;\n\n    public componentInstances = new EuiDialogComponentInstances<HC, BC, FC>();\n    public acceptButtonDisabled$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    public dismissButtonDisabled$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n\n    @HostBinding('class') string = 'eui-dialog-container';\n    @HostBinding('attr.aria-modal') ariaModal = true;\n\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        @Inject(DIALOG_CONTAINER_CONFIG) public dialogContainerConfig: EuiDialogInterface<HC, HCC, BC, BCC, FC, FCC>,\n        private injector: Injector,\n        private cd: ChangeDetectorRef,\n    ) {}\n\n    ngOnInit(): void {\n        if (this.dialogContainerConfig.header instanceof TemplatePortal) {\n            this.isHeaderTemplatePortal = true;\n        }\n        if (this.dialogContainerConfig.content instanceof TemplatePortal) {\n            this.isBodyTemplatePortal = true;\n        }\n        if (this.dialogContainerConfig.footer instanceof TemplatePortal) {\n            this.isFooterTemplatePortal = true;\n        }\n\n        if (this.dialogContainerConfig.headerComponent?.component) {\n            this.isHeaderComponentPortal = true;\n            this.headerComponentPortal = this.createComponentPortal(\n                this.dialogContainerConfig.headerComponent.component,\n                this.dialogContainerConfig.headerComponent.config,\n            ) as ComponentPortal<HC>;\n        }\n        if (this.dialogContainerConfig.bodyComponent?.component) {\n            this.isBodyComponentPortal = true;\n            this.bodyComponentPortal = this.createComponentPortal(\n                this.dialogContainerConfig.bodyComponent.component,\n                this.dialogContainerConfig.bodyComponent.config,\n            ) as ComponentPortal<BC>;\n        }\n        if (this.dialogContainerConfig.footerComponent?.component) {\n            this.isFooterComponentPortal = true;\n            this.footerComponentPortal = this.createComponentPortal(\n                this.dialogContainerConfig.footerComponent.component,\n                this.dialogContainerConfig.footerComponent.config,\n            ) as ComponentPortal<FC>;\n        }\n\n        this.dialogContainerConfig.open();\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    get getComponentInstances(): EuiDialogComponentInstances<HC, BC, FC> {\n        return this.componentInstances;\n    }\n\n    get getPortalOutlet(): TemplatePortal | null {\n        return this.dialogContainerConfig.content as TemplatePortal;\n    }\n\n    get dialogContainerConfigContent(): string {\n        return this.dialogContainerConfig.content as string;\n    }\n\n    public portalAttached(\n        attachedRef: CdkPortalOutletAttachedRef,\n        component: 'headerComponent' | 'bodyComponent' | 'footerComponent',\n    ): void {\n        const componentRef = attachedRef as ComponentRef<HC | BC | FC>;\n\n        componentRef.instance['overlayRef'] = this.dialogContainerConfig.overlayRef;\n\n        this.componentInstances = {\n            ...this.componentInstances,\n            [component]: componentRef.instance,\n        };\n\n        this.dialogContainerConfig.init(this.componentInstances);\n\n        if (this.dialogContainerConfig[component].config) {\n            Object.keys(this.dialogContainerConfig[component].config).forEach((c) => {\n                if (typeof this.dialogContainerConfig[component].config[c] === 'function') {\n                    if (componentRef.instance[c]) {\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                        componentRef.instance[c].pipe(takeUntil(this.destroy$)).subscribe((args: any) => {\n                            this.dialogContainerConfig[component].config[c].apply(componentRef.instance[c], [args]);\n                        });\n                    }\n                } else {\n                    componentRef.instance[c] = this.dialogContainerConfig[component].config[c];\n                }\n            });\n        }\n    }\n\n    public closeDialog(): void {\n        this.dialogContainerConfig.close(this.componentInstances);\n    }\n\n    public onDismiss(): void {\n        this.dialogContainerConfig.dismiss(this.componentInstances);\n        if (!this.dialogContainerConfig.isHandleCloseOnDismiss) {\n            this.closeDialog();\n        }\n    }\n\n    public onAccept(): void {\n        this.dialogContainerConfig.accept(this.componentInstances);\n        if (!this.dialogContainerConfig.isHandleCloseOnAccept) {\n            this.closeDialog();\n        }\n    }\n\n    /**\n     * Based on certain conditions returns the id of the body content to the aria-describedby attr of the container\n     */\n    public getContentId(): string {\n        if(!this.isBodyTemplatePortal && !this.isBodyComponentPortal) {\n            return 'containerConfigId';\n        } else if (this.isBodyTemplatePortal && !this.isBodyComponentPortal) {\n            return 'bodyTemplatePortalId';\n        } else if(this.isBodyComponentPortal) {\n            return 'bodyComponentPortalId'\n        }\n    }\n\n    /**\n     * Disable Accept button of default eui-dialog footer.\n     */\n    public disableAcceptButton(): void {\n        this.acceptButtonDisabled$.next(true);\n    }\n\n    /**\n     * Enable Accept button of default eui-dialog footer.\n     */\n    public enableAcceptButton(): void {\n        this.acceptButtonDisabled$.next(false);\n    }\n\n    /**\n     * Disable Dismiss button of default eui-dialog footer.\n     */\n    public disableDismissButton(): void {\n        this.dismissButtonDisabled$.next(true);\n    }\n\n    /**\n     * Enable Dismiss button of default eui-dialog footer.\n     */\n    public enableDismissButton(): void {\n        this.dismissButtonDisabled$.next(false);\n    }\n\n    public onScroll(): void {\n        this.cd.detectChanges();\n    }\n\n    private createComponentPortal(component: ComponentType<HC | BC | FC>, config: HCC | BCC | FCC): ComponentPortal<HC | BC | FC> {\n        const extendedConfig = { ...config, id: this.dialogContainerConfig.dialogId, overlayRef: this.dialogContainerConfig.overlayRef };\n        return new ComponentPortal(component, null, this.createInjector(extendedConfig));\n    }\n\n    private createInjector(data: HCC | BCC | FCC): Injector {\n        const injectorTokens: StaticProvider = [{ provide: DIALOG_COMPONENT_CONFIG, useValue: data }];\n        return Injector.create({\n            parent: this.injector,\n            providers: injectorTokens,\n        });\n    }\n}\n","<div\n    class=\"eui-dialog eui-dialog--{{ dialogContainerConfig.typeClass }}\"\n    [class.eui-dialog--draggable]=\"dialogContainerConfig.isDraggable\"\n    [class.eui-dialog--message-box]=\"dialogContainerConfig.isMessageBox\"\n    [class.eui-dialog--no-padding]=\"dialogContainerConfig.hasNoBodyPadding\"\n    [class.eui-dialog--custom-size]=\"dialogContainerConfig.hasMobileCustomSize\"\n    [attr.role]=\"dialogContainerConfig.isMessageBox ? 'alertdialog' : 'dialog'\"\n    aria-labelledby=\"dialogContent\"\n    [attr.aria-describedby]=\"getContentId()\"\n    tabindex=\"-1\"\n    attr.data-e2e=\"{{ dialogContainerConfig.e2eAttr }}\"\n    cdkDrag\n    cdkDragRootElement=\".cdk-overlay-pane\"\n    [cdkDragDisabled]=\"!dialogContainerConfig.isDraggable\"\n    cdkTrapFocus\n    cdkTrapFocusAutoCapture>\n    <div class=\"eui-dialog__content\" role=\"document\" id=\"dialogContent\" aria-labelledby=\"headerTitle\">\n        <div class=\"eui-dialog__header\" [class.eui-dialog__header--handle-disabled]=\"!dialogContainerConfig.isDraggable\" cdkDragHandle>\n            <ng-container *ngIf=\"!isHeaderTemplatePortal && !isHeaderComponentPortal\">\n                <h5 id=\"headerTitle\" class=\"eui-dialog__header-title\">{{ dialogContainerConfig.title | translate }}</h5>\n                <button\n                    *ngIf=\"dialogContainerConfig.hasCloseButton\"\n                    class=\"dialog-close-button\"\n                    (click)=\"closeDialog()\"\n                    euiButton\n                    euiIconButton\n                    euiRounded\n                    euiBasicButton\n                    euiSizeS\n                    aria-label=\"Dialog close icon\">\n                    <eui-icon-svg icon=\"eui-close\"></eui-icon-svg>\n                </button>\n            </ng-container>\n            <ng-container *ngIf=\"isHeaderTemplatePortal\">\n                <ng-template [cdkPortalOutlet]=\"dialogContainerConfig.header\"></ng-template>\n            </ng-container>\n            <ng-container *ngIf=\"isHeaderComponentPortal\">\n                <ng-template [cdkPortalOutlet]=\"headerComponentPortal\" (attached)=\"portalAttached($event, 'headerComponent')\"></ng-template>\n            </ng-container>\n        </div>\n        <div\n            class=\"eui-dialog__body\"\n            cdkScrollable\n            [style.height]=\"dialogContainerConfig.height\"\n            [style.max-height]=\"dialogContainerConfig.height\"\n            (scroll)=\"onScroll()\"\n            tabindex=\"0\">\n            <span *ngIf=\"dialogContainerConfig.isMessageBox\" class=\"eui-dialog__body-content-icon-container\">\n                <div class=\"eui-dialog__body-content-icon\">\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'primary'\">\n                        <eui-icon-svg icon=\"eui-question\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'secondary'\">\n                        <eui-icon-svg icon=\"eui-ecl-warning\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'info'\">\n                        <eui-icon-svg icon=\"eui-info\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'success'\">\n                        <eui-icon-svg icon=\"eui-check\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'warning'\">\n                        <eui-icon-svg icon=\"eui-ecl-warning\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'danger'\">\n                        <eui-icon-svg icon=\"eui-ecl-error\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                </div>\n            </span>\n            <div\n                *ngIf=\"!isBodyTemplatePortal && !isBodyComponentPortal\"\n                id=\"containerConfigId\"\n                class=\"eui-dialog__body-content not-isBodyTemplatePortal\"\n                [innerHTML]=\"dialogContainerConfig.content ? (dialogContainerConfigContent | translate) : null\"></div>\n            <div *ngIf=\"isBodyTemplatePortal && !isBodyComponentPortal\" id=\"bodyTemplatePortalId\" class=\"eui-dialog__body-content isBodyTemplatePortal\">\n                <ng-template [cdkPortalOutlet]=\"getPortalOutlet\"></ng-template>\n            </div>\n            <div *ngIf=\"isBodyComponentPortal\" id=\"bodyComponentPortalId\" class=\"eui-dialog__body-content isBodyComponentPortal\">\n                <ng-template [cdkPortalOutlet]=\"bodyComponentPortal\" (attached)=\"portalAttached($event, 'bodyComponent')\"></ng-template>\n            </div>\n        </div>\n        <div class=\"eui-dialog__footer\" *ngIf=\"dialogContainerConfig.hasFooter\">\n            <ng-container *ngIf=\"!isFooterTemplatePortal && !isFooterComponentPortal\">\n                <ng-container *ngIf=\"isFooterTemplatePortal\">\n                    <ng-template [cdkPortalOutlet]=\"dialogContainerConfig.footer\"></ng-template>\n                </ng-container>\n                <ng-container *ngIf=\"!isFooterTemplatePortal\">\n                    <div class=\"eui-dialog__footer-content\">\n                        <button\n                            euiButton\n                            type=\"button\"\n                            *ngIf=\"dialogContainerConfig.hasDismissButton\"\n                            [euiDisabled]=\"dismissButtonDisabled$ | async\"\n                            class=\"eui-dialog__footer-dismiss-button\"\n                            [class.eui-dialog__footer-dismiss-button--with-accept-button]=\"dialogContainerConfig.hasAcceptButton\"\n                            (click)=\"onDismiss()\">\n                            {{ dialogContainerConfig.dismissLabel | translate }}\n                        </button>\n                        <button\n                            euiButton\n                            euiPrimary\n                            type=\"button\"\n                            *ngIf=\"dialogContainerConfig.hasAcceptButton\"\n                            [euiDisabled]=\"acceptButtonDisabled$ | async\"\n                            class=\"eui-dialog__footer-accept-button\"\n                            (click)=\"onAccept()\">\n                            {{ dialogContainerConfig.acceptLabel | translate }}\n                        </button>\n                    </div>\n                </ng-container>\n            </ng-container>\n\n            <ng-container *ngIf=\"isFooterTemplatePortal\">\n                <ng-template [cdkPortalOutlet]=\"dialogContainerConfig.footer\"></ng-template>\n            </ng-container>\n            <ng-container *ngIf=\"isFooterComponentPortal\">\n                <ng-template [cdkPortalOutlet]=\"footerComponentPortal\" (attached)=\"portalAttached($event, 'footerComponent')\"></ng-template>\n            </ng-container>\n        </div>\n    </div>\n</div>\n"]}
|
180
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-dialog-container.component.js","sourceRoot":"","sources":["../../../../eui-dialog/container/eui-dialog-container.component.ts","../../../../eui-dialog/container/eui-dialog-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ChangeDetectionStrategy,\n    ViewEncapsulation,\n    OnInit,\n    ComponentRef,\n    Inject,\n    Injector,\n    StaticProvider,\n    OnDestroy,\n    HostBinding,\n    ChangeDetectorRef,\n} from '@angular/core';\nimport { CdkPortalOutletAttachedRef, ComponentPortal, ComponentType, TemplatePortal } from '@angular/cdk/portal';\nimport { BehaviorSubject, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { DIALOG_CONTAINER_CONFIG } from '../services/eui-dialog.token';\nimport { EuiDialogInterface, EuiDialogComponentInstances } from '../models/eui-dialog.config';\nimport { DIALOG_COMPONENT_CONFIG } from '../services/eui-dialog.token';\n\n@Component({\n    selector: 'eui-dialog-container',\n    templateUrl: './eui-dialog-container.component.html',\n    styleUrls: ['../styles/_index.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiDialogContainerComponent<HC, HCC, BC, BCC, FC, FCC> implements OnInit, OnDestroy {\n    public isHeaderTemplatePortal = false;\n    public isBodyTemplatePortal = false;\n    public isFooterTemplatePortal = false;\n\n    public isHeaderComponentPortal = false;\n    public isBodyComponentPortal = false;\n    public isFooterComponentPortal = false;\n\n    public headerComponentPortal: ComponentPortal<HC>;\n    public bodyComponentPortal: ComponentPortal<BC>;\n    public footerComponentPortal: ComponentPortal<FC>;\n\n    public componentInstances = new EuiDialogComponentInstances<HC, BC, FC>();\n    public acceptButtonDisabled$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    public dismissButtonDisabled$: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n\n    @HostBinding('class') string = 'eui-dialog-container';\n    @HostBinding('attr.aria-modal') ariaModal = true;\n\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        @Inject(DIALOG_CONTAINER_CONFIG) public dialogContainerConfig: EuiDialogInterface<HC, HCC, BC, BCC, FC, FCC>,\n        private injector: Injector,\n        private cd: ChangeDetectorRef,\n    ) {}\n\n    ngOnInit(): void {\n        if (this.dialogContainerConfig.header instanceof TemplatePortal) {\n            this.isHeaderTemplatePortal = true;\n        }\n        if (this.dialogContainerConfig.content instanceof TemplatePortal) {\n            this.isBodyTemplatePortal = true;\n        }\n        if (this.dialogContainerConfig.footer instanceof TemplatePortal) {\n            this.isFooterTemplatePortal = true;\n        }\n\n        if (this.dialogContainerConfig.headerComponent?.component) {\n            this.isHeaderComponentPortal = true;\n            this.headerComponentPortal = this.createComponentPortal(\n                this.dialogContainerConfig.headerComponent.component,\n                this.dialogContainerConfig.headerComponent.config,\n            ) as ComponentPortal<HC>;\n        }\n        if (this.dialogContainerConfig.bodyComponent?.component) {\n            this.isBodyComponentPortal = true;\n            this.bodyComponentPortal = this.createComponentPortal(\n                this.dialogContainerConfig.bodyComponent.component,\n                this.dialogContainerConfig.bodyComponent.config,\n            ) as ComponentPortal<BC>;\n        }\n        if (this.dialogContainerConfig.footerComponent?.component) {\n            this.isFooterComponentPortal = true;\n            this.footerComponentPortal = this.createComponentPortal(\n                this.dialogContainerConfig.footerComponent.component,\n                this.dialogContainerConfig.footerComponent.config,\n            ) as ComponentPortal<FC>;\n        }\n\n        this.dialogContainerConfig.open();\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    get getComponentInstances(): EuiDialogComponentInstances<HC, BC, FC> {\n        return this.componentInstances;\n    }\n\n    get getPortalOutlet(): TemplatePortal | null {\n        return this.dialogContainerConfig.content as TemplatePortal;\n    }\n\n    get dialogContainerConfigContent(): string {\n        return this.dialogContainerConfig.content as string;\n    }\n\n    public portalAttached(\n        attachedRef: CdkPortalOutletAttachedRef,\n        component: 'headerComponent' | 'bodyComponent' | 'footerComponent',\n    ): void {\n        const componentRef = attachedRef as ComponentRef<HC | BC | FC>;\n\n        componentRef.instance['overlayRef'] = this.dialogContainerConfig.overlayRef;\n\n        this.componentInstances = {\n            ...this.componentInstances,\n            [component]: componentRef.instance,\n        };\n\n        this.dialogContainerConfig.init(this.componentInstances);\n\n        if (this.dialogContainerConfig[component].config) {\n            Object.keys(this.dialogContainerConfig[component].config).forEach((c) => {\n                if (typeof this.dialogContainerConfig[component].config[c] === 'function') {\n                    if (componentRef.instance[c] && typeof componentRef.instance[c] !== 'function') {\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                        componentRef.instance[c].pipe(takeUntil(this.destroy$)).subscribe((args: any) => {\n                            this.dialogContainerConfig[component].config[c].apply(componentRef.instance[c], [args]);\n                        });\n                    }\n                } else {\n                    componentRef.instance[c] = this.dialogContainerConfig[component].config[c];\n                }\n            });\n        }\n    }\n\n    public closeDialog(): void {\n        this.dialogContainerConfig.close(this.componentInstances);\n    }\n\n    public onDismiss(): void {\n        this.dialogContainerConfig.dismiss(this.componentInstances);\n        if (!this.dialogContainerConfig.isHandleCloseOnDismiss) {\n            this.closeDialog();\n        }\n    }\n\n    public onAccept(): void {\n        this.dialogContainerConfig.accept(this.componentInstances);\n        if (!this.dialogContainerConfig.isHandleCloseOnAccept) {\n            this.closeDialog();\n        }\n    }\n\n    /**\n     * Based on certain conditions returns the id of the body content to the aria-describedby attr of the container\n     */\n    public getContentId(): string {\n        if(!this.isBodyTemplatePortal && !this.isBodyComponentPortal) {\n            return 'containerConfigId';\n        } else if (this.isBodyTemplatePortal && !this.isBodyComponentPortal) {\n            return 'bodyTemplatePortalId';\n        } else if(this.isBodyComponentPortal) {\n            return 'bodyComponentPortalId'\n        }\n    }\n\n    /**\n     * Disable Accept button of default eui-dialog footer.\n     */\n    public disableAcceptButton(): void {\n        this.acceptButtonDisabled$.next(true);\n    }\n\n    /**\n     * Enable Accept button of default eui-dialog footer.\n     */\n    public enableAcceptButton(): void {\n        this.acceptButtonDisabled$.next(false);\n    }\n\n    /**\n     * Disable Dismiss button of default eui-dialog footer.\n     */\n    public disableDismissButton(): void {\n        this.dismissButtonDisabled$.next(true);\n    }\n\n    /**\n     * Enable Dismiss button of default eui-dialog footer.\n     */\n    public enableDismissButton(): void {\n        this.dismissButtonDisabled$.next(false);\n    }\n\n    public onScroll(): void {\n        this.cd.detectChanges();\n    }\n\n    private createComponentPortal(component: ComponentType<HC | BC | FC>, config: HCC | BCC | FCC): ComponentPortal<HC | BC | FC> {\n        const extendedConfig = { ...config, id: this.dialogContainerConfig.dialogId, overlayRef: this.dialogContainerConfig.overlayRef };\n        return new ComponentPortal(component, null, this.createInjector(extendedConfig));\n    }\n\n    private createInjector(data: HCC | BCC | FCC): Injector {\n        const injectorTokens: StaticProvider = [{ provide: DIALOG_COMPONENT_CONFIG, useValue: data }];\n        return Injector.create({\n            parent: this.injector,\n            providers: injectorTokens,\n        });\n    }\n}\n","<div\n    class=\"eui-dialog eui-dialog--{{ dialogContainerConfig.typeClass }}\"\n    [class.eui-dialog--draggable]=\"dialogContainerConfig.isDraggable\"\n    [class.eui-dialog--message-box]=\"dialogContainerConfig.isMessageBox\"\n    [class.eui-dialog--no-padding]=\"dialogContainerConfig.hasNoBodyPadding\"\n    [class.eui-dialog--custom-size]=\"dialogContainerConfig.hasMobileCustomSize\"\n    [attr.role]=\"dialogContainerConfig.isMessageBox ? 'alertdialog' : 'dialog'\"\n    aria-labelledby=\"dialogContent\"\n    [attr.aria-describedby]=\"getContentId()\"\n    tabindex=\"-1\"\n    attr.data-e2e=\"{{ dialogContainerConfig.e2eAttr }}\"\n    cdkDrag\n    cdkDragRootElement=\".cdk-overlay-pane\"\n    [cdkDragDisabled]=\"!dialogContainerConfig.isDraggable\"\n    cdkTrapFocus\n    cdkTrapFocusAutoCapture>\n    <div class=\"eui-dialog__content\" role=\"document\" id=\"dialogContent\" aria-labelledby=\"headerTitle\">\n        <div class=\"eui-dialog__header\" [class.eui-dialog__header--handle-disabled]=\"!dialogContainerConfig.isDraggable\" cdkDragHandle>\n            <ng-container *ngIf=\"!isHeaderTemplatePortal && !isHeaderComponentPortal\">\n                <h5 id=\"headerTitle\" class=\"eui-dialog__header-title\">{{ dialogContainerConfig.title | translate }}</h5>\n                <button\n                    *ngIf=\"dialogContainerConfig.hasCloseButton\"\n                    class=\"dialog-close-button\"\n                    (click)=\"closeDialog()\"\n                    euiButton\n                    euiIconButton\n                    euiRounded\n                    euiBasicButton\n                    euiSizeS\n                    aria-label=\"Dialog close icon\">\n                    <eui-icon-svg icon=\"eui-close\"></eui-icon-svg>\n                </button>\n            </ng-container>\n            <ng-container *ngIf=\"isHeaderTemplatePortal\">\n                <ng-template [cdkPortalOutlet]=\"dialogContainerConfig.header\"></ng-template>\n            </ng-container>\n            <ng-container *ngIf=\"isHeaderComponentPortal\">\n                <ng-template [cdkPortalOutlet]=\"headerComponentPortal\" (attached)=\"portalAttached($event, 'headerComponent')\"></ng-template>\n            </ng-container>\n        </div>\n        <div\n            class=\"eui-dialog__body\"\n            cdkScrollable\n            [style.height]=\"dialogContainerConfig.height\"\n            [style.max-height]=\"dialogContainerConfig.height\"\n            (scroll)=\"onScroll()\"\n            tabindex=\"0\">\n            <span *ngIf=\"dialogContainerConfig.isMessageBox\" class=\"eui-dialog__body-content-icon-container\">\n                <div class=\"eui-dialog__body-content-icon\">\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'primary'\">\n                        <eui-icon-svg icon=\"eui-question\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'secondary'\">\n                        <eui-icon-svg icon=\"eui-ecl-warning\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'info'\">\n                        <eui-icon-svg icon=\"eui-info\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'success'\">\n                        <eui-icon-svg icon=\"eui-check\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'warning'\">\n                        <eui-icon-svg icon=\"eui-ecl-warning\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                    <ng-container *ngIf=\"dialogContainerConfig.typeClass === 'danger'\">\n                        <eui-icon-svg icon=\"eui-ecl-error\" fillColor=\"{{ dialogContainerConfig.typeClass }}\"></eui-icon-svg>\n                    </ng-container>\n                </div>\n            </span>\n            <div\n                *ngIf=\"!isBodyTemplatePortal && !isBodyComponentPortal\"\n                id=\"containerConfigId\"\n                class=\"eui-dialog__body-content not-isBodyTemplatePortal\"\n                [innerHTML]=\"dialogContainerConfig.content ? (dialogContainerConfigContent | translate) : null\"></div>\n            <div *ngIf=\"isBodyTemplatePortal && !isBodyComponentPortal\" id=\"bodyTemplatePortalId\" class=\"eui-dialog__body-content isBodyTemplatePortal\">\n                <ng-template [cdkPortalOutlet]=\"getPortalOutlet\"></ng-template>\n            </div>\n            <div *ngIf=\"isBodyComponentPortal\" id=\"bodyComponentPortalId\" class=\"eui-dialog__body-content isBodyComponentPortal\">\n                <ng-template [cdkPortalOutlet]=\"bodyComponentPortal\" (attached)=\"portalAttached($event, 'bodyComponent')\"></ng-template>\n            </div>\n        </div>\n        <div class=\"eui-dialog__footer\" *ngIf=\"dialogContainerConfig.hasFooter\">\n            <ng-container *ngIf=\"!isFooterTemplatePortal && !isFooterComponentPortal\">\n                <ng-container *ngIf=\"isFooterTemplatePortal\">\n                    <ng-template [cdkPortalOutlet]=\"dialogContainerConfig.footer\"></ng-template>\n                </ng-container>\n                <ng-container *ngIf=\"!isFooterTemplatePortal\">\n                    <div class=\"eui-dialog__footer-content\">\n                        <button\n                            euiButton\n                            type=\"button\"\n                            *ngIf=\"dialogContainerConfig.hasDismissButton\"\n                            [euiDisabled]=\"dismissButtonDisabled$ | async\"\n                            class=\"eui-dialog__footer-dismiss-button\"\n                            [class.eui-dialog__footer-dismiss-button--with-accept-button]=\"dialogContainerConfig.hasAcceptButton\"\n                            (click)=\"onDismiss()\">\n                            {{ dialogContainerConfig.dismissLabel | translate }}\n                        </button>\n                        <button\n                            euiButton\n                            euiPrimary\n                            type=\"button\"\n                            *ngIf=\"dialogContainerConfig.hasAcceptButton\"\n                            [euiDisabled]=\"acceptButtonDisabled$ | async\"\n                            class=\"eui-dialog__footer-accept-button\"\n                            (click)=\"onAccept()\">\n                            {{ dialogContainerConfig.acceptLabel | translate }}\n                        </button>\n                    </div>\n                </ng-container>\n            </ng-container>\n\n            <ng-container *ngIf=\"isFooterTemplatePortal\">\n                <ng-template [cdkPortalOutlet]=\"dialogContainerConfig.footer\"></ng-template>\n            </ng-container>\n            <ng-container *ngIf=\"isFooterComponentPortal\">\n                <ng-template [cdkPortalOutlet]=\"footerComponentPortal\" (attached)=\"portalAttached($event, 'footerComponent')\"></ng-template>\n            </ng-container>\n        </div>\n    </div>\n</div>\n"]}
|
@@ -302,7 +302,7 @@ export class EuiDropdownComponent extends BaseDirective {
|
|
302
302
|
!this.activeDescendantKeyManager?.activeItem.elementRef?.nativeElement?.disabled) {
|
303
303
|
this.activeDescendantKeyManager?.activeItem.focus();
|
304
304
|
this.isExpandOnHover
|
305
|
-
? this.activeDescendantKeyManager
|
305
|
+
? this.activeDescendantKeyManager?.activeItem.mouseenter()
|
306
306
|
: this.activeDescendantKeyManager?.activeItem.click();
|
307
307
|
if (this.activeDescendantKeyManager?.activeItem.subDropdown) {
|
308
308
|
this.activeDescendantKeyManager.activeItem.subDropdown.setParentDropdown(this);
|
@@ -480,4 +480,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
480
480
|
type: HostBinding,
|
481
481
|
args: ['class']
|
482
482
|
}] } });
|
483
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-dropdown.component.js","sourceRoot":"","sources":["../../../eui-dropdown/eui-dropdown.component.ts","../../../eui-dropdown/eui-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ChangeDetectionStrategy,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    OnInit,\n    OnDestroy,\n    AfterViewInit,\n    ViewContainerRef,\n    ViewChild,\n    TemplateRef,\n    ContentChildren,\n    QueryList,\n    ElementRef,\n    Renderer2,\n} from '@angular/core';\nimport { BooleanInput } from '@angular/cdk/coercion';\nimport {\n    CdkScrollable,\n    ConnectionPositionPair,\n    FlexibleConnectedPositionStrategy,\n    FlexibleConnectedPositionStrategyOrigin,\n    GlobalPositionStrategy,\n    Overlay,\n    OverlayRef,\n    ScrollDispatcher,\n} from '@angular/cdk/overlay';\nimport { BehaviorSubject, fromEvent, Subject, Subscription, takeUntil } from 'rxjs';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { ActiveDescendantKeyManager, Highlightable } from '@angular/cdk/a11y';\n\nimport { BaseDirective } from '@eui/components/shared';\nimport { coerceBoolean } from '@eui/base';\n\nimport { openClose } from './animations/open-close';\nimport { EuiDropdownItemComponent } from './dropdown-item/eui-dropdown-item.component';\nimport { EuiDropdownService } from './eui-dropdown.service';\n@Component({\n    selector: 'eui-dropdown',\n    templateUrl: './eui-dropdown.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    animations: [openClose],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiDropdownComponent extends BaseDirective implements OnInit, OnDestroy, AfterViewInit {\n    @Input() e2eAttr = 'eui-dropdown';\n    @Input() tabIndex = -1;\n    @Input() width = 'auto';\n    @Input() position: 'top' | 'right' | 'bottom' | 'left' = 'bottom';\n\n    @ViewChild('templatePortalContent') templatePortalContent: TemplateRef<unknown>;\n    @ViewChild('triggerRef') triggerRef: ElementRef<HTMLElement>;\n    @ContentChildren(EuiDropdownItemComponent, { descendants: true }) euiDropdownItems: QueryList<Highlightable & EuiDropdownItemComponent>;\n\n    public trapFocusAutoCapture = true;\n    public parentDropdown: EuiDropdownComponent;\n\n    @Input()\n    @coerceBoolean\n    isBlock:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    isDropDownRightAligned:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    isClosedOnClickInside:BooleanInput = true;\n    @Input()\n    @coerceBoolean\n    isLabelUpdatedFromSelectedItem:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    isExpandOnHover:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    hasTabNavigation:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    isRightClickEnabled:BooleanInput = false;\n\n    private mousePositionX = 0;\n    private mousePositionY = 0;\n    private initialScrollX = 0;\n    private initialScrollY = 0;\n    private originX: 'start' | 'end' | 'center' = 'start';\n    private originY: 'top' | 'bottom' | 'center' = 'bottom';\n    private overlayX: 'start' | 'end' | 'center' = 'start';\n    private overlayY: 'top' | 'bottom' | 'center' = 'top';\n    private templatePortal: TemplatePortal;\n    private overlayRef: OverlayRef;\n    private destroy$ = new Subject<boolean>();\n    private isOpen$ = new BehaviorSubject<boolean>(false);\n    private scrollDispatcherSubscription = new Subscription();\n    private keydownListenerSubscription = new Subscription();\n    private euiDropdownItemsEventSubscriptions: Subscription[] = [];\n    private activeDescendantKeyManagerChangeSubscription = new Subscription();\n    private activeDescendantKeyManager: ActiveDescendantKeyManager<EuiDropdownItemComponent>;\n    private origin: HTMLElement;\n    private positionStrategy: FlexibleConnectedPositionStrategy;\n    private scrollSubscription = new Subscription();\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            this.isBlock ? 'eui-dropdown--block' : '',\n            this.isRightClickEnabled ? 'eui-dropdown--contextual-menu' : '',\n            super.getCssClasses('eui-dropdown'),\n        ].join(' ').trim();\n    }\n\n    constructor(\n        private overlay: Overlay,\n        private viewContainerRef: ViewContainerRef,\n        private scrollDispatcher: ScrollDispatcher,\n        private dropdownService: EuiDropdownService,\n        protected _renderer: Renderer2,\n    ) {\n        super();\n    }\n\n    ngOnInit(): void {\n        // Currently the `cdkTrapFocusAutoCapture` is only checked once on init.\n        if (this.hasDropdownItems) {\n            this.trapFocusAutoCapture = false;\n        } else {\n            this.trapFocusAutoCapture = true;\n        }\n\n        if (this.hasTabNavigation) {\n            this.trapFocusAutoCapture = true;\n            this.isClosedOnClickInside = false;\n        }\n\n        if (this.isRightClickEnabled) {\n            this.hasTabNavigation = false;  // UX wise, contextual menu contains only menu items accessible through arrow keys nav\n        }\n\n        this.setPosition();\n    }\n\n    ngAfterViewInit(): void {\n        this.templatePortal = new TemplatePortal(this.templatePortalContent, this.viewContainerRef);\n\n        if(this.triggerRef && this.triggerRef.nativeElement.firstChild){\n            this._renderer.setAttribute(this.triggerRef.nativeElement.firstChild, 'aria-haspopup', 'true');\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n        this.euiDropdownItemsEventSubscriptions.forEach((euiDropdownItemsEventSubscription) => {\n            euiDropdownItemsEventSubscription.unsubscribe();\n        });\n        this.keydownListenerSubscription.unsubscribe();\n        this.scrollDispatcherSubscription.unsubscribe();\n        this.activeDescendantKeyManagerChangeSubscription.unsubscribe();\n        this.overlayRef?.dispose();\n        this.overlayRef = null;\n        this.activeDescendantKeyManager = null;\n        this.scrollSubscription.unsubscribe();\n    }\n\n    /**\n     * Whether the eui-dropdown is open.\n     *\n     * @usageNotes\n     * ```html\n     * <eui-dropdown #dropdown>\n     *      <my-component *ngIf=\"dropdown.isOpen\"></my-component>\n     * </eui-dropdown>\n     * ```\n     * @returns A boolean with value `true` when open, otherwise `false`.\n     */\n    get isOpen(): boolean {\n        return this.isOpen$.value;\n    }\n\n    public onTriggerClicked(e: Event): void {\n        if (\n            !(e.target as HTMLElement).querySelector('.disabled') &&\n            !(e.target as HTMLElement).querySelector(':disabled') &&\n            !this.isOpen\n        ) {\n            if (this.isBlock) {\n                this.width = this.triggerRef.nativeElement.offsetWidth + 'px';\n            }\n\n            this.openDropdown(e.target as HTMLElement);\n            e.stopPropagation();\n        }\n    }\n\n    public onTriggerRightClicked(e: Event): void {\n        if (\n            !(e.target as HTMLElement).querySelector('.disabled') &&\n            !(e.target as HTMLElement).querySelector(':disabled') &&\n            !this.isOpen\n        ) {\n            if (this.isBlock) {\n                this.width = this.triggerRef.nativeElement.offsetWidth + 'px';\n            }\n\n            this.mousePositionX = (e as PointerEvent).clientX;\n            this.mousePositionY = (e as PointerEvent).clientY;\n            this.initialScrollX = window.pageXOffset;\n            this.initialScrollY = window.pageYOffset;\n\n            this.openDropdown(e.target as HTMLElement);\n            e.preventDefault();\n            e.stopPropagation();\n        }\n    }\n\n    public onClick(): void {\n        if (\n            this.isClosedOnClickInside &&\n            !this.activeDescendantKeyManager?.activeItem.subDropdown &&\n            !this.activeDescendantKeyManager?.activeItem.elementRef?.nativeElement?.disabled\n        ) {\n            this.closeDropdown(true);\n        }\n    }\n\n    /**\n     * Open a dropdown\n     *\n     * @param origin Origin of the dropdown position\n     */\n    public openDropdown(origin: HTMLElement, position?: { x: number, y: number }): void {\n        this.origin = origin;\n\n        if (position) {\n            this.mousePositionX = position.x;\n            this.mousePositionY = position.y;\n            this.initialScrollX = window.pageXOffset;\n            this.initialScrollY = window.pageYOffset;\n        }\n\n        if (this.isRightClickEnabled) {\n            this.scrollSubscription = fromEvent(window, 'scroll').subscribe((event: Event) => {\n                this.overlayRef?.updatePositionStrategy(this.getContextualMenuPositionStrategy());\n            });\n        }\n\n        if (!this.isTriggerFocusableOnClose(origin)) {\n            this.origin = origin.closest('button:not([disabled])') || (this.triggerRef.nativeElement.firstChild as HTMLElement);\n\n            if (!this.origin) {\n                this.origin = origin.closest('a');\n            }\n\n            if (!this.origin) {\n                this.origin = origin;\n            }\n        }\n\n        if (!this.isOpen) {\n            this.scrollDispatcherSubscription = this.scrollDispatcher\n                .ancestorScrolled(this.origin)\n                .pipe(takeUntil(this.destroy$))\n                .subscribe((event: CdkScrollable) => {\n                    if (!this.isVisible(this.origin, event ? event.getElementRef().nativeElement : document.querySelector('body'))) {\n                        this.closeDropdown();\n                    }\n                });\n\n            const positionStrategy = this.isRightClickEnabled ? this.getContextualMenuPositionStrategy() : this.getPositionStrategy();\n            const scrollStrategy = this.overlay.scrollStrategies.reposition({ scrollThrottle: 10 });\n\n            this.overlayRef = this.overlay.create({\n                hasBackdrop: false,\n                backdropClass: 'eui-dropdown__backdrop',\n                panelClass: 'eui-dropdown__panel',\n                positionStrategy,\n                scrollStrategy,\n                disposeOnNavigation: true,\n            });\n            this.overlayRef.attach(this.templatePortal);\n\n            if (this.isRightClickEnabled) {\n                this.overlayRef?.updatePositionStrategy(this.getContextualMenuPositionStrategy());\n            }\n\n            this.overlayRef\n                .outsidePointerEvents()\n                .pipe(takeUntil(this.destroy$))\n                .subscribe(() => {\n                    this.closeDropdown();\n                });\n            this.overlayRef\n                .backdropClick()\n                .pipe(takeUntil(this.destroy$))\n                .subscribe(() => {\n                    this.closeDropdown();\n                });\n            this.overlayRef\n                .keydownEvents()\n                .pipe(takeUntil(this.destroy$))\n                .subscribe((keyboardEvent) => {\n                    if (keyboardEvent.key?.toLowerCase() === 'escape') {\n                        this.closeDropdown();\n                    }\n                });\n\n            if (this.hasDropdownItems) {\n                this.euiDropdownItems.toArray().forEach((euiDropdownItem, i) => {\n                    if (this.isExpandOnHover) {\n                        this.euiDropdownItemsEventSubscriptions[i] = fromEvent(\n                            euiDropdownItem.elementRef.nativeElement,\n                            'mouseenter',\n                        ).subscribe((e: MouseEvent) => {\n                            this.activeDescendantKeyManager.setActiveItem(euiDropdownItem);\n                            if (this.activeDescendantKeyManager.activeItem.subDropdown) {\n                                this.activeDescendantKeyManager.activeItem.subDropdown.setParentDropdown(this);\n                                this.activeDescendantKeyManager.activeItem.subDropdown.overlayRef.detachBackdrop();\n                                this.keydownListenerSubscription.unsubscribe();\n                            }\n\n                            const triggerOutsidePointerEvents = (subDropdown: EuiDropdownComponent): void => {\n                                subDropdown?.overlayRef?._outsidePointerEvents.next(e);\n\n                                if (subDropdown?.hasDropdownItems) {\n                                    subDropdown.euiDropdownItems.toArray().forEach((s) => {\n                                        triggerOutsidePointerEvents(s.subDropdown);\n                                    });\n                                }\n                            };\n\n                            this.euiDropdownItems\n                                .filter((item) => !item.isActive)\n                                .forEach((euiDropdownItemHavingSubDropdown) => {\n                                    triggerOutsidePointerEvents(euiDropdownItemHavingSubDropdown.subDropdown);\n                                });\n                        });\n                    } else {\n                        this.euiDropdownItemsEventSubscriptions[i] = fromEvent(euiDropdownItem.elementRef.nativeElement, 'click').subscribe(\n                            () => {\n                                this.activeDescendantKeyManager.setActiveItem(euiDropdownItem);\n                                if (this.activeDescendantKeyManager.activeItem.subDropdown) {\n                                    this.activeDescendantKeyManager.activeItem.subDropdown.setParentDropdown(this);\n                                    this.activeDescendantKeyManager.activeItem.subDropdown.overlayRef.detachBackdrop();\n                                    this.keydownListenerSubscription.unsubscribe();\n                                }\n\n                                const labelElement = this.triggerRef.nativeElement.querySelector('button .eui-label');\n                                if (this.isLabelUpdatedFromSelectedItem && labelElement) {\n                                    (labelElement as HTMLElement).innerText = euiDropdownItem.elementRef.nativeElement.innerText;\n                                }\n                            },\n                        );\n                    }\n                });\n\n                this.activeDescendantKeyManager = new ActiveDescendantKeyManager(this.euiDropdownItems)\n                    .withHomeAndEnd(true)\n                    .withVerticalOrientation(true)\n                    .withWrap();\n                this.activeDescendantKeyManager.setFirstItemActive();\n            }\n\n            this.createKeyboardHandlerSubscription();\n            this.isOpen$.next(true);\n            this.dropdownService.isDropdownOpen.emit(true);\n        }\n    }\n\n    /**\n     * Close a dropdown\n     */\n    public closeDropdown(recursively = false): void {\n        this.isOpen$.next(false);\n        this.euiDropdownItemsEventSubscriptions.forEach((euiDropdownItemsEventSubscription) => {\n            euiDropdownItemsEventSubscription.unsubscribe();\n        });\n        this.keydownListenerSubscription.unsubscribe();\n        if (this.hasDropdownItems) {\n            this.activeDescendantKeyManager?.setFirstItemActive();\n        }\n        this.scrollDispatcherSubscription.unsubscribe();\n        this.activeDescendantKeyManagerChangeSubscription.unsubscribe();\n        this.scrollSubscription.unsubscribe();\n        this.overlayRef?.dispose();\n        this.overlayRef = null;\n        this.activeDescendantKeyManager = null;\n        if (this.trapFocusAutoCapture) {\n            this.origin.focus();\n        }\n        if (recursively && this.parentDropdown) {\n            this.parentDropdown.closeDropdown(true);\n        }\n\n        this.dropdownService.isDropdownOpen.emit(false);\n    }\n\n    public projectContentChanged(): void {\n        if (!this.isRightClickEnabled) {\n            this.positionStrategy = this.getPositionStrategy();\n            this.overlayRef.updatePositionStrategy(this.positionStrategy);\n        }\n    }\n\n    public createKeyboardHandlerSubscription(): void {\n        this.keydownListenerSubscription = fromEvent(document, 'keydown').subscribe((event: KeyboardEvent) => {\n            if (this.isOpen) {\n                if (\n                    event.code === 'Enter' &&\n                    !this.hasTabNavigation &&\n                    !this.activeDescendantKeyManager?.activeItem.elementRef?.nativeElement?.disabled\n                ) {\n                    this.activeDescendantKeyManager?.activeItem.focus();\n                    this.isExpandOnHover\n                        ? this.activeDescendantKeyManager.activeItem.mouseenter()\n                        : this.activeDescendantKeyManager?.activeItem.click();\n\n                    if (this.activeDescendantKeyManager?.activeItem.subDropdown) {\n                        this.activeDescendantKeyManager.activeItem.subDropdown.setParentDropdown(this);\n                        this.keydownListenerSubscription.unsubscribe();\n                    } else {\n                        this.closeDropdown();\n                    }\n                    event.preventDefault();\n                } else if (event.code === 'ArrowLeft') {\n                    if (this.parentDropdown) {\n                        this.parentDropdown.createKeyboardHandlerSubscription();\n                        this.closeDropdown();\n                    }\n                    event.preventDefault();\n                } else if (event.code === 'ArrowRight') {\n                    if (this.activeDescendantKeyManager?.activeItem.subDropdown) {\n                        this.activeDescendantKeyManager.activeItem.focus();\n                        this.isExpandOnHover\n                            ? this.activeDescendantKeyManager.activeItem.mouseenter()\n                            : this.activeDescendantKeyManager.activeItem.click();\n                        this.activeDescendantKeyManager.activeItem.subDropdown.setParentDropdown(this);\n                        this.keydownListenerSubscription.unsubscribe();\n                    }\n                    event.preventDefault();\n                } else if (event.code === 'Tab' && !this.hasTabNavigation) {\n                    this.closeDropdown(true);\n                } else {\n                    this.activeDescendantKeyManager?.onKeydown(event);\n                }\n            }\n        });\n    }\n\n    public setParentDropdown(parentDropdown: EuiDropdownComponent): void {\n        this.parentDropdown = parentDropdown;\n        this.position = 'right';\n        this.setPosition();\n\n        const positionStrategy = this.getPositionStrategy();\n        this.overlayRef.updatePositionStrategy(positionStrategy);\n    }\n\n    private get hasDropdownItems(): boolean {\n        return this.euiDropdownItems?.length > 0;\n    }\n\n    private getPositionStrategy(): FlexibleConnectedPositionStrategy {\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.origin as FlexibleConnectedPositionStrategyOrigin)\n            .withPositions([\n                new ConnectionPositionPair(\n                    { originX: this.originX, originY: this.originY },\n                    { overlayX: this.overlayX, overlayY: this.overlayY },\n                ),\n            ])\n            .withFlexibleDimensions(false)\n            .withLockedPosition(true);\n    }\n\n    private getContextualMenuPositionStrategy(): GlobalPositionStrategy {\n        const panelHeight = this.overlayRef?.overlayElement.clientHeight || 0;\n        const scrollX = window.scrollX || window.pageXOffset;\n        const scrollY = window.scrollY || window.pageYOffset;\n        const newX = this.mousePositionX + (this.initialScrollX - scrollX);\n        const newY = this.mousePositionY + (this.initialScrollY - scrollY);\n        const menuBottomPosition = newY + panelHeight;\n        const isMenuBelowWindowBottom = menuBottomPosition > window.innerHeight;\n\n        const positionStrategy = this.overlay\n            .position()\n            .global()\n            .left(newX + 'px');\n\n        if (isMenuBelowWindowBottom) {\n            positionStrategy.bottom(window.innerHeight - newY + 'px');\n        } else {\n            positionStrategy.top(newY + 'px');\n        }\n\n        return positionStrategy;\n    }\n\n    private isVisible(origin: HTMLElement, scrollableParent: HTMLElement): boolean {\n        const originY = origin.getBoundingClientRect().y;\n        const scrollableParentY = Math.abs(scrollableParent.getBoundingClientRect().y);\n        const scrollableParentHeight = scrollableParent.getBoundingClientRect().height - 50;\n\n        return (\n            (originY > 0 && originY < scrollableParentHeight) ||\n            (originY - scrollableParentY > 0 && originY < scrollableParentY + scrollableParentHeight)\n        );\n    }\n\n    private isTriggerFocusableOnClose(origin: HTMLElement): boolean {\n        return origin.matches('button:not([disabled])') || origin.matches('a');\n    }\n\n    private setPosition(): void {\n        if (this.position === 'top') {\n            this.originY = 'top';\n            this.overlayY = 'bottom';\n\n            if (this.isDropDownRightAligned) {\n                this.originX = 'end';\n                this.overlayX = 'end';\n            }\n        }\n        if (this.position === 'right') {\n            this.originX = 'end';\n            this.overlayX = 'start';\n            this.overlayY = 'center';\n        }\n        if (this.position === 'bottom') {\n            this.originY = 'bottom';\n            this.overlayY = 'top';\n\n            if (this.isDropDownRightAligned) {\n                this.originX = 'end';\n                this.overlayX = 'end';\n            }\n        }\n        if (this.position === 'left') {\n            this.originX = 'start';\n            this.overlayX = 'end';\n            this.overlayY = 'center';\n        }\n    }\n}\n","<div #triggerRef class=\"eui-dropdown__trigger-container\"\n    (click)=\"!isRightClickEnabled ? onTriggerClicked($event) : null\"\n    (contextmenu)=\"isRightClickEnabled ? onTriggerRightClicked($event) : null\">\n    <ng-content></ng-content>\n</div>\n\n<ng-template #templatePortalContent>\n    <div\n        attr.data-e2e=\"{{ e2eAttr }}\"\n        [@openClose]=\"isOpen ? 'open' : 'closed'\"\n        cdkTrapFocus\n        [cdkTrapFocusAutoCapture]=\"trapFocusAutoCapture\"\n        role=\"dialog\"\n        aria-label=\"eUI dropdown panel\"\n        class=\"eui-dropdown__panel-container\"\n        [style.width]=\"width\"\n        [tabindex]=\"tabIndex\"\n        (click)=\"onClick()\"\n        (cdkObserveContent)=\"projectContentChanged()\">\n        <ng-content select=\"eui-dropdown-content\"></ng-content>\n    </div>\n</ng-template>\n"]}
|
483
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-dropdown.component.js","sourceRoot":"","sources":["../../../eui-dropdown/eui-dropdown.component.ts","../../../eui-dropdown/eui-dropdown.component.html"],"names":[],"mappings":";AAAA,OAAO,EACH,SAAS,EACT,uBAAuB,EACvB,WAAW,EACX,iBAAiB,EACjB,KAAK,EAKL,SAAS,EAET,eAAe,GAIlB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAEH,sBAAsB,GAOzB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,eAAe,EAAE,SAAS,EAAE,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,0BAA0B,EAAiB,MAAM,mBAAmB,CAAC;AAE9E,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAE1C,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,wBAAwB,EAAE,MAAM,6CAA6C,CAAC;;;;;;AAUvF,MAAM,OAAO,oBAAqB,SAAQ,aAAa;IAwDnD,IACI,UAAU;QACV,OAAO;YACH,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE;YACzC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,+BAA+B,CAAC,CAAC,CAAC,EAAE;YAC/D,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC;SACtC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;IAED,YACY,OAAgB,EAChB,gBAAkC,EAClC,gBAAkC,EAClC,eAAmC,EACjC,SAAoB;QAE9B,KAAK,EAAE,CAAC;QANA,YAAO,GAAP,OAAO,CAAS;QAChB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,oBAAe,GAAf,eAAe,CAAoB;QACjC,cAAS,GAAT,SAAS,CAAW;QArEzB,YAAO,GAAG,cAAc,CAAC;QACzB,aAAQ,GAAG,CAAC,CAAC,CAAC;QACd,UAAK,GAAG,MAAM,CAAC;QACf,aAAQ,GAAwC,QAAQ,CAAC;QAM3D,yBAAoB,GAAG,IAAI,CAAC;QAKnC,YAAO,GAAgB,KAAK,CAAC;QAG7B,2BAAsB,GAAgB,KAAK,CAAC;QAG5C,0BAAqB,GAAgB,IAAI,CAAC;QAG1C,mCAA8B,GAAgB,KAAK,CAAC;QAGpD,oBAAe,GAAgB,KAAK,CAAC;QAGrC,qBAAgB,GAAgB,KAAK,CAAC;QAGtC,wBAAmB,GAAgB,KAAK,CAAC;QAEjC,mBAAc,GAAG,CAAC,CAAC;QACnB,mBAAc,GAAG,CAAC,CAAC;QACnB,mBAAc,GAAG,CAAC,CAAC;QACnB,mBAAc,GAAG,CAAC,CAAC;QACnB,YAAO,GAA+B,OAAO,CAAC;QAC9C,YAAO,GAAgC,QAAQ,CAAC;QAChD,aAAQ,GAA+B,OAAO,CAAC;QAC/C,aAAQ,GAAgC,KAAK,CAAC;QAG9C,aAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;QAClC,YAAO,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAC9C,iCAA4B,GAAG,IAAI,YAAY,EAAE,CAAC;QAClD,gCAA2B,GAAG,IAAI,YAAY,EAAE,CAAC;QACjD,uCAAkC,GAAmB,EAAE,CAAC;QACxD,iDAA4C,GAAG,IAAI,YAAY,EAAE,CAAC;QAIlE,uBAAkB,GAAG,IAAI,YAAY,EAAE,CAAC;IAmBhD,CAAC;IAED,QAAQ;QACJ,wEAAwE;QACxE,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;SACrC;aAAM;YACH,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;SACpC;QAED,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;YACjC,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;SACtC;QAED,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC1B,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,CAAE,sFAAsF;SACzH;QAED,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAED,eAAe;QACX,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,qBAAqB,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAE5F,IAAG,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,EAAC;YAC3D,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,EAAE,eAAe,EAAE,MAAM,CAAC,CAAC;SAClG;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;QAC5B,IAAI,CAAC,kCAAkC,CAAC,OAAO,CAAC,CAAC,iCAAiC,EAAE,EAAE;YAClF,iCAAiC,CAAC,WAAW,EAAE,CAAC;QACpD,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,2BAA2B,CAAC,WAAW,EAAE,CAAC;QAC/C,IAAI,CAAC,4BAA4B,CAAC,WAAW,EAAE,CAAC;QAChD,IAAI,CAAC,4CAA4C,CAAC,WAAW,EAAE,CAAC;QAChE,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC;QACvC,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,CAAC;IAC1C,CAAC;IAED;;;;;;;;;;OAUG;IACH,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IAC9B,CAAC;IAEM,gBAAgB,CAAC,CAAQ;QAC5B,IACI,CAAE,CAAC,CAAC,MAAsB,CAAC,aAAa,CAAC,WAAW,CAAC;YACrD,CAAE,CAAC,CAAC,MAAsB,CAAC,aAAa,CAAC,WAAW,CAAC;YACrD,CAAC,IAAI,CAAC,MAAM,EACd;YACE,IAAI,IAAI,CAAC,OAAO,EAAE;gBACd,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC;aACjE;YAED,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,MAAqB,CAAC,CAAC;YAC3C,CAAC,CAAC,eAAe,EAAE,CAAC;SACvB;IACL,CAAC;IAEM,qBAAqB,CAAC,CAAQ;QACjC,IACI,CAAE,CAAC,CAAC,MAAsB,CAAC,aAAa,CAAC,WAAW,CAAC;YACrD,CAAE,CAAC,CAAC,MAAsB,CAAC,aAAa,CAAC,WAAW,CAAC;YACrD,CAAC,IAAI,CAAC,MAAM,EACd;YACE,IAAI,IAAI,CAAC,OAAO,EAAE;gBACd,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC;aACjE;YAED,IAAI,CAAC,cAAc,GAAI,CAAkB,CAAC,OAAO,CAAC;YAClD,IAAI,CAAC,cAAc,GAAI,CAAkB,CAAC,OAAO,CAAC;YAClD,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,WAAW,CAAC;YACzC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,WAAW,CAAC;YAEzC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,MAAqB,CAAC,CAAC;YAC3C,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,CAAC,CAAC,eAAe,EAAE,CAAC;SACvB;IACL,CAAC;IAEM,OAAO;QACV,IACI,IAAI,CAAC,qBAAqB;YAC1B,CAAC,IAAI,CAAC,0BAA0B,EAAE,UAAU,CAAC,WAAW;YACxD,CAAC,IAAI,CAAC,0BAA0B,EAAE,UAAU,CAAC,UAAU,EAAE,aAAa,EAAE,QAAQ,EAClF;YACE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SAC5B;IACL,CAAC;IAED;;;;OAIG;IACI,YAAY,CAAC,MAAmB,EAAE,QAAmC;QACxE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QAErB,IAAI,QAAQ,EAAE;YACV,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC;YACjC,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC;YACjC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,WAAW,CAAC;YACzC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,WAAW,CAAC;SAC5C;QAED,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC1B,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,KAAY,EAAE,EAAE;gBAC7E,IAAI,CAAC,UAAU,EAAE,sBAAsB,CAAC,IAAI,CAAC,iCAAiC,EAAE,CAAC,CAAC;YACtF,CAAC,CAAC,CAAC;SACN;QAED,IAAI,CAAC,IAAI,CAAC,yBAAyB,CAAC,MAAM,CAAC,EAAE;YACzC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,wBAAwB,CAAC,IAAK,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAA0B,CAAC;YAEpH,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;gBACd,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;aACrC;YAED,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;gBACd,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;aACxB;SACJ;QAED,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACd,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC,gBAAgB;iBACpD,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC;iBAC7B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;iBAC9B,SAAS,CAAC,CAAC,KAAoB,EAAE,EAAE;gBAChC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,EAAE;oBAC5G,IAAI,CAAC,aAAa,EAAE,CAAC;iBACxB;YACL,CAAC,CAAC,CAAC;YAEP,MAAM,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,iCAAiC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC1H,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,CAAC,EAAE,cAAc,EAAE,EAAE,EAAE,CAAC,CAAC;YAExF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;gBAClC,WAAW,EAAE,KAAK;gBAClB,aAAa,EAAE,wBAAwB;gBACvC,UAAU,EAAE,qBAAqB;gBACjC,gBAAgB;gBAChB,cAAc;gBACd,mBAAmB,EAAE,IAAI;aAC5B,CAAC,CAAC;YACH,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAE5C,IAAI,IAAI,CAAC,mBAAmB,EAAE;gBAC1B,IAAI,CAAC,UAAU,EAAE,sBAAsB,CAAC,IAAI,CAAC,iCAAiC,EAAE,CAAC,CAAC;aACrF;YAED,IAAI,CAAC,UAAU;iBACV,oBAAoB,EAAE;iBACtB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;iBAC9B,SAAS,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,aAAa,EAAE,CAAC;YACzB,CAAC,CAAC,CAAC;YACP,IAAI,CAAC,UAAU;iBACV,aAAa,EAAE;iBACf,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;iBAC9B,SAAS,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,aAAa,EAAE,CAAC;YACzB,CAAC,CAAC,CAAC;YACP,IAAI,CAAC,UAAU;iBACV,aAAa,EAAE;iBACf,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;iBAC9B,SAAS,CAAC,CAAC,aAAa,EAAE,EAAE;gBACzB,IAAI,aAAa,CAAC,GAAG,EAAE,WAAW,EAAE,KAAK,QAAQ,EAAE;oBAC/C,IAAI,CAAC,aAAa,EAAE,CAAC;iBACxB;YACL,CAAC,CAAC,CAAC;YAEP,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBACvB,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC,eAAe,EAAE,CAAC,EAAE,EAAE;oBAC3D,IAAI,IAAI,CAAC,eAAe,EAAE;wBACtB,IAAI,CAAC,kCAAkC,CAAC,CAAC,CAAC,GAAG,SAAS,CAClD,eAAe,CAAC,UAAU,CAAC,aAAa,EACxC,YAAY,CACf,CAAC,SAAS,CAAC,CAAC,CAAa,EAAE,EAAE;4BAC1B,IAAI,CAAC,0BAA0B,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;4BAC/D,IAAI,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,WAAW,EAAE;gCACxD,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gCAC/E,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;gCACnF,IAAI,CAAC,2BAA2B,CAAC,WAAW,EAAE,CAAC;6BAClD;4BAED,MAAM,2BAA2B,GAAG,CAAC,WAAiC,EAAQ,EAAE;gCAC5E,WAAW,EAAE,UAAU,EAAE,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gCAEvD,IAAI,WAAW,EAAE,gBAAgB,EAAE;oCAC/B,WAAW,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;wCACjD,2BAA2B,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;oCAC/C,CAAC,CAAC,CAAC;iCACN;4BACL,CAAC,CAAC;4BAEF,IAAI,CAAC,gBAAgB;iCAChB,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;iCAChC,OAAO,CAAC,CAAC,gCAAgC,EAAE,EAAE;gCAC1C,2BAA2B,CAAC,gCAAgC,CAAC,WAAW,CAAC,CAAC;4BAC9E,CAAC,CAAC,CAAC;wBACX,CAAC,CAAC,CAAC;qBACN;yBAAM;wBACH,IAAI,CAAC,kCAAkC,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,SAAS,CAC/G,GAAG,EAAE;4BACD,IAAI,CAAC,0BAA0B,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;4BAC/D,IAAI,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,WAAW,EAAE;gCACxD,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gCAC/E,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;gCACnF,IAAI,CAAC,2BAA2B,CAAC,WAAW,EAAE,CAAC;6BAClD;4BAED,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;4BACtF,IAAI,IAAI,CAAC,8BAA8B,IAAI,YAAY,EAAE;gCACpD,YAA4B,CAAC,SAAS,GAAG,eAAe,CAAC,UAAU,CAAC,aAAa,CAAC,SAAS,CAAC;6BAChG;wBACL,CAAC,CACJ,CAAC;qBACL;gBACL,CAAC,CAAC,CAAC;gBAEH,IAAI,CAAC,0BAA0B,GAAG,IAAI,0BAA0B,CAAC,IAAI,CAAC,gBAAgB,CAAC;qBAClF,cAAc,CAAC,IAAI,CAAC;qBACpB,uBAAuB,CAAC,IAAI,CAAC;qBAC7B,QAAQ,EAAE,CAAC;gBAChB,IAAI,CAAC,0BAA0B,CAAC,kBAAkB,EAAE,CAAC;aACxD;YAED,IAAI,CAAC,iCAAiC,EAAE,CAAC;YACzC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxB,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAClD;IACL,CAAC;IAED;;OAEG;IACI,aAAa,CAAC,WAAW,GAAG,KAAK;QACpC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzB,IAAI,CAAC,kCAAkC,CAAC,OAAO,CAAC,CAAC,iCAAiC,EAAE,EAAE;YAClF,iCAAiC,CAAC,WAAW,EAAE,CAAC;QACpD,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,2BAA2B,CAAC,WAAW,EAAE,CAAC;QAC/C,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,0BAA0B,EAAE,kBAAkB,EAAE,CAAC;SACzD;QACD,IAAI,CAAC,4BAA4B,CAAC,WAAW,EAAE,CAAC;QAChD,IAAI,CAAC,4CAA4C,CAAC,WAAW,EAAE,CAAC;QAChE,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,CAAC;QACtC,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC;QACvC,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC3B,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;SACvB;QACD,IAAI,WAAW,IAAI,IAAI,CAAC,cAAc,EAAE;YACpC,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SAC3C;QAED,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpD,CAAC;IAEM,qBAAqB;QACxB,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE;YAC3B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACnD,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SACjE;IACL,CAAC;IAEM,iCAAiC;QACpC,IAAI,CAAC,2BAA2B,GAAG,SAAS,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,SAAS,CAAC,CAAC,KAAoB,EAAE,EAAE;YACjG,IAAI,IAAI,CAAC,MAAM,EAAE;gBACb,IACI,KAAK,CAAC,IAAI,KAAK,OAAO;oBACtB,CAAC,IAAI,CAAC,gBAAgB;oBACtB,CAAC,IAAI,CAAC,0BAA0B,EAAE,UAAU,CAAC,UAAU,EAAE,aAAa,EAAE,QAAQ,EAClF;oBACE,IAAI,CAAC,0BAA0B,EAAE,UAAU,CAAC,KAAK,EAAE,CAAC;oBACpD,IAAI,CAAC,eAAe;wBAChB,CAAC,CAAC,IAAI,CAAC,0BAA0B,EAAE,UAAU,CAAC,UAAU,EAAE;wBAC1D,CAAC,CAAC,IAAI,CAAC,0BAA0B,EAAE,UAAU,CAAC,KAAK,EAAE,CAAC;oBAE1D,IAAI,IAAI,CAAC,0BAA0B,EAAE,UAAU,CAAC,WAAW,EAAE;wBACzD,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;wBAC/E,IAAI,CAAC,2BAA2B,CAAC,WAAW,EAAE,CAAC;qBAClD;yBAAM;wBACH,IAAI,CAAC,aAAa,EAAE,CAAC;qBACxB;oBACD,KAAK,CAAC,cAAc,EAAE,CAAC;iBAC1B;qBAAM,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,EAAE;oBACnC,IAAI,IAAI,CAAC,cAAc,EAAE;wBACrB,IAAI,CAAC,cAAc,CAAC,iCAAiC,EAAE,CAAC;wBACxD,IAAI,CAAC,aAAa,EAAE,CAAC;qBACxB;oBACD,KAAK,CAAC,cAAc,EAAE,CAAC;iBAC1B;qBAAM,IAAI,KAAK,CAAC,IAAI,KAAK,YAAY,EAAE;oBACpC,IAAI,IAAI,CAAC,0BAA0B,EAAE,UAAU,CAAC,WAAW,EAAE;wBACzD,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;wBACnD,IAAI,CAAC,eAAe;4BAChB,CAAC,CAAC,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,UAAU,EAAE;4BACzD,CAAC,CAAC,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;wBACzD,IAAI,CAAC,0BAA0B,CAAC,UAAU,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;wBAC/E,IAAI,CAAC,2BAA2B,CAAC,WAAW,EAAE,CAAC;qBAClD;oBACD,KAAK,CAAC,cAAc,EAAE,CAAC;iBAC1B;qBAAM,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;oBACvD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;iBAC5B;qBAAM;oBACH,IAAI,CAAC,0BAA0B,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;iBACrD;aACJ;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,iBAAiB,CAAC,cAAoC;QACzD,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,MAAM,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACpD,IAAI,CAAC,UAAU,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,CAAC;IAC7D,CAAC;IAED,IAAY,gBAAgB;QACxB,OAAO,IAAI,CAAC,gBAAgB,EAAE,MAAM,GAAG,CAAC,CAAC;IAC7C,CAAC;IAEO,mBAAmB;QACvB,OAAO,IAAI,CAAC,OAAO;aACd,QAAQ,EAAE;aACV,mBAAmB,CAAC,IAAI,CAAC,MAAiD,CAAC;aAC3E,aAAa,CAAC;YACX,IAAI,sBAAsB,CACtB,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,EAChD,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CACvD;SACJ,CAAC;aACD,sBAAsB,CAAC,KAAK,CAAC;aAC7B,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IAEO,iCAAiC;QACrC,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,cAAc,CAAC,YAAY,IAAI,CAAC,CAAC;QACtE,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,WAAW,CAAC;QACrD,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,WAAW,CAAC;QACrD,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,CAAC;QACnE,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,CAAC;QACnE,MAAM,kBAAkB,GAAG,IAAI,GAAG,WAAW,CAAC;QAC9C,MAAM,uBAAuB,GAAG,kBAAkB,GAAG,MAAM,CAAC,WAAW,CAAC;QAExE,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO;aAChC,QAAQ,EAAE;aACV,MAAM,EAAE;aACR,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QAEvB,IAAI,uBAAuB,EAAE;YACzB,gBAAgB,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,GAAG,IAAI,GAAG,IAAI,CAAC,CAAC;SAC7D;aAAM;YACH,gBAAgB,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;SACrC;QAED,OAAO,gBAAgB,CAAC;IAC5B,CAAC;IAEO,SAAS,CAAC,MAAmB,EAAE,gBAA6B;QAChE,MAAM,OAAO,GAAG,MAAM,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC;QACjD,MAAM,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC,CAAC;QAC/E,MAAM,sBAAsB,GAAG,gBAAgB,CAAC,qBAAqB,EAAE,CAAC,MAAM,GAAG,EAAE,CAAC;QAEpF,OAAO,CACH,CAAC,OAAO,GAAG,CAAC,IAAI,OAAO,GAAG,sBAAsB,CAAC;YACjD,CAAC,OAAO,GAAG,iBAAiB,GAAG,CAAC,IAAI,OAAO,GAAG,iBAAiB,GAAG,sBAAsB,CAAC,CAC5F,CAAC;IACN,CAAC;IAEO,yBAAyB,CAAC,MAAmB;QACjD,OAAO,MAAM,CAAC,OAAO,CAAC,wBAAwB,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC3E,CAAC;IAEO,WAAW;QACf,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;YACzB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YAEzB,IAAI,IAAI,CAAC,sBAAsB,EAAE;gBAC7B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;aACzB;SACJ;QACD,IAAI,IAAI,CAAC,QAAQ,KAAK,OAAO,EAAE;YAC3B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;YACxB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;SAC5B;QACD,IAAI,IAAI,CAAC,QAAQ,KAAK,QAAQ,EAAE;YAC5B,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;YACxB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YAEtB,IAAI,IAAI,CAAC,sBAAsB,EAAE;gBAC7B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;aACzB;SACJ;QACD,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE;YAC1B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;SAC5B;IACL,CAAC;iIAhfQ,oBAAoB;qHAApB,oBAAoB,qhBAQZ,wBAAwB,kSCtD7C,i1BAsBA,yuIDoBgB,CAAC,SAAS,CAAC;;AAmBvB;IADC,aAAa;qDACe;AAG7B;IADC,aAAa;oEAC8B;AAG5C;IADC,aAAa;mEAC4B;AAG1C;IADC,aAAa;4EACsC;AAGpD;IADC,aAAa;6DACuB;AAGrC;IADC,aAAa;8DACwB;AAGtC;IADC,aAAa;iEAC2B;2FAjChC,oBAAoB;kBARhC,SAAS;+BACI,cAAc,cAGZ,CAAC,SAAS,CAAC,mBACN,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI;mMAG5B,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAE8B,qBAAqB;sBAAxD,SAAS;uBAAC,uBAAuB;gBACT,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBAC2C,gBAAgB;sBAAjF,eAAe;uBAAC,wBAAwB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAOhE,OAAO;sBAFN,KAAK;gBAKN,sBAAsB;sBAFrB,KAAK;gBAKN,qBAAqB;sBAFpB,KAAK;gBAKN,8BAA8B;sBAF7B,KAAK;gBAKN,eAAe;sBAFd,KAAK;gBAKN,gBAAgB;sBAFf,KAAK;gBAKN,mBAAmB;sBAFlB,KAAK;gBA0BF,UAAU;sBADb,WAAW;uBAAC,OAAO","sourcesContent":["import {\n    Component,\n    ChangeDetectionStrategy,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    OnInit,\n    OnDestroy,\n    AfterViewInit,\n    ViewContainerRef,\n    ViewChild,\n    TemplateRef,\n    ContentChildren,\n    QueryList,\n    ElementRef,\n    Renderer2,\n} from '@angular/core';\nimport { BooleanInput } from '@angular/cdk/coercion';\nimport {\n    CdkScrollable,\n    ConnectionPositionPair,\n    FlexibleConnectedPositionStrategy,\n    FlexibleConnectedPositionStrategyOrigin,\n    GlobalPositionStrategy,\n    Overlay,\n    OverlayRef,\n    ScrollDispatcher,\n} from '@angular/cdk/overlay';\nimport { BehaviorSubject, fromEvent, Subject, Subscription, takeUntil } from 'rxjs';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { ActiveDescendantKeyManager, Highlightable } from '@angular/cdk/a11y';\n\nimport { BaseDirective } from '@eui/components/shared';\nimport { coerceBoolean } from '@eui/base';\n\nimport { openClose } from './animations/open-close';\nimport { EuiDropdownItemComponent } from './dropdown-item/eui-dropdown-item.component';\nimport { EuiDropdownService } from './eui-dropdown.service';\n@Component({\n    selector: 'eui-dropdown',\n    templateUrl: './eui-dropdown.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    animations: [openClose],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiDropdownComponent extends BaseDirective implements OnInit, OnDestroy, AfterViewInit {\n    @Input() e2eAttr = 'eui-dropdown';\n    @Input() tabIndex = -1;\n    @Input() width = 'auto';\n    @Input() position: 'top' | 'right' | 'bottom' | 'left' = 'bottom';\n\n    @ViewChild('templatePortalContent') templatePortalContent: TemplateRef<unknown>;\n    @ViewChild('triggerRef') triggerRef: ElementRef<HTMLElement>;\n    @ContentChildren(EuiDropdownItemComponent, { descendants: true }) euiDropdownItems: QueryList<Highlightable & EuiDropdownItemComponent>;\n\n    public trapFocusAutoCapture = true;\n    public parentDropdown: EuiDropdownComponent;\n\n    @Input()\n    @coerceBoolean\n    isBlock:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    isDropDownRightAligned:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    isClosedOnClickInside:BooleanInput = true;\n    @Input()\n    @coerceBoolean\n    isLabelUpdatedFromSelectedItem:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    isExpandOnHover:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    hasTabNavigation:BooleanInput = false;\n    @Input()\n    @coerceBoolean\n    isRightClickEnabled:BooleanInput = false;\n\n    private mousePositionX = 0;\n    private mousePositionY = 0;\n    private initialScrollX = 0;\n    private initialScrollY = 0;\n    private originX: 'start' | 'end' | 'center' = 'start';\n    private originY: 'top' | 'bottom' | 'center' = 'bottom';\n    private overlayX: 'start' | 'end' | 'center' = 'start';\n    private overlayY: 'top' | 'bottom' | 'center' = 'top';\n    private templatePortal: TemplatePortal;\n    private overlayRef: OverlayRef;\n    private destroy$ = new Subject<boolean>();\n    private isOpen$ = new BehaviorSubject<boolean>(false);\n    private scrollDispatcherSubscription = new Subscription();\n    private keydownListenerSubscription = new Subscription();\n    private euiDropdownItemsEventSubscriptions: Subscription[] = [];\n    private activeDescendantKeyManagerChangeSubscription = new Subscription();\n    private activeDescendantKeyManager: ActiveDescendantKeyManager<EuiDropdownItemComponent>;\n    private origin: HTMLElement;\n    private positionStrategy: FlexibleConnectedPositionStrategy;\n    private scrollSubscription = new Subscription();\n\n    @HostBinding('class')\n    get cssClasses(): string {\n        return [\n            this.isBlock ? 'eui-dropdown--block' : '',\n            this.isRightClickEnabled ? 'eui-dropdown--contextual-menu' : '',\n            super.getCssClasses('eui-dropdown'),\n        ].join(' ').trim();\n    }\n\n    constructor(\n        private overlay: Overlay,\n        private viewContainerRef: ViewContainerRef,\n        private scrollDispatcher: ScrollDispatcher,\n        private dropdownService: EuiDropdownService,\n        protected _renderer: Renderer2,\n    ) {\n        super();\n    }\n\n    ngOnInit(): void {\n        // Currently the `cdkTrapFocusAutoCapture` is only checked once on init.\n        if (this.hasDropdownItems) {\n            this.trapFocusAutoCapture = false;\n        } else {\n            this.trapFocusAutoCapture = true;\n        }\n\n        if (this.hasTabNavigation) {\n            this.trapFocusAutoCapture = true;\n            this.isClosedOnClickInside = false;\n        }\n\n        if (this.isRightClickEnabled) {\n            this.hasTabNavigation = false;  // UX wise, contextual menu contains only menu items accessible through arrow keys nav\n        }\n\n        this.setPosition();\n    }\n\n    ngAfterViewInit(): void {\n        this.templatePortal = new TemplatePortal(this.templatePortalContent, this.viewContainerRef);\n\n        if(this.triggerRef && this.triggerRef.nativeElement.firstChild){\n            this._renderer.setAttribute(this.triggerRef.nativeElement.firstChild, 'aria-haspopup', 'true');\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n        this.euiDropdownItemsEventSubscriptions.forEach((euiDropdownItemsEventSubscription) => {\n            euiDropdownItemsEventSubscription.unsubscribe();\n        });\n        this.keydownListenerSubscription.unsubscribe();\n        this.scrollDispatcherSubscription.unsubscribe();\n        this.activeDescendantKeyManagerChangeSubscription.unsubscribe();\n        this.overlayRef?.dispose();\n        this.overlayRef = null;\n        this.activeDescendantKeyManager = null;\n        this.scrollSubscription.unsubscribe();\n    }\n\n    /**\n     * Whether the eui-dropdown is open.\n     *\n     * @usageNotes\n     * ```html\n     * <eui-dropdown #dropdown>\n     *      <my-component *ngIf=\"dropdown.isOpen\"></my-component>\n     * </eui-dropdown>\n     * ```\n     * @returns A boolean with value `true` when open, otherwise `false`.\n     */\n    get isOpen(): boolean {\n        return this.isOpen$.value;\n    }\n\n    public onTriggerClicked(e: Event): void {\n        if (\n            !(e.target as HTMLElement).querySelector('.disabled') &&\n            !(e.target as HTMLElement).querySelector(':disabled') &&\n            !this.isOpen\n        ) {\n            if (this.isBlock) {\n                this.width = this.triggerRef.nativeElement.offsetWidth + 'px';\n            }\n\n            this.openDropdown(e.target as HTMLElement);\n            e.stopPropagation();\n        }\n    }\n\n    public onTriggerRightClicked(e: Event): void {\n        if (\n            !(e.target as HTMLElement).querySelector('.disabled') &&\n            !(e.target as HTMLElement).querySelector(':disabled') &&\n            !this.isOpen\n        ) {\n            if (this.isBlock) {\n                this.width = this.triggerRef.nativeElement.offsetWidth + 'px';\n            }\n\n            this.mousePositionX = (e as PointerEvent).clientX;\n            this.mousePositionY = (e as PointerEvent).clientY;\n            this.initialScrollX = window.pageXOffset;\n            this.initialScrollY = window.pageYOffset;\n\n            this.openDropdown(e.target as HTMLElement);\n            e.preventDefault();\n            e.stopPropagation();\n        }\n    }\n\n    public onClick(): void {\n        if (\n            this.isClosedOnClickInside &&\n            !this.activeDescendantKeyManager?.activeItem.subDropdown &&\n            !this.activeDescendantKeyManager?.activeItem.elementRef?.nativeElement?.disabled\n        ) {\n            this.closeDropdown(true);\n        }\n    }\n\n    /**\n     * Open a dropdown\n     *\n     * @param origin Origin of the dropdown position\n     */\n    public openDropdown(origin: HTMLElement, position?: { x: number, y: number }): void {\n        this.origin = origin;\n\n        if (position) {\n            this.mousePositionX = position.x;\n            this.mousePositionY = position.y;\n            this.initialScrollX = window.pageXOffset;\n            this.initialScrollY = window.pageYOffset;\n        }\n\n        if (this.isRightClickEnabled) {\n            this.scrollSubscription = fromEvent(window, 'scroll').subscribe((event: Event) => {\n                this.overlayRef?.updatePositionStrategy(this.getContextualMenuPositionStrategy());\n            });\n        }\n\n        if (!this.isTriggerFocusableOnClose(origin)) {\n            this.origin = origin.closest('button:not([disabled])') || (this.triggerRef.nativeElement.firstChild as HTMLElement);\n\n            if (!this.origin) {\n                this.origin = origin.closest('a');\n            }\n\n            if (!this.origin) {\n                this.origin = origin;\n            }\n        }\n\n        if (!this.isOpen) {\n            this.scrollDispatcherSubscription = this.scrollDispatcher\n                .ancestorScrolled(this.origin)\n                .pipe(takeUntil(this.destroy$))\n                .subscribe((event: CdkScrollable) => {\n                    if (!this.isVisible(this.origin, event ? event.getElementRef().nativeElement : document.querySelector('body'))) {\n                        this.closeDropdown();\n                    }\n                });\n\n            const positionStrategy = this.isRightClickEnabled ? this.getContextualMenuPositionStrategy() : this.getPositionStrategy();\n            const scrollStrategy = this.overlay.scrollStrategies.reposition({ scrollThrottle: 10 });\n\n            this.overlayRef = this.overlay.create({\n                hasBackdrop: false,\n                backdropClass: 'eui-dropdown__backdrop',\n                panelClass: 'eui-dropdown__panel',\n                positionStrategy,\n                scrollStrategy,\n                disposeOnNavigation: true,\n            });\n            this.overlayRef.attach(this.templatePortal);\n\n            if (this.isRightClickEnabled) {\n                this.overlayRef?.updatePositionStrategy(this.getContextualMenuPositionStrategy());\n            }\n\n            this.overlayRef\n                .outsidePointerEvents()\n                .pipe(takeUntil(this.destroy$))\n                .subscribe(() => {\n                    this.closeDropdown();\n                });\n            this.overlayRef\n                .backdropClick()\n                .pipe(takeUntil(this.destroy$))\n                .subscribe(() => {\n                    this.closeDropdown();\n                });\n            this.overlayRef\n                .keydownEvents()\n                .pipe(takeUntil(this.destroy$))\n                .subscribe((keyboardEvent) => {\n                    if (keyboardEvent.key?.toLowerCase() === 'escape') {\n                        this.closeDropdown();\n                    }\n                });\n\n            if (this.hasDropdownItems) {\n                this.euiDropdownItems.toArray().forEach((euiDropdownItem, i) => {\n                    if (this.isExpandOnHover) {\n                        this.euiDropdownItemsEventSubscriptions[i] = fromEvent(\n                            euiDropdownItem.elementRef.nativeElement,\n                            'mouseenter',\n                        ).subscribe((e: MouseEvent) => {\n                            this.activeDescendantKeyManager.setActiveItem(euiDropdownItem);\n                            if (this.activeDescendantKeyManager.activeItem.subDropdown) {\n                                this.activeDescendantKeyManager.activeItem.subDropdown.setParentDropdown(this);\n                                this.activeDescendantKeyManager.activeItem.subDropdown.overlayRef.detachBackdrop();\n                                this.keydownListenerSubscription.unsubscribe();\n                            }\n\n                            const triggerOutsidePointerEvents = (subDropdown: EuiDropdownComponent): void => {\n                                subDropdown?.overlayRef?._outsidePointerEvents.next(e);\n\n                                if (subDropdown?.hasDropdownItems) {\n                                    subDropdown.euiDropdownItems.toArray().forEach((s) => {\n                                        triggerOutsidePointerEvents(s.subDropdown);\n                                    });\n                                }\n                            };\n\n                            this.euiDropdownItems\n                                .filter((item) => !item.isActive)\n                                .forEach((euiDropdownItemHavingSubDropdown) => {\n                                    triggerOutsidePointerEvents(euiDropdownItemHavingSubDropdown.subDropdown);\n                                });\n                        });\n                    } else {\n                        this.euiDropdownItemsEventSubscriptions[i] = fromEvent(euiDropdownItem.elementRef.nativeElement, 'click').subscribe(\n                            () => {\n                                this.activeDescendantKeyManager.setActiveItem(euiDropdownItem);\n                                if (this.activeDescendantKeyManager.activeItem.subDropdown) {\n                                    this.activeDescendantKeyManager.activeItem.subDropdown.setParentDropdown(this);\n                                    this.activeDescendantKeyManager.activeItem.subDropdown.overlayRef.detachBackdrop();\n                                    this.keydownListenerSubscription.unsubscribe();\n                                }\n\n                                const labelElement = this.triggerRef.nativeElement.querySelector('button .eui-label');\n                                if (this.isLabelUpdatedFromSelectedItem && labelElement) {\n                                    (labelElement as HTMLElement).innerText = euiDropdownItem.elementRef.nativeElement.innerText;\n                                }\n                            },\n                        );\n                    }\n                });\n\n                this.activeDescendantKeyManager = new ActiveDescendantKeyManager(this.euiDropdownItems)\n                    .withHomeAndEnd(true)\n                    .withVerticalOrientation(true)\n                    .withWrap();\n                this.activeDescendantKeyManager.setFirstItemActive();\n            }\n\n            this.createKeyboardHandlerSubscription();\n            this.isOpen$.next(true);\n            this.dropdownService.isDropdownOpen.emit(true);\n        }\n    }\n\n    /**\n     * Close a dropdown\n     */\n    public closeDropdown(recursively = false): void {\n        this.isOpen$.next(false);\n        this.euiDropdownItemsEventSubscriptions.forEach((euiDropdownItemsEventSubscription) => {\n            euiDropdownItemsEventSubscription.unsubscribe();\n        });\n        this.keydownListenerSubscription.unsubscribe();\n        if (this.hasDropdownItems) {\n            this.activeDescendantKeyManager?.setFirstItemActive();\n        }\n        this.scrollDispatcherSubscription.unsubscribe();\n        this.activeDescendantKeyManagerChangeSubscription.unsubscribe();\n        this.scrollSubscription.unsubscribe();\n        this.overlayRef?.dispose();\n        this.overlayRef = null;\n        this.activeDescendantKeyManager = null;\n        if (this.trapFocusAutoCapture) {\n            this.origin.focus();\n        }\n        if (recursively && this.parentDropdown) {\n            this.parentDropdown.closeDropdown(true);\n        }\n\n        this.dropdownService.isDropdownOpen.emit(false);\n    }\n\n    public projectContentChanged(): void {\n        if (!this.isRightClickEnabled) {\n            this.positionStrategy = this.getPositionStrategy();\n            this.overlayRef.updatePositionStrategy(this.positionStrategy);\n        }\n    }\n\n    public createKeyboardHandlerSubscription(): void {\n        this.keydownListenerSubscription = fromEvent(document, 'keydown').subscribe((event: KeyboardEvent) => {\n            if (this.isOpen) {\n                if (\n                    event.code === 'Enter' &&\n                    !this.hasTabNavigation &&\n                    !this.activeDescendantKeyManager?.activeItem.elementRef?.nativeElement?.disabled\n                ) {\n                    this.activeDescendantKeyManager?.activeItem.focus();\n                    this.isExpandOnHover\n                        ? this.activeDescendantKeyManager?.activeItem.mouseenter()\n                        : this.activeDescendantKeyManager?.activeItem.click();\n\n                    if (this.activeDescendantKeyManager?.activeItem.subDropdown) {\n                        this.activeDescendantKeyManager.activeItem.subDropdown.setParentDropdown(this);\n                        this.keydownListenerSubscription.unsubscribe();\n                    } else {\n                        this.closeDropdown();\n                    }\n                    event.preventDefault();\n                } else if (event.code === 'ArrowLeft') {\n                    if (this.parentDropdown) {\n                        this.parentDropdown.createKeyboardHandlerSubscription();\n                        this.closeDropdown();\n                    }\n                    event.preventDefault();\n                } else if (event.code === 'ArrowRight') {\n                    if (this.activeDescendantKeyManager?.activeItem.subDropdown) {\n                        this.activeDescendantKeyManager.activeItem.focus();\n                        this.isExpandOnHover\n                            ? this.activeDescendantKeyManager.activeItem.mouseenter()\n                            : this.activeDescendantKeyManager.activeItem.click();\n                        this.activeDescendantKeyManager.activeItem.subDropdown.setParentDropdown(this);\n                        this.keydownListenerSubscription.unsubscribe();\n                    }\n                    event.preventDefault();\n                } else if (event.code === 'Tab' && !this.hasTabNavigation) {\n                    this.closeDropdown(true);\n                } else {\n                    this.activeDescendantKeyManager?.onKeydown(event);\n                }\n            }\n        });\n    }\n\n    public setParentDropdown(parentDropdown: EuiDropdownComponent): void {\n        this.parentDropdown = parentDropdown;\n        this.position = 'right';\n        this.setPosition();\n\n        const positionStrategy = this.getPositionStrategy();\n        this.overlayRef.updatePositionStrategy(positionStrategy);\n    }\n\n    private get hasDropdownItems(): boolean {\n        return this.euiDropdownItems?.length > 0;\n    }\n\n    private getPositionStrategy(): FlexibleConnectedPositionStrategy {\n        return this.overlay\n            .position()\n            .flexibleConnectedTo(this.origin as FlexibleConnectedPositionStrategyOrigin)\n            .withPositions([\n                new ConnectionPositionPair(\n                    { originX: this.originX, originY: this.originY },\n                    { overlayX: this.overlayX, overlayY: this.overlayY },\n                ),\n            ])\n            .withFlexibleDimensions(false)\n            .withLockedPosition(true);\n    }\n\n    private getContextualMenuPositionStrategy(): GlobalPositionStrategy {\n        const panelHeight = this.overlayRef?.overlayElement.clientHeight || 0;\n        const scrollX = window.scrollX || window.pageXOffset;\n        const scrollY = window.scrollY || window.pageYOffset;\n        const newX = this.mousePositionX + (this.initialScrollX - scrollX);\n        const newY = this.mousePositionY + (this.initialScrollY - scrollY);\n        const menuBottomPosition = newY + panelHeight;\n        const isMenuBelowWindowBottom = menuBottomPosition > window.innerHeight;\n\n        const positionStrategy = this.overlay\n            .position()\n            .global()\n            .left(newX + 'px');\n\n        if (isMenuBelowWindowBottom) {\n            positionStrategy.bottom(window.innerHeight - newY + 'px');\n        } else {\n            positionStrategy.top(newY + 'px');\n        }\n\n        return positionStrategy;\n    }\n\n    private isVisible(origin: HTMLElement, scrollableParent: HTMLElement): boolean {\n        const originY = origin.getBoundingClientRect().y;\n        const scrollableParentY = Math.abs(scrollableParent.getBoundingClientRect().y);\n        const scrollableParentHeight = scrollableParent.getBoundingClientRect().height - 50;\n\n        return (\n            (originY > 0 && originY < scrollableParentHeight) ||\n            (originY - scrollableParentY > 0 && originY < scrollableParentY + scrollableParentHeight)\n        );\n    }\n\n    private isTriggerFocusableOnClose(origin: HTMLElement): boolean {\n        return origin.matches('button:not([disabled])') || origin.matches('a');\n    }\n\n    private setPosition(): void {\n        if (this.position === 'top') {\n            this.originY = 'top';\n            this.overlayY = 'bottom';\n\n            if (this.isDropDownRightAligned) {\n                this.originX = 'end';\n                this.overlayX = 'end';\n            }\n        }\n        if (this.position === 'right') {\n            this.originX = 'end';\n            this.overlayX = 'start';\n            this.overlayY = 'center';\n        }\n        if (this.position === 'bottom') {\n            this.originY = 'bottom';\n            this.overlayY = 'top';\n\n            if (this.isDropDownRightAligned) {\n                this.originX = 'end';\n                this.overlayX = 'end';\n            }\n        }\n        if (this.position === 'left') {\n            this.originX = 'start';\n            this.overlayX = 'end';\n            this.overlayY = 'center';\n        }\n    }\n}\n","<div #triggerRef class=\"eui-dropdown__trigger-container\"\n    (click)=\"!isRightClickEnabled ? onTriggerClicked($event) : null\"\n    (contextmenu)=\"isRightClickEnabled ? onTriggerRightClicked($event) : null\">\n    <ng-content></ng-content>\n</div>\n\n<ng-template #templatePortalContent>\n    <div\n        attr.data-e2e=\"{{ e2eAttr }}\"\n        [@openClose]=\"isOpen ? 'open' : 'closed'\"\n        cdkTrapFocus\n        [cdkTrapFocusAutoCapture]=\"trapFocusAutoCapture\"\n        role=\"dialog\"\n        aria-label=\"eUI dropdown panel\"\n        class=\"eui-dropdown__panel-container\"\n        [style.width]=\"width\"\n        [tabindex]=\"tabIndex\"\n        (click)=\"onClick()\"\n        (cdkObserveContent)=\"projectContentChanged()\">\n        <ng-content select=\"eui-dropdown-content\"></ng-content>\n    </div>\n</ng-template>\n"]}
|
@@ -590,11 +590,11 @@ export class EuiTableComponent extends BaseDirective {
|
|
590
590
|
return prop ? prop.split('.').reduce((prev, curr) => (prev ? prev[curr] : null), obj || self) : null;
|
591
591
|
}
|
592
592
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: EuiTableComponent, deps: [{ token: i1.EuiTableSortService }, { token: i0.ChangeDetectorRef }, { token: i2.EuiTableSelectableRowService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
593
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: EuiTableComponent, selector: "eui-table, table[euiTable]", inputs: { rows: "rows", propId: "propId", paginator: "paginator", filter: "filter", preselectedRows: "preselectedRows", loading: "loading", asyncTable: "asyncTable", paginable: "paginable", euiTableResponsive: "euiTableResponsive", euiTableFixedLayout: "euiTableFixedLayout", euiTableDraggable: "euiTableDraggable", euiTableCards: "euiTableCards", euiTableBordered: "euiTableBordered", euiTableCompact: "euiTableCompact", hasStickyHeader: "hasStickyHeader", hasStickyColumns: "hasStickyColumns", isSelectOnlyVisibleRows: "isSelectOnlyVisibleRows", isColsOrderable: "isColsOrderable", isHoverable: "isHoverable" }, outputs: { selectedRows: "selectedRows", sortChange: "sortChange", multiSortChange: "multiSortChange" }, host: { properties: { "class": "this.cssClasses", "class.eui-table__loading": "this.hasLoading" } }, providers: [EuiTableSortService, EuiTableSelectableRowService], queries: [{ propertyName: "templates", predicate: EuiTemplateDirective }], viewQueries: [{ propertyName: "theadRef", first: true, predicate: ["theadRef"], descendants: true }, { propertyName: "tbodyRef", first: true, predicate: ["tbodyRef"], descendants: true }, { propertyName: "tfootRef", first: true, predicate: ["tfootRef"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<thead #theadRef *ngIf=\"headerTemplate\">\n <ng-template [ngTemplateOutlet]=\"headerTemplate\"></ng-template>\n</thead>\n<tbody #tbodyRef *ngIf=\"bodyTemplate\">\n <ng-container *ngFor=\"let row of rowsRendered; let i = index; trackBy: trackByFn\">\n <ng-template\n [ngTemplateOutlet]=\"bodyTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: i + page * pageSize }\">\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"emptyMessageTemplate && rowsRendered.length === 0\">\n <ng-template [ngTemplateOutlet]=\"emptyMessageTemplate\"></ng-template>\n </ng-container>\n</tbody>\n<tfoot #tfootRef *ngIf=\"footerTemplate\">\n <ng-template [ngTemplateOutlet]=\"footerTemplate\"></ng-template>\n</tfoot>\n", styles: [".eui-table__scrollable-wrapper{overflow:auto}.eui-table__scrollable-wrapper::-webkit-scrollbar{display:inherit;height:10px;width:10px;background-color:var(--eui-base-color-grey-5)}.eui-table__scrollable-wrapper::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-table__scrollable-wrapper::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-table__scrollable-wrapper::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-table__orderable-cols-preview{background-color:var(--eui-base-color-grey-25);border-color:transparent;padding:calc(var(--eui-base-spacing-m) - 2px) var(--eui-base-spacing-s);cursor:move;opacity:.7}.eui-table{--eui-table-compact-scale-factor: .95;--eui-table-background-color: var(--eui-base-color-white);--eui-table-text-color: var(--eui-base-color-text);--eui-table-selected-row-background-color: var(--eui-base-color-primary-10);--eui-table-highlighted-background-color: var(--eui-base-color-accent-100);--eui-table-hover-background-color: var(--eui-base-color-primary-10);--eui-table-bordered-color: var(--eui-base-color-grey-15);--eui-table-loading-position: 50%;background-color:var(--eui-table-background-color);border-collapse:collapse;border-spacing:0;color:var(--eui-table-text-color);display:table;overflow:auto;-webkit-overflow-scrolling:touch;position:relative;width:auto}.eui-table thead>tr>th,.eui-table tbody>tr>td,.eui-table tfoot>tr>td{vertical-align:middle}.eui-table--bordered{box-shadow:var(--eui-base-shadow-1)}.eui-table--bordered td,.eui-table--bordered th{border:1px solid var(--eui-table-bordered-color)}.eui-table--compact thead th,.eui-table--compact thead tr{font-size:calc(var(--eui-base-font-size) * var(--eui-table-compact-scale-factor))!important;padding:var(--eui-base-spacing-s)!important}.eui-table--compact tbody tr{height:calc(2 * var(--eui-base-spacing-m))!important}.eui-table--compact tbody tr td{font-size:calc(var(--eui-base-font-size) * var(--eui-table-compact-scale-factor))!important;padding:0 var(--eui-base-spacing-s)!important}.eui-table--responsive{width:100%}.eui-table--fixed-layout{table-layout:fixed}.eui-table--highlighted{background-color:var(--eui-table-highlighted-background-color);text-decoration:none}.eui-table--hoverable tbody tr:hover,.eui-table--hoverable tbody tr:hover td{background-color:var(--eui-table-hover-background-color)!important}.eui-table--hoverable tbody tr:hover td:hover{background-color:var(--eui-base-color-primary-25)!important}.eui-table--cols-orderable .cdk-drag-placeholder{background-color:var(--eui-base-color-white);color:var(--eui-base-color-info-100);cursor:move;opacity:1}.eui-table--cols-orderable tr{display:table-row}.eui-table--cols-orderable tr th{cursor:move}.eui-table .actionsColumn,.eui-table__actions-column{text-align:center;width:calc(15 * var(--eui-base-spacing-m))}.eui-table.eui-table__loading:before{animation:.8s linear infinite spin;border:8px solid transparent;border-radius:50%;border-top-color:var(--eui-base-color-primary-100);content:\"\";display:block;height:80px;left:50%;margin:-40px 0 0 -40px;position:absolute;top:var(--eui-table-loading-position);width:80px;z-index:1000001}.eui-table.eui-table__loading tbody{opacity:var(--eui-base-disabled-opacity)}.eui-table thead tr.eui-table__columns-filter th{background-color:var(--eui-base-color-grey-5);position:relative;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family)}.eui-table thead tr th{background-color:var(--eui-base-color-grey-10);padding:var(--eui-base-spacing-m) var(--eui-base-spacing-s);text-align:left;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family);font-weight:700}.eui-table thead tr th .eui-resizable .eui-resizable-icon__container{transform:translateY(calc(var(--eui-base-spacing-l) + 2px + 2px))}.eui-table thead tr th.eui-table__sortable-col .eui-table__sortable-col-content{align-items:center;display:inline-flex;position:relative;vertical-align:middle;white-space:nowrap}.eui-table thead tr th.eui-table__sortable-col--disabled{cursor:default}.eui-table thead tr th .eui-table__sortable-icon-button{margin-left:var(--eui-base-spacing-2xs)}.eui-table thead tr th.eui-table__cell-select{color:var(--eui-base-color-grey-75);width:auto}.eui-table thead tr th.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table thead tr th.eui-table__cell-select .eui-table__cell-select--indeterminated{position:absolute;right:50%;top:var(--eui-base-spacing-s);transform:translate(50%)}.eui-table tbody tr{border-top:1px solid var(--eui-base-color-grey-15);height:calc(3 * var(--eui-base-spacing-m))}.eui-table tbody tr.eui-table__row--selected,.eui-table tbody tr.eui-table__row--selected td{background-color:var(--eui-table-selected-row-background-color)!important}.eui-table tbody tr:not(.eui-table-expandable-row):nth-child(odd){background-color:var(--eui-base-color-grey-2)}.eui-table tbody tr:not(.eui-table-expandable-row):nth-child(odd) td{background-color:var(--eui-base-color-grey-2)}.eui-table tbody tr td{padding:var(--eui-base-spacing-xs) var(--eui-base-spacing-s);vertical-align:middle}.eui-table tbody tr td.eui-table__cell-select{color:var(--eui-base-color-grey-75);width:auto}.eui-table tbody tr td.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table tbody tr:nth-of-type(odd){background-color:var(--eui-base-color-white)}.eui-table tbody tr:nth-of-type(2n){background-color:var(--eui-base-color-grey-5)}.eui-table tbody tr:nth-of-type(2n) td{background-color:var(--eui-base-color-grey-5)}.eui-table tfoot tr{border-bottom:1px solid var(--eui-base-color-grey-15);border-top:1px solid var(--eui-base-color-grey-15)}.eui-table tfoot tr td{padding:var(--eui-base-spacing-s);vertical-align:middle}.eui-table__sticky-container{overflow:auto}.eui-table__sticky-container::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-base-color-grey-5)}.eui-table__sticky-container::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-table__sticky-container::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-table__sticky-container::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-table--sticky-header thead tr th{position:sticky;top:0;z-index:8}.eui-table--sticky-columns .eui-table__col--sticky{position:sticky}.eui-table--sticky-columns th.eui-table__col--sticky{z-index:9}.eui-table--sticky-columns th.eui-table__col--sticky.eui-table__col--sticky-shadowed-first{box-shadow:inset -5px 0 8px -8px #0003}.eui-table--sticky-columns th.eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:inset 5px 0 8px -8px #0003}.eui-table--sticky-columns td.eui-table__col--sticky{z-index:8}.eui-table--sticky-columns td.eui-table__col--sticky.eui-table__col--sticky-shadowed-first{box-shadow:inset -5px 0 8px -8px #0003}.eui-table--sticky-columns td.eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:inset 5px 0 8px -8px #0003}@media screen and (max-width: 767px){.eui-table:not(.eui-table-cards).eui-table--responsive{width:100%}.eui-table:not(.eui-table-cards).eui-table--responsive thead,.eui-table:not(.eui-table-cards).eui-table--responsive tbody,.eui-table:not(.eui-table-cards).eui-table--responsive tfoot,.eui-table:not(.eui-table-cards).eui-table--responsive th,.eui-table:not(.eui-table-cards).eui-table--responsive td,.eui-table:not(.eui-table-cards).eui-table--responsive tr{display:block}.eui-table:not(.eui-table-cards).eui-table--responsive thead tr{left:-9999px;position:absolute;top:-9999px}.eui-table:not(.eui-table-cards).eui-table--responsive tr{height:auto}.eui-table:not(.eui-table-cards).eui-table--responsive td{border:none;border-bottom:1px solid var(--eui-base-color-grey-10);padding:var(--eui-base-spacing-xs);padding-left:50%;position:relative;text-align:left!important}.eui-table:not(.eui-table-cards).eui-table--responsive td:before{color:var(--eui-base-color-grey-80);content:attr(data-col-label);left:var(--eui-base-spacing-xs);padding-right:var(--eui-base-spacing-xs);position:absolute;top:var(--eui-base-spacing-xs);white-space:nowrap;width:45%;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family);font-weight:700}.eui-table:not(.eui-table-cards) .actionsColumn{text-align:left;width:100%}}.eui-table__filter{align-items:center;display:flex;justify-content:flex-end;position:relative}.eui-table__filter--responsive{width:100%}.eui-table__filter-input{padding-left:var(--eui-base-spacing-2xl)!important}.eui-table__filter-search-icon{left:var(--eui-base-spacing-xs);position:absolute;top:calc(var(--eui-base-spacing-xs) + 2px)}@media screen and (max-width: 767px){.eui-table__filter--responsive{display:block;width:100%}}.eui-table__draggable-preview--no-preview.cdk-drag-preview{display:none}.eui-table--draggable tr.eui-table__draggable-preview--no-placeholder{opacity:1}.eui-table--draggable tr:hover{background-color:var(--eui-base-color-accent-5)}.eui-table--draggable td .cdk-drop-list{flex-direction:column}.eui-table-cards{background-color:transparent;display:flex;flex-direction:column;overflow:hidden;width:100%}.eui-table-cards thead{width:100%}.eui-table-cards thead tr{align-items:center;height:auto}.eui-table-cards thead tr th{position:relative;vertical-align:middle;width:100%}.eui-table-cards thead tr th.eui-table__cell-select{padding:var(--eui-base-spacing-s) var(--eui-base-spacing-m);width:auto}.eui-table-cards thead tr th.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table-cards tbody{width:100%}.eui-table-cards tbody tr{align-items:center;border-top:0;display:flex;height:auto;width:100%}.eui-table-cards tbody tr.eui-table__row--selected .eui-card:first-child{--eui-card-header-background-color: var(--eui-table-selected-row-background-color)}.eui-table-cards tbody tr td{position:relative;vertical-align:middle;width:100%}.eui-table-cards tbody tr td.eui-table__cell-select{padding:var(--eui-base-spacing-s) var(--eui-base-spacing-m);width:auto}.eui-table-cards tbody tr td.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table-cards tbody tr:hover{background-color:transparent}.eui-table-cards tbody tr:not(.eui-table-expandable-row):nth-child(odd){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(2n){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(2n):hover:not(.eui-table__row--selected){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(odd):hover:not(.eui-table__row--selected){background-color:transparent}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
593
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: EuiTableComponent, selector: "eui-table, table[euiTable]", inputs: { rows: "rows", propId: "propId", paginator: "paginator", filter: "filter", preselectedRows: "preselectedRows", loading: "loading", asyncTable: "asyncTable", paginable: "paginable", euiTableResponsive: "euiTableResponsive", euiTableFixedLayout: "euiTableFixedLayout", euiTableDraggable: "euiTableDraggable", euiTableCards: "euiTableCards", euiTableBordered: "euiTableBordered", euiTableCompact: "euiTableCompact", hasStickyHeader: "hasStickyHeader", hasStickyColumns: "hasStickyColumns", isSelectOnlyVisibleRows: "isSelectOnlyVisibleRows", isColsOrderable: "isColsOrderable", isHoverable: "isHoverable" }, outputs: { selectedRows: "selectedRows", sortChange: "sortChange", multiSortChange: "multiSortChange" }, host: { properties: { "class": "this.cssClasses", "class.eui-table__loading": "this.hasLoading" } }, providers: [EuiTableSortService, EuiTableSelectableRowService], queries: [{ propertyName: "templates", predicate: EuiTemplateDirective }], viewQueries: [{ propertyName: "theadRef", first: true, predicate: ["theadRef"], descendants: true }, { propertyName: "tbodyRef", first: true, predicate: ["tbodyRef"], descendants: true }, { propertyName: "tfootRef", first: true, predicate: ["tfootRef"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<thead #theadRef *ngIf=\"headerTemplate\">\n <ng-template [ngTemplateOutlet]=\"headerTemplate\"></ng-template>\n</thead>\n<tbody #tbodyRef *ngIf=\"bodyTemplate\">\n <ng-container *ngFor=\"let row of rowsRendered; let i = index; trackBy: trackByFn\">\n <ng-template\n [ngTemplateOutlet]=\"bodyTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: i + page * pageSize }\">\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"emptyMessageTemplate && rowsRendered.length === 0\">\n <ng-template [ngTemplateOutlet]=\"emptyMessageTemplate\"></ng-template>\n </ng-container>\n</tbody>\n<tfoot #tfootRef *ngIf=\"footerTemplate\">\n <ng-template [ngTemplateOutlet]=\"footerTemplate\"></ng-template>\n</tfoot>\n", styles: [".eui-table__scrollable-wrapper{overflow:auto}.eui-table__scrollable-wrapper::-webkit-scrollbar{display:inherit;height:10px;width:10px;background-color:var(--eui-base-color-grey-5)}.eui-table__scrollable-wrapper::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-table__scrollable-wrapper::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-table__scrollable-wrapper::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-table__orderable-cols-preview{background-color:var(--eui-base-color-grey-25);border-color:transparent;padding:calc(var(--eui-base-spacing-m) - 2px) var(--eui-base-spacing-s);cursor:move;opacity:.7}.eui-table{--eui-table-compact-scale-factor: .95;--eui-table-background-color: var(--eui-base-color-white);--eui-table-text-color: var(--eui-base-color-text);--eui-table-selected-row-background-color: var(--eui-base-color-primary-10);--eui-table-highlighted-background-color: var(--eui-base-color-accent-100);--eui-table-hover-background-color: var(--eui-base-color-primary-10);--eui-table-bordered-color: var(--eui-base-color-grey-15);--eui-table-loading-position: 50%;background-color:var(--eui-table-background-color);border-collapse:collapse;border-spacing:0;color:var(--eui-table-text-color);display:table;overflow:auto;-webkit-overflow-scrolling:touch;position:relative;width:auto}.eui-table thead>tr>th,.eui-table tbody>tr>td,.eui-table tfoot>tr>td{vertical-align:middle}.eui-table--bordered{box-shadow:var(--eui-base-shadow-1)}.eui-table--bordered td,.eui-table--bordered th{border:1px solid var(--eui-table-bordered-color)}.eui-table--compact thead th,.eui-table--compact thead tr{font-size:calc(var(--eui-base-font-size) * var(--eui-table-compact-scale-factor))!important;padding:var(--eui-base-spacing-s)!important}.eui-table--compact tbody tr{height:calc(2 * var(--eui-base-spacing-m))!important}.eui-table--compact tbody tr td{font-size:calc(var(--eui-base-font-size) * var(--eui-table-compact-scale-factor))!important;padding:0 var(--eui-base-spacing-s)!important}.eui-table--responsive{width:100%}.eui-table--fixed-layout{table-layout:fixed}.eui-table--highlighted{background-color:var(--eui-table-highlighted-background-color);text-decoration:none}.eui-table--hoverable tbody tr:hover,.eui-table--hoverable tbody tr:hover td{background-color:var(--eui-table-hover-background-color)!important}.eui-table--hoverable tbody tr:hover td:hover{background-color:var(--eui-base-color-primary-25)!important}.eui-table--cols-orderable .cdk-drag-placeholder{background-color:var(--eui-base-color-white);color:var(--eui-base-color-info-100);cursor:move;opacity:1}.eui-table--cols-orderable tr{display:table-row}.eui-table--cols-orderable tr th{cursor:move}.eui-table .actionsColumn,.eui-table__actions-column{text-align:center;width:calc(15 * var(--eui-base-spacing-m))}.eui-table.eui-table__loading:before{animation:.8s linear infinite spin;border:8px solid transparent;border-radius:50%;border-top-color:var(--eui-base-color-primary-100);content:\"\";display:block;height:80px;left:50%;margin:-40px 0 0 -40px;position:absolute;top:var(--eui-table-loading-position);width:80px;z-index:1000001}.eui-table.eui-table__loading tbody{opacity:var(--eui-base-disabled-opacity)}.eui-table thead tr.eui-table__columns-filter th{background-color:var(--eui-base-color-grey-5);position:relative;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family)}.eui-table thead tr th{background-color:var(--eui-base-color-grey-10);padding:var(--eui-base-spacing-m) var(--eui-base-spacing-s);text-align:left;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family);font-weight:700}.eui-table thead tr th .eui-resizable .eui-resizable-icon__container{transform:translateY(calc(var(--eui-base-spacing-l) + 2px + 2px))}.eui-table thead tr th.eui-table__sortable-col .eui-table__sortable-col-content{align-items:center;display:inline-flex;position:relative;vertical-align:middle;white-space:nowrap}.eui-table thead tr th.eui-table__sortable-col--disabled{cursor:default}.eui-table thead tr th .eui-table__sortable-icon-button{margin-left:var(--eui-base-spacing-2xs)}.eui-table thead tr th.eui-table__cell-select{color:var(--eui-base-color-grey-75);width:auto}.eui-table thead tr th.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table thead tr th.eui-table__cell-select .eui-table__cell-select--indeterminated{position:absolute;right:50%;top:var(--eui-base-spacing-s);transform:translate(50%)}.eui-table tbody tr{border-top:1px solid var(--eui-base-color-grey-15);height:calc(3 * var(--eui-base-spacing-m))}.eui-table tbody tr.eui-table__row--selected,.eui-table tbody tr.eui-table__row--selected td{background-color:var(--eui-table-selected-row-background-color)!important}.eui-table tbody tr:not(.eui-table-expandable-row):nth-child(odd){background-color:var(--eui-base-color-grey-2)}.eui-table tbody tr:not(.eui-table-expandable-row):nth-child(odd) td{background-color:var(--eui-base-color-grey-2)}.eui-table tbody tr td{padding:var(--eui-base-spacing-xs) var(--eui-base-spacing-s);vertical-align:middle}.eui-table tbody tr td.eui-table__cell-select{color:var(--eui-base-color-grey-75);width:auto}.eui-table tbody tr td.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table tbody tr:nth-of-type(odd){background-color:var(--eui-base-color-white)}.eui-table tbody tr:nth-of-type(2n){background-color:var(--eui-base-color-grey-5)}.eui-table tbody tr:nth-of-type(2n) td{background-color:var(--eui-base-color-grey-5)}.eui-table tfoot tr{border-bottom:1px solid var(--eui-base-color-grey-15);border-top:1px solid var(--eui-base-color-grey-15)}.eui-table tfoot tr td{padding:var(--eui-base-spacing-s);vertical-align:middle}.eui-table__sticky-container{overflow:auto}.eui-table__sticky-container::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-base-color-grey-5)}.eui-table__sticky-container::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-table__sticky-container::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-table__sticky-container::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-table--sticky-header thead tr th{position:sticky;top:0;z-index:8}.eui-table--sticky-columns .eui-table__col--sticky{position:sticky}.eui-table--sticky-columns th.eui-table__col--sticky{z-index:9}.eui-table--sticky-columns th.eui-table__col--sticky.eui-table__col--sticky-shadowed-first{box-shadow:inset -5px 0 8px -8px #0003}.eui-table--sticky-columns th.eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:inset 5px 0 8px -8px #0003}.eui-table--sticky-columns td.eui-table__col--sticky{z-index:8}.eui-table--sticky-columns td.eui-table__col--sticky.eui-table__col--sticky-shadowed-first{box-shadow:inset -5px 0 8px -8px #0003}.eui-table--sticky-columns td.eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:inset 5px 0 8px -8px #0003}@media screen and (max-width: 767px){.eui-table:not(.eui-table-cards).eui-table--responsive{width:100%!important}.eui-table:not(.eui-table-cards).eui-table--responsive thead,.eui-table:not(.eui-table-cards).eui-table--responsive tbody,.eui-table:not(.eui-table-cards).eui-table--responsive tfoot,.eui-table:not(.eui-table-cards).eui-table--responsive th,.eui-table:not(.eui-table-cards).eui-table--responsive td,.eui-table:not(.eui-table-cards).eui-table--responsive tr{display:block}.eui-table:not(.eui-table-cards).eui-table--responsive thead tr{left:-9999px;position:absolute;top:-9999px}.eui-table:not(.eui-table-cards).eui-table--responsive tr{height:auto}.eui-table:not(.eui-table-cards).eui-table--responsive td{border:none;border-bottom:1px solid var(--eui-base-color-grey-10);padding-left:50%;position:relative;text-align:left!important}.eui-table:not(.eui-table-cards).eui-table--responsive td:before{color:var(--eui-base-color-grey-80);content:attr(data-col-label);left:var(--eui-base-spacing-xs);padding-right:var(--eui-base-spacing-xs);position:absolute;width:45%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family);font-weight:700}.eui-table:not(.eui-table-cards) .actionsColumn,.eui-table:not(.eui-table-cards) .actions-column{justify-content:flex-start;text-align:left;width:100%}.eui-table__sticky-container{height:auto!important;width:auto!important}.eui-table--sticky-columns th,.eui-table--sticky-columns td,.eui-table--sticky-columns th .eui-table__col--sticky,.eui-table--sticky-columns td .eui-table__col--sticky{width:auto;z-index:auto}.eui-table--sticky-columns th .eui-table__col--sticky.eui-table__col--sticky-shadowed-first,.eui-table--sticky-columns th .eui-table__col--sticky.eui-table__col--sticky-shadowed-last,.eui-table--sticky-columns td .eui-table__col--sticky.eui-table__col--sticky-shadowed-first,.eui-table--sticky-columns td .eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:none!important}.eui-table--sticky-columns tfoot tr td:empty{display:none!important}}.eui-table__filter{align-items:center;display:flex;justify-content:flex-end;position:relative}.eui-table__filter--responsive{width:100%}.eui-table__filter-input{padding-left:var(--eui-base-spacing-2xl)!important}.eui-table__filter-search-icon{left:var(--eui-base-spacing-xs);position:absolute;top:calc(var(--eui-base-spacing-xs) + 2px)}@media screen and (max-width: 767px){.eui-table__filter--responsive{display:block;width:100%}}.eui-table__draggable-preview--no-preview.cdk-drag-preview{display:none}.eui-table--draggable tr.eui-table__draggable-preview--no-placeholder{opacity:1}.eui-table--draggable tr:hover{background-color:var(--eui-base-color-accent-5)}.eui-table--draggable td .cdk-drop-list{flex-direction:column}.eui-table-cards{background-color:transparent;display:flex;flex-direction:column;overflow:hidden;width:100%}.eui-table-cards thead{width:100%}.eui-table-cards thead tr{align-items:center;height:auto}.eui-table-cards thead tr th{position:relative;vertical-align:middle;width:100%}.eui-table-cards thead tr th.eui-table__cell-select{padding:var(--eui-base-spacing-s) var(--eui-base-spacing-m);width:auto}.eui-table-cards thead tr th.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table-cards tbody{width:100%}.eui-table-cards tbody tr{align-items:center;border-top:0;display:flex;height:auto;width:100%}.eui-table-cards tbody tr.eui-table__row--selected .eui-card:first-child{--eui-card-header-background-color: var(--eui-table-selected-row-background-color)}.eui-table-cards tbody tr td{position:relative;vertical-align:middle;width:100%}.eui-table-cards tbody tr td.eui-table__cell-select{padding:var(--eui-base-spacing-s) var(--eui-base-spacing-m);width:auto}.eui-table-cards tbody tr td.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table-cards tbody tr:hover{background-color:transparent}.eui-table-cards tbody tr:not(.eui-table-expandable-row):nth-child(odd){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(2n){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(2n):hover:not(.eui-table__row--selected){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(odd):hover:not(.eui-table__row--selected){background-color:transparent}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
594
594
|
}
|
595
595
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: EuiTableComponent, decorators: [{
|
596
596
|
type: Component,
|
597
|
-
args: [{ selector: 'eui-table, table[euiTable]', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [EuiTableSortService, EuiTableSelectableRowService], template: "<thead #theadRef *ngIf=\"headerTemplate\">\n <ng-template [ngTemplateOutlet]=\"headerTemplate\"></ng-template>\n</thead>\n<tbody #tbodyRef *ngIf=\"bodyTemplate\">\n <ng-container *ngFor=\"let row of rowsRendered; let i = index; trackBy: trackByFn\">\n <ng-template\n [ngTemplateOutlet]=\"bodyTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: i + page * pageSize }\">\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"emptyMessageTemplate && rowsRendered.length === 0\">\n <ng-template [ngTemplateOutlet]=\"emptyMessageTemplate\"></ng-template>\n </ng-container>\n</tbody>\n<tfoot #tfootRef *ngIf=\"footerTemplate\">\n <ng-template [ngTemplateOutlet]=\"footerTemplate\"></ng-template>\n</tfoot>\n", styles: [".eui-table__scrollable-wrapper{overflow:auto}.eui-table__scrollable-wrapper::-webkit-scrollbar{display:inherit;height:10px;width:10px;background-color:var(--eui-base-color-grey-5)}.eui-table__scrollable-wrapper::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-table__scrollable-wrapper::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-table__scrollable-wrapper::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-table__orderable-cols-preview{background-color:var(--eui-base-color-grey-25);border-color:transparent;padding:calc(var(--eui-base-spacing-m) - 2px) var(--eui-base-spacing-s);cursor:move;opacity:.7}.eui-table{--eui-table-compact-scale-factor: .95;--eui-table-background-color: var(--eui-base-color-white);--eui-table-text-color: var(--eui-base-color-text);--eui-table-selected-row-background-color: var(--eui-base-color-primary-10);--eui-table-highlighted-background-color: var(--eui-base-color-accent-100);--eui-table-hover-background-color: var(--eui-base-color-primary-10);--eui-table-bordered-color: var(--eui-base-color-grey-15);--eui-table-loading-position: 50%;background-color:var(--eui-table-background-color);border-collapse:collapse;border-spacing:0;color:var(--eui-table-text-color);display:table;overflow:auto;-webkit-overflow-scrolling:touch;position:relative;width:auto}.eui-table thead>tr>th,.eui-table tbody>tr>td,.eui-table tfoot>tr>td{vertical-align:middle}.eui-table--bordered{box-shadow:var(--eui-base-shadow-1)}.eui-table--bordered td,.eui-table--bordered th{border:1px solid var(--eui-table-bordered-color)}.eui-table--compact thead th,.eui-table--compact thead tr{font-size:calc(var(--eui-base-font-size) * var(--eui-table-compact-scale-factor))!important;padding:var(--eui-base-spacing-s)!important}.eui-table--compact tbody tr{height:calc(2 * var(--eui-base-spacing-m))!important}.eui-table--compact tbody tr td{font-size:calc(var(--eui-base-font-size) * var(--eui-table-compact-scale-factor))!important;padding:0 var(--eui-base-spacing-s)!important}.eui-table--responsive{width:100%}.eui-table--fixed-layout{table-layout:fixed}.eui-table--highlighted{background-color:var(--eui-table-highlighted-background-color);text-decoration:none}.eui-table--hoverable tbody tr:hover,.eui-table--hoverable tbody tr:hover td{background-color:var(--eui-table-hover-background-color)!important}.eui-table--hoverable tbody tr:hover td:hover{background-color:var(--eui-base-color-primary-25)!important}.eui-table--cols-orderable .cdk-drag-placeholder{background-color:var(--eui-base-color-white);color:var(--eui-base-color-info-100);cursor:move;opacity:1}.eui-table--cols-orderable tr{display:table-row}.eui-table--cols-orderable tr th{cursor:move}.eui-table .actionsColumn,.eui-table__actions-column{text-align:center;width:calc(15 * var(--eui-base-spacing-m))}.eui-table.eui-table__loading:before{animation:.8s linear infinite spin;border:8px solid transparent;border-radius:50%;border-top-color:var(--eui-base-color-primary-100);content:\"\";display:block;height:80px;left:50%;margin:-40px 0 0 -40px;position:absolute;top:var(--eui-table-loading-position);width:80px;z-index:1000001}.eui-table.eui-table__loading tbody{opacity:var(--eui-base-disabled-opacity)}.eui-table thead tr.eui-table__columns-filter th{background-color:var(--eui-base-color-grey-5);position:relative;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family)}.eui-table thead tr th{background-color:var(--eui-base-color-grey-10);padding:var(--eui-base-spacing-m) var(--eui-base-spacing-s);text-align:left;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family);font-weight:700}.eui-table thead tr th .eui-resizable .eui-resizable-icon__container{transform:translateY(calc(var(--eui-base-spacing-l) + 2px + 2px))}.eui-table thead tr th.eui-table__sortable-col .eui-table__sortable-col-content{align-items:center;display:inline-flex;position:relative;vertical-align:middle;white-space:nowrap}.eui-table thead tr th.eui-table__sortable-col--disabled{cursor:default}.eui-table thead tr th .eui-table__sortable-icon-button{margin-left:var(--eui-base-spacing-2xs)}.eui-table thead tr th.eui-table__cell-select{color:var(--eui-base-color-grey-75);width:auto}.eui-table thead tr th.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table thead tr th.eui-table__cell-select .eui-table__cell-select--indeterminated{position:absolute;right:50%;top:var(--eui-base-spacing-s);transform:translate(50%)}.eui-table tbody tr{border-top:1px solid var(--eui-base-color-grey-15);height:calc(3 * var(--eui-base-spacing-m))}.eui-table tbody tr.eui-table__row--selected,.eui-table tbody tr.eui-table__row--selected td{background-color:var(--eui-table-selected-row-background-color)!important}.eui-table tbody tr:not(.eui-table-expandable-row):nth-child(odd){background-color:var(--eui-base-color-grey-2)}.eui-table tbody tr:not(.eui-table-expandable-row):nth-child(odd) td{background-color:var(--eui-base-color-grey-2)}.eui-table tbody tr td{padding:var(--eui-base-spacing-xs) var(--eui-base-spacing-s);vertical-align:middle}.eui-table tbody tr td.eui-table__cell-select{color:var(--eui-base-color-grey-75);width:auto}.eui-table tbody tr td.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table tbody tr:nth-of-type(odd){background-color:var(--eui-base-color-white)}.eui-table tbody tr:nth-of-type(2n){background-color:var(--eui-base-color-grey-5)}.eui-table tbody tr:nth-of-type(2n) td{background-color:var(--eui-base-color-grey-5)}.eui-table tfoot tr{border-bottom:1px solid var(--eui-base-color-grey-15);border-top:1px solid var(--eui-base-color-grey-15)}.eui-table tfoot tr td{padding:var(--eui-base-spacing-s);vertical-align:middle}.eui-table__sticky-container{overflow:auto}.eui-table__sticky-container::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-base-color-grey-5)}.eui-table__sticky-container::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-table__sticky-container::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-table__sticky-container::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-table--sticky-header thead tr th{position:sticky;top:0;z-index:8}.eui-table--sticky-columns .eui-table__col--sticky{position:sticky}.eui-table--sticky-columns th.eui-table__col--sticky{z-index:9}.eui-table--sticky-columns th.eui-table__col--sticky.eui-table__col--sticky-shadowed-first{box-shadow:inset -5px 0 8px -8px #0003}.eui-table--sticky-columns th.eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:inset 5px 0 8px -8px #0003}.eui-table--sticky-columns td.eui-table__col--sticky{z-index:8}.eui-table--sticky-columns td.eui-table__col--sticky.eui-table__col--sticky-shadowed-first{box-shadow:inset -5px 0 8px -8px #0003}.eui-table--sticky-columns td.eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:inset 5px 0 8px -8px #0003}@media screen and (max-width: 767px){.eui-table:not(.eui-table-cards).eui-table--responsive{width:100%}.eui-table:not(.eui-table-cards).eui-table--responsive thead,.eui-table:not(.eui-table-cards).eui-table--responsive tbody,.eui-table:not(.eui-table-cards).eui-table--responsive tfoot,.eui-table:not(.eui-table-cards).eui-table--responsive th,.eui-table:not(.eui-table-cards).eui-table--responsive td,.eui-table:not(.eui-table-cards).eui-table--responsive tr{display:block}.eui-table:not(.eui-table-cards).eui-table--responsive thead tr{left:-9999px;position:absolute;top:-9999px}.eui-table:not(.eui-table-cards).eui-table--responsive tr{height:auto}.eui-table:not(.eui-table-cards).eui-table--responsive td{border:none;border-bottom:1px solid var(--eui-base-color-grey-10);padding:var(--eui-base-spacing-xs);padding-left:50%;position:relative;text-align:left!important}.eui-table:not(.eui-table-cards).eui-table--responsive td:before{color:var(--eui-base-color-grey-80);content:attr(data-col-label);left:var(--eui-base-spacing-xs);padding-right:var(--eui-base-spacing-xs);position:absolute;top:var(--eui-base-spacing-xs);white-space:nowrap;width:45%;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family);font-weight:700}.eui-table:not(.eui-table-cards) .actionsColumn{text-align:left;width:100%}}.eui-table__filter{align-items:center;display:flex;justify-content:flex-end;position:relative}.eui-table__filter--responsive{width:100%}.eui-table__filter-input{padding-left:var(--eui-base-spacing-2xl)!important}.eui-table__filter-search-icon{left:var(--eui-base-spacing-xs);position:absolute;top:calc(var(--eui-base-spacing-xs) + 2px)}@media screen and (max-width: 767px){.eui-table__filter--responsive{display:block;width:100%}}.eui-table__draggable-preview--no-preview.cdk-drag-preview{display:none}.eui-table--draggable tr.eui-table__draggable-preview--no-placeholder{opacity:1}.eui-table--draggable tr:hover{background-color:var(--eui-base-color-accent-5)}.eui-table--draggable td .cdk-drop-list{flex-direction:column}.eui-table-cards{background-color:transparent;display:flex;flex-direction:column;overflow:hidden;width:100%}.eui-table-cards thead{width:100%}.eui-table-cards thead tr{align-items:center;height:auto}.eui-table-cards thead tr th{position:relative;vertical-align:middle;width:100%}.eui-table-cards thead tr th.eui-table__cell-select{padding:var(--eui-base-spacing-s) var(--eui-base-spacing-m);width:auto}.eui-table-cards thead tr th.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table-cards tbody{width:100%}.eui-table-cards tbody tr{align-items:center;border-top:0;display:flex;height:auto;width:100%}.eui-table-cards tbody tr.eui-table__row--selected .eui-card:first-child{--eui-card-header-background-color: var(--eui-table-selected-row-background-color)}.eui-table-cards tbody tr td{position:relative;vertical-align:middle;width:100%}.eui-table-cards tbody tr td.eui-table__cell-select{padding:var(--eui-base-spacing-s) var(--eui-base-spacing-m);width:auto}.eui-table-cards tbody tr td.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table-cards tbody tr:hover{background-color:transparent}.eui-table-cards tbody tr:not(.eui-table-expandable-row):nth-child(odd){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(2n){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(2n):hover:not(.eui-table__row--selected){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(odd):hover:not(.eui-table__row--selected){background-color:transparent}\n"] }]
|
597
|
+
args: [{ selector: 'eui-table, table[euiTable]', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [EuiTableSortService, EuiTableSelectableRowService], template: "<thead #theadRef *ngIf=\"headerTemplate\">\n <ng-template [ngTemplateOutlet]=\"headerTemplate\"></ng-template>\n</thead>\n<tbody #tbodyRef *ngIf=\"bodyTemplate\">\n <ng-container *ngFor=\"let row of rowsRendered; let i = index; trackBy: trackByFn\">\n <ng-template\n [ngTemplateOutlet]=\"bodyTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: row, index: i + page * pageSize }\">\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"emptyMessageTemplate && rowsRendered.length === 0\">\n <ng-template [ngTemplateOutlet]=\"emptyMessageTemplate\"></ng-template>\n </ng-container>\n</tbody>\n<tfoot #tfootRef *ngIf=\"footerTemplate\">\n <ng-template [ngTemplateOutlet]=\"footerTemplate\"></ng-template>\n</tfoot>\n", styles: [".eui-table__scrollable-wrapper{overflow:auto}.eui-table__scrollable-wrapper::-webkit-scrollbar{display:inherit;height:10px;width:10px;background-color:var(--eui-base-color-grey-5)}.eui-table__scrollable-wrapper::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-table__scrollable-wrapper::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-table__scrollable-wrapper::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-table__orderable-cols-preview{background-color:var(--eui-base-color-grey-25);border-color:transparent;padding:calc(var(--eui-base-spacing-m) - 2px) var(--eui-base-spacing-s);cursor:move;opacity:.7}.eui-table{--eui-table-compact-scale-factor: .95;--eui-table-background-color: var(--eui-base-color-white);--eui-table-text-color: var(--eui-base-color-text);--eui-table-selected-row-background-color: var(--eui-base-color-primary-10);--eui-table-highlighted-background-color: var(--eui-base-color-accent-100);--eui-table-hover-background-color: var(--eui-base-color-primary-10);--eui-table-bordered-color: var(--eui-base-color-grey-15);--eui-table-loading-position: 50%;background-color:var(--eui-table-background-color);border-collapse:collapse;border-spacing:0;color:var(--eui-table-text-color);display:table;overflow:auto;-webkit-overflow-scrolling:touch;position:relative;width:auto}.eui-table thead>tr>th,.eui-table tbody>tr>td,.eui-table tfoot>tr>td{vertical-align:middle}.eui-table--bordered{box-shadow:var(--eui-base-shadow-1)}.eui-table--bordered td,.eui-table--bordered th{border:1px solid var(--eui-table-bordered-color)}.eui-table--compact thead th,.eui-table--compact thead tr{font-size:calc(var(--eui-base-font-size) * var(--eui-table-compact-scale-factor))!important;padding:var(--eui-base-spacing-s)!important}.eui-table--compact tbody tr{height:calc(2 * var(--eui-base-spacing-m))!important}.eui-table--compact tbody tr td{font-size:calc(var(--eui-base-font-size) * var(--eui-table-compact-scale-factor))!important;padding:0 var(--eui-base-spacing-s)!important}.eui-table--responsive{width:100%}.eui-table--fixed-layout{table-layout:fixed}.eui-table--highlighted{background-color:var(--eui-table-highlighted-background-color);text-decoration:none}.eui-table--hoverable tbody tr:hover,.eui-table--hoverable tbody tr:hover td{background-color:var(--eui-table-hover-background-color)!important}.eui-table--hoverable tbody tr:hover td:hover{background-color:var(--eui-base-color-primary-25)!important}.eui-table--cols-orderable .cdk-drag-placeholder{background-color:var(--eui-base-color-white);color:var(--eui-base-color-info-100);cursor:move;opacity:1}.eui-table--cols-orderable tr{display:table-row}.eui-table--cols-orderable tr th{cursor:move}.eui-table .actionsColumn,.eui-table__actions-column{text-align:center;width:calc(15 * var(--eui-base-spacing-m))}.eui-table.eui-table__loading:before{animation:.8s linear infinite spin;border:8px solid transparent;border-radius:50%;border-top-color:var(--eui-base-color-primary-100);content:\"\";display:block;height:80px;left:50%;margin:-40px 0 0 -40px;position:absolute;top:var(--eui-table-loading-position);width:80px;z-index:1000001}.eui-table.eui-table__loading tbody{opacity:var(--eui-base-disabled-opacity)}.eui-table thead tr.eui-table__columns-filter th{background-color:var(--eui-base-color-grey-5);position:relative;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family)}.eui-table thead tr th{background-color:var(--eui-base-color-grey-10);padding:var(--eui-base-spacing-m) var(--eui-base-spacing-s);text-align:left;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family);font-weight:700}.eui-table thead tr th .eui-resizable .eui-resizable-icon__container{transform:translateY(calc(var(--eui-base-spacing-l) + 2px + 2px))}.eui-table thead tr th.eui-table__sortable-col .eui-table__sortable-col-content{align-items:center;display:inline-flex;position:relative;vertical-align:middle;white-space:nowrap}.eui-table thead tr th.eui-table__sortable-col--disabled{cursor:default}.eui-table thead tr th .eui-table__sortable-icon-button{margin-left:var(--eui-base-spacing-2xs)}.eui-table thead tr th.eui-table__cell-select{color:var(--eui-base-color-grey-75);width:auto}.eui-table thead tr th.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table thead tr th.eui-table__cell-select .eui-table__cell-select--indeterminated{position:absolute;right:50%;top:var(--eui-base-spacing-s);transform:translate(50%)}.eui-table tbody tr{border-top:1px solid var(--eui-base-color-grey-15);height:calc(3 * var(--eui-base-spacing-m))}.eui-table tbody tr.eui-table__row--selected,.eui-table tbody tr.eui-table__row--selected td{background-color:var(--eui-table-selected-row-background-color)!important}.eui-table tbody tr:not(.eui-table-expandable-row):nth-child(odd){background-color:var(--eui-base-color-grey-2)}.eui-table tbody tr:not(.eui-table-expandable-row):nth-child(odd) td{background-color:var(--eui-base-color-grey-2)}.eui-table tbody tr td{padding:var(--eui-base-spacing-xs) var(--eui-base-spacing-s);vertical-align:middle}.eui-table tbody tr td.eui-table__cell-select{color:var(--eui-base-color-grey-75);width:auto}.eui-table tbody tr td.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table tbody tr:nth-of-type(odd){background-color:var(--eui-base-color-white)}.eui-table tbody tr:nth-of-type(2n){background-color:var(--eui-base-color-grey-5)}.eui-table tbody tr:nth-of-type(2n) td{background-color:var(--eui-base-color-grey-5)}.eui-table tfoot tr{border-bottom:1px solid var(--eui-base-color-grey-15);border-top:1px solid var(--eui-base-color-grey-15)}.eui-table tfoot tr td{padding:var(--eui-base-spacing-s);vertical-align:middle}.eui-table__sticky-container{overflow:auto}.eui-table__sticky-container::-webkit-scrollbar{display:inherit;height:8px;width:8px;background-color:var(--eui-base-color-grey-5)}.eui-table__sticky-container::-webkit-scrollbar-thumb{background-color:var(--eui-base-color-grey-20);border-radius:5rem}.eui-table__sticky-container::-webkit-scrollbar-thumb:hover{background-color:var(--eui-base-color-grey-50)}.eui-table__sticky-container::-webkit-scrollbar-track{background-color:var(--eui-base-color-grey-5);border-radius:0}.eui-table--sticky-header thead tr th{position:sticky;top:0;z-index:8}.eui-table--sticky-columns .eui-table__col--sticky{position:sticky}.eui-table--sticky-columns th.eui-table__col--sticky{z-index:9}.eui-table--sticky-columns th.eui-table__col--sticky.eui-table__col--sticky-shadowed-first{box-shadow:inset -5px 0 8px -8px #0003}.eui-table--sticky-columns th.eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:inset 5px 0 8px -8px #0003}.eui-table--sticky-columns td.eui-table__col--sticky{z-index:8}.eui-table--sticky-columns td.eui-table__col--sticky.eui-table__col--sticky-shadowed-first{box-shadow:inset -5px 0 8px -8px #0003}.eui-table--sticky-columns td.eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:inset 5px 0 8px -8px #0003}@media screen and (max-width: 767px){.eui-table:not(.eui-table-cards).eui-table--responsive{width:100%!important}.eui-table:not(.eui-table-cards).eui-table--responsive thead,.eui-table:not(.eui-table-cards).eui-table--responsive tbody,.eui-table:not(.eui-table-cards).eui-table--responsive tfoot,.eui-table:not(.eui-table-cards).eui-table--responsive th,.eui-table:not(.eui-table-cards).eui-table--responsive td,.eui-table:not(.eui-table-cards).eui-table--responsive tr{display:block}.eui-table:not(.eui-table-cards).eui-table--responsive thead tr{left:-9999px;position:absolute;top:-9999px}.eui-table:not(.eui-table-cards).eui-table--responsive tr{height:auto}.eui-table:not(.eui-table-cards).eui-table--responsive td{border:none;border-bottom:1px solid var(--eui-base-color-grey-10);padding-left:50%;position:relative;text-align:left!important}.eui-table:not(.eui-table-cards).eui-table--responsive td:before{color:var(--eui-base-color-grey-80);content:attr(data-col-label);left:var(--eui-base-spacing-xs);padding-right:var(--eui-base-spacing-xs);position:absolute;width:45%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font:normal normal 400 1rem/1.25rem var(--eui-base-font-family);font-weight:700}.eui-table:not(.eui-table-cards) .actionsColumn,.eui-table:not(.eui-table-cards) .actions-column{justify-content:flex-start;text-align:left;width:100%}.eui-table__sticky-container{height:auto!important;width:auto!important}.eui-table--sticky-columns th,.eui-table--sticky-columns td,.eui-table--sticky-columns th .eui-table__col--sticky,.eui-table--sticky-columns td .eui-table__col--sticky{width:auto;z-index:auto}.eui-table--sticky-columns th .eui-table__col--sticky.eui-table__col--sticky-shadowed-first,.eui-table--sticky-columns th .eui-table__col--sticky.eui-table__col--sticky-shadowed-last,.eui-table--sticky-columns td .eui-table__col--sticky.eui-table__col--sticky-shadowed-first,.eui-table--sticky-columns td .eui-table__col--sticky.eui-table__col--sticky-shadowed-last{box-shadow:none!important}.eui-table--sticky-columns tfoot tr td:empty{display:none!important}}.eui-table__filter{align-items:center;display:flex;justify-content:flex-end;position:relative}.eui-table__filter--responsive{width:100%}.eui-table__filter-input{padding-left:var(--eui-base-spacing-2xl)!important}.eui-table__filter-search-icon{left:var(--eui-base-spacing-xs);position:absolute;top:calc(var(--eui-base-spacing-xs) + 2px)}@media screen and (max-width: 767px){.eui-table__filter--responsive{display:block;width:100%}}.eui-table__draggable-preview--no-preview.cdk-drag-preview{display:none}.eui-table--draggable tr.eui-table__draggable-preview--no-placeholder{opacity:1}.eui-table--draggable tr:hover{background-color:var(--eui-base-color-accent-5)}.eui-table--draggable td .cdk-drop-list{flex-direction:column}.eui-table-cards{background-color:transparent;display:flex;flex-direction:column;overflow:hidden;width:100%}.eui-table-cards thead{width:100%}.eui-table-cards thead tr{align-items:center;height:auto}.eui-table-cards thead tr th{position:relative;vertical-align:middle;width:100%}.eui-table-cards thead tr th.eui-table__cell-select{padding:var(--eui-base-spacing-s) var(--eui-base-spacing-m);width:auto}.eui-table-cards thead tr th.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table-cards tbody{width:100%}.eui-table-cards tbody tr{align-items:center;border-top:0;display:flex;height:auto;width:100%}.eui-table-cards tbody tr.eui-table__row--selected .eui-card:first-child{--eui-card-header-background-color: var(--eui-table-selected-row-background-color)}.eui-table-cards tbody tr td{position:relative;vertical-align:middle;width:100%}.eui-table-cards tbody tr td.eui-table__cell-select{padding:var(--eui-base-spacing-s) var(--eui-base-spacing-m);width:auto}.eui-table-cards tbody tr td.eui-table__cell-select .eui-table__cell-select-checkbox-container{display:flex}.eui-table-cards tbody tr:hover{background-color:transparent}.eui-table-cards tbody tr:not(.eui-table-expandable-row):nth-child(odd){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(2n){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(2n):hover:not(.eui-table__row--selected){background-color:transparent}.eui-table-cards tbody tr:nth-of-type(odd):hover:not(.eui-table__row--selected){background-color:transparent}\n"] }]
|
598
598
|
}], ctorParameters: () => [{ type: i1.EuiTableSortService }, { type: i0.ChangeDetectorRef }, { type: i2.EuiTableSelectableRowService }, { type: i0.ElementRef }], propDecorators: { rows: [{
|
599
599
|
type: Input
|
600
600
|
}], propId: [{
|