9.8 KiB
Special Check Family Asset Liability Frontend Implementation Plan
For agentic workers: REQUIRED: Use superpowers:subagent-driven-development (if subagents available) or superpowers:executing-plans to implement this plan. Steps use checkbox (
- [ ]) syntax for tracking.
Goal: 将项目详情专项排查页从占位页升级为真实页面,新增“员工家庭资产负债专项核查”卡片,支持项目内员工列表展示与行内展开详情。
Architecture: 保持 SpecialCheck.vue 作为专项排查页入口,不新增路由或平行页面。前端拆成“主容器 + 专项核查列表区块 + 行内展开详情”三层结构,列表接口与详情接口分开请求,样式沿用结果总览已有卡片、表格、标签和空态语言。
Tech Stack: Vue 2, Element UI, Axios (@/utils/request), Node.js
Task 1: 补专项核查 API 封装
Files:
-
Create:
ruoyi-ui/src/api/ccdi/projectSpecialCheck.js -
Test:
ruoyi-ui/tests/unit/special-check-family-asset-liability-api.test.js -
Step 1: Write the failing test
新增接口契约静态断言,锁定以下方法与路径:
-
getFamilyAssetLiabilityList -
getFamilyAssetLiabilityDetail -
/ccdi/project/special-check/family-asset-liability/list -
/ccdi/project/special-check/family-asset-liability/detail -
Step 2: Run test to verify it fails
Run:
cd ruoyi-ui
node tests/unit/special-check-family-asset-liability-api.test.js
Expected:
-
FAIL -
Step 3: Write minimal implementation
在 API 模块中新增:
getFamilyAssetLiabilityList(projectId)getFamilyAssetLiabilityDetail(projectId, staffIdCard)
要求:
-
统一使用
@/utils/request -
详情接口透传
projectId与staffIdCard -
不和
projectOverview.js混写 -
Step 4: Run test to verify it passes
Run:
cd ruoyi-ui
node tests/unit/special-check-family-asset-liability-api.test.js
Expected:
-
PASS -
Step 5: Commit
git add ruoyi-ui/src/api/ccdi/projectSpecialCheck.js ruoyi-ui/tests/unit/special-check-family-asset-liability-api.test.js
git commit -m "补充专项核查家庭资产负债前端接口"
Task 2: 将 SpecialCheck.vue 从占位页升级为页面主容器
Files:
-
Modify:
ruoyi-ui/src/views/ccdiProject/components/detail/SpecialCheck.vue -
Create:
ruoyi-ui/src/views/ccdiProject/components/detail/specialCheck.mock.js -
Test:
ruoyi-ui/tests/unit/special-check-layout.test.js -
Test:
ruoyi-ui/tests/unit/special-check-states.test.js -
Step 1: Write the failing test
补页面主容器静态断言,锁定以下内容:
-
SpecialCheck.vue不再渲染“功能开发中...” -
页面包含专项核查卡片标题“员工家庭资产负债专项核查”
-
页面保留
loading / empty / loaded三态结构 -
Step 2: Run test to verify it fails
Run:
cd ruoyi-ui
node tests/unit/special-check-layout.test.js
node tests/unit/special-check-states.test.js
Expected:
-
FAIL -
Step 3: Write minimal implementation
在 SpecialCheck.vue 中:
-
引入真实列表接口
-
维持页面级
loading / empty / loaded状态 -
页面主卡片采用与结果总览一致的白卡结构
-
specialCheck.mock.js仅保留空态和骨架所需结构,不额外扩展伪业务数据 -
Step 4: Run test to verify it passes
Run:
cd ruoyi-ui
node tests/unit/special-check-layout.test.js
node tests/unit/special-check-states.test.js
Expected:
-
PASS -
Step 5: Commit
git add ruoyi-ui/src/views/ccdiProject/components/detail/SpecialCheck.vue ruoyi-ui/src/views/ccdiProject/components/detail/specialCheck.mock.js ruoyi-ui/tests/unit/special-check-layout.test.js ruoyi-ui/tests/unit/special-check-states.test.js
git commit -m "升级专项排查页主容器"
Task 3: 实现员工家庭核查列表与风险标签
Files:
-
Create:
ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilitySection.vue -
Test:
ruoyi-ui/tests/unit/special-check-family-table.test.js -
Test:
ruoyi-ui/tests/unit/special-check-risk-tag.test.js -
Step 1: Write the failing test
新增区块组件静态断言,锁定:
-
列表字段包含姓名、身份证号、所属部门、家庭总年收入、家庭总资产、家庭总负债、风险情况、操作
-
风险情况使用标签展示
-
操作列文案为“查看详情”
-
Step 2: Run test to verify it fails
Run:
cd ruoyi-ui
node tests/unit/special-check-family-table.test.js
node tests/unit/special-check-risk-tag.test.js
Expected:
-
FAIL -
Step 3: Write minimal implementation
在 FamilyAssetLiabilitySection.vue 中:
-
接收列表数据与加载状态
-
使用
el-table渲染员工家庭核查列表 -
风险标签颜色与结果总览现有标签语义保持一致
-
金额统一格式化为元或万元显示,前后一致即可,不增加额外切换控件
-
Step 4: Run test to verify it passes
Run:
cd ruoyi-ui
node tests/unit/special-check-family-table.test.js
node tests/unit/special-check-risk-tag.test.js
Expected:
-
PASS -
Step 5: Commit
git add ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilitySection.vue ruoyi-ui/tests/unit/special-check-family-table.test.js ruoyi-ui/tests/unit/special-check-risk-tag.test.js
git commit -m "补充专项核查家庭资产负债列表展示"
Task 4: 实现行内展开详情与按需查询
Files:
-
Create:
ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilityDetail.vue -
Modify:
ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilitySection.vue -
Test:
ruoyi-ui/tests/unit/special-check-detail-expand.test.js -
Test:
ruoyi-ui/tests/unit/special-check-detail-layout.test.js -
Step 1: Write the failing test
新增详情展开断言,锁定:
-
点击“查看详情”后在当前行内展开
-
不出现弹窗、抽屉或路由跳转
-
详情固定分为收入、资产、负债三组
-
资产和负债明细均以表格或列表形式展开
-
Step 2: Run test to verify it fails
Run:
cd ruoyi-ui
node tests/unit/special-check-detail-expand.test.js
node tests/unit/special-check-detail-layout.test.js
Expected:
-
FAIL -
Step 3: Write minimal implementation
在 FamilyAssetLiabilitySection.vue 中:
- 管理当前展开员工
expandedStaffIdCard - 首次展开时调用详情接口
- 再次点击同一行时收起
- 切换项目
projectId时清空展开状态和详情缓存
在 FamilyAssetLiabilityDetail.vue 中:
-
展示收入明细、本人与配偶小计
-
展示资产合计与资产明细列表
-
展示负债合计与负债明细列表
-
对空明细显示局部空态,不额外跳页
-
Step 4: Run test to verify it passes
Run:
cd ruoyi-ui
node tests/unit/special-check-detail-expand.test.js
node tests/unit/special-check-detail-layout.test.js
Expected:
-
PASS -
Step 5: Commit
git add ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilityDetail.vue ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilitySection.vue ruoyi-ui/tests/unit/special-check-detail-expand.test.js ruoyi-ui/tests/unit/special-check-detail-layout.test.js
git commit -m "补充专项核查家庭资产负债详情展开"
Task 5: 对齐结果总览视觉并补记录
Files:
-
Modify:
ruoyi-ui/src/views/ccdiProject/components/detail/SpecialCheck.vue -
Modify:
ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilitySection.vue -
Modify:
ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilityDetail.vue -
Test:
ruoyi-ui/tests/unit/special-check-visual-alignment.test.js -
Create:
docs/reports/implementation/2026-03-24-special-check-family-asset-liability-frontend-record.md -
Create:
docs/tests/records/2026-03-24-special-check-family-asset-liability-frontend-verification.md -
Step 1: Write the failing test
新增样式/结构静态断言,锁定:
-
使用结果总览同类白卡容器结构
-
标题、副标题、表格头、风险标签与页面留白节奏统一
-
页面不再出现占位图标与“功能开发中...”文案
-
Step 2: Run test to verify it fails
Run:
cd ruoyi-ui
node tests/unit/special-check-visual-alignment.test.js
Expected:
-
FAIL -
Step 3: Write minimal implementation
收口样式与文档:
-
对齐结果总览现有
section-card / block-header / el-table风格 -
保持桌面端阅读密度稳定
-
确认空态、加载态、异常态都在当前卡片内解决
-
写前端实施记录与验证记录
-
Step 4: Run test to verify it passes
Run:
cd ruoyi-ui
node tests/unit/special-check-family-asset-liability-api.test.js
node tests/unit/special-check-layout.test.js
node tests/unit/special-check-states.test.js
node tests/unit/special-check-family-table.test.js
node tests/unit/special-check-risk-tag.test.js
node tests/unit/special-check-detail-expand.test.js
node tests/unit/special-check-detail-layout.test.js
node tests/unit/special-check-visual-alignment.test.js
Expected:
PASS
将执行命令与结果记录到 docs/tests/records/2026-03-24-special-check-family-asset-liability-frontend-verification.md。
- Step 5: Commit
git add ruoyi-ui/src/views/ccdiProject/components/detail/SpecialCheck.vue ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilitySection.vue ruoyi-ui/src/views/ccdiProject/components/detail/FamilyAssetLiabilityDetail.vue docs/reports/implementation/2026-03-24-special-check-family-asset-liability-frontend-record.md docs/tests/records/2026-03-24-special-check-family-asset-liability-frontend-verification.md ruoyi-ui/tests/unit/special-check-visual-alignment.test.js
git commit -m "完成专项核查家庭资产负债前端实现"