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