feat(multiSelect.js): 新增selectedRow参数来控制某一行数据是否选中
This commit is contained in:
parent
b9de7de510
commit
3f0c3be121
|
@ -131,6 +131,7 @@ import multiSelect from "bee-table/build/lib/multiSelect.js"
|
||||||
| multiSelect.param | 通过设置该参数来设计获取的数据数组,默认返还所有数据 | string | '' |
|
| multiSelect.param | 通过设置该参数来设计获取的数据数组,默认返还所有数据 | string | '' |
|
||||||
| getSelectedDataFunc | 返回当前选中的数据数组 | Function | 无 |
|
| getSelectedDataFunc | 返回当前选中的数据数组 | Function | 无 |
|
||||||
| selectDisabled | 设置某一行数据无法被选中,使用类似于rowClassName | Function(record, index):bool | 无 |
|
| selectDisabled | 设置某一行数据无法被选中,使用类似于rowClassName | Function(record, index):bool | 无 |
|
||||||
|
| selectedRow | 设置某一行数据是否被选中,使用类似于rowClassName | Function(record, index):bool | 无 |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -46,9 +46,11 @@
|
||||||
.u-table-fixed-header .u-table-body {
|
.u-table-fixed-header .u-table-body {
|
||||||
background: #fff;
|
background: #fff;
|
||||||
position: relative; }
|
position: relative; }
|
||||||
|
.u-table-fixed-left .u-table-body-inner {
|
||||||
|
margin-right: -20px; }
|
||||||
.u-table-fixed-header .u-table-body-inner {
|
.u-table-fixed-header .u-table-body-inner {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
overflow-y: hidden; }
|
overflow: scroll; }
|
||||||
.u-table-fixed-header .u-table-scroll .u-table-header {
|
.u-table-fixed-header .u-table-scroll .u-table-header {
|
||||||
overflow-x: scroll;
|
overflow-x: scroll;
|
||||||
padding-bottom: 20px;
|
padding-bottom: 20px;
|
||||||
|
@ -63,6 +65,8 @@
|
||||||
.u-table-footer {
|
.u-table-footer {
|
||||||
padding: 16px 8px;
|
padding: 16px 8px;
|
||||||
border-bottom: 1px solid #e9e9e9; }
|
border-bottom: 1px solid #e9e9e9; }
|
||||||
|
.u-table-footer .u-table-scroll {
|
||||||
|
overflow-x: hidden; }
|
||||||
.u-table-footer .u-table {
|
.u-table-footer .u-table {
|
||||||
margin: -16px -8px; }
|
margin: -16px -8px; }
|
||||||
.u-table-placeholder {
|
.u-table-placeholder {
|
||||||
|
@ -128,7 +132,7 @@
|
||||||
.u-table-fixed-left {
|
.u-table-fixed-left {
|
||||||
left: 0;
|
left: 0;
|
||||||
box-shadow: 4px 0 4px rgba(100, 100, 100, 0.1); }
|
box-shadow: 4px 0 4px rgba(100, 100, 100, 0.1); }
|
||||||
.u-table-fixed-left .u-table-fixed-left-body-inner {
|
.u-table-fixed-left-body-inner {
|
||||||
margin-right: -20px;
|
margin-right: -20px;
|
||||||
padding-right: 20px; }
|
padding-right: 20px; }
|
||||||
.u-table-fixed-left-fixed-header .u-table-fixed-left .u-table-fixed-left-body-inner {
|
.u-table-fixed-left-fixed-header .u-table-fixed-left .u-table-fixed-left-body-inner {
|
||||||
|
@ -139,9 +143,9 @@
|
||||||
.u-table-fixed-right-expanded-row {
|
.u-table-fixed-right-expanded-row {
|
||||||
color: transparent;
|
color: transparent;
|
||||||
pointer-events: none; }
|
pointer-events: none; }
|
||||||
.u-table .u-table-scroll-position-left .u-table-fixed-left {
|
.u-table-scroll-position-left .u-table-fixed-left {
|
||||||
box-shadow: none; }
|
box-shadow: none; }
|
||||||
.u-table .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.bordered table {
|
.u-table.bordered table {
|
||||||
|
|
|
@ -519,7 +519,8 @@ var Table = function (_Component) {
|
||||||
clsPrefix = _props3.clsPrefix,
|
clsPrefix = _props3.clsPrefix,
|
||||||
_props3$scroll = _props3.scroll,
|
_props3$scroll = _props3.scroll,
|
||||||
scroll = _props3$scroll === undefined ? {} : _props3$scroll,
|
scroll = _props3$scroll === undefined ? {} : _props3$scroll,
|
||||||
getBodyWrapper = _props3.getBodyWrapper;
|
getBodyWrapper = _props3.getBodyWrapper,
|
||||||
|
footerScroll = _props3.footerScroll;
|
||||||
var useFixedHeader = this.props.useFixedHeader;
|
var useFixedHeader = this.props.useFixedHeader;
|
||||||
|
|
||||||
var bodyStyle = _extends({}, this.props.bodyStyle);
|
var bodyStyle = _extends({}, this.props.bodyStyle);
|
||||||
|
@ -528,8 +529,10 @@ var Table = function (_Component) {
|
||||||
var tableClassName = '';
|
var tableClassName = '';
|
||||||
if (scroll.x || fixed) {
|
if (scroll.x || fixed) {
|
||||||
tableClassName = clsPrefix + '-fixed';
|
tableClassName = clsPrefix + '-fixed';
|
||||||
|
if (!footerScroll) {
|
||||||
bodyStyle.overflowX = bodyStyle.overflowX || 'auto';
|
bodyStyle.overflowX = bodyStyle.overflowX || 'auto';
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (scroll.y) {
|
if (scroll.y) {
|
||||||
// maxHeight will make fixed-Table scrolling not working
|
// maxHeight will make fixed-Table scrolling not working
|
||||||
|
@ -544,7 +547,7 @@ var Table = function (_Component) {
|
||||||
|
|
||||||
// Add negative margin bottom for scroll bar overflow bug
|
// Add negative margin bottom for scroll bar overflow bug
|
||||||
var scrollbarWidth = (0, _utils.measureScrollbar)();
|
var scrollbarWidth = (0, _utils.measureScrollbar)();
|
||||||
if (scrollbarWidth > 0) {
|
if (scrollbarWidth >= 0) {
|
||||||
(fixed ? bodyStyle : headStyle).marginBottom = '-' + scrollbarWidth + 'px';
|
(fixed ? bodyStyle : headStyle).marginBottom = '-' + scrollbarWidth + 'px';
|
||||||
(fixed ? bodyStyle : headStyle).paddingBottom = '0px';
|
(fixed ? bodyStyle : headStyle).paddingBottom = '0px';
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,6 +35,8 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
|
||||||
* 使用全选时得注意,data中的key值一定要是唯一值
|
* 使用全选时得注意,data中的key值一定要是唯一值
|
||||||
*/
|
*/
|
||||||
function multiSelect(Table) {
|
function multiSelect(Table) {
|
||||||
|
var _class, _temp, _initialiseProps;
|
||||||
|
|
||||||
Array.prototype.indexOf = function (val) {
|
Array.prototype.indexOf = function (val) {
|
||||||
for (var i = 0; i < this.length; i++) {
|
for (var i = 0; i < this.length; i++) {
|
||||||
if (this[i] == val) return i;
|
if (this[i] == val) return i;
|
||||||
|
@ -47,86 +49,47 @@ function multiSelect(Table) {
|
||||||
this.splice(index, 1);
|
this.splice(index, 1);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
return function (_Component) {
|
return _temp = _class = function (_Component) {
|
||||||
_inherits(BookLoader, _Component);
|
_inherits(multiSelect, _Component);
|
||||||
|
|
||||||
function BookLoader(props) {
|
function multiSelect(props) {
|
||||||
_classCallCheck(this, BookLoader);
|
_classCallCheck(this, multiSelect);
|
||||||
|
|
||||||
var _this = _possibleConstructorReturn(this, _Component.call(this, props));
|
var _this = _possibleConstructorReturn(this, _Component.call(this, props));
|
||||||
|
|
||||||
_this.onAllCheckChange = function () {
|
_initialiseProps.call(_this);
|
||||||
var self = _this;
|
|
||||||
var listData = self.state.data.concat();
|
|
||||||
var checkedObj = _extends({}, self.state.checkedObj);
|
|
||||||
var data = self.props.data;
|
|
||||||
var selIds = [];
|
|
||||||
var id = self.props.multiSelect.param;
|
|
||||||
for (var i = 0; i < data.length; i++) {
|
|
||||||
checkedObj[data[i]["key"]] = !self.state.checkedAll;
|
|
||||||
}
|
|
||||||
if (self.state.checkedAll) {
|
|
||||||
selIds = [];
|
|
||||||
} else {
|
|
||||||
for (var i = 0; i < listData.length; i++) {
|
|
||||||
if (id) {
|
|
||||||
selIds[i] = listData[i][id];
|
|
||||||
} else {
|
|
||||||
selIds[i] = listData[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
self.setState({
|
|
||||||
checkedAll: !self.state.checkedAll,
|
|
||||||
checkedObj: checkedObj,
|
|
||||||
selIds: selIds
|
|
||||||
});
|
|
||||||
self.props.getSelectedDataFunc(selIds);
|
|
||||||
};
|
|
||||||
|
|
||||||
_this.onCheckboxChange = function (text, record, index) {
|
var data = props.data,
|
||||||
var self = _this;
|
checkedObj = _this.initCheckedObj(props);
|
||||||
var allFlag = false;
|
|
||||||
var selIds = self.state.selIds;
|
|
||||||
var id = self.props.multiSelect ? self.props.multiSelect.param ? record[self.props.multiSelect.param] : record : record;
|
|
||||||
var checkedObj = _extends({}, self.state.checkedObj);
|
|
||||||
var checkedArray = Object.keys(checkedObj);
|
|
||||||
var getSelectedDataFunc = self.props.getSelectedDataFunc;
|
|
||||||
|
|
||||||
if (checkedObj[record["key"]]) {
|
|
||||||
selIds.remove(id);
|
|
||||||
} else {
|
|
||||||
selIds.push(id);
|
|
||||||
}
|
|
||||||
checkedObj[record["key"]] = !checkedObj[record["key"]];
|
|
||||||
for (var i = 0; i < checkedArray.length; i++) {
|
|
||||||
if (!checkedObj[checkedArray[i]]) {
|
|
||||||
allFlag = false;
|
|
||||||
break;
|
|
||||||
} else {
|
|
||||||
allFlag = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
self.setState({
|
|
||||||
checkedAll: allFlag,
|
|
||||||
checkedObj: checkedObj,
|
|
||||||
selIds: selIds
|
|
||||||
});
|
|
||||||
if (typeof getSelectedDataFunc === "function") {
|
|
||||||
getSelectedDataFunc(selIds);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
_this.state = {
|
_this.state = {
|
||||||
checkedAll: false,
|
checkedAll: false,
|
||||||
checkedObj: {},
|
checkedObj: checkedObj,
|
||||||
selIds: [],
|
selIds: [],
|
||||||
data: _this.props.data
|
data: _this.props.data
|
||||||
};
|
};
|
||||||
return _this;
|
return _this;
|
||||||
}
|
}
|
||||||
|
|
||||||
BookLoader.prototype.renderColumnsMultiSelect = function renderColumnsMultiSelect(columns) {
|
multiSelect.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {
|
||||||
|
var props = this.props,
|
||||||
|
selectDisabled = props.selectDisabled,
|
||||||
|
selectedRow = props.selectedRow,
|
||||||
|
data = props.data,
|
||||||
|
checkedObj = {};
|
||||||
|
|
||||||
|
if (nextProps.data !== data || nextProps.selectDisabled !== selectDisabled || nextProps.selectedRow !== selectedRow) {
|
||||||
|
checkedObj = this.initCheckedObj(nextProps);
|
||||||
|
this.setState({
|
||||||
|
checkedAll: false,
|
||||||
|
checkedObj: checkedObj,
|
||||||
|
selIds: [],
|
||||||
|
data: nextProps.data
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
multiSelect.prototype.renderColumnsMultiSelect = function renderColumnsMultiSelect(columns) {
|
||||||
var _this2 = this;
|
var _this2 = this;
|
||||||
|
|
||||||
var data = this.state.data;
|
var data = this.state.data;
|
||||||
|
@ -157,11 +120,13 @@ function multiSelect(Table) {
|
||||||
}),
|
}),
|
||||||
key: "checkbox",
|
key: "checkbox",
|
||||||
dataIndex: "checkbox",
|
dataIndex: "checkbox",
|
||||||
width: "5%",
|
width: "100px",
|
||||||
render: function render(text, record, index) {
|
render: function render(text, record, index) {
|
||||||
|
var bool = checkedObj.hasOwnProperty(record["key"]);
|
||||||
return _react2["default"].createElement(_beeCheckbox2["default"], {
|
return _react2["default"].createElement(_beeCheckbox2["default"], {
|
||||||
className: "table-checkbox",
|
className: "table-checkbox",
|
||||||
checked: checkedObj[record.key],
|
checked: checkedObj[record.key],
|
||||||
|
disabled: !bool,
|
||||||
onChange: _this2.onCheckboxChange.bind(_this2, text, record, index)
|
onChange: _this2.onCheckboxChange.bind(_this2, text, record, index)
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -171,12 +136,101 @@ function multiSelect(Table) {
|
||||||
return columns;
|
return columns;
|
||||||
};
|
};
|
||||||
|
|
||||||
BookLoader.prototype.render = function render() {
|
multiSelect.prototype.render = function render() {
|
||||||
var columns = this.renderColumnsMultiSelect(this.props.columns).concat();
|
var columns = this.renderColumnsMultiSelect(this.props.columns).concat();
|
||||||
return _react2["default"].createElement(Table, _extends({}, this.props, { columns: columns }));
|
return _react2["default"].createElement(Table, _extends({}, this.props, { columns: columns }));
|
||||||
};
|
};
|
||||||
|
|
||||||
return BookLoader;
|
return multiSelect;
|
||||||
}(_react.Component);
|
}(_react.Component), _initialiseProps = function _initialiseProps() {
|
||||||
|
var _this3 = this;
|
||||||
|
|
||||||
|
this.initCheckedObj = function (props) {
|
||||||
|
var checkedObj = {},
|
||||||
|
selectDisabled = props.selectDisabled,
|
||||||
|
selectedRow = props.selectedRow,
|
||||||
|
data = props.data;
|
||||||
|
|
||||||
|
for (var i = 0; i < data.length; i++) {
|
||||||
|
var bool = selectDisabled(data[i], i);
|
||||||
|
if (!bool) {
|
||||||
|
if (selectedRow && selectedRow(data[i], i)) {
|
||||||
|
checkedObj[data[i]["key"]] = true;
|
||||||
|
} else {
|
||||||
|
checkedObj[data[i]["key"]] = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return checkedObj;
|
||||||
|
};
|
||||||
|
|
||||||
|
this.onAllCheckChange = function () {
|
||||||
|
var self = _this3;
|
||||||
|
var listData = self.state.data.concat();
|
||||||
|
var checkedObj = _extends({}, self.state.checkedObj);
|
||||||
|
var data = self.props.data;
|
||||||
|
|
||||||
|
var selIds = [];
|
||||||
|
var id = self.props.multiSelect.param;
|
||||||
|
if (self.state.checkedAll) {
|
||||||
|
selIds = [];
|
||||||
|
} else {
|
||||||
|
for (var i = 0; i < listData.length; i++) {
|
||||||
|
if (id) {
|
||||||
|
selIds[i] = listData[i][id];
|
||||||
|
} else {
|
||||||
|
selIds[i] = listData[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (var i = 0; i < data.length; i++) {
|
||||||
|
var bool = checkedObj.hasOwnProperty(data[i]["key"]);
|
||||||
|
if (!bool) {
|
||||||
|
selIds.splice(i, 1);
|
||||||
|
} else {
|
||||||
|
checkedObj[data[i]["key"]] = !self.state.checkedAll;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
self.setState({
|
||||||
|
checkedAll: !self.state.checkedAll,
|
||||||
|
checkedObj: checkedObj,
|
||||||
|
selIds: selIds
|
||||||
|
});
|
||||||
|
self.props.getSelectedDataFunc(selIds);
|
||||||
|
};
|
||||||
|
|
||||||
|
this.onCheckboxChange = function (text, record, index) {
|
||||||
|
var self = _this3;
|
||||||
|
var allFlag = false;
|
||||||
|
var selIds = self.state.selIds;
|
||||||
|
var id = self.props.multiSelect ? self.props.multiSelect.param ? record[self.props.multiSelect.param] : record : record;
|
||||||
|
var checkedObj = _extends({}, self.state.checkedObj);
|
||||||
|
var checkedArray = Object.keys(checkedObj);
|
||||||
|
var getSelectedDataFunc = self.props.getSelectedDataFunc;
|
||||||
|
|
||||||
|
if (checkedObj[record["key"]]) {
|
||||||
|
selIds.remove(id);
|
||||||
|
} else {
|
||||||
|
selIds.push(id);
|
||||||
|
}
|
||||||
|
checkedObj[record["key"]] = !checkedObj[record["key"]];
|
||||||
|
for (var i = 0; i < checkedArray.length; i++) {
|
||||||
|
if (!checkedObj[checkedArray[i]]) {
|
||||||
|
allFlag = false;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
allFlag = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
self.setState({
|
||||||
|
checkedAll: allFlag,
|
||||||
|
checkedObj: checkedObj,
|
||||||
|
selIds: selIds
|
||||||
|
});
|
||||||
|
if (typeof getSelectedDataFunc === "function") {
|
||||||
|
getSelectedDataFunc(selIds);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}, _temp;
|
||||||
}
|
}
|
||||||
module.exports = exports["default"];
|
module.exports = exports["default"];
|
|
@ -87,6 +87,16 @@ function sort(Table) {
|
||||||
return _this;
|
return _this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Demo11.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {
|
||||||
|
if (nextProps.data !== this.props.data) {
|
||||||
|
this.setState({
|
||||||
|
sortOrder: "",
|
||||||
|
data: nextProps.data,
|
||||||
|
oldData: nextProps.data.concat()
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
Demo11.prototype.renderColumnsDropdown = function renderColumnsDropdown(columns) {
|
Demo11.prototype.renderColumnsDropdown = function renderColumnsDropdown(columns) {
|
||||||
var _this2 = this;
|
var _this2 = this;
|
||||||
|
|
||||||
|
|
|
@ -73,7 +73,7 @@ function sum(Table) {
|
||||||
}
|
}
|
||||||
return item;
|
return item;
|
||||||
});
|
});
|
||||||
return _react2["default"].createElement(Table, { showHeader: false, columns: columns_sum, data: obj });
|
return _react2["default"].createElement(Table, _extends({}, _this.props, { footerScroll: true, showHeader: false, columns: columns_sum, data: obj }));
|
||||||
};
|
};
|
||||||
|
|
||||||
return _this;
|
return _this;
|
||||||
|
@ -83,6 +83,7 @@ function sum(Table) {
|
||||||
|
|
||||||
SumTable.prototype.render = function render() {
|
SumTable.prototype.render = function render() {
|
||||||
return _react2["default"].createElement(Table, _extends({}, this.props, {
|
return _react2["default"].createElement(Table, _extends({}, this.props, {
|
||||||
|
footerScroll: true,
|
||||||
columns: this.props.columns,
|
columns: this.props.columns,
|
||||||
data: this.props.data,
|
data: this.props.data,
|
||||||
footer: this.currentFooter
|
footer: this.currentFooter
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
import React, { Component } from "react";
|
import React, { Component } from "react";
|
||||||
import Table from "../../src";
|
import Table from "../../src";
|
||||||
import Checkbox from "bee-checkbox";
|
import Checkbox from "bee-checkbox";
|
||||||
|
import Button from "bee-button";
|
||||||
import multiSelect from "../../src/lib/multiSelect.js";
|
import multiSelect from "../../src/lib/multiSelect.js";
|
||||||
import sort from "../../src/lib/sort.js";
|
import sort from "../../src/lib/sort.js";
|
||||||
import sum from "../../src/lib/sum.js";
|
import sum from "../../src/lib/sum.js";
|
||||||
|
@ -46,10 +47,25 @@ const data13 = [
|
||||||
{ a: "令狐冲", b: "男", c: 41, d: "大侠", key: "1" },
|
{ a: "令狐冲", b: "男", c: 41, d: "大侠", key: "1" },
|
||||||
{ a: "郭靖", b: "男", c: 25, d: "大侠", key: "3" }
|
{ a: "郭靖", b: "男", c: 25, d: "大侠", key: "3" }
|
||||||
];
|
];
|
||||||
|
const data13_1 = [
|
||||||
|
{ a: "杨过", b: "男", c: 30, d: "内行", key: "2" },
|
||||||
|
{ a: "杨过", b: "男", c: 30, d: "内行", key: "22" },
|
||||||
|
{ a: "杨过", b: "男", c: 30, d: "内行", key: "222" },
|
||||||
|
{ a: "令狐冲", b: "男", c: 41, d: "大侠", key: "1" },
|
||||||
|
{ a: "郭靖", b: "男", c: 25, d: "大侠", key: "3" }
|
||||||
|
];
|
||||||
//拼接成复杂功能的table组件不能在render中定义,需要像此例子声明在组件的外侧,不然操作state会导致功能出现异常
|
//拼接成复杂功能的table组件不能在render中定义,需要像此例子声明在组件的外侧,不然操作state会导致功能出现异常
|
||||||
let ComplexTable = multiSelect(sum(sort(Table)));
|
let ComplexTable = multiSelect(sum(sort(Table)));
|
||||||
|
|
||||||
class Demo13 extends Component {
|
class Demo13 extends Component {
|
||||||
|
constructor(props) {
|
||||||
|
super(props);
|
||||||
|
this.state = {
|
||||||
|
data13: data13,
|
||||||
|
selectedRow: this.selectedRow,
|
||||||
|
selectDisabled: this.selectDisabled
|
||||||
|
};
|
||||||
|
}
|
||||||
getSelectedDataFunc = data => {
|
getSelectedDataFunc = data => {
|
||||||
console.log(data);
|
console.log(data);
|
||||||
};
|
};
|
||||||
|
@ -60,16 +76,50 @@ class Demo13 extends Component {
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
|
selectedRow = (record, index) => {
|
||||||
|
console.log(record);
|
||||||
|
if (index === 0) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
};
|
||||||
|
onClick = () => {
|
||||||
|
this.setState({
|
||||||
|
selectedRow: function() {}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
onClick1 = () => {
|
||||||
|
this.setState({
|
||||||
|
selectDisabled: (record, index) => {
|
||||||
|
console.log(record);
|
||||||
|
if (index === 2) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
render() {
|
render() {
|
||||||
let multiObj = {
|
let multiObj = {
|
||||||
type: "checkbox"
|
type: "checkbox"
|
||||||
};
|
};
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
|
<Button className="editable-add-btn" onClick={this.onClick}>
|
||||||
|
change selectedRow
|
||||||
|
</Button>
|
||||||
|
<Button
|
||||||
|
className="editable-add-btn"
|
||||||
|
style={{ marginLeft: "5px" }}
|
||||||
|
onClick={this.onClick1}
|
||||||
|
>
|
||||||
|
change selectDisabled
|
||||||
|
</Button>
|
||||||
<ComplexTable
|
<ComplexTable
|
||||||
selectDisabled={this.selectDisabled}
|
selectDisabled={this.state.selectDisabled}
|
||||||
|
selectedRow={this.state.selectedRow}
|
||||||
columns={columns13}
|
columns={columns13}
|
||||||
data={data13}
|
data={this.state.data13}
|
||||||
multiSelect={multiObj}
|
multiSelect={multiObj}
|
||||||
getSelectedDataFunc={this.getSelectedDataFunc}
|
getSelectedDataFunc={this.getSelectedDataFunc}
|
||||||
/>
|
/>
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -6437,6 +6437,8 @@ input.u-button[type="submit"] {
|
||||||
top: 2px;
|
top: 2px;
|
||||||
height: 18px;
|
height: 18px;
|
||||||
width: 18px; }
|
width: 18px; }
|
||||||
|
.u-checkbox input[disabled] {
|
||||||
|
cursor: not-allowed; }
|
||||||
.u-checkbox.is-checked .u-checkbox-label:before {
|
.u-checkbox.is-checked .u-checkbox-label:before {
|
||||||
box-shadow: inset 0 0 0 10px rgb(30,136,229);
|
box-shadow: inset 0 0 0 10px rgb(30,136,229);
|
||||||
border-color: rgb(30,136,229); }
|
border-color: rgb(30,136,229); }
|
||||||
|
@ -7458,9 +7460,40 @@ ul {
|
||||||
.u-form .u-row .u-label {
|
.u-form .u-row .u-label {
|
||||||
line-height: 40px; }
|
line-height: 40px; }
|
||||||
|
|
||||||
|
.u-form-item .u-input-group-outer .u-input-group .u-form-control:last-child, .u-form-item .u-input-group-outer .u-input-group .u-form-control:first-child {
|
||||||
|
border-bottom-left-radius: 3px;
|
||||||
|
border-top-left-radius: 3px;
|
||||||
|
border-bottom-right-radius: 3px;
|
||||||
|
border-top-right-radius: 3px; }
|
||||||
|
|
||||||
.u-form-item.u-form-inline .u-input-group-outer {
|
.u-form-item.u-form-inline .u-input-group-outer {
|
||||||
display: inline-block; }
|
display: inline-block; }
|
||||||
|
|
||||||
|
.u-form-item .u-input-group-outer .u-input-before, .u-form-item .u-input-group-outer .u-input-after {
|
||||||
|
line-height: 28px;
|
||||||
|
padding-left: 5px;
|
||||||
|
padding-right: 5px;
|
||||||
|
border: 1px solid #bdbdbd;
|
||||||
|
background: #eee;
|
||||||
|
float: left; }
|
||||||
|
|
||||||
|
.u-form-item .u-input-group-outer .u-input-inner {
|
||||||
|
float: left; }
|
||||||
|
|
||||||
|
.u-form-item .u-input-group-outer .u-input-before {
|
||||||
|
border-right: none;
|
||||||
|
border-bottom-left-radius: 3px;
|
||||||
|
border-top-left-radius: 3px; }
|
||||||
|
|
||||||
|
.u-form-item .u-input-group-outer .u-input-before + .u-form-control {
|
||||||
|
border-bottom-left-radius: 0 !important;
|
||||||
|
border-top-left-radius: 0 !important; }
|
||||||
|
|
||||||
|
.u-form-item .u-input-group-outer .u-input-after {
|
||||||
|
border-left: none;
|
||||||
|
border-bottom-right-radius: 3px;
|
||||||
|
border-top-right-radius: 3px; }
|
||||||
|
|
||||||
.u-mast {
|
.u-mast {
|
||||||
color: #F22C1D;
|
color: #F22C1D;
|
||||||
position: relative;
|
position: relative;
|
||||||
|
@ -7626,9 +7659,11 @@ ul {
|
||||||
.u-table-fixed-header .u-table-body {
|
.u-table-fixed-header .u-table-body {
|
||||||
background: #fff;
|
background: #fff;
|
||||||
position: relative; }
|
position: relative; }
|
||||||
|
.u-table-fixed-left .u-table-body-inner {
|
||||||
|
margin-right: -20px; }
|
||||||
.u-table-fixed-header .u-table-body-inner {
|
.u-table-fixed-header .u-table-body-inner {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
overflow-y: hidden; }
|
overflow: scroll; }
|
||||||
.u-table-fixed-header .u-table-scroll .u-table-header {
|
.u-table-fixed-header .u-table-scroll .u-table-header {
|
||||||
overflow-x: scroll;
|
overflow-x: scroll;
|
||||||
padding-bottom: 20px;
|
padding-bottom: 20px;
|
||||||
|
@ -7643,6 +7678,8 @@ ul {
|
||||||
.u-table-footer {
|
.u-table-footer {
|
||||||
padding: 16px 8px;
|
padding: 16px 8px;
|
||||||
border-bottom: 1px solid #e9e9e9; }
|
border-bottom: 1px solid #e9e9e9; }
|
||||||
|
.u-table-footer .u-table-scroll {
|
||||||
|
overflow-x: hidden; }
|
||||||
.u-table-footer .u-table {
|
.u-table-footer .u-table {
|
||||||
margin: -16px -8px; }
|
margin: -16px -8px; }
|
||||||
.u-table-placeholder {
|
.u-table-placeholder {
|
||||||
|
@ -7711,7 +7748,7 @@ ul {
|
||||||
.u-table-fixed-left {
|
.u-table-fixed-left {
|
||||||
left: 0;
|
left: 0;
|
||||||
box-shadow: 4px 0 4px rgba(100, 100, 100, 0.1); }
|
box-shadow: 4px 0 4px rgba(100, 100, 100, 0.1); }
|
||||||
.u-table-fixed-left .u-table-fixed-left-body-inner {
|
.u-table-fixed-left-body-inner {
|
||||||
margin-right: -20px;
|
margin-right: -20px;
|
||||||
padding-right: 20px; }
|
padding-right: 20px; }
|
||||||
.u-table-fixed-left-fixed-header .u-table-fixed-left .u-table-fixed-left-body-inner {
|
.u-table-fixed-left-fixed-header .u-table-fixed-left .u-table-fixed-left-body-inner {
|
||||||
|
@ -7722,9 +7759,9 @@ 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 .u-table-scroll-position-left .u-table-fixed-left {
|
.u-table-scroll-position-left .u-table-fixed-left {
|
||||||
box-shadow: none; }
|
box-shadow: none; }
|
||||||
.u-table .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.bordered table {
|
.u-table.bordered table {
|
||||||
|
@ -7979,6 +8016,97 @@ ul {
|
||||||
right: 7px;
|
right: 7px;
|
||||||
color: rgba(0, 0, 0, 0.65); }
|
color: rgba(0, 0, 0, 0.65); }
|
||||||
|
|
||||||
|
/* FormGroup */
|
||||||
|
/* Navlayout */
|
||||||
|
/* FormGroup */
|
||||||
|
/* Navlayout */
|
||||||
|
.u-input-group-addon {
|
||||||
|
padding: 6px 12px;
|
||||||
|
font-size: 14px;
|
||||||
|
font-weight: 400;
|
||||||
|
line-height: 1;
|
||||||
|
color: #555;
|
||||||
|
text-align: center;
|
||||||
|
background-color: #eee;
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
border-radius: 4px;
|
||||||
|
width: 1%;
|
||||||
|
white-space: nowrap;
|
||||||
|
vertical-align: middle;
|
||||||
|
display: table-cell; }
|
||||||
|
.u-input-group-addon:last-child {
|
||||||
|
border-left: 0;
|
||||||
|
border-top-left-radius: 0;
|
||||||
|
border-bottom-left-radius: 0; }
|
||||||
|
.u-input-group-addon:first-child {
|
||||||
|
border-right: 0;
|
||||||
|
border-bottom-right-radius: 0;
|
||||||
|
border-top-right-radius: 0; }
|
||||||
|
|
||||||
|
/* FormGroup */
|
||||||
|
/* Navlayout */
|
||||||
|
.u-input-group-btn {
|
||||||
|
font-size: 0;
|
||||||
|
white-space: nowrap;
|
||||||
|
position: relative;
|
||||||
|
width: 1%;
|
||||||
|
vertical-align: middle;
|
||||||
|
display: table-cell; }
|
||||||
|
.u-input-group-btn .u-button {
|
||||||
|
position: relative; }
|
||||||
|
|
||||||
|
.u-input-group-btn:first-child > button, .u-input-group-btn:first-child > .btn-group > button, .u-input-group-btn:first-child > .dropdown-toggle, .u-input-group-btn:last-child > .btn-group:not(:last-child) > button, .u-input-group-btn:last-child > button:not(:last-child):not(.dropdown-toggle) {
|
||||||
|
border-bottom-right-radius: 0;
|
||||||
|
border-top-right-radius: 0; }
|
||||||
|
|
||||||
|
.u-input-group-btn:first-child > .btn-group:not(:first-child) > button, .u-input-group-btn:first-child > button:not(:first-child), .u-input-group-btn:last-child > button, .u-input-group-btn:last-child > .btn-group > button, .u-input-group-btn:last-child > .dropdown-toggle {
|
||||||
|
border-bottom-left-radius: 0;
|
||||||
|
border-top-left-radius: 0; }
|
||||||
|
|
||||||
|
.u-input-group-btn:last-child > button, .u-input-group-btn:last-child > .btn-group {
|
||||||
|
z-index: 2;
|
||||||
|
margin-left: -1px; }
|
||||||
|
|
||||||
|
.u-input-group-btn:first-child > button, .u-input-group-btn:first-child > .btn-group {
|
||||||
|
margin-right: -1px; }
|
||||||
|
|
||||||
|
.u-input-group-btn > button:active, .u-input-group-btn > .btn:focus, .u-input-group-btn > button:hover {
|
||||||
|
z-index: 2; }
|
||||||
|
|
||||||
|
.u-input-group {
|
||||||
|
position: relative;
|
||||||
|
display: table;
|
||||||
|
border-collapse: separate; }
|
||||||
|
.u-input-group .u-input-group-btn .u-button {
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
height: 30px;
|
||||||
|
line-height: 1.3; }
|
||||||
|
.u-input-group .u-form-control {
|
||||||
|
position: relative;
|
||||||
|
z-index: 2;
|
||||||
|
float: left;
|
||||||
|
width: 100%;
|
||||||
|
margin-bottom: 0;
|
||||||
|
display: table-cell; }
|
||||||
|
.u-input-group .u-form-control:first-child {
|
||||||
|
border-bottom-right-radius: 0;
|
||||||
|
border-top-right-radius: 0; }
|
||||||
|
.u-input-group .u-form-control:last-child {
|
||||||
|
border-bottom-left-radius: 0;
|
||||||
|
border-top-left-radius: 0; }
|
||||||
|
.u-input-group .u-form-control:not(:first-child):not(:last-child) {
|
||||||
|
border-radius: 0; }
|
||||||
|
.u-input-group.simple .u-form-control {
|
||||||
|
border-radius: 3px; }
|
||||||
|
.u-input-group.simple .u-input-group-btn {
|
||||||
|
position: absolute;
|
||||||
|
top: 2px;
|
||||||
|
bottom: 0;
|
||||||
|
z-index: 2;
|
||||||
|
right: 20px; }
|
||||||
|
.u-input-group.simple .u-form-control:not(:last-child) {
|
||||||
|
padding-right: 23px; }
|
||||||
|
|
||||||
.rc-calendar {
|
.rc-calendar {
|
||||||
box-sizing: border-box; }
|
box-sizing: border-box; }
|
||||||
|
|
||||||
|
@ -9223,4 +9351,10 @@ li.rc-time-picker-panel-select-option-disabled:hover {
|
||||||
.calendar-picker {
|
.calendar-picker {
|
||||||
width: 300px; }
|
width: 300px; }
|
||||||
|
|
||||||
|
.icon-container {
|
||||||
|
position: relative; }
|
||||||
|
|
||||||
|
.datepicker-input-group.u-input-group {
|
||||||
|
display: block; }
|
||||||
|
|
||||||
/*# sourceMappingURL=demo.css.map */
|
/*# sourceMappingURL=demo.css.map */
|
||||||
|
|
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
|
@ -22,6 +22,7 @@ import multiSelect from "bee-table/build/lib/multiSelect.js"
|
||||||
| multiSelect.param | 通过设置该参数来设计获取的数据数组,默认返还所有数据 | string | '' |
|
| multiSelect.param | 通过设置该参数来设计获取的数据数组,默认返还所有数据 | string | '' |
|
||||||
| getSelectedDataFunc | 返回当前选中的数据数组 | Function | 无 |
|
| getSelectedDataFunc | 返回当前选中的数据数组 | Function | 无 |
|
||||||
| selectDisabled | 设置某一行数据无法被选中,使用类似于rowClassName | Function(record, index):bool | 无 |
|
| selectDisabled | 设置某一行数据无法被选中,使用类似于rowClassName | Function(record, index):bool | 无 |
|
||||||
|
| selectedRow | 设置某一行数据是否被选中,使用类似于rowClassName | Function(record, index):bool | 无 |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "bee-table",
|
"name": "bee-table",
|
||||||
"version": "1.0.8",
|
"version": "1.0.9",
|
||||||
"description": "Table ui component for react",
|
"description": "Table ui component for react",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"react",
|
"react",
|
||||||
|
|
|
@ -24,14 +24,8 @@ export default function multiSelect(Table) {
|
||||||
return class multiSelect extends Component {
|
return class multiSelect extends Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
let { selectDisabled, data } = props,
|
let { data } = props,
|
||||||
checkedObj = {};
|
checkedObj = this.initCheckedObj(props);
|
||||||
for (var i = 0; i < data.length; i++) {
|
|
||||||
let bool = selectDisabled(data[i], i);
|
|
||||||
if (!bool) {
|
|
||||||
checkedObj[data[i]["key"]] = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
this.state = {
|
this.state = {
|
||||||
checkedAll: false,
|
checkedAll: false,
|
||||||
checkedObj: checkedObj,
|
checkedObj: checkedObj,
|
||||||
|
@ -41,15 +35,10 @@ export default function multiSelect(Table) {
|
||||||
}
|
}
|
||||||
componentWillReceiveProps(nextProps) {
|
componentWillReceiveProps(nextProps) {
|
||||||
let props = this.props,
|
let props = this.props,
|
||||||
{ selectDisabled, data } = props,
|
{ selectDisabled, selectedRow, data } = props,
|
||||||
checkedObj = {};
|
checkedObj = {};
|
||||||
if (nextProps.data !== data) {
|
if (nextProps.data !== data || nextProps.selectDisabled !== selectDisabled || nextProps.selectedRow !== selectedRow) {
|
||||||
for (var i = 0; i < nextProps.data.length; i++) {
|
checkedObj = this.initCheckedObj(nextProps);
|
||||||
let bool = selectDisabled(nextProps.data[i], i);
|
|
||||||
if (!bool) {
|
|
||||||
checkedObj[nextProps.data[i]["key"]] = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
this.setState({
|
this.setState({
|
||||||
checkedAll: false,
|
checkedAll: false,
|
||||||
checkedObj: checkedObj,
|
checkedObj: checkedObj,
|
||||||
|
@ -58,6 +47,21 @@ export default function multiSelect(Table) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
initCheckedObj = props => {
|
||||||
|
let checkedObj = {},
|
||||||
|
{ selectDisabled, selectedRow, data } = props;
|
||||||
|
for (var i = 0; i < data.length; i++) {
|
||||||
|
let bool = selectDisabled(data[i], i);
|
||||||
|
if (!bool) {
|
||||||
|
if(selectedRow&&selectedRow(data[i], i)){
|
||||||
|
checkedObj[data[i]["key"]] = true;
|
||||||
|
}else{
|
||||||
|
checkedObj[data[i]["key"]] = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return checkedObj;
|
||||||
|
};
|
||||||
onAllCheckChange = () => {
|
onAllCheckChange = () => {
|
||||||
let self = this;
|
let self = this;
|
||||||
let listData = self.state.data.concat();
|
let listData = self.state.data.concat();
|
||||||
|
|
Loading…
Reference in New Issue