ekko
Version:
Excel like Grid in React
61 lines (48 loc) • 1.76 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
require("core-js/modules/es6.function.name");
var _react = _interopRequireDefault(require("react"));
var _Cell = _interopRequireDefault(require("./Cell"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
class Row extends _react.default.PureComponent {
constructor(...args) {
var _temp;
return _temp = super(...args), _defineProperty(this, "handleRowChange", (value, updater) => {
const _this$props = this.props,
id = _this$props.id,
onRowChange = _this$props.onRowChange,
data = _this$props.data;
if (onRowChange) {
onRowChange(id, updater(value, data));
}
}), _temp;
}
componentWillReceiveProps(nextProps) {
Object.keys(nextProps).forEach(key => {
if (nextProps[key] !== this.props[key]) {
console.log(`\t[Row]: Prop ${key} changed`);
}
});
}
render() {
const _this$props2 = this.props,
columns = _this$props2.columns,
data = _this$props2.data;
console.log('[Row]: render');
return columns.map(column => _react.default.createElement(_Cell.default, {
key: column.name,
value: column.getter(data),
render: column.render,
updater: column.updater,
editor: column.editor,
editorDisplay: column.editorDisplay,
onCellUpdate: this.handleRowChange
}));
}
}
var _default = Row;
exports.default = _default;