react-native-list 1.0.1 → 2.0.0-alpha.2

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.
Files changed (224) hide show
  1. package/README.md +186 -32
  2. package/ReactNativeList.podspec +39 -0
  3. package/android/CMakeLists.txt +48 -0
  4. package/android/build.gradle +151 -0
  5. package/android/fix-prefab.gradle +51 -0
  6. package/android/gradle.properties +5 -0
  7. package/android/src/main/AndroidManifest.xml +2 -0
  8. package/android/src/main/cpp/JHybridUiListModule.cpp +192 -0
  9. package/android/src/main/cpp/JHybridUiListModule.h +50 -0
  10. package/android/src/main/cpp/cpp-adapter.cpp +12 -0
  11. package/android/src/main/java/com/hannojg/reactnativelist/ReactNativeListPackage.kt +27 -0
  12. package/android/src/main/java/com/margelo/nitro/reactnativelist/HybridNativeListDataSource.kt +146 -0
  13. package/android/src/main/java/com/margelo/nitro/reactnativelist/HybridNativeListLayout.kt +86 -0
  14. package/android/src/main/java/com/margelo/nitro/reactnativelist/HybridUiListModule.kt +116 -0
  15. package/android/src/main/java/com/margelo/nitro/reactnativelist/HybridUiListView.kt +410 -0
  16. package/android/src/main/java/com/margelo/nitro/reactnativelist/HybridViewHolder.kt +9 -0
  17. package/android/src/main/java/com/margelo/nitro/reactnativelist/NativeListAdapter.kt +217 -0
  18. package/ios/DataSource/HybridNativeListDataSource.swift +213 -0
  19. package/ios/HybridObjects/HybridUiListModule.swift +49 -0
  20. package/ios/HybridObjects/HybridViewHolder.swift +16 -0
  21. package/ios/Layout/HybridNativeListLayout.swift +128 -0
  22. package/ios/Utils/ErrorUtils.h +26 -0
  23. package/ios/Utils/HybridIOSWorkletsModuleProxyHolder.swift +10 -0
  24. package/ios/Utils/SurfaceHelper.h +20 -0
  25. package/ios/Utils/SurfaceHelper.mm +144 -0
  26. package/ios/Utils/SurfacePresenterRegistry.h +17 -0
  27. package/ios/Utils/SurfacePresenterRegistry.m +31 -0
  28. package/ios/Utils/TurboModuleInstaller.h +18 -0
  29. package/ios/Utils/TurboModuleInstaller.mm +267 -0
  30. package/ios/Views/HostCell.swift +216 -0
  31. package/ios/Views/HybridUiListView.swift +695 -0
  32. package/lib/ReactFabricMirror.d.ts +4 -0
  33. package/lib/ReactFabricMirror.js +515 -0
  34. package/lib/UiListModule.d.ts +2 -0
  35. package/lib/UiListModule.js +2 -0
  36. package/lib/index.d.ts +8 -0
  37. package/lib/index.js +21 -0
  38. package/lib/privateGlobals.d.ts +14 -0
  39. package/lib/privateGlobals.js +2 -0
  40. package/lib/renderer/RenderHelper.d.ts +2 -0
  41. package/lib/renderer/RenderHelper.js +11 -0
  42. package/lib/renderer/UiManagerHelper.d.ts +2 -0
  43. package/lib/renderer/UiManagerHelper.js +2 -0
  44. package/lib/renderer/fabric/RenderHelper.d.ts +2 -0
  45. package/lib/renderer/fabric/RenderHelper.js +11 -0
  46. package/lib/renderer/fabric/UiManagerHelper.d.ts +2 -0
  47. package/lib/renderer/fabric/UiManagerHelper.js +2 -0
  48. package/lib/renderer/react/ReactFabricMirror.d.ts +4 -0
  49. package/lib/renderer/react/ReactFabricMirror.js +515 -0
  50. package/lib/renderer/react/ReactFabricRenderer.d.ts +3 -0
  51. package/lib/renderer/react/ReactFabricRenderer.js +9 -0
  52. package/lib/specs/IOSWorkletsModuleProxyHolder.nitro.d.ts +6 -0
  53. package/lib/specs/IOSWorkletsModuleProxyHolder.nitro.js +1 -0
  54. package/lib/specs/UIListModule.nitro.d.ts +9 -0
  55. package/lib/specs/UIListModule.nitro.js +1 -0
  56. package/lib/specs/UIManagerHelper.nitro.d.ts +13 -0
  57. package/lib/specs/UIManagerHelper.nitro.js +1 -0
  58. package/lib/specs/UiListView.nitro.d.ts +20 -0
  59. package/lib/specs/UiListView.nitro.js +1 -0
  60. package/lib/specs/ViewHolder.nitro.d.ts +6 -0
  61. package/lib/specs/ViewHolder.nitro.js +1 -0
  62. package/lib/views/List.d.ts +35 -0
  63. package/lib/views/List.js +225 -0
  64. package/lib/views/UiListHostComponent.d.ts +2 -0
  65. package/lib/views/UiListHostComponent.js +3 -0
  66. package/metro/RendererProxyThreadSwitch.js +66 -0
  67. package/metro-config.d.ts +1 -0
  68. package/metro-config.js +124 -0
  69. package/nitro.json +47 -0
  70. package/nitrogen/generated/.gitattributes +1 -0
  71. package/nitrogen/generated/android/ReactNativeList+autolinking.cmake +99 -0
  72. package/nitrogen/generated/android/ReactNativeList+autolinking.gradle +27 -0
  73. package/nitrogen/generated/android/ReactNativeListOnLoad.cpp +156 -0
  74. package/nitrogen/generated/android/ReactNativeListOnLoad.hpp +34 -0
  75. package/nitrogen/generated/android/c++/JFunc_bool_NativeListItem_NativeListItem.hpp +83 -0
  76. package/nitrogen/generated/android/c++/JFunc_bool_double_NativeListItem_double.hpp +83 -0
  77. package/nitrogen/generated/android/c++/JFunc_double_std__string.hpp +78 -0
  78. package/nitrogen/generated/android/c++/JHybridIOSWorkletsModuleProxyHolderSpec.cpp +49 -0
  79. package/nitrogen/generated/android/c++/JHybridIOSWorkletsModuleProxyHolderSpec.hpp +63 -0
  80. package/nitrogen/generated/android/c++/JHybridNativeLinearListLayoutSpec.cpp +63 -0
  81. package/nitrogen/generated/android/c++/JHybridNativeLinearListLayoutSpec.hpp +65 -0
  82. package/nitrogen/generated/android/c++/JHybridNativeListDataSourceSpec.cpp +101 -0
  83. package/nitrogen/generated/android/c++/JHybridNativeListDataSourceSpec.hpp +70 -0
  84. package/nitrogen/generated/android/c++/JHybridNativeListLayoutSpec.cpp +49 -0
  85. package/nitrogen/generated/android/c++/JHybridNativeListLayoutSpec.hpp +63 -0
  86. package/nitrogen/generated/android/c++/JHybridUiListModuleSpec.cpp +65 -0
  87. package/nitrogen/generated/android/c++/JHybridUiListModuleSpec.hpp +64 -0
  88. package/nitrogen/generated/android/c++/JHybridUiListViewSpec.cpp +92 -0
  89. package/nitrogen/generated/android/c++/JHybridUiListViewSpec.hpp +67 -0
  90. package/nitrogen/generated/android/c++/JHybridViewHolderSpec.cpp +49 -0
  91. package/nitrogen/generated/android/c++/JHybridViewHolderSpec.hpp +63 -0
  92. package/nitrogen/generated/android/c++/JNativeItemSizeEstimate.hpp +61 -0
  93. package/nitrogen/generated/android/c++/JNativeLinearListLayoutConfig.hpp +81 -0
  94. package/nitrogen/generated/android/c++/JNativeLinearListLayoutIOSConfig.hpp +59 -0
  95. package/nitrogen/generated/android/c++/JNativeListItem.hpp +76 -0
  96. package/nitrogen/generated/android/c++/JVariant_NullType_HybridIOSWorkletsModuleProxyHolderSpec.cpp +26 -0
  97. package/nitrogen/generated/android/c++/JVariant_NullType_HybridIOSWorkletsModuleProxyHolderSpec.hpp +72 -0
  98. package/nitrogen/generated/android/c++/views/JHybridUiListViewStateUpdater.cpp +53 -0
  99. package/nitrogen/generated/android/c++/views/JHybridUiListViewStateUpdater.hpp +49 -0
  100. package/nitrogen/generated/android/c++/views/JHybridViewHolderStateUpdater.cpp +53 -0
  101. package/nitrogen/generated/android/c++/views/JHybridViewHolderStateUpdater.hpp +49 -0
  102. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/Func_bool_NativeListItem_NativeListItem.kt +80 -0
  103. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/Func_bool_double_NativeListItem_double.kt +80 -0
  104. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/Func_double_std__string.kt +80 -0
  105. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/HybridIOSWorkletsModuleProxyHolderSpec.kt +52 -0
  106. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/HybridNativeLinearListLayoutSpec.kt +54 -0
  107. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/HybridNativeListDataSourceSpec.kt +87 -0
  108. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/HybridNativeListLayoutSpec.kt +52 -0
  109. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/HybridUiListModuleSpec.kt +59 -0
  110. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/HybridUiListViewSpec.kt +76 -0
  111. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/HybridViewHolderSpec.kt +53 -0
  112. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/NativeItemSizeEstimate.kt +56 -0
  113. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/NativeLinearListLayoutConfig.kt +76 -0
  114. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/NativeLinearListLayoutIOSConfig.kt +51 -0
  115. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/NativeListItem.kt +71 -0
  116. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/ReactNativeListOnLoad.kt +35 -0
  117. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/Variant_NullType_HybridIOSWorkletsModuleProxyHolderSpec.kt +62 -0
  118. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/views/HybridUiListViewManager.kt +80 -0
  119. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/views/HybridUiListViewStateUpdater.kt +23 -0
  120. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/views/HybridViewHolderManager.kt +80 -0
  121. package/nitrogen/generated/android/kotlin/com/margelo/nitro/reactnativelist/views/HybridViewHolderStateUpdater.kt +23 -0
  122. package/nitrogen/generated/ios/ReactNativeList+autolinking.rb +62 -0
  123. package/nitrogen/generated/ios/ReactNativeList-Swift-Cxx-Bridge.cpp +162 -0
  124. package/nitrogen/generated/ios/ReactNativeList-Swift-Cxx-Bridge.hpp +368 -0
  125. package/nitrogen/generated/ios/ReactNativeList-Swift-Cxx-Umbrella.hpp +92 -0
  126. package/nitrogen/generated/ios/ReactNativeListAutolinking.mm +83 -0
  127. package/nitrogen/generated/ios/ReactNativeListAutolinking.swift +86 -0
  128. package/nitrogen/generated/ios/c++/HybridIOSWorkletsModuleProxyHolderSpecSwift.cpp +11 -0
  129. package/nitrogen/generated/ios/c++/HybridIOSWorkletsModuleProxyHolderSpecSwift.hpp +75 -0
  130. package/nitrogen/generated/ios/c++/HybridNativeLinearListLayoutSpecSwift.cpp +11 -0
  131. package/nitrogen/generated/ios/c++/HybridNativeLinearListLayoutSpecSwift.hpp +92 -0
  132. package/nitrogen/generated/ios/c++/HybridNativeListDataSourceSpecSwift.cpp +11 -0
  133. package/nitrogen/generated/ios/c++/HybridNativeListDataSourceSpecSwift.hpp +132 -0
  134. package/nitrogen/generated/ios/c++/HybridNativeListLayoutSpecSwift.cpp +11 -0
  135. package/nitrogen/generated/ios/c++/HybridNativeListLayoutSpecSwift.hpp +75 -0
  136. package/nitrogen/generated/ios/c++/HybridUiListModuleSpecSwift.cpp +11 -0
  137. package/nitrogen/generated/ios/c++/HybridUiListModuleSpecSwift.hpp +93 -0
  138. package/nitrogen/generated/ios/c++/HybridUiListViewSpecSwift.cpp +11 -0
  139. package/nitrogen/generated/ios/c++/HybridUiListViewSpecSwift.hpp +121 -0
  140. package/nitrogen/generated/ios/c++/HybridViewHolderSpecSwift.cpp +11 -0
  141. package/nitrogen/generated/ios/c++/HybridViewHolderSpecSwift.hpp +75 -0
  142. package/nitrogen/generated/ios/c++/views/HybridUiListViewComponent.mm +118 -0
  143. package/nitrogen/generated/ios/c++/views/HybridViewHolderComponent.mm +118 -0
  144. package/nitrogen/generated/ios/swift/Func_bool_NativeListItem_NativeListItem.swift +47 -0
  145. package/nitrogen/generated/ios/swift/Func_bool_double_NativeListItem_double.swift +47 -0
  146. package/nitrogen/generated/ios/swift/Func_double_std__string.swift +47 -0
  147. package/nitrogen/generated/ios/swift/HybridIOSWorkletsModuleProxyHolderSpec.swift +55 -0
  148. package/nitrogen/generated/ios/swift/HybridIOSWorkletsModuleProxyHolderSpec_cxx.swift +128 -0
  149. package/nitrogen/generated/ios/swift/HybridNativeLinearListLayoutSpec.swift +55 -0
  150. package/nitrogen/generated/ios/swift/HybridNativeLinearListLayoutSpec_cxx.swift +140 -0
  151. package/nitrogen/generated/ios/swift/HybridNativeListDataSourceSpec.swift +62 -0
  152. package/nitrogen/generated/ios/swift/HybridNativeListDataSourceSpec_cxx.swift +222 -0
  153. package/nitrogen/generated/ios/swift/HybridNativeListLayoutSpec.swift +55 -0
  154. package/nitrogen/generated/ios/swift/HybridNativeListLayoutSpec_cxx.swift +128 -0
  155. package/nitrogen/generated/ios/swift/HybridUiListModuleSpec.swift +56 -0
  156. package/nitrogen/generated/ios/swift/HybridUiListModuleSpec_cxx.swift +175 -0
  157. package/nitrogen/generated/ios/swift/HybridUiListViewSpec.swift +59 -0
  158. package/nitrogen/generated/ios/swift/HybridUiListViewSpec_cxx.swift +227 -0
  159. package/nitrogen/generated/ios/swift/HybridViewHolderSpec.swift +55 -0
  160. package/nitrogen/generated/ios/swift/HybridViewHolderSpec_cxx.swift +147 -0
  161. package/nitrogen/generated/ios/swift/NativeItemSizeEstimate.swift +60 -0
  162. package/nitrogen/generated/ios/swift/NativeLinearListLayoutConfig.swift +60 -0
  163. package/nitrogen/generated/ios/swift/NativeLinearListLayoutIOSConfig.swift +35 -0
  164. package/nitrogen/generated/ios/swift/NativeListItem.swift +75 -0
  165. package/nitrogen/generated/ios/swift/Variant_NullType__any_HybridIOSWorkletsModuleProxyHolderSpec_.swift +30 -0
  166. package/nitrogen/generated/shared/c++/HybridIOSWorkletsModuleProxyHolderSpec.cpp +21 -0
  167. package/nitrogen/generated/shared/c++/HybridIOSWorkletsModuleProxyHolderSpec.hpp +62 -0
  168. package/nitrogen/generated/shared/c++/HybridNativeLinearListLayoutSpec.cpp +22 -0
  169. package/nitrogen/generated/shared/c++/HybridNativeLinearListLayoutSpec.hpp +67 -0
  170. package/nitrogen/generated/shared/c++/HybridNativeListDataSourceSpec.cpp +28 -0
  171. package/nitrogen/generated/shared/c++/HybridNativeListDataSourceSpec.hpp +72 -0
  172. package/nitrogen/generated/shared/c++/HybridNativeListLayoutSpec.cpp +21 -0
  173. package/nitrogen/generated/shared/c++/HybridNativeListLayoutSpec.hpp +62 -0
  174. package/nitrogen/generated/shared/c++/HybridUiListModuleSpec.cpp +22 -0
  175. package/nitrogen/generated/shared/c++/HybridUiListModuleSpec.hpp +68 -0
  176. package/nitrogen/generated/shared/c++/HybridUiListViewSpec.cpp +25 -0
  177. package/nitrogen/generated/shared/c++/HybridUiListViewSpec.hpp +79 -0
  178. package/nitrogen/generated/shared/c++/HybridUiManagerHelperSpec.cpp +23 -0
  179. package/nitrogen/generated/shared/c++/HybridUiManagerHelperSpec.hpp +65 -0
  180. package/nitrogen/generated/shared/c++/HybridViewHolderSpec.cpp +21 -0
  181. package/nitrogen/generated/shared/c++/HybridViewHolderSpec.hpp +62 -0
  182. package/nitrogen/generated/shared/c++/NativeItemSizeEstimate.hpp +87 -0
  183. package/nitrogen/generated/shared/c++/NativeLinearListLayoutConfig.hpp +105 -0
  184. package/nitrogen/generated/shared/c++/NativeLinearListLayoutIOSConfig.hpp +85 -0
  185. package/nitrogen/generated/shared/c++/NativeListItem.hpp +101 -0
  186. package/nitrogen/generated/shared/c++/views/HybridUiListViewComponent.cpp +72 -0
  187. package/nitrogen/generated/shared/c++/views/HybridUiListViewComponent.hpp +109 -0
  188. package/nitrogen/generated/shared/c++/views/HybridViewHolderComponent.cpp +72 -0
  189. package/nitrogen/generated/shared/c++/views/HybridViewHolderComponent.hpp +109 -0
  190. package/nitrogen/generated/shared/json/UiListViewConfig.json +9 -0
  191. package/nitrogen/generated/shared/json/ViewHolderConfig.json +9 -0
  192. package/package.json +152 -5
  193. package/react-native.config.js +16 -0
  194. package/src/ListDataSource.ts +232 -0
  195. package/src/ListLayout.ts +95 -0
  196. package/src/UiListModule.ts +5 -0
  197. package/src/hooks/useChangeEffect.ts +50 -0
  198. package/src/index.tsx +49 -0
  199. package/src/privateGlobals.ts +20 -0
  200. package/src/renderer/fabric/RenderHelper.ts +29 -0
  201. package/src/renderer/fabric/UiManagerHelper.ts +5 -0
  202. package/src/renderer/react/ReactFabricMirror.bundle.js +1984 -0
  203. package/src/renderer/react/ReactFabricMirror.ts +766 -0
  204. package/src/renderer/react/ReactFabricRenderer.ts +11 -0
  205. package/src/specs/IOSWorkletsModuleProxyHolder.nitro.ts +6 -0
  206. package/src/specs/NativeLinearListLayout.nitro.ts +23 -0
  207. package/src/specs/NativeListDataSource.nitro.ts +28 -0
  208. package/src/specs/NativeListLayout.nitro.ts +6 -0
  209. package/src/specs/UIListModule.nitro.ts +13 -0
  210. package/src/specs/UIManagerHelper.nitro.ts +34 -0
  211. package/src/specs/UiListView.nitro.ts +31 -0
  212. package/src/specs/ViewHolder.nitro.ts +11 -0
  213. package/src/views/List.tsx +525 -0
  214. package/src/views/UiListHostComponent.ts +8 -0
  215. package/FillRateHelper.js +0 -179
  216. package/FlatList.js +0 -494
  217. package/LICENSE.md +0 -31
  218. package/MetroListView.js +0 -166
  219. package/SectionList.js +0 -291
  220. package/ViewabilityHelper.js +0 -260
  221. package/VirtualizeUtils.js +0 -163
  222. package/VirtualizedList.js +0 -861
  223. package/VirtualizedSectionList.js +0 -397
  224. package/index.js +0 -5
@@ -1,260 +0,0 @@
1
- /**
2
- * Copyright (c) 2015-present, Facebook, Inc.
3
- * All rights reserved.
4
- *
5
- * This source code is licensed under the BSD-style license found in the
6
- * LICENSE file in the root directory of this source tree. An additional grant
7
- * of patent rights can be found in the PATENTS file in the same directory.
8
- *
9
- * @flow
10
- */
11
- 'use strict';
12
-
13
- const invariant = require('fbjs/lib/invariant');
14
-
15
- export type ViewToken = {item: any, key: string, index: ?number, isViewable: boolean, section?: any};
16
-
17
- export type ViewabilityConfig = {|
18
- /**
19
- * Minimum amount of time (in milliseconds) that an item must be physically viewable before the
20
- * viewability callback will be fired. A high number means that scrolling through content without
21
- * stopping will not mark the content as viewable.
22
- */
23
- minimumViewTime?: number,
24
-
25
- /**
26
- * Percent of viewport that must be covered for a partially occluded item to count as
27
- * "viewable", 0-100. Fully visible items are always considered viewable. A value of 0 means
28
- * that a single pixel in the viewport makes the item viewable, and a value of 100 means that
29
- * an item must be either entirely visible or cover the entire viewport to count as viewable.
30
- */
31
- viewAreaCoveragePercentThreshold?: number,
32
-
33
- /**
34
- * Similar to `viewAreaPercentThreshold`, but considers the percent of the item that is visible,
35
- * rather than the fraction of the viewable area it covers.
36
- */
37
- itemVisiblePercentThreshold?: number,
38
-
39
- /**
40
- * Nothing is considered viewable until the user scrolls or `recordInteraction` is called after
41
- * render.
42
- */
43
- waitForInteraction?: boolean,
44
- |};
45
-
46
- /**
47
- * A Utility class for calculating viewable items based on current metrics like scroll position and
48
- * layout.
49
- *
50
- * An item is said to be in a "viewable" state when any of the following
51
- * is true for longer than `minimumViewTime` milliseconds (after an interaction if `waitForInteraction`
52
- * is true):
53
- *
54
- * - Occupying >= `viewAreaCoveragePercentThreshold` of the view area XOR fraction of the item
55
- * visible in the view area >= `itemVisiblePercentThreshold`.
56
- * - Entirely visible on screen
57
- */
58
- class ViewabilityHelper {
59
- _config: ViewabilityConfig;
60
- _hasInteracted: boolean = false;
61
- _lastUpdateTime: number = 0;
62
- _timers: Set<number> = new Set();
63
- _viewableIndices: Array<number> = [];
64
- _viewableItems: Map<string, ViewToken> = new Map();
65
-
66
- constructor(config: ViewabilityConfig = {viewAreaCoveragePercentThreshold: 0}) {
67
- this._config = config;
68
- }
69
-
70
- /**
71
- * Cleanup, e.g. on unmount. Clears any pending timers.
72
- */
73
- dispose() {
74
- this._timers.forEach(clearTimeout);
75
- }
76
-
77
- /**
78
- * Determines which items are viewable based on the current metrics and config.
79
- */
80
- computeViewableItems(
81
- itemCount: number,
82
- scrollOffset: number,
83
- viewportHeight: number,
84
- getFrameMetrics: (index: number) => ?{length: number, offset: number},
85
- renderRange?: {first: number, last: number}, // Optional optimization to reduce the scan size
86
- ): Array<number> {
87
- const {itemVisiblePercentThreshold, viewAreaCoveragePercentThreshold} = this._config;
88
- const viewAreaMode = viewAreaCoveragePercentThreshold != null;
89
- const viewablePercentThreshold = viewAreaMode ?
90
- viewAreaCoveragePercentThreshold :
91
- itemVisiblePercentThreshold;
92
- invariant(
93
- viewablePercentThreshold != null &&
94
- (itemVisiblePercentThreshold != null) !== (viewAreaCoveragePercentThreshold != null),
95
- 'Must set exactly one of itemVisiblePercentThreshold or viewAreaCoveragePercentThreshold',
96
- );
97
- const viewableIndices = [];
98
- if (itemCount === 0) {
99
- return viewableIndices;
100
- }
101
- let firstVisible = -1;
102
- const {first, last} = renderRange || {first: 0, last: itemCount - 1};
103
- invariant(
104
- last < itemCount,
105
- 'Invalid render range ' + JSON.stringify({renderRange, itemCount})
106
- );
107
- for (let idx = first; idx <= last; idx++) {
108
- const metrics = getFrameMetrics(idx);
109
- if (!metrics) {
110
- continue;
111
- }
112
- const top = metrics.offset - scrollOffset;
113
- const bottom = top + metrics.length;
114
- if ((top < viewportHeight) && (bottom > 0)) {
115
- firstVisible = idx;
116
- if (_isViewable(
117
- viewAreaMode,
118
- viewablePercentThreshold,
119
- top,
120
- bottom,
121
- viewportHeight,
122
- metrics.length,
123
- )) {
124
- viewableIndices.push(idx);
125
- }
126
- } else if (firstVisible >= 0) {
127
- break;
128
- }
129
- }
130
- return viewableIndices;
131
- }
132
-
133
- /**
134
- * Figures out which items are viewable and how that has changed from before and calls
135
- * `onViewableItemsChanged` as appropriate.
136
- */
137
- onUpdate(
138
- itemCount: number,
139
- scrollOffset: number,
140
- viewportHeight: number,
141
- getFrameMetrics: (index: number) => ?{length: number, offset: number},
142
- createViewToken: (index: number, isViewable: boolean) => ViewToken,
143
- onViewableItemsChanged: ({viewableItems: Array<ViewToken>, changed: Array<ViewToken>}) => void,
144
- renderRange?: {first: number, last: number}, // Optional optimization to reduce the scan size
145
- ): void {
146
- const updateTime = Date.now();
147
- if (this._lastUpdateTime === 0 && itemCount > 0 && getFrameMetrics(0)) {
148
- // Only count updates after the first item is rendered and has a frame.
149
- this._lastUpdateTime = updateTime;
150
- }
151
- const updateElapsed = this._lastUpdateTime ? updateTime - this._lastUpdateTime : 0;
152
- if (this._config.waitForInteraction && !this._hasInteracted) {
153
- return;
154
- }
155
- let viewableIndices = [];
156
- if (itemCount) {
157
- viewableIndices = this.computeViewableItems(
158
- itemCount,
159
- scrollOffset,
160
- viewportHeight,
161
- getFrameMetrics,
162
- renderRange,
163
- );
164
- }
165
- if (this._viewableIndices.length === viewableIndices.length &&
166
- this._viewableIndices.every((v, ii) => v === viewableIndices[ii])) {
167
- // We might get a lot of scroll events where visibility doesn't change and we don't want to do
168
- // extra work in those cases.
169
- return;
170
- }
171
- this._viewableIndices = viewableIndices;
172
- this._lastUpdateTime = updateTime;
173
- if (this._config.minimumViewTime && updateElapsed < this._config.minimumViewTime) {
174
- const handle = setTimeout(
175
- () => {
176
- this._timers.delete(handle);
177
- this._onUpdateSync(viewableIndices, onViewableItemsChanged, createViewToken);
178
- },
179
- this._config.minimumViewTime,
180
- );
181
- this._timers.add(handle);
182
- } else {
183
- this._onUpdateSync(viewableIndices, onViewableItemsChanged, createViewToken);
184
- }
185
- }
186
-
187
- /**
188
- * Records that an interaction has happened even if there has been no scroll.
189
- */
190
- recordInteraction() {
191
- this._hasInteracted = true;
192
- }
193
-
194
- _onUpdateSync(viewableIndicesToCheck, onViewableItemsChanged, createViewToken) {
195
- // Filter out indices that have gone out of view since this call was scheduled.
196
- viewableIndicesToCheck = viewableIndicesToCheck.filter(
197
- (ii) => this._viewableIndices.includes(ii)
198
- );
199
- const prevItems = this._viewableItems;
200
- const nextItems = new Map(
201
- viewableIndicesToCheck.map(ii => {
202
- const viewable = createViewToken(ii, true);
203
- return [viewable.key, viewable];
204
- })
205
- );
206
-
207
- const changed = [];
208
- for (const [key, viewable] of nextItems) {
209
- if (!prevItems.has(key)) {
210
- changed.push(viewable);
211
- }
212
- }
213
- for (const [key, viewable] of prevItems) {
214
- if (!nextItems.has(key)) {
215
- changed.push({...viewable, isViewable: false});
216
- }
217
- }
218
- if (changed.length > 0) {
219
- this._viewableItems = nextItems;
220
- onViewableItemsChanged({viewableItems: Array.from(nextItems.values()), changed});
221
- }
222
- }
223
- }
224
-
225
-
226
- function _isViewable(
227
- viewAreaMode: boolean,
228
- viewablePercentThreshold: number,
229
- top: number,
230
- bottom: number,
231
- viewportHeight: number,
232
- itemLength: number,
233
- ): bool {
234
- if (_isEntirelyVisible(top, bottom, viewportHeight)) {
235
- return true;
236
- } else {
237
- const pixels = _getPixelsVisible(top, bottom, viewportHeight);
238
- const percent = 100 * (viewAreaMode ? pixels / viewportHeight : pixels / itemLength);
239
- return percent >= viewablePercentThreshold;
240
- }
241
- }
242
-
243
- function _getPixelsVisible(
244
- top: number,
245
- bottom: number,
246
- viewportHeight: number
247
- ): number {
248
- const visibleHeight = Math.min(bottom, viewportHeight) - Math.max(top, 0);
249
- return Math.max(0, visibleHeight);
250
- }
251
-
252
- function _isEntirelyVisible(
253
- top: number,
254
- bottom: number,
255
- viewportHeight: number
256
- ): bool {
257
- return top >= 0 && bottom <= viewportHeight && bottom > top;
258
- }
259
-
260
- module.exports = ViewabilityHelper;
@@ -1,163 +0,0 @@
1
- /**
2
- * Copyright (c) 2015-present, Facebook, Inc.
3
- * All rights reserved.
4
- *
5
- * This source code is licensed under the BSD-style license found in the
6
- * LICENSE file in the root directory of this source tree. An additional grant
7
- * of patent rights can be found in the PATENTS file in the same directory.
8
- *
9
- * @providesModule VirtualizeUtils
10
- * @flow
11
- */
12
- 'use strict';
13
-
14
- const invariant = require('fbjs/lib/invariant');
15
-
16
- /**
17
- * Used to find the indices of the frames that overlap the given offsets. Useful for finding the
18
- * items that bound different windows of content, such as the visible area or the buffered overscan
19
- * area.
20
- */
21
- function elementsThatOverlapOffsets(
22
- offsets: Array<number>,
23
- itemCount: number,
24
- getFrameMetrics: (index: number) => {length: number, offset: number},
25
- ): Array<number> {
26
- const out = [];
27
- for (let ii = 0; ii < itemCount; ii++) {
28
- const frame = getFrameMetrics(ii);
29
- const trailingOffset = frame.offset + frame.length;
30
- for (let kk = 0; kk < offsets.length; kk++) {
31
- if (out[kk] == null && trailingOffset >= offsets[kk]) {
32
- out[kk] = ii;
33
- if (kk === offsets.length - 1) {
34
- invariant(
35
- out.length === offsets.length,
36
- 'bad offsets input, should be in increasing order ' + JSON.stringify(offsets)
37
- );
38
- return out;
39
- }
40
- }
41
- }
42
- }
43
- return out;
44
- }
45
-
46
- /**
47
- * Computes the number of elements in the `next` range that are new compared to the `prev` range.
48
- * Handy for calculating how many new items will be rendered when the render window changes so we
49
- * can restrict the number of new items render at once so that content can appear on the screen
50
- * faster.
51
- */
52
- function newRangeCount(
53
- prev: {first: number, last: number},
54
- next: {first: number, last: number},
55
- ): number {
56
- return (next.last - next.first + 1) -
57
- Math.max(
58
- 0,
59
- 1 + Math.min(next.last, prev.last) - Math.max(next.first, prev.first)
60
- );
61
- }
62
-
63
- /**
64
- * Custom logic for determining which items should be rendered given the current frame and scroll
65
- * metrics, as well as the previous render state. The algorithm may evolve over time, but generally
66
- * prioritizes the visible area first, then expands that with overscan regions ahead and behind,
67
- * biased in the direction of scroll.
68
- */
69
- function computeWindowedRenderLimits(
70
- props: {
71
- data: any,
72
- getItemCount: (data: any) => number,
73
- maxToRenderPerBatch: number,
74
- windowSize: number,
75
- },
76
- prev: {first: number, last: number},
77
- getFrameMetricsApprox: (index: number) => {length: number, offset: number},
78
- scrollMetrics: {dt: number, offset: number, velocity: number, visibleLength: number},
79
- ): {first: number, last: number} {
80
- const {data, getItemCount, maxToRenderPerBatch, windowSize} = props;
81
- const itemCount = getItemCount(data);
82
- if (itemCount === 0) {
83
- return prev;
84
- }
85
- const {offset, velocity, visibleLength} = scrollMetrics;
86
-
87
- // Start with visible area, then compute maximum overscan region by expanding from there, biased
88
- // in the direction of scroll. Total overscan area is capped, which should cap memory consumption
89
- // too.
90
- const visibleBegin = Math.max(0, offset);
91
- const visibleEnd = visibleBegin + visibleLength;
92
- const overscanLength = (windowSize - 1) * visibleLength;
93
- const leadFactor = Math.max(0, Math.min(1, velocity / 5 + 0.5));
94
- const overscanBegin = Math.max(0, visibleBegin - (1 - leadFactor) * overscanLength);
95
- const overscanEnd = Math.max(0, visibleEnd + leadFactor * overscanLength);
96
-
97
- // Find the indices that correspond to the items at the render boundaries we're targetting.
98
- let [overscanFirst, first, last, overscanLast] = elementsThatOverlapOffsets(
99
- [overscanBegin, visibleBegin, visibleEnd, overscanEnd],
100
- props.getItemCount(props.data),
101
- getFrameMetricsApprox,
102
- );
103
- overscanFirst = overscanFirst == null ? 0 : overscanFirst;
104
- first = first == null ? Math.max(0, overscanFirst) : first;
105
- overscanLast = overscanLast == null ? (itemCount - 1) : overscanLast;
106
- last = last == null ? Math.min(overscanLast, first + maxToRenderPerBatch - 1) : last;
107
- const visible = {first, last};
108
-
109
- // We want to limit the number of new cells we're rendering per batch so that we can fill the
110
- // content on the screen quickly. If we rendered the entire overscan window at once, the user
111
- // could be staring at white space for a long time waiting for a bunch of offscreen content to
112
- // render.
113
- let newCellCount = newRangeCount(prev, visible);
114
-
115
- while (true) {
116
- if (first <= overscanFirst && last >= overscanLast) {
117
- // If we fill the entire overscan range, we're done.
118
- break;
119
- }
120
- const maxNewCells = newCellCount >= maxToRenderPerBatch;
121
- const firstWillAddMore = first <= prev.first || first > prev.last;
122
- const firstShouldIncrement = first > overscanFirst && (!maxNewCells || !firstWillAddMore);
123
- const lastWillAddMore = last >= prev.last || last < prev.first;
124
- const lastShouldIncrement = last < overscanLast && (!maxNewCells || !lastWillAddMore);
125
- if (maxNewCells && !firstShouldIncrement && !lastShouldIncrement) {
126
- // We only want to stop if we've hit maxNewCells AND we cannot increment first or last
127
- // without rendering new items. This let's us preserve as many already rendered items as
128
- // possible, reducing render churn and keeping the rendered overscan range as large as
129
- // possible.
130
- break;
131
- }
132
- if (firstShouldIncrement) {
133
- if (firstWillAddMore) {
134
- newCellCount++;
135
- }
136
- first--;
137
- }
138
- if (lastShouldIncrement) {
139
- if (lastWillAddMore) {
140
- newCellCount++;
141
- }
142
- last++;
143
- }
144
- }
145
- if (!(
146
- last >= first &&
147
- first >= 0 && last < itemCount &&
148
- first >= overscanFirst && last <= overscanLast &&
149
- first <= visible.first && last >= visible.last
150
- )) {
151
- throw new Error('Bad window calculation ' +
152
- JSON.stringify({first, last, itemCount, overscanFirst, overscanLast, visible}));
153
- }
154
- return {first, last};
155
- }
156
-
157
- const VirtualizeUtils = {
158
- computeWindowedRenderLimits,
159
- elementsThatOverlapOffsets,
160
- newRangeCount,
161
- };
162
-
163
- module.exports = VirtualizeUtils;