diff --git a/dist/index.common.js b/dist/index.common.js index 75bc8f2..cf372a5 100644 --- a/dist/index.common.js +++ b/dist/index.common.js @@ -137,11 +137,12 @@ function checkImportData(columns, fields, rows) { }); } -function importXLSX(params, evnt) { +function importXLSX(params) { var $table = params.$table, - columns = params.columns; - var importCallback = $table.importCallback; - var file = evnt.target.files[0]; + columns = params.columns, + options = params.options, + file = params.file; + var _importCallback = $table._importCallback; var fileReader = new FileReader(); fileReader.onload = function (e) { @@ -156,22 +157,26 @@ function importXLSX(params, evnt) { if (status) { $table.createData(rows).then(function (data) { - return $table.reloadData(data); + if (options.mode === 'append') { + $table.insertAt(data, -1); + } else { + $table.reloadData(data); + } }); } - if (importCallback) { - importCallback(status); + if (_importCallback) { + _importCallback(status); } }; fileReader.readAsBinaryString(file); } -function handleImportEvent(params, evnt) { +function handleImportEvent(params) { switch (params.options.type) { case 'xlsx': - importXLSX(params, evnt); + importXLSX(params); return false; } } @@ -207,4 +212,4 @@ if (typeof window !== 'undefined' && window.VXETable) { 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","exportXLSX","params","options","columns","datas","sheetName","type","isHeader","original","colHead","forEach","column","id","property","getTitle","rowList","map","row","item","XEUtils","get","book","XLSX","utils","book_new","sheet","json_to_sheet","concat","skipHeader","book_append_sheet","write","bookType","bookSST","blob","Blob","download","window","filename","navigator","msSaveBlob","linkElem","document","createElement","target","href","URL","createObjectURL","body","appendChild","click","removeChild","console","error","replaceDoubleQuotation","val","replace","parseCsv","content","list","split","fields","rows","rList","slice","field","push","r","colIndex","checkImportData","tableFields","every","includes","importXLSX","evnt","$table","importCallback","file","files","fileReader","FileReader","onload","e","workbook","read","result","csvData","sheet_to_csv","Sheets","Sheet1","rest","status","createData","then","data","reloadData","readAsBinaryString","handleImportEvent","handleExportEvent","VXETablePluginExport","install","xtable","Object","assign","types","xlsx","interceptor","mixin","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 exportXLSX(params: any) {\r\n  const { options, columns, datas } = params\r\n  const { 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] = original ? column.property : 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 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, evnt: any) {\r\n  const { $table, columns } = params\r\n  const { importCallback } = $table\r\n  const file = evnt.target.files[0]\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[]) => $table.reloadData(data))\r\n    }\r\n    if (importCallback) {\r\n      importCallback(status)\r\n    }\r\n  }\r\n  fileReader.readAsBinaryString(file)\r\n}\r\n\r\nfunction handleImportEvent(params: any, evnt: any) {\r\n  switch (params.options.type) {\r\n    case 'xlsx':\r\n      importXLSX(params, evnt)\r\n      return false\r\n  }\r\n}\r\n\r\nfunction handleExportEvent(params: any) {\r\n  switch (params.options.type) {\r\n    case '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 VXETablePluginExport = {\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  }\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"]} +//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.ts"],"names":["toBuffer","wbout","buf","ArrayBuffer","length","view","Uint8Array","index","charCodeAt","exportXLSX","params","options","columns","datas","sheetName","type","isHeader","original","colHead","forEach","column","id","property","getTitle","rowList","map","row","item","XEUtils","get","book","XLSX","utils","book_new","sheet","json_to_sheet","concat","skipHeader","book_append_sheet","write","bookType","bookSST","blob","Blob","download","window","filename","navigator","msSaveBlob","linkElem","document","createElement","target","href","URL","createObjectURL","body","appendChild","click","removeChild","console","error","replaceDoubleQuotation","val","replace","parseCsv","content","list","split","fields","rows","rList","slice","field","push","r","colIndex","checkImportData","tableFields","every","includes","importXLSX","$table","file","_importCallback","fileReader","FileReader","onload","e","workbook","read","result","csvData","sheet_to_csv","Sheets","Sheet1","rest","status","createData","then","data","mode","insertAt","reloadData","readAsBinaryString","handleImportEvent","handleExportEvent","VXETablePluginExport","install","xtable","Object","assign","types","xlsx","interceptor","mixin","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 exportXLSX(params: any) {\r\n  const { options, columns, datas } = params\r\n  const { 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] = original ? column.property : 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 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 } = $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    }\r\n    if (_importCallback) {\r\n      _importCallback(status)\r\n    }\r\n  }\r\n  fileReader.readAsBinaryString(file)\r\n}\r\n\r\nfunction handleImportEvent(params: any) {\r\n  switch (params.options.type) {\r\n    case 'xlsx':\r\n      importXLSX(params)\r\n      return false\r\n  }\r\n}\r\n\r\nfunction handleExportEvent(params: any) {\r\n  switch (params.options.type) {\r\n    case '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 VXETablePluginExport = {\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  }\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"]} diff --git a/dist/index.js b/dist/index.js index 0ff601b..61a4133 100644 --- a/dist/index.js +++ b/dist/index.js @@ -148,11 +148,12 @@ }); } - function importXLSX(params, evnt) { + function importXLSX(params) { var $table = params.$table, - columns = params.columns; - var importCallback = $table.importCallback; - var file = evnt.target.files[0]; + columns = params.columns, + options = params.options, + file = params.file; + var _importCallback = $table._importCallback; var fileReader = new FileReader(); fileReader.onload = function (e) { @@ -167,22 +168,26 @@ if (status) { $table.createData(rows).then(function (data) { - return $table.reloadData(data); + if (options.mode === 'append') { + $table.insertAt(data, -1); + } else { + $table.reloadData(data); + } }); } - if (importCallback) { - importCallback(status); + if (_importCallback) { + _importCallback(status); } }; fileReader.readAsBinaryString(file); } - function handleImportEvent(params, evnt) { + function handleImportEvent(params) { switch (params.options.type) { case 'xlsx': - importXLSX(params, evnt); + importXLSX(params); return false; } } diff --git a/dist/index.min.js b/dist/index.min.js index bc3d814..a8bdf4e 100644 --- a/dist/index.min.js +++ b/dist/index.min.js @@ -1 +1 @@ -!function(e,t){if("function"==typeof define&&define.amd)define("vxe-table-plugin-export",["exports","xe-utils","xlsx"],t);else if("undefined"!=typeof exports)t(exports,require("xe-utils"),require("xlsx"));else{var r={exports:{}};t(r.exports,e.XEUtils,e.XLSX),e.VXETablePluginExport=r.exports.default}}(this,function(e,d,v){"use strict";var t;function a(){if("function"!=typeof WeakMap)return null;var e=new WeakMap;return a=function(){return e},e}function r(e){var t=e.options,n=e.columns,r=e.datas,o=t.sheetName,i=t.type,a=t.isHeader,l=t.original,u={};a&&n.forEach(function(e){u[e.id]=l?e.property:e.getTitle()});var s=r.map(function(t){var r={};return n.forEach(function(e){r[e.id]=l?d.default.get(t,e.property):t[e.id]}),r}),c=v.utils.book_new(),f=v.utils.json_to_sheet((a?[u]:[]).concat(s),{skipHeader:!0});v.utils.book_append_sheet(c,f,o);var p=v.write(c,{bookType:i,bookSST:!1,type:"binary"});!function(e,t){if(window.Blob){var r=t.filename,n=t.type;if(navigator.msSaveBlob)navigator.msSaveBlob(e,r);else{var o=document.createElement("a");o.target="_blank",o.download="".concat(r,".").concat(n),o.href=URL.createObjectURL(e),document.body.appendChild(o),o.click(),document.body.removeChild(o)}}else console.error("[vxe-table-plugin-export] The current environment does not support exports.")}(new Blob([function(e){for(var t=new ArrayBuffer(e.length),r=new Uint8Array(t),n=0;n!==e.length;++n)r[n]=255&e.charCodeAt(n);return t}(p)],{type:"application/octet-stream"}),t)}function s(e){return e.replace(/^"/,"").replace(/"$/,"")}function n(e,t){var a=e.$table,l=e.columns,u=a.importCallback,r=t.target.files[0],n=new FileReader;n.onload=function(e){var t=v.read(e.target.result,{type:"binary"}),r=function(e,t){var r=t.split("\n"),n=[],o=[];if(r.length){var i=r.slice(1);r[0].split(",").forEach(function(e){var t=s(e);t&&n.push(t)}),i.forEach(function(e){if(e){var r={};e.split(",").forEach(function(e,t){r[n[t]]=s(e)}),o.push(r)}})}return{fields:n,rows:o}}(0,v.utils.sheet_to_csv(t.Sheets.Sheet1)),n=r.fields,o=r.rows,i=function(e,t){var r=[];return e.forEach(function(e){var t=e.property;t&&r.push(t)}),r.every(function(e){return t.includes(e)})}(l,n);i&&a.createData(o).then(function(e){return a.reloadData(e)}),u&&u(i)},n.readAsBinaryString(r)}function o(e,t){switch(e.options.type){case"xlsx":return n(e,t),!1}}function i(e){switch(e.options.type){case"xlsx":return r(e),!1}}Object.defineProperty(e,"__esModule",{value:!0}),e.default=e.VXETablePluginExport=void 0,d=(t=d)&&t.__esModule?t:{default:t},v=function(e){if(e&&e.__esModule)return e;var t=a();if(t&&t.has(e))return t.get(e);var r={};if(null!=e){var n=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var o in e)if(Object.prototype.hasOwnProperty.call(e,o)){var i=n?Object.getOwnPropertyDescriptor(e,o):null;i&&(i.get||i.set)?Object.defineProperty(r,o,i):r[o]=e[o]}}r.default=e,t&&t.set(e,r);return r}(v);var l={install:function(e){Object.assign(e.types,{xlsx:1}),e.interceptor.mixin({"event.import":o,"event.export":i})}};e.VXETablePluginExport=l,"undefined"!=typeof window&&window.VXETable&&window.VXETable.use(l);var u=l;e.default=u}); \ No newline at end of file +!function(e,t){if("function"==typeof define&&define.amd)define("vxe-table-plugin-export",["exports","xe-utils","xlsx"],t);else if("undefined"!=typeof exports)t(exports,require("xe-utils"),require("xlsx"));else{var n={exports:{}};t(n.exports,e.XEUtils,e.XLSX),e.VXETablePluginExport=n.exports.default}}(this,function(e,d,v){"use strict";var t;function a(){if("function"!=typeof WeakMap)return null;var e=new WeakMap;return a=function(){return e},e}function n(e){var t=e.options,r=e.columns,n=e.datas,o=t.sheetName,i=t.type,a=t.isHeader,l=t.original,u={};a&&r.forEach(function(e){u[e.id]=l?e.property:e.getTitle()});var s=n.map(function(t){var n={};return r.forEach(function(e){n[e.id]=l?d.default.get(t,e.property):t[e.id]}),n}),c=v.utils.book_new(),p=v.utils.json_to_sheet((a?[u]:[]).concat(s),{skipHeader:!0});v.utils.book_append_sheet(c,p,o);var f=v.write(c,{bookType:i,bookSST:!1,type:"binary"});!function(e,t){if(window.Blob){var n=t.filename,r=t.type;if(navigator.msSaveBlob)navigator.msSaveBlob(e,n);else{var o=document.createElement("a");o.target="_blank",o.download="".concat(n,".").concat(r),o.href=URL.createObjectURL(e),document.body.appendChild(o),o.click(),document.body.removeChild(o)}}else console.error("[vxe-table-plugin-export] The current environment does not support exports.")}(new Blob([function(e){for(var t=new ArrayBuffer(e.length),n=new Uint8Array(t),r=0;r!==e.length;++r)n[r]=255&e.charCodeAt(r);return t}(f)],{type:"application/octet-stream"}),t)}function c(e){return e.replace(/^"/,"").replace(/"$/,"")}function r(e){var a=e.$table,l=e.columns,u=e.options,t=e.file,s=a._importCallback,n=new FileReader;n.onload=function(e){var t=v.read(e.target.result,{type:"binary"}),n=function(e,t){var n=t.split("\n"),r=[],o=[];if(n.length){var i=n.slice(1);n[0].split(",").forEach(function(e){var t=c(e);t&&r.push(t)}),i.forEach(function(e){if(e){var n={};e.split(",").forEach(function(e,t){n[r[t]]=c(e)}),o.push(n)}})}return{fields:r,rows:o}}(0,v.utils.sheet_to_csv(t.Sheets.Sheet1)),r=n.fields,o=n.rows,i=function(e,t){var n=[];return e.forEach(function(e){var t=e.property;t&&n.push(t)}),n.every(function(e){return t.includes(e)})}(l,r);i&&a.createData(o).then(function(e){"append"===u.mode?a.insertAt(e,-1):a.reloadData(e)}),s&&s(i)},n.readAsBinaryString(t)}function o(e){switch(e.options.type){case"xlsx":return r(e),!1}}function i(e){switch(e.options.type){case"xlsx":return n(e),!1}}Object.defineProperty(e,"__esModule",{value:!0}),e.default=e.VXETablePluginExport=void 0,d=(t=d)&&t.__esModule?t:{default:t},v=function(e){if(e&&e.__esModule)return e;var t=a();if(t&&t.has(e))return t.get(e);var n={};if(null!=e){var r=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var o in e)if(Object.prototype.hasOwnProperty.call(e,o)){var i=r?Object.getOwnPropertyDescriptor(e,o):null;i&&(i.get||i.set)?Object.defineProperty(n,o,i):n[o]=e[o]}}n.default=e,t&&t.set(e,n);return n}(v);var l={install:function(e){Object.assign(e.types,{xlsx:1}),e.interceptor.mixin({"event.import":o,"event.export":i})}};e.VXETablePluginExport=l,"undefined"!=typeof window&&window.VXETable&&window.VXETable.use(l);var u=l;e.default=u}); \ No newline at end of file diff --git a/index.ts b/index.ts index c52070e..c508eb0 100644 --- a/index.ts +++ b/index.ts @@ -94,10 +94,9 @@ function checkImportData(columns: any[], fields: string[], rows: any[]) { return tableFields.every((field: string) => fields.includes(field)) } -function importXLSX(params: any, evnt: any) { - const { $table, columns } = params - const { importCallback } = $table - const file = evnt.target.files[0] +function importXLSX(params: any) { + const { $table, columns, options, file } = params + const { _importCallback } = $table const fileReader = new FileReader() fileReader.onload = (e: any) => { const workbook = XLSX.read(e.target.result, { type: 'binary' }) @@ -107,19 +106,25 @@ function importXLSX(params: any, evnt: any) { const status = checkImportData(columns, fields, rows) if (status) { $table.createData(rows) - .then((data: any[]) => $table.reloadData(data)) + .then((data: any[]) => { + if (options.mode === 'append') { + $table.insertAt(data, -1) + } else { + $table.reloadData(data) + } + }) } - if (importCallback) { - importCallback(status) + if (_importCallback) { + _importCallback(status) } } fileReader.readAsBinaryString(file) } -function handleImportEvent(params: any, evnt: any) { +function handleImportEvent(params: any) { switch (params.options.type) { case 'xlsx': - importXLSX(params, evnt) + importXLSX(params) return false } } diff --git a/package.json b/package.json index bdfe85b..e60bc6c 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "vxe-table-plugin-export", - "version": "1.0.5", + "version": "1.0.6", "description": "基于 vxe-table 表格的增强插件,支持导出 xlsx 等格式", "scripts": { "lib": "gulp build" @@ -54,7 +54,7 @@ "xlsx": "^0.15.1" }, "peerDependencies": { - "vxe-table": ">=2.6.12", + "vxe-table": ">=2.6.14", "xe-utils": ">=2.2.0" }, "repository": {