ng-virtual-list 16.7.13 → 16.7.14
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.
- package/README.md +1 -0
- package/esm2022/lib/const/index.mjs +2 -1
- package/esm2022/lib/ng-virtual-list.component.mjs +61 -5
- package/esm2022/lib/ng-virtual-list.service.mjs +12 -2
- package/fesm2022/ng-virtual-list.mjs +71 -4
- package/fesm2022/ng-virtual-list.mjs.map +1 -1
- package/lib/const/index.d.ts +1 -0
- package/lib/ng-virtual-list.component.d.ts +14 -1
- package/lib/ng-virtual-list.service.d.ts +5 -1
- package/package.json +1 -1
|
@@ -26,7 +26,17 @@ export class NgVirtualListService {
|
|
|
26
26
|
selectByClick = DEFAULT_SELECT_BY_CLICK;
|
|
27
27
|
collapseByClick = DEFAULT_COLLAPSE_BY_CLICK;
|
|
28
28
|
listElement = null;
|
|
29
|
-
|
|
29
|
+
_$displayItems = new BehaviorSubject([]);
|
|
30
|
+
$displayItems = this._$displayItems.asObservable();
|
|
31
|
+
_collection = [];
|
|
32
|
+
set collection(v) {
|
|
33
|
+
if (this._collection === v) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
this._collection = v;
|
|
37
|
+
this._$displayItems.next(v);
|
|
38
|
+
}
|
|
39
|
+
get collection() { return this._collection; }
|
|
30
40
|
constructor() {
|
|
31
41
|
this._$methodOfSelecting.pipe(takeUntilDestroyed(), tap(v => {
|
|
32
42
|
switch (v) {
|
|
@@ -191,4 +201,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
191
201
|
providedIn: 'root'
|
|
192
202
|
}]
|
|
193
203
|
}], ctorParameters: function () { return []; } });
|
|
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"]}
|
|
204
|
+
//# 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  private _$displayItems = new BehaviorSubject<IRenderVirtualListCollection>([]);\r\n  readonly $displayItems = this._$displayItems.asObservable();\r\n\r\n  private _collection: IRenderVirtualListCollection = [];\r\n  set collection(v: IRenderVirtualListCollection) {\r\n    if (this._collection === v) {\r\n      return;\r\n    }\r\n\r\n    this._collection = v;\r\n\r\n    this._$displayItems.next(v);\r\n  }\r\n  get collection() { return this._collection; }\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"]}
|
|
@@ -113,6 +113,7 @@ const DISPLAY_OBJECTS_LENGTH_MESUREMENT_ERROR = 1;
|
|
|
113
113
|
const MAX_SCROLL_TO_ITERATIONS = 5;
|
|
114
114
|
const DEFAULT_SNAPPING_METHOD = SnappingMethods.NORMAL;
|
|
115
115
|
const DEFAULT_SELECT_METHOD = MethodsForSelecting.NONE;
|
|
116
|
+
const DEFAULT_SCREEN_READER_MESSAGE = 'Showing items $1 to $2';
|
|
116
117
|
// presets
|
|
117
118
|
const BEHAVIOR_AUTO = 'auto';
|
|
118
119
|
const BEHAVIOR_INSTANT = 'instant';
|
|
@@ -259,7 +260,17 @@ class NgVirtualListService {
|
|
|
259
260
|
selectByClick = DEFAULT_SELECT_BY_CLICK;
|
|
260
261
|
collapseByClick = DEFAULT_COLLAPSE_BY_CLICK;
|
|
261
262
|
listElement = null;
|
|
262
|
-
|
|
263
|
+
_$displayItems = new BehaviorSubject([]);
|
|
264
|
+
$displayItems = this._$displayItems.asObservable();
|
|
265
|
+
_collection = [];
|
|
266
|
+
set collection(v) {
|
|
267
|
+
if (this._collection === v) {
|
|
268
|
+
return;
|
|
269
|
+
}
|
|
270
|
+
this._collection = v;
|
|
271
|
+
this._$displayItems.next(v);
|
|
272
|
+
}
|
|
273
|
+
get collection() { return this._collection; }
|
|
263
274
|
constructor() {
|
|
264
275
|
this._$methodOfSelecting.pipe(takeUntilDestroyed(), tap(v => {
|
|
265
276
|
switch (v) {
|
|
@@ -2238,6 +2249,30 @@ const validateScrollIteration = (value) => {
|
|
|
2238
2249
|
throw Error('The "align" parameter must have the value `none`, `start`, `center` or `end`.');
|
|
2239
2250
|
}
|
|
2240
2251
|
};
|
|
2252
|
+
const formatScreenReaderMessage = (items, messagePattern, scrollSize, isVertical, bounds) => {
|
|
2253
|
+
if (!messagePattern) {
|
|
2254
|
+
return '';
|
|
2255
|
+
}
|
|
2256
|
+
const list = items ?? [], size = isVertical ? bounds.height : bounds.width;
|
|
2257
|
+
let start = Number.NaN, end = Number.NaN, prevItem;
|
|
2258
|
+
for (let i = 0, l = list.length; i < l; i++) {
|
|
2259
|
+
const item = list[i], position = isVertical ? item.measures.y : item.measures.x, itemSize = isVertical ? item.measures.height : item.measures.width;
|
|
2260
|
+
if (((position + itemSize) >= scrollSize) && Number.isNaN(start)) {
|
|
2261
|
+
start = item.index + 1;
|
|
2262
|
+
}
|
|
2263
|
+
if ((position >= (scrollSize + size)) && Number.isNaN(end) && prevItem) {
|
|
2264
|
+
end = prevItem.index + 1;
|
|
2265
|
+
}
|
|
2266
|
+
prevItem = item;
|
|
2267
|
+
}
|
|
2268
|
+
if (Number.isNaN(start) || Number.isNaN(end)) {
|
|
2269
|
+
return '';
|
|
2270
|
+
}
|
|
2271
|
+
let formatted = messagePattern ?? '';
|
|
2272
|
+
formatted = formatted.replace('$1', `${start}`);
|
|
2273
|
+
formatted = formatted.replace('$2', `${end}`);
|
|
2274
|
+
return formatted;
|
|
2275
|
+
};
|
|
2241
2276
|
/**
|
|
2242
2277
|
* Virtual list component.
|
|
2243
2278
|
* Maximum performance for extremely large lists.
|
|
@@ -2781,6 +2816,33 @@ class NgVirtualListComponent {
|
|
|
2781
2816
|
}
|
|
2782
2817
|
;
|
|
2783
2818
|
get trackBy() { return this._$trackBy.getValue(); }
|
|
2819
|
+
_$screenReaderMessage = new BehaviorSubject$1(DEFAULT_SCREEN_READER_MESSAGE);
|
|
2820
|
+
$screenReaderMessage = this._$screenReaderMessage.asObservable();
|
|
2821
|
+
_screenReaderMessageTransform = (v) => {
|
|
2822
|
+
const valid = validateString(v);
|
|
2823
|
+
if (!valid) {
|
|
2824
|
+
console.error('The "screenReaderMessage" parameter must be of type `string`.');
|
|
2825
|
+
return DEFAULT_SCREEN_READER_MESSAGE;
|
|
2826
|
+
}
|
|
2827
|
+
return v;
|
|
2828
|
+
};
|
|
2829
|
+
/**
|
|
2830
|
+
* Message for screen reader.
|
|
2831
|
+
* The message format is: "some text $1 some text $2",
|
|
2832
|
+
* where $1 is the number of the first element of the screen collection,
|
|
2833
|
+
* $2 is the number of the last element of the screen collection.
|
|
2834
|
+
*/
|
|
2835
|
+
set screenReaderMessage(v) {
|
|
2836
|
+
if (this._$screenReaderMessage.getValue() === v) {
|
|
2837
|
+
return;
|
|
2838
|
+
}
|
|
2839
|
+
const transformedValue = this._screenReaderMessageTransform(v);
|
|
2840
|
+
this._$screenReaderMessage.next(transformedValue);
|
|
2841
|
+
}
|
|
2842
|
+
;
|
|
2843
|
+
get screenReaderMessage() { return this._$screenReaderMessage.getValue(); }
|
|
2844
|
+
_$screenReaderFormattedMessage = new BehaviorSubject$1(DEFAULT_SCREEN_READER_MESSAGE);
|
|
2845
|
+
$screenReaderFormattedMessage = this._$screenReaderFormattedMessage.asObservable();
|
|
2784
2846
|
_isVertical = this.getIsVertical();
|
|
2785
2847
|
_isLazy = this.getIsLazy();
|
|
2786
2848
|
get orientation() {
|
|
@@ -2959,7 +3021,10 @@ class NgVirtualListComponent {
|
|
|
2959
3021
|
$trackBy.pipe(takeUntilDestroyed(), tap(v => {
|
|
2960
3022
|
this._trackBox.trackingPropertyName = v;
|
|
2961
3023
|
})).subscribe();
|
|
2962
|
-
const $bounds = this._$bounds.asObservable().pipe(filter(b => !!b)), $items = this.$items.pipe(map$1(i => !i ? [] : i)), $scrollSize = this._$scrollSize.asObservable(), $itemSize = this.$itemSize.pipe(map$1(v => v <= 0 ? DEFAULT_ITEM_SIZE : v)), $bufferSize = this.$bufferSize.pipe(map$1(v => v < 0 ? DEFAULT_BUFFER_SIZE : v)), $maxBufferSize = this.$maxBufferSize.pipe(map$1(v => v < 0 ? DEFAULT_MAX_BUFFER_SIZE : v)), $itemConfigMap = this.$itemConfigMap.pipe(map$1(v => !v ? {} : v)), $snap = this.$snap, $isVertical = this.$direction.pipe(map$1(v => this.getIsVertical(v || DEFAULT_DIRECTION))), $isLazy = this.$collectionMode.pipe(map$1(v => this.getIsLazy(v || DEFAULT_COLLECTION_MODE))), $dynamicSize = this.$dynamicSize, $enabledBufferOptimization = this.$enabledBufferOptimization, $snappingMethod = this.$snappingMethod.pipe(map$1(v => this.getIsSnappingMethodAdvanced(v || DEFAULT_SNAPPING_METHOD))), $methodForSelecting = this.$methodForSelecting, $selectedIds = this.$selectedIds, $collapsedIds = this.$collapsedIds.pipe(map$1(v => Array.isArray(v) ? v : [])), $collapsedItemIds = this._$collapsedItemIds.asObservable().pipe(map$1(v => Array.isArray(v) ? v : [])), $actualItems = this._$actualItems.asObservable(), $cacheVersion = this.$cacheVersion;
|
|
3024
|
+
const $bounds = this._$bounds.asObservable().pipe(filter(b => !!b)), $items = this.$items.pipe(map$1(i => !i ? [] : i)), $scrollSize = this._$scrollSize.asObservable(), $itemSize = this.$itemSize.pipe(map$1(v => v <= 0 ? DEFAULT_ITEM_SIZE : v)), $bufferSize = this.$bufferSize.pipe(map$1(v => v < 0 ? DEFAULT_BUFFER_SIZE : v)), $maxBufferSize = this.$maxBufferSize.pipe(map$1(v => v < 0 ? DEFAULT_MAX_BUFFER_SIZE : v)), $itemConfigMap = this.$itemConfigMap.pipe(map$1(v => !v ? {} : v)), $snap = this.$snap, $isVertical = this.$direction.pipe(map$1(v => this.getIsVertical(v || DEFAULT_DIRECTION))), $isLazy = this.$collectionMode.pipe(map$1(v => this.getIsLazy(v || DEFAULT_COLLECTION_MODE))), $dynamicSize = this.$dynamicSize, $enabledBufferOptimization = this.$enabledBufferOptimization, $snappingMethod = this.$snappingMethod.pipe(map$1(v => this.getIsSnappingMethodAdvanced(v || DEFAULT_SNAPPING_METHOD))), $methodForSelecting = this.$methodForSelecting, $selectedIds = this.$selectedIds, $collapsedIds = this.$collapsedIds.pipe(map$1(v => Array.isArray(v) ? v : [])), $collapsedItemIds = this._$collapsedItemIds.asObservable().pipe(map$1(v => Array.isArray(v) ? v : [])), $actualItems = this._$actualItems.asObservable(), $screenReaderMessage = this.$screenReaderMessage, $displayItems = this._service.$displayItems, $cacheVersion = this.$cacheVersion;
|
|
3025
|
+
combineLatest([$displayItems, $screenReaderMessage, $isVertical, $scrollSize, $bounds]).pipe(takeUntilDestroyed(), distinctUntilChanged(), debounceTime(100), tap(([items, screenReaderMessage, isVertical, scrollSize, bounds]) => {
|
|
3026
|
+
this._$screenReaderFormattedMessage.next(formatScreenReaderMessage(items, screenReaderMessage, scrollSize, isVertical, bounds));
|
|
3027
|
+
})).subscribe();
|
|
2963
3028
|
$isLazy.pipe(takeUntilDestroyed(), tap(v => {
|
|
2964
3029
|
this._trackBox.isLazy = v;
|
|
2965
3030
|
})).subscribe();
|
|
@@ -3385,13 +3450,13 @@ class NgVirtualListComponent {
|
|
|
3385
3450
|
}
|
|
3386
3451
|
}
|
|
3387
3452
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: NgVirtualListService }], target: i0.ɵɵFactoryTarget.Component });
|
|
3388
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListComponent, selector: "ng-virtual-list", inputs: { items: "items", selectedIds: "selectedIds", collapsedIds: "collapsedIds", selectByClick: "selectByClick", collapseByClick: "collapseByClick", snap: "snap", enabledBufferOptimization: "enabledBufferOptimization", itemRenderer: "itemRenderer", itemConfigMap: "itemConfigMap", itemSize: "itemSize", dynamicSize: "dynamicSize", direction: "direction", collectionMode: "collectionMode", bufferSize: "bufferSize", maxBufferSize: "maxBufferSize", snappingMethod: "snappingMethod", methodForSelecting: "methodForSelecting", trackBy: "trackBy" }, outputs: { onScroll: "onScroll", onScrollEnd: "onScrollEnd", onViewportChange: "onViewportChange", onItemClick: "onItemClick", onSelect: "onSelect", onCollapse: "onCollapse", onScrollReachStart: "onScrollReachStart", onScrollReachEnd: "onScrollReachEnd" }, host: { styleAttribute: "position: relative;" }, providers: [NgVirtualListService], viewQueries: [{ propertyName: "_listContainerRef", first: true, predicate: ["renderersContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_container", first: true, predicate: ["container"], descendants: true, read: (ElementRef) }, { propertyName: "_list", first: true, predicate: ["list"], descendants: true, read: (ElementRef) }, { propertyName: "_snapContainerRef", first: true, predicate: ["snapRendererContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_snappedContainer", first: true, predicate: ["snapped"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <div [attr.aria-orientation]=\"orientation\" [attr.aria-activedescendant]=\"$focusedElement | async\" #list part=\"list\"\r\n class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </div>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.horizontal) .ngvl__list{display:inline-flex}:host(.horizontal) .ngvl__scroller{overflow:auto hidden}:host(.vertical) .ngvl__scroller{overflow:hidden auto}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.ShadowDom });
|
|
3453
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListComponent, selector: "ng-virtual-list", inputs: { items: "items", selectedIds: "selectedIds", collapsedIds: "collapsedIds", selectByClick: "selectByClick", collapseByClick: "collapseByClick", snap: "snap", enabledBufferOptimization: "enabledBufferOptimization", itemRenderer: "itemRenderer", itemConfigMap: "itemConfigMap", itemSize: "itemSize", dynamicSize: "dynamicSize", direction: "direction", collectionMode: "collectionMode", bufferSize: "bufferSize", maxBufferSize: "maxBufferSize", snappingMethod: "snappingMethod", methodForSelecting: "methodForSelecting", trackBy: "trackBy", screenReaderMessage: "screenReaderMessage" }, outputs: { onScroll: "onScroll", onScrollEnd: "onScrollEnd", onViewportChange: "onViewportChange", onItemClick: "onItemClick", onSelect: "onSelect", onCollapse: "onCollapse", onScrollReachStart: "onScrollReachStart", onScrollReachEnd: "onScrollReachEnd" }, host: { styleAttribute: "position: relative;" }, providers: [NgVirtualListService], viewQueries: [{ propertyName: "_listContainerRef", first: true, predicate: ["renderersContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_container", first: true, predicate: ["container"], descendants: true, read: (ElementRef) }, { propertyName: "_list", first: true, predicate: ["list"], descendants: true, read: (ElementRef) }, { propertyName: "_snapContainerRef", first: true, predicate: ["snapRendererContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_snappedContainer", first: true, predicate: ["snapped"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div aria-live=\"polite\" aria-atomic=\"true\" class=\"ngvl__screen-reader\">\r\n {{ $screenReaderFormattedMessage | async}}\r\n</div>\r\n<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <div [attr.aria-orientation]=\"orientation\" [attr.aria-activedescendant]=\"$focusedElement | async\" #list part=\"list\"\r\n class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </div>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.horizontal) .ngvl__list{display:inline-flex}:host(.horizontal) .ngvl__scroller{overflow:auto hidden}:host(.vertical) .ngvl__scroller{overflow:hidden auto}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}.ngvl__screen-reader{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.ShadowDom });
|
|
3389
3454
|
}
|
|
3390
3455
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListComponent, decorators: [{
|
|
3391
3456
|
type: Component,
|
|
3392
3457
|
args: [{ selector: 'ng-virtual-list', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.ShadowDom, providers: [NgVirtualListService], host: {
|
|
3393
3458
|
'style': 'position: relative;'
|
|
3394
|
-
}, template: "<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <div [attr.aria-orientation]=\"orientation\" [attr.aria-activedescendant]=\"$focusedElement | async\" #list part=\"list\"\r\n class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </div>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.horizontal) .ngvl__list{display:inline-flex}:host(.horizontal) .ngvl__scroller{overflow:auto hidden}:host(.vertical) .ngvl__scroller{overflow:hidden auto}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}\n"] }]
|
|
3459
|
+
}, template: "<div aria-live=\"polite\" aria-atomic=\"true\" class=\"ngvl__screen-reader\">\r\n {{ $screenReaderFormattedMessage | async}}\r\n</div>\r\n<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <div [attr.aria-orientation]=\"orientation\" [attr.aria-activedescendant]=\"$focusedElement | async\" #list part=\"list\"\r\n class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </div>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.horizontal) .ngvl__list{display:inline-flex}:host(.horizontal) .ngvl__scroller{overflow:auto hidden}:host(.vertical) .ngvl__scroller{overflow:hidden auto}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}.ngvl__screen-reader{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}\n"] }]
|
|
3395
3460
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: NgVirtualListService }]; }, propDecorators: { _listContainerRef: [{
|
|
3396
3461
|
type: ViewChild,
|
|
3397
3462
|
args: ['renderersContainer', { read: ViewContainerRef }]
|
|
@@ -3459,6 +3524,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
3459
3524
|
type: Input
|
|
3460
3525
|
}], trackBy: [{
|
|
3461
3526
|
type: Input
|
|
3527
|
+
}], screenReaderMessage: [{
|
|
3528
|
+
type: Input
|
|
3462
3529
|
}] } });
|
|
3463
3530
|
|
|
3464
3531
|
class NgVirtualListModule {
|