linkmore-design 1.1.26 → 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 (117) hide show
  1. package/dist/LmEditTable/DndContainer.d.ts +6 -3
  2. package/dist/LmEditTable/EditTable.d.ts +10 -5
  3. package/dist/LmEditTable/components/DraggableContainer.d.ts +10 -0
  4. package/dist/LmEditTable/components/QuickOpetate.d.ts +12 -0
  5. package/dist/LmEditTable/components/bottomOpetateComponent.d.ts +13 -0
  6. package/dist/LmEditTable/components/customRenderEmpty.d.ts +2 -0
  7. package/dist/LmEditTable/components/index.d.ts +17 -0
  8. package/dist/LmEditTable/hooks/useForkRef.d.ts +2 -0
  9. package/dist/LmEditTable/rowSort/DndContainerRow.d.ts +10 -0
  10. package/dist/LmEditTable/sortableItem.d.ts +3 -2
  11. package/dist/LmEditTable/util.d.ts +8 -0
  12. package/dist/LmEditTable/virtual/VirtualRow.d.ts +7 -0
  13. package/dist/LmEditTable/virtual/VirtualRow2.d.ts +7 -0
  14. package/dist/LmEditTable/virtual/VirtualTable.d.ts +3 -0
  15. package/dist/LmEditTable/virtual/VirtualWrapper.d.ts +3 -0
  16. package/dist/LmEditTable/virtual/context.d.ts +13 -0
  17. package/dist/LmEditTable/virtual/index.d.ts +4 -0
  18. package/dist/LmTable/virTual/VirtualRow.d.ts +1 -1
  19. package/dist/index.d.ts +1 -2
  20. package/dist/index.umd.js +1380 -576
  21. package/dist/index.umd.min.js +21 -21
  22. package/dist/variables.css +92 -0
  23. package/es/InputNumber/index.js +7 -9
  24. package/es/LmEditTable/DndContainer.d.ts +6 -3
  25. package/es/LmEditTable/DndContainer.js +70 -10
  26. package/es/LmEditTable/DragHandle.js +1 -1
  27. package/es/LmEditTable/EditTable.d.ts +10 -5
  28. package/es/LmEditTable/EditTable.js +364 -360
  29. package/es/LmEditTable/components/DraggableContainer.d.ts +10 -0
  30. package/es/LmEditTable/components/DraggableContainer.js +39 -0
  31. package/es/LmEditTable/components/QuickOpetate.d.ts +12 -0
  32. package/es/LmEditTable/components/QuickOpetate.js +82 -0
  33. package/es/LmEditTable/components/bottomOpetateComponent.d.ts +13 -0
  34. package/es/LmEditTable/components/bottomOpetateComponent.js +23 -0
  35. package/es/LmEditTable/components/customRenderEmpty.d.ts +2 -0
  36. package/es/LmEditTable/components/customRenderEmpty.js +20 -0
  37. package/es/LmEditTable/components/index.d.ts +17 -0
  38. package/es/LmEditTable/components/index.js +8 -0
  39. package/es/LmEditTable/hooks/useForkRef.d.ts +2 -0
  40. package/es/LmEditTable/hooks/useForkRef.js +22 -0
  41. package/es/LmEditTable/rowSort/DndContainerRow.d.ts +10 -0
  42. package/es/LmEditTable/rowSort/DndContainerRow.js +81 -0
  43. package/es/LmEditTable/sortableItem.d.ts +3 -2
  44. package/es/LmEditTable/sortableItem.js +16 -4
  45. package/es/LmEditTable/sortableItemCol.js +40 -10
  46. package/es/LmEditTable/style/index.css +92 -0
  47. package/es/LmEditTable/style/variables.css +92 -0
  48. package/es/LmEditTable/util.d.ts +8 -0
  49. package/es/LmEditTable/util.js +103 -7
  50. package/es/LmEditTable/virtual/VirtualRow.d.ts +7 -0
  51. package/es/LmEditTable/virtual/VirtualRow.js +140 -0
  52. package/es/LmEditTable/virtual/VirtualRow2.d.ts +7 -0
  53. package/es/LmEditTable/virtual/VirtualRow2.js +62 -0
  54. package/es/LmEditTable/virtual/VirtualTable.d.ts +3 -0
  55. package/es/LmEditTable/virtual/VirtualTable.js +62 -0
  56. package/es/LmEditTable/virtual/VirtualWrapper.d.ts +3 -0
  57. package/es/LmEditTable/virtual/VirtualWrapper.js +60 -0
  58. package/es/LmEditTable/virtual/context.d.ts +13 -0
  59. package/es/LmEditTable/virtual/context.js +66 -0
  60. package/es/LmEditTable/virtual/index.d.ts +4 -0
  61. package/es/LmEditTable/virtual/index.js +4 -0
  62. package/es/LmFilter/filterFns/index.js +7 -2
  63. package/es/LmTable/virTual/VirtualRow.d.ts +1 -1
  64. package/es/LmTable/virTual/VirtualRow.js +82 -48
  65. package/es/LmTable/virTual/VirtualTable.js +17 -9
  66. package/es/LmTable/virTual/context.js +14 -2
  67. package/es/hooks/useEvent/index.js +1 -1
  68. package/es/index.d.ts +1 -2
  69. package/es/styles/variables.css +92 -0
  70. package/lib/InputNumber/index.js +9 -9
  71. package/lib/LmEditTable/DndContainer.d.ts +6 -3
  72. package/lib/LmEditTable/DndContainer.js +74 -9
  73. package/lib/LmEditTable/DragHandle.js +1 -1
  74. package/lib/LmEditTable/EditTable.d.ts +10 -5
  75. package/lib/LmEditTable/EditTable.js +362 -357
  76. package/lib/LmEditTable/components/DraggableContainer.d.ts +10 -0
  77. package/lib/LmEditTable/components/DraggableContainer.js +52 -0
  78. package/lib/LmEditTable/components/QuickOpetate.d.ts +12 -0
  79. package/lib/LmEditTable/components/QuickOpetate.js +96 -0
  80. package/lib/LmEditTable/components/bottomOpetateComponent.d.ts +13 -0
  81. package/lib/LmEditTable/components/bottomOpetateComponent.js +34 -0
  82. package/lib/LmEditTable/components/customRenderEmpty.d.ts +2 -0
  83. package/lib/LmEditTable/components/customRenderEmpty.js +32 -0
  84. package/lib/LmEditTable/components/index.d.ts +17 -0
  85. package/lib/LmEditTable/components/index.js +45 -0
  86. package/lib/LmEditTable/hooks/useForkRef.d.ts +2 -0
  87. package/lib/LmEditTable/hooks/useForkRef.js +29 -0
  88. package/lib/LmEditTable/rowSort/DndContainerRow.d.ts +10 -0
  89. package/lib/LmEditTable/rowSort/DndContainerRow.js +99 -0
  90. package/lib/LmEditTable/sortableItem.d.ts +3 -2
  91. package/lib/LmEditTable/sortableItem.js +19 -5
  92. package/lib/LmEditTable/sortableItemCol.js +37 -8
  93. package/lib/LmEditTable/style/index.css +92 -0
  94. package/lib/LmEditTable/style/variables.css +92 -0
  95. package/lib/LmEditTable/util.d.ts +8 -0
  96. package/lib/LmEditTable/util.js +110 -6
  97. package/lib/LmEditTable/virtual/VirtualRow.d.ts +7 -0
  98. package/lib/LmEditTable/virtual/VirtualRow.js +155 -0
  99. package/lib/LmEditTable/virtual/VirtualRow2.d.ts +7 -0
  100. package/lib/LmEditTable/virtual/VirtualRow2.js +78 -0
  101. package/lib/LmEditTable/virtual/VirtualTable.d.ts +3 -0
  102. package/lib/LmEditTable/virtual/VirtualTable.js +79 -0
  103. package/lib/LmEditTable/virtual/VirtualWrapper.d.ts +3 -0
  104. package/lib/LmEditTable/virtual/VirtualWrapper.js +73 -0
  105. package/lib/LmEditTable/virtual/context.d.ts +13 -0
  106. package/lib/LmEditTable/virtual/context.js +76 -0
  107. package/lib/LmEditTable/virtual/index.d.ts +4 -0
  108. package/lib/LmEditTable/virtual/index.js +31 -0
  109. package/lib/LmFilter/filterFns/index.js +7 -2
  110. package/lib/LmTable/virTual/VirtualRow.d.ts +1 -1
  111. package/lib/LmTable/virTual/VirtualRow.js +81 -48
  112. package/lib/LmTable/virTual/VirtualTable.js +16 -8
  113. package/lib/LmTable/virTual/context.js +14 -2
  114. package/lib/hooks/useEvent/index.js +1 -1
  115. package/lib/index.d.ts +1 -2
  116. package/lib/styles/variables.css +92 -0
  117. package/package.json +7 -9
@@ -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
  }
@@ -538,6 +542,9 @@ p {
538
542
  width: 32px;
539
543
  padding: 0 8px;
540
544
  }
545
+ .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 {
546
+ height: 100%;
547
+ }
541
548
  .lm_editTable_warpper .lm_editTable_cell {
542
549
  cursor: pointer;
543
550
  height: 40px;
@@ -549,6 +556,21 @@ p {
549
556
  letter-spacing: 0px;
550
557
  color: var(--color-85);
551
558
  }
559
+ .lm_editTable_warpper .lm_custom_cell_td {
560
+ position: relative;
561
+ }
562
+ .lm_editTable_warpper .lm_custom_cell_td.ant-table-cell-with-append {
563
+ display: flex;
564
+ flex-direction: row;
565
+ flex-wrap: nowrap;
566
+ }
567
+ .lm_editTable_warpper .lm_custom_cell_td.ant-table-cell-with-append .ant-table-row-expand-icon {
568
+ margin-right: 8px;
569
+ flex: none;
570
+ }
571
+ .lm_editTable_warpper .lm_custom_cell_td > .ant-form-item {
572
+ flex: 1 1 auto;
573
+ }
552
574
  .lm_editTable_warpper .lm_custom_cell_td .ant-form-item-control-input-content {
553
575
  display: flex;
554
576
  flex-direction: row;
@@ -560,6 +582,32 @@ p {
560
582
  .lm_editTable_warpper .lm_custom_cell_td .ant-table-row-expand-icon {
561
583
  margin-top: 6px;
562
584
  }
585
+ .lm_editTable_warpper .lm_custom_cell_td .quick_copy_warp {
586
+ font-size: 8px;
587
+ position: absolute;
588
+ left: calc(50% - 10px);
589
+ z-index: 100;
590
+ width: 20px;
591
+ height: 10px;
592
+ background-color: var(--color-6);
593
+ display: flex;
594
+ align-items: center;
595
+ justify-content: center;
596
+ color: #D8D8D8;
597
+ }
598
+ .lm_editTable_warpper .lm_custom_cell_td .quick_copy_warp:hover {
599
+ cursor: pointer;
600
+ background-color: var(--primary-color);
601
+ color: #fff;
602
+ }
603
+ .lm_editTable_warpper .lm_custom_cell_td .quick_copy_up {
604
+ top: -4px;
605
+ left: calc(50% - 10px);
606
+ }
607
+ .lm_editTable_warpper .lm_custom_cell_td .quick_copy_down {
608
+ bottom: -6px;
609
+ left: calc(50% - 10px);
610
+ }
563
611
  .lm_editTable_warpper .lm_editTable_cell_edit {
564
612
  height: 40px;
565
613
  padding: 8px 8px !important;
@@ -571,6 +619,9 @@ p {
571
619
  .lm_editTable_warpper .lm_table_quickcopy .anticon {
572
620
  color: var(--text-color);
573
621
  }
622
+ .lm_editTable_warpper .ant-table-body {
623
+ scroll-behavior: smooth;
624
+ }
574
625
  .lm_editTable_warpper .icon_drag {
575
626
  color: var(--tip-text-color);
576
627
  }
@@ -587,6 +638,32 @@ p {
587
638
  .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 {
588
639
  background-color: rgba(0, 0, 0, 0.06) !important;
589
640
  }
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 {
642
+ background-color: rgba(0, 0, 0, 0.06) !important;
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
+ }
590
667
  .lm_editTable_warpper .ant-picker {
591
668
  height: 24px !important;
592
669
  padding: 2px 8px;
@@ -630,3 +707,18 @@ p {
630
707
  .lm_table_append_add_popover .ant-popover-inner-content ul li:hover {
631
708
  background-color: var(--color-15);
632
709
  }
710
+ .lm_edittable_col_sort_item {
711
+ overflow: hidden;
712
+ }
713
+ .lm_editable_col_drag {
714
+ background-color: #fff;
715
+ font-size: 12px;
716
+ display: flex;
717
+ box-sizing: border-box;
718
+ transform: translate3d(var(--translate-x, 0), var(--translate-y, 0), 0) scaleX(var(--scale-x, 1)) scaleY(var(--scale-y, 1));
719
+ transform-origin: 0 0;
720
+ touch-action: manipulation;
721
+ scale: 1.05;
722
+ box-shadow: 0 0 0 calc(1px / var(--scale-x, 1)) rgba(63, 63, 68, 0.05), 0 1px calc(3px / var(--scale-x, 1)) 0 rgba(34, 33, 81, 0.15);
723
+ padding: 8px;
724
+ }
@@ -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
  }
@@ -26,6 +30,9 @@
26
30
  width: 32px;
27
31
  padding: 0 8px;
28
32
  }
33
+ .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 {
34
+ height: 100%;
35
+ }
29
36
  .lm_editTable_warpper .lm_editTable_cell {
30
37
  cursor: pointer;
31
38
  height: 40px;
@@ -37,6 +44,21 @@
37
44
  letter-spacing: 0px;
38
45
  color: var(--color-85);
39
46
  }
47
+ .lm_editTable_warpper .lm_custom_cell_td {
48
+ position: relative;
49
+ }
50
+ .lm_editTable_warpper .lm_custom_cell_td.ant-table-cell-with-append {
51
+ display: flex;
52
+ flex-direction: row;
53
+ flex-wrap: nowrap;
54
+ }
55
+ .lm_editTable_warpper .lm_custom_cell_td.ant-table-cell-with-append .ant-table-row-expand-icon {
56
+ margin-right: 8px;
57
+ flex: none;
58
+ }
59
+ .lm_editTable_warpper .lm_custom_cell_td > .ant-form-item {
60
+ flex: 1 1 auto;
61
+ }
40
62
  .lm_editTable_warpper .lm_custom_cell_td .ant-form-item-control-input-content {
41
63
  display: flex;
42
64
  flex-direction: row;
@@ -48,6 +70,32 @@
48
70
  .lm_editTable_warpper .lm_custom_cell_td .ant-table-row-expand-icon {
49
71
  margin-top: 6px;
50
72
  }
73
+ .lm_editTable_warpper .lm_custom_cell_td .quick_copy_warp {
74
+ font-size: 8px;
75
+ position: absolute;
76
+ left: calc(50% - 10px);
77
+ z-index: 100;
78
+ width: 20px;
79
+ height: 10px;
80
+ background-color: var(--color-6);
81
+ display: flex;
82
+ align-items: center;
83
+ justify-content: center;
84
+ color: #D8D8D8;
85
+ }
86
+ .lm_editTable_warpper .lm_custom_cell_td .quick_copy_warp:hover {
87
+ cursor: pointer;
88
+ background-color: var(--primary-color);
89
+ color: #fff;
90
+ }
91
+ .lm_editTable_warpper .lm_custom_cell_td .quick_copy_up {
92
+ top: -4px;
93
+ left: calc(50% - 10px);
94
+ }
95
+ .lm_editTable_warpper .lm_custom_cell_td .quick_copy_down {
96
+ bottom: -6px;
97
+ left: calc(50% - 10px);
98
+ }
51
99
  .lm_editTable_warpper .lm_editTable_cell_edit {
52
100
  height: 40px;
53
101
  padding: 8px 8px !important;
@@ -59,6 +107,9 @@
59
107
  .lm_editTable_warpper .lm_table_quickcopy .anticon {
60
108
  color: var(--text-color);
61
109
  }
110
+ .lm_editTable_warpper .ant-table-body {
111
+ scroll-behavior: smooth;
112
+ }
62
113
  .lm_editTable_warpper .icon_drag {
63
114
  color: var(--tip-text-color);
64
115
  }
@@ -75,6 +126,32 @@
75
126
  .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 {
76
127
  background-color: rgba(0, 0, 0, 0.06) !important;
77
128
  }
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 {
130
+ background-color: rgba(0, 0, 0, 0.06) !important;
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
+ }
78
155
  .lm_editTable_warpper .ant-picker {
79
156
  height: 24px !important;
80
157
  padding: 2px 8px;
@@ -118,3 +195,18 @@
118
195
  .lm_table_append_add_popover .ant-popover-inner-content ul li:hover {
119
196
  background-color: var(--color-15);
120
197
  }
198
+ .lm_edittable_col_sort_item {
199
+ overflow: hidden;
200
+ }
201
+ .lm_editable_col_drag {
202
+ background-color: #fff;
203
+ font-size: 12px;
204
+ display: flex;
205
+ box-sizing: border-box;
206
+ transform: translate3d(var(--translate-x, 0), var(--translate-y, 0), 0) scaleX(var(--scale-x, 1)) scaleY(var(--scale-y, 1));
207
+ transform-origin: 0 0;
208
+ touch-action: manipulation;
209
+ scale: 1.05;
210
+ box-shadow: 0 0 0 calc(1px / var(--scale-x, 1)) rgba(63, 63, 68, 0.05), 0 1px calc(3px / var(--scale-x, 1)) 0 rgba(34, 33, 81, 0.15);
211
+ padding: 8px;
212
+ }
@@ -2,6 +2,14 @@ export declare function isObjEmpty(obj: Record<string, any>): boolean;
2
2
  export declare function deepDataSourcePreKeys(dataSource: any[], rowKey: string): any;
3
3
  export declare function isExpandRow(children: any): boolean;
4
4
  export declare function checkRowKeyByDataSource(dataSource: any, rowKey: any): any;
5
+ export declare function getExpandStatus(children: any): any;
6
+ export declare function checkMemoShouldUploadSpecialFun(prev: any, next: any): any;
7
+ export declare function checkExpandIconColumnIndex({ rowSelection, sortOpen, indexCol }: {
8
+ rowSelection: any;
9
+ sortOpen: any;
10
+ indexCol: any;
11
+ }): number;
12
+ export declare function checkDataSourceIsEmpty(config: any, dataSource: any): any;
5
13
  declare const _default: {
6
14
  isObjEmpty: typeof isObjEmpty;
7
15
  };
@@ -5,9 +5,13 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
+ exports.checkDataSourceIsEmpty = checkDataSourceIsEmpty;
9
+ exports.checkExpandIconColumnIndex = checkExpandIconColumnIndex;
10
+ exports.checkMemoShouldUploadSpecialFun = checkMemoShouldUploadSpecialFun;
8
11
  exports.checkRowKeyByDataSource = checkRowKeyByDataSource;
9
12
  exports.deepDataSourcePreKeys = deepDataSourcePreKeys;
10
13
  exports.default = void 0;
14
+ exports.getExpandStatus = getExpandStatus;
11
15
  exports.isExpandRow = isExpandRow;
12
16
  exports.isObjEmpty = isObjEmpty;
13
17
 
@@ -26,19 +30,20 @@ function isObjEmpty(obj) {
26
30
  function deepDataSourcePreKeys(dataSource, rowKey) {
27
31
  var deepDataSource = [];
28
32
 
29
- var eachChildren = function eachChildren(children, preKeys) {
30
- children === null || children === void 0 ? void 0 : children.forEach(function (item) {
33
+ var eachChildren = function eachChildren(children, preKeys, deepIds) {
34
+ children === null || children === void 0 ? void 0 : children.forEach(function (item, index) {
31
35
  deepDataSource.push(Object.assign(Object.assign({}, item), {
32
- preKeys: [].concat((0, _toConsumableArray2.default)(preKeys), [item === null || item === void 0 ? void 0 : item[rowKey]])
36
+ preKeys: [].concat((0, _toConsumableArray2.default)(preKeys), [item === null || item === void 0 ? void 0 : item[rowKey]]),
37
+ _deepIds: [].concat((0, _toConsumableArray2.default)(deepIds), [index + 1])
33
38
  }));
34
39
 
35
40
  if (item === null || item === void 0 ? void 0 : item.children) {
36
- eachChildren(item === null || item === void 0 ? void 0 : item.children, [].concat((0, _toConsumableArray2.default)(preKeys), [item === null || item === void 0 ? void 0 : item[rowKey]])); // deepDataSource.push({ ...item, preKeys: [...preKeys, item[rowKey]] })
41
+ eachChildren(item === null || item === void 0 ? void 0 : item.children, [].concat((0, _toConsumableArray2.default)(preKeys), [item === null || item === void 0 ? void 0 : item[rowKey]]), [].concat((0, _toConsumableArray2.default)(deepIds), [index + 1])); // deepDataSource.push({ ...item, preKeys: [...preKeys, item[rowKey]] })
37
42
  }
38
43
  });
39
44
  };
40
45
 
41
- eachChildren(dataSource, []);
46
+ eachChildren(dataSource, [], []);
42
47
  return (0, _lodash.keyBy)(deepDataSource, rowKey);
43
48
  }
44
49
 
@@ -72,7 +77,106 @@ function checkRowKeyByDataSource(dataSource, rowKey) {
72
77
 
73
78
  return Object.assign(Object.assign({}, v), (0, _defineProperty2.default)({}, rowKey, v[rowKey] || "v".concat(idx + 1)));
74
79
  });
75
- return res;
80
+ return res || [];
81
+ }
82
+
83
+ function getExpandStatus(children) {
84
+ var _a, _b, _c, _d, _e;
85
+
86
+ return isExpandRow(children) ? (_e = (_d = (_c = (_b = (_a = children === null || children === void 0 ? void 0 : children[0]) === null || _a === void 0 ? void 0 : _a.props) === null || _b === void 0 ? void 0 : _b.children) === null || _c === void 0 ? void 0 : _c[1]) === null || _d === void 0 ? void 0 : _d.props) === null || _e === void 0 ? void 0 : _e['aria-label'] : '';
87
+ }
88
+
89
+ function checkMemoShouldUploadSpecialFun(prev, next) {
90
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r;
91
+
92
+ var checkExpandStatus = getExpandStatus(prev.children) === getExpandStatus(next.children);
93
+
94
+ if (!checkExpandStatus) {
95
+ return false;
96
+ }
97
+
98
+ var prevCol = prev === null || prev === void 0 ? void 0 : prev.col;
99
+ var nextCol = next === null || next === void 0 ? void 0 : next.col;
100
+ /** TODO: 使用了自定义render, 是否要判断rowIndex? 这样排序之后,渲染的性能就会变差 */
101
+
102
+ if (((prevCol === null || prevCol === void 0 ? void 0 : prevCol.render) || (nextCol === null || nextCol === void 0 ? void 0 : nextCol.render)) && !(0, _lodash.isEqual)((0, _lodash.pick)(prev, ['colIndex', 'record', 'children']), (0, _lodash.pick)(next, ['colIndex', 'record', 'children']))) {
103
+ return false;
104
+ }
105
+
106
+ if (!(next === null || next === void 0 ? void 0 : next.quickOpetateClearAll) && ((next === null || next === void 0 ? void 0 : next.getLength) < 2 || (prev === null || prev === void 0 ? void 0 : prev.getLength) === 1) && (next === null || next === void 0 ? void 0 : next.dataIndex) === 'lm_edit_opetate') {
107
+ return false;
108
+ }
109
+
110
+ if (prev.isEdit !== next.isEdit) {
111
+ return false;
112
+ } // console.log(22, prevCol?.editable === 'render', nextCol?.editable === 'render', prevCol?.componentProps, prevCol?.componentProps)
113
+
114
+
115
+ if (((prevCol === null || prevCol === void 0 ? void 0 : prevCol.editable) === 'render' || (nextCol === null || nextCol === void 0 ? void 0 : nextCol.editable) === 'render') && (((_a = prevCol === null || prevCol === void 0 ? void 0 : prevCol.componentProps) === null || _a === void 0 ? void 0 : _a.render) || ((_b = nextCol === null || nextCol === void 0 ? void 0 : nextCol.componentProps) === null || _b === void 0 ? void 0 : _b.render)) && (!(0, _lodash.isEqual)((0, _lodash.omit)(prevCol === null || prevCol === void 0 ? void 0 : prevCol.componentProps, ['render']), (0, _lodash.omit)(nextCol === null || nextCol === void 0 ? void 0 : nextCol.componentProps, ['render'])) || !(0, _lodash.isEqual)((0, _lodash.pick)(prev, ['colIndex', 'record', 'rowIndex']), (0, _lodash.pick)(next, ['colIndex', 'record', 'rowIndex'])))) {
116
+ return false;
117
+ }
118
+
119
+ if (((prevCol === null || prevCol === void 0 ? void 0 : prevCol.fixed) || (nextCol === null || nextCol === void 0 ? void 0 : nextCol.fixed)) && !(0, _lodash.isEqual)(prev === null || prev === void 0 ? void 0 : prev.style, next === null || next === void 0 ? void 0 : next.style)) {
120
+ return false;
121
+ }
122
+
123
+ if ((((_c = prevCol === null || prevCol === void 0 ? void 0 : prevCol.componentProps) === null || _c === void 0 ? void 0 : _c.optionOnly) || ((_d = nextCol === null || nextCol === void 0 ? void 0 : nextCol.componentProps) === null || _d === void 0 ? void 0 : _d.optionOnly)) && !(0, _lodash.isEqual)((_e = prevCol === null || prevCol === void 0 ? void 0 : prevCol.componentProps) === null || _e === void 0 ? void 0 : _e.options, (_f = nextCol === null || nextCol === void 0 ? void 0 : nextCol.componentProps) === null || _f === void 0 ? void 0 : _f.options)) {
124
+ return false;
125
+ }
126
+
127
+ if ((((_g = prevCol === null || prevCol === void 0 ? void 0 : prevCol.componentProps) === null || _g === void 0 ? void 0 : _g.options) || ((_h = nextCol === null || nextCol === void 0 ? void 0 : nextCol.componentProps) === null || _h === void 0 ? void 0 : _h.options)) && !(0, _lodash.isEqual)((_j = prevCol === null || prevCol === void 0 ? void 0 : prevCol.componentProps) === null || _j === void 0 ? void 0 : _j.options, (_k = nextCol === null || nextCol === void 0 ? void 0 : nextCol.componentProps) === null || _k === void 0 ? void 0 : _k.options)) {
128
+ return false;
129
+ }
130
+
131
+ if (((0, _lodash.isFunction)(prevCol === null || prevCol === void 0 ? void 0 : prevCol.componentProps) || (0, _lodash.isFunction)(nextCol === null || nextCol === void 0 ? void 0 : nextCol.componentProps)) && !(0, _lodash.isEqual)(prevCol.newOptions, nextCol.newOptions) && !(0, _lodash.isEqual)(prevCol === null || prevCol === void 0 ? void 0 : prevCol.componentProps, nextCol === null || nextCol === void 0 ? void 0 : nextCol.componentProps)) {
132
+ return false;
133
+ }
134
+
135
+ if (((prevCol === null || prevCol === void 0 ? void 0 : prevCol.order) || (nextCol === null || nextCol === void 0 ? void 0 : nextCol.order)) && !(0, _lodash.isEqual)(prevCol === null || prevCol === void 0 ? void 0 : prevCol.order, nextCol === null || nextCol === void 0 ? void 0 : nextCol.order)) {
136
+ // return isEqual(prevCol?.order, nextCol?.fixed)
137
+ return false;
138
+ }
139
+
140
+ if (next.className.indexOf('drag-visible') > -1) {
141
+ return (0, _lodash.isEqual)(prev.style, next.style);
142
+ }
143
+
144
+ if (next.className.indexOf('ant-table-selection-column') > -1) {
145
+ return (0, _lodash.isEqual)((_m = (_l = prev.children) === null || _l === void 0 ? void 0 : _l[1]) === null || _m === void 0 ? void 0 : _m.props, (_p = (_o = next.children) === null || _o === void 0 ? void 0 : _o[1]) === null || _p === void 0 ? void 0 : _p.props);
146
+ }
147
+ /** 如果启用了快速复制功能,需要实时判断rowIndex与getLength */
148
+
149
+
150
+ if (((_q = prevCol === null || prevCol === void 0 ? void 0 : prevCol.componentProps) === null || _q === void 0 ? void 0 : _q.quickcopy) || ((_r = nextCol === null || nextCol === void 0 ? void 0 : nextCol.componentProps) === null || _r === void 0 ? void 0 : _r.quickcopy)) {
151
+ var pickProps = ['record', 'colIndex', 'rowIndex', 'getLength'];
152
+ var p = (0, _lodash.pick)(prev, pickProps);
153
+ var n = (0, _lodash.pick)(next, pickProps);
154
+ return (0, _lodash.isEqual)(p, n);
155
+ }
156
+
157
+ return true;
158
+ }
159
+
160
+ function checkExpandIconColumnIndex(_ref) {
161
+ var rowSelection = _ref.rowSelection,
162
+ sortOpen = _ref.sortOpen,
163
+ indexCol = _ref.indexCol;
164
+ var arr = [rowSelection, sortOpen, indexCol].filter(function (item) {
165
+ return !!item;
166
+ });
167
+ return arr.length;
168
+ }
169
+
170
+ function checkDataSourceIsEmpty(config, dataSource) {
171
+ if (dataSource.length) {
172
+ return config;
173
+ }
174
+
175
+ return Object.assign(Object.assign({}, config), {
176
+ components: Object.assign(Object.assign({}, config.components), {
177
+ body: {}
178
+ })
179
+ });
76
180
  }
77
181
 
78
182
  var _default = {
@@ -0,0 +1,7 @@
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,155 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.default = void 0;
11
+
12
+ var _react = _interopRequireWildcard(require("react"));
13
+
14
+ var _context = require("./context");
15
+
16
+ var _useForkRef = _interopRequireDefault(require("../hooks/useForkRef"));
17
+
18
+ var __rest = void 0 && (void 0).__rest || function (s, e) {
19
+ var t = {};
20
+
21
+ for (var p in s) {
22
+ if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
23
+ }
24
+
25
+ if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
26
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
27
+ }
28
+ return t;
29
+ };
30
+
31
+ var useOptions = function useOptions(_ref) {
32
+ var children = _ref.children,
33
+ ref = _ref.ref,
34
+ trRef = _ref.trRef;
35
+
36
+ var _useStore = (0, _context.useStore)(),
37
+ state = _useStore.state,
38
+ dispatch = _useStore.dispatch,
39
+ instance = _useStore.instance;
40
+
41
+ var virtualItems = instance.columnVirtual.virtualItems;
42
+ var rowHeight = state.rowHeight,
43
+ totalLen = state.totalLen;
44
+ var sliceColumns = (0, _react.useMemo)(function () {
45
+ return children === null || children === void 0 ? void 0 : children.reduce(function (pre, cur) {
46
+ var _a, _b;
47
+
48
+ if (typeof ((_a = cur.props) === null || _a === void 0 ? void 0 : _a.fixLeft) === 'number') {
49
+ pre.leftColumns.push(cur);
50
+ return pre;
51
+ }
52
+
53
+ if (typeof ((_b = cur.props) === null || _b === void 0 ? void 0 : _b.fixRight) === 'number') {
54
+ pre.rightColumns.push(cur);
55
+ return pre;
56
+ }
57
+
58
+ pre.centerColumns.push(cur);
59
+ return pre;
60
+ }, {
61
+ leftColumns: [],
62
+ rightColumns: [],
63
+ centerColumns: []
64
+ });
65
+ }, [children]);
66
+ (0, _react.useEffect)(function () {
67
+ dispatch({
68
+ type: 'changeSliceColumns',
69
+ sliceColumns: sliceColumns
70
+ });
71
+ }, [sliceColumns]); // 非固定列长度
72
+
73
+ var centerColumnsLen = (0, _react.useMemo)(function () {
74
+ var _a;
75
+
76
+ return (_a = sliceColumns.centerColumns.length) !== null && _a !== void 0 ? _a : 0;
77
+ }, [sliceColumns]);
78
+ (0, _react.useEffect)(function () {
79
+ if (state.columnsLen !== centerColumnsLen) {
80
+ dispatch({
81
+ type: 'changeColumnsLen',
82
+ columnsLen: centerColumnsLen !== null && centerColumnsLen !== void 0 ? centerColumnsLen : 0
83
+ });
84
+ }
85
+ }, [centerColumnsLen, dispatch, state.columnsLen]); // 获取行的高度
86
+
87
+ (0, _react.useEffect)(function () {
88
+ var initHeight = function initHeight(tempRef) {
89
+ var _a, _b, _c;
90
+
91
+ if (((_a = tempRef === null || tempRef === void 0 ? void 0 : tempRef.current) === null || _a === void 0 ? void 0 : _a.offsetHeight) && !rowHeight && totalLen) {
92
+ 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;
93
+ dispatch({
94
+ type: 'initHeight',
95
+ rowHeight: tempRowHeight + 1
96
+ });
97
+ }
98
+ };
99
+
100
+ initHeight(Object.prototype.hasOwnProperty.call(ref, 'current') ? ref : trRef);
101
+ }, [trRef, dispatch, rowHeight, totalLen, ref]); // 横向单元格合并
102
+
103
+ var leftColSpan = (0, _react.useMemo)(function () {
104
+ var _a;
105
+
106
+ return (_a = virtualItems[0]) === null || _a === void 0 ? void 0 : _a.index;
107
+ }, [virtualItems]); // 右侧隐藏数量
108
+
109
+ var rightColSpan = (0, _react.useMemo)(function () {
110
+ return sliceColumns.centerColumns.length - virtualItems.length - leftColSpan || 0;
111
+ }, [sliceColumns.centerColumns.length, virtualItems.length, leftColSpan]);
112
+ return Object.assign(Object.assign({
113
+ virtualItems: virtualItems
114
+ }, sliceColumns), {
115
+ leftColSpan: leftColSpan,
116
+ rightColSpan: rightColSpan
117
+ });
118
+ };
119
+
120
+ var VirtualRow = /*#__PURE__*/_react.default.memo(function (_a, ref) {
121
+ var children = _a.children,
122
+ pref = _a.pref,
123
+ resetProps = __rest(_a, ["children", "pref"]);
124
+
125
+ var trRef = (0, _react.useRef)(null);
126
+
127
+ var _useOptions = useOptions({
128
+ children: children,
129
+ ref: ref,
130
+ trRef: trRef
131
+ }),
132
+ virtualItems = _useOptions.virtualItems,
133
+ leftColumns = _useOptions.leftColumns,
134
+ centerColumns = _useOptions.centerColumns,
135
+ rightColumns = _useOptions.rightColumns,
136
+ leftColSpan = _useOptions.leftColSpan,
137
+ rightColSpan = _useOptions.rightColSpan;
138
+
139
+ return /*#__PURE__*/_react.default.createElement("tr", Object.assign({}, resetProps, {
140
+ ref: (0, _useForkRef.default)(pref, trRef)
141
+ }), leftColumns, !!leftColSpan && /*#__PURE__*/_react.default.createElement("td", {
142
+ key: "leftColSpan",
143
+ colSpan: leftColSpan
144
+ }), virtualItems.map(function (virtualCol) {
145
+ return /*#__PURE__*/_react.default.cloneElement(centerColumns[virtualCol.index], {
146
+ ref: virtualCol.measureRef
147
+ });
148
+ }), !!rightColSpan && /*#__PURE__*/_react.default.createElement("td", {
149
+ key: "rightColSpan",
150
+ colSpan: rightColSpan
151
+ }), rightColumns);
152
+ });
153
+
154
+ var _default = VirtualRow;
155
+ exports.default = _default;
@@ -0,0 +1,7 @@
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;