New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

cdk-table-exporter

Package Overview
Dependencies
Maintainers
1
Versions
31
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

cdk-table-exporter - npm Package Compare versions

Comparing version 1.0.0 to 1.0.1

2

bundles/cdk-table-exporter.umd.js

@@ -103,3 +103,3 @@ (function (global, factory) {

this.extractDataOnCurrentPage();
this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);
this.exportExtractedData();
};

@@ -106,0 +106,0 @@ /**

@@ -1,2 +0,2 @@

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("xlsx")):"function"==typeof define&&define.amd?define("cdk-table-exporter",["exports","@angular/core","xlsx"],e):e(t["cdk-table-exporter"]={},t.ng.core,t.XLSX)}(this,function(t,r,p){"use strict";var e=function(){function t(){}return t.decorators=[{type:r.NgModule,args:[{declarations:[],imports:[],exports:[]}]}],t}(),o=function(){function t(t,e){this.renderer=t,this.jsonExporter=e,this.sheetName="Sheet1",this.fileName="export.xlsx",this.exportCompleted=new r.EventEmitter,this.exportStarted=new r.EventEmitter}return t.prototype.ngAfterViewInit=function(){var e=this;this.renderer.listen(this.exporterButton._elementRef.nativeElement,"click",function(t){e.exportTable()})},t.prototype.exportTable=function(){this.exportStarted.emit(),this._isIterating=!0,this._isExporting=!0,this._data=new Array,this.enableExportButton(!1);try{this.exportWithPagination()}catch(t){this.exportSinglePage()}},t.prototype.exportWithPagination=function(){this._initialPageIndex=this.getCurrentPageIndex(),this.initPageHandler(),this.goToPage(0)},t.prototype.exportSinglePage=function(){this.extractDataOnCurrentPage(),this.jsonExporter.exportExcel(this.extractExcelHeaderRow(),this._data,this.fileName,this.sheetName)},t.prototype.extractDataOnCurrentPage=function(){this._data=this._data.concat(this.extractExcelRows())},t.prototype.initPageHandler=function(){var e=this;this.getPageChangeObservable().subscribe(function(t){setTimeout(function(){e._isIterating?(e.extractDataOnCurrentPage(),e.hasNextPage()?e.nextPage():(e._isIterating=!1,e.goToPage(e._initialPageIndex))):e._isExporting&&(e._isExporting=!1,e.exportExtractedData())})})},t.prototype.exportExtractedData=function(){this.jsonExporter.exportExcel(this.extractExcelHeaderRow(),this._data,this.fileName,this.sheetName),this._data=new Array,this.enableExportButton(!0),this.exportCompleted.emit()},t.prototype.extractExcelRows=function(){return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._rowOutlet))},t.prototype.extractExcelHeaderRow=function(){return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._headerRowOutlet))[0]},t.prototype.getRenderedRows=function(t){return this.cdkTable._getRenderedRows(t)},t.prototype.convertToJsonArray=function(t){for(var e=new Array,r=0;r<t.length;r++){var o=this.convertRow(t[r]);this.customizeRow(o),e.push(this.createExcelItem(o))}return e},t.prototype.convertRow=function(t){for(var e=new Array,r=t.children,o=0;o<r.length;o++)if(!this.shouldHide(o)){var n=r.item(o).innerText;e.push(n)}return e},t.prototype.shouldHide=function(t){return!(!this.hiddenColumns||!this.hiddenColumns.includes(t))},t.prototype.customizeRow=function(t){return t},t.prototype.createExcelItem=function(t){return Object.assign({},t)},t.prototype.hasNextPage=function(){return this.getCurrentPageIndex()<this.getPageCount()-1},t.prototype.nextPage=function(){this.goToPage(this.getCurrentPageIndex()+1)},t.prototype.enableExportButton=function(t){this.renderer.setProperty(this.exporterButton._elementRef.nativeElement,"disabled",t?null:"true")},t.propDecorators={cdkTable:[{type:r.Input}],exporterButton:[{type:r.Input}],sheetName:[{type:r.Input}],fileName:[{type:r.Input}],hiddenColumns:[{type:r.Input}],exportCompleted:[{type:r.Output}],exportStarted:[{type:r.Output}]},t}(),n=function(){function t(){}return t.prototype.exportExcel=function(t,e,r,o,n){if(e.unshift(t),n)for(var i=0;i<e.length;i++)e[i]=this.hideColumns(n,e[i]);var a=p.utils.book_new(),s=p.utils.json_to_sheet(e,{skipHeader:!0});p.utils.book_append_sheet(a,s,o),r=this.appendExtensionIfNotProvided(r),p.writeFile(a,r)},t.prototype.hideColumns=function(t,e){for(var r=0;r<t.length;r++){delete e[t[r]]}},t.prototype.appendExtensionIfNotProvided=function(t){return t.includes(i.XLSX)||t.includes(i.XLS)||(t=t.concat(i.XLSX)),t},t.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],t.ctorParameters=function(){return[]},t.ngInjectableDef=r.defineInjectable({factory:function(){return new t},token:t,providedIn:"root"}),t}(),i={XLSX:".xlsx",XLS:".xls"};t.CdkTableExporter=o,t.JsonExporterService=n,t.CdkTableExporterModule=e,Object.defineProperty(t,"__esModule",{value:!0})});
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("xlsx")):"function"==typeof define&&define.amd?define("cdk-table-exporter",["exports","@angular/core","xlsx"],e):e(t["cdk-table-exporter"]={},t.ng.core,t.XLSX)}(this,function(t,r,p){"use strict";var e=function(){function t(){}return t.decorators=[{type:r.NgModule,args:[{declarations:[],imports:[],exports:[]}]}],t}(),n=function(){function t(t,e){this.renderer=t,this.jsonExporter=e,this.sheetName="Sheet1",this.fileName="export.xlsx",this.exportCompleted=new r.EventEmitter,this.exportStarted=new r.EventEmitter}return t.prototype.ngAfterViewInit=function(){var e=this;this.renderer.listen(this.exporterButton._elementRef.nativeElement,"click",function(t){e.exportTable()})},t.prototype.exportTable=function(){this.exportStarted.emit(),this._isIterating=!0,this._isExporting=!0,this._data=new Array,this.enableExportButton(!1);try{this.exportWithPagination()}catch(t){this.exportSinglePage()}},t.prototype.exportWithPagination=function(){this._initialPageIndex=this.getCurrentPageIndex(),this.initPageHandler(),this.goToPage(0)},t.prototype.exportSinglePage=function(){this.extractDataOnCurrentPage(),this.exportExtractedData()},t.prototype.extractDataOnCurrentPage=function(){this._data=this._data.concat(this.extractExcelRows())},t.prototype.initPageHandler=function(){var e=this;this.getPageChangeObservable().subscribe(function(t){setTimeout(function(){e._isIterating?(e.extractDataOnCurrentPage(),e.hasNextPage()?e.nextPage():(e._isIterating=!1,e.goToPage(e._initialPageIndex))):e._isExporting&&(e._isExporting=!1,e.exportExtractedData())})})},t.prototype.exportExtractedData=function(){this.jsonExporter.exportExcel(this.extractExcelHeaderRow(),this._data,this.fileName,this.sheetName),this._data=new Array,this.enableExportButton(!0),this.exportCompleted.emit()},t.prototype.extractExcelRows=function(){return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._rowOutlet))},t.prototype.extractExcelHeaderRow=function(){return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._headerRowOutlet))[0]},t.prototype.getRenderedRows=function(t){return this.cdkTable._getRenderedRows(t)},t.prototype.convertToJsonArray=function(t){for(var e=new Array,r=0;r<t.length;r++){var n=this.convertRow(t[r]);this.customizeRow(n),e.push(this.createExcelItem(n))}return e},t.prototype.convertRow=function(t){for(var e=new Array,r=t.children,n=0;n<r.length;n++)if(!this.shouldHide(n)){var o=r.item(n).innerText;e.push(o)}return e},t.prototype.shouldHide=function(t){return!(!this.hiddenColumns||!this.hiddenColumns.includes(t))},t.prototype.customizeRow=function(t){return t},t.prototype.createExcelItem=function(t){return Object.assign({},t)},t.prototype.hasNextPage=function(){return this.getCurrentPageIndex()<this.getPageCount()-1},t.prototype.nextPage=function(){this.goToPage(this.getCurrentPageIndex()+1)},t.prototype.enableExportButton=function(t){this.renderer.setProperty(this.exporterButton._elementRef.nativeElement,"disabled",t?null:"true")},t.propDecorators={cdkTable:[{type:r.Input}],exporterButton:[{type:r.Input}],sheetName:[{type:r.Input}],fileName:[{type:r.Input}],hiddenColumns:[{type:r.Input}],exportCompleted:[{type:r.Output}],exportStarted:[{type:r.Output}]},t}(),o=function(){function t(){}return t.prototype.exportExcel=function(t,e,r,n,o){if(e.unshift(t),o)for(var i=0;i<e.length;i++)e[i]=this.hideColumns(o,e[i]);var a=p.utils.book_new(),s=p.utils.json_to_sheet(e,{skipHeader:!0});p.utils.book_append_sheet(a,s,n),r=this.appendExtensionIfNotProvided(r),p.writeFile(a,r)},t.prototype.hideColumns=function(t,e){for(var r=0;r<t.length;r++){delete e[t[r]]}},t.prototype.appendExtensionIfNotProvided=function(t){return t.includes(i.XLSX)||t.includes(i.XLS)||(t=t.concat(i.XLSX)),t},t.decorators=[{type:r.Injectable,args:[{providedIn:"root"}]}],t.ctorParameters=function(){return[]},t.ngInjectableDef=r.defineInjectable({factory:function(){return new t},token:t,providedIn:"root"}),t}(),i={XLSX:".xlsx",XLS:".xls"};t.CdkTableExporter=n,t.JsonExporterService=o,t.CdkTableExporterModule=e,Object.defineProperty(t,"__esModule",{value:!0})});
//# sourceMappingURL=cdk-table-exporter.umd.min.js.map

@@ -67,3 +67,3 @@ /**

this.extractDataOnCurrentPage();
this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);
this.exportExtractedData();
}

@@ -314,2 +314,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-table-exporter.js","sourceRoot":"ng://cdk-table-exporter/","sources":["lib/cdk-table-exporter.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataRowOutlet } from '@angular/cdk/table';\r\nimport { AfterViewInit, EventEmitter, Input, Output, Renderer2 } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { JsonExporterService } from './json-exporter.service';\r\n\r\n/**\r\n * Excel exporter class for CdkTable. Abstracts the varying behaviors among different CdkTable implementations.\r\n */\r\nexport abstract class CdkTableExporter implements AfterViewInit {\r\n\r\n  @Input() cdkTable: any;\r\n  @Input() exporterButton: any;\r\n  @Input() sheetName = 'Sheet1';\r\n  @Input() fileName = 'export.xlsx';\r\n  @Input() hiddenColumns: Array<number>;\r\n  @Output() exportCompleted = new EventEmitter<void>();\r\n  @Output() exportStarted = new EventEmitter<void>();\r\n\r\n  /**\r\n   * Data array which is extracted from nativeTable\r\n   */\r\n  private _data: Array<any>;\r\n\r\n  private _isIterating: boolean;\r\n\r\n  private _initialPageIndex: number;\r\n\r\n  private _isExporting: boolean;\r\n\r\n  constructor(protected renderer: Renderer2, protected jsonExporter: JsonExporterService) {\r\n\r\n  }\r\n\r\n  /**\r\n   * Must return the number of pages of the table\r\n   */\r\n  public abstract getPageCount(): number;\r\n\r\n  /**\r\n   * Must return the index of the current page that's displayed\r\n   */\r\n  public abstract getCurrentPageIndex(): number;\r\n\r\n  /**\r\n   * When called, the CdkTable should render the rows inside the page whose index given as parameter\r\n   * @param index page index\r\n   */\r\n  public abstract goToPage(index: number): void;\r\n\r\n  /**\r\n   * Must return an observable that notifies the subscribers about page changes\r\n   */\r\n  public abstract getPageChangeObservable(): Observable<any>;\r\n\r\n  ngAfterViewInit(): void {\r\n    this.renderer.listen(this.exporterButton._elementRef.nativeElement, 'click', (evt) => {\r\n     this.exportTable();\r\n    });\r\n  }\r\n\r\n\r\n/**\r\n * Triggers page event chain thus extracting and exporting all the rows in nativetables in pages\r\n */\r\n  exportTable() {\r\n    this.exportStarted.emit();\r\n    this._isIterating = true;\r\n    this._isExporting = true;\r\n    this._data = new Array<any>();\r\n    this.enableExportButton(false);\r\n    try {\r\n      this.exportWithPagination();\r\n    } catch (notPaginated) {\r\n      this.exportSinglePage();\r\n    }\r\n\r\n  }\r\n\r\n  private exportWithPagination() {\r\n    this._initialPageIndex = this.getCurrentPageIndex();\r\n    this.initPageHandler(); // to make sure datasource is not null during export\r\n    this.goToPage(0);\r\n  }\r\n\r\n  private exportSinglePage() {\r\n    this.extractDataOnCurrentPage();\r\n    this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);\r\n  }\r\n\r\n  private extractDataOnCurrentPage() {\r\n    this._data = this._data.concat(this.extractExcelRows());\r\n  }\r\n\r\n\r\n  private initPageHandler(): void {\r\n    this.getPageChangeObservable().subscribe(_ => {\r\n      setTimeout(() => {\r\n        if (this._isIterating) {\r\n          this.extractDataOnCurrentPage();\r\n          if (this.hasNextPage()) {\r\n            this.nextPage();\r\n          } else {\r\n            this._isIterating = false;\r\n            this.goToPage(this._initialPageIndex);\r\n          }\r\n        } else if (this._isExporting) {\r\n          this._isExporting = false;\r\n          this.exportExtractedData();\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  private exportExtractedData() {\r\n    this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);\r\n    this._data = new Array<any>();\r\n    this.enableExportButton(true);\r\n    this.exportCompleted.emit();\r\n  }\r\n\r\n\r\n  private extractExcelRows() {\r\n    return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._rowOutlet));\r\n  }\r\n\r\n  private extractExcelHeaderRow() {\r\n    return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._headerRowOutlet))[0];\r\n  }\r\n\r\n  private getRenderedRows(outlet: DataRowOutlet): HTMLTableRowElement[] {\r\n    const result = this.cdkTable._getRenderedRows(outlet) as HTMLTableRowElement[];\r\n    return result;\r\n\r\n  }\r\n\r\n  private convertToJsonArray(rows: HTMLTableRowElement[]): Array<any> {\r\n    const result = new Array<any>();\r\n\r\n    // tslint:disable-next-line:prefer-for-of\r\n    for (let i = 0; i < rows.length; i++) {\r\n      const row: Array<string> = this.convertRow(rows[i]);\r\n      this.customizeRow(row);\r\n      result.push(this.createExcelItem(row));\r\n    }\r\n    return result;\r\n  }\r\n\r\n  private convertRow(row: HTMLTableRowElement): Array<string> {\r\n    const result = new Array<string>();\r\n    const cells: any = row.children;\r\n    for (let i = 0; i < cells.length; i++) {\r\n      if (this.shouldHide(i)) {\r\n        continue;\r\n      }\r\n      const element = cells.item(i).innerText;\r\n      result.push(element);\r\n    }\r\n    return result;\r\n  }\r\n\r\n  private shouldHide(columnIndex: number) {\r\n    if (this.hiddenColumns && this.hiddenColumns.includes(columnIndex)) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  public customizeRow(row: Array<string>): Array<string> {\r\n    return row;\r\n  }\r\n\r\n  private createExcelItem(row: Array<string>): any {\r\n    return Object.assign({}, row);\r\n  }\r\n\r\n  public hasNextPage(): boolean {\r\n    if (this.getCurrentPageIndex() < this.getPageCount() - 1) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n  public nextPage(): void {\r\n    this.goToPage(this.getCurrentPageIndex() + 1);\r\n  }\r\n\r\n  private enableExportButton(value: boolean) {\r\n      this.renderer.setProperty(this.exporterButton._elementRef.nativeElement, 'disabled', value ? null : 'true');\r\n  }\r\n}\r\n\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-table-exporter.js","sourceRoot":"ng://cdk-table-exporter/","sources":["lib/cdk-table-exporter.ts"],"names":[],"mappings":";;;;AACA,OAAO,EAAiB,YAAY,EAAE,KAAK,EAAE,MAAM,EAAa,MAAM,eAAe,CAAC;;;;;AAOtF,MAAM,OAAgB,gBAAgB;;;;;IAqBpC,YAAsB,QAAmB,EAAY,YAAiC;QAAhE,aAAQ,GAAR,QAAQ,CAAW;QAAY,iBAAY,GAAZ,YAAY,CAAqB;QAjB7E,cAAS,GAAG,QAAQ,CAAC;QACrB,aAAQ,GAAG,aAAa,CAAC;QAExB,oBAAe,GAAG,IAAI,YAAY,EAAQ,CAAC;QAC3C,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;IAenD,CAAC;;;;IAuBD,eAAe;QACb,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,aAAa,EAAE,OAAO;;;;QAAE,CAAC,GAAG,EAAE,EAAE;YACpF,IAAI,CAAC,WAAW,EAAE,CAAC;QACpB,CAAC,EAAC,CAAC;IACL,CAAC;;;;;IAMD,WAAW;QACT,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,EAAO,CAAC;QAC9B,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI;YACF,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;QAAC,OAAO,YAAY,EAAE;YACrB,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IAEH,CAAC;;;;;IAEO,oBAAoB;QAC1B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACpD,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,oDAAoD;QAC5E,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IACnB,CAAC;;;;;IAEO,gBAAgB;QACtB,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;;;;;IAEO,wBAAwB;QAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC1D,CAAC;;;;;IAGO,eAAe;QACrB,IAAI,CAAC,uBAAuB,EAAE,CAAC,SAAS;;;;QAAC,CAAC,CAAC,EAAE;YAC3C,UAAU;;;YAAC,GAAG,EAAE;gBACd,IAAI,IAAI,CAAC,YAAY,EAAE;oBACrB,IAAI,CAAC,wBAAwB,EAAE,CAAC;oBAChC,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE;wBACtB,IAAI,CAAC,QAAQ,EAAE,CAAC;qBACjB;yBAAM;wBACL,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;wBAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;qBACvC;iBACF;qBAAM,IAAI,IAAI,CAAC,YAAY,EAAE;oBAC5B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;oBAC1B,IAAI,CAAC,mBAAmB,EAAE,CAAC;iBAC5B;YACH,CAAC,EAAC,CAAC;QACL,CAAC,EAAC,CAAC;IACL,CAAC;;;;;IAEO,mBAAmB;QACzB,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,qBAAqB,EAAE,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QACvG,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,EAAO,CAAC;QAC9B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAC9B,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IAC9B,CAAC;;;;;IAGO,gBAAgB;QACtB,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC;IACjF,CAAC;;;;;IAEO,qBAAqB;QAC3B,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1F,CAAC;;;;;;IAEO,eAAe,CAAC,MAAqB;;cACrC,MAAM,GAAG,mBAAA,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAyB;QAC9E,OAAO,MAAM,CAAC;IAEhB,CAAC;;;;;;IAEO,kBAAkB,CAAC,IAA2B;;cAC9C,MAAM,GAAG,IAAI,KAAK,EAAO;QAE/B,yCAAyC;QACzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;;kBAC9B,GAAG,GAAkB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACnD,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;YACvB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC;SACxC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;;;;;;IAEO,UAAU,CAAC,GAAwB;;cACnC,MAAM,GAAG,IAAI,KAAK,EAAU;;cAC5B,KAAK,GAAQ,GAAG,CAAC,QAAQ;QAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACrC,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE;gBACtB,SAAS;aACV;;kBACK,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;YACvC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACtB;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;;;;;;IAEO,UAAU,CAAC,WAAmB;QACpC,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE;YAClE,OAAO,IAAI,CAAC;SACb;aAAM;YACL,OAAO,KAAK,CAAC;SACd;IACH,CAAC;;;;;IAEM,YAAY,CAAC,GAAkB;QACpC,OAAO,GAAG,CAAC;IACb,CAAC;;;;;;IAEO,eAAe,CAAC,GAAkB;QACxC,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,CAAC,CAAC;IAChC,CAAC;;;;IAEM,WAAW;QAChB,IAAI,IAAI,CAAC,mBAAmB,EAAE,GAAG,IAAI,CAAC,YAAY,EAAE,GAAG,CAAC,EAAE;YACxD,OAAO,IAAI,CAAC;SACb;aAAM;YACL,OAAO,KAAK,CAAC;SACd;IACH,CAAC;;;;IACM,QAAQ;QACb,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAC,CAAC;IAChD,CAAC;;;;;;IAEO,kBAAkB,CAAC,KAAc;QACrC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,aAAa,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IAChH,CAAC;;;uBAnLA,KAAK;6BACL,KAAK;wBACL,KAAK;uBACL,KAAK;4BACL,KAAK;8BACL,MAAM;4BACN,MAAM;;;;IANP,oCAAuB;;IACvB,0CAA6B;;IAC7B,qCAA8B;;IAC9B,oCAAkC;;IAClC,yCAAsC;;IACtC,2CAAqD;;IACrD,yCAAmD;;;;;;IAKnD,iCAA0B;;;;;IAE1B,wCAA8B;;;;;IAE9B,6CAAkC;;;;;IAElC,wCAA8B;;;;;IAElB,oCAA6B;;;;;IAAE,wCAA2C;;;;;;IAOtF,0DAAuC;;;;;;IAKvC,iEAA8C;;;;;;;IAM9C,2DAA8C;;;;;;IAK9C,qEAA2D","sourcesContent":["import { DataRowOutlet } from '@angular/cdk/table';\r\nimport { AfterViewInit, EventEmitter, Input, Output, Renderer2 } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { JsonExporterService } from './json-exporter.service';\r\n\r\n/**\r\n * Excel exporter class for CdkTable. Abstracts the varying behaviors among different CdkTable implementations.\r\n */\r\nexport abstract class CdkTableExporter implements AfterViewInit {\r\n\r\n  @Input() cdkTable: any;\r\n  @Input() exporterButton: any;\r\n  @Input() sheetName = 'Sheet1';\r\n  @Input() fileName = 'export.xlsx';\r\n  @Input() hiddenColumns: Array<number>;\r\n  @Output() exportCompleted = new EventEmitter<void>();\r\n  @Output() exportStarted = new EventEmitter<void>();\r\n\r\n  /**\r\n   * Data array which is extracted from nativeTable\r\n   */\r\n  private _data: Array<any>;\r\n\r\n  private _isIterating: boolean;\r\n\r\n  private _initialPageIndex: number;\r\n\r\n  private _isExporting: boolean;\r\n\r\n  constructor(protected renderer: Renderer2, protected jsonExporter: JsonExporterService) {\r\n\r\n  }\r\n\r\n  /**\r\n   * Must return the number of pages of the table\r\n   */\r\n  public abstract getPageCount(): number;\r\n\r\n  /**\r\n   * Must return the index of the current page that's displayed\r\n   */\r\n  public abstract getCurrentPageIndex(): number;\r\n\r\n  /**\r\n   * When called, the CdkTable should render the rows inside the page whose index given as parameter\r\n   * @param index page index\r\n   */\r\n  public abstract goToPage(index: number): void;\r\n\r\n  /**\r\n   * Must return an observable that notifies the subscribers about page changes\r\n   */\r\n  public abstract getPageChangeObservable(): Observable<any>;\r\n\r\n  ngAfterViewInit(): void {\r\n    this.renderer.listen(this.exporterButton._elementRef.nativeElement, 'click', (evt) => {\r\n     this.exportTable();\r\n    });\r\n  }\r\n\r\n\r\n/**\r\n * Triggers page event chain thus extracting and exporting all the rows in nativetables in pages\r\n */\r\n  exportTable() {\r\n    this.exportStarted.emit();\r\n    this._isIterating = true;\r\n    this._isExporting = true;\r\n    this._data = new Array<any>();\r\n    this.enableExportButton(false);\r\n    try {\r\n      this.exportWithPagination();\r\n    } catch (notPaginated) {\r\n      this.exportSinglePage();\r\n    }\r\n\r\n  }\r\n\r\n  private exportWithPagination() {\r\n    this._initialPageIndex = this.getCurrentPageIndex();\r\n    this.initPageHandler(); // to make sure datasource is not null during export\r\n    this.goToPage(0);\r\n  }\r\n\r\n  private exportSinglePage() {\r\n    this.extractDataOnCurrentPage();\r\n    this.exportExtractedData();\r\n  }\r\n\r\n  private extractDataOnCurrentPage() {\r\n    this._data = this._data.concat(this.extractExcelRows());\r\n  }\r\n\r\n\r\n  private initPageHandler(): void {\r\n    this.getPageChangeObservable().subscribe(_ => {\r\n      setTimeout(() => {\r\n        if (this._isIterating) {\r\n          this.extractDataOnCurrentPage();\r\n          if (this.hasNextPage()) {\r\n            this.nextPage();\r\n          } else {\r\n            this._isIterating = false;\r\n            this.goToPage(this._initialPageIndex);\r\n          }\r\n        } else if (this._isExporting) {\r\n          this._isExporting = false;\r\n          this.exportExtractedData();\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  private exportExtractedData() {\r\n    this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);\r\n    this._data = new Array<any>();\r\n    this.enableExportButton(true);\r\n    this.exportCompleted.emit();\r\n  }\r\n\r\n\r\n  private extractExcelRows() {\r\n    return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._rowOutlet));\r\n  }\r\n\r\n  private extractExcelHeaderRow() {\r\n    return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._headerRowOutlet))[0];\r\n  }\r\n\r\n  private getRenderedRows(outlet: DataRowOutlet): HTMLTableRowElement[] {\r\n    const result = this.cdkTable._getRenderedRows(outlet) as HTMLTableRowElement[];\r\n    return result;\r\n\r\n  }\r\n\r\n  private convertToJsonArray(rows: HTMLTableRowElement[]): Array<any> {\r\n    const result = new Array<any>();\r\n\r\n    // tslint:disable-next-line:prefer-for-of\r\n    for (let i = 0; i < rows.length; i++) {\r\n      const row: Array<string> = this.convertRow(rows[i]);\r\n      this.customizeRow(row);\r\n      result.push(this.createExcelItem(row));\r\n    }\r\n    return result;\r\n  }\r\n\r\n  private convertRow(row: HTMLTableRowElement): Array<string> {\r\n    const result = new Array<string>();\r\n    const cells: any = row.children;\r\n    for (let i = 0; i < cells.length; i++) {\r\n      if (this.shouldHide(i)) {\r\n        continue;\r\n      }\r\n      const element = cells.item(i).innerText;\r\n      result.push(element);\r\n    }\r\n    return result;\r\n  }\r\n\r\n  private shouldHide(columnIndex: number) {\r\n    if (this.hiddenColumns && this.hiddenColumns.includes(columnIndex)) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  public customizeRow(row: Array<string>): Array<string> {\r\n    return row;\r\n  }\r\n\r\n  private createExcelItem(row: Array<string>): any {\r\n    return Object.assign({}, row);\r\n  }\r\n\r\n  public hasNextPage(): boolean {\r\n    if (this.getCurrentPageIndex() < this.getPageCount() - 1) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n  public nextPage(): void {\r\n    this.goToPage(this.getCurrentPageIndex() + 1);\r\n  }\r\n\r\n  private enableExportButton(value: boolean) {\r\n      this.renderer.setProperty(this.exporterButton._elementRef.nativeElement, 'disabled', value ? null : 'true');\r\n  }\r\n}\r\n\r\n"]}

@@ -82,3 +82,3 @@ /**

this.extractDataOnCurrentPage();
this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);
this.exportExtractedData();
};

@@ -392,2 +392,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-table-exporter.js","sourceRoot":"ng://cdk-table-exporter/","sources":["lib/cdk-table-exporter.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataRowOutlet } from '@angular/cdk/table';\r\nimport { AfterViewInit, EventEmitter, Input, Output, Renderer2 } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { JsonExporterService } from './json-exporter.service';\r\n\r\n/**\r\n * Excel exporter class for CdkTable. Abstracts the varying behaviors among different CdkTable implementations.\r\n */\r\nexport abstract class CdkTableExporter implements AfterViewInit {\r\n\r\n  @Input() cdkTable: any;\r\n  @Input() exporterButton: any;\r\n  @Input() sheetName = 'Sheet1';\r\n  @Input() fileName = 'export.xlsx';\r\n  @Input() hiddenColumns: Array<number>;\r\n  @Output() exportCompleted = new EventEmitter<void>();\r\n  @Output() exportStarted = new EventEmitter<void>();\r\n\r\n  /**\r\n   * Data array which is extracted from nativeTable\r\n   */\r\n  private _data: Array<any>;\r\n\r\n  private _isIterating: boolean;\r\n\r\n  private _initialPageIndex: number;\r\n\r\n  private _isExporting: boolean;\r\n\r\n  constructor(protected renderer: Renderer2, protected jsonExporter: JsonExporterService) {\r\n\r\n  }\r\n\r\n  /**\r\n   * Must return the number of pages of the table\r\n   */\r\n  public abstract getPageCount(): number;\r\n\r\n  /**\r\n   * Must return the index of the current page that's displayed\r\n   */\r\n  public abstract getCurrentPageIndex(): number;\r\n\r\n  /**\r\n   * When called, the CdkTable should render the rows inside the page whose index given as parameter\r\n   * @param index page index\r\n   */\r\n  public abstract goToPage(index: number): void;\r\n\r\n  /**\r\n   * Must return an observable that notifies the subscribers about page changes\r\n   */\r\n  public abstract getPageChangeObservable(): Observable<any>;\r\n\r\n  ngAfterViewInit(): void {\r\n    this.renderer.listen(this.exporterButton._elementRef.nativeElement, 'click', (evt) => {\r\n     this.exportTable();\r\n    });\r\n  }\r\n\r\n\r\n/**\r\n * Triggers page event chain thus extracting and exporting all the rows in nativetables in pages\r\n */\r\n  exportTable() {\r\n    this.exportStarted.emit();\r\n    this._isIterating = true;\r\n    this._isExporting = true;\r\n    this._data = new Array<any>();\r\n    this.enableExportButton(false);\r\n    try {\r\n      this.exportWithPagination();\r\n    } catch (notPaginated) {\r\n      this.exportSinglePage();\r\n    }\r\n\r\n  }\r\n\r\n  private exportWithPagination() {\r\n    this._initialPageIndex = this.getCurrentPageIndex();\r\n    this.initPageHandler(); // to make sure datasource is not null during export\r\n    this.goToPage(0);\r\n  }\r\n\r\n  private exportSinglePage() {\r\n    this.extractDataOnCurrentPage();\r\n    this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);\r\n  }\r\n\r\n  private extractDataOnCurrentPage() {\r\n    this._data = this._data.concat(this.extractExcelRows());\r\n  }\r\n\r\n\r\n  private initPageHandler(): void {\r\n    this.getPageChangeObservable().subscribe(_ => {\r\n      setTimeout(() => {\r\n        if (this._isIterating) {\r\n          this.extractDataOnCurrentPage();\r\n          if (this.hasNextPage()) {\r\n            this.nextPage();\r\n          } else {\r\n            this._isIterating = false;\r\n            this.goToPage(this._initialPageIndex);\r\n          }\r\n        } else if (this._isExporting) {\r\n          this._isExporting = false;\r\n          this.exportExtractedData();\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  private exportExtractedData() {\r\n    this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);\r\n    this._data = new Array<any>();\r\n    this.enableExportButton(true);\r\n    this.exportCompleted.emit();\r\n  }\r\n\r\n\r\n  private extractExcelRows() {\r\n    return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._rowOutlet));\r\n  }\r\n\r\n  private extractExcelHeaderRow() {\r\n    return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._headerRowOutlet))[0];\r\n  }\r\n\r\n  private getRenderedRows(outlet: DataRowOutlet): HTMLTableRowElement[] {\r\n    const result = this.cdkTable._getRenderedRows(outlet) as HTMLTableRowElement[];\r\n    return result;\r\n\r\n  }\r\n\r\n  private convertToJsonArray(rows: HTMLTableRowElement[]): Array<any> {\r\n    const result = new Array<any>();\r\n\r\n    // tslint:disable-next-line:prefer-for-of\r\n    for (let i = 0; i < rows.length; i++) {\r\n      const row: Array<string> = this.convertRow(rows[i]);\r\n      this.customizeRow(row);\r\n      result.push(this.createExcelItem(row));\r\n    }\r\n    return result;\r\n  }\r\n\r\n  private convertRow(row: HTMLTableRowElement): Array<string> {\r\n    const result = new Array<string>();\r\n    const cells: any = row.children;\r\n    for (let i = 0; i < cells.length; i++) {\r\n      if (this.shouldHide(i)) {\r\n        continue;\r\n      }\r\n      const element = cells.item(i).innerText;\r\n      result.push(element);\r\n    }\r\n    return result;\r\n  }\r\n\r\n  private shouldHide(columnIndex: number) {\r\n    if (this.hiddenColumns && this.hiddenColumns.includes(columnIndex)) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  public customizeRow(row: Array<string>): Array<string> {\r\n    return row;\r\n  }\r\n\r\n  private createExcelItem(row: Array<string>): any {\r\n    return Object.assign({}, row);\r\n  }\r\n\r\n  public hasNextPage(): boolean {\r\n    if (this.getCurrentPageIndex() < this.getPageCount() - 1) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n  public nextPage(): void {\r\n    this.goToPage(this.getCurrentPageIndex() + 1);\r\n  }\r\n\r\n  private enableExportButton(value: boolean) {\r\n      this.renderer.setProperty(this.exporterButton._elementRef.nativeElement, 'disabled', value ? null : 'true');\r\n  }\r\n}\r\n\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cdk-table-exporter.js","sourceRoot":"ng://cdk-table-exporter/","sources":["lib/cdk-table-exporter.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataRowOutlet } from '@angular/cdk/table';\r\nimport { AfterViewInit, EventEmitter, Input, Output, Renderer2 } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { JsonExporterService } from './json-exporter.service';\r\n\r\n/**\r\n * Excel exporter class for CdkTable. Abstracts the varying behaviors among different CdkTable implementations.\r\n */\r\nexport abstract class CdkTableExporter implements AfterViewInit {\r\n\r\n  @Input() cdkTable: any;\r\n  @Input() exporterButton: any;\r\n  @Input() sheetName = 'Sheet1';\r\n  @Input() fileName = 'export.xlsx';\r\n  @Input() hiddenColumns: Array<number>;\r\n  @Output() exportCompleted = new EventEmitter<void>();\r\n  @Output() exportStarted = new EventEmitter<void>();\r\n\r\n  /**\r\n   * Data array which is extracted from nativeTable\r\n   */\r\n  private _data: Array<any>;\r\n\r\n  private _isIterating: boolean;\r\n\r\n  private _initialPageIndex: number;\r\n\r\n  private _isExporting: boolean;\r\n\r\n  constructor(protected renderer: Renderer2, protected jsonExporter: JsonExporterService) {\r\n\r\n  }\r\n\r\n  /**\r\n   * Must return the number of pages of the table\r\n   */\r\n  public abstract getPageCount(): number;\r\n\r\n  /**\r\n   * Must return the index of the current page that's displayed\r\n   */\r\n  public abstract getCurrentPageIndex(): number;\r\n\r\n  /**\r\n   * When called, the CdkTable should render the rows inside the page whose index given as parameter\r\n   * @param index page index\r\n   */\r\n  public abstract goToPage(index: number): void;\r\n\r\n  /**\r\n   * Must return an observable that notifies the subscribers about page changes\r\n   */\r\n  public abstract getPageChangeObservable(): Observable<any>;\r\n\r\n  ngAfterViewInit(): void {\r\n    this.renderer.listen(this.exporterButton._elementRef.nativeElement, 'click', (evt) => {\r\n     this.exportTable();\r\n    });\r\n  }\r\n\r\n\r\n/**\r\n * Triggers page event chain thus extracting and exporting all the rows in nativetables in pages\r\n */\r\n  exportTable() {\r\n    this.exportStarted.emit();\r\n    this._isIterating = true;\r\n    this._isExporting = true;\r\n    this._data = new Array<any>();\r\n    this.enableExportButton(false);\r\n    try {\r\n      this.exportWithPagination();\r\n    } catch (notPaginated) {\r\n      this.exportSinglePage();\r\n    }\r\n\r\n  }\r\n\r\n  private exportWithPagination() {\r\n    this._initialPageIndex = this.getCurrentPageIndex();\r\n    this.initPageHandler(); // to make sure datasource is not null during export\r\n    this.goToPage(0);\r\n  }\r\n\r\n  private exportSinglePage() {\r\n    this.extractDataOnCurrentPage();\r\n    this.exportExtractedData();\r\n  }\r\n\r\n  private extractDataOnCurrentPage() {\r\n    this._data = this._data.concat(this.extractExcelRows());\r\n  }\r\n\r\n\r\n  private initPageHandler(): void {\r\n    this.getPageChangeObservable().subscribe(_ => {\r\n      setTimeout(() => {\r\n        if (this._isIterating) {\r\n          this.extractDataOnCurrentPage();\r\n          if (this.hasNextPage()) {\r\n            this.nextPage();\r\n          } else {\r\n            this._isIterating = false;\r\n            this.goToPage(this._initialPageIndex);\r\n          }\r\n        } else if (this._isExporting) {\r\n          this._isExporting = false;\r\n          this.exportExtractedData();\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  private exportExtractedData() {\r\n    this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);\r\n    this._data = new Array<any>();\r\n    this.enableExportButton(true);\r\n    this.exportCompleted.emit();\r\n  }\r\n\r\n\r\n  private extractExcelRows() {\r\n    return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._rowOutlet));\r\n  }\r\n\r\n  private extractExcelHeaderRow() {\r\n    return this.convertToJsonArray(this.getRenderedRows(this.cdkTable._headerRowOutlet))[0];\r\n  }\r\n\r\n  private getRenderedRows(outlet: DataRowOutlet): HTMLTableRowElement[] {\r\n    const result = this.cdkTable._getRenderedRows(outlet) as HTMLTableRowElement[];\r\n    return result;\r\n\r\n  }\r\n\r\n  private convertToJsonArray(rows: HTMLTableRowElement[]): Array<any> {\r\n    const result = new Array<any>();\r\n\r\n    // tslint:disable-next-line:prefer-for-of\r\n    for (let i = 0; i < rows.length; i++) {\r\n      const row: Array<string> = this.convertRow(rows[i]);\r\n      this.customizeRow(row);\r\n      result.push(this.createExcelItem(row));\r\n    }\r\n    return result;\r\n  }\r\n\r\n  private convertRow(row: HTMLTableRowElement): Array<string> {\r\n    const result = new Array<string>();\r\n    const cells: any = row.children;\r\n    for (let i = 0; i < cells.length; i++) {\r\n      if (this.shouldHide(i)) {\r\n        continue;\r\n      }\r\n      const element = cells.item(i).innerText;\r\n      result.push(element);\r\n    }\r\n    return result;\r\n  }\r\n\r\n  private shouldHide(columnIndex: number) {\r\n    if (this.hiddenColumns && this.hiddenColumns.includes(columnIndex)) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  public customizeRow(row: Array<string>): Array<string> {\r\n    return row;\r\n  }\r\n\r\n  private createExcelItem(row: Array<string>): any {\r\n    return Object.assign({}, row);\r\n  }\r\n\r\n  public hasNextPage(): boolean {\r\n    if (this.getCurrentPageIndex() < this.getPageCount() - 1) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n  public nextPage(): void {\r\n    this.goToPage(this.getCurrentPageIndex() + 1);\r\n  }\r\n\r\n  private enableExportButton(value: boolean) {\r\n      this.renderer.setProperty(this.exporterButton._elementRef.nativeElement, 'disabled', value ? null : 'true');\r\n  }\r\n}\r\n\r\n"]}

@@ -83,3 +83,3 @@ import { NgModule, EventEmitter, Input, Output, Injectable, defineInjectable } from '@angular/core';

this.extractDataOnCurrentPage();
this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);
this.exportExtractedData();
}

@@ -86,0 +86,0 @@ /**

@@ -101,3 +101,3 @@ import { NgModule, EventEmitter, Input, Output, Injectable, defineInjectable } from '@angular/core';

this.extractDataOnCurrentPage();
this.jsonExporter.exportExcel(this.extractExcelHeaderRow(), this._data, this.fileName, this.sheetName);
this.exportExtractedData();
};

@@ -104,0 +104,0 @@ /**

{
"name": "cdk-table-exporter",
"version": "1.0.0",
"version": "1.0.1",
"description": "Abstract CdkTable Exporter",

@@ -5,0 +5,0 @@ "author": "Halit Talha Türe",

@@ -26,4 +26,4 @@ # CdkTable Table Exporter

Thus the usage is simply as follows:
1- Generate a directive class
2- Extend CdkTableExporter class implement the abstract methods
1. Generate a directive class
2. Extend CdkTableExporter class implement the abstract methods

@@ -30,0 +30,0 @@

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc