feat(admin): complete decoration module database integration including DIY pages, RLS and RPCs
This commit is contained in:
@@ -0,0 +1,51 @@
|
||||
# 装修模块 (Decoration) 全量集成与数据库构建报告
|
||||
|
||||
## 摘要
|
||||
本次对 Admin 侧装修模块(Decoration Module)进行了深度的端到端修复。补齐了该模块完全缺失的数据库表结构(用于存储 DIY 布局 JSON)、行级安全策略(RLS)以及 4 个管理端 RPC 接口。同时重构了前端 3 个核心页面,实现了从 Mock 数据到真实数据库持久化的闭环。
|
||||
|
||||
## 动机
|
||||
装修模块允许管理员自定义商城的视觉表现(首页、专题页、个人中心风格)。此前该功能仅有 UI 静态模拟,无法保存任何配置。为了支撑个性化商城运营,必须补齐底层存储架构,并按照项目规范落地管理端接口。
|
||||
|
||||
## 影响范围
|
||||
- **模块**:后台管理系统 - 装修模块
|
||||
- **页面**:首页装修、商品分类装修、个人中心装修
|
||||
- **接口**:新增 4 个 `rpc_admin_...` 接口
|
||||
- **权限**:增加了 DIY 页面表的 RLS 策略,消费者端仅允许读取已启用配置
|
||||
|
||||
## 变更清单
|
||||
|
||||
### 数据库 SQL
|
||||
- **新增 Schema** (docs/sql/10_schema/decoration/):
|
||||
- `ak_diy_pages_v1.sql` (核心配置表)
|
||||
- **新增 RLS** (docs/sql/20_rls/decoration/):
|
||||
- `ml_decoration_rls_v1.sql`
|
||||
- **新增 RPC** (docs/sql/30_rpc/decoration/):
|
||||
- `rpc_admin_get_diy_page_list_v1.sql`
|
||||
- `rpc_admin_save_diy_page_v1.sql`
|
||||
- `rpc_admin_delete_diy_page_v1.sql`
|
||||
- `rpc_admin_set_home_page_v1.sql`
|
||||
|
||||
### 前端代码
|
||||
- **新增服务层**:`services/admin/decorationService.uts` (封装全量 DIY 接口)
|
||||
- **重构页面**:
|
||||
- `pages/mall/admin/decoration/home.uvue` (接入分页列表、删除及设为首页逻辑)
|
||||
- `pages/mall/admin/decoration/user.uvue` (接入样式持久化存取)
|
||||
- `pages/mall/admin/decoration/category.uvue` (接入样式持久化存取)
|
||||
|
||||
## 兼容性与风险
|
||||
- **配置格式**:`config` 字段采用 JSONB 存储,前端 UTS 解析时需确保类型强制转换正确(使用 `UTSJSONObject`)。
|
||||
- **首页约束**:数据库侧实现了原子切换逻辑,确保同类型页面(如 `home`)全局仅有一个生效项。
|
||||
|
||||
## 回滚方案
|
||||
1. **数据库**:依次 DROP `ak_diy_pages` 表及相关 4 个 RPC 函数。
|
||||
2. **代码**:使用 `git checkout` 恢复重构的 3 个 `.uvue` 页面,并删除 `decorationService.uts`。
|
||||
|
||||
## 验证方式
|
||||
1. **功能验证**:
|
||||
- 首页切换:在“首页装修”列表中将另一个模板设为首页,确认移动端展示内容实时变更。
|
||||
- 样式保存:在“个人中心装修”切换样式并点击保存,刷新页面后确认选中状态保持一致。
|
||||
2. **安全验证**:确认非 admin 角色无法通过接口修改 DIY 配置。
|
||||
|
||||
## 关联规范
|
||||
- 遵循 `AGENT_PROJECT_SPEC.md` 规范。
|
||||
- 遵循统一的 RPC 入口鉴权(admin 角色)。
|
||||
Reference in New Issue
Block a user