mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-15 09:21:22 +08:00
32 lines
906 B
TypeScript
32 lines
906 B
TypeScript
|
import useMergedState from 'rc-util/lib/hooks/useMergedState';
|
||
|
import { useLayoutEffect } from 'react';
|
||
|
import type { TourProps } from './interface';
|
||
|
|
||
|
interface Props {
|
||
|
defaultType?: string;
|
||
|
steps?: TourProps['steps'];
|
||
|
current?: number;
|
||
|
defaultCurrent?: number;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* returns the merged type of a step or the default type.
|
||
|
*/
|
||
|
const useMergedType = ({ defaultType, steps = [], current, defaultCurrent }: Props) => {
|
||
|
const [innerCurrent, updateInnerCurrent] = useMergedState<number | undefined>(defaultCurrent, {
|
||
|
value: current,
|
||
|
});
|
||
|
|
||
|
useLayoutEffect(() => {
|
||
|
if (current === undefined) return;
|
||
|
updateInnerCurrent(current);
|
||
|
}, [current]);
|
||
|
|
||
|
const innerType = typeof innerCurrent === 'number' ? steps[innerCurrent]?.type : defaultType;
|
||
|
const currentMergedType = innerType ?? defaultType;
|
||
|
|
||
|
return { currentMergedType, updateInnerCurrent };
|
||
|
};
|
||
|
|
||
|
export default useMergedType;
|