@atomictech/xlsx-write-stream
Advanced tools
Comparing version 1.0.3 to 1.1.0
@@ -19,6 +19,8 @@ "use strict"; | ||
* @param {Object} [options] | ||
* @param {Boolean} [options.format=true] - If set to false writer will not format cells with number, date, boolean and text. Default: true. | ||
* @param {Boolean} [options.headers=false] - If set to true writer will output first row with an header style. | ||
* @param {Boolean} [options.format=true] - If set to false writer will not format cells with number, date, boolean and text. | ||
* @param {Styles} [options.styles=new Styles()] - If set you can overwrite default standard type styles by other standard ones or even define custom `formatCode`. | ||
*/ | ||
constructor({ | ||
headers = false, | ||
format = true, | ||
@@ -31,4 +33,6 @@ styles = new _templates.Styles() | ||
this.rowCount = 0; | ||
this.headers = headers; | ||
this.format = format; | ||
this.styles = styles; | ||
if (this.headers) throw new Error('Headers special style output not yet implemented.'); | ||
} | ||
@@ -41,4 +45,2 @@ /** | ||
_transform(row, encoding, callback) { | ||
if (!Array.isArray(row)) return callback(); // TODO: Handle row as Object with column headers as keys | ||
const xlsxRow = (0, _templates.Row)(this.rowCount, row, this.format, this.styles); | ||
@@ -52,2 +54,2 @@ this.rowCount++; | ||
exports.default = XLSXRowTransform; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9YTFNYUm93VHJhbnNmb3JtLmpzIl0sIm5hbWVzIjpbIlhMU1hSb3dUcmFuc2Zvcm0iLCJUcmFuc2Zvcm0iLCJjb25zdHJ1Y3RvciIsImZvcm1hdCIsInN0eWxlcyIsIlN0eWxlcyIsIm9iamVjdE1vZGUiLCJyb3dDb3VudCIsIl90cmFuc2Zvcm0iLCJyb3ciLCJlbmNvZGluZyIsImNhbGxiYWNrIiwiQXJyYXkiLCJpc0FycmF5IiwieGxzeFJvdyJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUVBOzs7QUFHZSxNQUFNQSxnQkFBTixTQUErQkMsaUJBQS9CLENBQXlDO0FBQ3REOzs7Ozs7QUFNQUMsRUFBQUEsV0FBVyxDQUFDO0FBQUVDLElBQUFBLE1BQU0sR0FBRyxJQUFYO0FBQWlCQyxJQUFBQSxNQUFNLEdBQUcsSUFBSUMsaUJBQUo7QUFBMUIsR0FBRCxFQUEyQztBQUNwRCxVQUFNO0FBQUVDLE1BQUFBLFVBQVUsRUFBRTtBQUFkLEtBQU47QUFDQSxTQUFLQyxRQUFMLEdBQWdCLENBQWhCO0FBQ0EsU0FBS0osTUFBTCxHQUFjQSxNQUFkO0FBQ0EsU0FBS0MsTUFBTCxHQUFjQSxNQUFkO0FBQ0Q7QUFFRDs7Ozs7QUFHQUksRUFBQUEsVUFBVSxDQUFDQyxHQUFELEVBQU1DLFFBQU4sRUFBZ0JDLFFBQWhCLEVBQTBCO0FBQ2xDLFFBQUksQ0FBQ0MsS0FBSyxDQUFDQyxPQUFOLENBQWNKLEdBQWQsQ0FBTCxFQUF5QixPQUFPRSxRQUFRLEVBQWYsQ0FEUyxDQUNVOztBQUU1QyxVQUFNRyxPQUFPLEdBQUcsb0JBQUksS0FBS1AsUUFBVCxFQUFtQkUsR0FBbkIsRUFBd0IsS0FBS04sTUFBN0IsRUFBcUMsS0FBS0MsTUFBMUMsQ0FBaEI7QUFDQSxTQUFLRyxRQUFMO0FBQ0FJLElBQUFBLFFBQVEsQ0FBQyxJQUFELEVBQU9HLE9BQVAsQ0FBUjtBQUNEOztBQXZCcUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcmFuc2Zvcm0gfSBmcm9tICdzdHJlYW0nO1xuaW1wb3J0IHsgUm93LCBTdHlsZXMgfSBmcm9tICcuL3RlbXBsYXRlcyc7XG5cbi8qKlxuICogQ2xhc3MgcmVwcmVzZW50aW5nIGEgWExTWCBSb3cgdHJhbnNmb3JtYXRpb24gZnJvbSBhcnJheSB0byBSb3cuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFhMU1hSb3dUcmFuc2Zvcm0gZXh0ZW5kcyBUcmFuc2Zvcm0ge1xuICAvKipcbiAgICogQ3JlYXRlIG5ldyB4bHN4IHJvdyB0cmFuc2Zvcm0gc3RyZWFtXG4gICAqIEBwYXJhbSB7T2JqZWN0fSBbb3B0aW9uc11cbiAgICogQHBhcmFtIHtCb29sZWFufSBbb3B0aW9ucy5mb3JtYXQ9dHJ1ZV0gLSBJZiBzZXQgdG8gZmFsc2Ugd3JpdGVyIHdpbGwgbm90IGZvcm1hdCBjZWxscyB3aXRoIG51bWJlciwgZGF0ZSwgYm9vbGVhbiBhbmQgdGV4dC4gRGVmYXVsdDogdHJ1ZS5cbiAgICogQHBhcmFtIHtTdHlsZXN9IFtvcHRpb25zLnN0eWxlcz1uZXcgU3R5bGVzKCldIC0gSWYgc2V0IHlvdSBjYW4gb3ZlcndyaXRlIGRlZmF1bHQgc3RhbmRhcmQgdHlwZSBzdHlsZXMgYnkgb3RoZXIgc3RhbmRhcmQgb25lcyBvciBldmVuIGRlZmluZSBjdXN0b20gYGZvcm1hdENvZGVgLlxuICAgKi9cbiAgY29uc3RydWN0b3IoeyBmb3JtYXQgPSB0cnVlLCBzdHlsZXMgPSBuZXcgU3R5bGVzKCkgfSkge1xuICAgIHN1cGVyKHsgb2JqZWN0TW9kZTogdHJ1ZSB9KTtcbiAgICB0aGlzLnJvd0NvdW50ID0gMDtcbiAgICB0aGlzLmZvcm1hdCA9IGZvcm1hdDtcbiAgICB0aGlzLnN0eWxlcyA9IHN0eWxlcztcbiAgfVxuXG4gIC8qKlxuICAgKiBUcmFuc2Zvcm0gYXJyYXkgdG8gcm93IHN0cmluZ1xuICAgKi9cbiAgX3RyYW5zZm9ybShyb3csIGVuY29kaW5nLCBjYWxsYmFjaykge1xuICAgIGlmICghQXJyYXkuaXNBcnJheShyb3cpKSByZXR1cm4gY2FsbGJhY2soKTsgLy8gVE9ETzogSGFuZGxlIHJvdyBhcyBPYmplY3Qgd2l0aCBjb2x1bW4gaGVhZGVycyBhcyBrZXlzXG5cbiAgICBjb25zdCB4bHN4Um93ID0gUm93KHRoaXMucm93Q291bnQsIHJvdywgdGhpcy5mb3JtYXQsIHRoaXMuc3R5bGVzKTtcbiAgICB0aGlzLnJvd0NvdW50Kys7XG4gICAgY2FsbGJhY2sobnVsbCwgeGxzeFJvdyk7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9YTFNYUm93VHJhbnNmb3JtLmpzIl0sIm5hbWVzIjpbIlhMU1hSb3dUcmFuc2Zvcm0iLCJUcmFuc2Zvcm0iLCJjb25zdHJ1Y3RvciIsImhlYWRlcnMiLCJmb3JtYXQiLCJzdHlsZXMiLCJTdHlsZXMiLCJvYmplY3RNb2RlIiwicm93Q291bnQiLCJFcnJvciIsIl90cmFuc2Zvcm0iLCJyb3ciLCJlbmNvZGluZyIsImNhbGxiYWNrIiwieGxzeFJvdyJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUVBOzs7QUFHZSxNQUFNQSxnQkFBTixTQUErQkMsaUJBQS9CLENBQXlDO0FBQ3REOzs7Ozs7O0FBT0FDLEVBQUFBLFdBQVcsQ0FBQztBQUFFQyxJQUFBQSxPQUFPLEdBQUcsS0FBWjtBQUFtQkMsSUFBQUEsTUFBTSxHQUFHLElBQTVCO0FBQWtDQyxJQUFBQSxNQUFNLEdBQUcsSUFBSUMsaUJBQUo7QUFBM0MsR0FBRCxFQUE0RDtBQUNyRSxVQUFNO0FBQUVDLE1BQUFBLFVBQVUsRUFBRTtBQUFkLEtBQU47QUFFQSxTQUFLQyxRQUFMLEdBQWdCLENBQWhCO0FBQ0EsU0FBS0wsT0FBTCxHQUFlQSxPQUFmO0FBQ0EsU0FBS0MsTUFBTCxHQUFjQSxNQUFkO0FBQ0EsU0FBS0MsTUFBTCxHQUFjQSxNQUFkO0FBRUEsUUFBSSxLQUFLRixPQUFULEVBQWtCLE1BQU0sSUFBSU0sS0FBSixDQUFVLG1EQUFWLENBQU47QUFDbkI7QUFFRDs7Ozs7QUFHQUMsRUFBQUEsVUFBVSxDQUFDQyxHQUFELEVBQU1DLFFBQU4sRUFBZ0JDLFFBQWhCLEVBQTBCO0FBQ2xDLFVBQU1DLE9BQU8sR0FBRyxvQkFBSSxLQUFLTixRQUFULEVBQW1CRyxHQUFuQixFQUF3QixLQUFLUCxNQUE3QixFQUFxQyxLQUFLQyxNQUExQyxDQUFoQjtBQUNBLFNBQUtHLFFBQUw7QUFDQUssSUFBQUEsUUFBUSxDQUFDLElBQUQsRUFBT0MsT0FBUCxDQUFSO0FBQ0Q7O0FBMUJxRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRyYW5zZm9ybSB9IGZyb20gJ3N0cmVhbSc7XG5pbXBvcnQgeyBSb3csIFN0eWxlcyB9IGZyb20gJy4vdGVtcGxhdGVzJztcblxuLyoqXG4gKiBDbGFzcyByZXByZXNlbnRpbmcgYSBYTFNYIFJvdyB0cmFuc2Zvcm1hdGlvbiBmcm9tIGFycmF5IHRvIFJvdy5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgWExTWFJvd1RyYW5zZm9ybSBleHRlbmRzIFRyYW5zZm9ybSB7XG4gIC8qKlxuICAgKiBDcmVhdGUgbmV3IHhsc3ggcm93IHRyYW5zZm9ybSBzdHJlYW1cbiAgICogQHBhcmFtIHtPYmplY3R9IFtvcHRpb25zXVxuICAgKiBAcGFyYW0ge0Jvb2xlYW59IFtvcHRpb25zLmhlYWRlcnM9ZmFsc2VdIC0gSWYgc2V0IHRvIHRydWUgd3JpdGVyIHdpbGwgb3V0cHV0IGZpcnN0IHJvdyB3aXRoIGFuIGhlYWRlciBzdHlsZS5cbiAgICogQHBhcmFtIHtCb29sZWFufSBbb3B0aW9ucy5mb3JtYXQ9dHJ1ZV0gLSBJZiBzZXQgdG8gZmFsc2Ugd3JpdGVyIHdpbGwgbm90IGZvcm1hdCBjZWxscyB3aXRoIG51bWJlciwgZGF0ZSwgYm9vbGVhbiBhbmQgdGV4dC5cbiAgICogQHBhcmFtIHtTdHlsZXN9IFtvcHRpb25zLnN0eWxlcz1uZXcgU3R5bGVzKCldIC0gSWYgc2V0IHlvdSBjYW4gb3ZlcndyaXRlIGRlZmF1bHQgc3RhbmRhcmQgdHlwZSBzdHlsZXMgYnkgb3RoZXIgc3RhbmRhcmQgb25lcyBvciBldmVuIGRlZmluZSBjdXN0b20gYGZvcm1hdENvZGVgLlxuICAgKi9cbiAgY29uc3RydWN0b3IoeyBoZWFkZXJzID0gZmFsc2UsIGZvcm1hdCA9IHRydWUsIHN0eWxlcyA9IG5ldyBTdHlsZXMoKSB9KSB7XG4gICAgc3VwZXIoeyBvYmplY3RNb2RlOiB0cnVlIH0pO1xuXG4gICAgdGhpcy5yb3dDb3VudCA9IDA7XG4gICAgdGhpcy5oZWFkZXJzID0gaGVhZGVycztcbiAgICB0aGlzLmZvcm1hdCA9IGZvcm1hdDtcbiAgICB0aGlzLnN0eWxlcyA9IHN0eWxlcztcblxuICAgIGlmICh0aGlzLmhlYWRlcnMpIHRocm93IG5ldyBFcnJvcignSGVhZGVycyBzcGVjaWFsIHN0eWxlIG91dHB1dCBub3QgeWV0IGltcGxlbWVudGVkLicpO1xuICB9XG5cbiAgLyoqXG4gICAqIFRyYW5zZm9ybSBhcnJheSB0byByb3cgc3RyaW5nXG4gICAqL1xuICBfdHJhbnNmb3JtKHJvdywgZW5jb2RpbmcsIGNhbGxiYWNrKSB7XG4gICAgY29uc3QgeGxzeFJvdyA9IFJvdyh0aGlzLnJvd0NvdW50LCByb3csIHRoaXMuZm9ybWF0LCB0aGlzLnN0eWxlcyk7XG4gICAgdGhpcy5yb3dDb3VudCsrO1xuICAgIGNhbGxiYWNrKG51bGwsIHhsc3hSb3cpO1xuICB9XG59XG4iXX0= |
@@ -8,2 +8,4 @@ "use strict"; | ||
var _defaultsDeep = _interopRequireDefault(require("lodash/defaultsDeep")); | ||
var _archiver = _interopRequireDefault(require("archiver")); | ||
@@ -23,17 +25,18 @@ | ||
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } | ||
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } | ||
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | ||
const isBoolean = value => value === !!value; | ||
/** | ||
* XLSX Write Stream base class | ||
*/ | ||
class XLSXWriteStream extends _stream.Transform { | ||
/** | ||
* Create new Stream | ||
* Create new stream transform that handles Array or Object as input chunks. | ||
* Be aware that first row chunk is determinant in the transform configuration process for further row chunks. | ||
* @class XLSXWriteStream | ||
* @extends Transform | ||
* @param {Object} [options] | ||
* @param {Array|Boolean} [options.headers=false] - If set to an array they will be printed in first row, no matter what is streamed in input. | ||
* If receiving objects from input stream, only properties given in headers will be printed following headers order. | ||
* If set to true it only has effect when streaming objects in order to print inferred headers in first place. | ||
* @param {Boolean} [options.format=true] - If set to false writer will not format cells with number, date, boolean and text. | ||
@@ -47,9 +50,30 @@ * @param {Object} [options.styleDefs] - If set you can overwrite default standard type styles by other standard ones or even define custom `formatCode`. | ||
}); | ||
this.pipelineInitialized = false; | ||
this.initialized = false; | ||
this.options = Object.assign({ | ||
this.arrayMode = null; | ||
this.options = (0, _defaultsDeep.default)({}, options, { | ||
headers: false, | ||
format: true, | ||
immediateInitialization: false | ||
}, options); | ||
}); | ||
if (this.options.immediateInitialization) this._initializePipeline(); | ||
} | ||
_transform(chunk, encoding, callback) { | ||
if (!this.initialized) this._initialize(chunk); | ||
this.toXlsxRow.write(this.normalize(chunk), encoding, callback); | ||
} | ||
_initialize(chunk) { | ||
this._initializePipeline(); | ||
this._initializeHeaders(chunk); | ||
if (chunk) { | ||
this.arrayMode = Array.isArray(chunk); | ||
this.normalize = this.arrayMode ? chunk => this.options.headers.map((value, index) => chunk[index]) : chunk => this.options.headers.map(key => chunk[key]); | ||
} | ||
this.initialized = true; | ||
} | ||
/** | ||
@@ -61,2 +85,3 @@ * Initialize pipeline with xlsx archive common files | ||
_initializePipeline() { | ||
if (this.pipelineInitialized) return; | ||
this.zip = (0, _archiver.default)('zip', { | ||
@@ -85,5 +110,6 @@ forceUTC: true | ||
this.zip.on('data', data => this.push(data)).on('warning', err => this.emit('warning', err)).on('error', err => this.error('error', err)); | ||
this.toXlsxRow = new _XLSXRowTransform.default(_objectSpread({}, this.options, { | ||
this.toXlsxRow = new _XLSXRowTransform.default({ | ||
format: this.options.format, | ||
styles | ||
})); | ||
}); | ||
this.sheetStream = new _stream.PassThrough(); | ||
@@ -95,12 +121,29 @@ this.sheetStream.write(templates.SheetHeader); | ||
}); | ||
this.initialized = true; | ||
this.pipelineInitialized = true; | ||
} | ||
_transform(chunk, encoding, callback) { | ||
if (!this.initialized) this._initializePipeline(); | ||
this.toXlsxRow.write(chunk, encoding, callback); | ||
_initializeHeaders(chunk = []) { | ||
const shouldPrintHeaders = !!this.options.headers; | ||
if (Array.isArray(chunk)) { | ||
if (isBoolean(this.options.headers)) { | ||
// Cannot infer headers from an Array | ||
// => Ignore `headers` option silently. | ||
this.options.headers = chunk.map(() => undefined); | ||
return; | ||
} | ||
} else { | ||
if (isBoolean(this.options.headers)) { | ||
// Init headers from chunk | ||
this.options.headers = [...Object.keys(chunk)]; | ||
} | ||
} | ||
if (shouldPrintHeaders) { | ||
this.toXlsxRow.write(this.options.headers); | ||
} | ||
} | ||
_flush(callback) { | ||
if (!this.initialized) this._initializePipeline(); | ||
if (!this.initialized) this._initialize(); | ||
@@ -124,2 +167,2 @@ this._finalize().then(() => { | ||
exports.default = XLSXWriteStream; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9YTFNYV3JpdGVTdHJlYW0uanMiXSwibmFtZXMiOlsiWExTWFdyaXRlU3RyZWFtIiwiVHJhbnNmb3JtIiwiY29uc3RydWN0b3IiLCJvcHRpb25zIiwib2JqZWN0TW9kZSIsImluaXRpYWxpemVkIiwiT2JqZWN0IiwiYXNzaWduIiwiZm9ybWF0IiwiaW1tZWRpYXRlSW5pdGlhbGl6YXRpb24iLCJfaW5pdGlhbGl6ZVBpcGVsaW5lIiwiemlwIiwiZm9yY2VVVEMiLCJjYXRjaEVhcmx5RXhpdEF0dGFjaGVkIiwiYXBwZW5kIiwidGVtcGxhdGVzIiwiQ29udGVudFR5cGVzIiwibmFtZSIsIlJlbHMiLCJXb3JrYm9vayIsIldvcmtib29rUmVscyIsInN0eWxlcyIsIlN0eWxlcyIsInN0eWxlRGVmcyIsInJlbmRlciIsIm9uIiwiZGF0YSIsInB1c2giLCJlcnIiLCJlbWl0IiwiZXJyb3IiLCJ0b1hsc3hSb3ciLCJYTFNYUm93VHJhbnNmb3JtIiwic2hlZXRTdHJlYW0iLCJQYXNzVGhyb3VnaCIsIndyaXRlIiwiU2hlZXRIZWFkZXIiLCJwaXBlIiwiX3RyYW5zZm9ybSIsImNodW5rIiwiZW5jb2RpbmciLCJjYWxsYmFjayIsIl9mbHVzaCIsIl9maW5hbGl6ZSIsInRoZW4iLCJlbmQiLCJTaGVldEZvb3RlciIsImZpbmFsaXplIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7Ozs7Ozs7Ozs7O0FBRUE7OztBQUdlLE1BQU1BLGVBQU4sU0FBOEJDLGlCQUE5QixDQUF3QztBQUNyRDs7Ozs7Ozs7O0FBU0FDLEVBQUFBLFdBQVcsQ0FBQ0MsT0FBRCxFQUFVO0FBQ25CLFVBQU07QUFBRUMsTUFBQUEsVUFBVSxFQUFFO0FBQWQsS0FBTjtBQUVBLFNBQUtDLFdBQUwsR0FBbUIsS0FBbkI7QUFFQSxTQUFLRixPQUFMLEdBQWVHLE1BQU0sQ0FBQ0MsTUFBUCxDQUFjO0FBQUVDLE1BQUFBLE1BQU0sRUFBRSxJQUFWO0FBQWdCQyxN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QUFDK0IsV0FBL0I7QUFDQSxXQUFPLEtBQUtuQyxHQUFMLENBQVNvQyxRQUFULEVBQVA7QUFDRDs7QUF2RW9EIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFyY2hpdmVyIGZyb20gJ2FyY2hpdmVyJztcbmltcG9ydCB7IFRyYW5zZm9ybSwgUGFzc1Rocm91Z2ggfSBmcm9tICdzdHJlYW0nO1xuaW1wb3J0ICogYXMgdGVtcGxhdGVzIGZyb20gJy4vdGVtcGxhdGVzJztcbmltcG9ydCBYTFNYUm93VHJhbnNmb3JtIGZyb20gJy4vWExTWFJvd1RyYW5zZm9ybSc7XG5cbi8qKlxuICogWExTWCBXcml0ZSBTdHJlYW0gYmFzZSBjbGFzc1xuICovXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBYTFNYV3JpdGVTdHJlYW0gZXh0ZW5kcyBUcmFuc2Zvcm0ge1xuICAvKipcbiAgICogQ3JlYXRlIG5ldyBTdHJlYW1cbiAgICogQGNsYXNzIFhMU1hXcml0ZVN0cmVhbVxuICAgKiBAZXh0ZW5kcyBUcmFuc2Zvcm1cbiAgICogQHBhcmFtIHtPYmplY3R9IFtvcHRpb25zXVxuICAgKiBAcGFyYW0ge0Jvb2xlYW59IFtvcHRpb25zLmZvcm1hdD10cnVlXSAtIElmIHNldCB0byBmYWxzZSB3cml0ZXIgd2lsbCBub3QgZm9ybWF0IGNlbGxzIHdpdGggbnVtYmVyLCBkYXRlLCBib29sZWFuIGFuZCB0ZXh0LlxuICAgKiBAcGFyYW0ge09iamVjdH0gW29wdGlvbnMuc3R5bGVEZWZzXSAtIElmIHNldCB5b3UgY2FuIG92ZXJ3cml0ZSBkZWZhdWx0IHN0YW5kYXJkIHR5cGUgc3R5bGVzIGJ5IG90aGVyIHN0YW5kYXJkIG9uZXMgb3IgZXZlbiBkZWZpbmUgY3VzdG9tIGBmb3JtYXRDb2RlYC5cbiAgICogQHBhcmFtIHtCb29sZWFufSBbb3B0aW9ucy5pbW1lZGlhdGVJbml0aWFsaXphdGlvbj1mYWxzZV0gLSBJZiBzZXQgdG8gdHJ1ZSB3cml0ZXIgd2lsbCBpbml0aWFsaXplIGFyY2hpdmUgYW5kIHN0YXJ0IGNvbXByZXNzaW5nIHhsc3ggY29tbW9uIHN0dWZmIGltbWVkaWF0ZWx5LCBhZGRpbmcgc3Vic2VxdWVudGx5IGEgbGl0dGxlIG1lbW9yeSBhbmQgcHJvY2Vzc29yIGZvb3RwcmludC4gSWYgbm90LCBpbml0aWFsaXphdGlvbiB3aWxsIGJlIGRlbGF5ZWQgdG8gdGhlIGZpcnN0IGRhdGEgcHJvY2Vzc2luZy5cbiAgICovXG4gIGNvbnN0cnVjdG9yKG9wdGlvbnMpIHtcbiAgICBzdXBlcih7IG9iamVjdE1vZGU6IHRydWUgfSk7XG5cbiAgICB0aGlzLmluaXRpYWxpemVkID0gZmFsc2U7XG5cbiAgICB0aGlzLm9wdGlvbnMgPSBPYmplY3QuYXNzaWduKHsgZm9ybWF0OiB0cnVlLCBpbW1lZGlhdGVJbml0aWFsaXphdGlvbjogZmFsc2UgfSwgb3B0aW9ucyk7XG5cbiAgICBpZiAodGhpcy5vcHRpb25zLmltbWVkaWF0ZUluaXRpYWxpemF0aW9uKSB0aGlzLl9pbml0aWFsaXplUGlwZWxpbmUoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBJbml0aWFsaXplIHBpcGVsaW5lIHdpdGggeGxzeCBhcmNoaXZlIGNvbW1vbiBmaWxlc1xuICAgKi9cbiAgX2luaXRpYWxpemVQaXBlbGluZSgpIHtcbiAgICB0aGlzLnppcCA9IEFyY2hpdmVyKCd6aXAnLCB7IGZvcmNlVVRDOiB0cnVlIH0pO1xuICAgIHRoaXMuemlwLmNhdGNoRWFybHlFeGl0QXR0YWNoZWQgPSB0cnVlO1xuXG4gICAgLy8gQ29tbW9uIHhsc3ggYXJjaGl2ZSBmaWxlcyAobm90IGVkaXRhYmxlKVxuICAgIHRoaXMuemlwLmFwcGVuZCh0ZW1wbGF0ZXMuQ29udGVudFR5cGVzLCB7IG5hbWU6ICdbQ29udGVudF9UeXBlc10ueG1sJyB9KTtcbiAgICB0aGlzLnppcC5hcHBlbmQodGVtcGxhdGVzLlJlbHMsIHsgbmFtZTogJ19yZWxzLy5yZWxzJyB9KTtcbiAgICB0aGlzLnppcC5hcHBlbmQodGVtcGxhdGVzLldvcmtib29rLCB7IG5hbWU6ICd4bC93b3JrYm9vay54bWwnIH0pO1xuICAgIHRoaXMuemlwLmFwcGVuZCh0ZW1wbGF0ZXMuV29ya2Jvb2tSZWxzLCB7IG5hbWU6ICd4bC9fcmVscy93b3JrYm9vay54bWwucmVscycgfSk7XG5cbiAgICAvLyBTdHlsZSB4bHN4IGRlZmluaXRpb25zIChvbmUgdGltZSBnZW5lcmF0aW9uKVxuICAgIGNvbnN0IHN0eWxlcyA9IG5ldyB0ZW1wbGF0ZXMuU3R5bGVzKHRoaXMub3B0aW9ucy5zdHlsZURlZnMpO1xuICAgIHRoaXMuemlwLmFwcGVuZChzdHlsZXMucmVuZGVyKCksIHsgbmFtZTogJ3hsL3N0eWxlcy54bWwnIH0pO1xuXG4gICAgdGhpcy56aXBcbiAgICAgIC5vbignZGF0YScsIGRhdGEgPT4gdGhpcy5wdXNoKGRhdGEpKVxuICAgICAgLm9uKCd3YXJuaW5nJywgZXJyID0+IHRoaXMuZW1pdCgnd2FybmluZycsIGVycikpXG4gICAgICAub24oJ2Vycm9yJywgZXJyID0+IHRoaXMuZXJyb3IoJ2Vycm9yJywgZXJyKSk7XG5cbiAgICB0aGlzLnRvWGxzeFJvdyA9IG5ldyBYTFNYUm93VHJhbnNmb3JtKHsgLi4udGhpcy5vcHRpb25zLCBzdHlsZXMgfSk7XG4gICAgdGhpcy5zaGVldFN0cmVhbSA9IG5ldyBQYXNzVGhyb3VnaCgpO1xuICAgIHRoaXMuc2hlZXRTdHJlYW0ud3JpdGUodGVtcGxhdGVzLlNoZWV0SGVhZGVyKTtcbiAgICB0aGlzLnRvWGxzeFJvdy5waXBlKHRoaXMuc2hlZXRTdHJlYW0pO1xuICAgIHRoaXMuemlwLmFwcGVuZCh0aGlzLnNoZWV0U3RyZWFtLCB7XG4gICAgICBuYW1lOiAneGwvd29ya3NoZWV0cy9zaGVldDEueG1sJ1xuICAgIH0pO1xuXG4gICAgdGhpcy5pbml0aWFsaXplZCA9IHRydWU7XG4gIH1cblxuICBfdHJhbnNmb3JtKGNodW5rLCBlbmNvZGluZywgY2FsbGJhY2spIHtcbiAgICBpZiAoIXRoaXMuaW5pdGlhbGl6ZWQpIHRoaXMuX2luaXRpYWxpemVQaXBlbGluZSgpO1xuICAgIHRoaXMudG9YbHN4Um93LndyaXRlKGNodW5rLCBlbmNvZGluZywgY2FsbGJhY2spO1xuICB9XG5cbiAgX2ZsdXNoKGNhbGxiYWNrKSB7XG4gICAgaWYgKCF0aGlzLmluaXRpYWxpemVkKSB0aGlzLl9pbml0aWFsaXplUGlwZWxpbmUoKTtcbiAgICB0aGlzLl9maW5hbGl6ZSgpLnRoZW4oKCkgPT4ge1xuICAgICAgY2FsbGJhY2soKTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBGaW5hbGl6ZSB0aGUgemlwIGFyY2hpdmVcbiAgICovXG4gIF9maW5hbGl6ZSgpIHtcbiAgICB0aGlzLnNoZWV0U3RyZWFtLmVuZCh0ZW1wbGF0ZXMuU2hlZXRGb290ZXIpO1xuICAgIHJldHVybiB0aGlzLnppcC5maW5hbGl6ZSgpO1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/XLSXWriteStream.js"],"names":["isBoolean","value","XLSXWriteStream","Transform","constructor","options","objectMode","pipelineInitialized","initialized","arrayMode","headers","format","immediateInitialization","_initializePipeline","_transform","chunk","encoding","callback","_initialize","toXlsxRow","write","normalize","_initializeHeaders","Array","isArray","map","index","key","zip","forceUTC","catchEarlyExitAttached","append","templates","ContentTypes","name","Rels","Workbook","WorkbookRels","styles","Styles","styleDefs","render","on","data","push","err","emit","error","XLSXRowTransform","sheetStream","PassThrough","SheetHeader","pipe","shouldPrintHeaders","undefined","Object","keys","_flush","_finalize","then","end","SheetFooter","finalize"],"mappings":"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","sourcesContent":["import defaultsDeep from 'lodash/defaultsDeep';\nimport Archiver from 'archiver';\nimport { Transform, PassThrough } from 'stream';\nimport * as templates from './templates';\nimport XLSXRowTransform from './XLSXRowTransform';\n\nconst isBoolean = value => value === !!value;\n\n/**\n * XLSX Write Stream base class\n */\nexport default class XLSXWriteStream extends Transform {\n  /**\n   * Create new stream transform that handles Array or Object as input chunks.\n   * Be aware that first row chunk is determinant in the transform configuration process for further row chunks.\n   * @class XLSXWriteStream\n   * @extends Transform\n   * @param {Object} [options]\n   * @param {Array|Boolean} [options.headers=false] - If set to an array they will be printed in first row, no matter what is streamed in input.\n   *                                                  If receiving objects from input stream, only properties given in headers will be printed following headers order.\n   *                                                  If set to true it only has effect when streaming objects in order to print inferred headers in first place.\n   * @param {Boolean} [options.format=true] - If set to false writer will not format cells with number, date, boolean and text.\n   * @param {Object} [options.styleDefs] - If set you can overwrite default standard type styles by other standard ones or even define custom `formatCode`.\n   * @param {Boolean} [options.immediateInitialization=false] - If set to true writer will initialize archive and start compressing xlsx common stuff immediately, adding subsequently a little memory and processor footprint. If not, initialization will be delayed to the first data processing.\n   */\n  constructor(options) {\n    super({ objectMode: true });\n\n    this.pipelineInitialized = false;\n    this.initialized = false;\n    this.arrayMode = null;\n\n    this.options = defaultsDeep({}, options, { headers: false, format: true, immediateInitialization: false });\n\n    if (this.options.immediateInitialization) this._initializePipeline();\n  }\n\n  _transform(chunk, encoding, callback) {\n    if (!this.initialized) this._initialize(chunk);\n\n    this.toXlsxRow.write(this.normalize(chunk), encoding, callback);\n  }\n\n  _initialize(chunk) {\n    this._initializePipeline();\n    this._initializeHeaders(chunk);\n\n    if (chunk) {\n      this.arrayMode = Array.isArray(chunk);\n      this.normalize = this.arrayMode\n        ? chunk => this.options.headers.map((value, index) => chunk[index])\n        : chunk => this.options.headers.map(key => chunk[key]);\n    }\n\n    this.initialized = true;\n  }\n\n  /**\n   * Initialize pipeline with xlsx archive common files\n   */\n  _initializePipeline() {\n    if (this.pipelineInitialized) return;\n\n    this.zip = Archiver('zip', { forceUTC: true });\n    this.zip.catchEarlyExitAttached = true;\n\n    // Common xlsx archive files (not editable)\n    this.zip.append(templates.ContentTypes, { name: '[Content_Types].xml' });\n    this.zip.append(templates.Rels, { name: '_rels/.rels' });\n    this.zip.append(templates.Workbook, { name: 'xl/workbook.xml' });\n    this.zip.append(templates.WorkbookRels, { name: 'xl/_rels/workbook.xml.rels' });\n\n    // Style xlsx definitions (one time generation)\n    const styles = new templates.Styles(this.options.styleDefs);\n    this.zip.append(styles.render(), { name: 'xl/styles.xml' });\n\n    this.zip\n      .on('data', data => this.push(data))\n      .on('warning', err => this.emit('warning', err))\n      .on('error', err => this.error('error', err));\n\n    this.toXlsxRow = new XLSXRowTransform({ format: this.options.format, styles });\n    this.sheetStream = new PassThrough();\n    this.sheetStream.write(templates.SheetHeader);\n    this.toXlsxRow.pipe(this.sheetStream);\n    this.zip.append(this.sheetStream, {\n      name: 'xl/worksheets/sheet1.xml'\n    });\n\n    this.pipelineInitialized = true;\n  }\n\n  _initializeHeaders(chunk = []) {\n    const shouldPrintHeaders = !!this.options.headers;\n\n    if (Array.isArray(chunk)) {\n      if (isBoolean(this.options.headers)) {\n        // Cannot infer headers from an Array\n        // => Ignore `headers` option silently.\n        this.options.headers = chunk.map(() => undefined);\n        return;\n      }\n    } else {\n      if (isBoolean(this.options.headers)) {\n        // Init headers from chunk\n        this.options.headers = [...Object.keys(chunk)];\n      }\n    }\n\n    if (shouldPrintHeaders) {\n      this.toXlsxRow.write(this.options.headers);\n    }\n  }\n\n  _flush(callback) {\n    if (!this.initialized) this._initialize();\n    this._finalize().then(() => {\n      callback();\n    });\n  }\n\n  /**\n   * Finalize the zip archive\n   */\n  _finalize() {\n    this.sheetStream.end(templates.SheetFooter);\n    return this.zip.finalize();\n  }\n}\n"]} |
{ | ||
"name": "@atomictech/xlsx-write-stream", | ||
"version": "1.0.3", | ||
"version": "1.1.0", | ||
"description": "Stream huge amount of data into an XLSX generated file stream with minimum memory footprint.", | ||
@@ -50,2 +50,3 @@ "main": "dist/index.js", | ||
"archiver": "^3.1.1", | ||
"lodash": "^4.17.15", | ||
"xml-escape": "^1.1.0" | ||
@@ -52,0 +53,0 @@ }, |
@@ -19,4 +19,5 @@ # ⏩ XLSX Write Stream ⏩ | ||
- [🦄 Usage](#%f0%9f%a6%84-usage) | ||
- [Basic](#basic) | ||
- [Custom Styles](#custom-styles) | ||
- [Basic pipe](#basic-pipe) | ||
- [Basic write](#basic-write) | ||
- [Custom styles](#custom-styles) | ||
- [🔧 API](#%f0%9f%94%a7-api) | ||
@@ -35,3 +36,3 @@ - [XLSXWriteStream ⇐ `Transform`](#xlsxwritestream-%e2%87%90-transform) | ||
```sh | ||
npm install '@atomictech/xlsx-write-stream' | ||
npm install @atomictech/xlsx-write-stream | ||
``` | ||
@@ -41,7 +42,26 @@ | ||
### Basic | ||
For all usages keep in mind that you should feed your `XLSXWriteStream` instance one row at a time, where a row could be an array or an object. | ||
```js | ||
import XLSXWriteStream from 'xlsx-write-stream'; | ||
const row = [1, '02', new Date('2015-10-21T16:29:00.000Z'), true, false, '🦄']; | ||
``` | ||
or | ||
```js | ||
const row = { | ||
'A Number Column': 1, | ||
'A Text Column': '02', | ||
'A Date Column': new Date('2015-10-21T16:29:00.000Z'), | ||
'A Boolean Column': true, | ||
'Another Boolean Column': false, | ||
'Another Text Column': '🦄' | ||
}; | ||
``` | ||
### Basic pipe | ||
```js | ||
import XLSXWriteStream from '@atomictech/xlsx-write-stream'; | ||
// Initialize the writer | ||
@@ -54,9 +74,19 @@ const xlsxWriter = new XLSXWriteStream(); | ||
// xlsxWriter should be feed with chunks representing a row as an array of values. | ||
// Cell values type supported are: string, number, boolean and date. | ||
// Pipe the writer into a Stream.Writable output stream in order to retrieve XLSX file data, | ||
// write it into file or send it as HTTP response. | ||
const writeStream = fs.createWriteStream('file.xlsx'); | ||
xlsxWriter.pipe(writeStream); | ||
``` | ||
// Alternatively you can use the writer `write(chunk)` method in order to fill your xlsx. | ||
const row = [1, '02', new Date('2015-10-21T16:29:00.000Z'), true, false]; | ||
xlsxWriter.write(row); | ||
### Basic write | ||
```js | ||
import XLSXWriteStream from '@atomictech/xlsx-write-stream'; | ||
// [optional] Define some headers | ||
const headers = ['A Number Column', 'A Text Column', 'A Date Column', 'A Boolean Column', 'Another Boolean Column', 'Another Text Column']; | ||
// Initialize the writer | ||
const xlsxWriter = new XLSXWriteStream({ headers }); | ||
// Pipe the writer into a Stream.Writable output stream in order to retrieve XLSX file data, | ||
@@ -66,10 +96,20 @@ // write it into file or send it as HTTP response. | ||
xlsxWriter.pipe(writeStream); | ||
// Write rows one by one with | ||
const row = [1, '02', new Date('2015-10-21T16:29:00.000Z'), true, false, '🦄']; | ||
xlsxWriter.write(row); | ||
xlsxWriter.end(); // Do not forget to end the stream! | ||
``` | ||
### Custom Styles | ||
⚠️ **Caution** ⚠️ | ||
If you are not familiar with streams, in order to take advantage of the smallest memory footprint possible with this form, you need to be aware of backpressure concept and use the boolean returned by the write function! | ||
> See explanations here: [writable.write(chunk[, encoding][, callback])](https://nodejs.org/api/stream.html#stream_writable_write_chunk_encoding_callback) | ||
### Custom styles | ||
An `options.styleDefs` parameter is available in order to redefine type style formats. | ||
```js | ||
import { TypeStyleKey } from 'xlsx-write-stream'; | ||
import { TypeStyleKey } from '@atomictech/xlsx-write-stream'; | ||
@@ -93,7 +133,11 @@ // Declare custom styles definitions | ||
Create new stream transform that handles Array or Object as input chunks. | ||
Be aware that first row chunk is determinant in the transform configuration process for further row chunks. | ||
| Param | Type | Default | Description | | ||
| --- | --- | --- | --- | | ||
| [options] | `Object` | | | | ||
| [options.headers] | `Array|Boolean` | `false` | If set to an array they will be printed in first row, no matter what is streamed in input. If receiving objects from input stream, only properties given in headers will be printed following headers order. If set to true it only has effect when streaming objects in order to print inferred headers in first place.| | ||
| [options.format] | `Boolean` | `true` | If set to false writer will not format cells with number, date, boolean and text. | | ||
| [options.styleDefs] | [`StyleDefs`](###styledefs) | | If set you can overwrite default standard type styles by other standard ones or even define custom `formatCode`. | | ||
| [options.styleDefs] | [`StyleDefs`](#styledefs) | | If set you can overwrite default standard type styles by other standard ones or even define custom `formatCode`. | | ||
| [options.immediateInitialization] | `Boolean` | `false` | If set to true writer will initialize archive and start compressing xlsx common stuff immediately, adding subsequently a little memory and processor footprint. If not, initialization will be delayed to the first data processing. | | ||
@@ -170,3 +214,3 @@ | ||
- comments | ||
- ... and a myriad of other OOXML features. It's strictly an CSV replacement. | ||
- ... and a myriad of other OOXML features. It's strictly a CSV replacement. | ||
@@ -173,0 +217,0 @@ ## 👥 Authors |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
82098
531
232
3
+ Addedlodash@^4.17.15