mirror of
https://gitee.com/ant-design/ant-design.git
synced 2024-12-15 09:21:22 +08:00
47 lines
1022 B
TypeScript
47 lines
1022 B
TypeScript
|
import type { CSSMotionProps } from 'rc-motion';
|
||
|
import type { AnimatedConfig } from 'rc-tabs/lib/interface';
|
||
|
import type { TabsProps } from '..';
|
||
|
import { getTransitionName } from '../../_util/motion';
|
||
|
|
||
|
const motion: CSSMotionProps = {
|
||
|
motionAppear: false,
|
||
|
motionEnter: true,
|
||
|
motionLeave: true,
|
||
|
};
|
||
|
|
||
|
export default function useAnimateConfig(
|
||
|
prefixCls: string,
|
||
|
animated: TabsProps['animated'] = {
|
||
|
inkBar: true,
|
||
|
tabPane: false,
|
||
|
},
|
||
|
): AnimatedConfig {
|
||
|
let mergedAnimated: AnimatedConfig;
|
||
|
|
||
|
if (animated === false) {
|
||
|
mergedAnimated = {
|
||
|
inkBar: false,
|
||
|
tabPane: false,
|
||
|
};
|
||
|
} else if (animated === true) {
|
||
|
mergedAnimated = {
|
||
|
inkBar: true,
|
||
|
tabPane: false,
|
||
|
};
|
||
|
} else {
|
||
|
mergedAnimated = {
|
||
|
inkBar: true,
|
||
|
...(typeof animated === 'object' ? animated : {}),
|
||
|
};
|
||
|
}
|
||
|
|
||
|
if (mergedAnimated.tabPane) {
|
||
|
mergedAnimated.tabPaneMotion = {
|
||
|
...motion,
|
||
|
motionName: getTransitionName(prefixCls, 'switch'),
|
||
|
};
|
||
|
}
|
||
|
|
||
|
return mergedAnimated;
|
||
|
}
|