import React from 'react'; import PropTypes from 'prop-types'; import { FormattedMessage } from 'react-intl'; import { source_url, version } from 'mastodon/initial_state'; export default class ErrorBoundary extends React.PureComponent { static propTypes = { children: PropTypes.node, }; state = { hasError : false, stackTrace : undefined, componentStack: undefined, }; componentDidCatch(error, info) { this.setState({ hasError : true, stackTrace : error.stack, componentStack: info && info.componentStack, copied : false, }); } handleCopyStackTrace = () => { const { stackTrace } = this.state; const textarea = document.createElement('textarea'); textarea.textContent = stackTrace; textarea.style.position = 'fixed'; document.body.appendChild(textarea); try { textarea.select(); document.execCommand('copy'); } catch (e) { } finally { document.body.removeChild(textarea); } this.setState({ copied: true }); setTimeout(() => this.setState({ copied: false }), 700); }; render() { const { hasError, copied } = this.state; if (!hasError) { return this.props.children; } return (

Mastodon v{version} · ·

); } }