vxe-table 3.19.39 → 3.20.0-beta.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/es/index.css +1 -1
- package/es/index.esm.js +2 -1
- package/es/index.min.css +1 -1
- package/es/style.css +1 -1
- package/es/style.min.css +1 -1
- package/es/table/module/custom/mixin.js +6 -4
- package/es/table/module/custom/panel.js +806 -799
- package/es/table/module/edit/mixin.js +43 -31
- package/es/table/module/export/export-panel.js +511 -458
- package/es/table/module/export/import-panel.js +224 -192
- package/es/table/module/keyboard/mixin.js +2 -2
- package/es/table/module/menu/panel.js +165 -161
- package/es/table/module/validator/mixin.js +255 -236
- package/es/table/src/body.js +2 -1
- package/es/table/src/cell.js +2 -2
- package/es/table/src/methods.js +33 -43
- package/es/table/src/table.js +13 -249
- package/es/table/src/util.js +242 -0
- package/es/table/style.css +23 -50
- package/es/table/style.min.css +1 -1
- package/es/ui/index.js +2 -2
- package/es/ui/src/dom.js +22 -0
- package/es/ui/src/log.js +1 -1
- package/es/vxe-table/style.css +23 -50
- package/es/vxe-table/style.min.css +1 -1
- package/lib/index.common.js +2 -1
- package/lib/index.css +1 -1
- package/lib/index.min.css +1 -1
- package/lib/index.umd.js +3640 -4790
- package/lib/index.umd.min.js +1 -1
- package/lib/style.css +1 -1
- package/lib/style.min.css +1 -1
- package/lib/table/module/custom/mixin.js +6 -4
- package/lib/table/module/custom/mixin.min.js +1 -1
- package/lib/table/module/custom/panel.js +693 -685
- package/lib/table/module/custom/panel.min.js +1 -1
- package/lib/table/module/edit/mixin.js +47 -31
- package/lib/table/module/edit/mixin.min.js +1 -1
- package/lib/table/module/export/export-panel.js +450 -384
- package/lib/table/module/export/export-panel.min.js +1 -1
- package/lib/table/module/export/import-panel.js +200 -159
- package/lib/table/module/export/import-panel.min.js +1 -1
- package/lib/table/module/keyboard/mixin.js +2 -2
- package/lib/table/module/keyboard/mixin.min.js +1 -1
- package/lib/table/module/menu/panel.js +119 -114
- package/lib/table/module/menu/panel.min.js +1 -1
- package/lib/table/module/validator/mixin.js +271 -259
- package/lib/table/module/validator/mixin.min.js +1 -1
- package/lib/table/src/body.js +2 -1
- package/lib/table/src/body.min.js +1 -1
- package/lib/table/src/cell.js +2 -2
- package/lib/table/src/cell.min.js +1 -1
- package/lib/table/src/methods.js +33 -45
- package/lib/table/src/methods.min.js +1 -1
- package/lib/table/src/table.js +12 -248
- package/lib/table/src/table.min.js +1 -1
- package/lib/table/src/util.js +243 -0
- package/lib/table/src/util.min.js +1 -1
- package/lib/table/style/style.css +23 -50
- package/lib/table/style/style.min.css +1 -1
- package/lib/ui/index.js +2 -2
- package/lib/ui/index.min.js +1 -1
- package/lib/ui/src/dom.js +22 -0
- package/lib/ui/src/dom.min.js +1 -1
- package/lib/ui/src/log.js +1 -1
- package/lib/ui/src/log.min.js +1 -1
- package/lib/v-x-e-table/index.js +2 -1
- package/lib/v-x-e-table/index.min.js +1 -1
- package/lib/vxe-colgroup/index.js +2 -1
- package/lib/vxe-colgroup/index.min.js +1 -1
- package/lib/vxe-column/index.js +2 -1
- package/lib/vxe-column/index.min.js +1 -1
- package/lib/vxe-grid/index.js +2 -1
- package/lib/vxe-grid/index.min.js +1 -1
- package/lib/vxe-table/index.js +2 -1
- package/lib/vxe-table/index.min.js +1 -1
- package/lib/vxe-table/style/style.css +23 -50
- package/lib/vxe-table/style/style.min.css +1 -1
- package/lib/vxe-toolbar/index.js +2 -1
- package/lib/vxe-toolbar/index.min.js +1 -1
- package/lib/vxe-ui/index.js +2 -1
- package/lib/vxe-ui/index.min.js +1 -1
- package/lib/vxe-v-x-e-table/index.js +2 -1
- package/lib/vxe-v-x-e-table/index.min.js +1 -1
- package/package.json +1 -1
- package/packages/table/module/custom/mixin.ts +7 -4
- package/packages/table/module/custom/panel.ts +846 -839
- package/packages/table/module/edit/mixin.ts +55 -35
- package/packages/table/module/export/export-panel.ts +545 -469
- package/packages/table/module/export/import-panel.ts +245 -202
- package/packages/table/module/filter/panel.ts +4 -18
- package/packages/table/module/keyboard/mixin.ts +2 -2
- package/packages/table/module/menu/panel.ts +171 -163
- package/packages/table/module/validator/mixin.ts +279 -240
- package/packages/table/src/body.ts +2 -1
- package/packages/table/src/cell.ts +2 -2
- package/packages/table/src/methods.ts +43 -45
- package/packages/table/src/table.ts +14 -260
- package/packages/table/src/util.ts +254 -0
- package/packages/ui/index.ts +1 -1
- package/packages/ui/src/dom.ts +22 -0
- package/styles/components/table.scss +5 -2
- package/styles/theme/base.scss +2 -1
- /package/es/{iconfont.1767145426781.ttf → iconfont.1767492234857.ttf} +0 -0
- /package/es/{iconfont.1767145426781.woff → iconfont.1767492234857.woff} +0 -0
- /package/es/{iconfont.1767145426781.woff2 → iconfont.1767492234857.woff2} +0 -0
- /package/lib/{iconfont.1767145426781.ttf → iconfont.1767492234857.ttf} +0 -0
- /package/lib/{iconfont.1767145426781.woff → iconfont.1767492234857.woff} +0 -0
- /package/lib/{iconfont.1767145426781.woff2 → iconfont.1767492234857.woff2} +0 -0
package/es/table/src/methods.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import XEUtils from 'xe-utils';
|
|
2
|
-
import { getTpImg, isPx, isScale, hasClass, addClass, removeClass, getEventTargetNode, getPaddingTopBottomSize, setScrollTop, setScrollLeft, toCssUnit, hasControlKey, checkTargetElement } from '../../ui/src/dom';
|
|
2
|
+
import { getTpImg, isPx, isScale, hasClass, addClass, removeClass, scrollTopTo, getEventTargetNode, getPaddingTopBottomSize, setScrollTop, setScrollLeft, toCssUnit, hasControlKey, checkTargetElement } from '../../ui/src/dom';
|
|
3
3
|
import { getLastZIndex, nextZIndex, hasChildrenList, getFuncText, isEnableConf, formatText, eqEmptyValue } from '../../ui/src/utils';
|
|
4
4
|
import { VxeUI } from '../../ui';
|
|
5
5
|
import Cell from './cell';
|
|
@@ -3900,28 +3900,6 @@ const wheelScrollLeftTo = (scrollLeft, cb) => {
|
|
|
3900
3900
|
cb(scrollLeft);
|
|
3901
3901
|
});
|
|
3902
3902
|
};
|
|
3903
|
-
const wheelScrollTopTo = (diffNum, cb) => {
|
|
3904
|
-
const duration = Math.abs(diffNum);
|
|
3905
|
-
const startTime = performance.now();
|
|
3906
|
-
let countTop = 0;
|
|
3907
|
-
const step = (timestamp) => {
|
|
3908
|
-
let progress = (timestamp - startTime) / duration;
|
|
3909
|
-
if (progress < 0) {
|
|
3910
|
-
progress = 0;
|
|
3911
|
-
}
|
|
3912
|
-
else if (progress > 1) {
|
|
3913
|
-
progress = 1;
|
|
3914
|
-
}
|
|
3915
|
-
const easedProgress = Math.pow(progress, 2);
|
|
3916
|
-
const offsetTop = Math.floor((diffNum * easedProgress)) - countTop;
|
|
3917
|
-
countTop += offsetTop;
|
|
3918
|
-
cb(offsetTop);
|
|
3919
|
-
if (progress < 1) {
|
|
3920
|
-
requestAnimationFrame(step);
|
|
3921
|
-
}
|
|
3922
|
-
};
|
|
3923
|
-
requestAnimationFrame(step);
|
|
3924
|
-
};
|
|
3925
3903
|
const syncGanttScrollTop = ($xeTable, scrollTop) => {
|
|
3926
3904
|
const internalData = $xeTable;
|
|
3927
3905
|
const $xeGanttView = internalData.xeGanttView;
|
|
@@ -7184,8 +7162,8 @@ const tableMethods = {
|
|
|
7184
7162
|
const { actived } = editStore;
|
|
7185
7163
|
if (isActivated && !filterStore.visible) {
|
|
7186
7164
|
if (!(actived.row || actived.column)) {
|
|
7187
|
-
if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area &&
|
|
7188
|
-
|
|
7165
|
+
if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area && $xeTable.handlePeClAreaEvent) {
|
|
7166
|
+
$xeTable.handlePeClAreaEvent(evnt);
|
|
7189
7167
|
}
|
|
7190
7168
|
}
|
|
7191
7169
|
$xeTable.dispatchEvent('paste', {}, evnt);
|
|
@@ -7197,8 +7175,8 @@ const tableMethods = {
|
|
|
7197
7175
|
const { actived } = editStore;
|
|
7198
7176
|
if (isActivated && !filterStore.visible) {
|
|
7199
7177
|
if (!(actived.row || actived.column)) {
|
|
7200
|
-
if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area &&
|
|
7201
|
-
|
|
7178
|
+
if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area && $xeTable.handleCyClAreaEvent) {
|
|
7179
|
+
$xeTable.handleCyClAreaEvent(evnt);
|
|
7202
7180
|
}
|
|
7203
7181
|
}
|
|
7204
7182
|
$xeTable.dispatchEvent('copy', {}, evnt);
|
|
@@ -7210,8 +7188,8 @@ const tableMethods = {
|
|
|
7210
7188
|
const { actived } = editStore;
|
|
7211
7189
|
if (isActivated && !filterStore.visible) {
|
|
7212
7190
|
if (!(actived.row || actived.column)) {
|
|
7213
|
-
if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area &&
|
|
7214
|
-
|
|
7191
|
+
if (keyboardConfig && keyboardOpts.isClip && mouseConfig && mouseOpts.area && $xeTable.handleCutCellAreaEvent) {
|
|
7192
|
+
$xeTable.handleCutCellAreaEvent(evnt);
|
|
7215
7193
|
}
|
|
7216
7194
|
}
|
|
7217
7195
|
$xeTable.dispatchEvent('cut', {}, evnt);
|
|
@@ -7392,12 +7370,12 @@ const tableMethods = {
|
|
|
7392
7370
|
}
|
|
7393
7371
|
},
|
|
7394
7372
|
openTooltip(target, content) {
|
|
7395
|
-
const
|
|
7396
|
-
const commTip = $refs.refCommTooltip;
|
|
7373
|
+
const $xeTable = this;
|
|
7374
|
+
const commTip = $xeTable.$refs.refCommTooltip;
|
|
7397
7375
|
if (commTip) {
|
|
7398
7376
|
return commTip.open(target, content);
|
|
7399
7377
|
}
|
|
7400
|
-
return
|
|
7378
|
+
return $xeTable.$nextTick();
|
|
7401
7379
|
},
|
|
7402
7380
|
/**
|
|
7403
7381
|
* 关闭 tooltip
|
|
@@ -7424,23 +7402,28 @@ const tableMethods = {
|
|
|
7424
7402
|
if (commTip) {
|
|
7425
7403
|
commTip.close();
|
|
7426
7404
|
}
|
|
7427
|
-
return
|
|
7405
|
+
return $xeTable.$nextTick();
|
|
7428
7406
|
},
|
|
7429
7407
|
/**
|
|
7430
7408
|
* 判断列头复选框是否被选中
|
|
7431
7409
|
*/
|
|
7432
7410
|
isAllCheckboxChecked() {
|
|
7433
|
-
|
|
7411
|
+
const $xeTable = this;
|
|
7412
|
+
const reactData = $xeTable;
|
|
7413
|
+
return reactData.isAllSelected;
|
|
7434
7414
|
},
|
|
7435
7415
|
/**
|
|
7436
7416
|
* 判断列头复选框是否被半选
|
|
7437
7417
|
*/
|
|
7438
7418
|
isAllCheckboxIndeterminate() {
|
|
7439
|
-
|
|
7419
|
+
const $xeTable = this;
|
|
7420
|
+
const reactData = $xeTable;
|
|
7421
|
+
return !reactData.isAllSelected && reactData.isIndeterminate;
|
|
7440
7422
|
},
|
|
7441
7423
|
isCheckboxIndeterminate() {
|
|
7424
|
+
const $xeTable = this;
|
|
7442
7425
|
warnLog('vxe.error.delFunc', ['isCheckboxIndeterminate', 'isAllCheckboxIndeterminate']);
|
|
7443
|
-
return
|
|
7426
|
+
return $xeTable.isAllCheckboxIndeterminate();
|
|
7444
7427
|
},
|
|
7445
7428
|
/**
|
|
7446
7429
|
* 获取复选框半选状态的行数据
|
|
@@ -8007,8 +7990,10 @@ const tableMethods = {
|
|
|
8007
7990
|
return null;
|
|
8008
7991
|
},
|
|
8009
7992
|
clearRadioReserve() {
|
|
8010
|
-
|
|
8011
|
-
|
|
7993
|
+
const $xeTable = this;
|
|
7994
|
+
const internalData = $xeTable;
|
|
7995
|
+
internalData.radioReserveRow = null;
|
|
7996
|
+
return $xeTable.$nextTick();
|
|
8012
7997
|
},
|
|
8013
7998
|
/**
|
|
8014
7999
|
* 获取复选框保留选中的行
|
|
@@ -8054,13 +8039,18 @@ const tableMethods = {
|
|
|
8054
8039
|
return reserveSelection;
|
|
8055
8040
|
},
|
|
8056
8041
|
clearCheckboxReserve() {
|
|
8057
|
-
|
|
8058
|
-
|
|
8042
|
+
const $xeTable = this;
|
|
8043
|
+
const internalData = $xeTable;
|
|
8044
|
+
internalData.checkboxReserveRowMap = {};
|
|
8045
|
+
return $xeTable.$nextTick();
|
|
8059
8046
|
},
|
|
8060
8047
|
handleCheckboxReserveRow(row, checked) {
|
|
8061
|
-
const
|
|
8048
|
+
const $xeTable = this;
|
|
8049
|
+
const internalData = $xeTable;
|
|
8050
|
+
const { checkboxReserveRowMap } = internalData;
|
|
8051
|
+
const checkboxOpts = $xeTable.computeCheckboxOpts;
|
|
8062
8052
|
if (checkboxOpts.reserve) {
|
|
8063
|
-
const rowid = getRowid(
|
|
8053
|
+
const rowid = getRowid($xeTable, row);
|
|
8064
8054
|
if (checked) {
|
|
8065
8055
|
checkboxReserveRowMap[rowid] = row;
|
|
8066
8056
|
}
|
|
@@ -11351,7 +11341,7 @@ const tableMethods = {
|
|
|
11351
11341
|
});
|
|
11352
11342
|
}
|
|
11353
11343
|
else {
|
|
11354
|
-
|
|
11344
|
+
scrollTopTo(scrollTop - currScrollTop, (offsetTop) => {
|
|
11355
11345
|
const currTopNum = bodyScrollElem.scrollTop + offsetTop;
|
|
11356
11346
|
internalData.inWheelScroll = true;
|
|
11357
11347
|
setScrollTop(yHandleEl, currTopNum);
|
package/es/table/src/table.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import XEUtils from 'xe-utils';
|
|
2
2
|
import { getFuncText, isEnableConf } from '../../ui/src/utils';
|
|
3
3
|
import { initTpImg } from '../../ui/src/dom';
|
|
4
|
-
import { createInternalData, createHandleGetRowId, getCalcHeight, hasDeepKey } from './util';
|
|
4
|
+
import { createReactData, createInternalData, createHandleGetRowId, getCalcHeight, hasDeepKey } from './util';
|
|
5
5
|
import { VxeUI } from '../../ui';
|
|
6
6
|
import methods from './methods';
|
|
7
7
|
import TableBodyComponent from './body';
|
|
@@ -510,246 +510,7 @@ export default {
|
|
|
510
510
|
},
|
|
511
511
|
data() {
|
|
512
512
|
const xID = XEUtils.uniqueId();
|
|
513
|
-
const reactData =
|
|
514
|
-
// 低性能的静态列
|
|
515
|
-
staticColumns: [],
|
|
516
|
-
// 渲染的列分组
|
|
517
|
-
tableGroupColumn: [],
|
|
518
|
-
// 可视区渲染的列
|
|
519
|
-
tableColumn: [],
|
|
520
|
-
// 渲染中的数据
|
|
521
|
-
tableData: [],
|
|
522
|
-
// 是否启用了横向 X 可视渲染方式加载
|
|
523
|
-
scrollXLoad: false,
|
|
524
|
-
// 是否启用了纵向 Y 可视渲染方式加载
|
|
525
|
-
scrollYLoad: false,
|
|
526
|
-
// 是否存在纵向滚动条
|
|
527
|
-
overflowY: true,
|
|
528
|
-
// 是否存在横向滚动条
|
|
529
|
-
overflowX: false,
|
|
530
|
-
// 纵向滚动条的宽度
|
|
531
|
-
scrollbarWidth: 0,
|
|
532
|
-
// 横向滚动条的高度
|
|
533
|
-
scrollbarHeight: 0,
|
|
534
|
-
// 最后滚动时间戳
|
|
535
|
-
lastScrollTime: 0,
|
|
536
|
-
// 行高
|
|
537
|
-
rowHeight: 0,
|
|
538
|
-
// 表格父容器的高度
|
|
539
|
-
parentHeight: 0,
|
|
540
|
-
// 是否使用分组表头
|
|
541
|
-
isGroup: false,
|
|
542
|
-
isAllOverflow: false,
|
|
543
|
-
// 复选框属性,是否全选
|
|
544
|
-
isAllSelected: false,
|
|
545
|
-
// 复选框属性,有选中且非全选状态
|
|
546
|
-
isIndeterminate: false,
|
|
547
|
-
// 当前行
|
|
548
|
-
currentRow: null,
|
|
549
|
-
// 单选框属性,选中列
|
|
550
|
-
currentColumn: null,
|
|
551
|
-
// 单选框属性,选中行
|
|
552
|
-
selectRadioRow: null,
|
|
553
|
-
// 表尾合计数据
|
|
554
|
-
footerTableData: [],
|
|
555
|
-
// 行分组列信息
|
|
556
|
-
rowGroupColumn: null,
|
|
557
|
-
// 展开列信息
|
|
558
|
-
expandColumn: null,
|
|
559
|
-
checkboxColumn: null,
|
|
560
|
-
radioColumn: null,
|
|
561
|
-
// 树节点列信息
|
|
562
|
-
treeNodeColumn: null,
|
|
563
|
-
hasFixedColumn: false,
|
|
564
|
-
// 刷新列标识,当列筛选被改变时,触发表格刷新数据
|
|
565
|
-
upDataFlag: 0,
|
|
566
|
-
// 刷新列标识,当列的特定属性被改变时,触发表格刷新列
|
|
567
|
-
reColumnFlag: 0,
|
|
568
|
-
// 初始化标识
|
|
569
|
-
initStore: {
|
|
570
|
-
filter: false,
|
|
571
|
-
import: false,
|
|
572
|
-
export: false,
|
|
573
|
-
custom: false
|
|
574
|
-
},
|
|
575
|
-
// 自定义列相关的信息
|
|
576
|
-
customStore: {
|
|
577
|
-
btnEl: null,
|
|
578
|
-
isAll: false,
|
|
579
|
-
isIndeterminate: false,
|
|
580
|
-
activeBtn: false,
|
|
581
|
-
activeWrapper: false,
|
|
582
|
-
visible: false,
|
|
583
|
-
maxHeight: 0,
|
|
584
|
-
oldSortMaps: {},
|
|
585
|
-
oldFixedMaps: {},
|
|
586
|
-
oldVisibleMaps: {}
|
|
587
|
-
},
|
|
588
|
-
customColumnList: [],
|
|
589
|
-
// 当前选中的筛选列
|
|
590
|
-
filterStore: {
|
|
591
|
-
isAllSelected: false,
|
|
592
|
-
isIndeterminate: false,
|
|
593
|
-
style: null,
|
|
594
|
-
column: null,
|
|
595
|
-
visible: false,
|
|
596
|
-
maxHeight: null
|
|
597
|
-
},
|
|
598
|
-
// 存放列相关的信息
|
|
599
|
-
columnStore: {
|
|
600
|
-
leftList: [],
|
|
601
|
-
centerList: [],
|
|
602
|
-
rightList: [],
|
|
603
|
-
resizeList: [],
|
|
604
|
-
pxList: [],
|
|
605
|
-
pxMinList: [],
|
|
606
|
-
autoMinList: [],
|
|
607
|
-
scaleList: [],
|
|
608
|
-
scaleMinList: [],
|
|
609
|
-
autoList: [],
|
|
610
|
-
remainList: []
|
|
611
|
-
},
|
|
612
|
-
// 存放快捷菜单的信息
|
|
613
|
-
ctxMenuStore: {
|
|
614
|
-
selected: null,
|
|
615
|
-
visible: false,
|
|
616
|
-
showChild: false,
|
|
617
|
-
selectChild: null,
|
|
618
|
-
list: [],
|
|
619
|
-
style: null
|
|
620
|
-
},
|
|
621
|
-
// 存放可编辑相关信息
|
|
622
|
-
editStore: {
|
|
623
|
-
indexs: {
|
|
624
|
-
columns: []
|
|
625
|
-
},
|
|
626
|
-
titles: {
|
|
627
|
-
columns: []
|
|
628
|
-
},
|
|
629
|
-
// 选中源
|
|
630
|
-
selected: {
|
|
631
|
-
row: null,
|
|
632
|
-
column: null
|
|
633
|
-
},
|
|
634
|
-
// 已复制源
|
|
635
|
-
copyed: {
|
|
636
|
-
cut: false,
|
|
637
|
-
rows: [],
|
|
638
|
-
columns: []
|
|
639
|
-
},
|
|
640
|
-
// 激活
|
|
641
|
-
actived: {
|
|
642
|
-
row: null,
|
|
643
|
-
column: null
|
|
644
|
-
},
|
|
645
|
-
// 当前被强制聚焦单元格,只会在鼠标点击后算聚焦
|
|
646
|
-
focused: {
|
|
647
|
-
row: null,
|
|
648
|
-
column: null
|
|
649
|
-
}
|
|
650
|
-
},
|
|
651
|
-
// 存放 tooltip 相关信息
|
|
652
|
-
tooltipStore: {
|
|
653
|
-
row: null,
|
|
654
|
-
column: null,
|
|
655
|
-
content: null,
|
|
656
|
-
visible: false,
|
|
657
|
-
type: null,
|
|
658
|
-
currOpts: {}
|
|
659
|
-
},
|
|
660
|
-
// 存放数据校验相关信息
|
|
661
|
-
validStore: {
|
|
662
|
-
visible: false
|
|
663
|
-
},
|
|
664
|
-
validErrorMaps: {},
|
|
665
|
-
// 导入相关信息
|
|
666
|
-
importStore: {
|
|
667
|
-
inited: false,
|
|
668
|
-
file: null,
|
|
669
|
-
type: '',
|
|
670
|
-
modeList: [],
|
|
671
|
-
typeList: [],
|
|
672
|
-
filename: '',
|
|
673
|
-
visible: false
|
|
674
|
-
},
|
|
675
|
-
importParams: {
|
|
676
|
-
mode: '',
|
|
677
|
-
types: null,
|
|
678
|
-
message: true
|
|
679
|
-
},
|
|
680
|
-
// 导出相关信息
|
|
681
|
-
exportStore: {
|
|
682
|
-
inited: false,
|
|
683
|
-
name: '',
|
|
684
|
-
modeList: [],
|
|
685
|
-
typeList: [],
|
|
686
|
-
columns: [],
|
|
687
|
-
isPrint: false,
|
|
688
|
-
hasFooter: false,
|
|
689
|
-
hasMerge: false,
|
|
690
|
-
hasTree: false,
|
|
691
|
-
hasColgroup: false,
|
|
692
|
-
visible: false
|
|
693
|
-
},
|
|
694
|
-
exportParams: {
|
|
695
|
-
filename: '',
|
|
696
|
-
sheetName: '',
|
|
697
|
-
mode: '',
|
|
698
|
-
type: '',
|
|
699
|
-
isColgroup: false,
|
|
700
|
-
isMerge: false,
|
|
701
|
-
isAllExpand: false,
|
|
702
|
-
useStyle: false,
|
|
703
|
-
original: false,
|
|
704
|
-
message: true,
|
|
705
|
-
isHeader: false,
|
|
706
|
-
isTitle: false,
|
|
707
|
-
isFooter: false
|
|
708
|
-
},
|
|
709
|
-
visiblwRowsFlag: 1,
|
|
710
|
-
isRowGroupStatus: false,
|
|
711
|
-
rowGroupList: [],
|
|
712
|
-
aggHandleFields: [],
|
|
713
|
-
aggHandleAggColumns: [],
|
|
714
|
-
rowGroupExpandedFlag: 1,
|
|
715
|
-
rowExpandedFlag: 1,
|
|
716
|
-
treeExpandedFlag: 1,
|
|
717
|
-
updateCheckboxFlag: 1,
|
|
718
|
-
pendingRowFlag: 1,
|
|
719
|
-
insertRowFlag: 1,
|
|
720
|
-
removeRowFlag: 1,
|
|
721
|
-
mergeHeadFlag: 1,
|
|
722
|
-
mergeBodyFlag: 1,
|
|
723
|
-
mergeFootFlag: 1,
|
|
724
|
-
rowHeightStore: {
|
|
725
|
-
large: 52,
|
|
726
|
-
default: 48,
|
|
727
|
-
medium: 44,
|
|
728
|
-
small: 40,
|
|
729
|
-
mini: 36
|
|
730
|
-
},
|
|
731
|
-
scrollVMLoading: false,
|
|
732
|
-
scrollYHeight: 0,
|
|
733
|
-
scrollYTop: 0,
|
|
734
|
-
isScrollYBig: false,
|
|
735
|
-
scrollXLeft: 0,
|
|
736
|
-
scrollXWidth: 0,
|
|
737
|
-
isScrollXBig: false,
|
|
738
|
-
lazScrollLoading: false,
|
|
739
|
-
rowExpandHeightFlag: 1,
|
|
740
|
-
calcCellHeightFlag: 1,
|
|
741
|
-
resizeHeightFlag: 1,
|
|
742
|
-
resizeWidthFlag: 1,
|
|
743
|
-
isCustomStatus: false,
|
|
744
|
-
isCrossDragRow: false,
|
|
745
|
-
dragRow: null,
|
|
746
|
-
isCrossDragCol: false,
|
|
747
|
-
dragCol: null,
|
|
748
|
-
dragTipText: '',
|
|
749
|
-
isDragResize: false,
|
|
750
|
-
isRowLoading: false,
|
|
751
|
-
isColLoading: false
|
|
752
|
-
};
|
|
513
|
+
const reactData = createReactData();
|
|
753
514
|
return Object.assign(Object.assign({ xID }, reactData), {
|
|
754
515
|
// 私有属性
|
|
755
516
|
reScrollFlag: 0, reLayoutFlag: 0, footFlag: 0, mergeFooteCellFlag: 0, crossTableDragRowInfo: crossTableDragRowGlobal });
|
|
@@ -783,7 +544,12 @@ export default {
|
|
|
783
544
|
computeValidOpts() {
|
|
784
545
|
const $xeTable = this;
|
|
785
546
|
const props = $xeTable;
|
|
786
|
-
|
|
547
|
+
const opts = Object.assign({}, getConfig().table.validConfig, props.validConfig);
|
|
548
|
+
// 兼容老版本
|
|
549
|
+
if (XEUtils.isBoolean(opts.showMessage)) {
|
|
550
|
+
opts.showErrorMessage = opts.showMessage;
|
|
551
|
+
}
|
|
552
|
+
return opts;
|
|
787
553
|
},
|
|
788
554
|
sXOpts() {
|
|
789
555
|
return this.computeVirtualXOpts;
|
|
@@ -1721,7 +1487,7 @@ export default {
|
|
|
1721
1487
|
if (rowOpts.height && !this.showOverflow) {
|
|
1722
1488
|
warnLog('vxe.error.notProp', ['table.show-overflow']);
|
|
1723
1489
|
}
|
|
1724
|
-
if (!$xeTable.
|
|
1490
|
+
if (!$xeTable.triggerClAreaModnEvent) {
|
|
1725
1491
|
if (props.areaConfig) {
|
|
1726
1492
|
warnLog('vxe.error.notProp', ['area-config']);
|
|
1727
1493
|
}
|
|
@@ -2003,6 +1769,7 @@ export default {
|
|
|
2003
1769
|
},
|
|
2004
1770
|
beforeDestroy() {
|
|
2005
1771
|
const $xeTable = this;
|
|
1772
|
+
const reactData = $xeTable;
|
|
2006
1773
|
const teleportWrapperEl = $xeTable.$refs.refTeleportWrapper;
|
|
2007
1774
|
if (teleportWrapperEl && teleportWrapperEl.parentElement) {
|
|
2008
1775
|
teleportWrapperEl.parentElement.removeChild(teleportWrapperEl);
|
|
@@ -2031,6 +1798,7 @@ export default {
|
|
|
2031
1798
|
globalEvents.off($xeTable, 'resize');
|
|
2032
1799
|
globalEvents.off($xeTable, 'contextmenu');
|
|
2033
1800
|
this.preventEvent(null, 'beforeDestroy');
|
|
1801
|
+
XEUtils.assign(reactData, createReactData());
|
|
2034
1802
|
},
|
|
2035
1803
|
destroyed() {
|
|
2036
1804
|
const $xeTable = this;
|
|
@@ -2293,11 +2061,7 @@ export default {
|
|
|
2293
2061
|
isContentMenu
|
|
2294
2062
|
? h(TableMenuPanelComponent, {
|
|
2295
2063
|
key: 'tm',
|
|
2296
|
-
ref: 'refTableMenu'
|
|
2297
|
-
props: {
|
|
2298
|
-
ctxMenuStore: this.ctxMenuStore,
|
|
2299
|
-
ctxMenuOpts: this.ctxMenuOpts
|
|
2300
|
-
}
|
|
2064
|
+
ref: 'refTableMenu'
|
|
2301
2065
|
})
|
|
2302
2066
|
: renderEmptyElement($xeTable)
|
|
2303
2067
|
])
|
|
@@ -2390,7 +2154,7 @@ export default {
|
|
|
2390
2154
|
/**
|
|
2391
2155
|
* 校验提示
|
|
2392
2156
|
*/
|
|
2393
|
-
VxeUITooltipComponent && this.editRules && validOpts.
|
|
2157
|
+
VxeUITooltipComponent && this.editRules && validOpts.showErrorMessage && (validOpts.message === 'default' ? !height : validOpts.message === 'tooltip')
|
|
2394
2158
|
? h(VxeUITooltipComponent, {
|
|
2395
2159
|
key: 'vtp',
|
|
2396
2160
|
ref: 'refValidTooltip',
|