12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- import { Avatar, Icon, Menu, Spin } from 'antd';
- import { FormattedMessage } from 'umi-plugin-react/locale';
- import React from 'react';
- import { connect } from 'dva';
- import { router } from 'umi';
- import HeaderDropdown from '../HeaderDropdown';
- import styles from './index.less';
-
- class AvatarDropdown extends React.Component {
- onMenuClick = (event) => {
- const { key } = event;
-
- if (key === 'logout') {
- const { dispatch } = this.props;
-
- if (dispatch) {
- dispatch({
- type: 'login/logout',
- });
- }
-
- return;
- }
-
- router.push(`/account/${key}`);
- };
-
- render() {
- const {
- currentUser = {
- avatar: '',
- name: '',
- },
- menu,
- } = this.props;
- const menuHeaderDropdown = (
- <Menu className={styles.menu} selectedKeys={[]} onClick={this.onMenuClick}>
- {menu && (
- <Menu.Item key="center">
- <Icon type="user" />
- <FormattedMessage id="menu.account.center" defaultMessage="account center" />
- </Menu.Item>
- )}
- {menu && (
- <Menu.Item key="settings">
- <Icon type="setting" />
- <FormattedMessage id="menu.account.settings" defaultMessage="account settings" />
- </Menu.Item>
- )}
- {menu && <Menu.Divider />}
-
- <Menu.Item key="logout">
- <Icon type="logout" />
- <FormattedMessage id="menu.account.logout" defaultMessage="logout" />
- </Menu.Item>
- </Menu>
- );
- return currentUser && currentUser.name ? (
- <HeaderDropdown overlay={menuHeaderDropdown}>
- <span className={`${styles.action} ${styles.account}`}>
- <Avatar size="small" className={styles.avatar} src={currentUser.avatar} alt="avatar" />
- <span className={styles.name}>{currentUser.name}</span>
- </span>
- </HeaderDropdown>
- ) : (
- <Spin
- size="small"
- style={{
- marginLeft: 8,
- marginRight: 8,
- }}
- />
- );
- }
- }
-
- export default connect(({ user }) => ({
- currentUser: user.currentUser,
- }))(AvatarDropdown);
|