2019-12-07 13:28:52 +02:00
import React from 'react' ;
2019-12-07 21:43:08 +02:00
import clsx from 'clsx' ;
2020-06-04 19:41:27 +03:00
import { defineMessages , 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 { 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 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
2020-06-04 19:41:27 +03:00
const labels = defineMessages ( {
addNew : 'Add new' ,
} ) ;
2018-03-25 22:16:45 +03:00
type Props = {
2020-05-24 02:08:24 +03: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 > {
2020-05-24 02:08:24 +03:00
render() {
return (
< div className = { styles . container } >
< div className = { styles . welcomeContainer } >
2020-06-04 19:41:27 +03:00
< Message key = "accountsForDevelopers" defaultMessage = "Ely.by Accounts for developers" >
2020-05-24 02:08:24 +03:00
{ ( pageTitle : string ) = > (
< h2 className = { styles . welcomeTitle } >
< Helmet title = { pageTitle } / >
{ pageTitle }
< / h2 >
) }
< / Message >
< div className = { styles . welcomeTitleDelimiter } / >
< div className = { styles . welcomeParagraph } >
< Message
2020-06-04 19:41:27 +03:00
key = "accountsAllowsYouYoUseOauth2"
defaultMessage = "Ely.by Accounts service provides users with a quick and easy-to-use way to login to your site, launcher or Minecraft server via OAuth2 authorization protocol. You can find more information about integration with Ely.by Accounts in {ourDocumentation}."
2020-05-24 02:08:24 +03:00
values = { {
ourDocumentation : (
< a href = "https://docs.ely.by/en/oauth.html" target = "_blank" >
2020-06-04 19:41:27 +03:00
< Message key = "ourDocumentation" defaultMessage = "our documentation" / >
2020-05-24 02:08:24 +03:00
< / a >
) ,
} }
/ >
< / div >
< div className = { styles . welcomeParagraph } >
< Message
2020-06-04 19:41:27 +03:00
key = "ifYouHaveAnyTroubles"
defaultMessage = "If you are experiencing difficulties, you can always use {feedback}. We'll surely help you."
2020-05-24 02:08:24 +03:00
values = { {
feedback : (
< ContactLink >
2020-06-04 19:41:27 +03:00
< Message key = "feedback" defaultMessage = "feedback" / >
2020-05-24 02:08:24 +03:00
< / ContactLink >
) ,
} }
/ >
< / div >
< / div >
2018-03-25 22:16:45 +03:00
2020-05-24 02:08:24 +03:00
{ this . getContent ( ) }
< / div >
) ;
}
2018-11-04 07:31:31 +02:00
2020-05-24 02:08:24 +03:00
getContent() {
const { displayForGuest , applications , isLoading , resetApp , deleteApp , clientId , resetClientId } = this . props ;
2019-01-24 02:34:02 +03:00
2020-05-24 02:08:24 +03: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
2020-05-24 02:08:24 +03:00
if ( displayForGuest ) {
return < Guest / > ;
}
2018-11-04 07:31:31 +02:00
2020-05-24 02:08:24 +03:00
return < Loader noApps = { ! isLoading } / > ;
}
2019-11-27 11:03:32 +02:00
}
2019-01-14 22:52:42 +02:00
2019-11-27 11:03:32 +02:00
function Loader ( { noApps } : { noApps : boolean } ) {
2020-05-24 02:08:24 +03:00
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
2020-05-24 02:08:24 +03:00
< div
className = { clsx ( styles . noAppsContainer , {
[ styles . noAppsAnimating ] : noApps ,
} ) }
>
< div className = { styles . emptyStateText } >
< div >
2020-06-04 19:41:27 +03:00
< Message
key = "youDontHaveAnyApplication"
defaultMessage = "You don't have any app registered yet."
/ >
2020-05-24 02:08:24 +03:00
< / div >
< div >
2020-06-04 19:41:27 +03:00
< Message key = "shallWeStart" defaultMessage = "Shall we start?" / >
2020-05-24 02:08:24 +03:00
< / div >
< / div >
2019-11-27 11:03:32 +02:00
2020-05-24 02:08:24 +03:00
< LinkButton
to = "/dev/applications/new"
data - e2e = "newApp"
color = { COLOR_GREEN }
className = { styles . emptyStateActionButton }
2020-07-22 14:20:10 +03:00
>
< Message { ...labels.addNew } / >
< / LinkButton >
2020-05-24 02:08:24 +03:00
< / div >
< / div >
) ;
2018-11-04 07:31:31 +02:00
}
function Guest() {
2020-05-24 02:08:24 +03:00
return (
< div className = { styles . emptyState } >
< img src = { toolsIcon } className = { styles . emptyStateIcon } / >
< div className = { styles . emptyStateText } >
< div >
2020-06-04 19:41:27 +03:00
< Message key = "weDontKnowAnythingAboutYou" defaultMessage = "We don't know anything about you yet." / >
2020-05-24 02:08:24 +03:00
< / div >
< div >
2020-06-04 19:41:27 +03:00
< Message key = "youMustAuthToBegin" defaultMessage = "You have to authorize to start." / >
2020-05-24 02:08:24 +03:00
< / div >
< / div >
2019-11-27 11:03:32 +02:00
2020-07-22 14:20:10 +03:00
< LinkButton to = "/login" color = { COLOR_BLUE } className = { styles . emptyStateActionButton } >
< Message key = "authorization" defaultMessage = "Authorization" / >
< / LinkButton >
2020-05-24 02:08:24 +03:00
< / div >
) ;
2018-11-04 07:31:31 +02:00
}