1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- import { LogoutOutlined, SettingOutlined, UserOutlined } from '@ant-design/icons'
- import { Avatar, Menu, Spin } from 'antd'
- import React from 'react'
- import { history, connect } 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
- }
- history.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">
- <UserOutlined />
- 个人中心
- </Menu.Item>
- )}
- {menu && (
- <Menu.Item key="settings">
- <SettingOutlined />
- 个人设置
- </Menu.Item>
- )}
- {menu && <Menu.Divider />}
- <Menu.Item key="logout">
- <LogoutOutlined />
- 退出登录
- </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} anticon`}>{currentUser.name}</span>
- </span>
- </HeaderDropdown>
- ) : (
- <span className={`${styles.action} ${styles.account}`}>
- <Spin
- size="small"
- style={{
- marginLeft: 8,
- marginRight: 8
- }}
- />
- </span>
- )
- }
- }
- export default connect(({ user }) => ({
- currentUser: user.currentUser
- }))(AvatarDropdown)
|