2023-10-23 23:33:39 +02:00
|
|
|
import { useEffect } from "react"
|
|
|
|
import type { AppType } from "next/app"
|
|
|
|
import { ThemeProvider } from "next-themes"
|
|
|
|
import useTranslation from "next-translate/useTranslation"
|
2021-10-24 05:19:39 +02:00
|
|
|
|
2023-10-23 23:33:39 +02:00
|
|
|
import "../styles/global.css"
|
2021-10-24 05:19:39 +02:00
|
|
|
|
2023-10-23 23:33:39 +02:00
|
|
|
import "@fontsource/montserrat/400.css"
|
|
|
|
import "@fontsource/montserrat/500.css"
|
|
|
|
import "@fontsource/montserrat/600.css"
|
|
|
|
import "@fontsource/montserrat/700.css"
|
2021-10-24 05:19:39 +02:00
|
|
|
|
2023-10-23 23:33:39 +02:00
|
|
|
import "@fontsource/roboto/400.css"
|
|
|
|
import "@fontsource/roboto/700.css"
|
2021-10-24 05:19:39 +02:00
|
|
|
|
2023-10-23 23:33:39 +02:00
|
|
|
import { cookies } from "../tools/cookies"
|
2021-10-24 05:48:06 +02:00
|
|
|
|
2022-09-21 10:09:36 +02:00
|
|
|
const Application: AppType = ({ Component, pageProps }) => {
|
2021-10-24 05:19:39 +02:00
|
|
|
const { lang } = useTranslation()
|
|
|
|
|
|
|
|
useEffect(() => {
|
2023-10-23 23:33:39 +02:00
|
|
|
cookies.set("NEXT_LOCALE", lang)
|
2022-04-07 16:54:05 +02:00
|
|
|
const appHeight = (): void => {
|
|
|
|
document.documentElement.style.setProperty(
|
2023-10-23 23:33:39 +02:00
|
|
|
"--app-height",
|
|
|
|
`${window.innerHeight}px`,
|
2022-04-07 16:54:05 +02:00
|
|
|
)
|
|
|
|
}
|
2023-10-23 23:33:39 +02:00
|
|
|
window.addEventListener("resize", appHeight)
|
2022-04-07 16:54:05 +02:00
|
|
|
appHeight()
|
2022-08-24 17:22:55 +02:00
|
|
|
return () => {
|
2023-10-23 23:33:39 +02:00
|
|
|
window.removeEventListener("resize", appHeight)
|
2022-08-24 17:22:55 +02:00
|
|
|
}
|
2021-10-24 05:19:39 +02:00
|
|
|
}, [lang])
|
|
|
|
|
|
|
|
return (
|
2023-10-23 23:33:39 +02:00
|
|
|
<ThemeProvider attribute="class" defaultTheme="dark">
|
2021-10-24 05:48:06 +02:00
|
|
|
<Component {...pageProps} />
|
|
|
|
</ThemeProvider>
|
2021-10-24 05:19:39 +02:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-10-24 05:48:06 +02:00
|
|
|
export default Application
|