2.7 KiB
2.7 KiB
装修模块 (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.sqlrpc_admin_save_diy_page_v1.sqlrpc_admin_delete_diy_page_v1.sqlrpc_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)全局仅有一个生效项。
回滚方案
- 数据库:依次 DROP
ak_diy_pages表及相关 4 个 RPC 函数。 - 代码:使用
git checkout恢复重构的 3 个.uvue页面,并删除decorationService.uts。
验证方式
- 功能验证:
- 首页切换:在“首页装修”列表中将另一个模板设为首页,确认移动端展示内容实时变更。
- 样式保存:在“个人中心装修”切换样式并点击保存,刷新页面后确认选中状态保持一致。
- 安全验证:确认非 admin 角色无法通过接口修改 DIY 配置。
关联规范
- 遵循
AGENT_PROJECT_SPEC.md规范。 - 遵循统一的 RPC 入口鉴权(admin 角色)。