Skip to content

Commit

Permalink
Bruce/910 fixing error component (DataBiosphere#3754)
Browse files Browse the repository at this point in the history
* feat: using error component #854

* fix: forcing rerender when route changes #910
  • Loading branch information
BruceRodrigues authored Nov 8, 2023
1 parent a373022 commit d2feb84
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 6 deletions.
18 changes: 14 additions & 4 deletions explorer/pages/_app.tsx
Original file line number Diff line number Diff line change
@@ -1,23 +1,25 @@
import "@clevercanary/data-explorer-ui";
import { AzulEntitiesStaticResponse } from "@clevercanary/data-explorer-ui/lib/apis/azul/common/entities";
import { Error } from "@clevercanary/data-explorer-ui/lib/components/Error/error";
import { ErrorBoundary } from "@clevercanary/data-explorer-ui/lib/components/ErrorBoundary";
import { Head } from "@clevercanary/data-explorer-ui/lib/components/Head/head";
import { AppLayout } from "@clevercanary/data-explorer-ui/lib/components/Layout/components/AppLayout/appLayout.styles";
import { Footer } from "@clevercanary/data-explorer-ui/lib/components/Layout/components/Footer/footer";
import { Header } from "@clevercanary/data-explorer-ui/lib/components/Layout/components/Header/header";
import { Main } from "@clevercanary/data-explorer-ui/lib/components/Layout/components/Main/main.styles";
import { Support } from "@clevercanary/data-explorer-ui/lib/components/Support/support";
import { TempError } from "@clevercanary/data-explorer-ui/lib/components/TempError";
import { AuthProvider } from "@clevercanary/data-explorer-ui/lib/providers/authentication";
import { ConfigProvider as DXConfigProvider } from "@clevercanary/data-explorer-ui/lib/providers/config";
import { ExploreStateProvider } from "@clevercanary/data-explorer-ui/lib/providers/exploreState";
import { FileManifestStateProvider } from "@clevercanary/data-explorer-ui/lib/providers/fileManifestState";
import { createAppTheme } from "@clevercanary/data-explorer-ui/lib/theme/theme";
import { DataExplorerError } from "@clevercanary/data-explorer-ui/lib/types/error";
import { ThemeProvider as EmotionThemeProvider } from "@emotion/react";
import { CssBaseline } from "@mui/material";
import { ThemeProvider } from "@mui/material/styles";
import { config } from "app/config/config";
import type { AppProps } from "next/app";
import { useRouter } from "next/router";
import { useEffect } from "react";
import TagManager from "react-gtm-module";

Expand All @@ -26,7 +28,8 @@ const SESSION_TIMEOUT = 15 * 60 * 1000; // 15 minutes
function MyApp({ Component, pageProps }: AppProps): JSX.Element {
// Set up the site configuration, layout and theme.
const appConfig = config();
const { analytics, layout, themeOptions } = appConfig;
const { asPath } = useRouter();
const { analytics, layout, redirectRootToPath, themeOptions } = appConfig;
const { gtmAuth, gtmId, gtmPreview } = analytics || {};
const theme = createAppTheme(themeOptions);
const { entityListType } = pageProps as AzulEntitiesStaticResponse;
Expand All @@ -51,8 +54,15 @@ function MyApp({ Component, pageProps }: AppProps): JSX.Element {
<FileManifestStateProvider>
<Main>
<ErrorBoundary
fallbackRender={(error): JSX.Element => (
<TempError error={error} />
key={asPath}
fallbackRender={(
error: DataExplorerError
): JSX.Element => (
<Error
errorMessage={error.message}
requestUrlMessage={error.requestUrlMessage}
rootPath={redirectRootToPath}
/>
)}
>
<Component {...pageProps} />
Expand Down
11 changes: 9 additions & 2 deletions explorer/pages/_error.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,19 @@
import { TempError as CustomError } from "@clevercanary/data-explorer-ui/lib/components/TempError";
import { Error as ErrorComponent } from "@clevercanary/data-explorer-ui/lib/components/Error/error";
import { useConfig } from "@clevercanary/data-explorer-ui/lib/hooks/useConfig";
import { NextPage, NextPageContext } from "next";

interface ErrorProps {
error?: Error | null;
}

const Error: NextPage<ErrorProps> = ({ error }: ErrorProps) => {
return error ? <CustomError error={error} /> : <></>;
const { config } = useConfig();

return error ? (
<ErrorComponent rootPath={config.redirectRootToPath} />
) : (
<></>
);
};

Error.getInitialProps = ({ err }: NextPageContext): ErrorProps => {
Expand Down

0 comments on commit d2feb84

Please sign in to comment.