npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@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

Readme

Collapsible Tab View

npm version npm downloads license

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:

Optional (for TabFlashList):

# 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-list

Note: 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-view

Examples

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-list

Usage:

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 interfaces
  • onStartReached - Callback for loading older content
  • maintainVisibleContentPosition - 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