import { mergeProps } from 'zag-ripple';
import { trackSplit, track } from 'ripple';
import { SwapApiContext } from './use-swap-context';
import { useSwap, type UseSwapProps } from './use-swap.ripple';
import { ark } from '../factory';
import type { HTMLProps, MaybeTracked, PolymorphicProps } from '../../types';

export interface SwapRootBaseProps extends PolymorphicProps<'span'>, UseSwapProps {}
export interface SwapRootProps extends HTMLProps<'span'>, SwapRootBaseProps {}

export component SwapRoot(props: MaybeTracked<SwapRootProps>) {
  const [swap, lazyMount, unmountOnExit, children, localProps] = trackSplit(props, [
    'swap',
    'lazyMount',
    'unmountOnExit',
    'children',
  ]);

  const swapApi = useSwap({ swap, lazyMount, unmountOnExit });
  SwapApiContext.set(swapApi);

  let mergedProps = track(() => mergeProps(@swapApi.getRootProps(), @localProps));
  <ark.span {...@mergedProps}>
    <@children />
  </ark.span>
}
