@react-native-ohos/flash-list 1.8.3 → 2.1.1-rc.1
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/LICENSE +1 -1
- package/README.OpenSource +1 -1
- package/dist/AnimatedFlashList.d.ts +4 -28
- package/dist/AnimatedFlashList.d.ts.map +1 -1
- package/dist/AnimatedFlashList.js +5 -30
- package/dist/AnimatedFlashList.js.map +1 -1
- package/dist/FlashList.d.ts +1 -179
- package/dist/FlashList.d.ts.map +1 -1
- package/dist/FlashList.js +1 -599
- package/dist/FlashList.js.map +1 -1
- package/dist/FlashListProps.d.ts +285 -278
- package/dist/FlashListProps.d.ts.map +1 -1
- package/dist/FlashListProps.js +5 -31
- package/dist/FlashListProps.js.map +1 -1
- package/dist/FlashListRef.d.ts +305 -0
- package/dist/FlashListRef.d.ts.map +1 -0
- package/dist/FlashListRef.js +2 -0
- package/dist/FlashListRef.js.map +1 -0
- package/dist/benchmark/AutoScrollHelper.d.ts +17 -40
- package/dist/benchmark/AutoScrollHelper.d.ts.map +1 -1
- package/dist/benchmark/AutoScrollHelper.js +59 -90
- package/dist/benchmark/AutoScrollHelper.js.map +1 -1
- package/dist/benchmark/JSFPSMonitor.d.ts +22 -45
- package/dist/benchmark/JSFPSMonitor.d.ts.map +1 -1
- package/dist/benchmark/JSFPSMonitor.js +59 -87
- package/dist/benchmark/JSFPSMonitor.js.map +1 -1
- package/dist/benchmark/roundToDecimalPlaces.d.ts +1 -24
- package/dist/benchmark/roundToDecimalPlaces.d.ts.map +1 -1
- package/dist/benchmark/roundToDecimalPlaces.js +4 -31
- package/dist/benchmark/roundToDecimalPlaces.js.map +1 -1
- package/dist/benchmark/useBenchmark.d.ts +40 -57
- package/dist/benchmark/useBenchmark.d.ts.map +1 -1
- package/dist/benchmark/useBenchmark.js +119 -189
- package/dist/benchmark/useBenchmark.js.map +1 -1
- package/dist/benchmark/useDataMultiplier.d.ts +8 -31
- package/dist/benchmark/useDataMultiplier.d.ts.map +1 -1
- package/dist/benchmark/useDataMultiplier.js +19 -47
- package/dist/benchmark/useDataMultiplier.js.map +1 -1
- package/dist/benchmark/useFlatListBenchmark.d.ts +14 -35
- package/dist/benchmark/useFlatListBenchmark.d.ts.map +1 -1
- package/dist/benchmark/useFlatListBenchmark.js +92 -122
- package/dist/benchmark/useFlatListBenchmark.js.map +1 -1
- package/dist/errors/ErrorMessages.d.ts +16 -0
- package/dist/errors/ErrorMessages.d.ts.map +1 -0
- package/dist/errors/ErrorMessages.js +16 -0
- package/dist/errors/ErrorMessages.js.map +1 -0
- package/dist/errors/WarningMessages.d.ts +6 -0
- package/dist/errors/WarningMessages.d.ts.map +1 -0
- package/dist/errors/WarningMessages.js +7 -0
- package/dist/errors/WarningMessages.js.map +1 -0
- package/dist/index.d.ts +15 -36
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +19 -54
- package/dist/index.js.map +1 -1
- package/dist/isNewArch.d.ts +2 -0
- package/dist/isNewArch.d.ts.map +1 -0
- package/dist/isNewArch.js +22 -0
- package/dist/isNewArch.js.map +1 -0
- package/dist/native/config/PlatformHelper.android.d.ts +6 -48
- package/dist/native/config/PlatformHelper.android.d.ts.map +1 -1
- package/dist/native/config/PlatformHelper.android.js +6 -45
- package/dist/native/config/PlatformHelper.android.js.map +1 -1
- package/dist/native/config/PlatformHelper.d.ts +6 -48
- package/dist/native/config/PlatformHelper.d.ts.map +1 -1
- package/dist/native/config/PlatformHelper.harmony.d.ts +29 -48
- package/dist/native/config/PlatformHelper.harmony.d.ts.map +1 -1
- package/dist/native/config/PlatformHelper.harmony.js +29 -44
- package/dist/native/config/PlatformHelper.harmony.js.map +1 -1
- package/dist/native/config/PlatformHelper.ios.d.ts +6 -48
- package/dist/native/config/PlatformHelper.ios.d.ts.map +1 -1
- package/dist/native/config/PlatformHelper.ios.js +6 -44
- package/dist/native/config/PlatformHelper.ios.js.map +1 -1
- package/dist/native/config/PlatformHelper.js +6 -45
- package/dist/native/config/PlatformHelper.js.map +1 -1
- package/dist/native/config/PlatformHelper.web.d.ts +6 -49
- package/dist/native/config/PlatformHelper.web.d.ts.map +1 -1
- package/dist/native/config/PlatformHelper.web.js +6 -47
- package/dist/native/config/PlatformHelper.web.js.map +1 -1
- package/dist/recyclerview/LayoutCommitObserver.d.ts +12 -0
- package/dist/recyclerview/LayoutCommitObserver.d.ts.map +1 -0
- package/dist/recyclerview/LayoutCommitObserver.js +58 -0
- package/dist/recyclerview/LayoutCommitObserver.js.map +1 -0
- package/dist/recyclerview/RecyclerView.d.ts +13 -0
- package/dist/recyclerview/RecyclerView.d.ts.map +1 -0
- package/dist/recyclerview/RecyclerView.js +368 -0
- package/dist/recyclerview/RecyclerView.js.map +1 -0
- package/dist/recyclerview/RecyclerViewContextProvider.d.ts +46 -0
- package/dist/recyclerview/RecyclerViewContextProvider.d.ts.map +1 -0
- package/dist/recyclerview/RecyclerViewContextProvider.js +10 -0
- package/dist/recyclerview/RecyclerViewContextProvider.js.map +1 -0
- package/dist/recyclerview/RecyclerViewManager.d.ts +78 -0
- package/dist/recyclerview/RecyclerViewManager.d.ts.map +1 -0
- package/dist/recyclerview/RecyclerViewManager.js +343 -0
- package/dist/recyclerview/RecyclerViewManager.js.map +1 -0
- package/dist/recyclerview/RecyclerViewProps.d.ts +2 -0
- package/dist/recyclerview/RecyclerViewProps.d.ts.map +1 -0
- package/dist/recyclerview/RecyclerViewProps.js +2 -0
- package/dist/recyclerview/RecyclerViewProps.js.map +1 -0
- package/dist/recyclerview/RenderStackManager.d.ts +86 -0
- package/dist/recyclerview/RenderStackManager.d.ts.map +1 -0
- package/dist/recyclerview/RenderStackManager.js +252 -0
- package/dist/recyclerview/RenderStackManager.js.map +1 -0
- package/dist/recyclerview/ViewHolder.d.ts +45 -0
- package/dist/recyclerview/ViewHolder.d.ts.map +1 -0
- package/dist/recyclerview/ViewHolder.js +94 -0
- package/dist/recyclerview/ViewHolder.js.map +1 -0
- package/dist/recyclerview/ViewHolderCollection.d.ts +63 -0
- package/dist/recyclerview/ViewHolderCollection.d.ts.map +1 -0
- package/dist/recyclerview/ViewHolderCollection.js +87 -0
- package/dist/recyclerview/ViewHolderCollection.js.map +1 -0
- package/dist/recyclerview/components/CompatScroller.d.ts +7 -0
- package/dist/recyclerview/components/CompatScroller.d.ts.map +1 -0
- package/dist/recyclerview/components/CompatScroller.js +7 -0
- package/dist/recyclerview/components/CompatScroller.js.map +1 -0
- package/dist/recyclerview/components/CompatView.d.ts +7 -0
- package/dist/recyclerview/components/CompatView.d.ts.map +1 -0
- package/dist/recyclerview/components/CompatView.js +7 -0
- package/dist/recyclerview/components/CompatView.js.map +1 -0
- package/dist/recyclerview/components/ScrollAnchor.d.ts +29 -0
- package/dist/recyclerview/components/ScrollAnchor.d.ts.map +1 -0
- package/dist/recyclerview/components/ScrollAnchor.js +33 -0
- package/dist/recyclerview/components/ScrollAnchor.js.map +1 -0
- package/dist/recyclerview/components/StickyHeaders.d.ts +38 -0
- package/dist/recyclerview/components/StickyHeaders.d.ts.map +1 -0
- package/dist/recyclerview/components/StickyHeaders.js +112 -0
- package/dist/recyclerview/components/StickyHeaders.js.map +1 -0
- package/dist/recyclerview/helpers/ConsecutiveNumbers.d.ts +51 -0
- package/dist/recyclerview/helpers/ConsecutiveNumbers.d.ts.map +1 -0
- package/dist/recyclerview/helpers/ConsecutiveNumbers.js +95 -0
- package/dist/recyclerview/helpers/ConsecutiveNumbers.js.map +1 -0
- package/dist/recyclerview/helpers/EngagedIndicesTracker.d.ts +105 -0
- package/dist/recyclerview/helpers/EngagedIndicesTracker.d.ts.map +1 -0
- package/dist/recyclerview/helpers/EngagedIndicesTracker.js +202 -0
- package/dist/recyclerview/helpers/EngagedIndicesTracker.js.map +1 -0
- package/dist/recyclerview/helpers/RenderTimeTracker.d.ts +14 -0
- package/dist/recyclerview/helpers/RenderTimeTracker.d.ts.map +1 -0
- package/dist/recyclerview/helpers/RenderTimeTracker.js +44 -0
- package/dist/recyclerview/helpers/RenderTimeTracker.js.map +1 -0
- package/dist/recyclerview/helpers/VelocityTracker.d.ts +29 -0
- package/dist/recyclerview/helpers/VelocityTracker.d.ts.map +1 -0
- package/dist/recyclerview/helpers/VelocityTracker.js +64 -0
- package/dist/recyclerview/helpers/VelocityTracker.js.map +1 -0
- package/dist/recyclerview/hooks/useBoundDetection.d.ts +17 -0
- package/dist/recyclerview/hooks/useBoundDetection.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useBoundDetection.js +132 -0
- package/dist/recyclerview/hooks/useBoundDetection.js.map +1 -0
- package/dist/recyclerview/hooks/useLayoutState.d.ts +14 -0
- package/dist/recyclerview/hooks/useLayoutState.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useLayoutState.js +38 -0
- package/dist/recyclerview/hooks/useLayoutState.js.map +1 -0
- package/dist/recyclerview/hooks/useMappingHelper.d.ts +9 -0
- package/dist/recyclerview/hooks/useMappingHelper.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useMappingHelper.js +15 -0
- package/dist/recyclerview/hooks/useMappingHelper.js.map +1 -0
- package/dist/recyclerview/hooks/useOnLoad.d.ts +25 -0
- package/dist/recyclerview/hooks/useOnLoad.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useOnLoad.js +67 -0
- package/dist/recyclerview/hooks/useOnLoad.js.map +1 -0
- package/dist/recyclerview/hooks/useRecyclerViewController.d.ts +28 -0
- package/dist/recyclerview/hooks/useRecyclerViewController.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useRecyclerViewController.js +507 -0
- package/dist/recyclerview/hooks/useRecyclerViewController.js.map +1 -0
- package/dist/recyclerview/hooks/useRecyclerViewManager.d.ts +8 -0
- package/dist/recyclerview/hooks/useRecyclerViewManager.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useRecyclerViewManager.js +32 -0
- package/dist/recyclerview/hooks/useRecyclerViewManager.js.map +1 -0
- package/dist/recyclerview/hooks/useRecyclingState.d.ts +18 -0
- package/dist/recyclerview/hooks/useRecyclingState.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useRecyclingState.js +49 -0
- package/dist/recyclerview/hooks/useRecyclingState.js.map +1 -0
- package/dist/recyclerview/hooks/useSecondaryProps.d.ts +27 -0
- package/dist/recyclerview/hooks/useSecondaryProps.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useSecondaryProps.js +90 -0
- package/dist/recyclerview/hooks/useSecondaryProps.js.map +1 -0
- package/dist/recyclerview/hooks/useUnmountAwareCallbacks.d.ts +15 -0
- package/dist/recyclerview/hooks/useUnmountAwareCallbacks.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useUnmountAwareCallbacks.js +58 -0
- package/dist/recyclerview/hooks/useUnmountAwareCallbacks.js.map +1 -0
- package/dist/recyclerview/hooks/useUnmountFlag.d.ts +10 -0
- package/dist/recyclerview/hooks/useUnmountFlag.d.ts.map +1 -0
- package/dist/recyclerview/hooks/useUnmountFlag.js +25 -0
- package/dist/recyclerview/hooks/useUnmountFlag.js.map +1 -0
- package/dist/recyclerview/layout-managers/GridLayoutManager.d.ts +79 -0
- package/dist/recyclerview/layout-managers/GridLayoutManager.d.ts.map +1 -0
- package/dist/recyclerview/layout-managers/GridLayoutManager.js +221 -0
- package/dist/recyclerview/layout-managers/GridLayoutManager.js.map +1 -0
- package/dist/recyclerview/layout-managers/LayoutManager.d.ts +296 -0
- package/dist/recyclerview/layout-managers/LayoutManager.d.ts.map +1 -0
- package/dist/recyclerview/layout-managers/LayoutManager.js +279 -0
- package/dist/recyclerview/layout-managers/LayoutManager.js.map +1 -0
- package/dist/recyclerview/layout-managers/LinearLayoutManager.d.ts +51 -0
- package/dist/recyclerview/layout-managers/LinearLayoutManager.d.ts.map +1 -0
- package/dist/recyclerview/layout-managers/LinearLayoutManager.js +151 -0
- package/dist/recyclerview/layout-managers/LinearLayoutManager.js.map +1 -0
- package/dist/recyclerview/layout-managers/MasonryLayoutManager.d.ts +81 -0
- package/dist/recyclerview/layout-managers/MasonryLayoutManager.d.ts.map +1 -0
- package/dist/recyclerview/layout-managers/MasonryLayoutManager.js +269 -0
- package/dist/recyclerview/layout-managers/MasonryLayoutManager.js.map +1 -0
- package/dist/recyclerview/utils/adjustOffsetForRTL.d.ts +12 -0
- package/dist/recyclerview/utils/adjustOffsetForRTL.d.ts.map +1 -0
- package/dist/recyclerview/utils/adjustOffsetForRTL.js +14 -0
- package/dist/recyclerview/utils/adjustOffsetForRTL.js.map +1 -0
- package/dist/recyclerview/utils/componentUtils.d.ts +19 -0
- package/dist/recyclerview/utils/componentUtils.d.ts.map +1 -0
- package/dist/recyclerview/utils/componentUtils.js +27 -0
- package/dist/recyclerview/utils/componentUtils.js.map +1 -0
- package/dist/recyclerview/utils/findVisibleIndex.d.ts +24 -0
- package/dist/recyclerview/utils/findVisibleIndex.d.ts.map +1 -0
- package/dist/recyclerview/utils/findVisibleIndex.js +76 -0
- package/dist/recyclerview/utils/findVisibleIndex.js.map +1 -0
- package/dist/recyclerview/utils/measureLayout.d.ts +52 -0
- package/dist/recyclerview/utils/measureLayout.d.ts.map +1 -0
- package/dist/recyclerview/utils/measureLayout.js +99 -0
- package/dist/recyclerview/utils/measureLayout.js.map +1 -0
- package/dist/recyclerview/utils/measureLayout.web.d.ts +29 -0
- package/dist/recyclerview/utils/measureLayout.web.d.ts.map +1 -0
- package/dist/recyclerview/utils/measureLayout.web.js +79 -0
- package/dist/recyclerview/utils/measureLayout.web.js.map +1 -0
- package/dist/recyclerview/viewability/ViewToken.d.ts +8 -0
- package/dist/recyclerview/viewability/ViewToken.d.ts.map +1 -0
- package/dist/recyclerview/viewability/ViewToken.js +2 -0
- package/dist/recyclerview/viewability/ViewToken.js.map +1 -0
- package/dist/recyclerview/viewability/ViewabilityHelper.d.ts +26 -0
- package/dist/recyclerview/viewability/ViewabilityHelper.d.ts.map +1 -0
- package/dist/recyclerview/viewability/ViewabilityHelper.js +98 -0
- package/dist/recyclerview/viewability/ViewabilityHelper.js.map +1 -0
- package/dist/recyclerview/viewability/ViewabilityManager.d.ts +25 -0
- package/dist/recyclerview/viewability/ViewabilityManager.d.ts.map +1 -0
- package/dist/recyclerview/viewability/ViewabilityManager.js +94 -0
- package/dist/recyclerview/viewability/ViewabilityManager.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/utils/AverageWindow.d.ts +33 -43
- package/dist/utils/AverageWindow.d.ts.map +1 -1
- package/dist/utils/AverageWindow.js +66 -71
- package/dist/utils/AverageWindow.js.map +1 -1
- package/jestSetup.js +23 -37
- package/package.json +15 -24
- package/src/AnimatedFlashList.ts +2 -25
- package/src/FlashList.ts +1 -0
- package/src/FlashListProps.ts +109 -100
- package/src/FlashListRef.ts +320 -0
- package/src/benchmark/AutoScrollHelper.ts +0 -24
- package/src/benchmark/JSFPSMonitor.ts +2 -26
- package/src/benchmark/roundToDecimalPlaces.ts +0 -24
- package/src/benchmark/useBenchmark.ts +59 -105
- package/src/benchmark/useDataMultiplier.ts +0 -24
- package/src/benchmark/useFlatListBenchmark.ts +43 -32
- package/src/errors/ErrorMessages.ts +26 -0
- package/src/errors/WarningMessages.ts +9 -0
- package/src/index.ts +18 -46
- package/src/isNewArch.ts +25 -0
- package/src/native/config/PlatformHelper.android.ts +3 -49
- package/src/native/config/PlatformHelper.harmony.ts +3 -24
- package/src/native/config/PlatformHelper.ios.ts +3 -48
- package/src/native/config/PlatformHelper.ts +3 -49
- package/src/native/config/PlatformHelper.web.ts +4 -55
- package/src/recyclerview/LayoutCommitObserver.tsx +74 -0
- package/src/recyclerview/RecyclerView.tsx +616 -0
- package/src/recyclerview/RecyclerViewContextProvider.ts +65 -0
- package/src/recyclerview/RecyclerViewManager.ts +461 -0
- package/src/recyclerview/RecyclerViewProps.ts +1 -0
- package/src/recyclerview/RenderStackManager.ts +317 -0
- package/src/recyclerview/ViewHolder.tsx +180 -0
- package/src/recyclerview/ViewHolderCollection.tsx +193 -0
- package/src/recyclerview/components/CompatScroller.ts +9 -0
- package/src/recyclerview/components/CompatView.ts +9 -0
- package/src/recyclerview/components/ScrollAnchor.tsx +66 -0
- package/src/recyclerview/components/StickyHeaders.tsx +222 -0
- package/src/recyclerview/helpers/ConsecutiveNumbers.ts +120 -0
- package/src/recyclerview/helpers/EngagedIndicesTracker.ts +301 -0
- package/src/recyclerview/helpers/RenderTimeTracker.ts +50 -0
- package/src/recyclerview/helpers/VelocityTracker.ts +77 -0
- package/src/recyclerview/hooks/useBoundDetection.ts +176 -0
- package/src/recyclerview/hooks/useLayoutState.ts +55 -0
- package/src/recyclerview/hooks/useMappingHelper.ts +20 -0
- package/src/recyclerview/hooks/useOnLoad.ts +80 -0
- package/src/recyclerview/hooks/useRecyclerViewController.tsx +633 -0
- package/src/recyclerview/hooks/useRecyclerViewManager.ts +42 -0
- package/src/recyclerview/hooks/useRecyclingState.ts +67 -0
- package/src/recyclerview/hooks/useSecondaryProps.tsx +124 -0
- package/src/recyclerview/hooks/useUnmountAwareCallbacks.ts +73 -0
- package/src/recyclerview/hooks/useUnmountFlag.ts +27 -0
- package/src/recyclerview/layout-managers/GridLayoutManager.ts +256 -0
- package/src/recyclerview/layout-managers/LayoutManager.ts +568 -0
- package/src/recyclerview/layout-managers/LinearLayoutManager.ts +171 -0
- package/src/recyclerview/layout-managers/MasonryLayoutManager.ts +323 -0
- package/src/recyclerview/utils/adjustOffsetForRTL.ts +17 -0
- package/src/recyclerview/utils/componentUtils.ts +28 -0
- package/src/recyclerview/utils/findVisibleIndex.ts +93 -0
- package/src/recyclerview/utils/measureLayout.ts +128 -0
- package/src/recyclerview/utils/measureLayout.web.ts +102 -0
- package/src/recyclerview/viewability/ViewToken.ts +7 -0
- package/src/{viewability → recyclerview/viewability}/ViewabilityHelper.ts +8 -33
- package/src/{viewability → recyclerview/viewability}/ViewabilityManager.ts +23 -46
- package/src/utils/AverageWindow.ts +33 -24
- package/dist/GridLayoutProviderWithProps.d.ts +0 -65
- package/dist/GridLayoutProviderWithProps.d.ts.map +0 -1
- package/dist/GridLayoutProviderWithProps.js +0 -138
- package/dist/GridLayoutProviderWithProps.js.map +0 -1
- package/dist/MasonryFlashList.d.ts +0 -74
- package/dist/MasonryFlashList.d.ts.map +0 -1
- package/dist/MasonryFlashList.js +0 -275
- package/dist/MasonryFlashList.js.map +0 -1
- package/dist/PureComponentWrapper.d.ts +0 -45
- package/dist/PureComponentWrapper.d.ts.map +0 -1
- package/dist/PureComponentWrapper.js +0 -60
- package/dist/PureComponentWrapper.js.map +0 -1
- package/dist/benchmark/useBlankAreaTracker.d.ts +0 -57
- package/dist/benchmark/useBlankAreaTracker.d.ts.map +0 -1
- package/dist/benchmark/useBlankAreaTracker.js +0 -90
- package/dist/benchmark/useBlankAreaTracker.js.map +0 -1
- package/dist/errors/CustomError.d.ts +0 -31
- package/dist/errors/CustomError.d.ts.map +0 -1
- package/dist/errors/CustomError.js +0 -37
- package/dist/errors/CustomError.js.map +0 -1
- package/dist/errors/ExceptionList.d.ts +0 -47
- package/dist/errors/ExceptionList.d.ts.map +0 -1
- package/dist/errors/ExceptionList.js +0 -49
- package/dist/errors/ExceptionList.js.map +0 -1
- package/dist/errors/Warnings.d.ts +0 -32
- package/dist/errors/Warnings.d.ts.map +0 -1
- package/dist/errors/Warnings.js +0 -36
- package/dist/errors/Warnings.js.map +0 -1
- package/dist/fabric/AutoLayoutNativeComponent.d.ts +0 -42
- package/dist/fabric/AutoLayoutNativeComponent.d.ts.map +0 -1
- package/dist/fabric/AutoLayoutNativeComponent.js +0 -29
- package/dist/fabric/AutoLayoutNativeComponent.js.map +0 -1
- package/dist/fabric/CellContainerNativeComponent.d.ts +0 -31
- package/dist/fabric/CellContainerNativeComponent.d.ts.map +0 -1
- package/dist/fabric/CellContainerNativeComponent.js +0 -29
- package/dist/fabric/CellContainerNativeComponent.js.map +0 -1
- package/dist/native/auto-layout/AutoLayoutView.d.ts +0 -45
- package/dist/native/auto-layout/AutoLayoutView.d.ts.map +0 -1
- package/dist/native/auto-layout/AutoLayoutView.js +0 -71
- package/dist/native/auto-layout/AutoLayoutView.js.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.android.d.ts +0 -27
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.android.d.ts.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.android.js +0 -29
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.android.js.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.d.ts +0 -28
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.d.ts.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.harmony.d.ts +0 -27
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.harmony.d.ts.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.harmony.js +0 -29
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.harmony.js.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.ios.d.ts +0 -27
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.ios.d.ts.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.ios.js +0 -29
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.ios.js.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.js +0 -29
- package/dist/native/auto-layout/AutoLayoutViewNativeComponent.js.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponentProps.d.ts +0 -39
- package/dist/native/auto-layout/AutoLayoutViewNativeComponentProps.d.ts.map +0 -1
- package/dist/native/auto-layout/AutoLayoutViewNativeComponentProps.js +0 -26
- package/dist/native/auto-layout/AutoLayoutViewNativeComponentProps.js.map +0 -1
- package/dist/native/cell-container/CellContainer.android.d.ts +0 -29
- package/dist/native/cell-container/CellContainer.android.d.ts.map +0 -1
- package/dist/native/cell-container/CellContainer.android.js +0 -32
- package/dist/native/cell-container/CellContainer.android.js.map +0 -1
- package/dist/native/cell-container/CellContainer.d.ts +0 -31
- package/dist/native/cell-container/CellContainer.d.ts.map +0 -1
- package/dist/native/cell-container/CellContainer.harmony.d.ts +0 -29
- package/dist/native/cell-container/CellContainer.harmony.d.ts.map +0 -1
- package/dist/native/cell-container/CellContainer.harmony.js +0 -32
- package/dist/native/cell-container/CellContainer.harmony.js.map +0 -1
- package/dist/native/cell-container/CellContainer.ios.d.ts +0 -29
- package/dist/native/cell-container/CellContainer.ios.d.ts.map +0 -1
- package/dist/native/cell-container/CellContainer.ios.js +0 -32
- package/dist/native/cell-container/CellContainer.ios.js.map +0 -1
- package/dist/native/cell-container/CellContainer.js +0 -34
- package/dist/native/cell-container/CellContainer.js.map +0 -1
- package/dist/native/cell-container/CellContainer.web.d.ts +0 -30
- package/dist/native/cell-container/CellContainer.web.d.ts.map +0 -1
- package/dist/native/cell-container/CellContainer.web.js +0 -36
- package/dist/native/cell-container/CellContainer.web.js.map +0 -1
- package/dist/utils/ContentContainerUtils.d.ts +0 -50
- package/dist/utils/ContentContainerUtils.d.ts.map +0 -1
- package/dist/utils/ContentContainerUtils.js +0 -71
- package/dist/utils/ContentContainerUtils.js.map +0 -1
- package/dist/viewability/ViewToken.d.ts +0 -31
- package/dist/viewability/ViewToken.d.ts.map +0 -1
- package/dist/viewability/ViewToken.js +0 -26
- package/dist/viewability/ViewToken.js.map +0 -1
- package/dist/viewability/ViewabilityHelper.d.ts +0 -49
- package/dist/viewability/ViewabilityHelper.d.ts.map +0 -1
- package/dist/viewability/ViewabilityHelper.js +0 -130
- package/dist/viewability/ViewabilityHelper.js.map +0 -1
- package/dist/viewability/ViewabilityManager.d.ts +0 -48
- package/dist/viewability/ViewabilityManager.d.ts.map +0 -1
- package/dist/viewability/ViewabilityManager.js +0 -131
- package/dist/viewability/ViewabilityManager.js.map +0 -1
- package/harmony/flash_list/BuildProfile.ets +0 -17
- package/harmony/flash_list/LICENSE +0 -7
- package/harmony/flash_list/build-profile.json5 +0 -8
- package/harmony/flash_list/hvigorfile.ts +0 -1
- package/harmony/flash_list/index.ets +0 -27
- package/harmony/flash_list/obfuscation-rules.txt +0 -18
- package/harmony/flash_list/oh-package.json5 +0 -24
- package/harmony/flash_list/src/main/cpp/AutoLayoutNode.cpp +0 -63
- package/harmony/flash_list/src/main/cpp/AutoLayoutNode.h +0 -54
- package/harmony/flash_list/src/main/cpp/AutoLayoutShadow.cpp +0 -140
- package/harmony/flash_list/src/main/cpp/AutoLayoutShadow.h +0 -66
- package/harmony/flash_list/src/main/cpp/AutoLayoutViewComponentInstance.cpp +0 -208
- package/harmony/flash_list/src/main/cpp/AutoLayoutViewComponentInstance.h +0 -78
- package/harmony/flash_list/src/main/cpp/AutoLayoutViewEventEmitRequestHandler.h +0 -53
- package/harmony/flash_list/src/main/cpp/AutoLayoutViewJSIBinder.h +0 -50
- package/harmony/flash_list/src/main/cpp/CMakeLists.txt +0 -12
- package/harmony/flash_list/src/main/cpp/CellContainerComponentInstance.cpp +0 -80
- package/harmony/flash_list/src/main/cpp/CellContainerComponentInstance.h +0 -64
- package/harmony/flash_list/src/main/cpp/CellContainerJSIBinder.h +0 -39
- package/harmony/flash_list/src/main/cpp/ComponentDescriptors.h +0 -40
- package/harmony/flash_list/src/main/cpp/EventEmitters.cpp +0 -40
- package/harmony/flash_list/src/main/cpp/EventEmitters.h +0 -48
- package/harmony/flash_list/src/main/cpp/FlashListPackage.h +0 -85
- package/harmony/flash_list/src/main/cpp/FlashListStackNode.cpp +0 -87
- package/harmony/flash_list/src/main/cpp/FlashListStackNode.h +0 -57
- package/harmony/flash_list/src/main/cpp/Props.cpp +0 -52
- package/harmony/flash_list/src/main/cpp/Props.h +0 -64
- package/harmony/flash_list/src/main/cpp/ShadowNodes.cpp +0 -34
- package/harmony/flash_list/src/main/cpp/ShadowNodes.h +0 -48
- package/harmony/flash_list/src/main/ets/Logger.ets +0 -64
- package/harmony/flash_list/src/main/ets/RNAutoLayoutShadow.ets +0 -154
- package/harmony/flash_list/src/main/ets/RNAutoLayoutView.ets +0 -277
- package/harmony/flash_list/src/main/ets/RNCellContainer.ets +0 -113
- package/harmony/flash_list/src/main/module.json5 +0 -9
- package/harmony/flash_list/src/main/resources/base/element/color.json +0 -8
- package/harmony/flash_list/src/main/resources/base/element/string.json +0 -16
- package/harmony/flash_list/src/main/resources/base/media/icon.png +0 -0
- package/harmony/flash_list/src/main/resources/base/profile/main_pages.json +0 -5
- package/harmony/flash_list/src/main/resources/en_US/element/string.json +0 -16
- package/harmony/flash_list/src/main/resources/zh_CN/element/string.json +0 -16
- package/harmony/flash_list.har +0 -0
- package/src/FlashList.tsx +0 -949
- package/src/GridLayoutProviderWithProps.ts +0 -204
- package/src/MasonryFlashList.tsx +0 -499
- package/src/PureComponentWrapper.tsx +0 -65
- package/src/benchmark/useBlankAreaTracker.ts +0 -141
- package/src/errors/CustomError.ts +0 -34
- package/src/errors/ExceptionList.ts +0 -52
- package/src/errors/Warnings.ts +0 -39
- package/src/fabric/AutoLayoutNativeComponent.ts +0 -52
- package/src/fabric/CellContainerNativeComponent.ts +0 -35
- package/src/native/auto-layout/AutoLayoutView.tsx +0 -97
- package/src/native/auto-layout/AutoLayoutViewNativeComponent.android.ts +0 -31
- package/src/native/auto-layout/AutoLayoutViewNativeComponent.harmony.ts +0 -31
- package/src/native/auto-layout/AutoLayoutViewNativeComponent.ios.ts +0 -31
- package/src/native/auto-layout/AutoLayoutViewNativeComponent.ts +0 -31
- package/src/native/auto-layout/AutoLayoutViewNativeComponentProps.ts +0 -41
- package/src/native/cell-container/CellContainer.android.ts +0 -31
- package/src/native/cell-container/CellContainer.harmony.ts +0 -31
- package/src/native/cell-container/CellContainer.ios.ts +0 -31
- package/src/native/cell-container/CellContainer.tsx +0 -38
- package/src/native/cell-container/CellContainer.web.tsx +0 -33
- package/src/utils/ContentContainerUtils.ts +0 -116
- package/src/viewability/ViewToken.ts +0 -31
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { PixelRatio, View } from "react-native";
|
|
2
|
+
|
|
3
|
+
interface Layout {
|
|
4
|
+
x: number;
|
|
5
|
+
y: number;
|
|
6
|
+
width: number;
|
|
7
|
+
height: number;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Measures the layout of a view relative to itselft.
|
|
12
|
+
* Using measure wasn't returing accurate values but this workaround does.
|
|
13
|
+
* Returns the x, y coordinates and dimensions of the view.
|
|
14
|
+
*
|
|
15
|
+
* @param view - The React Native View component to measure
|
|
16
|
+
* @returns An object containing x, y, width, and height measurements
|
|
17
|
+
*/
|
|
18
|
+
function measureLayout(view: View, oldLayout: Layout | undefined) {
|
|
19
|
+
// const layout = view.unstable_getBoundingClientRect();
|
|
20
|
+
// layout.width = roundOffPixel(layout.width);
|
|
21
|
+
// layout.height = roundOffPixel(layout.height);
|
|
22
|
+
// return layout;
|
|
23
|
+
return measureLayoutRelative(view, view, oldLayout);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Measures the layout of a view relative to another view.
|
|
28
|
+
* Useful for measuring positions relative to a specific reference view.
|
|
29
|
+
*
|
|
30
|
+
* @param view - The React Native View component to measure
|
|
31
|
+
* @param relativeTo - The reference view to measure against
|
|
32
|
+
* @returns An object containing x, y, width, and height measurements
|
|
33
|
+
*/
|
|
34
|
+
function measureLayoutRelative(
|
|
35
|
+
view: View,
|
|
36
|
+
relativeTo: View,
|
|
37
|
+
oldLayout: Layout | undefined
|
|
38
|
+
) {
|
|
39
|
+
const layout = { x: 0, y: 0, width: 0, height: 0 };
|
|
40
|
+
view.measureLayout(relativeTo, (x, y, width, height) => {
|
|
41
|
+
layout.x = x;
|
|
42
|
+
layout.y = y;
|
|
43
|
+
layout.width = roundOffPixel(width);
|
|
44
|
+
layout.height = roundOffPixel(height);
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
if (oldLayout) {
|
|
48
|
+
if (areDimensionsEqual(layout.width, oldLayout.width)) {
|
|
49
|
+
layout.width = oldLayout.width;
|
|
50
|
+
}
|
|
51
|
+
if (areDimensionsEqual(layout.height, oldLayout.height)) {
|
|
52
|
+
layout.height = oldLayout.height;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
return layout;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Checks if two dimension values are not equal, with a small tolerance.
|
|
60
|
+
* Used to handle floating-point precision issues in layout measurements.
|
|
61
|
+
*
|
|
62
|
+
* @param value1 - First dimension value to compare
|
|
63
|
+
* @param value2 - Second dimension value to compare
|
|
64
|
+
* @returns true if the values are significantly different, false otherwise
|
|
65
|
+
*/
|
|
66
|
+
export function areDimensionsNotEqual(value1: number, value2: number): boolean {
|
|
67
|
+
return !areDimensionsEqual(value1, value2);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Checks if two dimension values are equal, with a small tolerance.
|
|
72
|
+
* Used to handle floating-point precision issues in layout measurements.
|
|
73
|
+
*
|
|
74
|
+
* @param value1 - First dimension value to compare
|
|
75
|
+
* @param value2 - Second dimension value to compare
|
|
76
|
+
* @returns true if the values are approximately equal, false otherwise
|
|
77
|
+
*/
|
|
78
|
+
export function areDimensionsEqual(value1: number, value2: number): boolean {
|
|
79
|
+
return (
|
|
80
|
+
Math.abs(
|
|
81
|
+
PixelRatio.getPixelSizeForLayoutSize(value1) -
|
|
82
|
+
PixelRatio.getPixelSizeForLayoutSize(value2)
|
|
83
|
+
) <= 1
|
|
84
|
+
);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
export function roundOffPixel(value: number): number {
|
|
88
|
+
return PixelRatio.roundToNearestPixel(value);
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Specific method for easier mocking
|
|
93
|
+
* Measures the layout of parent of RecyclerView
|
|
94
|
+
* Returns the x, y coordinates and dimensions of the view.
|
|
95
|
+
* @param view - The React Native View component to measure
|
|
96
|
+
* @returns An object containing x, y, width, and height measurements
|
|
97
|
+
*/
|
|
98
|
+
export function measureParentSize(view: View): Layout {
|
|
99
|
+
return measureLayout(view, undefined);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* Specific method for easier mocking
|
|
104
|
+
* Measures the layout of child container of RecyclerView
|
|
105
|
+
* @param childContainerView
|
|
106
|
+
* @param parentView
|
|
107
|
+
* @returns
|
|
108
|
+
*/
|
|
109
|
+
export function measureFirstChildLayout(
|
|
110
|
+
childContainerView: View,
|
|
111
|
+
parentView: View
|
|
112
|
+
): Layout {
|
|
113
|
+
return measureLayoutRelative(childContainerView, parentView, undefined);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* Specific method for easier mocking
|
|
118
|
+
* Measures the layout of items of RecyclerView
|
|
119
|
+
* @param item
|
|
120
|
+
* @param oldLayout
|
|
121
|
+
* @returns
|
|
122
|
+
*/
|
|
123
|
+
export function measureItemLayout(
|
|
124
|
+
item: View,
|
|
125
|
+
oldLayout: Layout | undefined
|
|
126
|
+
): Layout {
|
|
127
|
+
return measureLayout(item, oldLayout);
|
|
128
|
+
}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
interface Layout {
|
|
2
|
+
x: number;
|
|
3
|
+
y: number;
|
|
4
|
+
width: number;
|
|
5
|
+
height: number;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Gets scroll offsets from up to 3 parent elements
|
|
10
|
+
*/
|
|
11
|
+
function getScrollOffsets(element: Element, stopAt: Element) {
|
|
12
|
+
let scrollX = 0;
|
|
13
|
+
let scrollY = 0;
|
|
14
|
+
let currentElement: Element | null = element;
|
|
15
|
+
|
|
16
|
+
// Only check up to 3 parent elements
|
|
17
|
+
while (currentElement && currentElement !== stopAt) {
|
|
18
|
+
const htmlElement = currentElement as HTMLElement;
|
|
19
|
+
scrollX += htmlElement.scrollLeft ?? 0;
|
|
20
|
+
scrollY += htmlElement.scrollTop ?? 0;
|
|
21
|
+
currentElement = currentElement.parentElement;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
return { scrollX, scrollY };
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Checks if two dimension values are not equal, with a small tolerance.
|
|
29
|
+
*/
|
|
30
|
+
export function areDimensionsNotEqual(value1: number, value2: number): boolean {
|
|
31
|
+
return !areDimensionsEqual(value1, value2);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Checks if two dimension values are equal, with a small tolerance.
|
|
36
|
+
*/
|
|
37
|
+
export function areDimensionsEqual(value1: number, value2: number): boolean {
|
|
38
|
+
return Math.abs(value1 - value2) <= 1;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export function roundOffPixel(value: number): number {
|
|
42
|
+
return value;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Measures the layout of parent of RecyclerView
|
|
47
|
+
*/
|
|
48
|
+
export function measureParentSize(view: Element): Layout {
|
|
49
|
+
return {
|
|
50
|
+
x: 0,
|
|
51
|
+
y: 0,
|
|
52
|
+
width: view.clientWidth,
|
|
53
|
+
height: view.clientHeight,
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Measures the layout of child container of RecyclerView
|
|
59
|
+
*/
|
|
60
|
+
export function measureFirstChildLayout(
|
|
61
|
+
childContainerView: Element,
|
|
62
|
+
parentView: Element
|
|
63
|
+
): Layout {
|
|
64
|
+
const childRect = childContainerView.getBoundingClientRect();
|
|
65
|
+
const parentRect = parentView.getBoundingClientRect();
|
|
66
|
+
|
|
67
|
+
// Get scroll offsets for child container (max 3 parents)
|
|
68
|
+
const scrollOffsets = getScrollOffsets(childContainerView, parentView);
|
|
69
|
+
|
|
70
|
+
return {
|
|
71
|
+
x: childRect.left - parentRect.left + scrollOffsets.scrollX,
|
|
72
|
+
y: childRect.top - parentRect.top + scrollOffsets.scrollY,
|
|
73
|
+
width: roundOffPixel(childRect.width),
|
|
74
|
+
height: roundOffPixel(childRect.height),
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Measures the layout of items of RecyclerView
|
|
80
|
+
*/
|
|
81
|
+
export function measureItemLayout(
|
|
82
|
+
item: Element,
|
|
83
|
+
oldLayout: Layout | undefined
|
|
84
|
+
): Layout {
|
|
85
|
+
const layout = {
|
|
86
|
+
x: 0,
|
|
87
|
+
y: 0,
|
|
88
|
+
width: item.clientWidth,
|
|
89
|
+
height: item.clientHeight,
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
if (oldLayout) {
|
|
93
|
+
if (areDimensionsEqual(layout.width, oldLayout.width)) {
|
|
94
|
+
layout.width = oldLayout.width;
|
|
95
|
+
}
|
|
96
|
+
if (areDimensionsEqual(layout.height, oldLayout.height)) {
|
|
97
|
+
layout.height = oldLayout.height;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
return layout;
|
|
102
|
+
}
|
|
@@ -1,32 +1,7 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* MIT License
|
|
3
|
-
*
|
|
4
|
-
* Copyright (C) 2024 Huawei Device Co., Ltd.
|
|
5
|
-
*
|
|
6
|
-
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
7
|
-
* of this software and associated documentation files (the "Software"), to deal
|
|
8
|
-
* in the Software without restriction, including without limitation the rights
|
|
9
|
-
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
10
|
-
* copies of the Software, and to permit persons to whom the Software is
|
|
11
|
-
* furnished to do so, subject to the following conditions:
|
|
12
|
-
*
|
|
13
|
-
* The above copyright notice and this permission notice shall be included in all
|
|
14
|
-
* copies or substantial portions of the Software.
|
|
15
|
-
*
|
|
16
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
17
|
-
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
18
|
-
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
19
|
-
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
20
|
-
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
21
|
-
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
|
-
* SOFTWARE.
|
|
23
|
-
*/
|
|
24
|
-
|
|
25
1
|
import { ViewabilityConfig } from "react-native";
|
|
26
|
-
import { Dimension, Layout } from "recyclerlistview";
|
|
27
2
|
|
|
28
|
-
import
|
|
29
|
-
import
|
|
3
|
+
import { RVDimension, RVLayout } from "../layout-managers/LayoutManager";
|
|
4
|
+
import { ErrorMessages } from "../../errors/ErrorMessages";
|
|
30
5
|
|
|
31
6
|
/**
|
|
32
7
|
* Helper class for computing viewable items based on the passed `viewabilityConfig`.
|
|
@@ -72,8 +47,8 @@ class ViewabilityHelper {
|
|
|
72
47
|
public updateViewableItems(
|
|
73
48
|
horizontal: boolean,
|
|
74
49
|
scrollOffset: number,
|
|
75
|
-
listSize:
|
|
76
|
-
getLayout: (index: number) =>
|
|
50
|
+
listSize: RVDimension,
|
|
51
|
+
getLayout: (index: number) => RVLayout | undefined,
|
|
77
52
|
viewableIndices?: number[]
|
|
78
53
|
) {
|
|
79
54
|
if (viewableIndices !== undefined) {
|
|
@@ -85,8 +60,8 @@ class ViewabilityHelper {
|
|
|
85
60
|
this.viewabilityConfig?.viewAreaCoveragePercentThreshold !== null &&
|
|
86
61
|
this.viewabilityConfig?.viewAreaCoveragePercentThreshold !== undefined
|
|
87
62
|
) {
|
|
88
|
-
throw new
|
|
89
|
-
|
|
63
|
+
throw new Error(
|
|
64
|
+
ErrorMessages.multipleViewabilityThresholdTypesNotSupported
|
|
90
65
|
);
|
|
91
66
|
}
|
|
92
67
|
if (
|
|
@@ -150,10 +125,10 @@ class ViewabilityHelper {
|
|
|
150
125
|
index: number,
|
|
151
126
|
horizontal: boolean,
|
|
152
127
|
scrollOffset: number,
|
|
153
|
-
listSize:
|
|
128
|
+
listSize: RVDimension,
|
|
154
129
|
viewAreaCoveragePercentThreshold: number | null | undefined,
|
|
155
130
|
itemVisiblePercentThreshold: number | null | undefined,
|
|
156
|
-
getLayout: (index: number) =>
|
|
131
|
+
getLayout: (index: number) => RVLayout | undefined
|
|
157
132
|
) {
|
|
158
133
|
const itemLayout = getLayout(index);
|
|
159
134
|
if (itemLayout === undefined) {
|
|
@@ -1,30 +1,6 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* MIT License
|
|
3
|
-
*
|
|
4
|
-
* Copyright (C) 2024 Huawei Device Co., Ltd.
|
|
5
|
-
*
|
|
6
|
-
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
7
|
-
* of this software and associated documentation files (the "Software"), to deal
|
|
8
|
-
* in the Software without restriction, including without limitation the rights
|
|
9
|
-
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
10
|
-
* copies of the Software, and to permit persons to whom the Software is
|
|
11
|
-
* furnished to do so, subject to the following conditions:
|
|
12
|
-
*
|
|
13
|
-
* The above copyright notice and this permission notice shall be included in all
|
|
14
|
-
* copies or substantial portions of the Software.
|
|
15
|
-
*
|
|
16
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
17
|
-
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
18
|
-
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
19
|
-
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
20
|
-
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
21
|
-
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
|
-
* SOFTWARE.
|
|
23
|
-
*/
|
|
24
|
-
|
|
25
1
|
import { ViewabilityConfig } from "react-native";
|
|
26
2
|
|
|
27
|
-
import
|
|
3
|
+
import { RecyclerViewManager } from "../RecyclerViewManager";
|
|
28
4
|
|
|
29
5
|
import ViewabilityHelper from "./ViewabilityHelper";
|
|
30
6
|
import ViewToken from "./ViewToken";
|
|
@@ -33,31 +9,31 @@ import ViewToken from "./ViewToken";
|
|
|
33
9
|
* Manager for viewability tracking. It holds multiple viewability callback pairs and keeps them updated.
|
|
34
10
|
*/
|
|
35
11
|
export default class ViewabilityManager<T> {
|
|
36
|
-
private
|
|
12
|
+
private rvManager: RecyclerViewManager<T>;
|
|
37
13
|
private viewabilityHelpers: ViewabilityHelper[] = [];
|
|
38
14
|
private hasInteracted = false;
|
|
39
15
|
|
|
40
|
-
constructor(
|
|
41
|
-
this.
|
|
16
|
+
constructor(rvManager: RecyclerViewManager<T>) {
|
|
17
|
+
this.rvManager = rvManager;
|
|
42
18
|
if (
|
|
43
|
-
|
|
44
|
-
|
|
19
|
+
rvManager.props.onViewableItemsChanged !== null &&
|
|
20
|
+
rvManager.props.onViewableItemsChanged !== undefined
|
|
45
21
|
) {
|
|
46
22
|
this.viewabilityHelpers.push(
|
|
47
23
|
this.createViewabilityHelper(
|
|
48
|
-
|
|
24
|
+
rvManager.props.viewabilityConfig,
|
|
49
25
|
(info) => {
|
|
50
|
-
|
|
26
|
+
rvManager.props.onViewableItemsChanged?.(info);
|
|
51
27
|
}
|
|
52
28
|
)
|
|
53
29
|
);
|
|
54
30
|
}
|
|
55
|
-
(
|
|
31
|
+
(rvManager.props.viewabilityConfigCallbackPairs ?? []).forEach(
|
|
56
32
|
(pair, index) => {
|
|
57
33
|
this.viewabilityHelpers.push(
|
|
58
34
|
this.createViewabilityHelper(pair.viewabilityConfig, (info) => {
|
|
59
35
|
const callback =
|
|
60
|
-
|
|
36
|
+
rvManager.props.viewabilityConfigCallbackPairs?.[index]
|
|
61
37
|
?.onViewableItemsChanged;
|
|
62
38
|
callback?.(info);
|
|
63
39
|
})
|
|
@@ -95,21 +71,19 @@ export default class ViewabilityManager<T> {
|
|
|
95
71
|
};
|
|
96
72
|
|
|
97
73
|
public updateViewableItems = (newViewableIndices?: number[]) => {
|
|
98
|
-
const listSize =
|
|
99
|
-
this.flashListRef.getWindowSize() ??
|
|
100
|
-
this.flashListRef.props.estimatedListSize;
|
|
74
|
+
const listSize = this.rvManager.getWindowSize();
|
|
101
75
|
if (listSize === undefined || !this.shouldListenToVisibleIndices) {
|
|
102
76
|
return;
|
|
103
77
|
}
|
|
104
78
|
const scrollOffset =
|
|
105
|
-
(this.
|
|
106
|
-
this.
|
|
79
|
+
(this.rvManager.getAbsoluteLastScrollOffset() ?? 0) -
|
|
80
|
+
this.rvManager.firstItemOffset;
|
|
107
81
|
this.viewabilityHelpers.forEach((viewabilityHelper) => {
|
|
108
82
|
viewabilityHelper.updateViewableItems(
|
|
109
|
-
this.
|
|
83
|
+
this.rvManager.props.horizontal ?? false,
|
|
110
84
|
scrollOffset,
|
|
111
85
|
listSize,
|
|
112
|
-
(index: number) => this.
|
|
86
|
+
(index: number) => this.rvManager.getLayout(index),
|
|
113
87
|
newViewableIndices
|
|
114
88
|
);
|
|
115
89
|
});
|
|
@@ -130,19 +104,22 @@ export default class ViewabilityManager<T> {
|
|
|
130
104
|
private createViewabilityHelper = (
|
|
131
105
|
viewabilityConfig: ViewabilityConfig | null | undefined,
|
|
132
106
|
onViewableItemsChanged:
|
|
133
|
-
| ((info: {
|
|
107
|
+
| ((info: {
|
|
108
|
+
viewableItems: ViewToken<T>[];
|
|
109
|
+
changed: ViewToken<T>[];
|
|
110
|
+
}) => void)
|
|
134
111
|
| null
|
|
135
112
|
| undefined
|
|
136
113
|
) => {
|
|
137
|
-
const mapViewToken: (index: number, isViewable: boolean) => ViewToken = (
|
|
114
|
+
const mapViewToken: (index: number, isViewable: boolean) => ViewToken<T> = (
|
|
138
115
|
index: number,
|
|
139
116
|
isViewable: boolean
|
|
140
117
|
) => {
|
|
141
|
-
const item = this.
|
|
118
|
+
const item = this.rvManager.props.data![index];
|
|
142
119
|
const key =
|
|
143
|
-
item === undefined || this.
|
|
120
|
+
item === undefined || this.rvManager.props.keyExtractor === undefined
|
|
144
121
|
? index.toString()
|
|
145
|
-
: this.
|
|
122
|
+
: this.rvManager.props.keyExtractor(item, index);
|
|
146
123
|
return {
|
|
147
124
|
index,
|
|
148
125
|
isViewable,
|
|
@@ -1,27 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* MIT License
|
|
3
|
-
*
|
|
4
|
-
* Copyright (C) 2024 Huawei Device Co., Ltd.
|
|
5
|
-
*
|
|
6
|
-
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
7
|
-
* of this software and associated documentation files (the "Software"), to deal
|
|
8
|
-
* in the Software without restriction, including without limitation the rights
|
|
9
|
-
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
10
|
-
* copies of the Software, and to permit persons to whom the Software is
|
|
11
|
-
* furnished to do so, subject to the following conditions:
|
|
12
|
-
*
|
|
13
|
-
* The above copyright notice and this permission notice shall be included in all
|
|
14
|
-
* copies or substantial portions of the Software.
|
|
15
|
-
*
|
|
16
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
17
|
-
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
18
|
-
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
19
|
-
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
20
|
-
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
21
|
-
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
|
-
* SOFTWARE.
|
|
23
|
-
*/
|
|
24
|
-
|
|
25
1
|
/**
|
|
26
2
|
* Helper class to calculate running average of the most recent n values
|
|
27
3
|
*/
|
|
@@ -71,3 +47,36 @@ export class AverageWindow {
|
|
|
71
47
|
return newTarget;
|
|
72
48
|
}
|
|
73
49
|
}
|
|
50
|
+
|
|
51
|
+
export class MultiTypeAverageWindow {
|
|
52
|
+
private averageWindows: Map<string | number, AverageWindow>;
|
|
53
|
+
private windowSize: number;
|
|
54
|
+
private defaultValue?: number;
|
|
55
|
+
/**
|
|
56
|
+
* @param windowSize Size of the average window
|
|
57
|
+
* @param defaultValue Default value to return if no value is available
|
|
58
|
+
*/
|
|
59
|
+
constructor(windowSize: number, defaultValue?: number) {
|
|
60
|
+
this.averageWindows = new Map<string | number, AverageWindow>();
|
|
61
|
+
this.windowSize = windowSize;
|
|
62
|
+
this.defaultValue = defaultValue;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
public addValue(value: number, type: string | number): void {
|
|
66
|
+
let averageWindow = this.averageWindows.get(type);
|
|
67
|
+
if (!averageWindow) {
|
|
68
|
+
averageWindow = new AverageWindow(this.windowSize);
|
|
69
|
+
this.averageWindows.set(type, averageWindow);
|
|
70
|
+
}
|
|
71
|
+
averageWindow.addValue(value);
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
public getCurrentValue(type: string | number): number {
|
|
75
|
+
const averageWindow = this.averageWindows.get(type);
|
|
76
|
+
return averageWindow?.currentValue ?? this.defaultValue ?? 0;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
public reset(): void {
|
|
80
|
+
this.averageWindows.clear();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* MIT License
|
|
3
|
-
*
|
|
4
|
-
* Copyright (C) 2024 Huawei Device Co., Ltd.
|
|
5
|
-
*
|
|
6
|
-
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
7
|
-
* of this software and associated documentation files (the "Software"), to deal
|
|
8
|
-
* in the Software without restriction, including without limitation the rights
|
|
9
|
-
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
10
|
-
* copies of the Software, and to permit persons to whom the Software is
|
|
11
|
-
* furnished to do so, subject to the following conditions:
|
|
12
|
-
*
|
|
13
|
-
* The above copyright notice and this permission notice shall be included in all
|
|
14
|
-
* copies or substantial portions of the Software.
|
|
15
|
-
*
|
|
16
|
-
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
17
|
-
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
18
|
-
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
19
|
-
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
20
|
-
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
21
|
-
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
22
|
-
* SOFTWARE.
|
|
23
|
-
*/
|
|
24
|
-
import { Dimension, GridLayoutProvider, Layout, LayoutManager } from "recyclerlistview";
|
|
25
|
-
import { FlashListProps } from "./FlashListProps";
|
|
26
|
-
export default class GridLayoutProviderWithProps<T> extends GridLayoutProvider {
|
|
27
|
-
private props;
|
|
28
|
-
private layoutObject;
|
|
29
|
-
private averageWindow;
|
|
30
|
-
private renderWindowInsets;
|
|
31
|
-
private _hasExpired;
|
|
32
|
-
defaultEstimatedItemSize: number;
|
|
33
|
-
constructor(maxSpan: number, getLayoutType: (index: number, props: FlashListProps<T>, mutableLayout: {
|
|
34
|
-
span?: number;
|
|
35
|
-
size?: number;
|
|
36
|
-
}) => string | number, getSpan: (index: number, props: FlashListProps<T>, mutableLayout: {
|
|
37
|
-
span?: number;
|
|
38
|
-
size?: number;
|
|
39
|
-
}) => number, getHeightOrWidth: (index: number, props: FlashListProps<T>, mutableLayout: {
|
|
40
|
-
span?: number;
|
|
41
|
-
size?: number;
|
|
42
|
-
}) => number | undefined, props: FlashListProps<T>, acceptableRelayoutDelta?: number);
|
|
43
|
-
updateProps(props: FlashListProps<T>): GridLayoutProviderWithProps<T>;
|
|
44
|
-
/**
|
|
45
|
-
* This methods returns true if the layout provider has expired and needs to be recreated.
|
|
46
|
-
* This can happen if the number of columns has changed or the render window size has changed in a way that cannot be handled by the layout provider internally.
|
|
47
|
-
*/
|
|
48
|
-
get hasExpired(): boolean;
|
|
49
|
-
/**
|
|
50
|
-
* Calling this method will mark the layout provider as expired. As a result, a new one will be created by FlashList and old cached layouts will be discarded.
|
|
51
|
-
*/
|
|
52
|
-
markExpired(): void;
|
|
53
|
-
/**
|
|
54
|
-
* Calling this method will help the layout provider track average item sizes on its own
|
|
55
|
-
* Overriding layout manager can help achieve the same thing without relying on this method being called however, it will make implementation very complex for a simple use case
|
|
56
|
-
* @param index Index of the item being reported
|
|
57
|
-
*/
|
|
58
|
-
reportItemLayout(index: number): void;
|
|
59
|
-
get averageItemSize(): number;
|
|
60
|
-
newLayoutManager(renderWindowSize: Dimension, isHorizontal?: boolean, cachedLayouts?: Layout[]): LayoutManager;
|
|
61
|
-
private updateCachedDimensions;
|
|
62
|
-
private getCleanLayoutObj;
|
|
63
|
-
private getAdjustedRenderWindowSize;
|
|
64
|
-
}
|
|
65
|
-
//# sourceMappingURL=GridLayoutProviderWithProps.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"GridLayoutProviderWithProps.d.ts","sourceRoot":"","sources":["../src/GridLayoutProviderWithProps.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;GAsBG;AAEH,OAAO,EACL,SAAS,EACT,kBAAkB,EAClB,MAAM,EACN,aAAa,EACd,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAIlD,MAAM,CAAC,OAAO,OAAO,2BAA2B,CAAC,CAAC,CAAE,SAAQ,kBAAkB;IAC5E,OAAO,CAAC,KAAK,CAAoB;IACjC,OAAO,CAAC,YAAY,CAAwC;IAC5D,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,kBAAkB,CAAsC;IAChE,OAAO,CAAC,WAAW,CAAS;IACrB,wBAAwB,SAAO;gBAGpC,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,CACb,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,EACxB,aAAa,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,KAC5C,MAAM,GAAG,MAAM,EACpB,OAAO,EAAE,CACP,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,EACxB,aAAa,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,KAC5C,MAAM,EACX,gBAAgB,EAAE,CAChB,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,EACxB,aAAa,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,KAC5C,MAAM,GAAG,SAAS,EACvB,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,EACxB,uBAAuB,CAAC,EAAE,MAAM;IA6B3B,WAAW,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,2BAA2B,CAAC,CAAC,CAAC;IAmB5E;;;OAGG;IACH,IAAW,UAAU,YAEpB;IAED;;OAEG;IACI,WAAW;IAIlB;;;;OAIG;IACI,gBAAgB,CAAC,KAAK,EAAE,MAAM;IAYrC,IAAW,eAAe,WAEzB;IAEM,gBAAgB,CACrB,gBAAgB,EAAE,SAAS,EAC3B,YAAY,CAAC,EAAE,OAAO,EACtB,aAAa,CAAC,EAAE,MAAM,EAAE,GACvB,aAAa;IA0BhB,OAAO,CAAC,sBAAsB;IAe9B,OAAO,CAAC,iBAAiB;IAMzB,OAAO,CAAC,2BAA2B;CAOpC"}
|