@fundamental-ngx/cx 0.48.0-rc.21 → 0.48.0-rc.23

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.
@@ -1,6 +1,5 @@
1
- import { ChangeDetectorRef, ContentChild, Directive, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, Renderer2 } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import { takeUntil } from 'rxjs/operators';
1
+ import { ChangeDetectorRef, ContentChild, DestroyRef, Directive, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, inject } from '@angular/core';
2
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
3
  import { NestedItemService } from '../nested-item/nested-item.service';
5
4
  import { NestedLinkComponent } from '../nested-link/nested-link.component';
6
5
  import { NestedListExpandIconComponent } from '../nested-list-directives';
@@ -8,9 +7,8 @@ import * as i0 from "@angular/core";
8
7
  import * as i1 from "../nested-item/nested-item.service";
9
8
  export class NestedListContentDirective {
10
9
  /** @hidden */
11
- constructor(changeDetRef, _renderer, _elementRef, _itemService) {
10
+ constructor(changeDetRef, _elementRef, _itemService) {
12
11
  this.changeDetRef = changeDetRef;
13
- this._renderer = _renderer;
14
12
  this._elementRef = _elementRef;
15
13
  this._itemService = _itemService;
16
14
  /** Whether this element is selected*/
@@ -32,19 +30,14 @@ export class NestedListContentDirective {
32
30
  * Attribute controlled by the parent `NestedItemComponent`
33
31
  */
34
32
  this.hasChildren = false;
35
- /** An RxJS Subject that will kill the data stream upon component’s destruction (for unsubscribing) */
36
- this.onDestroy$ = new Subject();
33
+ /** @hidden */
34
+ this._destroyRef = inject(DestroyRef);
37
35
  }
38
36
  /** @hidden */
39
37
  ngAfterContentInit() {
40
38
  this._makeLinkUnFocusable();
41
39
  this._setFocusSubscription();
42
40
  }
43
- /** @hidden */
44
- ngOnDestroy() {
45
- this.onDestroy$.next();
46
- this.onDestroy$.complete();
47
- }
48
41
  /** Keyboard Event Handler */
49
42
  onKeyDown(event) {
50
43
  this.keyboardTriggered.emit(event);
@@ -72,7 +65,7 @@ export class NestedListContentDirective {
72
65
  }
73
66
  /** Add subscription for child focusing */
74
67
  _setFocusSubscription() {
75
- this._itemService.focus.pipe(takeUntil(this.onDestroy$)).subscribe(() => this.focus());
68
+ this._itemService.focus.pipe(takeUntilDestroyed(this._destroyRef)).subscribe(() => this.focus());
76
69
  }
77
70
  /** Hide link child element from tab key */
78
71
  _makeLinkUnFocusable() {
@@ -81,7 +74,7 @@ export class NestedListContentDirective {
81
74
  this.changeDetRef.detectChanges();
82
75
  }
83
76
  }
84
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: NestedListContentDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.NestedItemService }], target: i0.ɵɵFactoryTarget.Directive }); }
77
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: NestedListContentDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.NestedItemService }], target: i0.ɵɵFactoryTarget.Directive }); }
85
78
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.4", type: NestedListContentDirective, selector: "[cxNestedListContent], [fdx-nested-list-content]", inputs: { selected: "selected" }, outputs: { selectedChange: "selectedChange", keyboardTriggered: "keyboardTriggered", clicked: "clicked" }, host: { attributes: { "tabindex": "0" }, listeners: { "keydown": "onKeyDown($event)", "click": "onClick($event)" }, properties: { "class.is-selected": "this.selected", "attr.role": "this.role", "attr.aria-expanded": "this.ariaExpanded", "class.fdx-nested-list__content": "this.cxNestedListContentClass", "class.has-child": "this.hasChildren" } }, queries: [{ propertyName: "nestedLink", first: true, predicate: NestedLinkComponent, descendants: true }, { propertyName: "nestedExpandIcon", first: true, predicate: NestedListExpandIconComponent, descendants: true }], ngImport: i0 }); }
86
79
  }
87
80
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: NestedListContentDirective, decorators: [{
@@ -92,7 +85,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImpor
92
85
  tabindex: '0'
93
86
  }
94
87
  }]
95
- }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.NestedItemService }], propDecorators: { selected: [{
88
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i1.NestedItemService }], propDecorators: { selected: [{
96
89
  type: Input
97
90
  }, {
98
91
  type: HostBinding,
@@ -128,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImpor
128
121
  type: HostListener,
129
122
  args: ['click', ['$event']]
130
123
  }] } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-list-content.directive.js","sourceRoot":"","sources":["../../../../../../libs/cx/nested-list/nested-content/nested-list-content.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,iBAAiB,EACjB,YAAY,EACZ,SAAS,EACT,UAAU,EACV,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,SAAS,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,6BAA6B,EAAE,MAAM,2BAA2B,CAAC;;;AAQ1E,MAAM,OAAO,0BAA0B;IAgDnC,cAAc;IACd,YACW,YAA+B,EAC9B,SAAoB,EACpB,WAAuB,EACvB,YAA+B;QAHhC,iBAAY,GAAZ,YAAY,CAAmB;QAC9B,cAAS,GAAT,SAAS,CAAW;QACpB,gBAAW,GAAX,WAAW,CAAY;QACvB,iBAAY,GAAZ,YAAY,CAAmB;QApD3C,sCAAsC;QAGtC,aAAQ,GAAG,KAAK,CAAC;QAEjB,cAAc;QAEd,SAAI,GAAG,UAAU,CAAC;QAElB,cAAc;QAEd,iBAAY,GAAG,KAAK,CAAC;QAErB,mDAAmD;QAEnD,mBAAc,GAA0B,IAAI,YAAY,EAAW,CAAC;QAEpE,kFAAkF;QAEzE,sBAAiB,GAAgC,IAAI,YAAY,EAAiB,CAAC;QAE5F,yDAAyD;QAEhD,YAAO,GAA6B,IAAI,YAAY,EAAc,CAAC;QAE5E,cAAc;QAEd,6BAAwB,GAAG,IAAI,CAAC;QAEhC;;;WAGG;QAEH,gBAAW,GAAG,KAAK,CAAC;QAUpB,uGAAuG;QACtF,eAAU,GAAkB,IAAI,OAAO,EAAQ,CAAC;IAQ9D,CAAC;IAEJ,cAAc;IACd,kBAAkB;QACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,qBAAqB,EAAE,CAAC;IACjC,CAAC;IAED,cAAc;IACd,WAAW;QACP,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED,6BAA6B;IAE7B,SAAS,CAAC,KAAoB;QAC1B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;IAED,+BAA+B;IAE/B,OAAO;QACH,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACnC,CAAC;IAED,8CAA8C;IAC9C,cAAc,CAAC,QAAiB;QAC5B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;IAED,gCAAgC;IAChC,KAAK;QACD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC3C,CAAC;IAED,gDAAgD;IAChD,KAAK;QACD,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;SAC3B;IACL,CAAC;IAED,0CAA0C;IAClC,qBAAqB;QACzB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;IAC3F,CAAC;IAED,2CAA2C;IACnC,oBAAoB;QACxB,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;YACvD,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;SACrC;IACL,CAAC;8GA/GQ,0BAA0B;kGAA1B,0BAA0B,wmBAsCrB,mBAAmB,mFAInB,6BAA6B;;2FA1ClC,0BAA0B;kBANtC,SAAS;mBAAC;oBACP,QAAQ,EAAE,kDAAkD;oBAC5D,IAAI,EAAE;wBACF,QAAQ,EAAE,GAAG;qBAChB;iBACJ;uKAKG,QAAQ;sBAFP,KAAK;;sBACL,WAAW;uBAAC,mBAAmB;gBAKhC,IAAI;sBADH,WAAW;uBAAC,WAAW;gBAKxB,YAAY;sBADX,WAAW;uBAAC,oBAAoB;gBAKjC,cAAc;sBADb,MAAM;gBAKE,iBAAiB;sBADzB,MAAM;gBAKE,OAAO;sBADf,MAAM;gBAKP,wBAAwB;sBADvB,WAAW;uBAAC,gCAAgC;gBAQ7C,WAAW;sBADV,WAAW;uBAAC,iBAAiB;gBAK9B,UAAU;sBADT,YAAY;uBAAC,mBAAmB;gBAKjC,gBAAgB;sBADf,YAAY;uBAAC,6BAA6B;gBA4B3C,SAAS;sBADR,YAAY;uBAAC,SAAS,EAAE,CAAC,QAAQ,CAAC;gBAQnC,OAAO;sBADN,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectorRef,\n    ContentChild,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    OnDestroy,\n    Output,\n    Renderer2\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { NestedItemService } from '../nested-item/nested-item.service';\nimport { NestedLinkComponent } from '../nested-link/nested-link.component';\nimport { NestedListExpandIconComponent } from '../nested-list-directives';\n\n@Directive({\n    selector: '[cxNestedListContent], [fdx-nested-list-content]',\n    host: {\n        tabindex: '0'\n    }\n})\nexport class NestedListContentDirective implements AfterContentInit, OnDestroy {\n    /** Whether this element is selected*/\n    @Input()\n    @HostBinding('class.is-selected')\n    selected = false;\n\n    /** @hidden */\n    @HostBinding('attr.role')\n    role = 'treeitem';\n\n    /** @hidden */\n    @HostBinding('attr.aria-expanded')\n    ariaExpanded = false;\n\n    /** Event thrown, when selected state is changed */\n    @Output()\n    selectedChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    /** Event that is thrown, when any keyboard event is dispatched on this element */\n    @Output()\n    readonly keyboardTriggered: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n    /** Event that is thrown, when this element is clicked */\n    @Output()\n    readonly clicked: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__content')\n    cxNestedListContentClass = true;\n\n    /**\n     * @hidden\n     * Attribute controlled by the parent `NestedItemComponent`\n     */\n    @HostBinding('class.has-child')\n    hasChildren = false;\n\n    /** @hidden */\n    @ContentChild(NestedLinkComponent)\n    nestedLink: NestedLinkComponent;\n\n    /** @hidden */\n    @ContentChild(NestedListExpandIconComponent)\n    nestedExpandIcon: NestedListExpandIconComponent;\n\n    /** An RxJS Subject that will kill the data stream upon component’s destruction (for unsubscribing)  */\n    private readonly onDestroy$: Subject<void> = new Subject<void>();\n\n    /** @hidden */\n    constructor(\n        public changeDetRef: ChangeDetectorRef,\n        private _renderer: Renderer2,\n        private _elementRef: ElementRef,\n        private _itemService: NestedItemService\n    ) {}\n\n    /** @hidden */\n    ngAfterContentInit(): void {\n        this._makeLinkUnFocusable();\n        this._setFocusSubscription();\n    }\n\n    /** @hidden */\n    ngOnDestroy(): void {\n        this.onDestroy$.next();\n        this.onDestroy$.complete();\n    }\n\n    /** Keyboard Event Handler */\n    @HostListener('keydown', ['$event'])\n    onKeyDown(event: KeyboardEvent): void {\n        this.keyboardTriggered.emit(event);\n        this._itemService.keyDown.next(event);\n    }\n\n    /** Handler for mouse events */\n    @HostListener('click', ['$event'])\n    onClick(): void {\n        this._itemService.click.next();\n    }\n\n    /** Method to trigger selected state change */\n    changeSelected(selected: boolean): void {\n        this.selected = selected;\n        this.selectedChange.emit(selected);\n    }\n\n    /** Set focus on the element. */\n    focus(): void {\n        this._elementRef.nativeElement.focus();\n    }\n\n    /** Dispatches the click event on the element */\n    click(): void {\n        this.focus();\n        if (this.nestedLink) {\n            this.nestedLink.click();\n        }\n    }\n\n    /** Add subscription for child focusing */\n    private _setFocusSubscription(): void {\n        this._itemService.focus.pipe(takeUntil(this.onDestroy$)).subscribe(() => this.focus());\n    }\n\n    /** Hide link child element from tab key */\n    private _makeLinkUnFocusable(): void {\n        if (this.nestedLink) {\n            this.nestedLink.elementRef.nativeElement.tabIndex = -1;\n            this.changeDetRef.detectChanges();\n        }\n    }\n}\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-list-content.directive.js","sourceRoot":"","sources":["../../../../../../libs/cx/nested-list/nested-content/nested-list-content.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectorRef,\n    ContentChild,\n    DestroyRef,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    Output,\n    inject\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { NestedItemService } from '../nested-item/nested-item.service';\nimport { NestedLinkComponent } from '../nested-link/nested-link.component';\nimport { NestedListExpandIconComponent } from '../nested-list-directives';\n\n@Directive({\n    selector: '[cxNestedListContent], [fdx-nested-list-content]',\n    host: {\n        tabindex: '0'\n    }\n})\nexport class NestedListContentDirective implements AfterContentInit {\n    /** Whether this element is selected*/\n    @Input()\n    @HostBinding('class.is-selected')\n    selected = false;\n\n    /** @hidden */\n    @HostBinding('attr.role')\n    role = 'treeitem';\n\n    /** @hidden */\n    @HostBinding('attr.aria-expanded')\n    ariaExpanded = false;\n\n    /** Event thrown, when selected state is changed */\n    @Output()\n    selectedChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    /** Event that is thrown, when any keyboard event is dispatched on this element */\n    @Output()\n    readonly keyboardTriggered: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n    /** Event that is thrown, when this element is clicked */\n    @Output()\n    readonly clicked: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__content')\n    cxNestedListContentClass = true;\n\n    /**\n     * @hidden\n     * Attribute controlled by the parent `NestedItemComponent`\n     */\n    @HostBinding('class.has-child')\n    hasChildren = false;\n\n    /** @hidden */\n    @ContentChild(NestedLinkComponent)\n    nestedLink: NestedLinkComponent;\n\n    /** @hidden */\n    @ContentChild(NestedListExpandIconComponent)\n    nestedExpandIcon: NestedListExpandIconComponent;\n\n    /** @hidden */\n    private readonly _destroyRef = inject(DestroyRef);\n\n    /** @hidden */\n    constructor(\n        public changeDetRef: ChangeDetectorRef,\n        private _elementRef: ElementRef,\n        private _itemService: NestedItemService\n    ) {}\n\n    /** @hidden */\n    ngAfterContentInit(): void {\n        this._makeLinkUnFocusable();\n        this._setFocusSubscription();\n    }\n\n    /** Keyboard Event Handler */\n    @HostListener('keydown', ['$event'])\n    onKeyDown(event: KeyboardEvent): void {\n        this.keyboardTriggered.emit(event);\n        this._itemService.keyDown.next(event);\n    }\n\n    /** Handler for mouse events */\n    @HostListener('click', ['$event'])\n    onClick(): void {\n        this._itemService.click.next();\n    }\n\n    /** Method to trigger selected state change */\n    changeSelected(selected: boolean): void {\n        this.selected = selected;\n        this.selectedChange.emit(selected);\n    }\n\n    /** Set focus on the element. */\n    focus(): void {\n        this._elementRef.nativeElement.focus();\n    }\n\n    /** Dispatches the click event on the element */\n    click(): void {\n        this.focus();\n        if (this.nestedLink) {\n            this.nestedLink.click();\n        }\n    }\n\n    /** Add subscription for child focusing */\n    private _setFocusSubscription(): void {\n        this._itemService.focus.pipe(takeUntilDestroyed(this._destroyRef)).subscribe(() => this.focus());\n    }\n\n    /** Hide link child element from tab key */\n    private _makeLinkUnFocusable(): void {\n        if (this.nestedLink) {\n            this.nestedLink.elementRef.nativeElement.tabIndex = -1;\n            this.changeDetRef.detectChanges();\n        }\n    }\n}\n"]}
@@ -1,6 +1,6 @@
1
- import { Component, ContentChild, ElementRef, EventEmitter, HostBinding, Input, Output, forwardRef } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import { filter, takeUntil } from 'rxjs/operators';
1
+ import { Component, ContentChild, DestroyRef, ElementRef, EventEmitter, HostBinding, Input, Output, forwardRef, inject } from '@angular/core';
2
+ import { filter } from 'rxjs/operators';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
4
  import { NestedListContentDirective } from '../nested-content/nested-list-content.directive';
5
5
  import { NestedLinkComponent } from '../nested-link/nested-link.component';
6
6
  import { NestedListExpandIconComponent } from '../nested-list-directives';
@@ -56,8 +56,8 @@ export class NestedItemComponent {
56
56
  this._ariaDisabled = false;
57
57
  /** @hidden */
58
58
  this._ariaHidden = true;
59
- /** An RxJS Subject that will kill the data stream upon component’s destruction (for unsubscribing) */
60
- this._onDestroy$ = new Subject();
59
+ /** @hidden */
60
+ this._destroyRef = inject(DestroyRef);
61
61
  /** Unique element ID */
62
62
  this._elementId = 'fdNestedItem' + sideNavigationItemUniqueId++;
63
63
  }
@@ -74,11 +74,6 @@ export class NestedItemComponent {
74
74
  this._title = this.linkItem.getTitle();
75
75
  }
76
76
  }
77
- /** @hidden */
78
- ngOnDestroy() {
79
- this._onDestroy$.next();
80
- this._onDestroy$.complete();
81
- }
82
77
  /** Check if the item element has any child */
83
78
  get hasChildren() {
84
79
  return !!this._itemService?.list;
@@ -178,19 +173,19 @@ export class NestedItemComponent {
178
173
  }
179
174
  if (!this.display) {
180
175
  /** Subscribe to mouse click event, thrown by link item */
181
- this._itemService.toggle.pipe(takeUntil(this._onDestroy$)).subscribe(() => this.toggle());
176
+ this._itemService.toggle.pipe(takeUntilDestroyed(this._destroyRef)).subscribe(() => this.toggle());
182
177
  /** Subscribe to mouse click event, thrown by link item */
183
178
  this._itemService.click
184
- .pipe(takeUntil(this._onDestroy$))
179
+ .pipe(takeUntilDestroyed(this._destroyRef))
185
180
  .subscribe(() => this._stateService.onSelected.next(this._elementId));
186
181
  }
187
182
  /** Subscribe to keyboard event and throw it farther */
188
183
  this._itemService.keyDown
189
- .pipe(takeUntil(this._onDestroy$))
184
+ .pipe(takeUntilDestroyed(this._destroyRef))
190
185
  .subscribe((keyboardEvent) => this.keyboardTriggered.emit(keyboardEvent));
191
186
  /** Subscribe to selected state change, it's not triggered, when selectable flag is disabled*/
192
187
  this._stateService.onSelected
193
- .pipe(takeUntil(this._onDestroy$), filter(() => this._stateService.selectable))
188
+ .pipe(takeUntilDestroyed(this._destroyRef), filter(() => this._stateService.selectable))
194
189
  .subscribe((id) => this._selectedChange(id));
195
190
  }
196
191
  /** @hidden */
@@ -290,4 +285,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImpor
290
285
  type: HostBinding,
291
286
  args: ['attr.aria-hidden']
292
287
  }] } });
293
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-item.component.js","sourceRoot":"","sources":["../../../../../../libs/cx/nested-list/nested-item/nested-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnDestroy,\n    Output,\n    forwardRef\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\n\nimport { Nullable } from '@fundamental-ngx/cdk/utils';\nimport { NestedListContentDirective } from '../nested-content/nested-list-content.directive';\nimport { NestedLinkComponent } from '../nested-link/nested-link.component';\nimport { NestedListExpandIconComponent } from '../nested-list-directives';\nimport { NestedListKeyboardService } from '../nested-list-keyboard.service';\nimport { NestedListStateService } from '../nested-list-state.service';\nimport { NestedListComponent } from '../nested-list/nested-list.component';\nimport { NestedItemInterface } from './nested-item.interface';\nimport { NestedItemService } from './nested-item.service';\n\nlet sideNavigationItemUniqueId = 0;\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[cxNestedItem], [fdx-nested-list-item], li[fdx-nested-list-item]',\n    template: ` <ng-content></ng-content> `,\n    providers: [NestedItemService],\n    host: {\n        role: 'treeitem'\n    }\n})\nexport class NestedItemComponent implements AfterContentInit, NestedItemInterface, OnDestroy {\n    /** Whether item should be expanded */\n    @Input() set expanded(expanded: boolean) {\n        if (expanded !== this._expanded) {\n            this.propagateOpenChange(expanded);\n        }\n    }\n\n    /** @hidden */\n    get expanded(): boolean {\n        return this._expanded;\n    }\n\n    /** Event thrown, when expanded state is changed */\n    @Output()\n    readonly expandedChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    /** Event thrown, when any keyboard event is dispatched on this, or link element */\n    @Output()\n    readonly keyboardTriggered: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n    /** @hidden */\n    @Input()\n    @HostBinding('class.fdx-nested-list__item')\n    fdNestedListItemClass = true;\n\n    /** Whether this item is a header item. */\n    @Input()\n    @HostBinding('class.fdx-nested-list__item--header')\n    header = false;\n\n    /** Whether this item is only meant for display purposes, meaning it cannot be used for navigation or shown as selected. */\n    @Input()\n    display = false;\n\n    /**\n     * @hidden\n     * Reference to the link directive, to allow manipulating the properties of this element.\n     */\n    @ContentChild(NestedLinkComponent)\n    linkItem: NestedLinkComponent;\n\n    /**\n     * @hidden\n     * Mostly used, when this item has list\n     * Reference to the content directive, to allow manipulating the properties of this element.\n     */\n    @ContentChild(NestedListContentDirective)\n    contentItem: NestedListContentDirective;\n\n    /** @hidden */\n    @ContentChild(NestedListExpandIconComponent, { descendants: true })\n    expandIcon: NestedListExpandIconComponent;\n\n    /** @hidden */\n    @ContentChild(forwardRef(() => NestedListComponent))\n    _nestedList: NestedListComponent;\n\n    /** @hidden */\n    @HostBinding('attr.aria-level')\n    _ariaLevel: Nullable<number> = null;\n\n    /** @hidden */\n    @HostBinding('attr.title')\n    _title: string;\n\n    /** @hidden */\n    @HostBinding('style.display')\n    _display = 'block';\n\n    /** @hidden */\n    _narrow = false;\n\n    /** @hidden */\n    @HostBinding('attr.role')\n    private _role: string;\n\n    /** @hidden */\n    private _expanded = false;\n\n    /** @hidden */\n    @HostBinding('attr.aria-expanded')\n    private _ariaExpanded: Nullable<boolean> = null;\n\n    /** @hidden */\n    @HostBinding('attr.aria-selected')\n    private _ariaSelected: Nullable<boolean> = null;\n\n    /** @hidden */\n    @HostBinding('attr.aria-disabled')\n    private _ariaDisabled = false;\n\n    /** @hidden */\n    @HostBinding('attr.aria-label')\n    private _ariaLabel: string;\n\n    /** @hidden */\n    @HostBinding('attr.aria-hidden')\n    private _ariaHidden = true;\n\n    /** An RxJS Subject that will kill the data stream upon component’s destruction (for unsubscribing)  */\n    private readonly _onDestroy$: Subject<void> = new Subject<void>();\n\n    /** Unique element ID */\n    private readonly _elementId: string = 'fdNestedItem' + sideNavigationItemUniqueId++;\n\n    /** @hidden */\n    constructor(\n        private _itemService: NestedItemService,\n        private _keyboardService: NestedListKeyboardService,\n        private _stateService: NestedListStateService,\n        public elementRef: ElementRef\n    ) {}\n\n    /** @hidden */\n    ngAfterContentInit(): void {\n        this._setUpSubscriptions();\n        this._propagateHasChildrenProperty();\n        this._passItemReferences();\n        /** Propagate initial open state to children */\n        this.propagateOpenChange(this._expanded);\n\n        if (this.linkItem) {\n            this._ariaSelected = this.linkItem.selected;\n            this._ariaDisabled = !this._stateService.selectable && !this.linkItem.selected;\n            this._title = this.linkItem.getTitle();\n        }\n    }\n\n    /** @hidden */\n    ngOnDestroy(): void {\n        this._onDestroy$.next();\n        this._onDestroy$.complete();\n    }\n\n    /** Check if the item element has any child */\n    get hasChildren(): boolean {\n        return !!this._itemService?.list;\n    }\n\n    /** Get all of the children item elements */\n    get allChildrenItems(): NestedItemInterface[] {\n        if (this._itemService?.list) {\n            return this._itemService.list.nestedItems.toArray();\n        }\n\n        return [];\n    }\n\n    /** Method that expand the item and propagate it to children */\n    triggerOpen(): void {\n        if (!this.expanded) {\n            /** Propagate initial open state to children */\n            this.propagateOpenChange(true);\n        }\n    }\n\n    /** Method that close the item and propagate it to children */\n    triggerClose(): void {\n        if (this.expanded) {\n            /** Propagate initial open state to children */\n            this.propagateOpenChange(false);\n        }\n    }\n\n    /** Method that toggle the item and propagate it to children */\n    toggle(): void {\n        /** Propagate initial open state to children */\n        this.propagateOpenChange(!this._expanded);\n    }\n\n    /** Method that dispatches `click` event on link item*/\n    click(): void {\n        if (!this.display) {\n            if (this.contentItem) {\n                this.contentItem.click();\n            } else if (this.linkItem) {\n                this.linkItem.click();\n            }\n        }\n    }\n\n    /** Method that focuses link item*/\n    focus(): void {\n        if (this.contentItem) {\n            this.contentItem.focus();\n        } else if (this.linkItem) {\n            this.linkItem.focus();\n        }\n    }\n\n    /** Method that provides information if element, or children of this element has passed id */\n    containsId(id: string): boolean {\n        if (this._elementId === id) {\n            return true;\n        }\n\n        if (this._itemService.list) {\n            return !!this._itemService.list.nestedItems.find((item) => item.containsId(id));\n        }\n\n        return false;\n    }\n\n    /**\n     * @hidden\n     * Propagate open state to all of the children\n     */\n    private propagateOpenChange(open: boolean): void {\n        this._expanded = open;\n\n        if (this.hasChildren) {\n            this._ariaExpanded = this._expanded;\n        }\n\n        this.expandIcon?.changeExpandedState(open);\n\n        /** Propagate hidden flag to list component, that is passed from child */\n        if (this._itemService.list) {\n            this._itemService.list.hidden = !open;\n            this._itemService.list.detectChanges();\n        }\n\n        /** Propagate open flag to popover list component, that is passed from child */\n        if (this._itemService.popover) {\n            this._itemService.popover.open = open;\n        }\n\n        /**\n         * If there are any list below\n         * Trigger event to provide keyboard support to new list of opened item element.\n         * */\n        if (this._shouldRefreshKeyboardService()) {\n            this._keyboardService.refresh$.next();\n        }\n\n        this.expandedChange.emit(open);\n    }\n\n    /** @hidden */\n    private _shouldRefreshKeyboardService(): boolean {\n        return !!(this._itemService.popover || this._itemService.list || this.contentItem);\n    }\n\n    /** @hidden */\n    private _setUpSubscriptions(): void {\n        if (this._stateService.condensed) {\n            this._role = 'menuitemradio';\n        }\n\n        if (!this.display) {\n            /** Subscribe to mouse click event, thrown by link item */\n            this._itemService.toggle.pipe(takeUntil(this._onDestroy$)).subscribe(() => this.toggle());\n\n            /** Subscribe to mouse click event, thrown by link item */\n            this._itemService.click\n                .pipe(takeUntil(this._onDestroy$))\n                .subscribe(() => this._stateService.onSelected.next(this._elementId));\n        }\n\n        /** Subscribe to keyboard event and throw it farther */\n        this._itemService.keyDown\n            .pipe(takeUntil(this._onDestroy$))\n            .subscribe((keyboardEvent) => this.keyboardTriggered.emit(keyboardEvent));\n\n        /** Subscribe to selected state change, it's not triggered, when selectable flag is disabled*/\n        this._stateService.onSelected\n            .pipe(\n                takeUntil(this._onDestroy$),\n                filter(() => this._stateService.selectable)\n            )\n            .subscribe((id) => this._selectedChange(id));\n    }\n\n    /** @hidden */\n    private _propagateHasChildrenProperty(): void {\n        if (this.contentItem && this.hasChildren) {\n            this._ariaExpanded = false;\n            this.contentItem.hasChildren = true;\n            this.contentItem.changeDetRef.detectChanges();\n        }\n    }\n\n    /** Pass this element to popover child item, to allow control `expanded` value */\n    private _passItemReferences(): void {\n        if (this._itemService.popover) {\n            this._itemService.popover.parentItemElement = this;\n        }\n    }\n\n    /** Change of selected state of content or link, if there is any children with I */\n    private _selectedChange(id: string): void {\n        const selected = this.containsId(id);\n        this._ariaSelected = selected;\n\n        if (this.contentItem) {\n            this.contentItem.changeSelected(selected);\n        } else if (this.linkItem) {\n            this.linkItem.changeSelected(selected);\n        }\n    }\n}\n"]}
288
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-item.component.js","sourceRoot":"","sources":["../../../../../../libs/cx/nested-list/nested-item/nested-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    Component,\n    ContentChild,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    Output,\n    forwardRef,\n    inject\n} from '@angular/core';\nimport { filter } from 'rxjs/operators';\n\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { Nullable } from '@fundamental-ngx/cdk/utils';\nimport { NestedListContentDirective } from '../nested-content/nested-list-content.directive';\nimport { NestedLinkComponent } from '../nested-link/nested-link.component';\nimport { NestedListExpandIconComponent } from '../nested-list-directives';\nimport { NestedListKeyboardService } from '../nested-list-keyboard.service';\nimport { NestedListStateService } from '../nested-list-state.service';\nimport { NestedListComponent } from '../nested-list/nested-list.component';\nimport { NestedItemInterface } from './nested-item.interface';\nimport { NestedItemService } from './nested-item.service';\n\nlet sideNavigationItemUniqueId = 0;\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[cxNestedItem], [fdx-nested-list-item], li[fdx-nested-list-item]',\n    template: ` <ng-content></ng-content> `,\n    providers: [NestedItemService],\n    host: {\n        role: 'treeitem'\n    }\n})\nexport class NestedItemComponent implements AfterContentInit, NestedItemInterface {\n    /** Whether item should be expanded */\n    @Input() set expanded(expanded: boolean) {\n        if (expanded !== this._expanded) {\n            this.propagateOpenChange(expanded);\n        }\n    }\n\n    /** @hidden */\n    get expanded(): boolean {\n        return this._expanded;\n    }\n\n    /** Event thrown, when expanded state is changed */\n    @Output()\n    readonly expandedChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    /** Event thrown, when any keyboard event is dispatched on this, or link element */\n    @Output()\n    readonly keyboardTriggered: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n    /** @hidden */\n    @Input()\n    @HostBinding('class.fdx-nested-list__item')\n    fdNestedListItemClass = true;\n\n    /** Whether this item is a header item. */\n    @Input()\n    @HostBinding('class.fdx-nested-list__item--header')\n    header = false;\n\n    /** Whether this item is only meant for display purposes, meaning it cannot be used for navigation or shown as selected. */\n    @Input()\n    display = false;\n\n    /**\n     * @hidden\n     * Reference to the link directive, to allow manipulating the properties of this element.\n     */\n    @ContentChild(NestedLinkComponent)\n    linkItem: NestedLinkComponent;\n\n    /**\n     * @hidden\n     * Mostly used, when this item has list\n     * Reference to the content directive, to allow manipulating the properties of this element.\n     */\n    @ContentChild(NestedListContentDirective)\n    contentItem: NestedListContentDirective;\n\n    /** @hidden */\n    @ContentChild(NestedListExpandIconComponent, { descendants: true })\n    expandIcon: NestedListExpandIconComponent;\n\n    /** @hidden */\n    @ContentChild(forwardRef(() => NestedListComponent))\n    _nestedList: NestedListComponent;\n\n    /** @hidden */\n    @HostBinding('attr.aria-level')\n    _ariaLevel: Nullable<number> = null;\n\n    /** @hidden */\n    @HostBinding('attr.title')\n    _title: string;\n\n    /** @hidden */\n    @HostBinding('style.display')\n    _display = 'block';\n\n    /** @hidden */\n    _narrow = false;\n\n    /** @hidden */\n    @HostBinding('attr.role')\n    private _role: string;\n\n    /** @hidden */\n    private _expanded = false;\n\n    /** @hidden */\n    @HostBinding('attr.aria-expanded')\n    private _ariaExpanded: Nullable<boolean> = null;\n\n    /** @hidden */\n    @HostBinding('attr.aria-selected')\n    private _ariaSelected: Nullable<boolean> = null;\n\n    /** @hidden */\n    @HostBinding('attr.aria-disabled')\n    private _ariaDisabled = false;\n\n    /** @hidden */\n    @HostBinding('attr.aria-label')\n    private _ariaLabel: string;\n\n    /** @hidden */\n    @HostBinding('attr.aria-hidden')\n    private _ariaHidden = true;\n\n    /** @hidden */\n    private readonly _destroyRef = inject(DestroyRef);\n\n    /** Unique element ID */\n    private readonly _elementId: string = 'fdNestedItem' + sideNavigationItemUniqueId++;\n\n    /** @hidden */\n    constructor(\n        private _itemService: NestedItemService,\n        private _keyboardService: NestedListKeyboardService,\n        private _stateService: NestedListStateService,\n        public elementRef: ElementRef\n    ) {}\n\n    /** @hidden */\n    ngAfterContentInit(): void {\n        this._setUpSubscriptions();\n        this._propagateHasChildrenProperty();\n        this._passItemReferences();\n        /** Propagate initial open state to children */\n        this.propagateOpenChange(this._expanded);\n\n        if (this.linkItem) {\n            this._ariaSelected = this.linkItem.selected;\n            this._ariaDisabled = !this._stateService.selectable && !this.linkItem.selected;\n            this._title = this.linkItem.getTitle();\n        }\n    }\n\n    /** Check if the item element has any child */\n    get hasChildren(): boolean {\n        return !!this._itemService?.list;\n    }\n\n    /** Get all of the children item elements */\n    get allChildrenItems(): NestedItemInterface[] {\n        if (this._itemService?.list) {\n            return this._itemService.list.nestedItems.toArray();\n        }\n\n        return [];\n    }\n\n    /** Method that expand the item and propagate it to children */\n    triggerOpen(): void {\n        if (!this.expanded) {\n            /** Propagate initial open state to children */\n            this.propagateOpenChange(true);\n        }\n    }\n\n    /** Method that close the item and propagate it to children */\n    triggerClose(): void {\n        if (this.expanded) {\n            /** Propagate initial open state to children */\n            this.propagateOpenChange(false);\n        }\n    }\n\n    /** Method that toggle the item and propagate it to children */\n    toggle(): void {\n        /** Propagate initial open state to children */\n        this.propagateOpenChange(!this._expanded);\n    }\n\n    /** Method that dispatches `click` event on link item*/\n    click(): void {\n        if (!this.display) {\n            if (this.contentItem) {\n                this.contentItem.click();\n            } else if (this.linkItem) {\n                this.linkItem.click();\n            }\n        }\n    }\n\n    /** Method that focuses link item*/\n    focus(): void {\n        if (this.contentItem) {\n            this.contentItem.focus();\n        } else if (this.linkItem) {\n            this.linkItem.focus();\n        }\n    }\n\n    /** Method that provides information if element, or children of this element has passed id */\n    containsId(id: string): boolean {\n        if (this._elementId === id) {\n            return true;\n        }\n\n        if (this._itemService.list) {\n            return !!this._itemService.list.nestedItems.find((item) => item.containsId(id));\n        }\n\n        return false;\n    }\n\n    /**\n     * @hidden\n     * Propagate open state to all of the children\n     */\n    private propagateOpenChange(open: boolean): void {\n        this._expanded = open;\n\n        if (this.hasChildren) {\n            this._ariaExpanded = this._expanded;\n        }\n\n        this.expandIcon?.changeExpandedState(open);\n\n        /** Propagate hidden flag to list component, that is passed from child */\n        if (this._itemService.list) {\n            this._itemService.list.hidden = !open;\n            this._itemService.list.detectChanges();\n        }\n\n        /** Propagate open flag to popover list component, that is passed from child */\n        if (this._itemService.popover) {\n            this._itemService.popover.open = open;\n        }\n\n        /**\n         * If there are any list below\n         * Trigger event to provide keyboard support to new list of opened item element.\n         * */\n        if (this._shouldRefreshKeyboardService()) {\n            this._keyboardService.refresh$.next();\n        }\n\n        this.expandedChange.emit(open);\n    }\n\n    /** @hidden */\n    private _shouldRefreshKeyboardService(): boolean {\n        return !!(this._itemService.popover || this._itemService.list || this.contentItem);\n    }\n\n    /** @hidden */\n    private _setUpSubscriptions(): void {\n        if (this._stateService.condensed) {\n            this._role = 'menuitemradio';\n        }\n\n        if (!this.display) {\n            /** Subscribe to mouse click event, thrown by link item */\n            this._itemService.toggle.pipe(takeUntilDestroyed(this._destroyRef)).subscribe(() => this.toggle());\n\n            /** Subscribe to mouse click event, thrown by link item */\n            this._itemService.click\n                .pipe(takeUntilDestroyed(this._destroyRef))\n                .subscribe(() => this._stateService.onSelected.next(this._elementId));\n        }\n\n        /** Subscribe to keyboard event and throw it farther */\n        this._itemService.keyDown\n            .pipe(takeUntilDestroyed(this._destroyRef))\n            .subscribe((keyboardEvent) => this.keyboardTriggered.emit(keyboardEvent));\n\n        /** Subscribe to selected state change, it's not triggered, when selectable flag is disabled*/\n        this._stateService.onSelected\n            .pipe(\n                takeUntilDestroyed(this._destroyRef),\n                filter(() => this._stateService.selectable)\n            )\n            .subscribe((id) => this._selectedChange(id));\n    }\n\n    /** @hidden */\n    private _propagateHasChildrenProperty(): void {\n        if (this.contentItem && this.hasChildren) {\n            this._ariaExpanded = false;\n            this.contentItem.hasChildren = true;\n            this.contentItem.changeDetRef.detectChanges();\n        }\n    }\n\n    /** Pass this element to popover child item, to allow control `expanded` value */\n    private _passItemReferences(): void {\n        if (this._itemService.popover) {\n            this._itemService.popover.parentItemElement = this;\n        }\n    }\n\n    /** Change of selected state of content or link, if there is any children with I */\n    private _selectedChange(id: string): void {\n        const selected = this.containsId(id);\n        this._ariaSelected = selected;\n\n        if (this.contentItem) {\n            this.contentItem.changeSelected(selected);\n        } else if (this.linkItem) {\n            this.linkItem.changeSelected(selected);\n        }\n    }\n}\n"]}
@@ -1,12 +1,8 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, Directive, ElementRef, HostBinding, HostListener, Input, Optional, ViewEncapsulation } from '@angular/core';
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, Directive, ElementRef, HostBinding, HostListener, Input, ViewEncapsulation } from '@angular/core';
2
2
  import { IconComponent } from '@fundamental-ngx/core/icon';
3
- import { RtlService } from '@fundamental-ngx/core/utils';
4
- import { of } from 'rxjs';
5
- import { map } from 'rxjs/operators';
6
3
  import { NestedItemService } from './nested-item/nested-item.service';
7
4
  import * as i0 from "@angular/core";
8
5
  import * as i1 from "./nested-item/nested-item.service";
9
- import * as i2 from "@fundamental-ngx/core/utils";
10
6
  let uniqueId = 0;
11
7
  export class NestedListHeaderDirective {
12
8
  /** @hidden */
@@ -98,11 +94,9 @@ export class NestedListExpandIconComponent {
98
94
  return !this.expanded;
99
95
  }
100
96
  /** @hidden */
101
- constructor(_itemService, _changeDetRef, _elementRef, _rtlService) {
97
+ constructor(_itemService, _changeDetRef) {
102
98
  this._itemService = _itemService;
103
99
  this._changeDetRef = _changeDetRef;
104
- this._elementRef = _elementRef;
105
- this._rtlService = _rtlService;
106
100
  /** @hidden */
107
101
  this.fdNestedListArrowClass = true;
108
102
  /**
@@ -112,7 +106,6 @@ export class NestedListExpandIconComponent {
112
106
  this.expanded = false;
113
107
  /** @hidden */
114
108
  this.ariaHidden = true;
115
- this._listenOnTextDirection();
116
109
  }
117
110
  /** Mouse event handler */
118
111
  onClick(event) {
@@ -129,11 +122,7 @@ export class NestedListExpandIconComponent {
129
122
  this.expanded = expanded;
130
123
  this._changeDetRef.detectChanges();
131
124
  }
132
- /** @hidden Sets expand arrow depending on text direction */
133
- _listenOnTextDirection() {
134
- this.rtl$ = this._rtlService ? this._rtlService.rtl.pipe(map((isRtl) => isRtl)) : of(false);
135
- }
136
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: NestedListExpandIconComponent, deps: [{ token: i1.NestedItemService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i2.RtlService, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
125
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: NestedListExpandIconComponent, deps: [{ token: i1.NestedItemService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
137
126
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.4", type: NestedListExpandIconComponent, selector: "[cxNestedListExpandIcon], [fdx-nested-list-expand-icon]", host: { attributes: { "aria-haspopup": "true", "role": "presentation" }, listeners: { "click": "onClick($event)", "focus": "onFocus()" }, properties: { "class.fdx-nested-list__arrow": "this.fdNestedListArrowClass", "class.sap-icon--navigation-down-arrow": "this.fdNestedListDownArrowClass", "class.sap-icon--navigation-right-arrow": "this.fdNestedListRightArrowClass", "class.is-expanded": "this.expanded", "attr.aria-expanded": "this.expanded", "attr.aria-hidden": "this.ariaHidden" } }, ngImport: i0, template: ` <ng-content></ng-content> `, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
138
127
  }
139
128
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: NestedListExpandIconComponent, decorators: [{
@@ -149,9 +138,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImpor
149
138
  changeDetection: ChangeDetectionStrategy.OnPush,
150
139
  encapsulation: ViewEncapsulation.None
151
140
  }]
152
- }], ctorParameters: () => [{ type: i1.NestedItemService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i2.RtlService, decorators: [{
153
- type: Optional
154
- }] }], propDecorators: { fdNestedListArrowClass: [{
141
+ }], ctorParameters: () => [{ type: i1.NestedItemService }, { type: i0.ChangeDetectorRef }], propDecorators: { fdNestedListArrowClass: [{
155
142
  type: HostBinding,
156
143
  args: ['class.fdx-nested-list__arrow']
157
144
  }], fdNestedListDownArrowClass: [{
@@ -217,4 +204,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImpor
217
204
  type: HostListener,
218
205
  args: ['keydown.space', ['$event']]
219
206
  }] } });
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-list-directives.js","sourceRoot":"","sources":["../../../../../libs/cx/nested-list/nested-list-directives.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    Directive,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    Optional,\n    ViewEncapsulation\n} from '@angular/core';\nimport { IconComponent } from '@fundamental-ngx/core/icon';\nimport { RtlService } from '@fundamental-ngx/core/utils';\nimport { Observable, of } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { NestedItemService } from './nested-item/nested-item.service';\n\nlet uniqueId = 0;\n\n@Directive({\n    selector: '[cxNestedDirectivesHeader], [fdx-nested-list-header]'\n})\nexport class NestedListHeaderDirective {\n    /** Id of the element. */\n    @Input()\n    @HostBinding('attr.id')\n    id: string | null = `fdx-nested-list-group-header-${++uniqueId}`;\n\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__group-header')\n    cxNestedListHeaderClass = true;\n\n    /** @hidden */\n    constructor(private _elementRef: ElementRef) {}\n\n    /** Get the header title */\n    get title(): string {\n        return this._elementRef.nativeElement.textContent;\n    }\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[cxNestedDirectivesIcon], [fdx-nested-list-icon]',\n    template: `<ng-content></ng-content>`\n})\nexport class NestedListIconComponent extends IconComponent {\n    /** Role attribute */\n    @Input()\n    @HostBinding('attr.role')\n    role = 'presentation';\n\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__icon')\n    fdNestedListIconClass = true;\n}\n\n@Directive({\n    selector: '[cxNestedDirectivesTitle], [fdx-nested-list-title]'\n})\nexport class NestedListTitleDirective {\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__title')\n    fdNestedListTitleClass = true;\n\n    /** @hidden */\n    constructor(private elementRef: ElementRef) {}\n\n    /** Returns element's InnerText */\n    getInnerText(): string {\n        return this.elementRef && this.elementRef.nativeElement.textContent;\n    }\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[cxNestedListExpandIcon], [fdx-nested-list-expand-icon]',\n    template: ` <ng-content></ng-content> `,\n    host: {\n        'aria-haspopup': 'true',\n        role: 'presentation'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None\n})\nexport class NestedListExpandIconComponent {\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__arrow')\n    fdNestedListArrowClass = true;\n\n    /** @hidden */\n    @HostBinding('class.sap-icon--navigation-down-arrow')\n    get fdNestedListDownArrowClass(): boolean {\n        return this.expanded;\n    }\n\n    /** @hidden */\n    @HostBinding('class.sap-icon--navigation-right-arrow')\n    get fdNestedListRightArrowClass(): any {\n        return !this.expanded;\n    }\n\n    /**\n     * @hidden\n     * Attribute controlled by the parent `NestedItemComponent`\n     */\n    @HostBinding('class.is-expanded')\n    @HostBinding('attr.aria-expanded')\n    expanded = false;\n\n    /** @hidden */\n    @HostBinding('attr.aria-hidden')\n    ariaHidden = true;\n\n    /** @hidden */\n    rtl$: Observable<boolean>;\n\n    /** @hidden */\n    constructor(\n        private _itemService: NestedItemService,\n        private _changeDetRef: ChangeDetectorRef,\n        private _elementRef: ElementRef,\n        @Optional() private _rtlService: RtlService\n    ) {\n        this._listenOnTextDirection();\n    }\n\n    /** Mouse event handler */\n    @HostListener('click', ['$event'])\n    onClick(event?: MouseEvent): void {\n        this.expanded = !this.expanded;\n        this._itemService.toggle.next(this.expanded);\n        event?.stopPropagation();\n    }\n\n    /** Handler for focus events */\n    @HostListener('focus')\n    onFocus(): void {\n        this._itemService.focus.next();\n    }\n\n    /** @hidden */\n    changeExpandedState(expanded: boolean): void {\n        this.expanded = expanded;\n        this._changeDetRef.detectChanges();\n    }\n\n    /** @hidden Sets expand arrow depending on text direction */\n    private _listenOnTextDirection(): void {\n        this.rtl$ = this._rtlService ? this._rtlService.rtl.pipe(map((isRtl) => isRtl)) : of(false);\n    }\n}\n\n@Directive({\n    selector: '[cxNestedDirectivesButton], [fdx-nested-list-button]'\n})\nexport class NestedListButtonDirective implements AfterContentInit {\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__button')\n    fdNestedListButtonClass = true;\n\n    /** @hidden */\n    @ContentChild(NestedListExpandIconComponent)\n    _expandIcon: NestedListExpandIconComponent;\n\n    /** @hidden */\n    @HostListener('click', ['$event'])\n    @HostListener('keydown.enter', ['$event'])\n    @HostListener('keydown.space', ['$event'])\n    onClick(event: Event): void {\n        event.preventDefault();\n        event.stopPropagation();\n        this._expandIcon.onClick();\n    }\n\n    /** @hidden */\n    ngAfterContentInit(): void {\n        if (this._expandIcon) {\n            this._expandIcon.fdNestedListArrowClass = false;\n        }\n    }\n}\n"]}
207
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-list-directives.js","sourceRoot":"","sources":["../../../../../libs/cx/nested-list/nested-list-directives.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    Directive,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    ViewEncapsulation\n} from '@angular/core';\nimport { IconComponent } from '@fundamental-ngx/core/icon';\nimport { NestedItemService } from './nested-item/nested-item.service';\n\nlet uniqueId = 0;\n\n@Directive({\n    selector: '[cxNestedDirectivesHeader], [fdx-nested-list-header]'\n})\nexport class NestedListHeaderDirective {\n    /** Id of the element. */\n    @Input()\n    @HostBinding('attr.id')\n    id: string | null = `fdx-nested-list-group-header-${++uniqueId}`;\n\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__group-header')\n    cxNestedListHeaderClass = true;\n\n    /** @hidden */\n    constructor(private _elementRef: ElementRef) {}\n\n    /** Get the header title */\n    get title(): string {\n        return this._elementRef.nativeElement.textContent;\n    }\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[cxNestedDirectivesIcon], [fdx-nested-list-icon]',\n    template: `<ng-content></ng-content>`\n})\nexport class NestedListIconComponent extends IconComponent {\n    /** Role attribute */\n    @Input()\n    @HostBinding('attr.role')\n    role = 'presentation';\n\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__icon')\n    fdNestedListIconClass = true;\n}\n\n@Directive({\n    selector: '[cxNestedDirectivesTitle], [fdx-nested-list-title]'\n})\nexport class NestedListTitleDirective {\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__title')\n    fdNestedListTitleClass = true;\n\n    /** @hidden */\n    constructor(private elementRef: ElementRef) {}\n\n    /** Returns element's InnerText */\n    getInnerText(): string {\n        return this.elementRef && this.elementRef.nativeElement.textContent;\n    }\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: '[cxNestedListExpandIcon], [fdx-nested-list-expand-icon]',\n    template: ` <ng-content></ng-content> `,\n    host: {\n        'aria-haspopup': 'true',\n        role: 'presentation'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None\n})\nexport class NestedListExpandIconComponent {\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__arrow')\n    fdNestedListArrowClass = true;\n\n    /** @hidden */\n    @HostBinding('class.sap-icon--navigation-down-arrow')\n    get fdNestedListDownArrowClass(): boolean {\n        return this.expanded;\n    }\n\n    /** @hidden */\n    @HostBinding('class.sap-icon--navigation-right-arrow')\n    get fdNestedListRightArrowClass(): any {\n        return !this.expanded;\n    }\n\n    /**\n     * @hidden\n     * Attribute controlled by the parent `NestedItemComponent`\n     */\n    @HostBinding('class.is-expanded')\n    @HostBinding('attr.aria-expanded')\n    expanded = false;\n\n    /** @hidden */\n    @HostBinding('attr.aria-hidden')\n    ariaHidden = true;\n\n    /** @hidden */\n    constructor(\n        private _itemService: NestedItemService,\n        private _changeDetRef: ChangeDetectorRef\n    ) {}\n\n    /** Mouse event handler */\n    @HostListener('click', ['$event'])\n    onClick(event?: MouseEvent): void {\n        this.expanded = !this.expanded;\n        this._itemService.toggle.next(this.expanded);\n        event?.stopPropagation();\n    }\n\n    /** Handler for focus events */\n    @HostListener('focus')\n    onFocus(): void {\n        this._itemService.focus.next();\n    }\n\n    /** @hidden */\n    changeExpandedState(expanded: boolean): void {\n        this.expanded = expanded;\n        this._changeDetRef.detectChanges();\n    }\n}\n\n@Directive({\n    selector: '[cxNestedDirectivesButton], [fdx-nested-list-button]'\n})\nexport class NestedListButtonDirective implements AfterContentInit {\n    /** @hidden */\n    @HostBinding('class.fdx-nested-list__button')\n    fdNestedListButtonClass = true;\n\n    /** @hidden */\n    @ContentChild(NestedListExpandIconComponent)\n    _expandIcon: NestedListExpandIconComponent;\n\n    /** @hidden */\n    @HostListener('click', ['$event'])\n    @HostListener('keydown.enter', ['$event'])\n    @HostListener('keydown.space', ['$event'])\n    onClick(event: Event): void {\n        event.preventDefault();\n        event.stopPropagation();\n        this._expandIcon.onClick();\n    }\n\n    /** @hidden */\n    ngAfterContentInit(): void {\n        if (this._expandIcon) {\n            this._expandIcon.fdNestedListArrowClass = false;\n        }\n    }\n}\n"]}
@@ -16,14 +16,11 @@ export class NestedListKeyboardService {
16
16
  constructor(keyboardService, _rtlService) {
17
17
  this.keyboardService = keyboardService;
18
18
  this._rtlService = _rtlService;
19
- /** @hidden handles rtl service */
20
- this._dir = 'ltr';
21
19
  /**
22
20
  * Event, that is thrown always, when the open/close i being called on item components.
23
21
  * Also triggers changing of elements, to remove closed/hidden elements
24
22
  */
25
23
  this.refresh$ = new Subject();
26
- this._subscribeToRtl();
27
24
  }
28
25
  /**
29
26
  * Function called after refresh$ event is triggered.
@@ -67,15 +64,16 @@ export class NestedListKeyboardService {
67
64
  */
68
65
  _handleKeyDown(keyboardEvent, index, items) {
69
66
  const item = items[index];
70
- if ((this._dir === 'ltr' && KeyUtil.isKeyCode(keyboardEvent, RIGHT_ARROW)) ||
71
- (this._dir === 'rtl' && KeyUtil.isKeyCode(keyboardEvent, LEFT_ARROW))) {
67
+ const isRtl = !!this._rtlService?.rtlSignal();
68
+ if ((!isRtl && KeyUtil.isKeyCode(keyboardEvent, RIGHT_ARROW)) ||
69
+ (isRtl && KeyUtil.isKeyCode(keyboardEvent, LEFT_ARROW))) {
72
70
  if (!item.expanded && item.hasChildren) {
73
71
  item.triggerOpen();
74
72
  }
75
73
  keyboardEvent.preventDefault();
76
74
  }
77
- if ((this._dir === 'ltr' && KeyUtil.isKeyCode(keyboardEvent, LEFT_ARROW)) ||
78
- (this._dir === 'rtl' && KeyUtil.isKeyCode(keyboardEvent, RIGHT_ARROW))) {
75
+ if ((!isRtl && KeyUtil.isKeyCode(keyboardEvent, LEFT_ARROW)) ||
76
+ (isRtl && KeyUtil.isKeyCode(keyboardEvent, RIGHT_ARROW))) {
79
77
  if (item.expanded && item.hasChildren) {
80
78
  item.triggerClose();
81
79
  }
@@ -83,15 +81,6 @@ export class NestedListKeyboardService {
83
81
  }
84
82
  this.keyboardService.keyDownHandler(keyboardEvent, index, items);
85
83
  }
86
- /** @hidden Rtl change subscription */
87
- _subscribeToRtl() {
88
- if (!this._rtlService) {
89
- return;
90
- }
91
- this._rtlService.rtl.subscribe((isRtl) => {
92
- this._dir = isRtl ? 'rtl' : 'ltr';
93
- });
94
- }
95
84
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: NestedListKeyboardService, deps: [{ token: MenuKeyboardService }, { token: i1.RtlService, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
96
85
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.4", ngImport: i0, type: NestedListKeyboardService }); }
97
86
  }
@@ -103,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.4", ngImpor
103
92
  }] }, { type: i1.RtlService, decorators: [{
104
93
  type: Optional
105
94
  }] }] });
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-list-keyboard.service.js","sourceRoot":"","sources":["../../../../../libs/cx/nested-list/nested-list-keyboard.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes';\nimport { Inject, Injectable, Optional } from '@angular/core';\nimport { MenuKeyboardService } from '@fundamental-ngx/core/menu';\nimport { KeyUtil, RtlService } from '@fundamental-ngx/core/utils';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { NestedItemInterface } from './nested-item/nested-item.interface';\nimport { NestedListInterface } from './nested-list/nested-list.interface';\n\n/**\n * Nested list keyboard service, which uses MenuKeyboardService, to deal with ArrowUp, ArrowDown, Space, Enter.\n * Also has own handling of ArrowLeft and ArrowRight, to open/close the menu if it has any children.\n */\n@Injectable()\nexport class NestedListKeyboardService {\n    /** @hidden handles rtl service */\n    private _dir: 'ltr' | 'rtl' | null = 'ltr';\n\n    /**\n     * Event, that is thrown always, when the open/close i being called on item components.\n     * Also triggers changing of elements, to remove closed/hidden elements\n     */\n    readonly refresh$: Subject<void> = new Subject<void>();\n\n    /** @hidden */\n    constructor(\n        @Inject(MenuKeyboardService) private keyboardService: MenuKeyboardService,\n        @Optional() private _rtlService: RtlService | null\n    ) {\n        this._subscribeToRtl();\n    }\n\n    /**\n     * Function called after refresh$ event is triggered.\n     * Refresh the list of NestedItems, that the keyboard support should be provided for\n     */\n    refreshItems(lists: NestedListInterface[]): void {\n        const items: NestedItemInterface[] = [];\n\n        /** Gathering all of the items */\n        lists.forEach((list) => items.push(...this._getAllListItems(list)));\n        /** Putting the keyboard support function to each of the items */\n        items.forEach((item, index) => {\n            item.keyboardTriggered\n                .pipe(takeUntil(this.refresh$))\n                .subscribe((keyboardEvent: KeyboardEvent) => this._handleKeyDown(keyboardEvent, index, items));\n        });\n    }\n\n    /** Recursive function to get all of the NestedItem elements in correct order. */\n    private _getItems(item: NestedItemInterface): NestedItemInterface[] {\n        const childrenItems = item.expanded ? item.allChildrenItems : [];\n        return childrenItems.reduce(\n            (actualArray: NestedItemInterface[], nextItem: NestedItemInterface) => [\n                ...actualArray,\n                ...this._getItems(nextItem)\n            ],\n            [item]\n        );\n    }\n\n    /** Method that calls the recursive function, getItems() and gathers all of the items in the NestedList */\n    private _getAllListItems(list: NestedListInterface): NestedItemInterface[] {\n        const _items: NestedItemInterface[] = [];\n        if (list && list.nestedItems && list.nestedItems.length > 0) {\n            list.nestedItems.forEach((item) => {\n                _items.push(...this._getItems(item));\n            });\n        }\n\n        return _items;\n    }\n\n    /**\n     * Keyboard handle function. Uses keyboard support service from MenuComponent, to deal with ArrowUp, ArrowDown, Space, Enter.\n     * For ArrowRight, if item is not expanded and has children (list or popup), the open function is triggered.\n     * Otherwise it follows ArrowDown functionality.\n     * For ArrowLeft, if item is expanded and has children (list or popup), the close function is triggered.\n     * Otherwise it follows ArrowUp functionality\n     */\n    private _handleKeyDown(keyboardEvent: KeyboardEvent, index: number, items: NestedItemInterface[]): void {\n        const item: NestedItemInterface = items[index];\n\n        if (\n            (this._dir === 'ltr' && KeyUtil.isKeyCode(keyboardEvent, RIGHT_ARROW)) ||\n            (this._dir === 'rtl' && KeyUtil.isKeyCode(keyboardEvent, LEFT_ARROW))\n        ) {\n            if (!item.expanded && item.hasChildren) {\n                item.triggerOpen();\n            }\n            keyboardEvent.preventDefault();\n        }\n\n        if (\n            (this._dir === 'ltr' && KeyUtil.isKeyCode(keyboardEvent, LEFT_ARROW)) ||\n            (this._dir === 'rtl' && KeyUtil.isKeyCode(keyboardEvent, RIGHT_ARROW))\n        ) {\n            if (item.expanded && item.hasChildren) {\n                item.triggerClose();\n            }\n            keyboardEvent.preventDefault();\n        }\n\n        this.keyboardService.keyDownHandler(keyboardEvent, index, items);\n    }\n\n    /** @hidden Rtl change subscription */\n    private _subscribeToRtl(): void {\n        if (!this._rtlService) {\n            return;\n        }\n\n        this._rtlService.rtl.subscribe((isRtl) => {\n            this._dir = isRtl ? 'rtl' : 'ltr';\n        });\n    }\n}\n"]}
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-list-keyboard.service.js","sourceRoot":"","sources":["../../../../../libs/cx/nested-list/nested-list-keyboard.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { LEFT_ARROW, RIGHT_ARROW } from '@angular/cdk/keycodes';\nimport { Inject, Injectable, Optional } from '@angular/core';\nimport { MenuKeyboardService } from '@fundamental-ngx/core/menu';\nimport { KeyUtil, RtlService } from '@fundamental-ngx/core/utils';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { NestedItemInterface } from './nested-item/nested-item.interface';\nimport { NestedListInterface } from './nested-list/nested-list.interface';\n\n/**\n * Nested list keyboard service, which uses MenuKeyboardService, to deal with ArrowUp, ArrowDown, Space, Enter.\n * Also has own handling of ArrowLeft and ArrowRight, to open/close the menu if it has any children.\n */\n@Injectable()\nexport class NestedListKeyboardService {\n    /**\n     * Event, that is thrown always, when the open/close i being called on item components.\n     * Also triggers changing of elements, to remove closed/hidden elements\n     */\n    readonly refresh$: Subject<void> = new Subject<void>();\n\n    /** @hidden */\n    constructor(\n        @Inject(MenuKeyboardService) private keyboardService: MenuKeyboardService,\n        @Optional() private _rtlService: RtlService | null\n    ) {}\n\n    /**\n     * Function called after refresh$ event is triggered.\n     * Refresh the list of NestedItems, that the keyboard support should be provided for\n     */\n    refreshItems(lists: NestedListInterface[]): void {\n        const items: NestedItemInterface[] = [];\n\n        /** Gathering all of the items */\n        lists.forEach((list) => items.push(...this._getAllListItems(list)));\n        /** Putting the keyboard support function to each of the items */\n        items.forEach((item, index) => {\n            item.keyboardTriggered\n                .pipe(takeUntil(this.refresh$))\n                .subscribe((keyboardEvent: KeyboardEvent) => this._handleKeyDown(keyboardEvent, index, items));\n        });\n    }\n\n    /** Recursive function to get all of the NestedItem elements in correct order. */\n    private _getItems(item: NestedItemInterface): NestedItemInterface[] {\n        const childrenItems = item.expanded ? item.allChildrenItems : [];\n        return childrenItems.reduce(\n            (actualArray: NestedItemInterface[], nextItem: NestedItemInterface) => [\n                ...actualArray,\n                ...this._getItems(nextItem)\n            ],\n            [item]\n        );\n    }\n\n    /** Method that calls the recursive function, getItems() and gathers all of the items in the NestedList */\n    private _getAllListItems(list: NestedListInterface): NestedItemInterface[] {\n        const _items: NestedItemInterface[] = [];\n        if (list && list.nestedItems && list.nestedItems.length > 0) {\n            list.nestedItems.forEach((item) => {\n                _items.push(...this._getItems(item));\n            });\n        }\n\n        return _items;\n    }\n\n    /**\n     * Keyboard handle function. Uses keyboard support service from MenuComponent, to deal with ArrowUp, ArrowDown, Space, Enter.\n     * For ArrowRight, if item is not expanded and has children (list or popup), the open function is triggered.\n     * Otherwise it follows ArrowDown functionality.\n     * For ArrowLeft, if item is expanded and has children (list or popup), the close function is triggered.\n     * Otherwise it follows ArrowUp functionality\n     */\n    private _handleKeyDown(keyboardEvent: KeyboardEvent, index: number, items: NestedItemInterface[]): void {\n        const item: NestedItemInterface = items[index];\n        const isRtl = !!this._rtlService?.rtlSignal();\n\n        if (\n            (!isRtl && KeyUtil.isKeyCode(keyboardEvent, RIGHT_ARROW)) ||\n            (isRtl && KeyUtil.isKeyCode(keyboardEvent, LEFT_ARROW))\n        ) {\n            if (!item.expanded && item.hasChildren) {\n                item.triggerOpen();\n            }\n            keyboardEvent.preventDefault();\n        }\n\n        if (\n            (!isRtl && KeyUtil.isKeyCode(keyboardEvent, LEFT_ARROW)) ||\n            (isRtl && KeyUtil.isKeyCode(keyboardEvent, RIGHT_ARROW))\n        ) {\n            if (item.expanded && item.hasChildren) {\n                item.triggerClose();\n            }\n            keyboardEvent.preventDefault();\n        }\n\n        this.keyboardService.keyDownHandler(keyboardEvent, index, items);\n    }\n}\n"]}