linkmore-design 1.1.27-alpha.0 → 1.1.27-alpha.1

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 (48) hide show
  1. package/dist/LmEditTable/components/customRenderEmpty.d.ts +2 -0
  2. package/dist/LmEditTable/components/index.d.ts +2 -1
  3. package/dist/LmEditTable/util.d.ts +1 -0
  4. package/{lib/LmEditTable/virtual/VirtualRowBack.d.ts → dist/LmEditTable/virtual/VirtualRow2.d.ts} +7 -6
  5. package/dist/LmTable/virTual/VirtualRow.d.ts +1 -1
  6. package/dist/index.umd.js +280 -87
  7. package/dist/index.umd.min.js +21 -21
  8. package/dist/variables.css +27 -0
  9. package/es/LmEditTable/EditTable.js +19 -7
  10. package/es/LmEditTable/components/customRenderEmpty.d.ts +2 -0
  11. package/es/LmEditTable/components/customRenderEmpty.js +20 -0
  12. package/es/LmEditTable/components/index.d.ts +2 -1
  13. package/es/LmEditTable/components/index.js +2 -1
  14. package/es/LmEditTable/style/index.css +27 -0
  15. package/es/LmEditTable/style/variables.css +27 -0
  16. package/es/LmEditTable/util.d.ts +1 -0
  17. package/es/LmEditTable/util.js +11 -0
  18. package/es/LmEditTable/virtual/VirtualRow.js +94 -16
  19. package/{dist/LmEditTable/virtual/VirtualRowBack.d.ts → es/LmEditTable/virtual/VirtualRow2.d.ts} +7 -6
  20. package/es/LmEditTable/virtual/VirtualRow2.js +62 -0
  21. package/es/LmEditTable/virtual/VirtualTable.js +17 -9
  22. package/es/LmEditTable/virtual/context.js +14 -2
  23. package/es/LmTable/virTual/VirtualRow.d.ts +1 -1
  24. package/es/LmTable/virTual/VirtualRow.js +80 -44
  25. package/es/LmTable/virTual/VirtualTable.js +17 -9
  26. package/es/LmTable/virTual/context.js +14 -2
  27. package/es/styles/variables.css +27 -0
  28. package/lib/LmEditTable/EditTable.js +18 -5
  29. package/lib/LmEditTable/components/customRenderEmpty.d.ts +2 -0
  30. package/lib/LmEditTable/components/customRenderEmpty.js +32 -0
  31. package/lib/LmEditTable/components/index.d.ts +2 -1
  32. package/lib/LmEditTable/components/index.js +8 -0
  33. package/lib/LmEditTable/style/index.css +27 -0
  34. package/lib/LmEditTable/style/variables.css +27 -0
  35. package/lib/LmEditTable/util.d.ts +1 -0
  36. package/lib/LmEditTable/util.js +13 -0
  37. package/lib/LmEditTable/virtual/VirtualRow.js +93 -16
  38. package/{es/LmEditTable/virtual/VirtualRowBack.d.ts → lib/LmEditTable/virtual/VirtualRow2.d.ts} +1 -0
  39. package/lib/LmEditTable/virtual/{VirtualRowBack.js → VirtualRow2.js} +13 -48
  40. package/lib/LmEditTable/virtual/VirtualTable.js +16 -8
  41. package/lib/LmEditTable/virtual/context.js +14 -2
  42. package/lib/LmTable/virTual/VirtualRow.d.ts +1 -1
  43. package/lib/LmTable/virTual/VirtualRow.js +79 -44
  44. package/lib/LmTable/virTual/VirtualTable.js +16 -8
  45. package/lib/LmTable/virTual/context.js +14 -2
  46. package/lib/styles/variables.css +27 -0
  47. package/package.json +1 -1
  48. package/es/LmEditTable/virtual/VirtualRowBack.js +0 -100
@@ -9710,6 +9710,10 @@ p {
9710
9710
  .lm_tree_warp .ant-tree-list-holder-inner .ant-tree-treenode > .ant-tree-node-content-wrapper.ant-tree-node-selected {
9711
9711
  background-color: var(--primary-select-color);
9712
9712
  }
9713
+ .lm_editTable_warpper {
9714
+ height: 100%;
9715
+ width: 100%;
9716
+ }
9713
9717
  .lm_editTable_warpper .ant-picker {
9714
9718
  width: 100%;
9715
9719
  }
@@ -9837,6 +9841,29 @@ p {
9837
9841
  .lm_editTable_warpper .ant-table-thead > tr > th:not(:last-child):not(.ant-table-selection-column):not(.ant-table-row-expand-icon-cell):not([colspan])::before {
9838
9842
  background-color: rgba(0, 0, 0, 0.06) !important;
9839
9843
  }
9844
+ .lm_editTable_warpper .lm_table_empty {
9845
+ display: flex;
9846
+ flex-direction: column;
9847
+ align-items: center;
9848
+ padding: 12px 0;
9849
+ font-size: 12px;
9850
+ }
9851
+ .lm_editTable_warpper .lm_table_empty > img {
9852
+ width: 130px;
9853
+ height: 80px;
9854
+ margin-bottom: 8px;
9855
+ }
9856
+ .lm_editTable_warpper .lm_table_empty .empty_img {
9857
+ margin-bottom: 8px;
9858
+ background-image: url('');
9859
+ background-size: cover;
9860
+ }
9861
+ .lm_editTable_warpper .lm_table_empty > span {
9862
+ color: var(--font-color);
9863
+ }
9864
+ .lm_editTable_warpper .ant-table-empty table {
9865
+ height: 100%;
9866
+ }
9840
9867
  .lm_editTable_warpper .ant-picker {
9841
9868
  height: 24px !important;
9842
9869
  padding: 2px 8px;
@@ -61,9 +61,10 @@ import SortableItem from './sortableItem';
61
61
  import ColSortableItem from './sortableItemCol';
62
62
  import DragHandle from './DragHandle';
63
63
  import UploadOss from '../UploadOss';
64
- import { isObjEmpty, deepDataSourcePreKeys, isExpandRow, checkRowKeyByDataSource, checkMemoShouldUploadSpecialFun, checkExpandIconColumnIndex } from './util';
65
- import { DraggableContainer, BottomOpetateComponent, QuickOpetate } from './components';
64
+ import { isObjEmpty, deepDataSourcePreKeys, isExpandRow, checkRowKeyByDataSource, checkMemoShouldUploadSpecialFun, checkExpandIconColumnIndex, checkDataSourceIsEmpty } from './util';
65
+ import { DraggableContainer, BottomOpetateComponent, QuickOpetate, CustomizeRenderEmpty } from './components';
66
66
  import cls from 'classnames';
67
+ import ConfigProvider from '../ConfigProvider';
67
68
  import { VirtualTable, VirtualWrapper, VirtualRow } from './virtual';
68
69
  var UploadBtn = UploadOss.UploadBtn;
69
70
  var EditableContext = /*#__PURE__*/React.createContext(null); // 表格行
@@ -1254,7 +1255,10 @@ var EditTable = /*#__PURE__*/forwardRef(function (props, ref) {
1254
1255
  setLocalRowSelectList({
1255
1256
  selectedRows: value
1256
1257
  });
1257
- }
1258
+ },
1259
+ columns: columns.map(function (item) {
1260
+ return omit(item, ['render', 'sorter', 'onFilter', 'filters', 'componentProps', 'formProps', 'editable']);
1261
+ })
1258
1262
  };
1259
1263
  });
1260
1264
  var isShowAddAction = useMemo(function () {
@@ -1313,6 +1317,10 @@ var EditTable = /*#__PURE__*/forwardRef(function (props, ref) {
1313
1317
  return /*#__PURE__*/React.createElement("div", {
1314
1318
  className: "lm_editTable_warpper",
1315
1319
  ref: tableWarpRef
1320
+ }, /*#__PURE__*/React.createElement(ConfigProvider, {
1321
+ renderEmpty: loading ? function () {
1322
+ return null;
1323
+ } : CustomizeRenderEmpty
1316
1324
  }, /*#__PURE__*/React.createElement(DndContainer, {
1317
1325
  rowKey: _rowKey,
1318
1326
  options: resultColumns,
@@ -1321,7 +1329,7 @@ var EditTable = /*#__PURE__*/forwardRef(function (props, ref) {
1321
1329
  items: columns.reduce(function (acc, item) {
1322
1330
  return [].concat(_toConsumableArray(acc), [item.dataIndex]);
1323
1331
  }, [])
1324
- }, /*#__PURE__*/React.createElement(Table, Object.assign({}, config.current, {
1332
+ }, /*#__PURE__*/React.createElement(Table, Object.assign({}, checkDataSourceIsEmpty(config.current, dataSourceRef.current), {
1325
1333
  loading: loading,
1326
1334
  size: size || 'small',
1327
1335
  columns: resultColumns,
@@ -1341,7 +1349,7 @@ var EditTable = /*#__PURE__*/forwardRef(function (props, ref) {
1341
1349
  }
1342
1350
  }),
1343
1351
  dataSource: dataSource
1344
- })))), /*#__PURE__*/React.createElement(BottomOpetateComponent, {
1352
+ }))))), /*#__PURE__*/React.createElement(BottomOpetateComponent, {
1345
1353
  disabled: disabled,
1346
1354
  isShowAddAction: isShowAddAction,
1347
1355
  recordCreatorProps: recordCreatorProps,
@@ -1353,7 +1361,11 @@ var EditTable = /*#__PURE__*/forwardRef(function (props, ref) {
1353
1361
  return /*#__PURE__*/React.createElement("div", {
1354
1362
  className: "lm_editTable_warpper",
1355
1363
  ref: tableWarpRef
1356
- }, /*#__PURE__*/React.createElement(Table, Object.assign({}, config.current, {
1364
+ }, /*#__PURE__*/React.createElement(ConfigProvider, {
1365
+ renderEmpty: loading ? function () {
1366
+ return null;
1367
+ } : CustomizeRenderEmpty
1368
+ }, /*#__PURE__*/React.createElement(Table, Object.assign({}, checkDataSourceIsEmpty(config.current, dataSourceRef.current), {
1357
1369
  size: size || 'small',
1358
1370
  columns: resultColumns,
1359
1371
  rowClassName: "editable-row",
@@ -1387,7 +1399,7 @@ var EditTable = /*#__PURE__*/forwardRef(function (props, ref) {
1387
1399
  }
1388
1400
  }),
1389
1401
  dataSource: dataSource
1390
- })), /*#__PURE__*/React.createElement(BottomOpetateComponent, {
1402
+ }))), /*#__PURE__*/React.createElement(BottomOpetateComponent, {
1391
1403
  disabled: disabled,
1392
1404
  isShowAddAction: isShowAddAction,
1393
1405
  recordCreatorProps: recordCreatorProps,
@@ -0,0 +1,2 @@
1
+ declare const CustomizeRenderEmpty: () => JSX.Element;
2
+ export default CustomizeRenderEmpty;
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ import ConfigProvider from '../../ConfigProvider';
3
+ var ConfigContext = ConfigProvider.ConfigContext;
4
+
5
+ var CustomizeRenderEmpty = function CustomizeRenderEmpty() {
6
+ var _React$useContext = React.useContext(ConfigContext),
7
+ locale = _React$useContext.locale;
8
+
9
+ return /*#__PURE__*/React.createElement("div", {
10
+ className: "lm_table_empty"
11
+ }, /*#__PURE__*/React.createElement("div", {
12
+ className: "empty_img",
13
+ style: {
14
+ width: '130px',
15
+ height: '80px'
16
+ }
17
+ }), /*#__PURE__*/React.createElement("span", null, (locale === null || locale === void 0 ? void 0 : locale.locale) === 'en' ? 'no Data' : '暂无数据'));
18
+ };
19
+
20
+ export default CustomizeRenderEmpty;
@@ -1,7 +1,8 @@
1
1
  import DraggableContainer from './DraggableContainer';
2
2
  import BottomOpetateComponent from './bottomOpetateComponent';
3
3
  import QuickOpetate from './QuickOpetate';
4
- export { DraggableContainer, BottomOpetateComponent, QuickOpetate };
4
+ import CustomizeRenderEmpty from './customRenderEmpty';
5
+ export { DraggableContainer, BottomOpetateComponent, QuickOpetate, CustomizeRenderEmpty };
5
6
  declare const _default: {
6
7
  DraggableContainer: ({ keys, onSortEnd, virtual, rowKey, options, tableWidth, ...props }: {
7
8
  [x: string]: any;
@@ -1,7 +1,8 @@
1
1
  import DraggableContainer from './DraggableContainer';
2
2
  import BottomOpetateComponent from './bottomOpetateComponent';
3
3
  import QuickOpetate from './QuickOpetate';
4
- export { DraggableContainer, BottomOpetateComponent, QuickOpetate };
4
+ import CustomizeRenderEmpty from './customRenderEmpty';
5
+ export { DraggableContainer, BottomOpetateComponent, QuickOpetate, CustomizeRenderEmpty };
5
6
  export default {
6
7
  DraggableContainer: DraggableContainer
7
8
  };
@@ -510,6 +510,10 @@ html {
510
510
  p {
511
511
  margin-bottom: 0;
512
512
  }
513
+ .lm_editTable_warpper {
514
+ height: 100%;
515
+ width: 100%;
516
+ }
513
517
  .lm_editTable_warpper .ant-picker {
514
518
  width: 100%;
515
519
  }
@@ -637,6 +641,29 @@ p {
637
641
  .lm_editTable_warpper .ant-table-thead > tr > th:not(:last-child):not(.ant-table-selection-column):not(.ant-table-row-expand-icon-cell):not([colspan])::before {
638
642
  background-color: rgba(0, 0, 0, 0.06) !important;
639
643
  }
644
+ .lm_editTable_warpper .lm_table_empty {
645
+ display: flex;
646
+ flex-direction: column;
647
+ align-items: center;
648
+ padding: 12px 0;
649
+ font-size: 12px;
650
+ }
651
+ .lm_editTable_warpper .lm_table_empty > img {
652
+ width: 130px;
653
+ height: 80px;
654
+ margin-bottom: 8px;
655
+ }
656
+ .lm_editTable_warpper .lm_table_empty .empty_img {
657
+ margin-bottom: 8px;
658
+ background-image: url('');
659
+ background-size: cover;
660
+ }
661
+ .lm_editTable_warpper .lm_table_empty > span {
662
+ color: var(--font-color);
663
+ }
664
+ .lm_editTable_warpper .ant-table-empty table {
665
+ height: 100%;
666
+ }
640
667
  .lm_editTable_warpper .ant-picker {
641
668
  height: 24px !important;
642
669
  padding: 2px 8px;
@@ -1,3 +1,7 @@
1
+ .lm_editTable_warpper {
2
+ height: 100%;
3
+ width: 100%;
4
+ }
1
5
  .lm_editTable_warpper .ant-picker {
2
6
  width: 100%;
3
7
  }
@@ -125,6 +129,29 @@
125
129
  .lm_editTable_warpper .ant-table-thead > tr > th:not(:last-child):not(.ant-table-selection-column):not(.ant-table-row-expand-icon-cell):not([colspan])::before {
126
130
  background-color: rgba(0, 0, 0, 0.06) !important;
127
131
  }
132
+ .lm_editTable_warpper .lm_table_empty {
133
+ display: flex;
134
+ flex-direction: column;
135
+ align-items: center;
136
+ padding: 12px 0;
137
+ font-size: 12px;
138
+ }
139
+ .lm_editTable_warpper .lm_table_empty > img {
140
+ width: 130px;
141
+ height: 80px;
142
+ margin-bottom: 8px;
143
+ }
144
+ .lm_editTable_warpper .lm_table_empty .empty_img {
145
+ margin-bottom: 8px;
146
+ background-image: url('');
147
+ background-size: cover;
148
+ }
149
+ .lm_editTable_warpper .lm_table_empty > span {
150
+ color: var(--font-color);
151
+ }
152
+ .lm_editTable_warpper .ant-table-empty table {
153
+ height: 100%;
154
+ }
128
155
  .lm_editTable_warpper .ant-picker {
129
156
  height: 24px !important;
130
157
  padding: 2px 8px;
@@ -9,6 +9,7 @@ export declare function checkExpandIconColumnIndex({ rowSelection, sortOpen, ind
9
9
  sortOpen: any;
10
10
  indexCol: any;
11
11
  }): number;
12
+ export declare function checkDataSourceIsEmpty(config: any, dataSource: any): any;
12
13
  declare const _default: {
13
14
  isObjEmpty: typeof isObjEmpty;
14
15
  };
@@ -140,6 +140,17 @@ export function checkExpandIconColumnIndex(_ref) {
140
140
  });
141
141
  return arr.length;
142
142
  }
143
+ export function checkDataSourceIsEmpty(config, dataSource) {
144
+ if (dataSource.length) {
145
+ return config;
146
+ }
147
+
148
+ return Object.assign(Object.assign({}, config), {
149
+ components: Object.assign(Object.assign({}, config.components), {
150
+ body: {}
151
+ })
152
+ });
153
+ }
143
154
  export default {
144
155
  isObjEmpty: isObjEmpty
145
156
  };
@@ -14,32 +14,63 @@ var __rest = this && this.__rest || function (s, e) {
14
14
  import React, { useRef, useMemo, useEffect } from 'react';
15
15
  import { useStore } from './context';
16
16
  import useForkRef from '../hooks/useForkRef';
17
- var VirtualRow = /*#__PURE__*/React.memo(function (_a, ref) {
18
- var children = _a.children,
19
- pref = _a.pref,
20
- resetProps = __rest(_a, ["children", "pref"]);
17
+
18
+ var useOptions = function useOptions(_ref) {
19
+ var children = _ref.children,
20
+ ref = _ref.ref,
21
+ trRef = _ref.trRef;
21
22
 
22
23
  var _useStore = useStore(),
23
24
  state = _useStore.state,
24
- dispatch = _useStore.dispatch;
25
+ dispatch = _useStore.dispatch,
26
+ instance = _useStore.instance;
25
27
 
28
+ var virtualItems = instance.columnVirtual.virtualItems;
26
29
  var rowHeight = state.rowHeight,
27
30
  totalLen = state.totalLen;
28
- var trRef = useRef(null); // 列长度
31
+ var sliceColumns = useMemo(function () {
32
+ return children === null || children === void 0 ? void 0 : children.reduce(function (pre, cur) {
33
+ var _a, _b;
29
34
 
30
- var columnsLen = useMemo(function () {
31
- var _a;
35
+ if (typeof ((_a = cur.props) === null || _a === void 0 ? void 0 : _a.fixLeft) === 'number') {
36
+ pre.leftColumns.push(cur);
37
+ return pre;
38
+ }
32
39
 
33
- return (_a = children === null || children === void 0 ? void 0 : children.length) !== null && _a !== void 0 ? _a : 0;
40
+ if (typeof ((_b = cur.props) === null || _b === void 0 ? void 0 : _b.fixRight) === 'number') {
41
+ pre.rightColumns.push(cur);
42
+ return pre;
43
+ }
44
+
45
+ pre.centerColumns.push(cur);
46
+ return pre;
47
+ }, {
48
+ leftColumns: [],
49
+ rightColumns: [],
50
+ centerColumns: []
51
+ });
34
52
  }, [children]);
35
53
  useEffect(function () {
36
- if (state.columnsLen !== columnsLen) {
54
+ dispatch({
55
+ type: 'changeSliceColumns',
56
+ sliceColumns: sliceColumns
57
+ });
58
+ }, [sliceColumns]); // 非固定列长度
59
+
60
+ var centerColumnsLen = useMemo(function () {
61
+ var _a;
62
+
63
+ return (_a = sliceColumns.centerColumns.length) !== null && _a !== void 0 ? _a : 0;
64
+ }, [sliceColumns]);
65
+ useEffect(function () {
66
+ if (state.columnsLen !== centerColumnsLen) {
37
67
  dispatch({
38
68
  type: 'changeColumnsLen',
39
- columnsLen: columnsLen !== null && columnsLen !== void 0 ? columnsLen : 0
69
+ columnsLen: centerColumnsLen !== null && centerColumnsLen !== void 0 ? centerColumnsLen : 0
40
70
  });
41
71
  }
42
- }, [columnsLen, dispatch, state.columnsLen]);
72
+ }, [centerColumnsLen, dispatch, state.columnsLen]); // 获取行的高度
73
+
43
74
  useEffect(function () {
44
75
  var initHeight = function initHeight(tempRef) {
45
76
  var _a, _b, _c;
@@ -48,15 +79,62 @@ var VirtualRow = /*#__PURE__*/React.memo(function (_a, ref) {
48
79
  var tempRowHeight = (_c = (_b = tempRef === null || tempRef === void 0 ? void 0 : tempRef.current) === null || _b === void 0 ? void 0 : _b.offsetHeight) !== null && _c !== void 0 ? _c : 0;
49
80
  dispatch({
50
81
  type: 'initHeight',
51
- rowHeight: tempRowHeight
82
+ rowHeight: tempRowHeight + 1
52
83
  });
53
84
  }
54
85
  };
55
86
 
56
- initHeight(trRef);
57
- }, [trRef, dispatch, rowHeight, totalLen, ref]);
87
+ initHeight(Object.prototype.hasOwnProperty.call(ref, 'current') ? ref : trRef);
88
+ }, [trRef, dispatch, rowHeight, totalLen, ref]); // 横向单元格合并
89
+
90
+ var leftColSpan = useMemo(function () {
91
+ var _a;
92
+
93
+ return (_a = virtualItems[0]) === null || _a === void 0 ? void 0 : _a.index;
94
+ }, [virtualItems]); // 右侧隐藏数量
95
+
96
+ var rightColSpan = useMemo(function () {
97
+ return sliceColumns.centerColumns.length - virtualItems.length - leftColSpan || 0;
98
+ }, [sliceColumns.centerColumns.length, virtualItems.length, leftColSpan]);
99
+ return Object.assign(Object.assign({
100
+ virtualItems: virtualItems
101
+ }, sliceColumns), {
102
+ leftColSpan: leftColSpan,
103
+ rightColSpan: rightColSpan
104
+ });
105
+ };
106
+
107
+ var VirtualRow = /*#__PURE__*/React.memo(function (_a, ref) {
108
+ var children = _a.children,
109
+ pref = _a.pref,
110
+ resetProps = __rest(_a, ["children", "pref"]);
111
+
112
+ var trRef = useRef(null);
113
+
114
+ var _useOptions = useOptions({
115
+ children: children,
116
+ ref: ref,
117
+ trRef: trRef
118
+ }),
119
+ virtualItems = _useOptions.virtualItems,
120
+ leftColumns = _useOptions.leftColumns,
121
+ centerColumns = _useOptions.centerColumns,
122
+ rightColumns = _useOptions.rightColumns,
123
+ leftColSpan = _useOptions.leftColSpan,
124
+ rightColSpan = _useOptions.rightColSpan;
125
+
58
126
  return /*#__PURE__*/React.createElement("tr", Object.assign({}, resetProps, {
59
127
  ref: useForkRef(pref, trRef)
60
- }), children);
128
+ }), leftColumns, !!leftColSpan && /*#__PURE__*/React.createElement("td", {
129
+ key: "leftColSpan",
130
+ colSpan: leftColSpan
131
+ }), virtualItems.map(function (virtualCol) {
132
+ return /*#__PURE__*/React.cloneElement(centerColumns[virtualCol.index], {
133
+ ref: virtualCol.measureRef
134
+ });
135
+ }), !!rightColSpan && /*#__PURE__*/React.createElement("td", {
136
+ key: "rightColSpan",
137
+ colSpan: rightColSpan
138
+ }), rightColumns);
61
139
  });
62
140
  export default VirtualRow;
@@ -1,6 +1,7 @@
1
- import React from 'react';
2
- interface rowProps {
3
- children?: any;
4
- }
5
- declare const VirtualRow: React.NamedExoticComponent<rowProps>;
6
- export default VirtualRow;
1
+ import React from 'react';
2
+ interface rowProps {
3
+ children?: any;
4
+ pref?: any;
5
+ }
6
+ declare const VirtualRow: React.NamedExoticComponent<rowProps>;
7
+ export default VirtualRow;
@@ -0,0 +1,62 @@
1
+ var __rest = this && this.__rest || function (s, e) {
2
+ var t = {};
3
+
4
+ for (var p in s) {
5
+ if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
6
+ }
7
+
8
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
9
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+
14
+ import React, { useRef, useMemo, useEffect } from 'react';
15
+ import { useStore } from './context';
16
+ import useForkRef from '../hooks/useForkRef';
17
+ var VirtualRow = /*#__PURE__*/React.memo(function (_a, ref) {
18
+ var children = _a.children,
19
+ pref = _a.pref,
20
+ resetProps = __rest(_a, ["children", "pref"]);
21
+
22
+ var _useStore = useStore(),
23
+ state = _useStore.state,
24
+ dispatch = _useStore.dispatch;
25
+
26
+ var rowHeight = state.rowHeight,
27
+ totalLen = state.totalLen;
28
+ var trRef = useRef(null); // 列长度
29
+
30
+ var columnsLen = useMemo(function () {
31
+ var _a;
32
+
33
+ return (_a = children === null || children === void 0 ? void 0 : children.length) !== null && _a !== void 0 ? _a : 0;
34
+ }, [children]);
35
+ useEffect(function () {
36
+ if (state.columnsLen !== columnsLen) {
37
+ dispatch({
38
+ type: 'changeColumnsLen',
39
+ columnsLen: columnsLen !== null && columnsLen !== void 0 ? columnsLen : 0
40
+ });
41
+ }
42
+ }, [columnsLen, dispatch, state.columnsLen]);
43
+ useEffect(function () {
44
+ var initHeight = function initHeight(tempRef) {
45
+ var _a, _b, _c;
46
+
47
+ if (((_a = tempRef === null || tempRef === void 0 ? void 0 : tempRef.current) === null || _a === void 0 ? void 0 : _a.offsetHeight) && !rowHeight && totalLen) {
48
+ var tempRowHeight = (_c = (_b = tempRef === null || tempRef === void 0 ? void 0 : tempRef.current) === null || _b === void 0 ? void 0 : _b.offsetHeight) !== null && _c !== void 0 ? _c : 0;
49
+ dispatch({
50
+ type: 'initHeight',
51
+ rowHeight: tempRowHeight
52
+ });
53
+ }
54
+ };
55
+
56
+ initHeight(trRef);
57
+ }, [trRef, dispatch, rowHeight, totalLen, ref]);
58
+ return /*#__PURE__*/React.createElement("tr", Object.assign({}, resetProps, {
59
+ ref: useForkRef(pref, trRef)
60
+ }), children);
61
+ });
62
+ export default VirtualRow;
@@ -1,5 +1,5 @@
1
1
  import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
2
- import React, { useRef } from 'react';
2
+ import React, { useCallback, useRef } from 'react';
3
3
  import { useVirtual } from 'react-virtual';
4
4
  import { TableContext, useRealive } from './context';
5
5
  var VirtualTable = /*#__PURE__*/React.memo(function (tableProps) {
@@ -10,7 +10,7 @@ var VirtualTable = /*#__PURE__*/React.memo(function (tableProps) {
10
10
  var _useRealive = useRealive(),
11
11
  _useRealive2 = _slicedToArray(_useRealive, 2),
12
12
  state = _useRealive2[0],
13
- dispatch = _useRealive2[1]; // { totalSize, virtualItems }
13
+ dispatch = _useRealive2[1]; // 行虚拟化 { totalSize, virtualItems }
14
14
 
15
15
 
16
16
  var rowVirtual = useVirtual({
@@ -23,18 +23,26 @@ var VirtualTable = /*#__PURE__*/React.memo(function (tableProps) {
23
23
  return state.rowHeight;
24
24
  }, [state.rowHeight]),
25
25
  overscan: 5
26
- });
26
+ }); // 列动态宽度
27
+
28
+ var columnEstimateSize = useCallback(function (i) {
29
+ var _a, _b;
30
+
31
+ var colWidths = (_b = (_a = tableProps === null || tableProps === void 0 ? void 0 : tableProps.children[0]) === null || _a === void 0 ? void 0 : _a.props) === null || _b === void 0 ? void 0 : _b.colWidths;
32
+ var leftColumnsLen = state.sliceColumns.leftColumns.length;
33
+ var centerColumnsLen = state.sliceColumns.centerColumns.length; // 获取非固定列
34
+
35
+ var virList = colWidths.slice(leftColumnsLen, leftColumnsLen + centerColumnsLen);
36
+ return virList[i] || 0;
37
+ }, [(_c = (_b = tableProps.children[0]) === null || _b === void 0 ? void 0 : _b.props) === null || _c === void 0 ? void 0 : _c.colWidths, state.sliceColumns.leftColumns.length, state.sliceColumns.centerColumns.length]); // 列虚拟化
38
+
27
39
  var columnVirtual = useVirtual({
28
40
  horizontal: true,
29
41
  size: state.columnsLen,
30
42
  parentRef: {
31
- current: (_b = bodyRef === null || bodyRef === void 0 ? void 0 : bodyRef.current) === null || _b === void 0 ? void 0 : _b.parentNode
43
+ current: (_d = bodyRef === null || bodyRef === void 0 ? void 0 : bodyRef.current) === null || _d === void 0 ? void 0 : _d.parentNode
32
44
  },
33
- estimateSize: React.useCallback(function (i) {
34
- var _a, _b;
35
-
36
- return (_b = (_a = tableProps === null || tableProps === void 0 ? void 0 : tableProps.children[0]) === null || _a === void 0 ? void 0 : _a.props) === null || _b === void 0 ? void 0 : _b.colWidths[i];
37
- }, [(_d = (_c = tableProps.children[0]) === null || _c === void 0 ? void 0 : _c.props) === null || _d === void 0 ? void 0 : _d.colWidths]),
45
+ estimateSize: columnEstimateSize,
38
46
  overscan: 5
39
47
  });
40
48
  var instance = {
@@ -15,13 +15,20 @@ var initialState = {
15
15
  rowHeight: 0,
16
16
  columnsLen: 0,
17
17
  // 总行数
18
- totalLen: 0
18
+ totalLen: 0,
19
+ // 分割后的列数组
20
+ sliceColumns: {
21
+ leftColumns: [],
22
+ centerColumns: [],
23
+ rightColumns: []
24
+ }
19
25
  };
20
26
 
21
27
  var reducer = function reducer(state, action) {
22
28
  var totalLen = action.totalLen,
23
29
  columnsLen = action.columnsLen,
24
- rowHeight = action.rowHeight;
30
+ rowHeight = action.rowHeight,
31
+ sliceColumns = action.sliceColumns;
25
32
 
26
33
  switch (action.type) {
27
34
  // 数据数量
@@ -42,6 +49,11 @@ var reducer = function reducer(state, action) {
42
49
  rowHeight: rowHeight
43
50
  });
44
51
 
52
+ case 'changeSliceColumns':
53
+ return Object.assign(Object.assign({}, state), {
54
+ sliceColumns: sliceColumns
55
+ });
56
+
45
57
  default:
46
58
  throw new Error();
47
59
  }
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  interface rowProps {
3
- children: any;
3
+ children?: any;
4
4
  }
5
5
  declare const VirtualRow: React.NamedExoticComponent<rowProps>;
6
6
  export default VirtualRow;