mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-27 14:44:12 +00:00
* feat: remixicon * chore: update deps * chore: update icon * chore: fix issues * chore: build registry * chore: changeset * deps --------- Co-authored-by: shadcn <m@shadcn.com>
339 lines
9.7 KiB
TypeScript
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>
|
|
)
|
|
}
|