igniteui-angular 14.2.23 → 14.2.25
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/card/card.component.mjs +2 -15
- package/esm2020/lib/grids/grid-base.directive.mjs +4 -3
- package/esm2020/lib/services/excel/excel-files.mjs +2 -2
- package/esm2020/lib/services/excel/worksheet-data-dictionary.mjs +4 -17
- package/esm2020/lib/services/exporter-common/base-export-service.mjs +2 -2
- package/esm2020/lib/services/exporter-common/export-utilities.mjs +14 -1
- package/fesm2015/igniteui-angular.mjs +22 -34
- package/fesm2015/igniteui-angular.mjs.map +1 -1
- package/fesm2020/igniteui-angular.mjs +22 -34
- package/fesm2020/igniteui-angular.mjs.map +1 -1
- package/lib/card/card.component.d.ts +0 -10
- package/lib/services/excel/worksheet-data-dictionary.d.ts +1 -2
- package/lib/services/exporter-common/export-utilities.d.ts +1 -0
- package/package.json +1 -1
- package/src/lib/card/README.md +0 -1
|
@@ -321,7 +321,7 @@ export class WorksheetFile {
|
|
|
321
321
|
const rowCoordinate = isVertical
|
|
322
322
|
? startValue + owner.maxLevel + 2
|
|
323
323
|
: this.rowIndex;
|
|
324
|
-
const columnValue = dictionary.saveValue(currentCol.header, true);
|
|
324
|
+
const columnValue = dictionary.saveValue(currentCol.header, true, false);
|
|
325
325
|
columnCoordinate = ExcelStrings.getExcelColumn(column) + rowCoordinate;
|
|
326
326
|
rowStyle = isVertical && currentCol.rowSpan > 1 ? ' s="4"' : rowStyle;
|
|
327
327
|
str = `<c r="${columnCoordinate}"${rowStyle} t="s"><v>${columnValue}</v></c>`;
|
|
@@ -453,4 +453,4 @@ export class WorksheetRelsFile {
|
|
|
453
453
|
folder['sheet1.xml.rels'] = strToU8(ExcelStrings.getWorksheetRels());
|
|
454
454
|
}
|
|
455
455
|
}
|
|
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"]}
|
|
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, false);\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"]}
|
|
@@ -20,12 +20,12 @@ export class WorksheetDataDictionary {
|
|
|
20
20
|
get columnWidths() {
|
|
21
21
|
return this._columnWidths;
|
|
22
22
|
}
|
|
23
|
-
saveValue(value, isHeader) {
|
|
23
|
+
saveValue(value, isHeader, shouldSanitizeValue = true) {
|
|
24
24
|
let sanitizedValue = '';
|
|
25
25
|
const isDate = value instanceof Date;
|
|
26
26
|
const isSavedAsString = isHeader || (typeof value !== 'number' && value !== Number(value) && !Number.isFinite(value) && !isDate);
|
|
27
27
|
if (isSavedAsString) {
|
|
28
|
-
sanitizedValue =
|
|
28
|
+
sanitizedValue = shouldSanitizeValue ? ExportUtilities.sanitizeValue(value) : value;
|
|
29
29
|
if (this._dictionary[sanitizedValue] === undefined) {
|
|
30
30
|
this._dictionary[sanitizedValue] = this._counter++;
|
|
31
31
|
this.dirtyKeyCollections();
|
|
@@ -41,7 +41,7 @@ export class WorksheetDataDictionary {
|
|
|
41
41
|
return isSavedAsString ? this.getSanitizedValue(sanitizedValue) : -1;
|
|
42
42
|
}
|
|
43
43
|
getValue(value) {
|
|
44
|
-
return this.getSanitizedValue(
|
|
44
|
+
return this.getSanitizedValue(ExportUtilities.sanitizeValue(value));
|
|
45
45
|
}
|
|
46
46
|
getSanitizedValue(sanitizedValue) {
|
|
47
47
|
return this._dictionary[sanitizedValue];
|
|
@@ -69,23 +69,10 @@ export class WorksheetDataDictionary {
|
|
|
69
69
|
}
|
|
70
70
|
return this._context;
|
|
71
71
|
}
|
|
72
|
-
sanitizeValue(value) {
|
|
73
|
-
if (ExportUtilities.hasValue(value) === false) {
|
|
74
|
-
return '';
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
const stringValue = String(value);
|
|
78
|
-
return stringValue.replace(/&/g, '&')
|
|
79
|
-
.replace(/</g, '<')
|
|
80
|
-
.replace(/>/g, '>')
|
|
81
|
-
.replace(/"/g, '"')
|
|
82
|
-
.replace(/'/g, ''');
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
72
|
dirtyKeyCollections() {
|
|
86
73
|
this._keysAreValid = false;
|
|
87
74
|
}
|
|
88
75
|
}
|
|
89
76
|
WorksheetDataDictionary.DEFAULT_FONT = '11pt Calibri';
|
|
90
77
|
WorksheetDataDictionary.TEXT_PADDING = 5;
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"worksheet-data-dictionary.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/services/excel/worksheet-data-dictionary.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AAEtE,cAAc;AACd,MAAM,OAAO,uBAAuB;IAmBhC,YAAY,WAAmB,EAAE,WAAmB,EAAE,gBAA0B;QAfzE,oBAAe,GAAG,KAAK,CAAC;QACxB,kBAAa,GAAG,KAAK,CAAC;QAezB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;QAC5B,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;QAClB,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,IAAI,CAAC,aAAa,GAAG,IAAI,KAAK,CAAS,WAAW,CAAC,CAAC;QAEpD,IAAI,WAAW,EAAE;YACb,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACxC;aAAM;YACH,IAAI,CAAC,aAAa,GAAG,gBAAgB,CAAC;SACzC;QAED,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,IAAW,YAAY;QACnB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC9B,CAAC;IAEM,SAAS,CAAC,KAAU,EAAE,QAAiB,EAAE,sBAA+B,IAAI;QAC/E,IAAI,cAAc,GAAG,EAAE,CAAC;QACxB,MAAM,MAAM,GAAG,KAAK,YAAY,IAAI,CAAC;QACrC,MAAM,eAAe,GAAG,QAAQ,IAAI,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEjI,IAAI,eAAe,EAAE;YACjB,cAAc,GAAG,mBAAmB,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YAEpF,IAAI,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,KAAK,SAAS,EAAE;gBAChD,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACnD,IAAI,CAAC,mBAAmB,EAAE,CAAC;aAC9B;YAED,IAAI,CAAC,YAAY,EAAG,CAAC;SACxB;aAAM,IAAI,MAAM,EAAE;YACf,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC7B;aAAM;YACH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC/B;QAED,OAAO,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACzE,CAAC;IAEM,QAAQ,CAAC,KAAa;QACzB,OAAO,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC;IACxE,CAAC;IAEM,iBAAiB,CAAC,cAAsB;QAC3C,OAAO,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;IAC5C,CAAC;IAEM,OAAO;QACV,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAC3C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC7B;QAED,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IAEO,YAAY,CAAC,KAAU;QAC3B,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,SAAS,EAAE;YAC7C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAClC,MAAM,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAC3C,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,KAAK,GAAG,uBAAuB,CAAC,YAAY,CAAC;SACxF;QAED,OAAO,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAEO,UAAU;QACd,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAChB,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAChD,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACxC,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,uBAAuB,CAAC,YAAY,CAAC;SAC7D;QAED,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAEO,mBAAmB;QACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC/B,CAAC;;AArGc,oCAAY,GAAG,cAAc,CAAC;AAC9B,oCAAY,GAAG,CAAC,CAAC","sourcesContent":["import { ExportUtilities } from '../exporter-common/export-utilities';\n\n/** @hidden */\nexport class WorksheetDataDictionary {\n    private static DEFAULT_FONT = '11pt Calibri';\n    private static TEXT_PADDING = 5;\n\n    public hasNumberValues = false;\n    public hasDateValues = false;\n\n    public stringsCount: number;\n\n    private _dictionary: any;\n    private _widthsDictionary: any;\n\n    private _keys: string[];\n    private _keysAreValid: boolean;\n\n    private _counter: number;\n    private _columnWidths: number[];\n    private _context: any;\n\n    constructor(columnCount: number, columnWidth: number, columnWidthsList: number[]) {\n        this._dictionary = {};\n        this._widthsDictionary = {};\n        this._counter = 0;\n        this.dirtyKeyCollections();\n\n        this._columnWidths = new Array<number>(columnCount);\n\n        if (columnWidth) {\n            this._columnWidths.fill(columnWidth);\n        } else {\n            this._columnWidths = columnWidthsList;\n        }\n\n        this.stringsCount = 0;\n    }\n\n    public get columnWidths() {\n        return this._columnWidths;\n    }\n\n    public saveValue(value: any, isHeader: boolean, shouldSanitizeValue: boolean = true): number {\n        let sanitizedValue = '';\n        const isDate = value instanceof Date;\n        const isSavedAsString = isHeader || (typeof value !== 'number' && value !== Number(value) && !Number.isFinite(value) && !isDate);\n\n        if (isSavedAsString) {\n            sanitizedValue = shouldSanitizeValue ? ExportUtilities.sanitizeValue(value) : value;\n\n            if (this._dictionary[sanitizedValue] === undefined) {\n                this._dictionary[sanitizedValue] = this._counter++;\n                this.dirtyKeyCollections();\n            }\n\n            this.stringsCount ++;\n        } else if (isDate) {\n            this.hasDateValues = true;\n        } else {\n            this.hasNumberValues = true;\n        }\n\n        return isSavedAsString ? this.getSanitizedValue(sanitizedValue) : -1;\n    }\n\n    public getValue(value: string): number {\n        return this.getSanitizedValue(ExportUtilities.sanitizeValue(value));\n    }\n\n    public getSanitizedValue(sanitizedValue: string): number {\n        return this._dictionary[sanitizedValue];\n    }\n\n    public getKeys(): string[] {\n        if (!this._keysAreValid) {\n            this._keys = Object.keys(this._dictionary);\n            this._keysAreValid = true;\n        }\n\n        return this._keys;\n    }\n\n    private getTextWidth(value: any): number {\n        if (this._widthsDictionary[value] === undefined) {\n            const context = this.getContext();\n            const metrics = context.measureText(value);\n            this._widthsDictionary[value] = metrics.width + WorksheetDataDictionary.TEXT_PADDING;\n        }\n\n        return this._widthsDictionary[value];\n    }\n\n    private getContext(): any {\n        if (!this._context) {\n            const canvas = document.createElement('canvas');\n            this._context = canvas.getContext('2d');\n            this._context.font = WorksheetDataDictionary.DEFAULT_FONT;\n        }\n\n        return this._context;\n    }\n\n    private dirtyKeyCollections(): void {\n        this._keysAreValid = false;\n    }\n}\n"]}
|