Tabs
Organize content to sections.
Food shopping
12:00pm
John's Birthday party
5:00pm
Work management meeting
22/03/2024 - 12:00pm (in 2 days)
Jane's Birthday
24/03/2024 - 8:00pm (in 4 days)
<script lang="ts">
import { Tabs, TabsButton, TabsContent, TabsList } from 'lithesome';
import { cn } from '$site/index.js';
const tabs = [
{
btn: 'today',
content: [
{
title: 'Food shopping',
date: {
time: '12:00pm',
date: undefined,
daysLeft: undefined
}
},
{
title: `John's Birthday party`,
date: {
time: '5:00pm',
date: undefined,
daysLeft: undefined
}
}
]
},
{
btn: 'upcoming',
content: [
{
title: 'Work management meeting',
date: {
time: '12:00pm',
date: '22/03/2024',
daysLeft: '2 days'
}
},
{
title: `Jane's Birthday`,
date: {
time: '8:00pm',
date: '24/03/2024',
daysLeft: '4 days'
}
}
]
}
];
</script>
<Tabs class="w-full max-w-[70%] rounded-md border border-neutral-300 bg-white dark:border-white/10 dark:bg-white/5">
<TabsList class="flex border-b border-neutral-300 dark:border-white/10">
{#each tabs as tab}
<TabsButton
value={tab.btn}
class={({ active }) =>
cn(
'relative flex-1 border-r py-4 text-center capitalize last:border-r-0',
'border-neutral-300 hover:bg-black/[0.035] dark:border-white/10 dark:hover:bg-white/5',
active ? 'text-black dark:text-white' : ''
)}
>
{#snippet children({ active })}
{tab.btn}
{#if active}
<div class="absolute bottom-2 left-1/2 h-1 w-8 -translate-x-1/2 rounded-xl bg-teal-500"></div>
{/if}
{/snippet}
</TabsButton>
{/each}
</TabsList>
{#each tabs as tab}
<TabsContent value={tab.btn} class="p-4">
{#each tab.content as { title, date }}
<div class="rounded-md px-5 py-2 hover:bg-black/[0.035] dark:hover:bg-white/5">
<h4 class="font-medium text-black dark:text-white">{title}</h4>
<p class="text-neutral-500 dark:text-neutral-400">
{#if date.date}
<span>{date.date} -</span>
{/if}
{date.time}
{#if date.daysLeft}
<span>(in {date.daysLeft})</span>
{/if}
</p>
</div>
{/each}
</TabsContent>
{/each}
</Tabs>
API Reference
Tabs
Prop | Type | Description |
---|---|---|
orientation | 'horizontal' | 'vertical' Default: horizontal | The direction of the tabs. This setting will only effect how the keyboard navigation works. |
value | string Default: —— | The selected tab. |
use | Array Default: [] | Any svelte action to be applied to the underlying element. View use api for more info. |
self | HTMLDivElement Default: —— | The underlying html element that you can use to bind to. |
Child prop | Type | Description |
---|---|---|
active | string | The value of the active tab. |
Data attribute | Value | Description |
---|---|---|
data-tabs | '' | The base data attribute, can be used for styling. |
data-orientation | 'horizontal' | 'vertical' | The direction of the tabs. |
TabsList
This component is a child of Tabs
Prop | Type | Description |
---|---|---|
use | Array Default: [] | Any svelte action to be applied to the underlying element. View use api for more info. |
self | HTMLDivElement Default: —— | The underlying html element that you can use to bind to. |
Data attribute | Value | Description |
---|---|---|
data-tabslist | '' | The base data attribute, can be used for styling. |
data-orientation | 'horizontal' | 'vertical' | The direction of the tabs. |
TabsButton
This component is a child of TabsList
Prop | Type | Description |
---|---|---|
value * | string Default: —— | The unique value of the button. This must match one of the content values. |
disabled | boolean Default: false | Disables the button, disallowing the clicking and keyboard navigation. |
use | Array Default: [] | Any svelte action to be applied to the underlying element. View use api for more info. |
self | HTMLButtonElement Default: —— | The underlying html element that you can use to bind to. |
Child prop | Type | Description |
---|---|---|
active | boolean | Whether or not the tab is currently active. |
Data attribute | Value | Description |
---|---|---|
data-tabsbutton | '' | The base data attribute, can be used for styling. |
data-state | 'active' | 'inactive' | |
data-value | —— | The value of the button, passed through the prop. |
TabsContent
This component is a child of Tabs
Prop | Type | Description |
---|---|---|
value * | string Default: —— | The unique value of the content. This must match one of the button values. |
use | Array Default: [] | Any svelte action to be applied to the underlying element. View use api for more info. |
self | HTMLDivElement Default: —— | The underlying html element that you can use to bind to. |
Data attribute | Value | Description |
---|---|---|
data-tabscontent | '' | The base data attribute, can be used for styling. |
data-state | 'active' | 'inactive' | |
data-hidden | 'true' | 'false' | |
data-value | —— | The value of the button, passed through the prop. |
data-orientation | 'horizontal' | 'vertical' | The direction of the tabs. |
Basic Example
<script>
import { Tabs, TabsList, TabsButton, TabsContent } from 'lithesome';
</script>
<Tabs>
<TabsList>
<TabsButton value="1">Tab 1</TabsButton>
<TabsButton value="2">Tab 2</TabsButton>
</TabsList>
<TabsContent value="1">Tab content 1</TabsContent>
<TabsContent value="2">Tab content 2</TabsContent>
</Tabs>