mirror of
https://github.com/status-im/spiff-arena.git
synced 2025-01-18 14:12:44 +00:00
2b6b053671
The same issue was happening on the ProcessInstanceListTable, and there it was being managed by a "SafelySetErrorMessage" function in one case, but would not be addressed in all possible cases. Reworked error handling into a context provider (APIErrorProvider) and hook (UseApiError) and removed the "(useContext as any)(ErrorContext)[1];" that felt a little off but that never was an actual problem.
48 lines
1.4 KiB
TypeScript
48 lines
1.4 KiB
TypeScript
// @ts-ignore
|
|
import { Content } from '@carbon/react';
|
|
|
|
import { BrowserRouter, Routes, Route } from 'react-router-dom';
|
|
import { defineAbility } from '@casl/ability';
|
|
import NavigationBar from './components/NavigationBar';
|
|
|
|
import HomePageRoutes from './routes/HomePageRoutes';
|
|
import ErrorBoundary from './components/ErrorBoundary';
|
|
import AdminRoutes from './routes/AdminRoutes';
|
|
|
|
import { AbilityContext } from './contexts/Can';
|
|
import UserService from './services/UserService';
|
|
import ErrorDisplay from './components/ErrorDisplay';
|
|
import APIErrorProvider from './contexts/APIErrorContext';
|
|
|
|
export default function App() {
|
|
if (!UserService.isLoggedIn()) {
|
|
UserService.doLogin();
|
|
return null;
|
|
}
|
|
|
|
const ability = defineAbility(() => {});
|
|
|
|
return (
|
|
<div className="cds--white">
|
|
{/* @ts-ignore */}
|
|
<AbilityContext.Provider value={ability}>
|
|
<APIErrorProvider>
|
|
<BrowserRouter>
|
|
<NavigationBar />
|
|
<Content>
|
|
<ErrorDisplay />
|
|
<ErrorBoundary>
|
|
<Routes>
|
|
<Route path="/*" element={<HomePageRoutes />} />
|
|
<Route path="/tasks/*" element={<HomePageRoutes />} />
|
|
<Route path="/admin/*" element={<AdminRoutes />} />
|
|
</Routes>
|
|
</ErrorBoundary>
|
|
</Content>
|
|
</BrowserRouter>
|
|
</APIErrorProvider>
|
|
</AbilityContext.Provider>
|
|
</div>
|
|
);
|
|
}
|