1
Fork 0
mirror of https://github.com/Steffo99/festa.git synced 2024-12-23 07:04:22 +00:00
festa/components/errors/ErrorBoundary.tsx
2022-06-04 05:13:19 +02:00

40 lines
No EOL
992 B
TypeScript

import { Component, ErrorInfo, ReactNode } from "react";
import { ErrorBlock } from "./ErrorBlock";
type ErrorBoundaryProps = {
text: string,
children: ReactNode,
}
type ErrorBoundaryState = {
error?: Error,
errorInfo?: ErrorInfo,
}
export class ErrorBoundary extends Component<ErrorBoundaryProps, ErrorBoundaryState> {
constructor(props: ErrorBoundaryProps) {
super(props)
this.state = {error: undefined, errorInfo: undefined}
}
componentDidCatch(error: Error, errorInfo: ErrorInfo) {
this.setState(state => {
return {...state, error, errorInfo}
})
}
render() {
if(this.state.error) {
return (
<ViewNotice
<main id="page-error-fatal" className="page">
<ErrorBlock text={this.props.text} error={this.state.error}/>
</main>
)
}
else {
return this.props.children
}
}
}