1、hover呼出当前菜单内容;2、拖拽时,增加列className bug 3、固定列滚动时显示阴影

This commit is contained in:
wanghaoo 2019-02-18 14:22:20 +08:00
parent a693f7d04e
commit ebdcaa5563
12 changed files with 476 additions and 69 deletions

101
demo/demolist/Demo35.js Normal file
View File

@ -0,0 +1,101 @@
/**
*
* @title hover呼出菜单栏
* @description
*/
import React, { Component } from "react";
import Button from "bee-button";
import Tooltip from "bee-tooltip";
import Table from "../../src";
const columns = [
{
title: "用户名", dataIndex: "a", key: "a", width: 80, className: "rowClassName",
fixed:'left',
render: (text, record, index) => {
return (
<Tooltip inverse overlay={text}>
<span tootip={text} style={{
display: "inline-block",
width: "60px",
textOverflow: "ellipsis",
overflow: "hidden",
whiteSpace: "nowrap",
verticalAlign: "middle",
}}>{text}</span>
</Tooltip>
);
}
},
{ id: "123", title: "性别", dataIndex: "b", key: "b", width: 100 },
{ title: "年龄", dataIndex: "c", key: "c", width: 300 },
{
title: "操作",
dataIndex: "d",
key: "d",
render(text, record, index) {
return (
<div style={{ position: 'relative' }} title={text} >
<a
href="javascript:;"
tooltip={text}
onClick={() => {
alert('这是第' + index + '列,内容为:' + text);
}}
>
一些操作
</a>
</div>
);
}
}
];
const data = [
{ a: "令狐冲", b: "男", c: 41, d: "操作", key: "1" },
{ a: "杨过叔叔的女儿黄蓉", b: "男", c: 67, d: "操作", key: "2" },
{ a: "郭靖", b: "男", c: 25, d: "操作", key: "3" }
];
class Demo35 extends Component {
constructor(props) {
super(props);
this.state = {
data: data,
selectedRowIndex: 0
}
}
clickFun=()=>{
// console.log('click'+this.currentIndex);
}
onRowHover=(index)=>{
this.currentIndex = index;
}
render() {
let hoverContent = <div className="opt-btns"><button onClick={this.clickFun}>删除</button> </div>
return (
<Table
columns={columns}
data={data}
parentNodeId='parent'
height={43}
headerHeight={42}
hoverContent={hoverContent}
onRowHover={this.onRowHover}
onRowClick={(record, index, indent) => {
this.setState({
selectedRowIndex: index
});
}}
/>
);
}
}
export default Demo35;

View File

@ -0,0 +1,8 @@
.opt-btns{
button{
background: #505F79 ;
height: 26px;
color:#FFFFFF;
line-height: 26px;
}
}

File diff suppressed because one or more lines are too long

26
dist/demo.css vendored
View File

@ -8441,11 +8441,11 @@ ul {
.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;
@ -8586,6 +8586,8 @@ ul {
.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 {
@ -8901,6 +8903,20 @@ ul {
padding: 0px 16px 0 16px; padding: 0px 16px 0 16px;
cursor: pointer; } cursor: pointer; }
.u-row-hover {
position: absolute;
right: 24px;
display: none;
-ms-flex-align: center;
align-items: center;
-ms-flex-pack: center;
justify-content: center;
background: #E7F2FC; }
.u-row-hover2 {
position: absolute;
left: 100; }
/* FormGroup */ /* FormGroup */
/* Navlayout */ /* Navlayout */
/* FormGroup */ /* FormGroup */
@ -10345,4 +10361,10 @@ th:hover .uf {
padding-bottom: 0px; } padding-bottom: 0px; }
.opt-btns button {
background: #505F79;
height: 26px;
color: #FFFFFF;
line-height: 26px; }
/*# sourceMappingURL=demo.css.map */ /*# sourceMappingURL=demo.css.map */

2
dist/demo.css.map vendored

File diff suppressed because one or more lines are too long

282
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

@ -9,7 +9,7 @@ import addEventListener from 'tinper-bee-core/lib/addEventListener';
import ColumnManager from './ColumnManager'; import ColumnManager from './ColumnManager';
import createStore from './createStore'; import createStore from './createStore';
import Loading from 'bee-loading'; import Loading from 'bee-loading';
import { Event,EventUtil} from "./utils"; import { Event,EventUtil,closest} from "./utils";
const propTypes = { const propTypes = {
data: PropTypes.array, data: PropTypes.array,
@ -28,6 +28,7 @@ const propTypes = {
expandedRowClassName: PropTypes.func, expandedRowClassName: PropTypes.func,
childrenColumnName: PropTypes.string, childrenColumnName: PropTypes.string,
onExpand: PropTypes.func, onExpand: PropTypes.func,
onRowHover:PropTypes.func,
onExpandedRowsChange: PropTypes.func, onExpandedRowsChange: PropTypes.func,
indentSize: PropTypes.number, indentSize: PropTypes.number,
onRowClick: PropTypes.func, onRowClick: PropTypes.func,
@ -137,6 +138,7 @@ class Table extends 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);
} }
componentDidMount() { componentDidMount() {
@ -548,9 +550,9 @@ class Table extends Component {
let className = rowClassName(record, i, indent); let className = rowClassName(record, i, indent);
const onHoverProps = {}; const onHoverProps = {};
if (this.columnManager.isAnyColumnsFixed()) {
onHoverProps.onHover = this.handleRowHover; onHoverProps.onHover = this.handleRowHover;
}
//fixedIndex一般是跟index是一个值的只有是树结构时会讲子节点的值也累计上 //fixedIndex一般是跟index是一个值的只有是树结构时会讲子节点的值也累计上
let fixedIndex = i; let fixedIndex = i;
//判断是否是tree结构 //判断是否是tree结构
@ -623,7 +625,7 @@ 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++;
@ -813,7 +815,7 @@ class Table extends Component {
tableStyle.width = this.contentWidth - this.columnManager.getLeftColumnsWidth(this.contentWidth) - this.columnManager.getRightColumnsWidth(this.contentWidth); tableStyle.width = this.contentWidth - this.columnManager.getLeftColumnsWidth(this.contentWidth) - this.columnManager.getRightColumnsWidth(this.contentWidth);
} }
const tableBody = hasBody ? getBodyWrapper( const tableBody = hasBody ? getBodyWrapper(
<tbody className={`${clsPrefix}-tbody`}> <tbody className={`${clsPrefix}-tbody`} onMouseLeave={this.onBodyMouseLeave}>
{this.getRows(columns, fixed)} {this.getRows(columns, fixed)}
</tbody> </tbody>
) : null; ) : null;
@ -852,6 +854,7 @@ class Table extends Component {
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)}
@ -979,6 +982,9 @@ class Table extends Component {
isRowExpanded(record, index) { isRowExpanded(record, index) {
return typeof this.findExpandedRow(record, index) !== 'undefined'; return typeof this.findExpandedRow(record, index) !== 'undefined';
} }
onBodyMouseLeave(e){
this.hideHoverDom(e);
}
detectScrollTarget(e) { detectScrollTarget(e) {
if (this.scrollTarget !== e.currentTarget) { if (this.scrollTarget !== e.currentTarget) {
@ -986,6 +992,13 @@ class Table extends Component {
} }
} }
hideHoverDom(e){
if(this.hoverDom){
this.hoverDom.style.display = 'none';
}
}
handleBodyScroll(e) { handleBodyScroll(e) {
const { scroll = {},clsPrefix,handleScrollY, handleScrollX} = this.props; const { scroll = {},clsPrefix,handleScrollY, handleScrollX} = this.props;
@ -1045,17 +1058,41 @@ class Table extends Component {
this.lastScrollLeft = e.target.scrollLeft; this.lastScrollLeft = e.target.scrollLeft;
} }
handleRowHover(isHover, key) { handleRowHover(isHover, key,event,currentIndex) {
//增加新的API设置是否同步Hover状态提高性能避免无关的渲染 //增加新的API设置是否同步Hover状态提高性能避免无关的渲染
let { syncHover } = this.props; let { syncHover,onRowHover } = this.props;
if(syncHover){ // 固定列、或者含有hoverdom时情况下同步hover状态
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;
const td = 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);
} }
onRowHoverMouseEnter = () =>{
this.store.setState({
currentHoverKey: this.currentHoverKey,
});
this.hoverDom.style.display = 'block';
}
onRowHoverMouseLeave = () =>{
}
onFocus=(e)=>{ onFocus=(e)=>{
this.props.onKeyTab&&this.props.onKeyTab(); this.props.onKeyTab&&this.props.onKeyTab();
} }
@ -1126,6 +1163,8 @@ class Table extends Component {
<Loading <Loading
container={this} container={this}
{...loading} /> {...loading} />
{ props.hoverContent && <div className="u-row-hover"
onMouseEnter={this.onRowHoverMouseEnter} onMouseLeave={this.onRowHoverMouseLeave} ref={el=> this.hoverDom = el }>{props.hoverContent}</div>}
</div> </div>
); );
} }

View File

@ -11,7 +11,7 @@ $vertical-padding: 12px;
$horizontal-padding: 8px; $horizontal-padding: 8px;
$table-border-color: #e9e9e9; $table-border-color: #e9e9e9;
$table-hover-color: unquote("rgb(#{$palette-blue-50})") !default; $table-hover-color: #E7F2FC;
$table-move-in-color: $bg-color-base; $table-move-in-color: $bg-color-base;
$checkbox-height:16px; $checkbox-height:16px;
.u-table { .u-table {
@ -290,9 +290,9 @@ $checkbox-height:16px;
} }
// &-scroll-position-left &-fixed-left { &-scroll-position-left &-fixed-left {
// box-shadow: none; box-shadow: none;
// } }
&-scroll-position-right &-fixed-right { &-scroll-position-right &-fixed-right {
box-shadow: none; box-shadow: none;
@ -740,6 +740,16 @@ $checkbox-height:16px;
} }
} }
.u-row-hover{
position: absolute;
right: 24px;
display: none;
align-items: center;
justify-content: center;
background: $table-hover-color
}
.u-row-hover2{
position: absolute;
left: 100;
}

View File

@ -583,10 +583,10 @@ class TableHeader extends Component {
let thDefaultObj = {}; let 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

@ -127,14 +127,17 @@ class TableRow extends Component{
onRowDoubleClick(record, index, event); onRowDoubleClick(record, index, event);
} }
onMouseEnter() { onMouseEnter(e) {
const { onHover, hoverKey } = this.props; const { onHover, hoverKey,fixedIndex } = this.props;
onHover(true, hoverKey); this.setState({ hovered: true });
onHover(true, hoverKey,e,fixedIndex);
} }
onMouseLeave() { onMouseLeave(e) {
const { onHover, hoverKey } = this.props;
onHover(false, hoverKey); const { onHover, hoverKey ,fixedIndex} = this.props;
this.setState({ hovered: false });
onHover(false, hoverKey,e,fixedIndex);
} }
set =(fn)=> { set =(fn)=> {
@ -156,7 +159,7 @@ class TableRow extends Component{
const { const {
clsPrefix, columns, record, height, visible, index, clsPrefix, columns, record, height, visible, index,
expandIconColumnIndex, expandIconAsCell, expanded, expandRowByClick, expandIconColumnIndex, expandIconAsCell, expanded, expandRowByClick,
expandable, onExpand, needIndentSpaced, indent, indentSize,isHiddenExpandIcon,fixed,hoverKey expandable, onExpand, needIndentSpaced, indent, indentSize,isHiddenExpandIcon,fixed
} = this.props; } = this.props;
let showSum = false; let showSum = false;
let { className } = this.props; let { className } = this.props;
@ -164,7 +167,7 @@ class TableRow extends 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;
@ -227,6 +230,7 @@ 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>
); );
} }

View File

@ -69,7 +69,22 @@ export function warningOnce(condition, format, args) {
warned[format] = true; warned[format] = true;
} }
} }
export 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;
};