@kdcloudjs/table 1.1.3-canary.5 → 1.1.3-canary.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/LICENSE +568 -568
  2. package/README.md +111 -111
  3. package/dist/@kdcloudjs/table.css +1 -1
  4. package/dist/@kdcloudjs/table.js +1366 -1093
  5. package/dist/@kdcloudjs/table.js.map +1 -1
  6. package/dist/@kdcloudjs/table.min.css +1 -1
  7. package/dist/@kdcloudjs/table.min.js +24 -15
  8. package/dist/@kdcloudjs/table.min.js.map +1 -1
  9. package/dist/kd-ui-complete.less +777 -777
  10. package/es/style/color/colors.less +1 -1
  11. package/es/style/core/index.less +1 -1
  12. package/es/style/core/motion/other.less +27 -27
  13. package/es/style/core/motion/slide.less +53 -53
  14. package/es/style/core/motion.less +1 -1
  15. package/es/style/core/reset.less +185 -185
  16. package/es/style/index.less +1 -1
  17. package/es/style/mixins/index.less +18 -18
  18. package/es/style/mixins/overlay.less +21 -21
  19. package/es/style/mixins/reset.less +12 -12
  20. package/es/style/themes/default.less +445 -445
  21. package/es/table/base/helpers/getRichVisibleRectsStream.js +1 -1
  22. package/es/table/pipeline/features/columnFilter.d.ts +1 -1
  23. package/es/table/pipeline/features/columnFilter.js +35 -15
  24. package/es/table/pipeline/features/filter/Filter.js +1 -1
  25. package/es/table/pipeline/features/filter/FilterPanel.js +1 -1
  26. package/es/table/pipeline/features/filter/util.js +4 -4
  27. package/es/table/pipeline/features/multiSelect.js +3 -2
  28. package/es/table/pipeline/features/treeMode.d.ts +2 -0
  29. package/es/table/pipeline/features/treeMode.js +18 -20
  30. package/es/table/style/index.less +1 -1
  31. package/lib/style/color/colors.less +1 -1
  32. package/lib/style/components.less +1 -1
  33. package/lib/style/core/index.less +1 -1
  34. package/lib/style/core/motion/other.less +27 -27
  35. package/lib/style/core/motion/slide.less +53 -53
  36. package/lib/style/core/motion.less +1 -1
  37. package/lib/style/core/reset.less +185 -185
  38. package/lib/style/index.less +1 -1
  39. package/lib/style/mixins/index.less +18 -18
  40. package/lib/style/mixins/overlay.less +21 -21
  41. package/lib/style/mixins/reset.less +12 -12
  42. package/lib/style/themes/default.less +445 -445
  43. package/lib/table/base/helpers/getRichVisibleRectsStream.js +1 -1
  44. package/lib/table/pipeline/features/columnFilter.d.ts +1 -1
  45. package/lib/table/pipeline/features/columnFilter.js +33 -15
  46. package/lib/table/pipeline/features/filter/Filter.js +1 -1
  47. package/lib/table/pipeline/features/filter/FilterPanel.js +1 -1
  48. package/lib/table/pipeline/features/filter/util.js +4 -4
  49. package/lib/table/pipeline/features/multiSelect.js +2 -1
  50. package/lib/table/pipeline/features/treeMode.d.ts +2 -0
  51. package/lib/table/pipeline/features/treeMode.js +19 -22
  52. package/lib/table/style/index.less +1 -1
  53. package/package.json +218 -218
  54. package/CHANGELOG.md +0 -0
@@ -42,7 +42,7 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof _WeakMap !== "functi
42
42
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && _Object$getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? _Object$getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
43
43
 
44
44
  function isWindow(arg) {
45
- return arg.toString() === '[object Window]';
45
+ return arg.toString() === '[object Window]' || arg.toString() === '[object global]';
46
46
  }
47
47
 
48
48
  function isBody(arg) {
@@ -12,7 +12,7 @@ export interface FilterFeatureOptions {
12
12
  keepDataSource?: boolean;
13
13
  /** 过滤模式。单列过滤 single,多列过滤 multiple,默认为多选 */
14
14
  mode?: 'single' | 'multiple';
15
- /**过滤图标 */
15
+ /** 过滤图标 */
16
16
  filterIcon?: ReactNode;
17
17
  /** 是否对触发弹出过滤面板 的 click 事件调用 event.stopPropagation() */
18
18
  stopClickEventPropagation?: boolean;
@@ -65,7 +65,7 @@ function filter() {
65
65
  return (0, _map2.default)(columns).call(columns, dfs);
66
66
 
67
67
  function dfs(col) {
68
- var _a, _b, _c, _d, _e;
68
+ var _a, _b, _c, _d, _e, _f, _g;
69
69
 
70
70
  var result = (0, _extends2.default)({}, col);
71
71
  var filterable = col.code && ((_a = col.features) === null || _a === void 0 ? void 0 : _a.filterable);
@@ -104,12 +104,13 @@ function filter() {
104
104
  };
105
105
 
106
106
  var filterPanel = (_d = col.features) === null || _d === void 0 ? void 0 : _d.filterPanel;
107
- result.title = (0, _concat.default)(_context = []).call(_context, (0, _toConsumableArray2.default)((0, _concat.default)(_context2 = []).call(_context2, (_e = result.title) !== null && _e !== void 0 ? _e : [_internals.internals.safeRenderHeader((0, _extends2.default)((0, _extends2.default)({}, col), {
107
+ var colFilterIcon = (_f = (_e = col.features) === null || _e === void 0 ? void 0 : _e.filterIcon) !== null && _f !== void 0 ? _f : filterIcon;
108
+ result.title = (0, _concat.default)(_context = []).call(_context, (0, _toConsumableArray2.default)((0, _concat.default)(_context2 = []).call(_context2, (_g = result.title) !== null && _g !== void 0 ? _g : [_internals.internals.safeRenderHeader((0, _extends2.default)((0, _extends2.default)({}, col), {
108
109
  title: null
109
110
  }))])), [/*#__PURE__*/_react.default.createElement(_filter2.Filter, {
110
111
  key: "filter",
111
112
  FilterPanelContent: filterPanel,
112
- filterIcon: filterIcon,
113
+ filterIcon: colFilterIcon,
113
114
  filterModel: inputFiltersMap.get(col.code),
114
115
  setFilterModel: handleFilterChanged,
115
116
  setFilter: setFilter,
@@ -157,8 +158,8 @@ function filter() {
157
158
  return [item.key, (0, _extends2.default)({}, item)];
158
159
  }));
159
160
 
160
- function isMatchedFilterCondition(record, rowIndex) {
161
- return !filtersKeys.some(function (key) {
161
+ function isMatchedFilterCondition(record) {
162
+ return filtersKeys.every(function (key) {
162
163
  var _a, _b;
163
164
 
164
165
  var filterItem = inputFiltersMap.get(key);
@@ -172,24 +173,41 @@ function filter() {
172
173
  } else {
173
174
  console.warn("\u5217[".concat(key, "]\u672A\u914D\u7F6E\u7B5B\u9009\u51FD\u6570\uFF0C\u8BF7\u8BBE\u7F6E column.features.filterable \u6765\u4F5C\u4E3A\u8BE5\u5217\u7684\u7B5B\u9009\u51FD\u6570, \u76EE\u524D\u4F7F\u7528\u9ED8\u8BA4\u5305\u542B\u7B5B\u9009\u51FD\u6570"));
174
175
  comparisonFn = (0, _filter.default)(defaultFilterOptionsMap.get('contain'));
175
- } // 不符合过滤条件,退出循环
176
+ }
176
177
 
177
-
178
- return !comparisonFn((0, _filter.default)(filterItem), filterItem)(_internals.internals.safeGetValue(columnsMap.get(key), record, rowIndex), record);
178
+ return comparisonFn((0, _filter.default)(filterItem), filterItem)(_internals.internals.safeGetValue(columnsMap.get(key), record, -1), record);
179
179
  });
180
180
  }
181
181
 
182
- return dataSource.reduce(function (pre, record, rowIndex) {
183
- if (isMatchedFilterCondition(record, rowIndex)) {
184
- return (0, _concat.default)(pre).call(pre, [record]);
185
- }
186
-
187
- return pre;
188
- }, []);
182
+ return layeredFilter(dataSource, isMatchedFilterCondition);
189
183
  }
190
184
 
191
185
  pipeline.dataSource(processDataSource(dataSource));
192
186
  pipeline.columns(processColumns(columns));
193
187
  return pipeline;
194
188
  };
189
+ }
190
+
191
+ function layeredFilter(array, matchFn) {
192
+ return dfs(array);
193
+
194
+ function dfs(rows) {
195
+ var _context6;
196
+
197
+ var parentMatched = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
198
+ return (0, _filter.default)(_context6 = (0, _map2.default)(rows).call(rows, function (row) {
199
+ var currentMatched = matchFn(row);
200
+
201
+ if ((0, _utils.isLeafNode)(row)) {
202
+ return (parentMatched || currentMatched) && (0, _extends2.default)({}, row);
203
+ }
204
+
205
+ var children = row.children;
206
+ var rowAfterFilterChildren = (0, _extends2.default)((0, _extends2.default)({}, row), {
207
+ children: dfs(children, parentMatched || currentMatched)
208
+ });
209
+ var matchedByChildren = !(0, _utils.isLeafNode)(rowAfterFilterChildren);
210
+ return (parentMatched || currentMatched || matchedByChildren) && rowAfterFilterChildren;
211
+ })).call(_context6, Boolean);
212
+ }
195
213
  }
@@ -167,7 +167,7 @@ function Filter(_ref2) {
167
167
  fill: "currentColor",
168
168
  "aria-hidden": "true"
169
169
  }, /*#__PURE__*/_react.default.createElement("path", {
170
- d: "M349 838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3\r\n 31.8-32V642H349v196zm531.1-684H143.9c-24.5 0-39.8 26.7-27.5\r\n 48l221.3 376h348.8l221.3-376c12.1-21.3-3.2-48-27.7-48z"
170
+ d: "M349 838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3\n 31.8-32V642H349v196zm531.1-684H143.9c-24.5 0-39.8 26.7-27.5\n 48l221.3 376h348.8l221.3-376c12.1-21.3-3.2-48-27.7-48z"
171
171
  }))), showPanel && /*#__PURE__*/(0, _reactDom.createPortal)( /*#__PURE__*/_react.default.createElement(Panel, {
172
172
  ele: iconRef.current,
173
173
  filterIcon: filterIcon,
@@ -96,7 +96,7 @@ function FilterPanel(_ref) {
96
96
  fill: "currentColor",
97
97
  "aria-hidden": "true"
98
98
  }, /*#__PURE__*/_react.default.createElement("path", {
99
- d: "M349 838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3\r\n 31.8-32V642H349v196zm531.1-684H143.9c-24.5 0-39.8 26.7-27.5\r\n 48l221.3 376h348.8l221.3-376c12.1-21.3-3.2-48-27.7-48z"
99
+ d: "M349 838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3\n 31.8-32V642H349v196zm531.1-684H143.9c-24.5 0-39.8 26.7-27.5\n 48l221.3 376h348.8l221.3-376c12.1-21.3-3.2-48-27.7-48z"
100
100
  })))), /*#__PURE__*/_react.default.createElement("div", {
101
101
  className: "popup-body"
102
102
  }, children));
@@ -22,7 +22,7 @@ var DEFAULT_FILTER_OPTIONS = [{
22
22
  data = data + '';
23
23
  }
24
24
 
25
- return (0, _includes.default)(data).call(data, value);
25
+ return (0, _includes.default)(data).call(data, value[0]);
26
26
  };
27
27
  }
28
28
  }, {
@@ -38,7 +38,7 @@ var DEFAULT_FILTER_OPTIONS = [{
38
38
  data = data + '';
39
39
  }
40
40
 
41
- return !(0, _includes.default)(data).call(data, value);
41
+ return !(0, _includes.default)(data).call(data, value[0]);
42
42
  };
43
43
  }
44
44
  }, {
@@ -46,7 +46,7 @@ var DEFAULT_FILTER_OPTIONS = [{
46
46
  key: 'equal',
47
47
  filter: function filter(value) {
48
48
  return function (data) {
49
- return value !== data;
49
+ return value[0] === data;
50
50
  };
51
51
  }
52
52
  }, {
@@ -54,7 +54,7 @@ var DEFAULT_FILTER_OPTIONS = [{
54
54
  key: 'notEqual',
55
55
  filter: function filter(value) {
56
56
  return function (data) {
57
- return value !== data;
57
+ return value[0] !== data;
58
58
  };
59
59
  }
60
60
  }, {
@@ -61,7 +61,8 @@ function multiSelect() {
61
61
  /** 所有有效的 keys(disable 状态为 false) */
62
62
 
63
63
  var allKeys = [];
64
- dataSource.forEach(function (row, rowIndex) {
64
+ var flatDataSource = (0, _utils.collectNodes)(dataSource);
65
+ flatDataSource.forEach(function (row, rowIndex) {
65
66
  var rowKey = _internals.internals.safeGetRowKey(primaryKey, row, rowIndex);
66
67
 
67
68
  fullKeySet.add(rowKey); // 在 allKeys 中排除被禁用的 key
@@ -32,6 +32,8 @@ export interface TreeModeFeatureOptions {
32
32
  stopClickEventPropagation?: boolean;
33
33
  /** 指定表格每一行元信息的记录字段 */
34
34
  treeMetaKey?: string | symbol;
35
+ /** 指定展开列 */
36
+ expandColCode?: string;
35
37
  }
36
38
  export declare function treeMode(opts?: TreeModeFeatureOptions): (pipeline: TablePipeline) => TablePipeline;
37
39
  export {};
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- var _sliceInstanceProperty2 = require("@babel/runtime-corejs3/core-js-stable/instance/slice");
3
+ var _sliceInstanceProperty = require("@babel/runtime-corejs3/core-js-stable/instance/slice");
4
4
 
5
5
  var _Array$from = require("@babel/runtime-corejs3/core-js-stable/array/from");
6
6
 
@@ -16,8 +16,6 @@ Object.defineProperty(exports, "__esModule", {
16
16
  exports.treeMetaSymbol = void 0;
17
17
  exports.treeMode = treeMode;
18
18
 
19
- var _toArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/toArray"));
20
-
21
19
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
22
20
 
23
21
  var _extends3 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
@@ -32,7 +30,7 @@ var _filter = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-sta
32
30
 
33
31
  var _concat = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat"));
34
32
 
35
- var _slice = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/slice"));
33
+ var _findIndex = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/find-index"));
36
34
 
37
35
  var _classnames = _interopRequireDefault(require("classnames"));
38
36
 
@@ -48,7 +46,7 @@ var _styles = require("../../base/styles");
48
46
 
49
47
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof _Symbol2 !== "undefined" && _getIteratorMethod(o) || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
50
48
 
51
- function _unsupportedIterableToArray(o, minLen) { var _context3; if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = _sliceInstanceProperty2(_context3 = Object.prototype.toString.call(o)).call(_context3, 8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return _Array$from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
49
+ function _unsupportedIterableToArray(o, minLen) { var _context2; if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = _sliceInstanceProperty(_context2 = Object.prototype.toString.call(o)).call(_context2, 8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return _Array$from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
52
50
 
53
51
  function _arrayLikeToArray(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; }
54
52
 
@@ -63,11 +61,6 @@ function treeMode() {
63
61
  var stateKey = 'treeMode';
64
62
  var ctx = pipeline.ctx;
65
63
  var primaryKey = pipeline.ensurePrimaryKey('treeMode');
66
-
67
- if (typeof primaryKey !== 'string') {
68
- throw new Error('treeMode 仅支持字符串作为 primaryKey');
69
- }
70
-
71
64
  var openKeys = (_c = (_b = (_a = opts.openKeys) !== null && _a !== void 0 ? _a : pipeline.getStateAtKey(stateKey)) !== null && _b !== void 0 ? _b : opts.defaultOpenKeys) !== null && _c !== void 0 ? _c : [];
72
65
  var openKeySet = new _set.default(openKeys);
73
66
 
@@ -122,7 +115,9 @@ function treeMode() {
122
115
  try {
123
116
  for (_iterator.s(); !(_step = _iterator.n()).done;) {
124
117
  var node = _step.value;
125
- var rowKey = node[primaryKey];
118
+
119
+ var rowKey = _internals.internals.safeGetRowKey(primaryKey, node, -1);
120
+
126
121
  var expanded = openKeySet.has(rowKey);
127
122
  var isLeaf = isLeafNode(node, {
128
123
  depth: depth,
@@ -152,18 +147,19 @@ function treeMode() {
152
147
  }
153
148
 
154
149
  function processColumns(columns) {
155
- var _context2;
156
-
157
150
  if (columns.length === 0) {
158
151
  return columns;
159
152
  }
160
153
 
161
- var _columns = (0, _toArray2.default)(columns),
162
- firstCol = _columns[0],
163
- others = (0, _slice.default)(_columns).call(_columns, 1);
154
+ var expandColIndex = (0, _findIndex.default)(columns).call(columns, function (_ref) {
155
+ var code = _ref.code;
156
+ return code && opts.expandColCode === code;
157
+ });
158
+ expandColIndex = expandColIndex === -1 ? 0 : expandColIndex;
159
+ var expandCol = columns[expandColIndex];
164
160
 
165
161
  var render = function render(value, record, recordIndex) {
166
- var content = _internals.internals.safeRender(firstCol, record, recordIndex);
162
+ var content = _internals.internals.safeRender(expandCol, record, recordIndex);
167
163
 
168
164
  if (record[treeMetaKey] == null) {
169
165
  // 没有 treeMeta 信息的话,就返回原先的渲染结果
@@ -223,7 +219,7 @@ function treeMode() {
223
219
  };
224
220
 
225
221
  var getCellProps = function getCellProps(value, record, rowIndex) {
226
- var prevProps = _internals.internals.safeGetCellProps(firstCol, record, rowIndex);
222
+ var prevProps = _internals.internals.safeGetCellProps(expandCol, record, rowIndex);
227
223
 
228
224
  if (record[treeMetaKey] == null) {
229
225
  // 没有 treeMeta 信息的话,就返回原先的 cellProps
@@ -252,15 +248,16 @@ function treeMode() {
252
248
  });
253
249
  };
254
250
 
255
- return (0, _concat.default)(_context2 = [(0, _extends3.default)((0, _extends3.default)({}, firstCol), {
251
+ columns[expandColIndex] = (0, _extends3.default)((0, _extends3.default)({}, expandCol), {
256
252
  title: /*#__PURE__*/_react.default.createElement("span", {
257
253
  style: {
258
254
  marginLeft: iconIndent + iconWidth + iconGap
259
255
  }
260
- }, _internals.internals.safeRenderHeader(firstCol)),
256
+ }, _internals.internals.safeRenderHeader(expandCol)),
261
257
  render: render,
262
- getCellProps: clickArea === 'cell' ? getCellProps : firstCol.getCellProps
263
- })]).call(_context2, (0, _toConsumableArray2.default)(others));
258
+ getCellProps: clickArea === 'cell' ? getCellProps : expandCol.getCellProps
259
+ });
260
+ return (0, _toConsumableArray2.default)(columns);
264
261
  }
265
262
  };
266
263
  }
@@ -1 +1 @@
1
-
1
+