A simple React tab component with scrollable tab content
Made with create-react-library
react-scroll-tab
requires Node.js version 10 or greater and React 16.
# npm
npm install --save @eardi/react-scroll-tab
# yarn
yarn add @eardi/react-scroll-tab
import React from 'react';
import { Tabs, Tab, TabPanel, TabScrollableContent } from '@eardi/react-scroll-tab';
const INITIAL_TAB_VALUE = 0;
function Page() {
const [selectedTab, setSelectedTab] = useState(INITIAL_TAB_VALUE);
return (
<>
<Tabs value={selectedTab} variant="fullWidth" onChange={(index) => setSelectedTab(index)}>
<Tab>Tab 1</Tab>
<Tab>Tab 2</Tab>
<Tab>Tab 3</Tab>
</Tabs>
<TabScrollableContent>
<TabPanel value={selectedTab}>
<div>Tab 1 content</div>
</TabPanel>
<TabPanel value={selectedTab}>
<div>Tab 2 content</div>
</TabPanel>
<TabPanel value={selectedTab}>
<div>Tab 3 content</div>
</TabPanel>
</TabScrollableContent>
</>
);
}
The component is themeable. Below are the defined theme variables:
Name | Description | Default |
---|---|---|
tabTextColor | Tab text color when not selected | #333 |
tabSelectedTextColor | Selected Tab text color | #2980b9 (blue) |
tabIndicatorColor | Indicator line background color | #2980b9 (blue) |
tabFocusHoverBgColor | Tab background color when hovered or focused | rgba(41, 128, 185, 0.06) (transparent blue) |
tabFocusHoverColor | Tab text color when hovered or focused | #2980b9 (blue) |
tabBorderRadius | Border radius of the tab background | 0 |
tabListBorderBottomColor | Color of the Border line beneath the tabs list | rgba(0, 0, 0, 0.05) |
tabGap | Gap or margin between each tab item | 0 |
Below is an example (for more examples look at Storybook demos):
import React from 'react';
import { Tabs, Tab, TabPanel, TabScrollableContent } from '@eardi/react-scroll-tab';
const INITIAL_TAB_VALUE = 0;
const customTheme = {
tabTextColor: 'black',
tabSelectedTextColor: 'black',
tabSelectedBgColor: 'white',
tabIndicatorColor: 'black',
tabFocusHoverBgColor: 'rgb(0 0 0 / 1%)'
};
function Page() {
const [selectedTab, setSelectedTab] = useState(INITIAL_TAB_VALUE);
return (
<Tabs value={selectedTab} theme={customTheme} onChange={(index) => setSelectedTab(index)}>
<Tab>Tab 1</Tab>
<Tab>Tab 2</Tab>
<Tab>Tab 3</Tab>
</Tabs>
...
);
}
This should be mainly used for mobile views as swiping on mobile and touch devices is more friendly than scrolling. This wraps react-swipeable-views so you can use the documentation there.
import React from 'react';
import { Tabs, Tab, TabSwipeableContent } from '@eardi/react-scroll-tab';
const INITIAL_TAB_VALUE = 0;
function Page() {
const [selectedTab, setSelectedTab] = useState(INITIAL_TAB_VALUE);
return (
<>
<Tabs variant='fullWidth' value={selectedTab} onChange={setSelectedTab}>
<Tab>Tab 1</Tab>
<Tab>Tab 2</Tab>
<Tab>Tab 3</Tab>
</Tabs>
<TabSwipeableContent index={selectedTab} onChangeIndex={setSelectedTab}>
<div>
<h2>Tab 1 content</h2>
<h3>
Non do sint occaecat aliqua culpa culpa laboris tempor amet veniam
et duis.
</h3>
<p>
Elit do qui excepteur reprehenderit ex irure officia pariatur. Nulla
quis enim est deserunt irure esse veniam. Commodo enim tempor do in.
</p>
</div>
<div>
<h2>Tab 2 content</h2>
<h3>
Non do sint occaecat aliqua culpa culpa laboris tempor amet veniam
et duis.
</h3>
<p>
Elit do qui excepteur reprehenderit ex irure officia pariatur. Nulla
quis enim est deserunt irure esse veniam. Commodo enim tempor do in.
</p>
</div>
<div>
<h2>Tab 3 content</h2>
<h3>
Non do sint occaecat aliqua culpa culpa laboris tempor amet veniam
et duis.
</h3>
<p>
Elit do qui excepteur reprehenderit ex irure officia pariatur. Nulla
quis enim est deserunt irure esse veniam. Commodo enim tempor do in.
</p>
</div>
</TabSwipeableContent>
</>
);
}
MIT © ardeshireshghi