UNPKG

choerodon-ui

Version:

An enterprise-class UI design language and React-based implementation

187 lines (148 loc) 6.76 kB
"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 _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