raain-app 1.5.21 → 1.5.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
CHANGED
|
@@ -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"]}
|
package/fesm2015/raain-app.mjs
CHANGED
|
@@ -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
|
});
|