Sidebar
Side navigation, commonly used as the primary navigation in web applications.
Source
Theme source
@saas-ui/core
- 2.8.10 (latest)
Import
Sidebar
: The container component that manages state.SidebarSection
: A sidebar section.SidebarToggleButton
: Button to toggle the sidebar visibility.SidebarOverlay
: Background overlay visible when the sidebar is open on mobile.NavGroup
: A group of navigation items.NavItem
: A navigation item.
import {Sidebar,SidebarSection,SidebarToggleButton,SidebarOverlay,NavGroup,NavItem,} from '@saas-ui/react'
Usage
Basic
import {Box,Spacer,Button,IconButton,Menu,MenuButton,MenuList,MenuItem,} from '@chakra-ui/react'import {AppShell,Sidebar,SidebarToggleButton,SidebarSection,NavItem,PersonaAvatar,} from '@saas-ui/react'import { FiHome, FiUsers } from 'react-icons/fi'export default function Page() {return (<AppShellsidebar={<Sidebar toggleBreakpoint="sm"><SidebarToggleButton /><SidebarSection direction="row"><Imagesrc="https://saas-ui.dev/favicons/favicon-96x96.png"boxSize="7"/><Spacer /><Menu><MenuButtonas={IconButton}icon={<PersonaAvatarpresence="online"size="xs"src="/showcase-avatar.jpg"/>}variant="ghost"/><MenuList><MenuItem>Sign out</MenuItem></MenuList></Menu></SidebarSection><SidebarSection aria-label="Main"><NavItem icon={<FiHome />} isActive>Home</NavItem><NavItem icon={<FiUsers />}>Users</NavItem><NavItem icon={<FiSettings />}>Settings</NavItem></SidebarSection></Sidebar>}/>)}
Grouped items
import {Box,Spacer,Button,IconButton,Menu,MenuButton,MenuList,MenuItem,} from '@chakra-ui/react'import {AppShell,Sidebar,SidebarToggleButton,SidebarSection,NavItem,NavGroup,PersonaAvatar,} from '@saas-ui/react'import { FiHome, FiUsers, FiSettings } from 'react-icons/fi'export default function Page() {return (<AppShellsidebar={<Sidebar toggleBreakpoint="sm"><SidebarToggleButton /><SidebarSection direction="row"><Imagesrc="https://saas-ui.dev/favicons/favicon-96x96.png"boxSize="7"/><Spacer /><Menu><MenuButtonas={IconButton}icon={<PersonaAvatarpresence="online"size="xs"src="/showcase-avatar.jpg"/>}variant="ghost"/><MenuList><MenuItem>Sign out</MenuItem></MenuList></Menu></SidebarSection><SidebarSection aria-label="Main"><NavGroup><NavItem icon={<FiHome />} isActive>Home</NavItem><NavItem icon={<FiUsers />}>Users</NavItem><NavItem icon={<FiSettings />}>Settings</NavItem></NavGroup><NavGroup title="Teams" isCollapsible><NavItem>Sales</NavItem><NavItem>Support</NavItem></NavGroup></SidebarSection></Sidebar>}/>)}
Scroll
Make a section in the sidebar scrollable by setting the overflowY
prop, use flex=1
to make sure it fills up the entire vertical space.
<SidebarSection flex="1" overflowY="auto"></SidebarSection>
import {Box,Badge,Text,Spacer,Button,IconButton,Menu,MenuButton,MenuList,MenuItem,} from '@chakra-ui/react'import {AppShell,Sidebar,SidebarToggleButton,SidebarSection,NavItem,NavGroup,PersonaAvatar,} from '@saas-ui/react'import { FiHome, FiUsers, FiSettings, FiHelpCircle } from 'react-icons/fi'export default function Page() {return (<AppShellsidebar={<Sidebar toggleBreakpoint="sm"><SidebarToggleButton /><SidebarSection direction="row"><Imagesrc="https://saas-ui.dev/favicons/favicon-96x96.png"boxSize="7"/><Spacer /><Menu><MenuButtonas={IconButton}icon={<PersonaAvatarpresence="online"size="xs"src="/showcase-avatar.jpg"/>}variant="ghost"/><MenuList><MenuItem>Sign out</MenuItem></MenuList></Menu></SidebarSection><SidebarSection flex="1" overflowY="auto"><NavGroup><NavItem icon={<FiHome />} isActive>Home</NavItem><NavItem icon={<FiUsers />}>Users</NavItem><NavItem icon={<FiSettings />}>Settings</NavItem></NavGroup><NavGroup title="Teams" isCollapsible><NavItem>Sales</NavItem><NavItem>Support</NavItem></NavGroup><NavGroup title="Tags" isCollapsible><NavItemicon={<Badge bg="purple.500" boxSize="2" borderRadius="full" />}><Text>Lead</Text><Badge opacity="0.6" borderRadius="full" bg="none" ms="auto">83</Badge></NavItem><NavItemicon={<Badge bg="cyan.500" boxSize="2" borderRadius="full" />}><Text>Customer</Text><Badge opacity="0.6" borderRadius="full" bg="none" ms="auto">210</Badge></NavItem></NavGroup></SidebarSection><SidebarSection><NavItem icon={<FiHelpCircle />}>Documentation</NavItem></SidebarSection></Sidebar>}/>)}
Compact variant
The compact
variant can be used as a collapsed state on smaller screens, or as the primary navigation in a double sidebar layout, see below.
NavItem labels will be rendered as tooltips.
Use the tooltipProps
prop to customize the tooltip.
import { Box, Image } from '@chakra-ui/react'import {AppShell,Sidebar,SidebarSection,SidebarToggleButton,NavItem,} from '@saas-ui/react'import { FiHome, FiUsers, FiSettings } from 'react-icons/fi'export default function Page() {return (<AppShellsidebar={<Sidebar variant="compact" width="64px" toggleBreakpoint="sm"><SidebarToggleButton /><SidebarSection alignItems="center"><Imagesrc="https://saas-ui.dev/favicons/favicon-96x96.png"boxSize="7"/></SidebarSection><SidebarSection><NavItem icon={<FiHome size="1.2em" />} size="md">Home</NavItem><NavItem icon={<FiUsers size="1.2em" />} size="md">Users</NavItem><NavItem icon={<FiSettings size="1.2em" />} size="md">Settings</NavItem></SidebarSection></Sidebar>}/>)}
Toggle variant
import { Box, Spacer, IconButton, Image, useDisclosure } from '@chakra-ui/react'import {AppShell,Sidebar,SidebarSection,SidebarOverlay,NavItem,NavGroup,} from '@saas-ui/react'import {FiHome,FiUsers,FiSettings,FiStar,FiChevronsLeft,FiChevronsRight,} from 'react-icons/fi'export default function ToggleVariant() {const { isOpen, onToggle } = useDisclosure({defaultIsOpen: true,})return (<AppShellsidebar={<SidebartoggleBreakpoint={false}variant={isOpen ? 'default' : 'compact'}transition="width"transitionDuration="normal"width={isOpen ? '280px' : '14'}minWidth="auto"><SidebarSection direction={isOpen ? 'row' : 'column'}><Imagesrc="https://saas-ui.dev/favicons/favicon-96x96.png"boxSize="6"mb="1"display={isOpen ? 'block' : 'none'}/><Spacer /><IconButtononClick={onToggle}variant="ghost"size="sm"icon={isOpen ? <FiChevronsLeft /> : <FiChevronsRight />}aria-label="Toggle Sidebar"/></SidebarSection><SidebarSection flex="1" overflowY="auto" overflowX="hidden"><NavGroup><NavItem icon={<FiHome />} isActive>All users</NavItem><NavItem icon={<FiStar />}>Favourite users</NavItem></NavGroup></SidebarSection><SidebarOverlay zIndex="1" /></Sidebar>}/>)}
Double sidebar
You can stack multiple sidebars together to create a double sidebar layout.
import { Box, HStack, Image, Heading, Text, Badge } from '@chakra-ui/react'import {AppShell,Sidebar,SidebarSection,NavItem,NavGroup,PersonaAvatar,} from '@saas-ui/react'import { FiHome, FiUsers, FiSettings, FiHelpCircle } from 'react-icons/fi'export default function Page() {return (<AppShellsidebar={<HStack spacing="0" alignItems="stretch"><Sidebarvariant="compact"bg="purple.500"borderWidth="0"spacing="3"_dark={{bg: 'purple.500',}}><SidebarSection><Imagesrc="https://saas-ui.dev/favicons/favicon-96x96.png"boxSize="7"/></SidebarSection><SidebarSection><NavItem icon={<FiHome size="1.2em" color="white" />}>Home</NavItem><NavItem icon={<FiUsers size="1.2em" color="white" />} isActive>Users</NavItem><NavItem icon={<FiSettings size="1.2em" color="white" />}>Settings</NavItem></SidebarSection></Sidebar><Sidebar toggleBreakpoint="sm"><SidebarSection direction="row" mt="2" px="4"><Heading size="sm" fontWeight="semibold">Users</Heading></SidebarSection><SidebarSection flex="1" overflowY="auto"><NavGroup><NavItem icon={<FiUsers />} isActive>Overview</NavItem></NavGroup><NavGroup title="Teams" isCollapsible><NavItem>Sales</NavItem><NavItem>Support</NavItem></NavGroup><NavGroup title="Tags" isCollapsible><NavItemicon={<Badge bg="purple.500" boxSize="2" borderRadius="full" />}><Text>Lead</Text><Badge opacity="0.6" borderRadius="full" bg="none" ms="auto">83</Badge></NavItem><NavItemicon={<Badge bg="cyan.500" boxSize="2" borderRadius="full" />}><Text>Customer</Text><Badge opacity="0.6" borderRadius="full" bg="none" ms="auto">210</Badge></NavItem></NavGroup></SidebarSection><SidebarSection><NavItem icon={<FiHelpCircle />}>Documentation</NavItem></SidebarSection></Sidebar></HStack>}/>)}
Breakpoints
The sidebar will automatically close on small screens. You can change this behavior by customizing the toggleBreakpoint
. Breakpoints are disabled for the compact
variant.
The default breakpoint is lg
, to disable the breakpoint set the toggleBreakpoint
to false
.
<Sidebar toggleBreakpoint="lg" />
Custom toggleBreakpoint
value:
import {Box,Spacer,Button,IconButton,Menu,MenuButton,MenuList,MenuItem,Image,} from '@chakra-ui/react'import {AppShell,Sidebar,SidebarSection,NavItem,NavGroup,PersonaAvatar,} from '@saas-ui/react'import { FiHome, FiUsers, FiSettings } from 'react-icons/fi'export default function Page() {return (<AppShellsidebar={<Sidebar toggleBreakpoint="xl"><SidebarToggleButton /><SidebarSection direction="row"><Imagesrc="https://saas-ui.dev/favicons/favicon-96x96.png"boxSize="7"/><Spacer /><Menu><MenuButtonas={IconButton}icon={<PersonaAvatarpresence="online"size="xs"src="/showcase-avatar.jpg"/>}variant="ghost"/><MenuList><MenuItem>Sign out</MenuItem></MenuList></Menu></SidebarSection><SidebarSection aria-label="Main"><NavItem icon={<FiHome />} isActive>Home</NavItem><NavItem icon={<FiUsers />}>Users</NavItem><NavItem icon={<FiSettings />}>Settings</NavItem></SidebarSection><SidebarOverlay /></Sidebar>}/>)}
Was this helpful?