forked from sheetjs/sheetjs
SheetJS
86d6a093f0
- README and example cleanup - basic XLSB and ODS write support - flow typecheck for ODS file Note: xlsx.js flow fails: https://github.com/facebook/flow/issues/380 - exposed jszip compression (fixes #220, closes #284) README issues: | id | author | comment | |-----:|:---------------|:---------------------------------------------| | #202 | @sao93859 | closes #202 | | #211 | @alexanderchan | closes #211 corrected examples | | #327 | @cskaandorp | changed saveAs example to match write tests | | #424 | @dskrvk | added note about s2roa h/t @LeonardoPatignio | | #496 | @jimmywarting | closes #496 adapted rABS examples with rAAS | ODS file format issues: | id | author | comment | |-----:|:---------------|:---------------------------------------------| | #148 | @user4815162342| closes #148 h/t @ziacik | | #166 | @paulproteus | closes #166 rudimentary ODS write support | | #177 | @ziacik | closes #177 | | #179 | @ziacik | closes #179 use JSON when available | | #317 | @ziacik | closes #317 | | #328 | @think01 | closes #328 | | #383 | @mdamt | closes #383 duplicate cells should be copied | | #430 | @RB-Lab | closes #430 | | #546 | @lgodard | closes #546 thanks to other changes |
40 lines
1.1 KiB
JavaScript
40 lines
1.1 KiB
JavaScript
function write_zip_type(wb, opts) {
|
|
var o = opts||{};
|
|
var z = write_zip(wb, o);
|
|
var oopts = {};
|
|
if(opts.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, opts) {
|
|
var o = opts||{};
|
|
switch(o.bookType) {
|
|
case 'xml': return write_xlml(wb, o);
|
|
default: return write_zip_type(wb, o);
|
|
}
|
|
}
|
|
|
|
function writeFileSync(wb, filename, opts) {
|
|
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 = 'xls'; break;
|
|
case '.xml': o.bookType = 'xml'; break;
|
|
case '.ods': o.bookType = 'ods'; break;
|
|
}}
|
|
return writeSync(wb, o);
|
|
}
|
|
|