@grapecity/spread-sheets-angular
Version:
SpreadJS angular support
208 lines • 23.3 kB
JavaScript
/*import_begin*/
import { Component, ContentChildren, Input, } from '@angular/core';
/*import_end*/
import { ColumnComponent } from './column.component';
import * as GC from '@grapecity/spread-sheets';
import * as i0 from "@angular/core";
/*code_begin*/
export class WorksheetComponent {
constructor() {
this.sheet = new GC["default"].Spread.Sheets.Worksheet('');
}
onAttached() {
const sheet = this.sheet;
const columns = this.columns;
sheet.suspendPaint();
sheet.suspendEvent();
if (this.dataSource) {
sheet.setDataSource(this.dataSource);
columns.forEach((columnComponent, index) => {
if (columnComponent.dataField) {
sheet.bindColumn(index, {
name: columnComponent.dataField,
displayName: columnComponent.headerText,
});
}
});
}
if (columns.length > 0) {
sheet.setColumnCount(columns.length);
columns.forEach((columnComponent, index) => {
columnComponent.onAttached(this.sheet, index);
});
}
sheet.resumeEvent();
sheet.resumePaint();
}
getSheet() {
return this.sheet;
}
ngOnChanges(changes) {
const sheet = this.sheet;
sheet.suspendPaint();
sheet.suspendEvent();
for (const changeName in changes) {
const newValue = changes[changeName].currentValue;
if (newValue === null || newValue === void 0) {
continue;
}
switch (changeName) {
case 'rowCount':
sheet.setRowCount(newValue);
break;
case 'colCount':
sheet.setColumnCount(newValue);
break;
case 'name':
sheet.name(newValue);
break;
case 'frozenColumnCount':
sheet.frozenColumnCount(newValue);
break;
case 'frozenRowCount':
sheet.frozenRowCount(newValue);
break;
case 'frozenTrailingRowCount':
sheet.frozenTrailingRowCount(newValue);
break;
case 'frozenTrailingColumnCount':
sheet.frozenTrailingColumnCount(newValue);
break;
case 'selectionPolicy':
sheet.selectionPolicy(newValue);
break;
case 'selectionUnit':
sheet.selectionUnit(newValue);
break;
case 'zoom':
sheet.zoom(newValue);
break;
case 'currentTheme':
sheet.currentTheme(newValue);
break;
case 'defaultStyle':
sheet.setDefaultStyle(newValue);
break;
case 'rowOutlineInfo':
newValue.forEach((item) => {
sheet.rowOutlines.group(item.index, item.count);
});
sheet.repaint();
break;
case 'columnOutlineInfo':
newValue.forEach((item) => {
sheet.columnOutlines.group(item.index, item.count);
});
sheet.repaint();
break;
case 'showRowOutline':
sheet.showRowOutline(newValue);
break;
case 'showColumnOutline':
sheet.showColumnOutline(newValue);
break;
case 'dataSource':
sheet.setDataSource(newValue);
break;
case 'autoGenerateColumns':
sheet[changeName] = newValue;
default:
sheet.options[changeName] = newValue;
}
}
sheet.resumeEvent();
sheet.resumePaint();
}
ngAfterViewInit() {
this.columns.changes.subscribe(() => { this.onAttached(); });
}
ngOnDestroy() {
const sheet = this.sheet;
const spread = sheet ? sheet.getParent() : null;
if (spread) {
const sheetIndex = spread.getSheetIndex(sheet.name());
if (sheetIndex !== void 0) {
spread.removeSheet(sheetIndex);
}
}
}
}
WorksheetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: WorksheetComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
WorksheetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: WorksheetComponent, selector: "gc-worksheet", inputs: { rowCount: "rowCount", colCount: "colCount", dataSource: "dataSource", name: "name", frozenColumnCount: "frozenColumnCount", frozenRowCount: "frozenRowCount", frozenTrailingRowCount: "frozenTrailingRowCount", frozenTrailingColumnCount: "frozenTrailingColumnCount", allowCellOverflow: "allowCellOverflow", frozenlineColor: "frozenlineColor", sheetTabColor: "sheetTabColor", selectionPolicy: "selectionPolicy", selectionUnit: "selectionUnit", zoom: "zoom", currentTheme: "currentTheme", clipBoardOptions: "clipBoardOptions", rowHeaderVisible: "rowHeaderVisible", colHeaderVisible: "colHeaderVisible", rowHeaderAutoText: "rowHeaderAutoText", colHeaderAutoText: "colHeaderAutoText", rowHeaderAutoTextIndex: "rowHeaderAutoTextIndex", colHeaderAutoTextIndex: "colHeaderAutoTextIndex", isProtected: "isProtected", showRowOutline: "showRowOutline", showColumnOutline: "showColumnOutline", selectionBackColor: "selectionBackColor", selectionBorderColor: "selectionBorderColor", defaultStyle: "defaultStyle", rowOutlineInfo: "rowOutlineInfo", columnOutlineInfo: "columnOutlineInfo", autoGenerateColumns: "autoGenerateColumns" }, queries: [{ propertyName: "columns", predicate: ColumnComponent }], usesOnChanges: true, ngImport: i0, template: `
<ng-content></ng-content>
`, isInline: true });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: WorksheetComponent, decorators: [{
type: Component,
args: [{
selector: 'gc-worksheet',
template: `
<ng-content></ng-content>
`,
}]
}], ctorParameters: function () { return []; }, propDecorators: { columns: [{
type: ContentChildren,
args: [ColumnComponent]
}], rowCount: [{
type: Input
}], colCount: [{
type: Input
}], dataSource: [{
type: Input
}], name: [{
type: Input
}], frozenColumnCount: [{
type: Input
}], frozenRowCount: [{
type: Input
}], frozenTrailingRowCount: [{
type: Input
}], frozenTrailingColumnCount: [{
type: Input
}], allowCellOverflow: [{
type: Input
}], frozenlineColor: [{
type: Input
}], sheetTabColor: [{
type: Input
}], selectionPolicy: [{
type: Input
}], selectionUnit: [{
type: Input
}], zoom: [{
type: Input
}], currentTheme: [{
type: Input
}], clipBoardOptions: [{
type: Input
}], rowHeaderVisible: [{
type: Input
}], colHeaderVisible: [{
type: Input
}], rowHeaderAutoText: [{
type: Input
}], colHeaderAutoText: [{
type: Input
}], rowHeaderAutoTextIndex: [{
type: Input
}], colHeaderAutoTextIndex: [{
type: Input
}], isProtected: [{
type: Input
}], showRowOutline: [{
type: Input
}], showColumnOutline: [{
type: Input
}], selectionBackColor: [{
type: Input
}], selectionBorderColor: [{
type: Input
}], defaultStyle: [{
type: Input
}], rowOutlineInfo: [{
type: Input
}], columnOutlineInfo: [{
type: Input
}], autoGenerateColumns: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"worksheet.component.js","sourceRoot":"","sources":["../../../src/worksheet.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*import_begin*/\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  ContentChildren,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  QueryList, SimpleChanges,\r\n} from '@angular/core';\r\n/*import_end*/\r\nimport { ColumnComponent } from './column.component';\r\nimport * as GC from '@grapecity/spread-sheets';\r\n/*code_begin*/\r\n@Component({\r\n  selector: 'gc-worksheet',\r\n  template: `\r\n        <ng-content></ng-content>\r\n    `,\r\n})\r\nexport class WorksheetComponent implements OnChanges, AfterViewInit {\r\n  private sheet: GC.Spread.Sheets.Worksheet;\r\n  @ContentChildren(ColumnComponent)\r\n  public columns?: QueryList<ColumnComponent>;\r\n\r\n  // indicate all inputs\r\n  @Input() public rowCount?: number;\r\n  @Input() public colCount?: number;\r\n  @Input() public dataSource: any;\r\n  @Input() public name?: string;\r\n  @Input() public frozenColumnCount?: number;\r\n  @Input() public frozenRowCount?: number;\r\n  @Input() public frozenTrailingRowCount?: number;\r\n  @Input() public frozenTrailingColumnCount?: number;\r\n  @Input() public allowCellOverflow?: boolean;\r\n  @Input() public frozenlineColor?: string;\r\n  @Input() public sheetTabColor?: string;\r\n  @Input() public selectionPolicy?: number;\r\n  @Input() public selectionUnit?: number;\r\n  @Input() public zoom?: number;\r\n  @Input() public currentTheme?: string;\r\n  @Input() public clipBoardOptions?: number;\r\n  @Input() public rowHeaderVisible?: boolean;\r\n  @Input() public colHeaderVisible?: boolean;\r\n  @Input() public rowHeaderAutoText?: number;\r\n  @Input() public colHeaderAutoText?: number;\r\n  @Input() public rowHeaderAutoTextIndex?: number;\r\n  @Input() public colHeaderAutoTextIndex?: number;\r\n  @Input() public isProtected?: boolean;\r\n  @Input() public showRowOutline?: boolean;\r\n  @Input() public showColumnOutline?: boolean;\r\n  @Input() public selectionBackColor?: string;\r\n  @Input() public selectionBorderColor?: string;\r\n  @Input() public defaultStyle?: GC.Spread.Sheets.Style;\r\n  @Input() public rowOutlineInfo?: any[];\r\n  @Input() public columnOutlineInfo?: any[];\r\n  @Input() public autoGenerateColumns?: boolean;\r\n\r\n  constructor() {\r\n    this.sheet = new GC[\"default\"].Spread.Sheets.Worksheet('');\r\n  }\r\n\r\n  public onAttached(): void {\r\n    const sheet = this.sheet;\r\n    const columns = (this.columns as QueryList<ColumnComponent>);\r\n    sheet.suspendPaint();\r\n    sheet.suspendEvent();\r\n    if (this.dataSource) {\r\n      sheet.setDataSource(this.dataSource);\r\n      columns.forEach((columnComponent: ColumnComponent, index: number) => {\r\n        if (columnComponent.dataField) {\r\n          sheet.bindColumn(index, {\r\n            name: columnComponent.dataField,\r\n            displayName: columnComponent.headerText,\r\n          });\r\n        }\r\n      });\r\n    }\r\n    if (columns.length > 0) {\r\n      sheet.setColumnCount(columns.length);\r\n      columns.forEach((columnComponent: ColumnComponent, index: number) => {\r\n        columnComponent.onAttached(this.sheet, index);\r\n      });\r\n    }\r\n    sheet.resumeEvent();\r\n    sheet.resumePaint();\r\n  }\r\n  public getSheet() {\r\n    return this.sheet;\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges) {\r\n    const sheet = this.sheet;\r\n    sheet.suspendPaint();\r\n    sheet.suspendEvent();\r\n    for (const changeName in changes) {\r\n      const newValue = changes[changeName].currentValue;\r\n      if (newValue === null || newValue === void 0) {\r\n        continue;\r\n      }\r\n      switch (changeName) {\r\n        case 'rowCount':\r\n          sheet.setRowCount(newValue);\r\n          break;\r\n        case 'colCount':\r\n          sheet.setColumnCount(newValue);\r\n          break;\r\n        case 'name':\r\n          sheet.name(newValue);\r\n          break;\r\n        case 'frozenColumnCount':\r\n          sheet.frozenColumnCount(newValue);\r\n          break;\r\n        case 'frozenRowCount':\r\n          sheet.frozenRowCount(newValue);\r\n          break;\r\n        case 'frozenTrailingRowCount':\r\n          sheet.frozenTrailingRowCount(newValue);\r\n          break;\r\n        case 'frozenTrailingColumnCount':\r\n          sheet.frozenTrailingColumnCount(newValue);\r\n          break;\r\n        case 'selectionPolicy':\r\n          sheet.selectionPolicy(newValue);\r\n          break;\r\n        case 'selectionUnit':\r\n          sheet.selectionUnit(newValue);\r\n          break;\r\n        case 'zoom':\r\n          sheet.zoom(newValue);\r\n          break;\r\n        case 'currentTheme':\r\n          sheet.currentTheme(newValue);\r\n          break;\r\n        case 'defaultStyle':\r\n          sheet.setDefaultStyle(newValue);\r\n          break;\r\n        case 'rowOutlineInfo':\r\n          newValue.forEach((item: any) => {\r\n            sheet.rowOutlines.group(item.index, item.count);\r\n          });\r\n          sheet.repaint();\r\n          break;\r\n        case 'columnOutlineInfo':\r\n          newValue.forEach((item: any) => {\r\n            sheet.columnOutlines.group(item.index, item.count);\r\n          });\r\n          sheet.repaint();\r\n          break;\r\n        case 'showRowOutline':\r\n          sheet.showRowOutline(newValue);\r\n          break;\r\n        case 'showColumnOutline':\r\n          sheet.showColumnOutline(newValue);\r\n          break;\r\n        case 'dataSource':\r\n          sheet.setDataSource(newValue);\r\n          break;\r\n        case 'autoGenerateColumns':\r\n          sheet[changeName] = newValue;\r\n        default:\r\n          (sheet.options as any)[changeName] = newValue;\r\n      }\r\n    }\r\n    sheet.resumeEvent();\r\n    sheet.resumePaint();\r\n  }\r\n\r\n  public ngAfterViewInit() {\r\n    (this.columns as QueryList<ColumnComponent>).changes.subscribe(() => { this.onAttached(); });\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    const sheet = this.sheet;\r\n    const spread = sheet ? sheet.getParent() : null;\r\n    if (spread) {\r\n      const sheetIndex = spread.getSheetIndex(sheet.name());\r\n      if (sheetIndex !== void 0) {\r\n        spread.removeSheet(sheetIndex);\r\n      }\r\n    }\r\n  }\r\n}\r\n/*code_end*/\r\n"]}