@siemens/element-ng 49.7.0 → 49.9.0

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 (124) hide show
  1. package/fesm2022/siemens-element-ng-accordion.mjs +1 -1
  2. package/fesm2022/siemens-element-ng-accordion.mjs.map +1 -1
  3. package/fesm2022/siemens-element-ng-action-modal.mjs +8 -8
  4. package/fesm2022/siemens-element-ng-action-modal.mjs.map +1 -1
  5. package/fesm2022/siemens-element-ng-ag-grid.mjs +3 -3
  6. package/fesm2022/siemens-element-ng-ag-grid.mjs.map +1 -1
  7. package/fesm2022/siemens-element-ng-application-header.mjs +4 -4
  8. package/fesm2022/siemens-element-ng-application-header.mjs.map +1 -1
  9. package/fesm2022/siemens-element-ng-avatar.mjs +2 -2
  10. package/fesm2022/siemens-element-ng-avatar.mjs.map +1 -1
  11. package/fesm2022/siemens-element-ng-breadcrumb-router.mjs +6 -2
  12. package/fesm2022/siemens-element-ng-breadcrumb-router.mjs.map +1 -1
  13. package/fesm2022/siemens-element-ng-card.mjs +43 -8
  14. package/fesm2022/siemens-element-ng-card.mjs.map +1 -1
  15. package/fesm2022/siemens-element-ng-chat-messages.mjs +8 -8
  16. package/fesm2022/siemens-element-ng-chat-messages.mjs.map +1 -1
  17. package/fesm2022/siemens-element-ng-circle-status.mjs +2 -2
  18. package/fesm2022/siemens-element-ng-circle-status.mjs.map +1 -1
  19. package/fesm2022/siemens-element-ng-column-selection-dialog.mjs +2 -2
  20. package/fesm2022/siemens-element-ng-column-selection-dialog.mjs.map +1 -1
  21. package/fesm2022/siemens-element-ng-common.mjs +4 -4
  22. package/fesm2022/siemens-element-ng-common.mjs.map +1 -1
  23. package/fesm2022/siemens-element-ng-content-action-bar.mjs +2 -2
  24. package/fesm2022/siemens-element-ng-content-action-bar.mjs.map +1 -1
  25. package/fesm2022/siemens-element-ng-dashboard.mjs +15 -13
  26. package/fesm2022/siemens-element-ng-dashboard.mjs.map +1 -1
  27. package/fesm2022/siemens-element-ng-datatable.mjs +10 -19
  28. package/fesm2022/siemens-element-ng-datatable.mjs.map +1 -1
  29. package/fesm2022/siemens-element-ng-date-range-filter.mjs +1 -1
  30. package/fesm2022/siemens-element-ng-date-range-filter.mjs.map +1 -1
  31. package/fesm2022/siemens-element-ng-datepicker.mjs +51 -41
  32. package/fesm2022/siemens-element-ng-datepicker.mjs.map +1 -1
  33. package/fesm2022/siemens-element-ng-file-uploader.mjs +9 -8
  34. package/fesm2022/siemens-element-ng-file-uploader.mjs.map +1 -1
  35. package/fesm2022/siemens-element-ng-filter-bar.mjs +4 -4
  36. package/fesm2022/siemens-element-ng-filter-bar.mjs.map +1 -1
  37. package/fesm2022/siemens-element-ng-filtered-search.mjs +12 -12
  38. package/fesm2022/siemens-element-ng-filtered-search.mjs.map +1 -1
  39. package/fesm2022/siemens-element-ng-form.mjs +8 -10
  40. package/fesm2022/siemens-element-ng-form.mjs.map +1 -1
  41. package/fesm2022/siemens-element-ng-formly.mjs +1 -1
  42. package/fesm2022/siemens-element-ng-formly.mjs.map +1 -1
  43. package/fesm2022/siemens-element-ng-header-dropdown.mjs +19 -55
  44. package/fesm2022/siemens-element-ng-header-dropdown.mjs.map +1 -1
  45. package/fesm2022/siemens-element-ng-menu.mjs +5 -7
  46. package/fesm2022/siemens-element-ng-menu.mjs.map +1 -1
  47. package/fesm2022/siemens-element-ng-navbar-vertical-next.mjs +94 -61
  48. package/fesm2022/siemens-element-ng-navbar-vertical-next.mjs.map +1 -1
  49. package/fesm2022/siemens-element-ng-navbar-vertical.mjs +25 -29
  50. package/fesm2022/siemens-element-ng-navbar-vertical.mjs.map +1 -1
  51. package/fesm2022/siemens-element-ng-navbar.mjs +4 -4
  52. package/fesm2022/siemens-element-ng-navbar.mjs.map +1 -1
  53. package/fesm2022/siemens-element-ng-notification-item.mjs +2 -2
  54. package/fesm2022/siemens-element-ng-notification-item.mjs.map +1 -1
  55. package/fesm2022/siemens-element-ng-number-input.mjs +2 -2
  56. package/fesm2022/siemens-element-ng-number-input.mjs.map +1 -1
  57. package/fesm2022/siemens-element-ng-password-toggle.mjs +2 -2
  58. package/fesm2022/siemens-element-ng-password-toggle.mjs.map +1 -1
  59. package/fesm2022/siemens-element-ng-photo-upload.mjs +2 -2
  60. package/fesm2022/siemens-element-ng-photo-upload.mjs.map +1 -1
  61. package/fesm2022/siemens-element-ng-pills-input.mjs +4 -4
  62. package/fesm2022/siemens-element-ng-pills-input.mjs.map +1 -1
  63. package/fesm2022/siemens-element-ng-popover.mjs +10 -3
  64. package/fesm2022/siemens-element-ng-popover.mjs.map +1 -1
  65. package/fesm2022/siemens-element-ng-search-bar.mjs +10 -4
  66. package/fesm2022/siemens-element-ng-search-bar.mjs.map +1 -1
  67. package/fesm2022/siemens-element-ng-select.mjs +457 -50
  68. package/fesm2022/siemens-element-ng-select.mjs.map +1 -1
  69. package/fesm2022/siemens-element-ng-side-panel.mjs +2 -2
  70. package/fesm2022/siemens-element-ng-side-panel.mjs.map +1 -1
  71. package/fesm2022/siemens-element-ng-slider.mjs +2 -2
  72. package/fesm2022/siemens-element-ng-slider.mjs.map +1 -1
  73. package/fesm2022/siemens-element-ng-status-bar.mjs +47 -22
  74. package/fesm2022/siemens-element-ng-status-bar.mjs.map +1 -1
  75. package/fesm2022/siemens-element-ng-status-toggle.mjs +2 -2
  76. package/fesm2022/siemens-element-ng-status-toggle.mjs.map +1 -1
  77. package/fesm2022/siemens-element-ng-summary-chip.mjs +2 -2
  78. package/fesm2022/siemens-element-ng-summary-chip.mjs.map +1 -1
  79. package/fesm2022/siemens-element-ng-summary-widget.mjs +2 -2
  80. package/fesm2022/siemens-element-ng-summary-widget.mjs.map +1 -1
  81. package/fesm2022/siemens-element-ng-tabs-legacy.mjs +2 -2
  82. package/fesm2022/siemens-element-ng-tabs-legacy.mjs.map +1 -1
  83. package/fesm2022/siemens-element-ng-tabs.mjs +4 -4
  84. package/fesm2022/siemens-element-ng-tabs.mjs.map +1 -1
  85. package/fesm2022/siemens-element-ng-threshold.mjs +2 -2
  86. package/fesm2022/siemens-element-ng-threshold.mjs.map +1 -1
  87. package/fesm2022/siemens-element-ng-toast-notification.mjs +2 -2
  88. package/fesm2022/siemens-element-ng-toast-notification.mjs.map +1 -1
  89. package/fesm2022/siemens-element-ng-tooltip.mjs +10 -8
  90. package/fesm2022/siemens-element-ng-tooltip.mjs.map +1 -1
  91. package/fesm2022/siemens-element-ng-tour.mjs +2 -2
  92. package/fesm2022/siemens-element-ng-tour.mjs.map +1 -1
  93. package/fesm2022/siemens-element-ng-translate.mjs.map +1 -1
  94. package/fesm2022/siemens-element-ng-tree-view.mjs +52 -30
  95. package/fesm2022/siemens-element-ng-tree-view.mjs.map +1 -1
  96. package/package.json +3 -3
  97. package/schematics/migrations/data/element-migration-data.js +20 -0
  98. package/schematics/migrations/data/index.js +1 -16
  99. package/schematics/migrations/ngx-translate/index.js +1 -137
  100. package/schematics/migrations/ngx-translate/missing-translate-migration.js +141 -0
  101. package/schematics/ng-add/index.js +1 -12
  102. package/schematics/ng-add/ng-add-rule.js +16 -0
  103. package/schematics/ng-update/index.js +1 -17
  104. package/schematics/ng-update/migrate-to-v49.js +21 -0
  105. package/template-i18n.json +3 -1
  106. package/types/siemens-element-ng-breadcrumb-router.d.ts +6 -2
  107. package/types/siemens-element-ng-card.d.ts +26 -1
  108. package/types/siemens-element-ng-common.d.ts +3 -3
  109. package/types/siemens-element-ng-dashboard.d.ts +2 -1
  110. package/types/siemens-element-ng-datatable.d.ts +0 -1
  111. package/types/siemens-element-ng-file-uploader.d.ts +4 -3
  112. package/types/siemens-element-ng-filtered-search.d.ts +1 -1
  113. package/types/siemens-element-ng-form.d.ts +1 -1
  114. package/types/siemens-element-ng-header-dropdown.d.ts +0 -8
  115. package/types/siemens-element-ng-navbar-vertical-next.d.ts +33 -20
  116. package/types/siemens-element-ng-navbar-vertical.d.ts +2 -1
  117. package/types/siemens-element-ng-navbar.d.ts +2 -2
  118. package/types/siemens-element-ng-popover.d.ts +9 -2
  119. package/types/siemens-element-ng-search-bar.d.ts +7 -1
  120. package/types/siemens-element-ng-select.d.ts +241 -2
  121. package/types/siemens-element-ng-status-bar.d.ts +11 -5
  122. package/types/siemens-element-ng-tooltip.d.ts +9 -3
  123. package/types/siemens-element-ng-translate.d.ts +2 -0
  124. package/types/siemens-element-ng-tree-view.d.ts +4 -5
@@ -28,6 +28,14 @@ declare class SiNavbarVerticalNextComponent implements OnChanges, OnInit {
28
28
  * @defaultValue false
29
29
  */
30
30
  readonly textOnly: _angular_core.InputSignalWithTransform<boolean, unknown>;
31
+ /**
32
+ * When `true`, item-groups always open as a transient flyout panel adjacent to the
33
+ * trigger, regardless of whether the navbar is collapsed or expanded.
34
+ * Flyouts open and close on click.
35
+ *
36
+ * @defaultValue false
37
+ */
38
+ readonly alwaysFlyout: _angular_core.InputSignalWithTransform<boolean, unknown>;
31
39
  /**
32
40
  * List of vertical navigation items
33
41
  *
@@ -38,23 +46,15 @@ declare class SiNavbarVerticalNextComponent implements OnChanges, OnInit {
38
46
  */
39
47
  readonly visible: _angular_core.InputSignalWithTransform<boolean, unknown>;
40
48
  /**
41
- * Text for the navbar expand button. Required for a11y
42
- *
43
- * @defaultValue
44
- * ```
45
- * t(() => $localize`:@@SI_NAVBAR_VERTICAL.EXPAND:Expand`)
46
- * ```
47
- */
48
- readonly navbarExpandButtonText: _angular_core.InputSignal<_siemens_element_translate_ng_translate.TranslatableString>;
49
- /**
50
- * Text for the navbar collapse button. Required for a11y
49
+ * Text for the navbar toggle button used as `aria-label`.
50
+ * The expanded state is communicated via `aria-expanded`.
51
51
  *
52
52
  * @defaultValue
53
53
  * ```
54
- * t(() => $localize`:@@SI_NAVBAR_VERTICAL.COLLAPSE:Collapse`)
54
+ * t(() => $localize`:@@SI_NAVBAR_VERTICAL.TOGGLE:Toggle`)
55
55
  * ```
56
56
  */
57
- readonly navbarCollapseButtonText: _angular_core.InputSignal<_siemens_element_translate_ng_translate.TranslatableString>;
57
+ readonly toggleButtonText: _angular_core.InputSignal<_siemens_element_translate_ng_translate.TranslatableString>;
58
58
  /**
59
59
  * An optional stateId to uniquely identify a component instance.
60
60
  * Required for persistence of ui state.
@@ -80,6 +80,8 @@ declare class SiNavbarVerticalNextComponent implements OnChanges, OnInit {
80
80
  readonly skipLinkMainContentLabel: _angular_core.InputSignal<_siemens_element_translate_ng_translate.TranslatableString>;
81
81
  private uiStateService;
82
82
  private breakpointObserver;
83
+ private injector;
84
+ protected readonly ready: _angular_core.WritableSignal<boolean>;
83
85
  protected readonly smallScreen: _angular_core.WritableSignal<boolean>;
84
86
  /**
85
87
  * @defaultValue
@@ -103,7 +105,7 @@ declare class SiNavbarVerticalNextComponent implements OnChanges, OnInit {
103
105
  /** @internal */
104
106
  itemTriggered(): void;
105
107
  static ɵfac: _angular_core.ɵɵFactoryDeclaration<SiNavbarVerticalNextComponent, never>;
106
- static ɵcmp: _angular_core.ɵɵComponentDeclaration<SiNavbarVerticalNextComponent, "si-navbar-vertical-next", never, { "collapsed": { "alias": "collapsed"; "required": false; "isSignal": true; }; "textOnly": { "alias": "textOnly"; "required": false; "isSignal": true; }; "visible": { "alias": "visible"; "required": false; "isSignal": true; }; "navbarExpandButtonText": { "alias": "navbarExpandButtonText"; "required": false; "isSignal": true; }; "navbarCollapseButtonText": { "alias": "navbarCollapseButtonText"; "required": false; "isSignal": true; }; "stateId": { "alias": "stateId"; "required": false; "isSignal": true; }; "skipLinkNavigationLabel": { "alias": "skipLinkNavigationLabel"; "required": false; "isSignal": true; }; "skipLinkMainContentLabel": { "alias": "skipLinkMainContentLabel"; "required": false; "isSignal": true; }; }, { "collapsed": "collapsedChange"; }, never, ["si-navbar-vertical-next-search", "si-navbar-vertical-next-items", "si-navbar-vertical-next-footer-items", "*"], true, never>;
108
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<SiNavbarVerticalNextComponent, "si-navbar-vertical-next", never, { "collapsed": { "alias": "collapsed"; "required": false; "isSignal": true; }; "textOnly": { "alias": "textOnly"; "required": false; "isSignal": true; }; "alwaysFlyout": { "alias": "alwaysFlyout"; "required": false; "isSignal": true; }; "visible": { "alias": "visible"; "required": false; "isSignal": true; }; "toggleButtonText": { "alias": "toggleButtonText"; "required": false; "isSignal": true; }; "stateId": { "alias": "stateId"; "required": false; "isSignal": true; }; "skipLinkNavigationLabel": { "alias": "skipLinkNavigationLabel"; "required": false; "isSignal": true; }; "skipLinkMainContentLabel": { "alias": "skipLinkMainContentLabel"; "required": false; "isSignal": true; }; }, { "collapsed": "collapsedChange"; }, never, ["si-navbar-vertical-next-search", "si-navbar-vertical-next-items", "si-navbar-vertical-next-footer-items", "*"], true, never>;
107
109
  }
108
110
 
109
111
  /**
@@ -127,7 +129,7 @@ declare class SiNavbarVerticalNextFooterItemsComponent {
127
129
  }
128
130
 
129
131
  /** @experimental */
130
- declare class SiNavbarVerticalNextGroupTriggerDirective implements OnInit {
132
+ declare class SiNavbarVerticalNextGroupTriggerDirective {
131
133
  private static idCounter;
132
134
  /** @internal */
133
135
  readonly groupId: string;
@@ -136,27 +138,38 @@ declare class SiNavbarVerticalNextGroupTriggerDirective implements OnInit {
136
138
  readonly stateId: _angular_core.InputSignal<string | undefined>;
137
139
  /** @defaultValue false */
138
140
  readonly expanded: _angular_core.WritableSignal<boolean>;
139
- /** @internal */
141
+ /**
142
+ * Whether the group is currently rendered as a transient flyout overlay
143
+ * (true) or inline within the navbar (false). Automatically resets to
144
+ * `false` whenever the rendering mode changes.
145
+ * @internal
146
+ */
140
147
  readonly flyout: _angular_core.WritableSignal<boolean>;
141
- /** @internal */
148
+ /**
149
+ * Whether the open flyout overlay currently contains the active route.
150
+ * Reset together with `flyout` so it never lingers across mode changes.
151
+ * @internal
152
+ */
142
153
  readonly active: _angular_core.WritableSignal<boolean>;
143
154
  protected readonly navbar: _siemens_element_ng_navbar_vertical_next.SiNavbarVerticalNextComponent;
155
+ /** @internal */
156
+ readonly flyoutMode: _angular_core.Signal<boolean>;
144
157
  private flyoutOutsideClickSubscription?;
145
158
  private readonly viewContainer;
146
159
  private readonly overlay;
147
160
  private readonly injector;
148
161
  private readonly overlayRef;
149
- private groupView;
162
+ private groupView?;
150
163
  private flyoutAnchorComponentRef?;
151
164
  private readonly templatePortal;
152
165
  constructor();
153
- ngOnInit(): void;
154
166
  /** @internal */
155
167
  hideFlyout(): void;
156
168
  protected triggered(): void;
157
169
  private toggleFlyout;
158
170
  private attachInline;
159
171
  private attachFlyout;
172
+ private detachFlyout;
160
173
  static ɵfac: _angular_core.ɵɵFactoryDeclaration<SiNavbarVerticalNextGroupTriggerDirective, never>;
161
174
  static ɵdir: _angular_core.ɵɵDirectiveDeclaration<SiNavbarVerticalNextGroupTriggerDirective, "button[siNavbarVerticalNextGroupTriggerFor]", never, { "groupTemplate": { "alias": "siNavbarVerticalNextGroupTriggerFor"; "required": true; "isSignal": true; }; "stateId": { "alias": "stateId"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
162
175
  }
@@ -166,7 +179,6 @@ declare class SiNavbarVerticalNextGroupComponent {
166
179
  protected readonly navbar: _siemens_element_ng_navbar_vertical_next.SiNavbarVerticalNextComponent;
167
180
  protected readonly groupTrigger: SiNavbarVerticalNextGroupTriggerDirective;
168
181
  private readonly routerLinkActive;
169
- protected flyout: boolean;
170
182
  protected readonly visible: _angular_core.Signal<boolean>;
171
183
  constructor();
172
184
  protected close(): void;
@@ -183,7 +195,7 @@ declare class SiNavbarVerticalNextHeaderComponent {
183
195
 
184
196
  /** @experimental */
185
197
  declare class SiNavbarVerticalNextItemComponent implements OnInit {
186
- protected readonly icons: Record<"elementDown2", string>;
198
+ protected readonly icons: Record<"elementDown2" | "elementRight2", string>;
187
199
  /** Optional icon to render before the label. */
188
200
  readonly icon: _angular_core.InputSignal<string | undefined>;
189
201
  /** Badge value to display. */
@@ -211,6 +223,7 @@ declare class SiNavbarVerticalNextItemComponent implements OnInit {
211
223
  * Formats badge value to limit display to "+99" for numbers greater than 99
212
224
  */
213
225
  protected readonly formattedBadge: _angular_core.Signal<string>;
226
+ protected readonly isDropdownItem: _angular_core.Signal<boolean>;
214
227
  ngOnInit(): void;
215
228
  protected triggered(): void;
216
229
  get active(): boolean;
@@ -199,12 +199,13 @@ declare class SiNavbarVerticalComponent implements OnChanges, OnInit {
199
199
  readonly searchEvent: _angular_core.OutputEmitterRef<string>;
200
200
  private readonly searchBar;
201
201
  protected readonly activatedRoute: ActivatedRoute | null;
202
- protected readonly ready = true;
203
202
  private uiStateService;
204
203
  private breakpointObserver;
204
+ private injector;
205
205
  private readonly navbarItems;
206
206
  private readonly navbarItemsLegacy;
207
207
  private readonly itemsToComponents;
208
+ protected readonly ready: _angular_core.WritableSignal<boolean>;
208
209
  protected readonly smallScreen: _angular_core.WritableSignal<boolean>;
209
210
  protected readonly uiStateExpandedItems: _angular_core.WritableSignal<Record<string, boolean>>;
210
211
  private preferCollapse;
@@ -129,7 +129,7 @@ declare class SiNavbarPrimaryComponent implements OnChanges, HeaderWithDropdowns
129
129
  *
130
130
  * @defaultValue
131
131
  * ```
132
- * t(() => $localize`:@@SI_LAUNCHPAD.TITLE:Launchpad`)
132
+ * t(() => $localize`:@@SI_LAUNCHPAD.TITLE:Switch applications`)
133
133
  * ```
134
134
  */
135
135
  readonly appSwitcherTitle: _angular_core.InputSignal<_siemens_element_translate_ng_translate.TranslatableString>;
@@ -147,7 +147,7 @@ declare class SiNavbarPrimaryComponent implements OnChanges, HeaderWithDropdowns
147
147
  *
148
148
  * @defaultValue
149
149
  * ```
150
- * t(() => $localize`:@@SI_LAUNCHPAD.FAVORITE_APPS:Favorite apps`)
150
+ * t(() => $localize`:@@SI_LAUNCHPAD.FAVORITE_APPS:Favorites`)
151
151
  * ```
152
152
  */
153
153
  readonly favoriteAppsTitle: _angular_core.InputSignal<_siemens_element_translate_ng_translate.TranslatableString>;
@@ -1,8 +1,8 @@
1
1
  import * as _angular_core from '@angular/core';
2
2
  import { OnDestroy, TemplateRef, OnInit, ElementRef, Injector } from '@angular/core';
3
+ import { ScrollStrategy, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';
3
4
  import { TranslatableString } from '@siemens/element-translate-ng/translate-types';
4
5
  import * as _siemens_element_translate_ng_translate from '@siemens/element-translate-ng/translate';
5
- import { ConnectedOverlayPositionChange } from '@angular/cdk/overlay';
6
6
  import { OverlayArrowPosition } from '@siemens/element-ng/common';
7
7
 
8
8
  declare class SiPopoverDirective implements OnDestroy {
@@ -42,6 +42,13 @@ declare class SiPopoverDirective implements OnDestroy {
42
42
  * @defaultValue undefined
43
43
  */
44
44
  readonly context: _angular_core.InputSignal<unknown>;
45
+ /**
46
+ * Optional CDK scroll strategy used for the popover overlay.
47
+ * If not provided, the default reposition strategy is used.
48
+ *
49
+ * @defaultValue undefined
50
+ */
51
+ readonly scrollStrategy: _angular_core.InputSignal<ScrollStrategy | undefined>;
45
52
  /**
46
53
  * Emits an event when the popover is shown/hidden
47
54
  */
@@ -71,7 +78,7 @@ declare class SiPopoverDirective implements OnDestroy {
71
78
  updatePosition(): void;
72
79
  protected onClick(): void;
73
80
  static ɵfac: _angular_core.ɵɵFactoryDeclaration<SiPopoverDirective, never>;
74
- static ɵdir: _angular_core.ɵɵDirectiveDeclaration<SiPopoverDirective, "[siPopover]", ["si-popover"], { "siPopover": { "alias": "siPopover"; "required": false; "isSignal": true; }; "placement": { "alias": "siPopoverPlacement"; "required": false; "isSignal": true; }; "title": { "alias": "siPopoverTitle"; "required": false; "isSignal": true; }; "containerClass": { "alias": "siPopoverContainerClass"; "required": false; "isSignal": true; }; "icon": { "alias": "siPopoverIcon"; "required": false; "isSignal": true; }; "context": { "alias": "siPopoverContext"; "required": false; "isSignal": true; }; }, { "visibilityChange": "siPopoverVisibilityChange"; }, never, never, true, never>;
81
+ static ɵdir: _angular_core.ɵɵDirectiveDeclaration<SiPopoverDirective, "[siPopover]", ["si-popover"], { "siPopover": { "alias": "siPopover"; "required": false; "isSignal": true; }; "placement": { "alias": "siPopoverPlacement"; "required": false; "isSignal": true; }; "title": { "alias": "siPopoverTitle"; "required": false; "isSignal": true; }; "containerClass": { "alias": "siPopoverContainerClass"; "required": false; "isSignal": true; }; "icon": { "alias": "siPopoverIcon"; "required": false; "isSignal": true; }; "context": { "alias": "siPopoverContext"; "required": false; "isSignal": true; }; "scrollStrategy": { "alias": "siPopoverScrollStrategy"; "required": false; "isSignal": true; }; }, { "visibilityChange": "siPopoverVisibilityChange"; }, never, never, true, never>;
75
82
  }
76
83
 
77
84
  declare class PopoverComponent implements OnInit, OnDestroy {
@@ -50,6 +50,12 @@ declare class SiSearchBarComponent implements OnInit, OnDestroy, ControlValueAcc
50
50
  readonly colorVariant: _angular_core.InputSignal<BackgroundColorVariant>;
51
51
  /** @defaultValue false */
52
52
  readonly disabledInput: _angular_core.InputSignalWithTransform<boolean, unknown>;
53
+ /**
54
+ * Defines the maximum length of the search input.
55
+ *
56
+ * @defaultValue undefined
57
+ */
58
+ readonly maxlength: _angular_core.InputSignalWithTransform<number | undefined, unknown>;
53
59
  /**
54
60
  * Aria label for the clear button.
55
61
  *
@@ -91,7 +97,7 @@ declare class SiSearchBarComponent implements OnInit, OnDestroy, ControlValueAcc
91
97
  protected resetForm(): void;
92
98
  protected writeSearchValue(value: string): void;
93
99
  static ɵfac: _angular_core.ɵɵFactoryDeclaration<SiSearchBarComponent, never>;
94
- static ɵcmp: _angular_core.ɵɵComponentDeclaration<SiSearchBarComponent, "si-search-bar", never, { "debounceTime": { "alias": "debounceTime"; "required": false; "isSignal": true; }; "prohibitedCharacters": { "alias": "prohibitedCharacters"; "required": false; "isSignal": true; }; "placeholder": { "alias": "placeholder"; "required": false; "isSignal": true; }; "showIcon": { "alias": "showIcon"; "required": false; "isSignal": true; }; "tabbable": { "alias": "tabbable"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "readonly": { "alias": "readonly"; "required": false; "isSignal": true; }; "colorVariant": { "alias": "colorVariant"; "required": false; "isSignal": true; }; "disabledInput": { "alias": "disabled"; "required": false; "isSignal": true; }; "clearButtonAriaLabel": { "alias": "clearButtonAriaLabel"; "required": false; "isSignal": true; }; }, { "searchChange": "searchChange"; }, never, never, true, never>;
100
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<SiSearchBarComponent, "si-search-bar", never, { "debounceTime": { "alias": "debounceTime"; "required": false; "isSignal": true; }; "prohibitedCharacters": { "alias": "prohibitedCharacters"; "required": false; "isSignal": true; }; "placeholder": { "alias": "placeholder"; "required": false; "isSignal": true; }; "showIcon": { "alias": "showIcon"; "required": false; "isSignal": true; }; "tabbable": { "alias": "tabbable"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "readonly": { "alias": "readonly"; "required": false; "isSignal": true; }; "colorVariant": { "alias": "colorVariant"; "required": false; "isSignal": true; }; "disabledInput": { "alias": "disabled"; "required": false; "isSignal": true; }; "maxlength": { "alias": "maxlength"; "required": false; "isSignal": true; }; "clearButtonAriaLabel": { "alias": "clearButtonAriaLabel"; "required": false; "isSignal": true; }; }, { "searchChange": "searchChange"; }, never, never, true, never>;
95
101
  }
96
102
 
97
103
  declare class SiSearchBarModule {
@@ -546,5 +546,244 @@ declare class SiSelectListHasFilterComponent<T> extends SiSelectListBase<T> impl
546
546
  static ɵcmp: _angular_core.ɵɵComponentDeclaration<SiSelectListHasFilterComponent<any>, "si-select-list-has-filter", never, { "filterPlaceholder": { "alias": "filterPlaceholder"; "required": true; "isSignal": true; }; "noResultsFoundLabel": { "alias": "noResultsFoundLabel"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
547
547
  }
548
548
 
549
- export { SiSelectActionDirective, SiSelectActionsDirective, SiSelectComponent, SiSelectGroupTemplateDirective, SiSelectLazyOptionsDirective, SiSelectListHasFilterComponent, SiSelectModule, SiSelectMultiValueDirective, SiSelectOptionTemplateDirective, SiSelectSimpleOptionsDirective, SiSelectSingleValueDirective };
550
- export type { SelectGroup, SelectItem, SelectOption, SelectOptionSource };
549
+ /**
550
+ * Possible values for the `aria-haspopup` attribute exposed by the
551
+ * combobox host of a custom select.
552
+ */
553
+ type SiSelectDropdownContentType = 'false' | 'true' | 'menu' | 'listbox' | 'tree' | 'grid' | 'dialog';
554
+ /**
555
+ * Structural directive marking the dropdown template for custom selects
556
+ * built with {@link SiCustomSelectDirective}.
557
+ *
558
+ * When placed on an `<ng-template>`, it automatically registers the template
559
+ * with the parent {@link SiCustomSelectDirective}.
560
+ *
561
+ * @example
562
+ * ```html
563
+ * <ng-template si-select-dropdown contentType="listbox">
564
+ * <!-- custom dropdown content -->
565
+ * </ng-template>
566
+ * ```
567
+ *
568
+ * @experimental
569
+ */
570
+ declare class SiSelectDropdownDirective {
571
+ /**
572
+ * Describes the kind of content rendered by the dropdown. The value is
573
+ * forwarded to the `aria-haspopup` attribute of the combobox host of
574
+ * the parent {@link SiCustomSelectDirective}.
575
+ */
576
+ readonly contentType: _angular_core.InputSignal<SiSelectDropdownContentType>;
577
+ /** @internal */
578
+ readonly templateRef: TemplateRef<void>;
579
+ constructor();
580
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<SiSelectDropdownDirective, never>;
581
+ static ɵdir: _angular_core.ɵɵDirectiveDeclaration<SiSelectDropdownDirective, "[si-select-dropdown]", never, { "contentType": { "alias": "contentType"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
582
+ }
583
+
584
+ /**
585
+ * Host directive for building custom selects.
586
+ *
587
+ * Add this as a `hostDirective` on your component and expose the inputs/outputs you need.
588
+ * The directive handles:
589
+ * - {@link ControlValueAccessor} integration (`formControl`, `ngModel`, `[(value)]`)
590
+ * - Disabled / readonly state management
591
+ * - Overlay lifecycle for the dropdown (open/close)
592
+ * - Focus management and focus trapping in the dropdown
593
+ * - Opening the dropdown on click, Enter, Space, ArrowDown, ArrowUp
594
+ * - {@link SiFormItemControl} integration
595
+ *
596
+ * Use {@link SiSelectDropdownDirective} to mark the dropdown template in your component,
597
+ * and call {@link open}, {@link close}, {@link updateValue} from your component logic.
598
+ *
599
+ * @example
600
+ * ```ts
601
+ * @Component({
602
+ * selector: 'app-my-select',
603
+ * hostDirectives: [{
604
+ * directive: SiCustomSelectDirective,
605
+ * inputs: ['disabled', 'readonly', 'value'],
606
+ * outputs: ['valueChange']
607
+ * }],
608
+ * template: `
609
+ * <si-select-combobox>
610
+ * {{ select.value() }}
611
+ * </si-select-combobox>
612
+ * <ng-template si-select-dropdown contentType="listbox">
613
+ * <button (click)="select.updateValue('new'); select.close()">Pick</button>
614
+ * </ng-template>
615
+ * `
616
+ * })
617
+ * export class MySelectComponent {
618
+ * readonly select = inject(SiCustomSelectDirective);
619
+ * }
620
+ * ```
621
+ *
622
+ * @experimental
623
+ */
624
+ declare class SiCustomSelectDirective<T> implements ControlValueAccessor, SiFormItemControl {
625
+ private static idCounter;
626
+ /**
627
+ * Unique identifier.
628
+ *
629
+ * @defaultValue
630
+ * ```
631
+ * `__si-custom-select-${SiCustomSelectDirective.idCounter++}`
632
+ * ```
633
+ */
634
+ readonly id: _angular_core.InputSignal<string>;
635
+ /**
636
+ * Whether the select input is disabled.
637
+ *
638
+ * @defaultValue false
639
+ */
640
+ readonly disabledInput: _angular_core.InputSignalWithTransform<boolean, unknown>;
641
+ /**
642
+ * Readonly state. Similar to disabled but with higher contrast.
643
+ *
644
+ * @defaultValue false
645
+ */
646
+ readonly readonly: _angular_core.InputSignalWithTransform<boolean, unknown>;
647
+ /** Emits when the dropdown open state changes. */
648
+ readonly openChange: _angular_core.OutputEmitterRef<boolean>;
649
+ /**
650
+ * The current value, supports two-way binding via `[(value)]`.
651
+ *
652
+ * @defaultValue undefined
653
+ */
654
+ readonly value: _angular_core.ModelSignal<T | undefined>;
655
+ /**
656
+ * Whether the dropdown is currently open.
657
+ *
658
+ * @defaultValue false
659
+ */
660
+ readonly isOpen: _angular_core.WritableSignal<boolean>;
661
+ /** @internal */
662
+ readonly labelledby: _angular_core.Signal<string>;
663
+ /** @internal */
664
+ readonly comboboxLabelId: _angular_core.Signal<string>;
665
+ /** @internal */
666
+ readonly dropdownId: _angular_core.Signal<string>;
667
+ /**
668
+ * Value forwarded to the `aria-haspopup` attribute. Reflects the
669
+ * `contentType` input of the registered {@link SiSelectDropdownDirective},
670
+ * defaulting to `'listbox'` until a dropdown template is registered.
671
+ * @internal
672
+ */
673
+ readonly haspopup: _angular_core.Signal<_siemens_element_ng_select.SiSelectDropdownContentType>;
674
+ /**
675
+ * This ID will be bound to the `aria-describedby` attribute of the select.
676
+ *
677
+ * @defaultValue
678
+ * ```
679
+ * `${this.id()}-errormessage`
680
+ * ```
681
+ */
682
+ readonly errormessageId: _angular_core.InputSignal<string>;
683
+ /** Combined disabled state from input and form control. */
684
+ readonly disabled: _angular_core.Signal<boolean>;
685
+ private onTouched;
686
+ private onChange;
687
+ private readonly disabledByForm;
688
+ private readonly overlay;
689
+ private readonly focusTrapFactory;
690
+ private readonly elementRef;
691
+ private readonly viewContainerRef;
692
+ private readonly destroyRef;
693
+ private readonly isBrowser;
694
+ private overlayRef?;
695
+ private focusTrap?;
696
+ private readonly closeOverlay$;
697
+ private readonly dropdownDirective;
698
+ constructor();
699
+ /**
700
+ * Registers the dropdown directive. Called by
701
+ * {@link SiSelectDropdownDirective} when it is initialized.
702
+ * @internal
703
+ */
704
+ registerDropdown(directive: SiSelectDropdownDirective): void;
705
+ /**
706
+ * Updates the value programmatically.
707
+ * Call this from your dropdown template to set the new value.
708
+ */
709
+ updateValue(value: T | undefined): void;
710
+ /** Opens the dropdown overlay. */
711
+ open(event?: Event): void;
712
+ /** Closes the dropdown overlay and restores focus. */
713
+ close(): void;
714
+ /** @internal */
715
+ writeValue(obj: T | null): void;
716
+ /** @internal */
717
+ registerOnChange(fn: (_: T | undefined) => void): void;
718
+ /** @internal */
719
+ registerOnTouched(fn: () => void): void;
720
+ /** @internal */
721
+ setDisabledState(isDisabled: boolean): void;
722
+ private disposeOverlay;
723
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<SiCustomSelectDirective<any>, never>;
724
+ static ɵdir: _angular_core.ɵɵDirectiveDeclaration<SiCustomSelectDirective<any>, "[siCustomSelect]", never, { "id": { "alias": "id"; "required": false; "isSignal": true; }; "disabledInput": { "alias": "disabled"; "required": false; "isSignal": true; }; "readonly": { "alias": "readonly"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "errormessageId": { "alias": "errormessageId"; "required": false; "isSignal": true; }; }, { "openChange": "openChange"; "value": "valueChange"; }, never, never, true, never>;
725
+ }
726
+
727
+ /**
728
+ * Visual trigger element for custom selects built with {@link SiCustomSelectDirective}.
729
+ * Renders the projected content and a dropdown caret icon.
730
+ *
731
+ * The ARIA role, focus handling, and state attributes live on the host component
732
+ * via {@link SiCustomSelectDirective} — this component is purely visual.
733
+ *
734
+ * @example
735
+ * ```html
736
+ * <si-select-combobox>
737
+ * {{ select.value() }}
738
+ * </si-select-combobox>
739
+ * ```
740
+ *
741
+ * @experimental
742
+ */
743
+ declare class SiSelectComboboxComponent {
744
+ protected readonly icons: Record<"elementDown2", string>;
745
+ protected readonly customSelect: SiCustomSelectDirective<any>;
746
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<SiSelectComboboxComponent, never>;
747
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<SiSelectComboboxComponent, "si-select-combobox", never, {}, {}, never, ["*"], true, never>;
748
+ }
749
+
750
+ /**
751
+ * Represents a single selected value inside an {@link SiSelectComboboxComponent}.
752
+ *
753
+ * Project one `<si-select-combobox-value>` per selected entry. Optional
754
+ * `icon`, `iconColor`, `stackedIcon` and `stackedIconColor` inputs mirror the
755
+ * icon API of {@link SelectOption} and render an icon (with optional stacked
756
+ * overlay) before the projected content.
757
+ *
758
+ * Add the `comma-separated` CSS class to render a comma between adjacent
759
+ * values. Omit it when using chips, custom separators, or a single value.
760
+ *
761
+ * @example
762
+ * ```html
763
+ * <si-select-combobox>
764
+ * <si-select-combobox-value
765
+ * icon="element-face-happy"
766
+ * iconColor="status-success"
767
+ * >
768
+ * {{ select.value() }}
769
+ * </si-select-combobox-value>
770
+ * </si-select-combobox>
771
+ * ```
772
+ *
773
+ * @experimental
774
+ */
775
+ declare class SiSelectComboboxValueComponent {
776
+ /** An optional icon rendered before the projected content. */
777
+ readonly icon: _angular_core.InputSignal<string | undefined>;
778
+ /** Optional CSS color class applied to {@link icon}. */
779
+ readonly iconColor: _angular_core.InputSignal<string | undefined>;
780
+ /** Optional secondary icon stacked on top of {@link icon}. */
781
+ readonly stackedIcon: _angular_core.InputSignal<string | undefined>;
782
+ /** Optional CSS color class applied to {@link stackedIcon}. */
783
+ readonly stackedIconColor: _angular_core.InputSignal<string | undefined>;
784
+ static ɵfac: _angular_core.ɵɵFactoryDeclaration<SiSelectComboboxValueComponent, never>;
785
+ static ɵcmp: _angular_core.ɵɵComponentDeclaration<SiSelectComboboxValueComponent, "si-select-combobox-value", never, { "icon": { "alias": "icon"; "required": false; "isSignal": true; }; "iconColor": { "alias": "iconColor"; "required": false; "isSignal": true; }; "stackedIcon": { "alias": "stackedIcon"; "required": false; "isSignal": true; }; "stackedIconColor": { "alias": "stackedIconColor"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true, never>;
786
+ }
787
+
788
+ export { SiCustomSelectDirective, SiSelectActionDirective, SiSelectActionsDirective, SiSelectComboboxComponent, SiSelectComboboxValueComponent, SiSelectComponent, SiSelectDropdownDirective, SiSelectGroupTemplateDirective, SiSelectLazyOptionsDirective, SiSelectListHasFilterComponent, SiSelectModule, SiSelectMultiValueDirective, SiSelectOptionTemplateDirective, SiSelectSimpleOptionsDirective, SiSelectSingleValueDirective };
789
+ export type { SelectGroup, SelectItem, SelectOption, SelectOptionSource, SiSelectDropdownContentType };
@@ -49,12 +49,16 @@ interface ExtendedStatusBarItem extends StatusBarItem {
49
49
  * about important status information.
50
50
  */
51
51
  declare class SiStatusBarComponent implements OnDestroy, OnChanges {
52
- private static readonly itemMinWidth;
53
- private static readonly itemMaxWidth;
52
+ private static readonly minNumberOfItems;
53
+ private static readonly itemMinWidthEm;
54
+ private static readonly itemMaxWidthEm;
54
55
  private static readonly itemSpacing;
55
- private static readonly itemPaddingX;
56
- private static readonly itemPaddingXdeprecated;
57
- private static readonly muteButtonWidth;
56
+ private static readonly itemPadding;
57
+ private static readonly itemColorBarWidth;
58
+ private static readonly itemColorBarMargin;
59
+ private static readonly itemIconWidthEm;
60
+ private static readonly itemIconMargin;
61
+ private static readonly mainPadding;
58
62
  /**
59
63
  * Array of status bar items.
60
64
  */
@@ -145,9 +149,11 @@ declare class SiStatusBarComponent implements OnDestroy, OnChanges {
145
149
  protected onItemClicked(item: StatusBarItem): void;
146
150
  protected toggleExpand(): void;
147
151
  protected resizeHandler(): void;
152
+ private getMuteButtonWidth;
148
153
  private setResponsiveMode;
149
154
  private calcResponsiveItems;
150
155
  private calculateRequiredWidth;
156
+ private getItemWidth;
151
157
  static ɵfac: _angular_core.ɵɵFactoryDeclaration<SiStatusBarComponent, never>;
152
158
  static ɵcmp: _angular_core.ɵɵComponentDeclaration<SiStatusBarComponent, "si-status-bar", never, { "items": { "alias": "items"; "required": true; "isSignal": true; }; "blink": { "alias": "blink"; "required": false; "isSignal": true; }; "muteButton": { "alias": "muteButton"; "required": false; "isSignal": true; }; "muteButtonText": { "alias": "muteButtonText"; "required": false; "isSignal": true; }; "allOkText": { "alias": "allOkText"; "required": false; "isSignal": true; }; "compact": { "alias": "compact"; "required": false; "isSignal": true; }; "blinkPulse": { "alias": "blinkPulse"; "required": false; "isSignal": true; }; "expandButtonText": { "alias": "expandButtonText"; "required": false; "isSignal": true; }; "collapseButtonText": { "alias": "collapseButtonText"; "required": false; "isSignal": true; }; }, { "muteToggle": "muteToggle"; }, never, ["*"], true, never>;
153
159
  }
@@ -1,7 +1,7 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { OnDestroy, TemplateRef, Type, ElementRef, Injector } from '@angular/core';
3
+ import { ScrollStrategy, OverlayRef } from '@angular/cdk/overlay';
3
4
  import { TranslatableString } from '@siemens/element-translate-ng/translate';
4
- import { OverlayRef } from '@angular/cdk/overlay';
5
5
  import { positions } from '@siemens/element-ng/common';
6
6
 
7
7
  declare class SiTooltipDirective implements OnDestroy {
@@ -17,13 +17,18 @@ declare class SiTooltipDirective implements OnDestroy {
17
17
  *
18
18
  * @defaultValue 'auto'
19
19
  */
20
- readonly placement: i0.InputSignal<"auto" | "top" | "start" | "end" | "bottom">;
20
+ readonly placement: i0.InputSignal<"auto" | "start" | "end" | "top" | "bottom">;
21
21
  /**
22
22
  * Allows the tooltip to be disabled
23
23
  *
24
24
  * @defaultValue false
25
25
  */
26
26
  readonly isDisabled: i0.InputSignalWithTransform<boolean, unknown>;
27
+ /**
28
+ * Optional CDK scroll strategy used for the tooltip overlay.
29
+ * If not provided, the default reposition strategy is used.
30
+ */
31
+ readonly tooltipScrollStrategy: i0.InputSignal<ScrollStrategy | undefined>;
27
32
  /**
28
33
  * The context for the attached template
29
34
  */
@@ -41,7 +46,7 @@ declare class SiTooltipDirective implements OnDestroy {
41
46
  protected show(): void;
42
47
  protected hide(): void;
43
48
  static ɵfac: i0.ɵɵFactoryDeclaration<SiTooltipDirective, never>;
44
- static ɵdir: i0.ɵɵDirectiveDeclaration<SiTooltipDirective, "[siTooltip]", never, { "siTooltip": { "alias": "siTooltip"; "required": false; "isSignal": true; }; "placement": { "alias": "placement"; "required": false; "isSignal": true; }; "isDisabled": { "alias": "isDisabled"; "required": false; "isSignal": true; }; "tooltipContext": { "alias": "tooltipContext"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
49
+ static ɵdir: i0.ɵɵDirectiveDeclaration<SiTooltipDirective, "[siTooltip]", never, { "siTooltip": { "alias": "siTooltip"; "required": false; "isSignal": true; }; "placement": { "alias": "placement"; "required": false; "isSignal": true; }; "isDisabled": { "alias": "isDisabled"; "required": false; "isSignal": true; }; "tooltipScrollStrategy": { "alias": "tooltipScrollStrategy"; "required": false; "isSignal": true; }; "tooltipContext": { "alias": "tooltipContext"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
45
50
  }
46
51
 
47
52
  declare class SiTooltipModule {
@@ -94,6 +99,7 @@ declare class SiTooltipService {
94
99
  injector?: Injector;
95
100
  tooltip: () => SiTooltipContent;
96
101
  tooltipContext: () => unknown;
102
+ scrollStrategy?: ScrollStrategy;
97
103
  }): TooltipRef;
98
104
  static ɵfac: i0.ɵɵFactoryDeclaration<SiTooltipService, never>;
99
105
  static ɵprov: i0.ɵɵInjectableDeclaration<SiTooltipService>;
@@ -9,6 +9,7 @@ interface SiTranslatableKeys {
9
9
  'SI_APPLICATION_HEADER.TOGGLE_NAVIGATION'?: string;
10
10
  'SI_ATTACHMENT_LIST.REMOVE_ATTACHMENT'?: string;
11
11
  'SI_BREADCRUMB'?: string;
12
+ 'SI_BREADCRUMB_ROUTER_LABEL'?: string;
12
13
  'SI_CHANGE_PASSWORD.BACK'?: string;
13
14
  'SI_CHANGE_PASSWORD.CHANGE'?: string;
14
15
  'SI_CHANGE_PASSWORD.CHANGE_FACTORY_PASSWORD'?: string;
@@ -180,6 +181,7 @@ interface SiTranslatableKeys {
180
181
  'SI_NAVBAR_VERTICAL.SEARCH_PLACEHOLDER'?: string;
181
182
  'SI_NAVBAR_VERTICAL.SKIP_LINK.MAIN_LABEL'?: string;
182
183
  'SI_NAVBAR_VERTICAL.SKIP_LINK.NAVIGATION_LABEL'?: string;
184
+ 'SI_NAVBAR_VERTICAL.TOGGLE'?: string;
183
185
  'SI_PAGINATION.BACK'?: string;
184
186
  'SI_PAGINATION.FORWARD'?: string;
185
187
  'SI_PAGINATION.NAV_LABEL'?: string;
@@ -1,5 +1,5 @@
1
1
  import * as _angular_core from '@angular/core';
2
- import { OnInit, OnDestroy, AfterViewInit, DoCheck, TemplateRef, OnChanges, AfterViewChecked, Signal, SimpleChanges, ElementRef } from '@angular/core';
2
+ import { OnInit, AfterViewInit, DoCheck, TemplateRef, OnChanges, OnDestroy, AfterViewChecked, Signal, SimpleChanges, ElementRef } from '@angular/core';
3
3
  import { MenuItem } from '@siemens/element-ng/common';
4
4
  import { MenuItem as MenuItem$1 } from '@siemens/element-ng/menu';
5
5
  import { TranslatableString } from '@siemens/element-translate-ng/translate';
@@ -9,10 +9,11 @@ import { FocusableOption } from '@angular/cdk/a11y';
9
9
  import { CdkMenuTrigger } from '@angular/cdk/menu';
10
10
  import { CdkDragDrop } from '@angular/cdk/drag-drop';
11
11
 
12
- declare class SiTreeViewItemComponent implements OnInit, OnDestroy, AfterViewInit, FocusableOption, DoCheck {
12
+ declare class SiTreeViewItemComponent implements OnInit, AfterViewInit, FocusableOption, DoCheck {
13
13
  private element;
14
14
  private siTreeViewService;
15
15
  private cdRef;
16
+ private destroyRef;
16
17
  protected treeItemContext: {
17
18
  record: _angular_core.IterableChangeRecord<TreeItem<any>>;
18
19
  parent: _siemens_element_ng_tree_view.SiTreeViewComponent;
@@ -39,7 +40,6 @@ declare class SiTreeViewItemComponent implements OnInit, OnDestroy, AfterViewIni
39
40
  itemExpandedLeft: string;
40
41
  }>;
41
42
  private savedElement;
42
- private subscriptions;
43
43
  private indentLevel;
44
44
  private nextSiblingElement;
45
45
  protected readonly menuTrigger: _angular_core.Signal<CdkMenuTrigger | undefined>;
@@ -53,7 +53,6 @@ declare class SiTreeViewItemComponent implements OnInit, OnDestroy, AfterViewIni
53
53
  ngOnInit(): void;
54
54
  ngDoCheck(): void;
55
55
  ngAfterViewInit(): void;
56
- ngOnDestroy(): void;
57
56
  protected readonly enableSelection: _angular_core.InputSignalWithTransform<boolean, unknown>;
58
57
  protected readonly enableContextMenuButton: _angular_core.InputSignalWithTransform<boolean, unknown>;
59
58
  protected readonly enableDataField1: _angular_core.InputSignalWithTransform<boolean, unknown>;
@@ -340,7 +339,6 @@ declare class SiTreeViewComponent implements OnInit, OnChanges, OnDestroy, After
340
339
  private manuallySelectedTreeItems;
341
340
  private latestFolderChanged?;
342
341
  private breadCrumbTreeItems;
343
- private subscriptions;
344
342
  private multiSelectionStart;
345
343
  private _multiSelectionActive;
346
344
  private domChangeObserver?;
@@ -353,6 +351,7 @@ declare class SiTreeViewComponent implements OnInit, OnChanges, OnDestroy, After
353
351
  private cdRef;
354
352
  private resizeObserver;
355
353
  private injector;
354
+ private destroyRef;
356
355
  /**
357
356
  * Create a virtual root node so there is just a single root node. This makes sure the tree
358
357
  * can be fully traversed starting from any node. This is needed e.g. for recursively