62 lines
2.1 KiB
TypeScript
Raw Normal View History

import React, { ComponentType } from 'react';
import { FormattedMessage as Message } from 'react-intl';
import appName from 'app/components/auth/appInfo/appName.intl';
import BoxesField from './BoxesField';
import styles from './styles.scss';
2019-12-07 13:28:52 +02:00
interface State {
2020-05-24 02:08:24 +03:00
lastEventId?: string | void;
2019-12-07 13:28:52 +02:00
}
interface Props {
2020-05-24 02:08:24 +03:00
lastEventId?: string;
}
2018-05-02 21:22:13 +03:00
// TODO: probably it's better to render this view from the App view
// to remove dependencies from the store and IntlProvider
const BSoD: ComponentType<Props> = ({ lastEventId }) => {
2020-05-24 02:08:24 +03:00
let emailUrl = 'mailto:support@ely.by';
if (lastEventId) {
emailUrl += `?subject=Bug report for #${lastEventId}`;
}
return (
<div className={styles.body}>
<canvas className={styles.canvas} ref={(el: HTMLCanvasElement | null) => el && new BoxesField(el)} />
<div className={styles.wrapper}>
<div className={styles.title}>
<Message {...appName} />
2020-05-24 02:08:24 +03:00
</div>
<div className={styles.lineWithMargin}>
<Message
key="criticalErrorHappened"
defaultMessage="There was a critical error due to which the application can not continue its normal operation."
/>
2020-05-24 02:08:24 +03:00
</div>
<div className={styles.line}>
<Message
key="reloadPageOrContactUs"
defaultMessage="Please reload this page and try again. If problem occurs again, please report it to the developers by sending email to"
/>
2020-05-24 02:08:24 +03:00
</div>
<a href={emailUrl} className={styles.support}>
support@ely.by
</a>
<div className={styles.easterEgg}>
<Message
key="alsoYouCanInteractWithBackground"
defaultMessage="You can also play around with the background it's interactable ;)"
/>
2020-05-24 02:08:24 +03:00
</div>
</div>
</div>
2020-05-24 02:08:24 +03:00
);
};
2019-12-07 13:28:52 +02:00
export default BSoD;