import React, { Component } from 'react'; import PropTypes from 'prop-types'; import { observer } from 'mobx-react'; import { defineMessages, intlShape } from 'react-intl'; import Button from '../../ui/Button'; const messages = defineMessages({ headline: { id: 'service.crashHandler.headline', defaultMessage: '!!!Oh no!', }, text: { id: 'service.crashHandler.text', defaultMessage: '!!!{name} has caused an error.', }, action: { id: 'service.crashHandler.action', defaultMessage: '!!!Reload {name}', }, autoReload: { id: 'service.crashHandler.autoReload', defaultMessage: '!!!Trying to automatically restore {name} in {seconds} seconds', }, }); @observer export default class WebviewCrashHandler extends Component { static propTypes = { name: PropTypes.string.isRequired, reload: PropTypes.func.isRequired, }; static contextTypes = { intl: intlShape, }; state = { countdown: 10000, } componentDidMount() { const { reload } = this.props; this.countdownInterval = setInterval(() => { this.setState({ countdown: this.state.countdown - this.countdownIntervalTimeout, }); if (this.state.countdown <= 0) { reload(); clearInterval(this.countdownInterval); } }, this.countdownIntervalTimeout); } countdownInterval = null; countdownIntervalTimeout = 1000; render() { const { name, reload } = this.props; const { intl } = this.context; return (

{intl.formatMessage(messages.headline)}

{intl.formatMessage(messages.text, { name })}

); } }