@eui/components 18.0.1-snapshot-1718044857495 → 18.0.1-snapshot-1718110610951

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/docs/classes/CustomNodeSelectFnHelper.html +556 -0
  2. package/docs/components/EuiMenuComponent.html +1 -1
  3. package/docs/components/EuiNotificationsComponent.html +1 -1
  4. package/docs/components/EuiTreeComponent.html +19 -0
  5. package/docs/components/EuiUserProfileCardComponent.html +3 -3
  6. package/docs/dependencies.html +10 -10
  7. package/docs/directives/EuiTreeFormControlDirective.html +1 -1
  8. package/docs/index.html +1 -1
  9. package/docs/interfaces/UserProfile.html +92 -2
  10. package/docs/js/menu-wc.js +9 -6
  11. package/docs/js/menu-wc_es5.js +1 -1
  12. package/docs/js/search/search_index.js +2 -2
  13. package/docs/miscellaneous/typealiases.html +67 -48
  14. package/esm2022/eui-menu/eui-menu.component.mjs +3 -3
  15. package/esm2022/eui-tree/eui-tree-form-control.directive.mjs +2 -2
  16. package/esm2022/eui-tree/eui-tree.component.mjs +46 -24
  17. package/esm2022/eui-tree/eui-tree.model.mjs +20 -1
  18. package/esm2022/eui-user-profile/user-profile-card/user-profile-card.component.mjs +1 -1
  19. package/esm2022/eui-user-profile/user-profile.component.mjs +1 -1
  20. package/esm2022/layout/eui-notifications/eui-notifications.component.mjs +3 -3
  21. package/eui-tree/eui-tree.component.d.ts +5 -2
  22. package/eui-tree/eui-tree.component.d.ts.map +1 -1
  23. package/eui-tree/eui-tree.model.d.ts +9 -0
  24. package/eui-tree/eui-tree.model.d.ts.map +1 -1
  25. package/eui-user-profile/user-profile-card/user-profile-card.component.d.ts +3 -3
  26. package/eui-user-profile/user-profile-card/user-profile-card.component.d.ts.map +1 -1
  27. package/eui-user-profile/user-profile.component.d.ts +5 -1
  28. package/eui-user-profile/user-profile.component.d.ts.map +1 -1
  29. package/fesm2022/eui-components-eui-menu.mjs +2 -2
  30. package/fesm2022/eui-components-eui-menu.mjs.map +1 -1
  31. package/fesm2022/eui-components-eui-tree.mjs +65 -24
  32. package/fesm2022/eui-components-eui-tree.mjs.map +1 -1
  33. package/fesm2022/eui-components-eui-user-profile.mjs.map +1 -1
  34. package/fesm2022/eui-components-layout.mjs +2 -2
  35. package/fesm2022/eui-components-layout.mjs.map +1 -1
  36. package/package.json +3 -3
@@ -72,4 +72,23 @@ export class EuiTreePagination {
72
72
  };
73
73
  }
74
74
  }
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-tree.model.js","sourceRoot":"","sources":["../../../eui-tree/eui-tree.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { UxLinkLegacy } from '@eui/core';\n\nexport type TreeDataModel = Array<TreeItemModel>;\n\nexport type TreeItemModel = {\n    node: TreeNode;\n    children?: TreeDataModel;\n};\n\nexport type TreeNode = {\n    // metadata can be block content, or any\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    treeContentBlock: EuiTreeContentBlockModel | any;\n} & SelectionModel &\n    ExpandModel;\n\nexport interface EuiTreeContentBlockModel {\n    id?: string | number;\n    label: string;\n    tooltipLabel: string;\n    url: string;\n    urlExternal: string;\n    urlExternalTarget: string;\n    typeLabel: string;\n    typeClass: string;\n    chips?: Array<{ label: string; typeClass?: string; isOutline?: boolean }>;\n    iconClass: string;\n    iconTypeClass: string;\n    iconSvgName?: string;\n    rightContent?: {\n        iconClass: string;\n        iconTypeClass: string;\n        iconSvgName?: string;\n        badges?: Array<{ label: string; typeClass: string }>;\n        chips?: Array<{ label: string; typeClass?: string; isOutline?: boolean }>;\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        contextMenuMetaData?: any;\n    };\n    metaData: string;\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    [key: string]: any;\n}\n\nexport type SelectionModel = {\n    selectable?: boolean;\n    isSelected?: boolean;\n    // if one of sub is selected, it becomes intermediate\n    isIndeterminate?: boolean;\n    selectConfig?: SelectConfigModel;\n};\n\nexport interface SelectConfigModel extends MultiSelectionLogic, SingleSelectionLogic {\n    /*\n    If It is true;\n    When user select parent, all the children will be selected\n    When selection state is changed, If all children is selected parent will be selected as long as noAutoSelectParent is not true\n    */\n    recursive?: boolean;\n    /* when It is true, If all children is selected, parent will not be selected, while recursive is true*/\n    noAutoSelectParent?: boolean;\n    singleSelect?: boolean;\n}\n\nexport interface MultiSelectionLogic {\n    /*\n    If It is true;\n    When user select parent, all the children will be selected\n    When selection state is changed, If all children is selected parent will be selected as long as noAutoSelectParent is not true\n    */\n    recursive?: boolean;\n    /* when It is true, If all children is selected, parent will not be selected, while recursive is true*/\n    noAutoSelectParent?: boolean;\n}\n\nexport interface SingleSelectionLogic {\n    singleSelect?: boolean;\n}\n\nexport type ExpandModel = {\n    isExpanded?: boolean;\n};\n\nexport type EuiTreeSelectionChanges = { added: TreeDataModel; removed: TreeDataModel; selection: TreeDataModel };\n\nexport type TreeDataRunTimeModel = Array<TreeItemRunTimeModel>;\n\nexport type TreeItemRunTimeModel = { index: number; path: string; children?: Array<TreeItemRunTimeModel>; last?: boolean, matched?: boolean };\n\nexport type TreeItemSelectionRecursiveModel = {\n    selectionRecursiveState: SelectionRecursiveState;\n    children?: Array<TreeItemSelectionRecursiveModel>;\n};\n\nexport type SelectionRecursiveState = 'indeterminate' | 'allSelected' | 'allNotSelected';\n\n// eslint-disable-next-line prefer-arrow/prefer-arrow-functions\nexport function uxTreeNodesMetaDataMapper(oldTree: Array<UxLinkLegacy>): TreeDataModel {\n    return oldTree.map((item) => {\n        if (item?.typeClass === 'default') {\n            // default typeClass will be\n            item.typeClass = 'secondary';\n        }\n        if (item?.badgeLabel) {\n            // default typeClass will be\n            if (item?.badges?.length > 0) {\n                item.badges.push({ label: item?.badgeLabel, typeClass: 'secondary' });\n            } else {\n                item.badges = [{ label: item?.badgeLabel, typeClass: 'secondary' }];\n            }\n        }\n        return {\n            node: {\n                treeContentBlock: {\n                    label: item.label,\n                    typeLabel: item.typeLabel,\n                    typeClass: item.typeLabel && !item.typeClass ? 'secondary' : item.typeClass,\n                    tooltipLabel: item.tooltipLabel,\n                    url: item.url,\n                    urlExternal: item.urlExternal,\n                    urlExternalTarget: item.urlExternal && item.urlExternalTarget ? item.urlExternalTarget : undefined,\n                    badges: item.badges,\n                    metadata: item.metadata,\n                },\n            },\n            children: item.children ? uxTreeNodesMetaDataMapper(item.children) : undefined,\n        };\n    });\n}\n\nexport class EuiTreePagination<T> {\n    private data: T[];\n    private startPage: number;\n    private totalItems: number;\n    private renderedPageCount: number;\n    private perPage: number;\n    private totalPages: number;\n\n    constructor(data: T[], startPage: number, renderedPageCount: number, perPage: number) {\n        this.data = data;\n        this.setCurrentStartPage(startPage);\n        this.renderedPageCount = renderedPageCount;\n        this.totalItems = this.data.length;\n        this.perPage = perPage;\n        this.totalPages = Math.ceil(this.totalItems / this.perPage);\n    }\n\n    public paginateNext(): { startPage: number; data: T[] } {\n        if (this.startPage < this.totalPages) {\n            this.startPage += 1;\n        }\n        return this.getViewData();\n    }\n\n    public paginatePrev(): { startPage: number; data: T[] } {\n        if (this.startPage > 1) {\n            this.startPage -= 1;\n        }\n        return this.getViewData();\n    }\n\n    public getCurrentStartPage(): number {\n        return this.startPage;\n    }\n\n    public setCurrentStartPage(startPage: number): void {\n        this.startPage = startPage;\n    }\n\n    public isAtMax(): boolean {\n        return this.totalPages < this.startPage + this.renderedPageCount;\n    }\n\n    public getViewData(): { startPage: number; data: T[] } {\n        const startIndex = (this.startPage - 1) * this.perPage;\n        const endIndex = startIndex + this.perPage * this.renderedPageCount;\n        const pageData = structuredClone(this.data).slice(startIndex, endIndex);\n        return {\n            startPage: this.startPage,\n            data: pageData,\n        };\n    }\n}\n"]}
75
+ export class CustomNodeSelectFnHelper {
76
+ // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
77
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
78
+ constructor(compInstance) {
79
+ this.compInstance = compInstance;
80
+ }
81
+ select(path, isChecked) {
82
+ this.compInstance.silentSelect(path, isChecked);
83
+ }
84
+ getParents(path) {
85
+ return this.compInstance.getParentPaths(path);
86
+ }
87
+ getTreeItem(path) {
88
+ return this.compInstance.getTreeItem(path);
89
+ }
90
+ getSelectionRecursiveState(path) {
91
+ return this.compInstance.getRunTimeSelectionRecursiveState(path);
92
+ }
93
+ }
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-tree.model.js","sourceRoot":"","sources":["../../../eui-tree/eui-tree.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { UxLinkLegacy } from '@eui/core';\n\nexport type TreeDataModel = Array<TreeItemModel>;\n\nexport type TreeItemModel = {\n    node: TreeNode;\n    children?: TreeDataModel;\n};\n\nexport type TreeNode = {\n    // metadata can be block content, or any\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    treeContentBlock: EuiTreeContentBlockModel | any;\n} & SelectionModel &\n    ExpandModel;\n\nexport interface EuiTreeContentBlockModel {\n    id?: string | number;\n    label: string;\n    tooltipLabel: string;\n    url: string;\n    urlExternal: string;\n    urlExternalTarget: string;\n    typeLabel: string;\n    typeClass: string;\n    chips?: Array<{ label: string; typeClass?: string; isOutline?: boolean }>;\n    iconClass: string;\n    iconTypeClass: string;\n    iconSvgName?: string;\n    rightContent?: {\n        iconClass: string;\n        iconTypeClass: string;\n        iconSvgName?: string;\n        badges?: Array<{ label: string; typeClass: string }>;\n        chips?: Array<{ label: string; typeClass?: string; isOutline?: boolean }>;\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        contextMenuMetaData?: any;\n    };\n    metaData: string;\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    [key: string]: any;\n}\n\nexport type SelectionModel = {\n    selectable?: boolean;\n    isSelected?: boolean;\n    // if one of sub is selected, it becomes intermediate\n    isIndeterminate?: boolean;\n    selectConfig?: SelectConfigModel;\n};\n\nexport interface SelectConfigModel extends MultiSelectionLogic, SingleSelectionLogic {\n    /*\n    If It is true;\n    When user select parent, all the children will be selected\n    When selection state is changed, If all children is selected parent will be selected as long as noAutoSelectParent is not true\n    */\n    recursive?: boolean;\n    /* when It is true, If all children is selected, parent will not be selected, while recursive is true*/\n    noAutoSelectParent?: boolean;\n    singleSelect?: boolean;\n}\n\nexport interface MultiSelectionLogic {\n    /*\n    If It is true;\n    When user select parent, all the children will be selected\n    When selection state is changed, If all children is selected parent will be selected as long as noAutoSelectParent is not true\n    */\n    recursive?: boolean;\n    /* when It is true, If all children is selected, parent will not be selected, while recursive is true*/\n    noAutoSelectParent?: boolean;\n}\n\nexport interface SingleSelectionLogic {\n    singleSelect?: boolean;\n}\n\nexport type ExpandModel = {\n    isExpanded?: boolean;\n};\n\nexport type EuiTreeSelectionChanges = { added: TreeDataModel; removed: TreeDataModel; selection: TreeDataModel };\n\nexport type TreeDataRunTimeModel = Array<TreeItemRunTimeModel>;\n\nexport type TreeItemRunTimeModel = { index: number; path: string; children?: Array<TreeItemRunTimeModel>; last?: boolean, matched?: boolean };\n\nexport type TreeItemSelectionRecursiveModel = {\n    selectionRecursiveState: SelectionRecursiveState;\n    children?: Array<TreeItemSelectionRecursiveModel>;\n};\n\nexport type SelectionRecursiveState = 'indeterminate' | 'allSelected' | 'allNotSelected';\n\n// eslint-disable-next-line prefer-arrow/prefer-arrow-functions\nexport function uxTreeNodesMetaDataMapper(oldTree: Array<UxLinkLegacy>): TreeDataModel {\n    return oldTree.map((item) => {\n        if (item?.typeClass === 'default') {\n            // default typeClass will be\n            item.typeClass = 'secondary';\n        }\n        if (item?.badgeLabel) {\n            // default typeClass will be\n            if (item?.badges?.length > 0) {\n                item.badges.push({ label: item?.badgeLabel, typeClass: 'secondary' });\n            } else {\n                item.badges = [{ label: item?.badgeLabel, typeClass: 'secondary' }];\n            }\n        }\n        return {\n            node: {\n                treeContentBlock: {\n                    label: item.label,\n                    typeLabel: item.typeLabel,\n                    typeClass: item.typeLabel && !item.typeClass ? 'secondary' : item.typeClass,\n                    tooltipLabel: item.tooltipLabel,\n                    url: item.url,\n                    urlExternal: item.urlExternal,\n                    urlExternalTarget: item.urlExternal && item.urlExternalTarget ? item.urlExternalTarget : undefined,\n                    badges: item.badges,\n                    metadata: item.metadata,\n                },\n            },\n            children: item.children ? uxTreeNodesMetaDataMapper(item.children) : undefined,\n        };\n    });\n}\n\nexport class EuiTreePagination<T> {\n    private data: T[];\n    private startPage: number;\n    private totalItems: number;\n    private renderedPageCount: number;\n    private perPage: number;\n    private totalPages: number;\n\n    constructor(data: T[], startPage: number, renderedPageCount: number, perPage: number) {\n        this.data = data;\n        this.setCurrentStartPage(startPage);\n        this.renderedPageCount = renderedPageCount;\n        this.totalItems = this.data.length;\n        this.perPage = perPage;\n        this.totalPages = Math.ceil(this.totalItems / this.perPage);\n    }\n\n    public paginateNext(): { startPage: number; data: T[] } {\n        if (this.startPage < this.totalPages) {\n            this.startPage += 1;\n        }\n        return this.getViewData();\n    }\n\n    public paginatePrev(): { startPage: number; data: T[] } {\n        if (this.startPage > 1) {\n            this.startPage -= 1;\n        }\n        return this.getViewData();\n    }\n\n    public getCurrentStartPage(): number {\n        return this.startPage;\n    }\n\n    public setCurrentStartPage(startPage: number): void {\n        this.startPage = startPage;\n    }\n\n    public isAtMax(): boolean {\n        return this.totalPages < this.startPage + this.renderedPageCount;\n    }\n\n    public getViewData(): { startPage: number; data: T[] } {\n        const startIndex = (this.startPage - 1) * this.perPage;\n        const endIndex = startIndex + this.perPage * this.renderedPageCount;\n        const pageData = structuredClone(this.data).slice(startIndex, endIndex);\n        return {\n            startPage: this.startPage,\n            data: pageData,\n        };\n    }\n}\n\nexport class CustomNodeSelectFnHelper{\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    constructor(private compInstance: any) {\n    }\n\n    select(path: string, isChecked: boolean): void{\n        this.compInstance.silentSelect(path, isChecked);\n    }\n\n    getParents(path: string): Array<string>{\n        return this.compInstance.getParentPaths(path);\n    }\n\n    getTreeItem(path: string): TreeItemModel{\n        return this.compInstance.getTreeItem(path);\n    }\n\n    getSelectionRecursiveState(path: string): TreeItemSelectionRecursiveModel{\n        return this.compInstance.getRunTimeSelectionRecursiveState(path);\n    }\n\n}\n\nexport type CustomNodeSelectFn = (path: string, isChecked:boolean, treeItem: TreeItemModel, helper: CustomNodeSelectFnHelper) => void;\n"]}
@@ -68,4 +68,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
68
68
  }], closeProfileMenu: [{
69
69
  type: Output
70
70
  }] } });
71
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-profile-card.component.js","sourceRoot":"","sources":["../../../../eui-user-profile/user-profile-card/user-profile-card.component.ts","../../../../eui-user-profile/user-profile-card/user-profile-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,KAAK,EAAU,YAAY,EAAE,MAAM,EAAa,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAGrK,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;;;;;;;AAQ/B,MAAM,OAAO,2BAA2B;IACpC,IACW,UAAU;QACjB,OAAO,uBAAuB,CAAC;IACnC,CAAC;IAgBD,YACY,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;QAbpC,aAAQ,GAAG,IAAI,CAAC;QAEP,qBAAgB,GAAG,eAAe,CAAC;QACnC,qBAAgB,GAAG,sBAAsB,CAAC;QAEX,yBAAoB,GAAG,KAAK,CAAC;QAE3D,oBAAe,GAAuB,IAAI,YAAY,EAAE,CAAC;QACzD,qBAAgB,GAAuB,IAAI,YAAY,EAAE,CAAC;QAE5D,wBAAmB,GAAkB,IAAI,OAAO,EAAE,CAAC;IAIxD,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,WAAW;aACX,QAAQ,EAAE;aACV,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CACtC;aACA,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACjB,IAAI,KAAK,EAAE,CAAC;gBACR,MAAM,gBAAgB,GAAG,KAAK,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBACxE,MAAM,eAAe,GAAG,KAAK,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBACtE,IAAI,CAAC,cAAc,GAAG,GAAG,gBAAgB,GAAG,eAAe,EAAE,CAAC;gBAC9D,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YAC3B,CAAC;QACL,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC;QAChC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,CAAC;IACxC,CAAC;IAED,eAAe;QACX,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;IAED,OAAO;QACH,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;IACjC,CAAC;8GAnDQ,2BAA2B;kGAA3B,2BAA2B,0NAahB,gBAAgB,0KCzBxC,u6DAsCA;;2FD1Ba,2BAA2B;kBANvC,SAAS;+BACI,uBAAuB,mBAEhB,uBAAuB,CAAC,OAAO,iBACjC,iBAAiB,CAAC,IAAI;gFAI1B,UAAU;sBADpB,WAAW;uBAAC,OAAO;gBASX,gBAAgB;sBAAxB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACkC,oBAAoB;sBAA3D,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAE5B,eAAe;sBAAxB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM","sourcesContent":["import { Component, HostBinding, ChangeDetectionStrategy, ViewEncapsulation, Input, OnInit, EventEmitter, Output, OnDestroy, booleanAttribute } from '@angular/core';\nimport { UserState } from '@eui/core';\nimport { UserService } from '@eui/core';\nimport { takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\n@Component({\n    selector: 'eui-user-profile-card',\n    templateUrl: './user-profile-card.component.html',\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiUserProfileCardComponent implements OnInit, OnDestroy {\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return 'eui-user-profile-card';\n    }\n\n    avatarInitials: string;\n    userState: UserState;\n    isOnline = true;\n\n    @Input() impersonateLabel = 'impersonating';\n    @Input() showDetailsLabel = 'Show profile details';\n    @Input() avatarUrl: string;\n    @Input({ transform: booleanAttribute }) isShowAvatarInitials = false;\n\n    @Output() showProfileInfo: EventEmitter<void> = new EventEmitter();\n    @Output() closeProfileMenu: EventEmitter<void> = new EventEmitter();\n\n    private unsubscribeSubject$: Subject<void> = new Subject();\n\n    constructor(\n        private userService: UserService,\n    ) {}\n\n    ngOnInit(): void {\n        this.userService\n            .getState()\n            .pipe(\n                takeUntil(this.unsubscribeSubject$),\n            )\n            .subscribe((state) => {\n                if (state) {\n                    const firstNameInitial = state.firstName?.substring(0, 1).toUpperCase();\n                    const lastNameInitial = state.lastName?.substring(0, 1).toUpperCase();\n                    this.avatarInitials = `${firstNameInitial}${lastNameInitial}`;\n                    this.userState = state;\n                }\n            });\n    }\n\n    ngOnDestroy(): void {\n        this.unsubscribeSubject$.next();\n        this.unsubscribeSubject$.complete();\n    }\n\n    onShowInfoClick(): void {\n        this.showProfileInfo.emit();\n    }\n\n    onClose(): void {\n        this.closeProfileMenu.emit();\n    }\n}\n","<div class=\"eui-user-profile-card__main-wrapper\">\n    <div class=\"eui-user-profile-card__avatar-wrapper\">\n        <eui-avatar euiSizeL isFlat>\n            <eui-avatar-text *ngIf=\"isShowAvatarInitials; else noAvatarInitials\">\n                {{ avatarInitials }}\n            </eui-avatar-text>\n            <ng-template #noAvatarInitials>\n                <eui-avatar-image *ngIf=\"!avatarUrl\"></eui-avatar-image>\n                <eui-avatar-image *ngIf=\"avatarUrl\" [imageUrl]=\"avatarUrl\"></eui-avatar-image>\n            </ng-template>\n        </eui-avatar>\n    </div>\n    <div class=\"eui-user-profile-card__userInfos\">\n        <div class=\"eui-u-f-xl eui-u-mb-s\">{{ userState.fullName }}</div>\n        <div *ngIf=\"userState.function\" class=\"eui-user-profile-card__userInfos-item\">\n            {{ userState.function }}\n        </div>\n        <div *ngIf=\"userState.organisation && userState.organisation.code\" class=\"eui-user-profile-card__userInfos-item\">\n            {{ userState.organisation.code }}\n        </div>\n    </div>\n    <div class=\"eui-user-profile-card__main-wrapper-right-content\">\n        <eui-icon-button icon=\"close:outline\" size=\"s\" euiRounded (buttonClick)=\"onClose()\"/>\n        <button euiButton euiIconButton euiInfo euiSizeS class=\"eui-u-ml-auto eui-u-mt-m\" tabindex=\"0\" (click)=\"onShowInfoClick()\" title=\"{{ showDetailsLabel }}\">\n            <eui-icon-svg icon=\"information:outline\"></eui-icon-svg>\n        </button>\n    </div>\n</div>\n\n<ng-container *ngIf=\"userState?.impersonatingUser\">\n    <div class=\"eui-user-profile-card__impersonateInfos\">\n        <div>{{ userState?.impersonatingUser?.firstName }} {{ userState?.impersonatingUser?.lastName }}</div>\n        <div class=\"eui-u-mt-2xs\">{{ impersonateLabel }}</div>\n        <div class=\"eui-u-mt-2xs\">\n            <strong>{{ userState?.fullName }}</strong>\n        </div>\n    </div>\n</ng-container>\n"]}
71
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-profile-card.component.js","sourceRoot":"","sources":["../../../../eui-user-profile/user-profile-card/user-profile-card.component.ts","../../../../eui-user-profile/user-profile-card/user-profile-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,KAAK,EAAU,YAAY,EAAE,MAAM,EAAa,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAGrK,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;;;;;;;AAQ/B,MAAM,OAAO,2BAA2B;IACpC,IACW,UAAU;QACjB,OAAO,uBAAuB,CAAC;IACnC,CAAC;IAgBD,YACY,WAAqC;QAArC,gBAAW,GAAX,WAAW,CAA0B;QAbjD,aAAQ,GAAG,IAAI,CAAC;QAEP,qBAAgB,GAAG,eAAe,CAAC;QACnC,qBAAgB,GAAG,sBAAsB,CAAC;QAEX,yBAAoB,GAAG,KAAK,CAAC;QAE3D,oBAAe,GAAuB,IAAI,YAAY,EAAE,CAAC;QACzD,qBAAgB,GAAuB,IAAI,YAAY,EAAE,CAAC;QAE5D,wBAAmB,GAAkB,IAAI,OAAO,EAAE,CAAC;IAIxD,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,WAAW;aACX,QAAQ,EAAE;aACV,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CACtC;aACA,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACjB,IAAI,KAAK,EAAE,CAAC;gBACR,MAAM,gBAAgB,GAAG,KAAK,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBACxE,MAAM,eAAe,GAAG,KAAK,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBACtE,IAAI,CAAC,cAAc,GAAG,GAAG,gBAAgB,GAAG,eAAe,EAAE,CAAC;gBAC9D,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YAC3B,CAAC;QACL,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC;QAChC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,CAAC;IACxC,CAAC;IAED,eAAe;QACX,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IAChC,CAAC;IAED,OAAO;QACH,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;IACjC,CAAC;8GAnDQ,2BAA2B;kGAA3B,2BAA2B,0NAahB,gBAAgB,0KCzBxC,u6DAsCA;;2FD1Ba,2BAA2B;kBANvC,SAAS;+BACI,uBAAuB,mBAEhB,uBAAuB,CAAC,OAAO,iBACjC,iBAAiB,CAAC,IAAI;gFAI1B,UAAU;sBADpB,WAAW;uBAAC,OAAO;gBASX,gBAAgB;sBAAxB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACkC,oBAAoB;sBAA3D,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAE5B,eAAe;sBAAxB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM","sourcesContent":["import { Component, HostBinding, ChangeDetectionStrategy, ViewEncapsulation, Input, OnInit, EventEmitter, Output, OnDestroy, booleanAttribute } from '@angular/core';\nimport { UserProfile } from '../user-profile.component';\nimport { UserService } from '@eui/core';\nimport { takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\n@Component({\n    selector: 'eui-user-profile-card',\n    templateUrl: './user-profile-card.component.html',\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiUserProfileCardComponent implements OnInit, OnDestroy {\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return 'eui-user-profile-card';\n    }\n\n    avatarInitials: string;\n    userState: UserProfile;\n    isOnline = true;\n\n    @Input() impersonateLabel = 'impersonating';\n    @Input() showDetailsLabel = 'Show profile details';\n    @Input() avatarUrl: string;\n    @Input({ transform: booleanAttribute }) isShowAvatarInitials = false;\n\n    @Output() showProfileInfo: EventEmitter<void> = new EventEmitter();\n    @Output() closeProfileMenu: EventEmitter<void> = new EventEmitter();\n\n    private unsubscribeSubject$: Subject<void> = new Subject();\n\n    constructor(\n        private userService: UserService<UserProfile>,\n    ) {}\n\n    ngOnInit(): void {\n        this.userService\n            .getState()\n            .pipe(\n                takeUntil(this.unsubscribeSubject$),\n            )\n            .subscribe((state) => {\n                if (state) {\n                    const firstNameInitial = state.firstName?.substring(0, 1).toUpperCase();\n                    const lastNameInitial = state.lastName?.substring(0, 1).toUpperCase();\n                    this.avatarInitials = `${firstNameInitial}${lastNameInitial}`;\n                    this.userState = state;\n                }\n            });\n    }\n\n    ngOnDestroy(): void {\n        this.unsubscribeSubject$.next();\n        this.unsubscribeSubject$.complete();\n    }\n\n    onShowInfoClick(): void {\n        this.showProfileInfo.emit();\n    }\n\n    onClose(): void {\n        this.closeProfileMenu.emit();\n    }\n}\n","<div class=\"eui-user-profile-card__main-wrapper\">\n    <div class=\"eui-user-profile-card__avatar-wrapper\">\n        <eui-avatar euiSizeL isFlat>\n            <eui-avatar-text *ngIf=\"isShowAvatarInitials; else noAvatarInitials\">\n                {{ avatarInitials }}\n            </eui-avatar-text>\n            <ng-template #noAvatarInitials>\n                <eui-avatar-image *ngIf=\"!avatarUrl\"></eui-avatar-image>\n                <eui-avatar-image *ngIf=\"avatarUrl\" [imageUrl]=\"avatarUrl\"></eui-avatar-image>\n            </ng-template>\n        </eui-avatar>\n    </div>\n    <div class=\"eui-user-profile-card__userInfos\">\n        <div class=\"eui-u-f-xl eui-u-mb-s\">{{ userState.fullName }}</div>\n        <div *ngIf=\"userState.function\" class=\"eui-user-profile-card__userInfos-item\">\n            {{ userState.function }}\n        </div>\n        <div *ngIf=\"userState.organisation && userState.organisation.code\" class=\"eui-user-profile-card__userInfos-item\">\n            {{ userState.organisation.code }}\n        </div>\n    </div>\n    <div class=\"eui-user-profile-card__main-wrapper-right-content\">\n        <eui-icon-button icon=\"close:outline\" size=\"s\" euiRounded (buttonClick)=\"onClose()\"/>\n        <button euiButton euiIconButton euiInfo euiSizeS class=\"eui-u-ml-auto eui-u-mt-m\" tabindex=\"0\" (click)=\"onShowInfoClick()\" title=\"{{ showDetailsLabel }}\">\n            <eui-icon-svg icon=\"information:outline\"></eui-icon-svg>\n        </button>\n    </div>\n</div>\n\n<ng-container *ngIf=\"userState?.impersonatingUser\">\n    <div class=\"eui-user-profile-card__impersonateInfos\">\n        <div>{{ userState?.impersonatingUser?.firstName }} {{ userState?.impersonatingUser?.lastName }}</div>\n        <div class=\"eui-u-mt-2xs\">{{ impersonateLabel }}</div>\n        <div class=\"eui-u-mt-2xs\">\n            <strong>{{ userState?.fullName }}</strong>\n        </div>\n    </div>\n</ng-container>\n"]}
@@ -158,4 +158,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
158
158
  type: ContentChildren,
159
159
  args: [forwardRef(() => EuiUserProfileMenuComponent), { descendants: true }]
160
160
  }] } });
161
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-profile.component.js","sourceRoot":"","sources":["../../../eui-user-profile/user-profile.component.ts","../../../eui-user-profile/user-profile.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, ChangeDetectionStrategy, ViewEncapsulation, Input, OnInit, ViewChild, OnDestroy, Host, Optional, Inject, forwardRef, AfterContentInit, ContentChild, QueryList, AfterViewInit, ContentChildren, ElementRef, booleanAttribute, Renderer2 } from '@angular/core';\nimport { UserState } from '@eui/core';\nimport { UserService } from '@eui/core';\nimport { takeUntil } from 'rxjs/operators';\nimport { EuiDropdownComponent } from '@eui/components/eui-dropdown';\nimport { Subject } from 'rxjs';\nimport { BaseStatesDirective } from '@eui/components/shared';\nimport { EuiUserProfileMenuComponent } from './user-profile-menu/user-profile-menu.component';\n\nexport interface UserProfile extends UserState {\n    impersonatingUser?: UserState;\n}\n\n@Component({\n    selector: 'eui-user-profile',\n    templateUrl: './user-profile.component.html',\n    styleUrls: ['./_styles/_index.scss'],\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n            inputs: [\n                'euiSizeS',\n                'euiSecondary',\n                'euiPrimary',\n            ],\n        },\n    ],\n})\nexport class EuiUserProfileComponent implements OnInit, OnDestroy, AfterViewInit {\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [\n            this.baseStatesDirective.getCssClasses('eui-user-profile'),\n            this.isReverse ? 'eui-user-profile--reverse': '',\n            this.isShowAvatarInitials ? 'eui-user-profile--initials': '',\n        ].join(' ').trim();\n    }\n\n    userState: UserProfile;\n    isOnline = true;\n    avatarInitials: string;\n\n    @Input() welcomeLabel = 'Welcome';\n    @Input() impersonateLabel = 'impersonating';\n    @Input() avatarUrl: string;\n    @Input() subInfos: string;\n    @Input() statusVariant = 'success';\n\n    @Input({ transform: booleanAttribute }) hasMenu = false;\n    @Input({ transform: booleanAttribute }) hasWelcomeLabel = true;\n    @Input({ transform: booleanAttribute }) isShowAvatarInitials = false;\n    @Input({ transform: booleanAttribute }) hasTabNavigation = false;\n    @Input({ transform: booleanAttribute }) isReverse = false;\n    @Input({ transform: booleanAttribute }) hasToggle = false;\n    @Input({ transform: booleanAttribute }) isHeaderUserProfile = false;\n    @Input({ transform: booleanAttribute }) isShowUserInfos = true;\n\n    @Input({ transform: booleanAttribute }) euiStatusSecondary = false;\n    @Input({ transform: booleanAttribute }) euiStatusSuccess = false;\n    @Input({ transform: booleanAttribute }) euiStatusDanger = false;\n\n    @ViewChild('dropdown') dropdown: EuiDropdownComponent;\n    @ContentChildren(forwardRef(() => EuiUserProfileMenuComponent), { descendants: true })\n    hasMenuContent: QueryList<EuiUserProfileMenuComponent>;\n\n    isDropdownOpen = false;\n\n    private unsubscribeSubject$: Subject<void> = new Subject();\n\n    constructor(\n        private elRef: ElementRef,\n        private userService: UserService,\n        public baseStatesDirective: BaseStatesDirective,\n    ) {\n    }\n\n    ngOnInit(): void {\n        this.userService\n            .getState()\n            .pipe(takeUntil(this.unsubscribeSubject$))\n            .subscribe((state: UserProfile) => {\n                if (state) {\n                    this.userState = state;\n                    const firstNameInitial = state.firstName?.substring(0, 1).toUpperCase();\n                    const lastNameInitial = state.lastName?.substring(0, 1).toUpperCase();\n                    this.avatarInitials = `${firstNameInitial}${lastNameInitial}`;\n                }\n            });\n    }\n\n    ngAfterViewInit(): void {\n        let hasToolbarItemParent = false, toolbar;\n\n        try {\n            hasToolbarItemParent = this.elRef.nativeElement.closest('eui-toolbar-item');\n            toolbar = this.elRef.nativeElement.closest('eui-toolbar');\n        } catch(e) {\n           // do nothing\n        }\n\n        setTimeout(() => {\n            if (hasToolbarItemParent) {\n                this.baseStatesDirective.euiSizeS = true;\n                if (toolbar && toolbar.classList.contains('eui--secondary') || this.baseStatesDirective.euiSecondary) {\n                    console.log(toolbar);\n                    this.baseStatesDirective.euiSecondary = true;\n                } else {\n                    this.baseStatesDirective.euiPrimary = true;\n                }\n            }\n            if (hasToolbarItemParent || !this.isHeaderUserProfile) {\n                this.hasMenu = this.hasMenuContent.length !== 0;\n            }\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.unsubscribeSubject$.next();\n        this.unsubscribeSubject$.complete();\n    }\n\n    closeDropdown(): void {\n        this.dropdown.closeDropdown();\n        this.isDropdownOpen = false;\n    }\n\n    onDropdownExpand(isOpen: boolean): void {\n        this.isDropdownOpen = isOpen;\n    }\n}\n","@if (hasMenu) {\n    <eui-dropdown [hasTabNavigation]=\"hasTabNavigation\" width=\"340px\" #dropdown (expand)=\"onDropdownExpand($event)\">\n        <ng-container *ngTemplateOutlet=\"userProfileContent\"/>\n        <eui-dropdown-content>\n            <ng-content/>\n        </eui-dropdown-content>\n    </eui-dropdown>\n} @else {\n    <ng-container *ngTemplateOutlet=\"userProfileContent\"/>\n}\n\n<ng-template #userProfileContent>\n    <button class=\"eui-user-profile-content\" [tabindex]=\"hasMenu ? '0' : '-1'\" [class.eui-user-profile-content--no-menu]=\"!hasMenu\">\n\n        @if (isShowUserInfos) {\n            <div class=\"eui-user-profile__infos\">\n                @if (userState?.impersonatingUser) {\n                    <div class=\"eui-user-profile__infos-welcome\">\n                        @if (hasWelcomeLabel) {\n                            <span class=\"eui-u-mr-2xs\">{{ welcomeLabel }}</span>\n                        }\n                        {{ userState?.impersonatingUser?.firstName }} <strong>{{ userState?.impersonatingUser?.lastName}}</strong>\n                        <span class=\"eui-u-ml-2xs\">{{ impersonateLabel }}</span>\n                    </div>\n                    <div class=\"eui-user-profile__infos-name\">\n                        {{ userState?.firstName }} <strong>{{ userState?.lastName }}</strong>\n                    </div>\n                    @if (subInfos) {\n                        <div class=\"eui-user-profile__infos-subinfos\">{{ subInfos }}</div>\n                    }\n                } @else {\n                    @if (hasWelcomeLabel) {\n                        <div class=\"eui-user-profile__infos-welcome\">{{ welcomeLabel }}</div>\n                    }\n                    <div class=\"eui-user-profile__infos-name\">\n                        {{ userState?.firstName }} <strong>{{ userState?.lastName }}</strong>\n                    </div>\n                    @if (subInfos) {\n                        <div class=\"eui-user-profile__infos-subinfos\">{{ subInfos }}</div>\n                    }\n                }\n            </div>\n        }\n\n        <eui-avatar isFlat [euiSizeS]=\"baseStatesDirective.euiSizeS\" [hasShadow]=\"userState?.impersonatingUser\">\n\n            @if (isShowAvatarInitials) {\n                <eui-avatar-text>{{ avatarInitials }}</eui-avatar-text>\n            } @else {\n                <eui-avatar-image [imageUrl]=\"avatarUrl\"/>\n            }\n\n            @if (euiStatusSecondary || euiStatusSuccess || euiStatusDanger) {\n                <eui-avatar-badge position=\"bottom\">\n                    @if (euiStatusSuccess) {\n                        <eui-badge euiSuccess euiSizeS euiIconBadge>\n                            <eui-icon-svg icon=\"checkmark:outline\" size=\"xs\"/>\n                        </eui-badge>\n                    } @else if (euiStatusDanger) {\n                        <eui-badge euiDanger euiSizeS euiIconBadge>\n                            <eui-icon-svg icon=\"remove:outline\" size=\"xs\"/>\n                        </eui-badge>\n                    } @else if (euiStatusSecondary) {\n                        <eui-badge euiSecondary euiSizeS euiIconBadge>\n                            <eui-icon-svg icon=\"close-circle:outline\" fillColor=\"neutral\" size=\"xs\"/>\n                        </eui-badge>\n                    }\n                </eui-avatar-badge>\n            }\n        </eui-avatar>\n\n        @if (hasMenu || hasToggle) {\n            @if (isDropdownOpen) {\n                <eui-icon-svg icon=\"chevron-up:sharp\" size=\"s\" class=\"eui-user-profile__drop-indicator\"/>\n            } @else {\n                <eui-icon-svg icon=\"chevron-down:sharp\" size=\"s\" class=\"eui-user-profile__drop-indicator\"/>\n            }\n        }\n    </button>\n</ng-template>\n"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-profile.component.js","sourceRoot":"","sources":["../../../eui-user-profile/user-profile.component.ts","../../../eui-user-profile/user-profile.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, ChangeDetectionStrategy, ViewEncapsulation, Input, OnInit, ViewChild, OnDestroy, Host, Optional, Inject, forwardRef, AfterContentInit, ContentChild, QueryList, AfterViewInit, ContentChildren, ElementRef, booleanAttribute, Renderer2 } from '@angular/core';\nimport { UserState } from '@eui/core';\nimport { UserService } from '@eui/core';\nimport { takeUntil } from 'rxjs/operators';\nimport { EuiDropdownComponent } from '@eui/components/eui-dropdown';\nimport { Subject } from 'rxjs';\nimport { BaseStatesDirective } from '@eui/components/shared';\nimport { EuiUserProfileMenuComponent } from './user-profile-menu/user-profile-menu.component';\n\nexport interface UserProfile extends UserState {\n    impersonatingUser?: UserProfile;\n    function?: string;\n    organisation?: {\n        code: string\n    }\n}\n\n@Component({\n    selector: 'eui-user-profile',\n    templateUrl: './user-profile.component.html',\n    styleUrls: ['./_styles/_index.scss'],\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n            inputs: [\n                'euiSizeS',\n                'euiSecondary',\n                'euiPrimary',\n            ],\n        },\n    ],\n})\nexport class EuiUserProfileComponent implements OnInit, OnDestroy, AfterViewInit {\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return [\n            this.baseStatesDirective.getCssClasses('eui-user-profile'),\n            this.isReverse ? 'eui-user-profile--reverse': '',\n            this.isShowAvatarInitials ? 'eui-user-profile--initials': '',\n        ].join(' ').trim();\n    }\n\n    userState: UserProfile;\n    isOnline = true;\n    avatarInitials: string;\n\n    @Input() welcomeLabel = 'Welcome';\n    @Input() impersonateLabel = 'impersonating';\n    @Input() avatarUrl: string;\n    @Input() subInfos: string;\n    @Input() statusVariant = 'success';\n\n    @Input({ transform: booleanAttribute }) hasMenu = false;\n    @Input({ transform: booleanAttribute }) hasWelcomeLabel = true;\n    @Input({ transform: booleanAttribute }) isShowAvatarInitials = false;\n    @Input({ transform: booleanAttribute }) hasTabNavigation = false;\n    @Input({ transform: booleanAttribute }) isReverse = false;\n    @Input({ transform: booleanAttribute }) hasToggle = false;\n    @Input({ transform: booleanAttribute }) isHeaderUserProfile = false;\n    @Input({ transform: booleanAttribute }) isShowUserInfos = true;\n\n    @Input({ transform: booleanAttribute }) euiStatusSecondary = false;\n    @Input({ transform: booleanAttribute }) euiStatusSuccess = false;\n    @Input({ transform: booleanAttribute }) euiStatusDanger = false;\n\n    @ViewChild('dropdown') dropdown: EuiDropdownComponent;\n    @ContentChildren(forwardRef(() => EuiUserProfileMenuComponent), { descendants: true })\n    hasMenuContent: QueryList<EuiUserProfileMenuComponent>;\n\n    isDropdownOpen = false;\n\n    private unsubscribeSubject$: Subject<void> = new Subject();\n\n    constructor(\n        private elRef: ElementRef,\n        private userService: UserService,\n        public baseStatesDirective: BaseStatesDirective,\n    ) {\n    }\n\n    ngOnInit(): void {\n        this.userService\n            .getState()\n            .pipe(takeUntil(this.unsubscribeSubject$))\n            .subscribe((state: UserProfile) => {\n                if (state) {\n                    this.userState = state;\n                    const firstNameInitial = state.firstName?.substring(0, 1).toUpperCase();\n                    const lastNameInitial = state.lastName?.substring(0, 1).toUpperCase();\n                    this.avatarInitials = `${firstNameInitial}${lastNameInitial}`;\n                }\n            });\n    }\n\n    ngAfterViewInit(): void {\n        let hasToolbarItemParent = false, toolbar;\n\n        try {\n            hasToolbarItemParent = this.elRef.nativeElement.closest('eui-toolbar-item');\n            toolbar = this.elRef.nativeElement.closest('eui-toolbar');\n        } catch(e) {\n           // do nothing\n        }\n\n        setTimeout(() => {\n            if (hasToolbarItemParent) {\n                this.baseStatesDirective.euiSizeS = true;\n                if (toolbar && toolbar.classList.contains('eui--secondary') || this.baseStatesDirective.euiSecondary) {\n                    console.log(toolbar);\n                    this.baseStatesDirective.euiSecondary = true;\n                } else {\n                    this.baseStatesDirective.euiPrimary = true;\n                }\n            }\n            if (hasToolbarItemParent || !this.isHeaderUserProfile) {\n                this.hasMenu = this.hasMenuContent.length !== 0;\n            }\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.unsubscribeSubject$.next();\n        this.unsubscribeSubject$.complete();\n    }\n\n    closeDropdown(): void {\n        this.dropdown.closeDropdown();\n        this.isDropdownOpen = false;\n    }\n\n    onDropdownExpand(isOpen: boolean): void {\n        this.isDropdownOpen = isOpen;\n    }\n}\n","@if (hasMenu) {\n    <eui-dropdown [hasTabNavigation]=\"hasTabNavigation\" width=\"340px\" #dropdown (expand)=\"onDropdownExpand($event)\">\n        <ng-container *ngTemplateOutlet=\"userProfileContent\"/>\n        <eui-dropdown-content>\n            <ng-content/>\n        </eui-dropdown-content>\n    </eui-dropdown>\n} @else {\n    <ng-container *ngTemplateOutlet=\"userProfileContent\"/>\n}\n\n<ng-template #userProfileContent>\n    <button class=\"eui-user-profile-content\" [tabindex]=\"hasMenu ? '0' : '-1'\" [class.eui-user-profile-content--no-menu]=\"!hasMenu\">\n\n        @if (isShowUserInfos) {\n            <div class=\"eui-user-profile__infos\">\n                @if (userState?.impersonatingUser) {\n                    <div class=\"eui-user-profile__infos-welcome\">\n                        @if (hasWelcomeLabel) {\n                            <span class=\"eui-u-mr-2xs\">{{ welcomeLabel }}</span>\n                        }\n                        {{ userState?.impersonatingUser?.firstName }} <strong>{{ userState?.impersonatingUser?.lastName}}</strong>\n                        <span class=\"eui-u-ml-2xs\">{{ impersonateLabel }}</span>\n                    </div>\n                    <div class=\"eui-user-profile__infos-name\">\n                        {{ userState?.firstName }} <strong>{{ userState?.lastName }}</strong>\n                    </div>\n                    @if (subInfos) {\n                        <div class=\"eui-user-profile__infos-subinfos\">{{ subInfos }}</div>\n                    }\n                } @else {\n                    @if (hasWelcomeLabel) {\n                        <div class=\"eui-user-profile__infos-welcome\">{{ welcomeLabel }}</div>\n                    }\n                    <div class=\"eui-user-profile__infos-name\">\n                        {{ userState?.firstName }} <strong>{{ userState?.lastName }}</strong>\n                    </div>\n                    @if (subInfos) {\n                        <div class=\"eui-user-profile__infos-subinfos\">{{ subInfos }}</div>\n                    }\n                }\n            </div>\n        }\n\n        <eui-avatar isFlat [euiSizeS]=\"baseStatesDirective.euiSizeS\" [hasShadow]=\"userState?.impersonatingUser\">\n\n            @if (isShowAvatarInitials) {\n                <eui-avatar-text>{{ avatarInitials }}</eui-avatar-text>\n            } @else {\n                <eui-avatar-image [imageUrl]=\"avatarUrl\"/>\n            }\n\n            @if (euiStatusSecondary || euiStatusSuccess || euiStatusDanger) {\n                <eui-avatar-badge position=\"bottom\">\n                    @if (euiStatusSuccess) {\n                        <eui-badge euiSuccess euiSizeS euiIconBadge>\n                            <eui-icon-svg icon=\"checkmark:outline\" size=\"xs\"/>\n                        </eui-badge>\n                    } @else if (euiStatusDanger) {\n                        <eui-badge euiDanger euiSizeS euiIconBadge>\n                            <eui-icon-svg icon=\"remove:outline\" size=\"xs\"/>\n                        </eui-badge>\n                    } @else if (euiStatusSecondary) {\n                        <eui-badge euiSecondary euiSizeS euiIconBadge>\n                            <eui-icon-svg icon=\"close-circle:outline\" fillColor=\"neutral\" size=\"xs\"/>\n                        </eui-badge>\n                    }\n                </eui-avatar-badge>\n            }\n        </eui-avatar>\n\n        @if (hasMenu || hasToggle) {\n            @if (isDropdownOpen) {\n                <eui-icon-svg icon=\"chevron-up:sharp\" size=\"s\" class=\"eui-user-profile__drop-indicator\"/>\n            } @else {\n                <eui-icon-svg icon=\"chevron-down:sharp\" size=\"s\" class=\"eui-user-profile__drop-indicator\"/>\n            }\n        }\n    </button>\n</ng-template>\n"]}
@@ -110,11 +110,11 @@ export class EuiNotificationsComponent {
110
110
  return unreadNotifications.length;
111
111
  }
112
112
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: EuiNotificationsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
113
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.2", type: EuiNotificationsComponent, selector: "eui-notifications", inputs: { count: "count", items: "items", unreadLabel: "unreadLabel", totalLabel: "totalLabel", markAsReadLabel: "markAsReadLabel", markAsUnReadLabel: "markAsUnReadLabel", markAllAsReadLabel: "markAllAsReadLabel", settingsLabel: "settingsLabel", refreshLabel: "refreshLabel", viewAllNotificationsLabel: "viewAllNotificationsLabel", headerTitleLabel: "headerTitleLabel", noNotificationFoundLabel: "noNotificationFoundLabel", nbUnreadCount: "nbUnreadCount", dateFormat: "dateFormat", noNotificationFoundLink: ["noNotificationFoundLink", "noNotificationFoundLink", booleanAttribute], isShowMarkAsRead: ["isShowMarkAsRead", "isShowMarkAsRead", booleanAttribute], isShowViewAllAction: ["isShowViewAllAction", "isShowViewAllAction", booleanAttribute], isHidePanelOnViewAllAction: ["isHidePanelOnViewAllAction", "isHidePanelOnViewAllAction", booleanAttribute], customUnreadCount: ["customUnreadCount", "customUnreadCount", booleanAttribute], isShowMarkAllAsReadButton: ["isShowMarkAllAsReadButton", "isShowMarkAllAsReadButton", booleanAttribute], isShowSettingsButton: ["isShowSettingsButton", "isShowSettingsButton", booleanAttribute], isShowRefreshButton: ["isShowRefreshButton", "isShowRefreshButton", booleanAttribute] }, outputs: { refreshClick: "refreshClick", notificationsClick: "notificationsClick", viewAllClick: "viewAllClick", settingsClick: "settingsClick", markAllAsReadClick: "markAllAsReadClick", noNotificationFoundClick: "noNotificationFoundClick", itemClick: "itemClick", itemMarkAsReadClick: "itemMarkAsReadClick" }, host: { listeners: { "body:click": "onHide()" }, properties: { "class": "this.string" } }, usesOnChanges: true, ngImport: i0, template: "<eui-icon-button\n class=\"eui-notifications__trigger\"\n icon=\"notifications:outline\"\n fillColor=\"white\"\n (click)=\"onClicked($event)\"\n (keydown.enter)=\"onClicked($event)\"\n (keydown.esc)=\"onHide()\">\n <eui-badge *ngIf=\"count\" euiDanger [maxCharCount]=\"2\">{{ count }}</eui-badge>\n</eui-icon-button>\n\n<eui-overlay [isActive]=\"isOverlayActive\" class=\"eui-overlay-offset--width-30\">\n <eui-overlay-header>\n <div class=\"eui-notifications__header-title\">\n <div class=\"eui-notifications__header-title-label\">\n {{ headerTitleLabel ? headerTitleLabel : ('eui.MYNOTIFICATIONS' | translate) }}\n <span\n *ngIf=\"items\"\n class=\"eui-u-cursor-help eui-u-ml-s\"\n attr.aria-label=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\"\n title=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\">\n </span>\n <eui-badge *ngIf=\"count\">{{ count }}</eui-badge>\n <eui-badge *ngIf=\"!count\">{{ items.length }}</eui-badge>\n </div>\n </div>\n\n <div *ngIf=\"items\" class=\"eui-notifications__header-actions\">\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowMarkAllAsReadButton\"\n [attr.aria-label]=\"markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate)\"\n title=\"{{ markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate) }}\"\n (click)=\"onMarkAllAsRead($event)\">\n <eui-icon-svg icon=\"checkmark-done:sharp\"></eui-icon-svg>\n </button>\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowSettingsButton\"\n [attr.aria-label]=\"settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate)\"\n title=\"{{ settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate) }}\"\n (click)=\"onSettings($event)\">\n <eui-icon-svg icon=\"settings:sharp\"></eui-icon-svg>\n </button>\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowRefreshButton\"\n [attr.aria-label]=\"refreshLabel ? refreshLabel : ('eui.REFRESH' | translate)\"\n title=\"{{ refreshLabel ? refreshLabel : ('eui.REFRESH' | translate) }}\"\n (click)=\"onRefresh($event)\">\n <eui-icon-svg icon=\"refresh:sharp\"></eui-icon-svg>\n </button>\n </div>\n </eui-overlay-header>\n\n <eui-overlay-body>\n <ul class=\"eui-notifications-items\" *ngIf=\"items\">\n <eui-notification-item\n *ngFor=\"let item of items; trackBy: trackByFn\"\n [item]=\"item\"\n [dateFormat]=\"dateFormat\"\n [markAsReadLabel]=\"markAsReadLabel\"\n [isShowMarkAsRead]=\"isShowMarkAsRead\"\n (itemClick)=\"onItemClick($event)\"\n (itemMarkAsRead)=\"onItemMarkAsRead($event)\">\n </eui-notification-item>\n </ul>\n </eui-overlay-body>\n\n <eui-overlay-footer>\n <ng-template [ngIf]=\"items?.length > 0\">\n <a (click)=\"onViewAllClick($event)\" class=\"eui-u-text-link\">\n <strong>{{ viewAllNotificationsLabel ? viewAllNotificationsLabel : ('eui.VIEWALLNOTIFICATIONS' | translate) }}</strong>\n </a>\n </ng-template>\n <ng-template [ngIf]=\"items?.length === 0\">\n <div class=\"ux-notification__item-content\" *ngIf=\"!noNotificationFoundLink\">\n {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n </div>\n <div class=\"ux-notification__item-content\" *ngIf=\"noNotificationFoundLink\">\n <a (click)=\"onNoNotificationFoundClick()\" class=\"eui-u-text-link\">\n {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n </a>\n </div>\n </ng-template>\n </eui-overlay-footer>\n</eui-overlay>\n", styles: [".eui-overlay-header{background-color:var(--eui-c-neutral-bg-light);border-bottom:1px solid var(--eui-c-neutral-lightest)}.eui-notifications-items{margin:0;padding:0}.eui-notifications__trigger .eui-icon-svg svg{position:relative;top:var(--eui-s-2xs);transform:scale(1.1)}.eui-notifications__header{align-items:center;border-bottom:1px solid var(--eui-c-neutral-bg-light);color:var(--eui-c-text);cursor:default;display:flex;padding:var(--eui-s-xs) var(--eui-s-m)}.eui-notifications__header-title{display:flex}.eui-notifications__header-title-label{font:var(--eui-f-l-bold)}.eui-notifications__header-title-subLabel{margin-top:var(--eui-s-xs);font:var(--eui-f-m)}.eui-notifications__header-actions{align-items:center;display:flex;margin-left:auto}.eui-notification-item{display:flex;flex-direction:column;overflow-y:auto;margin:0}.eui-notification-item-content{background-color:var(--eui-c-info-bg);border-bottom:1px solid var(--eui-c-neutral-lightest);display:flex;flex-direction:column;min-height:var(--eui-s-4xl);padding:var(--eui-s-s) var(--eui-s-m);cursor:pointer}.eui-notification-item-content:hover{background-color:var(--eui-c-neutral-bg-light)!important}.eui-notification-item-content-top{align-items:center;display:flex;justify-content:space-between}.eui-notification-item-content-top__date{display:flex;align-items:center}.eui-notification-item-content-top__date-icon{align-items:center;display:flex;position:relative}.eui-notification-item-content-top__date-icon--rotated{transform:rotate(20deg)}.eui-notification-item-content-top__date-icon-dot{position:absolute;top:0;right:0}.eui-notification-item-content-middle{margin:var(--eui-s-2xs) 0}.eui-notification-item-content-middle__sub-label{margin-top:var(--eui-s-2xs)}.eui-notification-item-content-bottom{display:flex;justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.EuiOverlayHeaderComponent, selector: "eui-overlay-header" }, { kind: "component", type: i2.EuiOverlayBodyComponent, selector: "eui-overlay-body" }, { kind: "component", type: i2.EuiOverlayFooterComponent, selector: "eui-overlay-footer" }, { kind: "component", type: i2.EuiOverlayComponent, selector: "eui-overlay", inputs: ["isActive", "euiHighlighted", "hasClosedOnClickOutside", "position", "width", "fixedWidth"], outputs: ["activeState"] }, { kind: "component", type: i3.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "euiIconButton", "euiLineWrap", "isChecked", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "component", type: i4.EuiBadgeComponent, selector: "div[euiBadge], span[euiBadge], eui-badge", inputs: ["e2eAttr", "aria-label", "maxCharCount", "charReplacement", "euiIconBadge", "euiDottedBadge"] }, { kind: "component", type: i5.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "style", "iconUrl", "transform", "euiVariant", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "component", type: i6.EuiIconButtonComponent, selector: "eui-icon-button", inputs: ["icon", "fillColor", "size", "ariaLabel", "tabindex", "hasNoPadding", "hasFocusHoverColor", "hasFocusHoverBg", "euiRounded", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "component", type: i7.EuiNotificationItemComponent, selector: "eui-notification-item", inputs: ["markAsReadLabel", "item", "dateFormat", "isShowMarkAsRead"], outputs: ["itemClick", "itemMarkAsRead"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
113
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.2", type: EuiNotificationsComponent, selector: "eui-notifications", inputs: { count: "count", items: "items", unreadLabel: "unreadLabel", totalLabel: "totalLabel", markAsReadLabel: "markAsReadLabel", markAsUnReadLabel: "markAsUnReadLabel", markAllAsReadLabel: "markAllAsReadLabel", settingsLabel: "settingsLabel", refreshLabel: "refreshLabel", viewAllNotificationsLabel: "viewAllNotificationsLabel", headerTitleLabel: "headerTitleLabel", noNotificationFoundLabel: "noNotificationFoundLabel", nbUnreadCount: "nbUnreadCount", dateFormat: "dateFormat", noNotificationFoundLink: ["noNotificationFoundLink", "noNotificationFoundLink", booleanAttribute], isShowMarkAsRead: ["isShowMarkAsRead", "isShowMarkAsRead", booleanAttribute], isShowViewAllAction: ["isShowViewAllAction", "isShowViewAllAction", booleanAttribute], isHidePanelOnViewAllAction: ["isHidePanelOnViewAllAction", "isHidePanelOnViewAllAction", booleanAttribute], customUnreadCount: ["customUnreadCount", "customUnreadCount", booleanAttribute], isShowMarkAllAsReadButton: ["isShowMarkAllAsReadButton", "isShowMarkAllAsReadButton", booleanAttribute], isShowSettingsButton: ["isShowSettingsButton", "isShowSettingsButton", booleanAttribute], isShowRefreshButton: ["isShowRefreshButton", "isShowRefreshButton", booleanAttribute] }, outputs: { refreshClick: "refreshClick", notificationsClick: "notificationsClick", viewAllClick: "viewAllClick", settingsClick: "settingsClick", markAllAsReadClick: "markAllAsReadClick", noNotificationFoundClick: "noNotificationFoundClick", itemClick: "itemClick", itemMarkAsReadClick: "itemMarkAsReadClick" }, host: { listeners: { "body:click": "onHide()" }, properties: { "class": "this.string" } }, usesOnChanges: true, ngImport: i0, template: "<eui-icon-button\n class=\"eui-notifications__trigger\"\n icon=\"notifications:outline\"\n fillColor=\"white\"\n (click)=\"onClicked($event)\"\n (keydown.enter)=\"onClicked($event)\"\n (keydown.esc)=\"onHide()\">\n <eui-badge *ngIf=\"count\" euiDanger [maxCharCount]=\"2\">{{ count }}</eui-badge>\n</eui-icon-button>\n\n<eui-overlay [isActive]=\"isOverlayActive\" class=\"eui-overlay-offset--width-30\">\n <eui-overlay-header>\n <div class=\"eui-notifications__header-title\">\n <div class=\"eui-notifications__header-title-label\">\n {{ headerTitleLabel ? headerTitleLabel : ('eui.MYNOTIFICATIONS' | translate) }}\n <span\n *ngIf=\"items\"\n class=\"eui-u-cursor-help eui-u-ml-s\"\n attr.aria-label=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\"\n title=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\">\n </span>\n <eui-badge *ngIf=\"count\">{{ count }}</eui-badge>\n <eui-badge *ngIf=\"!count\">{{ items.length }}</eui-badge>\n </div>\n </div>\n\n <div *ngIf=\"items\" class=\"eui-notifications__header-actions\">\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowMarkAllAsReadButton\"\n [attr.aria-label]=\"markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate)\"\n title=\"{{ markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate) }}\"\n (click)=\"onMarkAllAsRead($event)\">\n <eui-icon-svg icon=\"checkmark-done:outline\" fillColor=\"neutral\"></eui-icon-svg>\n </button>\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowSettingsButton\"\n [attr.aria-label]=\"settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate)\"\n title=\"{{ settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate) }}\"\n (click)=\"onSettings($event)\">\n <eui-icon-svg icon=\"settings:outline\" fillColor=\"neutral\"></eui-icon-svg>\n </button>\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowRefreshButton\"\n [attr.aria-label]=\"refreshLabel ? refreshLabel : ('eui.REFRESH' | translate)\"\n title=\"{{ refreshLabel ? refreshLabel : ('eui.REFRESH' | translate) }}\"\n (click)=\"onRefresh($event)\">\n <eui-icon-svg icon=\"refresh:outline\" fillColor=\"neutral\"></eui-icon-svg>\n </button>\n </div>\n </eui-overlay-header>\n\n <eui-overlay-body>\n <ul class=\"eui-notifications-items\" *ngIf=\"items\">\n <eui-notification-item\n *ngFor=\"let item of items; trackBy: trackByFn\"\n [item]=\"item\"\n [dateFormat]=\"dateFormat\"\n [markAsReadLabel]=\"markAsReadLabel\"\n [isShowMarkAsRead]=\"isShowMarkAsRead\"\n (itemClick)=\"onItemClick($event)\"\n (itemMarkAsRead)=\"onItemMarkAsRead($event)\">\n </eui-notification-item>\n </ul>\n </eui-overlay-body>\n\n <eui-overlay-footer>\n <ng-template [ngIf]=\"items?.length > 0\">\n <a (click)=\"onViewAllClick($event)\" class=\"eui-u-text-link\">\n <strong>{{ viewAllNotificationsLabel ? viewAllNotificationsLabel : ('eui.VIEWALLNOTIFICATIONS' | translate) }}</strong>\n </a>\n </ng-template>\n <ng-template [ngIf]=\"items?.length === 0\">\n <div class=\"ux-notification__item-content\" *ngIf=\"!noNotificationFoundLink\">\n {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n </div>\n <div class=\"ux-notification__item-content\" *ngIf=\"noNotificationFoundLink\">\n <a (click)=\"onNoNotificationFoundClick()\" class=\"eui-u-text-link\">\n {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n </a>\n </div>\n </ng-template>\n </eui-overlay-footer>\n</eui-overlay>\n", styles: [".eui-overlay-header{background-color:var(--eui-c-neutral-bg-light);border-bottom:1px solid var(--eui-c-neutral-lightest)}.eui-notifications-items{margin:0;padding:0}.eui-notifications__trigger .eui-icon-svg svg{position:relative;top:var(--eui-s-2xs);transform:scale(1.1)}.eui-notifications__header{align-items:center;border-bottom:1px solid var(--eui-c-neutral-bg-light);color:var(--eui-c-text);cursor:default;display:flex;padding:var(--eui-s-xs) var(--eui-s-m)}.eui-notifications__header-title{display:flex}.eui-notifications__header-title-label{font:var(--eui-f-l-bold)}.eui-notifications__header-title-subLabel{margin-top:var(--eui-s-xs);font:var(--eui-f-m)}.eui-notifications__header-actions{align-items:center;display:flex;margin-left:auto}.eui-notification-item{display:flex;flex-direction:column;overflow-y:auto;margin:0}.eui-notification-item-content{background-color:var(--eui-c-info-bg);border-bottom:1px solid var(--eui-c-neutral-lightest);display:flex;flex-direction:column;min-height:var(--eui-s-4xl);padding:var(--eui-s-s) var(--eui-s-m);cursor:pointer}.eui-notification-item-content:hover{background-color:var(--eui-c-neutral-bg-light)!important}.eui-notification-item-content-top{align-items:center;display:flex;justify-content:space-between}.eui-notification-item-content-top__date{display:flex;align-items:center}.eui-notification-item-content-top__date-icon{align-items:center;display:flex;position:relative}.eui-notification-item-content-top__date-icon--rotated{transform:rotate(20deg)}.eui-notification-item-content-top__date-icon-dot{position:absolute;top:0;right:0}.eui-notification-item-content-middle{margin:var(--eui-s-2xs) 0}.eui-notification-item-content-middle__sub-label{margin-top:var(--eui-s-2xs)}.eui-notification-item-content-bottom{display:flex;justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.EuiOverlayHeaderComponent, selector: "eui-overlay-header" }, { kind: "component", type: i2.EuiOverlayBodyComponent, selector: "eui-overlay-body" }, { kind: "component", type: i2.EuiOverlayFooterComponent, selector: "eui-overlay-footer" }, { kind: "component", type: i2.EuiOverlayComponent, selector: "eui-overlay", inputs: ["isActive", "euiHighlighted", "hasClosedOnClickOutside", "position", "width", "fixedWidth"], outputs: ["activeState"] }, { kind: "component", type: i3.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "euiIconButton", "euiLineWrap", "isChecked", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "component", type: i4.EuiBadgeComponent, selector: "div[euiBadge], span[euiBadge], eui-badge", inputs: ["e2eAttr", "aria-label", "maxCharCount", "charReplacement", "euiIconBadge", "euiDottedBadge"] }, { kind: "component", type: i5.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "style", "iconUrl", "transform", "euiVariant", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "component", type: i6.EuiIconButtonComponent, selector: "eui-icon-button", inputs: ["icon", "fillColor", "size", "ariaLabel", "tabindex", "hasNoPadding", "hasFocusHoverColor", "hasFocusHoverBg", "euiRounded", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "component", type: i7.EuiNotificationItemComponent, selector: "eui-notification-item", inputs: ["markAsReadLabel", "item", "dateFormat", "isShowMarkAsRead"], outputs: ["itemClick", "itemMarkAsRead"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
114
114
  }
115
115
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: EuiNotificationsComponent, decorators: [{
116
116
  type: Component,
117
- args: [{ selector: 'eui-notifications', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, template: "<eui-icon-button\n class=\"eui-notifications__trigger\"\n icon=\"notifications:outline\"\n fillColor=\"white\"\n (click)=\"onClicked($event)\"\n (keydown.enter)=\"onClicked($event)\"\n (keydown.esc)=\"onHide()\">\n <eui-badge *ngIf=\"count\" euiDanger [maxCharCount]=\"2\">{{ count }}</eui-badge>\n</eui-icon-button>\n\n<eui-overlay [isActive]=\"isOverlayActive\" class=\"eui-overlay-offset--width-30\">\n <eui-overlay-header>\n <div class=\"eui-notifications__header-title\">\n <div class=\"eui-notifications__header-title-label\">\n {{ headerTitleLabel ? headerTitleLabel : ('eui.MYNOTIFICATIONS' | translate) }}\n <span\n *ngIf=\"items\"\n class=\"eui-u-cursor-help eui-u-ml-s\"\n attr.aria-label=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\"\n title=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\">\n </span>\n <eui-badge *ngIf=\"count\">{{ count }}</eui-badge>\n <eui-badge *ngIf=\"!count\">{{ items.length }}</eui-badge>\n </div>\n </div>\n\n <div *ngIf=\"items\" class=\"eui-notifications__header-actions\">\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowMarkAllAsReadButton\"\n [attr.aria-label]=\"markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate)\"\n title=\"{{ markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate) }}\"\n (click)=\"onMarkAllAsRead($event)\">\n <eui-icon-svg icon=\"checkmark-done:sharp\"></eui-icon-svg>\n </button>\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowSettingsButton\"\n [attr.aria-label]=\"settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate)\"\n title=\"{{ settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate) }}\"\n (click)=\"onSettings($event)\">\n <eui-icon-svg icon=\"settings:sharp\"></eui-icon-svg>\n </button>\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowRefreshButton\"\n [attr.aria-label]=\"refreshLabel ? refreshLabel : ('eui.REFRESH' | translate)\"\n title=\"{{ refreshLabel ? refreshLabel : ('eui.REFRESH' | translate) }}\"\n (click)=\"onRefresh($event)\">\n <eui-icon-svg icon=\"refresh:sharp\"></eui-icon-svg>\n </button>\n </div>\n </eui-overlay-header>\n\n <eui-overlay-body>\n <ul class=\"eui-notifications-items\" *ngIf=\"items\">\n <eui-notification-item\n *ngFor=\"let item of items; trackBy: trackByFn\"\n [item]=\"item\"\n [dateFormat]=\"dateFormat\"\n [markAsReadLabel]=\"markAsReadLabel\"\n [isShowMarkAsRead]=\"isShowMarkAsRead\"\n (itemClick)=\"onItemClick($event)\"\n (itemMarkAsRead)=\"onItemMarkAsRead($event)\">\n </eui-notification-item>\n </ul>\n </eui-overlay-body>\n\n <eui-overlay-footer>\n <ng-template [ngIf]=\"items?.length > 0\">\n <a (click)=\"onViewAllClick($event)\" class=\"eui-u-text-link\">\n <strong>{{ viewAllNotificationsLabel ? viewAllNotificationsLabel : ('eui.VIEWALLNOTIFICATIONS' | translate) }}</strong>\n </a>\n </ng-template>\n <ng-template [ngIf]=\"items?.length === 0\">\n <div class=\"ux-notification__item-content\" *ngIf=\"!noNotificationFoundLink\">\n {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n </div>\n <div class=\"ux-notification__item-content\" *ngIf=\"noNotificationFoundLink\">\n <a (click)=\"onNoNotificationFoundClick()\" class=\"eui-u-text-link\">\n {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n </a>\n </div>\n </ng-template>\n </eui-overlay-footer>\n</eui-overlay>\n", styles: [".eui-overlay-header{background-color:var(--eui-c-neutral-bg-light);border-bottom:1px solid var(--eui-c-neutral-lightest)}.eui-notifications-items{margin:0;padding:0}.eui-notifications__trigger .eui-icon-svg svg{position:relative;top:var(--eui-s-2xs);transform:scale(1.1)}.eui-notifications__header{align-items:center;border-bottom:1px solid var(--eui-c-neutral-bg-light);color:var(--eui-c-text);cursor:default;display:flex;padding:var(--eui-s-xs) var(--eui-s-m)}.eui-notifications__header-title{display:flex}.eui-notifications__header-title-label{font:var(--eui-f-l-bold)}.eui-notifications__header-title-subLabel{margin-top:var(--eui-s-xs);font:var(--eui-f-m)}.eui-notifications__header-actions{align-items:center;display:flex;margin-left:auto}.eui-notification-item{display:flex;flex-direction:column;overflow-y:auto;margin:0}.eui-notification-item-content{background-color:var(--eui-c-info-bg);border-bottom:1px solid var(--eui-c-neutral-lightest);display:flex;flex-direction:column;min-height:var(--eui-s-4xl);padding:var(--eui-s-s) var(--eui-s-m);cursor:pointer}.eui-notification-item-content:hover{background-color:var(--eui-c-neutral-bg-light)!important}.eui-notification-item-content-top{align-items:center;display:flex;justify-content:space-between}.eui-notification-item-content-top__date{display:flex;align-items:center}.eui-notification-item-content-top__date-icon{align-items:center;display:flex;position:relative}.eui-notification-item-content-top__date-icon--rotated{transform:rotate(20deg)}.eui-notification-item-content-top__date-icon-dot{position:absolute;top:0;right:0}.eui-notification-item-content-middle{margin:var(--eui-s-2xs) 0}.eui-notification-item-content-middle__sub-label{margin-top:var(--eui-s-2xs)}.eui-notification-item-content-bottom{display:flex;justify-content:flex-end}\n"] }]
117
+ args: [{ selector: 'eui-notifications', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, template: "<eui-icon-button\n class=\"eui-notifications__trigger\"\n icon=\"notifications:outline\"\n fillColor=\"white\"\n (click)=\"onClicked($event)\"\n (keydown.enter)=\"onClicked($event)\"\n (keydown.esc)=\"onHide()\">\n <eui-badge *ngIf=\"count\" euiDanger [maxCharCount]=\"2\">{{ count }}</eui-badge>\n</eui-icon-button>\n\n<eui-overlay [isActive]=\"isOverlayActive\" class=\"eui-overlay-offset--width-30\">\n <eui-overlay-header>\n <div class=\"eui-notifications__header-title\">\n <div class=\"eui-notifications__header-title-label\">\n {{ headerTitleLabel ? headerTitleLabel : ('eui.MYNOTIFICATIONS' | translate) }}\n <span\n *ngIf=\"items\"\n class=\"eui-u-cursor-help eui-u-ml-s\"\n attr.aria-label=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\"\n title=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\">\n </span>\n <eui-badge *ngIf=\"count\">{{ count }}</eui-badge>\n <eui-badge *ngIf=\"!count\">{{ items.length }}</eui-badge>\n </div>\n </div>\n\n <div *ngIf=\"items\" class=\"eui-notifications__header-actions\">\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowMarkAllAsReadButton\"\n [attr.aria-label]=\"markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate)\"\n title=\"{{ markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate) }}\"\n (click)=\"onMarkAllAsRead($event)\">\n <eui-icon-svg icon=\"checkmark-done:outline\" fillColor=\"neutral\"></eui-icon-svg>\n </button>\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowSettingsButton\"\n [attr.aria-label]=\"settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate)\"\n title=\"{{ settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate) }}\"\n (click)=\"onSettings($event)\">\n <eui-icon-svg icon=\"settings:outline\" fillColor=\"neutral\"></eui-icon-svg>\n </button>\n <button\n euiButton\n euiPrimary\n euiRounded\n euiIconButton\n euiBasicButton\n euiSizeS\n type=\"button\"\n *ngIf=\"isShowRefreshButton\"\n [attr.aria-label]=\"refreshLabel ? refreshLabel : ('eui.REFRESH' | translate)\"\n title=\"{{ refreshLabel ? refreshLabel : ('eui.REFRESH' | translate) }}\"\n (click)=\"onRefresh($event)\">\n <eui-icon-svg icon=\"refresh:outline\" fillColor=\"neutral\"></eui-icon-svg>\n </button>\n </div>\n </eui-overlay-header>\n\n <eui-overlay-body>\n <ul class=\"eui-notifications-items\" *ngIf=\"items\">\n <eui-notification-item\n *ngFor=\"let item of items; trackBy: trackByFn\"\n [item]=\"item\"\n [dateFormat]=\"dateFormat\"\n [markAsReadLabel]=\"markAsReadLabel\"\n [isShowMarkAsRead]=\"isShowMarkAsRead\"\n (itemClick)=\"onItemClick($event)\"\n (itemMarkAsRead)=\"onItemMarkAsRead($event)\">\n </eui-notification-item>\n </ul>\n </eui-overlay-body>\n\n <eui-overlay-footer>\n <ng-template [ngIf]=\"items?.length > 0\">\n <a (click)=\"onViewAllClick($event)\" class=\"eui-u-text-link\">\n <strong>{{ viewAllNotificationsLabel ? viewAllNotificationsLabel : ('eui.VIEWALLNOTIFICATIONS' | translate) }}</strong>\n </a>\n </ng-template>\n <ng-template [ngIf]=\"items?.length === 0\">\n <div class=\"ux-notification__item-content\" *ngIf=\"!noNotificationFoundLink\">\n {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n </div>\n <div class=\"ux-notification__item-content\" *ngIf=\"noNotificationFoundLink\">\n <a (click)=\"onNoNotificationFoundClick()\" class=\"eui-u-text-link\">\n {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n </a>\n </div>\n </ng-template>\n </eui-overlay-footer>\n</eui-overlay>\n", styles: [".eui-overlay-header{background-color:var(--eui-c-neutral-bg-light);border-bottom:1px solid var(--eui-c-neutral-lightest)}.eui-notifications-items{margin:0;padding:0}.eui-notifications__trigger .eui-icon-svg svg{position:relative;top:var(--eui-s-2xs);transform:scale(1.1)}.eui-notifications__header{align-items:center;border-bottom:1px solid var(--eui-c-neutral-bg-light);color:var(--eui-c-text);cursor:default;display:flex;padding:var(--eui-s-xs) var(--eui-s-m)}.eui-notifications__header-title{display:flex}.eui-notifications__header-title-label{font:var(--eui-f-l-bold)}.eui-notifications__header-title-subLabel{margin-top:var(--eui-s-xs);font:var(--eui-f-m)}.eui-notifications__header-actions{align-items:center;display:flex;margin-left:auto}.eui-notification-item{display:flex;flex-direction:column;overflow-y:auto;margin:0}.eui-notification-item-content{background-color:var(--eui-c-info-bg);border-bottom:1px solid var(--eui-c-neutral-lightest);display:flex;flex-direction:column;min-height:var(--eui-s-4xl);padding:var(--eui-s-s) var(--eui-s-m);cursor:pointer}.eui-notification-item-content:hover{background-color:var(--eui-c-neutral-bg-light)!important}.eui-notification-item-content-top{align-items:center;display:flex;justify-content:space-between}.eui-notification-item-content-top__date{display:flex;align-items:center}.eui-notification-item-content-top__date-icon{align-items:center;display:flex;position:relative}.eui-notification-item-content-top__date-icon--rotated{transform:rotate(20deg)}.eui-notification-item-content-top__date-icon-dot{position:absolute;top:0;right:0}.eui-notification-item-content-middle{margin:var(--eui-s-2xs) 0}.eui-notification-item-content-middle__sub-label{margin-top:var(--eui-s-2xs)}.eui-notification-item-content-bottom{display:flex;justify-content:flex-end}\n"] }]
118
118
  }], propDecorators: { refreshClick: [{
119
119
  type: Output
120
120
  }], notificationsClick: [{
@@ -190,4 +190,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
190
190
  type: HostListener,
191
191
  args: ['body:click']
192
192
  }] } });
193
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-notifications.component.js","sourceRoot":"","sources":["../../../../layout/eui-notifications/eui-notifications.component.ts","../../../../layout/eui-notifications/eui-notifications.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    booleanAttribute,\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { consumeEvent } from '@eui/core';\nimport { UxLinkLegacy } from '@eui/base';\nimport { NotificationMetadata } from './eui-notification-item.component';\n\n@Component({\n    selector: 'eui-notifications',\n    templateUrl: './eui-notifications.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiNotificationsComponent implements OnInit, OnChanges {\n    @Output() refreshClick: EventEmitter<void> = new EventEmitter<void>();\n    @Output() notificationsClick: EventEmitter<void> = new EventEmitter<void>();\n    @Output() viewAllClick: EventEmitter<void> = new EventEmitter<void>();\n    @Output() settingsClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n    @Output() markAllAsReadClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n    @Output() noNotificationFoundClick: EventEmitter<void> = new EventEmitter<void>();\n    @Output() itemClick: EventEmitter<UxLinkLegacy<NotificationMetadata>> = new EventEmitter<UxLinkLegacy<NotificationMetadata>>();\n    @Output() itemMarkAsReadClick: EventEmitter<UxLinkLegacy<NotificationMetadata>> = new EventEmitter<UxLinkLegacy<NotificationMetadata>>();\n\n    isOverlayActive = false;\n    currentDayNotifications = [];\n    oldestNotifications = [];\n    unreadNotifications = [];\n    today: Date = new Date();\n\n    @HostBinding('class') string = 'eui-notifications';\n\n    @Input() count: number = null;\n    @Input() items = [];\n    @Input() unreadLabel: string = null;\n    @Input() totalLabel: string = null;\n    @Input() markAsReadLabel: string = null;\n    @Input() markAsUnReadLabel: string = null;\n    @Input() markAllAsReadLabel: string = null;\n    @Input() settingsLabel: string = null;\n    @Input() refreshLabel: string = null;\n    @Input() viewAllNotificationsLabel: string = null;\n    @Input() headerTitleLabel: string = null;\n    @Input() noNotificationFoundLabel: string = null;\n    @Input() nbUnreadCount: number = null;\n    @Input() dateFormat = 'dd/MM/YYYY';\n    @Input({ transform: booleanAttribute }) noNotificationFoundLink = false;\n    @Input({ transform: booleanAttribute }) isShowMarkAsRead = true;\n    @Input({ transform: booleanAttribute }) isShowViewAllAction = true;\n    @Input({ transform: booleanAttribute })isHidePanelOnViewAllAction = true;\n    @Input({ transform: booleanAttribute }) customUnreadCount = false;\n    @Input({ transform: booleanAttribute }) isShowMarkAllAsReadButton = true;\n    @Input({ transform: booleanAttribute }) isShowSettingsButton = true;\n    @Input({ transform: booleanAttribute }) isShowRefreshButton = true;\n\n    @HostListener('body:click')\n    onHide(): void {\n        this.isOverlayActive = false;\n    }\n\n    onClicked(event: MouseEvent | Event): void {\n        this.notificationsClick.emit();\n        consumeEvent(event);\n        this.isOverlayActive = !this.isOverlayActive;\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.customUnreadCount) {\n            const customUnreadCount = changes.customUnreadCount.currentValue;\n            if (!customUnreadCount) {\n                this.nbUnreadCount = this._getUnreadCount();\n            }\n        }\n    }\n\n    ngOnInit(): void {\n        if (!this.customUnreadCount) {\n            this.nbUnreadCount = this._getUnreadCount();\n        }\n    }\n\n    onRefresh(event: Event): void {\n        this.refreshClick.emit();\n        consumeEvent(event);\n    }\n\n    onItemClick(link: UxLinkLegacy<NotificationMetadata>): void {\n        this.itemClick.emit(link);\n        consumeEvent(event);\n    }\n\n    onViewAllClick(event: Event): void {\n        this.viewAllClick.emit();\n        if (!this.isHidePanelOnViewAllAction) {\n            consumeEvent(event);\n        }\n    }\n\n    onNoNotificationFoundClick(): void {\n        this.noNotificationFoundClick.emit();\n    }\n\n    onItemMarkAsRead(link: UxLinkLegacy<NotificationMetadata>): void {\n        this.itemMarkAsReadClick.emit(link);\n    }\n\n    onMarkAllAsRead(e: MouseEvent): void {\n        this.markAllAsReadClick.emit(e);\n        consumeEvent(e);\n    }\n\n    onSettings(e: MouseEvent): void {\n        this.settingsClick.emit(e);\n        consumeEvent(e);\n    }\n\n    protected trackByFn(index: number, item: UxLinkLegacy<NotificationMetadata>): string {\n        return item.id;\n    }\n\n    private _getUnreadCount(): number {\n        const unreadNotifications = this.items.filter((link) => {\n            if (link.metadata) {\n                return link.metadata.read === false;\n            }\n            return false;\n        });\n        return unreadNotifications.length;\n    }\n}\n","<eui-icon-button\n    class=\"eui-notifications__trigger\"\n    icon=\"notifications:outline\"\n    fillColor=\"white\"\n    (click)=\"onClicked($event)\"\n    (keydown.enter)=\"onClicked($event)\"\n    (keydown.esc)=\"onHide()\">\n    <eui-badge *ngIf=\"count\" euiDanger [maxCharCount]=\"2\">{{ count }}</eui-badge>\n</eui-icon-button>\n\n<eui-overlay [isActive]=\"isOverlayActive\" class=\"eui-overlay-offset--width-30\">\n    <eui-overlay-header>\n        <div class=\"eui-notifications__header-title\">\n            <div class=\"eui-notifications__header-title-label\">\n                {{ headerTitleLabel ? headerTitleLabel : ('eui.MYNOTIFICATIONS' | translate) }}\n                <span\n                    *ngIf=\"items\"\n                    class=\"eui-u-cursor-help eui-u-ml-s\"\n                    attr.aria-label=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\"\n                    title=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\">\n                </span>\n                <eui-badge *ngIf=\"count\">{{ count }}</eui-badge>\n                <eui-badge *ngIf=\"!count\">{{ items.length }}</eui-badge>\n            </div>\n        </div>\n\n        <div *ngIf=\"items\" class=\"eui-notifications__header-actions\">\n            <button\n                euiButton\n                euiPrimary\n                euiRounded\n                euiIconButton\n                euiBasicButton\n                euiSizeS\n                type=\"button\"\n                *ngIf=\"isShowMarkAllAsReadButton\"\n                [attr.aria-label]=\"markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate)\"\n                title=\"{{ markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate) }}\"\n                (click)=\"onMarkAllAsRead($event)\">\n                <eui-icon-svg icon=\"checkmark-done:sharp\"></eui-icon-svg>\n            </button>\n            <button\n                euiButton\n                euiPrimary\n                euiRounded\n                euiIconButton\n                euiBasicButton\n                euiSizeS\n                type=\"button\"\n                *ngIf=\"isShowSettingsButton\"\n                [attr.aria-label]=\"settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate)\"\n                title=\"{{ settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate) }}\"\n                (click)=\"onSettings($event)\">\n                <eui-icon-svg icon=\"settings:sharp\"></eui-icon-svg>\n            </button>\n            <button\n                euiButton\n                euiPrimary\n                euiRounded\n                euiIconButton\n                euiBasicButton\n                euiSizeS\n                type=\"button\"\n                *ngIf=\"isShowRefreshButton\"\n                [attr.aria-label]=\"refreshLabel ? refreshLabel : ('eui.REFRESH' | translate)\"\n                title=\"{{ refreshLabel ? refreshLabel : ('eui.REFRESH' | translate) }}\"\n                (click)=\"onRefresh($event)\">\n                <eui-icon-svg icon=\"refresh:sharp\"></eui-icon-svg>\n            </button>\n        </div>\n    </eui-overlay-header>\n\n    <eui-overlay-body>\n        <ul class=\"eui-notifications-items\" *ngIf=\"items\">\n            <eui-notification-item\n                *ngFor=\"let item of items; trackBy: trackByFn\"\n                [item]=\"item\"\n                [dateFormat]=\"dateFormat\"\n                [markAsReadLabel]=\"markAsReadLabel\"\n                [isShowMarkAsRead]=\"isShowMarkAsRead\"\n                (itemClick)=\"onItemClick($event)\"\n                (itemMarkAsRead)=\"onItemMarkAsRead($event)\">\n            </eui-notification-item>\n        </ul>\n    </eui-overlay-body>\n\n    <eui-overlay-footer>\n        <ng-template [ngIf]=\"items?.length > 0\">\n            <a (click)=\"onViewAllClick($event)\" class=\"eui-u-text-link\">\n                <strong>{{ viewAllNotificationsLabel ? viewAllNotificationsLabel : ('eui.VIEWALLNOTIFICATIONS' | translate) }}</strong>\n            </a>\n        </ng-template>\n        <ng-template [ngIf]=\"items?.length === 0\">\n            <div class=\"ux-notification__item-content\" *ngIf=\"!noNotificationFoundLink\">\n                {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n            </div>\n            <div class=\"ux-notification__item-content\" *ngIf=\"noNotificationFoundLink\">\n                <a (click)=\"onNoNotificationFoundClick()\" class=\"eui-u-text-link\">\n                    {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n                </a>\n            </div>\n        </ng-template>\n    </eui-overlay-footer>\n</eui-overlay>\n"]}
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-notifications.component.js","sourceRoot":"","sources":["../../../../layout/eui-notifications/eui-notifications.component.ts","../../../../layout/eui-notifications/eui-notifications.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    booleanAttribute,\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { consumeEvent } from '@eui/core';\nimport { UxLinkLegacy } from '@eui/base';\nimport { NotificationMetadata } from './eui-notification-item.component';\n\n@Component({\n    selector: 'eui-notifications',\n    templateUrl: './eui-notifications.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    changeDetection: ChangeDetectionStrategy.Default,\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuiNotificationsComponent implements OnInit, OnChanges {\n    @Output() refreshClick: EventEmitter<void> = new EventEmitter<void>();\n    @Output() notificationsClick: EventEmitter<void> = new EventEmitter<void>();\n    @Output() viewAllClick: EventEmitter<void> = new EventEmitter<void>();\n    @Output() settingsClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n    @Output() markAllAsReadClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n    @Output() noNotificationFoundClick: EventEmitter<void> = new EventEmitter<void>();\n    @Output() itemClick: EventEmitter<UxLinkLegacy<NotificationMetadata>> = new EventEmitter<UxLinkLegacy<NotificationMetadata>>();\n    @Output() itemMarkAsReadClick: EventEmitter<UxLinkLegacy<NotificationMetadata>> = new EventEmitter<UxLinkLegacy<NotificationMetadata>>();\n\n    isOverlayActive = false;\n    currentDayNotifications = [];\n    oldestNotifications = [];\n    unreadNotifications = [];\n    today: Date = new Date();\n\n    @HostBinding('class') string = 'eui-notifications';\n\n    @Input() count: number = null;\n    @Input() items = [];\n    @Input() unreadLabel: string = null;\n    @Input() totalLabel: string = null;\n    @Input() markAsReadLabel: string = null;\n    @Input() markAsUnReadLabel: string = null;\n    @Input() markAllAsReadLabel: string = null;\n    @Input() settingsLabel: string = null;\n    @Input() refreshLabel: string = null;\n    @Input() viewAllNotificationsLabel: string = null;\n    @Input() headerTitleLabel: string = null;\n    @Input() noNotificationFoundLabel: string = null;\n    @Input() nbUnreadCount: number = null;\n    @Input() dateFormat = 'dd/MM/YYYY';\n    @Input({ transform: booleanAttribute }) noNotificationFoundLink = false;\n    @Input({ transform: booleanAttribute }) isShowMarkAsRead = true;\n    @Input({ transform: booleanAttribute }) isShowViewAllAction = true;\n    @Input({ transform: booleanAttribute })isHidePanelOnViewAllAction = true;\n    @Input({ transform: booleanAttribute }) customUnreadCount = false;\n    @Input({ transform: booleanAttribute }) isShowMarkAllAsReadButton = true;\n    @Input({ transform: booleanAttribute }) isShowSettingsButton = true;\n    @Input({ transform: booleanAttribute }) isShowRefreshButton = true;\n\n    @HostListener('body:click')\n    onHide(): void {\n        this.isOverlayActive = false;\n    }\n\n    onClicked(event: MouseEvent | Event): void {\n        this.notificationsClick.emit();\n        consumeEvent(event);\n        this.isOverlayActive = !this.isOverlayActive;\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.customUnreadCount) {\n            const customUnreadCount = changes.customUnreadCount.currentValue;\n            if (!customUnreadCount) {\n                this.nbUnreadCount = this._getUnreadCount();\n            }\n        }\n    }\n\n    ngOnInit(): void {\n        if (!this.customUnreadCount) {\n            this.nbUnreadCount = this._getUnreadCount();\n        }\n    }\n\n    onRefresh(event: Event): void {\n        this.refreshClick.emit();\n        consumeEvent(event);\n    }\n\n    onItemClick(link: UxLinkLegacy<NotificationMetadata>): void {\n        this.itemClick.emit(link);\n        consumeEvent(event);\n    }\n\n    onViewAllClick(event: Event): void {\n        this.viewAllClick.emit();\n        if (!this.isHidePanelOnViewAllAction) {\n            consumeEvent(event);\n        }\n    }\n\n    onNoNotificationFoundClick(): void {\n        this.noNotificationFoundClick.emit();\n    }\n\n    onItemMarkAsRead(link: UxLinkLegacy<NotificationMetadata>): void {\n        this.itemMarkAsReadClick.emit(link);\n    }\n\n    onMarkAllAsRead(e: MouseEvent): void {\n        this.markAllAsReadClick.emit(e);\n        consumeEvent(e);\n    }\n\n    onSettings(e: MouseEvent): void {\n        this.settingsClick.emit(e);\n        consumeEvent(e);\n    }\n\n    protected trackByFn(index: number, item: UxLinkLegacy<NotificationMetadata>): string {\n        return item.id;\n    }\n\n    private _getUnreadCount(): number {\n        const unreadNotifications = this.items.filter((link) => {\n            if (link.metadata) {\n                return link.metadata.read === false;\n            }\n            return false;\n        });\n        return unreadNotifications.length;\n    }\n}\n","<eui-icon-button\n    class=\"eui-notifications__trigger\"\n    icon=\"notifications:outline\"\n    fillColor=\"white\"\n    (click)=\"onClicked($event)\"\n    (keydown.enter)=\"onClicked($event)\"\n    (keydown.esc)=\"onHide()\">\n    <eui-badge *ngIf=\"count\" euiDanger [maxCharCount]=\"2\">{{ count }}</eui-badge>\n</eui-icon-button>\n\n<eui-overlay [isActive]=\"isOverlayActive\" class=\"eui-overlay-offset--width-30\">\n    <eui-overlay-header>\n        <div class=\"eui-notifications__header-title\">\n            <div class=\"eui-notifications__header-title-label\">\n                {{ headerTitleLabel ? headerTitleLabel : ('eui.MYNOTIFICATIONS' | translate) }}\n                <span\n                    *ngIf=\"items\"\n                    class=\"eui-u-cursor-help eui-u-ml-s\"\n                    attr.aria-label=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\"\n                    title=\"{{ unreadLabel ? unreadLabel : ('eui.NOTIFICATIONSUNREAD' | translate) }}\">\n                </span>\n                <eui-badge *ngIf=\"count\">{{ count }}</eui-badge>\n                <eui-badge *ngIf=\"!count\">{{ items.length }}</eui-badge>\n            </div>\n        </div>\n\n        <div *ngIf=\"items\" class=\"eui-notifications__header-actions\">\n            <button\n                euiButton\n                euiPrimary\n                euiRounded\n                euiIconButton\n                euiBasicButton\n                euiSizeS\n                type=\"button\"\n                *ngIf=\"isShowMarkAllAsReadButton\"\n                [attr.aria-label]=\"markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate)\"\n                title=\"{{ markAllAsReadLabel ? markAllAsReadLabel : ('eui.NOTIFICATIONMARKALLASREAD' | translate) }}\"\n                (click)=\"onMarkAllAsRead($event)\">\n                <eui-icon-svg icon=\"checkmark-done:outline\" fillColor=\"neutral\"></eui-icon-svg>\n            </button>\n            <button\n                euiButton\n                euiPrimary\n                euiRounded\n                euiIconButton\n                euiBasicButton\n                euiSizeS\n                type=\"button\"\n                *ngIf=\"isShowSettingsButton\"\n                [attr.aria-label]=\"settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate)\"\n                title=\"{{ settingsLabel ? settingsLabel : ('eui.SETTINGS' | translate) }}\"\n                (click)=\"onSettings($event)\">\n                <eui-icon-svg icon=\"settings:outline\" fillColor=\"neutral\"></eui-icon-svg>\n            </button>\n            <button\n                euiButton\n                euiPrimary\n                euiRounded\n                euiIconButton\n                euiBasicButton\n                euiSizeS\n                type=\"button\"\n                *ngIf=\"isShowRefreshButton\"\n                [attr.aria-label]=\"refreshLabel ? refreshLabel : ('eui.REFRESH' | translate)\"\n                title=\"{{ refreshLabel ? refreshLabel : ('eui.REFRESH' | translate) }}\"\n                (click)=\"onRefresh($event)\">\n                <eui-icon-svg icon=\"refresh:outline\" fillColor=\"neutral\"></eui-icon-svg>\n            </button>\n        </div>\n    </eui-overlay-header>\n\n    <eui-overlay-body>\n        <ul class=\"eui-notifications-items\" *ngIf=\"items\">\n            <eui-notification-item\n                *ngFor=\"let item of items; trackBy: trackByFn\"\n                [item]=\"item\"\n                [dateFormat]=\"dateFormat\"\n                [markAsReadLabel]=\"markAsReadLabel\"\n                [isShowMarkAsRead]=\"isShowMarkAsRead\"\n                (itemClick)=\"onItemClick($event)\"\n                (itemMarkAsRead)=\"onItemMarkAsRead($event)\">\n            </eui-notification-item>\n        </ul>\n    </eui-overlay-body>\n\n    <eui-overlay-footer>\n        <ng-template [ngIf]=\"items?.length > 0\">\n            <a (click)=\"onViewAllClick($event)\" class=\"eui-u-text-link\">\n                <strong>{{ viewAllNotificationsLabel ? viewAllNotificationsLabel : ('eui.VIEWALLNOTIFICATIONS' | translate) }}</strong>\n            </a>\n        </ng-template>\n        <ng-template [ngIf]=\"items?.length === 0\">\n            <div class=\"ux-notification__item-content\" *ngIf=\"!noNotificationFoundLink\">\n                {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n            </div>\n            <div class=\"ux-notification__item-content\" *ngIf=\"noNotificationFoundLink\">\n                <a (click)=\"onNoNotificationFoundClick()\" class=\"eui-u-text-link\">\n                    {{ noNotificationFoundLabel ? noNotificationFoundLabel : ('eui.NONOTIFICATIONFOUND' | translate) }}\n                </a>\n            </div>\n        </ng-template>\n    </eui-overlay-footer>\n</eui-overlay>\n"]}
@@ -1,5 +1,5 @@
1
1
  import { EventEmitter, TemplateRef, ChangeDetectorRef, SimpleChanges, OnInit, OnChanges, OnDestroy } from '@angular/core';
2
- import { TreeDataModel, TreeItemModel, TreeItemRunTimeModel, TreeItemSelectionRecursiveModel, EuiTreeSelectionChanges } from './eui-tree.model';
2
+ import { TreeDataModel, TreeItemModel, TreeItemRunTimeModel, TreeItemSelectionRecursiveModel, EuiTreeSelectionChanges, CustomNodeSelectFn } from './eui-tree.model';
3
3
  import { NestedTreeControl, CdkTree } from '@angular/cdk/tree';
4
4
  import { ArrayDataSource } from '@angular/cdk/collections';
5
5
  import { ScrollDispatcher, CdkScrollable } from '@angular/cdk/scrolling';
@@ -26,6 +26,7 @@ export declare class EuiTreeComponent implements OnInit, OnChanges, OnDestroy {
26
26
  nodeTemplateRef: TemplateRef<any>;
27
27
  nodeContentMetadataTemplateRef: TemplateRef<any>;
28
28
  rightContextMenuTemplateRef: TemplateRef<any>;
29
+ customNodeSelectFn: CustomNodeSelectFn;
29
30
  expandedIconClass: string;
30
31
  collapsedIconClass: string;
31
32
  expandedSvgIconClass: string;
@@ -54,6 +55,7 @@ export declare class EuiTreeComponent implements OnInit, OnChanges, OnDestroy {
54
55
  private treeDataRunTimeBackup;
55
56
  private runTimeSelectionRecursiveState;
56
57
  private selectionModel;
58
+ private tempSelectionModel;
57
59
  private selectionModelSubs;
58
60
  private scrollDispatcherSubs;
59
61
  private _selection;
@@ -84,6 +86,7 @@ export declare class EuiTreeComponent implements OnInit, OnChanges, OnDestroy {
84
86
  private overrideTreeDataModelForSelection;
85
87
  private runScrollListener;
86
88
  private getSelectionIndexOfItem;
89
+ private silentSelect;
87
90
  private selectTreeItem;
88
91
  private deselectTreeItem;
89
92
  private createTreeDataRuntime;
@@ -116,7 +119,7 @@ export declare class EuiTreeComponent implements OnInit, OnChanges, OnDestroy {
116
119
  private checkIfMultiLevel;
117
120
  private checkIfCurrentScrollable;
118
121
  static ɵfac: i0.ɵɵFactoryDeclaration<EuiTreeComponent, never>;
119
- static ɵcmp: i0.ɵɵComponentDeclaration<EuiTreeComponent, "eui-tree", never, { "e2eAttr": { "alias": "e2eAttr"; "required": false; }; "nodes": { "alias": "nodes"; "required": false; }; "nodeTemplateRef": { "alias": "nodeTemplateRef"; "required": false; }; "nodeContentMetadataTemplateRef": { "alias": "nodeContentMetadataTemplateRef"; "required": false; }; "rightContextMenuTemplateRef": { "alias": "rightContextMenuTemplateRef"; "required": false; }; "expandedIconClass": { "alias": "expandedIconClass"; "required": false; }; "collapsedIconClass": { "alias": "collapsedIconClass"; "required": false; }; "expandedSvgIconClass": { "alias": "expandedSvgIconClass"; "required": false; }; "collapsedSvgIconClass": { "alias": "collapsedSvgIconClass"; "required": false; }; "isClickTogglingNode": { "alias": "isClickTogglingNode"; "required": false; }; "isMultiselect": { "alias": "isMultiselect"; "required": false; }; "isSingleSelect": { "alias": "isSingleSelect"; "required": false; }; "isRecursiveSelection": { "alias": "isRecursiveSelection"; "required": false; }; "isRecursiveParentSelection": { "alias": "isRecursiveParentSelection"; "required": false; }; "showUnderlinedLinks": { "alias": "showUnderlinedLinks"; "required": false; }; "showLines": { "alias": "showLines"; "required": false; }; "autoTranslate": { "alias": "autoTranslate"; "required": false; }; "highlightPath": { "alias": "highlightPath"; "required": false; }; }, { "selectionChange": "selectionChange"; "nodeClick": "nodeClick"; "nodeToggle": "nodeToggle"; }, never, never, false, never>;
122
+ static ɵcmp: i0.ɵɵComponentDeclaration<EuiTreeComponent, "eui-tree", never, { "e2eAttr": { "alias": "e2eAttr"; "required": false; }; "nodes": { "alias": "nodes"; "required": false; }; "nodeTemplateRef": { "alias": "nodeTemplateRef"; "required": false; }; "nodeContentMetadataTemplateRef": { "alias": "nodeContentMetadataTemplateRef"; "required": false; }; "rightContextMenuTemplateRef": { "alias": "rightContextMenuTemplateRef"; "required": false; }; "customNodeSelectFn": { "alias": "customNodeSelectFn"; "required": false; }; "expandedIconClass": { "alias": "expandedIconClass"; "required": false; }; "collapsedIconClass": { "alias": "collapsedIconClass"; "required": false; }; "expandedSvgIconClass": { "alias": "expandedSvgIconClass"; "required": false; }; "collapsedSvgIconClass": { "alias": "collapsedSvgIconClass"; "required": false; }; "isClickTogglingNode": { "alias": "isClickTogglingNode"; "required": false; }; "isMultiselect": { "alias": "isMultiselect"; "required": false; }; "isSingleSelect": { "alias": "isSingleSelect"; "required": false; }; "isRecursiveSelection": { "alias": "isRecursiveSelection"; "required": false; }; "isRecursiveParentSelection": { "alias": "isRecursiveParentSelection"; "required": false; }; "showUnderlinedLinks": { "alias": "showUnderlinedLinks"; "required": false; }; "showLines": { "alias": "showLines"; "required": false; }; "autoTranslate": { "alias": "autoTranslate"; "required": false; }; "highlightPath": { "alias": "highlightPath"; "required": false; }; }, { "selectionChange": "selectionChange"; "nodeClick": "nodeClick"; "nodeToggle": "nodeToggle"; }, never, never, false, never>;
120
123
  static ngAcceptInputType_isClickTogglingNode: unknown;
121
124
  static ngAcceptInputType_isMultiselect: unknown;
122
125
  static ngAcceptInputType_isSingleSelect: unknown;
@@ -1 +1 @@
1
- {"version":3,"file":"eui-tree.component.d.ts","sourceRoot":"","sources":["../../eui-tree/eui-tree.component.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"eui-tree.component.d.ts","sourceRoot":"","sources":["../../eui-tree/eui-tree.component.ts"],"names":[],"mappings":"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"}
@@ -106,4 +106,13 @@ export declare class EuiTreePagination<T> {
106
106
  data: T[];
107
107
  };
108
108
  }
109
+ export declare class CustomNodeSelectFnHelper {
110
+ private compInstance;
111
+ constructor(compInstance: any);
112
+ select(path: string, isChecked: boolean): void;
113
+ getParents(path: string): Array<string>;
114
+ getTreeItem(path: string): TreeItemModel;
115
+ getSelectionRecursiveState(path: string): TreeItemSelectionRecursiveModel;
116
+ }
117
+ export type CustomNodeSelectFn = (path: string, isChecked: boolean, treeItem: TreeItemModel, helper: CustomNodeSelectFnHelper) => void;
109
118
  //# sourceMappingURL=eui-tree.model.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"eui-tree.model.d.ts","sourceRoot":"","sources":["../../eui-tree/eui-tree.model.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"eui-tree.model.d.ts","sourceRoot":"","sources":["../../eui-tree/eui-tree.model.ts"],"names":[],"mappings":"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"}
@@ -1,12 +1,12 @@
1
1
  import { OnInit, EventEmitter, OnDestroy } from '@angular/core';
2
- import { UserState } from '@eui/core';
2
+ import { UserProfile } from '../user-profile.component';
3
3
  import { UserService } from '@eui/core';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class EuiUserProfileCardComponent implements OnInit, OnDestroy {
6
6
  private userService;
7
7
  get cssClasses(): string;
8
8
  avatarInitials: string;
9
- userState: UserState;
9
+ userState: UserProfile;
10
10
  isOnline: boolean;
11
11
  impersonateLabel: string;
12
12
  showDetailsLabel: string;
@@ -15,7 +15,7 @@ export declare class EuiUserProfileCardComponent implements OnInit, OnDestroy {
15
15
  showProfileInfo: EventEmitter<void>;
16
16
  closeProfileMenu: EventEmitter<void>;
17
17
  private unsubscribeSubject$;
18
- constructor(userService: UserService);
18
+ constructor(userService: UserService<UserProfile>);
19
19
  ngOnInit(): void;
20
20
  ngOnDestroy(): void;
21
21
  onShowInfoClick(): void;
@@ -1 +1 @@
1
- {"version":3,"file":"user-profile-card.component.d.ts","sourceRoot":"","sources":["../../../eui-user-profile/user-profile-card/user-profile-card.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6E,MAAM,EAAE,YAAY,EAAU,SAAS,EAAoB,MAAM,eAAe,CAAC;AACrK,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AACtC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;;AAIxC,qBAMa,2BAA4B,YAAW,MAAM,EAAE,SAAS;IAqB7D,OAAO,CAAC,WAAW;IApBvB,IACW,UAAU,IAAI,MAAM,CAE9B;IAED,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,SAAS,CAAC;IACrB,QAAQ,UAAQ;IAEP,gBAAgB,SAAmB;IACnC,gBAAgB,SAA0B;IAC1C,SAAS,EAAE,MAAM,CAAC;IACa,oBAAoB,UAAS;IAE3D,eAAe,EAAE,YAAY,CAAC,IAAI,CAAC,CAAsB;IACzD,gBAAgB,EAAE,YAAY,CAAC,IAAI,CAAC,CAAsB;IAEpE,OAAO,CAAC,mBAAmB,CAAgC;gBAG/C,WAAW,EAAE,WAAW;IAGpC,QAAQ,IAAI,IAAI;IAgBhB,WAAW,IAAI,IAAI;IAKnB,eAAe,IAAI,IAAI;IAIvB,OAAO,IAAI,IAAI;yCAjDN,2BAA2B;2CAA3B,2BAA2B;mDAqDy9zB,OAAQ;CADxg0B"}
1
+ {"version":3,"file":"user-profile-card.component.d.ts","sourceRoot":"","sources":["../../../eui-user-profile/user-profile-card/user-profile-card.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6E,MAAM,EAAE,YAAY,EAAU,SAAS,EAAoB,MAAM,eAAe,CAAC;AACrK,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;;AAIxC,qBAMa,2BAA4B,YAAW,MAAM,EAAE,SAAS;IAqB7D,OAAO,CAAC,WAAW;IApBvB,IACW,UAAU,IAAI,MAAM,CAE9B;IAED,cAAc,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,UAAQ;IAEP,gBAAgB,SAAmB;IACnC,gBAAgB,SAA0B;IAC1C,SAAS,EAAE,MAAM,CAAC;IACa,oBAAoB,UAAS;IAE3D,eAAe,EAAE,YAAY,CAAC,IAAI,CAAC,CAAsB;IACzD,gBAAgB,EAAE,YAAY,CAAC,IAAI,CAAC,CAAsB;IAEpE,OAAO,CAAC,mBAAmB,CAAgC;gBAG/C,WAAW,EAAE,WAAW,CAAC,WAAW,CAAC;IAGjD,QAAQ,IAAI,IAAI;IAgBhB,WAAW,IAAI,IAAI;IAKnB,eAAe,IAAI,IAAI;IAIvB,OAAO,IAAI,IAAI;yCAjDN,2BAA2B;2CAA3B,2BAA2B;mDAqDw7zB,OAAQ;CADv+zB"}
@@ -7,7 +7,11 @@ import { EuiUserProfileMenuComponent } from './user-profile-menu/user-profile-me
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@eui/components/shared";
9
9
  export interface UserProfile extends UserState {
10
- impersonatingUser?: UserState;
10
+ impersonatingUser?: UserProfile;
11
+ function?: string;
12
+ organisation?: {
13
+ code: string;
14
+ };
11
15
  }
12
16
  export declare class EuiUserProfileComponent implements OnInit, OnDestroy, AfterViewInit {
13
17
  private elRef;
@@ -1 +1 @@
1
- {"version":3,"file":"user-profile.component.d.ts","sourceRoot":"","sources":["../../eui-user-profile/user-profile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6E,MAAM,EAAa,SAAS,EAAsE,SAAS,EAAE,aAAa,EAAmB,UAAU,EAA+B,MAAM,eAAe,CAAC;AAChS,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AACtC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExC,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AAEpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,2BAA2B,EAAE,MAAM,iDAAiD,CAAC;;;AAE9F,MAAM,WAAW,WAAY,SAAQ,SAAS;IAC1C,iBAAiB,CAAC,EAAE,SAAS,CAAC;CACjC;AAED,qBAiBa,uBAAwB,YAAW,MAAM,EAAE,SAAS,EAAE,aAAa;IA0CxE,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,WAAW;IACZ,mBAAmB,EAAE,mBAAmB;IA3CnD,IACW,UAAU,IAAI,MAAM,CAM9B;IAED,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,UAAQ;IAChB,cAAc,EAAE,MAAM,CAAC;IAEd,YAAY,SAAa;IACzB,gBAAgB,SAAmB;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,aAAa,SAAa;IAEK,OAAO,UAAS;IAChB,eAAe,UAAQ;IACvB,oBAAoB,UAAS;IAC7B,gBAAgB,UAAS;IACzB,SAAS,UAAS;IAClB,SAAS,UAAS;IAClB,mBAAmB,UAAS;IAC5B,eAAe,UAAQ;IAEvB,kBAAkB,UAAS;IAC3B,gBAAgB,UAAS;IACzB,eAAe,UAAS;IAEzC,QAAQ,EAAE,oBAAoB,CAAC;IAEtD,cAAc,EAAE,SAAS,CAAC,2BAA2B,CAAC,CAAC;IAEvD,cAAc,UAAS;IAEvB,OAAO,CAAC,mBAAmB,CAAgC;gBAG/C,KAAK,EAAE,UAAU,EACjB,WAAW,EAAE,WAAW,EACzB,mBAAmB,EAAE,mBAAmB;IAInD,QAAQ,IAAI,IAAI;IAchB,eAAe,IAAI,IAAI;IA0BvB,WAAW,IAAI,IAAI;IAKnB,aAAa,IAAI,IAAI;IAKrB,gBAAgB,CAAC,MAAM,EAAE,OAAO,GAAG,IAAI;yCAlG9B,uBAAuB;2CAAvB,uBAAuB;sCAsGysuB,OAAQ;8CAAR,OAAQ;mDAAR,OAAQ;+CAAR,OAAQ;wCAAR,OAAQ;wCAAR,OAAQ;kDAAR,OAAQ;8CAAR,OAAQ;iDAAR,OAAQ;+CAAR,OAAQ;8CAAR,OAAQ;CADpvuB"}
1
+ {"version":3,"file":"user-profile.component.d.ts","sourceRoot":"","sources":["../../eui-user-profile/user-profile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA6E,MAAM,EAAa,SAAS,EAAsE,SAAS,EAAE,aAAa,EAAmB,UAAU,EAA+B,MAAM,eAAe,CAAC;AAChS,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AACtC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAExC,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;AAEpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,2BAA2B,EAAE,MAAM,iDAAiD,CAAC;;;AAE9F,MAAM,WAAW,WAAY,SAAQ,SAAS;IAC1C,iBAAiB,CAAC,EAAE,WAAW,CAAC;IAChC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE;QACX,IAAI,EAAE,MAAM,CAAA;KACf,CAAA;CACJ;AAED,qBAiBa,uBAAwB,YAAW,MAAM,EAAE,SAAS,EAAE,aAAa;IA0CxE,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,WAAW;IACZ,mBAAmB,EAAE,mBAAmB;IA3CnD,IACW,UAAU,IAAI,MAAM,CAM9B;IAED,SAAS,EAAE,WAAW,CAAC;IACvB,QAAQ,UAAQ;IAChB,cAAc,EAAE,MAAM,CAAC;IAEd,YAAY,SAAa;IACzB,gBAAgB,SAAmB;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,aAAa,SAAa;IAEK,OAAO,UAAS;IAChB,eAAe,UAAQ;IACvB,oBAAoB,UAAS;IAC7B,gBAAgB,UAAS;IACzB,SAAS,UAAS;IAClB,SAAS,UAAS;IAClB,mBAAmB,UAAS;IAC5B,eAAe,UAAQ;IAEvB,kBAAkB,UAAS;IAC3B,gBAAgB,UAAS;IACzB,eAAe,UAAS;IAEzC,QAAQ,EAAE,oBAAoB,CAAC;IAEtD,cAAc,EAAE,SAAS,CAAC,2BAA2B,CAAC,CAAC;IAEvD,cAAc,UAAS;IAEvB,OAAO,CAAC,mBAAmB,CAAgC;gBAG/C,KAAK,EAAE,UAAU,EACjB,WAAW,EAAE,WAAW,EACzB,mBAAmB,EAAE,mBAAmB;IAInD,QAAQ,IAAI,IAAI;IAchB,eAAe,IAAI,IAAI;IA0BvB,WAAW,IAAI,IAAI;IAKnB,aAAa,IAAI,IAAI;IAKrB,gBAAgB,CAAC,MAAM,EAAE,OAAO,GAAG,IAAI;yCAlG9B,uBAAuB;2CAAvB,uBAAuB;sCAsGgouB,OAAQ;8CAAR,OAAQ;mDAAR,OAAQ;+CAAR,OAAQ;wCAAR,OAAQ;wCAAR,OAAQ;kDAAR,OAAQ;8CAAR,OAAQ;iDAAR,OAAQ;+CAAR,OAAQ;8CAAR,OAAQ;CAD3quB"}