vxe-table-plugin-export-xlsx-xhx 1.0.1 → 1.0.3

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,259 +1,237 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports["default"] = exports.VXETablePluginExportXLSX = void 0;
7
-
8
- var _xeUtils = _interopRequireDefault(require("xe-utils/methods/xe-utils"));
9
-
10
- var _xlsx = _interopRequireDefault(require("xlsx"));
11
-
12
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
13
-
14
- /* eslint-disable no-unused-vars */
15
-
16
- /* eslint-enable no-unused-vars */
17
- var _vxetable;
18
-
19
- function getFooterCellValue($table, opts, rows, column) {
20
- var cellValue = _xeUtils["default"].toString(rows[$table.$getColumnIndex(column)]);
21
-
22
- return cellValue;
23
- }
24
-
25
- function toBuffer(wbout) {
26
- var buf = new ArrayBuffer(wbout.length);
27
- var view = new Uint8Array(buf);
28
-
29
- for (var index = 0; index !== wbout.length; ++index) {
30
- view[index] = wbout.charCodeAt(index) & 0xFF;
31
- }
32
-
33
- return buf;
34
- }
35
-
36
- function exportXLSX(params) {
37
- var $table = params.$table,
38
- options = params.options,
39
- columns = params.columns,
40
- datas = params.datas;
41
- var sheetName = options.sheetName,
42
- type = options.type,
43
- isHeader = options.isHeader,
44
- isFooter = options.isFooter,
45
- original = options.original,
46
- message = options.message,
47
- footerFilterMethod = options.footerFilterMethod;
48
- var colHead = {};
49
- var footList = [];
50
- var rowList = datas;
51
-
52
- if (isHeader) {
53
- columns.forEach(function (column) {
54
- colHead[column.id] = _xeUtils["default"].toString(original ? column.property : column.getTitle());
55
- });
56
- }
57
-
58
- if (isFooter) {
59
- var _$table$getTableData = $table.getTableData(),
60
- footerData = _$table$getTableData.footerData;
61
-
62
- var footers = footerFilterMethod ? footerData.filter(footerFilterMethod) : footerData;
63
- footers.forEach(function (rows) {
64
- var item = {};
65
- columns.forEach(function (column) {
66
- item[column.id] = getFooterCellValue($table, options, rows, column);
67
- });
68
- footList.push(item);
69
- });
70
- }
71
-
72
- var book = _xlsx["default"].utils.book_new();
73
-
74
- var sheet = _xlsx["default"].utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), {
75
- skipHeader: true
76
- }); // 转换数据
77
-
78
-
79
- _xlsx["default"].utils.book_append_sheet(book, sheet, sheetName);
80
-
81
- var wbout = _xlsx["default"].write(book, {
82
- bookType: type,
83
- bookSST: false,
84
- type: 'binary'
85
- });
86
-
87
- var blob = new Blob([toBuffer(wbout)], {
88
- type: 'application/octet-stream'
89
- }); // 保存导出
90
-
91
- downloadFile(blob, options);
92
-
93
- if (message !== false) {
94
- _vxetable.modal.message({
95
- message: _vxetable.t('vxe.table.expSuccess'),
96
- status: 'success'
97
- });
98
- }
99
- }
100
-
101
- function downloadFile(blob, options) {
102
- if (window.Blob) {
103
- var filename = options.filename,
104
- type = options.type;
105
-
106
- if (navigator.msSaveBlob) {
107
- navigator.msSaveBlob(blob, "".concat(filename, ".").concat(type));
108
- } else {
109
- var linkElem = document.createElement('a');
110
- linkElem.target = '_blank';
111
- linkElem.download = "".concat(filename, ".").concat(type);
112
- linkElem.href = URL.createObjectURL(blob);
113
- document.body.appendChild(linkElem);
114
- linkElem.click();
115
- document.body.removeChild(linkElem);
116
- }
117
- } else {
118
- console.error(_vxetable.t('vxe.error.notExp'));
119
- }
120
- }
121
-
122
- function replaceDoubleQuotation(val) {
123
- return val.replace(/^"/, '').replace(/"$/, '');
124
- }
125
-
126
- function parseCsv(columns, content) {
127
- var list = content.split('\n');
128
- var fields = [];
129
- var rows = [];
130
-
131
- if (list.length) {
132
- var rList = list.slice(1);
133
- list[0].split(',').map(replaceDoubleQuotation);
134
- rList.forEach(function (r) {
135
- if (r) {
136
- var item = {};
137
- r.split(',').forEach(function (val, colIndex) {
138
- if (fields[colIndex]) {
139
- item[fields[colIndex]] = replaceDoubleQuotation(val);
140
- }
141
- });
142
- rows.push(item);
143
- }
144
- });
145
- }
146
-
147
- return {
148
- fields: fields,
149
- rows: rows
150
- };
151
- }
152
-
153
- function checkImportData(columns, fields, rows) {
154
- var tableFields = [];
155
- columns.forEach(function (column) {
156
- var field = column.property;
157
-
158
- if (field) {
159
- tableFields.push(field);
160
- }
161
- });
162
- return tableFields.every(function (field) {
163
- return fields.includes(field);
164
- });
165
- }
166
-
167
- function importXLSX(params) {
168
- var columns = params.columns,
169
- options = params.options,
170
- file = params.file;
171
- var $table = params.$table;
172
- var _importResolve = $table._importResolve;
173
- var fileReader = new FileReader();
174
-
175
- fileReader.onload = function (e) {
176
- var workbook = _xlsx["default"].read(e.target.result, {
177
- type: 'binary'
178
- });
179
-
180
- var csvData = _xlsx["default"].utils.sheet_to_csv(workbook.Sheets.Sheet1);
181
-
182
- var _parseCsv = parseCsv(columns, csvData),
183
- fields = _parseCsv.fields,
184
- rows = _parseCsv.rows;
185
-
186
- var status = checkImportData(columns, fields, rows);
187
-
188
- if (status) {
189
- $table.createData(rows).then(function (data) {
190
- if (options.mode === 'append') {
191
- $table.insertAt(data, -1);
192
- } else {
193
- $table.reloadData(data);
194
- }
195
- });
196
-
197
- if (options.message !== false) {
198
- _vxetable.modal.message({
199
- message: _xeUtils["default"].template(_vxetable.t('vxe.table.impSuccess'), [rows.length]),
200
- status: 'success'
201
- });
202
- }
203
- } else if (options.message !== false) {
204
- _vxetable.modal.message({
205
- message: _vxetable.t('vxe.error.impFields'),
206
- status: 'error'
207
- });
208
- }
209
-
210
- if (_importResolve) {
211
- _importResolve(status);
212
-
213
- $table._importResolve = null;
214
- }
215
- };
216
-
217
- fileReader.readAsBinaryString(file);
218
- }
219
-
220
- function handleImportEvent(params) {
221
- if (params.options.type === 'xlsx') {
222
- importXLSX(params);
223
- return false;
224
- }
225
- }
226
-
227
- function handleExportEvent(params) {
228
- if (params.options.type === 'xlsx') {
229
- exportXLSX(params);
230
- return false;
231
- }
232
- }
233
- /**
234
- * 基于 vxe-table 表格的增强插件,支持导出 xlsx 格式
235
- */
236
-
237
-
238
- var VXETablePluginExportXLSX = {
239
- install: function install(xtable) {
240
- var interceptor = xtable.interceptor;
241
- _vxetable = xtable;
242
- Object.assign(xtable.types, {
243
- xlsx: 1
244
- });
245
- interceptor.mixin({
246
- 'event.import': handleImportEvent,
247
- 'event.export': handleExportEvent
248
- });
249
- }
250
- };
251
- exports.VXETablePluginExportXLSX = VXETablePluginExportXLSX;
252
-
253
- if (typeof window !== 'undefined' && window.VXETable) {
254
- window.VXETable.use(VXETablePluginExportXLSX);
255
- }
256
-
257
- var _default = VXETablePluginExportXLSX;
258
- exports["default"] = _default;
259
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.ts"],"names":["_vxetable","getFooterCellValue","$table","opts","rows","column","cellValue","XEUtils","toString","$getColumnIndex","toBuffer","wbout","buf","ArrayBuffer","length","view","Uint8Array","index","charCodeAt","exportXLSX","params","options","columns","datas","sheetName","type","isHeader","isFooter","original","message","footerFilterMethod","colHead","footList","rowList","forEach","id","property","getTitle","getTableData","footerData","footers","filter","item","push","book","XLSX","utils","book_new","sheet","json_to_sheet","concat","skipHeader","book_append_sheet","write","bookType","bookSST","blob","Blob","downloadFile","modal","t","status","window","filename","navigator","msSaveBlob","linkElem","document","createElement","target","download","href","URL","createObjectURL","body","appendChild","click","removeChild","console","error","replaceDoubleQuotation","val","replace","parseCsv","content","list","split","fields","rList","slice","map","r","colIndex","checkImportData","tableFields","field","every","includes","importXLSX","file","_importResolve","fileReader","FileReader","onload","e","workbook","read","result","csvData","sheet_to_csv","Sheets","Sheet1","createData","then","data","mode","insertAt","reloadData","template","readAsBinaryString","handleImportEvent","handleExportEvent","VXETablePluginExportXLSX","install","xtable","interceptor","Object","assign","types","xlsx","mixin","VXETable","use"],"mappings":"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","file":"index.common.js","sourcesContent":["/* eslint-disable no-unused-vars */\r\nimport XEUtils from 'xe-utils/methods/xe-utils'\r\nimport {\r\n  VXETable,\r\n  Table,\r\n  InterceptorExportParams,\r\n  InterceptorImportParams,\r\n  ColumnConfig,\r\n  ExportOptons\r\n} from 'vxe-table/lib/vxe-table'\r\nimport XLSX from 'xlsx'\r\n/* eslint-enable no-unused-vars */\r\n\r\nlet _vxetable: typeof VXETable\r\n\r\nfunction getFooterCellValue ($table: Table, opts: ExportOptons, rows: any[], column: ColumnConfig) {\r\n  var cellValue = XEUtils.toString(rows[$table.$getColumnIndex(column)])\r\n  return cellValue\r\n}\r\n\r\nfunction toBuffer (wbout: any) {\r\n  let buf = new ArrayBuffer(wbout.length)\r\n  let view = new Uint8Array(buf)\r\n  for (let index = 0; index !== wbout.length; ++index) view[index] = wbout.charCodeAt(index) & 0xFF\r\n  return buf\r\n}\r\n\r\nfunction exportXLSX (params: InterceptorExportParams) {\r\n  const { $table, options, columns, datas } = params\r\n  const { sheetName, type, isHeader, isFooter, original, message, footerFilterMethod } = options\r\n  const colHead: { [key: string]: any } = {}\r\n  const footList: { [key: string]: any }[] = []\r\n  const rowList = datas\r\n  if (isHeader) {\r\n    columns.forEach((column) => {\r\n      colHead[column.id] = XEUtils.toString(original ? column.property : column.getTitle())\r\n    })\r\n  }\r\n  if (isFooter) {\r\n    const { footerData } = $table.getTableData()\r\n    const footers = footerFilterMethod ? footerData.filter(footerFilterMethod) : footerData\r\n    footers.forEach((rows) => {\r\n      const item: { [key: string]: any } = {}\r\n      columns.forEach((column) => {\r\n        item[column.id] = getFooterCellValue($table, options, rows, column)\r\n      })\r\n      footList.push(item)\r\n    })\r\n  }\r\n  const book = XLSX.utils.book_new()\r\n  const sheet = XLSX.utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), { skipHeader: true })\r\n  // 转换数据\r\n  XLSX.utils.book_append_sheet(book, sheet, sheetName)\r\n  const wbout = XLSX.write(book, { bookType: type, bookSST: false, type: 'binary' })\r\n  const blob = new Blob([toBuffer(wbout)], { type: 'application/octet-stream' })\r\n  // 保存导出\r\n  downloadFile(blob, options)\r\n  if (message !== false) {\r\n    _vxetable.modal.message({ message: _vxetable.t('vxe.table.expSuccess'), status: 'success' })\r\n  }\r\n}\r\n\r\nfunction downloadFile (blob: Blob, options: ExportOptons) {\r\n  if (window.Blob) {\r\n    const { filename, type } = options\r\n    if (navigator.msSaveBlob) {\r\n      navigator.msSaveBlob(blob, `${filename}.${type}`)\r\n    } else {\r\n      var linkElem = document.createElement('a')\r\n      linkElem.target = '_blank'\r\n      linkElem.download = `${filename}.${type}`\r\n      linkElem.href = URL.createObjectURL(blob)\r\n      document.body.appendChild(linkElem)\r\n      linkElem.click()\r\n      document.body.removeChild(linkElem)\r\n    }\r\n  } else {\r\n    console.error(_vxetable.t('vxe.error.notExp'))\r\n  }\r\n}\r\n\r\nfunction replaceDoubleQuotation (val: string) {\r\n  return val.replace(/^\"/, '').replace(/\"$/, '')\r\n}\r\n\r\nfunction parseCsv (columns: ColumnConfig[], content: string) {\r\n  const list = content.split('\\n')\r\n  const fields: string[] = []\r\n  const rows: any[] = []\r\n  if (list.length) {\r\n    const rList = list.slice(1)\r\n    list[0].split(',').map(replaceDoubleQuotation)\r\n    rList.forEach((r) => {\r\n      if (r) {\r\n        const item: { [key: string]: any } = {}\r\n        r.split(',').forEach((val, colIndex) => {\r\n          if (fields[colIndex]) {\r\n            item[fields[colIndex]] = replaceDoubleQuotation(val)\r\n          }\r\n        })\r\n        rows.push(item)\r\n      }\r\n    })\r\n  }\r\n  return { fields, rows }\r\n}\r\n\r\nfunction checkImportData (columns: ColumnConfig[], fields: string[], rows: any[]) {\r\n  let tableFields: string[] = []\r\n  columns.forEach((column) => {\r\n    let field = column.property\r\n    if (field) {\r\n      tableFields.push(field)\r\n    }\r\n  })\r\n  return tableFields.every((field) => fields.includes(field))\r\n}\r\n\r\nfunction importXLSX (params: InterceptorImportParams) {\r\n  const { columns, options, file } = params\r\n  const $table: any = params.$table\r\n  const { _importResolve } = $table\r\n  const fileReader = new FileReader()\r\n  fileReader.onload = (e: any) => {\r\n    const workbook = XLSX.read(e.target.result, { type: 'binary' })\r\n    const csvData: string = XLSX.utils.sheet_to_csv(workbook.Sheets.Sheet1)\r\n    const { fields, rows } = parseCsv(columns, csvData)\r\n    const status = checkImportData(columns, fields, rows)\r\n    if (status) {\r\n      $table.createData(rows)\r\n        .then((data: any[]) => {\r\n          if (options.mode === 'append') {\r\n            $table.insertAt(data, -1)\r\n          } else {\r\n            $table.reloadData(data)\r\n          }\r\n        })\r\n      if (options.message !== false) {\r\n        _vxetable.modal.message({ message: XEUtils.template(_vxetable.t('vxe.table.impSuccess'), [rows.length]), status: 'success' })\r\n      }\r\n    } else if (options.message !== false) {\r\n      _vxetable.modal.message({ message: _vxetable.t('vxe.error.impFields'), status: 'error' })\r\n    }\r\n    if (_importResolve) {\r\n      _importResolve(status)\r\n      $table._importResolve = null\r\n    }\r\n  }\r\n  fileReader.readAsBinaryString(file)\r\n}\r\n\r\nfunction handleImportEvent (params: InterceptorImportParams) {\r\n  if (params.options.type === 'xlsx') {\r\n    importXLSX(params)\r\n    return false\r\n  }\r\n}\r\n\r\nfunction handleExportEvent (params: InterceptorExportParams) {\r\n  if (params.options.type === 'xlsx') {\r\n    exportXLSX(params)\r\n    return false\r\n  }\r\n}\r\n\r\n/**\r\n * 基于 vxe-table 表格的增强插件，支持导出 xlsx 格式\r\n */\r\nexport const VXETablePluginExportXLSX = {\r\n  install (xtable: typeof VXETable) {\r\n    const { interceptor } = xtable\r\n    _vxetable = xtable\r\n    Object.assign(xtable.types, { xlsx: 1 })\r\n    interceptor.mixin({\r\n      'event.import': handleImportEvent,\r\n      'event.export': handleExportEvent\r\n    })\r\n  }\r\n}\r\n\r\nif (typeof window !== 'undefined' && window.VXETable) {\r\n  window.VXETable.use(VXETablePluginExportXLSX)\r\n}\r\n\r\nexport default VXETablePluginExportXLSX\r\n"]}
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ /* eslint-disable no-unused-vars */
7
+ var xe_utils_1 = require("xe-utils/methods/xe-utils");
8
+ var xlsx_1 = require("xlsx");
9
+ /* eslint-enable no-unused-vars */
10
+ var _vxetable;
11
+ function getCellLabel(column, cellValue) {
12
+ if (cellValue) {
13
+ switch (column.cellType) {
14
+ case 'string':
15
+ return xe_utils_1["default"].toValueString(cellValue);
16
+ case 'number':
17
+ if (!isNaN(cellValue)) {
18
+ return Number(cellValue);
19
+ }
20
+ break;
21
+ default:
22
+ if (cellValue.length < 12 && !isNaN(cellValue)) {
23
+ return Number(cellValue);
24
+ }
25
+ break;
26
+ }
27
+ }
28
+ return cellValue;
29
+ }
30
+ function getFooterCellValue($table, opts, rows, column) {
31
+ var cellValue = xe_utils_1["default"].toString(rows[$table.$getColumnIndex(column)]);
32
+ return cellValue;
33
+ }
34
+ function toBuffer(wbout) {
35
+ var buf = new ArrayBuffer(wbout.length);
36
+ var view = new Uint8Array(buf);
37
+ for (var index = 0; index !== wbout.length; ++index) {
38
+ view[index] = wbout.charCodeAt(index) & 0xFF;
39
+ }
40
+ return buf;
41
+ }
42
+ function exportXLSX(params) {
43
+ var $table = params.$table,
44
+ options = params.options,
45
+ columns = params.columns,
46
+ datas = params.datas;
47
+ var sheetName = options.sheetName,
48
+ type = options.type,
49
+ isHeader = options.isHeader,
50
+ isFooter = options.isFooter,
51
+ original = options.original,
52
+ message = options.message,
53
+ footerFilterMethod = options.footerFilterMethod;
54
+ var colHead = {};
55
+ var footList = [];
56
+ // const rowList = datas
57
+ if (isHeader) {
58
+ columns.forEach(function (column) {
59
+ colHead[column.id] = xe_utils_1["default"].toString(original ? column.property : column.getTitle());
60
+ });
61
+ }
62
+ // 新增部分
63
+ var rowList = datas.map(function (item) {
64
+ var rest = {};
65
+ columns.forEach(function (column) {
66
+ rest[column.id] = getCellLabel(column, item[column.id]);
67
+ });
68
+ return rest;
69
+ });
70
+ if (isFooter) {
71
+ var footerData = $table.getTableData().footerData;
72
+ var footers = footerFilterMethod ? footerData.filter(footerFilterMethod) : footerData;
73
+ footers.forEach(function (rows) {
74
+ var item = {};
75
+ columns.forEach(function (column) {
76
+ item[column.id] = getFooterCellValue($table, options, rows, column);
77
+ });
78
+ footList.push(item);
79
+ });
80
+ }
81
+ var book = xlsx_1["default"].utils.book_new();
82
+ var sheet = xlsx_1["default"].utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), {
83
+ skipHeader: true
84
+ });
85
+ // 转换数据
86
+ xlsx_1["default"].utils.book_append_sheet(book, sheet, sheetName);
87
+ var wbout = xlsx_1["default"].write(book, {
88
+ bookType: type,
89
+ bookSST: false,
90
+ type: 'binary'
91
+ });
92
+ var blob = new Blob([toBuffer(wbout)], {
93
+ type: 'application/octet-stream'
94
+ });
95
+ // 保存导出
96
+ downloadFile(blob, options);
97
+ if (message !== false) {
98
+ _vxetable.modal.message({
99
+ message: _vxetable.t('vxe.table.expSuccess'),
100
+ status: 'success'
101
+ });
102
+ }
103
+ }
104
+ function downloadFile(blob, options) {
105
+ if (window.Blob) {
106
+ var filename = options.filename,
107
+ type = options.type;
108
+ if (navigator.msSaveBlob) {
109
+ navigator.msSaveBlob(blob, filename + "." + type);
110
+ } else {
111
+ var linkElem = document.createElement('a');
112
+ linkElem.target = '_blank';
113
+ linkElem.download = filename + "." + type;
114
+ linkElem.href = URL.createObjectURL(blob);
115
+ document.body.appendChild(linkElem);
116
+ linkElem.click();
117
+ document.body.removeChild(linkElem);
118
+ }
119
+ } else {
120
+ console.error(_vxetable.t('vxe.error.notExp'));
121
+ }
122
+ }
123
+ function replaceDoubleQuotation(val) {
124
+ return val.replace(/^"/, '').replace(/"$/, '');
125
+ }
126
+ function parseCsv(columns, content) {
127
+ var list = content.split('\n');
128
+ var fields = [];
129
+ var rows = [];
130
+ if (list.length) {
131
+ var rList = list.slice(1);
132
+ list[0].split(',').map(replaceDoubleQuotation);
133
+ rList.forEach(function (r) {
134
+ if (r) {
135
+ var item_1 = {};
136
+ r.split(',').forEach(function (val, colIndex) {
137
+ if (fields[colIndex]) {
138
+ item_1[fields[colIndex]] = replaceDoubleQuotation(val);
139
+ }
140
+ });
141
+ rows.push(item_1);
142
+ }
143
+ });
144
+ }
145
+ return {
146
+ fields: fields,
147
+ rows: rows
148
+ };
149
+ }
150
+ function checkImportData(columns, fields, rows) {
151
+ var tableFields = [];
152
+ columns.forEach(function (column) {
153
+ var field = column.property;
154
+ if (field) {
155
+ tableFields.push(field);
156
+ }
157
+ });
158
+ return tableFields.every(function (field) {
159
+ return fields.includes(field);
160
+ });
161
+ }
162
+ function importXLSX(params) {
163
+ var columns = params.columns,
164
+ options = params.options,
165
+ file = params.file;
166
+ var $table = params.$table;
167
+ var _importResolve = $table._importResolve;
168
+ var fileReader = new FileReader();
169
+ fileReader.onload = function (e) {
170
+ var workbook = xlsx_1["default"].read(e.target.result, {
171
+ type: 'binary'
172
+ });
173
+ var csvData = xlsx_1["default"].utils.sheet_to_csv(workbook.Sheets.Sheet1);
174
+ var _a = parseCsv(columns, csvData),
175
+ fields = _a.fields,
176
+ rows = _a.rows;
177
+ var status = checkImportData(columns, fields, rows);
178
+ if (status) {
179
+ $table.createData(rows).then(function (data) {
180
+ if (options.mode === 'append') {
181
+ $table.insertAt(data, -1);
182
+ } else {
183
+ $table.reloadData(data);
184
+ }
185
+ });
186
+ if (options.message !== false) {
187
+ _vxetable.modal.message({
188
+ message: xe_utils_1["default"].template(_vxetable.t('vxe.table.impSuccess'), [rows.length]),
189
+ status: 'success'
190
+ });
191
+ }
192
+ } else if (options.message !== false) {
193
+ _vxetable.modal.message({
194
+ message: _vxetable.t('vxe.error.impFields'),
195
+ status: 'error'
196
+ });
197
+ }
198
+ if (_importResolve) {
199
+ _importResolve(status);
200
+ $table._importResolve = null;
201
+ }
202
+ };
203
+ fileReader.readAsBinaryString(file);
204
+ }
205
+ function handleImportEvent(params) {
206
+ if (params.options.type === 'xlsx') {
207
+ importXLSX(params);
208
+ return false;
209
+ }
210
+ }
211
+ function handleExportEvent(params) {
212
+ if (params.options.type === 'xlsx') {
213
+ exportXLSX(params);
214
+ return false;
215
+ }
216
+ }
217
+ /**
218
+ * 基于 vxe-table 表格的增强插件,支持导出 xlsx 格式
219
+ */
220
+ exports.VXETablePluginExportXLSX = {
221
+ install: function install(xtable) {
222
+ var interceptor = xtable.interceptor;
223
+ _vxetable = xtable;
224
+ Object.assign(xtable.types, {
225
+ xlsx: 1
226
+ });
227
+ interceptor.mixin({
228
+ 'event.import': handleImportEvent,
229
+ 'event.export': handleExportEvent
230
+ });
231
+ }
232
+ };
233
+ if (typeof window !== 'undefined' && window.VXETable) {
234
+ window.VXETable.use(exports.VXETablePluginExportXLSX);
235
+ }
236
+ exports["default"] = exports.VXETablePluginExportXLSX;
237
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.js","index.ts"],"names":["Object","defineProperty","exports","value","xe_utils_1","require","xlsx_1","_vxetable","getCellLabel","column","cellValue","cellType","toValueString","isNaN","Number","length","getFooterCellValue","$table","opts","rows","toString","$getColumnIndex","toBuffer","wbout","buf","ArrayBuffer","view","Uint8Array","index","charCodeAt","exportXLSX","params","options","columns","datas","sheetName","type","isHeader","isFooter","original","message","footerFilterMethod","colHead","footList","forEach","id","property","getTitle","rowList","map","item","rest","footerData","getTableData","footers","filter","push","book","utils","book_new","sheet","json_to_sheet","concat","skipHeader","book_append_sheet","write","bookType","bookSST","blob","Blob","downloadFile","modal","t","status","window","filename","navigator","msSaveBlob","linkElem","document","createElement","target","download","href","URL","createObjectURL","body","appendChild","click","removeChild","console","error","replaceDoubleQuotation","val","replace","parseCsv","content","list","split","fields","rList","slice","r","item_1","colIndex","checkImportData","tableFields","field","every","includes","importXLSX","file","_importResolve","fileReader","FileReader","onload","e","workbook","read","result","csvData","sheet_to_csv","Sheets","Sheet1","_a","createData","then","data","mode","insertAt","reloadData","template","readAsBinaryString","handleImportEvent","handleExportEvent","VXETablePluginExportXLSX","install","xtable","interceptor","assign","types","xlsx","mixin","VXETable","use"],"mappings":"AAAA,YAAY;;AACZA,MAAM,CAACC,cAAc,CAACC,OAAO,EAAE,YAAY,EAAE;EAAEC,KAAK,EAAE;AAAK,CAAC,CAAC;ACD7D;AACA,IAAAC,UAAA,GAAAC,OAAA,CAAA,2BAAA,CAAA;AASA,IAAAC,MAAA,GAAAD,OAAA,CAAA,MAAA,CAAA;AACA;AAEA,IAAIE,SAA0B;AAG9B,SAASC,YAAY,CAAEC,MAAoB,EAAEC,SAAc,EAAA;EACzD,IAAIA,SAAS,EAAE;IACb,QAAQD,MAAM,CAACE,QAAQ;MACrB,KAAK,QAAQ;QACX,OAAOP,UAAA,WAAO,CAACQ,aAAa,CAACF,SAAS,CAAC;MACzC,KAAK,QAAQ;QACX,IAAI,CAACG,KAAK,CAACH,SAAS,CAAC,EAAE;UACrB,OAAOI,MAAM,CAACJ,SAAS,CAAC;QDRlB;QCUR;MACF;QACE,IAAIA,SAAS,CAACK,MAAM,GAAG,EAAE,IAAI,CAACF,KAAK,CAACH,SAAS,CAAC,EAAE;UAC9C,OAAOI,MAAM,CAACJ,SAAS,CAAC;QDRlB;QCUR;IAAK;EDPT;ECUF,OAAOA,SAAS;AAClB;AAIA,SAASM,kBAAkB,CAAEC,MAAa,EAAEC,IAAkB,EAAEC,IAAW,EAAEV,MAAoB,EAAA;EAC/F,IAAIC,SAAS,GAAGN,UAAA,WAAO,CAACgB,QAAQ,CAACD,IAAI,CAACF,MAAM,CAACI,eAAe,CAACZ,MAAM,CAAC,CAAC,CAAC;EACtE,OAAOC,SAAS;AAClB;AAEA,SAASY,QAAQ,CAAEC,KAAU,EAAA;EAC3B,IAAIC,GAAG,GAAG,IAAIC,WAAW,CAACF,KAAK,CAACR,MAAM,CAAC;EACvC,IAAIW,IAAI,GAAG,IAAIC,UAAU,CAACH,GAAG,CAAC;EAC9B,KAAK,IAAII,KAAK,GAAG,CAAC,EAAEA,KAAK,KAAKL,KAAK,CAACR,MAAM,EAAE,EAAEa,KAAK;IAAEF,IAAI,CAACE,KAAK,CAAC,GAAGL,KAAK,CAACM,UAAU,CAACD,KAAK,CAAC,GAAG,IAAI;EAAA;EACjG,OAAOJ,GAAG;AACZ;AAEA,SAASM,UAAU,CAAEC,MAA+B,EAAA;EAC1C,IAAAd,MAAA,GAAAc,MAAA,CAAAd,MAAM;IAAEe,OAAA,GAAAD,MAAA,CAAAC,OAAO;IAAEC,OAAA,GAAAF,MAAA,CAAAE,OAAO;IAAEC,KAAA,GAAAH,MAAA,CAAAG,KAAK;EAC/B,IAAAC,SAAA,GAAAH,OAAA,CAAAG,SAAS;IAAEC,IAAA,GAAAJ,OAAA,CAAAI,IAAI;IAAEC,QAAA,GAAAL,OAAA,CAAAK,QAAQ;IAAEC,QAAA,GAAAN,OAAA,CAAAM,QAAQ;IAAEC,QAAA,GAAAP,OAAA,CAAAO,QAAQ;IAAEC,OAAA,GAAAR,OAAA,CAAAQ,OAAO;IAAEC,kBAAA,GAAAT,OAAA,CAAAS,kBAAkB;EAClF,IAAMC,OAAO,GAA2B,CAAA,CAAE;EAC1C,IAAMC,QAAQ,GAA6B,EAAE;EAC7C;EAEA,IAAIN,QAAQ,EAAE;IACZJ,OAAO,CAACW,OAAO,CAAC,UAACnC,MAAM,EAAA;MACrBiC,OAAO,CAACjC,MAAM,CAACoC,EAAE,CAAC,GAAGzC,UAAA,WAAO,CAACgB,QAAQ,CAACmB,QAAQ,GAAG9B,MAAM,CAACqC,QAAQ,GAAGrC,MAAM,CAACsC,QAAQ,EAAE,CAAC;IACvF,CAAC,CAAC;EDbF;ECgBF;EACA,IAAMC,OAAO,GAAGd,KAAK,CAACe,GAAG,CAAC,UAAAC,IAAI,EAAA;IAC5B,IAAMC,IAAI,GAAQ,CAAA,CAAE;IACpBlB,OAAO,CAACW,OAAO,CAAC,UAACnC,MAAM,EAAA;MACrB0C,IAAI,CAAC1C,MAAM,CAACoC,EAAE,CAAC,GAAGrC,YAAY,CAACC,MAAM,EAAEyC,IAAI,CAACzC,MAAM,CAACoC,EAAE,CAAC,CAAC;IACzD,CAAC,CAAC;IACF,OAAOM,IAAI;EACb,CAAC,CAAC;EAEF,IAAIb,QAAQ,EAAE;IACJ,IAAAc,UAAA,GAAAnC,MAAA,CAAAoC,YAAA,EAAA,CAAAD,UAAU;IAClB,IAAME,OAAO,GAAGb,kBAAkB,GAAGW,UAAU,CAACG,MAAM,CAACd,kBAAkB,CAAC,GAAGW,UAAU;IACvFE,OAAO,CAACV,OAAO,CAAC,UAACzB,IAAI,EAAA;MACnB,IAAM+B,IAAI,GAA2B,CAAA,CAAE;MACvCjB,OAAO,CAACW,OAAO,CAAC,UAACnC,MAAM,EAAA;QACrByC,IAAI,CAACzC,MAAM,CAACoC,EAAE,CAAC,GAAG7B,kBAAkB,CAACC,MAAM,EAAEe,OAAO,EAAEb,IAAI,EAAEV,MAAM,CAAC;MACrE,CAAC,CAAC;MACFkC,QAAQ,CAACa,IAAI,CAACN,IAAI,CAAC;IACrB,CAAC,CAAC;EDfF;ECiBF,IAAMO,IAAI,GAAGnD,MAAA,WAAI,CAACoD,KAAK,CAACC,QAAQ,EAAE;EAClC,IAAMC,KAAK,GAAGtD,MAAA,WAAI,CAACoD,KAAK,CAACG,aAAa,CAAC,CAACxB,QAAQ,GAAG,CAACK,OAAO,CAAC,GAAG,EAAE,EAAEoB,MAAM,CAACd,OAAO,CAAC,CAACc,MAAM,CAACnB,QAAQ,CAAC,EAAE;IAAEoB,UAAU,EAAE;EAAI,CAAE,CAAC;EAC1H;EACAzD,MAAA,WAAI,CAACoD,KAAK,CAACM,iBAAiB,CAACP,IAAI,EAAEG,KAAK,EAAEzB,SAAS,CAAC;EACpD,IAAMZ,KAAK,GAAGjB,MAAA,WAAI,CAAC2D,KAAK,CAACR,IAAI,EAAE;IAAES,QAAQ,EAAE9B,IAAI;IAAE+B,OAAO,EAAE,KAAK;IAAE/B,IAAI,EAAE;EAAQ,CAAE,CAAC;EAClF,IAAMgC,IAAI,GAAG,IAAIC,IAAI,CAAC,CAAC/C,QAAQ,CAACC,KAAK,CAAC,CAAC,EAAE;IAAEa,IAAI,EAAE;EAA0B,CAAE,CAAC;EAC9E;EACAkC,YAAY,CAACF,IAAI,EAAEpC,OAAO,CAAC;EAC3B,IAAIQ,OAAO,KAAK,KAAK,EAAE;IACrBjC,SAAS,CAACgE,KAAK,CAAC/B,OAAO,CAAC;MAAEA,OAAO,EAAEjC,SAAS,CAACiE,CAAC,CAAC,sBAAsB,CAAC;MAAEC,MAAM,EAAE;IAAS,CAAE,CAAC;EDf5F;ACiBJ;AAEA,SAASH,YAAY,CAAEF,IAAU,EAAEpC,OAAqB,EAAA;EACtD,IAAI0C,MAAM,CAACL,IAAI,EAAE;IACP,IAAAM,QAAA,GAAA3C,OAAA,CAAA2C,QAAQ;MAAEvC,IAAA,GAAAJ,OAAA,CAAAI,IAAI;IACtB,IAAIwC,SAAS,CAACC,UAAU,EAAE;MACxBD,SAAS,CAACC,UAAU,CAACT,IAAI,EAAKO,QAAQ,GAAA,GAAA,GAAIvC,IAAM,CAAC;IDhB/C,CCiBH,MAAM;MACL,IAAI0C,QAAQ,GAAGC,QAAQ,CAACC,aAAa,CAAC,GAAG,CAAC;MAC1CF,QAAQ,CAACG,MAAM,GAAG,QAAQ;MAC1BH,QAAQ,CAACI,QAAQ,GAAMP,QAAQ,GAAA,GAAA,GAAIvC,IAAM;MACzC0C,QAAQ,CAACK,IAAI,GAAGC,GAAG,CAACC,eAAe,CAACjB,IAAI,CAAC;MACzCW,QAAQ,CAACO,IAAI,CAACC,WAAW,CAACT,QAAQ,CAAC;MACnCA,QAAQ,CAACU,KAAK,EAAE;MAChBT,QAAQ,CAACO,IAAI,CAACG,WAAW,CAACX,QAAQ,CAAC;IDfjC;EACJ,CCgBD,MAAM;IACLY,OAAO,CAACC,KAAK,CAACpF,SAAS,CAACiE,CAAC,CAAC,kBAAkB,CAAC,CAAC;EDd9C;ACgBJ;AAEA,SAASoB,sBAAsB,CAAEC,GAAW,EAAA;EAC1C,OAAOA,GAAG,CAACC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAACA,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC;AAChD;AAEA,SAASC,QAAQ,CAAE9D,OAAuB,EAAE+D,OAAe,EAAA;EACzD,IAAMC,IAAI,GAAGD,OAAO,CAACE,KAAK,CAAC,IAAI,CAAC;EAChC,IAAMC,MAAM,GAAa,EAAE;EAC3B,IAAMhF,IAAI,GAAU,EAAE;EACtB,IAAI8E,IAAI,CAAClF,MAAM,EAAE;IACf,IAAMqF,KAAK,GAAGH,IAAI,CAACI,KAAK,CAAC,CAAC,CAAC;IAC3BJ,IAAI,CAAC,CAAC,CAAC,CAACC,KAAK,CAAC,GAAG,CAAC,CAACjD,GAAG,CAAC2C,sBAAsB,CAAC;IAC9CQ,KAAK,CAACxD,OAAO,CAAC,UAAC0D,CAAC,EAAA;MACd,IAAIA,CAAC,EAAE;QACL,IAAMC,MAAI,GAA2B,CAAA,CAAE;QACvCD,CAAC,CAACJ,KAAK,CAAC,GAAG,CAAC,CAACtD,OAAO,CAAC,UAACiD,GAAG,EAAEW,QAAQ,EAAA;UACjC,IAAIL,MAAM,CAACK,QAAQ,CAAC,EAAE;YACpBD,MAAI,CAACJ,MAAM,CAACK,QAAQ,CAAC,CAAC,GAAGZ,sBAAsB,CAACC,GAAG,CAAC;UDhB5C;QCkBZ,CAAC,CAAC;QACF1E,IAAI,CAACqC,IAAI,CAAC+C,MAAI,CAAC;MDhBX;ICkBR,CAAC,CAAC;EDhBF;ECkBF,OAAO;IAAEJ,MAAM,EAAAA,MAAA;IAAEhF,IAAI,EAAAA;EAAA,CAAE;AACzB;AAEA,SAASsF,eAAe,CAAExE,OAAuB,EAAEkE,MAAgB,EAAEhF,IAAW,EAAA;EAC9E,IAAIuF,WAAW,GAAa,EAAE;EAC9BzE,OAAO,CAACW,OAAO,CAAC,UAACnC,MAAM,EAAA;IACrB,IAAIkG,KAAK,GAAGlG,MAAM,CAACqC,QAAQ;IAC3B,IAAI6D,KAAK,EAAE;MACTD,WAAW,CAAClD,IAAI,CAACmD,KAAK,CAAC;IDjBrB;ECmBN,CAAC,CAAC;EACF,OAAOD,WAAW,CAACE,KAAK,CAAC,UAACD,KAAK,EAAA;IAAK,OAAAR,MAAM,CAACU,QAAQ,CAACF,KAAK,CAAC;EAAtB,CAAsB,CAAC;AAC7D;AAEA,SAASG,UAAU,CAAE/E,MAA+B,EAAA;EAC1C,IAAAE,OAAA,GAAAF,MAAA,CAAAE,OAAO;IAAED,OAAA,GAAAD,MAAA,CAAAC,OAAO;IAAE+E,IAAA,GAAAhF,MAAA,CAAAgF,IAAI;EAC9B,IAAM9F,MAAM,GAAQc,MAAM,CAACd,MAAM;EACzB,IAAA+F,cAAA,GAAA/F,MAAA,CAAA+F,cAAc;EACtB,IAAMC,UAAU,GAAG,IAAIC,UAAU,EAAE;EACnCD,UAAU,CAACE,MAAM,GAAG,UAACC,CAAM,EAAA;IACzB,IAAMC,QAAQ,GAAG/G,MAAA,WAAI,CAACgH,IAAI,CAACF,CAAC,CAACnC,MAAM,CAACsC,MAAM,EAAE;MAAEnF,IAAI,EAAE;IAAQ,CAAE,CAAC;IAC/D,IAAMoF,OAAO,GAAWlH,MAAA,WAAI,CAACoD,KAAK,CAAC+D,YAAY,CAACJ,QAAQ,CAACK,MAAM,CAACC,MAAM,CAAC;IACjE,IAAAC,EAAA,GAAA7B,QAAA,CAAA9D,OAAA,EAAAuF,OAAA,CAA6C;MAA3CrB,MAAA,GAAAyB,EAAA,CAAAzB,MAAM;MAAEhF,IAAA,GAAAyG,EAAA,CAAAzG,IAAmC;IACnD,IAAMsD,MAAM,GAAGgC,eAAe,CAACxE,OAAO,EAAEkE,MAAM,EAAEhF,IAAI,CAAC;IACrD,IAAIsD,MAAM,EAAE;MACVxD,MAAM,CAAC4G,UAAU,CAAC1G,IAAI,CAAC,CACpB2G,IAAI,CAAC,UAACC,IAAW,EAAA;QAChB,IAAI/F,OAAO,CAACgG,IAAI,KAAK,QAAQ,EAAE;UAC7B/G,MAAM,CAACgH,QAAQ,CAACF,IAAI,EAAE,CAAC,CAAC,CAAC;QDlBrB,CCmBL,MAAM;UACL9G,MAAM,CAACiH,UAAU,CAACH,IAAI,CAAC;QDjBnB;MCmBR,CAAC,CAAC;MACJ,IAAI/F,OAAO,CAACQ,OAAO,KAAK,KAAK,EAAE;QAC7BjC,SAAS,CAACgE,KAAK,CAAC/B,OAAO,CAAC;UAAEA,OAAO,EAAEpC,UAAA,WAAO,CAAC+H,QAAQ,CAAC5H,SAAS,CAACiE,CAAC,CAAC,sBAAsB,CAAC,EAAE,CAACrD,IAAI,CAACJ,MAAM,CAAC,CAAC;UAAE0D,MAAM,EAAE;QAAS,CAAE,CAAC;MDjBzH;IACJ,CCkBH,MAAM,IAAIzC,OAAO,CAACQ,OAAO,KAAK,KAAK,EAAE;MACpCjC,SAAS,CAACgE,KAAK,CAAC/B,OAAO,CAAC;QAAEA,OAAO,EAAEjC,SAAS,CAACiE,CAAC,CAAC,qBAAqB,CAAC;QAAEC,MAAM,EAAE;MAAO,CAAE,CAAC;IDhBvF;ICkBJ,IAAIuC,cAAc,EAAE;MAClBA,cAAc,CAACvC,MAAM,CAAC;MACtBxD,MAAM,CAAC+F,cAAc,GAAG,IAAI;IDhB1B;ECkBN,CAAC;EACDC,UAAU,CAACmB,kBAAkB,CAACrB,IAAI,CAAC;AACrC;AAEA,SAASsB,iBAAiB,CAAEtG,MAA+B,EAAA;EACzD,IAAIA,MAAM,CAACC,OAAO,CAACI,IAAI,KAAK,MAAM,EAAE;IAClC0E,UAAU,CAAC/E,MAAM,CAAC;IAClB,OAAO,KAAK;EDjBZ;ACmBJ;AAEA,SAASuG,iBAAiB,CAAEvG,MAA+B,EAAA;EACzD,IAAIA,MAAM,CAACC,OAAO,CAACI,IAAI,KAAK,MAAM,EAAE;IAClCN,UAAU,CAACC,MAAM,CAAC;IAClB,OAAO,KAAK;EDlBZ;ACoBJ;AAEA;ADnBA;AACA;ACqBa7B,OAAA,CAAAqI,wBAAwB,GAAG;EACtCC,OAAO,EAAP,iBAASC,MAAuB,EAAA;IACtB,IAAAC,WAAA,GAAAD,MAAA,CAAAC,WAAW;IACnBnI,SAAS,GAAGkI,MAAM;IAClBzI,MAAM,CAAC2I,MAAM,CAACF,MAAM,CAACG,KAAK,EAAE;MAAEC,IAAI,EAAE;IAAC,CAAE,CAAC;IACxCH,WAAW,CAACI,KAAK,CAAC;MAChB,cAAc,EAAET,iBAAiB;MACjC,cAAc,EAAEC;IDnBd,CCoBH,CAAC;EACJ;ADnBF,CCoBC;AAED,IAAI,OAAO5D,MAAM,KAAK,WAAW,IAAIA,MAAM,CAACqE,QAAQ,EAAE;EACpDrE,MAAM,CAACqE,QAAQ,CAACC,GAAG,CAAC9I,OAAA,CAAAqI,wBAAwB,CAAC;ADpB/C;ACuBArI,OAAA,WAAA,GAAeA,OAAA,CAAAqI,wBAAwB","file":"index.common.js","sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n/* eslint-disable no-unused-vars */\nvar xe_utils_1 = require(\"xe-utils/methods/xe-utils\");\nvar xlsx_1 = require(\"xlsx\");\n/* eslint-enable no-unused-vars */\nvar _vxetable;\nfunction getCellLabel(column, cellValue) {\n    if (cellValue) {\n        switch (column.cellType) {\n            case 'string':\n                return xe_utils_1.default.toValueString(cellValue);\n            case 'number':\n                if (!isNaN(cellValue)) {\n                    return Number(cellValue);\n                }\n                break;\n            default:\n                if (cellValue.length < 12 && !isNaN(cellValue)) {\n                    return Number(cellValue);\n                }\n                break;\n        }\n    }\n    return cellValue;\n}\nfunction getFooterCellValue($table, opts, rows, column) {\n    var cellValue = xe_utils_1.default.toString(rows[$table.$getColumnIndex(column)]);\n    return cellValue;\n}\nfunction toBuffer(wbout) {\n    var buf = new ArrayBuffer(wbout.length);\n    var view = new Uint8Array(buf);\n    for (var index = 0; index !== wbout.length; ++index)\n        view[index] = wbout.charCodeAt(index) & 0xFF;\n    return buf;\n}\nfunction exportXLSX(params) {\n    var $table = params.$table, options = params.options, columns = params.columns, datas = params.datas;\n    var sheetName = options.sheetName, type = options.type, isHeader = options.isHeader, isFooter = options.isFooter, original = options.original, message = options.message, footerFilterMethod = options.footerFilterMethod;\n    var colHead = {};\n    var footList = [];\n    // const rowList = datas\n    if (isHeader) {\n        columns.forEach(function (column) {\n            colHead[column.id] = xe_utils_1.default.toString(original ? column.property : column.getTitle());\n        });\n    }\n    // 新增部分\n    var rowList = datas.map(function (item) {\n        var rest = {};\n        columns.forEach(function (column) {\n            rest[column.id] = getCellLabel(column, item[column.id]);\n        });\n        return rest;\n    });\n    if (isFooter) {\n        var footerData = $table.getTableData().footerData;\n        var footers = footerFilterMethod ? footerData.filter(footerFilterMethod) : footerData;\n        footers.forEach(function (rows) {\n            var item = {};\n            columns.forEach(function (column) {\n                item[column.id] = getFooterCellValue($table, options, rows, column);\n            });\n            footList.push(item);\n        });\n    }\n    var book = xlsx_1.default.utils.book_new();\n    var sheet = xlsx_1.default.utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), { skipHeader: true });\n    // 转换数据\n    xlsx_1.default.utils.book_append_sheet(book, sheet, sheetName);\n    var wbout = xlsx_1.default.write(book, { bookType: type, bookSST: false, type: 'binary' });\n    var blob = new Blob([toBuffer(wbout)], { type: 'application/octet-stream' });\n    // 保存导出\n    downloadFile(blob, options);\n    if (message !== false) {\n        _vxetable.modal.message({ message: _vxetable.t('vxe.table.expSuccess'), status: 'success' });\n    }\n}\nfunction downloadFile(blob, options) {\n    if (window.Blob) {\n        var filename = options.filename, type = options.type;\n        if (navigator.msSaveBlob) {\n            navigator.msSaveBlob(blob, filename + \".\" + type);\n        }\n        else {\n            var linkElem = document.createElement('a');\n            linkElem.target = '_blank';\n            linkElem.download = filename + \".\" + type;\n            linkElem.href = URL.createObjectURL(blob);\n            document.body.appendChild(linkElem);\n            linkElem.click();\n            document.body.removeChild(linkElem);\n        }\n    }\n    else {\n        console.error(_vxetable.t('vxe.error.notExp'));\n    }\n}\nfunction replaceDoubleQuotation(val) {\n    return val.replace(/^\"/, '').replace(/\"$/, '');\n}\nfunction parseCsv(columns, content) {\n    var list = content.split('\\n');\n    var fields = [];\n    var rows = [];\n    if (list.length) {\n        var rList = list.slice(1);\n        list[0].split(',').map(replaceDoubleQuotation);\n        rList.forEach(function (r) {\n            if (r) {\n                var item_1 = {};\n                r.split(',').forEach(function (val, colIndex) {\n                    if (fields[colIndex]) {\n                        item_1[fields[colIndex]] = replaceDoubleQuotation(val);\n                    }\n                });\n                rows.push(item_1);\n            }\n        });\n    }\n    return { fields: fields, rows: rows };\n}\nfunction checkImportData(columns, fields, rows) {\n    var tableFields = [];\n    columns.forEach(function (column) {\n        var field = column.property;\n        if (field) {\n            tableFields.push(field);\n        }\n    });\n    return tableFields.every(function (field) { return fields.includes(field); });\n}\nfunction importXLSX(params) {\n    var columns = params.columns, options = params.options, file = params.file;\n    var $table = params.$table;\n    var _importResolve = $table._importResolve;\n    var fileReader = new FileReader();\n    fileReader.onload = function (e) {\n        var workbook = xlsx_1.default.read(e.target.result, { type: 'binary' });\n        var csvData = xlsx_1.default.utils.sheet_to_csv(workbook.Sheets.Sheet1);\n        var _a = parseCsv(columns, csvData), fields = _a.fields, rows = _a.rows;\n        var status = checkImportData(columns, fields, rows);\n        if (status) {\n            $table.createData(rows)\n                .then(function (data) {\n                if (options.mode === 'append') {\n                    $table.insertAt(data, -1);\n                }\n                else {\n                    $table.reloadData(data);\n                }\n            });\n            if (options.message !== false) {\n                _vxetable.modal.message({ message: xe_utils_1.default.template(_vxetable.t('vxe.table.impSuccess'), [rows.length]), status: 'success' });\n            }\n        }\n        else if (options.message !== false) {\n            _vxetable.modal.message({ message: _vxetable.t('vxe.error.impFields'), status: 'error' });\n        }\n        if (_importResolve) {\n            _importResolve(status);\n            $table._importResolve = null;\n        }\n    };\n    fileReader.readAsBinaryString(file);\n}\nfunction handleImportEvent(params) {\n    if (params.options.type === 'xlsx') {\n        importXLSX(params);\n        return false;\n    }\n}\nfunction handleExportEvent(params) {\n    if (params.options.type === 'xlsx') {\n        exportXLSX(params);\n        return false;\n    }\n}\n/**\n * 基于 vxe-table 表格的增强插件，支持导出 xlsx 格式\n */\nexports.VXETablePluginExportXLSX = {\n    install: function (xtable) {\n        var interceptor = xtable.interceptor;\n        _vxetable = xtable;\n        Object.assign(xtable.types, { xlsx: 1 });\n        interceptor.mixin({\n            'event.import': handleImportEvent,\n            'event.export': handleExportEvent\n        });\n    }\n};\nif (typeof window !== 'undefined' && window.VXETable) {\n    window.VXETable.use(exports.VXETablePluginExportXLSX);\n}\nexports.default = exports.VXETablePluginExportXLSX;\n","/* eslint-disable no-unused-vars */\r\nimport XEUtils from 'xe-utils/methods/xe-utils'\r\nimport {\r\n  VXETable,\r\n  Table,\r\n  InterceptorExportParams,\r\n  InterceptorImportParams,\r\n  ColumnConfig,\r\n  ExportOptons\r\n} from 'vxe-table/lib/vxe-table'\r\nimport XLSX from 'xlsx'\r\n/* eslint-enable no-unused-vars */\r\n\r\nlet _vxetable: typeof VXETable\r\n\r\n\r\nfunction getCellLabel (column: ColumnConfig, cellValue: any) {\r\n  if (cellValue) {\r\n    switch (column.cellType) {\r\n      case 'string':\r\n        return XEUtils.toValueString(cellValue)\r\n      case 'number':\r\n        if (!isNaN(cellValue)) {\r\n          return Number(cellValue)\r\n        }\r\n        break\r\n      default:\r\n        if (cellValue.length < 12 && !isNaN(cellValue)) {\r\n          return Number(cellValue)\r\n        }\r\n        break\r\n    }\r\n  }\r\n  return cellValue\r\n}\r\n\r\n\r\n\r\nfunction getFooterCellValue ($table: Table, opts: ExportOptons, rows: any[], column: ColumnConfig) {\r\n  var cellValue = XEUtils.toString(rows[$table.$getColumnIndex(column)])\r\n  return cellValue\r\n}\r\n\r\nfunction toBuffer (wbout: any) {\r\n  let buf = new ArrayBuffer(wbout.length)\r\n  let view = new Uint8Array(buf)\r\n  for (let index = 0; index !== wbout.length; ++index) view[index] = wbout.charCodeAt(index) & 0xFF\r\n  return buf\r\n}\r\n\r\nfunction exportXLSX (params: InterceptorExportParams) {\r\n  const { $table, options, columns, datas } = params\r\n  const { sheetName, type, isHeader, isFooter, original, message, footerFilterMethod } = options\r\n  const colHead: { [key: string]: any } = {}\r\n  const footList: { [key: string]: any }[] = []\r\n  // const rowList = datas\r\n\r\n  if (isHeader) {\r\n    columns.forEach((column) => {\r\n      colHead[column.id] = XEUtils.toString(original ? column.property : column.getTitle())\r\n    })\r\n  }\r\n\r\n  // 新增部分\r\n  const rowList = datas.map(item => {\r\n    const rest: any = {}\r\n    columns.forEach((column) => {\r\n      rest[column.id] = getCellLabel(column, item[column.id])\r\n    })\r\n    return rest\r\n  })\r\n\r\n  if (isFooter) {\r\n    const { footerData } = $table.getTableData()\r\n    const footers = footerFilterMethod ? footerData.filter(footerFilterMethod) : footerData\r\n    footers.forEach((rows) => {\r\n      const item: { [key: string]: any } = {}\r\n      columns.forEach((column) => {\r\n        item[column.id] = getFooterCellValue($table, options, rows, column)\r\n      })\r\n      footList.push(item)\r\n    })\r\n  }\r\n  const book = XLSX.utils.book_new()\r\n  const sheet = XLSX.utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), { skipHeader: true })\r\n  // 转换数据\r\n  XLSX.utils.book_append_sheet(book, sheet, sheetName)\r\n  const wbout = XLSX.write(book, { bookType: type, bookSST: false, type: 'binary' })\r\n  const blob = new Blob([toBuffer(wbout)], { type: 'application/octet-stream' })\r\n  // 保存导出\r\n  downloadFile(blob, options)\r\n  if (message !== false) {\r\n    _vxetable.modal.message({ message: _vxetable.t('vxe.table.expSuccess'), status: 'success' })\r\n  }\r\n}\r\n\r\nfunction downloadFile (blob: Blob, options: ExportOptons) {\r\n  if (window.Blob) {\r\n    const { filename, type } = options\r\n    if (navigator.msSaveBlob) {\r\n      navigator.msSaveBlob(blob, `${filename}.${type}`)\r\n    } else {\r\n      var linkElem = document.createElement('a')\r\n      linkElem.target = '_blank'\r\n      linkElem.download = `${filename}.${type}`\r\n      linkElem.href = URL.createObjectURL(blob)\r\n      document.body.appendChild(linkElem)\r\n      linkElem.click()\r\n      document.body.removeChild(linkElem)\r\n    }\r\n  } else {\r\n    console.error(_vxetable.t('vxe.error.notExp'))\r\n  }\r\n}\r\n\r\nfunction replaceDoubleQuotation (val: string) {\r\n  return val.replace(/^\"/, '').replace(/\"$/, '')\r\n}\r\n\r\nfunction parseCsv (columns: ColumnConfig[], content: string) {\r\n  const list = content.split('\\n')\r\n  const fields: string[] = []\r\n  const rows: any[] = []\r\n  if (list.length) {\r\n    const rList = list.slice(1)\r\n    list[0].split(',').map(replaceDoubleQuotation)\r\n    rList.forEach((r) => {\r\n      if (r) {\r\n        const item: { [key: string]: any } = {}\r\n        r.split(',').forEach((val, colIndex) => {\r\n          if (fields[colIndex]) {\r\n            item[fields[colIndex]] = replaceDoubleQuotation(val)\r\n          }\r\n        })\r\n        rows.push(item)\r\n      }\r\n    })\r\n  }\r\n  return { fields, rows }\r\n}\r\n\r\nfunction checkImportData (columns: ColumnConfig[], fields: string[], rows: any[]) {\r\n  let tableFields: string[] = []\r\n  columns.forEach((column) => {\r\n    let field = column.property\r\n    if (field) {\r\n      tableFields.push(field)\r\n    }\r\n  })\r\n  return tableFields.every((field) => fields.includes(field))\r\n}\r\n\r\nfunction importXLSX (params: InterceptorImportParams) {\r\n  const { columns, options, file } = params\r\n  const $table: any = params.$table\r\n  const { _importResolve } = $table\r\n  const fileReader = new FileReader()\r\n  fileReader.onload = (e: any) => {\r\n    const workbook = XLSX.read(e.target.result, { type: 'binary' })\r\n    const csvData: string = XLSX.utils.sheet_to_csv(workbook.Sheets.Sheet1)\r\n    const { fields, rows } = parseCsv(columns, csvData)\r\n    const status = checkImportData(columns, fields, rows)\r\n    if (status) {\r\n      $table.createData(rows)\r\n        .then((data: any[]) => {\r\n          if (options.mode === 'append') {\r\n            $table.insertAt(data, -1)\r\n          } else {\r\n            $table.reloadData(data)\r\n          }\r\n        })\r\n      if (options.message !== false) {\r\n        _vxetable.modal.message({ message: XEUtils.template(_vxetable.t('vxe.table.impSuccess'), [rows.length]), status: 'success' })\r\n      }\r\n    } else if (options.message !== false) {\r\n      _vxetable.modal.message({ message: _vxetable.t('vxe.error.impFields'), status: 'error' })\r\n    }\r\n    if (_importResolve) {\r\n      _importResolve(status)\r\n      $table._importResolve = null\r\n    }\r\n  }\r\n  fileReader.readAsBinaryString(file)\r\n}\r\n\r\nfunction handleImportEvent (params: InterceptorImportParams) {\r\n  if (params.options.type === 'xlsx') {\r\n    importXLSX(params)\r\n    return false\r\n  }\r\n}\r\n\r\nfunction handleExportEvent (params: InterceptorExportParams) {\r\n  if (params.options.type === 'xlsx') {\r\n    exportXLSX(params)\r\n    return false\r\n  }\r\n}\r\n\r\n/**\r\n * 基于 vxe-table 表格的增强插件，支持导出 xlsx 格式\r\n */\r\nexport const VXETablePluginExportXLSX = {\r\n  install (xtable: typeof VXETable) {\r\n    const { interceptor } = xtable\r\n    _vxetable = xtable\r\n    Object.assign(xtable.types, { xlsx: 1 })\r\n    interceptor.mixin({\r\n      'event.import': handleImportEvent,\r\n      'event.export': handleExportEvent\r\n    })\r\n  }\r\n}\r\n\r\nif (typeof window !== 'undefined' && window.VXETable) {\r\n  window.VXETable.use(VXETablePluginExportXLSX)\r\n}\r\n\r\nexport default VXETablePluginExportXLSX\r\n"]}