# Tabs
Kickstand UI's tabs component are a useful way to group related information in a discoverable way.
data:image/s3,"s3://crabby-images/728bc/728bc294596c1f3eb8667f24666d2d49f7fcee86" alt="three-hole-punch jim"
data:image/s3,"s3://crabby-images/54b44/54b44ec3bfa4253d34eaf955f6bfcfb1b342451e" alt="jim dressed as dave"
data:image/s3,"s3://crabby-images/cf56b/cf56be6180bc4f3e1842c44ebb4b4d284541cd1f" alt="jim dressed as facebook"
data:image/s3,"s3://crabby-images/9bc09/9bc09f1d0fa0710e7fe2556b0e69ce5d124a149b" alt="jim dressed as popeye"
<ks-tabs>
<ks-tab tab-text="Three Hole Punch Jim">
<img src="/images/demo/costumes/three_hole_punch_jim.jpg" alt="three-hole-punch jim" />
</ks-tab>
<ks-tab tab-text="Dave">
<img src="/images/demo/costumes/jim_as_dave.jpg" alt="jim dressed as dave" />
</ks-tab>
<ks-tab tab-text="Facebook">
<img src="/images/demo/costumes/jim_as_facebook.jpg" alt="jim dressed as facebook" />
</ks-tab>
<ks-tab tab-text="Popeye <ks-badge class='ml-sm'>New</ks-badge>">
<img src="/images/demo/costumes/jim_as_popeye.jpeg" alt="jim dressed as popeye" />
</ks-tab>
</ks-tabs>
NOTE
As you can see in the last tab, the tab-text
attribute supports markup to increase functionality and flexibility.
# Positioning
You can configure the position of the tabs using the position
property. The available options are top
, bottom
, left
, or right
.
# Left
data:image/s3,"s3://crabby-images/4c849/4c849a9987c25697347bef23674a20c39d30cfa9" alt="Dwight dressed as The Joker"
data:image/s3,"s3://crabby-images/4916d/4916dd7bc2df3678190002131b95bc1be28c9e97" alt="Creed dressed as The Joker"
data:image/s3,"s3://crabby-images/bd54b/bd54b85999a5f0c4a73d96d6b01e55c89a5a31ce" alt="Kevin dressed as The Joker"
<ks-tabs position="left">
<ks-tab tab-text="Dwight">
<img src="/images/demo/costumes/dwight_joker.jpg" alt="Dwight dressed as The Joker" />
</ks-tab>
<ks-tab tab-text="Creed">
<img src="/images/demo/costumes/creed_joker.jpg" alt="Creed dressed as The Joker" />
</ks-tab>
<ks-tab tab-text="Kevin">
<img src="/images/demo/costumes/kevin_joker.jpg" alt="Kevin dressed as The Joker" />
</ks-tab>
</ks-tabs>
# Right
data:image/s3,"s3://crabby-images/6825c/6825cd37d6855c64594550db881a2c12ce7b69d1" alt="Meredith dressed as Black Widow"
data:image/s3,"s3://crabby-images/27f39/27f39fad829129a0fdf179f122e676cd9f08721f" alt="Daryl dressed as Dracula"
data:image/s3,"s3://crabby-images/ee6aa/ee6aa5e9c900bbf0df8b7162e1ec2bc9ae690ae7" alt="Ryan dressed as Justin Bieber"
<ks-tabs position="right">
<ks-tab tab-text="Black Widow">
<img src="/images/demo/costumes/black_widow.jpg" alt="Meredith dressed as Black Widow" />
</ks-tab>
<ks-tab tab-text="Dracula">
<img src="/images/demo/costumes/dracula.jpg" alt="Daryl dressed as Dracula" />
</ks-tab>
<ks-tab tab-text="Justin Bieber">
<img src="/images/demo/costumes/justin_bieber.jpg" alt="Ryan dressed as Justin Bieber" />
</ks-tab>
</ks-tabs>
# Bottom
data:image/s3,"s3://crabby-images/ee4b8/ee4b8c51006b58e942ffc38306a73f2f1acb6723" alt="Gabe dressed as Lady Gaga"
data:image/s3,"s3://crabby-images/c4929/c4929e0024f5b8ad8efa091f11602e6847620672" alt="Angela dressed as Nancy Reagan"
data:image/s3,"s3://crabby-images/55c0c/55c0c69a59f8703060e90bf5dc9987ebbb2ad8f6" alt="Phillis dressed as Raggedy Ann"
<ks-tabs position="bottom">
<ks-tab tab-text="Lady Gaga">
<img src="/images/demo/costumes/lady_gaga.jpg" alt="Gabe dressed as Lady Gaga" />
</ks-tab>
<ks-tab tab-text="Nancy Reagan">
<img src="/images/demo/costumes/nancy_reagan.jpg" alt="Angela dressed as Nancy Reagan" />
</ks-tab>
<ks-tab tab-text="Raggedy Ann">
<img src="/images/demo/costumes/raggedy_ann.jpg" alt="Phillis dressed as Raggedy Ann" />
</ks-tab>
</ks-tabs>
# Alignment
You can also control the alignment of the tabs within the tab-list
container using the align
property. The available options are start
, center
, end
, and justified
. Tabs will be aligned at the start
of the container by default.
# Start
data:image/s3,"s3://crabby-images/4c849/4c849a9987c25697347bef23674a20c39d30cfa9" alt="Dwight dressed as The Joker"
data:image/s3,"s3://crabby-images/4916d/4916dd7bc2df3678190002131b95bc1be28c9e97" alt="Creed dressed as The Joker"
data:image/s3,"s3://crabby-images/bd54b/bd54b85999a5f0c4a73d96d6b01e55c89a5a31ce" alt="Kevin dressed as The Joker"
<ks-tabs align="start">
<ks-tab tab-text="Dwight">
<img src="/images/demo/costumes/dwight_joker.jpg" alt="Dwight dressed as The Joker" />
</ks-tab>
<ks-tab tab-text="Creed">
<img src="/images/demo/costumes/creed_joker.jpg" alt="Creed dressed as The Joker" />
</ks-tab>
<ks-tab tab-text="Kevin">
<img src="/images/demo/costumes/kevin_joker.jpg" alt="Kevin dressed as The Joker" />
</ks-tab>
</ks-tabs>
# Center
data:image/s3,"s3://crabby-images/6825c/6825cd37d6855c64594550db881a2c12ce7b69d1" alt="Meredith dressed as Black Widow"
data:image/s3,"s3://crabby-images/27f39/27f39fad829129a0fdf179f122e676cd9f08721f" alt="Daryl dressed as Dracula"
data:image/s3,"s3://crabby-images/ee6aa/ee6aa5e9c900bbf0df8b7162e1ec2bc9ae690ae7" alt="Ryan dressed as Justin Bieber"
<ks-tabs align="center">
<ks-tab tab-text="Black Widow">
<img src="/images/demo/costumes/black_widow.jpg" alt="Meredith dressed as Black Widow" />
</ks-tab>
<ks-tab tab-text="Dracula">
<img src="/images/demo/costumes/dracula.jpg" alt="Daryl dressed as Dracula" />
</ks-tab>
<ks-tab tab-text="Justin Bieber">
<img src="/images/demo/costumes/justin_bieber.jpg" alt="Ryan dressed as Justin Bieber" />
</ks-tab>
</ks-tabs>
# End
data:image/s3,"s3://crabby-images/ee4b8/ee4b8c51006b58e942ffc38306a73f2f1acb6723" alt="Gabe dressed as Lady Gaga"
data:image/s3,"s3://crabby-images/c4929/c4929e0024f5b8ad8efa091f11602e6847620672" alt="Angela dressed as Nancy Reagan"
data:image/s3,"s3://crabby-images/55c0c/55c0c69a59f8703060e90bf5dc9987ebbb2ad8f6" alt="Phillis dressed as Raggedy Ann"
<ks-tabs align="end">
<ks-tab tab-text="Lady Gaga">
<img src="/images/demo/costumes/lady_gaga.jpg" alt="Gabe dressed as Lady Gaga" />
</ks-tab>
<ks-tab tab-text="Nancy Reagan">
<img src="/images/demo/costumes/nancy_reagan.jpg" alt="Angela dressed as Nancy Reagan" />
</ks-tab>
<ks-tab tab-text="Raggedy Ann">
<img src="/images/demo/costumes/raggedy_ann.jpg" alt="Phillis dressed as Raggedy Ann" />
</ks-tab>
</ks-tabs>
# Justified
data:image/s3,"s3://crabby-images/728bc/728bc294596c1f3eb8667f24666d2d49f7fcee86" alt="three-hole-punch jim"
data:image/s3,"s3://crabby-images/54b44/54b44ec3bfa4253d34eaf955f6bfcfb1b342451e" alt="jim dressed as dave"
data:image/s3,"s3://crabby-images/cf56b/cf56be6180bc4f3e1842c44ebb4b4d284541cd1f" alt="jim dressed as facebook"
data:image/s3,"s3://crabby-images/9bc09/9bc09f1d0fa0710e7fe2556b0e69ce5d124a149b" alt="jim dressed as popeye"
<ks-tabs align="justified">
<ks-tab tab-text="Three Hole Punch Jim">
<img src="/images/demo/costumes/three_hole_punch_jim.jpg" alt="three-hole-punch jim" />
</ks-tab>
<ks-tab tab-text="Dave">
<img src="/images/demo/costumes/jim_as_dave.jpg" alt="jim dressed as dave" />
</ks-tab>
<ks-tab tab-text="Facebook">
<img src="/images/demo/costumes/jim_as_facebook.jpg" alt="jim dressed as facebook" />
</ks-tab>
<ks-tab tab-text="Popeye">
<img src="/images/demo/costumes/jim_as_popeye.jpeg" alt="jim dressed as popeye" />
</ks-tab>
</ks-tabs>
# Accessibility
A number of features have been added to the tab components to make tabs more identifiable and accessible for assistive technologies:
- The tab buttons are wrapped in a
<div>
withrole="tablist"
to identify the available tab options. - Each of the tab buttons has
role="tab"
and usesaria-controls
to associate the tab with the tab panel. - The
<ks-tab>
component hasrole="tabpanel"
and uses thearia-labelledby
to use the tab content to describe the tab. - Having to tab through each of the tab options can be tedious for keyboard users, so when users are focused on tabs, they can use the ← (left) and → (right) arrow keys to select different tabs.
# Properties
# <ks-tabs>
Property | Attribute | Description | Type | Default |
---|---|---|---|---|
position | position | the position of the tabs around the tab content | top , bottom , left , or right | top |
align | align | the alignment if the tabs | start , center , end , or justified | start |
# <ks-tab>
Property | Attribute | Description | Type | Default |
---|---|---|---|---|
tabText | tab-text | the text that will display in the tab button | string | undefined |