ng-virtual-list 14.0.13 → 14.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.
- package/esm2020/lib/components/ng-virtual-list-item.component.mjs +2 -2
- package/esm2020/lib/const/index.mjs +2 -3
- package/esm2020/lib/ng-virtual-list.component.mjs +72 -193
- package/esm2020/lib/utils/cacheMap.mjs +15 -7
- package/esm2020/lib/utils/trackBox.mjs +38 -8
- package/esm2020/lib/utils/tracker.mjs +17 -24
- package/fesm2015/ng-virtual-list.mjs +135 -226
- package/fesm2015/ng-virtual-list.mjs.map +1 -1
- package/fesm2020/ng-virtual-list.mjs +136 -227
- package/fesm2020/ng-virtual-list.mjs.map +1 -1
- package/lib/components/ng-virtual-list-item.component.d.ts +1 -1
- package/lib/const/index.d.ts +1 -2
- package/lib/ng-virtual-list.component.d.ts +4 -17
- package/lib/utils/tracker.d.ts +10 -4
- package/package.json +1 -1
|
@@ -34,29 +34,24 @@ export class Tracker {
|
|
|
34
34
|
/**
|
|
35
35
|
* tracking by propName
|
|
36
36
|
*/
|
|
37
|
-
track(items, components,
|
|
37
|
+
track(items, components, direction) {
|
|
38
38
|
if (!items) {
|
|
39
39
|
return;
|
|
40
40
|
}
|
|
41
|
-
const idPropName = this._trackingPropertyName, untrackedItems = [...components];
|
|
42
|
-
for (let i = 0, l = items.length; i < l; i++) {
|
|
41
|
+
const idPropName = this._trackingPropertyName, untrackedItems = [...components], isDown = direction === 0 || direction === 1;
|
|
42
|
+
for (let i = isDown ? 0 : items.length - 1, l = isDown ? items.length : 0; isDown ? i < l : i >= l; isDown ? i++ : i--) {
|
|
43
43
|
const item = items[i], itemTrackingProperty = item[idPropName];
|
|
44
44
|
if (this._trackMap) {
|
|
45
|
-
const diId = this._trackMap[itemTrackingProperty];
|
|
46
45
|
if (this._trackMap.hasOwnProperty(itemTrackingProperty)) {
|
|
47
|
-
const
|
|
48
|
-
const
|
|
49
|
-
if (
|
|
46
|
+
const diId = this._trackMap[itemTrackingProperty], compIndex = this._displayObjectIndexMapById[diId], comp = components[compIndex];
|
|
47
|
+
const compId = comp?.instance?.id;
|
|
48
|
+
if (comp !== undefined && compId == diId) {
|
|
50
49
|
const indexByUntrackedItems = untrackedItems.findIndex(v => {
|
|
51
|
-
return v.instance.id
|
|
50
|
+
return v.instance.id == compId;
|
|
52
51
|
});
|
|
53
52
|
if (indexByUntrackedItems > -1) {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
if (afterComponentSetup !== undefined) {
|
|
57
|
-
afterComponentSetup(el.instance, item);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
53
|
+
comp.instance.item = item;
|
|
54
|
+
comp.instance.show();
|
|
60
55
|
untrackedItems.splice(indexByUntrackedItems, 1);
|
|
61
56
|
continue;
|
|
62
57
|
}
|
|
@@ -67,20 +62,18 @@ export class Tracker {
|
|
|
67
62
|
if (untrackedItems.length > 0) {
|
|
68
63
|
const el = untrackedItems.shift(), item = items[i];
|
|
69
64
|
if (el) {
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
this._trackMap[itemTrackingProperty] = el.instance.id;
|
|
74
|
-
}
|
|
75
|
-
if (afterComponentSetup !== undefined) {
|
|
76
|
-
afterComponentSetup(el.instance, item);
|
|
77
|
-
}
|
|
65
|
+
el.instance.item = item;
|
|
66
|
+
if (this._trackMap) {
|
|
67
|
+
this._trackMap[itemTrackingProperty] = el.instance.id;
|
|
78
68
|
}
|
|
79
69
|
}
|
|
80
70
|
}
|
|
81
71
|
}
|
|
82
72
|
if (untrackedItems.length) {
|
|
83
|
-
|
|
73
|
+
for (let i = 0, l = untrackedItems.length; i < l; i++) {
|
|
74
|
+
const comp = untrackedItems[i];
|
|
75
|
+
comp.instance.hide();
|
|
76
|
+
}
|
|
84
77
|
}
|
|
85
78
|
}
|
|
86
79
|
untrackComponentByIdProperty(component) {
|
|
@@ -96,4 +89,4 @@ export class Tracker {
|
|
|
96
89
|
this._trackMap = null;
|
|
97
90
|
}
|
|
98
91
|
}
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tracker.js","sourceRoot":"","sources":["../../../../../projects/ng-virtual-list/src/lib/utils/tracker.ts"],"names":[],"mappings":"AAYA;;;;;GAKG;AACH,MAAM,OAAO,OAAO;IAiChB,YAAY,oBAA4B;QAhCxC;;WAEG;QACK,+BAA0B,GAA6B,EAAE,CAAC;QAclE;;WAEG;QACK,cAAS,GAAgD,EAAE,CAAC;QAahE,IAAI,CAAC,qBAAqB,GAAG,oBAAoB,CAAC;IACtD,CAAC;IA7BD,IAAI,yBAAyB,CAAC,CAA2B;QACrD,IAAI,IAAI,CAAC,0BAA0B,KAAK,CAAC,EAAE;YACvC,OAAO;SACV;QAED,IAAI,CAAC,0BAA0B,GAAG,CAAC,CAAC;IACxC,CAAC;IAED,IAAI,yBAAyB;QACzB,OAAO,IAAI,CAAC,0BAA0B,CAAC;IAC3C,CAAC;IAOD,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAID,IAAI,oBAAoB,CAAC,CAAS;QAC9B,IAAI,CAAC,qBAAqB,GAAG,CAAC,CAAC;IACnC,CAAC;IAMD;;OAEG;IACH,KAAK,CAAC,KAAiB,EAAE,UAAkC,EACvD,SAA0B;QAC1B,IAAI,CAAC,KAAK,EAAE;YACR,OAAO;SACV;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,qBAAqB,EAAE,cAAc,GAAG,CAAC,GAAG,UAAU,CAAC,EAAE,MAAM,GAAG,SAAS,KAAK,CAAC,IAAI,SAAS,KAAK,CAAC,CAAC;QAE7H,KAAK,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE;YACpH,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,oBAAoB,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;YAE/D,IAAI,IAAI,CAAC,SAAS,EAAE;gBAChB,IAAI,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,oBAAoB,CAAC,EAAE;oBACrD,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,EAC7C,SAAS,GAAG,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,EAAE,IAAI,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC;oBAEpF,MAAM,MAAM,GAAG,IAAI,EAAE,QAAQ,EAAE,EAAE,CAAC;oBAClC,IAAI,IAAI,KAAK,SAAS,IAAI,MAAM,IAAI,IAAI,EAAE;wBACtC,MAAM,qBAAqB,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;4BACvD,OAAO,CAAC,CAAC,QAAQ,CAAC,EAAE,IAAI,MAAM,CAAC;wBACnC,CAAC,CAAC,CAAC;wBACH,IAAI,qBAAqB,GAAG,CAAC,CAAC,EAAE;4BAC5B,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;4BAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;4BACrB,cAAc,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC;4BAChD,SAAS;yBACZ;qBACJ;oBACD,OAAO,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;iBAC/C;aACJ;YAED,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC3B,MAAM,EAAE,GAAG,cAAc,CAAC,KAAK,EAAE,EAAE,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;gBACnD,IAAI,EAAE,EAAE;oBACJ,EAAE,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;oBAExB,IAAI,IAAI,CAAC,SAAS,EAAE;wBAChB,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC;qBACzD;iBACJ;aACJ;SACJ;QAED,IAAI,cAAc,CAAC,MAAM,EAAE;YACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBACnD,MAAM,IAAI,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;gBAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;aACxB;SACJ;IACL,CAAC;IAED,4BAA4B,CAAC,SAAa;QACtC,IAAI,CAAC,SAAS,EAAE;YACZ,OAAO;SACV;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,qBAAqB,CAAC;QAElD,IAAI,IAAI,CAAC,SAAS,IAAK,SAAiB,CAAC,cAAc,CAAC,KAAK,SAAS,EAAE;YACpE,OAAO,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;SACzC;IACL,CAAC;IAED,OAAO;QACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IAC1B,CAAC;CACJ","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/14.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>>,\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\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                            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 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._trackMap[itemTrackingProperty] = el.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\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}"]}
|