@esfaenza/dashboard-feature 15.2.13 → 19.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/README.md +24 -24
- package/fesm2022/esfaenza-dashboard-feature.mjs +988 -0
- package/fesm2022/esfaenza-dashboard-feature.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/components/dashboard/dashboard.component.d.ts +46 -46
- package/lib/components/widgets/BaseWidgetComponent.d.ts +44 -47
- package/lib/components/widgets/IWidgetComponent.d.ts +23 -23
- package/lib/components/widgets/JaceWidgetTypes.d.ts +6 -6
- package/lib/components/widgets/chart/jace-dsh-chart.component.d.ts +25 -25
- package/lib/components/widgets/counter/jace-dsh-counter.component.d.ts +24 -24
- package/lib/components/widgets/list/jace-dsh-list.component.d.ts +27 -27
- package/lib/components/widgets/multiprog/jace-dsh-multiprog.component.d.ts +26 -26
- package/lib/dashboard-feature.module.d.ts +22 -24
- package/lib/models/config/JaceDashboardConfig.d.ts +51 -51
- package/lib/models/externals/JaceDashboardLayoutAppSearch.d.ts +6 -6
- package/lib/models/externals/JaceDashboardLayoutDetail.d.ts +6 -6
- package/lib/models/externals/JaceWidgetInstanceDetail.d.ts +18 -18
- package/lib/models/externals/Repository.d.ts +5 -5
- package/lib/models/externals/SaveJaceDashboardLayoutDTO.d.ts +6 -6
- package/lib/models/options/DefaultDashboardModuleOptions.d.ts +6 -6
- package/lib/models/options/IDashboardModuleOptions.d.ts +4 -4
- package/lib/models/options/IWidgetTypeConfig.d.ts +8 -8
- package/lib/models/widgets/BaseJaceWidgetModel.d.ts +32 -32
- package/lib/models/widgets/IJaceWidgetModel.d.ts +33 -33
- package/lib/models/widgets/JaceChartWidgetModel.d.ts +8 -8
- package/lib/models/widgets/JaceCounterWidgetModel.d.ts +10 -10
- package/lib/models/widgets/JaceListWidgetModel.d.ts +16 -16
- package/lib/models/widgets/JaceMultiprogWidgetModel.d.ts +9 -9
- package/lib/private-injection-tokens.d.ts +3 -0
- package/lib/{tokens.d.ts → public-injection-tokens.d.ts} +7 -9
- package/lib/services/DashboardWidgetFactory.d.ts +28 -28
- package/lib/services/IDashboardFeatureDataService.d.ts +11 -31
- package/lib/services/dashboard-feature.service.d.ts +18 -38
- package/package.json +15 -16
- package/public-api.d.ts +23 -23
- package/esm2020/esfaenza-dashboard-feature.mjs +0 -5
- package/esm2020/lib/components/dashboard/dashboard.component.mjs +0 -163
- package/esm2020/lib/components/widgets/BaseWidgetComponent.mjs +0 -89
- package/esm2020/lib/components/widgets/IWidgetComponent.mjs +0 -2
- package/esm2020/lib/components/widgets/JaceWidgetTypes.mjs +0 -8
- package/esm2020/lib/components/widgets/chart/jace-dsh-chart.component.mjs +0 -81
- package/esm2020/lib/components/widgets/counter/jace-dsh-counter.component.mjs +0 -80
- package/esm2020/lib/components/widgets/list/jace-dsh-list.component.mjs +0 -91
- package/esm2020/lib/components/widgets/multiprog/jace-dsh-multiprog.component.mjs +0 -82
- package/esm2020/lib/dashboard-feature.module.mjs +0 -98
- package/esm2020/lib/models/config/JaceDashboardConfig.mjs +0 -57
- package/esm2020/lib/models/externals/JaceDashboardLayoutAppSearch.mjs +0 -8
- package/esm2020/lib/models/externals/JaceDashboardLayoutDetail.mjs +0 -4
- package/esm2020/lib/models/externals/JaceWidgetInstanceDetail.mjs +0 -7
- package/esm2020/lib/models/externals/Repository.mjs +0 -6
- package/esm2020/lib/models/externals/SaveJaceDashboardLayoutDTO.mjs +0 -6
- package/esm2020/lib/models/options/DefaultDashboardModuleOptions.mjs +0 -35
- package/esm2020/lib/models/options/IDashboardModuleOptions.mjs +0 -2
- package/esm2020/lib/models/options/IWidgetTypeConfig.mjs +0 -2
- package/esm2020/lib/models/widgets/BaseJaceWidgetModel.mjs +0 -24
- package/esm2020/lib/models/widgets/IJaceWidgetModel.mjs +0 -2
- package/esm2020/lib/models/widgets/JaceChartWidgetModel.mjs +0 -27
- package/esm2020/lib/models/widgets/JaceCounterWidgetModel.mjs +0 -23
- package/esm2020/lib/models/widgets/JaceListWidgetModel.mjs +0 -39
- package/esm2020/lib/models/widgets/JaceMultiprogWidgetModel.mjs +0 -28
- package/esm2020/lib/services/DashboardWidgetFactory.mjs +0 -49
- package/esm2020/lib/services/IDashboardFeatureDataService.mjs +0 -2
- package/esm2020/lib/services/dashboard-feature.service.mjs +0 -58
- package/esm2020/lib/tokens.mjs +0 -8
- package/esm2020/public-api.mjs +0 -34
- package/fesm2015/esfaenza-dashboard-feature.mjs +0 -1041
- package/fesm2015/esfaenza-dashboard-feature.mjs.map +0 -1
- package/fesm2020/esfaenza-dashboard-feature.mjs +0 -1024
- package/fesm2020/esfaenza-dashboard-feature.mjs.map +0 -1
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
import { InjectionToken } from "@angular/core";
|
|
2
|
-
import { IDashboardFeatureDataService } from "./services/IDashboardFeatureDataService";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
*
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
export declare const DSH_DATA_SERVICE: InjectionToken<IDashboardFeatureDataService>;
|
|
9
|
-
export declare const DSH_OPTIONS: InjectionToken<IDashboardModuleOptions>;
|
|
1
|
+
import { InjectionToken } from "@angular/core";
|
|
2
|
+
import { IDashboardFeatureDataService } from "./services/IDashboardFeatureDataService";
|
|
3
|
+
/**
|
|
4
|
+
* Token di registrazione della DashboardFeatureService.
|
|
5
|
+
* Permette di fare l'override dell'implementazione di default a scopo di test delle widget
|
|
6
|
+
*/
|
|
7
|
+
export declare const DSH_DATA_SERVICE: InjectionToken<IDashboardFeatureDataService>;
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
import { ComponentRef, ViewContainerRef } from '@angular/core';
|
|
2
|
-
import { IWidgetComponent } from '../components/widgets/IWidgetComponent';
|
|
3
|
-
import { JaceWidgetInstanceDetail } from '../models/externals/JaceWidgetInstanceDetail';
|
|
4
|
-
import { IJaceWidgetModel } from '../models/widgets/IJaceWidgetModel';
|
|
5
|
-
import { IDashboardModuleOptions } from '../models/options/IDashboardModuleOptions';
|
|
6
|
-
import { IWidgetTypeConfig } from '../models/options/IWidgetTypeConfig';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export interface IConstructableModel<T> {
|
|
9
|
-
new (): T;
|
|
10
|
-
}
|
|
11
|
-
export declare class DashboardWidgetFactory {
|
|
12
|
-
types: {
|
|
13
|
-
[name: string]: IWidgetTypeConfig;
|
|
14
|
-
};
|
|
15
|
-
constructor();
|
|
16
|
-
addOption(option: IDashboardModuleOptions): void;
|
|
17
|
-
/**
|
|
18
|
-
* Versione
|
|
19
|
-
* @param type
|
|
20
|
-
* @param vcr
|
|
21
|
-
* @returns
|
|
22
|
-
*/
|
|
23
|
-
resolveComponent(type: string, vcr: ViewContainerRef): ComponentRef<IWidgetComponent> | null;
|
|
24
|
-
resolveDefinition(type: string, details: JaceWidgetInstanceDetail): IJaceWidgetModel | null;
|
|
25
|
-
private createInstance;
|
|
26
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<DashboardWidgetFactory, never>;
|
|
27
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<DashboardWidgetFactory>;
|
|
28
|
-
}
|
|
1
|
+
import { ComponentRef, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { IWidgetComponent } from '../components/widgets/IWidgetComponent';
|
|
3
|
+
import { JaceWidgetInstanceDetail } from '../models/externals/JaceWidgetInstanceDetail';
|
|
4
|
+
import { IJaceWidgetModel } from '../models/widgets/IJaceWidgetModel';
|
|
5
|
+
import { IDashboardModuleOptions } from '../models/options/IDashboardModuleOptions';
|
|
6
|
+
import { IWidgetTypeConfig } from '../models/options/IWidgetTypeConfig';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export interface IConstructableModel<T> {
|
|
9
|
+
new (): T;
|
|
10
|
+
}
|
|
11
|
+
export declare class DashboardWidgetFactory {
|
|
12
|
+
types: {
|
|
13
|
+
[name: string]: IWidgetTypeConfig;
|
|
14
|
+
};
|
|
15
|
+
constructor();
|
|
16
|
+
addOption(option: IDashboardModuleOptions): void;
|
|
17
|
+
/**
|
|
18
|
+
* Versione ng11 della creazione dei componenti dinamici delle widget
|
|
19
|
+
* @param type
|
|
20
|
+
* @param vcr
|
|
21
|
+
* @returns
|
|
22
|
+
*/
|
|
23
|
+
resolveComponent(type: string, vcr: ViewContainerRef): ComponentRef<IWidgetComponent> | null;
|
|
24
|
+
resolveDefinition(type: string, details: JaceWidgetInstanceDetail): IJaceWidgetModel | null;
|
|
25
|
+
private createInstance;
|
|
26
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DashboardWidgetFactory, never>;
|
|
27
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<DashboardWidgetFactory>;
|
|
28
|
+
}
|
|
@@ -1,31 +1,11 @@
|
|
|
1
|
-
import { CallResult } from "@esfaenza/extensions";
|
|
2
|
-
import { Observable } from "rxjs";
|
|
3
|
-
import { JaceDashboardLayoutDetail } from "../models/externals/JaceDashboardLayoutDetail";
|
|
4
|
-
import { SaveJaceDashboardLayoutDTO } from "../models/externals/SaveJaceDashboardLayoutDTO";
|
|
5
|
-
export interface IDashboardFeatureDataService {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
* @returns JaceDashboardLayoutDetail layout della dashboard
|
|
13
|
-
*/
|
|
14
|
-
GetUserDashboard(backendid: string, idaccount: number, dashboardName: string): Observable<JaceDashboardLayoutDetail>;
|
|
15
|
-
/**
|
|
16
|
-
*Salva le impostazioni della dashboard (es. preferenze specifiche dell'utente)
|
|
17
|
-
* @param dto dati di salvataggio
|
|
18
|
-
* @returns CallResult
|
|
19
|
-
*/
|
|
20
|
-
SaveUserDashboard(dto: SaveJaceDashboardLayoutDTO): Observable<CallResult>;
|
|
21
|
-
/**
|
|
22
|
-
* Recupera i dati di una specifica Widget. Chiamato dal metodo refreshData() di BaseWidgetComponent.
|
|
23
|
-
* @param backendid id del backend che pubblica i dati di questa Widget
|
|
24
|
-
* @param name nome univoco di questa Widget
|
|
25
|
-
* @param options dizionario di configurazioni impostate sulla specifica Widget (aka configurazioni particolari)
|
|
26
|
-
* @returns Un oggetto any con i dati della Widget (Nota: ogni Widget è responsabile di interpretare i propri dati)
|
|
27
|
-
*/
|
|
28
|
-
GetWidgetData(backendid: string, name: string, options: {
|
|
29
|
-
[key: string]: string;
|
|
30
|
-
}): Observable<any>;
|
|
31
|
-
}
|
|
1
|
+
import { CallResult } from "@esfaenza/extensions";
|
|
2
|
+
import { Observable } from "rxjs";
|
|
3
|
+
import { JaceDashboardLayoutDetail } from "../models/externals/JaceDashboardLayoutDetail";
|
|
4
|
+
import { SaveJaceDashboardLayoutDTO } from "../models/externals/SaveJaceDashboardLayoutDTO";
|
|
5
|
+
export interface IDashboardFeatureDataService {
|
|
6
|
+
GetUserDashboard(backendid: string, idaccount: number, dashboardName: string): Observable<JaceDashboardLayoutDetail>;
|
|
7
|
+
SaveUserDashboard(dto: SaveJaceDashboardLayoutDTO): Observable<CallResult>;
|
|
8
|
+
GetWidgetData(backendid: string, name: string, options: {
|
|
9
|
+
[key: string]: string;
|
|
10
|
+
}): Observable<any>;
|
|
11
|
+
}
|
|
@@ -1,38 +1,18 @@
|
|
|
1
|
-
import { JaceDashboardLayoutDetail } from '../models/externals/JaceDashboardLayoutDetail';
|
|
2
|
-
import { Observable } from 'rxjs';
|
|
3
|
-
import { SaveJaceDashboardLayoutDTO } from '../models/externals/SaveJaceDashboardLayoutDTO';
|
|
4
|
-
import { CallResult } from '@esfaenza/extensions';
|
|
5
|
-
import { HTTPService } from '@esfaenza/httpservice';
|
|
6
|
-
import { IDashboardFeatureDataService } from './IDashboardFeatureDataService';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export declare class DashboardFeatureAPIDataService implements IDashboardFeatureDataService {
|
|
9
|
-
private http;
|
|
10
|
-
constructor(http: HTTPService);
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
GetUserDashboard(backendid: string, idaccount: number, dashboardName: string): Observable<JaceDashboardLayoutDetail>;
|
|
20
|
-
/**
|
|
21
|
-
*Salva le impostazioni della dashboard (es. preferenze specifiche dell'utente)
|
|
22
|
-
* @param dto dati di salvataggio
|
|
23
|
-
* @returns CallResult
|
|
24
|
-
*/
|
|
25
|
-
SaveUserDashboard(dto: SaveJaceDashboardLayoutDTO): Observable<CallResult>;
|
|
26
|
-
/**
|
|
27
|
-
* Recupera i dati di una specifica Widget. Chiamato dal metodo refreshData() di BaseWidgetComponent.
|
|
28
|
-
* @param backendid id del backend che pubblica i dati di questa Widget
|
|
29
|
-
* @param name nome univoco di questa Widget
|
|
30
|
-
* @param options dizionario di configurazioni impostate sulla specifica Widget (aka configurazioni particolari)
|
|
31
|
-
* @returns Un oggetto any con i dati della Widget (Nota: ogni Widget è responsabile di interpretare i propri dati)
|
|
32
|
-
*/
|
|
33
|
-
GetWidgetData(backendid: string, name: string, options: {
|
|
34
|
-
[key: string]: string;
|
|
35
|
-
}): Observable<any>;
|
|
36
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<DashboardFeatureAPIDataService, never>;
|
|
37
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<DashboardFeatureAPIDataService>;
|
|
38
|
-
}
|
|
1
|
+
import { JaceDashboardLayoutDetail } from '../models/externals/JaceDashboardLayoutDetail';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
import { SaveJaceDashboardLayoutDTO } from '../models/externals/SaveJaceDashboardLayoutDTO';
|
|
4
|
+
import { CallResult } from '@esfaenza/extensions';
|
|
5
|
+
import { HTTPService } from '@esfaenza/httpservice';
|
|
6
|
+
import { IDashboardFeatureDataService } from './IDashboardFeatureDataService';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export declare class DashboardFeatureAPIDataService implements IDashboardFeatureDataService {
|
|
9
|
+
private http;
|
|
10
|
+
constructor(http: HTTPService);
|
|
11
|
+
GetUserDashboard(backendid: string, idaccount: number, dashboardName: string): Observable<JaceDashboardLayoutDetail>;
|
|
12
|
+
SaveUserDashboard(dto: SaveJaceDashboardLayoutDTO): Observable<CallResult>;
|
|
13
|
+
GetWidgetData(backendid: string, name: string, options: {
|
|
14
|
+
[key: string]: string;
|
|
15
|
+
}): Observable<any>;
|
|
16
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DashboardFeatureAPIDataService, never>;
|
|
17
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<DashboardFeatureAPIDataService>;
|
|
18
|
+
}
|
package/package.json
CHANGED
|
@@ -1,21 +1,24 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@esfaenza/dashboard-feature",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "19.2.0",
|
|
4
4
|
"peerDependencies": {
|
|
5
|
-
"@angular/animations": "^
|
|
6
|
-
"@angular/
|
|
7
|
-
"@angular/
|
|
8
|
-
"@angular/
|
|
9
|
-
"@
|
|
5
|
+
"@angular/animations": "^19.2.15",
|
|
6
|
+
"@angular/cdk": "^19.2.19",
|
|
7
|
+
"@angular/common": "^19.2.15",
|
|
8
|
+
"@angular/compiler": "^19.2.15",
|
|
9
|
+
"@angular/core": "^19.2.15",
|
|
10
|
+
"@angular/forms": "^19.2.15",
|
|
11
|
+
"@angular/platform-browser": "^19.2.15",
|
|
12
|
+
"@angular/platform-browser-dynamic": "^19.2.15",
|
|
13
|
+
"@angular/router": "^19.2.15",
|
|
14
|
+
"@angular/service-worker": "^19.2.15",
|
|
15
|
+
"angular-gridster2": "19.0.0",
|
|
16
|
+
"@esfaenza/core": "^19.2.132"
|
|
10
17
|
},
|
|
11
18
|
"dependencies": {
|
|
12
19
|
"tslib": "^2.0.0"
|
|
13
20
|
},
|
|
14
|
-
"module": "
|
|
15
|
-
"es2020": "fesm2020/esfaenza-dashboard-feature.mjs",
|
|
16
|
-
"esm2020": "esm2020/esfaenza-dashboard-feature.mjs",
|
|
17
|
-
"fesm2020": "fesm2020/esfaenza-dashboard-feature.mjs",
|
|
18
|
-
"fesm2015": "fesm2015/esfaenza-dashboard-feature.mjs",
|
|
21
|
+
"module": "fesm2022/esfaenza-dashboard-feature.mjs",
|
|
19
22
|
"typings": "index.d.ts",
|
|
20
23
|
"exports": {
|
|
21
24
|
"./package.json": {
|
|
@@ -23,11 +26,7 @@
|
|
|
23
26
|
},
|
|
24
27
|
".": {
|
|
25
28
|
"types": "./index.d.ts",
|
|
26
|
-
"
|
|
27
|
-
"es2020": "./fesm2020/esfaenza-dashboard-feature.mjs",
|
|
28
|
-
"es2015": "./fesm2015/esfaenza-dashboard-feature.mjs",
|
|
29
|
-
"node": "./fesm2015/esfaenza-dashboard-feature.mjs",
|
|
30
|
-
"default": "./fesm2020/esfaenza-dashboard-feature.mjs"
|
|
29
|
+
"default": "./fesm2022/esfaenza-dashboard-feature.mjs"
|
|
31
30
|
}
|
|
32
31
|
},
|
|
33
32
|
"sideEffects": false
|
package/public-api.d.ts
CHANGED
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
export * from './lib/tokens';
|
|
2
|
-
export * from './lib/dashboard-feature.module';
|
|
3
|
-
export * from './lib/models/config/JaceDashboardConfig';
|
|
4
|
-
export * from './lib/models/externals/JaceDashboardLayoutAppSearch';
|
|
5
|
-
export * from './lib/models/externals/JaceDashboardLayoutDetail';
|
|
6
|
-
export * from './lib/models/externals/JaceWidgetInstanceDetail';
|
|
7
|
-
export * from './lib/models/externals/SaveJaceDashboardLayoutDTO';
|
|
8
|
-
export * from './lib/models/options/IWidgetTypeConfig';
|
|
9
|
-
export * from './lib/models/options/IDashboardModuleOptions';
|
|
10
|
-
export * from './lib/models/options/DefaultDashboardModuleOptions';
|
|
11
|
-
export * from './lib/models/widgets/IJaceWidgetModel';
|
|
12
|
-
export * from './lib/models/widgets/BaseJaceWidgetModel';
|
|
13
|
-
export * from './lib/services/IDashboardFeatureDataService';
|
|
14
|
-
export * from './lib/services/dashboard-feature.service';
|
|
15
|
-
export * from './lib/services/DashboardWidgetFactory';
|
|
16
|
-
export * from './lib/components/dashboard/dashboard.component';
|
|
17
|
-
export * from './lib/components/widgets/chart/jace-dsh-chart.component';
|
|
18
|
-
export * from './lib/components/widgets/counter/jace-dsh-counter.component';
|
|
19
|
-
export * from './lib/components/widgets/list/jace-dsh-list.component';
|
|
20
|
-
export * from './lib/components/widgets/multiprog/jace-dsh-multiprog.component';
|
|
21
|
-
export * from './lib/components/widgets/BaseWidgetComponent';
|
|
22
|
-
export * from './lib/components/widgets/IWidgetComponent';
|
|
23
|
-
export * from './lib/components/widgets/JaceWidgetTypes';
|
|
1
|
+
export * from './lib/public-injection-tokens';
|
|
2
|
+
export * from './lib/dashboard-feature.module';
|
|
3
|
+
export * from './lib/models/config/JaceDashboardConfig';
|
|
4
|
+
export * from './lib/models/externals/JaceDashboardLayoutAppSearch';
|
|
5
|
+
export * from './lib/models/externals/JaceDashboardLayoutDetail';
|
|
6
|
+
export * from './lib/models/externals/JaceWidgetInstanceDetail';
|
|
7
|
+
export * from './lib/models/externals/SaveJaceDashboardLayoutDTO';
|
|
8
|
+
export * from './lib/models/options/IWidgetTypeConfig';
|
|
9
|
+
export * from './lib/models/options/IDashboardModuleOptions';
|
|
10
|
+
export * from './lib/models/options/DefaultDashboardModuleOptions';
|
|
11
|
+
export * from './lib/models/widgets/IJaceWidgetModel';
|
|
12
|
+
export * from './lib/models/widgets/BaseJaceWidgetModel';
|
|
13
|
+
export * from './lib/services/IDashboardFeatureDataService';
|
|
14
|
+
export * from './lib/services/dashboard-feature.service';
|
|
15
|
+
export * from './lib/services/DashboardWidgetFactory';
|
|
16
|
+
export * from './lib/components/dashboard/dashboard.component';
|
|
17
|
+
export * from './lib/components/widgets/chart/jace-dsh-chart.component';
|
|
18
|
+
export * from './lib/components/widgets/counter/jace-dsh-counter.component';
|
|
19
|
+
export * from './lib/components/widgets/list/jace-dsh-list.component';
|
|
20
|
+
export * from './lib/components/widgets/multiprog/jace-dsh-multiprog.component';
|
|
21
|
+
export * from './lib/components/widgets/BaseWidgetComponent';
|
|
22
|
+
export * from './lib/components/widgets/IWidgetComponent';
|
|
23
|
+
export * from './lib/components/widgets/JaceWidgetTypes';
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './public-api';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNmYWVuemEtZGFzaGJvYXJkLWZlYXR1cmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9kYXNoYm9hcmQtZmVhdHVyZS9zcmMvZXNmYWVuemEtZGFzaGJvYXJkLWZlYXR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -1,163 +0,0 @@
|
|
|
1
|
-
import { Component, Inject, Input, ViewChildren, ViewContainerRef, ViewEncapsulation } from "@angular/core";
|
|
2
|
-
import { InboundMessageTypes } from "@esfaenza/extensions";
|
|
3
|
-
import { SaveJaceDashboardLayoutDTO } from "../../models/externals/SaveJaceDashboardLayoutDTO";
|
|
4
|
-
import { JaceWidgetInstanceDetail } from "../../models/externals/JaceWidgetInstanceDetail";
|
|
5
|
-
import { Subject, timer } from "rxjs";
|
|
6
|
-
import { map, takeUntil } from "rxjs/operators";
|
|
7
|
-
import { DSH_DATA_SERVICE } from "../../tokens";
|
|
8
|
-
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@esfaenza/extensions";
|
|
10
|
-
import * as i2 from "@angular/router";
|
|
11
|
-
import * as i3 from "../../services/DashboardWidgetFactory";
|
|
12
|
-
import * as i4 from "@angular/common";
|
|
13
|
-
import * as i5 from "@angular/forms";
|
|
14
|
-
import * as i6 from "angular-gridster2";
|
|
15
|
-
import * as i7 from "@esfaenza/forms-and-validations";
|
|
16
|
-
/**
|
|
17
|
-
* Componente di base che rappresenta una dashboard.
|
|
18
|
-
* Utilizza Gridster2 per il layout delle widget [Gridster2](https://tiberiuzuld.github.io/angular-gridster2/)
|
|
19
|
-
*/
|
|
20
|
-
export class DashboardComponent {
|
|
21
|
-
constructor(dshService, intercom, route, cmpFactory, cdr) {
|
|
22
|
-
this.dshService = dshService;
|
|
23
|
-
this.intercom = intercom;
|
|
24
|
-
this.route = route;
|
|
25
|
-
this.cmpFactory = cmpFactory;
|
|
26
|
-
this.cdr = cdr;
|
|
27
|
-
this.dashboardDate = new Date();
|
|
28
|
-
this.widgetDefinitions = [];
|
|
29
|
-
this.trackedSubscriptions = [];
|
|
30
|
-
this.destroySignal$ = new Subject();
|
|
31
|
-
this.intercom.send(InboundMessageTypes.Navigation, { sub: false, routeTitle: this.route.snapshot.data["title"] });
|
|
32
|
-
}
|
|
33
|
-
ngOnInit() { }
|
|
34
|
-
ngAfterViewInit() {
|
|
35
|
-
//qui this.gridItemRefs è 'riempito'
|
|
36
|
-
// sottoscrivo changes che sparerà tutte le volte che ngFor si aggiorna (ovvero quando cambia dashboard)
|
|
37
|
-
this.changesSub = this.gridItemRefs.changes.pipe(takeUntil(this.destroySignal$)).subscribe((comps) => {
|
|
38
|
-
this.renderLayout(comps);
|
|
39
|
-
});
|
|
40
|
-
//prima volta
|
|
41
|
-
//setTimeout(()=>this.reloadData(),500);
|
|
42
|
-
this.trackedSubscriptions.push(timer(500).pipe(takeUntil(this.destroySignal$), map(() => this.reloadData())).subscribe());
|
|
43
|
-
}
|
|
44
|
-
ngOnDestroy() {
|
|
45
|
-
//unsubscribe dalle changes dei viewref
|
|
46
|
-
if (this.changesSub)
|
|
47
|
-
this.changesSub.unsubscribe();
|
|
48
|
-
this.clearTrackedSubscriptions();
|
|
49
|
-
this.destroySignal$.next();
|
|
50
|
-
this.destroySignal$.complete();
|
|
51
|
-
}
|
|
52
|
-
clearTrackedSubscriptions() {
|
|
53
|
-
if (this.trackedSubscriptions) {
|
|
54
|
-
for (let index = 0; index < this.trackedSubscriptions.length; index++) {
|
|
55
|
-
const element = this.trackedSubscriptions[index];
|
|
56
|
-
element.unsubscribe();
|
|
57
|
-
}
|
|
58
|
-
this.trackedSubscriptions = [];
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
ngOnChanges(changes) {
|
|
62
|
-
//occhio: arriva prima di ngAfterViewInit
|
|
63
|
-
if (changes.Configuration) {
|
|
64
|
-
//appena ho configuration
|
|
65
|
-
console.log(changes.Configuration);
|
|
66
|
-
// la prima volta l'ho già fatta alla creazione del componente
|
|
67
|
-
if (!changes.Configuration.firstChange) {
|
|
68
|
-
this.reloadData();
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
reloadData() {
|
|
73
|
-
if (!this.Configuration)
|
|
74
|
-
return;
|
|
75
|
-
this.dshService.GetUserDashboard(this.Configuration.backendId, this.Configuration.accountId, this.Configuration.dashboardName).pipe(takeUntil(this.destroySignal$)).subscribe(c => {
|
|
76
|
-
this.dashboardLayout = c;
|
|
77
|
-
this.widgetDefinitions = c.widgets.map(i => {
|
|
78
|
-
return this.cmpFactory.resolveDefinition(i.type, i);
|
|
79
|
-
});
|
|
80
|
-
});
|
|
81
|
-
}
|
|
82
|
-
removeItem(widgetName) {
|
|
83
|
-
if (!this.dashboardLayout)
|
|
84
|
-
return;
|
|
85
|
-
let idx = this.dashboardLayout.widgets.findIndex(s => s.name == widgetName);
|
|
86
|
-
this.widgetDefinitions.splice(idx, 1);
|
|
87
|
-
}
|
|
88
|
-
saveDashboard() {
|
|
89
|
-
if (!this.dashboardLayout)
|
|
90
|
-
return;
|
|
91
|
-
const dto = new SaveJaceDashboardLayoutDTO();
|
|
92
|
-
dto.backendid = this.Configuration.backendId;
|
|
93
|
-
dto.widgets = [];
|
|
94
|
-
for (let index = 0; index < this.widgetDefinitions.length; index++) {
|
|
95
|
-
const w = this.widgetDefinitions[index];
|
|
96
|
-
if (w == null)
|
|
97
|
-
continue;
|
|
98
|
-
let v = new JaceWidgetInstanceDetail();
|
|
99
|
-
v.id = w.id;
|
|
100
|
-
v.name = w.name;
|
|
101
|
-
v.x = w.x;
|
|
102
|
-
v.y = w.y;
|
|
103
|
-
v.cols = w.cols;
|
|
104
|
-
v.rows = w.rows;
|
|
105
|
-
v.compactenabled = w.compactEnabled;
|
|
106
|
-
v.dragenabled = w.dragEnabled;
|
|
107
|
-
v.resizeenabled = w.resizeEnabled;
|
|
108
|
-
v.type = w.widgetType;
|
|
109
|
-
v.title = w.title;
|
|
110
|
-
v.options = w.options;
|
|
111
|
-
dto.widgets.push(v);
|
|
112
|
-
}
|
|
113
|
-
this.dshService.SaveUserDashboard(dto).subscribe(res => {
|
|
114
|
-
if (res.success)
|
|
115
|
-
console.log('Dashboard saved');
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
renderLayout(comps) {
|
|
119
|
-
this.clearTrackedSubscriptions();
|
|
120
|
-
comps.map((host, index) => {
|
|
121
|
-
const vcr = host;
|
|
122
|
-
vcr.clear();
|
|
123
|
-
const widgetData = this.widgetDefinitions[index];
|
|
124
|
-
if (!widgetData || !widgetData.widgetType)
|
|
125
|
-
return;
|
|
126
|
-
let componentRef;
|
|
127
|
-
componentRef = this.cmpFactory.resolveComponent(widgetData?.widgetType, vcr);
|
|
128
|
-
if (!componentRef) {
|
|
129
|
-
console.log(`Tipo widget sconosciuto ${widgetData.widgetType}`);
|
|
130
|
-
return;
|
|
131
|
-
}
|
|
132
|
-
//setta l'input della data
|
|
133
|
-
if (this.Configuration.showDateInput)
|
|
134
|
-
componentRef.instance.DashboardDate = this.dashboardDate;
|
|
135
|
-
//setta il modello
|
|
136
|
-
componentRef.instance.setWidgetModel(this.Configuration.backendId, widgetData);
|
|
137
|
-
//setta la callback per OnRemove
|
|
138
|
-
let s = componentRef.instance.OnRemove.pipe(takeUntil(this.destroySignal$)).subscribe(name => this.removeItem(name));
|
|
139
|
-
this.trackedSubscriptions.push(s);
|
|
140
|
-
//componentRef.changeDetectorRef.markForCheck();
|
|
141
|
-
//componentRef.changeDetectorRef.detectChanges();
|
|
142
|
-
});
|
|
143
|
-
this.cdr.detectChanges();
|
|
144
|
-
}
|
|
145
|
-
addItem() {
|
|
146
|
-
//this.dashboard.push({});
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
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.ActivatedRoute }, { token: i3.DashboardWidgetFactory }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
150
|
-
DashboardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DashboardComponent, selector: "es-dashboard", inputs: { Configuration: "Configuration" }, 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: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i6.GridsterComponent, selector: "gridster", inputs: ["options"] }, { kind: "component", type: i6.GridsterItemComponent, selector: "gridster-item", inputs: ["item"], outputs: ["itemInit", "itemChange", "itemResize"] }, { kind: "component", type: i7.FormDateComponent, selector: "form-date", inputs: ["JsDates"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
151
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardComponent, decorators: [{
|
|
152
|
-
type: Component,
|
|
153
|
-
args: [{ selector: 'es-dashboard', encapsulation: ViewEncapsulation.None, 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"] }]
|
|
154
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
155
|
-
type: Inject,
|
|
156
|
-
args: [DSH_DATA_SERVICE]
|
|
157
|
-
}] }, { type: i1.InterComService }, { type: i2.ActivatedRoute }, { type: i3.DashboardWidgetFactory }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { Configuration: [{
|
|
158
|
-
type: Input
|
|
159
|
-
}], gridItemRefs: [{
|
|
160
|
-
type: ViewChildren,
|
|
161
|
-
args: ['grid_item', { read: ViewContainerRef }]
|
|
162
|
-
}] } });
|
|
163
|
-
//# 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 { 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 \"../../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: 'es-dashboard',\r\n  encapsulation: ViewEncapsulation.None,\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    private route: ActivatedRoute,\r\n    private cmpFactory: DashboardWidgetFactory,\r\n    private cdr: ChangeDetectorRef\r\n  ) {\r\n    this.intercom.send(InboundMessageTypes.Navigation, { sub: false, routeTitle: this.route.snapshot.data[\"title\"] });\r\n  }\r\n\r\n  public ngOnInit() { }\r\n\r\n  ngAfterViewInit(): void {\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  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      //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    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  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  renderLayout(comps: QueryList<ViewContainerRef>) {\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      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      //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      //componentRef.changeDetectorRef.detectChanges();\r\n    });\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  addItem() {\r\n    //this.dashboard.push({});\r\n  }\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>"]}
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
import { EventEmitter, Inject, Injectable } from "@angular/core";
|
|
2
|
-
import { DSH_DATA_SERVICE } from "../../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
|
-
/**
|
|
23
|
-
* Ascolta i cambiamenti sull'input DashboardDate e, se è cambiata, lancia refreshData()
|
|
24
|
-
*/
|
|
25
|
-
ngOnChanges(changes) {
|
|
26
|
-
//console.log(changes['DashboardDate'].currentValue);
|
|
27
|
-
if (changes['DashboardDate'].previousValue)
|
|
28
|
-
this.lastdate = changes['DashboardDate'].previousValue.toISOString();
|
|
29
|
-
let curdate = "";
|
|
30
|
-
if (changes['DashboardDate'].currentValue)
|
|
31
|
-
curdate = changes['DashboardDate'].currentValue.toISOString();
|
|
32
|
-
//fix per il datetimepicker material che cambia l'oggetto al momento del caricamento
|
|
33
|
-
if (this.lastdate != curdate) {
|
|
34
|
-
this.lastdate = curdate;
|
|
35
|
-
this.refreshData();
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* Prepara i parametri e lancia la chiamata GetWidgetData della service DashboardFeatureService.
|
|
40
|
-
* Imposta il model con i dati restituiti (setData) ed imposta il campo dataReady del component a true
|
|
41
|
-
*/
|
|
42
|
-
refreshData() {
|
|
43
|
-
if (!this.model)
|
|
44
|
-
return;
|
|
45
|
-
const pars = {};
|
|
46
|
-
if (this.DashboardDate)
|
|
47
|
-
pars["DT"] = this.DashboardDate.toISOString();
|
|
48
|
-
if (this.model.options && Object.keys(this.model.options).length != 0) {
|
|
49
|
-
for (let index = 0; index < Object.keys(this.model.options).length; index++) {
|
|
50
|
-
const k = Object.keys(this.model.options)[index];
|
|
51
|
-
pars[k] = this.model.options[k];
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
this.prepareGetDataParameters(pars);
|
|
55
|
-
this.dshService.GetWidgetData(this.model.backendid, this.model.name, pars).subscribe(data => {
|
|
56
|
-
if (this.model) {
|
|
57
|
-
this.model.setData(data);
|
|
58
|
-
this.dataReady = true;
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
/**
|
|
63
|
-
* Da chiamare quando l'utente preme il pulsante 'rimuovi' nella toolbar della widget.
|
|
64
|
-
*/
|
|
65
|
-
removeWidget() {
|
|
66
|
-
if (!this.model)
|
|
67
|
-
return;
|
|
68
|
-
this.OnRemove.emit(this.model.name);
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Da chiamare quando viene premuto il pulsante 'configure' nella toolbar della widget
|
|
72
|
-
*/
|
|
73
|
-
configureWidget() {
|
|
74
|
-
if (this.configuration) {
|
|
75
|
-
//finito di configurare -> refreshData
|
|
76
|
-
this.refreshData();
|
|
77
|
-
}
|
|
78
|
-
this.configuration = !this.configuration;
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
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 });
|
|
82
|
-
BaseWidgetComponent.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseWidgetComponent });
|
|
83
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BaseWidgetComponent, decorators: [{
|
|
84
|
-
type: Injectable
|
|
85
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
86
|
-
type: Inject,
|
|
87
|
-
args: [DSH_DATA_SERVICE]
|
|
88
|
-
}] }]; } });
|
|
89
|
-
//# 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 \"../../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  /**\r\n   * Ascolta i cambiamenti sull'input DashboardDate e, se è cambiata, lancia refreshData()\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 service DashboardFeatureService.\r\n   * Imposta il model con i dati restituiti (setData) ed imposta il campo dataReady del component 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   * HOOK: chiamato da refreshData() permette di modificare/aggiornare i parametri della chiamata GetWidgetData (della service DashboardFeatureService) 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}\r\n"]}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSVdpZGdldENvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rhc2hib2FyZC1mZWF0dXJlL3NyYy9saWIvY29tcG9uZW50cy93aWRnZXRzL0lXaWRnZXRDb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW1pdHRlciwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBJSmFjZVdpZGdldE1vZGVsIH0gZnJvbSBcIi4uLy4uL21vZGVscy93aWRnZXRzL0lKYWNlV2lkZ2V0TW9kZWxcIjtcclxuXHJcbi8qKlxyXG4gKiBJbnRlcmZhY2NpYSBjaGUgb2duaSBDb21wb25lbnQgY2hlIHJhcHByZXNlbnRhIHVuYSB3aWRnZXQgZGV2ZSBpbXBsZW1lbnRhcmUuXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIElXaWRnZXRDb21wb25lbnR7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBTZSByaWxldmFudGUgcGVyIHF1ZXN0YSBkYXNoYm9hcmQsIGluIHF1ZXN0byBpbnB1dCB2aWVuZSBpbXBvc3RhdGEgbGEgZGF0YSBzZWxlemlvbmF0YSBkYWxsJ3V0ZW50ZS5cclxuICAgICAqL1xyXG4gICAgRGFzaGJvYXJkRGF0ZTogRGF0ZTtcclxuICAgIC8qKlxyXG4gICAgICogTGFuY2lhdG8gcXVhbmRvIHF1ZXN0YSB3aWRnZXQgdmllbmUgcmltb3NzYSBkYWxsYSBkYXNoYm9hcmRcclxuICAgICAqL1xyXG4gICAgT25SZW1vdmU6IEV2ZW50RW1pdHRlcjxzdHJpbmc+O1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogSW1wb3N0YSBpbCBtb2RlbGxvIGRlbGxhIHdpZGdldCBuZWwgY29tcG9uZW50ZSBlIGwnaWQgZGVsIGJhY2tlbmQgZGEgY29udGF0dGFyZSBpbXBvc3RhdG8gYSBsaXZlbGxvIGRpIGRhc2hib2FyZCAodmVkaSBKYWNlRGFzaGJvYXJkQ29uZmlnKS5cclxuICAgICAqIFxyXG4gICAgICogTGFuY2lhdGEgc3ViaXRvIGRvcG8gbGEgY3JlYXppb25lIGRlbCBDb21wb25lbnRlLCBkdXJhbnRlIGlsIHJlbmRlcmluZyBkZWwgbGF5b3V0IGRlbGxhIGRhc2hib2FyZC5cclxuICAgICAqIFxyXG4gICAgICogQHBhcmFtIHdpZGdldE1vZGVsIEltcG9zdGEgaWwgbW9kZWxsbyBkZWxsYSB3aWRnZXQgbGV0dG8gbmVsIGxheW91dCByaWNldnV0byBkYWwgQkVcclxuICAgICAqL1xyXG4gICAgc2V0V2lkZ2V0TW9kZWwoZHNoQmFja2VuZElkOnN0cmluZywgd2lkZ2V0TW9kZWw6IElKYWNlV2lkZ2V0TW9kZWwpOnZvaWQ7XHJcbn0iXX0=
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
export var JaceWidgetTypes;
|
|
2
|
-
(function (JaceWidgetTypes) {
|
|
3
|
-
JaceWidgetTypes["CHART"] = "CHART";
|
|
4
|
-
JaceWidgetTypes["COUNTER"] = "COUNTER";
|
|
5
|
-
JaceWidgetTypes["LIST"] = "LIST";
|
|
6
|
-
JaceWidgetTypes["MULTIPROGRESS"] = "MULTIPROGRESS";
|
|
7
|
-
})(JaceWidgetTypes || (JaceWidgetTypes = {}));
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSmFjZVdpZGdldFR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGFzaGJvYXJkLWZlYXR1cmUvc3JjL2xpYi9jb21wb25lbnRzL3dpZGdldHMvSmFjZVdpZGdldFR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGVBS1g7QUFMRCxXQUFZLGVBQWU7SUFDM0Isa0NBQWEsQ0FBQTtJQUNiLHNDQUFpQixDQUFBO0lBQ2pCLGdDQUFXLENBQUE7SUFDWCxrREFBNkIsQ0FBQTtBQUM3QixDQUFDLEVBTFcsZUFBZSxLQUFmLGVBQWUsUUFLMUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBKYWNlV2lkZ2V0VHlwZXN7XHJcbkNIQVJUPSdDSEFSVCcsXHJcbkNPVU5URVI9J0NPVU5URVInLFxyXG5MSVNUPSdMSVNUJyxcclxuTVVMVElQUk9HUkVTUz0nTVVMVElQUk9HUkVTUydcclxufSJdfQ==
|