vxe-table 4.12.2 → 4.12.4

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 (118) hide show
  1. package/es/locale/lang/ar-EG.js +1 -0
  2. package/es/locale/lang/de-DE.js +1 -0
  3. package/es/locale/lang/en-US.js +1 -0
  4. package/es/locale/lang/es-ES.js +1 -0
  5. package/es/locale/lang/fr-FR.js +1 -0
  6. package/es/locale/lang/hu-HU.js +1 -0
  7. package/es/locale/lang/hy-AM.js +1 -0
  8. package/es/locale/lang/id-ID.js +1 -0
  9. package/es/locale/lang/it-IT.js +1 -0
  10. package/es/locale/lang/ja-JP.js +1 -0
  11. package/es/locale/lang/ko-KR.js +1 -0
  12. package/es/locale/lang/nb-NO.js +1 -0
  13. package/es/locale/lang/pt-BR.js +1 -0
  14. package/es/locale/lang/ru-RU.js +1 -0
  15. package/es/locale/lang/th-TH.js +1 -0
  16. package/es/locale/lang/ug-CN.js +1 -0
  17. package/es/locale/lang/uk-UA.js +1 -0
  18. package/es/locale/lang/vi-VN.js +1 -0
  19. package/es/locale/lang/zh-CHT.js +1 -0
  20. package/es/locale/lang/zh-CN.js +1 -0
  21. package/es/style.css +1 -1
  22. package/es/table/module/keyboard/hook.js +26 -9
  23. package/es/table/module/menu/hook.js +1 -1
  24. package/es/table/src/table.js +67 -23
  25. package/es/ui/index.js +1 -1
  26. package/es/ui/src/log.js +1 -1
  27. package/lib/index.umd.js +881 -12071
  28. package/lib/index.umd.min.js +1 -1
  29. package/lib/locale/lang/ar-EG.js +1 -0
  30. package/lib/locale/lang/ar-EG.min.js +1 -1
  31. package/lib/locale/lang/de-DE.js +1 -0
  32. package/lib/locale/lang/de-DE.min.js +1 -1
  33. package/lib/locale/lang/en-US.js +1 -0
  34. package/lib/locale/lang/en-US.min.js +1 -1
  35. package/lib/locale/lang/en-US.umd.js +1 -0
  36. package/lib/locale/lang/es-ES.js +1 -0
  37. package/lib/locale/lang/es-ES.min.js +1 -1
  38. package/lib/locale/lang/es-ES.umd.js +1 -0
  39. package/lib/locale/lang/fr-FR.js +1 -0
  40. package/lib/locale/lang/fr-FR.min.js +1 -1
  41. package/lib/locale/lang/hu-HU.js +1 -0
  42. package/lib/locale/lang/hu-HU.min.js +1 -1
  43. package/lib/locale/lang/hu-HU.umd.js +1 -0
  44. package/lib/locale/lang/hy-AM.js +1 -0
  45. package/lib/locale/lang/hy-AM.min.js +1 -1
  46. package/lib/locale/lang/id-ID.js +1 -0
  47. package/lib/locale/lang/id-ID.min.js +1 -1
  48. package/lib/locale/lang/it-IT.js +1 -0
  49. package/lib/locale/lang/it-IT.min.js +1 -1
  50. package/lib/locale/lang/ja-JP.js +1 -0
  51. package/lib/locale/lang/ja-JP.min.js +1 -1
  52. package/lib/locale/lang/ja-JP.umd.js +1 -0
  53. package/lib/locale/lang/ko-KR.js +1 -0
  54. package/lib/locale/lang/ko-KR.min.js +1 -1
  55. package/lib/locale/lang/ko-KR.umd.js +1 -0
  56. package/lib/locale/lang/nb-NO.js +1 -0
  57. package/lib/locale/lang/nb-NO.min.js +1 -1
  58. package/lib/locale/lang/pt-BR.js +1 -0
  59. package/lib/locale/lang/pt-BR.min.js +1 -1
  60. package/lib/locale/lang/pt-BR.umd.js +1 -0
  61. package/lib/locale/lang/ru-RU.js +1 -0
  62. package/lib/locale/lang/ru-RU.min.js +1 -1
  63. package/lib/locale/lang/ru-RU.umd.js +1 -0
  64. package/lib/locale/lang/th-TH.js +1 -0
  65. package/lib/locale/lang/th-TH.min.js +1 -1
  66. package/lib/locale/lang/ug-CN.js +1 -0
  67. package/lib/locale/lang/ug-CN.min.js +1 -1
  68. package/lib/locale/lang/uk-UA.js +1 -0
  69. package/lib/locale/lang/uk-UA.min.js +1 -1
  70. package/lib/locale/lang/uk-UA.umd.js +1 -0
  71. package/lib/locale/lang/vi-VN.js +1 -0
  72. package/lib/locale/lang/vi-VN.min.js +1 -1
  73. package/lib/locale/lang/zh-CHT.js +1 -0
  74. package/lib/locale/lang/zh-CHT.min.js +1 -1
  75. package/lib/locale/lang/zh-CN.js +1 -0
  76. package/lib/locale/lang/zh-CN.min.js +1 -1
  77. package/lib/locale/lang/zh-CN.umd.js +1 -0
  78. package/lib/style.css +1 -1
  79. package/lib/table/module/keyboard/hook.js +27 -9
  80. package/lib/table/module/keyboard/hook.min.js +1 -1
  81. package/lib/table/module/menu/hook.js +1 -1
  82. package/lib/table/module/menu/hook.min.js +1 -1
  83. package/lib/table/src/table.js +65 -19
  84. package/lib/table/src/table.min.js +1 -1
  85. package/lib/ui/index.js +1 -1
  86. package/lib/ui/index.min.js +1 -1
  87. package/lib/ui/src/log.js +1 -1
  88. package/lib/ui/src/log.min.js +1 -1
  89. package/package.json +2 -2
  90. package/packages/locale/lang/ar-EG.ts +1 -0
  91. package/packages/locale/lang/de-DE.ts +1 -0
  92. package/packages/locale/lang/en-US.ts +1 -0
  93. package/packages/locale/lang/es-ES.ts +1 -0
  94. package/packages/locale/lang/fr-FR.ts +1 -0
  95. package/packages/locale/lang/hu-HU.ts +1 -0
  96. package/packages/locale/lang/hy-AM.ts +1 -0
  97. package/packages/locale/lang/id-ID.ts +1 -0
  98. package/packages/locale/lang/it-IT.ts +1 -0
  99. package/packages/locale/lang/ja-JP.ts +1 -0
  100. package/packages/locale/lang/ko-KR.ts +1 -0
  101. package/packages/locale/lang/nb-NO.ts +1 -0
  102. package/packages/locale/lang/pt-BR.ts +1 -0
  103. package/packages/locale/lang/ru-RU.ts +1 -0
  104. package/packages/locale/lang/th-TH.ts +1 -0
  105. package/packages/locale/lang/ug-CN.ts +1 -0
  106. package/packages/locale/lang/uk-UA.ts +1 -0
  107. package/packages/locale/lang/vi-VN.ts +1 -0
  108. package/packages/locale/lang/zh-CHT.ts +1 -0
  109. package/packages/locale/lang/zh-CN.ts +1 -0
  110. package/packages/table/module/keyboard/hook.ts +24 -9
  111. package/packages/table/module/menu/hook.ts +1 -1
  112. package/packages/table/src/table.ts +70 -23
  113. /package/es/{iconfont.1743125693758.ttf → iconfont.1743394011765.ttf} +0 -0
  114. /package/es/{iconfont.1743125693758.woff → iconfont.1743394011765.woff} +0 -0
  115. /package/es/{iconfont.1743125693758.woff2 → iconfont.1743394011765.woff2} +0 -0
  116. /package/lib/{iconfont.1743125693758.ttf → iconfont.1743394011765.ttf} +0 -0
  117. /package/lib/{iconfont.1743125693758.woff → iconfont.1743394011765.woff} +0 -0
  118. /package/lib/{iconfont.1743125693758.woff2 → iconfont.1743394011765.woff2} +0 -0
@@ -138,7 +138,7 @@ hooks.add('tableMenuModule', {
138
138
  ctxMenuStore[property] = selectItem || menuList[0];
139
139
  }
140
140
  else if (ctxMenuStore[property] && (globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.ENTER) || globalEvents.hasKey(evnt, GLOBAL_EVENT_KEYS.SPACEBAR))) {
141
- menuPrivateMethods.ctxMenuLinkEvent(evnt, ctxMenuStore[property]);
141
+ $xeTable.ctxMenuLinkEvent(evnt, ctxMenuStore[property]);
142
142
  }
143
143
  },
144
144
  handleOpenMenuEvent,
@@ -792,6 +792,7 @@ export default defineComponent({
792
792
  computeBodyMenu,
793
793
  computeFooterMenu,
794
794
  computeIsMenu,
795
+ computeMenuList,
795
796
  computeMenuOpts,
796
797
  computeExportOpts,
797
798
  computeImportOpts,
@@ -1834,11 +1835,11 @@ export default defineComponent({
1834
1835
  }
1835
1836
  if (xLeftCornerEl) {
1836
1837
  xLeftCornerEl.style.width = scrollbarXToTop ? `${osbWidth}px` : '';
1837
- xLeftCornerEl.style.display = scrollbarXToTop ? (osbWidth && osbHeight ? 'block' : '') : '';
1838
+ xLeftCornerEl.style.display = scrollbarXToTop ? (overflowX && osbHeight ? 'block' : '') : '';
1838
1839
  }
1839
1840
  if (xRightCornerEl) {
1840
1841
  xRightCornerEl.style.width = scrollbarXToTop ? '' : `${osbWidth}px`;
1841
- xRightCornerEl.style.display = scrollbarXToTop ? '' : (osbWidth && osbHeight ? 'block' : '');
1842
+ xRightCornerEl.style.display = scrollbarXToTop ? '' : (overflowX && osbHeight ? 'block' : '');
1842
1843
  }
1843
1844
  const scrollYVirtualEl = refScrollYVirtualElem.value;
1844
1845
  if (scrollYVirtualEl) {
@@ -1849,7 +1850,7 @@ export default defineComponent({
1849
1850
  const yTopCornerEl = refScrollYTopCornerElem.value;
1850
1851
  if (yTopCornerEl) {
1851
1852
  yTopCornerEl.style.height = `${headerHeight}px`;
1852
- yTopCornerEl.style.display = headerHeight ? 'block' : '';
1853
+ yTopCornerEl.style.display = overflowY && headerHeight ? 'block' : '';
1853
1854
  }
1854
1855
  const yWrapperEl = refScrollYWrapperElem.value;
1855
1856
  if (yWrapperEl) {
@@ -1860,7 +1861,7 @@ export default defineComponent({
1860
1861
  if (yBottomCornerEl) {
1861
1862
  yBottomCornerEl.style.height = `${footerHeight}px`;
1862
1863
  yBottomCornerEl.style.top = `${headerHeight + bodyHeight}px`;
1863
- yBottomCornerEl.style.display = footerHeight ? 'block' : '';
1864
+ yBottomCornerEl.style.display = overflowY && footerHeight ? 'block' : '';
1864
1865
  }
1865
1866
  const rowExpandEl = refRowExpandElem.value;
1866
1867
  if (rowExpandEl) {
@@ -6095,8 +6096,8 @@ export default defineComponent({
6095
6096
  const handleGlobalKeydownEvent = (evnt) => {
6096
6097
  // 该行为只对当前激活的表格有效
6097
6098
  if (internalData.isActivated) {
6098
- tablePrivateMethods.preventEvent(evnt, 'event.keydown', null, () => {
6099
- const { mouseConfig, keyboardConfig, treeConfig, editConfig, highlightCurrentRow } = props;
6099
+ $xeTable.preventEvent(evnt, 'event.keydown', null, () => {
6100
+ const { mouseConfig, keyboardConfig, treeConfig, editConfig, highlightCurrentRow, highlightCurrentColumn } = props;
6100
6101
  const { ctxMenuStore, editStore, currentRow } = reactData;
6101
6102
  const { afterFullData } = internalData;
6102
6103
  const isMenu = computeIsMenu.value;
@@ -6107,6 +6108,7 @@ export default defineComponent({
6107
6108
  const treeOpts = computeTreeOpts.value;
6108
6109
  const menuList = computeMenuList.value;
6109
6110
  const rowOpts = computeRowOpts.value;
6111
+ const columnOpts = computeColumnOpts.value;
6110
6112
  const { selected, actived } = editStore;
6111
6113
  const childrenField = treeOpts.children || treeOpts.childrenField;
6112
6114
  const keyCode = evnt.keyCode;
@@ -6148,7 +6150,7 @@ export default defineComponent({
6148
6150
  if ($xeTable.closeMenu) {
6149
6151
  $xeTable.closeMenu();
6150
6152
  }
6151
- tableMethods.closeFilter();
6153
+ $xeTable.closeFilter();
6152
6154
  if (keyboardConfig && keyboardOpts.isEsc) {
6153
6155
  // 如果是激活编辑状态,则取消编辑
6154
6156
  if (actived.row) {
@@ -6264,12 +6266,12 @@ export default defineComponent({
6264
6266
  const params = {
6265
6267
  $table: $xeTable,
6266
6268
  row: targetRow,
6267
- rowIndex: tableMethods.getRowIndex(targetRow),
6268
- $rowIndex: tableMethods.getVMRowIndex(targetRow)
6269
+ rowIndex: $xeTable.getRowIndex(targetRow),
6270
+ $rowIndex: $xeTable.getVMRowIndex(targetRow)
6269
6271
  };
6270
- tableMethods.setTreeExpand(currentRow, true)
6271
- .then(() => tableMethods.scrollToRow(targetRow))
6272
- .then(() => tablePrivateMethods.triggerCurrentRowEvent(evnt, params));
6272
+ $xeTable.setTreeExpand(currentRow, true)
6273
+ .then(() => $xeTable.scrollToRow(targetRow))
6274
+ .then(() => $xeTable.triggerCurrentRowEvent(evnt, params));
6273
6275
  }
6274
6276
  }
6275
6277
  }
@@ -6277,9 +6279,19 @@ export default defineComponent({
6277
6279
  else if (operArrow && keyboardConfig && keyboardOpts.isArrow) {
6278
6280
  if (!isEditStatus) {
6279
6281
  // 如果按下了方向键
6280
- if (selected.row && selected.column) {
6282
+ if (mouseOpts.selected && selected.row && selected.column) {
6281
6283
  $xeTable.moveArrowSelected(selected.args, isLeftArrow, isUpArrow, isRightArrow, isDwArrow, evnt);
6282
6284
  }
6285
+ else {
6286
+ // 当前行按键上下移动
6287
+ if ((isUpArrow || isDwArrow) && (rowOpts.isCurrent || highlightCurrentRow)) {
6288
+ $xeTable.moveCurrentRow(isUpArrow, isDwArrow, evnt);
6289
+ }
6290
+ // 当前行按键左右移动
6291
+ if ((isLeftArrow || isRightArrow) && (columnOpts.isCurrent || highlightCurrentColumn)) {
6292
+ $xeTable.moveCurrentColumn(isLeftArrow, isRightArrow, evnt);
6293
+ }
6294
+ }
6283
6295
  }
6284
6296
  }
6285
6297
  else if (isTab && keyboardConfig && keyboardOpts.isTab) {
@@ -6324,9 +6336,9 @@ export default defineComponent({
6324
6336
  if (keyboardOpts.isDel && isEnableConf(editConfig) && (selected.row || selected.column)) {
6325
6337
  const params = {
6326
6338
  row: selected.row,
6327
- rowIndex: tableMethods.getRowIndex(selected.row),
6339
+ rowIndex: $xeTable.getRowIndex(selected.row),
6328
6340
  column: selected.column,
6329
- columnIndex: tableMethods.getColumnIndex(selected.column),
6341
+ columnIndex: $xeTable.getColumnIndex(selected.column),
6330
6342
  $table: $xeTable,
6331
6343
  $grid: $xeGrid
6332
6344
  };
@@ -6351,14 +6363,14 @@ export default defineComponent({
6351
6363
  evnt.preventDefault();
6352
6364
  const params = {
6353
6365
  row: parentRow,
6354
- rowIndex: tableMethods.getRowIndex(parentRow),
6355
- $rowIndex: tableMethods.getVMRowIndex(parentRow),
6366
+ rowIndex: $xeTable.getRowIndex(parentRow),
6367
+ $rowIndex: $xeTable.getVMRowIndex(parentRow),
6356
6368
  $table: $xeTable,
6357
6369
  $grid: $xeGrid
6358
6370
  };
6359
- tableMethods.setTreeExpand(parentRow, false)
6360
- .then(() => tableMethods.scrollToRow(parentRow))
6361
- .then(() => tablePrivateMethods.triggerCurrentRowEvent(evnt, params));
6371
+ $xeTable.setTreeExpand(parentRow, false)
6372
+ .then(() => $xeTable.scrollToRow(parentRow))
6373
+ .then(() => $xeTable.triggerCurrentRowEvent(evnt, params));
6362
6374
  }
6363
6375
  }
6364
6376
  else if (keyboardConfig && isEnableConf(editConfig) && keyboardOpts.isEdit && !hasCtrlKey && !hasMetaKey && (isSpacebar || (keyCode >= 48 && keyCode <= 57) || (keyCode >= 65 && keyCode <= 90) || (keyCode >= 96 && keyCode <= 111) || (keyCode >= 186 && keyCode <= 192) || (keyCode >= 219 && keyCode <= 222))) {
@@ -6372,9 +6384,9 @@ export default defineComponent({
6372
6384
  const beforeEditMethod = editOpts.beforeEditMethod || editOpts.activeMethod;
6373
6385
  const params = {
6374
6386
  row: selected.row,
6375
- rowIndex: tableMethods.getRowIndex(selected.row),
6387
+ rowIndex: $xeTable.getRowIndex(selected.row),
6376
6388
  column: selected.column,
6377
- columnIndex: tableMethods.getColumnIndex(selected.column),
6389
+ columnIndex: $xeTable.getColumnIndex(selected.column),
6378
6390
  $table: $xeTable,
6379
6391
  $grid: $xeGrid
6380
6392
  };
@@ -9224,6 +9236,7 @@ export default defineComponent({
9224
9236
  updateScrollXSpace() {
9225
9237
  const { isGroup, scrollXLoad, overflowX, scrollXWidth } = reactData;
9226
9238
  const { visibleColumn, scrollXStore, elemStore, fullColumnIdData } = internalData;
9239
+ const mouseOpts = computeMouseOpts.value;
9227
9240
  const tableBody = refTableBody.value;
9228
9241
  const tableBodyElem = tableBody ? tableBody.$el : null;
9229
9242
  if (tableBodyElem) {
@@ -9283,6 +9296,9 @@ export default defineComponent({
9283
9296
  if (scrollXSpaceEl) {
9284
9297
  scrollXSpaceEl.style.width = `${ySpaceWidth}px`;
9285
9298
  }
9299
+ if (isScrollXBig && mouseOpts.area) {
9300
+ errLog('vxe.error.notProp', ['mouse-config.area']);
9301
+ }
9286
9302
  nextTick(() => {
9287
9303
  updateStyle();
9288
9304
  });
@@ -9293,6 +9309,7 @@ export default defineComponent({
9293
9309
  const { isAllOverflow, scrollYLoad, expandColumn } = reactData;
9294
9310
  const { scrollYStore, elemStore, isResizeCellHeight, afterFullData, fullAllDataRowIdData, rowExpandedMaps } = internalData;
9295
9311
  const { startIndex } = scrollYStore;
9312
+ const mouseOpts = computeMouseOpts.value;
9296
9313
  const expandOpts = computeExpandOpts.value;
9297
9314
  const rowOpts = computeRowOpts.value;
9298
9315
  const cellOpts = computeCellOpts.value;
@@ -9376,6 +9393,9 @@ export default defineComponent({
9376
9393
  reactData.scrollYTop = scrollYTop;
9377
9394
  reactData.scrollYHeight = scrollYHeight;
9378
9395
  reactData.isScrollYBig = isScrollYBig;
9396
+ if (isScrollYBig && mouseOpts.area) {
9397
+ errLog('vxe.error.notProp', ['mouse-config.area']);
9398
+ }
9379
9399
  return nextTick().then(() => {
9380
9400
  updateStyle();
9381
9401
  });
@@ -10253,7 +10273,7 @@ export default defineComponent({
10253
10273
  initTpImg();
10254
10274
  }
10255
10275
  nextTick(() => {
10256
- const { data, exportConfig, importConfig, treeConfig, showOverflow } = props;
10276
+ const { data, exportConfig, importConfig, treeConfig, showOverflow, highlightCurrentRow, highlightCurrentColumn } = props;
10257
10277
  const { scrollXStore, scrollYStore } = internalData;
10258
10278
  const editOpts = computeEditOpts.value;
10259
10279
  const treeOpts = computeTreeOpts.value;
@@ -10265,6 +10285,10 @@ export default defineComponent({
10265
10285
  const mouseOpts = computeMouseOpts.value;
10266
10286
  const exportOpts = computeExportOpts.value;
10267
10287
  const importOpts = computeImportOpts.value;
10288
+ const currentRowOpts = computeCurrentRowOpts.value;
10289
+ const currentColumnOpts = computeCurrentColumnOpts.value;
10290
+ const virtualXOpts = computeVirtualXOpts.value;
10291
+ const virtualYOpts = computeVirtualYOpts.value;
10268
10292
  if (props.rowId) {
10269
10293
  warnLog('vxe.error.delProp', ['row-id', 'row-config.keyField']);
10270
10294
  }
@@ -10364,6 +10388,26 @@ export default defineComponent({
10364
10388
  if (checkboxOpts.halfField) {
10365
10389
  warnLog('vxe.error.delProp', ['checkbox-config.halfField', 'checkbox-config.indeterminateField']);
10366
10390
  }
10391
+ if ((rowOpts.isCurrent || highlightCurrentRow) && !XEUtils.isBoolean(currentRowOpts.isFollowSelected)) {
10392
+ warnLog('vxe.error.notConflictProp', ['row-config.isCurrent', 'current-row-config.isFollowSelected']);
10393
+ }
10394
+ if ((columnOpts.isCurrent || highlightCurrentColumn) && !XEUtils.isBoolean(currentColumnOpts.isFollowSelected)) {
10395
+ warnLog('vxe.error.notConflictProp', ['column-config.isCurrent', 'current-column-config.isFollowSelected']);
10396
+ }
10397
+ // 如果不支持虚拟滚动
10398
+ if (props.spanMethod) {
10399
+ if (virtualXOpts.enabled) {
10400
+ warnLog('vxe.error.notConflictProp', ['span-method', 'virtual-x-config.enabled=false']);
10401
+ }
10402
+ if (virtualYOpts.enabled) {
10403
+ warnLog('vxe.error.notConflictProp', ['span-method', 'virtual-y-config.enabled=false']);
10404
+ }
10405
+ }
10406
+ if (props.footerSpanMethod) {
10407
+ if (virtualXOpts.enabled) {
10408
+ warnLog('vxe.error.notConflictProp', ['footer-span-method', 'virtual-x-config.enabled=false']);
10409
+ }
10410
+ }
10367
10411
  // 检查是否有安装需要的模块
10368
10412
  if (props.editConfig && !$xeTable.insert) {
10369
10413
  errLog('vxe.error.reqModule', ['Edit']);
package/es/ui/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { VxeUI } from '@vxe-ui/core';
2
2
  import { getFuncText } from './src/utils';
3
- export const version = "4.12.2";
3
+ export const version = "4.12.4";
4
4
  VxeUI.version = version;
5
5
  VxeUI.tableVersion = version;
6
6
  VxeUI.setConfig({
package/es/ui/src/log.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { VxeUI } from '@vxe-ui/core';
2
2
  const { log } = VxeUI;
3
- const version = `table v${"4.12.2"}`;
3
+ const version = `table v${"4.12.4"}`;
4
4
  export const warnLog = log.create('warn', version);
5
5
  export const errLog = log.create('error', version);