UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

117 lines 13.7 kB
import { __decorate, __extends, __metadata, __values } from "tslib"; 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'; /** * **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")); * ``` */ var IgxExcelExporterService = /** @class */ (function (_super) { __extends(IgxExcelExporterService, _super); function IgxExcelExporterService() { var _this = _super !== null && _super.apply(this, arguments) || this; /** * 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(); return _this; } IgxExcelExporterService_1 = IgxExcelExporterService; IgxExcelExporterService.populateFolder = function (folder, zip, worksheetData) { var e_1, _a, e_2, _b; try { for (var _c = __values(folder.childFolders(worksheetData)), _d = _c.next(); !_d.done; _d = _c.next()) { var childFolder = _d.value; var folderIntance = ExcelElementsFactory.getExcelFolder(childFolder); var zipFolder = zip.folder(folderIntance.folderName); IgxExcelExporterService_1.populateFolder(folderIntance, zipFolder, worksheetData); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_d && !_d.done && (_a = _c.return)) _a.call(_c); } finally { if (e_1) throw e_1.error; } } try { for (var _e = __values(folder.childFiles(worksheetData)), _f = _e.next(); !_f.done; _f = _e.next()) { var childFile = _f.value; var fileInstance = ExcelElementsFactory.getExcelFile(childFile); fileInstance.writeElement(zip, worksheetData); } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (_f && !_f.done && (_b = _e.return)) _b.call(_e); } finally { if (e_2) throw e_2.error; } } }; IgxExcelExporterService.prototype.exportDataImplementation = function (data, options) { var _this = this; if (this._isTreeGrid) { var maxLevel_1 = 0; data.forEach(function (r) { maxLevel_1 = Math.max(maxLevel_1, r.originalRowData.level); }); if (maxLevel_1 > 7) { throw Error('Can create an outline of up to eight levels!'); } } var worksheetData = new WorksheetData(data, options, this._indexOfLastPinnedColumn, this._sort, this._isTreeGrid); this._xlsx = new JSZip(); var rootFolder = ExcelElementsFactory.getExcelFolder(ExcelFolderTypes.RootExcelFolder); IgxExcelExporterService_1.populateFolder(rootFolder, this._xlsx, worksheetData); this._xlsx.generateAsync(IgxExcelExporterService_1.ZIP_OPTIONS).then(function (result) { _this.saveFile(result, options.fileName); _this.onExportEnded.emit({ xlsx: _this._xlsx }); }); }; IgxExcelExporterService.prototype.saveFile = function (data, fileName) { var blob = new Blob([ExportUtilities.stringToArrayBuffer(atob(data))], { type: '' }); ExportUtilities.saveBlobToFile(blob, fileName); }; var IgxExcelExporterService_1; IgxExcelExporterService.ZIP_OPTIONS = { compression: 'DEFLATE', type: 'base64' }; __decorate([ Output(), __metadata("design:type", Object) ], IgxExcelExporterService.prototype, "onExportEnded", void 0); IgxExcelExporterService = IgxExcelExporterService_1 = __decorate([ Injectable() ], IgxExcelExporterService); return IgxExcelExporterService; }(IgxBaseExporter)); export { IgxExcelExporterService }; //# 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';\nimport { IBaseEventArgs } from '../../core/utils';\n\nexport interface IExcelExportEndedEventArgs extends IBaseEventArgs {\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"]}