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.
- package/dist/LmEditTable/components/customRenderEmpty.d.ts +2 -0
- package/dist/LmEditTable/components/index.d.ts +2 -1
- package/dist/LmEditTable/util.d.ts +1 -0
- package/{lib/LmEditTable/virtual/VirtualRowBack.d.ts → dist/LmEditTable/virtual/VirtualRow2.d.ts} +7 -6
- package/dist/LmTable/virTual/VirtualRow.d.ts +1 -1
- package/dist/index.umd.js +280 -87
- package/dist/index.umd.min.js +21 -21
- package/dist/variables.css +27 -0
- package/es/LmEditTable/EditTable.js +19 -7
- package/es/LmEditTable/components/customRenderEmpty.d.ts +2 -0
- package/es/LmEditTable/components/customRenderEmpty.js +20 -0
- package/es/LmEditTable/components/index.d.ts +2 -1
- package/es/LmEditTable/components/index.js +2 -1
- package/es/LmEditTable/style/index.css +27 -0
- package/es/LmEditTable/style/variables.css +27 -0
- package/es/LmEditTable/util.d.ts +1 -0
- package/es/LmEditTable/util.js +11 -0
- package/es/LmEditTable/virtual/VirtualRow.js +94 -16
- package/{dist/LmEditTable/virtual/VirtualRowBack.d.ts → es/LmEditTable/virtual/VirtualRow2.d.ts} +7 -6
- package/es/LmEditTable/virtual/VirtualRow2.js +62 -0
- package/es/LmEditTable/virtual/VirtualTable.js +17 -9
- package/es/LmEditTable/virtual/context.js +14 -2
- package/es/LmTable/virTual/VirtualRow.d.ts +1 -1
- package/es/LmTable/virTual/VirtualRow.js +80 -44
- package/es/LmTable/virTual/VirtualTable.js +17 -9
- package/es/LmTable/virTual/context.js +14 -2
- package/es/styles/variables.css +27 -0
- package/lib/LmEditTable/EditTable.js +18 -5
- package/lib/LmEditTable/components/customRenderEmpty.d.ts +2 -0
- package/lib/LmEditTable/components/customRenderEmpty.js +32 -0
- package/lib/LmEditTable/components/index.d.ts +2 -1
- package/lib/LmEditTable/components/index.js +8 -0
- package/lib/LmEditTable/style/index.css +27 -0
- package/lib/LmEditTable/style/variables.css +27 -0
- package/lib/LmEditTable/util.d.ts +1 -0
- package/lib/LmEditTable/util.js +13 -0
- package/lib/LmEditTable/virtual/VirtualRow.js +93 -16
- package/{es/LmEditTable/virtual/VirtualRowBack.d.ts → lib/LmEditTable/virtual/VirtualRow2.d.ts} +1 -0
- package/lib/LmEditTable/virtual/{VirtualRowBack.js → VirtualRow2.js} +13 -48
- package/lib/LmEditTable/virtual/VirtualTable.js +16 -8
- package/lib/LmEditTable/virtual/context.js +14 -2
- package/lib/LmTable/virTual/VirtualRow.d.ts +1 -1
- package/lib/LmTable/virTual/VirtualRow.js +79 -44
- package/lib/LmTable/virTual/VirtualTable.js +16 -8
- package/lib/LmTable/virTual/context.js +14 -2
- package/lib/styles/variables.css +27 -0
- package/package.json +1 -1
- package/es/LmEditTable/virtual/VirtualRowBack.js +0 -100
package/dist/variables.css
CHANGED
|
@@ -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(
|
|
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,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
|
-
|
|
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
|
-
|
|
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;
|
package/es/LmEditTable/util.d.ts
CHANGED
|
@@ -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
|
};
|
package/es/LmEditTable/util.js
CHANGED
|
@@ -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
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
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
|
|
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
|
-
|
|
31
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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:
|
|
69
|
+
columnsLen: centerColumnsLen !== null && centerColumnsLen !== void 0 ? centerColumnsLen : 0
|
|
40
70
|
});
|
|
41
71
|
}
|
|
42
|
-
}, [
|
|
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
|
-
}),
|
|
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;
|
package/{dist/LmEditTable/virtual/VirtualRowBack.d.ts → es/LmEditTable/virtual/VirtualRow2.d.ts}
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
interface rowProps {
|
|
3
|
-
children?: any;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
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: (
|
|
43
|
+
current: (_d = bodyRef === null || bodyRef === void 0 ? void 0 : bodyRef.current) === null || _d === void 0 ? void 0 : _d.parentNode
|
|
32
44
|
},
|
|
33
|
-
estimateSize:
|
|
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
|
}
|