2022-10-12 10:21:49 -04:00
|
|
|
import { useMemo, useState } from 'react';
|
2022-10-31 15:09:21 -04:00
|
|
|
// @ts-ignore
|
2022-10-31 16:03:14 -04:00
|
|
|
import { Content } from '@carbon/react';
|
2022-10-12 10:21:49 -04:00
|
|
|
|
|
|
|
import { BrowserRouter, Routes, Route } from 'react-router-dom';
|
2022-11-15 14:40:35 -05:00
|
|
|
import { defineAbility } from '@casl/ability';
|
2022-10-12 10:21:49 -04:00
|
|
|
import ErrorContext from './contexts/ErrorContext';
|
|
|
|
import NavigationBar from './components/NavigationBar';
|
|
|
|
|
2022-11-10 17:30:27 -05:00
|
|
|
import HomePageRoutes from './routes/HomePageRoutes';
|
2022-10-12 10:21:49 -04:00
|
|
|
import ErrorBoundary from './components/ErrorBoundary';
|
|
|
|
import AdminRoutes from './routes/AdminRoutes';
|
2022-10-18 16:41:13 -04:00
|
|
|
import { ErrorForDisplay } from './interfaces';
|
2022-10-12 10:21:49 -04:00
|
|
|
|
2022-11-15 14:40:35 -05:00
|
|
|
import { AbilityContext } from './contexts/Can';
|
|
|
|
|
2022-10-12 10:21:49 -04:00
|
|
|
export default function App() {
|
2022-10-18 16:41:13 -04:00
|
|
|
const [errorMessage, setErrorMessage] = useState<ErrorForDisplay | null>(
|
|
|
|
null
|
|
|
|
);
|
2022-10-12 10:21:49 -04:00
|
|
|
|
|
|
|
const errorContextValueArray = useMemo(
|
|
|
|
() => [errorMessage, setErrorMessage],
|
|
|
|
[errorMessage]
|
|
|
|
);
|
|
|
|
|
2022-11-15 14:40:35 -05:00
|
|
|
const ability = defineAbility((can: any) => {});
|
|
|
|
|
2022-10-12 10:21:49 -04:00
|
|
|
let errorTag = null;
|
2022-10-18 16:41:13 -04:00
|
|
|
if (errorMessage) {
|
|
|
|
let sentryLinkTag = null;
|
|
|
|
if (errorMessage.sentry_link) {
|
|
|
|
sentryLinkTag = (
|
|
|
|
<span>
|
|
|
|
{
|
|
|
|
': Find details about this error here (it may take a moment to become available): '
|
|
|
|
}
|
|
|
|
<a href={errorMessage.sentry_link} target="_blank" rel="noreferrer">
|
|
|
|
{errorMessage.sentry_link}
|
|
|
|
</a>
|
|
|
|
</span>
|
|
|
|
);
|
|
|
|
}
|
2022-10-12 10:21:49 -04:00
|
|
|
errorTag = (
|
|
|
|
<div id="filter-errors" className="mt-4 alert alert-danger" role="alert">
|
2022-10-18 16:41:13 -04:00
|
|
|
{errorMessage.message}
|
|
|
|
{sentryLinkTag}
|
2022-10-12 10:21:49 -04:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2022-11-07 10:10:47 -05:00
|
|
|
<div className="cds--white">
|
2022-11-15 14:40:35 -05:00
|
|
|
{/* @ts-ignore */}
|
|
|
|
<AbilityContext.Provider value={ability}>
|
|
|
|
<ErrorContext.Provider value={errorContextValueArray}>
|
|
|
|
<BrowserRouter>
|
|
|
|
<NavigationBar />
|
|
|
|
<Content>
|
|
|
|
{errorTag}
|
|
|
|
<ErrorBoundary>
|
|
|
|
<Routes>
|
|
|
|
<Route path="/" element={<HomePageRoutes />} />
|
|
|
|
<Route path="/tasks/*" element={<HomePageRoutes />} />
|
|
|
|
<Route path="/admin/*" element={<AdminRoutes />} />
|
|
|
|
</Routes>
|
|
|
|
</ErrorBoundary>
|
|
|
|
</Content>
|
|
|
|
</BrowserRouter>
|
|
|
|
</ErrorContext.Provider>
|
|
|
|
</AbilityContext.Provider>
|
2022-11-07 10:10:47 -05:00
|
|
|
</div>
|
2022-10-12 10:21:49 -04:00
|
|
|
);
|
|
|
|
}
|