2024-12-10 20:42:06 +01:00
|
|
|
import React, { FC, MouseEventHandler, useEffect } from 'react';
|
|
|
|
import { Redirect } from 'react-router-dom';
|
2020-07-22 14:20:10 +03:00
|
|
|
import { FormattedMessage as Message } from 'react-intl';
|
2019-12-30 09:29:39 +02:00
|
|
|
import { Helmet } from 'react-helmet-async';
|
2020-07-22 13:01:12 +03:00
|
|
|
|
2024-12-10 20:42:06 +01:00
|
|
|
import { useReduxSelector } from 'app/functions';
|
2019-12-07 21:02:00 +02:00
|
|
|
import { Button } from 'app/components/ui/form';
|
|
|
|
import copy from 'app/services/copy';
|
2016-03-04 00:27:33 +03:00
|
|
|
|
|
|
|
import styles from './finish.scss';
|
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
interface Props {
|
2020-05-24 02:08:24 +03:00
|
|
|
appName: string;
|
|
|
|
code?: string;
|
|
|
|
state: string;
|
|
|
|
displayCode?: boolean;
|
|
|
|
success?: boolean;
|
2019-12-07 13:28:52 +02:00
|
|
|
}
|
2016-03-04 00:27:33 +03:00
|
|
|
|
2024-12-10 20:42:06 +01:00
|
|
|
const Finish: FC<Props> = () => {
|
|
|
|
const { client, oauth } = useReduxSelector((state) => state.auth);
|
|
|
|
|
|
|
|
const onCopyClick: MouseEventHandler = (event) => {
|
|
|
|
event.preventDefault();
|
|
|
|
copy(oauth!.code!);
|
|
|
|
};
|
|
|
|
|
|
|
|
let authData: string | undefined;
|
|
|
|
|
|
|
|
if (oauth && 'state' in oauth.params) {
|
|
|
|
authData = JSON.stringify({
|
|
|
|
auth_code: oauth.code,
|
|
|
|
state: oauth.params.state,
|
2020-05-24 02:08:24 +03:00
|
|
|
});
|
2024-12-10 20:42:06 +01:00
|
|
|
}
|
2016-03-16 06:46:44 +02:00
|
|
|
|
2024-12-10 20:42:06 +01:00
|
|
|
useEffect(() => {
|
|
|
|
if (authData) {
|
|
|
|
history.pushState(null, document.title, `#${authData}`);
|
|
|
|
}
|
|
|
|
}, []);
|
2016-03-04 00:27:33 +03:00
|
|
|
|
2024-12-10 20:42:06 +01:00
|
|
|
if (!client || !oauth) {
|
|
|
|
return <Redirect to="/" />;
|
|
|
|
}
|
2016-03-16 06:46:44 +02:00
|
|
|
|
2024-12-10 20:42:06 +01:00
|
|
|
return (
|
|
|
|
<div className={styles.finishPage}>
|
|
|
|
{authData && <Helmet title={authData} />}
|
|
|
|
|
|
|
|
{oauth.success ? (
|
|
|
|
<div>
|
|
|
|
<div className={styles.successBackground} />
|
|
|
|
<div className={styles.greenTitle}>
|
|
|
|
<Message
|
|
|
|
key="authForAppSuccessful"
|
|
|
|
defaultMessage="Authorization for {appName} was successfully completed"
|
|
|
|
values={{
|
|
|
|
appName: <span className={styles.appName}>{client.name}</span>,
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
{oauth.displayCode ? (
|
|
|
|
<div data-testid="oauth-code-container">
|
2020-05-24 02:08:24 +03:00
|
|
|
<div className={styles.description}>
|
2020-06-04 19:41:27 +03:00
|
|
|
<Message
|
2024-12-10 20:42:06 +01:00
|
|
|
key="passCodeToApp"
|
|
|
|
defaultMessage="To complete authorization process, please, provide the following code to {appName}"
|
|
|
|
values={{ appName: client.name }}
|
2020-06-04 19:41:27 +03:00
|
|
|
/>
|
2020-05-24 02:08:24 +03:00
|
|
|
</div>
|
2024-12-10 20:42:06 +01:00
|
|
|
<div className={styles.codeContainer}>
|
|
|
|
<div className={styles.code}>{oauth.code}</div>
|
|
|
|
</div>
|
|
|
|
<Button color="green" small onClick={onCopyClick}>
|
|
|
|
<Message key="copy" defaultMessage="Copy" />
|
|
|
|
</Button>
|
2020-05-24 02:08:24 +03:00
|
|
|
</div>
|
2024-12-10 20:42:06 +01:00
|
|
|
) : (
|
2020-05-24 02:08:24 +03:00
|
|
|
<div className={styles.description}>
|
2020-06-04 19:41:27 +03:00
|
|
|
<Message
|
|
|
|
key="waitAppReaction"
|
|
|
|
defaultMessage="Please, wait till your application response"
|
|
|
|
/>
|
2020-05-24 02:08:24 +03:00
|
|
|
</div>
|
2024-12-10 20:42:06 +01:00
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
) : (
|
|
|
|
<div>
|
|
|
|
<div className={styles.failBackground} />
|
|
|
|
<div className={styles.redTitle}>
|
|
|
|
<Message
|
|
|
|
key="authForAppFailed"
|
|
|
|
defaultMessage="Authorization for {appName} was failed"
|
|
|
|
values={{
|
|
|
|
appName: <span className={styles.appName}>{client.name}</span>,
|
|
|
|
}}
|
|
|
|
/>
|
2020-05-24 02:08:24 +03:00
|
|
|
</div>
|
2024-12-10 20:42:06 +01:00
|
|
|
<div className={styles.description}>
|
|
|
|
<Message key="waitAppReaction" defaultMessage="Please, wait till your application response" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
2019-12-07 13:28:52 +02:00
|
|
|
|
2024-12-10 20:42:06 +01:00
|
|
|
export default Finish;
|