Components
- Accordion
- Alert
- Alert Dialog
- Aspect Ratio
- Autocomplete
- Avatar
- Badge
- Bar List
- Breadcrumb
- Button
- Button Group
- Calendar
- Card
- Carousel
- Checkbox
- Checkbox Group
- Circular Progress
- Collapsible
- Combobox
- Command
- Context Menu
- Copy Button
- Currency Input
- Data Table
- Date Picker
- Dialog
- Drawer
- Dropdown Menu
- Empty
- Field
- Hover Card
- Input
- Input Group
- Input OTP
- Item
- Kbd
- Label
- Menubar
- Meter
- Multi Combobox
- Native Select
- Navigation Menu
- Number Field
- Pagination
- Phone Input
- Popover
- Progress
- Progress List
- Prompt
- Radio Group
- Resizable
- Scroll Area
- Select
- Separator
- Sheet
- Sidebar
- Skeleton
- Slider
- Sonner
- Spinner
- Stat
- Switch
- Table
- Tabs
- Textarea
- Toggle
- Toggle Group
- Tooltip
- Typography
Loading...
import { CopyButton } from "@/components/ui/copy-button";
export function CopyButtonDemo() {
return (
<div className="flex items-center gap-2 rounded-lg border border-input bg-card px-3 py-2">
<code className="text-muted-foreground text-sm">npm install @blode/ui</code>
<CopyButton value="npm install @blode/ui" />
</div>
);
}Installation
npx shadcn@latest add "https://ui.blode.co/r/styles/default/copy-button"
Usage
import { CopyButton } from "@/components/ui/copy-button";<CopyButton value="Text to copy" />Props
| Prop | Type | Default | Description |
|---|---|---|---|
value | string | - | The text to copy to clipboard (required). |
onCopy | () => void | - | Callback fired when the text is copied. |
timeout | number | 2000 | Milliseconds before resetting the icon. |
label | string | "Copy" | Accessible label for screen readers. |
variant | ButtonVariant | "ghost" | Button variant (all Button variants work). |
size | ButtonSize | "icon" | Button size (all Button sizes work). |
All other props are forwarded to the underlying Button component.
Examples
Default
Loading...
import { CopyButton } from "@/components/ui/copy-button";
export function CopyButtonDemo() {
return (
<div className="flex items-center gap-2 rounded-lg border border-input bg-card px-3 py-2">
<code className="text-muted-foreground text-sm">npm install @blode/ui</code>
<CopyButton value="npm install @blode/ui" />
</div>
);
}