import { mergeProps } from 'zag-ripple';
import { trackSplit, track } from 'ripple';
import { CollapsibleApiContext } from './use-collapsible-context';
import { useCollapsible, type UseCollapsibleProps } from './use-collapsible.ripple';
import { splitCollapsibleProps } from './split-collapsible-props.ripple';
import { ark } from '../factory';
import type { HTMLProps, MaybeTracked, PolymorphicProps } from '../../types';

export interface CollapsibleRootBaseProps extends PolymorphicProps<'div'>, UseCollapsibleProps {}
export interface CollapsibleRootProps extends HTMLProps<'div'>, CollapsibleRootBaseProps {}

export component CollapsibleRoot(props: MaybeTracked<CollapsibleRootProps>) {
  const [children, rest] = trackSplit(props, ['children']);
  const [collapsibleProps, localProps] = splitCollapsibleProps(@rest);
  const collapsible = useCollapsible(collapsibleProps);

  CollapsibleApiContext.set(collapsible);

  let mergedProps = track(() => mergeProps(@collapsible.getRootProps(), @localProps));

  <ark.div {...@mergedProps}>
    <@children />
  </ark.div>
}
