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';
|
2020-08-18 18:32:26 +02:00
|
|
|
import { Transfer } from './Transfer';
|
2021-01-12 22:59:12 +01:00
|
|
|
import { Deanery } from './DeaneryPanel';
|
2020-08-17 22:05:13 +02:00
|
|
|
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';
|
2020-08-17 22:05:13 +02:00
|
|
|
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';
|
2020-08-17 22:05:13 +02:00
|
|
|
const Wrapper = styled.div`
|
|
|
|
display: flex;
|
2020-08-29 18:52:03 +02:00
|
|
|
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;
|
2020-08-17 22:05:13 +02:00
|
|
|
`;
|
|
|
|
|
|
|
|
export const App = () => {
|
2021-01-05 23:46:51 +01:00
|
|
|
const { role } = useContext(CASContext)!;
|
2020-08-17 22:05:13 +02:00
|
|
|
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 = () => {
|
2020-08-17 22:05:13 +02:00
|
|
|
setOpenTransfer(!isOpenTransfer);
|
|
|
|
};
|
|
|
|
|
2020-12-12 17:54:13 +01:00
|
|
|
const userPrivilige = localStorage.getItem('userPrivilige');
|
2020-08-17 22:05:13 +02:00
|
|
|
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' && (
|
2020-12-12 17:54:13 +01:00
|
|
|
<>
|
2021-01-12 22:59:12 +01:00
|
|
|
<Topbar handleTransfer={handleTransfer} />
|
|
|
|
<Transfer isOpen={isOpenTransfer} handleClose={handleTransfer} />
|
|
|
|
<Wrapper>
|
|
|
|
{userPrivilige === 'STUDENT' && (
|
|
|
|
<>
|
|
|
|
<Scheduler schedulerEvents={schedulerEvents} />
|
|
|
|
<Rightbar />
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
{userPrivilige === 'DEANERY' && <Deanery schedulerEvents={schedulerEvents} />}
|
|
|
|
</Wrapper>
|
2020-12-12 17:54:13 +01:00
|
|
|
</>
|
2021-01-05 23:46:51 +01:00
|
|
|
)}
|
2021-01-12 22:59:12 +01:00
|
|
|
{userPrivilige === 'ADMIN' && (
|
|
|
|
<Administrator></Administrator>
|
|
|
|
)}
|
2020-12-12 17:54:13 +01:00
|
|
|
</LoadingOverlay>
|
2020-08-17 22:05:13 +02:00
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|