"use client"; import { useState } from "react"; import { LineChart, Line, BarChart, Bar, Cell, XAxis, YAxis, CartesianGrid, Tooltip, Legend, ResponsiveContainer, ComposedChart, Area, } from "recharts"; import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card"; import { Tabs, TabsContent, TabsList, TabsTrigger } from "@/components/ui/tabs"; import type { PriceData, PriceStats } from "@/lib/types"; interface PriceChartProps { priceData: PriceData[]; priceStats: PriceStats; ticker: string; } export function PriceChart({ priceData, priceStats, ticker }: PriceChartProps) { const [chartType, setChartType] = useState<"line" | "candlestick">("line"); // 格式化數字 const formatNumber = (num: number) => { return num.toLocaleString('zh-TW', { minimumFractionDigits: 2, maximumFractionDigits: 2 }); }; // 格式化日期(只顯示月-日) const formatDate = (dateStr: string) => { const date = new Date(dateStr); return `${date.getMonth() + 1}/${date.getDate()}`; }; return (
{ticker} 價格走勢 setChartType(v as "line" | "candlestick")}> 折線圖 K線圖
{/* 統計資訊 */}

增長率

= 0 ? 'text-green-600' : 'text-red-600'}`}> {priceStats.growth_rate >= 0 ? '+' : ''}{priceStats.growth_rate}%

時長

{priceStats.duration_days} 天

起始價格

${formatNumber(priceStats.start_price)}

{priceStats.start_date}

結束價格

${formatNumber(priceStats.end_price)}

{priceStats.end_date}

{/* 價格圖表 */}

價格走勢

{chartType === "line" ? ( `$${value.toFixed(0)}`} /> [`$${formatNumber(value)}`, '收盤價']} labelFormatter={(label) => `日期: ${label}`} /> ) : ( // K線圖:簡化版實現 `$${value.toFixed(0)}`} /> { if (active && payload && payload.length) { const data = payload[0].payload; const isUp = data.Close >= data.Open; return (

日期: {data.Date}

開: ${formatNumber(data.Open)}

收: ${formatNumber(data.Close)}

高: ${formatNumber(data.High)}

低: ${formatNumber(data.Low)}

{isUp ? '↑ 上漲' : '↓ 下跌'} ${formatNumber(Math.abs(data.Close - data.Open))}

); } return null; }} /> {/* 使用 Bar 顯示收盤價,顏色根據漲跌決定 */} {priceData.map((entry: any, index: number) => ( = entry.Open ? '#22c55e' : '#ef4444'} /> ))}
)}
{/* 交易量圖表 */}

交易量

{ if (value >= 1000000) return `${(value / 1000000).toFixed(1)}M`; if (value >= 1000) return `${(value / 1000).toFixed(1)}K`; return value.toString(); }} /> [value.toLocaleString(), '交易量']} labelFormatter={(label) => `日期: ${label}`} />
); }