blob: e9e5328eddbd4358d7cec980343d648e9b39e4c0 [file] [log] [blame]
simond47ef9e2022-09-28 22:24:28 -04001import CircularProgress from '@mui/material/CircularProgress';
simon07b4eb02022-09-29 17:50:26 -04002import Container from '@mui/material/Container';
simon80b7b3b2022-09-28 17:50:10 -04003import { useEffect, useState } from 'react';
simonfe1de722022-10-02 00:21:43 -04004import { useParams } from 'react-router-dom';
simon07b4eb02022-09-29 17:50:26 -04005
simond47ef9e2022-09-28 22:24:28 -04006import Account from '../../../model/Account';
simon07b4eb02022-09-29 17:50:26 -04007import authManager from '../AuthManager';
8import AccountPreferences from '../components/AccountPreferences';
9import Header from '../components/Header';
Adrien Béraud4e287b92021-04-24 16:15:56 -040010
simonfe1de722022-10-02 00:21:43 -040011type ServerOverviewProps = {
12 accountId?: string;
13};
14
15const ServerOverview = (props: ServerOverviewProps) => {
16 const [account, setAccount] = useState<Account | null>(null);
17 const params = useParams();
18 const accountId = props.accountId || params.accountId;
Adrien Béraud4e287b92021-04-24 16:15:56 -040019
Adrien Béraudab519ff2022-05-03 15:34:48 -040020 useEffect(() => {
simond47ef9e2022-09-28 22:24:28 -040021 const controller = new AbortController();
22 authManager
23 .fetch(`/api/serverConfig`, { signal: controller.signal })
24 .then((res) => res.json())
25 .then((result) => {
26 console.log(result);
simon80b7b3b2022-09-28 17:50:10 -040027 setAccount(Account.from(result));
simond47ef9e2022-09-28 22:24:28 -040028 })
29 .catch((e) => console.log(e));
30 // return () => controller.abort() // crash on React18
31 }, [accountId]);
Adrien Béraudab519ff2022-05-03 15:34:48 -040032
Adrien Béraud4e287b92021-04-24 16:15:56 -040033 return (
simond47ef9e2022-09-28 22:24:28 -040034 <Container maxWidth="sm" className="app">
Adrien Béraud4e287b92021-04-24 16:15:56 -040035 <Header />
simonfe1de722022-10-02 00:21:43 -040036 {account != null ? <AccountPreferences account={account} /> : <CircularProgress />}
Adrien Béraud4e287b92021-04-24 16:15:56 -040037 </Container>
simond47ef9e2022-09-28 22:24:28 -040038 );
39};
Adrien Béraud4e287b92021-04-24 16:15:56 -040040
simond47ef9e2022-09-28 22:24:28 -040041export default ServerOverview;