ng-virtual-list 0.7.2 → 14.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +44 -71
- package/esm2020/lib/components/ng-virtual-list-item.component.mjs +80 -0
- package/esm2020/lib/const/index.mjs +34 -0
- package/esm2020/lib/enums/direction.mjs +2 -0
- package/esm2020/lib/enums/directions.mjs +18 -0
- package/esm2020/lib/enums/index.mjs +3 -0
- package/esm2020/lib/models/collection.model.mjs +3 -0
- package/esm2020/lib/models/index.mjs +2 -0
- package/esm2020/lib/models/item.model.mjs +3 -0
- package/esm2020/lib/models/render-collection.model.mjs +3 -0
- package/esm2020/lib/models/render-item-config.model.mjs +2 -0
- package/esm2020/lib/models/render-item.model.mjs +3 -0
- package/esm2020/lib/models/sticky-map.model.mjs +2 -0
- package/esm2020/lib/ng-virtual-list.component.mjs +510 -0
- package/esm2020/lib/ng-virtual-list.module.mjs +20 -0
- package/esm2020/lib/types/id.mjs +2 -0
- package/esm2020/lib/types/index.mjs +2 -0
- package/esm2020/lib/types/rect.mjs +2 -0
- package/esm2020/lib/types/size.mjs +2 -0
- package/esm2020/lib/utils/cacheMap.mjs +52 -0
- package/esm2020/lib/utils/debounce.mjs +31 -0
- package/esm2020/lib/utils/disposableComponent.mjs +29 -0
- package/esm2020/lib/utils/eventEmitter.mjs +106 -0
- package/esm2020/lib/utils/index.mjs +8 -0
- package/esm2020/lib/utils/isDirection.mjs +15 -0
- package/esm2020/lib/utils/toggleClassName.mjs +15 -0
- package/esm2020/lib/utils/trackBox.mjs +352 -0
- package/esm2020/lib/utils/tracker.mjs +108 -0
- package/esm2020/ng-virtual-list.mjs +5 -0
- package/esm2020/public-api.mjs +8 -0
- package/fesm2015/ng-virtual-list.mjs +1360 -0
- package/fesm2015/ng-virtual-list.mjs.map +1 -0
- package/fesm2020/ng-virtual-list.mjs +1359 -0
- package/fesm2020/ng-virtual-list.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/components/ng-virtual-list-item.component.d.ts +28 -35
- package/lib/const/index.d.ts +32 -31
- package/lib/enums/direction.d.ts +8 -2
- package/lib/enums/directions.d.ts +16 -4
- package/lib/enums/index.d.ts +4 -4
- package/lib/models/collection.model.d.ts +9 -3
- package/lib/models/index.d.ts +4 -4
- package/lib/models/item.model.d.ts +14 -5
- package/lib/models/render-collection.model.d.ts +9 -3
- package/lib/models/render-item-config.model.d.ts +33 -7
- package/lib/models/render-item.model.d.ts +28 -10
- package/lib/models/sticky-map.model.d.ts +12 -6
- package/lib/ng-virtual-list.component.d.ts +151 -110
- package/lib/ng-virtual-list.module.d.ts +9 -0
- package/lib/types/id.d.ts +7 -1
- package/lib/types/index.d.ts +4 -4
- package/lib/types/rect.d.ts +17 -5
- package/lib/types/size.d.ts +16 -4
- package/lib/utils/cacheMap.d.ts +34 -31
- package/lib/utils/debounce.d.ts +16 -10
- package/lib/utils/disposableComponent.d.ts +15 -0
- package/lib/utils/eventEmitter.d.ts +40 -37
- package/lib/utils/index.d.ts +7 -6
- package/lib/utils/isDirection.d.ts +8 -2
- package/lib/utils/toggleClassName.d.ts +7 -1
- package/lib/utils/trackBox.d.ts +113 -73
- package/lib/utils/tracker.d.ts +38 -38
- package/package.json +18 -6
- package/public-api.d.ts +4 -3
- package/fesm2022/ng-virtual-list.mjs +0 -942
- package/fesm2022/ng-virtual-list.mjs.map +0 -1
|
@@ -0,0 +1,352 @@
|
|
|
1
|
+
import { CacheMap } from "./cacheMap";
|
|
2
|
+
import { Tracker } from "./tracker";
|
|
3
|
+
import { debounce } from "./debounce";
|
|
4
|
+
import { HEIGHT_PROP_NAME, WIDTH_PROP_NAME, X_PROP_NAME, Y_PROP_NAME } from "../const";
|
|
5
|
+
export const TRACK_BOX_CHANGE_EVENT_NAME = 'change';
|
|
6
|
+
/**
|
|
7
|
+
* An object that performs tracking, calculations and caching.
|
|
8
|
+
* @link https://github.com/DjonnyX/ng-virtual-list/blob/main/projects/ng-virtual-list/src/lib/utils/trackBox.ts
|
|
9
|
+
* @author Evgenii Grebennikov
|
|
10
|
+
* @email djonnyx@gmail.com
|
|
11
|
+
*/
|
|
12
|
+
export class TrackBox extends CacheMap {
|
|
13
|
+
constructor(trackingPropertyName) {
|
|
14
|
+
super();
|
|
15
|
+
this._fireChanges = (version) => {
|
|
16
|
+
this.dispatch(TRACK_BOX_CHANGE_EVENT_NAME, version);
|
|
17
|
+
};
|
|
18
|
+
this._debounceChanges = debounce(this._fireChanges, 0);
|
|
19
|
+
this._tracker = new Tracker(trackingPropertyName);
|
|
20
|
+
}
|
|
21
|
+
set items(v) {
|
|
22
|
+
if (this._items === v) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
this._items = v;
|
|
26
|
+
}
|
|
27
|
+
set displayComponents(v) {
|
|
28
|
+
if (this._displayComponents === v) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
this._displayComponents = v;
|
|
32
|
+
}
|
|
33
|
+
set(id, bounds) {
|
|
34
|
+
if (this._map.has(id) && JSON.stringify(this._map.get(id)) === JSON.stringify(bounds)) {
|
|
35
|
+
return this._map;
|
|
36
|
+
}
|
|
37
|
+
const v = this._map.set(id, bounds);
|
|
38
|
+
this.bumpVersion();
|
|
39
|
+
this.fireChange();
|
|
40
|
+
return v;
|
|
41
|
+
}
|
|
42
|
+
fireChange() {
|
|
43
|
+
this._debounceChanges.execute(this._version);
|
|
44
|
+
}
|
|
45
|
+
getItemPosition(id, stickyMap, options) {
|
|
46
|
+
const opt = { fromItemId: id, stickyMap, scrollDirection: undefined, ...options };
|
|
47
|
+
const { scrollSize } = this.recalculateMetrics(opt);
|
|
48
|
+
return scrollSize;
|
|
49
|
+
}
|
|
50
|
+
updateCollection(items, stickyMap, options) {
|
|
51
|
+
const opt = { stickyMap, scrollDirection: undefined, ...options };
|
|
52
|
+
this.cacheElements();
|
|
53
|
+
const metrics = this.recalculateMetrics({
|
|
54
|
+
...opt,
|
|
55
|
+
collection: items,
|
|
56
|
+
});
|
|
57
|
+
const displayItems = this.generateDisplayCollection(items, stickyMap, metrics);
|
|
58
|
+
return { displayItems, totalSize: metrics.totalSize, delta: metrics.delta };
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Calculates list metrics
|
|
62
|
+
*/
|
|
63
|
+
recalculateMetrics(options) {
|
|
64
|
+
const { scrollDirection = 0, fromItemId, bounds, collection, dynamicSize, isVertical, itemSize, itemsOffset, scrollSize, snap, stickyMap } = options;
|
|
65
|
+
const { width, height } = bounds, sizeProperty = isVertical ? HEIGHT_PROP_NAME : WIDTH_PROP_NAME, size = isVertical ? height : width, totalLength = collection.length, typicalItemSize = itemSize, w = isVertical ? width : typicalItemSize, h = isVertical ? typicalItemSize : height, totalSize = dynamicSize ? this.getBoundsFromCache(collection, typicalItemSize, isVertical) : totalLength * typicalItemSize, snippedPos = Math.floor(scrollSize), leftItemsWeights = [], isFromId = fromItemId !== undefined && (typeof fromItemId === 'number' && fromItemId > -1)
|
|
66
|
+
|| (typeof fromItemId === 'string' && fromItemId > '-1');
|
|
67
|
+
let itemsFromStartToScrollEnd = -1, itemsFromDisplayEndToOffsetEnd = 0, itemsFromStartToDisplayEnd = -1, leftItemLength = 0, rightItemLength = 0, leftItemsWeight = 0, rightItemsWeight = 0, leftHiddenItemsWeight = 0, totalItemsToDisplayEndWeight = 0, itemById = undefined, itemByIdPos = 0, lastDisplayItemId = undefined, actualScrollSize = itemByIdPos, fullHeight = 0, startIndex;
|
|
68
|
+
if (dynamicSize) {
|
|
69
|
+
let y = 0, stickyCollectionItem = undefined, stickyComponentSize = 0;
|
|
70
|
+
for (let i = 0, l = collection.length; i < l; i++) {
|
|
71
|
+
const ii = i + 1, collectionItem = collection[i], map = this._map;
|
|
72
|
+
let componentSize = 0;
|
|
73
|
+
if (map.has(collectionItem.id)) {
|
|
74
|
+
const bounds = map.get(collectionItem.id);
|
|
75
|
+
componentSize = bounds ? bounds[sizeProperty] : typicalItemSize;
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
componentSize = typicalItemSize;
|
|
79
|
+
}
|
|
80
|
+
if (isFromId) {
|
|
81
|
+
if (itemById === undefined) {
|
|
82
|
+
leftItemsWeights.push(componentSize);
|
|
83
|
+
leftHiddenItemsWeight += componentSize;
|
|
84
|
+
itemsFromStartToScrollEnd = ii;
|
|
85
|
+
if (stickyMap && stickyMap[collectionItem.id] > 0) {
|
|
86
|
+
stickyComponentSize = componentSize;
|
|
87
|
+
stickyCollectionItem = collectionItem;
|
|
88
|
+
}
|
|
89
|
+
if (collectionItem.id === fromItemId) {
|
|
90
|
+
itemById = collectionItem;
|
|
91
|
+
itemByIdPos = y;
|
|
92
|
+
if (stickyCollectionItem && stickyMap && stickyMap[stickyCollectionItem.id] > 0) {
|
|
93
|
+
itemByIdPos = itemByIdPos - stickyComponentSize;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
else if (y < scrollSize - componentSize) {
|
|
99
|
+
leftItemsWeights.push(componentSize);
|
|
100
|
+
leftHiddenItemsWeight += componentSize;
|
|
101
|
+
itemsFromStartToScrollEnd = ii;
|
|
102
|
+
}
|
|
103
|
+
if (isFromId) {
|
|
104
|
+
if (!lastDisplayItemId) {
|
|
105
|
+
if (itemById === undefined || y < itemByIdPos + size + componentSize) {
|
|
106
|
+
itemsFromStartToDisplayEnd = ii;
|
|
107
|
+
totalItemsToDisplayEndWeight += componentSize;
|
|
108
|
+
itemsFromDisplayEndToOffsetEnd = itemsFromStartToDisplayEnd + itemsOffset;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
else if (y < scrollSize + size + componentSize) {
|
|
113
|
+
itemsFromStartToDisplayEnd = ii;
|
|
114
|
+
totalItemsToDisplayEndWeight += componentSize;
|
|
115
|
+
itemsFromDisplayEndToOffsetEnd = itemsFromStartToDisplayEnd + itemsOffset;
|
|
116
|
+
}
|
|
117
|
+
else if (i < itemsFromDisplayEndToOffsetEnd) {
|
|
118
|
+
rightItemsWeight += componentSize;
|
|
119
|
+
}
|
|
120
|
+
y += componentSize;
|
|
121
|
+
}
|
|
122
|
+
fullHeight = y;
|
|
123
|
+
if (itemsFromStartToScrollEnd === -1) {
|
|
124
|
+
itemsFromStartToScrollEnd = 0;
|
|
125
|
+
}
|
|
126
|
+
if (itemsFromStartToDisplayEnd === -1) {
|
|
127
|
+
itemsFromStartToDisplayEnd = 0;
|
|
128
|
+
}
|
|
129
|
+
actualScrollSize = isFromId ? itemByIdPos : scrollSize;
|
|
130
|
+
leftItemsWeights.splice(0, leftItemsWeights.length - itemsOffset);
|
|
131
|
+
leftItemsWeights.forEach(v => {
|
|
132
|
+
leftItemsWeight += v;
|
|
133
|
+
});
|
|
134
|
+
leftItemLength = Math.min(itemsFromStartToScrollEnd, itemsOffset);
|
|
135
|
+
rightItemLength = itemsFromStartToDisplayEnd + itemsOffset > totalLength
|
|
136
|
+
? totalLength - itemsFromStartToDisplayEnd : itemsOffset;
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
itemsFromStartToScrollEnd = Math.floor(scrollSize / typicalItemSize);
|
|
140
|
+
itemsFromStartToDisplayEnd = Math.ceil((scrollSize + size) / typicalItemSize);
|
|
141
|
+
leftItemLength = Math.min(itemsFromStartToScrollEnd, itemsOffset);
|
|
142
|
+
rightItemLength = itemsFromStartToDisplayEnd + itemsOffset > totalLength
|
|
143
|
+
? totalLength - itemsFromStartToDisplayEnd : itemsOffset;
|
|
144
|
+
leftItemsWeight = leftItemLength * typicalItemSize;
|
|
145
|
+
rightItemsWeight = rightItemLength * typicalItemSize,
|
|
146
|
+
leftHiddenItemsWeight = itemsFromStartToScrollEnd * typicalItemSize,
|
|
147
|
+
totalItemsToDisplayEndWeight = itemsFromStartToDisplayEnd * typicalItemSize;
|
|
148
|
+
actualScrollSize = scrollSize,
|
|
149
|
+
fullHeight = totalLength * typicalItemSize;
|
|
150
|
+
}
|
|
151
|
+
startIndex = Math.min(itemsFromStartToScrollEnd - leftItemLength, totalLength > 0 ? totalLength - 1 : 0);
|
|
152
|
+
const itemsOnDisplay = totalItemsToDisplayEndWeight - leftHiddenItemsWeight, itemsOnDisplayLength = itemsFromStartToDisplayEnd - itemsFromStartToScrollEnd, startPosition = leftHiddenItemsWeight - leftItemsWeight, renderItems = itemsOnDisplayLength + leftItemLength + rightItemLength, delta = fullHeight - this._previouseFullHeigh;
|
|
153
|
+
if (scrollDirection === -1) {
|
|
154
|
+
this._delta += delta;
|
|
155
|
+
}
|
|
156
|
+
const metrics = {
|
|
157
|
+
delta: this._delta,
|
|
158
|
+
normalizedItemWidth: w,
|
|
159
|
+
normalizedItemHeight: h,
|
|
160
|
+
width,
|
|
161
|
+
height,
|
|
162
|
+
dynamicSize,
|
|
163
|
+
itemSize,
|
|
164
|
+
itemsFromStartToScrollEnd,
|
|
165
|
+
itemsFromStartToDisplayEnd,
|
|
166
|
+
itemsOnDisplay,
|
|
167
|
+
itemsOnDisplayLength,
|
|
168
|
+
isVertical,
|
|
169
|
+
leftHiddenItemsWeight,
|
|
170
|
+
leftItemLength,
|
|
171
|
+
leftItemsWeight,
|
|
172
|
+
renderItems,
|
|
173
|
+
rightItemLength,
|
|
174
|
+
rightItemsWeight,
|
|
175
|
+
scrollSize: actualScrollSize,
|
|
176
|
+
sizeProperty,
|
|
177
|
+
snap,
|
|
178
|
+
snippedPos,
|
|
179
|
+
startIndex,
|
|
180
|
+
startPosition,
|
|
181
|
+
totalItemsToDisplayEndWeight,
|
|
182
|
+
totalLength,
|
|
183
|
+
totalSize,
|
|
184
|
+
typicalItemSize,
|
|
185
|
+
};
|
|
186
|
+
if (scrollDirection !== 0) {
|
|
187
|
+
this._previouseFullHeigh = fullHeight;
|
|
188
|
+
}
|
|
189
|
+
return metrics;
|
|
190
|
+
}
|
|
191
|
+
clearDelta() {
|
|
192
|
+
this._delta = 0;
|
|
193
|
+
}
|
|
194
|
+
generateDisplayCollection(items, stickyMap, metrics) {
|
|
195
|
+
const {
|
|
196
|
+
// delta,
|
|
197
|
+
normalizedItemWidth, normalizedItemHeight,
|
|
198
|
+
// width,
|
|
199
|
+
// height,
|
|
200
|
+
dynamicSize,
|
|
201
|
+
// itemSize,
|
|
202
|
+
itemsFromStartToScrollEnd,
|
|
203
|
+
// itemsFromStartToDisplayEnd,
|
|
204
|
+
// itemsOnDisplay,
|
|
205
|
+
// itemsOnDisplayLength,
|
|
206
|
+
isVertical,
|
|
207
|
+
// leftHiddenItemsWeight,
|
|
208
|
+
// leftItemLength,
|
|
209
|
+
// leftItemsWeight,
|
|
210
|
+
renderItems: renderItemsLength,
|
|
211
|
+
// rightItemLength,
|
|
212
|
+
// rightItemsWeight,
|
|
213
|
+
scrollSize, sizeProperty, snap, snippedPos, startPosition,
|
|
214
|
+
// totalItemsToDisplayEndWeight,
|
|
215
|
+
totalLength,
|
|
216
|
+
// totalSize,
|
|
217
|
+
startIndex, typicalItemSize, } = metrics, displayItems = [];
|
|
218
|
+
if (items.length) {
|
|
219
|
+
const actualSnippedPosition = snippedPos;
|
|
220
|
+
let pos = startPosition, renderItems = renderItemsLength, stickyItem, nextSticky, stickyItemIndex = -1, stickyItemSize = 0;
|
|
221
|
+
if (snap) {
|
|
222
|
+
for (let i = Math.min(itemsFromStartToScrollEnd > 0 ? itemsFromStartToScrollEnd : 0, totalLength - 1); i >= 0; i--) {
|
|
223
|
+
const id = items[i].id, sticky = stickyMap[id], size = dynamicSize ? this.get(id)?.[sizeProperty] || typicalItemSize : typicalItemSize;
|
|
224
|
+
stickyItemSize = size;
|
|
225
|
+
if (sticky > 0) {
|
|
226
|
+
const measures = {
|
|
227
|
+
x: isVertical ? 0 : actualSnippedPosition,
|
|
228
|
+
y: isVertical ? actualSnippedPosition : 0,
|
|
229
|
+
width: normalizedItemWidth,
|
|
230
|
+
height: normalizedItemHeight,
|
|
231
|
+
}, config = {
|
|
232
|
+
isVertical,
|
|
233
|
+
sticky,
|
|
234
|
+
snap,
|
|
235
|
+
snapped: true,
|
|
236
|
+
snappedOut: false,
|
|
237
|
+
dynamic: dynamicSize,
|
|
238
|
+
};
|
|
239
|
+
const itemData = items[i];
|
|
240
|
+
stickyItem = { id, measures, data: itemData, config };
|
|
241
|
+
stickyItemIndex = i;
|
|
242
|
+
displayItems.push(stickyItem);
|
|
243
|
+
break;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
let i = startIndex;
|
|
248
|
+
while (renderItems > 0) {
|
|
249
|
+
if (i >= totalLength) {
|
|
250
|
+
break;
|
|
251
|
+
}
|
|
252
|
+
const id = items[i].id, size = dynamicSize ? this.get(id)?.[sizeProperty] || typicalItemSize : typicalItemSize;
|
|
253
|
+
if (id !== stickyItem?.id) {
|
|
254
|
+
const snapped = snap && stickyMap[id] > 0 && pos <= scrollSize, measures = {
|
|
255
|
+
x: isVertical ? 0 : pos,
|
|
256
|
+
y: isVertical ? pos : 0,
|
|
257
|
+
width: normalizedItemWidth,
|
|
258
|
+
height: normalizedItemHeight,
|
|
259
|
+
}, config = {
|
|
260
|
+
isVertical,
|
|
261
|
+
sticky: stickyMap[id],
|
|
262
|
+
snap,
|
|
263
|
+
snapped: false,
|
|
264
|
+
snappedOut: false,
|
|
265
|
+
dynamic: dynamicSize,
|
|
266
|
+
};
|
|
267
|
+
const itemData = items[i];
|
|
268
|
+
const item = { id, measures, data: itemData, config };
|
|
269
|
+
if (!nextSticky && stickyItemIndex < i && snap && stickyMap[id] > 0 && pos <= scrollSize + size) {
|
|
270
|
+
item.measures.x = isVertical ? 0 : snapped ? actualSnippedPosition : pos;
|
|
271
|
+
item.measures.y = isVertical ? snapped ? actualSnippedPosition : pos : 0;
|
|
272
|
+
nextSticky = item;
|
|
273
|
+
nextSticky.config.snapped = snapped;
|
|
274
|
+
}
|
|
275
|
+
displayItems.push(item);
|
|
276
|
+
}
|
|
277
|
+
renderItems -= 1;
|
|
278
|
+
pos += size;
|
|
279
|
+
i++;
|
|
280
|
+
}
|
|
281
|
+
const axis = isVertical ? Y_PROP_NAME : X_PROP_NAME;
|
|
282
|
+
if (nextSticky && stickyItem && nextSticky.measures[axis] <= scrollSize + stickyItemSize) {
|
|
283
|
+
if (nextSticky.measures[axis] > scrollSize) {
|
|
284
|
+
stickyItem.measures[axis] = nextSticky.measures[axis] - stickyItemSize;
|
|
285
|
+
stickyItem.config.snapped = nextSticky.config.snapped = false;
|
|
286
|
+
stickyItem.config.snappedOut = true;
|
|
287
|
+
stickyItem.config.sticky = 1;
|
|
288
|
+
}
|
|
289
|
+
else {
|
|
290
|
+
nextSticky.config.snapped = true;
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
return displayItems;
|
|
295
|
+
}
|
|
296
|
+
/**
|
|
297
|
+
* tracking by propName
|
|
298
|
+
*/
|
|
299
|
+
track() {
|
|
300
|
+
if (!this._items || !this._displayComponents) {
|
|
301
|
+
return;
|
|
302
|
+
}
|
|
303
|
+
this._tracker.track(this._items, this._displayComponents);
|
|
304
|
+
}
|
|
305
|
+
setDisplayObjectIndexMapById(v) {
|
|
306
|
+
this._tracker.displayObjectIndexMapById = v;
|
|
307
|
+
}
|
|
308
|
+
untrackComponentByIdProperty(component) {
|
|
309
|
+
this._tracker.untrackComponentByIdProperty(component);
|
|
310
|
+
}
|
|
311
|
+
cacheElements() {
|
|
312
|
+
if (!this._displayComponents) {
|
|
313
|
+
return;
|
|
314
|
+
}
|
|
315
|
+
for (let i = 0, l = this._displayComponents.length; i < l; i++) {
|
|
316
|
+
const component = this._displayComponents[i], itemId = component.instance.itemId;
|
|
317
|
+
if (itemId === undefined) {
|
|
318
|
+
continue;
|
|
319
|
+
}
|
|
320
|
+
const bounds = component.instance.getBounds();
|
|
321
|
+
this.set(itemId, bounds);
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
/**
|
|
325
|
+
* Returns calculated bounds from cache
|
|
326
|
+
*/
|
|
327
|
+
getBoundsFromCache(items, typicalItemSize, isVertical) {
|
|
328
|
+
const sizeProperty = isVertical ? HEIGHT_PROP_NAME : WIDTH_PROP_NAME, map = this._map;
|
|
329
|
+
let size = 0;
|
|
330
|
+
for (let i = 0, l = items.length; i < l; i++) {
|
|
331
|
+
const item = items[i];
|
|
332
|
+
if (map.has(item.id)) {
|
|
333
|
+
const bounds = map.get(item.id);
|
|
334
|
+
size += bounds ? bounds[sizeProperty] : typicalItemSize;
|
|
335
|
+
}
|
|
336
|
+
else {
|
|
337
|
+
size += typicalItemSize;
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
return size;
|
|
341
|
+
}
|
|
342
|
+
dispose() {
|
|
343
|
+
super.dispose();
|
|
344
|
+
if (this._debounceChanges) {
|
|
345
|
+
this._debounceChanges.dispose();
|
|
346
|
+
}
|
|
347
|
+
if (this._tracker) {
|
|
348
|
+
this._tracker.dispose();
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
//# 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 { IVirtualListCollection } from \"../models/collection.model\";\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 { 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    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 type ScrollDirection = -1 | 0 | 1;\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    fromItemId?: Id;\r\n    scrollDirection?: ScrollDirection;\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\n/**\r\n * An object that performs tracking, calculations and caching.\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/main/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, 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 _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    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, scrollDirection: undefined, ...options };\r\n        const { scrollSize } = this.recalculateMetrics(opt);\r\n        return scrollSize;\r\n    }\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, scrollDirection: undefined, ...options };\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        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     * 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 { scrollDirection = 0, fromItemId, bounds, collection, dynamicSize, isVertical, itemSize,\r\n            itemsOffset, scrollSize, snap, stickyMap } = 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            totalSize = dynamicSize ? this.getBoundsFromCache(collection, typicalItemSize, isVertical) : totalLength * 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            itemById: I | undefined = undefined,\r\n            itemByIdPos: number = 0,\r\n            lastDisplayItemId: Id | undefined = undefined,\r\n            actualScrollSize = itemByIdPos,\r\n            fullHeight = 0,\r\n            startIndex;\r\n\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], map = this._map;\r\n\r\n                let componentSize = 0;\r\n                if (map.has(collectionItem.id)) {\r\n                    const bounds = map.get(collectionItem.id);\r\n                    componentSize = bounds ? bounds[sizeProperty] : typicalItemSize;\r\n                } else {\r\n                    componentSize = typicalItemSize;\r\n                }\r\n\r\n                if (isFromId) {\r\n                    if (itemById === undefined) {\r\n                        leftItemsWeights.push(componentSize);\r\n                        leftHiddenItemsWeight += componentSize;\r\n                        itemsFromStartToScrollEnd = ii;\r\n\r\n                        if (stickyMap && stickyMap[collectionItem.id] > 0) {\r\n                            stickyComponentSize = componentSize;\r\n                            stickyCollectionItem = collectionItem;\r\n                        }\r\n\r\n                        if (collectionItem.id === fromItemId) {\r\n                            itemById = collectionItem;\r\n                            itemByIdPos = y;\r\n                            if (stickyCollectionItem && stickyMap && stickyMap[stickyCollectionItem.id] > 0) {\r\n                                itemByIdPos = itemByIdPos - stickyComponentSize;\r\n                            }\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 (!lastDisplayItemId) {\r\n                        if (itemById === undefined || y < itemByIdPos + size + componentSize) {\r\n                            itemsFromStartToDisplayEnd = ii;\r\n                            totalItemsToDisplayEndWeight += componentSize;\r\n                            itemsFromDisplayEndToOffsetEnd = itemsFromStartToDisplayEnd + itemsOffset;\r\n                        }\r\n                    }\r\n                } else if (y < scrollSize + size + componentSize) {\r\n                    itemsFromStartToDisplayEnd = ii;\r\n                    totalItemsToDisplayEndWeight += componentSize;\r\n                    itemsFromDisplayEndToOffsetEnd = itemsFromStartToDisplayEnd + itemsOffset;\r\n                } else if (i < itemsFromDisplayEndToOffsetEnd) {\r\n                    rightItemsWeight += componentSize;\r\n                }\r\n\r\n                y += componentSize;\r\n            }\r\n            fullHeight = y;\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 - itemsOffset);\r\n            leftItemsWeights.forEach(v => {\r\n                leftItemsWeight += v;\r\n            });\r\n\r\n            leftItemLength = Math.min(itemsFromStartToScrollEnd, itemsOffset);\r\n            rightItemLength = itemsFromStartToDisplayEnd + itemsOffset > totalLength\r\n                ? totalLength - itemsFromStartToDisplayEnd : itemsOffset;\r\n        } else {\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                fullHeight = 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 = fullHeight - this._previouseFullHeigh;\r\n\r\n        if (scrollDirection === -1) {\r\n            this._delta += delta;\r\n        }\r\n\r\n        const metrics: IMetrics = {\r\n            delta: this._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            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        if (scrollDirection !== 0) {\r\n            this._previouseFullHeigh = fullHeight;\r\n        }\r\n\r\n        return metrics;\r\n    }\r\n\r\n    clearDelta(): void {\r\n        this._delta = 0;\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            // delta,\r\n            normalizedItemWidth,\r\n            normalizedItemHeight,\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: renderItemsLength,\r\n            // rightItemLength,\r\n            // rightItemsWeight,\r\n            scrollSize,\r\n            sizeProperty,\r\n            snap,\r\n            snippedPos,\r\n            startPosition,\r\n            // totalItemsToDisplayEndWeight,\r\n            totalLength,\r\n            // totalSize,\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                    stickyItemSize = size;\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\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 && snap && stickyMap[id] > 0 && pos <= scrollSize + size) {\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    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    /**\r\n     * Returns calculated bounds from cache\r\n     */\r\n    private getBoundsFromCache(items: IVirtualListCollection, typicalItemSize: number, isVertical: boolean) {\r\n        const sizeProperty = isVertical ? HEIGHT_PROP_NAME : WIDTH_PROP_NAME, map = this._map;\r\n        let size: number = 0;\r\n        for (let i = 0, l = items.length; i < l; i++) {\r\n            const item = items[i];\r\n            if (map.has(item.id)) {\r\n                const bounds = map.get(item.id);\r\n                size += bounds ? bounds[sizeProperty] : typicalItemSize;\r\n            } else {\r\n                size += typicalItemSize;\r\n            }\r\n        }\r\n        return size;\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"]}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tracks display items by property
|
|
3
|
+
* @link https://github.com/DjonnyX/ng-virtual-list/blob/main/projects/ng-virtual-list/src/lib/utils/tracker.ts
|
|
4
|
+
* @author Evgenii Grebennikov
|
|
5
|
+
* @email djonnyx@gmail.com
|
|
6
|
+
*/
|
|
7
|
+
export class Tracker {
|
|
8
|
+
constructor(trackingPropertyName) {
|
|
9
|
+
/**
|
|
10
|
+
* display objects dictionary of indexes by id
|
|
11
|
+
*/
|
|
12
|
+
this._displayObjectIndexMapById = {};
|
|
13
|
+
/**
|
|
14
|
+
* Dictionary displayItems propertyNameId by items propertyNameId
|
|
15
|
+
*/
|
|
16
|
+
this._trackMap = {};
|
|
17
|
+
this._trackingPropertyName = trackingPropertyName;
|
|
18
|
+
}
|
|
19
|
+
set displayObjectIndexMapById(v) {
|
|
20
|
+
if (this._displayObjectIndexMapById === v) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
this._displayObjectIndexMapById = v;
|
|
24
|
+
}
|
|
25
|
+
get displayObjectIndexMapById() {
|
|
26
|
+
return this._displayObjectIndexMapById;
|
|
27
|
+
}
|
|
28
|
+
get trackMap() {
|
|
29
|
+
return this._trackMap;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* tracking by propName
|
|
33
|
+
*/
|
|
34
|
+
track(items, components, afterComponentSetup) {
|
|
35
|
+
if (!items) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const idPropName = this._trackingPropertyName, untrackedItems = [...components];
|
|
39
|
+
for (let i = 0, l = items.length; i < l; i++) {
|
|
40
|
+
const item = items[i], itemTrackingProperty = item[idPropName];
|
|
41
|
+
if (this._trackMap) {
|
|
42
|
+
const diId = this._trackMap[itemTrackingProperty];
|
|
43
|
+
if (this._trackMap.hasOwnProperty(itemTrackingProperty)) {
|
|
44
|
+
const lastIndex = this._displayObjectIndexMapById[diId], el = components[lastIndex];
|
|
45
|
+
this._checkComponentProperty(el?.instance);
|
|
46
|
+
const elId = el?.instance?.[itemTrackingProperty];
|
|
47
|
+
if (el && elId === diId) {
|
|
48
|
+
const indexByUntrackedItems = untrackedItems.findIndex(v => {
|
|
49
|
+
this._checkComponentProperty(v.instance);
|
|
50
|
+
return v.instance[itemTrackingProperty] === elId;
|
|
51
|
+
});
|
|
52
|
+
if (indexByUntrackedItems > -1) {
|
|
53
|
+
el.instance.item = item;
|
|
54
|
+
if (afterComponentSetup !== undefined) {
|
|
55
|
+
afterComponentSetup(el.instance, item);
|
|
56
|
+
}
|
|
57
|
+
untrackedItems.splice(indexByUntrackedItems, 1);
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
delete this._trackMap[itemTrackingProperty];
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
if (untrackedItems.length > 0) {
|
|
65
|
+
const el = untrackedItems.shift(), item = items[i];
|
|
66
|
+
if (el) {
|
|
67
|
+
el.instance.item = item;
|
|
68
|
+
if (this._trackMap) {
|
|
69
|
+
this._checkComponentProperty(el.instance);
|
|
70
|
+
this._trackMap[itemTrackingProperty] = el.instance[itemTrackingProperty];
|
|
71
|
+
}
|
|
72
|
+
if (afterComponentSetup !== undefined) {
|
|
73
|
+
afterComponentSetup(el.instance, item);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
if (untrackedItems.length) {
|
|
79
|
+
throw Error('Tracking by id caused an error.');
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
untrackComponentByIdProperty(component) {
|
|
83
|
+
if (!component) {
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
const propertyIdName = this._trackingPropertyName;
|
|
87
|
+
this._checkComponentProperty(component);
|
|
88
|
+
if (this._trackMap && component[propertyIdName] !== undefined) {
|
|
89
|
+
delete this._trackMap[propertyIdName];
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
_checkComponentProperty(component) {
|
|
93
|
+
if (!component) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
const propertyIdName = this._trackingPropertyName;
|
|
97
|
+
try {
|
|
98
|
+
component[propertyIdName];
|
|
99
|
+
}
|
|
100
|
+
catch (err) {
|
|
101
|
+
throw Error(`Property ${propertyIdName} does not exist.`);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
dispose() {
|
|
105
|
+
this._trackMap = null;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
//# 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/main/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}"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctdmlydHVhbC1saXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvbmctdmlydHVhbC1saXN0L3NyYy9uZy12aXJ0dWFsLWxpc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of ng-virtual-list
|
|
3
|
+
*/
|
|
4
|
+
export * from './lib/ng-virtual-list.module';
|
|
5
|
+
export * from './lib/ng-virtual-list.component';
|
|
6
|
+
export * from './lib/models';
|
|
7
|
+
export * from './lib/types';
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLXZpcnR1YWwtbGlzdC9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuZy12aXJ0dWFsLWxpc3RcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9uZy12aXJ0dWFsLWxpc3QubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbmctdmlydHVhbC1saXN0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzJztcclxuIl19
|