107 lines
2.8 KiB
TypeScript
Executable File
107 lines
2.8 KiB
TypeScript
Executable File
// @types
|
|
import { VariantsType } from '../type';
|
|
//
|
|
import { varTranEnter, varTranExit } from './transition';
|
|
|
|
// ----------------------------------------------------------------------
|
|
|
|
export const varBounce = (props?: VariantsType) => {
|
|
const durationIn = props?.durationIn;
|
|
const durationOut = props?.durationOut;
|
|
const easeIn = props?.easeIn;
|
|
const easeOut = props?.easeOut;
|
|
|
|
return {
|
|
// IN
|
|
in: {
|
|
initial: {},
|
|
animate: {
|
|
scale: [0.3, 1.1, 0.9, 1.03, 0.97, 1],
|
|
opacity: [0, 1, 1, 1, 1, 1],
|
|
transition: varTranEnter({ durationIn, easeIn }),
|
|
},
|
|
exit: {
|
|
scale: [0.9, 1.1, 0.3],
|
|
opacity: [1, 1, 0],
|
|
},
|
|
},
|
|
inUp: {
|
|
initial: {},
|
|
animate: {
|
|
y: [720, -24, 12, -4, 0],
|
|
scaleY: [4, 0.9, 0.95, 0.985, 1],
|
|
opacity: [0, 1, 1, 1, 1],
|
|
transition: { ...varTranEnter({ durationIn, easeIn }) },
|
|
},
|
|
exit: {
|
|
y: [12, -24, 720],
|
|
scaleY: [0.985, 0.9, 3],
|
|
opacity: [1, 1, 0],
|
|
transition: varTranExit({ durationOut, easeOut }),
|
|
},
|
|
},
|
|
inDown: {
|
|
initial: {},
|
|
animate: {
|
|
y: [-720, 24, -12, 4, 0],
|
|
scaleY: [4, 0.9, 0.95, 0.985, 1],
|
|
opacity: [0, 1, 1, 1, 1],
|
|
transition: varTranEnter({ durationIn, easeIn }),
|
|
},
|
|
exit: {
|
|
y: [-12, 24, -720],
|
|
scaleY: [0.985, 0.9, 3],
|
|
opacity: [1, 1, 0],
|
|
transition: varTranExit({ durationOut, easeOut }),
|
|
},
|
|
},
|
|
inLeft: {
|
|
initial: {},
|
|
animate: {
|
|
x: [-720, 24, -12, 4, 0],
|
|
scaleX: [3, 1, 0.98, 0.995, 1],
|
|
opacity: [0, 1, 1, 1, 1],
|
|
transition: varTranEnter({ durationIn, easeIn }),
|
|
},
|
|
exit: {
|
|
x: [0, 24, -720],
|
|
scaleX: [1, 0.9, 2],
|
|
opacity: [1, 1, 0],
|
|
transition: varTranExit({ durationOut, easeOut }),
|
|
},
|
|
},
|
|
inRight: {
|
|
initial: {},
|
|
animate: {
|
|
x: [720, -24, 12, -4, 0],
|
|
scaleX: [3, 1, 0.98, 0.995, 1],
|
|
opacity: [0, 1, 1, 1, 1],
|
|
transition: varTranEnter({ durationIn, easeIn }),
|
|
},
|
|
exit: {
|
|
x: [0, -24, 720],
|
|
scaleX: [1, 0.9, 2],
|
|
opacity: [1, 1, 0],
|
|
transition: varTranExit({ durationOut, easeOut }),
|
|
},
|
|
},
|
|
|
|
// OUT
|
|
out: {
|
|
animate: { scale: [0.9, 1.1, 0.3], opacity: [1, 1, 0] },
|
|
},
|
|
outUp: {
|
|
animate: { y: [-12, 24, -720], scaleY: [0.985, 0.9, 3], opacity: [1, 1, 0] },
|
|
},
|
|
outDown: {
|
|
animate: { y: [12, -24, 720], scaleY: [0.985, 0.9, 3], opacity: [1, 1, 0] },
|
|
},
|
|
outLeft: {
|
|
animate: { x: [0, 24, -720], scaleX: [1, 0.9, 2], opacity: [1, 1, 0] },
|
|
},
|
|
outRight: {
|
|
animate: { x: [0, -24, 720], scaleX: [1, 0.9, 2], opacity: [1, 1, 0] },
|
|
},
|
|
};
|
|
};
|