blob: 56574c2c6e78f69a313115b0823a46dfc50b485e [file] [log] [blame]
/*
* Copyright (C) 2022 Savoir-faire Linux Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation; either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public
* License along with this program. If not, see
* <https://www.gnu.org/licenses/>.
*/
import { Container } from '@mui/material';
import { AnimatePresence, motion } from 'framer-motion';
import { useState } from 'react';
import { useTranslation } from 'react-i18next';
import { ReactComponent as JamiLogo } from '../icons/jamiLogoIcon.svg';
const list = {
hidden: { opacity: 0 },
visible: {
opacity: 1,
transition: {
when: 'beforeChildren',
staggerChildren: 0.3,
},
},
};
const item = {
visible: { opacity: 1, x: 0 },
hidden: { opacity: 0, x: 0 },
};
export default function WelcomeAnimation(props) {
const { t } = useTranslation();
const [visible, setVisible] = useState(true);
return (
<Container style={{ textAlign: 'center', display: 'flex', flexDirection: 'column', alignItems: 'center' }}>
<AnimatePresence>
{visible && (
<motion.div
initial="hidden"
animate="visible"
exit="hidden"
variants={list}
onAnimationComplete={(a) => {
if (a === 'hidden') {
props.onComplete();
} else {
setVisible(false);
}
}}
>
<motion.div variants={item}>
<JamiLogo width="95%" />
</motion.div>
<motion.h1 variants={item}>{t('welcome_text')}</motion.h1>
</motion.div>
)}
</AnimatePresence>
</Container>
);
}