Newer
Older
CrypticOreWallet / src / App.tsx
// 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 { 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 <Suspense fallback={<AppLoading />}>
    <Provider store={store}>
      <LocaleContext>
        <AuthProvider>
          <WebsocketProvider>
            <Router>
              <AppLayout />

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

export default App;