UNPKG

ui-ingredients

Version:

Headless component library for Svelte powered by zag

16 lines (15 loc) 664 B
import * as dialog from '@zag-js/dialog'; import { normalizeProps, useMachine } from '@zag-js/svelte'; import { getEnvironmentContext } from '../EnvironmentProvider/EnvironmentProviderContext.svelte.js'; import { getLocaleContext } from '../LocaleProvider/LocaleProviderContext.svelte.js'; export function createDialog(props) { const locale = getLocaleContext(); const environment = getEnvironmentContext(); const service = useMachine(dialog.machine, () => ({ dir: locale?.().dir, role: 'dialog', getRootNode: environment?.().getRootNode, ...props(), })); return () => dialog.connect(service, normalizeProps); }