优化1000行数据
This commit is contained in:
parent
70a0e0a460
commit
9d00bd42a5
|
@ -0,0 +1,257 @@
|
|||
/**
|
||||
*
|
||||
* @title 简单表格、文字过长,两种tip
|
||||
* 【Tooltip】
|
||||
* @description
|
||||
*/
|
||||
|
||||
import React, { Component } from "react";
|
||||
import Button from "bee-button";
|
||||
import Tooltip from "bee-tooltip";
|
||||
import Table from "../../src";
|
||||
|
||||
const columns = [
|
||||
{
|
||||
title: "序号",
|
||||
dataIndex: "index",
|
||||
width: 50,
|
||||
key: "index",
|
||||
render(text,record,index){
|
||||
return(
|
||||
<span className="serial-number-center" title={text}>{index + 1}</span>
|
||||
)
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "订单编号",
|
||||
dataIndex: "ebeln",
|
||||
key: "ebeln",
|
||||
width: 100,
|
||||
className:'text-center',//列内容居中
|
||||
onCellClick: (record) => this.cellClick(record, false),
|
||||
render(text,record,index){
|
||||
return(
|
||||
<span className="link">{text}</span>
|
||||
)
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "供应商编码",
|
||||
width: 80,
|
||||
dataIndex: "lifnr",
|
||||
key: "lifnr",
|
||||
className:'text-center',
|
||||
},
|
||||
{
|
||||
title: "供应商名称",
|
||||
//width: 250,
|
||||
dataIndex: "lifnrName",
|
||||
className: "text-ellipsis",//溢出省略号,写了溢出省略号必须加上下面的render
|
||||
key: "lifnrName",
|
||||
render(text,record,index){
|
||||
return(
|
||||
<span title={text}>{text}</span>//title是鼠标放上去显示所有的内容
|
||||
)
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "订单类型",
|
||||
width: 150,
|
||||
dataIndex: "bsart",
|
||||
key: "bsart",
|
||||
render(text,record,index) {
|
||||
return text=='NB'?'标准采购订单':(text=='YB'?'直发工地采购订单':(text=='Z100'?'跨公司重机采购6.0':(text=='ZCB'?'非生产材料领料单':(text=='ZDB'?'D02领料单':(text=='ZEB'?'配送转储采购订单':(text=='ZFB'?'维修采购订单':(text=='ZLB'?'网购订单':(text=='ZMB'?'委托加工采购订单':(text=='ZRB'?'退货采购订单':(text=='ZWB'?'工序外协采购订单':(text=='ZTB'?'紧急订单':(text=='ZWB'?'工序外协采购订单':(text=='UB'?'转储采购订单':'')))))))))))))
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "采购组织",
|
||||
width: 80,
|
||||
dataIndex: "ekorg",
|
||||
key: "ekorg",
|
||||
className:'text-center',
|
||||
},
|
||||
{
|
||||
title: "采购组",
|
||||
width: 60,
|
||||
dataIndex: "ekgrp",
|
||||
key: "ekgrp",
|
||||
className:'text-center',
|
||||
},
|
||||
{
|
||||
title: "凭证日期",
|
||||
dataIndex: "bedat",
|
||||
width: 80,
|
||||
key: "bedat",
|
||||
className:'text-center',
|
||||
render(text,record,index) {
|
||||
return moment(text).format('YYYY-MM-DD')
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "一级审批",
|
||||
dataIndex: "frgc1",
|
||||
width: 80,
|
||||
key: "frgc1",
|
||||
className:'text-center'
|
||||
},
|
||||
{
|
||||
title: "二级审批",
|
||||
dataIndex: "frgc2",
|
||||
width: 80,
|
||||
key: "frgc2",
|
||||
className:'text-center'
|
||||
},
|
||||
{
|
||||
title: "审批状态",
|
||||
dataIndex: "frgrl",
|
||||
width: 80,
|
||||
key: "frgrl",
|
||||
className:'text-center',
|
||||
render(text,record,index) {
|
||||
return text?(text=='X'?'未审批':''):'已审批'
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "确认状态",
|
||||
dataIndex: "confirmResult",
|
||||
width: 80,
|
||||
key: "confirmResult",
|
||||
className:'text-center',
|
||||
render(text,record,index) {
|
||||
return text?(text=='1'?'已确认':'拒绝'):'未确认'
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "确认人",
|
||||
dataIndex: "confirmUsername",
|
||||
width: 150,
|
||||
key: "confirmUsername",
|
||||
className: "text-ellipsis",//溢出省略号,写了溢出省略号必须加上下面的render
|
||||
render(text,record,index){
|
||||
return(
|
||||
<span title={text}>{text}</span>//title是鼠标放上去显示所有的内容
|
||||
)
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "确认时间",
|
||||
dataIndex: "confirmDate",
|
||||
width: 80,
|
||||
key: "confirmDate",
|
||||
className:'text-center',
|
||||
render(text,record,index) {
|
||||
return text?moment(text).format('YYYY-MM-DD hh:mm:ss'):''
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "关闭状态",
|
||||
dataIndex: "elikz",
|
||||
width: 80,
|
||||
key: "elikz",
|
||||
className:'text-center',
|
||||
render(text,record,index) {
|
||||
return text?(text=='X'?'已关闭':''):'未关闭'
|
||||
}
|
||||
},
|
||||
{
|
||||
title: "沟通",
|
||||
dataIndex: "gt",
|
||||
width: 80,
|
||||
key: "gt",
|
||||
className:'text-center',
|
||||
render:(text,record,index)=>{
|
||||
return (
|
||||
<DelModal
|
||||
hide={this.props.hideModal}
|
||||
confirmFn={this.confirm}
|
||||
modalTitle="反馈"
|
||||
showFooter={false}
|
||||
dialogClassName="modal-communicate"
|
||||
onShow={
|
||||
()=>{
|
||||
this.getContent({"orderType":"purchase","ebeln":record.ebeln})
|
||||
}
|
||||
}
|
||||
modalContent={
|
||||
(
|
||||
<div className="modal-communicate-con">
|
||||
<Row>
|
||||
<Col md={6} xs={12}>
|
||||
<Label>采购订单号:</Label>
|
||||
<span>
|
||||
{record.ebeln}
|
||||
</span>
|
||||
</Col>
|
||||
<Col md={6} xs={12}>
|
||||
<Label>供应商代码:</Label>
|
||||
<span>
|
||||
{record.lifnr}
|
||||
</span>
|
||||
</Col>
|
||||
<Col md={6} xs={12}>
|
||||
<Label>供应商名称:</Label>
|
||||
<span>
|
||||
{record.lifnrName}
|
||||
</span>
|
||||
</Col>
|
||||
</Row>
|
||||
<div className="modal-communicate-record">
|
||||
{this.state.feedbacks.map((item,index)=>{
|
||||
return (
|
||||
<p>
|
||||
<span>【{item.feedbackUsername}】</span>
|
||||
<span style={{'color':'#555','padding':'0 10px'}}>{item.feedbackContent}</span>
|
||||
<span>{moment(item.feedbackDate).format('YYYY-MM-DD HH:MM:SS')}</span>
|
||||
</p>
|
||||
)
|
||||
})}
|
||||
</div>
|
||||
<FormItem>
|
||||
<textarea name="feedbackContent" ref='textarea' className="modal-chat" placeholder=""></textarea>
|
||||
<span style={{'display':this.state.showError?'block':'none','color':'red'}}>反馈内容必填</span>
|
||||
<Button shape="border" colors="primary" size='sm' onClick={() => this.feedback(record.ebeln)}>发送</Button>
|
||||
</FormItem>
|
||||
</div>
|
||||
)
|
||||
|
||||
}>
|
||||
<span className="text-center link"><i className="iconfont icon-xiaoxi"></i></span>
|
||||
</DelModal>
|
||||
)
|
||||
}
|
||||
}
|
||||
];
|
||||
|
||||
const data = [
|
||||
{ a: "令狐冲", b: "男", c: 41, d: "操作", key: "1" },
|
||||
{ a: "杨过叔叔的女儿黄蓉", b: "男", c: 67, d: "操作", key: "2" },
|
||||
{ a: "郭靖", b: "男", c: 25, d: "操作", key: "3" }
|
||||
];
|
||||
|
||||
class Demo1 extends Component {
|
||||
|
||||
constructor(props){
|
||||
super(props);
|
||||
this.state = {
|
||||
data: [],
|
||||
selectedRowIndex: 0
|
||||
}
|
||||
}
|
||||
|
||||
render() {
|
||||
return (
|
||||
<Table
|
||||
columns={columns}
|
||||
data={this.state.data}
|
||||
scroll={{ x: 1560}}
|
||||
onRowClick={(record,index,indent)=>{
|
||||
this.setState({
|
||||
selectedRowIndex: index
|
||||
});
|
||||
}}
|
||||
/>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
export default Demo1;
|
File diff suppressed because one or more lines are too long
|
@ -6620,6 +6620,8 @@ input.u-button[type="submit"] {
|
|||
height: 36px;
|
||||
line-height: 36px;
|
||||
margin: 5px; }
|
||||
.u-pagination-total span {
|
||||
padding: 0 5px; }
|
||||
|
||||
.pagination-state {
|
||||
float: left;
|
||||
|
@ -7434,7 +7436,10 @@ ul {
|
|||
cursor: pointer;
|
||||
white-space: nowrap;
|
||||
overflow: hidden;
|
||||
transition: background 0.3s ease; }
|
||||
transition: background 0.3s ease;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
white-space: nowrap; }
|
||||
.u-select-dropdown .u-select-dropdown-menu-item:hover,
|
||||
.u-select-dropdown .u-select-dropdown-menu-item-active {
|
||||
background-color: #e7f4fd; }
|
||||
|
@ -7980,6 +7985,32 @@ ul {
|
|||
margin-left: -5px;
|
||||
border-width: 0 5px 5px;
|
||||
border-bottom-color: #000; }
|
||||
.u-tooltip.inverse-arrow.right .tooltip-arrow {
|
||||
top: 50%;
|
||||
left: auto;
|
||||
right: 0;
|
||||
margin-top: -5px;
|
||||
border-width: 5px 0 5px 5px;
|
||||
border-left-color: #000; }
|
||||
.u-tooltip.inverse-arrow.left .tooltip-arrow {
|
||||
top: 50%;
|
||||
left: 0;
|
||||
margin-top: -5px;
|
||||
border-width: 5px 5px 5px 0;
|
||||
border-right-color: #000; }
|
||||
.u-tooltip.inverse-arrow.top .tooltip-arrow {
|
||||
top: 0;
|
||||
left: 50%;
|
||||
margin-left: -5px;
|
||||
border-width: 0 5px 5px;
|
||||
border-bottom-color: #000; }
|
||||
.u-tooltip.inverse-arrow.bottom .tooltip-arrow {
|
||||
top: auto;
|
||||
bottom: 0;
|
||||
left: 50%;
|
||||
margin-left: -5px;
|
||||
border-width: 5px 5px 0;
|
||||
border-top-color: #000; }
|
||||
.u-tooltip.inverse.bottom .tooltip-arrow::after {
|
||||
top: 1px;
|
||||
margin-left: -5px;
|
||||
|
@ -7987,6 +8018,14 @@ ul {
|
|||
border-bottom-color: #fff; }
|
||||
.u-tooltip.inverse.bottom .tooltip-arrow {
|
||||
border-bottom-color: #d9d9d9; }
|
||||
.u-tooltip.inverse-arrow.inverse.top .tooltip-arrow::after {
|
||||
top: 1px;
|
||||
margin-left: -5px;
|
||||
border-top-width: 0;
|
||||
border-bottom-color: #fff;
|
||||
border-bottom-width: inherit; }
|
||||
.u-tooltip.inverse-arrow.inverse.top .tooltip-arrow {
|
||||
border-bottom-color: #d9d9d9; }
|
||||
.u-tooltip.inverse.left .tooltip-arrow::after {
|
||||
border-right-width: 0;
|
||||
top: -5px;
|
||||
|
@ -7994,6 +8033,14 @@ ul {
|
|||
border-left-color: #fff; }
|
||||
.u-tooltip.inverse.left .tooltip-arrow {
|
||||
border-left-color: #d9d9d9; }
|
||||
.u-tooltip.inverse-arrow.inverse.right .tooltip-arrow::after {
|
||||
border-right-width: 0;
|
||||
top: -5px;
|
||||
margin-left: -6px;
|
||||
border-left-color: #fff;
|
||||
border-left-width: inherit; }
|
||||
.u-tooltip.inverse-arrow.inverse.right .tooltip-arrow {
|
||||
border-left-color: #d9d9d9; }
|
||||
.u-tooltip.inverse.right .tooltip-arrow::after {
|
||||
border-left-width: 0;
|
||||
top: -5px;
|
||||
|
@ -8001,6 +8048,14 @@ ul {
|
|||
border-right-color: #fff; }
|
||||
.u-tooltip.inverse.right .tooltip-arrow {
|
||||
border-right-color: #d9d9d9; }
|
||||
.u-tooltip.inverse-arrow.inverse.left .tooltip-arrow::after {
|
||||
border-left-width: 0;
|
||||
top: -5px;
|
||||
margin-left: 1px;
|
||||
border-right-color: #fff;
|
||||
border-right-width: inherit; }
|
||||
.u-tooltip.inverse-arrow.inverse.left .tooltip-arrow {
|
||||
border-right-color: #d9d9d9; }
|
||||
.u-tooltip.inverse.top .tooltip-arrow::after {
|
||||
top: -6px;
|
||||
margin-left: -5px;
|
||||
|
@ -8009,6 +8064,15 @@ ul {
|
|||
border-top-color: #fff; }
|
||||
.u-tooltip.inverse.top .tooltip-arrow {
|
||||
border-top-color: #d9d9d9; }
|
||||
.u-tooltip.inverse-arrow.inverse.bottom .tooltip-arrow::after {
|
||||
top: -6px;
|
||||
margin-left: -5px;
|
||||
border-bottom-width: 0;
|
||||
border-bottom-color: #d9d9d9;
|
||||
border-top-color: #fff;
|
||||
border-top-width: inherit; }
|
||||
.u-tooltip.inverse-arrow.inverse.bottom .tooltip-arrow {
|
||||
border-top-color: #d9d9d9; }
|
||||
.u-tooltip.inverse .tooltip-inner {
|
||||
background-color: #fff;
|
||||
color: #333333;
|
||||
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -125,7 +125,7 @@ class Table extends Component{
|
|||
}
|
||||
|
||||
componentDidMount() {
|
||||
this.resetScrollY();
|
||||
setTimeout(this.resetScrollY,300);
|
||||
if (this.columnManager.isAnyColumnsFixed()) {
|
||||
this.syncFixedTableRowHeight();
|
||||
this.resizeEvent = addEventListener(
|
||||
|
@ -156,8 +156,10 @@ class Table extends Component{
|
|||
}
|
||||
|
||||
componentDidUpdate() {
|
||||
if (this.columnManager.isAnyColumnsFixed()) {
|
||||
this.syncFixedTableRowHeight();
|
||||
}
|
||||
}
|
||||
|
||||
componentWillUnmount() {
|
||||
if (this.resizeEvent) {
|
||||
|
|
Loading…
Reference in New Issue