From 1fd9b6d3aa3bd206e402bba78484bf8e6f956222 Mon Sep 17 00:00:00 2001 From: askhogan Date: Fri, 25 Oct 2024 04:50:07 -0700 Subject: [PATCH] feat: Add y-axis label support to chart rendering - Implemented y-axis label functionality to ensure charts display corresponding labels. - Previously, charts had hover values but no y-axis label, causing confusion when interpreting data. - This update improves clarity and readability by providing labeled y-axes alongside interactive hover values. --- .../app/api/finance/route.ts | 3 ++ .../components/ChartRenderer.tsx | 45 +++++++++++++++++++ financial-data-analyst/types/chart.ts | 1 + 3 files changed, 49 insertions(+) diff --git a/financial-data-analyst/app/api/finance/route.ts b/financial-data-analyst/app/api/finance/route.ts index 4b990bda..41c60b73 100644 --- a/financial-data-analyst/app/api/finance/route.ts +++ b/financial-data-analyst/app/api/finance/route.ts @@ -73,6 +73,7 @@ const tools: ToolSchema[] = [ footer: { type: "string" as const }, totalLabel: { type: "string" as const }, xAxisKey: { type: "string" as const }, + yAxisKey: { type: "string" as const }, }, required: ["title", "description"], }, @@ -270,6 +271,7 @@ For Time-Series (Line/Bar/Area): ], config: { xAxisKey: "period", + yAxisKey: "sales", title: "Quarterly Revenue", description: "Revenue growth over time" }, @@ -286,6 +288,7 @@ For Comparisons (MultiBar): ], config: { xAxisKey: "category", + yAxisKey: "sales", title: "Product Performance", description: "Sales vs Costs by Product" }, diff --git a/financial-data-analyst/components/ChartRenderer.tsx b/financial-data-analyst/components/ChartRenderer.tsx index 66c7d05a..6da38576 100644 --- a/financial-data-analyst/components/ChartRenderer.tsx +++ b/financial-data-analyst/components/ChartRenderer.tsx @@ -22,6 +22,7 @@ import { Pie, PieChart, XAxis, + YAxis } from "recharts"; import { ChartContainer, @@ -54,6 +55,17 @@ function BarChartComponent({ data }: { data: ChartData }) { : value; }} /> + { + return value.length > 20 + ? `${value.substring(0, 17)}...` + : value; + }} + /> } @@ -110,6 +122,17 @@ function MultiBarChartComponent({ data }: { data: ChartData }) { : value; }} /> + { + return value.length > 20 + ? `${value.substring(0, 17)}...` + : value; + }} + /> } @@ -176,6 +199,17 @@ function LineChartComponent({ data }: { data: ChartData }) { : value; }} /> + { + return value.length > 20 + ? `${value.substring(0, 17)}...` + : value; + }} + /> } @@ -342,6 +376,17 @@ function AreaChartComponent({ : value; }} /> + { + return value.length > 20 + ? `${value.substring(0, 17)}...` + : value; + }} + /> >; chartConfig: ChartConfig;