App Shell
The App Shell defines the main structure of your app.
Source
Theme source
@saas-ui/core
- 2.8.10 (latest)
Import
AppShell
: The container component that manages composition.
import { AppShell } from '@saas-ui/react'
Usage
A shell is a collection of components shared throughout your app and can consist of a header, sidebar, content aside, and footer.
To make sure AppShell fills up the entire viewport height, you can set
height="$100vh"
on the AppShell to make it fill the entire viewport height.
Basic shell
AppShell will try to fit it's parent with position absolute
and inset: 0
by default.
import { Box } from '@chakra-ui/react'import {AppShell,Sidebar,SidebarSection,NavItem,Navbar,NavbarBrand,NavbarContent,NavbarItem,SearchInput,} from '@saas-ui/react'export default function Page() {return (<AppShellnavbar={<Navbar borderBottomWidth="1px" position="sticky" top="0"><NavbarBrand><SaasUILogo width="100px" /></NavbarBrand><NavbarContent justifyContent="flex-end"><NavbarItem><SearchInput size="sm" /></NavbarItem></NavbarContent></Navbar>}sidebar={<Sidebar><SidebarSection><NavItem>Home</NavItem><NavItem>Settings</NavItem></SidebarSection></Sidebar>}><Box as="main" flex="1" py="2" px="4" overflowY="auto">Your application content</Box></AppShell>)}
Variants
The default variant is fullscreen
, using the static
variant the AppShell will behave like a regular flex box.
Use the static variant when the AppShell needs a fixed height, or when using a sticky header / sidebar.
import { Box } from '@chakra-ui/react'import {AppShell,Sidebar,SidebarSection,NavItem,Navbar,NavbarBrand,NavbarContent,NavbarItem,SearchInput,} from '@saas-ui/react'export default function Page() {return (<AppShellvariant="static"minH="$100vh"navbar={<Navbar borderBottomWidth="1px" position="sticky" top="0"><NavbarBrand><SaasUILogo width="100px" /></NavbarBrand><NavbarContent justifyContent="flex-end"><NavbarItem><SearchInput size="sm" /></NavbarItem></NavbarContent></Navbar>}sidebar={<Sidebar position="sticky" top="56px" toggleBreakpoint="sm"><SidebarSection><NavItem>Home</NavItem><NavItem>Settings</NavItem></SidebarSection></Sidebar>}><Box as="main" flex="1" py="2" px="4">Your application content</Box></AppShell>)}
Example layout
Full example with Sidebar, Page Pro and DataGrid Pro
import {Box,Spacer,Button,IconButton,Menu,MenuButton,MenuList,MenuItem,} from '@chakra-ui/react'import {AppShell,Sidebar,SidebarSection,NavItem,PersonaAvatar,} from '@saas-ui/react'import {Page,PageHeader,PageBody,DataGrid,DataGridPagination,} from '@saas-ui-pro/react'import { FiHome, FiUsers } from 'react-icons/fi'export default function Page() {return (<AppShellsidebar={<Sidebar width="30%" toggleBreakpoint="sm"><SidebarSection direction="row"><SaasUILogo width="100px" /><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"><NavItem icon={<FiHome size="1.2em" />}>Home</NavItem><NavItem icon={<FiUsers size="1.2em" />}>Contacts</NavItem></SidebarSection></Sidebar>}><Page><PageHeader title="Users" /><PageBody p="0"><DataGridisHoverableisSelectableisSortablecolumns={[{ id: 'name', Header: 'Name' },{ id: 'role', Header: 'Role' },{id: 'actions',width: '100px',Cell: () => <Button>Edit</Button>,},]}data={[{ name: 'Renata Alink', role: 'Founder' }]}><DataGridPagination /></DataGrid></PageBody></Page></AppShell>)}
Was this helpful?