choerodon-ui
Version:
An enterprise-class UI design language and React-based implementation
187 lines (148 loc) • 6.76 kB
JavaScript
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 _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
var _tslib = require("tslib");
var _react = _interopRequireWildcard(require("react"));
var _mobxReact = require("mobx-react");
var _isObject = _interopRequireDefault(require("lodash/isObject"));
var _Table = require("../Table");
var _TableContext = _interopRequireDefault(require("../TableContext"));
var _autobind = _interopRequireDefault(require("../../_util/autobind"));
var _utils = require("../../table/utils");
var _TableProfessionalBar = _interopRequireDefault(require("./TableProfessionalBar"));
var _TableDynamicFilterBar = _interopRequireDefault(require("./TableDynamicFilterBar"));
var PerformanceTableQueryBar = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(PerformanceTableQueryBar, _Component);
var _super = (0, _createSuper2["default"])(PerformanceTableQueryBar);
function PerformanceTableQueryBar() {
(0, _classCallCheck2["default"])(this, PerformanceTableQueryBar);
return _super.apply(this, arguments);
}
(0, _createClass2["default"])(PerformanceTableQueryBar, [{
key: "handleQueryReset",
value: function handleQueryReset() {
var queryDataSet = this.context.tableStore.dataSet.queryDataSet;
if (queryDataSet) {
var current = queryDataSet.current;
if (current) {
current.reset();
}
this.handleQuery();
}
}
}, {
key: "handleQuery",
value: function handleQuery() {
var dataSet = this.context.tableStore.dataSet;
return dataSet.query();
}
}, {
key: "getQueryFields",
value: function getQueryFields() {
var _this$context$tableSt = this.context.tableStore,
dataSet = _this$context$tableSt.dataSet,
_this$context$tableSt2 = _this$context$tableSt.queryBar,
_this$context$tableSt3 = _this$context$tableSt2.queryFields,
queryFields = _this$context$tableSt3 === void 0 ? {} : _this$context$tableSt3,
type = _this$context$tableSt2.type;
var queryDataSet = dataSet.queryDataSet;
var result = [];
if (queryDataSet) {
var fields = queryDataSet.fields,
current = queryDataSet.current;
fields.forEach(function (field, name) {
if (!field.get('bind', current) && !name.includes('__tls')) {
var element = queryFields[name];
var filterBarProps = {};
if (type === _Table.TableQueryBarType.filterBar) {
var placeholder = /*#__PURE__*/(0, _react.isValidElement)(element) && element.props.placeholder ? element.props.placeholder : (0, _utils.getPlaceholderByField)(field, current);
filterBarProps = {
placeholder: placeholder,
border: false,
clearButton: true
};
}
var props = (0, _objectSpread2["default"])({
key: name,
name: name,
dataSet: queryDataSet,
isFlat: type === _Table.TableQueryBarType.filterBar
}, filterBarProps);
result.push( /*#__PURE__*/(0, _react.isValidElement)(element) ? /*#__PURE__*/(0, _react.cloneElement)(element, props) : /*#__PURE__*/(0, _react.cloneElement)((0, _utils.getEditorByField)(field, current, type !== _Table.TableQueryBarType.professionalBar, type === _Table.TableQueryBarType.filterBar), (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, props), (0, _isObject["default"])(element) ? element : {})));
}
});
}
return result;
}
}, {
key: "renderProfessionalBar",
value: function renderProfessionalBar(props) {
var prefixCls = this.context.tableStore.prefixCls;
return /*#__PURE__*/_react["default"].createElement(_TableProfessionalBar["default"], (0, _extends2["default"])({
key: "toolbar",
prefixCls: prefixCls
}, props));
}
}, {
key: "renderDynamicFilterBar",
value: function renderDynamicFilterBar(props) {
var prefixCls = this.context.tableStore.prefixCls; // @ts-ignore
return /*#__PURE__*/_react["default"].createElement(_TableDynamicFilterBar["default"], (0, _extends2["default"])({
key: "toolbar",
prefixCls: prefixCls
}, props));
}
}, {
key: "render",
value: function render() {
var _this$context$tableSt4 = this.context.tableStore,
queryBar = _this$context$tableSt4.queryBar,
dataSet = _this$context$tableSt4.dataSet;
if (dataSet) {
var queryFields = this.getQueryFields();
var queryDataSet = dataSet.queryDataSet;
var props = (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, queryBar), {}, {
queryFields: queryFields,
queryDataSet: queryDataSet
});
if (typeof queryBar.renderer === 'function') {
return queryBar.renderer(props);
}
switch (queryBar.type) {
case _Table.TableQueryBarType.professionalBar:
return this.renderProfessionalBar(props);
case _Table.TableQueryBarType.filterBar:
return this.renderDynamicFilterBar(props);
default:
}
}
return null;
}
}], [{
key: "contextType",
get: function get() {
return _TableContext["default"];
}
}]);
return PerformanceTableQueryBar;
}(_react.Component);
PerformanceTableQueryBar.displayName = 'PerformanceTableQueryBar';
PerformanceTableQueryBar.defaultProps = {
queryFieldsLimit: 3
};
(0, _tslib.__decorate)([_autobind["default"]], PerformanceTableQueryBar.prototype, "handleQueryReset", null);
(0, _tslib.__decorate)([_autobind["default"]], PerformanceTableQueryBar.prototype, "handleQuery", null);
PerformanceTableQueryBar = (0, _tslib.__decorate)([_mobxReact.observer], PerformanceTableQueryBar);
var _default = PerformanceTableQueryBar;
exports["default"] = _default;
//# sourceMappingURL=index.js.map
;