igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
148 lines • 13.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as JSZip from 'jszip/dist/jszip';
import { EventEmitter, Injectable, Output } from '@angular/core';
import { ExcelElementsFactory } from './excel-elements-factory';
import { ExcelFolderTypes } from './excel-enums';
import { IgxBaseExporter } from '../exporter-common/base-export-service';
import { ExportUtilities } from '../exporter-common/export-utilities';
import { WorksheetData } from './worksheet-data';
/**
* @record
*/
export function IExcelExportEndedEventArgs() { }
if (false) {
/** @type {?} */
IExcelExportEndedEventArgs.prototype.xlsx;
}
/**
* **Ignite UI for Angular Excel Exporter Service** -
* [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/exporter_excel.html)
*
* The Ignite UI for Angular Excel Exporter service can export data in Microsoft® Excel® format from both raw data
* (array) or from an `IgxGrid`.
*
* Example:
* ```typescript
* public localData = [
* { Name: "Eric Ridley", Age: "26" },
* { Name: "Alanis Brook", Age: "22" },
* { Name: "Jonathan Morris", Age: "23" }
* ];
*
* constructor(private excelExportService: IgxExcelExporterService) {
* }
*
* this.excelExportService.exportData(this.localData, new IgxExcelExporterOptions("FileName"));
* ```
*/
export class IgxExcelExporterService extends IgxBaseExporter {
constructor() {
super(...arguments);
/**
* This event is emitted when the export process finishes.
* ```typescript
* this.exporterService.onExportEnded.subscribe((args: IExcelExportEndedEventArgs) => {
* // put event handler code here
* });
* ```
* \@memberof IgxExcelExporterService
*/
this.onExportEnded = new EventEmitter();
}
/**
* @private
* @param {?} folder
* @param {?} zip
* @param {?} worksheetData
* @return {?}
*/
static populateFolder(folder, zip, worksheetData) {
for (const childFolder of folder.childFolders(worksheetData)) {
/** @type {?} */
const folderIntance = ExcelElementsFactory.getExcelFolder(childFolder);
/** @type {?} */
const zipFolder = zip.folder(folderIntance.folderName);
IgxExcelExporterService.populateFolder(folderIntance, zipFolder, worksheetData);
}
for (const childFile of folder.childFiles(worksheetData)) {
/** @type {?} */
const fileInstance = ExcelElementsFactory.getExcelFile(childFile);
fileInstance.writeElement(zip, worksheetData);
}
}
/**
* @protected
* @param {?} data
* @param {?} options
* @return {?}
*/
exportDataImplementation(data, options) {
if (this._isTreeGrid) {
/** @type {?} */
let maxLevel = 0;
data.forEach((r) => {
maxLevel = Math.max(maxLevel, r.originalRowData.level);
});
if (maxLevel > 7) {
throw Error('Can create an outline of up to eight levels!');
}
}
/** @type {?} */
const worksheetData = new WorksheetData(data, options, this._indexOfLastPinnedColumn, this._sort, this._isTreeGrid);
this._xlsx = new JSZip();
/** @type {?} */
const rootFolder = ExcelElementsFactory.getExcelFolder(ExcelFolderTypes.RootExcelFolder);
IgxExcelExporterService.populateFolder(rootFolder, this._xlsx, worksheetData);
this._xlsx.generateAsync(IgxExcelExporterService.ZIP_OPTIONS).then((result) => {
this.saveFile(result, options.fileName);
this.onExportEnded.emit({ xlsx: this._xlsx });
});
}
/**
* @private
* @param {?} data
* @param {?} fileName
* @return {?}
*/
saveFile(data, fileName) {
/** @type {?} */
const blob = new Blob([ExportUtilities.stringToArrayBuffer(atob(data))], {
type: ''
});
ExportUtilities.saveBlobToFile(blob, fileName);
}
}
IgxExcelExporterService.ZIP_OPTIONS = { compression: 'DEFLATE', type: 'base64' };
IgxExcelExporterService.decorators = [
{ type: Injectable }
];
IgxExcelExporterService.propDecorators = {
onExportEnded: [{ type: Output }]
};
if (false) {
/**
* @type {?}
* @private
*/
IgxExcelExporterService.ZIP_OPTIONS;
/**
* @type {?}
* @private
*/
IgxExcelExporterService.prototype._xlsx;
/**
* This event is emitted when the export process finishes.
* ```typescript
* this.exporterService.onExportEnded.subscribe((args: IExcelExportEndedEventArgs) => {
* // put event handler code here
* });
* ```
* \@memberof IgxExcelExporterService
* @type {?}
*/
IgxExcelExporterService.prototype.onExportEnded;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-exporter.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/services/excel/excel-exporter.ts"],"names":[],"mappings":"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","sourcesContent":["import * as JSZip from 'jszip/dist/jszip';\n\nimport { EventEmitter, Injectable, Output } from '@angular/core';\nimport { ExcelElementsFactory } from './excel-elements-factory';\nimport { ExcelFolderTypes } from './excel-enums';\nimport { IgxExcelExporterOptions } from './excel-exporter-options';\nimport { IExcelFolder } from './excel-interfaces';\nimport { IgxBaseExporter } from '../exporter-common/base-export-service';\nimport { ExportUtilities } from '../exporter-common/export-utilities';\nimport { WorksheetData } from './worksheet-data';\n\nexport interface IExcelExportEndedEventArgs {\n    xlsx: JSZip;\n}\n\n/**\n * **Ignite UI for Angular Excel Exporter Service** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/exporter_excel.html)\n *\n * The Ignite UI for Angular Excel Exporter service can export data in Microsoft® Excel® format from both raw data\n * (array) or from an `IgxGrid`.\n *\n * Example:\n * ```typescript\n * public localData = [\n *   { Name: \"Eric Ridley\", Age: \"26\" },\n *   { Name: \"Alanis Brook\", Age: \"22\" },\n *   { Name: \"Jonathan Morris\", Age: \"23\" }\n * ];\n *\n * constructor(private excelExportService: IgxExcelExporterService) {\n * }\n *\n * this.excelExportService.exportData(this.localData, new IgxExcelExporterOptions(\"FileName\"));\n * ```\n */\n@Injectable()\nexport class IgxExcelExporterService extends IgxBaseExporter {\n\n    private static ZIP_OPTIONS = { compression: 'DEFLATE', type: 'base64' };\n    private _xlsx: JSZip;\n\n    /**\n     * This event is emitted when the export process finishes.\n     * ```typescript\n     * this.exporterService.onExportEnded.subscribe((args: IExcelExportEndedEventArgs) => {\n     * // put event handler code here\n     * });\n     * ```\n     * @memberof IgxExcelExporterService\n     */\n    @Output()\n    public onExportEnded = new EventEmitter<IExcelExportEndedEventArgs>();\n\n    private static populateFolder(folder: IExcelFolder, zip: JSZip, worksheetData: WorksheetData): any {\n        for (const childFolder of folder.childFolders(worksheetData)) {\n            const folderIntance = ExcelElementsFactory.getExcelFolder(childFolder);\n            const zipFolder = zip.folder(folderIntance.folderName);\n            IgxExcelExporterService.populateFolder(folderIntance, zipFolder, worksheetData);\n        }\n\n        for (const childFile of folder.childFiles(worksheetData)) {\n            const fileInstance = ExcelElementsFactory.getExcelFile(childFile);\n            fileInstance.writeElement(zip, worksheetData);\n        }\n    }\n\n    protected exportDataImplementation(data: any[], options: IgxExcelExporterOptions): void {\n        if (this._isTreeGrid) {\n            let maxLevel = 0;\n            data.forEach((r) => {\n                maxLevel = Math.max(maxLevel, r.originalRowData.level);\n            });\n            if (maxLevel > 7) {\n                throw Error('Can create an outline of up to eight levels!');\n            }\n        }\n\n        const worksheetData = new WorksheetData(data, options, this._indexOfLastPinnedColumn, this._sort, this._isTreeGrid);\n        this._xlsx = new JSZip();\n\n        const rootFolder = ExcelElementsFactory.getExcelFolder(ExcelFolderTypes.RootExcelFolder);\n        IgxExcelExporterService.populateFolder(rootFolder, this._xlsx, worksheetData);\n\n        this._xlsx.generateAsync(IgxExcelExporterService.ZIP_OPTIONS).then((result) => {\n            this.saveFile(result, options.fileName);\n\n            this.onExportEnded.emit({ xlsx: this._xlsx });\n        });\n    }\n\n    private saveFile(data: string, fileName: string): void {\n        const blob = new Blob([ExportUtilities.stringToArrayBuffer(atob(data))], {\n            type: ''\n        });\n\n        ExportUtilities.saveBlobToFile(blob, fileName);\n    }\n}\n"]}