From c4a9cad1c50e89365e2a58b50e259af642ed3b8c Mon Sep 17 00:00:00 2001
From: Codex Assistant <codex@example.com>
Date: 星期二, 07 十月 2025 16:12:20 +0800
Subject: [PATCH] feat(review): 调整评审详情展示顺序与样式,描述支持多行,项目信息列宽40/60 fix(auth): 登录页与首页循环跳转保护;api.ts 在登录页不再重定向;401分支在登录页不跳转 fix(router): /login 放行策略优化,避免死循环;评审列表跳转到 /project-review/:id/detail fix(frontend): 补齐 utils/appConfig.ts,避免启动白屏 fix(review): 详情页提交评分缺少stageId时回退使用项目详情的stageId feat(backend): ActivityPlayerDetailResponse.playerInfo 补充 avatarUrl/avatar,服务组装时填充用户头像 chore(dev): 启动脚本注入本地JWT密钥,重启前后端

---
 web/src/api/dashboard.js |   59 ++++++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 38 insertions(+), 21 deletions(-)

diff --git a/web/src/api/dashboard.js b/web/src/api/dashboard.js
index 90aa3c9..a7adc52 100644
--- a/web/src/api/dashboard.js
+++ b/web/src/api/dashboard.js
@@ -1,7 +1,6 @@
-// Dashboard API
-const GRAPHQL_ENDPOINT = 'http://localhost:8080/api/graphql';
+import { graphqlRequest } from '../config/api'
 
-// GraphQL 鏌ヨ璇彞
+// Dashboard 鎸囨爣鏌ヨ
 const GET_DASHBOARD_STATS_QUERY = `
   query GetDashboardStats {
     dashboardStats {
@@ -11,23 +10,41 @@
       totalJudges
     }
   }
-`;
+`
 
-// API 鍑芥暟
-export const getDashboardStats = async () => {
-  const response = await fetch(GRAPHQL_ENDPOINT, {
-    method: 'POST',
-    headers: {
-      'Content-Type': 'application/json',
-    },
-    body: JSON.stringify({
-      query: GET_DASHBOARD_STATS_QUERY
-    })
-  });
-
-  const result = await response.json();
-  if (result.errors) {
-    throw new Error(result.errors[0].message);
+// 鎶ュ悕瓒嬪娍缁熻
+const GET_REGISTRATION_TREND_QUERY = `
+  query RegistrationTrend($days: Int) {
+    registrationTrend(days: $days) {
+      date
+      count
+    }
   }
-  return result.data.dashboardStats;
-};
\ No newline at end of file
+`
+
+// 鍖哄煙鎶ュ悕缁熻
+const GET_REGION_REGISTRATION_STATS_QUERY = `
+  query RegistrationRegionStats {
+    registrationRegionStats {
+      regionId
+      regionName
+      leafFlag
+      count
+    }
+  }
+`
+
+export const getDashboardStats = async () => {
+  const result = await graphqlRequest(GET_DASHBOARD_STATS_QUERY)
+  return result.data.dashboardStats
+}
+
+export const getRegistrationTrend = async (days = 15) => {
+  const result = await graphqlRequest(GET_REGISTRATION_TREND_QUERY, { days })
+  return result.data.registrationTrend || []
+}
+
+export const getRegionRegistrationStats = async () => {
+  const result = await graphqlRequest(GET_REGION_REGISTRATION_STATS_QUERY)
+  return result.data.registrationRegionStats || []
+}

--
Gitblit v1.8.0