nsc-react-component 1.2.4 → 1.2.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.
@@ -1,10 +1,41 @@
1
1
  function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
2
2
 
3
- var _excluded = ["resizeColumn"];
3
+ import "antd/es/table/style/css";
4
+ import _Table from "antd/es/table";
5
+ import "antd/es/popover/style/css";
6
+ import _Popover from "antd/es/popover";
7
+ import "antd/es/tooltip/style/css";
8
+ import _Tooltip from "antd/es/tooltip";
9
+ import "antd/es/checkbox/style/css";
10
+ import _Checkbox from "antd/es/checkbox";
11
+ var _excluded = ["onResize", "width"],
12
+ _excluded2 = ["listeners"];
4
13
 
5
- function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
14
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
6
15
 
7
- function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
16
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
17
+
18
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
19
+
20
+ function _iterableToArrayLimit(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; }
21
+
22
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
23
+
24
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
25
+
26
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
27
+
28
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
29
+
30
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
31
+
32
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(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(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
33
+
34
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
35
+
36
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
37
+
38
+ 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; }
8
39
 
9
40
  function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
10
41
 
@@ -28,6 +59,10 @@ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.g
28
59
 
29
60
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
30
61
 
62
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
63
+
64
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
65
+
31
66
  /*
32
67
  * @Descripttion:
33
68
  * @version:
@@ -36,36 +71,559 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
36
71
  * @LastEditors: rxzhu
37
72
  * @LastEditTime: 2021-03-23 10:30:42
38
73
  */
74
+ import { AppstoreOutlined } from "@ant-design/icons";
75
+ import { isEmptyObj } from "@bj-nsc/functions";
76
+ import Store, { PageStore } from "@bj-nsc/msn";
77
+ import { utils } from "@bj-nsc/msn/lib/utils";
39
78
  import * as React from "react";
40
- import { DndContextType, IBodyRowProps } from "../common/BodyRow";
79
+ import { DndProvider } from "react-dnd";
80
+ import BodyRow, { DndContextType, IBodyRowProps } from "../common/BodyRow";
81
+ import treeUtils from "../treeUtils";
82
+ import styles from "./index.less";
83
+ var BodyRowComponent = BodyRow.BodyRowComponent,
84
+ HTML5Backend = BodyRow.HTML5Backend;
41
85
  import withZhLocale from "../common/withZhLocale";
42
- import ResizeTable from "./ResizeColumn";
43
- import NormalTable from "./NormalTabl";
86
+ import { NoData } from "..";
87
+ import { Resizable } from "react-resizable";
88
+ import "./resize.less";
44
89
  export { DndContextType, IBodyRowProps };
45
90
 
91
+ var ResizeableTitle = function ResizeableTitle(props) {
92
+ var onResize = props.onResize,
93
+ width = props.width,
94
+ restProps = _objectWithoutProperties(props, _excluded);
95
+
96
+ return /*#__PURE__*/React.createElement(Resizable, {
97
+ width: width || 150,
98
+ height: 0,
99
+ onResize: onResize,
100
+ draggableOpts: {
101
+ enableUserSelectHack: false
102
+ }
103
+ }, /*#__PURE__*/React.createElement("th", restProps));
104
+ };
105
+
46
106
  var NSCTable = /*#__PURE__*/function (_React$Component) {
47
107
  _inherits(NSCTable, _React$Component);
48
108
 
49
109
  var _super = _createSuper(NSCTable);
50
110
 
51
- function NSCTable() {
111
+ function NSCTable(props) {
112
+ var _this2;
113
+
52
114
  _classCallCheck(this, NSCTable);
53
115
 
54
- return _super.apply(this, arguments);
116
+ _this2 = _super.call(this, props);
117
+
118
+ _defineProperty(_assertThisInitialized(_this2), "store", {});
119
+
120
+ _defineProperty(_assertThisInitialized(_this2), "thIconRef", /*#__PURE__*/React.createRef());
121
+
122
+ _defineProperty(_assertThisInitialized(_this2), "state", {
123
+ dataSource: [],
124
+ columns: [],
125
+ loading: false,
126
+ pagination: {},
127
+ activeIndex: -1,
128
+ //搜索文本
129
+ searchText: null,
130
+ fieldOption: null,
131
+ searchColor: null,
132
+ cols: []
133
+ });
134
+
135
+ _defineProperty(_assertThisInitialized(_this2), "listeners", {
136
+ onBeforeLoad: null,
137
+ load: null
138
+ });
139
+
140
+ _defineProperty(_assertThisInitialized(_this2), "components", {
141
+ header: {
142
+ cell: ResizeableTitle
143
+ }
144
+ });
145
+
146
+ _defineProperty(_assertThisInitialized(_this2), "handleResize", function (index) {
147
+ return function (e, _ref) {
148
+ var size = _ref.size;
149
+ var cols = _this2.state.cols;
150
+ console.log("handleResize", cols);
151
+
152
+ var nextColumns = _toConsumableArray(cols);
153
+
154
+ nextColumns[index] = _objectSpread(_objectSpread({}, nextColumns[index]), {}, {
155
+ width: size.width
156
+ });
157
+
158
+ _this2.setState({
159
+ cols: nextColumns
160
+ });
161
+ };
162
+ });
163
+
164
+ _defineProperty(_assertThisInitialized(_this2), "moveRow", function (dragIndex, hoverIndex, drag, target) {
165
+ var _this = _assertThisInitialized(_this2);
166
+
167
+ var dragNode = drag.record;
168
+ var targetNode = target.record;
169
+ dragNode.moveArray(dragNode, targetNode);
170
+ var ids = dragNode.parentNode.getChildNodeIds();
171
+ var params = {
172
+ id: dragNode.id,
173
+ parentId: dragNode.attribute.parentId,
174
+ ids: ids
175
+ };
176
+
177
+ if (_this2.props.moveRow) {
178
+ _this2.props.moveRow(params);
179
+ } else {
180
+ _this2.store.reload();
181
+ } // request("http://demo.javasvn.com/api/admin/menus/drag", {
182
+ // method: "PATCH",
183
+ // data: params,
184
+ // callback: function (data) {
185
+ // this.store.reload();
186
+ // },
187
+ // });
188
+
189
+ });
190
+
191
+ if (props.store instanceof Store) {
192
+ _this2.store = props.store;
193
+ } else {
194
+ var _ref2 = props.store || {},
195
+ _ref2$listeners = _ref2.listeners,
196
+ listenersProps = _ref2$listeners === void 0 ? {} : _ref2$listeners,
197
+ restStore = _objectWithoutProperties(_ref2, _excluded2);
198
+
199
+ var storeProps = _objectSpread(_objectSpread({
200
+ model: "model",
201
+ component: _assertThisInitialized(_this2),
202
+ listeners: {
203
+ onBeforeLoad: function onBeforeLoad(store, options) {
204
+ _this2.setState({
205
+ loading: true
206
+ });
207
+
208
+ utils.callback(listenersProps.onBeforeLoad, _assertThisInitialized(_this2), [store, options]);
209
+ },
210
+ dataChanged: function dataChanged(data, modelData, store) {
211
+ var paging = !(_this2.props.pagination === false);
212
+
213
+ if (paging && !_this2.props.dataSource) {
214
+ _this2.setState({
215
+ dataSource: modelData,
216
+ pagination: store.getPagination(),
217
+ loading: false,
218
+ activeIndex: -1
219
+ });
220
+ } else {
221
+ _this2.setState({
222
+ dataSource: modelData,
223
+ loading: false
224
+ });
225
+ }
226
+
227
+ utils.callback(listenersProps.dataChanged, _assertThisInitialized(_this2), [data, modelData, store, paging]);
228
+ },
229
+ load: function load(data, modelData, store) {
230
+ utils.callback(listenersProps.load, _assertThisInitialized(_this2), [data, modelData, store]);
231
+ },
232
+ onErrorLoad: function onErrorLoad(err, response) {
233
+ _this2.setState({
234
+ loading: false
235
+ });
236
+
237
+ utils.callback(listenersProps.onErrorLoad, _assertThisInitialized(_this2), [err, response]);
238
+ }
239
+ },
240
+ data: restStore.data ? restStore.data : props.dataSource ? props.dataSource : null
241
+ }, restStore), {}, {
242
+ autoLoad: restStore.autoLoad === false ? false : true
243
+ });
244
+
245
+ _this2.store = new PageStore(Object.assign({}, storeProps, {
246
+ pagination: _this2.props.pagination
247
+ }));
248
+ }
249
+
250
+ return _this2;
55
251
  }
56
252
 
57
253
  _createClass(NSCTable, [{
254
+ key: "componentDidMount",
255
+ value: function componentDidMount() {
256
+ var resizeColumn = this.props.resizeColumn;
257
+
258
+ if (!resizeColumn) {
259
+ this.setState({
260
+ columns: _toConsumableArray(this.props.columns)
261
+ });
262
+ } else {
263
+ this.setState({
264
+ cols: _toConsumableArray(this.props.columns)
265
+ }); // this.resetColumn();
266
+ }
267
+
268
+ var store = this.props.store;
269
+
270
+ if (store && store.data) {
271
+ this.store.setData(store.data);
272
+ }
273
+ }
274
+ }, {
275
+ key: "componentDidUpdate",
276
+ value: function componentDidUpdate(prevProps, preState) {
277
+ var resizeColumn = this.props.resizeColumn;
278
+
279
+ if (!resizeColumn) {
280
+ if (this.props.columns !== prevProps.columns) {
281
+ this.setState({
282
+ columns: this.props.columns
283
+ });
284
+ }
285
+ } else {
286
+ if (preState.cols !== this.state.cols) {
287
+ this.resetColumn();
288
+ }
289
+ }
290
+ }
291
+ }, {
292
+ key: "resetColumn",
293
+ value: function resetColumn() {
294
+ var _this3 = this;
295
+
296
+ var cols = this.state.cols;
297
+ var newCols = [];
298
+ var colss = cols || [];
299
+ colss.map(function (col, index) {
300
+ var temp = _objectSpread(_objectSpread({}, col), {}, {
301
+ onHeaderCell: function onHeaderCell(column) {
302
+ return {
303
+ width: column.width,
304
+ onResize: _this3.handleResize(index)
305
+ };
306
+ }
307
+ });
308
+
309
+ newCols.push(temp);
310
+ });
311
+ this.setState({
312
+ columns: newCols
313
+ });
314
+ }
315
+ /**
316
+ * 清除选中颜色
317
+ */
318
+
319
+ }, {
320
+ key: "clearSelectColor",
321
+ value: function clearSelectColor() {
322
+ this.setState({
323
+ activeIndex: -1
324
+ });
325
+ return this;
326
+ }
327
+ }, {
328
+ key: "getPaginationByStore",
329
+ value: function getPaginationByStore() {
330
+ return this.store.getPagination();
331
+ }
332
+ }, {
333
+ key: "onChange",
334
+ value: function onChange(pagination, filters, sorter, extra) {
335
+ var _this4 = this;
336
+
337
+ var _this$props = this.props,
338
+ autoOnChange = _this$props.autoOnChange,
339
+ autoSort = _this$props.autoSort,
340
+ autoPagination = _this$props.autoPagination,
341
+ onChange = _this$props.onChange;
342
+
343
+ if (autoOnChange === false) {
344
+ onChange && onChange(pagination, filters, sorter, extra);
345
+ return;
346
+ }
347
+
348
+ var handlePagination = function handlePagination() {
349
+ var params = {};
350
+ var paging = _this4.getPaginationByStore() || {};
351
+
352
+ if (!isEmptyObj(pagination)) {
353
+ var _p;
354
+
355
+ var p = (_p = {}, _defineProperty(_p, paging.currentKey || "current", pagination.current), _defineProperty(_p, paging.pageSizeKey || "size", pagination.pageSize), _p);
356
+ Object.assign(params, p);
357
+ }
358
+
359
+ if (autoSort === true && !isEmptyObj(sorter)) {
360
+ if (sorter.order == "ascend") {
361
+ params.ascs = sorter.column.sortField || sorter.column.field || sorter.field;
362
+ params.descs = "";
363
+ }
364
+
365
+ if (sorter.order == "descend") {
366
+ params.descs = sorter.column.sortField || sorter.column.field || sorter.field;
367
+ params.ascs = "";
368
+ }
369
+ }
370
+
371
+ _this4.store.reload({
372
+ params: params
373
+ });
374
+ };
375
+
376
+ var onChangeFn = this.props.onChange; // 用户传了onChange保留用户自主处理表格变化的权力
377
+
378
+ if (onChangeFn) {
379
+ utils.callback(onChangeFn, this, [pagination, filters, sorter, extra]);
380
+ }
381
+
382
+ if (this.props.autoPagination) {
383
+ handlePagination();
384
+ }
385
+ }
386
+ }, {
387
+ key: "getStore",
388
+ value: function getStore() {
389
+ return this.store;
390
+ }
391
+ /**
392
+ * 获取数据模型对象
393
+ */
394
+
395
+ }, {
396
+ key: "getModel",
397
+ value: function getModel() {
398
+ return this.store.getModel();
399
+ }
400
+ /**
401
+ * 菜单搜索过滤显示
402
+ * @param {String} val
403
+ */
404
+
405
+ }, {
406
+ key: "handleSearch",
407
+ value: function handleSearch(val, fieldOption, searchColor) {
408
+ this.setState({
409
+ searchText: val,
410
+ fieldOption: fieldOption,
411
+ searchColor: searchColor
412
+ });
413
+ }
414
+ /**
415
+ * 模块列表移动排序
416
+ */
417
+
418
+ }, {
419
+ key: "filterColumn",
420
+ value: function filterColumn(checkedValue) {
421
+ var filterColumns = this.props.columns.map(function (col) {
422
+ var newCol = _objectSpread({}, col);
423
+
424
+ if (checkedValue.includes(col.dataIndex)) {
425
+ newCol.initShow = true;
426
+ } else {
427
+ newCol.initShow = false;
428
+ }
429
+
430
+ return newCol;
431
+ }); // this.setState({ columns: filterColumns });
432
+
433
+ var resizeColumn = this.props.resizeColumn;
434
+
435
+ if (!resizeColumn) {
436
+ this.setState({
437
+ columns: filterColumns
438
+ });
439
+ } else {
440
+ this.setState({
441
+ cols: filterColumns
442
+ });
443
+ }
444
+ }
445
+ }, {
446
+ key: "getColumns",
447
+ value: function getColumns() {
448
+ var _this5 = this;
449
+
450
+ var columns = this.state.columns;
451
+ var _this$props2 = this.props,
452
+ disableColumns = _this$props2.disableColumns,
453
+ colLists = _this$props2.columns;
454
+ var defaultShowCols = columns.filter(function (cols) {
455
+ return cols.initShow !== false;
456
+ });
457
+ var defaultHideCols = columns.filter(function (cols) {
458
+ return cols.initShow === false;
459
+ });
460
+ var content = /*#__PURE__*/React.createElement(_Checkbox.Group, {
461
+ onChange: this.filterColumn.bind(this),
462
+ options: colLists.map(function (col) {
463
+ return {
464
+ label: col.title,
465
+ value: col.dataIndex
466
+ };
467
+ }),
468
+ defaultValue: defaultShowCols.map(function (col) {
469
+ return col.dataIndex;
470
+ })
471
+ });
472
+ var cols = defaultShowCols.map(function (col) {
473
+ if (col.ellipsis && !col.render) {
474
+ col.ellipsis = {
475
+ showTitle: false
476
+ };
477
+
478
+ col.render = function (text) {
479
+ return /*#__PURE__*/React.createElement(_Tooltip, {
480
+ placement: "topLeft",
481
+ title: text
482
+ }, text);
483
+ };
484
+ }
485
+
486
+ return col;
487
+ });
488
+ var IconAction = {
489
+ title: /*#__PURE__*/React.createElement("div", {
490
+ className: styles["th-icon"],
491
+ ref: this.thIconRef
492
+ }, /*#__PURE__*/React.createElement(_Popover, {
493
+ title: "\u9009\u62E9\u663E\u793A\u7684\u5217",
494
+ content: content,
495
+ placement: "bottomRight",
496
+ trigger: "click",
497
+ overlayStyle: {
498
+ minWidth: 410,
499
+ maxWidth: 450
500
+ },
501
+ getPopupContainer: function getPopupContainer() {
502
+ return _this5.thIconRef.current;
503
+ }
504
+ }, /*#__PURE__*/React.createElement(AppstoreOutlined, {
505
+ size: 24,
506
+ className: styles["app-store-icon"]
507
+ }))),
508
+ dataIndex: "icon-menu",
509
+ key: "icon-menu",
510
+ width: 50,
511
+ align: "center" // fixed: "right",
512
+
513
+ };
514
+
515
+ if (this.props.filterColumn) {
516
+ cols.push(IconAction);
517
+ }
518
+
519
+ return cols;
520
+ }
521
+ }, {
58
522
  key: "render",
59
523
  value: function render() {
60
- var _this$props = this.props,
61
- resizeColumn = _this$props.resizeColumn,
62
- params = _objectWithoutProperties(_this$props, _excluded);
524
+ var _this6 = this;
525
+
526
+ var _this = this,
527
+ _this$state = this.state,
528
+ loading = _this$state.loading,
529
+ dataSource = _this$state.dataSource,
530
+ _this$state$paginatio = _this$state.pagination,
531
+ pagination = _this$state$paginatio === void 0 ? {} : _this$state$paginatio,
532
+ searchText = _this$state.searchText,
533
+ fieldOption = _this$state.fieldOption,
534
+ searchColor = _this$state.searchColor,
535
+ props = utils.omit(this.props, ["store", "onChange", "columns", "resetColumn"], {
536
+ rowKey: "id",
537
+ clickChangeColor: false
538
+ });
539
+
540
+ if (props.pagination !== false) {
541
+ props.pagination = _objectSpread(_objectSpread({
542
+ position: ["bottomRight"],
543
+ showSizeChanger: true,
544
+ showQuickJumper: true
545
+ }, props.pagination), pagination);
63
546
 
64
- if (resizeColumn) {
65
- return /*#__PURE__*/React.createElement(ResizeTable, params);
547
+ if (props.showTotal == true) {
548
+ props.pagination.showTotal = function (total, _ref3) {
549
+ var _ref4 = _slicedToArray(_ref3, 2),
550
+ from = _ref4[0],
551
+ to = _ref4[1];
552
+
553
+ // return "显示 " + from + " - " + to + "条,共 " + total + " 条";
554
+ return "共 " + total + " 条";
555
+ };
556
+ }
557
+ }
558
+
559
+ props.onChange = function (pagination, filters, sorter, extra) {
560
+ _this.onChange(pagination, filters, sorter, extra);
561
+ };
562
+
563
+ if (props.clickChangeColor) {
564
+ var onRowFn = props.onRow;
565
+
566
+ props.onRow = function (record, index) {
567
+ var custom = onRowFn ? onRowFn(record, index) : {};
568
+ var onClickFn = custom.onClick;
569
+
570
+ custom.onClick = function (event) {
571
+ _this.setState({
572
+ activeIndex: index //获取点击行的索引
573
+
574
+ });
575
+
576
+ utils.callback(onClickFn, _this, [event]);
577
+ };
578
+
579
+ return custom;
580
+ };
581
+
582
+ props.rowClassName = function (record, index) {
583
+ return index === _this.state.activeIndex ? "".concat(styles.clickRowStyle) : "";
584
+ };
585
+ }
586
+
587
+ var newDataSource = [];
588
+
589
+ if (searchText) {
590
+ var data = treeUtils.getSearchMenuDatas(this, searchText, fieldOption, searchColor);
591
+ newDataSource = data.treeDatas;
592
+ props.expandedRowKeys = data.openKeys;
66
593
  } else {
67
- return /*#__PURE__*/React.createElement(NormalTable, params);
594
+ newDataSource = dataSource;
68
595
  }
596
+
597
+ props.store = props.store || {};
598
+ props.store.autoLoad = props.store.autoLoad === false ? false : true;
599
+ var dragable = _this.props.dragable;
600
+ var dragableProps = dragable === true ? {
601
+ components: BodyRowComponent,
602
+ onRow: function onRow(record, index) {
603
+ return {
604
+ index: index,
605
+ record: record,
606
+ moveRow: _this6.moveRow
607
+ };
608
+ }
609
+ } : {};
610
+ var resizeColumn = this.props.resizeColumn;
611
+ var resizeProps = resizeColumn === true ? {
612
+ components: this.components
613
+ } : null;
614
+ var DefaultTable = /*#__PURE__*/React.createElement(_Table, _extends({
615
+ childrenColumnName: "childNodes",
616
+ dataSource: newDataSource,
617
+ columns: this.getColumns(),
618
+ loading: loading,
619
+ className: styles["nsc-table"],
620
+ locale: {
621
+ emptyText: /*#__PURE__*/React.createElement(NoData, null)
622
+ }
623
+ }, resizeProps, props, dragableProps));
624
+ return dragable === true ? /*#__PURE__*/React.createElement(DndProvider, {
625
+ backend: HTML5Backend
626
+ }, DefaultTable) : DefaultTable;
69
627
  }
70
628
  }]);
71
629
 
@@ -80,8 +638,9 @@ _defineProperty(NSCTable, "defaultProps", {
80
638
  dragUrl: "",
81
639
  autoPagination: true,
82
640
  autoSort: true,
83
- autoOnChange: true
641
+ autoOnChange: true,
642
+ resizeColumn: false
84
643
  });
85
644
 
86
645
  export default withZhLocale(NSCTable);
87
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RhYmxlL2luZGV4LnRzeCJdLCJuYW1lcyI6WyJSZWFjdCIsIkRuZENvbnRleHRUeXBlIiwiSUJvZHlSb3dQcm9wcyIsIndpdGhaaExvY2FsZSIsIlJlc2l6ZVRhYmxlIiwiTm9ybWFsVGFibGUiLCJOU0NUYWJsZSIsInByb3BzIiwicmVzaXplQ29sdW1uIiwicGFyYW1zIiwiQ29tcG9uZW50IiwiZGlzYWJsZUNvbHVtbnMiLCJkcmFnYWJsZSIsInNob3dUb3RhbCIsImZpbHRlckNvbHVtbiIsImRyYWdVcmwiLCJhdXRvUGFnaW5hdGlvbiIsImF1dG9Tb3J0IiwiYXV0b09uQ2hhbmdlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBY0EsT0FBTyxLQUFLQSxLQUFaLE1BQXVCLE9BQXZCO0FBQ0EsU0FBa0JDLGNBQWxCLEVBQWtDQyxhQUFsQyxRQUF1RCxtQkFBdkQ7QUFFQSxPQUFPQyxZQUFQLE1BQXlCLHdCQUF6QjtBQUNBLE9BQU9DLFdBQVAsTUFBd0IsZ0JBQXhCO0FBQ0EsT0FBT0MsV0FBUCxNQUF3QixjQUF4QjtBQWlDQSxTQUFTSixjQUFULEVBQXlCQyxhQUF6Qjs7SUFDTUksUTs7Ozs7Ozs7Ozs7OztXQVdKLGtCQUFTO0FBQ1Asd0JBQW9DLEtBQUtDLEtBQXpDO0FBQUEsVUFBUUMsWUFBUixlQUFRQSxZQUFSO0FBQUEsVUFBeUJDLE1BQXpCOztBQUNBLFVBQUlELFlBQUosRUFBa0I7QUFDaEIsNEJBQU8sb0JBQUMsV0FBRCxFQUFpQkMsTUFBakIsQ0FBUDtBQUNELE9BRkQsTUFFTztBQUNMLDRCQUFPLG9CQUFDLFdBQUQsRUFBaUJBLE1BQWpCLENBQVA7QUFDRDtBQUNGOzs7O0VBbEJvQlQsS0FBSyxDQUFDVSxTOztnQkFBdkJKLFEsa0JBQ2tCO0FBQ3BCSyxFQUFBQSxjQUFjLEVBQUUsRUFESTtBQUVwQkMsRUFBQUEsUUFBUSxFQUFFLEtBRlU7QUFHcEJDLEVBQUFBLFNBQVMsRUFBRSxJQUhTO0FBSXBCQyxFQUFBQSxZQUFZLEVBQUUsSUFKTTtBQUtwQkMsRUFBQUEsT0FBTyxFQUFFLEVBTFc7QUFNcEJDLEVBQUFBLGNBQWMsRUFBRSxJQU5JO0FBT3BCQyxFQUFBQSxRQUFRLEVBQUUsSUFQVTtBQVFwQkMsRUFBQUEsWUFBWSxFQUFFO0FBUk0sQzs7QUFvQnhCLGVBQWVmLFlBQVksQ0FBQ0csUUFBRCxDQUEzQiIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIEBEZXNjcmlwdHRpb246XHJcbiAqIEB2ZXJzaW9uOlxyXG4gKiBAQXV0aG9yOiByeHpodVxyXG4gKiBARGF0ZTogMjAyMS0wMy0yMyAwODo0NjoyMFxyXG4gKiBATGFzdEVkaXRvcnM6IHJ4emh1XHJcbiAqIEBMYXN0RWRpdFRpbWU6IDIwMjEtMDMtMjMgMTA6MzA6NDJcclxuICovXHJcbmltcG9ydCB7IEFwcHN0b3JlT3V0bGluZWQgfSBmcm9tIFwiQGFudC1kZXNpZ24vaWNvbnNcIjtcclxuaW1wb3J0IHsgaXNFbXB0eU9iaiB9IGZyb20gXCJAYmotbnNjL2Z1bmN0aW9uc1wiO1xyXG5pbXBvcnQgU3RvcmUsIHsgUGFnZVN0b3JlLCBTdG9yZVByb3BzIH0gZnJvbSBcIkBiai1uc2MvbXNuXCI7XHJcbmltcG9ydCB7IHV0aWxzIH0gZnJvbSBcIkBiai1uc2MvbXNuL2xpYi91dGlsc1wiO1xyXG5pbXBvcnQge1xyXG4gIENoZWNrYm94LFxyXG4gIENoZWNrYm94T3B0aW9uVHlwZSxcclxuICBQb3BvdmVyLFxyXG4gIFRhYmxlLFxyXG4gIFRhYmxlUHJvcHMsXHJcbiAgVG9vbHRpcCxcclxufSBmcm9tIFwiYW50ZFwiO1xyXG5pbXBvcnQgeyBDb2x1bW5UeXBlLCBUYWJsZVBhZ2luYXRpb25Db25maWcgfSBmcm9tIFwiYW50ZC9saWIvdGFibGVcIjtcclxuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSBcInJlYWN0XCI7XHJcbmltcG9ydCBCb2R5Um93LCB7IERuZENvbnRleHRUeXBlLCBJQm9keVJvd1Byb3BzIH0gZnJvbSBcIi4uL2NvbW1vbi9Cb2R5Um93XCI7XHJcbmltcG9ydCBzdHlsZXMgZnJvbSBcIi4vaW5kZXgubGVzc1wiO1xyXG5pbXBvcnQgd2l0aFpoTG9jYWxlIGZyb20gXCIuLi9jb21tb24vd2l0aFpoTG9jYWxlXCI7XHJcbmltcG9ydCBSZXNpemVUYWJsZSBmcm9tIFwiLi9SZXNpemVDb2x1bW5cIjtcclxuaW1wb3J0IE5vcm1hbFRhYmxlIGZyb20gXCIuL05vcm1hbFRhYmxcIjtcclxuXHJcbmludGVyZmFjZSBJRHJhZ1BhcmFtcyB7XHJcbiAgaWQ6IHN0cmluZyB8IG51bWJlcjtcclxuICBpZHM6IEFycmF5PHN0cmluZyB8IG51bWJlcj47XHJcbiAgcGFyZW50SWQ6IHN0cmluZyB8IG51bWJlcjtcclxufVxyXG4vLyBpbnRlcmZhY2UgU3RvcmVQcm9wcyB7fVxyXG5cclxuZXhwb3J0IHR5cGUgU3RvcmVUeXBlID0gXCJQYWdlU3RvcmVcIiB8IFwiVHJlZVN0b3JlXCIgfCBcIkJhc2VTdG9yZVwiO1xyXG5cclxuaW50ZXJmYWNlIE5TQ1RhYmxlUGFnaW5hdGlvbiBleHRlbmRzIFRhYmxlUGFnaW5hdGlvbkNvbmZpZyB7XHJcbiAgdG90YWxLZXk/OiBzdHJpbmc7XHJcbiAgcGFnZVNpemVLZXk/OiBzdHJpbmc7XHJcbiAgY3VycmVudEtleT86IHN0cmluZztcclxufVxyXG5cclxuaW50ZXJmYWNlIE5TQ1RhYmxlUHJvcHMgZXh0ZW5kcyBUYWJsZVByb3BzPGFueT4ge1xyXG4gIHN0b3JlPzogU3RvcmVQcm9wcztcclxuICBzaG93VG90YWw/OiBib29sZWFuOyAvLyDmmK/lkKbmmL7npLrmgLvmnaHmlbDkv6Hmga/vvIzpu5jorqR0cnVlXHJcbiAgZGlzYWJsZUNvbHVtbnM/OiBzdHJpbmdbXTsgLy8g5LiN5Y+v6ZqQ6JeP5b+F6aG75pi+56S655qE5YiXXHJcbiAgZHJhZ2FibGU/OiBib29sZWFuOyAvLyDmmK/lkKblj6/mi5bliqgsIOm7mOiupGZhbHNlXHJcbiAgZmlsdGVyQ29sdW1uPzogYm9vbGVhbjsgLy8g5piv5ZCm5pSv5oyB6L+H5ruk5pi+56S66KGo5qC85YiXLCDpu5jorqR0cnVlXHJcbiAgbW92ZVJvdz86IChwYXJhbXM6IElEcmFnUGFyYW1zKSA9PiB2b2lkOyAvLyDmi5bmi73lrozmiJDlkI7nmoTlm57osINcclxuICBkcmFnVXJsPzogc3RyaW5nOyAvLyDkv53lrZjmi5bmi73mjpLluo/nmoTmjqXlj6NcclxuICBwYWdpbmF0aW9uPzogZmFsc2UgfCBOU0NUYWJsZVBhZ2luYXRpb247XHJcbiAgYXV0b1BhZ2luYXRpb24/OiBib29sZWFuOyAvLyDnu4Tku7bmmK/lkKboh6rliqjlpITnkIbliIbpobVcclxuICBhdXRvU29ydD86IGJvb2xlYW47IC8v57uE5Lu25piv5ZCm6Ieq5Yqo5aSE55CG5o6S5bqPXHJcbiAgYXV0b09uQ2hhbmdlPzogYm9vbGVhbjsgLy8g57uE5Lu25piv5ZCm6Ieq5Yqob25DaGFuZ2UsIGZhbHNl5YiZ5LiN5YGa5Lu75L2V5aSE55CG5YWo6YOo5Lqk57uZ6LCD55So5pa5XHJcbiAgcmVzaXplQ29sdW1uPzogYm9vbGVhbjtcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgSU5TQ1RhYmxlUHJvcHMgPSB0eXBlb2YgTlNDVGFibGUuZGVmYXVsdFByb3BzICYgTlNDVGFibGVQcm9wcztcclxuZXhwb3J0IHsgRG5kQ29udGV4dFR5cGUsIElCb2R5Um93UHJvcHMgfTtcclxuY2xhc3MgTlNDVGFibGUgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQ8SU5TQ1RhYmxlUHJvcHM+IHtcclxuICBzdGF0aWMgZGVmYXVsdFByb3BzID0ge1xyXG4gICAgZGlzYWJsZUNvbHVtbnM6IFtdLFxyXG4gICAgZHJhZ2FibGU6IGZhbHNlLFxyXG4gICAgc2hvd1RvdGFsOiB0cnVlLFxyXG4gICAgZmlsdGVyQ29sdW1uOiB0cnVlLFxyXG4gICAgZHJhZ1VybDogXCJcIixcclxuICAgIGF1dG9QYWdpbmF0aW9uOiB0cnVlLFxyXG4gICAgYXV0b1NvcnQ6IHRydWUsXHJcbiAgICBhdXRvT25DaGFuZ2U6IHRydWUsXHJcbiAgfTtcclxuICByZW5kZXIoKSB7XHJcbiAgICBjb25zdCB7IHJlc2l6ZUNvbHVtbiwgLi4ucGFyYW1zIH0gPSB0aGlzLnByb3BzO1xyXG4gICAgaWYgKHJlc2l6ZUNvbHVtbikge1xyXG4gICAgICByZXR1cm4gPFJlc2l6ZVRhYmxlIHsuLi5wYXJhbXN9IC8+O1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgcmV0dXJuIDxOb3JtYWxUYWJsZSB7Li4ucGFyYW1zfSAvPjtcclxuICAgIH1cclxuICB9XHJcbn1cclxuXHJcbmV4cG9ydCBkZWZhdWx0IHdpdGhaaExvY2FsZShOU0NUYWJsZSk7XHJcbiJdfQ==
646
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/table/index.tsx"],"names":["AppstoreOutlined","isEmptyObj","Store","PageStore","utils","React","DndProvider","BodyRow","DndContextType","IBodyRowProps","treeUtils","styles","BodyRowComponent","HTML5Backend","withZhLocale","NoData","Resizable","ResizeableTitle","props","onResize","width","restProps","enableUserSelectHack","NSCTable","createRef","dataSource","columns","loading","pagination","activeIndex","searchText","fieldOption","searchColor","cols","onBeforeLoad","load","header","cell","index","e","size","state","console","log","nextColumns","setState","dragIndex","hoverIndex","drag","target","_this","dragNode","record","targetNode","moveArray","ids","parentNode","getChildNodeIds","params","id","parentId","attribute","moveRow","store","reload","listeners","listenersProps","restStore","storeProps","model","component","options","callback","dataChanged","data","modelData","paging","getPagination","onErrorLoad","err","response","autoLoad","Object","assign","resizeColumn","setData","prevProps","preState","resetColumn","newCols","colss","map","col","temp","onHeaderCell","column","handleResize","push","filters","sorter","extra","autoOnChange","autoSort","autoPagination","onChange","handlePagination","getPaginationByStore","p","currentKey","current","pageSizeKey","pageSize","order","ascs","sortField","field","descs","onChangeFn","getModel","val","checkedValue","filterColumns","newCol","includes","dataIndex","initShow","disableColumns","colLists","defaultShowCols","filter","defaultHideCols","content","filterColumn","bind","label","title","value","ellipsis","render","showTitle","text","IconAction","thIconRef","minWidth","maxWidth","key","align","omit","rowKey","clickChangeColor","position","showSizeChanger","showQuickJumper","showTotal","total","from","to","onRowFn","onRow","custom","onClickFn","onClick","event","rowClassName","clickRowStyle","newDataSource","getSearchMenuDatas","treeDatas","expandedRowKeys","openKeys","dragable","dragableProps","components","resizeProps","DefaultTable","getColumns","emptyText","Component","dragUrl"],"mappings":"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","sourcesContent":["/*\r\n * @Descripttion:\r\n * @version:\r\n * @Author: rxzhu\r\n * @Date: 2021-03-23 08:46:20\r\n * @LastEditors: rxzhu\r\n * @LastEditTime: 2021-03-23 10:30:42\r\n */\r\nimport { AppstoreOutlined } from \"@ant-design/icons\";\r\nimport { isEmptyObj } from \"@bj-nsc/functions\";\r\nimport Store, { PageStore, StoreProps } from \"@bj-nsc/msn\";\r\nimport { utils } from \"@bj-nsc/msn/lib/utils\";\r\nimport {\r\n  Checkbox,\r\n  CheckboxOptionType,\r\n  Popover,\r\n  Table,\r\n  TableProps,\r\n  Tooltip,\r\n} from \"antd\";\r\nimport { ColumnType, TablePaginationConfig } from \"antd/lib/table\";\r\nimport * as React from \"react\";\r\nimport { DndProvider } from \"react-dnd\";\r\nimport BodyRow, { DndContextType, IBodyRowProps } from \"../common/BodyRow\";\r\nimport treeUtils from \"../treeUtils\";\r\nimport styles from \"./index.less\";\r\nconst { BodyRowComponent, HTML5Backend } = BodyRow;\r\nimport withZhLocale from \"../common/withZhLocale\";\r\nimport { NoData } from \"..\";\r\nimport { Resizable } from \"react-resizable\";\r\nimport \"./resize.less\";\r\n\r\ninterface IDragParams {\r\n  id: string | number;\r\n  ids: Array<string | number>;\r\n  parentId: string | number;\r\n}\r\n// interface StoreProps {}\r\n\r\nexport type StoreType = \"PageStore\" | \"TreeStore\" | \"BaseStore\";\r\n\r\ninterface NSCTablePagination extends TablePaginationConfig {\r\n  totalKey?: string;\r\n  pageSizeKey?: string;\r\n  currentKey?: string;\r\n}\r\n\r\ninterface NSCTableProps extends TableProps<any> {\r\n  store?: StoreProps;\r\n  showTotal?: boolean; // 是否显示总条数信息，默认true\r\n  disableColumns?: string[]; // 不可隐藏必须显示的列\r\n  dragable?: boolean; // 是否可拖动, 默认false\r\n  filterColumn?: boolean; // 是否支持过滤显示表格列, 默认true\r\n  moveRow?: (params: IDragParams) => void; // 拖拽完成后的回调\r\n  dragUrl?: string; // 保存拖拽排序的接口\r\n  pagination?: false | NSCTablePagination;\r\n  autoPagination?: boolean; // 组件是否自动处理分页\r\n  autoSort?: boolean; //组件是否自动处理排序\r\n  autoOnChange?: boolean; // 组件是否自动onChange, false则不做任何处理全部交给调用方\r\n  resizeColumn?: boolean;\r\n}\r\n\r\nexport type INSCTableProps = typeof NSCTable.defaultProps & NSCTableProps;\r\nexport { DndContextType, IBodyRowProps };\r\n\r\nconst ResizeableTitle = (props: any) => {\r\n  const { onResize, width, ...restProps } = props;\r\n  return (\r\n    <Resizable\r\n      width={width || 150}\r\n      height={0}\r\n      onResize={onResize}\r\n      draggableOpts={{ enableUserSelectHack: false }}\r\n    >\r\n      <th {...restProps} />\r\n    </Resizable>\r\n  );\r\n};\r\nclass NSCTable extends React.Component<INSCTableProps> {\r\n  static defaultProps = {\r\n    disableColumns: [],\r\n    dragable: false,\r\n    showTotal: true,\r\n    filterColumn: true,\r\n    dragUrl: \"\",\r\n    autoPagination: true,\r\n    autoSort: true,\r\n    autoOnChange: true,\r\n    resizeColumn: false,\r\n  };\r\n\r\n  store = {} as StoreProps;\r\n  thIconRef = React.createRef<HTMLDivElement>();\r\n\r\n  state = {\r\n    dataSource: [],\r\n    columns: [],\r\n    loading: false,\r\n    pagination: {},\r\n    activeIndex: -1,\r\n    //搜索文本\r\n    searchText: null,\r\n    fieldOption: null,\r\n    searchColor: null,\r\n    cols: [],\r\n  };\r\n\r\n  listeners = {\r\n    onBeforeLoad: null,\r\n    load: null,\r\n  };\r\n\r\n  components = {\r\n    header: {\r\n      cell: ResizeableTitle,\r\n    },\r\n  };\r\n\r\n  constructor(props) {\r\n    super(props);\r\n    if (props.store instanceof Store) {\r\n      this.store = props.store;\r\n    } else {\r\n      const { listeners: listenersProps = {}, ...restStore } =\r\n        props.store || {};\r\n      const storeProps = {\r\n        model: \"model\",\r\n        component: this,\r\n        listeners: {\r\n          onBeforeLoad: (store, options) => {\r\n            this.setState({ loading: true });\r\n            utils.callback(listenersProps.onBeforeLoad, this, [store, options]);\r\n          },\r\n          dataChanged: (data, modelData, store) => {\r\n            let paging = !(this.props.pagination === false);\r\n\r\n            if (paging && !this.props.dataSource) {\r\n              this.setState({\r\n                dataSource: modelData,\r\n                pagination: store.getPagination(),\r\n                loading: false,\r\n                activeIndex: -1,\r\n              });\r\n            } else {\r\n              this.setState({ dataSource: modelData, loading: false });\r\n            }\r\n\r\n            utils.callback(listenersProps.dataChanged, this, [\r\n              data,\r\n              modelData,\r\n              store,\r\n              paging,\r\n            ]);\r\n          },\r\n          load: (data, modelData, store) => {\r\n            utils.callback(listenersProps.load, this, [data, modelData, store]);\r\n          },\r\n          onErrorLoad: (err, response) => {\r\n            this.setState({ loading: false });\r\n            utils.callback(listenersProps.onErrorLoad, this, [err, response]);\r\n          },\r\n        },\r\n        data: restStore.data\r\n          ? restStore.data\r\n          : props.dataSource\r\n          ? props.dataSource\r\n          : null,\r\n        ...restStore,\r\n        autoLoad: restStore.autoLoad === false ? false : true,\r\n      };\r\n\r\n      this.store = new PageStore(\r\n        Object.assign({}, storeProps, {\r\n          pagination: this.props.pagination,\r\n        })\r\n      );\r\n    }\r\n  }\r\n\r\n  handleResize =\r\n    (index: any) =>\r\n    (e: any, { size }: any) => {\r\n      const { cols } = this.state;\r\n      console.log(\"handleResize\", cols);\r\n      const nextColumns = [...cols];\r\n      nextColumns[index] = {\r\n        ...nextColumns[index],\r\n        width: size.width,\r\n      };\r\n      this.setState({\r\n        cols: nextColumns,\r\n      });\r\n    };\r\n\r\n  componentDidMount() {\r\n    const { resizeColumn } = this.props;\r\n    if (!resizeColumn) {\r\n      this.setState({ columns: [...this.props.columns] });\r\n    } else {\r\n      this.setState({ cols: [...this.props.columns] });\r\n      // this.resetColumn();\r\n    }\r\n    const store = this.props.store;\r\n    if (store && store.data) {\r\n      this.store.setData(store.data);\r\n    }\r\n  }\r\n\r\n  componentDidUpdate(prevProps, preState) {\r\n    const { resizeColumn } = this.props;\r\n    if (!resizeColumn) {\r\n      if (this.props.columns !== prevProps.columns) {\r\n        this.setState({ columns: this.props.columns });\r\n      }\r\n    } else {\r\n      if (preState.cols !== this.state.cols) {\r\n        this.resetColumn();\r\n      }\r\n    }\r\n  }\r\n\r\n  resetColumn() {\r\n    const { cols } = this.state;\r\n    const newCols: any = [];\r\n    let colss = cols || [];\r\n    colss.map((col: any, index: any) => {\r\n      let temp = {\r\n        ...col,\r\n        onHeaderCell: (column: { width: any }) => ({\r\n          width: column.width,\r\n          onResize: this.handleResize(index),\r\n        }),\r\n      };\r\n      newCols.push(temp);\r\n    });\r\n    this.setState({\r\n      columns: newCols,\r\n    });\r\n  }\r\n\r\n  /**\r\n   * 清除选中颜色\r\n   */\r\n  clearSelectColor() {\r\n    this.setState({ activeIndex: -1 });\r\n    return this;\r\n  }\r\n\r\n  getPaginationByStore() {\r\n    return this.store.getPagination();\r\n  }\r\n\r\n  onChange(pagination, filters, sorter, extra) {\r\n    const { autoOnChange, autoSort, autoPagination, onChange } = this.props;\r\n    if (autoOnChange === false) {\r\n      onChange && onChange(pagination, filters, sorter, extra);\r\n      return;\r\n    }\r\n\r\n    const handlePagination = () => {\r\n      let params = {} as {\r\n        size?: string;\r\n        pageSize?: string;\r\n        ascs?: string;\r\n        descs?: string;\r\n        [propName: string]: string;\r\n      };\r\n\r\n      const paging = this.getPaginationByStore() || {};\r\n\r\n      if (!isEmptyObj(pagination)) {\r\n        const p = {\r\n          [paging.currentKey || \"current\"]: pagination.current,\r\n          [paging.pageSizeKey || \"size\"]: pagination.pageSize,\r\n        };\r\n        Object.assign(params, p);\r\n      }\r\n\r\n      if (autoSort === true && !isEmptyObj(sorter)) {\r\n        if (sorter.order == \"ascend\") {\r\n          params.ascs =\r\n            sorter.column.sortField || sorter.column.field || sorter.field;\r\n          params.descs = \"\";\r\n        }\r\n        if (sorter.order == \"descend\") {\r\n          params.descs =\r\n            sorter.column.sortField || sorter.column.field || sorter.field;\r\n          params.ascs = \"\";\r\n        }\r\n      }\r\n      this.store.reload({ params });\r\n    };\r\n\r\n    const onChangeFn = this.props.onChange;\r\n    // 用户传了onChange保留用户自主处理表格变化的权力\r\n    if (onChangeFn) {\r\n      utils.callback(onChangeFn, this, [pagination, filters, sorter, extra]);\r\n    }\r\n    if (this.props.autoPagination) {\r\n      handlePagination();\r\n    }\r\n  }\r\n\r\n  getStore() {\r\n    return this.store;\r\n  }\r\n\r\n  /**\r\n   * 获取数据模型对象\r\n   */\r\n  getModel() {\r\n    return this.store.getModel();\r\n  }\r\n\r\n  /**\r\n   * 菜单搜索过滤显示\r\n   * @param {String} val\r\n   */\r\n  handleSearch(val, fieldOption, searchColor) {\r\n    this.setState({\r\n      searchText: val,\r\n      fieldOption: fieldOption,\r\n      searchColor: searchColor,\r\n    });\r\n  }\r\n\r\n  /**\r\n   * 模块列表移动排序\r\n   */\r\n  moveRow = (dragIndex, hoverIndex, drag, target) => {\r\n    const _this = this;\r\n    let dragNode = drag.record;\r\n    let targetNode = target.record;\r\n    dragNode.moveArray(dragNode, targetNode);\r\n    let ids = dragNode.parentNode.getChildNodeIds();\r\n    let params = {\r\n      id: dragNode.id,\r\n      parentId: dragNode.attribute.parentId,\r\n      ids: ids,\r\n    };\r\n\r\n    if (this.props.moveRow) {\r\n      this.props.moveRow(params);\r\n    } else {\r\n      this.store.reload();\r\n    }\r\n    // request(\"http://demo.javasvn.com/api/admin/menus/drag\", {\r\n    //   method: \"PATCH\",\r\n    //   data: params,\r\n    //   callback: function (data) {\r\n    //     this.store.reload();\r\n    //   },\r\n    // });\r\n  };\r\n\r\n  filterColumn(checkedValue) {\r\n    const filterColumns = this.props.columns.map((col: ColumnType<{}>) => {\r\n      const newCol = { ...col } as ColumnType<{}> & { initShow: boolean };\r\n      if (checkedValue.includes(col.dataIndex)) {\r\n        newCol.initShow = true;\r\n      } else {\r\n        newCol.initShow = false;\r\n      }\r\n      return newCol;\r\n    });\r\n    // this.setState({ columns: filterColumns });\r\n    const { resizeColumn } = this.props;\r\n    if (!resizeColumn) {\r\n      this.setState({ columns: filterColumns });\r\n    } else {\r\n      this.setState({ cols: filterColumns });\r\n    }\r\n  }\r\n\r\n  getColumns() {\r\n    const { columns } = this.state;\r\n    const { disableColumns, columns: colLists } = this.props;\r\n    const defaultShowCols = columns.filter((cols) => cols.initShow !== false);\r\n    const defaultHideCols = columns.filter((cols) => cols.initShow === false);\r\n\r\n    const content = (\r\n      <Checkbox.Group\r\n        onChange={this.filterColumn.bind(this)}\r\n        options={colLists.map(\r\n          (col: ColumnType<{}>) =>\r\n            ({\r\n              label: col.title,\r\n              value: col.dataIndex,\r\n            } as CheckboxOptionType)\r\n        )}\r\n        defaultValue={defaultShowCols.map((col) => col.dataIndex)}\r\n      ></Checkbox.Group>\r\n    );\r\n\r\n    const cols = defaultShowCols.map((col) => {\r\n      if (col.ellipsis && !col.render) {\r\n        col.ellipsis = {\r\n          showTitle: false,\r\n        };\r\n        col.render = (text) => {\r\n          return (\r\n            <Tooltip placement=\"topLeft\" title={text}>\r\n              {text}\r\n            </Tooltip>\r\n          );\r\n        };\r\n      }\r\n      return col;\r\n    });\r\n\r\n    const IconAction: ColumnType<{}> = {\r\n      title: (\r\n        <div className={styles[\"th-icon\"]} ref={this.thIconRef}>\r\n          <Popover\r\n            title=\"选择显示的列\"\r\n            content={content}\r\n            placement=\"bottomRight\"\r\n            trigger=\"click\"\r\n            overlayStyle={{ minWidth: 410, maxWidth: 450 }}\r\n            getPopupContainer={() => this.thIconRef.current}\r\n          >\r\n            <AppstoreOutlined size={24} className={styles[\"app-store-icon\"]} />\r\n          </Popover>\r\n        </div>\r\n      ),\r\n      dataIndex: \"icon-menu\",\r\n      key: \"icon-menu\",\r\n      width: 50,\r\n      align: \"center\",\r\n      // fixed: \"right\",\r\n    };\r\n    if (this.props.filterColumn) {\r\n      cols.push(IconAction);\r\n    }\r\n\r\n    return cols;\r\n  }\r\n\r\n  render() {\r\n    let _this = this,\r\n      {\r\n        loading,\r\n        dataSource,\r\n        pagination = {},\r\n        searchText,\r\n        fieldOption,\r\n        searchColor,\r\n      } = this.state,\r\n      props = utils.omit(\r\n        this.props,\r\n        [\"store\", \"onChange\", \"columns\", \"resetColumn\"],\r\n        {\r\n          rowKey: \"id\",\r\n          clickChangeColor: false,\r\n        }\r\n      );\r\n\r\n    if (props.pagination !== false) {\r\n      props.pagination = {\r\n        position: [\"bottomRight\"],\r\n        showSizeChanger: true,\r\n        showQuickJumper: true,\r\n        ...props.pagination,\r\n        ...pagination,\r\n      };\r\n      if (props.showTotal == true) {\r\n        props.pagination.showTotal = function (total, [from, to]) {\r\n          // return \"显示 \" + from + \" - \" + to + \"条，共 \" + total + \" 条\";\r\n          return \"共 \" + total + \" 条\";\r\n        };\r\n      }\r\n    }\r\n\r\n    props.onChange = function (pagination, filters, sorter, extra) {\r\n      _this.onChange(pagination, filters, sorter, extra);\r\n    };\r\n    if (props.clickChangeColor) {\r\n      const onRowFn = props.onRow;\r\n      props.onRow = function (record, index) {\r\n        var custom = onRowFn ? onRowFn(record, index) : {};\r\n        const onClickFn = custom.onClick;\r\n        custom.onClick = (event) => {\r\n          _this.setState({\r\n            activeIndex: index, //获取点击行的索引\r\n          });\r\n          utils.callback(onClickFn, _this, [event]);\r\n        };\r\n        return custom;\r\n      };\r\n      props.rowClassName = function (record, index) {\r\n        return index === _this.state.activeIndex\r\n          ? `${styles.clickRowStyle}`\r\n          : \"\";\r\n      };\r\n    }\r\n    let newDataSource = [];\r\n    if (searchText) {\r\n      const data = treeUtils.getSearchMenuDatas(\r\n        this,\r\n        searchText,\r\n        fieldOption,\r\n        searchColor\r\n      );\r\n      newDataSource = data.treeDatas;\r\n      props.expandedRowKeys = data.openKeys;\r\n    } else {\r\n      newDataSource = dataSource;\r\n    }\r\n    props.store = props.store || {};\r\n    props.store.autoLoad = props.store.autoLoad === false ? false : true;\r\n    const { dragable } = _this.props;\r\n    const dragableProps =\r\n      dragable === true\r\n        ? {\r\n            components: BodyRowComponent,\r\n            onRow: (record, index) => ({\r\n              index,\r\n              record,\r\n              moveRow: this.moveRow,\r\n            }),\r\n          }\r\n        : {};\r\n    let { resizeColumn } = this.props;\r\n\r\n    const resizeProps =\r\n      resizeColumn === true ? { components: this.components } : null;\r\n\r\n    const DefaultTable = (\r\n      <Table\r\n        childrenColumnName=\"childNodes\"\r\n        dataSource={newDataSource}\r\n        columns={this.getColumns()}\r\n        loading={loading}\r\n        className={styles[\"nsc-table\"]}\r\n        locale={{ emptyText: <NoData /> }}\r\n        {...resizeProps}\r\n        {...props}\r\n        {...dragableProps}\r\n      />\r\n    );\r\n\r\n    return dragable === true ? (\r\n      <DndProvider backend={HTML5Backend}>{DefaultTable}</DndProvider>\r\n    ) : (\r\n      DefaultTable\r\n    );\r\n  }\r\n}\r\n\r\nexport default withZhLocale(NSCTable);\r\n"]}