Files
shadcn-ui/apps/v4/registry/bases/base/examples/toggle-example.tsx
Neeraj Dalal 66d2400784 feat(icons): the icons we all love and adore - remixicon (#9156)
* feat: remixicon

* chore: update deps

* chore: update icon

* chore: fix issues

* chore: build registry

* chore: changeset

* deps

---------

Co-authored-by: shadcn <m@shadcn.com>
2026-01-16 18:00:06 +04:00

339 lines
9.7 KiB
TypeScript

import {
Example,
ExampleWrapper,
} from "@/registry/bases/base/components/example"
import { Button } from "@/registry/bases/base/ui/button"
import { Toggle } from "@/registry/bases/base/ui/toggle"
import { IconPlaceholder } from "@/app/(create)/components/icon-placeholder"
export default function ToggleExample() {
return (
<ExampleWrapper>
<ToggleBasic />
<ToggleOutline />
<ToggleSizes />
<ToggleWithButtonText />
<ToggleWithButtonIcon />
<ToggleWithButtonIconText />
<ToggleDisabled />
<ToggleWithIcon />
</ExampleWrapper>
)
}
function ToggleBasic() {
return (
<Example title="Basic">
<div className="flex flex-wrap items-center gap-2">
<Toggle aria-label="Toggle bold" defaultPressed>
<IconPlaceholder
lucide="BoldIcon"
tabler="IconBold"
hugeicons="TextBoldIcon"
phosphor="TextBIcon"
remixicon="RiBold"
/>
</Toggle>
<Toggle aria-label="Toggle italic">
<IconPlaceholder
lucide="ItalicIcon"
tabler="IconItalic"
hugeicons="TextItalicIcon"
phosphor="TextItalicIcon"
remixicon="RiItalic"
/>
</Toggle>
<Toggle aria-label="Toggle underline">
<IconPlaceholder
lucide="UnderlineIcon"
tabler="IconUnderline"
hugeicons="TextUnderlineIcon"
phosphor="TextUnderlineIcon"
remixicon="RiUnderline"
/>
</Toggle>
</div>
</Example>
)
}
function ToggleOutline() {
return (
<Example title="Outline">
<div className="flex flex-wrap items-center gap-2">
<Toggle variant="outline" aria-label="Toggle italic">
<IconPlaceholder
lucide="ItalicIcon"
tabler="IconItalic"
hugeicons="TextItalicIcon"
phosphor="TextItalicIcon"
remixicon="RiItalic"
/>
Italic
</Toggle>
<Toggle variant="outline" aria-label="Toggle bold">
<IconPlaceholder
lucide="BoldIcon"
tabler="IconBold"
hugeicons="TextBoldIcon"
phosphor="TextBIcon"
remixicon="RiBold"
/>
Bold
</Toggle>
</div>
</Example>
)
}
function ToggleSizes() {
return (
<Example title="Sizes">
<div className="flex flex-wrap items-center gap-2">
<Toggle variant="outline" aria-label="Toggle small" size="sm">
Small
</Toggle>
<Toggle variant="outline" aria-label="Toggle default" size="default">
Default
</Toggle>
<Toggle variant="outline" aria-label="Toggle large" size="lg">
Large
</Toggle>
</div>
</Example>
)
}
function ToggleWithButtonText() {
return (
<Example title="With Button Text">
<div className="flex flex-col gap-4">
<div className="flex items-center gap-2">
<Button size="sm" variant="outline">
Button
</Button>
<Toggle variant="outline" aria-label="Toggle sm" size="sm">
Toggle
</Toggle>
</div>
<div className="flex items-center gap-2">
<Button size="default" variant="outline">
Button
</Button>
<Toggle variant="outline" aria-label="Toggle default" size="default">
Toggle
</Toggle>
</div>
<div className="flex items-center gap-2">
<Button size="lg" variant="outline">
Button
</Button>
<Toggle variant="outline" aria-label="Toggle lg" size="lg">
Toggle
</Toggle>
</div>
</div>
</Example>
)
}
function ToggleWithButtonIcon() {
return (
<Example title="With Button Icon">
<div className="flex flex-col gap-4">
<div className="flex items-center gap-2">
<Button variant="outline" size="icon-sm">
<IconPlaceholder
lucide="BoldIcon"
tabler="IconBold"
hugeicons="TextBoldIcon"
phosphor="TextBIcon"
remixicon="RiBold"
/>
</Button>
<Toggle variant="outline" aria-label="Toggle sm icon" size="sm">
<IconPlaceholder
lucide="BoldIcon"
tabler="IconBold"
hugeicons="TextBoldIcon"
phosphor="TextBIcon"
remixicon="RiBold"
/>
</Toggle>
</div>
<div className="flex items-center gap-2">
<Button variant="outline" size="icon">
<IconPlaceholder
lucide="ItalicIcon"
tabler="IconItalic"
hugeicons="TextItalicIcon"
phosphor="TextItalicIcon"
remixicon="RiItalic"
/>
</Button>
<Toggle
variant="outline"
aria-label="Toggle default icon"
size="default"
>
<IconPlaceholder
lucide="ItalicIcon"
tabler="IconItalic"
hugeicons="TextItalicIcon"
phosphor="TextItalicIcon"
remixicon="RiItalic"
/>
</Toggle>
</div>
<div className="flex items-center gap-2">
<Button variant="outline" size="icon-lg">
<IconPlaceholder
lucide="UnderlineIcon"
tabler="IconUnderline"
hugeicons="TextUnderlineIcon"
phosphor="TextUnderlineIcon"
remixicon="RiUnderline"
/>
</Button>
<Toggle variant="outline" aria-label="Toggle lg icon" size="lg">
<IconPlaceholder
lucide="UnderlineIcon"
tabler="IconUnderline"
hugeicons="TextUnderlineIcon"
phosphor="TextUnderlineIcon"
remixicon="RiUnderline"
/>
</Toggle>
</div>
</div>
</Example>
)
}
function ToggleWithButtonIconText() {
return (
<Example title="With Button Icon + Text">
<div className="flex flex-col gap-4">
<div className="flex items-center gap-2">
<Button size="sm" variant="outline">
<IconPlaceholder
lucide="BoldIcon"
tabler="IconBold"
hugeicons="TextBoldIcon"
phosphor="TextBIcon"
remixicon="RiBold"
data-icon="inline-start"
/>
Button
</Button>
<Toggle variant="outline" aria-label="Toggle sm icon text" size="sm">
<IconPlaceholder
lucide="BoldIcon"
tabler="IconBold"
hugeicons="TextBoldIcon"
phosphor="TextBIcon"
remixicon="RiBold"
/>
Toggle
</Toggle>
</div>
<div className="flex items-center gap-2">
<Button size="default" variant="outline">
<IconPlaceholder
lucide="ItalicIcon"
tabler="IconItalic"
hugeicons="TextItalicIcon"
phosphor="TextItalicIcon"
remixicon="RiItalic"
data-icon="inline-start"
/>
Button
</Button>
<Toggle
variant="outline"
aria-label="Toggle default icon text"
size="default"
>
<IconPlaceholder
lucide="ItalicIcon"
tabler="IconItalic"
hugeicons="TextItalicIcon"
phosphor="TextItalicIcon"
remixicon="RiItalic"
/>
Toggle
</Toggle>
</div>
<div className="flex items-center gap-2">
<Button size="lg" variant="outline">
<IconPlaceholder
lucide="UnderlineIcon"
tabler="IconUnderline"
hugeicons="TextUnderlineIcon"
phosphor="TextUnderlineIcon"
remixicon="RiUnderline"
data-icon="inline-start"
/>
Button
</Button>
<Toggle variant="outline" aria-label="Toggle lg icon text" size="lg">
<IconPlaceholder
lucide="UnderlineIcon"
tabler="IconUnderline"
hugeicons="TextUnderlineIcon"
phosphor="TextUnderlineIcon"
remixicon="RiUnderline"
/>
Toggle
</Toggle>
</div>
</div>
</Example>
)
}
function ToggleDisabled() {
return (
<Example title="Disabled">
<div className="flex flex-wrap items-center gap-2">
<Toggle aria-label="Toggle disabled" disabled>
Disabled
</Toggle>
<Toggle variant="outline" aria-label="Toggle disabled outline" disabled>
Disabled
</Toggle>
</div>
</Example>
)
}
function ToggleWithIcon() {
return (
<Example title="With Icon">
<div className="flex flex-wrap items-center gap-2">
<Toggle aria-label="Toggle bookmark" defaultPressed>
<IconPlaceholder
lucide="BookmarkIcon"
tabler="IconBookmark"
hugeicons="BookmarkIcon"
phosphor="BookmarkIcon"
remixicon="RiBookmarkLine"
className="group-data-[state=on]/toggle:fill-accent-foreground"
/>
</Toggle>
<Toggle variant="outline" aria-label="Toggle bookmark outline">
<IconPlaceholder
lucide="BookmarkIcon"
tabler="IconBookmark"
hugeicons="BookmarkIcon"
phosphor="BookmarkIcon"
remixicon="RiBookmarkLine"
className="group-data-[state=on]/toggle:fill-accent-foreground"
/>
Bookmark
</Toggle>
</div>
</Example>
)
}