Files
swiss-datashare/frontend/src/pages/_app.tsx

92 lines
3.1 KiB
TypeScript
Raw Normal View History

2022-04-25 15:15:17 +02:00
import {
ColorScheme,
2022-12-24 23:58:31 +01:00
ColorSchemeProvider,
2022-04-25 15:15:17 +02:00
Container,
LoadingOverlay,
MantineProvider,
} from "@mantine/core";
2022-10-10 22:30:04 +02:00
import { useColorScheme } from "@mantine/hooks";
2022-04-25 15:15:17 +02:00
import { ModalsProvider } from "@mantine/modals";
import { NotificationsProvider } from "@mantine/notifications";
import type { AppProps } from "next/app";
import { useEffect, useState } from "react";
import Header from "../components/navBar/NavBar";
2022-12-24 23:58:31 +01:00
import { ConfigContext } from "../hooks/config.hook";
import usePreferences from "../hooks/usePreferences";
import { UserContext } from "../hooks/user.hook";
import authService from "../services/auth.service";
import configService from "../services/config.service";
import userService from "../services/user.service";
2022-05-16 13:11:51 +02:00
import GlobalStyle from "../styles/global.style";
import globalStyle from "../styles/mantine.style";
import Config from "../types/config.type";
import { CurrentUser } from "../types/user.type";
2022-04-25 15:15:17 +02:00
import { GlobalLoadingContext } from "../utils/loading.util";
function App({ Component, pageProps }: AppProps) {
2022-10-10 22:30:04 +02:00
const systemTheme = useColorScheme();
2022-12-24 23:58:31 +01:00
const preferences = usePreferences();
const [colorScheme, setColorScheme] = useState<ColorScheme>("light");
2022-04-25 15:15:17 +02:00
const [isLoading, setIsLoading] = useState(true);
const [user, setUser] = useState<CurrentUser | null>(null);
2022-12-01 23:07:49 +01:00
const [configVariables, setConfigVariables] = useState<Config[] | null>(null);
2022-05-02 08:22:53 +02:00
const getInitalData = async () => {
2022-04-25 15:15:17 +02:00
setIsLoading(true);
2022-12-01 23:07:49 +01:00
setConfigVariables(await configService.list());
await authService.refreshAccessToken();
setUser(await userService.getCurrentUser());
2022-04-25 15:15:17 +02:00
setIsLoading(false);
};
2022-10-10 22:30:04 +02:00
2022-04-25 15:15:17 +02:00
useEffect(() => {
setInterval(async () => await authService.refreshAccessToken(), 30 * 1000);
2022-05-02 08:22:53 +02:00
getInitalData();
2022-04-25 15:15:17 +02:00
}, []);
2022-10-10 22:30:04 +02:00
useEffect(() => {
2022-12-24 23:58:31 +01:00
setColorScheme(
preferences.get("colorScheme") == "system"
? systemTheme
: preferences.get("colorScheme")
);
2022-10-10 22:30:04 +02:00
}, [systemTheme]);
2022-04-25 15:15:17 +02:00
return (
2022-10-10 22:30:04 +02:00
<MantineProvider
withGlobalStyles
withNormalizeCSS
theme={{ colorScheme, ...globalStyle }}
>
2022-12-24 23:58:31 +01:00
<ColorSchemeProvider
colorScheme={colorScheme}
toggleColorScheme={(value) => setColorScheme(value ?? "light")}
>
<GlobalStyle />
<NotificationsProvider>
<ModalsProvider>
<GlobalLoadingContext.Provider value={{ isLoading, setIsLoading }}>
{isLoading ? (
<LoadingOverlay visible overlayOpacity={1} />
) : (
<ConfigContext.Provider value={configVariables}>
<UserContext.Provider value={{ user, setUser }}>
<LoadingOverlay visible={isLoading} overlayOpacity={1} />
<Header />
<Container>
<Component {...pageProps} />
</Container>
</UserContext.Provider>
2022-12-24 23:58:31 +01:00
</ConfigContext.Provider>
)}
</GlobalLoadingContext.Provider>
</ModalsProvider>
</NotificationsProvider>
</ColorSchemeProvider>
2022-04-25 15:15:17 +02:00
</MantineProvider>
);
}
export default App;