import { LogoutOutlined, SettingOutlined, UserOutlined } from '@ant-design/icons'; import { Avatar, Menu, Spin } from 'antd'; import { ClickParam } from 'antd/es/menu'; import React from 'react'; import { history, ConnectProps, connect } from 'umi'; import { ConnectState } from '@/models/connect'; import { CurrentUser } from '@/models/user'; import HeaderDropdown from '../HeaderDropdown'; import styles from './index.less'; export interface GlobalHeaderRightProps extends Partial { currentUser?: CurrentUser; menu?: boolean; } class AvatarDropdown extends React.Component { onMenuClick = (event: ClickParam) => { const { key } = event; if (key === 'logout') { const { dispatch } = this.props; if (dispatch) { dispatch({ type: 'login/logout', }); } return; } history.push(`/account/${key}`); }; render(): React.ReactNode { const { currentUser = { avatar: '', userName: '', }, menu, } = this.props; const menuHeaderDropdown = ( {menu && ( 个人中心 )} {menu && ( 个人设置 )} {menu && } 退出登录 ); return currentUser && currentUser.userName ? ( {currentUser.userName} ) : ( ); } } export default connect(({ user }: ConnectState) => ({ currentUser: user.currentUser, }))(AvatarDropdown);