import PropTypes from 'prop-types';
import { FormattedMessage } from 'react-intl';
import { preferencesLink } from 'flavours/glitch/util/backend_links';
+import StackTrace from 'stacktrace-js';
export default class ErrorBoundary extends React.PureComponent {
state = {
hasError: false,
+ errorMessage: undefined,
stackTrace: undefined,
+ mappedStackTrace: undefined,
componentStack: undefined,
}
componentDidCatch(error, info) {
this.setState({
hasError: true,
+ errorMessage: error.toString(),
stackTrace: error.stack,
componentStack: info && info.componentStack,
+ mappedStackTrace: undefined,
+ });
+
+ StackTrace.fromError(error).then((stackframes) => {
+ this.setState({
+ mappedStackTrace: stackframes.map((sf) => sf.toString()).join('\n'),
+ });
+ }).catch(() => {
+ this.setState({
+ mappedStackTrace: undefined,
+ });
});
}
}
render() {
- const { hasError, stackTrace, componentStack } = this.state;
+ const { hasError, errorMessage, stackTrace, mappedStackTrace, componentStack } = this.state;
if (!hasError) return this.props.children;
let debugInfo = '';
if (stackTrace) {
- debugInfo += 'Stack trace\n-----------\n\n```\n' + stackTrace.toString() + '\n```';
+ debugInfo += 'Stack trace\n-----------\n\n```\n' + errorMessage + '\n' + stackTrace.toString() + '\n```';
+ }
+ if (mappedStackTrace) {
+ debugInfo += 'Mapped stack trace\n-----------\n\n```\n' + errorMessage + '\n' + mappedStackTrace.toString() + '\n```';
}
if (componentStack) {
if (debugInfo) {