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

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,259 +1,243 @@
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
+ exports["default"] = exports.VXETablePluginExportXLSX = void 0;
7
+ var _xeUtils = _interopRequireDefault(require("xe-utils/methods/xe-utils"));
8
+ var _xlsx = _interopRequireDefault(require("xlsx"));
9
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
10
+ /* eslint-disable no-unused-vars */
11
+
12
+ /* eslint-enable no-unused-vars */
13
+ var _vxetable;
14
+ function getCellLabel(column, cellValue) {
15
+ if (cellValue) {
16
+ switch (column.cellType) {
17
+ case 'string':
18
+ return _xeUtils["default"].toValueString(cellValue);
19
+ case 'number':
20
+ if (!isNaN(cellValue)) {
21
+ return Number(cellValue);
22
+ }
23
+ break;
24
+ default:
25
+ if (cellValue.length < 12 && !isNaN(cellValue)) {
26
+ return Number(cellValue);
27
+ }
28
+ break;
29
+ }
30
+ }
31
+ return cellValue;
32
+ }
33
+ function getFooterCellValue($table, opts, rows, column) {
34
+ var cellValue = _xeUtils["default"].toString(rows[$table.$getColumnIndex(column)]);
35
+ return cellValue;
36
+ }
37
+ function toBuffer(wbout) {
38
+ var buf = new ArrayBuffer(wbout.length);
39
+ var view = new Uint8Array(buf);
40
+ for (var index = 0; index !== wbout.length; ++index) {
41
+ view[index] = wbout.charCodeAt(index) & 0xFF;
42
+ }
43
+ return buf;
44
+ }
45
+ function exportXLSX(params) {
46
+ var $table = params.$table,
47
+ options = params.options,
48
+ columns = params.columns,
49
+ datas = params.datas;
50
+ var sheetName = options.sheetName,
51
+ type = options.type,
52
+ isHeader = options.isHeader,
53
+ isFooter = options.isFooter,
54
+ original = options.original,
55
+ message = options.message,
56
+ footerFilterMethod = options.footerFilterMethod;
57
+ var colHead = {};
58
+ var footList = [];
59
+ // const rowList = datas
60
+ if (isHeader) {
61
+ columns.forEach(function (column) {
62
+ colHead[column.id] = _xeUtils["default"].toString(original ? column.property : column.getTitle());
63
+ });
64
+ }
65
+ // 新增部分
66
+ var rowList = datas.map(function (item) {
67
+ var rest = {};
68
+ columns.forEach(function (column) {
69
+ rest[column.id] = getCellLabel(column, item[column.id]);
70
+ });
71
+ return rest;
72
+ });
73
+ if (isFooter) {
74
+ var _$table$getTableData = $table.getTableData(),
75
+ footerData = _$table$getTableData.footerData;
76
+ var footers = footerFilterMethod ? footerData.filter(footerFilterMethod) : footerData;
77
+ footers.forEach(function (rows) {
78
+ var item = {};
79
+ columns.forEach(function (column) {
80
+ item[column.id] = getFooterCellValue($table, options, rows, column);
81
+ });
82
+ footList.push(item);
83
+ });
84
+ }
85
+ var book = _xlsx["default"].utils.book_new();
86
+ var sheet = _xlsx["default"].utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), {
87
+ skipHeader: true
88
+ });
89
+ // 转换数据
90
+ _xlsx["default"].utils.book_append_sheet(book, sheet, sheetName);
91
+ var wbout = _xlsx["default"].write(book, {
92
+ bookType: type,
93
+ bookSST: false,
94
+ type: 'binary'
95
+ });
96
+ var blob = new Blob([toBuffer(wbout)], {
97
+ type: 'application/octet-stream'
98
+ });
99
+ // 保存导出
100
+ downloadFile(blob, options);
101
+ if (message !== false) {
102
+ _vxetable.modal.message({
103
+ message: _vxetable.t('vxe.table.expSuccess'),
104
+ status: 'success'
105
+ });
106
+ }
107
+ }
108
+ function downloadFile(blob, options) {
109
+ if (window.Blob) {
110
+ var filename = options.filename,
111
+ type = options.type;
112
+ if (navigator.msSaveBlob) {
113
+ navigator.msSaveBlob(blob, "".concat(filename, ".").concat(type));
114
+ } else {
115
+ var linkElem = document.createElement('a');
116
+ linkElem.target = '_blank';
117
+ linkElem.download = "".concat(filename, ".").concat(type);
118
+ linkElem.href = URL.createObjectURL(blob);
119
+ document.body.appendChild(linkElem);
120
+ linkElem.click();
121
+ document.body.removeChild(linkElem);
122
+ }
123
+ } else {
124
+ console.error(_vxetable.t('vxe.error.notExp'));
125
+ }
126
+ }
127
+ function replaceDoubleQuotation(val) {
128
+ return val.replace(/^"/, '').replace(/"$/, '');
129
+ }
130
+ function parseCsv(columns, content) {
131
+ var list = content.split('\n');
132
+ var fields = [];
133
+ var rows = [];
134
+ if (list.length) {
135
+ var rList = list.slice(1);
136
+ list[0].split(',').map(replaceDoubleQuotation);
137
+ rList.forEach(function (r) {
138
+ if (r) {
139
+ var item = {};
140
+ r.split(',').forEach(function (val, colIndex) {
141
+ if (fields[colIndex]) {
142
+ item[fields[colIndex]] = replaceDoubleQuotation(val);
143
+ }
144
+ });
145
+ rows.push(item);
146
+ }
147
+ });
148
+ }
149
+ return {
150
+ fields: fields,
151
+ rows: rows
152
+ };
153
+ }
154
+ function checkImportData(columns, fields, rows) {
155
+ var tableFields = [];
156
+ columns.forEach(function (column) {
157
+ var field = column.property;
158
+ if (field) {
159
+ tableFields.push(field);
160
+ }
161
+ });
162
+ return tableFields.every(function (field) {
163
+ return fields.includes(field);
164
+ });
165
+ }
166
+ function importXLSX(params) {
167
+ var columns = params.columns,
168
+ options = params.options,
169
+ file = params.file;
170
+ var $table = params.$table;
171
+ var _importResolve = $table._importResolve;
172
+ var fileReader = new FileReader();
173
+ fileReader.onload = function (e) {
174
+ var workbook = _xlsx["default"].read(e.target.result, {
175
+ type: 'binary'
176
+ });
177
+ var csvData = _xlsx["default"].utils.sheet_to_csv(workbook.Sheets.Sheet1);
178
+ var _parseCsv = parseCsv(columns, csvData),
179
+ fields = _parseCsv.fields,
180
+ rows = _parseCsv.rows;
181
+ var status = checkImportData(columns, fields, rows);
182
+ if (status) {
183
+ $table.createData(rows).then(function (data) {
184
+ if (options.mode === 'append') {
185
+ $table.insertAt(data, -1);
186
+ } else {
187
+ $table.reloadData(data);
188
+ }
189
+ });
190
+ if (options.message !== false) {
191
+ _vxetable.modal.message({
192
+ message: _xeUtils["default"].template(_vxetable.t('vxe.table.impSuccess'), [rows.length]),
193
+ status: 'success'
194
+ });
195
+ }
196
+ } else if (options.message !== false) {
197
+ _vxetable.modal.message({
198
+ message: _vxetable.t('vxe.error.impFields'),
199
+ status: 'error'
200
+ });
201
+ }
202
+ if (_importResolve) {
203
+ _importResolve(status);
204
+ $table._importResolve = null;
205
+ }
206
+ };
207
+ fileReader.readAsBinaryString(file);
208
+ }
209
+ function handleImportEvent(params) {
210
+ if (params.options.type === 'xlsx') {
211
+ importXLSX(params);
212
+ return false;
213
+ }
214
+ }
215
+ function handleExportEvent(params) {
216
+ if (params.options.type === 'xlsx') {
217
+ exportXLSX(params);
218
+ return false;
219
+ }
220
+ }
221
+ /**
222
+ * 基于 vxe-table 表格的增强插件,支持导出 xlsx 格式
223
+ */
224
+ var VXETablePluginExportXLSX = {
225
+ install: function install(xtable) {
226
+ var interceptor = xtable.interceptor;
227
+ _vxetable = xtable;
228
+ Object.assign(xtable.types, {
229
+ xlsx: 1
230
+ });
231
+ interceptor.mixin({
232
+ 'event.import': handleImportEvent,
233
+ 'event.export': handleExportEvent
234
+ });
235
+ }
236
+ };
237
+ exports.VXETablePluginExportXLSX = VXETablePluginExportXLSX;
238
+ if (typeof window !== 'undefined' && window.VXETable) {
239
+ window.VXETable.use(VXETablePluginExportXLSX);
240
+ }
241
+ var _default = VXETablePluginExportXLSX;
242
+ exports["default"] = _default;
243
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.ts","index.js"],"names":["_vxetable","getCellLabel","column","cellValue","cellType","XEUtils","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","getTableData","footerData","footers","filter","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","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\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","/* eslint-disable no-unused-vars */\nimport XEUtils from 'xe-utils/methods/xe-utils';\nimport XLSX from 'xlsx';\n/* eslint-enable no-unused-vars */\nlet _vxetable;\nfunction getCellLabel(column, cellValue) {\n    if (cellValue) {\n        switch (column.cellType) {\n            case 'string':\n                return XEUtils.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 = XEUtils.toString(rows[$table.$getColumnIndex(column)]);\n    return cellValue;\n}\nfunction toBuffer(wbout) {\n    let buf = new ArrayBuffer(wbout.length);\n    let view = new Uint8Array(buf);\n    for (let index = 0; index !== wbout.length; ++index)\n        view[index] = wbout.charCodeAt(index) & 0xFF;\n    return buf;\n}\nfunction exportXLSX(params) {\n    const { $table, options, columns, datas } = params;\n    const { sheetName, type, isHeader, isFooter, original, message, footerFilterMethod } = options;\n    const colHead = {};\n    const footList = [];\n    // const rowList = datas\n    if (isHeader) {\n        columns.forEach((column) => {\n            colHead[column.id] = XEUtils.toString(original ? column.property : column.getTitle());\n        });\n    }\n    // 新增部分\n    const rowList = datas.map(item => {\n        const rest = {};\n        columns.forEach((column) => {\n            rest[column.id] = getCellLabel(column, item[column.id]);\n        });\n        return rest;\n    });\n    if (isFooter) {\n        const { footerData } = $table.getTableData();\n        const footers = footerFilterMethod ? footerData.filter(footerFilterMethod) : footerData;\n        footers.forEach((rows) => {\n            const item = {};\n            columns.forEach((column) => {\n                item[column.id] = getFooterCellValue($table, options, rows, column);\n            });\n            footList.push(item);\n        });\n    }\n    const book = XLSX.utils.book_new();\n    const sheet = XLSX.utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), { skipHeader: true });\n    // 转换数据\n    XLSX.utils.book_append_sheet(book, sheet, sheetName);\n    const wbout = XLSX.write(book, { bookType: type, bookSST: false, type: 'binary' });\n    const 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        const { filename, type } = options;\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    const list = content.split('\\n');\n    const fields = [];\n    const rows = [];\n    if (list.length) {\n        const rList = list.slice(1);\n        list[0].split(',').map(replaceDoubleQuotation);\n        rList.forEach((r) => {\n            if (r) {\n                const item = {};\n                r.split(',').forEach((val, colIndex) => {\n                    if (fields[colIndex]) {\n                        item[fields[colIndex]] = replaceDoubleQuotation(val);\n                    }\n                });\n                rows.push(item);\n            }\n        });\n    }\n    return { fields, rows };\n}\nfunction checkImportData(columns, fields, rows) {\n    let tableFields = [];\n    columns.forEach((column) => {\n        let field = column.property;\n        if (field) {\n            tableFields.push(field);\n        }\n    });\n    return tableFields.every((field) => fields.includes(field));\n}\nfunction importXLSX(params) {\n    const { columns, options, file } = params;\n    const $table = params.$table;\n    const { _importResolve } = $table;\n    const fileReader = new FileReader();\n    fileReader.onload = (e) => {\n        const workbook = XLSX.read(e.target.result, { type: 'binary' });\n        const csvData = XLSX.utils.sheet_to_csv(workbook.Sheets.Sheet1);\n        const { fields, rows } = parseCsv(columns, csvData);\n        const status = checkImportData(columns, fields, rows);\n        if (status) {\n            $table.createData(rows)\n                .then((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: XEUtils.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 */\nexport const VXETablePluginExportXLSX = {\n    install(xtable) {\n        const { interceptor } = xtable;\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(VXETablePluginExportXLSX);\n}\nexport default VXETablePluginExportXLSX;\n"]}