raain-app 1.6.37 → 3.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -18,7 +18,7 @@ export class CompareManager {
18
18
  if (!this.buildCompares?.compareCumulative) {
19
19
  return new XYType(0, 0);
20
20
  }
21
- const maxValue = this.buildCompares.compareCumulative.maxValue * 1.2;
21
+ const maxValue = Math.max(this.buildCompares.compareCumulative.maxValue * 1.2, 1);
22
22
  return new XYType(maxValue, maxValue);
23
23
  }
24
24
  // Default: KGE normalized 0-1 (from raain-model defaults)
@@ -77,7 +77,7 @@ export class CompareManager {
77
77
  date: c.date,
78
78
  name: c.name,
79
79
  comparePoints: c.qualityPoints.map((p) => new XYType(p.getGaugeValue(), p.getRainValue(), 2, p.gaugeLabel, p.gaugeId)),
80
- comparePointsMax: new XYType(c.maxValue * 1.2, c.maxValue * 1.2),
80
+ comparePointsMax: new XYType(Math.max(c.maxValue * 1.2, 1), Math.max(c.maxValue * 1.2, 1)),
81
81
  comparePointsHistory: c.qualityPointsLegacy,
82
82
  remarks: c.remarks,
83
83
  qualityIndicator,
@@ -103,7 +103,7 @@ export class CompareManager {
103
103
  return;
104
104
  }
105
105
  const countForAverage = targetsOrdered.length;
106
- const maxValue = this.buildCompares.compareCumulative.maxValue * 1.2;
106
+ const maxValue = Math.max(this.buildCompares.compareCumulative.maxValue * 1.2, 1);
107
107
  const cumulativePoints = this.buildCompares.compareCumulative.qualityPoints.map((qp) => new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId));
108
108
  const cumulativePointsMax = new XYType(maxValue, maxValue);
109
109
  // Default: KGE normalized 0-1
@@ -364,4 +364,4 @@ export class CompareManager {
364
364
  this.selectGaugeInCompare();
365
365
  }
366
366
  }
367
- //# 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    SpeedMatrix,\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    qualityIndicator: number;\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 globalQualityIndicator: number;\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    // Merged cumulative from granular comparisons (computed from buildCompares)\n    public get granularCumulativePoints(): XYType[] {\n        if (!this.buildCompares?.compareCumulative?.qualityPoints?.length) {\n            return [];\n        }\n        return this.buildCompares.compareCumulative.qualityPoints.map(\n            (qp) => new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId)\n        );\n    }\n\n    public get granularCumulativePointsMax(): XYType {\n        if (!this.buildCompares?.compareCumulative) {\n            return new XYType(0, 0);\n        }\n        const maxValue = this.buildCompares.compareCumulative.maxValue * 1.2;\n        return new XYType(maxValue, maxValue);\n    }\n\n    // Default: KGE normalized 0-1 (from raain-model defaults)\n    public get granularCumulativeQualityIndicator(): number {\n        if (!this.buildCompares?.compareCumulative?.qualityPoints?.length) {\n            return null;\n        }\n        return SpeedMatrix.ComputeQualityIndicator(\n            this.buildCompares.compareCumulative.qualityPoints\n        );\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.globalQualityIndicator = null;\n        // granularCumulative* are now getters computed from buildCompares\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                // Default: KGE normalized 0-1\n                const qualityIndicator = SpeedMatrix.ComputeQualityIndicator(c.qualityPoints);\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                    qualityIndicator,\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        period: {begin: Date; end: Date},\n        withCompareDuplicate: boolean,\n        provider: string = 'Raain',\n        timeStepInMinutes: number = 5,\n        timeStepMode: 'eq' | 'lte' = 'eq'\n    ) {\n        try {\n            await this.fetchRainComputationQualities(targetsOrdered, provider, timeStepInMinutes, timeStepMode);\n\n            await this.buildComparesTimeline(targetsOrdered, period, 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            const cumulativePoints = this.buildCompares.compareCumulative.qualityPoints.map(\n                (qp) =>\n                    new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId)\n            );\n            const cumulativePointsMax = new XYType(maxValue, maxValue);\n            // Default: KGE normalized 0-1\n            const cumulativeQualityIndicator = SpeedMatrix.ComputeQualityIndicator(\n                this.buildCompares.compareCumulative.qualityPoints\n            );\n\n            // Set for cumulative mode\n            this.globalComparePoints = cumulativePoints;\n            this.globalComparePointsMax = cumulativePointsMax;\n            this.globalQualityIndicator = cumulativeQualityIndicator;\n            // granularCumulative* are now getters computed from buildCompares.compareCumulative\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<\n            string,\n            {id: string; latitude: number; longitude: number; name: string}\n        >();\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        period: {begin: Date; end: Date},\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?.length > 1 ? compareDates : [period.begin, period.end];\n        if (this.compareDates[0].getTime() > period.begin.getTime()) {\n            this.compareDates.unshift(period.begin);\n        }\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        provider: string = 'Raain',\n        timeStepInMinutes: number = 5,\n        timeStepMode: 'eq' | 'lte' = 'eq'\n    ) {\n        for (const target of targetsOrdered) {\n            if (!this.rainComputationQualitiesPerDate[target.date.toISOString()]) {\n                try {\n                    let rainComputationQuality: RainComputationQuality;\n\n                    if (target.rainComputationCumulativeId) {\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCumulativesCompare(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                provider,\n                                timeStepInMinutes,\n                                timeStepMode\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"]}
367
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CompareManager.js","sourceRoot":"","sources":["../../../src/core/shared/tools/CompareManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAC,MAAM,UAAU,CAAC;AACnC,OAAO,EACH,SAAS,EAOT,WAAW,EACX,oBAAoB,GACvB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAC,MAAM,EAAC,MAAM,WAAW,CAAC;AAoBjC,MAAM,OAAO,cAAc;IA6BvB,YACc,cAA8B,EACjC,YAAwB,GAAG,EAAE,GAAE,CAAC;QAD7B,mBAAc,GAAd,cAAc,CAAgB;QACjC,cAAS,GAAT,SAAS,CAAuB;QAEvC,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAED,4EAA4E;IAC5E,IAAW,wBAAwB;QAC/B,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,EAAE;YAC/D,OAAO,EAAE,CAAC;SACb;QACD,OAAO,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,aAAa,CAAC,GAAG,CACzD,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,MAAM,CAAC,EAAE,CAAC,aAAa,EAAE,EAAE,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,OAAO,CAAC,CAC1F,CAAC;IACN,CAAC;IAED,IAAW,2BAA2B;QAClC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,iBAAiB,EAAE;YACxC,OAAO,IAAI,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SAC3B;QACD,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,QAAQ,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC;QAClF,OAAO,IAAI,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;IAC1C,CAAC;IAED,0DAA0D;IAC1D,IAAW,kCAAkC;QACzC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,EAAE;YAC/D,OAAO,IAAI,CAAC;SACf;QACD,OAAO,WAAW,CAAC,uBAAuB,CACtC,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,aAAa,CACrD,CAAC;IACN,CAAC;IAID,IAAW,QAAQ;QACf,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,IAAW,QAAQ,CAAC,QAAkB;QAClC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QAEjB,IAAI,CAAC,aAAa,GAAG;YACjB,eAAe,EAAE,EAAE;YACnB,iBAAiB,EAAE,IAAI;SAC1B,CAAC;QACF,IAAI,CAAC,mBAAmB,GAAG,EAAE,CAAC;QAC9B,IAAI,CAAC,sBAAsB,GAAG,IAAI,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/C,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;QACnC,kEAAkE;QAClE,IAAI,CAAC,+BAA+B,GAAG,EAAE,CAAC;QAE1C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;QAClC,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,CAAC;IAC/C,CAAC;IAED,KAAK,CAAC,qBAAqB,CAAC,QAAkB,EAAE,OAAgB;QAC5D,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAE7D,IACI,CAAC,cAAc;YACf,CAAC,cAAc,CAAC,sBAAsB,EAAE,2BAA2B,EACrE;YACE,4BAA4B;YAC5B,gFAAgF;YAChF,KAAK;YACL,oBAAoB;YACpB,OAAO;SACV;QAED,IAAI,OAAO,EAAE;YACT,cAAc,CAAC,eAAe,GAAG,cAAc,CAAC,eAAe,CAAC,MAAM,CAClE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,CACtD,CAAC;SACL;QAED,MAAM,UAAU,GAAiB,cAAc,CAAC,eAAe;aAC1D,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACP,8BAA8B;YAC9B,MAAM,gBAAgB,GAAG,WAAW,CAAC,uBAAuB,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC;YAC9E,OAAO;gBACH,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,CAAC,CAAC,IAAI;gBACZ,aAAa,EAAE,CAAC,CAAC,aAAa,CAAC,GAAG,CAC9B,CAAC,CAAC,EAAE,EAAE,CACF,IAAI,MAAM,CACN,CAAC,CAAC,aAAa,EAAE,EACjB,CAAC,CAAC,YAAY,EAAE,EAChB,CAAC,EACD,CAAC,CAAC,UAAU,EACZ,CAAC,CAAC,OAAO,CACZ,CACR;gBACD,gBAAgB,EAAE,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,GAAG,GAAG,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC;gBAC1F,oBAAoB,EAAE,CAAC,CAAC,mBAAmB;gBAC3C,OAAO,EAAE,CAAC,CAAC,OAAO;gBAClB,gBAAgB;aACnB,CAAC;QACN,CAAC,CAAC;aACD,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,OAAO,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;QAE3D,IAAI,CAAC,sBAAsB,GAAG,cAAc,CAAC,sBAAsB,CAAC,UAAU,CAAC;QAC/E,IAAI,CAAC,2BAA2B,GAAG,cAAc,CAAC,sBAAsB,CAAC,aAAa,CAAC;QACvF,IAAI,CAAC,wBAAwB,GAAG,cAAc,CAAC,sBAAsB,CAAC,UAAU,CAAC;QACjF,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC,sBAAsB,CAAC,UAAU,EAAE,CAAC;QAEzE,IAAI,CAAC,YAAY;YACb,cAAc,CAAC,sBAAsB,CAAC,2BAA2B,CAAC,QAAQ,EAAE,CAAC;QACjF,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAClD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAE7B,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,KAAK,CAAC,2BAA2B,CAC7B,cAAgC,EAChC,MAAgC,EAChC,oBAA6B,EAC7B,WAAmB,OAAO,EAC1B,oBAA4B,CAAC,EAC7B,eAA6B,IAAI;QAEjC,IAAI;YACA,MAAM,IAAI,CAAC,6BAA6B,CACpC,cAAc,EACd,QAAQ,EACR,iBAAiB,EACjB,YAAY,CACf,CAAC;YAEF,MAAM,IAAI,CAAC,qBAAqB,CAAC,cAAc,EAAE,MAAM,EAAE,oBAAoB,CAAC,CAAC;YAE/E,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,iBAAiB,EAAE;gBACvC,2CAA2C;gBAC3C,OAAO;aACV;YAED,MAAM,eAAe,GAAG,cAAc,CAAC,MAAM,CAAC;YAC9C,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,QAAQ,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC;YAClF,MAAM,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,aAAa,CAAC,GAAG,CAC3E,CAAC,EAAE,EAAE,EAAE,CACH,IAAI,MAAM,CAAC,EAAE,CAAC,aAAa,EAAE,EAAE,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,OAAO,CAAC,CACtF,CAAC;YACF,MAAM,mBAAmB,GAAG,IAAI,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;YAC3D,8BAA8B;YAC9B,MAAM,0BAA0B,GAAG,WAAW,CAAC,uBAAuB,CAClE,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,aAAa,CACrD,CAAC;YAEF,0BAA0B;YAC1B,IAAI,CAAC,mBAAmB,GAAG,gBAAgB,CAAC;YAC5C,IAAI,CAAC,sBAAsB,GAAG,mBAAmB,CAAC;YAClD,IAAI,CAAC,sBAAsB,GAAG,0BAA0B,CAAC;YACzD,oFAAoF;SACvF;QAAC,OAAO,CAAC,EAAE;YACR,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SACnB;IACL,CAAC;IAED,KAAK,CAAC,cAAc;QAChB,4CAA4C;QAC5C,MAAM,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QAEtF,kDAAkD;QAClD,IAAI,cAAc,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CACpD,IAAI,CAAC,QAAQ,EAAE,EAAE,EACjB,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAC5B,CAAC;QACF,cAAc,GAAG,cAAc;aAC1B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACX,OAAO,CACH,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC;gBAC/C,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,CAClD,CAAC;QACN,CAAC,CAAC;aACD,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;QAEvC,0CAA0C;QAC1C,MAAM,aAAa,GAAG,IAAI,GAAG,EAG1B,CAAC;QACJ,KAAK,MAAM,KAAK,IAAI,cAAc,EAAE;YAChC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;SACtC;QAED,2EAA2E;QAC3E,MAAM,eAAe,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAChF,KAAK,MAAM,OAAO,IAAI,eAAe,EAAE;YACnC,IAAI;gBACA,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;gBAC1D,IAAI,KAAK,EAAE;oBACP,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;iBACtC;aACJ;YAAC,OAAO,CAAC,EAAE;gBACR,OAAO,CAAC,IAAI,CAAC,yBAAyB,OAAO,GAAG,EAAE,CAAC,CAAC,CAAC;aACxD;SACJ;QAED,gDAAgD;QAChD,MAAM,aAAa,GAAG,gBAAgB;aACjC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;aAClC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,aAAa,CAAC,MAAM,EAAE,GAAG,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAC;QAElF,MAAM,YAAY,GAAgB,EAAE,CAAC;QACrC,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE;YAC/B,YAAY,CAAC,IAAI,CACb,IAAI,SAAS,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,SAAS,EAAE,SAAS,EAAE,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,CAClF,CAAC;SACL;QACD,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,kBAAkB;QACpB,MAAM,aAAa,GAAmB,EAAE,CAAC;QACzC,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,UAAU,EAAE;YACnC,KAAK,MAAM,YAAY,IAAI,OAAO,CAAC,oBAAoB,EAAE;gBACrD,MAAM,YAAY,GAAG,aAAa,CAAC,MAAM,CACrC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,KAAK,YAAY,CAAC,OAAO,CAC7C,CAAC;gBACF,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;oBAC3B,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;iBACpC;aACJ;SACJ;QAED,IAAI,CAAC,eAAe,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YAC3C,OAAO,IAAI,SAAS,CAChB,CAAC,CAAC,mBAAmB,CAAC,GAAG,EACzB,CAAC,CAAC,mBAAmB,CAAC,GAAG,EACzB,CAAC,EACD,CAAC,CAAC,OAAO,EACT,CAAC,CAAC,UAAU,GAAG,GAAG,GAAG,CAAC,CAAC,aAAa,EAAE,EACtC,CAAC,CAAC,aAAa,EAAE,CACpB,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAe,EAAE,YAAoB;QACnD,IAAI,OAAO,EAAE;YACT,MAAM,GAAG,GAAG,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,MAAM,CACzD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAC/B,CAAC;YACF,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;SACzD;aAAM;YACH,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC7B;QAED,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC;YACxE,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE;gBAC7B,IAAI,CAAC,cAAc,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;aAC7C;YACD,OAAO;SACV;QAED,MAAM,qBAAqB,GAAG,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,MAAM,CAC3E,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,IAAI,CAAC,aAAa,CAAC,OAAO,CAClD,CAAC;QACF,IAAI,eAAe,GAAkB,EAAE,CAAC;QAExC,IAAI,qBAAqB,CAAC,MAAM,KAAK,CAAC,EAAE;YACpC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAC5D,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,4BAA4B,GAAG,CAAC,CAAC,4BAA4B,CAC5E,CAAC;YACF,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YACrB,eAAe,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CACrC,MAAM,CAAC,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAC9B,CAAC,CAAC,EAAE,EAAE,CACF,IAAI,SAAS,CACT,CAAC,CAAC,CAAC,GAAG,KAAK,EACX,CAAC,CAAC,CAAC,GAAG,IAAI,EACV,CAAC,EACD,EAAE,GAAG,CAAC,MAAM,CAAC,WAAW,EACxB,EAAE,GAAG,CAAC,MAAM,CAAC,WAAW,EACxB,CAAC,CACJ,CACR,CACJ,CAAC;YAEF,MAAM,kBAAkB,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC,qBAAqB,EAAE,CAAC;YAC5E,IAAI,CAAC,2BAA2B;gBAC5B,EAAE;oBACF,qBAAqB,CAAC,CAAC,CAAC,CAAC,UAAU;oBACnC,KAAK;oBACL,IAAI,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,aAAa,EAAE,GAAG,GAAG,CAAC,GAAG,GAAG;oBAChE,KAAK;oBACL,IAAI,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,GAAG,GAAG,CAAC,GAAG,GAAG;oBAC/D,MAAM;oBACN,kBAAkB,CAAC;YAEvB,IAAI,CAAC,qBAAqB,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;SACzD;aAAM;YACH,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;YAClC,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;YACzB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;YAC1B,OAAO;SACV;QAED,IAAI,CAAC,cAAc,GAAG;YAClB,IAAI,SAAS,CACT,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,CAAC,GAAG,EAClD,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,CAAC,GAAG,EAClD,SAAS,EACT,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAClC,IAAI,CAAC,qBAAqB,CAAC,UAAU;gBACjC,GAAG;gBACH,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,CAAC,KAAK,EACxD,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,CAAC,KAAK,CACvD;SACJ,CAAC;QAEF,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,MAAM,MAAM,GAAgB,EAAE,CAAC;QAC/B,KAAK,MAAM,kBAAkB,IAAI,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,EAAE;YAC7E,MAAM,CAAC,IAAI,CACP,IAAI,SAAS,CAAC,kBAAkB,CAAC,GAAG,GAAG,KAAK,EAAE,kBAAkB,CAAC,GAAG,GAAG,IAAI,CAAC,CAC/E,CAAC;SACL;QACD,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;QAE7B,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;IAC3C,CAAC;IAED,oGAAoG;IACpG,2BAA2B;QAMvB,MAAM,MAAM,GACR,EAAE,CAAC;QAEP,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,eAAe,EAAE,MAAM,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE;YAC5E,OAAO,MAAM,CAAC;SACjB;QAED,yDAAyD;QACzD,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAE5E,KAAK,MAAM,cAAc,IAAI,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE;YAC7D,sDAAsD;YACtD,IAAI,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,YAAY,EAAE;gBAC/C,SAAS;aACZ;YACD,IAAI,CAAC,cAAc,CAAC,eAAe,EAAE,MAAM,EAAE;gBACzC,SAAS;aACZ;YACD,wDAAwD;YACxD,MAAM,cAAc,GAAG,cAAc,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;YACzD,IAAI,CAAC,cAAc,EAAE,aAAa,EAAE,MAAM,EAAE;gBACxC,SAAS;aACZ;YACD,KAAK,MAAM,EAAE,IAAI,cAAc,CAAC,aAAa,EAAE;gBAC3C,MAAM,CAAC,IAAI,CAAC;oBACR,IAAI,EAAE,cAAc,CAAC,IAAI;oBACzB,SAAS,EAAE,EAAE,CAAC,UAAU;oBACxB,UAAU,EAAE,EAAE,CAAC,aAAa,EAAE;oBAC9B,UAAU,EAAE,EAAE,CAAC,YAAY,EAAE;iBAChC,CAAC,CAAC;aACN;SACJ;QAED,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IACtE,CAAC;IAES,KAAK,CAAC,qBAAqB,CACjC,cAAgC,EAChC,MAAgC,EAChC,oBAA6B;QAE7B,MAAM,YAAY,GAAG,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAEvD,MAAM,SAAS,GAA6B,YAAY;aACnD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;aAClB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC;aAC7C,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAE5B,IAAI,CAAC,YAAY,GAAG,YAAY,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;QACzF,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE;YACzD,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;SAC3C;QAED,IAAI,CAAC,aAAa,GAAG,oBAAoB,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC,oBAAoB,CAAC,CAAC;QAC1F,OAAO,IAAI,CAAC,aAAa,CAAC;IAC9B,CAAC;IAES,iBAAiB,CAAC,IAAU;QAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,MAAM,CACtD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,OAAO,EAAE,CAC7C,CAAC;QACF,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YACvB,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC;SACtB;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAES,uBAAuB,CAAC,YAAoB;QAClD,IACI,IAAI,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC;YAC5B,YAAY,GAAG,CAAC;YAChB,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,YAAY,EACzC;YACE,OAAO,EAAE,CAAC;SACb;QAED,OAAO,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,oBAAoB,CAAC;IAC9D,CAAC;IAES,mBAAmB,CAAC,OAAgB;QAC1C,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC;QAC9B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;QAC7B,IAAI,CAAC,uBAAuB,GAAG,SAAS,CAAC;QAEzC,IAAI,CAAC,sBAAsB,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,wBAAwB,GAAG,EAAE,CAAC;QACnC,IAAI,CAAC,2BAA2B,GAAG,CAAC,CAAC,CAAC;IAC1C,CAAC;IAES,KAAK,CAAC,6BAA6B,CACzC,cAAgC,EAChC,WAAmB,OAAO,EAC1B,oBAA4B,CAAC,EAC7B,eAA6B,IAAI;QAEjC,KAAK,MAAM,MAAM,IAAI,cAAc,EAAE;YACjC,IAAI,CAAC,IAAI,CAAC,+BAA+B,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,EAAE;gBAClE,IAAI;oBACA,IAAI,sBAA8C,CAAC;oBAEnD,IAAI,MAAM,CAAC,2BAA2B,EAAE;wBACpC,sBAAsB;4BAClB,MAAM,IAAI,CAAC,cAAc,CAAC,mCAAmC,CACzD,IAAI,CAAC,QAAQ,EACb,MAAM,CAAC,2BAA2B,EAClC,QAAQ,EACR,iBAAiB,EACjB,YAAY,CACf,CAAC;qBACT;oBAED,IAAI,sBAAsB,EAAE;wBACxB,IAAI,YAAY,GAAG,IAAI,CAAC;wBACxB,MAAM,QAAQ,GACV,sBAAsB,CAAC,2BAA2B,CAAC,WAAW,EAAE,CAAC;wBACrE,KAAK,MAAM,MAAM,IAAI,QAAQ,EAAE;4BAC3B,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,EAAE;gCACxB,YAAY,GAAG,KAAK,CAAC;6BACxB;yBACJ;wBAED,IAAI,CAAC,YAAY,EAAE;4BACf,OAAO,CAAC,IAAI,CACR,gEAAgE,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,CAC9F,CAAC;yBACL;wBAED,IAAI,CAAC,+BAA+B,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;4BAC3D,sBAAsB,CAAC;qBAC9B;iBACJ;gBAAC,OAAO,CAAC,EAAE;oBACR,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBACnB;aACJ;SACJ;IACL,CAAC;IAES,yBAAyB,CAAC,IAAU;QAC1C,OAAO,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IACpE,CAAC;IAES,oBAAoB;QAC1B,MAAM,mBAAmB,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC;QACjF,KAAK,MAAM,CAAC,IAAI,mBAAmB,EAAE;YACjC,IAAI,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,qBAAqB,EAAE,OAAO,EAAE;gBAC9C,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;aACZ;iBAAM;gBACH,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;aACX;SACJ;QACD,IAAI,CAAC,mBAAmB,GAAG,mBAAmB,CAAC;QAE/C,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,UAAU,EAAE;YACnC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CAAC;YACxE,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;gBACxB,IAAI,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,qBAAqB,EAAE,OAAO,EAAE;oBAC9C,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;iBACZ;qBAAM;oBACH,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;iBACX;YACL,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,aAAa,GAAG,aAAa,CAAC;SACzC;IACL,CAAC;IAES,mBAAmB;QACzB,4CAA4C;QAC5C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;QAClC,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;CACJ","sourcesContent":["import {MapLatLng} from 'raain-ui';\nimport {\n    GaugeNode,\n    IComparePerDate,\n    ICompares,\n    PositionValue,\n    QualityPoint,\n    RainComputationQuality,\n    RainNode,\n    SpeedMatrix,\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    qualityIndicator: number;\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 globalQualityIndicator: number;\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    // Merged cumulative from granular comparisons (computed from buildCompares)\n    public get granularCumulativePoints(): XYType[] {\n        if (!this.buildCompares?.compareCumulative?.qualityPoints?.length) {\n            return [];\n        }\n        return this.buildCompares.compareCumulative.qualityPoints.map(\n            (qp) => new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId)\n        );\n    }\n\n    public get granularCumulativePointsMax(): XYType {\n        if (!this.buildCompares?.compareCumulative) {\n            return new XYType(0, 0);\n        }\n        const maxValue = Math.max(this.buildCompares.compareCumulative.maxValue * 1.2, 1);\n        return new XYType(maxValue, maxValue);\n    }\n\n    // Default: KGE normalized 0-1 (from raain-model defaults)\n    public get granularCumulativeQualityIndicator(): number {\n        if (!this.buildCompares?.compareCumulative?.qualityPoints?.length) {\n            return null;\n        }\n        return SpeedMatrix.ComputeQualityIndicator(\n            this.buildCompares.compareCumulative.qualityPoints\n        );\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.globalQualityIndicator = null;\n        // granularCumulative* are now getters computed from buildCompares\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                // Default: KGE normalized 0-1\n                const qualityIndicator = SpeedMatrix.ComputeQualityIndicator(c.qualityPoints);\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(Math.max(c.maxValue * 1.2, 1), Math.max(c.maxValue * 1.2, 1)),\n                    comparePointsHistory: c.qualityPointsLegacy,\n                    remarks: c.remarks,\n                    qualityIndicator,\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        period: {begin: Date; end: Date},\n        withCompareDuplicate: boolean,\n        provider: string = 'Raain',\n        timeStepInMinutes: number = 5,\n        timeStepMode: 'eq' | 'lte' = 'eq'\n    ) {\n        try {\n            await this.fetchRainComputationQualities(\n                targetsOrdered,\n                provider,\n                timeStepInMinutes,\n                timeStepMode\n            );\n\n            await this.buildComparesTimeline(targetsOrdered, period, 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 = Math.max(this.buildCompares.compareCumulative.maxValue * 1.2, 1);\n            const cumulativePoints = this.buildCompares.compareCumulative.qualityPoints.map(\n                (qp) =>\n                    new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId)\n            );\n            const cumulativePointsMax = new XYType(maxValue, maxValue);\n            // Default: KGE normalized 0-1\n            const cumulativeQualityIndicator = SpeedMatrix.ComputeQualityIndicator(\n                this.buildCompares.compareCumulative.qualityPoints\n            );\n\n            // Set for cumulative mode\n            this.globalComparePoints = cumulativePoints;\n            this.globalComparePointsMax = cumulativePointsMax;\n            this.globalQualityIndicator = cumulativeQualityIndicator;\n            // granularCumulative* are now getters computed from buildCompares.compareCumulative\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<\n            string,\n            {id: string; latitude: number; longitude: number; name: string}\n        >();\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        period: {begin: Date; end: Date},\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?.length > 1 ? compareDates : [period.begin, period.end];\n        if (this.compareDates[0].getTime() > period.begin.getTime()) {\n            this.compareDates.unshift(period.begin);\n        }\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        provider: string = 'Raain',\n        timeStepInMinutes: number = 5,\n        timeStepMode: 'eq' | 'lte' = 'eq'\n    ) {\n        for (const target of targetsOrdered) {\n            if (!this.rainComputationQualitiesPerDate[target.date.toISOString()]) {\n                try {\n                    let rainComputationQuality: RainComputationQuality;\n\n                    if (target.rainComputationCumulativeId) {\n                        rainComputationQuality =\n                            await this.profileService.getRainCumulativeCumulativesCompare(\n                                this.rainNode,\n                                target.rainComputationCumulativeId,\n                                provider,\n                                timeStepInMinutes,\n                                timeStepMode\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"]}
@@ -1469,7 +1469,7 @@ class CompareManager {
1469
1469
  if (!((_a = this.buildCompares) === null || _a === void 0 ? void 0 : _a.compareCumulative)) {
1470
1470
  return new XYType(0, 0);
1471
1471
  }
1472
- const maxValue = this.buildCompares.compareCumulative.maxValue * 1.2;
1472
+ const maxValue = Math.max(this.buildCompares.compareCumulative.maxValue * 1.2, 1);
1473
1473
  return new XYType(maxValue, maxValue);
1474
1474
  }
1475
1475
  // Default: KGE normalized 0-1 (from raain-model defaults)
@@ -1531,7 +1531,7 @@ class CompareManager {
1531
1531
  date: c.date,
1532
1532
  name: c.name,
1533
1533
  comparePoints: c.qualityPoints.map((p) => new XYType(p.getGaugeValue(), p.getRainValue(), 2, p.gaugeLabel, p.gaugeId)),
1534
- comparePointsMax: new XYType(c.maxValue * 1.2, c.maxValue * 1.2),
1534
+ comparePointsMax: new XYType(Math.max(c.maxValue * 1.2, 1), Math.max(c.maxValue * 1.2, 1)),
1535
1535
  comparePointsHistory: c.qualityPointsLegacy,
1536
1536
  remarks: c.remarks,
1537
1537
  qualityIndicator,
@@ -1559,7 +1559,7 @@ class CompareManager {
1559
1559
  return;
1560
1560
  }
1561
1561
  const countForAverage = targetsOrdered.length;
1562
- const maxValue = this.buildCompares.compareCumulative.maxValue * 1.2;
1562
+ const maxValue = Math.max(this.buildCompares.compareCumulative.maxValue * 1.2, 1);
1563
1563
  const cumulativePoints = this.buildCompares.compareCumulative.qualityPoints.map((qp) => new XYType(qp.getGaugeValue(), qp.getRainValue(), 2, qp.gaugeLabel, qp.gaugeId));
1564
1564
  const cumulativePointsMax = new XYType(maxValue, maxValue);
1565
1565
  // Default: KGE normalized 0-1
@@ -2976,8 +2976,7 @@ class ProfileService {
2976
2976
  // Merge additional qualities (lte mode returns multiple freq groups)
2977
2977
  for (let i = 1; i < allQualities.length; i++) {
2978
2978
  const extra = new RainComputationQuality(allQualities[i]);
2979
- extra.qualitySpeedMatrixContainer =
2980
- SpeedMatrixContainer.CreateFromJson(extra.qualitySpeedMatrixContainer);
2979
+ extra.qualitySpeedMatrixContainer = SpeedMatrixContainer.CreateFromJson(extra.qualitySpeedMatrixContainer);
2981
2980
  rainComputationQuality.merge(extra);
2982
2981
  }
2983
2982
  return rainComputationQuality;