12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- /*
- * @Author: your name
- * @Date: 2021-09-03 14:28:27
- * @LastEditTime: 2021-09-29 18:32:49
- * @LastEditors: Please set LastEditors
- * @Description: In User Settings Edit
- * @FilePath: /MedicalWisdomCheckSys/src/components/RightContent/AvatarDropdown.tsx
- */
- import React, { useCallback } from 'react';
- import { LogoutOutlined, SettingOutlined, UserOutlined } from '@ant-design/icons';
- import { Avatar, Menu, Spin } from 'antd';
- import { history, useModel } from 'umi';
- import HeaderDropdown from '../HeaderDropdown';
- import styles from './index.less';
- // import { outLogin } from '@/services/ant-design-pro/api';
- import type { MenuInfo } from 'rc-menu/lib/interface';
- import {loginOut} from '@/utils';
- export type GlobalHeaderRightProps = {
- menu?: boolean;
- };
- const AvatarDropdown: React.FC<GlobalHeaderRightProps> = ({ menu }) => {
- const { initialState, setInitialState } = useModel('@@initialState');
- const onMenuClick = useCallback(
- (event: MenuInfo) => {
- const { key } = event;
- if (key === 'logout') {
- setInitialState((s) => ({ ...s, currentUser: undefined }));
- localStorage.removeItem('userData');
- loginOut();
- return;
- }
- history.push(`/account/${key}`);
- },
- [setInitialState],
- );
- const loading = (
- <span className={`${styles.action} ${styles.account}`}>
- <Spin
- size="small"
- style={{
- marginLeft: 8,
- marginRight: 8,
- }}
- />
- </span>
- );
- if (!initialState) {
- return loading;
- }
- const { currentUser } = initialState;
- if (!currentUser || !currentUser.name) {
- return loading;
- }
- const menuHeaderDropdown = (
- <Menu className={styles.menu} selectedKeys={[]} onClick={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 (
- <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>
- );
- };
- export default AvatarDropdown;
|