UNPKG

ui-ingredients

Version:

Headless component library for Svelte powered by zag

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