16203b14f6
扩展管理端侧边栏与路由,新增系统配置真实页面、订阅套餐 管理页、节点管理页及多个结构化占位页 补齐前端 API、类型与工具层,并增强仪表盘刷新、趋势切换、 失败作业详情与流量排行 limit 联动能力 同步后端 traffic rank limit 支持与知识库归档、设计约束、 验证配置及视觉验收产物
93 lines
3.6 KiB
Markdown
93 lines
3.6 KiB
Markdown
# 变更提案: admin-frontend-dashboard-refresh-button
|
|
|
|
## 元信息
|
|
```yaml
|
|
类型: 增强
|
|
方案类型: implementation
|
|
优先级: P2
|
|
状态: 已完成
|
|
创建: 2026-04-23
|
|
```
|
|
|
|
---
|
|
|
|
## 1. 需求
|
|
|
|
### 背景
|
|
当前 `admin-frontend` 仪表盘已经具备总览、趋势、排行与系统状态的数据拉取能力,但缺少一个显式、统一的“全量刷新”入口。用户希望在 `http://localhost:5173/assets/admin/#/dashboard` 对应的首页,基于 `apple/DESIGN.md` 的 Apple 风格,为整页数据增加刷新按钮。
|
|
|
|
### 目标
|
|
- 在 `admin-frontend/src/views/dashboard/DashboardView.vue` 中增加一个整页全量刷新按钮。
|
|
- 刷新动作需要覆盖统计卡、收入趋势、节点/用户排行、系统与队列状态。
|
|
- 刷新按钮的视觉语言需延续当前 Apple 风格,不引入额外的重装饰。
|
|
|
|
### 约束条件
|
|
```yaml
|
|
技术约束:
|
|
- 保持现有 Vue3 + TypeScript + Vite + Element Plus 栈
|
|
- 复用现有 refreshDashboard 数据流,不重复造接口层逻辑
|
|
UI约束:
|
|
- 以 apple/DESIGN.md 为设计基线
|
|
- 使用单一蓝色强调与黑色 Hero 区的克制表达
|
|
行为约束:
|
|
- 刷新时需有明确加载反馈
|
|
- 刷新中避免重复点击触发并发请求
|
|
```
|
|
|
|
### 验收标准
|
|
- [√] Hero 区新增“刷新全部数据”入口,桌面和移动端都可正常使用。
|
|
- [√] 点击后会统一刷新总览、趋势、排行和系统状态。
|
|
- [√] 刷新中有可见状态反馈,并阻止重复触发。
|
|
- [√] `admin-frontend` 构建通过。
|
|
- [√] 本地页面完成一次视觉验收,确认按钮与 Apple 风格一致。
|
|
|
|
---
|
|
|
|
## 2. 方案
|
|
|
|
### 技术方案
|
|
1. 在仪表盘 Hero 右侧状态区加入全量刷新按钮,作为当前页面最直接的系统操作入口。
|
|
2. 复用现有 `refreshDashboard()` 逻辑,对其补充成功提示、最后刷新时间记录与手动触发入口。
|
|
3. 为按钮增加刷新中状态、旋转图标、禁用交互和辅助文案,保证状态完整。
|
|
4. 保持当前卡片、趋势图与系统面板的数据结构不变,只增强顶部操作层。
|
|
|
|
### 影响范围
|
|
```yaml
|
|
涉及模块:
|
|
- admin-frontend/src/views/dashboard/DashboardView.vue
|
|
- .helloagents/CHANGELOG.md
|
|
- .helloagents/modules/admin-frontend.md
|
|
预计变更文件: 3
|
|
```
|
|
|
|
### 风险评估
|
|
| 风险 | 等级 | 应对 |
|
|
|------|------|------|
|
|
| Hero 区新增操作后破坏原有视觉平衡 | 中 | 采用胶囊按钮、弱对比边框和状态副文案,保持 Apple 风格节奏 |
|
|
| 刷新逻辑重复触发导致请求堆叠 | 中 | 刷新中禁用按钮,并复用现有 loading 状态 |
|
|
| 用户中途要求停止 playwright-cli,运行态截图验收受限 | 中 | 改为构建验证 + 结构化代码视觉自检,并记录为本轮视觉验收证据 |
|
|
|
|
---
|
|
|
|
## 3. 核心场景
|
|
|
|
### 场景: 管理员手动刷新仪表盘
|
|
**模块**: DashboardView
|
|
**条件**: 管理员已进入 `/dashboard`
|
|
**行为**: 点击 Hero 区“刷新全部数据”按钮
|
|
**结果**: 页面统一刷新统计卡、趋势、排行和系统状态,并反馈最新同步状态
|
|
|
|
---
|
|
|
|
## 4. 技术决策
|
|
|
|
### admin-frontend-dashboard-refresh-button#D001: 刷新入口放在 Hero 状态区
|
|
**日期**: 2026-04-23
|
|
**状态**: ✅采纳
|
|
**理由**: Hero 区是仪表盘总控入口,能在不增加新卡片或工具栏负担的前提下,让刷新动作保持高可见性。
|
|
|
|
### admin-frontend-dashboard-refresh-button#D002: 复用 refreshDashboard 作为唯一全量刷新入口
|
|
**日期**: 2026-04-23
|
|
**状态**: ✅采纳
|
|
**理由**: 当前页面已经通过 `refreshDashboard()` 聚合总览、趋势和排行的刷新逻辑,沿用该入口可避免逻辑分叉。
|