ui-ingredients
Version:
Headless component library for Svelte powered by zag
16 lines (15 loc) • 679 B
JavaScript
import * as clipboard from '@zag-js/clipboard';
import { normalizeProps, reflect, useMachine } from '@zag-js/svelte';
import { createUniqueId } from '../create-unique-id.js';
import { getEnvironmentContext } from '../environment-provider/enviroment-provider-context.svelte.js';
export function createClipboard(props) {
const environment = getEnvironmentContext();
const id = createUniqueId();
const context = reflect(() => ({
id,
getRootNode: environment?.getRootNode,
...props,
}));
const [state, send] = useMachine(clipboard.machine(context), { context });
return reflect(() => clipboard.connect(state, send, normalizeProps));
}