Browse Source

feat: split holdings in chart dynamically

pull/3938/head
vitalymatyushik 10 months ago
committed by Thomas Kaul
parent
commit
bfc20a4b79
  1. 96
      libs/ui/src/lib/treemap-chart/treemap-chart.component.ts

96
libs/ui/src/lib/treemap-chart/treemap-chart.component.ts

@ -86,7 +86,32 @@ export class GfTreemapChartComponent
this.isLoading = true; this.isLoading = true;
const { endDate, startDate } = getIntervalFromDateRange(this.dateRange); const { endDate, startDate } = getIntervalFromDateRange(this.dateRange);
const netPerformancePercentsWithCurrencyEffect = this.holdings.map((h) =>
getAnnualizedPerformancePercent({
daysInMarket: differenceInDays(
endDate,
max([h.dateOfFirstActivity ?? new Date(0), startDate])
),
netPerformancePercentage: new Big(
h.netPerformancePercentWithCurrencyEffect
)
}).toNumber()
);
const positiveNetPercents = netPerformancePercentsWithCurrencyEffect.filter(
(v) => v > 0
);
const positiveNetPercentsRange = {
max: Math.max(...positiveNetPercents),
min: Math.min(...positiveNetPercents)
};
const negativeNetPercents = netPerformancePercentsWithCurrencyEffect.filter(
(v) => v < 0
);
const negativeNetPercentsRange = {
max: Math.max(...negativeNetPercents),
min: Math.min(...negativeNetPercents)
};
const data: ChartConfiguration['data'] = { const data: ChartConfiguration['data'] = {
datasets: [ datasets: [
{ {
@ -104,7 +129,6 @@ export class GfTreemapChartComponent
ctx.raw._data.netPerformancePercentWithCurrencyEffect ctx.raw._data.netPerformancePercentWithCurrencyEffect
) )
}).toNumber(); }).toNumber();
// Round to 2 decimal places // Round to 2 decimal places
annualizedNetPerformancePercentWithCurrencyEffect = annualizedNetPerformancePercentWithCurrencyEffect =
Math.round( Math.round(
@ -112,47 +136,59 @@ export class GfTreemapChartComponent
) / 100; ) / 100;
if ( if (
annualizedNetPerformancePercentWithCurrencyEffect > Math.abs(annualizedNetPerformancePercentWithCurrencyEffect) === 0
0.03 * GfTreemapChartComponent.HEAT_MULTIPLIER ) {
annualizedNetPerformancePercentWithCurrencyEffect = Math.abs(
annualizedNetPerformancePercentWithCurrencyEffect
);
return gray[3];
}
if (annualizedNetPerformancePercentWithCurrencyEffect > 0) {
const range =
positiveNetPercentsRange.max - positiveNetPercentsRange.min;
if (
annualizedNetPerformancePercentWithCurrencyEffect >=
positiveNetPercentsRange.max - range * 0.25
) { ) {
return green[9]; return green[9];
} else if ( }
annualizedNetPerformancePercentWithCurrencyEffect > if (
0.02 * GfTreemapChartComponent.HEAT_MULTIPLIER annualizedNetPerformancePercentWithCurrencyEffect >=
positiveNetPercentsRange.max - range * 0.5
) { ) {
return green[7]; return green[7];
} else if ( }
annualizedNetPerformancePercentWithCurrencyEffect > if (
0.01 * GfTreemapChartComponent.HEAT_MULTIPLIER annualizedNetPerformancePercentWithCurrencyEffect >=
positiveNetPercentsRange.max - range * 0.75
) { ) {
return green[5]; return green[5];
} else if (annualizedNetPerformancePercentWithCurrencyEffect > 0) { }
return green[3]; return green[3];
} else if ( }
Math.abs(annualizedNetPerformancePercentWithCurrencyEffect) === 0
) { const range =
annualizedNetPerformancePercentWithCurrencyEffect = Math.abs( negativeNetPercentsRange.min - negativeNetPercentsRange.max;
annualizedNetPerformancePercentWithCurrencyEffect if (
); annualizedNetPerformancePercentWithCurrencyEffect <=
return gray[3]; negativeNetPercentsRange.min + range * 0.25
} else if (
annualizedNetPerformancePercentWithCurrencyEffect >
-0.01 * GfTreemapChartComponent.HEAT_MULTIPLIER
) { ) {
return red[3]; return red[9];
} else if ( }
annualizedNetPerformancePercentWithCurrencyEffect > if (
-0.02 * GfTreemapChartComponent.HEAT_MULTIPLIER annualizedNetPerformancePercentWithCurrencyEffect <=
negativeNetPercentsRange.min + range * 0.5
) { ) {
return red[5]; return red[7];
} else if ( }
annualizedNetPerformancePercentWithCurrencyEffect > if (
-0.03 * GfTreemapChartComponent.HEAT_MULTIPLIER annualizedNetPerformancePercentWithCurrencyEffect <=
negativeNetPercentsRange.min + range * 0.75
) { ) {
return red[7]; return red[7];
} else {
return red[9];
} }
return red[9];
}, },
borderRadius: 4, borderRadius: 4,
key: 'allocationInPercentage', key: 'allocationInPercentage',

Loading…
Cancel
Save