From 028d3a21b17ea56f959c2a42b97353ef58e3eac4 Mon Sep 17 00:00:00 2001 From: Rafi Zadanly Date: Fri, 31 Mar 2023 17:00:45 +0700 Subject: toaster --- src/pages/_app.jsx | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) (limited to 'src/pages/_app.jsx') diff --git a/src/pages/_app.jsx b/src/pages/_app.jsx index 7b04fea2..634e631f 100644 --- a/src/pages/_app.jsx +++ b/src/pages/_app.jsx @@ -5,6 +5,7 @@ import { AnimatePresence } from 'framer-motion' import { Toaster } from 'react-hot-toast' import { QueryClient, QueryClientProvider } from 'react-query' import useDevice from '@/core/hooks/useDevice' +import { useEffect, useState } from 'react' const queryClient = new QueryClient() @@ -12,10 +13,26 @@ function MyApp({ Component, pageProps }) { const router = useRouter() const { isMobile } = useDevice() + const [toasterStyle, setToasterStyle] = useState({}) + + useEffect(() => { + let elems = document.querySelectorAll('nav') + let totalNavHeight = 0 + + elems.forEach(function (elem) { + totalNavHeight += elem.offsetHeight + }) + + setToasterStyle({ + marginTop: isMobile ? totalNavHeight - 8 : totalNavHeight + }) + }, [isMobile]) + return ( <>