raain-app 1.0.6 → 1.0.7

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.
@@ -18,6 +18,7 @@ export class CompareManager {
18
18
  }
19
19
  static async BuildCompare(frameSet, targetsOrdered, rainComputationQualities, withCompareDuplicate) {
20
20
  let compareSpeedMatrix, compareTrustedIndicator;
21
+ let compareNames = [];
21
22
  let compares = [];
22
23
  const currentTarget = targetsOrdered.filter(t => t.date === '' + frameSet.date.getTime())[0];
23
24
  const currentPos = targetsOrdered.indexOf(currentTarget);
@@ -25,7 +26,7 @@ export class CompareManager {
25
26
  const nextTarget = currentPos >= 0 && currentPos < targetsOrdered.length - 1 ? targetsOrdered[currentPos + 1] : null;
26
27
  const currentQuality = rainComputationQualities[currentTarget?.date];
27
28
  if (!currentQuality) {
28
- return { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares };
29
+ return { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compareNames, compares };
29
30
  }
30
31
  const previousQuality = previousTarget &&
31
32
  CompareManager.CompareDate(previousTarget.date, currentTarget.date, -5) ?
@@ -37,6 +38,9 @@ export class CompareManager {
37
38
  compareSpeedMatrix = qualitySpeedMatrixContainer.renderMergedMatrix({ normalize: true });
38
39
  compareTrustedIndicator = qualitySpeedMatrixContainer.getTrustedIndicators()[0];
39
40
  const comparesToMap = SpeedMatrixContainer.BuildCompares(currentQuality, previousQuality, nextQuality, !withCompareDuplicate);
41
+ compareNames = qualitySpeedMatrixContainer.getMatrices()
42
+ .map(m => m.name)
43
+ .sort((a, b) => parseInt(a, 10) - parseInt(b, 10));
40
44
  compares = comparesToMap.map(c => {
41
45
  return {
42
46
  name: c.name,
@@ -46,7 +50,7 @@ export class CompareManager {
46
50
  remarks: c.remarks
47
51
  };
48
52
  });
49
- return { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares };
53
+ return { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compareNames, compares };
50
54
  }
51
55
  cleanAll() {
52
56
  this.gaugesInCompare = [];
@@ -64,7 +68,7 @@ export class CompareManager {
64
68
  return { date: '' + t.date.getTime(), rainComputationId: t.rainComputationId, rainComputationQualityId: t.rainComputationQualityId };
65
69
  });
66
70
  await this.fetchRainComputationQualities(targetsOrdered);
67
- const { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares } = await CompareManager.BuildCompare(frameSet, targetsOrdered, this.rainComputationQualities, withCompareDuplicate);
71
+ const { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compareNames, compares } = await CompareManager.BuildCompare(frameSet, targetsOrdered, this.rainComputationQualities, withCompareDuplicate);
68
72
  if (!currentQuality) {
69
73
  this.cleanCompareQuality('no current quality ' + Object.keys(this.rainComputationQualities));
70
74
  }
@@ -75,6 +79,7 @@ export class CompareManager {
75
79
  this.compareVersion = currentQuality.getVersion();
76
80
  this.compareSpeedMatrix = compareSpeedMatrix;
77
81
  this.compareTrustedIndicator = compareTrustedIndicator;
82
+ this.compareNames = compareNames;
78
83
  this.compares = compares;
79
84
  }
80
85
  this.onChanges();
@@ -230,4 +235,4 @@ export class CompareManager {
230
235
  this.selectGaugeInCompare();
231
236
  }
232
237
  }
233
- //# 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, SpeedMatrixContainer} from 'raain-model';\nimport {XYType} from '../xytype';\nimport {ProfileService} from '../profile.service';\nimport {FrameSet} from './FrameSet';\n\nexport interface ICompare {\n  name: string;\n  comparePoints: XYType[];\n  comparePointsMax: XYType;\n  comparePointsHistory: QualityPoint[];\n  remarks: string;\n}\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: ICompare[];\n  public compareSpeedMatrix: PositionValue[];\n  public compareVersion: string;\n  public compareTrustedIndicator: number;\n  public currentQualityDoneDate: Date;\n  public currentQualityLaunchedBy: string;\n  public currentQualityTimeSpentInMs: number;\n  public globalComparePoints: XYType[];\n  public globalComparePointsMax: XYType;\n\n  protected selectedGauge: QualityPoint;\n  protected selectedGaugeInPoints: QualityPoint;\n  protected selectedGaugeInPointsDetail: string;\n  protected rainComputationQualities: any;\n\n  constructor(\n    protected rainNode: RainNode,\n    protected profileService: ProfileService,\n    public onChanges: () => void = () => {\n    }\n  ) {\n    this.cleanAll();\n  }\n\n  protected 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  protected static async BuildCompare(frameSet: { date: Date },\n                                      targetsOrdered: { date: string; rainComputationId: string; rainComputationQualityId: string }[],\n                                      rainComputationQualities: any,\n                                      withCompareDuplicate: boolean) {\n\n    let compareSpeedMatrix, compareTrustedIndicator;\n    let compares: ICompare[] = [];\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\n    const currentQuality: RainComputationQuality = rainComputationQualities[currentTarget?.date];\n    if (!currentQuality) {\n      return {currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares};\n    }\n\n    const previousQuality: RainComputationQuality = previousTarget &&\n    CompareManager.CompareDate(previousTarget.date, currentTarget.date, -5) ?\n      rainComputationQualities[previousTarget.date] : null;\n    const nextQuality: RainComputationQuality = nextTarget\n    && CompareManager.CompareDate(nextTarget.date, currentTarget.date, +5) ?\n      rainComputationQualities[nextTarget.date] : null;\n\n    const qualitySpeedMatrixContainer = currentQuality.qualitySpeedMatrixContainer;\n    compareSpeedMatrix = qualitySpeedMatrixContainer.renderMergedMatrix({normalize: true});\n    compareTrustedIndicator = qualitySpeedMatrixContainer.getTrustedIndicators()[0];\n\n    const comparesToMap = SpeedMatrixContainer.BuildCompares(currentQuality, previousQuality, nextQuality, !withCompareDuplicate);\n    compares = comparesToMap.map(c => {\n      return {\n        name: c.name,\n        comparePoints: c.qualityPoints.map(p => new XYType(p.getGaugeValue(), p.getRainValue(), 2, p.gaugeLabel, p.gaugeId)),\n        comparePointsMax: new XYType(c.maxValue + 20, c.maxValue + 20),\n        comparePointsHistory: c.qualityPointsLegacy,\n        remarks: c.remarks\n      };\n    });\n    return {currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares};\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    await this.fetchRainComputationQualities(targetsOrdered);\n\n    const {currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares} =\n      await CompareManager.BuildCompare(frameSet, targetsOrdered, this.rainComputationQualities, withCompareDuplicate);\n\n    if (!currentQuality) {\n      this.cleanCompareQuality('no current quality ' + Object.keys(this.rainComputationQualities));\n    } else {\n      this.currentQualityDoneDate = currentQuality.isDoneDate;\n      this.currentQualityTimeSpentInMs = currentQuality.timeSpentInMs;\n      this.currentQualityLaunchedBy = currentQuality.launchedBy;\n      this.compareVersion = currentQuality.getVersion();\n      this.compareSpeedMatrix = compareSpeedMatrix;\n      this.compareTrustedIndicator = compareTrustedIndicator;\n      this.compares = compares;\n    }\n\n    this.onChanges();\n  }\n\n  async refreshGlobalCompareQuality(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    await this.fetchRainComputationQualities(targetsOrdered);\n\n    let globalComparePoints: XYType[] = [];\n    for (const frameSet of targets) {\n      const {currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares} =\n        await CompareManager.BuildCompare(frameSet, targetsOrdered, this.rainComputationQualities, withCompareDuplicate);\n      for (const compare of compares ? compares : []) {\n        globalComparePoints = globalComparePoints.concat(compare.comparePoints);\n      }\n    }\n\n    let maxX = 0, maxY = 0;\n    const globalComparePointsGrouped = [];\n    const pointsGroupedById = globalComparePoints.reduce((res, value) => {\n      if (!res[value.id]) {\n        res[value.id] = value;\n        globalComparePointsGrouped.push(res[value.id]);\n      } else {\n        res[value.id].x += value.x;\n        res[value.id].y += value.y;\n      }\n      maxX = Math.max(maxX, res[value.id].x);\n      maxY = Math.max(maxY, res[value.id].y);\n      return res;\n    }, {});\n    this.globalComparePoints = globalComparePointsGrouped;\n    this.globalComparePointsMax = new XYType(maxX, maxY);\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  protected getCurrentQualityPoints(compareIndex: number) {\n    if (compareIndex < 0 || this.compareNames.length < compareIndex) {\n      return [];\n    }\n\n    return this.compares[compareIndex].comparePointsHistory;\n  }\n\n  protected cleanCompareQuality(details?: string) {\n    this.compareVersion = details;\n    this.compareNames = [];\n    this.compares = [];\n    this.compareSpeedMatrix = [];\n    this.compareTrustedIndicator = undefined;\n    this.rainComputationQualities = {};\n  }\n\n  protected 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  protected 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  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"]}
238
+ //# 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, SpeedMatrixContainer} from 'raain-model';\nimport {XYType} from '../xytype';\nimport {ProfileService} from '../profile.service';\nimport {FrameSet} from './FrameSet';\n\nexport interface ICompare {\n  name: string;\n  comparePoints: XYType[];\n  comparePointsMax: XYType;\n  comparePointsHistory: QualityPoint[];\n  remarks: string;\n}\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: ICompare[];\n  public compareSpeedMatrix: PositionValue[];\n  public compareVersion: string;\n  public compareTrustedIndicator: number;\n  public currentQualityDoneDate: Date;\n  public currentQualityLaunchedBy: string;\n  public currentQualityTimeSpentInMs: number;\n  public globalComparePoints: XYType[];\n  public globalComparePointsMax: XYType;\n\n  protected selectedGauge: QualityPoint;\n  protected selectedGaugeInPoints: QualityPoint;\n  protected selectedGaugeInPointsDetail: string;\n  protected rainComputationQualities: any;\n\n  constructor(\n    protected rainNode: RainNode,\n    protected profileService: ProfileService,\n    public onChanges: () => void = () => {\n    }\n  ) {\n    this.cleanAll();\n  }\n\n  protected 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  protected static async BuildCompare(frameSet: { date: Date },\n                                      targetsOrdered: { date: string; rainComputationId: string; rainComputationQualityId: string }[],\n                                      rainComputationQualities: any,\n                                      withCompareDuplicate: boolean) {\n\n    let compareSpeedMatrix, compareTrustedIndicator;\n    let compareNames: string[] = [];\n    let compares: ICompare[] = [];\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\n    const currentQuality: RainComputationQuality = rainComputationQualities[currentTarget?.date];\n    if (!currentQuality) {\n      return {currentQuality, compareSpeedMatrix, compareTrustedIndicator, compareNames, compares};\n    }\n\n    const previousQuality: RainComputationQuality = previousTarget &&\n    CompareManager.CompareDate(previousTarget.date, currentTarget.date, -5) ?\n      rainComputationQualities[previousTarget.date] : null;\n    const nextQuality: RainComputationQuality = nextTarget\n    && CompareManager.CompareDate(nextTarget.date, currentTarget.date, +5) ?\n      rainComputationQualities[nextTarget.date] : null;\n\n    const qualitySpeedMatrixContainer = currentQuality.qualitySpeedMatrixContainer;\n    compareSpeedMatrix = qualitySpeedMatrixContainer.renderMergedMatrix({normalize: true});\n    compareTrustedIndicator = qualitySpeedMatrixContainer.getTrustedIndicators()[0];\n\n    const comparesToMap = SpeedMatrixContainer.BuildCompares(currentQuality, previousQuality, nextQuality, !withCompareDuplicate);\n\n    compareNames = qualitySpeedMatrixContainer.getMatrices()\n      .map(m => m.name)\n      .sort((a, b) => parseInt(a, 10) - parseInt(b, 10));\n    compares = comparesToMap.map(c => {\n      return {\n        name: c.name,\n        comparePoints: c.qualityPoints.map(p => new XYType(p.getGaugeValue(), p.getRainValue(), 2, p.gaugeLabel, p.gaugeId)),\n        comparePointsMax: new XYType(c.maxValue + 20, c.maxValue + 20),\n        comparePointsHistory: c.qualityPointsLegacy,\n        remarks: c.remarks\n      };\n    });\n    return {currentQuality, compareSpeedMatrix, compareTrustedIndicator, compareNames, compares};\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    await this.fetchRainComputationQualities(targetsOrdered);\n\n    const {currentQuality, compareSpeedMatrix, compareTrustedIndicator, compareNames, compares} =\n      await CompareManager.BuildCompare(frameSet, targetsOrdered, this.rainComputationQualities, withCompareDuplicate);\n\n    if (!currentQuality) {\n      this.cleanCompareQuality('no current quality ' + Object.keys(this.rainComputationQualities));\n    } else {\n      this.currentQualityDoneDate = currentQuality.isDoneDate;\n      this.currentQualityTimeSpentInMs = currentQuality.timeSpentInMs;\n      this.currentQualityLaunchedBy = currentQuality.launchedBy;\n      this.compareVersion = currentQuality.getVersion();\n      this.compareSpeedMatrix = compareSpeedMatrix;\n      this.compareTrustedIndicator = compareTrustedIndicator;\n      this.compareNames = compareNames;\n      this.compares = compares;\n    }\n\n    this.onChanges();\n  }\n\n  async refreshGlobalCompareQuality(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    await this.fetchRainComputationQualities(targetsOrdered);\n\n    let globalComparePoints: XYType[] = [];\n    for (const frameSet of targets) {\n      const {currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares} =\n        await CompareManager.BuildCompare(frameSet, targetsOrdered, this.rainComputationQualities, withCompareDuplicate);\n      for (const compare of compares ? compares : []) {\n        globalComparePoints = globalComparePoints.concat(compare.comparePoints);\n      }\n    }\n\n    let maxX = 0, maxY = 0;\n    const globalComparePointsGrouped = [];\n    const pointsGroupedById = globalComparePoints.reduce((res, value) => {\n      if (!res[value.id]) {\n        res[value.id] = value;\n        globalComparePointsGrouped.push(res[value.id]);\n      } else {\n        res[value.id].x += value.x;\n        res[value.id].y += value.y;\n      }\n      maxX = Math.max(maxX, res[value.id].x);\n      maxY = Math.max(maxY, res[value.id].y);\n      return res;\n    }, {});\n    this.globalComparePoints = globalComparePointsGrouped;\n    this.globalComparePointsMax = new XYType(maxX, maxY);\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  protected getCurrentQualityPoints(compareIndex: number) {\n    if (compareIndex < 0 || this.compareNames.length < compareIndex) {\n      return [];\n    }\n\n    return this.compares[compareIndex].comparePointsHistory;\n  }\n\n  protected cleanCompareQuality(details?: string) {\n    this.compareVersion = details;\n    this.compareNames = [];\n    this.compares = [];\n    this.compareSpeedMatrix = [];\n    this.compareTrustedIndicator = undefined;\n    this.rainComputationQualities = {};\n  }\n\n  protected 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  protected 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  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"]}
@@ -756,6 +756,7 @@ class CompareManager {
756
756
  static BuildCompare(frameSet, targetsOrdered, rainComputationQualities, withCompareDuplicate) {
757
757
  return __awaiter(this, void 0, void 0, function* () {
758
758
  let compareSpeedMatrix, compareTrustedIndicator;
759
+ let compareNames = [];
759
760
  let compares = [];
760
761
  const currentTarget = targetsOrdered.filter(t => t.date === '' + frameSet.date.getTime())[0];
761
762
  const currentPos = targetsOrdered.indexOf(currentTarget);
@@ -763,7 +764,7 @@ class CompareManager {
763
764
  const nextTarget = currentPos >= 0 && currentPos < targetsOrdered.length - 1 ? targetsOrdered[currentPos + 1] : null;
764
765
  const currentQuality = rainComputationQualities[currentTarget === null || currentTarget === void 0 ? void 0 : currentTarget.date];
765
766
  if (!currentQuality) {
766
- return { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares };
767
+ return { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compareNames, compares };
767
768
  }
768
769
  const previousQuality = previousTarget &&
769
770
  CompareManager.CompareDate(previousTarget.date, currentTarget.date, -5) ?
@@ -775,6 +776,9 @@ class CompareManager {
775
776
  compareSpeedMatrix = qualitySpeedMatrixContainer.renderMergedMatrix({ normalize: true });
776
777
  compareTrustedIndicator = qualitySpeedMatrixContainer.getTrustedIndicators()[0];
777
778
  const comparesToMap = SpeedMatrixContainer.BuildCompares(currentQuality, previousQuality, nextQuality, !withCompareDuplicate);
779
+ compareNames = qualitySpeedMatrixContainer.getMatrices()
780
+ .map(m => m.name)
781
+ .sort((a, b) => parseInt(a, 10) - parseInt(b, 10));
778
782
  compares = comparesToMap.map(c => {
779
783
  return {
780
784
  name: c.name,
@@ -784,7 +788,7 @@ class CompareManager {
784
788
  remarks: c.remarks
785
789
  };
786
790
  });
787
- return { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares };
791
+ return { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compareNames, compares };
788
792
  });
789
793
  }
790
794
  cleanAll() {
@@ -804,7 +808,7 @@ class CompareManager {
804
808
  return { date: '' + t.date.getTime(), rainComputationId: t.rainComputationId, rainComputationQualityId: t.rainComputationQualityId };
805
809
  });
806
810
  yield this.fetchRainComputationQualities(targetsOrdered);
807
- const { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compares } = yield CompareManager.BuildCompare(frameSet, targetsOrdered, this.rainComputationQualities, withCompareDuplicate);
811
+ const { currentQuality, compareSpeedMatrix, compareTrustedIndicator, compareNames, compares } = yield CompareManager.BuildCompare(frameSet, targetsOrdered, this.rainComputationQualities, withCompareDuplicate);
808
812
  if (!currentQuality) {
809
813
  this.cleanCompareQuality('no current quality ' + Object.keys(this.rainComputationQualities));
810
814
  }
@@ -815,6 +819,7 @@ class CompareManager {
815
819
  this.compareVersion = currentQuality.getVersion();
816
820
  this.compareSpeedMatrix = compareSpeedMatrix;
817
821
  this.compareTrustedIndicator = compareTrustedIndicator;
822
+ this.compareNames = compareNames;
818
823
  this.compares = compares;
819
824
  }
820
825
  this.onChanges();