UNPKG

@schema-render/search-table-react

Version:
286 lines (285 loc) 10.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return useSortColumns; } }); var _jsxruntime = require("react/jsx-runtime"); var _corereact = require("@schema-render/core-react"); var _react = require("react"); var _ColumnSettingModal = /*#__PURE__*/ _interop_require_default(require("../../components/ColumnSettingModal")); var _setting = require("./helpers/setting"); function _array_like_to_array(arr, len) { if (len == null || len > arr.length) len = arr.length; for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i]; return arr2; } function _array_with_holes(arr) { if (Array.isArray(arr)) return arr; } function _array_without_holes(arr) { if (Array.isArray(arr)) return _array_like_to_array(arr); } function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _async_to_generator(fn) { return function() { var self = this, args = arguments; return new Promise(function(resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _iterable_to_array(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } function _iterable_to_array_limit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){ _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally{ try { if (!_n && _i["return"] != null) _i["return"](); } finally{ if (_d) throw _e; } } return _arr; } function _non_iterable_rest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _non_iterable_spread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _sliced_to_array(arr, i) { return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest(); } function _to_consumable_array(arr) { return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread(); } function _unsupported_iterable_to_array(o, minLen) { if (!o) return; if (typeof o === "string") return _array_like_to_array(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen); } function _ts_generator(thisArg, body) { var f, y, t, g, _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }; return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; function verb(n) { return function(v) { return step([ n, v ]); }; } function step(op) { if (f) throw new TypeError("Generator is already executing."); while(_)try { if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [ op[0] & 2, t.value ]; switch(op[0]){ case 0: case 1: t = op; break; case 4: _.label++; return { value: op[1], done: false }; case 5: _.label++; y = op[1]; op = [ 0 ]; continue; case 7: op = _.ops.pop(); _.trys.pop(); continue; default: if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) { _.label = op[1]; break; } if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } if (t[2]) _.ops.pop(); _.trys.pop(); continue; } op = body.call(thisArg, _); } catch (e) { op = [ 6, e ]; y = 0; } finally{ f = t = 0; } if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; } } var pick = _corereact.utils.pick; function useSortColumns(param) { var baseColumns = param.baseColumns, table = param.table, globalStateRef = param.globalStateRef; var sortColumnsRef = (0, _react.useRef)([]); var _useState = _sliced_to_array((0, _react.useState)(false), 2), modalVisible = _useState[0], setModalVisible = _useState[1]; var _useState1 = _sliced_to_array((0, _react.useState)([]), 2), settingColumns = _useState1[0], setSettingColumns = _useState1[1]; var isTabChanging = globalStateRef.current.isTabChanging; // 「基础列」、「设置列」变换时,排序列重新生成 (0, _react.useMemo)(function() { // Tab 切换中不需要执行 if (isTabChanging) { return; } if (settingColumns.length) { var mergeAlgo = table.settingColumnsMergeAlgo || _setting.defaultColumnsMergeAlgo; sortColumnsRef.current = mergeAlgo(baseColumns, settingColumns); } else { // 浅复制一层,避免基础列数据被污染 sortColumnsRef.current = _to_consumable_array(baseColumns); } // eslint-disable-next-line react-hooks/exhaustive-deps }, [ baseColumns, settingColumns ]); // 打开列设置弹窗 var openSettingModal = (0, _corereact.useMemoizedFn)(function() { setModalVisible(true); }); // 关闭列设置弹窗 var closeSettingModal = (0, _corereact.useMemoizedFn)(function() { setModalVisible(false); }); // 保存排序数据 var handleOk = (0, _corereact.useMemoizedFn)(function(newSortColumns) { var _table_onSettingChanged; sortColumnsRef.current = newSortColumns; closeSettingModal(); // 触发设置改变事件 var storeColumns = newSortColumns.map(function(col) { return pick(col, 'title', 'dataIndex', 'width', 'hidden', 'fixed'); }); (_table_onSettingChanged = table.onSettingChanged) === null || _table_onSettingChanged === void 0 ? void 0 : _table_onSettingChanged.call(table, { columns: storeColumns }, table.settingId); }); var sortModalHolder = /*#__PURE__*/ (0, _jsxruntime.jsx)(_ColumnSettingModal.default, { open: modalVisible, sortColumns: sortColumnsRef.current, defaultColumns: baseColumns, onCancel: closeSettingModal, onOk: handleOk }); // 组件加载完毕、settingId 变化时,重新获取存储数据 (0, _corereact.useAsyncEffect)(/*#__PURE__*/ _async_to_generator(function() { var _table_getSetting, _data_columns, data; return _ts_generator(this, function(_state) { switch(_state.label){ case 0: return [ 4, (_table_getSetting = table.getSetting) === null || _table_getSetting === void 0 ? void 0 : _table_getSetting.call(table, table.settingId) ]; case 1: data = _state.sent(); if (data === null || data === void 0 ? void 0 : (_data_columns = data.columns) === null || _data_columns === void 0 ? void 0 : _data_columns.length) { setSettingColumns(data.columns); } return [ 2 ]; } }); }), [ table.settingId ]); return { sortColumns: sortColumnsRef.current, sortModalHolder: sortModalHolder, openSettingModal: openSettingModal, closeSettingModal: closeSettingModal }; }