ant-design/components/tabs/style/motion.tsx

41 lines
883 B
TypeScript
Raw Normal View History

2022-08-08 19:08:43 +08:00
import type { TabsToken } from '.';
import type { GenerateStyle } from '../../theme/internal';
2022-08-08 19:08:43 +08:00
const genMotionStyle: GenerateStyle<TabsToken> = (token) => {
2022-08-08 19:08:43 +08:00
const { componentCls, motionDurationSlow } = token;
return {
[componentCls]: {
[`${componentCls}-switch`]: {
'&-appear, &-enter': {
transition: 'none',
'&-start': {
opacity: 0,
},
'&-active': {
opacity: 1,
transition: `opacity ${motionDurationSlow}`,
},
},
'&-leave': {
position: 'absolute',
transition: 'none',
inset: 0,
'&-start': {
opacity: 1,
},
'&-active': {
opacity: 0,
transition: `opacity ${motionDurationSlow}`,
},
},
},
},
};
};
export default genMotionStyle;