Clipboard
A component to copy text to the clipboard
Anatomy
To set up the Clipboard correctly, you'll need to understand its anatomy and how we name its parts.
Each part includes a
data-partattribute to help identify them in the DOM.
Examples
Learn how to use the Clipboard component in your project. Let's take a look at the most basic example:
import { Clipboard } from '@ark-ui/react/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-react'
export const Basic = () => {
return (
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator copied={<CheckIcon />}>
<ClipboardCopyIcon />
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
)
}
import { Clipboard } from '@ark-ui/solid/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-solid'
export const Basic = () => {
return (
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator copied={<CheckIcon />}>
<ClipboardCopyIcon />
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
)
}
<script setup lang="ts">
import { Clipboard } from '@ark-ui/vue/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-vue-next'
</script>
<template>
<Clipboard.Root default-value="https://ark-ui.com">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
<template #copied>
<CheckIcon />
</template>
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
</template>
<script lang="ts">
import { Clipboard } from '@ark-ui/svelte/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-svelte'
</script>
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
{#snippet copied()}
<CheckIcon />
{/snippet}
<ClipboardCopyIcon />
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
Using Context
Access the clipboard state and methods using Clipboard.Context. This provides access to properties like copied,
value, and setValue
Alternatively, you can use the
useClipboardContexthook to access the clipboard context.
import { Clipboard } from '@ark-ui/react/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-react'
export const Context = () => {
return (
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Trigger>
<Clipboard.Context>
{(clipboard) => (
<div>
{clipboard.copied ? <CheckIcon /> : <ClipboardCopyIcon />}
<span>{clipboard.copied ? 'Copied!' : 'Copy'}</span>
<small>Value: {clipboard.value}</small>
</div>
)}
</Clipboard.Context>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
)
}
import { Clipboard } from '@ark-ui/solid/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-solid'
import { Show } from 'solid-js'
export const Context = () => {
return (
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Trigger>
<Clipboard.Context>
{(clipboard) => (
<div>
<Show when={clipboard().copied} fallback={<ClipboardCopyIcon />}>
<CheckIcon />
</Show>
<span>
<Show when={clipboard().copied} fallback="Copy">
Copied!
</Show>
</span>
<small>Value: {clipboard().value}</small>
</div>
)}
</Clipboard.Context>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
)
}
<script setup lang="ts">
import { Clipboard } from '@ark-ui/vue/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-vue-next'
</script>
<template>
<Clipboard.Root default-value="https://ark-ui.com">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Trigger>
<Clipboard.Context v-slot="clipboard">
<div>
<CheckIcon v-if="clipboard.copied" />
<ClipboardCopyIcon v-else />
<span>
{{ clipboard.copied ? 'Copied!' : 'Copy' }}
</span>
<small>Value: {{ clipboard.value }}</small>
</div>
</Clipboard.Context>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
</template>
<script lang="ts">
import { CheckIcon, ClipboardCopyIcon } from 'lucide-svelte'
import { Clipboard } from '@ark-ui/svelte/clipboard'
</script>
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Trigger>
<Clipboard.Context>
{#snippet render(clipboard)}
<div>
{#if clipboard().copied}
<CheckIcon />
{:else}
<ClipboardCopyIcon />
{/if}
<span>
{#if clipboard().copied}
Copied!
{:else}
Copy
{/if}
</span>
<small>Value: {clipboard().value}</small>
</div>
{/snippet}
</Clipboard.Context>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>Copy Status
Use the onStatusChange prop to listen for copy operations. It exposes a copied property that you can use to display
a success message.
import { Clipboard } from '@ark-ui/react/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-react'
import { useState } from 'react'
export const CopyStatus = () => {
const [copyCount, setCopyCount] = useState(0)
return (
<Clipboard.Root
value="https://ark-ui.com"
onStatusChange={(details) => {
if (details.copied) {
setCopyCount((prev) => prev + 1)
}
}}
>
<Clipboard.Trigger>
<Clipboard.Indicator copied={<CheckIcon />}>
<ClipboardCopyIcon />
</Clipboard.Indicator>
Copy
</Clipboard.Trigger>
<p>Copied {copyCount} times</p>
</Clipboard.Root>
)
}
import { Clipboard } from '@ark-ui/solid/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-solid'
import { Show, createSignal } from 'solid-js'
export const CopyStatus = () => {
const [copyCount, setCopyCount] = createSignal(0)
return (
<Clipboard.Root
value="https://ark-ui.com"
onStatusChange={(details) => {
if (details.copied) {
setCopyCount((prev) => prev + 1)
}
}}
>
<Clipboard.Trigger>
<Clipboard.Indicator>
<Show when={false} fallback={<ClipboardCopyIcon />}>
<CheckIcon />
</Show>
</Clipboard.Indicator>
Copy
</Clipboard.Trigger>
<p>Copied {copyCount()} times</p>
</Clipboard.Root>
)
}
<script setup lang="ts">
import { Clipboard } from '@ark-ui/vue/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-vue-next'
import { ref } from 'vue'
const copyCount = ref(0)
</script>
<template>
<Clipboard.Root
default-value="https://ark-ui.com"
@status-change="
(details) => {
if (details.copied) {
copyCount += 1
}
}
"
>
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
<template #copied>
<CheckIcon />
</template>
</Clipboard.Indicator>
Copy
</Clipboard.Trigger>
<p>Copied {{ copyCount }} times</p>
</Clipboard.Root>
</template>
<script lang="ts">
import { CheckIcon, ClipboardCopyIcon } from 'lucide-svelte'
import { Clipboard } from '@ark-ui/svelte/clipboard'
let copyCount = $state(0)
</script>
<Clipboard.Root
value="https://ark-ui.com"
onStatusChange={(details) => {
if (details.copied) {
copyCount += 1
}
}}
>
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
{#snippet copied()}
<CheckIcon />
{/snippet}
</Clipboard.Indicator>
Copy
</Clipboard.Trigger>
<p>Copied {copyCount} times</p>
</Clipboard.Root>Controlled
Control the clipboard value externally by managing the state yourself and using onValueChange to handle updates.
import { Clipboard } from '@ark-ui/react/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-react'
import { useState } from 'react'
export const Controlled = () => {
const [url, setUrl] = useState('https://ark-ui.com')
const handleUrlChange = () => {
setUrl('https://chakra-ui.com')
}
return (
<Clipboard.Root value={url} onValueChange={({ value }) => setUrl(value)}>
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator copied={<CheckIcon />}>
<ClipboardCopyIcon />
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
<button onClick={handleUrlChange}>Change Url</button>
</Clipboard.Root>
)
}
import { Clipboard } from '@ark-ui/solid/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-solid'
import { Show, createSignal } from 'solid-js'
export const Controlled = () => {
const [url, setUrl] = createSignal('https://ark-ui.com')
const handleUrlChange = () => {
setUrl('https://chakra-ui.com')
}
return (
<Clipboard.Root value={url()} onValueChange={({ value }) => setUrl(value)}>
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
<Show when={false} fallback={<ClipboardCopyIcon />}>
<CheckIcon />
</Show>
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
<button onClick={handleUrlChange}>Change Url</button>
</Clipboard.Root>
)
}
<script setup lang="ts">
import { Clipboard } from '@ark-ui/vue/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-vue-next'
import { ref } from 'vue'
const url = ref('https://ark-ui.com')
const setUrl = () => {
url.value = 'https://chakra-ui.com'
}
</script>
<template>
<Clipboard.Root v-model="url">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
<template #copied>
<CheckIcon />
</template>
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
<button @click="setUrl">Change Url</button>
</Clipboard.Root>
</template>
<script lang="ts">
import { CheckIcon, ClipboardCopyIcon } from 'lucide-svelte'
import { Clipboard } from '@ark-ui/svelte/clipboard'
let url = $state('https://ark-ui.com')
const handleUrlChange = () => {
url = 'https://chakra-ui.com'
}
</script>
<Clipboard.Root bind:value={url}>
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
{#snippet copied()}
<CheckIcon />
{/snippet}
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
<button onclick={handleUrlChange}>Change Url</button>
</Clipboard.Root>Root Provider
Use the useClipboard hook to create the clipboard store and pass it to the Clipboard.RootProvider component. This
allows you to have maximum control over the clipboard programmatically.
If you're using the
Clipboard.RootProvidercomponent, you don't need to use theClipboard.Rootcomponent.
import { Clipboard, useClipboard } from '@ark-ui/react/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-react'
export const RootProvider = () => {
const clipboard = useClipboard({ value: 'https://ark-ui.com' })
return (
<>
<button onClick={() => clipboard.copy()}>Copy</button>
<Clipboard.RootProvider value={clipboard}>
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator copied={<CheckIcon />}>
<ClipboardCopyIcon />
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.RootProvider>
</>
)
}
import { Clipboard, useClipboard } from '@ark-ui/solid/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-solid'
export const RootProvider = () => {
const clipboard = useClipboard({ value: 'https://ark-ui.com' })
return (
<>
<button onClick={() => clipboard().copy()}>Copy</button>
<Clipboard.RootProvider value={clipboard}>
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator copied={<CheckIcon />}>
<ClipboardCopyIcon />
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.RootProvider>
</>
)
}
<script setup lang="ts">
import { Clipboard, useClipboard } from '@ark-ui/vue/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-vue-next'
const clipboard = useClipboard({ value: 'https.//ark-ui.com' })
</script>
<template>
<button @click="clipboard.copy()">Copy</button>
<Clipboard.RootProvider :value="clipboard">
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
<template #copied>
<CheckIcon />
</template>
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.RootProvider>
</template>
<script lang="ts">
import { Clipboard, useClipboard } from '@ark-ui/svelte/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-svelte'
const clipboard = useClipboard(() => ({ value: 'https://ark-ui.com' }))
</script>
<Clipboard.RootProvider value={clipboard}>
<Clipboard.Label>Copy this link</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
{#snippet copied()}
<CheckIcon />
{/snippet}
<ClipboardCopyIcon />
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.RootProvider>
Custom Timeout
Configure the copy status timeout duration using the timeout prop. Default is 3000ms (3 seconds).
import { Clipboard } from '@ark-ui/react/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-react'
export const CustomTimeout = () => {
return (
<Clipboard.Root value="https://ark-ui.com" timeout={5000}>
<Clipboard.Label>Copy this link (5 second timeout)</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator copied={<CheckIcon />}>
<ClipboardCopyIcon />
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
)
}
import { Clipboard } from '@ark-ui/solid/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-solid'
import { Show } from 'solid-js'
export const CustomTimeout = () => {
return (
<Clipboard.Root value="https://ark-ui.com" timeout={5000}>
<Clipboard.Label>Copy this link (5 second timeout)</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
<Show when={false} fallback={<ClipboardCopyIcon />}>
<CheckIcon />
</Show>
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
)
}
<script setup lang="ts">
import { Clipboard } from '@ark-ui/vue/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-vue-next'
</script>
<template>
<Clipboard.Root default-value="https://ark-ui.com" :timeout="5000">
<Clipboard.Label>Copy this link (5 second timeout)</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
<template #copied>
<CheckIcon />
</template>
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>
</template>
<script lang="ts">
import { CheckIcon, ClipboardCopyIcon } from 'lucide-svelte'
import { Clipboard } from '@ark-ui/svelte/clipboard'
</script>
<Clipboard.Root value="https://ark-ui.com" timeout={5000}>
<Clipboard.Label>Copy this link (5 second timeout)</Clipboard.Label>
<Clipboard.Control>
<Clipboard.Input />
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
{#snippet copied()}
<CheckIcon />
{/snippet}
</Clipboard.Indicator>
</Clipboard.Trigger>
</Clipboard.Control>
</Clipboard.Root>Programmatic Copy
Trigger copy operations programmatically using the context's copy() method.
import { Clipboard } from '@ark-ui/react/clipboard'
export const Programmatic = () => {
return (
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.Context>
{(clipboard) => <button onClick={() => clipboard.copy()}>{clipboard.copied ? 'Copied!' : 'Copy URL'}</button>}
</Clipboard.Context>
</Clipboard.Root>
)
}
import { Clipboard } from '@ark-ui/solid/clipboard'
export const Programmatic = () => {
return (
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.Context>
{(clipboard) => (
<button onClick={() => clipboard().copy()}>{clipboard().copied ? 'Copied!' : 'Copy URL'}</button>
)}
</Clipboard.Context>
</Clipboard.Root>
)
}
<script setup lang="ts">
import { Clipboard } from '@ark-ui/vue/clipboard'
</script>
<template>
<Clipboard.Root default-value="https://ark-ui.com">
<Clipboard.Context v-slot="clipboard">
<button @click="clipboard.copy()">
{{ clipboard.copied ? 'Copied!' : 'Copy URL' }}
</button>
</Clipboard.Context>
</Clipboard.Root>
</template>
<script lang="ts">
import { Clipboard } from '@ark-ui/svelte/clipboard'
</script>
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.Context>
{#snippet render(clipboard)}
<button onclick={() => clipboard().copy()}>
{clipboard().copied ? 'Copied!' : 'Copy URL'}
</button>
{/snippet}
</Clipboard.Context>
</Clipboard.Root>Value Text
Use Clipboard.ValueText to display the current clipboard value.
import { Clipboard } from '@ark-ui/react/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-react'
export const ValueText = () => {
return (
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.ValueText />
<Clipboard.Trigger>
<Clipboard.Indicator copied={<CheckIcon />}>
<ClipboardCopyIcon />
</Clipboard.Indicator>
Copy
</Clipboard.Trigger>
</Clipboard.Root>
)
}
import { Clipboard } from '@ark-ui/solid/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-solid'
import { Show } from 'solid-js'
export const ValueText = () => {
return (
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.ValueText />
<Clipboard.Trigger>
<Clipboard.Indicator>
<Show when={false} fallback={<ClipboardCopyIcon />}>
<CheckIcon />
</Show>
</Clipboard.Indicator>
Copy
</Clipboard.Trigger>
</Clipboard.Root>
)
}
<script setup lang="ts">
import { Clipboard } from '@ark-ui/vue/clipboard'
import { CheckIcon, ClipboardCopyIcon } from 'lucide-vue-next'
</script>
<template>
<Clipboard.Root default-value="https://ark-ui.com">
<Clipboard.ValueText />
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
<template #copied>
<CheckIcon />
</template>
</Clipboard.Indicator>
Copy
</Clipboard.Trigger>
</Clipboard.Root>
</template>
<script lang="ts">
import { CheckIcon, ClipboardCopyIcon } from 'lucide-svelte'
import { Clipboard } from '@ark-ui/svelte/clipboard'
</script>
<Clipboard.Root value="https://ark-ui.com">
<Clipboard.ValueText />
<Clipboard.Trigger>
<Clipboard.Indicator>
<ClipboardCopyIcon />
{#snippet copied()}
<CheckIcon />
{/snippet}
</Clipboard.Indicator>
Copy
</Clipboard.Trigger>
</Clipboard.Root>API Reference
Root
| Prop | Default | Type |
|---|---|---|
asChild | booleanUse the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. | |
defaultValue | stringThe initial value to be copied to the clipboard when rendered. Use when you don't need to control the value of the clipboard. | |
id | stringThe unique identifier of the machine. | |
ids | Partial<{ root: string; input: string; label: string }>The ids of the elements in the clipboard. Useful for composition. | |
onStatusChange | (details: CopyStatusDetails) => voidThe function to be called when the value is copied to the clipboard | |
onValueChange | (details: ValueChangeDetails) => voidThe function to be called when the value changes | |
timeout | 3000 | numberThe timeout for the copy operation |
value | stringThe controlled value of the clipboard |
| Data Attribute | Value |
|---|---|
[data-scope] | clipboard |
[data-part] | root |
[data-copied] | Present when copied state is true |
Control
| Prop | Default | Type |
|---|---|---|
asChild | booleanUse the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. |
| Data Attribute | Value |
|---|---|
[data-scope] | clipboard |
[data-part] | control |
[data-copied] | Present when copied state is true |
Indicator
| Prop | Default | Type |
|---|---|---|
asChild | booleanUse the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. | |
copied | string | number | bigint | boolean | ReactElement<unknown, string | JSXElementConstructor<any>> | Iterable<ReactNode> | ReactPortal | Promise<...> |
Input
| Prop | Default | Type |
|---|---|---|
asChild | booleanUse the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. |
| Data Attribute | Value |
|---|---|
[data-scope] | clipboard |
[data-part] | input |
[data-copied] | Present when copied state is true |
[data-readonly] | Present when read-only |
Label
| Prop | Default | Type |
|---|---|---|
asChild | booleanUse the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. |
| Data Attribute | Value |
|---|---|
[data-scope] | clipboard |
[data-part] | label |
[data-copied] | Present when copied state is true |
RootProvider
| Prop | Default | Type |
|---|---|---|
value | UseClipboardReturn | |
asChild | booleanUse the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. |
Trigger
| Prop | Default | Type |
|---|---|---|
asChild | booleanUse the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. |
| Data Attribute | Value |
|---|---|
[data-scope] | clipboard |
[data-part] | trigger |
[data-copied] | Present when copied state is true |
ValueText
| Prop | Default | Type |
|---|---|---|
asChild | booleanUse the provided child element as the default rendered element, combining their props and behavior. For more details, read our Composition guide. |