forked from sheetjs/sheetjs
SheetJS
ab2ecebac9
- basic support for parsing BIFF2-4 - basic support for writing BIFF2 - cleaned up some bad substr uses for IE6 compatibility - added flow type annotations for xlsx.flow.js - added numerous null guards (fixes #255 h/t @martinheidegger) - README cleanup (fixes #539 h/t @oliversalzburg) - pin jszip to local version (closes #408 h/t @limouri) bower issues: | id | author | comment | |-----:|:------------------|:------------------------------------------| | #254 | @kkirsche | fixes #254 by removing version from json | | #165 | @vincentcialdella | fixes #165 by changing default script | | #180 | @owencraig | fixes #180 by using xlsx.core.min.js | format issues: | id | author | comment | |-----:|:------------------|:------------------------------------------| | #271 | @morstaine | fixes #271 by reworking related parse fns | | #504 | @JanSchuermannPH | fixes #504 detect FullPaths h/t @Mithgol | | #508 | @basma-emad | fixes #508 offending file used `x:` NS |
41 lines
1.3 KiB
JavaScript
41 lines
1.3 KiB
JavaScript
function write_zip_type(wb/*:Workbook*/, opts/*:?WriteOpts*/) {
|
|
var o = opts||{};
|
|
var z = write_zip(wb, o);
|
|
var oopts = {};
|
|
if(o.compression) oopts.compression = 'DEFLATE';
|
|
switch(o.type) {
|
|
case "base64": oopts.type = "base64"; break;
|
|
case "binary": oopts.type = "string"; break;
|
|
case "buffer":
|
|
case "file": oopts.type = "nodebuffer"; break;
|
|
default: throw new Error("Unrecognized type " + o.type);
|
|
}
|
|
if(o.type === "file") return _fs.writeFileSync(o.file, z.generate(oopts));
|
|
return z.generate(oopts);
|
|
}
|
|
|
|
function writeSync(wb/*:Workbook*/, opts/*:?WriteOpts*/) {
|
|
var o = opts||{};
|
|
switch(o.bookType) {
|
|
case 'xml': return write_xlml(wb, o);
|
|
case 'biff2': return write_biff(wb, o);
|
|
default: return write_zip_type(wb, o);
|
|
}
|
|
}
|
|
|
|
function writeFileSync(wb/*:Workbook*/, filename/*:string*/, opts/*:?WriteFileOpts*/) {
|
|
var o = opts||{}; o.type = 'file';
|
|
o.file = filename;
|
|
if(!o.bookType) switch(o.file.substr(-5).toLowerCase()) {
|
|
case '.xlsx': o.bookType = 'xlsx'; break;
|
|
case '.xlsm': o.bookType = 'xlsm'; break;
|
|
case '.xlsb': o.bookType = 'xlsb'; break;
|
|
default: switch(o.file.substr(-4).toLowerCase()) {
|
|
case '.xls': o.bookType = 'biff2'; break;
|
|
case '.xml': o.bookType = 'xml'; break;
|
|
case '.ods': o.bookType = 'ods'; break;
|
|
}}
|
|
return writeSync(wb, o);
|
|
}
|
|
|