@bizdoc/core 1.10.0-next.3 → 1.10.0-next.7

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.
Files changed (79) hide show
  1. package/assets/bizdoc-schema.json +7 -1
  2. package/assets/themes/brown.min.css +1 -1
  3. package/assets/themes/deep-purple-light-blue.min.css +1 -1
  4. package/assets/themes/default.min.css +1 -1
  5. package/assets/themes/green.min.css +1 -1
  6. package/assets/themes/indigo.min.css +1 -1
  7. package/esm2020/lib/browse/browse-items.component.mjs +3 -3
  8. package/esm2020/lib/compose/compose.mobile.component.mjs +25 -15
  9. package/esm2020/lib/compose/compose.pane.component.mjs +3 -3
  10. package/esm2020/lib/compose/trace/flow.component.mjs +23 -8
  11. package/esm2020/lib/core/animations.mjs +7 -1
  12. package/esm2020/lib/core/controls/combination-picker-body.mjs +5 -2
  13. package/esm2020/lib/core/functions.mjs +4 -1
  14. package/esm2020/lib/core/mailbox.service.mjs +20 -23
  15. package/esm2020/lib/core/models.mjs +1 -1
  16. package/esm2020/lib/core/pipes/translate.pipe.mjs +17 -2
  17. package/esm2020/lib/cube/chart/chart.component.mjs +5 -5
  18. package/esm2020/lib/cube/cube-info.service.mjs +5 -5
  19. package/esm2020/lib/cube/cube-view.component.mjs +11 -10
  20. package/esm2020/lib/cube/grid/spreadsheet.component.mjs +1 -1
  21. package/esm2020/lib/cube/matrix/matrix.base.mjs +1 -1
  22. package/esm2020/lib/cube/matrix/matrix.component.mjs +9 -9
  23. package/esm2020/lib/cube/matrix/matrix.mobile.component.mjs +4 -4
  24. package/esm2020/lib/cube/matrix/matrix.pane.component.mjs +4 -4
  25. package/esm2020/lib/cube/matrix/table.component.mjs +207 -149
  26. package/esm2020/lib/cube/parallel/parallel.component.mjs +8 -8
  27. package/esm2020/lib/cube/pivot/pivot.component.mjs +3 -3
  28. package/esm2020/lib/cube/sum/sum.component.mjs +13 -13
  29. package/esm2020/lib/cube/view.mobile.component.mjs +4 -7
  30. package/esm2020/lib/cube/view.pane.component.mjs +3 -3
  31. package/esm2020/lib/dashboard/cube/cube-analysis.base.mjs +1 -1
  32. package/esm2020/lib/dashboard/cube/cube-analysis.widget.mjs +3 -1
  33. package/esm2020/lib/dashboard/cube/cube-chart.widget.mjs +2 -2
  34. package/esm2020/lib/dashboard/cube/documents.widget.mjs +1 -1
  35. package/esm2020/lib/dashboard/cube/filter/filter.component.mjs +10 -6
  36. package/esm2020/lib/home/home.mobile.component.mjs +3 -3
  37. package/esm2020/lib/modules/chart.module.mjs +4 -4
  38. package/esm2020/lib/notifications/notifications-table.component.mjs +3 -3
  39. package/esm2020/lib/routes.desktop.mjs +2 -2
  40. package/esm2020/lib/routes.mobile.mjs +9 -9
  41. package/esm2020/lib/shared.module.mjs +4 -4
  42. package/esm2020/lib/views/cube/chart.component.mjs +5 -5
  43. package/esm2020/lib/views/cube/matrix.component.mjs +6 -6
  44. package/esm2020/lib/views/cube/parallel.component.mjs +3 -3
  45. package/esm2020/lib/views/cube/pivot.component.mjs +3 -3
  46. package/esm2020/lib/views/cube/sum.component.mjs +3 -3
  47. package/esm2020/lib/views/cube/view.component.mjs +3 -3
  48. package/esm2020/lib/views/views.mobile.component.mjs +10 -14
  49. package/esm2020/public-api.mjs +1 -1
  50. package/fesm2015/bizdoc-core.mjs +397 -296
  51. package/fesm2015/bizdoc-core.mjs.map +1 -1
  52. package/fesm2020/bizdoc-core.mjs +404 -297
  53. package/fesm2020/bizdoc-core.mjs.map +1 -1
  54. package/lib/compose/compose.mobile.component.d.ts +2 -2
  55. package/lib/compose/trace/flow.component.d.ts +1 -1
  56. package/lib/core/animations.d.ts +1 -0
  57. package/lib/core/controls/combination-picker-body.d.ts +4 -6
  58. package/lib/core/functions.d.ts +1 -0
  59. package/lib/core/mailbox.service.d.ts +4 -8
  60. package/lib/core/models.d.ts +2 -2
  61. package/lib/core/pipes/translate.pipe.d.ts +9 -1
  62. package/lib/cube/chart/chart.component.d.ts +2 -2
  63. package/lib/cube/cube-info.service.d.ts +3 -6
  64. package/lib/cube/cube-view.component.d.ts +2 -2
  65. package/lib/cube/matrix/matrix.base.d.ts +3 -7
  66. package/lib/cube/matrix/matrix.component.d.ts +3 -3
  67. package/lib/cube/matrix/table.component.d.ts +21 -31
  68. package/lib/cube/parallel/parallel.component.d.ts +2 -2
  69. package/lib/cube/pivot/pivot.component.d.ts +2 -2
  70. package/lib/cube/sum/sum.component.d.ts +3 -3
  71. package/lib/dashboard/cube/cube-analysis.base.d.ts +1 -1
  72. package/lib/shared.module.d.ts +1 -1
  73. package/lib/views/cube/chart.component.d.ts +2 -2
  74. package/lib/views/cube/matrix.component.d.ts +5 -15
  75. package/lib/views/cube/pivot.component.d.ts +1 -1
  76. package/lib/views/cube/sum.component.d.ts +2 -2
  77. package/lib/views/views.mobile.component.d.ts +1 -5
  78. package/package.json +2 -2
  79. package/public-api.d.ts +1 -1
@@ -1,10 +1,10 @@
1
1
  import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
- import { query, stagger, style, transition, trigger } from '@angular/animations';
3
2
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
4
3
  import { forkJoin, first } from 'rxjs';
5
4
  import { tap } from 'rxjs/operators';
6
- import { isArray } from '../../core/functions';
5
+ import { isArray, isFunction } from '../../core/functions';
7
6
  import { modelize } from '../cube.service';
7
+ import { matrixAnimation } from '../../core/animations';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "../../core/prompt.service";
10
10
  import * as i2 from "../cube.service";
@@ -12,12 +12,6 @@ import * as i3 from "../../core/session.service";
12
12
  import * as i4 from "../../core/datasource.service";
13
13
  import * as i5 from "@angular/common";
14
14
  const LOADING_DELAY = 200;
15
- const matrixAnimation = trigger('table', [transition('void=>*', [
16
- query('.mat-row', [
17
- style({ opacity: 0, transform: 'translateX(10px)' }),
18
- stagger(100, style({ opacity: 1, transform: 'none' }))
19
- ], { optional: true })
20
- ])]);
21
15
  /** cube matrix component*/
22
16
  export class CubeMatrixComponent {
23
17
  constructor(_sb, _service, _session, _ds) {
@@ -30,12 +24,30 @@ export class CubeMatrixComponent {
30
24
  this.onExplore = new EventEmitter();
31
25
  this.loadingChange = new EventEmitter();
32
26
  }
33
- get indices() {
34
- return this._indices;
35
- }
36
- set indices(value) {
37
- if (value)
38
- this._indices = isArray(value) ? value : [value];
27
+ set sum(val) {
28
+ if (val)
29
+ this._sum = (isArray(val) ? val : [val]).
30
+ map(sum => {
31
+ let value;
32
+ if (sum.value)
33
+ value = sum.value.toString();
34
+ else if (sum.calculate)
35
+ switch (sum.calculate) {
36
+ case 'month':
37
+ value = 'M' + ('0' + new Date().getMonth().toString()).slice(-2);
38
+ break;
39
+ case 'year':
40
+ value = new Date().getFullYear().toString();
41
+ break;
42
+ case 'quarter':
43
+ value = Math.ceil(new Date().getMonth() / 3).toString();
44
+ break;
45
+ }
46
+ return {
47
+ value,
48
+ ...sum
49
+ };
50
+ });
39
51
  }
40
52
  get interactive() {
41
53
  return this._interactive;
@@ -45,64 +57,69 @@ export class CubeMatrixComponent {
45
57
  }
46
58
  ngOnChanges(changes) {
47
59
  if (changes['_cube']) {
48
- this.cube = this.cube ? this._session.profile.cubes.find(c => c.name === this._cube) :
49
- this._session.profile.cubes[0];
60
+ this.cube = this._session.profile.cubes.find(c => c.name === this._cube);
50
61
  this.CURRENCY = this.cube.currencyCode /*|| this._service.currencyCode*/;
51
62
  }
52
- if (this._indices)
53
- this.indexes = this.cube.indices.filter(i => this._indices.indexOf(i.name) > -1);
54
- else {
55
- this.indexes = this.cube.indices;
56
- this._indices = this.indexes.map(i => i.name);
63
+ if (!this.cube) {
64
+ this.cube = this._session.profile.cubes[0];
65
+ this.CURRENCY = this.cube.currencyCode /*|| this._service.currencyCode*/;
57
66
  }
58
- if (changes['_xAxis'] || changes['_serie']) {
59
- this.xAxis = this.cube.axes.find(a => a.name === this._xAxis) || this.cube.axes[0];
60
- this.series = this.cube.axes.find(a => a.name === this._serie) || this.cube.axes[1];
61
- this._prepare = forkJoin(this._ds.all(this.series.dataType).pipe(tap(r => this.rows = r)), this._ds.all(this.xAxis.dataType).pipe(tap(c => this.columns = c))).toPromise().then(() => this.sum &&
67
+ if (changes['_indices'])
68
+ this.indices = this.cube.indices.filter(i => isArray(this._indices) ? this._indices.indexOf(i.name) > -1 : this._indices === i.name);
69
+ if (changes['_xAxis'] || changes['_series']) {
70
+ this.xAxis = this.cube.axes.find(a => a.name === this._xAxis);
71
+ this.series = this.cube.axes.find(a => a.name === this._series);
72
+ this._prepare = forkJoin(this._ds.all(this.series.dataType).pipe(tap(r => this.rows = r)), this._ds.all(this.xAxis.dataType).pipe(tap(c => this.columns = c))).toPromise().then(() => this._sum &&
62
73
  this._addsum());
63
74
  }
64
- if (changes['axes'])
75
+ if (changes['filters'])
65
76
  this.refresh();
66
77
  }
67
78
  _addsum() {
68
- let { xAxis, serie } = this._dsum;
69
- if (xAxis) {
70
- const columns = [];
71
- this.columns.forEach(c => {
72
- columns.push(c);
73
- if (xAxis.toString() === c.key)
74
- columns.push({
75
- key: '_sum',
76
- value: this.sum.title
77
- });
78
- });
79
- this.columns = columns;
80
- }
81
- if (serie) {
82
- const rows = [];
83
- this.rows.forEach(r => {
84
- rows.push(r);
85
- if (serie.toString() === r.key)
86
- rows.push({
87
- key: '_sum',
88
- value: this.sum.title
89
- });
90
- });
91
- this.rows = rows;
92
- }
79
+ this._sum.forEach((s, i) => {
80
+ let { value, axis } = s;
81
+ const element = {
82
+ key: '_sum_' + i,
83
+ value: s.title
84
+ };
85
+ let j = 0;
86
+ if (axis === 'xAxis') {
87
+ while (j < this.columns.length) {
88
+ if (this.columns[j].key === value) {
89
+ this.columns.splice(j + 1, 0, element);
90
+ break;
91
+ }
92
+ j++;
93
+ }
94
+ if (j === this.columns.length)
95
+ this.columns.push(element);
96
+ }
97
+ else {
98
+ while (j < this.rows.length) {
99
+ if (this.rows[j].key === value) {
100
+ this.rows.splice(j + 1, 0, element);
101
+ break;
102
+ }
103
+ j++;
104
+ }
105
+ if (j === this.rows.length)
106
+ this.rows.push(element);
107
+ }
108
+ });
93
109
  }
94
110
  refresh() {
95
111
  const progressTask = setTimeout(() => this.loadingChange.next(this.loading = true), LOADING_DELAY);
96
- this._prepare.then(() => this._service.series(this.cube.name, this.xAxis.name, {
97
- series: this.series.name,
112
+ this._prepare.then(() => this._service.series(this.cube.name, this._xAxis, {
113
+ series: this._series,
98
114
  indices: this._indices,
99
- filters: this.axes,
115
+ filters: this.filters,
100
116
  scope: this.scope
101
- }).pipe(modelize(), first(), tap(d => {
102
- this._totals(d);
103
- this.sum &&
117
+ }).pipe(modelize(), first()).subscribe(d => {
118
+ this._sum &&
104
119
  this._calculatesum(d);
105
- })).subscribe(d => this.data = d, (e) => {
120
+ this._totals(d);
121
+ this.data = d;
122
+ }, (e) => {
106
123
  this._sb.error(e.status === 401 ? 'Unauthorized' : null);
107
124
  }, () => {
108
125
  clearTimeout(progressTask);
@@ -110,8 +127,9 @@ export class CubeMatrixComponent {
110
127
  }));
111
128
  }
112
129
  _totals(data) {
130
+ this.totals = {};
113
131
  let grand = 0;
114
- this.indexes.forEach(i => {
132
+ this.indices && this.indices.forEach(i => {
115
133
  const index = data[i.name];
116
134
  if (!index)
117
135
  data[i.name] = {};
@@ -134,8 +152,7 @@ export class CubeMatrixComponent {
134
152
  data[r.key]['_total'] = sum;
135
153
  grand -= sum;
136
154
  });
137
- this.totals = {};
138
- this.columns.forEach(c => {
155
+ this._indices && this.columns.forEach(c => {
139
156
  let sum = 0, key;
140
157
  for (key in data) {
141
158
  const val = data[key][c.key];
@@ -147,92 +164,136 @@ export class CubeMatrixComponent {
147
164
  this.totals['_total'] = grand;
148
165
  }
149
166
  _calculatesum(data) {
150
- let { xAxis, serie } = this._dsum;
151
- if (xAxis) {
152
- let total = 0;
153
- this.rows.forEach(r => {
154
- const row = data[r.key];
155
- if (!row)
156
- return;
157
- let sum = 0, i = 0;
158
- while (i < this.columns.length) {
159
- let key = this.columns[i].key, val = row[key];
160
- if (val !== undefined)
161
- sum += val;
162
- if (key === xAxis.toString())
163
- break;
164
- i++;
165
- }
166
- data[r.key]['_sum'] = sum;
167
- total += sum;
168
- });
169
- this.totals['_sum'] = total;
170
- }
171
- if (serie) {
172
- let total = 0;
173
- this.columns.forEach(c => {
174
- let sum = 0, i = 0;
175
- while (i < this.rows.length) {
176
- let key = this.rows[i].key, row = data[key];
177
- if (row) {
178
- let val = row[c.key];
179
- if (val !== undefined)
180
- sum += val;
181
- if (key === serie.toString())
182
- break;
167
+ this._sum.forEach((s, i) => {
168
+ const { axis, value, calculate } = s, name = '_sum_' + i;
169
+ if (axis === 'xAxis') {
170
+ let total = 0;
171
+ this.rows.forEach(r => {
172
+ const row = data[r.key];
173
+ if (!row)
174
+ return;
175
+ let sum = 0, j = 0;
176
+ while (j < this.columns.length) {
177
+ let key = this.columns[j].key;
178
+ if (isFunction(calculate)) {
179
+ let val = calculate(key, this.data);
180
+ if (val !== undefined)
181
+ sum += val;
182
+ }
183
+ else {
184
+ let val = row[key];
185
+ if (val !== undefined)
186
+ sum += val;
187
+ if (key === value)
188
+ break;
189
+ }
190
+ j++;
183
191
  }
184
- i++;
185
- }
186
- data['_sum'][c.key] = sum;
187
- total += sum;
188
- });
189
- data['_sum']['_total'] = total;
190
- }
191
- }
192
- get _dsum() {
193
- if (this._evalsum)
194
- return this._evalsum;
195
- const { xAxis, serie } = this.sum;
196
- function translate(axis) {
197
- switch (axis) {
198
- case '$month':
199
- return 'M' + ('0' + new Date().getMonth().toString()).slice(-2);
200
- case '$year':
201
- return new Date().getFullYear().toString();
202
- case '$quarter':
203
- return Math.ceil(new Date().getMonth() / 3).toString();
204
- default:
205
- return axis;
192
+ row[name] = sum;
193
+ total += sum;
194
+ });
195
+ this.indices && this.indices.forEach(i => {
196
+ const row = data[i.name];
197
+ if (!row)
198
+ return;
199
+ let sum = 0, j = 0;
200
+ while (j < this.columns.length) {
201
+ let key = this.columns[j].key;
202
+ if (isFunction(calculate)) {
203
+ let val = calculate(key, this.data);
204
+ if (val !== undefined)
205
+ sum += val;
206
+ }
207
+ else {
208
+ let val = row[key];
209
+ if (val !== undefined)
210
+ sum += val;
211
+ if (key === value)
212
+ break;
213
+ }
214
+ j++;
215
+ }
216
+ row[name] = sum;
217
+ });
218
+ this.totals[name] = total;
206
219
  }
207
- }
208
- return this._evalsum = { xAxis: translate(xAxis), serie: translate(serie) };
220
+ else {
221
+ let total = 0;
222
+ this.columns.forEach(c => {
223
+ let sum = 0, j = 0;
224
+ while (j < this.rows.length) {
225
+ let key = this.rows[j].key;
226
+ if (isFunction(calculate)) {
227
+ let val = calculate(key, this.data);
228
+ if (val !== undefined)
229
+ sum += val;
230
+ }
231
+ else {
232
+ let row = data[key];
233
+ if (row) {
234
+ let val = row[c.key];
235
+ if (val !== undefined)
236
+ sum += val;
237
+ if (key === value)
238
+ break;
239
+ }
240
+ }
241
+ j++;
242
+ }
243
+ data[name][c.key] = sum;
244
+ total += sum;
245
+ });
246
+ data[name]['_total'] = total;
247
+ }
248
+ });
209
249
  }
210
- explore(x, serie) {
250
+ explore(x, series) {
211
251
  if (!this.interactive)
212
252
  return;
213
- if (this.sum) {
214
- if (x === '_sum') {
215
- x = [];
216
- for (let i = 0; i < this.columns.length; i++) {
217
- let key = this.columns[i].key;
218
- x.push(key);
219
- if (key === this.sum.xAxis.toString())
220
- break;
253
+ const axes = { ...this.filters };
254
+ if (this._sum) {
255
+ let i = 0;
256
+ while (i < this._sum.length) {
257
+ let { value, calculate } = this._sum[i], name = '_sum_' + i;
258
+ if (x === name) {
259
+ x = [];
260
+ for (let i = 0; i < this.columns.length; i++) {
261
+ let key = this.columns[i].key;
262
+ if (isFunction(calculate)) {
263
+ let val = calculate(key, this.data);
264
+ if (val !== undefined)
265
+ x.push(key);
266
+ }
267
+ else {
268
+ x.push(key);
269
+ if (key === value)
270
+ break;
271
+ }
272
+ }
273
+ break;
221
274
  }
222
- }
223
- if (serie === '_sum') {
224
- serie = [];
225
- for (let i = 0; i < this.rows.length; i++) {
226
- let key = this.rows[i].key;
227
- serie.push(key);
228
- if (key === this.sum.serie.toString())
229
- break;
275
+ else if (series === name) {
276
+ series = [];
277
+ for (let i = 0; i < this.rows.length; i++) {
278
+ let key = this.rows[i].key;
279
+ if (isFunction(calculate)) {
280
+ let val = calculate(key, this.data);
281
+ if (val !== undefined)
282
+ series.push(key);
283
+ }
284
+ else {
285
+ series.push(key);
286
+ if (key === value)
287
+ break;
288
+ }
289
+ }
290
+ break;
230
291
  }
292
+ i++;
231
293
  }
232
294
  }
233
- const axes = { ...this.axes };
234
295
  axes[this.xAxis.name] = x;
235
- axes[this.series.name] = serie;
296
+ axes[this.series.name] = series;
236
297
  this.onExplore.emit(axes);
237
298
  }
238
299
  move(x, y) {
@@ -266,10 +327,10 @@ export class CubeMatrixComponent {
266
327
  }
267
328
  }
268
329
  CubeMatrixComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: CubeMatrixComponent, deps: [{ token: i1.PromptService }, { token: i2.CubeService }, { token: i3.SessionService }, { token: i4.DatasourceService }], target: i0.ɵɵFactoryTarget.Component });
269
- CubeMatrixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: CubeMatrixComponent, selector: "bizdoc-cube-matrix", inputs: { _cube: ["cube", "_cube"], _xAxis: ["xAxis", "_xAxis"], _serie: ["serie", "_serie"], indices: "indices", scope: "scope", sum: "sum", axes: "axes", loading: "loading", interactive: "interactive" }, outputs: { onExplore: "explore", loadingChange: "loadingChange" }, viewQueries: [{ propertyName: "tableElement", first: true, predicate: ["table"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<table #table class=\"mat-table cube-table\" (mouseleave)=\"move(-1, -1)\" *ngIf=\"data\">\r\n <thead>\r\n <!-- headers -->\r\n <tr class=\"mat-row\">\r\n <th></th>\r\n <th *ngFor=\"let column of columns; let x = index\" (mouseenter)=\"move(x + 1, -2)\" class=\"mat-header-cell\">\r\n {{ column.value }}\r\n </th>\r\n <th></th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <!-- indices -->\r\n <tr class=\"mat-row cube-index\" *ngFor=\"let index of indexes; let y = index\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"move(0, y)\">{{index.title}}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y)\">\r\n <span *ngIf=\"data[index.name] && data[index.name][column.key]; else zero\">{{ data[index.name][column.key] | number : PRECISION }}</span>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"move(0, y)\" [ngSwitch]=\"!CURRENCY\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ data[index.name]['_total'] | number : PRECISION }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ data[index.name]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </ng-container>\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tbody>\r\n <!-- rows -->\r\n <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"move(-2, y + indices.length)\">{{ row.value }}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y + indices.length)\">\r\n <ng-container *ngIf=\"data[row.key] && data[row.key][column.key] !== undefined; else zero\">\r\n <span [class.clickable]=\"interactive\" (click)=\"explore(column.key, row.key)\">\r\n {{data[row.key][column.key] | number : PRECISION }}\r\n </span>\r\n </ng-container>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"move(-1, y + indices.length)\" [ngSwitch]=\"!CURRENCY\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ data[row.key]['_total'] | number : PRECISION }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ data[row.key]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </ng-container>\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tfoot>\r\n <!-- available -->\r\n <tr>\r\n <th></th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, -2)\"\r\n [class.negative-figure]=\"totals[column.key] < 0\">\r\n {{totals[column.key] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </td>\r\n <th class=\"mat-cell figure\">{{totals['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}</th>\r\n </tr>\r\n </tfoot>\r\n</table>\r\n<ng-template #zero>\r\n 0\r\n</ng-template>\r\n", styles: [".clickable{cursor:pointer}.cube-table{width:100%;display:inline-table;border-collapse:collapse}.cube-table th{cursor:default}.cube-table th.figure{font-weight:500}.cube-table td{padding-right:4px}\n"], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i5.NgSwitchDefault, selector: "[ngSwitchDefault]" }], pipes: { "number": i5.DecimalPipe, "currency": i5.CurrencyPipe }, animations: [matrixAnimation] });
330
+ CubeMatrixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: CubeMatrixComponent, selector: "bizdoc-cube-matrix", inputs: { _cube: ["cube", "_cube"], _xAxis: ["xAxis", "_xAxis"], _series: ["series", "_series"], _indices: ["indices", "_indices"], scope: "scope", sum: "sum", filters: "filters", loading: "loading", interactive: "interactive" }, outputs: { onExplore: "explore", loadingChange: "loadingChange" }, viewQueries: [{ propertyName: "tableElement", first: true, predicate: ["table"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<table #table class=\"mat-table cube-table\" (mouseleave)=\"move(-1, -1)\" *ngIf=\"data\">\r\n <thead>\r\n <!-- headers -->\r\n <tr class=\"mat-row\">\r\n <th></th>\r\n <th *ngFor=\"let column of columns; let x = index\" (mouseenter)=\"move(x + 1, -2)\" class=\"mat-header-cell\">\r\n {{ column.value }}\r\n </th>\r\n <th></th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <!-- indices -->\r\n <tr class=\"mat-row cube-index\" *ngFor=\"let index of indices; let y = index\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"move(0, y)\">{{index.title}}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y)\">\r\n <span *ngIf=\"data[index.name] && data[index.name][column.key]; else zero\">{{ data[index.name][column.key] | number : PRECISION }}</span>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"move(0, y)\" [ngSwitch]=\"!CURRENCY\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ data[index.name]['_total'] | number : PRECISION }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ data[index.name]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </ng-container>\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tbody>\r\n <!-- rows -->\r\n <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"move(-2, y + indices.length)\">{{ row.value }}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y + indices.length)\">\r\n <ng-container *ngIf=\"data[row.key] && data[row.key][column.key] !== undefined; else zero\">\r\n <span [class.clickable]=\"interactive\" (click)=\"explore(column.key, row.key)\">\r\n {{data[row.key][column.key] | number : PRECISION }}\r\n </span>\r\n </ng-container>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"move(-1, y + indices.length)\" [ngSwitch]=\"!CURRENCY\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ data[row.key]['_total'] | number : PRECISION }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ data[row.key]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </ng-container>\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tfoot>\r\n <!-- available -->\r\n <tr>\r\n <th></th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, -2)\"\r\n [class.negative-figure]=\"totals[column.key] < 0\">\r\n {{totals[column.key] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </td>\r\n <th class=\"mat-cell figure\">{{totals['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}</th>\r\n </tr>\r\n </tfoot>\r\n</table>\r\n<ng-template #zero>\r\n 0\r\n</ng-template>\r\n", styles: [".clickable{cursor:pointer}.cube-table{width:100%;display:inline-table;border-collapse:collapse}.cube-table th{cursor:default}.cube-table th.figure{font-weight:500}.cube-table td{padding-right:4px}\n"], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i5.NgSwitchDefault, selector: "[ngSwitchDefault]" }], pipes: { "number": i5.DecimalPipe, "currency": i5.CurrencyPipe }, animations: [matrixAnimation] });
270
331
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: CubeMatrixComponent, decorators: [{
271
332
  type: Component,
272
- args: [{ selector: 'bizdoc-cube-matrix', animations: [matrixAnimation], template: "<table #table class=\"mat-table cube-table\" (mouseleave)=\"move(-1, -1)\" *ngIf=\"data\">\r\n <thead>\r\n <!-- headers -->\r\n <tr class=\"mat-row\">\r\n <th></th>\r\n <th *ngFor=\"let column of columns; let x = index\" (mouseenter)=\"move(x + 1, -2)\" class=\"mat-header-cell\">\r\n {{ column.value }}\r\n </th>\r\n <th></th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <!-- indices -->\r\n <tr class=\"mat-row cube-index\" *ngFor=\"let index of indexes; let y = index\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"move(0, y)\">{{index.title}}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y)\">\r\n <span *ngIf=\"data[index.name] && data[index.name][column.key]; else zero\">{{ data[index.name][column.key] | number : PRECISION }}</span>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"move(0, y)\" [ngSwitch]=\"!CURRENCY\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ data[index.name]['_total'] | number : PRECISION }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ data[index.name]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </ng-container>\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tbody>\r\n <!-- rows -->\r\n <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"move(-2, y + indices.length)\">{{ row.value }}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y + indices.length)\">\r\n <ng-container *ngIf=\"data[row.key] && data[row.key][column.key] !== undefined; else zero\">\r\n <span [class.clickable]=\"interactive\" (click)=\"explore(column.key, row.key)\">\r\n {{data[row.key][column.key] | number : PRECISION }}\r\n </span>\r\n </ng-container>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"move(-1, y + indices.length)\" [ngSwitch]=\"!CURRENCY\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ data[row.key]['_total'] | number : PRECISION }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ data[row.key]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </ng-container>\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tfoot>\r\n <!-- available -->\r\n <tr>\r\n <th></th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, -2)\"\r\n [class.negative-figure]=\"totals[column.key] < 0\">\r\n {{totals[column.key] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </td>\r\n <th class=\"mat-cell figure\">{{totals['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}</th>\r\n </tr>\r\n </tfoot>\r\n</table>\r\n<ng-template #zero>\r\n 0\r\n</ng-template>\r\n", styles: [".clickable{cursor:pointer}.cube-table{width:100%;display:inline-table;border-collapse:collapse}.cube-table th{cursor:default}.cube-table th.figure{font-weight:500}.cube-table td{padding-right:4px}\n"] }]
333
+ args: [{ selector: 'bizdoc-cube-matrix', animations: [matrixAnimation], template: "<table #table class=\"mat-table cube-table\" (mouseleave)=\"move(-1, -1)\" *ngIf=\"data\">\r\n <thead>\r\n <!-- headers -->\r\n <tr class=\"mat-row\">\r\n <th></th>\r\n <th *ngFor=\"let column of columns; let x = index\" (mouseenter)=\"move(x + 1, -2)\" class=\"mat-header-cell\">\r\n {{ column.value }}\r\n </th>\r\n <th></th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <!-- indices -->\r\n <tr class=\"mat-row cube-index\" *ngFor=\"let index of indices; let y = index\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"move(0, y)\">{{index.title}}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y)\">\r\n <span *ngIf=\"data[index.name] && data[index.name][column.key]; else zero\">{{ data[index.name][column.key] | number : PRECISION }}</span>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"move(0, y)\" [ngSwitch]=\"!CURRENCY\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ data[index.name]['_total'] | number : PRECISION }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ data[index.name]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </ng-container>\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tbody>\r\n <!-- rows -->\r\n <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"move(-2, y + indices.length)\">{{ row.value }}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y + indices.length)\">\r\n <ng-container *ngIf=\"data[row.key] && data[row.key][column.key] !== undefined; else zero\">\r\n <span [class.clickable]=\"interactive\" (click)=\"explore(column.key, row.key)\">\r\n {{data[row.key][column.key] | number : PRECISION }}\r\n </span>\r\n </ng-container>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"move(-1, y + indices.length)\" [ngSwitch]=\"!CURRENCY\">\r\n <ng-container *ngSwitchCase=\"true\">\r\n {{ data[row.key]['_total'] | number : PRECISION }}\r\n </ng-container>\r\n <ng-container *ngSwitchDefault>\r\n {{ data[row.key]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </ng-container>\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tfoot>\r\n <!-- available -->\r\n <tr>\r\n <th></th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, -2)\"\r\n [class.negative-figure]=\"totals[column.key] < 0\">\r\n {{totals[column.key] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n </td>\r\n <th class=\"mat-cell figure\">{{totals['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}</th>\r\n </tr>\r\n </tfoot>\r\n</table>\r\n<ng-template #zero>\r\n 0\r\n</ng-template>\r\n", styles: [".clickable{cursor:pointer}.cube-table{width:100%;display:inline-table;border-collapse:collapse}.cube-table th{cursor:default}.cube-table th.figure{font-weight:500}.cube-table td{padding-right:4px}\n"] }]
273
334
  }], ctorParameters: function () { return [{ type: i1.PromptService }, { type: i2.CubeService }, { type: i3.SessionService }, { type: i4.DatasourceService }]; }, propDecorators: { tableElement: [{
274
335
  type: ViewChild,
275
336
  args: ['table']
@@ -279,16 +340,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImpor
279
340
  }], _xAxis: [{
280
341
  type: Input,
281
342
  args: ['xAxis']
282
- }], _serie: [{
343
+ }], _series: [{
283
344
  type: Input,
284
- args: ['serie']
285
- }], indices: [{
286
- type: Input
345
+ args: ['series']
346
+ }], _indices: [{
347
+ type: Input,
348
+ args: ['indices']
287
349
  }], scope: [{
288
350
  type: Input
289
351
  }], sum: [{
290
352
  type: Input
291
- }], axes: [{
353
+ }], filters: [{
292
354
  type: Input
293
355
  }], loading: [{
294
356
  type: Input
@@ -300,8 +362,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImpor
300
362
  }], loadingChange: [{
301
363
  type: Output
302
364
  }] } });
303
- export class CubeInfoCellArgs {
304
- get value() { return this._value; }
305
- get summary() { return this._summary; }
306
- }
307
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/cube/matrix/table.component.ts","../../../../../../libraries/core/src/lib/cube/matrix/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,KAAK,EAAa,MAAM,EAAiB,SAAS,EAAE,MAAM,eAAe,CAAC;AAExH,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACjF,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AACvC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAe,QAAQ,EAAa,MAAM,iBAAiB,CAAC;;;;;;;AAMnE,MAAM,aAAa,GAAG,GAAG,CAAC;AAE1B,MAAM,eAAe,GAAG,OAAO,CAAC,OAAO,EACrC,CAAC,UAAU,CAAC,SAAS,EACnB;QACE,KAAK,CAAC,UAAU,EACd;YACE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC;YACpD,OAAO,CAAC,GAAG,EACT,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;SAC5C,EACD,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;KACtB,CAAC,CAAC,CAAC,CAAC;AACT,2BAA2B;AAO3B,MAAM,OAAO,mBAAmB;IAuC9B,YACU,GAAkB,EAClB,QAAqB,EACrB,QAAwB,EACxB,GAAsB;QAHtB,QAAG,GAAH,GAAG,CAAe;QAClB,aAAQ,GAAR,QAAQ,CAAa;QACrB,aAAQ,GAAR,QAAQ,CAAgB;QACxB,QAAG,GAAH,GAAG,CAAmB;QA1CvB,cAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC;QAkBtC,iBAAY,GAAY,IAAI,CAAC;QAST,cAAS,GAAG,IAAI,YAAY,EAAW,CAAC;QACjD,kBAAa,GAAG,IAAI,YAAY,EAAW,CAAC;IAc3B,CAAC;IAlCrC,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IACD,IACW,OAAO,CAAC,KAAwB;QACzC,IAAI,KAAK;YAAE,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAC9D,CAAC;IAMD,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IACD,IACW,WAAW,CAAC,KAAc;QACnC,IAAI,CAAC,YAAY,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IAkBD,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE;YACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;gBACpF,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,iCAAiC,CAAC;SAC1E;QACD,IAAI,IAAI,CAAC,QAAQ;YACf,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;aAC9E;YACH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;YACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;SAC/C;QACD,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,EAAE;YAC1C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACnF,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACpF,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CACvE,IAAI,CAAC,IAAI,GAAG,CAAC,CACd,CAAC,EACA,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAC7C,IAAI,CAAC,OAAO,GAAG,CAAC,CACjB,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC,IAAI,CAClB,GAAG,EAAE,CACH,IAAI,CAAC,GAAG;gBACR,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;SACvB;QACD,IAAI,OAAO,CAAC,MAAM,CAAC;YACjB,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IACO,OAAO;QACb,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QAClC,IAAI,KAAK,EAAE;YACT,MAAM,OAAO,GAAG,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACvB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAChB,IAAI,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,GAAG;oBAC5B,OAAO,CAAC,IAAI,CAAC;wBACX,GAAG,EAAE,MAAM;wBACX,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK;qBACtB,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;SACxB;QACD,IAAI,KAAK,EAAE;YACT,MAAM,IAAI,GAAG,EAAE,CAAC;YAChB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACpB,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACb,IAAI,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,GAAG;oBAC5B,IAAI,CAAC,IAAI,CAAC;wBACR,GAAG,EAAE,MAAM;wBACX,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK;qBACtB,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;SAClB;IACH,CAAC;IAED,OAAO;QACL,MAAM,YAAY,GAAG,UAAU,CAAC,GAAG,EAAE,CACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,EAC1C,aAAa,CAAC,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE;YAC7E,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI;YACxB,OAAO,EAAE,IAAI,CAAC,QAAQ;YACtB,OAAO,EAAE,IAAI,CAAC,IAAI;YAClB,KAAK,EAAE,IAAI,CAAC,KAAK;SACX,CAAC,CAAC,IAAI,CACZ,QAAQ,EAAE,EAAE,KAAK,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE;YAC3B,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAChB,IAAI,CAAC,GAAG;gBACN,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAChB,IAAI,CAAC,IAAI,GAAG,CAAC,EACb,CAAC,CAAoB,EAAE,EAAE;YACvB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,KAAK,GAAG,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAC3D,CAAC,EAAE,GAAG,EAAE;YACN,YAAY,CAAC,YAAY,CAAC,CAAC;YAC3B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC;QAChD,CAAC,CAAC,CACL,CAAC;IACJ,CAAC;IACO,OAAO,CAAC,IAAoD;QAClE,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACvB,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAI,CAAC,KAAK;gBAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;iBAE9B;gBACE,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;gBACf,KAAK,CAAC,IAAI,KAAK;oBACb,GAAG,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC;gBAClB,KAAK,CAAC,QAAQ,CAAC,GAAG,GAAG,CAAC;gBACtB,KAAK,IAAI,GAAG,CAAC;aACd;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACpB,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC;gBACd,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;YACnB,MAAM,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACzB,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;YACf,IAAI,IAAI;gBACN,KAAK,CAAC,IAAI,IAAI;oBACZ,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;YACnB,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,GAAG,GAAG,CAAC;YAC5B,KAAK,IAAI,GAAG,CAAC;QACf,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACvB,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,CAAC;YACjB,KAAK,GAAG,IAAI,IAAI,EAAE;gBAChB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;gBAC7B,IAAI,GAAG,KAAK,SAAS;oBACnB,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;aACvD;YACD,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;QAC3B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,KAAK,CAAC;IAChC,CAAC;IAEO,aAAa,CAAC,IAAI;QACxB,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QAClC,IAAI,KAAK,EAAE;YACT,IAAI,KAAK,GAAG,CAAC,CAAC;YACd,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACpB,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;gBACxB,IAAI,CAAC,GAAG;oBACN,OAAO;gBACT,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;gBACnB,OAAO,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;oBAC9B,IAAI,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;oBAC9C,IAAI,GAAG,KAAK,SAAS;wBACnB,GAAG,IAAI,GAAG,CAAC;oBACb,IAAI,GAAG,KAAK,KAAK,CAAC,QAAQ,EAAE;wBAC1B,MAAM;oBACR,CAAC,EAAE,CAAC;iBACL;gBACD,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,GAAG,GAAG,CAAC;gBAC1B,KAAK,IAAI,GAAG,CAAC;YACf,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC;SAC7B;QACD,IAAI,KAAK,EAAE;YACT,IAAI,KAAK,GAAG,CAAC,CAAC;YACd,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACvB,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;gBACnB,OAAO,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;oBAC3B,IAAI,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;oBAC5C,IAAI,GAAG,EAAE;wBACP,IAAI,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;wBACrB,IAAI,GAAG,KAAK,SAAS;4BACnB,GAAG,IAAI,GAAG,CAAC;wBACb,IAAI,GAAG,KAAK,KAAK,CAAC,QAAQ,EAAE;4BAC1B,MAAM;qBACT;oBACD,CAAC,EAAE,CAAC;iBACL;gBACD,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;gBAC1B,KAAK,IAAI,GAAG,CAAC;YACf,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,GAAG,KAAK,CAAC;SAChC;IACH,CAAC;IACD,IAAY,KAAK;QACf,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO,IAAI,CAAC,QAAQ,CAAC;QACxC,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC;QAClC,SAAS,SAAS,CAAC,IAAqB;YACtC,QAAQ,IAAI,EAAE;gBACZ,KAAK,QAAQ;oBACX,OAAO,GAAG,GAAG,CAAC,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;gBAClE,KAAK,OAAO;oBACV,OAAO,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,QAAQ,EAAE,CAAC;gBAC7C,KAAK,UAAU;oBACb,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACzD;oBACE,OAAO,IAAI,CAAC;aACf;QACH,CAAC;QACD,OAAO,IAAI,CAAC,QAAQ,GAAG,EAAE,KAAK,EAAE,SAAS,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;IAC9E,CAAC;IAED,OAAO,CAAC,CAAwC,EAAE,KAA4C;QAC5F,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,OAAO;QAC9B,IAAI,IAAI,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,KAAK,MAAM,EAAE;gBAChB,CAAC,GAAG,EAAc,CAAC;gBACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAC5C,IAAI,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;oBAC9B,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBACZ,IAAI,GAAG,KAAK,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE;wBACnC,MAAM;iBACT;aACF;YACD,IAAI,KAAK,KAAK,MAAM,EAAE;gBACpB,KAAK,GAAG,EAAc,CAAC;gBACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACzC,IAAI,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;oBAC3B,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBAChB,IAAI,GAAG,KAAK,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE;wBACnC,MAAM;iBACT;aACF;SACF;QACD,MAAM,IAAI,GAAG,EAAE,GAAG,IAAI,CAAC,IAAI,EAAa,CAAC;QACzC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IACD,IAAI,CAAC,CAAC,EAAE,CAAC;QACP,IAAI,QAAQ,GAAG,CAAC,CAAC;QACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACvE,IAAI,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAC5D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC1C,IAAI,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACzC,IAAI,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBAC7B,IAAI,CAAC,KAAK,CAAC;wBACT,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;;wBAE7B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;oBAClC,IAAI,QAAQ,KAAK,CAAC;wBAChB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;;wBAE7B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;iBACnC;gBACD,QAAQ,EAAE,CAAC;aACZ;YACD,IAAI,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACvE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACzC,IAAI,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC7B,IAAI,CAAC,KAAK,CAAC;oBACT,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;;oBAE7B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;aACnC;SACF;IACH,CAAC;;gHAvRU,mBAAmB;oGAAnB,mBAAmB,ucCjChC,47FAgEA,gsBDjCc,CAAC,eAAe,CAAC;2FAElB,mBAAmB;kBAN/B,SAAS;+BACE,oBAAoB,cAGlB,CAAC,eAAe,CAAC;2LAKT,YAAY;sBAA/B,SAAS;uBAAC,OAAO;gBACH,KAAK;sBAAnB,KAAK;uBAAC,MAAM;gBACG,MAAM;sBAArB,KAAK;uBAAC,OAAO;gBACE,MAAM;sBAArB,KAAK;uBAAC,OAAO;gBAOH,OAAO;sBADjB,KAAK;gBAIG,KAAK;sBAAb,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAKK,WAAW;sBADrB,KAAK;gBAIsB,SAAS;sBAApC,MAAM;uBAAC,SAAS;gBACE,aAAa;sBAA/B,MAAM;;AA6PT,MAAM,OAAO,gBAAgB;IAE3B,IAAI,KAAK,KAAa,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAE3C,IAAI,OAAO,KAAc,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;CAMjD","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { query, stagger, style, transition, trigger } from '@angular/animations';\r\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { forkJoin, first } from 'rxjs';\r\nimport { tap } from 'rxjs/operators';\r\nimport { isArray } from '../../core/functions';\r\nimport { CubeService, modelize, ScopeType } from '../cube.service';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { DatasourceService } from '../../core/datasource.service';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { AxesMap, Cube, CubeAxis, CubeIndex } from '../../core/models';\r\n\r\nconst LOADING_DELAY = 200;\r\n\r\nconst matrixAnimation = trigger('table',\r\n  [transition('void=>*',\r\n    [\r\n      query('.mat-row',\r\n        [\r\n          style({ opacity: 0, transform: 'translateX(10px)' }),\r\n          stagger(100,\r\n            style({ opacity: 1, transform: 'none' }))\r\n        ],\r\n        { optional: true })\r\n    ])]);\r\n/** cube matrix component*/\r\n@Component({\r\n  selector: 'bizdoc-cube-matrix',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.scss'],\r\n  animations: [matrixAnimation]\r\n})\r\nexport class CubeMatrixComponent implements OnChanges {\r\n  readonly PRECISION = this._service.digitsInfo;\r\n  CURRENCY: string;\r\n  @ViewChild('table') tableElement: ElementRef<HTMLTableElement>;\r\n  @Input('cube') _cube?: string;\r\n  @Input('xAxis') _xAxis!: string;\r\n  @Input('serie') _serie!: string;\r\n  private _indices?: string[];\r\n  private _evalsum: { xAxis: string | number; serie: string | number; };\r\n  public get indices(): string[] | string {\r\n    return this._indices;\r\n  }\r\n  @Input()\r\n  public set indices(value: string[] | string) {\r\n    if (value) this._indices = isArray(value) ? value : [value];\r\n  }\r\n  @Input() scope: ScopeType;\r\n  @Input() sum: SumOptions;\r\n  @Input() axes: AxesMap;\r\n  private _interactive: boolean = true;\r\n  @Input() loading: boolean;\r\n  public get interactive(): boolean {\r\n    return this._interactive;\r\n  }\r\n  @Input()\r\n  public set interactive(value: boolean) {\r\n    this._interactive = coerceBooleanProperty(value);\r\n  }\r\n  @Output('explore') readonly onExplore = new EventEmitter<AxesMap>();\r\n  @Output() readonly loadingChange = new EventEmitter<boolean>();\r\n  rows: KeyValue[];\r\n  columns: KeyValue[];\r\n  indexes: CubeIndex[];\r\n  data: { [row: string]: { [column: string]: number; }; };\r\n  totals: { [column: string]: number };\r\n  cube: Cube;\r\n  xAxis: CubeAxis;\r\n  series: CubeAxis;\r\n  private _prepare: Promise<any>;\r\n  constructor(\r\n    private _sb: PromptService,\r\n    private _service: CubeService,\r\n    private _session: SessionService,\r\n    private _ds: DatasourceService) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['_cube']) {\r\n      this.cube = this.cube ? this._session.profile.cubes.find(c => c.name === this._cube) :\r\n        this._session.profile.cubes[0];\r\n      this.CURRENCY = this.cube.currencyCode /*|| this._service.currencyCode*/;\r\n    }\r\n    if (this._indices)\r\n      this.indexes = this.cube.indices.filter(i => this._indices.indexOf(i.name) > -1);\r\n    else {\r\n      this.indexes = this.cube.indices;\r\n      this._indices = this.indexes.map(i => i.name);\r\n    }\r\n    if (changes['_xAxis'] || changes['_serie']) {\r\n      this.xAxis = this.cube.axes.find(a => a.name === this._xAxis) || this.cube.axes[0];\r\n      this.series = this.cube.axes.find(a => a.name === this._serie) || this.cube.axes[1];\r\n      this._prepare = forkJoin(this._ds.all(this.series.dataType).pipe(tap(r =>\r\n        this.rows = r\r\n      )),\r\n        this._ds.all(this.xAxis.dataType).pipe(tap(c =>\r\n          this.columns = c\r\n        ))).toPromise().then(\r\n          () =>\r\n            this.sum &&\r\n            this._addsum());\r\n    }\r\n    if (changes['axes'])\r\n      this.refresh();\r\n  }\r\n  private _addsum() {\r\n    let { xAxis, serie } = this._dsum;\r\n    if (xAxis) {\r\n      const columns = [];\r\n      this.columns.forEach(c => {\r\n        columns.push(c);\r\n        if (xAxis.toString() === c.key)\r\n          columns.push({\r\n            key: '_sum',\r\n            value: this.sum.title\r\n          });\r\n      });\r\n      this.columns = columns;\r\n    }\r\n    if (serie) {\r\n      const rows = [];\r\n      this.rows.forEach(r => {\r\n        rows.push(r);\r\n        if (serie.toString() === r.key)\r\n          rows.push({\r\n            key: '_sum',\r\n            value: this.sum.title\r\n          });\r\n      });\r\n      this.rows = rows;\r\n    }\r\n  }\r\n\r\n  refresh() {\r\n    const progressTask = setTimeout(() =>\r\n      this.loadingChange.next(this.loading = true)\r\n      , LOADING_DELAY);\r\n    this._prepare.then(() => this._service.series(this.cube.name, this.xAxis.name, {\r\n      series: this.series.name,\r\n      indices: this._indices,\r\n      filters: this.axes,\r\n      scope: this.scope\r\n    } as any).pipe(\r\n      modelize(), first(), tap(d => {\r\n        this._totals(d);\r\n        this.sum &&\r\n          this._calculatesum(d);\r\n      })).subscribe(d =>\r\n        this.data = d,\r\n        (e: HttpErrorResponse) => {\r\n          this._sb.error(e.status === 401 ? 'Unauthorized' : null);\r\n        }, () => {\r\n          clearTimeout(progressTask);\r\n          this.loadingChange.next(this.loading = false);\r\n        })\r\n    );\r\n  }\r\n  private _totals(data: { [key: string]: { [key: string]: number; }; }) {\r\n    let grand = 0;\r\n    this.indexes.forEach(i => {\r\n      const index = data[i.name];\r\n      if (!index) data[i.name] = {};\r\n      else\r\n      {\r\n        let sum = 0, x;\r\n        for (x in index)\r\n          sum += index[x];\r\n        index['_total'] = sum;\r\n        grand += sum;\r\n      }\r\n    });\r\n    this.rows.forEach(r => {\r\n      if (!data[r.key])\r\n        data[r.key] = {};\r\n      const line = data[r.key];\r\n      let sum = 0, x;\r\n      if (line)\r\n        for (x in line)\r\n          sum += line[x];\r\n      data[r.key]['_total'] = sum;\r\n      grand -= sum;\r\n    });\r\n    this.totals = {};\r\n    this.columns.forEach(c => {\r\n      let sum = 0, key;\r\n      for (key in data) {\r\n        const val = data[key][c.key];\r\n        if (val !== undefined)\r\n          sum += this._indices.indexOf(key) > -1 ? val : -val;\r\n      }\r\n      this.totals[c.key] = sum;\r\n    });\r\n    this.totals['_total'] = grand;\r\n  }\r\n\r\n  private _calculatesum(data) {\r\n    let { xAxis, serie } = this._dsum;\r\n    if (xAxis) {\r\n      let total = 0;\r\n      this.rows.forEach(r => {\r\n        const row = data[r.key];\r\n        if (!row)\r\n          return;\r\n        let sum = 0, i = 0;\r\n        while (i < this.columns.length) {\r\n          let key = this.columns[i].key, val = row[key];\r\n          if (val !== undefined)\r\n            sum += val;\r\n          if (key === xAxis.toString())\r\n            break;\r\n          i++;\r\n        }\r\n        data[r.key]['_sum'] = sum;\r\n        total += sum;\r\n      });\r\n      this.totals['_sum'] = total;\r\n    }\r\n    if (serie) {\r\n      let total = 0;\r\n      this.columns.forEach(c => {\r\n        let sum = 0, i = 0;\r\n        while (i < this.rows.length) {\r\n          let key = this.rows[i].key, row = data[key];\r\n          if (row) {\r\n            let val = row[c.key];\r\n            if (val !== undefined)\r\n              sum += val;\r\n            if (key === serie.toString())\r\n              break;\r\n          }\r\n          i++;\r\n        }\r\n        data['_sum'][c.key] = sum;\r\n        total += sum;\r\n      });\r\n      data['_sum']['_total'] = total;\r\n    }\r\n  }\r\n  private get _dsum(): { xAxis: any; serie: any; } {\r\n    if (this._evalsum) return this._evalsum;\r\n    const { xAxis, serie } = this.sum;\r\n    function translate(axis: string | number) {\r\n      switch (axis) {\r\n        case '$month':\r\n          return 'M' + ('0' + new Date().getMonth().toString()).slice(-2);\r\n        case '$year':\r\n          return new Date().getFullYear().toString();\r\n        case '$quarter':\r\n          return Math.ceil(new Date().getMonth() / 3).toString();\r\n        default:\r\n          return axis;\r\n      }\r\n    }\r\n    return this._evalsum = { xAxis: translate(xAxis), serie: translate(serie) };\r\n  }\r\n\r\n  explore(x: string | number | string[] | number[], serie: string | number | string[] | number[]) {\r\n    if (!this.interactive) return;\r\n    if (this.sum) {\r\n      if (x === '_sum') {\r\n        x = [] as string[];\r\n        for (let i = 0; i < this.columns.length; i++) {\r\n          let key = this.columns[i].key;\r\n          x.push(key);\r\n          if (key === this.sum.xAxis.toString())\r\n            break;\r\n        }\r\n      }\r\n      if (serie === '_sum') {\r\n        serie = [] as string[];\r\n        for (let i = 0; i < this.rows.length; i++) {\r\n          let key = this.rows[i].key;\r\n          serie.push(key);\r\n          if (key === this.sum.serie.toString())\r\n            break;\r\n        }\r\n      }\r\n    }\r\n    const axes = { ...this.axes } as AxesMap;\r\n    axes[this.xAxis.name] = x;\r\n    axes[this.series.name] = serie;\r\n    this.onExplore.emit(axes);\r\n  }\r\n  move(x, y) {\r\n    let rowIndex = 0;\r\n    for (let b = 0; b < this.tableElement.nativeElement.tBodies.length; b++) {\r\n      let tBody = this.tableElement.nativeElement.tBodies.item(b);\r\n      for (let r = 0; r < tBody.rows.length; r++) {\r\n        let row = tBody.rows.item(r);\r\n        for (let c = 0; c < row.cells.length; c++) {\r\n          let cell = row.cells.item(c);\r\n          if (c === x)\r\n            cell.classList.add('cell-x');\r\n          else\r\n            cell.classList.remove('cell-x');\r\n          if (rowIndex === y)\r\n            cell.classList.add('cell-y');\r\n          else\r\n            cell.classList.remove('cell-y');\r\n        }\r\n        rowIndex++;\r\n      }\r\n      let tFoot = this.tableElement.nativeElement.tFoot, row = tFoot.rows[0];\r\n      for (let c = 0; c < row.cells.length; c++) {\r\n        let cell = row.cells.item(c);\r\n        if (c === x)\r\n          cell.classList.add('cell-x');\r\n        else\r\n          cell.classList.remove('cell-x');\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\nexport class CubeInfoCellArgs {\r\n  private _value: number;\r\n  get value(): number { return this._value; }\r\n  private _summary: boolean;\r\n  get summary(): boolean { return this._summary; }\r\n  color: string;\r\n  backgroundColor: string;\r\n  data: { [row: string]: { [column: string]: number; }; };\r\n  row: string;\r\n  column: string;\r\n}\r\n\r\ntype SumOptions = {\r\n  xAxis?: string | number;\r\n  serie?: string | number;\r\n  title: any;\r\n}\r\ntype KeyValue = {\r\n  key: string;\r\n  value: any;\r\n};\r\n\r\n","<table #table class=\"mat-table cube-table\" (mouseleave)=\"move(-1, -1)\" *ngIf=\"data\">\r\n  <thead>\r\n    <!-- headers -->\r\n    <tr class=\"mat-row\">\r\n      <th></th>\r\n      <th *ngFor=\"let column of columns; let x = index\" (mouseenter)=\"move(x + 1, -2)\" class=\"mat-header-cell\">\r\n        {{ column.value }}\r\n      </th>\r\n      <th></th>\r\n    </tr>\r\n  </thead>\r\n  <tbody>\r\n    <!-- indices -->\r\n    <tr class=\"mat-row cube-index\" *ngFor=\"let index of indexes; let y = index\">\r\n      <th class=\"mat-header-cell\" (mouseenter)=\"move(0, y)\">{{index.title}}</th>\r\n      <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y)\">\r\n        <span *ngIf=\"data[index.name] && data[index.name][column.key]; else zero\">{{ data[index.name][column.key] | number : PRECISION }}</span>\r\n      </td>\r\n      <th class=\"mat-cell figure\" (mouseenter)=\"move(0, y)\" [ngSwitch]=\"!CURRENCY\">\r\n        <ng-container *ngSwitchCase=\"true\">\r\n          {{ data[index.name]['_total'] | number : PRECISION }}\r\n        </ng-container>\r\n        <ng-container *ngSwitchDefault>\r\n          {{ data[index.name]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n        </ng-container>\r\n      </th>\r\n    </tr>\r\n  </tbody>\r\n  <tbody>\r\n    <!-- rows -->\r\n    <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\">\r\n      <th class=\"mat-header-cell\" (mouseenter)=\"move(-2, y + indices.length)\">{{ row.value }}</th>\r\n      <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y + indices.length)\">\r\n        <ng-container *ngIf=\"data[row.key] && data[row.key][column.key] !== undefined; else zero\">\r\n          <span [class.clickable]=\"interactive\" (click)=\"explore(column.key, row.key)\">\r\n            {{data[row.key][column.key] | number : PRECISION }}\r\n          </span>\r\n        </ng-container>\r\n      </td>\r\n      <th class=\"mat-cell figure\" (mouseenter)=\"move(-1, y + indices.length)\" [ngSwitch]=\"!CURRENCY\">\r\n        <ng-container *ngSwitchCase=\"true\">\r\n          {{ data[row.key]['_total'] | number : PRECISION }}\r\n        </ng-container>\r\n        <ng-container *ngSwitchDefault>\r\n          {{ data[row.key]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n        </ng-container>\r\n      </th>\r\n    </tr>\r\n  </tbody>\r\n  <tfoot>\r\n    <!-- available -->\r\n    <tr>\r\n      <th></th>\r\n      <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, -2)\"\r\n          [class.negative-figure]=\"totals[column.key] < 0\">\r\n        {{totals[column.key] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n      </td>\r\n      <th class=\"mat-cell figure\">{{totals['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}</th>\r\n    </tr>\r\n  </tfoot>\r\n</table>\r\n<ng-template #zero>\r\n  0\r\n</ng-template>\r\n"]}
365
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/cube/matrix/table.component.ts","../../../../../../libraries/core/src/lib/cube/matrix/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\r\nimport { forkJoin, first } from 'rxjs';\r\nimport { tap } from 'rxjs/operators';\r\nimport { isArray, isFunction } from '../../core/functions';\r\nimport { CubeService, modelize, ScopeType } from '../cube.service';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { DatasourceService } from '../../core/datasource.service';\r\nimport { PromptService } from '../../core/prompt.service';\r\nimport { AxesMap, Cube, CubeAxis, CubeIndex } from '../../core/models';\r\nimport { matrixAnimation } from '../../core/animations';\r\n\r\nconst LOADING_DELAY = 200;\r\n\r\n/** cube matrix component*/\r\n@Component({\r\n  selector: 'bizdoc-cube-matrix',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.scss'],\r\n  animations: [matrixAnimation]\r\n})\r\nexport class CubeMatrixComponent implements OnChanges {\r\n  readonly PRECISION = this._service.digitsInfo;\r\n  CURRENCY: string;\r\n  @ViewChild('table') tableElement: ElementRef<HTMLTableElement>;\r\n  @Input('cube') _cube?: string;\r\n  @Input('xAxis') _xAxis!: string;\r\n  @Input('series') _series!: string;\r\n  @Input('indices')\r\n  private _indices?: string[] | string;\r\n  @Input() scope: ScopeType;\r\n  private _sum: SumSettings[];\r\n  @Input() set sum(val: SumSettings | SumSettings[]) {\r\n    if(val) this._sum = (isArray(val) ? val : [val]).\r\n      map(sum => {\r\n        let value;\r\n        if (sum.value)\r\n          value = sum.value.toString();\r\n        else if (sum.calculate)\r\n          switch (sum.calculate) {\r\n            case 'month':\r\n              value = 'M' + ('0' + new Date().getMonth().toString()).slice(-2);\r\n              break;\r\n            case 'year':\r\n              value = new Date().getFullYear().toString();\r\n              break;\r\n            case 'quarter':\r\n              value = Math.ceil(new Date().getMonth() / 3).toString();\r\n              break;\r\n          }\r\n        return {\r\n          value,\r\n          ...sum\r\n        };\r\n      });\r\n  }\r\n  @Input() filters: AxesMap;\r\n  private _interactive: boolean = true;\r\n  @Input() loading: boolean;\r\n  public get interactive(): boolean {\r\n    return this._interactive;\r\n  }\r\n  @Input()\r\n  public set interactive(value: boolean) {\r\n    this._interactive = coerceBooleanProperty(value);\r\n  }\r\n  @Output('explore') readonly onExplore = new EventEmitter<AxesMap>();\r\n  @Output() readonly loadingChange = new EventEmitter<boolean>();\r\n  rows: KeyValue[];\r\n  columns: KeyValue[];\r\n  indices: CubeIndex[];\r\n  data: { [series: string]: { [xAxis: string]: number; }; };\r\n  totals: { [xAxis: string]: number };\r\n  cube: Cube;\r\n  xAxis: CubeAxis;\r\n  series: CubeAxis;\r\n  private _prepare: Promise<any>;\r\n  constructor(\r\n    private _sb: PromptService,\r\n    private _service: CubeService,\r\n    private _session: SessionService,\r\n    private _ds: DatasourceService) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['_cube']) {\r\n      this.cube = this._session.profile.cubes.find(c => c.name === this._cube);\r\n      this.CURRENCY = this.cube.currencyCode /*|| this._service.currencyCode*/;\r\n    }\r\n    if (!this.cube) {\r\n      this.cube = this._session.profile.cubes[0];\r\n      this.CURRENCY = this.cube.currencyCode /*|| this._service.currencyCode*/;\r\n    }\r\n    if (changes['_indices'])\r\n      this.indices = this.cube.indices.filter(i => isArray(this._indices) ? this._indices.indexOf(i.name) > -1 : this._indices === i.name);\r\n    if (changes['_xAxis'] || changes['_series']) {\r\n      this.xAxis = this.cube.axes.find(a => a.name === this._xAxis);\r\n      this.series = this.cube.axes.find(a => a.name === this._series);\r\n      this._prepare = forkJoin(this._ds.all(this.series.dataType).pipe(tap(r =>\r\n        this.rows = r\r\n      )),\r\n        this._ds.all(this.xAxis.dataType).pipe(tap(c =>\r\n          this.columns = c\r\n        ))).toPromise().then(\r\n          () =>\r\n            this._sum &&\r\n            this._addsum());\r\n    }\r\n    if (changes['filters'])\r\n      this.refresh();\r\n  }\r\n  private _addsum() {\r\n    this._sum.forEach((s, i) => {\r\n      let { value, axis } = s;\r\n      const element = {\r\n        key: '_sum_' + i,\r\n        value: s.title\r\n      } as KeyValue;\r\n      let j = 0;\r\n      if (axis === 'xAxis') {\r\n        while (j < this.columns.length) {\r\n          if (this.columns[j].key === value) {\r\n            this.columns.splice(j + 1, 0, element);\r\n            break;\r\n          }\r\n          j++;\r\n        }\r\n        if (j === this.columns.length)\r\n          this.columns.push(element);\r\n      }\r\n      else {\r\n        while (j < this.rows.length) {\r\n          if (this.rows[j].key === value) {\r\n            this.rows.splice(j + 1, 0, element);\r\n            break;\r\n          }\r\n          j++;\r\n        }\r\n        if (j === this.rows.length)\r\n          this.rows.push(element);\r\n      }\r\n    });\r\n  }\r\n\r\n  refresh() {\r\n    const progressTask = setTimeout(() =>\r\n      this.loadingChange.next(this.loading = true)\r\n      , LOADING_DELAY);\r\n    this._prepare.then(() => this._service.series(this.cube.name, this._xAxis, {\r\n      series: this._series,\r\n      indices: this._indices,\r\n      filters: this.filters,\r\n      scope: this.scope\r\n    } as any).pipe(\r\n      modelize(), first()).subscribe(d => {\r\n        this._sum &&\r\n          this._calculatesum(d);\r\n        this._totals(d);\r\n        this.data = d;\r\n      },\r\n        (e: HttpErrorResponse) => {\r\n          this._sb.error(e.status === 401 ? 'Unauthorized' : null);\r\n        }, () => {\r\n          clearTimeout(progressTask);\r\n          this.loadingChange.next(this.loading = false);\r\n        })\r\n    );\r\n  }\r\n  private _totals(data: { [key: string]: { [key: string]: number; }; }) {\r\n    this.totals = {};\r\n    let grand = 0;\r\n    this.indices && this.indices.forEach(i => {\r\n      const index = data[i.name];\r\n      if (!index) data[i.name] = {};\r\n      else {\r\n        let sum = 0, x;\r\n        for (x in index)\r\n          sum += index[x];\r\n        index['_total'] = sum;\r\n        grand += sum;\r\n      }\r\n    });\r\n    this.rows.forEach(r => {\r\n      if (!data[r.key])\r\n        data[r.key] = {};\r\n      const line = data[r.key];\r\n      let sum = 0, x;\r\n      if (line)\r\n        for (x in line)\r\n          sum += line[x];\r\n      data[r.key]['_total'] = sum;\r\n      grand -= sum;\r\n    });\r\n    this._indices && this.columns.forEach(c => {\r\n      let sum = 0, key;\r\n      for (key in data) {\r\n        const val = data[key][c.key];\r\n        if (val !== undefined)\r\n          sum += this._indices.indexOf(key) > -1 ? val : -val;\r\n      }\r\n      this.totals[c.key] = sum;\r\n    });\r\n    this.totals['_total'] = grand;\r\n  }\r\n  private _calculatesum(data) {\r\n    this._sum.forEach((s, i) => {\r\n      const { axis, value, calculate } = s, name = '_sum_' + i;\r\n      if (axis === 'xAxis') {\r\n        let total = 0;\r\n        this.rows.forEach(r => {\r\n          const row = data[r.key];\r\n          if (!row)\r\n            return;\r\n          let sum = 0, j = 0;\r\n          while (j < this.columns.length) {\r\n            let key = this.columns[j].key;\r\n            if (isFunction(calculate)) {\r\n              let val = (calculate as CalculateFn)(key, this.data);\r\n              if (val !== undefined)\r\n                sum += val;\r\n            }\r\n            else {\r\n              let val = row[key];\r\n              if (val !== undefined)\r\n                sum += val;\r\n              if (key === value)\r\n                break;\r\n            }\r\n            j++;\r\n          }\r\n          row[name] = sum;\r\n          total += sum;\r\n        });\r\n        this.indices && this.indices.forEach(i => {\r\n          const row = data[i.name];\r\n          if (!row)\r\n            return;\r\n          let sum = 0, j = 0;\r\n          while (j < this.columns.length) {\r\n            let key = this.columns[j].key;\r\n            if (isFunction(calculate)) {\r\n              let val = (calculate as CalculateFn)(key, this.data);\r\n              if (val !== undefined)\r\n                sum += val;\r\n            }\r\n            else {\r\n              let val = row[key];\r\n              if (val !== undefined)\r\n                sum += val;\r\n              if (key === value)\r\n                break;\r\n            }\r\n            j++;\r\n          }\r\n          row[name] = sum;\r\n        });\r\n        this.totals[name] = total;\r\n      }\r\n      else {\r\n        let total = 0;\r\n        this.columns.forEach(c => {\r\n          let sum = 0, j = 0;\r\n          while (j < this.rows.length) {\r\n            let key = this.rows[j].key;\r\n            if (isFunction(calculate)) {\r\n              let val = (calculate as CalculateFn)(key, this.data);\r\n              if (val !== undefined)\r\n                sum += val;\r\n            }\r\n            else {\r\n              let row = data[key];\r\n              if (row) {\r\n                let val = row[c.key];\r\n                if (val !== undefined)\r\n                  sum += val;\r\n                if (key === value)\r\n                  break;\r\n              }\r\n            }\r\n            j++;\r\n          }\r\n          data[name][c.key] = sum;\r\n          total += sum;\r\n        });\r\n        data[name]['_total'] = total;\r\n      }\r\n    });\r\n  }\r\n  explore(x: string | number | string[] | number[], series: string | number | string[] | number[]) {\r\n    if (!this.interactive) return;\r\n    const axes = { ...this.filters } as AxesMap;\r\n    if (this._sum) {\r\n      let i = 0;\r\n      while (i < this._sum.length) {\r\n        let { value, calculate } = this._sum[i], name = '_sum_' + i;\r\n        if (x === name) {\r\n          x = [] as string[];\r\n          for (let i = 0; i < this.columns.length; i++) {\r\n            let key = this.columns[i].key;\r\n            if (isFunction(calculate)) {\r\n              let val = (calculate as (string, data) => number)(key, this.data);\r\n              if (val !== undefined)\r\n                x.push(key);\r\n            } else {\r\n              x.push(key);\r\n              if (key === value)\r\n                break;\r\n            }\r\n          }\r\n          break;\r\n        }\r\n        else if (series === name) {\r\n          series = [] as string[];\r\n          for (let i = 0; i < this.rows.length; i++) {\r\n            let key = this.rows[i].key;\r\n            if (isFunction(calculate)) {\r\n              let val = (calculate as (string, data) => number)(key, this.data);\r\n              if (val !== undefined)\r\n                series.push(key);\r\n            } else {\r\n              series.push(key);\r\n              if (key === value)\r\n                break;\r\n            }\r\n          }\r\n          break;\r\n        }\r\n        i++;\r\n      }\r\n    }\r\n    axes[this.xAxis.name] = x;\r\n    axes[this.series.name] = series;\r\n    this.onExplore.emit(axes);\r\n  }\r\n  move(x, y) {\r\n    let rowIndex = 0;\r\n    for (let b = 0; b < this.tableElement.nativeElement.tBodies.length; b++) {\r\n      let tBody = this.tableElement.nativeElement.tBodies.item(b);\r\n      for (let r = 0; r < tBody.rows.length; r++) {\r\n        let row = tBody.rows.item(r);\r\n        for (let c = 0; c < row.cells.length; c++) {\r\n          let cell = row.cells.item(c);\r\n          if (c === x)\r\n            cell.classList.add('cell-x');\r\n          else\r\n            cell.classList.remove('cell-x');\r\n          if (rowIndex === y)\r\n            cell.classList.add('cell-y');\r\n          else\r\n            cell.classList.remove('cell-y');\r\n        }\r\n        rowIndex++;\r\n      }\r\n      let tFoot = this.tableElement.nativeElement.tFoot, row = tFoot.rows[0];\r\n      for (let c = 0; c < row.cells.length; c++) {\r\n        let cell = row.cells.item(c);\r\n        if (c === x)\r\n          cell.classList.add('cell-x');\r\n        else\r\n          cell.classList.remove('cell-x');\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\nexport type SumSettings = {\r\n  value?: string | number;\r\n  axis: 'series' | 'xAxis';\r\n  title: string;\r\n  calculate?: 'quarter' | 'year' | 'month' | CalculateFn;\r\n}\r\n\r\nexport declare interface CalculateFn {\r\n  (value: string, data: { [series: string]: { [xAxis: string]: number; }; }): number;\r\n}\r\n\r\ntype KeyValue = {\r\n  key: string;\r\n  value: any;\r\n};\r\n","<table #table class=\"mat-table cube-table\" (mouseleave)=\"move(-1, -1)\" *ngIf=\"data\">\r\n  <thead>\r\n    <!-- headers -->\r\n    <tr class=\"mat-row\">\r\n      <th></th>\r\n      <th *ngFor=\"let column of columns; let x = index\" (mouseenter)=\"move(x + 1, -2)\" class=\"mat-header-cell\">\r\n        {{ column.value }}\r\n      </th>\r\n      <th></th>\r\n    </tr>\r\n  </thead>\r\n  <tbody>\r\n    <!-- indices -->\r\n    <tr class=\"mat-row cube-index\" *ngFor=\"let index of indices; let y = index\">\r\n      <th class=\"mat-header-cell\" (mouseenter)=\"move(0, y)\">{{index.title}}</th>\r\n      <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y)\">\r\n        <span *ngIf=\"data[index.name] && data[index.name][column.key]; else zero\">{{ data[index.name][column.key] | number : PRECISION }}</span>\r\n      </td>\r\n      <th class=\"mat-cell figure\" (mouseenter)=\"move(0, y)\" [ngSwitch]=\"!CURRENCY\">\r\n        <ng-container *ngSwitchCase=\"true\">\r\n          {{ data[index.name]['_total'] | number : PRECISION }}\r\n        </ng-container>\r\n        <ng-container *ngSwitchDefault>\r\n          {{ data[index.name]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n        </ng-container>\r\n      </th>\r\n    </tr>\r\n  </tbody>\r\n  <tbody>\r\n    <!-- rows -->\r\n    <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\">\r\n      <th class=\"mat-header-cell\" (mouseenter)=\"move(-2, y + indices.length)\">{{ row.value }}</th>\r\n      <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, y + indices.length)\">\r\n        <ng-container *ngIf=\"data[row.key] && data[row.key][column.key] !== undefined; else zero\">\r\n          <span [class.clickable]=\"interactive\" (click)=\"explore(column.key, row.key)\">\r\n            {{data[row.key][column.key] | number : PRECISION }}\r\n          </span>\r\n        </ng-container>\r\n      </td>\r\n      <th class=\"mat-cell figure\" (mouseenter)=\"move(-1, y + indices.length)\" [ngSwitch]=\"!CURRENCY\">\r\n        <ng-container *ngSwitchCase=\"true\">\r\n          {{ data[row.key]['_total'] | number : PRECISION }}\r\n        </ng-container>\r\n        <ng-container *ngSwitchDefault>\r\n          {{ data[row.key]['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n        </ng-container>\r\n      </th>\r\n    </tr>\r\n  </tbody>\r\n  <tfoot>\r\n    <!-- available -->\r\n    <tr>\r\n      <th></th>\r\n      <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\" (mouseenter)=\"move(x + 1, -2)\"\r\n          [class.negative-figure]=\"totals[column.key] < 0\">\r\n        {{totals[column.key] | currency : CURRENCY: 'symbol' : PRECISION }}\r\n      </td>\r\n      <th class=\"mat-cell figure\">{{totals['_total'] | currency : CURRENCY: 'symbol' : PRECISION }}</th>\r\n    </tr>\r\n  </tfoot>\r\n</table>\r\n<ng-template #zero>\r\n  0\r\n</ng-template>\r\n"]}