Files
yinjianm f7cef30b9c feat(admin-frontend): 完成订阅与系统管理真实工作台
补齐订单、优惠券、主题、插件、公告与支付管理页面,
接入对应后台接口、路由入口与工具层类型定义。
同时修复套餐页开关初始化误写问题,避免浏览即触发写操作。

在订阅协议侧为 Stash 导出增加 AnyTLS 版本守卫,
未知版本或低于 3.3.0 时不再导出该协议,并补充回归测试与知识记录。
2026-04-24 16:52:41 +08:00

48 lines
2.6 KiB
Markdown

# admin-frontend 插件管理首版交付 — 需求
确认后冻结,执行阶段不可修改。如需变更必须回到设计阶段重新确认。
## 核心目标
-`admin-frontend` 中把 `/system/plugins` 从结构化占位页升级为真实插件管理工作台。
- 页面视觉继续遵循 `apple/DESIGN.md` 与当前后台 Apple 化风格,并尽量贴近用户提供的目标截图:顶部搜索 / 分组切换 / 状态筛选 / 上传入口,下方插件卡片列表。
- 让管理员可以在同一页面完成插件浏览、筛选、上传、安装、启用 / 禁用、升级、卸载,以及 README / 配置查看与编辑。
## 功能边界
- 必须接入现有 Laravel 管理接口的真实数据链路:
- `GET /plugin/types`
- `GET /plugin/getPlugins`
- `POST /plugin/upload`
- `POST /plugin/install`
- `POST /plugin/uninstall`
- `POST /plugin/enable`
- `POST /plugin/disable`
- `GET /plugin/config`
- `POST /plugin/config`
- `POST /plugin/upgrade`
- 必须支持:
- 按关键词搜索插件
- 按插件类型切换(全部 / 功能 / 支付方式)
- 按状态筛选(全部 / 已启用 / 已安装未启用 / 未安装 / 可升级)
- 上传 zip 插件包
- 列表中直接执行安装、启用、禁用、升级、卸载动作
- 打开插件详情工作台,查看 README、基础元信息,并对可配置插件进行配置保存
- 必须覆盖加载、空列表、错误、按钮提交中、配置保存成功 / 失败等状态。
## 非目标
- 本轮不实现主题、公告、支付配置、知识库管理的真实 CRUD 页面。
- 本轮不新增或重构 Laravel 插件管理接口。
- 本轮不接入浏览器端拖拽上传、批量操作或插件市场远程下载能力。
- 本轮不修改 `public/assets/admin` 子模块之外的发布流程。
## 技术约束
- 技术栈固定为 `Vue 3 + TypeScript + Vite + Element Plus`
- 后端真相源以现有 `PluginController` / `PluginConfigService` / `PluginManager` 为准,不在前端猜测额外字段。
- 视觉契约优先级:本方案 > `.helloagents/DESIGN.md` > `apple/DESIGN.md` 参考原则。
- 构建验证使用 `admin-frontend/package.json` 中已有 `npm run build`
## 质量要求
- 插件管理页必须保持 Apple 风格后台的一致性,同时比现有占位页更强调运营效率与状态可读性。
- 卡片与详情工作台中的插件状态、危险动作和受保护插件边界必须清晰可辨。
- README 展示与配置编辑必须是真实数据流,不允许停留在纯展示占位。
- 最终至少完成一次构建验证,并补一份本轮 UI 验收结论。