From 6e4758a1831b0f9d55ed56997391b2931f223819 Mon Sep 17 00:00:00 2001 From: vitalymatyushik Date: Sat, 19 Oct 2024 10:39:36 +0200 Subject: [PATCH] Feature/Improve backgrounds in tree map chart (#3938) * Improve backgrounds in tree map chart * Update changelog --- CHANGELOG.md | 4 + .../treemap-chart/treemap-chart.component.ts | 118 ++++++++++++------ 2 files changed, 87 insertions(+), 35 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e08f74559..ccf35095c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## Unreleased +### Changed + +- Improved the backgrounds of the chart of the holdings tab on the home page (experimental) + ### Fixed - Fixed an issue in the carousel component for the testimonial section on the landing page diff --git a/libs/ui/src/lib/treemap-chart/treemap-chart.component.ts b/libs/ui/src/lib/treemap-chart/treemap-chart.component.ts index 7f74a81e1..388f75052 100644 --- a/libs/ui/src/lib/treemap-chart/treemap-chart.component.ts +++ b/libs/ui/src/lib/treemap-chart/treemap-chart.component.ts @@ -57,8 +57,6 @@ export class GfTreemapChartComponent @ViewChild('chartCanvas') chartCanvas: ElementRef; - public static readonly HEAT_MULTIPLIER = 5; - public chart: Chart<'treemap'>; public isLoading = true; @@ -87,6 +85,44 @@ export class GfTreemapChartComponent const { endDate, startDate } = getIntervalFromDateRange(this.dateRange); + const netPerformancePercentsWithCurrencyEffect = this.holdings.map( + ({ dateOfFirstActivity, netPerformancePercentWithCurrencyEffect }) => { + return getAnnualizedPerformancePercent({ + daysInMarket: differenceInDays( + endDate, + max([dateOfFirstActivity ?? new Date(0), startDate]) + ), + netPerformancePercentage: new Big( + netPerformancePercentWithCurrencyEffect + ) + }).toNumber(); + } + ); + + const positiveNetPerformancePercents = + netPerformancePercentsWithCurrencyEffect.filter( + (annualizedNetPerformancePercent) => { + return annualizedNetPerformancePercent > 0; + } + ); + + const positiveNetPerformancePercentsRange = { + max: Math.max(...positiveNetPerformancePercents), + min: Math.min(...positiveNetPerformancePercents) + }; + + const negativeNetPerformancePercents = + netPerformancePercentsWithCurrencyEffect.filter( + (annualizedNetPerformancePercent) => { + return annualizedNetPerformancePercent < 0; + } + ); + + const negativeNetPerformancePercentsRange = { + max: Math.max(...negativeNetPerformancePercents), + min: Math.min(...negativeNetPerformancePercents) + }; + const data: ChartConfiguration['data'] = { datasets: [ { @@ -112,46 +148,58 @@ export class GfTreemapChartComponent ) / 100; if ( - annualizedNetPerformancePercentWithCurrencyEffect > - 0.03 * GfTreemapChartComponent.HEAT_MULTIPLIER - ) { - return green[9]; - } else if ( - annualizedNetPerformancePercentWithCurrencyEffect > - 0.02 * GfTreemapChartComponent.HEAT_MULTIPLIER - ) { - return green[7]; - } else if ( - annualizedNetPerformancePercentWithCurrencyEffect > - 0.01 * GfTreemapChartComponent.HEAT_MULTIPLIER - ) { - return green[5]; - } else if (annualizedNetPerformancePercentWithCurrencyEffect > 0) { - return green[3]; - } else if ( Math.abs(annualizedNetPerformancePercentWithCurrencyEffect) === 0 ) { annualizedNetPerformancePercentWithCurrencyEffect = Math.abs( annualizedNetPerformancePercentWithCurrencyEffect ); return gray[3]; - } else if ( - annualizedNetPerformancePercentWithCurrencyEffect > - -0.01 * GfTreemapChartComponent.HEAT_MULTIPLIER - ) { - return red[3]; - } else if ( - annualizedNetPerformancePercentWithCurrencyEffect > - -0.02 * GfTreemapChartComponent.HEAT_MULTIPLIER - ) { - return red[5]; - } else if ( - annualizedNetPerformancePercentWithCurrencyEffect > - -0.03 * GfTreemapChartComponent.HEAT_MULTIPLIER - ) { - return red[7]; + } else if (annualizedNetPerformancePercentWithCurrencyEffect > 0) { + const range = + positiveNetPerformancePercentsRange.max - + positiveNetPerformancePercentsRange.min; + + if ( + annualizedNetPerformancePercentWithCurrencyEffect >= + positiveNetPerformancePercentsRange.max - range * 0.25 + ) { + return green[9]; + } else if ( + annualizedNetPerformancePercentWithCurrencyEffect >= + positiveNetPerformancePercentsRange.max - range * 0.5 + ) { + return green[7]; + } else if ( + annualizedNetPerformancePercentWithCurrencyEffect >= + positiveNetPerformancePercentsRange.max - range * 0.75 + ) { + return green[5]; + } + + return green[3]; } else { - return red[9]; + const range = + negativeNetPerformancePercentsRange.min - + negativeNetPerformancePercentsRange.max; + + if ( + annualizedNetPerformancePercentWithCurrencyEffect <= + negativeNetPerformancePercentsRange.min + range * 0.25 + ) { + return red[9]; + } else if ( + annualizedNetPerformancePercentWithCurrencyEffect <= + negativeNetPerformancePercentsRange.min + range * 0.5 + ) { + return red[7]; + } else if ( + annualizedNetPerformancePercentWithCurrencyEffect <= + negativeNetPerformancePercentsRange.min + range * 0.75 + ) { + return red[5]; + } + + return red[3]; } }, borderRadius: 4,