@bizdoc/core 1.9.9 → 1.9.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -21,6 +21,8 @@ export class CubeSpreadsheetComponent {
21
21
  this.loadingChange = new EventEmitter();
22
22
  this.id = `cube-spreadsheet-${CubeSpreadsheetComponent.nextId++}`;
23
23
  this.dataSource = [];
24
+ this.numberStyle = { textAlign: 'right' };
25
+ this.autoFillSettings = { showFillOptions: false };
24
26
  this._yrows = [];
25
27
  this._xcolumns = [];
26
28
  this._intl = new Internationalization();
@@ -95,39 +97,10 @@ export class CubeSpreadsheetComponent {
95
97
  }
96
98
  execute() {
97
99
  this.loadingChange.emit(true);
98
- const numberStyle = { textAlign: 'right' };
99
100
  if (!this._series)
100
101
  this._service.table(this.cube, this._xAxis, { filters: this.filters, indices: this._indices }).
101
102
  subscribe(data => {
102
- const cells = [], style = { fontWeight: 'bold', textAlign: 'center' };
103
- this._axes.forEach(c => cells.push({
104
- value: c.title, style
105
- }));
106
- this._indices && this._cindices.forEach(i => cells.push({ value: i.title, style }));
107
- cells.push({
108
- value: this.yAxis ? this.yAxis.title : this._translate.get('Value'),
109
- style
110
- });
111
- this.dataSource = [{
112
- cells, height: 20
113
- }];
114
- data.forEach(d => {
115
- const cells = [];
116
- this._xAxis.forEach(c => cells.push({
117
- value: d[c],
118
- }));
119
- this._indices && this._indices.forEach(i => cells.push({
120
- style: numberStyle,
121
- format: this._numberFormat,
122
- value: (d[i] || 0).toString(),
123
- }));
124
- cells.push({
125
- style: numberStyle,
126
- format: this._numberFormat,
127
- value: (d.value || 0).toString(),
128
- });
129
- this.dataSource.push({ cells, source: d, height: 20 });
130
- });
103
+ this._datatable(data);
131
104
  this._draw();
132
105
  this.loadingChange.emit(false);
133
106
  }, (e) => {
@@ -136,39 +109,9 @@ export class CubeSpreadsheetComponent {
136
109
  });
137
110
  else
138
111
  this._service.series(this.cube, this._xAxis, { series: this._series, filters: this.filters }).
139
- subscribe(d => {
112
+ subscribe(data => {
140
113
  this._prepare.then(() => {
141
- const style = { fontWeight: 'bold', textAlign: 'center' };
142
- const cells = [{ value: '' }];
143
- this._xcolumns.forEach(c => cells.push({ value: c.value, style }));
144
- this.dataSource = [{ cells, height: 20 }];
145
- this._indices && this._cube.indices.filter(i => this._indices.indexOf(i.name) > 0).
146
- forEach(i => {
147
- const cells = [{ value: i.title, style }], serie = d.find(s => s.index === i.name), map = {};
148
- if (serie) {
149
- serie.points.forEach(p => map[p.x] = p.y);
150
- this._xcolumns.forEach(c => cells.push({
151
- value: (map[c.key] || 0).toString(),
152
- format: this._numberFormat,
153
- style: numberStyle
154
- }));
155
- this.dataSource.push({ cells, height: 20 });
156
- }
157
- });
158
- this._yrows.forEach(r => {
159
- const cells = [{ value: r.value, style }], serie = d.find(s => s.name === r.key), map = {};
160
- if (serie) {
161
- serie.points.forEach(p => map[p.x] = p.y);
162
- this._xcolumns.forEach(c => cells.push({
163
- value: (map[c.key] || 0).toString(),
164
- format: this._numberFormat,
165
- style: numberStyle
166
- }));
167
- }
168
- else
169
- this._xcolumns.forEach(_ => cells.push({ value: '0' }));
170
- this.dataSource.push({ cells, height: 20 });
171
- });
114
+ this._dataseries(data);
172
115
  this._draw();
173
116
  this.loadingChange.emit(false);
174
117
  });
@@ -177,6 +120,70 @@ export class CubeSpreadsheetComponent {
177
120
  this.loadingChange.emit(false);
178
121
  });
179
122
  }
123
+ _datatable(data) {
124
+ const cells = [], style = { fontWeight: 'bold', textAlign: 'center' };
125
+ this._axes.forEach(c => cells.push({
126
+ value: c.title, style
127
+ }));
128
+ this._indices && this._cindices.forEach(i => cells.push({ value: i.title, style }));
129
+ cells.push({
130
+ value: this.yAxis ? this.yAxis.title : this._translate.get('Value'),
131
+ style
132
+ });
133
+ this.dataSource = [{
134
+ cells, height: 25
135
+ }];
136
+ data.forEach(d => {
137
+ const cells = [];
138
+ this._xAxis.forEach(c => cells.push({
139
+ value: d[c],
140
+ }));
141
+ this._indices && this._indices.forEach(i => cells.push({
142
+ style: this.numberStyle,
143
+ format: this._numberFormat,
144
+ value: (d[i] || 0).toString(),
145
+ }));
146
+ cells.push({
147
+ style: this.numberStyle,
148
+ format: this._numberFormat,
149
+ value: (d.value || 0).toString(),
150
+ });
151
+ this.dataSource.push({ cells, source: d, height: 25 });
152
+ });
153
+ }
154
+ _dataseries(d) {
155
+ const style = { fontWeight: 'bold', textAlign: 'center' };
156
+ const cells = [{ value: '' }];
157
+ this._xcolumns.forEach(c => cells.push({ value: c.value, style }));
158
+ this.dataSource = [{ cells, height: 25 }];
159
+ this._indices && this._cube.indices.filter(i => this._indices.indexOf(i.name) > 0).
160
+ forEach(i => {
161
+ const cells = [{ value: i.title, style }], serie = d.find(s => s.index === i.name), map = {};
162
+ if (serie) {
163
+ serie.points.forEach(p => map[p.x] = p.y);
164
+ this._xcolumns.forEach(c => cells.push({
165
+ value: (map[c.key] || 0).toString(),
166
+ format: this._numberFormat,
167
+ style: this.numberStyle
168
+ }));
169
+ this.dataSource.push({ cells, height: 25 });
170
+ }
171
+ });
172
+ this._yrows.forEach(r => {
173
+ const cells = [{ value: r.value, style }], serie = d.find(s => s.name === r.key), map = {};
174
+ if (serie) {
175
+ serie.points.forEach(p => map[p.x] = p.y);
176
+ this._xcolumns.forEach(c => cells.push({
177
+ value: (map[c.key] || 0).toString(),
178
+ format: this._numberFormat,
179
+ style: this.numberStyle
180
+ }));
181
+ }
182
+ else
183
+ this._xcolumns.forEach(_ => cells.push({ value: '0' }));
184
+ this.dataSource.push({ cells, height: 25 });
185
+ });
186
+ }
180
187
  _draw() {
181
188
  this.spreadsheet && this.spreadsheet.destroy();
182
189
  this.spreadsheet = new Spreadsheet({
@@ -185,19 +192,13 @@ export class CubeSpreadsheetComponent {
185
192
  allowDelete: false,
186
193
  allowInsert: false,
187
194
  allowSorting: true,
188
- //allowSave: false,
189
195
  showRibbon: false,
190
196
  allowAutoFill: false,
191
- autoFillSettings: { showFillOptions: false },
192
- //enableClipboard: true,
193
- //allowChart: false,
194
- //allowFiltering: false,
195
- //allowDataValidation: false,
196
- //allowFindAndReplace: false,
197
+ autoFillSettings: this.autoFillSettings,
198
+ enableClipboard: true,
197
199
  enableContextMenu: false,
198
200
  showFormulaBar: false,
199
201
  showSheetTabs: false,
200
- //scrollSettings: { isFinite: true },
201
202
  select: this.select.bind(this),
202
203
  sheets: [{
203
204
  columns: this.columns,
@@ -289,7 +290,6 @@ export class CubeSpreadsheetComponent {
289
290
  }
290
291
  }
291
292
  exportToExcel(title) {
292
- //this.spreadsheet.save({ saveType: 'Xlsx', fileName: `${title}.xlsx`})
293
293
  const wb = XLSX.utils.book_new();
294
294
  const rows = this.spreadsheet.sheets[0].rows.map(r => r.cells.map(c => c.value));
295
295
  const ws = XLSX.utils.aoa_to_sheet(rows);
@@ -345,4 +345,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
345
345
  }], id: [{
346
346
  type: HostBinding
347
347
  }] } });
348
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spreadsheet.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/cube/grid/spreadsheet.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Component, Output, Inject, OnInit, HostBinding, ElementRef, OnDestroy, Input, SimpleChanges, OnChanges } from \"@angular/core\";\r\nimport { HttpResponse } from \"@angular/common/http\";\r\nimport { CellModel, ColumnModel, RowModel, Spreadsheet, CellStyleModel, SelectEventArgs } from \"@syncfusion/ej2-angular-spreadsheet\";\r\nimport { Internationalization, NumberFormatOptions } from \"@syncfusion/ej2-base\";\r\nimport * as XLSX from 'xlsx';\r\nimport { AxisClickEvent, CubeViewerComponent } from \"../declarations\";\r\nimport { AxesMap, Cube, CubeAxis, CubeIndex, YAxis } from \"../../core/models\";\r\nimport { CubeService } from \"../cube.service\";\r\nimport { PromptService } from \"../../core/prompt.service\";\r\nimport { TranslateService } from \"../../core/translate.service\";\r\nimport { DatasourceService } from \"../../core/datasource.service\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { isArray, isString } from \"../../core/functions\";\r\n\r\n@Component({\r\n  selector: 'bizdoc-cube-spreadsheet',\r\n  template: '',\r\n  styles: [`::ng-deep .e-spreadsheet .e-dragfill-ddb {\r\n  display: none !important;\r\n}\r\n`],\r\n  host: {\r\n    class: 'cube-view'\r\n  }\r\n})\r\nexport class CubeSpreadsheetComponent implements OnInit, CubeViewerComponent, OnChanges, OnDestroy {\r\n  private static nextId = 0;\r\n  @Input()\r\n  width: string;\r\n  @Input()\r\n  height: string;\r\n  @Input()\r\n  cube: string;\r\n  @Input()\r\n  set xAxis(val: string[] | string) {\r\n    this._xAxis = isArray(val) ? val : [val];\r\n  }\r\n  @Input()\r\n  yAxis?: YAxis;\r\n  @Input()\r\n  set series(val: string[] | string) {\r\n    if (val) this._series = isArray(val) ? val : [val];\r\n  }\r\n  @Input()\r\n  set indices(val: string[] | string) {\r\n    if (val) this._indices = isArray(val) ? val : [val];\r\n  }\r\n  @Input()\r\n  filters?: AxesMap;\r\n  @Input()\r\n  currencyCode: string;\r\n  @Output() readonly explore = new EventEmitter<AxisClickEvent>();\r\n  @Input() loading: boolean;\r\n  @Output() readonly loadingChange = new EventEmitter<boolean>();\r\n  @HostBinding() id = `cube-spreadsheet-${CubeSpreadsheetComponent.nextId++}`;\r\n  spreadsheet: Spreadsheet;\r\n  dataSource: RowModel[] = [];\r\n  columns: ColumnModel[];\r\n  private _xAxis: string[];\r\n  private _series?: string[];\r\n  private _indices?: string[];\r\n  private _axes: CubeAxis[];\r\n  private _cindices: CubeIndex[];\r\n  private _yrows: { key: any; value: any }[] = [];\r\n  private _xcolumns: { key: any; value: any }[] = [];\r\n  private _prepare: Promise<any[]>;\r\n  private _cube: Cube;\r\n  private readonly _intl: Internationalization = new Internationalization();\r\n  private _numberFormat: string;\r\n  constructor(\r\n    private _session: SessionService,\r\n    private _sb: PromptService,\r\n    private _service: CubeService,\r\n    private _translate: TranslateService,\r\n    private _ds: DatasourceService,\r\n    private _elementRef: ElementRef) { }\r\n  ngOnInit(): void {\r\n    this._numberFormat = this._intl.getNumberPattern({\r\n      currency: this.currencyCode,\r\n      format: this.currencyCode ? 'c' : 'n',\r\n      useGrouping: true,\r\n      maximumFractionDigits: this._service.fractionDigits,\r\n      minimumFractionDigits: this._service.fractionDigits\r\n    } as NumberFormatOptions)\r\n\r\n    this._cube = this._session.profile.cubes.find(c => c.name === this.cube);\r\n    if (!this._series) {\r\n      this._axes = this._xAxis.map(c => this._cube.axes.find(a => a.name == c));\r\n      if (this._indices) this._cindices = this._cube.indices.filter(i => this._indices.indexOf(i.name) > -1);\r\n      this.columns = this._axes.map(_ => {\r\n        return {\r\n          width: 120\r\n        } as ColumnModel;\r\n      });\r\n      this.columns.push({\r\n        width: 90\r\n      } /* value */);\r\n      this._indices && this._indices.forEach(_ => this.columns.push({\r\n        width: 90\r\n      } as ColumnModel\r\n      ));\r\n    }\r\n    else {\r\n      const yName = this._series[0], xName = this._xAxis[0],\r\n        xAxis = this._cube.axes.find(a => a.name === xName),\r\n        yAxis = this._cube.axes.find(a => a.name === yName);\r\n      const promises: Promise<any>[] = [];\r\n      this.columns = [{\r\n        width: 120\r\n      }];\r\n      // acquire columns source\r\n      let observe = this._ds.all(xAxis.dataType).toPromise().\r\n        then(c => {\r\n          this._xcolumns = c;\r\n          c.forEach(_ => this.columns.push({\r\n            width: 90\r\n          } as ColumnModel\r\n          ));\r\n        }) as Promise<any>;\r\n      promises.push(observe);\r\n      // acquire rows source\r\n      observe = this._ds.all(yAxis.dataType).toPromise().\r\n        then(r => this._yrows = r);\r\n      promises.push(observe);\r\n\r\n\r\n      this._prepare = Promise.all(promises);\r\n    }\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['filters'])\r\n      this.execute();\r\n    else\r\n      if (changes['height'] || changes['width'])\r\n        if (this.spreadsheet) {\r\n          this.spreadsheet.height = this.height;\r\n          this.spreadsheet.width = this.width;\r\n          this.spreadsheet.resize();\r\n        }\r\n  }\r\n  private execute() {\r\n    this.loadingChange.emit(true);\r\n    const numberStyle = { textAlign: 'right' } as CellStyleModel;\r\n    if (!this._series)\r\n      this._service.table(this.cube, this._xAxis, { filters: this.filters, indices: this._indices }).\r\n        subscribe(data => {\r\n          const cells = [],\r\n            style = { fontWeight: 'bold', textAlign: 'center' } as CellStyleModel;\r\n          this._axes.forEach(c => cells.push({\r\n            value: c.title, style\r\n          } as CellModel));\r\n          this._indices && this._cindices.forEach(i => cells.push({ value: i.title, style } as CellModel));\r\n          cells.push({\r\n            value: this.yAxis ? this.yAxis.title : this._translate.get('Value'),\r\n            style\r\n          } as CellModel);\r\n          this.dataSource = [{\r\n            cells, height: 20\r\n          } as RowModel];\r\n          data.forEach(d => {\r\n            const cells = [];\r\n            this._xAxis.forEach(c => cells.push({\r\n              value: d[c],\r\n            } as CellModel));\r\n            this._indices && this._indices.forEach(i => cells.push({\r\n              style: numberStyle,\r\n              format: this._numberFormat,\r\n              value: (d[i] || 0).toString(),\r\n            } as CellModel));\r\n            cells.push({\r\n              style: numberStyle,\r\n              format: this._numberFormat,\r\n              value: (d.value || 0).toString(),\r\n            } as CellModel);\r\n            this.dataSource.push({ cells, source: d, height: 20 } as RowModel);\r\n          });\r\n          this._draw();\r\n          this.loadingChange.emit(false);\r\n        }, (e: HttpResponse<any>) => {\r\n          this._sb.error(e.status === 401 ? 'Unauthorized' : null);\r\n          this.loadingChange.emit(false);\r\n        });\r\n    else this._service.series(this.cube, this._xAxis, { series: this._series, filters: this.filters }).\r\n      subscribe(d => {\r\n        this._prepare.then(() => {\r\n          const style = { fontWeight: 'bold', textAlign: 'center' } as CellStyleModel;\r\n          const cells = [{ value: '' } as CellModel];\r\n          this._xcolumns.forEach(c => cells.push({ value: c.value, style }));\r\n          this.dataSource = [{ cells, height: 20 }];\r\n\r\n          this._indices && this._cube.indices.filter(i => this._indices.indexOf(i.name) > 0).\r\n            forEach(i => {\r\n              const cells = [{ value: i.title, style } as CellModel],\r\n                serie = d.find(s => s.index === i.name), map = {};\r\n              if (serie) {\r\n                serie.points.forEach(p => map[p.x] = p.y);\r\n                this._xcolumns.forEach(c =>\r\n                  cells.push({\r\n                    value: (map[c.key] || 0).toString(),\r\n                    format: this._numberFormat,\r\n                    style: numberStyle\r\n                  })\r\n                );\r\n                this.dataSource.push({ cells, height: 20 } as RowModel);\r\n              }\r\n            });\r\n          this._yrows.forEach(r => {\r\n            const cells = [{ value: r.value, style } as CellModel],\r\n              serie = d.find(s => s.name === r.key), map = {};\r\n            if (serie) {\r\n              serie.points.forEach(p => map[p.x] = p.y);\r\n              this._xcolumns.forEach(c =>\r\n                cells.push({\r\n                  value: (map[c.key] || 0).toString(),\r\n                  format: this._numberFormat,\r\n                  style: numberStyle\r\n                })\r\n              );\r\n            }\r\n            else\r\n              this._xcolumns.forEach(_ =>\r\n                cells.push({ value: '0' })\r\n              );\r\n            this.dataSource.push({ cells, height: 20 } as RowModel);\r\n          });\r\n          this._draw();\r\n          this.loadingChange.emit(false);\r\n        });\r\n      }, (e: HttpResponse<any>) => {\r\n        this._sb.error(e.status === 401 ? 'Unauthorized' : null);\r\n        this.loadingChange.emit(false);\r\n      });\r\n  }\r\n\r\n  private _draw() {\r\n    this.spreadsheet && this.spreadsheet.destroy();\r\n    this.spreadsheet = new Spreadsheet({\r\n      isProtected: true,\r\n      allowEditing: false,\r\n      allowDelete: false,\r\n      allowInsert: false,\r\n      allowSorting: true,\r\n      //allowSave: false,\r\n      showRibbon: false,\r\n      allowAutoFill: false,\r\n      autoFillSettings: { showFillOptions: false },\r\n      //enableClipboard: true,\r\n      //allowChart: false,\r\n      //allowFiltering: false,\r\n      //allowDataValidation: false,\r\n      //allowFindAndReplace: false,\r\n      enableContextMenu: false,\r\n      showFormulaBar: false,\r\n      showSheetTabs: false,\r\n//scrollSettings: { isFinite: true },\r\n      select: this.select.bind(this),\r\n      sheets: [{\r\n        columns: this.columns,\r\n        //frozenColumns: this.series !== undefined ? 1 : 0,\r\n        //frozenRows: 1,\r\n        rows: this.dataSource,\r\n      }],\r\n      width: this.width,\r\n      height: this.height,\r\n    }, this._elementRef.nativeElement);\r\n  }\r\n  select(evt: SelectEventArgs) {\r\n    const address = this.spreadsheet.getAddressInfo(evt.range);\r\n    let [y, x, y1, x1] = address.indices;\r\n    if (y1 < y) {\r\n      const range = y;\r\n      y = y1, y1 = range;\r\n    }\r\n    if (x1 < x) {\r\n      const range = x;\r\n      x = x1, x1 = range;\r\n    }\r\n    const axes: {} = {};\r\n    if (!this._series) {\r\n      if (y === 0) return;\r\n      const index = this._indices && y < this._indices.length ? this._cindices[y].name : null;\r\n      let i = y;\r\n      do {\r\n        this._axes.forEach(a => {\r\n          const key = (this.dataSource[i] as any).source['_' + a.name];\r\n          if (!axes[a.name])\r\n            axes[a.name] = key;\r\n          else if (isString(axes[a.name]))\r\n            axes[a.name] = [axes[a.name], key];\r\n          else if ((axes[a.name] as string[]).indexOf(key) < 0) (axes[a.name] as string[]).push(key);\r\n        });\r\n        i++;\r\n      }\r\n      while (i <= y1);\r\n      this.explore.emit({ axes, index });\r\n    }\r\n    else {\r\n      if (y === 0) {\r\n        if (y < y1) {\r\n          const { key } = this._xcolumns[x - 1], xName = this._xAxis[0];\r\n          axes[xName] = key;\r\n        }\r\n        else return;\r\n      }\r\n      else if (x === 0) {\r\n        if (x < x1) {\r\n          const { key } = this._yrows[y - 1], yName = this._series[0];\r\n          axes[yName] = key;\r\n        }\r\n        else return;\r\n      }\r\n      else if (y === y1 && x === x1 && this.dataSource[y].cells[x].value === '0') return;\r\n      else if (y > this.dataSource.length - 1 || x > this.dataSource[y].cells.length - 1) return;\r\n      else {\r\n        const xName = this._xAxis[0], yName = this._series[0];\r\n        let i = y - 1, j = x - 1;\r\n        while (j < x1) {\r\n          let { key } = this._xcolumns[j];\r\n          if (!axes[xName])\r\n            axes[xName] = key;\r\n          else if (isString(axes[xName]))\r\n            axes[xName] = [axes[xName], key];\r\n          else if ((axes[xName] as string[]).indexOf(key) < 0)\r\n            (axes[xName] as string[]).push(key);\r\n          j++;\r\n        }\r\n        while (i < y1) {\r\n          let { key } = this._yrows[i];\r\n          if (!axes[yName]) axes[yName] = key;\r\n          else if (isString(axes[yName]))\r\n            axes[yName] = [axes[yName], key];\r\n          else if ((axes[yName] as string[]).indexOf(key) < 0)\r\n            (axes[yName] as string[]).push(key);\r\n          i++;\r\n        }\r\n      }\r\n      this.explore.emit({ axes });\r\n    }\r\n  }\r\n  exportToExcel(title: string) {\r\n    //this.spreadsheet.save({ saveType: 'Xlsx', fileName: `${title}.xlsx`})\r\n    const wb = XLSX.utils.book_new();\r\n\r\n    const rows = this.spreadsheet.sheets[0].rows.map(r => r.cells.map(c => c.value));\r\n    const ws = XLSX.utils.aoa_to_sheet(rows);\r\n\r\n    const name = this._translate.get('SheetN', 1);\r\n    wb.Sheets[name] = ws;\r\n    wb.SheetNames.push(name);\r\n\r\n    XLSX.writeFile(wb, `${title}.xlsx`);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.spreadsheet && this.spreadsheet.destroy();\r\n  }\r\n}\r\n"]}
348
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"spreadsheet.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/cube/grid/spreadsheet.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter, Component, Output, OnInit, HostBinding, ElementRef, OnDestroy, Input, SimpleChanges, OnChanges } from \"@angular/core\";\r\nimport { HttpResponse } from \"@angular/common/http\";\r\nimport { CellModel, ColumnModel, RowModel, Spreadsheet, CellStyleModel, SelectEventArgs, AutoFillSettingsModel } from \"@syncfusion/ej2-angular-spreadsheet\";\r\nimport { Internationalization, NumberFormatOptions } from \"@syncfusion/ej2-base\";\r\nimport * as XLSX from 'xlsx';\r\nimport { AxisClickEvent, CubeViewerComponent } from \"../declarations\";\r\nimport { AxesMap, Cube, CubeAxis, CubeIndex, YAxis } from \"../../core/models\";\r\nimport { CubeService, Series } from \"../cube.service\";\r\nimport { PromptService } from \"../../core/prompt.service\";\r\nimport { TranslateService } from \"../../core/translate.service\";\r\nimport { DatasourceService } from \"../../core/datasource.service\";\r\nimport { SessionService } from \"../../core/session.service\";\r\nimport { isArray, isString } from \"../../core/functions\";\r\n\r\n@Component({\r\n  selector: 'bizdoc-cube-spreadsheet',\r\n  template: '',\r\n  styles: [`::ng-deep .e-spreadsheet .e-dragfill-ddb {\r\n  display: none !important;\r\n}\r\n`],\r\n  host: {\r\n    class: 'cube-view'\r\n  }\r\n})\r\nexport class CubeSpreadsheetComponent implements OnInit, CubeViewerComponent, OnChanges, OnDestroy {\r\n  private static nextId = 0;\r\n  @Input()\r\n  width: string;\r\n  @Input()\r\n  height: string;\r\n  @Input()\r\n  cube: string;\r\n  @Input()\r\n  set xAxis(val: string[] | string) {\r\n    this._xAxis = isArray(val) ? val : [val];\r\n  }\r\n  @Input()\r\n  yAxis?: YAxis;\r\n  @Input()\r\n  set series(val: string[] | string) {\r\n    if (val) this._series = isArray(val) ? val : [val];\r\n  }\r\n  @Input()\r\n  set indices(val: string[] | string) {\r\n    if (val) this._indices = isArray(val) ? val : [val];\r\n  }\r\n  @Input()\r\n  filters?: AxesMap;\r\n  @Input()\r\n  currencyCode: string;\r\n  @Output() readonly explore = new EventEmitter<AxisClickEvent>();\r\n  @Input() loading: boolean;\r\n  @Output() readonly loadingChange = new EventEmitter<boolean>();\r\n  @HostBinding() id = `cube-spreadsheet-${CubeSpreadsheetComponent.nextId++}`;\r\n  spreadsheet: Spreadsheet;\r\n  dataSource: RowModel[] = [];\r\n  columns: ColumnModel[];\r\n  readonly numberStyle = { textAlign: 'right' } as CellStyleModel;\r\n  readonly autoFillSettings = { showFillOptions: false } as AutoFillSettingsModel;\r\n  private _xAxis: string[];\r\n  private _series?: string[];\r\n  private _indices?: string[];\r\n  private _axes: CubeAxis[];\r\n  private _cindices: CubeIndex[];\r\n  private _yrows: { key: any; value: any }[] = [];\r\n  private _xcolumns: { key: any; value: any }[] = [];\r\n  private _prepare: Promise<any[]>;\r\n  private _cube: Cube;\r\n  private readonly _intl: Internationalization = new Internationalization();\r\n  private _numberFormat: string;\r\n  constructor(\r\n    private _session: SessionService,\r\n    private _sb: PromptService,\r\n    private _service: CubeService,\r\n    private _translate: TranslateService,\r\n    private _ds: DatasourceService,\r\n    private _elementRef: ElementRef) { }\r\n  ngOnInit(): void {\r\n    this._numberFormat = this._intl.getNumberPattern({\r\n      currency: this.currencyCode,\r\n      format: this.currencyCode ? 'c' : 'n',\r\n      useGrouping: true,\r\n      maximumFractionDigits: this._service.fractionDigits,\r\n      minimumFractionDigits: this._service.fractionDigits\r\n    } as NumberFormatOptions)\r\n\r\n    this._cube = this._session.profile.cubes.find(c => c.name === this.cube);\r\n    if (!this._series) {\r\n      this._axes = this._xAxis.map(c => this._cube.axes.find(a => a.name == c));\r\n      if (this._indices) this._cindices = this._cube.indices.filter(i => this._indices.indexOf(i.name) > -1);\r\n      this.columns = this._axes.map(_ => {\r\n        return {\r\n          width: 120\r\n        } as ColumnModel;\r\n      });\r\n      this.columns.push({\r\n        width: 90\r\n      } /* value */);\r\n      this._indices && this._indices.forEach(_ => this.columns.push({\r\n        width: 90\r\n      } as ColumnModel\r\n      ));\r\n    }\r\n    else {\r\n      const yName = this._series[0], xName = this._xAxis[0],\r\n        xAxis = this._cube.axes.find(a => a.name === xName),\r\n        yAxis = this._cube.axes.find(a => a.name === yName);\r\n      const promises: Promise<any>[] = [];\r\n      this.columns = [{\r\n        width: 120\r\n      }];\r\n      // acquire columns source\r\n      let observe = this._ds.all(xAxis.dataType).toPromise().\r\n        then(c => {\r\n          this._xcolumns = c;\r\n          c.forEach(_ => this.columns.push({\r\n            width: 90\r\n          } as ColumnModel\r\n          ));\r\n        }) as Promise<any>;\r\n      promises.push(observe);\r\n      // acquire rows source\r\n      observe = this._ds.all(yAxis.dataType).toPromise().\r\n        then(r => this._yrows = r);\r\n      promises.push(observe);\r\n\r\n\r\n      this._prepare = Promise.all(promises);\r\n    }\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['filters'])\r\n      this.execute();\r\n    else\r\n      if (changes['height'] || changes['width'])\r\n        if (this.spreadsheet) {\r\n          this.spreadsheet.height = this.height;\r\n          this.spreadsheet.width = this.width;\r\n          this.spreadsheet.resize();\r\n        }\r\n  }\r\n  private execute() {\r\n    this.loadingChange.emit(true);\r\n    if (!this._series)\r\n      this._service.table(this.cube, this._xAxis, { filters: this.filters, indices: this._indices }).\r\n        subscribe(data => {\r\n          this._datatable(data);\r\n          this._draw();\r\n          this.loadingChange.emit(false);\r\n        }, (e: HttpResponse<any>) => {\r\n          this._sb.error(e.status === 401 ? 'Unauthorized' : null);\r\n          this.loadingChange.emit(false);\r\n        });\r\n    else this._service.series(this.cube, this._xAxis, { series: this._series, filters: this.filters }).\r\n      subscribe(data => {\r\n        this._prepare.then(() => {\r\n          this._dataseries(data);\r\n          this._draw();\r\n          this.loadingChange.emit(false);\r\n        });\r\n      }, (e: HttpResponse<any>) => {\r\n        this._sb.error(e.status === 401 ? 'Unauthorized' : null);\r\n        this.loadingChange.emit(false);\r\n      });\r\n  }\r\n  private _datatable(data: { value: number; }[]) {\r\n    const cells = [], style = { fontWeight: 'bold', textAlign: 'center' } as CellStyleModel;\r\n    this._axes.forEach(c => cells.push({\r\n      value: c.title, style\r\n    } as CellModel));\r\n    this._indices && this._cindices.forEach(i => cells.push({ value: i.title, style } as CellModel));\r\n    cells.push({\r\n      value: this.yAxis ? this.yAxis.title : this._translate.get('Value'),\r\n      style\r\n    } as CellModel);\r\n    this.dataSource = [{\r\n      cells, height: 25\r\n    } as RowModel];\r\n    data.forEach(d => {\r\n      const cells = [];\r\n      this._xAxis.forEach(c => cells.push({\r\n        value: d[c],\r\n      } as CellModel));\r\n      this._indices && this._indices.forEach(i => cells.push({\r\n        style: this.numberStyle,\r\n        format: this._numberFormat,\r\n        value: (d[i] || 0).toString(),\r\n      } as CellModel));\r\n      cells.push({\r\n        style: this.numberStyle,\r\n        format: this._numberFormat,\r\n        value: (d.value || 0).toString(),\r\n      } as CellModel);\r\n      this.dataSource.push({ cells, source: d, height: 25 } as RowModel);\r\n    });\r\n  }\r\n\r\n  private _dataseries(d: Series[]) {\r\n    const style = { fontWeight: 'bold', textAlign: 'center' } as CellStyleModel;\r\n    const cells = [{ value: '' } as CellModel];\r\n    this._xcolumns.forEach(c => cells.push({ value: c.value, style }));\r\n    this.dataSource = [{ cells, height: 25 }];\r\n\r\n    this._indices && this._cube.indices.filter(i => this._indices.indexOf(i.name) > 0).\r\n      forEach(i => {\r\n        const cells = [{ value: i.title, style } as CellModel], serie = d.find(s => s.index === i.name), map = {};\r\n        if (serie) {\r\n          serie.points.forEach(p => map[p.x] = p.y);\r\n          this._xcolumns.forEach(c => cells.push({\r\n            value: (map[c.key] || 0).toString(),\r\n            format: this._numberFormat,\r\n            style: this.numberStyle\r\n          })\r\n          );\r\n          this.dataSource.push({ cells, height: 25 } as RowModel);\r\n        }\r\n      });\r\n    this._yrows.forEach(r => {\r\n      const cells = [{ value: r.value, style } as CellModel], serie = d.find(s => s.name === r.key), map = {};\r\n      if (serie) {\r\n        serie.points.forEach(p => map[p.x] = p.y);\r\n        this._xcolumns.forEach(c => cells.push({\r\n          value: (map[c.key] || 0).toString(),\r\n          format: this._numberFormat,\r\n          style: this.numberStyle\r\n        })\r\n        );\r\n      }\r\n      else\r\n        this._xcolumns.forEach(_ => cells.push({ value: '0' })\r\n        );\r\n      this.dataSource.push({ cells, height: 25 } as RowModel);\r\n    });\r\n  }\r\n\r\n  private _draw() {\r\n    this.spreadsheet && this.spreadsheet.destroy();\r\n    this.spreadsheet = new Spreadsheet({\r\n      isProtected: true,\r\n      allowEditing: false,\r\n      allowDelete: false,\r\n      allowInsert: false,\r\n      allowSorting: true,\r\n      showRibbon: false,\r\n      allowAutoFill: false,\r\n      autoFillSettings: this.autoFillSettings,\r\n      enableClipboard: true,\r\n      enableContextMenu: false,\r\n      showFormulaBar: false,\r\n      showSheetTabs: false,\r\n      select: this.select.bind(this),\r\n      sheets: [{\r\n        columns: this.columns,\r\n        //frozenColumns: this.series !== undefined ? 1 : 0,\r\n        //frozenRows: 1,\r\n        rows: this.dataSource,\r\n      }],\r\n      width: this.width,\r\n      height: this.height,\r\n    }, this._elementRef.nativeElement);\r\n  }\r\n  select(evt: SelectEventArgs) {\r\n    const address = this.spreadsheet.getAddressInfo(evt.range);\r\n    let [y, x, y1, x1] = address.indices;\r\n    if (y1 < y) {\r\n      const range = y;\r\n      y = y1, y1 = range;\r\n    }\r\n    if (x1 < x) {\r\n      const range = x;\r\n      x = x1, x1 = range;\r\n    }\r\n    const axes: {} = {};\r\n    if (!this._series) {\r\n      if (y === 0) return;\r\n      const index = this._indices && y < this._indices.length ? this._cindices[y].name : null;\r\n      let i = y;\r\n      do {\r\n        this._axes.forEach(a => {\r\n          const key = (this.dataSource[i] as any).source['_' + a.name];\r\n          if (!axes[a.name])\r\n            axes[a.name] = key;\r\n          else if (isString(axes[a.name]))\r\n            axes[a.name] = [axes[a.name], key];\r\n          else if ((axes[a.name] as string[]).indexOf(key) < 0) (axes[a.name] as string[]).push(key);\r\n        });\r\n        i++;\r\n      }\r\n      while (i <= y1);\r\n      this.explore.emit({ axes, index });\r\n    }\r\n    else {\r\n      if (y === 0) {\r\n        if (y < y1) {\r\n          const { key } = this._xcolumns[x - 1], xName = this._xAxis[0];\r\n          axes[xName] = key;\r\n        }\r\n        else return;\r\n      }\r\n      else if (x === 0) {\r\n        if (x < x1) {\r\n          const { key } = this._yrows[y - 1], yName = this._series[0];\r\n          axes[yName] = key;\r\n        }\r\n        else return;\r\n      }\r\n      else if (y === y1 && x === x1 && this.dataSource[y].cells[x].value === '0') return;\r\n      else if (y > this.dataSource.length - 1 || x > this.dataSource[y].cells.length - 1) return;\r\n      else {\r\n        const xName = this._xAxis[0], yName = this._series[0];\r\n        let i = y - 1, j = x - 1;\r\n        while (j < x1) {\r\n          let { key } = this._xcolumns[j];\r\n          if (!axes[xName])\r\n            axes[xName] = key;\r\n          else if (isString(axes[xName]))\r\n            axes[xName] = [axes[xName], key];\r\n          else if ((axes[xName] as string[]).indexOf(key) < 0)\r\n            (axes[xName] as string[]).push(key);\r\n          j++;\r\n        }\r\n        while (i < y1) {\r\n          let { key } = this._yrows[i];\r\n          if (!axes[yName]) axes[yName] = key;\r\n          else if (isString(axes[yName]))\r\n            axes[yName] = [axes[yName], key];\r\n          else if ((axes[yName] as string[]).indexOf(key) < 0)\r\n            (axes[yName] as string[]).push(key);\r\n          i++;\r\n        }\r\n      }\r\n      this.explore.emit({ axes });\r\n    }\r\n  }\r\n  exportToExcel(title: string) {\r\n    const wb = XLSX.utils.book_new();\r\n\r\n    const rows = this.spreadsheet.sheets[0].rows.map(r => r.cells.map(c => c.value));\r\n    const ws = XLSX.utils.aoa_to_sheet(rows);\r\n\r\n    const name = this._translate.get('SheetN', 1);\r\n    wb.Sheets[name] = ws;\r\n    wb.SheetNames.push(name);\r\n\r\n    XLSX.writeFile(wb, `${title}.xlsx`);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.spreadsheet && this.spreadsheet.destroy();\r\n  }\r\n}\r\n"]}
@@ -26,7 +26,7 @@ export class CubeAccumAnalysisWidget extends CubeAnalysisBase {
26
26
  visible: true,
27
27
  position: 'Outside',
28
28
  connectorStyle: { length: '10%' },
29
- name: 'x',
29
+ name: 'name',
30
30
  font: {
31
31
  size: '14px',
32
32
  fontFamily: FONT_FAMILY,
@@ -143,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
143
143
  }
144
144
  }]
145
145
  }], ctorParameters: function () { return [{ type: i1.WidgetRef }, { type: i2.CubeInfo }, { type: i3.SessionService }, { type: i4.DatasourceService }, { type: i5.CubeService }, { type: i0.ElementRef }]; } });
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accum-cube.widget.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/dashboard/cube/accum-cube.widget.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, ViewChild, ElementRef } from '@angular/core';\r\nimport {\r\n  LegendSeriesModel, TooltipSettingsModel, AccumulationChart,\r\n  AccumulationDataLabelSettingsModel, AnimationModel, IAccTooltipRenderEventArgs, AccumulationDataLabel, AccumulationTooltip,\r\n  AccumulationSeriesModel,\r\n  IPointEventArgs\r\n} from '@syncfusion/ej2-angular-charts';\r\nimport { CubeAnalysisBase, Point, Options } from './cube-analysis.base';\r\nimport { DatasourceService } from '../../core/datasource.service';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { AXES_CODE_DIVIDER, CubeService, Series } from '../../cube/cube.service';\r\nimport { WidgetRef } from \"../widget-ref\";\r\nimport { AxesMap, Dimentions } from '../../core/models';\r\nimport { FONT_FAMILY } from '../../core/colors';\r\nimport { CubeInfo } from '../../cube/cube-info.service';\r\n\r\nAccumulationChart.Inject(AccumulationDataLabel, AccumulationTooltip);\r\n\r\nfunction cardColor(): string {\r\n  return getComputedStyle(document.querySelector(\".mat-card-title\")).color;\r\n}\r\n\r\n@Component({\r\n  selector: 'bizdoc-accum-cube-analysis',\r\n  template: '',\r\n  //  templateUrl: './accum-cube.widget.html',\r\n  host: {\r\n    '[id]': 'id',\r\n    dir: 'ltr'\r\n  }\r\n})\r\n/** statistics component*/\r\nexport class CubeAccumAnalysisWidget extends CubeAnalysisBase implements OnDestroy {\r\n  //@ViewChild(AccumulationChartComponent)\r\n  chart: AccumulationChart;\r\n  data: Point[] = [];\r\n  startAngle = 0;\r\n  endAngle = 360;\r\n  innerRadius = '0';\r\n  readonly dataLabel: AccumulationDataLabelSettingsModel = {\r\n    visible: true,\r\n    position: 'Outside',\r\n    connectorStyle: { length: '10%' },\r\n    name: 'x',\r\n    font: {\r\n      size: '14px',\r\n      fontFamily: FONT_FAMILY,\r\n      color: cardColor()\r\n    }\r\n  };\r\n  readonly legend: LegendSeriesModel = {\r\n    isInversed: this._session.inverse,\r\n    visible: false\r\n  };\r\n  readonly tooltip: TooltipSettingsModel = {\r\n    enable: true,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  };\r\n  readonly animation: AnimationModel = { enable: true, duration: 1000 };\r\n  readonly enableRtl = this._session.inverse;\r\n\r\n  constructor(ref: WidgetRef<Options>,\r\n    info: CubeInfo,\r\n    session: SessionService,\r\n    ds: DatasourceService,\r\n    cube: CubeService,\r\n    private _elementRef: ElementRef) {\r\n    super(ref, info,session, ds, cube);\r\n    switch (this._options.chartType) {\r\n      case 'Doughnut':\r\n        this.innerRadius = '40%';\r\n        break;\r\n      case 'HalfDoughnut':\r\n        this.startAngle = 270;\r\n        this.endAngle = 90;\r\n        this.innerRadius = '40%';\r\n        break;\r\n      default:\r\n    }\r\n  }\r\n  onLoad(data: Series[]) {\r\n    this.data = data.length ? data[0].points : [];\r\n    this._draw();\r\n  }\r\n  onResize(dim: Dimentions) {\r\n    if (this.chart) {\r\n     // this.chart.height = `${dim.height}px`;\r\n      //this.chart.width = `${dim.width}px`;\r\n      this.chart.refresh();\r\n    }\r\n  }\r\n  onThemeChange() {\r\n    this.data = this.data.slice();\r\n    if (this.chart) {\r\n      this.chart.theme = this.theme;\r\n      this.chart.series[0].palettes = this.palettes;\r\n      this.chart.series[0].dataLabel.font.color = cardColor();\r\n      this.chart.refresh();\r\n    }\r\n  }\r\n\r\n  tooltipRender(e: IAccTooltipRenderEventArgs) {\r\n    (e as any).text = this._intl.formatNumber(e.point.y, {\r\n      currency: this.currencyCode,\r\n      format: this.currencyCode ? 'c' : 'n',\r\n      maximumFractionDigits: this._service.fractionDigits\r\n    });\r\n  }\r\n  private _draw() {\r\n    const series: AccumulationSeriesModel[] = [{\r\n      dataSource: this.data,\r\n      xName: 'x',\r\n      yName: 'y',\r\n      startAngle: this.startAngle,\r\n      endAngle: this.endAngle,\r\n      radius: '70%',\r\n      dataLabel: this.dataLabel,\r\n      explode: true,\r\n      explodeOffset: '10%',\r\n      explodeIndex: 0,\r\n      innerRadius: this.innerRadius,\r\n      animation: this.animation,\r\n      palettes: this.palettes\r\n    }];\r\n    this.chart && this.chart.destroy();\r\n    if(this.data.length) this.chart = new AccumulationChart({\r\n     // width: `${this.width}px`,\r\n      // height: `${this.height}px`,\r\n      enableRtl: this.enableRtl,\r\n      background: 'transparent',\r\n      legendSettings: this.legend,\r\n      enableAnimation: true,\r\n      pointClick: this.pointClick.bind(this),\r\n      tooltip: this.tooltip,\r\n      currencyCode: this.currencyCode,\r\n      tooltipRender: this.tooltipRender.bind(this),\r\n      theme: this.theme,\r\n      series\r\n    }, this._elementRef.nativeElement);\r\n  }\r\n  pointClick(evt: IPointEventArgs) {\r\n    const axes: AxesMap = {};\r\n    const x = (evt.series.dataSource[evt.pointIndex].x as string).split(AXES_CODE_DIVIDER);\r\n    for (let i = 0; i < this.xAxis.length; i++)\r\n      axes[this.xAxis[i]] = x[i];\r\n    this.explore(axes);\r\n  }\r\n  ngOnDestroy() {\r\n    this.chart && this.chart.destroy();\r\n    super.ngOnDestroy();\r\n  }\r\n}\r\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accum-cube.widget.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/dashboard/cube/accum-cube.widget.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, ElementRef } from '@angular/core';\r\nimport {\r\n  LegendSeriesModel, TooltipSettingsModel, AccumulationChart,\r\n  AccumulationDataLabelSettingsModel, AnimationModel, IAccTooltipRenderEventArgs, AccumulationDataLabel, AccumulationTooltip,\r\n  AccumulationSeriesModel,\r\n  IPointEventArgs\r\n} from '@syncfusion/ej2-angular-charts';\r\nimport { CubeAnalysisBase, Point, Options } from './cube-analysis.base';\r\nimport { DatasourceService } from '../../core/datasource.service';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { AXES_CODE_DIVIDER, CubeService, Series } from '../../cube/cube.service';\r\nimport { WidgetRef } from \"../widget-ref\";\r\nimport { AxesMap, Dimentions } from '../../core/models';\r\nimport { FONT_FAMILY } from '../../core/colors';\r\nimport { CubeInfo } from '../../cube/cube-info.service';\r\n\r\nAccumulationChart.Inject(AccumulationDataLabel, AccumulationTooltip);\r\n\r\nfunction cardColor(): string {\r\n  return getComputedStyle(document.querySelector(\".mat-card-title\")).color;\r\n}\r\n\r\n@Component({\r\n  selector: 'bizdoc-accum-cube-analysis',\r\n  template: '',\r\n  //  templateUrl: './accum-cube.widget.html',\r\n  host: {\r\n    '[id]': 'id',\r\n    dir: 'ltr'\r\n  }\r\n})\r\n/** statistics component*/\r\nexport class CubeAccumAnalysisWidget extends CubeAnalysisBase implements OnDestroy {\r\n  //@ViewChild(AccumulationChartComponent)\r\n  chart: AccumulationChart;\r\n  data: Point[] = [];\r\n  startAngle = 0;\r\n  endAngle = 360;\r\n  innerRadius = '0';\r\n  readonly dataLabel: AccumulationDataLabelSettingsModel = {\r\n    visible: true,\r\n    position: 'Outside',\r\n    connectorStyle: { length: '10%' },\r\n    name: 'name',\r\n    font: {\r\n      size: '14px',\r\n      fontFamily: FONT_FAMILY,\r\n      color: cardColor()\r\n    }\r\n  };\r\n  readonly legend: LegendSeriesModel = {\r\n    isInversed: this._session.inverse,\r\n    visible: false\r\n  };\r\n  readonly tooltip: TooltipSettingsModel = {\r\n    enable: true,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  };\r\n  readonly animation: AnimationModel = { enable: true, duration: 1000 };\r\n  readonly enableRtl = this._session.inverse;\r\n\r\n  constructor(ref: WidgetRef<Options>,\r\n    info: CubeInfo,\r\n    session: SessionService,\r\n    ds: DatasourceService,\r\n    cube: CubeService,\r\n    private _elementRef: ElementRef) {\r\n    super(ref, info,session, ds, cube);\r\n    switch (this._options.chartType) {\r\n      case 'Doughnut':\r\n        this.innerRadius = '40%';\r\n        break;\r\n      case 'HalfDoughnut':\r\n        this.startAngle = 270;\r\n        this.endAngle = 90;\r\n        this.innerRadius = '40%';\r\n        break;\r\n      default:\r\n    }\r\n  }\r\n  onLoad(data: Series[]) {\r\n    this.data = data.length ? data[0].points : [];\r\n    this._draw();\r\n  }\r\n  onResize(dim: Dimentions) {\r\n    if (this.chart) {\r\n     // this.chart.height = `${dim.height}px`;\r\n      //this.chart.width = `${dim.width}px`;\r\n      this.chart.refresh();\r\n    }\r\n  }\r\n  onThemeChange() {\r\n    this.data = this.data.slice();\r\n    if (this.chart) {\r\n      this.chart.theme = this.theme;\r\n      this.chart.series[0].palettes = this.palettes;\r\n      this.chart.series[0].dataLabel.font.color = cardColor();\r\n      this.chart.refresh();\r\n    }\r\n  }\r\n\r\n  tooltipRender(e: IAccTooltipRenderEventArgs) {\r\n    (e as any).text = this._intl.formatNumber(e.point.y, {\r\n      currency: this.currencyCode,\r\n      format: this.currencyCode ? 'c' : 'n',\r\n      maximumFractionDigits: this._service.fractionDigits\r\n    });\r\n  }\r\n  private _draw() {\r\n    const series: AccumulationSeriesModel[] = [{\r\n      dataSource: this.data,\r\n      xName: 'x',\r\n      yName: 'y',\r\n      startAngle: this.startAngle,\r\n      endAngle: this.endAngle,\r\n      radius: '70%',\r\n      dataLabel: this.dataLabel,\r\n      explode: true,\r\n      explodeOffset: '10%',\r\n      explodeIndex: 0,\r\n      innerRadius: this.innerRadius,\r\n      animation: this.animation,\r\n      palettes: this.palettes\r\n    }];\r\n    this.chart && this.chart.destroy();\r\n    if(this.data.length) this.chart = new AccumulationChart({\r\n     // width: `${this.width}px`,\r\n      // height: `${this.height}px`,\r\n      enableRtl: this.enableRtl,\r\n      background: 'transparent',\r\n      legendSettings: this.legend,\r\n      enableAnimation: true,\r\n      pointClick: this.pointClick.bind(this),\r\n      tooltip: this.tooltip,\r\n      currencyCode: this.currencyCode,\r\n      tooltipRender: this.tooltipRender.bind(this),\r\n      theme: this.theme,\r\n      series\r\n    }, this._elementRef.nativeElement);\r\n  }\r\n  pointClick(evt: IPointEventArgs) {\r\n    const axes: AxesMap = {};\r\n    const x = (evt.series.dataSource[evt.pointIndex].x as string).split(AXES_CODE_DIVIDER);\r\n    for (let i = 0; i < this.xAxis.length; i++)\r\n      axes[this.xAxis[i]] = x[i];\r\n    this.explore(axes);\r\n  }\r\n  ngOnDestroy() {\r\n    this.chart && this.chart.destroy();\r\n    super.ngOnDestroy();\r\n  }\r\n}\r\n"]}