igniteui-angular 14.2.0-alpha.3 → 14.2.0-beta.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.
@@ -1,4 +1,5 @@
1
1
  import { ExcelStrings } from './excel-strings';
2
+ import { strToU8 } from 'fflate';
2
3
  import { yieldingLoop } from '../../core/utils';
3
4
  import { HeaderType, ExportRecordType } from '../exporter-common/base-export-service';
4
5
  /**
@@ -6,7 +7,7 @@ import { HeaderType, ExportRecordType } from '../exporter-common/base-export-ser
6
7
  */
7
8
  export class RootRelsFile {
8
9
  writeElement(folder) {
9
- folder.file('.rels', ExcelStrings.getRels());
10
+ folder['.rels'] = strToU8(ExcelStrings.getRels());
10
11
  }
11
12
  }
12
13
  /**
@@ -14,7 +15,7 @@ export class RootRelsFile {
14
15
  */
15
16
  export class AppFile {
16
17
  writeElement(folder, worksheetData) {
17
- folder.file('app.xml', ExcelStrings.getApp(worksheetData.options.worksheetName));
18
+ folder['app.xml'] = strToU8(ExcelStrings.getApp(worksheetData.options.worksheetName));
18
19
  }
19
20
  }
20
21
  /**
@@ -22,7 +23,7 @@ export class AppFile {
22
23
  */
23
24
  export class CoreFile {
24
25
  writeElement(folder) {
25
- folder.file('core.xml', ExcelStrings.getCore());
26
+ folder['core.xml'] = strToU8(ExcelStrings.getCore());
26
27
  }
27
28
  }
28
29
  /**
@@ -31,7 +32,7 @@ export class CoreFile {
31
32
  export class WorkbookRelsFile {
32
33
  writeElement(folder, worksheetData) {
33
34
  const hasSharedStrings = !worksheetData.isEmpty || worksheetData.options.alwaysExportHeaders;
34
- folder.file('workbook.xml.rels', ExcelStrings.getWorkbookRels(hasSharedStrings));
35
+ folder['workbook.xml.rels'] = strToU8(ExcelStrings.getWorkbookRels(hasSharedStrings));
35
36
  }
36
37
  }
37
38
  /**
@@ -39,7 +40,7 @@ export class WorkbookRelsFile {
39
40
  */
40
41
  export class ThemeFile {
41
42
  writeElement(folder) {
42
- folder.file('theme1.xml', ExcelStrings.getTheme());
43
+ folder['theme1.xml'] = strToU8(ExcelStrings.getTheme());
43
44
  }
44
45
  }
45
46
  /**
@@ -48,12 +49,14 @@ export class ThemeFile {
48
49
  export class WorksheetFile {
49
50
  constructor() {
50
51
  this.maxOutlineLevel = 0;
52
+ this.sheetData = '';
51
53
  this.dimension = '';
52
54
  this.freezePane = '';
53
55
  this.rowHeight = '';
54
56
  this.mergeCellStr = '';
55
57
  this.mergeCellsCounter = 0;
56
58
  this.rowIndex = 0;
59
+ this.pivotGridRowHeadersMap = new Map();
57
60
  }
58
61
  writeElement() { }
59
62
  async writeElementAsync(folder, worksheetData) {
@@ -61,69 +64,55 @@ export class WorksheetFile {
61
64
  this.prepareDataAsync(worksheetData, (cols, rows) => {
62
65
  const hasTable = (!worksheetData.isEmpty || worksheetData.options.alwaysExportHeaders)
63
66
  && worksheetData.options.exportAsTable;
64
- folder.file('sheet1.xml', ExcelStrings.getSheetXML(this.dimension, this.freezePane, cols, rows, hasTable, this.maxOutlineLevel, worksheetData.isHierarchical));
67
+ folder['sheet1.xml'] = strToU8(ExcelStrings.getSheetXML(this.dimension, this.freezePane, cols, rows, hasTable, this.maxOutlineLevel, worksheetData.isHierarchical));
65
68
  resolve();
66
69
  });
67
70
  });
68
71
  }
69
72
  prepareDataAsync(worksheetData, done) {
70
- let sheetData = '';
73
+ this.sheetData = '';
71
74
  let cols = '';
72
75
  const dictionary = worksheetData.dataDictionary;
73
76
  this.rowIndex = 0;
74
77
  if (worksheetData.isEmpty && (!worksheetData.options.alwaysExportHeaders || worksheetData.owner.columns.length === 0)) {
75
- sheetData += '<sheetData/>';
78
+ this.sheetData += '<sheetData/>';
76
79
  this.dimension = 'A1';
77
- done('', sheetData);
80
+ done('', this.sheetData);
78
81
  }
79
82
  else {
80
83
  const owner = worksheetData.owner;
81
84
  const isHierarchicalGrid = worksheetData.isHierarchical;
82
85
  const hasMultiColumnHeader = worksheetData.hasMultiColumnHeader;
86
+ const hasMultiRowHeader = worksheetData.hasMultiRowHeader;
83
87
  const hasUserSetIndex = owner.columns.some(col => col.exportIndex !== undefined);
84
88
  const height = worksheetData.options.rowHeight;
85
- const rowStyle = isHierarchicalGrid ? ' s="3"' : '';
86
89
  this.rowHeight = height ? ` ht="${height}" customHeight="1"` : '';
87
- sheetData += `<sheetData>`;
90
+ this.sheetData += `<sheetData>`;
91
+ let headersForLevel = [];
92
+ for (let i = 0; i <= owner.maxRowLevel; i++) {
93
+ headersForLevel = owner.columns.filter(c => c.level === i && c.rowSpan > 0 && !c.skip);
94
+ this.printHeaders(worksheetData, headersForLevel, i, true);
95
+ this.rowIndex++;
96
+ }
97
+ this.rowIndex = 0;
88
98
  for (let i = 0; i <= owner.maxLevel; i++) {
89
99
  this.rowIndex++;
90
- sheetData += `<row r="${this.rowIndex}"${this.rowHeight}>`;
91
- const headersForLevel = hasMultiColumnHeader ?
92
- owner.columns
100
+ const pivotGridColumns = this.pivotGridRowHeadersMap.get(this.rowIndex) ?? "";
101
+ this.sheetData += `<row r="${this.rowIndex}"${this.rowHeight}>${pivotGridColumns}`;
102
+ const allowedColumns = owner.columns.filter(c => c.headerType !== HeaderType.RowHeader && c.headerType !== HeaderType.MultiRowHeader);
103
+ headersForLevel = hasMultiColumnHeader ?
104
+ allowedColumns
93
105
  .filter(c => (c.level < i &&
94
106
  c.headerType !== HeaderType.MultiColumnHeader || c.level === i) && c.columnSpan > 0 && !c.skip)
95
107
  .sort((a, b) => a.startIndex - b.startIndex)
96
108
  .sort((a, b) => a.pinnedIndex - b.pinnedIndex) :
97
109
  hasUserSetIndex ?
98
- owner.columns.filter(c => !c.skip) :
99
- owner.columns.filter(c => !c.skip)
110
+ allowedColumns.filter(c => !c.skip) :
111
+ allowedColumns.filter(c => !c.skip)
100
112
  .sort((a, b) => a.startIndex - b.startIndex)
101
113
  .sort((a, b) => a.pinnedIndex - b.pinnedIndex);
102
- let startValue = 0;
103
- for (const currentCol of headersForLevel) {
104
- if (currentCol.level === i) {
105
- let columnCoordinate;
106
- columnCoordinate = ExcelStrings.getExcelColumn(startValue) + this.rowIndex;
107
- const columnValue = dictionary.saveValue(currentCol.header, true);
108
- sheetData += `<c r="${columnCoordinate}"${rowStyle} t="s"><v>${columnValue}</v></c>`;
109
- if (i !== owner.maxLevel) {
110
- this.mergeCellsCounter++;
111
- this.mergeCellStr += ` <mergeCell ref="${columnCoordinate}:`;
112
- if (currentCol.headerType === HeaderType.ColumnHeader) {
113
- columnCoordinate = ExcelStrings.getExcelColumn(startValue) + (owner.maxLevel + 1);
114
- }
115
- else {
116
- for (let k = 1; k < currentCol.columnSpan; k++) {
117
- columnCoordinate = ExcelStrings.getExcelColumn(startValue + k) + this.rowIndex;
118
- sheetData += `<c r="${columnCoordinate}"${rowStyle} />`;
119
- }
120
- }
121
- this.mergeCellStr += `${columnCoordinate}" />`;
122
- }
123
- }
124
- startValue += currentCol.columnSpan;
125
- }
126
- sheetData += `</row>`;
114
+ this.printHeaders(worksheetData, headersForLevel, i, false);
115
+ this.sheetData += `</row>`;
127
116
  }
128
117
  const multiColumnHeaderLevel = worksheetData.options.ignoreMultiColumnHeaders ? 0 : owner.maxLevel;
129
118
  const freezeHeaders = worksheetData.options.freezeHeaders ? 2 + multiColumnHeaderLevel : 1;
@@ -176,12 +165,12 @@ export class WorksheetFile {
176
165
  }
177
166
  }
178
167
  this.processDataRecordsAsync(worksheetData, (rows) => {
179
- sheetData += rows;
180
- sheetData += '</sheetData>';
181
- if (hasMultiColumnHeader && this.mergeCellsCounter > 0) {
182
- sheetData += `<mergeCells count="${this.mergeCellsCounter}">${this.mergeCellStr}</mergeCells>`;
168
+ this.sheetData += rows;
169
+ this.sheetData += '</sheetData>';
170
+ if ((hasMultiColumnHeader || hasMultiRowHeader) && this.mergeCellsCounter > 0) {
171
+ this.sheetData += `<mergeCells count="${this.mergeCellsCounter}">${this.mergeCellStr}</mergeCells>`;
183
172
  }
184
- done(cols, sheetData);
173
+ done(cols, this.sheetData);
185
174
  });
186
175
  }
187
176
  }
@@ -200,7 +189,7 @@ export class WorksheetFile {
200
189
  }
201
190
  else {
202
191
  recordHeaders = worksheetData.owner.columns
203
- .filter(c => c.headerType !== HeaderType.MultiColumnHeader && !c.skip)
192
+ .filter(c => c.headerType !== HeaderType.MultiColumnHeader && c.headerType !== HeaderType.MultiRowHeader && c.headerType !== HeaderType.RowHeader && !c.skip)
204
193
  .sort((a, b) => a.startIndex - b.startIndex)
205
194
  .sort((a, b) => a.pinnedIndex - b.pinnedIndex)
206
195
  .map(c => c.field);
@@ -274,11 +263,12 @@ export class WorksheetFile {
274
263
  this.maxOutlineLevel = this.maxOutlineLevel < rowLevel ? rowLevel : this.maxOutlineLevel;
275
264
  const sHidden = record.hidden ? ` hidden="1"` : '';
276
265
  this.rowIndex++;
266
+ const pivotGridColumns = this.pivotGridRowHeadersMap.get(this.rowIndex) ?? "";
277
267
  rowData[0] =
278
- `<row r="${this.rowIndex}"${this.rowHeight}${outlineLevel}${sHidden}>`;
268
+ `<row r="${this.rowIndex}"${this.rowHeight}${outlineLevel}${sHidden}>${pivotGridColumns}`;
279
269
  const keys = worksheetData.isSpecialData ? [record.data] : headersForLevel;
280
270
  for (let j = 0; j < keys.length; j++) {
281
- const col = j + (isHierarchicalGrid ? rowLevel : 0);
271
+ const col = j + (isHierarchicalGrid ? rowLevel : worksheetData.isPivotGrid ? worksheetData.owner.maxRowLevel : 0);
282
272
  const cellData = this.getCellData(worksheetData, i, col, keys[j]);
283
273
  rowData[j + 1] = cellData;
284
274
  }
@@ -311,6 +301,74 @@ export class WorksheetFile {
311
301
  return `<c r="${columnName}"${type}${format}><v>${value}</v></c>`;
312
302
  }
313
303
  }
304
+ printHeaders(worksheetData, headersForLevel, i, isVertical) {
305
+ let startValue = 0;
306
+ let str = '';
307
+ const isHierarchicalGrid = worksheetData.isHierarchical;
308
+ let rowStyle = isHierarchicalGrid ? ' s="3"' : '';
309
+ const dictionary = worksheetData.dataDictionary;
310
+ const owner = worksheetData.owner;
311
+ const maxLevel = isVertical
312
+ ? owner.maxRowLevel
313
+ : owner.maxLevel;
314
+ for (const currentCol of headersForLevel) {
315
+ const spanLength = isVertical ? currentCol.rowSpan : currentCol.columnSpan;
316
+ if (currentCol.level === i) {
317
+ let columnCoordinate;
318
+ const column = isVertical
319
+ ? this.rowIndex
320
+ : startValue + (owner.maxRowLevel ?? 0);
321
+ const rowCoordinate = isVertical
322
+ ? startValue + owner.maxLevel + 2
323
+ : this.rowIndex;
324
+ const columnValue = dictionary.saveValue(currentCol.header, true);
325
+ columnCoordinate = ExcelStrings.getExcelColumn(column) + rowCoordinate;
326
+ rowStyle = isVertical && currentCol.rowSpan > 1 ? ' s="4"' : rowStyle;
327
+ str = `<c r="${columnCoordinate}"${rowStyle} t="s"><v>${columnValue}</v></c>`;
328
+ if (isVertical) {
329
+ if (this.pivotGridRowHeadersMap.has(rowCoordinate)) {
330
+ this.pivotGridRowHeadersMap.set(rowCoordinate, this.pivotGridRowHeadersMap.get(rowCoordinate) + str);
331
+ }
332
+ else {
333
+ this.pivotGridRowHeadersMap.set(rowCoordinate, str);
334
+ }
335
+ }
336
+ else {
337
+ this.sheetData += str;
338
+ }
339
+ if (i !== maxLevel) {
340
+ this.mergeCellsCounter++;
341
+ this.mergeCellStr += ` <mergeCell ref="${columnCoordinate}:`;
342
+ if (currentCol.headerType === HeaderType.ColumnHeader) {
343
+ const col = isVertical
344
+ ? maxLevel
345
+ : startValue + (owner.maxRowLevel ?? 0);
346
+ const row = isVertical
347
+ ? rowCoordinate
348
+ : owner.maxLevel + 1;
349
+ columnCoordinate = ExcelStrings.getExcelColumn(col) + row;
350
+ }
351
+ else {
352
+ for (let k = 1; k < spanLength; k++) {
353
+ const col = isVertical
354
+ ? column
355
+ : column + k;
356
+ const row = isVertical
357
+ ? rowCoordinate + k
358
+ : this.rowIndex;
359
+ columnCoordinate = ExcelStrings.getExcelColumn(col) + row;
360
+ str = `<c r="${columnCoordinate}"${rowStyle} />`;
361
+ isVertical
362
+ ? this.pivotGridRowHeadersMap.set(row, str)
363
+ : this.sheetData += str;
364
+ }
365
+ }
366
+ this.mergeCellStr += `${columnCoordinate}" />`;
367
+ }
368
+ }
369
+ startValue += spanLength;
370
+ }
371
+ }
314
372
  }
315
373
  WorksheetFile.MIN_WIDTH = 8.43;
316
374
  /**
@@ -318,7 +376,7 @@ WorksheetFile.MIN_WIDTH = 8.43;
318
376
  */
319
377
  export class StyleFile {
320
378
  writeElement(folder) {
321
- folder.file('styles.xml', ExcelStrings.getStyles());
379
+ folder['styles.xml'] = strToU8(ExcelStrings.getStyles());
322
380
  }
323
381
  }
324
382
  /**
@@ -326,7 +384,7 @@ export class StyleFile {
326
384
  */
327
385
  export class WorkbookFile {
328
386
  writeElement(folder, worksheetData) {
329
- folder.file('workbook.xml', ExcelStrings.getWorkbook(worksheetData.options.worksheetName));
387
+ folder['workbook.xml'] = strToU8(ExcelStrings.getWorkbook(worksheetData.options.worksheetName));
330
388
  }
331
389
  }
332
390
  /**
@@ -335,7 +393,7 @@ export class WorkbookFile {
335
393
  export class ContentTypesFile {
336
394
  writeElement(folder, worksheetData) {
337
395
  const hasSharedStrings = !worksheetData.isEmpty || worksheetData.options.alwaysExportHeaders;
338
- folder.file('[Content_Types].xml', ExcelStrings.getContentTypesXML(hasSharedStrings, worksheetData.options.exportAsTable));
396
+ folder['[Content_Types].xml'] = strToU8(ExcelStrings.getContentTypesXML(hasSharedStrings, worksheetData.options.exportAsTable));
339
397
  }
340
398
  }
341
399
  /**
@@ -349,7 +407,7 @@ export class SharedStringsFile {
349
407
  for (const value of sortedValues) {
350
408
  sharedStrings[dict.getSanitizedValue(value)] = '<si><t>' + value + '</t></si>';
351
409
  }
352
- folder.file('sharedStrings.xml', ExcelStrings.getSharedStringXML(dict.stringsCount, sortedValues.length, sharedStrings.join('')));
410
+ folder['sharedStrings.xml'] = strToU8(ExcelStrings.getSharedStringXML(dict.stringsCount, sortedValues.length, sharedStrings.join('')));
353
411
  }
354
412
  }
355
413
  /**
@@ -384,7 +442,7 @@ export class TablesFile {
384
442
  const dir = sortingExpression.dir - 1;
385
443
  sortString = `<sortState ref="A2:${lastColumn}"><sortCondition descending="${dir}" ref="${sc}1:${sc}15"/></sortState>`;
386
444
  }
387
- folder.file('table1.xml', ExcelStrings.getTablesXML(autoFilterDimension, tableDimension, tableColumns, sortString));
445
+ folder['table1.xml'] = strToU8(ExcelStrings.getTablesXML(autoFilterDimension, tableDimension, tableColumns, sortString));
388
446
  }
389
447
  }
390
448
  /**
@@ -392,7 +450,7 @@ export class TablesFile {
392
450
  */
393
451
  export class WorksheetRelsFile {
394
452
  writeElement(folder) {
395
- folder.file('sheet1.xml.rels', ExcelStrings.getWorksheetRels());
453
+ folder['sheet1.xml.rels'] = strToU8(ExcelStrings.getWorksheetRels());
396
454
  }
397
455
  }
398
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-files.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/services/excel/excel-files.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAI/C,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAA8B,MAAM,wCAAwC,CAAC;AAElH;;GAEG;AACH,MAAM,OAAO,YAAY;IACd,YAAY,CAAC,MAAa;QAC7B,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC;IACjD,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,OAAO;IACT,YAAY,CAAC,MAAa,EAAE,aAA4B;QAC3D,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,YAAY,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC;IACrF,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,QAAQ;IACV,YAAY,CAAC,MAAa;QAC7B,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC;IACpD,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,gBAAgB;IAClB,YAAY,CAAC,MAAa,EAAE,aAA4B;QAC3D,MAAM,gBAAgB,GAAG,CAAC,aAAa,CAAC,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,mBAAmB,CAAC;QAC7F,MAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE,YAAY,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACrF,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,SAAS;IACX,YAAY,CAAC,MAAa;QAC7B,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,QAAQ,EAAE,CAAC,CAAC;IACvD,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,aAAa;IAA1B;QAEY,oBAAe,GAAG,CAAC,CAAC;QACpB,cAAS,GAAG,EAAE,CAAC;QACf,eAAU,GAAG,EAAE,CAAC;QAChB,cAAS,GAAG,EAAE,CAAC;QAEf,iBAAY,GAAG,EAAE,CAAC;QAClB,sBAAiB,GAAG,CAAC,CAAC;QACtB,aAAQ,GAAG,CAAC,CAAC;IA6TzB,CAAC;IA3TU,YAAY,KAAI,CAAC;IAEjB,KAAK,CAAC,iBAAiB,CAAC,MAAa,EAAE,aAA4B;QACtE,OAAO,IAAI,OAAO,CAAO,OAAO,CAAC,EAAE;YAC/B,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;gBAChD,MAAM,QAAQ,GAAG,CAAC,CAAC,aAAa,CAAC,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,mBAAmB,CAAC;uBAC/E,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC;gBAE3C,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,WAAW,CAC9C,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC;gBAChH,OAAO,EAAE,CAAC;YACd,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,gBAAgB,CAAC,aAA4B,EAAE,IAA+C;QAClG,IAAI,SAAS,GAAG,EAAE,CAAC;QACnB,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,MAAM,UAAU,GAAG,aAAa,CAAC,cAAc,CAAC;QAChD,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;QAElB,IAAI,aAAa,CAAC,OAAO,IAAI,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,mBAAmB,IAAI,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,CAAC,EAAE;YACnH,SAAS,IAAI,cAAc,CAAC;YAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;SACvB;aAAM;YACH,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC;YAClC,MAAM,kBAAkB,GAAG,aAAa,CAAC,cAAc,CAAC;YACxD,MAAM,oBAAoB,GAAG,aAAa,CAAC,oBAAoB,CAAC;YAEhE,MAAM,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC;YAEjF,MAAM,MAAM,GAAI,aAAa,CAAC,OAAO,CAAC,SAAS,CAAC;YAChD,MAAM,QAAQ,GAAG,kBAAkB,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;YACpD,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,CAAC,CAAC,QAAQ,MAAM,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC;YAElE,SAAS,IAAI,aAAa,CAAC;YAE3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE;gBACtC,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAChB,SAAS,IAAI,WAAW,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC;gBAE3D,MAAM,eAAe,GAAG,oBAAoB,CAAC,CAAC;oBAC1C,KAAK,CAAC,OAAO;yBACR,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;wBACrB,CAAC,CAAC,UAAU,KAAK,UAAU,CAAC,iBAAiB,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;yBAClG,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC;yBAC3C,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC;oBACpD,eAAe,CAAC,CAAC;wBACb,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;wBACpC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;6BAC7B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC;6BAC3C,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC;gBAE3D,IAAI,UAAU,GAAG,CAAC,CAAC;gBAEnB,KAAK,MAAM,UAAU,IAAI,eAAe,EAAE;oBACtC,IAAI,UAAU,CAAC,KAAK,KAAK,CAAC,EAAE;wBACxB,IAAI,gBAAgB,CAAC;wBACrB,gBAAgB,GAAG,YAAY,CAAC,cAAc,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;wBAC3E,MAAM,WAAW,GAAG,UAAU,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;wBAClE,SAAS,IAAI,SAAS,gBAAgB,IAAI,QAAQ,aAAa,WAAW,UAAU,CAAC;wBAErF,IAAI,CAAC,KAAK,KAAK,CAAC,QAAQ,EAAE;4BACtB,IAAI,CAAC,iBAAiB,EAAE,CAAC;4BACzB,IAAI,CAAC,YAAY,IAAI,oBAAoB,gBAAgB,GAAG,CAAC;4BAE7D,IAAI,UAAU,CAAC,UAAU,KAAK,UAAU,CAAC,YAAY,EAAE;gCACnD,gBAAgB,GAAG,YAAY,CAAC,cAAc,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;6BACrF;iCAAM;gCACH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE;oCAC5C,gBAAgB,GAAG,YAAY,CAAC,cAAc,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;oCAC/E,SAAS,IAAI,SAAS,gBAAgB,IAAI,QAAQ,KAAK,CAAC;iCAC3D;6BACJ;4BAED,IAAI,CAAC,YAAY,IAAI,GAAG,gBAAgB,MAAM,CAAC;yBAClD;qBACJ;oBAED,UAAU,IAAI,UAAU,CAAC,UAAU,CAAC;iBACvC;gBAED,SAAS,IAAI,QAAQ,CAAC;aACzB;YAED,MAAM,sBAAsB,GAAG,aAAa,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;YACnG,MAAM,aAAa,GAAG,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,GAAG,sBAAsB,CAAC,CAAC,CAAC,CAAC,CAAC;YAE3F,IAAI,CAAC,kBAAkB,EAAE;gBACrB,IAAI,CAAC,SAAS;oBACV,KAAK,GAAG,YAAY,CAAC,cAAc,CAAC,aAAa,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBAElG,IAAI,IAAI,QAAQ,CAAC;gBAEjB,IAAI,CAAC,oBAAoB,EAAE;oBACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,WAAW,EAAE,CAAC,EAAE,EAAE;wBAChD,MAAM,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;wBACzC,qDAAqD;wBACrD,IAAI,YAAY,GAAG,aAAa,CAAC,OAAO,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC;4BAC5C,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;4BACnC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,aAAa,CAAC,SAAS,CAAC,CAAC;wBACjF,IAAI,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC,EAAE;4BACrB,YAAY,GAAG,aAAa,CAAC,SAAS,CAAC;yBAC1C;wBAED,IAAI,IAAI,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,YAAY,YAAY,qBAAqB,CAAC;qBAC9F;iBACJ;qBAAM;oBACH,IAAI,IAAI,qBAAqB,aAAa,CAAC,WAAW,gCAAgC,CAAC;iBAC1F;gBAED,IAAI,IAAI,SAAS,CAAC;gBAElB,MAAM,uBAAuB,GAAG,aAAa,CAAC,uBAAuB,CAAC;gBACtE,MAAM,iBAAiB,GAAG,uBAAuB,GAAG,CAAC,CAAC;gBACtD,IAAI,SAAS,GAAG,YAAY,CAAC,cAAc,CAAC,iBAAiB,CAAC,GAAG,aAAa,CAAC;gBAC/E,IAAI,uBAAuB,KAAK,SAAS,IAAI,uBAAuB,KAAK,CAAC,CAAC;oBACvE,CAAC,aAAa,CAAC,OAAO,CAAC,aAAa;oBACpC,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,EAAE;oBAC3C,IAAI,CAAC,UAAU;wBACX,iBAAiB,iBAAiB,aAAa,aAAa,GAAG,CAAC;wCAChD,SAAS,0CAA0C,CAAC;iBAC3E;qBAAM,IAAI,aAAa,CAAC,OAAO,CAAC,aAAa,EAAE;oBAC5C,SAAS,GAAG,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC;oBAC3D,IAAI,CAAC,UAAU;wBACX,4BAA4B,aAAa,GAAG,CAAC;wCAC7B,SAAS,0CAA0C,CAAC;iBAC3E;aACJ;iBAAM;gBACH,MAAM,WAAW,GAAG,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC/F,IAAI,IAAI,2BAA2B,aAAa,CAAC,WAAW,YAAY,WAAW,4BAA4B,CAAC;gBAChH,IAAI,aAAa,CAAC,OAAO,CAAC,aAAa,EAAE;oBACrC,MAAM,SAAS,GAAG,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC;oBACjE,IAAI,CAAC,UAAU;wBACX,4BAA4B,aAAa,GAAG,CAAC;wCAC7B,SAAS,0CAA0C,CAAC;iBAC3E;aACJ;YAED,IAAI,CAAC,uBAAuB,CAAC,aAAa,EAAE,CAAC,IAAI,EAAE,EAAE;gBACjD,SAAS,IAAI,IAAI,CAAC;gBAClB,SAAS,IAAI,cAAc,CAAC;gBAE5B,IAAI,oBAAoB,IAAI,IAAI,CAAC,iBAAiB,GAAG,CAAC,EAAE;oBACpD,SAAS,IAAI,sBAAsB,IAAI,CAAC,iBAAiB,KAAK,IAAI,CAAC,YAAY,eAAe,CAAC;iBAClG;gBAED,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;YAC1B,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAEO,uBAAuB,CAAC,aAA4B,EAAE,IAA4B;QACtF,MAAM,UAAU,GAAG,EAAE,CAAC;QACtB,MAAM,MAAM,GAAI,aAAa,CAAC,OAAO,CAAC,SAAS,CAAC;QAChD,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,CAAC,CAAC,OAAO,GAAG,MAAM,GAAG,oBAAoB,CAAC,CAAC,CAAC,EAAE,CAAC;QAEvE,MAAM,kBAAkB,GAAG,aAAa,CAAC,cAAc,CAAC;QACxD,MAAM,eAAe,GAAG,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC;QAE3F,IAAI,aAAa,GAAG,EAAE,CAAC;QAEvB,YAAY,CAAC,aAAa,CAAC,QAAQ,GAAG,aAAa,CAAC,qBAAqB,GAAG,CAAC,EAAE,IAAI,EAC/E,CAAC,CAAC,EAAE,EAAE;YACF,IAAI,CAAC,aAAa,CAAC,OAAO,EAAC;gBACvB,IAAI,CAAC,kBAAkB,EAAE;oBACrB,IAAI,eAAe,EAAE;wBACjB,aAAa,GAAG,aAAa,CAAC,QAAQ,CAAC;qBAC1C;yBAAM;wBACH,aAAa,GAAG,aAAa,CAAC,KAAK,CAAC,OAAO;6BACtC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,UAAU,CAAC,iBAAiB,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;6BACrE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,GAAC,CAAC,CAAC,UAAU,CAAC;6BACzC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,GAAC,CAAC,CAAC,WAAW,CAAC;6BAC3C,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;qBAC1B;iBACJ;qBAAM;oBACH,MAAM,MAAM,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBAErC,IAAI,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC,YAAY,EAAE;wBAC/C,MAAM,WAAW,GAAG,aAAa,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;wBAC3D,MAAM,qBAAqB,GAAG,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,UAAU,KAAK,UAAU,CAAC,iBAAiB,CAAC,CAAC;wBAEtH,IAAI,qBAAqB,EAAE;4BACvB,IAAI,CAAC,yBAAyB,CAAC,aAAa,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;yBAClF;qBACJ;oBAED,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;iBAC3D;gBAED,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC,EAAE,aAAa,EAAE,kBAAkB,CAAC,CAAC,CAAC;aACzF;QACL,CAAC,EACD,GAAG,EAAE;YACD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,yBAAyB,CAAC,aAA4B,EAAE,UAAiB,EAAE,MAAqB,EACpG,KAAkB;QAClB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,EAAE,EAAE;YACrC,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC;YACjC,MAAM,YAAY,GAAG,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC,kBAAkB,WAAW,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;YAC7E,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC;YAC/F,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC;YAEnD,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,IAAI,GAAG,GAAG,WAAW,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,GAAG,YAAY,GAAG,OAAO,GAAG,CAAC;YAEjF,MAAM,eAAe,GAAG,KAAK,CAAC,OAAO;iBAChC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;gBACrB,CAAC,CAAC,UAAU,KAAK,UAAU,CAAC,iBAAiB,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;iBAClG,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC;iBAC3C,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC;YAEnD,IAAI,UAAU,GAAG,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC;YAElC,KAAK,MAAM,UAAU,IAAI,eAAe,EAAE;gBACtC,IAAI,UAAU,CAAC,KAAK,KAAK,CAAC,EAAE;oBACxB,IAAI,gBAAgB,CAAC;oBACrB,gBAAgB;wBACZ,YAAY,CAAC,cAAc,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;oBAE5D,MAAM,WAAW,GAAG,aAAa,CAAC,cAAc,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;oBACpF,GAAG,IAAI,SAAS,gBAAgB,oBAAoB,WAAW,UAAU,CAAC;oBAE1E,IAAI,CAAC,KAAK,KAAK,CAAC,QAAQ,EAAE;wBACtB,IAAI,CAAC,iBAAiB,EAAE,CAAC;wBACzB,IAAI,CAAC,YAAY,IAAI,oBAAoB,gBAAgB,GAAG,CAAC;wBAE7D,IAAI,UAAU,CAAC,UAAU,KAAK,UAAU,CAAC,YAAY,EAAE;4BACnD,gBAAgB,GAAG,YAAY,CAAC,cAAc,CAAC,UAAU,CAAC;gCACtD,CAAC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC;yBAC3D;6BAAM;4BACH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE;gCAC5C,gBAAgB,GAAG,YAAY,CAAC,cAAc,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;gCAC/E,GAAG,IAAI,SAAS,gBAAgB,YAAY,CAAC;6BAChD;yBACJ;wBAED,IAAI,CAAC,YAAY,IAAI,GAAG,gBAAgB,MAAM,CAAC;qBAClD;iBACJ;gBAED,UAAU,IAAI,UAAU,CAAC,UAAU,CAAC;aACvC;YACD,GAAG,IAAI,QAAQ,CAAC;YAChB,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACxB;IACL,CAAC;IAEO,UAAU,CAAC,aAA4B,EAAE,CAAS,EAAE,eAAsB,EAAE,kBAA2B;QAC3G,MAAM,MAAM,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAErC,MAAM,OAAO,GAAG,IAAI,KAAK,CAAC,aAAa,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC;QAEzD,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC;QAC9B,MAAM,YAAY,GAAG,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,kBAAkB,QAAQ,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QACvE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,GAAG,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC;QAEzF,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC;QAEnD,IAAI,CAAC,QAAQ,EAAE,CAAC;QAChB,OAAO,CAAC,CAAC,CAAC;YACN,WAAW,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,GAAG,YAAY,GAAG,OAAO,GAAG,CAAC;QAE3E,MAAM,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC;QAE3E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAClC,MAAM,GAAG,GAAG,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAEpD,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YAElE,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC;SAC7B;QAED,OAAO,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC;QAEpC,OAAO,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;IAEO,WAAW,CAAC,aAA4B,EAAE,GAAW,EAAE,MAAc,EAAE,GAAW;QACtF,MAAM,UAAU,GAAG,aAAa,CAAC,cAAc,CAAC;QAChD,MAAM,UAAU,GAAG,YAAY,CAAC,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzE,MAAM,OAAO,GAAG,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACxC,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,KAAK,gBAAgB,CAAC,YAAY,CAAC;QAEtE,MAAM,SAAS,GAAG,aAAa,CAAC,aAAa,CAAC,CAAC;YAC3C,OAAO,CAAC,IAAI,CAAC,CAAC;YACd,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEtB,IAAI,SAAS,KAAK,SAAS,IAAI,SAAS,KAAK,IAAI,EAAE;YAC/C,OAAO,SAAS,UAAU,WAAW,CAAC;SACzC;aAAM;YACH,MAAM,UAAU,GAAG,UAAU,CAAC,SAAS,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC;YACnE,MAAM,eAAe,GAAG,UAAU,KAAK,CAAC,CAAC,CAAC;YAE1C,MAAM,aAAa,GAAG,CAAC,eAAe,IAAI,SAAS,YAAY,IAAI,CAAC;YAEpE,IAAI,KAAK,GAAG,eAAe,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;YAErD,IAAI,aAAa,EAAE;gBACf,MAAM,cAAc,GAAG,KAAK,CAAC,iBAAiB,EAAE,GAAG,KAAK,CAAC;gBACzD,MAAM,SAAS,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,GAAG,cAAc,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBACnE,KAAK,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;aAC1D;YAED,MAAM,IAAI,GAAG,eAAe,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;YAExE,MAAM,MAAM,GAAG,cAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC;YAEtG,OAAO,SAAS,UAAU,IAAI,IAAI,GAAG,MAAM,OAAO,KAAK,UAAU,CAAC;SACrE;IACL,CAAC;;AApUc,uBAAS,GAAG,IAAI,CAAC;AAuUpC;;GAEG;AACH,MAAM,OAAO,SAAS;IACX,YAAY,CAAC,MAAa;QAC7B,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,SAAS,EAAE,CAAC,CAAC;IACxD,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,YAAY;IACd,YAAY,CAAC,MAAa,EAAE,aAA4B;QAC3D,MAAM,CAAC,IAAI,CAAC,cAAc,EAAE,YAAY,CAAC,WAAW,CAAC,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC;IAC/F,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,gBAAgB;IAClB,YAAY,CAAC,MAAa,EAAE,aAA4B;QAC3D,MAAM,gBAAgB,GAAG,CAAC,aAAa,CAAC,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,mBAAmB,CAAC;QAC7F,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE,YAAY,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC;IAC/H,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,iBAAiB;IACnB,YAAY,CAAC,MAAa,EAAE,aAA4B;QAC3D,MAAM,IAAI,GAAG,aAAa,CAAC,cAAc,CAAC;QAC1C,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QACpC,MAAM,aAAa,GAAG,IAAI,KAAK,CAAS,YAAY,CAAC,MAAM,CAAC,CAAC;QAE7D,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE;YAC9B,aAAa,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,GAAG,SAAS,GAAG,KAAK,GAAG,WAAW,CAAC;SAClF;QAED,MAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE,YAAY,CAAC,kBAAkB,CAChD,IAAI,CAAC,YAAY,EACjB,YAAY,CAAC,MAAM,EACnB,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAC1B,CAAC;IAClB,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,UAAU;IACZ,YAAY,CAAC,MAAa,EAAE,aAA4B;QAC3D,MAAM,WAAW,GAAG,aAAa,CAAC,WAAW,CAAC;QAC9C,MAAM,UAAU,GAAG,YAAY,CAAC,cAAc,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,aAAa,CAAC,QAAQ,CAAC;QACzF,MAAM,mBAAmB,GAAG,KAAK,GAAG,UAAU,CAAC;QAC/C,MAAM,cAAc,GAAG,aAAa,CAAC,OAAO;YACxC,CAAC,CAAC,KAAK,GAAG,YAAY,CAAC,cAAc,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,CAAC,aAAa,CAAC,QAAQ,GAAG,CAAC,CAAC;YACrF,CAAC,CAAC,mBAAmB,CAAC;QAC1B,MAAM,eAAe,GAAG,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC;QAC3F,MAAM,MAAM,GAAG,eAAe;YAC1B,CAAC,CAAC,aAAa,CAAC,QAAQ;YACxB,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO;iBACxB,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;iBACpB,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC;iBAC3C,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC;iBAC7C,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAE5B,IAAI,UAAU,GAAG,EAAE,CAAC;QAEpB,IAAI,YAAY,GAAG,uBAAuB,GAAG,WAAW,GAAG,IAAI,CAAC;QAChE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,EAAE,CAAC,EAAE,EAAE;YAClC,MAAM,KAAK,GAAI,MAAM,CAAC,CAAC,CAAC,CAAC;YACzB,YAAY,IAAI,mBAAmB,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,UAAU,GAAG,KAAK,GAAG,KAAK,CAAC;SAC9E;QAED,YAAY,IAAI,iBAAiB,CAAC;QAElC,IAAI,aAAa,CAAC,IAAI,EAAE;YACpB,MAAM,iBAAiB,GAAG,aAAa,CAAC,IAAI,CAAC;YAC7C,MAAM,EAAE,GAAG,YAAY,CAAC,cAAc,CAAC,MAAM,CAAC,OAAO,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC;YACpF,MAAM,GAAG,GAAG,iBAAiB,CAAC,GAAG,GAAG,CAAC,CAAC;YACtC,UAAU,GAAG,sBAAsB,UAAU,gCAAgC,GAAG,UAAU,EAAE,KAAK,EAAE,mBAAmB,CAAC;SAC1H;QAED,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,YAAY,CAAC,mBAAmB,EAAE,cAAc,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC,CAAC;IACxH,CAAC;CACJ;AAED;;GAEG;AACH,MAAM,OAAO,iBAAiB;IACnB,YAAY,CAAC,MAAa;QAC7B,MAAM,CAAC,IAAI,CAAC,iBAAiB,EAAE,YAAY,CAAC,gBAAgB,EAAE,CAAC,CAAC;IACpE,CAAC;CACJ","sourcesContent":["import { IExcelFile } from './excel-interfaces';\nimport { ExcelStrings } from './excel-strings';\nimport { WorksheetData } from './worksheet-data';\n\nimport * as JSZip from 'jszip';\nimport { yieldingLoop } from '../../core/utils';\nimport { HeaderType, ExportRecordType, IExportRecord, IColumnList } from '../exporter-common/base-export-service';\n\n/**\n * @hidden\n */\nexport class RootRelsFile implements IExcelFile {\n    public writeElement(folder: JSZip) {\n        folder.file('.rels', ExcelStrings.getRels());\n    }\n}\n\n/**\n * @hidden\n */\nexport class AppFile implements IExcelFile {\n    public writeElement(folder: JSZip, worksheetData: WorksheetData) {\n        folder.file('app.xml', ExcelStrings.getApp(worksheetData.options.worksheetName));\n    }\n}\n\n/**\n * @hidden\n */\nexport class CoreFile implements IExcelFile {\n    public writeElement(folder: JSZip) {\n        folder.file('core.xml', ExcelStrings.getCore());\n    }\n}\n\n/**\n * @hidden\n */\nexport class WorkbookRelsFile implements IExcelFile {\n    public writeElement(folder: JSZip, worksheetData: WorksheetData) {\n        const hasSharedStrings = !worksheetData.isEmpty || worksheetData.options.alwaysExportHeaders;\n        folder.file('workbook.xml.rels', ExcelStrings.getWorkbookRels(hasSharedStrings));\n    }\n}\n\n/**\n * @hidden\n */\nexport class ThemeFile implements IExcelFile {\n    public writeElement(folder: JSZip) {\n        folder.file('theme1.xml', ExcelStrings.getTheme());\n    }\n}\n\n/**\n * @hidden\n */\nexport class WorksheetFile implements IExcelFile {\n    private static MIN_WIDTH = 8.43;\n    private maxOutlineLevel = 0;\n    private dimension = '';\n    private freezePane = '';\n    private rowHeight = '';\n\n    private mergeCellStr = '';\n    private mergeCellsCounter = 0;\n    private rowIndex = 0;\n\n    public writeElement() {}\n\n    public async writeElementAsync(folder: JSZip, worksheetData: WorksheetData) {\n        return new Promise<void>(resolve => {\n            this.prepareDataAsync(worksheetData, (cols, rows) => {\n                const hasTable = (!worksheetData.isEmpty || worksheetData.options.alwaysExportHeaders)\n                    && worksheetData.options.exportAsTable;\n\n                folder.file('sheet1.xml', ExcelStrings.getSheetXML(\n                    this.dimension, this.freezePane, cols, rows, hasTable, this.maxOutlineLevel, worksheetData.isHierarchical));\n                resolve();\n            });\n        });\n    }\n\n    private prepareDataAsync(worksheetData: WorksheetData, done: (cols: string, sheetData: string) => void) {\n        let sheetData = '';\n        let cols = '';\n        const dictionary = worksheetData.dataDictionary;\n        this.rowIndex = 0;\n\n        if (worksheetData.isEmpty && (!worksheetData.options.alwaysExportHeaders || worksheetData.owner.columns.length === 0)) {\n            sheetData += '<sheetData/>';\n            this.dimension = 'A1';\n            done('', sheetData);\n        } else {\n            const owner = worksheetData.owner;\n            const isHierarchicalGrid = worksheetData.isHierarchical;\n            const hasMultiColumnHeader = worksheetData.hasMultiColumnHeader;\n\n            const hasUserSetIndex = owner.columns.some(col => col.exportIndex !== undefined);\n\n            const height =  worksheetData.options.rowHeight;\n            const rowStyle = isHierarchicalGrid ? ' s=\"3\"' : '';\n            this.rowHeight = height ? ` ht=\"${height}\" customHeight=\"1\"` : '';\n\n            sheetData += `<sheetData>`;\n\n            for (let i = 0; i <= owner.maxLevel; i++) {\n                this.rowIndex++;\n                sheetData += `<row r=\"${this.rowIndex}\"${this.rowHeight}>`;\n\n                const headersForLevel = hasMultiColumnHeader ?\n                    owner.columns\n                        .filter(c => (c.level < i &&\n                            c.headerType !== HeaderType.MultiColumnHeader || c.level === i) && c.columnSpan > 0 && !c.skip)\n                        .sort((a, b) => a.startIndex - b.startIndex)\n                        .sort((a, b) => a.pinnedIndex - b.pinnedIndex) :\n                    hasUserSetIndex ?\n                        owner.columns.filter(c => !c.skip) :\n                        owner.columns.filter(c => !c.skip)\n                            .sort((a, b) => a.startIndex - b.startIndex)\n                            .sort((a, b) => a.pinnedIndex - b.pinnedIndex);\n\n                let startValue = 0;\n\n                for (const currentCol of headersForLevel) {\n                    if (currentCol.level === i) {\n                        let columnCoordinate;\n                        columnCoordinate = ExcelStrings.getExcelColumn(startValue) + this.rowIndex;\n                        const columnValue = dictionary.saveValue(currentCol.header, true);\n                        sheetData += `<c r=\"${columnCoordinate}\"${rowStyle} t=\"s\"><v>${columnValue}</v></c>`;\n\n                        if (i !== owner.maxLevel) {\n                            this.mergeCellsCounter++;\n                            this.mergeCellStr += ` <mergeCell ref=\"${columnCoordinate}:`;\n\n                            if (currentCol.headerType === HeaderType.ColumnHeader) {\n                                columnCoordinate = ExcelStrings.getExcelColumn(startValue) + (owner.maxLevel + 1);\n                            } else {\n                                for (let k = 1; k < currentCol.columnSpan; k++) {\n                                    columnCoordinate = ExcelStrings.getExcelColumn(startValue + k) + this.rowIndex;\n                                    sheetData += `<c r=\"${columnCoordinate}\"${rowStyle} />`;\n                                }\n                            }\n\n                            this.mergeCellStr += `${columnCoordinate}\" />`;\n                        }\n                    }\n\n                    startValue += currentCol.columnSpan;\n                }\n\n                sheetData += `</row>`;\n            }\n\n            const multiColumnHeaderLevel = worksheetData.options.ignoreMultiColumnHeaders ? 0 : owner.maxLevel;\n            const freezeHeaders = worksheetData.options.freezeHeaders ? 2 + multiColumnHeaderLevel : 1;\n\n            if (!isHierarchicalGrid) {\n                this.dimension =\n                    'A1:' + ExcelStrings.getExcelColumn(worksheetData.columnCount - 1) + (worksheetData.rowCount);\n\n                cols += '<cols>';\n\n                if (!hasMultiColumnHeader) {\n                    for (let j = 0; j < worksheetData.columnCount; j++) {\n                        const width = dictionary.columnWidths[j];\n                        // Use the width provided in the options if it exists\n                        let widthInTwips = worksheetData.options.columnWidth !== undefined ?\n                                                worksheetData.options.columnWidth :\n                                                Math.max(((width / 96) * 14.4), WorksheetFile.MIN_WIDTH);\n                        if (!(widthInTwips > 0)) {\n                            widthInTwips = WorksheetFile.MIN_WIDTH;\n                        }\n\n                        cols += `<col min=\"${(j + 1)}\" max=\"${(j + 1)}\" width=\"${widthInTwips}\" customWidth=\"1\"/>`;\n                    }\n                } else {\n                    cols += `<col min=\"1\" max=\"${worksheetData.columnCount}\" width=\"15\" customWidth=\"1\"/>`;\n                }\n\n                cols += '</cols>';\n\n                const indexOfLastPinnedColumn = worksheetData.indexOfLastPinnedColumn;\n                const frozenColumnCount = indexOfLastPinnedColumn + 1;\n                let firstCell = ExcelStrings.getExcelColumn(frozenColumnCount) + freezeHeaders;\n                if (indexOfLastPinnedColumn !== undefined && indexOfLastPinnedColumn !== -1 &&\n                    !worksheetData.options.ignorePinning &&\n                    !worksheetData.options.ignoreColumnsOrder) {\n                    this.freezePane =\n                        `<pane xSplit=\"${frozenColumnCount}\" ySplit=\"${freezeHeaders - 1}\"\n                         topLeftCell=\"${firstCell}\" activePane=\"topRight\" state=\"frozen\"/>`;\n                } else if (worksheetData.options.freezeHeaders) {\n                    firstCell = ExcelStrings.getExcelColumn(0) + freezeHeaders;\n                    this.freezePane =\n                        `<pane xSplit=\"0\" ySplit=\"${freezeHeaders - 1}\"\n                         topLeftCell=\"${firstCell}\" activePane=\"topRight\" state=\"frozen\"/>`;\n                }\n            } else {\n                const columnWidth = worksheetData.options.columnWidth ? worksheetData.options.columnWidth : 20;\n                cols += `<cols><col min=\"1\" max=\"${worksheetData.columnCount}\" width=\"${columnWidth}\" customWidth=\"1\"/></cols>`;\n                if (worksheetData.options.freezeHeaders) {\n                    const firstCell = ExcelStrings.getExcelColumn(0) + freezeHeaders;\n                    this.freezePane =\n                        `<pane xSplit=\"0\" ySplit=\"${freezeHeaders - 1}\"\n                         topLeftCell=\"${firstCell}\" activePane=\"topRight\" state=\"frozen\"/>`;\n                }\n            }\n\n            this.processDataRecordsAsync(worksheetData, (rows) => {\n                sheetData += rows;\n                sheetData += '</sheetData>';\n\n                if (hasMultiColumnHeader && this.mergeCellsCounter > 0) {\n                    sheetData += `<mergeCells count=\"${this.mergeCellsCounter}\">${this.mergeCellStr}</mergeCells>`;\n                }\n\n                done(cols, sheetData);\n            });\n        }\n    }\n\n    private processDataRecordsAsync(worksheetData: WorksheetData, done: (rows: string) => void) {\n        const rowDataArr = [];\n        const height =  worksheetData.options.rowHeight;\n        this.rowHeight = height ? ' ht=\"' + height + '\" customHeight=\"1\"' : '';\n\n        const isHierarchicalGrid = worksheetData.isHierarchical;\n        const hasUserSetIndex = worksheetData.owner.columns.some(c => c.exportIndex !== undefined);\n\n        let recordHeaders = [];\n\n        yieldingLoop(worksheetData.rowCount - worksheetData.multiColumnHeaderRows - 1, 1000,\n            (i) => {\n                if (!worksheetData.isEmpty){\n                    if (!isHierarchicalGrid) {\n                        if (hasUserSetIndex) {\n                            recordHeaders = worksheetData.rootKeys;\n                        } else {\n                            recordHeaders = worksheetData.owner.columns\n                                .filter(c => c.headerType !== HeaderType.MultiColumnHeader && !c.skip)\n                                .sort((a, b) => a.startIndex-b.startIndex)\n                                .sort((a, b) => a.pinnedIndex-b.pinnedIndex)\n                                .map(c => c.field);\n                        }\n                    } else {\n                        const record = worksheetData.data[i];\n\n                        if (record.type === ExportRecordType.HeaderRecord) {\n                            const recordOwner = worksheetData.owners.get(record.owner);\n                            const hasMultiColumnHeaders = recordOwner.columns.some(c => !c.skip && c.headerType === HeaderType.MultiColumnHeader);\n\n                            if (hasMultiColumnHeaders) {\n                                this.hGridPrintMultiColHeaders(worksheetData, rowDataArr, record, recordOwner);\n                            }\n                        }\n\n                        recordHeaders = Object.keys(worksheetData.data[i].data);\n                    }\n\n                    rowDataArr.push(this.processRow(worksheetData, i, recordHeaders, isHierarchicalGrid));\n                }\n            },\n            () => {\n                done(rowDataArr.join(''));\n        });\n    }\n\n    private hGridPrintMultiColHeaders(worksheetData: WorksheetData, rowDataArr: any[], record: IExportRecord,\n        owner: IColumnList) {\n        for (let j = 0; j < owner.maxLevel; j++) {\n            const recordLevel = record.level;\n            const outlineLevel = recordLevel > 0 ? ` outlineLevel=\"${recordLevel}\"` : '';\n            this.maxOutlineLevel = this.maxOutlineLevel < recordLevel ? recordLevel : this.maxOutlineLevel;\n            const sHidden = record.hidden ? ` hidden=\"1\"` : '';\n\n            this.rowIndex++;\n            let row = `<row r=\"${this.rowIndex}\"${this.rowHeight}${outlineLevel}${sHidden}>`;\n\n            const headersForLevel = owner.columns\n                .filter(c => (c.level < j &&\n                    c.headerType !== HeaderType.MultiColumnHeader || c.level === j) && c.columnSpan > 0 && !c.skip)\n                .sort((a, b) => a.startIndex - b.startIndex)\n                .sort((a, b) => a.pinnedIndex - b.pinnedIndex);\n\n            let startValue = 0 + record.level;\n\n            for (const currentCol of headersForLevel) {\n                if (currentCol.level === j) {\n                    let columnCoordinate;\n                    columnCoordinate =\n                        ExcelStrings.getExcelColumn(startValue) + this.rowIndex;\n\n                    const columnValue = worksheetData.dataDictionary.saveValue(currentCol.header, true);\n                    row += `<c r=\"${columnCoordinate}\" s=\"3\" t=\"s\"><v>${columnValue}</v></c>`;\n\n                    if (j !== owner.maxLevel) {\n                        this.mergeCellsCounter++;\n                        this.mergeCellStr += ` <mergeCell ref=\"${columnCoordinate}:`;\n\n                        if (currentCol.headerType === HeaderType.ColumnHeader) {\n                            columnCoordinate = ExcelStrings.getExcelColumn(startValue) +\n                                (this.rowIndex + owner.maxLevel - currentCol.level);\n                        } else {\n                            for (let k = 1; k < currentCol.columnSpan; k++) {\n                                columnCoordinate = ExcelStrings.getExcelColumn(startValue + k) + this.rowIndex;\n                                row += `<c r=\"${columnCoordinate}\" s=\"3\" />`;\n                            }\n                        }\n\n                        this.mergeCellStr += `${columnCoordinate}\" />`;\n                    }\n                }\n\n                startValue += currentCol.columnSpan;\n            }\n            row += `</row>`;\n            rowDataArr.push(row);\n        }\n    }\n\n    private processRow(worksheetData: WorksheetData, i: number, headersForLevel: any[], isHierarchicalGrid: boolean) {\n        const record = worksheetData.data[i];\n\n        const rowData = new Array(worksheetData.columnCount + 2);\n\n        const rowLevel = record.level;\n        const outlineLevel = rowLevel > 0 ? ` outlineLevel=\"${rowLevel}\"` : '';\n        this.maxOutlineLevel = this.maxOutlineLevel < rowLevel ? rowLevel : this.maxOutlineLevel;\n\n        const sHidden = record.hidden ? ` hidden=\"1\"` : '';\n\n        this.rowIndex++;\n        rowData[0] =\n            `<row r=\"${this.rowIndex}\"${this.rowHeight}${outlineLevel}${sHidden}>`;\n\n        const keys = worksheetData.isSpecialData ? [record.data] : headersForLevel;\n\n        for (let j = 0; j < keys.length; j++) {\n            const col = j + (isHierarchicalGrid ? rowLevel : 0);\n\n            const cellData = this.getCellData(worksheetData, i, col, keys[j]);\n\n            rowData[j + 1] = cellData;\n        }\n\n        rowData[keys.length + 1] = '</row>';\n\n        return rowData.join('');\n    }\n\n    private getCellData(worksheetData: WorksheetData, row: number, column: number, key: string): string {\n        const dictionary = worksheetData.dataDictionary;\n        const columnName = ExcelStrings.getExcelColumn(column) + (this.rowIndex);\n        const fullRow = worksheetData.data[row];\n        const isHeaderRecord = fullRow.type === ExportRecordType.HeaderRecord;\n\n        const cellValue = worksheetData.isSpecialData ?\n            fullRow.data :\n            fullRow.data[key];\n\n        if (cellValue === undefined || cellValue === null) {\n            return `<c r=\"${columnName}\" s=\"1\"/>`;\n        } else {\n            const savedValue = dictionary.saveValue(cellValue, isHeaderRecord);\n            const isSavedAsString = savedValue !== -1;\n\n            const isSavedAsDate = !isSavedAsString && cellValue instanceof Date;\n\n            let value = isSavedAsString ? savedValue : cellValue;\n\n            if (isSavedAsDate) {\n                const timeZoneOffset = value.getTimezoneOffset() * 60000;\n                const isoString = (new Date(value - timeZoneOffset)).toISOString();\n                value = isoString.substring(0, isoString.indexOf('.'));\n            }\n\n            const type = isSavedAsString ? ` t=\"s\"` : isSavedAsDate ? ` t=\"d\"` : '';\n\n            const format = isHeaderRecord ? ` s=\"3\"` : isSavedAsString ? '' : isSavedAsDate ? ` s=\"2\"` : ` s=\"1\"`;\n\n            return `<c r=\"${columnName}\"${type}${format}><v>${value}</v></c>`;\n        }\n    }\n}\n\n/**\n * @hidden\n */\nexport class StyleFile implements IExcelFile {\n    public writeElement(folder: JSZip) {\n        folder.file('styles.xml', ExcelStrings.getStyles());\n    }\n}\n\n/**\n * @hidden\n */\nexport class WorkbookFile implements IExcelFile {\n    public writeElement(folder: JSZip, worksheetData: WorksheetData) {\n        folder.file('workbook.xml', ExcelStrings.getWorkbook(worksheetData.options.worksheetName));\n    }\n}\n\n/**\n * @hidden\n */\nexport class ContentTypesFile implements IExcelFile {\n    public writeElement(folder: JSZip, worksheetData: WorksheetData) {\n        const hasSharedStrings = !worksheetData.isEmpty || worksheetData.options.alwaysExportHeaders;\n        folder.file('[Content_Types].xml', ExcelStrings.getContentTypesXML(hasSharedStrings, worksheetData.options.exportAsTable));\n    }\n}\n\n/**\n * @hidden\n */\nexport class SharedStringsFile implements IExcelFile {\n    public writeElement(folder: JSZip, worksheetData: WorksheetData) {\n        const dict = worksheetData.dataDictionary;\n        const sortedValues = dict.getKeys();\n        const sharedStrings = new Array<string>(sortedValues.length);\n\n        for (const value of sortedValues) {\n            sharedStrings[dict.getSanitizedValue(value)] = '<si><t>' + value + '</t></si>';\n        }\n\n        folder.file('sharedStrings.xml', ExcelStrings.getSharedStringXML(\n                        dict.stringsCount,\n                        sortedValues.length,\n                        sharedStrings.join(''))\n                    );\n    }\n}\n\n/**\n * @hidden\n */\nexport class TablesFile implements IExcelFile {\n    public writeElement(folder: JSZip, worksheetData: WorksheetData) {\n        const columnCount = worksheetData.columnCount;\n        const lastColumn = ExcelStrings.getExcelColumn(columnCount - 1) + worksheetData.rowCount;\n        const autoFilterDimension = 'A1:' + lastColumn;\n        const tableDimension = worksheetData.isEmpty\n            ? 'A1:' + ExcelStrings.getExcelColumn(columnCount - 1) + (worksheetData.rowCount + 1)\n            : autoFilterDimension;\n        const hasUserSetIndex = worksheetData.owner.columns.some(c => c.exportIndex !== undefined);\n        const values = hasUserSetIndex\n            ? worksheetData.rootKeys\n            : worksheetData.owner.columns\n                .filter(c => !c.skip)\n                .sort((a, b) => a.startIndex - b.startIndex)\n                .sort((a, b) => a.pinnedIndex - b.pinnedIndex)\n                .map(c => c.header);\n\n        let sortString = '';\n\n        let tableColumns = '<tableColumns count=\"' + columnCount + '\">';\n        for (let i = 0; i < columnCount; i++) {\n            const value =  values[i];\n            tableColumns += '<tableColumn id=\"' + (i + 1) + '\" name=\"' + value + '\"/>';\n        }\n\n        tableColumns += '</tableColumns>';\n\n        if (worksheetData.sort) {\n            const sortingExpression = worksheetData.sort;\n            const sc = ExcelStrings.getExcelColumn(values.indexOf(sortingExpression.fieldName));\n            const dir = sortingExpression.dir - 1;\n            sortString = `<sortState ref=\"A2:${lastColumn}\"><sortCondition descending=\"${dir}\" ref=\"${sc}1:${sc}15\"/></sortState>`;\n        }\n\n        folder.file('table1.xml', ExcelStrings.getTablesXML(autoFilterDimension, tableDimension, tableColumns, sortString));\n    }\n}\n\n/**\n * @hidden\n */\nexport class WorksheetRelsFile implements IExcelFile {\n    public writeElement(folder: JSZip) {\n        folder.file('sheet1.xml.rels', ExcelStrings.getWorksheetRels());\n    }\n}\n"]}
456
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-files.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/services/excel/excel-files.ts"],"names":[],"mappings":"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","sourcesContent":["import { IExcelFile } from './excel-interfaces';\nimport { ExcelStrings } from './excel-strings';\nimport { WorksheetData } from './worksheet-data';\n\nimport { strToU8 } from 'fflate';\nimport { yieldingLoop } from '../../core/utils';\nimport { HeaderType, ExportRecordType, IExportRecord, IColumnList, IColumnInfo } from '../exporter-common/base-export-service';\n\n/**\n * @hidden\n */\nexport class RootRelsFile implements IExcelFile {\n    public writeElement(folder: Object) {\n        folder['.rels'] = strToU8(ExcelStrings.getRels());\n    }\n}\n\n/**\n * @hidden\n */\nexport class AppFile implements IExcelFile {\n    public writeElement(folder: Object, worksheetData: WorksheetData) {\n        folder['app.xml'] = strToU8(ExcelStrings.getApp(worksheetData.options.worksheetName));\n    }\n}\n\n/**\n * @hidden\n */\nexport class CoreFile implements IExcelFile {\n    public writeElement(folder: Object) {\n        folder['core.xml'] = strToU8(ExcelStrings.getCore());\n    }\n}\n\n/**\n * @hidden\n */\nexport class WorkbookRelsFile implements IExcelFile {\n    public writeElement(folder: Object, worksheetData: WorksheetData) {\n        const hasSharedStrings = !worksheetData.isEmpty || worksheetData.options.alwaysExportHeaders;\n        folder['workbook.xml.rels'] = strToU8(ExcelStrings.getWorkbookRels(hasSharedStrings));\n    }\n}\n\n/**\n * @hidden\n */\nexport class ThemeFile implements IExcelFile {\n    public writeElement(folder: Object) {\n        folder['theme1.xml'] = strToU8(ExcelStrings.getTheme());\n    }\n}\n\n/**\n * @hidden\n */\nexport class WorksheetFile implements IExcelFile {\n    private static MIN_WIDTH = 8.43;\n    private maxOutlineLevel = 0;\n    private sheetData = '';\n    private dimension = '';\n    private freezePane = '';\n    private rowHeight = '';\n\n    private mergeCellStr = '';\n    private mergeCellsCounter = 0;\n    private rowIndex = 0;\n    private pivotGridRowHeadersMap = new Map<number, string>();\n\n    public writeElement() {}\n\n    public async writeElementAsync(folder: Object, worksheetData: WorksheetData) {\n        return new Promise<void>(resolve => {\n            this.prepareDataAsync(worksheetData, (cols, rows) => {\n                const hasTable = (!worksheetData.isEmpty || worksheetData.options.alwaysExportHeaders)\n                    && worksheetData.options.exportAsTable;\n\n                folder['sheet1.xml'] = strToU8(ExcelStrings.getSheetXML(\n                    this.dimension, this.freezePane, cols, rows, hasTable, this.maxOutlineLevel, worksheetData.isHierarchical));\n                resolve();\n            });\n        });\n    }\n\n    private prepareDataAsync(worksheetData: WorksheetData, done: (cols: string, sheetData: string) => void) {\n        this.sheetData = '';\n        let cols = '';\n        const dictionary = worksheetData.dataDictionary;\n        this.rowIndex = 0;\n\n        if (worksheetData.isEmpty && (!worksheetData.options.alwaysExportHeaders || worksheetData.owner.columns.length === 0)) {\n            this.sheetData += '<sheetData/>';\n            this.dimension = 'A1';\n            done('', this.sheetData);\n        } else {\n            const owner = worksheetData.owner;\n            const isHierarchicalGrid = worksheetData.isHierarchical;\n            const hasMultiColumnHeader = worksheetData.hasMultiColumnHeader;\n            const hasMultiRowHeader = worksheetData.hasMultiRowHeader;\n\n            const hasUserSetIndex = owner.columns.some(col => col.exportIndex !== undefined);\n\n            const height =  worksheetData.options.rowHeight;\n            this.rowHeight = height ? ` ht=\"${height}\" customHeight=\"1\"` : '';\n            this.sheetData += `<sheetData>`;\n\n            let headersForLevel: IColumnInfo[] = [];\n\n            for(let i = 0; i <= owner.maxRowLevel; i++) {\n                headersForLevel =  owner.columns.filter(c => c.level === i && c.rowSpan > 0 && !c.skip)\n\n                this.printHeaders(worksheetData, headersForLevel, i, true);\n\n                this.rowIndex++;\n            }\n\n            this.rowIndex = 0;\n\n            for (let i = 0; i <= owner.maxLevel; i++) {\n                this.rowIndex++;\n                const pivotGridColumns = this.pivotGridRowHeadersMap.get(this.rowIndex) ?? \"\";\n                this.sheetData += `<row r=\"${this.rowIndex}\"${this.rowHeight}>${pivotGridColumns}`;\n\n                const allowedColumns = owner.columns.filter(c => c.headerType !== HeaderType.RowHeader && c.headerType !== HeaderType.MultiRowHeader);\n\n                headersForLevel = hasMultiColumnHeader ?\n                    allowedColumns\n                        .filter(c => (c.level < i &&\n                            c.headerType !== HeaderType.MultiColumnHeader || c.level === i) && c.columnSpan > 0 && !c.skip)\n                        .sort((a, b) => a.startIndex - b.startIndex)\n                        .sort((a, b) => a.pinnedIndex - b.pinnedIndex) :\n                    hasUserSetIndex ?\n                        allowedColumns.filter(c => !c.skip) :\n                        allowedColumns.filter(c => !c.skip)\n                            .sort((a, b) => a.startIndex - b.startIndex)\n                            .sort((a, b) => a.pinnedIndex - b.pinnedIndex);\n\n                this.printHeaders(worksheetData, headersForLevel, i, false);\n\n                this.sheetData += `</row>`;\n            }\n\n            const multiColumnHeaderLevel = worksheetData.options.ignoreMultiColumnHeaders ? 0 : owner.maxLevel;\n            const freezeHeaders = worksheetData.options.freezeHeaders ? 2 + multiColumnHeaderLevel : 1;\n\n            if (!isHierarchicalGrid) {\n                this.dimension =\n                    'A1:' + ExcelStrings.getExcelColumn(worksheetData.columnCount - 1) + (worksheetData.rowCount);\n\n                cols += '<cols>';\n\n                if (!hasMultiColumnHeader) {\n                    for (let j = 0; j < worksheetData.columnCount; j++) {\n                        const width = dictionary.columnWidths[j];\n                        // Use the width provided in the options if it exists\n                        let widthInTwips = worksheetData.options.columnWidth !== undefined ?\n                                                worksheetData.options.columnWidth :\n                                                Math.max(((width / 96) * 14.4), WorksheetFile.MIN_WIDTH);\n                        if (!(widthInTwips > 0)) {\n                            widthInTwips = WorksheetFile.MIN_WIDTH;\n                        }\n\n                        cols += `<col min=\"${(j + 1)}\" max=\"${(j + 1)}\" width=\"${widthInTwips}\" customWidth=\"1\"/>`;\n                    }\n                } else {\n                    cols += `<col min=\"1\" max=\"${worksheetData.columnCount}\" width=\"15\" customWidth=\"1\"/>`;\n                }\n\n                cols += '</cols>';\n\n                const indexOfLastPinnedColumn = worksheetData.indexOfLastPinnedColumn;\n                const frozenColumnCount = indexOfLastPinnedColumn + 1;\n                let firstCell = ExcelStrings.getExcelColumn(frozenColumnCount) + freezeHeaders;\n                if (indexOfLastPinnedColumn !== undefined && indexOfLastPinnedColumn !== -1 &&\n                    !worksheetData.options.ignorePinning &&\n                    !worksheetData.options.ignoreColumnsOrder) {\n                    this.freezePane =\n                        `<pane xSplit=\"${frozenColumnCount}\" ySplit=\"${freezeHeaders - 1}\"\n                         topLeftCell=\"${firstCell}\" activePane=\"topRight\" state=\"frozen\"/>`;\n                } else if (worksheetData.options.freezeHeaders) {\n                    firstCell = ExcelStrings.getExcelColumn(0) + freezeHeaders;\n                    this.freezePane =\n                        `<pane xSplit=\"0\" ySplit=\"${freezeHeaders - 1}\"\n                         topLeftCell=\"${firstCell}\" activePane=\"topRight\" state=\"frozen\"/>`;\n                }\n            } else {\n                const columnWidth = worksheetData.options.columnWidth ? worksheetData.options.columnWidth : 20;\n                cols += `<cols><col min=\"1\" max=\"${worksheetData.columnCount}\" width=\"${columnWidth}\" customWidth=\"1\"/></cols>`;\n                if (worksheetData.options.freezeHeaders) {\n                    const firstCell = ExcelStrings.getExcelColumn(0) + freezeHeaders;\n                    this.freezePane =\n                        `<pane xSplit=\"0\" ySplit=\"${freezeHeaders - 1}\"\n                         topLeftCell=\"${firstCell}\" activePane=\"topRight\" state=\"frozen\"/>`;\n                }\n            }\n\n            this.processDataRecordsAsync(worksheetData, (rows) => {\n                this.sheetData += rows;\n                this.sheetData += '</sheetData>';\n\n                if ((hasMultiColumnHeader || hasMultiRowHeader) && this.mergeCellsCounter > 0) {\n                    this.sheetData += `<mergeCells count=\"${this.mergeCellsCounter}\">${this.mergeCellStr}</mergeCells>`;\n                }\n\n                done(cols, this.sheetData);\n            });\n        }\n    }\n\n    private processDataRecordsAsync(worksheetData: WorksheetData, done: (rows: string) => void) {\n        const rowDataArr = [];\n        const height =  worksheetData.options.rowHeight;\n        this.rowHeight = height ? ' ht=\"' + height + '\" customHeight=\"1\"' : '';\n\n        const isHierarchicalGrid = worksheetData.isHierarchical;\n        const hasUserSetIndex = worksheetData.owner.columns.some(c => c.exportIndex !== undefined);\n\n        let recordHeaders = [];\n\n        yieldingLoop(worksheetData.rowCount - worksheetData.multiColumnHeaderRows - 1, 1000,\n            (i) => {\n                if (!worksheetData.isEmpty){\n                    if (!isHierarchicalGrid) {\n                        if (hasUserSetIndex) {\n                            recordHeaders = worksheetData.rootKeys;\n                        } else {\n                            recordHeaders = worksheetData.owner.columns\n                                .filter(c => c.headerType !== HeaderType.MultiColumnHeader && c.headerType !== HeaderType.MultiRowHeader && c.headerType !== HeaderType.RowHeader && !c.skip)\n                                .sort((a, b) => a.startIndex-b.startIndex)\n                                .sort((a, b) => a.pinnedIndex-b.pinnedIndex)\n                                .map(c => c.field);\n                        }\n                    } else {\n                        const record = worksheetData.data[i];\n\n                        if (record.type === ExportRecordType.HeaderRecord) {\n                            const recordOwner = worksheetData.owners.get(record.owner);\n                            const hasMultiColumnHeaders = recordOwner.columns.some(c => !c.skip && c.headerType === HeaderType.MultiColumnHeader);\n\n                            if (hasMultiColumnHeaders) {\n                                this.hGridPrintMultiColHeaders(worksheetData, rowDataArr, record, recordOwner);\n                            }\n                        }\n\n                        recordHeaders = Object.keys(worksheetData.data[i].data);\n                    }\n\n                    rowDataArr.push(this.processRow(worksheetData, i, recordHeaders, isHierarchicalGrid));\n                }\n            },\n            () => {\n                done(rowDataArr.join(''));\n        });\n    }\n\n    private hGridPrintMultiColHeaders(worksheetData: WorksheetData, rowDataArr: any[], record: IExportRecord,\n        owner: IColumnList) {\n        for (let j = 0; j < owner.maxLevel; j++) {\n            const recordLevel = record.level;\n            const outlineLevel = recordLevel > 0 ? ` outlineLevel=\"${recordLevel}\"` : '';\n            this.maxOutlineLevel = this.maxOutlineLevel < recordLevel ? recordLevel : this.maxOutlineLevel;\n            const sHidden = record.hidden ? ` hidden=\"1\"` : '';\n\n            this.rowIndex++;\n            let row = `<row r=\"${this.rowIndex}\"${this.rowHeight}${outlineLevel}${sHidden}>`;\n\n            const headersForLevel = owner.columns\n                .filter(c => (c.level < j &&\n                    c.headerType !== HeaderType.MultiColumnHeader || c.level === j) && c.columnSpan > 0 && !c.skip)\n                .sort((a, b) => a.startIndex - b.startIndex)\n                .sort((a, b) => a.pinnedIndex - b.pinnedIndex);\n\n            let startValue = 0 + record.level;\n\n            for (const currentCol of headersForLevel) {\n                if (currentCol.level === j) {\n                    let columnCoordinate;\n                    columnCoordinate =\n                        ExcelStrings.getExcelColumn(startValue) + this.rowIndex;\n\n                    const columnValue = worksheetData.dataDictionary.saveValue(currentCol.header, true);\n                    row += `<c r=\"${columnCoordinate}\" s=\"3\" t=\"s\"><v>${columnValue}</v></c>`;\n\n                    if (j !== owner.maxLevel) {\n                        this.mergeCellsCounter++;\n                        this.mergeCellStr += ` <mergeCell ref=\"${columnCoordinate}:`;\n\n                        if (currentCol.headerType === HeaderType.ColumnHeader) {\n                            columnCoordinate = ExcelStrings.getExcelColumn(startValue) +\n                                (this.rowIndex + owner.maxLevel - currentCol.level);\n                        } else {\n                            for (let k = 1; k < currentCol.columnSpan; k++) {\n                                columnCoordinate = ExcelStrings.getExcelColumn(startValue + k) + this.rowIndex;\n                                row += `<c r=\"${columnCoordinate}\" s=\"3\" />`;\n                            }\n                        }\n\n                        this.mergeCellStr += `${columnCoordinate}\" />`;\n                    }\n                }\n\n                startValue += currentCol.columnSpan;\n            }\n            row += `</row>`;\n            rowDataArr.push(row);\n        }\n    }\n\n    private processRow(worksheetData: WorksheetData, i: number, headersForLevel: any[], isHierarchicalGrid: boolean) {\n        const record = worksheetData.data[i];\n\n        const rowData = new Array(worksheetData.columnCount + 2);\n\n        const rowLevel = record.level;\n        const outlineLevel = rowLevel > 0 ? ` outlineLevel=\"${rowLevel}\"` : '';\n        this.maxOutlineLevel = this.maxOutlineLevel < rowLevel ? rowLevel : this.maxOutlineLevel;\n\n        const sHidden = record.hidden ? ` hidden=\"1\"` : '';\n\n        this.rowIndex++;\n        const pivotGridColumns = this.pivotGridRowHeadersMap.get(this.rowIndex) ?? \"\";\n\n        rowData[0] =\n            `<row r=\"${this.rowIndex}\"${this.rowHeight}${outlineLevel}${sHidden}>${pivotGridColumns}`;\n\n        const keys = worksheetData.isSpecialData ? [record.data] : headersForLevel;\n\n        for (let j = 0; j < keys.length; j++) {\n            const col = j + (isHierarchicalGrid ? rowLevel : worksheetData.isPivotGrid ? worksheetData.owner.maxRowLevel : 0);\n\n            const cellData = this.getCellData(worksheetData, i, col, keys[j]);\n\n            rowData[j + 1] = cellData;\n        }\n\n        rowData[keys.length + 1] = '</row>';\n\n        return rowData.join('');\n    }\n\n    private getCellData(worksheetData: WorksheetData, row: number, column: number, key: string): string {\n        const dictionary = worksheetData.dataDictionary;\n        const columnName = ExcelStrings.getExcelColumn(column) + (this.rowIndex);\n        const fullRow = worksheetData.data[row];\n        const isHeaderRecord = fullRow.type === ExportRecordType.HeaderRecord;\n\n        const cellValue = worksheetData.isSpecialData ?\n            fullRow.data :\n            fullRow.data[key];\n\n        if (cellValue === undefined || cellValue === null) {\n            return `<c r=\"${columnName}\" s=\"1\"/>`;\n        } else {\n            const savedValue = dictionary.saveValue(cellValue, isHeaderRecord);\n            const isSavedAsString = savedValue !== -1;\n\n            const isSavedAsDate = !isSavedAsString && cellValue instanceof Date;\n\n            let value = isSavedAsString ? savedValue : cellValue;\n\n            if (isSavedAsDate) {\n                const timeZoneOffset = value.getTimezoneOffset() * 60000;\n                const isoString = (new Date(value - timeZoneOffset)).toISOString();\n                value = isoString.substring(0, isoString.indexOf('.'));\n            }\n\n            const type = isSavedAsString ? ` t=\"s\"` : isSavedAsDate ? ` t=\"d\"` : '';\n\n            const format = isHeaderRecord ? ` s=\"3\"` : isSavedAsString ? '' : isSavedAsDate ? ` s=\"2\"` : ` s=\"1\"`;\n\n            return `<c r=\"${columnName}\"${type}${format}><v>${value}</v></c>`;\n        }\n    }\n\n    private printHeaders(worksheetData: WorksheetData, headersForLevel: IColumnInfo[], i: number, isVertical: boolean) {\n        let startValue = 0;\n        let str = '';\n\n        const isHierarchicalGrid = worksheetData.isHierarchical;\n        let rowStyle = isHierarchicalGrid ? ' s=\"3\"' : '';\n        const dictionary = worksheetData.dataDictionary;\n        const owner = worksheetData.owner;\n        const maxLevel = isVertical\n            ? owner.maxRowLevel\n            : owner.maxLevel;\n\n        for (const currentCol of headersForLevel) {\n            const spanLength = isVertical ? currentCol.rowSpan : currentCol.columnSpan;\n\n            if (currentCol.level === i) {\n                let columnCoordinate;\n                const column = isVertical\n                    ? this.rowIndex\n                    : startValue + (owner.maxRowLevel ?? 0)\n\n                const rowCoordinate = isVertical\n                    ? startValue + owner.maxLevel + 2\n                    : this.rowIndex\n\n                const columnValue = dictionary.saveValue(currentCol.header, true);\n\n                columnCoordinate = ExcelStrings.getExcelColumn(column) + rowCoordinate;\n                rowStyle = isVertical && currentCol.rowSpan > 1 ? ' s=\"4\"' : rowStyle;\n                str = `<c r=\"${columnCoordinate}\"${rowStyle} t=\"s\"><v>${columnValue}</v></c>`;\n\n                if (isVertical) {\n                    if (this.pivotGridRowHeadersMap.has(rowCoordinate)) {\n                        this.pivotGridRowHeadersMap.set(rowCoordinate, this.pivotGridRowHeadersMap.get(rowCoordinate) + str)\n                    } else {\n                        this.pivotGridRowHeadersMap.set(rowCoordinate, str)\n                    }\n                } else {\n                    this.sheetData += str;\n                }\n\n                if (i !== maxLevel) {\n                    this.mergeCellsCounter++;\n                    this.mergeCellStr += ` <mergeCell ref=\"${columnCoordinate}:`;\n\n                    if (currentCol.headerType === HeaderType.ColumnHeader) {\n                        const col = isVertical\n                            ? maxLevel\n                            : startValue + (owner.maxRowLevel ?? 0);\n\n                        const row = isVertical\n                            ? rowCoordinate\n                            : owner.maxLevel + 1;\n\n                        columnCoordinate = ExcelStrings.getExcelColumn(col) + row;\n                    } else {\n                        for (let k = 1; k < spanLength; k++) {\n                            const col = isVertical\n                                ? column\n                                : column + k;\n\n                            const row = isVertical\n                                ? rowCoordinate + k\n                                : this.rowIndex;\n\n                            columnCoordinate = ExcelStrings.getExcelColumn(col) + row;\n                            str = `<c r=\"${columnCoordinate}\"${rowStyle} />`;\n\n                            isVertical\n                                ? this.pivotGridRowHeadersMap.set(row, str)\n                                : this.sheetData += str\n                        }\n                    }\n\n                    this.mergeCellStr += `${columnCoordinate}\" />`;\n                }\n            }\n\n            startValue += spanLength;\n        }\n    }\n}\n\n/**\n * @hidden\n */\nexport class StyleFile implements IExcelFile {\n    public writeElement(folder: Object) {\n        folder['styles.xml'] = strToU8(ExcelStrings.getStyles());\n    }\n}\n\n/**\n * @hidden\n */\nexport class WorkbookFile implements IExcelFile {\n    public writeElement(folder: Object, worksheetData: WorksheetData) {\n        folder['workbook.xml'] = strToU8(ExcelStrings.getWorkbook(worksheetData.options.worksheetName));\n    }\n}\n\n/**\n * @hidden\n */\nexport class ContentTypesFile implements IExcelFile {\n    public writeElement(folder: Object, worksheetData: WorksheetData) {\n        const hasSharedStrings = !worksheetData.isEmpty || worksheetData.options.alwaysExportHeaders;\n        folder['[Content_Types].xml'] = strToU8(ExcelStrings.getContentTypesXML(hasSharedStrings, worksheetData.options.exportAsTable));\n    }\n}\n\n/**\n * @hidden\n */\nexport class SharedStringsFile implements IExcelFile {\n    public writeElement(folder: Object, worksheetData: WorksheetData) {\n        const dict = worksheetData.dataDictionary;\n        const sortedValues = dict.getKeys();\n        const sharedStrings = new Array<string>(sortedValues.length);\n\n        for (const value of sortedValues) {\n            sharedStrings[dict.getSanitizedValue(value)] = '<si><t>' + value + '</t></si>';\n        }\n\n        folder['sharedStrings.xml'] = strToU8(ExcelStrings.getSharedStringXML(\n                        dict.stringsCount,\n                        sortedValues.length,\n                        sharedStrings.join(''))\n                    );\n    }\n}\n\n/**\n * @hidden\n */\nexport class TablesFile implements IExcelFile {\n    public writeElement(folder: Object, worksheetData: WorksheetData) {\n        const columnCount = worksheetData.columnCount;\n        const lastColumn = ExcelStrings.getExcelColumn(columnCount - 1) + worksheetData.rowCount;\n        const autoFilterDimension = 'A1:' + lastColumn;\n        const tableDimension = worksheetData.isEmpty\n            ? 'A1:' + ExcelStrings.getExcelColumn(columnCount - 1) + (worksheetData.rowCount + 1)\n            : autoFilterDimension;\n        const hasUserSetIndex = worksheetData.owner.columns.some(c => c.exportIndex !== undefined);\n        const values = hasUserSetIndex\n            ? worksheetData.rootKeys\n            : worksheetData.owner.columns\n                .filter(c => !c.skip)\n                .sort((a, b) => a.startIndex - b.startIndex)\n                .sort((a, b) => a.pinnedIndex - b.pinnedIndex)\n                .map(c => c.header);\n\n        let sortString = '';\n\n        let tableColumns = '<tableColumns count=\"' + columnCount + '\">';\n        for (let i = 0; i < columnCount; i++) {\n            const value =  values[i];\n            tableColumns += '<tableColumn id=\"' + (i + 1) + '\" name=\"' + value + '\"/>';\n        }\n\n        tableColumns += '</tableColumns>';\n\n        if (worksheetData.sort) {\n            const sortingExpression = worksheetData.sort;\n            const sc = ExcelStrings.getExcelColumn(values.indexOf(sortingExpression.fieldName));\n            const dir = sortingExpression.dir - 1;\n            sortString = `<sortState ref=\"A2:${lastColumn}\"><sortCondition descending=\"${dir}\" ref=\"${sc}1:${sc}15\"/></sortState>`;\n        }\n\n        folder['table1.xml'] = strToU8(ExcelStrings.getTablesXML(autoFilterDimension, tableDimension, tableColumns, sortString));\n    }\n}\n\n/**\n * @hidden\n */\nexport class WorksheetRelsFile implements IExcelFile {\n    public writeElement(folder: Object) {\n        folder['sheet1.xml.rels'] = strToU8(ExcelStrings.getWorksheetRels());\n    }\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhjZWwtaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2lnbml0ZXVpLWFuZ3VsYXIvc3JjL2xpYi9zZXJ2aWNlcy9leGNlbC9leGNlbC1pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBKU1ppcCBmcm9tICdqc3ppcCc7XG5cbmltcG9ydCB7XG4gICAgRXhjZWxGaWxlVHlwZXMsXG4gICAgRXhjZWxGb2xkZXJUeXBlc1xufSBmcm9tICcuL2V4Y2VsLWVudW1zJztcblxuaW1wb3J0IHsgV29ya3NoZWV0RGF0YSB9IGZyb20gJy4vd29ya3NoZWV0LWRhdGEnO1xuXG4vKiogQGhpZGRlbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJRXhjZWxGaWxlIHtcbiAgICB3cml0ZUVsZW1lbnQoZm9sZGVyOiBKU1ppcCwgZGF0YTogV29ya3NoZWV0RGF0YSk6IHZvaWQ7XG59XG5cbi8qKiBAaGlkZGVuICovXG5leHBvcnQgaW50ZXJmYWNlIElFeGNlbEZvbGRlciB7XG4gICAgZm9sZGVyTmFtZTogc3RyaW5nO1xuXG4gICAgY2hpbGRGaWxlcyhkYXRhOiBXb3Jrc2hlZXREYXRhKTogRXhjZWxGaWxlVHlwZXNbXTtcbiAgICBjaGlsZEZvbGRlcnMoZGF0YTogV29ya3NoZWV0RGF0YSk6IEV4Y2VsRm9sZGVyVHlwZXNbXTtcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhjZWwtaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2lnbml0ZXVpLWFuZ3VsYXIvc3JjL2xpYi9zZXJ2aWNlcy9leGNlbC9leGNlbC1pbnRlcmZhY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIEV4Y2VsRmlsZVR5cGVzLFxuICAgIEV4Y2VsRm9sZGVyVHlwZXNcbn0gZnJvbSAnLi9leGNlbC1lbnVtcyc7XG5cbmltcG9ydCB7IFdvcmtzaGVldERhdGEgfSBmcm9tICcuL3dvcmtzaGVldC1kYXRhJztcblxuLyoqIEBoaWRkZW4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSUV4Y2VsRmlsZSB7XG4gICAgd3JpdGVFbGVtZW50KGZvbGRlcjogT2JqZWN0LCBkYXRhOiBXb3Jrc2hlZXREYXRhKTogdm9pZDtcbn1cblxuLyoqIEBoaWRkZW4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSUV4Y2VsRm9sZGVyIHtcbiAgICBmb2xkZXJOYW1lOiBzdHJpbmc7XG5cbiAgICBjaGlsZEZpbGVzKGRhdGE6IFdvcmtzaGVldERhdGEpOiBFeGNlbEZpbGVUeXBlc1tdO1xuICAgIGNoaWxkRm9sZGVycyhkYXRhOiBXb3Jrc2hlZXREYXRhKTogRXhjZWxGb2xkZXJUeXBlc1tdO1xufVxuIl19