Browse Source

*大屏运营左侧条件过滤修改为只展示搜索的对应数据

release_0.0.4
wanyiwei 3 years ago
parent
commit
ffa95765cd
  1. 39
      web/client/src/sections/quanju/containers/footer/operation/left.js

39
web/client/src/sections/quanju/containers/footer/operation/left.js

@ -10,6 +10,7 @@ const Left = (props) => {
const [treeData, setTreeData] = useState([]) const [treeData, setTreeData] = useState([])
const [treeDataList, setTreeDataList] = useState([]) const [treeDataList, setTreeDataList] = useState([])
const [expandedKeys, setExpandedKeys] = useState([]); const [expandedKeys, setExpandedKeys] = useState([]);
const [searchValue, setSearchValue] = useState('');
const [autoExpandParent, setAutoExpandParent] = useState(true); const [autoExpandParent, setAutoExpandParent] = useState(true);
const onExpand = (newExpandedKeys) => { const onExpand = (newExpandedKeys) => {
@ -20,6 +21,7 @@ const Left = (props) => {
useEffect(() => { useEffect(() => {
const { dispatch } = props const { dispatch } = props
dispatch(getBusTierList()) dispatch(getBusTierList())
}, []) }, [])
const { busTier } = props const { busTier } = props
const style = { height: "97%", marginTop: "3%" } const style = { height: "97%", marginTop: "3%" }
@ -35,10 +37,45 @@ const Left = (props) => {
setSearchValue(value); setSearchValue(value);
setAutoExpandParent(true); setAutoExpandParent(true);
}; };
const loop = (treeData) =>
treeData.map((item) => {
const index = item.title.indexOf(searchValue);
const beforeStr = item.title.substr(0, index);
const afterStr = item.title.substr(index + searchValue.length);
const title =
index > -1 ? (
<span>
{beforeStr}
<span className="site-tree-search-value">{searchValue}</span>
{afterStr}
</span>
) : (
<span>{item.title}</span>
);
if (item.children && item.children.length > 0) {
const children = loop(item.children);
return {
...item,
title: index > -1 || children.length ? title : null,
children: children.length ? children : undefined
};
}
return index > -1
? {
...item,
title
}
: {
...item,
title: null
};
})
.filter((item) => !!item.title);
useEffect(() => { useEffect(() => {
let busTierList = [] let busTierList = []
let busTierOpen = [] let busTierOpen = []
let dataList = [] let dataList = []
busTier && busTier.data && busTier.data.forEach((e, index) => { busTier && busTier.data && busTier.data.forEach((e, index) => {
if (index == 0) { if (index == 0) {
busTierOpen.push(e.name) busTierOpen.push(e.name)
@ -115,7 +152,7 @@ const Left = (props) => {
onExpand={onExpand} onExpand={onExpand}
expandedKeys={expandedKeys} expandedKeys={expandedKeys}
autoExpandParent={autoExpandParent} autoExpandParent={autoExpandParent}
treeData={treeData} treeData={loop(treeData)}
/> : <div style={{ width: '100%', color: '#fff', textAlign: 'center', marginTop: '90%' }}></div> /> : <div style={{ width: '100%', color: '#fff', textAlign: 'center', marginTop: '90%' }}></div>
} }

Loading…
Cancel
Save