Files
aso/frontend/client-portal/src/components/animate/variants/flip.ts
Linksehat Staging Server ce024c2bcd merge
2023-05-08 08:50:15 +07:00

38 lines
1.2 KiB
TypeScript
Executable File

// @types
import { VariantsType } from '../type';
//
import { varTranEnter, varTranExit } from './transition';
// ----------------------------------------------------------------------
export const varFlip = (props?: VariantsType) => {
const durationIn = props?.durationIn;
const durationOut = props?.durationOut;
const easeIn = props?.easeIn;
const easeOut = props?.easeOut;
return {
// IN
inX: {
initial: { rotateX: -180, opacity: 0 },
animate: { rotateX: 0, opacity: 1, transition: varTranEnter({ durationIn, easeIn }) },
exit: { rotateX: -180, opacity: 0, transition: varTranExit({ durationOut, easeOut }) },
},
inY: {
initial: { rotateY: -180, opacity: 0 },
animate: { rotateY: 0, opacity: 1, transition: varTranEnter({ durationIn, easeIn }) },
exit: { rotateY: -180, opacity: 0, transition: varTranExit({ durationOut, easeOut }) },
},
// OUT
outX: {
initial: { rotateX: 0, opacity: 1 },
animate: { rotateX: 70, opacity: 0, transition: varTranExit({ durationOut, easeOut }) },
},
outY: {
initial: { rotateY: 0, opacity: 1 },
animate: { rotateY: 70, opacity: 0, transition: varTranExit({ durationOut, easeOut }) },
},
};
};