spiff-arena/src/App.tsx

60 lines
1.8 KiB
TypeScript
Raw Normal View History

import { useMemo, useState } from 'react';
import { Container } from 'react-bootstrap';
import { BrowserRouter, Routes, Route } from 'react-router-dom';
import ErrorContext from './contexts/ErrorContext';
import NavigationBar from './components/NavigationBar';
import HomePage from './routes/HomePage';
import TaskShow from './routes/TaskShow';
import ErrorBoundary from './components/ErrorBoundary';
import AdminRoutes from './routes/AdminRoutes';
import SubNavigation from './components/SubNavigation';
export default function App() {
const [errorMessage, setErrorMessage] = useState('');
const errorContextValueArray = useMemo(
() => [errorMessage, setErrorMessage],
[errorMessage]
);
let errorTag = null;
if (errorMessage !== '') {
errorTag = (
<div id="filter-errors" className="mt-4 alert alert-danger" role="alert">
{errorMessage}
</div>
);
}
return (
<ErrorContext.Provider value={errorContextValueArray}>
<NavigationBar />
<Container>
{errorTag}
<ErrorBoundary>
<BrowserRouter>
<SubNavigation />
<main style={{ padding: '1rem 0' }}>
<Routes>
<Route path="/" element={<HomePage />} />
<Route path="/tasks" element={<HomePage />} />
<Route path="/admin/*" element={<AdminRoutes />} />
<Route
path="/tasks/:process_instance_id/:task_id"
element={<TaskShow />}
/>
<Route
path="/tasks/:process_instance_id/:task_id"
element={<TaskShow />}
/>
</Routes>
</main>
</BrowserRouter>
</ErrorBoundary>
</Container>
</ErrorContext.Provider>
);
}