ng-virtual-list 16.7.12 → 16.7.13

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,7 @@
1
1
  import { Injectable } from '@angular/core';
2
2
  import { Subject, tap } from 'rxjs';
3
3
  import { BehaviorSubject } from 'rxjs/internal/BehaviorSubject';
4
+ import { FocusAlignments } from './enums';
4
5
  import { MethodsForSelectingTypes } from './enums/method-for-selecting-types';
5
6
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
7
  import { DEFAULT_COLLAPSE_BY_CLICK, DEFAULT_SELECT_BY_CLICK } from './const';
@@ -167,11 +168,11 @@ export class NgVirtualListService {
167
168
  this._trackBox = trackBox;
168
169
  }
169
170
  itemToFocus;
170
- focus(element) {
171
+ focus(element, align = FocusAlignments.CENTER) {
171
172
  element.focus({ preventScroll: true });
172
173
  if (element.parentElement) {
173
174
  const pos = parseFloat(element.parentElement?.getAttribute('position') ?? '0');
174
- this.itemToFocus?.(element, pos);
175
+ this.itemToFocus?.(element, pos, align);
175
176
  }
176
177
  }
177
178
  areaFocus(id) {
@@ -190,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
190
191
  providedIn: 'root'
191
192
  }]
192
193
  }], ctorParameters: function () { return []; } });
193
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list.service.js","sourceRoot":"","sources":["../../../../projects/ng-virtual-list/src/lib/ng-virtual-list.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { Subject, tap } from 'rxjs';\r\nimport { TrackBox } from './utils/trackBox';\r\nimport { IRenderVirtualListItem } from './models';\r\nimport { BehaviorSubject } from 'rxjs/internal/BehaviorSubject';\r\nimport { Id } from './types';\r\nimport { MethodsForSelectingTypes } from './enums/method-for-selecting-types';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { DEFAULT_COLLAPSE_BY_CLICK, DEFAULT_SELECT_BY_CLICK } from './const';\r\nimport { IRenderVirtualListCollection } from './models/render-collection.model';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class NgVirtualListService {\r\n  private _nextComponentId: number = 0;\r\n\r\n  private _$itemClick = new Subject<IRenderVirtualListItem<any> | undefined>();\r\n  $itemClick = this._$itemClick.asObservable();\r\n\r\n  private _$selectedIds = new BehaviorSubject<Array<Id> | Id | undefined>(undefined);\r\n  $selectedIds = this._$selectedIds.asObservable();\r\n\r\n  private _$collapsedIds = new BehaviorSubject<Array<Id>>([]);\r\n  $collapsedIds = this._$collapsedIds.asObservable();\r\n\r\n  private _$methodOfSelecting = new BehaviorSubject<MethodsForSelectingTypes>(0);\r\n  $methodOfSelecting = this._$methodOfSelecting.asObservable();\r\n\r\n  set methodOfSelecting(v: MethodsForSelectingTypes) {\r\n    this._$methodOfSelecting.next(v);\r\n  }\r\n\r\n  private _trackBox: TrackBox | undefined;\r\n\r\n  private _$focusedId = new BehaviorSubject<Id | null>(null);\r\n  $focusedId = this._$focusedId.asObservable();\r\n  get focusedId() { return this._$focusedId.getValue(); }\r\n\r\n  selectByClick: boolean = DEFAULT_SELECT_BY_CLICK;\r\n\r\n  collapseByClick: boolean = DEFAULT_COLLAPSE_BY_CLICK;\r\n\r\n  listElement: HTMLDivElement | null = null;\r\n\r\n  collection: IRenderVirtualListCollection = [];\r\n\r\n  constructor() {\r\n    this._$methodOfSelecting.pipe(\r\n      takeUntilDestroyed(),\r\n      tap(v => {\r\n        switch (v) {\r\n          case MethodsForSelectingTypes.SELECT: {\r\n            const curr = this._$selectedIds.getValue();\r\n            if (typeof curr !== 'number' && typeof curr !== 'string') {\r\n              this._$selectedIds.next(undefined);\r\n            }\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.MULTI_SELECT: {\r\n            if (!Array.isArray(this._$selectedIds.getValue())) {\r\n              this._$selectedIds.next([]);\r\n            }\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.NONE:\r\n          default: {\r\n            this._$selectedIds.next(undefined);\r\n            break;\r\n          }\r\n        }\r\n      }),\r\n    ).subscribe();\r\n  }\r\n\r\n  setSelectedIds(ids: Array<Id> | Id | undefined) {\r\n    if (JSON.stringify(this._$selectedIds.getValue()) !== JSON.stringify(ids)) {\r\n      this._$selectedIds.next(ids);\r\n    }\r\n  }\r\n\r\n  setCollapsedIds(ids: Array<Id>) {\r\n    if (JSON.stringify(this._$collapsedIds.getValue()) !== JSON.stringify(ids)) {\r\n      this._$collapsedIds.next(ids);\r\n    }\r\n  }\r\n\r\n  itemClick(data: IRenderVirtualListItem | undefined) {\r\n    this._$itemClick.next(data);\r\n    if (this.collapseByClick) {\r\n      this.collapse(data);\r\n    }\r\n    if (this.selectByClick) {\r\n      this.select(data);\r\n    }\r\n  }\r\n\r\n  update() {\r\n    this._trackBox?.changes();\r\n  }\r\n\r\n  /**\r\n   * Selects a list item\r\n   * @param data \r\n   * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.\r\n   */\r\n  select(data: IRenderVirtualListItem | undefined, selected: boolean | undefined = undefined) {\r\n    if (data && data.config.selectable) {\r\n      switch (this._$methodOfSelecting.getValue()) {\r\n        case MethodsForSelectingTypes.SELECT: {\r\n          const curr = this._$selectedIds.getValue() as (Id | undefined);\r\n          if (selected === undefined) {\r\n            this._$selectedIds.next(curr !== data?.id ? data?.id : undefined);\r\n          } else {\r\n            this._$selectedIds.next(selected ? data?.id : undefined);\r\n          }\r\n          break;\r\n        }\r\n        case MethodsForSelectingTypes.MULTI_SELECT: {\r\n          const curr = [...(this._$selectedIds.getValue() || []) as Array<Id>], index = curr.indexOf(data.id);\r\n          if (selected === undefined) {\r\n            if (index > -1) {\r\n              curr.splice(index, 1);\r\n              this._$selectedIds.next(curr);\r\n            } else {\r\n              this._$selectedIds.next([...curr, data.id]);\r\n            }\r\n          } else if (selected) {\r\n            if (index > -1) {\r\n              this._$selectedIds.next(curr);\r\n            } else {\r\n              this._$selectedIds.next([...curr, data.id]);\r\n            }\r\n          } else {\r\n            if (index > -1) {\r\n              curr.splice(index, 1);\r\n              this._$selectedIds.next(curr);\r\n            } else {\r\n              this._$selectedIds.next(curr);\r\n            }\r\n          }\r\n          break;\r\n        }\r\n        case MethodsForSelectingTypes.NONE:\r\n        default: {\r\n          this._$selectedIds.next(undefined);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n    * Collapse list items\r\n    * @param data \r\n    * @param collapsed - If the value is undefined, then the toggle method is executed, if false or true, then the collapse/expand is performed.\r\n    */\r\n  collapse(data: IRenderVirtualListItem | undefined, collapsed: boolean | undefined = undefined) {\r\n    if (data && data.config.sticky > 0 && data.config.collapsable) {\r\n      const curr = [...(this._$collapsedIds.getValue() || []) as Array<Id>], index = curr.indexOf(data.id);\r\n      if (collapsed === undefined) {\r\n        if (index > -1) {\r\n          curr.splice(index, 1);\r\n          this._$collapsedIds.next(curr);\r\n        } else {\r\n          this._$collapsedIds.next([...curr, data.id]);\r\n        }\r\n      } else if (collapsed) {\r\n        if (index > -1) {\r\n          this._$collapsedIds.next(curr);\r\n        } else {\r\n          this._$collapsedIds.next([...curr, data.id]);\r\n        }\r\n      } else {\r\n        if (index > -1) {\r\n          curr.splice(index, 1);\r\n          this._$collapsedIds.next(curr);\r\n        } else {\r\n          this._$collapsedIds.next(curr);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  initialize(trackBox: TrackBox) {\r\n    this._trackBox = trackBox;\r\n  }\r\n\r\n  itemToFocus: ((element: HTMLElement, position: number) => void) | undefined;\r\n\r\n  focus(element: HTMLElement) {\r\n    element.focus({ preventScroll: true });\r\n    if (element.parentElement) {\r\n      const pos = parseFloat(element.parentElement?.getAttribute('position') ?? '0');\r\n      this.itemToFocus?.(element, pos);\r\n    }\r\n  }\r\n\r\n  areaFocus(id: Id | null) {\r\n    this._$focusedId.next(id);\r\n  }\r\n\r\n  generateComponentId() {\r\n    return this._nextComponentId = this._nextComponentId === Number.MAX_SAFE_INTEGER\r\n      ? 0 : this._nextComponentId + 1;\r\n  }\r\n}\r\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-virtual-list.service.js","sourceRoot":"","sources":["../../../../projects/ng-virtual-list/src/lib/ng-virtual-list.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { Subject, takeUntil, tap } from 'rxjs';\r\nimport { BehaviorSubject } from 'rxjs/internal/BehaviorSubject';\r\nimport { TrackBox } from './utils/trackBox';\r\nimport { IRenderVirtualListItem } from './models';\r\nimport { IRenderVirtualListCollection } from './models/render-collection.model';\r\nimport { FocusAlignments } from './enums';\r\nimport { MethodsForSelectingTypes } from './enums/method-for-selecting-types';\r\nimport { FocusAlignment, Id } from './types';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { DEFAULT_COLLAPSE_BY_CLICK, DEFAULT_SELECT_BY_CLICK } from './const';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class NgVirtualListService {\r\n  private _nextComponentId: number = 0;\r\n\r\n  private _$itemClick = new Subject<IRenderVirtualListItem<any> | undefined>();\r\n  $itemClick = this._$itemClick.asObservable();\r\n\r\n  private _$selectedIds = new BehaviorSubject<Array<Id> | Id | undefined>(undefined);\r\n  $selectedIds = this._$selectedIds.asObservable();\r\n\r\n  private _$collapsedIds = new BehaviorSubject<Array<Id>>([]);\r\n  $collapsedIds = this._$collapsedIds.asObservable();\r\n\r\n  private _$methodOfSelecting = new BehaviorSubject<MethodsForSelectingTypes>(0);\r\n  $methodOfSelecting = this._$methodOfSelecting.asObservable();\r\n\r\n  set methodOfSelecting(v: MethodsForSelectingTypes) {\r\n    this._$methodOfSelecting.next(v);\r\n  }\r\n\r\n  private _trackBox: TrackBox | undefined;\r\n\r\n  private _$focusedId = new BehaviorSubject<Id | null>(null);\r\n  $focusedId = this._$focusedId.asObservable();\r\n  get focusedId() { return this._$focusedId.getValue(); }\r\n\r\n  selectByClick: boolean = DEFAULT_SELECT_BY_CLICK;\r\n\r\n  collapseByClick: boolean = DEFAULT_COLLAPSE_BY_CLICK;\r\n\r\n  listElement: HTMLDivElement | null = null;\r\n\r\n  collection: IRenderVirtualListCollection = [];\r\n\r\n  constructor() {\r\n    this._$methodOfSelecting.pipe(\r\n      takeUntilDestroyed(),\r\n      tap(v => {\r\n        switch (v) {\r\n          case MethodsForSelectingTypes.SELECT: {\r\n            const curr = this._$selectedIds.getValue();\r\n            if (typeof curr !== 'number' && typeof curr !== 'string') {\r\n              this._$selectedIds.next(undefined);\r\n            }\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.MULTI_SELECT: {\r\n            if (!Array.isArray(this._$selectedIds.getValue())) {\r\n              this._$selectedIds.next([]);\r\n            }\r\n            break;\r\n          }\r\n          case MethodsForSelectingTypes.NONE:\r\n          default: {\r\n            this._$selectedIds.next(undefined);\r\n            break;\r\n          }\r\n        }\r\n      }),\r\n    ).subscribe();\r\n  }\r\n\r\n  setSelectedIds(ids: Array<Id> | Id | undefined) {\r\n    if (JSON.stringify(this._$selectedIds.getValue()) !== JSON.stringify(ids)) {\r\n      this._$selectedIds.next(ids);\r\n    }\r\n  }\r\n\r\n  setCollapsedIds(ids: Array<Id>) {\r\n    if (JSON.stringify(this._$collapsedIds.getValue()) !== JSON.stringify(ids)) {\r\n      this._$collapsedIds.next(ids);\r\n    }\r\n  }\r\n\r\n  itemClick(data: IRenderVirtualListItem | undefined) {\r\n    this._$itemClick.next(data);\r\n    if (this.collapseByClick) {\r\n      this.collapse(data);\r\n    }\r\n    if (this.selectByClick) {\r\n      this.select(data);\r\n    }\r\n  }\r\n\r\n  update() {\r\n    this._trackBox?.changes();\r\n  }\r\n\r\n  /**\r\n   * Selects a list item\r\n   * @param data \r\n   * @param selected - If the value is undefined, then the toggle method is executed, if false or true, then the selection/deselection is performed.\r\n   */\r\n  select(data: IRenderVirtualListItem | undefined, selected: boolean | undefined = undefined) {\r\n    if (data && data.config.selectable) {\r\n      switch (this._$methodOfSelecting.getValue()) {\r\n        case MethodsForSelectingTypes.SELECT: {\r\n          const curr = this._$selectedIds.getValue() as (Id | undefined);\r\n          if (selected === undefined) {\r\n            this._$selectedIds.next(curr !== data?.id ? data?.id : undefined);\r\n          } else {\r\n            this._$selectedIds.next(selected ? data?.id : undefined);\r\n          }\r\n          break;\r\n        }\r\n        case MethodsForSelectingTypes.MULTI_SELECT: {\r\n          const curr = [...(this._$selectedIds.getValue() || []) as Array<Id>], index = curr.indexOf(data.id);\r\n          if (selected === undefined) {\r\n            if (index > -1) {\r\n              curr.splice(index, 1);\r\n              this._$selectedIds.next(curr);\r\n            } else {\r\n              this._$selectedIds.next([...curr, data.id]);\r\n            }\r\n          } else if (selected) {\r\n            if (index > -1) {\r\n              this._$selectedIds.next(curr);\r\n            } else {\r\n              this._$selectedIds.next([...curr, data.id]);\r\n            }\r\n          } else {\r\n            if (index > -1) {\r\n              curr.splice(index, 1);\r\n              this._$selectedIds.next(curr);\r\n            } else {\r\n              this._$selectedIds.next(curr);\r\n            }\r\n          }\r\n          break;\r\n        }\r\n        case MethodsForSelectingTypes.NONE:\r\n        default: {\r\n          this._$selectedIds.next(undefined);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n    * Collapse list items\r\n    * @param data \r\n    * @param collapsed - If the value is undefined, then the toggle method is executed, if false or true, then the collapse/expand is performed.\r\n    */\r\n  collapse(data: IRenderVirtualListItem | undefined, collapsed: boolean | undefined = undefined) {\r\n    if (data && data.config.sticky > 0 && data.config.collapsable) {\r\n      const curr = [...(this._$collapsedIds.getValue() || []) as Array<Id>], index = curr.indexOf(data.id);\r\n      if (collapsed === undefined) {\r\n        if (index > -1) {\r\n          curr.splice(index, 1);\r\n          this._$collapsedIds.next(curr);\r\n        } else {\r\n          this._$collapsedIds.next([...curr, data.id]);\r\n        }\r\n      } else if (collapsed) {\r\n        if (index > -1) {\r\n          this._$collapsedIds.next(curr);\r\n        } else {\r\n          this._$collapsedIds.next([...curr, data.id]);\r\n        }\r\n      } else {\r\n        if (index > -1) {\r\n          curr.splice(index, 1);\r\n          this._$collapsedIds.next(curr);\r\n        } else {\r\n          this._$collapsedIds.next(curr);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  initialize(trackBox: TrackBox) {\r\n    this._trackBox = trackBox;\r\n  }\r\n\r\n  itemToFocus: ((element: HTMLElement, position: number, align: FocusAlignment) => void) | undefined;\r\n\r\n  focus(element: HTMLElement, align: FocusAlignment = FocusAlignments.CENTER) {\r\n    element.focus({ preventScroll: true });\r\n    if (element.parentElement) {\r\n      const pos = parseFloat(element.parentElement?.getAttribute('position') ?? '0');\r\n      this.itemToFocus?.(element, pos, align);\r\n    }\r\n  }\r\n\r\n  areaFocus(id: Id | null) {\r\n    this._$focusedId.next(id);\r\n  }\r\n\r\n  generateComponentId() {\r\n    return this._nextComponentId = this._nextComponentId === Number.MAX_SAFE_INTEGER\r\n      ? 0 : this._nextComponentId + 1;\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9jdXMtYWxpZ25tZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9saWIvdHlwZXMvZm9jdXMtYWxpZ25tZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb2N1c0FsaWdubWVudHMgfSBmcm9tIFwiLi4vZW51bXNcIjtcclxuXHJcbi8qKlxyXG4gKiBGb2N1cyBBbGlnbm1lbnRcclxuICogQGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL0Rqb25ueVgvbmctdmlydHVhbC1saXN0L2Jsb2IvMTYueC9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi90eXBlcy9mb2N1cy1hbGlnbm1lbnQudHNcclxuICogQGF1dGhvciBFdmdlbmlpIEdyZWJlbm5pa292XHJcbiAqIEBlbWFpbCBkam9ubnl4QGdtYWlsLmNvbVxyXG4gKi9cclxuZXhwb3J0IHR5cGUgRm9jdXNBbGlnbm1lbnQgPSBGb2N1c0FsaWdubWVudHMgfCAnbm9uZScgfCAnc3RhcnQnIHwgJ2NlbnRlcicgfCAnZW5kJztcclxuIl19
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi90eXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWQgfSBmcm9tICcuL2lkJztcclxuaW1wb3J0IHsgSVNpemUgfSBmcm9tICcuL3NpemUnO1xyXG5pbXBvcnQgeyBJUmVjdCB9IGZyb20gJy4vcmVjdCc7XHJcblxyXG5leHBvcnQgdHlwZSB7XHJcbiAgICBJZCxcclxuICAgIElTaXplLFxyXG4gICAgSVJlY3QsXHJcbn0iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy12aXJ0dWFsLWxpc3Qvc3JjL2xpYi90eXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWQgfSBmcm9tICcuL2lkJztcclxuaW1wb3J0IHsgSVNpemUgfSBmcm9tICcuL3NpemUnO1xyXG5pbXBvcnQgeyBJUmVjdCB9IGZyb20gJy4vcmVjdCc7XHJcbmltcG9ydCB7IEZvY3VzQWxpZ25tZW50IH0gZnJvbSAnLi9mb2N1cy1hbGlnbm1lbnQnO1xyXG5cclxuZXhwb3J0IHR5cGUge1xyXG4gICAgSWQsXHJcbiAgICBJU2l6ZSxcclxuICAgIElSZWN0LFxyXG4gICAgRm9jdXNBbGlnbm1lbnQsXHJcbn0iXX0=
@@ -1,9 +1,9 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { Injectable, Component, ChangeDetectionStrategy, EventEmitter as EventEmitter$1, ViewContainerRef, ElementRef, ViewEncapsulation, ViewChild, Output, Input, NgModule, NO_ERRORS_SCHEMA } from '@angular/core';
3
- import { takeUntil, tap as tap$1, map } from 'rxjs/operators';
3
+ import { tap as tap$1, map } from 'rxjs/operators';
4
4
  import { Subject, tap, BehaviorSubject as BehaviorSubject$1, fromEvent, combineLatest, filter, distinctUntilChanged, map as map$1, debounceTime, switchMap, of } from 'rxjs';
5
- import { BehaviorSubject } from 'rxjs/internal/BehaviorSubject';
6
5
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
6
+ import { BehaviorSubject } from 'rxjs/internal/BehaviorSubject';
7
7
  import * as i2 from '@angular/common';
8
8
  import { CommonModule } from '@angular/common';
9
9
 
@@ -83,6 +83,20 @@ var SnappingMethods;
83
83
  SnappingMethods["ADVANCED"] = "advanced";
84
84
  })(SnappingMethods || (SnappingMethods = {}));
85
85
 
86
+ /**
87
+ * Focus Alignments.
88
+ * @link https://github.com/DjonnyX/ng-virtual-list/blob/16.x/projects/ng-virtual-list/src/lib/enums/focus-alignments.ts
89
+ * @author Evgenii Grebennikov
90
+ * @email djonnyx@gmail.com
91
+ */
92
+ var FocusAlignments;
93
+ (function (FocusAlignments) {
94
+ FocusAlignments["NONE"] = "none";
95
+ FocusAlignments["START"] = "start";
96
+ FocusAlignments["CENTER"] = "center";
97
+ FocusAlignments["END"] = "end";
98
+ })(FocusAlignments || (FocusAlignments = {}));
99
+
86
100
  const DEFAULT_ITEM_SIZE = 24;
87
101
  const DEFAULT_BUFFER_SIZE = 2;
88
102
  const DEFAULT_MAX_BUFFER_SIZE = 10;
@@ -387,11 +401,11 @@ class NgVirtualListService {
387
401
  this._trackBox = trackBox;
388
402
  }
389
403
  itemToFocus;
390
- focus(element) {
404
+ focus(element, align = FocusAlignments.CENTER) {
391
405
  element.focus({ preventScroll: true });
392
406
  if (element.parentElement) {
393
407
  const pos = parseFloat(element.parentElement?.getAttribute('position') ?? '0');
394
- this.itemToFocus?.(element, pos);
408
+ this.itemToFocus?.(element, pos, align);
395
409
  }
396
410
  }
397
411
  areaFocus(id) {
@@ -411,7 +425,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
411
425
  }]
412
426
  }], ctorParameters: function () { return []; } });
413
427
 
414
- const ATTR_AREA_SELECTED = 'area-selected', TABINDEX = 'ng-vl-index', KEY_SPACE = " ", KEY_ARR_LEFT = "ArrowLeft", KEY_ARR_UP = "ArrowUp", KEY_ARR_RIGHT = "ArrowRight", KEY_ARR_DOWN = "ArrowDown", EVENT_FOCUS_IN = 'focusin', EVENT_FOCUS_OUT = 'focusout', EVENT_KEY_DOWN = 'keydown';
428
+ const ATTR_AREA_SELECTED = 'area-selected', TABINDEX = 'ng-vl-index', POSITION = 'position', POSITION_ZERO = '0', ID = 'item-id', KEY_SPACE = " ", KEY_ARR_LEFT = "ArrowLeft", KEY_ARR_UP = "ArrowUp", KEY_ARR_RIGHT = "ArrowRight", KEY_ARR_DOWN = "ArrowDown", EVENT_FOCUS_IN = 'focusin', EVENT_FOCUS_OUT = 'focusout', EVENT_KEY_DOWN = 'keydown';
415
429
  const getElementByIndex = (index) => {
416
430
  return `[${TABINDEX}="${index}"]`;
417
431
  };
@@ -425,7 +439,6 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
425
439
  _cdr;
426
440
  _elementRef;
427
441
  _service;
428
- _$unsubscribe = new Subject();
429
442
  _id;
430
443
  get id() {
431
444
  return this._id;
@@ -437,12 +450,12 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
437
450
  _$config = new BehaviorSubject$1({});
438
451
  $config = this._$config.asObservable();
439
452
  measures = new BehaviorSubject$1(undefined);
440
- _$focus = new BehaviorSubject$1(false);
441
- $focus = this._$focus.asObservable();
453
+ _$focused = new BehaviorSubject$1(false);
454
+ $focused = this._$focused.asObservable();
442
455
  _$part = new BehaviorSubject$1(PART_DEFAULT_ITEM);
443
456
  $part = this._$part.asObservable();
444
457
  regular = false;
445
- data = undefined;
458
+ data;
446
459
  _$data = new BehaviorSubject$1(this.data);
447
460
  $data = this._$data.asObservable();
448
461
  set item(v) {
@@ -509,28 +522,35 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
509
522
  }
510
523
  this._service.collapse(data, collapsed);
511
524
  };
525
+ _focusHandler = () =>
526
+ /**
527
+ * Focus a list item
528
+ */
529
+ (align = FocusAlignments.CENTER) => {
530
+ this.focus(align);
531
+ };
512
532
  constructor(_cdr, _elementRef, _service) {
513
533
  super();
514
534
  this._cdr = _cdr;
515
535
  this._elementRef = _elementRef;
516
536
  this._service = _service;
517
537
  this._id = this._service.generateComponentId();
518
- const $data = this.$data, $focus = this.$focus;
538
+ const $data = this.$data, $focus = this.$focused;
519
539
  this._elementRef.nativeElement.setAttribute('id', String(this._id));
520
- $focus.pipe(takeUntil(this._$unsubscribe), tap$1(v => {
540
+ $focus.pipe(takeUntilDestroyed(), tap$1(v => {
521
541
  this._service.areaFocus(v ? this._id : this._service.focusedId === this._id ? null : this._service.focusedId);
522
542
  })).subscribe();
523
- fromEvent(this.element, EVENT_FOCUS_IN).pipe(takeUntil(this._$unsubscribe), tap$1(e => {
524
- this._$focus.next(true);
543
+ fromEvent(this.element, EVENT_FOCUS_IN).pipe(takeUntilDestroyed(), tap$1(e => {
544
+ this._$focused.next(true);
525
545
  this.updateConfig(this.data);
526
546
  this.updatePartStr(this.data, this._isSelected, this._isCollapsed);
527
547
  })).subscribe(),
528
- fromEvent(this.element, EVENT_FOCUS_OUT).pipe(takeUntil(this._$unsubscribe), tap$1(e => {
529
- this._$focus.next(false);
548
+ fromEvent(this.element, EVENT_FOCUS_OUT).pipe(takeUntilDestroyed(), tap$1(e => {
549
+ this._$focused.next(false);
530
550
  this.updateConfig(this.data);
531
551
  this.updatePartStr(this.data, this._isSelected, this._isCollapsed);
532
552
  })).subscribe(),
533
- fromEvent(this.element, EVENT_KEY_DOWN).pipe(takeUntil(this._$unsubscribe), tap$1(e => {
553
+ fromEvent(this.element, EVENT_KEY_DOWN).pipe(takeUntilDestroyed(), tap$1(e => {
534
554
  switch (e.key) {
535
555
  case KEY_SPACE: {
536
556
  e.stopImmediatePropagation();
@@ -573,7 +593,7 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
573
593
  break;
574
594
  }
575
595
  })).subscribe();
576
- combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds, this._service.$collapsedIds]).pipe(takeUntil(this._$unsubscribe), map(([, m, selectedIds, collapsedIds]) => ({ method: m, selectedIds, collapsedIds })), tap$1(({ method, selectedIds, collapsedIds }) => {
596
+ combineLatest([$data, this._service.$methodOfSelecting, this._service.$selectedIds, this._service.$collapsedIds]).pipe(takeUntilDestroyed(), map(([, m, selectedIds, collapsedIds]) => ({ method: m, selectedIds, collapsedIds })), tap$1(({ method, selectedIds, collapsedIds }) => {
577
597
  switch (method) {
578
598
  case MethodsForSelectingTypes.SELECT: {
579
599
  const id = selectedIds, isSelected = id === this.itemId;
@@ -629,18 +649,29 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
629
649
  }
630
650
  }
631
651
  }
652
+ focus(align = FocusAlignments.CENTER) {
653
+ if (this._service.listElement) {
654
+ const tabIndex = this.data?.config?.tabIndex ?? 0;
655
+ let index = tabIndex;
656
+ const el = this._service.listElement.querySelector(getElementByIndex(index));
657
+ if (el) {
658
+ this._service.focus(el, align);
659
+ }
660
+ }
661
+ }
632
662
  updateMeasures(v) {
633
663
  this.measures.next(v?.measures ? { ...v.measures } : undefined);
634
664
  }
635
665
  updateConfig(v) {
636
666
  this._$config.next({
637
- ...v?.config || {}, selected: this._isSelected, collapsed: this._isCollapsed, focus: this._$focus.getValue(),
638
- collapse: this._collapseHandler(v), select: this._selectHandler(v)
667
+ ...v?.config || {}, selected: this._isSelected, collapsed: this._isCollapsed, focused: this._$focused.getValue(),
668
+ collapse: this._collapseHandler(v), select: this._selectHandler(v), focus: this._focusHandler(),
639
669
  });
640
670
  }
641
671
  update() {
642
672
  const data = this.data, regular = this.regular, length = this._regularLength;
643
673
  if (data) {
674
+ this._elementRef.nativeElement.setAttribute(ID, `${data.id}`);
644
675
  const styles = this._elementRef.nativeElement.style;
645
676
  styles.zIndex = data.config.zIndex;
646
677
  if (data.config.snapped) {
@@ -664,6 +695,9 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
664
695
  styles.height = data.config.isVertical ? data.config.dynamic ? SIZE_AUTO : `${data.measures.height}${PX}` : regular ? length : SIZE_100_PERSENT;
665
696
  styles.width = data.config.isVertical ? regular ? length : SIZE_100_PERSENT : data.config.dynamic ? SIZE_AUTO : `${data.measures.width}${PX}`;
666
697
  }
698
+ else {
699
+ this._elementRef.nativeElement.removeAttribute(ID);
700
+ }
667
701
  this._cdr.markForCheck();
668
702
  }
669
703
  updatePartStr(v, isSelected, isCollapsed) {
@@ -685,7 +719,7 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
685
719
  if (v ? v.config.new : false) {
686
720
  part += PART_ITEM_NEW;
687
721
  }
688
- if (this._$focus.getValue()) {
722
+ if (this._$focused.getValue()) {
689
723
  part += PART_ITEM_FOCUSED;
690
724
  }
691
725
  this._$part.next(part);
@@ -731,21 +765,15 @@ class NgVirtualListItemComponent extends BaseVirtualListItemComponent {
731
765
  onClickHandler() {
732
766
  this._service.itemClick(this.data);
733
767
  }
734
- ngOnDestroy() {
735
- if (this._$unsubscribe) {
736
- this._$unsubscribe.next();
737
- this._$unsubscribe.complete();
738
- }
739
- }
740
768
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: NgVirtualListService }], target: i0.ɵɵFactoryTarget.Component });
741
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListItemComponent, selector: "ng-virtual-list-item", host: { attributes: { "role": "listitem" }, classAttribute: "ngvl__item" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"data\">\r\n <div #listItem [part]=\"$part | async\" [attr.ng-vl-index]=\"data.config.tabIndex || -1\" tabindex=\"0\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut, 'focus': $focus | async}\" (click)=\"onClickHandler()\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, measures: measures | async, config: $config | async}\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit;box-sizing:border-box}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
769
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListItemComponent, selector: "ng-virtual-list-item", host: { attributes: { "role": "listitem" }, classAttribute: "ngvl__item" }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"data\">\r\n <div #listItem [part]=\"$part | async\" [attr.ng-vl-index]=\"data.config.tabIndex || -1\" tabindex=\"0\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut, 'focus': $focused | async}\" (click)=\"onClickHandler()\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, measures: measures | async, config: $config | async}\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit;box-sizing:border-box}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
742
770
  }
743
771
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListItemComponent, decorators: [{
744
772
  type: Component,
745
773
  args: [{ selector: 'ng-virtual-list-item', host: {
746
774
  'class': 'ngvl__item',
747
775
  'role': 'listitem',
748
- }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"data\">\r\n <div #listItem [part]=\"$part | async\" [attr.ng-vl-index]=\"data.config.tabIndex || -1\" tabindex=\"0\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut, 'focus': $focus | async}\" (click)=\"onClickHandler()\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, measures: measures | async, config: $config | async}\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit;box-sizing:border-box}\n"] }]
776
+ }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"data\">\r\n <div #listItem [part]=\"$part | async\" [attr.ng-vl-index]=\"data.config.tabIndex || -1\" tabindex=\"0\" class=\"ngvl-item__container\" [ngClass]=\"{'snapped': data.config.snapped,\r\n 'snapped-out': data.config.snappedOut, 'focus': $focused | async}\" (click)=\"onClickHandler()\">\r\n <ng-container *ngIf=\"itemRenderer\">\r\n <ng-container [ngTemplateOutlet]=\"itemRenderer\"\r\n [ngTemplateOutletContext]=\"{data: data.data || {}, measures: measures | async, config: $config | async}\"></ng-container>\r\n </ng-container>\r\n </div>\r\n</ng-container>", styles: [":host{display:block;position:absolute;left:0;top:0;box-sizing:border-box;overflow:hidden}.ngvl-item__container{margin:0;padding:0;overflow:hidden;background-color:#fff;width:inherit;height:inherit;box-sizing:border-box}\n"] }]
749
777
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: NgVirtualListService }]; } });
750
778
 
751
779
  /**
@@ -2185,7 +2213,7 @@ const isCollectionMode = (src, expected) => {
2185
2213
  return NORMAL_ALIASES.includes(src);
2186
2214
  };
2187
2215
 
2188
- const ROLE_LIST = 'list', ROLE_LIST_BOX = 'listbox';
2216
+ const ROLE_LIST = 'list', ROLE_LIST_BOX = 'listbox', ITEM_ID = 'item-id', ITEM_CONTAINER = 'ngvl-item__container';
2189
2217
  const validateScrollIteration = (value) => {
2190
2218
  return Number.isNaN(value) || (value < 0) ? 0 : value > MAX_SCROLL_TO_ITERATIONS ? MAX_SCROLL_TO_ITERATIONS : value;
2191
2219
  }, validateId = (id) => {
@@ -2204,6 +2232,11 @@ const validateScrollIteration = (value) => {
2204
2232
  if (!valid) {
2205
2233
  throw Error('The "iteration" parameter must be of type `number`.');
2206
2234
  }
2235
+ }, validateFocusAlignment = (align) => {
2236
+ const valid = validateString(align) && (align === 'none' || align === 'start' || align === 'center' || align === 'end');
2237
+ if (!valid) {
2238
+ throw Error('The "align" parameter must have the value `none`, `start`, `center` or `end`.');
2239
+ }
2207
2240
  };
2208
2241
  /**
2209
2242
  * Virtual list component.
@@ -2825,12 +2858,33 @@ class NgVirtualListComponent {
2825
2858
  this._$scrollSize.next(scrollSize);
2826
2859
  }
2827
2860
  };
2828
- itemToFocus = (element, position) => {
2861
+ itemToFocus = (element, position, align = FocusAlignments.CENTER) => {
2829
2862
  const container = this._container?.nativeElement;
2830
2863
  if (container) {
2831
- const { width, height } = this._$bounds.getValue(), { width: elementWidth, height: elementHeight } = element.getBoundingClientRect(), isVertical = this._isVertical, pos = isVertical ? position - (height - elementHeight) * .5 : position - (width - elementWidth) * .5;
2832
- const params = { [this._isVertical ? TOP_PROP_NAME : LEFT_PROP_NAME]: pos, behavior: 'instant' };
2833
- container.scrollTo(params);
2864
+ const { width, height } = this._$bounds.getValue(), { width: elementWidth, height: elementHeight } = element.getBoundingClientRect(), isVertical = this._isVertical;
2865
+ let pos = Number.NaN;
2866
+ switch (align) {
2867
+ case FocusAlignments.START: {
2868
+ pos = isVertical ? position : position;
2869
+ break;
2870
+ }
2871
+ case FocusAlignments.CENTER: {
2872
+ pos = isVertical ? position - (height - elementHeight) * .5 : position - (width - elementWidth) * .5;
2873
+ break;
2874
+ }
2875
+ case FocusAlignments.END: {
2876
+ pos = isVertical ? position - (height - elementHeight) : position - (width - elementWidth);
2877
+ break;
2878
+ }
2879
+ case FocusAlignments.NONE:
2880
+ default: {
2881
+ break;
2882
+ }
2883
+ }
2884
+ if (!Number.isNaN(pos)) {
2885
+ const params = { [this._isVertical ? TOP_PROP_NAME : LEFT_PROP_NAME]: pos, behavior: 'instant' };
2886
+ container.scrollTo(params);
2887
+ }
2834
2888
  }
2835
2889
  };
2836
2890
  _$initialized = new BehaviorSubject$1(false);
@@ -3156,6 +3210,20 @@ class NgVirtualListComponent {
3156
3210
  validateId(id);
3157
3211
  return this._trackBox.getItemBounds(id);
3158
3212
  }
3213
+ /**
3214
+ * Focus an list item by a given id.
3215
+ */
3216
+ focus(id, align = FocusAlignments.NONE) {
3217
+ validateId(id);
3218
+ validateFocusAlignment(align);
3219
+ const el = this._list?.nativeElement.querySelector(`[${ITEM_ID}="${id}"]`);
3220
+ if (el) {
3221
+ const focusedEl = el.querySelector(`.${ITEM_CONTAINER}`);
3222
+ if (focusedEl) {
3223
+ this._service.focus(focusedEl, align);
3224
+ }
3225
+ }
3226
+ }
3159
3227
  /**
3160
3228
  * The method scrolls the list to the element with the given id and returns the value of the scrolled area.
3161
3229
  * Behavior accepts the values ​​"auto", "instant" and "smooth".
@@ -3416,5 +3484,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
3416
3484
  * Generated bundle index. Do not edit.
3417
3485
  */
3418
3486
 
3419
- export { CollectionModes, Directions, MethodsForSelecting, NgVirtualListComponent, NgVirtualListItemComponent, NgVirtualListModule, ScrollEvent, SnappingMethods, debounce, toggleClassName };
3487
+ export { CollectionModes, Directions, FocusAlignments, MethodsForSelecting, NgVirtualListComponent, NgVirtualListItemComponent, NgVirtualListModule, ScrollEvent, SnappingMethods, debounce, toggleClassName };
3420
3488
  //# sourceMappingURL=ng-virtual-list.mjs.map