行编辑half done

This commit is contained in:
梁才军 2019-04-23 13:33:52 +08:00
parent 6fe1233f27
commit a04389d003
11 changed files with 182 additions and 110 deletions

View File

@ -5,7 +5,7 @@
* *
*/ */
import React, { Component } from "react"; import React, { Component } from "react";
import { Table } from "tinper-bee"; import Table from "../../src";
import { Icon, Select, Tooltip } from "tinper-bee"; import { Icon, Select, Tooltip } from "tinper-bee";
const Option = Select.Option; const Option = Select.Option;
@ -58,6 +58,7 @@ class StringEditCell extends Component {
{value === "" ? ( {value === "" ? (
<Tooltip <Tooltip
inverse inverse
className="tp-501"
placement="bottom" placement="bottom"
overlay={ overlay={
<div className="help-tip"> <div className="help-tip">
@ -136,11 +137,11 @@ class SelectEditCell extends Component {
} }
const dataSource = [ const dataSource = [
{ name: "全能法戒", quality: "远古传奇", level: 70.11 }, { name: "全能法戒", quality: "远古传奇", level: 70, key: "1" },
{ name: "绝命", quality: "太古传奇", level: 70 }, { name: "绝命", quality: "太古传奇", level: 70, key: "2" },
{ name: "蚀刻符印", quality: "太古传奇", level: 70 }, { name: "蚀刻符印", quality: "太古传奇", level: 70, key: "3" },
{ name: "虹光", quality: "传奇", level: 70 }, { name: "虹光", quality: "传奇", level: 70, key: "4" },
{ name: "复仇者护腕", quality: "传奇", level: 70 } { name: "复仇者护腕", quality: "传奇", level: 70, key: "5" }
]; ];
class Demo501 extends Component { class Demo501 extends Component {

View File

@ -4,6 +4,7 @@
border: 1px dashed #A5ADBA; border: 1px dashed #A5ADBA;
} }
} }
.require { .require {
position: absolute; position: absolute;
top: 2px; top: 2px;
@ -11,12 +12,17 @@
font-size: 20px; font-size: 20px;
} }
} }
.help-tip { .help-tip {
color: #F44336; color: #F44336;
} }
.tooltip-arrow {
border-bottom-color: #F44336 !important; .tp-501 {
} .tooltip-arrow {
.tooltip-inner { border-bottom-color: #F44336 !important;
border-color: #F44336 !important; }
.tooltip-inner {
border-color: #F44336 !important;
}
} }

View File

@ -5,8 +5,8 @@
* *
*/ */
import React, { Component } from "react"; import React, { Component } from "react";
import { Table } from "tinper-bee"; import Table from "../../src";
import { Icon, FormControl } from "tinper-bee"; import { Button, FormControl } from "tinper-bee";
class EditableCell extends Component { class EditableCell extends Component {
constructor(props, context) { constructor(props, context) {
@ -42,37 +42,27 @@ class EditableCell extends Component {
} }
} }
const dataSource = [ let dataSource = [
{ name: "全能法戒", quality: "远古传奇", level: 70 }, { name: "全能法戒", quality: "远古传奇", level: 70, key: "1" },
{ name: "绝命", quality: "太古传奇", level: 70 }, { name: "绝命", quality: "太古传奇", level: 70, key: "2" },
{ name: "蚀刻符印", quality: "太古传奇", level: 70 }, { name: "蚀刻符印", quality: "太古传奇", level: 70, key: "3" },
{ name: "虹光", quality: "传奇", level: 70 }, { name: "虹光", quality: "传奇", level: 70, key: "4" },
{ name: "复仇者护腕", quality: "传奇", level: 70 } { name: "复仇者护腕", quality: "传奇", level: 70, key: "5" }
]; ];
for (let i = 5; i < 10; i++) {
dataSource.push({
name: "复仇者护腕",
quality: "传奇",
level: 70,
key: i + 1 + ""
});
}
class Demo502 extends Component { class Demo502 extends Component {
constructor(props, context) { constructor(props, context) {
super(props); super(props);
this.columns = [ this.columns = [
{
key: "row_edit",
width: "45px",
render: (text, record, index) => {
return this.state.editingRows.indexOf(index) > -1 ? (
<Icon
type="uf-correct"
className="editable-row-icon-check"
onClick={this.commitChange(index)}
/>
) : (
<Icon
type="uf-pencil"
className="editable-row-icon"
onClick={this.edit(index)}
/>
);
}
},
{ {
title: "装备名称", title: "装备名称",
dataIndex: "name", dataIndex: "name",
@ -101,6 +91,7 @@ class Demo502 extends Component {
title: "需求等级", title: "需求等级",
dataIndex: "level", dataIndex: "level",
key: "level", key: "level",
width: 100,
render: (text, record, index) => ( render: (text, record, index) => (
<EditableCell <EditableCell
editable={this.state.editingRows.indexOf(index) > -1} editable={this.state.editingRows.indexOf(index) > -1}
@ -108,6 +99,10 @@ class Demo502 extends Component {
onChange={this.onCellChange(index, "level")} onChange={this.onCellChange(index, "level")}
/> />
) )
},
{
key: "placeholder",
dataIndex: "undefined"
} }
]; ];
@ -117,15 +112,38 @@ class Demo502 extends Component {
}; };
this.dataBuffer = {}; this.dataBuffer = {};
this.currentIndex = null;
this.currentRecord = null;
this.__OPTS_BTN_GROUP__ = null;
}
createBtn = (text, props, event) => {
let btn = document.createElement("button");
btn.innerText = text;
for (let pKey in props) {
btn.setAttribute(pKey, props[pKey]);
}
for (let eKey in event) {
btn.addEventListener(eKey, event[eKey]);
}
return btn
} }
edit = index => () => { edit = index => () => {
if (index === null) return;
let editingRows = [...this.state.editingRows]; let editingRows = [...this.state.editingRows];
editingRows.push(index); editingRows.push(index);
this.dataBuffer[index] = Object.assign({}, dataSource[index]); this.dataBuffer[index] = Object.assign({}, dataSource[index]);
this.setState({ editingRows }); this.setState({ editingRows });
}; };
abortEdit = () => {
let editingRows = [...this.state.editingRows];
editingRows.splice(index, 1);
delete this.dataBuffer[index];
this.setState({ editingRows });
};
commitChange = index => () => { commitChange = index => () => {
let editingRows = [...this.state.editingRows]; let editingRows = [...this.state.editingRows];
let dataSource = [...this.state.dataSource]; let dataSource = [...this.state.dataSource];
@ -144,7 +162,12 @@ class Demo502 extends Component {
const columns = this.columns; const columns = this.columns;
return ( return (
<div className="demo502"> <div className="demo502">
<Table data={dataSource} columns={columns} /> <Table
data={dataSource}
columns={columns}
onRowHover={this.handleRowHover}
hoverContent={this.renderRowHover}
/>
</div> </div>
); );
} }

View File

@ -1,15 +1,15 @@
.demo502 { .demo502 {
.u-table-row-hover {
.editable-row-icon,
.editable-row-icon-check {
display: block !important;
}
}
.u-table-row { .u-table-row {
height: 58px; height: 58px;
.editable-row-icon, }
.editable-row-icon-check { .u-row-hover {
display: none; .opt-btns {
button {
border-radius: 5px;
&:first-child {
margin-right: 10px;
}
} }
}
} }
} }

View File

@ -43,11 +43,11 @@ class EditableCell extends Component {
} }
const dataSource = [ const dataSource = [
{ name: "全能法戒", quality: "远古传奇", level: 70 }, { name: "全能法戒", quality: "远古传奇", level: 70, key: "1" },
{ name: "绝命", quality: "太古传奇", level: 70 }, { name: "绝命", quality: "太古传奇", level: 70, key: "2" },
{ name: "蚀刻符印", quality: "太古传奇", level: 70 }, { name: "蚀刻符印", quality: "太古传奇", level: 70, key: "3" },
{ name: "虹光", quality: "传奇", level: 70 }, { name: "虹光", quality: "传奇", level: 70, key: "4" },
{ name: "复仇者护腕", quality: "传奇", level: 70 } { name: "复仇者护腕", quality: "传奇", level: 70, key: "5" }
]; ];
class Demo503 extends Component { class Demo503 extends Component {

File diff suppressed because one or more lines are too long

16
dist/demo.css vendored
View File

@ -9904,21 +9904,19 @@ ul {
.help-tip { .help-tip {
color: #F44336; } color: #F44336; }
.tooltip-arrow { .tp-501 .tooltip-arrow {
border-bottom-color: #F44336 !important; } border-bottom-color: #F44336 !important; }
.tooltip-inner { .tp-501 .tooltip-inner {
border-color: #F44336 !important; } border-color: #F44336 !important; }
.demo502 .u-table-row-hover .editable-row-icon,
.demo502 .u-table-row-hover .editable-row-icon-check {
display: block !important; }
.demo502 .u-table-row { .demo502 .u-table-row {
height: 58px; } height: 58px; }
.demo502 .u-table-row .editable-row-icon,
.demo502 .u-table-row .editable-row-icon-check { .demo502 .u-row-hover .opt-btns button {
display: none; } border-radius: 5px; }
.demo502 .u-row-hover .opt-btns button:first-child {
margin-right: 10px; }
th .drop-menu .uf { th .drop-menu .uf {
font-size: 12px; font-size: 12px;

2
dist/demo.css.map vendored

File diff suppressed because one or more lines are too long

133
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

@ -1207,6 +1207,7 @@ class Table extends Component {
if (props.size) { if (props.size) {
className += ` ${clsPrefix}-${props.size}`; className += ` ${clsPrefix}-${props.size}`;
} }
console.log("update");
return ( return (
<div className={className} style={props.style} ref={el => this.contentTable = el} <div className={className} style={props.style} ref={el => this.contentTable = el}