import { LogoutOutlined, SettingOutlined, UserOutlined } from '@ant-design/icons'; import { Avatar, Menu, Spin } from 'antd'; 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: { key: React.Key; keyPath: React.Key[]; item: React.ReactInstance; domEvent: React.MouseEvent; }) => { 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: '', name: '', }, menu, } = this.props; const menuHeaderDropdown = ( 个人中心 个人设置 退出登录 ); return currentUser && currentUser.name ? ( {currentUser.name} ) : ( ); } } export default connect(({ user }: ConnectState) => ({ currentUser: user.currentUser, }))(AvatarDropdown);