2020-10-23 01:23:59 +03:00
|
|
|
import React, { ComponentType, useCallback, useState } from 'react';
|
2019-12-07 21:43:08 +02:00
|
|
|
import clsx from 'clsx';
|
2020-10-23 01:23:59 +03:00
|
|
|
import ClickAwayListener from 'react-click-away-listener';
|
2016-11-05 12:57:01 +02:00
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
import { Account } from 'app/components/accounts';
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
import AccountSwitcher from './AccountSwitcher';
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
import styles from './loggedInPanel.scss';
|
2016-11-11 09:39:01 +02:00
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
interface Props {
|
|
|
|
activeAccount: Account;
|
|
|
|
accounts: ReadonlyArray<Account>;
|
|
|
|
onSwitchAccount?: (account: Account) => Promise<any>;
|
|
|
|
onRemoveAccount?: (account: Account) => Promise<any>;
|
|
|
|
}
|
2017-07-12 21:30:05 +03:00
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
const LoggedInPanel: ComponentType<Props> = ({ activeAccount, accounts, onSwitchAccount, onRemoveAccount }) => {
|
|
|
|
const [isAccountSwitcherActive, setAccountSwitcherState] = useState(false);
|
|
|
|
const hideAccountSwitcher = useCallback(() => setAccountSwitcherState(false), []);
|
|
|
|
const onAccountClick = useCallback(
|
|
|
|
async (account: Account) => {
|
|
|
|
if (onSwitchAccount) {
|
|
|
|
await onSwitchAccount(account);
|
|
|
|
}
|
2016-11-11 09:39:01 +02:00
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
setAccountSwitcherState(false);
|
|
|
|
},
|
|
|
|
[onSwitchAccount],
|
|
|
|
);
|
2020-05-24 02:08:24 +03:00
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
return (
|
|
|
|
<div className={styles.loggedInPanel}>
|
|
|
|
<div
|
|
|
|
className={clsx(styles.activeAccount, {
|
|
|
|
[styles.activeAccountExpanded]: isAccountSwitcherActive,
|
|
|
|
})}
|
|
|
|
>
|
|
|
|
<ClickAwayListener onClickAway={hideAccountSwitcher}>
|
|
|
|
<button
|
|
|
|
className={styles.activeAccountButton}
|
|
|
|
onClick={setAccountSwitcherState.bind(null, !isAccountSwitcherActive)}
|
|
|
|
>
|
2020-05-24 02:08:24 +03:00
|
|
|
<span className={styles.userIcon} />
|
2020-10-23 01:23:59 +03:00
|
|
|
<span className={styles.userName}>{activeAccount.username}</span>
|
2020-05-24 02:08:24 +03:00
|
|
|
<span className={styles.expandIcon} />
|
|
|
|
</button>
|
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
<div className={styles.accountSwitcherContainer}>
|
|
|
|
<AccountSwitcher
|
|
|
|
activeAccount={activeAccount}
|
|
|
|
accounts={accounts}
|
|
|
|
onAccountClick={onAccountClick}
|
|
|
|
onRemoveClick={onRemoveAccount}
|
|
|
|
onLoginClick={hideAccountSwitcher}
|
|
|
|
/>
|
2020-05-24 02:08:24 +03:00
|
|
|
</div>
|
2020-10-23 01:23:59 +03:00
|
|
|
</ClickAwayListener>
|
2020-05-24 02:08:24 +03:00
|
|
|
</div>
|
2020-10-23 01:23:59 +03:00
|
|
|
</div>
|
2020-05-24 02:08:24 +03:00
|
|
|
);
|
2020-10-23 01:23:59 +03:00
|
|
|
};
|
2016-11-11 09:39:01 +02:00
|
|
|
|
2020-10-23 01:23:59 +03:00
|
|
|
export default LoggedInPanel;
|