mirror of
https://gitee.com/x-extends/vxe-table-plugin-export-xlsx.git
synced 2026-01-21 05:21:33 +08:00
121 lines
12 KiB
JavaScript
121 lines
12 KiB
JavaScript
"use strict";
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports["default"] = exports.VXETablePluginExport = void 0;
|
|
|
|
var _xeUtils = _interopRequireDefault(require("xe-utils/methods/xe-utils"));
|
|
|
|
var XLSX = _interopRequireWildcard(require("xlsx"));
|
|
|
|
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
|
|
|
|
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; if (obj != null) { var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
|
|
function toBuffer(wbout) {
|
|
var buf = new ArrayBuffer(wbout.length);
|
|
var view = new Uint8Array(buf);
|
|
|
|
for (var index = 0; index !== wbout.length; ++index) {
|
|
view[index] = wbout.charCodeAt(index) & 0xFF;
|
|
}
|
|
|
|
return buf;
|
|
}
|
|
|
|
function toXLSX(params) {
|
|
var options = params.options,
|
|
columns = params.columns,
|
|
datas = params.datas;
|
|
var filename = options.filename,
|
|
sheetName = options.sheetName,
|
|
type = options.type,
|
|
isHeader = options.isHeader,
|
|
original = options.original;
|
|
var colHead = {};
|
|
|
|
if (isHeader) {
|
|
columns.forEach(function (column) {
|
|
colHead[column.id] = column.getTitle();
|
|
});
|
|
}
|
|
|
|
var rowList = datas.map(function (row) {
|
|
var item = {};
|
|
columns.forEach(function (column) {
|
|
item[column.id] = original ? _xeUtils["default"].get(row, column.property) : row[column.id];
|
|
});
|
|
return item;
|
|
});
|
|
var book = XLSX.utils.book_new();
|
|
var sheet = XLSX.utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList), {
|
|
skipHeader: true
|
|
}); // 转换数据
|
|
|
|
XLSX.utils.book_append_sheet(book, sheet, sheetName);
|
|
var wbout = XLSX.write(book, {
|
|
bookType: type,
|
|
bookSST: false,
|
|
type: 'binary'
|
|
});
|
|
var blob = new Blob([toBuffer(wbout)], {
|
|
type: 'application/octet-stream'
|
|
}); // 保存导出
|
|
|
|
download(blob, options);
|
|
}
|
|
|
|
function download(blob, options) {
|
|
if (window.Blob) {
|
|
var filename = options.filename,
|
|
type = options.type;
|
|
|
|
if (navigator.msSaveBlob) {
|
|
navigator.msSaveBlob(blob, filename);
|
|
} else {
|
|
var linkElem = document.createElement('a');
|
|
linkElem.target = '_blank';
|
|
linkElem.download = "".concat(filename, ".").concat(type);
|
|
linkElem.href = URL.createObjectURL(blob);
|
|
document.body.appendChild(linkElem);
|
|
linkElem.click();
|
|
document.body.removeChild(linkElem);
|
|
}
|
|
} else {
|
|
console.error('[vxe-table-plugin-export] The current environment does not support exports.');
|
|
}
|
|
}
|
|
|
|
function handleExportEvent(params) {
|
|
switch (params.options.type) {
|
|
case 'xlsx':
|
|
toXLSX(params);
|
|
return false;
|
|
}
|
|
}
|
|
/**
|
|
* 基于 vxe-table 表格的增强插件,支持导出 xlsx 等格式
|
|
*/
|
|
|
|
|
|
var VXETablePluginExport = {
|
|
install: function install(xtable) {
|
|
Object.assign(xtable.types, {
|
|
xlsx: 1
|
|
});
|
|
xtable.interceptor.add('event.export', handleExportEvent);
|
|
}
|
|
};
|
|
exports.VXETablePluginExport = VXETablePluginExport;
|
|
|
|
if (typeof window !== 'undefined' && window.VXETable) {
|
|
window.VXETable.use(VXETablePluginExport);
|
|
}
|
|
|
|
var _default = VXETablePluginExport;
|
|
exports["default"] = _default;
|
|
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.ts"],"names":["toBuffer","wbout","buf","ArrayBuffer","length","view","Uint8Array","index","charCodeAt","toXLSX","params","options","columns","datas","filename","sheetName","type","isHeader","original","colHead","forEach","column","id","getTitle","rowList","map","row","item","XEUtils","get","property","book","XLSX","utils","book_new","sheet","json_to_sheet","concat","skipHeader","book_append_sheet","write","bookType","bookSST","blob","Blob","download","window","navigator","msSaveBlob","linkElem","document","createElement","target","href","URL","createObjectURL","body","appendChild","click","removeChild","console","error","handleExportEvent","VXETablePluginExport","install","xtable","Object","assign","types","xlsx","interceptor","add","VXETable","use"],"mappings":"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","file":"index.common.js","sourcesContent":["import XEUtils from 'xe-utils/methods/xe-utils'\r\nimport VXETable from 'vxe-table/lib/vxe-table'\r\nimport * as XLSX from 'xlsx'\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 toXLSX(params: any) {\r\n  const { options, columns, datas } = params\r\n  const { filename, sheetName, type, isHeader, original } = options\r\n  const colHead: any = {}\r\n  if (isHeader) {\r\n    columns.forEach((column: any) => {\r\n      colHead[column.id] = column.getTitle()\r\n    })\r\n  }\r\n  const rowList = datas.map((row: any) => {\r\n    const item: any = {}\r\n    columns.forEach((column: any) => {\r\n      item[column.id] = original ? XEUtils.get(row, column.property) : row[column.id]\r\n    })\r\n    return item\r\n  })\r\n  const book = XLSX.utils.book_new()\r\n  const sheet = XLSX.utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList), { 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  download(blob, options)\r\n}\r\n\r\nfunction download(blob: Blob, options: any) {\r\n  if (window.Blob) {\r\n    const { filename, type } = options\r\n    if (navigator.msSaveBlob) {\r\n      navigator.msSaveBlob(blob, filename)\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('[vxe-table-plugin-export] The current environment does not support exports.')\r\n  }\r\n}\r\n\r\nfunction handleExportEvent(params: any) {\r\n  switch (params.options.type) {\r\n    case 'xlsx':\r\n      toXLSX(params)\r\n      return false\r\n  }\r\n}\r\n\r\n/**\r\n * 基于 vxe-table 表格的增强插件，支持导出 xlsx 等格式\r\n */\r\nexport const VXETablePluginExport = {\r\n  install(xtable: typeof VXETable) {\r\n    Object.assign(xtable.types, { xlsx: 1 })\r\n    xtable.interceptor.add('event.export', handleExportEvent)\r\n  }\r\n}\r\n\r\nif (typeof window !== 'undefined' && window.VXETable) {\r\n  window.VXETable.use(VXETablePluginExport)\r\n}\r\n\r\nexport default VXETablePluginExport\r\n"]}
|