ng-virtual-list 18.0.13 → 18.0.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.
@@ -2,7 +2,6 @@ import { CacheMap } from "./cacheMap";
2
2
  import { Tracker } from "./tracker";
3
3
  import { debounce } from "./debounce";
4
4
  import { DEFAULT_ITEMS_OFFSET, HEIGHT_PROP_NAME, WIDTH_PROP_NAME, X_PROP_NAME, Y_PROP_NAME } from "../const";
5
- import { getCollectionRemovedOrUpdatedItems } from "./collection";
6
5
  export const TRACK_BOX_CHANGE_EVENT_NAME = 'change';
7
6
  var ItemDisplayMethods;
8
7
  (function (ItemDisplayMethods) {
@@ -33,13 +32,22 @@ export class TrackBox extends CacheMap {
33
32
  }
34
33
  this._displayComponents = v;
35
34
  }
35
+ /**
36
+ * Set the trackBy property
37
+ */
38
+ set trackingPropertyName(v) {
39
+ this._tracker.trackingPropertyName = v;
40
+ }
36
41
  constructor(trackingPropertyName) {
37
42
  super();
38
43
  this._tracker = new Tracker(trackingPropertyName);
39
44
  }
40
45
  set(id, bounds) {
41
- if (this._map.has(id) && JSON.stringify(this._map.get(id)) === JSON.stringify(bounds)) {
42
- return this._map;
46
+ if (this._map.has(id)) {
47
+ const b = this._map.get(id);
48
+ if (b?.width === bounds.width && b.height === bounds.height) {
49
+ return this._map;
50
+ }
43
51
  }
44
52
  const v = this._map.set(id, bounds);
45
53
  this.bumpVersion();
@@ -62,31 +70,69 @@ export class TrackBox extends CacheMap {
62
70
  console.warn('Attention! The collection must be immutable.');
63
71
  return;
64
72
  }
65
- const { deleted, updated, added } = getCollectionRemovedOrUpdatedItems(this._previousCollection, currentCollection);
66
- this.clearCache(deleted, updated, added, itemSize);
73
+ this.updateCache(this._previousCollection, currentCollection, itemSize);
67
74
  this._previousCollection = currentCollection;
68
75
  }
69
76
  /**
70
- * Clears the cache of items from the list
77
+ * Update the cache of items from the list
71
78
  */
72
- clearCache(deleted, updated, added, itemSize) {
73
- if (deleted) {
74
- for (let i = 0, l = deleted.length; i < l; i++) {
75
- const item = deleted[i], id = item.id;
76
- if (this._map.has(id)) {
77
- this._map.delete(id);
79
+ updateCache(previousCollection, currentCollection, itemSize) {
80
+ if (!currentCollection || currentCollection.length === 0) {
81
+ if (previousCollection) {
82
+ // deleted
83
+ for (let i = 0, l = previousCollection.length; i < l; i++) {
84
+ const item = previousCollection[i], id = item.id;
85
+ if (this._map.has(id)) {
86
+ this._map.delete(id);
87
+ }
88
+ }
89
+ }
90
+ return;
91
+ }
92
+ if (!previousCollection || previousCollection.length === 0) {
93
+ if (currentCollection) {
94
+ // added
95
+ for (let i = 0, l = currentCollection.length; i < l; i++) {
96
+ const item = currentCollection[i], id = item.id;
97
+ this._map.set(id, { x: 0, y: 0, width: itemSize, height: itemSize, method: ItemDisplayMethods.CREATE });
78
98
  }
79
99
  }
100
+ return;
80
101
  }
81
- if (updated) {
82
- for (let i = 0, l = updated.length; i < l; i++) {
83
- const item = updated[i], id = item.id;
84
- this._map.set(id, { ...(this._map.get(id) || { x: 0, y: 0, width: itemSize, height: itemSize }), method: ItemDisplayMethods.UPDATE });
102
+ const collectionDict = {};
103
+ for (let i = 0, l = currentCollection.length; i < l; i++) {
104
+ const item = currentCollection[i];
105
+ if (item) {
106
+ collectionDict[item.id] = item;
85
107
  }
86
108
  }
87
- if (added) {
88
- for (let i = 0, l = added.length; i < l; i++) {
89
- const item = added[i], id = item.id;
109
+ const notChangedMap = {}, deletedMap = {}, updatedMap = {};
110
+ for (let i = 0, l = previousCollection.length; i < l; i++) {
111
+ const item = previousCollection[i], id = item.id;
112
+ if (item) {
113
+ if (collectionDict.hasOwnProperty(id)) {
114
+ if (item === collectionDict[id]) {
115
+ // not changed
116
+ notChangedMap[item.id] = item;
117
+ this._map.set(id, { ...(this._map.get(id) || { x: 0, y: 0, width: itemSize, height: itemSize }), method: ItemDisplayMethods.NOT_CHANGED });
118
+ continue;
119
+ }
120
+ else {
121
+ // updated
122
+ updatedMap[item.id] = item;
123
+ this._map.set(id, { ...(this._map.get(id) || { x: 0, y: 0, width: itemSize, height: itemSize }), method: ItemDisplayMethods.UPDATE });
124
+ continue;
125
+ }
126
+ }
127
+ // deleted
128
+ deletedMap[item.id] = item;
129
+ this._map.delete(id);
130
+ }
131
+ }
132
+ for (let i = 0, l = currentCollection.length; i < l; i++) {
133
+ const item = currentCollection[i], id = item.id;
134
+ if (item && !deletedMap.hasOwnProperty(id) && !updatedMap.hasOwnProperty(id) && !notChangedMap.hasOwnProperty(id)) {
135
+ // added
90
136
  this._map.set(id, { x: 0, y: 0, width: itemSize, height: itemSize, method: ItemDisplayMethods.CREATE });
91
137
  }
92
138
  }
@@ -358,6 +404,10 @@ export class TrackBox extends CacheMap {
358
404
  this.clearScrollDirectionCache();
359
405
  }
360
406
  }
407
+ changes() {
408
+ this.bumpVersion();
409
+ this.fireChange();
410
+ }
361
411
  generateDisplayCollection(items, stickyMap, metrics) {
362
412
  const { normalizedItemWidth, normalizedItemHeight, dynamicSize, itemsFromStartToScrollEnd, isVertical, renderItems: renderItemsLength, scrollSize, sizeProperty, snap, snippedPos, startPosition, totalLength, startIndex, typicalItemSize, } = metrics, displayItems = [];
363
413
  if (items.length) {
@@ -482,4 +532,4 @@ export class TrackBox extends CacheMap {
482
532
  }
483
533
  }
484
534
  }
485
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trackBox.js","sourceRoot":"","sources":["../../../../../projects/ng-virtual-list/src/lib/utils/trackBox.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef } from \"@angular/core\";\r\nimport { NgVirtualListItemComponent } from \"../components/ng-virtual-list-item.component\";\r\nimport { IRenderVirtualListCollection } from \"../models/render-collection.model\";\r\nimport { IRenderVirtualListItem } from \"../models/render-item.model\";\r\nimport { Id } from \"../types/id\";\r\nimport { IRect } from \"../types/rect\";\r\nimport { CacheMap } from \"./cacheMap\";\r\nimport { Tracker } from \"./tracker\";\r\nimport { ISize } from \"../types\";\r\nimport { debounce } from \"./debounce\";\r\nimport { DEFAULT_ITEMS_OFFSET, HEIGHT_PROP_NAME, WIDTH_PROP_NAME, X_PROP_NAME, Y_PROP_NAME } from \"../const\";\r\nimport { IVirtualListStickyMap } from \"../models\";\r\nimport { getCollectionRemovedOrUpdatedItems } from \"./collection\";\r\n\r\nexport const TRACK_BOX_CHANGE_EVENT_NAME = 'change';\r\n\r\nexport interface IMetrics {\r\n    delta: number;\r\n    normalizedItemWidth: number;\r\n    normalizedItemHeight: number;\r\n    width: number;\r\n    height: number;\r\n    dynamicSize: boolean;\r\n    itemSize: number;\r\n    itemsFromStartToScrollEnd: number;\r\n    itemsFromStartToDisplayEnd: number;\r\n    itemsOnDisplay: number;\r\n    itemsOnDisplayLength: number;\r\n    isVertical: boolean;\r\n    leftHiddenItemsWeight: number;\r\n    leftItemLength: number;\r\n    leftItemsWeight: number;\r\n    renderItems: number;\r\n    rightItemLength: number;\r\n    rightItemsWeight: number;\r\n    scrollSize: number;\r\n    leftSizeOfAddedItems: number;\r\n    rightSizeOfAddedItems: number;\r\n    sizeProperty: typeof HEIGHT_PROP_NAME | typeof WIDTH_PROP_NAME;\r\n    snap: boolean;\r\n    snippedPos: number;\r\n    startIndex: number;\r\n    startPosition: number;\r\n    totalItemsToDisplayEndWeight: number;\r\n    totalLength: number;\r\n    totalSize: number;\r\n    typicalItemSize: number;\r\n}\r\n\r\nexport interface IRecalculateMetricsOptions<I extends { id: Id }, C extends Array<I>> {\r\n    bounds: ISize;\r\n    collection: C;\r\n    isVertical: boolean;\r\n    itemSize: number;\r\n    itemsOffset: number;\r\n    dynamicSize: boolean;\r\n    scrollSize: number;\r\n    snap: boolean;\r\n    enabledBufferOptimization: boolean;\r\n    fromItemId?: Id;\r\n}\r\n\r\ntype CacheMapEvents = typeof TRACK_BOX_CHANGE_EVENT_NAME;\r\n\r\ntype OnChangeEventListener = (version: number) => void;\r\n\r\ntype CacheMapListeners = OnChangeEventListener;\r\n\r\nenum ItemDisplayMethods {\r\n    CREATE,\r\n    UPDATE,\r\n    DELETE,\r\n    NOT_CHANGED,\r\n}\r\n\r\n/**\r\n * An object that performs tracking, calculations and caching.\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/utils/trackBox.ts\r\n * @author Evgenii Grebennikov\r\n * @email djonnyx@gmail.com\r\n */\r\nexport class TrackBox extends CacheMap<Id, IRect & { method?: ItemDisplayMethods }, CacheMapEvents, CacheMapListeners> {\r\n    protected _tracker!: Tracker<IRenderVirtualListItem, NgVirtualListItemComponent>;\r\n\r\n    protected _items: IRenderVirtualListCollection | null | undefined;\r\n\r\n    set items(v: IRenderVirtualListCollection | null | undefined) {\r\n        if (this._items === v) {\r\n            return;\r\n        }\r\n\r\n        this._items = v;\r\n    }\r\n\r\n    protected _displayComponents: Array<ComponentRef<NgVirtualListItemComponent>> | null | undefined;\r\n\r\n    set displayComponents(v: Array<ComponentRef<NgVirtualListItemComponent>> | null | undefined) {\r\n        if (this._displayComponents === v) {\r\n            return;\r\n        }\r\n\r\n        this._displayComponents = v;\r\n    }\r\n\r\n    constructor(trackingPropertyName: string) {\r\n        super();\r\n\r\n        this._tracker = new Tracker(trackingPropertyName);\r\n    }\r\n\r\n    override set(id: Id, bounds: IRect): Map<Id, IRect> {\r\n        if (this._map.has(id) && JSON.stringify(this._map.get(id)) === JSON.stringify(bounds)) {\r\n            return this._map;\r\n        }\r\n\r\n        const v = this._map.set(id, bounds);\r\n\r\n        this.bumpVersion();\r\n\r\n        this.fireChange();\r\n\r\n        return v;\r\n    }\r\n\r\n    private _fireChanges = (version: number) => {\r\n        this.dispatch(TRACK_BOX_CHANGE_EVENT_NAME, version);\r\n    };\r\n\r\n    private _previousCollection: Array<{ id: Id }> | null | undefined;\r\n\r\n    private _debounceChanges = debounce(this._fireChanges, 0);\r\n\r\n    protected override fireChange() {\r\n        this._debounceChanges.execute(this._version);\r\n    }\r\n\r\n    /**\r\n     * Scans the collection for deleted items and flushes the deleted item cache.\r\n     */\r\n    resetCollection<I extends { id: Id }, C extends Array<I>>(currentCollection: C | null | undefined, itemSize: number): void {\r\n        if (currentCollection !== undefined && currentCollection !== null && currentCollection === this._previousCollection) {\r\n            console.warn('Attention! The collection must be immutable.');\r\n            return;\r\n        }\r\n        const { deleted, updated, added } = getCollectionRemovedOrUpdatedItems(this._previousCollection, currentCollection);\r\n\r\n        this.clearCache(deleted, updated, added, itemSize);\r\n\r\n        this._previousCollection = currentCollection;\r\n    }\r\n\r\n    /**\r\n     * Clears the cache of items from the list\r\n     */\r\n    protected clearCache<I extends { id: Id }, C extends Array<I>>(deleted: C | null | undefined, updated: C | null | undefined,\r\n        added: C | null | undefined, itemSize: number): void {\r\n        if (deleted) {\r\n            for (let i = 0, l = deleted.length; i < l; i++) {\r\n                const item = deleted[i], id = item.id;\r\n                if (this._map.has(id)) {\r\n                    this._map.delete(id);\r\n                }\r\n            }\r\n        }\r\n        if (updated) {\r\n            for (let i = 0, l = updated.length; i < l; i++) {\r\n                const item = updated[i], id = item.id;\r\n                this._map.set(id, { ...(this._map.get(id) || { x: 0, y: 0, width: itemSize, height: itemSize }), method: ItemDisplayMethods.UPDATE });\r\n            }\r\n        }\r\n        if (added) {\r\n            for (let i = 0, l = added.length; i < l; i++) {\r\n                const item = added[i], id = item.id;\r\n                this._map.set(id, { x: 0, y: 0, width: itemSize, height: itemSize, method: ItemDisplayMethods.CREATE });\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Finds the position of a collection element by the given Id\r\n     */\r\n    getItemPosition<I extends { id: Id }, C extends Array<I>>(id: Id, stickyMap: IVirtualListStickyMap, options: IRecalculateMetricsOptions<I, C>): number {\r\n        const opt = { fromItemId: id, stickyMap, ...options };\r\n        const { scrollSize } = this.recalculateMetrics(opt);\r\n        return scrollSize;\r\n    }\r\n\r\n    /**\r\n     * Updates the collection of display objects\r\n     */\r\n    updateCollection<I extends { id: Id }, C extends Array<I>>(items: C, stickyMap: IVirtualListStickyMap,\r\n        options: Omit<IRecalculateMetricsOptions<I, C>, 'collection'>): { displayItems: IRenderVirtualListCollection; totalSize: number; delta: number; } {\r\n        const opt = { stickyMap, ...options };\r\n\r\n        this.cacheElements();\r\n\r\n        const metrics = this.recalculateMetrics({\r\n            ...opt,\r\n            collection: items,\r\n        });\r\n\r\n        this._delta += metrics.delta;\r\n\r\n        this.snapshot();\r\n\r\n        const displayItems = this.generateDisplayCollection(items, stickyMap, metrics);\r\n        return { displayItems, totalSize: metrics.totalSize, delta: metrics.delta };\r\n    }\r\n\r\n    /**\r\n     * Finds the closest element in the collection by scrollSize\r\n     */\r\n    getNearestItem<I extends { id: Id }, C extends Array<I>>(scrollSize: number, items: C, itemSize: number, isVertical: boolean): I | undefined {\r\n        return this.getElementFromStart(scrollSize, items, this._map, itemSize, isVertical);\r\n    }\r\n\r\n    /**\r\n     * Calculates the position of an element based on the given scrollSize\r\n     */\r\n    private getElementFromStart<I extends { id: Id }, C extends Array<I>>(scrollSize: number, collection: C, map: Map<Id, IRect>, typicalItemSize: number,\r\n        isVertical: boolean): I | undefined {\r\n        const sizeProperty = isVertical ? HEIGHT_PROP_NAME : WIDTH_PROP_NAME;\r\n        let offset = 0;\r\n        for (let i = 0, l = collection.length; i < l; i++) {\r\n            const item = collection[i];\r\n            let itemSize = 0;\r\n            if (map.has(item.id)) {\r\n                const bounds = map.get(item.id);\r\n                itemSize = bounds ? bounds[sizeProperty] : typicalItemSize;\r\n            } else {\r\n                itemSize = typicalItemSize;\r\n            }\r\n            if (offset > scrollSize) {\r\n                return item;\r\n            }\r\n            offset += itemSize;\r\n        }\r\n        return undefined;\r\n    }\r\n\r\n    /**\r\n     * Calculates the entry into the overscroll area and returns the number of overscroll elements\r\n     */\r\n    private getElementNumToEnd<I extends { id: Id }, C extends Array<I>>(i: number, collection: C, map: Map<Id, IRect>, typicalItemSize: number,\r\n        size: number, isVertical: boolean, indexOffset: number = 0): { num: number, offset: number } {\r\n        const sizeProperty = isVertical ? HEIGHT_PROP_NAME : WIDTH_PROP_NAME;\r\n        let offset = 0, num = 0;\r\n        for (let j = collection.length - indexOffset - 1; j >= i; j--) {\r\n            const item = collection[j];\r\n            let itemSize = 0;\r\n            if (map.has(item.id)) {\r\n                const bounds = map.get(item.id);\r\n                itemSize = bounds ? bounds[sizeProperty] : typicalItemSize;\r\n            } else {\r\n                itemSize = typicalItemSize;\r\n            }\r\n            offset += itemSize;\r\n            num++;\r\n            if (offset > size) {\r\n                return { num: 0, offset };\r\n            }\r\n        }\r\n        return { num, offset };\r\n    }\r\n\r\n    /**\r\n     * Calculates list metrics\r\n     */\r\n    protected recalculateMetrics<I extends { id: Id }, C extends Array<I>>(options: IRecalculateMetricsOptions<I, C>): IMetrics {\r\n        const { fromItemId, bounds, collection, dynamicSize, isVertical, itemSize,\r\n            itemsOffset, scrollSize, snap, stickyMap, enabledBufferOptimization } = options as IRecalculateMetricsOptions<I, C> & {\r\n                stickyMap: IVirtualListStickyMap,\r\n            };\r\n\r\n        const { width, height } = bounds, sizeProperty = isVertical ? HEIGHT_PROP_NAME : WIDTH_PROP_NAME, size = isVertical ? height : width,\r\n            totalLength = collection.length, typicalItemSize = itemSize,\r\n            w = isVertical ? width : typicalItemSize, h = isVertical ? typicalItemSize : height,\r\n            map = this._map, snapshot = this._snapshot,\r\n            leftItemsOffset = enabledBufferOptimization ? this.deltaDirection === 1 ? DEFAULT_ITEMS_OFFSET : itemsOffset : itemsOffset,\r\n            rightItemsOffset = enabledBufferOptimization ? this.deltaDirection === -1 ? DEFAULT_ITEMS_OFFSET : itemsOffset : itemsOffset,\r\n            checkOverscrollItemsLimit = Math.ceil(size / typicalItemSize),\r\n            snippedPos = Math.floor(scrollSize),\r\n            leftItemsWeights: Array<number> = [],\r\n            isFromId = fromItemId !== undefined && (typeof fromItemId === 'number' && fromItemId > -1)\r\n                || (typeof fromItemId === 'string' && fromItemId > '-1');\r\n\r\n        let itemsFromStartToScrollEnd: number = -1, itemsFromDisplayEndToOffsetEnd = 0, itemsFromStartToDisplayEnd = -1,\r\n            leftItemLength = 0, rightItemLength = 0,\r\n            leftItemsWeight = 0, rightItemsWeight = 0,\r\n            leftHiddenItemsWeight = 0,\r\n            totalItemsToDisplayEndWeight = 0,\r\n            rightSizeOfAddedItems = 0,\r\n            leftSizeOfAddedItems = 0,\r\n            rightSizeOfUpdatedItems = 0,\r\n            leftSizeOfUpdatedItems = 0,\r\n            itemById: I | undefined = undefined,\r\n            itemByIdPos: number = 0,\r\n            targetDisplayItemIndex: number = -1,\r\n            isTargetInOverscroll: boolean = false,\r\n            actualScrollSize = itemByIdPos,\r\n            totalSize = 0,\r\n            startIndex;\r\n\r\n        // If the list is dynamic or there are new elements in the collection, then it switches to the long algorithm.\r\n        if (dynamicSize) {\r\n            let y = 0, stickyCollectionItem: I | undefined = undefined, stickyComponentSize = 0;\r\n            for (let i = 0, l = collection.length; i < l; i++) {\r\n                const ii = i + 1, collectionItem = collection[i], id = collectionItem.id;\r\n\r\n                let componentSize = 0, componentSizeDelta = 0, itemDisplayMethod: ItemDisplayMethods = ItemDisplayMethods.NOT_CHANGED;\r\n                if (map.has(id)) {\r\n                    const bounds = map.get(id) || { x: 0, y: 0, width: typicalItemSize, height: typicalItemSize };\r\n                    componentSize = bounds[sizeProperty];\r\n\r\n                    itemDisplayMethod = bounds?.method ?? ItemDisplayMethods.UPDATE;\r\n                    if (itemDisplayMethod === ItemDisplayMethods.UPDATE) {\r\n                        const snapshotBounds = snapshot.get(id);\r\n                        const componentSnapshotSize = componentSize - (snapshotBounds ? snapshotBounds[sizeProperty] : typicalItemSize);\r\n                        componentSizeDelta = componentSnapshotSize;\r\n                        map.set(id, { ...bounds, method: ItemDisplayMethods.NOT_CHANGED });\r\n                    }\r\n                    if (itemDisplayMethod === ItemDisplayMethods.CREATE) {\r\n                        componentSizeDelta = typicalItemSize;\r\n                        map.set(id, { ...bounds, method: ItemDisplayMethods.NOT_CHANGED });\r\n                    }\r\n                } else {\r\n                    componentSize = typicalItemSize;\r\n                    if (snapshot.has(id)) {\r\n                        itemDisplayMethod = ItemDisplayMethods.DELETE;\r\n                    }\r\n                }\r\n\r\n                totalSize += componentSize;\r\n\r\n                if (isFromId) {\r\n                    if (itemById === undefined) {\r\n                        if (id !== fromItemId && stickyMap && stickyMap[id] > 0) {\r\n                            stickyComponentSize = componentSize;\r\n                            stickyCollectionItem = collectionItem;\r\n                        }\r\n\r\n                        if (id === fromItemId) {\r\n                            targetDisplayItemIndex = i;\r\n                            if (stickyCollectionItem && stickyMap && stickyMap[stickyCollectionItem.id] > 0) {\r\n                                const { num } = this.getElementNumToEnd(i, collection, map, typicalItemSize, size, isVertical);\r\n                                if (num > 0) {\r\n                                    isTargetInOverscroll = true;\r\n                                    y -= size - componentSize;\r\n                                } else {\r\n                                    y -= stickyComponentSize;\r\n                                    leftHiddenItemsWeight -= stickyComponentSize;\r\n                                }\r\n                            }\r\n                            itemById = collectionItem;\r\n                            itemByIdPos = y;\r\n                        } else {\r\n                            leftItemsWeights.push(componentSize);\r\n                            leftHiddenItemsWeight += componentSize;\r\n                            itemsFromStartToScrollEnd = ii;\r\n                        }\r\n                    }\r\n                } else if (y < scrollSize - componentSize) {\r\n                    leftItemsWeights.push(componentSize);\r\n                    leftHiddenItemsWeight += componentSize;\r\n                    itemsFromStartToScrollEnd = ii;\r\n                }\r\n\r\n                if (isFromId) {\r\n                    if (itemById === undefined || y < itemByIdPos + size + componentSize) {\r\n                        itemsFromStartToDisplayEnd = ii;\r\n                        totalItemsToDisplayEndWeight += componentSize;\r\n                        itemsFromDisplayEndToOffsetEnd = itemsFromStartToDisplayEnd + rightItemsOffset;\r\n                    }\r\n                    if (y > itemByIdPos + size + componentSize) {\r\n                        if (itemDisplayMethod === ItemDisplayMethods.UPDATE) {\r\n                            rightSizeOfAddedItems += componentSizeDelta;\r\n                        }\r\n                    }\r\n                } else if (y < scrollSize + size + componentSize) {\r\n                    itemsFromStartToDisplayEnd = ii;\r\n                    totalItemsToDisplayEndWeight += componentSize;\r\n                    itemsFromDisplayEndToOffsetEnd = itemsFromStartToDisplayEnd + rightItemsOffset;\r\n\r\n                    if (y < scrollSize - componentSize) {\r\n                        if (itemDisplayMethod === ItemDisplayMethods.UPDATE) {\r\n                            leftSizeOfUpdatedItems += componentSizeDelta;\r\n                        }\r\n                        if (itemDisplayMethod === ItemDisplayMethods.CREATE) {\r\n                            leftSizeOfAddedItems += componentSizeDelta;\r\n                        }\r\n                    }\r\n                } else {\r\n                    if (i < itemsFromDisplayEndToOffsetEnd) {\r\n                        rightItemsWeight += componentSize;\r\n                    }\r\n                    if (itemDisplayMethod === ItemDisplayMethods.UPDATE) {\r\n                        rightSizeOfUpdatedItems += componentSizeDelta;\r\n                    }\r\n                    if (itemDisplayMethod === ItemDisplayMethods.CREATE) {\r\n                        rightSizeOfAddedItems += componentSizeDelta;\r\n                    }\r\n                }\r\n\r\n                y += componentSize;\r\n            }\r\n\r\n            if (isTargetInOverscroll) {\r\n                const { num } = this.getElementNumToEnd(\r\n                    collection.length - (checkOverscrollItemsLimit < 0 ? 0 : collection.length - checkOverscrollItemsLimit),\r\n                    collection, map, typicalItemSize, size, isVertical, collection.length - (collection.length - (targetDisplayItemIndex + 1)),\r\n                );\r\n                if (num > 0) {\r\n                    itemsFromStartToScrollEnd -= num;\r\n                }\r\n            }\r\n\r\n            if (itemsFromStartToScrollEnd <= -1) {\r\n                itemsFromStartToScrollEnd = 0;\r\n            }\r\n            if (itemsFromStartToDisplayEnd <= -1) {\r\n                itemsFromStartToDisplayEnd = 0;\r\n            }\r\n            actualScrollSize = isFromId ? itemByIdPos : scrollSize;\r\n\r\n            leftItemsWeights.splice(0, leftItemsWeights.length - leftItemsOffset);\r\n            leftItemsWeights.forEach(v => {\r\n                leftItemsWeight += v;\r\n            });\r\n\r\n            leftItemLength = Math.min(itemsFromStartToScrollEnd, leftItemsOffset);\r\n            rightItemLength = itemsFromStartToDisplayEnd + rightItemsOffset > totalLength\r\n                ? totalLength - itemsFromStartToDisplayEnd : rightItemsOffset;\r\n        } else\r\n        // Buffer optimization does not work on fast linear algorithm\r\n        {\r\n            itemsFromStartToScrollEnd = Math.floor(scrollSize / typicalItemSize);\r\n            itemsFromStartToDisplayEnd = Math.ceil((scrollSize + size) / typicalItemSize);\r\n            leftItemLength = Math.min(itemsFromStartToScrollEnd, itemsOffset);\r\n            rightItemLength = itemsFromStartToDisplayEnd + itemsOffset > totalLength\r\n                ? totalLength - itemsFromStartToDisplayEnd : itemsOffset;\r\n            leftItemsWeight = leftItemLength * typicalItemSize;\r\n            rightItemsWeight = rightItemLength * typicalItemSize,\r\n                leftHiddenItemsWeight = itemsFromStartToScrollEnd * typicalItemSize,\r\n                totalItemsToDisplayEndWeight = itemsFromStartToDisplayEnd * typicalItemSize;\r\n            actualScrollSize = scrollSize;\r\n            totalSize = totalLength * typicalItemSize;\r\n        }\r\n        startIndex = Math.min(itemsFromStartToScrollEnd - leftItemLength, totalLength > 0 ? totalLength - 1 : 0);\r\n\r\n        const itemsOnDisplay = totalItemsToDisplayEndWeight - leftHiddenItemsWeight,\r\n            itemsOnDisplayLength = itemsFromStartToDisplayEnd - itemsFromStartToScrollEnd,\r\n            startPosition = leftHiddenItemsWeight - leftItemsWeight,\r\n            renderItems = itemsOnDisplayLength + leftItemLength + rightItemLength,\r\n            delta = leftSizeOfUpdatedItems + leftSizeOfAddedItems;\r\n\r\n        const metrics: IMetrics = {\r\n            delta,\r\n            normalizedItemWidth: w,\r\n            normalizedItemHeight: h,\r\n            width,\r\n            height,\r\n            dynamicSize,\r\n            itemSize,\r\n            itemsFromStartToScrollEnd,\r\n            itemsFromStartToDisplayEnd,\r\n            itemsOnDisplay,\r\n            itemsOnDisplayLength,\r\n            isVertical,\r\n            leftHiddenItemsWeight,\r\n            leftItemLength,\r\n            leftItemsWeight,\r\n            renderItems,\r\n            rightItemLength,\r\n            rightItemsWeight,\r\n            scrollSize: actualScrollSize,\r\n            leftSizeOfAddedItems,\r\n            rightSizeOfAddedItems,\r\n            sizeProperty,\r\n            snap,\r\n            snippedPos,\r\n            startIndex,\r\n            startPosition,\r\n            totalItemsToDisplayEndWeight,\r\n            totalLength,\r\n            totalSize,\r\n            typicalItemSize,\r\n        };\r\n\r\n        return metrics;\r\n    }\r\n\r\n    protected _scrollDelta: number = 0;\r\n    get scrollDelta() { return this._scrollDelta; }\r\n\r\n    clearDeltaDirection() {\r\n        this.clearScrollDirectionCache();\r\n    }\r\n\r\n    clearDelta(clearDirectionDetector = false): void {\r\n        this._delta = 0;\r\n\r\n        if (clearDirectionDetector) {\r\n            this.clearScrollDirectionCache();\r\n        }\r\n    }\r\n\r\n    protected generateDisplayCollection<I extends { id: Id }, C extends Array<I>>(items: C, stickyMap: IVirtualListStickyMap,\r\n        metrics: IMetrics): IRenderVirtualListCollection {\r\n        const {\r\n            normalizedItemWidth,\r\n            normalizedItemHeight,\r\n            dynamicSize,\r\n            itemsFromStartToScrollEnd,\r\n            isVertical,\r\n            renderItems: renderItemsLength,\r\n            scrollSize,\r\n            sizeProperty,\r\n            snap,\r\n            snippedPos,\r\n            startPosition,\r\n            totalLength,\r\n            startIndex,\r\n            typicalItemSize,\r\n        } = metrics,\r\n            displayItems: IRenderVirtualListCollection = [];\r\n        if (items.length) {\r\n            const actualSnippedPosition = snippedPos;\r\n            let pos = startPosition,\r\n                renderItems = renderItemsLength,\r\n                stickyItem: IRenderVirtualListItem | undefined, nextSticky: IRenderVirtualListItem | undefined, stickyItemIndex = -1,\r\n                stickyItemSize = 0;\r\n\r\n            if (snap) {\r\n                for (let i = Math.min(itemsFromStartToScrollEnd > 0 ? itemsFromStartToScrollEnd : 0, totalLength - 1); i >= 0; i--) {\r\n                    const id = items[i].id, sticky = stickyMap[id], size = dynamicSize ? this.get(id)?.[sizeProperty] || typicalItemSize : typicalItemSize;\r\n                    if (sticky > 0) {\r\n                        const measures = {\r\n                            x: isVertical ? 0 : actualSnippedPosition,\r\n                            y: isVertical ? actualSnippedPosition : 0,\r\n                            width: normalizedItemWidth,\r\n                            height: normalizedItemHeight,\r\n                        }, config = {\r\n                            isVertical,\r\n                            sticky,\r\n                            snap,\r\n                            snapped: true,\r\n                            snappedOut: false,\r\n                            dynamic: dynamicSize,\r\n                        };\r\n\r\n                        const itemData: I = items[i];\r\n\r\n                        stickyItem = { id, measures, data: itemData, config };\r\n                        stickyItemIndex = i;\r\n                        stickyItemSize = size;\r\n\r\n                        displayItems.push(stickyItem);\r\n                        break;\r\n                    }\r\n                }\r\n            }\r\n\r\n            let i = startIndex;\r\n\r\n            while (renderItems > 0) {\r\n                if (i >= totalLength) {\r\n                    break;\r\n                }\r\n\r\n                const id = items[i].id, size = dynamicSize ? this.get(id)?.[sizeProperty] || typicalItemSize : typicalItemSize;\r\n\r\n                if (id !== stickyItem?.id) {\r\n                    const snapped = snap && stickyMap[id] > 0 && pos <= scrollSize,\r\n                        measures = {\r\n                            x: isVertical ? 0 : pos,\r\n                            y: isVertical ? pos : 0,\r\n                            width: normalizedItemWidth,\r\n                            height: normalizedItemHeight,\r\n                        }, config = {\r\n                            isVertical,\r\n                            sticky: stickyMap[id],\r\n                            snap,\r\n                            snapped: false,\r\n                            snappedOut: false,\r\n                            dynamic: dynamicSize,\r\n                        };\r\n\r\n                    const itemData: I = items[i];\r\n\r\n                    const item: IRenderVirtualListItem = { id, measures, data: itemData, config };\r\n                    if (!nextSticky && stickyItemIndex < i && stickyMap[id] > 0 && pos <= scrollSize + size + stickyItemSize) {\r\n                        item.measures.x = isVertical ? 0 : snapped ? actualSnippedPosition : pos;\r\n                        item.measures.y = isVertical ? snapped ? actualSnippedPosition : pos : 0;\r\n                        nextSticky = item;\r\n                        nextSticky.config.snapped = snapped;\r\n                    }\r\n                    displayItems.push(item);\r\n                }\r\n\r\n                renderItems -= 1;\r\n                pos += size;\r\n                i++;\r\n            }\r\n\r\n            const axis = isVertical ? Y_PROP_NAME : X_PROP_NAME;\r\n\r\n            if (nextSticky && stickyItem && nextSticky.measures[axis] <= scrollSize + stickyItemSize) {\r\n                if (nextSticky.measures[axis] > scrollSize) {\r\n                    stickyItem.measures[axis] = nextSticky.measures[axis] - stickyItemSize;\r\n                    stickyItem.config.snapped = nextSticky.config.snapped = false;\r\n                    stickyItem.config.snappedOut = true;\r\n                    stickyItem.config.sticky = 1;\r\n                } else {\r\n                    nextSticky.config.snapped = true;\r\n                }\r\n            }\r\n        }\r\n        return displayItems;\r\n    }\r\n\r\n    /**\r\n     * tracking by propName\r\n     */\r\n    track(): void {\r\n        if (!this._items || !this._displayComponents) {\r\n            return;\r\n        }\r\n\r\n        this._tracker.track(this._items, this._displayComponents);\r\n    }\r\n\r\n    setDisplayObjectIndexMapById(v: { [id: number]: number }): void {\r\n        this._tracker.displayObjectIndexMapById = v;\r\n    }\r\n\r\n    untrackComponentByIdProperty(component?: NgVirtualListItemComponent | undefined) {\r\n        this._tracker.untrackComponentByIdProperty(component);\r\n    }\r\n\r\n    getItemBounds(id: Id): IRect | undefined {\r\n        if (this.has(id)) {\r\n            return this.get(id);\r\n        }\r\n        return undefined;\r\n    }\r\n\r\n    protected cacheElements(): void {\r\n        if (!this._displayComponents) {\r\n            return;\r\n        }\r\n\r\n        for (let i = 0, l = this._displayComponents.length; i < l; i++) {\r\n            const component = this._displayComponents[i], itemId = component.instance.itemId;\r\n            if (itemId === undefined) {\r\n                continue;\r\n            }\r\n            const bounds = component.instance.getBounds();\r\n            this.set(itemId, bounds);\r\n        }\r\n    }\r\n\r\n    override dispose() {\r\n        super.dispose();\r\n\r\n        if (this._debounceChanges) {\r\n            this._debounceChanges.dispose();\r\n        }\r\n\r\n        if (this._tracker) {\r\n            this._tracker.dispose();\r\n        }\r\n    }\r\n}\r\n"]}
535
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"trackBox.js","sourceRoot":"","sources":["../../../../../projects/ng-virtual-list/src/lib/utils/trackBox.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef } from \"@angular/core\";\r\nimport { NgVirtualListItemComponent } from \"../components/ng-virtual-list-item.component\";\r\nimport { IRenderVirtualListCollection } from \"../models/render-collection.model\";\r\nimport { IRenderVirtualListItem } from \"../models/render-item.model\";\r\nimport { Id } from \"../types/id\";\r\nimport { IRect } from \"../types/rect\";\r\nimport { CacheMap } from \"./cacheMap\";\r\nimport { Tracker } from \"./tracker\";\r\nimport { ISize } from \"../types\";\r\nimport { debounce } from \"./debounce\";\r\nimport { DEFAULT_ITEMS_OFFSET, HEIGHT_PROP_NAME, WIDTH_PROP_NAME, X_PROP_NAME, Y_PROP_NAME } from \"../const\";\r\nimport { IVirtualListStickyMap } from \"../models\";\r\n\r\nexport const TRACK_BOX_CHANGE_EVENT_NAME = 'change';\r\n\r\nexport interface IMetrics {\r\n    delta: number;\r\n    normalizedItemWidth: number;\r\n    normalizedItemHeight: number;\r\n    width: number;\r\n    height: number;\r\n    dynamicSize: boolean;\r\n    itemSize: number;\r\n    itemsFromStartToScrollEnd: number;\r\n    itemsFromStartToDisplayEnd: number;\r\n    itemsOnDisplay: number;\r\n    itemsOnDisplayLength: number;\r\n    isVertical: boolean;\r\n    leftHiddenItemsWeight: number;\r\n    leftItemLength: number;\r\n    leftItemsWeight: number;\r\n    renderItems: number;\r\n    rightItemLength: number;\r\n    rightItemsWeight: number;\r\n    scrollSize: number;\r\n    leftSizeOfAddedItems: number;\r\n    rightSizeOfAddedItems: number;\r\n    sizeProperty: typeof HEIGHT_PROP_NAME | typeof WIDTH_PROP_NAME;\r\n    snap: boolean;\r\n    snippedPos: number;\r\n    startIndex: number;\r\n    startPosition: number;\r\n    totalItemsToDisplayEndWeight: number;\r\n    totalLength: number;\r\n    totalSize: number;\r\n    typicalItemSize: number;\r\n}\r\n\r\nexport interface IRecalculateMetricsOptions<I extends { id: Id }, C extends Array<I>> {\r\n    bounds: ISize;\r\n    collection: C;\r\n    isVertical: boolean;\r\n    itemSize: number;\r\n    itemsOffset: number;\r\n    dynamicSize: boolean;\r\n    scrollSize: number;\r\n    snap: boolean;\r\n    enabledBufferOptimization: boolean;\r\n    fromItemId?: Id;\r\n}\r\n\r\ntype CacheMapEvents = typeof TRACK_BOX_CHANGE_EVENT_NAME;\r\n\r\ntype OnChangeEventListener = (version: number) => void;\r\n\r\ntype CacheMapListeners = OnChangeEventListener;\r\n\r\nenum ItemDisplayMethods {\r\n    CREATE,\r\n    UPDATE,\r\n    DELETE,\r\n    NOT_CHANGED,\r\n}\r\n\r\n/**\r\n * An object that performs tracking, calculations and caching.\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/utils/trackBox.ts\r\n * @author Evgenii Grebennikov\r\n * @email djonnyx@gmail.com\r\n */\r\nexport class TrackBox extends CacheMap<Id, IRect & { method?: ItemDisplayMethods }, CacheMapEvents, CacheMapListeners> {\r\n    protected _tracker!: Tracker<IRenderVirtualListItem, NgVirtualListItemComponent>;\r\n\r\n    protected _items: IRenderVirtualListCollection | null | undefined;\r\n\r\n    set items(v: IRenderVirtualListCollection | null | undefined) {\r\n        if (this._items === v) {\r\n            return;\r\n        }\r\n\r\n        this._items = v;\r\n    }\r\n\r\n    protected _displayComponents: Array<ComponentRef<NgVirtualListItemComponent>> | null | undefined;\r\n\r\n    set displayComponents(v: Array<ComponentRef<NgVirtualListItemComponent>> | null | undefined) {\r\n        if (this._displayComponents === v) {\r\n            return;\r\n        }\r\n\r\n        this._displayComponents = v;\r\n    }\r\n\r\n    /**\r\n     * Set the trackBy property\r\n     */\r\n    set trackingPropertyName(v: string) {\r\n        this._tracker.trackingPropertyName = v;\r\n    }\r\n\r\n    constructor(trackingPropertyName: string) {\r\n        super();\r\n\r\n        this._tracker = new Tracker(trackingPropertyName);\r\n    }\r\n\r\n    override set(id: Id, bounds: IRect): Map<Id, IRect> {\r\n        if (this._map.has(id)) {\r\n            const b = this._map.get(id);\r\n            if (b?.width === bounds.width && b.height === bounds.height) {\r\n                return this._map;\r\n            }\r\n        }\r\n\r\n        const v = this._map.set(id, bounds);\r\n\r\n        this.bumpVersion();\r\n\r\n        this.fireChange();\r\n\r\n        return v;\r\n    }\r\n\r\n    private _fireChanges = (version: number) => {\r\n        this.dispatch(TRACK_BOX_CHANGE_EVENT_NAME, version);\r\n    };\r\n\r\n    private _previousCollection: Array<{ id: Id }> | null | undefined;\r\n\r\n    private _debounceChanges = debounce(this._fireChanges, 0);\r\n\r\n    protected override fireChange() {\r\n        this._debounceChanges.execute(this._version);\r\n    }\r\n\r\n    /**\r\n     * Scans the collection for deleted items and flushes the deleted item cache.\r\n     */\r\n    resetCollection<I extends { id: Id }, C extends Array<I>>(currentCollection: C | null | undefined, itemSize: number): void {\r\n        if (currentCollection !== undefined && currentCollection !== null && currentCollection === this._previousCollection) {\r\n            console.warn('Attention! The collection must be immutable.');\r\n            return;\r\n        }\r\n\r\n        this.updateCache(this._previousCollection, currentCollection, itemSize);\r\n\r\n        this._previousCollection = currentCollection;\r\n    }\r\n\r\n    /**\r\n     * Update the cache of items from the list\r\n     */\r\n    protected updateCache<I extends { id: Id }, C extends Array<I>>(previousCollection: C | null | undefined, currentCollection: C | null | undefined,\r\n        itemSize: number): void {\r\n        if (!currentCollection || currentCollection.length === 0) {\r\n            if (previousCollection) {\r\n                // deleted\r\n                for (let i = 0, l = previousCollection.length; i < l; i++) {\r\n                    const item = previousCollection[i], id = item.id;\r\n                    if (this._map.has(id)) {\r\n                        this._map.delete(id);\r\n                    }\r\n                }\r\n            }\r\n            return;\r\n        }\r\n        if (!previousCollection || previousCollection.length === 0) {\r\n            if (currentCollection) {\r\n                // added\r\n                for (let i = 0, l = currentCollection.length; i < l; i++) {\r\n                    const item = currentCollection[i], id = item.id;\r\n                    this._map.set(id, { x: 0, y: 0, width: itemSize, height: itemSize, method: ItemDisplayMethods.CREATE });\r\n                }\r\n            }\r\n            return;\r\n        }\r\n        const collectionDict: { [id: Id]: I } = {};\r\n        for (let i = 0, l = currentCollection.length; i < l; i++) {\r\n            const item = currentCollection[i];\r\n            if (item) {\r\n                collectionDict[item.id] = item;\r\n            }\r\n        }\r\n        const notChangedMap: { [id: Id]: I } = {}, deletedMap: { [id: Id]: I } = {}, updatedMap: { [id: Id]: I } = {};\r\n        for (let i = 0, l = previousCollection.length; i < l; i++) {\r\n            const item = previousCollection[i], id = item.id;\r\n            if (item) {\r\n                if (collectionDict.hasOwnProperty(id)) {\r\n                    if (item === collectionDict[id]) {\r\n                        // not changed\r\n                        notChangedMap[item.id] = item;\r\n                        this._map.set(id, { ...(this._map.get(id) || { x: 0, y: 0, width: itemSize, height: itemSize }), method: ItemDisplayMethods.NOT_CHANGED });\r\n                        continue;\r\n                    } else {\r\n                        // updated\r\n                        updatedMap[item.id] = item;\r\n                        this._map.set(id, { ...(this._map.get(id) || { x: 0, y: 0, width: itemSize, height: itemSize }), method: ItemDisplayMethods.UPDATE });\r\n                        continue;\r\n                    }\r\n                }\r\n\r\n                // deleted\r\n                deletedMap[item.id] = item;\r\n                this._map.delete(id);\r\n            }\r\n        }\r\n\r\n        for (let i = 0, l = currentCollection.length; i < l; i++) {\r\n            const item = currentCollection[i], id = item.id;\r\n            if (item && !deletedMap.hasOwnProperty(id) && !updatedMap.hasOwnProperty(id) && !notChangedMap.hasOwnProperty(id)) {\r\n                // added\r\n                this._map.set(id, { x: 0, y: 0, width: itemSize, height: itemSize, method: ItemDisplayMethods.CREATE });\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Finds the position of a collection element by the given Id\r\n     */\r\n    getItemPosition<I extends { id: Id }, C extends Array<I>>(id: Id, stickyMap: IVirtualListStickyMap, options: IRecalculateMetricsOptions<I, C>): number {\r\n        const opt = { fromItemId: id, stickyMap, ...options };\r\n        const { scrollSize } = this.recalculateMetrics(opt);\r\n        return scrollSize;\r\n    }\r\n\r\n    /**\r\n     * Updates the collection of display objects\r\n     */\r\n    updateCollection<I extends { id: Id }, C extends Array<I>>(items: C, stickyMap: IVirtualListStickyMap,\r\n        options: Omit<IRecalculateMetricsOptions<I, C>, 'collection'>): { displayItems: IRenderVirtualListCollection; totalSize: number; delta: number; } {\r\n        const opt = { stickyMap, ...options };\r\n\r\n        this.cacheElements();\r\n\r\n        const metrics = this.recalculateMetrics({\r\n            ...opt,\r\n            collection: items,\r\n        });\r\n\r\n        this._delta += metrics.delta;\r\n\r\n        this.snapshot();\r\n\r\n        const displayItems = this.generateDisplayCollection(items, stickyMap, metrics);\r\n        return { displayItems, totalSize: metrics.totalSize, delta: metrics.delta };\r\n    }\r\n\r\n    /**\r\n     * Finds the closest element in the collection by scrollSize\r\n     */\r\n    getNearestItem<I extends { id: Id }, C extends Array<I>>(scrollSize: number, items: C, itemSize: number, isVertical: boolean): I | undefined {\r\n        return this.getElementFromStart(scrollSize, items, this._map, itemSize, isVertical);\r\n    }\r\n\r\n    /**\r\n     * Calculates the position of an element based on the given scrollSize\r\n     */\r\n    private getElementFromStart<I extends { id: Id }, C extends Array<I>>(scrollSize: number, collection: C, map: Map<Id, IRect>, typicalItemSize: number,\r\n        isVertical: boolean): I | undefined {\r\n        const sizeProperty = isVertical ? HEIGHT_PROP_NAME : WIDTH_PROP_NAME;\r\n        let offset = 0;\r\n        for (let i = 0, l = collection.length; i < l; i++) {\r\n            const item = collection[i];\r\n            let itemSize = 0;\r\n            if (map.has(item.id)) {\r\n                const bounds = map.get(item.id);\r\n                itemSize = bounds ? bounds[sizeProperty] : typicalItemSize;\r\n            } else {\r\n                itemSize = typicalItemSize;\r\n            }\r\n            if (offset > scrollSize) {\r\n                return item;\r\n            }\r\n            offset += itemSize;\r\n        }\r\n        return undefined;\r\n    }\r\n\r\n    /**\r\n     * Calculates the entry into the overscroll area and returns the number of overscroll elements\r\n     */\r\n    private getElementNumToEnd<I extends { id: Id }, C extends Array<I>>(i: number, collection: C, map: Map<Id, IRect>, typicalItemSize: number,\r\n        size: number, isVertical: boolean, indexOffset: number = 0): { num: number, offset: number } {\r\n        const sizeProperty = isVertical ? HEIGHT_PROP_NAME : WIDTH_PROP_NAME;\r\n        let offset = 0, num = 0;\r\n        for (let j = collection.length - indexOffset - 1; j >= i; j--) {\r\n            const item = collection[j];\r\n            let itemSize = 0;\r\n            if (map.has(item.id)) {\r\n                const bounds = map.get(item.id);\r\n                itemSize = bounds ? bounds[sizeProperty] : typicalItemSize;\r\n            } else {\r\n                itemSize = typicalItemSize;\r\n            }\r\n            offset += itemSize;\r\n            num++;\r\n            if (offset > size) {\r\n                return { num: 0, offset };\r\n            }\r\n        }\r\n        return { num, offset };\r\n    }\r\n\r\n    /**\r\n     * Calculates list metrics\r\n     */\r\n    protected recalculateMetrics<I extends { id: Id }, C extends Array<I>>(options: IRecalculateMetricsOptions<I, C>): IMetrics {\r\n        const { fromItemId, bounds, collection, dynamicSize, isVertical, itemSize,\r\n            itemsOffset, scrollSize, snap, stickyMap, enabledBufferOptimization } = options as IRecalculateMetricsOptions<I, C> & {\r\n                stickyMap: IVirtualListStickyMap,\r\n            };\r\n\r\n        const { width, height } = bounds, sizeProperty = isVertical ? HEIGHT_PROP_NAME : WIDTH_PROP_NAME, size = isVertical ? height : width,\r\n            totalLength = collection.length, typicalItemSize = itemSize,\r\n            w = isVertical ? width : typicalItemSize, h = isVertical ? typicalItemSize : height,\r\n            map = this._map, snapshot = this._snapshot,\r\n            leftItemsOffset = enabledBufferOptimization ? this.deltaDirection === 1 ? DEFAULT_ITEMS_OFFSET : itemsOffset : itemsOffset,\r\n            rightItemsOffset = enabledBufferOptimization ? this.deltaDirection === -1 ? DEFAULT_ITEMS_OFFSET : itemsOffset : itemsOffset,\r\n            checkOverscrollItemsLimit = Math.ceil(size / typicalItemSize),\r\n            snippedPos = Math.floor(scrollSize),\r\n            leftItemsWeights: Array<number> = [],\r\n            isFromId = fromItemId !== undefined && (typeof fromItemId === 'number' && fromItemId > -1)\r\n                || (typeof fromItemId === 'string' && fromItemId > '-1');\r\n\r\n        let itemsFromStartToScrollEnd: number = -1, itemsFromDisplayEndToOffsetEnd = 0, itemsFromStartToDisplayEnd = -1,\r\n            leftItemLength = 0, rightItemLength = 0,\r\n            leftItemsWeight = 0, rightItemsWeight = 0,\r\n            leftHiddenItemsWeight = 0,\r\n            totalItemsToDisplayEndWeight = 0,\r\n            rightSizeOfAddedItems = 0,\r\n            leftSizeOfAddedItems = 0,\r\n            rightSizeOfUpdatedItems = 0,\r\n            leftSizeOfUpdatedItems = 0,\r\n            itemById: I | undefined = undefined,\r\n            itemByIdPos: number = 0,\r\n            targetDisplayItemIndex: number = -1,\r\n            isTargetInOverscroll: boolean = false,\r\n            actualScrollSize = itemByIdPos,\r\n            totalSize = 0,\r\n            startIndex;\r\n\r\n        // If the list is dynamic or there are new elements in the collection, then it switches to the long algorithm.\r\n        if (dynamicSize) {\r\n            let y = 0, stickyCollectionItem: I | undefined = undefined, stickyComponentSize = 0;\r\n            for (let i = 0, l = collection.length; i < l; i++) {\r\n                const ii = i + 1, collectionItem = collection[i], id = collectionItem.id;\r\n\r\n                let componentSize = 0, componentSizeDelta = 0, itemDisplayMethod: ItemDisplayMethods = ItemDisplayMethods.NOT_CHANGED;\r\n                if (map.has(id)) {\r\n                    const bounds = map.get(id) || { x: 0, y: 0, width: typicalItemSize, height: typicalItemSize };\r\n                    componentSize = bounds[sizeProperty];\r\n\r\n                    itemDisplayMethod = bounds?.method ?? ItemDisplayMethods.UPDATE;\r\n                    if (itemDisplayMethod === ItemDisplayMethods.UPDATE) {\r\n                        const snapshotBounds = snapshot.get(id);\r\n                        const componentSnapshotSize = componentSize - (snapshotBounds ? snapshotBounds[sizeProperty] : typicalItemSize);\r\n                        componentSizeDelta = componentSnapshotSize;\r\n                        map.set(id, { ...bounds, method: ItemDisplayMethods.NOT_CHANGED });\r\n                    }\r\n                    if (itemDisplayMethod === ItemDisplayMethods.CREATE) {\r\n                        componentSizeDelta = typicalItemSize;\r\n                        map.set(id, { ...bounds, method: ItemDisplayMethods.NOT_CHANGED });\r\n                    }\r\n                } else {\r\n                    componentSize = typicalItemSize;\r\n                    if (snapshot.has(id)) {\r\n                        itemDisplayMethod = ItemDisplayMethods.DELETE;\r\n                    }\r\n                }\r\n\r\n                totalSize += componentSize;\r\n\r\n                if (isFromId) {\r\n                    if (itemById === undefined) {\r\n                        if (id !== fromItemId && stickyMap && stickyMap[id] > 0) {\r\n                            stickyComponentSize = componentSize;\r\n                            stickyCollectionItem = collectionItem;\r\n                        }\r\n\r\n                        if (id === fromItemId) {\r\n                            targetDisplayItemIndex = i;\r\n                            if (stickyCollectionItem && stickyMap && stickyMap[stickyCollectionItem.id] > 0) {\r\n                                const { num } = this.getElementNumToEnd(i, collection, map, typicalItemSize, size, isVertical);\r\n                                if (num > 0) {\r\n                                    isTargetInOverscroll = true;\r\n                                    y -= size - componentSize;\r\n                                } else {\r\n                                    y -= stickyComponentSize;\r\n                                    leftHiddenItemsWeight -= stickyComponentSize;\r\n                                }\r\n                            }\r\n                            itemById = collectionItem;\r\n                            itemByIdPos = y;\r\n                        } else {\r\n                            leftItemsWeights.push(componentSize);\r\n                            leftHiddenItemsWeight += componentSize;\r\n                            itemsFromStartToScrollEnd = ii;\r\n                        }\r\n                    }\r\n                } else if (y < scrollSize - componentSize) {\r\n                    leftItemsWeights.push(componentSize);\r\n                    leftHiddenItemsWeight += componentSize;\r\n                    itemsFromStartToScrollEnd = ii;\r\n                }\r\n\r\n                if (isFromId) {\r\n                    if (itemById === undefined || y < itemByIdPos + size + componentSize) {\r\n                        itemsFromStartToDisplayEnd = ii;\r\n                        totalItemsToDisplayEndWeight += componentSize;\r\n                        itemsFromDisplayEndToOffsetEnd = itemsFromStartToDisplayEnd + rightItemsOffset;\r\n                    }\r\n                    if (y > itemByIdPos + size + componentSize) {\r\n                        if (itemDisplayMethod === ItemDisplayMethods.UPDATE) {\r\n                            rightSizeOfAddedItems += componentSizeDelta;\r\n                        }\r\n                    }\r\n                } else if (y < scrollSize + size + componentSize) {\r\n                    itemsFromStartToDisplayEnd = ii;\r\n                    totalItemsToDisplayEndWeight += componentSize;\r\n                    itemsFromDisplayEndToOffsetEnd = itemsFromStartToDisplayEnd + rightItemsOffset;\r\n\r\n                    if (y < scrollSize - componentSize) {\r\n                        if (itemDisplayMethod === ItemDisplayMethods.UPDATE) {\r\n                            leftSizeOfUpdatedItems += componentSizeDelta;\r\n                        }\r\n                        if (itemDisplayMethod === ItemDisplayMethods.CREATE) {\r\n                            leftSizeOfAddedItems += componentSizeDelta;\r\n                        }\r\n                    }\r\n                } else {\r\n                    if (i < itemsFromDisplayEndToOffsetEnd) {\r\n                        rightItemsWeight += componentSize;\r\n                    }\r\n                    if (itemDisplayMethod === ItemDisplayMethods.UPDATE) {\r\n                        rightSizeOfUpdatedItems += componentSizeDelta;\r\n                    }\r\n                    if (itemDisplayMethod === ItemDisplayMethods.CREATE) {\r\n                        rightSizeOfAddedItems += componentSizeDelta;\r\n                    }\r\n                }\r\n\r\n                y += componentSize;\r\n            }\r\n\r\n            if (isTargetInOverscroll) {\r\n                const { num } = this.getElementNumToEnd(\r\n                    collection.length - (checkOverscrollItemsLimit < 0 ? 0 : collection.length - checkOverscrollItemsLimit),\r\n                    collection, map, typicalItemSize, size, isVertical, collection.length - (collection.length - (targetDisplayItemIndex + 1)),\r\n                );\r\n                if (num > 0) {\r\n                    itemsFromStartToScrollEnd -= num;\r\n                }\r\n            }\r\n\r\n            if (itemsFromStartToScrollEnd <= -1) {\r\n                itemsFromStartToScrollEnd = 0;\r\n            }\r\n            if (itemsFromStartToDisplayEnd <= -1) {\r\n                itemsFromStartToDisplayEnd = 0;\r\n            }\r\n            actualScrollSize = isFromId ? itemByIdPos : scrollSize;\r\n\r\n            leftItemsWeights.splice(0, leftItemsWeights.length - leftItemsOffset);\r\n            leftItemsWeights.forEach(v => {\r\n                leftItemsWeight += v;\r\n            });\r\n\r\n            leftItemLength = Math.min(itemsFromStartToScrollEnd, leftItemsOffset);\r\n            rightItemLength = itemsFromStartToDisplayEnd + rightItemsOffset > totalLength\r\n                ? totalLength - itemsFromStartToDisplayEnd : rightItemsOffset;\r\n        } else\r\n        // Buffer optimization does not work on fast linear algorithm\r\n        {\r\n            itemsFromStartToScrollEnd = Math.floor(scrollSize / typicalItemSize);\r\n            itemsFromStartToDisplayEnd = Math.ceil((scrollSize + size) / typicalItemSize);\r\n            leftItemLength = Math.min(itemsFromStartToScrollEnd, itemsOffset);\r\n            rightItemLength = itemsFromStartToDisplayEnd + itemsOffset > totalLength\r\n                ? totalLength - itemsFromStartToDisplayEnd : itemsOffset;\r\n            leftItemsWeight = leftItemLength * typicalItemSize;\r\n            rightItemsWeight = rightItemLength * typicalItemSize,\r\n                leftHiddenItemsWeight = itemsFromStartToScrollEnd * typicalItemSize,\r\n                totalItemsToDisplayEndWeight = itemsFromStartToDisplayEnd * typicalItemSize;\r\n            actualScrollSize = scrollSize;\r\n            totalSize = totalLength * typicalItemSize;\r\n        }\r\n        startIndex = Math.min(itemsFromStartToScrollEnd - leftItemLength, totalLength > 0 ? totalLength - 1 : 0);\r\n\r\n        const itemsOnDisplay = totalItemsToDisplayEndWeight - leftHiddenItemsWeight,\r\n            itemsOnDisplayLength = itemsFromStartToDisplayEnd - itemsFromStartToScrollEnd,\r\n            startPosition = leftHiddenItemsWeight - leftItemsWeight,\r\n            renderItems = itemsOnDisplayLength + leftItemLength + rightItemLength,\r\n            delta = leftSizeOfUpdatedItems + leftSizeOfAddedItems;\r\n\r\n        const metrics: IMetrics = {\r\n            delta,\r\n            normalizedItemWidth: w,\r\n            normalizedItemHeight: h,\r\n            width,\r\n            height,\r\n            dynamicSize,\r\n            itemSize,\r\n            itemsFromStartToScrollEnd,\r\n            itemsFromStartToDisplayEnd,\r\n            itemsOnDisplay,\r\n            itemsOnDisplayLength,\r\n            isVertical,\r\n            leftHiddenItemsWeight,\r\n            leftItemLength,\r\n            leftItemsWeight,\r\n            renderItems,\r\n            rightItemLength,\r\n            rightItemsWeight,\r\n            scrollSize: actualScrollSize,\r\n            leftSizeOfAddedItems,\r\n            rightSizeOfAddedItems,\r\n            sizeProperty,\r\n            snap,\r\n            snippedPos,\r\n            startIndex,\r\n            startPosition,\r\n            totalItemsToDisplayEndWeight,\r\n            totalLength,\r\n            totalSize,\r\n            typicalItemSize,\r\n        };\r\n\r\n        return metrics;\r\n    }\r\n\r\n    protected _scrollDelta: number = 0;\r\n    get scrollDelta() { return this._scrollDelta; }\r\n\r\n    clearDeltaDirection() {\r\n        this.clearScrollDirectionCache();\r\n    }\r\n\r\n    clearDelta(clearDirectionDetector = false): void {\r\n        this._delta = 0;\r\n\r\n        if (clearDirectionDetector) {\r\n            this.clearScrollDirectionCache();\r\n        }\r\n    }\r\n\r\n    changes(): void {\r\n        this.bumpVersion();\r\n\r\n        this.fireChange();\r\n    }\r\n\r\n    protected generateDisplayCollection<I extends { id: Id }, C extends Array<I>>(items: C, stickyMap: IVirtualListStickyMap,\r\n        metrics: IMetrics): IRenderVirtualListCollection {\r\n        const {\r\n            normalizedItemWidth,\r\n            normalizedItemHeight,\r\n            dynamicSize,\r\n            itemsFromStartToScrollEnd,\r\n            isVertical,\r\n            renderItems: renderItemsLength,\r\n            scrollSize,\r\n            sizeProperty,\r\n            snap,\r\n            snippedPos,\r\n            startPosition,\r\n            totalLength,\r\n            startIndex,\r\n            typicalItemSize,\r\n        } = metrics,\r\n            displayItems: IRenderVirtualListCollection = [];\r\n        if (items.length) {\r\n            const actualSnippedPosition = snippedPos;\r\n            let pos = startPosition,\r\n                renderItems = renderItemsLength,\r\n                stickyItem: IRenderVirtualListItem | undefined, nextSticky: IRenderVirtualListItem | undefined, stickyItemIndex = -1,\r\n                stickyItemSize = 0;\r\n\r\n            if (snap) {\r\n                for (let i = Math.min(itemsFromStartToScrollEnd > 0 ? itemsFromStartToScrollEnd : 0, totalLength - 1); i >= 0; i--) {\r\n                    const id = items[i].id, sticky = stickyMap[id], size = dynamicSize ? this.get(id)?.[sizeProperty] || typicalItemSize : typicalItemSize;\r\n                    if (sticky > 0) {\r\n                        const measures = {\r\n                            x: isVertical ? 0 : actualSnippedPosition,\r\n                            y: isVertical ? actualSnippedPosition : 0,\r\n                            width: normalizedItemWidth,\r\n                            height: normalizedItemHeight,\r\n                        }, config = {\r\n                            isVertical,\r\n                            sticky,\r\n                            snap,\r\n                            snapped: true,\r\n                            snappedOut: false,\r\n                            dynamic: dynamicSize,\r\n                        };\r\n\r\n                        const itemData: I = items[i];\r\n\r\n                        stickyItem = { id, measures, data: itemData, config };\r\n                        stickyItemIndex = i;\r\n                        stickyItemSize = size;\r\n\r\n                        displayItems.push(stickyItem);\r\n                        break;\r\n                    }\r\n                }\r\n            }\r\n\r\n            let i = startIndex;\r\n\r\n            while (renderItems > 0) {\r\n                if (i >= totalLength) {\r\n                    break;\r\n                }\r\n\r\n                const id = items[i].id, size = dynamicSize ? this.get(id)?.[sizeProperty] || typicalItemSize : typicalItemSize;\r\n\r\n                if (id !== stickyItem?.id) {\r\n                    const snapped = snap && stickyMap[id] > 0 && pos <= scrollSize,\r\n                        measures = {\r\n                            x: isVertical ? 0 : pos,\r\n                            y: isVertical ? pos : 0,\r\n                            width: normalizedItemWidth,\r\n                            height: normalizedItemHeight,\r\n                        }, config = {\r\n                            isVertical,\r\n                            sticky: stickyMap[id],\r\n                            snap,\r\n                            snapped: false,\r\n                            snappedOut: false,\r\n                            dynamic: dynamicSize,\r\n                        };\r\n\r\n                    const itemData: I = items[i];\r\n\r\n                    const item: IRenderVirtualListItem = { id, measures, data: itemData, config };\r\n                    if (!nextSticky && stickyItemIndex < i && stickyMap[id] > 0 && pos <= scrollSize + size + stickyItemSize) {\r\n                        item.measures.x = isVertical ? 0 : snapped ? actualSnippedPosition : pos;\r\n                        item.measures.y = isVertical ? snapped ? actualSnippedPosition : pos : 0;\r\n                        nextSticky = item;\r\n                        nextSticky.config.snapped = snapped;\r\n                    }\r\n                    displayItems.push(item);\r\n                }\r\n\r\n                renderItems -= 1;\r\n                pos += size;\r\n                i++;\r\n            }\r\n\r\n            const axis = isVertical ? Y_PROP_NAME : X_PROP_NAME;\r\n\r\n            if (nextSticky && stickyItem && nextSticky.measures[axis] <= scrollSize + stickyItemSize) {\r\n                if (nextSticky.measures[axis] > scrollSize) {\r\n                    stickyItem.measures[axis] = nextSticky.measures[axis] - stickyItemSize;\r\n                    stickyItem.config.snapped = nextSticky.config.snapped = false;\r\n                    stickyItem.config.snappedOut = true;\r\n                    stickyItem.config.sticky = 1;\r\n                } else {\r\n                    nextSticky.config.snapped = true;\r\n                }\r\n            }\r\n        }\r\n        return displayItems;\r\n    }\r\n\r\n    /**\r\n     * tracking by propName\r\n     */\r\n    track(): void {\r\n        if (!this._items || !this._displayComponents) {\r\n            return;\r\n        }\r\n\r\n        this._tracker.track(this._items, this._displayComponents);\r\n    }\r\n\r\n    setDisplayObjectIndexMapById(v: { [id: number]: number }): void {\r\n        this._tracker.displayObjectIndexMapById = v;\r\n    }\r\n\r\n    untrackComponentByIdProperty(component?: NgVirtualListItemComponent | undefined) {\r\n        this._tracker.untrackComponentByIdProperty(component);\r\n    }\r\n\r\n    getItemBounds(id: Id): IRect | undefined {\r\n        if (this.has(id)) {\r\n            return this.get(id);\r\n        }\r\n        return undefined;\r\n    }\r\n\r\n    protected cacheElements(): void {\r\n        if (!this._displayComponents) {\r\n            return;\r\n        }\r\n\r\n        for (let i = 0, l = this._displayComponents.length; i < l; i++) {\r\n            const component = this._displayComponents[i], itemId = component.instance.itemId;\r\n            if (itemId === undefined) {\r\n                continue;\r\n            }\r\n            const bounds = component.instance.getBounds();\r\n            this.set(itemId, bounds);\r\n        }\r\n    }\r\n\r\n    override dispose() {\r\n        super.dispose();\r\n\r\n        if (this._debounceChanges) {\r\n            this._debounceChanges.dispose();\r\n        }\r\n\r\n        if (this._tracker) {\r\n            this._tracker.dispose();\r\n        }\r\n    }\r\n}\r\n"]}
@@ -26,6 +26,9 @@ export class Tracker {
26
26
  return this._trackMap;
27
27
  }
28
28
  _trackingPropertyName;
29
+ set trackingPropertyName(v) {
30
+ this._trackingPropertyName = v;
31
+ }
29
32
  constructor(trackingPropertyName) {
30
33
  this._trackingPropertyName = trackingPropertyName;
31
34
  }
@@ -43,17 +46,17 @@ export class Tracker {
43
46
  const diId = this._trackMap[itemTrackingProperty];
44
47
  if (this._trackMap.hasOwnProperty(itemTrackingProperty)) {
45
48
  const lastIndex = this._displayObjectIndexMapById[diId], el = components[lastIndex];
46
- this._checkComponentProperty(el?.instance);
47
- const elId = el?.instance?.[itemTrackingProperty];
49
+ const elId = el?.instance?.id;
48
50
  if (el && elId === diId) {
49
51
  const indexByUntrackedItems = untrackedItems.findIndex(v => {
50
- this._checkComponentProperty(v.instance);
51
- return v.instance[itemTrackingProperty] === elId;
52
+ return v.instance.id === elId;
52
53
  });
53
54
  if (indexByUntrackedItems > -1) {
54
- el.instance.item = item;
55
- if (afterComponentSetup !== undefined) {
56
- afterComponentSetup(el.instance, item);
55
+ if (el.instance.item !== item) {
56
+ el.instance.item = item;
57
+ if (afterComponentSetup !== undefined) {
58
+ afterComponentSetup(el.instance, item);
59
+ }
57
60
  }
58
61
  untrackedItems.splice(indexByUntrackedItems, 1);
59
62
  continue;
@@ -65,13 +68,14 @@ export class Tracker {
65
68
  if (untrackedItems.length > 0) {
66
69
  const el = untrackedItems.shift(), item = items[i];
67
70
  if (el) {
68
- el.instance.item = item;
69
- if (this._trackMap) {
70
- this._checkComponentProperty(el.instance);
71
- this._trackMap[itemTrackingProperty] = el.instance[itemTrackingProperty];
72
- }
73
- if (afterComponentSetup !== undefined) {
74
- afterComponentSetup(el.instance, item);
71
+ if (el.instance.item !== item) {
72
+ el.instance.item = item;
73
+ if (this._trackMap) {
74
+ this._trackMap[itemTrackingProperty] = el.instance.id;
75
+ }
76
+ if (afterComponentSetup !== undefined) {
77
+ afterComponentSetup(el.instance, item);
78
+ }
75
79
  }
76
80
  }
77
81
  }
@@ -85,25 +89,12 @@ export class Tracker {
85
89
  return;
86
90
  }
87
91
  const propertyIdName = this._trackingPropertyName;
88
- this._checkComponentProperty(component);
89
92
  if (this._trackMap && component[propertyIdName] !== undefined) {
90
93
  delete this._trackMap[propertyIdName];
91
94
  }
92
95
  }
93
- _checkComponentProperty(component) {
94
- if (!component) {
95
- return;
96
- }
97
- const propertyIdName = this._trackingPropertyName;
98
- try {
99
- component[propertyIdName];
100
- }
101
- catch (err) {
102
- throw Error(`Property ${propertyIdName} does not exist.`);
103
- }
104
- }
105
96
  dispose() {
106
97
  this._trackMap = null;
107
98
  }
108
99
  }
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tracker.js","sourceRoot":"","sources":["../../../../../projects/ng-virtual-list/src/lib/utils/tracker.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef } from \"@angular/core\";\r\n\r\ntype TrackingPropertyId = string | number;\r\n\r\n/**\r\n * Tracks display items by property\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/utils/tracker.ts\r\n * @author Evgenii Grebennikov\r\n * @email djonnyx@gmail.com\r\n */\r\nexport class Tracker<I = any, C = { [prop: string]: any; }> {\r\n    /**\r\n     * display objects dictionary of indexes by id\r\n     */\r\n    private _displayObjectIndexMapById: { [id: number]: number } = {};\r\n\r\n    set displayObjectIndexMapById(v: { [id: number]: number }) {\r\n        if (this._displayObjectIndexMapById === v) {\r\n            return;\r\n        }\r\n\r\n        this._displayObjectIndexMapById = v;\r\n    }\r\n\r\n    get displayObjectIndexMapById() {\r\n        return this._displayObjectIndexMapById;\r\n    }\r\n\r\n    /**\r\n     * Dictionary displayItems propertyNameId by items propertyNameId\r\n     */\r\n    private _trackMap: { [id: TrackingPropertyId]: number } | null = {};\r\n\r\n    get trackMap() {\r\n        return this._trackMap;\r\n    }\r\n\r\n    private _trackingPropertyName!: string;\r\n\r\n    constructor(trackingPropertyName: string) {\r\n        this._trackingPropertyName = trackingPropertyName;\r\n    }\r\n\r\n    /**\r\n     * tracking by propName\r\n     */\r\n    track(items: Array<any>, components: Array<ComponentRef<any>>,\r\n        afterComponentSetup?: (component: C, item: I) => void): void {\r\n        if (!items) {\r\n            return;\r\n        }\r\n\r\n        const idPropName = this._trackingPropertyName, untrackedItems = [...components];\r\n\r\n        for (let i = 0, l = items.length; i < l; i++) {\r\n            const item = items[i], itemTrackingProperty = item[idPropName];\r\n\r\n            if (this._trackMap) {\r\n                const diId = this._trackMap[itemTrackingProperty];\r\n                if (this._trackMap.hasOwnProperty(itemTrackingProperty)) {\r\n                    const lastIndex = this._displayObjectIndexMapById[diId], el = components[lastIndex];\r\n\r\n                    this._checkComponentProperty(el?.instance);\r\n\r\n                    const elId = el?.instance?.[itemTrackingProperty];\r\n                    if (el && elId === diId) {\r\n                        const indexByUntrackedItems = untrackedItems.findIndex(v => {\r\n                            this._checkComponentProperty(v.instance);\r\n\r\n                            return v.instance[itemTrackingProperty] === elId;\r\n                        });\r\n                        if (indexByUntrackedItems > -1) {\r\n                            el.instance.item = item;\r\n\r\n                            if (afterComponentSetup !== undefined) {\r\n                                afterComponentSetup(el.instance, item);\r\n                            }\r\n\r\n                            untrackedItems.splice(indexByUntrackedItems, 1);\r\n                            continue;\r\n                        }\r\n                    }\r\n                    delete this._trackMap[itemTrackingProperty];\r\n                }\r\n            }\r\n\r\n            if (untrackedItems.length > 0) {\r\n                const el = untrackedItems.shift(), item = items[i];\r\n                if (el) {\r\n                    el.instance.item = item;\r\n\r\n                    if (this._trackMap) {\r\n                        this._checkComponentProperty(el.instance);\r\n\r\n                        this._trackMap[itemTrackingProperty] = el.instance[itemTrackingProperty];\r\n                    }\r\n\r\n                    if (afterComponentSetup !== undefined) {\r\n                        afterComponentSetup(el.instance, item);\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        if (untrackedItems.length) {\r\n            throw Error('Tracking by id caused an error.')\r\n        }\r\n    }\r\n\r\n    untrackComponentByIdProperty(component?: C): void {\r\n        if (!component) {\r\n            return;\r\n        }\r\n\r\n        const propertyIdName = this._trackingPropertyName;\r\n\r\n        this._checkComponentProperty(component);\r\n\r\n        if (this._trackMap && (component as any)[propertyIdName] !== undefined) {\r\n            delete this._trackMap[propertyIdName];\r\n        }\r\n    }\r\n\r\n    private _checkComponentProperty(component?: C): void {\r\n        if (!component) {\r\n            return;\r\n        }\r\n\r\n        const propertyIdName = this._trackingPropertyName;\r\n\r\n        try {\r\n            (component as any)[propertyIdName];\r\n        } catch (err) {\r\n            throw Error(`Property ${propertyIdName} does not exist.`);\r\n        }\r\n    }\r\n\r\n    dispose() {\r\n        this._trackMap = null;\r\n    }\r\n}"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tracker.js","sourceRoot":"","sources":["../../../../../projects/ng-virtual-list/src/lib/utils/tracker.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef } from \"@angular/core\";\r\n\r\ntype TrackingPropertyId = string | number;\r\n\r\n/**\r\n * Tracks display items by property\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/18.x/projects/ng-virtual-list/src/lib/utils/tracker.ts\r\n * @author Evgenii Grebennikov\r\n * @email djonnyx@gmail.com\r\n */\r\nexport class Tracker<I = any, C = { [prop: string]: any; }> {\r\n    /**\r\n     * display objects dictionary of indexes by id\r\n     */\r\n    private _displayObjectIndexMapById: { [id: number]: number } = {};\r\n\r\n    set displayObjectIndexMapById(v: { [id: number]: number }) {\r\n        if (this._displayObjectIndexMapById === v) {\r\n            return;\r\n        }\r\n\r\n        this._displayObjectIndexMapById = v;\r\n    }\r\n\r\n    get displayObjectIndexMapById() {\r\n        return this._displayObjectIndexMapById;\r\n    }\r\n\r\n    /**\r\n     * Dictionary displayItems propertyNameId by items propertyNameId\r\n     */\r\n    private _trackMap: { [id: TrackingPropertyId]: number } | null = {};\r\n\r\n    get trackMap() {\r\n        return this._trackMap;\r\n    }\r\n\r\n    private _trackingPropertyName!: string;\r\n\r\n    set trackingPropertyName(v: string) {\r\n        this._trackingPropertyName = v;\r\n    }\r\n\r\n    constructor(trackingPropertyName: string) {\r\n        this._trackingPropertyName = trackingPropertyName;\r\n    }\r\n\r\n    /**\r\n     * tracking by propName\r\n     */\r\n    track(items: Array<any>, components: Array<ComponentRef<any>>,\r\n        afterComponentSetup?: (component: C, item: I) => void): void {\r\n        if (!items) {\r\n            return;\r\n        }\r\n\r\n        const idPropName = this._trackingPropertyName, untrackedItems = [...components];\r\n\r\n        for (let i = 0, l = items.length; i < l; i++) {\r\n            const item = items[i], itemTrackingProperty = item[idPropName];\r\n\r\n            if (this._trackMap) {\r\n                const diId = this._trackMap[itemTrackingProperty];\r\n                if (this._trackMap.hasOwnProperty(itemTrackingProperty)) {\r\n                    const lastIndex = this._displayObjectIndexMapById[diId], el = components[lastIndex];\r\n\r\n                    const elId = el?.instance?.id;\r\n                    if (el && elId === diId) {\r\n                        const indexByUntrackedItems = untrackedItems.findIndex(v => {\r\n                            return v.instance.id === elId;\r\n                        });\r\n                        if (indexByUntrackedItems > -1) {\r\n                            if (el.instance.item !== item) {\r\n                                el.instance.item = item;\r\n\r\n                                if (afterComponentSetup !== undefined) {\r\n                                    afterComponentSetup(el.instance, item);\r\n                                }\r\n                            }\r\n\r\n                            untrackedItems.splice(indexByUntrackedItems, 1);\r\n                            continue;\r\n                        }\r\n                    }\r\n                    delete this._trackMap[itemTrackingProperty];\r\n                }\r\n            }\r\n\r\n            if (untrackedItems.length > 0) {\r\n                const el = untrackedItems.shift(), item = items[i];\r\n                if (el) {\r\n                    if (el.instance.item !== item) {\r\n                        el.instance.item = item;\r\n\r\n                        if (this._trackMap) {\r\n                            this._trackMap[itemTrackingProperty] = el.instance.id;\r\n                        }\r\n\r\n                        if (afterComponentSetup !== undefined) {\r\n                            afterComponentSetup(el.instance, item);\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        if (untrackedItems.length) {\r\n            throw Error('Tracking by id caused an error.')\r\n        }\r\n    }\r\n\r\n    untrackComponentByIdProperty(component?: C): void {\r\n        if (!component) {\r\n            return;\r\n        }\r\n\r\n        const propertyIdName = this._trackingPropertyName;\r\n\r\n        if (this._trackMap && (component as any)[propertyIdName] !== undefined) {\r\n            delete this._trackMap[propertyIdName];\r\n        }\r\n    }\r\n\r\n    dispose() {\r\n        this._trackMap = null;\r\n    }\r\n}"]}