UNPKG

choerodon-ui

Version:

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

340 lines (286 loc) 12.7 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 _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _react = _interopRequireWildcard(require("react")); var _mobxReactLite = require("mobx-react-lite"); var _mobx = require("mobx"); var _noop = _interopRequireDefault(require("lodash/noop")); var _collapse = _interopRequireDefault(require("../../../../lib/collapse")); var _CollapsePanel = _interopRequireDefault(require("../../../../lib/collapse/CollapsePanel")); var _columnGroups = _interopRequireDefault(require("./column-groups")); var _utils = require("../utils"); var _DataSet = _interopRequireDefault(require("../../data-set/DataSet")); var _TableContext = _interopRequireDefault(require("../TableContext")); var _localeContext = require("../../locale-context"); var _Button = _interopRequireDefault(require("../../button/Button")); var _enum = require("../../button/enum"); var _enum2 = require("../../core/enum"); var _Form = _interopRequireDefault(require("../../form/Form")); var _NumberField = _interopRequireDefault(require("../../number-field/NumberField")); var _SelectBox = _interopRequireDefault(require("../../select-box/SelectBox")); var _Option = _interopRequireDefault(require("../../option/Option")); var _enum3 = require("../../table/enum"); var _enum4 = require("../../form/enum"); var _enum5 = require("../../field/enum"); var _icon = _interopRequireDefault(require("../../icon")); var _treeUtils = require("../../_util/treeUtils"); function normalizeColumnsToTreeData(columns) { return (0, _treeUtils.treeReduce)(columns, function (list, column, _sort, parentColumn) { return list.concat({ key: (0, _utils.getColumnKey)(column), parentKey: parentColumn && (0, _utils.getColumnKey)(parentColumn), fixed: (0, _utils.getColumnFixed)(column.fixed), width: column.width, title: column.title, header: column.header, hidden: column.hidden, sort: column.sort, titleEditable: column.titleEditable, hideable: column.hideable }); }, []); } function diff() { var height = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; if (typeof document !== 'undefined') { return document.documentElement.clientHeight - height; } return 0; } var HEIGHT_CHANGE_KEY = '__heightChange__'; var CustomizationSettings = function CustomizationSettings(props) { var modal = props.modal; var _ref = modal || { update: _noop["default"], handleOk: _noop["default"] }, handleOk = _ref.handleOk, handleCancel = _ref.handleCancel; var _useContext = (0, _react.useContext)(_TableContext["default"]), tableStore = _useContext.tableStore; var originalColumns = tableStore.originalColumns, customized = tableStore.customized, prefixCls = tableStore.proPrefixCls; var _useState = (0, _react.useState)(originalColumns), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), customizedColumns = _useState2[0], setCustomizedColumns = _useState2[1]; var tableRecord = (0, _react.useMemo)(function () { return new _DataSet["default"]({ data: [{ heightType: tableStore.heightType, height: tableStore.totalHeight, heightDiff: diff(tableStore.totalHeight) }], events: { update: function update(_ref2) { var record = _ref2.record, name = _ref2.name, value = _ref2.value; record.setState(HEIGHT_CHANGE_KEY, (record.getState(HEIGHT_CHANGE_KEY) || 0) + 1); var tempCustomized = tableStore.tempCustomized; if (tempCustomized) { (0, _mobx.set)(tempCustomized, name, value); if (name === 'heightType') { if (value === _enum3.TableHeightType.fixed) { (0, _mobx.set)(tempCustomized, 'height', record.get('height')); } else if (value === _enum3.TableHeightType.flex) { (0, _mobx.set)(tempCustomized, 'heightDiff', record.get('heightDiff')); } } else if (name === 'height' && record.get('heightType') === _enum3.TableHeightType.fixed) { record.set('heightDiff', diff(value)); (0, _mobx.set)(tempCustomized, 'heightType', _enum3.TableHeightType.fixed); } else if (name === 'heightDiff' && record.get('heightType') === _enum3.TableHeightType.flex) { record.set('height', diff(value)); (0, _mobx.set)(tempCustomized, 'heightType', _enum3.TableHeightType.flex); } } record.setState(HEIGHT_CHANGE_KEY, record.getState(HEIGHT_CHANGE_KEY) - 1); if (record.getState(HEIGHT_CHANGE_KEY) === 0) { tableStore.node.handleHeightTypeChange(); record.setState(HEIGHT_CHANGE_KEY, undefined); } } } }).current; }, [tableStore]); var columnDataSet = (0, _react.useMemo)(function () { return new _DataSet["default"]({ data: normalizeColumnsToTreeData(customizedColumns), paging: false, primaryKey: 'key', idField: 'key', parentField: 'parentKey', fields: [{ name: 'fixed', group: true }], events: { update: function update(_ref3) { var record = _ref3.record, name = _ref3.name, value = _ref3.value; if (name === 'hidden') { var records = record.children; if (records) { records.forEach(function (child) { return child.set(name, value); }); } } var tempCustomized = tableStore.tempCustomized; if (tempCustomized) { var key = record.key; if (!tempCustomized.columns[key]) { tempCustomized.columns[key] = {}; } tempCustomized.columns[key][name] = value; } } } }); }, [customizedColumns, tableStore]); var handleRestoreTable = (0, _react.useCallback)((0, _mobx.action)(function (e) { e.stopPropagation(); var originalHeightType = tableStore.originalHeightType; tableStore.node.handleHeightTypeChange(); tableRecord.init({ heightType: originalHeightType, height: tableStore.totalHeight, heightDiff: diff(tableStore.totalHeight) }); }), [tableRecord, tableStore]); var handleRestoreColumns = (0, _react.useCallback)((0, _mobx.action)(function (e) { e.stopPropagation(); var _tableStore$node$prop = tableStore.node.props.columns, columns = _tableStore$node$prop === void 0 ? [] : _tableStore$node$prop; setCustomizedColumns(columns.map(function (column) { var fixed = (0, _utils.getColumnFixed)(column.fixed); var hidden = column.hidden || false; return (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, column), {}, { fixed: fixed, hidden: hidden }); })); tableStore.tempCustomized.columns = {}; }), [tableRecord, tableStore]); var handleOption = (0, _react.useCallback)(function () { return { className: "".concat(prefixCls, "-customization-option") }; }, [prefixCls]); var handleCollapseChange = (0, _react.useCallback)((0, _mobx.action)(function (key) { tableStore.customizedActiveKey = [].concat(key); }), [tableStore]); (0, _react.useEffect)((0, _mobx.action)(function () { tableStore.tempCustomized = (0, _objectSpread2["default"])({ height: tableStore.totalHeight, heightDiff: diff(tableStore.totalHeight) }, (0, _mobx.toJS)(customized)); }), [tableStore]); (0, _react.useEffect)(function () { if (handleOk) { handleOk((0, _mobx.action)(function () { var tempCustomized = tableStore.tempCustomized; tableStore.tempCustomized = { columns: {} }; tableStore.saveCustomized(tempCustomized); tableStore.initColumns(); tableStore.node.handleHeightTypeChange(); })); } if (handleCancel) { handleCancel((0, _mobx.action)(function () { tableStore.tempCustomized = { columns: {} }; tableStore.node.handleHeightTypeChange(); })); } }, [handleOk, handleCancel, columnDataSet, tableStore]); var renderIcon = (0, _react.useCallback)(function (_ref4) { var isActive = _ref4.isActive; return /*#__PURE__*/_react["default"].createElement(_icon["default"], { type: isActive ? 'expand_more' : 'navigate_next' }); }, []); var tableHeightType = tableRecord.get('heightType'); return /*#__PURE__*/_react["default"].createElement(_collapse["default"], { activeKey: tableStore.customizedActiveKey.slice(), onChange: handleCollapseChange, expandIcon: renderIcon, expandIconPosition: "text-right", className: "".concat(prefixCls, "-customization"), ghost: true }, /*#__PURE__*/_react["default"].createElement(_CollapsePanel["default"], { header: /*#__PURE__*/_react["default"].createElement("span", { className: "".concat(prefixCls, "-customization-panel-title") }, (0, _localeContext.$l)('Table', 'table_settings')), key: "table", extra: /*#__PURE__*/_react["default"].createElement(_Button["default"], { className: "".concat(prefixCls, "-customization-header-button"), color: _enum.ButtonColor.primary, funcType: _enum.FuncType.flat, size: _enum2.Size.small, onClick: handleRestoreTable }, (0, _localeContext.$l)('Table', 'restore_default')) }, /*#__PURE__*/_react["default"].createElement(_Form["default"], { className: "".concat(prefixCls, "-customization-form"), record: tableRecord, labelLayout: _enum4.LabelLayout["float"] }, /*#__PURE__*/_react["default"].createElement(_SelectBox["default"], { vertical: true, name: "heightType", label: (0, _localeContext.$l)('Table', 'height_settings'), onOption: handleOption }, /*#__PURE__*/_react["default"].createElement(_Option["default"], { value: _enum3.TableHeightType.auto }, (0, _localeContext.$l)('Table', 'auto_height')), /*#__PURE__*/_react["default"].createElement(_Option["default"], { value: _enum3.TableHeightType.fixed }, /*#__PURE__*/_react["default"].createElement("span", { className: "".concat(prefixCls, "-customization-option-label") }, (0, _localeContext.$l)('Table', 'fixed_height')), /*#__PURE__*/_react["default"].createElement(_NumberField["default"], { className: "".concat(prefixCls, "-customization-option-input"), labelLayout: _enum4.LabelLayout.none, name: "height", disabled: tableHeightType !== _enum3.TableHeightType.fixed, step: 1 })), /*#__PURE__*/_react["default"].createElement(_Option["default"], { value: _enum3.TableHeightType.flex }, /*#__PURE__*/_react["default"].createElement("span", { className: "".concat(prefixCls, "-customization-option-label") }, (0, _localeContext.$l)('Table', 'flex_height')), /*#__PURE__*/_react["default"].createElement(_NumberField["default"], { groupClassName: "".concat(prefixCls, "-customization-option-input"), labelLayout: _enum4.LabelLayout.none, name: "heightDiff", disabled: tableHeightType !== _enum3.TableHeightType.flex, showHelp: _enum5.ShowHelp.tooltip, help: (0, _localeContext.$l)('Table', 'flex_height_help'), step: 1 }))))), /*#__PURE__*/_react["default"].createElement(_CollapsePanel["default"], { header: /*#__PURE__*/_react["default"].createElement("span", { className: "".concat(prefixCls, "-customization-panel-title") }, (0, _localeContext.$l)('Table', 'column_settings')), key: "columns", extra: /*#__PURE__*/_react["default"].createElement(_Button["default"], { className: "".concat(prefixCls, "-customization-header-button"), color: _enum.ButtonColor.primary, funcType: _enum.FuncType.flat, size: _enum2.Size.small, onClick: handleRestoreColumns }, (0, _localeContext.$l)('Table', 'restore_default')) }, /*#__PURE__*/_react["default"].createElement(_columnGroups["default"], { dataSet: columnDataSet }))); }; CustomizationSettings.displayName = 'CustomizationSettings'; var _default = (0, _mobxReactLite.observer)(CustomizationSettings); exports["default"] = _default; //# sourceMappingURL=CustomizationSettings.js.map