ui-ingredients
Version:
Headless component library for Svelte powered by zag
21 lines (20 loc) • 890 B
JavaScript
import * as dialog from '@zag-js/dialog';
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';
import { getLocaleContext } from '../locale-provider/local-provider-context.svelte.js';
export function createDialog(props) {
const locale = getLocaleContext();
const environment = getEnvironmentContext();
const id = createUniqueId();
const context = reflect(() => ({
id,
dir: locale?.dir,
role: 'dialog',
getRootNode: environment?.getRootNode,
'open.controlled': props.openControlled,
...props,
}));
const [state, send] = useMachine(dialog.machine(context), { context });
return reflect(() => dialog.connect(state, send, normalizeProps));
}