Files
ccdi/docs/plans/2026-03-13-employee-family-asset-import-split-frontend-implementation.md

231 lines
6.2 KiB
Markdown

# 员工资产导入与亲属资产导入拆分前端实施计划
> **For Claude:** REQUIRED SUB-SKILL: Use superpowers:executing-plans to implement this plan task-by-task.
**Goal:** 将员工页与亲属页的资产导入前端交互彻底拆开,确保员工页只走员工资产导入接口,亲属页只走亲属资产导入接口。
**Architecture:** 保留亲属页现有资产导入状态管理,新增员工资产专用 API 封装并改造员工页上传地址、模板下载、状态轮询与失败记录查询。两边继续复用现有异步导入交互样式,但数据源和文案完全隔离。
**Tech Stack:** Vue 2, Element UI, Axios request wrapper, Node 静态契约测试
---
### Task 1: 固化前端拆分契约测试
**Files:**
- Modify: `ruoyi-ui/tests/unit/employee-asset-api-contract.test.js`
- Modify: `ruoyi-ui/tests/unit/employee-asset-import-ui.test.js`
- Modify: `ruoyi-ui/tests/unit/staff-family-asset-api-contract.test.js`
- Modify: `ruoyi-ui/tests/unit/staff-family-asset-detail-import-ui.test.js`
**Step 1: 写员工页失败测试**
- 断言员工页不再引用 `/ccdi/assetInfo/importData`
- 断言员工页引用新的员工资产 API 文件或路由
- 断言模板文案为“员工资产模板”
**Step 2: 运行员工页静态测试确认失败**
Run:
```bash
node tests/unit/employee-asset-api-contract.test.js
node tests/unit/employee-asset-import-ui.test.js
```
Expected:
- 至少一个断言失败
- 失败原因是员工页仍指向旧接口
**Step 3: 写亲属页保护性测试**
- 断言亲属页继续使用 `/ccdi/assetInfo/*`
- 断言亲属页模板文案仍为“亲属资产”
**Step 4: 运行亲属页测试确认当前仍通过**
Run:
```bash
node tests/unit/staff-family-asset-api-contract.test.js
node tests/unit/staff-family-asset-detail-import-ui.test.js
```
Expected:
- 现有亲属页测试通过
**Step 5: 提交**
```bash
git add ruoyi-ui/tests/unit/employee-asset-api-contract.test.js ruoyi-ui/tests/unit/employee-asset-import-ui.test.js ruoyi-ui/tests/unit/staff-family-asset-api-contract.test.js ruoyi-ui/tests/unit/staff-family-asset-detail-import-ui.test.js
git commit -m "补充资产导入拆分前端失败测试"
```
### Task 2: 新增员工资产导入 API 封装
**Files:**
- Create: `ruoyi-ui/src/api/ccdiBaseStaffAsset.js`
- Modify: `ruoyi-ui/tests/unit/employee-asset-api-contract.test.js`
**Step 1: 写最小 API 文件**
导出以下方法:
```javascript
export function importBaseStaffAssetTemplate() {}
export function importBaseStaffAssetData(data) {}
export function getBaseStaffAssetImportStatus(taskId) {}
export function getBaseStaffAssetImportFailures(taskId, pageNum, pageSize) {}
```
**Step 2: 接入员工专用路由**
- `/ccdi/baseStaff/asset/importTemplate`
- `/ccdi/baseStaff/asset/importData`
- `/ccdi/baseStaff/asset/importStatus/`
- `/ccdi/baseStaff/asset/importFailures/`
**Step 3: 运行员工资产 API 静态测试**
Run:
```bash
node tests/unit/employee-asset-api-contract.test.js
```
Expected:
- API 契约测试通过
**Step 4: 提交**
```bash
git add ruoyi-ui/src/api/ccdiBaseStaffAsset.js ruoyi-ui/tests/unit/employee-asset-api-contract.test.js
git commit -m "新增员工资产导入前端接口"
```
### Task 3: 改造员工页导入交互
**Files:**
- Modify: `ruoyi-ui/src/views/ccdiBaseStaff/index.vue`
- Modify: `ruoyi-ui/tests/unit/employee-asset-import-ui.test.js`
**Step 1: 替换员工页上传地址**
- `assetUpload.url` 改为 `/ccdi/baseStaff/asset/importData`
- 模板下载改为 `/ccdi/baseStaff/asset/importTemplate`
- 状态查询与失败记录改为员工资产专用 API
**Step 2: 保持状态隔离**
- 保留 `assetUpload``assetPollingTimer``assetCurrentTaskId`
- 仅替换其数据来源
- 不改动普通员工导入状态
**Step 3: 调整员工页提示文案**
- 提示用户仅支持员工本人资产导入
- 下载链接文字明确为“下载员工资产模板”
**Step 4: 运行员工页静态测试**
Run:
```bash
node tests/unit/employee-asset-import-ui.test.js
```
Expected:
- 测试通过
**Step 5: 提交**
```bash
git add ruoyi-ui/src/views/ccdiBaseStaff/index.vue ruoyi-ui/tests/unit/employee-asset-import-ui.test.js
git commit -m "切换员工页资产导入到专用接口"
```
### Task 4: 保护亲属页导入交互不回归
**Files:**
- Modify: `ruoyi-ui/src/views/ccdiStaffFmyRelation/index.vue`
- Modify: `ruoyi-ui/tests/unit/staff-family-asset-api-contract.test.js`
- Modify: `ruoyi-ui/tests/unit/staff-family-asset-detail-import-ui.test.js`
**Step 1: 检查亲属页调用**
- 确认亲属页仍使用 `/ccdi/assetInfo/importData`
- 确认模板下载仍使用 `/ccdi/assetInfo/importTemplate`
- 确认提示文案仍强调“亲属资产”
**Step 2: 如有必要补充只读修正**
- 若之前误改了亲属页文案或下载文件名,恢复为亲属专用表达
**Step 3: 运行亲属页静态测试**
Run:
```bash
node tests/unit/staff-family-asset-api-contract.test.js
node tests/unit/staff-family-asset-detail-import-ui.test.js
```
Expected:
- 测试通过
**Step 4: 提交**
```bash
git add ruoyi-ui/src/views/ccdiStaffFmyRelation/index.vue ruoyi-ui/tests/unit/staff-family-asset-api-contract.test.js ruoyi-ui/tests/unit/staff-family-asset-detail-import-ui.test.js
git commit -m "保护亲属页资产导入交互不回归"
```
### Task 5: 执行前端回归验证
**Files:**
- Modify: `docs/plans/2026-03-13-employee-family-asset-import-split-design.md`
**Step 1: 运行全部相关静态测试**
Run:
```bash
node tests/unit/employee-asset-api-contract.test.js
node tests/unit/employee-asset-import-ui.test.js
node tests/unit/staff-family-asset-api-contract.test.js
node tests/unit/staff-family-asset-detail-import-ui.test.js
```
Expected:
- 四个测试全部通过
**Step 2: 做源码检查**
Run:
```bash
git grep -n "/ccdi/baseStaff/asset|/ccdi/assetInfo" -- "ruoyi-ui/src/views/**/*.vue" "ruoyi-ui/src/api/*.js"
```
Expected:
- 员工页仅指向 `/ccdi/baseStaff/asset/*`
- 亲属页仅指向 `/ccdi/assetInfo/*`
**Step 3: 更新设计文档实现状态**
- 在设计文档末尾补充前端已完成拆分验证说明
**Step 4: 提交**
```bash
git add docs/plans/2026-03-13-employee-family-asset-import-split-design.md
git commit -m "完成资产导入拆分前端验证"
```