@stamhoofd/excel-writer 2.118.1 → 2.120.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.
- package/dist/{src/XlsxColumnFilterer.d.ts → XlsxColumnFilterer.d.ts} +1 -1
- package/dist/XlsxColumnFilterer.d.ts.map +1 -0
- package/{esm/dist/src → dist}/XlsxColumnFilterer.js +3 -3
- package/dist/XlsxColumnFilterer.js.map +1 -0
- package/dist/{src/XlsxTransformer.d.ts → XlsxTransformer.d.ts} +1 -1
- package/dist/XlsxTransformer.d.ts.map +1 -0
- package/dist/XlsxTransformer.js.map +1 -0
- package/dist/{src/exportToExcel.d.ts → exportToExcel.d.ts} +1 -1
- package/dist/exportToExcel.d.ts.map +1 -0
- package/dist/exportToExcel.js.map +1 -0
- package/dist/index.d.ts +3 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -6
- package/dist/index.js.map +1 -1
- package/dist/interfaces.d.ts.map +1 -0
- package/dist/interfaces.js.map +1 -0
- package/dist/stream-writer/XlsxAppPropsWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxAppPropsWriter.js.map +1 -0
- package/dist/stream-writer/XlsxContentTypesWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxContentTypesWriter.js.map +1 -0
- package/dist/stream-writer/XlsxCorePropsWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxCorePropsWriter.js.map +1 -0
- package/dist/stream-writer/XlsxFileWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxFileWriter.js.map +1 -0
- package/dist/stream-writer/XlsxRelationsWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxRelationsWriter.js.map +1 -0
- package/dist/stream-writer/XlsxSharedStringsWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxSharedStringsWriter.js.map +1 -0
- package/{esm/dist/src → dist}/stream-writer/XlsxSheetWriter.d.ts +2 -2
- package/dist/stream-writer/XlsxSheetWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxSheetWriter.js.map +1 -0
- package/dist/{src/stream-writer → stream-writer}/XlsxStylesWriter.d.ts +1 -1
- package/dist/stream-writer/XlsxStylesWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxStylesWriter.js.map +1 -0
- package/dist/stream-writer/XlsxThemeWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxThemeWriter.js.map +1 -0
- package/dist/stream-writer/XlsxWorkbookWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxWorkbookWriter.js.map +1 -0
- package/dist/{src/stream-writer → stream-writer}/XlsxWriter.d.ts +2 -2
- package/dist/stream-writer/XlsxWriter.d.ts.map +1 -0
- package/dist/stream-writer/XlsxWriter.js.map +1 -0
- package/dist/{src/stream-writer → stream-writer}/adapters/ArchiverWriterAdapter.d.ts +1 -1
- package/dist/stream-writer/adapters/ArchiverWriterAdapter.d.ts.map +1 -0
- package/dist/stream-writer/adapters/ArchiverWriterAdapter.js.map +1 -0
- package/dist/stream-writer/escapeXml.d.ts.map +1 -0
- package/dist/stream-writer/escapeXml.js.map +1 -0
- package/dist/stream-writer/index.d.ts.map +1 -0
- package/dist/stream-writer/index.js.map +1 -0
- package/dist/stream-writer/interfaces.d.ts.map +1 -0
- package/dist/stream-writer/interfaces.js.map +1 -0
- package/package.json +16 -9
- package/dist/src/XlsxColumnFilterer.d.ts.map +0 -1
- package/dist/src/XlsxColumnFilterer.js +0 -128
- package/dist/src/XlsxColumnFilterer.js.map +0 -1
- package/dist/src/XlsxTransformer.d.ts.map +0 -1
- package/dist/src/XlsxTransformer.js +0 -105
- package/dist/src/XlsxTransformer.js.map +0 -1
- package/dist/src/exportToExcel.d.ts.map +0 -1
- package/dist/src/exportToExcel.js +0 -24
- package/dist/src/exportToExcel.js.map +0 -1
- package/dist/src/interfaces.d.ts.map +0 -1
- package/dist/src/interfaces.js +0 -105
- package/dist/src/interfaces.js.map +0 -1
- package/dist/src/stream-writer/XlsxAppPropsWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxAppPropsWriter.js +0 -13
- package/dist/src/stream-writer/XlsxAppPropsWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxContentTypesWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxContentTypesWriter.js +0 -24
- package/dist/src/stream-writer/XlsxContentTypesWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxCorePropsWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxCorePropsWriter.js +0 -26
- package/dist/src/stream-writer/XlsxCorePropsWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxFileWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxFileWriter.js +0 -44
- package/dist/src/stream-writer/XlsxFileWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxRelationsWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxRelationsWriter.js +0 -28
- package/dist/src/stream-writer/XlsxRelationsWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxSharedStringsWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxSharedStringsWriter.js +0 -12
- package/dist/src/stream-writer/XlsxSharedStringsWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxSheetWriter.d.ts +0 -31
- package/dist/src/stream-writer/XlsxSheetWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxSheetWriter.js +0 -154
- package/dist/src/stream-writer/XlsxSheetWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxStylesWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxStylesWriter.js +0 -159
- package/dist/src/stream-writer/XlsxStylesWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxThemeWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxThemeWriter.js +0 -327
- package/dist/src/stream-writer/XlsxThemeWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxWorkbookWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxWorkbookWriter.js +0 -31
- package/dist/src/stream-writer/XlsxWorkbookWriter.js.map +0 -1
- package/dist/src/stream-writer/XlsxWriter.d.ts.map +0 -1
- package/dist/src/stream-writer/XlsxWriter.js +0 -254
- package/dist/src/stream-writer/XlsxWriter.js.map +0 -1
- package/dist/src/stream-writer/adapters/ArchiverWriterAdapter.d.ts.map +0 -1
- package/dist/src/stream-writer/adapters/ArchiverWriterAdapter.js +0 -103
- package/dist/src/stream-writer/adapters/ArchiverWriterAdapter.js.map +0 -1
- package/dist/src/stream-writer/escapeXml.d.ts.map +0 -1
- package/dist/src/stream-writer/escapeXml.js +0 -16
- package/dist/src/stream-writer/escapeXml.js.map +0 -1
- package/dist/src/stream-writer/index.d.ts.map +0 -1
- package/dist/src/stream-writer/index.js +0 -6
- package/dist/src/stream-writer/index.js.map +0 -1
- package/dist/src/stream-writer/interfaces.d.ts.map +0 -1
- package/dist/src/stream-writer/interfaces.js +0 -3
- package/dist/src/stream-writer/interfaces.js.map +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/esm/dist/index.d.ts +0 -4
- package/esm/dist/index.d.ts.map +0 -1
- package/esm/dist/index.js +0 -4
- package/esm/dist/index.js.map +0 -1
- package/esm/dist/src/XlsxColumnFilterer.d.ts +0 -11
- package/esm/dist/src/XlsxColumnFilterer.d.ts.map +0 -1
- package/esm/dist/src/XlsxColumnFilterer.js.map +0 -1
- package/esm/dist/src/XlsxTransformer.d.ts +0 -14
- package/esm/dist/src/XlsxTransformer.d.ts.map +0 -1
- package/esm/dist/src/XlsxTransformer.js.map +0 -1
- package/esm/dist/src/exportToExcel.d.ts +0 -8
- package/esm/dist/src/exportToExcel.d.ts.map +0 -1
- package/esm/dist/src/exportToExcel.js.map +0 -1
- package/esm/dist/src/interfaces.d.ts +0 -173
- package/esm/dist/src/interfaces.d.ts.map +0 -1
- package/esm/dist/src/interfaces.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxAppPropsWriter.d.ts +0 -5
- package/esm/dist/src/stream-writer/XlsxAppPropsWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxAppPropsWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxContentTypesWriter.d.ts +0 -13
- package/esm/dist/src/stream-writer/XlsxContentTypesWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxContentTypesWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxCorePropsWriter.d.ts +0 -7
- package/esm/dist/src/stream-writer/XlsxCorePropsWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxCorePropsWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxFileWriter.d.ts +0 -11
- package/esm/dist/src/stream-writer/XlsxFileWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxFileWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxRelationsWriter.d.ts +0 -17
- package/esm/dist/src/stream-writer/XlsxRelationsWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxRelationsWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxSharedStringsWriter.d.ts +0 -5
- package/esm/dist/src/stream-writer/XlsxSharedStringsWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxSharedStringsWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxSheetWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxSheetWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxStylesWriter.d.ts +0 -24
- package/esm/dist/src/stream-writer/XlsxStylesWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxStylesWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxThemeWriter.d.ts +0 -5
- package/esm/dist/src/stream-writer/XlsxThemeWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxThemeWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxWorkbookWriter.d.ts +0 -17
- package/esm/dist/src/stream-writer/XlsxWorkbookWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxWorkbookWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/XlsxWriter.d.ts +0 -35
- package/esm/dist/src/stream-writer/XlsxWriter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/XlsxWriter.js.map +0 -1
- package/esm/dist/src/stream-writer/adapters/ArchiverWriterAdapter.d.ts +0 -20
- package/esm/dist/src/stream-writer/adapters/ArchiverWriterAdapter.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/adapters/ArchiverWriterAdapter.js.map +0 -1
- package/esm/dist/src/stream-writer/escapeXml.d.ts +0 -2
- package/esm/dist/src/stream-writer/escapeXml.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/escapeXml.js.map +0 -1
- package/esm/dist/src/stream-writer/index.d.ts +0 -3
- package/esm/dist/src/stream-writer/index.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/index.js.map +0 -1
- package/esm/dist/src/stream-writer/interfaces.d.ts +0 -14
- package/esm/dist/src/stream-writer/interfaces.d.ts.map +0 -1
- package/esm/dist/src/stream-writer/interfaces.js.map +0 -1
- package/esm/dist/tsconfig.tsbuildinfo +0 -1
- package/esm/package.json +0 -3
- /package/{esm/dist/src → dist}/XlsxTransformer.js +0 -0
- /package/{esm/dist/src → dist}/exportToExcel.js +0 -0
- /package/dist/{src/interfaces.d.ts → interfaces.d.ts} +0 -0
- /package/{esm/dist/src → dist}/interfaces.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/XlsxAppPropsWriter.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxAppPropsWriter.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/XlsxContentTypesWriter.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxContentTypesWriter.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/XlsxCorePropsWriter.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxCorePropsWriter.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/XlsxFileWriter.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxFileWriter.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/XlsxRelationsWriter.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxRelationsWriter.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/XlsxSharedStringsWriter.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxSharedStringsWriter.js +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxSheetWriter.js +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxStylesWriter.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/XlsxThemeWriter.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxThemeWriter.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/XlsxWorkbookWriter.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxWorkbookWriter.js +0 -0
- /package/{esm/dist/src → dist}/stream-writer/XlsxWriter.js +0 -0
- /package/{esm/dist/src → dist}/stream-writer/adapters/ArchiverWriterAdapter.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/escapeXml.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/escapeXml.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/index.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/index.js +0 -0
- /package/dist/{src/stream-writer → stream-writer}/interfaces.d.ts +0 -0
- /package/{esm/dist/src → dist}/stream-writer/interfaces.js +0 -0
|
@@ -1,154 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.XlsxSheetWriter = void 0;
|
|
4
|
-
const interfaces_js_1 = require("../interfaces.js");
|
|
5
|
-
const escapeXml_js_1 = require("./escapeXml.js");
|
|
6
|
-
const XlsxFileWriter_js_1 = require("./XlsxFileWriter.js");
|
|
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_js_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
|
-
mergeCells = [];
|
|
49
|
-
async writeHeader(columnCount = 0) {
|
|
50
|
-
await this.write('<?xml version="1.0" encoding="UTF-8"?>\n');
|
|
51
|
-
await this.write(`<worksheet xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main">`);
|
|
52
|
-
// Sadly <cols> must be before <sheetData> - so we cant calculate the best widths on the fly
|
|
53
|
-
await this.write('<cols>');
|
|
54
|
-
for (const [index, column] of this.columns.entries()) {
|
|
55
|
-
const width = column.width ?? 20;
|
|
56
|
-
await this.write(`<col min="${index + 1}" max="${index + 1}" width="${width}" />`);
|
|
57
|
-
}
|
|
58
|
-
await this.write('</cols>');
|
|
59
|
-
await this.write('<sheetData>');
|
|
60
|
-
this.didWriteHeader = true;
|
|
61
|
-
}
|
|
62
|
-
async writeFooter() {
|
|
63
|
-
if (!this.didWriteHeader) {
|
|
64
|
-
await this.writeHeader(0);
|
|
65
|
-
}
|
|
66
|
-
await this.write('</sheetData>');
|
|
67
|
-
if (this.mergeCells.length > 0) {
|
|
68
|
-
await this.write('<mergeCells count="' + this.mergeCells.length + '">');
|
|
69
|
-
for (const merge of this.mergeCells) {
|
|
70
|
-
await this.write('<mergeCell ref="' + (0, escapeXml_js_1.escapeXml)(merge) + '" />');
|
|
71
|
-
}
|
|
72
|
-
await this.write('</mergeCells>');
|
|
73
|
-
}
|
|
74
|
-
await this.write('</worksheet>');
|
|
75
|
-
}
|
|
76
|
-
async writeRow(cells) {
|
|
77
|
-
if (!this.didWriteHeader) {
|
|
78
|
-
while (this.columns.length < cells.length) {
|
|
79
|
-
// Append until we have enough columns
|
|
80
|
-
const cell = cells[this.columns.length];
|
|
81
|
-
const info = new ColumnInfo();
|
|
82
|
-
if (cell.width !== undefined) {
|
|
83
|
-
info.width = cell.width;
|
|
84
|
-
}
|
|
85
|
-
this.columns.push(info);
|
|
86
|
-
}
|
|
87
|
-
await this.writeHeader(cells.length);
|
|
88
|
-
}
|
|
89
|
-
this.rowCount++;
|
|
90
|
-
let str = `<row r="${this.rowCount}">`;
|
|
91
|
-
for (const [index, cell] of cells.entries()) {
|
|
92
|
-
str += await this.getCellString(cell, { row: this.rowCount, column: index + 1 });
|
|
93
|
-
if (cell.merge && (cell.merge.width > 1 || cell.merge.height > 1)) {
|
|
94
|
-
const start = `${numberToAlpha(index + 1).toUpperCase()}${this.rowCount}`;
|
|
95
|
-
const end = `${numberToAlpha(index + cell.merge.width).toUpperCase()}${this.rowCount + cell.merge.height - 1}`;
|
|
96
|
-
// append at the end of the file
|
|
97
|
-
this.mergeCells.push(`${start}:${end}`);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
str += '</row>';
|
|
101
|
-
await this.write(str);
|
|
102
|
-
}
|
|
103
|
-
async getCellString(cell, { row, column }) {
|
|
104
|
-
let type = interfaces_js_1.CellType.InlineString;
|
|
105
|
-
let str = '';
|
|
106
|
-
const r = `${numberToAlpha(column).toUpperCase()}${row}`;
|
|
107
|
-
switch (typeof cell.value) {
|
|
108
|
-
case 'boolean':
|
|
109
|
-
type = interfaces_js_1.CellType.Boolean;
|
|
110
|
-
str = cell.value ? '1' : '0';
|
|
111
|
-
break;
|
|
112
|
-
case 'number':
|
|
113
|
-
type = interfaces_js_1.CellType.Number;
|
|
114
|
-
if (isNaN(cell.value) || !isFinite(cell.value)) {
|
|
115
|
-
type = interfaces_js_1.CellType.Error;
|
|
116
|
-
str = '#VALUE!';
|
|
117
|
-
}
|
|
118
|
-
else {
|
|
119
|
-
str = cell.value.toString();
|
|
120
|
-
}
|
|
121
|
-
break;
|
|
122
|
-
case 'string':
|
|
123
|
-
// todo: we can use shared strings here
|
|
124
|
-
type = interfaces_js_1.CellType.InlineString;
|
|
125
|
-
str = cell.value;
|
|
126
|
-
break;
|
|
127
|
-
case 'object':
|
|
128
|
-
if (cell.value instanceof Date) {
|
|
129
|
-
// Excel has this funny thing where they ALWAYS interpret dates as the local timezone
|
|
130
|
-
// 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.
|
|
131
|
-
const dateTime = luxon_1.DateTime.fromJSDate(cell.value).setZone(this.timezone);
|
|
132
|
-
type = interfaces_js_1.CellType.Number;
|
|
133
|
-
str = ((cell.value.getTime() + dateTime.offset * 60 * 1000) / 1000 / 24 / 60 / 60 + 25569).toFixed(6);
|
|
134
|
-
}
|
|
135
|
-
// Null
|
|
136
|
-
if (cell.value === null) {
|
|
137
|
-
type = interfaces_js_1.CellType.InlineString;
|
|
138
|
-
str = '';
|
|
139
|
-
}
|
|
140
|
-
break;
|
|
141
|
-
}
|
|
142
|
-
const styleId = (await this.styles.requestCellStyleId(cell.style ?? {})).toString();
|
|
143
|
-
if (type === interfaces_js_1.CellType.InlineString) {
|
|
144
|
-
return `<c r="${(0, escapeXml_js_1.escapeXml)(r)}" s="${(0, escapeXml_js_1.escapeXml)(styleId)}" t="${(0, escapeXml_js_1.escapeXml)(type)}"><is><t>${(0, escapeXml_js_1.escapeXml)(str)}</t></is></c>`;
|
|
145
|
-
}
|
|
146
|
-
return `<c r="${(0, escapeXml_js_1.escapeXml)(r)}" s="${(0, escapeXml_js_1.escapeXml)(styleId)}" t="${(0, escapeXml_js_1.escapeXml)(type)}"><v>${(0, escapeXml_js_1.escapeXml)(str)}</v></c>`;
|
|
147
|
-
}
|
|
148
|
-
async close() {
|
|
149
|
-
await this.writeFooter();
|
|
150
|
-
await super.close();
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
exports.XlsxSheetWriter = XlsxSheetWriter;
|
|
154
|
-
//# sourceMappingURL=XlsxSheetWriter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"XlsxSheetWriter.js","sourceRoot":"","sources":["../../../src/stream-writer/XlsxSheetWriter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
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,kBAAkB,CAAC;AAErI,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAErD,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,CAAC;AAEF,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;CAiFd"}
|
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.XlsxStylesWriter = void 0;
|
|
4
|
-
const interfaces_js_1 = require("../interfaces.js");
|
|
5
|
-
const escapeXml_js_1 = require("./escapeXml.js");
|
|
6
|
-
const XlsxFileWriter_js_1 = require("./XlsxFileWriter.js");
|
|
7
|
-
class XlsxStylesWriter extends XlsxFileWriter_js_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_js_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_js_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_js_1.escapeXml)(format.id.toString())}" formatCode="${(0, escapeXml_js_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_js_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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"XlsxStylesWriter.js","sourceRoot":"","sources":["../../../src/stream-writer/XlsxStylesWriter.ts"],"names":[],"mappings":";;;AAAA,oDAAqI;AACrI,iDAA2C;AAC3C,2DAAqD;AAWrD,MAAa,gBAAiB,SAAQ,kCAAc;IAChD,aAAa,GAAoC,EAAE,CAAC;IACpD,KAAK,GAAkB,EAAE,CAAC;IAC1B,UAAU,GAAgB,EAAE,CAAC;IAE7B,KAAK,CAAC,qBAAqB,CAAC,UAA+B,EAAE;QACzD,IAAI,OAAO,CAAC,EAAE,EAAE,CAAC;YACb,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACjC,IAAI,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,EAAE,CAAC;oBACtB,IAAI,OAAO,CAAC,UAAU,IAAI,CAAC,CAAC,UAAU,KAAK,OAAO,CAAC,UAAU,EAAE,CAAC;wBAC5D,CAAC,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;oBACtC,CAAC;oBACD,OAAO,CAAC,CAAC,EAAE,CAAC;gBAChB,CAAC;YACL,CAAC;YAED,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;gBACtB,IAAI,MAAM,CAAC,MAAM,CAAC,uCAAuB,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;oBAC9D,yBAAyB;oBACzB,OAAO,OAAO,CAAC,EAAE,CAAC;gBACtB,CAAC;gBAED,MAAM,IAAI,KAAK,CAAC,4BAA4B,GAAG,OAAO,CAAC,EAAE,GAAG,sBAAsB,CAAC,CAAC;YACxF,CAAC;YAED,yCAAyC;YACzC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAwC,CAAC,CAAC;YAClE,OAAO,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;YACtB,0BAA0B;YAC1B,uBAAuB;YACvB,OAAO,uCAAuB,CAAC,MAAM,CAAC;QAC1C,CAAC;QAED,2BAA2B;QAC3B,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACjC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,UAAU,IAAI,CAAC,CAAC,UAAU,KAAK,OAAO,CAAC,UAAU,EAAE,CAAC;gBAC9D,OAAO,CAAC,CAAC,EAAE,CAAC;YAChB,CAAC;QACL,CAAC;QAED,oBAAoB;QACpB,MAAM,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,GAAG,CAAC;QAC3C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,UAAU,EAAE,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;QAEhE,OAAO,EAAE,CAAC;IACd,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,OAAoB;QACpC,IAAI,OAAO,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC7B,OAAO,CAAC,IAAI,GAAG,EAAE,CAAC;QACtB,CAAC;QAED,IAAI,OAAO,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC7B,OAAO,CAAC,IAAI,GAAG,KAAK,CAAC;QACzB,CAAC;QAED,oDAAoD;QACpD,KAAK,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC;YACzC,IAAI,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,EAAE,CAAC;gBACrD,OAAO,EAAE,CAAC;YACd,CAAC;QACL,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACzB,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAClD,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,KAAuB;QACtC,OAAO;YACH,MAAM,EAAE,MAAM,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC;YAClD,cAAc,EAAE,MAAM,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,YAAY,CAAC;YACpE,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,iBAAiB,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS;YACxD,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK;YACpC,cAAc,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK;SACjD,CAAC;IACN,CAAC;IAED,eAAe,CAAC,CAAuB,EAAE,CAAuB;QAC5D,OAAO,CAAC,CAAC,UAAU,KAAK,CAAC,CAAC,UAAU,IAAI,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,QAAQ,CAAC;IACnG,CAAC;IAED,WAAW,CAAC,CAAY,EAAE,CAAY;QAClC,OAAO,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM;eACrB,CAAC,CAAC,cAAc,KAAK,CAAC,CAAC,cAAc;eACrC,CAAC,CAAC,iBAAiB,KAAK,CAAC,CAAC,iBAAiB;eAC3C,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC,SAAS;eAC3B,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS,IAAI,EAAE,EAAE,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC;eAC1D,CAAC,CAAC,cAAc,KAAK,CAAC,CAAC,cAAc,CAAC;IACjD,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,OAAyB;QAC9C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QAE/C,KAAK,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC;YAC9C,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC;gBAC7B,OAAO,EAAE,CAAC;YACd,CAAC;QACL,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,KAAK,CAAC,KAAK;QACP,MAAM,IAAI,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;QAE3D,MAAM,IAAI,CAAC,KAAK,CAAC,gFAAgF,CAAC,CAAC;QAEnG,MAAM,IAAI,CAAC,KAAK,CAAC,mBAAmB,IAAI,CAAC,aAAa,CAAC,MAAM,IAAI,CAAC,CAAC;QAEnE,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACtC,MAAM,IAAI,CAAC,KAAK,CAAC,qBAAqB,IAAA,wBAAS,EAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,iBAAiB,IAAA,wBAAS,EAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAC9H,CAAC;QAED,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAE/B,MAAM,IAAI,CAAC,KAAK,CAAC,iBAAiB,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,CAAC;QAEzD,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC5B,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YAC3B,MAAM,IAAI,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC;YAEhD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACZ,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,IAAA,wBAAS,EAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC;YACxE,CAAC;YACD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACZ,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC9B,CAAC;YACD,MAAM,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAChC,CAAC;QAED,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAE7B,MAAM,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;QACtC,MAAM,IAAI,CAAC,KAAK,CAAC,iDAAiD,CAAC,CAAC;QACpE,MAAM,IAAI,CAAC,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACvE,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAE7B,MAAM,IAAI,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACxC,MAAM,IAAI,CAAC,KAAK,CAAC,iEAAiE,CAAC,CAAC;QACpF,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAE/B,MAAM,IAAI,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAC7C,MAAM,IAAI,CAAC,KAAK,CAAC,wDAAwD,CAAC,CAAC;QAC3E,MAAM,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAEpC,MAAM,IAAI,CAAC,KAAK,CAAC,mBAAmB,IAAI,CAAC,UAAU,CAAC,MAAM,IAAI,CAAC,CAAC;QAEhE,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClC,MAAM,KAAK,GAAG,aAAa,KAAK,CAAC,cAAc,aAAa,KAAK,CAAC,MAAM,yDAAyD,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,gBAAgB,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,qBAAqB,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;YAE5P,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;gBAClB,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,KAAK,GAAG,CAAC,CAAC;gBAClC,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;gBAC/B,IAAI,KAAK,CAAC,SAAS,CAAC,UAAU,EAAE,CAAC;oBAC7B,MAAM,IAAI,CAAC,KAAK,CAAC,gBAAgB,KAAK,CAAC,SAAS,CAAC,UAAU,GAAG,CAAC,CAAC;gBACpE,CAAC;gBACD,IAAI,KAAK,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;oBAC3B,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,KAAK,CAAC,SAAS,CAAC,QAAQ,GAAG,CAAC,CAAC;gBAChE,CAAC;gBACD,IAAI,KAAK,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;oBAC3B,MAAM,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;gBACtC,CAAC;gBACD,MAAM,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBACxB,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC9B,CAAC;iBACI,CAAC;gBACF,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,KAAK,KAAK,CAAC,CAAC;YACxC,CAAC;QACL,CAAC;QAED,MAAM,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAE/B,MAAM,IAAI,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC3C,MAAM,IAAI,CAAC,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACvE,MAAM,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;QAElC,MAAM,IAAI,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;QACvC,MAAM,IAAI,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;QAE9C,MAAM,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;QAElC,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;CACJ;AA5LD,4CA4LC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"XlsxThemeWriter.d.ts","sourceRoot":"","sources":["../../../src/stream-writer/XlsxThemeWriter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAErD,qBAAa,eAAgB,SAAQ,cAAc;IACzC,KAAK;CAgUd"}
|