raain-app 1.6.21 → 1.6.24

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.
@@ -17,6 +17,7 @@ import { RaainSpeedComponent } from './raain-speed/raain-speed.component';
17
17
  import { RaainCompareStackComponent } from './raain-compare-stack/raain-compare-stack.component';
18
18
  import { RaainGlobeComponent } from './raain-globe/raain-globe.component';
19
19
  import { RaainDetailsComponent } from './raain-details/raain-details.component';
20
+ import { CumulativeSelectorComponent } from './cumulative-selector/cumulative-selector.component';
20
21
  import * as i0 from "@angular/core";
21
22
  export class SharedModule {
22
23
  constructor(parentModule) {
@@ -36,7 +37,8 @@ SharedModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
36
37
  RaainSpeedComponent,
37
38
  RaainGlobeComponent,
38
39
  ProfileIconDirective,
39
- RaainDetailsComponent], imports: [CommonModule, FormsModule, IonicModule, NgOptimizedImage, PipesModule], exports: [CommonModule,
40
+ RaainDetailsComponent,
41
+ CumulativeSelectorComponent], imports: [CommonModule, FormsModule, IonicModule, NgOptimizedImage, PipesModule], exports: [CommonModule,
40
42
  NgStyle,
41
43
  PipesModule,
42
44
  RaainMapComponent,
@@ -48,7 +50,8 @@ SharedModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
48
50
  RaainSpeedComponent,
49
51
  RaainGlobeComponent,
50
52
  ProfileIconDirective,
51
- RaainDetailsComponent] });
53
+ RaainDetailsComponent,
54
+ CumulativeSelectorComponent] });
52
55
  SharedModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SharedModule, providers: [Storage, RadarService, ProfileService, Cache, IonRange], imports: [CommonModule, FormsModule, IonicModule, PipesModule, CommonModule,
53
56
  PipesModule] });
54
57
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SharedModule, decorators: [{
@@ -65,6 +68,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
65
68
  RaainGlobeComponent,
66
69
  ProfileIconDirective,
67
70
  RaainDetailsComponent,
71
+ CumulativeSelectorComponent,
68
72
  ],
69
73
  imports: [CommonModule, FormsModule, IonicModule, NgOptimizedImage, PipesModule],
70
74
  providers: [Storage, RadarService, ProfileService, Cache, IonRange],
@@ -82,6 +86,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
82
86
  RaainGlobeComponent,
83
87
  ProfileIconDirective,
84
88
  RaainDetailsComponent,
89
+ CumulativeSelectorComponent,
85
90
  ],
86
91
  }]
87
92
  }], ctorParameters: function () { return [{ type: SharedModule, decorators: [{
@@ -89,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
89
94
  }, {
90
95
  type: SkipSelf
91
96
  }] }]; } });
92
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb3JlL3NoYXJlZC9zaGFyZWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsT0FBTyxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDeEUsT0FBTyxFQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzNELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUUzQyxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQzFDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsS0FBSyxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDdEMsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDOUQsT0FBTyxFQUFDLFdBQVcsRUFBRSxRQUFRLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDOUUsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0scURBQXFELENBQUM7QUFDaEcsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDdEYsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDNUYsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDeEUsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0scURBQXFELENBQUM7QUFDL0YsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDeEUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0seUNBQXlDLENBQUM7O0FBa0M5RSxNQUFNLE9BQU8sWUFBWTtJQUNyQixZQUFvQyxZQUEyQjtRQUMzRCxJQUFJLFlBQVksRUFBRTtZQUNkLG1CQUFtQjtZQUNuQixPQUFPLENBQUMsSUFBSSxDQUFDLGlFQUFpRSxDQUFDLENBQUM7U0FDbkY7SUFDTCxDQUFDOzswR0FOUSxZQUFZOzJHQUFaLFlBQVksaUJBOUJqQixpQkFBaUI7UUFDakIscUJBQXFCO1FBQ3JCLDBCQUEwQjtRQUMxQix1QkFBdUI7UUFDdkIseUJBQXlCO1FBQ3pCLDJCQUEyQjtRQUMzQixtQkFBbUI7UUFDbkIsbUJBQW1CO1FBQ25CLG9CQUFvQjtRQUNwQixxQkFBcUIsYUFFZixZQUFZLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLGFBRzNFLFlBQVk7UUFDWixPQUFPO1FBQ1AsV0FBVztRQUVYLGlCQUFpQjtRQUNqQixxQkFBcUI7UUFDckIsMEJBQTBCO1FBQzFCLHVCQUF1QjtRQUN2Qix5QkFBeUI7UUFDekIsMkJBQTJCO1FBQzNCLG1CQUFtQjtRQUNuQixtQkFBbUI7UUFDbkIsb0JBQW9CO1FBQ3BCLHFCQUFxQjsyR0FHaEIsWUFBWSxhQWxCVixDQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsY0FBYyxFQUFFLEtBQUssRUFBRSxRQUFRLENBQUMsWUFEekQsWUFBWSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQW9CLFdBQVcsRUFHM0UsWUFBWTtRQUVaLFdBQVc7NEZBY04sWUFBWTtrQkFoQ3hCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFO3dCQUNWLGlCQUFpQjt3QkFDakIscUJBQXFCO3dCQUNyQiwwQkFBMEI7d0JBQzFCLHVCQUF1Qjt3QkFDdkIseUJBQXlCO3dCQUN6QiwyQkFBMkI7d0JBQzNCLG1CQUFtQjt3QkFDbkIsbUJBQW1CO3dCQUNuQixvQkFBb0I7d0JBQ3BCLHFCQUFxQjtxQkFDeEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxDQUFDO29CQUNoRixTQUFTLEVBQUUsQ0FBQyxPQUFPLEVBQUUsWUFBWSxFQUFFLGNBQWMsRUFBRSxLQUFLLEVBQUUsUUFBUSxDQUFDO29CQUNuRSxPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixPQUFPO3dCQUNQLFdBQVc7d0JBRVgsaUJBQWlCO3dCQUNqQixxQkFBcUI7d0JBQ3JCLDBCQUEwQjt3QkFDMUIsdUJBQXVCO3dCQUN2Qix5QkFBeUI7d0JBQ3pCLDJCQUEyQjt3QkFDM0IsbUJBQW1CO3dCQUNuQixtQkFBbUI7d0JBQ25CLG9CQUFvQjt3QkFDcEIscUJBQXFCO3FCQUN4QjtpQkFDSjs7MEJBRWdCLFFBQVE7OzBCQUFJLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZSwgTmdPcHRpbWl6ZWRJbWFnZSwgTmdTdHlsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGUsIE9wdGlvbmFsLCBTa2lwU2VsZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Zvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7UHJvZmlsZVNlcnZpY2V9IGZyb20gJy4vcHJvZmlsZS5zZXJ2aWNlJztcbmltcG9ydCB7U3RvcmFnZX0gZnJvbSAnLi9zdG9yYWdlLnNlcnZpY2UnO1xuaW1wb3J0IHtSYWRhclNlcnZpY2V9IGZyb20gJy4vcmFkYXIuc2VydmljZSc7XG5pbXBvcnQge0NhY2hlfSBmcm9tICcuL2NhY2hlLnNlcnZpY2UnO1xuaW1wb3J0IHtQcm9maWxlSWNvbkRpcmVjdGl2ZX0gZnJvbSAnLi9wcm9maWxlLWljb24uZGlyZWN0aXZlJztcbmltcG9ydCB7SW9uaWNNb2R1bGUsIElvblJhbmdlfSBmcm9tICdAaW9uaWMvYW5ndWxhcic7XG5pbXBvcnQge1BpcGVzTW9kdWxlfSBmcm9tICcuL3BpcGVzLm1vZHVsZSc7XG5pbXBvcnQge1JhYWluTWFwQ29tcG9uZW50fSBmcm9tICcuL3JhYWluLW1hcC9yYWFpbi1tYXAuY29tcG9uZW50JztcbmltcG9ydCB7UmFhaW5Db21wYXJlQ29tcG9uZW50fSBmcm9tICcuL3JhYWluLWNvbXBhcmUvcmFhaW4tY29tcGFyZS5jb21wb25lbnQnO1xuaW1wb3J0IHtSYWFpbkNvbmZpZ3VyYXRpb25Db21wb25lbnR9IGZyb20gJy4vcmFhaW4tY29uZmlndXJhdGlvbi9yYWFpbi1jb25maWd1cmF0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQge1JhYWluRGF0ZUZvY3VzQ29tcG9uZW50fSBmcm9tICcuL3JhYWluLWRhdGUtZm9jdXMvcmFhaW4tZGF0ZS1mb2N1cy5jb21wb25lbnQnO1xuaW1wb3J0IHtSYWFpbkRhdGVEeW5hbWljQ29tcG9uZW50fSBmcm9tICcuL3JhYWluLWRhdGUtZHluYW1pYy9yYWFpbi1kYXRlLWR5bmFtaWMuY29tcG9uZW50JztcbmltcG9ydCB7UmFhaW5TcGVlZENvbXBvbmVudH0gZnJvbSAnLi9yYWFpbi1zcGVlZC9yYWFpbi1zcGVlZC5jb21wb25lbnQnO1xuaW1wb3J0IHtSYWFpbkNvbXBhcmVTdGFja0NvbXBvbmVudH0gZnJvbSAnLi9yYWFpbi1jb21wYXJlLXN0YWNrL3JhYWluLWNvbXBhcmUtc3RhY2suY29tcG9uZW50JztcbmltcG9ydCB7UmFhaW5HbG9iZUNvbXBvbmVudH0gZnJvbSAnLi9yYWFpbi1nbG9iZS9yYWFpbi1nbG9iZS5jb21wb25lbnQnO1xuaW1wb3J0IHtSYWFpbkRldGFpbHNDb21wb25lbnR9IGZyb20gJy4vcmFhaW4tZGV0YWlscy9yYWFpbi1kZXRhaWxzLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIFJhYWluTWFwQ29tcG9uZW50LFxuICAgICAgICBSYWFpbkNvbXBhcmVDb21wb25lbnQsXG4gICAgICAgIFJhYWluQ29tcGFyZVN0YWNrQ29tcG9uZW50LFxuICAgICAgICBSYWFpbkRhdGVGb2N1c0NvbXBvbmVudCxcbiAgICAgICAgUmFhaW5EYXRlRHluYW1pY0NvbXBvbmVudCxcbiAgICAgICAgUmFhaW5Db25maWd1cmF0aW9uQ29tcG9uZW50LFxuICAgICAgICBSYWFpblNwZWVkQ29tcG9uZW50LFxuICAgICAgICBSYWFpbkdsb2JlQ29tcG9uZW50LFxuICAgICAgICBQcm9maWxlSWNvbkRpcmVjdGl2ZSxcbiAgICAgICAgUmFhaW5EZXRhaWxzQ29tcG9uZW50LFxuICAgIF0sXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIElvbmljTW9kdWxlLCBOZ09wdGltaXplZEltYWdlLCBQaXBlc01vZHVsZV0sXG4gICAgcHJvdmlkZXJzOiBbU3RvcmFnZSwgUmFkYXJTZXJ2aWNlLCBQcm9maWxlU2VydmljZSwgQ2FjaGUsIElvblJhbmdlXSxcbiAgICBleHBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgTmdTdHlsZSxcbiAgICAgICAgUGlwZXNNb2R1bGUsXG5cbiAgICAgICAgUmFhaW5NYXBDb21wb25lbnQsXG4gICAgICAgIFJhYWluQ29tcGFyZUNvbXBvbmVudCxcbiAgICAgICAgUmFhaW5Db21wYXJlU3RhY2tDb21wb25lbnQsXG4gICAgICAgIFJhYWluRGF0ZUZvY3VzQ29tcG9uZW50LFxuICAgICAgICBSYWFpbkRhdGVEeW5hbWljQ29tcG9uZW50LFxuICAgICAgICBSYWFpbkNvbmZpZ3VyYXRpb25Db21wb25lbnQsXG4gICAgICAgIFJhYWluU3BlZWRDb21wb25lbnQsXG4gICAgICAgIFJhYWluR2xvYmVDb21wb25lbnQsXG4gICAgICAgIFByb2ZpbGVJY29uRGlyZWN0aXZlLFxuICAgICAgICBSYWFpbkRldGFpbHNDb21wb25lbnQsXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgU2hhcmVkTW9kdWxlIHtcbiAgICBjb25zdHJ1Y3RvcihAT3B0aW9uYWwoKSBAU2tpcFNlbGYoKSBwYXJlbnRNb2R1bGU/OiBTaGFyZWRNb2R1bGUpIHtcbiAgICAgICAgaWYgKHBhcmVudE1vZHVsZSkge1xuICAgICAgICAgICAgLy8gdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgICAgY29uc29sZS53YXJuKCdTaGFyZWRNb2R1bGUgaXMgYWxyZWFkeSBsb2FkZWQuIEltcG9ydCBpdCBpbiB0aGUgQXBwTW9kdWxlIG9ubHknKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
97
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb3JlL3NoYXJlZC9zaGFyZWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsT0FBTyxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDeEUsT0FBTyxFQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzNELE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUUzQyxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLG1CQUFtQixDQUFDO0FBQzFDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsS0FBSyxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDdEMsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDOUQsT0FBTyxFQUFDLFdBQVcsRUFBRSxRQUFRLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDOUUsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0scURBQXFELENBQUM7QUFDaEcsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sK0NBQStDLENBQUM7QUFDdEYsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sbURBQW1ELENBQUM7QUFDNUYsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDeEUsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0scURBQXFELENBQUM7QUFDL0YsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDeEUsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDOUUsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0scURBQXFELENBQUM7O0FBb0NoRyxNQUFNLE9BQU8sWUFBWTtJQUNyQixZQUFvQyxZQUEyQjtRQUMzRCxJQUFJLFlBQVksRUFBRTtZQUNkLG1CQUFtQjtZQUNuQixPQUFPLENBQUMsSUFBSSxDQUFDLGlFQUFpRSxDQUFDLENBQUM7U0FDbkY7SUFDTCxDQUFDOzswR0FOUSxZQUFZOzJHQUFaLFlBQVksaUJBaENqQixpQkFBaUI7UUFDakIscUJBQXFCO1FBQ3JCLDBCQUEwQjtRQUMxQix1QkFBdUI7UUFDdkIseUJBQXlCO1FBQ3pCLDJCQUEyQjtRQUMzQixtQkFBbUI7UUFDbkIsbUJBQW1CO1FBQ25CLG9CQUFvQjtRQUNwQixxQkFBcUI7UUFDckIsMkJBQTJCLGFBRXJCLFlBQVksRUFBRSxXQUFXLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLFdBQVcsYUFHM0UsWUFBWTtRQUNaLE9BQU87UUFDUCxXQUFXO1FBRVgsaUJBQWlCO1FBQ2pCLHFCQUFxQjtRQUNyQiwwQkFBMEI7UUFDMUIsdUJBQXVCO1FBQ3ZCLHlCQUF5QjtRQUN6QiwyQkFBMkI7UUFDM0IsbUJBQW1CO1FBQ25CLG1CQUFtQjtRQUNuQixvQkFBb0I7UUFDcEIscUJBQXFCO1FBQ3JCLDJCQUEyQjsyR0FHdEIsWUFBWSxhQW5CVixDQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsY0FBYyxFQUFFLEtBQUssRUFBRSxRQUFRLENBQUMsWUFEekQsWUFBWSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQW9CLFdBQVcsRUFHM0UsWUFBWTtRQUVaLFdBQVc7NEZBZU4sWUFBWTtrQkFsQ3hCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFO3dCQUNWLGlCQUFpQjt3QkFDakIscUJBQXFCO3dCQUNyQiwwQkFBMEI7d0JBQzFCLHVCQUF1Qjt3QkFDdkIseUJBQXlCO3dCQUN6QiwyQkFBMkI7d0JBQzNCLG1CQUFtQjt3QkFDbkIsbUJBQW1CO3dCQUNuQixvQkFBb0I7d0JBQ3BCLHFCQUFxQjt3QkFDckIsMkJBQTJCO3FCQUM5QjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLENBQUM7b0JBQ2hGLFNBQVMsRUFBRSxDQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsY0FBYyxFQUFFLEtBQUssRUFBRSxRQUFRLENBQUM7b0JBQ25FLE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLE9BQU87d0JBQ1AsV0FBVzt3QkFFWCxpQkFBaUI7d0JBQ2pCLHFCQUFxQjt3QkFDckIsMEJBQTBCO3dCQUMxQix1QkFBdUI7d0JBQ3ZCLHlCQUF5Qjt3QkFDekIsMkJBQTJCO3dCQUMzQixtQkFBbUI7d0JBQ25CLG1CQUFtQjt3QkFDbkIsb0JBQW9CO3dCQUNwQixxQkFBcUI7d0JBQ3JCLDJCQUEyQjtxQkFDOUI7aUJBQ0o7OzBCQUVnQixRQUFROzswQkFBSSxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21tb25Nb2R1bGUsIE5nT3B0aW1pemVkSW1hZ2UsIE5nU3R5bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge05nTW9kdWxlLCBPcHRpb25hbCwgU2tpcFNlbGZ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3Jtc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQge1Byb2ZpbGVTZXJ2aWNlfSBmcm9tICcuL3Byb2ZpbGUuc2VydmljZSc7XG5pbXBvcnQge1N0b3JhZ2V9IGZyb20gJy4vc3RvcmFnZS5zZXJ2aWNlJztcbmltcG9ydCB7UmFkYXJTZXJ2aWNlfSBmcm9tICcuL3JhZGFyLnNlcnZpY2UnO1xuaW1wb3J0IHtDYWNoZX0gZnJvbSAnLi9jYWNoZS5zZXJ2aWNlJztcbmltcG9ydCB7UHJvZmlsZUljb25EaXJlY3RpdmV9IGZyb20gJy4vcHJvZmlsZS1pY29uLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0lvbmljTW9kdWxlLCBJb25SYW5nZX0gZnJvbSAnQGlvbmljL2FuZ3VsYXInO1xuaW1wb3J0IHtQaXBlc01vZHVsZX0gZnJvbSAnLi9waXBlcy5tb2R1bGUnO1xuaW1wb3J0IHtSYWFpbk1hcENvbXBvbmVudH0gZnJvbSAnLi9yYWFpbi1tYXAvcmFhaW4tbWFwLmNvbXBvbmVudCc7XG5pbXBvcnQge1JhYWluQ29tcGFyZUNvbXBvbmVudH0gZnJvbSAnLi9yYWFpbi1jb21wYXJlL3JhYWluLWNvbXBhcmUuY29tcG9uZW50JztcbmltcG9ydCB7UmFhaW5Db25maWd1cmF0aW9uQ29tcG9uZW50fSBmcm9tICcuL3JhYWluLWNvbmZpZ3VyYXRpb24vcmFhaW4tY29uZmlndXJhdGlvbi5jb21wb25lbnQnO1xuaW1wb3J0IHtSYWFpbkRhdGVGb2N1c0NvbXBvbmVudH0gZnJvbSAnLi9yYWFpbi1kYXRlLWZvY3VzL3JhYWluLWRhdGUtZm9jdXMuY29tcG9uZW50JztcbmltcG9ydCB7UmFhaW5EYXRlRHluYW1pY0NvbXBvbmVudH0gZnJvbSAnLi9yYWFpbi1kYXRlLWR5bmFtaWMvcmFhaW4tZGF0ZS1keW5hbWljLmNvbXBvbmVudCc7XG5pbXBvcnQge1JhYWluU3BlZWRDb21wb25lbnR9IGZyb20gJy4vcmFhaW4tc3BlZWQvcmFhaW4tc3BlZWQuY29tcG9uZW50JztcbmltcG9ydCB7UmFhaW5Db21wYXJlU3RhY2tDb21wb25lbnR9IGZyb20gJy4vcmFhaW4tY29tcGFyZS1zdGFjay9yYWFpbi1jb21wYXJlLXN0YWNrLmNvbXBvbmVudCc7XG5pbXBvcnQge1JhYWluR2xvYmVDb21wb25lbnR9IGZyb20gJy4vcmFhaW4tZ2xvYmUvcmFhaW4tZ2xvYmUuY29tcG9uZW50JztcbmltcG9ydCB7UmFhaW5EZXRhaWxzQ29tcG9uZW50fSBmcm9tICcuL3JhYWluLWRldGFpbHMvcmFhaW4tZGV0YWlscy5jb21wb25lbnQnO1xuaW1wb3J0IHtDdW11bGF0aXZlU2VsZWN0b3JDb21wb25lbnR9IGZyb20gJy4vY3VtdWxhdGl2ZS1zZWxlY3Rvci9jdW11bGF0aXZlLXNlbGVjdG9yLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIFJhYWluTWFwQ29tcG9uZW50LFxuICAgICAgICBSYWFpbkNvbXBhcmVDb21wb25lbnQsXG4gICAgICAgIFJhYWluQ29tcGFyZVN0YWNrQ29tcG9uZW50LFxuICAgICAgICBSYWFpbkRhdGVGb2N1c0NvbXBvbmVudCxcbiAgICAgICAgUmFhaW5EYXRlRHluYW1pY0NvbXBvbmVudCxcbiAgICAgICAgUmFhaW5Db25maWd1cmF0aW9uQ29tcG9uZW50LFxuICAgICAgICBSYWFpblNwZWVkQ29tcG9uZW50LFxuICAgICAgICBSYWFpbkdsb2JlQ29tcG9uZW50LFxuICAgICAgICBQcm9maWxlSWNvbkRpcmVjdGl2ZSxcbiAgICAgICAgUmFhaW5EZXRhaWxzQ29tcG9uZW50LFxuICAgICAgICBDdW11bGF0aXZlU2VsZWN0b3JDb21wb25lbnQsXG4gICAgXSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZSwgSW9uaWNNb2R1bGUsIE5nT3B0aW1pemVkSW1hZ2UsIFBpcGVzTW9kdWxlXSxcbiAgICBwcm92aWRlcnM6IFtTdG9yYWdlLCBSYWRhclNlcnZpY2UsIFByb2ZpbGVTZXJ2aWNlLCBDYWNoZSwgSW9uUmFuZ2VdLFxuICAgIGV4cG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBOZ1N0eWxlLFxuICAgICAgICBQaXBlc01vZHVsZSxcblxuICAgICAgICBSYWFpbk1hcENvbXBvbmVudCxcbiAgICAgICAgUmFhaW5Db21wYXJlQ29tcG9uZW50LFxuICAgICAgICBSYWFpbkNvbXBhcmVTdGFja0NvbXBvbmVudCxcbiAgICAgICAgUmFhaW5EYXRlRm9jdXNDb21wb25lbnQsXG4gICAgICAgIFJhYWluRGF0ZUR5bmFtaWNDb21wb25lbnQsXG4gICAgICAgIFJhYWluQ29uZmlndXJhdGlvbkNvbXBvbmVudCxcbiAgICAgICAgUmFhaW5TcGVlZENvbXBvbmVudCxcbiAgICAgICAgUmFhaW5HbG9iZUNvbXBvbmVudCxcbiAgICAgICAgUHJvZmlsZUljb25EaXJlY3RpdmUsXG4gICAgICAgIFJhYWluRGV0YWlsc0NvbXBvbmVudCxcbiAgICAgICAgQ3VtdWxhdGl2ZVNlbGVjdG9yQ29tcG9uZW50LFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIFNoYXJlZE1vZHVsZSB7XG4gICAgY29uc3RydWN0b3IoQE9wdGlvbmFsKCkgQFNraXBTZWxmKCkgcGFyZW50TW9kdWxlPzogU2hhcmVkTW9kdWxlKSB7XG4gICAgICAgIGlmIChwYXJlbnRNb2R1bGUpIHtcbiAgICAgICAgICAgIC8vIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICAgIGNvbnNvbGUud2FybignU2hhcmVkTW9kdWxlIGlzIGFscmVhZHkgbG9hZGVkLiBJbXBvcnQgaXQgaW4gdGhlIEFwcE1vZHVsZSBvbmx5Jyk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
@@ -66,10 +66,10 @@ export class CompareManager {
66
66
  this.uiCompares = uiCompares;
67
67
  this.onChanges();
68
68
  }
69
- async refreshGlobalCompareQuality(targetsOrdered, withCompareDuplicate, cumulativeHours = 0) {
69
+ async refreshGlobalCompareQuality(targetsOrdered, period, withCompareDuplicate, cumulativeHours = 0) {
70
70
  try {
71
71
  await this.fetchRainComputationQualities(targetsOrdered, cumulativeHours);
72
- await this.buildComparesTimeline(targetsOrdered, withCompareDuplicate);
72
+ await this.buildComparesTimeline(targetsOrdered, period, withCompareDuplicate);
73
73
  if (!this.buildCompares.compareCumulative) {
74
74
  // throw Error('needs cumulative compare');
75
75
  return;
@@ -84,6 +84,9 @@ export class CompareManager {
84
84
  }
85
85
  }
86
86
  async setGaugesInMap() {
87
+ // Get all gauge IDs linked to this rainNode
88
+ const rainNodeGaugeIds = this.rainNode.getLinks(GaugeNode.TYPE).map((l) => l.getId());
89
+ // Fetch gauges from API (may be filtered/limited)
87
90
  let gaugesToFilter = await this.profileService.getGauges(this.rainNode?.id, this.rainNode.getCenter());
88
91
  gaugesToFilter = gaugesToFilter
89
92
  .sort((a, b) => {
@@ -91,9 +94,29 @@ export class CompareManager {
91
94
  b.approxDistanceFrom(this.rainNode.getCenter()));
92
95
  })
93
96
  .filter((v, index) => index < 200);
94
- const rainNodeGaugeIds = this.rainNode.getLinks(GaugeNode.TYPE).map((l) => l.getId());
95
- const visibleGauges = gaugesToFilter.filter((g) => rainNodeGaugeIds.indexOf(g.id) > -1);
96
- console.log('visibleGauges:', visibleGauges);
97
+ // Build a map of gauges from API response
98
+ const gaugesFromApi = new Map();
99
+ for (const gauge of gaugesToFilter) {
100
+ gaugesFromApi.set(gauge.id, gauge);
101
+ }
102
+ // Fetch missing gauges individually (those linked but not in API response)
103
+ const missingGaugeIds = rainNodeGaugeIds.filter((id) => !gaugesFromApi.has(id));
104
+ for (const gaugeId of missingGaugeIds) {
105
+ try {
106
+ const gauge = await this.profileService.getGauge(gaugeId);
107
+ if (gauge) {
108
+ gaugesFromApi.set(gauge.id, gauge);
109
+ }
110
+ }
111
+ catch (e) {
112
+ console.warn(`Failed to fetch gauge ${gaugeId}:`, e);
113
+ }
114
+ }
115
+ // Filter to only gauges linked to this rainNode
116
+ const visibleGauges = rainNodeGaugeIds
117
+ .map((id) => gaugesFromApi.get(id))
118
+ .filter((g) => !!g);
119
+ console.log('visibleGauges:', visibleGauges.length, '/', rainNodeGaugeIds.length);
97
120
  const gaugesLatLng = [];
98
121
  for (const gauge of visibleGauges) {
99
122
  gaugesLatLng.push(new MapLatLng(gauge.latitude, gauge.longitude, undefined, gauge.id, gauge.name));
@@ -201,13 +224,13 @@ export class CompareManager {
201
224
  }
202
225
  return result.sort((a, b) => a.date.getTime() - b.date.getTime());
203
226
  }
204
- async buildComparesTimeline(targetsOrdered, withCompareDuplicate) {
227
+ async buildComparesTimeline(targetsOrdered, period, withCompareDuplicate) {
205
228
  const compareDates = targetsOrdered.map((t) => t.date);
206
229
  const qualities = compareDates
207
230
  .filter((d) => !!d)
208
231
  .map((d) => this.getRainComputationQuality(d))
209
232
  .filter((rcq) => !!rcq);
210
- this.compareDates = compareDates; // compareDates.slice(1, -1);
233
+ this.compareDates = compareDates?.length > 1 ? compareDates : [period.begin, period.end]; // compareDates.slice(1, -1);
211
234
  this.buildCompares = SpeedMatrixContainer.BuildCompares(qualities, !withCompareDuplicate);
212
235
  return this.buildCompares;
213
236
  }
@@ -311,4 +334,4 @@ export class CompareManager {
311
334
  this.selectGaugeInCompare();
312
335
  }
313
336
  }
314
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompareManager.js","sourceRoot":"","sources":["../../../src/core/shared/tools/CompareManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {MapLatLng} from 'raain-ui';\nimport {\n    GaugeNode,\n    IComparePerDate,\n    ICompares,\n    PositionValue,\n    QualityPoint,\n    RainComputationQuality,\n    RainNode,\n    SpeedMatrixContainer,\n} from 'raain-model';\nimport {XYType} from '../xytype';\nimport {ProfileService} from '../profile.service';\nimport {FrameSet} from './FrameSet';\n\nexport interface ICompareTarget {\n    date: Date;\n    rainComputationId?: string;\n    rainComputationCumulativeId?: string;\n}\n\nexport interface IUICompare {\n    date: Date;\n    name: string;\n    comparePoints: XYType[];\n    comparePointsMax: XYType;\n    comparePointsHistory: QualityPoint[];\n    remarks: string;\n}\n\nexport class CompareManager {\n    public gaugesInMap: MapLatLng[];\n    public gaugesInCompare: MapLatLng[];\n    public selectedGauges: MapLatLng[];\n    public selectedPixels: MapLatLng[];\n    public pixelsSolutions: MapLatLng[][];\n    public speeds: MapLatLng[];\n\n    // from comparesTimeline\n    public compareNames: string[];\n    public uiCompares: IUICompare[];\n    public compareSpeedMatrix: PositionValue[];\n    public compareVersion: string;\n    public compareTrustedIndicator: number;\n    public compareDates: Date[];\n\n    public currentQualityDoneDate: Date;\n    public currentQualityLaunchedBy: string;\n    public currentQualityTimeSpentInMs: number;\n    public globalComparePoints: XYType[];\n    public globalComparePointsMax: XYType;\n    public compareSpeed: {angleInDegrees: number; pixelsPerPeriod: number};\n    protected buildCompares: ICompares;\n    protected selectedGauge: QualityPoint;\n    protected selectedGaugeInPoints: QualityPoint;\n    protected selectedGaugeInPointsDetail: string;\n    protected rainComputationQualitiesPerDate: any;\n\n    constructor(\n        protected profileService: ProfileService,\n        public onChanges: () => void = () => {}\n    ) {\n        this.cleanAll();\n    }\n\n    protected _rainNode: RainNode;\n\n    public get rainNode(): RainNode {\n        return this._rainNode;\n    }\n\n    public set rainNode(rainNode: RainNode) {\n        this._rainNode = rainNode;\n        this.cleanAll();\n    }\n\n    public cleanAll() {\n        this.gaugesInMap = [];\n        this.gaugesInCompare = [];\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\n        this.compareDates = [];\n        this.speeds = [];\n\n        this.buildCompares = {\n            comparesPerDate: [],\n            compareCumulative: null,\n        };\n        this.globalComparePoints = [];\n        this.globalComparePointsMax = new XYType(0, 0);\n        this.rainComputationQualitiesPerDate = {};\n\n        this.selectedGauge = null;\n        this.selectedGaugeInPoints = null;\n        this.cleanCompareQuality('no compare yet');\n    }\n\n    async refreshCompareQuality(frameSet: FrameSet, onlyOne: boolean) {\n        const comparePerDate = this.getComparePerDate(frameSet.date);\n\n        if (\n            !comparePerDate ||\n            !comparePerDate.rainComputationQuality?.qualitySpeedMatrixContainer\n        ) {\n            this.cleanCompareQuality(\n                'no current quality ' + Object.keys(this.rainComputationQualitiesPerDate)\n            );\n            this.onChanges();\n            return;\n        }\n\n        if (onlyOne) {\n            comparePerDate.compareTimeline = comparePerDate.compareTimeline.filter(\n                (c) => c.date.getTime() === frameSet.date.getTime()\n            );\n        }\n\n        const uiCompares: IUICompare[] = comparePerDate.compareTimeline\n            .map((c) => {\n                return {\n                    date: c.date,\n                    name: c.name,\n                    comparePoints: c.qualityPoints.map(\n                        (p) =>\n                            new XYType(\n                                p.getGaugeValue(),\n                                p.getRainValue(),\n                                2,\n                                p.gaugeLabel,\n                                p.gaugeId\n                            )\n                    ),\n                    comparePointsMax: new XYType(c.maxValue * 1.2, c.maxValue * 1.2),\n                    comparePointsHistory: c.qualityPointsLegacy,\n                    remarks: c.remarks,\n                };\n            })\n            .sort((a, b) => a.date?.getTime() - b.date?.getTime());\n\n        this.currentQualityDoneDate = comparePerDate.rainComputationQuality.isDoneDate;\n        this.currentQualityTimeSpentInMs = comparePerDate.rainComputationQuality.timeSpentInMs;\n        this.currentQualityLaunchedBy = comparePerDate.rainComputationQuality.launchedBy;\n        this.compareVersion = comparePerDate.rainComputationQuality.getVersion();\n\n        this.compareSpeed =\n            comparePerDate.rainComputationQuality.qualitySpeedMatrixContainer.getSpeed();\n        this.compareNames = uiCompares.map((c) => c.name);\n        this.uiCompares = uiCompares;\n\n        this.onChanges();\n    }\n\n    async refreshGlobalCompareQuality(\n        targetsOrdered: ICompareTarget[],\n        withCompareDuplicate: boolean,\n        cumulativeHours: number = 0\n    ) {\n        try {\n            await this.fetchRainComputationQualities(targetsOrdered, cumulativeHours);\n\n            await this.buildComparesTimeline(targetsOrdered, withCompareDuplicate);\n\n            if (!this.buildCompares.compareCumulative) {\n                // throw Error('needs cumulative compare');\n                return;\n            }\n\n            const countForAverage = targetsOrdered.length;\n            const maxValue = this.buildCompares.compareCumulative.maxValue * 1.2;\n            this.globalComparePoints = this.buildCompares.compareCumulative.qualityPoints.map(\n                (qp) =>\n                    new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId)\n            );\n            this.globalComparePointsMax = new XYType(maxValue, maxValue);\n        } catch (e) {\n            console.warn(e);\n        }\n    }\n\n    async setGaugesInMap() {\n        let gaugesToFilter = await this.profileService.getGauges(\n            this.rainNode?.id,\n            this.rainNode.getCenter()\n        );\n        gaugesToFilter = gaugesToFilter\n            .sort((a, b) => {\n                return (\n                    a.approxDistanceFrom(this.rainNode.getCenter()) -\n                    b.approxDistanceFrom(this.rainNode.getCenter())\n                );\n            })\n            .filter((v, index) => index < 200);\n\n        const rainNodeGaugeIds = this.rainNode.getLinks(GaugeNode.TYPE).map((l) => l.getId());\n\n        const visibleGauges = gaugesToFilter.filter((g) => rainNodeGaugeIds.indexOf(g.id) > -1);\n        console.log('visibleGauges:', visibleGauges);\n\n        const gaugesLatLng: MapLatLng[] = [];\n        for (const gauge of visibleGauges) {\n            gaugesLatLng.push(\n                new MapLatLng(gauge.latitude, gauge.longitude, undefined, gauge.id, gauge.name)\n            );\n        }\n        this.gaugesInMap = gaugesLatLng;\n    }\n\n    async setGaugesInCompare() {\n        const qualityPoints: QualityPoint[] = [];\n        for (const compare of this.uiCompares) {\n            for (const qualityPoint of compare.comparePointsHistory) {\n                const alreadyAdded = qualityPoints.filter(\n                    (p) => p?.gaugeId === qualityPoint.gaugeId\n                );\n                if (alreadyAdded.length === 0) {\n                    qualityPoints.push(qualityPoint);\n                }\n            }\n        }\n\n        this.gaugesInCompare = qualityPoints.map((p) => {\n            return new MapLatLng(\n                p.gaugeCartesianValue.lat,\n                p.gaugeCartesianValue.lng,\n                0,\n                p.gaugeId,\n                p.gaugeLabel + '>' + p.getGaugeValue(),\n                p.getGaugeValue()\n            );\n        });\n\n        this.resetSelectedGauges();\n    }\n\n    async selectGauge(gaugeId: string, compareIndex: number) {\n        if (gaugeId) {\n            const xys = this.getCurrentQualityPoints(compareIndex).filter(\n                (p) => p.gaugeId === gaugeId\n            );\n            this.selectedGauge = xys.length === 1 ? xys[0] : null;\n        } else {\n            this.selectedGauge = null;\n        }\n\n        if (!this.selectedGauge) {\n            this.resetSelectedGauges();\n            const gaugesFiltered = this.gaugesInMap.filter((g) => g.id === gaugeId);\n            if (gaugesFiltered.length === 1) {\n                this.selectedGauges = [gaugesFiltered[0]];\n            }\n            return;\n        }\n\n        const selectedGaugeInPoints = this.getCurrentQualityPoints(compareIndex).filter(\n            (p) => p.gaugeId === this.selectedGauge.gaugeId\n        );\n        let pixelsSolutions: MapLatLng[][] = [];\n\n        if (selectedGaugeInPoints.length === 1) {\n            const remarks = JSON.parse(selectedGaugeInPoints[0].remark).sort(\n                (a, b) => a.criteriaAttemptedToBeMinimum - b.criteriaAttemptedToBeMinimum\n            );\n            console.log(remarks);\n            pixelsSolutions = remarks.map((remark) =>\n                remark.solutionForGauge.pixels.map(\n                    (p) =>\n                        new MapLatLng(\n                            p.y + 0.005,\n                            p.x + 0.01,\n                            0,\n                            '' + !remark.notPossible,\n                            '' + !remark.notPossible,\n                            1\n                        )\n                )\n            );\n\n            const timeDeltaInMinutes = selectedGaugeInPoints[0].getTimeDeltaInMinutes();\n            this.selectedGaugeInPointsDetail =\n                '' +\n                selectedGaugeInPoints[0].gaugeLabel +\n                ' > ' +\n                Math.round(selectedGaugeInPoints[0].getGaugeValue() * 100) / 100 +\n                ' / ' +\n                Math.round(selectedGaugeInPoints[0].getRainValue() * 100) / 100 +\n                ' dT=' +\n                timeDeltaInMinutes;\n\n            this.selectedGaugeInPoints = selectedGaugeInPoints[0];\n        } else {\n            this.selectedGaugeInPoints = null;\n            this.selectedGauges = [];\n            this.selectedPixels = [];\n            this.pixelsSolutions = [];\n            return;\n        }\n\n        this.selectedGauges = [\n            new MapLatLng(\n                this.selectedGaugeInPoints.gaugeCartesianValue.lat,\n                this.selectedGaugeInPoints.gaugeCartesianValue.lng,\n                undefined,\n                this.selectedGaugeInPoints.gaugeId,\n                this.selectedGaugeInPoints.gaugeLabel +\n                    '>' +\n                    this.selectedGaugeInPoints.gaugeCartesianValue.value,\n                this.selectedGaugeInPoints.gaugeCartesianValue.value\n            ),\n        ];\n\n        this.selectGaugeInCompare();\n\n        const pixels: MapLatLng[] = [];\n        for (const rainCartesianValue of this.selectedGaugeInPoints.rainCartesianValues) {\n            pixels.push(\n                new MapLatLng(rainCartesianValue.lat + 0.005, rainCartesianValue.lng + 0.01)\n            );\n        }\n        this.selectedPixels = pixels;\n\n        this.pixelsSolutions = pixelsSolutions;\n    }\n\n    // Returns all granular quality points across all dates in the period (excludes cumulative end date)\n    getAllGranularComparePoints(): {\n        date: Date;\n        gaugeName: string;\n        gaugeValue: number;\n        pixelValue: number;\n    }[] {\n        const result: {date: Date; gaugeName: string; gaugeValue: number; pixelValue: number}[] =\n            [];\n\n        if (!this.buildCompares?.comparesPerDate?.length || !this.compareDates?.length) {\n            return result;\n        }\n\n        // Find the last date (cumulative end date) to exclude it\n        const lastDateTime = Math.max(...this.compareDates.map((d) => d.getTime()));\n\n        for (const comparePerDate of this.buildCompares.comparesPerDate) {\n            // Skip the last date which contains cumulative values\n            if (comparePerDate.date.getTime() >= lastDateTime) {\n                continue;\n            }\n            if (!comparePerDate.compareTimeline?.length) {\n                continue;\n            }\n            // Get first timeline entry (current step) for each date\n            const currentCompare = comparePerDate.compareTimeline[0];\n            if (!currentCompare?.qualityPoints?.length) {\n                continue;\n            }\n            for (const qp of currentCompare.qualityPoints) {\n                result.push({\n                    date: comparePerDate.date,\n                    gaugeName: qp.gaugeLabel,\n                    gaugeValue: qp.getGaugeValue(),\n                    pixelValue: qp.getRainValue(),\n                });\n            }\n        }\n\n        return result.sort((a, b) => a.date.getTime() - b.date.getTime());\n    }\n\n    protected async buildComparesTimeline(\n        targetsOrdered: ICompareTarget[],\n        withCompareDuplicate: boolean\n    ): Promise<ICompares> {\n        const compareDates = targetsOrdered.map((t) => t.date);\n\n        const qualities: RainComputationQuality[] = compareDates\n            .filter((d) => !!d)\n            .map((d) => this.getRainComputationQuality(d))\n            .filter((rcq) => !!rcq);\n\n        this.compareDates = compareDates; // compareDates.slice(1, -1);\n\n        this.buildCompares = SpeedMatrixContainer.BuildCompares(qualities, !withCompareDuplicate);\n        return this.buildCompares;\n    }\n\n    protected getComparePerDate(date: Date): IComparePerDate {\n        const existing = this.buildCompares.comparesPerDate.filter(\n            (c) => c.date.getTime() === date.getTime()\n        );\n        if (existing.length === 1) {\n            return existing[0];\n        }\n        return null;\n    }\n\n    protected getCurrentQualityPoints(compareIndex: number) {\n        if (\n            this.uiCompares.length === 0 ||\n            compareIndex < 0 ||\n            this.compareNames.length < compareIndex\n        ) {\n            return [];\n        }\n\n        return this.uiCompares[compareIndex].comparePointsHistory;\n    }\n\n    protected cleanCompareQuality(details?: string) {\n        this.compareVersion = details;\n        this.compareNames = [];\n        this.uiCompares = [];\n        this.compareSpeedMatrix = [];\n        this.compareTrustedIndicator = undefined;\n\n        this.currentQualityDoneDate = new Date(-1);\n        this.currentQualityLaunchedBy = '';\n        this.currentQualityTimeSpentInMs = -1;\n    }\n\n    protected async fetchRainComputationQualities(\n        targetsOrdered: ICompareTarget[],\n        cumulativeHours: number = 0\n    ) {\n        // For N-hour cumulative, only fetch once for the last target (end of period)\n        const targetsToFetch =\n            cumulativeHours > 0 ? [targetsOrdered[targetsOrdered.length - 1]] : targetsOrdered;\n\n        for (const target of targetsToFetch) {\n            if (!this.rainComputationQualitiesPerDate[target.date.toISOString()]) {\n                try {\n                    let rainComputationQuality: RainComputationQuality;\n\n                    if (cumulativeHours > 0 && target.rainComputationCumulativeId) {\n                        // N-hour cumulative: fetch aggregated quality for the whole period\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCumulativesCompareByDate(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                target.date,\n                                cumulativeHours\n                            );\n                    } else if (target.rainComputationCumulativeId) {\n                        // 5-min granular: fetch individual quality\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCompareByDate(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                target.date\n                            );\n                    }\n\n                    if (rainComputationQuality) {\n                        let isConsistent = true;\n                        const matrices =\n                            rainComputationQuality.qualitySpeedMatrixContainer.getMatrices();\n                        for (const matrix of matrices) {\n                            if (!matrix.isConsistent()) {\n                                isConsistent = false;\n                            }\n                        }\n\n                        if (!isConsistent) {\n                            console.warn(\n                                `One of rainComputationQuality matrices is not consistent for ${target.date.toISOString()}`\n                            );\n                        }\n\n                        this.rainComputationQualitiesPerDate[target.date.toISOString()] =\n                            rainComputationQuality;\n                    }\n                } catch (e) {\n                    console.warn(e);\n                }\n            }\n        }\n    }\n\n    protected getRainComputationQuality(date: Date): RainComputationQuality {\n        return this.rainComputationQualitiesPerDate[date.toISOString()];\n    }\n\n    protected selectGaugeInCompare() {\n        const globalComparePoints = JSON.parse(JSON.stringify(this.globalComparePoints));\n        for (const p of globalComparePoints) {\n            if (p.id === this.selectedGaugeInPoints?.gaugeId) {\n                p.r = 10;\n            } else {\n                p.r = 2;\n            }\n        }\n        this.globalComparePoints = globalComparePoints;\n\n        for (const compare of this.uiCompares) {\n            const comparePoints = JSON.parse(JSON.stringify(compare.comparePoints));\n            comparePoints.forEach((p) => {\n                if (p.id === this.selectedGaugeInPoints?.gaugeId) {\n                    p.r = 10;\n                } else {\n                    p.r = 3;\n                }\n            });\n            compare.comparePoints = comparePoints;\n        }\n    }\n\n    protected resetSelectedGauges() {\n        // console.log('resetSelectedGauges reset');\n        this.selectedGauge = null;\n        this.selectedGaugeInPoints = null;\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\n        this.selectGaugeInCompare();\n    }\n}\n"]}
337
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompareManager.js","sourceRoot":"","sources":["../../../src/core/shared/tools/CompareManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {MapLatLng} from 'raain-ui';\nimport {\n    GaugeNode,\n    IComparePerDate,\n    ICompares,\n    PositionValue,\n    QualityPoint,\n    RainComputationQuality,\n    RainNode,\n    SpeedMatrixContainer,\n} from 'raain-model';\nimport {XYType} from '../xytype';\nimport {ProfileService} from '../profile.service';\nimport {FrameSet} from './FrameSet';\n\nexport interface ICompareTarget {\n    date: Date;\n    rainComputationId?: string;\n    rainComputationCumulativeId?: string;\n}\n\nexport interface IUICompare {\n    date: Date;\n    name: string;\n    comparePoints: XYType[];\n    comparePointsMax: XYType;\n    comparePointsHistory: QualityPoint[];\n    remarks: string;\n}\n\nexport class CompareManager {\n    public gaugesInMap: MapLatLng[];\n    public gaugesInCompare: MapLatLng[];\n    public selectedGauges: MapLatLng[];\n    public selectedPixels: MapLatLng[];\n    public pixelsSolutions: MapLatLng[][];\n    public speeds: MapLatLng[];\n\n    // from comparesTimeline\n    public compareNames: string[];\n    public uiCompares: IUICompare[];\n    public compareSpeedMatrix: PositionValue[];\n    public compareVersion: string;\n    public compareTrustedIndicator: number;\n    public compareDates: Date[];\n\n    public currentQualityDoneDate: Date;\n    public currentQualityLaunchedBy: string;\n    public currentQualityTimeSpentInMs: number;\n    public globalComparePoints: XYType[];\n    public globalComparePointsMax: XYType;\n    public compareSpeed: {angleInDegrees: number; pixelsPerPeriod: number};\n    protected buildCompares: ICompares;\n    protected selectedGauge: QualityPoint;\n    protected selectedGaugeInPoints: QualityPoint;\n    protected selectedGaugeInPointsDetail: string;\n    protected rainComputationQualitiesPerDate: any;\n\n    constructor(\n        protected profileService: ProfileService,\n        public onChanges: () => void = () => {}\n    ) {\n        this.cleanAll();\n    }\n\n    protected _rainNode: RainNode;\n\n    public get rainNode(): RainNode {\n        return this._rainNode;\n    }\n\n    public set rainNode(rainNode: RainNode) {\n        this._rainNode = rainNode;\n        this.cleanAll();\n    }\n\n    public cleanAll() {\n        this.gaugesInMap = [];\n        this.gaugesInCompare = [];\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\n        this.compareDates = [];\n        this.speeds = [];\n\n        this.buildCompares = {\n            comparesPerDate: [],\n            compareCumulative: null,\n        };\n        this.globalComparePoints = [];\n        this.globalComparePointsMax = new XYType(0, 0);\n        this.rainComputationQualitiesPerDate = {};\n\n        this.selectedGauge = null;\n        this.selectedGaugeInPoints = null;\n        this.cleanCompareQuality('no compare yet');\n    }\n\n    async refreshCompareQuality(frameSet: FrameSet, onlyOne: boolean) {\n        const comparePerDate = this.getComparePerDate(frameSet.date);\n\n        if (\n            !comparePerDate ||\n            !comparePerDate.rainComputationQuality?.qualitySpeedMatrixContainer\n        ) {\n            this.cleanCompareQuality(\n                'no current quality ' + Object.keys(this.rainComputationQualitiesPerDate)\n            );\n            this.onChanges();\n            return;\n        }\n\n        if (onlyOne) {\n            comparePerDate.compareTimeline = comparePerDate.compareTimeline.filter(\n                (c) => c.date.getTime() === frameSet.date.getTime()\n            );\n        }\n\n        const uiCompares: IUICompare[] = comparePerDate.compareTimeline\n            .map((c) => {\n                return {\n                    date: c.date,\n                    name: c.name,\n                    comparePoints: c.qualityPoints.map(\n                        (p) =>\n                            new XYType(\n                                p.getGaugeValue(),\n                                p.getRainValue(),\n                                2,\n                                p.gaugeLabel,\n                                p.gaugeId\n                            )\n                    ),\n                    comparePointsMax: new XYType(c.maxValue * 1.2, c.maxValue * 1.2),\n                    comparePointsHistory: c.qualityPointsLegacy,\n                    remarks: c.remarks,\n                };\n            })\n            .sort((a, b) => a.date?.getTime() - b.date?.getTime());\n\n        this.currentQualityDoneDate = comparePerDate.rainComputationQuality.isDoneDate;\n        this.currentQualityTimeSpentInMs = comparePerDate.rainComputationQuality.timeSpentInMs;\n        this.currentQualityLaunchedBy = comparePerDate.rainComputationQuality.launchedBy;\n        this.compareVersion = comparePerDate.rainComputationQuality.getVersion();\n\n        this.compareSpeed =\n            comparePerDate.rainComputationQuality.qualitySpeedMatrixContainer.getSpeed();\n        this.compareNames = uiCompares.map((c) => c.name);\n        this.uiCompares = uiCompares;\n\n        this.onChanges();\n    }\n\n    async refreshGlobalCompareQuality(\n        targetsOrdered: ICompareTarget[],\n        period: {begin: Date; end: Date},\n        withCompareDuplicate: boolean,\n        cumulativeHours: number = 0\n    ) {\n        try {\n            await this.fetchRainComputationQualities(targetsOrdered, cumulativeHours);\n\n            await this.buildComparesTimeline(targetsOrdered, period, withCompareDuplicate);\n\n            if (!this.buildCompares.compareCumulative) {\n                // throw Error('needs cumulative compare');\n                return;\n            }\n\n            const countForAverage = targetsOrdered.length;\n            const maxValue = this.buildCompares.compareCumulative.maxValue * 1.2;\n            this.globalComparePoints = this.buildCompares.compareCumulative.qualityPoints.map(\n                (qp) =>\n                    new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId)\n            );\n            this.globalComparePointsMax = new XYType(maxValue, maxValue);\n        } catch (e) {\n            console.warn(e);\n        }\n    }\n\n    async setGaugesInMap() {\n        // Get all gauge IDs linked to this rainNode\n        const rainNodeGaugeIds = this.rainNode.getLinks(GaugeNode.TYPE).map((l) => l.getId());\n\n        // Fetch gauges from API (may be filtered/limited)\n        let gaugesToFilter = await this.profileService.getGauges(\n            this.rainNode?.id,\n            this.rainNode.getCenter()\n        );\n        gaugesToFilter = gaugesToFilter\n            .sort((a, b) => {\n                return (\n                    a.approxDistanceFrom(this.rainNode.getCenter()) -\n                    b.approxDistanceFrom(this.rainNode.getCenter())\n                );\n            })\n            .filter((v, index) => index < 200);\n\n        // Build a map of gauges from API response\n        const gaugesFromApi = new Map<\n            string,\n            {id: string; latitude: number; longitude: number; name: string}\n        >();\n        for (const gauge of gaugesToFilter) {\n            gaugesFromApi.set(gauge.id, gauge);\n        }\n\n        // Fetch missing gauges individually (those linked but not in API response)\n        const missingGaugeIds = rainNodeGaugeIds.filter((id) => !gaugesFromApi.has(id));\n        for (const gaugeId of missingGaugeIds) {\n            try {\n                const gauge = await this.profileService.getGauge(gaugeId);\n                if (gauge) {\n                    gaugesFromApi.set(gauge.id, gauge);\n                }\n            } catch (e) {\n                console.warn(`Failed to fetch gauge ${gaugeId}:`, e);\n            }\n        }\n\n        // Filter to only gauges linked to this rainNode\n        const visibleGauges = rainNodeGaugeIds\n            .map((id) => gaugesFromApi.get(id))\n            .filter((g) => !!g);\n        console.log('visibleGauges:', visibleGauges.length, '/', rainNodeGaugeIds.length);\n\n        const gaugesLatLng: MapLatLng[] = [];\n        for (const gauge of visibleGauges) {\n            gaugesLatLng.push(\n                new MapLatLng(gauge.latitude, gauge.longitude, undefined, gauge.id, gauge.name)\n            );\n        }\n        this.gaugesInMap = gaugesLatLng;\n    }\n\n    async setGaugesInCompare() {\n        const qualityPoints: QualityPoint[] = [];\n        for (const compare of this.uiCompares) {\n            for (const qualityPoint of compare.comparePointsHistory) {\n                const alreadyAdded = qualityPoints.filter(\n                    (p) => p?.gaugeId === qualityPoint.gaugeId\n                );\n                if (alreadyAdded.length === 0) {\n                    qualityPoints.push(qualityPoint);\n                }\n            }\n        }\n\n        this.gaugesInCompare = qualityPoints.map((p) => {\n            return new MapLatLng(\n                p.gaugeCartesianValue.lat,\n                p.gaugeCartesianValue.lng,\n                0,\n                p.gaugeId,\n                p.gaugeLabel + '>' + p.getGaugeValue(),\n                p.getGaugeValue()\n            );\n        });\n\n        this.resetSelectedGauges();\n    }\n\n    async selectGauge(gaugeId: string, compareIndex: number) {\n        if (gaugeId) {\n            const xys = this.getCurrentQualityPoints(compareIndex).filter(\n                (p) => p.gaugeId === gaugeId\n            );\n            this.selectedGauge = xys.length === 1 ? xys[0] : null;\n        } else {\n            this.selectedGauge = null;\n        }\n\n        if (!this.selectedGauge) {\n            this.resetSelectedGauges();\n            const gaugesFiltered = this.gaugesInMap.filter((g) => g.id === gaugeId);\n            if (gaugesFiltered.length === 1) {\n                this.selectedGauges = [gaugesFiltered[0]];\n            }\n            return;\n        }\n\n        const selectedGaugeInPoints = this.getCurrentQualityPoints(compareIndex).filter(\n            (p) => p.gaugeId === this.selectedGauge.gaugeId\n        );\n        let pixelsSolutions: MapLatLng[][] = [];\n\n        if (selectedGaugeInPoints.length === 1) {\n            const remarks = JSON.parse(selectedGaugeInPoints[0].remark).sort(\n                (a, b) => a.criteriaAttemptedToBeMinimum - b.criteriaAttemptedToBeMinimum\n            );\n            console.log(remarks);\n            pixelsSolutions = remarks.map((remark) =>\n                remark.solutionForGauge.pixels.map(\n                    (p) =>\n                        new MapLatLng(\n                            p.y + 0.005,\n                            p.x + 0.01,\n                            0,\n                            '' + !remark.notPossible,\n                            '' + !remark.notPossible,\n                            1\n                        )\n                )\n            );\n\n            const timeDeltaInMinutes = selectedGaugeInPoints[0].getTimeDeltaInMinutes();\n            this.selectedGaugeInPointsDetail =\n                '' +\n                selectedGaugeInPoints[0].gaugeLabel +\n                ' > ' +\n                Math.round(selectedGaugeInPoints[0].getGaugeValue() * 100) / 100 +\n                ' / ' +\n                Math.round(selectedGaugeInPoints[0].getRainValue() * 100) / 100 +\n                ' dT=' +\n                timeDeltaInMinutes;\n\n            this.selectedGaugeInPoints = selectedGaugeInPoints[0];\n        } else {\n            this.selectedGaugeInPoints = null;\n            this.selectedGauges = [];\n            this.selectedPixels = [];\n            this.pixelsSolutions = [];\n            return;\n        }\n\n        this.selectedGauges = [\n            new MapLatLng(\n                this.selectedGaugeInPoints.gaugeCartesianValue.lat,\n                this.selectedGaugeInPoints.gaugeCartesianValue.lng,\n                undefined,\n                this.selectedGaugeInPoints.gaugeId,\n                this.selectedGaugeInPoints.gaugeLabel +\n                    '>' +\n                    this.selectedGaugeInPoints.gaugeCartesianValue.value,\n                this.selectedGaugeInPoints.gaugeCartesianValue.value\n            ),\n        ];\n\n        this.selectGaugeInCompare();\n\n        const pixels: MapLatLng[] = [];\n        for (const rainCartesianValue of this.selectedGaugeInPoints.rainCartesianValues) {\n            pixels.push(\n                new MapLatLng(rainCartesianValue.lat + 0.005, rainCartesianValue.lng + 0.01)\n            );\n        }\n        this.selectedPixels = pixels;\n\n        this.pixelsSolutions = pixelsSolutions;\n    }\n\n    // Returns all granular quality points across all dates in the period (excludes cumulative end date)\n    getAllGranularComparePoints(): {\n        date: Date;\n        gaugeName: string;\n        gaugeValue: number;\n        pixelValue: number;\n    }[] {\n        const result: {date: Date; gaugeName: string; gaugeValue: number; pixelValue: number}[] =\n            [];\n\n        if (!this.buildCompares?.comparesPerDate?.length || !this.compareDates?.length) {\n            return result;\n        }\n\n        // Find the last date (cumulative end date) to exclude it\n        const lastDateTime = Math.max(...this.compareDates.map((d) => d.getTime()));\n\n        for (const comparePerDate of this.buildCompares.comparesPerDate) {\n            // Skip the last date which contains cumulative values\n            if (comparePerDate.date.getTime() >= lastDateTime) {\n                continue;\n            }\n            if (!comparePerDate.compareTimeline?.length) {\n                continue;\n            }\n            // Get first timeline entry (current step) for each date\n            const currentCompare = comparePerDate.compareTimeline[0];\n            if (!currentCompare?.qualityPoints?.length) {\n                continue;\n            }\n            for (const qp of currentCompare.qualityPoints) {\n                result.push({\n                    date: comparePerDate.date,\n                    gaugeName: qp.gaugeLabel,\n                    gaugeValue: qp.getGaugeValue(),\n                    pixelValue: qp.getRainValue(),\n                });\n            }\n        }\n\n        return result.sort((a, b) => a.date.getTime() - b.date.getTime());\n    }\n\n    protected async buildComparesTimeline(\n        targetsOrdered: ICompareTarget[],\n        period: {begin: Date; end: Date},\n        withCompareDuplicate: boolean\n    ): Promise<ICompares> {\n        const compareDates = targetsOrdered.map((t) => t.date);\n\n        const qualities: RainComputationQuality[] = compareDates\n            .filter((d) => !!d)\n            .map((d) => this.getRainComputationQuality(d))\n            .filter((rcq) => !!rcq);\n\n        this.compareDates = compareDates?.length > 1 ? compareDates : [period.begin, period.end]; // compareDates.slice(1, -1);\n\n        this.buildCompares = SpeedMatrixContainer.BuildCompares(qualities, !withCompareDuplicate);\n        return this.buildCompares;\n    }\n\n    protected getComparePerDate(date: Date): IComparePerDate {\n        const existing = this.buildCompares.comparesPerDate.filter(\n            (c) => c.date.getTime() === date.getTime()\n        );\n        if (existing.length === 1) {\n            return existing[0];\n        }\n        return null;\n    }\n\n    protected getCurrentQualityPoints(compareIndex: number) {\n        if (\n            this.uiCompares.length === 0 ||\n            compareIndex < 0 ||\n            this.compareNames.length < compareIndex\n        ) {\n            return [];\n        }\n\n        return this.uiCompares[compareIndex].comparePointsHistory;\n    }\n\n    protected cleanCompareQuality(details?: string) {\n        this.compareVersion = details;\n        this.compareNames = [];\n        this.uiCompares = [];\n        this.compareSpeedMatrix = [];\n        this.compareTrustedIndicator = undefined;\n\n        this.currentQualityDoneDate = new Date(-1);\n        this.currentQualityLaunchedBy = '';\n        this.currentQualityTimeSpentInMs = -1;\n    }\n\n    protected async fetchRainComputationQualities(\n        targetsOrdered: ICompareTarget[],\n        cumulativeHours: number = 0\n    ) {\n        // For N-hour cumulative, only fetch once for the last target (end of period)\n        const targetsToFetch =\n            cumulativeHours > 0 ? [targetsOrdered[targetsOrdered.length - 1]] : targetsOrdered;\n\n        for (const target of targetsToFetch) {\n            if (!this.rainComputationQualitiesPerDate[target.date.toISOString()]) {\n                try {\n                    let rainComputationQuality: RainComputationQuality;\n\n                    if (cumulativeHours > 0 && target.rainComputationCumulativeId) {\n                        // N-hour cumulative: fetch aggregated quality for the whole period\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCumulativesCompareByDate(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                target.date,\n                                cumulativeHours\n                            );\n                    } else if (target.rainComputationCumulativeId) {\n                        // 5-min granular: fetch individual quality\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCompareByDate(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                target.date\n                            );\n                    }\n\n                    if (rainComputationQuality) {\n                        let isConsistent = true;\n                        const matrices =\n                            rainComputationQuality.qualitySpeedMatrixContainer.getMatrices();\n                        for (const matrix of matrices) {\n                            if (!matrix.isConsistent()) {\n                                isConsistent = false;\n                            }\n                        }\n\n                        if (!isConsistent) {\n                            console.warn(\n                                `One of rainComputationQuality matrices is not consistent for ${target.date.toISOString()}`\n                            );\n                        }\n\n                        this.rainComputationQualitiesPerDate[target.date.toISOString()] =\n                            rainComputationQuality;\n                    }\n                } catch (e) {\n                    console.warn(e);\n                }\n            }\n        }\n    }\n\n    protected getRainComputationQuality(date: Date): RainComputationQuality {\n        return this.rainComputationQualitiesPerDate[date.toISOString()];\n    }\n\n    protected selectGaugeInCompare() {\n        const globalComparePoints = JSON.parse(JSON.stringify(this.globalComparePoints));\n        for (const p of globalComparePoints) {\n            if (p.id === this.selectedGaugeInPoints?.gaugeId) {\n                p.r = 10;\n            } else {\n                p.r = 2;\n            }\n        }\n        this.globalComparePoints = globalComparePoints;\n\n        for (const compare of this.uiCompares) {\n            const comparePoints = JSON.parse(JSON.stringify(compare.comparePoints));\n            comparePoints.forEach((p) => {\n                if (p.id === this.selectedGaugeInPoints?.gaugeId) {\n                    p.r = 10;\n                } else {\n                    p.r = 3;\n                }\n            });\n            compare.comparePoints = comparePoints;\n        }\n    }\n\n    protected resetSelectedGauges() {\n        // console.log('resetSelectedGauges reset');\n        this.selectedGauge = null;\n        this.selectedGaugeInPoints = null;\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\n        this.selectGaugeInCompare();\n    }\n}\n"]}
@@ -229,7 +229,7 @@ export class RefreshManager {
229
229
  const cumulativeHours = this.cumulative
230
230
  ? (this.period.end.getTime() - this.period.begin.getTime()) / (60 * 60 * 1000)
231
231
  : 0;
232
- await this.compareManager.refreshGlobalCompareQuality(targets, !this.removeDuplicate, cumulativeHours);
232
+ await this.compareManager.refreshGlobalCompareQuality(targets, this.period, !this.removeDuplicate, cumulativeHours);
233
233
  }
234
234
  catch (e) {
235
235
  console.error('refreshGlobalCompareReport', e);
@@ -311,4 +311,4 @@ export class RefreshManager {
311
311
  return values;
312
312
  }
313
313
  }
314
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RefreshManager.js","sourceRoot":"","sources":["../../../src/core/shared/tools/RefreshManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {FrameSet} from './FrameSet';\nimport {from, mergeMap, Subject, takeUntil, timer} from 'rxjs';\nimport {\n    CartesianMeasureValue,\n    CartesianTools,\n    ICartesianMeasureValue,\n    RadarNode,\n    RainComputationMap,\n    RainNode,\n} from 'raain-model';\nimport {CartesianMapValue, TimeframeContainer, TimeframeContainers} from 'raain-ui';\nimport {RadarService} from '../radar.service';\nimport {ProfileService} from '../profile.service';\nimport {CompareManager, ICompareTarget} from './CompareManager';\nimport {XYType} from '../xytype';\n\nconst sleep = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms));\n\nexport class RefreshManager {\n    public rainComputationMapVersion: string;\n    public rainComputationMapDate: Date;\n    public rainComputationMapDoneDate: Date;\n    public rainComputationMapLaunchedBy: string;\n    public rainComputationMapTimeSpentInMs: number;\n\n    public rainComputationMapOriginalMin: number;\n    public rainComputationMapOriginalMax: number;\n\n    public sumFn: (cartesianMapValues: CartesianMapValue[]) => number;\n    public sumValues: CartesianMapValue[];\n\n    public provider: string = 'Raain';\n    public timeStepInMinutes: number = 10;\n    public lastError: string = '';\n    public cumulative: boolean = false;\n\n    protected closeRefreshTimer: Subject<unknown>;\n    protected countsPeriod: {\n        percentImages?: XYType[];\n        queueRunning?: number;\n        progress?: number;\n    };\n    protected timeframesFromRadars: FrameSet[];\n    protected timeframesFromRadarsExtended: FrameSet[];\n    protected timelineSelectedFrameSet: FrameSet;\n    protected timeframeDates: Date[];\n    protected cartesianTools: CartesianTools;\n    protected removeDuplicate: boolean;\n    protected dataInternal: boolean;\n    protected onRefreshInProgress: (\n        countPeriods: {\n            percentImages?: XYType[];\n            queueRunning?: number;\n            progress?: number;\n        },\n        timeframeDates: Date[]\n    ) => Promise<void>;\n    protected onRefreshDone: (timeframeDates: Date[]) => Promise<void>;\n    protected onFetchDone: (timeframeContainers?: TimeframeContainers) => Promise<void>;\n\n    constructor(\n        protected radarService: RadarService,\n        protected profileService: ProfileService,\n        protected compareManager: CompareManager\n    ) {\n        this._period = {begin: new Date(), end: new Date()};\n        this.closeRefreshTimer = new Subject<unknown>();\n        this.cartesianTools = new CartesianTools();\n        this.cleanAll();\n    }\n\n    protected _rainNode: RainNode;\n\n    public get rainNode(): RainNode {\n        return this._rainNode;\n    }\n\n    public set rainNode(rainNode: RainNode) {\n        this._rainNode = rainNode;\n        this.cleanAll();\n    }\n\n    protected _period: {begin: Date; end: Date};\n\n    get period(): {begin: Date; end: Date} {\n        return this._period;\n    }\n\n    set period(period: {begin: Date; end: Date}) {\n        this._period.begin = new Date(period.begin);\n        this._period.end = new Date(period.end);\n        this.refreshCounts().then((ignored) => {});\n    }\n\n    public setMethods(\n        onRefreshInProgress: (\n            countPeriods: {\n                percentImages?: XYType[];\n                queueRunning?: number;\n            },\n            timeframeDates: Date[]\n        ) => Promise<void>,\n        onRefreshDone: (timeframeDates: Date[]) => Promise<void>,\n        onFetchDone: (timeframeContainers?: TimeframeContainers) => Promise<void>\n    ) {\n        this.onRefreshInProgress = onRefreshInProgress;\n        this.onRefreshDone = onRefreshDone;\n        this.onFetchDone = onFetchDone;\n    }\n\n    cleanAll() {\n        this.lastError = '';\n        this.countsPeriod = {percentImages: [], queueRunning: 0, progress: 0};\n        this.timeframesFromRadars = [];\n        this.timeframesFromRadarsExtended = [];\n        this.timeframeDates = [];\n        this.removeDuplicate = true;\n        this.closeRefreshTimer?.next(null);\n    }\n\n    async fetch(\n        dateShown: Date,\n        withGaugesMeasures: boolean,\n        cumulativeHours = 0\n    ): Promise<FrameSet> {\n        // set the target\n        const currents = this.timeframesFromRadarsExtended.filter(\n            (t) => t.date.getTime() === dateShown.getTime()\n        );\n        if (currents.length !== 1) {\n            return;\n        }\n\n        // build current Frameset\n        const current: FrameSet = currents[0];\n        const target = {\n            ...current,\n            withGauge: withGaugesMeasures,\n            cumulativeHours: cumulativeHours,\n        };\n\n        const timeframeContainers = await this.refreshMapTimeframeContainers(target);\n\n        this.onFetchDone(timeframeContainers)\n            .then(() => this.refreshCompareQuality(current))\n            .then((ignored) => {}); // NO Sync\n\n        this.timelineSelectedFrameSet = current;\n    }\n\n    getTimelineFrameSet(): FrameSet[] {\n        return this.timeframesFromRadars;\n    }\n\n    getTimelineSelectedFrameSet(): FrameSet {\n        return this.timelineSelectedFrameSet;\n    }\n\n    async refresh(launchQualityAfter: boolean, dataInternal: boolean) {\n        this.lastError = '';\n\n        this.checkPeriod();\n\n        this.dataInternal = dataInternal;\n\n        const asyncDone = (error?: string) => {\n            if (error) {\n                console.error('Error in refresh', error);\n            }\n            this.closeRefreshTimer.next(null);\n            this.onRefreshDone(this.timeframeDates).then((_ignored) => {});\n        };\n\n        const asyncRefresh = async () => {\n            this.onRefreshInProgress(await this.refreshCounts(), this.timeframeDates).then(\n                (_ignored) => {}\n            );\n            const done = await this.refreshPeriodInsidePolling();\n            if (done) {\n                asyncDone();\n            }\n        };\n\n        timer(1000, 10000) // Wait 1s, then every 10s\n            .pipe(\n                mergeMap(() => from(asyncRefresh())),\n                takeUntil(this.closeRefreshTimer)\n            )\n            .subscribe({\n                error: (error) => asyncDone(JSON.stringify(error)),\n            });\n    }\n\n    setRemoveDuplicate(b: boolean) {\n        this.removeDuplicate = b;\n    }\n\n    public async setReportPeriod(date: Date) {\n        let values: CartesianMapValue[] = [];\n        for (const frameSet of this.timeframesFromRadars) {\n            if (frameSet.date.getTime() !== date.getTime()) {\n                continue;\n            }\n            values = values.concat(await this.getValues(frameSet));\n        }\n\n        this.sumFn = (cartesianMapValues: CartesianMapValue[]) => {\n            return cartesianMapValues.reduce((p, v) => p + v.value, 0);\n        };\n        this.sumValues = values;\n    }\n\n    protected checkPeriod() {\n        if (this.period.begin.getTime() === this.period.end.getTime()) {\n            const message = 'need a period';\n            this.lastError += message;\n            throw new Error(message);\n        }\n    }\n\n    protected async refreshCounts() {\n        if (!this.rainNode) {\n            return this.countsPeriod;\n        }\n\n        const counts = await this.profileService.getCounts(this.rainNode.id, {\n            range: 'day',\n            periodBegin: this._period.begin,\n        });\n\n        let progress = 0;\n\n        // Verify progress only for SimpleZone\n        if (this.rainNode.getLinks(RadarNode.TYPE).length <= 1) {\n            progress = await this.profileService.getRainProgress(this.rainNode.id);\n        }\n\n        this.countsPeriod = {\n            ...counts,\n            progress,\n        };\n\n        return this.countsPeriod;\n    }\n\n    protected getRainComputationQualityTarget(frameset: FrameSet): string {\n        if (frameset.rainComputationQualities.length <= 0) {\n            return undefined;\n        }\n        return frameset.rainComputationQualities[0].id;\n    }\n\n    protected async refreshPeriodInsidePolling(): Promise<boolean> {\n        try {\n            const done = await this.refreshCheckIfDone();\n\n            // behind refresh\n            await this.refreshTimeframesFromRadars(done);\n            await this.refreshGlobalCompareReport(done);\n\n            return done;\n        } catch (e) {\n            console.warn(e);\n            this.lastError += e.message;\n        }\n        return false;\n    }\n\n    protected async refreshCheckIfDone(): Promise<boolean> {\n        await sleep(2000);\n        return this.countsPeriod.progress === 0;\n    }\n\n    protected async refreshTimeframesFromRadars(done: boolean) {\n        if (!done || !this.rainNode) {\n            return [];\n        }\n\n        try {\n            const beginExtended = new Date(this.period.begin);\n            const endExtended = new Date(this.period.end);\n            if (!this.cumulative) {\n                // Only extend period for granular mode (to get neighboring frames)\n                // For cumulative mode, use exact period\n                beginExtended.setMinutes(beginExtended.getMinutes() - 7);\n                endExtended.setMinutes(endExtended.getMinutes() + 7);\n            }\n\n            // Calculate windowInMinutes for cumulative mode\n            const windowInMinutes = this.cumulative\n                ? Math.round(\n                      (this.period.end.getTime() - this.period.begin.getTime()) / (60 * 1000)\n                  )\n                : 0;\n\n            this.rainNode = await this.profileService.getRainTimeframe(\n                this.rainNode.id,\n                beginExtended,\n                endExtended,\n                this.dataInternal,\n                this.provider,\n                this.timeStepInMinutes,\n                windowInMinutes\n            );\n\n            this.timeframesFromRadarsExtended = await this.radarService.getTimeline(this.rainNode);\n            this.timeframesFromRadars = this.timeframesFromRadarsExtended\n                .filter(\n                    (frameSet) =>\n                        this.period.begin.getTime() <= frameSet.date.getTime() &&\n                        frameSet.date.getTime() <= this.period.end.getTime()\n                )\n                .sort((a, b) => a.date.getTime() - b.date.getTime());\n\n            this.timeframeDates = this.timeframesFromRadars.map((frameSet) => frameSet.date);\n\n            // Compute all expected dates\n            // For cumulative mode: only 1 expected date (the period end)\n            // For granular mode: all dates from period.begin to period.end with timeStepInMinutes\n            const allExpectedDates: Date[] = [];\n            if (this.cumulative) {\n                // In cumulative mode, we expect only ONE timeframe (the cumulative)\n                allExpectedDates.push(new Date(this.period.end));\n            } else {\n                const currentDate = new Date(this.period.begin);\n                while (currentDate.getTime() <= this.period.end.getTime()) {\n                    allExpectedDates.push(new Date(currentDate));\n                    currentDate.setMinutes(currentDate.getMinutes() + this.timeStepInMinutes);\n                }\n            }\n\n            // Check if all expected dates are present in timeframeDates\n            const timeframeDateTimes = new Set(this.timeframeDates.map((d) => d.getTime()));\n            const missingDates = allExpectedDates.filter(\n                (expectedDate) => !timeframeDateTimes.has(expectedDate.getTime())\n            );\n\n            if (missingDates.length > 0) {\n                const message =\n                    `Missing ${missingDates.length} timeframe(s) out of ${allExpectedDates.length} expected: ` +\n                    missingDates.map((d) => d.toISOString()).join(', ');\n                console.warn(message);\n                this.lastError += message;\n            }\n\n            return this.timeframesFromRadars;\n        } catch (e) {\n            console.error('refreshTimeframesFromRadars', e);\n        }\n\n        return [];\n    }\n\n    protected async refreshGlobalCompareReport(done: boolean) {\n        if (!done) {\n            return;\n        }\n\n        try {\n            const targets: ICompareTarget[] = [];\n            for (const frameSet of this.timeframesFromRadarsExtended) {\n                const target = JSON.parse(JSON.stringify(frameSet));\n                target.date = new Date(target.date);\n                targets.push(target);\n            }\n\n            const cumulativeHours = this.cumulative\n                ? (this.period.end.getTime() - this.period.begin.getTime()) / (60 * 60 * 1000)\n                : 0;\n            await this.compareManager.refreshGlobalCompareQuality(\n                targets,\n                !this.removeDuplicate,\n                cumulativeHours\n            );\n        } catch (e) {\n            console.error('refreshGlobalCompareReport', e);\n        }\n    }\n\n    protected async refreshMapTimeframeContainers(target: {\n        date: Date;\n        rainComputationCumulativeId: string;\n        withGauge: boolean;\n        cumulativeHours: number;\n    }) {\n        if (!target?.rainComputationCumulativeId) {\n            const message = `Pb with refreshMapTimeframeContainers insights ${target?.date.toISOString()}`;\n            console.warn(message);\n            this.lastError += message;\n            return null;\n        }\n\n        const rainNode = this.rainNode;\n        const containers: TimeframeContainer[] = [];\n        const newCreatedTimeframeContainers = new TimeframeContainers(containers);\n        try {\n            let rainNodeCartesianMap: RainComputationMap;\n\n            if (target.cumulativeHours && target.rainComputationCumulativeId) {\n                // For N-hour cumulative, use the last frame's cumulative (end of period)\n                // The cumulative is pre-computed by raain-ground with windowInMinutes=60\n                const lastFrame =\n                    this.timeframesFromRadarsExtended[this.timeframesFromRadarsExtended.length - 1];\n                const cumulativeId =\n                    lastFrame?.rainComputationCumulativeId || target.rainComputationCumulativeId;\n\n                // Use direct cartesian-map endpoint - cumulative data fetched from S3\n                rainNodeCartesianMap =\n                    await this.profileService.getRainComputationCumulativeCartesianMapById(\n                        rainNode.id,\n                        cumulativeId\n                    );\n            } else {\n                rainNodeCartesianMap =\n                    await this.profileService.getRainComputationCumulativeCartesianMapById(\n                        rainNode.id,\n                        target.rainComputationCumulativeId\n                    );\n            }\n\n            if (rainNodeCartesianMap) {\n                newCreatedTimeframeContainers.addFromRainComputationMap(\n                    rainNodeCartesianMap,\n                    false\n                );\n\n                this.rainComputationMapVersion = rainNodeCartesianMap.version;\n                this.rainComputationMapDate = new Date(rainNodeCartesianMap.date);\n                this.rainComputationMapDoneDate = rainNodeCartesianMap.isDoneDate;\n                this.rainComputationMapLaunchedBy = rainNodeCartesianMap.launchedBy;\n                this.rainComputationMapTimeSpentInMs = rainNodeCartesianMap.timeSpentInMs;\n\n                this.rainComputationMapOriginalMin = rainNodeCartesianMap.originalDBZMin;\n                this.rainComputationMapOriginalMax = rainNodeCartesianMap.originalDBZMax;\n            }\n        } catch (e) {\n            const message = `Pb with cumulatives for id: ${target.rainComputationCumulativeId} ${e.message}`;\n            console.warn(message);\n            this.lastError += message;\n        }\n\n        return newCreatedTimeframeContainers;\n    }\n\n    protected async refreshCompareQuality(frameSet: FrameSet) {\n        await this.compareManager.refreshCompareQuality(frameSet, true);\n        await this.compareManager.setGaugesInCompare();\n    }\n\n    protected async getValues(target: FrameSet): Promise<CartesianMapValue[]> {\n        if (!target?.rainComputationCumulativeId) {\n            const message = `Pb with target insights ${target?.date.toISOString()}`;\n            console.warn(message);\n            this.lastError += message;\n            return [];\n        }\n\n        let values: CartesianMapValue[] = [];\n        const rainComputationMap =\n            await this.profileService.getRainComputationCumulativeCartesianMapById(\n                this.rainNode.id,\n                target.rainComputationCumulativeId\n            );\n\n        try {\n            if (rainComputationMap) {\n                rainComputationMap.getMapData().forEach((m) => {\n                    if (m.values) {\n                        (m.values as ICartesianMeasureValue[]).forEach((v) => {\n                            const cartesianMeasureValue = CartesianMeasureValue.From(v);\n                            values = values.concat(\n                                CartesianMapValue.From(\n                                    cartesianMeasureValue.getCartesianValues(),\n                                    this.cartesianTools\n                                )\n                            );\n                        });\n                    }\n                });\n            }\n        } catch (e) {\n            const message = `Pb with cumulatives for id: ${target.rainComputationCumulativeId} ${e.message}`;\n            console.warn(message);\n            this.lastError += message;\n        }\n\n        return values;\n    }\n}\n"]}
314
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RefreshManager.js","sourceRoot":"","sources":["../../../src/core/shared/tools/RefreshManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {FrameSet} from './FrameSet';\nimport {from, mergeMap, Subject, takeUntil, timer} from 'rxjs';\nimport {\n    CartesianMeasureValue,\n    CartesianTools,\n    ICartesianMeasureValue,\n    RadarNode,\n    RainComputationMap,\n    RainNode,\n} from 'raain-model';\nimport {CartesianMapValue, TimeframeContainer, TimeframeContainers} from 'raain-ui';\nimport {RadarService} from '../radar.service';\nimport {ProfileService} from '../profile.service';\nimport {CompareManager, ICompareTarget} from './CompareManager';\nimport {XYType} from '../xytype';\n\nconst sleep = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms));\n\nexport class RefreshManager {\n    public rainComputationMapVersion: string;\n    public rainComputationMapDate: Date;\n    public rainComputationMapDoneDate: Date;\n    public rainComputationMapLaunchedBy: string;\n    public rainComputationMapTimeSpentInMs: number;\n\n    public rainComputationMapOriginalMin: number;\n    public rainComputationMapOriginalMax: number;\n\n    public sumFn: (cartesianMapValues: CartesianMapValue[]) => number;\n    public sumValues: CartesianMapValue[];\n\n    public provider: string = 'Raain';\n    public timeStepInMinutes: number = 10;\n    public lastError: string = '';\n    public cumulative: boolean = false;\n\n    protected closeRefreshTimer: Subject<unknown>;\n    protected countsPeriod: {\n        percentImages?: XYType[];\n        queueRunning?: number;\n        progress?: number;\n    };\n    protected timeframesFromRadars: FrameSet[];\n    protected timeframesFromRadarsExtended: FrameSet[];\n    protected timelineSelectedFrameSet: FrameSet;\n    protected timeframeDates: Date[];\n    protected cartesianTools: CartesianTools;\n    protected removeDuplicate: boolean;\n    protected dataInternal: boolean;\n    protected onRefreshInProgress: (\n        countPeriods: {\n            percentImages?: XYType[];\n            queueRunning?: number;\n            progress?: number;\n        },\n        timeframeDates: Date[]\n    ) => Promise<void>;\n    protected onRefreshDone: (timeframeDates: Date[]) => Promise<void>;\n    protected onFetchDone: (timeframeContainers?: TimeframeContainers) => Promise<void>;\n\n    constructor(\n        protected radarService: RadarService,\n        protected profileService: ProfileService,\n        protected compareManager: CompareManager\n    ) {\n        this._period = {begin: new Date(), end: new Date()};\n        this.closeRefreshTimer = new Subject<unknown>();\n        this.cartesianTools = new CartesianTools();\n        this.cleanAll();\n    }\n\n    protected _rainNode: RainNode;\n\n    public get rainNode(): RainNode {\n        return this._rainNode;\n    }\n\n    public set rainNode(rainNode: RainNode) {\n        this._rainNode = rainNode;\n        this.cleanAll();\n    }\n\n    protected _period: {begin: Date; end: Date};\n\n    get period(): {begin: Date; end: Date} {\n        return this._period;\n    }\n\n    set period(period: {begin: Date; end: Date}) {\n        this._period.begin = new Date(period.begin);\n        this._period.end = new Date(period.end);\n        this.refreshCounts().then((ignored) => {});\n    }\n\n    public setMethods(\n        onRefreshInProgress: (\n            countPeriods: {\n                percentImages?: XYType[];\n                queueRunning?: number;\n            },\n            timeframeDates: Date[]\n        ) => Promise<void>,\n        onRefreshDone: (timeframeDates: Date[]) => Promise<void>,\n        onFetchDone: (timeframeContainers?: TimeframeContainers) => Promise<void>\n    ) {\n        this.onRefreshInProgress = onRefreshInProgress;\n        this.onRefreshDone = onRefreshDone;\n        this.onFetchDone = onFetchDone;\n    }\n\n    cleanAll() {\n        this.lastError = '';\n        this.countsPeriod = {percentImages: [], queueRunning: 0, progress: 0};\n        this.timeframesFromRadars = [];\n        this.timeframesFromRadarsExtended = [];\n        this.timeframeDates = [];\n        this.removeDuplicate = true;\n        this.closeRefreshTimer?.next(null);\n    }\n\n    async fetch(\n        dateShown: Date,\n        withGaugesMeasures: boolean,\n        cumulativeHours = 0\n    ): Promise<FrameSet> {\n        // set the target\n        const currents = this.timeframesFromRadarsExtended.filter(\n            (t) => t.date.getTime() === dateShown.getTime()\n        );\n        if (currents.length !== 1) {\n            return;\n        }\n\n        // build current Frameset\n        const current: FrameSet = currents[0];\n        const target = {\n            ...current,\n            withGauge: withGaugesMeasures,\n            cumulativeHours: cumulativeHours,\n        };\n\n        const timeframeContainers = await this.refreshMapTimeframeContainers(target);\n\n        this.onFetchDone(timeframeContainers)\n            .then(() => this.refreshCompareQuality(current))\n            .then((ignored) => {}); // NO Sync\n\n        this.timelineSelectedFrameSet = current;\n    }\n\n    getTimelineFrameSet(): FrameSet[] {\n        return this.timeframesFromRadars;\n    }\n\n    getTimelineSelectedFrameSet(): FrameSet {\n        return this.timelineSelectedFrameSet;\n    }\n\n    async refresh(launchQualityAfter: boolean, dataInternal: boolean) {\n        this.lastError = '';\n\n        this.checkPeriod();\n\n        this.dataInternal = dataInternal;\n\n        const asyncDone = (error?: string) => {\n            if (error) {\n                console.error('Error in refresh', error);\n            }\n            this.closeRefreshTimer.next(null);\n            this.onRefreshDone(this.timeframeDates).then((_ignored) => {});\n        };\n\n        const asyncRefresh = async () => {\n            this.onRefreshInProgress(await this.refreshCounts(), this.timeframeDates).then(\n                (_ignored) => {}\n            );\n            const done = await this.refreshPeriodInsidePolling();\n            if (done) {\n                asyncDone();\n            }\n        };\n\n        timer(1000, 10000) // Wait 1s, then every 10s\n            .pipe(\n                mergeMap(() => from(asyncRefresh())),\n                takeUntil(this.closeRefreshTimer)\n            )\n            .subscribe({\n                error: (error) => asyncDone(JSON.stringify(error)),\n            });\n    }\n\n    setRemoveDuplicate(b: boolean) {\n        this.removeDuplicate = b;\n    }\n\n    public async setReportPeriod(date: Date) {\n        let values: CartesianMapValue[] = [];\n        for (const frameSet of this.timeframesFromRadars) {\n            if (frameSet.date.getTime() !== date.getTime()) {\n                continue;\n            }\n            values = values.concat(await this.getValues(frameSet));\n        }\n\n        this.sumFn = (cartesianMapValues: CartesianMapValue[]) => {\n            return cartesianMapValues.reduce((p, v) => p + v.value, 0);\n        };\n        this.sumValues = values;\n    }\n\n    protected checkPeriod() {\n        if (this.period.begin.getTime() === this.period.end.getTime()) {\n            const message = 'need a period';\n            this.lastError += message;\n            throw new Error(message);\n        }\n    }\n\n    protected async refreshCounts() {\n        if (!this.rainNode) {\n            return this.countsPeriod;\n        }\n\n        const counts = await this.profileService.getCounts(this.rainNode.id, {\n            range: 'day',\n            periodBegin: this._period.begin,\n        });\n\n        let progress = 0;\n\n        // Verify progress only for SimpleZone\n        if (this.rainNode.getLinks(RadarNode.TYPE).length <= 1) {\n            progress = await this.profileService.getRainProgress(this.rainNode.id);\n        }\n\n        this.countsPeriod = {\n            ...counts,\n            progress,\n        };\n\n        return this.countsPeriod;\n    }\n\n    protected getRainComputationQualityTarget(frameset: FrameSet): string {\n        if (frameset.rainComputationQualities.length <= 0) {\n            return undefined;\n        }\n        return frameset.rainComputationQualities[0].id;\n    }\n\n    protected async refreshPeriodInsidePolling(): Promise<boolean> {\n        try {\n            const done = await this.refreshCheckIfDone();\n\n            // behind refresh\n            await this.refreshTimeframesFromRadars(done);\n            await this.refreshGlobalCompareReport(done);\n\n            return done;\n        } catch (e) {\n            console.warn(e);\n            this.lastError += e.message;\n        }\n        return false;\n    }\n\n    protected async refreshCheckIfDone(): Promise<boolean> {\n        await sleep(2000);\n        return this.countsPeriod.progress === 0;\n    }\n\n    protected async refreshTimeframesFromRadars(done: boolean) {\n        if (!done || !this.rainNode) {\n            return [];\n        }\n\n        try {\n            const beginExtended = new Date(this.period.begin);\n            const endExtended = new Date(this.period.end);\n            if (!this.cumulative) {\n                // Only extend period for granular mode (to get neighboring frames)\n                // For cumulative mode, use exact period\n                beginExtended.setMinutes(beginExtended.getMinutes() - 7);\n                endExtended.setMinutes(endExtended.getMinutes() + 7);\n            }\n\n            // Calculate windowInMinutes for cumulative mode\n            const windowInMinutes = this.cumulative\n                ? Math.round(\n                      (this.period.end.getTime() - this.period.begin.getTime()) / (60 * 1000)\n                  )\n                : 0;\n\n            this.rainNode = await this.profileService.getRainTimeframe(\n                this.rainNode.id,\n                beginExtended,\n                endExtended,\n                this.dataInternal,\n                this.provider,\n                this.timeStepInMinutes,\n                windowInMinutes\n            );\n\n            this.timeframesFromRadarsExtended = await this.radarService.getTimeline(this.rainNode);\n            this.timeframesFromRadars = this.timeframesFromRadarsExtended\n                .filter(\n                    (frameSet) =>\n                        this.period.begin.getTime() <= frameSet.date.getTime() &&\n                        frameSet.date.getTime() <= this.period.end.getTime()\n                )\n                .sort((a, b) => a.date.getTime() - b.date.getTime());\n\n            this.timeframeDates = this.timeframesFromRadars.map((frameSet) => frameSet.date);\n\n            // Compute all expected dates\n            // For cumulative mode: only 1 expected date (the period end)\n            // For granular mode: all dates from period.begin to period.end with timeStepInMinutes\n            const allExpectedDates: Date[] = [];\n            if (this.cumulative) {\n                // In cumulative mode, we expect only ONE timeframe (the cumulative)\n                allExpectedDates.push(new Date(this.period.end));\n            } else {\n                const currentDate = new Date(this.period.begin);\n                while (currentDate.getTime() <= this.period.end.getTime()) {\n                    allExpectedDates.push(new Date(currentDate));\n                    currentDate.setMinutes(currentDate.getMinutes() + this.timeStepInMinutes);\n                }\n            }\n\n            // Check if all expected dates are present in timeframeDates\n            const timeframeDateTimes = new Set(this.timeframeDates.map((d) => d.getTime()));\n            const missingDates = allExpectedDates.filter(\n                (expectedDate) => !timeframeDateTimes.has(expectedDate.getTime())\n            );\n\n            if (missingDates.length > 0) {\n                const message =\n                    `Missing ${missingDates.length} timeframe(s) out of ${allExpectedDates.length} expected: ` +\n                    missingDates.map((d) => d.toISOString()).join(', ');\n                console.warn(message);\n                this.lastError += message;\n            }\n\n            return this.timeframesFromRadars;\n        } catch (e) {\n            console.error('refreshTimeframesFromRadars', e);\n        }\n\n        return [];\n    }\n\n    protected async refreshGlobalCompareReport(done: boolean) {\n        if (!done) {\n            return;\n        }\n\n        try {\n            const targets: ICompareTarget[] = [];\n            for (const frameSet of this.timeframesFromRadarsExtended) {\n                const target = JSON.parse(JSON.stringify(frameSet));\n                target.date = new Date(target.date);\n                targets.push(target);\n            }\n\n            const cumulativeHours = this.cumulative\n                ? (this.period.end.getTime() - this.period.begin.getTime()) / (60 * 60 * 1000)\n                : 0;\n            await this.compareManager.refreshGlobalCompareQuality(\n                targets,\n                this.period,\n                !this.removeDuplicate,\n                cumulativeHours\n            );\n        } catch (e) {\n            console.error('refreshGlobalCompareReport', e);\n        }\n    }\n\n    protected async refreshMapTimeframeContainers(target: {\n        date: Date;\n        rainComputationCumulativeId: string;\n        withGauge: boolean;\n        cumulativeHours: number;\n    }) {\n        if (!target?.rainComputationCumulativeId) {\n            const message = `Pb with refreshMapTimeframeContainers insights ${target?.date.toISOString()}`;\n            console.warn(message);\n            this.lastError += message;\n            return null;\n        }\n\n        const rainNode = this.rainNode;\n        const containers: TimeframeContainer[] = [];\n        const newCreatedTimeframeContainers = new TimeframeContainers(containers);\n        try {\n            let rainNodeCartesianMap: RainComputationMap;\n\n            if (target.cumulativeHours && target.rainComputationCumulativeId) {\n                // For N-hour cumulative, use the last frame's cumulative (end of period)\n                // The cumulative is pre-computed by raain-ground with windowInMinutes=60\n                const lastFrame =\n                    this.timeframesFromRadarsExtended[this.timeframesFromRadarsExtended.length - 1];\n                const cumulativeId =\n                    lastFrame?.rainComputationCumulativeId || target.rainComputationCumulativeId;\n\n                // Use direct cartesian-map endpoint - cumulative data fetched from S3\n                rainNodeCartesianMap =\n                    await this.profileService.getRainComputationCumulativeCartesianMapById(\n                        rainNode.id,\n                        cumulativeId\n                    );\n            } else {\n                rainNodeCartesianMap =\n                    await this.profileService.getRainComputationCumulativeCartesianMapById(\n                        rainNode.id,\n                        target.rainComputationCumulativeId\n                    );\n            }\n\n            if (rainNodeCartesianMap) {\n                newCreatedTimeframeContainers.addFromRainComputationMap(\n                    rainNodeCartesianMap,\n                    false\n                );\n\n                this.rainComputationMapVersion = rainNodeCartesianMap.version;\n                this.rainComputationMapDate = new Date(rainNodeCartesianMap.date);\n                this.rainComputationMapDoneDate = rainNodeCartesianMap.isDoneDate;\n                this.rainComputationMapLaunchedBy = rainNodeCartesianMap.launchedBy;\n                this.rainComputationMapTimeSpentInMs = rainNodeCartesianMap.timeSpentInMs;\n\n                this.rainComputationMapOriginalMin = rainNodeCartesianMap.originalDBZMin;\n                this.rainComputationMapOriginalMax = rainNodeCartesianMap.originalDBZMax;\n            }\n        } catch (e) {\n            const message = `Pb with cumulatives for id: ${target.rainComputationCumulativeId} ${e.message}`;\n            console.warn(message);\n            this.lastError += message;\n        }\n\n        return newCreatedTimeframeContainers;\n    }\n\n    protected async refreshCompareQuality(frameSet: FrameSet) {\n        await this.compareManager.refreshCompareQuality(frameSet, true);\n        await this.compareManager.setGaugesInCompare();\n    }\n\n    protected async getValues(target: FrameSet): Promise<CartesianMapValue[]> {\n        if (!target?.rainComputationCumulativeId) {\n            const message = `Pb with target insights ${target?.date.toISOString()}`;\n            console.warn(message);\n            this.lastError += message;\n            return [];\n        }\n\n        let values: CartesianMapValue[] = [];\n        const rainComputationMap =\n            await this.profileService.getRainComputationCumulativeCartesianMapById(\n                this.rainNode.id,\n                target.rainComputationCumulativeId\n            );\n\n        try {\n            if (rainComputationMap) {\n                rainComputationMap.getMapData().forEach((m) => {\n                    if (m.values) {\n                        (m.values as ICartesianMeasureValue[]).forEach((v) => {\n                            const cartesianMeasureValue = CartesianMeasureValue.From(v);\n                            values = values.concat(\n                                CartesianMapValue.From(\n                                    cartesianMeasureValue.getCartesianValues(),\n                                    this.cartesianTools\n                                )\n                            );\n                        });\n                    }\n                });\n            }\n        } catch (e) {\n            const message = `Pb with cumulatives for id: ${target.rainComputationCumulativeId} ${e.message}`;\n            console.warn(message);\n            this.lastError += message;\n        }\n\n        return values;\n    }\n}\n"]}