2019-12-07 13:28:52 +02:00
|
|
|
import React from 'react';
|
2017-08-06 02:44:35 +03:00
|
|
|
import { Link } from 'react-router-dom';
|
|
|
|
import { FormattedMessage as Message } from 'react-intl';
|
2019-12-30 09:29:39 +02:00
|
|
|
import { Helmet } from 'react-helmet-async';
|
2019-12-07 21:02:00 +02:00
|
|
|
import loader from 'app/services/loader';
|
|
|
|
import { Query } from 'app/services/request';
|
2017-08-07 23:11:39 +03:00
|
|
|
|
2019-12-07 21:02:00 +02:00
|
|
|
import rootMessages from '../root/RootPage.intl.json';
|
2017-08-07 23:11:39 +03:00
|
|
|
import styles from './success-oauth.scss';
|
2017-08-06 02:44:35 +03:00
|
|
|
import messages from './SuccessOauthPage.intl.json';
|
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
export default class SuccessOauthPage extends React.Component<{
|
2019-11-27 11:03:32 +02:00
|
|
|
location: {
|
2019-12-07 13:28:52 +02:00
|
|
|
query: Query<'appName'>;
|
|
|
|
};
|
2017-08-22 23:31:41 +03:00
|
|
|
}> {
|
2019-11-27 11:03:32 +02:00
|
|
|
componentDidMount() {
|
|
|
|
this.onPageUpdate();
|
2017-08-07 23:11:39 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
setTimeout(() => {
|
|
|
|
try {
|
|
|
|
// try to close window if possible
|
2019-12-07 13:28:52 +02:00
|
|
|
// @ts-ignore
|
2019-11-27 11:03:32 +02:00
|
|
|
window.open('', '_self').close();
|
|
|
|
} catch (err) {
|
|
|
|
// don't care
|
|
|
|
}
|
|
|
|
}, 8000);
|
|
|
|
}
|
2017-08-07 23:11:39 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
componentDidUpdate() {
|
|
|
|
this.onPageUpdate();
|
|
|
|
}
|
2017-08-07 23:11:39 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
onPageUpdate() {
|
|
|
|
loader.hide();
|
|
|
|
}
|
2017-08-07 23:11:39 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
render() {
|
|
|
|
const appName = this.props.location.query.get('appName');
|
2017-08-06 02:44:35 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
return (
|
|
|
|
<div className={styles.page}>
|
|
|
|
<Message {...messages.title}>
|
2019-12-30 10:47:29 +02:00
|
|
|
{pageTitle => <Helmet title={pageTitle as string} />}
|
2019-11-27 11:03:32 +02:00
|
|
|
</Message>
|
2017-08-06 02:44:35 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
<div className={styles.wrapper}>
|
|
|
|
<Link to="/" className={styles.logo}>
|
|
|
|
<Message {...rootMessages.siteName} />
|
|
|
|
</Link>
|
2017-08-06 02:44:35 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
<div className={styles.title}>
|
|
|
|
<Message {...messages.applicationAuth} />
|
|
|
|
</div>
|
2017-08-06 02:44:35 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
<div className={styles.checkmark} />
|
2017-08-06 02:44:35 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
<div className={styles.description}>
|
|
|
|
{appName ? (
|
|
|
|
<Message
|
|
|
|
{...messages.authorizationForAppSuccessful}
|
|
|
|
values={{
|
|
|
|
appName: <b>{appName}</b>,
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
) : (
|
|
|
|
<Message {...messages.authorizationSuccessful} />
|
|
|
|
)}
|
|
|
|
|
|
|
|
<Message {...messages.youCanCloseThisPage} />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2017-08-06 02:44:35 +03:00
|
|
|
}
|