2022-05-20 13:59:24 +02:00
|
|
|
import '../styles/globals.css'
|
|
|
|
import type { AppProps } from 'next/app'
|
2022-05-24 18:55:21 +02:00
|
|
|
import { LoginContext } from '../contexts/login'
|
2022-05-30 05:19:49 +02:00
|
|
|
import { useState } from 'react'
|
2022-05-26 16:32:11 +02:00
|
|
|
import defaultPostcard from "../public/postcards/adi-goldstein-Hli3R6LKibo-unsplash.jpg"
|
2022-05-24 18:55:21 +02:00
|
|
|
import { Postcard } from '../components/Postcard'
|
|
|
|
import { PostcardContext } from '../contexts/postcard'
|
|
|
|
import { StaticImageData } from 'next/image'
|
2022-05-25 16:20:22 +02:00
|
|
|
import { appWithTranslation } from 'next-i18next'
|
2022-05-29 04:01:56 +02:00
|
|
|
import { FestaLoginData } from '../types/user'
|
|
|
|
import {useStoredLogin} from "../hooks/useStoredLogin"
|
2022-06-02 01:29:37 +02:00
|
|
|
import { SWRConfig } from 'swr'
|
|
|
|
import { AxiosRequestConfig } from 'axios'
|
|
|
|
import { useAxios } from '../hooks/useAxios'
|
2022-05-27 02:46:30 +02:00
|
|
|
|
2022-05-20 13:59:24 +02:00
|
|
|
|
2022-05-25 16:20:22 +02:00
|
|
|
const App = ({ Component, pageProps }: AppProps): JSX.Element => {
|
2022-05-27 02:46:30 +02:00
|
|
|
const [postcard, setPostcard] = useState<string | StaticImageData>(defaultPostcard)
|
2022-05-31 17:07:25 +02:00
|
|
|
const [login, setLogin] = useState<FestaLoginData | null>(null)
|
2022-05-29 04:01:56 +02:00
|
|
|
useStoredLogin(setLogin)
|
2022-05-24 18:55:21 +02:00
|
|
|
|
2022-06-02 04:26:52 +02:00
|
|
|
const axios = useAxios({}, login)
|
2022-05-31 17:07:25 +02:00
|
|
|
|
|
|
|
const swrConfig = {
|
2022-06-02 01:29:37 +02:00
|
|
|
fetcher: async (resource: string, init: AxiosRequestConfig<any>) => {
|
|
|
|
const response = await axios.get(resource, init)
|
2022-06-01 18:54:59 +02:00
|
|
|
// To test loading uncomment the following line:
|
|
|
|
// await new Promise(res => setTimeout(res, 100000))
|
2022-05-31 17:07:25 +02:00
|
|
|
return response.data
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-24 18:55:21 +02:00
|
|
|
return (
|
2022-05-27 02:46:30 +02:00
|
|
|
<PostcardContext.Provider value={[postcard, setPostcard]}>
|
|
|
|
<LoginContext.Provider value={[login, setLogin]}>
|
2022-05-31 17:07:25 +02:00
|
|
|
<SWRConfig value={swrConfig}>
|
2022-05-24 18:55:21 +02:00
|
|
|
<Postcard/>
|
|
|
|
<Component {...pageProps} />
|
2022-05-31 17:07:25 +02:00
|
|
|
</SWRConfig>
|
2022-05-24 18:55:21 +02:00
|
|
|
</LoginContext.Provider>
|
|
|
|
</PostcardContext.Provider>
|
|
|
|
)
|
2022-05-20 13:59:24 +02:00
|
|
|
}
|
|
|
|
|
2022-05-25 16:20:22 +02:00
|
|
|
export default appWithTranslation(App)
|