2023-02-10 14:06:55 +08:00
|
|
|
|
import { Avatar, Dropdown, Menu, message, Modal } from 'antd';
|
|
|
|
|
import { DownOutlined, UserOutlined, UserSwitchOutlined, CarryOutOutlined, HomeOutlined, ImportOutlined } from '@ant-design/icons';
|
2022-03-10 14:24:13 +08:00
|
|
|
|
import React, { useEffect } from 'react';
|
|
|
|
|
import moment from 'moment'
|
|
|
|
|
import { connect, history } from 'umi';
|
2020-12-23 11:14:35 +08:00
|
|
|
|
import { ConnectState } from '@/models/connect';
|
2022-03-10 14:24:13 +08:00
|
|
|
|
import logo from '../../assets/logo.svg';
|
|
|
|
|
import './index.less';
|
2023-02-10 14:06:55 +08:00
|
|
|
|
import { getMenu, getLogout } from './services'
|
2022-03-10 14:24:13 +08:00
|
|
|
|
import { getSessionUserData } from "@/utils/session";
|
2020-12-23 11:14:35 +08:00
|
|
|
|
|
2022-03-10 14:24:13 +08:00
|
|
|
|
const GlobalHeaderRight: React.FC<{}> = (props) => {
|
|
|
|
|
// let className = styles.right;
|
|
|
|
|
let data = getSessionUserData();
|
|
|
|
|
const [dataMenu, setDataMenu] = React.useState<any>([]);
|
2023-02-10 14:06:55 +08:00
|
|
|
|
const handelRole = (item: any) => {
|
2022-03-10 14:24:13 +08:00
|
|
|
|
sessionStorage.setItem('roleData', JSON.stringify(item));
|
|
|
|
|
sessionStorage.setItem('roleAuthority', JSON.stringify([item.roleCode]));
|
|
|
|
|
let params = {
|
2023-02-10 14:06:55 +08:00
|
|
|
|
roleIdList: [item.roleId]
|
2022-03-10 14:24:13 +08:00
|
|
|
|
}
|
|
|
|
|
history.push('/Dashboard')
|
|
|
|
|
window.location.reload()
|
2023-02-10 14:06:55 +08:00
|
|
|
|
getMenu(params).then(res => {
|
|
|
|
|
if (res?.code == 1) {
|
2022-03-10 14:24:13 +08:00
|
|
|
|
setDataMenu(res?.data)
|
2023-02-10 14:06:55 +08:00
|
|
|
|
} else {
|
2022-03-10 14:24:13 +08:00
|
|
|
|
message.error("数据错误请联系管理员")
|
|
|
|
|
}
|
|
|
|
|
})
|
2020-12-23 11:14:35 +08:00
|
|
|
|
}
|
2023-02-10 14:06:55 +08:00
|
|
|
|
//角色退出登录
|
|
|
|
|
const toLogout = () => {
|
|
|
|
|
let _data = {
|
2022-03-10 14:24:13 +08:00
|
|
|
|
mall3_token: sessionStorage.getItem('Authorization')
|
|
|
|
|
}
|
2023-02-10 14:06:55 +08:00
|
|
|
|
Modal.info({
|
|
|
|
|
title: '请确认是否退出?',
|
|
|
|
|
content: false,
|
|
|
|
|
onOk() {
|
|
|
|
|
getLogout({ ..._data }).then((res) => {
|
|
|
|
|
if (res?.success) {
|
|
|
|
|
if (data?.userType == "0") {//联通智慧门户
|
|
|
|
|
window.close();
|
|
|
|
|
} else if (data?.userType == "1") {//合作方
|
|
|
|
|
window.close();
|
|
|
|
|
} else if (data?.userType == "2") {//专家
|
|
|
|
|
window.location.href = "/userformal/login"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
closable: true,
|
|
|
|
|
centered: true,
|
|
|
|
|
okText: "确认退出",
|
|
|
|
|
className: "layout-modal-logout",
|
|
|
|
|
});
|
2022-03-10 14:24:13 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const droMenu = (
|
2023-02-10 14:06:55 +08:00
|
|
|
|
<Menu style={{ top: "17px" }}>
|
2022-03-10 14:24:13 +08:00
|
|
|
|
{data?.authorityList != undefined ?
|
2023-02-10 14:06:55 +08:00
|
|
|
|
data?.authorityList?.map((item: any, index: any) => (
|
2022-03-10 14:24:13 +08:00
|
|
|
|
<Menu.Item key={index}>
|
2023-02-10 14:06:55 +08:00
|
|
|
|
<a target="_blank" rel="noopener noreferrer" onClick={() => handelRole(item)}>{item.roleName}</a>
|
|
|
|
|
</Menu.Item>
|
2022-03-10 14:24:13 +08:00
|
|
|
|
)) : null}
|
2023-02-10 14:06:55 +08:00
|
|
|
|
<>
|
2022-03-10 14:24:13 +08:00
|
|
|
|
<Menu.Divider />
|
|
|
|
|
<Menu.Item key="exit">
|
2023-02-10 14:06:55 +08:00
|
|
|
|
<a key="1" onClick={() => toLogout()}>退出登录</a>
|
2022-03-10 14:24:13 +08:00
|
|
|
|
</Menu.Item>
|
2023-02-10 14:06:55 +08:00
|
|
|
|
</>
|
2022-03-10 14:24:13 +08:00
|
|
|
|
</Menu>
|
|
|
|
|
);
|
2020-12-23 11:14:35 +08:00
|
|
|
|
|
|
|
|
|
return (
|
2022-03-10 14:24:13 +08:00
|
|
|
|
<div className="top-menu">
|
|
|
|
|
<div className="left-logo">
|
2023-02-10 14:06:55 +08:00
|
|
|
|
<img src={logo} alt="" />中国联通智慧供应链平台 | 招标采购中心
|
2022-03-10 14:24:13 +08:00
|
|
|
|
</div>
|
|
|
|
|
<ul className="right-btns">
|
|
|
|
|
{/* <li><ImportOutlined /><a onClick={()=>window.open(REACT_APP_MALL_V2_URL)}>交易平台2.0</a></li> */}
|
2023-02-10 14:06:55 +08:00
|
|
|
|
<li><HomeOutlined /><a onClick={() => history.push('/Dashboard')}>首页</a></li>
|
2022-03-10 14:24:13 +08:00
|
|
|
|
<li><CarryOutOutlined />{moment().format("YYYY-MM-DD")}</li>
|
|
|
|
|
{data?.organizationName == null ? null : (<li><UserSwitchOutlined />{data?.organizationName}</li>)}
|
|
|
|
|
<li>
|
2023-02-10 14:06:55 +08:00
|
|
|
|
<Avatar size="small" src="https://gw.alipayobjects.com/zos/antfincdn/XAosXuNZyF/BiazfanxmamNRoxxVxka.png" style={{ width: '30px' }} />
|
2022-03-10 14:24:13 +08:00
|
|
|
|
<Dropdown overlay={droMenu}>
|
2023-02-10 14:06:55 +08:00
|
|
|
|
<a className="antd-dropdown-link" style={{ color: "#fff" }}>
|
|
|
|
|
{data?.fullName} <DownOutlined />
|
2022-03-10 14:24:13 +08:00
|
|
|
|
</a>
|
|
|
|
|
</Dropdown>
|
|
|
|
|
</li>
|
2023-02-10 14:06:55 +08:00
|
|
|
|
|
2022-03-10 14:24:13 +08:00
|
|
|
|
</ul>
|
2023-02-10 14:06:55 +08:00
|
|
|
|
|
2020-12-23 11:14:35 +08:00
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|
export default connect(({ settings }: ConnectState) => ({
|
|
|
|
|
theme: settings.navTheme,
|
|
|
|
|
layout: settings.layout,
|
|
|
|
|
}))(GlobalHeaderRight);
|