frontend/src/components/App.tsx

57 lines
1.8 KiB
TypeScript
Raw Normal View History

2021-01-05 23:46:51 +01:00
import React, { useContext, useState } from 'react';
2020-08-20 18:14:28 +02:00
import Topbar from './Topbar';
import { Transfer } from './Transfer';
2021-01-12 22:59:12 +01:00
import { Deanery } from './DeaneryPanel';
import { Scheduler } from './Scheduler';
2020-08-17 23:56:34 +02:00
import { Rightbar } from './Rightbar';
2021-01-12 22:59:12 +01:00
import { Administrator } from './Administrator';
import styled from 'styled-components';
2020-12-12 17:54:13 +01:00
import LoadingOverlay from 'react-loading-overlay';
import { SyncLoader } from 'react-spinners';
2021-01-05 21:05:16 +01:00
import { CASContext } from '../contexts/CASProvider';
2021-01-12 22:59:12 +01:00
import { coursesContext } from '../contexts/CoursesProvider';
const Wrapper = styled.div`
display: flex;
height: calc(100vh - 80px);
2020-11-22 18:22:07 +01:00
background-color: #eceef4;
padding-top: 20px;
padding-bottom: 20px;
2020-11-24 19:01:20 +01:00
padding-right: 20px;
`;
export const App = () => {
2021-01-05 23:46:51 +01:00
const { role } = useContext(CASContext)!;
const [isOpenTransfer, setOpenTransfer] = useState(false);
2021-01-12 22:59:12 +01:00
const { selectSchedulerEvents } = useContext(coursesContext)!;
const schedulerEvents = selectSchedulerEvents();
2021-01-05 21:05:16 +01:00
const handleTransfer = () => {
setOpenTransfer(!isOpenTransfer);
};
2020-12-12 17:54:13 +01:00
const userPrivilige = localStorage.getItem('userPrivilige');
return (
<>
2021-01-05 21:05:16 +01:00
<LoadingOverlay active={role === undefined} spinner={<SyncLoader />}>
2021-01-12 22:59:12 +01:00
{userPrivilige !== 'ADMIN' && (
2021-01-18 22:37:31 +01:00
<>
<Topbar handleTransfer={handleTransfer} />
<Transfer isTransferOpen={isOpenTransfer} handleClose={handleTransfer} />
<Wrapper>
{userPrivilige === 'STUDENT' && (
<>
<Scheduler schedulerEvents={schedulerEvents} />
<Rightbar />
</>
)}
{userPrivilige === 'DEANERY' && <Deanery schedulerEvents={schedulerEvents} />}
</Wrapper>
</>
2021-01-12 22:59:12 +01:00
)}
2021-01-18 22:37:31 +01:00
{userPrivilige === 'ADMIN' && <Administrator></Administrator>}
2020-12-12 17:54:13 +01:00
</LoadingOverlay>
</>
);
};