From 8824724280d1d4567a19987a0b0ef584674f194d Mon Sep 17 00:00:00 2001 From: xuliangzhan Date: Wed, 19 Feb 2020 11:36:48 +0800 Subject: [PATCH] update --- dist/index.common.js | 18 ++++++------------ dist/index.js | 18 ++++++------------ dist/index.min.js | 2 +- index.ts | 32 +++++++++++++++----------------- package.json | 2 +- 5 files changed, 29 insertions(+), 43 deletions(-) diff --git a/dist/index.common.js b/dist/index.common.js index 4eee3a9..070a025 100644 --- a/dist/index.common.js +++ b/dist/index.common.js @@ -11,16 +11,10 @@ var _xlsx = _interopRequireDefault(require("xlsx")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } -function getSeq($table, row, rowIndex, column, columnIndex) { - // 在 v3.0 中废弃 startIndex、indexMethod - var seqOpts = $table.seqOpts; - var seqMethod = seqOpts.seqMethod || column.indexMethod; - return seqMethod ? seqMethod({ - row: row, - rowIndex: rowIndex, - column: column, - columnIndex: columnIndex - }) : (seqOpts.startIndex || $table.startIndex) + rowIndex + 1; +function getFooterCellValue($table, opts, rows, column) { + var cellValue = _xeUtils["default"].toString(rows[$table.$getColumnIndex(column)]); + + return cellValue; } function toBuffer(wbout) { @@ -62,7 +56,7 @@ function exportXLSX(params) { footers.forEach(function (rows) { var item = {}; columns.forEach(function (column) { - item[column.id] = rows[$table.$getColumnIndex(column)] || ''; + item[column.id] = getFooterCellValue($table, options, rows, column); }); footList.push(item); }); @@ -265,4 +259,4 @@ if (typeof window !== 'undefined' && window.VXETable) { var _default = VXETablePluginExportXLSX; exports["default"] = _default; -//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.ts"],"names":["getSeq","$table","row","rowIndex","column","columnIndex","seqOpts","seqMethod","indexMethod","startIndex","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","XEUtils","toString","property","getTitle","footerData","footers","filter","rows","item","$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","map","r","colIndex","checkImportData","tableFields","field","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 getSeq($table: any, row: any, rowIndex: number, column: any, columnIndex: number) {\r\n  // 在 v3.0 中废弃 startIndex、indexMethod\r\n  let seqOpts = $table.seqOpts\r\n  let seqMethod = seqOpts.seqMethod || column.indexMethod\r\n  return seqMethod ? seqMethod({ row, rowIndex, column, columnIndex }) : ((seqOpts.startIndex || $table.startIndex) + rowIndex + 1)\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: 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  const rowList = datas\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  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(',').map(replaceDoubleQuotation)\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          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: 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"]} +//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.ts"],"names":["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","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","$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","map","r","colIndex","checkImportData","tableFields","field","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":";;;;;;;AAAA;;AAEA;;;;AAEA,SAASA,kBAAT,CAA6BC,MAA7B,EAA0CC,IAA1C,EAAqDC,IAArD,EAAkEC,MAAlE,EAA6E;AAC3E,MAAIC,SAAS,GAAGC,oBAAQC,QAAR,CAAiBJ,IAAI,CAACF,MAAM,CAACO,eAAP,CAAuBJ,MAAvB,CAAD,CAArB,CAAhB;;AACA,SAAOC,SAAP;AACD;;AAED,SAASI,QAAT,CAAmBC,KAAnB,EAA6B;AAC3B,MAAIC,GAAG,GAAG,IAAIC,WAAJ,CAAgBF,KAAK,CAACG,MAAtB,CAAV;AACA,MAAIC,IAAI,GAAG,IAAIC,UAAJ,CAAeJ,GAAf,CAAX;;AACA,OAAK,IAAIK,KAAK,GAAG,CAAjB,EAAoBA,KAAK,KAAKN,KAAK,CAACG,MAApC,EAA4C,EAAEG,KAA9C;AAAqDF,IAAAA,IAAI,CAACE,KAAD,CAAJ,GAAcN,KAAK,CAACO,UAAN,CAAiBD,KAAjB,IAA0B,IAAxC;AAArD;;AACA,SAAOL,GAAP;AACD;;AAED,SAASO,UAAT,CAAqBC,MAArB,EAAgC;AAAA,MACtBlB,MADsB,GACckB,MADd,CACtBlB,MADsB;AAAA,MACdmB,OADc,GACcD,MADd,CACdC,OADc;AAAA,MACLC,OADK,GACcF,MADd,CACLE,OADK;AAAA,MACIC,KADJ,GACcH,MADd,CACIG,KADJ;AAAA,MAEtBC,SAFsB,GAEyDH,OAFzD,CAEtBG,SAFsB;AAAA,MAEXC,IAFW,GAEyDJ,OAFzD,CAEXI,IAFW;AAAA,MAELC,QAFK,GAEyDL,OAFzD,CAELK,QAFK;AAAA,MAEKC,QAFL,GAEyDN,OAFzD,CAEKM,QAFL;AAAA,MAEeC,QAFf,GAEyDP,OAFzD,CAEeO,QAFf;AAAA,MAEyBC,OAFzB,GAEyDR,OAFzD,CAEyBQ,OAFzB;AAAA,MAEkCC,kBAFlC,GAEyDT,OAFzD,CAEkCS,kBAFlC;AAG9B,MAAMC,OAAO,GAAQ,EAArB;AACA,MAAMC,QAAQ,GAAU,EAAxB;AACA,MAAMC,OAAO,GAAGV,KAAhB;;AACA,MAAIG,QAAJ,EAAc;AACZJ,IAAAA,OAAO,CAACY,OAAR,CAAgB,UAAC7B,MAAD,EAAgB;AAC9B0B,MAAAA,OAAO,CAAC1B,MAAM,CAAC8B,EAAR,CAAP,GAAqB5B,oBAAQC,QAAR,CAAiBoB,QAAQ,GAAGvB,MAAM,CAAC+B,QAAV,GAAqB/B,MAAM,CAACgC,QAAP,EAA9C,CAArB;AACD,KAFD;AAGD;;AACD,MAAIV,QAAJ,EAAc;AACZ,QAAMW,UAAU,GAAUpC,MAAM,CAACoC,UAAjC;AACA,QAAMC,OAAO,GAAUT,kBAAkB,GAAGQ,UAAU,CAACE,MAAX,CAAkBV,kBAAlB,CAAH,GAA2CQ,UAApF;AACAC,IAAAA,OAAO,CAACL,OAAR,CAAgB,UAAC9B,IAAD,EAAgB;AAC9B,UAAMqC,IAAI,GAAQ,EAAlB;AACAnB,MAAAA,OAAO,CAACY,OAAR,CAAgB,UAAC7B,MAAD,EAAgB;AAC9BoC,QAAAA,IAAI,CAACpC,MAAM,CAAC8B,EAAR,CAAJ,GAAkBlC,kBAAkB,CAACC,MAAD,EAASmB,OAAT,EAAkBjB,IAAlB,EAAwBC,MAAxB,CAApC;AACD,OAFD;AAGA2B,MAAAA,QAAQ,CAACU,IAAT,CAAcD,IAAd;AACD,KAND;AAOD;;AACD,MAAME,IAAI,GAAGC,iBAAKC,KAAL,CAAWC,QAAX,EAAb;;AACA,MAAMC,KAAK,GAAGH,iBAAKC,KAAL,CAAWG,aAAX,CAAyB,CAACtB,QAAQ,GAAG,CAACK,OAAD,CAAH,GAAe,EAAxB,EAA4BkB,MAA5B,CAAmChB,OAAnC,EAA4CgB,MAA5C,CAAmDjB,QAAnD,CAAzB,EAAuF;AAAEkB,IAAAA,UAAU,EAAE;AAAd,GAAvF,CAAd,CAvB8B,CAwB9B;;;AACAN,mBAAKC,KAAL,CAAWM,iBAAX,CAA6BR,IAA7B,EAAmCI,KAAnC,EAA0CvB,SAA1C;;AACA,MAAMb,KAAK,GAAGiC,iBAAKQ,KAAL,CAAWT,IAAX,EAAiB;AAAEU,IAAAA,QAAQ,EAAE5B,IAAZ;AAAkB6B,IAAAA,OAAO,EAAE,KAA3B;AAAkC7B,IAAAA,IAAI,EAAE;AAAxC,GAAjB,CAAd;;AACA,MAAM8B,IAAI,GAAG,IAAIC,IAAJ,CAAS,CAAC9C,QAAQ,CAACC,KAAD,CAAT,CAAT,EAA4B;AAAEc,IAAAA,IAAI,EAAE;AAAR,GAA5B,CAAb,CA3B8B,CA4B9B;;AACAgC,EAAAA,YAAY,CAACF,IAAD,EAAOlC,OAAP,CAAZ;;AACA,MAAIQ,OAAO,KAAK,KAAhB,EAAuB;AACrB3B,IAAAA,MAAM,CAACwD,OAAP,CAAe7B,OAAf,CAAuB;AAAEA,MAAAA,OAAO,EAAE8B,IAAI,CAAC,sBAAD,CAAf;AAAyCC,MAAAA,MAAM,EAAE;AAAjD,KAAvB;AACD;AACF;;AAED,SAASH,YAAT,CAAuBF,IAAvB,EAAmClC,OAAnC,EAA+C;AAC7C,MAAIwC,MAAM,CAACL,IAAX,EAAiB;AAAA,QACPM,QADO,GACYzC,OADZ,CACPyC,QADO;AAAA,QACGrC,IADH,GACYJ,OADZ,CACGI,IADH;;AAEf,QAAIsC,SAAS,CAACC,UAAd,EAA0B;AACxBD,MAAAA,SAAS,CAACC,UAAV,CAAqBT,IAArB,YAA8BO,QAA9B,cAA0CrC,IAA1C;AACD,KAFD,MAEO;AACL,UAAIwC,QAAQ,GAAGC,QAAQ,CAACC,aAAT,CAAuB,GAAvB,CAAf;AACAF,MAAAA,QAAQ,CAACG,MAAT,GAAkB,QAAlB;AACAH,MAAAA,QAAQ,CAACI,QAAT,aAAuBP,QAAvB,cAAmCrC,IAAnC;AACAwC,MAAAA,QAAQ,CAACK,IAAT,GAAgBC,GAAG,CAACC,eAAJ,CAAoBjB,IAApB,CAAhB;AACAW,MAAAA,QAAQ,CAACO,IAAT,CAAcC,WAAd,CAA0BT,QAA1B;AACAA,MAAAA,QAAQ,CAACU,KAAT;AACAT,MAAAA,QAAQ,CAACO,IAAT,CAAcG,WAAd,CAA0BX,QAA1B;AACD;AACF,GAbD,MAaO;AACLY,IAAAA,OAAO,CAACC,KAAR,CAAcnB,IAAI,CAAC,kBAAD,CAAlB;AACD;AACF;;AAED,SAASoB,sBAAT,CAAiCC,GAAjC,EAA4C;AAC1C,SAAOA,GAAG,CAACC,OAAJ,CAAY,IAAZ,EAAkB,EAAlB,EAAsBA,OAAtB,CAA8B,IAA9B,EAAoC,EAApC,CAAP;AACD;;AAED,SAASC,QAAT,CAAmB5D,OAAnB,EAAmC6D,OAAnC,EAAkD;AAChD,MAAMC,IAAI,GAAaD,OAAO,CAACE,KAAR,CAAc,IAAd,CAAvB;AACA,MAAMC,MAAM,GAAU,EAAtB;AACA,MAAMlF,IAAI,GAAU,EAApB;;AACA,MAAIgF,IAAI,CAACtE,MAAT,EAAiB;AACf,QAAMyE,KAAK,GAAaH,IAAI,CAACI,KAAL,CAAW,CAAX,CAAxB;AACAJ,IAAAA,IAAI,CAAC,CAAD,CAAJ,CAAQC,KAAR,CAAc,GAAd,EAAmBI,GAAnB,CAAuBV,sBAAvB;AACAQ,IAAAA,KAAK,CAACrD,OAAN,CAAc,UAACwD,CAAD,EAAc;AAC1B,UAAIA,CAAJ,EAAO;AACL,YAAMjD,IAAI,GAAQ,EAAlB;AACAiD,QAAAA,CAAC,CAACL,KAAF,CAAQ,GAAR,EAAanD,OAAb,CAAqB,UAAC8C,GAAD,EAAcW,QAAd,EAAkC;AACrD,cAAIL,MAAM,CAACK,QAAD,CAAV,EAAsB;AACpBlD,YAAAA,IAAI,CAAC6C,MAAM,CAACK,QAAD,CAAP,CAAJ,GAAyBZ,sBAAsB,CAACC,GAAD,CAA/C;AACD;AACF,SAJD;AAKA5E,QAAAA,IAAI,CAACsC,IAAL,CAAUD,IAAV;AACD;AACF,KAVD;AAWD;;AACD,SAAO;AAAE6C,IAAAA,MAAM,EAANA,MAAF;AAAUlF,IAAAA,IAAI,EAAJA;AAAV,GAAP;AACD;;AAED,SAASwF,eAAT,CAA0BtE,OAA1B,EAA0CgE,MAA1C,EAA4DlF,IAA5D,EAAuE;AACrE,MAAIyF,WAAW,GAAa,EAA5B;AACAvE,EAAAA,OAAO,CAACY,OAAR,CAAgB,UAAC7B,MAAD,EAAgB;AAC9B,QAAIyF,KAAK,GAAWzF,MAAM,CAAC+B,QAA3B;;AACA,QAAI0D,KAAJ,EAAW;AACTD,MAAAA,WAAW,CAACnD,IAAZ,CAAiBoD,KAAjB;AACD;AACF,GALD;AAMA,SAAOD,WAAW,CAACE,KAAZ,CAAkB,UAACD,KAAD;AAAA,WAAmBR,MAAM,CAACU,QAAP,CAAgBF,KAAhB,CAAnB;AAAA,GAAlB,CAAP;AACD;;AAED,SAASG,UAAT,CAAqB7E,MAArB,EAAgC;AAAA,MACtBlB,MADsB,GACakB,MADb,CACtBlB,MADsB;AAAA,MACdoB,OADc,GACaF,MADb,CACdE,OADc;AAAA,MACLD,OADK,GACaD,MADb,CACLC,OADK;AAAA,MACI6E,IADJ,GACa9E,MADb,CACI8E,IADJ;AAAA,MAEtBC,eAFsB,GAEcjG,MAFd,CAEtBiG,eAFsB;AAAA,MAELC,cAFK,GAEclG,MAFd,CAELkG,cAFK;AAG9B,MAAMC,UAAU,GAAG,IAAIC,UAAJ,EAAnB;;AACAD,EAAAA,UAAU,CAACE,MAAX,GAAoB,UAACC,CAAD,EAAW;AAC7B,QAAMC,QAAQ,GAAG7D,iBAAK8D,IAAL,CAAUF,CAAC,CAACpC,MAAF,CAASuC,MAAnB,EAA2B;AAAElF,MAAAA,IAAI,EAAE;AAAR,KAA3B,CAAjB;;AACA,QAAMmF,OAAO,GAAWhE,iBAAKC,KAAL,CAAWgE,YAAX,CAAwBJ,QAAQ,CAACK,MAAT,CAAgBC,MAAxC,CAAxB;;AACA,QAAMC,IAAI,GAAQ9B,QAAQ,CAAC5D,OAAD,EAAUsF,OAAV,CAA1B;AAH6B,QAIrBtB,MAJqB,GAIJ0B,IAJI,CAIrB1B,MAJqB;AAAA,QAIblF,IAJa,GAIJ4G,IAJI,CAIb5G,IAJa;AAK7B,QAAMwD,MAAM,GAAGgC,eAAe,CAACtE,OAAD,EAAUgE,MAAV,EAAkBlF,IAAlB,CAA9B;;AACA,QAAIwD,MAAJ,EAAY;AACV1D,MAAAA,MAAM,CAAC+G,UAAP,CAAkB7G,IAAlB,EACG8G,IADH,CACQ,UAACC,IAAD,EAAgB;AACpB,YAAI9F,OAAO,CAAC+F,IAAR,KAAiB,QAArB,EAA+B;AAC7BlH,UAAAA,MAAM,CAACmH,QAAP,CAAgBF,IAAhB,EAAsB,CAAC,CAAvB;AACD,SAFD,MAEO;AACLjH,UAAAA,MAAM,CAACoH,UAAP,CAAkBH,IAAlB;AACD;AACF,OAPH;;AAQA,UAAI9F,OAAO,CAACQ,OAAR,KAAoB,KAAxB,EAA+B;AAC7B3B,QAAAA,MAAM,CAACwD,OAAP,CAAe7B,OAAf,CAAuB;AAAEA,UAAAA,OAAO,EAAE8B,IAAI,CAAC,sBAAD,CAAf;AAAyCC,UAAAA,MAAM,EAAE;AAAjD,SAAvB;AACD;AACF,KAZD,MAYO,IAAIvC,OAAO,CAACQ,OAAR,KAAoB,KAAxB,EAA+B;AACpC3B,MAAAA,MAAM,CAACwD,OAAP,CAAe7B,OAAf,CAAuB;AAAEA,QAAAA,OAAO,EAAE8B,IAAI,CAAC,qBAAD,CAAf;AAAwCC,QAAAA,MAAM,EAAE;AAAhD,OAAvB;AACD;;AACD,QAAIwC,cAAJ,EAAoB;AAClBA,MAAAA,cAAc,CAACxC,MAAD,CAAd;;AACA1D,MAAAA,MAAM,CAACkG,cAAP,GAAwB,IAAxB;AACD,KAHD,MAGO,IAAID,eAAJ,EAAqB;AAC1B;AACAA,MAAAA,eAAe,CAACvC,MAAD,CAAf;;AACA1D,MAAAA,MAAM,CAACiG,eAAP,GAAyB,IAAzB;AACD;AACF,GA7BD;;AA8BAE,EAAAA,UAAU,CAACkB,kBAAX,CAA8BrB,IAA9B;AACD;;AAED,SAASsB,iBAAT,CAA4BpG,MAA5B,EAAuC;AACrC,MAAIA,MAAM,CAACC,OAAP,CAAeI,IAAf,KAAwB,MAA5B,EAAoC;AAClCwE,IAAAA,UAAU,CAAC7E,MAAD,CAAV;AACA,WAAO,KAAP;AACD;AACF;;AAED,SAASqG,iBAAT,CAA4BrG,MAA5B,EAAuC;AACrC,MAAIA,MAAM,CAACC,OAAP,CAAeI,IAAf,KAAwB,MAA5B,EAAoC;AAClCN,IAAAA,UAAU,CAACC,MAAD,CAAV;AACA,WAAO,KAAP;AACD;AACF;AAED;;;;;AAGO,IAAMsG,wBAAwB,GAAQ;AAC3CC,EAAAA,OAD2C,mBAClCC,MADkC,EACX;AAC9BC,IAAAA,MAAM,CAACC,MAAP,CAAcF,MAAM,CAACG,KAArB,EAA4B;AAAEC,MAAAA,IAAI,EAAE;AAAR,KAA5B;AACAJ,IAAAA,MAAM,CAACK,WAAP,CAAmBC,KAAnB,CAAyB;AACvB,sBAAgBV,iBADO;AAEvB,sBAAgBC;AAFO,KAAzB;AAIAC,IAAAA,wBAAwB,CAACS,CAAzB,GAA6BP,MAAM,CAACO,CAApC;AACD;AAR0C,CAAtC;;;AAWP,SAASxE,IAAT,CAAeyE,GAAf,EAA0B;AACxB,MAAIV,wBAAwB,CAACS,CAA7B,EAAgC;AAC9B,WAAOT,wBAAwB,CAACS,CAAzB,CAA2BC,GAA3B,CAAP;AACD;AACF;;AAED,IAAI,OAAOvE,MAAP,KAAkB,WAAlB,IAAiCA,MAAM,CAACwE,QAA5C,EAAsD;AACpDxE,EAAAA,MAAM,CAACwE,QAAP,CAAgBC,GAAhB,CAAoBZ,wBAApB;AACD;;eAEcA,wB","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 getFooterCellValue ($table: any, opts: any, rows: any[], column: any) {\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: 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  const rowList = datas\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  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] = 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    $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(',').map(replaceDoubleQuotation)\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          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: 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"]} diff --git a/dist/index.js b/dist/index.js index a83921b..0e3ffd4 100644 --- a/dist/index.js +++ b/dist/index.js @@ -10,7 +10,7 @@ factory(mod.exports, global.XEUtils, global.XLSX); global.VXETablePluginExportXLSX = mod.exports.default; } -})(typeof globalThis !== "undefined" ? globalThis : typeof self !== "undefined" ? self : this, function (_exports, _xeUtils, _xlsx) { +})(this, function (_exports, _xeUtils, _xlsx) { "use strict"; Object.defineProperty(_exports, "__esModule", { @@ -22,16 +22,10 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } - function getSeq($table, row, rowIndex, column, columnIndex) { - // 在 v3.0 中废弃 startIndex、indexMethod - var seqOpts = $table.seqOpts; - var seqMethod = seqOpts.seqMethod || column.indexMethod; - return seqMethod ? seqMethod({ - row: row, - rowIndex: rowIndex, - column: column, - columnIndex: columnIndex - }) : (seqOpts.startIndex || $table.startIndex) + rowIndex + 1; + function getFooterCellValue($table, opts, rows, column) { + var cellValue = _xeUtils["default"].toString(rows[$table.$getColumnIndex(column)]); + + return cellValue; } function toBuffer(wbout) { @@ -73,7 +67,7 @@ footers.forEach(function (rows) { var item = {}; columns.forEach(function (column) { - item[column.id] = rows[$table.$getColumnIndex(column)] || ''; + item[column.id] = getFooterCellValue($table, options, rows, column); }); footList.push(item); }); diff --git a/dist/index.min.js b/dist/index.min.js index e6eb129..5b72ba7 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-xlsx",["exports","xe-utils","xlsx"],t);else if("undefined"!=typeof exports)t(exports,require("xe-utils"),require("xlsx"));else{var o={exports:{}};t(o.exports,e.XEUtils,e.XLSX),e.VXETablePluginExportXLSX=o.exports.default}}("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:this,function(e,h,y){"use strict";function t(e){return e&&e.__esModule?e:{default:e}}function o(e){var n=e.$table,t=e.options,a=e.columns,o=e.datas,r=t.sheetName,i=t.type,s=t.isHeader,l=t.isFooter,u=t.original,f=t.message,c=t.footerFilterMethod,d={},p=[],v=o;if(s&&a.forEach(function(e){d[e.id]=h.default.toString(u?e.property:e.getTitle())}),l){var x=n.footerData;(c?x.filter(c):x).forEach(function(t){var o={};a.forEach(function(e){o[e.id]=t[n.$getColumnIndex(e)]||""}),p.push(o)})}var m=y.default.utils.book_new(),b=y.default.utils.json_to_sheet((s?[d]:[]).concat(v).concat(p),{skipHeader:!0});y.default.utils.book_append_sheet(m,b,r);var g=y.default.write(m,{bookType:i,bookSST:!1,type:"binary"});!function(e,t){if(window.Blob){var o=t.filename,n=t.type;if(navigator.msSaveBlob)navigator.msSaveBlob(e,"".concat(o,".").concat(n));else{var a=document.createElement("a");a.target="_blank",a.download="".concat(o,".").concat(n),a.href=URL.createObjectURL(e),document.body.appendChild(a),a.click(),document.body.removeChild(a)}}else console.error(w("vxe.error.notExp"))}(new Blob([function(e){for(var t=new ArrayBuffer(e.length),o=new Uint8Array(t),n=0;n!==e.length;++n)o[n]=255&e.charCodeAt(n);return t}(g)],{type:"application/octet-stream"}),t),!1!==f&&n.$XModal.message({message:w("vxe.table.expSuccess"),status:"success"})}function p(e){return e.replace(/^"/,"").replace(/"$/,"")}function n(e){var l=e.$table,u=e.columns,f=e.options,t=e.file,c=l._importCallback,d=l._importResolve,o=new FileReader;o.onload=function(e){var t,o,n=y.default.read(e.target.result,{type:"binary"}),a=function(e){var t=e.split("\n"),n=[],a=[];if(t.length){var o=t.slice(1);t[0].split(",").map(p),o.forEach(function(e){if(e){var o={};e.split(",").forEach(function(e,t){n[t]&&(o[n[t]]=p(e))}),a.push(o)}})}return{fields:n,rows:a}}(y.default.utils.sheet_to_csv(n.Sheets.Sheet1)),r=a.fields,i=a.rows,s=(t=r,o=[],u.forEach(function(e){var t=e.property;t&&o.push(t)}),o.every(function(e){return t.includes(e)}));s?(l.createData(i).then(function(e){"append"===f.mode?l.insertAt(e,-1):l.reloadData(e)}),!1!==f.message&&l.$XModal.message({message:w("vxe.table.impSuccess"),status:"success"})):!1!==f.message&&l.$XModal.message({message:w("vxe.error.impFields"),status:"error"}),d?(d(s),l._importResolve=null):c&&(c(s),l._importCallback=null)},o.readAsBinaryString(t)}function a(e){if("xlsx"===e.options.type)return n(e),!1}function r(e){if("xlsx"===e.options.type)return o(e),!1}Object.defineProperty(e,"__esModule",{value:!0}),e.default=e.VXETablePluginExportXLSX=void 0,h=t(h),y=t(y);var i={install:function(e){Object.assign(e.types,{xlsx:1}),e.interceptor.mixin({"event.import":a,"event.export":r}),i.t=e.t}};function w(e){if(i.t)return i.t(e)}e.VXETablePluginExportXLSX=i,"undefined"!=typeof window&&window.VXETable&&window.VXETable.use(i);var s=i;e.default=s}); \ No newline at end of file +!function(e,t){if("function"==typeof define&&define.amd)define("vxe-table-plugin-export-xlsx",["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.VXETablePluginExportXLSX=n.exports.default}}(this,function(e,h,y){"use strict";function t(e){return e&&e.__esModule?e:{default:e}}function n(e){var o=e.$table,t=e.options,r=e.columns,n=e.datas,a=t.sheetName,i=t.type,s=t.isHeader,l=t.isFooter,u=t.original,c=t.message,f=t.footerFilterMethod,d={},p=[],v=n;if(s&&r.forEach(function(e){d[e.id]=h.default.toString(u?e.property:e.getTitle())}),l){var x=o.footerData;(f?x.filter(f):x).forEach(function(t){var n={};r.forEach(function(e){n[e.id]=function(e,t,n,o){return h.default.toString(n[e.$getColumnIndex(o)])}(o,0,t,e)}),p.push(n)})}var m=y.default.utils.book_new(),b=y.default.utils.json_to_sheet((s?[d]:[]).concat(v).concat(p),{skipHeader:!0});y.default.utils.book_append_sheet(m,b,a);var g=y.default.write(m,{bookType:i,bookSST:!1,type:"binary"});!function(e,t){if(window.Blob){var n=t.filename,o=t.type;if(navigator.msSaveBlob)navigator.msSaveBlob(e,"".concat(n,".").concat(o));else{var r=document.createElement("a");r.target="_blank",r.download="".concat(n,".").concat(o),r.href=URL.createObjectURL(e),document.body.appendChild(r),r.click(),document.body.removeChild(r)}}else console.error(w("vxe.error.notExp"))}(new Blob([function(e){for(var t=new ArrayBuffer(e.length),n=new Uint8Array(t),o=0;o!==e.length;++o)n[o]=255&e.charCodeAt(o);return t}(g)],{type:"application/octet-stream"}),t),!1!==c&&o.$XModal.message({message:w("vxe.table.expSuccess"),status:"success"})}function f(e){return e.replace(/^"/,"").replace(/"$/,"")}function o(e){var i=e.$table,s=e.columns,l=e.options,t=e.file,u=i._importCallback,c=i._importResolve,n=new FileReader;n.onload=function(e){var t=y.default.read(e.target.result,{type:"binary"}),n=function(e,t){var n=t.split("\n"),o=[],r=[];if(n.length){var a=n.slice(1);n[0].split(",").map(f),a.forEach(function(e){if(e){var n={};e.split(",").forEach(function(e,t){o[t]&&(n[o[t]]=f(e))}),r.push(n)}})}return{fields:o,rows:r}}(0,y.default.utils.sheet_to_csv(t.Sheets.Sheet1)),o=n.fields,r=n.rows,a=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)})}(s,o);a?(i.createData(r).then(function(e){"append"===l.mode?i.insertAt(e,-1):i.reloadData(e)}),!1!==l.message&&i.$XModal.message({message:w("vxe.table.impSuccess"),status:"success"})):!1!==l.message&&i.$XModal.message({message:w("vxe.error.impFields"),status:"error"}),c?(c(a),i._importResolve=null):u&&(u(a),i._importCallback=null)},n.readAsBinaryString(t)}function r(e){if("xlsx"===e.options.type)return o(e),!1}function a(e){if("xlsx"===e.options.type)return n(e),!1}Object.defineProperty(e,"__esModule",{value:!0}),e.default=e.VXETablePluginExportXLSX=void 0,h=t(h),y=t(y);var i={install:function(e){Object.assign(e.types,{xlsx:1}),e.interceptor.mixin({"event.import":r,"event.export":a}),i.t=e.t}};function w(e){if(i.t)return i.t(e)}e.VXETablePluginExportXLSX=i,"undefined"!=typeof window&&window.VXETable&&window.VXETable.use(i);var s=i;e.default=s}); \ No newline at end of file diff --git a/index.ts b/index.ts index 38876d7..b9eeff9 100644 --- a/index.ts +++ b/index.ts @@ -2,21 +2,19 @@ import XEUtils from 'xe-utils/methods/xe-utils' import VXETable from 'vxe-table/lib/vxe-table' import XLSX from 'xlsx' -function getSeq($table: any, row: any, rowIndex: number, column: any, columnIndex: number) { - // 在 v3.0 中废弃 startIndex、indexMethod - let seqOpts = $table.seqOpts - let seqMethod = seqOpts.seqMethod || column.indexMethod - return seqMethod ? seqMethod({ row, rowIndex, column, columnIndex }) : ((seqOpts.startIndex || $table.startIndex) + rowIndex + 1) +function getFooterCellValue ($table: any, opts: any, rows: any[], column: any) { + var cellValue = XEUtils.toString(rows[$table.$getColumnIndex(column)]) + return cellValue } -function toBuffer(wbout: any) { +function toBuffer (wbout: any) { let buf = new ArrayBuffer(wbout.length) let view = new Uint8Array(buf) for (let index = 0; index !== wbout.length; ++index) view[index] = wbout.charCodeAt(index) & 0xFF return buf } -function exportXLSX(params: any) { +function exportXLSX (params: any) { const { $table, options, columns, datas } = params const { sheetName, type, isHeader, isFooter, original, message, footerFilterMethod } = options const colHead: any = {} @@ -33,7 +31,7 @@ function exportXLSX(params: any) { footers.forEach((rows: any[]) => { const item: any = {} columns.forEach((column: any) => { - item[column.id] = rows[$table.$getColumnIndex(column)] || '' + item[column.id] = getFooterCellValue($table, options, rows, column) }) footList.push(item) }) @@ -51,7 +49,7 @@ function exportXLSX(params: any) { } } -function downloadFile(blob: Blob, options: any) { +function downloadFile (blob: Blob, options: any) { if (window.Blob) { const { filename, type } = options if (navigator.msSaveBlob) { @@ -70,11 +68,11 @@ function downloadFile(blob: Blob, options: any) { } } -function replaceDoubleQuotation(val: string) { +function replaceDoubleQuotation (val: string) { return val.replace(/^"/, '').replace(/"$/, '') } -function parseCsv(columns: any[], content: string) { +function parseCsv (columns: any[], content: string) { const list: string[] = content.split('\n') const fields: any[] = [] const rows: any[] = [] @@ -96,7 +94,7 @@ function parseCsv(columns: any[], content: string) { return { fields, rows } } -function checkImportData(columns: any[], fields: string[], rows: any[]) { +function checkImportData (columns: any[], fields: string[], rows: any[]) { let tableFields: string[] = [] columns.forEach((column: any) => { let field: string = column.property @@ -107,7 +105,7 @@ function checkImportData(columns: any[], fields: string[], rows: any[]) { return tableFields.every((field: string) => fields.includes(field)) } -function importXLSX(params: any) { +function importXLSX (params: any) { const { $table, columns, options, file } = params const { _importCallback, _importResolve } = $table const fileReader = new FileReader() @@ -144,14 +142,14 @@ function importXLSX(params: any) { fileReader.readAsBinaryString(file) } -function handleImportEvent(params: any) { +function handleImportEvent (params: any) { if (params.options.type === 'xlsx') { importXLSX(params) return false } } -function handleExportEvent(params: any) { +function handleExportEvent (params: any) { if (params.options.type === 'xlsx') { exportXLSX(params) return false @@ -162,7 +160,7 @@ function handleExportEvent(params: any) { * 基于 vxe-table 表格的增强插件,支持导出 xlsx 格式 */ export const VXETablePluginExportXLSX: any = { - install(xtable: typeof VXETable) { + install (xtable: typeof VXETable) { Object.assign(xtable.types, { xlsx: 1 }) xtable.interceptor.mixin({ 'event.import': handleImportEvent, @@ -172,7 +170,7 @@ export const VXETablePluginExportXLSX: any = { } } -function i18n(key: string) { +function i18n (key: string) { if (VXETablePluginExportXLSX.t) { return VXETablePluginExportXLSX.t(key) } diff --git a/package.json b/package.json index 5f91854..7ebbee4 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "vxe-table-plugin-export-xlsx", - "version": "1.2.0", + "version": "1.2.1", "description": "基于 vxe-table 表格的增强插件,支持导出 xlsx 格式", "scripts": { "lib": "gulp build"