@provoly/dashboard 1.2.0 → 1.2.1
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.
- package/components/sinceDate/sinceDate.pipe.d.ts +2 -0
- package/esm2022/components/sinceDate/sinceDate.pipe.mjs +27 -10
- package/esm2022/lib/core/i18n/en.translations.mjs +3 -2
- package/esm2022/lib/core/i18n/fr.translations.mjs +3 -2
- package/esm2022/lib/core/model/widget-analytic-manifest.interface.mjs +1 -1
- package/esm2022/widgets/widget-analytic/component/widget-analytic.component.mjs +88 -14
- package/esm2022/widgets/widget-analytic/i18n/en.translations.mjs +7 -2
- package/esm2022/widgets/widget-analytic/i18n/fr.translations.mjs +7 -2
- package/esm2022/widgets/widget-analytic/style/css.component.mjs +2 -2
- package/esm2022/widgets/widget-analytic/widget-analytic.module.mjs +12 -8
- package/fesm2022/provoly-dashboard-components-sinceDate.mjs +26 -9
- package/fesm2022/provoly-dashboard-components-sinceDate.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-analytic.mjs +112 -24
- package/fesm2022/provoly-dashboard-widgets-widget-analytic.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +4 -2
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/i18n/en.translations.d.ts +2 -1
- package/lib/core/i18n/fr.translations.d.ts +2 -1
- package/lib/core/model/widget-analytic-manifest.interface.d.ts +8 -1
- package/package.json +1 -1
- package/widgets/widget-analytic/component/widget-analytic.component.d.ts +18 -0
- package/widgets/widget-analytic/i18n/en.translations.d.ts +5 -0
- package/widgets/widget-analytic/i18n/fr.translations.d.ts +5 -0
- package/widgets/widget-analytic/style/_o-widget-analytic.scss +48 -0
- package/widgets/widget-analytic/widget-analytic.module.d.ts +3 -2
|
@@ -1,16 +1,35 @@
|
|
|
1
1
|
import { Component } from '@angular/core';
|
|
2
2
|
import { ClassSelectors, DataWidgetComponent, WIDGET_HEADER_HEIGHT } from '@provoly/dashboard';
|
|
3
|
-
import { combineLatest, map } from 'rxjs';
|
|
3
|
+
import { combineLatest, map, startWith } from 'rxjs';
|
|
4
|
+
import { filter } from 'rxjs/operators';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@ngrx/store";
|
|
6
7
|
import * as i2 from "@angular/common";
|
|
7
8
|
import * as i3 from "@angular/forms";
|
|
8
9
|
import * as i4 from "@provoly/dashboard";
|
|
9
|
-
import * as i5 from "
|
|
10
|
+
import * as i5 from "@provoly/dashboard/components/checkbox";
|
|
11
|
+
import * as i6 from "@provoly/dashboard/components/color-picker";
|
|
12
|
+
import * as i7 from "@angular/cdk/drag-drop";
|
|
13
|
+
import * as i8 from "../style/css.component";
|
|
10
14
|
export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
11
15
|
change($event, prop) {
|
|
12
16
|
this.optionsCopy[prop] = $event;
|
|
13
17
|
}
|
|
18
|
+
changeColorConfig($event, prop) {
|
|
19
|
+
switch (prop) {
|
|
20
|
+
case 'prop': {
|
|
21
|
+
this.optionsCopy.colorConfig.prop = $event;
|
|
22
|
+
break;
|
|
23
|
+
}
|
|
24
|
+
case 'colors': {
|
|
25
|
+
this.optionsCopy.colorConfig.colors = $event;
|
|
26
|
+
break;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
changeFormat($event, prop = 'suffix') {
|
|
31
|
+
this.optionsCopy.format.suffix = $event;
|
|
32
|
+
}
|
|
14
33
|
constructor(store, el) {
|
|
15
34
|
super(store, el);
|
|
16
35
|
this.optionsCopy = { primaryProp: '', secondaryProp: '', verticalProp: '', valueProp: '' };
|
|
@@ -20,16 +39,16 @@ export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
|
20
39
|
this.subscriptions.add(this.options$.subscribe((options) => {
|
|
21
40
|
this.optionsCopy = JSON.parse(JSON.stringify(options));
|
|
22
41
|
}));
|
|
23
|
-
this.primaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.primaryProp)));
|
|
24
|
-
this.secondaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.secondaryProp, 1)));
|
|
25
|
-
this.verticalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 1)));
|
|
42
|
+
this.primaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(filter(([options]) => !!options.primaryProp), map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.primaryProp)));
|
|
43
|
+
this.secondaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(filter(([options]) => !!options.secondaryProp), map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.secondaryProp, 1)));
|
|
44
|
+
this.verticalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(filter(([options]) => !!options.verticalProp), map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 1)));
|
|
26
45
|
this.totalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 2)));
|
|
27
46
|
this.grandTotalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 3)));
|
|
28
47
|
this.lines$ = combineLatest([
|
|
29
48
|
this.options$,
|
|
30
|
-
this.primaryProperty
|
|
31
|
-
this.secondaryProperty
|
|
32
|
-
this.verticalProperty
|
|
49
|
+
this.primaryProperty$.pipe(startWith([])),
|
|
50
|
+
this.secondaryProperty$.pipe(startWith(undefined)),
|
|
51
|
+
this.verticalProperty$.pipe(startWith([])),
|
|
33
52
|
this.resultSet$
|
|
34
53
|
]).pipe(map(([options, primaryProps, secondaryProps, verticalProps, rs]) => this.createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, 1)));
|
|
35
54
|
this.totals$ = combineLatest([
|
|
@@ -45,6 +64,12 @@ export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
|
45
64
|
this.grandTotalProperty$,
|
|
46
65
|
this.resultSet$
|
|
47
66
|
]).pipe(map(([options, primaryProps, verticalProps, rs]) => this.createValueMap(verticalProps, primaryProps, undefined, rs, options, 3)));
|
|
67
|
+
this.colorMap$ = combineLatest([
|
|
68
|
+
this.options$,
|
|
69
|
+
this.resultSet$,
|
|
70
|
+
this.verticalProperty$,
|
|
71
|
+
this.primaryProperty$
|
|
72
|
+
]).pipe(filter(([options]) => !!options.colorConfig), map(([options, rs, vertical, primary]) => this.createColorMap(vertical, primary, rs, options)));
|
|
48
73
|
this.availableProperties$ = combineLatest([this.classes$, this.resultSet$]).pipe(map(([classes, rs]) => {
|
|
49
74
|
const presentClassesId = Object.keys(rs.items);
|
|
50
75
|
const presentClasses = presentClassesId
|
|
@@ -54,7 +79,7 @@ export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
|
54
79
|
}));
|
|
55
80
|
}
|
|
56
81
|
matchAttributeValue(item, prop, comparisonValue) {
|
|
57
|
-
return comparisonValue ? item.attributes[prop].value == comparisonValue : true;
|
|
82
|
+
return comparisonValue && prop ? item.attributes[prop].value == comparisonValue : true;
|
|
58
83
|
}
|
|
59
84
|
createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, level) {
|
|
60
85
|
return verticalProps.map((vertical) => {
|
|
@@ -73,7 +98,7 @@ export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
|
73
98
|
value[primary][secondary] = matchingItem.attributes[options.valueProp].value;
|
|
74
99
|
}
|
|
75
100
|
else {
|
|
76
|
-
value[primary] = matchingItem.attributes[options.valueProp]
|
|
101
|
+
value[primary] = matchingItem.attributes[options.valueProp]?.value;
|
|
77
102
|
}
|
|
78
103
|
}
|
|
79
104
|
});
|
|
@@ -84,7 +109,7 @@ export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
|
84
109
|
getPropertyLabelsForLevel(rs, property, level) {
|
|
85
110
|
const values = Object.values(rs.items)
|
|
86
111
|
.map((items) => items
|
|
87
|
-
.filter((item) => level
|
|
112
|
+
.filter((item) => level && 'level' in item.attributes
|
|
88
113
|
? [level, '' + level].includes(item.attributes['level'].value)
|
|
89
114
|
: true)
|
|
90
115
|
.map((item) => item.attributes[property].value + ''))
|
|
@@ -92,6 +117,55 @@ export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
|
92
117
|
.flat();
|
|
93
118
|
return [...new Set(values)];
|
|
94
119
|
}
|
|
120
|
+
createColorMap(verticalProps, primaryProps, rs, options) {
|
|
121
|
+
return options.colorConfig
|
|
122
|
+
? Object.fromEntries(verticalProps.map((vertical) => [
|
|
123
|
+
vertical,
|
|
124
|
+
Object.fromEntries(primaryProps.map((primary) => {
|
|
125
|
+
const matchingItem = (rs.items[Object.keys(rs.items)[0]] ?? []).find((item) => this.matchAttributeValue(item, options.primaryProp, primary) &&
|
|
126
|
+
this.matchAttributeValue(item, options.verticalProp, vertical));
|
|
127
|
+
return [
|
|
128
|
+
primary,
|
|
129
|
+
matchingItem && matchingItem.attributes[options.valueProp].value !== 0
|
|
130
|
+
? options.colorConfig?.colors[matchingItem.attributes[options.colorConfig.prop].value -
|
|
131
|
+
1]
|
|
132
|
+
: '#FFFFFF'
|
|
133
|
+
];
|
|
134
|
+
}))
|
|
135
|
+
]))
|
|
136
|
+
: {};
|
|
137
|
+
}
|
|
138
|
+
toggleColorConfig($event) {
|
|
139
|
+
if ($event !== !!this.optionsCopy.colorConfig) {
|
|
140
|
+
if (!this.optionsCopy.colorConfig) {
|
|
141
|
+
this.optionsCopy.colorConfig = { prop: '', colors: [] };
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
this.optionsCopy.colorConfig = undefined;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
toggleFormat($event) {
|
|
149
|
+
if ($event !== !!this.optionsCopy.format) {
|
|
150
|
+
if (!this.optionsCopy.format) {
|
|
151
|
+
this.optionsCopy.format = { suffix: '' };
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
this.optionsCopy.format = undefined;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
modifyColorScheme($event, index) {
|
|
159
|
+
$event && index !== undefined
|
|
160
|
+
? (this.optionsCopy.colorConfig.colors[index] = $event)
|
|
161
|
+
: this.optionsCopy.colorConfig.colors.push('#FFFFFF');
|
|
162
|
+
}
|
|
163
|
+
removeColor(index) {
|
|
164
|
+
this.optionsCopy.colorConfig.colors.splice(index, 1);
|
|
165
|
+
}
|
|
166
|
+
drop(event) {
|
|
167
|
+
this.optionsCopy.colorConfig.colors.splice(event.currentIndex, 0, this.optionsCopy.colorConfig.colors.splice(event.previousIndex, 1)[0]);
|
|
168
|
+
}
|
|
95
169
|
emitManifest() {
|
|
96
170
|
this.manifestModified.emit({
|
|
97
171
|
widgetIndex: this.widgetIndex,
|
|
@@ -99,10 +173,10 @@ export class WidgetAnalyticComponent extends DataWidgetComponent {
|
|
|
99
173
|
});
|
|
100
174
|
}
|
|
101
175
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: WidgetAnalyticComponent, deps: [{ token: i1.Store }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
102
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: WidgetAnalyticComponent, selector: "pry-widget-analytic", usesInheritance: true, ngImport: i0, template: "<pry-widget-analytic-css></pry-widget-analytic-css>\n<div class=\"o-widget o-widget__analytic\">\n <pry-widget-header\n *ngIf=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [manifest]=\"manifest\"\n (manifestModified)=\"manifestModified.emit($event)\"\n #header\n [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n >\n <pry-settings\n (saveTriggered)=\"emitManifest()\"\n (changeTitle)=\"changeWidgetTitle($event)\"\n [headerPresent]=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [header]=\"header\"\n [open$]=\"open$\"\n class=\"o-settings\"\n >\n <div class=\"o-settings__fields\">\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"primaryProp\">{{ '@pry.widget.analytic.primaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'primaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.primaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"primaryProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"secondaryProp\">{{ '@pry.widget.analytic.secondaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'secondaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.secondaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"secondaryProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"verticalProp\">{{ '@pry.widget.analytic.verticalProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'verticalProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.verticalProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"verticalProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"valueProp\">{{ '@pry.widget.analytic.valueProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'valueProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.valueProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"valueProp\"\n ></pry-select>\n </div>\n </div>\n </pry-settings>\n </pry-widget-header>\n <div class=\"o-widget__analytic__table\">\n <table [style.height.px]=\"height$ | async\">\n <thead>\n <tr class=\"primary-header\">\n <th></th>\n @for (primary of primaryProperty$ | async; track primary) {\n <th [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n {{ primary }}\n </th>\n }\n </tr>\n <tr class=\"secondary-header\">\n <th></th>\n @for (primary of primaryProperty$ | async; track primary) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <th>{{ secondary }}</th>\n }\n }\n </tr>\n </thead>\n <tbody>\n @for (line of lines$ | async; track line.name) {\n <tr>\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <td>\n {{ line.value[primary][secondary] }}\n </td>\n }\n }\n </tr>\n }\n </tbody>\n <tfoot>\n @for (line of totals$ | async; track line.name) {\n <tr class=\"partial-total\">\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <td>\n {{ line.value[primary][secondary] }}\n </td>\n }\n }\n </tr>\n }\n @for (line of grandTotals$ | async; track line.name) {\n <tr class=\"grand-total\">\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n <td [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n {{ line.value[primary] }}\n </td>\n }\n </tr>\n }\n </tfoot>\n </table>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.SettingsComponent, selector: "pry-settings", inputs: ["widgetIndex", "isDisable", "headerPresent", "open$", "header"], outputs: ["triggerClick", "saveTriggered", "changeTitle"] }, { kind: "component", type: i4.PryWidgetHeaderComponent, selector: "pry-widget-header", inputs: ["manifest", "openData$", "additionalOptions", "headerOptions", "displayCount", "datasourceIds", "widgetIndex"], outputs: ["manifestModified"] }, { kind: "component", type: i4.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked"] }, { kind: "component", type: i5.PryWidgetAnalyticCssComponent, selector: "pry-widget-analytic-css" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
176
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: WidgetAnalyticComponent, selector: "pry-widget-analytic", usesInheritance: true, ngImport: i0, template: "<pry-widget-analytic-css></pry-widget-analytic-css>\n<div class=\"o-widget o-widget__analytic\">\n <pry-widget-header\n *ngIf=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [manifest]=\"manifest\"\n (manifestModified)=\"manifestModified.emit($event)\"\n #header\n [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n >\n <pry-settings\n (saveTriggered)=\"emitManifest()\"\n (changeTitle)=\"changeWidgetTitle($event)\"\n [headerPresent]=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [header]=\"header\"\n [open$]=\"open$\"\n class=\"o-settings\"\n >\n <div class=\"o-settings__fields\">\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"primaryProp\">{{ '@pry.widget.analytic.primaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'primaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.primaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"primaryProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"secondaryProp\">{{ '@pry.widget.analytic.secondaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'secondaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.secondaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"secondaryProp\"\n [clearable]=\"true\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"verticalProp\">{{ '@pry.widget.analytic.verticalProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'verticalProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.verticalProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"verticalProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"valueProp\">{{ '@pry.widget.analytic.valueProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'valueProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.valueProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"valueProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <pry-checkbox (ngModelChange)=\"toggleColorConfig($event)\" [ngModel]=\"!!optionsCopy.colorConfig\">\n {{ '@pry.widget.analytic.colorConfig' | i18n }}\n </pry-checkbox>\n @if (optionsCopy.colorConfig) {\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colorProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"changeColorConfig($event, 'prop')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.colorConfig.prop\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"colorProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colors' | i18n }}</label>\n <div\n class=\"o-widget__analytic__color-picker-container u-display-flex -align-center\"\n cdkDropList\n (cdkDropListDropped)=\"drop($event)\"\n cdkDropListOrientation=\"horizontal\"\n >\n @for (color of optionsCopy.colorConfig.colors; track color; let i = $index) {\n <div class=\"o-widget__analytic__color-picker\" cdkDrag>\n <pry-color-picker\n [ngModel]=\"color\"\n (ngModelChange)=\"modifyColorScheme($event, i)\"\n ></pry-color-picker>\n <button (click)=\"removeColor(i)\" class=\"o-widget__analytic__color-picker-remove\">\n <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n </button>\n <div *cdkDragPreview>\n <pry-color-picker [ngModel]=\"color\"></pry-color-picker>\n </div>\n </div>\n }\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-only o-widget__analytic__color-picker-add\"\n (click)=\"modifyColorScheme()\"\n >\n <pry-icon iconSvg=\"add\" [height]=\"20\" [width]=\"20\"></pry-icon>\n </button>\n </div>\n </div>\n }\n </div>\n <div class=\"m-form-label-field\">\n <pry-checkbox (ngModelChange)=\"toggleFormat($event)\" [ngModel]=\"!!optionsCopy.format\">\n {{ '@pry.widget.analytic.format' | i18n }}\n </pry-checkbox>\n @if (optionsCopy.format) {\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"format\">{{ '@pry.widget.analytic.suffix' | i18n }}</label>\n <input\n type=\"text\"\n class=\"a-form-field\"\n id=\"format\"\n [ngModel]=\"optionsCopy.format.suffix\"\n (ngModelChange)=\"changeFormat($event)\"\n />\n </div>\n }\n </div>\n </div>\n </pry-settings>\n </pry-widget-header>\n <div class=\"o-widget__analytic__table\">\n <table [style.height.px]=\"height$ | async\">\n <thead>\n <tr class=\"primary-header\">\n <th></th>\n @for (primary of primaryProperty$ | async; track primary) {\n <th [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n {{ primary }}\n </th>\n }\n </tr>\n @if (optionsCopy.secondaryProp) {\n <tr class=\"secondary-header\">\n <th></th>\n @for (primary of primaryProperty$ | async; track primary) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <th>{{ secondary }}</th>\n }\n }\n </tr>\n }\n </thead>\n <tbody>\n @for (line of lines$ | async; track line.name) {\n <tr>\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n @if (optionsCopy.secondaryProp) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <td\n [ngStyle]=\"\n optionsCopy.colorConfig ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] } : {}\n \"\n >\n {{ line.value[primary][secondary]\n }}{{ optionsCopy.format?.suffix ? ' ' + optionsCopy.format?.suffix : '' }}\n </td>\n }\n } @else {\n <td\n [ngStyle]=\"\n optionsCopy.colorConfig ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] } : {}\n \"\n >\n {{ line.value[primary] }}{{ optionsCopy.format?.suffix ? ' ' + optionsCopy.format?.suffix : '' }}\n </td>\n }\n }\n </tr>\n }\n </tbody>\n <tfoot>\n @for (line of totals$ | async; track line.name) {\n <tr class=\"partial-total\">\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <td>\n {{ line.value[primary][secondary] }}\n </td>\n }\n }\n </tr>\n }\n @for (line of grandTotals$ | async; track line.name) {\n <tr class=\"grand-total\">\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n <td [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n {{ line.value[primary] }}\n </td>\n }\n </tr>\n }\n </tfoot>\n </table>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.SettingsComponent, selector: "pry-settings", inputs: ["widgetIndex", "isDisable", "headerPresent", "open$", "header"], outputs: ["triggerClick", "saveTriggered", "changeTitle"] }, { kind: "component", type: i4.PryWidgetHeaderComponent, selector: "pry-widget-header", inputs: ["manifest", "openData$", "additionalOptions", "headerOptions", "displayCount", "datasourceIds", "widgetIndex"], outputs: ["manifestModified"] }, { kind: "component", type: i4.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i5.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "component", type: i6.PryColorPickerComponent, selector: "pry-color-picker" }, { kind: "directive", type: i7.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i7.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i7.CdkDragPreview, selector: "ng-template[cdkDragPreview]", inputs: ["data", "matchSize"] }, { kind: "component", type: i8.PryWidgetAnalyticCssComponent, selector: "pry-widget-analytic-css" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
103
177
|
}
|
|
104
178
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: WidgetAnalyticComponent, decorators: [{
|
|
105
179
|
type: Component,
|
|
106
|
-
args: [{ selector: 'pry-widget-analytic', template: "<pry-widget-analytic-css></pry-widget-analytic-css>\n<div class=\"o-widget o-widget__analytic\">\n <pry-widget-header\n *ngIf=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [manifest]=\"manifest\"\n (manifestModified)=\"manifestModified.emit($event)\"\n #header\n [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n >\n <pry-settings\n (saveTriggered)=\"emitManifest()\"\n (changeTitle)=\"changeWidgetTitle($event)\"\n [headerPresent]=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [header]=\"header\"\n [open$]=\"open$\"\n class=\"o-settings\"\n >\n <div class=\"o-settings__fields\">\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"primaryProp\">{{ '@pry.widget.analytic.primaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'primaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.primaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"primaryProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"secondaryProp\">{{ '@pry.widget.analytic.secondaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'secondaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.secondaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"secondaryProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"verticalProp\">{{ '@pry.widget.analytic.verticalProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'verticalProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.verticalProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"verticalProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"valueProp\">{{ '@pry.widget.analytic.valueProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'valueProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.valueProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"valueProp\"\n ></pry-select>\n </div>\n </div>\n </pry-settings>\n </pry-widget-header>\n <div class=\"o-widget__analytic__table\">\n <table [style.height.px]=\"height$ | async\">\n <thead>\n <tr class=\"primary-header\">\n <th></th>\n @for (primary of primaryProperty$ | async; track primary) {\n <th [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n {{ primary }}\n </th>\n }\n </tr>\n <tr class=\"secondary-header\">\n
|
|
180
|
+
args: [{ selector: 'pry-widget-analytic', template: "<pry-widget-analytic-css></pry-widget-analytic-css>\n<div class=\"o-widget o-widget__analytic\">\n <pry-widget-header\n *ngIf=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [manifest]=\"manifest\"\n (manifestModified)=\"manifestModified.emit($event)\"\n #header\n [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n >\n <pry-settings\n (saveTriggered)=\"emitManifest()\"\n (changeTitle)=\"changeWidgetTitle($event)\"\n [headerPresent]=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [header]=\"header\"\n [open$]=\"open$\"\n class=\"o-settings\"\n >\n <div class=\"o-settings__fields\">\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"primaryProp\">{{ '@pry.widget.analytic.primaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'primaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.primaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"primaryProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"secondaryProp\">{{ '@pry.widget.analytic.secondaryProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'secondaryProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.secondaryProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"secondaryProp\"\n [clearable]=\"true\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"verticalProp\">{{ '@pry.widget.analytic.verticalProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'verticalProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.verticalProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"verticalProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"valueProp\">{{ '@pry.widget.analytic.valueProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"change($event, 'valueProp')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.valueProp\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"valueProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <pry-checkbox (ngModelChange)=\"toggleColorConfig($event)\" [ngModel]=\"!!optionsCopy.colorConfig\">\n {{ '@pry.widget.analytic.colorConfig' | i18n }}\n </pry-checkbox>\n @if (optionsCopy.colorConfig) {\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colorProp' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"changeColorConfig($event, 'prop')\"\n [items]=\"availableProperties$ | async\"\n [ngModel]=\"optionsCopy.colorConfig.prop\"\n bindLabel=\"name\"\n bindValue=\"name\"\n id=\"colorProp\"\n ></pry-select>\n </div>\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colors' | i18n }}</label>\n <div\n class=\"o-widget__analytic__color-picker-container u-display-flex -align-center\"\n cdkDropList\n (cdkDropListDropped)=\"drop($event)\"\n cdkDropListOrientation=\"horizontal\"\n >\n @for (color of optionsCopy.colorConfig.colors; track color; let i = $index) {\n <div class=\"o-widget__analytic__color-picker\" cdkDrag>\n <pry-color-picker\n [ngModel]=\"color\"\n (ngModelChange)=\"modifyColorScheme($event, i)\"\n ></pry-color-picker>\n <button (click)=\"removeColor(i)\" class=\"o-widget__analytic__color-picker-remove\">\n <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n </button>\n <div *cdkDragPreview>\n <pry-color-picker [ngModel]=\"color\"></pry-color-picker>\n </div>\n </div>\n }\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-only o-widget__analytic__color-picker-add\"\n (click)=\"modifyColorScheme()\"\n >\n <pry-icon iconSvg=\"add\" [height]=\"20\" [width]=\"20\"></pry-icon>\n </button>\n </div>\n </div>\n }\n </div>\n <div class=\"m-form-label-field\">\n <pry-checkbox (ngModelChange)=\"toggleFormat($event)\" [ngModel]=\"!!optionsCopy.format\">\n {{ '@pry.widget.analytic.format' | i18n }}\n </pry-checkbox>\n @if (optionsCopy.format) {\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"format\">{{ '@pry.widget.analytic.suffix' | i18n }}</label>\n <input\n type=\"text\"\n class=\"a-form-field\"\n id=\"format\"\n [ngModel]=\"optionsCopy.format.suffix\"\n (ngModelChange)=\"changeFormat($event)\"\n />\n </div>\n }\n </div>\n </div>\n </pry-settings>\n </pry-widget-header>\n <div class=\"o-widget__analytic__table\">\n <table [style.height.px]=\"height$ | async\">\n <thead>\n <tr class=\"primary-header\">\n <th></th>\n @for (primary of primaryProperty$ | async; track primary) {\n <th [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n {{ primary }}\n </th>\n }\n </tr>\n @if (optionsCopy.secondaryProp) {\n <tr class=\"secondary-header\">\n <th></th>\n @for (primary of primaryProperty$ | async; track primary) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <th>{{ secondary }}</th>\n }\n }\n </tr>\n }\n </thead>\n <tbody>\n @for (line of lines$ | async; track line.name) {\n <tr>\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n @if (optionsCopy.secondaryProp) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <td\n [ngStyle]=\"\n optionsCopy.colorConfig ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] } : {}\n \"\n >\n {{ line.value[primary][secondary]\n }}{{ optionsCopy.format?.suffix ? ' ' + optionsCopy.format?.suffix : '' }}\n </td>\n }\n } @else {\n <td\n [ngStyle]=\"\n optionsCopy.colorConfig ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] } : {}\n \"\n >\n {{ line.value[primary] }}{{ optionsCopy.format?.suffix ? ' ' + optionsCopy.format?.suffix : '' }}\n </td>\n }\n }\n </tr>\n }\n </tbody>\n <tfoot>\n @for (line of totals$ | async; track line.name) {\n <tr class=\"partial-total\">\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n @for (secondary of secondaryProperty$ | async; track secondary) {\n <td>\n {{ line.value[primary][secondary] }}\n </td>\n }\n }\n </tr>\n }\n @for (line of grandTotals$ | async; track line.name) {\n <tr class=\"grand-total\">\n <th>{{ line.name }}</th>\n @for (primary of primaryProperty$ | async; track primary) {\n <td [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n {{ line.value[primary] }}\n </td>\n }\n </tr>\n }\n </tfoot>\n </table>\n </div>\n</div>\n" }]
|
|
107
181
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i0.ElementRef }] });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-analytic.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-analytic/component/widget-analytic.component.ts","../../../../../../../projects/provoly/dashboard/widgets/widget-analytic/component/widget-analytic.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef } from '@angular/core';\nimport {\n  AnalyticWidgetOptions,\n  Attribute,\n  AttributeSimpleValue,\n  Class,\n  ClassSelectors,\n  DataWidgetComponent,\n  Item,\n  ResultSet,\n  WIDGET_HEADER_HEIGHT\n} from '@provoly/dashboard';\nimport { combineLatest, map, Observable } from 'rxjs';\nimport { Store } from '@ngrx/store';\n\n@Component({\n  selector: 'pry-widget-analytic',\n  templateUrl: './widget-analytic.component.html'\n})\nexport class WidgetAnalyticComponent extends DataWidgetComponent {\n  optionsCopy: AnalyticWidgetOptions = { primaryProp: '', secondaryProp: '', verticalProp: '', valueProp: '' };\n  options$: Observable<AnalyticWidgetOptions>;\n\n  primaryProperty$: Observable<string[]>;\n  secondaryProperty$: Observable<string[]>;\n  verticalProperty$: Observable<string[]>;\n  totalProperty$: Observable<string[]>;\n  grandTotalProperty$: Observable<string[]>;\n  lines$: Observable<{ name: string; value: { [key: string]: { [key: string]: any } } }[]>;\n  totals$: Observable<{ name: string; value: { [key: string]: { [key: string]: any } } }[]>;\n  grandTotals$: Observable<{ name: any; value: { [p: string]: any } }[]>;\n  height$: Observable<number>;\n  classes$: Observable<Class[]>;\n  availableProperties$: Observable<Attribute[]>;\n\n  change($event: string, prop: 'primaryProp' | 'secondaryProp' | 'valueProp' | 'verticalProp') {\n    this.optionsCopy[prop] = $event;\n  }\n\n  constructor(store: Store<any>, el: ElementRef) {\n    super(store, el);\n    this.options$ = this.manifest$.pipe(map((manifest) => (manifest.options ?? {}) as AnalyticWidgetOptions));\n    this.classes$ = this.store.select(ClassSelectors.classes);\n    this.height$ = combineLatest([this.widgetSize$, this.displayHeader$]).pipe(\n      map(([size, header]) => size.height - (header ? WIDGET_HEADER_HEIGHT.value : 0))\n    );\n    this.subscriptions.add(\n      this.options$.subscribe((options) => {\n        this.optionsCopy = JSON.parse(JSON.stringify(options));\n      })\n    );\n    this.primaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.primaryProp))\n    );\n    this.secondaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.secondaryProp, 1))\n    );\n    this.verticalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 1))\n    );\n    this.totalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 2))\n    );\n    this.grandTotalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 3))\n    );\n\n    this.lines$ = combineLatest([\n      this.options$,\n      this.primaryProperty$,\n      this.secondaryProperty$,\n      this.verticalProperty$,\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, secondaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, 1)\n      )\n    );\n\n    this.totals$ = combineLatest([\n      this.options$,\n      this.primaryProperty$,\n      this.secondaryProperty$,\n      this.totalProperty$,\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, secondaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, 2)\n      )\n    );\n\n    this.grandTotals$ = combineLatest([\n      this.options$,\n      this.primaryProperty$,\n      this.grandTotalProperty$,\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, undefined, rs, options, 3)\n      )\n    );\n\n    this.availableProperties$ = combineLatest([this.classes$, this.resultSet$]).pipe(\n      map(([classes, rs]) => {\n        const presentClassesId = Object.keys(rs.items);\n        const presentClasses = presentClassesId\n          .map((classId) => classes.find((cl) => cl.id === classId))\n          .filter((cl) => !!cl) as Class[];\n        return presentClasses.map((cl) => cl.attributes).flat();\n      })\n    );\n  }\n\n  private matchAttributeValue(item: Item, prop: string, comparisonValue: string | undefined) {\n    return comparisonValue ? (item.attributes[prop] as AttributeSimpleValue).value == comparisonValue : true;\n  }\n\n  private createValueMap(\n    verticalProps: string[],\n    primaryProps: string[],\n    secondaryProps: string[] | undefined,\n    rs: ResultSet,\n    options: AnalyticWidgetOptions,\n    level?: number\n  ) {\n    return verticalProps.map((vertical) => {\n      const value = {} as { [key: string]: { [key: string]: any } | any };\n      primaryProps.forEach((primary) => {\n        (secondaryProps ?? [undefined]).forEach((secondary) => {\n          const matchingItem = (rs.items[Object.keys(rs.items)[0]] ?? []).find(\n            (item) =>\n              this.matchAttributeValue(item, options.primaryProp, primary) &&\n              this.matchAttributeValue(item, options.secondaryProp, secondary) &&\n              this.matchAttributeValue(item, options.verticalProp, vertical) &&\n              this.matchAttributeValue(item, 'level', level + '')\n          );\n          if (!!matchingItem) {\n            if (!!secondary) {\n              if (!value[primary]) {\n                value[primary] = {};\n              }\n              value[primary][secondary] = (matchingItem!.attributes[options.valueProp] as AttributeSimpleValue).value;\n            } else {\n              value[primary] = (matchingItem!.attributes[options.valueProp] as AttributeSimpleValue).value;\n            }\n          }\n        });\n      });\n      return { name: vertical, value };\n    });\n  }\n\n  getPropertyLabelsForLevel(rs: ResultSet, property: string, level?: number) {\n    const values = Object.values(rs.items)\n      .map((items) =>\n        items\n          .filter((item) =>\n            level\n              ? [level, '' + level].includes(\n                  (item.attributes['level'] as AttributeSimpleValue).value as string | number\n                )\n              : true\n          )\n          .map((item) => (item.attributes[property] as AttributeSimpleValue).value + '')\n      )\n      .flat()\n      .flat();\n    return [...new Set(values)];\n  }\n\n  emitManifest() {\n    this.manifestModified.emit({\n      widgetIndex: this.widgetIndex,\n      manifest: { ...this.manifest, options: this.optionsCopy }\n    });\n  }\n}\n","<pry-widget-analytic-css></pry-widget-analytic-css>\n<div class=\"o-widget o-widget__analytic\">\n  <pry-widget-header\n    *ngIf=\"displayHeader$ | async\"\n    [widgetIndex]=\"widgetIndex\"\n    [manifest]=\"manifest\"\n    (manifestModified)=\"manifestModified.emit($event)\"\n    #header\n    [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n    [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n  >\n    <pry-settings\n      (saveTriggered)=\"emitManifest()\"\n      (changeTitle)=\"changeWidgetTitle($event)\"\n      [headerPresent]=\"displayHeader$ | async\"\n      [widgetIndex]=\"widgetIndex\"\n      [header]=\"header\"\n      [open$]=\"open$\"\n      class=\"o-settings\"\n    >\n      <div class=\"o-settings__fields\">\n        <div class=\"m-form-label-field\">\n          <label class=\"a-label\" for=\"primaryProp\">{{ '@pry.widget.analytic.primaryProp' | i18n }}</label>\n          <pry-select\n            (ngModelChange)=\"change($event, 'primaryProp')\"\n            [items]=\"availableProperties$ | async\"\n            [ngModel]=\"optionsCopy.primaryProp\"\n            bindLabel=\"name\"\n            bindValue=\"name\"\n            id=\"primaryProp\"\n          ></pry-select>\n        </div>\n        <div class=\"m-form-label-field\">\n          <label class=\"a-label\" for=\"secondaryProp\">{{ '@pry.widget.analytic.secondaryProp' | i18n }}</label>\n          <pry-select\n            (ngModelChange)=\"change($event, 'secondaryProp')\"\n            [items]=\"availableProperties$ | async\"\n            [ngModel]=\"optionsCopy.secondaryProp\"\n            bindLabel=\"name\"\n            bindValue=\"name\"\n            id=\"secondaryProp\"\n          ></pry-select>\n        </div>\n        <div class=\"m-form-label-field\">\n          <label class=\"a-label\" for=\"verticalProp\">{{ '@pry.widget.analytic.verticalProp' | i18n }}</label>\n          <pry-select\n            (ngModelChange)=\"change($event, 'verticalProp')\"\n            [items]=\"availableProperties$ | async\"\n            [ngModel]=\"optionsCopy.verticalProp\"\n            bindLabel=\"name\"\n            bindValue=\"name\"\n            id=\"verticalProp\"\n          ></pry-select>\n        </div>\n        <div class=\"m-form-label-field\">\n          <label class=\"a-label\" for=\"valueProp\">{{ '@pry.widget.analytic.valueProp' | i18n }}</label>\n          <pry-select\n            (ngModelChange)=\"change($event, 'valueProp')\"\n            [items]=\"availableProperties$ | async\"\n            [ngModel]=\"optionsCopy.valueProp\"\n            bindLabel=\"name\"\n            bindValue=\"name\"\n            id=\"valueProp\"\n          ></pry-select>\n        </div>\n      </div>\n    </pry-settings>\n  </pry-widget-header>\n  <div class=\"o-widget__analytic__table\">\n    <table [style.height.px]=\"height$ | async\">\n      <thead>\n        <tr class=\"primary-header\">\n          <th></th>\n          @for (primary of primaryProperty$ | async; track primary) {\n            <th [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n              {{ primary }}\n            </th>\n          }\n        </tr>\n        <tr class=\"secondary-header\">\n          <th></th>\n          @for (primary of primaryProperty$ | async; track primary) {\n            @for (secondary of secondaryProperty$ | async; track secondary) {\n              <th>{{ secondary }}</th>\n            }\n          }\n        </tr>\n      </thead>\n      <tbody>\n        @for (line of lines$ | async; track line.name) {\n          <tr>\n            <th>{{ line.name }}</th>\n            @for (primary of primaryProperty$ | async; track primary) {\n              @for (secondary of secondaryProperty$ | async; track secondary) {\n                <td>\n                  {{ line.value[primary][secondary] }}\n                </td>\n              }\n            }\n          </tr>\n        }\n      </tbody>\n      <tfoot>\n        @for (line of totals$ | async; track line.name) {\n          <tr class=\"partial-total\">\n            <th>{{ line.name }}</th>\n            @for (primary of primaryProperty$ | async; track primary) {\n              @for (secondary of secondaryProperty$ | async; track secondary) {\n                <td>\n                  {{ line.value[primary][secondary] }}\n                </td>\n              }\n            }\n          </tr>\n        }\n        @for (line of grandTotals$ | async; track line.name) {\n          <tr class=\"grand-total\">\n            <th>{{ line.name }}</th>\n            @for (primary of primaryProperty$ | async; track primary) {\n              <td [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n                {{ line.value[primary] }}\n              </td>\n            }\n          </tr>\n        }\n      </tfoot>\n    </table>\n  </div>\n</div>\n"]}
|
|
182
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-analytic.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-analytic/component/widget-analytic.component.ts","../../../../../../../projects/provoly/dashboard/widgets/widget-analytic/component/widget-analytic.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,MAAM,eAAe,CAAC;AACtD,OAAO,EAKL,cAAc,EACd,mBAAmB,EAGnB,oBAAoB,EACrB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,aAAa,EAAE,GAAG,EAAc,SAAS,EAAE,MAAM,MAAM,CAAC;AAEjE,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;AAOxC,MAAM,OAAO,uBAAwB,SAAQ,mBAAmB;IAiB9D,MAAM,CAAC,MAAc,EAAE,IAAoE;QACzF,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC;IAClC,CAAC;IAED,iBAAiB,CAAC,MAAyB,EAAE,IAAuB;QAClE,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,MAAM,CAAC,CAAC,CAAC;gBACZ,IAAI,CAAC,WAAW,CAAC,WAAY,CAAC,IAAI,GAAG,MAAgB,CAAC;gBACtD,MAAM;YACR,CAAC;YACD,KAAK,QAAQ,CAAC,CAAC,CAAC;gBACd,IAAI,CAAC,WAAW,CAAC,WAAY,CAAC,MAAM,GAAG,MAAkB,CAAC;gBAC1D,MAAM;YACR,CAAC;QACH,CAAC;IACH,CAAC;IAED,YAAY,CAAC,MAAc,EAAE,IAAI,GAAG,QAAQ;QAC1C,IAAI,CAAC,WAAW,CAAC,MAAO,CAAC,MAAM,GAAG,MAAM,CAAC;IAC3C,CAAC;IAED,YAAY,KAAiB,EAAE,EAAc;QAC3C,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAtCnB,gBAAW,GAA0B,EAAE,WAAW,EAAE,EAAE,EAAE,aAAa,EAAE,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC;QAuC3G,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAA0B,CAAC,CAAC,CAAC;QAC1G,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QAC1D,IAAI,CAAC,OAAO,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CACxE,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CACjF,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;YAClC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;QACzD,CAAC,CAAC,CACH,CAAC;QACF,IAAI,CAAC,gBAAgB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAC1E,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,EAC5C,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,EAAE,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC,CAChF,CAAC;QACF,IAAI,CAAC,kBAAkB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAC5E,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,EAC9C,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,EAAE,EAAE,OAAO,CAAC,aAAc,EAAE,CAAC,CAAC,CAAC,CACtF,CAAC;QACF,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAC3E,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,EAC7C,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,EAAE,EAAE,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CACpF,CAAC;QACF,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CACxE,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,EAAE,EAAE,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CACpF,CAAC;QACF,IAAI,CAAC,mBAAmB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAC7E,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,EAAE,EAAE,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CACpF,CAAC;QAEF,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC;YAC1B,IAAI,CAAC,QAAQ;YACb,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YACzC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YAClD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC1C,IAAI,CAAC,UAAU;SAChB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CACjE,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,EAAE,cAAc,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,CACjF,CACF,CAAC;QAEF,IAAI,CAAC,OAAO,GAAG,aAAa,CAAC;YAC3B,IAAI,CAAC,QAAQ;YACb,IAAI,CAAC,gBAAgB;YACrB,IAAI,CAAC,kBAAkB;YACvB,IAAI,CAAC,cAAc;YACnB,IAAI,CAAC,UAAU;SAChB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CACjE,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,EAAE,cAAc,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,CACjF,CACF,CAAC;QAEF,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC;YAChC,IAAI,CAAC,QAAQ;YACb,IAAI,CAAC,gBAAgB;YACrB,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,UAAU;SAChB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CACjD,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,EAAE,SAAS,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,CAC5E,CACF,CAAC;QAEF,IAAI,CAAC,SAAS,GAAG,aAAa,CAAC;YAC7B,IAAI,CAAC,QAAQ;YACb,IAAI,CAAC,UAAU;YACf,IAAI,CAAC,iBAAiB;YACtB,IAAI,CAAC,gBAAgB;SACtB,CAAC,CAAC,IAAI,CACL,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC,EAC5C,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,EAAE,QAAQ,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,OAAO,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC,CAC/F,CAAC;QAEF,IAAI,CAAC,oBAAoB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAC9E,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,EAAE;YACpB,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;YAC/C,MAAM,cAAc,GAAG,gBAAgB;iBACpC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;iBACzD,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAY,CAAC;YACnC,OAAO,cAAc,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC;QAC1D,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,mBAAmB,CAAC,IAAU,EAAE,IAAa,EAAE,eAAwB;QAC7E,OAAO,eAAe,IAAI,IAAI,CAAC,CAAC,CAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAA0B,CAAC,KAAK,IAAI,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC;IACnH,CAAC;IAEO,cAAc,CACpB,aAAuB,EACvB,YAAsB,EACtB,cAAoC,EACpC,EAAa,EACb,OAA8B,EAC9B,KAAc;QAEd,OAAO,aAAa,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;YACpC,MAAM,KAAK,GAAG,EAAqD,CAAC;YACpE,YAAY,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;gBAC/B,CAAC,cAAc,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;oBACpD,MAAM,YAAY,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAClE,CAAC,IAAI,EAAE,EAAE,CACP,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC;wBAC5D,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,OAAO,CAAC,aAAa,EAAE,SAAS,CAAC;wBAChE,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,OAAO,CAAC,YAAY,EAAE,QAAQ,CAAC;wBAC9D,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,GAAG,EAAE,CAAC,CACtD,CAAC;oBACF,IAAI,CAAC,CAAC,YAAY,EAAE,CAAC;wBACnB,IAAI,CAAC,CAAC,SAAS,EAAE,CAAC;4BAChB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;gCACpB,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC;4BACtB,CAAC;4BACD,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,GAAI,YAAa,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAA0B,CAAC,KAAK,CAAC;wBAC1G,CAAC;6BAAM,CAAC;4BACN,KAAK,CAAC,OAAO,CAAC,GAAI,YAAa,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAA0B,EAAE,KAAK,CAAC;wBAChG,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QACnC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,yBAAyB,CAAC,EAAa,EAAE,QAAgB,EAAE,KAAc;QACvE,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC;aACnC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACb,KAAK;aACF,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CACf,KAAK,IAAI,OAAO,IAAI,IAAI,CAAC,UAAU;YACjC,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,QAAQ,CACzB,IAAI,CAAC,UAAU,CAAC,OAAO,CAA0B,CAAC,KAAwB,CAC5E;YACH,CAAC,CAAC,IAAI,CACT;aACA,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAA0B,CAAC,KAAK,GAAG,EAAE,CAAC,CACjF;aACA,IAAI,EAAE;aACN,IAAI,EAAE,CAAC;QACV,OAAO,CAAC,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;IAC9B,CAAC;IAED,cAAc,CAAC,aAAuB,EAAE,YAAsB,EAAE,EAAa,EAAE,OAA8B;QAC3G,OAAO,OAAO,CAAC,WAAW;YACxB,CAAC,CAAC,MAAM,CAAC,WAAW,CAChB,aAAa,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC;gBAC9B,QAAQ;gBACR,MAAM,CAAC,WAAW,CAChB,YAAY,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;oBAC3B,MAAM,YAAY,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAClE,CAAC,IAAI,EAAE,EAAE,CACP,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC;wBAC5D,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,OAAO,CAAC,YAAY,EAAE,QAAQ,CAAC,CACjE,CAAC;oBAEF,OAAO;wBACL,OAAO;wBACP,YAAY,IAAK,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAA0B,CAAC,KAAK,KAAK,CAAC;4BAC9F,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE,MAAM,CACvB,YAAY,CAAC,UAAU,CAAC,OAAO,CAAC,WAAY,CAAC,IAAI,CAA0B,CAAC,KAAgB;gCAC5F,CAAC,CACJ;4BACH,CAAC,CAAC,SAAS;qBACd,CAAC;gBACJ,CAAC,CAAC,CACH;aACF,CAAC,CACH;YACH,CAAC,CAAC,EAAE,CAAC;IACT,CAAC;IAED,iBAAiB,CAAC,MAAe;QAC/B,IAAI,MAAM,KAAK,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;YAC9C,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;gBAClC,IAAI,CAAC,WAAW,CAAC,WAAW,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;YAC1D,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,WAAW,CAAC,WAAW,GAAG,SAAS,CAAC;YAC3C,CAAC;QACH,CAAC;IACH,CAAC;IAED,YAAY,CAAC,MAAe;QAC1B,IAAI,MAAM,KAAK,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;YACzC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;gBAC7B,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;YAC3C,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,SAAS,CAAC;YACtC,CAAC;QACH,CAAC;IACH,CAAC;IAED,iBAAiB,CAAC,MAAe,EAAE,KAAc;QAC/C,MAAM,IAAI,KAAK,KAAK,SAAS;YAC3B,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,WAAY,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC;YACxD,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,WAAY,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC3D,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,IAAI,CAAC,WAAW,CAAC,WAAY,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IAED,IAAI,CAAC,KAA4B;QAC/B,IAAI,CAAC,WAAW,CAAC,WAAY,CAAC,MAAM,CAAC,MAAM,CACzC,KAAK,CAAC,YAAY,EAClB,CAAC,EACD,IAAI,CAAC,WAAW,CAAC,WAAY,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CACvE,CAAC;IACJ,CAAC;IAED,YAAY;QACV,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC;YACzB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,QAAQ,EAAE,EAAE,GAAG,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE;SAC1D,CAAC,CAAC;IACL,CAAC;8GA9PU,uBAAuB;kGAAvB,uBAAuB,kFCrBpC,+oRAqNA;;2FDhMa,uBAAuB;kBAJnC,SAAS;+BACE,qBAAqB","sourcesContent":["import { Component, ElementRef } from '@angular/core';\nimport {\n  AnalyticWidgetOptions,\n  Attribute,\n  AttributeSimpleValue,\n  Class,\n  ClassSelectors,\n  DataWidgetComponent,\n  Item,\n  ResultSet,\n  WIDGET_HEADER_HEIGHT\n} from '@provoly/dashboard';\nimport { combineLatest, map, Observable, startWith } from 'rxjs';\nimport { Store } from '@ngrx/store';\nimport { filter } from 'rxjs/operators';\nimport { CdkDragDrop } from '@angular/cdk/drag-drop';\n\n@Component({\n  selector: 'pry-widget-analytic',\n  templateUrl: './widget-analytic.component.html'\n})\nexport class WidgetAnalyticComponent extends DataWidgetComponent {\n  optionsCopy: AnalyticWidgetOptions = { primaryProp: '', secondaryProp: '', verticalProp: '', valueProp: '' };\n  options$: Observable<AnalyticWidgetOptions>;\n\n  primaryProperty$: Observable<string[]>;\n  secondaryProperty$: Observable<string[]>;\n  verticalProperty$: Observable<string[]>;\n  totalProperty$: Observable<string[]>;\n  grandTotalProperty$: Observable<string[]>;\n  lines$: Observable<{ name: string; value: { [key: string]: { [key: string]: any } } }[]>;\n  totals$: Observable<{ name: string; value: { [key: string]: { [key: string]: any } } }[]>;\n  grandTotals$: Observable<{ name: any; value: { [p: string]: any } }[]>;\n  colorMap$: Observable<{ [vertical: string]: { [primary: string]: string | undefined } }>;\n  height$: Observable<number>;\n  classes$: Observable<Class[]>;\n  availableProperties$: Observable<Attribute[]>;\n\n  change($event: string, prop: 'primaryProp' | 'secondaryProp' | 'valueProp' | 'verticalProp') {\n    this.optionsCopy[prop] = $event;\n  }\n\n  changeColorConfig($event: string | string[], prop: 'prop' | 'colors') {\n    switch (prop) {\n      case 'prop': {\n        this.optionsCopy.colorConfig!.prop = $event as string;\n        break;\n      }\n      case 'colors': {\n        this.optionsCopy.colorConfig!.colors = $event as string[];\n        break;\n      }\n    }\n  }\n\n  changeFormat($event: string, prop = 'suffix') {\n    this.optionsCopy.format!.suffix = $event;\n  }\n\n  constructor(store: Store<any>, el: ElementRef) {\n    super(store, el);\n    this.options$ = this.manifest$.pipe(map((manifest) => (manifest.options ?? {}) as AnalyticWidgetOptions));\n    this.classes$ = this.store.select(ClassSelectors.classes);\n    this.height$ = combineLatest([this.widgetSize$, this.displayHeader$]).pipe(\n      map(([size, header]) => size.height - (header ? WIDGET_HEADER_HEIGHT.value : 0))\n    );\n    this.subscriptions.add(\n      this.options$.subscribe((options) => {\n        this.optionsCopy = JSON.parse(JSON.stringify(options));\n      })\n    );\n    this.primaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      filter(([options]) => !!options.primaryProp),\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.primaryProp))\n    );\n    this.secondaryProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      filter(([options]) => !!options.secondaryProp),\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.secondaryProp!, 1))\n    );\n    this.verticalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      filter(([options]) => !!options.verticalProp),\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 1))\n    );\n    this.totalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 2))\n    );\n    this.grandTotalProperty$ = combineLatest([this.options$, this.resultSet$]).pipe(\n      map(([options, rs]) => this.getPropertyLabelsForLevel(rs, options.verticalProp, 3))\n    );\n\n    this.lines$ = combineLatest([\n      this.options$,\n      this.primaryProperty$.pipe(startWith([])),\n      this.secondaryProperty$.pipe(startWith(undefined)),\n      this.verticalProperty$.pipe(startWith([])),\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, secondaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, 1)\n      )\n    );\n\n    this.totals$ = combineLatest([\n      this.options$,\n      this.primaryProperty$,\n      this.secondaryProperty$,\n      this.totalProperty$,\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, secondaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, secondaryProps, rs, options, 2)\n      )\n    );\n\n    this.grandTotals$ = combineLatest([\n      this.options$,\n      this.primaryProperty$,\n      this.grandTotalProperty$,\n      this.resultSet$\n    ]).pipe(\n      map(([options, primaryProps, verticalProps, rs]) =>\n        this.createValueMap(verticalProps, primaryProps, undefined, rs, options, 3)\n      )\n    );\n\n    this.colorMap$ = combineLatest([\n      this.options$,\n      this.resultSet$,\n      this.verticalProperty$,\n      this.primaryProperty$\n    ]).pipe(\n      filter(([options]) => !!options.colorConfig),\n      map(([options, rs, vertical, primary]) => this.createColorMap(vertical, primary, rs, options))\n    );\n\n    this.availableProperties$ = combineLatest([this.classes$, this.resultSet$]).pipe(\n      map(([classes, rs]) => {\n        const presentClassesId = Object.keys(rs.items);\n        const presentClasses = presentClassesId\n          .map((classId) => classes.find((cl) => cl.id === classId))\n          .filter((cl) => !!cl) as Class[];\n        return presentClasses.map((cl) => cl.attributes).flat();\n      })\n    );\n  }\n\n  private matchAttributeValue(item: Item, prop?: string, comparisonValue?: string) {\n    return comparisonValue && prop ? (item.attributes[prop] as AttributeSimpleValue).value == comparisonValue : true;\n  }\n\n  private createValueMap(\n    verticalProps: string[],\n    primaryProps: string[],\n    secondaryProps: string[] | undefined,\n    rs: ResultSet,\n    options: AnalyticWidgetOptions,\n    level?: number\n  ) {\n    return verticalProps.map((vertical) => {\n      const value = {} as { [key: string]: { [key: string]: any } | any };\n      primaryProps.forEach((primary) => {\n        (secondaryProps ?? [undefined]).forEach((secondary) => {\n          const matchingItem = (rs.items[Object.keys(rs.items)[0]] ?? []).find(\n            (item) =>\n              this.matchAttributeValue(item, options.primaryProp, primary) &&\n              this.matchAttributeValue(item, options.secondaryProp, secondary) &&\n              this.matchAttributeValue(item, options.verticalProp, vertical) &&\n              this.matchAttributeValue(item, 'level', level + '')\n          );\n          if (!!matchingItem) {\n            if (!!secondary) {\n              if (!value[primary]) {\n                value[primary] = {};\n              }\n              value[primary][secondary] = (matchingItem!.attributes[options.valueProp] as AttributeSimpleValue).value;\n            } else {\n              value[primary] = (matchingItem!.attributes[options.valueProp] as AttributeSimpleValue)?.value;\n            }\n          }\n        });\n      });\n      return { name: vertical, value };\n    });\n  }\n\n  getPropertyLabelsForLevel(rs: ResultSet, property: string, level?: number) {\n    const values = Object.values(rs.items)\n      .map((items) =>\n        items\n          .filter((item) =>\n            level && 'level' in item.attributes\n              ? [level, '' + level].includes(\n                  (item.attributes['level'] as AttributeSimpleValue).value as string | number\n                )\n              : true\n          )\n          .map((item) => (item.attributes[property] as AttributeSimpleValue).value + '')\n      )\n      .flat()\n      .flat();\n    return [...new Set(values)];\n  }\n\n  createColorMap(verticalProps: string[], primaryProps: string[], rs: ResultSet, options: AnalyticWidgetOptions) {\n    return options.colorConfig\n      ? Object.fromEntries(\n          verticalProps.map((vertical) => [\n            vertical,\n            Object.fromEntries(\n              primaryProps.map((primary) => {\n                const matchingItem = (rs.items[Object.keys(rs.items)[0]] ?? []).find(\n                  (item) =>\n                    this.matchAttributeValue(item, options.primaryProp, primary) &&\n                    this.matchAttributeValue(item, options.verticalProp, vertical)\n                );\n\n                return [\n                  primary,\n                  matchingItem && (matchingItem.attributes[options.valueProp] as AttributeSimpleValue).value !== 0\n                    ? options.colorConfig?.colors[\n                        ((matchingItem.attributes[options.colorConfig!.prop] as AttributeSimpleValue).value as number) -\n                          1\n                      ]\n                    : '#FFFFFF'\n                ];\n              })\n            )\n          ])\n        )\n      : {};\n  }\n\n  toggleColorConfig($event: boolean) {\n    if ($event !== !!this.optionsCopy.colorConfig) {\n      if (!this.optionsCopy.colorConfig) {\n        this.optionsCopy.colorConfig = { prop: '', colors: [] };\n      } else {\n        this.optionsCopy.colorConfig = undefined;\n      }\n    }\n  }\n\n  toggleFormat($event: boolean) {\n    if ($event !== !!this.optionsCopy.format) {\n      if (!this.optionsCopy.format) {\n        this.optionsCopy.format = { suffix: '' };\n      } else {\n        this.optionsCopy.format = undefined;\n      }\n    }\n  }\n\n  modifyColorScheme($event?: string, index?: number) {\n    $event && index !== undefined\n      ? (this.optionsCopy.colorConfig!.colors[index] = $event)\n      : this.optionsCopy.colorConfig!.colors.push('#FFFFFF');\n  }\n\n  removeColor(index: number) {\n    this.optionsCopy.colorConfig!.colors.splice(index, 1);\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\n    this.optionsCopy.colorConfig!.colors.splice(\n      event.currentIndex,\n      0,\n      this.optionsCopy.colorConfig!.colors.splice(event.previousIndex, 1)[0]\n    );\n  }\n\n  emitManifest() {\n    this.manifestModified.emit({\n      widgetIndex: this.widgetIndex,\n      manifest: { ...this.manifest, options: this.optionsCopy }\n    });\n  }\n}\n","<pry-widget-analytic-css></pry-widget-analytic-css>\n<div class=\"o-widget o-widget__analytic\">\n  <pry-widget-header\n    *ngIf=\"displayHeader$ | async\"\n    [widgetIndex]=\"widgetIndex\"\n    [manifest]=\"manifest\"\n    (manifestModified)=\"manifestModified.emit($event)\"\n    #header\n    [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n    [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n  >\n    <pry-settings\n      (saveTriggered)=\"emitManifest()\"\n      (changeTitle)=\"changeWidgetTitle($event)\"\n      [headerPresent]=\"displayHeader$ | async\"\n      [widgetIndex]=\"widgetIndex\"\n      [header]=\"header\"\n      [open$]=\"open$\"\n      class=\"o-settings\"\n    >\n      <div class=\"o-settings__fields\">\n        <div class=\"m-form-label-field\">\n          <label class=\"a-label\" for=\"primaryProp\">{{ '@pry.widget.analytic.primaryProp' | i18n }}</label>\n          <pry-select\n            (ngModelChange)=\"change($event, 'primaryProp')\"\n            [items]=\"availableProperties$ | async\"\n            [ngModel]=\"optionsCopy.primaryProp\"\n            bindLabel=\"name\"\n            bindValue=\"name\"\n            id=\"primaryProp\"\n          ></pry-select>\n        </div>\n        <div class=\"m-form-label-field\">\n          <label class=\"a-label\" for=\"secondaryProp\">{{ '@pry.widget.analytic.secondaryProp' | i18n }}</label>\n          <pry-select\n            (ngModelChange)=\"change($event, 'secondaryProp')\"\n            [items]=\"availableProperties$ | async\"\n            [ngModel]=\"optionsCopy.secondaryProp\"\n            bindLabel=\"name\"\n            bindValue=\"name\"\n            id=\"secondaryProp\"\n            [clearable]=\"true\"\n          ></pry-select>\n        </div>\n        <div class=\"m-form-label-field\">\n          <label class=\"a-label\" for=\"verticalProp\">{{ '@pry.widget.analytic.verticalProp' | i18n }}</label>\n          <pry-select\n            (ngModelChange)=\"change($event, 'verticalProp')\"\n            [items]=\"availableProperties$ | async\"\n            [ngModel]=\"optionsCopy.verticalProp\"\n            bindLabel=\"name\"\n            bindValue=\"name\"\n            id=\"verticalProp\"\n          ></pry-select>\n        </div>\n        <div class=\"m-form-label-field\">\n          <label class=\"a-label\" for=\"valueProp\">{{ '@pry.widget.analytic.valueProp' | i18n }}</label>\n          <pry-select\n            (ngModelChange)=\"change($event, 'valueProp')\"\n            [items]=\"availableProperties$ | async\"\n            [ngModel]=\"optionsCopy.valueProp\"\n            bindLabel=\"name\"\n            bindValue=\"name\"\n            id=\"valueProp\"\n          ></pry-select>\n        </div>\n        <div class=\"m-form-label-field\">\n          <pry-checkbox (ngModelChange)=\"toggleColorConfig($event)\" [ngModel]=\"!!optionsCopy.colorConfig\">\n            {{ '@pry.widget.analytic.colorConfig' | i18n }}\n          </pry-checkbox>\n          @if (optionsCopy.colorConfig) {\n            <div class=\"m-form-label-field\">\n              <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colorProp' | i18n }}</label>\n              <pry-select\n                (ngModelChange)=\"changeColorConfig($event, 'prop')\"\n                [items]=\"availableProperties$ | async\"\n                [ngModel]=\"optionsCopy.colorConfig.prop\"\n                bindLabel=\"name\"\n                bindValue=\"name\"\n                id=\"colorProp\"\n              ></pry-select>\n            </div>\n            <div class=\"m-form-label-field\">\n              <label class=\"a-label\" for=\"colorProp\">{{ '@pry.widget.analytic.colors' | i18n }}</label>\n              <div\n                class=\"o-widget__analytic__color-picker-container u-display-flex -align-center\"\n                cdkDropList\n                (cdkDropListDropped)=\"drop($event)\"\n                cdkDropListOrientation=\"horizontal\"\n              >\n                @for (color of optionsCopy.colorConfig.colors; track color; let i = $index) {\n                  <div class=\"o-widget__analytic__color-picker\" cdkDrag>\n                    <pry-color-picker\n                      [ngModel]=\"color\"\n                      (ngModelChange)=\"modifyColorScheme($event, i)\"\n                    ></pry-color-picker>\n                    <button (click)=\"removeColor(i)\" class=\"o-widget__analytic__color-picker-remove\">\n                      <pry-icon iconSvg=\"close\" [height]=\"15\" [width]=\"15\"></pry-icon>\n                    </button>\n                    <div *cdkDragPreview>\n                      <pry-color-picker [ngModel]=\"color\"></pry-color-picker>\n                    </div>\n                  </div>\n                }\n                <button\n                  type=\"button\"\n                  class=\"a-btn a-btn--icon-only o-widget__analytic__color-picker-add\"\n                  (click)=\"modifyColorScheme()\"\n                >\n                  <pry-icon iconSvg=\"add\" [height]=\"20\" [width]=\"20\"></pry-icon>\n                </button>\n              </div>\n            </div>\n          }\n        </div>\n        <div class=\"m-form-label-field\">\n          <pry-checkbox (ngModelChange)=\"toggleFormat($event)\" [ngModel]=\"!!optionsCopy.format\">\n            {{ '@pry.widget.analytic.format' | i18n }}\n          </pry-checkbox>\n          @if (optionsCopy.format) {\n            <div class=\"m-form-label-field\">\n              <label class=\"a-label\" for=\"format\">{{ '@pry.widget.analytic.suffix' | i18n }}</label>\n              <input\n                type=\"text\"\n                class=\"a-form-field\"\n                id=\"format\"\n                [ngModel]=\"optionsCopy.format.suffix\"\n                (ngModelChange)=\"changeFormat($event)\"\n              />\n            </div>\n          }\n        </div>\n      </div>\n    </pry-settings>\n  </pry-widget-header>\n  <div class=\"o-widget__analytic__table\">\n    <table [style.height.px]=\"height$ | async\">\n      <thead>\n        <tr class=\"primary-header\">\n          <th></th>\n          @for (primary of primaryProperty$ | async; track primary) {\n            <th [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n              {{ primary }}\n            </th>\n          }\n        </tr>\n        @if (optionsCopy.secondaryProp) {\n          <tr class=\"secondary-header\">\n            <th></th>\n            @for (primary of primaryProperty$ | async; track primary) {\n              @for (secondary of secondaryProperty$ | async; track secondary) {\n                <th>{{ secondary }}</th>\n              }\n            }\n          </tr>\n        }\n      </thead>\n      <tbody>\n        @for (line of lines$ | async; track line.name) {\n          <tr>\n            <th>{{ line.name }}</th>\n            @for (primary of primaryProperty$ | async; track primary) {\n              @if (optionsCopy.secondaryProp) {\n                @for (secondary of secondaryProperty$ | async; track secondary) {\n                  <td\n                    [ngStyle]=\"\n                      optionsCopy.colorConfig ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] } : {}\n                    \"\n                  >\n                    {{ line.value[primary][secondary]\n                    }}{{ optionsCopy.format?.suffix ? ' ' + optionsCopy.format?.suffix : '' }}\n                  </td>\n                }\n              } @else {\n                <td\n                  [ngStyle]=\"\n                    optionsCopy.colorConfig ? { 'background-color': (colorMap$ | async)?.[line.name]?.[primary] } : {}\n                  \"\n                >\n                  {{ line.value[primary] }}{{ optionsCopy.format?.suffix ? ' ' + optionsCopy.format?.suffix : '' }}\n                </td>\n              }\n            }\n          </tr>\n        }\n      </tbody>\n      <tfoot>\n        @for (line of totals$ | async; track line.name) {\n          <tr class=\"partial-total\">\n            <th>{{ line.name }}</th>\n            @for (primary of primaryProperty$ | async; track primary) {\n              @for (secondary of secondaryProperty$ | async; track secondary) {\n                <td>\n                  {{ line.value[primary][secondary] }}\n                </td>\n              }\n            }\n          </tr>\n        }\n        @for (line of grandTotals$ | async; track line.name) {\n          <tr class=\"grand-total\">\n            <th>{{ line.name }}</th>\n            @for (primary of primaryProperty$ | async; track primary) {\n              <td [colSpan]=\"(secondaryProperty$ | async)?.length ?? 1\">\n                {{ line.value[primary] }}\n              </td>\n            }\n          </tr>\n        }\n      </tfoot>\n    </table>\n  </div>\n</div>\n"]}
|
|
@@ -5,9 +5,14 @@ export const enTranslations = {
|
|
|
5
5
|
primaryProp: 'Attribute that contains the horizontal primary field',
|
|
6
6
|
secondaryProp: 'Attribute that contains the horizontal secondary field',
|
|
7
7
|
verticalProp: 'Attribute that contains the vertical attribute',
|
|
8
|
-
valueProp: 'Attribute that contains the value'
|
|
8
|
+
valueProp: 'Attribute that contains the value',
|
|
9
|
+
colorConfig: 'Cell color configuration',
|
|
10
|
+
colorProp: 'Color attribute',
|
|
11
|
+
colors: 'Colors',
|
|
12
|
+
format: 'Value formatting',
|
|
13
|
+
suffix: 'Suffix'
|
|
9
14
|
}
|
|
10
15
|
}
|
|
11
16
|
}
|
|
12
17
|
};
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW4udHJhbnNsYXRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvd2lkZ2V0cy93aWRnZXQtYW5hbHl0aWMvaTE4bi9lbi50cmFuc2xhdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHO0lBQzVCLE1BQU0sRUFBRTtRQUNOLE1BQU0sRUFBRTtZQUNOLFFBQVEsRUFBRTtnQkFDUixXQUFXLEVBQUUsc0RBQXNEO2dCQUNuRSxhQUFhLEVBQUUsd0RBQXdEO2dCQUN2RSxZQUFZLEVBQUUsZ0RBQWdEO2dCQUM5RCxTQUFTLEVBQUUsbUNBQW1DO2dCQUM5QyxXQUFXLEVBQUUsMEJBQTBCO2dCQUN2QyxTQUFTLEVBQUUsaUJBQWlCO2dCQUM1QixNQUFNLEVBQUUsUUFBUTtnQkFDaEIsTUFBTSxFQUFFLGtCQUFrQjtnQkFDMUIsTUFBTSxFQUFFLFFBQVE7YUFDakI7U0FDRjtLQUNGO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBlblRyYW5zbGF0aW9ucyA9IHtcbiAgJ0BwcnknOiB7XG4gICAgd2lkZ2V0OiB7XG4gICAgICBhbmFseXRpYzoge1xuICAgICAgICBwcmltYXJ5UHJvcDogJ0F0dHJpYnV0ZSB0aGF0IGNvbnRhaW5zIHRoZSBob3Jpem9udGFsIHByaW1hcnkgZmllbGQnLFxuICAgICAgICBzZWNvbmRhcnlQcm9wOiAnQXR0cmlidXRlIHRoYXQgY29udGFpbnMgdGhlIGhvcml6b250YWwgc2Vjb25kYXJ5IGZpZWxkJyxcbiAgICAgICAgdmVydGljYWxQcm9wOiAnQXR0cmlidXRlIHRoYXQgY29udGFpbnMgdGhlIHZlcnRpY2FsIGF0dHJpYnV0ZScsXG4gICAgICAgIHZhbHVlUHJvcDogJ0F0dHJpYnV0ZSB0aGF0IGNvbnRhaW5zIHRoZSB2YWx1ZScsXG4gICAgICAgIGNvbG9yQ29uZmlnOiAnQ2VsbCBjb2xvciBjb25maWd1cmF0aW9uJyxcbiAgICAgICAgY29sb3JQcm9wOiAnQ29sb3IgYXR0cmlidXRlJyxcbiAgICAgICAgY29sb3JzOiAnQ29sb3JzJyxcbiAgICAgICAgZm9ybWF0OiAnVmFsdWUgZm9ybWF0dGluZycsXG4gICAgICAgIHN1ZmZpeDogJ1N1ZmZpeCdcbiAgICAgIH1cbiAgICB9XG4gIH1cbn07XG4iXX0=
|
|
@@ -5,9 +5,14 @@ export const frTranslations = {
|
|
|
5
5
|
primaryProp: 'Attribut horizontal primaire',
|
|
6
6
|
secondaryProp: 'Attribut horizontal secondaire',
|
|
7
7
|
verticalProp: 'Attribut vertical',
|
|
8
|
-
valueProp: 'Attribut contenant la valeur'
|
|
8
|
+
valueProp: 'Attribut contenant la valeur',
|
|
9
|
+
colorConfig: 'Configuration des couleurs de cellules',
|
|
10
|
+
colorProp: 'Attribut de la couleur',
|
|
11
|
+
colors: 'Couleurs',
|
|
12
|
+
format: 'Formattage des valeurs',
|
|
13
|
+
suffix: 'Suffixe'
|
|
9
14
|
}
|
|
10
15
|
}
|
|
11
16
|
}
|
|
12
17
|
};
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnIudHJhbnNsYXRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvd2lkZ2V0cy93aWRnZXQtYW5hbHl0aWMvaTE4bi9mci50cmFuc2xhdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHO0lBQzVCLE1BQU0sRUFBRTtRQUNOLE1BQU0sRUFBRTtZQUNOLFFBQVEsRUFBRTtnQkFDUixXQUFXLEVBQUUsOEJBQThCO2dCQUMzQyxhQUFhLEVBQUUsZ0NBQWdDO2dCQUMvQyxZQUFZLEVBQUUsbUJBQW1CO2dCQUNqQyxTQUFTLEVBQUUsOEJBQThCO2dCQUN6QyxXQUFXLEVBQUUsd0NBQXdDO2dCQUNyRCxTQUFTLEVBQUUsd0JBQXdCO2dCQUNuQyxNQUFNLEVBQUUsVUFBVTtnQkFDbEIsTUFBTSxFQUFFLHdCQUF3QjtnQkFDaEMsTUFBTSxFQUFFLFNBQVM7YUFDbEI7U0FDRjtLQUNGO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBmclRyYW5zbGF0aW9ucyA9IHtcbiAgJ0BwcnknOiB7XG4gICAgd2lkZ2V0OiB7XG4gICAgICBhbmFseXRpYzoge1xuICAgICAgICBwcmltYXJ5UHJvcDogJ0F0dHJpYnV0IGhvcml6b250YWwgcHJpbWFpcmUnLFxuICAgICAgICBzZWNvbmRhcnlQcm9wOiAnQXR0cmlidXQgaG9yaXpvbnRhbCBzZWNvbmRhaXJlJyxcbiAgICAgICAgdmVydGljYWxQcm9wOiAnQXR0cmlidXQgdmVydGljYWwnLFxuICAgICAgICB2YWx1ZVByb3A6ICdBdHRyaWJ1dCBjb250ZW5hbnQgbGEgdmFsZXVyJyxcbiAgICAgICAgY29sb3JDb25maWc6ICdDb25maWd1cmF0aW9uIGRlcyBjb3VsZXVycyBkZSBjZWxsdWxlcycsXG4gICAgICAgIGNvbG9yUHJvcDogJ0F0dHJpYnV0IGRlIGxhIGNvdWxldXInLFxuICAgICAgICBjb2xvcnM6ICdDb3VsZXVycycsXG4gICAgICAgIGZvcm1hdDogJ0Zvcm1hdHRhZ2UgZGVzIHZhbGV1cnMnLFxuICAgICAgICBzdWZmaXg6ICdTdWZmaXhlJ1xuICAgICAgfVxuICAgIH1cbiAgfVxufTtcbiJdfQ==
|
|
@@ -2,10 +2,10 @@ import { Component, ViewEncapsulation } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class PryWidgetAnalyticCssComponent {
|
|
4
4
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryWidgetAnalyticCssComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: PryWidgetAnalyticCssComponent, selector: "pry-widget-analytic-css", ngImport: i0, template: '', isInline: true, styles: [".o-widget__analytic__table,.o-widget__analytic__table table{width:100%}.o-widget__analytic__table table th,.o-widget__analytic__table table td{text-align:center}.o-widget__analytic__table table th:first-child,.o-widget__analytic__table table td:first-child{text-align:left}.o-widget__analytic__table table .primary-header th:not(:first-child){background-color:#d7e7f7}.o-widget__analytic__table table .secondary-header th:not(:first-child){background-color:#f3f8fc}.o-widget__analytic__table table .partial-total th,.o-widget__analytic__table table .partial-total td{background-color:#f0f0f0}.o-widget__analytic__table table .grand-total th,.o-widget__analytic__table table .grand-total td{background-color:#bdb9da}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
|
5
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: PryWidgetAnalyticCssComponent, selector: "pry-widget-analytic-css", ngImport: i0, template: '', isInline: true, styles: [".o-widget__analytic__table,.o-widget__analytic__table table{width:100%}.o-widget__analytic__table table th,.o-widget__analytic__table table td{text-align:center}.o-widget__analytic__table table th:first-child,.o-widget__analytic__table table td:first-child{text-align:left}.o-widget__analytic__table table .primary-header th:not(:first-child){background-color:#d7e7f7}.o-widget__analytic__table table .secondary-header th:not(:first-child){background-color:#f3f8fc}.o-widget__analytic__table table .partial-total th,.o-widget__analytic__table table .partial-total td{background-color:#f0f0f0}.o-widget__analytic__table table .grand-total th,.o-widget__analytic__table table .grand-total td{background-color:#bdb9da}.o-widget__analytic__color-picker-container{margin-top:.625rem;gap:.9375rem;flex-wrap:wrap}.o-widget__analytic__color-picker{position:relative}.o-widget__analytic__color-picker-remove{position:absolute;right:-20px;top:-10px;z-index:2;color:#263340;padding:0}.o-widget__analytic__color-picker-add{padding:.75rem;border:1px solid #263340;border-radius:50%;width:20px}.cdk-drop-list-dragging .cdk-drag,.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.cdk-drop-list-dragging .o-widget__analytic__color-picker:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}.cdk-drag-preview{box-sizing:border-box;border-radius:50%;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
|
6
6
|
}
|
|
7
7
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryWidgetAnalyticCssComponent, decorators: [{
|
|
8
8
|
type: Component,
|
|
9
|
-
args: [{ selector: 'pry-widget-analytic-css', template: '', encapsulation: ViewEncapsulation.None, styles: [".o-widget__analytic__table,.o-widget__analytic__table table{width:100%}.o-widget__analytic__table table th,.o-widget__analytic__table table td{text-align:center}.o-widget__analytic__table table th:first-child,.o-widget__analytic__table table td:first-child{text-align:left}.o-widget__analytic__table table .primary-header th:not(:first-child){background-color:#d7e7f7}.o-widget__analytic__table table .secondary-header th:not(:first-child){background-color:#f3f8fc}.o-widget__analytic__table table .partial-total th,.o-widget__analytic__table table .partial-total td{background-color:#f0f0f0}.o-widget__analytic__table table .grand-total th,.o-widget__analytic__table table .grand-total td{background-color:#bdb9da}\n"] }]
|
|
9
|
+
args: [{ selector: 'pry-widget-analytic-css', template: '', encapsulation: ViewEncapsulation.None, styles: [".o-widget__analytic__table,.o-widget__analytic__table table{width:100%}.o-widget__analytic__table table th,.o-widget__analytic__table table td{text-align:center}.o-widget__analytic__table table th:first-child,.o-widget__analytic__table table td:first-child{text-align:left}.o-widget__analytic__table table .primary-header th:not(:first-child){background-color:#d7e7f7}.o-widget__analytic__table table .secondary-header th:not(:first-child){background-color:#f3f8fc}.o-widget__analytic__table table .partial-total th,.o-widget__analytic__table table .partial-total td{background-color:#f0f0f0}.o-widget__analytic__table table .grand-total th,.o-widget__analytic__table table .grand-total td{background-color:#bdb9da}.o-widget__analytic__color-picker-container{margin-top:.625rem;gap:.9375rem;flex-wrap:wrap}.o-widget__analytic__color-picker{position:relative}.o-widget__analytic__color-picker-remove{position:absolute;right:-20px;top:-10px;z-index:2;color:#263340;padding:0}.o-widget__analytic__color-picker-add{padding:.75rem;border:1px solid #263340;border-radius:50%;width:20px}.cdk-drop-list-dragging .cdk-drag,.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.cdk-drop-list-dragging .o-widget__analytic__color-picker:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}.cdk-drag-preview{box-sizing:border-box;border-radius:50%;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}\n"] }]
|
|
10
10
|
}] });
|
|
11
11
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3NzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL3dpZGdldHMvd2lkZ2V0LWFuYWx5dGljL3N0eWxlL2Nzcy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFRN0QsTUFBTSxPQUFPLDZCQUE2Qjs4R0FBN0IsNkJBQTZCO2tHQUE3Qiw2QkFBNkIsK0RBSjlCLEVBQUU7OzJGQUlELDZCQUE2QjtrQkFOekMsU0FBUzsrQkFDRSx5QkFBeUIsWUFDekIsRUFBRSxpQkFFRyxpQkFBaUIsQ0FBQyxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwcnktd2lkZ2V0LWFuYWx5dGljLWNzcycsXG4gIHRlbXBsYXRlOiAnJyxcbiAgc3R5bGVVcmxzOiBbJy4vX28td2lkZ2V0LWFuYWx5dGljLnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxufSlcbmV4cG9ydCBjbGFzcyBQcnlXaWRnZXRBbmFseXRpY0Nzc0NvbXBvbmVudCB7fVxuIl19
|
|
@@ -4,11 +4,12 @@ import { NgModule } from '@angular/core';
|
|
|
4
4
|
import { FormsModule } from '@angular/forms';
|
|
5
5
|
import { BaseWidgetModule, PryCoreModule, PryDashboardModule, PryI18nModule, PryIconModule, PrySelectModule, PryToggleModule } from '@provoly/dashboard';
|
|
6
6
|
import { PryCheckboxModule } from '@provoly/dashboard/components/checkbox';
|
|
7
|
-
import { WidgetMapModule } from '@provoly/dashboard/widgets/widget-map';
|
|
8
7
|
import { WidgetAnalyticComponent } from './component/widget-analytic.component';
|
|
9
8
|
import { enTranslations } from './i18n/en.translations';
|
|
10
9
|
import { frTranslations } from './i18n/fr.translations';
|
|
11
10
|
import { PryWidgetAnalyticCssComponent } from './style/css.component';
|
|
11
|
+
import { PryColorPickerModule } from '@provoly/dashboard/components/color-picker';
|
|
12
|
+
import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
12
13
|
import * as i0 from "@angular/core";
|
|
13
14
|
import * as i1 from "@provoly/dashboard";
|
|
14
15
|
export class WidgetAnalyticModule extends BaseWidgetModule {
|
|
@@ -31,9 +32,10 @@ export class WidgetAnalyticModule extends BaseWidgetModule {
|
|
|
31
32
|
PryIconModule,
|
|
32
33
|
PryCheckboxModule,
|
|
33
34
|
PryToggleModule,
|
|
34
|
-
WidgetMapModule,
|
|
35
35
|
PryI18nModule,
|
|
36
|
-
AsyncPipe
|
|
36
|
+
AsyncPipe,
|
|
37
|
+
PryColorPickerModule,
|
|
38
|
+
DragDropModule], exports: [WidgetAnalyticComponent] }); }
|
|
37
39
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: WidgetAnalyticModule, imports: [CommonModule,
|
|
38
40
|
FormsModule,
|
|
39
41
|
OverlayModule,
|
|
@@ -43,8 +45,9 @@ export class WidgetAnalyticModule extends BaseWidgetModule {
|
|
|
43
45
|
PryIconModule,
|
|
44
46
|
PryCheckboxModule,
|
|
45
47
|
PryToggleModule,
|
|
46
|
-
|
|
47
|
-
|
|
48
|
+
PryI18nModule,
|
|
49
|
+
PryColorPickerModule,
|
|
50
|
+
DragDropModule] }); }
|
|
48
51
|
}
|
|
49
52
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: WidgetAnalyticModule, decorators: [{
|
|
50
53
|
type: NgModule,
|
|
@@ -60,11 +63,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
60
63
|
PryIconModule,
|
|
61
64
|
PryCheckboxModule,
|
|
62
65
|
PryToggleModule,
|
|
63
|
-
WidgetMapModule,
|
|
64
66
|
PryI18nModule,
|
|
65
|
-
AsyncPipe
|
|
67
|
+
AsyncPipe,
|
|
68
|
+
PryColorPickerModule,
|
|
69
|
+
DragDropModule
|
|
66
70
|
],
|
|
67
71
|
exports: [WidgetAnalyticComponent]
|
|
68
72
|
}]
|
|
69
73
|
}], ctorParameters: () => [{ type: i1.PryI18nService }] });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LWFuYWx5dGljLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL3dpZGdldHMvd2lkZ2V0LWFuYWx5dGljL3dpZGdldC1hbmFseXRpYy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDMUQsT0FBTyxFQUFFLFFBQVEsRUFBUSxNQUFNLGVBQWUsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUVMLGdCQUFnQixFQUNoQixhQUFhLEVBQ2Isa0JBQWtCLEVBQ2xCLGFBQWEsRUFFYixhQUFhLEVBQ2IsZUFBZSxFQUNmLGVBQWUsRUFDaEIsTUFBTSxvQkFBb0IsQ0FBQztBQUM1QixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUMzRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUNoRixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3hELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQ2xGLE9BQU8sRUFBd0IsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7OztBQXFCOUUsTUFBTSxPQUFPLG9CQUFxQixTQUFRLGdCQUFnQjtJQUN4RCxZQUFvQixtQkFBbUM7UUFDckQsS0FBSyxFQUFFLENBQUM7UUFEVSx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQWdCO1FBRXJELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLGFBQWEsRUFBRSxjQUFjLENBQUMsQ0FBQztRQUM1RSxJQUFJLENBQUMsbUJBQW1CLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxhQUFhLEVBQUUsY0FBYyxDQUFDLENBQUM7SUFDOUUsQ0FBQztJQUVRLFlBQVk7UUFDbkIsT0FBTyx1QkFBb0QsQ0FBQztJQUM5RCxDQUFDOzhHQVRVLG9CQUFvQjsrR0FBcEIsb0JBQW9CLGlCQWxCaEIsdUJBQXVCLEVBQUUsNkJBQTZCLGFBRW5FLFlBQVk7WUFDWixXQUFXO1lBQ1gsYUFBYTtZQUNiLGFBQWE7WUFDYixrQkFBa0I7WUFDbEIsZUFBZTtZQUNmLGFBQWE7WUFDYixpQkFBaUI7WUFDakIsZUFBZTtZQUNmLGFBQWE7WUFDYixTQUFTO1lBQ1Qsb0JBQW9CO1lBQ3BCLGNBQWMsYUFFTix1QkFBdUI7K0dBRXRCLG9CQUFvQixZQWhCN0IsWUFBWTtZQUNaLFdBQVc7WUFDWCxhQUFhO1lBQ2IsYUFBYTtZQUNiLGtCQUFrQjtZQUNsQixlQUFlO1lBQ2YsYUFBYTtZQUNiLGlCQUFpQjtZQUNqQixlQUFlO1lBQ2YsYUFBYTtZQUViLG9CQUFvQjtZQUNwQixjQUFjOzsyRkFJTCxvQkFBb0I7a0JBbkJoQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHVCQUF1QixFQUFFLDZCQUE2QixDQUFDO29CQUN0RSxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixrQkFBa0I7d0JBQ2xCLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixpQkFBaUI7d0JBQ2pCLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixTQUFTO3dCQUNULG9CQUFvQjt3QkFDcEIsY0FBYztxQkFDZjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztpQkFDbkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgQXN5bmNQaXBlLCBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUsIFR5cGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHtcbiAgQmFzZVdpZGdldENvbXBvbmVudCxcbiAgQmFzZVdpZGdldE1vZHVsZSxcbiAgUHJ5Q29yZU1vZHVsZSxcbiAgUHJ5RGFzaGJvYXJkTW9kdWxlLFxuICBQcnlJMThuTW9kdWxlLFxuICBQcnlJMThuU2VydmljZSxcbiAgUHJ5SWNvbk1vZHVsZSxcbiAgUHJ5U2VsZWN0TW9kdWxlLFxuICBQcnlUb2dnbGVNb2R1bGVcbn0gZnJvbSAnQHByb3ZvbHkvZGFzaGJvYXJkJztcbmltcG9ydCB7IFByeUNoZWNrYm94TW9kdWxlIH0gZnJvbSAnQHByb3ZvbHkvZGFzaGJvYXJkL2NvbXBvbmVudHMvY2hlY2tib3gnO1xuaW1wb3J0IHsgV2lkZ2V0QW5hbHl0aWNDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudC93aWRnZXQtYW5hbHl0aWMuY29tcG9uZW50JztcbmltcG9ydCB7IGVuVHJhbnNsYXRpb25zIH0gZnJvbSAnLi9pMThuL2VuLnRyYW5zbGF0aW9ucyc7XG5pbXBvcnQgeyBmclRyYW5zbGF0aW9ucyB9IGZyb20gJy4vaTE4bi9mci50cmFuc2xhdGlvbnMnO1xuaW1wb3J0IHsgUHJ5V2lkZ2V0QW5hbHl0aWNDc3NDb21wb25lbnQgfSBmcm9tICcuL3N0eWxlL2Nzcy5jb21wb25lbnQnO1xuaW1wb3J0IHsgUHJ5Q29sb3JQaWNrZXJNb2R1bGUgfSBmcm9tICdAcHJvdm9seS9kYXNoYm9hcmQvY29tcG9uZW50cy9jb2xvci1waWNrZXInO1xuaW1wb3J0IHsgQ2RrRHJhZywgQ2RrRHJvcExpc3QsIERyYWdEcm9wTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2RyYWctZHJvcCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1dpZGdldEFuYWx5dGljQ29tcG9uZW50LCBQcnlXaWRnZXRBbmFseXRpY0Nzc0NvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgT3ZlcmxheU1vZHVsZSxcbiAgICBQcnlDb3JlTW9kdWxlLFxuICAgIFByeURhc2hib2FyZE1vZHVsZSxcbiAgICBQcnlTZWxlY3RNb2R1bGUsXG4gICAgUHJ5SWNvbk1vZHVsZSxcbiAgICBQcnlDaGVja2JveE1vZHVsZSxcbiAgICBQcnlUb2dnbGVNb2R1bGUsXG4gICAgUHJ5STE4bk1vZHVsZSxcbiAgICBBc3luY1BpcGUsXG4gICAgUHJ5Q29sb3JQaWNrZXJNb2R1bGUsXG4gICAgRHJhZ0Ryb3BNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1dpZGdldEFuYWx5dGljQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBXaWRnZXRBbmFseXRpY01vZHVsZSBleHRlbmRzIEJhc2VXaWRnZXRNb2R1bGUge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHByeVRyYW5zbGF0ZVNlcnZpY2U6IFByeUkxOG5TZXJ2aWNlKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLnByeVRyYW5zbGF0ZVNlcnZpY2UuYWRkTGFuZ09iamVjdCgnZnInLCAnd2lkZ2V0LXZlZ2EnLCBmclRyYW5zbGF0aW9ucyk7XG4gICAgdGhpcy5wcnlUcmFuc2xhdGVTZXJ2aWNlLmFkZExhbmdPYmplY3QoJ2VuJywgJ3dpZGdldC12ZWdhJywgZW5UcmFuc2xhdGlvbnMpO1xuICB9XG5cbiAgb3ZlcnJpZGUgZ2V0Q29tcG9uZW50KCkge1xuICAgIHJldHVybiBXaWRnZXRBbmFseXRpY0NvbXBvbmVudCBhcyBUeXBlPEJhc2VXaWRnZXRDb21wb25lbnQ+O1xuICB9XG59XG4iXX0=
|
|
@@ -8,24 +8,41 @@ class PrySinceDatePipe {
|
|
|
8
8
|
}
|
|
9
9
|
transform(value, ...args) {
|
|
10
10
|
const date = new Date(value);
|
|
11
|
-
|
|
12
|
-
const dayDif = this.getDayDiff(date, dateNow);
|
|
13
|
-
if (dayDif > 30 || (!!args[0] && args[0].onlyLocale)) {
|
|
11
|
+
if (!!args[0] && args[0].onlyLocale) {
|
|
14
12
|
return date.toLocaleString();
|
|
15
13
|
}
|
|
16
|
-
|
|
17
|
-
return
|
|
14
|
+
if (isNaN(date.getTime())) {
|
|
15
|
+
return '';
|
|
16
|
+
}
|
|
17
|
+
const dateNow = this._now ?? new Date();
|
|
18
|
+
if (date.getFullYear() === dateNow.getFullYear() &&
|
|
19
|
+
date.getMonth() === dateNow.getMonth() &&
|
|
20
|
+
date.getDate() === dateNow.getDate()) {
|
|
21
|
+
return this.translateService.instant('@pry.toolbox.today', {
|
|
22
|
+
hour: `${date.getHours()}`.padStart(2, '0'),
|
|
23
|
+
min: `${date.getMinutes()}`.padStart(2, '0')
|
|
24
|
+
});
|
|
18
25
|
}
|
|
19
|
-
|
|
20
|
-
|
|
26
|
+
const dayDiff = this.getDayDiff(date, dateNow);
|
|
27
|
+
const dayDiffAbs = Math.ceil(Math.abs(dayDiff));
|
|
28
|
+
const dayDiffPast = dayDiff > 0;
|
|
29
|
+
if (dayDiffAbs > 30) {
|
|
30
|
+
return date.toLocaleString();
|
|
21
31
|
}
|
|
22
32
|
else {
|
|
23
|
-
return ''
|
|
33
|
+
return this.translateService.instant(dayDiffPast ? '@pry.toolbox.since_day' : '@pry.toolbox.from_day', {
|
|
34
|
+
day: dayDiffAbs,
|
|
35
|
+
plural: dayDiffAbs >= 2 ? 's' : ''
|
|
36
|
+
});
|
|
24
37
|
}
|
|
25
38
|
}
|
|
26
39
|
getDayDiff(startDate, endDate) {
|
|
27
40
|
const msInDay = 24 * 60 * 60 * 1000;
|
|
28
|
-
return
|
|
41
|
+
return (endDate.getTime() - startDate.getTime()) / msInDay;
|
|
42
|
+
}
|
|
43
|
+
useNow(date) {
|
|
44
|
+
this._now = date;
|
|
45
|
+
return this;
|
|
29
46
|
}
|
|
30
47
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PrySinceDatePipe, deps: [{ token: i1.PryI18nService }], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
31
48
|
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.1.3", ngImport: i0, type: PrySinceDatePipe, name: "sinceDate" }); }
|