sheetjs/demos/angular2/src/app/sheetjs.component.ts

65 lines
1.8 KiB
TypeScript
Raw Permalink Normal View History

2017-06-21 23:10:36 +00:00
/* xlsx.js (C) 2013-present SheetJS -- http://sheetjs.com */
/* vim: set ts=2: */
import { Component } from '@angular/core';
2022-02-14 01:28:13 +00:00
import { WorkBook, WorkSheet, WritingOptions, read, writeFileXLSX as writeFile, utils, version, set_cptable } from 'xlsx';
//import * as cpexcel from 'xlsx/dist/cpexcel.full.mjs';
//set_cptable(cpexcel);
2017-06-21 23:10:36 +00:00
type AOA = any[][];
2017-06-21 23:10:36 +00:00
@Component({
selector: 'sheetjs',
template: `
2021-10-03 01:41:36 +00:00
<pre><b>Version: {{ver}}</b></pre>
2017-06-21 23:10:36 +00:00
<input type="file" (change)="onFileChange($event)" multiple="false" />
<table class="sjs-table">
<tr *ngFor="let row of data">
<td *ngFor="let val of row">
{{val}}
</td>
2017-06-21 23:10:36 +00:00
</tr>
</table>
<button (click)="export()">Export!</button>
`
})
export class SheetJSComponent {
2017-09-24 23:40:09 +00:00
data: AOA = [ [1, 2], [3, 4] ];
2022-02-14 01:28:13 +00:00
wopts: WritingOptions = { bookType: 'xlsx', type: 'array' };
2017-09-24 23:40:09 +00:00
fileName: string = 'SheetJS.xlsx';
2022-02-14 01:28:13 +00:00
ver: string = version;
2017-06-21 23:10:36 +00:00
onFileChange(evt: any) {
2017-06-21 23:10:36 +00:00
/* wire up file reader */
const target: DataTransfer = <DataTransfer>(evt.target);
2017-09-24 23:40:09 +00:00
if (target.files.length !== 1) throw new Error('Cannot use multiple files');
const reader: FileReader = new FileReader();
reader.onload = (e: any) => {
2017-06-21 23:10:36 +00:00
/* read workbook */
2021-10-03 01:41:36 +00:00
const ab: ArrayBuffer = e.target.result;
2022-02-14 01:28:13 +00:00
const wb: WorkBook = read(ab);
2017-06-21 23:10:36 +00:00
/* grab first sheet */
2017-09-24 23:40:09 +00:00
const wsname: string = wb.SheetNames[0];
2022-02-14 01:28:13 +00:00
const ws: WorkSheet = wb.Sheets[wsname];
2017-06-21 23:10:36 +00:00
/* save data */
2022-02-14 01:28:13 +00:00
this.data = <AOA>(utils.sheet_to_json(ws, {header: 1}));
2017-06-21 23:10:36 +00:00
};
2021-10-03 01:41:36 +00:00
reader.readAsArrayBuffer(target.files[0]);
2017-06-21 23:10:36 +00:00
}
export(): void {
2017-06-21 23:10:36 +00:00
/* generate worksheet */
2022-02-14 01:28:13 +00:00
const ws: WorkSheet = utils.aoa_to_sheet(this.data);
2017-06-21 23:10:36 +00:00
/* generate workbook and add the worksheet */
2022-02-14 01:28:13 +00:00
const wb: WorkBook = utils.book_new();
utils.book_append_sheet(wb, ws, 'Sheet1');
2017-06-21 23:10:36 +00:00
/* save to file */
2022-02-14 01:28:13 +00:00
writeFile(wb, this.fileName);
2017-06-21 23:10:36 +00:00
}
}