1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- 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 { stringify } from 'querystring';
- import HeaderDropdown from '../HeaderDropdown';
- import styles from './index.less';
- import { outLogin } from '@/services/ant-design-pro/api';
-
- /**
- * 退出登录,并且将当前的 url 保存
- */
- const loginOut = async () => {
- await outLogin();
- const { query = {}, search, pathname } = history.location;
- const { redirect } = query; // Note: There may be security issues, please note
-
- if (window.location.pathname !== '/user/login' && !redirect) {
- history.replace({
- pathname: '/user/login',
- search: stringify({
- redirect: pathname + search,
- }),
- });
- }
- };
-
- const AvatarDropdown = ({ menu }) => {
- const { initialState, setInitialState } = useModel('@@initialState');
- const onMenuClick = useCallback(
- (event) => {
- const { key } = event;
-
- if (key === 'logout') {
- setInitialState((s) => ({ ...s, currentUser: undefined }));
- 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;
|