ng-virtual-list 16.1.3 → 16.2.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.
@@ -60,7 +60,17 @@ export class Tracker {
60
60
  }
61
61
  }
62
62
  comp.instance.item = item;
63
- comp.instance.show();
63
+ if (snapedComponent) {
64
+ if (item['config']['snapped'] || item['config']['snappedOut']) {
65
+ comp.instance.hide();
66
+ }
67
+ else {
68
+ comp.instance.show();
69
+ }
70
+ }
71
+ else {
72
+ comp.instance.show();
73
+ }
64
74
  untrackedItems.splice(indexByUntrackedItems, 1);
65
75
  continue;
66
76
  }
@@ -79,7 +89,17 @@ export class Tracker {
79
89
  }
80
90
  }
81
91
  comp.instance.item = item;
82
- comp.instance.show();
92
+ if (snapedComponent) {
93
+ if (item['config']['snapped'] || item['config']['snappedOut']) {
94
+ comp.instance.hide();
95
+ }
96
+ else {
97
+ comp.instance.show();
98
+ }
99
+ }
100
+ else {
101
+ comp.instance.show();
102
+ }
83
103
  if (this._trackMap) {
84
104
  this._trackMap[itemTrackingProperty] = comp.instance.id;
85
105
  }
@@ -112,4 +132,4 @@ export class Tracker {
112
132
  this._trackMap = null;
113
133
  }
114
134
  }
115
- //# 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\nimport { ScrollDirection } from \"../models\";\r\n\r\ntype TrackingPropertyId = string | number;\r\n\r\ninterface IVirtualListItemComponent<I = any> {\r\n    id: number;\r\n    item: I;\r\n    show: () => void;\r\n    hide: () => void;\r\n}\r\n\r\n/**\r\n * Tracks display items by property\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/16.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 extends IVirtualListItemComponent = 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<C>>, snapedComponent: ComponentRef<C> | null | undefined,\r\n        direction: ScrollDirection): void {\r\n        if (!items) {\r\n            return;\r\n        }\r\n\r\n        const idPropName = this._trackingPropertyName, untrackedItems = [...components], isDown = direction === 0 || direction === 1;\r\n        let isRegularSnapped = false;\r\n\r\n        for (let i = isDown ? 0 : items.length - 1, l = isDown ? items.length : 0; isDown ? i < l : i >= l; isDown ? i++ : i--) {\r\n            const item = items[i], itemTrackingProperty = item[idPropName];\r\n\r\n            if (this._trackMap) {\r\n                if (this._trackMap.hasOwnProperty(itemTrackingProperty)) {\r\n                    const diId = this._trackMap[itemTrackingProperty],\r\n                        compIndex = this._displayObjectIndexMapById[diId], comp = components[compIndex];\r\n\r\n                    const compId = comp?.instance?.id;\r\n                    if (comp !== undefined && compId === diId) {\r\n                        const indexByUntrackedItems = untrackedItems.findIndex(v => {\r\n                            return v.instance.id === compId;\r\n                        });\r\n                        if (indexByUntrackedItems > -1) {\r\n                            if (snapedComponent) {\r\n                                if (item['config']['snapped'] || item['config']['snappedOut']) {\r\n                                    isRegularSnapped = true;\r\n                                    snapedComponent.instance.item = item;\r\n                                    snapedComponent.instance.show();\r\n                                }\r\n                            }\r\n                            comp.instance.item = item;\r\n                            comp.instance.show();\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 comp = untrackedItems.shift(), item = items[i];\r\n                if (comp) {\r\n                    if (snapedComponent) {\r\n                        if (item['config']['snapped'] || item['config']['snappedOut']) {\r\n                            isRegularSnapped = true;\r\n                            snapedComponent.instance.item = item;\r\n                            snapedComponent.instance.show();\r\n                        }\r\n                    }\r\n                    comp.instance.item = item;\r\n                    comp.instance.show();\r\n\r\n                    if (this._trackMap) {\r\n                        this._trackMap[itemTrackingProperty] = comp.instance.id;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        if (untrackedItems.length) {\r\n            for (let i = 0, l = untrackedItems.length; i < l; i++) {\r\n                const comp = untrackedItems[i];\r\n                comp.instance.hide();\r\n            }\r\n        }\r\n\r\n        if (!isRegularSnapped) {\r\n            if (snapedComponent) {\r\n                snapedComponent.instance.item = null;\r\n                snapedComponent.instance.hide();\r\n            }\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}"]}
135
+ //# 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\nimport { ScrollDirection } from \"../models\";\r\n\r\ntype TrackingPropertyId = string | number;\r\n\r\ninterface IVirtualListItemComponent<I = any> {\r\n    id: number;\r\n    item: I;\r\n    show: () => void;\r\n    hide: () => void;\r\n}\r\n\r\n/**\r\n * Tracks display items by property\r\n * @link https://github.com/DjonnyX/ng-virtual-list/blob/16.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 extends IVirtualListItemComponent = 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<C>>, snapedComponent: ComponentRef<C> | null | undefined,\r\n        direction: ScrollDirection): void {\r\n        if (!items) {\r\n            return;\r\n        }\r\n\r\n        const idPropName = this._trackingPropertyName, untrackedItems = [...components], isDown = direction === 0 || direction === 1;\r\n        let isRegularSnapped = false;\r\n\r\n        for (let i = isDown ? 0 : items.length - 1, l = isDown ? items.length : 0; isDown ? i < l : i >= l; isDown ? i++ : i--) {\r\n            const item = items[i], itemTrackingProperty = item[idPropName];\r\n\r\n            if (this._trackMap) {\r\n                if (this._trackMap.hasOwnProperty(itemTrackingProperty)) {\r\n                    const diId = this._trackMap[itemTrackingProperty],\r\n                        compIndex = this._displayObjectIndexMapById[diId], comp = components[compIndex];\r\n\r\n                    const compId = comp?.instance?.id;\r\n                    if (comp !== undefined && compId === diId) {\r\n                        const indexByUntrackedItems = untrackedItems.findIndex(v => {\r\n                            return v.instance.id === compId;\r\n                        });\r\n                        if (indexByUntrackedItems > -1) {\r\n                            if (snapedComponent) {\r\n                                if (item['config']['snapped'] || item['config']['snappedOut']) {\r\n                                    isRegularSnapped = true;\r\n                                    snapedComponent.instance.item = item;\r\n                                    snapedComponent.instance.show();\r\n                                }\r\n                            }\r\n                            comp.instance.item = item;\r\n\r\n                            if (snapedComponent) {\r\n                                if (item['config']['snapped'] || item['config']['snappedOut']) {\r\n                                    comp.instance.hide();\r\n                                } else {\r\n                                    comp.instance.show();\r\n                                }\r\n                            } else {\r\n                                comp.instance.show();\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 comp = untrackedItems.shift(), item = items[i];\r\n                if (comp) {\r\n                    if (snapedComponent) {\r\n                        if (item['config']['snapped'] || item['config']['snappedOut']) {\r\n                            isRegularSnapped = true;\r\n                            snapedComponent.instance.item = item;\r\n                            snapedComponent.instance.show();\r\n                        }\r\n                    }\r\n                    comp.instance.item = item;\r\n                    if (snapedComponent) {\r\n                        if (item['config']['snapped'] || item['config']['snappedOut']) {\r\n                            comp.instance.hide();\r\n                        } else {\r\n                            comp.instance.show();\r\n                        }\r\n                    } else {\r\n                        comp.instance.show();\r\n                    }\r\n\r\n                    if (this._trackMap) {\r\n                        this._trackMap[itemTrackingProperty] = comp.instance.id;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        if (untrackedItems.length) {\r\n            for (let i = 0, l = untrackedItems.length; i < l; i++) {\r\n                const comp = untrackedItems[i];\r\n                comp.instance.hide();\r\n            }\r\n        }\r\n\r\n        if (!isRegularSnapped) {\r\n            if (snapedComponent) {\r\n                snapedComponent.instance.item = null;\r\n                snapedComponent.instance.hide();\r\n            }\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}"]}
@@ -142,9 +142,10 @@ class NgVirtualListItemComponent {
142
142
  const data = this.data, regular = this.regular, length = this._regularLength;
143
143
  if (data) {
144
144
  const styles = this._elementRef.nativeElement.style;
145
- styles.zIndex = String(data.config.sticky);
145
+ styles.zIndex = data.config.zIndex;
146
146
  if (data.config.snapped) {
147
- styles.transform = ZEROS_TRANSLATE_3D;
147
+ styles.transform = data.config.sticky === 1 ? ZEROS_TRANSLATE_3D : `${TRANSLATE_3D}(${data.config.isVertical ? 0 : data.measures.x}${PX}, ${data.config.isVertical ? data.measures.y : 0}${PX} , 0)`;
148
+ ;
148
149
  if (!data.config.isSnappingMethodAdvanced) {
149
150
  styles.position = POSITION_STICKY;
150
151
  }
@@ -181,7 +182,7 @@ class NgVirtualListItemComponent {
181
182
  }
182
183
  styles.visibility = VISIBILITY_VISIBLE;
183
184
  }
184
- styles.zIndex = String(this.data?.config?.sticky ?? DEFAULT_ZINDEX);
185
+ styles.zIndex = this.data?.config?.zIndex ?? DEFAULT_ZINDEX;
185
186
  }
186
187
  hide() {
187
188
  const styles = this._elementRef.nativeElement.style;
@@ -262,12 +263,12 @@ const debounce = (cb, debounceTime = 0) => {
262
263
  * @author Evgenii Grebennikov
263
264
  * @email djonnyx@gmail.com
264
265
  */
265
- const toggleClassName = (el, className, remove = false) => {
266
+ const toggleClassName = (el, className, removeClassName) => {
266
267
  if (!el.classList.contains(className)) {
267
268
  el.classList.add(className);
268
269
  }
269
- else if (remove) {
270
- el.classList.remove(className);
270
+ if (removeClassName) {
271
+ el.classList.remove(removeClassName);
271
272
  }
272
273
  };
273
274
 
@@ -333,7 +334,17 @@ class Tracker {
333
334
  }
334
335
  }
335
336
  comp.instance.item = item;
336
- comp.instance.show();
337
+ if (snapedComponent) {
338
+ if (item['config']['snapped'] || item['config']['snappedOut']) {
339
+ comp.instance.hide();
340
+ }
341
+ else {
342
+ comp.instance.show();
343
+ }
344
+ }
345
+ else {
346
+ comp.instance.show();
347
+ }
337
348
  untrackedItems.splice(indexByUntrackedItems, 1);
338
349
  continue;
339
350
  }
@@ -352,7 +363,17 @@ class Tracker {
352
363
  }
353
364
  }
354
365
  comp.instance.item = item;
355
- comp.instance.show();
366
+ if (snapedComponent) {
367
+ if (item['config']['snapped'] || item['config']['snappedOut']) {
368
+ comp.instance.hide();
369
+ }
370
+ else {
371
+ comp.instance.show();
372
+ }
373
+ }
374
+ else {
375
+ comp.instance.show();
376
+ }
356
377
  if (this._trackMap) {
357
378
  this._trackMap[itemTrackingProperty] = comp.instance.id;
358
379
  }
@@ -970,7 +991,7 @@ class TrackBox extends CacheMap {
970
991
  }
971
992
  }
972
993
  if (deletedItemsMap.hasOwnProperty(i)) {
973
- const bounds = deletedItemsMap[i], size = bounds[sizeProperty] ?? typicalItemSize;
994
+ const bounds = deletedItemsMap[i], size = bounds?.[sizeProperty] ?? typicalItemSize;
974
995
  if (y < scrollSize - size) {
975
996
  leftSizeOfDeletedItems += size;
976
997
  }
@@ -978,7 +999,7 @@ class TrackBox extends CacheMap {
978
999
  totalSize += componentSize;
979
1000
  if (isFromId) {
980
1001
  if (itemById === undefined) {
981
- if (id !== fromItemId && stickyMap && stickyMap[id] > 0) {
1002
+ if (id !== fromItemId && stickyMap && stickyMap[id] === 1) {
982
1003
  stickyComponentSize = componentSize;
983
1004
  stickyCollectionItem = collectionItem;
984
1005
  }
@@ -1174,19 +1195,19 @@ class TrackBox extends CacheMap {
1174
1195
  this.bumpVersion();
1175
1196
  }
1176
1197
  generateDisplayCollection(items, stickyMap, metrics) {
1177
- const { normalizedItemWidth, normalizedItemHeight, dynamicSize, itemsFromStartToScrollEnd, isVertical, renderItems: renderItemsLength, scrollSize, sizeProperty, snap, snippedPos, startPosition, totalLength, startIndex, typicalItemSize, } = metrics, displayItems = [];
1198
+ const { width, height, normalizedItemWidth, normalizedItemHeight, dynamicSize, itemsOnDisplayLength, itemsFromStartToScrollEnd, isVertical, renderItems: renderItemsLength, scrollSize, sizeProperty, snap, snippedPos, startPosition, totalLength, startIndex, typicalItemSize, } = metrics, displayItems = [];
1178
1199
  if (items.length) {
1179
- const actualSnippedPosition = snippedPos, isSnappingMethodAdvanced = this.isSnappingMethodAdvanced;
1180
- let pos = startPosition, renderItems = renderItemsLength, stickyItem, nextSticky, stickyItemIndex = -1, stickyItemSize = 0;
1200
+ const actualSnippedPosition = snippedPos, isSnappingMethodAdvanced = this.isSnappingMethodAdvanced, boundsSize = isVertical ? height : width, actualEndSnippedPosition = boundsSize;
1201
+ let pos = startPosition, renderItems = renderItemsLength, stickyItem, nextSticky, stickyItemIndex = -1, stickyItemSize = 0, endStickyItem, nextEndSticky, endStickyItemIndex = -1, endStickyItemSize = 0;
1181
1202
  if (snap) {
1182
1203
  for (let i = Math.min(itemsFromStartToScrollEnd > 0 ? itemsFromStartToScrollEnd : 0, totalLength - 1); i >= 0; i--) {
1183
1204
  const id = items[i].id, sticky = stickyMap[id], size = dynamicSize ? this.get(id)?.[sizeProperty] || typicalItemSize : typicalItemSize;
1184
- if (sticky > 0) {
1205
+ if (sticky === 1) {
1185
1206
  const measures = {
1186
1207
  x: isVertical ? 0 : actualSnippedPosition,
1187
1208
  y: isVertical ? actualSnippedPosition : 0,
1188
- width: normalizedItemWidth,
1189
- height: normalizedItemHeight,
1209
+ width: isVertical ? normalizedItemWidth : size,
1210
+ height: isVertical ? size : normalizedItemHeight,
1190
1211
  delta: 0,
1191
1212
  }, config = {
1192
1213
  isVertical,
@@ -1196,6 +1217,7 @@ class TrackBox extends CacheMap {
1196
1217
  snappedOut: false,
1197
1218
  dynamic: dynamicSize,
1198
1219
  isSnappingMethodAdvanced,
1220
+ zIndex: '1',
1199
1221
  };
1200
1222
  const itemData = items[i];
1201
1223
  stickyItem = { id, measures, data: itemData, config };
@@ -1206,18 +1228,50 @@ class TrackBox extends CacheMap {
1206
1228
  }
1207
1229
  }
1208
1230
  }
1231
+ if (snap) {
1232
+ const startIndex = itemsFromStartToScrollEnd + itemsOnDisplayLength - 1;
1233
+ for (let i = Math.min(startIndex, totalLength > 0 ? totalLength - 1 : 0), l = totalLength; i < l; i++) {
1234
+ const id = items[i].id, sticky = stickyMap[id], size = dynamicSize
1235
+ ? this.get(id)?.[sizeProperty] || typicalItemSize
1236
+ : typicalItemSize;
1237
+ if (sticky === 2) {
1238
+ const w = isVertical ? normalizedItemWidth : size, h = isVertical ? size : normalizedItemHeight, measures = {
1239
+ x: isVertical ? 0 : actualEndSnippedPosition - w,
1240
+ y: isVertical ? actualEndSnippedPosition - h : 0,
1241
+ width: w,
1242
+ height: h,
1243
+ delta: 0,
1244
+ }, config = {
1245
+ isVertical,
1246
+ sticky,
1247
+ snap,
1248
+ snapped: true,
1249
+ snappedOut: false,
1250
+ dynamic: dynamicSize,
1251
+ isSnappingMethodAdvanced,
1252
+ zIndex: '1',
1253
+ };
1254
+ const itemData = items[i];
1255
+ endStickyItem = { id, measures, data: itemData, config };
1256
+ endStickyItemIndex = i;
1257
+ endStickyItemSize = size;
1258
+ displayItems.push(endStickyItem);
1259
+ break;
1260
+ }
1261
+ }
1262
+ }
1209
1263
  let i = startIndex;
1210
1264
  while (renderItems > 0) {
1211
1265
  if (i >= totalLength) {
1212
1266
  break;
1213
1267
  }
1214
1268
  const id = items[i].id, size = dynamicSize ? this.get(id)?.[sizeProperty] || typicalItemSize : typicalItemSize;
1215
- if (id !== stickyItem?.id) {
1216
- const snapped = snap && stickyMap[id] > 0 && pos <= scrollSize, measures = {
1217
- x: isVertical ? 0 : pos,
1218
- y: isVertical ? pos : 0,
1219
- width: normalizedItemWidth,
1220
- height: normalizedItemHeight,
1269
+ if (id !== stickyItem?.id && id !== endStickyItem?.id) {
1270
+ const snapped = snap && (stickyMap[id] === 1 && pos <= scrollSize || stickyMap[id] === 2 && pos >= scrollSize + boundsSize - size), measures = {
1271
+ x: isVertical ? stickyMap[id] === 1 ? 0 : boundsSize - size : pos,
1272
+ y: isVertical ? pos : stickyMap[id] === 2 ? boundsSize - size : 0,
1273
+ width: isVertical ? normalizedItemWidth : size,
1274
+ height: isVertical ? size : normalizedItemHeight,
1221
1275
  delta: 0,
1222
1276
  }, config = {
1223
1277
  isVertical,
@@ -1227,15 +1281,28 @@ class TrackBox extends CacheMap {
1227
1281
  snappedOut: false,
1228
1282
  dynamic: dynamicSize,
1229
1283
  isSnappingMethodAdvanced,
1284
+ zIndex: '0',
1230
1285
  };
1286
+ if (snapped) {
1287
+ config.zIndex = '2';
1288
+ }
1231
1289
  const itemData = items[i];
1232
1290
  const item = { id, measures, data: itemData, config };
1233
- if (!nextSticky && stickyItemIndex < i && stickyMap[id] > 0 && pos <= scrollSize + size + stickyItemSize) {
1291
+ if (!nextSticky && stickyItemIndex < i && stickyMap[id] === 1 && (pos <= scrollSize + size + stickyItemSize)) {
1234
1292
  item.measures.x = isVertical ? 0 : snapped ? actualSnippedPosition : pos;
1235
1293
  item.measures.y = isVertical ? snapped ? actualSnippedPosition : pos : 0;
1236
1294
  nextSticky = item;
1237
1295
  nextSticky.config.snapped = snapped;
1238
- nextSticky.measures.delta = isVertical ? item.measures.y - scrollSize : item.measures.x - scrollSize;
1296
+ nextSticky.measures.delta = isVertical ? (item.measures.y - scrollSize) : (item.measures.x - scrollSize);
1297
+ nextSticky.config.zIndex = '3';
1298
+ }
1299
+ else if (!nextEndSticky && endStickyItemIndex > i && stickyMap[id] === 2 && (pos >= scrollSize + boundsSize - size - endStickyItemSize)) {
1300
+ item.measures.x = isVertical ? 0 : snapped ? actualEndSnippedPosition - size : pos;
1301
+ item.measures.y = isVertical ? snapped ? actualEndSnippedPosition - size : pos : 0;
1302
+ nextEndSticky = item;
1303
+ nextEndSticky.config.zIndex = '3';
1304
+ nextEndSticky.config.snapped = snapped;
1305
+ nextEndSticky.measures.delta = isVertical ? (item.measures.y - scrollSize) : (item.measures.x - scrollSize);
1239
1306
  }
1240
1307
  displayItems.push(item);
1241
1308
  }
@@ -1257,6 +1324,19 @@ class TrackBox extends CacheMap {
1257
1324
  nextSticky.measures.delta = isVertical ? nextSticky.measures.y - scrollSize : nextSticky.measures.x - scrollSize;
1258
1325
  }
1259
1326
  }
1327
+ if (nextEndSticky && endStickyItem && nextEndSticky.measures[axis] >= scrollSize + boundsSize - endStickyItemSize - nextEndSticky.measures[sizeProperty]) {
1328
+ if (nextEndSticky.measures[axis] < scrollSize + boundsSize - endStickyItemSize) {
1329
+ endStickyItem.measures[axis] = nextEndSticky.measures[axis] + nextEndSticky.measures[sizeProperty];
1330
+ endStickyItem.config.snapped = nextEndSticky.config.snapped = false;
1331
+ endStickyItem.config.snappedOut = true;
1332
+ endStickyItem.config.sticky = 2;
1333
+ endStickyItem.measures.delta = isVertical ? endStickyItem.measures.y - scrollSize : endStickyItem.measures.x - scrollSize;
1334
+ }
1335
+ else {
1336
+ nextEndSticky.config.snapped = true;
1337
+ nextEndSticky.measures.delta = isVertical ? nextEndSticky.measures.y - scrollSize : nextEndSticky.measures.x - scrollSize;
1338
+ }
1339
+ }
1260
1340
  }
1261
1341
  return displayItems;
1262
1342
  }
@@ -1558,6 +1638,7 @@ class NgVirtualListComponent {
1558
1638
  ;
1559
1639
  get snappingMethod() { return this._$snappingMethod.getValue(); }
1560
1640
  _isSnappingMethodAdvanced = this.getIsSnappingMethodAdvanced();
1641
+ get isSnappingMethodAdvanced() { return this._isSnappingMethodAdvanced; }
1561
1642
  _displayComponents = [];
1562
1643
  _snapedDisplayComponent;
1563
1644
  _$bounds = new BehaviorSubject(null);
@@ -1574,12 +1655,12 @@ class NgVirtualListComponent {
1574
1655
  if (isScrollBarOverlap && IS_FIREFOX) {
1575
1656
  scrollBarSize = overlapScrollBarSize = FIREFOX_SCROLLBAR_OVERLAP_SIZE;
1576
1657
  }
1577
- snappedComponent.element.style.clipPath = `path("M 0 0 L 0 ${snappedComponent.element.offsetHeight} L ${snappedComponent.element.offsetWidth - overlapScrollBarSize} ${snappedComponent.element.offsetHeight} L ${snappedComponent.element.offsetWidth - overlapScrollBarSize} 0 Z")`;
1658
+ const { width: sWidth, height: sHeight } = snappedComponent.getBounds() ?? { width: 0, height: 0 };
1659
+ snappedComponent.element.style.clipPath = `path("M 0 0 L 0 ${sHeight} L ${sWidth - overlapScrollBarSize} ${sHeight} L ${sWidth - overlapScrollBarSize} 0 Z")`;
1578
1660
  snappedComponent.regularLength = `${isVertical ? listBounds.width : listBounds.height}${PX}`;
1579
- const { width: sWidth, height: sHeight } = snappedComponent.getBounds() ?? { width: 0, height: 0 }, containerElement = container.nativeElement;
1661
+ const containerElement = container.nativeElement, delta = snappedComponent.item?.measures.delta ?? 0;
1580
1662
  let left, right, top, bottom;
1581
1663
  if (isVertical) {
1582
- const snappedY = snappedComponent.item?.measures.y ?? 0, scrollSize = container.nativeElement.scrollTop, delta = snappedY - scrollSize;
1583
1664
  left = 0;
1584
1665
  right = width - scrollBarSize;
1585
1666
  top = sHeight;
@@ -1587,7 +1668,6 @@ class NgVirtualListComponent {
1587
1668
  containerElement.style.clipPath = `path("M 0 ${top + delta} L 0 ${height} L ${width} ${height} L ${width} 0 L ${right} 0 L ${right} ${top + delta} Z")`;
1588
1669
  }
1589
1670
  else {
1590
- const snappedX = snappedComponent.item?.measures.x ?? 0, scrollSize = container.nativeElement.scrollLeft, delta = snappedX - scrollSize;
1591
1671
  left = sWidth;
1592
1672
  right = width;
1593
1673
  top = 0;
@@ -1645,7 +1725,7 @@ class NgVirtualListComponent {
1645
1725
  $isVertical.pipe(takeUntilDestroyed(), tap(v => {
1646
1726
  this._isVertical = v;
1647
1727
  const el = this._elementRef.nativeElement;
1648
- toggleClassName(el, v ? CLASS_LIST_VERTICAL : CLASS_LIST_HORIZONTAL, true);
1728
+ toggleClassName(el, v ? CLASS_LIST_VERTICAL : CLASS_LIST_HORIZONTAL, v ? CLASS_LIST_HORIZONTAL : CLASS_LIST_VERTICAL);
1649
1729
  })).subscribe();
1650
1730
  $snappingMethod.pipe(takeUntilDestroyed(), tap(v => {
1651
1731
  this._isSnappingMethodAdvanced = this._trackBox.isSnappingMethodAdvanced = v;
@@ -1913,11 +1993,11 @@ class NgVirtualListComponent {
1913
1993
  }
1914
1994
  }
1915
1995
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
1916
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListComponent, selector: "ng-virtual-list", inputs: { items: "items", snap: "snap", enabledBufferOptimization: "enabledBufferOptimization", itemRenderer: "itemRenderer", stickyMap: "stickyMap", itemSize: "itemSize", dynamicSize: "dynamicSize", direction: "direction", itemsOffset: "itemsOffset", trackBy: "trackBy", snappingMethod: "snappingMethod" }, outputs: { onScroll: "onScroll", onScrollEnd: "onScrollEnd" }, viewQueries: [{ propertyName: "_listContainerRef", first: true, predicate: ["renderersContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_container", first: true, predicate: ["container"], descendants: true, read: (ElementRef) }, { propertyName: "_list", first: true, predicate: ["list"], descendants: true, read: (ElementRef) }, { propertyName: "_snapContainerRef", first: true, predicate: ["snapRendererContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_snappedContainer", first: true, predicate: ["snapped"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <ul #list part=\"list\" class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </ul>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.ShadowDom });
1996
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgVirtualListComponent, selector: "ng-virtual-list", inputs: { items: "items", snap: "snap", enabledBufferOptimization: "enabledBufferOptimization", itemRenderer: "itemRenderer", stickyMap: "stickyMap", itemSize: "itemSize", dynamicSize: "dynamicSize", direction: "direction", itemsOffset: "itemsOffset", trackBy: "trackBy", snappingMethod: "snappingMethod" }, outputs: { onScroll: "onScroll", onScrollEnd: "onScrollEnd" }, viewQueries: [{ propertyName: "_listContainerRef", first: true, predicate: ["renderersContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_container", first: true, predicate: ["container"], descendants: true, read: (ElementRef) }, { propertyName: "_list", first: true, predicate: ["list"], descendants: true, read: (ElementRef) }, { propertyName: "_snapContainerRef", first: true, predicate: ["snapRendererContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "_snappedContainer", first: true, predicate: ["snapped"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <ul #list part=\"list\" class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </ul>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.horizontal) .ngvl__list{display:inline-flex}:host(.horizontal) .ngvl__scroller{overflow:auto hidden}:host(.vertical) .ngvl__scroller{overflow:hidden auto}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.ShadowDom });
1917
1997
  }
1918
1998
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgVirtualListComponent, decorators: [{
1919
1999
  type: Component,
1920
- args: [{ selector: 'ng-virtual-list', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.ShadowDom, template: "<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <ul #list part=\"list\" class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </ul>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}\n"] }]
2000
+ args: [{ selector: 'ng-virtual-list', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.ShadowDom, template: "<div *ngIf=\"snap\" #snapped part=\"snapped-item\" class=\"ngvl__list-snapper\">\r\n <ng-container #snapRendererContainer></ng-container>\r\n</div>\r\n<div #container part=\"scroller\" class=\"ngvl__scroller\">\r\n <ul #list part=\"list\" class=\"ngvl__list\">\r\n <ng-container #renderersContainer></ng-container>\r\n </ul>\r\n</div>", styles: [":host{position:relative;display:block;width:400px;overflow:hidden}:host(.horizontal){height:48px}:host(.horizontal) .ngvl__list{display:inline-flex}:host(.horizontal) .ngvl__scroller{overflow:auto hidden}:host(.vertical) .ngvl__scroller{overflow:hidden auto}:host(.vertical){height:320px}.ngvl__scroller{overflow:auto;width:100%;height:100%}.ngvl__list-snapper{pointer-events:none;position:absolute;list-style:none;left:0;top:0;z-index:1}.ngvl__list{position:relative;list-style:none;padding:0;margin:0;width:100%;height:100%}\n"] }]
1921
2001
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { _listContainerRef: [{
1922
2002
  type: ViewChild,
1923
2003
  args: ['renderersContainer', { read: ViewContainerRef }]