igniteui-angular 18.1.8 → 18.1.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/esm2022/lib/combo/combo.common.mjs +2 -10
  2. package/esm2022/lib/combo/combo.component.mjs +3 -3
  3. package/esm2022/lib/core/i18n/combo-resources.mjs +4 -2
  4. package/esm2022/lib/grids/pivot-grid/pivot-grid-navigation.service.mjs +2 -2
  5. package/esm2022/lib/grids/pivot-grid/pivot-grid.interface.mjs +1 -1
  6. package/esm2022/lib/grids/state-base.directive.mjs +10 -4
  7. package/esm2022/lib/services/excel/excel-files.mjs +26 -5
  8. package/esm2022/lib/simple-combo/simple-combo.component.mjs +18 -10
  9. package/fesm2022/igniteui-angular.mjs +80 -52
  10. package/fesm2022/igniteui-angular.mjs.map +1 -1
  11. package/lib/core/i18n/combo-resources.d.ts +2 -0
  12. package/lib/core/styles/components/input/_input-group-theme.scss +2 -2
  13. package/lib/simple-combo/simple-combo.component.d.ts +4 -3
  14. package/package.json +1 -1
  15. package/styles/igniteui-angular-dark.css +1 -1
  16. package/styles/igniteui-angular.css +1 -1
  17. package/styles/igniteui-bootstrap-dark.css +1 -1
  18. package/styles/igniteui-bootstrap-light.css +1 -1
  19. package/styles/igniteui-dark-green.css +1 -1
  20. package/styles/igniteui-fluent-dark-excel.css +1 -1
  21. package/styles/igniteui-fluent-dark-word.css +1 -1
  22. package/styles/igniteui-fluent-dark.css +1 -1
  23. package/styles/igniteui-fluent-light-excel.css +1 -1
  24. package/styles/igniteui-fluent-light-word.css +1 -1
  25. package/styles/igniteui-fluent-light.css +1 -1
  26. package/styles/igniteui-indigo-dark.css +1 -1
  27. package/styles/igniteui-indigo-light.css +1 -1
  28. package/styles/maps/igniteui-angular-dark.css.map +1 -1
  29. package/styles/maps/igniteui-angular.css.map +1 -1
  30. package/styles/maps/igniteui-bootstrap-dark.css.map +1 -1
  31. package/styles/maps/igniteui-bootstrap-light.css.map +1 -1
  32. package/styles/maps/igniteui-dark-green.css.map +1 -1
  33. package/styles/maps/igniteui-fluent-dark-excel.css.map +1 -1
  34. package/styles/maps/igniteui-fluent-dark-word.css.map +1 -1
  35. package/styles/maps/igniteui-fluent-dark.css.map +1 -1
  36. package/styles/maps/igniteui-fluent-light-excel.css.map +1 -1
  37. package/styles/maps/igniteui-fluent-light-word.css.map +1 -1
  38. package/styles/maps/igniteui-fluent-light.css.map +1 -1
  39. package/styles/maps/igniteui-indigo-dark.css.map +1 -1
  40. package/styles/maps/igniteui-indigo-light.css.map +1 -1
@@ -360,9 +360,30 @@ export class WorksheetFile {
360
360
  const level = worksheetData.isGroupedGrid ? worksheetData.maxLevel : fullRow.level;
361
361
  summaryFunc = this.getSummaryFunction(cellValue.label, key, dimensionMapKey, level, targetCol);
362
362
  if (!summaryFunc) {
363
- const cellStr = `${cellValue.label}: ${cellValue.value}`;
364
- const savedValue = dictionary.saveValue(cellStr, false);
365
- return `<c r="${columnName}" t="s" s="1"><v>${savedValue}</v></c>`;
363
+ let summaryValue;
364
+ const label = cellValue.label?.toString();
365
+ const value = cellValue.value?.toString();
366
+ if (label && value) {
367
+ summaryValue = `${cellValue.label}: ${cellValue.value}`;
368
+ }
369
+ else if (label) {
370
+ summaryValue = cellValue.label;
371
+ }
372
+ else if (value) {
373
+ summaryValue = cellValue.value;
374
+ }
375
+ const savedValue = dictionary.saveValue(summaryValue, false);
376
+ const isSavedAsString = savedValue !== -1;
377
+ const isSavedAsDate = !isSavedAsString && summaryValue instanceof Date;
378
+ if (isSavedAsDate) {
379
+ const timeZoneOffset = summaryValue.getTimezoneOffset() * 60000;
380
+ const isoString = (new Date(summaryValue - timeZoneOffset)).toISOString();
381
+ summaryValue = isoString.substring(0, isoString.indexOf('.'));
382
+ }
383
+ const resolvedValue = isSavedAsString ? savedValue : summaryValue;
384
+ const type = isSavedAsString ? `t="s"` : isSavedAsDate ? `t="d"` : '';
385
+ const style = isSavedAsDate ? `s="2"` : `s="1"`;
386
+ return `<c r="${columnName}" ${type} ${style}><v>${resolvedValue}</v></c>`;
366
387
  }
367
388
  return `<c r="${columnName}"><f t="array" ref="${columnName}">${summaryFunc}</f></c>`;
368
389
  }
@@ -426,7 +447,7 @@ export class WorksheetFile {
426
447
  let funcType = '';
427
448
  let result = '';
428
449
  const currencyInfo = this.currencyStyleMap.get(col.currencyCode);
429
- switch (type.toLowerCase()) {
450
+ switch (type?.toString().toLowerCase()) {
430
451
  case "count":
431
452
  return `"Count: "&amp;_xlfn.COUNTIF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}, ${recordLevel})`;
432
453
  case "min":
@@ -634,4 +655,4 @@ export class WorksheetRelsFile {
634
655
  folder['sheet1.xml.rels'] = strToU8(ExcelStrings.getWorksheetRels());
635
656
  }
636
657
  }
637
- //# 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 { ExportHeaderType, ExportRecordType, IExportRecord, IColumnList, IColumnInfo, GRID_ROOT_SUMMARY, GRID_PARENT, GRID_LEVEL_COL } 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\ninterface Dimensions {\n    startCoordinate: string\n    endCoordinate: string\n}\n\ninterface CurrencyInfo {\n    styleXf: number\n    symbol: string\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    private dimensionMap: Map<string, Dimensions> = new Map<string, Dimensions>();\n    private hierarchicalDimensionMap: Map<any,  Map<string, Dimensions>> = new Map<any,  Map<string, Dimensions>>();\n    private currentSummaryOwner = '';\n    private currentHierarchicalOwner = '';\n    private firstColumn = Number.MAX_VALUE;\n    private firstDataRow = Number.MAX_VALUE;\n    private isValidGrid: boolean;\n    private lastValidRow: string;\n\n    private currencyStyleMap = new Map<string, CurrencyInfo>([\n        ['USD', {styleXf: 5, symbol: '$'}],\n        ['GBP', {styleXf: 6, symbol: '£'}],\n        ['CNY', {styleXf: 7, symbol: '¥'}],\n        ['EUR', {styleXf: 8, symbol: '€'}],\n        ['JPY', {styleXf: 9, symbol: '¥'}],\n    ]);\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\n            this.isValidGrid = worksheetData.isHierarchical || worksheetData.isTreeGrid || worksheetData.isGroupedGrid;\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 !== ExportHeaderType.RowHeader &&\n                     c.headerType !== ExportHeaderType.MultiRowHeader &&\n                     c.headerType !== ExportHeaderType.PivotRowHeader &&\n                     c.headerType !== ExportHeaderType.PivotMergedHeader);\n\n                headersForLevel = hasMultiColumnHeader ?\n                    allowedColumns\n                        .filter(c => (c.level < i &&\n                            c.headerType !== ExportHeaderType.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                const col = worksheetData.hasSummaries ? worksheetData.columnCount + 1 : worksheetData.columnCount - 1\n                this.dimension = 'A1:' + ExcelStrings.getExcelColumn(col) + (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                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\"/>`;\n\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            if (worksheetData.hasSummaries) {\n                cols += `<col min=\"${worksheetData.columnCount + 2}\" max=\"${worksheetData.columnCount + 2}\" hidden=\"1\"/>`;\n            }\n\n            cols += '</cols>';\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 === ExportHeaderType.ColumnHeader && !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 === ExportHeaderType.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 !== ExportHeaderType.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 === ExportHeaderType.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] = `<row r=\"${this.rowIndex}\"${this.rowHeight}${outlineLevel}${sHidden}>${pivotGridColumns}`;\n        const keys = worksheetData.isSpecialData ? [record.data] : headersForLevel;\n        const isDataRecord = record.type === ExportRecordType.HierarchicalGridRecord\n            || record.type === ExportRecordType.DataRecord\n            || record.type === ExportRecordType.GroupedRecord\n            || record.type === ExportRecordType.TreeGridRecord;\n\n        const isValidRecordType = isDataRecord || record.type === ExportRecordType.SummaryRecord;\n\n        if (isValidRecordType && worksheetData.hasSummaries) {\n            this.resolveSummaryDimensions(record, isDataRecord, worksheetData.isGroupedGrid)\n        }\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        let columnName = ExcelStrings.getExcelColumn(column) + (this.rowIndex);\n        const fullRow = worksheetData.data[row];\n        const isHeaderRecord = fullRow.type === ExportRecordType.HeaderRecord;\n        const isSummaryRecord = fullRow.type === ExportRecordType.SummaryRecord;\n        const isValidRecordType = fullRow.type === ExportRecordType.GroupedRecord\n            || fullRow.type === ExportRecordType.DataRecord\n            || fullRow.type === ExportRecordType.HierarchicalGridRecord\n            || fullRow.type === ExportRecordType.TreeGridRecord;\n\n        this.firstDataRow = this.firstDataRow > this.rowIndex ? this.rowIndex : this.firstDataRow;\n\n        const cellValue = worksheetData.isSpecialData ?\n            fullRow.data :\n            fullRow.data[key];\n\n        if (cellValue === GRID_LEVEL_COL || key === GRID_LEVEL_COL) {\n            columnName = ExcelStrings.getExcelColumn(worksheetData.columnCount + 1) + (this.rowIndex);\n        }\n\n        if (worksheetData.hasSummaries && (isValidRecordType || (worksheetData.isGroupedGrid && isSummaryRecord))) {\n            this.setSummaryCoordinates(columnName, key, fullRow.hierarchicalOwner, worksheetData.isGroupedGrid && isSummaryRecord)\n        }\n\n        if (fullRow.summaryKey && fullRow.summaryKey === GRID_ROOT_SUMMARY && key !== GRID_LEVEL_COL && worksheetData.isGroupedGrid) {\n            this.setRootSummaryStartCoordinate(column, key);\n\n            if (this.firstColumn > column) {\n                this.setRootSummaryStartCoordinate(worksheetData.columnCount + 1, GRID_LEVEL_COL);\n                this.firstColumn = column;\n            }\n        }\n\n        const targetColArr = Array.from(worksheetData.owners.values()).map(arr => arr.columns).find(product => product.some(item => item.field === key));\n        const targetCol = targetColArr ? targetColArr.find(col => col.field === key) : undefined;\n\n        if ((cellValue === undefined || cellValue === null) && !worksheetData.hasSummaries) {\n            return `<c r=\"${columnName}\" s=\"1\"/>`;\n        } else if ((worksheetData.hasSummaries && (isValidRecordType || isHeaderRecord)) || !worksheetData.hasSummaries) {\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 isTime = targetCol?.dataType === 'time';\n            const isDateTime = targetCol?.dataType === 'dateTime';\n            const isPercentage = targetCol?.dataType === 'percent';\n            const isColumnCurrencyType = targetCol?.dataType === 'currency';\n\n            const format = isPercentage ? ` s=\"12\"` : isDateTime ? ` s=\"11\"` : isTime ? ` s=\"10\"` : isHeaderRecord ? ` s=\"3\"` : isSavedAsString ? '' : isSavedAsDate ? ` s=\"2\"` : isColumnCurrencyType ? ` s=\"${this.currencyStyleMap.get(targetCol.currencyCode)?.styleXf || 0}\"` : ` s=\"1\"`;\n\n            return `<c r=\"${columnName}\"${type}${format}><v>${value}</v></c>`;\n        } else {\n            let summaryFunc = `\"${cellValue ?? \"\"}\"`;\n\n            if (isSummaryRecord && cellValue) {\n                const dimensionMapKey = this.isValidGrid ? fullRow.hierarchicalOwner ?? GRID_PARENT : null;\n                const level = worksheetData.isGroupedGrid ? worksheetData.maxLevel : fullRow.level;\n\n                summaryFunc = this.getSummaryFunction(cellValue.label, key, dimensionMapKey, level, targetCol);\n\n                if (!summaryFunc) {\n                    const cellStr = `${cellValue.label}: ${cellValue.value}`;\n                    const savedValue = dictionary.saveValue(cellStr, false);\n                    return `<c r=\"${columnName}\" t=\"s\" s=\"1\"><v>${savedValue}</v></c>`;\n                }\n\n                return `<c r=\"${columnName}\"><f t=\"array\" ref=\"${columnName}\">${summaryFunc}</f></c>`;\n            }\n\n            return `<c r=\"${columnName}\" s=\"1\"><f>${summaryFunc}</f></c>`;\n        }\n    }\n\n    private resolveSummaryDimensions(record: IExportRecord, isDataRecord: boolean, isGroupedGrid: boolean) {\n        if (this.isValidGrid &&\n            this.currentHierarchicalOwner !== '' &&\n            this.currentHierarchicalOwner !== record.owner &&\n            !this.hierarchicalDimensionMap.get(this.currentHierarchicalOwner)) {\n            this.hierarchicalDimensionMap.set(this.currentHierarchicalOwner, new Map(this.dimensionMap))\n        }\n\n        if (isDataRecord) {\n            if (this.currentSummaryOwner !== record.summaryKey || this.currentHierarchicalOwner !== record.hierarchicalOwner) {\n                this.dimensionMap.clear();\n            }\n\n            this.currentSummaryOwner = record.summaryKey;\n\n            // For grouped grid we need to reset the parent map\n            // so we can change the startCoordinate for each record\n            if (isGroupedGrid && this.currentHierarchicalOwner !== '' && record.hierarchicalOwner === GRID_PARENT) {\n                this.hierarchicalDimensionMap.delete(GRID_PARENT)\n            }\n\n            this.currentHierarchicalOwner = record.hierarchicalOwner;\n        }\n    }\n\n    private setSummaryCoordinates(columnName: string, key: string, hierarchicalOwner: string, useLastValidEndCoordinate: boolean) {\n        const targetDimensionMap = this.hierarchicalDimensionMap.get(hierarchicalOwner) ?? this.dimensionMap;\n\n        if (!targetDimensionMap.get(key)) {\n            const initialDimensions: Dimensions = {\n                startCoordinate: columnName,\n                endCoordinate: columnName\n            };\n\n            targetDimensionMap.set(key, initialDimensions)\n        } else {\n            if (useLastValidEndCoordinate) {\n                this.setEndCoordinates(targetDimensionMap, true);\n            } else {\n                targetDimensionMap.get(key).endCoordinate = columnName;\n                this.lastValidRow = targetDimensionMap.get(key).endCoordinate.match(/[a-z]+|[^a-z]+/gi)[1]\n            }\n        }\n\n        if (this.isValidGrid && !useLastValidEndCoordinate && hierarchicalOwner !== GRID_PARENT) {\n            const parentMap = this.hierarchicalDimensionMap.get(GRID_PARENT);\n            this.setEndCoordinates(parentMap);\n        }\n    }\n\n    private setEndCoordinates(map: Map<string, Dimensions>, useLastValidEndCoordinate = false) {\n        for (const a of map.values()) {\n            const colName = a.endCoordinate.match(/[a-z]+|[^a-z]+/gi)[0];\n            a.endCoordinate = `${colName}${useLastValidEndCoordinate ? this.lastValidRow : this.rowIndex}`;\n         }\n    }\n\n    private getSummaryFunction(type: string, key: string, dimensionMapKey: any, recordLevel: number, col: IColumnInfo): string {\n        const dimensionMap = dimensionMapKey ? this.hierarchicalDimensionMap.get(dimensionMapKey) : this.dimensionMap;\n        const dimensions = dimensionMap.get(key);\n        const levelDimensions = dimensionMap.get(GRID_LEVEL_COL);\n\n        let func = '';\n        let funcType = '';\n        let result = '';\n        const currencyInfo = this.currencyStyleMap.get(col.currencyCode);\n\n        switch(type.toLowerCase()) {\n            case \"count\":\n                return `\"Count: \"&amp;_xlfn.COUNTIF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}, ${recordLevel})`\n            case \"min\":\n                func = `_xlfn.MIN(_xlfn.IF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}=${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate}))`\n                funcType = `\"Min: \"&amp;`;\n\n                result = funcType + (col.dataType === 'currency' && currencyInfo\n                    ? `_xlfn.TEXT(${func}, \"${currencyInfo.symbol}#,##0.00\")`\n                    : `${func}`);\n\n                return result\n            case \"max\":\n                func = `_xlfn.MAX(_xlfn.IF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}=${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate}))`\n                funcType = `\"Max: \"&amp;`;\n\n                result = funcType + (col.dataType === 'currency' && currencyInfo\n                    ? `_xlfn.TEXT(${func}, \"${currencyInfo.symbol}#,##0.00\")`\n                    : `${func}`);\n\n                return result\n            case \"sum\":\n                func =  `_xlfn.SUMIF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}, ${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate})`\n                funcType = `\"Sum: \"&amp;`;\n\n                result = funcType + (col.dataType === 'currency' && currencyInfo\n                    ? `_xlfn.TEXT(${func}, \"${currencyInfo.symbol}#,##0.00\")`\n                    : `${func}`);\n\n                return result\n            case \"avg\":\n                func = `_xlfn.AVERAGEIF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}, ${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate})`\n                funcType = `\"Avg: \"&amp;`;\n\n                result = funcType + (col.dataType === 'currency' && currencyInfo\n                    ? `_xlfn.TEXT(${func}, \"${currencyInfo.symbol}#,##0.00\")`\n                    : `${func}`);\n\n                return result\n            case \"earliest\":\n                // TODO: get date format from locale\n                return `\"Earliest: \"&amp;_xlfn.TEXT(_xlfn.MIN(_xlfn.IF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}=${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate})), \"m/d/yyyy\")`\n            case \"latest\":\n                // TODO: get date format from locale\n                return `\"Latest: \"&amp;_xlfn.TEXT(_xlfn.MAX(_xlfn.IF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}=${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate})), \"m/d/yyyy\")`\n        }\n    }\n\n    private setRootSummaryStartCoordinate(column: number, key: string) {\n        const firstDataRecordColName = ExcelStrings.getExcelColumn(column) + (this.firstDataRow);\n        const targetMap = this.hierarchicalDimensionMap.get(GRID_PARENT);\n\n        if (targetMap.get(key).startCoordinate !== firstDataRecordColName) {\n            targetMap.get(key).startCoordinate = firstDataRecordColName;\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 && currentCol.headerType !== ExportHeaderType.PivotMergedHeader) {\n                let columnCoordinate;\n                const column = isVertical\n                    ? this.rowIndex\n                    : startValue + (owner.maxRowLevel ?? 0)\n\n                let rowCoordinate = isVertical\n                    ? startValue + owner.maxLevel + 2\n                    : this.rowIndex\n                if (currentCol.headerType === ExportHeaderType.PivotRowHeader) {\n                    rowCoordinate = startValue + 1;\n                }\n                const columnValue = dictionary.saveValue(currentCol.header, true, false);\n\n                columnCoordinate = (currentCol.field === GRID_LEVEL_COL\n                    ? ExcelStrings.getExcelColumn(worksheetData.columnCount + 1)\n                    : ExcelStrings.getExcelColumn(column)) + rowCoordinate;\n\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 === ExportHeaderType.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                    if ((currentCol.headerType === ExportHeaderType.RowHeader || currentCol.headerType === ExportHeaderType.MultiRowHeader) &&\n                        currentCol.columnSpan && currentCol.columnSpan > 1 ) {\n                        columnCoordinate = ExcelStrings.getExcelColumn(column + currentCol.columnSpan - 1) + (rowCoordinate + spanLength - 1);\n                    }\n\n                    this.mergeCellStr += `${columnCoordinate}\" />`;\n                }\n            }\n            if (currentCol.headerType !== ExportHeaderType.PivotRowHeader) {\n                startValue += spanLength;\n            }\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"]}
658
+ //# 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 { ExportHeaderType, ExportRecordType, IExportRecord, IColumnList, IColumnInfo, GRID_ROOT_SUMMARY, GRID_PARENT, GRID_LEVEL_COL } 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\ninterface Dimensions {\n    startCoordinate: string\n    endCoordinate: string\n}\n\ninterface CurrencyInfo {\n    styleXf: number\n    symbol: string\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    private dimensionMap: Map<string, Dimensions> = new Map<string, Dimensions>();\n    private hierarchicalDimensionMap: Map<any,  Map<string, Dimensions>> = new Map<any,  Map<string, Dimensions>>();\n    private currentSummaryOwner = '';\n    private currentHierarchicalOwner = '';\n    private firstColumn = Number.MAX_VALUE;\n    private firstDataRow = Number.MAX_VALUE;\n    private isValidGrid: boolean;\n    private lastValidRow: string;\n\n    private currencyStyleMap = new Map<string, CurrencyInfo>([\n        ['USD', {styleXf: 5, symbol: '$'}],\n        ['GBP', {styleXf: 6, symbol: '£'}],\n        ['CNY', {styleXf: 7, symbol: '¥'}],\n        ['EUR', {styleXf: 8, symbol: '€'}],\n        ['JPY', {styleXf: 9, symbol: '¥'}],\n    ]);\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\n            this.isValidGrid = worksheetData.isHierarchical || worksheetData.isTreeGrid || worksheetData.isGroupedGrid;\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 !== ExportHeaderType.RowHeader &&\n                     c.headerType !== ExportHeaderType.MultiRowHeader &&\n                     c.headerType !== ExportHeaderType.PivotRowHeader &&\n                     c.headerType !== ExportHeaderType.PivotMergedHeader);\n\n                headersForLevel = hasMultiColumnHeader ?\n                    allowedColumns\n                        .filter(c => (c.level < i &&\n                            c.headerType !== ExportHeaderType.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                const col = worksheetData.hasSummaries ? worksheetData.columnCount + 1 : worksheetData.columnCount - 1\n                this.dimension = 'A1:' + ExcelStrings.getExcelColumn(col) + (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                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\"/>`;\n\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            if (worksheetData.hasSummaries) {\n                cols += `<col min=\"${worksheetData.columnCount + 2}\" max=\"${worksheetData.columnCount + 2}\" hidden=\"1\"/>`;\n            }\n\n            cols += '</cols>';\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 === ExportHeaderType.ColumnHeader && !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 === ExportHeaderType.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 !== ExportHeaderType.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 === ExportHeaderType.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] = `<row r=\"${this.rowIndex}\"${this.rowHeight}${outlineLevel}${sHidden}>${pivotGridColumns}`;\n        const keys = worksheetData.isSpecialData ? [record.data] : headersForLevel;\n        const isDataRecord = record.type === ExportRecordType.HierarchicalGridRecord\n            || record.type === ExportRecordType.DataRecord\n            || record.type === ExportRecordType.GroupedRecord\n            || record.type === ExportRecordType.TreeGridRecord;\n\n        const isValidRecordType = isDataRecord || record.type === ExportRecordType.SummaryRecord;\n\n        if (isValidRecordType && worksheetData.hasSummaries) {\n            this.resolveSummaryDimensions(record, isDataRecord, worksheetData.isGroupedGrid)\n        }\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        let columnName = ExcelStrings.getExcelColumn(column) + (this.rowIndex);\n        const fullRow = worksheetData.data[row];\n        const isHeaderRecord = fullRow.type === ExportRecordType.HeaderRecord;\n        const isSummaryRecord = fullRow.type === ExportRecordType.SummaryRecord;\n        const isValidRecordType = fullRow.type === ExportRecordType.GroupedRecord\n            || fullRow.type === ExportRecordType.DataRecord\n            || fullRow.type === ExportRecordType.HierarchicalGridRecord\n            || fullRow.type === ExportRecordType.TreeGridRecord;\n\n        this.firstDataRow = this.firstDataRow > this.rowIndex ? this.rowIndex : this.firstDataRow;\n\n        const cellValue = worksheetData.isSpecialData ?\n            fullRow.data :\n            fullRow.data[key];\n\n        if (cellValue === GRID_LEVEL_COL || key === GRID_LEVEL_COL) {\n            columnName = ExcelStrings.getExcelColumn(worksheetData.columnCount + 1) + (this.rowIndex);\n        }\n\n        if (worksheetData.hasSummaries && (isValidRecordType || (worksheetData.isGroupedGrid && isSummaryRecord))) {\n            this.setSummaryCoordinates(columnName, key, fullRow.hierarchicalOwner, worksheetData.isGroupedGrid && isSummaryRecord)\n        }\n\n        if (fullRow.summaryKey && fullRow.summaryKey === GRID_ROOT_SUMMARY && key !== GRID_LEVEL_COL && worksheetData.isGroupedGrid) {\n            this.setRootSummaryStartCoordinate(column, key);\n\n            if (this.firstColumn > column) {\n                this.setRootSummaryStartCoordinate(worksheetData.columnCount + 1, GRID_LEVEL_COL);\n                this.firstColumn = column;\n            }\n        }\n\n        const targetColArr = Array.from(worksheetData.owners.values()).map(arr => arr.columns).find(product => product.some(item => item.field === key));\n        const targetCol = targetColArr ? targetColArr.find(col => col.field === key) : undefined;\n\n        if ((cellValue === undefined || cellValue === null) && !worksheetData.hasSummaries) {\n            return `<c r=\"${columnName}\" s=\"1\"/>`;\n        } else if ((worksheetData.hasSummaries && (isValidRecordType || isHeaderRecord)) || !worksheetData.hasSummaries) {\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 isTime = targetCol?.dataType === 'time';\n            const isDateTime = targetCol?.dataType === 'dateTime';\n            const isPercentage = targetCol?.dataType === 'percent';\n            const isColumnCurrencyType = targetCol?.dataType === 'currency';\n\n            const format = isPercentage ? ` s=\"12\"` : isDateTime ? ` s=\"11\"` : isTime ? ` s=\"10\"` : isHeaderRecord ? ` s=\"3\"` : isSavedAsString ? '' : isSavedAsDate ? ` s=\"2\"` : isColumnCurrencyType ? ` s=\"${this.currencyStyleMap.get(targetCol.currencyCode)?.styleXf || 0}\"` : ` s=\"1\"`;\n\n            return `<c r=\"${columnName}\"${type}${format}><v>${value}</v></c>`;\n        } else {\n            let summaryFunc = `\"${cellValue ?? \"\"}\"`;\n\n            if (isSummaryRecord && cellValue) {\n                const dimensionMapKey = this.isValidGrid ? fullRow.hierarchicalOwner ?? GRID_PARENT : null;\n                const level = worksheetData.isGroupedGrid ? worksheetData.maxLevel : fullRow.level;\n\n                summaryFunc = this.getSummaryFunction(cellValue.label, key, dimensionMapKey, level, targetCol);\n\n                if (!summaryFunc) {\n                    let summaryValue;\n\n                    const label = cellValue.label?.toString();\n                    const value = cellValue.value?.toString();\n\n                    if (label && value) {\n                        summaryValue = `${cellValue.label}: ${cellValue.value}`;\n                    } else if (label) {\n                        summaryValue = cellValue.label;\n                    } else if (value) {\n                        summaryValue = cellValue.value;\n                    }\n\n                    const savedValue = dictionary.saveValue(summaryValue, false);\n                    const isSavedAsString = savedValue !== -1;\n                    const isSavedAsDate = !isSavedAsString && summaryValue instanceof Date;\n\n                    if (isSavedAsDate) {\n                        const timeZoneOffset = summaryValue.getTimezoneOffset() * 60000;\n                        const isoString = (new Date(summaryValue - timeZoneOffset)).toISOString();\n                        summaryValue = isoString.substring(0, isoString.indexOf('.'));\n                    }\n\n                    const resolvedValue = isSavedAsString ? savedValue : summaryValue;\n                    const type = isSavedAsString ? `t=\"s\"` : isSavedAsDate ? `t=\"d\"` : '';\n                    const style = isSavedAsDate ? `s=\"2\"` : `s=\"1\"`;\n\n                    return `<c r=\"${columnName}\" ${type} ${style}><v>${resolvedValue}</v></c>`;\n                }\n\n                return `<c r=\"${columnName}\"><f t=\"array\" ref=\"${columnName}\">${summaryFunc}</f></c>`;\n            }\n\n            return `<c r=\"${columnName}\" s=\"1\"><f>${summaryFunc}</f></c>`;\n        }\n    }\n\n    private resolveSummaryDimensions(record: IExportRecord, isDataRecord: boolean, isGroupedGrid: boolean) {\n        if (this.isValidGrid &&\n            this.currentHierarchicalOwner !== '' &&\n            this.currentHierarchicalOwner !== record.owner &&\n            !this.hierarchicalDimensionMap.get(this.currentHierarchicalOwner)) {\n            this.hierarchicalDimensionMap.set(this.currentHierarchicalOwner, new Map(this.dimensionMap))\n        }\n\n        if (isDataRecord) {\n            if (this.currentSummaryOwner !== record.summaryKey || this.currentHierarchicalOwner !== record.hierarchicalOwner) {\n                this.dimensionMap.clear();\n            }\n\n            this.currentSummaryOwner = record.summaryKey;\n\n            // For grouped grid we need to reset the parent map\n            // so we can change the startCoordinate for each record\n            if (isGroupedGrid && this.currentHierarchicalOwner !== '' && record.hierarchicalOwner === GRID_PARENT) {\n                this.hierarchicalDimensionMap.delete(GRID_PARENT)\n            }\n\n            this.currentHierarchicalOwner = record.hierarchicalOwner;\n        }\n    }\n\n    private setSummaryCoordinates(columnName: string, key: string, hierarchicalOwner: string, useLastValidEndCoordinate: boolean) {\n        const targetDimensionMap = this.hierarchicalDimensionMap.get(hierarchicalOwner) ?? this.dimensionMap;\n\n        if (!targetDimensionMap.get(key)) {\n            const initialDimensions: Dimensions = {\n                startCoordinate: columnName,\n                endCoordinate: columnName\n            };\n\n            targetDimensionMap.set(key, initialDimensions)\n        } else {\n            if (useLastValidEndCoordinate) {\n                this.setEndCoordinates(targetDimensionMap, true);\n            } else {\n                targetDimensionMap.get(key).endCoordinate = columnName;\n                this.lastValidRow = targetDimensionMap.get(key).endCoordinate.match(/[a-z]+|[^a-z]+/gi)[1]\n            }\n        }\n\n        if (this.isValidGrid && !useLastValidEndCoordinate && hierarchicalOwner !== GRID_PARENT) {\n            const parentMap = this.hierarchicalDimensionMap.get(GRID_PARENT);\n            this.setEndCoordinates(parentMap);\n        }\n    }\n\n    private setEndCoordinates(map: Map<string, Dimensions>, useLastValidEndCoordinate = false) {\n        for (const a of map.values()) {\n            const colName = a.endCoordinate.match(/[a-z]+|[^a-z]+/gi)[0];\n            a.endCoordinate = `${colName}${useLastValidEndCoordinate ? this.lastValidRow : this.rowIndex}`;\n         }\n    }\n\n    private getSummaryFunction(type: string, key: string, dimensionMapKey: any, recordLevel: number, col: IColumnInfo): string {\n        const dimensionMap = dimensionMapKey ? this.hierarchicalDimensionMap.get(dimensionMapKey) : this.dimensionMap;\n        const dimensions = dimensionMap.get(key);\n        const levelDimensions = dimensionMap.get(GRID_LEVEL_COL);\n\n        let func = '';\n        let funcType = '';\n        let result = '';\n        const currencyInfo = this.currencyStyleMap.get(col.currencyCode);\n\n        switch(type?.toString().toLowerCase()) {\n            case \"count\":\n                return `\"Count: \"&amp;_xlfn.COUNTIF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}, ${recordLevel})`\n            case \"min\":\n                func = `_xlfn.MIN(_xlfn.IF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}=${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate}))`\n                funcType = `\"Min: \"&amp;`;\n\n                result = funcType + (col.dataType === 'currency' && currencyInfo\n                    ? `_xlfn.TEXT(${func}, \"${currencyInfo.symbol}#,##0.00\")`\n                    : `${func}`);\n\n                return result\n            case \"max\":\n                func = `_xlfn.MAX(_xlfn.IF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}=${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate}))`\n                funcType = `\"Max: \"&amp;`;\n\n                result = funcType + (col.dataType === 'currency' && currencyInfo\n                    ? `_xlfn.TEXT(${func}, \"${currencyInfo.symbol}#,##0.00\")`\n                    : `${func}`);\n\n                return result\n            case \"sum\":\n                func =  `_xlfn.SUMIF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}, ${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate})`\n                funcType = `\"Sum: \"&amp;`;\n\n                result = funcType + (col.dataType === 'currency' && currencyInfo\n                    ? `_xlfn.TEXT(${func}, \"${currencyInfo.symbol}#,##0.00\")`\n                    : `${func}`);\n\n                return result\n            case \"avg\":\n                func = `_xlfn.AVERAGEIF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}, ${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate})`\n                funcType = `\"Avg: \"&amp;`;\n\n                result = funcType + (col.dataType === 'currency' && currencyInfo\n                    ? `_xlfn.TEXT(${func}, \"${currencyInfo.symbol}#,##0.00\")`\n                    : `${func}`);\n\n                return result\n            case \"earliest\":\n                // TODO: get date format from locale\n                return `\"Earliest: \"&amp;_xlfn.TEXT(_xlfn.MIN(_xlfn.IF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}=${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate})), \"m/d/yyyy\")`\n            case \"latest\":\n                // TODO: get date format from locale\n                return `\"Latest: \"&amp;_xlfn.TEXT(_xlfn.MAX(_xlfn.IF(${levelDimensions.startCoordinate}:${levelDimensions.endCoordinate}=${recordLevel}, ${dimensions.startCoordinate}:${dimensions.endCoordinate})), \"m/d/yyyy\")`\n        }\n    }\n\n    private setRootSummaryStartCoordinate(column: number, key: string) {\n        const firstDataRecordColName = ExcelStrings.getExcelColumn(column) + (this.firstDataRow);\n        const targetMap = this.hierarchicalDimensionMap.get(GRID_PARENT);\n\n        if (targetMap.get(key).startCoordinate !== firstDataRecordColName) {\n            targetMap.get(key).startCoordinate = firstDataRecordColName;\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 && currentCol.headerType !== ExportHeaderType.PivotMergedHeader) {\n                let columnCoordinate;\n                const column = isVertical\n                    ? this.rowIndex\n                    : startValue + (owner.maxRowLevel ?? 0)\n\n                let rowCoordinate = isVertical\n                    ? startValue + owner.maxLevel + 2\n                    : this.rowIndex\n                if (currentCol.headerType === ExportHeaderType.PivotRowHeader) {\n                    rowCoordinate = startValue + 1;\n                }\n                const columnValue = dictionary.saveValue(currentCol.header, true, false);\n\n                columnCoordinate = (currentCol.field === GRID_LEVEL_COL\n                    ? ExcelStrings.getExcelColumn(worksheetData.columnCount + 1)\n                    : ExcelStrings.getExcelColumn(column)) + rowCoordinate;\n\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 === ExportHeaderType.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                    if ((currentCol.headerType === ExportHeaderType.RowHeader || currentCol.headerType === ExportHeaderType.MultiRowHeader) &&\n                        currentCol.columnSpan && currentCol.columnSpan > 1 ) {\n                        columnCoordinate = ExcelStrings.getExcelColumn(column + currentCol.columnSpan - 1) + (rowCoordinate + spanLength - 1);\n                    }\n\n                    this.mergeCellStr += `${columnCoordinate}\" />`;\n                }\n            }\n            if (currentCol.headerType !== ExportHeaderType.PivotRowHeader) {\n                startValue += spanLength;\n            }\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"]}