Skip to main content Home
About About the Design SystemRoadmap
Get started OverviewDesignersDevelopers
Foundations OverviewColorGridIconographyInteractionsSpacingTypography
Tokens Overview Global colorBox shadowTypographyBorderOpacitySpaceLengthIconBreakpointsMedia queries
Elements All elements Accordion Alert Announcement Audio player Avatar Back to top Badge Blockquote Breadcrumb Button Card Chip Code block Call to action Dialog Disclosure Footer Health index Icon Jump links Navigation (primary) Navigation (secondary) Pagination PopoverPlanned Progress stepper Scheme toggle Site status Skeleton Skip link Spinner Statistic Subnavigation Surface Switch Table Tabs Tag Tile Timestamp Tooltip Video embed
Theming OverviewColor PalettesCustomizingDevelopers
Patterns All PatternsAccordionCardFilterFormLink with iconLogo wallSearch barSticky bannerSticky cardTabsTagTile
Personalization All Personalization PatternsAnnouncement
Accessibility FundamentalsAccessibility toolsAssistive technologiesCI/CDContentContributorsDesignDevelopmentManual testingResourcesScreen readers
Design/code status Release notes Get support

Tabs

OverviewStyleGuidelinesCodeAccessibilityDemos
ImportingUsagerh-tabsrh-tab-panelrh-tabImportingUsagerh-tabsrh-tab-panelrh-tab

Importing

Add rh-tabs to your page with this import statement:

<script type="module">
  import '@rhds/elements/rh-tabs/rh-tabs.js';
</script>
Copy to Clipboard Wrap lines

To learn more about installing RHDS elements on your site using an import map read our getting started docs.

Usage

<rh-tabs>
  <rh-tab id="users"
          slot="tab"
          active>Users</rh-tab>
  <rh-tab-panel>Users</rh-tab-panel>
  <rh-tab slot="tab">Containers</rh-tab>
  <rh-tab-panel>Containers <a href="#">Focusable element</a></rh-tab-panel>
  <rh-tab slot="tab">Database</rh-tab>
  <rh-tab-panel>Database</rh-tab-panel>
  <rh-tab slot="tab">Servers</rh-tab>
  <rh-tab-panel>Servers</rh-tab-panel>
  <rh-tab slot="tab">Cloud</rh-tab>
  <rh-tab-panel>Cloud</rh-tab-panel>
</rh-tabs>

<script type="module">
  import '@rhds/elements/rh-tabs/rh-tabs.js';
</script>

<style>
  a {
    color: var(--rh-color-interactive-primary-default);

    &:hover {
      color: var(--rh-color-interactive-primary-hover);
    }

    &:focus-within {
      color: var(--rh-color-interactive-primary-focus);
    }

    &:active {
      color: var(--rh-color-interactive-primary-active);
    }

    &:visited {
      color: var(--rh-color-interactive-primary-visited);

      &:hover {
        color: var(--rh-color-interactive-primary-visited-hover);
      }

      &:focus-within {
        color: var(--rh-color-interactive-primary-visited-focus);
      }

      &:active {
        color: var(--rh-color-interactive-primary-visited-active);
      }
    }
  }
</style>
Copy to Clipboard Wrap lines

rh-tabs

Tabs are used to organize and navigate between sections of content. They feature a horizontal or a vertical list of section text labels with a content panel below or to the right of the component.

Slots 2
Slot Name Summary Description
tab

Must contain one or more <rh-tab>

[default]

Must contain one or more <rh-tab-panel>
Note: [default] unnamed slots do not have a slot="name" attribute.

Attributes 8
Attribute DOM Property Description Type Default
label-scroll-left labelScrollLeft

Label for the scroll left button

string
'Scroll left'
label-scroll-right labelScrollRight

Label for the scroll right button

string
'Scroll right'
manual manual

Tabs can be either automatic activated or manual

boolean
false
active-index activeIndex

Index of the active tab

unknown
unknown
color-palette colorPalette

Sets color context for child components, overrides parent context

ColorPalette
unknown
centered centered

Aligns tabs to the center

boolean
false
box box

Sets tabs to a boxed style with or without an inset

'box' | 'inset'
unknown
vertical vertical

Sets the alignment of the tabs vertical

boolean
false
Methods 2
Method Name Description
firstUpdated()
select(option: RhTab | number)
Events 0
None
CSS Shadow Parts 4
Part Name Summary Description
container

outer container

tabs-container

tabs container

tabs

tablist

panels

panels

CSS Custom Properties 1
CSS Property Description Default
--rh-tabs-inset var(--_inset-inline-margin, auto)
Design Tokens 14
Token Summary Copy
--rh-font-size-body-text-md
Full CSS Variable Permalink to this token
--rh-color-accent-base
Full CSS Variable Permalink to this token
--rh-color-text-secondary
Full CSS Variable Permalink to this token
--rh-color-gray-40
Full CSS Variable Permalink to this token
--rh-color-gray-50
Full CSS Variable Permalink to this token
--rh-space-3xl
Full CSS Variable Permalink to this token
--rh-space-4xl
Full CSS Variable Permalink to this token
--rh-space-2xl
Full CSS Variable Permalink to this token
--rh-space-lg
Full CSS Variable Permalink to this token
--rh-color-surface
Full CSS Variable Permalink to this token
--rh-border-width-sm
Full CSS Variable Permalink to this token
--rh-color-text-primary
Full CSS Variable Permalink to this token
--rh-border-width-lg
Full CSS Variable Permalink to this token
--rh-color-border-subtle
Full CSS Variable Permalink to this token

rh-tab-panel

The tab panel for use within a rh-tabs element, must be paired with a rh-tab.

Slots 1
Slot Name Summary Description
[default]

Panel content should follow guidelines for tab panel content layout
Note: [default] unnamed slots do not have a slot="name" attribute.

Attributes 0
None
Methods 0
None
Events 0
None
CSS Shadow Parts 0
None
CSS Custom Properties 0
None
Design Tokens 2
Token Summary Copy
--rh-space-2xl
Full CSS Variable Permalink to this token
--rh-color-interactive-primary-default
Full CSS Variable Permalink to this token

rh-tab

The tab button for use within a rh-tabs element, must be paired with a rh-tab-panel.

Slots 2
Slot Name Summary Description
icon

Can contain an <svg> or <rh-icon>

[default]

Tab title text
Note: [default] unnamed slots do not have a slot="name" attribute.

Attributes 2
Attribute DOM Property Description Type Default
active active

True when the tab is selected

boolean
false
disabled disabled

True when the tab is disabled

boolean
false
Methods 0
None
Events 1
Event Name Description
expand

when a tab expands

CSS Shadow Parts 3
Part Name Summary Description
button

element that contains the interactive part of a tab

icon

Can contain an <svg> or <rh-icon>

text

Tab title text

CSS Custom Properties 6
CSS Property Description Default
--rh-tabs-active-border-color var(--rh-color-accent-brand)
--rh-tabs-link-padding-inline-end

Tab padding inline end

var(--rh-space-2xl, 32px)
--rh-tabs-link-padding-inline-start

Tab padding inline start

var(--rh-space-2xl, 32px)
--rh-tabs-link-padding-block-start

Tab padding block start

var(--rh-space-md, 8px)
--rh-tabs-link-padding-block-end

Tab padding block end

var(--rh-space-md, 8px)
--rh-tabs-link-color

Tab link text color

var(--rh-color-text-primary)
Design Tokens 16
Token Summary Copy
--rh-color-accent-brand
Full CSS Variable Permalink to this token
--rh-color-surface
Full CSS Variable Permalink to this token
--rh-line-height-heading
Full CSS Variable Permalink to this token
--rh-color-text-secondary
Full CSS Variable Permalink to this token
--rh-color-surface-lighter
Full CSS Variable Permalink to this token
--rh-color-surface-dark
Full CSS Variable Permalink to this token
--rh-space-lg
Full CSS Variable Permalink to this token
--rh-space-2xl
Full CSS Variable Permalink to this token
--rh-space-md
Full CSS Variable Permalink to this token
--rh-space-xl
Full CSS Variable Permalink to this token
--rh-color-text-primary
Full CSS Variable Permalink to this token
--rh-border-width-sm
Full CSS Variable Permalink to this token
--rh-color-border-subtle
Full CSS Variable Permalink to this token
--rh-border-width-lg
Full CSS Variable Permalink to this token
--rh-color-interactive-secondary-default
Full CSS Variable Permalink to this token
--rh-color-interactive-primary-default
Full CSS Variable Permalink to this token
© 2025 Red Hat Deploys by Netlify