Commit 8cd95b36 authored by 崔佳豪's avatar 崔佳豪

perf: 优化

parent 07468e06
...@@ -2,9 +2,11 @@ ...@@ -2,9 +2,11 @@
import React, { useState, useEffect, useRef } from 'react'; import React, { useState, useEffect, useRef } from 'react';
import { Link } from 'react-router-dom'; import { Link } from 'react-router-dom';
import { Input, Button, Tree, notification, Spin, message } from 'antd'; import { Input, Button, Tree, notification, Spin, message } from 'antd';
import { connect } from 'react-redux';
import classnames from 'classnames'; import classnames from 'classnames';
import { appService } from '@/api'; import { appService } from '@/api';
import { useHistory } from '@wisdom-utils/runtime';
import { savePagePartInfo } from '@/api/service/base'; import { savePagePartInfo } from '@/api/service/base';
import styles from './index.less'; import styles from './index.less';
import thumbnail from '../../assets/images/commonMenu/常用菜单.png'; import thumbnail from '../../assets/images/commonMenu/常用菜单.png';
...@@ -15,13 +17,15 @@ const isNeedFilterIcon = (icon = '') => { ...@@ -15,13 +17,15 @@ const isNeedFilterIcon = (icon = '') => {
return !icon.includes('一级') && !icon.includes('ios/'); return !icon.includes('一级') && !icon.includes('ios/');
}; };
const CommonMenu = () => { const CommonMenu = props => {
const history = useHistory();
const [menus, setMenus] = useState([]); // 常用菜单信息 const [menus, setMenus] = useState([]); // 常用菜单信息
const [widgets, setWidgets] = useState([]); // 菜单列表信息 const [widgets, setWidgets] = useState([]); // 菜单列表信息
const [showMenuInfo, setShowMenuInfo] = useState(false); // 菜单列表显示隐藏 const [showMenuInfo, setShowMenuInfo] = useState(false); // 菜单列表显示隐藏
const [loading, setLoading] = useState(true); // loading显示隐藏 const [loading, setLoading] = useState(true); // loading显示隐藏
const [searchInfo, setSearchInfo] = useState(''); const [searchInfo, setSearchInfo] = useState('');
const page = useRef(null); const page = useRef(null);
const searchBox = useRef(null);
const defaultSubmitMenu = () => { const defaultSubmitMenu = () => {
let submitData = []; let submitData = [];
...@@ -253,34 +257,44 @@ const CommonMenu = () => { ...@@ -253,34 +257,44 @@ const CommonMenu = () => {
}); });
}; };
const linkToMenu = menu => {
const { menuUrl } = menu;
console.log(props);
history.push(`civweb4/${menuUrl}`);
};
const focusOutSearchInfo = e => {
e.stopPropagation();
let element = e.target;
// 事件对象逐层网上找,只要不是菜单搜索信息内的就隐藏起来
while (element && element !== page.current) {
if (element === searchBox.current) return;
element = element.parentNode;
}
setShowMenuInfo(false);
};
return ( return (
<div <div className={styles.commonMenu} ref={page} onClick={focusOutSearchInfo}>
className={styles.commonMenu}
ref={page}
onClick={e => {
e.stopPropagation();
if (e.target === page.current) setShowMenuInfo(false);
}}
>
<Spin spinning={loading}> <Spin spinning={loading}>
<div className={styles.searchWrapper}> <div className={styles.searchWrapper}>
<div className={styles.searchBox}> <div className={styles.searchBox} ref={searchBox}>
<div className={styles.searchTitle}> <div className={styles.searchTitle}>
<i className="iconfont">&#xe611;</i> <i className="iconfont">&#xe611;</i>
<span>我的常用菜单</span> <span>我的常用菜单</span>
<span>{menus.length}</span> <span>{menus.length}</span>
</div> </div>
<div> <div className={styles.searchInput}>
<div className={styles.searchInput}> <Input
<Input.Search maxLength={50}
placeholder="搜索功能菜单" width={400}
// onFocus={() => setShowMenuInfo(true)} placeholder="搜索功能菜单"
onSearch={info => { onChange={e => {
setShowMenuInfo(true); setShowMenuInfo(true);
setSearchInfo(info); setSearchInfo(e.target.value);
}} }}
/> onFocus={() => setShowMenuInfo(true)}
</div> />
</div> </div>
<div <div
className={classnames( className={classnames(
...@@ -304,7 +318,7 @@ const CommonMenu = () => { ...@@ -304,7 +318,7 @@ const CommonMenu = () => {
</div> </div>
<div className={styles.menuCardWrapper}> <div className={styles.menuCardWrapper}>
{menus.map(item => ( {menus.map(item => (
<MenuCard menu={item} /> <MenuCard menu={item} linkToMenu={linkToMenu} />
))} ))}
</div> </div>
<div className={styles.pageLogo}> <div className={styles.pageLogo}>
...@@ -315,33 +329,35 @@ const CommonMenu = () => { ...@@ -315,33 +329,35 @@ const CommonMenu = () => {
); );
}; };
const MenuCard = ({ menu }) => { const MenuCard = ({ menu, linkToMenu }) => {
const { menuIcon, menuName, menuGroup, menuID, menuUrl, menuPic } = menu; const { menuIcon, menuName, menuGroup, menuID, menuUrl, menuPic } = menu;
return ( return (
<div className={styles.menuCard}> <div className={styles.menuCard} onClick={() => linkToMenu(menu)}>
<Link to={menuUrl} title={menuName}> {/* <Link to={menuUrl} title={menuName}> */}
<img <img className={styles.cardThumbnail} src={menuPic || thumbnail} alt="" />
className={styles.cardThumbnail} <div className={styles.cardLabel}>
src={menuPic || thumbnail} <div
alt="" className={classnames(
/> styles.cardTitle,
<div className={styles.cardLabel}> isNeedFilterIcon(menuIcon) ? styles.filterIconBox : '',
<div )}
className={classnames( >
styles.cardTitle, <span className={styles.iconBox}>
isNeedFilterIcon(menuIcon) ? styles.filterIconBox : '', <img className={styles.cardIcon} src={menuIcon} alt="" />
)} </span>
> <span className={styles.cardName}>{menuName}</span>
<span className={styles.iconBox}>
<img className={styles.cardIcon} src={menuIcon} alt="" />
</span>
<span className={styles.cardName}>{menuName}</span>
</div>
<div className={styles.cardGroup}>{menuGroup}</div>
</div> </div>
</Link> <div className={styles.cardGroup}>{menuGroup}</div>
</div>
{/* </Link> */}
</div> </div>
); );
}; };
export default CommonMenu; const mapStateToProps = state => ({
menu: state.getIn(['global', 'menu']),
});
export default connect(
mapStateToProps,
null,
)(CommonMenu);
...@@ -55,6 +55,11 @@ ...@@ -55,6 +55,11 @@
color: #3B7FDF; color: #3B7FDF;
} }
} }
.searchInput {
flex: 1;
overflow: hidden;
margin-left: 50px;
}
.searchInfoBox { .searchInfoBox {
width: 100%; width: 100%;
height: 400px; height: 400px;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment