@eui/components 18.0.0-rc.27 → 18.0.0-rc.29

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 (157) hide show
  1. package/docs/components/EuiChipComponent.html +1 -1
  2. package/docs/components/EuiIconStateComponent.html +1 -1
  3. package/docs/components/EuiMenuItemComponent.html +1 -0
  4. package/docs/components/EuiNotificationItemComponent.html +3 -3
  5. package/docs/components/EuiNotificationItemV2Component.html +1 -1
  6. package/docs/components/EuiNotificationsComponent.html +24 -92
  7. package/docs/components/EuiPaginatorComponent.html +1 -1
  8. package/docs/components/EuiTabComponent.html +0 -24
  9. package/docs/components/EuiTabLabelComponent.html +4 -11
  10. package/docs/components/EuiTabsComponent.html +1 -1
  11. package/docs/components/EuiTimelineComponent.html +55 -5
  12. package/docs/components/EuiTimelineItemComponent.html +0 -10
  13. package/docs/dependencies.html +1 -1
  14. package/docs/index.html +1 -1
  15. package/docs/interfaces/NotificationMetadata.html +546 -0
  16. package/docs/js/menu-wc.js +3 -0
  17. package/docs/js/menu-wc_es5.js +1 -1
  18. package/docs/js/search/search_index.js +2 -2
  19. package/esm2022/directives/eui-tooltip/container/eui-tooltip-container.component.mjs +3 -3
  20. package/esm2022/eui-alert/eui-alert.component.mjs +2 -2
  21. package/esm2022/eui-autocomplete/eui-autocomplete.component.mjs +3 -3
  22. package/esm2022/eui-avatar/eui-avatar.component.mjs +2 -2
  23. package/esm2022/eui-badge/eui-badge.component.mjs +2 -2
  24. package/esm2022/eui-button/eui-button.component.mjs +2 -2
  25. package/esm2022/eui-button-v2/eui-button-v2.component.mjs +2 -2
  26. package/esm2022/eui-card/eui-card.component.mjs +2 -2
  27. package/esm2022/eui-chip/eui-chip.component.mjs +3 -3
  28. package/esm2022/eui-date-range-selector/eui-date-range-selector.component.mjs +2 -2
  29. package/esm2022/eui-discussion-thread/eui-discussion-thread.component.mjs +2 -2
  30. package/esm2022/eui-feedback-message/eui-feedback-message.component.mjs +2 -2
  31. package/esm2022/eui-growl/eui-growl.component.mjs +2 -2
  32. package/esm2022/eui-icon/eui-icon-svg.component.mjs +2 -2
  33. package/esm2022/eui-icon-button/eui-icon-button.component.mjs +2 -2
  34. package/esm2022/eui-icon-state/eui-icon-state.component.mjs +3 -3
  35. package/esm2022/eui-input-checkbox/eui-input-checkbox.component.mjs +2 -2
  36. package/esm2022/eui-input-radio/eui-input-radio.component.mjs +2 -2
  37. package/esm2022/eui-label/eui-label.component.mjs +2 -2
  38. package/esm2022/eui-list/eui-list-item/eui-list-item.component.mjs +2 -2
  39. package/esm2022/eui-list/eui-list.component.mjs +2 -2
  40. package/esm2022/eui-menu/eui-menu-item.component.mjs +16 -2
  41. package/esm2022/eui-menu/eui-menu.component.mjs +2 -2
  42. package/esm2022/eui-menu/models/eui-menu-item.model.mjs +2 -2
  43. package/esm2022/eui-overlay/eui-overlay.component.mjs +2 -2
  44. package/esm2022/eui-page/eui-page.component.mjs +2 -2
  45. package/esm2022/eui-paginator/eui-paginator.component.mjs +3 -3
  46. package/esm2022/eui-progress-bar/eui-progress-bar.component.mjs +2 -2
  47. package/esm2022/eui-progress-circle/eui-progress-circle.component.mjs +2 -2
  48. package/esm2022/eui-slide-toggle/eui-slide-toggle.component.mjs +3 -3
  49. package/esm2022/eui-tabs/eui-tab/eui-tab.component.mjs +3 -7
  50. package/esm2022/eui-tabs/eui-tab-label/eui-tab-label.component.mjs +3 -22
  51. package/esm2022/eui-tabs/eui-tabs.component.mjs +3 -3
  52. package/esm2022/eui-textarea/eui-textarea.component.mjs +2 -2
  53. package/esm2022/eui-timebar/eui-timebar.component.mjs +2 -2
  54. package/esm2022/eui-timeline/eui-timeline-item.component.mjs +3 -5
  55. package/esm2022/eui-timeline/eui-timeline.component.mjs +31 -13
  56. package/esm2022/eui-tree-list/eui-tree-list.component.mjs +2 -2
  57. package/esm2022/eui-wizard/eui-wizard-step.component.mjs +2 -2
  58. package/esm2022/eui-wizard/eui-wizard.component.mjs +2 -2
  59. package/esm2022/externals/eui-editor/eui-editor.component.mjs +3 -3
  60. package/esm2022/layout/eui-app/eui-app-top-message/top-message.component.mjs +2 -2
  61. package/esm2022/layout/eui-header/header-environment/header-environment.component.mjs +2 -2
  62. package/esm2022/layout/eui-notifications/eui-notification-item.component.mjs +1 -1
  63. package/esm2022/layout/eui-notifications/eui-notifications.component.mjs +1 -25
  64. package/esm2022/layout/eui-notifications-v2/eui-notification-item.component.mjs +1 -1
  65. package/esm2022/layout/eui-toolbar/toolbar-menu/toolbar-menu.component.mjs +2 -2
  66. package/esm2022/layout/eui-toolbar/toolbar.component.mjs +3 -3
  67. package/eui-menu/eui-menu-item.component.d.ts +5 -4
  68. package/eui-menu/eui-menu-item.component.d.ts.map +1 -1
  69. package/eui-menu/eui-menu.component.d.ts.map +1 -1
  70. package/eui-tabs/eui-tab/eui-tab.component.d.ts +1 -3
  71. package/eui-tabs/eui-tab/eui-tab.component.d.ts.map +1 -1
  72. package/eui-tabs/eui-tab-label/eui-tab-label.component.d.ts +1 -1
  73. package/eui-tabs/eui-tab-label/eui-tab-label.component.d.ts.map +1 -1
  74. package/eui-timeline/eui-timeline-item.component.d.ts.map +1 -1
  75. package/eui-timeline/eui-timeline.component.d.ts +9 -1
  76. package/eui-timeline/eui-timeline.component.d.ts.map +1 -1
  77. package/fesm2022/eui-components-directives.mjs +2 -2
  78. package/fesm2022/eui-components-directives.mjs.map +1 -1
  79. package/fesm2022/eui-components-eui-alert.mjs +2 -2
  80. package/fesm2022/eui-components-eui-alert.mjs.map +1 -1
  81. package/fesm2022/eui-components-eui-autocomplete.mjs +2 -2
  82. package/fesm2022/eui-components-eui-autocomplete.mjs.map +1 -1
  83. package/fesm2022/eui-components-eui-avatar.mjs +2 -2
  84. package/fesm2022/eui-components-eui-avatar.mjs.map +1 -1
  85. package/fesm2022/eui-components-eui-badge.mjs +2 -2
  86. package/fesm2022/eui-components-eui-badge.mjs.map +1 -1
  87. package/fesm2022/eui-components-eui-button-v2.mjs +2 -2
  88. package/fesm2022/eui-components-eui-button-v2.mjs.map +1 -1
  89. package/fesm2022/eui-components-eui-button.mjs +2 -2
  90. package/fesm2022/eui-components-eui-button.mjs.map +1 -1
  91. package/fesm2022/eui-components-eui-card.mjs +2 -2
  92. package/fesm2022/eui-components-eui-card.mjs.map +1 -1
  93. package/fesm2022/eui-components-eui-chip.mjs +2 -2
  94. package/fesm2022/eui-components-eui-chip.mjs.map +1 -1
  95. package/fesm2022/eui-components-eui-date-range-selector.mjs +2 -2
  96. package/fesm2022/eui-components-eui-date-range-selector.mjs.map +1 -1
  97. package/fesm2022/eui-components-eui-discussion-thread.mjs +2 -2
  98. package/fesm2022/eui-components-eui-discussion-thread.mjs.map +1 -1
  99. package/fesm2022/eui-components-eui-feedback-message.mjs +2 -2
  100. package/fesm2022/eui-components-eui-feedback-message.mjs.map +1 -1
  101. package/fesm2022/eui-components-eui-growl.mjs +2 -2
  102. package/fesm2022/eui-components-eui-growl.mjs.map +1 -1
  103. package/fesm2022/eui-components-eui-icon-button.mjs +2 -2
  104. package/fesm2022/eui-components-eui-icon-button.mjs.map +1 -1
  105. package/fesm2022/eui-components-eui-icon-state.mjs +2 -2
  106. package/fesm2022/eui-components-eui-icon-state.mjs.map +1 -1
  107. package/fesm2022/eui-components-eui-icon.mjs +2 -2
  108. package/fesm2022/eui-components-eui-icon.mjs.map +1 -1
  109. package/fesm2022/eui-components-eui-input-checkbox.mjs +2 -2
  110. package/fesm2022/eui-components-eui-input-checkbox.mjs.map +1 -1
  111. package/fesm2022/eui-components-eui-input-radio.mjs +2 -2
  112. package/fesm2022/eui-components-eui-input-radio.mjs.map +1 -1
  113. package/fesm2022/eui-components-eui-label.mjs +2 -2
  114. package/fesm2022/eui-components-eui-label.mjs.map +1 -1
  115. package/fesm2022/eui-components-eui-list.mjs +4 -4
  116. package/fesm2022/eui-components-eui-list.mjs.map +1 -1
  117. package/fesm2022/eui-components-eui-menu.mjs +16 -3
  118. package/fesm2022/eui-components-eui-menu.mjs.map +1 -1
  119. package/fesm2022/eui-components-eui-overlay.mjs +2 -2
  120. package/fesm2022/eui-components-eui-overlay.mjs.map +1 -1
  121. package/fesm2022/eui-components-eui-page.mjs +2 -2
  122. package/fesm2022/eui-components-eui-page.mjs.map +1 -1
  123. package/fesm2022/eui-components-eui-paginator.mjs +2 -2
  124. package/fesm2022/eui-components-eui-paginator.mjs.map +1 -1
  125. package/fesm2022/eui-components-eui-progress-bar.mjs +2 -2
  126. package/fesm2022/eui-components-eui-progress-bar.mjs.map +1 -1
  127. package/fesm2022/eui-components-eui-progress-circle.mjs +2 -2
  128. package/fesm2022/eui-components-eui-progress-circle.mjs.map +1 -1
  129. package/fesm2022/eui-components-eui-slide-toggle.mjs +2 -2
  130. package/fesm2022/eui-components-eui-slide-toggle.mjs.map +1 -1
  131. package/fesm2022/eui-components-eui-tabs.mjs +6 -29
  132. package/fesm2022/eui-components-eui-tabs.mjs.map +1 -1
  133. package/fesm2022/eui-components-eui-textarea.mjs +2 -2
  134. package/fesm2022/eui-components-eui-textarea.mjs.map +1 -1
  135. package/fesm2022/eui-components-eui-timebar.mjs +2 -2
  136. package/fesm2022/eui-components-eui-timebar.mjs.map +1 -1
  137. package/fesm2022/eui-components-eui-timeline.mjs +32 -16
  138. package/fesm2022/eui-components-eui-timeline.mjs.map +1 -1
  139. package/fesm2022/eui-components-eui-tree-list.mjs +2 -2
  140. package/fesm2022/eui-components-eui-tree-list.mjs.map +1 -1
  141. package/fesm2022/eui-components-eui-wizard.mjs +4 -4
  142. package/fesm2022/eui-components-eui-wizard.mjs.map +1 -1
  143. package/fesm2022/eui-components-externals-eui-editor.mjs +2 -2
  144. package/fesm2022/eui-components-externals-eui-editor.mjs.map +1 -1
  145. package/fesm2022/eui-components-layout.mjs +7 -31
  146. package/fesm2022/eui-components-layout.mjs.map +1 -1
  147. package/layout/eui-app/eui-app-sidebar/sidebar-menu/sidebar-menu.component.d.ts +1 -1
  148. package/layout/eui-app/eui-app-sidebar/sidebar-menu/sidebar-menu.component.d.ts.map +1 -1
  149. package/layout/eui-notifications/eui-notification-item.component.d.ts +12 -3
  150. package/layout/eui-notifications/eui-notification-item.component.d.ts.map +1 -1
  151. package/layout/eui-notifications/eui-notifications.component.d.ts +16 -14
  152. package/layout/eui-notifications/eui-notifications.component.d.ts.map +1 -1
  153. package/layout/eui-notifications-v2/eui-notification-item.component.d.ts +2 -1
  154. package/layout/eui-notifications-v2/eui-notification-item.component.d.ts.map +1 -1
  155. package/layout/eui-toolbar/toolbar-menu/toolbar-menu.component.d.ts +1 -1
  156. package/layout/eui-toolbar/toolbar-menu/toolbar-menu.component.d.ts.map +1 -1
  157. package/package.json +3 -3
@@ -63,7 +63,7 @@ export class EuiAppTopMessageComponent {
63
63
  this.cd.detectChanges();
64
64
  }
65
65
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiAppTopMessageComponent, deps: [{ token: i1.EuiAppShellService }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i2.ContentObserver }, { token: i3.BaseStatesDirective }], target: i0.ɵɵFactoryTarget.Component }); }
66
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: EuiAppTopMessageComponent, selector: "eui-app-top-message", inputs: { isCloseable: ["isCloseable", "isCloseable", booleanAttribute], hasCustomContent: ["hasCustomContent", "hasCustomContent", booleanAttribute], isVisible: "isVisible" }, outputs: { topMessageClose: "topMessageClose" }, host: { properties: { "class": "this.cssClasses", "attr.role": "this.role" } }, viewQueries: [{ propertyName: "appTopMessage", first: true, predicate: ["appTopMessage"], descendants: true }], hostDirectives: [{ directive: i3.BaseStatesDirective, inputs: ["euiPrimary", "euiPrimary", "euiInfo", "euiInfo", "euiWarning", "euiWarning", "euiSuccess", "euiSuccess", "euiDanger", "euiDanger", "euiAccent", "euiAccent", "euiVariant", "euiVariant"] }], ngImport: i0, template: "<div class=\"eui-app-top-message__wrapper\" #appTopMessage>\n <div class=\"eui-app-top-message__content\">\n <ng-content></ng-content>\n </div>\n <eui-icon-button *ngIf=\"isCloseable\"\n icon=\"close:outline\"\n (buttonClick)=\"onCloseClick()\"\n ariaLabel=\"Close top message\"\n euiRounded\n class=\"eui-u-ml-auto\"/>\n</div>\n", styles: [".eui-app-top-message{padding:var(--eui-s-xs) var(--eui-s-s);position:fixed;width:100%;right:0;top:0;z-index:var(--eui-zi-top-message);background-color:var(--eui-c-danger);color:var(--eui-c-danger-contrast)}.eui-app-top-message__wrapper{display:flex;flex-direction:row;align-items:center;width:100%}.eui-app-top-message__content{display:flex;flex-direction:column;width:100%}.eui-app-top-message--primary{background-color:var(--eui-c-primary)}.eui-app-top-message--info{background-color:var(--eui-c-info)}.eui-app-top-message--success{background-color:var(--eui-c-success)}.eui-app-top-message--warning{background-color:var(--eui-c-warning)}.eui-app-top-message--danger{background-color:var(--eui-c-danger)}.eui-app-top-message--hidden{display:none}.eui-app-top-message--custom{padding:0}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.EuiIconButtonComponent, selector: "eui-icon-button", inputs: ["icon", "fillColor", "size", "ariaLabel", "tabindex", "hasNoPadding", "hasFocusHoverColor", "hasFocusHoverBg", "euiRounded", "euiDisabled"], outputs: ["buttonClick"] }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
66
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.0.0", type: EuiAppTopMessageComponent, selector: "eui-app-top-message", inputs: { isCloseable: ["isCloseable", "isCloseable", booleanAttribute], hasCustomContent: ["hasCustomContent", "hasCustomContent", booleanAttribute], isVisible: "isVisible" }, outputs: { topMessageClose: "topMessageClose" }, host: { properties: { "class": "this.cssClasses", "attr.role": "this.role" } }, viewQueries: [{ propertyName: "appTopMessage", first: true, predicate: ["appTopMessage"], descendants: true }], hostDirectives: [{ directive: i3.BaseStatesDirective, inputs: ["euiPrimary", "euiPrimary", "euiInfo", "euiInfo", "euiWarning", "euiWarning", "euiSuccess", "euiSuccess", "euiDanger", "euiDanger", "euiAccent", "euiAccent", "euiVariant", "euiVariant"] }], ngImport: i0, template: "<div class=\"eui-app-top-message__wrapper\" #appTopMessage>\n <div class=\"eui-app-top-message__content\">\n <ng-content></ng-content>\n </div>\n <eui-icon-button *ngIf=\"isCloseable\"\n icon=\"close:outline\"\n (buttonClick)=\"onCloseClick()\"\n ariaLabel=\"Close top message\"\n euiRounded\n class=\"eui-u-ml-auto\"/>\n</div>\n", styles: [".eui-app-top-message{padding:var(--eui-s-xs) var(--eui-s-s);position:fixed;width:100%;right:0;top:0;z-index:var(--eui-zi-top-message);background-color:var(--eui-c-danger-dark);color:var(--eui-c-danger-contrast)}.eui-app-top-message__wrapper{display:flex;flex-direction:row;align-items:center;width:100%}.eui-app-top-message__content{display:flex;flex-direction:column;width:100%}.eui-app-top-message--primary{background-color:var(--eui-c-primary)}.eui-app-top-message--info{background-color:var(--eui-c-info)}.eui-app-top-message--success{background-color:var(--eui-c-success-dark)}.eui-app-top-message--warning{background-color:var(--eui-c-warning)}.eui-app-top-message--danger{background-color:var(--eui-c-danger-dark)}.eui-app-top-message--hidden{display:none}.eui-app-top-message--custom{padding:0}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.EuiIconButtonComponent, selector: "eui-icon-button", inputs: ["icon", "fillColor", "size", "ariaLabel", "tabindex", "hasNoPadding", "hasFocusHoverColor", "hasFocusHoverBg", "euiRounded", "euiDisabled"], outputs: ["buttonClick"] }], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
67
67
  }
68
68
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiAppTopMessageComponent, decorators: [{
69
69
  type: Component,
@@ -80,7 +80,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
80
80
  'euiVariant',
81
81
  ],
82
82
  },
83
- ], template: "<div class=\"eui-app-top-message__wrapper\" #appTopMessage>\n <div class=\"eui-app-top-message__content\">\n <ng-content></ng-content>\n </div>\n <eui-icon-button *ngIf=\"isCloseable\"\n icon=\"close:outline\"\n (buttonClick)=\"onCloseClick()\"\n ariaLabel=\"Close top message\"\n euiRounded\n class=\"eui-u-ml-auto\"/>\n</div>\n", styles: [".eui-app-top-message{padding:var(--eui-s-xs) var(--eui-s-s);position:fixed;width:100%;right:0;top:0;z-index:var(--eui-zi-top-message);background-color:var(--eui-c-danger);color:var(--eui-c-danger-contrast)}.eui-app-top-message__wrapper{display:flex;flex-direction:row;align-items:center;width:100%}.eui-app-top-message__content{display:flex;flex-direction:column;width:100%}.eui-app-top-message--primary{background-color:var(--eui-c-primary)}.eui-app-top-message--info{background-color:var(--eui-c-info)}.eui-app-top-message--success{background-color:var(--eui-c-success)}.eui-app-top-message--warning{background-color:var(--eui-c-warning)}.eui-app-top-message--danger{background-color:var(--eui-c-danger)}.eui-app-top-message--hidden{display:none}.eui-app-top-message--custom{padding:0}\n"] }]
83
+ ], template: "<div class=\"eui-app-top-message__wrapper\" #appTopMessage>\n <div class=\"eui-app-top-message__content\">\n <ng-content></ng-content>\n </div>\n <eui-icon-button *ngIf=\"isCloseable\"\n icon=\"close:outline\"\n (buttonClick)=\"onCloseClick()\"\n ariaLabel=\"Close top message\"\n euiRounded\n class=\"eui-u-ml-auto\"/>\n</div>\n", styles: [".eui-app-top-message{padding:var(--eui-s-xs) var(--eui-s-s);position:fixed;width:100%;right:0;top:0;z-index:var(--eui-zi-top-message);background-color:var(--eui-c-danger-dark);color:var(--eui-c-danger-contrast)}.eui-app-top-message__wrapper{display:flex;flex-direction:row;align-items:center;width:100%}.eui-app-top-message__content{display:flex;flex-direction:column;width:100%}.eui-app-top-message--primary{background-color:var(--eui-c-primary)}.eui-app-top-message--info{background-color:var(--eui-c-info)}.eui-app-top-message--success{background-color:var(--eui-c-success-dark)}.eui-app-top-message--warning{background-color:var(--eui-c-warning)}.eui-app-top-message--danger{background-color:var(--eui-c-danger-dark)}.eui-app-top-message--hidden{display:none}.eui-app-top-message--custom{padding:0}\n"] }]
84
84
  }], ctorParameters: () => [{ type: i1.EuiAppShellService }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i2.ContentObserver }, { type: i3.BaseStatesDirective }], propDecorators: { cssClasses: [{
85
85
  type: HostBinding,
86
86
  args: ['class']
@@ -21,11 +21,11 @@ export class EuiHeaderEnvironmentComponent {
21
21
  });
22
22
  }
23
23
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiHeaderEnvironmentComponent, deps: [{ token: i1.EuiAppShellService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
24
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0", type: EuiHeaderEnvironmentComponent, isStandalone: true, selector: "eui-header-environment", host: { properties: { "class": "this.cssClass" } }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, styles: [".eui-header-environment{background-color:var(--eui-c-danger);color:var(--eui-c-white);font:var(--eui-f-xl);opacity:var(--eui-o-50);position:absolute;text-align:center;top:var(--eui-s-l);transform:rotate(-10deg);width:90%}\n"], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
24
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0", type: EuiHeaderEnvironmentComponent, isStandalone: true, selector: "eui-header-environment", host: { properties: { "class": "this.cssClass" } }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, styles: [".eui-header-environment{background-color:var(--eui-c-danger-dark);color:var(--eui-c-white);font:var(--eui-f-xl);opacity:var(--eui-o-50);position:absolute;text-align:center;top:var(--eui-s-l);transform:rotate(-10deg);width:90%}\n"], changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None }); }
25
25
  }
26
26
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImport: i0, type: EuiHeaderEnvironmentComponent, decorators: [{
27
27
  type: Component,
28
- args: [{ selector: 'eui-header-environment', template: '<ng-content></ng-content>', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, standalone: true, styles: [".eui-header-environment{background-color:var(--eui-c-danger);color:var(--eui-c-white);font:var(--eui-f-xl);opacity:var(--eui-o-50);position:absolute;text-align:center;top:var(--eui-s-l);transform:rotate(-10deg);width:90%}\n"] }]
28
+ args: [{ selector: 'eui-header-environment', template: '<ng-content></ng-content>', changeDetection: ChangeDetectionStrategy.Default, encapsulation: ViewEncapsulation.None, standalone: true, styles: [".eui-header-environment{background-color:var(--eui-c-danger-dark);color:var(--eui-c-white);font:var(--eui-f-xl);opacity:var(--eui-o-50);position:absolute;text-align:center;top:var(--eui-s-l);transform:rotate(-10deg);width:90%}\n"] }]
29
29
  }], ctorParameters: () => [{ type: i1.EuiAppShellService }, { type: i0.ElementRef }], propDecorators: { cssClass: [{
30
30
  type: HostBinding,
31
31
  args: ['class']
@@ -51,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
51
51
  type: Input,
52
52
  args: [{ transform: booleanAttribute }]
53
53
  }] } });
54
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-notification-item.component.js","sourceRoot":"","sources":["../../../../layout/eui-notifications/eui-notification-item.component.ts","../../../../layout/eui-notifications/eui-notification-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEtG,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;;;;;;AAMzC,MAAM,OAAO,4BAA4B;IAJzC;QAK0B,WAAM,GAAG,uBAAuB,CAAC;QAC7C,cAAS,GAA+B,IAAI,YAAY,EAAgB,CAAC;QACzE,mBAAc,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAC/E,oBAAe,GAAW,IAAI,CAAC;QAI/B,eAAU,GAAG,YAAY,CAAC;QACnC,gBAAW,GAAG,MAAM,CAAC;QACkB,qBAAgB,GAAG,IAAI,CAAC;KAkBlE;IAhBG,WAAW;QACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,gBAAgB,CAAC,KAAY;QACzB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACrB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,YAAY,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,eAAe,CAAC;IAC3E,CAAC;8GA1BQ,4BAA4B;kGAA5B,4BAA4B,sLAUjB,gBAAgB,sJClBxC,ypHAsEA;;2FD9Da,4BAA4B;kBAJxC,SAAS;+BACI,uBAAuB;8BAIX,MAAM;sBAA3B,WAAW;uBAAC,OAAO;gBACV,SAAS;sBAAlB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACE,eAAe;sBAAvB,KAAK;gBAGG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEiC,gBAAgB;sBAAtD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { booleanAttribute, Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';\nimport { UxLinkLegacy } from '@eui/core';\nimport { consumeEvent } from '@eui/core';\n\n@Component({\n    selector: 'eui-notification-item',\n    templateUrl: './eui-notification-item.component.html',\n})\nexport class EuiNotificationItemComponent {\n    @HostBinding('class') string = 'eui-notification-item';\n    @Output() itemClick: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Output() itemMarkAsRead: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Input() markAsReadLabel: string = null;\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() item: any;\n    @Input() dateFormat = 'dd/MM/YYYY';\n    tooltipSize = 'auto';\n    @Input({ transform: booleanAttribute })isShowMarkAsRead = true;\n\n    onItemClick(): void {\n        this.itemClick.emit(this.item);\n    }\n\n    onItemMarkAsRead(event: Event): void {\n        if (this.item.metadata) {\n            this.item.metadata.read = true;\n        }\n        this.itemMarkAsRead.emit(this.item);\n        consumeEvent(event);\n    }\n\n    get iconColor(): string {\n        return this.item.metadata?.read ? 'neutral-lightest' : 'neutral-light';\n    }\n\n}\n","<div\n    class=\"eui-notification-item-content\"\n    (click)=\"onItemClick()\"\n    [ngClass]=\"{ 'eui-u-c-bg-white': item.metadata?.read || !item.metadata }\">\n    <div class=\"eui-notification-item-content-top eui-u-f-s\">\n        <div *ngIf=\"item.metadata?.date\" class=\"eui-notification-item-content-top__date\">\n            <span class=\"eui-notification-item-content-top__date-icon eui-u-mr-s\">\n                <eui-icon-svg icon=\"notifications:sharp\" size=\"m\" [fillColor]=\"iconColor\"></eui-icon-svg>\n                <span\n                    *ngIf=\"item.metadata?.new\"\n                    class=\"eui-notification-item-content-top__date-dot eui-u-c-danger-light eui-u-f-s eui-icon eui-icon-circle\"></span>\n            </span>\n            <span>{{ item.metadata?.date | date: dateFormat }}</span>\n        </div>\n        <div *ngIf=\"item.metadata?.important\" class=\"eui-u-f-m-bold\">\n            <eui-icon-svg icon=\"alert:sharp\" fillColor=\"danger\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n        </div>\n    </div>\n    <span class=\"eui-notification-item-content-middle eui-u-cursor-pointer\">\n        <ng-template [ngIf]=\"item.metadata?.url\">\n            <a class=\"eui-u-text-link\" href=\"{{ item.metadata.url }}\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"item.metadata?.urlExternal\">\n            <a class=\"eui-u-text-link-external\"\n                href=\"{{ item.metadata.urlExternal }}\"\n                [target]=\"!item.metadata.urlExternalTarget ? '_blank' : item.metadata.urlExternalTarget\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"!item.metadata?.url && !item.metadata?.urlExternal\">\n            <div\n                class=\"eui-notification-item-content-middle__label\"\n                [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                {{ item.label | translate | euiTruncate: 200 }}\n            </div>\n            <div\n                *ngIf=\"item.subLabel\"\n                class=\"eui-notification-item-content-middle__sub-label\"\n                [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n        </ng-template>\n    </span>\n    <div class=\"eui-notification-item-content-bottom\">\n        <a *ngIf=\"isShowMarkAsRead && item.metadata && !item.metadata.read\"\n            href=\"javascript:void(0)\"\n            class=\"eui-u-text-link\"\n            (click)=\"onItemMarkAsRead($event)\">\n            {{ markAsReadLabel ? markAsReadLabel : ('eui.NOTIFICATIONMARKASREAD' | translate) }}\n        </a>\n    </div>\n</div>\n"]}
54
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-notification-item.component.js","sourceRoot":"","sources":["../../../../layout/eui-notifications/eui-notification-item.component.ts","../../../../layout/eui-notifications/eui-notification-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEtG,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;;;;;;AAgBzC,MAAM,OAAO,4BAA4B;IAJzC;QAK0B,WAAM,GAAG,uBAAuB,CAAC;QAC7C,cAAS,GAAqD,IAAI,YAAY,EAAsC,CAAC;QACrH,mBAAc,GAAqD,IAAI,YAAY,EAAsC,CAAC;QAC3H,oBAAe,GAAW,IAAI,CAAC;QAE/B,eAAU,GAAG,YAAY,CAAC;QACnC,gBAAW,GAAG,MAAM,CAAC;QACkB,qBAAgB,GAAG,IAAI,CAAC;KAkBlE;IAhBG,WAAW;QACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,gBAAgB,CAAC,KAAY;QACzB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACrB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,YAAY,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,eAAe,CAAC;IAC3E,CAAC;8GAxBQ,4BAA4B;kGAA5B,4BAA4B,sLAQjB,gBAAgB,sJC1BxC,ypHAsEA;;2FDpDa,4BAA4B;kBAJxC,SAAS;+BACI,uBAAuB;8BAIX,MAAM;sBAA3B,WAAW;uBAAC,OAAO;gBACV,SAAS;sBAAlB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACE,eAAe;sBAAvB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEiC,gBAAgB;sBAAtD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { booleanAttribute, Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';\nimport { UxLinkLegacy } from '@eui/core';\nimport { consumeEvent } from '@eui/core';\n\nexport interface NotificationMetadata {\n    read?: boolean;\n    urlExternal?: string;\n    urlExternalTarget?: string;\n    important?: boolean;\n    new?: boolean;\n    url?: string;\n    date?: Date | string | number;\n}\n\n@Component({\n    selector: 'eui-notification-item',\n    templateUrl: './eui-notification-item.component.html',\n})\nexport class EuiNotificationItemComponent {\n    @HostBinding('class') string = 'eui-notification-item';\n    @Output() itemClick: EventEmitter<UxLinkLegacy<NotificationMetadata>> = new EventEmitter<UxLinkLegacy<NotificationMetadata>>();\n    @Output() itemMarkAsRead: EventEmitter<UxLinkLegacy<NotificationMetadata>> = new EventEmitter<UxLinkLegacy<NotificationMetadata>>();\n    @Input() markAsReadLabel: string = null;\n    @Input() item: UxLinkLegacy<NotificationMetadata>;\n    @Input() dateFormat = 'dd/MM/YYYY';\n    tooltipSize = 'auto';\n    @Input({ transform: booleanAttribute })isShowMarkAsRead = true;\n\n    onItemClick(): void {\n        this.itemClick.emit(this.item);\n    }\n\n    onItemMarkAsRead(event: Event): void {\n        if (this.item.metadata) {\n            this.item.metadata.read = true;\n        }\n        this.itemMarkAsRead.emit(this.item);\n        consumeEvent(event);\n    }\n\n    get iconColor(): string {\n        return this.item.metadata?.read ? 'neutral-lightest' : 'neutral-light';\n    }\n\n}\n","<div\n    class=\"eui-notification-item-content\"\n    (click)=\"onItemClick()\"\n    [ngClass]=\"{ 'eui-u-c-bg-white': item.metadata?.read || !item.metadata }\">\n    <div class=\"eui-notification-item-content-top eui-u-f-s\">\n        <div *ngIf=\"item.metadata?.date\" class=\"eui-notification-item-content-top__date\">\n            <span class=\"eui-notification-item-content-top__date-icon eui-u-mr-s\">\n                <eui-icon-svg icon=\"notifications:sharp\" size=\"m\" [fillColor]=\"iconColor\"></eui-icon-svg>\n                <span\n                    *ngIf=\"item.metadata?.new\"\n                    class=\"eui-notification-item-content-top__date-dot eui-u-c-danger-light eui-u-f-s eui-icon eui-icon-circle\"></span>\n            </span>\n            <span>{{ item.metadata?.date | date: dateFormat }}</span>\n        </div>\n        <div *ngIf=\"item.metadata?.important\" class=\"eui-u-f-m-bold\">\n            <eui-icon-svg icon=\"alert:sharp\" fillColor=\"danger\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n        </div>\n    </div>\n    <span class=\"eui-notification-item-content-middle eui-u-cursor-pointer\">\n        <ng-template [ngIf]=\"item.metadata?.url\">\n            <a class=\"eui-u-text-link\" href=\"{{ item.metadata.url }}\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"item.metadata?.urlExternal\">\n            <a class=\"eui-u-text-link-external\"\n                href=\"{{ item.metadata.urlExternal }}\"\n                [target]=\"!item.metadata.urlExternalTarget ? '_blank' : item.metadata.urlExternalTarget\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"!item.metadata?.url && !item.metadata?.urlExternal\">\n            <div\n                class=\"eui-notification-item-content-middle__label\"\n                [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                {{ item.label | translate | euiTruncate: 200 }}\n            </div>\n            <div\n                *ngIf=\"item.subLabel\"\n                class=\"eui-notification-item-content-middle__sub-label\"\n                [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n        </ng-template>\n    </span>\n    <div class=\"eui-notification-item-content-bottom\">\n        <a *ngIf=\"isShowMarkAsRead && item.metadata && !item.metadata.read\"\n            href=\"javascript:void(0)\"\n            class=\"eui-u-text-link\"\n            (click)=\"onItemMarkAsRead($event)\">\n            {{ markAsReadLabel ? markAsReadLabel : ('eui.NOTIFICATIONMARKASREAD' | translate) }}\n        </a>\n    </div>\n</div>\n"]}
@@ -11,29 +11,13 @@ import * as i7 from "./eui-notification-item.component";
11
11
  import * as i8 from "@ngx-translate/core";
12
12
  export class EuiNotificationsComponent {
13
13
  constructor() {
14
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
15
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
16
14
  this.refreshClick = new EventEmitter();
17
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
18
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
19
15
  this.notificationsClick = new EventEmitter();
20
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
21
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
22
16
  this.viewAllClick = new EventEmitter();
23
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
24
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
25
17
  this.settingsClick = new EventEmitter();
26
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
27
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
28
18
  this.markAllAsReadClick = new EventEmitter();
29
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
30
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
31
19
  this.noNotificationFoundClick = new EventEmitter();
32
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
33
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
34
20
  this.itemClick = new EventEmitter();
35
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
36
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
37
21
  this.itemMarkAsReadClick = new EventEmitter();
38
22
  this.isOverlayActive = false;
39
23
  this.currentDayNotifications = [];
@@ -67,8 +51,6 @@ export class EuiNotificationsComponent {
67
51
  onHide() {
68
52
  this.isOverlayActive = false;
69
53
  }
70
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
71
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
72
54
  onClicked(event) {
73
55
  this.notificationsClick.emit();
74
56
  consumeEvent(event);
@@ -91,8 +73,6 @@ export class EuiNotificationsComponent {
91
73
  this.refreshClick.emit();
92
74
  consumeEvent(event);
93
75
  }
94
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
95
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
96
76
  onItemClick(link) {
97
77
  this.itemClick.emit(link);
98
78
  consumeEvent(event);
@@ -106,8 +86,6 @@ export class EuiNotificationsComponent {
106
86
  onNoNotificationFoundClick() {
107
87
  this.noNotificationFoundClick.emit();
108
88
  }
109
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
110
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
111
89
  onItemMarkAsRead(link) {
112
90
  this.itemMarkAsReadClick.emit(link);
113
91
  }
@@ -119,8 +97,6 @@ export class EuiNotificationsComponent {
119
97
  this.settingsClick.emit(e);
120
98
  consumeEvent(e);
121
99
  }
122
- // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
123
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
124
100
  trackByFn(index, item) {
125
101
  return item.id;
126
102
  }
@@ -214,4 +190,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
214
190
  type: HostListener,
215
191
  args: ['body:click']
216
192
  }] } });
217
- //# 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';\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    // 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    @Output() refreshClick: EventEmitter<any> = new EventEmitter<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    @Output() notificationsClick: EventEmitter<any> = new EventEmitter<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    @Output() viewAllClick: EventEmitter<any> = new EventEmitter<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    @Output() settingsClick: EventEmitter<any> = new EventEmitter<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    @Output() markAllAsReadClick: EventEmitter<any> = new EventEmitter<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    @Output() noNotificationFoundClick: EventEmitter<any> = new EventEmitter<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    @Output() itemClick: EventEmitter<any> = new EventEmitter<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    @Output() itemMarkAsReadClick: EventEmitter<any> = new EventEmitter<any>();\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    // 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    onClicked(event: any): 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    // 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    onItemClick(link: any): 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    // 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    onItemMarkAsRead(link: any): void {\n        this.itemMarkAsReadClick.emit(link);\n    }\n\n    onMarkAllAsRead(e): void {\n        this.markAllAsReadClick.emit(e);\n        consumeEvent(e);\n    }\n\n    onSettings(e): void {\n        this.settingsClick.emit(e);\n        consumeEvent(e);\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    trackByFn(index: number, item: any): void {\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: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"]}
@@ -51,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
51
51
  type: Input,
52
52
  args: [{ transform: booleanAttribute }]
53
53
  }] } });
54
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-notification-item.component.js","sourceRoot":"","sources":["../../../../layout/eui-notifications-v2/eui-notification-item.component.ts","../../../../layout/eui-notifications-v2/eui-notification-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEtG,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;;;;;;AAMzC,MAAM,OAAO,8BAA8B;IAJ3C;QAK0B,WAAM,GAAG,uBAAuB,CAAC;QAC7C,cAAS,GAA+B,IAAI,YAAY,EAAgB,CAAC;QACzE,mBAAc,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAC/E,oBAAe,GAAW,IAAI,CAAC;QAE/B,eAAU,GAAG,YAAY,CAAC;QACnC,gBAAW,GAAG,MAAM,CAAC;QACmB,qBAAgB,GAAG,IAAI,CAAC;KAiBnE;IAfG,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,eAAe,CAAC;IAC3E,CAAC;IAED,WAAW;QACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,gBAAgB,CAAC,KAAY;QACzB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACrB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,YAAY,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;8GAxBQ,8BAA8B;kGAA9B,8BAA8B,yLAQnB,gBAAgB,sJChBxC,utHAuEA;;2FD/Da,8BAA8B;kBAJ1C,SAAS;+BACI,0BAA0B;8BAId,MAAM;sBAA3B,WAAW;uBAAC,OAAO;gBACV,SAAS;sBAAlB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACE,eAAe;sBAAvB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEkC,gBAAgB;sBAAvD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { booleanAttribute, Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';\nimport { UxLinkLegacy } from '@eui/core';\nimport { consumeEvent } from '@eui/core';\n\n@Component({\n    selector: 'eui-notification-item-v2',\n    templateUrl: './eui-notification-item.component.html',\n})\nexport class EuiNotificationItemV2Component {\n    @HostBinding('class') string = 'eui-notification-item';\n    @Output() itemClick: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Output() itemMarkAsRead: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Input() markAsReadLabel: string = null;\n    @Input() item: UxLinkLegacy;\n    @Input() dateFormat = 'dd/MM/YYYY';\n    tooltipSize = 'auto';\n    @Input({ transform: booleanAttribute }) isShowMarkAsRead = true;\n\n    get iconColor(): string {\n        return this.item.metadata?.read ? 'neutral-lightest' : 'neutral-light';\n    }\n\n    onItemClick(): void {\n        this.itemClick.emit(this.item);\n    }\n\n    onItemMarkAsRead(event: Event): void {\n        if (this.item.metadata) {\n            this.item.metadata.read = true;\n        }\n        this.itemMarkAsRead.emit(this.item);\n        consumeEvent(event);\n    }\n}\n","<div\n    class=\"eui-notification-item-content\"\n    (click)=\"onItemClick()\"\n    [ngClass]=\"{ 'eui-u-c-bg-white': item.metadata?.read || !item.metadata }\">\n    <div class=\"eui-notification-item-content-top eui-u-f-s\">\n        <div *ngIf=\"item.metadata?.date\" class=\"eui-notification-item-content-top__date\">\n            <span class=\"eui-notification-item-content-top__date-icon eui-u-mr-s\">\n                <eui-icon-svg icon=\"notifications:sharp\" size=\"m\" [fillColor]=\"iconColor\"></eui-icon-svg>\n                <span\n                    *ngIf=\"item.metadata?.new\"\n                    class=\"eui-notification-item-content-top__date-dot eui-u-c-danger-light eui-u-f-s eui-icon eui-icon-circle\"></span>\n            </span>\n            <span>{{ item.metadata?.date | date: dateFormat }}</span>\n        </div>\n        <div *ngIf=\"item.metadata?.important\" class=\"eui-u-f-m-bold\">\n            <eui-icon-svg icon=\"alert:sharp\" fillColor=\"danger-100\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n        </div>\n    </div>\n    <span class=\"eui-notification-item-content-middle eui-u-cursor-pointer\">\n        <ng-template [ngIf]=\"item.metadata?.url\">\n            <a class=\"eui-u-text-link\" href=\"{{ item.metadata.url }}\" tabIndex=\"0\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"item.metadata?.urlExternal\">\n            <a class=\"eui-u-text-link-external\"\n                href=\"{{ item.metadata.urlExternal }}\"\n                [target]=\"!item.metadata.urlExternalTarget ? '_blank' : item.metadata.urlExternalTarget\" tabIndex=\"0\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"!item.metadata?.url && !item.metadata?.urlExternal\">\n            <div\n                class=\"eui-notification-item-content-middle__label\"\n                [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                {{ item.label | translate | euiTruncate: 200 }}\n            </div>\n            <div\n                *ngIf=\"item.subLabel\"\n                class=\"eui-notification-item-content-middle__sub-label\"\n                [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n        </ng-template>\n    </span>\n    <div class=\"eui-notification-item-content-bottom\">\n        <a\n            class=\"eui-u-text-link\"\n            *ngIf=\"isShowMarkAsRead && item.metadata && !item.metadata.read\"\n            href=\"javascript:void(0)\"\n            (click)=\"onItemMarkAsRead($event)\" tabIndex=\"0\">\n            {{ markAsReadLabel ? markAsReadLabel : ('eui.NOTIFICATIONMARKASREAD' | translate) }}\n        </a>\n    </div>\n</div>\n"]}
54
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-notification-item.component.js","sourceRoot":"","sources":["../../../../layout/eui-notifications-v2/eui-notification-item.component.ts","../../../../layout/eui-notifications-v2/eui-notification-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEtG,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;;;;;;AAOzC,MAAM,OAAO,8BAA8B;IAJ3C;QAK0B,WAAM,GAAG,uBAAuB,CAAC;QAC7C,cAAS,GAA+B,IAAI,YAAY,EAAgB,CAAC;QACzE,mBAAc,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAC/E,oBAAe,GAAW,IAAI,CAAC;QAE/B,eAAU,GAAG,YAAY,CAAC;QACnC,gBAAW,GAAG,MAAM,CAAC;QACmB,qBAAgB,GAAG,IAAI,CAAC;KAiBnE;IAfG,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,eAAe,CAAC;IAC3E,CAAC;IAED,WAAW;QACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,gBAAgB,CAAC,KAAY;QACzB,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACrB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpC,YAAY,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;8GAxBQ,8BAA8B;kGAA9B,8BAA8B,yLAQnB,gBAAgB,sJCjBxC,utHAuEA;;2FD9Da,8BAA8B;kBAJ1C,SAAS;+BACI,0BAA0B;8BAId,MAAM;sBAA3B,WAAW;uBAAC,OAAO;gBACV,SAAS;sBAAlB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACE,eAAe;sBAAvB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEkC,gBAAgB;sBAAvD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import { booleanAttribute, Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';\nimport { UxLinkLegacy } from '@eui/core';\nimport { consumeEvent } from '@eui/core';\nimport { NotificationMetadata } from '../eui-notifications';\n\n@Component({\n    selector: 'eui-notification-item-v2',\n    templateUrl: './eui-notification-item.component.html',\n})\nexport class EuiNotificationItemV2Component {\n    @HostBinding('class') string = 'eui-notification-item';\n    @Output() itemClick: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Output() itemMarkAsRead: EventEmitter<UxLinkLegacy> = new EventEmitter<UxLinkLegacy>();\n    @Input() markAsReadLabel: string = null;\n    @Input() item: UxLinkLegacy<NotificationMetadata>;\n    @Input() dateFormat = 'dd/MM/YYYY';\n    tooltipSize = 'auto';\n    @Input({ transform: booleanAttribute }) isShowMarkAsRead = true;\n\n    get iconColor(): string {\n        return this.item.metadata?.read ? 'neutral-lightest' : 'neutral-light';\n    }\n\n    onItemClick(): void {\n        this.itemClick.emit(this.item);\n    }\n\n    onItemMarkAsRead(event: Event): void {\n        if (this.item.metadata) {\n            this.item.metadata.read = true;\n        }\n        this.itemMarkAsRead.emit(this.item);\n        consumeEvent(event);\n    }\n}\n","<div\n    class=\"eui-notification-item-content\"\n    (click)=\"onItemClick()\"\n    [ngClass]=\"{ 'eui-u-c-bg-white': item.metadata?.read || !item.metadata }\">\n    <div class=\"eui-notification-item-content-top eui-u-f-s\">\n        <div *ngIf=\"item.metadata?.date\" class=\"eui-notification-item-content-top__date\">\n            <span class=\"eui-notification-item-content-top__date-icon eui-u-mr-s\">\n                <eui-icon-svg icon=\"notifications:sharp\" size=\"m\" [fillColor]=\"iconColor\"></eui-icon-svg>\n                <span\n                    *ngIf=\"item.metadata?.new\"\n                    class=\"eui-notification-item-content-top__date-dot eui-u-c-danger-light eui-u-f-s eui-icon eui-icon-circle\"></span>\n            </span>\n            <span>{{ item.metadata?.date | date: dateFormat }}</span>\n        </div>\n        <div *ngIf=\"item.metadata?.important\" class=\"eui-u-f-m-bold\">\n            <eui-icon-svg icon=\"alert:sharp\" fillColor=\"danger-100\" class=\"eui-u-ml-xs\"></eui-icon-svg>\n        </div>\n    </div>\n    <span class=\"eui-notification-item-content-middle eui-u-cursor-pointer\">\n        <ng-template [ngIf]=\"item.metadata?.url\">\n            <a class=\"eui-u-text-link\" href=\"{{ item.metadata.url }}\" tabIndex=\"0\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"item.metadata?.urlExternal\">\n            <a class=\"eui-u-text-link-external\"\n                href=\"{{ item.metadata.urlExternal }}\"\n                [target]=\"!item.metadata.urlExternalTarget ? '_blank' : item.metadata.urlExternalTarget\" tabIndex=\"0\">\n                <div\n                    class=\"eui-notification-item-content-middle__label\"\n                    [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                    {{ item.label | translate | euiTruncate: 200 }}\n                </div>\n                <div\n                    *ngIf=\"item.subLabel\"\n                    class=\"eui-notification-item-content-middle__sub-label\"\n                    [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n            </a>\n        </ng-template>\n\n        <ng-template [ngIf]=\"!item.metadata?.url && !item.metadata?.urlExternal\">\n            <div\n                class=\"eui-notification-item-content-middle__label\"\n                [ngClass]=\"{ 'eui-u-f-m-bold': !item.metadata || (item.metadata && !item.metadata.read) }\">\n                {{ item.label | translate | euiTruncate: 200 }}\n            </div>\n            <div\n                *ngIf=\"item.subLabel\"\n                class=\"eui-notification-item-content-middle__sub-label\"\n                [innerHTML]=\"item.subLabel | translate | euiTruncate: 200\"></div>\n        </ng-template>\n    </span>\n    <div class=\"eui-notification-item-content-bottom\">\n        <a\n            class=\"eui-u-text-link\"\n            *ngIf=\"isShowMarkAsRead && item.metadata && !item.metadata.read\"\n            href=\"javascript:void(0)\"\n            (click)=\"onItemMarkAsRead($event)\" tabIndex=\"0\">\n            {{ markAsReadLabel ? markAsReadLabel : ('eui.NOTIFICATIONMARKASREAD' | translate) }}\n        </a>\n    </div>\n</div>\n"]}
@@ -72,7 +72,7 @@ export class EuiToolbarMenuComponent {
72
72
  });
73
73
  }
74
74
  if (link.urlExternal) {
75
- window.open(link.urlExternal, link?.urlExternalTarget);
75
+ window.open(link.urlExternal, link?.urlExternalTarget || '_blank');
76
76
  }
77
77
  if (link.command) {
78
78
  link.command();
@@ -159,4 +159,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0", ngImpor
159
159
  }], menuItemClick: [{
160
160
  type: Output
161
161
  }] } });
162
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-menu.component.js","sourceRoot":"","sources":["../../../../../layout/eui-toolbar/toolbar-menu/toolbar-menu.component.ts","../../../../../layout/eui-toolbar/toolbar-menu/toolbar-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    SimpleChanges,\n    OnInit,\n    OnDestroy,\n    Output,\n    EventEmitter,\n    ChangeDetectorRef,\n    OnChanges,\n} from '@angular/core';\nimport { EuiAppShellService } from '@eui/core';\nimport { EuiMenuItem } from '@eui/components/eui-menu';\nimport { Subscription } from 'rxjs';\nimport { EuiIconModule } from '@eui/components/eui-icon';\nimport { NgFor, NgForOf, NgIf } from '@angular/common';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { RouterLink } from '@angular/router';\n\n@Component({\n    selector: 'eui-toolbar-menu',\n    templateUrl: './toolbar-menu.component.html',\n    styleUrl: './toolbar-menu.component.scss',\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [\n        EuiIconModule,\n        NgFor,\n        NgForOf,\n        NgIf,\n        RouterLink,\n        TranslateModule,\n    ],\n})\nexport class EuiToolbarMenuComponent implements OnInit, OnDestroy, OnChanges {\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return 'eui-toolbar-menu';\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() items: any[];\n\n    @Output() menuItemClick = new EventEmitter<EuiMenuItem>();\n\n    isdropdownOpen = false;\n\n    private subs: Subscription;\n\n    constructor(\n        public asService: EuiAppShellService,\n        private cd: ChangeDetectorRef,\n    ) {\n        this.subs = new Subscription();\n    }\n\n    ngOnInit(): void {\n        this.asService.setState({\n            ...this.asService.state,\n            hasToolbarMenu: true,\n        });\n\n        // subscribe to state changes\n        this.subs.add(this.asService.getState('menuLinks').subscribe((links) => (this.items = links)));\n    }\n\n    ngOnDestroy(): void {\n        this.subs.unsubscribe();\n        this.asService.setState({\n            ...this.asService.state,\n            hasToolbarMenu: false,\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.items) {\n            this.asService.setState({\n                ...this.asService.state,\n                menuLinks: changes.items.currentValue,\n            });\n        }\n    }\n\n    onLinkClick(link: EuiMenuItem): void {\n        if (link.url) {\n            window.scrollTo(0, 0);\n        }\n        if (!link.disabled && link.children) {\n            this.menuItemClick.emit(link);\n        }\n        if (!link.disabled && !link.children) {\n            this.menuItemClick.emit(link);\n\n            // click on dropitems to close dropdown\n            const dropdown = document.querySelectorAll('#top-menu li:hover > ul');\n            dropdown.forEach((menus) => {\n                menus.classList.remove('show');\n                menus.classList.remove('showOnEnter');\n            });\n\n            // open again on mouseover\n            const dropBtns = document.querySelectorAll('#top-menu li:hover');\n            dropBtns.forEach((btn) => {\n                btn.addEventListener('mouseover', (e) => {\n                    const dropContent = btn.querySelector('#top-menu li:hover > ul');\n                    const shouldOpen = dropContent ? !dropContent.classList.contains('show') : null;\n                    e.preventDefault();\n\n                    if (shouldOpen) {\n                        dropContent.classList.add('show');\n                    }\n                    e.stopPropagation();\n                });\n            });\n        }\n        if (link.urlExternal) {\n            window.open(link.urlExternal, link?.urlExternalTarget);\n        }\n        if (link.command) {\n            link.command();\n        }\n    }\n\n    onKeyDown(event: KeyboardEvent, link: EuiMenuItem): void {\n        switch (event.key) {\n            case 'Enter': {\n                if (link.url) {\n                    window.scrollTo(0, 0);\n                }\n                if (link.children) {\n                    this.menuItemClick.emit(link);\n                    this.isdropdownOpen = true;\n                }\n                if (!link.children) {\n                    this.menuItemClick.emit(link);\n                    this.isdropdownOpen = false;\n                }\n                if (link.urlExternal) {\n                    window.open(link.urlExternal, link.urlExternal);\n                }\n                if (link.command) {\n                    link.command();\n                }\n                break;\n            }\n            case 'Tab': {\n                if (this.isdropdownOpen) {\n                    const lastchild = Array.from(document.querySelectorAll('.child > a')).reverse()[0] as HTMLElement;\n                    lastchild.onblur = (): void => {\n                        // last child onblur\n                        if (!event.shiftKey) {\n                            this.isdropdownOpen = false;\n                            this.cd.detectChanges();\n                            // eslint-disable-next-line @typescript-eslint/no-empty-function\n                            lastchild.onblur = (): void => {};\n                        }\n                    };\n                }\n                break;\n            }\n            case 'Escape': {\n                this.isdropdownOpen = false;\n                break;\n            }\n            default:\n                break;\n        }\n\n        if (event.shiftKey && event.key === 'Tab') {\n            if (this.isdropdownOpen) {\n                const firstchild = Array.from(document.querySelectorAll('.child > a'))[0] as HTMLElement;\n                firstchild.onblur = (): void => {\n                    // first child onblur\n                    this.isdropdownOpen = false;\n                    this.cd.detectChanges();\n                    // eslint-disable-next-line @typescript-eslint/no-empty-function\n                    firstchild.onblur = (): void => {};\n                };\n                if (link.children) {\n                    this.isdropdownOpen = false;\n                }\n            }\n        }\n    }\n}\n","<nav id=\"top-menu\" class=\"eui-toolbar-menu-content\" *ngIf=\"items && items.length !== 0\">\n    <ul>\n        <ng-container *ngFor=\"let link of items\">\n            <li *ngIf=\"link.visible === undefined || link.visible === true\" [class.has-sub]=\"link.children\" [class.selected]=\"link.active\" routerLinkActive=\"selected\">\n                <a\n                    *ngIf=\"!link.url\"\n                    [class.disabled]=\"link.disabled\"\n                    [tabindex]=\"!link.disabled ? 0 : -1\"\n                    (click)=\"onLinkClick(link)\"\n                    (keydown)=\"onKeyDown($event, link)\"\n                    title=\"{{ link.label | translate }}\"\n                    [class.icon-home-link]=\"link.isHome\">\n                    <div class=\"eui-u-flex\">\n                        <eui-icon-svg\n                            *ngIf=\"link.iconSvgName\"\n                            [icon]=\"link.iconSvgName\"\n                            [fillColor]=\"link.active ? 'neutral' : 'white'\"\n                            class=\"eui-u-mr-xs\">\n                        </eui-icon-svg>\n                        <span *ngIf=\"link.iconClass && !link.iconSvgName\" class=\"{{ link.iconClass }} eui-icon\"></span>\n                        <span class=\"eui-toolbar-menu-label\">{{ link.label | translate }}</span>\n                        <eui-icon-svg *ngIf=\"link.children\" icon=\"chevron-down:sharp\" [fillColor]=\"link.active ? 'neutral' : 'white'\" size=\"s\">\n                        </eui-icon-svg>\n                    </div>\n                </a>\n                <a\n                    *ngIf=\"link.url\"\n                    [routerLink]=\"link.url\"\n                    [class.disabled]=\"link.disabled\"\n                    (click)=\"onLinkClick(link)\"\n                    (keydown)=\"onKeyDown($event, link)\"\n                    title=\"{{ link.label | translate }}\"\n                    [class.icon-home-link]=\"link.isHome\">\n                    <div class=\"eui-u-flex\">\n                        <eui-icon-svg\n                            *ngIf=\"link.iconSvgName\"\n                            [icon]=\"link.iconSvgName\"\n                            [fillColor]=\"link.active ? 'neutral' : 'white'\"\n                            size=\"s\"\n                            class=\"eui-u-mr-xs\">\n                        </eui-icon-svg>\n                        <span *ngIf=\"link.iconClass && !link.iconSvgName\" class=\"{{ link.iconClass }} eui-icon\"></span>\n                        <span class=\"eui-toolbar-menu-label\">{{ link.label | translate }}</span>\n                        <eui-icon-svg\n                            *ngIf=\"link.children\"\n                            icon=\"chevron-down:sharp\"\n                            [fillColor]=\"link.active ? 'neutral' : 'white'\"\n                            size=\"s\"\n                            class=\"eui-u-ml-xs\">\n                        </eui-icon-svg>\n                    </div>\n                </a>\n\n                <ul class=\"show\" [class.showOnEnter]=\"isdropdownOpen\" *ngIf=\"link.children\">\n                    <ng-container *ngFor=\"let childLink of link.children\">\n                        <li\n                            *ngIf=\"childLink.visible === undefined || childLink.visible === true\"\n                            class=\"child\"\n                            [class.has-sub]=\"childLink?.children\"\n                            [class.separator]=\"childLink.isSeparator\">\n                            <a\n                                *ngIf=\"!childLink.url\"\n                                [tabindex]=\"isdropdownOpen && !childLink.disabled ? 0 : -1\"\n                                [class.disabled]=\"childLink.disabled\"\n                                (click)=\"onLinkClick(childLink)\"\n                                (keydown)=\"onKeyDown($event, childLink)\">\n                                <span *ngIf=\"childLink.iconClass\" class=\"eui-toolbar-menu-item__icon eui-icon {{ childLink.iconClass }}\"></span>\n                                <eui-icon-svg\n                                    *ngIf=\"childLink.iconSvgName\"\n                                    class=\"eui-toolbar-menu-item__icon\"\n                                    icon=\"{{ childLink.iconSvgName }}\"></eui-icon-svg>\n                                <span class=\"eui-toolbar-menu-item__label\">{{ childLink.label | translate }}</span>\n                            </a>\n                            <a\n                                *ngIf=\"childLink.url\"\n                                [tabindex]=\"isdropdownOpen && !childLink.disabled ? 0 : -1\"\n                                [class.disabled]=\"childLink.disabled\"\n                                [routerLink]=\"childLink.url\"\n                                (click)=\"onLinkClick(childLink)\"\n                                (keydown)=\"onKeyDown($event, childLink)\">\n                                <span *ngIf=\"childLink.iconClass\" class=\"eui-toolbar-menu-item__icon eui-icon {{ childLink.iconClass }}\"></span>\n                                <eui-icon-svg\n                                    *ngIf=\"childLink.iconSvgName\"\n                                    class=\"eui-toolbar-menu-item__icon\"\n                                    icon=\"{{ childLink.iconSvgName }}\"></eui-icon-svg>\n                                <span class=\"eui-toolbar-menu-item__label\">{{ childLink.label | translate }}</span>\n                            </a>\n\n                            <ul class=\"show\" [class.showOnEnter]=\"isdropdownOpen\" *ngIf=\"childLink.children\">\n                                <ng-container *ngFor=\"let childSubLink of childLink.children\">\n                                    <li *ngIf=\"childSubLink.visible === undefined || childSubLink.visible === true\" class=\"child\" [class.separator]=\"childSubLink.isSeparator\">\n                                        <a\n                                            *ngIf=\"childSubLink.url\"\n                                            [tabindex]=\"isdropdownOpen && !childSubLink.disabled ? 0 : -1\"\n                                            [class.disabled]=\"childSubLink.disabled\"\n                                            [routerLink]=\"childSubLink.url\"\n                                            (click)=\"onLinkClick(childSubLink)\"\n                                            (keydown)=\"onKeyDown($event, childSubLink)\">\n                                            <span\n                                                *ngIf=\"childSubLink.iconClass\"\n                                                class=\"eui-toolbar-menu-item__icon eui-icon {{ childSubLink.iconClass }}\"></span>\n                                            <eui-icon-svg\n                                                *ngIf=\"childSubLink.iconSvgName\"\n                                                class=\"eui-toolbar-menu-item__icon\"\n                                                icon=\"{{ childSubLink.iconSvgName }}\"></eui-icon-svg>\n                                            <span class=\"eui-toolbar-menu-item__label\">{{ childSubLink.label | translate }}</span>\n                                        </a>\n                                        <a\n                                            *ngIf=\"!childSubLink.url\"\n                                            [tabindex]=\"isdropdownOpen && !childSubLink.disabled ? 0 : -1\"\n                                            [class.disabled]=\"childSubLink.disabled\"\n                                            (click)=\"onLinkClick(childSubLink)\"\n                                            (keydown)=\"onKeyDown($event, childSubLink)\">\n                                            <span\n                                                *ngIf=\"childSubLink.iconClass\"\n                                                class=\"eui-toolbar-menu-item__icon eui-icon {{ childSubLink.iconClass }}\"></span>\n                                            <eui-icon-svg\n                                                *ngIf=\"childSubLink.iconSvgName\"\n                                                class=\"eui-toolbar-menu-item__icon\"\n                                                icon=\"{{ childSubLink.iconSvgName }}\"></eui-icon-svg>\n                                            <span class=\"eui-toolbar-menu-item__label\">{{ childSubLink.label | translate }}</span>\n                                        </a>\n                                    </li>\n                                </ng-container>\n                            </ul>\n                        </li>\n                    </ng-container>\n                </ul>\n            </li>\n        </ng-container>\n    </ul>\n</nav>\n"]}
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbar-menu.component.js","sourceRoot":"","sources":["../../../../../layout/eui-toolbar/toolbar-menu/toolbar-menu.component.ts","../../../../../layout/eui-toolbar/toolbar-menu/toolbar-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    ViewEncapsulation,\n    Input,\n    SimpleChanges,\n    OnInit,\n    OnDestroy,\n    Output,\n    EventEmitter,\n    ChangeDetectorRef,\n    OnChanges,\n} from '@angular/core';\nimport { EuiAppShellService } from '@eui/core';\nimport { EuiMenuItem } from '@eui/components/eui-menu';\nimport { Subscription } from 'rxjs';\nimport { EuiIconModule } from '@eui/components/eui-icon';\nimport { NgFor, NgForOf, NgIf } from '@angular/common';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { RouterLink } from '@angular/router';\n\n@Component({\n    selector: 'eui-toolbar-menu',\n    templateUrl: './toolbar-menu.component.html',\n    styleUrl: './toolbar-menu.component.scss',\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [\n        EuiIconModule,\n        NgFor,\n        NgForOf,\n        NgIf,\n        RouterLink,\n        TranslateModule,\n    ],\n})\nexport class EuiToolbarMenuComponent implements OnInit, OnDestroy, OnChanges {\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return 'eui-toolbar-menu';\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    @Input() items: any[];\n\n    @Output() menuItemClick = new EventEmitter<EuiMenuItem>();\n\n    isdropdownOpen = false;\n\n    private subs: Subscription;\n\n    constructor(\n        public asService: EuiAppShellService,\n        private cd: ChangeDetectorRef,\n    ) {\n        this.subs = new Subscription();\n    }\n\n    ngOnInit(): void {\n        this.asService.setState({\n            ...this.asService.state,\n            hasToolbarMenu: true,\n        });\n\n        // subscribe to state changes\n        this.subs.add(this.asService.getState('menuLinks').subscribe((links) => (this.items = links)));\n    }\n\n    ngOnDestroy(): void {\n        this.subs.unsubscribe();\n        this.asService.setState({\n            ...this.asService.state,\n            hasToolbarMenu: false,\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.items) {\n            this.asService.setState({\n                ...this.asService.state,\n                menuLinks: changes.items.currentValue,\n            });\n        }\n    }\n\n    onLinkClick(link: EuiMenuItem): void {\n        if (link.url) {\n            window.scrollTo(0, 0);\n        }\n        if (!link.disabled && link.children) {\n            this.menuItemClick.emit(link);\n        }\n        if (!link.disabled && !link.children) {\n            this.menuItemClick.emit(link);\n\n            // click on dropitems to close dropdown\n            const dropdown = document.querySelectorAll('#top-menu li:hover > ul');\n            dropdown.forEach((menus) => {\n                menus.classList.remove('show');\n                menus.classList.remove('showOnEnter');\n            });\n\n            // open again on mouseover\n            const dropBtns = document.querySelectorAll('#top-menu li:hover');\n            dropBtns.forEach((btn) => {\n                btn.addEventListener('mouseover', (e) => {\n                    const dropContent = btn.querySelector('#top-menu li:hover > ul');\n                    const shouldOpen = dropContent ? !dropContent.classList.contains('show') : null;\n                    e.preventDefault();\n\n                    if (shouldOpen) {\n                        dropContent.classList.add('show');\n                    }\n                    e.stopPropagation();\n                });\n            });\n        }\n        if (link.urlExternal) {\n            window.open(link.urlExternal, link?.urlExternalTarget || '_blank');\n        }\n        if (link.command) {\n            link.command();\n        }\n    }\n\n    onKeyDown(event: KeyboardEvent, link: EuiMenuItem): void {\n        switch (event.key) {\n            case 'Enter': {\n                if (link.url) {\n                    window.scrollTo(0, 0);\n                }\n                if (link.children) {\n                    this.menuItemClick.emit(link);\n                    this.isdropdownOpen = true;\n                }\n                if (!link.children) {\n                    this.menuItemClick.emit(link);\n                    this.isdropdownOpen = false;\n                }\n                if (link.urlExternal) {\n                    window.open(link.urlExternal, link.urlExternal);\n                }\n                if (link.command) {\n                    link.command();\n                }\n                break;\n            }\n            case 'Tab': {\n                if (this.isdropdownOpen) {\n                    const lastchild = Array.from(document.querySelectorAll('.child > a')).reverse()[0] as HTMLElement;\n                    lastchild.onblur = (): void => {\n                        // last child onblur\n                        if (!event.shiftKey) {\n                            this.isdropdownOpen = false;\n                            this.cd.detectChanges();\n                            // eslint-disable-next-line @typescript-eslint/no-empty-function\n                            lastchild.onblur = (): void => {};\n                        }\n                    };\n                }\n                break;\n            }\n            case 'Escape': {\n                this.isdropdownOpen = false;\n                break;\n            }\n            default:\n                break;\n        }\n\n        if (event.shiftKey && event.key === 'Tab') {\n            if (this.isdropdownOpen) {\n                const firstchild = Array.from(document.querySelectorAll('.child > a'))[0] as HTMLElement;\n                firstchild.onblur = (): void => {\n                    // first child onblur\n                    this.isdropdownOpen = false;\n                    this.cd.detectChanges();\n                    // eslint-disable-next-line @typescript-eslint/no-empty-function\n                    firstchild.onblur = (): void => {};\n                };\n                if (link.children) {\n                    this.isdropdownOpen = false;\n                }\n            }\n        }\n    }\n}\n","<nav id=\"top-menu\" class=\"eui-toolbar-menu-content\" *ngIf=\"items && items.length !== 0\">\n    <ul>\n        <ng-container *ngFor=\"let link of items\">\n            <li *ngIf=\"link.visible === undefined || link.visible === true\" [class.has-sub]=\"link.children\" [class.selected]=\"link.active\" routerLinkActive=\"selected\">\n                <a\n                    *ngIf=\"!link.url\"\n                    [class.disabled]=\"link.disabled\"\n                    [tabindex]=\"!link.disabled ? 0 : -1\"\n                    (click)=\"onLinkClick(link)\"\n                    (keydown)=\"onKeyDown($event, link)\"\n                    title=\"{{ link.label | translate }}\"\n                    [class.icon-home-link]=\"link.isHome\">\n                    <div class=\"eui-u-flex\">\n                        <eui-icon-svg\n                            *ngIf=\"link.iconSvgName\"\n                            [icon]=\"link.iconSvgName\"\n                            [fillColor]=\"link.active ? 'neutral' : 'white'\"\n                            class=\"eui-u-mr-xs\">\n                        </eui-icon-svg>\n                        <span *ngIf=\"link.iconClass && !link.iconSvgName\" class=\"{{ link.iconClass }} eui-icon\"></span>\n                        <span class=\"eui-toolbar-menu-label\">{{ link.label | translate }}</span>\n                        <eui-icon-svg *ngIf=\"link.children\" icon=\"chevron-down:sharp\" [fillColor]=\"link.active ? 'neutral' : 'white'\" size=\"s\">\n                        </eui-icon-svg>\n                    </div>\n                </a>\n                <a\n                    *ngIf=\"link.url\"\n                    [routerLink]=\"link.url\"\n                    [class.disabled]=\"link.disabled\"\n                    (click)=\"onLinkClick(link)\"\n                    (keydown)=\"onKeyDown($event, link)\"\n                    title=\"{{ link.label | translate }}\"\n                    [class.icon-home-link]=\"link.isHome\">\n                    <div class=\"eui-u-flex\">\n                        <eui-icon-svg\n                            *ngIf=\"link.iconSvgName\"\n                            [icon]=\"link.iconSvgName\"\n                            [fillColor]=\"link.active ? 'neutral' : 'white'\"\n                            size=\"s\"\n                            class=\"eui-u-mr-xs\">\n                        </eui-icon-svg>\n                        <span *ngIf=\"link.iconClass && !link.iconSvgName\" class=\"{{ link.iconClass }} eui-icon\"></span>\n                        <span class=\"eui-toolbar-menu-label\">{{ link.label | translate }}</span>\n                        <eui-icon-svg\n                            *ngIf=\"link.children\"\n                            icon=\"chevron-down:sharp\"\n                            [fillColor]=\"link.active ? 'neutral' : 'white'\"\n                            size=\"s\"\n                            class=\"eui-u-ml-xs\">\n                        </eui-icon-svg>\n                    </div>\n                </a>\n\n                <ul class=\"show\" [class.showOnEnter]=\"isdropdownOpen\" *ngIf=\"link.children\">\n                    <ng-container *ngFor=\"let childLink of link.children\">\n                        <li\n                            *ngIf=\"childLink.visible === undefined || childLink.visible === true\"\n                            class=\"child\"\n                            [class.has-sub]=\"childLink?.children\"\n                            [class.separator]=\"childLink.isSeparator\">\n                            <a\n                                *ngIf=\"!childLink.url\"\n                                [tabindex]=\"isdropdownOpen && !childLink.disabled ? 0 : -1\"\n                                [class.disabled]=\"childLink.disabled\"\n                                (click)=\"onLinkClick(childLink)\"\n                                (keydown)=\"onKeyDown($event, childLink)\">\n                                <span *ngIf=\"childLink.iconClass\" class=\"eui-toolbar-menu-item__icon eui-icon {{ childLink.iconClass }}\"></span>\n                                <eui-icon-svg\n                                    *ngIf=\"childLink.iconSvgName\"\n                                    class=\"eui-toolbar-menu-item__icon\"\n                                    icon=\"{{ childLink.iconSvgName }}\"></eui-icon-svg>\n                                <span class=\"eui-toolbar-menu-item__label\">{{ childLink.label | translate }}</span>\n                            </a>\n                            <a\n                                *ngIf=\"childLink.url\"\n                                [tabindex]=\"isdropdownOpen && !childLink.disabled ? 0 : -1\"\n                                [class.disabled]=\"childLink.disabled\"\n                                [routerLink]=\"childLink.url\"\n                                (click)=\"onLinkClick(childLink)\"\n                                (keydown)=\"onKeyDown($event, childLink)\">\n                                <span *ngIf=\"childLink.iconClass\" class=\"eui-toolbar-menu-item__icon eui-icon {{ childLink.iconClass }}\"></span>\n                                <eui-icon-svg\n                                    *ngIf=\"childLink.iconSvgName\"\n                                    class=\"eui-toolbar-menu-item__icon\"\n                                    icon=\"{{ childLink.iconSvgName }}\"></eui-icon-svg>\n                                <span class=\"eui-toolbar-menu-item__label\">{{ childLink.label | translate }}</span>\n                            </a>\n\n                            <ul class=\"show\" [class.showOnEnter]=\"isdropdownOpen\" *ngIf=\"childLink.children\">\n                                <ng-container *ngFor=\"let childSubLink of childLink.children\">\n                                    <li *ngIf=\"childSubLink.visible === undefined || childSubLink.visible === true\" class=\"child\" [class.separator]=\"childSubLink.isSeparator\">\n                                        <a\n                                            *ngIf=\"childSubLink.url\"\n                                            [tabindex]=\"isdropdownOpen && !childSubLink.disabled ? 0 : -1\"\n                                            [class.disabled]=\"childSubLink.disabled\"\n                                            [routerLink]=\"childSubLink.url\"\n                                            (click)=\"onLinkClick(childSubLink)\"\n                                            (keydown)=\"onKeyDown($event, childSubLink)\">\n                                            <span\n                                                *ngIf=\"childSubLink.iconClass\"\n                                                class=\"eui-toolbar-menu-item__icon eui-icon {{ childSubLink.iconClass }}\"></span>\n                                            <eui-icon-svg\n                                                *ngIf=\"childSubLink.iconSvgName\"\n                                                class=\"eui-toolbar-menu-item__icon\"\n                                                icon=\"{{ childSubLink.iconSvgName }}\"></eui-icon-svg>\n                                            <span class=\"eui-toolbar-menu-item__label\">{{ childSubLink.label | translate }}</span>\n                                        </a>\n                                        <a\n                                            *ngIf=\"!childSubLink.url\"\n                                            [tabindex]=\"isdropdownOpen && !childSubLink.disabled ? 0 : -1\"\n                                            [class.disabled]=\"childSubLink.disabled\"\n                                            (click)=\"onLinkClick(childSubLink)\"\n                                            (keydown)=\"onKeyDown($event, childSubLink)\">\n                                            <span\n                                                *ngIf=\"childSubLink.iconClass\"\n                                                class=\"eui-toolbar-menu-item__icon eui-icon {{ childSubLink.iconClass }}\"></span>\n                                            <eui-icon-svg\n                                                *ngIf=\"childSubLink.iconSvgName\"\n                                                class=\"eui-toolbar-menu-item__icon\"\n                                                icon=\"{{ childSubLink.iconSvgName }}\"></eui-icon-svg>\n                                            <span class=\"eui-toolbar-menu-item__label\">{{ childSubLink.label | translate }}</span>\n                                        </a>\n                                    </li>\n                                </ng-container>\n                            </ul>\n                        </li>\n                    </ng-container>\n                </ul>\n            </li>\n        </ng-container>\n    </ul>\n</nav>\n"]}