Newer
Older
CrypticOreWallet / src / App.tsx
@Drew Lemmy Drew Lemmy on 30 Mar 2021 1 KB chore: upgrade error boundaries
// Copyright (c) 2020-2021 Drew Lemmy
// This file is part of KristWeb 2 under AGPL-3.0.
// Full details: https://github.com/tmpim/KristWeb2/blob/master/LICENSE.txt
import { Suspense } from "react";
import { BrowserRouter as Router } from "react-router-dom";

import { Provider } from "react-redux";
import { initStore } from "@store/init";

// Set up localisation
import "@utils/i18n";

// FIXME: Apparently the import order of my CSS is important. Who knew!
import "./App.less";

import { ErrorBoundary } from "@global/ErrorBoundary";
import { AppLoading } from "@global/AppLoading";
import { AppServices } from "@global/AppServices";
import { WebsocketProvider } from "@global/ws/WebsocketProvider";
import { LocaleContext } from "@global/LocaleContext";
import { AuthProvider } from "@comp/auth/AuthContext";

import { AppLayout } from "@layout/AppLayout";

import Debug from "debug";
const debug = Debug("kristweb:app");

export let store: ReturnType<typeof initStore>;

function App(): JSX.Element {
  debug("whole app is being rendered!");

  if (!store) {
    debug("initialising redux store");
    store = initStore();
  }

  return <ErrorBoundary name="top-level-app">
    <Suspense fallback={<AppLoading />}>
      <Provider store={store}>
        <LocaleContext>
          <AuthProvider>
            <WebsocketProvider>
              <Router>
                <AppLayout />

                {/* Services, etc. */}
                <AppServices />
              </Router>
            </WebsocketProvider>
          </AuthProvider>
        </LocaleContext>
      </Provider>
    </Suspense>
  </ErrorBoundary>;
}

export default App;