2022-08-08 19:08:43 +08:00
|
|
|
import type { TabsToken } from '.';
|
2022-11-23 20:22:38 +08:00
|
|
|
import type { GenerateStyle } from '../../theme/internal';
|
2022-08-08 19:08:43 +08:00
|
|
|
|
2022-11-19 13:47:33 +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;
|