raain-app 1.5.21 → 1.5.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -7,6 +7,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [1.5.21] - 2025-06-09
11
+
10
12
  ## [1.5.20] - 2025-06-09
11
13
 
12
14
  ### Fixed
@@ -172,7 +172,8 @@ export class CompareManager {
172
172
  const dates = targetsOrdered.map((t) => t.date);
173
173
  const qualities = dates
174
174
  .filter((d) => !!d)
175
- .map((d) => this.getRainComputationQuality(d));
175
+ .map((d) => this.getRainComputationQuality(d))
176
+ .filter((rcq) => !!rcq);
176
177
  this.buildCompares = SpeedMatrixContainer.BuildCompares(qualities, !withCompareDuplicate);
177
178
  return this.buildCompares;
178
179
  }
@@ -253,4 +254,4 @@ export class CompareManager {
253
254
  this.selectGaugeInCompare();
254
255
  }
255
256
  }
256
- //# 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    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';\nimport {GaugeNodeFilter} from './GaugeNodeFilter';\n\nexport interface ICompareTarget {\n    date: Date;\n    rainComputationId: string;\n    rainComputationQualityId: string;\n}\n\nexport interface IUICompare {\n    name: string;\n    comparePoints: XYType[];\n    comparePointsMax: XYType;\n    comparePointsHistory: QualityPoint[];\n    remarks: string;\n}\n\nexport class CompareManager {\n    public gaugesToFilter: GaugeNodeFilter[];\n    public rainNodeGauges: string[];\n\n    public gaugesInMap: MapLatLng[];\n    public gaugesInCompare: MapLatLng[];\n    public selectedGauges: MapLatLng[];\n    public selectedPixels: MapLatLng[];\n    public pixelsSolutions: 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\n    public currentQualityDoneDate: Date;\n    public currentQualityLaunchedBy: string;\n    public currentQualityTimeSpentInMs: number;\n    public globalComparePoints: XYType[];\n    public globalComparePointsMax: XYType;\n\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    }\n\n    protected static CompareDate(date1: Date, date2: Date, minutes: number): boolean {\n        const date1AsDate: Date = new Date(date1.getTime());\n        const date2Diff = new Date(date2.getTime());\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.gaugesInMap = [];\n        this.gaugesToFilter = [];\n        this.rainNodeGauges = [];\n        this.gaugesInCompare = [];\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\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) {\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        const uiCompares: IUICompare[] = comparePerDate.compareTimeline.map((c) => {\n            return {\n                name: c.name,\n                comparePoints: c.qualityPoints.map(\n                    (p) =>\n                        new XYType(p.getGaugeValue(), p.getRainValue(), 2, p.gaugeLabel, p.gaugeId)\n                ),\n                comparePointsMax: new XYType(c.maxValue * 1.2, c.maxValue * 1.2),\n                comparePointsHistory: c.qualityPointsLegacy,\n                remarks: c.remarks,\n            };\n        });\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        this.compareSpeedMatrix =\n            comparePerDate.rainComputationQuality.qualitySpeedMatrixContainer.renderMergedMatrix({\n                normalize: true,\n            });\n        this.compareTrustedIndicator =\n            comparePerDate.rainComputationQuality.qualitySpeedMatrixContainer.getTrustedIndicators()[0];\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    ) {\n        try {\n            await this.fetchRainComputationQualities(targetsOrdered);\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 / 12) * 1.2;\n            this.globalComparePoints = this.buildCompares.compareCumulative.qualityPoints.map(\n                (qp) =>\n                    new XYType(\n                        qp.getGaugeValue() / 12,\n                        qp.getRainValue() / 12,\n                        2,\n                        qp.gaugeLabel,\n                        qp.gaugeId\n                    )\n            );\n            this.globalComparePointsMax = new XYType(maxValue, maxValue);\n        } catch (e) {\n            console.warn(e);\n        }\n    }\n\n    async setGaugesInMap() {\n        const gaugesToFilter = await this.profileService.getGauges(this.rainNode?.id);\n        this.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        this.rainNodeGauges = this.rainNode.getLinks('gauge').map((l) => l.getId());\n\n        const visibleGauges = this.gaugesToFilter.filter(\n            (g) => this.rainNodeGauges.indexOf(g.id) > -1\n        );\n        const mapLatLng: MapLatLng[] = [];\n        for (const gauge of visibleGauges) {\n            mapLatLng.push(\n                new MapLatLng(gauge.latitude, gauge.longitude, undefined, gauge.id, gauge.name)\n            );\n        }\n        this.gaugesInMap = mapLatLng;\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        // console.log('selectGauge', gaugeId, compareIndex);\n\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            return this.resetSelectedGauges();\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    protected async buildComparesTimeline(\n        targetsOrdered: ICompareTarget[],\n        withCompareDuplicate: boolean\n    ): Promise<ICompares> {\n        const dates: Date[] = targetsOrdered.map((t) => t.date);\n        const qualities: RainComputationQuality[] = dates\n            .filter((d) => !!d)\n            .map((d) => this.getRainComputationQuality(d));\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 (compareIndex < 0 || this.compareNames.length < compareIndex) {\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(targetsOrdered: ICompareTarget[]) {\n        for (const target of targetsOrdered) {\n            if (\n                !this.rainComputationQualitiesPerDate[target.date.toISOString()] &&\n                target.rainComputationQualityId\n            ) {\n                try {\n                    const rainComputationQuality = await this.profileService.getRainCompareByDate(\n                        this.rainNode.id,\n                        target.rainComputationId,\n                        target.date\n                    );\n                    if (rainComputationQuality) {\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"]}
257
+ //# 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    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';\nimport {GaugeNodeFilter} from './GaugeNodeFilter';\n\nexport interface ICompareTarget {\n    date: Date;\n    rainComputationId: string;\n    rainComputationQualityId: string;\n}\n\nexport interface IUICompare {\n    name: string;\n    comparePoints: XYType[];\n    comparePointsMax: XYType;\n    comparePointsHistory: QualityPoint[];\n    remarks: string;\n}\n\nexport class CompareManager {\n    public gaugesToFilter: GaugeNodeFilter[];\n    public rainNodeGauges: string[];\n\n    public gaugesInMap: MapLatLng[];\n    public gaugesInCompare: MapLatLng[];\n    public selectedGauges: MapLatLng[];\n    public selectedPixels: MapLatLng[];\n    public pixelsSolutions: 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\n    public currentQualityDoneDate: Date;\n    public currentQualityLaunchedBy: string;\n    public currentQualityTimeSpentInMs: number;\n    public globalComparePoints: XYType[];\n    public globalComparePointsMax: XYType;\n\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    }\n\n    protected static CompareDate(date1: Date, date2: Date, minutes: number): boolean {\n        const date1AsDate: Date = new Date(date1.getTime());\n        const date2Diff = new Date(date2.getTime());\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.gaugesInMap = [];\n        this.gaugesToFilter = [];\n        this.rainNodeGauges = [];\n        this.gaugesInCompare = [];\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\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) {\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        const uiCompares: IUICompare[] = comparePerDate.compareTimeline.map((c) => {\n            return {\n                name: c.name,\n                comparePoints: c.qualityPoints.map(\n                    (p) =>\n                        new XYType(p.getGaugeValue(), p.getRainValue(), 2, p.gaugeLabel, p.gaugeId)\n                ),\n                comparePointsMax: new XYType(c.maxValue * 1.2, c.maxValue * 1.2),\n                comparePointsHistory: c.qualityPointsLegacy,\n                remarks: c.remarks,\n            };\n        });\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        this.compareSpeedMatrix =\n            comparePerDate.rainComputationQuality.qualitySpeedMatrixContainer.renderMergedMatrix({\n                normalize: true,\n            });\n        this.compareTrustedIndicator =\n            comparePerDate.rainComputationQuality.qualitySpeedMatrixContainer.getTrustedIndicators()[0];\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    ) {\n        try {\n            await this.fetchRainComputationQualities(targetsOrdered);\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 / 12) * 1.2;\n            this.globalComparePoints = this.buildCompares.compareCumulative.qualityPoints.map(\n                (qp) =>\n                    new XYType(\n                        qp.getGaugeValue() / 12,\n                        qp.getRainValue() / 12,\n                        2,\n                        qp.gaugeLabel,\n                        qp.gaugeId\n                    )\n            );\n            this.globalComparePointsMax = new XYType(maxValue, maxValue);\n        } catch (e) {\n            console.warn(e);\n        }\n    }\n\n    async setGaugesInMap() {\n        const gaugesToFilter = await this.profileService.getGauges(this.rainNode?.id);\n        this.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        this.rainNodeGauges = this.rainNode.getLinks('gauge').map((l) => l.getId());\n\n        const visibleGauges = this.gaugesToFilter.filter(\n            (g) => this.rainNodeGauges.indexOf(g.id) > -1\n        );\n        const mapLatLng: MapLatLng[] = [];\n        for (const gauge of visibleGauges) {\n            mapLatLng.push(\n                new MapLatLng(gauge.latitude, gauge.longitude, undefined, gauge.id, gauge.name)\n            );\n        }\n        this.gaugesInMap = mapLatLng;\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        // console.log('selectGauge', gaugeId, compareIndex);\n\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            return this.resetSelectedGauges();\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    protected async buildComparesTimeline(\n        targetsOrdered: ICompareTarget[],\n        withCompareDuplicate: boolean\n    ): Promise<ICompares> {\n        const dates: Date[] = targetsOrdered.map((t) => t.date);\n        const qualities: RainComputationQuality[] = dates\n            .filter((d) => !!d)\n            .map((d) => this.getRainComputationQuality(d))\n            .filter((rcq) => !!rcq);\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 (compareIndex < 0 || this.compareNames.length < compareIndex) {\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(targetsOrdered: ICompareTarget[]) {\n        for (const target of targetsOrdered) {\n            if (\n                !this.rainComputationQualitiesPerDate[target.date.toISOString()] &&\n                target.rainComputationQualityId\n            ) {\n                try {\n                    const rainComputationQuality = await this.profileService.getRainCompareByDate(\n                        this.rainNode.id,\n                        target.rainComputationId,\n                        target.date\n                    );\n                    if (rainComputationQuality) {\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"]}
@@ -1,6 +1,7 @@
1
1
  import { Subject, takeUntil, timer } from 'rxjs';
2
2
  import { switchMap } from 'rxjs/operators';
3
3
  import { TimeframeContainers } from 'raain-ui';
4
+ const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
4
5
  export class RefreshManager {
5
6
  constructor(radarService, profileService, compareManager) {
6
7
  this.radarService = radarService;
@@ -146,7 +147,7 @@ export class RefreshManager {
146
147
  async refreshPeriodInsidePolling() {
147
148
  let done = false;
148
149
  try {
149
- done = this.refreshCheckIfDone();
150
+ done = await this.refreshCheckIfDone();
150
151
  // behind refresh
151
152
  await this.refreshTimeframesFromRadars(done);
152
153
  this.refreshGlobalCompareReport(done).then((ignored) => { });
@@ -157,10 +158,10 @@ export class RefreshManager {
157
158
  }
158
159
  return done;
159
160
  }
160
- refreshCheckIfDone() {
161
- // console.log('refreshPeriodInsidePolling', this.countsPeriod.computationsByTeam, this.countsPeriod.radarMeasures)
162
- // return this.countsPeriod.computationsByTeam === this.countsPeriod.radarMeasures;
163
- return this.countsPeriod.queueRunning === 0;
161
+ async refreshCheckIfDone() {
162
+ // TODO return this.countsPeriod.queueRunning === 0;
163
+ await sleep(5000);
164
+ return true;
164
165
  }
165
166
  async refreshTimeframesFromRadars(done) {
166
167
  if (!done) {
@@ -239,4 +240,4 @@ export class RefreshManager {
239
240
  await this.compareManager.setGaugesInCompare();
240
241
  }
241
242
  }
242
- //# 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 {Subject, takeUntil, timer} from 'rxjs';\nimport {switchMap} from 'rxjs/operators';\nimport {RainNode} from 'raain-model';\nimport {TimeframeContainer, TimeframeContainers} from 'raain-ui';\nimport {RadarService} from '../radar.service';\nimport {ProfileService} from '../profile.service';\nimport {CompareManager} from './CompareManager';\nimport {XYType} from '../xytype';\n\nexport class RefreshManager {\n    public rainComputationMapDate: Date;\n    public rainComputationMapDoneDate: Date;\n    public rainComputationMapLaunchedBy: string;\n    public rainComputationMapTimeSpentInMs: number;\n    protected closeRefreshTimer: Subject<unknown>;\n    protected countsPeriod: {\n        percentImages?: XYType[];\n        queueRunning?: number;\n    };\n    protected timeframesFromRadars: FrameSet[];\n    protected timeframesFromRadarsExtended: FrameSet[];\n    protected timelineSelectedFrameSet: FrameSet;\n    protected timeframeDates: Date[];\n    protected removeDuplicate: boolean;\n    protected dataInternal: boolean;\n    protected onRefreshInProgress: (\n        countPeriods: {\n            percentImages?: XYType[];\n            queueRunning?: 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.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    }\n\n    private _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 static Delay(ms: number) {\n        return new Promise((resolve) => setTimeout(resolve, ms));\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.countsPeriod = {};\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            // 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,\n            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            cumulativeHours: number;\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                target.cumulativeHours = cumulativeHours;\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        // align Compare with current date\n        this.refreshCompareQuality(current).then((ignored) => {});\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.checkPeriod();\n\n        this.dataInternal = dataInternal;\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(\n                        (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                    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    setRemoveDuplicate(b: boolean) {\n        this.removeDuplicate = b;\n    }\n\n    protected checkPeriod() {\n        if (this.period.begin.getTime() === this.period.end.getTime()) {\n            throw new Error('need a period');\n        }\n    }\n\n    protected async refreshCounts() {\n        this.countsPeriod = await this.profileService.getCounts(this.rainNode.id, {\n            range: 'day',\n            periodBegin: this._period.begin,\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        let done = false;\n        try {\n            done = this.refreshCheckIfDone();\n\n            // behind refresh\n            await this.refreshTimeframesFromRadars(done);\n            this.refreshGlobalCompareReport(done).then((ignored) => {});\n\n            return done;\n        } catch (e) {\n            console.warn(e);\n        }\n\n        return done;\n    }\n\n    protected refreshCheckIfDone(): boolean {\n        // console.log('refreshPeriodInsidePolling', this.countsPeriod.computationsByTeam, this.countsPeriod.radarMeasures)\n        // return this.countsPeriod.computationsByTeam === this.countsPeriod.radarMeasures;\n        return this.countsPeriod.queueRunning === 0;\n    }\n\n    protected async refreshTimeframesFromRadars(done: boolean) {\n        if (!done) {\n            return [];\n        }\n\n        try {\n            const beginExtended = new Date(this.period.begin);\n            const endExtended = new Date(this.period.end);\n            beginExtended.setMinutes(beginExtended.getMinutes() - 7);\n            endExtended.setMinutes(endExtended.getMinutes() + 7);\n            this.rainNode = await this.profileService.getRainTimeframe(\n                this.rainNode.id,\n                beginExtended,\n                endExtended,\n                this.dataInternal\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            console.log('timeframesFromRadarsExtended:', this.timeframesFromRadarsExtended);\n\n            this.timeframeDates = this.timeframesFromRadars.map((frameSet) => frameSet.date);\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 = [];\n            for (const frameSet of this.timeframesFromRadarsExtended) {\n                const target = JSON.parse(JSON.stringify(frameSet));\n                target.date = new Date(target.date);\n                target.rainComputationQualityId = this.getRainComputationQualityTarget(frameSet);\n                targets.push(target);\n            }\n            await this.compareManager.refreshGlobalCompareQuality(targets, !this.removeDuplicate);\n        } catch (e) {\n            console.error('refreshGlobalCompareReport', e);\n        }\n    }\n\n    protected async refreshMapTimeframeContainers(target: {\n        date: Date;\n        rainComputationId: string;\n        withGauge: boolean;\n        cumulativeHours: number;\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            let rainNodeCartesianMap;\n\n            if (!target.cumulativeHours) {\n                rainNodeCartesianMap = await this.profileService.getRainComputationCartesianMapById(\n                    rainNode.id,\n                    target.rainComputationId\n                );\n            } else {\n                rainNodeCartesianMap =\n                    await this.profileService.getRainComputationCumulativeMapById(\n                        rainNode.id,\n                        target.rainComputationId,\n                        target.cumulativeHours\n                    );\n            }\n\n            if (rainNodeCartesianMap) {\n                newCreatedTimeframeContainers.addFromRainComputationMap(\n                    rainNodeCartesianMap,\n                    false\n                );\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) {\n        await this.compareManager.refreshCompareQuality(frameSet);\n        await this.compareManager.setGaugesInCompare();\n    }\n}\n"]}
243
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RefreshManager.js","sourceRoot":"","sources":["../../../src/core/shared/tools/RefreshManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,OAAO,EAAE,SAAS,EAAE,KAAK,EAAC,MAAM,MAAM,CAAC;AAC/C,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAEzC,OAAO,EAAqB,mBAAmB,EAAC,MAAM,UAAU,CAAC;AAMjE,MAAM,KAAK,GAAG,CAAC,EAAU,EAAE,EAAE,CAAC,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;AAEhF,MAAM,OAAO,cAAc;IA0BvB,YACc,YAA0B,EAC1B,cAA8B,EAC9B,cAA8B;QAF9B,iBAAY,GAAZ,YAAY,CAAc;QAC1B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,mBAAc,GAAd,cAAc,CAAgB;QAExC,IAAI,CAAC,OAAO,GAAG,EAAC,KAAK,EAAE,IAAI,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,IAAI,EAAE,EAAC,CAAC;QACpD,IAAI,CAAC,iBAAiB,GAAG,IAAI,OAAO,EAAW,CAAC;QAChD,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAID,IAAW,QAAQ;QACf,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,IAAW,QAAQ,CAAC,QAAkB;QAClC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;IAC9B,CAAC;IAID,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,IAAI,MAAM,CAAC,MAAgC;QACvC,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC5C,IAAI,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACxC,IAAI,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,GAAE,CAAC,CAAC,CAAC;IAC/C,CAAC;IAEM,MAAM,CAAC,KAAK,CAAC,EAAU;QAC1B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;IAC7D,CAAC;IAEM,UAAU,CACb,mBAMkB,EAClB,aAAwD,EACxD,WAAwE;QAExE,IAAI,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;QAC/C,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACnC,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,4BAA4B,GAAG,EAAE,CAAC;QACvC,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IAED,KAAK,CAAC,KAAK,CACP,SAAe,EACf,kBAA2B,EAC3B,eAAe,GAAG,CAAC;QAEnB,iBAAiB;QACjB,MAAM,QAAQ,GAAG,IAAI,CAAC,4BAA4B,CAAC,MAAM,CACrD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,SAAS,CAAC,OAAO,EAAE,CAClD,CAAC;QACF,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YACvB,qFAAqF;YACrF,OAAO;SACV;QAED,0CAA0C;QAC1C,MAAM,OAAO,GAAa,QAAQ,CAAC,CAAC,CAAC,CAAC;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,4BAA4B,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACpE,IAAI,QAAQ,GAAa,IAAI,EACzB,IAAI,GAAa,IAAI,CAAC;QAC1B,MAAM,aAAa,GAAa,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAC9D,MAAM,SAAS,GAAG,EAAE,CAAC;QACrB,SAAS,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,OAAO,CAAC;QACjD,IAAI,QAAQ,GAAG,CAAC,EAAE;YACd,QAAQ,GAAG,IAAI,CAAC,4BAA4B,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;YAC3D,aAAa,CAAC,IAAI,CAAC,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YACjD,SAAS,CAAC,EAAE,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,QAAQ,CAAC;SACtD;QACD,IAAI,QAAQ,GAAG,IAAI,CAAC,4BAA4B,CAAC,MAAM,EAAE;YACrD,IAAI,GAAG,IAAI,CAAC,4BAA4B,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;YACvD,IAAI,IAAI,EAAE,IAAI,EAAE;gBACZ,aAAa,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;gBAC7C,SAAS,CAAC,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC;aAC9C;SACJ;QAED,yBAAyB;QACzB,MAAM,OAAO,GAKP,EAAE,CAAC;QACT,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE;YACtC,IAAI,SAAS,CAAC,YAAY,CAAC,EAAE;gBACzB,MAAM,MAAM,GAAG,SAAS,CAAC,YAAY,CAAC,CAAC;gBACvC,MAAM,CAAC,wBAAwB,GAAG,IAAI,CAAC,+BAA+B,CAAC,MAAM,CAAC,CAAC;gBAC/E,MAAM,CAAC,SAAS,GAAG,kBAAkB,CAAC;gBACtC,MAAM,CAAC,eAAe,GAAG,eAAe,CAAC;gBACzC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAErB,MAAM,mBAAmB,GAAG,MAAM,IAAI,CAAC,6BAA6B,CAAC,MAAM,CAAC,CAAC;gBAE7E,IAAI,YAAY,KAAK,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE;oBAC9C,IAAI,CAAC,WAAW,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,GAAE,CAAC,CAAC,CAAC;iBAC/D;aACJ;SACJ;QAED,kCAAkC;QAClC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,GAAE,CAAC,CAAC,CAAC;QAE1D,IAAI,CAAC,wBAAwB,GAAG,OAAO,CAAC;IAC5C,CAAC;IAED,mBAAmB;QACf,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACrC,CAAC;IAED,2BAA2B;QACvB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,kBAA2B,EAAE,YAAqB;QAC5D,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;QAC/B,IAAI,iBAAiB,GAAG,KAAK,CAAC;QAC9B,IAAI,WAAW,GAAG,KAAK,CAAC;QAExB,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC;aACb,IAAI,CACD,SAAS,CAAC,KAAK,IAAI,EAAE;YACjB,IAAI,iBAAiB,EAAE;gBACnB,OAAO,WAAW,CAAC;aACtB;YAED,iBAAiB,GAAG,IAAI,CAAC;YACzB,IAAI,CAAC,mBAAmB,CAAC,MAAM,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,IAAI,CAC1E,CAAC,OAAO,EAAE,EAAE,GAAE,CAAC,CAClB,CAAC;YACF,WAAW,GAAG,MAAM,IAAI,CAAC,0BAA0B,EAAE,CAAC;YACtD,IAAI,CAAC,WAAW,EAAE;gBACd,iBAAiB,GAAG,KAAK,CAAC;aAC7B;YACD,OAAO,WAAW,CAAC;QACvB,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,iBAAiB,CAAC,CACpC;aACA,SAAS,CAAC;YACP,IAAI,EAAE,KAAK,EAAE,eAAwB,EAAE,EAAE;gBACrC,IAAI,eAAe,EAAE;oBACjB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAClC,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;iBACjD;YACL,CAAC;YACD,KAAK,EAAE,CAAC,KAAU,EAAE,EAAE;gBAClB,OAAO,CAAC,KAAK,CAAC,kBAAkB,EAAE,KAAK,CAAC,CAAC;YAC7C,CAAC;SACJ,CAAC,CAAC;IACX,CAAC;IAED,kBAAkB,CAAC,CAAU;QACzB,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC;IAC7B,CAAC;IAES,WAAW;QACjB,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE;YAC3D,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;SACpC;IACL,CAAC;IAES,KAAK,CAAC,aAAa;QACzB,IAAI,CAAC,YAAY,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;YACtE,KAAK,EAAE,KAAK;YACZ,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK;SAClC,CAAC,CAAC;QACH,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAES,+BAA+B,CAAC,QAAkB;QACxD,IAAI,QAAQ,CAAC,wBAAwB,CAAC,MAAM,IAAI,CAAC,EAAE;YAC/C,OAAO,SAAS,CAAC;SACpB;QACD,OAAO,QAAQ,CAAC,wBAAwB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACnD,CAAC;IAES,KAAK,CAAC,0BAA0B;QACtC,IAAI,IAAI,GAAG,KAAK,CAAC;QACjB,IAAI;YACA,IAAI,GAAG,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAEvC,iBAAiB;YACjB,MAAM,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,CAAC;YAC7C,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,GAAE,CAAC,CAAC,CAAC;YAE5D,OAAO,IAAI,CAAC;SACf;QAAC,OAAO,CAAC,EAAE;YACR,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SACnB;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAES,KAAK,CAAC,kBAAkB;QAC9B,oDAAoD;QACpD,MAAM,KAAK,CAAC,IAAI,CAAC,CAAC;QAClB,OAAO,IAAI,CAAC;IAChB,CAAC;IAES,KAAK,CAAC,2BAA2B,CAAC,IAAa;QACrD,IAAI,CAAC,IAAI,EAAE;YACP,OAAO,EAAE,CAAC;SACb;QAED,IAAI;YACA,MAAM,aAAa,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAClD,MAAM,WAAW,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAC9C,aAAa,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,CAAC;YACzD,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,CAAC;YACrD,IAAI,CAAC,QAAQ,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,gBAAgB,CACtD,IAAI,CAAC,QAAQ,CAAC,EAAE,EAChB,aAAa,EACb,WAAW,EACX,IAAI,CAAC,YAAY,CACpB,CAAC;YAEF,IAAI,CAAC,4BAA4B,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACvF,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,4BAA4B;iBACxD,MAAM,CACH,CAAC,QAAQ,EAAE,EAAE,CACT,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE;gBACtD,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,CAC3D;iBACA,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YAEzD,OAAO,CAAC,GAAG,CAAC,+BAA+B,EAAE,IAAI,CAAC,4BAA4B,CAAC,CAAC;YAEhF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YACjF,OAAO,IAAI,CAAC,oBAAoB,CAAC;SACpC;QAAC,OAAO,CAAC,EAAE;YACR,OAAO,CAAC,KAAK,CAAC,6BAA6B,EAAE,CAAC,CAAC,CAAC;SACnD;QAED,OAAO,EAAE,CAAC;IACd,CAAC;IAES,KAAK,CAAC,0BAA0B,CAAC,IAAa;QACpD,IAAI,CAAC,IAAI,EAAE;YACP,OAAO;SACV;QAED,IAAI;YACA,MAAM,OAAO,GAAG,EAAE,CAAC;YACnB,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,4BAA4B,EAAE;gBACtD,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACpD,MAAM,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;gBACpC,MAAM,CAAC,wBAAwB,GAAG,IAAI,CAAC,+BAA+B,CAAC,QAAQ,CAAC,CAAC;gBACjF,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aACxB;YACD,MAAM,IAAI,CAAC,cAAc,CAAC,2BAA2B,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SACzF;QAAC,OAAO,CAAC,EAAE;YACR,OAAO,CAAC,KAAK,CAAC,4BAA4B,EAAE,CAAC,CAAC,CAAC;SAClD;IACL,CAAC;IAES,KAAK,CAAC,6BAA6B,CAAC,MAK7C;QACG,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE;YACtC,OAAO,CAAC,IAAI,CAAC,gDAAgD,CAAC,CAAC;YAC/D,OAAO;SACV;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC/B,MAAM,UAAU,GAAyB,EAAE,CAAC;QAC5C,MAAM,6BAA6B,GAAG,IAAI,mBAAmB,CAAC,UAAU,CAAC,CAAC;QAC1E,IAAI;YACA,IAAI,oBAAoB,CAAC;YAEzB,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE;gBACzB,oBAAoB,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,kCAAkC,CAC/E,QAAQ,CAAC,EAAE,EACX,MAAM,CAAC,iBAAiB,CAC3B,CAAC;aACL;iBAAM;gBACH,oBAAoB;oBAChB,MAAM,IAAI,CAAC,cAAc,CAAC,mCAAmC,CACzD,QAAQ,CAAC,EAAE,EACX,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,eAAe,CACzB,CAAC;aACT;YAED,IAAI,oBAAoB,EAAE;gBACtB,6BAA6B,CAAC,yBAAyB,CACnD,oBAAoB,EACpB,KAAK,CACR,CAAC;gBAEF,IAAI,CAAC,sBAAsB,GAAG,oBAAoB,CAAC,IAAI,CAAC;gBACxD,IAAI,CAAC,0BAA0B,GAAG,oBAAoB,CAAC,UAAU,CAAC;gBAClE,IAAI,CAAC,4BAA4B,GAAG,oBAAoB,CAAC,UAAU,CAAC;gBACpE,IAAI,CAAC,+BAA+B,GAAG,oBAAoB,CAAC,aAAa,CAAC;aAC7E;SACJ;QAAC,OAAO,CAAC,EAAE;YACR,OAAO,CAAC,IAAI,CAAC,8BAA8B,EAAE,MAAM,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC;SAC7E;QAED,OAAO,6BAA6B,CAAC;IACzC,CAAC;IAES,KAAK,CAAC,qBAAqB,CAAC,QAAkB;QACpD,MAAM,IAAI,CAAC,cAAc,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;QAC1D,MAAM,IAAI,CAAC,cAAc,CAAC,kBAAkB,EAAE,CAAC;IACnD,CAAC;CACJ","sourcesContent":["import {FrameSet} from './FrameSet';\nimport {Subject, takeUntil, timer} from 'rxjs';\nimport {switchMap} from 'rxjs/operators';\nimport {RainNode} from 'raain-model';\nimport {TimeframeContainer, TimeframeContainers} from 'raain-ui';\nimport {RadarService} from '../radar.service';\nimport {ProfileService} from '../profile.service';\nimport {CompareManager} from './CompareManager';\nimport {XYType} from '../xytype';\n\nconst sleep = (ms: number) => new Promise((resolve) => setTimeout(resolve, ms));\n\nexport class RefreshManager {\n    public rainComputationMapDate: Date;\n    public rainComputationMapDoneDate: Date;\n    public rainComputationMapLaunchedBy: string;\n    public rainComputationMapTimeSpentInMs: number;\n    protected closeRefreshTimer: Subject<unknown>;\n    protected countsPeriod: {\n        percentImages?: XYType[];\n        queueRunning?: number;\n    };\n    protected timeframesFromRadars: FrameSet[];\n    protected timeframesFromRadarsExtended: FrameSet[];\n    protected timelineSelectedFrameSet: FrameSet;\n    protected timeframeDates: Date[];\n    protected removeDuplicate: boolean;\n    protected dataInternal: boolean;\n    protected onRefreshInProgress: (\n        countPeriods: {\n            percentImages?: XYType[];\n            queueRunning?: 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.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    }\n\n    private _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 static Delay(ms: number) {\n        return new Promise((resolve) => setTimeout(resolve, ms));\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.countsPeriod = {};\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            // 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,\n            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            cumulativeHours: number;\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                target.cumulativeHours = cumulativeHours;\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        // align Compare with current date\n        this.refreshCompareQuality(current).then((ignored) => {});\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.checkPeriod();\n\n        this.dataInternal = dataInternal;\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(\n                        (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                    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    setRemoveDuplicate(b: boolean) {\n        this.removeDuplicate = b;\n    }\n\n    protected checkPeriod() {\n        if (this.period.begin.getTime() === this.period.end.getTime()) {\n            throw new Error('need a period');\n        }\n    }\n\n    protected async refreshCounts() {\n        this.countsPeriod = await this.profileService.getCounts(this.rainNode.id, {\n            range: 'day',\n            periodBegin: this._period.begin,\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        let done = false;\n        try {\n            done = await this.refreshCheckIfDone();\n\n            // behind refresh\n            await this.refreshTimeframesFromRadars(done);\n            this.refreshGlobalCompareReport(done).then((ignored) => {});\n\n            return done;\n        } catch (e) {\n            console.warn(e);\n        }\n\n        return done;\n    }\n\n    protected async refreshCheckIfDone(): Promise<boolean> {\n        // TODO return this.countsPeriod.queueRunning === 0;\n        await sleep(5000);\n        return true;\n    }\n\n    protected async refreshTimeframesFromRadars(done: boolean) {\n        if (!done) {\n            return [];\n        }\n\n        try {\n            const beginExtended = new Date(this.period.begin);\n            const endExtended = new Date(this.period.end);\n            beginExtended.setMinutes(beginExtended.getMinutes() - 7);\n            endExtended.setMinutes(endExtended.getMinutes() + 7);\n            this.rainNode = await this.profileService.getRainTimeframe(\n                this.rainNode.id,\n                beginExtended,\n                endExtended,\n                this.dataInternal\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            console.log('timeframesFromRadarsExtended:', this.timeframesFromRadarsExtended);\n\n            this.timeframeDates = this.timeframesFromRadars.map((frameSet) => frameSet.date);\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 = [];\n            for (const frameSet of this.timeframesFromRadarsExtended) {\n                const target = JSON.parse(JSON.stringify(frameSet));\n                target.date = new Date(target.date);\n                target.rainComputationQualityId = this.getRainComputationQualityTarget(frameSet);\n                targets.push(target);\n            }\n            await this.compareManager.refreshGlobalCompareQuality(targets, !this.removeDuplicate);\n        } catch (e) {\n            console.error('refreshGlobalCompareReport', e);\n        }\n    }\n\n    protected async refreshMapTimeframeContainers(target: {\n        date: Date;\n        rainComputationId: string;\n        withGauge: boolean;\n        cumulativeHours: number;\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            let rainNodeCartesianMap;\n\n            if (!target.cumulativeHours) {\n                rainNodeCartesianMap = await this.profileService.getRainComputationCartesianMapById(\n                    rainNode.id,\n                    target.rainComputationId\n                );\n            } else {\n                rainNodeCartesianMap =\n                    await this.profileService.getRainComputationCumulativeMapById(\n                        rainNode.id,\n                        target.rainComputationId,\n                        target.cumulativeHours\n                    );\n            }\n\n            if (rainNodeCartesianMap) {\n                newCreatedTimeframeContainers.addFromRainComputationMap(\n                    rainNodeCartesianMap,\n                    false\n                );\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) {\n        await this.compareManager.refreshCompareQuality(frameSet);\n        await this.compareManager.setGaugesInCompare();\n    }\n}\n"]}
@@ -1367,7 +1367,8 @@ class CompareManager {
1367
1367
  const dates = targetsOrdered.map((t) => t.date);
1368
1368
  const qualities = dates
1369
1369
  .filter((d) => !!d)
1370
- .map((d) => this.getRainComputationQuality(d));
1370
+ .map((d) => this.getRainComputationQuality(d))
1371
+ .filter((rcq) => !!rcq);
1371
1372
  this.buildCompares = SpeedMatrixContainer.BuildCompares(qualities, !withCompareDuplicate);
1372
1373
  return this.buildCompares;
1373
1374
  });
@@ -1486,6 +1487,7 @@ class GaugeNodeFilter extends GaugeNode {
1486
1487
  }
1487
1488
  }
1488
1489
 
1490
+ const sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
1489
1491
  class RefreshManager {
1490
1492
  constructor(radarService, profileService, compareManager) {
1491
1493
  this.radarService = radarService;
@@ -1639,7 +1641,7 @@ class RefreshManager {
1639
1641
  return __awaiter(this, void 0, void 0, function* () {
1640
1642
  let done = false;
1641
1643
  try {
1642
- done = this.refreshCheckIfDone();
1644
+ done = yield this.refreshCheckIfDone();
1643
1645
  // behind refresh
1644
1646
  yield this.refreshTimeframesFromRadars(done);
1645
1647
  this.refreshGlobalCompareReport(done).then((ignored) => { });
@@ -1652,9 +1654,11 @@ class RefreshManager {
1652
1654
  });
1653
1655
  }
1654
1656
  refreshCheckIfDone() {
1655
- // console.log('refreshPeriodInsidePolling', this.countsPeriod.computationsByTeam, this.countsPeriod.radarMeasures)
1656
- // return this.countsPeriod.computationsByTeam === this.countsPeriod.radarMeasures;
1657
- return this.countsPeriod.queueRunning === 0;
1657
+ return __awaiter(this, void 0, void 0, function* () {
1658
+ // TODO return this.countsPeriod.queueRunning === 0;
1659
+ yield sleep(5000);
1660
+ return true;
1661
+ });
1658
1662
  }
1659
1663
  refreshTimeframesFromRadars(done) {
1660
1664
  return __awaiter(this, void 0, void 0, function* () {