补充hover显示菜单示例

This commit is contained in:
wanghaoo 2019-02-18 14:54:33 +08:00
parent ebdcaa5563
commit d767e1af81
13 changed files with 162 additions and 61 deletions

View File

@ -180,11 +180,11 @@
.u-table td { .u-table td {
border-bottom: 1px solid #e9e9e9; } border-bottom: 1px solid #e9e9e9; }
.u-table tr:hover { .u-table tr:hover {
background: rgb(227,242,253); } background: #E7F2FC; }
.u-table tr:hover td .uf-eye { .u-table tr:hover td .uf-eye {
visibility: visible !important; } visibility: visible !important; }
.u-table tr.tr-row-hover { .u-table tr.tr-row-hover {
background: rgb(227,242,253); } background: #E7F2FC; }
.u-table th, .u-table th,
.u-table td { .u-table td {
padding: 12px 8px; padding: 12px 8px;
@ -322,6 +322,8 @@
.u-table-fixed-right-expanded-row { .u-table-fixed-right-expanded-row {
color: transparent; color: transparent;
pointer-events: none; } pointer-events: none; }
.u-table-scroll-position-left .u-table-fixed-left {
box-shadow: none; }
.u-table-scroll-position-right .u-table-fixed-right { .u-table-scroll-position-right .u-table-fixed-right {
box-shadow: none; } box-shadow: none; }
.u-table-thead .filter-text, .u-table-thead .filter-dropdown, .u-table-thead .filter-date { .u-table-thead .filter-text, .u-table-thead .filter-dropdown, .u-table-thead .filter-date {
@ -637,3 +639,15 @@
height: 32px; height: 32px;
padding: 0px 16px 0 16px; padding: 0px 16px 0 16px;
cursor: pointer; } cursor: pointer; }
.u-row-hover {
position: absolute;
right: 24px;
display: none;
align-items: center;
justify-content: center;
background: #E7F2FC; }
.u-row-hover2 {
position: absolute;
left: 100; }

View File

@ -77,6 +77,7 @@ var propTypes = {
expandedRowClassName: _propTypes2["default"].func, expandedRowClassName: _propTypes2["default"].func,
childrenColumnName: _propTypes2["default"].string, childrenColumnName: _propTypes2["default"].string,
onExpand: _propTypes2["default"].func, onExpand: _propTypes2["default"].func,
onRowHover: _propTypes2["default"].func,
onExpandedRowsChange: _propTypes2["default"].func, onExpandedRowsChange: _propTypes2["default"].func,
indentSize: _propTypes2["default"].number, indentSize: _propTypes2["default"].number,
onRowClick: _propTypes2["default"].func, onRowClick: _propTypes2["default"].func,
@ -171,6 +172,16 @@ var Table = function (_Component) {
); );
}; };
_this.onRowHoverMouseEnter = function () {
_this.store.setState({
currentHoverKey: _this.currentHoverKey
});
_this.hoverDom.style.display = 'block';
};
_this.onRowHoverMouseLeave = function () {};
_this.onFocus = function (e) { _this.onFocus = function (e) {
_this.props.onKeyTab && _this.props.onKeyTab(); _this.props.onKeyTab && _this.props.onKeyTab();
}; };
@ -239,6 +250,7 @@ var Table = function (_Component) {
_this.handleBodyScroll = _this.handleBodyScroll.bind(_this); _this.handleBodyScroll = _this.handleBodyScroll.bind(_this);
_this.handleRowHover = _this.handleRowHover.bind(_this); _this.handleRowHover = _this.handleRowHover.bind(_this);
_this.computeTableWidth = _this.computeTableWidth.bind(_this); _this.computeTableWidth = _this.computeTableWidth.bind(_this);
_this.onBodyMouseLeave = _this.onBodyMouseLeave.bind(_this);
return _this; return _this;
} }
@ -676,9 +688,9 @@ var Table = function (_Component) {
var className = rowClassName(record, i, indent); var className = rowClassName(record, i, indent);
var onHoverProps = {}; var onHoverProps = {};
if (this.columnManager.isAnyColumnsFixed()) {
onHoverProps.onHover = this.handleRowHover; onHoverProps.onHover = this.handleRowHover;
}
//fixedIndex一般是跟index是一个值的只有是树结构时会讲子节点的值也累计上 //fixedIndex一般是跟index是一个值的只有是树结构时会讲子节点的值也累计上
var fixedIndex = i; var fixedIndex = i;
//判断是否是tree结构 //判断是否是tree结构
@ -748,8 +760,8 @@ var Table = function (_Component) {
setRowParentIndex: props.setRowParentIndex, setRowParentIndex: props.setRowParentIndex,
treeType: childrenColumn || this.treeType ? true : false, treeType: childrenColumn || this.treeType ? true : false,
fixedIndex: fixedIndex + lazyCurrentIndex, fixedIndex: fixedIndex + lazyCurrentIndex,
rootIndex: rootIndex rootIndex: rootIndex,
hoverContent: props.hoverContent
}))); })));
this.treeRowIndex++; this.treeRowIndex++;
var subVisible = visible && isRowExpanded; var subVisible = visible && isRowExpanded;
@ -940,7 +952,7 @@ var Table = function (_Component) {
} }
var tableBody = hasBody ? getBodyWrapper(_react2["default"].createElement( var tableBody = hasBody ? getBodyWrapper(_react2["default"].createElement(
'tbody', 'tbody',
{ className: clsPrefix + '-tbody' }, { className: clsPrefix + '-tbody', onMouseLeave: _this4.onBodyMouseLeave },
_this4.getRows(columns, fixed) _this4.getRows(columns, fixed)
)) : null; )) : null;
var _drag_class = _this4.props.dragborder ? "table-drag-bordered" : ""; var _drag_class = _this4.props.dragborder ? "table-drag-bordered" : "";
@ -977,7 +989,8 @@ var Table = function (_Component) {
ref: 'bodyTable', ref: 'bodyTable',
onMouseOver: this.detectScrollTarget, onMouseOver: this.detectScrollTarget,
onTouchStart: this.detectScrollTarget, onTouchStart: this.detectScrollTarget,
onScroll: this.handleBodyScroll onScroll: this.handleBodyScroll,
onMouseLeave: this.onBodyMouseLeave
}, },
this.renderDragHideTable(), this.renderDragHideTable(),
renderTable(!useFixedHeader) renderTable(!useFixedHeader)
@ -1128,12 +1141,22 @@ var Table = function (_Component) {
return typeof this.findExpandedRow(record, index) !== 'undefined'; return typeof this.findExpandedRow(record, index) !== 'undefined';
}; };
Table.prototype.onBodyMouseLeave = function onBodyMouseLeave(e) {
this.hideHoverDom(e);
};
Table.prototype.detectScrollTarget = function detectScrollTarget(e) { Table.prototype.detectScrollTarget = function detectScrollTarget(e) {
if (this.scrollTarget !== e.currentTarget) { if (this.scrollTarget !== e.currentTarget) {
this.scrollTarget = e.currentTarget; this.scrollTarget = e.currentTarget;
} }
}; };
Table.prototype.hideHoverDom = function hideHoverDom(e) {
if (this.hoverDom) {
this.hoverDom.style.display = 'none';
}
};
Table.prototype.handleBodyScroll = function handleBodyScroll(e) { Table.prototype.handleBodyScroll = function handleBodyScroll(e) {
var _props8 = this.props, var _props8 = this.props,
_props8$scroll = _props8.scroll, _props8$scroll = _props8.scroll,
@ -1194,15 +1217,30 @@ var Table = function (_Component) {
this.lastScrollLeft = e.target.scrollLeft; this.lastScrollLeft = e.target.scrollLeft;
}; };
Table.prototype.handleRowHover = function handleRowHover(isHover, key) { Table.prototype.handleRowHover = function handleRowHover(isHover, key, event, currentIndex) {
//增加新的API设置是否同步Hover状态提高性能避免无关的渲染 //增加新的API设置是否同步Hover状态提高性能避免无关的渲染
var syncHover = this.props.syncHover; var _props9 = this.props,
syncHover = _props9.syncHover,
onRowHover = _props9.onRowHover;
// 固定列、或者含有hoverdom时情况下同步hover状态
if (syncHover) { if (this.columnManager.isAnyColumnsFixed() && syncHover) {
this.hoverKey = key;
this.store.setState({ this.store.setState({
currentHoverKey: isHover ? key : null currentHoverKey: isHover ? key : null
}); });
} }
if (this.hoverDom && isHover) {
this.currentHoverKey = key;
var td = (0, _utils.closest)(event.target, 'td');
if (td) {
this.hoverDom.style.top = td.offsetTop + 'px';
this.hoverDom.style.height = td.offsetHeight + 'px';
this.hoverDom.style.lineHeight = td.offsetHeight + 'px';
this.hoverDom.style.display = 'block';
}
}
onRowHover && onRowHover(currentIndex);
}; };
Table.prototype.render = function render() { Table.prototype.render = function render() {
@ -1264,7 +1302,15 @@ var Table = function (_Component) {
), ),
_react2["default"].createElement(_beeLoading2["default"], _extends({ _react2["default"].createElement(_beeLoading2["default"], _extends({
container: this container: this
}, loading)) }, loading)),
props.hoverContent && _react2["default"].createElement(
'div',
{ className: 'u-row-hover',
onMouseEnter: this.onRowHoverMouseEnter, onMouseLeave: this.onRowHoverMouseLeave, ref: function ref(el) {
return _this6.hoverDom = el;
} },
props.hoverContent
)
); );
}; };

View File

@ -661,10 +661,10 @@ var TableHeader = function (_Component) {
var thDefaultObj = {}; var thDefaultObj = {};
if (draggable) { if (draggable) {
thClassName += clsPrefix + "-thead th-drag " + thHover + " "; thClassName += " " + clsPrefix + "-thead th-drag " + thHover + " ";
} }
if (dragborder) { if (dragborder) {
thClassName += clsPrefix + "-thead-th " + canDotDrag; thClassName += " " + clsPrefix + "-thead-th " + canDotDrag;
} }
thClassName += " " + fixedStyle; thClassName += " " + fixedStyle;

View File

@ -195,20 +195,24 @@ var TableRow = function (_Component) {
onRowDoubleClick(record, index, event); onRowDoubleClick(record, index, event);
}; };
TableRow.prototype.onMouseEnter = function onMouseEnter() { TableRow.prototype.onMouseEnter = function onMouseEnter(e) {
var _props7 = this.props, var _props7 = this.props,
onHover = _props7.onHover, onHover = _props7.onHover,
hoverKey = _props7.hoverKey; hoverKey = _props7.hoverKey,
fixedIndex = _props7.fixedIndex;
onHover(true, hoverKey); this.setState({ hovered: true });
onHover(true, hoverKey, e, fixedIndex);
}; };
TableRow.prototype.onMouseLeave = function onMouseLeave() { TableRow.prototype.onMouseLeave = function onMouseLeave(e) {
var _props8 = this.props, var _props8 = this.props,
onHover = _props8.onHover, onHover = _props8.onHover,
hoverKey = _props8.hoverKey; hoverKey = _props8.hoverKey,
fixedIndex = _props8.fixedIndex;
onHover(false, hoverKey); this.setState({ hovered: false });
onHover(false, hoverKey, e, fixedIndex);
}; };
TableRow.prototype.render = function render() { TableRow.prototype.render = function render() {
@ -229,8 +233,7 @@ var TableRow = function (_Component) {
indent = _props9.indent, indent = _props9.indent,
indentSize = _props9.indentSize, indentSize = _props9.indentSize,
isHiddenExpandIcon = _props9.isHiddenExpandIcon, isHiddenExpandIcon = _props9.isHiddenExpandIcon,
fixed = _props9.fixed, fixed = _props9.fixed;
hoverKey = _props9.hoverKey;
var showSum = false; var showSum = false;
var className = this.props.className; var className = this.props.className;
@ -239,7 +242,7 @@ var TableRow = function (_Component) {
if (this.state.hovered) { if (this.state.hovered) {
className += ' ' + clsPrefix + '-hover'; className += ' ' + clsPrefix + '-hover';
} }
// console.log('className--'+className,index);
//判断是否为合计行 //判断是否为合计行
if (className.indexOf('sumrow') > -1) { if (className.indexOf('sumrow') > -1) {
showSum = true; showSum = true;
@ -297,7 +300,8 @@ var TableRow = function (_Component) {
// key={hoverKey} // key={hoverKey}
, ref: this.bindElement , ref: this.bindElement
}, },
cells.length > 0 ? cells : _react2["default"].createElement('td', null) cells.length > 0 ? cells : _react2["default"].createElement('td', null),
_react2["default"].createElement('div', { className: 'u-row-hover2' })
); );
}; };

View File

@ -10,6 +10,7 @@ var _extends = Object.assign || function (target) { for (var i = 1; i < argument
exports.measureScrollbar = measureScrollbar; exports.measureScrollbar = measureScrollbar;
exports.debounce = debounce; exports.debounce = debounce;
exports.warningOnce = warningOnce; exports.warningOnce = warningOnce;
exports.getOffset = getOffset;
exports.addClass = addClass; exports.addClass = addClass;
exports.removeClass = removeClass; exports.removeClass = removeClass;
exports.ObjectAssign = ObjectAssign; exports.ObjectAssign = ObjectAssign;
@ -97,6 +98,19 @@ function warningOnce(condition, format, args) {
warned[format] = true; warned[format] = true;
} }
} }
function getOffset(Node, offset) {
if (!offset) {
offset = {};
offset.top = 0;
offset.left = 0;
}
if (Node == document.body) {
return offset;
}
offset.top += Node.offsetTop;
offset.left += Node.offsetLeft;
if (Node.offsetParent) return getOffset(Node.offsetParent, offset);else return offset;
};
var tryParseInt = exports.tryParseInt = function tryParseInt(value) { var tryParseInt = exports.tryParseInt = function tryParseInt(value) {
var defaultValue = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; var defaultValue = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;

View File

@ -68,14 +68,22 @@ class Demo35 extends Component {
} }
} }
clickFun=()=>{ delFun=()=>{
// console.log('click'+this.currentIndex); // console.log('click'+this.currentIndex);
let {data} = this.state;
data.splice(this.currentIndex,1);
this.setState({
data
});
} }
onRowHover=(index)=>{ onRowHover=(index,record)=>{
this.currentIndex = index; this.currentIndex = index;
this.currentRecord = record;
}
getHoverContent=()=>{
return <div className="opt-btns"><button onClick={this.delFun}>删除</button> </div>
} }
render() { render() {
let hoverContent = <div className="opt-btns"><button onClick={this.clickFun}>删除</button> </div>
return ( return (
<Table <Table
@ -84,7 +92,7 @@ class Demo35 extends Component {
parentNodeId='parent' parentNodeId='parent'
height={43} height={43}
headerHeight={42} headerHeight={42}
hoverContent={hoverContent} hoverContent={this.getHoverContent}
onRowHover={this.onRowHover} onRowHover={this.onRowHover}
onRowClick={(record, index, indent) => { onRowClick={(record, index, indent) => {
this.setState({ this.setState({

File diff suppressed because one or more lines are too long

58
dist/demo.js vendored

File diff suppressed because one or more lines are too long

2
dist/demo.js.map vendored

File diff suppressed because one or more lines are too long

View File

@ -57,6 +57,8 @@ import 'bee-table/build/Table.css';
| syncHover | 是否同步Hover状态到左侧Checkbox关闭此功能有助于提升性能 | bool| true | syncHover | 是否同步Hover状态到左侧Checkbox关闭此功能有助于提升性能 | bool| true
| loadBuffer | 使用BigData高阶组件实现大数据加载时上下加载的缓存 | number| 5 | loadBuffer | 使用BigData高阶组件实现大数据加载时上下加载的缓存 | number| 5
| resetScroll | 将表格横向滚动条位置还原 | bool| false | resetScroll | 将表格横向滚动条位置还原 | bool| false
| hoverContent | hover某行时动态渲染行菜单元素此方法需返回行菜单元素的内容 | Function|
| onRowHover | 行hover时的回调函数 | Function|
> 快捷键部分参考示例 (快捷键在table中的简单使用应用) > 快捷键部分参考示例 (快捷键在table中的简单使用应用)

View File

@ -1,6 +1,6 @@
{ {
"name": "bee-table", "name": "bee-table",
"version": "1.6.38", "version": "1.6.39",
"description": "Table ui component for react", "description": "Table ui component for react",
"keywords": [ "keywords": [
"react", "react",

View File

@ -51,6 +51,7 @@ const propTypes = {
onFilterClear: PropTypes.func, onFilterClear: PropTypes.func,
syncHover: PropTypes.bool, syncHover: PropTypes.bool,
tabIndex:PropTypes.string, tabIndex:PropTypes.string,
hoverContent:PropTypes.func
}; };
const defaultProps = { const defaultProps = {
@ -83,7 +84,7 @@ const defaultProps = {
syncHover: true, syncHover: true,
setRowHeight:()=>{}, setRowHeight:()=>{},
setRowParentIndex:()=>{}, setRowParentIndex:()=>{},
tabIndex:'0' tabIndex:'0',
}; };
class Table extends Component { class Table extends Component {
@ -625,7 +626,6 @@ class Table extends Component {
treeType={childrenColumn||this.treeType?true:false} treeType={childrenColumn||this.treeType?true:false}
fixedIndex={fixedIndex+lazyCurrentIndex} fixedIndex={fixedIndex+lazyCurrentIndex}
rootIndex = {rootIndex} rootIndex = {rootIndex}
hoverContent={props.hoverContent}
/> />
); );
this.treeRowIndex++; this.treeRowIndex++;
@ -1060,7 +1060,8 @@ class Table extends Component {
handleRowHover(isHover, key,event,currentIndex) { handleRowHover(isHover, key,event,currentIndex) {
//增加新的API设置是否同步Hover状态提高性能避免无关的渲染 //增加新的API设置是否同步Hover状态提高性能避免无关的渲染
let { syncHover,onRowHover } = this.props; let { syncHover,onRowHover,data } = this.props;
const record = data[currentIndex];
// 固定列、或者含有hoverdom时情况下同步hover状态 // 固定列、或者含有hoverdom时情况下同步hover状态
if(this.columnManager.isAnyColumnsFixed() && syncHover ){ if(this.columnManager.isAnyColumnsFixed() && syncHover ){
this.hoverKey = key; this.hoverKey = key;
@ -1078,7 +1079,8 @@ class Table extends Component {
this.hoverDom.style.display = 'block'; this.hoverDom.style.display = 'block';
} }
} }
onRowHover && onRowHover(currentIndex);
onRowHover && onRowHover(currentIndex,record);
} }
@ -1164,7 +1166,7 @@ class Table extends Component {
container={this} container={this}
{...loading} /> {...loading} />
{ props.hoverContent && <div className="u-row-hover" { props.hoverContent && <div className="u-row-hover"
onMouseEnter={this.onRowHoverMouseEnter} onMouseLeave={this.onRowHoverMouseLeave} ref={el=> this.hoverDom = el }>{props.hoverContent}</div>} onMouseEnter={this.onRowHoverMouseEnter} onMouseLeave={this.onRowHoverMouseLeave} ref={el=> this.hoverDom = el }>{props.hoverContent()}</div>}
</div> </div>
); );
} }

View File

@ -230,7 +230,6 @@ class TableRow extends Component{
ref={this.bindElement} ref={this.bindElement}
> >
{cells.length>0?cells:<td></td>} {cells.length>0?cells:<td></td>}
<div className="u-row-hover2" >{}</div>
</tr> </tr>
); );
} }