From 3d4d862d73daa5d3ada53e9536c9fbbff13b49e9 Mon Sep 17 00:00:00 2001 From: kkfluous Date: Wed, 29 Apr 2026 20:10:27 +0800 Subject: [PATCH] =?UTF-8?q?feat(energy):=20=E6=B0=A2=E8=83=BD=E6=80=BB?= =?UTF-8?q?=E8=A7=88=E5=88=A0=E9=99=A4=204=20=E5=BC=A0=20KPI=20=E5=8D=A1?= =?UTF-8?q?=EF=BC=8C=E5=BA=95=E9=83=A8=E5=8A=A0=E5=8A=A8=E6=80=81=E5=B9=BD?= =?UTF-8?q?=E9=BB=98=E6=8F=90=E7=A4=BA?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - 删除:年加氢量 / 年加氢费 / 累计羚牛承担 / 本月-今日 四张顶部 KPI 卡 (及对应的 Skeleton 占位、未用的 Fuel/Wallet/Coins/CalendarClock import 与 fmt 工具函数) - 新增 RotatingFooterHint:底部居中蓝色脉冲点 + 6 条幽默文案 4s 轮换淡入 例如「更多统计维度接入中,欢迎您的建议 ~」「数据科学家正在深夜挖掘新维度…」 Co-Authored-By: Claude Opus 4.7 (1M context) --- src/modules/energy/HydrogenOverview.tsx | 105 ++++++++---------------- 1 file changed, 36 insertions(+), 69 deletions(-) diff --git a/src/modules/energy/HydrogenOverview.tsx b/src/modules/energy/HydrogenOverview.tsx index e7a26fb..3f2c963 100644 --- a/src/modules/energy/HydrogenOverview.tsx +++ b/src/modules/energy/HydrogenOverview.tsx @@ -1,5 +1,4 @@ import { useEffect, useState } from 'react'; -import { Fuel, Wallet, Coins, CalendarClock } from 'lucide-react'; import { BarChart, Bar, XAxis, YAxis, ResponsiveContainer, Cell, PieChart, Pie, Tooltip, LabelList } from 'recharts'; import { fetchHydrogenOverview, type HydrogenOverviewResponse } from './api'; @@ -30,16 +29,15 @@ const REGION_COLORS = [ '#94a3b8', ]; -function fmtKg(kg: number) { - if (kg >= 1000) return `${(kg / 1000).toFixed(2)}T`; - return `${kg.toFixed(2)}Kg`; -} -function fmtYuanWan(yuan: number) { - return `¥${(yuan / 10_000).toFixed(2)}万`; -} -function fmtYuan(yuan: number) { - return `¥${yuan.toLocaleString('zh-CN', { maximumFractionDigits: 2 })}`; -} +// 幽默动态提示词,每 4 秒轮换一条 +const FOOTER_HINTS = [ + '更多统计维度接入中,欢迎您的建议 ~', + '下一个图表,可能就是您建议的那个', + '数据科学家正在深夜挖掘新维度…', + '想看哪个角度的数据?告诉我们一下嘛', + '维度灵感正在路上,钉一下产品同学也行', + '数字背后还有故事,等下一次上线揭晓', +]; export default function HydrogenOverview() { const [data, setData] = useState(null); @@ -67,50 +65,6 @@ export default function HydrogenOverview() {
数据自 2025-01-01 起,每 1 分钟更新
-
- {/* 卡 1:年加氢量 */} -
-
- 年加氢量 -
-
{fmtKg(k.yearKg)}
-
- {/* 卡 2:年加氢费 */} -
-
- 年加氢费 -
-
{fmtYuanWan(k.yearFee)}
-
- {/* 卡 3:累计羚牛承担 */} -
-
- 累计羚牛承担 -
-
{fmtYuanWan(k.lingniuBornFee)}
-
-
{fmtKg(k.lingniuBornKg)}
-
-
- {/* 卡 4:本月 / 今日 */} -
-
- 本月 / 今日 -
-
-
-
本月
-
{fmtKg(k.monthKg)}
-
{fmtYuanWan(k.monthFee)}
-
-
-
今日
-
{fmtKg(k.todayKg)}
-
{fmtYuan(k.todayFee)}
-
-
-
-
{/* Top5 加氢站 */}
@@ -194,6 +148,33 @@ export default function HydrogenOverview() {
+ + + ); +} + +function RotatingFooterHint() { + const [idx, setIdx] = useState(0); + useEffect(() => { + const t = setInterval(() => setIdx(i => (i + 1) % FOOTER_HINTS.length), 4000); + return () => clearInterval(t); + }, []); + return ( +
+ + + {FOOTER_HINTS[idx]} + +
); } @@ -206,20 +187,6 @@ function HydrogenOverviewSkeleton() {
- {/* 4 张 KPI 卡 */} -
- {Array.from({ length: 4 }).map((_, i) => ( -
-
-
-
-
-
-
-
- ))} -
-
{/* Top5 占位 */}