import type { MarkerProps } from '@zag-js/angle-slider';
import { mergeProps } from 'zag-ripple';
import { trackSplit, track } from 'ripple';
import { createSplitProps } from '../../utils/create-split-props.ripple';
import { useAngleSliderContext } from './use-angle-slider-context';
import { ark } from '../factory';
import type { HTMLProps, MaybeTracked, PolymorphicProps } from '../../types';

export interface AngleSliderMarkerBaseProps extends PolymorphicProps<'div'>, MarkerProps {}
export interface AngleSliderMarkerProps extends HTMLProps<'div'>, AngleSliderMarkerBaseProps {}

export component AngleSliderMarker(props: MaybeTracked<AngleSliderMarkerProps>) {
  const [value, localProps] = trackSplit(props, ['value']);
  const angleSlider = useAngleSliderContext();

  let mergedProps = track(
    () => mergeProps(@angleSlider.getMarkerProps({ value: @value }), @localProps),
  );

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