5.8 KiB
Project Bank Statement Tagging Frontend Implementation Plan
For Claude: REQUIRED SUB-SKILL: Use superpowers:executing-plans to implement this plan task-by-task.
Goal: 在本期“仅做后端能力、不改页面展示”的范围下,明确前端暂不接入流水标签展示,同时补齐后续接入所需的接口契约文档与回归检查,确保后端发布不会误伤现有项目详情页。
Architecture: 本期前端不新增 UI、不改造 UploadData.vue、DetailQuery.vue、PreliminaryCheck.vue、SpecialCheck.vue。前端实施计划聚焦于两件事:一是确认现有页面对新增后端能力保持兼容,二是在 API 层和页面待办文档中记录未来接入点,避免后续二次梳理。
Tech Stack: Vue 2, Element UI, Axios request wrapper, npm, Node
Task 1: 明确本期前端范围为零代码接入
Files:
- Modify:
docs/plans/2026-03-16-project-bank-statement-tagging-frontend-implementation.md
Step 1: Write the acceptance checklist
先把本期前端边界写清楚:
- 不新增标签展示页面
- 不新增标签查询按钮
- 不修改上传数据页现有轮询行为
- 不修改流水明细查询页现有筛选交互
- 不修改结果总览和专项排查占位页面
Step 2: Run a repository grep to verify no mandatory frontend dependency exists
Run:
Get-ChildItem -Recurse -File ruoyi-ui/src | Select-String -Pattern "project/tags|bank-tag|标签重算" | Measure-Object
Expected:
- 当前为
0,说明前端尚未被后端新能力反向强依赖
Step 3: Keep implementation minimal
不修改任何前端业务文件,仅在计划文档中记录本期范围。
Step 4: Commit
git add docs/plans/2026-03-16-project-bank-statement-tagging-frontend-implementation.md
git commit -m "docs: 明确流水标签前端一期范围"
Task 2: 记录未来 API 契约占位
Files:
- Modify:
docs/plans/2026-03-16-project-bank-statement-tagging-frontend-implementation.md
Step 1: Define the future API contract
在计划中补充后续前端接入时将消费的后端接口:
POST /ccdi/project/tags/rebuild- 后续可能新增:
GET /ccdi/project/tags/summaryGET /ccdi/project/tags/listGET /ccdi/project/tags/task/latest
并记录请求与响应最小示例。
Step 2: Run a smoke review
Run:
Get-Content docs/plans/2026-03-16-project-bank-statement-tagging-frontend-implementation.md | Select-String "/ccdi/project/tags/rebuild"
Expected:
- 能检索到接口说明
Step 3: Keep implementation minimal
仅补充文档,不提前创建未使用的前端 API 文件,避免本期产生无效代码。
Step 4: Commit
git add docs/plans/2026-03-16-project-bank-statement-tagging-frontend-implementation.md
git commit -m "docs: 补充流水标签前端后续接口契约"
Task 3: 约束后续页面接入位置
Files:
- Modify:
docs/plans/2026-03-16-project-bank-statement-tagging-frontend-implementation.md
Step 1: Write the page integration checklist
在计划中明确二期前端接入位置:
ruoyi-ui/src/views/ccdiProject/components/detail/PreliminaryCheck.vue- 适合展示项目级标签汇总、模型触发概览
ruoyi-ui/src/views/ccdiProject/components/detail/SpecialCheck.vue- 适合展示对象级异常标签列表
ruoyi-ui/src/views/ccdiProject/components/detail/DetailQuery.vue- 适合展示流水级标签明细与异常原因
ruoyi-ui/src/api/- 预留
ccdiProjectTag.js
- 预留
Step 2: Run a path existence smoke check
Run:
@(Test-Path 'ruoyi-ui/src/views/ccdiProject/components/detail/PreliminaryCheck.vue'), @(Test-Path 'ruoyi-ui/src/views/ccdiProject/components/detail/SpecialCheck.vue'), @(Test-Path 'ruoyi-ui/src/views/ccdiProject/components/detail/DetailQuery.vue')
Expected:
- 三个结果均为
True
Step 3: Keep implementation minimal
仅记录接入点和职责边界,不提前改页面。
Step 4: Commit
git add docs/plans/2026-03-16-project-bank-statement-tagging-frontend-implementation.md
git commit -m "docs: 约束流水标签前端二期接入位置"
Task 4: 完成本期前端回归检查
Files:
- Modify:
docs/plans/2026-03-16-project-bank-statement-tagging-frontend-implementation.md
Step 1: Run frontend build smoke check
Run:
cd ruoyi-ui
npm run build:prod
Expected:
- 构建成功
- 说明后端新能力引入后没有要求前端同步改动
Step 2: Run upload/detail page manual checklist
手工验证:
- 上传数据页可正常进入
- 批量上传弹窗行为不变
- 拉取本行信息弹窗行为不变
- 流水明细查询页可正常打开
- 结果总览和专项排查仍保持占位状态
Step 3: Update verification notes
在计划末尾补充本期前端“不变更但已验证兼容”的结论和后续待接入项。
Step 4: Commit
git add docs/plans/2026-03-16-project-bank-statement-tagging-frontend-implementation.md
git commit -m "docs: 完成流水标签前端一期兼容性核对"
Future API Contract
本期不接入,但二期前端可直接按以下契约接入:
POST /ccdi/project/tags/rebuild- 请求体:
{
"projectId": 40,
"modelCode": "LARGE_TRANSACTION"
}
- 成功响应:
{
"code": 200,
"msg": "标签重算任务已提交"
}
- 后续推荐新增:
GET /ccdi/project/tags/task/latest?projectId=40GET /ccdi/project/tags/summary?projectId=40GET /ccdi/project/tags/list?projectId=40&resultType=STATEMENT
Verification Notes
本期前端计划的核心结论是:
- 按当前需求不做页面实现是合理的
- 需要保证后端独立发布不影响现有项目详情页
- 后续若要展示标签结果,建议优先接入
PreliminaryCheck.vue、SpecialCheck.vue、DetailQuery.vue