@mstfmedeni/collapsible-tab-view
v0.2.2
Published
A react native component with collapsible header and custom refresh control, powered by Reanimated v4 & GestureHandler v2. Fork of @showtime-xyz/tab-view with additional features.
Downloads
12
Maintainers
Readme
Collapsible Tab View
A React Native component that supports a collapsible header and custom refresh control, powered by Reanimated v4 and GestureHandler v2.
Note: This is a fork of @showtime-xyz/tab-view with additional features and improvements, including:
- ✅ TabFlashList component with FlashList v2 support
- ✅ TypeScript 5.9 with improved type safety
- ✅ ESLint 9 with modern flat config
- ✅ Reanimated v4 compatibility
- ✅ Enhanced documentation and examples
What
This is a React Native tab view component that wraps gestures and animations on top of react-native-tab-view.
Original Repository: @showtime-xyz/tab-view Original Author: @alantoa
Features
- 🎯 Collapsible header - Smooth collapsing animation powered by Reanimated v4
- ⚡ High Performance - Built with Reanimated v4 for 60fps+ animations
- 📜 FlashList Support - Optional integration with FlashList v2 for optimal list performance
- 🔄 Custom Refresh Control - Pull-to-refresh with customizable animations
- 📱 Cross-Platform - Full support for iOS, Android, and Web
- 🎨 Customizable - Extensive styling and behavior customization options
- 🌊 Bounce Effect - Natural iOS-style bounce animations
- 🔍 Zoom Header - Optional zoom effect on pull-to-refresh (see example)
- 📦 TypeScript - Full TypeScript support with comprehensive type definitions
Installation
Prerequisites
This package requires the following peer dependencies to be installed in your project:
Required:
- react-native-reanimated (>= 4.0.0)
- react-native-gesture-handler (>= 2.0.0)
- react-native-pager-view (>= 5.0.0)
- react-native-tab-view (> 3.3.0)
Optional (for TabFlashList):
- @shopify/flash-list - For high-performance lists
# Install required dependencies
yarn add react-native-reanimated react-native-gesture-handler react-native-pager-view react-native-tab-view
# Optional: Install FlashList for better performance
yarn add @shopify/flash-listNote: Make sure to follow the setup instructions for react-native-reanimated and react-native-gesture-handler as they require additional native configuration.
Install Package
# Using yarn
yarn add @mstfmedeni/collapsible-tab-view
# Using npm
npm install @mstfmedeni/collapsible-tab-viewExamples
Usage
The API for this package is similar to react-native-tab-view, with extended props. A basic usage example is shown below:
import React, { useCallback, useState } from "react";
import { StatusBar, Text, View } from "react-native";
import { useSharedValue } from "react-native-reanimated";
import {
CollapsibleTabView,
Route,
TabFlashList,
TabFlatList,
TabScrollView,
TabSectionList,
} from "@mstfmedeni/collapsible-tab-view";
const StatusBarHeight = StatusBar.currentHeight ?? 0;
const TabScene = ({ route }: any) => {
return (
<TabFlashList
index={route.index}
data={new Array(20).fill(0)}
estimatedItemSize={60}
renderItem={({ index }) => {
return (
<View
style={{
height: 60,
backgroundColor: "#fff",
marginBottom: 8,
justifyContent: "center",
alignItems: "center",
}}
>
<Text>{`${route.title}-Item-${index}`}</Text>
</View>
);
}}
/>
);
};
export function Example() {
const [isRefreshing, setIsRefreshing] = useState(false);
const [routes] = useState<Route[]>([
{ key: "like", title: "Like", index: 0 },
{ key: "owner", title: "Owner", index: 1 },
{ key: "created", title: "Created", index: 2 },
]);
const [index, setIndex] = useState(0);
const animationHeaderPosition = useSharedValue(0);
const animationHeaderHeight = useSharedValue(0);
const renderScene = useCallback(({ route }: any) => {
switch (route.key) {
case "like":
return <TabScene route={route} index={0} />;
case "owner":
return <TabScene route={route} index={1} />;
case "created":
return <TabScene route={route} index={2} />;
default:
return null;
}
}, []);
const onStartRefresh = async () => {
setIsRefreshing(true);
setTimeout(() => {
console.log("onStartRefresh");
setIsRefreshing(false);
}, 300);
};
const renderHeader = () => (
<View style={{ height: 300, backgroundColor: "#000" }}></View>
);
return (
<CollapsibleTabView
onStartRefresh={onStartRefresh}
isRefreshing={isRefreshing}
navigationState={{ index, routes }}
renderScene={renderScene}
onIndexChange={setIndex}
lazy
renderScrollHeader={renderHeader}
minHeaderHeight={44 + StatusBarHeight}
animationHeaderPosition={animationHeaderPosition}
animationHeaderHeight={animationHeaderHeight}
/>
);
}API
Components
CollapsibleTabView
The main component that provides a tab view with a collapsible header. All props from react-native-tab-view are supported, plus additional props for header behavior.
Scrollable Components
All scrollable components require an index prop to identify the tab.
TabScrollView
A wrapper around React Native's ScrollView with collapsible header support.
import { TabScrollView } from "@mstfmedeni/collapsible-tab-view";
<TabScrollView index={0}>{/* Your content */}</TabScrollView>;TabFlatList
A wrapper around React Native's FlatList with collapsible header support.
import { TabFlatList } from "@mstfmedeni/collapsible-tab-view";
<TabFlatList
index={0}
data={data}
renderItem={({ item }) => <Item item={item} />}
keyExtractor={(item) => item.id}
/>;TabSectionList
A wrapper around React Native's SectionList with collapsible header support.
import { TabSectionList } from "@mstfmedeni/collapsible-tab-view";
<TabSectionList
index={0}
sections={sections}
renderItem={({ item }) => <Item item={item} />}
renderSectionHeader={({ section }) => <Header title={section.title} />}
/>;TabFlashList
A wrapper around Shopify's FlashList with collapsible header support. For optimal performance, especially with large lists.
Note: You need to install @shopify/flash-list separately:
yarn add @shopify/flash-listUsage:
import { TabFlashList } from "@mstfmedeni/collapsible-tab-view";
<TabFlashList
index={0}
data={data}
renderItem={({ item }) => <Item item={item} />}
estimatedItemSize={100} // Optional in FlashList v2
/>;FlashList v2 Features:
TabFlashList supports all FlashList v2 features including:
masonry- Enable masonry layout for grid-like interfacesonStartReached- Callback for loading older contentmaintainVisibleContentPosition- Maintain scroll position when content changes (enabled by default)- All FlashList hooks:
useLayoutState,useRecyclingState,useMappingHelper
Example with FlashList v2 features:
<TabFlashList
index={0}
data={data}
renderItem={({ item }) => <Item item={item} />}
masonry
numColumns={2}
onStartReached={() => loadOlderContent()}
maintainVisibleContentPosition={{
autoscrollToBottomThreshold: 0.2,
}}
/>For more details, see the FlashList documentation.
Contributing
To learn how to contribute to this repository and understand the development workflow, please refer to the contributing guide.
Shoutout
Special thanks to @Daavidaviid for experimenting with the zoom header effect with pull-to-refresh.
License
MIT
Made with create-react-native-library
