2016-11-05 22:23:56 +02:00
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
import { FormattedMessage as Message } from 'react-intl';
|
|
|
|
|
2019-12-07 21:02:00 +02:00
|
|
|
import BaseAuthBody from 'app/components/auth/BaseAuthBody';
|
|
|
|
import { AccountSwitcher } from 'app/components/accounts';
|
2020-01-17 23:37:52 +03:00
|
|
|
import { Account } from 'app/components/accounts/reducer';
|
2016-11-05 22:23:56 +02:00
|
|
|
|
|
|
|
import styles from './chooseAccount.scss';
|
|
|
|
import messages from './ChooseAccount.intl.json';
|
|
|
|
|
|
|
|
export default class ChooseAccountBody extends BaseAuthBody {
|
2019-11-27 11:03:32 +02:00
|
|
|
static displayName = 'ChooseAccountBody';
|
|
|
|
static panelId = 'chooseAccount';
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const { client } = this.context.auth;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
{this.renderErrors()}
|
|
|
|
|
|
|
|
<div className={styles.description}>
|
|
|
|
{client ? (
|
|
|
|
<Message
|
|
|
|
{...messages.pleaseChooseAccountForApp}
|
|
|
|
values={{
|
|
|
|
appName: <span className={styles.appName}>{client.name}</span>,
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
) : (
|
|
|
|
<div className={styles.description}>
|
|
|
|
<Message {...messages.pleaseChooseAccount} />
|
2016-11-05 22:23:56 +02:00
|
|
|
</div>
|
2019-11-27 11:03:32 +02:00
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className={styles.accountSwitcherContainer}>
|
|
|
|
<AccountSwitcher
|
|
|
|
allowAdd={false}
|
|
|
|
allowLogout={false}
|
|
|
|
highlightActiveAccount={false}
|
|
|
|
onSwitch={this.onSwitch}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-01-17 23:37:52 +03:00
|
|
|
onSwitch = (account: Account): void => {
|
2019-11-27 11:03:32 +02:00
|
|
|
this.context.resolve(account);
|
|
|
|
};
|
2016-11-05 22:23:56 +02:00
|
|
|
}
|