2019-12-07 13:28:52 +02:00
|
|
|
import React from 'react';
|
2019-12-07 21:43:08 +02:00
|
|
|
import clsx from 'clsx';
|
2018-03-25 22:16:45 +03:00
|
|
|
import { FormattedMessage as Message } from 'react-intl';
|
|
|
|
import { Helmet } from 'react-helmet';
|
2019-12-07 21:02:00 +02:00
|
|
|
import { LinkButton } from 'app/components/ui/form';
|
|
|
|
import { COLOR_GREEN, COLOR_BLUE } from 'app/components/ui';
|
|
|
|
import { ContactLink } from 'app/components/contact';
|
|
|
|
import { OauthAppResponse } from 'app/services/api/oauth';
|
2018-03-25 22:16:45 +03:00
|
|
|
|
|
|
|
import styles from './applicationsIndex.scss';
|
|
|
|
import messages from './ApplicationsIndex.intl.json';
|
|
|
|
import cubeIcon from './icons/cube.svg';
|
|
|
|
import loadingCubeIcon from './icons/loading-cube.svg';
|
|
|
|
import toolsIcon from './icons/tools.svg';
|
2018-11-04 07:31:31 +02:00
|
|
|
import ApplicationsList from './list';
|
2018-03-25 22:16:45 +03:00
|
|
|
|
|
|
|
type Props = {
|
2019-12-07 13:28:52 +02:00
|
|
|
clientId: string | null;
|
|
|
|
resetClientId: () => void; // notify parent to remove clientId from current location.href
|
|
|
|
displayForGuest: boolean;
|
|
|
|
applications: Array<OauthAppResponse>;
|
|
|
|
isLoading: boolean;
|
|
|
|
deleteApp: (clientId: string) => Promise<any>;
|
|
|
|
resetApp: (clientId: string, resetClientSecret: boolean) => Promise<any>;
|
2018-03-25 22:16:45 +03:00
|
|
|
};
|
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
export default class ApplicationsIndex extends React.Component<Props> {
|
2019-11-27 11:03:32 +02:00
|
|
|
render() {
|
|
|
|
return (
|
|
|
|
<div className={styles.container}>
|
|
|
|
<div className={styles.welcomeContainer}>
|
|
|
|
<Message {...messages.accountsForDevelopers}>
|
|
|
|
{(pageTitle: string) => (
|
|
|
|
<h2 className={styles.welcomeTitle}>
|
|
|
|
<Helmet title={pageTitle} />
|
|
|
|
{pageTitle}
|
|
|
|
</h2>
|
|
|
|
)}
|
|
|
|
</Message>
|
|
|
|
<div className={styles.welcomeTitleDelimiter} />
|
|
|
|
<div className={styles.welcomeParagraph}>
|
|
|
|
<Message
|
|
|
|
{...messages.accountsAllowsYouYoUseOauth2}
|
|
|
|
values={{
|
|
|
|
ourDocumentation: (
|
|
|
|
<a href="https://docs.ely.by/en/oauth.html" target="_blank">
|
|
|
|
<Message {...messages.ourDocumentation} />
|
|
|
|
</a>
|
|
|
|
),
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div className={styles.welcomeParagraph}>
|
|
|
|
<Message
|
|
|
|
{...messages.ifYouHaveAnyTroubles}
|
|
|
|
values={{
|
|
|
|
feedback: (
|
|
|
|
<ContactLink>
|
|
|
|
<Message {...messages.feedback} />
|
|
|
|
</ContactLink>
|
|
|
|
),
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</div>
|
2018-03-25 22:16:45 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
{this.getContent()}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2018-11-04 07:31:31 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
getContent() {
|
|
|
|
const {
|
|
|
|
displayForGuest,
|
|
|
|
applications,
|
|
|
|
isLoading,
|
|
|
|
resetApp,
|
|
|
|
deleteApp,
|
|
|
|
clientId,
|
|
|
|
resetClientId,
|
|
|
|
} = this.props;
|
2019-01-24 02:34:02 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
if (applications.length > 0) {
|
|
|
|
return (
|
|
|
|
<ApplicationsList
|
|
|
|
applications={applications}
|
|
|
|
resetApp={resetApp}
|
|
|
|
deleteApp={deleteApp}
|
|
|
|
clientId={clientId}
|
|
|
|
resetClientId={resetClientId}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
2018-11-04 07:31:31 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
if (displayForGuest) {
|
|
|
|
return <Guest />;
|
2018-11-04 07:31:31 +02:00
|
|
|
}
|
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
return <Loader noApps={!isLoading} />;
|
|
|
|
}
|
|
|
|
}
|
2019-01-14 22:52:42 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
function Loader({ noApps }: { noApps: boolean }) {
|
|
|
|
return (
|
|
|
|
<div className={styles.emptyState} data-e2e={noApps ? 'noApps' : 'loading'}>
|
|
|
|
<img
|
|
|
|
src={noApps ? cubeIcon : loadingCubeIcon}
|
|
|
|
className={styles.emptyStateIcon}
|
|
|
|
/>
|
2019-01-14 22:52:42 +02:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
<div
|
2019-12-07 21:43:08 +02:00
|
|
|
className={clsx(styles.noAppsContainer, {
|
2019-11-27 11:03:32 +02:00
|
|
|
[styles.noAppsAnimating]: noApps,
|
|
|
|
})}
|
|
|
|
>
|
|
|
|
<div className={styles.emptyStateText}>
|
|
|
|
<div>
|
|
|
|
<Message {...messages.youDontHaveAnyApplication} />
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<Message {...messages.shallWeStart} />
|
|
|
|
</div>
|
2018-11-04 07:31:31 +02:00
|
|
|
</div>
|
2019-11-27 11:03:32 +02:00
|
|
|
|
|
|
|
<LinkButton
|
|
|
|
to="/dev/applications/new"
|
|
|
|
data-e2e="newApp"
|
|
|
|
label={messages.addNew}
|
|
|
|
color={COLOR_GREEN}
|
|
|
|
className={styles.emptyStateActionButton}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
2018-11-04 07:31:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function Guest() {
|
2019-11-27 11:03:32 +02:00
|
|
|
return (
|
|
|
|
<div className={styles.emptyState}>
|
|
|
|
<img src={toolsIcon} className={styles.emptyStateIcon} />
|
|
|
|
<div className={styles.emptyStateText}>
|
|
|
|
<div>
|
|
|
|
<Message {...messages.weDontKnowAnythingAboutYou} />
|
2018-11-04 07:31:31 +02:00
|
|
|
</div>
|
2019-11-27 11:03:32 +02:00
|
|
|
<div>
|
|
|
|
<Message {...messages.youMustAuthToBegin} />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<LinkButton
|
|
|
|
to="/login"
|
|
|
|
label={messages.authorization}
|
|
|
|
color={COLOR_BLUE}
|
|
|
|
className={styles.emptyStateActionButton}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
);
|
2018-11-04 07:31:31 +02:00
|
|
|
}
|