raain-app 1.6.21 → 1.6.22
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 +2 -0
- package/esm2020/raain-details/raain-details.component.mjs +3 -1
- package/esm2020/tools/CompareManager.mjs +27 -4
- package/fesm2015/raain-app.mjs +28 -3
- package/fesm2015/raain-app.mjs.map +1 -1
- package/fesm2020/raain-app.mjs +28 -3
- package/fesm2020/raain-app.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -84,6 +84,9 @@ export class CompareManager {
|
|
|
84
84
|
}
|
|
85
85
|
}
|
|
86
86
|
async setGaugesInMap() {
|
|
87
|
+
// Get all gauge IDs linked to this rainNode
|
|
88
|
+
const rainNodeGaugeIds = this.rainNode.getLinks(GaugeNode.TYPE).map((l) => l.getId());
|
|
89
|
+
// Fetch gauges from API (may be filtered/limited)
|
|
87
90
|
let gaugesToFilter = await this.profileService.getGauges(this.rainNode?.id, this.rainNode.getCenter());
|
|
88
91
|
gaugesToFilter = gaugesToFilter
|
|
89
92
|
.sort((a, b) => {
|
|
@@ -91,9 +94,29 @@ export class CompareManager {
|
|
|
91
94
|
b.approxDistanceFrom(this.rainNode.getCenter()));
|
|
92
95
|
})
|
|
93
96
|
.filter((v, index) => index < 200);
|
|
94
|
-
|
|
95
|
-
const
|
|
96
|
-
|
|
97
|
+
// Build a map of gauges from API response
|
|
98
|
+
const gaugesFromApi = new Map();
|
|
99
|
+
for (const gauge of gaugesToFilter) {
|
|
100
|
+
gaugesFromApi.set(gauge.id, gauge);
|
|
101
|
+
}
|
|
102
|
+
// Fetch missing gauges individually (those linked but not in API response)
|
|
103
|
+
const missingGaugeIds = rainNodeGaugeIds.filter((id) => !gaugesFromApi.has(id));
|
|
104
|
+
for (const gaugeId of missingGaugeIds) {
|
|
105
|
+
try {
|
|
106
|
+
const gauge = await this.profileService.getGauge(gaugeId);
|
|
107
|
+
if (gauge) {
|
|
108
|
+
gaugesFromApi.set(gauge.id, gauge);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
catch (e) {
|
|
112
|
+
console.warn(`Failed to fetch gauge ${gaugeId}:`, e);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
// Filter to only gauges linked to this rainNode
|
|
116
|
+
const visibleGauges = rainNodeGaugeIds
|
|
117
|
+
.map((id) => gaugesFromApi.get(id))
|
|
118
|
+
.filter((g) => !!g);
|
|
119
|
+
console.log('visibleGauges:', visibleGauges.length, '/', rainNodeGaugeIds.length);
|
|
97
120
|
const gaugesLatLng = [];
|
|
98
121
|
for (const gauge of visibleGauges) {
|
|
99
122
|
gaugesLatLng.push(new MapLatLng(gauge.latitude, gauge.longitude, undefined, gauge.id, gauge.name));
|
|
@@ -311,4 +334,4 @@ export class CompareManager {
|
|
|
311
334
|
this.selectGaugeInCompare();
|
|
312
335
|
}
|
|
313
336
|
}
|
|
314
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompareManager.js","sourceRoot":"","sources":["../../../src/core/shared/tools/CompareManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {MapLatLng} from 'raain-ui';\nimport {\n    GaugeNode,\n    IComparePerDate,\n    ICompares,\n    PositionValue,\n    QualityPoint,\n    RainComputationQuality,\n    RainNode,\n    SpeedMatrixContainer,\n} from 'raain-model';\nimport {XYType} from '../xytype';\nimport {ProfileService} from '../profile.service';\nimport {FrameSet} from './FrameSet';\n\nexport interface ICompareTarget {\n    date: Date;\n    rainComputationId?: string;\n    rainComputationCumulativeId?: string;\n}\n\nexport interface IUICompare {\n    date: Date;\n    name: string;\n    comparePoints: XYType[];\n    comparePointsMax: XYType;\n    comparePointsHistory: QualityPoint[];\n    remarks: string;\n}\n\nexport class CompareManager {\n    public gaugesInMap: MapLatLng[];\n    public gaugesInCompare: MapLatLng[];\n    public selectedGauges: MapLatLng[];\n    public selectedPixels: MapLatLng[];\n    public pixelsSolutions: MapLatLng[][];\n    public speeds: MapLatLng[];\n\n    // from comparesTimeline\n    public compareNames: string[];\n    public uiCompares: IUICompare[];\n    public compareSpeedMatrix: PositionValue[];\n    public compareVersion: string;\n    public compareTrustedIndicator: number;\n    public compareDates: Date[];\n\n    public currentQualityDoneDate: Date;\n    public currentQualityLaunchedBy: string;\n    public currentQualityTimeSpentInMs: number;\n    public globalComparePoints: XYType[];\n    public globalComparePointsMax: XYType;\n    public compareSpeed: {angleInDegrees: number; pixelsPerPeriod: number};\n    protected buildCompares: ICompares;\n    protected selectedGauge: QualityPoint;\n    protected selectedGaugeInPoints: QualityPoint;\n    protected selectedGaugeInPointsDetail: string;\n    protected rainComputationQualitiesPerDate: any;\n\n    constructor(\n        protected profileService: ProfileService,\n        public onChanges: () => void = () => {}\n    ) {\n        this.cleanAll();\n    }\n\n    protected _rainNode: RainNode;\n\n    public get rainNode(): RainNode {\n        return this._rainNode;\n    }\n\n    public set rainNode(rainNode: RainNode) {\n        this._rainNode = rainNode;\n        this.cleanAll();\n    }\n\n    public cleanAll() {\n        this.gaugesInMap = [];\n        this.gaugesInCompare = [];\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\n        this.compareDates = [];\n        this.speeds = [];\n\n        this.buildCompares = {\n            comparesPerDate: [],\n            compareCumulative: null,\n        };\n        this.globalComparePoints = [];\n        this.globalComparePointsMax = new XYType(0, 0);\n        this.rainComputationQualitiesPerDate = {};\n\n        this.selectedGauge = null;\n        this.selectedGaugeInPoints = null;\n        this.cleanCompareQuality('no compare yet');\n    }\n\n    async refreshCompareQuality(frameSet: FrameSet, onlyOne: boolean) {\n        const comparePerDate = this.getComparePerDate(frameSet.date);\n\n        if (\n            !comparePerDate ||\n            !comparePerDate.rainComputationQuality?.qualitySpeedMatrixContainer\n        ) {\n            this.cleanCompareQuality(\n                'no current quality ' + Object.keys(this.rainComputationQualitiesPerDate)\n            );\n            this.onChanges();\n            return;\n        }\n\n        if (onlyOne) {\n            comparePerDate.compareTimeline = comparePerDate.compareTimeline.filter(\n                (c) => c.date.getTime() === frameSet.date.getTime()\n            );\n        }\n\n        const uiCompares: IUICompare[] = comparePerDate.compareTimeline\n            .map((c) => {\n                return {\n                    date: c.date,\n                    name: c.name,\n                    comparePoints: c.qualityPoints.map(\n                        (p) =>\n                            new XYType(\n                                p.getGaugeValue(),\n                                p.getRainValue(),\n                                2,\n                                p.gaugeLabel,\n                                p.gaugeId\n                            )\n                    ),\n                    comparePointsMax: new XYType(c.maxValue * 1.2, c.maxValue * 1.2),\n                    comparePointsHistory: c.qualityPointsLegacy,\n                    remarks: c.remarks,\n                };\n            })\n            .sort((a, b) => a.date?.getTime() - b.date?.getTime());\n\n        this.currentQualityDoneDate = comparePerDate.rainComputationQuality.isDoneDate;\n        this.currentQualityTimeSpentInMs = comparePerDate.rainComputationQuality.timeSpentInMs;\n        this.currentQualityLaunchedBy = comparePerDate.rainComputationQuality.launchedBy;\n        this.compareVersion = comparePerDate.rainComputationQuality.getVersion();\n\n        this.compareSpeed =\n            comparePerDate.rainComputationQuality.qualitySpeedMatrixContainer.getSpeed();\n        this.compareNames = uiCompares.map((c) => c.name);\n        this.uiCompares = uiCompares;\n\n        this.onChanges();\n    }\n\n    async refreshGlobalCompareQuality(\n        targetsOrdered: ICompareTarget[],\n        withCompareDuplicate: boolean,\n        cumulativeHours: number = 0\n    ) {\n        try {\n            await this.fetchRainComputationQualities(targetsOrdered, cumulativeHours);\n\n            await this.buildComparesTimeline(targetsOrdered, withCompareDuplicate);\n\n            if (!this.buildCompares.compareCumulative) {\n                // throw Error('needs cumulative compare');\n                return;\n            }\n\n            const countForAverage = targetsOrdered.length;\n            const maxValue = this.buildCompares.compareCumulative.maxValue * 1.2;\n            this.globalComparePoints = this.buildCompares.compareCumulative.qualityPoints.map(\n                (qp) =>\n                    new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId)\n            );\n            this.globalComparePointsMax = new XYType(maxValue, maxValue);\n        } catch (e) {\n            console.warn(e);\n        }\n    }\n\n    async setGaugesInMap() {\n        let gaugesToFilter = await this.profileService.getGauges(\n            this.rainNode?.id,\n            this.rainNode.getCenter()\n        );\n        gaugesToFilter = gaugesToFilter\n            .sort((a, b) => {\n                return (\n                    a.approxDistanceFrom(this.rainNode.getCenter()) -\n                    b.approxDistanceFrom(this.rainNode.getCenter())\n                );\n            })\n            .filter((v, index) => index < 200);\n\n        const rainNodeGaugeIds = this.rainNode.getLinks(GaugeNode.TYPE).map((l) => l.getId());\n\n        const visibleGauges = gaugesToFilter.filter((g) => rainNodeGaugeIds.indexOf(g.id) > -1);\n        console.log('visibleGauges:', visibleGauges);\n\n        const gaugesLatLng: MapLatLng[] = [];\n        for (const gauge of visibleGauges) {\n            gaugesLatLng.push(\n                new MapLatLng(gauge.latitude, gauge.longitude, undefined, gauge.id, gauge.name)\n            );\n        }\n        this.gaugesInMap = gaugesLatLng;\n    }\n\n    async setGaugesInCompare() {\n        const qualityPoints: QualityPoint[] = [];\n        for (const compare of this.uiCompares) {\n            for (const qualityPoint of compare.comparePointsHistory) {\n                const alreadyAdded = qualityPoints.filter(\n                    (p) => p?.gaugeId === qualityPoint.gaugeId\n                );\n                if (alreadyAdded.length === 0) {\n                    qualityPoints.push(qualityPoint);\n                }\n            }\n        }\n\n        this.gaugesInCompare = qualityPoints.map((p) => {\n            return new MapLatLng(\n                p.gaugeCartesianValue.lat,\n                p.gaugeCartesianValue.lng,\n                0,\n                p.gaugeId,\n                p.gaugeLabel + '>' + p.getGaugeValue(),\n                p.getGaugeValue()\n            );\n        });\n\n        this.resetSelectedGauges();\n    }\n\n    async selectGauge(gaugeId: string, compareIndex: number) {\n        if (gaugeId) {\n            const xys = this.getCurrentQualityPoints(compareIndex).filter(\n                (p) => p.gaugeId === gaugeId\n            );\n            this.selectedGauge = xys.length === 1 ? xys[0] : null;\n        } else {\n            this.selectedGauge = null;\n        }\n\n        if (!this.selectedGauge) {\n            this.resetSelectedGauges();\n            const gaugesFiltered = this.gaugesInMap.filter((g) => g.id === gaugeId);\n            if (gaugesFiltered.length === 1) {\n                this.selectedGauges = [gaugesFiltered[0]];\n            }\n            return;\n        }\n\n        const selectedGaugeInPoints = this.getCurrentQualityPoints(compareIndex).filter(\n            (p) => p.gaugeId === this.selectedGauge.gaugeId\n        );\n        let pixelsSolutions: MapLatLng[][] = [];\n\n        if (selectedGaugeInPoints.length === 1) {\n            const remarks = JSON.parse(selectedGaugeInPoints[0].remark).sort(\n                (a, b) => a.criteriaAttemptedToBeMinimum - b.criteriaAttemptedToBeMinimum\n            );\n            console.log(remarks);\n            pixelsSolutions = remarks.map((remark) =>\n                remark.solutionForGauge.pixels.map(\n                    (p) =>\n                        new MapLatLng(\n                            p.y + 0.005,\n                            p.x + 0.01,\n                            0,\n                            '' + !remark.notPossible,\n                            '' + !remark.notPossible,\n                            1\n                        )\n                )\n            );\n\n            const timeDeltaInMinutes = selectedGaugeInPoints[0].getTimeDeltaInMinutes();\n            this.selectedGaugeInPointsDetail =\n                '' +\n                selectedGaugeInPoints[0].gaugeLabel +\n                ' > ' +\n                Math.round(selectedGaugeInPoints[0].getGaugeValue() * 100) / 100 +\n                ' / ' +\n                Math.round(selectedGaugeInPoints[0].getRainValue() * 100) / 100 +\n                ' dT=' +\n                timeDeltaInMinutes;\n\n            this.selectedGaugeInPoints = selectedGaugeInPoints[0];\n        } else {\n            this.selectedGaugeInPoints = null;\n            this.selectedGauges = [];\n            this.selectedPixels = [];\n            this.pixelsSolutions = [];\n            return;\n        }\n\n        this.selectedGauges = [\n            new MapLatLng(\n                this.selectedGaugeInPoints.gaugeCartesianValue.lat,\n                this.selectedGaugeInPoints.gaugeCartesianValue.lng,\n                undefined,\n                this.selectedGaugeInPoints.gaugeId,\n                this.selectedGaugeInPoints.gaugeLabel +\n                    '>' +\n                    this.selectedGaugeInPoints.gaugeCartesianValue.value,\n                this.selectedGaugeInPoints.gaugeCartesianValue.value\n            ),\n        ];\n\n        this.selectGaugeInCompare();\n\n        const pixels: MapLatLng[] = [];\n        for (const rainCartesianValue of this.selectedGaugeInPoints.rainCartesianValues) {\n            pixels.push(\n                new MapLatLng(rainCartesianValue.lat + 0.005, rainCartesianValue.lng + 0.01)\n            );\n        }\n        this.selectedPixels = pixels;\n\n        this.pixelsSolutions = pixelsSolutions;\n    }\n\n    // Returns all granular quality points across all dates in the period (excludes cumulative end date)\n    getAllGranularComparePoints(): {\n        date: Date;\n        gaugeName: string;\n        gaugeValue: number;\n        pixelValue: number;\n    }[] {\n        const result: {date: Date; gaugeName: string; gaugeValue: number; pixelValue: number}[] =\n            [];\n\n        if (!this.buildCompares?.comparesPerDate?.length || !this.compareDates?.length) {\n            return result;\n        }\n\n        // Find the last date (cumulative end date) to exclude it\n        const lastDateTime = Math.max(...this.compareDates.map((d) => d.getTime()));\n\n        for (const comparePerDate of this.buildCompares.comparesPerDate) {\n            // Skip the last date which contains cumulative values\n            if (comparePerDate.date.getTime() >= lastDateTime) {\n                continue;\n            }\n            if (!comparePerDate.compareTimeline?.length) {\n                continue;\n            }\n            // Get first timeline entry (current step) for each date\n            const currentCompare = comparePerDate.compareTimeline[0];\n            if (!currentCompare?.qualityPoints?.length) {\n                continue;\n            }\n            for (const qp of currentCompare.qualityPoints) {\n                result.push({\n                    date: comparePerDate.date,\n                    gaugeName: qp.gaugeLabel,\n                    gaugeValue: qp.getGaugeValue(),\n                    pixelValue: qp.getRainValue(),\n                });\n            }\n        }\n\n        return result.sort((a, b) => a.date.getTime() - b.date.getTime());\n    }\n\n    protected async buildComparesTimeline(\n        targetsOrdered: ICompareTarget[],\n        withCompareDuplicate: boolean\n    ): Promise<ICompares> {\n        const compareDates = targetsOrdered.map((t) => t.date);\n\n        const qualities: RainComputationQuality[] = compareDates\n            .filter((d) => !!d)\n            .map((d) => this.getRainComputationQuality(d))\n            .filter((rcq) => !!rcq);\n\n        this.compareDates = compareDates; // compareDates.slice(1, -1);\n\n        this.buildCompares = SpeedMatrixContainer.BuildCompares(qualities, !withCompareDuplicate);\n        return this.buildCompares;\n    }\n\n    protected getComparePerDate(date: Date): IComparePerDate {\n        const existing = this.buildCompares.comparesPerDate.filter(\n            (c) => c.date.getTime() === date.getTime()\n        );\n        if (existing.length === 1) {\n            return existing[0];\n        }\n        return null;\n    }\n\n    protected getCurrentQualityPoints(compareIndex: number) {\n        if (\n            this.uiCompares.length === 0 ||\n            compareIndex < 0 ||\n            this.compareNames.length < compareIndex\n        ) {\n            return [];\n        }\n\n        return this.uiCompares[compareIndex].comparePointsHistory;\n    }\n\n    protected cleanCompareQuality(details?: string) {\n        this.compareVersion = details;\n        this.compareNames = [];\n        this.uiCompares = [];\n        this.compareSpeedMatrix = [];\n        this.compareTrustedIndicator = undefined;\n\n        this.currentQualityDoneDate = new Date(-1);\n        this.currentQualityLaunchedBy = '';\n        this.currentQualityTimeSpentInMs = -1;\n    }\n\n    protected async fetchRainComputationQualities(\n        targetsOrdered: ICompareTarget[],\n        cumulativeHours: number = 0\n    ) {\n        // For N-hour cumulative, only fetch once for the last target (end of period)\n        const targetsToFetch =\n            cumulativeHours > 0 ? [targetsOrdered[targetsOrdered.length - 1]] : targetsOrdered;\n\n        for (const target of targetsToFetch) {\n            if (!this.rainComputationQualitiesPerDate[target.date.toISOString()]) {\n                try {\n                    let rainComputationQuality: RainComputationQuality;\n\n                    if (cumulativeHours > 0 && target.rainComputationCumulativeId) {\n                        // N-hour cumulative: fetch aggregated quality for the whole period\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCumulativesCompareByDate(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                target.date,\n                                cumulativeHours\n                            );\n                    } else if (target.rainComputationCumulativeId) {\n                        // 5-min granular: fetch individual quality\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCompareByDate(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                target.date\n                            );\n                    }\n\n                    if (rainComputationQuality) {\n                        let isConsistent = true;\n                        const matrices =\n                            rainComputationQuality.qualitySpeedMatrixContainer.getMatrices();\n                        for (const matrix of matrices) {\n                            if (!matrix.isConsistent()) {\n                                isConsistent = false;\n                            }\n                        }\n\n                        if (!isConsistent) {\n                            console.warn(\n                                `One of rainComputationQuality matrices is not consistent for ${target.date.toISOString()}`\n                            );\n                        }\n\n                        this.rainComputationQualitiesPerDate[target.date.toISOString()] =\n                            rainComputationQuality;\n                    }\n                } catch (e) {\n                    console.warn(e);\n                }\n            }\n        }\n    }\n\n    protected getRainComputationQuality(date: Date): RainComputationQuality {\n        return this.rainComputationQualitiesPerDate[date.toISOString()];\n    }\n\n    protected selectGaugeInCompare() {\n        const globalComparePoints = JSON.parse(JSON.stringify(this.globalComparePoints));\n        for (const p of globalComparePoints) {\n            if (p.id === this.selectedGaugeInPoints?.gaugeId) {\n                p.r = 10;\n            } else {\n                p.r = 2;\n            }\n        }\n        this.globalComparePoints = globalComparePoints;\n\n        for (const compare of this.uiCompares) {\n            const comparePoints = JSON.parse(JSON.stringify(compare.comparePoints));\n            comparePoints.forEach((p) => {\n                if (p.id === this.selectedGaugeInPoints?.gaugeId) {\n                    p.r = 10;\n                } else {\n                    p.r = 3;\n                }\n            });\n            compare.comparePoints = comparePoints;\n        }\n    }\n\n    protected resetSelectedGauges() {\n        // console.log('resetSelectedGauges reset');\n        this.selectedGauge = null;\n        this.selectedGaugeInPoints = null;\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\n        this.selectGaugeInCompare();\n    }\n}\n"]}
|
|
337
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompareManager.js","sourceRoot":"","sources":["../../../src/core/shared/tools/CompareManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {MapLatLng} from 'raain-ui';\nimport {\n    GaugeNode,\n    IComparePerDate,\n    ICompares,\n    PositionValue,\n    QualityPoint,\n    RainComputationQuality,\n    RainNode,\n    SpeedMatrixContainer,\n} from 'raain-model';\nimport {XYType} from '../xytype';\nimport {ProfileService} from '../profile.service';\nimport {FrameSet} from './FrameSet';\n\nexport interface ICompareTarget {\n    date: Date;\n    rainComputationId?: string;\n    rainComputationCumulativeId?: string;\n}\n\nexport interface IUICompare {\n    date: Date;\n    name: string;\n    comparePoints: XYType[];\n    comparePointsMax: XYType;\n    comparePointsHistory: QualityPoint[];\n    remarks: string;\n}\n\nexport class CompareManager {\n    public gaugesInMap: MapLatLng[];\n    public gaugesInCompare: MapLatLng[];\n    public selectedGauges: MapLatLng[];\n    public selectedPixels: MapLatLng[];\n    public pixelsSolutions: MapLatLng[][];\n    public speeds: MapLatLng[];\n\n    // from comparesTimeline\n    public compareNames: string[];\n    public uiCompares: IUICompare[];\n    public compareSpeedMatrix: PositionValue[];\n    public compareVersion: string;\n    public compareTrustedIndicator: number;\n    public compareDates: Date[];\n\n    public currentQualityDoneDate: Date;\n    public currentQualityLaunchedBy: string;\n    public currentQualityTimeSpentInMs: number;\n    public globalComparePoints: XYType[];\n    public globalComparePointsMax: XYType;\n    public compareSpeed: {angleInDegrees: number; pixelsPerPeriod: number};\n    protected buildCompares: ICompares;\n    protected selectedGauge: QualityPoint;\n    protected selectedGaugeInPoints: QualityPoint;\n    protected selectedGaugeInPointsDetail: string;\n    protected rainComputationQualitiesPerDate: any;\n\n    constructor(\n        protected profileService: ProfileService,\n        public onChanges: () => void = () => {}\n    ) {\n        this.cleanAll();\n    }\n\n    protected _rainNode: RainNode;\n\n    public get rainNode(): RainNode {\n        return this._rainNode;\n    }\n\n    public set rainNode(rainNode: RainNode) {\n        this._rainNode = rainNode;\n        this.cleanAll();\n    }\n\n    public cleanAll() {\n        this.gaugesInMap = [];\n        this.gaugesInCompare = [];\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\n        this.compareDates = [];\n        this.speeds = [];\n\n        this.buildCompares = {\n            comparesPerDate: [],\n            compareCumulative: null,\n        };\n        this.globalComparePoints = [];\n        this.globalComparePointsMax = new XYType(0, 0);\n        this.rainComputationQualitiesPerDate = {};\n\n        this.selectedGauge = null;\n        this.selectedGaugeInPoints = null;\n        this.cleanCompareQuality('no compare yet');\n    }\n\n    async refreshCompareQuality(frameSet: FrameSet, onlyOne: boolean) {\n        const comparePerDate = this.getComparePerDate(frameSet.date);\n\n        if (\n            !comparePerDate ||\n            !comparePerDate.rainComputationQuality?.qualitySpeedMatrixContainer\n        ) {\n            this.cleanCompareQuality(\n                'no current quality ' + Object.keys(this.rainComputationQualitiesPerDate)\n            );\n            this.onChanges();\n            return;\n        }\n\n        if (onlyOne) {\n            comparePerDate.compareTimeline = comparePerDate.compareTimeline.filter(\n                (c) => c.date.getTime() === frameSet.date.getTime()\n            );\n        }\n\n        const uiCompares: IUICompare[] = comparePerDate.compareTimeline\n            .map((c) => {\n                return {\n                    date: c.date,\n                    name: c.name,\n                    comparePoints: c.qualityPoints.map(\n                        (p) =>\n                            new XYType(\n                                p.getGaugeValue(),\n                                p.getRainValue(),\n                                2,\n                                p.gaugeLabel,\n                                p.gaugeId\n                            )\n                    ),\n                    comparePointsMax: new XYType(c.maxValue * 1.2, c.maxValue * 1.2),\n                    comparePointsHistory: c.qualityPointsLegacy,\n                    remarks: c.remarks,\n                };\n            })\n            .sort((a, b) => a.date?.getTime() - b.date?.getTime());\n\n        this.currentQualityDoneDate = comparePerDate.rainComputationQuality.isDoneDate;\n        this.currentQualityTimeSpentInMs = comparePerDate.rainComputationQuality.timeSpentInMs;\n        this.currentQualityLaunchedBy = comparePerDate.rainComputationQuality.launchedBy;\n        this.compareVersion = comparePerDate.rainComputationQuality.getVersion();\n\n        this.compareSpeed =\n            comparePerDate.rainComputationQuality.qualitySpeedMatrixContainer.getSpeed();\n        this.compareNames = uiCompares.map((c) => c.name);\n        this.uiCompares = uiCompares;\n\n        this.onChanges();\n    }\n\n    async refreshGlobalCompareQuality(\n        targetsOrdered: ICompareTarget[],\n        withCompareDuplicate: boolean,\n        cumulativeHours: number = 0\n    ) {\n        try {\n            await this.fetchRainComputationQualities(targetsOrdered, cumulativeHours);\n\n            await this.buildComparesTimeline(targetsOrdered, withCompareDuplicate);\n\n            if (!this.buildCompares.compareCumulative) {\n                // throw Error('needs cumulative compare');\n                return;\n            }\n\n            const countForAverage = targetsOrdered.length;\n            const maxValue = this.buildCompares.compareCumulative.maxValue * 1.2;\n            this.globalComparePoints = this.buildCompares.compareCumulative.qualityPoints.map(\n                (qp) =>\n                    new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId)\n            );\n            this.globalComparePointsMax = new XYType(maxValue, maxValue);\n        } catch (e) {\n            console.warn(e);\n        }\n    }\n\n    async setGaugesInMap() {\n        // Get all gauge IDs linked to this rainNode\n        const rainNodeGaugeIds = this.rainNode.getLinks(GaugeNode.TYPE).map((l) => l.getId());\n\n        // Fetch gauges from API (may be filtered/limited)\n        let gaugesToFilter = await this.profileService.getGauges(\n            this.rainNode?.id,\n            this.rainNode.getCenter()\n        );\n        gaugesToFilter = gaugesToFilter\n            .sort((a, b) => {\n                return (\n                    a.approxDistanceFrom(this.rainNode.getCenter()) -\n                    b.approxDistanceFrom(this.rainNode.getCenter())\n                );\n            })\n            .filter((v, index) => index < 200);\n\n        // Build a map of gauges from API response\n        const gaugesFromApi = new Map<string, {id: string; latitude: number; longitude: number; name: string}>();\n        for (const gauge of gaugesToFilter) {\n            gaugesFromApi.set(gauge.id, gauge);\n        }\n\n        // Fetch missing gauges individually (those linked but not in API response)\n        const missingGaugeIds = rainNodeGaugeIds.filter((id) => !gaugesFromApi.has(id));\n        for (const gaugeId of missingGaugeIds) {\n            try {\n                const gauge = await this.profileService.getGauge(gaugeId);\n                if (gauge) {\n                    gaugesFromApi.set(gauge.id, gauge);\n                }\n            } catch (e) {\n                console.warn(`Failed to fetch gauge ${gaugeId}:`, e);\n            }\n        }\n\n        // Filter to only gauges linked to this rainNode\n        const visibleGauges = rainNodeGaugeIds\n            .map((id) => gaugesFromApi.get(id))\n            .filter((g) => !!g);\n        console.log('visibleGauges:', visibleGauges.length, '/', rainNodeGaugeIds.length);\n\n        const gaugesLatLng: MapLatLng[] = [];\n        for (const gauge of visibleGauges) {\n            gaugesLatLng.push(\n                new MapLatLng(gauge.latitude, gauge.longitude, undefined, gauge.id, gauge.name)\n            );\n        }\n        this.gaugesInMap = gaugesLatLng;\n    }\n\n    async setGaugesInCompare() {\n        const qualityPoints: QualityPoint[] = [];\n        for (const compare of this.uiCompares) {\n            for (const qualityPoint of compare.comparePointsHistory) {\n                const alreadyAdded = qualityPoints.filter(\n                    (p) => p?.gaugeId === qualityPoint.gaugeId\n                );\n                if (alreadyAdded.length === 0) {\n                    qualityPoints.push(qualityPoint);\n                }\n            }\n        }\n\n        this.gaugesInCompare = qualityPoints.map((p) => {\n            return new MapLatLng(\n                p.gaugeCartesianValue.lat,\n                p.gaugeCartesianValue.lng,\n                0,\n                p.gaugeId,\n                p.gaugeLabel + '>' + p.getGaugeValue(),\n                p.getGaugeValue()\n            );\n        });\n\n        this.resetSelectedGauges();\n    }\n\n    async selectGauge(gaugeId: string, compareIndex: number) {\n        if (gaugeId) {\n            const xys = this.getCurrentQualityPoints(compareIndex).filter(\n                (p) => p.gaugeId === gaugeId\n            );\n            this.selectedGauge = xys.length === 1 ? xys[0] : null;\n        } else {\n            this.selectedGauge = null;\n        }\n\n        if (!this.selectedGauge) {\n            this.resetSelectedGauges();\n            const gaugesFiltered = this.gaugesInMap.filter((g) => g.id === gaugeId);\n            if (gaugesFiltered.length === 1) {\n                this.selectedGauges = [gaugesFiltered[0]];\n            }\n            return;\n        }\n\n        const selectedGaugeInPoints = this.getCurrentQualityPoints(compareIndex).filter(\n            (p) => p.gaugeId === this.selectedGauge.gaugeId\n        );\n        let pixelsSolutions: MapLatLng[][] = [];\n\n        if (selectedGaugeInPoints.length === 1) {\n            const remarks = JSON.parse(selectedGaugeInPoints[0].remark).sort(\n                (a, b) => a.criteriaAttemptedToBeMinimum - b.criteriaAttemptedToBeMinimum\n            );\n            console.log(remarks);\n            pixelsSolutions = remarks.map((remark) =>\n                remark.solutionForGauge.pixels.map(\n                    (p) =>\n                        new MapLatLng(\n                            p.y + 0.005,\n                            p.x + 0.01,\n                            0,\n                            '' + !remark.notPossible,\n                            '' + !remark.notPossible,\n                            1\n                        )\n                )\n            );\n\n            const timeDeltaInMinutes = selectedGaugeInPoints[0].getTimeDeltaInMinutes();\n            this.selectedGaugeInPointsDetail =\n                '' +\n                selectedGaugeInPoints[0].gaugeLabel +\n                ' > ' +\n                Math.round(selectedGaugeInPoints[0].getGaugeValue() * 100) / 100 +\n                ' / ' +\n                Math.round(selectedGaugeInPoints[0].getRainValue() * 100) / 100 +\n                ' dT=' +\n                timeDeltaInMinutes;\n\n            this.selectedGaugeInPoints = selectedGaugeInPoints[0];\n        } else {\n            this.selectedGaugeInPoints = null;\n            this.selectedGauges = [];\n            this.selectedPixels = [];\n            this.pixelsSolutions = [];\n            return;\n        }\n\n        this.selectedGauges = [\n            new MapLatLng(\n                this.selectedGaugeInPoints.gaugeCartesianValue.lat,\n                this.selectedGaugeInPoints.gaugeCartesianValue.lng,\n                undefined,\n                this.selectedGaugeInPoints.gaugeId,\n                this.selectedGaugeInPoints.gaugeLabel +\n                    '>' +\n                    this.selectedGaugeInPoints.gaugeCartesianValue.value,\n                this.selectedGaugeInPoints.gaugeCartesianValue.value\n            ),\n        ];\n\n        this.selectGaugeInCompare();\n\n        const pixels: MapLatLng[] = [];\n        for (const rainCartesianValue of this.selectedGaugeInPoints.rainCartesianValues) {\n            pixels.push(\n                new MapLatLng(rainCartesianValue.lat + 0.005, rainCartesianValue.lng + 0.01)\n            );\n        }\n        this.selectedPixels = pixels;\n\n        this.pixelsSolutions = pixelsSolutions;\n    }\n\n    // Returns all granular quality points across all dates in the period (excludes cumulative end date)\n    getAllGranularComparePoints(): {\n        date: Date;\n        gaugeName: string;\n        gaugeValue: number;\n        pixelValue: number;\n    }[] {\n        const result: {date: Date; gaugeName: string; gaugeValue: number; pixelValue: number}[] =\n            [];\n\n        if (!this.buildCompares?.comparesPerDate?.length || !this.compareDates?.length) {\n            return result;\n        }\n\n        // Find the last date (cumulative end date) to exclude it\n        const lastDateTime = Math.max(...this.compareDates.map((d) => d.getTime()));\n\n        for (const comparePerDate of this.buildCompares.comparesPerDate) {\n            // Skip the last date which contains cumulative values\n            if (comparePerDate.date.getTime() >= lastDateTime) {\n                continue;\n            }\n            if (!comparePerDate.compareTimeline?.length) {\n                continue;\n            }\n            // Get first timeline entry (current step) for each date\n            const currentCompare = comparePerDate.compareTimeline[0];\n            if (!currentCompare?.qualityPoints?.length) {\n                continue;\n            }\n            for (const qp of currentCompare.qualityPoints) {\n                result.push({\n                    date: comparePerDate.date,\n                    gaugeName: qp.gaugeLabel,\n                    gaugeValue: qp.getGaugeValue(),\n                    pixelValue: qp.getRainValue(),\n                });\n            }\n        }\n\n        return result.sort((a, b) => a.date.getTime() - b.date.getTime());\n    }\n\n    protected async buildComparesTimeline(\n        targetsOrdered: ICompareTarget[],\n        withCompareDuplicate: boolean\n    ): Promise<ICompares> {\n        const compareDates = targetsOrdered.map((t) => t.date);\n\n        const qualities: RainComputationQuality[] = compareDates\n            .filter((d) => !!d)\n            .map((d) => this.getRainComputationQuality(d))\n            .filter((rcq) => !!rcq);\n\n        this.compareDates = compareDates; // compareDates.slice(1, -1);\n\n        this.buildCompares = SpeedMatrixContainer.BuildCompares(qualities, !withCompareDuplicate);\n        return this.buildCompares;\n    }\n\n    protected getComparePerDate(date: Date): IComparePerDate {\n        const existing = this.buildCompares.comparesPerDate.filter(\n            (c) => c.date.getTime() === date.getTime()\n        );\n        if (existing.length === 1) {\n            return existing[0];\n        }\n        return null;\n    }\n\n    protected getCurrentQualityPoints(compareIndex: number) {\n        if (\n            this.uiCompares.length === 0 ||\n            compareIndex < 0 ||\n            this.compareNames.length < compareIndex\n        ) {\n            return [];\n        }\n\n        return this.uiCompares[compareIndex].comparePointsHistory;\n    }\n\n    protected cleanCompareQuality(details?: string) {\n        this.compareVersion = details;\n        this.compareNames = [];\n        this.uiCompares = [];\n        this.compareSpeedMatrix = [];\n        this.compareTrustedIndicator = undefined;\n\n        this.currentQualityDoneDate = new Date(-1);\n        this.currentQualityLaunchedBy = '';\n        this.currentQualityTimeSpentInMs = -1;\n    }\n\n    protected async fetchRainComputationQualities(\n        targetsOrdered: ICompareTarget[],\n        cumulativeHours: number = 0\n    ) {\n        // For N-hour cumulative, only fetch once for the last target (end of period)\n        const targetsToFetch =\n            cumulativeHours > 0 ? [targetsOrdered[targetsOrdered.length - 1]] : targetsOrdered;\n\n        for (const target of targetsToFetch) {\n            if (!this.rainComputationQualitiesPerDate[target.date.toISOString()]) {\n                try {\n                    let rainComputationQuality: RainComputationQuality;\n\n                    if (cumulativeHours > 0 && target.rainComputationCumulativeId) {\n                        // N-hour cumulative: fetch aggregated quality for the whole period\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCumulativesCompareByDate(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                target.date,\n                                cumulativeHours\n                            );\n                    } else if (target.rainComputationCumulativeId) {\n                        // 5-min granular: fetch individual quality\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCompareByDate(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                target.date\n                            );\n                    }\n\n                    if (rainComputationQuality) {\n                        let isConsistent = true;\n                        const matrices =\n                            rainComputationQuality.qualitySpeedMatrixContainer.getMatrices();\n                        for (const matrix of matrices) {\n                            if (!matrix.isConsistent()) {\n                                isConsistent = false;\n                            }\n                        }\n\n                        if (!isConsistent) {\n                            console.warn(\n                                `One of rainComputationQuality matrices is not consistent for ${target.date.toISOString()}`\n                            );\n                        }\n\n                        this.rainComputationQualitiesPerDate[target.date.toISOString()] =\n                            rainComputationQuality;\n                    }\n                } catch (e) {\n                    console.warn(e);\n                }\n            }\n        }\n    }\n\n    protected getRainComputationQuality(date: Date): RainComputationQuality {\n        return this.rainComputationQualitiesPerDate[date.toISOString()];\n    }\n\n    protected selectGaugeInCompare() {\n        const globalComparePoints = JSON.parse(JSON.stringify(this.globalComparePoints));\n        for (const p of globalComparePoints) {\n            if (p.id === this.selectedGaugeInPoints?.gaugeId) {\n                p.r = 10;\n            } else {\n                p.r = 2;\n            }\n        }\n        this.globalComparePoints = globalComparePoints;\n\n        for (const compare of this.uiCompares) {\n            const comparePoints = JSON.parse(JSON.stringify(compare.comparePoints));\n            comparePoints.forEach((p) => {\n                if (p.id === this.selectedGaugeInPoints?.gaugeId) {\n                    p.r = 10;\n                } else {\n                    p.r = 3;\n                }\n            });\n            compare.comparePoints = comparePoints;\n        }\n    }\n\n    protected resetSelectedGauges() {\n        // console.log('resetSelectedGauges reset');\n        this.selectedGauge = null;\n        this.selectedGaugeInPoints = null;\n        this.selectedGauges = [];\n        this.selectedPixels = [];\n        this.pixelsSolutions = [];\n        this.selectGaugeInCompare();\n    }\n}\n"]}
|
package/fesm2015/raain-app.mjs
CHANGED
|
@@ -1534,6 +1534,9 @@ class CompareManager {
|
|
|
1534
1534
|
setGaugesInMap() {
|
|
1535
1535
|
var _a;
|
|
1536
1536
|
return __awaiter(this, void 0, void 0, function* () {
|
|
1537
|
+
// Get all gauge IDs linked to this rainNode
|
|
1538
|
+
const rainNodeGaugeIds = this.rainNode.getLinks(GaugeNode.TYPE).map((l) => l.getId());
|
|
1539
|
+
// Fetch gauges from API (may be filtered/limited)
|
|
1537
1540
|
let gaugesToFilter = yield this.profileService.getGauges((_a = this.rainNode) === null || _a === void 0 ? void 0 : _a.id, this.rainNode.getCenter());
|
|
1538
1541
|
gaugesToFilter = gaugesToFilter
|
|
1539
1542
|
.sort((a, b) => {
|
|
@@ -1541,9 +1544,29 @@ class CompareManager {
|
|
|
1541
1544
|
b.approxDistanceFrom(this.rainNode.getCenter()));
|
|
1542
1545
|
})
|
|
1543
1546
|
.filter((v, index) => index < 200);
|
|
1544
|
-
|
|
1545
|
-
const
|
|
1546
|
-
|
|
1547
|
+
// Build a map of gauges from API response
|
|
1548
|
+
const gaugesFromApi = new Map();
|
|
1549
|
+
for (const gauge of gaugesToFilter) {
|
|
1550
|
+
gaugesFromApi.set(gauge.id, gauge);
|
|
1551
|
+
}
|
|
1552
|
+
// Fetch missing gauges individually (those linked but not in API response)
|
|
1553
|
+
const missingGaugeIds = rainNodeGaugeIds.filter((id) => !gaugesFromApi.has(id));
|
|
1554
|
+
for (const gaugeId of missingGaugeIds) {
|
|
1555
|
+
try {
|
|
1556
|
+
const gauge = yield this.profileService.getGauge(gaugeId);
|
|
1557
|
+
if (gauge) {
|
|
1558
|
+
gaugesFromApi.set(gauge.id, gauge);
|
|
1559
|
+
}
|
|
1560
|
+
}
|
|
1561
|
+
catch (e) {
|
|
1562
|
+
console.warn(`Failed to fetch gauge ${gaugeId}:`, e);
|
|
1563
|
+
}
|
|
1564
|
+
}
|
|
1565
|
+
// Filter to only gauges linked to this rainNode
|
|
1566
|
+
const visibleGauges = rainNodeGaugeIds
|
|
1567
|
+
.map((id) => gaugesFromApi.get(id))
|
|
1568
|
+
.filter((g) => !!g);
|
|
1569
|
+
console.log('visibleGauges:', visibleGauges.length, '/', rainNodeGaugeIds.length);
|
|
1547
1570
|
const gaugesLatLng = [];
|
|
1548
1571
|
for (const gauge of visibleGauges) {
|
|
1549
1572
|
gaugesLatLng.push(new MapLatLng(gauge.latitude, gauge.longitude, undefined, gauge.id, gauge.name));
|
|
@@ -2657,6 +2680,8 @@ class RaainDetailsComponent {
|
|
|
2657
2680
|
const center = this.rainNode.getCenter();
|
|
2658
2681
|
this.coordinates = new MapLatLng(center.lat, center.lng);
|
|
2659
2682
|
this.teamNode = yield this.profileService.getTeam(this.rainNode.getLink(TeamNode.TYPE).getId());
|
|
2683
|
+
// Load all gauges linked to the rainNode on map
|
|
2684
|
+
yield this.compareManager.setGaugesInMap();
|
|
2660
2685
|
if (this.periodBegin && this.periodEnd) {
|
|
2661
2686
|
this.updateRefreshManagerPeriod();
|
|
2662
2687
|
yield this.refreshManager.refresh(false, this.toggleAdmin);
|