From 50b49c1b760489c3430fc382656d57c5fbbab07c Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期一, 29 四月 2024 16:07:24 +0800 Subject: [PATCH] 2024-04-29 --- src/tabviews/custom/components/tree/antd-tree/index.jsx | 124 +++++++++++++++++++++++------------------ 1 files changed, 69 insertions(+), 55 deletions(-) diff --git a/src/tabviews/custom/components/tree/antd-tree/index.jsx b/src/tabviews/custom/components/tree/antd-tree/index.jsx index 721d876..e218c48 100644 --- a/src/tabviews/custom/components/tree/antd-tree/index.jsx +++ b/src/tabviews/custom/components/tree/antd-tree/index.jsx @@ -1,7 +1,7 @@ import React, {Component} from 'react' import PropTypes from 'prop-types' import { is, fromJS } from 'immutable' -import { Spin, Empty, notification, Input, Tree, Modal, Dropdown } from 'antd' +import { Spin, Empty, Input, Tree, Dropdown } from 'antd' import { FolderOpenOutlined, FolderOutlined, FileOutlined, MoreOutlined } from '@ant-design/icons' import Api from '@/api' @@ -31,6 +31,7 @@ treeNodes: null, // 鍒楄〃鏁版嵁闆� expandedKeys: [], // 灞曞紑鐨勬爲鑺傜偣 selectedKeys: [], // 閫変腑鐨勬爲鑺傜偣 + lineActions: [], selected: false // 閫変腑棣栬 } @@ -71,13 +72,28 @@ } } + let lineActions = [] + _config.action = _config.action || [] + _config.action = _config.action.filter(item => { + if (item.Ot === 'requiredSgl') { + lineActions.push(item) + return false + } + return true + }) + _config.wrap.contentHeight = config.wrap.title || config.wrap.searchable === 'true' ? 'calc(100% - 45px)' : '100%' + + if (_config.wrap.lineHeight) { + _config.style['--mk-tree-line-height'] = _config.wrap.lineHeight + 'px' + } this.setState({ selected: _config.wrap.selected === 'true', config: _config, data: _data, - BID: BID || '' + BID: BID || '', + lineActions }) } @@ -254,7 +270,7 @@ * @param {*} position // 鍒锋柊浣嶇疆 * @param {*} btn // 鎵ц鐨勬寜閽� */ - refreshByButtonResult = (menuId, position, btn) => { + refreshByButtonResult = (menuId, position) => { const { config, BID } = this.state if (config.uuid !== menuId) return @@ -321,37 +337,14 @@ } } - if (result.message) { - if (result.ErrCode === 'Y') { - Modal.success({ - title: result.message - }) - } else if (result.ErrCode === 'S') { - notification.success({ - top: 92, - message: result.message, - duration: 2 - }) - } - } + UtilsDM.querySuccess(result) } else { this.setState({ loading: false }) this.timer && this.timer.stop() - if (!result.message) return - if (result.ErrCode === 'N') { - Modal.error({ - title: result.message, - }) - } else if (result.ErrCode !== '-2') { - notification.error({ - top: 92, - message: result.message, - duration: 10 - }) - } + UtilsDM.queryFail(result) } } @@ -376,9 +369,9 @@ let hasSelectKey = false data.forEach(item => { - let pval = item[config.wrap.parentField] - let val = item[config.wrap.valueField] - let uuid = item[config.setting.primaryKey] || '' + let pval = item[config.wrap.parentField] + '' + let val = item[config.wrap.valueField] + '' + let uuid = item[config.setting.primaryKey] + '' if (!val || logMap.has(val)) return @@ -528,30 +521,45 @@ }) } - renderActionTreeNodes = (nodes) => { + renderActionTreeNodes = (nodes, actShow) => { return nodes.map(item => { - let title = <> - {item.$title} - <Dropdown overlay={ - <div className="mk-tree-dropdown-wrap" onClick={(e) => e.stopPropagation()}> - <MainAction - BID={this.state.BID} - BData={this.state.BData} - setting={this.state.config.setting} - actions={this.state.config.action} - columns={this.state.config.columns} - selectedData={[{...item, children: ''}]} - /> - </div> - } placement="bottomCenter" trigger={['hover']}> - <MoreOutlined onClick={(e) => e.stopPropagation()}/> - </Dropdown> - </> + let title = null + if (actShow === 'line') { + title = <> + {item.$title} + <MainAction + BID={this.state.BID} + BData={this.state.BData} + setting={this.state.config.setting} + actions={this.state.lineActions} + columns={this.state.config.columns} + selectedData={[{...item, children: ''}]} + /> + </> + } else { + title = <> + {item.$title} + <Dropdown overlay={ + <div className="mk-tree-dropdown-wrap" onClick={(e) => e.stopPropagation()}> + <MainAction + BID={this.state.BID} + BData={this.state.BData} + setting={this.state.config.setting} + actions={this.state.lineActions} + columns={this.state.config.columns} + selectedData={[{...item, children: ''}]} + /> + </div> + } placement="bottomCenter" trigger={['hover']}> + <MoreOutlined onClick={(e) => e.stopPropagation()}/> + </Dropdown> + </> + } if (item.children) { return ( <TreeNode icon={<span><FolderOpenOutlined /><FolderOutlined /></span>} title={title} key={item.$key} dataRef={item}> - {this.renderActionTreeNodes(item.children)} + {this.renderActionTreeNodes(item.children, actShow)} </TreeNode> ) } @@ -614,9 +622,7 @@ } render() { - const { config, loading, treeNodes, expandedKeys, selectedKeys } = this.state - - let extra = config.action && config.action.length > 0 + const { BID, BData, config, loading, treeNodes, expandedKeys, selectedKeys, lineActions } = this.state return ( <div className="custom-tree-box" id={'anchor' + config.uuid} style={config.style}> @@ -630,18 +636,26 @@ <span className={'title ' + (config.wrap.searchable !== 'true' ? 'search-unable' : '')}>{config.wrap.title}</span> {config.wrap.searchable === 'true' ? <Search allowClear onSearch={this.treeFilter} /> : null} </div> : null} + {config.action.length ? <MainAction + BID={BID} + setting={config.setting} + actions={config.action} + BData={BData} + columns={config.columns} + selectedData={[]} + /> : null} {treeNodes && treeNodes.length > 0 ? <div className="tree-box" style={{height: config.wrap.contentHeight}}> <Tree blockNode onSelect={this.selectTreeNode} expandedKeys={expandedKeys} selectedKeys={selectedKeys} - onRightClick={!extra ? this.changeExpandedAllKeys : null} + onRightClick={!lineActions.length ? this.changeExpandedAllKeys : null} onExpand={this.changeExpandedKeys} showIcon={config.wrap.showIcon === 'true'} showLine={config.wrap.showLine === 'true'} > - {!extra ? this.renderTreeNodes(treeNodes) : this.renderActionTreeNodes(treeNodes)} + {!lineActions.length ? this.renderTreeNodes(treeNodes) : this.renderActionTreeNodes(treeNodes, config.wrap.actShow)} </Tree> </div> : null} {treeNodes && treeNodes.length === 0 ? <Empty description={false}/> : null} -- Gitblit v1.8.0