1
0
mirror of https://github.com/matrix-org/matrix-authentication-service.git synced 2025-11-24 23:01:05 +03:00

Error boundary (#1743)

* reinstate link to browser session detail

* add util hook for unwrapping current browser session id

* fix bug in compatsessiondetail createdAt -> finishedAt

* browser session detail page

* tweak naming

* add ErrorBoundary

* useCurrentBrowserSessionId throw when error

* add ErrorBoundary to pages

* throw errors instead of rendering error

* add unwrap util
This commit is contained in:
Kerry
2023-09-14 12:26:32 +12:00
committed by GitHub
parent 11ea6660c8
commit ce2395f94b
16 changed files with 154 additions and 48 deletions

View File

@@ -0,0 +1,72 @@
// Copyright 2023 The Matrix.org Foundation C.I.C.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import { CombinedError } from "@urql/core";
import { Alert } from "@vector-im/compound-web";
import { ErrorInfo, ReactNode, PureComponent } from "react";
import GraphQLError from "./GraphQLError";
interface Props {
children: ReactNode;
}
interface IState {
error?: Error;
}
const isGqlError = (error: Error): error is CombinedError =>
error.name === "CombinedError";
/**
* This error boundary component can be used to wrap large content areas and
* catch exceptions during rendering in the component tree below them.
*/
export default class ErrorBoundary extends PureComponent<Props, IState> {
public constructor(props: Props) {
super(props);
this.state = {};
}
public static getDerivedStateFromError(error: Error): Partial<IState> {
// Side effects are not permitted here, so we only update the state so
// that the next render shows an error message.
return { error };
}
public componentDidCatch(error: Error, { componentStack }: ErrorInfo): void {
console.error(error);
console.error(
"The above error occurred while React was rendering the following components:",
componentStack,
);
}
public render(): ReactNode {
if (this.state.error) {
if (isGqlError(this.state.error)) {
return <GraphQLError error={this.state.error} />;
}
return (
<Alert type="critical" title="Something went wrong">
{this.state.error.message}
</Alert>
);
}
return this.props.children;
}
}