2016-11-05 22:23:56 +02:00
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
import { FormattedMessage as Message } from 'react-intl';
|
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
import { connect } from 'app/functions';
|
2019-12-07 21:02:00 +02:00
|
|
|
import BaseAuthBody from 'app/components/auth/BaseAuthBody';
|
2020-10-27 01:46:57 +03:00
|
|
|
import { getSortedAccounts } from 'app/components/accounts/reducer';
|
2020-10-23 01:23:59 +03:00
|
|
|
import type { Account } from 'app/components/accounts';
|
2016-11-05 22:23:56 +02:00
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
import AccountSwitcher from './AccountSwitcher';
|
2016-11-05 22:23:56 +02:00
|
|
|
import styles from './chooseAccount.scss';
|
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
// I can't connect the ChooseAccountBody component with redux's "connect" function
|
|
|
|
// to get accounts list because it will break the TransitionMotion animation implementation.
|
|
|
|
//
|
|
|
|
// So to provide accounts list to the component, I'll create connected version of
|
|
|
|
// the composes with already provided accounts list
|
|
|
|
const ConnectedAccountSwitcher = connect((state) => ({
|
2020-10-27 01:46:57 +03:00
|
|
|
accounts: getSortedAccounts(state),
|
2020-10-23 01:23:59 +03:00
|
|
|
}))(AccountSwitcher);
|
|
|
|
|
2016-11-05 22:23:56 +02:00
|
|
|
export default class ChooseAccountBody extends BaseAuthBody {
|
2020-05-24 02:08:24 +03:00
|
|
|
static displayName = 'ChooseAccountBody';
|
|
|
|
static panelId = 'chooseAccount';
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const { client } = this.context.auth;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
{this.renderErrors()}
|
|
|
|
|
|
|
|
<div className={styles.description}>
|
|
|
|
{client ? (
|
|
|
|
<Message
|
2020-06-04 19:41:27 +03:00
|
|
|
key="pleaseChooseAccountForApp"
|
|
|
|
defaultMessage="Please select an account that you want to use to authorize {appName}"
|
2020-05-24 02:08:24 +03:00
|
|
|
values={{
|
|
|
|
appName: <span className={styles.appName}>{client.name}</span>,
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
) : (
|
2020-10-23 01:23:59 +03:00
|
|
|
<Message
|
|
|
|
key="pleaseChooseAccount"
|
|
|
|
defaultMessage="Please select an account you're willing to use"
|
|
|
|
/>
|
2020-05-24 02:08:24 +03:00
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className={styles.accountSwitcherContainer}>
|
2020-10-23 01:23:59 +03:00
|
|
|
<ConnectedAccountSwitcher onAccountClick={this.onSwitch} />
|
2020-05-24 02:08:24 +03:00
|
|
|
</div>
|
2016-11-05 22:23:56 +02:00
|
|
|
</div>
|
2020-05-24 02:08:24 +03:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
onSwitch = (account: Account): Promise<void> => {
|
|
|
|
return Promise.resolve(this.context.resolve(account));
|
2020-05-24 02:08:24 +03:00
|
|
|
};
|
2016-11-05 22:23:56 +02:00
|
|
|
}
|