vxe-table 4.19.8 → 4.19.9

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 (35) hide show
  1. package/dist/all.esm.js +208 -17
  2. package/dist/style.css +1 -1
  3. package/es/grid/src/grid.js +1 -1
  4. package/es/style.css +1 -1
  5. package/es/table/render/index.js +153 -14
  6. package/es/table/src/table.js +51 -0
  7. package/es/table/src/util.js +1 -0
  8. package/es/ui/index.js +1 -1
  9. package/es/ui/src/log.js +1 -1
  10. package/lib/grid/src/grid.js +1 -1
  11. package/lib/grid/src/grid.min.js +1 -1
  12. package/lib/index.umd.js +268 -20
  13. package/lib/index.umd.min.js +1 -1
  14. package/lib/style.css +1 -1
  15. package/lib/table/render/index.js +259 -15
  16. package/lib/table/render/index.min.js +1 -1
  17. package/lib/table/src/table.js +2 -2
  18. package/lib/table/src/table.min.js +1 -1
  19. package/lib/table/src/util.js +1 -0
  20. package/lib/table/src/util.min.js +1 -1
  21. package/lib/ui/index.js +1 -1
  22. package/lib/ui/index.min.js +1 -1
  23. package/lib/ui/src/log.js +1 -1
  24. package/lib/ui/src/log.min.js +1 -1
  25. package/package.json +2 -2
  26. package/packages/grid/src/grid.ts +1 -1
  27. package/packages/table/render/index.ts +156 -15
  28. package/packages/table/src/table.ts +53 -0
  29. package/packages/table/src/util.ts +2 -0
  30. /package/es/{iconfont.1780726776354.ttf → iconfont.1780878117167.ttf} +0 -0
  31. /package/es/{iconfont.1780726776354.woff → iconfont.1780878117167.woff} +0 -0
  32. /package/es/{iconfont.1780726776354.woff2 → iconfont.1780878117167.woff2} +0 -0
  33. /package/lib/{iconfont.1780726776354.ttf → iconfont.1780878117167.ttf} +0 -0
  34. /package/lib/{iconfont.1780726776354.woff → iconfont.1780878117167.woff} +0 -0
  35. /package/lib/{iconfont.1780726776354.woff2 → iconfont.1780878117167.woff2} +0 -0
@@ -778,7 +778,24 @@ renderer.mixin({
778
778
  renderTableEdit: nativeSelectEditRender,
779
779
  renderTableDefault: nativeSelectEditRender,
780
780
  renderTableCell(renderOpts, params) {
781
- return getCellLabelVNs(renderOpts, params, getSelectCellValue(renderOpts, params));
781
+ const { options, optionGroups } = renderOpts;
782
+ const { $table, row, column } = params;
783
+ const opSize = options ? options.length : null;
784
+ const ogSize = optionGroups ? optionGroups.length : null;
785
+ const { cellResult } = $table.effectCellData(row, column, {
786
+ key: 'render_table_cell',
787
+ isChanged({ oldValue, cellValue }) {
788
+ return oldValue && oldValue[0] === cellValue && oldValue[1] === opSize && oldValue[2] === ogSize;
789
+ },
790
+ setValue({ cellValue }) {
791
+ return [cellValue, opSize, ogSize];
792
+ },
793
+ getResult({ cellValue }) {
794
+ return handleSelectCellValue(cellValue, renderOpts);
795
+ }
796
+ });
797
+ // const cellResult = getSelectCellValue(renderOpts, params)
798
+ return getCellLabelVNs(renderOpts, params, cellResult);
782
799
  },
783
800
  createTableFilterOptions: defaultFilterOptions,
784
801
  renderTableFilter(renderOpts, params) {
@@ -889,15 +906,20 @@ renderer.mixin({
889
906
  tableAutoFocus: 'input',
890
907
  renderTableEdit: defaultEditRender,
891
908
  renderTableCell(renderOpts, params) {
892
- const { props = {} } = renderOpts;
893
- const { row, column } = params;
894
- let cellValue = XEUtils.get(row, column.field);
895
- if (cellValue) {
896
- if (props.type !== 'time') {
897
- cellValue = getLabelFormatDate(cellValue, props);
909
+ const props = renderOpts.props || {};
910
+ const { $table, row, column } = params;
911
+ const { cellResult } = $table.effectCellData(row, column, {
912
+ key: 'render_table_cell',
913
+ getResult({ cellValue }) {
914
+ if (cellValue) {
915
+ if (props.type !== 'time') {
916
+ return getLabelFormatDate(cellValue, props);
917
+ }
918
+ }
919
+ return cellValue;
898
920
  }
899
- }
900
- return getCellLabelVNs(renderOpts, params, cellValue);
921
+ });
922
+ return getCellLabelVNs(renderOpts, params, cellResult);
901
923
  },
902
924
  tableCellFormatter: handleFormatDatePicker,
903
925
  renderTableDefault: defaultEditRender,
@@ -945,6 +967,37 @@ renderer.mixin({
945
967
  }, seOs)))
946
968
  ];
947
969
  },
970
+ renderTableDefault(renderOpts, params) {
971
+ const { startField, endField } = renderOpts;
972
+ const { row, column } = params;
973
+ const { model } = column;
974
+ const cellValue = getCellValue(row, column);
975
+ const seProps = {};
976
+ const seOs = {};
977
+ if (startField && endField) {
978
+ seProps.startValue = XEUtils.get(row, startField);
979
+ seProps.endValue = XEUtils.get(row, endField);
980
+ seOs['onUpdate:startValue'] = (value) => {
981
+ if (startField) {
982
+ XEUtils.set(row, startField, value);
983
+ }
984
+ };
985
+ seOs['onUpdate:endValue'] = (value) => {
986
+ if (endField) {
987
+ XEUtils.set(row, endField, value);
988
+ }
989
+ };
990
+ }
991
+ return [
992
+ h(getDefaultComponent(renderOpts), Object.assign(Object.assign({}, getCellEditProps(renderOpts, params, cellValue, seProps)), getComponentOns(renderOpts, params, {
993
+ model(cellValue) {
994
+ model.update = true;
995
+ model.value = cellValue;
996
+ setCellValue(row, column, cellValue);
997
+ }
998
+ }, seOs)))
999
+ ];
1000
+ },
948
1001
  renderTableCell(renderOpts, params) {
949
1002
  const { startField, endField } = renderOpts;
950
1003
  const { row, column } = params;
@@ -977,6 +1030,7 @@ renderer.mixin({
977
1030
  },
978
1031
  VxeTextarea: {
979
1032
  tableAutoFocus: 'textarea',
1033
+ renderTableDefault: defaultEditRender,
980
1034
  renderTableEdit: defaultEditRender,
981
1035
  renderTableCell(renderOpts, params) {
982
1036
  const { row, column } = params;
@@ -1000,7 +1054,24 @@ renderer.mixin({
1000
1054
  renderTableEdit: defaultSelectEditRender,
1001
1055
  renderTableDefault: defaultSelectEditRender,
1002
1056
  renderTableCell(renderOpts, params) {
1003
- return getCellLabelVNs(renderOpts, params, getSelectCellValue(renderOpts, params));
1057
+ const { options, optionGroups } = renderOpts;
1058
+ const { $table, row, column } = params;
1059
+ const opSize = options ? options.length : null;
1060
+ const ogSize = optionGroups ? optionGroups.length : null;
1061
+ const { cellResult } = $table.effectCellData(row, column, {
1062
+ key: 'render_table_cell',
1063
+ isChanged({ oldValue, cellValue }) {
1064
+ return oldValue && oldValue[0] === cellValue && oldValue[1] === opSize && oldValue[2] === ogSize;
1065
+ },
1066
+ setValue({ cellValue }) {
1067
+ return [cellValue, opSize, ogSize];
1068
+ },
1069
+ getResult({ cellValue }) {
1070
+ return handleSelectCellValue(cellValue, renderOpts);
1071
+ }
1072
+ });
1073
+ // const cellResult = getSelectCellValue(renderOpts, params)
1074
+ return getCellLabelVNs(renderOpts, params, cellResult);
1004
1075
  },
1005
1076
  createTableFilterOptions: defaultFilterOptions,
1006
1077
  renderTableFilter(renderOpts, params) {
@@ -1055,7 +1126,24 @@ renderer.mixin({
1055
1126
  },
1056
1127
  FormatSelect: {
1057
1128
  renderTableDefault(renderOpts, params) {
1058
- return getCellLabelVNs(renderOpts, params, getSelectCellValue(renderOpts, params));
1129
+ const { options, optionGroups } = renderOpts;
1130
+ const { $table, row, column } = params;
1131
+ const opSize = options ? options.length : null;
1132
+ const ogSize = optionGroups ? optionGroups.length : null;
1133
+ const { cellResult } = $table.effectCellData(row, column, {
1134
+ key: 'render_table_cell',
1135
+ isChanged({ oldValue, cellValue }) {
1136
+ return oldValue && oldValue[0] === cellValue && oldValue[1] === opSize && oldValue[2] === ogSize;
1137
+ },
1138
+ setValue({ cellValue }) {
1139
+ return [cellValue, opSize, ogSize];
1140
+ },
1141
+ getResult({ cellValue }) {
1142
+ return handleSelectCellValue(cellValue, renderOpts);
1143
+ }
1144
+ });
1145
+ // const cellResult = getSelectCellValue(renderOpts, params)
1146
+ return getCellLabelVNs(renderOpts, params, cellResult);
1059
1147
  },
1060
1148
  tableCellFormatter: handleFormatSelect,
1061
1149
  tableCellCopyMethod: handleFormatSelect,
@@ -1067,7 +1155,24 @@ renderer.mixin({
1067
1155
  tableAutoFocus: 'input',
1068
1156
  renderTableEdit: defaultTableOrTreeSelectEditRender,
1069
1157
  renderTableCell(renderOpts, params) {
1070
- return getCellLabelVNs(renderOpts, params, getTreeSelectCellValue(renderOpts, params));
1158
+ const { options, optionGroups } = renderOpts;
1159
+ const { $table, row, column } = params;
1160
+ const opSize = options ? options.length : null;
1161
+ const ogSize = optionGroups ? optionGroups.length : null;
1162
+ const { cellResult } = $table.effectCellData(row, column, {
1163
+ key: 'render_table_cell',
1164
+ isChanged({ oldValue, cellValue }) {
1165
+ return oldValue && oldValue[0] === cellValue && oldValue[1] === opSize && oldValue[2] === ogSize;
1166
+ },
1167
+ setValue({ cellValue }) {
1168
+ return [cellValue, opSize, ogSize];
1169
+ },
1170
+ getResult({ cellValue }) {
1171
+ return handleTreeSelectCellValue(cellValue, renderOpts);
1172
+ }
1173
+ });
1174
+ // const cellResult = getTreeSelectCellValue(renderOpts, params)
1175
+ return getCellLabelVNs(renderOpts, params, cellResult);
1071
1176
  },
1072
1177
  tableCellFormatter: handleFormatTreeSelect,
1073
1178
  tableCellCopyMethod: handleFormatTreeSelect,
@@ -1085,7 +1190,24 @@ renderer.mixin({
1085
1190
  },
1086
1191
  FormatTreeSelect: {
1087
1192
  renderTableDefault(renderOpts, params) {
1088
- return getCellLabelVNs(renderOpts, params, getTreeSelectCellValue(renderOpts, params));
1193
+ const { options, optionGroups } = renderOpts;
1194
+ const { $table, row, column } = params;
1195
+ const opSize = options ? options.length : null;
1196
+ const ogSize = optionGroups ? optionGroups.length : null;
1197
+ const { cellResult } = $table.effectCellData(row, column, {
1198
+ key: 'render_table_cell',
1199
+ isChanged({ oldValue, cellValue }) {
1200
+ return oldValue && oldValue[0] === cellValue && oldValue[1] === opSize && oldValue[2] === ogSize;
1201
+ },
1202
+ setValue({ cellValue }) {
1203
+ return [cellValue, opSize, ogSize];
1204
+ },
1205
+ getResult({ cellValue }) {
1206
+ return handleTreeSelectCellValue(cellValue, renderOpts);
1207
+ }
1208
+ });
1209
+ // const cellResult = getTreeSelectCellValue(renderOpts, params)
1210
+ return getCellLabelVNs(renderOpts, params, cellResult);
1089
1211
  },
1090
1212
  tableCellFormatter: handleFormatTreeSelect,
1091
1213
  tableCellCopyMethod: handleFormatTreeSelect,
@@ -1096,7 +1218,24 @@ renderer.mixin({
1096
1218
  tableAutoFocus: 'input',
1097
1219
  renderTableEdit: defaultTableOrTreeSelectEditRender,
1098
1220
  renderTableCell(renderOpts, params) {
1099
- return getCellLabelVNs(renderOpts, params, getTreeSelectCellValue(renderOpts, params));
1221
+ const { options, optionGroups } = renderOpts;
1222
+ const { $table, row, column } = params;
1223
+ const opSize = options ? options.length : null;
1224
+ const ogSize = optionGroups ? optionGroups.length : null;
1225
+ const { cellResult } = $table.effectCellData(row, column, {
1226
+ key: 'render_table_cell',
1227
+ isChanged({ oldValue, cellValue }) {
1228
+ return oldValue && oldValue[0] === cellValue && oldValue[1] === opSize && oldValue[2] === ogSize;
1229
+ },
1230
+ setValue({ cellValue }) {
1231
+ return [cellValue, opSize, ogSize];
1232
+ },
1233
+ getResult({ cellValue }) {
1234
+ return handleTreeSelectCellValue(cellValue, renderOpts);
1235
+ }
1236
+ });
1237
+ // const cellResult = getTreeSelectCellValue(renderOpts, params)
1238
+ return getCellLabelVNs(renderOpts, params, cellResult);
1100
1239
  },
1101
1240
  tableCellFormatter: handleFormatTreeSelect,
1102
1241
  tableCellCopyMethod: handleFormatTreeSelect,
@@ -3742,6 +3742,7 @@ export default defineVxeComponent({
3742
3742
  internalData.removeRowMaps = {};
3743
3743
  reactData.removeRowFlag++;
3744
3744
  internalData.fullCellHeightMaps = {};
3745
+ internalData.fullCellStoreMaps = {};
3745
3746
  const sYLoad = updateScrollYStatus(fullData);
3746
3747
  // 全量数据
3747
3748
  internalData.tableFullData = fullData;
@@ -5234,6 +5235,56 @@ export default defineVxeComponent({
5234
5235
  }
5235
5236
  return nextTick();
5236
5237
  },
5238
+ effectCellData(row, column, options) {
5239
+ const { fullCellStoreMaps } = internalData;
5240
+ const editOpts = computeEditOpts.value;
5241
+ const { key, isChanged, setValue, getResult } = options;
5242
+ const rowid = getRowid($xeTable, row);
5243
+ const colid = column.id;
5244
+ let rowStore = fullCellStoreMaps[rowid];
5245
+ const cellValue = XEUtils.get(row, column.field);
5246
+ const restParams = {
5247
+ $table: $xeTable,
5248
+ row,
5249
+ rowid,
5250
+ column,
5251
+ colid,
5252
+ cellValue,
5253
+ oldValue: null
5254
+ };
5255
+ if (editOpts.cache === false && key === 'render_table_cell') {
5256
+ const rest = restParams;
5257
+ rest.cellResult = getResult ? getResult(restParams) : cellValue;
5258
+ return rest;
5259
+ }
5260
+ if (!rowStore) {
5261
+ rowStore = {};
5262
+ fullCellStoreMaps[rowid] = rowStore;
5263
+ }
5264
+ let cellStore = rowStore[colid];
5265
+ if (!cellStore) {
5266
+ cellStore = {
5267
+ value: undefined,
5268
+ result: {}
5269
+ };
5270
+ rowStore[colid] = cellStore;
5271
+ }
5272
+ const restData = rowStore[colid];
5273
+ const oldValue = restData.value;
5274
+ restParams.oldValue = oldValue;
5275
+ if (isChanged ? !isChanged(restParams) : oldValue !== cellValue) {
5276
+ restData.value = setValue ? setValue(restParams) : cellValue;
5277
+ restData.result = {};
5278
+ }
5279
+ const storeData = restData.result;
5280
+ if (XEUtils.isUndefined(storeData[key])) {
5281
+ storeData[key] = getResult ? getResult(restParams) : cellValue;
5282
+ }
5283
+ const cellResult = storeData[key];
5284
+ const rest = restParams;
5285
+ rest.cellResult = cellResult;
5286
+ return rest;
5287
+ },
5237
5288
  getCellElement(row, fieldOrColumn) {
5238
5289
  const { elemStore } = internalData;
5239
5290
  const column = handleFieldOrColumn($xeTable, fieldOrColumn);
@@ -84,6 +84,7 @@ export function createInternalData() {
84
84
  fullColumnIdData: {},
85
85
  fullColumnFieldData: {},
86
86
  fullCellHeightMaps: {},
87
+ fullCellStoreMaps: {},
87
88
  // 当前行
88
89
  currentRow: null,
89
90
  // 合并表头单元格的数据
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.19.8";
3
+ export const version = "4.19.9";
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.19.8"}`;
3
+ const version = `table v${"4.19.9"}`;
4
4
  export const warnLog = log.create('warn', version);
5
5
  export const errLog = log.create('error', version);
@@ -31,7 +31,7 @@ const {
31
31
  renderEmptyElement
32
32
  } = _ui.VxeUI;
33
33
  const tableComponentPropKeys = Object.keys(_props2.tableProps);
34
- const tableComponentMethodKeys = ['clearAll', 'syncData', 'updateData', 'loadData', 'reloadData', 'reloadRow', 'loadColumn', 'reloadColumn', 'getRowNode', 'getColumnNode', 'getRowIndex', 'getVTRowIndex', 'getVMRowIndex', 'getColumnIndex', 'getVTColumnIndex', 'getVMColumnIndex', 'setRow', 'createData', 'createRow', 'revertData', 'clearData', 'isRemoveByRow', 'isInsertByRow', 'isUpdateByRow', 'getColumns', 'getColumnById', 'getColumnByField', 'getTableColumn', 'getFullColumns', 'getData', 'getCheckboxRecords', 'getParentRow', 'getTreeRowChildren', 'getTreeRowLevel', 'getTreeParentRow', 'getRowSeq', 'getRowById', 'getRowid', 'getTableData', 'getFullData', 'setColumnFixed', 'clearColumnFixed', 'setColumnWidth', 'getColumnWidth', 'recalcRowHeight', 'setRowHeightConf', 'getRowHeightConf', 'setRowHeight', 'getRowHeight', 'hideColumn', 'showColumn', 'resetColumn', 'refreshColumn', 'refreshScroll', 'recalculate', 'closeTooltip', 'isAllCheckboxChecked', 'isAllCheckboxIndeterminate', 'getCheckboxIndeterminateRecords', 'setCheckboxRow', 'setCheckboxRowKey', 'isCheckedByCheckboxRow', 'isCheckedByCheckboxRowKey', 'isIndeterminateByCheckboxRow', 'isIndeterminateByCheckboxRowKey', 'toggleCheckboxRow', 'setAllCheckboxRow', 'getRadioReserveRecord', 'clearRadioReserve', 'getCheckboxReserveRecords', 'clearCheckboxReserve', 'toggleAllCheckboxRow', 'clearCheckboxRow', 'setCurrentRow', 'isCheckedByRadioRow', 'isCheckedByRadioRowKey', 'setRadioRow', 'setRadioRowKey', 'clearCurrentRow', 'clearRadioRow', 'getCurrentRecord', 'getRadioRecord', 'getCurrentColumn', 'setCurrentColumn', 'clearCurrentColumn', 'setPendingRow', 'togglePendingRow', 'hasPendingByRow', 'isPendingByRow', 'getPendingRecords', 'clearPendingRow', 'setFilterByEvent', 'sort', 'setSort', 'setSortByEvent', 'clearSort', 'clearSortByEvent', 'isSort', 'getSortColumns', 'closeFilter', 'isFilter', 'clearFilterByEvent', 'isActiveFilterByColumn', 'isRowExpandLoaded', 'clearRowExpandLoaded', 'reloadRowExpand', 'reloadRowExpand', 'toggleRowExpand', 'setAllRowExpand', 'setRowExpand', 'isExpandByRow', 'isRowExpandByRow', 'clearRowExpand', 'clearRowExpandReserve', 'getRowExpandRecords', 'getTreeExpandRecords', 'isTreeExpandLoaded', 'clearTreeExpandLoaded', 'reloadTreeExpand', 'reloadTreeChilds', 'toggleTreeExpand', 'setAllTreeExpand', 'setTreeExpand', 'isTreeExpandByRow', 'clearTreeExpand', 'clearTreeExpandReserve', 'getScroll', 'getScrollData', 'scrollTo', 'scrollToStartRow', 'scrollToEndRow', 'scrollToRow', 'scrollToStartColumn', 'scrollToEndColumn', 'scrollToColumn', 'clearScroll', 'updateFooter', 'updateStatus', 'setMergeCells', 'removeInsertRow', 'removeMergeCells', 'getMergeCells', 'setMergeHeaderCells', 'removeMergeHeaderCells', 'getMergeHeaderCells', 'clearMergeHeaderCells', 'clearMergeCells', 'setMergeFooterItems', 'removeMergeFooterItems', 'getMergeFooterItems', 'clearMergeFooterItems', 'setCustomStoreData', 'getCustomStoreData', 'setRowGroupExpand', 'setRowGroupExpandByField', 'setAllRowGroupExpand', 'clearRowGroupExpand', 'isRowGroupExpandByRow', 'isRowGroupRecord', 'isAggregateRecord', 'isAggregateExpandByRow', 'getAggregateContentByRow', 'getAggregateRowChildren', 'setRowGroups', 'clearRowGroups', 'openTooltip', 'moveColumnTo', 'moveRowTo', 'getCellLabel', 'updateCellLabel', 'clearFormatterCache', 'getFooterCellLabel', 'updateFooterCellLabel', 'clearFooterFormatterCache', 'undo', 'redo', 'getCellElement', 'focus', 'blur', 'connect', 'connectToolbar'];
34
+ const tableComponentMethodKeys = ['clearAll', 'syncData', 'updateData', 'loadData', 'reloadData', 'reloadRow', 'loadColumn', 'reloadColumn', 'getRowNode', 'getColumnNode', 'getRowIndex', 'getVTRowIndex', 'getVMRowIndex', 'getColumnIndex', 'getVTColumnIndex', 'getVMColumnIndex', 'setRow', 'createData', 'createRow', 'revertData', 'clearData', 'isRemoveByRow', 'isInsertByRow', 'isUpdateByRow', 'getColumns', 'getColumnById', 'getColumnByField', 'getTableColumn', 'getFullColumns', 'getData', 'getCheckboxRecords', 'getParentRow', 'getTreeRowChildren', 'getTreeRowLevel', 'getTreeParentRow', 'getRowSeq', 'getRowById', 'getRowid', 'getTableData', 'getFullData', 'setColumnFixed', 'clearColumnFixed', 'setColumnWidth', 'getColumnWidth', 'recalcRowHeight', 'setRowHeightConf', 'getRowHeightConf', 'setRowHeight', 'getRowHeight', 'hideColumn', 'showColumn', 'resetColumn', 'refreshColumn', 'refreshScroll', 'recalculate', 'closeTooltip', 'isAllCheckboxChecked', 'isAllCheckboxIndeterminate', 'getCheckboxIndeterminateRecords', 'setCheckboxRow', 'setCheckboxRowKey', 'isCheckedByCheckboxRow', 'isCheckedByCheckboxRowKey', 'isIndeterminateByCheckboxRow', 'isIndeterminateByCheckboxRowKey', 'toggleCheckboxRow', 'setAllCheckboxRow', 'getRadioReserveRecord', 'clearRadioReserve', 'getCheckboxReserveRecords', 'clearCheckboxReserve', 'toggleAllCheckboxRow', 'clearCheckboxRow', 'setCurrentRow', 'isCheckedByRadioRow', 'isCheckedByRadioRowKey', 'setRadioRow', 'setRadioRowKey', 'clearCurrentRow', 'clearRadioRow', 'getCurrentRecord', 'getRadioRecord', 'getCurrentColumn', 'setCurrentColumn', 'clearCurrentColumn', 'setPendingRow', 'togglePendingRow', 'hasPendingByRow', 'isPendingByRow', 'getPendingRecords', 'clearPendingRow', 'setFilterByEvent', 'sort', 'setSort', 'setSortByEvent', 'clearSort', 'clearSortByEvent', 'isSort', 'getSortColumns', 'closeFilter', 'isFilter', 'clearFilterByEvent', 'isActiveFilterByColumn', 'isRowExpandLoaded', 'clearRowExpandLoaded', 'reloadRowExpand', 'reloadRowExpand', 'toggleRowExpand', 'setAllRowExpand', 'setRowExpand', 'isExpandByRow', 'isRowExpandByRow', 'clearRowExpand', 'clearRowExpandReserve', 'getRowExpandRecords', 'getTreeExpandRecords', 'isTreeExpandLoaded', 'clearTreeExpandLoaded', 'reloadTreeExpand', 'reloadTreeChilds', 'toggleTreeExpand', 'setAllTreeExpand', 'setTreeExpand', 'isTreeExpandByRow', 'clearTreeExpand', 'clearTreeExpandReserve', 'getScroll', 'getScrollData', 'scrollTo', 'scrollToStartRow', 'scrollToEndRow', 'scrollToRow', 'scrollToStartColumn', 'scrollToEndColumn', 'scrollToColumn', 'clearScroll', 'updateFooter', 'updateStatus', 'setMergeCells', 'removeInsertRow', 'removeMergeCells', 'getMergeCells', 'setMergeHeaderCells', 'removeMergeHeaderCells', 'getMergeHeaderCells', 'clearMergeHeaderCells', 'clearMergeCells', 'setMergeFooterItems', 'removeMergeFooterItems', 'getMergeFooterItems', 'clearMergeFooterItems', 'setCustomStoreData', 'getCustomStoreData', 'setRowGroupExpand', 'setRowGroupExpandByField', 'setAllRowGroupExpand', 'clearRowGroupExpand', 'isRowGroupExpandByRow', 'isRowGroupRecord', 'isAggregateRecord', 'isAggregateExpandByRow', 'getAggregateContentByRow', 'getAggregateRowChildren', 'setRowGroups', 'clearRowGroups', 'openTooltip', 'moveColumnTo', 'moveRowTo', 'getCellLabel', 'updateCellLabel', 'clearFormatterCache', 'getFooterCellLabel', 'updateFooterCellLabel', 'clearFooterFormatterCache', 'undo', 'redo', 'effectCellData', 'getCellElement', 'focus', 'blur', 'connect', 'connectToolbar'];
35
35
  function createReactData() {
36
36
  var _a;
37
37
  return {
@@ -1 +1 @@
1
- Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _vue=require("vue"),_comp=require("../../ui/src/comp"),_xeUtils=_interopRequireDefault(require("xe-utils")),_utils=require("../../ui/src/utils"),_dom=require("../../ui/src/dom"),_ui=require("../../ui"),_props=require("./props"),_emits=require("./emits"),_vn=require("../../ui/src/vn"),_log=require("../../ui/src/log"),_emits2=require("../../table/src/emits"),_props2=require("../../table/src/props"),_table=_interopRequireDefault(require("../../table/src/table")),_toolbar=_interopRequireDefault(require("../../toolbar/src/toolbar"));function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}let{getConfig,getI18n,commands,hooks,useFns,createEvent,globalEvents,GLOBAL_EVENT_KEYS,renderEmptyElement}=_ui.VxeUI,tableComponentPropKeys=Object.keys(_props2.tableProps),tableComponentMethodKeys=["clearAll","syncData","updateData","loadData","reloadData","reloadRow","loadColumn","reloadColumn","getRowNode","getColumnNode","getRowIndex","getVTRowIndex","getVMRowIndex","getColumnIndex","getVTColumnIndex","getVMColumnIndex","setRow","createData","createRow","revertData","clearData","isRemoveByRow","isInsertByRow","isUpdateByRow","getColumns","getColumnById","getColumnByField","getTableColumn","getFullColumns","getData","getCheckboxRecords","getParentRow","getTreeRowChildren","getTreeRowLevel","getTreeParentRow","getRowSeq","getRowById","getRowid","getTableData","getFullData","setColumnFixed","clearColumnFixed","setColumnWidth","getColumnWidth","recalcRowHeight","setRowHeightConf","getRowHeightConf","setRowHeight","getRowHeight","hideColumn","showColumn","resetColumn","refreshColumn","refreshScroll","recalculate","closeTooltip","isAllCheckboxChecked","isAllCheckboxIndeterminate","getCheckboxIndeterminateRecords","setCheckboxRow","setCheckboxRowKey","isCheckedByCheckboxRow","isCheckedByCheckboxRowKey","isIndeterminateByCheckboxRow","isIndeterminateByCheckboxRowKey","toggleCheckboxRow","setAllCheckboxRow","getRadioReserveRecord","clearRadioReserve","getCheckboxReserveRecords","clearCheckboxReserve","toggleAllCheckboxRow","clearCheckboxRow","setCurrentRow","isCheckedByRadioRow","isCheckedByRadioRowKey","setRadioRow","setRadioRowKey","clearCurrentRow","clearRadioRow","getCurrentRecord","getRadioRecord","getCurrentColumn","setCurrentColumn","clearCurrentColumn","setPendingRow","togglePendingRow","hasPendingByRow","isPendingByRow","getPendingRecords","clearPendingRow","setFilterByEvent","sort","setSort","setSortByEvent","clearSort","clearSortByEvent","isSort","getSortColumns","closeFilter","isFilter","clearFilterByEvent","isActiveFilterByColumn","isRowExpandLoaded","clearRowExpandLoaded","reloadRowExpand","reloadRowExpand","toggleRowExpand","setAllRowExpand","setRowExpand","isExpandByRow","isRowExpandByRow","clearRowExpand","clearRowExpandReserve","getRowExpandRecords","getTreeExpandRecords","isTreeExpandLoaded","clearTreeExpandLoaded","reloadTreeExpand","reloadTreeChilds","toggleTreeExpand","setAllTreeExpand","setTreeExpand","isTreeExpandByRow","clearTreeExpand","clearTreeExpandReserve","getScroll","getScrollData","scrollTo","scrollToStartRow","scrollToEndRow","scrollToRow","scrollToStartColumn","scrollToEndColumn","scrollToColumn","clearScroll","updateFooter","updateStatus","setMergeCells","removeInsertRow","removeMergeCells","getMergeCells","setMergeHeaderCells","removeMergeHeaderCells","getMergeHeaderCells","clearMergeHeaderCells","clearMergeCells","setMergeFooterItems","removeMergeFooterItems","getMergeFooterItems","clearMergeFooterItems","setCustomStoreData","getCustomStoreData","setRowGroupExpand","setRowGroupExpandByField","setAllRowGroupExpand","clearRowGroupExpand","isRowGroupExpandByRow","isRowGroupRecord","isAggregateRecord","isAggregateExpandByRow","getAggregateContentByRow","getAggregateRowChildren","setRowGroups","clearRowGroups","openTooltip","moveColumnTo","moveRowTo","getCellLabel","updateCellLabel","clearFormatterCache","getFooterCellLabel","updateFooterCellLabel","clearFooterFormatterCache","undo","redo","getCellElement","focus","blur","connect","connectToolbar"];function createReactData(){var e;return{tableLoading:!1,proxyInited:!1,isZMax:!1,tableData:[],filterData:[],formData:{},sortData:[],footerData:[],tZindex:0,tablePage:{total:0,pageSize:(null==(e=getConfig().pager)?void 0:e.pageSize)||10,currentPage:1}}}function createInternalData(){return{uFoot:!1}}var _default=exports.default=(0,_comp.defineVxeComponent)({name:"VxeGrid",props:_props.gridProps,emits:_emits.gridEmits,setup(c,e){let{slots:d,emit:o}=e;var t=_xeUtils.default.uniqueId();let n=_ui.VxeUI.getComponent("VxeForm"),l=_ui.VxeUI.getComponent("VxePager"),w=[["Form"],["Toolbar","Top","Table","Bottom","Pager"]],P=useFns.useSize(c).computeSize,j=(0,_vue.reactive)(createReactData()),M=createInternalData(),g=(0,_vue.ref)(),$=(0,_vue.ref)(),i=(0,_vue.ref)(),u=(0,_vue.ref)(),s=(0,_vue.ref)(),v=(0,_vue.ref)(),m=(0,_vue.ref)(),p=(0,_vue.ref)(),f=(0,_vue.ref)(),x=(0,_vue.ref)(),b=(0,_vue.ref)();var r=e=>{let t={};return e.forEach(r=>{t[r]=(...e)=>{var t=$.value;if(t&&t[r])return t[r](...e)}}),t};let a=r(tableComponentMethodKeys),q=(tableComponentMethodKeys.forEach(r=>{a[r]=(...e)=>{var t=$.value;if(t&&t[r])return t&&t[r](...e)}}),(0,_vue.computed)(()=>_xeUtils.default.merge({},_xeUtils.default.clone(getConfig().grid.proxyConfig,!0),c.proxyConfig))),K=(0,_vue.computed)(()=>{var e=q.value;return!!(_xeUtils.default.isBoolean(e.message)?e.message:e.showResponseMsg)}),B=(0,_vue.computed)(()=>{var e=q.value;return _xeUtils.default.isBoolean(e.showActionMsg)?e.showActionMsg:!!e.showActiveMsg}),L=(0,_vue.computed)(()=>Object.assign({},getConfig().grid.pagerConfig,c.pagerConfig)),_=(0,_vue.computed)(()=>Object.assign({},getConfig().grid.formConfig,c.formConfig)),V=(0,_vue.computed)(()=>Object.assign({},getConfig().grid.toolbarConfig,c.toolbarConfig)),h=(0,_vue.computed)(()=>Object.assign({},getConfig().grid.zoomConfig,c.zoomConfig)),F=(0,_vue.computed)(()=>{var{height:e,maxHeight:t}=c,{isZMax:r,tZindex:o}=j,a={};return r?a.zIndex=o:(e&&(a.height="auto"===e||"100%"===e?"100%":(0,_dom.toCssUnit)(e)),t&&(a.maxHeight="auto"===t||"100%"===t?"100%":(0,_dom.toCssUnit)(t))),a}),T=(0,_vue.computed)(()=>{let t={};return tableComponentPropKeys.forEach(e=>{void 0!==c[e]&&(t[e]=c[e])}),t}),k=(0,_vue.computed)(()=>{var{showFooter:e,seqConfig:t,pagerConfig:r,editConfig:o,proxyConfig:a}=c,{isZMax:l,tablePage:n,footerData:i}=j,s=T.value,u=q.value,g=L.value,d=G.value,s=Object.assign({},s);return(e&&!s.footerData||u.footer&&i.length)&&(s.footerData=i),l&&(s.maxHeight?s.maxHeight="100%":s.height="100%"),a&&(0,_utils.isEnableConf)(u)&&(s.loading=d,r)&&u.seq&&(0,_utils.isEnableConf)(g)&&(s.seqConfig=Object.assign({},t,{startIndex:(n.currentPage-1)*n.pageSize})),o&&(s.editConfig=Object.assign({},o)),s}),U=(0,_vue.computed)(()=>{var e=c.layouts;let t=[],r=[],o=[],a=[];return(t=e&&e.length?e:getConfig().grid.layouts||w).length&&(_xeUtils.default.isArray(t[0])?(r=t[0],o=t[1]||[],a=t[2]||[]):o=t),{headKeys:r,bodyKeys:o,footKeys:a}});var S=(0,_vue.computed)(()=>L.value.currentPage),I=(0,_vue.computed)(()=>L.value.pageSize),O=(0,_vue.computed)(()=>L.value.total);let D=(0,_vue.computed)(()=>{var e=j.tablePage;return Math.max(Math.ceil(e.total/e.pageSize),1)}),G=(0,_vue.computed)(()=>{var{loading:e,proxyConfig:t}=c,r=j.tableLoading,o=q.value,a=o.showLoading;return e||r&&a&&t&&(0,_utils.isEnableConf)(o)}),N={refElem:g,refTable:$,refForm:i,refToolbar:u,refPager:s,refPopupContainerElem:v},Q={computeProxyOpts:q,computePagerOpts:L,computeFormOpts:_,computeToolbarOpts:V,computeZoomOpts:h},z={xID:t,props:c,context:e,reactData:j,internalData:M,getRefMaps:()=>N,getComputeMaps:()=>Q},W=()=>{var e=V.value;c.toolbarConfig&&(0,_utils.isEnableConf)(e)&&(0,_vue.nextTick)(()=>{var e=$.value,t=u.value;e&&t&&e.connectToolbar(t)})},A=()=>{var e=c.proxyConfig,t=j.formData,r=q.value,o=_.value;return e&&(0,_utils.isEnableConf)(r)&&r.form?t:o.data},C=e=>{var t=j.tablePage,r=c.pagerConfig,o=L.value;r&&(0,_utils.isEnableConf)(o)&&(e?o[e]&&(t[e]=_xeUtils.default.toNumber(o[e])):({currentPage:r,pageSize:e,total:o}=o,r&&(t.currentPage=r),e&&(t.pageSize=e),o&&(t.total=o)))},H=(e,t)=>{var r=q.value,r=(r.response||r.props||{}).message,o=$.value;let a;return(a=e&&r?_xeUtils.default.isFunction(r)?r({data:e,$table:o,$grid:z,$gantt:null}):_xeUtils.default.get(e,r):a)||getI18n(t)},Y=(e,t,r)=>{var o=B.value,a=z.getCheckboxRecords();if(o)if(a.length){if(_ui.VxeUI.modal)return _ui.VxeUI.modal.confirm({id:"cfm_"+e,content:getI18n(t),escClosable:!0}).then(e=>{if("confirm"===e)return r()})}else _ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:"msg_"+e,content:getI18n("vxe.grid.selectOneRecord"),status:"warning"});else a.length&&r();return Promise.resolve()},J=e=>{var t=c.proxyConfig,r=j.tablePage;let{$event:o,currentPage:a,pageSize:l}=e;var n=q.value;r.currentPage=a,r.pageSize=l,z.dispatchEvent("page-change",e,o),t&&(0,_utils.isEnableConf)(n)&&z.commitProxy("query").then(e=>{z.dispatchEvent("proxy-query",e,o)})},X=t=>{var e,r=$.value,o=c.proxyConfig;r&&(r=r.getComputeMaps().computeSortOpts,e=q.value,r.value.remote)&&(j.sortData=t.sortList,o)&&(0,_utils.isEnableConf)(e)&&(j.tablePage.currentPage=1,z.commitProxy("query").then(e=>{z.dispatchEvent("proxy-query",e,t.$event)}))},ee=e=>{X(e),z.dispatchEvent("sort-change",e,e.$event)},te=e=>{X(e),z.dispatchEvent("clear-all-sort",e,e.$event)},re=t=>{var e,r=$.value,o=c.proxyConfig;r&&(r=r.getComputeMaps().computeFilterOpts,e=q.value,r.value.remote)&&(j.filterData=t.filterList,o)&&(0,_utils.isEnableConf)(e)&&(j.tablePage.currentPage=1,M.uFoot=!0,z.commitProxy("query").then(e=>{z.dispatchEvent("proxy-query",e,t.$event)}),M.uFoot=!1,Z())},oe=e=>{re(e),z.dispatchEvent("filter-change",e,e.$event)},ae=e=>{re(e),z.dispatchEvent("clear-all-filter",e,e.$event)},le=t=>{var e=c.proxyConfig,r=q.value;j.tableLoading||(e&&(0,_utils.isEnableConf)(r)&&(M.uFoot=!0,z.commitProxy("reload").then(e=>{z.dispatchEvent("proxy-query",Object.assign(Object.assign({},e),{isReload:!0}),t.$event)}),M.uFoot=!1,Z()),z.dispatchEvent("form-submit",t,t.$event))},ne=e=>{var t=$.value,r=c.proxyConfig;let o=e.$event;var a=q.value;r&&(0,_utils.isEnableConf)(a)&&(t&&t.clearScroll(),M.uFoot=!0,z.commitProxy("reload").then(e=>{z.dispatchEvent("proxy-query",Object.assign(Object.assign({},e),{isReload:!0}),o)}),M.uFoot=!1,Z()),z.dispatchEvent("form-reset",e,o)},ie=e=>{z.dispatchEvent("form-submit-invalid",e,e.$event)},se=e=>{var t=e.$event;z.dispatchEvent("form-toggle-collapse",e,t),z.dispatchEvent("form-collapse",e,t)},ue=e=>{var t=j.isZMax;return(e?!t:t)&&(j.isZMax=!t,j.tZindex<(0,_utils.getLastZIndex)())&&(j.tZindex=(0,_utils.nextZIndex)()),(0,_vue.nextTick)().then(()=>z.recalculate(!0)).then(()=>(setTimeout(()=>z.recalculate(!0),15),j.isZMax))},y=(e,t)=>{e=e[t];if(e){if(!_xeUtils.default.isString(e))return e;if(d[e])return d[e];(0,_log.errLog)("vxe.error.notSlot",["[grid] "+e])}return null},ge=e=>{let r={};return _xeUtils.default.objectMap(e,(e,t)=>{e&&(_xeUtils.default.isString(e)?d[e]?r[t]=d[e]:(0,_log.errLog)("vxe.error.notSlot",["[grid] "+e]):r[t]=e)}),r},de=()=>{var{formConfig:e,proxyConfig:r}=c,o=j.formData,a=q.value,l=_.value;if(e&&(0,_utils.isEnableConf)(l)||d.form){let e=[];if(d.form)e=d.form({$grid:z,$gantt:null});else if(l.items){let t={};if(!l.inited){l.inited=!0;let t=a.beforeItem;a&&t&&l.items.forEach(e=>{t({$grid:z,$gantt:null,item:e})})}l.items.forEach(e=>{_xeUtils.default.each(e.slots,e=>{_xeUtils.default.isFunction(e)||d[e]&&(t[e]=d[e])})}),n&&e.push((0,_vue.h)(n,Object.assign(Object.assign({ref:i},Object.assign({},l,{data:r&&(0,_utils.isEnableConf)(a)&&a.form?o:l.data})),{onSubmit:le,onReset:ne,onSubmitInvalid:ie,onCollapse:se}),t))}return(0,_vue.h)("div",{ref:m,key:"form",class:"vxe-grid--form-wrapper"},e)}return renderEmptyElement(z)},ce=()=>{var t,r,o,a,l,n=c.toolbarConfig,i=V.value,s=d.toolbar;if(n&&(0,_utils.isEnableConf)(i)||s){let e=[];return s?e=s({$grid:z,$gantt:null}):(n={},(s=i.slots)&&(t=y(s,"buttons"),r=y(s,"buttonPrefix"),o=y(s,"buttonSuffix"),a=y(s,"tools"),l=y(s,"toolPrefix"),s=y(s,"toolSuffix"),t&&(n.buttons=t),r&&(n.buttonPrefix=r),o&&(n.buttonSuffix=o),a&&(n.tools=a),l&&(n.toolPrefix=l),s)&&(n.toolSuffix=s),e.push((0,_vue.h)(_toolbar.default,Object.assign(Object.assign({ref:u},i),{slots:void 0}),n))),(0,_vue.h)("div",{ref:p,key:"toolbar",class:"vxe-grid--toolbar-wrapper"},e)}return renderEmptyElement(z)},ve=()=>{var e=d.top;return e?(0,_vue.h)("div",{ref:f,key:"top",class:"vxe-grid--top-wrapper"},e({$grid:z,$gantt:null})):renderEmptyElement(z)},me=()=>{var e=d.left;return e?(0,_vue.h)("div",{class:"vxe-grid--left-wrapper"},e({$grid:z,$gantt:null})):renderEmptyElement(z)},pe=()=>{var e=d.right;return e?(0,_vue.h)("div",{class:"vxe-grid--right-wrapper"},e({$grid:z,$gantt:null})):renderEmptyElement(z)},fe=()=>{var e=c.proxyConfig,t=k.value,r=q.value,o=Object.assign({},_e),a=d.empty,l=d.loading,n=d.rowDragIcon||d["row-drag-icon"],i=d.columnDragIcon||d["column-drag-icon"],s=d.headerTooltip||d["header-tooltip"],u=d.tooltip,g=d.footerTooltip||d["footer-tooltip"],e=(e&&(0,_utils.isEnableConf)(r)&&(r.sort&&(o.onSortChange=ee,o.onClearAllSort=te),r.filter)&&(o.onFilterChange=oe,o.onClearAllFilter=ae),{});return a&&(e.empty=a),l&&(e.loading=l),n&&(e.rowDragIcon=n),i&&(e.columnDragIcon=i),s&&(e.headerTooltip=s),u&&(e.tooltip=u),g&&(e.footerTooltip=g),(0,_vue.h)("div",{class:"vxe-grid--table-wrapper"},[(0,_vue.h)(_table.default,Object.assign(Object.assign({ref:$},t),o),e)])},xe=()=>d.bottom?(0,_vue.h)("div",{ref:x,key:"bottom",class:"vxe-grid--bottom-wrapper"},d.bottom({$grid:z,$gantt:null})):renderEmptyElement(z),be=()=>{var{proxyConfig:e,pagerConfig:t}=c,r=q.value,o=L.value,a=d.pager;return t&&(0,_utils.isEnableConf)(o)||d.pager?(0,_vue.h)("div",{ref:b,key:"pager",class:"vxe-grid--pager-wrapper"},a?a({$grid:z,$gantt:null}):[l?(0,_vue.h)(l,Object.assign(Object.assign(Object.assign({ref:s},o),e&&(0,_utils.isEnableConf)(r)?j.tablePage:{}),{onPageChange:J}),ge(o.slots)):renderEmptyElement(z)]):renderEmptyElement(z)},E=e=>{let t=[];return e.forEach(e=>{switch(e){case"Form":t.push(de());break;case"Toolbar":t.push(ce());break;case"Top":t.push(ve());break;case"Table":t.push((0,_vue.h)("div",{key:"table",class:"vxe-grid--table-container"},[me(),fe(),pe()]));break;case"Bottom":t.push(xe());break;case"Pager":t.push(be());break;default:(0,_log.errLog)("vxe.error.notProp",["[grid] layouts -> "+e])}}),t},_e={},he=(_emits2.tableEmits.forEach(t=>{var e=_xeUtils.default.camelCase("on-"+t);_e[e]=(...e)=>o(t,...e)}),()=>{var e=_.value;if(e.items){let n={};return e.items.forEach(t=>{var r,o,{field:a,itemRender:l}=t;if(a){let e=null;l&&({startField:l,endField:r,defaultValue:o}=l,_xeUtils.default.isFunction(o)?e=o({item:t}):_xeUtils.default.isUndefined(o)||(e=o),l)&&r&&(_xeUtils.default.set(n,l,null),_xeUtils.default.set(n,r,null)),n[a]=e}}),n}return{}}),Ce=()=>{var{proxyConfig:e,formConfig:t}=c,r=j.proxyInited,o=q.value,a=_.value;e&&(0,_utils.isEnableConf)(o)&&(t&&(0,_utils.isEnableConf)(a)&&o.form&&a.items&&(j.formData=he()),r||!(j.proxyInited=!0)!==o.autoLoad&&(0,_vue.nextTick)().then(()=>{M.uFoot=!0;var e=z.commitProxy("initial");return M.uFoot=!1,Z(),e}).then(e=>{Ee("proxy-query",Object.assign(Object.assign({},e),{isInited:!0}),new Event("initial"))}))},Z=()=>{var e=q.value.ajax;if(e&&e.queryFooter)return z.commitProxy("queryFooter")},ye=e=>{var t=h.value;globalEvents.hasKey(e,GLOBAL_EVENT_KEYS.ESCAPE)&&j.isZMax&&!1!==t.escRestore&&z.triggerZoomEvent(e)},Ee=(e,t,r)=>{o(e,createEvent(r,{$grid:z,$gantt:null},t))};t={dispatchEvent:Ee,getEl(){return g.value},commitProxy(t,...v){let{showFooter:i,proxyConfig:s,toolbarConfig:e,pagerConfig:u,editRules:m,validConfig:p}=c,f=j.tablePage,x=B.value,b=K.value;var _=q.value;let h=L.value;var r=V.value;let{beforeQuery:C,afterQuery:y,beforeQueryFooter:a,afterQueryFooter:l,beforeDelete:n,afterDelete:E,beforeSave:R,afterSave:w,ajax:P={}}=_,F=_.response||_.props||{},T=$.value;if(T){let g=A(),d=null,c=null;c=_xeUtils.default.isString(t)?(o=r.buttons,r=e&&(0,_utils.isEnableConf)(r)&&o?_xeUtils.default.findTree(o,e=>e.code===t,{children:"dropdowns"}):null,d=r?r.item:null,t):(d=t).code;var o,k=d?d.params:null;switch(c){case"insert":return T.insert({});case"insert_edit":return T.insert({}).then(({row:e})=>T.setEditRow(e,!0));case"insert_actived":return T.insert({}).then(({row:e})=>T.setEditRow(e,!0));case"mark_cancel":O=c,I=B.value,U=$.value,(S=U?U.getCheckboxRecords():[]).length?(U&&U.togglePendingRow(S),z.clearCheckboxRow()):I&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:O,content:getI18n("vxe.grid.selectOneRecord"),status:"warning"});break;case"remove":return Y(c,"vxe.grid.removeSelectRecord",()=>T.removeCheckboxRow());case"import":T.importData(k);break;case"open_import":T.openImport(k);break;case"export":T.exportData(k);break;case"open_export":T.openExport(k);break;case"reset_custom":return T.resetCustom(!0);case"initial":case"reload":case"query":{var U=P.query;let n=P.querySuccess,o=P.queryError;if(U){var S="initial"===c,I="reload"===c;if(!S&&j.tableLoading)return(0,_vue.nextTick)();let e=null,r=[],a=[],t={};if(u&&((S||I)&&(f.currentPage=1),(0,_utils.isEnableConf)(h))&&(t=Object.assign({},f)),S){if(s&&(0,_utils.isEnableConf)(_)&&_.form&&(g=he(),j.formData=g),T){let{tableFullColumn:e,fullColumnFieldData:o}=T.internalData;var O=T.getComputeMaps().computeSortOpts;let t=O.value.defaultSort;e.forEach(e=>{e.order=null}),t&&(_xeUtils.default.isArray(t)||(t=[t]),r=t.map(e=>{var{field:e,order:t}=e,r=o[e];return r&&(r=r.column)&&(r.order=t),{field:e,property:e,order:t}})),a=T.getCheckedFilters()}}else T&&(I?e=T.clearAll():(r=T.getSortColumns(),a=T.getCheckedFilters()));let l={$table:T,$grid:z,$gantt:null,code:c,button:d,isInited:S,isReload:I,page:t,sort:r.length?r[0]:{},sorts:r,filters:a,form:g,options:U};return j.sortData=r,j.filterData=a,j.tableLoading=!0,Promise.all([Promise.resolve((C||U)(l,...v)),e]).then(([e])=>{let t=[];var r,o,a;return j.tableLoading=!1,e&&(r={data:e,$table:T,$grid:z,$gantt:null},u&&(0,_utils.isEnableConf)(h)?(a=F.total,a=(_xeUtils.default.isFunction(a)?a(r):_xeUtils.default.get(e,a||"page.total"))||0,f.total=_xeUtils.default.toNumber(a),o=F.result,t=(_xeUtils.default.isFunction(o)?o(r):_xeUtils.default.get(e,o||"result"))||[],o=Math.max(Math.ceil(a/f.pageSize),1),f.currentPage>o&&(f.currentPage=o)):(a=F.list,_xeUtils.default.isArray(e)?t=e:a&&(t=(_xeUtils.default.isFunction(a)?a(r):_xeUtils.default.get(e,a))||[])),i)&&(a=(o=F.footerData)?_xeUtils.default.isFunction(o)?o(r):_xeUtils.default.get(e,o):[],_xeUtils.default.isArray(a))&&(j.footerData=a),T?T.loadData(t):(0,_vue.nextTick)(()=>{var e=$.value;e&&e.loadData(t)}),y&&y(l,...v),n&&n(Object.assign(Object.assign({},l),{response:e})),{status:!0}}).catch(e=>(j.tableLoading=!1,o&&o(Object.assign(Object.assign({},l),{response:e})),{status:!1}))}(0,_log.errLog)("vxe.error.notFunc",["[grid] proxy-config.ajax.query"]);break}case"queryFooter":{var D=P.queryFooter;let r=P.queryFooterSuccess,o=P.queryFooterError;if(D){let e=[],t=(T&&(e=T.getCheckedFilters()),{$table:T,$grid:z,$gantt:null,code:c,button:d,filters:e,form:g,options:D});return Promise.resolve((a||D)(t,...v)).then(e=>(j.footerData=_xeUtils.default.isArray(e)?e:[],l&&l(t,...v),r&&r(Object.assign(Object.assign({},t),{response:e})),{status:!0})).catch(e=>(o&&o(Object.assign(Object.assign({},t),{response:e})),{status:!1}))}(0,_log.errLog)("vxe.error.notFunc",["[grid] proxy-config.ajax.queryFooter"]);break}case"delete":{let o=P.delete,a=P.deleteSuccess,l=P.deleteError;if(o){let e=z.getCheckboxRecords(),t=e.filter(e=>!T.isInsertByRow(e));D={removeRecords:t};let r={$table:T,$grid:z,$gantt:null,code:c,button:d,body:D,form:g,options:o};if(e.length)return Y(c,"vxe.grid.deleteSelectRecord",()=>t.length?(j.tableLoading=!0,Promise.resolve((n||o)(r,...v)).then(e=>(j.tableLoading=!1,T.setPendingRow(t,!1),b&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({content:H(e,"vxe.grid.delSuccess"),status:"success"}),E?E(r,...v):(M.uFoot=!0,z.commitProxy("query"),M.uFoot=!1,Z()),a&&a(Object.assign(Object.assign({},r),{response:e})),{status:!0})).catch(e=>(j.tableLoading=!1,b&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:c,content:H(e,"vxe.grid.operError"),status:"error"}),l&&l(Object.assign(Object.assign({},r),{response:e})),{status:!1}))):T.remove(e));x&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:c,content:getI18n("vxe.grid.selectOneRecord"),status:"warning"})}else(0,_log.errLog)("vxe.error.notFunc",["[grid] proxy-config.ajax.delete"]);break}case"save":{let i=P.save,s=P.saveSuccess,u=P.saveError;if(i){let t=T.getRecordset(),{insertRecords:r,removeRecords:o,updateRecords:a,pendingRecords:l}=t,n={$table:T,$grid:z,$gantt:null,code:c,button:d,body:t,form:g,options:i},e=(r.length&&(t.pendingRecords=l.filter(e=>-1===T.findRowIndexOf(r,e))),l.length&&(t.insertRecords=r.filter(e=>-1===T.findRowIndexOf(l,e))),Promise.resolve());return(e=m?T[p&&"full"===p.msgMode?"fullValidate":"validate"](t.insertRecords.concat(a)):e).then(e=>{if(!e)return t.insertRecords.length||o.length||a.length||t.pendingRecords.length?(j.tableLoading=!0,Promise.resolve((R||i)(n,...v)).then(e=>(j.tableLoading=!1,T.clearPendingRow(),b&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({content:H(e,"vxe.grid.saveSuccess"),status:"success"}),w?w(n,...v):(M.uFoot=!0,z.commitProxy("query"),M.uFoot=!1,Z()),s&&s(Object.assign(Object.assign({},n),{response:e})),{status:!0})).catch(e=>(j.tableLoading=!1,b&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:c,content:H(e,"vxe.grid.operError"),status:"error"}),u&&u(Object.assign(Object.assign({},n),{response:e})),{status:!1}))):void(x&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:c,content:getI18n("vxe.grid.dataUnchanged"),status:"info"}))})}(0,_log.errLog)("vxe.error.notFunc",["[grid] proxy-config.ajax.save"]);break}default:var D=commands.get(c);D&&((D=D.tableCommandMethod||D.commandMethod)?D({code:c,button:d,$grid:z,$table:T,$gantt:null},...v):(0,_log.errLog)("vxe.error.notCommands",["[grid] "+c]))}}return(0,_vue.nextTick)()},getParams(){return c.params},zoom(){return j.isZMax?z.revert():z.maximize()},isMaximized(){return j.isZMax},maximize(){return ue(!0)},revert(){return ue()},getFormData:A,getFormItems(e){var t=_.value,r=c.formConfig,o=t.items;let a=[];return _xeUtils.default.eachTree(r&&(0,_utils.isEnableConf)(t)&&o?o:[],e=>{a.push(e)},{children:"children"}),_xeUtils.default.isUndefined(e)?a:a[e]},resetForm(){var e=i.value;return e?e.reset():(0,_vue.nextTick)()},validateForm(){var e=i.value;return e?e.validate():(0,_vue.nextTick)()},validateFormField(e){var t=i.value;return t?t.validateField(e):(0,_vue.nextTick)()},clearFormValidate(e){var t=i.value;return t?t.clearValidate(e):(0,_vue.nextTick)()},homePage(){var e=j.tablePage;return e.currentPage=1,(0,_vue.nextTick)()},homePageByEvent(e){var t=s.value;t&&t.homePageByEvent(e)},endPage(){var e=j.tablePage,t=D.value;return e.currentPage=t,(0,_vue.nextTick)()},endPageByEvent(e){var t=s.value;t&&t.endPageByEvent(e)},getCurrentPage(){var e=j.tablePage;return e.currentPage},setCurrentPage(e){var t=j.tablePage,r=D.value;return t.currentPage=Math.min(r,Math.max(1,_xeUtils.default.toNumber(e))),(0,_vue.nextTick)()},setCurrentPageByEvent(e,t){var r=s.value;r&&r.setCurrentPageByEvent(e,t)},getPageSize(){var e=j.tablePage;return e.pageSize},setPageSize(e){var t=j.tablePage;return t.pageSize=Math.max(1,_xeUtils.default.toNumber(e)),(0,_vue.nextTick)()},setPageSizeByEvent(e,t){var r=s.value;r&&r.setPageSizeByEvent(e,t)},getProxyInfo(){var e,t=$.value;return c.proxyConfig?(e=j.sortData,{data:t?t.getFullData():[],filter:j.filterData,form:A(),sort:e.length?e[0]:{},sorts:e,pager:j.tablePage,pendingRecords:t?t.getPendingRecords():[]}):null}};let Re={extendTableMethods:r,callSlot(e,t){return e&&(_xeUtils.default.isString(e)&&(e=d[e]||null),_xeUtils.default.isFunction(e))?(0,_vn.getSlotVNs)(e(t)):[]},getExcludeHeight(){var t=c.height,r=j.isZMax,o=g.value;if(o){var a=m.value,l=p.value,n=f.value,i=x.value,s=b.value,u=o.parentElement;let e=0;return(e=!u||"100%"!==t&&"auto"!==t?e:r?0:(0,_dom.getPaddingTopBottomSize)(u))+(0,_dom.getPaddingTopBottomSize)(o)+(0,_dom.getOffsetHeight)(a)+(0,_dom.getOffsetHeight)(l)+(0,_dom.getOffsetHeight)(n)+(0,_dom.getOffsetHeight)(i)+(0,_dom.getOffsetHeight)(s)}return 0},getParentHeight(){var e=g.value;return e?(e=e.parentElement,(j.isZMax?(0,_dom.getDomNode)().visibleHeight:e?_xeUtils.default.toNumber(getComputedStyle(e).height):0)-Re.getExcludeHeight()):0},triggerToolbarCommitEvent(e,t){let r=e.code;var o;return r?((o=["reload","delete","save"].includes(r))&&(M.uFoot=!0),e=z.commitProxy(e,t).then(e=>{e&&e.status&&["query","reload","delete","save"].includes(r)&&z.dispatchEvent("delete"===r||"save"===r?"proxy-"+r:"proxy-query",Object.assign(Object.assign({},e),{isReload:"reload"===r}),t)}),M.uFoot=!1,o&&Z(),e):(0,_vue.nextTick)()},triggerToolbarBtnEvent(e,t){z.triggerToolbarCommitEvent(e,t),z.dispatchEvent("toolbar-button-click",{code:e.code,button:e},t)},triggerToolbarTolEvent(e,t){z.triggerToolbarCommitEvent(e,t),z.dispatchEvent("toolbar-tool-click",{code:e.code,tool:e},t)},triggerZoomEvent(e){z.zoom(),z.dispatchEvent("zoom",{type:j.isZMax?"max":"revert"},e)}};Object.assign(z,a,t,Re,{loadColumn(e){var t=$.value;return _xeUtils.default.eachTree(e,e=>{e.slots&&_xeUtils.default.each(e.slots,e=>{_xeUtils.default.isFunction(e)||d[e]||(0,_log.errLog)("vxe.error.notSlot",["[grid] "+e])})}),t?t.loadColumn(e):(0,_vue.nextTick)()},reloadColumn(e){return z.clearAll(),z.loadColumn(e)}});let R=(0,_vue.ref)(0);return(0,_vue.watch)(()=>c.columns?c.columns.length:-1,()=>{R.value++}),(0,_vue.watch)(()=>c.columns,()=>{R.value++}),(0,_vue.watch)(R,()=>{(0,_vue.nextTick)(()=>z.loadColumn(c.columns||[]))}),(0,_vue.watch)(()=>c.toolbarConfig,()=>{W()}),(0,_vue.watch)(S,()=>{C("currentPage")}),(0,_vue.watch)(I,()=>{C("pageSize")}),(0,_vue.watch)(O,()=>{C("total")}),(0,_vue.watch)(()=>c.proxyConfig,()=>{Ce()}),hooks.forEach(e=>{var e=e.setupGrid;e&&(e=e(z))&&_xeUtils.default.isObject(e)&&Object.assign(z,e)}),C(),(0,_vue.onMounted)(()=>{(0,_vue.nextTick)(()=>{var e=c.columns,t=q.value;c.formConfig&&!n&&(0,_log.errLog)("vxe.error.reqComp",["vxe-form"]),c.pagerConfig&&!l&&(0,_log.errLog)("vxe.error.reqComp",["vxe-pager"]),t.props&&(0,_log.warnLog)("vxe.error.delProp",["[grid] proxy-config.props","proxy-config.response"]),e&&e.length&&z.loadColumn(e),W(),Ce()}),globalEvents.on(z,"keydown",ye)}),(0,_vue.onBeforeUnmount)(()=>{globalEvents.off(z,"keydown"),_xeUtils.default.assign(j,createReactData()),_xeUtils.default.assign(M,createInternalData())}),z.renderVN=()=>{var e=P.value,t=F.value,r=G.value;return(0,_vue.h)("div",{ref:g,class:["vxe-grid",{["size--"+e]:e,"is--animat":!!c.animat,"is--round":c.round,"is--maximize":j.isZMax,"is--loading":r}],style:t},(()=>{var{headKeys:e,bodyKeys:t,footKeys:r}=U.value,o=d.asideLeft||d["aside-left"],a=d.asideRight||d["aside-right"];return[(0,_vue.h)("div",{class:"vxe-grid--layout-header-wrapper"},E(e)),(0,_vue.h)("div",{class:"vxe-grid--layout-body-wrapper"},[o?(0,_vue.h)("div",{class:"vxe-grid--layout-aside-left-wrapper"},o({})):renderEmptyElement(z),(0,_vue.h)("div",{class:"vxe-grid--layout-body-content-wrapper"},E(t)),a?(0,_vue.h)("div",{class:"vxe-grid--layout-aside-right-wrapper"},a({})):renderEmptyElement(z)]),(0,_vue.h)("div",{class:"vxe-grid--layout-footer-wrapper"},E(r)),(0,_vue.h)("div",{ref:v})]})())},(0,_vue.provide)("$xeGrid",z),(0,_vue.provide)("$xeGantt",null),z},render(){return this.renderVN()}});
1
+ Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _vue=require("vue"),_comp=require("../../ui/src/comp"),_xeUtils=_interopRequireDefault(require("xe-utils")),_utils=require("../../ui/src/utils"),_dom=require("../../ui/src/dom"),_ui=require("../../ui"),_props=require("./props"),_emits=require("./emits"),_vn=require("../../ui/src/vn"),_log=require("../../ui/src/log"),_emits2=require("../../table/src/emits"),_props2=require("../../table/src/props"),_table=_interopRequireDefault(require("../../table/src/table")),_toolbar=_interopRequireDefault(require("../../toolbar/src/toolbar"));function _interopRequireDefault(e){return e&&e.__esModule?e:{default:e}}let{getConfig,getI18n,commands,hooks,useFns,createEvent,globalEvents,GLOBAL_EVENT_KEYS,renderEmptyElement}=_ui.VxeUI,tableComponentPropKeys=Object.keys(_props2.tableProps),tableComponentMethodKeys=["clearAll","syncData","updateData","loadData","reloadData","reloadRow","loadColumn","reloadColumn","getRowNode","getColumnNode","getRowIndex","getVTRowIndex","getVMRowIndex","getColumnIndex","getVTColumnIndex","getVMColumnIndex","setRow","createData","createRow","revertData","clearData","isRemoveByRow","isInsertByRow","isUpdateByRow","getColumns","getColumnById","getColumnByField","getTableColumn","getFullColumns","getData","getCheckboxRecords","getParentRow","getTreeRowChildren","getTreeRowLevel","getTreeParentRow","getRowSeq","getRowById","getRowid","getTableData","getFullData","setColumnFixed","clearColumnFixed","setColumnWidth","getColumnWidth","recalcRowHeight","setRowHeightConf","getRowHeightConf","setRowHeight","getRowHeight","hideColumn","showColumn","resetColumn","refreshColumn","refreshScroll","recalculate","closeTooltip","isAllCheckboxChecked","isAllCheckboxIndeterminate","getCheckboxIndeterminateRecords","setCheckboxRow","setCheckboxRowKey","isCheckedByCheckboxRow","isCheckedByCheckboxRowKey","isIndeterminateByCheckboxRow","isIndeterminateByCheckboxRowKey","toggleCheckboxRow","setAllCheckboxRow","getRadioReserveRecord","clearRadioReserve","getCheckboxReserveRecords","clearCheckboxReserve","toggleAllCheckboxRow","clearCheckboxRow","setCurrentRow","isCheckedByRadioRow","isCheckedByRadioRowKey","setRadioRow","setRadioRowKey","clearCurrentRow","clearRadioRow","getCurrentRecord","getRadioRecord","getCurrentColumn","setCurrentColumn","clearCurrentColumn","setPendingRow","togglePendingRow","hasPendingByRow","isPendingByRow","getPendingRecords","clearPendingRow","setFilterByEvent","sort","setSort","setSortByEvent","clearSort","clearSortByEvent","isSort","getSortColumns","closeFilter","isFilter","clearFilterByEvent","isActiveFilterByColumn","isRowExpandLoaded","clearRowExpandLoaded","reloadRowExpand","reloadRowExpand","toggleRowExpand","setAllRowExpand","setRowExpand","isExpandByRow","isRowExpandByRow","clearRowExpand","clearRowExpandReserve","getRowExpandRecords","getTreeExpandRecords","isTreeExpandLoaded","clearTreeExpandLoaded","reloadTreeExpand","reloadTreeChilds","toggleTreeExpand","setAllTreeExpand","setTreeExpand","isTreeExpandByRow","clearTreeExpand","clearTreeExpandReserve","getScroll","getScrollData","scrollTo","scrollToStartRow","scrollToEndRow","scrollToRow","scrollToStartColumn","scrollToEndColumn","scrollToColumn","clearScroll","updateFooter","updateStatus","setMergeCells","removeInsertRow","removeMergeCells","getMergeCells","setMergeHeaderCells","removeMergeHeaderCells","getMergeHeaderCells","clearMergeHeaderCells","clearMergeCells","setMergeFooterItems","removeMergeFooterItems","getMergeFooterItems","clearMergeFooterItems","setCustomStoreData","getCustomStoreData","setRowGroupExpand","setRowGroupExpandByField","setAllRowGroupExpand","clearRowGroupExpand","isRowGroupExpandByRow","isRowGroupRecord","isAggregateRecord","isAggregateExpandByRow","getAggregateContentByRow","getAggregateRowChildren","setRowGroups","clearRowGroups","openTooltip","moveColumnTo","moveRowTo","getCellLabel","updateCellLabel","clearFormatterCache","getFooterCellLabel","updateFooterCellLabel","clearFooterFormatterCache","undo","redo","effectCellData","getCellElement","focus","blur","connect","connectToolbar"];function createReactData(){var e;return{tableLoading:!1,proxyInited:!1,isZMax:!1,tableData:[],filterData:[],formData:{},sortData:[],footerData:[],tZindex:0,tablePage:{total:0,pageSize:(null==(e=getConfig().pager)?void 0:e.pageSize)||10,currentPage:1}}}function createInternalData(){return{uFoot:!1}}var _default=exports.default=(0,_comp.defineVxeComponent)({name:"VxeGrid",props:_props.gridProps,emits:_emits.gridEmits,setup(c,e){let{slots:d,emit:o}=e;var t=_xeUtils.default.uniqueId();let n=_ui.VxeUI.getComponent("VxeForm"),l=_ui.VxeUI.getComponent("VxePager"),w=[["Form"],["Toolbar","Top","Table","Bottom","Pager"]],P=useFns.useSize(c).computeSize,j=(0,_vue.reactive)(createReactData()),M=createInternalData(),g=(0,_vue.ref)(),$=(0,_vue.ref)(),i=(0,_vue.ref)(),u=(0,_vue.ref)(),s=(0,_vue.ref)(),v=(0,_vue.ref)(),m=(0,_vue.ref)(),p=(0,_vue.ref)(),f=(0,_vue.ref)(),x=(0,_vue.ref)(),b=(0,_vue.ref)();var r=e=>{let t={};return e.forEach(r=>{t[r]=(...e)=>{var t=$.value;if(t&&t[r])return t[r](...e)}}),t};let a=r(tableComponentMethodKeys),q=(tableComponentMethodKeys.forEach(r=>{a[r]=(...e)=>{var t=$.value;if(t&&t[r])return t&&t[r](...e)}}),(0,_vue.computed)(()=>_xeUtils.default.merge({},_xeUtils.default.clone(getConfig().grid.proxyConfig,!0),c.proxyConfig))),K=(0,_vue.computed)(()=>{var e=q.value;return!!(_xeUtils.default.isBoolean(e.message)?e.message:e.showResponseMsg)}),B=(0,_vue.computed)(()=>{var e=q.value;return _xeUtils.default.isBoolean(e.showActionMsg)?e.showActionMsg:!!e.showActiveMsg}),L=(0,_vue.computed)(()=>Object.assign({},getConfig().grid.pagerConfig,c.pagerConfig)),_=(0,_vue.computed)(()=>Object.assign({},getConfig().grid.formConfig,c.formConfig)),V=(0,_vue.computed)(()=>Object.assign({},getConfig().grid.toolbarConfig,c.toolbarConfig)),h=(0,_vue.computed)(()=>Object.assign({},getConfig().grid.zoomConfig,c.zoomConfig)),F=(0,_vue.computed)(()=>{var{height:e,maxHeight:t}=c,{isZMax:r,tZindex:o}=j,a={};return r?a.zIndex=o:(e&&(a.height="auto"===e||"100%"===e?"100%":(0,_dom.toCssUnit)(e)),t&&(a.maxHeight="auto"===t||"100%"===t?"100%":(0,_dom.toCssUnit)(t))),a}),T=(0,_vue.computed)(()=>{let t={};return tableComponentPropKeys.forEach(e=>{void 0!==c[e]&&(t[e]=c[e])}),t}),k=(0,_vue.computed)(()=>{var{showFooter:e,seqConfig:t,pagerConfig:r,editConfig:o,proxyConfig:a}=c,{isZMax:l,tablePage:n,footerData:i}=j,s=T.value,u=q.value,g=L.value,d=G.value,s=Object.assign({},s);return(e&&!s.footerData||u.footer&&i.length)&&(s.footerData=i),l&&(s.maxHeight?s.maxHeight="100%":s.height="100%"),a&&(0,_utils.isEnableConf)(u)&&(s.loading=d,r)&&u.seq&&(0,_utils.isEnableConf)(g)&&(s.seqConfig=Object.assign({},t,{startIndex:(n.currentPage-1)*n.pageSize})),o&&(s.editConfig=Object.assign({},o)),s}),U=(0,_vue.computed)(()=>{var e=c.layouts;let t=[],r=[],o=[],a=[];return(t=e&&e.length?e:getConfig().grid.layouts||w).length&&(_xeUtils.default.isArray(t[0])?(r=t[0],o=t[1]||[],a=t[2]||[]):o=t),{headKeys:r,bodyKeys:o,footKeys:a}});var S=(0,_vue.computed)(()=>L.value.currentPage),I=(0,_vue.computed)(()=>L.value.pageSize),O=(0,_vue.computed)(()=>L.value.total);let D=(0,_vue.computed)(()=>{var e=j.tablePage;return Math.max(Math.ceil(e.total/e.pageSize),1)}),G=(0,_vue.computed)(()=>{var{loading:e,proxyConfig:t}=c,r=j.tableLoading,o=q.value,a=o.showLoading;return e||r&&a&&t&&(0,_utils.isEnableConf)(o)}),N={refElem:g,refTable:$,refForm:i,refToolbar:u,refPager:s,refPopupContainerElem:v},Q={computeProxyOpts:q,computePagerOpts:L,computeFormOpts:_,computeToolbarOpts:V,computeZoomOpts:h},z={xID:t,props:c,context:e,reactData:j,internalData:M,getRefMaps:()=>N,getComputeMaps:()=>Q},W=()=>{var e=V.value;c.toolbarConfig&&(0,_utils.isEnableConf)(e)&&(0,_vue.nextTick)(()=>{var e=$.value,t=u.value;e&&t&&e.connectToolbar(t)})},A=()=>{var e=c.proxyConfig,t=j.formData,r=q.value,o=_.value;return e&&(0,_utils.isEnableConf)(r)&&r.form?t:o.data},C=e=>{var t=j.tablePage,r=c.pagerConfig,o=L.value;r&&(0,_utils.isEnableConf)(o)&&(e?o[e]&&(t[e]=_xeUtils.default.toNumber(o[e])):({currentPage:r,pageSize:e,total:o}=o,r&&(t.currentPage=r),e&&(t.pageSize=e),o&&(t.total=o)))},H=(e,t)=>{var r=q.value,r=(r.response||r.props||{}).message,o=$.value;let a;return(a=e&&r?_xeUtils.default.isFunction(r)?r({data:e,$table:o,$grid:z,$gantt:null}):_xeUtils.default.get(e,r):a)||getI18n(t)},Y=(e,t,r)=>{var o=B.value,a=z.getCheckboxRecords();if(o)if(a.length){if(_ui.VxeUI.modal)return _ui.VxeUI.modal.confirm({id:"cfm_"+e,content:getI18n(t),escClosable:!0}).then(e=>{if("confirm"===e)return r()})}else _ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:"msg_"+e,content:getI18n("vxe.grid.selectOneRecord"),status:"warning"});else a.length&&r();return Promise.resolve()},J=e=>{var t=c.proxyConfig,r=j.tablePage;let{$event:o,currentPage:a,pageSize:l}=e;var n=q.value;r.currentPage=a,r.pageSize=l,z.dispatchEvent("page-change",e,o),t&&(0,_utils.isEnableConf)(n)&&z.commitProxy("query").then(e=>{z.dispatchEvent("proxy-query",e,o)})},X=t=>{var e,r=$.value,o=c.proxyConfig;r&&(r=r.getComputeMaps().computeSortOpts,e=q.value,r.value.remote)&&(j.sortData=t.sortList,o)&&(0,_utils.isEnableConf)(e)&&(j.tablePage.currentPage=1,z.commitProxy("query").then(e=>{z.dispatchEvent("proxy-query",e,t.$event)}))},ee=e=>{X(e),z.dispatchEvent("sort-change",e,e.$event)},te=e=>{X(e),z.dispatchEvent("clear-all-sort",e,e.$event)},re=t=>{var e,r=$.value,o=c.proxyConfig;r&&(r=r.getComputeMaps().computeFilterOpts,e=q.value,r.value.remote)&&(j.filterData=t.filterList,o)&&(0,_utils.isEnableConf)(e)&&(j.tablePage.currentPage=1,M.uFoot=!0,z.commitProxy("query").then(e=>{z.dispatchEvent("proxy-query",e,t.$event)}),M.uFoot=!1,Z())},oe=e=>{re(e),z.dispatchEvent("filter-change",e,e.$event)},ae=e=>{re(e),z.dispatchEvent("clear-all-filter",e,e.$event)},le=t=>{var e=c.proxyConfig,r=q.value;j.tableLoading||(e&&(0,_utils.isEnableConf)(r)&&(M.uFoot=!0,z.commitProxy("reload").then(e=>{z.dispatchEvent("proxy-query",Object.assign(Object.assign({},e),{isReload:!0}),t.$event)}),M.uFoot=!1,Z()),z.dispatchEvent("form-submit",t,t.$event))},ne=e=>{var t=$.value,r=c.proxyConfig;let o=e.$event;var a=q.value;r&&(0,_utils.isEnableConf)(a)&&(t&&t.clearScroll(),M.uFoot=!0,z.commitProxy("reload").then(e=>{z.dispatchEvent("proxy-query",Object.assign(Object.assign({},e),{isReload:!0}),o)}),M.uFoot=!1,Z()),z.dispatchEvent("form-reset",e,o)},ie=e=>{z.dispatchEvent("form-submit-invalid",e,e.$event)},se=e=>{var t=e.$event;z.dispatchEvent("form-toggle-collapse",e,t),z.dispatchEvent("form-collapse",e,t)},ue=e=>{var t=j.isZMax;return(e?!t:t)&&(j.isZMax=!t,j.tZindex<(0,_utils.getLastZIndex)())&&(j.tZindex=(0,_utils.nextZIndex)()),(0,_vue.nextTick)().then(()=>z.recalculate(!0)).then(()=>(setTimeout(()=>z.recalculate(!0),15),j.isZMax))},y=(e,t)=>{e=e[t];if(e){if(!_xeUtils.default.isString(e))return e;if(d[e])return d[e];(0,_log.errLog)("vxe.error.notSlot",["[grid] "+e])}return null},ge=e=>{let r={};return _xeUtils.default.objectMap(e,(e,t)=>{e&&(_xeUtils.default.isString(e)?d[e]?r[t]=d[e]:(0,_log.errLog)("vxe.error.notSlot",["[grid] "+e]):r[t]=e)}),r},de=()=>{var{formConfig:e,proxyConfig:r}=c,o=j.formData,a=q.value,l=_.value;if(e&&(0,_utils.isEnableConf)(l)||d.form){let e=[];if(d.form)e=d.form({$grid:z,$gantt:null});else if(l.items){let t={};if(!l.inited){l.inited=!0;let t=a.beforeItem;a&&t&&l.items.forEach(e=>{t({$grid:z,$gantt:null,item:e})})}l.items.forEach(e=>{_xeUtils.default.each(e.slots,e=>{_xeUtils.default.isFunction(e)||d[e]&&(t[e]=d[e])})}),n&&e.push((0,_vue.h)(n,Object.assign(Object.assign({ref:i},Object.assign({},l,{data:r&&(0,_utils.isEnableConf)(a)&&a.form?o:l.data})),{onSubmit:le,onReset:ne,onSubmitInvalid:ie,onCollapse:se}),t))}return(0,_vue.h)("div",{ref:m,key:"form",class:"vxe-grid--form-wrapper"},e)}return renderEmptyElement(z)},ce=()=>{var t,r,o,a,l,n=c.toolbarConfig,i=V.value,s=d.toolbar;if(n&&(0,_utils.isEnableConf)(i)||s){let e=[];return s?e=s({$grid:z,$gantt:null}):(n={},(s=i.slots)&&(t=y(s,"buttons"),r=y(s,"buttonPrefix"),o=y(s,"buttonSuffix"),a=y(s,"tools"),l=y(s,"toolPrefix"),s=y(s,"toolSuffix"),t&&(n.buttons=t),r&&(n.buttonPrefix=r),o&&(n.buttonSuffix=o),a&&(n.tools=a),l&&(n.toolPrefix=l),s)&&(n.toolSuffix=s),e.push((0,_vue.h)(_toolbar.default,Object.assign(Object.assign({ref:u},i),{slots:void 0}),n))),(0,_vue.h)("div",{ref:p,key:"toolbar",class:"vxe-grid--toolbar-wrapper"},e)}return renderEmptyElement(z)},ve=()=>{var e=d.top;return e?(0,_vue.h)("div",{ref:f,key:"top",class:"vxe-grid--top-wrapper"},e({$grid:z,$gantt:null})):renderEmptyElement(z)},me=()=>{var e=d.left;return e?(0,_vue.h)("div",{class:"vxe-grid--left-wrapper"},e({$grid:z,$gantt:null})):renderEmptyElement(z)},pe=()=>{var e=d.right;return e?(0,_vue.h)("div",{class:"vxe-grid--right-wrapper"},e({$grid:z,$gantt:null})):renderEmptyElement(z)},fe=()=>{var e=c.proxyConfig,t=k.value,r=q.value,o=Object.assign({},_e),a=d.empty,l=d.loading,n=d.rowDragIcon||d["row-drag-icon"],i=d.columnDragIcon||d["column-drag-icon"],s=d.headerTooltip||d["header-tooltip"],u=d.tooltip,g=d.footerTooltip||d["footer-tooltip"],e=(e&&(0,_utils.isEnableConf)(r)&&(r.sort&&(o.onSortChange=ee,o.onClearAllSort=te),r.filter)&&(o.onFilterChange=oe,o.onClearAllFilter=ae),{});return a&&(e.empty=a),l&&(e.loading=l),n&&(e.rowDragIcon=n),i&&(e.columnDragIcon=i),s&&(e.headerTooltip=s),u&&(e.tooltip=u),g&&(e.footerTooltip=g),(0,_vue.h)("div",{class:"vxe-grid--table-wrapper"},[(0,_vue.h)(_table.default,Object.assign(Object.assign({ref:$},t),o),e)])},xe=()=>d.bottom?(0,_vue.h)("div",{ref:x,key:"bottom",class:"vxe-grid--bottom-wrapper"},d.bottom({$grid:z,$gantt:null})):renderEmptyElement(z),be=()=>{var{proxyConfig:e,pagerConfig:t}=c,r=q.value,o=L.value,a=d.pager;return t&&(0,_utils.isEnableConf)(o)||d.pager?(0,_vue.h)("div",{ref:b,key:"pager",class:"vxe-grid--pager-wrapper"},a?a({$grid:z,$gantt:null}):[l?(0,_vue.h)(l,Object.assign(Object.assign(Object.assign({ref:s},o),e&&(0,_utils.isEnableConf)(r)?j.tablePage:{}),{onPageChange:J}),ge(o.slots)):renderEmptyElement(z)]):renderEmptyElement(z)},E=e=>{let t=[];return e.forEach(e=>{switch(e){case"Form":t.push(de());break;case"Toolbar":t.push(ce());break;case"Top":t.push(ve());break;case"Table":t.push((0,_vue.h)("div",{key:"table",class:"vxe-grid--table-container"},[me(),fe(),pe()]));break;case"Bottom":t.push(xe());break;case"Pager":t.push(be());break;default:(0,_log.errLog)("vxe.error.notProp",["[grid] layouts -> "+e])}}),t},_e={},he=(_emits2.tableEmits.forEach(t=>{var e=_xeUtils.default.camelCase("on-"+t);_e[e]=(...e)=>o(t,...e)}),()=>{var e=_.value;if(e.items){let n={};return e.items.forEach(t=>{var r,o,{field:a,itemRender:l}=t;if(a){let e=null;l&&({startField:l,endField:r,defaultValue:o}=l,_xeUtils.default.isFunction(o)?e=o({item:t}):_xeUtils.default.isUndefined(o)||(e=o),l)&&r&&(_xeUtils.default.set(n,l,null),_xeUtils.default.set(n,r,null)),n[a]=e}}),n}return{}}),Ce=()=>{var{proxyConfig:e,formConfig:t}=c,r=j.proxyInited,o=q.value,a=_.value;e&&(0,_utils.isEnableConf)(o)&&(t&&(0,_utils.isEnableConf)(a)&&o.form&&a.items&&(j.formData=he()),r||!(j.proxyInited=!0)!==o.autoLoad&&(0,_vue.nextTick)().then(()=>{M.uFoot=!0;var e=z.commitProxy("initial");return M.uFoot=!1,Z(),e}).then(e=>{Ee("proxy-query",Object.assign(Object.assign({},e),{isInited:!0}),new Event("initial"))}))},Z=()=>{var e=q.value.ajax;if(e&&e.queryFooter)return z.commitProxy("queryFooter")},ye=e=>{var t=h.value;globalEvents.hasKey(e,GLOBAL_EVENT_KEYS.ESCAPE)&&j.isZMax&&!1!==t.escRestore&&z.triggerZoomEvent(e)},Ee=(e,t,r)=>{o(e,createEvent(r,{$grid:z,$gantt:null},t))};t={dispatchEvent:Ee,getEl(){return g.value},commitProxy(t,...v){let{showFooter:i,proxyConfig:s,toolbarConfig:e,pagerConfig:u,editRules:m,validConfig:p}=c,f=j.tablePage,x=B.value,b=K.value;var _=q.value;let h=L.value;var r=V.value;let{beforeQuery:C,afterQuery:y,beforeQueryFooter:a,afterQueryFooter:l,beforeDelete:n,afterDelete:E,beforeSave:R,afterSave:w,ajax:P={}}=_,F=_.response||_.props||{},T=$.value;if(T){let g=A(),d=null,c=null;c=_xeUtils.default.isString(t)?(o=r.buttons,r=e&&(0,_utils.isEnableConf)(r)&&o?_xeUtils.default.findTree(o,e=>e.code===t,{children:"dropdowns"}):null,d=r?r.item:null,t):(d=t).code;var o,k=d?d.params:null;switch(c){case"insert":return T.insert({});case"insert_edit":return T.insert({}).then(({row:e})=>T.setEditRow(e,!0));case"insert_actived":return T.insert({}).then(({row:e})=>T.setEditRow(e,!0));case"mark_cancel":O=c,I=B.value,U=$.value,(S=U?U.getCheckboxRecords():[]).length?(U&&U.togglePendingRow(S),z.clearCheckboxRow()):I&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:O,content:getI18n("vxe.grid.selectOneRecord"),status:"warning"});break;case"remove":return Y(c,"vxe.grid.removeSelectRecord",()=>T.removeCheckboxRow());case"import":T.importData(k);break;case"open_import":T.openImport(k);break;case"export":T.exportData(k);break;case"open_export":T.openExport(k);break;case"reset_custom":return T.resetCustom(!0);case"initial":case"reload":case"query":{var U=P.query;let n=P.querySuccess,o=P.queryError;if(U){var S="initial"===c,I="reload"===c;if(!S&&j.tableLoading)return(0,_vue.nextTick)();let e=null,r=[],a=[],t={};if(u&&((S||I)&&(f.currentPage=1),(0,_utils.isEnableConf)(h))&&(t=Object.assign({},f)),S){if(s&&(0,_utils.isEnableConf)(_)&&_.form&&(g=he(),j.formData=g),T){let{tableFullColumn:e,fullColumnFieldData:o}=T.internalData;var O=T.getComputeMaps().computeSortOpts;let t=O.value.defaultSort;e.forEach(e=>{e.order=null}),t&&(_xeUtils.default.isArray(t)||(t=[t]),r=t.map(e=>{var{field:e,order:t}=e,r=o[e];return r&&(r=r.column)&&(r.order=t),{field:e,property:e,order:t}})),a=T.getCheckedFilters()}}else T&&(I?e=T.clearAll():(r=T.getSortColumns(),a=T.getCheckedFilters()));let l={$table:T,$grid:z,$gantt:null,code:c,button:d,isInited:S,isReload:I,page:t,sort:r.length?r[0]:{},sorts:r,filters:a,form:g,options:U};return j.sortData=r,j.filterData=a,j.tableLoading=!0,Promise.all([Promise.resolve((C||U)(l,...v)),e]).then(([e])=>{let t=[];var r,o,a;return j.tableLoading=!1,e&&(r={data:e,$table:T,$grid:z,$gantt:null},u&&(0,_utils.isEnableConf)(h)?(a=F.total,a=(_xeUtils.default.isFunction(a)?a(r):_xeUtils.default.get(e,a||"page.total"))||0,f.total=_xeUtils.default.toNumber(a),o=F.result,t=(_xeUtils.default.isFunction(o)?o(r):_xeUtils.default.get(e,o||"result"))||[],o=Math.max(Math.ceil(a/f.pageSize),1),f.currentPage>o&&(f.currentPage=o)):(a=F.list,_xeUtils.default.isArray(e)?t=e:a&&(t=(_xeUtils.default.isFunction(a)?a(r):_xeUtils.default.get(e,a))||[])),i)&&(a=(o=F.footerData)?_xeUtils.default.isFunction(o)?o(r):_xeUtils.default.get(e,o):[],_xeUtils.default.isArray(a))&&(j.footerData=a),T?T.loadData(t):(0,_vue.nextTick)(()=>{var e=$.value;e&&e.loadData(t)}),y&&y(l,...v),n&&n(Object.assign(Object.assign({},l),{response:e})),{status:!0}}).catch(e=>(j.tableLoading=!1,o&&o(Object.assign(Object.assign({},l),{response:e})),{status:!1}))}(0,_log.errLog)("vxe.error.notFunc",["[grid] proxy-config.ajax.query"]);break}case"queryFooter":{var D=P.queryFooter;let r=P.queryFooterSuccess,o=P.queryFooterError;if(D){let e=[],t=(T&&(e=T.getCheckedFilters()),{$table:T,$grid:z,$gantt:null,code:c,button:d,filters:e,form:g,options:D});return Promise.resolve((a||D)(t,...v)).then(e=>(j.footerData=_xeUtils.default.isArray(e)?e:[],l&&l(t,...v),r&&r(Object.assign(Object.assign({},t),{response:e})),{status:!0})).catch(e=>(o&&o(Object.assign(Object.assign({},t),{response:e})),{status:!1}))}(0,_log.errLog)("vxe.error.notFunc",["[grid] proxy-config.ajax.queryFooter"]);break}case"delete":{let o=P.delete,a=P.deleteSuccess,l=P.deleteError;if(o){let e=z.getCheckboxRecords(),t=e.filter(e=>!T.isInsertByRow(e));D={removeRecords:t};let r={$table:T,$grid:z,$gantt:null,code:c,button:d,body:D,form:g,options:o};if(e.length)return Y(c,"vxe.grid.deleteSelectRecord",()=>t.length?(j.tableLoading=!0,Promise.resolve((n||o)(r,...v)).then(e=>(j.tableLoading=!1,T.setPendingRow(t,!1),b&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({content:H(e,"vxe.grid.delSuccess"),status:"success"}),E?E(r,...v):(M.uFoot=!0,z.commitProxy("query"),M.uFoot=!1,Z()),a&&a(Object.assign(Object.assign({},r),{response:e})),{status:!0})).catch(e=>(j.tableLoading=!1,b&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:c,content:H(e,"vxe.grid.operError"),status:"error"}),l&&l(Object.assign(Object.assign({},r),{response:e})),{status:!1}))):T.remove(e));x&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:c,content:getI18n("vxe.grid.selectOneRecord"),status:"warning"})}else(0,_log.errLog)("vxe.error.notFunc",["[grid] proxy-config.ajax.delete"]);break}case"save":{let i=P.save,s=P.saveSuccess,u=P.saveError;if(i){let t=T.getRecordset(),{insertRecords:r,removeRecords:o,updateRecords:a,pendingRecords:l}=t,n={$table:T,$grid:z,$gantt:null,code:c,button:d,body:t,form:g,options:i},e=(r.length&&(t.pendingRecords=l.filter(e=>-1===T.findRowIndexOf(r,e))),l.length&&(t.insertRecords=r.filter(e=>-1===T.findRowIndexOf(l,e))),Promise.resolve());return(e=m?T[p&&"full"===p.msgMode?"fullValidate":"validate"](t.insertRecords.concat(a)):e).then(e=>{if(!e)return t.insertRecords.length||o.length||a.length||t.pendingRecords.length?(j.tableLoading=!0,Promise.resolve((R||i)(n,...v)).then(e=>(j.tableLoading=!1,T.clearPendingRow(),b&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({content:H(e,"vxe.grid.saveSuccess"),status:"success"}),w?w(n,...v):(M.uFoot=!0,z.commitProxy("query"),M.uFoot=!1,Z()),s&&s(Object.assign(Object.assign({},n),{response:e})),{status:!0})).catch(e=>(j.tableLoading=!1,b&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:c,content:H(e,"vxe.grid.operError"),status:"error"}),u&&u(Object.assign(Object.assign({},n),{response:e})),{status:!1}))):void(x&&_ui.VxeUI.modal&&_ui.VxeUI.modal.message({id:c,content:getI18n("vxe.grid.dataUnchanged"),status:"info"}))})}(0,_log.errLog)("vxe.error.notFunc",["[grid] proxy-config.ajax.save"]);break}default:var D=commands.get(c);D&&((D=D.tableCommandMethod||D.commandMethod)?D({code:c,button:d,$grid:z,$table:T,$gantt:null},...v):(0,_log.errLog)("vxe.error.notCommands",["[grid] "+c]))}}return(0,_vue.nextTick)()},getParams(){return c.params},zoom(){return j.isZMax?z.revert():z.maximize()},isMaximized(){return j.isZMax},maximize(){return ue(!0)},revert(){return ue()},getFormData:A,getFormItems(e){var t=_.value,r=c.formConfig,o=t.items;let a=[];return _xeUtils.default.eachTree(r&&(0,_utils.isEnableConf)(t)&&o?o:[],e=>{a.push(e)},{children:"children"}),_xeUtils.default.isUndefined(e)?a:a[e]},resetForm(){var e=i.value;return e?e.reset():(0,_vue.nextTick)()},validateForm(){var e=i.value;return e?e.validate():(0,_vue.nextTick)()},validateFormField(e){var t=i.value;return t?t.validateField(e):(0,_vue.nextTick)()},clearFormValidate(e){var t=i.value;return t?t.clearValidate(e):(0,_vue.nextTick)()},homePage(){var e=j.tablePage;return e.currentPage=1,(0,_vue.nextTick)()},homePageByEvent(e){var t=s.value;t&&t.homePageByEvent(e)},endPage(){var e=j.tablePage,t=D.value;return e.currentPage=t,(0,_vue.nextTick)()},endPageByEvent(e){var t=s.value;t&&t.endPageByEvent(e)},getCurrentPage(){var e=j.tablePage;return e.currentPage},setCurrentPage(e){var t=j.tablePage,r=D.value;return t.currentPage=Math.min(r,Math.max(1,_xeUtils.default.toNumber(e))),(0,_vue.nextTick)()},setCurrentPageByEvent(e,t){var r=s.value;r&&r.setCurrentPageByEvent(e,t)},getPageSize(){var e=j.tablePage;return e.pageSize},setPageSize(e){var t=j.tablePage;return t.pageSize=Math.max(1,_xeUtils.default.toNumber(e)),(0,_vue.nextTick)()},setPageSizeByEvent(e,t){var r=s.value;r&&r.setPageSizeByEvent(e,t)},getProxyInfo(){var e,t=$.value;return c.proxyConfig?(e=j.sortData,{data:t?t.getFullData():[],filter:j.filterData,form:A(),sort:e.length?e[0]:{},sorts:e,pager:j.tablePage,pendingRecords:t?t.getPendingRecords():[]}):null}};let Re={extendTableMethods:r,callSlot(e,t){return e&&(_xeUtils.default.isString(e)&&(e=d[e]||null),_xeUtils.default.isFunction(e))?(0,_vn.getSlotVNs)(e(t)):[]},getExcludeHeight(){var t=c.height,r=j.isZMax,o=g.value;if(o){var a=m.value,l=p.value,n=f.value,i=x.value,s=b.value,u=o.parentElement;let e=0;return(e=!u||"100%"!==t&&"auto"!==t?e:r?0:(0,_dom.getPaddingTopBottomSize)(u))+(0,_dom.getPaddingTopBottomSize)(o)+(0,_dom.getOffsetHeight)(a)+(0,_dom.getOffsetHeight)(l)+(0,_dom.getOffsetHeight)(n)+(0,_dom.getOffsetHeight)(i)+(0,_dom.getOffsetHeight)(s)}return 0},getParentHeight(){var e=g.value;return e?(e=e.parentElement,(j.isZMax?(0,_dom.getDomNode)().visibleHeight:e?_xeUtils.default.toNumber(getComputedStyle(e).height):0)-Re.getExcludeHeight()):0},triggerToolbarCommitEvent(e,t){let r=e.code;var o;return r?((o=["reload","delete","save"].includes(r))&&(M.uFoot=!0),e=z.commitProxy(e,t).then(e=>{e&&e.status&&["query","reload","delete","save"].includes(r)&&z.dispatchEvent("delete"===r||"save"===r?"proxy-"+r:"proxy-query",Object.assign(Object.assign({},e),{isReload:"reload"===r}),t)}),M.uFoot=!1,o&&Z(),e):(0,_vue.nextTick)()},triggerToolbarBtnEvent(e,t){z.triggerToolbarCommitEvent(e,t),z.dispatchEvent("toolbar-button-click",{code:e.code,button:e},t)},triggerToolbarTolEvent(e,t){z.triggerToolbarCommitEvent(e,t),z.dispatchEvent("toolbar-tool-click",{code:e.code,tool:e},t)},triggerZoomEvent(e){z.zoom(),z.dispatchEvent("zoom",{type:j.isZMax?"max":"revert"},e)}};Object.assign(z,a,t,Re,{loadColumn(e){var t=$.value;return _xeUtils.default.eachTree(e,e=>{e.slots&&_xeUtils.default.each(e.slots,e=>{_xeUtils.default.isFunction(e)||d[e]||(0,_log.errLog)("vxe.error.notSlot",["[grid] "+e])})}),t?t.loadColumn(e):(0,_vue.nextTick)()},reloadColumn(e){return z.clearAll(),z.loadColumn(e)}});let R=(0,_vue.ref)(0);return(0,_vue.watch)(()=>c.columns?c.columns.length:-1,()=>{R.value++}),(0,_vue.watch)(()=>c.columns,()=>{R.value++}),(0,_vue.watch)(R,()=>{(0,_vue.nextTick)(()=>z.loadColumn(c.columns||[]))}),(0,_vue.watch)(()=>c.toolbarConfig,()=>{W()}),(0,_vue.watch)(S,()=>{C("currentPage")}),(0,_vue.watch)(I,()=>{C("pageSize")}),(0,_vue.watch)(O,()=>{C("total")}),(0,_vue.watch)(()=>c.proxyConfig,()=>{Ce()}),hooks.forEach(e=>{var e=e.setupGrid;e&&(e=e(z))&&_xeUtils.default.isObject(e)&&Object.assign(z,e)}),C(),(0,_vue.onMounted)(()=>{(0,_vue.nextTick)(()=>{var e=c.columns,t=q.value;c.formConfig&&!n&&(0,_log.errLog)("vxe.error.reqComp",["vxe-form"]),c.pagerConfig&&!l&&(0,_log.errLog)("vxe.error.reqComp",["vxe-pager"]),t.props&&(0,_log.warnLog)("vxe.error.delProp",["[grid] proxy-config.props","proxy-config.response"]),e&&e.length&&z.loadColumn(e),W(),Ce()}),globalEvents.on(z,"keydown",ye)}),(0,_vue.onBeforeUnmount)(()=>{globalEvents.off(z,"keydown"),_xeUtils.default.assign(j,createReactData()),_xeUtils.default.assign(M,createInternalData())}),z.renderVN=()=>{var e=P.value,t=F.value,r=G.value;return(0,_vue.h)("div",{ref:g,class:["vxe-grid",{["size--"+e]:e,"is--animat":!!c.animat,"is--round":c.round,"is--maximize":j.isZMax,"is--loading":r}],style:t},(()=>{var{headKeys:e,bodyKeys:t,footKeys:r}=U.value,o=d.asideLeft||d["aside-left"],a=d.asideRight||d["aside-right"];return[(0,_vue.h)("div",{class:"vxe-grid--layout-header-wrapper"},E(e)),(0,_vue.h)("div",{class:"vxe-grid--layout-body-wrapper"},[o?(0,_vue.h)("div",{class:"vxe-grid--layout-aside-left-wrapper"},o({})):renderEmptyElement(z),(0,_vue.h)("div",{class:"vxe-grid--layout-body-content-wrapper"},E(t)),a?(0,_vue.h)("div",{class:"vxe-grid--layout-aside-right-wrapper"},a({})):renderEmptyElement(z)]),(0,_vue.h)("div",{class:"vxe-grid--layout-footer-wrapper"},E(r)),(0,_vue.h)("div",{ref:v})]})())},(0,_vue.provide)("$xeGrid",z),(0,_vue.provide)("$xeGantt",null),z},render(){return this.renderVN()}});