UNPKG

ui-ingredients

Version:

Headless component library for Svelte powered by zag

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