2023-12-25 16:53:27 +03:00
|
|
|
/**
|
|
|
|
* Module: animations parameters.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import { Variants } from 'framer-motion';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Duration constants in ms.
|
|
|
|
*/
|
|
|
|
export const animationDuration = {
|
|
|
|
navigationToggle: 500
|
|
|
|
};
|
|
|
|
|
|
|
|
export const animateNavigation: Variants = {
|
|
|
|
open: {
|
|
|
|
height: '3rem',
|
|
|
|
translateY: 0,
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: animationDuration.navigationToggle / 1000
|
|
|
|
}
|
|
|
|
},
|
|
|
|
closed: {
|
|
|
|
height: 0,
|
|
|
|
translateY: '-1.5rem',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: animationDuration.navigationToggle / 1000
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const animateNavigationToggle: Variants = {
|
|
|
|
on: {
|
|
|
|
height: '3rem',
|
|
|
|
width: '1.2rem',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: animationDuration.navigationToggle / 1000
|
|
|
|
}
|
|
|
|
},
|
|
|
|
off: {
|
|
|
|
height: '1.2rem',
|
|
|
|
width: '3rem',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: animationDuration.navigationToggle / 1000
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const animateDropdown: Variants = {
|
|
|
|
open: {
|
|
|
|
clipPath: 'inset(0% 0% 0% 0%)',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 0.4,
|
|
|
|
delayChildren: 0.2,
|
|
|
|
staggerChildren: 0.05
|
|
|
|
}
|
|
|
|
},
|
|
|
|
closed: {
|
|
|
|
clipPath: 'inset(10% 0% 90% 0%)',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 0.3
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const animateDropdownItem: Variants = {
|
|
|
|
open: {
|
|
|
|
opacity: 1,
|
|
|
|
y: 0,
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
duration: 0.1,
|
|
|
|
stiffness: 300,
|
|
|
|
damping: 24
|
|
|
|
}
|
|
|
|
},
|
|
|
|
closed: {
|
|
|
|
opacity: 0,
|
|
|
|
y: 10,
|
|
|
|
transition: {
|
|
|
|
duration: 0.1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const animateRSControl: Variants = {
|
|
|
|
open: {
|
|
|
|
clipPath: 'inset(0% 0% 0% 0%)',
|
2023-12-27 18:44:37 +03:00
|
|
|
marginTop: '0.25rem',
|
2023-12-25 16:53:27 +03:00
|
|
|
height: 'max-content',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 0.4
|
|
|
|
}
|
|
|
|
},
|
|
|
|
closed: {
|
|
|
|
clipPath: 'inset(0% 0% 100% 0%)',
|
2023-12-27 18:44:37 +03:00
|
|
|
marginTop: '0',
|
|
|
|
height: 0,
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 0.3
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const animateParseResults: Variants = {
|
|
|
|
open: {
|
|
|
|
clipPath: 'inset(0% 0% 0% 0%)',
|
|
|
|
marginTop: '0.75rem',
|
|
|
|
padding: '0.25rem 0.5rem 0.25rem 0.5rem',
|
|
|
|
borderWidth: '1px',
|
|
|
|
height: '4.5rem',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 0.4
|
|
|
|
}
|
|
|
|
},
|
|
|
|
closed: {
|
|
|
|
clipPath: 'inset(0% 0% 100% 0%)',
|
|
|
|
marginTop: '0',
|
|
|
|
borderWidth: '0',
|
|
|
|
padding: '0 0 0 0',
|
2023-12-25 16:53:27 +03:00
|
|
|
height: 0,
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 0.3
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const animateSideView = {
|
|
|
|
initial: {
|
|
|
|
clipPath: 'inset(0% 100% 0% 0%)',
|
|
|
|
},
|
|
|
|
animate: {
|
|
|
|
clipPath: 'inset(0% 0% 0% 0%)',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 1
|
|
|
|
}
|
|
|
|
},
|
|
|
|
exit: {
|
|
|
|
clipPath: 'inset(0% 100% 0% 0%)',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 1
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export const animateModal = {
|
|
|
|
initial: {
|
|
|
|
clipPath: 'inset(50% 50% 50% 50%)',
|
|
|
|
opacity: 0
|
|
|
|
},
|
|
|
|
animate: {
|
|
|
|
clipPath: 'inset(0% 0% 0% 0%)',
|
|
|
|
opacity: 1,
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 0.3
|
|
|
|
}
|
|
|
|
},
|
|
|
|
exit: {
|
|
|
|
opacity: 0,
|
|
|
|
clipPath: 'inset(50% 50% 50% 50%)',
|
|
|
|
transition: {
|
|
|
|
type: 'spring',
|
|
|
|
bounce: 0,
|
|
|
|
duration: 0.2
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|