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