exceljs
Version:
Excel Workbook Manager - Read and Write xlsx and csv Files.
142 lines (130 loc) • 3.36 kB
JavaScript
const fs = require('fs');
// useful stuff
const inherits = function(cls, superCtor, statics, prototype) {
// eslint-disable-next-line no-underscore-dangle
cls.super_ = superCtor;
if (!prototype) {
prototype = statics;
statics = null;
}
if (statics) {
Object.keys(statics).forEach(i => {
Object.defineProperty(cls, i, Object.getOwnPropertyDescriptor(statics, i));
});
}
const properties = {
constructor: {
value: cls,
enumerable: false,
writable: false,
configurable: true,
},
};
if (prototype) {
Object.keys(prototype).forEach(i => {
properties[i] = Object.getOwnPropertyDescriptor(prototype, i);
});
}
cls.prototype = Object.create(superCtor.prototype, properties);
};
const utils = {
nop() {},
promiseImmediate(value) {
return new Promise(resolve => {
if (global.setImmediate) {
setImmediate(() => {
resolve(value);
});
} else {
// poorman's setImmediate - must wait at least 1ms
setTimeout(() => {
resolve(value);
}, 1);
}
});
},
inherits,
dateToExcel(d, date1904) {
return 25569 + d.getTime() / (24 * 3600 * 1000) - (date1904 ? 1462 : 0);
},
excelToDate(v, date1904) {
const millisecondSinceEpoch = Math.round((v - 25569 + (date1904 ? 1462 : 0)) * 24 * 3600 * 1000);
return new Date(millisecondSinceEpoch);
},
parsePath(filepath) {
const last = filepath.lastIndexOf('/');
return {
path: filepath.substring(0, last),
name: filepath.substring(last + 1),
};
},
getRelsPath(filepath) {
const path = utils.parsePath(filepath);
return `${path.path}/_rels/${path.name}.rels`;
},
xmlEncode(text) {
// eslint-disable-next-line no-control-regex
return text.replace(/[<>&'"\x7F\x00-\x08\x0B-\x0C\x0E-\x1F]/g, c => {
switch (c) {
case '<':
return '<';
case '>':
return '>';
case '&':
return '&';
case '\'':
return ''';
case '"':
return '"';
default:
return '';
}
});
},
xmlDecode(text) {
return text.replace(/&([a-z]*);/, c => {
switch (c) {
case '<':
return '<';
case '>':
return '>';
case '&':
return '&';
case ''':
return '\'';
case '"':
return '"';
default:
return c;
}
});
},
validInt(value) {
const i = parseInt(value, 10);
return !Number.isNaN(i) ? i : 0;
},
isDateFmt(fmt) {
if (!fmt) {
return false;
}
// must remove all chars inside quotes and []
fmt = fmt.replace(/\[[^\]]*]/g, '');
fmt = fmt.replace(/"[^"]*"/g, '');
// then check for date formatting chars
const result = fmt.match(/[ymdhMsb]+/) !== null;
return result;
},
fs: {
exists(path) {
return new Promise(resolve => {
fs.access(path, fs.constants.F_OK, err => {
resolve(!err);
});
});
},
},
toIsoDateString(dt) {
return dt.toIsoString().subsstr(0, 10);
},
};
module.exports = utils;