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.
- package/README.md +1 -1
- package/esm2022/lib/components/ng-virtual-list-item.component.mjs +5 -4
- package/esm2022/lib/models/render-item-config.model.mjs +1 -1
- package/esm2022/lib/models/sticky-map.model.mjs +1 -1
- package/esm2022/lib/ng-virtual-list.component.mjs +8 -8
- package/esm2022/lib/utils/toggleClassName.mjs +4 -4
- package/esm2022/lib/utils/trackBox.mjs +76 -17
- package/esm2022/lib/utils/tracker.mjs +23 -3
- package/fesm2022/ng-virtual-list.mjs +111 -31
- package/fesm2022/ng-virtual-list.mjs.map +1 -1
- package/lib/models/render-item-config.model.d.ts +4 -0
- package/lib/models/sticky-map.model.d.ts +4 -2
- package/lib/ng-virtual-list.component.d.ts +1 -0
- package/lib/utils/toggleClassName.d.ts +1 -1
- package/package.json +1 -1
|
@@ -60,7 +60,17 @@ export class Tracker {
|
|
|
60
60
|
}
|
|
61
61
|
}
|
|
62
62
|
comp.instance.item = item;
|
|
63
|
-
|
|
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
|
-
|
|
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":"AAYA;;;;;GAKG;AACH,MAAM,OAAO,OAAO;IAChB;;OAEG;IACK,0BAA0B,GAA6B,EAAE,CAAC;IAElE,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;IAED;;OAEG;IACK,SAAS,GAAgD,EAAE,CAAC;IAEpE,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAEO,qBAAqB,CAAU;IAEvC,IAAI,oBAAoB,CAAC,CAAS;QAC9B,IAAI,CAAC,qBAAqB,GAAG,CAAC,CAAC;IACnC,CAAC;IAED,YAAY,oBAA4B;QACpC,IAAI,CAAC,qBAAqB,GAAG,oBAAoB,CAAC;IACtD,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAiB,EAAE,UAAkC,EAAE,eAAmD,EAC5G,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;QAC7H,IAAI,gBAAgB,GAAG,KAAK,CAAC;QAE7B,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,KAAK,IAAI,EAAE;wBACvC,MAAM,qBAAqB,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;4BACvD,OAAO,CAAC,CAAC,QAAQ,CAAC,EAAE,KAAK,MAAM,CAAC;wBACpC,CAAC,CAAC,CAAC;wBACH,IAAI,qBAAqB,GAAG,CAAC,CAAC,EAAE;4BAC5B,IAAI,eAAe,EAAE;gCACjB,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,EAAE;oCAC3D,gBAAgB,GAAG,IAAI,CAAC;oCACxB,eAAe,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;oCACrC,eAAe,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;iCACnC;6BACJ;4BACD,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;4BAE1B,IAAI,eAAe,EAAE;gCACjB,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,EAAE;oCAC3D,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;iCACxB;qCAAM;oCACH,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;iCACxB;6BACJ;iCAAM;gCACH,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;6BACxB;4BACD,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,IAAI,GAAG,cAAc,CAAC,KAAK,EAAE,EAAE,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;gBACrD,IAAI,IAAI,EAAE;oBACN,IAAI,eAAe,EAAE;wBACjB,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,EAAE;4BAC3D,gBAAgB,GAAG,IAAI,CAAC;4BACxB,eAAe,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;4BACrC,eAAe,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;yBACnC;qBACJ;oBACD,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;oBAC1B,IAAI,eAAe,EAAE;wBACjB,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,EAAE;4BAC3D,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;yBACxB;6BAAM;4BACH,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;yBACxB;qBACJ;yBAAM;wBACH,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;qBACxB;oBAED,IAAI,IAAI,CAAC,SAAS,EAAE;wBAChB,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;qBAC3D;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;QAED,IAAI,CAAC,gBAAgB,EAAE;YACnB,IAAI,eAAe,EAAE;gBACjB,eAAe,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,CAAC;gBACrC,eAAe,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;aACnC;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/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 =
|
|
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 =
|
|
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,
|
|
266
|
+
const toggleClassName = (el, className, removeClassName) => {
|
|
266
267
|
if (!el.classList.contains(className)) {
|
|
267
268
|
el.classList.add(className);
|
|
268
269
|
}
|
|
269
|
-
|
|
270
|
-
el.classList.remove(
|
|
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
|
-
|
|
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
|
-
|
|
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]
|
|
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
|
|
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]
|
|
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]
|
|
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
|
-
|
|
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
|
|
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,
|
|
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 }]
|