f7cef30b9c
补齐订单、优惠券、主题、插件、公告与支付管理页面, 接入对应后台接口、路由入口与工具层类型定义。 同时修复套餐页开关初始化误写问题,避免浏览即触发写操作。 在订阅协议侧为 Stash 导出增加 AnyTLS 版本守卫, 未知版本或低于 3.3.0 时不再导出该协议,并补充回归测试与知识记录。
4.9 KiB
4.9 KiB
变更提案: admin-frontend-notice-management
元信息
类型: 功能开发
方案类型: 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一致,不在前端猜测额外接口。
约束条件
范围约束: 仅实现公告管理工作台,不扩展插件/主题/支付/知识库等其他系统模块
技术约束: 继续使用 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. 方案
页面结构
- 延续系统配置/套餐管理的 Apple 风格后台结构,顶部保留黑色 hero,右侧展示公告统计摘要。
- 主工作区使用白色表格容器,头部提供“添加公告”“搜索公告标题”“编辑排序”。
- 编辑公告使用
ElDialog弹窗,参考用户截图采用“标题 + 公告内容 + 公告背景 + 节点标签 + 显示开关”的集中编辑方式。 - 排序使用独立对话框,通过上移/下移维护本地顺序,再提交到
/notice/sort。
前端实现策略
- 在
src/types/api.d.ts新增公告类型,明确列表项与保存载荷结构。 - 在
src/api/admin.ts新增公告管理 API 封装:fetchNotices / saveNotice / toggleNoticeVisibility / deleteNotice / sortNotices。 - 在
src/utils/notices.ts下沉公告筛选、标签归一化、表单回填、排序移动等逻辑,避免页面组件膨胀。 - 新增:
src/views/system/SystemNoticesView.vuesrc/views/system/SystemNoticeEditorDialog.vuesrc/views/system/SystemNoticeEditorDialog.scss
- 将路由
/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 开关初始渲染误触发写操作的回归。