import React, { Suspense, useMemo, useState } from "react"; import { BrowserRouter as Router, Switch, Route } from "react-router-dom"; import WarningHeader from "./WarningHeader"; import Home from "./Home"; import Search from "./Search"; import Title from "./Title"; import ConnectionErrorPanel from "./ConnectionErrorPanel"; import Footer from "./Footer"; import { ConnectionStatus } from "./types"; import { RuntimeContext, useRuntime } from "./useRuntime"; import { AppConfig, AppConfigContext } from "./useAppConfig"; import { SourcifySource } from "./url"; const Block = React.lazy(() => import("./Block")); const BlockTransactions = React.lazy(() => import("./BlockTransactions")); const AddressTransactions = React.lazy(() => import("./AddressTransactions")); const Transaction = React.lazy(() => import("./Transaction")); const London = React.lazy(() => import("./special/london/London")); const App = () => { const runtime = useRuntime(); const [sourcifySource, setSourcifySource] = useState( SourcifySource.IPFS_IPNS ); const appConfig = useMemo((): AppConfig => { return { sourcifySource, setSourcifySource, }; }, [sourcifySource, setSourcifySource]); return ( {runtime.connStatus !== ConnectionStatus.CONNECTED ? ( ) : (
<Route path="/block/:blockNumberOrHash" exact> <Block /> </Route> <Route path="/block/:blockNumber/txs" exact> <BlockTransactions /> </Route> <Route path="/tx/:txhash"> <Transaction /> </Route> <Route path="/address/:addressOrName/:direction?"> <AddressTransactions /> </Route> </AppConfigContext.Provider> </Route> </Switch> </Router> <Footer /> </div> </RuntimeContext.Provider> )} </Suspense> ); }; export default React.memo(App);