@stamhoofd/excel-writer 2.17.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (170) hide show
  1. package/LICENSE +661 -0
  2. package/dist/index.d.ts +4 -0
  3. package/dist/index.d.ts.map +1 -0
  4. package/dist/index.js +7 -0
  5. package/dist/index.js.map +1 -0
  6. package/dist/src/XlsxColumnFilterer.d.ts +11 -0
  7. package/dist/src/XlsxColumnFilterer.d.ts.map +1 -0
  8. package/dist/src/XlsxColumnFilterer.js +81 -0
  9. package/dist/src/XlsxColumnFilterer.js.map +1 -0
  10. package/dist/src/XlsxTransformer.d.ts +14 -0
  11. package/dist/src/XlsxTransformer.d.ts.map +1 -0
  12. package/dist/src/XlsxTransformer.js +59 -0
  13. package/dist/src/XlsxTransformer.js.map +1 -0
  14. package/dist/src/exportToExcel.d.ts +8 -0
  15. package/dist/src/exportToExcel.d.ts.map +1 -0
  16. package/dist/src/exportToExcel.js +23 -0
  17. package/dist/src/exportToExcel.js.map +1 -0
  18. package/dist/src/interfaces.d.ts +160 -0
  19. package/dist/src/interfaces.d.ts.map +1 -0
  20. package/dist/src/interfaces.js +101 -0
  21. package/dist/src/interfaces.js.map +1 -0
  22. package/dist/src/stream-writer/XlsxAppPropsWriter.d.ts +5 -0
  23. package/dist/src/stream-writer/XlsxAppPropsWriter.d.ts.map +1 -0
  24. package/dist/src/stream-writer/XlsxAppPropsWriter.js +13 -0
  25. package/dist/src/stream-writer/XlsxAppPropsWriter.js.map +1 -0
  26. package/dist/src/stream-writer/XlsxContentTypesWriter.d.ts +13 -0
  27. package/dist/src/stream-writer/XlsxContentTypesWriter.d.ts.map +1 -0
  28. package/dist/src/stream-writer/XlsxContentTypesWriter.js +24 -0
  29. package/dist/src/stream-writer/XlsxContentTypesWriter.js.map +1 -0
  30. package/dist/src/stream-writer/XlsxCorePropsWriter.d.ts +7 -0
  31. package/dist/src/stream-writer/XlsxCorePropsWriter.d.ts.map +1 -0
  32. package/dist/src/stream-writer/XlsxCorePropsWriter.js +26 -0
  33. package/dist/src/stream-writer/XlsxCorePropsWriter.js.map +1 -0
  34. package/dist/src/stream-writer/XlsxFileWriter.d.ts +11 -0
  35. package/dist/src/stream-writer/XlsxFileWriter.d.ts.map +1 -0
  36. package/dist/src/stream-writer/XlsxFileWriter.js +44 -0
  37. package/dist/src/stream-writer/XlsxFileWriter.js.map +1 -0
  38. package/dist/src/stream-writer/XlsxRelationsWriter.d.ts +17 -0
  39. package/dist/src/stream-writer/XlsxRelationsWriter.d.ts.map +1 -0
  40. package/dist/src/stream-writer/XlsxRelationsWriter.js +28 -0
  41. package/dist/src/stream-writer/XlsxRelationsWriter.js.map +1 -0
  42. package/dist/src/stream-writer/XlsxSharedStringsWriter.d.ts +5 -0
  43. package/dist/src/stream-writer/XlsxSharedStringsWriter.d.ts.map +1 -0
  44. package/dist/src/stream-writer/XlsxSharedStringsWriter.js +12 -0
  45. package/dist/src/stream-writer/XlsxSharedStringsWriter.js.map +1 -0
  46. package/dist/src/stream-writer/XlsxSheetWriter.d.ts +30 -0
  47. package/dist/src/stream-writer/XlsxSheetWriter.d.ts.map +1 -0
  48. package/dist/src/stream-writer/XlsxSheetWriter.js +140 -0
  49. package/dist/src/stream-writer/XlsxSheetWriter.js.map +1 -0
  50. package/dist/src/stream-writer/XlsxStylesWriter.d.ts +24 -0
  51. package/dist/src/stream-writer/XlsxStylesWriter.d.ts.map +1 -0
  52. package/dist/src/stream-writer/XlsxStylesWriter.js +159 -0
  53. package/dist/src/stream-writer/XlsxStylesWriter.js.map +1 -0
  54. package/dist/src/stream-writer/XlsxThemeWriter.d.ts +5 -0
  55. package/dist/src/stream-writer/XlsxThemeWriter.d.ts.map +1 -0
  56. package/dist/src/stream-writer/XlsxThemeWriter.js +327 -0
  57. package/dist/src/stream-writer/XlsxThemeWriter.js.map +1 -0
  58. package/dist/src/stream-writer/XlsxWorkbookWriter.d.ts +17 -0
  59. package/dist/src/stream-writer/XlsxWorkbookWriter.d.ts.map +1 -0
  60. package/dist/src/stream-writer/XlsxWorkbookWriter.js +31 -0
  61. package/dist/src/stream-writer/XlsxWorkbookWriter.js.map +1 -0
  62. package/dist/src/stream-writer/XlsxWriter.d.ts +35 -0
  63. package/dist/src/stream-writer/XlsxWriter.d.ts.map +1 -0
  64. package/dist/src/stream-writer/XlsxWriter.js +254 -0
  65. package/dist/src/stream-writer/XlsxWriter.js.map +1 -0
  66. package/dist/src/stream-writer/adapters/ArchiverWriterAdapter.d.ts +24 -0
  67. package/dist/src/stream-writer/adapters/ArchiverWriterAdapter.d.ts.map +1 -0
  68. package/dist/src/stream-writer/adapters/ArchiverWriterAdapter.js +90 -0
  69. package/dist/src/stream-writer/adapters/ArchiverWriterAdapter.js.map +1 -0
  70. package/dist/src/stream-writer/adapters/ZipJsWriterAdapter.d.ts +22 -0
  71. package/dist/src/stream-writer/adapters/ZipJsWriterAdapter.d.ts.map +1 -0
  72. package/dist/src/stream-writer/adapters/ZipJsWriterAdapter.js +50 -0
  73. package/dist/src/stream-writer/adapters/ZipJsWriterAdapter.js.map +1 -0
  74. package/dist/src/stream-writer/escapeXml.d.ts +2 -0
  75. package/dist/src/stream-writer/escapeXml.d.ts.map +1 -0
  76. package/dist/src/stream-writer/escapeXml.js +16 -0
  77. package/dist/src/stream-writer/escapeXml.js.map +1 -0
  78. package/dist/src/stream-writer/index.d.ts +4 -0
  79. package/dist/src/stream-writer/index.d.ts.map +1 -0
  80. package/dist/src/stream-writer/index.js +7 -0
  81. package/dist/src/stream-writer/index.js.map +1 -0
  82. package/dist/src/stream-writer/interfaces.d.ts +14 -0
  83. package/dist/src/stream-writer/interfaces.d.ts.map +1 -0
  84. package/dist/src/stream-writer/interfaces.js +3 -0
  85. package/dist/src/stream-writer/interfaces.js.map +1 -0
  86. package/esm/dist/index.d.ts +4 -0
  87. package/esm/dist/index.d.ts.map +1 -0
  88. package/esm/dist/index.js +4 -0
  89. package/esm/dist/index.js.map +1 -0
  90. package/esm/dist/src/XlsxColumnFilterer.d.ts +11 -0
  91. package/esm/dist/src/XlsxColumnFilterer.d.ts.map +1 -0
  92. package/esm/dist/src/XlsxColumnFilterer.js +77 -0
  93. package/esm/dist/src/XlsxColumnFilterer.js.map +1 -0
  94. package/esm/dist/src/XlsxTransformer.d.ts +14 -0
  95. package/esm/dist/src/XlsxTransformer.d.ts.map +1 -0
  96. package/esm/dist/src/XlsxTransformer.js +55 -0
  97. package/esm/dist/src/XlsxTransformer.js.map +1 -0
  98. package/esm/dist/src/exportToExcel.d.ts +8 -0
  99. package/esm/dist/src/exportToExcel.d.ts.map +1 -0
  100. package/esm/dist/src/exportToExcel.js +20 -0
  101. package/esm/dist/src/exportToExcel.js.map +1 -0
  102. package/esm/dist/src/interfaces.d.ts +160 -0
  103. package/esm/dist/src/interfaces.d.ts.map +1 -0
  104. package/esm/dist/src/interfaces.js +98 -0
  105. package/esm/dist/src/interfaces.js.map +1 -0
  106. package/esm/dist/src/stream-writer/XlsxAppPropsWriter.d.ts +5 -0
  107. package/esm/dist/src/stream-writer/XlsxAppPropsWriter.d.ts.map +1 -0
  108. package/esm/dist/src/stream-writer/XlsxAppPropsWriter.js +9 -0
  109. package/esm/dist/src/stream-writer/XlsxAppPropsWriter.js.map +1 -0
  110. package/esm/dist/src/stream-writer/XlsxContentTypesWriter.d.ts +13 -0
  111. package/esm/dist/src/stream-writer/XlsxContentTypesWriter.d.ts.map +1 -0
  112. package/esm/dist/src/stream-writer/XlsxContentTypesWriter.js +20 -0
  113. package/esm/dist/src/stream-writer/XlsxContentTypesWriter.js.map +1 -0
  114. package/esm/dist/src/stream-writer/XlsxCorePropsWriter.d.ts +7 -0
  115. package/esm/dist/src/stream-writer/XlsxCorePropsWriter.d.ts.map +1 -0
  116. package/esm/dist/src/stream-writer/XlsxCorePropsWriter.js +22 -0
  117. package/esm/dist/src/stream-writer/XlsxCorePropsWriter.js.map +1 -0
  118. package/esm/dist/src/stream-writer/XlsxFileWriter.d.ts +11 -0
  119. package/esm/dist/src/stream-writer/XlsxFileWriter.d.ts.map +1 -0
  120. package/esm/dist/src/stream-writer/XlsxFileWriter.js +40 -0
  121. package/esm/dist/src/stream-writer/XlsxFileWriter.js.map +1 -0
  122. package/esm/dist/src/stream-writer/XlsxRelationsWriter.d.ts +17 -0
  123. package/esm/dist/src/stream-writer/XlsxRelationsWriter.d.ts.map +1 -0
  124. package/esm/dist/src/stream-writer/XlsxRelationsWriter.js +24 -0
  125. package/esm/dist/src/stream-writer/XlsxRelationsWriter.js.map +1 -0
  126. package/esm/dist/src/stream-writer/XlsxSharedStringsWriter.d.ts +5 -0
  127. package/esm/dist/src/stream-writer/XlsxSharedStringsWriter.d.ts.map +1 -0
  128. package/esm/dist/src/stream-writer/XlsxSharedStringsWriter.js +8 -0
  129. package/esm/dist/src/stream-writer/XlsxSharedStringsWriter.js.map +1 -0
  130. package/esm/dist/src/stream-writer/XlsxSheetWriter.d.ts +30 -0
  131. package/esm/dist/src/stream-writer/XlsxSheetWriter.d.ts.map +1 -0
  132. package/esm/dist/src/stream-writer/XlsxSheetWriter.js +136 -0
  133. package/esm/dist/src/stream-writer/XlsxSheetWriter.js.map +1 -0
  134. package/esm/dist/src/stream-writer/XlsxStylesWriter.d.ts +24 -0
  135. package/esm/dist/src/stream-writer/XlsxStylesWriter.d.ts.map +1 -0
  136. package/esm/dist/src/stream-writer/XlsxStylesWriter.js +155 -0
  137. package/esm/dist/src/stream-writer/XlsxStylesWriter.js.map +1 -0
  138. package/esm/dist/src/stream-writer/XlsxThemeWriter.d.ts +5 -0
  139. package/esm/dist/src/stream-writer/XlsxThemeWriter.d.ts.map +1 -0
  140. package/esm/dist/src/stream-writer/XlsxThemeWriter.js +323 -0
  141. package/esm/dist/src/stream-writer/XlsxThemeWriter.js.map +1 -0
  142. package/esm/dist/src/stream-writer/XlsxWorkbookWriter.d.ts +17 -0
  143. package/esm/dist/src/stream-writer/XlsxWorkbookWriter.d.ts.map +1 -0
  144. package/esm/dist/src/stream-writer/XlsxWorkbookWriter.js +27 -0
  145. package/esm/dist/src/stream-writer/XlsxWorkbookWriter.js.map +1 -0
  146. package/esm/dist/src/stream-writer/XlsxWriter.d.ts +35 -0
  147. package/esm/dist/src/stream-writer/XlsxWriter.d.ts.map +1 -0
  148. package/esm/dist/src/stream-writer/XlsxWriter.js +250 -0
  149. package/esm/dist/src/stream-writer/XlsxWriter.js.map +1 -0
  150. package/esm/dist/src/stream-writer/adapters/ArchiverWriterAdapter.d.ts +24 -0
  151. package/esm/dist/src/stream-writer/adapters/ArchiverWriterAdapter.d.ts.map +1 -0
  152. package/esm/dist/src/stream-writer/adapters/ArchiverWriterAdapter.js +85 -0
  153. package/esm/dist/src/stream-writer/adapters/ArchiverWriterAdapter.js.map +1 -0
  154. package/esm/dist/src/stream-writer/adapters/ZipJsWriterAdapter.d.ts +22 -0
  155. package/esm/dist/src/stream-writer/adapters/ZipJsWriterAdapter.d.ts.map +1 -0
  156. package/esm/dist/src/stream-writer/adapters/ZipJsWriterAdapter.js +45 -0
  157. package/esm/dist/src/stream-writer/adapters/ZipJsWriterAdapter.js.map +1 -0
  158. package/esm/dist/src/stream-writer/escapeXml.d.ts +2 -0
  159. package/esm/dist/src/stream-writer/escapeXml.d.ts.map +1 -0
  160. package/esm/dist/src/stream-writer/escapeXml.js +13 -0
  161. package/esm/dist/src/stream-writer/escapeXml.js.map +1 -0
  162. package/esm/dist/src/stream-writer/index.d.ts +4 -0
  163. package/esm/dist/src/stream-writer/index.d.ts.map +1 -0
  164. package/esm/dist/src/stream-writer/index.js +4 -0
  165. package/esm/dist/src/stream-writer/index.js.map +1 -0
  166. package/esm/dist/src/stream-writer/interfaces.d.ts +14 -0
  167. package/esm/dist/src/stream-writer/interfaces.d.ts.map +1 -0
  168. package/esm/dist/src/stream-writer/interfaces.js +2 -0
  169. package/esm/dist/src/stream-writer/interfaces.js.map +1 -0
  170. package/package.json +28 -0
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.XlsxFileWriter = void 0;
4
+ class XlsxFileWriter {
5
+ /**
6
+ * The sheet writer will write
7
+ */
8
+ writeStream;
9
+ writeStreamWriter;
10
+ async write(str) {
11
+ if (!this.writeStreamWriter) {
12
+ this.writeStreamWriter = this.writeStream.getWriter();
13
+ }
14
+ await this.writeStreamWriter.ready;
15
+ await this.writeStreamWriter.write(Buffer.from(str, 'utf8'));
16
+ }
17
+ async close() {
18
+ // Release writer
19
+ if (this.writeStreamWriter) {
20
+ await this.writeStreamWriter.ready;
21
+ await this.writeStreamWriter.close();
22
+ this.writeStreamWriter = undefined;
23
+ }
24
+ else {
25
+ await this.writeStream.close();
26
+ }
27
+ }
28
+ async abort() {
29
+ if (!this.writeStream) {
30
+ // Not yet initialized
31
+ return;
32
+ }
33
+ if (this.writeStreamWriter) {
34
+ await this.writeStreamWriter.ready;
35
+ await this.writeStreamWriter.close();
36
+ this.writeStreamWriter = undefined;
37
+ }
38
+ else {
39
+ await this.writeStream.close();
40
+ }
41
+ }
42
+ }
43
+ exports.XlsxFileWriter = XlsxFileWriter;
44
+ //# sourceMappingURL=XlsxFileWriter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxFileWriter.js","sourceRoot":"","sources":["../../../src/stream-writer/XlsxFileWriter.ts"],"names":[],"mappings":";;;AAAA,MAAa,cAAc;IACvB;;OAEG;IACH,WAAW,CAAyB;IACpC,iBAAiB,CAAuC;IAExD,KAAK,CAAC,KAAK,CAAC,GAAW;QACnB,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC1B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC;QAC1D,CAAC;QAED,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;QACnC,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC;IACjE,CAAC;IAED,KAAK,CAAC,KAAK;QACP,iBAAiB;QACjB,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;YACnC,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;YACrC,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;QACvC,CAAC;aAAM,CAAC;YACJ,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAA;QAClC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,KAAK;QACP,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACpB,sBAAsB;YACtB,OAAO;QACX,CAAC;QAED,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;YACnC,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;YACrC,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;QACvC,CAAC;aAAM,CAAC;YACJ,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAA;QAClC,CAAC;IACL,CAAC;CACJ;AAzCD,wCAyCC"}
@@ -0,0 +1,17 @@
1
+ import { XlsxFileWriter } from "./XlsxFileWriter";
2
+ export declare class XlsxRelationsWriter extends XlsxFileWriter {
3
+ relations: {
4
+ target: string;
5
+ type: string;
6
+ id: string;
7
+ }[];
8
+ addRelation({ target, type }: {
9
+ target: string;
10
+ type: string;
11
+ }): Promise<string>;
12
+ /**
13
+ * Write remaining data to the file
14
+ */
15
+ close(): Promise<void>;
16
+ }
17
+ //# sourceMappingURL=XlsxRelationsWriter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxRelationsWriter.d.ts","sourceRoot":"","sources":["../../../src/stream-writer/XlsxRelationsWriter.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,qBAAa,mBAAoB,SAAQ,cAAc;IACnD,SAAS,EAAE;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,MAAM,CAAA;KAAC,EAAE,CAAM;IAEvD,WAAW,CAAC,EAAC,MAAM,EAAE,IAAI,EAAC,EAAE;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAMlF;;OAEG;IACG,KAAK;CAad"}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.XlsxRelationsWriter = void 0;
4
+ const escapeXml_1 = require("./escapeXml");
5
+ const XlsxFileWriter_1 = require("./XlsxFileWriter");
6
+ class XlsxRelationsWriter extends XlsxFileWriter_1.XlsxFileWriter {
7
+ relations = [];
8
+ async addRelation({ target, type }) {
9
+ const id = `rId${this.relations.length + 1}`;
10
+ this.relations.push({ target, type, id });
11
+ return Promise.resolve(id);
12
+ }
13
+ /**
14
+ * Write remaining data to the file
15
+ */
16
+ async close() {
17
+ // Write all
18
+ await this.write(`<?xml version="1.0" encoding="UTF-8" standalone="yes"?>\n`);
19
+ await this.write(`<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships">`);
20
+ for (const relation of this.relations) {
21
+ await this.write(`<Relationship Id="${(0, escapeXml_1.escapeXml)(relation.id)}" Type="${(0, escapeXml_1.escapeXml)(relation.type)}" Target="${(0, escapeXml_1.escapeXml)(relation.target)}"/>`);
22
+ }
23
+ await this.write(`</Relationships>`);
24
+ await super.close();
25
+ }
26
+ }
27
+ exports.XlsxRelationsWriter = XlsxRelationsWriter;
28
+ //# sourceMappingURL=XlsxRelationsWriter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxRelationsWriter.js","sourceRoot":"","sources":["../../../src/stream-writer/XlsxRelationsWriter.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AACxC,qDAAkD;AAElD,MAAa,mBAAoB,SAAQ,+BAAc;IACnD,SAAS,GAAiD,EAAE,CAAC;IAE7D,KAAK,CAAC,WAAW,CAAC,EAAC,MAAM,EAAE,IAAI,EAAiC;QAC5D,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;QAC1C,OAAO,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAK;QACP,YAAY;QACZ,MAAM,IAAI,CAAC,KAAK,CAAC,2DAA2D,CAAC,CAAC;QAC9E,MAAM,IAAI,CAAC,KAAK,CAAC,sFAAsF,CAAC,CAAC;QAEzG,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACpC,MAAM,IAAI,CAAC,KAAK,CAAC,qBAAqB,IAAA,qBAAS,EAAC,QAAQ,CAAC,EAAE,CAAC,WAAW,IAAA,qBAAS,EAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,IAAA,qBAAS,EAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACjJ,CAAC;QAED,MAAM,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;QAErC,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;CACJ;AAzBD,kDAyBC"}
@@ -0,0 +1,5 @@
1
+ import { XlsxFileWriter } from "./XlsxFileWriter";
2
+ export declare class XlsxSharedStringsWriter extends XlsxFileWriter {
3
+ close(): Promise<void>;
4
+ }
5
+ //# sourceMappingURL=XlsxSharedStringsWriter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxSharedStringsWriter.d.ts","sourceRoot":"","sources":["../../../src/stream-writer/XlsxSharedStringsWriter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,qBAAa,uBAAwB,SAAQ,cAAc;IACjD,KAAK;CAId"}
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.XlsxSharedStringsWriter = void 0;
4
+ const XlsxFileWriter_1 = require("./XlsxFileWriter");
5
+ class XlsxSharedStringsWriter extends XlsxFileWriter_1.XlsxFileWriter {
6
+ async close() {
7
+ await this.write(`<?xml version="1.0" encoding="UTF-8"?>\n<sst xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" count="0" uniqueCount="0"></sst>`);
8
+ await super.close();
9
+ }
10
+ }
11
+ exports.XlsxSharedStringsWriter = XlsxSharedStringsWriter;
12
+ //# sourceMappingURL=XlsxSharedStringsWriter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxSharedStringsWriter.js","sourceRoot":"","sources":["../../../src/stream-writer/XlsxSharedStringsWriter.ts"],"names":[],"mappings":";;;AAAA,qDAAkD;AAElD,MAAa,uBAAwB,SAAQ,+BAAc;IACvD,KAAK,CAAC,KAAK;QACP,MAAM,IAAI,CAAC,KAAK,CAAC,iJAAiJ,CAAC,CAAC;QACpK,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;CACJ;AALD,0DAKC"}
@@ -0,0 +1,30 @@
1
+ import { CellValue } from "../interfaces";
2
+ import { XlsxFileWriter } from "./XlsxFileWriter";
3
+ import { XlsxStylesWriter } from "./XlsxStylesWriter";
4
+ declare class ColumnInfo {
5
+ width?: number;
6
+ growToMinimum(width: number): void;
7
+ }
8
+ export declare class XlsxSheetWriter extends XlsxFileWriter {
9
+ /**
10
+ * The sheet writer will write
11
+ */
12
+ styles: XlsxStylesWriter;
13
+ didWriteHeader: boolean;
14
+ /**
15
+ * When running in the backend, you'll need to set this to the timezone offset of the user.
16
+ */
17
+ timezone: string;
18
+ columns: ColumnInfo[];
19
+ rowCount: number;
20
+ writeHeader(columnCount?: number): Promise<void>;
21
+ writeFooter(): Promise<void>;
22
+ writeRow(cells: CellValue[]): Promise<void>;
23
+ getCellString(cell: CellValue, { row, column }: {
24
+ row: number;
25
+ column: number;
26
+ }): Promise<string>;
27
+ close(): Promise<void>;
28
+ }
29
+ export {};
30
+ //# sourceMappingURL=XlsxSheetWriter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxSheetWriter.d.ts","sourceRoot":"","sources":["../../../src/stream-writer/XlsxSheetWriter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,SAAS,EAAE,MAAM,eAAe,CAAC;AAEpD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AA2BtD,cAAM,UAAU;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf,aAAa,CAAC,KAAK,EAAE,MAAM;CAK9B;AAED,qBAAa,eAAgB,SAAQ,cAAc;IAC/C;;OAEG;IACH,MAAM,EAAE,gBAAgB,CAAC;IACzB,cAAc,UAAS;IAEvB;;OAEG;IACH,QAAQ,SAAqB;IAE7B,OAAO,EAAE,UAAU,EAAE,CAAM;IAE3B,QAAQ,SAAK;IAEP,WAAW,CAAC,WAAW,SAAI;IAkB3B,WAAW;IAYX,QAAQ,CAAC,KAAK,EAAE,SAAS,EAAE;IA2B3B,aAAa,CAAC,IAAI,EAAE,SAAS,EAAE,EAAC,GAAG,EAAE,MAAM,EAAC,EAAE;QAAC,GAAG,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAC;IAqD3E,KAAK;CAId"}
@@ -0,0 +1,140 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.XlsxSheetWriter = void 0;
4
+ const interfaces_1 = require("../interfaces");
5
+ const escapeXml_1 = require("./escapeXml");
6
+ const XlsxFileWriter_1 = require("./XlsxFileWriter");
7
+ const luxon_1 = require("luxon");
8
+ function numberToAlpha(num) {
9
+ // 1 = a
10
+ // 2 = b
11
+ // 26 = z
12
+ // 27 = aa
13
+ // 28 = ab
14
+ // 52 = az
15
+ // 53 = ba
16
+ const aCharCode = 'a'.charCodeAt(0);
17
+ // Convert into an array with min-max values aCharCode - zCharCode
18
+ const chars = [];
19
+ // Calculate numeric value of this string
20
+ let val = num;
21
+ while (val > 0) {
22
+ const char = (val - 1) % 26;
23
+ chars.unshift(char + aCharCode);
24
+ val = Math.floor((val - 1) / 26);
25
+ }
26
+ return chars.map(c => String.fromCharCode(c)).join("");
27
+ }
28
+ class ColumnInfo {
29
+ width;
30
+ growToMinimum(width) {
31
+ if (this.width === undefined || this.width < width) {
32
+ this.width = width;
33
+ }
34
+ }
35
+ }
36
+ class XlsxSheetWriter extends XlsxFileWriter_1.XlsxFileWriter {
37
+ /**
38
+ * The sheet writer will write
39
+ */
40
+ styles;
41
+ didWriteHeader = false;
42
+ /**
43
+ * When running in the backend, you'll need to set this to the timezone offset of the user.
44
+ */
45
+ timezone = 'Europe/Brussels';
46
+ columns = [];
47
+ rowCount = 0;
48
+ async writeHeader(columnCount = 0) {
49
+ await this.write('<?xml version="1.0" encoding="UTF-8"?>\n');
50
+ await this.write(`<worksheet xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main">`);
51
+ // Sadly <cols> must be before <sheetData> - so we cant calculate the best widths on the fly
52
+ await this.write('<cols>');
53
+ for (const [index, column] of this.columns.entries()) {
54
+ const width = column.width ?? 20;
55
+ await this.write(`<col min="${index + 1}" max="${index + 1}" width="${width}" />`);
56
+ }
57
+ await this.write('</cols>');
58
+ await this.write('<sheetData>');
59
+ this.didWriteHeader = true;
60
+ }
61
+ async writeFooter() {
62
+ if (!this.didWriteHeader) {
63
+ await this.writeHeader(0);
64
+ }
65
+ await this.write('</sheetData>');
66
+ await this.write('</worksheet>');
67
+ }
68
+ async writeRow(cells) {
69
+ if (!this.didWriteHeader) {
70
+ while (this.columns.length < cells.length) {
71
+ // Append until we have enough columns
72
+ const cell = cells[this.columns.length];
73
+ const info = new ColumnInfo();
74
+ if (cell.width !== undefined) {
75
+ info.width = cell.width;
76
+ }
77
+ this.columns.push(info);
78
+ }
79
+ await this.writeHeader(cells.length);
80
+ }
81
+ this.rowCount++;
82
+ let str = `<row r="${this.rowCount}">`;
83
+ for (const [index, cell] of cells.entries()) {
84
+ str += await this.getCellString(cell, { row: this.rowCount, column: index + 1 });
85
+ }
86
+ str += '</row>';
87
+ await this.write(str);
88
+ }
89
+ async getCellString(cell, { row, column }) {
90
+ let type = interfaces_1.CellType.InlineString;
91
+ let str = '';
92
+ switch (typeof cell.value) {
93
+ case 'boolean':
94
+ type = interfaces_1.CellType.Boolean;
95
+ str = cell.value ? '1' : '0';
96
+ break;
97
+ case 'number':
98
+ type = interfaces_1.CellType.Number;
99
+ if (isNaN(cell.value) || !isFinite(cell.value)) {
100
+ type = interfaces_1.CellType.Error;
101
+ str = '#VALUE!';
102
+ }
103
+ else {
104
+ str = cell.value.toString();
105
+ }
106
+ break;
107
+ case 'string':
108
+ // todo: we can use shared strings here
109
+ type = interfaces_1.CellType.InlineString;
110
+ str = cell.value;
111
+ break;
112
+ case 'object':
113
+ if (cell.value instanceof Date) {
114
+ // Excel has this funny thing where they ALWAYS interpret dates as the local timezone
115
+ // This has the advantage that if you write a date in a cell, it will always contain the same value, regardless of the timezone of the user.
116
+ const dateTime = luxon_1.DateTime.fromJSDate(cell.value).setZone(this.timezone);
117
+ type = interfaces_1.CellType.Number;
118
+ str = ((cell.value.getTime() + dateTime.offset * 60 * 1000) / 1000 / 24 / 60 / 60 + 25569).toFixed(6);
119
+ }
120
+ // Null
121
+ if (cell.value === null) {
122
+ type = interfaces_1.CellType.InlineString;
123
+ str = '';
124
+ }
125
+ break;
126
+ }
127
+ const styleId = (await this.styles.requestCellStyleId(cell.style ?? {})).toString();
128
+ const r = `${numberToAlpha(column).toUpperCase()}${row}`;
129
+ if (type === interfaces_1.CellType.InlineString) {
130
+ return `<c r="${(0, escapeXml_1.escapeXml)(r)}" s="${(0, escapeXml_1.escapeXml)(styleId)}" t="${(0, escapeXml_1.escapeXml)(type)}"><is><t>${(0, escapeXml_1.escapeXml)(str)}</t></is></c>`;
131
+ }
132
+ return `<c r="${(0, escapeXml_1.escapeXml)(r)}" s="${(0, escapeXml_1.escapeXml)(styleId)}" t="${(0, escapeXml_1.escapeXml)(type)}"><v>${(0, escapeXml_1.escapeXml)(str)}</v></c>`;
133
+ }
134
+ async close() {
135
+ await this.writeFooter();
136
+ await super.close();
137
+ }
138
+ }
139
+ exports.XlsxSheetWriter = XlsxSheetWriter;
140
+ //# sourceMappingURL=XlsxSheetWriter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxSheetWriter.js","sourceRoot":"","sources":["../../../src/stream-writer/XlsxSheetWriter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import { CellAlignmentOptions, CellStyleRequest, FontOptions, NumberFormatOptions } from "../interfaces";
2
+ import { XlsxFileWriter } from "./XlsxFileWriter";
3
+ type CellStyle = {
4
+ fontId?: number;
5
+ numberFormatId?: number;
6
+ alignment?: CellAlignmentOptions;
7
+ applyNumberFormat?: boolean;
8
+ applyFont?: boolean;
9
+ applyAlignment?: boolean;
10
+ };
11
+ export declare class XlsxStylesWriter extends XlsxFileWriter {
12
+ numberFormats: Required<NumberFormatOptions>[];
13
+ fonts: FontOptions[];
14
+ cellStyles: CellStyle[];
15
+ requestNumberFormatId(options?: NumberFormatOptions): Promise<number>;
16
+ requestFontId(options: FontOptions): Promise<number>;
17
+ getCellStyle(style: CellStyleRequest): Promise<CellStyle>;
18
+ alignmentEquals(a: CellAlignmentOptions, b: CellAlignmentOptions): boolean;
19
+ styleEquals(a: CellStyle, b: CellStyle): boolean;
20
+ requestCellStyleId(request: CellStyleRequest): Promise<number>;
21
+ close(): Promise<void>;
22
+ }
23
+ export {};
24
+ //# sourceMappingURL=XlsxStylesWriter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxStylesWriter.d.ts","sourceRoot":"","sources":["../../../src/stream-writer/XlsxStylesWriter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,WAAW,EAAE,mBAAmB,EAA2B,MAAM,eAAe,CAAC;AAElI,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,KAAK,SAAS,GAAG;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,SAAS,CAAC,EAAE,oBAAoB,CAAC;IACjC,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,cAAc,CAAC,EAAE,OAAO,CAAC;CAC5B,CAAA;AAED,qBAAa,gBAAiB,SAAQ,cAAc;IAChD,aAAa,EAAE,QAAQ,CAAC,mBAAmB,CAAC,EAAE,CAAM;IACpD,KAAK,EAAE,WAAW,EAAE,CAAM;IAC1B,UAAU,EAAE,SAAS,EAAE,CAAM;IAEvB,qBAAqB,CAAC,OAAO,GAAE,mBAAwB,GAAG,OAAO,CAAC,MAAM,CAAC;IA6CzE,aAAa,CAAC,OAAO,EAAE,WAAW;IAoBlC,YAAY,CAAC,KAAK,EAAE,gBAAgB,GAAG,OAAO,CAAC,SAAS,CAAC;IAW/D,eAAe,CAAC,CAAC,EAAE,oBAAoB,EAAE,CAAC,EAAE,oBAAoB,GAAG,OAAO;IAI1E,WAAW,CAAC,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,SAAS,GAAG,OAAO;IAS1C,kBAAkB,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,MAAM,CAAC;IAa9D,KAAK;CAgFd"}
@@ -0,0 +1,159 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.XlsxStylesWriter = void 0;
4
+ const interfaces_1 = require("../interfaces");
5
+ const escapeXml_1 = require("./escapeXml");
6
+ const XlsxFileWriter_1 = require("./XlsxFileWriter");
7
+ class XlsxStylesWriter extends XlsxFileWriter_1.XlsxFileWriter {
8
+ numberFormats = [];
9
+ fonts = [];
10
+ cellStyles = [];
11
+ async requestNumberFormatId(options = {}) {
12
+ if (options.id) {
13
+ for (const o of this.numberFormats) {
14
+ if (o.id === options.id) {
15
+ if (options.formatCode && o.formatCode !== options.formatCode) {
16
+ o.formatCode = options.formatCode;
17
+ }
18
+ return o.id;
19
+ }
20
+ }
21
+ if (!options.formatCode) {
22
+ if (Object.values(interfaces_1.XlsxBuiltInNumberFormat).includes(options.id)) {
23
+ // Built in number format
24
+ return options.id;
25
+ }
26
+ throw new Error('Invalid number format id: ' + options.id + ', missing formatCode');
27
+ }
28
+ // Create a new one with this specific id
29
+ this.numberFormats.push(options);
30
+ return Promise.resolve(options.id);
31
+ }
32
+ if (!options.formatCode) {
33
+ // No formatting requested
34
+ // Return default style
35
+ return interfaces_1.XlsxBuiltInNumberFormat.Number;
36
+ }
37
+ // Check if we find a match
38
+ for (const o of this.numberFormats) {
39
+ if (o.id && o.formatCode && o.formatCode === options.formatCode) {
40
+ return o.id;
41
+ }
42
+ }
43
+ // Generate a new id
44
+ const id = this.numberFormats.length + 164;
45
+ this.numberFormats.push({ id, formatCode: options.formatCode });
46
+ return id;
47
+ }
48
+ async requestFontId(options) {
49
+ if (options.size === undefined) {
50
+ options.size = 12;
51
+ }
52
+ if (options.bold === undefined) {
53
+ options.bold = false;
54
+ }
55
+ // Checks whether this exists already, or creates it
56
+ for (const [id, o] of this.fonts.entries()) {
57
+ if (o.size === options.size && o.bold === options.bold) {
58
+ return id;
59
+ }
60
+ }
61
+ this.fonts.push(options);
62
+ return Promise.resolve(this.fonts.length - 1);
63
+ }
64
+ async getCellStyle(style) {
65
+ return {
66
+ fontId: await this.requestFontId(style.font ?? {}),
67
+ numberFormatId: await this.requestNumberFormatId(style.numberFormat),
68
+ alignment: style.alignment,
69
+ applyNumberFormat: style.numberFormat ? true : undefined,
70
+ applyFont: style.font ? true : false,
71
+ applyAlignment: style.alignment ? true : false,
72
+ };
73
+ }
74
+ alignmentEquals(a, b) {
75
+ return a.horizontal === b.horizontal && a.vertical === b.vertical && a.wrapText === b.wrapText;
76
+ }
77
+ styleEquals(a, b) {
78
+ return a.fontId === b.fontId &&
79
+ a.numberFormatId === b.numberFormatId &&
80
+ a.applyNumberFormat === b.applyNumberFormat &&
81
+ a.applyFont === b.applyFont &&
82
+ this.alignmentEquals(a.alignment || {}, b.alignment || {}) &&
83
+ a.applyAlignment === b.applyAlignment;
84
+ }
85
+ async requestCellStyleId(request) {
86
+ const style = await this.getCellStyle(request);
87
+ for (const [id, s] of this.cellStyles.entries()) {
88
+ if (this.styleEquals(style, s)) {
89
+ return id;
90
+ }
91
+ }
92
+ this.cellStyles.push(style);
93
+ return Promise.resolve(this.cellStyles.length - 1);
94
+ }
95
+ async close() {
96
+ await this.write(`<?xml version="1.0" encoding="UTF-8"?>`);
97
+ await this.write(`<styleSheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main">`);
98
+ await this.write(`<numFmts count="${this.numberFormats.length}">`);
99
+ for (const format of this.numberFormats) {
100
+ await this.write(`<numFmt numFmtId="${(0, escapeXml_1.escapeXml)(format.id.toString())}" formatCode="${(0, escapeXml_1.escapeXml)(format.formatCode)}" />`);
101
+ }
102
+ await this.write(`</numFmts>`);
103
+ await this.write(`<fonts count="${this.fonts.length}">`);
104
+ for (const font of this.fonts) {
105
+ await this.write(`<font>`);
106
+ await this.write(`<name val="Aptos Narrow" />`);
107
+ if (font.size) {
108
+ await this.write(`<sz val="${(0, escapeXml_1.escapeXml)(font.size.toString())}" />`);
109
+ }
110
+ if (font.bold) {
111
+ await this.write(`<b />`);
112
+ }
113
+ await this.write(`</font>`);
114
+ }
115
+ await this.write(`</fonts>`);
116
+ await this.write(`<fills count="2">`);
117
+ await this.write(`<fill><patternFill patternType="none" /></fill>`);
118
+ await this.write(`<fill><patternFill patternType="gray125" /></fill>`);
119
+ await this.write(`</fills>`);
120
+ await this.write(`<borders count="1">`);
121
+ await this.write(`<border><left /><right /><top /><bottom /><diagonal /></border>`);
122
+ await this.write(`</borders>`);
123
+ await this.write(`<cellStyleXfs count="1">`);
124
+ await this.write(`<xf numFmtId="0" fontId="0" fillId="0" borderId="0" />`);
125
+ await this.write(`</cellStyleXfs>`);
126
+ await this.write(`<cellXfs count="${this.cellStyles.length}">`);
127
+ for (const style of this.cellStyles) {
128
+ const attrs = `numFmtId="${style.numberFormatId}" fontId="${style.fontId}" fillId="0" borderId="0" xfId="0" applyNumberFormat="${style.applyNumberFormat ? 1 : 0}" applyFont="${style.applyFont ? 1 : 0}" applyAlignment="${style.applyAlignment ? 1 : 0}"`;
129
+ if (style.alignment) {
130
+ await this.write(`<xf ${attrs}>`);
131
+ await this.write(`<alignment`);
132
+ if (style.alignment.horizontal) {
133
+ await this.write(` horizontal="${style.alignment.horizontal}"`);
134
+ }
135
+ if (style.alignment.vertical) {
136
+ await this.write(` vertical="${style.alignment.vertical}"`);
137
+ }
138
+ if (style.alignment.wrapText) {
139
+ await this.write(` wrapText="1"`);
140
+ }
141
+ await this.write(` />`);
142
+ await this.write(`</xf>`);
143
+ }
144
+ else {
145
+ await this.write(`<xf ${attrs} />`);
146
+ }
147
+ }
148
+ await this.write(`</cellXfs>`);
149
+ await this.write(`<cellStyles count="1">`);
150
+ await this.write(`<cellStyle name="Normal" xfId="0" builtinId="0" />`);
151
+ await this.write(`</cellStyles>`);
152
+ await this.write(`<dxfs count="0" />`);
153
+ await this.write(`<tableStyles count="0" />`);
154
+ await this.write(`</styleSheet>`);
155
+ await super.close();
156
+ }
157
+ }
158
+ exports.XlsxStylesWriter = XlsxStylesWriter;
159
+ //# sourceMappingURL=XlsxStylesWriter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxStylesWriter.js","sourceRoot":"","sources":["../../../src/stream-writer/XlsxStylesWriter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import { XlsxFileWriter } from "./XlsxFileWriter";
2
+ export declare class XlsxThemeWriter extends XlsxFileWriter {
3
+ close(): Promise<void>;
4
+ }
5
+ //# sourceMappingURL=XlsxThemeWriter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"XlsxThemeWriter.d.ts","sourceRoot":"","sources":["../../../src/stream-writer/XlsxThemeWriter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,qBAAa,eAAgB,SAAQ,cAAc;IACzC,KAAK;CAgUd"}