Skip to main content
🏠ComponentsTabs

Tabs

Tabs organize content into multiple sections and allow users to navigate between them.

Basic tabs

A basic example with three tabs.

const [activeId, setActiveId] = useState('tab1');

<Tabs activeId={activeId} onActiveIdChanged={setActiveId}>
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

Sizes

Set size attribute to small or medium to style tabs size. By default, tabs have size medium.

<Tabs size="small">
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>
<Tabs size="medium">
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

States

Active State

Set the activeId prop on the Tabs component to control which tab is active.

<Tabs activeId="tab1">
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

Disabled State

Add disabled attribute to tab to style it as disabled.

<Tabs>
<Tab id="tab1" disabled label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

Divider

By default, tabs has a divider. Alternatively, tabs can be used without a divider by setting divider to false.

<Tabs divider={false}>
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

Layout

  • fullWidth attribute if you want the tabs container to take up the whole width.
  • fullHeight attribute if you want the tabs container to take up the whole height.

Fluid Tabs

Add fullWidth and fluid to Tabs if you want set equal tabs widths when the tabs wrapper takes up the whole width available.

<Tabs fullWidth fluid>
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

Alignment

Tabs alignment can be set by setting alignment attribute to left, center, right.

Left alignment

<Tabs fullWidth alignment="left">
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

Center alignment

<Tabs fullWidth alignment="center">
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

Right alignment

<Tabs fullWidth alignment="right">
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

Scrollable tabs

Use scrollHorizontally to allow horizontal scrolling if needed.

<Tabs scrollHorizontally fullWidth>
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
<Tab id="tab4" label="Item 4" />
<Tab id="tab5" label="Item 5" />
<Tab id="tab6" label="Item 6" />
<Tab id="tab7" label="Item 7" />
</Tabs>

Icons

Tab labels may be either all icons or all text.

<Tabs>
<Tab id="tab1" icon={<Icon icon="settings" />} />
<Tab id="tab2" icon={<Icon icon="account_circle" />} />
<Tab id="tab3" icon={<Icon icon="face" />} />
</Tabs>
<Tabs>
<Tab id="tab1" icon={<Icon icon="settings" />} label="Item 1" />
<Tab id="tab2" icon={<Icon icon="account_circle" />} label="Item 2" />
<Tab id="tab3" icon={<Icon icon="face" />} label="Item 3" />
</Tabs>

Icon position

By default, the icon is positioned at the start of a tab. Other supported position is end.

<Tabs>
<Tab id="tab1" icon={<Icon icon="settings" />} label="Item 1" iconPosition="start" />
<Tab id="tab2" icon={<Icon icon="account_circle" />} label="Item 2" iconPosition="end" />
<Tab id="tab3" icon={<Icon icon="face" />} label="Item 3" />
</Tabs>

Vertical Tab

Set tabItemDirection attribute to horizontal or vertical to allow horizontal/vertical tab layout.

<Tabs tabItemDirection="vertical">
<Tab id="tab1" icon={<Icon icon="settings" />} label="Item 1" />
<Tab id="tab2" icon={<Icon icon="account_circle" />} label="Item 2" />
<Tab id="tab3" icon={<Icon icon="face" />} label="Item 3" />
</Tabs>

Customization

A Tab can also take any content in their children.

<Tabs>
<Tab id="tab1">
<Icon icon="settings" />
<Typography classes="text-green-500">Item 1</Typography>
</Tab>
<Tab id="tab2">
<Icon icon="account_circle" />
<Typography classes="text-red-500">Item 2</Typography>
</Tab>
<Tab id="tab3">
<Icon icon="face" />
<Typography classes="text-primary-500">Item 3</Typography>
</Tab>
</Tabs>

Event handling

The Tabs component provides a main event handler to manage active tab changes:

onActiveIdChanged

Triggered when a user clicks on a tab. The callback receives the ID of the selected tab as a parameter.

const [activeId, setActiveId] = useState('tab1');

const handleTabChange = (id) => {
console.log(`Tab changed to: ${id}`);
setActiveId(id);

// Additional logic based on the selected tab
if (id === 'tab2') {
loadTabTwoContent();
}
};

<Tabs activeId={activeId} onActiveIdChanged={handleTabChange}>
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

By using this event handler with local state, you can:

  • Control which tab is active
  • Load specific content based on the selected tab
  • Trigger other actions when a particular tab is selected

Note that disabled tabs (disabled={true}) will not trigger this event when clicked.

Custom Classes

Add your own classes in the classes attribute. This way you will be able to override or extend the styles applied to the component (you can use available utility classes by importing @qtm/css/dist/utilities.css).

<Tabs classes="bg-bluegrey-100 p-s rounded-m">
<Tab id="tab1" label="Item 1" />
<Tab id="tab2" label="Item 2" />
<Tab id="tab3" label="Item 3" />
</Tabs>

API

QtmTabs

PropertyTypeDefaultDescription
alignment"center" | "left" | "right"'left'set the tabs alignement when the tabs component takes up the whole width available( fullWidth=true)
classesstringlist of classes to override or extend the styles applied to the component. You can use available utility classes by importing
dividerbooleantrueIf true, the divider is displayed.
fluidbooleanfalseset equal tabs widths when the tabs component takes up the whole width available( fullWidth=true)
fullHeightbooleanfalseIf true, the tabs component takes up the whole height available
fullWidthbooleanfalseIf true, the tabs component takes up the whole width available
scrollHorizontallybooleanfalseIf true, the tabs component scroll horizontally
size"medium" | "small"'medium'tab size
tabItemDirection"horizontal" | "vertical"'horizontal'set tabs component's direction

QtmTab

PropertyTypeDefaultDescription
activebooleanfalseIf true, the tab is active
classesstringlist of classes to override or extend the styles applied to the component. You can use available utility classes by importing
disabledbooleanfalseIf true, the component is disabled.
iconstring | { icon: string; classes?: string; lib?: IconLibType; size?: IconSizeType; variant?: IconVariantType; }icon to display
iconPosition"end" | "start"'start'icon position 'start' | 'end'
labelstringtext to display
EventTypeDescription
onClickedTabEventCustomEvent<string>Callback fired when the tab is clicked.