choerodon-ui
Version:
An enterprise-class UI design language and React-based implementation
157 lines (130 loc) • 5.84 kB
JavaScript
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard")["default"];
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault")["default"];
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _miniStore = require("mini-store");
var _ExpandIcon = _interopRequireDefault(require("./ExpandIcon"));
var ExpandableRow = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(ExpandableRow, _Component);
var _super = (0, _createSuper2["default"])(ExpandableRow);
function ExpandableRow() {
var _this;
(0, _classCallCheck2["default"])(this, ExpandableRow);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "hasExpandIcon", function (columnIndex) {
var expandRowByClick = _this.props.expandRowByClick;
return !_this.expandIconAsCell && !expandRowByClick && columnIndex === _this.expandIconColumnIndex;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleExpandChange", function (record, event) {
var _this$props = _this.props,
onExpandedChange = _this$props.onExpandedChange,
expanded = _this$props.expanded,
rowKey = _this$props.rowKey;
if (_this.expandable) {
onExpandedChange(!expanded, record, event, rowKey);
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleRowClick", function (record, index, event) {
var _this$props2 = _this.props,
expandRowByClick = _this$props2.expandRowByClick,
onRowClick = _this$props2.onRowClick;
if (expandRowByClick) {
_this.handleExpandChange(record, event);
}
if (onRowClick) {
onRowClick(record, index, event);
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "renderExpandIcon", function () {
var _this$props3 = _this.props,
prefixCls = _this$props3.prefixCls,
expanded = _this$props3.expanded,
record = _this$props3.record,
needIndentSpaced = _this$props3.needIndentSpaced;
return /*#__PURE__*/_react["default"].createElement(_ExpandIcon["default"], {
expandable: _this.expandable,
prefixCls: prefixCls,
onExpand: _this.handleExpandChange,
needIndentSpaced: needIndentSpaced,
expanded: expanded,
record: record
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "renderExpandIconCell", function (cells) {
if (!_this.expandIconAsCell) {
return;
}
var prefixCls = _this.props.prefixCls;
cells.push( /*#__PURE__*/_react["default"].createElement("td", {
className: "".concat(prefixCls, "-expand-icon-cell"),
key: "rc-table-expand-icon-cell"
}, _this.renderExpandIcon()));
});
return _this;
}
(0, _createClass2["default"])(ExpandableRow, [{
key: "componentWillUnmount",
value: function componentWillUnmount() {
this.handleDestroy();
}
}, {
key: "handleDestroy",
value: function handleDestroy() {
var _this$props4 = this.props,
onExpandedChange = _this$props4.onExpandedChange,
rowKey = _this$props4.rowKey,
record = _this$props4.record;
if (this.expandable) {
onExpandedChange(false, record, null, rowKey, true);
}
}
}, {
key: "render",
value: function render() {
var _this$props5 = this.props,
childrenColumnName = _this$props5.childrenColumnName,
expandedRowRender = _this$props5.expandedRowRender,
indentSize = _this$props5.indentSize,
record = _this$props5.record,
fixed = _this$props5.fixed,
expanded = _this$props5.expanded;
this.expandIconAsCell = fixed !== 'right' ? this.props.expandIconAsCell : false;
this.expandIconColumnIndex = fixed !== 'right' ? this.props.expandIconColumnIndex : -1;
var childrenData = record[childrenColumnName];
this.expandable = !!(childrenData || expandedRowRender);
var expandableRowProps = {
indentSize: indentSize,
// not used in TableRow, but it's required to re-render TableRow when `expanded` changes
expanded: expanded,
onRowClick: this.handleRowClick,
hasExpandIcon: this.hasExpandIcon,
renderExpandIcon: this.renderExpandIcon,
renderExpandIconCell: this.renderExpandIconCell
};
return this.props.children(expandableRowProps);
}
}]);
return ExpandableRow;
}(_react.Component);
var _default = (0, _miniStore.connect)(function (_ref, _ref2) {
var expandedRowKeys = _ref.expandedRowKeys;
var rowKey = _ref2.rowKey;
return {
expanded: expandedRowKeys.includes(rowKey)
};
})(ExpandableRow);
exports["default"] = _default;
//# sourceMappingURL=ExpandableRow.js.map