mirror of
https://gitee.com/x-extends/vxe-table-plugin-export-xlsx.git
synced 2026-01-21 05:21:33 +08:00
optimize
This commit is contained in:
32
dist/index.common.js
vendored
32
dist/index.common.js
vendored
File diff suppressed because one or more lines are too long
30
dist/index.js
vendored
30
dist/index.js
vendored
@@ -22,6 +22,11 @@
|
||||
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
||||
|
||||
/* eslint-disable no-unused-vars */
|
||||
|
||||
/* eslint-enable no-unused-vars */
|
||||
var _vxetable;
|
||||
|
||||
function getFooterCellValue($table, opts, rows, column) {
|
||||
var cellValue = _xeUtils["default"].toString(rows[$table.$getColumnIndex(column)]);
|
||||
|
||||
@@ -97,8 +102,8 @@
|
||||
downloadFile(blob, options);
|
||||
|
||||
if (message !== false) {
|
||||
$table.$XModal.message({
|
||||
message: i18n('vxe.table.expSuccess'),
|
||||
_vxetable.modal.message({
|
||||
message: _vxetable.t('vxe.table.expSuccess'),
|
||||
status: 'success'
|
||||
});
|
||||
}
|
||||
@@ -121,7 +126,7 @@
|
||||
document.body.removeChild(linkElem);
|
||||
}
|
||||
} else {
|
||||
console.error(i18n('vxe.error.notExp'));
|
||||
console.error(_vxetable.t('vxe.error.notExp'));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -201,14 +206,14 @@
|
||||
});
|
||||
|
||||
if (options.message !== false) {
|
||||
$table.$XModal.message({
|
||||
message: _xeUtils["default"].template(i18n('vxe.table.impSuccess'), [rows.length]),
|
||||
_vxetable.modal.message({
|
||||
message: _xeUtils["default"].template(_vxetable.t('vxe.table.impSuccess'), [rows.length]),
|
||||
status: 'success'
|
||||
});
|
||||
}
|
||||
} else if (options.message !== false) {
|
||||
$table.$XModal.message({
|
||||
message: i18n('vxe.error.impFields'),
|
||||
_vxetable.modal.message({
|
||||
message: _vxetable.t('vxe.error.impFields'),
|
||||
status: 'error'
|
||||
});
|
||||
}
|
||||
@@ -243,24 +248,19 @@
|
||||
|
||||
var VXETablePluginExportXLSX = {
|
||||
install: function install(xtable) {
|
||||
var interceptor = xtable.interceptor;
|
||||
_vxetable = xtable;
|
||||
Object.assign(xtable.types, {
|
||||
xlsx: 1
|
||||
});
|
||||
xtable.interceptor.mixin({
|
||||
interceptor.mixin({
|
||||
'event.import': handleImportEvent,
|
||||
'event.export': handleExportEvent
|
||||
});
|
||||
VXETablePluginExportXLSX.t = xtable.t;
|
||||
}
|
||||
};
|
||||
_exports.VXETablePluginExportXLSX = VXETablePluginExportXLSX;
|
||||
|
||||
function i18n(key) {
|
||||
if (VXETablePluginExportXLSX.t) {
|
||||
return VXETablePluginExportXLSX.t(key);
|
||||
}
|
||||
}
|
||||
|
||||
if (typeof window !== 'undefined' && window.VXETable) {
|
||||
window.VXETable.use(VXETablePluginExportXLSX);
|
||||
}
|
||||
|
||||
2
dist/index.min.js
vendored
2
dist/index.min.js
vendored
@@ -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 i=e.$table,t=e.options,o=e.columns,n=e.datas,a=t.sheetName,r=t.type,s=t.isHeader,l=t.isFooter,u=t.original,f=t.message,c=t.footerFilterMethod,d={},p=[],v=n;if(s&&o.forEach(function(e){d[e.id]=h.default.toString(u?e.property:e.getTitle())}),l){var x=i.getTableData().footerData;(c?x.filter(c):x).forEach(function(a){var r={};o.forEach(function(e){var t,o,n;r[e.id]=(t=i,o=a,n=e,h.default.toString(o[t.$getColumnIndex(n)]))}),p.push(r)})}var m=y.default.utils.book_new(),g=y.default.utils.json_to_sheet((s?[d]:[]).concat(v).concat(p),{skipHeader:!0});y.default.utils.book_append_sheet(m,g,a);var b=y.default.write(m,{bookType:r,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}(b)],{type:"application/octet-stream"}),t),!1!==f&&i.$XModal.message({message:w("vxe.table.expSuccess"),status:"success"})}function d(e){return e.replace(/^"/,"").replace(/"$/,"")}function n(e){var l=e.columns,u=e.options,t=e.file,f=e.$table,c=f._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(d),o.forEach(function(e){if(e){var o={};e.split(",").forEach(function(e,t){n[t]&&(o[n[t]]=d(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=[],l.forEach(function(e){var t=e.property;t&&o.push(t)}),o.every(function(e){return t.includes(e)}));s?(f.createData(i).then(function(e){"append"===u.mode?f.insertAt(e,-1):f.reloadData(e)}),!1!==u.message&&f.$XModal.message({message:h.default.template(w("vxe.table.impSuccess"),[i.length]),status:"success"})):!1!==u.message&&f.$XModal.message({message:w("vxe.error.impFields"),status:"error"}),c&&(c(s),f._importResolve=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});
|
||||
!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}}var w;function o(e){var i=e.$table,t=e.options,o=e.columns,n=e.datas,a=t.sheetName,r=t.type,s=t.isHeader,l=t.isFooter,u=t.original,f=t.message,c=t.footerFilterMethod,d={},p=[],v=n;if(s&&o.forEach(function(e){d[e.id]=h.default.toString(u?e.property:e.getTitle())}),l){var m=i.getTableData().footerData;(c?m.filter(c):m).forEach(function(a){var r={};o.forEach(function(e){var t,o,n;r[e.id]=(t=i,o=a,n=e,h.default.toString(o[t.$getColumnIndex(n)]))}),p.push(r)})}var x=y.default.utils.book_new(),g=y.default.utils.json_to_sheet((s?[d]:[]).concat(v).concat(p),{skipHeader:!0});y.default.utils.book_append_sheet(x,g,a);var b=y.default.write(x,{bookType:r,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.t("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}(b)],{type:"application/octet-stream"}),t),!1!==f&&w.modal.message({message:w.t("vxe.table.expSuccess"),status:"success"})}function d(e){return e.replace(/^"/,"").replace(/"$/,"")}function n(e){var l=e.columns,u=e.options,t=e.file,f=e.$table,c=f._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(d),o.forEach(function(e){if(e){var o={};e.split(",").forEach(function(e,t){n[t]&&(o[n[t]]=d(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=[],l.forEach(function(e){var t=e.property;t&&o.push(t)}),o.every(function(e){return t.includes(e)}));s?(f.createData(i).then(function(e){"append"===u.mode?f.insertAt(e,-1):f.reloadData(e)}),!1!==u.message&&w.modal.message({message:h.default.template(w.t("vxe.table.impSuccess"),[i.length]),status:"success"})):!1!==u.message&&w.modal.message({message:w.t("vxe.error.impFields"),status:"error"}),c&&(c(s),f._importResolve=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){var t=e.interceptor;w=e,Object.assign(e.types,{xlsx:1}),t.mixin({"event.import":a,"event.export":r})}};e.VXETablePluginExportXLSX=i,"undefined"!=typeof window&&window.VXETable&&window.VXETable.use(i);var s=i;e.default=s});
|
||||
34
index.ts
34
index.ts
@@ -1,6 +1,17 @@
|
||||
/* eslint-disable no-unused-vars */
|
||||
import XEUtils from 'xe-utils/methods/xe-utils'
|
||||
import { VXETable, Table, InterceptorExportParams, InterceptorImportParams, ColumnConfig, ExportOptons } from 'vxe-table/lib/vxe-table' // eslint-disable-line no-unused-vars
|
||||
import {
|
||||
VXETable,
|
||||
Table,
|
||||
InterceptorExportParams,
|
||||
InterceptorImportParams,
|
||||
ColumnConfig,
|
||||
ExportOptons
|
||||
} from 'vxe-table/lib/vxe-table'
|
||||
import XLSX from 'xlsx'
|
||||
/* eslint-enable no-unused-vars */
|
||||
|
||||
let _vxetable: typeof VXETable
|
||||
|
||||
function getFooterCellValue ($table: Table, opts: ExportOptons, rows: any[], column: ColumnConfig) {
|
||||
var cellValue = XEUtils.toString(rows[$table.$getColumnIndex(column)])
|
||||
@@ -45,7 +56,7 @@ function exportXLSX (params: InterceptorExportParams) {
|
||||
// 保存导出
|
||||
downloadFile(blob, options)
|
||||
if (message !== false) {
|
||||
$table.$XModal.message({ message: i18n('vxe.table.expSuccess'), status: 'success' })
|
||||
_vxetable.modal.message({ message: _vxetable.t('vxe.table.expSuccess'), status: 'success' })
|
||||
}
|
||||
}
|
||||
|
||||
@@ -64,7 +75,7 @@ function downloadFile (blob: Blob, options: ExportOptons) {
|
||||
document.body.removeChild(linkElem)
|
||||
}
|
||||
} else {
|
||||
console.error(i18n('vxe.error.notExp'))
|
||||
console.error(_vxetable.t('vxe.error.notExp'))
|
||||
}
|
||||
}
|
||||
|
||||
@@ -125,10 +136,10 @@ function importXLSX (params: InterceptorImportParams) {
|
||||
}
|
||||
})
|
||||
if (options.message !== false) {
|
||||
$table.$XModal.message({ message: XEUtils.template(i18n('vxe.table.impSuccess'), [rows.length]), status: 'success' })
|
||||
_vxetable.modal.message({ message: XEUtils.template(_vxetable.t('vxe.table.impSuccess'), [rows.length]), status: 'success' })
|
||||
}
|
||||
} else if (options.message !== false) {
|
||||
$table.$XModal.message({ message: i18n('vxe.error.impFields'), status: 'error' })
|
||||
_vxetable.modal.message({ message: _vxetable.t('vxe.error.impFields'), status: 'error' })
|
||||
}
|
||||
if (_importResolve) {
|
||||
_importResolve(status)
|
||||
@@ -155,20 +166,15 @@ function handleExportEvent (params: InterceptorExportParams) {
|
||||
/**
|
||||
* 基于 vxe-table 表格的增强插件,支持导出 xlsx 格式
|
||||
*/
|
||||
export const VXETablePluginExportXLSX: any = {
|
||||
export const VXETablePluginExportXLSX = {
|
||||
install (xtable: typeof VXETable) {
|
||||
const { interceptor } = xtable
|
||||
_vxetable = xtable
|
||||
Object.assign(xtable.types, { xlsx: 1 })
|
||||
xtable.interceptor.mixin({
|
||||
interceptor.mixin({
|
||||
'event.import': handleImportEvent,
|
||||
'event.export': handleExportEvent
|
||||
})
|
||||
VXETablePluginExportXLSX.t = xtable.t
|
||||
}
|
||||
}
|
||||
|
||||
function i18n (key: string) {
|
||||
if (VXETablePluginExportXLSX.t) {
|
||||
return VXETablePluginExportXLSX.t(key)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "vxe-table-plugin-export-xlsx",
|
||||
"version": "1.3.0-alpha.0",
|
||||
"version": "1.3.0",
|
||||
"description": "基于 vxe-table 表格的增强插件,支持导出 xlsx 格式",
|
||||
"scripts": {
|
||||
"lib": "gulp build"
|
||||
@@ -48,7 +48,7 @@
|
||||
"prettier": "^1.18.2",
|
||||
"typescript": "^3.8.3",
|
||||
"vue": "^2.6.11",
|
||||
"vxe-table": "^2.8.31-alpha.3",
|
||||
"vxe-table": "^2.8.31",
|
||||
"xe-utils": "^2.4.2",
|
||||
"xlsx": "^0.15.6"
|
||||
},
|
||||
|
||||
Reference in New Issue
Block a user