@esfaenza/dashboard-feature 11.2.12 → 15.2.0
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/esm2020/esfaenza-dashboard-feature.mjs +5 -0
- package/esm2020/lib/components/dashboard/dashboard.component.loc.mjs +15 -0
- package/esm2020/lib/components/dashboard/dashboard.component.mjs +172 -0
- package/esm2020/lib/components/widgets/BaseWidgetComponent.mjs +86 -0
- package/esm2020/lib/components/widgets/chart/jace-dsh-chart.component.mjs +81 -0
- package/esm2020/lib/components/widgets/counter/jace-dsh-counter.component.mjs +80 -0
- package/esm2020/lib/components/widgets/list/jace-dsh-list.component.mjs +91 -0
- package/esm2020/lib/components/widgets/multiprog/jace-dsh-multiprog.component.mjs +82 -0
- package/esm2020/lib/dashboard-feature.module.mjs +134 -0
- package/esm2020/lib/models/config/JaceDashboardConfig.mjs +57 -0
- package/esm2020/lib/models/widgets/BaseJaceWidgetModel.mjs +24 -0
- package/esm2020/lib/models/widgets/JaceMultiprogWidgetModel.mjs +28 -0
- package/esm2020/lib/services/DashboardWidgetFactory.mjs +89 -0
- package/esm2020/lib/services/dashboard-feature.service.mjs +43 -0
- package/fesm2015/esfaenza-dashboard-feature.mjs +1131 -0
- package/fesm2015/esfaenza-dashboard-feature.mjs.map +1 -0
- package/fesm2020/esfaenza-dashboard-feature.mjs +1112 -0
- package/fesm2020/esfaenza-dashboard-feature.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/dashboard/dashboard.component.d.ts +3 -0
- package/lib/components/dashboard/dashboard.component.loc.d.ts +5 -2
- package/lib/components/widgets/BaseWidgetComponent.d.ts +3 -0
- package/lib/components/widgets/chart/jace-dsh-chart.component.d.ts +3 -0
- package/lib/components/widgets/counter/jace-dsh-counter.component.d.ts +3 -0
- package/lib/components/widgets/list/jace-dsh-list.component.d.ts +3 -0
- package/lib/components/widgets/multiprog/jace-dsh-multiprog.component.d.ts +3 -0
- package/lib/dashboard-feature.module.d.ts +17 -0
- package/lib/services/DashboardWidgetFactory.d.ts +3 -0
- package/lib/services/dashboard-feature.service.d.ts +3 -0
- package/package.json +29 -16
- package/bundles/esfaenza-dashboard-feature.umd.js +0 -1470
- package/bundles/esfaenza-dashboard-feature.umd.js.map +0 -1
- package/bundles/esfaenza-dashboard-feature.umd.min.js +0 -2
- package/bundles/esfaenza-dashboard-feature.umd.min.js.map +0 -1
- package/esfaenza-dashboard-feature.d.ts +0 -6
- package/esfaenza-dashboard-feature.metadata.json +0 -1
- package/esm2015/esfaenza-dashboard-feature.js +0 -7
- package/esm2015/lib/components/dashboard/dashboard.component.js +0 -170
- package/esm2015/lib/components/dashboard/dashboard.component.loc.js +0 -16
- package/esm2015/lib/components/widgets/BaseWidgetComponent.js +0 -83
- package/esm2015/lib/components/widgets/chart/jace-dsh-chart.component.js +0 -79
- package/esm2015/lib/components/widgets/counter/jace-dsh-counter.component.js +0 -79
- package/esm2015/lib/components/widgets/list/jace-dsh-list.component.js +0 -91
- package/esm2015/lib/components/widgets/multiprog/jace-dsh-multiprog.component.js +0 -80
- package/esm2015/lib/dashboard-feature.module.js +0 -112
- package/esm2015/lib/models/config/JaceDashboardConfig.js +0 -54
- package/esm2015/lib/models/widgets/BaseJaceWidgetModel.js +0 -25
- package/esm2015/lib/models/widgets/JaceMultiprogWidgetModel.js +0 -29
- package/esm2015/lib/services/DashboardWidgetFactory.js +0 -90
- package/esm2015/lib/services/dashboard-feature.service.js +0 -41
- package/fesm2015/esfaenza-dashboard-feature.js +0 -1090
- package/fesm2015/esfaenza-dashboard-feature.js.map +0 -1
- /package/{esm2015/lib/components/widgets/IWidgetComponent.js → esm2020/lib/components/widgets/IWidgetComponent.mjs} +0 -0
- /package/{esm2015/lib/components/widgets/JaceWidgetTypes.js → esm2020/lib/components/widgets/JaceWidgetTypes.mjs} +0 -0
- /package/{esm2015/lib/models/externals/JaceDashboardLayoutAppSearch.js → esm2020/lib/models/externals/JaceDashboardLayoutAppSearch.mjs} +0 -0
- /package/{esm2015/lib/models/externals/JaceDashboardLayoutDetail.js → esm2020/lib/models/externals/JaceDashboardLayoutDetail.mjs} +0 -0
- /package/{esm2015/lib/models/externals/JaceWidgetInstanceDetail.js → esm2020/lib/models/externals/JaceWidgetInstanceDetail.mjs} +0 -0
- /package/{esm2015/lib/models/externals/Repository.js → esm2020/lib/models/externals/Repository.mjs} +0 -0
- /package/{esm2015/lib/models/externals/SaveJaceDashboardLayoutDTO.js → esm2020/lib/models/externals/SaveJaceDashboardLayoutDTO.mjs} +0 -0
- /package/{esm2015/lib/models/options/DefaultDashboardModuleOptions.js → esm2020/lib/models/options/DefaultDashboardModuleOptions.mjs} +0 -0
- /package/{esm2015/lib/models/options/IDashboardModuleOptions.js → esm2020/lib/models/options/IDashboardModuleOptions.mjs} +0 -0
- /package/{esm2015/lib/models/options/IWidgetTypeConfig.js → esm2020/lib/models/options/IWidgetTypeConfig.mjs} +0 -0
- /package/{esm2015/lib/models/widgets/IJaceWidgetModel.js → esm2020/lib/models/widgets/IJaceWidgetModel.mjs} +0 -0
- /package/{esm2015/lib/models/widgets/JaceChartWidgetModel.js → esm2020/lib/models/widgets/JaceChartWidgetModel.mjs} +0 -0
- /package/{esm2015/lib/models/widgets/JaceCounterWidgetModel.js → esm2020/lib/models/widgets/JaceCounterWidgetModel.mjs} +0 -0
- /package/{esm2015/lib/models/widgets/JaceListWidgetModel.js → esm2020/lib/models/widgets/JaceListWidgetModel.mjs} +0 -0
- /package/{esm2015/lib/private-injection-tokens.js → esm2020/lib/private-injection-tokens.mjs} +0 -0
- /package/{esm2015/lib/public-injection-tokens.js → esm2020/lib/public-injection-tokens.mjs} +0 -0
- /package/{esm2015/lib/services/IDashboardFeatureDataService.js → esm2020/lib/services/IDashboardFeatureDataService.mjs} +0 -0
- /package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNmYWVuemEtZGFzaGJvYXJkLWZlYXR1cmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9kYXNoYm9hcmQtZmVhdHVyZS9zcmMvZXNmYWVuemEtZGFzaGJvYXJkLWZlYXR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import { LocalizationService } from "@esfaenza/localizations";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class DashboardLoc extends LocalizationService {
|
|
5
|
+
constructor(injector) {
|
|
6
|
+
super(injector);
|
|
7
|
+
super.set("en->it", "Dashboard", ["Dashboard"]);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
DashboardLoc.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardLoc, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
11
|
+
DashboardLoc.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardLoc });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardLoc, decorators: [{
|
|
13
|
+
type: Injectable
|
|
14
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }]; } });
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGFzaGJvYXJkLmNvbXBvbmVudC5sb2MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXNoYm9hcmQtZmVhdHVyZS9zcmMvbGliL2NvbXBvbmVudHMvZGFzaGJvYXJkL2Rhc2hib2FyZC5jb21wb25lbnQubG9jLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQVksTUFBTSxlQUFlLENBQUM7QUFDckQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBSzlELE1BQU0sT0FBTyxZQUFhLFNBQVEsbUJBQW1CO0lBQ2pELFlBQVksUUFBa0I7UUFDMUIsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ2hCLEtBQUssQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLFdBQVcsRUFBRSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7SUFFcEQsQ0FBQzs7MEdBTFEsWUFBWTs4R0FBWixZQUFZOzRGQUFaLFlBQVk7a0JBRHhCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3RvciB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IExvY2FsaXphdGlvblNlcnZpY2UgfSBmcm9tIFwiQGVzZmFlbnphL2xvY2FsaXphdGlvbnNcIjtcclxuXHJcblxyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgRGFzaGJvYXJkTG9jIGV4dGVuZHMgTG9jYWxpemF0aW9uU2VydmljZSB7XHJcbiAgICBjb25zdHJ1Y3RvcihpbmplY3RvcjogSW5qZWN0b3IpIHtcclxuICAgICAgICBzdXBlcihpbmplY3Rvcik7XHJcbiAgICAgICAgc3VwZXIuc2V0KFwiZW4tPml0XCIsIFwiRGFzaGJvYXJkXCIsIFtcIkRhc2hib2FyZFwiXSk7XHJcbiAgICAgICAgXHJcbiAgICB9XHJcbn0iXX0=
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { Component, Inject, Input, ViewChildren, ViewContainerRef, ViewEncapsulation } from "@angular/core";
|
|
2
|
+
import { InboundMessageTypes } from "@esfaenza/extensions";
|
|
3
|
+
import { LocalizationService } from "@esfaenza/localizations";
|
|
4
|
+
import { DashboardLoc } from "./dashboard.component.loc";
|
|
5
|
+
import { SaveJaceDashboardLayoutDTO } from "../../models/externals/SaveJaceDashboardLayoutDTO";
|
|
6
|
+
import { JaceWidgetInstanceDetail } from "../../models/externals/JaceWidgetInstanceDetail";
|
|
7
|
+
import { Subject, timer } from "rxjs";
|
|
8
|
+
import { map, takeUntil } from "rxjs/operators";
|
|
9
|
+
import { DSH_DATA_SERVICE } from "../../public-injection-tokens";
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@esfaenza/extensions";
|
|
12
|
+
import * as i2 from "@esfaenza/localizations";
|
|
13
|
+
import * as i3 from "@angular/router";
|
|
14
|
+
import * as i4 from "../../services/DashboardWidgetFactory";
|
|
15
|
+
import * as i5 from "@angular/common";
|
|
16
|
+
import * as i6 from "@angular/forms";
|
|
17
|
+
import * as i7 from "angular-gridster2";
|
|
18
|
+
import * as i8 from "@esfaenza/forms-and-validations";
|
|
19
|
+
/**
|
|
20
|
+
* Componente di base che rappresenta una dashboard.
|
|
21
|
+
* Utilizza Gridster2 per il layout delle widget [Gridster2](https://tiberiuzuld.github.io/angular-gridster2/)
|
|
22
|
+
*/
|
|
23
|
+
export class DashboardComponent {
|
|
24
|
+
constructor(dshService, intercom, lc, route, cmpFactory, cdr) {
|
|
25
|
+
this.dshService = dshService;
|
|
26
|
+
this.intercom = intercom;
|
|
27
|
+
this.lc = lc;
|
|
28
|
+
this.route = route;
|
|
29
|
+
this.cmpFactory = cmpFactory;
|
|
30
|
+
this.cdr = cdr;
|
|
31
|
+
this.dashboardDate = new Date();
|
|
32
|
+
this.widgetDefinitions = [];
|
|
33
|
+
this.trackedSubscriptions = [];
|
|
34
|
+
this.destroySignal$ = new Subject();
|
|
35
|
+
this.intercom.send(InboundMessageTypes.Navigation, { sub: false, routeTitle: this.lc.loc(this.route.snapshot.data["title"]) });
|
|
36
|
+
}
|
|
37
|
+
ngOnInit() {
|
|
38
|
+
}
|
|
39
|
+
ngAfterViewInit() {
|
|
40
|
+
//qui this.gridItemRefs è 'riempito'
|
|
41
|
+
// sottoscrivo changes che sparerà tutte le volte che ngFor si aggiorna (ovvero quando cambia dashboard)
|
|
42
|
+
this.changesSub = this.gridItemRefs.changes.pipe(takeUntil(this.destroySignal$)).subscribe((comps) => {
|
|
43
|
+
this.renderLayout(comps);
|
|
44
|
+
});
|
|
45
|
+
//prima volta
|
|
46
|
+
//setTimeout(()=>this.reloadData(),500);
|
|
47
|
+
this.trackedSubscriptions.push(timer(500).pipe(takeUntil(this.destroySignal$), map(() => this.reloadData())).subscribe());
|
|
48
|
+
}
|
|
49
|
+
ngOnDestroy() {
|
|
50
|
+
//unsubscribe dalle changes dei viewref
|
|
51
|
+
if (this.changesSub)
|
|
52
|
+
this.changesSub.unsubscribe();
|
|
53
|
+
this.clearTrackedSubscriptions();
|
|
54
|
+
this.destroySignal$.next();
|
|
55
|
+
this.destroySignal$.complete();
|
|
56
|
+
}
|
|
57
|
+
clearTrackedSubscriptions() {
|
|
58
|
+
if (this.trackedSubscriptions) {
|
|
59
|
+
for (let index = 0; index < this.trackedSubscriptions.length; index++) {
|
|
60
|
+
const element = this.trackedSubscriptions[index];
|
|
61
|
+
element.unsubscribe();
|
|
62
|
+
}
|
|
63
|
+
this.trackedSubscriptions = [];
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
ngOnChanges(changes) {
|
|
67
|
+
//occhio: arriva prima di ngAfterViewInit
|
|
68
|
+
if (changes.Configuration) {
|
|
69
|
+
//appena ho configuration
|
|
70
|
+
console.log(changes.Configuration);
|
|
71
|
+
// la prima volta l'ho già fatta alla creazione del componente
|
|
72
|
+
if (!changes.Configuration.firstChange) {
|
|
73
|
+
this.reloadData();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
reloadData() {
|
|
78
|
+
if (!this.Configuration)
|
|
79
|
+
return;
|
|
80
|
+
this.dshService.GetUserDashboard(this.Configuration.backendId, this.Configuration.accountId, this.Configuration.dashboardName).pipe(takeUntil(this.destroySignal$)).subscribe(c => {
|
|
81
|
+
this.dashboardLayout = c;
|
|
82
|
+
this.widgetDefinitions = c.widgets.map(i => {
|
|
83
|
+
return this.cmpFactory.resolveDefinition(i.type, i);
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
removeItem(widgetName) {
|
|
88
|
+
if (!this.dashboardLayout)
|
|
89
|
+
return;
|
|
90
|
+
let idx = this.dashboardLayout.widgets.findIndex(s => s.name == widgetName);
|
|
91
|
+
this.widgetDefinitions.splice(idx, 1);
|
|
92
|
+
}
|
|
93
|
+
saveDashboard() {
|
|
94
|
+
if (!this.dashboardLayout)
|
|
95
|
+
return;
|
|
96
|
+
const dto = new SaveJaceDashboardLayoutDTO();
|
|
97
|
+
dto.backendid = this.Configuration.backendId;
|
|
98
|
+
dto.widgets = [];
|
|
99
|
+
for (let index = 0; index < this.widgetDefinitions.length; index++) {
|
|
100
|
+
const w = this.widgetDefinitions[index];
|
|
101
|
+
if (w == null)
|
|
102
|
+
continue;
|
|
103
|
+
let v = new JaceWidgetInstanceDetail();
|
|
104
|
+
v.id = w.id;
|
|
105
|
+
v.name = w.name;
|
|
106
|
+
v.x = w.x;
|
|
107
|
+
v.y = w.y;
|
|
108
|
+
v.cols = w.cols;
|
|
109
|
+
v.rows = w.rows;
|
|
110
|
+
v.compactenabled = w.compactEnabled;
|
|
111
|
+
v.dragenabled = w.dragEnabled;
|
|
112
|
+
v.resizeenabled = w.resizeEnabled;
|
|
113
|
+
v.type = w.widgetType;
|
|
114
|
+
v.title = w.title;
|
|
115
|
+
v.options = w.options;
|
|
116
|
+
dto.widgets.push(v);
|
|
117
|
+
}
|
|
118
|
+
this.dshService.SaveUserDashboard(dto).subscribe(res => {
|
|
119
|
+
if (res.success)
|
|
120
|
+
console.log('Dashboard saved');
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
renderLayout(comps) {
|
|
124
|
+
this.clearTrackedSubscriptions();
|
|
125
|
+
comps.map((host, index) => {
|
|
126
|
+
const vcr = host;
|
|
127
|
+
vcr.clear();
|
|
128
|
+
const widgetData = this.widgetDefinitions[index];
|
|
129
|
+
if (!widgetData || !widgetData.widgetType)
|
|
130
|
+
return;
|
|
131
|
+
let componentRef;
|
|
132
|
+
componentRef = this.cmpFactory.resolveComponent(widgetData?.widgetType, vcr);
|
|
133
|
+
if (!componentRef) {
|
|
134
|
+
console.log(`Tipo widget sconosciuto ${widgetData.widgetType}`);
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
//setta l'input della data
|
|
138
|
+
if (this.Configuration.showDateInput)
|
|
139
|
+
componentRef.instance.DashboardDate = this.dashboardDate;
|
|
140
|
+
//setta il modello
|
|
141
|
+
componentRef.instance.setWidgetModel(this.Configuration.backendId, widgetData);
|
|
142
|
+
//setta la callback per OnRemove
|
|
143
|
+
let s = componentRef.instance.OnRemove.pipe(takeUntil(this.destroySignal$)).subscribe(name => this.removeItem(name));
|
|
144
|
+
this.trackedSubscriptions.push(s);
|
|
145
|
+
//componentRef.changeDetectorRef.markForCheck();
|
|
146
|
+
//componentRef.changeDetectorRef.detectChanges();
|
|
147
|
+
});
|
|
148
|
+
this.cdr.detectChanges();
|
|
149
|
+
}
|
|
150
|
+
addItem() {
|
|
151
|
+
//this.dashboard.push({});
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
DashboardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardComponent, deps: [{ token: DSH_DATA_SERVICE }, { token: i1.InterComService }, { token: i2.LocalizationService }, { token: i3.ActivatedRoute }, { token: i4.DashboardWidgetFactory }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
155
|
+
DashboardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DashboardComponent, selector: "dashboard", inputs: { Configuration: "Configuration" }, providers: [
|
|
156
|
+
{ provide: LocalizationService, useClass: DashboardLoc }
|
|
157
|
+
], viewQueries: [{ propertyName: "gridItemRefs", predicate: ["grid_item"], descendants: true, read: ViewContainerRef }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"Configuration\">\r\n\r\n <form role=\"form\" class=\"jace-dsh-toolbar\" *ngIf=\"Configuration.showToolbar\">\r\n <div *ngIf=\"Configuration.dashboardTitle\" class=\"jace-dsh-toolbar-title\">\r\n {{Configuration.dashboardTitle}}\r\n </div>\r\n <div class=\"jace-dsh-toolbar-dtp\" *ngIf=\"Configuration?.showDateInput\">\r\n <form-date [JsDates]=\"true\" [FormLayout]=\"false\" id=\"txt_dashboarddate\" [Validation]=\"false\"\r\n autocomplete=\"off\" [(ngModel)]=\"dashboardDate\" name=\"dashboarddate\" [Placeholder]=\"'Dashboard Date'\">\r\n </form-date>\r\n </div>\r\n <div class=\"jace-dsh-save-button\" (click)=\"saveDashboard()\">\r\n <span class=\"transition\">\r\n <i class=\"fa fa-save\"></i>\r\n </span>\r\n </div>\r\n </form>\r\n\r\n <gridster [options]=\"Configuration.gridsterConfig\" class=\"jace-dsh-widget-area\">\r\n <gridster-item [item]=\"item\" *ngFor=\"let item of widgetDefinitions\" class=\"jace-dsh-widget {{item.name}}\">\r\n <!-- <ng-container *ngFor=\"let item of widgetDefinitions\"> -->\r\n <ng-template #grid_item></ng-template>\r\n <!-- </ng-container> -->\r\n </gridster-item>\r\n </gridster>\r\n\r\n</ng-container>", styles: [".jace-dsh-toolbar{font-size:smaller;display:flex;flex-flow:row;justify-content:flex-end;align-items:center;padding:0 1em .5em}.jace-dsh-toolbar-title{flex:2 1 auto;font-size:2em;color:#777;font-variant:small-caps}.jace-dsh-toolbar-dtp{flex:1 1 auto}.jace-dsh-save-button{font-size:larger;padding:.5em 1em;border-radius:4px;border:1px solid #ddd;color:#777;margin-left:.5em;cursor:pointer;flex:0 0 auto}.jace-dsh-save-button:hover{color:#000;border-color:#000}.jace-dsh-widget-area{background:#e9ebee;scroll-behavior:auto}.jace-dsh-widget{border:solid 1px #ddd;border-radius:5px;min-width:204px}.jace-dsh-widget-header{margin:0rem .5rem;display:flex;flex-flow:row;justify-content:left;align-items:center}.jace-dsh-widget-title{padding:.5rem .2rem .3rem;border-bottom:solid 1px #ddd;text-transform:uppercase;font-size:.8rem}.jace-dsh-widget-body{margin:0rem .5rem;display:flex;flex-wrap:nowrap;overflow-x:clip}.jace-dsh-widget-loading{padding:.5rem;width:100%;flex:0 0 auto;font-size:4rem;font-weight:700;text-align:center}.jace-dsh-widget-slide{transition-property:transform;transition-duration:.75s;transition-timing-function:ease;width:100%;flex:0 0 auto}.jace-dsh-widget-content-show{transform:translate(0) translateZ(0)}.jace-dsh-widget-content-hide,.jace-dsh-widget-settings-show{transform:translate(-100%) translateZ(0)}.jace-dsh-widget-settings-hide{transform:translate(0) translateZ(0)}.jace-dsh-widget-settings{padding:.5rem;width:100%;flex:0 0 auto}.jace-dsh-widget-controls{margin-left:auto;order:2;z-index:1;top:0rem;right:0rem;padding:.2rem .1rem;font-size:1rem;color:#bbb;align-items:center;cursor:pointer}.jace-dsh-widget-drag{font-size:.78em}.jace-dsh-widget-opts{font-size:.92em}.jace-dsh-widget-close{font-size:1.1em}.jace-dsh-widget-controls span{margin-right:.1rem;margin-left:.1rem}.jace-dsh-widget-controls span:hover{color:#637ca0}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i7.GridsterComponent, selector: "gridster", inputs: ["options"] }, { kind: "component", type: i7.GridsterItemComponent, selector: "gridster-item", inputs: ["item"] }, { kind: "component", type: i8.FormDateComponent, selector: "form-date", inputs: ["JsDates"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
158
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardComponent, decorators: [{
|
|
159
|
+
type: Component,
|
|
160
|
+
args: [{ selector: 'dashboard', encapsulation: ViewEncapsulation.None, providers: [
|
|
161
|
+
{ provide: LocalizationService, useClass: DashboardLoc }
|
|
162
|
+
], template: "<ng-container *ngIf=\"Configuration\">\r\n\r\n <form role=\"form\" class=\"jace-dsh-toolbar\" *ngIf=\"Configuration.showToolbar\">\r\n <div *ngIf=\"Configuration.dashboardTitle\" class=\"jace-dsh-toolbar-title\">\r\n {{Configuration.dashboardTitle}}\r\n </div>\r\n <div class=\"jace-dsh-toolbar-dtp\" *ngIf=\"Configuration?.showDateInput\">\r\n <form-date [JsDates]=\"true\" [FormLayout]=\"false\" id=\"txt_dashboarddate\" [Validation]=\"false\"\r\n autocomplete=\"off\" [(ngModel)]=\"dashboardDate\" name=\"dashboarddate\" [Placeholder]=\"'Dashboard Date'\">\r\n </form-date>\r\n </div>\r\n <div class=\"jace-dsh-save-button\" (click)=\"saveDashboard()\">\r\n <span class=\"transition\">\r\n <i class=\"fa fa-save\"></i>\r\n </span>\r\n </div>\r\n </form>\r\n\r\n <gridster [options]=\"Configuration.gridsterConfig\" class=\"jace-dsh-widget-area\">\r\n <gridster-item [item]=\"item\" *ngFor=\"let item of widgetDefinitions\" class=\"jace-dsh-widget {{item.name}}\">\r\n <!-- <ng-container *ngFor=\"let item of widgetDefinitions\"> -->\r\n <ng-template #grid_item></ng-template>\r\n <!-- </ng-container> -->\r\n </gridster-item>\r\n </gridster>\r\n\r\n</ng-container>", styles: [".jace-dsh-toolbar{font-size:smaller;display:flex;flex-flow:row;justify-content:flex-end;align-items:center;padding:0 1em .5em}.jace-dsh-toolbar-title{flex:2 1 auto;font-size:2em;color:#777;font-variant:small-caps}.jace-dsh-toolbar-dtp{flex:1 1 auto}.jace-dsh-save-button{font-size:larger;padding:.5em 1em;border-radius:4px;border:1px solid #ddd;color:#777;margin-left:.5em;cursor:pointer;flex:0 0 auto}.jace-dsh-save-button:hover{color:#000;border-color:#000}.jace-dsh-widget-area{background:#e9ebee;scroll-behavior:auto}.jace-dsh-widget{border:solid 1px #ddd;border-radius:5px;min-width:204px}.jace-dsh-widget-header{margin:0rem .5rem;display:flex;flex-flow:row;justify-content:left;align-items:center}.jace-dsh-widget-title{padding:.5rem .2rem .3rem;border-bottom:solid 1px #ddd;text-transform:uppercase;font-size:.8rem}.jace-dsh-widget-body{margin:0rem .5rem;display:flex;flex-wrap:nowrap;overflow-x:clip}.jace-dsh-widget-loading{padding:.5rem;width:100%;flex:0 0 auto;font-size:4rem;font-weight:700;text-align:center}.jace-dsh-widget-slide{transition-property:transform;transition-duration:.75s;transition-timing-function:ease;width:100%;flex:0 0 auto}.jace-dsh-widget-content-show{transform:translate(0) translateZ(0)}.jace-dsh-widget-content-hide,.jace-dsh-widget-settings-show{transform:translate(-100%) translateZ(0)}.jace-dsh-widget-settings-hide{transform:translate(0) translateZ(0)}.jace-dsh-widget-settings{padding:.5rem;width:100%;flex:0 0 auto}.jace-dsh-widget-controls{margin-left:auto;order:2;z-index:1;top:0rem;right:0rem;padding:.2rem .1rem;font-size:1rem;color:#bbb;align-items:center;cursor:pointer}.jace-dsh-widget-drag{font-size:.78em}.jace-dsh-widget-opts{font-size:.92em}.jace-dsh-widget-close{font-size:1.1em}.jace-dsh-widget-controls span{margin-right:.1rem;margin-left:.1rem}.jace-dsh-widget-controls span:hover{color:#637ca0}\n"] }]
|
|
163
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
164
|
+
type: Inject,
|
|
165
|
+
args: [DSH_DATA_SERVICE]
|
|
166
|
+
}] }, { type: i1.InterComService }, { type: i2.LocalizationService }, { type: i3.ActivatedRoute }, { type: i4.DashboardWidgetFactory }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { Configuration: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], gridItemRefs: [{
|
|
169
|
+
type: ViewChildren,
|
|
170
|
+
args: ['grid_item', { read: ViewContainerRef }]
|
|
171
|
+
}] } });
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.component.js","sourceRoot":"","sources":["../../../../../../projects/dashboard-feature/src/lib/components/dashboard/dashboard.component.ts","../../../../../../projects/dashboard-feature/src/lib/components/dashboard/dashboard.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, ComponentRef, Inject, Input, OnChanges, OnDestroy, OnInit, QueryList, SimpleChanges, ViewChildren, ViewContainerRef, ViewEncapsulation } from \"@angular/core\";\r\nimport { JaceDashboardConfig } from \"../../models/config/JaceDashboardConfig\";\r\nimport { IJaceWidgetModel } from \"../../models/widgets/IJaceWidgetModel\";\r\nimport { InboundMessageTypes, InterComService } from \"@esfaenza/extensions\";\r\n\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\nimport { DashboardLoc } from \"./dashboard.component.loc\";\r\nimport { ActivatedRoute } from \"@angular/router\";\r\nimport { SaveJaceDashboardLayoutDTO } from \"../../models/externals/SaveJaceDashboardLayoutDTO\";\r\nimport { JaceWidgetInstanceDetail } from \"../../models/externals/JaceWidgetInstanceDetail\";\r\nimport { JaceDashboardLayoutDetail } from \"../../models/externals/JaceDashboardLayoutDetail\";\r\nimport { DashboardWidgetFactory } from \"../../services/DashboardWidgetFactory\";\r\nimport { interval, scheduled, Subject, Subscription, timer } from \"rxjs\";\r\nimport { delay, map, take, takeUntil } from \"rxjs/operators\";\r\nimport { IWidgetComponent } from \"../widgets/IWidgetComponent\";\r\nimport { DSH_DATA_SERVICE } from \"../../public-injection-tokens\";\r\nimport { IDashboardFeatureDataService } from \"../../services/IDashboardFeatureDataService\";\r\n\r\n/**\r\n * Componente di base che rappresenta una dashboard.\r\n * Utilizza Gridster2 per il layout delle widget [Gridster2](https://tiberiuzuld.github.io/angular-gridster2/)\r\n */\r\n@Component({\r\n    selector: 'dashboard',\r\n    encapsulation: ViewEncapsulation.None,\r\n    providers: [\r\n        { provide: LocalizationService, useClass: DashboardLoc }\r\n    ],\r\n    templateUrl: './dashboard.component.html',\r\n    styleUrls: ['./dashboard.component.css']\r\n})\r\nexport class DashboardComponent implements OnInit, AfterViewInit, OnDestroy, OnChanges {\r\n    /**\r\n     * Configurazione di questa dashboard.\r\n     * Contiene anche le configurazioni di layout di Gridster2\r\n     */\r\n    @Input() Configuration!: JaceDashboardConfig;\r\n\r\n    public dashboardDate = new Date();\r\n    public dashboardLayout?: JaceDashboardLayoutDetail;\r\n\r\n    widgetDefinitions: (IJaceWidgetModel | null)[] = [];\r\n\r\n    changesSub?: Subscription;\r\n\r\n    trackedSubscriptions: Subscription[] = [];\r\n\r\n    readonly destroySignal$: Subject<void> = new Subject<void>();\r\n\r\n    @ViewChildren('grid_item', { read: ViewContainerRef }) gridItemRefs!: QueryList<ViewContainerRef>;\r\n\r\n    constructor(\r\n        @Inject(DSH_DATA_SERVICE) private dshService: IDashboardFeatureDataService,\r\n        private intercom: InterComService,\r\n        public lc: LocalizationService,\r\n        private route: ActivatedRoute,\r\n        private cmpFactory: DashboardWidgetFactory,\r\n        private cdr: ChangeDetectorRef\r\n    ) {\r\n\r\n        this.intercom.send(InboundMessageTypes.Navigation, { sub: false, routeTitle: this.lc.loc(this.route.snapshot.data[\"title\"]) });\r\n    }\r\n\r\n\r\n\r\n    public ngOnInit() {\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n\r\n        //qui this.gridItemRefs è 'riempito'\r\n        // sottoscrivo changes che sparerà tutte le volte che ngFor si aggiorna (ovvero quando cambia dashboard)\r\n        this.changesSub = this.gridItemRefs.changes.pipe(\r\n            takeUntil(this.destroySignal$)\r\n        ).subscribe((comps: QueryList<ViewContainerRef>) => {\r\n            this.renderLayout(comps);\r\n        });\r\n        //prima volta\r\n\r\n        //setTimeout(()=>this.reloadData(),500);\r\n        this.trackedSubscriptions.push(timer(500).pipe(\r\n            takeUntil(this.destroySignal$),\r\n            map(() => this.reloadData())\r\n        ).subscribe()\r\n        );\r\n    }\r\n\r\n\r\n\r\n    ngOnDestroy(): void {\r\n        //unsubscribe dalle changes dei viewref\r\n        if (this.changesSub)\r\n            this.changesSub.unsubscribe();\r\n\r\n        this.clearTrackedSubscriptions();\r\n\r\n        this.destroySignal$.next();\r\n        this.destroySignal$.complete();\r\n    }\r\n\r\n    clearTrackedSubscriptions() {\r\n        if (this.trackedSubscriptions) {\r\n            for (let index = 0; index < this.trackedSubscriptions.length; index++) {\r\n                const element = this.trackedSubscriptions[index];\r\n                element.unsubscribe();\r\n            }\r\n            this.trackedSubscriptions = [];\r\n        }\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        //occhio: arriva prima di ngAfterViewInit\r\n        if (changes.Configuration) {\r\n\r\n            //appena ho configuration            \r\n            console.log(changes.Configuration);\r\n            // la prima volta l'ho già fatta alla creazione del componente\r\n            if(!changes.Configuration.firstChange){\r\n                this.reloadData();\r\n            }\r\n        }\r\n    }\r\n\r\n    reloadData() {\r\n\r\n        if (!this.Configuration)\r\n            return;\r\n\r\n        this.dshService.GetUserDashboard(this.Configuration.backendId, this.Configuration.accountId, this.Configuration.dashboardName).pipe(\r\n            takeUntil(this.destroySignal$)\r\n        ).subscribe(c => {\r\n            this.dashboardLayout = c;\r\n            this.widgetDefinitions = c.widgets.map(i => {\r\n                return this.cmpFactory.resolveDefinition(i.type, i)\r\n            });\r\n\r\n        });\r\n    }\r\n\r\n    removeItem(widgetName: string) {\r\n        if (!this.dashboardLayout)\r\n            return;\r\n        let idx = this.dashboardLayout.widgets.findIndex(s => s.name == widgetName);\r\n        this.widgetDefinitions.splice(idx, 1);\r\n    }\r\n\r\n    saveDashboard() {\r\n        if (!this.dashboardLayout)\r\n            return;\r\n        const dto = new SaveJaceDashboardLayoutDTO();\r\n        dto.backendid = this.Configuration.backendId;\r\n        dto.widgets = [];\r\n        for (let index = 0; index < this.widgetDefinitions.length; index++) {\r\n            const w: IJaceWidgetModel | null = this.widgetDefinitions[index];\r\n            if (w == null)\r\n                continue;\r\n            let v = new JaceWidgetInstanceDetail();\r\n            v.id = w.id;\r\n            v.name = w.name;\r\n            v.x = w.x;\r\n            v.y = w.y;\r\n            v.cols = w.cols;\r\n            v.rows = w.rows;\r\n            v.compactenabled = w.compactEnabled;\r\n            v.dragenabled = w.dragEnabled;\r\n            v.resizeenabled = w.resizeEnabled;\r\n            v.type = w.widgetType;\r\n            v.title = w.title;\r\n            v.options = w.options;\r\n            dto.widgets.push(v);\r\n        }\r\n        this.dshService.SaveUserDashboard(dto).subscribe(res => {\r\n            if (res.success)\r\n                console.log('Dashboard saved');\r\n\r\n        });\r\n    }\r\n\r\n    renderLayout(comps: QueryList<ViewContainerRef>) {\r\n\r\n        this.clearTrackedSubscriptions();\r\n\r\n        comps.map((host, index) => {\r\n            const vcr = host;\r\n            vcr.clear();\r\n            const widgetData = this.widgetDefinitions[index];\r\n\r\n            if (!widgetData || !widgetData.widgetType)\r\n                return;\r\n\r\n\r\n\r\n            let componentRef: ComponentRef<IWidgetComponent> | null;\r\n            componentRef = this.cmpFactory.resolveComponent(widgetData?.widgetType, vcr);\r\n\r\n            if (!componentRef) {\r\n                console.log(`Tipo widget sconosciuto ${widgetData.widgetType}`);\r\n                return;\r\n            }\r\n\r\n\r\n            //setta l'input della data\r\n            if (this.Configuration.showDateInput)\r\n                componentRef.instance.DashboardDate = this.dashboardDate;\r\n\r\n            //setta il modello\r\n            componentRef.instance.setWidgetModel(this.Configuration.backendId, widgetData);\r\n\r\n            //setta la callback per OnRemove\r\n            let s = componentRef.instance.OnRemove.pipe(\r\n                takeUntil(this.destroySignal$)\r\n            ).subscribe(name => this.removeItem(name));\r\n            this.trackedSubscriptions.push(s);\r\n\r\n            //componentRef.changeDetectorRef.markForCheck();\r\n\r\n            //componentRef.changeDetectorRef.detectChanges();\r\n        });\r\n        this.cdr.detectChanges();\r\n    }\r\n\r\n\r\n    addItem() {\r\n\r\n        //this.dashboard.push({});\r\n    }\r\n}","<ng-container *ngIf=\"Configuration\">\r\n\r\n    <form role=\"form\" class=\"jace-dsh-toolbar\" *ngIf=\"Configuration.showToolbar\">\r\n        <div *ngIf=\"Configuration.dashboardTitle\" class=\"jace-dsh-toolbar-title\">\r\n            {{Configuration.dashboardTitle}}\r\n        </div>\r\n        <div class=\"jace-dsh-toolbar-dtp\" *ngIf=\"Configuration?.showDateInput\">\r\n            <form-date [JsDates]=\"true\" [FormLayout]=\"false\" id=\"txt_dashboarddate\" [Validation]=\"false\"\r\n                autocomplete=\"off\" [(ngModel)]=\"dashboardDate\" name=\"dashboarddate\" [Placeholder]=\"'Dashboard Date'\">\r\n            </form-date>\r\n        </div>\r\n        <div class=\"jace-dsh-save-button\" (click)=\"saveDashboard()\">\r\n            <span class=\"transition\">\r\n                <i class=\"fa fa-save\"></i>\r\n            </span>\r\n        </div>\r\n    </form>\r\n\r\n    <gridster [options]=\"Configuration.gridsterConfig\" class=\"jace-dsh-widget-area\">\r\n        <gridster-item [item]=\"item\" *ngFor=\"let item of widgetDefinitions\" class=\"jace-dsh-widget {{item.name}}\">\r\n        <!-- <ng-container *ngFor=\"let item of widgetDefinitions\"> -->\r\n            <ng-template #grid_item></ng-template>\r\n        <!-- </ng-container> -->\r\n        </gridster-item>\r\n    </gridster>\r\n\r\n</ng-container>"]}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { EventEmitter, Inject, Injectable } from "@angular/core";
|
|
2
|
+
import { DSH_DATA_SERVICE } from "../../public-injection-tokens";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* Classe di base astratta per la creazione di Widget custom.
|
|
6
|
+
*/
|
|
7
|
+
export class BaseWidgetComponent {
|
|
8
|
+
constructor(dshService) {
|
|
9
|
+
this.dshService = dshService;
|
|
10
|
+
this.OnRemove = new EventEmitter();
|
|
11
|
+
this.configuration = false;
|
|
12
|
+
this.dataReady = false;
|
|
13
|
+
this.lastdate = "";
|
|
14
|
+
}
|
|
15
|
+
setWidgetModel(dshBackendId, widgetModel) {
|
|
16
|
+
this.model = widgetModel;
|
|
17
|
+
if (this.model.backendid === undefined || this.model.backendid == "default_backend")
|
|
18
|
+
this.model.backendid = dshBackendId;
|
|
19
|
+
this.refreshData();
|
|
20
|
+
}
|
|
21
|
+
ngOnInit() { }
|
|
22
|
+
ngOnChanges(changes) {
|
|
23
|
+
//console.log(changes['DashboardDate'].currentValue);
|
|
24
|
+
if (changes['DashboardDate'].previousValue)
|
|
25
|
+
this.lastdate = changes['DashboardDate'].previousValue.toISOString();
|
|
26
|
+
let curdate = "";
|
|
27
|
+
if (changes['DashboardDate'].currentValue)
|
|
28
|
+
curdate = changes['DashboardDate'].currentValue.toISOString();
|
|
29
|
+
//fix per il datetimepicker material che cambia l'oggetto al momento del caricamento
|
|
30
|
+
if (this.lastdate != curdate) {
|
|
31
|
+
this.lastdate = curdate;
|
|
32
|
+
this.refreshData();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Prepara i parametri e lancia la chiamata GetWidgetData della DashboardFeatureService.
|
|
37
|
+
* Imposta il model con i dati restituiti (setData) e imposta la variabile dataReady del campo a true
|
|
38
|
+
*/
|
|
39
|
+
refreshData() {
|
|
40
|
+
if (!this.model)
|
|
41
|
+
return;
|
|
42
|
+
const pars = {};
|
|
43
|
+
if (this.DashboardDate)
|
|
44
|
+
pars["DT"] = this.DashboardDate.toISOString();
|
|
45
|
+
if (this.model.options && Object.keys(this.model.options).length != 0) {
|
|
46
|
+
for (let index = 0; index < Object.keys(this.model.options).length; index++) {
|
|
47
|
+
const k = Object.keys(this.model.options)[index];
|
|
48
|
+
pars[k] = this.model.options[k];
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
this.prepareGetDataParameters(pars);
|
|
52
|
+
this.dshService.GetWidgetData(this.model.backendid, this.model.name, pars).subscribe(data => {
|
|
53
|
+
if (this.model) {
|
|
54
|
+
this.model.setData(data);
|
|
55
|
+
this.dataReady = true;
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Da chiamare quando l'utente preme il pulsante 'rimuovi' nella toolbar della widget.
|
|
61
|
+
*/
|
|
62
|
+
removeWidget() {
|
|
63
|
+
if (!this.model)
|
|
64
|
+
return;
|
|
65
|
+
this.OnRemove.emit(this.model.name);
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Da chiamare quando viene premuto il pulsante 'configure' nella toolbar della widget
|
|
69
|
+
*/
|
|
70
|
+
configureWidget() {
|
|
71
|
+
if (this.configuration) {
|
|
72
|
+
//finito di configurare -> refreshData
|
|
73
|
+
this.refreshData();
|
|
74
|
+
}
|
|
75
|
+
this.configuration = !this.configuration;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
BaseWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseWidgetComponent, deps: [{ token: DSH_DATA_SERVICE }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
79
|
+
BaseWidgetComponent.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseWidgetComponent });
|
|
80
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseWidgetComponent, decorators: [{
|
|
81
|
+
type: Injectable
|
|
82
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
83
|
+
type: Inject,
|
|
84
|
+
args: [DSH_DATA_SERVICE]
|
|
85
|
+
}] }]; } });
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"BaseWidgetComponent.js","sourceRoot":"","sources":["../../../../../../projects/dashboard-feature/src/lib/components/widgets/BaseWidgetComponent.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Component, Directive, EventEmitter, Inject, Injectable, SimpleChanges } from \"@angular/core\";\r\nimport { IJaceWidgetModel } from \"../../models/widgets/IJaceWidgetModel\";\r\nimport { IWidgetComponent } from \"./IWidgetComponent\";\r\nimport { IDashboardFeatureDataService } from \"../../services/IDashboardFeatureDataService\";\r\nimport { DSH_DATA_SERVICE } from \"../../public-injection-tokens\";\r\n\r\n/**\r\n * Classe di base astratta per la creazione di Widget custom.\r\n */\r\n @Injectable()\r\nexport abstract class BaseWidgetComponent<T extends IJaceWidgetModel> implements IWidgetComponent{\r\n\r\n    model?: T;\r\n\r\n    DashboardDate!: Date;\r\n    OnRemove = new EventEmitter<string>();\r\n\r\n    configuration: boolean = false;\r\n    dataReady: boolean = false;\r\n    lastdate: string = \"\";\r\n\r\n    constructor(@Inject(DSH_DATA_SERVICE) protected dshService: IDashboardFeatureDataService) { }\r\n\r\n    setWidgetModel(dshBackendId:string, widgetModel: IJaceWidgetModel): void {\r\n        \r\n        this.model = <T>widgetModel;\r\n\r\n        if(this.model.backendid === undefined || this.model.backendid==\"default_backend\")\r\n                this.model.backendid = dshBackendId;\r\n\r\n        this.refreshData();\r\n    }\r\n\r\n    ngOnInit() { }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        //console.log(changes['DashboardDate'].currentValue);\r\n        if (changes['DashboardDate'].previousValue)\r\n            this.lastdate = changes['DashboardDate'].previousValue.toISOString();\r\n\r\n        let curdate: string = \"\";\r\n\r\n        if (changes['DashboardDate'].currentValue)\r\n            curdate = changes['DashboardDate'].currentValue.toISOString();\r\n        //fix per il datetimepicker material che cambia l'oggetto al momento del caricamento\r\n        if (this.lastdate != curdate) {\r\n            this.lastdate = curdate;\r\n            this.refreshData();\r\n        }\r\n\r\n    }\r\n\r\n    /**\r\n     * Prepara i parametri e lancia la chiamata GetWidgetData della DashboardFeatureService.\r\n     * Imposta il model con i dati restituiti (setData) e imposta la variabile dataReady del campo a true\r\n     */\r\n    refreshData() : void {\r\n        if (!this.model)\r\n            return;\r\n        const pars: { [key: string]: string } = {};\r\n        if(this.DashboardDate)\r\n            pars[\"DT\"] = this.DashboardDate.toISOString();\r\n        if (this.model.options && Object.keys(this.model.options).length != 0) {\r\n            for (let index = 0; index < Object.keys(this.model.options).length; index++) {\r\n                const k = Object.keys(this.model.options)[index];\r\n                pars[k] = this.model.options[k];\r\n            }\r\n        }\r\n\r\n        this.prepareGetDataParameters(pars);\r\n\r\n        this.dshService.GetWidgetData(this.model.backendid, this.model.name, pars).subscribe(data => {\r\n            if (this.model) {\r\n                this.model.setData(data);\r\n                this.dataReady = true;\r\n            }\r\n        }\r\n        );\r\n    }    \r\n    /**\r\n     * Modifica/aggiorna i parametri della chiamata GetWidgetData prima di eseguirla.     * \r\n     * \r\n     * @param pars parametri della chiamata. Se impostata, già contengono il parametro 'DT' con la data selezionata a livello di dashboard\r\n     */\r\n    abstract prepareGetDataParameters(pars: { [key: string]: string; }) :void;\r\n\r\n    /**\r\n     * Da chiamare quando l'utente preme il pulsante 'rimuovi' nella toolbar della widget.\r\n     */\r\n    removeWidget() :void{\r\n        if (!this.model)\r\n            return;\r\n        this.OnRemove.emit(this.model.name);\r\n    }\r\n\r\n    /**\r\n     * Da chiamare quando viene premuto il pulsante 'configure' nella toolbar della widget\r\n     */\r\n    configureWidget() :void{\r\n        if (this.configuration) {\r\n            //finito di configurare -> refreshData\r\n            this.refreshData();\r\n        }\r\n        this.configuration = !this.configuration;\r\n    }\r\n}"]}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { Component, EventEmitter, Inject, Input, Output } from '@angular/core';
|
|
2
|
+
import { DSH_DATA_SERVICE } from '../../../public-injection-tokens';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@esfaenza/es-charts";
|
|
6
|
+
export class JaceChartWidgetComponent {
|
|
7
|
+
constructor(dshService) {
|
|
8
|
+
this.dshService = dshService;
|
|
9
|
+
this.OnRemove = new EventEmitter();
|
|
10
|
+
this.configuration = false;
|
|
11
|
+
this.dataReady = false;
|
|
12
|
+
this.lastdate = "";
|
|
13
|
+
this.chartName = "";
|
|
14
|
+
}
|
|
15
|
+
setWidgetModel(dshBackendId, widgetModel) {
|
|
16
|
+
this.model = widgetModel;
|
|
17
|
+
if (this.model.backendid === undefined || this.model.backendid == "default_backend")
|
|
18
|
+
this.model.backendid = dshBackendId;
|
|
19
|
+
this.refreshData();
|
|
20
|
+
}
|
|
21
|
+
ngOnInit() { }
|
|
22
|
+
ngOnChanges(changes) {
|
|
23
|
+
//console.log(changes['DashboardDate'].currentValue);
|
|
24
|
+
if (changes['DashboardDate'].previousValue)
|
|
25
|
+
this.lastdate = changes['DashboardDate'].previousValue.toISOString();
|
|
26
|
+
let curdate = "";
|
|
27
|
+
if (changes['DashboardDate'].currentValue)
|
|
28
|
+
curdate = changes['DashboardDate'].currentValue.toISOString();
|
|
29
|
+
//fix per il datetimepicker material che cambia l'oggetto al momento del caricamento
|
|
30
|
+
if (this.lastdate != curdate) {
|
|
31
|
+
this.lastdate = curdate;
|
|
32
|
+
this.refreshData();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
refreshData() {
|
|
36
|
+
if (!this.model)
|
|
37
|
+
return;
|
|
38
|
+
const pars = {};
|
|
39
|
+
if (this.DashboardDate)
|
|
40
|
+
pars["DT"] = this.DashboardDate.toISOString();
|
|
41
|
+
if (this.model.options && Object.keys(this.model.options).length != 0) {
|
|
42
|
+
for (let index = 0; index < Object.keys(this.model.options).length; index++) {
|
|
43
|
+
const k = Object.keys(this.model.options)[index];
|
|
44
|
+
pars[k] = this.model.options[k];
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
this.dshService.GetWidgetData(this.model.backendid, this.model.name, pars).subscribe(data => {
|
|
48
|
+
if (this.model) {
|
|
49
|
+
this.model.setData(data);
|
|
50
|
+
this.chartName = this.model.name;
|
|
51
|
+
this.dataReady = true;
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
removeWidget() {
|
|
56
|
+
if (!this.model)
|
|
57
|
+
return;
|
|
58
|
+
this.OnRemove.emit(this.model.name);
|
|
59
|
+
}
|
|
60
|
+
configure() {
|
|
61
|
+
if (this.configuration) {
|
|
62
|
+
//finito di configurare -> refreshData
|
|
63
|
+
this.refreshData();
|
|
64
|
+
}
|
|
65
|
+
this.configuration = !this.configuration;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
JaceChartWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: JaceChartWidgetComponent, deps: [{ token: DSH_DATA_SERVICE }], target: i0.ɵɵFactoryTarget.Component });
|
|
69
|
+
JaceChartWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: JaceChartWidgetComponent, selector: "jace-dsh-chart", inputs: { DashboardDate: "DashboardDate" }, outputs: { OnRemove: "OnRemove" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"jace-dsh-widget-header {{model?.name}}-header\">\r\n <div class=\"jace-dsh-widget-title\" *ngIf=\"model.title\">\r\n {{model.title}}\r\n </div>\r\n <div class=\"jace-dsh-widget-controls\" *ngIf=\"dataReady\">\r\n <span class=\"transition drag-handler jace-dsh-widget-drag\" *ngIf=\"model.dragEnabled\">\r\n <i class=\"fa fa-arrows-alt\"></i>\r\n </span>\r\n <span class=\"transition jace-dsh-widget-opts\" (click)=\"configure()\">\r\n <i class=\"fa fa-cog\"></i>\r\n </span>\r\n <span (click)=\"removeWidget()\" class=\"transition remove-button jace-dsh-widget-close\">\r\n <i class=\"fa fa-times\"></i>\r\n </span>\r\n </div>\r\n</div>\r\n<div class=\"jace-dsh-widget-body gridster-item-content {{model?.name}}-body\">\r\n <div class=\"jace-dsh-widget-loading\" *ngIf=\"!dataReady\">\r\n <i class=\"fa fa-spinner fa-spin\"></i>\r\n </div>\r\n\r\n <div class=\"jace-dsh-chart-container jace-dsh-widget-slide\"\r\n [ngClass]=\"{'jace-dsh-widget-content-hide':configuration,'jace-dsh-widget-content-show':!configuration}\"\r\n *ngIf=\"dataReady\">\r\n <!-- [Type]=\"Widget.chartType\" -->\r\n <h6 *ngIf=\"model?.queryerror\" class=\"fg-disabled\" style=\"margin-top: 0.5rem;\"><span\r\n class=\"fa fa-times-circle-o\"></span> Error retrieving data</h6>\r\n <es-chart [Legend]=\"model.legend\" [Theme]=\"'dataviz'\" [Type]=\"model.chartType\" [Data]=\"model.chartData\"\r\n [name]=\"chartName\"></es-chart>\r\n </div>\r\n\r\n <div class=\"jace-dsh-widget-settings jace-dsh-widget-slide \"\r\n [ngClass]=\"{'jace-dsh-widget-settings-hide':!configuration,'jace-dsh-widget-settings-show':configuration}\">\r\n <p>Configuration</p>\r\n </div>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.EsChartComponent, selector: "es-chart", inputs: ["Type", "Data", "DataArray"] }] });
|
|
70
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: JaceChartWidgetComponent, decorators: [{
|
|
71
|
+
type: Component,
|
|
72
|
+
args: [{ selector: 'jace-dsh-chart', template: "<div class=\"jace-dsh-widget-header {{model?.name}}-header\">\r\n <div class=\"jace-dsh-widget-title\" *ngIf=\"model.title\">\r\n {{model.title}}\r\n </div>\r\n <div class=\"jace-dsh-widget-controls\" *ngIf=\"dataReady\">\r\n <span class=\"transition drag-handler jace-dsh-widget-drag\" *ngIf=\"model.dragEnabled\">\r\n <i class=\"fa fa-arrows-alt\"></i>\r\n </span>\r\n <span class=\"transition jace-dsh-widget-opts\" (click)=\"configure()\">\r\n <i class=\"fa fa-cog\"></i>\r\n </span>\r\n <span (click)=\"removeWidget()\" class=\"transition remove-button jace-dsh-widget-close\">\r\n <i class=\"fa fa-times\"></i>\r\n </span>\r\n </div>\r\n</div>\r\n<div class=\"jace-dsh-widget-body gridster-item-content {{model?.name}}-body\">\r\n <div class=\"jace-dsh-widget-loading\" *ngIf=\"!dataReady\">\r\n <i class=\"fa fa-spinner fa-spin\"></i>\r\n </div>\r\n\r\n <div class=\"jace-dsh-chart-container jace-dsh-widget-slide\"\r\n [ngClass]=\"{'jace-dsh-widget-content-hide':configuration,'jace-dsh-widget-content-show':!configuration}\"\r\n *ngIf=\"dataReady\">\r\n <!-- [Type]=\"Widget.chartType\" -->\r\n <h6 *ngIf=\"model?.queryerror\" class=\"fg-disabled\" style=\"margin-top: 0.5rem;\"><span\r\n class=\"fa fa-times-circle-o\"></span> Error retrieving data</h6>\r\n <es-chart [Legend]=\"model.legend\" [Theme]=\"'dataviz'\" [Type]=\"model.chartType\" [Data]=\"model.chartData\"\r\n [name]=\"chartName\"></es-chart>\r\n </div>\r\n\r\n <div class=\"jace-dsh-widget-settings jace-dsh-widget-slide \"\r\n [ngClass]=\"{'jace-dsh-widget-settings-hide':!configuration,'jace-dsh-widget-settings-show':configuration}\">\r\n <p>Configuration</p>\r\n </div>\r\n</div>" }]
|
|
73
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
74
|
+
type: Inject,
|
|
75
|
+
args: [DSH_DATA_SERVICE]
|
|
76
|
+
}] }]; }, propDecorators: { DashboardDate: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], OnRemove: [{
|
|
79
|
+
type: Output
|
|
80
|
+
}] } });
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jace-dsh-chart.component.js","sourceRoot":"","sources":["../../../../../../../projects/dashboard-feature/src/lib/components/widgets/chart/jace-dsh-chart.component.ts","../../../../../../../projects/dashboard-feature/src/lib/components/widgets/chart/jace-dsh-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, OnInit, Output, SimpleChanges } from '@angular/core';\r\n\r\nimport { IJaceWidgetModel } from '../../../models/widgets/IJaceWidgetModel';\r\nimport { IWidgetComponent } from '../IWidgetComponent';\r\n\r\nimport { JaceChartWidgetModel } from '../../../models/widgets/JaceChartWidgetModel';\r\nimport { DSH_DATA_SERVICE } from '../../../public-injection-tokens';\r\nimport { IDashboardFeatureDataService } from '../../../services/IDashboardFeatureDataService';\r\n\r\n@Component({\r\n    selector: 'jace-dsh-chart',\r\n    templateUrl: './jace-dsh-chart.component.html',\r\n    styleUrls: ['./jace-dsh-chart.component.css']\r\n})\r\n\r\nexport class JaceChartWidgetComponent implements IWidgetComponent, OnInit {\r\n\r\n    model?: JaceChartWidgetModel;\r\n\r\n    @Input() DashboardDate!: Date;\r\n    @Output() OnRemove = new EventEmitter<string>();\r\n\r\n    configuration: boolean = false;\r\n    dataReady: boolean = false;\r\n    lastdate: string = \"\";\r\n    public chartName:string=\"\";\r\n\r\n    constructor(@Inject(DSH_DATA_SERVICE) private dshService: IDashboardFeatureDataService) { }\r\n\r\n    setWidgetModel(dshBackendId:string,widgetModel: IJaceWidgetModel): void {\r\n        this.model = <JaceChartWidgetModel>widgetModel;\r\n        if(this.model.backendid === undefined || this.model.backendid==\"default_backend\")\r\n                this.model.backendid = dshBackendId;\r\n        this.refreshData();\r\n    }\r\n\r\n    ngOnInit() { }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        //console.log(changes['DashboardDate'].currentValue);\r\n        if (changes['DashboardDate'].previousValue)\r\n            this.lastdate = changes['DashboardDate'].previousValue.toISOString();\r\n\r\n        let curdate: string = \"\";\r\n\r\n        if (changes['DashboardDate'].currentValue)\r\n            curdate = changes['DashboardDate'].currentValue.toISOString();\r\n        //fix per il datetimepicker material che cambia l'oggetto al momento del caricamento\r\n        if (this.lastdate != curdate) {\r\n            this.lastdate = curdate;\r\n            this.refreshData();\r\n        }\r\n\r\n    }\r\n\r\n    refreshData() {\r\n        if (!this.model)\r\n            return;\r\n        const pars: { [key: string]: string } = {};\r\n        if(this.DashboardDate)\r\n            pars[\"DT\"] = this.DashboardDate.toISOString();\r\n        if (this.model.options && Object.keys(this.model.options).length != 0) {\r\n            for (let index = 0; index < Object.keys(this.model.options).length; index++) {\r\n                const k = Object.keys(this.model.options)[index];\r\n                pars[k] = this.model.options[k];\r\n            }\r\n        }\r\n\r\n        this.dshService.GetWidgetData(this.model.backendid,this.model.name, pars).subscribe(data => {\r\n            if (this.model) {\r\n                this.model.setData(data);\r\n                this.chartName = this.model.name;\r\n                this.dataReady = true;\r\n            }\r\n        }\r\n        );\r\n    }\r\n\r\n    removeWidget() {\r\n        if (!this.model)\r\n            return;\r\n        this.OnRemove.emit(this.model.name);\r\n    }\r\n\r\n    configure() {\r\n        if (this.configuration) {\r\n            //finito di configurare -> refreshData\r\n            this.refreshData();\r\n        }\r\n        this.configuration = !this.configuration;\r\n    }\r\n}","<div class=\"jace-dsh-widget-header {{model?.name}}-header\">\r\n    <div class=\"jace-dsh-widget-title\" *ngIf=\"model.title\">\r\n        {{model.title}}\r\n    </div>\r\n    <div class=\"jace-dsh-widget-controls\" *ngIf=\"dataReady\">\r\n        <span class=\"transition drag-handler jace-dsh-widget-drag\" *ngIf=\"model.dragEnabled\">\r\n            <i class=\"fa fa-arrows-alt\"></i>\r\n        </span>\r\n        <span class=\"transition jace-dsh-widget-opts\" (click)=\"configure()\">\r\n            <i class=\"fa fa-cog\"></i>\r\n        </span>\r\n        <span (click)=\"removeWidget()\" class=\"transition remove-button jace-dsh-widget-close\">\r\n            <i class=\"fa fa-times\"></i>\r\n        </span>\r\n    </div>\r\n</div>\r\n<div class=\"jace-dsh-widget-body gridster-item-content {{model?.name}}-body\">\r\n    <div class=\"jace-dsh-widget-loading\" *ngIf=\"!dataReady\">\r\n        <i class=\"fa fa-spinner fa-spin\"></i>\r\n    </div>\r\n\r\n    <div class=\"jace-dsh-chart-container jace-dsh-widget-slide\"\r\n        [ngClass]=\"{'jace-dsh-widget-content-hide':configuration,'jace-dsh-widget-content-show':!configuration}\"\r\n        *ngIf=\"dataReady\">\r\n        <!-- [Type]=\"Widget.chartType\" -->\r\n        <h6 *ngIf=\"model?.queryerror\" class=\"fg-disabled\" style=\"margin-top: 0.5rem;\"><span\r\n                class=\"fa fa-times-circle-o\"></span>&nbsp;&nbsp;Error retrieving data</h6>\r\n        <es-chart [Legend]=\"model.legend\" [Theme]=\"'dataviz'\" [Type]=\"model.chartType\" [Data]=\"model.chartData\"\r\n            [name]=\"chartName\"></es-chart>\r\n    </div>\r\n\r\n    <div class=\"jace-dsh-widget-settings jace-dsh-widget-slide \"\r\n        [ngClass]=\"{'jace-dsh-widget-settings-hide':!configuration,'jace-dsh-widget-settings-show':configuration}\">\r\n        <p>Configuration</p>\r\n    </div>\r\n</div>"]}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { Component, EventEmitter, Inject, Input, Output } from '@angular/core';
|
|
2
|
+
import { DSH_DATA_SERVICE } from '../../../public-injection-tokens';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
export class JaceCounterWidgetComponent {
|
|
6
|
+
constructor(dshService) {
|
|
7
|
+
this.dshService = dshService;
|
|
8
|
+
this.OnRemove = new EventEmitter();
|
|
9
|
+
this.configuration = false;
|
|
10
|
+
this.dataReady = false;
|
|
11
|
+
this.lastdate = "";
|
|
12
|
+
}
|
|
13
|
+
//TODO per online update: importare cdr: ChangeDectectorRef
|
|
14
|
+
setWidgetModel(dshBackendId, widgetModel) {
|
|
15
|
+
this.model = widgetModel;
|
|
16
|
+
if (this.model.backendid === undefined || this.model.backendid == "default_backend")
|
|
17
|
+
this.model.backendid = dshBackendId;
|
|
18
|
+
this.refreshData();
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() { }
|
|
21
|
+
ngOnChanges(changes) {
|
|
22
|
+
//console.log(changes['DashboardDate'].currentValue);
|
|
23
|
+
if (changes['DashboardDate'].previousValue)
|
|
24
|
+
this.lastdate = changes['DashboardDate'].previousValue.toISOString();
|
|
25
|
+
let curdate = "";
|
|
26
|
+
if (changes['DashboardDate'].currentValue)
|
|
27
|
+
curdate = changes['DashboardDate'].currentValue.toISOString();
|
|
28
|
+
//fix per il datetimepicker material che cambia l'oggetto al momento del caricamento
|
|
29
|
+
if (this.lastdate != curdate) {
|
|
30
|
+
this.lastdate = curdate;
|
|
31
|
+
this.refreshData();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
refreshData() {
|
|
35
|
+
if (!this.model)
|
|
36
|
+
return;
|
|
37
|
+
const pars = {};
|
|
38
|
+
if (this.DashboardDate)
|
|
39
|
+
pars["DT"] = this.DashboardDate.toISOString();
|
|
40
|
+
if (this.model.options && Object.keys(this.model.options).length != 0) {
|
|
41
|
+
for (let index = 0; index < Object.keys(this.model.options).length; index++) {
|
|
42
|
+
const k = Object.keys(this.model.options)[index];
|
|
43
|
+
pars[k] = this.model.options[k];
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
this.dshService.GetWidgetData(this.model.backendid, this.model.name, pars).subscribe(data => {
|
|
47
|
+
if (this.model) {
|
|
48
|
+
this.model.setData(data);
|
|
49
|
+
this.dataReady = true;
|
|
50
|
+
//TODO per online update: this.cdr.markForCheck();
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
removeWidget() {
|
|
55
|
+
if (!this.model)
|
|
56
|
+
return;
|
|
57
|
+
this.OnRemove.emit(this.model.name);
|
|
58
|
+
}
|
|
59
|
+
configure() {
|
|
60
|
+
if (this.configuration) {
|
|
61
|
+
//finito di configurare -> refreshData
|
|
62
|
+
this.refreshData();
|
|
63
|
+
}
|
|
64
|
+
this.configuration = !this.configuration;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
JaceCounterWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: JaceCounterWidgetComponent, deps: [{ token: DSH_DATA_SERVICE }], target: i0.ɵɵFactoryTarget.Component });
|
|
68
|
+
JaceCounterWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: JaceCounterWidgetComponent, selector: "jace-dsh-counter", inputs: { DashboardDate: "DashboardDate" }, outputs: { OnRemove: "OnRemove" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"jace-dsh-widget-header {{model?.name}}-header\">\r\n <div class=\"jace-dsh-widget-title\" *ngIf=\"model.title\">\r\n {{model.title}}\r\n </div>\r\n <div class=\"jace-dsh-widget-controls\" *ngIf=\"dataReady\">\r\n <span class=\"transition drag-handler jace-dsh-widget-drag\" *ngIf=\"model.dragEnabled\">\r\n <i class=\"fa fa-arrows-alt\"></i>\r\n </span>\r\n <span class=\"transition jace-dsh-widget-opts\" (click)=\"configure()\">\r\n <i class=\"fa fa-cog\"></i>\r\n </span>\r\n <span (click)=\"removeWidget()\" class=\"transition remove-button jace-dsh-widget-close\">\r\n <i class=\"fa fa-times\"></i>\r\n </span>\r\n </div>\r\n</div>\r\n<div class=\"jace-dsh-widget-body gridster-item-content {{model?.name}}-body\">\r\n <div class=\"jace-dsh-widget-loading\" *ngIf=\"!dataReady\">\r\n <i class=\"fa fa-spinner fa-spin\"></i>\r\n </div>\r\n <div class=\"jace-dsh-counter-body jace-dsh-widget-slide\"\r\n [ngClass]=\"{'jace-dsh-widget-content-hide':configuration,'jace-dsh-widget-content-show':!configuration}\"\r\n *ngIf=\"dataReady\">\r\n <i class=\"jace-dsh-counter-icon fa fa-2x\" [ngClass]=\"[ model.icon ? model.icon : '']\" *ngIf=\"model.icon\"></i>\r\n <div class=\"jace-dsh-counter-super\">{{model.superText}}</div>\r\n <div class=\"jace-dsh-counter-value\"><span>{{model.value}}</span> <span\r\n class=\"jace-dsh-counter-unit\">{{model.unit}}</span> </div>\r\n\r\n <div class=\"jace-dsh-counter-sub\">{{model.subText}}</div>\r\n </div>\r\n\r\n <div class=\"jace-dsh-widget-settings jace-dsh-widget-slide \"\r\n [ngClass]=\"{'jace-dsh-widget-settings-hide':!configuration,'jace-dsh-widget-settings-show':configuration}\">\r\n <p>Configuration</p>\r\n </div>\r\n</div>", styles: [".jace-dsh-counter-body{padding:1em .5em}.jace-dsh-counter-value{font-size:2em;font-weight:700;text-align:center}.jace-dsh-counter-unit{margin-left:.08em;font-size:.5em;text-align:center}.jace-dsh-counter-super{font-size:1em;text-align:center}.jace-dsh-counter-sub{font-size:.8em;text-align:center}.jace-dsh-counter-icon{position:absolute;font-size:2.6em;color:#b0c4de}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
69
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: JaceCounterWidgetComponent, decorators: [{
|
|
70
|
+
type: Component,
|
|
71
|
+
args: [{ selector: 'jace-dsh-counter', template: "<div class=\"jace-dsh-widget-header {{model?.name}}-header\">\r\n <div class=\"jace-dsh-widget-title\" *ngIf=\"model.title\">\r\n {{model.title}}\r\n </div>\r\n <div class=\"jace-dsh-widget-controls\" *ngIf=\"dataReady\">\r\n <span class=\"transition drag-handler jace-dsh-widget-drag\" *ngIf=\"model.dragEnabled\">\r\n <i class=\"fa fa-arrows-alt\"></i>\r\n </span>\r\n <span class=\"transition jace-dsh-widget-opts\" (click)=\"configure()\">\r\n <i class=\"fa fa-cog\"></i>\r\n </span>\r\n <span (click)=\"removeWidget()\" class=\"transition remove-button jace-dsh-widget-close\">\r\n <i class=\"fa fa-times\"></i>\r\n </span>\r\n </div>\r\n</div>\r\n<div class=\"jace-dsh-widget-body gridster-item-content {{model?.name}}-body\">\r\n <div class=\"jace-dsh-widget-loading\" *ngIf=\"!dataReady\">\r\n <i class=\"fa fa-spinner fa-spin\"></i>\r\n </div>\r\n <div class=\"jace-dsh-counter-body jace-dsh-widget-slide\"\r\n [ngClass]=\"{'jace-dsh-widget-content-hide':configuration,'jace-dsh-widget-content-show':!configuration}\"\r\n *ngIf=\"dataReady\">\r\n <i class=\"jace-dsh-counter-icon fa fa-2x\" [ngClass]=\"[ model.icon ? model.icon : '']\" *ngIf=\"model.icon\"></i>\r\n <div class=\"jace-dsh-counter-super\">{{model.superText}}</div>\r\n <div class=\"jace-dsh-counter-value\"><span>{{model.value}}</span> <span\r\n class=\"jace-dsh-counter-unit\">{{model.unit}}</span> </div>\r\n\r\n <div class=\"jace-dsh-counter-sub\">{{model.subText}}</div>\r\n </div>\r\n\r\n <div class=\"jace-dsh-widget-settings jace-dsh-widget-slide \"\r\n [ngClass]=\"{'jace-dsh-widget-settings-hide':!configuration,'jace-dsh-widget-settings-show':configuration}\">\r\n <p>Configuration</p>\r\n </div>\r\n</div>", styles: [".jace-dsh-counter-body{padding:1em .5em}.jace-dsh-counter-value{font-size:2em;font-weight:700;text-align:center}.jace-dsh-counter-unit{margin-left:.08em;font-size:.5em;text-align:center}.jace-dsh-counter-super{font-size:1em;text-align:center}.jace-dsh-counter-sub{font-size:.8em;text-align:center}.jace-dsh-counter-icon{position:absolute;font-size:2.6em;color:#b0c4de}\n"] }]
|
|
72
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
73
|
+
type: Inject,
|
|
74
|
+
args: [DSH_DATA_SERVICE]
|
|
75
|
+
}] }]; }, propDecorators: { DashboardDate: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}], OnRemove: [{
|
|
78
|
+
type: Output
|
|
79
|
+
}] } });
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jace-dsh-counter.component.js","sourceRoot":"","sources":["../../../../../../../projects/dashboard-feature/src/lib/components/widgets/counter/jace-dsh-counter.component.ts","../../../../../../../projects/dashboard-feature/src/lib/components/widgets/counter/jace-dsh-counter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, OnInit, Output, SimpleChanges } from '@angular/core';\r\n\r\nimport { IJaceWidgetModel } from '../../../models/widgets/IJaceWidgetModel';\r\nimport { IWidgetComponent } from '../IWidgetComponent';\r\nimport { JaceCounterWidgetModel } from '../../../models/widgets/JaceCounterWidgetModel';\r\n\r\nimport { DSH_DATA_SERVICE } from '../../../public-injection-tokens';\r\nimport { IDashboardFeatureDataService } from '../../../services/IDashboardFeatureDataService';\r\n\r\n@Component({\r\n    selector: 'jace-dsh-counter',\r\n    templateUrl: './jace-dsh-counter.component.html',\r\n    styleUrls: ['./jace-dsh-counter.component.css'],\r\n    //TODO per online update: scommentare OnPush\r\n    //changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\n\r\nexport class JaceCounterWidgetComponent implements IWidgetComponent, OnInit {\r\n\r\n    model?: JaceCounterWidgetModel;\r\n\r\n    @Input() DashboardDate!: Date;\r\n    @Output() OnRemove = new EventEmitter<string>();\r\n\r\n    configuration: boolean = false;\r\n    dataReady: boolean = false;\r\n    lastdate: string = \"\";\r\n\r\n    constructor(@Inject(DSH_DATA_SERVICE) private dshService: IDashboardFeatureDataService) { }\r\n\r\n//TODO per online update: importare cdr: ChangeDectectorRef \r\n\r\n    setWidgetModel(dshBackendId:string,widgetModel: IJaceWidgetModel): void {\r\n        this.model = <JaceCounterWidgetModel>widgetModel;\r\n        if(this.model.backendid === undefined || this.model.backendid==\"default_backend\")\r\n                this.model.backendid = dshBackendId;\r\n        this.refreshData();\r\n    }\r\n\r\n    ngOnInit() { }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        //console.log(changes['DashboardDate'].currentValue);\r\n        if (changes['DashboardDate'].previousValue)\r\n            this.lastdate = changes['DashboardDate'].previousValue.toISOString();\r\n\r\n        let curdate: string = \"\";\r\n\r\n        if (changes['DashboardDate'].currentValue)\r\n            curdate = changes['DashboardDate'].currentValue.toISOString();\r\n        //fix per il datetimepicker material che cambia l'oggetto al momento del caricamento\r\n        if (this.lastdate != curdate) {\r\n            this.lastdate = curdate;\r\n            this.refreshData();\r\n        }\r\n\r\n    }\r\n\r\n    refreshData() {\r\n        if (!this.model)\r\n            return;\r\n        const pars: { [key: string]: string } = {};\r\n        if(this.DashboardDate)\r\n            pars[\"DT\"] = this.DashboardDate.toISOString();\r\n        if (this.model.options && Object.keys(this.model.options).length != 0) {\r\n            for (let index = 0; index < Object.keys(this.model.options).length; index++) {\r\n                const k = Object.keys(this.model.options)[index];\r\n                pars[k] = this.model.options[k];\r\n            }\r\n        }\r\n\r\n        this.dshService.GetWidgetData(this.model.backendid,this.model.name, pars).subscribe(data => {\r\n            if (this.model) {\r\n                this.model.setData(data);\r\n                \r\n                this.dataReady = true;\r\n                //TODO per online update: this.cdr.markForCheck();                \r\n            }\r\n        }\r\n        );\r\n    }\r\n\r\n    removeWidget() {\r\n        if (!this.model)\r\n            return;\r\n        this.OnRemove.emit(this.model.name);\r\n    }\r\n\r\n    configure() {\r\n        if (this.configuration) {\r\n            //finito di configurare -> refreshData\r\n            this.refreshData();\r\n        }\r\n        this.configuration = !this.configuration;\r\n    }\r\n}","<div class=\"jace-dsh-widget-header {{model?.name}}-header\">\r\n    <div class=\"jace-dsh-widget-title\" *ngIf=\"model.title\">\r\n        {{model.title}}\r\n    </div>\r\n    <div class=\"jace-dsh-widget-controls\" *ngIf=\"dataReady\">\r\n        <span class=\"transition drag-handler jace-dsh-widget-drag\" *ngIf=\"model.dragEnabled\">\r\n            <i class=\"fa fa-arrows-alt\"></i>\r\n        </span>\r\n        <span class=\"transition jace-dsh-widget-opts\" (click)=\"configure()\">\r\n            <i class=\"fa fa-cog\"></i>\r\n        </span>\r\n        <span (click)=\"removeWidget()\" class=\"transition remove-button jace-dsh-widget-close\">\r\n            <i class=\"fa fa-times\"></i>\r\n        </span>\r\n    </div>\r\n</div>\r\n<div class=\"jace-dsh-widget-body gridster-item-content {{model?.name}}-body\">\r\n    <div class=\"jace-dsh-widget-loading\" *ngIf=\"!dataReady\">\r\n        <i class=\"fa fa-spinner fa-spin\"></i>\r\n    </div>\r\n    <div class=\"jace-dsh-counter-body jace-dsh-widget-slide\"\r\n        [ngClass]=\"{'jace-dsh-widget-content-hide':configuration,'jace-dsh-widget-content-show':!configuration}\"\r\n        *ngIf=\"dataReady\">\r\n        <i class=\"jace-dsh-counter-icon fa fa-2x\" [ngClass]=\"[ model.icon ? model.icon : '']\" *ngIf=\"model.icon\"></i>\r\n        <div class=\"jace-dsh-counter-super\">{{model.superText}}</div>\r\n        <div class=\"jace-dsh-counter-value\"><span>{{model.value}}</span> <span\r\n                class=\"jace-dsh-counter-unit\">{{model.unit}}</span> </div>\r\n\r\n        <div class=\"jace-dsh-counter-sub\">{{model.subText}}</div>\r\n    </div>\r\n\r\n    <div class=\"jace-dsh-widget-settings jace-dsh-widget-slide \"\r\n        [ngClass]=\"{'jace-dsh-widget-settings-hide':!configuration,'jace-dsh-widget-settings-show':configuration}\">\r\n        <p>Configuration</p>\r\n    </div>\r\n</div>"]}
|