vxe-table-plugin-export-xlsx-xhx 1.0.13 → 1.0.15

Sign up to get free protection for your applications and to get access to all the features.
package/README.md CHANGED
@@ -10,7 +10,7 @@
10
10
 
11
11
  ## history
12
12
 
13
- 版本 1.0.13 增加导出时默认样式
13
+ 版本 1.0.15 增加导出时默认样式
14
14
  版本 1.0.11 完善单元文本cellType的支持自定义 string 或 number
15
15
  版本 1.0.9 修复IE11报错
16
16
  版本 1.0.2 修复未定义数据项导出
@@ -1,14 +1,19 @@
1
1
  "use strict";
2
2
 
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
3
4
  Object.defineProperty(exports, "__esModule", {
4
5
  value: true
5
6
  });
6
7
  exports["default"] = exports.VXETablePluginExportXLSX = void 0;
7
8
  var _xeUtils = _interopRequireDefault(require("xe-utils/methods/xe-utils"));
8
- var _xlsx = _interopRequireDefault(require("xlsx"));
9
+ var XLSX = _interopRequireWildcard(require("xlsx-js-style"));
10
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
11
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && 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; }
9
12
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
10
13
  /* eslint-disable no-unused-vars */
11
14
 
15
+ // import XLSX from 'xlsx'
16
+
12
17
  /* eslint-enable no-unused-vars */
13
18
  var _vxetable;
14
19
  function getCellLabel(column, cellValue) {
@@ -81,42 +86,62 @@ function exportXLSX(params) {
81
86
  footList.push(item);
82
87
  });
83
88
  }
84
- var book = _xlsx["default"].utils.book_new();
85
- var sheet = _xlsx["default"].utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), {
89
+ var book = XLSX.utils.book_new();
90
+ var sheet = XLSX.utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), {
86
91
  skipHeader: true
87
92
  });
88
93
  Object.keys(sheet).forEach(function (key) {
89
94
  // 非!开头的属性都是单元格
90
95
  if (!key.startsWith('!')) {
91
- sheet[key].s = {
92
- font: {
93
- sz: '12'
94
- },
95
- alignment: {
96
- horizontal: 'left',
97
- vertical: 'center',
98
- wrapText: true
99
- },
100
- border: {
101
- top: {
102
- style: 'thin'
103
- },
104
- right: {
105
- style: 'thin'
96
+ if (key.replace(/[^\d]/g, '') === '1') {
97
+ sheet[key].s = {
98
+ font: {
99
+ sz: '12',
100
+ bold: true
106
101
  },
107
- bottom: {
108
- style: 'thin'
102
+ fill: {
103
+ bgColor: {
104
+ rgb: 'FF0000'
105
+ }
109
106
  },
110
- left: {
111
- style: 'thin'
107
+ border: {
108
+ top: {
109
+ style: 'thin'
110
+ },
111
+ right: {
112
+ style: 'thin'
113
+ },
114
+ bottom: {
115
+ style: 'thin'
116
+ },
117
+ left: {
118
+ style: 'thin'
119
+ }
112
120
  }
113
- }
114
- };
121
+ };
122
+ } else {
123
+ sheet[key].s = {
124
+ border: {
125
+ top: {
126
+ style: 'thin'
127
+ },
128
+ right: {
129
+ style: 'thin'
130
+ },
131
+ bottom: {
132
+ style: 'thin'
133
+ },
134
+ left: {
135
+ style: 'thin'
136
+ }
137
+ }
138
+ };
139
+ }
115
140
  }
116
141
  });
117
142
  // 转换数据
118
- _xlsx["default"].utils.book_append_sheet(book, sheet, sheetName);
119
- var wbout = _xlsx["default"].write(book, {
143
+ XLSX.utils.book_append_sheet(book, sheet, sheetName);
144
+ var wbout = XLSX.write(book, {
120
145
  bookType: 'xlsx',
121
146
  bookSST: false,
122
147
  type: 'binary'
@@ -199,10 +224,10 @@ function importXLSX(params) {
199
224
  var _importResolve = $table._importResolve;
200
225
  var fileReader = new FileReader();
201
226
  fileReader.onload = function (e) {
202
- var workbook = _xlsx["default"].read(e.target.result, {
227
+ var workbook = XLSX.read(e.target.result, {
203
228
  type: 'binary'
204
229
  });
205
- var csvData = _xlsx["default"].utils.sheet_to_csv(workbook.Sheets.Sheet1);
230
+ var csvData = XLSX.utils.sheet_to_csv(workbook.Sheets.Sheet1);
206
231
  var _parseCsv = parseCsv(columns, csvData),
207
232
  fields = _parseCsv.fields,
208
233
  rows = _parseCsv.rows;
@@ -268,4 +293,4 @@ if (typeof window !== 'undefined' && window.VXETable) {
268
293
  }
269
294
  var _default = VXETablePluginExportXLSX;
270
295
  exports["default"] = _default;
271
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.ts","index.js"],"names":["_vxetable","getCellLabel","column","cellValue","cellType","XEUtils","toString","isNaN","Number","length","getFooterCellValue","$table","opts","rows","$getColumnIndex","toBuffer","wbout","buf","ArrayBuffer","view","Uint8Array","index","charCodeAt","exportXLSX","params","options","columns","datas","sheetName","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","Object","keys","key","startsWith","s","font","sz","alignment","horizontal","vertical","wrapText","border","top","style","right","bottom","left","book_append_sheet","write","bookType","bookSST","type","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","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 getCellLabel (column: ColumnConfig, cellValue: any) {\r\n  if (cellValue) {\r\n    switch (column.cellType) {\r\n      case 'string':\r\n        return XEUtils.toString(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\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, 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  Object.keys(sheet).forEach(key => {\r\n    // 非!开头的属性都是单元格\r\n    if (!key.startsWith('!')) {\r\n      sheet[key].s = {\r\n        font: {\r\n          sz: '12'\r\n        },\r\n        alignment: {\r\n          horizontal: 'left',\r\n          vertical: 'center',\r\n          wrapText: true\r\n        },\r\n        border: {\r\n          top: { style: 'thin' },\r\n          right: { style: 'thin' },\r\n          bottom: { style: 'thin' },\r\n          left: { style: 'thin' }\r\n        }\r\n      }\r\n    }\r\n  })\r\n\r\n  // 转换数据\r\n  XLSX.utils.book_append_sheet(book, sheet, sheetName)\r\n  const wbout = XLSX.write(book, { bookType: 'xlsx', 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.toString(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, 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    Object.keys(sheet).forEach(key => {\n        // 非!开头的属性都是单元格\n        if (!key.startsWith('!')) {\n            sheet[key].s = {\n                font: {\n                    sz: '12'\n                },\n                alignment: {\n                    horizontal: 'left',\n                    vertical: 'center',\n                    wrapText: true\n                },\n                border: {\n                    top: { style: 'thin' },\n                    right: { style: 'thin' },\n                    bottom: { style: 'thin' },\n                    left: { style: 'thin' }\n                }\n            };\n        }\n    });\n    // 转换数据\n    XLSX.utils.book_append_sheet(book, sheet, sheetName);\n    const wbout = XLSX.write(book, { bookType: 'xlsx', 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"]}
296
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.ts","index.js"],"names":["_vxetable","getCellLabel","column","cellValue","cellType","XEUtils","toString","isNaN","Number","length","getFooterCellValue","$table","opts","rows","$getColumnIndex","toBuffer","wbout","buf","ArrayBuffer","view","Uint8Array","index","charCodeAt","exportXLSX","params","options","columns","datas","sheetName","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","Object","keys","key","startsWith","replace","s","font","sz","bold","fill","bgColor","rgb","border","top","style","right","bottom","left","book_append_sheet","write","bookType","bookSST","type","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","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","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\n// import XLSX from 'xlsx'\r\nimport * as XLSX from 'xlsx-js-style'\r\n/* eslint-enable no-unused-vars */\r\n\r\nlet _vxetable: typeof VXETable\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.toString(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\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, 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  Object.keys(sheet).forEach(key => {\r\n    // 非!开头的属性都是单元格\r\n    if (!key.startsWith('!')) {\r\n      if (key.replace(/[^\\d]/g, '') === '1') {\r\n        sheet[key].s = {\r\n          font: {\r\n            sz: '12',\r\n            bold: true\r\n          },\r\n          fill: {\r\n            bgColor: { rgb: 'FF0000' }\r\n          },\r\n          border: {\r\n            top: { style: 'thin' },\r\n            right: { style: 'thin' },\r\n            bottom: { style: 'thin' },\r\n            left: { style: 'thin' }\r\n          }\r\n        }\r\n      } else {\r\n        sheet[key].s = {\r\n          border: {\r\n            top: { style: 'thin' },\r\n            right: { style: 'thin' },\r\n            bottom: { style: 'thin' },\r\n            left: { style: 'thin' }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  })\r\n\r\n  // 转换数据\r\n  XLSX.utils.book_append_sheet(book, sheet, sheetName)\r\n  const wbout = XLSX.write(book, { bookType: 'xlsx', 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';\n// import XLSX from 'xlsx'\nimport * as XLSX from 'xlsx-js-style';\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.toString(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, 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    Object.keys(sheet).forEach(key => {\n        // 非!开头的属性都是单元格\n        if (!key.startsWith('!')) {\n            if (key.replace(/[^\\d]/g, '') === '1') {\n                sheet[key].s = {\n                    font: {\n                        sz: '12',\n                        bold: true\n                    },\n                    fill: {\n                        bgColor: { rgb: 'FF0000' }\n                    },\n                    border: {\n                        top: { style: 'thin' },\n                        right: { style: 'thin' },\n                        bottom: { style: 'thin' },\n                        left: { style: 'thin' }\n                    }\n                };\n            }\n            else {\n                sheet[key].s = {\n                    border: {\n                        top: { style: 'thin' },\n                        right: { style: 'thin' },\n                        bottom: { style: 'thin' },\n                        left: { style: 'thin' }\n                    }\n                };\n            }\n        }\n    });\n    // 转换数据\n    XLSX.utils.book_append_sheet(book, sheet, sheetName);\n    const wbout = XLSX.write(book, { bookType: 'xlsx', 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"]}
package/dist/index.js CHANGED
@@ -1,16 +1,17 @@
1
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
1
2
  (function (global, factory) {
2
3
  if (typeof define === "function" && define.amd) {
3
- define("vxe-table-plugin-export-xlsx-xhx", ["exports", "xe-utils", "xlsx"], factory);
4
+ define("vxe-table-plugin-export-xlsx-xhx", ["exports", "xe-utils", "xlsx-js-style"], factory);
4
5
  } else if (typeof exports !== "undefined") {
5
- factory(exports, require("xe-utils"), require("xlsx"));
6
+ factory(exports, require("xe-utils"), require("xlsx-js-style"));
6
7
  } else {
7
8
  var mod = {
8
9
  exports: {}
9
10
  };
10
- factory(mod.exports, global.XEUtils, global.XLSX);
11
+ factory(mod.exports, global.XEUtils, global.xlsxJsStyle);
11
12
  global.VXETablePluginExportXLSX = mod.exports.default;
12
13
  }
13
- })(typeof globalThis !== "undefined" ? globalThis : typeof self !== "undefined" ? self : this, function (_exports, _xeUtils, _xlsx) {
14
+ })(typeof globalThis !== "undefined" ? globalThis : typeof self !== "undefined" ? self : this, function (_exports, _xeUtils, XLSX) {
14
15
  "use strict";
15
16
 
16
17
  Object.defineProperty(_exports, "__esModule", {
@@ -18,10 +19,14 @@
18
19
  });
19
20
  _exports["default"] = _exports.VXETablePluginExportXLSX = void 0;
20
21
  _xeUtils = _interopRequireDefault(_xeUtils);
21
- _xlsx = _interopRequireDefault(_xlsx);
22
+ XLSX = _interopRequireWildcard(XLSX);
23
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
24
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && 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; }
22
25
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
23
26
  /* eslint-disable no-unused-vars */
24
27
 
28
+ // import XLSX from 'xlsx'
29
+
25
30
  /* eslint-enable no-unused-vars */
26
31
  var _vxetable;
27
32
  function getCellLabel(column, cellValue) {
@@ -94,42 +99,62 @@
94
99
  footList.push(item);
95
100
  });
96
101
  }
97
- var book = _xlsx["default"].utils.book_new();
98
- var sheet = _xlsx["default"].utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), {
102
+ var book = XLSX.utils.book_new();
103
+ var sheet = XLSX.utils.json_to_sheet((isHeader ? [colHead] : []).concat(rowList).concat(footList), {
99
104
  skipHeader: true
100
105
  });
101
106
  Object.keys(sheet).forEach(function (key) {
102
107
  // 非!开头的属性都是单元格
103
108
  if (!key.startsWith('!')) {
104
- sheet[key].s = {
105
- font: {
106
- sz: '12'
107
- },
108
- alignment: {
109
- horizontal: 'left',
110
- vertical: 'center',
111
- wrapText: true
112
- },
113
- border: {
114
- top: {
115
- style: 'thin'
116
- },
117
- right: {
118
- style: 'thin'
109
+ if (key.replace(/[^\d]/g, '') === '1') {
110
+ sheet[key].s = {
111
+ font: {
112
+ sz: '12',
113
+ bold: true
119
114
  },
120
- bottom: {
121
- style: 'thin'
115
+ fill: {
116
+ bgColor: {
117
+ rgb: 'FF0000'
118
+ }
122
119
  },
123
- left: {
124
- style: 'thin'
120
+ border: {
121
+ top: {
122
+ style: 'thin'
123
+ },
124
+ right: {
125
+ style: 'thin'
126
+ },
127
+ bottom: {
128
+ style: 'thin'
129
+ },
130
+ left: {
131
+ style: 'thin'
132
+ }
125
133
  }
126
- }
127
- };
134
+ };
135
+ } else {
136
+ sheet[key].s = {
137
+ border: {
138
+ top: {
139
+ style: 'thin'
140
+ },
141
+ right: {
142
+ style: 'thin'
143
+ },
144
+ bottom: {
145
+ style: 'thin'
146
+ },
147
+ left: {
148
+ style: 'thin'
149
+ }
150
+ }
151
+ };
152
+ }
128
153
  }
129
154
  });
130
155
  // 转换数据
131
- _xlsx["default"].utils.book_append_sheet(book, sheet, sheetName);
132
- var wbout = _xlsx["default"].write(book, {
156
+ XLSX.utils.book_append_sheet(book, sheet, sheetName);
157
+ var wbout = XLSX.write(book, {
133
158
  bookType: 'xlsx',
134
159
  bookSST: false,
135
160
  type: 'binary'
@@ -212,10 +237,10 @@
212
237
  var _importResolve = $table._importResolve;
213
238
  var fileReader = new FileReader();
214
239
  fileReader.onload = function (e) {
215
- var workbook = _xlsx["default"].read(e.target.result, {
240
+ var workbook = XLSX.read(e.target.result, {
216
241
  type: 'binary'
217
242
  });
218
- var csvData = _xlsx["default"].utils.sheet_to_csv(workbook.Sheets.Sheet1);
243
+ var csvData = XLSX.utils.sheet_to_csv(workbook.Sheets.Sheet1);
219
244
  var _parseCsv = parseCsv(columns, csvData),
220
245
  fields = _parseCsv.fields,
221
246
  rows = _parseCsv.rows;
package/dist/index.min.js CHANGED
@@ -1 +1 @@
1
- !function(e,t){"function"==typeof define&&define.amd?define("vxe-table-plugin-export-xlsx-xhx",["exports","xe-utils","xlsx"],t):"undefined"!=typeof exports?t(exports,require("xe-utils"),require("xlsx")):(t((t={exports:{}}).exports,e.XEUtils,e.XLSX),e.VXETablePluginExportXLSX=t.exports.default)}("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:this,function(e,p,m){"use strict";function t(e){return e&&e.__esModule?e:{default:e}}var h;function n(e){var o=e.$table,t=e.options,r=e.columns,e=e.datas,n=t.sheetName,a=t.isHeader,i=t.isFooter,s=t.original,l=t.message,u=t.footerFilterMethod,c={},f=[],e=(a&&r.forEach(function(e){c[e.id]=p.default.toString(s?e.property:e.getTitle())}),e.map(function(t){var n={};return r.forEach(function(e){n[e.id]=function(e,t){if(t)switch(e.cellType){case"string":return p.default.toString(t);case"number":if(isNaN(t))break;return Number(t);default:if(t.length<12&&!isNaN(t))return Number(t)}return t}(e,t[e.id])}),n})),u=(i&&(i=o.getTableData().footerData,(u?i.filter(u):i).forEach(function(t){var n={};r.forEach(function(e){n[e.id]=p.default.toString(t[o.$getColumnIndex(e)])}),f.push(n)})),m.default.utils.book_new()),d=m.default.utils.json_to_sheet((a?[c]:[]).concat(e).concat(f),{skipHeader:!0}),i=(Object.keys(d).forEach(function(e){e.startsWith("!")||(d[e].s={font:{sz:"12"},alignment:{horizontal:"left",vertical:"center",wrapText:!0},border:{top:{style:"thin"},right:{style:"thin"},bottom:{style:"thin"},left:{style:"thin"}}})}),m.default.utils.book_append_sheet(u,d,n),m.default.write(u,{bookType:"xlsx",bookSST:!1,type:"binary"})),a=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}(i)],{type:"application/octet-stream"}),e=t;window.Blob?(n=e.filename,e=e.type,navigator.msSaveBlob?navigator.msSaveBlob(a,"".concat(n,".").concat(e)):((u=document.createElement("a")).target="_blank",u.download="".concat(n,".").concat(e),u.href=URL.createObjectURL(a),document.body.appendChild(u),u.click(),document.body.removeChild(u))):console.error(h.t("vxe.error.notExp")),!1!==l&&h.modal.message({message:h.t("vxe.table.expSuccess"),status:"success"})}function c(e){return e.replace(/^"/,"").replace(/"$/,"")}function o(e){var i=e.columns,s=e.options,t=e.file,l=e.$table,u=l._importResolve,e=new FileReader;e.onload=function(e){var o,t,n,r,e=m.default.read(e.target.result,{type:"binary"}),e=m.default.utils.sheet_to_csv(e.Sheets.Sheet1),e=(e=(e=e).split("\n"),o=[],t=[],e.length&&(a=e.slice(1),e[0].split(",").map(c),a.forEach(function(e){var n;e&&(n={},e.split(",").forEach(function(e,t){o[t]&&(n[o[t]]=c(e))}),t.push(n))})),{fields:o,rows:t}),a=e.rows,e=(n=e.fields,r=[],i.forEach(function(e){e=e.property;e&&r.push(e)}),r.every(function(e){return n.includes(e)}));e?(l.createData(a).then(function(e){"append"===s.mode?l.insertAt(e,-1):l.reloadData(e)}),!1!==s.message&&h.modal.message({message:p.default.template(h.t("vxe.table.impSuccess"),[a.length]),status:"success"})):!1!==s.message&&h.modal.message({message:h.t("vxe.error.impFields"),status:"error"}),u&&(u(e),l._importResolve=null)},e.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,p=t(p),m=t(m);var i={install:function(e){var t=e.interceptor;h=e,Object.assign(e.types,{xlsx:1}),t.mixin({"event.import":r,"event.export":a})}};e.VXETablePluginExportXLSX=i,"undefined"!=typeof window&&window.VXETable&&window.VXETable.use(i);e.default=i});
1
+ function _typeof(e){return(_typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}!function(e,t){"function"==typeof define&&define.amd?define("vxe-table-plugin-export-xlsx-xhx",["exports","xe-utils","xlsx-js-style"],t):"undefined"!=typeof exports?t(exports,require("xe-utils"),require("xlsx-js-style")):(t((t={exports:{}}).exports,e.XEUtils,e.xlsxJsStyle),e.VXETablePluginExportXLSX=t.exports.default)}("undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:this,function(e,d,y){"use strict";var b;function s(e){var t,o;return"function"!=typeof WeakMap?null:(t=new WeakMap,o=new WeakMap,(s=function(e){return e?o:t})(e))}function t(e){var n=e.$table,t=e.options,r=e.columns,e=e.datas,o=t.sheetName,i=t.isHeader,s=t.isFooter,a=t.original,l=t.message,u=t.footerFilterMethod,f={},c=[],e=(i&&r.forEach(function(e){f[e.id]=d.default.toString(a?e.property:e.getTitle())}),e.map(function(t){var o={};return r.forEach(function(e){o[e.id]=function(e,t){if(t)switch(e.cellType){case"string":return d.default.toString(t);case"number":if(isNaN(t))break;return Number(t);default:if(t.length<12&&!isNaN(t))return Number(t)}return t}(e,t[e.id])}),o})),u=(s&&(s=n.getTableData().footerData,(u?s.filter(u):s).forEach(function(t){var o={};r.forEach(function(e){o[e.id]=d.default.toString(t[n.$getColumnIndex(e)])}),c.push(o)})),y.utils.book_new()),p=y.utils.json_to_sheet((i?[f]:[]).concat(e).concat(c),{skipHeader:!0}),s=(Object.keys(p).forEach(function(e){e.startsWith("!")||("1"===e.replace(/[^\d]/g,"")?p[e].s={font:{sz:"12",bold:!0},fill:{bgColor:{rgb:"FF0000"}},border:{top:{style:"thin"},right:{style:"thin"},bottom:{style:"thin"},left:{style:"thin"}}}:p[e].s={border:{top:{style:"thin"},right:{style:"thin"},bottom:{style:"thin"},left:{style:"thin"}}})}),y.utils.book_append_sheet(u,p,o),y.write(u,{bookType:"xlsx",bookSST:!1,type:"binary"})),i=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}(s)],{type:"application/octet-stream"}),e=t;window.Blob?(o=e.filename,e=e.type,navigator.msSaveBlob?navigator.msSaveBlob(i,"".concat(o,".").concat(e)):((u=document.createElement("a")).target="_blank",u.download="".concat(o,".").concat(e),u.href=URL.createObjectURL(i),document.body.appendChild(u),u.click(),document.body.removeChild(u))):console.error(b.t("vxe.error.notExp")),!1!==l&&b.modal.message({message:b.t("vxe.table.expSuccess"),status:"success"})}function f(e){return e.replace(/^"/,"").replace(/"$/,"")}function o(e){var s=e.columns,a=e.options,t=e.file,l=e.$table,u=l._importResolve,e=new FileReader;e.onload=function(e){var n,t,o,r,e=y.read(e.target.result,{type:"binary"}),e=y.utils.sheet_to_csv(e.Sheets.Sheet1),e=(e=(e=e).split("\n"),n=[],t=[],e.length&&(i=e.slice(1),e[0].split(",").map(f),i.forEach(function(e){var o;e&&(o={},e.split(",").forEach(function(e,t){n[t]&&(o[n[t]]=f(e))}),t.push(o))})),{fields:n,rows:t}),i=e.rows,e=(o=e.fields,r=[],s.forEach(function(e){e=e.property;e&&r.push(e)}),r.every(function(e){return o.includes(e)}));e?(l.createData(i).then(function(e){"append"===a.mode?l.insertAt(e,-1):l.reloadData(e)}),!1!==a.message&&b.modal.message({message:d.default.template(b.t("vxe.table.impSuccess"),[i.length]),status:"success"})):!1!==a.message&&b.modal.message({message:b.t("vxe.error.impFields"),status:"error"}),u&&(u(e),l._importResolve=null)},e.readAsBinaryString(t)}function n(e){if("xlsx"===e.options.type)return o(e),!1}function r(e){if("xlsx"===e.options.type)return t(e),!1}Object.defineProperty(e,"__esModule",{value:!0}),e.default=e.VXETablePluginExportXLSX=void 0,d=(i=d)&&i.__esModule?i:{default:i},y=function(e,t){if(!t&&e&&e.__esModule)return e;if(null===e||"object"!==_typeof(e)&&"function"!=typeof e)return{default:e};t=s(t);if(t&&t.has(e))return t.get(e);var o,n={},r=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(o in e){var i;"default"!==o&&Object.prototype.hasOwnProperty.call(e,o)&&((i=r?Object.getOwnPropertyDescriptor(e,o):null)&&(i.get||i.set)?Object.defineProperty(n,o,i):n[o]=e[o])}n.default=e,t&&t.set(e,n);return n}(y);var i={install:function(e){var t=e.interceptor;b=e,Object.assign(e.types,{xlsx:1}),t.mixin({"event.import":n,"event.export":r})}};e.VXETablePluginExportXLSX=i,"undefined"!=typeof window&&window.VXETable&&window.VXETable.use(i);e.default=i});
package/index.ts CHANGED
@@ -8,7 +8,8 @@ import {
8
8
  ColumnConfig,
9
9
  ExportOptons
10
10
  } from 'vxe-table/lib/vxe-table'
11
- import XLSX from 'xlsx'
11
+ // import XLSX from 'xlsx'
12
+ import * as XLSX from 'xlsx-js-style'
12
13
  /* eslint-enable no-unused-vars */
13
14
 
14
15
  let _vxetable: typeof VXETable
@@ -84,20 +85,30 @@ function exportXLSX (params: InterceptorExportParams) {
84
85
  Object.keys(sheet).forEach(key => {
85
86
  // 非!开头的属性都是单元格
86
87
  if (!key.startsWith('!')) {
87
- sheet[key].s = {
88
- font: {
89
- sz: '12'
90
- },
91
- alignment: {
92
- horizontal: 'left',
93
- vertical: 'center',
94
- wrapText: true
95
- },
96
- border: {
97
- top: { style: 'thin' },
98
- right: { style: 'thin' },
99
- bottom: { style: 'thin' },
100
- left: { style: 'thin' }
88
+ if (key.replace(/[^\d]/g, '') === '1') {
89
+ sheet[key].s = {
90
+ font: {
91
+ sz: '12',
92
+ bold: true
93
+ },
94
+ fill: {
95
+ bgColor: { rgb: 'FF0000' }
96
+ },
97
+ border: {
98
+ top: { style: 'thin' },
99
+ right: { style: 'thin' },
100
+ bottom: { style: 'thin' },
101
+ left: { style: 'thin' }
102
+ }
103
+ }
104
+ } else {
105
+ sheet[key].s = {
106
+ border: {
107
+ top: { style: 'thin' },
108
+ right: { style: 'thin' },
109
+ bottom: { style: 'thin' },
110
+ left: { style: 'thin' }
111
+ }
101
112
  }
102
113
  }
103
114
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "vxe-table-plugin-export-xlsx-xhx",
3
- "version": "1.0.13",
3
+ "version": "1.0.15",
4
4
  "description": "基于 vxe-table 表格的增强插件,支持导出 xlsx 格式",
5
5
  "scripts": {
6
6
  "lib": "gulp build"
@@ -72,5 +72,8 @@
72
72
  "bugs": {
73
73
  "url": "https://github.com/xuliangzhan/vxe-table-plugin-export-xlsx/issues"
74
74
  },
75
- "homepage": "https://github.com/xuliangzhan/vxe-table-plugin-export-xlsx#readme"
75
+ "homepage": "https://github.com/xuliangzhan/vxe-table-plugin-export-xlsx#readme",
76
+ "dependencies": {
77
+ "xlsx-js-style": "^1.2.0"
78
+ }
76
79
  }