12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- 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<ConnectProps> {
- currentUser?: CurrentUser;
- menu?: boolean;
- }
- class AvatarDropdown extends React.Component<GlobalHeaderRightProps> {
- 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 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.userName ? (
- <HeaderDropdown overlay={menuHeaderDropdown}>
- <span className={`${styles.action} ${styles.account}`}>
- <Avatar size="small" className={styles.avatar} src="/avatar.png" alt="avatar" />
- <span className={styles.name}>{currentUser.userName}</span>
- </span>
- </HeaderDropdown>
- ) : (
- <span className={`${styles.action} ${styles.account}`}>
- <Spin
- size="small"
- style={{
- marginLeft: 8,
- marginRight: 8,
- }}
- />
- </span>
- );
- }
- }
- export default connect(({ user }: ConnectState) => ({
- currentUser: user.currentUser,
- }))(AvatarDropdown);
|