import type { Graph } from '@antv/g6'; import React, { ForwardRefExoticComponent, PropsWithChildren, PropsWithoutRef, RefAttributes, forwardRef, useMemo, } from 'react'; import { BaseGraph } from '../../core/base-graph'; import { COMMON_OPTIONS } from '../../core/constants'; import { mergeOptions } from '../../core/utils/options'; import { DEFAULT_OPTIONS, getOrganizationChartOptions } from './options'; import type { OrganizationChartOptions } from './types'; export const OrganizationChart: ForwardRefExoticComponent< PropsWithoutRef> & RefAttributes > = forwardRef>(({ children, ...props }, ref) => { const options = useMemo(() => { const { direction = 'vertical', labelField, ...restProps } = props; const options = mergeOptions( COMMON_OPTIONS, DEFAULT_OPTIONS, getOrganizationChartOptions({ direction, labelField }), restProps, ); return options; }, [props]); return ( {children} ); }); export type { OrganizationChartOptions };