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