@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.
Files changed (70) hide show
  1. package/esm2020/esfaenza-dashboard-feature.mjs +5 -0
  2. package/esm2020/lib/components/dashboard/dashboard.component.loc.mjs +15 -0
  3. package/esm2020/lib/components/dashboard/dashboard.component.mjs +172 -0
  4. package/esm2020/lib/components/widgets/BaseWidgetComponent.mjs +86 -0
  5. package/esm2020/lib/components/widgets/chart/jace-dsh-chart.component.mjs +81 -0
  6. package/esm2020/lib/components/widgets/counter/jace-dsh-counter.component.mjs +80 -0
  7. package/esm2020/lib/components/widgets/list/jace-dsh-list.component.mjs +91 -0
  8. package/esm2020/lib/components/widgets/multiprog/jace-dsh-multiprog.component.mjs +82 -0
  9. package/esm2020/lib/dashboard-feature.module.mjs +134 -0
  10. package/esm2020/lib/models/config/JaceDashboardConfig.mjs +57 -0
  11. package/esm2020/lib/models/widgets/BaseJaceWidgetModel.mjs +24 -0
  12. package/esm2020/lib/models/widgets/JaceMultiprogWidgetModel.mjs +28 -0
  13. package/esm2020/lib/services/DashboardWidgetFactory.mjs +89 -0
  14. package/esm2020/lib/services/dashboard-feature.service.mjs +43 -0
  15. package/fesm2015/esfaenza-dashboard-feature.mjs +1131 -0
  16. package/fesm2015/esfaenza-dashboard-feature.mjs.map +1 -0
  17. package/fesm2020/esfaenza-dashboard-feature.mjs +1112 -0
  18. package/fesm2020/esfaenza-dashboard-feature.mjs.map +1 -0
  19. package/index.d.ts +5 -0
  20. package/lib/components/dashboard/dashboard.component.d.ts +3 -0
  21. package/lib/components/dashboard/dashboard.component.loc.d.ts +5 -2
  22. package/lib/components/widgets/BaseWidgetComponent.d.ts +3 -0
  23. package/lib/components/widgets/chart/jace-dsh-chart.component.d.ts +3 -0
  24. package/lib/components/widgets/counter/jace-dsh-counter.component.d.ts +3 -0
  25. package/lib/components/widgets/list/jace-dsh-list.component.d.ts +3 -0
  26. package/lib/components/widgets/multiprog/jace-dsh-multiprog.component.d.ts +3 -0
  27. package/lib/dashboard-feature.module.d.ts +17 -0
  28. package/lib/services/DashboardWidgetFactory.d.ts +3 -0
  29. package/lib/services/dashboard-feature.service.d.ts +3 -0
  30. package/package.json +29 -16
  31. package/bundles/esfaenza-dashboard-feature.umd.js +0 -1470
  32. package/bundles/esfaenza-dashboard-feature.umd.js.map +0 -1
  33. package/bundles/esfaenza-dashboard-feature.umd.min.js +0 -2
  34. package/bundles/esfaenza-dashboard-feature.umd.min.js.map +0 -1
  35. package/esfaenza-dashboard-feature.d.ts +0 -6
  36. package/esfaenza-dashboard-feature.metadata.json +0 -1
  37. package/esm2015/esfaenza-dashboard-feature.js +0 -7
  38. package/esm2015/lib/components/dashboard/dashboard.component.js +0 -170
  39. package/esm2015/lib/components/dashboard/dashboard.component.loc.js +0 -16
  40. package/esm2015/lib/components/widgets/BaseWidgetComponent.js +0 -83
  41. package/esm2015/lib/components/widgets/chart/jace-dsh-chart.component.js +0 -79
  42. package/esm2015/lib/components/widgets/counter/jace-dsh-counter.component.js +0 -79
  43. package/esm2015/lib/components/widgets/list/jace-dsh-list.component.js +0 -91
  44. package/esm2015/lib/components/widgets/multiprog/jace-dsh-multiprog.component.js +0 -80
  45. package/esm2015/lib/dashboard-feature.module.js +0 -112
  46. package/esm2015/lib/models/config/JaceDashboardConfig.js +0 -54
  47. package/esm2015/lib/models/widgets/BaseJaceWidgetModel.js +0 -25
  48. package/esm2015/lib/models/widgets/JaceMultiprogWidgetModel.js +0 -29
  49. package/esm2015/lib/services/DashboardWidgetFactory.js +0 -90
  50. package/esm2015/lib/services/dashboard-feature.service.js +0 -41
  51. package/fesm2015/esfaenza-dashboard-feature.js +0 -1090
  52. package/fesm2015/esfaenza-dashboard-feature.js.map +0 -1
  53. /package/{esm2015/lib/components/widgets/IWidgetComponent.js → esm2020/lib/components/widgets/IWidgetComponent.mjs} +0 -0
  54. /package/{esm2015/lib/components/widgets/JaceWidgetTypes.js → esm2020/lib/components/widgets/JaceWidgetTypes.mjs} +0 -0
  55. /package/{esm2015/lib/models/externals/JaceDashboardLayoutAppSearch.js → esm2020/lib/models/externals/JaceDashboardLayoutAppSearch.mjs} +0 -0
  56. /package/{esm2015/lib/models/externals/JaceDashboardLayoutDetail.js → esm2020/lib/models/externals/JaceDashboardLayoutDetail.mjs} +0 -0
  57. /package/{esm2015/lib/models/externals/JaceWidgetInstanceDetail.js → esm2020/lib/models/externals/JaceWidgetInstanceDetail.mjs} +0 -0
  58. /package/{esm2015/lib/models/externals/Repository.js → esm2020/lib/models/externals/Repository.mjs} +0 -0
  59. /package/{esm2015/lib/models/externals/SaveJaceDashboardLayoutDTO.js → esm2020/lib/models/externals/SaveJaceDashboardLayoutDTO.mjs} +0 -0
  60. /package/{esm2015/lib/models/options/DefaultDashboardModuleOptions.js → esm2020/lib/models/options/DefaultDashboardModuleOptions.mjs} +0 -0
  61. /package/{esm2015/lib/models/options/IDashboardModuleOptions.js → esm2020/lib/models/options/IDashboardModuleOptions.mjs} +0 -0
  62. /package/{esm2015/lib/models/options/IWidgetTypeConfig.js → esm2020/lib/models/options/IWidgetTypeConfig.mjs} +0 -0
  63. /package/{esm2015/lib/models/widgets/IJaceWidgetModel.js → esm2020/lib/models/widgets/IJaceWidgetModel.mjs} +0 -0
  64. /package/{esm2015/lib/models/widgets/JaceChartWidgetModel.js → esm2020/lib/models/widgets/JaceChartWidgetModel.mjs} +0 -0
  65. /package/{esm2015/lib/models/widgets/JaceCounterWidgetModel.js → esm2020/lib/models/widgets/JaceCounterWidgetModel.mjs} +0 -0
  66. /package/{esm2015/lib/models/widgets/JaceListWidgetModel.js → esm2020/lib/models/widgets/JaceListWidgetModel.mjs} +0 -0
  67. /package/{esm2015/lib/private-injection-tokens.js → esm2020/lib/private-injection-tokens.mjs} +0 -0
  68. /package/{esm2015/lib/public-injection-tokens.js → esm2020/lib/public-injection-tokens.mjs} +0 -0
  69. /package/{esm2015/lib/services/IDashboardFeatureDataService.js → esm2020/lib/services/IDashboardFeatureDataService.mjs} +0 -0
  70. /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>&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>", 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>&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>" }]
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>"]}