mirror of
https://github.com/antd-tiny-vue/antd-tiny-vue.git
synced 2025-01-25 15:39:08 +08:00
47 lines
1.1 KiB
TypeScript
47 lines
1.1 KiB
TypeScript
import type { CSSInterpolation } from '@antd-tiny-vue/cssinjs'
|
|
import { Keyframes } from '@antd-tiny-vue/cssinjs'
|
|
import type { AliasToken } from '../../theme/internal'
|
|
import type { TokenWithCommonCls } from '../../theme/util/genComponentStyleHook'
|
|
import { initMotion } from './motion'
|
|
|
|
export const fadeIn = new Keyframes('antFadeIn', {
|
|
'0%': {
|
|
opacity: 0
|
|
},
|
|
'100%': {
|
|
opacity: 1
|
|
}
|
|
})
|
|
|
|
export const fadeOut = new Keyframes('antFadeOut', {
|
|
'0%': {
|
|
opacity: 1
|
|
},
|
|
'100%': {
|
|
opacity: 0
|
|
}
|
|
})
|
|
|
|
export const initFadeMotion = (token: TokenWithCommonCls<AliasToken>, sameLevel = false): CSSInterpolation => {
|
|
const { antCls } = token
|
|
const motionCls = `${antCls}-fade`
|
|
const sameLevelPrefix = sameLevel ? '&' : ''
|
|
|
|
return [
|
|
initMotion(motionCls, fadeIn, fadeOut, token.motionDurationMid, sameLevel),
|
|
{
|
|
[`
|
|
${sameLevelPrefix}${motionCls}-enter,
|
|
${sameLevelPrefix}${motionCls}-appear
|
|
`]: {
|
|
opacity: 0,
|
|
animationTimingFunction: 'linear'
|
|
},
|
|
|
|
[`${sameLevelPrefix}${motionCls}-leave`]: {
|
|
animationTimingFunction: 'linear'
|
|
}
|
|
}
|
|
]
|
|
}
|