index.tsx 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  1. /*
  2. * @Author: your name
  3. * @Date: 2021-11-16 09:12:37
  4. * @LastEditTime: 2023-03-24 16:34:14
  5. * @LastEditors: code4eat awesomedema@gmail.com
  6. * @Description: 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
  7. * @FilePath: /KC-MiddlePlatform/src/pages/index/components/topBar/index.tsx
  8. */
  9. import React, { useEffect, useState } from 'react';
  10. import './style.less';
  11. import { Tooltip } from 'antd';
  12. import { LogoutOutlined, SettingOutlined } from '@ant-design/icons';
  13. import logo from '../../../public/images/kc-logo.png';
  14. import platFormMenuIcon from '../../../public/images/platformMenu.png';
  15. import tabCloseIcon from '../../../public/images/tabCloseIcon.png';
  16. import { history, useModel } from 'umi';
  17. import { Divider } from 'antd';
  18. import { addFastEntry, getUserPlatformNav } from '@/service/menu';
  19. import { NavSelecterData } from '../NavSelecter';
  20. interface TopBarType {
  21. onTabChange?: (data: TopBar.Tab[]) => void; //当tab切换时回调
  22. openedTabs: TopBar.Tab[]; //已打开的列表
  23. currentTab?: TopBar.Tab | undefined; //当前tab
  24. userPannelTabClick?: (tag: 'SETTING' | 'LOGOUT' | 'SETUSERINFO') => void;
  25. onCloseTab?: (data: TopBar.Tab) => void;
  26. onTabClick?: (data: TopBar.Tab) => void;
  27. userData?: { name: string;[key: string]: any };
  28. navData: TopBar.PanelData[];
  29. }
  30. const TopBar: React.FC<TopBarType> = (props) => {
  31. const { onTabChange, userPannelTabClick, onCloseTab, onTabClick, userData, navData,currentTab } = props;
  32. const [systemTabs, setSystemTabs] = useState<TopBar.Tab[]>([]); //已打开的tab
  33. const [currentSelectedTab, setCurrentSelectedTab] = useState<TopBar.Tab>();
  34. const [ifOpenPannel, setIfOpenPannel] = useState(false);
  35. const [arrowRotate, setArrowRotate] = useState(false);
  36. const [pageTitle, set_pageTitle] = useState('欢迎进入医管平台');
  37. const [currentActivedBlockIndex, set_currentActivedBlockIndex] = useState(0);
  38. const [panelData, set_panelData] = useState<TopBar.PanelData[]>([]);
  39. const [onTabSystemTabs,set_onTabSystemTabs] = useState<TopBar.Tab[]>([]); //tab导航可以放下的数量,剩余通过下拉获取
  40. const { initialState, setInitialState } = useModel('@@initialState');
  41. const localSavedTab = localStorage.getItem('currentSelectedTab');
  42. const currentSelectedTabFromLocal = localSavedTab ? JSON.parse(localSavedTab) : {};
  43. const _systemTabClickHandle = (item: TopBar.Tab) => {
  44. //导航栏tab点击
  45. // console.log('_systemTabClickHandle',item);
  46. onTabClick && onTabClick(item);
  47. localStorage.setItem('currentSelectedTab', JSON.stringify(item));
  48. setCurrentSelectedTab(item);
  49. };
  50. const _systemListClickHandle = (data: TopBar.Tab, currentActivedBlockIndex: number, index: number, i: number) => {
  51. //导航栏系统菜单列表点击回调
  52. if (currentSelectedTab?.menuId == data.menuId) return;
  53. //临时保存衣打开过的菜单
  54. const t = localStorage.getItem('visitedTabs');
  55. if(t){
  56. let visitedTabs = JSON.parse(t);
  57. let index = visitedTabs.findIndex((t:TopBar.Tab)=>t.menuId == data.menuId);
  58. if(index == -1){
  59. visitedTabs.push(data);
  60. localStorage.setItem('visitedTabs',JSON.stringify(visitedTabs));
  61. }
  62. }else{
  63. localStorage.setItem('visitedTabs',JSON.stringify([data]));
  64. }
  65. _systemTabClickHandle(data); //触发一次tab点击
  66. set_pageTitle(panelData[currentActivedBlockIndex].child[index].name)
  67. if (panelData[currentActivedBlockIndex].child[index].child) {
  68. // console.log([...panelData[currentActivedBlockIndex].child[index].child])
  69. setSystemTabs([...panelData[currentActivedBlockIndex].child[index].child]);
  70. }
  71. setIfOpenPannel(false);
  72. };
  73. const _userPannelTabClick = (tag: 'SETTING' | 'LOGOUT') => {
  74. //用户菜单tab点击回调
  75. userPannelTabClick && userPannelTabClick(tag);
  76. };
  77. const closeTabHandle = (item: TopBar.Tab, e: React.MouseEvent) => {
  78. e.stopPropagation();
  79. let _systemTabs = [...systemTabs];
  80. let delIndex = -1;
  81. const filtered = _systemTabs.filter((t, index) => {
  82. if (t.menuId == item.menuId) {
  83. delIndex = index;
  84. }
  85. return t.menuId != item.menuId;
  86. });
  87. setSystemTabs([...filtered]);
  88. if (delIndex != 0) {
  89. _systemTabClickHandle(_systemTabs[delIndex - 1]); //自动切换为前一个tab
  90. }
  91. onTabChange && onTabChange(filtered);
  92. onCloseTab && onCloseTab(item);
  93. };
  94. const UserPannel = () => {
  95. return (
  96. <div className='userPannel'>
  97. <div className='userPannelTab' onClick={() => _userPannelTabClick('SETTING')}>
  98. <SettingOutlined />
  99. 设置
  100. </div>
  101. <div className='userPannelTab' onClick={() => _userPannelTabClick('LOGOUT')}>
  102. <LogoutOutlined />
  103. 退出
  104. </div>
  105. </div>
  106. );
  107. };
  108. const goChannelIndex = (menuData:any) => {
  109. setIfOpenPannel(false);
  110. onTabClick&&onTabClick(menuData)
  111. }
  112. const goToHome = () => {
  113. history.replace('/index');
  114. setSystemTabs([]); //清空tab导航
  115. onTabChange && onTabChange([]);
  116. setCurrentSelectedTab(undefined);
  117. set_pageTitle('欢迎进入医管平台');
  118. setIfOpenPannel(false);
  119. localStorage.removeItem('currentSelectedTab');
  120. localStorage.removeItem('selectedKeys');
  121. localStorage.removeItem('visitedTabs');
  122. localStorage.removeItem('openKeys');
  123. }
  124. const goSystemIndex = (name:string)=>{
  125. if(panelData[currentActivedBlockIndex]){
  126. const result:TopBar.TypeBlock[] = panelData[currentActivedBlockIndex].child.filter(t=>(t.name == name));
  127. if(result.length>0){
  128. _systemTabClickHandle(Object.assign(result[0]))
  129. // history.push(result[0].path)
  130. }
  131. }
  132. }
  133. const openNav = () => {
  134. setIfOpenPannel(!ifOpenPannel);
  135. }
  136. const reSetNav = (_panelData: TopBar.PanelData[], cur: TopBar.Tab) => {
  137. if (!(_panelData.length > 0)) return
  138. if (JSON.stringify(cur) != '{}') {
  139. let blockIndex = 0;
  140. let channelIndex = 0;
  141. const _currentSelectedTabFromLocal = cur;
  142. one: for (let index = 0; index < _panelData.length; index++) {
  143. blockIndex = index;
  144. if (_panelData[index] && _panelData[index].child) {
  145. two: for (let i = 0; i < _panelData[index].child.length; i++) {
  146. channelIndex = i;
  147. if (_panelData && _panelData.length > 0) {
  148. const _systems = _panelData[index].child[i].child;
  149. if (_systems && _systems.length > 0) {
  150. for (let k = 0; k < _systems.length; k++) {
  151. if (_systems[k].menuId == _currentSelectedTabFromLocal.menuId) {
  152. set_currentActivedBlockIndex(blockIndex);
  153. set_pageTitle(_panelData[blockIndex].child[channelIndex].name); //设置体系标题
  154. break one;
  155. }
  156. }
  157. }
  158. }
  159. }
  160. }
  161. }
  162. if (_panelData && _panelData.length > 0 && _panelData[blockIndex].child) {
  163. setSystemTabs(_panelData[blockIndex].child[channelIndex].child); //恢复体系列表
  164. setCurrentSelectedTab(_currentSelectedTabFromLocal);
  165. localStorage.setItem('currentSelectedTab', JSON.stringify(_currentSelectedTabFromLocal));
  166. setInitialState((s) => ({ ...s, currentSelectedSys: _currentSelectedTabFromLocal }));
  167. }
  168. //_systemTabClickHandle(_currentSelectedTabFromLocal); //恢复选中的tab
  169. }
  170. }
  171. useEffect(() => {
  172. if (currentSelectedTabFromLocal) {
  173. reSetNav(navData, currentSelectedTabFromLocal);
  174. }
  175. set_panelData(navData);
  176. }, [navData])
  177. useEffect(()=>{
  178. if(currentTab)reSetNav(panelData,currentTab);
  179. },[currentTab]);
  180. useEffect(()=>{
  181. // console.log('systemTabs.length',systemTabs.length);
  182. if(systemTabs.length>6){
  183. const tabs = systemTabs.filter((a:any,index:number)=>{
  184. //暂时限制只展示最多5个
  185. if(index<=5){
  186. return a
  187. }
  188. });
  189. set_onTabSystemTabs(tabs);
  190. }else{
  191. set_onTabSystemTabs(systemTabs);
  192. }
  193. },[systemTabs]);
  194. useEffect(() => {
  195. //_systemTabClickHandle(currentSelectedTabFromLocal); //恢复选中的tab
  196. document.body.addEventListener('click', (e:any) => {
  197. const classes = ['panel', 'left','typeBlockIcon', 'typeBlock', 'active', 'right', 'row', 'rowDetai', 'channelName', 'channelList', 'systemTab', 'channelIcon'];
  198. if (e.target) {
  199. if (classes.includes(e.target.className)) {
  200. return
  201. }
  202. }
  203. setIfOpenPannel(false);
  204. });
  205. }, []);
  206. return (
  207. <div className='topBar' onClick={e => e.stopPropagation()}>
  208. <div className='logoWrap'>
  209. <img className='logo' src={logo} onClick={() => goToHome()} />
  210. <Divider type="vertical" style={{ background: 'white', height: 16, opacity: 0.29, position: 'relative', top: 1, marginLeft: 24, marginRight: 8 }} />
  211. <div className='menu' onClick={() => openNav()}>
  212. <img src={require('../../../public/images/menu.png')} alt="" />
  213. </div>
  214. <span className='systemTitle' onClick={()=>goSystemIndex(pageTitle)}>{pageTitle}</span>
  215. </div>
  216. <div className='userRelaInfoWrap'>
  217. <>
  218. {/**
  219. * 已打开的tab
  220. */}
  221. <div className='tabWrap'>
  222. {onTabSystemTabs&&(onTabSystemTabs).map((item, index) => (
  223. <div key={index} className={currentSelectedTab?.menuId == item.menuId ? `tab on` : `tab`} onClick={() => _systemTabClickHandle(item)}>
  224. <div className='tabText'>{item.name} </div>
  225. <div className='closeIconWrap'>
  226. <img src={tabCloseIcon} onClick={(e) => closeTabHandle(item, e)} />
  227. </div>
  228. </div>
  229. ))}
  230. </div>
  231. </>
  232. {/* <div className='notification'>
  233. <img className='notificationIcon' src={require('../../../public/images/notificationIcon.png')} />
  234. </div> */}
  235. <Tooltip title={<UserPannel />} color="#fff" onVisibleChange={(visible) => setArrowRotate(visible)}>
  236. <div className='user'>
  237. <img className='avator' src={require('../../../public/images/Mask.png')} />
  238. <span className='name'>{userData?.name}</span>
  239. <img className={arrowRotate ? `arrow on` : `arrow`} src={require('../../../public/images/arrow_white.png')} />
  240. </div>
  241. </Tooltip>
  242. </div>
  243. {
  244. ifOpenPannel && (
  245. <div className='panel' onClick={e => e.stopPropagation()}>
  246. <div className='left'>
  247. {
  248. panelData.map((item, index) => {
  249. return (
  250. <div className={currentActivedBlockIndex == index ? `typeBlock active` : `typeBlock`} key={index} onClick={() => set_currentActivedBlockIndex(index)}>
  251. {/* <img className='typeBlockIcon' src={item?.icon} alt="" /> */}
  252. <img className='typeBlockIcon' src={require('../../../public/images/blueBook.png')} alt="" />
  253. <span>{item.name}</span>
  254. </div>
  255. )
  256. })
  257. }
  258. </div>
  259. <div className='right'>
  260. {
  261. panelData.length > 0 && panelData[currentActivedBlockIndex] && panelData[currentActivedBlockIndex].child && panelData[currentActivedBlockIndex].child.map((item, index: number) => {
  262. return (
  263. <div className='row' key={index}>
  264. <img className='channelIcon' src={require('../../../public/images/zhilianganquan.png')} alt="" />
  265. <div className='rowDetail'>
  266. <div className='channelName' onClick={() => goChannelIndex(item)}>{item.name}</div>
  267. <div className='channelList'>
  268. {
  269. item.child && item.child.length > 0 && item.child.map((val, i: number) => {
  270. return (
  271. <div className={currentSelectedTab?.menuId == val.menuId ? 'systemTab on' : 'systemTab'} key={i} onClick={() => _systemListClickHandle(val, currentActivedBlockIndex, index, i)}>{val.name}</div>
  272. )
  273. })
  274. }
  275. </div>
  276. </div>
  277. </div>
  278. )
  279. })
  280. }
  281. </div>
  282. </div>
  283. )
  284. }
  285. </div>
  286. );
  287. };
  288. export default TopBar;