raain-app 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +12 -0
  3. package/RELEASE.md +3 -0
  4. package/cache.service.d.ts +9 -0
  5. package/esm2020/cache.service.mjs +33 -0
  6. package/esm2020/fidj-storage.model.mjs +162 -0
  7. package/esm2020/index.mjs +18 -0
  8. package/esm2020/profile.service.mjs +881 -0
  9. package/esm2020/raain-app.mjs +5 -0
  10. package/esm2020/raain-compare/raain-compare.component.mjs +106 -0
  11. package/esm2020/raain-compare-stack/raain-compare-stack.component.mjs +27 -0
  12. package/esm2020/raain-configuration/raain-configuration.component.mjs +97 -0
  13. package/esm2020/raain-date-focus/raain-date-focus.component.mjs +94 -0
  14. package/esm2020/raain-map/raain-map.component.mjs +295 -0
  15. package/esm2020/raain-speed/raain-speed.component.mjs +83 -0
  16. package/esm2020/raain-test/raain-test.component.mjs +17 -0
  17. package/esm2020/radar.service.mjs +91 -0
  18. package/esm2020/shared.const.mjs +25 -0
  19. package/esm2020/shared.module.mjs +142 -0
  20. package/esm2020/shared.pipe.mjs +203 -0
  21. package/esm2020/storage.service.mjs +17 -0
  22. package/esm2020/tools/CompareManager.mjs +248 -0
  23. package/esm2020/tools/FrameSet.mjs +10 -0
  24. package/esm2020/tools/GaugeNodeFilter.mjs +19 -0
  25. package/esm2020/tools/RefreshManager.mjs +202 -0
  26. package/esm2020/tools/index.mjs +5 -0
  27. package/esm2020/xytype.mjs +10 -0
  28. package/fesm2015/raain-app.mjs +2871 -0
  29. package/fesm2015/raain-app.mjs.map +1 -0
  30. package/fesm2020/raain-app.mjs +2707 -0
  31. package/fesm2020/raain-app.mjs.map +1 -0
  32. package/fidj-storage.model.d.ts +23 -0
  33. package/index.d.ts +17 -0
  34. package/package.json +58 -0
  35. package/profile.service.d.ts +114 -0
  36. package/raain-compare/raain-compare.component.d.ts +33 -0
  37. package/raain-compare-stack/raain-compare-stack.component.d.ts +20 -0
  38. package/raain-configuration/raain-configuration.component.d.ts +29 -0
  39. package/raain-date-focus/raain-date-focus.component.d.ts +36 -0
  40. package/raain-map/raain-map.component.d.ts +58 -0
  41. package/raain-speed/raain-speed.component.d.ts +25 -0
  42. package/raain-test/raain-test.component.d.ts +6 -0
  43. package/radar.service.d.ts +19 -0
  44. package/shared.const.d.ts +23 -0
  45. package/shared.module.d.ts +17 -0
  46. package/shared.pipe.d.ts +69 -0
  47. package/storage.service.d.ts +7 -0
  48. package/tools/CompareManager.d.ts +49 -0
  49. package/tools/FrameSet.d.ts +14 -0
  50. package/tools/GaugeNodeFilter.d.ts +9 -0
  51. package/tools/RefreshManager.d.ts +49 -0
  52. package/tools/index.d.ts +4 -0
  53. package/xytype.d.ts +8 -0
@@ -0,0 +1,248 @@
1
+ import { MapLatLng } from 'raain-ui';
2
+ import { XYType } from '../xytype';
3
+ export class CompareManager {
4
+ constructor(rainNode, profileService, onChanges = () => {
5
+ }) {
6
+ this.rainNode = rainNode;
7
+ this.profileService = profileService;
8
+ this.onChanges = onChanges;
9
+ this.cleanAll();
10
+ }
11
+ static CompareDate(date1, date2, minutes) {
12
+ const date1AsDate = new Date(parseInt(date1, 10));
13
+ const date2Diff = new Date(parseInt(date2, 10));
14
+ date2Diff.setMinutes(date2Diff.getMinutes() + minutes);
15
+ const diff = Math.round((date1AsDate.getTime() - date2Diff.getTime()) / (60 * 1000));
16
+ return diff === 0;
17
+ }
18
+ cleanAll() {
19
+ this.gaugesInCompare = [];
20
+ this.selectedGauges = [];
21
+ this.selectedPixels = [];
22
+ this.pixelsSolutions = [];
23
+ this.selectedGauge = null;
24
+ this.selectedGaugeInPoints = null;
25
+ this.cleanCompareQuality('no compare');
26
+ }
27
+ async refreshCompareQuality(frameSet, targets, withCompareDuplicate) {
28
+ const targetsOrdered = targets
29
+ .sort((a, b) => a.date.getTime() - b.date.getTime())
30
+ .map(t => {
31
+ return { date: '' + t.date.getTime(), rainComputationId: t.rainComputationId, rainComputationQualityId: t.rainComputationQualityId };
32
+ });
33
+ const currentTarget = targetsOrdered.filter(t => t.date === '' + frameSet.date.getTime())[0];
34
+ const currentPos = targetsOrdered.indexOf(currentTarget);
35
+ const previousTarget = currentPos >= 0 ? targetsOrdered[currentPos - 1] : null;
36
+ const nextTarget = currentPos >= 0 && currentPos < targetsOrdered.length - 1 ? targetsOrdered[currentPos + 1] : null;
37
+ await this.fetchRainComputationQualities(targetsOrdered);
38
+ const currentQuality = this.rainComputationQualities[currentTarget?.date];
39
+ if (!currentQuality) {
40
+ this.cleanCompareQuality('no current quality ' + Object.keys(this.rainComputationQualities));
41
+ return;
42
+ }
43
+ this.currentQualityDoneDate = currentQuality.isDoneDate;
44
+ this.currentQualityTimeSpentInMs = currentQuality.timeSpentInMs;
45
+ this.currentQualityLaunchedBy = currentQuality.launchedBy;
46
+ this.currentQualityVersion = currentQuality.version;
47
+ const previousQuality = previousTarget &&
48
+ CompareManager.CompareDate(previousTarget.date, currentTarget.date, -5) ?
49
+ this.rainComputationQualities[previousTarget.date] : null;
50
+ const nextQuality = nextTarget
51
+ && CompareManager.CompareDate(nextTarget.date, currentTarget.date, +5) ?
52
+ this.rainComputationQualities[nextTarget.date] : null;
53
+ const qualitySpeedMatrixContainer = currentQuality.qualitySpeedMatrixContainer;
54
+ this.compareNames = qualitySpeedMatrixContainer.getMatrices()
55
+ .map(m => m.name)
56
+ .sort((a, b) => parseInt(a, 10) - parseInt(b, 10));
57
+ this.compareVersion = currentQuality.getVersion();
58
+ this.compareSpeedMatrix = qualitySpeedMatrixContainer.renderMergedMatrix({ normalize: true });
59
+ this.compareTrustedIndicator = qualitySpeedMatrixContainer.getTrustedIndicators()[0];
60
+ this.compares = this.buildCompares(currentQuality, previousQuality, nextQuality, withCompareDuplicate);
61
+ this.onChanges();
62
+ }
63
+ async setGauges() {
64
+ // console.log('setGauges');
65
+ const qualityPoints = [];
66
+ for (const compare of this.compares) {
67
+ for (const qualityPoint of compare.comparePointsHistory) {
68
+ const alreadyAdded = qualityPoints.filter(p => p?.gaugeId === qualityPoint.gaugeId);
69
+ if (alreadyAdded.length === 0) {
70
+ qualityPoints.push(qualityPoint);
71
+ }
72
+ }
73
+ }
74
+ this.gaugesInCompare = qualityPoints.map(p => {
75
+ return new MapLatLng(p.gaugeCartesianValue.lat, p.gaugeCartesianValue.lng, 0, p.gaugeId, p.gaugeLabel + '>' + p.getGaugeValue(), p.getGaugeValue());
76
+ });
77
+ this.resetSelectedGauges();
78
+ }
79
+ async selectGauge(gaugeId, compareIndex) {
80
+ // console.log('selectGauge', gaugeId, compareIndex);
81
+ if (gaugeId) {
82
+ const xys = this.getCurrentQualityPoints(compareIndex).filter(p => p.gaugeId === gaugeId);
83
+ this.selectedGauge = xys.length === 1 ? xys[0] : null;
84
+ }
85
+ else {
86
+ this.selectedGauge = null;
87
+ }
88
+ if (!this.selectedGauge) {
89
+ return this.resetSelectedGauges();
90
+ }
91
+ const selectedGaugeInPoints = this.getCurrentQualityPoints(compareIndex).filter(p => p.gaugeId === this.selectedGauge.gaugeId);
92
+ let pixelsSolutions = [];
93
+ if (selectedGaugeInPoints.length === 1) {
94
+ const remarks = JSON.parse(selectedGaugeInPoints[0].remark)
95
+ .sort((a, b) => a.criteriaAttemptedToBeMinimum - b.criteriaAttemptedToBeMinimum);
96
+ console.log(remarks);
97
+ pixelsSolutions = remarks
98
+ .map(remark => remark.solutionForGauge.pixels
99
+ .map(p => new MapLatLng(p.y + 0.005, p.x + 0.01, 0, '' + !remark.notPossible, '' + !remark.notPossible, 1)));
100
+ const timeDeltaInMinutes = selectedGaugeInPoints[0].getTimeDeltaInMinutes();
101
+ this.selectedGaugeInPointsDetail = '' + selectedGaugeInPoints[0].gaugeLabel + ' > '
102
+ + Math.round(selectedGaugeInPoints[0].getGaugeValue() * 100) / 100 + ' / '
103
+ + Math.round(selectedGaugeInPoints[0].getRainValue() * 100) / 100
104
+ + ' dT=' + timeDeltaInMinutes;
105
+ this.selectedGaugeInPoints = selectedGaugeInPoints[0];
106
+ }
107
+ else {
108
+ this.selectedGaugeInPoints = null;
109
+ this.selectedGauges = [];
110
+ this.selectedPixels = [];
111
+ this.pixelsSolutions = [];
112
+ return;
113
+ }
114
+ this.selectedGauges = [
115
+ new MapLatLng(this.selectedGaugeInPoints.gaugeCartesianValue.lat, this.selectedGaugeInPoints.gaugeCartesianValue.lng, undefined, this.selectedGaugeInPoints.gaugeId, this.selectedGaugeInPoints.gaugeLabel + '>' + this.selectedGaugeInPoints.gaugeCartesianValue.value, this.selectedGaugeInPoints.gaugeCartesianValue.value),
116
+ ];
117
+ this.selectGaugeInCompare();
118
+ const pixels = [];
119
+ for (const rainCartesianValue of this.selectedGaugeInPoints.rainCartesianValues) {
120
+ pixels.push(new MapLatLng(rainCartesianValue.lat + 0.005, rainCartesianValue.lng + 0.01));
121
+ }
122
+ this.selectedPixels = pixels;
123
+ this.pixelsSolutions = pixelsSolutions;
124
+ }
125
+ getCurrentQualityPoints(compareIndex) {
126
+ if (compareIndex < 0 || this.compareNames.length < compareIndex) {
127
+ return [];
128
+ }
129
+ return this.compares[compareIndex].comparePointsHistory;
130
+ }
131
+ cleanCompareQuality(details) {
132
+ this.compareVersion = details;
133
+ this.compareNames = [];
134
+ this.compares = [];
135
+ this.rainComputationQualities = {};
136
+ }
137
+ async fetchRainComputationQualities(targetsOrdered) {
138
+ for (const key of Object.keys(this.rainComputationQualities)) {
139
+ const found = targetsOrdered.filter(t => t.date === key);
140
+ if (found.length < 0) {
141
+ delete this.rainComputationQualities[key];
142
+ }
143
+ }
144
+ for (const target of targetsOrdered) {
145
+ if (!this.rainComputationQualities[target.date] && target.rainComputationQualityId) {
146
+ try {
147
+ this.rainComputationQualities[target.date] = await this.profileService
148
+ .getRainCompareById(this.rainNode.getId(), target.rainComputationId, target.rainComputationQualityId);
149
+ }
150
+ catch (e) {
151
+ console.log(e);
152
+ }
153
+ }
154
+ }
155
+ }
156
+ buildCompares(currentQuality, previousQuality, nextQuality, withCompareDuplicate) {
157
+ const compares = [];
158
+ const qualitySpeedMatrixContainer = currentQuality.qualitySpeedMatrixContainer;
159
+ for (const [index, name] of this.compareNames.entries()) {
160
+ const comparePointsHistory = qualitySpeedMatrixContainer.getQualityPoints(name);
161
+ const maxValue = Math.max(qualitySpeedMatrixContainer.getMaxGauge(), qualitySpeedMatrixContainer.getMaxRain());
162
+ const remarks = qualitySpeedMatrixContainer.getMatrix(index)?.remarks;
163
+ const delta = parseInt(name, 10);
164
+ let renamed = new Date(currentQuality.date.getTime() - delta * 60 * 1000).toLocaleString();
165
+ renamed += delta > 0 ? ' since ' : ' in ';
166
+ renamed += Math.abs(delta) + ' minutes';
167
+ console.log('index:', index, 'delta:', delta, 'renamed:', renamed);
168
+ // remove previous or next better values from comparePoints
169
+ let qualityPoints = comparePointsHistory.filter((p) => p); // no real filter
170
+ const removeDuplicates = !withCompareDuplicate;
171
+ if (removeDuplicates) {
172
+ if (index === this.compareNames.length - 1) {
173
+ if (!previousQuality?.qualitySpeedMatrixContainer) {
174
+ qualityPoints = [];
175
+ }
176
+ else {
177
+ qualityPoints = qualityPoints.filter((p) => {
178
+ const previousQPs = previousQuality.qualitySpeedMatrixContainer
179
+ .getQualityPointsByHistoricalPosition(0)
180
+ .filter(previousQP => p.gaugeId === previousQP.gaugeId);
181
+ // better before ?
182
+ const betterBefore = (previousQPs.length === 1 && p.getDelta() > previousQPs[0].getDelta());
183
+ if (betterBefore) {
184
+ console.log('removed from', renamed, p.gaugeLabel, previousQuality.date.toISOString(), p.getDelta(), previousQPs.length === 1 ? previousQPs[0].getDelta() + ' dated ' + previousQPs[0].gaugeDate.toISOString() : 0);
185
+ return false; // => remove it
186
+ }
187
+ return true;
188
+ });
189
+ }
190
+ }
191
+ else if (index === 0) {
192
+ if (!nextQuality?.qualitySpeedMatrixContainer) {
193
+ qualityPoints = [];
194
+ }
195
+ else {
196
+ qualityPoints = qualityPoints.filter((p) => {
197
+ const nextQPs = nextQuality.qualitySpeedMatrixContainer
198
+ .getQualityPointsByHistoricalPosition(1)
199
+ .filter(nextQP => p.gaugeId === nextQP.gaugeId);
200
+ // better after ?
201
+ const betterAfter = (nextQPs.length === 1 && p.getDelta() > nextQPs[0].getDelta());
202
+ if (betterAfter) {
203
+ console.log('removed from', renamed, p.gaugeLabel, nextQuality.date.toISOString(), p.getDelta(), nextQPs.length === 1 ? nextQPs[0].getDelta() + ' dated ' + nextQPs[0].gaugeDate.toISOString() : 0);
204
+ return false; // => remove it
205
+ }
206
+ return true;
207
+ });
208
+ }
209
+ }
210
+ }
211
+ const comparePoints = qualityPoints.map((qualityPoint) => new XYType(qualityPoint.getGaugeValue(), qualityPoint.getRainValue(), 2, qualityPoint.gaugeLabel, qualityPoint.gaugeId));
212
+ const compare = {
213
+ name: renamed,
214
+ comparePointsHistory,
215
+ comparePoints,
216
+ maxValue,
217
+ comparePointsMax: new XYType(maxValue + 20, maxValue + 20),
218
+ remarks,
219
+ };
220
+ compares.push(compare);
221
+ }
222
+ return compares;
223
+ }
224
+ selectGaugeInCompare() {
225
+ for (const compare of this.compares) {
226
+ const comparePoints = JSON.parse(JSON.stringify(compare.comparePoints));
227
+ comparePoints.forEach(p => {
228
+ if (p.id === this.selectedGaugeInPoints?.gaugeId) {
229
+ p.r = 10;
230
+ }
231
+ else {
232
+ p.r = 3;
233
+ }
234
+ });
235
+ compare.comparePoints = comparePoints;
236
+ }
237
+ }
238
+ resetSelectedGauges() {
239
+ // console.log('resetSelectedGauges reset');
240
+ this.selectedGauge = null;
241
+ this.selectedGaugeInPoints = null;
242
+ this.selectedGauges = [];
243
+ this.selectedPixels = [];
244
+ this.pixelsSolutions = [];
245
+ this.selectGaugeInCompare();
246
+ }
247
+ }
248
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompareManager.js","sourceRoot":"","sources":["../../../src/app/shared/tools/CompareManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {MapLatLng} from 'raain-ui';\nimport {PositionValue, QualityPoint, RainComputationQuality, RainNode} from 'raain-model';\nimport {XYType} from '../xytype';\nimport {ProfileService} from '../profile.service';\nimport {FrameSet} from './FrameSet';\n\nexport class CompareManager {\n\n  // public computed$: Observable<boolean>;\n\n  public gaugesInCompare: MapLatLng[];\n  public selectedGauges: MapLatLng[];\n  public selectedPixels: MapLatLng[];\n  public pixelsSolutions: MapLatLng[][];\n\n  public compareNames: string[];\n  public compares: {\n    name: string;\n    comparePoints: XYType[];\n    comparePointsMax: XYType;\n    comparePointsHistory: QualityPoint[];\n    remarks: string;\n  }[];\n  public compareSpeedMatrix: PositionValue[];\n  public compareVersion: string;\n  public compareTrustedIndicator: number;\n\n  public currentQualityDoneDate: Date;\n  public currentQualityLaunchedBy: string;\n  public currentQualityVersion: string;\n  public currentQualityTimeSpentInMs: number;\n\n  private selectedGauge: QualityPoint;\n  private selectedGaugeInPoints: QualityPoint;\n  private selectedGaugeInPointsDetail: string;\n  private rainComputationQualities: any;\n\n  constructor(\n    private rainNode: RainNode,\n    private profileService: ProfileService,\n    public onChanges: () => void = () => {\n    }\n  ) {\n    this.cleanAll();\n  }\n\n  private static CompareDate(date1: string, date2: string, minutes: number): boolean {\n\n    const date1AsDate: Date = new Date(parseInt(date1, 10));\n    const date2Diff = new Date(parseInt(date2, 10));\n    date2Diff.setMinutes(date2Diff.getMinutes() + minutes);\n    const diff = Math.round((date1AsDate.getTime() - date2Diff.getTime()) / (60 * 1000));\n    return diff === 0;\n  }\n\n  public cleanAll() {\n    this.gaugesInCompare = [];\n    this.selectedGauges = [];\n    this.selectedPixels = [];\n    this.pixelsSolutions = [];\n\n    this.selectedGauge = null;\n    this.selectedGaugeInPoints = null;\n    this.cleanCompareQuality('no compare');\n  }\n\n  async refreshCompareQuality(frameSet: FrameSet,\n                              targets: { date: Date; rainComputationId: string; rainComputationQualityId: string }[],\n                              withCompareDuplicate: boolean) {\n\n    const targetsOrdered = targets\n      .sort((a, b) => a.date.getTime() - b.date.getTime())\n      .map(t => {\n        return {date: '' + t.date.getTime(), rainComputationId: t.rainComputationId, rainComputationQualityId: t.rainComputationQualityId};\n      });\n\n    const currentTarget = targetsOrdered.filter(t => t.date === '' + frameSet.date.getTime())[0];\n    const currentPos = targetsOrdered.indexOf(currentTarget);\n    const previousTarget = currentPos >= 0 ? targetsOrdered[currentPos - 1] : null;\n    const nextTarget = currentPos >= 0 && currentPos < targetsOrdered.length - 1 ? targetsOrdered[currentPos + 1] : null;\n\n    await this.fetchRainComputationQualities(targetsOrdered);\n\n    const currentQuality: RainComputationQuality = this.rainComputationQualities[currentTarget?.date];\n    if (!currentQuality) {\n      this.cleanCompareQuality('no current quality ' + Object.keys(this.rainComputationQualities));\n      return;\n    }\n\n    this.currentQualityDoneDate = currentQuality.isDoneDate;\n    this.currentQualityTimeSpentInMs = currentQuality.timeSpentInMs;\n    this.currentQualityLaunchedBy = currentQuality.launchedBy;\n    this.currentQualityVersion = currentQuality.version;\n\n    const previousQuality: RainComputationQuality = previousTarget &&\n    CompareManager.CompareDate(previousTarget.date, currentTarget.date, -5) ?\n      this.rainComputationQualities[previousTarget.date] : null;\n    const nextQuality: RainComputationQuality = nextTarget\n    && CompareManager.CompareDate(nextTarget.date, currentTarget.date, +5) ?\n      this.rainComputationQualities[nextTarget.date] : null;\n\n    const qualitySpeedMatrixContainer = currentQuality.qualitySpeedMatrixContainer;\n\n    this.compareNames = qualitySpeedMatrixContainer.getMatrices()\n      .map(m => m.name)\n      .sort((a, b) => parseInt(a, 10) - parseInt(b, 10));\n    this.compareVersion = currentQuality.getVersion();\n    this.compareSpeedMatrix = qualitySpeedMatrixContainer.renderMergedMatrix({normalize: true});\n    this.compareTrustedIndicator = qualitySpeedMatrixContainer.getTrustedIndicators()[0];\n    this.compares = this.buildCompares(currentQuality, previousQuality, nextQuality, withCompareDuplicate);\n    this.onChanges();\n  }\n\n  async setGauges() {\n    // console.log('setGauges');\n\n    const qualityPoints: QualityPoint[] = [];\n    for (const compare of this.compares) {\n      for (const qualityPoint of compare.comparePointsHistory) {\n        const alreadyAdded = qualityPoints.filter(p => p?.gaugeId === qualityPoint.gaugeId);\n        if (alreadyAdded.length === 0) {\n          qualityPoints.push(qualityPoint);\n        }\n      }\n    }\n\n    this.gaugesInCompare = qualityPoints.map(p => {\n      return new MapLatLng(p.gaugeCartesianValue.lat, p.gaugeCartesianValue.lng, 0,\n        p.gaugeId, p.gaugeLabel + '>' + p.getGaugeValue(),\n        p.getGaugeValue());\n    });\n\n    this.resetSelectedGauges();\n  }\n\n  async selectGauge(gaugeId: string, compareIndex: number) {\n    // console.log('selectGauge', gaugeId, compareIndex);\n\n    if (gaugeId) {\n      const xys = this.getCurrentQualityPoints(compareIndex).filter(p => p.gaugeId === gaugeId);\n      this.selectedGauge = xys.length === 1 ? xys[0] : null;\n    } else {\n      this.selectedGauge = null;\n    }\n\n    if (!this.selectedGauge) {\n      return this.resetSelectedGauges();\n    }\n\n    const selectedGaugeInPoints = this.getCurrentQualityPoints(compareIndex).filter(p => p.gaugeId === this.selectedGauge.gaugeId);\n    let pixelsSolutions: MapLatLng[][] = [];\n\n    if (selectedGaugeInPoints.length === 1) {\n      const remarks = JSON.parse(selectedGaugeInPoints[0].remark)\n        .sort((a, b) => a.criteriaAttemptedToBeMinimum - b.criteriaAttemptedToBeMinimum);\n      console.log(remarks);\n      pixelsSolutions = remarks\n        .map(remark => remark.solutionForGauge.pixels\n          .map(p => new MapLatLng(p.y + 0.005, p.x + 0.01, 0, '' + !remark.notPossible, '' + !remark.notPossible, 1)));\n\n      const timeDeltaInMinutes = selectedGaugeInPoints[0].getTimeDeltaInMinutes();\n      this.selectedGaugeInPointsDetail = '' + selectedGaugeInPoints[0].gaugeLabel + ' > '\n        + Math.round(selectedGaugeInPoints[0].getGaugeValue() * 100) / 100 + ' / '\n        + Math.round(selectedGaugeInPoints[0].getRainValue() * 100) / 100\n        + ' dT=' + timeDeltaInMinutes;\n\n      this.selectedGaugeInPoints = selectedGaugeInPoints[0];\n\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(this.selectedGaugeInPoints.gaugeCartesianValue.lat, this.selectedGaugeInPoints.gaugeCartesianValue.lng, undefined,\n        this.selectedGaugeInPoints.gaugeId,\n        this.selectedGaugeInPoints.gaugeLabel + '>' + this.selectedGaugeInPoints.gaugeCartesianValue.value,\n        this.selectedGaugeInPoints.gaugeCartesianValue.value),\n    ];\n\n    this.selectGaugeInCompare();\n\n    const pixels: MapLatLng[] = [];\n    for (const rainCartesianValue of this.selectedGaugeInPoints.rainCartesianValues) {\n      pixels.push(new MapLatLng(rainCartesianValue.lat + 0.005, rainCartesianValue.lng + 0.01));\n    }\n    this.selectedPixels = pixels;\n\n    this.pixelsSolutions = pixelsSolutions;\n  }\n\n  private getCurrentQualityPoints(compareIndex: number) {\n    if (compareIndex < 0 || this.compareNames.length < compareIndex) {\n      return [];\n    }\n\n    return this.compares[compareIndex].comparePointsHistory;\n  }\n\n  private cleanCompareQuality(details?: string) {\n    this.compareVersion = details;\n    this.compareNames = [];\n    this.compares = [];\n    this.rainComputationQualities = {};\n  }\n\n  private async fetchRainComputationQualities(targetsOrdered: {\n    date: string;\n    rainComputationId: string;\n    rainComputationQualityId: string\n  }[]) {\n\n    for (const key of Object.keys(this.rainComputationQualities)) {\n      const found = targetsOrdered.filter(t => t.date === key);\n      if (found.length < 0) {\n        delete this.rainComputationQualities[key];\n      }\n    }\n\n    for (const target of targetsOrdered) {\n      if (!this.rainComputationQualities[target.date] && target.rainComputationQualityId) {\n        try {\n          this.rainComputationQualities[target.date] = await this.profileService\n            .getRainCompareById(this.rainNode.getId(), target.rainComputationId, target.rainComputationQualityId);\n        } catch (e) {\n          console.log(e);\n        }\n      }\n    }\n  }\n\n  private buildCompares(currentQuality: RainComputationQuality,\n                        previousQuality: RainComputationQuality,\n                        nextQuality: RainComputationQuality,\n                        withCompareDuplicate: boolean) {\n    const compares = [];\n    const qualitySpeedMatrixContainer = currentQuality.qualitySpeedMatrixContainer;\n    for (const [index, name] of this.compareNames.entries()) {\n\n      const comparePointsHistory = qualitySpeedMatrixContainer.getQualityPoints(name);\n      const maxValue = Math.max(qualitySpeedMatrixContainer.getMaxGauge(), qualitySpeedMatrixContainer.getMaxRain());\n      const remarks = qualitySpeedMatrixContainer.getMatrix(index)?.remarks;\n\n      const delta = parseInt(name, 10);\n      let renamed = new Date(currentQuality.date.getTime() - delta * 60 * 1000).toLocaleString();\n      renamed += delta > 0 ? ' since ' : ' in ';\n      renamed += Math.abs(delta) + ' minutes';\n\n      console.log('index:', index, 'delta:', delta, 'renamed:', renamed);\n\n      // remove previous or next better values from comparePoints\n      let qualityPoints = comparePointsHistory.filter((p: any) => p); // no real filter\n\n      const removeDuplicates = !withCompareDuplicate;\n      if (removeDuplicates) {\n        if (index === this.compareNames.length - 1) {\n          if (!previousQuality?.qualitySpeedMatrixContainer) {\n            qualityPoints = [];\n          } else {\n            qualityPoints = qualityPoints.filter((p: QualityPoint) => {\n              const previousQPs = previousQuality.qualitySpeedMatrixContainer\n                .getQualityPointsByHistoricalPosition(0)\n                .filter(previousQP => p.gaugeId === previousQP.gaugeId);\n\n              // better before ?\n              const betterBefore = (previousQPs.length === 1 && p.getDelta() > previousQPs[0].getDelta());\n              if (betterBefore) {\n                console.log('removed from', renamed, p.gaugeLabel, previousQuality.date.toISOString(),\n                  p.getDelta(),\n                  previousQPs.length === 1 ? previousQPs[0].getDelta() + ' dated ' + previousQPs[0].gaugeDate.toISOString() : 0);\n                return false; // => remove it\n              }\n              return true;\n            });\n          }\n        } else if (index === 0) {\n          if (!nextQuality?.qualitySpeedMatrixContainer) {\n            qualityPoints = [];\n          } else {\n            qualityPoints = qualityPoints.filter((p: QualityPoint) => {\n              const nextQPs = nextQuality.qualitySpeedMatrixContainer\n                .getQualityPointsByHistoricalPosition(1)\n                .filter(nextQP => p.gaugeId === nextQP.gaugeId);\n\n              // better after ?\n              const betterAfter = (nextQPs.length === 1 && p.getDelta() > nextQPs[0].getDelta());\n              if (betterAfter) {\n                console.log('removed from', renamed, p.gaugeLabel, nextQuality.date.toISOString(),\n                  p.getDelta(),\n                  nextQPs.length === 1 ? nextQPs[0].getDelta() + ' dated ' + nextQPs[0].gaugeDate.toISOString() : 0);\n                return false; // => remove it\n              }\n              return true;\n            });\n          }\n        }\n      }\n\n      const comparePoints = qualityPoints.map((qualityPoint: QualityPoint) =>\n        new XYType(qualityPoint.getGaugeValue(), qualityPoint.getRainValue(), 2, qualityPoint.gaugeLabel, qualityPoint.gaugeId));\n\n      const compare = {\n        name: renamed,\n        comparePointsHistory,\n        comparePoints,\n        maxValue,\n        comparePointsMax: new XYType(maxValue + 20, maxValue + 20),\n        remarks,\n      };\n\n      compares.push(compare);\n    }\n\n    return compares;\n  }\n\n  private selectGaugeInCompare() {\n    for (const compare of this.compares) {\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  private 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"]}
@@ -0,0 +1,10 @@
1
+ export class FrameSet {
2
+ constructor(date, radarMeasureIds = [], rainComputationId = null, rainComputationVersion = null, rainComputationQualities = []) {
3
+ this.date = date;
4
+ this.radarMeasureIds = radarMeasureIds;
5
+ this.rainComputationId = rainComputationId;
6
+ this.rainComputationVersion = rainComputationVersion;
7
+ this.rainComputationQualities = rainComputationQualities;
8
+ }
9
+ }
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRnJhbWVTZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL3NoYXJlZC90b29scy9GcmFtZVNldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sUUFBUTtJQUNuQixZQUFtQixJQUFVLEVBQ1Ysa0JBQTRCLEVBQUUsRUFDOUIsb0JBQTRCLElBQUksRUFDaEMseUJBQWlDLElBQUksRUFDckMsMkJBR0QsRUFBRTtRQVBELFNBQUksR0FBSixJQUFJLENBQU07UUFDVixvQkFBZSxHQUFmLGVBQWUsQ0FBZTtRQUM5QixzQkFBaUIsR0FBakIsaUJBQWlCLENBQWU7UUFDaEMsMkJBQXNCLEdBQXRCLHNCQUFzQixDQUFlO1FBQ3JDLDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FHdkI7SUFDcEIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIEZyYW1lU2V0IHtcbiAgY29uc3RydWN0b3IocHVibGljIGRhdGU6IERhdGUsXG4gICAgICAgICAgICAgIHB1YmxpYyByYWRhck1lYXN1cmVJZHM6IHN0cmluZ1tdID0gW10sXG4gICAgICAgICAgICAgIHB1YmxpYyByYWluQ29tcHV0YXRpb25JZDogc3RyaW5nID0gbnVsbCxcbiAgICAgICAgICAgICAgcHVibGljIHJhaW5Db21wdXRhdGlvblZlcnNpb246IHN0cmluZyA9IG51bGwsXG4gICAgICAgICAgICAgIHB1YmxpYyByYWluQ29tcHV0YXRpb25RdWFsaXRpZXM6IHtcbiAgICAgICAgICAgICAgICB2ZXJzaW9uOiBzdHJpbmcsXG4gICAgICAgICAgICAgICAgaWQ6IHN0cmluZ1xuICAgICAgICAgICAgICB9W10gPSBbXSkge1xuICB9XG59XG4iXX0=
@@ -0,0 +1,19 @@
1
+ import { GaugeNode } from 'raain-model';
2
+ export class GaugeNodeFilter extends GaugeNode {
3
+ constructor(json) {
4
+ super(json);
5
+ this.isIn = true;
6
+ this.distance = 0;
7
+ }
8
+ approxDistanceFrom(center) {
9
+ this.distance = Math.round((Math.pow(this.latitude - center.lat, 2) + Math.pow(this.longitude - center.lng, 2)) * 100 * 100) / 100;
10
+ return this.distance;
11
+ }
12
+ add() {
13
+ this.isIn = true;
14
+ }
15
+ remove() {
16
+ this.isIn = false;
17
+ }
18
+ }
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiR2F1Z2VOb2RlRmlsdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2FwcC9zaGFyZWQvdG9vbHMvR2F1Z2VOb2RlRmlsdGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVMsTUFBTSxhQUFhLENBQUM7QUFFOUMsTUFBTSxPQUFPLGVBQWdCLFNBQVEsU0FBUztJQUs1QyxZQUFZLElBQVM7UUFDbkIsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBSlAsU0FBSSxHQUFHLElBQUksQ0FBQztRQUNaLGFBQVEsR0FBRyxDQUFDLENBQUM7SUFJcEIsQ0FBQztJQUVELGtCQUFrQixDQUFDLE1BQWM7UUFDL0IsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxHQUFHLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxHQUFHLEdBQUcsR0FBRyxDQUFDLEdBQUcsR0FBRyxDQUFDO1FBQ25JLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN2QixDQUFDO0lBRUQsR0FBRztRQUNELElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFFRCxNQUFNO1FBQ0osSUFBSSxDQUFDLElBQUksR0FBRyxLQUFLLENBQUM7SUFDcEIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtHYXVnZU5vZGUsIExhdExuZ30gZnJvbSAncmFhaW4tbW9kZWwnO1xuXG5leHBvcnQgY2xhc3MgR2F1Z2VOb2RlRmlsdGVyIGV4dGVuZHMgR2F1Z2VOb2RlIHtcblxuICBwdWJsaWMgaXNJbiA9IHRydWU7XG4gIHB1YmxpYyBkaXN0YW5jZSA9IDA7XG5cbiAgY29uc3RydWN0b3IoanNvbjogYW55KSB7XG4gICAgc3VwZXIoanNvbik7XG4gIH1cblxuICBhcHByb3hEaXN0YW5jZUZyb20oY2VudGVyOiBMYXRMbmcpOiBudW1iZXIge1xuICAgIHRoaXMuZGlzdGFuY2UgPSBNYXRoLnJvdW5kKChNYXRoLnBvdyh0aGlzLmxhdGl0dWRlIC0gY2VudGVyLmxhdCwgMikgKyBNYXRoLnBvdyh0aGlzLmxvbmdpdHVkZSAtIGNlbnRlci5sbmcsIDIpKSAqIDEwMCAqIDEwMCkgLyAxMDA7XG4gICAgcmV0dXJuIHRoaXMuZGlzdGFuY2U7XG4gIH1cblxuICBhZGQoKSB7XG4gICAgdGhpcy5pc0luID0gdHJ1ZTtcbiAgfVxuXG4gIHJlbW92ZSgpIHtcbiAgICB0aGlzLmlzSW4gPSBmYWxzZTtcbiAgfVxufVxuIl19
@@ -0,0 +1,202 @@
1
+ import { Subject, takeUntil, timer } from 'rxjs';
2
+ import { switchMap } from 'rxjs/operators';
3
+ import { TimeframeContainers } from 'raain-ui';
4
+ export class RefreshManager {
5
+ constructor(rainNode, radarService, profileService, compareManager, onRefreshInProgress, onRefreshDone, onFetchDone) {
6
+ this.rainNode = rainNode;
7
+ this.radarService = radarService;
8
+ this.profileService = profileService;
9
+ this.compareManager = compareManager;
10
+ this.onRefreshInProgress = onRefreshInProgress;
11
+ this.onRefreshDone = onRefreshDone;
12
+ this.onFetchDone = onFetchDone;
13
+ this.closeRefreshTimer = new Subject();
14
+ this.cleanAll();
15
+ }
16
+ static Delay(ms) {
17
+ return new Promise(resolve => setTimeout(resolve, ms));
18
+ }
19
+ cleanAll() {
20
+ this.countsPeriod = {};
21
+ this.timeframesFromRadars = [];
22
+ this.timeframesFromRadarsExtended = [];
23
+ this.timeframeDates = [];
24
+ this.closeRefreshTimer?.next(null);
25
+ }
26
+ async fetch(dateShown, withGaugesMeasures, withCompareDuplicate) {
27
+ // set the target
28
+ const currents = this.timeframesFromRadarsExtended.filter(t => t.date.getTime() === dateShown.getTime());
29
+ if (currents.length !== 1) {
30
+ console.log('no correct dateShown', dateShown, this.timeframesFromRadarsExtended);
31
+ return;
32
+ }
33
+ // build [current, previous, next] targets
34
+ const current = currents[0];
35
+ const position = this.timeframesFromRadarsExtended.indexOf(current);
36
+ let previous = null, next = null;
37
+ const positionNames = ['' + current.date.getTime()];
38
+ const frameSets = {};
39
+ frameSets['' + current.date.getTime()] = current;
40
+ if (position > 0) {
41
+ previous = this.timeframesFromRadarsExtended[position - 1];
42
+ positionNames.push('' + previous.date.getTime());
43
+ frameSets['' + previous.date.getTime()] = previous;
44
+ }
45
+ if (position < this.timeframesFromRadarsExtended.length) {
46
+ next = this.timeframesFromRadarsExtended[position + 1];
47
+ if (next?.date) {
48
+ positionNames.push('' + next.date.getTime());
49
+ frameSets['' + next.date.getTime()] = next;
50
+ }
51
+ }
52
+ // align Map with targets
53
+ const targets = [];
54
+ for (const positionName of positionNames) {
55
+ if (frameSets[positionName]) {
56
+ const target = frameSets[positionName];
57
+ target.rainComputationQualityId = this.getRainComputationQualityTarget(target);
58
+ target.withGauge = withGaugesMeasures;
59
+ targets.push(target);
60
+ const timeframeContainers = await this.refreshMapTimeframeContainers(target);
61
+ if (positionName === ('' + current.date.getTime())) {
62
+ this.onFetchDone(timeframeContainers).then(ignored => {
63
+ });
64
+ }
65
+ }
66
+ }
67
+ // align Compare with targets
68
+ this.refreshCompareQuality(current, targets, withCompareDuplicate).then((ignored) => {
69
+ });
70
+ return current;
71
+ }
72
+ async stopAll() {
73
+ this.closeRefreshTimer.next(null); // <-- stop polling
74
+ await this.profileService.stopAll(this.rainNode.id);
75
+ await this.onRefreshDone(this.timeframeDates);
76
+ }
77
+ async setPeriod(begin, end) {
78
+ this.begin = begin;
79
+ this.end = end;
80
+ return this.refreshCounts();
81
+ }
82
+ async refresh(launchQualityAfter) {
83
+ if (!this.begin || !this.end) {
84
+ throw new Error('need a period');
85
+ }
86
+ this.compareManager.cleanAll();
87
+ let refreshInProgress = false;
88
+ let refreshDone = false;
89
+ timer(1000, 15000)
90
+ .pipe(switchMap(async () => {
91
+ if (refreshInProgress) {
92
+ return refreshDone;
93
+ }
94
+ refreshInProgress = true;
95
+ this.onRefreshInProgress(await this.refreshCounts(), this.timeframeDates).then(ignored => {
96
+ });
97
+ refreshDone = await this.refreshPeriodInsidePolling();
98
+ if (!refreshDone) {
99
+ refreshInProgress = false;
100
+ }
101
+ return refreshDone;
102
+ }), takeUntil(this.closeRefreshTimer))
103
+ .subscribe({
104
+ next: async (refreshFinished) => {
105
+ console.log('refreshFinished', refreshFinished, launchQualityAfter);
106
+ if (refreshFinished) {
107
+ this.closeRefreshTimer.next(null);
108
+ await this.onRefreshDone(this.timeframeDates);
109
+ }
110
+ },
111
+ error: (error) => {
112
+ console.error('error in refresh', error);
113
+ }
114
+ });
115
+ }
116
+ async selectGauge(gaugeId, compareIndex) {
117
+ return this.compareManager.selectGauge(gaugeId, compareIndex);
118
+ }
119
+ async refreshCounts() {
120
+ const counts = await this.profileService.getCounts(this.rainNode.id, this.begin, this.end, true);
121
+ this.countsPeriod = {
122
+ radarMeasures: counts.radarMeasures.reduce((partialSum, a) => partialSum + a.x, 0),
123
+ gaugeMeasures: counts.gaugeMeasures.reduce((partialSum, a) => partialSum + a.x, 0),
124
+ computationsByTeam: counts.computationsByTeam.reduce((partialSum, a) => partialSum + a.x, 0),
125
+ computationsByR2R: counts.computationsByR2R.reduce((partialSum, a) => partialSum + a.x, 0),
126
+ computationsUnderProcessing: counts.computationsUnderProcessing.reduce((partialSum, a) => partialSum + a.x, 0),
127
+ gaugeIntensity: counts.gaugeIntensity.reduce((partialSum, a) => partialSum + a.x, 0),
128
+ queueStoreSize: counts.queueStoreSize,
129
+ queueWaiting: counts.queueWaiting,
130
+ queueRunning: counts.queueRunning,
131
+ qualitiesInternal: counts.qualitiesInternal.reduce((partialSum, a) => partialSum + a.x, 0),
132
+ qualitiesInternalInProgress: counts.qualitiesInternalInProgress.reduce((partialSum, a) => partialSum + a.x, 0),
133
+ };
134
+ return this.countsPeriod;
135
+ }
136
+ getRainComputationQualityTarget(frameset) {
137
+ if (frameset.rainComputationQualities.length <= 0) {
138
+ return undefined;
139
+ }
140
+ return frameset.rainComputationQualities[0].id;
141
+ }
142
+ async refreshPeriodInsidePolling() {
143
+ // await RefreshManager.Delay(1000);
144
+ await this.refreshTimeframesFromRadars();
145
+ // if (this.countsPeriod.queueRunning === 0) {
146
+ // return true;
147
+ // }
148
+ if (this.countsPeriod.computationsUnderProcessing > 0) {
149
+ return false; // => continue
150
+ }
151
+ if (this.countsPeriod.qualitiesInternalInProgress > 0) {
152
+ return false; // => continue
153
+ }
154
+ console.log('refreshPeriodInsidePolling', this.countsPeriod.computationsByR2R, this.countsPeriod.radarMeasures);
155
+ // return this.countsPeriod.qualitiesInternal >= this.countsPeriod.radarMeasures;
156
+ const done = this.countsPeriod.computationsByR2R === this.countsPeriod.radarMeasures;
157
+ return done;
158
+ }
159
+ async refreshTimeframesFromRadars() {
160
+ const beginExtended = new Date(this.begin);
161
+ const endExtended = new Date(this.end);
162
+ beginExtended.setMinutes(beginExtended.getMinutes() - 7);
163
+ endExtended.setMinutes(endExtended.getMinutes() + 7);
164
+ this.rainNode = await this.profileService.getRainTimeframe(this.rainNode.getId(), beginExtended, endExtended);
165
+ this.timeframesFromRadarsExtended = await this.radarService.getTimeline(this.rainNode);
166
+ this.timeframesFromRadars = this.timeframesFromRadarsExtended
167
+ .filter((frameSet) => this.begin.getTime() <= frameSet.date.getTime() && frameSet.date.getTime() <= this.end.getTime())
168
+ .sort((a, b) => a.date.getTime() - b.date.getTime());
169
+ // console.log('timeframesFromRadarsExtended:', this.timeframesFromRadarsExtended);
170
+ this.timeframeDates = this.timeframesFromRadars.map(frameSet => frameSet.date);
171
+ return this.timeframesFromRadars;
172
+ }
173
+ async refreshMapTimeframeContainers(target) {
174
+ if (!target || !target.rainComputationId) {
175
+ console.warn('Pb with refreshMapTimeframeContainers insights');
176
+ return;
177
+ }
178
+ const rainNode = this.rainNode;
179
+ const containers = [];
180
+ const newCreatedTimeframeContainers = new TimeframeContainers(containers);
181
+ try {
182
+ const rainNodeCartesianMap = await this.profileService
183
+ .getRainComputationCartesianMapById(rainNode.getId(), target.rainComputationId);
184
+ if (rainNodeCartesianMap) {
185
+ newCreatedTimeframeContainers.addFromRainComputationMap(rainNodeCartesianMap, false);
186
+ this.rainComputationMapDate = rainNodeCartesianMap.date;
187
+ this.rainComputationMapDoneDate = rainNodeCartesianMap.isDoneDate;
188
+ this.rainComputationMapLaunchedBy = rainNodeCartesianMap.launchedBy;
189
+ this.rainComputationMapTimeSpentInMs = rainNodeCartesianMap.timeSpentInMs;
190
+ }
191
+ }
192
+ catch (e) {
193
+ console.warn('Pb with computations for id:', target.rainComputationId, e);
194
+ }
195
+ return newCreatedTimeframeContainers;
196
+ }
197
+ async refreshCompareQuality(frameSet, targets, withCompareDuplicate) {
198
+ await this.compareManager.refreshCompareQuality(frameSet, targets, withCompareDuplicate);
199
+ await this.compareManager.setGauges();
200
+ }
201
+ }
202
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RefreshManager.js","sourceRoot":"","sources":["../../../src/app/shared/tools/RefreshManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {FrameSet} from './FrameSet';\nimport {Subject, takeUntil, timer} from 'rxjs';\nimport {switchMap} from 'rxjs/operators';\nimport {GaugeNode, RainNode} from 'raain-model';\nimport {FrameContainer, IconMapValue, TimeframeContainer, TimeframeContainers} from 'raain-ui';\nimport {RadarService} from '../radar.service';\nimport {ProfileService} from '../profile.service';\nimport {CompareManager} from './CompareManager';\n\nexport class RefreshManager {\n\n  public rainComputationMapDate: Date;\n  public rainComputationMapDoneDate: Date;\n  public rainComputationMapLaunchedBy: string;\n  public rainComputationMapTimeSpentInMs: number;\n\n  protected closeRefreshTimer: Subject<any>;\n  protected countsPeriod: any;\n  protected timeframesFromRadars: FrameSet[];\n  protected timeframesFromRadarsExtended: FrameSet[];\n  protected timeframeDates: Date[];\n  protected begin: Date;\n  protected end: Date;\n\n  constructor(\n    protected rainNode: RainNode,\n    protected radarService: RadarService,\n    protected profileService: ProfileService,\n    protected compareManager: CompareManager,\n    protected onRefreshInProgress: (countPeriods: any, timeframeDates: Date[]) => Promise<void>,\n    protected onRefreshDone: (timeframeDates: Date[]) => Promise<void>,\n    protected onFetchDone: (timeframeContainers: TimeframeContainers) => Promise<void>,\n  ) {\n    this.closeRefreshTimer = new Subject<any>();\n    this.cleanAll();\n  }\n\n  public static Delay(ms: number) {\n    return new Promise(resolve => setTimeout(resolve, ms));\n  }\n\n  cleanAll() {\n\n    this.countsPeriod = {};\n    this.timeframesFromRadars = [];\n    this.timeframesFromRadarsExtended = [];\n    this.timeframeDates = [];\n    this.closeRefreshTimer?.next(null);\n  }\n\n  async fetch(dateShown: Date, withGaugesMeasures: boolean, withCompareDuplicate: boolean): Promise<FrameSet> {\n    // set the target\n    const currents = this.timeframesFromRadarsExtended.filter(t => t.date.getTime() === dateShown.getTime());\n    if (currents.length !== 1) {\n      console.log('no correct dateShown', dateShown, this.timeframesFromRadarsExtended);\n      return;\n    }\n\n    // build [current, previous, next] targets\n    const current: FrameSet = currents[0];\n    const position = this.timeframesFromRadarsExtended.indexOf(current);\n    let previous: FrameSet = null, next: FrameSet = null;\n    const positionNames: string[] = ['' + current.date.getTime()];\n    const frameSets = {};\n    frameSets['' + current.date.getTime()] = current;\n    if (position > 0) {\n      previous = this.timeframesFromRadarsExtended[position - 1];\n      positionNames.push('' + previous.date.getTime());\n      frameSets['' + previous.date.getTime()] = previous;\n    }\n    if (position < this.timeframesFromRadarsExtended.length) {\n      next = this.timeframesFromRadarsExtended[position + 1];\n      if (next?.date) {\n        positionNames.push('' + next.date.getTime());\n        frameSets['' + next.date.getTime()] = next;\n      }\n    }\n\n    // align Map with targets\n    const targets: {\n      date: Date,\n      rainComputationId: string,\n      rainComputationQualityId: string,\n    }[] = [];\n    for (const positionName of positionNames) {\n      if (frameSets[positionName]) {\n        const target = frameSets[positionName];\n        target.rainComputationQualityId = this.getRainComputationQualityTarget(target);\n        target.withGauge = withGaugesMeasures;\n        targets.push(target);\n\n        const timeframeContainers = await this.refreshMapTimeframeContainers(target);\n\n        if (positionName === ('' + current.date.getTime())) {\n          this.onFetchDone(timeframeContainers).then(ignored => {\n          });\n        }\n      }\n    }\n\n    // align Compare with targets\n    this.refreshCompareQuality(current, targets, withCompareDuplicate).then((ignored) => {\n    });\n\n    return current;\n  }\n\n  async stopAll() {\n    this.closeRefreshTimer.next(null); // <-- stop polling\n    await this.profileService.stopAll(this.rainNode.id);\n    await this.onRefreshDone(this.timeframeDates);\n  }\n\n  async setPeriod(begin: Date, end: Date) {\n    this.begin = begin;\n    this.end = end;\n\n    return this.refreshCounts();\n  }\n\n  async refresh(launchQualityAfter: boolean) {\n\n    if (!this.begin || !this.end) {\n      throw new Error('need a period');\n    }\n\n    this.compareManager.cleanAll();\n    let refreshInProgress = false;\n    let refreshDone = false;\n\n    timer(1000, 15000)\n      .pipe(\n        switchMap(async () => {\n          if (refreshInProgress) {\n            return refreshDone;\n          }\n\n          refreshInProgress = true;\n          this.onRefreshInProgress(await this.refreshCounts(), this.timeframeDates).then(ignored => {\n          });\n          refreshDone = await this.refreshPeriodInsidePolling();\n          if (!refreshDone) {\n            refreshInProgress = false;\n          }\n          return refreshDone;\n        }),\n        takeUntil(this.closeRefreshTimer),\n      )\n      .subscribe({\n        next: async (refreshFinished: boolean) => {\n          console.log('refreshFinished', refreshFinished, launchQualityAfter);\n          if (refreshFinished) {\n            this.closeRefreshTimer.next(null);\n            await this.onRefreshDone(this.timeframeDates);\n          }\n        },\n        error: (error: any) => {\n          console.error('error in refresh', error);\n        }\n      });\n\n  }\n\n  async selectGauge(gaugeId: string, compareIndex: number) {\n    return this.compareManager.selectGauge(gaugeId, compareIndex);\n  }\n\n  protected async refreshCounts() {\n    const counts = await this.profileService.getCounts(this.rainNode.id, this.begin, this.end, true);\n    this.countsPeriod = {\n      radarMeasures: counts.radarMeasures.reduce((partialSum, a) => partialSum + a.x, 0),\n      gaugeMeasures: counts.gaugeMeasures.reduce((partialSum, a) => partialSum + a.x, 0),\n      computationsByTeam: counts.computationsByTeam.reduce((partialSum, a) => partialSum + a.x, 0),\n      computationsByR2R: counts.computationsByR2R.reduce((partialSum, a) => partialSum + a.x, 0),\n      computationsUnderProcessing: counts.computationsUnderProcessing.reduce((partialSum, a) => partialSum + a.x, 0),\n      gaugeIntensity: counts.gaugeIntensity.reduce((partialSum, a) => partialSum + a.x, 0),\n      queueStoreSize: counts.queueStoreSize,\n      queueWaiting: counts.queueWaiting,\n      queueRunning: counts.queueRunning,\n      qualitiesInternal: counts.qualitiesInternal.reduce((partialSum, a) => partialSum + a.x, 0),\n      qualitiesInternalInProgress: counts.qualitiesInternalInProgress.reduce((partialSum, a) => partialSum + a.x, 0),\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\n    // await RefreshManager.Delay(1000);\n\n    await this.refreshTimeframesFromRadars();\n\n    // if (this.countsPeriod.queueRunning === 0) {\n    //  return true;\n    // }\n\n    if (this.countsPeriod.computationsUnderProcessing > 0) {\n      return false; // => continue\n    }\n\n    if (this.countsPeriod.qualitiesInternalInProgress > 0) {\n      return false; // => continue\n    }\n\n    console.log('refreshPeriodInsidePolling', this.countsPeriod.computationsByR2R, this.countsPeriod.radarMeasures)\n    // return this.countsPeriod.qualitiesInternal >= this.countsPeriod.radarMeasures;\n    const done = this.countsPeriod.computationsByR2R === this.countsPeriod.radarMeasures;\n    return done;\n  }\n\n  protected async refreshTimeframesFromRadars() {\n\n    const beginExtended = new Date(this.begin);\n    const endExtended = new Date(this.end);\n    beginExtended.setMinutes(beginExtended.getMinutes() - 7);\n    endExtended.setMinutes(endExtended.getMinutes() + 7);\n    this.rainNode = await this.profileService.getRainTimeframe(this.rainNode.getId(), beginExtended, endExtended);\n\n    this.timeframesFromRadarsExtended = await this.radarService.getTimeline(this.rainNode);\n    this.timeframesFromRadars = this.timeframesFromRadarsExtended\n      .filter((frameSet) => this.begin.getTime() <= frameSet.date.getTime() && frameSet.date.getTime() <= this.end.getTime())\n      .sort((a, b) => a.date.getTime() - b.date.getTime());\n\n    // console.log('timeframesFromRadarsExtended:', this.timeframesFromRadarsExtended);\n\n    this.timeframeDates = this.timeframesFromRadars.map(frameSet => frameSet.date);\n    return this.timeframesFromRadars;\n  }\n\n  protected async refreshMapTimeframeContainers(target: {\n    date: Date,\n    rainComputationId: string,\n    withGauge: boolean\n  }) {\n    if (!target || !target.rainComputationId) {\n      console.warn('Pb with refreshMapTimeframeContainers insights');\n      return;\n    }\n\n    const rainNode = this.rainNode;\n    const containers: TimeframeContainer[] = [];\n    const newCreatedTimeframeContainers = new TimeframeContainers(containers);\n    try {\n      const rainNodeCartesianMap = await this.profileService\n        .getRainComputationCartesianMapById(rainNode.getId(), target.rainComputationId);\n      if (rainNodeCartesianMap) {\n        newCreatedTimeframeContainers.addFromRainComputationMap(rainNodeCartesianMap, false);\n\n        this.rainComputationMapDate = rainNodeCartesianMap.date;\n        this.rainComputationMapDoneDate = rainNodeCartesianMap.isDoneDate;\n        this.rainComputationMapLaunchedBy = rainNodeCartesianMap.launchedBy;\n        this.rainComputationMapTimeSpentInMs = rainNodeCartesianMap.timeSpentInMs;\n      }\n    } catch (e) {\n      console.warn('Pb with computations for id:', target.rainComputationId, e);\n    }\n\n    return newCreatedTimeframeContainers;\n  }\n\n  protected async refreshCompareQuality(frameSet: FrameSet, targets: {\n                                        date: Date,\n                                        rainComputationId: string,\n                                        rainComputationQualityId: string,\n                                      }[],\n                                      withCompareDuplicate: boolean) {\n    await this.compareManager.refreshCompareQuality(frameSet, targets, withCompareDuplicate);\n    await this.compareManager.setGauges();\n  }\n\n}\n"]}
@@ -0,0 +1,5 @@
1
+ export * from './CompareManager';
2
+ export * from './FrameSet';
3
+ export * from './GaugeNodeFilter';
4
+ export * from './RefreshManager';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBwL3NoYXJlZC90b29scy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vQ29tcGFyZU1hbmFnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9GcmFtZVNldCc7XG5leHBvcnQgKiBmcm9tICcuL0dhdWdlTm9kZUZpbHRlcic7XG5leHBvcnQgKiBmcm9tICcuL1JlZnJlc2hNYW5hZ2VyJztcbiJdfQ==
@@ -0,0 +1,10 @@
1
+ export class XYType {
2
+ constructor(x, y, r, name, id) {
3
+ this.x = x;
4
+ this.y = y;
5
+ this.r = r;
6
+ this.name = name;
7
+ this.id = id;
8
+ }
9
+ }
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieHl0eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FwcC9zaGFyZWQveHl0eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyxNQUFNO0lBQ2pCLFlBQW1CLENBQVMsRUFDVCxDQUFTLEVBQ1QsQ0FBVSxFQUNWLElBQWEsRUFDYixFQUFXO1FBSlgsTUFBQyxHQUFELENBQUMsQ0FBUTtRQUNULE1BQUMsR0FBRCxDQUFDLENBQVE7UUFDVCxNQUFDLEdBQUQsQ0FBQyxDQUFTO1FBQ1YsU0FBSSxHQUFKLElBQUksQ0FBUztRQUNiLE9BQUUsR0FBRixFQUFFLENBQVM7SUFDOUIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIFhZVHlwZSB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyB4OiBudW1iZXIsXG4gICAgICAgICAgICAgIHB1YmxpYyB5OiBudW1iZXIsXG4gICAgICAgICAgICAgIHB1YmxpYyByPzogbnVtYmVyLFxuICAgICAgICAgICAgICBwdWJsaWMgbmFtZT86IHN0cmluZyxcbiAgICAgICAgICAgICAgcHVibGljIGlkPzogc3RyaW5nKSB7XG4gIH1cbn1cblxuIl19