@bizdoc/core 2.3.35 → 2.3.39

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 (36) hide show
  1. package/esm2022/lib/admin/architecture/elements/performance-report.component.mjs +3 -4
  2. package/esm2022/lib/admin/diff/configuration-diff.component.mjs +5 -4
  3. package/esm2022/lib/admin/document-trace/document-trace.component.mjs +3 -3
  4. package/esm2022/lib/admin/utility.pane.component.mjs +10 -12
  5. package/esm2022/lib/browse/browse.pane.component.mjs +3 -3
  6. package/esm2022/lib/browse/expanded-item/expanded-item.component.mjs +3 -3
  7. package/esm2022/lib/core/animations.mjs +5 -2
  8. package/esm2022/lib/core/slots/slots.component.mjs +3 -3
  9. package/esm2022/lib/core/sticky-toolbar.exp.mjs +30 -0
  10. package/esm2022/lib/core/translations.mjs +6 -2
  11. package/esm2022/lib/core/virtual-tabs.component.exp.mjs +84 -0
  12. package/esm2022/lib/cube/filter/filter-tags.component.exp.mjs +3 -3
  13. package/esm2022/lib/cube/filter/filter.component.mjs +3 -3
  14. package/esm2022/lib/modules/chart.module.mjs +3 -3
  15. package/esm2022/lib/options/options.component.mjs +3 -3
  16. package/esm2022/lib/reports/cube/role-performance.component.mjs +152 -33
  17. package/esm2022/lib/reports/cube/role-performance1.component.mjs +178 -0
  18. package/esm2022/lib/reports/report-viewer.component.mjs +10 -6
  19. package/esm2022/lib/reports/report.pane.component.mjs +2 -2
  20. package/esm2022/lib/shared.module.mjs +11 -9
  21. package/esm2022/public-api.mjs +3 -2
  22. package/fesm2022/bizdoc-core.mjs +440 -75
  23. package/fesm2022/bizdoc-core.mjs.map +1 -1
  24. package/lib/admin/architecture/elements/performance-report.component.d.ts +0 -1
  25. package/lib/admin/utility.pane.component.d.ts +2 -2
  26. package/lib/core/translations.d.ts +4 -0
  27. package/lib/core/virtual-tabs.component.exp.d.ts +22 -0
  28. package/lib/reports/cube/role-performance.component.d.ts +35 -21
  29. package/lib/reports/cube/role-performance1.component.d.ts +49 -0
  30. package/lib/reports/report-viewer.component.d.ts +1 -1
  31. package/lib/reports/report.pane.component.d.ts +1 -1
  32. package/lib/shared.module.d.ts +195 -193
  33. package/package.json +1 -1
  34. package/public-api.d.ts +2 -1
  35. package/esm2022/lib/core/StickyToolbar.mjs +0 -30
  36. /package/lib/core/{StickyToolbar.d.ts → sticky-toolbar.exp.d.ts} +0 -0
@@ -1,50 +1,171 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { Component } from '@angular/core';
3
- import { BizDoc } from '../../core/decorators';
4
3
  import { Chart } from '@syncfusion/ej2-charts';
4
+ import { Subject, startWith, takeUntil } from 'rxjs';
5
+ /// <reference path="./node_modules/dayjs/plugin/duration.d.ts" />
6
+ import dayjs from 'dayjs';
7
+ import { BizDoc } from '../../core/decorators';
8
+ import { FONT_FAMILY } from '../../core/colors';
5
9
  import * as i0 from "@angular/core";
6
10
  import * as i1 from "../../core/router";
7
- import * as i2 from "../../core/session.service";
8
- import * as i3 from "../../core/translate.service";
9
- import * as i4 from "../report-ref";
11
+ import * as i2 from "../../core/account.service";
12
+ import * as i3 from "../../core/session.service";
13
+ import * as i4 from "../../core/translate.service";
10
14
  let RolesPerformanceComponent = class RolesPerformanceComponent {
11
- constructor(_elementRef, _router, _session, _translate, _reportRef) {
15
+ constructor(_elementRef, _router, _accounts, _session, _translate) {
12
16
  this._elementRef = _elementRef;
13
17
  this._router = _router;
18
+ this._accounts = _accounts;
14
19
  this._session = _session;
15
20
  this._translate = _translate;
16
- this._reportRef = _reportRef;
17
- this.legendSettings = {};
18
- const { cube: name } = _reportRef.options;
19
- this._cube = name ? this._session.profile.cubes.find(c => c.name === name) : this._session.profile.cubes[0];
20
- }
21
- onBind(data, args) {
22
- const roles = [];
23
- data.forEach(d => { });
24
- const series = [{}];
25
- new Chart({
26
- series,
21
+ this.legendSettings = {
22
+ position: 'Left',
23
+ isInversed: this._session.inverse,
24
+ //toggleVisibility: false,
25
+ enablePages: true,
26
+ enableHighlight: true,
27
+ };
28
+ this.tooltip = {
29
+ enable: true,
30
+ textStyle: {
31
+ fontFamily: FONT_FAMILY
32
+ }
33
+ };
34
+ this.titleStyle = {
35
+ fontFamily: FONT_FAMILY
36
+ };
37
+ this.primaryXAxis = { valueType: 'Double' };
38
+ this.primaryYAxis = {};
39
+ this.actions = {};
40
+ this._destroy = new Subject();
41
+ _session.profile.actions.forEach(a => this.actions[a.name] = a);
42
+ _session.themeChange.pipe(takeUntil(this._destroy), startWith(_session.theme)).subscribe(t => {
43
+ this.theme = t.dark ? 'Material3Dark' : 'Material3';
44
+ this.chart && this._draw();
45
+ });
46
+ }
47
+ onBind(data) {
48
+ this.chart?.destroy();
49
+ if (!data.length)
50
+ return;
51
+ let accumStd = 0, countStd = 0, accumDuration = 0, maxStd = 0, maxDuration = 0, standards = [], map = {};
52
+ data.forEach(e => {
53
+ let accumStd1 = 0, countStd1 = 0, accumDuration1 = 0;
54
+ e.items.forEach(e => {
55
+ if (e.standardTime) {
56
+ if (e.standardTime > maxStd)
57
+ maxStd = e.standardTime;
58
+ countStd++;
59
+ countStd1++;
60
+ accumStd += e.standardTime;
61
+ accumStd1 += e.standardTime;
62
+ standards.push(e);
63
+ }
64
+ if (e.duration > maxDuration)
65
+ maxDuration = e.duration;
66
+ accumDuration += e.duration;
67
+ accumDuration1 += e.duration;
68
+ });
69
+ map[e.userId] = {
70
+ items: e.items,
71
+ stdAvg: countStd1 ? accumStd1 / countStd1 : 0,
72
+ durationAvg: accumDuration1 / data.length,
73
+ };
74
+ });
75
+ this.stdAvg = countStd ? accumStd / countStd : 0,
76
+ this.durationAvg = accumDuration / data.length;
77
+ this._accounts.getAll(data.map(e => e.userId)).
78
+ subscribe(users => {
79
+ this.series = [{
80
+ name: this._translate.get('Standard'),
81
+ xName: 'date',
82
+ yName: 'standardTime',
83
+ type: 'Polar',
84
+ drawType: 'Line',
85
+ marker: {
86
+ visible: true,
87
+ shape: 'Triangle',
88
+ width: 5,
89
+ height: 5
90
+ },
91
+ dataSource: standards.
92
+ sort((e1, e2) => e1.standardTime < e2.standardTime ? -1 : 1),
93
+ },
94
+ ...users.map(u => ({
95
+ dataSource: map[u.id].items,
96
+ name: u.name,
97
+ type: 'Polar',
98
+ drawType: 'Line',
99
+ marker: {
100
+ visible: true,
101
+ width: 5, height: 5,
102
+ shape: 'Pentagon',
103
+ },
104
+ xName: 'date',
105
+ yName: 'duration',
106
+ }))];
107
+ this._draw();
108
+ });
109
+ }
110
+ _draw() {
111
+ this.chart?.destroy();
112
+ const colors = this._session.accentPalette;
113
+ let palettes = [this._session.getPrimery(),
114
+ ...colors
115
+ ];
116
+ while (this.series.length < palettes.length) {
117
+ palettes.push(...colors);
118
+ }
119
+ this.chart = new Chart({
120
+ theme: this.theme,
121
+ selectionMode: 'Series',
122
+ title: this._translate.get('AverageValue', dayjs.duration(this.durationAvg, 'seconds').format('DD:HH:mm')),
123
+ titleStyle: this.titleStyle,
124
+ subTitle: this.stdAvg ?
125
+ this._translate.get('StandardValue', dayjs.duration(this.stdAvg, 'seconds').format('DD:HH:mm')) : null,
126
+ subTitleStyle: this.titleStyle,
127
+ series: this.series,
128
+ tooltip: this.tooltip,
129
+ tooltipRender: this.tooltipRender.bind(this),
27
130
  legendSettings: this.legendSettings,
131
+ legendRender: this.legendRender.bind(this),
28
132
  axisLabelRender: this.labelRender.bind(this),
29
- palettes: this._session.accentPalette,
133
+ palettes,
30
134
  enableRtl: this._session.inverse,
135
+ height: '100%',
136
+ highlightMode: 'Series',
31
137
  pointClick: this.explore.bind(this)
32
138
  }, this._elementRef.nativeElement);
33
139
  }
34
- labelRender(evt) { }
140
+ legendRender(evt) {
141
+ //evt.text
142
+ }
143
+ tooltipRender(evt) {
144
+ evt.text = dayjs.duration(evt.data.pointY, 's').humanize(); // 'DD:HH:ss'
145
+ }
146
+ labelRender(evt) {
147
+ switch (evt.axis.name) {
148
+ case 'primaryYAxis':
149
+ evt.text = dayjs.duration(evt.value, 's').format('DD:HH:mm');
150
+ break;
151
+ case 'primaryXAxis':
152
+ evt.text = dayjs(evt.value).format('MMM YYYY');
153
+ break;
154
+ }
155
+ }
35
156
  explore(evt) {
36
- const { point: { x, yValue }, series: { name: title } } = evt;
37
- const { cube, series } = this._reportRef.options;
38
- const axes = {};
39
- axes[series] = x;
40
- this._router.navigate(['cube', cube, 'explore'], {
41
- queryParams: axes,
42
- });
157
+ const { pointIndex, seriesIndex } = evt;
158
+ if (seriesIndex === 0)
159
+ return;
160
+ const { documentId } = this.chart.series[seriesIndex].dataSource[pointIndex];
161
+ this._router.navigate(['mailbox', 'd', documentId.encodeId()]);
43
162
  }
44
- ngOnInit() {
163
+ ngOnDestroy() {
164
+ this.chart?.destroy();
165
+ this._destroy.next();
45
166
  }
46
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: RolesPerformanceComponent, deps: [{ token: i0.ElementRef }, { token: i1.RouterImpl }, { token: i2.SessionService }, { token: i3.TranslateService }, { token: i4.ReportRef }], target: i0.ɵɵFactoryTarget.Component }); }
47
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: RolesPerformanceComponent, selector: "ng-component", ngImport: i0, template: '', isInline: true }); }
167
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: RolesPerformanceComponent, deps: [{ token: i0.ElementRef }, { token: i1.RouterImpl }, { token: i2.AccountService }, { token: i3.SessionService }, { token: i4.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
168
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: RolesPerformanceComponent, selector: "ng-component", ngImport: i0, template: '', isInline: true, styles: [":host{flex:1}\n"] }); }
48
169
  };
49
170
  RolesPerformanceComponent = __decorate([
50
171
  BizDoc({
@@ -54,8 +175,6 @@ RolesPerformanceComponent = __decorate([
54
175
  export { RolesPerformanceComponent };
55
176
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: RolesPerformanceComponent, decorators: [{
56
177
  type: Component,
57
- args: [{
58
- template: ''
59
- }]
60
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.RouterImpl }, { type: i2.SessionService }, { type: i3.TranslateService }, { type: i4.ReportRef }] });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9sZS1wZXJmb3JtYW5jZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJpZXMvY29yZS9zcmMvbGliL3JlcG9ydHMvY3ViZS9yb2xlLXBlcmZvcm1hbmNlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBc0IsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBTy9DLE9BQU8sRUFBRSxLQUFLLEVBQStELE1BQU0sd0JBQXdCLENBQUM7Ozs7OztBQVFyRyxJQUFNLHlCQUF5QixHQUEvQixNQUFNLHlCQUF5QjtJQUdwQyxZQUNVLFdBQXVDLEVBQ3ZDLE9BQW1CLEVBQ2pCLFFBQXdCLEVBQ3hCLFVBQTRCLEVBQzlCLFVBQStDO1FBSi9DLGdCQUFXLEdBQVgsV0FBVyxDQUE0QjtRQUN2QyxZQUFPLEdBQVAsT0FBTyxDQUFZO1FBQ2pCLGFBQVEsR0FBUixRQUFRLENBQWdCO1FBQ3hCLGVBQVUsR0FBVixVQUFVLENBQWtCO1FBQzlCLGVBQVUsR0FBVixVQUFVLENBQXFDO1FBSWhELG1CQUFjLEdBQUcsRUFBeUIsQ0FBQztRQUhsRCxNQUFNLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUM7UUFDMUMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDOUcsQ0FBQztJQUVELE1BQU0sQ0FBQyxJQUFhLEVBQUUsSUFBVTtRQUM5QixNQUFNLEtBQUssR0FBRyxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ3ZCLE1BQU0sTUFBTSxHQUFHLENBQUMsRUFFQSxDQUFDLENBQUM7UUFDbEIsSUFBSSxLQUFLLENBQUM7WUFDUixNQUFNO1lBQ04sY0FBYyxFQUFFLElBQUksQ0FBQyxjQUFjO1lBQ25DLGVBQWUsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7WUFDNUMsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYTtZQUNyQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPO1lBQ2hDLFVBQVUsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUM7U0FDcEMsRUFDQyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFDRCxXQUFXLENBQUMsR0FBOEIsSUFBSSxDQUFDO0lBQy9DLE9BQU8sQ0FBQyxHQUFRO1FBQ2QsTUFBTSxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsRUFBRSxNQUFNLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLEVBQUUsR0FBRyxHQUFHLENBQUM7UUFDOUQsTUFBTSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQztRQUVqRCxNQUFNLElBQUksR0FBRyxFQUFFLENBQUM7UUFDaEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNqQixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsU0FBUyxDQUFDLEVBQzdDO1lBQ0UsV0FBVyxFQUFFLElBQUk7U0FDbEIsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUNELFFBQVE7SUFDUixDQUFDOzhHQTFDVSx5QkFBeUI7a0dBQXpCLHlCQUF5QixvREFMMUIsRUFBRTs7QUFLRCx5QkFBeUI7SUFIckMsTUFBTSxDQUFDO1FBQ04sUUFBUSxFQUFFLHlCQUF5QjtLQUNwQyxDQUFDO0dBQ1cseUJBQXlCLENBMkNyQzs7MkZBM0NZLHlCQUF5QjtrQkFOckMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsRUFBRTtpQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEJpekRvYyB9IGZyb20gJy4uLy4uL2NvcmUvZGVjb3JhdG9ycyc7XHJcbmltcG9ydCB7IFJlcG9ydFJlZiB9IGZyb20gJy4uL3JlcG9ydC1yZWYnO1xyXG5pbXBvcnQgeyBSZXBvcnRDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb3JlL2Jhc2UnO1xyXG5pbXBvcnQgeyBTZXNzaW9uU2VydmljZSB9IGZyb20gJy4uLy4uL2NvcmUvc2Vzc2lvbi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJy4uLy4uL2NvcmUvdHJhbnNsYXRlLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBSb3V0ZXJJbXBsIH0gZnJvbSAnLi4vLi4vY29yZS9yb3V0ZXInO1xyXG5pbXBvcnQgeyBBeGVzTWFwLCBDdWJlIH0gZnJvbSAnLi4vLi4vY29yZS9tb2RlbHMnO1xyXG5pbXBvcnQgeyBDaGFydCwgSUF4aXNMYWJlbFJlbmRlckV2ZW50QXJncywgTGVnZW5kU2V0dGluZ3NNb2RlbCwgU2VyaWVzTW9kZWwgfSBmcm9tICdAc3luY2Z1c2lvbi9lajItY2hhcnRzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHRlbXBsYXRlOiAnJ1xyXG59KVxyXG5AQml6RG9jKHtcclxuICBzZWxlY3RvcjogJ2JpemRvYy1yb2xlLXBlcmZvcm1hbmNlJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgUm9sZXNQZXJmb3JtYW5jZUNvbXBvbmVudCBpbXBsZW1lbnRzIFJlcG9ydENvbXBvbmVudDxNb2RlbD4sIE9uSW5pdCB7XHJcbiAgcHJpdmF0ZSBfYXJnczogQXhlc01hcDtcclxuICBwcml2YXRlIHJlYWRvbmx5IF9jdWJlOiBDdWJlO1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBfZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRGl2RWxlbWVudD4sXHJcbiAgICBwcml2YXRlIF9yb3V0ZXI6IFJvdXRlckltcGwsXHJcbiAgICBwcm90ZWN0ZWQgX3Nlc3Npb246IFNlc3Npb25TZXJ2aWNlLFxyXG4gICAgcHJvdGVjdGVkIF90cmFuc2xhdGU6IFRyYW5zbGF0ZVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIF9yZXBvcnRSZWY6IFJlcG9ydFJlZjxQZXJmb3JtYW5jZVNldHRpbmdzTW9kZWw+KSB7XHJcbiAgICBjb25zdCB7IGN1YmU6IG5hbWUgfSA9IF9yZXBvcnRSZWYub3B0aW9ucztcclxuICAgIHRoaXMuX2N1YmUgPSBuYW1lID8gdGhpcy5fc2Vzc2lvbi5wcm9maWxlLmN1YmVzLmZpbmQoYyA9PiBjLm5hbWUgPT09IG5hbWUpIDogdGhpcy5fc2Vzc2lvbi5wcm9maWxlLmN1YmVzWzBdO1xyXG4gIH1cclxuICByZWFkb25seSBsZWdlbmRTZXR0aW5ncyA9IHt9IGFzIExlZ2VuZFNldHRpbmdzTW9kZWw7XHJcbiAgb25CaW5kKGRhdGE6IE1vZGVsW10sIGFyZ3M/OiBhbnkpIHtcclxuICAgIGNvbnN0IHJvbGVzID0gW107XHJcbiAgICBkYXRhLmZvckVhY2goZCA9PiB7IH0pO1xyXG4gICAgY29uc3Qgc2VyaWVzID0gW3tcclxuICAgICAgXHJcbiAgICB9IGFzIFNlcmllc01vZGVsXTtcclxuICAgIG5ldyBDaGFydCh7XHJcbiAgICAgIHNlcmllcyxcclxuICAgICAgbGVnZW5kU2V0dGluZ3M6IHRoaXMubGVnZW5kU2V0dGluZ3MsXHJcbiAgICAgIGF4aXNMYWJlbFJlbmRlcjogdGhpcy5sYWJlbFJlbmRlci5iaW5kKHRoaXMpLFxyXG4gICAgICBwYWxldHRlczogdGhpcy5fc2Vzc2lvbi5hY2NlbnRQYWxldHRlLFxyXG4gICAgICBlbmFibGVSdGw6IHRoaXMuX3Nlc3Npb24uaW52ZXJzZSxcclxuICAgICAgcG9pbnRDbGljazogdGhpcy5leHBsb3JlLmJpbmQodGhpcylcclxuICAgIH0sXHJcbiAgICAgIHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCk7XHJcbiAgfVxyXG4gIGxhYmVsUmVuZGVyKGV2dDogSUF4aXNMYWJlbFJlbmRlckV2ZW50QXJncykgeyB9XHJcbiAgZXhwbG9yZShldnQ6IGFueSkge1xyXG4gICAgY29uc3QgeyBwb2ludDogeyB4LCB5VmFsdWUgfSwgc2VyaWVzOiB7IG5hbWU6IHRpdGxlIH0gfSA9IGV2dDtcclxuICAgIGNvbnN0IHsgY3ViZSwgc2VyaWVzIH0gPSB0aGlzLl9yZXBvcnRSZWYub3B0aW9ucztcclxuXHJcbiAgICBjb25zdCBheGVzID0ge307XHJcbiAgICBheGVzW3Nlcmllc10gPSB4O1xyXG4gICAgdGhpcy5fcm91dGVyLm5hdmlnYXRlKFsnY3ViZScsIGN1YmUsICdleHBsb3JlJ10sXHJcbiAgICAgIHtcclxuICAgICAgICBxdWVyeVBhcmFtczogYXhlcyxcclxuICAgICAgfSk7XHJcbiAgfVxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gIH1cclxufVxyXG5pbnRlcmZhY2UgTW9kZWwge1xyXG4gIHJvbGVJZDogc3RyaW5nO1xyXG4gIGNvdW50OiBudW1iZXI7XHJcbiAgZGF0ZTogRGF0ZTtcclxuICBheGlzOiBzdHJpbmc7XHJcbn1cclxuaW50ZXJmYWNlIFBvaW50IHtcclxufVxyXG5pbnRlcmZhY2UgUGVyZm9ybWFuY2VTZXR0aW5nc01vZGVsIHtcclxuICBjdWJlPzogc3RyaW5nO1xyXG4gIHNlcmllczogc3RyaW5nO1xyXG59XHJcbiJdfQ==
178
+ args: [{ template: '', styles: [":host{flex:1}\n"] }]
179
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.RouterImpl }, { type: i2.AccountService }, { type: i3.SessionService }, { type: i4.TranslateService }] });
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role-performance.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/reports/cube/role-performance.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnDestroy } from '@angular/core';\r\nimport { ILegendRenderEventArgs, IPointEventArgs, AxisModel, ChartTheme, IPointRenderEventArgs, ITooltipRenderEventArgs, Chart, IAxisLabelRenderEventArgs, LegendSettingsModel, SeriesModel, TooltipSettingsModel, titleSettingsModel } from '@syncfusion/ej2-charts';\r\nimport { Subject, startWith, takeUntil } from 'rxjs';\r\n/// <reference path=\"./node_modules/dayjs/plugin/duration.d.ts\" />\r\nimport dayjs from 'dayjs';\r\nimport { BizDoc } from '../../core/decorators';\r\nimport { ReportRef } from '../report-ref';\r\nimport { ReportComponent } from '../../core/base';\r\nimport { AccountService } from '../../core/account.service';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { RouterImpl } from '../../core/router';\r\nimport { Action, AxesMap } from '../../core/models';\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { FONT_FAMILY } from '../../core/colors';\r\n\r\n@Component({\r\n  template: '',\r\n  styles: `:host {flex: 1}`\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-role-performance'\r\n})\r\nexport class RolesPerformanceComponent implements ReportComponent<Model>, OnDestroy {\r\n  durationAvg: number;\r\n  stdAvg: number;\r\n  series: SeriesModel[];\r\n  chart: Chart;\r\n  readonly legendSettings = {\r\n    position: 'Left',\r\n    isInversed: this._session.inverse,\r\n    //toggleVisibility: false,\r\n    enablePages: true,\r\n    enableHighlight: true,\r\n  } as LegendSettingsModel;\r\n  readonly tooltip = {\r\n    enable: true,\r\n    textStyle: {\r\n      fontFamily: FONT_FAMILY\r\n    }\r\n  } as TooltipSettingsModel;\r\n  theme: ChartTheme;\r\n  readonly titleStyle = {\r\n    fontFamily: FONT_FAMILY\r\n  } as titleSettingsModel;\r\n  readonly primaryXAxis = { valueType: 'Double' } as AxisModel;\r\n  readonly primaryYAxis = {} as AxisModel;\r\n  private actions: { [name: string]: Action } = {};\r\n  private readonly _destroy = new Subject<void>();\r\n  constructor(\r\n    private _elementRef: ElementRef<HTMLDivElement>,\r\n    private _router: RouterImpl,\r\n    private _accounts: AccountService,\r\n    private _session: SessionService,\r\n    private _translate: TranslateService,\r\n  ) {\r\n    _session.profile.actions.forEach(a =>\r\n      this.actions[a.name] = a\r\n    );\r\n    _session.themeChange.pipe(takeUntil(this._destroy), startWith(_session.theme)).subscribe(t => {\r\n      this.theme = t.dark ? 'Material3Dark' : 'Material3';\r\n      this.chart && this._draw();\r\n    })\r\n  }\r\n  onBind(data: Model[]) {\r\n    this.chart?.destroy();\r\n    if (!data.length) return;\r\n    let accumStd = 0, countStd = 0, accumDuration = 0, maxStd = 0, maxDuration = 0,\r\n      standards = [] as ItemModel[], map: {\r\n        [userId: string]: {\r\n          items: ItemModel[];\r\n          durationAvg: number;\r\n          stdAvg: number;\r\n        }\r\n      } = {};\r\n    data.forEach(e => {\r\n      let accumStd1 = 0, countStd1 = 0, accumDuration1 = 0;\r\n      e.items.forEach(e => {\r\n        if (e.standardTime) {\r\n          if (e.standardTime > maxStd)\r\n            maxStd = e.standardTime;\r\n          countStd++;\r\n          countStd1++;\r\n          accumStd += e.standardTime;\r\n          accumStd1 += e.standardTime;\r\n          standards.push(e);\r\n        }\r\n        if (e.duration > maxDuration)\r\n          maxDuration = e.duration;\r\n        accumDuration += e.duration;\r\n        accumDuration1 += e.duration;\r\n      });\r\n      map[e.userId] = {\r\n        items: e.items,\r\n        stdAvg: countStd1 ? accumStd1 / countStd1 : 0,\r\n        durationAvg: accumDuration1 / data.length,\r\n      };\r\n    });\r\n    this.stdAvg = countStd ? accumStd / countStd : 0,\r\n      this.durationAvg = accumDuration / data.length;\r\n    this._accounts.getAll(data.map(e => e.userId)).\r\n      subscribe(users => {\r\n        this.series = [{\r\n          name: this._translate.get('Standard'),\r\n          xName: 'date',\r\n          yName: 'standardTime',\r\n          type: 'Polar',\r\n          drawType: 'Line',\r\n          marker: {\r\n            visible: true,\r\n            shape: 'Triangle',\r\n            width: 5,\r\n            height: 5\r\n          },\r\n          dataSource: standards.\r\n            sort((e1, e2) => e1.standardTime < e2.standardTime ? -1 : 1),\r\n        } as SeriesModel,\r\n        ...users.map(u =>\r\n        ({\r\n          dataSource: map[u.id].items,\r\n          name: u.name,\r\n          type: 'Polar',\r\n          drawType: 'Line',\r\n          marker: {\r\n            visible: true,\r\n            width: 5, height: 5,\r\n            shape: 'Pentagon',\r\n          },\r\n          xName: 'date',\r\n          yName: 'duration',\r\n        } as SeriesModel))];\r\n        this._draw();\r\n      });\r\n  }\r\n  private _draw() {\r\n    this.chart?.destroy();\r\n    const colors = this._session.accentPalette;\r\n    let palettes = [this._session.getPrimery(),\r\n    ...colors\r\n    ];\r\n    while (this.series.length < palettes.length) {\r\n      palettes.push(...colors);\r\n    }\r\n    this.chart = new Chart({\r\n      theme: this.theme,\r\n      selectionMode: 'Series',\r\n      title: this._translate.get('AverageValue', dayjs.duration(this.durationAvg, 'seconds').format('DD:HH:mm')),\r\n      titleStyle: this.titleStyle,\r\n      subTitle: this.stdAvg ?\r\n        this._translate.get('StandardValue', dayjs.duration(this.stdAvg, 'seconds').format('DD:HH:mm')) : null,\r\n      subTitleStyle: this.titleStyle,\r\n      series: this.series,\r\n      tooltip: this.tooltip,\r\n      tooltipRender: this.tooltipRender.bind(this),\r\n      legendSettings: this.legendSettings,\r\n      legendRender: this.legendRender.bind(this),\r\n      axisLabelRender: this.labelRender.bind(this),\r\n      palettes,\r\n      enableRtl: this._session.inverse,\r\n      height: '100%',\r\n      highlightMode: 'Series',\r\n      pointClick: this.explore.bind(this)\r\n    },\r\n      this._elementRef.nativeElement);\r\n  }\r\n  legendRender(evt: ILegendRenderEventArgs) {\r\n    //evt.text\r\n  }\r\n  tooltipRender(evt: ITooltipRenderEventArgs) {\r\n    evt.text = dayjs.duration(evt.data.pointY as any, 's').humanize();// 'DD:HH:ss'\r\n  }\r\n  labelRender(evt: IAxisLabelRenderEventArgs) {\r\n    switch (evt.axis.name) {\r\n      case 'primaryYAxis':\r\n        evt.text = dayjs.duration(evt.value, 's').format('DD:HH:mm');\r\n        break;\r\n      case 'primaryXAxis':\r\n        evt.text = dayjs(evt.value).format('MMM YYYY');\r\n        break;\r\n    }\r\n  }\r\n  explore(evt: IPointEventArgs) {\r\n    const { pointIndex, seriesIndex } = evt;\r\n    if (seriesIndex === 0) return;\r\n\r\n    const { documentId } = this.chart.series[seriesIndex].dataSource[pointIndex] as ItemModel;\r\n\r\n    this._router.navigate(['mailbox', 'd', documentId.encodeId()]);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.chart?.destroy();\r\n    this._destroy.next();\r\n  }\r\n}\r\n\r\ninterface Model {\r\n  userId: string;\r\n  items: ItemModel[];\r\n}\r\ninterface ItemModel {\r\n  documentId: number;\r\n  date: number;\r\n  standardTime?: number;\r\n  duration: number;\r\n  isFYI: boolean;\r\n  actionId: string;\r\n}\r\ninterface PerformanceSettingsModel {\r\n  cube?: string;\r\n  filters?: AxesMap;\r\n}\r\n"]}
@@ -0,0 +1,178 @@
1
+ import { __decorate } from "tslib";
2
+ import { Component } from '@angular/core';
3
+ import { Subject, startWith, takeUntil } from 'rxjs';
4
+ /// <reference path="./node_modules/dayjs/plugin/duration.d.ts" />
5
+ import dayjs from 'dayjs';
6
+ import { BizDoc } from '../../core/decorators';
7
+ import { FONT_FAMILY } from '../../core/colors';
8
+ //import { CircularGauge, GaugeTheme, IAxisLabelRenderEventArgs, ITooltipRenderEventArgs, LegendSettingsModel, RangeModel, TooltipSettingsModel } from '@syncfusion/ej2-angular-circulargauge';
9
+ import { Chart } from '@syncfusion/ej2-angular-charts';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "../../core/account.service";
12
+ import * as i2 from "../../core/session.service";
13
+ import * as i3 from "../../core/translate.service";
14
+ let RolesPerformanceComponent1 = class RolesPerformanceComponent1 {
15
+ constructor(_elementRef, _accounts, _session, _translate) {
16
+ this._elementRef = _elementRef;
17
+ this._accounts = _accounts;
18
+ this._session = _session;
19
+ this._translate = _translate;
20
+ this.titleStyle = {
21
+ fontFamily: FONT_FAMILY
22
+ };
23
+ this._destroy = new Subject();
24
+ _session.themeChange.pipe(takeUntil(this._destroy), startWith(_session.theme)).subscribe(t => {
25
+ //this.theme = t.dark ? 'Material3Dark' : 'Material3';
26
+ //this.gauge && this._draw();
27
+ this.chart && this._draw();
28
+ });
29
+ }
30
+ onBind(data) {
31
+ //this.gauge?.destroy();
32
+ this.chart?.destroy();
33
+ if (!data.length)
34
+ return;
35
+ let accumStd = 0, countStd = 0, accumDuration = 0;
36
+ this.maxStd = 0, this.minStd = 0, this.maxDuration = 0, this.minDuration = data[0].durationLow;
37
+ data.forEach(e => {
38
+ if (e.standardAvg) {
39
+ if (e.standardHigh > this.maxStd)
40
+ this.maxStd = e.standardHigh;
41
+ if (e.standardLow < this.minStd || this.minStd === 0)
42
+ this.minStd = e.standardLow;
43
+ countStd++;
44
+ accumStd += e.standardAvg;
45
+ }
46
+ accumDuration += e.durationAvg;
47
+ if (e.durationHigh > this.maxDuration)
48
+ this.maxDuration = e.durationHigh;
49
+ if (e.durationLow < this.minDuration)
50
+ this.minDuration = e.durationLow;
51
+ });
52
+ this.stdAvg = countStd ? accumStd / countStd : 0,
53
+ this.durationAvg = accumDuration / data.length;
54
+ this._accounts.getAll(data.map(e => e.userId)).
55
+ subscribe(users => {
56
+ this.data = data.map((d, i) => {
57
+ const durationDev = d.durationAvg / this.durationAvg, standardDev = this.stdAvg ? d.durationAvg / this.stdAvg : 0;
58
+ return ({
59
+ durationDev,
60
+ standardDev,
61
+ ...d,
62
+ name: users[i].name,
63
+ values: [d.standardHigh, d.durationHigh, d.durationAvg, d.durationLow, d.standardLow]
64
+ });
65
+ });
66
+ this._draw();
67
+ });
68
+ }
69
+ _draw() {
70
+ this.chart?.destroy();
71
+ //const colors = this._session.accentPalette;
72
+ //this.gauge?.destroy();
73
+ //this.gauge = new CircularGauge({
74
+ // theme: this.theme,
75
+ // title: this._translate.get('AverageValue', dayjs.duration(this.durationAvg, 'seconds').format('DD:HH:mm')),
76
+ // titleStyle: this.titleStyle,
77
+ // tooltip: this.tooltip,
78
+ // axes: [{
79
+ // startAngle: 270,
80
+ // endAngle: 90,
81
+ // pointers: [{
82
+ // text: this._translate.get('Standard'),
83
+ // color: this._session.getPrimery(),
84
+ // value: this.stdAvg
85
+ // }],
86
+ // ranges: this.data.map((e, i) => ({
87
+ // legendText: e.name,
88
+ // radius: `${100 - i * 5}%`,
89
+ // startWidth: 3,
90
+ // endWidth: 3,
91
+ // start: this.minDuration,
92
+ // end: this.stdAvg ? Math.floor(e.durationAvg / this.stdAvg) : Math.floor(e.durationAvg / this.durationAvg),
93
+ // color: colors[Math.floor((i + 9) / i)]
94
+ // } as RangeModel))
95
+ // }],
96
+ // tooltipRender: this.tooltipRender.bind(this),
97
+ // legendSettings: this.legendSettings,
98
+ // enableRtl: this._session.inverse,
99
+ // height: '100%',
100
+ //},
101
+ // this._elementRef.nativeElement);
102
+ this.chart = new Chart({
103
+ primaryYAxis: {
104
+ stripLines: [{
105
+ text: this._translate.get('Standard'),
106
+ textStyle: {
107
+ fontFamily: FONT_FAMILY,
108
+ },
109
+ opacity: .8,
110
+ start: this.minStd,
111
+ end: this.maxStd,
112
+ }]
113
+ },
114
+ primaryXAxis: {
115
+ valueType: 'Category'
116
+ },
117
+ tooltip: { enable: true },
118
+ tooltipRender: this.tooltipRender.bind(this),
119
+ series: [{
120
+ type: 'BoxAndWhisker',
121
+ dataSource: this.data,
122
+ boxPlotMode: 'Normal',
123
+ enableTooltip: true,
124
+ xName: 'name',
125
+ yName: 'values'
126
+ }, {
127
+ type: 'Spline',
128
+ dataSource: this.data,
129
+ xName: 'name',
130
+ width: 3,
131
+ dashArray: '3 2',
132
+ yName: 'durationAvg',
133
+ }],
134
+ height: '100%',
135
+ axisLabelRender: this.axisLabelRender.bind(this),
136
+ palettes: [
137
+ this._session.getAccent(), this._session.getPrimery()
138
+ ]
139
+ }, this._elementRef.nativeElement);
140
+ }
141
+ axisLabelRender(evt) {
142
+ if (evt.axis.name === 'primaryYAxis')
143
+ evt.text = dayjs.duration(evt.value, 's').humanize(); // 'DD:HH:mm'
144
+ }
145
+ tooltipRender(evt) {
146
+ //evt.content = dayjs.duration(evt.range.end, 's').humanize();// 'DD:HH:mm'
147
+ if (evt.data.seriesIndex === 0) {
148
+ const [standardHigh, durationHigh, durationAvg, durationLow, standardLow] = evt.point.y;
149
+ evt.text = dayjs.duration(durationHigh, 's').format('DD:HH:mm');
150
+ if (standardHigh) {
151
+ const deviation = Math.round(this.data[evt.data.pointIndex].standardDev);
152
+ evt.text += ` ${deviation}%`;
153
+ }
154
+ }
155
+ else {
156
+ evt.headerText = this._translate.get('Average');
157
+ evt.text = dayjs.duration(evt.data.pointY, 's').format('DD:HH:mm');
158
+ }
159
+ }
160
+ ngOnDestroy() {
161
+ //this.gauge?.destroy();
162
+ this.chart?.destroy();
163
+ this._destroy.next();
164
+ }
165
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: RolesPerformanceComponent1, deps: [{ token: i0.ElementRef }, { token: i1.AccountService }, { token: i2.SessionService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
166
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: RolesPerformanceComponent1, selector: "ng-component", ngImport: i0, template: '', isInline: true, styles: [":host{flex:1}\n"] }); }
167
+ };
168
+ RolesPerformanceComponent1 = __decorate([
169
+ BizDoc({
170
+ selector: 'bizdoc-role-performance1'
171
+ })
172
+ ], RolesPerformanceComponent1);
173
+ export { RolesPerformanceComponent1 };
174
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: RolesPerformanceComponent1, decorators: [{
175
+ type: Component,
176
+ args: [{ template: '', styles: [":host{flex:1}\n"] }]
177
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.AccountService }, { type: i2.SessionService }, { type: i3.TranslateService }] });
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role-performance1.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/reports/cube/role-performance1.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnDestroy } from '@angular/core';\r\nimport { Subject, startWith, takeUntil } from 'rxjs';\r\n/// <reference path=\"./node_modules/dayjs/plugin/duration.d.ts\" />\r\nimport dayjs from 'dayjs';\r\nimport { BizDoc } from '../../core/decorators';\r\nimport { ReportComponent } from '../../core/base';\r\nimport { AccountService } from '../../core/account.service';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { AxesMap, UserInfo } from '../../core/models';\r\nimport { TranslateService } from '../../core/translate.service';\r\nimport { FONT_FAMILY } from '../../core/colors';\r\n//import { CircularGauge, GaugeTheme, IAxisLabelRenderEventArgs, ITooltipRenderEventArgs, LegendSettingsModel, RangeModel, TooltipSettingsModel } from '@syncfusion/ej2-angular-circulargauge';\r\nimport { Chart, IAxisLabelRenderEventArgs, ITooltipRenderEventArgs } from '@syncfusion/ej2-angular-charts';\r\n\r\n@Component({\r\n  template: '',\r\n  styles: `:host {flex: 1}`\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-role-performance1'\r\n})\r\nexport class RolesPerformanceComponent1 implements ReportComponent<Model>, OnDestroy {\r\n  //theme: GaugeTheme;\r\n  //gauge: CircularGauge;\r\n  durationAvg: number;\r\n  stdAvg: number;\r\n  maxStd: number;\r\n  minStd: number;\r\n  minDuration: number;\r\n  maxDuration: number;\r\n  data: Item[];\r\n  readonly titleStyle = {\r\n    fontFamily: FONT_FAMILY\r\n  };\r\n  private readonly _destroy = new Subject<void>();\r\n  //readonly legendSettings: LegendSettingsModel = {};\r\n  //readonly tooltip: TooltipSettingsModel = {};\r\n  chart: Chart;\r\n  constructor(\r\n    private _elementRef: ElementRef<HTMLDivElement>,\r\n    private _accounts: AccountService,\r\n    private _session: SessionService,\r\n    private _translate: TranslateService,\r\n    //  private _reportRef: ReportRef<PerformanceSettingsModel>\r\n  ) {\r\n    _session.themeChange.pipe(takeUntil(this._destroy), startWith(_session.theme)).subscribe(t => {\r\n      //this.theme = t.dark ? 'Material3Dark' : 'Material3';\r\n      //this.gauge && this._draw();\r\n      this.chart && this._draw();\r\n    })\r\n  }\r\n  onBind(data: Model[]) {\r\n    //this.gauge?.destroy();\r\n    this.chart?.destroy();\r\n    if (!data.length) return;\r\n    let accumStd = 0, countStd = 0, accumDuration = 0;\r\n    this.maxStd = 0, this.minStd = 0, this.maxDuration = 0, this.minDuration = data[0].durationLow;\r\n    data.forEach(e => {\r\n      if (e.standardAvg) {\r\n        if (e.standardHigh > this.maxStd)\r\n          this.maxStd = e.standardHigh;\r\n        if (e.standardLow < this.minStd || this.minStd === 0)\r\n          this.minStd = e.standardLow;\r\n        countStd++;\r\n        accumStd += e.standardAvg;\r\n      }\r\n      accumDuration += e.durationAvg;\r\n      if (e.durationHigh > this.maxDuration)\r\n        this.maxDuration = e.durationHigh;\r\n      if (e.durationLow < this.minDuration)\r\n        this.minDuration = e.durationLow;\r\n    });\r\n    this.stdAvg = countStd ? accumStd / countStd : 0,\r\n      this.durationAvg = accumDuration / data.length;\r\n    this._accounts.getAll(data.map(e => e.userId)).\r\n      subscribe(users => {\r\n        this.data = data.map((d, i) => {\r\n          const durationDev = d.durationAvg / this.durationAvg,\r\n            standardDev = this.stdAvg ? d.durationAvg / this.stdAvg : 0;\r\n\r\n          return ({\r\n            durationDev,\r\n            standardDev,\r\n            ...d,\r\n            name: users[i].name,\r\n            values: [d.standardHigh, d.durationHigh, d.durationAvg, d.durationLow, d.standardLow]\r\n          });\r\n        });\r\n        this._draw();\r\n      });\r\n  }\r\n  private _draw() {\r\n    this.chart?.destroy();\r\n    //const colors = this._session.accentPalette;\r\n    //this.gauge?.destroy();\r\n    //this.gauge = new CircularGauge({\r\n    //  theme: this.theme,\r\n    //  title: this._translate.get('AverageValue', dayjs.duration(this.durationAvg, 'seconds').format('DD:HH:mm')),\r\n    //  titleStyle: this.titleStyle,\r\n    //  tooltip: this.tooltip,\r\n    //  axes: [{\r\n    //    startAngle: 270,\r\n    //    endAngle: 90,\r\n    //    pointers: [{\r\n    //      text: this._translate.get('Standard'),\r\n    //      color: this._session.getPrimery(),\r\n    //      value: this.stdAvg\r\n    //    }],\r\n    //    ranges: this.data.map((e, i) => ({\r\n    //      legendText: e.name,\r\n    //      radius: `${100 - i * 5}%`,\r\n    //      startWidth: 3,\r\n    //      endWidth: 3,\r\n    //      start: this.minDuration,\r\n    //      end: this.stdAvg ? Math.floor(e.durationAvg / this.stdAvg) : Math.floor(e.durationAvg / this.durationAvg),\r\n    //      color: colors[Math.floor((i + 9) / i)]\r\n    //    } as RangeModel))\r\n    //  }],\r\n    //  tooltipRender: this.tooltipRender.bind(this),\r\n    //  legendSettings: this.legendSettings,\r\n    //  enableRtl: this._session.inverse,\r\n    //  height: '100%',\r\n    //},\r\n    //  this._elementRef.nativeElement);\r\n    this.chart = new Chart({\r\n      primaryYAxis: {\r\n        stripLines: [{\r\n          text: this._translate.get('Standard'),\r\n          textStyle: {\r\n            fontFamily: FONT_FAMILY,\r\n          },\r\n          opacity: .8,\r\n          start: this.minStd,\r\n          end: this.maxStd,\r\n        }]\r\n      },\r\n      primaryXAxis: {\r\n        valueType: 'Category'\r\n      },\r\n      tooltip: { enable: true },\r\n      tooltipRender: this.tooltipRender.bind(this),\r\n      series: [{\r\n        type: 'BoxAndWhisker',\r\n        dataSource: this.data,\r\n        boxPlotMode: 'Normal',\r\n        enableTooltip: true,\r\n        xName: 'name',\r\n        yName: 'values'\r\n      }, {\r\n        type: 'Spline',\r\n        dataSource: this.data,\r\n        xName: 'name',\r\n        width: 3,\r\n        dashArray: '3 2',\r\n        yName: 'durationAvg',\r\n      }],\r\n      height: '100%',\r\n      axisLabelRender: this.axisLabelRender.bind(this),\r\n      palettes: [\r\n        this._session.getAccent(), this._session.getPrimery()]\r\n    },\r\n      this._elementRef.nativeElement);\r\n  }\r\n  axisLabelRender(evt: IAxisLabelRenderEventArgs) {\r\n    if (evt.axis.name === 'primaryYAxis')\r\n      evt.text = dayjs.duration(evt.value, 's').humanize();// 'DD:HH:mm'\r\n  }\r\n  tooltipRender(evt: ITooltipRenderEventArgs) {\r\n    //evt.content = dayjs.duration(evt.range.end, 's').humanize();// 'DD:HH:mm'\r\n    if (evt.data.seriesIndex === 0) {\r\n      const [standardHigh, durationHigh, durationAvg, durationLow, standardLow] = evt.point.y as number[];\r\n      evt.text = dayjs.duration(durationHigh, 's').format('DD:HH:mm');\r\n      if (standardHigh) {\r\n        const deviation = Math.round(this.data[evt.data.pointIndex].standardDev);\r\n        evt.text += ` ${deviation}%`\r\n      }\r\n    }\r\n    else {\r\n      evt.headerText = this._translate.get('Average');\r\n      evt.text = dayjs.duration(evt.data.pointY as any, 's').format('DD:HH:mm');\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    //this.gauge?.destroy();\r\n    this.chart?.destroy();\r\n    this._destroy.next();\r\n  }\r\n}\r\n\r\ninterface Model {\r\n  userId: string;\r\n  standardAvg: number;\r\n  standardHigh: number;\r\n  standardLow: number;\r\n  durationAvg: number;\r\n  durationHigh: number;\r\n  durationLow: number;\r\n}\r\ntype Item = Model & {\r\n  standardDev?: number;\r\n  durationDev: number;\r\n  name: string;\r\n  values: number[]\r\n};\r\ninterface PerformanceSettingsModel {\r\n  cube?: string;\r\n  filters?: AxesMap;\r\n}\r\n"]}
@@ -1,6 +1,6 @@
1
1
  import { Component, ViewChild, ViewContainerRef, Injector, HostListener, Input } from '@angular/core';
2
2
  import { BehaviorSubject, firstValueFrom, Subject } from 'rxjs';
3
- import { debounceTime, takeUntil, filter, tap } from 'rxjs/operators';
3
+ import { debounceTime, takeUntil, filter } from 'rxjs/operators';
4
4
  import { Workbook } from '@syncfusion/ej2-excel-export';
5
5
  import { ReportRef } from './report-ref';
6
6
  import { TableViewComponent } from './table/table-view.component';
@@ -69,14 +69,18 @@ export class ReportViewerComponent {
69
69
  /** */
70
70
  execute() {
71
71
  this.progress = 0;
72
- return firstValueFrom(this._http.post(`/api/report/${encodeURIComponent(this.report.name)}`, this.args).
73
- pipe(tap({
72
+ return new Promise((resolve, reject) => this._http.post(`/api/report/${encodeURIComponent(this.report.name)}`, this.args).
73
+ subscribe({
74
74
  next: r => {
75
75
  this._instance.onBind(r, this.args);
76
76
  this._data = r;
77
- }, error: () => this._sb.error(),
77
+ resolve();
78
+ }, error: () => {
79
+ this._sb.error();
80
+ reject();
81
+ },
78
82
  complete: () => this.progress = -1
79
- })));
83
+ }));
80
84
  }
81
85
  explore(item) {
82
86
  const args = {};
@@ -152,4 +156,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImpor
152
156
  type: HostListener,
153
157
  args: ['window:resize']
154
158
  }] } });
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-viewer.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/reports/report-viewer.component.ts","../../../../../libraries/core/src/lib/reports/report-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, OnDestroy, ViewContainerRef, Injector, HostListener, Input, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { BehaviorSubject, firstValueFrom, Subject } from 'rxjs';\r\nimport { debounceTime, takeUntil, filter, tap } from 'rxjs/operators';\r\nimport { Workbook, Worksheet, Row, Column } from '@syncfusion/ej2-excel-export';\r\nimport { ReportComponent } from '../core/base';\r\nimport { Report } from '../core/models';\r\nimport { ParamMap } from '../core/configuration';\r\nimport { ReportRef, ExportEventArgs } from './report-ref';\r\nimport { HubService } from '../core/hub.service';\r\nimport { PromptService } from '../core/prompt.service';\r\nimport { TranslateService } from '../core/translate.service';\r\nimport { SessionService } from '../core/session.service';\r\nimport { BizDocComponentFactoryResolver } from '../core/component-factory-resolver';\r\nimport { TableViewComponent } from './table/table-view.component';\r\n\r\n@Component({\r\n  selector: 'bizdoc-report-viewer',\r\n  templateUrl: './report-viewer.component.html',\r\n  styleUrls: ['./report-viewer.component.scss']\r\n})\r\n/** reportviewer component*/\r\nexport class ReportViewerComponent implements OnChanges, OnDestroy {\r\n  @Input() report!: Report;\r\n  @Input() args: ParamMap;\r\n  progress = -1;\r\n  public get reportRef(): ReportRef {\r\n    return this._reportRef;\r\n  }\r\n  @ViewChild('vc', { static: true, read: ViewContainerRef }) viewContainer: ViewContainerRef;\r\n  @ViewChild(TableViewComponent) table: TableViewComponent;\r\n  private _data: any[];\r\n  private _instance: ReportComponent<any, any>;\r\n  private _reportRef: ReportRef;\r\n  private readonly _resizing = new BehaviorSubject({});\r\n  private readonly _destroy = new Subject<void>();\r\n  /** reportviewer ctor */\r\n  constructor(\r\n    private _http: HttpClient,\r\n    private _sb: PromptService,\r\n    private _injector: Injector,\r\n    private _hub: HubService,\r\n    private _translate: TranslateService,\r\n    private _session: SessionService,\r\n    private _factoryResolver: BizDocComponentFactoryResolver) {\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['report']) {\r\n      this._destroy.next();\r\n      this._reportRef && this._reportRef._destroy();\r\n      this._reportRef = new ReportRef(this.report, this.args, this._hub, this._dim());\r\n      if (this.report.template)\r\n        this._createView();\r\n      else\r\n        this._instance = this.table;\r\n      // listen to progress\r\n      this._hub.reportProgress$.\r\n        pipe(filter(e =>\r\n          e.name === this.report.name),\r\n          takeUntil(this._destroy),\r\n          debounceTime(50)).\r\n        subscribe(i => {\r\n          if (this.progress > 0) this.progress = i.progress;\r\n        });\r\n      this._resizing.pipe(debounceTime(150)).subscribe(() => this._reportRef._resize.next(this._dim()));\r\n    }\r\n    if (changes['args'])\r\n      this._reportRef._args.next(this.args);\r\n  }\r\n  /** */\r\n  private _createView() {\r\n    const component = this._factoryResolver.component(this.report.template);\r\n    this.viewContainer.clear();\r\n    const injector = Injector.create({ providers: [{ provide: ReportRef, useValue: this._reportRef }], parent: this._injector });\r\n    const componentRef = this.viewContainer.createComponent(component, { injector });\r\n\r\n    this._instance = componentRef.instance as ReportComponent<any, any>;\r\n  }\r\n  @HostListener('window:resize')\r\n  resize() {\r\n    this._resizing.next({});\r\n  }\r\n  private _dim(): { height: number; width: number } {\r\n    const { width, height } = (this.viewContainer.element.nativeElement as HTMLDivElement).parentElement.getBoundingClientRect();\r\n    return { width: Math.floor(width - 2), height: Math.floor(height) };\r\n  }\r\n  /** */\r\n  execute() {\r\n    this.progress = 0;\r\n    return firstValueFrom(this._http.post<any[]>(`/api/report/${encodeURIComponent(this.report.name)}`, this.args).\r\n      pipe(tap({\r\n        next: r => {\r\n          this._instance.onBind(r, this.args);\r\n          this._data = r;\r\n        }, error: () =>\r\n          this._sb.error()\r\n        , complete: () =>\r\n          this.progress = -1\r\n      })))\r\n  }\r\n\r\n  explore(item: any) {\r\n    const args = {};\r\n    const keys = this.report.fields.filter(c => c.flags?.indexOf('Key') > -1);\r\n    if (keys.length === 0)\r\n      throw `report ${this.report.name} item model missing key attribute`;\r\n    keys.forEach(f => args[f.name] = item[f.name]);\r\n    return firstValueFrom(this._http.put<any[]>(`/api/report/${encodeURIComponent(this.report.name)}`, args));\r\n  }\r\n\r\n  /** */\r\n  exportExcel() {\r\n    const args = {\r\n      data: this._data.map(r => { return { ...r } }),\r\n      args: this.args\r\n    } as ExportEventArgs;\r\n    this._reportRef._exporting.next(args);\r\n    if (args.cancel) return;\r\n    const rows = [{\r\n      index: 1,\r\n      cells: this.report.columns.map((c, j) => ({\r\n        index: j + 1, value: c.label || c.name,\r\n        style: {\r\n          bold: true,\r\n          hAlign: c.controlType === 'number' ? 'right' : 'general'\r\n        }\r\n      } as Cell))\r\n    }] as Row[];\r\n    args.data.forEach((r, i) => rows.push(\r\n      {\r\n        index: i + 2,\r\n        cells: this.report.columns.map((c, j) => ({\r\n          index: j + 1, value: r[c.name],\r\n          style: {\r\n            hAlign: c.controlType === 'number' ? 'right' : 'general'\r\n          }\r\n        }))\r\n      } as Row));\r\n    const book = new Workbook(\r\n      {\r\n        worksheets: [\r\n          {\r\n            enableRtl: this._session.inverse,\r\n            name: this._translate.get('SheetN', 1),\r\n            columns: this.report.columns.map((_, i) => ({ index: i + 1, width: 250 } as Column)),\r\n            rows\r\n          } as Worksheet\r\n        ],\r\n      },\r\n      'xlsx'\r\n    );\r\n    book.save(`${this.report.title}.xlsx`);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._reportRef._destroy();\r\n    this._resizing.complete();\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\ninterface Cell { }\r\n","<mat-progress-bar [mode]=\"progress === 0 ? 'query' : 'buffer'\" [value]=progress [bufferValue]=0 [style.visibility]=\"progress > -1 ? 'visible':'hidden'\"></mat-progress-bar>\r\n<ng-container #vc></ng-container>\r\n"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"report-viewer.component.js","sourceRoot":"","sources":["../../../../../libraries/core/src/lib/reports/report-viewer.component.ts","../../../../../libraries/core/src/lib/reports/report-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, OnDestroy, ViewContainerRef, Injector, HostListener, Input, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { BehaviorSubject, firstValueFrom, Subject } from 'rxjs';\r\nimport { debounceTime, takeUntil, filter, tap } from 'rxjs/operators';\r\nimport { Workbook, Worksheet, Row, Column } from '@syncfusion/ej2-excel-export';\r\nimport { ReportComponent } from '../core/base';\r\nimport { Report } from '../core/models';\r\nimport { ParamMap } from '../core/configuration';\r\nimport { ReportRef, ExportEventArgs } from './report-ref';\r\nimport { HubService } from '../core/hub.service';\r\nimport { PromptService } from '../core/prompt.service';\r\nimport { TranslateService } from '../core/translate.service';\r\nimport { SessionService } from '../core/session.service';\r\nimport { BizDocComponentFactoryResolver } from '../core/component-factory-resolver';\r\nimport { TableViewComponent } from './table/table-view.component';\r\n\r\n@Component({\r\n  selector: 'bizdoc-report-viewer',\r\n  templateUrl: './report-viewer.component.html',\r\n  styleUrls: ['./report-viewer.component.scss']\r\n})\r\n/** reportviewer component*/\r\nexport class ReportViewerComponent implements OnChanges, OnDestroy {\r\n  @Input() report!: Report;\r\n  @Input() args: ParamMap;\r\n  progress = -1;\r\n  public get reportRef(): ReportRef {\r\n    return this._reportRef;\r\n  }\r\n  @ViewChild('vc', { static: true, read: ViewContainerRef }) viewContainer: ViewContainerRef;\r\n  @ViewChild(TableViewComponent) table: TableViewComponent;\r\n  private _data: any[];\r\n  private _instance: ReportComponent<any, any>;\r\n  private _reportRef: ReportRef;\r\n  private readonly _resizing = new BehaviorSubject({});\r\n  private readonly _destroy = new Subject<void>();\r\n  /** reportviewer ctor */\r\n  constructor(\r\n    private _http: HttpClient,\r\n    private _sb: PromptService,\r\n    private _injector: Injector,\r\n    private _hub: HubService,\r\n    private _translate: TranslateService,\r\n    private _session: SessionService,\r\n    private _factoryResolver: BizDocComponentFactoryResolver) {\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['report']) {\r\n      this._destroy.next();\r\n      this._reportRef && this._reportRef._destroy();\r\n      this._reportRef = new ReportRef(this.report, this.args, this._hub, this._dim());\r\n      if (this.report.template)\r\n        this._createView();\r\n      else\r\n        this._instance = this.table;\r\n      // listen to progress\r\n      this._hub.reportProgress$.\r\n        pipe(filter(e =>\r\n          e.name === this.report.name),\r\n          takeUntil(this._destroy),\r\n          debounceTime(50)).\r\n        subscribe(i => {\r\n          if (this.progress > 0) this.progress = i.progress;\r\n        });\r\n      this._resizing.pipe(debounceTime(150)).subscribe(() => this._reportRef._resize.next(this._dim()));\r\n    }\r\n    if (changes['args'])\r\n      this._reportRef._args.next(this.args);\r\n  }\r\n  /** */\r\n  private _createView() {\r\n    const component = this._factoryResolver.component(this.report.template);\r\n    this.viewContainer.clear();\r\n    const injector = Injector.create({ providers: [{ provide: ReportRef, useValue: this._reportRef }], parent: this._injector });\r\n    const componentRef = this.viewContainer.createComponent(component, { injector });\r\n\r\n    this._instance = componentRef.instance as ReportComponent<any, any>;\r\n  }\r\n  @HostListener('window:resize')\r\n  resize() {\r\n    this._resizing.next({});\r\n  }\r\n  private _dim(): { height: number; width: number } {\r\n    const { width, height } = (this.viewContainer.element.nativeElement as HTMLDivElement).parentElement.getBoundingClientRect();\r\n    return { width: Math.floor(width - 2), height: Math.floor(height) };\r\n  }\r\n  /** */\r\n  execute() {\r\n    this.progress = 0;\r\n    return new Promise<void>((resolve, reject) =>\r\n      this._http.post<any[]>(`/api/report/${encodeURIComponent(this.report.name)}`, this.args).\r\n        subscribe({\r\n          next: r => {\r\n            this._instance.onBind(r, this.args);\r\n            this._data = r;\r\n            resolve();\r\n          }, error: () => {\r\n            this._sb.error();\r\n            reject();\r\n          }\r\n          , complete: () =>\r\n            this.progress = -1\r\n        }));\r\n  }\r\n\r\n  explore(item: any) {\r\n    const args = {};\r\n    const keys = this.report.fields.filter(c => c.flags?.indexOf('Key') > -1);\r\n    if (keys.length === 0)\r\n      throw `report ${this.report.name} item model missing key attribute`;\r\n    keys.forEach(f => args[f.name] = item[f.name]);\r\n    return firstValueFrom(this._http.put<any[]>(`/api/report/${encodeURIComponent(this.report.name)}`, args));\r\n  }\r\n\r\n  /** */\r\n  exportExcel() {\r\n    const args = {\r\n      data: this._data.map(r => { return { ...r } }),\r\n      args: this.args\r\n    } as ExportEventArgs;\r\n    this._reportRef._exporting.next(args);\r\n    if (args.cancel) return;\r\n    const rows = [{\r\n      index: 1,\r\n      cells: this.report.columns.map((c, j) => ({\r\n        index: j + 1, value: c.label || c.name,\r\n        style: {\r\n          bold: true,\r\n          hAlign: c.controlType === 'number' ? 'right' : 'general'\r\n        }\r\n      } as Cell))\r\n    }] as Row[];\r\n    args.data.forEach((r, i) => rows.push(\r\n      {\r\n        index: i + 2,\r\n        cells: this.report.columns.map((c, j) => ({\r\n          index: j + 1, value: r[c.name],\r\n          style: {\r\n            hAlign: c.controlType === 'number' ? 'right' : 'general'\r\n          }\r\n        }))\r\n      } as Row));\r\n    const book = new Workbook(\r\n      {\r\n        worksheets: [\r\n          {\r\n            enableRtl: this._session.inverse,\r\n            name: this._translate.get('SheetN', 1),\r\n            columns: this.report.columns.map((_, i) => ({ index: i + 1, width: 250 } as Column)),\r\n            rows\r\n          } as Worksheet\r\n        ],\r\n      },\r\n      'xlsx'\r\n    );\r\n    book.save(`${this.report.title}.xlsx`);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._reportRef._destroy();\r\n    this._resizing.complete();\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\ninterface Cell { }\r\n","<mat-progress-bar [mode]=\"progress === 0 ? 'query' : 'buffer'\" [value]=progress [bufferValue]=0 [style.visibility]=\"progress > -1 ? 'visible':'hidden'\"></mat-progress-bar>\r\n<ng-container #vc></ng-container>\r\n"]}