Files
vxe-table-plugin-export-xlsx/dist/index.common.js
xuliangzhan 0c2b1bd9d0 update
2019-12-03 14:58:19 +08:00

283 lines
28 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = exports.VXETablePluginExportXLSX = void 0;
var _xeUtils = _interopRequireDefault(require("xe-utils/methods/xe-utils"));
var _xlsx = _interopRequireDefault(require("xlsx"));
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 exportXLSX(params) {
var $table = params.$table,
options = params.options,
columns = params.columns,
datas = params.datas;
var sheetName = options.sheetName,
type = options.type,
isHeader = options.isHeader,
isFooter = options.isFooter,
original = options.original,
message = options.message,
footerFilterMethod = options.footerFilterMethod;
var colHead = {};
var footList = [];
if (isHeader) {
columns.forEach(function (column) {
colHead[column.id] = _xeUtils["default"].toString(original ? column.property : column.getTitle());
});
}
var rowList = datas.map(function (row, rowIndex) {
var item = {};
columns.forEach(function (column, columnIndex) {
var cellValue;
var property = column.property;
var isIndex = column.type === 'index';
if (!original || isIndex) {
cellValue = isIndex ? column.indexMethod ? column.indexMethod({
row: row,
rowIndex: rowIndex,
column: column,
columnIndex: columnIndex
}) : rowIndex + 1 : row[column.id];
} else {
cellValue = _xeUtils["default"].get(row, property);
}
item[column.id] = cellValue;
});
return item;
});
if (isFooter) {
var footerData = $table.footerData;
var footers = footerFilterMethod ? footerData.filter(footerFilterMethod) : footerData;
footers.forEach(function (rows) {
var item = {};
columns.forEach(function (column) {
item[column.id] = rows[$table.$getColumnIndex(column)] || '';
});
footList.push(item);
});
}
var book = _xlsx["default"].utils.book_new();
var sheet = _xlsx["default"].utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), {
skipHeader: true
}); // 转换数据
_xlsx["default"].utils.book_append_sheet(book, sheet, sheetName);
var wbout = _xlsx["default"].write(book, {
bookType: type,
bookSST: false,
type: 'binary'
});
var blob = new Blob([toBuffer(wbout)], {
type: 'application/octet-stream'
}); // 保存导出
downloadFile(blob, options);
if (message !== false) {
$table.$XModal.message({
message: i18n('vxe.table.expSuccess'),
status: 'success'
});
}
}
function downloadFile(blob, options) {
if (window.Blob) {
var filename = options.filename,
type = options.type;
if (navigator.msSaveBlob) {
navigator.msSaveBlob(blob, "".concat(filename, ".").concat(type));
} 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(i18n('vxe.error.notExp'));
}
}
function replaceDoubleQuotation(val) {
return val.replace(/^"/, '').replace(/"$/, '');
}
function parseCsv(columns, content) {
var list = content.split('\n');
var fields = [];
var rows = [];
if (list.length) {
var rList = list.slice(1);
list[0].split(',').forEach(function (val) {
var field = replaceDoubleQuotation(val);
if (field) {
fields.push(field);
}
});
rList.forEach(function (r) {
if (r) {
var item = {};
r.split(',').forEach(function (val, colIndex) {
item[fields[colIndex]] = replaceDoubleQuotation(val);
});
rows.push(item);
}
});
}
return {
fields: fields,
rows: rows
};
}
function checkImportData(columns, fields, rows) {
var tableFields = [];
columns.forEach(function (column) {
var field = column.property;
if (field) {
tableFields.push(field);
}
});
return tableFields.every(function (field) {
return fields.includes(field);
});
}
function importXLSX(params) {
var $table = params.$table,
columns = params.columns,
options = params.options,
file = params.file;
var _importCallback = $table._importCallback,
_importResolve = $table._importResolve;
var fileReader = new FileReader();
fileReader.onload = function (e) {
var workbook = _xlsx["default"].read(e.target.result, {
type: 'binary'
});
var csvData = _xlsx["default"].utils.sheet_to_csv(workbook.Sheets.Sheet1);
var rest = parseCsv(columns, csvData);
var fields = rest.fields,
rows = rest.rows;
var status = checkImportData(columns, fields, rows);
if (status) {
$table.createData(rows).then(function (data) {
if (options.mode === 'append') {
$table.insertAt(data, -1);
} else {
$table.reloadData(data);
}
});
if (options.message !== false) {
$table.$XModal.message({
message: i18n('vxe.table.impSuccess'),
status: 'success'
});
}
} else if (options.message !== false) {
$table.$XModal.message({
message: i18n('vxe.error.impFields'),
status: 'error'
});
}
if (_importResolve) {
_importResolve(status);
$table._importResolve = null;
} else if (_importCallback) {
// 已废弃
_importCallback(status);
$table._importCallback = null;
}
};
fileReader.readAsBinaryString(file);
}
function handleImportEvent(params) {
if (params.options.type === 'xlsx') {
importXLSX(params);
return false;
}
}
function handleExportEvent(params) {
if (params.options.type === 'xlsx') {
exportXLSX(params);
return false;
}
}
/**
* 基于 vxe-table 表格的增强插件,支持导出 xlsx 格式
*/
var VXETablePluginExportXLSX = {
install: function install(xtable) {
Object.assign(xtable.types, {
xlsx: 1
});
xtable.interceptor.mixin({
'event.import': handleImportEvent,
'event.export': handleExportEvent
});
VXETablePluginExportXLSX.t = xtable.t;
}
};
exports.VXETablePluginExportXLSX = VXETablePluginExportXLSX;
function i18n(key) {
if (VXETablePluginExportXLSX.t) {
return VXETablePluginExportXLSX.t(key);
}
}
if (typeof window !== 'undefined' && window.VXETable) {
window.VXETable.use(VXETablePluginExportXLSX);
}
var _default = VXETablePluginExportXLSX;
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","exportXLSX","params","$table","options","columns","datas","sheetName","type","isHeader","isFooter","original","message","footerFilterMethod","colHead","footList","forEach","column","id","XEUtils","toString","property","getTitle","rowList","map","row","rowIndex","item","columnIndex","cellValue","isIndex","indexMethod","get","footerData","footers","filter","rows","$getColumnIndex","push","book","XLSX","utils","book_new","sheet","json_to_sheet","concat","skipHeader","book_append_sheet","write","bookType","bookSST","blob","Blob","downloadFile","$XModal","i18n","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","field","r","colIndex","checkImportData","tableFields","every","includes","importXLSX","file","_importCallback","_importResolve","fileReader","FileReader","onload","e","workbook","read","result","csvData","sheet_to_csv","Sheets","Sheet1","rest","createData","then","data","mode","insertAt","reloadData","readAsBinaryString","handleImportEvent","handleExportEvent","VXETablePluginExportXLSX","install","xtable","Object","assign","types","xlsx","interceptor","mixin","t","key","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 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 exportXLSX(params: any) {\r\n  const { $table, options, columns, datas } = params\r\n  const { sheetName, type, isHeader, isFooter, original, message, footerFilterMethod } = options\r\n  const colHead: any = {}\r\n  const footList: any[] = []\r\n  if (isHeader) {\r\n    columns.forEach((column: any) => {\r\n      colHead[column.id] = XEUtils.toString(original ? column.property : column.getTitle())\r\n    })\r\n  }\r\n  const rowList: any[] = datas.map((row: any, rowIndex: number) => {\r\n    const item: any = {}\r\n    columns.forEach((column: any, columnIndex: number) => {\r\n      let cellValue\r\n      const property = column.property\r\n      const isIndex = column.type === 'index'\r\n      if (!original || isIndex) {\r\n        cellValue = isIndex ? (column.indexMethod ? column.indexMethod({ row, rowIndex, column, columnIndex }) : rowIndex + 1) : row[column.id]\r\n      } else {\r\n        cellValue = XEUtils.get(row, property)\r\n      }\r\n      item[column.id] = cellValue\r\n    })\r\n    return item\r\n  })\r\n  if (isFooter) {\r\n    const footerData: any[] = $table.footerData\r\n    const footers: any[] = footerFilterMethod ? footerData.filter(footerFilterMethod) : footerData\r\n    footers.forEach((rows: any[]) => {\r\n      const item: any = {}\r\n      columns.forEach((column: any) => {\r\n        item[column.id] = rows[$table.$getColumnIndex(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    $table.$XModal.message({ message: i18n('vxe.table.expSuccess'), status: 'success' })\r\n  }\r\n}\r\n\r\nfunction downloadFile(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}.${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(i18n('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: any[], content: string) {\r\n  const list: string[] = content.split('\\n')\r\n  const fields: any[] = []\r\n  const rows: any[] = []\r\n  if (list.length) {\r\n    const rList: string[] = list.slice(1)\r\n    list[0].split(',').forEach((val: string) => {\r\n      const field: string = replaceDoubleQuotation(val)\r\n      if (field) {\r\n        fields.push(field)\r\n      }\r\n    })\r\n    rList.forEach((r: string) => {\r\n      if (r) {\r\n        const item: any = {}\r\n        r.split(',').forEach((val: string, colIndex: number) => {\r\n          item[fields[colIndex]] = replaceDoubleQuotation(val)\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: any[], fields: string[], rows: any[]) {\r\n  let tableFields: string[] = []\r\n  columns.forEach((column: any) => {\r\n    let field: string = column.property\r\n    if (field) {\r\n      tableFields.push(field)\r\n    }\r\n  })\r\n  return tableFields.every((field: string) => fields.includes(field))\r\n}\r\n\r\nfunction importXLSX(params: any) {\r\n  const { $table, columns, options, file } = params\r\n  const { _importCallback, _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 rest: any = parseCsv(columns, csvData)\r\n    const { fields, rows } = rest\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        $table.$XModal.message({ message: i18n('vxe.table.impSuccess'), status: 'success' })\r\n      }\r\n    } else if (options.message !== false) {\r\n      $table.$XModal.message({ message: i18n('vxe.error.impFields'), status: 'error' })\r\n    }\r\n    if (_importResolve) {\r\n      _importResolve(status)\r\n      $table._importResolve = null\r\n    } else if (_importCallback) {\r\n      // 已废弃\r\n      _importCallback(status)\r\n      $table._importCallback = null\r\n    }\r\n  }\r\n  fileReader.readAsBinaryString(file)\r\n}\r\n\r\nfunction handleImportEvent(params: any) {\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: any) {\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: any = {\r\n  install(xtable: typeof VXETable) {\r\n    Object.assign(xtable.types, { xlsx: 1 })\r\n    xtable.interceptor.mixin({\r\n      'event.import': handleImportEvent,\r\n      'event.export': handleExportEvent\r\n    })\r\n    VXETablePluginExportXLSX.t = xtable.t\r\n  }\r\n}\r\n\r\nfunction i18n(key: string) {\r\n  if (VXETablePluginExportXLSX.t) {\r\n    return VXETablePluginExportXLSX.t(key)\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"]}