1
0
mirror of https://github.com/kremalicious/portfolio.git synced 2025-01-09 13:14:30 +01:00
portfolio/src/components/Layout.jsx
Matthias Kretschmann b315f5bbb0
Migrate to Framer Motion (#656)
* migrate to Framer Motion

* animation tweaks

* faster animations

* handle reduced motion

* handle SSR
2021-09-11 21:37:38 +02:00

67 lines
2.1 KiB
JavaScript

import React from 'react'
import PropTypes from 'prop-types'
import { motion, AnimatePresence, useReducedMotion } from 'framer-motion'
import { fadeIn, moveInBottom, getAnimationProps } from './atoms/Transitions'
import Typekit from './atoms/Typekit'
import HostnameCheck from './atoms/HostnameCheck'
import ThemeSwitch from './molecules/ThemeSwitch'
import Header from './organisms/Header'
import Footer from './organisms/Footer'
import { screen } from './Layout.module.css'
import { useMeta } from '../hooks/use-meta'
// https://github.com/welldone-software/why-did-you-render
// if (process.env.NODE_ENV !== 'production') {
// // eslint-disable-next-line
// const whyDidYouRender = require('@welldone-software/why-did-you-render')
// whyDidYouRender(React, { trackAllPureComponents: true })
// }
Layout.propTypes = {
children: PropTypes.any.isRequired,
location: PropTypes.shape({
pathname: PropTypes.string.isRequired
}).isRequired
}
export default function Layout({ children, location }) {
const { allowedHosts } = useMeta()
const shouldReduceMotion = useReducedMotion()
const isSsr = typeof window === 'undefined'
const isHomepage =
location.pathname === '/' ||
location.pathname === '/offline-plugin-app-shell-fallback/'
const isResume =
location.pathname === '/resume' || location.pathname === '/resume/'
return (
<>
<Typekit />
<HostnameCheck allowedHosts={allowedHosts} />
<ThemeSwitch />
<AnimatePresence exitBeforeEnter>
<motion.div
key={location.pathname}
variants={fadeIn}
{...getAnimationProps(shouldReduceMotion, isSsr)}
>
<Header minimal={!isHomepage} hide={isResume} />
<motion.main
key={location.pathname}
variants={moveInBottom}
initial={`${shouldReduceMotion || isSsr ? 'enter' : 'initial'}`}
animate={`${shouldReduceMotion || isSsr ? null : 'enter'}`}
className={screen}
>
{children}
</motion.main>
</motion.div>
</AnimatePresence>
<Footer />
</>
)
}