feat(admin-frontend): 完成订阅与系统管理真实工作台

补齐订单、优惠券、主题、插件、公告与支付管理页面,
接入对应后台接口、路由入口与工具层类型定义。
同时修复套餐页开关初始化误写问题,避免浏览即触发写操作。

在订阅协议侧为 Stash 导出增加 AnyTLS 版本守卫,
未知版本或低于 3.3.0 时不再导出该协议,并补充回归测试与知识记录。
This commit is contained in:
yinjianm
2026-04-24 16:52:41 +08:00
parent 16203b14f6
commit f7cef30b9c
89 changed files with 11122 additions and 92 deletions
@@ -0,0 +1,11 @@
{
"status": "completed",
"completed": 5,
"failed": 0,
"pending": 0,
"total": 5,
"done": 5,
"percent": 100,
"current": "公告管理真实工作台、构建验证与知识库同步已完成,等待用户验收",
"updated_at": "2026-04-24 16:09:00"
}
@@ -0,0 +1,51 @@
{
"updatedAt": "2026-04-24T07:55:06.613Z",
"version": 1,
"source": "R2",
"originCommand": "design",
"verifyMode": "review-first",
"reviewerFocus": [
"公告管理页面是否延续当前 Apple 风格后台的黑色 hero 与白色工作台结构",
"列表、编辑弹窗与排序模式是否覆盖用户要求的完整 CRUD 工作台",
"其余系统管理入口是否仍保持当前边界不被误改"
],
"testerFocus": [
"公告列表是否真实连接 /notice/fetch",
"新增编辑是否真实连接 /notice/save,显隐是否连接 /notice/show,删除是否连接 /notice/drop",
"排序模式是否真实调用 /notice/sort 且 admin-frontend 构建通过"
],
"ui": {
"required": true,
"designContract": true,
"sourcePriority": [
"plan.md",
".helloagents/DESIGN.md",
"hello-ui"
],
"styleAdvisor": {
"required": false,
"reason": "",
"focus": []
},
"visualValidation": {
"required": true,
"reason": "公告管理属于真实后台 CRUD 页,需要确认列表、编辑弹窗与排序模式在浏览器中符合 Apple 风格后台契约",
"screens": [
"#/system/notices desktop",
"#/system/notices editor dialog",
"#/system/notices sort dialog"
],
"states": [
"公告列表加载完成态",
"新增/编辑弹窗态",
"排序编辑态"
]
}
},
"advisor": {
"required": false,
"reason": "",
"focus": [],
"preferredSources": []
}
}
@@ -0,0 +1,90 @@
# 变更提案: admin-frontend-notice-management
## 元信息
```yaml
类型: 功能开发
方案类型: implementation
优先级: P1
状态: 已完成
创建: 2026-04-24
```
---
## 1. 需求
### 背景
用户要求继续完成 `admin-frontend` 的“公告管理”模块,并明确选择“完整 CRUD 工作台”方案。当前 `/system/notices` 仍是占位页,但 Laravel 后端已存在 `notice/fetch``notice/save``notice/show``notice/drop``notice/sort` 管理接口,可直接承接真实公告管理工作流。
### 目标
-`#/system/notices` 从占位页升级为真实可用的公告管理页。
- 提供符合当前 Apple 风格后台体系的公告列表、搜索、显隐切换、编辑弹窗、删除与排序能力。
- 保持前后端字段契约与现有 `NoticeController` / `NoticeSave` 一致,不在前端猜测额外接口。
### 约束条件
```yaml
范围约束: 仅实现公告管理工作台,不扩展插件/主题/支付/知识库等其他系统模块
技术约束: 继续使用 Vue3 + TypeScript + Element Plus,不新增第三方编辑器依赖
业务约束: 公告保存字段以 title/content/img_url/tags/show/popup/id 为准;排序继续调用 /notice/sort
视觉约束: 延续 apple/DESIGN.md 与 .helloagents/DESIGN.md 的黑色 hero + 白色工作台 + 克制蓝色交互体系
```
### 验收标准
- [ ] `#/system/notices` 可真实拉取公告列表,并显示 ID、显隐状态、标题与操作列。
- [ ] 页面支持标题关键词搜索,筛选后结果与计数同步更新。
- [ ] 支持新增/编辑公告,字段覆盖标题、内容、背景图、标签、显示状态与弹窗公告开关。
- [ ] 支持删除公告与显隐切换,并给出明确成功/失败反馈。
- [ ] 支持独立排序模式,保存后调用 `/notice/sort` 同步顺序。
- [ ] `admin-frontend` 执行 `npm run build` 通过。
---
## 2. 方案
### 页面结构
1. 延续系统配置/套餐管理的 Apple 风格后台结构,顶部保留黑色 hero,右侧展示公告统计摘要。
2. 主工作区使用白色表格容器,头部提供“添加公告”“搜索公告标题”“编辑排序”。
3. 编辑公告使用 `ElDialog` 弹窗,参考用户截图采用“标题 + 公告内容 + 公告背景 + 节点标签 + 显示开关”的集中编辑方式。
4. 排序使用独立对话框,通过上移/下移维护本地顺序,再提交到 `/notice/sort`
### 前端实现策略
1.`src/types/api.d.ts` 新增公告类型,明确列表项与保存载荷结构。
2.`src/api/admin.ts` 新增公告管理 API 封装:`fetchNotices / saveNotice / toggleNoticeVisibility / deleteNotice / sortNotices`
3.`src/utils/notices.ts` 下沉公告筛选、标签归一化、表单回填、排序移动等逻辑,避免页面组件膨胀。
4. 新增:
- `src/views/system/SystemNoticesView.vue`
- `src/views/system/SystemNoticeEditorDialog.vue`
- `src/views/system/SystemNoticeEditorDialog.scss`
5. 将路由 `/system/notices` 指向真实页面,保留其他系统入口占位不变。
### 风险评估
| 风险 | 等级 | 应对 |
|------|------|------|
| 后端 `show` / `popup` 可能返回 `0/1` | 中 | 前端统一布尔归一化,提交时再按接口兼容输出 |
| 公告内容编辑器缺少富文本能力 | 低 | 本轮延续轻量文本/Markdown 输入策略,优先保证 CRUD 与数据流闭环 |
| 构建会刷新 `public/assets/admin` 子模块产物 | 中 | 仅执行 `admin-frontend` 构建验证,不代做子模块发布 |
---
## 3. 技术决策
### admin-frontend-notice-management#D001: 公告管理采用“真实列表页 + 独立编辑弹窗 + 独立排序对话框”
**日期**: 2026-04-24
**状态**: ✅采纳
**背景**: 用户明确要求对齐截图所表达的后台管理工作台体验。
**决策**: 列表与行操作保留在主页面,新增/编辑使用集中弹窗,排序单独进入对话框处理。
**理由**: 最符合当前后台已有套餐管理模式,也能覆盖截图中的核心操作链路。
### admin-frontend-notice-management#D002: 公告内容编辑延续轻量文本输入,不引入新的富文本依赖
**日期**: 2026-04-24
**状态**: ✅采纳
**背景**: 现有 `admin-frontend` 已尽量控制依赖规模,且后端只要求标题/内容/图片/标签等基本字段。
**决策**: 本轮使用增强型 textarea 输入公告内容,并保留 Markdown 友好提示,不新增第三方富文本编辑器。
**理由**: 优先完成真实 CRUD 与可维护数据流,避免为了富文本皮层扩大实现成本。
### admin-frontend-notice-management#D003: 公告显隐与弹窗开关在前端统一做布尔归一化
**日期**: 2026-04-24
**状态**: ✅采纳
**背景**: 后台现有开关型字段历史上存在 `0/1` 与布尔混用情况。
**决策**: 拉取、回填和提交前都通过工具层统一归一化 `show / popup / tags`
**理由**: 可避免再次出现 Element Plus 开关初始渲染误触发写操作的回归。
@@ -0,0 +1,43 @@
# 任务清单: admin-frontend-notice-management
> **@status:** completed | 2026-04-24 16:09
```yaml
@feature: admin-frontend-notice-management
@created: 2026-04-24
@status: completed
@mode: R2
```
## 进度概览
| 完成 | 失败 | 跳过 | 总数 |
|------|------|------|------|
| 5 | 0 | 0 | 5 |
---
## 任务列表
- [√] 1. 读取公告管理相关前后端代码、类型与 UI 模式,冻结本轮实现边界
- [√] 2. 新增公告管理 API、类型定义与工具函数,统一字段归一化/排序/表单转换
- [√] 3. 实现真实公告管理页面与编辑弹窗,接通搜索、显隐、删除、新增/编辑工作流
- [√] 4. 实现公告排序模式并将 `/system/notices` 路由切换到真实页面
- [√] 5. 运行 `admin-frontend` 构建验证,并同步 `.helloagents` 文档与交付记录
---
## 执行日志
| 时间 | 任务 | 状态 | 备注 |
|------|------|------|------|
| 2026-04-24 15:55 | 方案包初始化 | completed | 已确认本轮采用完整 CRUD 工作台方案,目标对齐 `/notice/*` 后端接口与用户截图 |
| 2026-04-24 16:04 | 页面实现 | completed | 已补齐公告 API、类型、工具层、真实列表页、编辑弹窗与排序模式 |
| 2026-04-24 16:08 | 构建与知识同步 | completed | `admin-frontend` 执行 `npm run build` 通过,并已更新 context/module/changelog 记录 |
---
## 执行备注
- 其余系统模块(插件/主题/支付/知识库)继续保持当前占位页,不在本轮展开。
- 构建验证会刷新 `public/assets/admin` 子模块产物,本轮仅提供功能实现与验证证据,不自动代做发布。