Switcher
A fully interactive, accessible, user interface component allowing users to select a single value among a linear set of options.
import { Switcher, SwitcherItem } from "@/registry/ui/switcher"
export default function SwitcherDemo() {  return (    <Switcher defaultValue="24h">      <SwitcherItem value="12h">12-hour</SwitcherItem>      <SwitcherItem value="24h">24-hour</SwitcherItem>    </Switcher>  )}Installation# 
npx shadcn@latest add https://jakeisonline.com/registry/switcher.jsonUsage# 
import { Switcher, SwitcherItem } from "@/registry/ui/switcher"<Switcher defaultValue="Option 1">  <SwitcherItem value="Option 1">Option 1</SwitcherItem>  <SwitcherItem value="Option 2">Option 2</SwitcherItem></Switcher>Accessibility# 
Adheres to the Radio Group WAI-ARIA design pattern. The Switcher component uses the role="radio" attribute to indicate that the component is a linear set of buttons represented as a single element. The aria-checked attribute is used to indicate whether the component is selected.
Keyboard Navigation# 
| Key | Action | 
|---|---|
| ArrowRight | Move focus to the next SwitcherItemin the group, uncheck the previously focusedSwitcherItem, and check the newly focusedSwitcherItem. If focus is on the lastSwitcherItem, focus moves to the firstSwitcherItem. | 
| ArrowLeft | Move focus to the previous SwitcherItemin the group, uncheck the previously focusedSwitcherItem, and check the newly focusedSwitcherItem. If focus is on the firstSwitcherItem, focus moves to the lastSwitcherItem. | 
Component Reference# 
Switcher# 
Used to wrap a single <Switcher> component. Also provides the context for the SwitcherItem components.
| Prop | Type | Description | 
|---|---|---|
| defaultValue | string | The value of the default selected SwitcherItem. Required. | 
SwitcherItem# 
Used to wrap a single <button> component.
| Prop | Type | Description | 
|---|---|---|
| value | string | The value of the SwitcherItem. Required. | 
Examples# 
Add icons# 
Icons add a quick way to visually identify the SwitcherItem, in addition to a little visual flair to the component.
import { Switcher, SwitcherItem } from "@/registry/ui/switcher"import { Grid2x2Icon, ListIcon, Table2Icon } from "lucide-react"
export default function SwitcherDemo() {  return (    <Switcher defaultValue="list">      <SwitcherItem value="table" className="flex items-center gap-1">        <Table2Icon className="h-4 w-4" />        Table      </SwitcherItem>      <SwitcherItem value="list" className="flex items-center gap-1">        <ListIcon className="h-4 w-4" />        List      </SwitcherItem>      <SwitcherItem value="grid" className="flex items-center gap-1">        <Grid2x2Icon className="h-4 w-4" />        Grid      </SwitcherItem>    </Switcher>  )}