react-native-nitro-list 0.1.2 → 0.1.3
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 +16 -44
- package/ios/HybridNitroList.swift +7 -5
- package/lib/commonjs/index.js +31 -3
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/layout/MutableLinearLayout.js.map +1 -1
- package/lib/commonjs/native/NitroListView.js +20 -0
- package/lib/commonjs/native/NitroListView.js.map +1 -0
- package/lib/commonjs/recycler/CellPool.js +5 -18
- package/lib/commonjs/recycler/CellPool.js.map +1 -1
- package/lib/commonjs/recycler/{RecyclerList.js → NitroList.js} +91 -92
- package/lib/commonjs/recycler/NitroList.js.map +1 -0
- package/lib/commonjs/scroll/useScrollVelocity.js +20 -0
- package/lib/commonjs/scroll/useScrollVelocity.js.map +1 -0
- package/lib/commonjs/{native/NitroList.types.js → specs/NitroList.nitro.js} +1 -1
- package/lib/commonjs/{native/NitroList.types.js.map → specs/NitroList.nitro.js.map} +1 -1
- package/lib/commonjs/types/CellType.js +25 -0
- package/lib/commonjs/types/CellType.js.map +1 -1
- package/lib/commonjs/types/recycler/CellPool.js +42 -0
- package/lib/commonjs/types/recycler/CellPool.js.map +1 -0
- package/lib/commonjs/types/recycler/{RecyclerListProps.js → NitroListProps.js} +1 -1
- package/lib/commonjs/types/recycler/NitroListProps.js.map +1 -0
- package/lib/commonjs/types/recycler/{RecyclerCellInstance.js → RecyclerCell.js} +1 -1
- package/lib/commonjs/types/recycler/RecyclerCell.js.map +1 -0
- package/lib/commonjs/windowing/computeVisibleItemRange.js +22 -32
- package/lib/commonjs/windowing/computeVisibleItemRange.js.map +1 -1
- package/lib/module/index.js +5 -1
- package/lib/module/index.js.map +1 -1
- package/lib/module/layout/MutableLinearLayout.js.map +1 -1
- package/lib/module/native/NitroListView.js +17 -0
- package/lib/module/native/NitroListView.js.map +1 -0
- package/lib/module/recycler/CellPool.js +5 -18
- package/lib/module/recycler/CellPool.js.map +1 -1
- package/lib/module/recycler/NitroList.js +220 -0
- package/lib/module/recycler/NitroList.js.map +1 -0
- package/lib/module/scroll/useScrollVelocity.js +16 -0
- package/lib/module/scroll/useScrollVelocity.js.map +1 -0
- package/lib/module/specs/NitroList.nitro.js +4 -0
- package/lib/module/{native/NitroList.types.js.map → specs/NitroList.nitro.js.map} +1 -1
- package/lib/module/types/CellType.js +20 -0
- package/lib/module/types/CellType.js.map +1 -1
- package/lib/module/types/recycler/CellPool.js +37 -0
- package/lib/module/types/recycler/CellPool.js.map +1 -0
- package/lib/module/types/recycler/NitroListProps.js +4 -0
- package/lib/module/types/recycler/NitroListProps.js.map +1 -0
- package/lib/module/types/recycler/RecyclerCell.js +4 -0
- package/lib/module/types/recycler/RecyclerCell.js.map +1 -0
- package/lib/module/windowing/computeVisibleItemRange.js +22 -32
- package/lib/module/windowing/computeVisibleItemRange.js.map +1 -1
- package/lib/typescript/src/index.d.ts +3 -1
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/native/NitroListView.d.ts +20 -0
- package/lib/typescript/src/native/NitroListView.d.ts.map +1 -0
- package/lib/typescript/src/recycler/CellPool.d.ts +4 -7
- package/lib/typescript/src/recycler/CellPool.d.ts.map +1 -1
- package/lib/typescript/src/recycler/NitroList.d.ts +4 -0
- package/lib/typescript/src/recycler/NitroList.d.ts.map +1 -0
- package/lib/typescript/src/scroll/useScrollVelocity.d.ts +2 -0
- package/lib/typescript/src/scroll/useScrollVelocity.d.ts.map +1 -0
- package/lib/typescript/src/specs/NitroList.nitro.d.ts +26 -0
- package/lib/typescript/src/specs/NitroList.nitro.d.ts.map +1 -0
- package/lib/typescript/src/types/CellKey.d.ts +1 -9
- package/lib/typescript/src/types/CellKey.d.ts.map +1 -1
- package/lib/typescript/src/types/CellType.d.ts +12 -1
- package/lib/typescript/src/types/CellType.d.ts.map +1 -1
- package/lib/typescript/src/types/recycler/CellPool.d.ts +16 -0
- package/lib/typescript/src/types/recycler/CellPool.d.ts.map +1 -0
- package/lib/typescript/src/types/recycler/{RecyclerListProps.d.ts → NitroListProps.d.ts} +3 -3
- package/lib/typescript/src/types/recycler/NitroListProps.d.ts.map +1 -0
- package/lib/typescript/src/types/recycler/RecyclerCell.d.ts +12 -0
- package/lib/typescript/src/types/recycler/RecyclerCell.d.ts.map +1 -0
- package/lib/typescript/src/types/recycler/RecyclerItemRenderer.d.ts +6 -2
- package/lib/typescript/src/types/recycler/RecyclerItemRenderer.d.ts.map +1 -1
- package/lib/typescript/src/types/recycler/index.d.ts +2 -2
- package/lib/typescript/src/types/recycler/index.d.ts.map +1 -1
- package/lib/typescript/src/windowing/computeVisibleItemRange.d.ts +16 -12
- package/lib/typescript/src/windowing/computeVisibleItemRange.d.ts.map +1 -1
- package/nitro.json +5 -5
- package/nitrogen/generated/android/NitroList+autolinking.cmake +2 -2
- package/nitrogen/generated/android/NitroListOnLoad.cpp +2 -2
- package/nitrogen/generated/android/c++/{JHybridNitroLayoutEngineSpec.cpp → JHybridNitroListSpec.cpp} +15 -15
- package/nitrogen/generated/android/c++/{JHybridNitroLayoutEngineSpec.hpp → JHybridNitroListSpec.hpp} +11 -11
- package/nitrogen/generated/android/c++/{JLayoutRect.hpp → JItemLayout.hpp} +10 -10
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrolist/{HybridNitroLayoutEngineSpec.kt → HybridNitroListSpec.kt} +7 -7
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrolist/{LayoutRect.kt → ItemLayout.kt} +5 -5
- package/nitrogen/generated/ios/NitroList-Swift-Cxx-Bridge.cpp +9 -9
- package/nitrogen/generated/ios/NitroList-Swift-Cxx-Bridge.hpp +27 -27
- package/nitrogen/generated/ios/NitroList-Swift-Cxx-Umbrella.hpp +8 -8
- package/nitrogen/generated/ios/c++/{HybridNitroLayoutEngineSpecSwift.cpp → HybridNitroListSpecSwift.cpp} +2 -2
- package/nitrogen/generated/ios/c++/{HybridNitroLayoutEngineSpecSwift.hpp → HybridNitroListSpecSwift.hpp} +16 -16
- package/nitrogen/generated/ios/swift/HybridNitroListSpec.swift +56 -0
- package/nitrogen/generated/ios/swift/{HybridNitroLayoutEngineSpec_cxx.swift → HybridNitroListSpec_cxx.swift} +23 -23
- package/nitrogen/generated/ios/swift/{LayoutRect.swift → ItemLayout.swift} +5 -5
- package/nitrogen/generated/shared/c++/{HybridNitroLayoutEngineSpec.cpp → HybridNitroListSpec.cpp} +4 -4
- package/nitrogen/generated/shared/c++/{HybridNitroLayoutEngineSpec.hpp → HybridNitroListSpec.hpp} +13 -13
- package/nitrogen/generated/shared/c++/{LayoutRect.hpp → ItemLayout.hpp} +11 -11
- package/package.json +5 -5
- package/src/index.ts +7 -1
- package/src/layout/MutableLinearLayout.ts +1 -1
- package/src/native/NitroListView.ts +22 -0
- package/src/recycler/CellPool.ts +10 -24
- package/src/recycler/NitroList.tsx +317 -0
- package/src/scroll/useScrollVelocity.ts +16 -0
- package/src/specs/NitroList.nitro.ts +29 -0
- package/src/types/CellKey.ts +2 -9
- package/src/types/CellType.ts +8 -9
- package/src/types/recycler/CellPool.ts +45 -0
- package/src/types/recycler/{RecyclerListProps.ts → NitroListProps.ts} +2 -2
- package/src/types/recycler/RecyclerCell.ts +12 -0
- package/src/types/recycler/RecyclerItemRenderer.ts +6 -2
- package/src/types/recycler/index.ts +2 -2
- package/src/windowing/computeVisibleItemRange.ts +42 -38
- package/lib/commonjs/NitroList.js +0 -9
- package/lib/commonjs/NitroList.js.map +0 -1
- package/lib/commonjs/native/NitroLayoutEngine.js +0 -9
- package/lib/commonjs/native/NitroLayoutEngine.js.map +0 -1
- package/lib/commonjs/native/NitroRecyclerView.js +0 -9
- package/lib/commonjs/native/NitroRecyclerView.js.map +0 -1
- package/lib/commonjs/recycler/RecyclerList.js.map +0 -1
- package/lib/commonjs/specs/nitro-layout-engine.nitro.js +0 -6
- package/lib/commonjs/specs/nitro-layout-engine.nitro.js.map +0 -1
- package/lib/commonjs/types/recycler/RecyclerCellInstance.js.map +0 -1
- package/lib/commonjs/types/recycler/RecyclerListProps.js.map +0 -1
- package/lib/module/NitroList.js +0 -5
- package/lib/module/NitroList.js.map +0 -1
- package/lib/module/native/NitroLayoutEngine.js +0 -5
- package/lib/module/native/NitroLayoutEngine.js.map +0 -1
- package/lib/module/native/NitroList.types.js +0 -4
- package/lib/module/native/NitroRecyclerView.js +0 -5
- package/lib/module/native/NitroRecyclerView.js.map +0 -1
- package/lib/module/recycler/RecyclerList.js +0 -221
- package/lib/module/recycler/RecyclerList.js.map +0 -1
- package/lib/module/specs/nitro-layout-engine.nitro.js +0 -4
- package/lib/module/specs/nitro-layout-engine.nitro.js.map +0 -1
- package/lib/module/types/recycler/RecyclerCellInstance.js +0 -4
- package/lib/module/types/recycler/RecyclerCellInstance.js.map +0 -1
- package/lib/module/types/recycler/RecyclerListProps.js +0 -4
- package/lib/module/types/recycler/RecyclerListProps.js.map +0 -1
- package/lib/typescript/src/NitroList.d.ts +0 -5
- package/lib/typescript/src/NitroList.d.ts.map +0 -1
- package/lib/typescript/src/native/NitroLayoutEngine.d.ts +0 -3
- package/lib/typescript/src/native/NitroLayoutEngine.d.ts.map +0 -1
- package/lib/typescript/src/native/NitroList.types.d.ts +0 -9
- package/lib/typescript/src/native/NitroList.types.d.ts.map +0 -1
- package/lib/typescript/src/native/NitroRecyclerView.d.ts +0 -5
- package/lib/typescript/src/native/NitroRecyclerView.d.ts.map +0 -1
- package/lib/typescript/src/recycler/RecyclerList.d.ts +0 -4
- package/lib/typescript/src/recycler/RecyclerList.d.ts.map +0 -1
- package/lib/typescript/src/specs/nitro-layout-engine.nitro.d.ts +0 -14
- package/lib/typescript/src/specs/nitro-layout-engine.nitro.d.ts.map +0 -1
- package/lib/typescript/src/types/recycler/RecyclerCellInstance.d.ts +0 -37
- package/lib/typescript/src/types/recycler/RecyclerCellInstance.d.ts.map +0 -1
- package/lib/typescript/src/types/recycler/RecyclerListProps.d.ts.map +0 -1
- package/nitrogen/generated/ios/swift/HybridNitroLayoutEngineSpec.swift +0 -56
- package/src/NitroList.ts +0 -8
- package/src/native/NitroLayoutEngine.ts +0 -7
- package/src/native/NitroList.types.ts +0 -13
- package/src/native/NitroRecyclerView.ts +0 -8
- package/src/recycler/RecyclerList.tsx +0 -304
- package/src/specs/nitro-layout-engine.nitro.ts +0 -17
- package/src/types/recycler/RecyclerCellInstance.ts +0 -40
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.CellPool = void 0;
|
|
7
|
+
/**
|
|
8
|
+
* Owns recycled physical cells.
|
|
9
|
+
* Enforces hard caps.
|
|
10
|
+
*/
|
|
11
|
+
class CellPool {
|
|
12
|
+
pools = new Map();
|
|
13
|
+
maxPerType = new Map();
|
|
14
|
+
hasType(type) {
|
|
15
|
+
return this.pools.has(type);
|
|
16
|
+
}
|
|
17
|
+
registerType(type, maxCount) {
|
|
18
|
+
if (this.pools.has(type)) return;
|
|
19
|
+
this.pools.set(type, []);
|
|
20
|
+
this.maxPerType.set(type, maxCount);
|
|
21
|
+
}
|
|
22
|
+
acquire(type) {
|
|
23
|
+
const bucket = this.pools.get(type);
|
|
24
|
+
if (!bucket || bucket.length === 0) return null;
|
|
25
|
+
return bucket.pop() ?? null;
|
|
26
|
+
}
|
|
27
|
+
release(cell) {
|
|
28
|
+
const bucket = this.pools.get(cell.type);
|
|
29
|
+
const max = this.maxPerType.get(cell.type);
|
|
30
|
+
if (!bucket || max === undefined) return;
|
|
31
|
+
cell.index = -1;
|
|
32
|
+
if (bucket.length >= max) return;
|
|
33
|
+
bucket.push(cell);
|
|
34
|
+
}
|
|
35
|
+
clear() {
|
|
36
|
+
for (const bucket of this.pools.values()) {
|
|
37
|
+
bucket.length = 0;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.CellPool = CellPool;
|
|
42
|
+
//# sourceMappingURL=CellPool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["CellPool","pools","Map","maxPerType","hasType","type","has","registerType","maxCount","set","acquire","bucket","get","length","pop","release","cell","max","undefined","index","push","clear","values","exports"],"sourceRoot":"../../../../src","sources":["types/recycler/CellPool.ts"],"mappings":";;;;;;AAIA;AACA;AACA;AACA;AACO,MAAMA,QAAQ,CAAyB;EAC3BC,KAAK,GAAG,IAAIC,GAAG,CAAgB,CAAC;EAChCC,UAAU,GAAG,IAAID,GAAG,CAAmB,CAAC;EAEzDE,OAAOA,CAACC,IAAc,EAAW;IAC/B,OAAO,IAAI,CAACJ,KAAK,CAACK,GAAG,CAACD,IAAI,CAAC;EAC7B;EAEAE,YAAYA,CAACF,IAAc,EAAEG,QAAgB,EAAQ;IACnD,IAAI,IAAI,CAACP,KAAK,CAACK,GAAG,CAACD,IAAI,CAAC,EAAE;IAC1B,IAAI,CAACJ,KAAK,CAACQ,GAAG,CAACJ,IAAI,EAAE,EAAE,CAAC;IACxB,IAAI,CAACF,UAAU,CAACM,GAAG,CAACJ,IAAI,EAAEG,QAAQ,CAAC;EACrC;EAEAE,OAAOA,CAACL,IAAc,EAAY;IAChC,MAAMM,MAAM,GAAG,IAAI,CAACV,KAAK,CAACW,GAAG,CAACP,IAAI,CAAC;IACnC,IAAI,CAACM,MAAM,IAAIA,MAAM,CAACE,MAAM,KAAK,CAAC,EAAE,OAAO,IAAI;IAC/C,OAAOF,MAAM,CAACG,GAAG,CAAC,CAAC,IAAI,IAAI;EAC7B;EAEAC,OAAOA,CAACC,IAAO,EAAQ;IACrB,MAAML,MAAM,GAAG,IAAI,CAACV,KAAK,CAACW,GAAG,CAACI,IAAI,CAACX,IAAI,CAAC;IACxC,MAAMY,GAAG,GAAG,IAAI,CAACd,UAAU,CAACS,GAAG,CAACI,IAAI,CAACX,IAAI,CAAC;IAC1C,IAAI,CAACM,MAAM,IAAIM,GAAG,KAAKC,SAAS,EAAE;IAElCF,IAAI,CAACG,KAAK,GAAG,CAAC,CAAC;IACf,IAAIR,MAAM,CAACE,MAAM,IAAII,GAAG,EAAE;IAE1BN,MAAM,CAACS,IAAI,CAACJ,IAAI,CAAC;EACnB;EAEAK,KAAKA,CAAA,EAAS;IACZ,KAAK,MAAMV,MAAM,IAAI,IAAI,CAACV,KAAK,CAACqB,MAAM,CAAC,CAAC,EAAE;MACxCX,MAAM,CAACE,MAAM,GAAG,CAAC;IACnB;EACF;AACF;AAACU,OAAA,CAAAvB,QAAA,GAAAA,QAAA","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../../src","sources":["types/recycler/NitroListProps.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../../src","sources":["types/recycler/RecyclerCell.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -5,15 +5,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports.computeVisibleItemRange = computeVisibleItemRange;
|
|
7
7
|
/**
|
|
8
|
-
* Computes
|
|
9
|
-
*
|
|
10
|
-
* Responsibilities:
|
|
11
|
-
* - Determine which items intersect the visible window
|
|
12
|
-
* - Stay independent of rendering and recycling
|
|
13
|
-
*
|
|
14
|
-
* Performance:
|
|
15
|
-
* - O(log n) to locate the first visible item
|
|
16
|
-
* - O(k) to expand to the last visible item (k = visible count)
|
|
8
|
+
* Computes visible item range using binary search + forward scan.
|
|
9
|
+
* Type-safe and defensive against invalid indices.
|
|
17
10
|
*/
|
|
18
11
|
function computeVisibleItemRange(input) {
|
|
19
12
|
const {
|
|
@@ -23,49 +16,46 @@ function computeVisibleItemRange(input) {
|
|
|
23
16
|
buffer,
|
|
24
17
|
isVertical
|
|
25
18
|
} = input;
|
|
26
|
-
const
|
|
27
|
-
if (
|
|
19
|
+
const count = layouts.length;
|
|
20
|
+
if (count === 0) return null;
|
|
28
21
|
const windowStart = Math.max(0, offset - buffer);
|
|
29
22
|
const windowEnd = offset + viewportSize + buffer;
|
|
30
23
|
|
|
31
|
-
//
|
|
32
|
-
// Binary search:
|
|
33
|
-
//
|
|
34
|
-
// --------------------------------------------------
|
|
24
|
+
// ------------------------------
|
|
25
|
+
// Binary search: first visible
|
|
26
|
+
// ------------------------------
|
|
35
27
|
let low = 0;
|
|
36
|
-
let high =
|
|
37
|
-
let
|
|
28
|
+
let high = count - 1;
|
|
29
|
+
let first = count;
|
|
38
30
|
while (low <= high) {
|
|
39
31
|
const mid = low + high >>> 1;
|
|
40
32
|
const rect = layouts[mid];
|
|
33
|
+
if (!rect) break;
|
|
41
34
|
const start = isVertical ? rect.y : rect.x;
|
|
42
35
|
const size = isVertical ? rect.height : rect.width;
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
firstVisibleIndex = mid;
|
|
36
|
+
if (start + size >= windowStart) {
|
|
37
|
+
first = mid;
|
|
46
38
|
high = mid - 1;
|
|
47
39
|
} else {
|
|
48
40
|
low = mid + 1;
|
|
49
41
|
}
|
|
50
42
|
}
|
|
51
|
-
if (
|
|
52
|
-
return null;
|
|
53
|
-
}
|
|
43
|
+
if (first === count) return null;
|
|
54
44
|
|
|
55
|
-
//
|
|
56
|
-
// Linear scan
|
|
57
|
-
//
|
|
58
|
-
|
|
59
|
-
let
|
|
60
|
-
for (let i = firstVisibleIndex + 1; i < itemCount; i++) {
|
|
45
|
+
// ------------------------------
|
|
46
|
+
// Linear scan: last visible
|
|
47
|
+
// ------------------------------
|
|
48
|
+
let last = first;
|
|
49
|
+
for (let i = first + 1; i < count; i++) {
|
|
61
50
|
const rect = layouts[i];
|
|
51
|
+
if (!rect) break;
|
|
62
52
|
const start = isVertical ? rect.y : rect.x;
|
|
63
53
|
if (start > windowEnd) break;
|
|
64
|
-
|
|
54
|
+
last = i;
|
|
65
55
|
}
|
|
66
56
|
return {
|
|
67
|
-
startIndex:
|
|
68
|
-
endIndex:
|
|
57
|
+
startIndex: first,
|
|
58
|
+
endIndex: last
|
|
69
59
|
};
|
|
70
60
|
}
|
|
71
61
|
//# sourceMappingURL=computeVisibleItemRange.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["computeVisibleItemRange","input","layouts","offset","viewportSize","buffer","isVertical","
|
|
1
|
+
{"version":3,"names":["computeVisibleItemRange","input","layouts","offset","viewportSize","buffer","isVertical","count","length","windowStart","Math","max","windowEnd","low","high","first","mid","rect","start","y","x","size","height","width","last","i","startIndex","endIndex"],"sourceRoot":"../../../src","sources":["windowing/computeVisibleItemRange.ts"],"mappings":";;;;;;AAgBA;AACA;AACA;AACA;AACO,SAASA,uBAAuBA,CACrCC,KAAY,EACS;EACrB,MAAM;IACJC,OAAO;IACPC,MAAM;IACNC,YAAY;IACZC,MAAM;IACNC;EACF,CAAC,GAAGL,KAAK;EAET,MAAMM,KAAK,GAAGL,OAAO,CAACM,MAAM;EAC5B,IAAID,KAAK,KAAK,CAAC,EAAE,OAAO,IAAI;EAE5B,MAAME,WAAW,GAAGC,IAAI,CAACC,GAAG,CAAC,CAAC,EAAER,MAAM,GAAGE,MAAM,CAAC;EAChD,MAAMO,SAAS,GAAGT,MAAM,GAAGC,YAAY,GAAGC,MAAM;;EAEhD;EACA;EACA;EACA,IAAIQ,GAAG,GAAG,CAAC;EACX,IAAIC,IAAI,GAAGP,KAAK,GAAG,CAAC;EACpB,IAAIQ,KAAK,GAAGR,KAAK;EAEjB,OAAOM,GAAG,IAAIC,IAAI,EAAE;IAClB,MAAME,GAAG,GAAIH,GAAG,GAAGC,IAAI,KAAM,CAAC;IAC9B,MAAMG,IAAI,GAAGf,OAAO,CAACc,GAAG,CAAC;IACzB,IAAI,CAACC,IAAI,EAAE;IAEX,MAAMC,KAAK,GAAGZ,UAAU,GAAGW,IAAI,CAACE,CAAC,GAAGF,IAAI,CAACG,CAAC;IAC1C,MAAMC,IAAI,GAAGf,UAAU,GAAGW,IAAI,CAACK,MAAM,GAAGL,IAAI,CAACM,KAAK;IAElD,IAAIL,KAAK,GAAGG,IAAI,IAAIZ,WAAW,EAAE;MAC/BM,KAAK,GAAGC,GAAG;MACXF,IAAI,GAAGE,GAAG,GAAG,CAAC;IAChB,CAAC,MAAM;MACLH,GAAG,GAAGG,GAAG,GAAG,CAAC;IACf;EACF;EAEA,IAAID,KAAK,KAAKR,KAAK,EAAE,OAAO,IAAI;;EAEhC;EACA;EACA;EACA,IAAIiB,IAAI,GAAGT,KAAK;EAEhB,KAAK,IAAIU,CAAC,GAAGV,KAAK,GAAG,CAAC,EAAEU,CAAC,GAAGlB,KAAK,EAAEkB,CAAC,EAAE,EAAE;IACtC,MAAMR,IAAI,GAAGf,OAAO,CAACuB,CAAC,CAAC;IACvB,IAAI,CAACR,IAAI,EAAE;IAEX,MAAMC,KAAK,GAAGZ,UAAU,GAAGW,IAAI,CAACE,CAAC,GAAGF,IAAI,CAACG,CAAC;IAC1C,IAAIF,KAAK,GAAGN,SAAS,EAAE;IAEvBY,IAAI,GAAGC,CAAC;EACV;EAEA,OAAO;IACLC,UAAU,EAAEX,KAAK;IACjBY,QAAQ,EAAEH;EACZ,CAAC;AACH","ignoreList":[]}
|
package/lib/module/index.js
CHANGED
|
@@ -1,4 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
// Export the Native View
|
|
4
|
+
export * from './native/NitroListView';
|
|
5
|
+
// Export the JSI Specs
|
|
6
|
+
export * from './specs/NitroList.nitro';
|
|
7
|
+
export { default as NitroList } from './recycler/NitroList';
|
|
4
8
|
//# sourceMappingURL=index.js.map
|
package/lib/module/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["
|
|
1
|
+
{"version":3,"names":["default","NitroList"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":";;AACA;AACA,cAAc,wBAAwB;AACtC;AACA,cAAc,yBAAyB;AAEvC,SAASA,OAAO,IAAIC,SAAS,QAAQ,sBAAsB","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DEFAULT_ITEM_SPACING","MutableLinearLayout","layouts","contentSize","constructor","axis","isVertical","compute","input","crossAxisSize","itemMainAxisSizes","padding","itemSpacing","itemCount","length","Array","cursor","start","i","mainAxisSize","x","y","width","height","end","getLayouts","getContentSize","reset"],"sourceRoot":"../../../src","sources":["layout/MutableLinearLayout.ts"],"mappings":";;
|
|
1
|
+
{"version":3,"names":["DEFAULT_ITEM_SPACING","MutableLinearLayout","layouts","contentSize","constructor","axis","isVertical","compute","input","crossAxisSize","itemMainAxisSizes","padding","itemSpacing","itemCount","length","Array","cursor","start","i","mainAxisSize","x","y","width","height","end","getLayouts","getContentSize","reset"],"sourceRoot":"../../../src","sources":["layout/MutableLinearLayout.ts"],"mappings":";;AAGA,SAASA,oBAAoB,QAAQ,4BAA4B;;AAGjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,mBAAmB,CAAC;EAG/B;EACQC,OAAO,GAAiB,EAAE;;EAElC;EACQC,WAAW,GAAG,CAAC;EAEvBC,WAAWA,CAACC,IAAU,EAAE;IACtB,IAAI,CAACC,UAAU,GAAGD,IAAI,KAAK,UAAU;EACvC;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEE,OAAOA,CAACC,KAAwB,EAAQ;IACtC,MAAM;MACJC,aAAa;MACbC,iBAAiB;MACjBC,OAAO;MACPC,WAAW,GAAGZ;IAChB,CAAC,GAAGQ,KAAK;IAET,MAAMK,SAAS,GAAGH,iBAAiB,CAACI,MAAM;IAC1C,MAAMZ,OAAqB,GAAG,IAAIa,KAAK,CAACF,SAAS,CAAC;IAElD,IAAIG,MAAM,GAAGL,OAAO,CAACM,KAAK;IAE1B,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGL,SAAS,EAAEK,CAAC,EAAE,EAAE;MAClC,MAAMC,YAAY,GAAGT,iBAAiB,CAACQ,CAAC,CAAE;MAE1ChB,OAAO,CAACgB,CAAC,CAAC,GAAG,IAAI,CAACZ,UAAU,GACxB;QACEc,CAAC,EAAE,CAAC;QACJC,CAAC,EAAEL,MAAM;QACTM,KAAK,EAAEb,aAAa;QACpBc,MAAM,EAAEJ;MACV,CAAC,GACD;QACEC,CAAC,EAAEJ,MAAM;QACTK,CAAC,EAAE,CAAC;QACJC,KAAK,EAAEH,YAAY;QACnBI,MAAM,EAAEd;MACV,CAAC;MAELO,MAAM,IAAIG,YAAY;;MAEtB;MACA,IAAID,CAAC,GAAGL,SAAS,GAAG,CAAC,EAAE;QACrBG,MAAM,IAAIJ,WAAW;MACvB;IACF;IAEA,IAAI,CAACV,OAAO,GAAGA,OAAO;IACtB,IAAI,CAACC,WAAW,GAAGa,MAAM,GAAGL,OAAO,CAACa,GAAG;EACzC;;EAEA;AACF;AACA;AACA;AACA;AACA;EACEC,UAAUA,CAAA,EAA0B;IAClC,OAAO,IAAI,CAACvB,OAAO;EACrB;;EAEA;AACF;AACA;AACA;EACEwB,cAAcA,CAAA,EAAW;IACvB,OAAO,IAAI,CAACvB,WAAW;EACzB;;EAEA;AACF;AACA;AACA;EACEwB,KAAKA,CAAA,EAAS;IACZ,IAAI,CAACzB,OAAO,GAAG,EAAE;IACjB,IAAI,CAACC,WAAW,GAAG,CAAC;EACtB;AACF","ignoreList":[]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { requireNativeComponent } from 'react-native';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Props for the NitroListView.
|
|
7
|
+
* * We extend ViewProps so that developers can use standard styles
|
|
8
|
+
* like 'flex: 1' or 'backgroundColor' on the list.
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* The Native Component that maps to the physical view in Swift/Kotlin.
|
|
13
|
+
* * 'NitroListView' is the "Secret Handshake" name. It must match
|
|
14
|
+
* the name exported by your Native ViewManagers.
|
|
15
|
+
*/
|
|
16
|
+
export const NitroListView = requireNativeComponent('NitroListView');
|
|
17
|
+
//# sourceMappingURL=NitroListView.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["requireNativeComponent","NitroListView"],"sourceRoot":"../../../src","sources":["native/NitroListView.ts"],"mappings":";;AAAA,SAASA,sBAAsB,QAAwB,cAAc;;AAErE;AACA;AACA;AACA;AACA;;AASA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,aAAa,GACxBD,sBAAsB,CAAqB,eAAe,CAAC","ignoreList":[]}
|
|
@@ -3,39 +3,26 @@
|
|
|
3
3
|
export class CellPool {
|
|
4
4
|
pools = new Map();
|
|
5
5
|
maxPerType = new Map();
|
|
6
|
-
|
|
7
|
-
/** ✅ NEW: check if a type is registered */
|
|
8
6
|
hasType(type) {
|
|
9
7
|
return this.pools.has(type);
|
|
10
8
|
}
|
|
11
9
|
registerType(type, maxCount) {
|
|
12
|
-
if (this.
|
|
13
|
-
this.maxPerType.set(type, maxCount);
|
|
10
|
+
if (this.pools.has(type)) return;
|
|
14
11
|
this.pools.set(type, []);
|
|
12
|
+
this.maxPerType.set(type, maxCount);
|
|
15
13
|
}
|
|
16
14
|
acquire(type) {
|
|
17
15
|
const bucket = this.pools.get(type);
|
|
18
16
|
if (!bucket || bucket.length === 0) return null;
|
|
19
|
-
return bucket.pop();
|
|
17
|
+
return bucket.pop() ?? null;
|
|
20
18
|
}
|
|
21
19
|
release(cell) {
|
|
22
|
-
const
|
|
23
|
-
|
|
24
|
-
} = cell;
|
|
25
|
-
const bucket = this.pools.get(type);
|
|
26
|
-
const max = this.maxPerType.get(type);
|
|
20
|
+
const bucket = this.pools.get(cell.type);
|
|
21
|
+
const max = this.maxPerType.get(cell.type);
|
|
27
22
|
if (!bucket || max === undefined) return;
|
|
28
23
|
cell.index = -1;
|
|
29
24
|
if (bucket.length >= max) return;
|
|
30
25
|
bucket.push(cell);
|
|
31
26
|
}
|
|
32
|
-
clear() {
|
|
33
|
-
for (const bucket of this.pools.values()) {
|
|
34
|
-
bucket.length = 0;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
getPoolSize(type) {
|
|
38
|
-
return this.pools.get(type)?.length ?? 0;
|
|
39
|
-
}
|
|
40
27
|
}
|
|
41
28
|
//# sourceMappingURL=CellPool.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["CellPool","pools","Map","maxPerType","hasType","type","has","registerType","maxCount","set","acquire","bucket","get","length","pop","release","cell","max","undefined","index","push"
|
|
1
|
+
{"version":3,"names":["CellPool","pools","Map","maxPerType","hasType","type","has","registerType","maxCount","set","acquire","bucket","get","length","pop","release","cell","max","undefined","index","push"],"sourceRoot":"../../../src","sources":["recycler/CellPool.ts"],"mappings":";;AAGA,OAAO,MAAMA,QAAQ,CAA8B;EAChCC,KAAK,GAAG,IAAIC,GAAG,CAAgB,CAAC;EAChCC,UAAU,GAAG,IAAID,GAAG,CAAmB,CAAC;EAEzDE,OAAOA,CAACC,IAAc,EAAW;IAC/B,OAAO,IAAI,CAACJ,KAAK,CAACK,GAAG,CAACD,IAAI,CAAC;EAC7B;EAEAE,YAAYA,CAACF,IAAc,EAAEG,QAAgB,EAAQ;IACnD,IAAI,IAAI,CAACP,KAAK,CAACK,GAAG,CAACD,IAAI,CAAC,EAAE;IAC1B,IAAI,CAACJ,KAAK,CAACQ,GAAG,CAACJ,IAAI,EAAE,EAAE,CAAC;IACxB,IAAI,CAACF,UAAU,CAACM,GAAG,CAACJ,IAAI,EAAEG,QAAQ,CAAC;EACrC;EAEAE,OAAOA,CAACL,IAAc,EAAY;IAChC,MAAMM,MAAM,GAAG,IAAI,CAACV,KAAK,CAACW,GAAG,CAACP,IAAI,CAAC;IACnC,IAAI,CAACM,MAAM,IAAIA,MAAM,CAACE,MAAM,KAAK,CAAC,EAAE,OAAO,IAAI;IAC/C,OAAOF,MAAM,CAACG,GAAG,CAAC,CAAC,IAAI,IAAI;EAC7B;EAEAC,OAAOA,CAACC,IAAO,EAAQ;IACrB,MAAML,MAAM,GAAG,IAAI,CAACV,KAAK,CAACW,GAAG,CAACI,IAAI,CAACX,IAAI,CAAC;IACxC,MAAMY,GAAG,GAAG,IAAI,CAACd,UAAU,CAACS,GAAG,CAACI,IAAI,CAACX,IAAI,CAAC;IAC1C,IAAI,CAACM,MAAM,IAAIM,GAAG,KAAKC,SAAS,EAAE;IAElCF,IAAI,CAACG,KAAK,GAAG,CAAC,CAAC;IACf,IAAIR,MAAM,CAACE,MAAM,IAAII,GAAG,EAAE;IAC1BN,MAAM,CAACS,IAAI,CAACJ,IAAI,CAAC;EACnB;AACF","ignoreList":[]}
|
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React, { useRef, useEffect, useState } from 'react';
|
|
4
|
+
import { ScrollView, View, StyleSheet } from 'react-native';
|
|
5
|
+
import { MutableLinearLayout } from '../layout/MutableLinearLayout';
|
|
6
|
+
import { computeVisibleItemRange } from '../windowing';
|
|
7
|
+
import { CellPool } from './CellPool';
|
|
8
|
+
|
|
9
|
+
/* ========================================================= */
|
|
10
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
11
|
+
const DEFAULT_VIEWPORT_SIZE = 800;
|
|
12
|
+
const DEFAULT_ITEM_SIZE = 60;
|
|
13
|
+
const SCROLL_EVENT_THROTTLE = 16;
|
|
14
|
+
|
|
15
|
+
/* ========================================================= */
|
|
16
|
+
/* Internal (mutable) cell */
|
|
17
|
+
/* ========================================================= */
|
|
18
|
+
|
|
19
|
+
/* ========================================================= */
|
|
20
|
+
/* NitroList */
|
|
21
|
+
/* ========================================================= */
|
|
22
|
+
|
|
23
|
+
export default function NitroList(props) {
|
|
24
|
+
const {
|
|
25
|
+
data,
|
|
26
|
+
renderItem,
|
|
27
|
+
getCellType,
|
|
28
|
+
scrollDirection = 'vertical',
|
|
29
|
+
bufferRatio = 1.3,
|
|
30
|
+
containerCrossAxisSize,
|
|
31
|
+
itemMainAxisSizes,
|
|
32
|
+
padding = {
|
|
33
|
+
start: 0,
|
|
34
|
+
end: 0
|
|
35
|
+
},
|
|
36
|
+
itemSpacing
|
|
37
|
+
} = props;
|
|
38
|
+
const isVertical = scrollDirection === 'vertical';
|
|
39
|
+
const [, forceRender] = useState(0);
|
|
40
|
+
const DEBUG = true;
|
|
41
|
+
|
|
42
|
+
/* ======================================================= */
|
|
43
|
+
/* Layout engine (recomputed when signature changes) */
|
|
44
|
+
/* ======================================================= */
|
|
45
|
+
|
|
46
|
+
const layoutEngineRef = useRef(null);
|
|
47
|
+
const layoutSignatureRef = useRef('');
|
|
48
|
+
const layoutSignature = [scrollDirection, containerCrossAxisSize, data.length, itemMainAxisSizes, padding.start, padding.end, itemSpacing ?? 'none'].join('|');
|
|
49
|
+
if (layoutEngineRef.current === null || layoutSignatureRef.current !== layoutSignature) {
|
|
50
|
+
const engine = new MutableLinearLayout(scrollDirection);
|
|
51
|
+
engine.compute({
|
|
52
|
+
crossAxisSize: containerCrossAxisSize,
|
|
53
|
+
itemMainAxisSizes,
|
|
54
|
+
padding,
|
|
55
|
+
itemSpacing
|
|
56
|
+
});
|
|
57
|
+
layoutEngineRef.current = engine;
|
|
58
|
+
layoutSignatureRef.current = layoutSignature;
|
|
59
|
+
}
|
|
60
|
+
const layouts = layoutEngineRef.current.getLayouts();
|
|
61
|
+
const contentSize = layoutEngineRef.current.getContentSize();
|
|
62
|
+
|
|
63
|
+
/* ======================================================= */
|
|
64
|
+
/* Scroll metrics */
|
|
65
|
+
/* ======================================================= */
|
|
66
|
+
|
|
67
|
+
const scrollOffsetRef = useRef(0);
|
|
68
|
+
const viewportSizeRef = useRef(DEFAULT_VIEWPORT_SIZE);
|
|
69
|
+
|
|
70
|
+
/* ======================================================= */
|
|
71
|
+
/* Cell pool */
|
|
72
|
+
/* ======================================================= */
|
|
73
|
+
|
|
74
|
+
const cellPoolRef = useRef(new CellPool());
|
|
75
|
+
const activeCellsRef = useRef([]);
|
|
76
|
+
const nextKeyRef = useRef(0);
|
|
77
|
+
const createCell = type => ({
|
|
78
|
+
key: nextKeyRef.current++,
|
|
79
|
+
type,
|
|
80
|
+
index: -1,
|
|
81
|
+
active: false
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
/* ======================================================= */
|
|
85
|
+
/* Visible window coordination */
|
|
86
|
+
/* ======================================================= */
|
|
87
|
+
|
|
88
|
+
const updateVisibleCells = () => {
|
|
89
|
+
const range = computeVisibleItemRange({
|
|
90
|
+
layouts,
|
|
91
|
+
offset: scrollOffsetRef.current,
|
|
92
|
+
viewportSize: viewportSizeRef.current,
|
|
93
|
+
buffer: viewportSizeRef.current * bufferRatio,
|
|
94
|
+
isVertical
|
|
95
|
+
});
|
|
96
|
+
if (range === null) return;
|
|
97
|
+
if (DEBUG) {
|
|
98
|
+
console.log('[NitroList] range:', range.startIndex, range.endIndex);
|
|
99
|
+
}
|
|
100
|
+
const active = activeCellsRef.current;
|
|
101
|
+
|
|
102
|
+
// 1. Mark all inactive
|
|
103
|
+
for (const cell of active) {
|
|
104
|
+
cell.active = false;
|
|
105
|
+
}
|
|
106
|
+
let writeIndex = 0;
|
|
107
|
+
|
|
108
|
+
// 2. Activate visible range
|
|
109
|
+
for (let index = range.startIndex; index <= range.endIndex; index++) {
|
|
110
|
+
const item = data[index];
|
|
111
|
+
if (item === undefined) continue;
|
|
112
|
+
const type = getCellType(item, index);
|
|
113
|
+
|
|
114
|
+
// Seed pool once per type
|
|
115
|
+
if (!cellPoolRef.current.hasType(type)) {
|
|
116
|
+
const maxCells = Math.ceil(viewportSizeRef.current / DEFAULT_ITEM_SIZE * bufferRatio) + 2;
|
|
117
|
+
cellPoolRef.current.registerType(type, maxCells);
|
|
118
|
+
for (let i = 0; i < maxCells; i++) {
|
|
119
|
+
cellPoolRef.current.release(createCell(type));
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
let cell = cellPoolRef.current.acquire(type);
|
|
123
|
+
if (cell === null) {
|
|
124
|
+
const reusable = active.find(c => !c.active && c.type === type);
|
|
125
|
+
cell = reusable ?? createCell(type);
|
|
126
|
+
}
|
|
127
|
+
cell.index = index;
|
|
128
|
+
cell.active = true;
|
|
129
|
+
active[writeIndex++] = cell;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
// 3. Recycle unused cells
|
|
133
|
+
for (let i = writeIndex; i < active.length; i++) {
|
|
134
|
+
const cell = active[i];
|
|
135
|
+
if (cell === undefined) continue;
|
|
136
|
+
cell.index = -1;
|
|
137
|
+
cell.active = false;
|
|
138
|
+
cellPoolRef.current.release(cell);
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
// 4. Compact once
|
|
142
|
+
if (active.length !== writeIndex) {
|
|
143
|
+
active.length = writeIndex;
|
|
144
|
+
forceRender(v => v + 1);
|
|
145
|
+
}
|
|
146
|
+
};
|
|
147
|
+
|
|
148
|
+
/* ======================================================= */
|
|
149
|
+
/* Handlers */
|
|
150
|
+
/* ======================================================= */
|
|
151
|
+
|
|
152
|
+
const onScroll = e => {
|
|
153
|
+
scrollOffsetRef.current = isVertical ? e.nativeEvent.contentOffset.y : e.nativeEvent.contentOffset.x;
|
|
154
|
+
updateVisibleCells();
|
|
155
|
+
};
|
|
156
|
+
const onLayout = e => {
|
|
157
|
+
viewportSizeRef.current = isVertical ? e.nativeEvent.layout.height : e.nativeEvent.layout.width;
|
|
158
|
+
updateVisibleCells();
|
|
159
|
+
};
|
|
160
|
+
useEffect(() => {
|
|
161
|
+
updateVisibleCells();
|
|
162
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
163
|
+
}, []);
|
|
164
|
+
if (DEBUG) {
|
|
165
|
+
console.log('[NitroList] layouts:', layouts.length);
|
|
166
|
+
console.log('[NitroList] contentSize:', contentSize);
|
|
167
|
+
console.log('[NitroList] data.length:', data.length);
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
/* ======================================================= */
|
|
171
|
+
/* Render */
|
|
172
|
+
/* ======================================================= */
|
|
173
|
+
|
|
174
|
+
return /*#__PURE__*/_jsx(ScrollView, {
|
|
175
|
+
onScroll: onScroll,
|
|
176
|
+
onLayout: onLayout,
|
|
177
|
+
horizontal: !isVertical,
|
|
178
|
+
scrollEventThrottle: SCROLL_EVENT_THROTTLE,
|
|
179
|
+
removeClippedSubviews: true,
|
|
180
|
+
children: /*#__PURE__*/_jsx(View, {
|
|
181
|
+
style: isVertical ? {
|
|
182
|
+
height: contentSize
|
|
183
|
+
} : {
|
|
184
|
+
width: contentSize
|
|
185
|
+
},
|
|
186
|
+
children: activeCellsRef.current.map(cell => {
|
|
187
|
+
const layout = layouts[cell.index];
|
|
188
|
+
const item = data[cell.index];
|
|
189
|
+
if (layout === undefined || item === undefined) {
|
|
190
|
+
return null;
|
|
191
|
+
}
|
|
192
|
+
return /*#__PURE__*/_jsx(View, {
|
|
193
|
+
style: [styles.cell, isVertical ? {
|
|
194
|
+
top: layout.y,
|
|
195
|
+
height: layout.height,
|
|
196
|
+
width: layout.width
|
|
197
|
+
} : {
|
|
198
|
+
left: layout.x,
|
|
199
|
+
width: layout.width,
|
|
200
|
+
height: layout.height
|
|
201
|
+
}],
|
|
202
|
+
children: renderItem({
|
|
203
|
+
item,
|
|
204
|
+
index: cell.index,
|
|
205
|
+
cell
|
|
206
|
+
})
|
|
207
|
+
}, cell.key);
|
|
208
|
+
})
|
|
209
|
+
})
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
/* ========================================================= */
|
|
214
|
+
|
|
215
|
+
const styles = StyleSheet.create({
|
|
216
|
+
cell: {
|
|
217
|
+
position: 'absolute'
|
|
218
|
+
}
|
|
219
|
+
});
|
|
220
|
+
//# sourceMappingURL=NitroList.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","useRef","useEffect","useState","ScrollView","View","StyleSheet","MutableLinearLayout","computeVisibleItemRange","CellPool","jsx","_jsx","DEFAULT_VIEWPORT_SIZE","DEFAULT_ITEM_SIZE","SCROLL_EVENT_THROTTLE","NitroList","props","data","renderItem","getCellType","scrollDirection","bufferRatio","containerCrossAxisSize","itemMainAxisSizes","padding","start","end","itemSpacing","isVertical","forceRender","DEBUG","layoutEngineRef","layoutSignatureRef","layoutSignature","length","join","current","engine","compute","crossAxisSize","layouts","getLayouts","contentSize","getContentSize","scrollOffsetRef","viewportSizeRef","cellPoolRef","activeCellsRef","nextKeyRef","createCell","type","key","index","active","updateVisibleCells","range","offset","viewportSize","buffer","console","log","startIndex","endIndex","cell","writeIndex","item","undefined","hasType","maxCells","Math","ceil","registerType","i","release","acquire","reusable","find","c","v","onScroll","e","nativeEvent","contentOffset","y","x","onLayout","layout","height","width","horizontal","scrollEventThrottle","removeClippedSubviews","children","style","map","styles","top","left","create","position"],"sourceRoot":"../../../src","sources":["recycler/NitroList.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
export function createScrollVelocityTracker() {
|
|
4
|
+
let lastOffset = 0;
|
|
5
|
+
let lastTime = Date.now();
|
|
6
|
+
return function getVelocity(offset) {
|
|
7
|
+
const now = Date.now();
|
|
8
|
+
const dt = now - lastTime;
|
|
9
|
+
const dy = Math.abs(offset - lastOffset);
|
|
10
|
+
lastOffset = offset;
|
|
11
|
+
lastTime = now;
|
|
12
|
+
if (dt === 0) return 0;
|
|
13
|
+
return dy / dt; // px per ms
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=useScrollVelocity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createScrollVelocityTracker","lastOffset","lastTime","Date","now","getVelocity","offset","dt","dy","Math","abs"],"sourceRoot":"../../../src","sources":["scroll/useScrollVelocity.ts"],"mappings":";;AAAA,OAAO,SAASA,2BAA2BA,CAAA,EAAG;EAC5C,IAAIC,UAAU,GAAG,CAAC;EAClB,IAAIC,QAAQ,GAAGC,IAAI,CAACC,GAAG,CAAC,CAAC;EAEzB,OAAO,SAASC,WAAWA,CAACC,MAAc,EAAU;IAClD,MAAMF,GAAG,GAAGD,IAAI,CAACC,GAAG,CAAC,CAAC;IACtB,MAAMG,EAAE,GAAGH,GAAG,GAAGF,QAAQ;IACzB,MAAMM,EAAE,GAAGC,IAAI,CAACC,GAAG,CAACJ,MAAM,GAAGL,UAAU,CAAC;IAExCA,UAAU,GAAGK,MAAM;IACnBJ,QAAQ,GAAGE,GAAG;IAEd,IAAIG,EAAE,KAAK,CAAC,EAAE,OAAO,CAAC;IACtB,OAAOC,EAAE,GAAGD,EAAE,EAAC;EACjB,CAAC;AACH","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["specs/NitroList.nitro.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -1,2 +1,22 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Logical cell type.
|
|
5
|
+
*
|
|
6
|
+
* Used to group compatible cells for recycling.
|
|
7
|
+
*
|
|
8
|
+
* Cross-platform equivalent:
|
|
9
|
+
* - Android: viewType
|
|
10
|
+
* - iOS: reuseIdentifier
|
|
11
|
+
*
|
|
12
|
+
* NOTE:
|
|
13
|
+
* This is a branded type to prevent accidental mixing
|
|
14
|
+
* with keys, indexes, or other strings/numbers.
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Helper to create a CellType safely.
|
|
19
|
+
* Keeps ergonomics simple for users.
|
|
20
|
+
*/
|
|
21
|
+
export const createCellType = value => value;
|
|
2
22
|
//# sourceMappingURL=CellType.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[],"sourceRoot":"../../../src","sources":["types/CellType.ts"],"mappings":"","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["createCellType","value"],"sourceRoot":"../../../src","sources":["types/CellType.ts"],"mappings":";;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAKA;AACA;AACA;AACA;AACA,OAAO,MAAMA,cAAc,GACzBC,KAAa,IACAA,KAAiB","ignoreList":[]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Owns recycled physical cells.
|
|
5
|
+
* Enforces hard caps.
|
|
6
|
+
*/
|
|
7
|
+
export class CellPool {
|
|
8
|
+
pools = new Map();
|
|
9
|
+
maxPerType = new Map();
|
|
10
|
+
hasType(type) {
|
|
11
|
+
return this.pools.has(type);
|
|
12
|
+
}
|
|
13
|
+
registerType(type, maxCount) {
|
|
14
|
+
if (this.pools.has(type)) return;
|
|
15
|
+
this.pools.set(type, []);
|
|
16
|
+
this.maxPerType.set(type, maxCount);
|
|
17
|
+
}
|
|
18
|
+
acquire(type) {
|
|
19
|
+
const bucket = this.pools.get(type);
|
|
20
|
+
if (!bucket || bucket.length === 0) return null;
|
|
21
|
+
return bucket.pop() ?? null;
|
|
22
|
+
}
|
|
23
|
+
release(cell) {
|
|
24
|
+
const bucket = this.pools.get(cell.type);
|
|
25
|
+
const max = this.maxPerType.get(cell.type);
|
|
26
|
+
if (!bucket || max === undefined) return;
|
|
27
|
+
cell.index = -1;
|
|
28
|
+
if (bucket.length >= max) return;
|
|
29
|
+
bucket.push(cell);
|
|
30
|
+
}
|
|
31
|
+
clear() {
|
|
32
|
+
for (const bucket of this.pools.values()) {
|
|
33
|
+
bucket.length = 0;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=CellPool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["CellPool","pools","Map","maxPerType","hasType","type","has","registerType","maxCount","set","acquire","bucket","get","length","pop","release","cell","max","undefined","index","push","clear","values"],"sourceRoot":"../../../../src","sources":["types/recycler/CellPool.ts"],"mappings":";;AAIA;AACA;AACA;AACA;AACA,OAAO,MAAMA,QAAQ,CAAyB;EAC3BC,KAAK,GAAG,IAAIC,GAAG,CAAgB,CAAC;EAChCC,UAAU,GAAG,IAAID,GAAG,CAAmB,CAAC;EAEzDE,OAAOA,CAACC,IAAc,EAAW;IAC/B,OAAO,IAAI,CAACJ,KAAK,CAACK,GAAG,CAACD,IAAI,CAAC;EAC7B;EAEAE,YAAYA,CAACF,IAAc,EAAEG,QAAgB,EAAQ;IACnD,IAAI,IAAI,CAACP,KAAK,CAACK,GAAG,CAACD,IAAI,CAAC,EAAE;IAC1B,IAAI,CAACJ,KAAK,CAACQ,GAAG,CAACJ,IAAI,EAAE,EAAE,CAAC;IACxB,IAAI,CAACF,UAAU,CAACM,GAAG,CAACJ,IAAI,EAAEG,QAAQ,CAAC;EACrC;EAEAE,OAAOA,CAACL,IAAc,EAAY;IAChC,MAAMM,MAAM,GAAG,IAAI,CAACV,KAAK,CAACW,GAAG,CAACP,IAAI,CAAC;IACnC,IAAI,CAACM,MAAM,IAAIA,MAAM,CAACE,MAAM,KAAK,CAAC,EAAE,OAAO,IAAI;IAC/C,OAAOF,MAAM,CAACG,GAAG,CAAC,CAAC,IAAI,IAAI;EAC7B;EAEAC,OAAOA,CAACC,IAAO,EAAQ;IACrB,MAAML,MAAM,GAAG,IAAI,CAACV,KAAK,CAACW,GAAG,CAACI,IAAI,CAACX,IAAI,CAAC;IACxC,MAAMY,GAAG,GAAG,IAAI,CAACd,UAAU,CAACS,GAAG,CAACI,IAAI,CAACX,IAAI,CAAC;IAC1C,IAAI,CAACM,MAAM,IAAIM,GAAG,KAAKC,SAAS,EAAE;IAElCF,IAAI,CAACG,KAAK,GAAG,CAAC,CAAC;IACf,IAAIR,MAAM,CAACE,MAAM,IAAII,GAAG,EAAE;IAE1BN,MAAM,CAACS,IAAI,CAACJ,IAAI,CAAC;EACnB;EAEAK,KAAKA,CAAA,EAAS;IACZ,KAAK,MAAMV,MAAM,IAAI,IAAI,CAACV,KAAK,CAACqB,MAAM,CAAC,CAAC,EAAE;MACxCX,MAAM,CAACE,MAAM,GAAG,CAAC;IACnB;EACF;AACF","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../../src","sources":["types/recycler/NitroListProps.ts"],"mappings":"","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"../../../../src","sources":["types/recycler/RecyclerCell.ts"],"mappings":"","ignoreList":[]}
|