Compare commits

...

94 Commits

Author SHA1 Message Date
sheng
e60c004b3c feat: 新增多模块功能并完善功能清单
Some checks are pending
Release pipeline / publish (push) Waiting to run
Release pipeline / Always run job (push) Waiting to run
1. 新增BOM物料清单、班组管理、班次管理、排班日历、监控设置页面及对应路由
2. 新增相关业务API接口
3. 完善多语言国际化配置
4. 更新功能迁移状态清单,完成所有功能迁移
5. 新增各模块测试用例文档
2026-06-23 10:39:42 +08:00
sheng
8ef94ecf2e 迁移排班日历功能
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
2026-06-22 23:39:45 +08:00
sheng
e8e79fcb3f 迁移班次管理功能 2026-06-22 23:32:58 +08:00
sheng
c670488c80 迁移班组管理功能 2026-06-22 23:23:06 +08:00
sheng
cf90981c5d 迁移BOM物料清单功能 2026-06-22 23:10:00 +08:00
sheng
964cf0b6ad 迁移监控设置功能 2026-06-22 23:00:27 +08:00
sheng
8ee13f322f Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 22:46:57 +08:00
sheng
7cf7caf31f 新增工艺流程参数与补偿配置
Some checks failed
Release pipeline / Always run job (push) Has been cancelled
Release pipeline / publish (push) Has been cancelled
2026-06-22 22:44:45 +08:00
sheng
795d4d3b58 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 19:49:35 +08:00
sheng
c1e8626289 迁移质量管理UChart报表
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
2026-06-22 19:33:09 +08:00
sheng
dcc706308b 迁移质量管理CChart报表 2026-06-22 19:32:47 +08:00
sheng
f40ff30943 迁移质量管理NPChart报表 2026-06-22 19:32:25 +08:00
sheng
5d1fbcc508 迁移质量管理PChart报表 2026-06-22 19:32:03 +08:00
sheng
5a4001ddf7 迁移质量管理DPMO报表 2026-06-22 19:31:42 +08:00
sheng
9af7dbf668 迁移质量管理CPK报表 2026-06-22 19:31:20 +08:00
sheng
d984ea6107 迁移质量管理MAMS报表 2026-06-22 19:30:58 +08:00
sheng
f817714c56 迁移质量管理MAMR报表 2026-06-22 19:30:36 +08:00
sheng
f625f3063d 迁移质量管理MA报表 2026-06-22 19:30:15 +08:00
sheng
9c54df9600 迁移质量管理CUSUM报表 2026-06-22 19:29:53 +08:00
sheng
7c48d0b7c7 迁移质量管理EWMA报表 2026-06-22 19:29:32 +08:00
sheng
ffead080ad 迁移质量管理Levey-Jennings报表 2026-06-22 19:29:10 +08:00
sheng
2739415e35 迁移质量管理I-MR报表 2026-06-22 19:28:49 +08:00
sheng
54ba033db6 迁移质量管理XBar-S报表 2026-06-22 19:28:28 +08:00
sheng
9f349d325a 迁移质量管理XBar-R报表 2026-06-22 19:28:05 +08:00
sheng
cc7e06fdb1 迁移质量管理SPC渲染条件配置 2026-06-22 19:27:43 +08:00
sheng
15105bc5c7 迁移质量管理抽样方案配置 2026-06-22 19:27:19 +08:00
sheng
a9c88eb264 迁移质量管理检验项目 2026-06-22 19:26:52 +08:00
sheng
7125bc4884 迁移质量管理检测方案维护 2026-06-22 19:26:29 +08:00
sheng
19f8f18f85 迁移质量管理接收质量限 2026-06-22 19:26:07 +08:00
sheng
9675227702 迁移质量管理检验标准 2026-06-22 19:25:45 +08:00
sheng
e1111fe6df 迁移质量管理检验单管理 2026-06-22 19:25:23 +08:00
sheng
e9faea739a 迁移质量管理首巡检报表 2026-06-22 19:25:01 +08:00
sheng
be119060f0 迁移质量管理首巡检录入 2026-06-22 19:24:39 +08:00
sheng
1e2945d4a3 迁移质量管理首巡检项目配置 2026-06-22 19:24:18 +08:00
sheng
bf493321cb 迁移质量管理检验类别管理 2026-06-22 19:23:56 +08:00
sheng
92de685b9d Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 19:04:37 +08:00
sheng
2690204ec5 按组件规范重构设备模型页面
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
2026-06-22 19:03:44 +08:00
sheng
700da7c42a Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 18:47:03 +08:00
sheng
8eaa5f90ca 修正设备维修日志迁移状态
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
2026-06-22 18:26:25 +08:00
sheng
25bd394f96 迁移设备损耗品更换日志模块 2026-06-22 18:25:25 +08:00
sheng
80ef16f3e5 迁移设备损耗品寿命管理模块 2026-06-22 18:25:04 +08:00
sheng
86313d309f 迁移设备损耗品项目模块 2026-06-22 18:24:42 +08:00
sheng
6a664277a5 迁移设备损耗品类别模块 2026-06-22 18:24:21 +08:00
sheng
19050966b4 迁移设备维修日志模块 2026-06-22 18:24:00 +08:00
sheng
c58525b284 迁移设备维修管理模块 2026-06-22 18:23:39 +08:00
sheng
bf1365c1ea 迁移设备保养日志模块 2026-06-22 18:20:51 +08:00
sheng
8d1be42ce2 迁移设备保养详情模块 2026-06-22 18:19:57 +08:00
sheng
0740f82083 迁移设备保养项目模块 2026-06-22 18:19:35 +08:00
sheng
4714bbabc5 迁移设备点检日志模块 2026-06-22 18:19:14 +08:00
sheng
8e5127ea88 迁移设备点检记录模块 2026-06-22 18:18:52 +08:00
sheng
f2ffac4a06 迁移设备点检项目模块 2026-06-22 18:16:26 +08:00
sheng
41bbe3bf62 迁移设备信息模块 2026-06-22 18:12:51 +08:00
sheng
3412ae93a3 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 17:55:56 +08:00
sheng
6bb98edca5 chore(package): 更新node版本和js-cookie依赖
将node引擎要求调整为>=20.19.0,升级js-cookie到3.0.7版本,同步更新volta配置的node版本
2026-06-22 17:55:50 +08:00
sheng
c07f95a45e 迁移鹰眼模块
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
2026-06-22 17:51:29 +08:00
sheng
973c780bf6 迁移电池详情报表模块 2026-06-22 17:44:16 +08:00
sheng
6768eb9ead 迁移设备履历报表模块 2026-06-22 17:40:40 +08:00
sheng
a1716b0069 迁移电池追溯模块 2026-06-22 17:36:22 +08:00
sheng
15526ca6e4 迁移托盘追溯模块 2026-06-22 17:32:32 +08:00
sheng
d582f9779a Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 17:30:56 +08:00
sheng
2bd0e49bb6 fix: 修复依赖版本和接口路径错误
1. 将sass版本从^1.54.5改为固定1.54.5并更新lock文件
2. 修正团队管理页面的用户接口导入路径
2026-06-22 17:30:53 +08:00
sheng
264474eced 迁移电池曲线模块
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
2026-06-22 17:29:23 +08:00
sheng
0c6c4dc93c Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 17:24:20 +08:00
sheng
fe45390997 迁移正向追溯模块
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
2026-06-22 17:22:00 +08:00
sheng
a1e79dcdcf Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 17:00:18 +08:00
sheng
3c4a665dc3 修复反向追溯图谱迁移问题
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
2026-06-22 16:57:37 +08:00
sheng
94fcb85e5b Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 16:35:23 +08:00
sheng
7987d9a085 迁移反向追溯模块
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
- 新增数据中台反向追溯 V2 页面

- 新增反向追溯查询导出接口、旧路径路由和中英文文案

- 更新迁移任务列表并补充人工功能测试清单
2026-06-22 16:33:18 +08:00
sheng
5fa4043c69 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 16:27:16 +08:00
sheng
e3fd31e33d 迁移电池复投管理模块
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
- 新增计划与生产电池复投管理 V2 页面

- 新增复投验证接口、旧路径路由和中英文文案

- 更新迁移任务列表并补充人工功能测试清单
2026-06-22 16:26:05 +08:00
sheng
d7aee0f93a Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 16:17:23 +08:00
sheng
9863bf1113 迁移物料监控模块
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
- 新增计划与生产物料监控 V2 页面

- 新增 WIP 物料监控接口、旧路径路由和中英文文案

- 更新迁移任务列表中的物料监控状态
2026-06-22 16:12:59 +08:00
sheng
cffbe39e99 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 16:08:08 +08:00
sheng
6bb2d1285c 迁移托盘登录模块
Some checks failed
Release pipeline / Always run job (push) Has been cancelled
Release pipeline / publish (push) Has been cancelled
- 新增计划与生产托盘登录 V2 页面

- 新增托盘登录接口、旧路径路由和中英文文案

- 更新迁移任务列表中的托盘登录状态
2026-06-22 16:01:21 +08:00
sheng
37daca561d Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 15:51:53 +08:00
sheng
eb31da72e0 迁移设备监控模块
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
- 新增计划与生产设备监控 V2 页面

- 新增设备监控接口、路由和中英文文案

- 更新迁移任务列表中的设备监控状态
2026-06-22 15:50:19 +08:00
sheng
d66a934f06 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 15:29:58 +08:00
sheng
b942d24f2c 迁移预警中心模块
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
- 新增计划与生产预警中心 V2 页面

- 新增预警中心接口、路由和中英文文案

- 更新迁移任务列表中的预警中心状态
2026-06-22 15:24:59 +08:00
sheng
12abbd51a8 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 15:10:23 +08:00
sheng
8ef087676f feat: migrate process execution module
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
- add V2 process execution page for planning production monitoring

- add process execution API, route, and i18n entries

- update migration task list status for process execution
2026-06-22 15:07:38 +08:00
sheng
ed087a1c83 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 15:00:05 +08:00
sheng
45c2ea6e63 feat: migrate tray management module
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
- add V2 tray management page for planning production monitoring

- add tray management API, route, and i18n entries

- update migration task list status for tray management
2026-06-22 14:58:04 +08:00
sheng
05c98e30c0 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-22 14:27:28 +08:00
sheng
248557a293 feat(production-master-data): 新增班组管理功能模块
1. 新增班组管理路由配置,添加对应页面访问路径
2. 新建班组管理API接口文件,封装增删改查、导入导出等接口
3. 补充中英文多语言文案,适配页面所有交互文本
4. 新增班组管理页面组件,包含搜索、列表、新增/编辑、成员管理、导入导出全功能
5. 更新功能测试文档,补充35条班组管理测试用例并更新用例统计
6. 更新系统功能清单对照表,新增班组管理模块条目
2026-06-22 14:27:18 +08:00
sheng
b44e031e74 feat: migrate planning batch management modules
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
- migrate batch list, tray tracking, and batch defect report pages to V2

- add planning production APIs, workerman helper, routes, and i18n entries

- add markdown migration task list generated from the Webman function matrix
2026-06-22 14:13:01 +08:00
sheng
3f546564cc feat(production-master-data): 新增工艺流程管理完整模块
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
- 添加工艺流程、流程卡工序的全套CRUD及复制接口
- 新增工艺流程列表页与流程卡详情页的路由和页面组件
- 补充产品、工序分类、工序子类的全量查询接口
- 优化弹窗表单组件,支持字段禁用与focus/blur/change事件回调
- 修复工序单元页面的国际化调用和权限配置问题
- 补充中英文多语言国际化文案
- 新增该模块的功能测试文档
2026-06-04 17:07:15 +08:00
b6c362d906 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
2026-06-02 16:00:24 +08:00
76b480ece5 feat(production-master-data): add SPC采集配置功能
实现SPC数据采集配置页面,包含路由配置、API接口、多语言文案以及完整的增删改查功能,附带功能测试文档
2026-06-02 15:59:58 +08:00
sheng
76f9657fe9 style: 调整函数声明的空格格式,统一代码风格
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
对所有函数声明添加前后空格,保持代码排版一致性,提升可读性
2026-06-02 15:17:51 +08:00
e0d2c7c886 fix(pnpm): 修复@achrinza/node-ipc的安全版本问题
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
通过pnpm overrides将@achrinza/node-ipc强制升级到>=9.2.7版本,更新lockfile中的依赖版本记录。
2026-06-02 15:10:45 +08:00
sheng
df11ca0db6 docs: 更新项目环境搭建文档并添加volta配置
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
1. 补充Windows下Volta安装后的生效方式说明
2. 完善不同环境下Node版本安装指引
3. 新增volta命令无法识别的问题排查方案
4. 在package.json中添加volta的node版本配置
2026-06-02 14:42:33 +08:00
sheng
8b587163df chore: 配置项目开发环境并重构接口路由前缀
Some checks failed
Release pipeline / publish (push) Has been cancelled
Release pipeline / Always run job (push) Has been cancelled
1.  添加 .node-version 和 .npmrc 配置文件,使用 Volta 锁定 Node.js 18.16.0 版本,强制使用 pnpm 作为包管理器
2.  更新 package.json,添加 packageManager 和 engines 字段限制依赖安装版本,替换 npm 脚本为 pnpm
3.  重构设备管理模块的接口 BASE 路径和路由路径,统一命名为 device_model/device_category
4.  完善 README.md,新增环境要求、安装启动流程、常用命令和目录结构说明
2026-06-02 14:26:17 +08:00
sheng
f1e73f3319 Merge branch 'master' of http://119.91.43.128:3001/sheng/mes-ui-d2 2026-06-02 14:05:32 +08:00
sheng
ddc715e17c feat(production-master-data): add 异常不良管理功能
1. 新增设备类别API接口封装
2. 新增异常不良管理的CRUD、导入导出API
3. 添加异常不良管理页面路由与多语言配置
4. 新增文件工具类支持Excel读写下载
5. 实现完整的异常不良管理页面与导入弹窗
6. 新增功能测试流程文档
7. 安装xlsx依赖支持Excel操作
2026-06-02 14:05:15 +08:00
187 changed files with 35199 additions and 1352 deletions

1
.node-version Normal file
View File

@@ -0,0 +1 @@
18.16.0

8
.npmrc Normal file
View File

@@ -0,0 +1,8 @@
# pnpm 配置
# 强制通过 pnpm 安装,禁止使用 npm / yarn
engine-strict=true
# 使用 lockfile 锁定依赖版本
lockfile=true
# 依赖提升模式(兼容旧项目)
shamefully-hoist=true
# 允许在 package.json 中通过 packageManager 字段指定包管理器版本

479
README.md
View File

@@ -1,6 +1,167 @@
# MES-UI
基于 [D2 Admin](https://github.com/d2-projects/d2-admin)Vue 2 + Element UI的企业级中后台前端项目。
基于 [D2 Admin](https://github.com/d2-projects/d2-admin)Vue 2.7 + Element UI的企业级 MES 中后台前端项目。
---
## 环境要求
本项目通过 **[Volta](https://volta.sh/)** 和 **[pnpm](https://pnpm.io/)** 锁定开发环境版本,确保团队成员使用完全一致的 Node.js 和包管理器版本。
| 工具 | 锁定版本 | 作用 |
| --- | --- | --- |
| **Node.js** | `18.16.0` | JavaScript 运行时(`.node-version` 文件) |
| **pnpm** | `10.33.0` | 包管理器(`package.json``packageManager` 字段) |
> 配置文件说明:
> - `.node-version` → Volta 读取,自动切换 Node.js 版本
> - `package.json` → `engines` 字段限制版本范围,`packageManager` 字段锁定 pnpm 版本
> - `.npmrc` → `engine-strict=true` 强制使用锁定版本,不满足则安装失败
---
## 从零开始安装到启动
### 第一步:安装 Volta如果尚未安装
Volta 会根据 `.node-version` 自动安装并切换到项目所需的 Node.js 版本。
**WindowsPowerShell**
```powershell
winget install Volta.Volta
```
> `winget` 安装完成后,**当前终端窗口不会自动加载 Volta**。选择以下任一方式生效:
>
> **方式一(关闭重开):** 关掉当前终端,重新打开一个 PowerShell / VS Code 终端。
>
> **方式二(不重启立即生效):** 在当前终端执行:
> ```powershell
> $env:PATH = [System.Environment]::GetEnvironmentVariable("PATH", "Machine") + ";" + [System.Environment]::GetEnvironmentVariable("PATH", "User")
> ```
>
> 生效后验证:
> ```powershell
> volta --version # 应输出版本号(如 2.0.2
> ```
**macOS / Linux**
```bash
curl https://get.volta.sh | bash
# 重新加载 shell 配置
source ~/.bashrc # 或 source ~/.zshrc
volta --version
```
> 更多安装方式请参考 [Volta 官方文档](https://docs.volta.sh/guide/getting-started)。
### 第二步:启用 pnpmVolta 内置支持,无需额外安装)
```bash
# Volta 会根据 package.json 中的 packageManager 字段
# 自动安装并使用 pnpm@10.33.0
volta install pnpm@10.33.0
# 验证版本
pnpm --version # 应输出 10.33.0
```
> 如果没有 Volta也可以手动安装 pnpm
> ```bash
> npm install -g pnpm@10.33.0
> ```
### 第三步:克隆项目并安装依赖
```bash
# 克隆仓库
git clone <仓库地址>
cd mes-ui
# Volta 检测到 .node-version 后,自动下载并安装 Node.js 18.16.0
# 如果你本机没有这个版本Volta 会提示 "Fetching node@18.16.0" —— 等它完成即可
node --version # 应输出 v18.16.0
# 安装依赖
pnpm install
```
> **没有安装 Node 18.16.0 怎么办?**
> **Volta 用户**:无需手动操作。进入项目目录时 Volta 会自动检测 `.node-version`,如果本机缺这个版本,它会**自动下载安装**,你只需等待几秒终端提示完成即可。
> **nvm 用户**:执行 `nvm install 18.16.0 && nvm use 18.16.0`。
> **手动安装**:去 [nodejs.org](https://nodejs.org/) 下载 Node.js 18.16.0 安装包。
>
> 装完后建议运行 `node --version` 确认输出 `v18.16.0`,否则 `pnpm install` 会因为 `engine-strict=true` 直接报错拒绝安装。
### 第四步:配置环境变量
在项目根目录创建 `.env.development.local` 文件(此文件已在 `.gitignore` 中,不会提交):
```bash
# 后台 API 地址
VUE_APP_API=http://你的后台服务器地址/
```
### 第五步:启动开发服务器
```bash
pnpm serve
```
浏览器会自动打开 `http://localhost:8080`(或终端提示的实际端口)。
---
## 常用命令速查
| 命令 | 说明 |
| --- | --- |
| `pnpm serve` | 启动开发服务器(自动打开浏览器) |
| `pnpm build` | 生产环境构建 |
| `pnpm build:preview` | 预发布环境构建 |
| `pnpm lint` | ESLint 代码检查并自动修复 |
| `pnpm test:unit` | 运行单元测试 |
| `pnpm install` | 安装依赖 |
| `pnpm add <包名>` | 添加新依赖(**禁止使用 npm install** |
| `pnpm remove <包名>` | 移除依赖 |
---
## 版本锁定机制
### Node.js 版本锁定Volta
```
项目根目录
├── .node-version → 18.16.0Volta 自动读取切换)
```
- Volta 进入项目目录时自动将 Node.js 切换为 `18.16.0`
- 如果该版本未安装Volta 会自动下载并安装
- 传统方案nvm也兼容`nvm use` 读取 `.nvmrc`,本项目同时提供 `.node-version` 供 Volta 使用
### pnpm 版本锁定
```
package.json
├── packageManager → pnpm@10.33.0Corepack / Volta 识别)
├── engines.pnpm → >=10.33.0 <11npm/pnpm install 时校验)
```
```ini
# .npmrc
engine-strict=true # 版本不满足 → 安装直接报错
```
### 依赖版本锁定
```
pnpm-lock.yaml → 锁定所有依赖的精确版本(等价于 npm 的 package-lock.json
```
> `pnpm-lock.yaml` **必须提交到 Git**,保证所有环境安装的依赖版本完全一致。
---
@@ -12,234 +173,109 @@ mes-ui/
├── docs/ # 项目文档
├── public/ # 静态资源(不经过 webpack 处理)
├── src/ # PC 端业务源码
│ ├── api/ # 接口请求层
│ ├── assets/ # 静态资源(经 webpack 处理)
│ ├── api/ # 接口请求层(按业务模块拆分)
│ ├── _service.js # axios 请求服务实例
│ │ └── production-master-data/ # 生产主数据模块 API
│ ├── assets/ # 静态资源(经 webpack 处理,含 SCSS / SVG
│ ├── components/ # 公共组件
│ │ ├── page-table/ # CRUD 表格便捷组合体
│ │ └── page-dialog-form/ # 新增/编辑弹框组件
│ ├── composables/ # 可复用逻辑函数
│ ├── layout/ # 页面布局
│ ├── useTableColumns.js # 列定义工厂
│ │ ├── useTableButtons.js # 按钮定义工厂
│ │ └── useI18n.js # i18n Mixin 工厂
│ ├── layout/ # 页面布局header-aside
│ ├── libs/ # 工具函数
│ ├── locales/ # 国际化语言包
│ ├── menu/ # 菜单配置
│ ├── plugin/ # Vue 插件
│ ├── router/ # 路由配置
│ ├── locales/ # 国际化语言包zh-chs / en
│ ├── router/ # 路由配置modules/ 按业务模块拆分)
│ ├── store/ # Vuex 状态管理
── views/ # 业务页面
── utils/ # 通用工具文件下载、Excel 读取等)
│ └── views/ # 业务页面(按模块三级目录组织)
│ ├── production-master-data/ # 生产主数据
│ ├── system-administration/ # 系统管理
│ ├── equipment-management/ # 设备管理
│ ├── quality-management/ # 质量管控
│ ├── planning-production/ # 计划生产
│ └── data-platform/ # 数据平台
├── src.mobile/ # 移动端业务源码
├── .browserslistrc # 浏览器兼容配置
├── .editorconfig # 编辑器统一配置
├── .env / .env.development / .env.preview # 环境变量
├── .eslintignore / .eslintrc.js # ESLint 配置
├── .gitignore # Git 忽略配置
├── .node-version # Volta Node.js 版本锁定18.16.0
├── .npmrc # pnpm 配置(版本强校验)
├── .postcssrc.js # PostCSS 配置
├── babel.config.js # Babel 配置
├── jest.config.js # Jest 单元测试配置
├── jsconfig.json # VS Code 路径别名提示
├── package.json # 项目依赖与脚本
├── pnpm-lock.yaml # pnpm 依赖锁定文件
├── pnpm-lock.yaml # pnpm 依赖锁定文件(必须提交)
├── vue.config.js # Vue CLI 构建配置
└── README.md # 项目说明(本文件)
```
---
## 各目录详解
### `.github/`
GitHub 相关配置,包含 Issue 模板和 CI/CD 工作流(`workflows/`)。
### `docs/`
项目文档目录,存放变更日志、修复记录等 Markdown 文档。子目录 `image/` 存放文档引用的图片。
## 项目文档
| 文档 | 说明 |
|------|------|
| [表格组件使用说明](./docs/表格组件使用说明.md) | page-table / page-dialog-form 完整使用手册 |
| [SCT基础表格重构设计](./docs/SCT基础表格重构设计.md) | 旧 sct-base-table → 新架构的设计文档 |
| [Sass废弃修复](./docs/Sass废弃修复.md) | Sass 废弃警告修复记录 |
| --- | --- |
| [表格组件使用说明](./docs/表格组件使用说明.md) | `page-table` + `page-dialog-form` 完整使用手册 |
| [国际化规则](./docs/国际化规则.md) | i18n 使用规范与迁移指南 |
| [迁移提示词](./docs/迁移提示词.md) | 旧页面迁移到新方案的规则文档 |
| [SCT基础表格重构设计](./docs/SCT基础表格重构设计.md) | 旧 `sct-base-table` → 新架构设计文档 |
| [变更日志](./docs/变更日志.md) | 项目变更日志 |
### `public/`
---
**静态资源目录**,文件会原样复制到构建产物中,不经过 webpack 编译。
## 关键目录说明
| 子目录 | 作用 |
|--------|------|
| `lib/UEditor/` | 百度 UEditor 富文本编辑器(第三方库,通过 `<script>` 直接引入) |
| `image/theme/` | 各主题的 Logo 图片和预览图chester / d2 / element / line / star / tomorrow-night-blue / violet |
| `image/loading/` | 页面加载动画的 SVG |
| `html/` | 独立 HTML 页面(如 demo.html |
| `index.html` | SPA 入口 HTML 模板 |
| `icon.ico` | 网站 Favicon |
### `src/` — PC 端源码
#### `src/api/`
**接口请求层**。封装后端 API 调用,按业务模块拆分为独立文件。
- `_service.js` — 基于 axios 的请求服务实例
- `_tools.js` — 请求工具函数
- `demo.js` — 演示接口
- `sys.user.js` — 用户相关接口
#### `src/assets/`
**静态资源**,会被 webpack 处理。
| 子目录 | 作用 |
|--------|------|
| `style/unit/color.scss` | 全局颜色变量定义 |
| `style/public.scss` | 全局 SCSS 变量、mixin、placeholder通过 `additionalData` 自动注入每个组件) |
| `style/public-class.scss` | 全局通用 CSS class间距、浮动、文字对齐等工具类 |
| `style/fixed/` | 第三方库样式覆盖element / markdown / n-progress / vue-splitpane 等) |
| `style/animate/` | 过渡动画样式vue-transition |
| `style/theme/` | 主题切换样式,每个主题独立目录,含 `index.scss` + `setting.scss` |
| `svg-icons/icons/` | SVG 图标文件,通过 `svg-sprite-loader` 生成雪碧图 |
| `svg-icons/index.js` | SVG 图标自动注册脚本 |
#### `src/components/`
**公共组件库**,所有可复用组件集中管理。
### `src/components/` — 公共组件
| 组件 | 作用 |
|------|------|
| `d2-container` | 页面容器组件,提供卡片、全屏、透明等多种布局变体 |
| --- | --- |
| `page-table` | CRUD 表格组合体(按钮栏 + 表格 + 分页 + 高度自适应 + 帮助按钮) |
| `page-dialog-form` | 新增/编辑弹框(表单渲染 + 校验 + i18n 自动翻译) |
| `d2-container` | 页面容器(卡片、全屏、透明等多种布局变体) |
| `d2-container-frame` | iframe 嵌套外部页面容器 |
| `d2-count-up` | 数字滚动动画组件 |
| `d2-highlight` | 代码高亮展示组件 |
| `d2-icon` / `d2-icon-svg` | 图标组件Font Awesome / SVG |
| `d2-icon-select` / `d2-icon-svg-select` | 图标选择器组件 |
| `d2-link-btn` | 链接式按钮 |
| `d2-markdown` | Markdown 渲染组件 |
| `d2-module-index-banner` | 首页 Banner 展示组件 |
| `d2-module-index-menu` | 首页菜单组件 |
| `d2-quill` | Quill 富文本编辑器封装 |
| `d2-scrollbar` | 自定义滚动条组件 |
| `d2-ueditor` | 百度 UEditor 编辑器封装 |
| `page-table` | **新** CRUD 表格便捷组合体(按钮栏 + 表格 + 分页 + 高度自适应 + 帮助按钮) |
| `page-dialog-form` | **新** 增删改查弹框组件(表单渲染 + 校验 + i18n |
> `page-table` 和 `page-dialog-form` 详细用法见[表格组件使用说明](./docs/表格组件使用说明.md)
> `page-table` 和 `page-dialog-form` 是本项目核心组件,详细用法见 [表格组件使用说明](./docs/表格组件使用说明.md)
#### `src/composables/`
**可复用的逻辑函数Composition Utilities**。把散落在各页面中的重复 JS 逻辑抽成纯函数,组件只需调用即可。
### `src/composables/` — 逻辑复用层
| 文件 | 作用 |
|------|------|
| `useTableColumns.js` | 列定义工厂,消除手动分配 `idx` 序号;约定 `prop: '_actions'` 为操作列 |
| `useTableButtons.js` | 按钮定义工厂,一键生成顶部工具栏 + 行内操作按钮,自动注入权限过滤 |
| `useI18n.js` | i18n Mixin 工厂,通过 `i18nMixin(prefix)` 注入 `key()` / `ckey()` 方法,消除每个页面手写 `T` 常量 |
| --- | --- |
| `useTableColumns.js` | 列定义工厂,消除手动分配 `idx`约定 `prop: '_actions'` 为操作列 |
| `useTableButtons.js` | 按钮工厂,一键生成工具栏 + 行内按钮,自动注入权限过滤 |
| `useI18n.js` | i18n Mixin 工厂,通过 `i18nMixin(prefix)` 注入 `key()` / `ckey()` |
| `useConfirmHandle.js` | 确认操作 Mixin封装 `$confirm` + API 调用 |
> **为什么放在 `src/` 根目录?**
> composable 不是 UI 组件(不需要 `<template>`),也不属于 `libs/`(通用工具库)。它是介于**组件和逻辑之间**的中间层——被多个组件调用,但本身不渲染 DOM。放在 `src/` 根目录下与 `components/`、`views/` 同级,方便一眼看到项目的公共逻辑层。
### `src/router/modules/` — 路由模块
#### `src/layout/`
**页面布局**。当前使用 `header-aside` 布局(顶栏 + 侧边栏 + 主内容区)。
按业务一级模块拆分examples:
| 子目录 | 作用 |
|--------|------|
| `layout.vue` | 布局主文件 |
| `components/menu-side/` | 侧边菜单组件 |
| `components/menu-header/` | 顶部导航菜单组件 |
| `components/header-user/` | 顶栏用户信息下拉 |
| `components/header-theme/` | 主题切换面板 |
| `components/header-color/` | 主题色切换 |
| `components/header-locales/` | 多语言切换 |
| `components/header-fullscreen/` | 全屏切换 |
| `components/header-search/` | 全局搜索 |
| `components/header-log/` | 操作日志 |
| `components/header-size/` | 字号大小切换 |
| `components/tabs/` | 多标签页栏 |
| `components/contextmenu/` | 标签页右键菜单 |
| `components/panel-search/` | 全局搜索面板 |
| `mixins/search.js` | 搜索 mixin |
| `mixins/` | 菜单相关 mixin |
| 文件 | 路由前缀 | 对应模块 |
| --- | --- | --- |
| `production-master-data.js` | `/production_configuration` | 生产主数据 |
| `system-administration.js` | `/system_settings` | 系统管理 |
| `equipment-management.js` | `/equipment_management` | 设备管理 |
| `quality-management.js` | `/quality_management` | 质量管控 |
| `planning-production.js` | `/planning_production` | 计划生产 |
| `data-platform.js` | `/data_platform` | 数据平台 |
#### `src/libs/`
**工具函数库**。
- `util.js` — 通用工具方法
- `util.cookies.js` — Cookie 操作
- `util.db.js` — 本地存储(基于 lowdb
- `util.log.js` — 日志工具
- `util.import.development.js` / `util.import.production.js` — 开发/生产环境动态加载
### `src/api/` — 接口请求层
#### `src/locales/`
**国际化i18n**。JSON 格式的语言文件,支持:
- `zh-chs` — 简体中文
- `zh-cht` — 繁体中文
- `en` — 英文
- `ja` — 日文
- `mixin.js` — Vue 国际化 mixin
#### `src/menu/`
**菜单配置**。按业务模块拆分,定义侧边栏菜单结构。`modules/` 下按 demo-components、demo-playground、demo-plugins 组织。
#### `src/plugin/`
**Vue 插件**。
- `d2admin/` — D2Admin 核心插件(初始化全局功能)
- `error/` — 全局错误捕获
- `log/` — 通用日志输出
- `open/` — 新窗口打开工具
#### `src/router/`
**路由配置**。`modules/` 下按 components、playground、plugins 拆分路由表。`routes.js` 为汇总路由,`index.js` 创建 Vue Router 实例。
#### `src/store/`
**Vuex 状态管理**。`modules/d2admin/` 下按功能拆分为独立模块:
| 模块 | 作用 |
|------|------|
| `account` | 用户账户信息 |
| `color` | 主题色管理 |
| `db` | 本地数据库状态 |
| `fullscreen` | 全屏状态 |
| `gray` | 灰度模式 |
| `log` | 操作日志 |
| `menu` | 菜单状态(展开/收缩/激活项) |
| `page` | 页面缓存与标签页 |
| `releases` | 版本信息 |
| `search` | 全局搜索 |
| `size` | 字号大小 |
| `theme` | 主题切换 |
| `transition` | 页面过渡动画 |
| `ua` | 用户代理信息 |
| `user` | 用户登录态 |
#### `src/views/`
**页面视图**。
- `demo/` — 各功能展示页面(组件演示 / 插件演示 / 功能试验场)
- `system/` — 系统级页面(首页 / 登录 / 404 / 日志 / 重定向 / 刷新)
- `production-master-data/` — 生产配置模块(工厂区域 / 产线 / 工艺 / 产品 / 物料等)
> 页面按一级模块 → 二级模块 → 三级模块 三层目录组织,与 [后台Webman界面截图对照表](./后台Webman界面截图对照表.md) 中的英文命名一致。
#### `src/` 根文件
| 文件 | 作用 |
|------|------|
| `main.js` | PC 端应用入口 |
| `App.vue` | 根组件 |
| `setting.js` | 全局设置(站点标题等) |
| `i18n.js` | 国际化初始化 |
按业务模块父目录存放,命名规则:`{模块名}.js`。例如:
- `production-master-data/device-category.js` → 设备类型
- `production-master-data/factory-area.js` → 工厂区域
---
### `src.mobile/` — 移动端源码
基于 Vant UI 的移动端适配版本,与 PC 端共用部分业务逻辑。
| 文件/目录 | 作用 |
|-----------|------|
| `main.js` | 移动端应用入口 |
| `App.vue` | 移动端根组件 |
| `vant.js` | Vant UI 按需引入配置 |
| `router/` | 移动端路由 |
| `store/` | 移动端状态管理 |
| `views/` | 移动端页面 |
---
### 构建配置文件
## 构建配置文件
| 文件 | 作用 |
|------|------|
| --- | --- |
| `vue.config.js` | Vue CLI 构建配置多页入口、CDN、webpack 插件、主题色替换、SVG sprites、路径别名 |
| `babel.config.js` | Babel 转译配置 |
| `.postcssrc.js` | PostCSS 自动前缀等配置 |
@@ -249,22 +285,73 @@ GitHub 相关配置,包含 Issue 模板和 CI/CD 工作流(`workflows/`
| `.browserslistrc` | 目标浏览器范围 |
| `.editorconfig` | 编辑器缩进/换行风格统一 |
### 环境变量文件
---
| 文件 | 作用 |
|------|------|
## 环境变量
| 文件 | 说明 |
| --- | --- |
| `.env` | 所有环境通用变量 |
| `.env.development` | 开发环境变量 |
| `.env.development.local` | 本地开发环境变量(不提交 Git需自行创建 |
| `.env.preview` | 预发布环境变量 |
---
## 常用命令
## 常见问题
| 命令 | 说明 |
|------|------|
| `pnpm serve` | 启动开发服务器 |
| `pnpm build` | 生产环境构建 |
| `pnpm build:preview` | 预发布环境构建 |
| `pnpm lint` | ESLint 检查并自动修复 |
| `pnpm test:unit` | 运行单元测试 |
### Q1`pnpm install` 报错 "Unsupported engine"
> 意思:本机 Node.js 或 pnpm 版本不在项目规定范围内install 被阻断。
**先排查版本:**
```bash
node --version # 项目要求 >=18.16.0 <19
pnpm --version # 项目要求 >=10.33.0 <11
```
**谁把版本不对:**
| 情景 | 解决办法 |
| --- | --- |
| **用 Volta**(推荐) | `volta install node@18.16.0` + `volta install pnpm@10.33.0`,进入项目目录自动生效 |
| **用 nvm** | `nvm install 18.16.0 && nvm use 18.16.0`,再 `npm install -g pnpm@10.33.0` |
| **手动安装** | 去 [nodejs.org](https://nodejs.org/) 下载 18.16.0,再 `npm install -g pnpm@10.33.0` |
| **已有正确版本但切换不生效** | 重新打开终端,确保 `volta` / `nvm` 已正确加载 |
> 版本验证通过后,重新执行 `pnpm install`。
### Q2启动后页面报跨域错误
`.env.development.local` 中确认 `VUE_APP_API` 指向正确的后台地址,且后台已开启 CORS。
### Q3端口被占用
默认端口为 `8080`。如需修改,在 `.env.development.local` 中添加:
```bash
PORT=8081
```
### Q4`volta` 命令无法识别 / "无法将 volta 项识别为 cmdlet"
> 原因:`winget install Volta.Volta` 不会自动刷新当前终端的 PATH 缓存。
**解决办法二选一:**
```powershell
# 方案 A关掉当前终端重新打开一个推荐最简单
# 方案 B在当前终端执行以下命令立即生效免重启
$env:PATH = [System.Environment]::GetEnvironmentVariable("PATH", "Machine") + ";" + [System.Environment]::GetEnvironmentVariable("PATH", "User")
```
> 生效后 `volta --version` 应输出版本号。
### Q5依赖安装慢
pnpm 默认使用 npm registry。如需加速可配置镜像
```bash
pnpm config set registry https://registry.npmmirror.com
```

View File

@@ -0,0 +1,20 @@
# 功能测试任务列表 - BOM物料清单
> 路由:`/production_configuration/matetial_model/bom`
| 序号 | 测试项 | 操作步骤 | 预期结果 | 结果 |
|---|---|---|---|---|
| 1 | 页面入口 | 从菜单进入“BOM物料清单”或直接访问路由 | 页面正常打开,表格展示 BOM 编码、名称、产品型号、状态、创建人、创建时间和备注 | ☐ |
| 2 | 条件查询 | 输入 BOM 编码、名称或选择产品型号后点击“查询” | 列表按条件刷新,分页回到第一页 | ☐ |
| 3 | 重置查询 | 点击“重置” | 查询条件清空,列表恢复默认数据 | ☐ |
| 4 | 新增校验 | 点击“新增”,不填写编码、名称或产品型号直接确认 | 表单提示必填校验,不提交请求 | ☐ |
| 5 | 新增 BOM | 填写 BOM 编码、名称、产品型号、状态和备注后确认 | 弹窗关闭,提示操作成功,列表出现新增 BOM | ☐ |
| 6 | 编辑 BOM | 点击“编辑”,修改名称、状态或备注后确认 | 表单回显旧值,保存后列表展示新值 | ☐ |
| 7 | 删除 BOM | 点击“删除”并确认 | 提示操作成功,记录被删除,分页刷新正确 | ☐ |
| 8 | 打开 BOM 关系 | 点击“设置BOM” | 全屏关系弹窗打开,左侧显示工序单元,右侧显示当前工序 IN/OUT 关系 | ☐ |
| 9 | 切换工序 | 在左侧选择不同工序单元 | IN/OUT 列表按工序刷新 | ☐ |
| 10 | 添加 IN 物料 | 在 IN 区域点击“新增”,选择一个或多个物料后确认 | 物料加入 IN 列表,重复物料提示不可重复选择 | ☐ |
| 11 | 编辑 IN 投入数量 | 修改 IN 列表的投入数量并移出输入框 | 数量保存成功,刷新后仍保持新值 | ☐ |
| 12 | 添加 OUT 物料限制 | 在 OUT 区域尝试选择多个物料或已有 OUT 后继续新增 | 系统提示 OUT 结构只允许 1 个半成品 | ☐ |
| 13 | 删除 BOM 关系 | 勾选 IN/OUT 关系后点击删除,或点击行内删除 | 关系删除成功,列表刷新 | ☐ |
| 14 | 权限按钮 | 使用缺少新增/编辑/删除/设置BOM权限的账号进入页面 | 对应按钮不显示或不可操作 | ☐ |

View File

@@ -0,0 +1,648 @@
# SPC采集配置功能测试流程文档
> **测试对象**:生产配置 → SPC采集模型 → SPC采集配置Data Collection Configuration
> **迁移日期**2026-06-02
> **对应页面**[`src/views/production-master-data/spc-configuration/data-collection-configuration/index.vue`](file:///c:/code/compony/mes-ui-d2/src/views/production-master-data/spc-configuration/data-collection-configuration/index.vue)
> **API 文件**[`src/api/production-master-data/data-collection-configuration.js`](file:///c:/code/compony/mes-ui-d2/src/api/production-master-data/data-collection-configuration.js)
> **路由路径**`/production_configuration/spc_configuration/binding_scada_node`(旧值暂留,后续批量替换)
> **i18n 前缀**`page.production_master_data.spc_configuration.data_collection_configuration`
---
## 一、测试环境配置
| 配置项 | 要求 |
|--------|------|
| 浏览器 | Chrome 最新版、Edge 最新版(兼容 IE 11+ |
| 屏幕分辨率 | ≥ 1920×1080 |
| Node.js | ≥ 16.x |
| 包管理器 | pnpm ≥ 7.x |
| 后端服务 | Webman 已启动,且 SPC采集配置相关 API 可正常访问(`production_configuration/spc_configuration/binding_scada_node/*` |
| 测试账号 | 具有「生产配置 → SPC采集模型 → SPC采集配置」菜单权限的管理员账号含 create / edit / delete 权限) |
| 测试数据 | 准备至少 5 条测试用 SPC采集配置采集编码唯一覆盖不同采集类型实时、周期、触发、不同状态启用、禁用 |
| SCADA节点依赖 | 系统中至少配置 1 个可用的 SCADA 节点,便于绑定 |
| 语言切换 | 先测中文(简体中文),再切到英文验证 i18n 是否正常 |
| 权限分配 | 系统管理 → 菜单管理中确认 SPC采集配置按钮权限新增、编辑、删除已正确配置 |
---
## 二、测试前置条件
1. 后端服务Webman已启动`production_configuration/spc_configuration/binding_scada_node/` 模块的 API 可正常访问
2. 前端项目已执行 `pnpm install``pnpm dev` 正常启动,可访问登录页
3. 使用具有「生产配置 → SPC采集模型 → SPC采集配置」菜单权限的管理员账号登录
4. 侧边栏菜单 **生产配置 → SPC采集模型** 下可见 **SPC采集配置** 子菜单
5. 浏览器控制台无 Vue 警告或 i18n key 缺失报错
6. 确认 `src/locales/zh-chs.json``src/locales/en.json` 中存在 `page.production_master_data.spc_configuration.data_collection_configuration` 配置
7. 数据库中 SPC采集配置表为空或仅有少量测试数据便于验证
8. 系统中至少存在 1 个已配置的 SCADA 节点
---
## 三、功能测试用例
### 3.1 页面加载与数据展示
#### TC-SCC-001菜单导航与页面加载
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 登录系统 2. 点击侧边栏菜单「生产配置 → SPC采集模型 → SPC采集配置」 |
| **预期结果** | 页面正常加载URL 显示 `/production_configuration/spc_configuration/binding_scada_node`页面顶部显示搜索栏采集编码、采集名称、SCADA节点、状态、查询、重置按钮中部显示 SPC采集配置 列表表格;底部分页组件显示 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-002列表表格列头与数据展示
| 项目 | 内容 |
|------|------|
| **测试步骤** | 查看 SPC采集配置 列表的表头列与各行数据 |
| **预期结果** | 表格列依次为序号、采集编码、采集名称、SCADA节点、采集类型、采集间隔(秒)、状态tag 标签展示)、备注、操作;操作列包含「编辑」「删除」两个按钮(带图标);当数据为空时显示空数据占位提示 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-003状态列 Tag 展示
| 项目 | 内容 |
|------|------|
| **测试步骤** | 查看列表中状态列的不同取值 |
| **预期结果** | 启用状态显示绿色 tagsuccess 类型),禁用状态显示红色 tagdanger 类型) |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-004工具栏按钮显示
| 项目 | 内容 |
|------|------|
| **测试步骤** | 查看表格上方的工具栏 |
| **预期结果** | 显示蓝色「新增」按钮(含加号图标),右上角显示问号「帮助」按钮(点击跳转 `/help/data-collection-configuration` |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-005表格自适应高度
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 加载页面后查看表格高度 2. 缩小/放大浏览器窗口 3. 折叠/展开侧边栏 |
| **预期结果** | 表格高度自动填满 d2-container 剩余空间,窗口变化时无空白或滚动条异常 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### 3.2 搜索功能
#### TC-SCC-006按采集编码精确搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在「采集编码」输入框输入完整的采集编码(如 `SCC_001` 2. 点击「查询」按钮 |
| **预期结果** | 表格仅显示编码匹配的数据行;分页总数更新为匹配条数;输入框右侧 X 按钮可清空内容 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-007按采集编码模糊搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在「采集编码」输入框输入编码的片段(如 `SCC_` 2. 点击「查询」按钮 |
| **预期结果** | 表格显示所有编码包含 `SCC_` 的数据行 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-008按采集名称搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在「采集名称」输入框输入关键字(如「温度」) 2. 点击「查询」按钮 |
| **预期结果** | 表格仅显示名称包含关键字的 SPC采集配置 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-009按 SCADA 节点搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在「SCADA节点」输入框输入节点关键字 2. 点击「查询」按钮 |
| **预期结果** | 表格仅显示 SCADA 节点字段匹配的数据行 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-010按状态筛选
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在「状态」下拉中选择「启用」 2. 点击「查询」按钮 |
| **预期结果** | 表格仅显示状态为启用的数据行;下拉中可选择「启用」「禁用」或留空(全部) |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-011组合条件搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 同时输入「采集编码」「采集名称」「SCADA节点」「状态」搜索条件 2. 点击「查询」按钮 |
| **预期结果** | 表格显示同时满足所有条件的数据行AND 关系) |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-012回车键触发搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在搜索输入框中输入关键字 2. 按下键盘回车键 |
| **预期结果** | 等同于点击「查询」按钮,表格按搜索条件刷新 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-013重置搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 输入搜索条件并点击「查询」 2. 点击「重置」按钮 |
| **预期结果** | 搜索输入框和状态下拉清空,表格恢复显示全部 SPC采集配置 数据 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-014搜索无结果
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 输入不存在的编码或名称 2. 点击「查询」 |
| **预期结果** | 表格显示空数据占位提示,分页总数显示 0 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### 3.3 分页功能
#### TC-SCC-015分页默认显示
| 项目 | 内容 |
|------|------|
| **测试步骤** | 加载页面后查看分页组件 |
| **预期结果** | 分页默认显示第 1 页,每页 10 条记录,总条数显示当前数据库 SPC采集配置 总数 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-016切换每页条数
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在分页组件的「每页显示」下拉中切换为 20、50、100 2. 观察表格变化 |
| **预期结果** | 表格按新条数加载数据,分页组件正确显示总页数 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-017翻页功能
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 准备至少 25 条测试数据 2. 点击「下一页」「上一页」「首页」「末页」按钮 3. 输入页码跳转 |
| **预期结果** | 表格按页加载数据,翻页流畅无报错 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### 3.4 新增 SPC采集配置
#### TC-SCC-018打开新增弹框
| 项目 | 内容 |
|------|------|
| **测试步骤** | 点击表格上方「新增」按钮 |
| **预期结果** | 弹出新增 SPC采集配置 对话框,标题显示"新增SPC采集配置"包含采集编码、采集名称、SCADA节点、采集类型、采集间隔(秒)、状态、备注共 7 个表单项;「确定」「取消」按钮位于底部;弹框宽度约 50% |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-019新增表单必填校验 - 采集编码
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 不填写「采集编码」直接点击「确定」 |
| **预期结果** | 「采集编码」输入框下方显示红色校验提示"请输入采集编码" |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-020新增表单必填校验 - 采集名称
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 不填写「采集名称」直接点击「确定」 |
| **预期结果** | 「采集名称」输入框下方显示红色校验提示"请输入采集名称" |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-021新增表单必填校验 - SCADA 节点
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 不填写「SCADA节点」直接点击「确定」 |
| **预期结果** | 「SCADA节点」输入框下方显示红色校验提示"请输入SCADA节点" |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-022新增表单必填校验 - 采集类型
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 不选择「采集类型」直接点击「确定」 |
| **预期结果** | 「采集类型」下拉框下方显示红色校验提示"请选择采集类型" |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-023新增表单必填校验 - 状态
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 清空「状态」下拉框 3. 点击「确定」 |
| **预期结果** | 「状态」下拉框下方显示红色校验提示"请选择状态" |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-024新增成功 - 实时采集类型
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 采集编码输入 `SCC_TEST_001` 3. 采集名称输入「温度实时采集」 4. SCADA节点输入 `SCADA_NODE_01` 5. 采集类型选择「实时」 6. 采集间隔输入 `1` 7. 状态选择「启用」 8. 备注输入「测试用」 9. 点击「确定」 |
| **预期结果** | 弹框关闭,页面右上角显示绿色成功提示"操作成功";表格自动刷新并显示新增的 SPC采集配置 行 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-025新增成功 - 周期采集类型
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 采集编码输入 `SCC_TEST_002` 3. 采集名称输入「压力周期采集」 4. SCADA节点输入 `SCADA_NODE_02` 5. 采集类型选择「周期」 6. 采集间隔输入 `60` 7. 状态选择「启用」 8. 备注留空 9. 点击「确定」 |
| **预期结果** | 新增成功,备注字段允许为空,表格中可见新增行(采集类型显示为"周期",采集间隔 60 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-026新增成功 - 触发采集类型
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 采集编码输入 `SCC_TEST_003` 3. 采集名称输入「流量触发采集」 4. SCADA节点输入 `SCADA_NODE_03` 5. 采集类型选择「触发」 6. 状态选择「禁用」 7. 点击「确定」 |
| **预期结果** | 新增成功,表格中状态列 tag 显示为红色(禁用) |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-027新增 - 编码长度校验
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 在采集编码输入框输入超过 100 个字符 3. 失焦后观察 |
| **预期结果** | 输入框下方显示校验提示"长度在 1 到 100 个字符" |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-028新增 - 编码重复
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 输入已存在的 SPC采集配置 编码 3. 点击「确定」 |
| **预期结果** | 提示后端返回的"编码已存在"等错误信息,新增失败,弹框不关闭 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-029取消新增
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 填写部分内容 3. 点击「取消」按钮 |
| **预期结果** | 弹框关闭,表格数据无变化,无任何提示 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-030新增 - 备注多行输入
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 在备注框中输入多行文字(超过 2 行) 3. 观察文本框是否自动扩展 |
| **预期结果** | 备注为 textarea 类型,输入多行内容后自动扩展(最少 2 行,最多 6 行) |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### 3.5 编辑 SPC采集配置
#### TC-SCC-031打开编辑弹框
| 项目 | 内容 |
|------|------|
| **测试步骤** | 点击某一 SPC采集配置 行操作列的「编辑」按钮 |
| **预期结果** | 弹出编辑 SPC采集配置 对话框,标题显示"编辑SPC采集配置"采集编码、采集名称、SCADA节点、采集类型、采集间隔(秒)、状态、备注共 7 个字段正确回填该行的数据 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-032编辑成功 - 修改名称
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开编辑弹框(选择名称为"温度实时采集"的行) 2. 修改采集名称为"温度实时采集-改" 3. 点击「确定」 |
| **预期结果** | 弹框关闭,提示"操作成功",表格对应行的名称列更新为新值 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-033编辑成功 - 修改状态
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开编辑弹框(选择状态为启用的行) 2. 修改状态为「禁用」 3. 点击「确定」 |
| **预期结果** | 弹框关闭,提示"操作成功",表格对应行的状态 tag 由绿色变为红色 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-034编辑成功 - 修改采集间隔
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开编辑弹框 2. 修改采集间隔为 `120` 3. 点击「确定」 |
| **预期结果** | 弹框关闭,提示"操作成功",表格对应行的采集间隔列更新为 `120` |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-035编辑后清空必填项 - 采集名称
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开编辑弹框 2. 清空「采集名称」输入框 3. 点击「确定」 |
| **预期结果** | 「采集名称」下方显示红色校验提示,无法提交 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-036编辑后清空必填项 - SCADA 节点
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开编辑弹框 2. 清空「SCADA节点」输入框 3. 点击「确定」 |
| **预期结果** | 「SCADA节点」下方显示红色校验提示无法提交 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-037取消编辑
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开编辑弹框 2. 修改部分字段 3. 点击「取消」按钮 |
| **预期结果** | 弹框关闭,表格数据无变化,无任何提示 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### 3.6 删除 SPC采集配置
#### TC-SCC-038删除确认弹框
| 项目 | 内容 |
|------|------|
| **测试步骤** | 点击某一 SPC采集配置 行操作列的「删除」按钮 |
| **预期结果** | 弹出确认对话框,标题显示"提示",内容为"确定要删除该SPC采集配置吗?",按钮为"确定""取消" |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-039取消删除
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 点击「删除」按钮 2. 在确认弹框中点击「取消」 |
| **预期结果** | 确认弹框关闭,表格数据无变化,无任何提示 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-040删除成功
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 点击「删除」按钮 2. 在确认弹框中点击「确定」 |
| **预期结果** | 确认弹框关闭,提示"操作成功",表格对应行被移除;分页组件总数减 1如删除的是当前页最后一行则自动跳到上一页 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-041删除最后一行后页码修正
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 确保当前页只有 1 条数据 2. 删除该行 |
| **预期结果** | 删除成功后自动跳转到上一页(如当前已是第 1 页则停留在第 1 页),不会出现空页或无数据错误 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### 3.7 国际化i18n
#### TC-SCC-042中文显示
| 项目 | 内容 |
|------|------|
| **测试步骤** | 系统语言切换为简体中文,查看 SPC采集配置 页面 |
| **预期结果** | 所有列头、表单 label、按钮、提示、状态枚举均显示中文采集编码、采集名称、SCADA节点、采集类型、采集间隔(秒)、状态、备注、新增、编辑、删除、确定、取消、提示、操作成功、实时、周期、触发、启用、禁用 等) |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-043英文显示
| 项目 | 内容 |
|------|------|
| **测试步骤** | 系统语言切换为英文,查看 SPC采集配置 页面 |
| **预期结果** | 所有列头、表单 label、按钮、提示、状态枚举均显示英文Collection Code、Collection Name、SCADA Node、Collection Type、Interval (s)、Status、Remark、Add、Edit、Delete、Confirm、Cancel、Tip、Operation succeeded、Real-time、Periodic、Trigger、Enable、Disable 等) |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-044弹框 i18n 自动响应
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在中文状态下打开新增弹框 2. 不关闭弹框,将语言切换为英文 3. 观察弹框标题、按钮文字、表单 label 是否自动翻译为英文 |
| **预期结果** | 弹框中的所有文案(包括 title、label、placeholder、按钮文字、校验提示跟随语言切换自动更新为对应英文无需关闭重开 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-045缺失 key 校验
| 项目 | 内容 |
|------|------|
| **测试步骤** | 打开浏览器开发者工具,切换页面、打开弹框、切换语言 |
| **预期结果** | 控制台无 i18n key 缺失警告(如 `[vue-i18n] Value of key 'xxx' is not a string` |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### 3.8 权限控制
#### TC-SCC-046无 create 权限时隐藏新增按钮
| 项目 | 内容 |
|------|------|
| **测试步骤** | 使用没有 `create` 权限的账号登录,访问 SPC采集配置 页面 |
| **预期结果** | 工具栏不显示「新增」按钮 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-047无 edit 权限时隐藏编辑按钮
| 项目 | 内容 |
|------|------|
| **测试步骤** | 使用没有 `edit` 权限的账号登录,访问 SPC采集配置 页面 |
| **预期结果** | 行内操作列不显示「编辑」按钮 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-048无 delete 权限时隐藏删除按钮
| 项目 | 内容 |
|------|------|
| **测试步骤** | 使用没有 `delete` 权限的账号登录,访问 SPC采集配置 页面 |
| **预期结果** | 行内操作列不显示「删除」按钮 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### 3.9 错误处理
#### TC-SCC-049网络异常 - 列表加载失败
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 关闭后端服务或断开网络 2. 刷新 SPC采集配置 页面 |
| **预期结果** | 表格 loading 状态结束,显示空数据占位;页面顶部弹出红色错误提示(来自全局拦截器);表格不卡死 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
#### TC-SCC-050网络异常 - 提交失败
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 填写完整数据 3. 在点击「确定」之前断开网络 4. 点击「确定」 |
| **预期结果** | 弹框不关闭loading 状态结束;弹出红色错误提示;用户可修改后重试 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
---
## 四、测试结果汇总
| 用例编号 | 测试项 | 结果 | 问题摘要 |
|:--------:|--------|:----:|---------|
| TC-SCC-001 | 菜单导航与页面加载 | ⬜ | |
| TC-SCC-002 | 列表表格列头与数据展示 | ⬜ | |
| TC-SCC-003 | 状态列 Tag 展示 | ⬜ | |
| TC-SCC-004 | 工具栏按钮显示 | ⬜ | |
| TC-SCC-005 | 表格自适应高度 | ⬜ | |
| TC-SCC-006 | 按采集编码精确搜索 | ⬜ | |
| TC-SCC-007 | 按采集编码模糊搜索 | ⬜ | |
| TC-SCC-008 | 按采集名称搜索 | ⬜ | |
| TC-SCC-009 | 按 SCADA 节点搜索 | ⬜ | |
| TC-SCC-010 | 按状态筛选 | ⬜ | |
| TC-SCC-011 | 组合条件搜索 | ⬜ | |
| TC-SCC-012 | 回车键触发搜索 | ⬜ | |
| TC-SCC-013 | 重置搜索 | ⬜ | |
| TC-SCC-014 | 搜索无结果 | ⬜ | |
| TC-SCC-015 | 分页默认显示 | ⬜ | |
| TC-SCC-016 | 切换每页条数 | ⬜ | |
| TC-SCC-017 | 翻页功能 | ⬜ | |
| TC-SCC-018 | 打开新增弹框 | ⬜ | |
| TC-SCC-019 | 新增表单必填校验 - 采集编码 | ⬜ | |
| TC-SCC-020 | 新增表单必填校验 - 采集名称 | ⬜ | |
| TC-SCC-021 | 新增表单必填校验 - SCADA 节点 | ⬜ | |
| TC-SCC-022 | 新增表单必填校验 - 采集类型 | ⬜ | |
| TC-SCC-023 | 新增表单必填校验 - 状态 | ⬜ | |
| TC-SCC-024 | 新增成功 - 实时采集类型 | ⬜ | |
| TC-SCC-025 | 新增成功 - 周期采集类型 | ⬜ | |
| TC-SCC-026 | 新增成功 - 触发采集类型 | ⬜ | |
| TC-SCC-027 | 新增 - 编码长度校验 | ⬜ | |
| TC-SCC-028 | 新增 - 编码重复 | ⬜ | |
| TC-SCC-029 | 取消新增 | ⬜ | |
| TC-SCC-030 | 新增 - 备注多行输入 | ⬜ | |
| TC-SCC-031 | 打开编辑弹框 | ⬜ | |
| TC-SCC-032 | 编辑成功 - 修改名称 | ⬜ | |
| TC-SCC-033 | 编辑成功 - 修改状态 | ⬜ | |
| TC-SCC-034 | 编辑成功 - 修改采集间隔 | ⬜ | |
| TC-SCC-035 | 编辑后清空必填项 - 采集名称 | ⬜ | |
| TC-SCC-036 | 编辑后清空必填项 - SCADA 节点 | ⬜ | |
| TC-SCC-037 | 取消编辑 | ⬜ | |
| TC-SCC-038 | 删除确认弹框 | ⬜ | |
| TC-SCC-039 | 取消删除 | ⬜ | |
| TC-SCC-040 | 删除成功 | ⬜ | |
| TC-SCC-041 | 删除最后一行后页码修正 | ⬜ | |
| TC-SCC-042 | 中文显示 | ⬜ | |
| TC-SCC-043 | 英文显示 | ⬜ | |
| TC-SCC-044 | 弹框 i18n 自动响应 | ⬜ | |
| TC-SCC-045 | 缺失 key 校验 | ⬜ | |
| TC-SCC-046 | 无 create 权限时隐藏新增按钮 | ⬜ | |
| TC-SCC-047 | 无 edit 权限时隐藏编辑按钮 | ⬜ | |
| TC-SCC-048 | 无 delete 权限时隐藏删除按钮 | ⬜ | |
| TC-SCC-049 | 网络异常 - 列表加载失败 | ⬜ | |
| TC-SCC-050 | 网络异常 - 提交失败 | ⬜ | |
---
## 五、问题记录
| 序号 | 用例编号 | 问题描述 | 复现步骤 | 严重程度 | 截图 | 处理状态 | 责任人 |
|:----:|:--------:|---------|---------|:--------:|:----:|:--------:|--------|
| 1 | | | | | | | |
| 2 | | | | | | | |
| 3 | | | | | | | |
---
## 六、测试结论
| 项目 | 描述 |
|------|------|
| 测试用例总数 | 50 |
| 通过用例数 | |
| 未通过用例数 | |
| 通过率 | |
| 是否达到上线标准 | ⬜ 是 / ⬜ 否 |
| 备注 | |
**测试人员**________________
**测试日期**________________
**审核人员**________________
**审核日期**________________

View File

@@ -0,0 +1,40 @@
# 功能测试 - 反向追溯
> 模块:数据中台 / 基础追溯 / 反向追溯 (Backward Traceability)
> 路由:`/data_middleground/basic_traceability/reverse_direction_traceability`
## 测试前置条件
- 测试账号具备访问“反向追溯”的菜单权限。
- 准备至少 2 个电池条码:
- 一个存在完整反向追溯关系图的电池条码。
- 一个不存在追溯数据或数据为空的电池条码。
- 后端接口 `data_middleground/basic_traceability/reverse_direction_traceability/get_data``export_tree` 可正常访问。
## 测试任务列表
| 序号 | 测试项 | 操作步骤 | 预期结果 |
|---:|---|---|---|
| 1 | 页面入口 | 从菜单进入“反向追溯”,或直接访问 `/data_middleground/basic_traceability/reverse_direction_traceability` | 页面正常打开,显示电池条码输入框、查询、导出、重置按钮和空态区域 |
| 2 | 空输入查询 | 不输入电池条码,点击“查询” | 页面提示请输入电池条码,不发起有效查询 |
| 3 | 有效条码查询 | 输入存在追溯数据的电池条码,点击“查询” | 页面通过 relation-graph 展示追溯图谱,节点包含物料名称、编码、批次、工序、时间、设备等信息 |
| 4 | 无数据条码查询 | 输入不存在追溯数据的电池条码,点击“查询” | 页面保持空态或显示无节点,不出现脚本错误 |
| 5 | 横向/纵向切换 | 查询出数据后,切换“横向图谱”和“纵向图谱” | 追溯节点展示方向切换,页面不丢失数据 |
| 6 | 图谱拖拽与缩放 | 查询出数据后,在图谱空白区域拖拽,并使用鼠标滚轮缩放 | 图谱内容可以平移和缩放,节点不会被页面容器裁切 |
| 7 | 节点内容完整性 | 查看包含较多字段的节点,滚动节点内容区域 | 节点卡片外框完整显示,字段内容可在节点内部滚动查看 |
| 8 | 物料编码定位 | 查询出数据后,输入某个节点的物料编码,点击定位确认 | 匹配节点高亮并居中聚焦到可视区域 |
| 9 | 物料批次定位 | 输入某个节点的物料批次,点击定位确认 | 匹配节点高亮并居中聚焦到可视区域 |
| 10 | 工序单元定位 | 输入某个制成品节点的工序单元编码,点击定位确认 | 匹配节点高亮并居中聚焦到可视区域;不存在时提示未找到匹配节点 |
| 11 | 导出前校验 | 未输入电池条码时点击“导出” | 页面提示请输入电池条码 |
| 12 | 查询前导出 | 输入电池条码但未查询出追溯树,点击“导出” | 页面提示请先查询追溯数据后再导出 |
| 13 | 正常导出 | 查询出追溯树后点击“导出” | 调用导出接口,浏览器开始下载或打开导出文件 |
| 14 | 重置功能 | 查询出追溯树后点击“重置” | 输入框、追溯树、定位输入和高亮状态全部清空 |
| 15 | 国际化检查 | 切换中英文语言后重新进入页面 | 页面按钮、节点字段和提示文案随语言切换显示 |
## 回归关注点
- 接口返回 `relation_graph.nodes``relation_graph.lines` 为空时页面不能报错。
- 图谱必须使用 `relation-graph` 渲染,支持拖拽、缩放和定位聚焦。
- 节点字段较多时,节点卡片外框不应被裁切,内容应可在卡片内部滚动查看。
- 导出接口参数中的 `tree_list` 应为当前追溯树节点数组 JSON。
- 路由参数携带 `battery_id` 时,页面应能自动查询对应追溯数据。

View File

@@ -0,0 +1,31 @@
# 功能测试 - 托盘追溯
> 模块:数据中台 / 基础追溯 / 托盘追溯 (Tray Traceability)
> 路由:`/data_middleground/produce/traceability/tray`
## 测试前置条件
- 测试账号具备访问“托盘追溯”和“电池追溯”的菜单权限。
- 准备至少 1 个存在电池明细和工序时间线的托盘号。
- 后端接口 `tray``traydetail``batteryactive` 可正常访问。
## 测试任务列表
| 序号 | 测试项 | 操作步骤 | 预期结果 |
|---:|---|---|---|
| 1 | 页面入口 | 进入“托盘追溯”页面 | 页面显示托盘号输入框、查询、重置按钮和托盘列表 |
| 2 | 托盘查询 | 输入有效托盘号并查询 | 表格展示托盘、批次、LOT、激活状态、投入电池数和时间信息 |
| 3 | 空数据查询 | 输入无数据托盘号并查询 | 表格显示空态,页面不报错 |
| 4 | 打开电池明细 | 点击某行“电池明细” | 打开全屏抽屉,展示左侧工序时间线和右侧电池明细表 |
| 5 | 明细搜索 | 在抽屉内输入电池条码关键字 | 明细表按电池条码过滤 |
| 6 | 取消激活校验 | 不选择电池,点击取消电池激活 | 页面提示请至少选择一个电池 |
| 7 | 取消激活 | 选择一个或多个电池后点击取消电池激活 | 调用取消激活接口,成功后刷新明细 |
| 8 | 跳转电池追溯 | 点击明细中的电池条码 | 跳转到电池追溯页面并携带 battery_id 查询参数 |
| 9 | 重置功能 | 查询后点击重置 | 托盘号、列表和分页状态清空 |
| 10 | 国际化检查 | 切换中英文语言后重新进入页面 | 页面按钮、表格列和抽屉文案随语言切换显示 |
## 回归关注点
- 电池明细过滤需要排除空电池条码和 0。
- 取消激活接口参数 `batterData` 必须是已选择电池数组的 JSON 字符串。
- 电池条码跳转需保留 `battery_id` 查询参数。

View File

@@ -0,0 +1,14 @@
# 功能测试任务列表 - 排班日历
> 路由:`/system_settings/organization/production_shift_calender`
| 序号 | 测试项 | 操作步骤 | 预期结果 | 结果 |
|---|---|---|---|---|
| 1 | 页面入口 | 从菜单进入“排班日历” | 页面正常打开,展示当前月份日历 | ☐ |
| 2 | 初始数据加载 | 打开页面后观察日历单元格 | 系统请求当前日历可视范围的排班数据,并在日期下显示班次计划标签 | ☐ |
| 3 | 休息日展示 | 查看包含休息日的日期 | 休息日以灰色标签显示“休” | ☐ |
| 4 | 工作日展示 | 查看包含排班的日期 | 日期下展示班次计划标签 | ☐ |
| 5 | 明细悬浮 | 鼠标悬浮工作日班次计划标签 | 弹出层展示班次名称、开始/结束时间、绑定班组和跨天标识 | ☐ |
| 6 | 跨月切换 | 点击日历上一月/下一月 | 日历切换月份并重新加载新可视范围数据 | ☐ |
| 7 | 选择日期 | 点击任意日期 | 日期高亮状态正常,不影响排班数据显示 | ☐ |
| 8 | 空数据展示 | 切换到无排班数据的月份 | 日历正常显示,无错误提示或残留旧数据 | ☐ |

View File

@@ -0,0 +1,33 @@
# 功能测试 - 正向追溯
> 模块:数据中台 / 基础追溯 / 正向追溯 (Forward Traceability)
> 路由:`/data_middleground/basic_traceability/positive_direction_traceability`
## 测试前置条件
- 测试账号具备访问“正向追溯”和“反向追溯”的菜单权限。
- 准备至少一组可查询到数据的物料编码和物料批次。
- 准备至少一个可查询到数据的半成品码。
- 后端接口 `data_middleground/basic_traceability/positive_direction_traceability/list``export_task` 可正常访问。
## 测试任务列表
| 序号 | 测试项 | 操作步骤 | 预期结果 |
|---:|---|---|---|
| 1 | 页面入口 | 从菜单进入“正向追溯”,或直接访问路由 | 页面正常打开,显示物料编码、物料批次、半成品码筛选项和查询、导出、重置按钮 |
| 2 | 初始查询 | 进入页面后等待默认查询完成 | 表格正常渲染,空数据时显示空态,不出现脚本错误 |
| 3 | 物料编码校验 | 只输入物料编码,不输入物料批次,点击查询 | 页面提示请输入物料批次,不发起有效查询 |
| 4 | 物料批次查询 | 输入物料编码和物料批次,点击查询 | 表格展示匹配数据,包含电池条码、批次号、物料、设备、工序和完成时间 |
| 5 | 半成品码查询 | 输入半成品码,点击查询 | 表格展示匹配数据或空态,页面不报错 |
| 6 | 分页切换 | 查询出多条数据后切换分页 | 当前页数据正确变化,总数显示正确 |
| 7 | 跳转反向追溯 | 点击某行“反向追溯” | 跳转到反向追溯页面,并携带当前行电池条码自动查询 |
| 8 | 导出前校验 | 不输入任何筛选条件时点击导出 | 页面提示请选择筛选条件 |
| 9 | 创建导出任务 | 输入筛选条件后点击导出并确认 | 调用导出任务接口,提示创建下载任务成功,并跳转任务页面 |
| 10 | 重置功能 | 输入筛选条件并查询后点击重置 | 筛选项清空,分页回到第一页并重新加载数据 |
| 11 | 国际化检查 | 切换中英文语言后重新进入页面 | 页面按钮、表格列名和提示文案随语言切换显示 |
## 回归关注点
- 物料编码存在时必须同时输入物料批次。
- 导出任务必须携带当前筛选条件、总数和 `action=download`
- 反向追溯跳转必须使用行数据中的 `battery_id`

View File

@@ -0,0 +1,19 @@
# 功能测试任务列表 - 班次管理
> 路由:`/system_settings/organization/production_shift_management`
| 序号 | 测试项 | 操作步骤 | 预期结果 | 结果 |
|---|---|---|---|---|
| 1 | 页面入口 | 从菜单进入“班次管理” | 页面正常打开,展示班次计划名称、编码、起止时间、状态、创建/更新时间 | ☐ |
| 2 | 条件查询 | 输入计划名称、编码或创建时间后查询 | 列表按条件刷新 | ☐ |
| 3 | 新增校验 | 点击新增,不填名称、编码或时间范围直接确认 | 显示必填校验 | ☐ |
| 4 | 新增班次计划 | 填写计划信息、选择班组、添加班次明细后确认 | 保存成功,列表出现新计划 | ☐ |
| 5 | 班组绑定唯一性 | 两条班次明细绑定同一个班组 | 第二次绑定被阻止并提示 | ☐ |
| 6 | 明细必填校验 | 添加班次明细但缺少名称、开始时间或结束时间 | 提示对应行缺失字段 | ☐ |
| 7 | 编辑班次计划 | 点击编辑,修改状态、休息日、明细后确认 | 保存成功,重新打开可回显新数据 | ☐ |
| 8 | 单条删除 | 点击删除并确认 | 计划删除成功 | ☐ |
| 9 | 批量删除 | 勾选多条计划后批量删除 | 所选计划删除成功 | ☐ |
| 10 | 导入模板 | 点击导入后下载模板 | 浏览器下载班次计划导入模板 | ☐ |
| 11 | 导入数据 | 选择合法 xls/xlsx 文件并确认导入 | 预览展示后提交成功,列表刷新 | ☐ |
| 12 | 导出任务 | 点击导出并确认 | 提示下载任务创建成功 | ☐ |
| 13 | 权限按钮 | 使用缺少权限账号进入页面 | 对应新增/编辑/删除/导入/导出按钮隐藏或不可操作 | ☐ |

View File

@@ -0,0 +1,19 @@
# 功能测试任务列表 - 班组管理
> 路由:`/system_settings/organization/production_team_manage`
| 序号 | 测试项 | 操作步骤 | 预期结果 | 结果 |
|---|---|---|---|---|
| 1 | 页面入口 | 从菜单进入“班组管理” | 页面正常打开,展示班组名称、所属厂区、所属产线、创建/更新时间 | ☐ |
| 2 | 条件查询 | 输入班组名称、选择厂区/产线或创建时间后查询 | 列表按条件刷新 | ☐ |
| 3 | 新增校验 | 点击新增,不填班组名称、厂区或产线直接确认 | 显示必填校验,不提交 | ☐ |
| 4 | 新增班组 | 填写班组信息,添加成员并设置班组长后确认 | 提示操作成功,列表出现新班组 | ☐ |
| 5 | 班组长唯一性 | 添加多个成员并尝试设置两个班组长 | 第二个班组长被拦截,提示只允许一个班组长 | ☐ |
| 6 | 编辑班组 | 点击编辑,修改成员或班组信息后确认 | 保存成功,重新打开可看到新数据 | ☐ |
| 7 | 删除成员 | 编辑已有班组,删除已有成员 | 成员删除成功,列表刷新 | ☐ |
| 8 | 单条删除 | 点击行内删除并确认 | 班组删除成功 | ☐ |
| 9 | 批量删除 | 勾选多条数据后点击批量删除并确认 | 所选班组删除成功 | ☐ |
| 10 | 导入模板 | 点击导入后下载模板 | 浏览器下载班组导入模板 | ☐ |
| 11 | 导入数据 | 选择合法 xls/xlsx 文件并确认导入 | 预览数据正确,提交后提示成功并刷新列表 | ☐ |
| 12 | 导出任务 | 点击导出并确认 | 提示下载任务创建成功 | ☐ |
| 13 | 权限按钮 | 使用缺少权限账号进入页面 | 对应新增/编辑/删除/导入/导出按钮隐藏或不可操作 | ☐ |

View File

@@ -0,0 +1,36 @@
# 功能测试 - 电池复投管理
> 模块:计划与生产 / 生产监控 / 电池复投管理 (Rework Management)
> 路由:`/planning_production/produce/monitor/set_battery_rebatch`
## 测试前置条件
- 测试账号具备访问“电池复投管理”的菜单权限。
- 准备至少 3 个可用于验证的电池条码,其中包含:
- 允许复投的电池条码。
- 不允许复投或不存在的电池条码。
- 已激活和未激活状态各一条。
- 后端 Workerman 服务可用,接口 `production_configuration/workerman/send` 可正常响应。
## 测试任务列表
| 序号 | 测试项 | 操作步骤 | 预期结果 |
|---:|---|---|---|
| 1 | 页面入口 | 从菜单进入“电池复投管理”页面,或直接访问 `/planning_production/produce/monitor/set_battery_rebatch` | 页面正常打开,显示电池条码输入框、验证数据、重置、复投激活按钮和空表格 |
| 2 | 单个电池验证 | 在电池条码输入框输入一条有效电池条码,点击“验证数据” | 表格展示该电池的批次、托盘、流水号、激活状态、档位、上一工序和当前工序 |
| 3 | 多电池粘贴验证 | 在输入框输入多个条码,使用逗号、空格或换行分隔,点击“验证数据” | 系统可自动规范化输入并返回多行电池数据 |
| 4 | 多电池弹窗输入 | 点击输入框右侧导入按钮,在弹窗中每行输入一个电池条码,点击“确定”后再点击“验证数据” | 输入框自动填入逗号分隔条码,表格展示对应验证数据 |
| 5 | 空输入校验 | 清空电池条码,点击“验证数据” | 页面提示“请输入电池条码数据”,不发起有效验证 |
| 6 | 重置功能 | 输入条码并验证出表格数据后,点击“重置” | 输入框、表格数据和已选行清空 |
| 7 | 全部复投激活 | 验证出多条可复投电池数据,不勾选表格行,点击“复投激活”并确认 | 请求提交表格内全部电池条码,成功后提示复投激活操作成功 |
| 8 | 选中行复投激活 | 验证出多条电池数据,勾选其中一部分,点击“复投激活”并确认 | 仅提交被勾选的电池条码,成功后提示复投激活操作成功 |
| 9 | 未验证直接复投 | 输入电池条码但不点击“验证数据”,直接点击“复投激活” | 页面提示需要先验证电池数据,不提交 Workerman 复投请求 |
| 10 | 复投取消 | 验证出表格数据,点击“复投激活”,在确认框点击取消 | 不提交复投请求,页面数据保持不变 |
| 11 | 后端失败提示 | 使用后端会返回失败的电池数据执行复投 | 页面显示后端错误信息或“复投激活失败”提示 |
| 12 | 国际化检查 | 切换中英文语言后重新进入页面 | 页面按钮、表格列和提示文案随语言切换显示 |
## 回归关注点
- 验证接口返回空数据时,表格应显示空态且页面不报错。
- 表格行勾选后再重置,已选状态应同步清空。
- 复投激活接口调用参数中的 `action` 应为 `set_battery_rebatch``battery_ids` 应与测试输入或勾选行一致。

View File

@@ -0,0 +1,31 @@
# 功能测试 - 电池曲线
> 模块:数据中台 / 基础追溯 / 电池曲线 (Battery Curve)
> 路由:`/data_middleground/produce/traceability/curve`
## 测试前置条件
- 测试账号具备访问“电池曲线”的菜单权限。
- 准备至少 1 个存在曲线记录的电池条码。
- 后端接口 `planning_production/produce/traceability/batterytraceability``curveread``export` 可正常访问。
## 测试任务列表
| 序号 | 测试项 | 操作步骤 | 预期结果 |
|---:|---|---|---|
| 1 | 页面入口 | 从菜单进入“电池曲线”,或直接访问路由 | 页面正常打开,显示电池条码输入框、查询、重置按钮、左侧记录区和右侧图表区 |
| 2 | 有效条码查询 | 输入存在曲线记录的电池条码,点击查询 | 左侧展示批次、工序、上传时间记录,默认选中第一条记录 |
| 3 | 曲线渲染 | 查询成功后查看右侧图表 | 图表显示电流、电压、容量三组数据,支持 tooltip、图例和图片保存 |
| 4 | 记录切换 | 点击左侧不同曲线记录 | 右侧设备编码、电池通道和曲线数据随选中记录刷新 |
| 5 | 图表缩放 | 在图表上使用鼠标滚轮或触控板缩放 | 曲线支持局部缩放,不影响页面布局 |
| 6 | 整盘曲线 | 选中带有 URL 的记录,点击“查看整盘曲线” | 浏览器跳转或打开整盘曲线页面 |
| 7 | 导出所有数据 | 选中记录后点击“导出所有数据” | 调用导出接口并触发文件下载或新窗口打开 |
| 8 | 无数据查询 | 输入不存在曲线记录的条码并查询 | 左侧显示暂无曲线记录,右侧图表清空,页面不报错 |
| 9 | 重置功能 | 查询后点击重置 | 输入框、记录列表、选中记录和图表数据清空 |
| 10 | 国际化检查 | 切换中英文语言后重新进入页面 | 页面按钮、字段和图表标题随语言切换显示 |
## 回归关注点
- 曲线读取必须使用选中记录的 `id`
- 后端返回空数组时图表应清空,不应抛出异常。
- 导出链接需要兼容相对路径和完整 URL。

View File

@@ -0,0 +1,23 @@
# 功能测试 - 电池详情报表
> 模块:数据中台 / 生产报表 / 电池详情报表 (Battery Detail Report)
> 路由:`/data_middleground/produce/report/battery-detail`
## 测试任务列表
| 序号 | 测试项 | 操作步骤 | 预期结果 |
|---:|---|---|---|
| 1 | 页面入口 | 进入电池详情报表页面 | 页面显示工艺流程、批次、工序、托盘、时间筛选项 |
| 2 | 工艺选择 | 选择工艺流程 | 批次和工序下拉数据按工艺刷新 |
| 3 | 批次必填校验 | 不选批次点击查询 | 页面提示请选择批次 |
| 4 | 查询报表 | 选择批次和筛选条件后查询 | 表格按动态表头展示电池详情数据 |
| 5 | 分页切换 | 查询出多页数据后切换分页 | 当前页数据刷新,总数正确 |
| 6 | 导出任务 | 选择批次后点击导出并确认 | 创建导出任务成功并跳转任务页面 |
| 7 | 重置功能 | 点击重置 | 筛选项、动态表头、表格和分页清空 |
| 8 | 国际化检查 | 切换中英文语言 | 页面文案随语言切换 |
## 回归关注点
- 查询前必须先获取动态表头。
- 导出任务 action 必须为 `download`
- 后端返回嵌套表头时需要展开为可展示列。

View File

@@ -0,0 +1,31 @@
# 功能测试 - 电池追溯
> 模块:数据中台 / 基础追溯 / 电池追溯 (Battery Traceability)
> 路由:`/data_middleground/produce/traceability/battery`
## 测试前置条件
- 测试账号具备访问“电池追溯”的菜单权限。
- 准备至少 1 个存在工序过程数据的电池条码。
- 准备 1 个已激活电池和 1 个 NG 且未激活电池,用于验证操作按钮。
## 测试任务列表
| 序号 | 测试项 | 操作步骤 | 预期结果 |
|---:|---|---|---|
| 1 | 页面入口 | 进入“电池追溯”页面 | 页面显示电池条码输入框、查询、重置按钮和列表区域 |
| 2 | 电池查询 | 输入有效电池条码并查询 | 表格展示批次、托盘、LOT、激活状态、GOOD/NG、等级、不良信息、当前工序 |
| 3 | URL 参数查询 | 访问路由并携带 `?battery_id=xxx` | 页面自动按该电池条码查询 |
| 4 | 打开电池详情 | 点击某行“电池详情” | 弹出全屏详情,左侧展示工序列表,右侧展示默认工序数据 |
| 5 | 切换工序 | 在详情中点击不同工序 | 右侧工序数据按选中工序刷新 |
| 6 | 工序数据搜索 | 在详情中输入项目名称关键字 | 工序数据表按项目名称过滤 |
| 7 | 取消激活 | 对已激活电池点击取消激活并确认 | 调用取消激活接口,行状态更新为停止 |
| 8 | 复投激活 | 对 NG 且未激活电池点击复投激活并确认 | 调用 Workerman 复投接口,成功后刷新该电池数据 |
| 9 | 重置功能 | 查询后点击重置 | 电池条码、列表和分页状态清空 |
| 10 | 国际化检查 | 切换中英文语言后重新进入页面 | 页面按钮、表格列和弹窗文案随语言切换显示 |
## 回归关注点
- 工序详情接口必须携带当前行的批次、电池条码、托盘、LOT 和工序信息。
- 取消激活接口参数 `batterData` 必须是数组 JSON。
- 复投激活必须发送 `set_battery_rebatch` action。

View File

@@ -0,0 +1,15 @@
# 功能测试任务列表 - 监控设置
> 路由:`/system_settings/system_monitoring/setting`
| 序号 | 测试项 | 操作步骤 | 预期结果 | 结果 |
|---|---|---|---|---|
| 1 | 页面入口 | 从菜单进入“监控设置”,或直接访问路由 | 页面正常打开表格展示监控编码、名称、IP、端口、版本和预警阈值字段 | ☐ |
| 2 | 条件查询 | 输入监控编码或监控名称后点击“查询” | 列表按条件刷新,分页回到第一页 | ☐ |
| 3 | 重置查询 | 输入查询条件后点击“重置” | 查询条件清空,列表恢复默认数据 | ☐ |
| 4 | 新增必填校验 | 点击“新增”不填写编码、名称、IP 或端口直接确认 | 表单提示对应必填校验,不提交请求 | ☐ |
| 5 | 新增监控配置 | 填写编码、名称、IP、端口、刷新间隔、CPU/磁盘/内存阈值和 Python 版本后确认 | 弹窗关闭,提示操作成功,列表出现新增记录 | ☐ |
| 6 | 编辑监控配置 | 点击某条记录“编辑”,修改名称或阈值后确认 | 弹窗回显旧值,保存后列表展示新值 | ☐ |
| 7 | 删除取消 | 点击“删除”后在确认框选择取消 | 数据不删除,列表保持不变 | ☐ |
| 8 | 删除确认 | 点击“删除”后确认 | 提示操作成功,记录从列表移除,分页数量正确刷新 | ☐ |
| 9 | 权限按钮 | 使用无新增/编辑/删除权限的账号进入页面 | 对应按钮不显示或不可操作 | ☐ |

View File

@@ -0,0 +1,9 @@
# 设备保养日志功能测试任务列表
- [ ] 进入 `设备模型 / 设备保养 / 设备保养日志`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,10 @@
# 设备保养详情功能测试任务列表
- [ ] 进入 `设备模型 / 设备保养 / 设备保养详情`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,10 @@
# 设备保养项目功能测试任务列表
- [ ] 进入 `设备模型 / 设备保养 / 设备保养项目`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,11 @@
# 设备信息功能测试任务列表
- [ ] 进入 `设备模型 / 设备信息 / 设备信息`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 如当前账号有导出权限,点击导出可创建导出任务。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,22 @@
# 功能测试 - 设备履历报表
> 模块:数据中台 / 生产报表 / 设备履历报表 (Equipment History Report)
> 路由:`/data_middleground/produce/report/equipment-history`
## 测试任务列表
| 序号 | 测试项 | 操作步骤 | 预期结果 |
|---:|---|---|---|
| 1 | 页面入口 | 进入设备履历报表页面 | 页面显示设备编码、状态、时间范围筛选项和列表 |
| 2 | 设备编码查询 | 输入有效设备编码并查询 | 表格展示设备履历记录 |
| 3 | 状态筛选 | 选择运行/空闲/异常状态查询 | 表格仅展示匹配状态数据 |
| 4 | 时间范围筛选 | 选择开始结束时间后查询 | 表格展示时间范围内履历 |
| 5 | 分页切换 | 查询出多页数据后切换分页 | 当前页数据刷新,总数正确 |
| 6 | 重置功能 | 点击重置 | 筛选项、表格和分页状态清空 |
| 7 | 空数据 | 输入无匹配条件查询 | 显示空态,不出现脚本错误 |
| 8 | 国际化检查 | 切换中英文语言 | 页面文案随语言切换 |
## 回归关注点
- 接口必须调用 `report/device/log`method 为 `get.device.status.log`
- 时间范围需要拆分为 `start_time``end_time`

View File

@@ -0,0 +1,11 @@
# 设备损耗品寿命管理功能测试任务列表
- [ ] 进入 `设备模型 / 设备损耗品 / 设备损耗品寿命管理`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,11 @@
# 设备损耗品更换日志功能测试任务列表
- [ ] 进入 `设备模型 / 设备损耗品 / 设备损耗品更换日志`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,11 @@
# 设备损耗品类别功能测试任务列表
- [ ] 进入 `设备模型 / 设备损耗品 / 设备损耗品类别`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,11 @@
# 设备损耗品项目功能测试任务列表
- [ ] 进入 `设备模型 / 设备损耗品 / 设备损耗品项目`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,8 @@
# 设备点检日志功能测试任务列表
- [ ] 进入 `设备模型 / 设备点检 / 设备点检日志`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,9 @@
# 设备点检记录功能测试任务列表
- [ ] 进入 `设备模型 / 设备点检 / 设备点检记录`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,10 @@
# 设备点检项目功能测试任务列表
- [ ] 进入 `设备模型 / 设备点检 / 设备点检项目`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,11 @@
# 设备维修日志功能测试任务列表
- [ ] 进入 `设备模型 / 设备维修 / 设备维修日志`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,11 @@
# 设备维修管理功能测试任务列表
- [ ] 进入 `设备模型 / 设备维修 / 设备维修管理`,页面正常加载,无控制台报错。
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
- [ ] 输入关键字后点击查询,列表按条件刷新。
- [ ] 点击重置,查询条件清空并重新加载列表。
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
- [ ] 点击删除,确认后记录删除并刷新列表。
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。

View File

@@ -0,0 +1,36 @@
# 鹰眼功能测试任务列表
## 基础入口
- [ ] 进入 `数据中台 / 相关性分析 / 鹰眼`,页面正常加载,无控制台报错。
- [ ] 左侧分析条件区域显示生产批次、工序、NG 码三个筛选项和分析按钮。
- [ ] 页面右侧显示分析详情区域,未查询时为空状态。
## 查询条件
- [ ] 选择生产批次后,工序下拉框自动加载该批次下的不良工序列。
- [ ] 选择工序后NG 码下拉框自动切换为该工序对应的不良代码。
- [ ] 点击重置后批次、工序、NG 码、相关性结果和图表全部清空。
## 相关性分析
- [ ] 未选择生产批次时点击分析,系统提示需要选择批次。
- [ ] 未选择工序时点击分析,系统提示需要选择工序。
- [ ] 选择有效批次、工序和 NG 码后点击分析Pearson 相关性散点图正常渲染。
- [ ] PCC 表格显示工序参数、样本量、相关系数、P 值和相关性判断。
- [ ] 卡方表格显示工序参数、样本量、卡方值、P 值和相关性判断。
- [ ] 有不能参与分析的数据列时,顶部折叠区域展示对应参数名称。
## 图表与交互
- [ ] 散点图鼠标悬停时显示参数名称、相关系数和 P 值。
- [ ] P 值大于 0.05 的记录以蓝色相关状态显示。
- [ ] P 值小于或等于 0.05 的记录以红色不相关状态显示。
- [ ] 已选择 NG 码时点击表格中的相关性文字,弹出分析报告弹窗。
- [ ] 分析报告弹窗内按分类展示折线分布图,关闭后再次打开能正常刷新。
## 兼容性
- [ ] 页面在 1366px 宽度下表格和图表不重叠。
- [ ] 浏览器窗口缩放后图表能自动适配。
- [ ] 切换不同批次再次分析,旧批次结果不会残留。

View File

@@ -0,0 +1,140 @@
# 功能测试流程文档 ——【工艺流程】
> 本文档为【工艺流程】功能补齐后的独立测试文档。测试人员请按以下流程逐步执行,对通过的用例在“通过”列打勾(`[x]`),未通过的用例在“问题记录”列描述具体现象。
| 项目名称 | MES-UI生产主数据 → 工艺模型 → 工艺流程) |
| --- | --- |
| 文档版本 | v1.0 |
| 适用版本 | mes-ui 本次迁移版本 |
| 编写日期 | 2026-06-22 |
| 测试入口 | 菜单:生产主数据 → 工艺模型 → 工艺流程 |
| 关联文件 | `src/views/production-master-data/process-model/process-routing/index.vue``src/views/production-master-data/process-model/process-routing-card/index.vue``src/api/production-master-data/process-routing-card.js``src/api/production-master-data/calculation-script.js` |
---
## 一、测试环境配置要求
| 项 | 要求 |
| --- | --- |
| 后台环境 | Webman 已部署 `production_configuration/technology_model/technology_flow``technology_flow_process``calculation_script` 相关接口 |
| 前端环境 | 使用 Node 18.16.0,执行 `pnpm run serve` 启动 V2 项目 |
| 登录账号 | 拥有工艺流程、流程卡、设定值、结果参数、温度补偿、计算脚本相关权限点 |
| 数据准备 | 至少 1 个流程类别、1 个产品型号、多个工序单元;至少 1 个未绑定批次的工艺流程 |
| 浏览器工具 | 打开 DevTools → Network 与 Console便于核对接口参数和异常 |
---
## 二、测试前置条件
1. 已成功登录系统,侧边栏可进入 **生产主数据 → 工艺模型 → 工艺流程**
2. 工艺流程列表能正常加载,且存在可进入“设置工序”的流程。
3. 测试账号拥有以下权限点:新增、编辑、删除、复制、设置工序、排序、设定值、结果参数、温度补偿、计算脚本、查看日志。
4. 浏览器语言分别切换为简体中文 / English 时页面无 i18n key 缺失。
---
## 三、测试用例
### 3.1 工艺流程主列表
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.1.1 | 进入“工艺流程”菜单 | 列表加载成功,展示编码、名称、流程类别、产品、备注、创建人、创建时间、操作 | | [ ] | |
| 3.1.2 | 按编码、名称、流程类别、产品分别查询 | 请求参数正确,列表按条件刷新 | | [ ] | |
| 3.1.3 | 点击重置 | 查询条件清空,列表恢复第一页 | | [ ] | |
| 3.1.4 | 新增工艺流程并保存 | 调用 `technology_flow/create`,保存成功后列表刷新 | | [ ] | |
| 3.1.5 | 编辑工艺流程 | 表单回显正确,编码禁用,保存后列表更新 | | [ ] | |
| 3.1.6 | 复制工艺流程 | 弹出确认框;确认后调用 `technology_flow/copy` 并刷新列表 | | [ ] | |
| 3.1.7 | 删除未绑定批次流程 | 弹出确认框;确认后调用删除接口并刷新 | | [ ] | |
| 3.1.8 | 删除已绑定批次流程 | 页面提示已绑定批次不可删除,不发删除请求 | | [ ] | |
### 3.2 流程卡工序维护
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.2.1 | 点击列表行“设置工序” | 进入流程卡页面,展示工艺信息和工序明细 | | [ ] | |
| 3.2.2 | 点击“新增”选择工序单元 | 自动生成工序编码/名称,并按工序单元编码自动设置通道检测 | | [ ] | |
| 3.2.3 | 新增工序保存 | 调用 `technology_flow_process/create`,参数包含 `flow_id``workingsubclass_id``code``name``pin_check` | | [ ] | |
| 3.2.4 | 编辑工序 | 工序单元、编码、名称禁用,通道检测可回显;保存调用 `edit` | | [ ] | |
| 3.2.5 | 删除工序 | 调用 `technology_flow_process/delete`,参数包含 `id: []``flow_id` | | [ ] | |
| 3.2.6 | 上移/下移工序 | 调用 `move_up` / `move_down`,排序刷新正确 | | [ ] | |
| 3.2.7 | 已绑定批次流程 | 新增、删除、排序被限制或提示不可操作 | | [ ] | |
### 3.3 设定值
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.3.1 | 点击有 `setting_plugin` 的工序“设定值” | 弹出设定值窗口,显示插件类型、工序编码和现有 JSON | | [ ] | |
| 3.3.2 | 输入合法 JSON 并保存 | 调用 `technology_flow_process/set_setting``setting` 为 JSON 字符串 | | [ ] | |
| 3.3.3 | 输入非法 JSON | 页面提示 JSON 格式不正确,不提交接口 | | [ ] | |
### 3.4 结果参数
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.4.1 | 点击任一工序“结果参数” | 弹窗按当前 `flow_process_id` 调用 `get_optional_params_details` | | [ ] | |
| 3.4.2 | 按名称/参数查询 | 请求包含 `process_id``name``code`,列表刷新 | | [ ] | |
| 3.4.3 | 点击“添加结果参数” | 调用 `get_all_workingsubclass_params`,左侧显示全部参数,右侧显示已选参数 | | [ ] | |
| 3.4.4 | 勾选参数并同步到右侧后提交 | 调用 `add_optional_params``optional_params` 为 JSON 字符串,列表刷新 | | [ ] | |
| 3.4.5 | 未变更直接提交 | 页面提示请选择结果参数,不提交保存 | | [ ] | |
### 3.5 温度补偿
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.5.1 | 对化成/分容类工序点击“温度补偿” | 打开抽屉,调用 `get_step``get_temperature_list` | | [ ] | |
| 3.5.2 | 选择开始/结束工步 | 开始大于结束时出现提示 | | [ ] | |
| 3.5.3 | 新增温度补偿行并保存 | 调用 `create_temperature`,包含 `process_id`、工步范围、`temp_data` | | [ ] | |
| 3.5.4 | 输入非数字温度或补偿值 | 页面提示必须为数字,不提交 | | [ ] | |
| 3.5.5 | 输入重复温度 | 页面提示重复温度,不提交 | | [ ] | |
| 3.5.6 | 下载模板 | 调用 `get_temperature_template`,浏览器下载 xlsx 文件 | | [ ] | |
| 3.5.7 | 导入含“温度 / 温度补偿值”列的 Excel | 数据追加到表格并按温度升序排列 | | [ ] | |
### 3.6 计算脚本
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.6.1 | 点击工序“计算脚本” | 打开弹窗并调用 `calculation_script/all` | | [ ] | |
| 3.6.2 | 新增计算脚本 | 必填编码、名称、接口、接口位置、脚本内容;保存调用 `create` | | [ ] | |
| 3.6.3 | 编辑计算脚本 | 表单和脚本内容回显,保存调用 `edit` | | [ ] | |
| 3.6.4 | 删除计算脚本 | 弹出确认框,确认后调用 `delete` 并刷新列表 | | [ ] | |
| 3.6.5 | 脚本内容为空时保存 | 页面提示请输入脚本内容,不提交 | | [ ] | |
### 3.7 日志、权限与异常
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.7.1 | 点击“查看日志” | 打开日志抽屉并展示 `technology_flow_operate_log` | | [ ] | |
| 3.7.2 | 使用只读账号访问 | 新增/编辑/删除/排序/插件按钮按权限隐藏 | | [ ] | |
| 3.7.3 | 切换英文 | 主列表、流程卡、结果参数、温度补偿、计算脚本文案显示英文 | | [ ] | |
| 3.7.4 | 后端返回 500 或字段缺失 | 页面不白屏Console 无未捕获异常 | | [ ] | |
---
## 四、测试结果汇总
| 用例总数 | 通过 | 失败 | 阻塞 | 通过率 |
| --- | --- | --- | --- | --- |
| | | | | |
---
## 五、问题记录区
| 编号 | 用例编号 | 复现步骤 | 实际结果 | 严重程度 | 处理人 | 状态 | 备注 |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 1 | | | | | | | |
| 2 | | | | | | | | |
---
## 六、测试结论
| 项目 | 结论 |
| --- | --- |
| 功能完整性 | ☐ 满足 ☐ 部分缺失 ☐ 不满足 |
| 权限控制 | ☐ 正确 ☐ 存在漏洞 |
| 国际化 | ☐ 完整 ☐ 部分缺失 ☐ 缺失 |
| 是否可发布 | ☐ 是 ☐ 否(请说明阻塞问题) |
测试人员签字__________________ 日期__________

View File

@@ -0,0 +1,210 @@
# 功能测试流程文档 ——【异常不良管理】
> 本文档为【异常不良管理】功能迁移后的独立测试文档。测试人员请按以下流程逐步执行,对通过的用例在"通过"列打勾(`[x]`),未通过的用例在"问题记录"列描述具体现象(包括错误截图编号、操作步骤、实际/预期差异等)。
| 项目名称 | MES-UI生产主数据 → 产品模型 → 异常不良管理) |
| --- | --- |
| 文档版本 | v1.0 |
| 适用版本 | mes-ui 本次迁移版本 |
| 编写日期 | 2026-06-02 |
| 测试入口 | 菜单:生产主数据 → 产品模型 → 异常不良管理 |
| 关联文件 | [主页面](file:///d:/code/mes/mes-ui/src/views/production-master-data/product-model/product-ng-info/index.vue) · [导入组件](file:///d:/code/mes/mes-ui/src/views/production-master-data/product-model/product-ng-info/components/ImportDialog/index.vue) · [API](file:///d:/code/mes/mes-ui/src/api/production-master-data/product-ng-info.js) · [路由](file:///d:/code/mes/mes-ui/src/router/modules/production-master-data.js) · [文件工具](file:///d:/code/mes/mes-ui/src/utils/file.js) |
---
## 一、测试环境配置要求
| 项 | 要求 |
| --- | --- |
| 后台环境 | Webman + 已部署 `production_configuration/product_model/product_ng_info/` 路由接口;数据库中已创建 `product_ng_info``device_category` 数据表 |
| 前端环境 | `npm run serve` / `pnpm run serve` 启动 mes-ui 工程;浏览器推荐 Chrome 110+ |
| 登录账号 | 拥有「生产主数据 / 异常不良管理」菜单访问权限,且分配以下权限点:<br>· `…/product_ng_info/create`(新增 / 导入)<br>· `…/product_ng_info/edit`(编辑)<br>· `…/product_ng_info/delete`(删除 / 批量删除)<br>· `…/product_ng_info/export`(导出) |
| 网络要求 | 前后端网络互通;浏览器可访问 `VUE_APP_API` 环境变量对应域名 |
| 数据准备 | · 至少 3 条设备类别device_category数据<br>· 至少 5 条异常不良类别记录<br>· 准备一份合法格式的 Excel 导入文件(含 3 行导入数据)和一份缺少列的非法文件 |
| 浏览器工具 | 打开 DevToolsF12→ Network 与 Console便于抓取接口与异常 |
| 第三方库 | `xlsx` 已安装Excel 读写支持),确认 `node_modules/xlsx/` 目录存在 |
---
## 二、测试前置条件
1. 已成功登录系统,登录账号具备上述所有权限点。
2. 侧边栏显示 **生产主数据 → 产品模型 → 异常不良管理** 菜单可点击进入。
3. 浏览器语言切换为「简体中文」,界面文字全部为中文,无 `key is not defined` 或英文缺失。
4. 列表默认展示至少 5 条记录(通过 `product_ng_info/list` 接口返回)。
5. 浏览器缩放比例 100%;分辨率建议 1440×900 及以上。
6. DevTools 关闭缓存Network → Disable cache确保加载最新前端资源。
---
## 三、测试用例
> **字段说明**
> - 设备类别 `device_category_id`:必选,从设备类别 API 动态加载
> - 类别 `type`:必选,下拉值「异常(ERR)/不良(NG)」
> - 异常不良编码 `number`:必填,长度 1~100
> - 异常不良名称 `explain`:必填,长度 1~100
> - 备注 `note`:选填,多行文本
> - 列表展示字段:复选框 / 设备类别 / 异常不良类别 / 异常不良编码 / 异常不良名称 / 备注 / 操作
### 3.1 列表展示与加载
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.1.1 | 进入「异常不良管理」菜单 | 列表正常加载,无 JS 报错;表头依次为:复选框、设备类别、异常不良类别、异常不良编码、异常不良名称、备注、操作 | | [ ] | |
| 3.1.2 | 观察列表加载过程 | 列表加载期间显示 loading 遮罩动画,加载完成后消失 | | [ ] | |
| 3.1.3 | 列表为空时(搜索条件无匹配结果) | 表格区域显示空状态占位(如"暂无数据"),无 JavaScript 报错 | | [ ] | |
| 3.1.4 | 分页组件:跳转到第 2 页 | 请求参数 `page_no=2` 正确,数据刷新 | | [ ] | |
| 3.1.5 | 修改每页条数(如从 10 改为 20 | `page_size=20`,列表重载 | | [ ] | |
| 3.1.6 | 列表行内操作列固定在右侧,横向滚动查看 | 操作列不随滚动条消失,固定可见 | | [ ] | |
### 3.2 搜索功能
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.2.1 | 点击「设备类别」下拉框 → 从列表中选择一项 → 点击「查询」 | 列表仅展示所选设备类别的记录 | | [ ] | |
| 3.2.2 | 在「查询类型」下拉框中选择「异常」→ 点击「查询」 | 列表仅展示 `type=ERR` 的记录 | | [ ] | |
| 3.2.3 | 在「查询类型」下拉框中选择「不良」→ 点击「查询」 | 列表仅展示 `type=NG` 的记录 | | [ ] | |
| 3.2.4 | 在「异常不良编码」输入框输入关键字 → 点击「查询」 | 列表仅展示编码包含该关键字的记录 | | [ ] | |
| 3.2.5 | 在「异常不良名称」输入框输入关键字 → 点击「查询」 | 列表仅展示名称包含该关键字的记录 | | [ ] | |
| 3.2.6 | 设备类别 + 类型 + 编码同时填写 → 点击「查询」 | 列表为三条件 AND 过滤结果 | | [ ] | |
| 3.2.7 | 输入查询条件后点击「重置」 | 所有输入框、下拉框恢复初始状态,列表恢复为全量数据 | | [ ] | |
| 3.2.8 | 在搜索输入框中按回车键 | 等同于点击「查询」,触发列表刷新 | | [ ] | |
| 3.2.9 | 设备类别下拉框首次展开时(即 focus 事件) | 自动调用 `/device_category/all` 加载选项;未展开时不再重复请求 | | [ ] | |
### 3.3 新增
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.3.1 | 点击工具栏「新增」按钮 | 弹出标题为「新增异常不良类别」的对话框,表单为空 | | [ ] | |
| 3.3.2 | 新增弹框打开时,设备类别下拉框自动加载可选项 | 设备类别下拉列表有数据,与搜索时的下拉来源一致 | | [ ] | |
| 3.3.3 | 不填任何字段,点击「确定」 | 表单校验:设备类别、类别、编码、名称四个字段下方均红字提示必填 | | [ ] | |
| 3.3.4 | 仅选择设备类别与类别,不填编码 → 点击「确定」 | 仅编码字段提示必填;名称字段提示必填 | | [ ] | |
| 3.3.5 | 编码输入 101 字符 → 点击「确定」 | 编码字段下方提示「长度在1到100个字符」 | | [ ] | |
| 3.3.6 | 名称输入 101 字符 → 点击「确定」 | 名称字段下方提示「长度在1到100个字符」 | | [ ] | |
| 3.3.7 | 正常填写:设备类别=任意、类别=异常、编码=ERR-01、名称=设备宕机、备注=生产设备意外停机 → 点击「确定」 | 弹出"操作成功"提示,对话框自动关闭,列表自动刷新并出现该条记录 | | [ ] | |
| 3.3.8 | 新增弹框点击「取消」或右上角 × | 对话框关闭,列表未新增任何记录 | | [ ] | |
| 3.3.9 | 使用无 `product_ng_info/create` 权限的账号访问 | 工具栏不显示「新增」按钮 | | [ ] | |
| 3.3.10 | 后端返回「编码已存在」业务错误 | 页面友好提示错误原因,弹框不关闭(可修正后重试) | | [ ] | |
### 3.4 编辑
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.4.1 | 列表行点击「编辑」 | 弹出标题为「编辑异常不良类别」的对话框,表单字段回显该行当前数据 | | [ ] | |
| 3.4.2 | 清空编码后「确定」 | 提示编码必填 | | [ ] | |
| 3.4.3 | 修改名称为新值,备注保留为空 → 「确定」 | 操作成功,列表对应行名称更新,备注为空 | | [ ] | |
| 3.4.4 | 修改编码(与已有数据重复)→ 「确定」 | 后端返回重复提示,页面友好显示不崩溃 | | [ ] | |
| 3.4.5 | 编辑对话中点击「取消」 | 对话框关闭,列表数据未变化 | | [ ] | |
| 3.4.6 | 无 `product_ng_info/edit` 权限的账号 | 行内不显示「编辑」按钮 | | [ ] | |
| 3.4.7 | 两个标签页同时打开同一条编辑 → A 保存后 B 再次保存 | 后端返回最新数据的验证结果,不产生脏写 | | [ ] | |
### 3.5 删除(行内删除)
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.5.1 | 列表行点击「删除」 | 弹出确认框,提示「确定要执行该操作吗?」 | | [ ] | |
| 3.5.2 | 确认框点击「取消」 | 关闭确认框,数据未删除 | | [ ] | |
| 3.5.3 | 确认框点击「确定」 | 操作成功,列表自动移除该记录 | | [ ] | |
| 3.5.4 | 删除最后一页唯一一条数据 | 列表自动回退到上一页(或空状态),不出现空白页 | | [ ] | |
| 3.5.5 | 删除已被其他业务引用的记录 | 后端返回业务级错误提示,数据保留,页面不崩溃 | | [ ] | |
| 3.5.6 | 无 `product_ng_info/delete` 权限的账号 | 行内不显示「删除」按钮 | | [ ] | |
| 3.5.7 | 网络断开时点击「删除」 | 提示网络异常,数据未被误删 | | [ ] | |
### 3.6 批量删除
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.6.1 | 不勾选任何复选框,点击「批量删除」 | 提示"请先选择数据" | | [ ] | |
| 3.6.2 | 勾选 2~3 行记录 → 点击「批量删除」 | 弹出确认框「确定要删除所选异常不良类别吗?」 | | [ ] | |
| 3.6.3 | 确认框点击「确定」 | 选中的记录全部从列表消失,操作成功提示 | | [ ] | |
| 3.6.4 | 确认框点击「取消」 | 数据保留,勾选状态保留 | | [ ] | |
| 3.6.5 | 选中的行中包含已被引用的数据 | 后端返回针对性的业务错误提示,未删除任何数据 | | [ ] | |
| 3.6.6 | 勾选全选(表头复选框)→ 批量删除 | 所有可见页数据被选中并删除 | | [ ] | |
### 3.7 Excel 导入
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.7.1 | 点击工具栏「导入」按钮 | 弹出标题为「导入异常不良数据」的对话框,上方显示黄色警告提示 | | [ ] | |
| 3.7.2 | 点击「下载模板」按钮 | 浏览器下载 Excel 文件(文件名为「异常不良数据导入模版.xlsx」内容包含表头 | | [ ] | |
| 3.7.3 | 点击「选择文件」→ 选择非 Excel 文件(如 .txt | 提示"上传文件格式错误" | | [ ] | |
| 3.7.4 | 点击「选择文件」→ 选择列缺失的 Excel缺少"异常不良编码"列) | 提示"文件列缺失: 异常不良编码" | | [ ] | |
| 3.7.5 | 选择合法 Excel 文件(含 3 行数据) | 预览表格展示 3 行数据,列与 Excel 内容一致 | | [ ] | |
| 3.7.6 | 选择合法 Excel 后,再次选择另一个文件 | 上一个文件被替换,预览表格刷新为新文件数据 | | [ ] | |
| 3.7.7 | 预览数据无误后点击「确定」 | 提示"操作成功",弹框关闭,列表刷新,新数据出现在列表中 | | [ ] | |
| 3.7.8 | 未选择文件(预览表格为空)点击「确定」 | 提示"请先导入数据" | | [ ] | |
| 3.7.9 | 导入过程中点击「取消」或关闭弹框 | 操作中断,已读取的预览数据被清空 | | [ ] | |
| 3.7.10 | 无 `product_ng_info/create` 权限的账号 | 工具栏不显示「导入」按钮 | | [ ] | |
| 3.7.11 | 导入的 Excel 中设备类别名称在后端无法匹配 | 后端返回相应错误提示,列表不新增 | | [ ] | |
### 3.8 Excel 导出
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.8.1 | 点击工具栏「导出」按钮 | 弹出确认框「确定要导出当前查询结果吗?」 | | [ ] | |
| 3.8.2 | 确认框点击「取消」 | 提示"操作已取消",未触发任何请求 | | [ ] | |
| 3.8.3 | 确认框点击「确定」 | 提示"创建导出任务成功",自动跳转至任务管理页面 | | [ ] | |
| 3.8.4 | 在查询条件中筛选后再点击「导出」 | 后端收到的请求包含当前搜索条件 `device_category_id` / `type` / `number` / `explain` | | [ ] | |
| 3.8.5 | 无 `product_ng_info/export` 权限的账号 | 工具栏不显示「导出」按钮 | | [ ] | |
### 3.9 权限与国际化
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.9.1 | 切换为仅有「查询」权限的账号 | 仅能查看列表与查询,无新增/编辑/删除/导入/导出按钮 | | [ ] | |
| 3.9.2 | 切换为中文环境 → 英文环境 → 刷新页面 | 表头、按钮、弹框标题、验证提示语全部为英文 | | [ ] | |
| 3.9.3 | 中文下打开新增弹框 → 切换至英文 | 弹框标题、表单 label 立即切换为英文(无需关闭弹框) | | [ ] | |
| 3.9.4 | 英文环境下切换回中文 | 所有文案恢复中文 | | [ ] | |
| 3.9.5 | 英文下执行新增/编辑/导入功能,成功/失败提示 | 提示语为英文,含义正确 | | [ ] | |
### 3.10 异常与边界
| 用例编号 | 操作步骤 | 预期结果 | 实际结果 | 通过 | 问题记录 |
| --- | --- | --- | --- | --- | --- |
| 3.10.1 | 后端 `/list` 接口返回 500 错误 | 列表显示空状态或错误提示用 Message 弹窗展示,页面不白屏 | | [ ] | |
| 3.10.2 | 后端返回字段缺失(如某行缺少 `device_category` | 缺失字段列显示为空,不抛 JS 异常 | | [ ] | |
| 3.10.3 | 备注字段输入 5000 字符并保存 | 提交成功,列表备注列可滚动展示(建议使用省略号截断) | | [ ] | |
| 3.10.4 | 新增/编辑弹框打开后按 ESC 键 | 弹框关闭,表单状态被重置 | | [ ] | |
| 3.10.5 | 列表横向宽度超过浏览器视口 | 操作列固定在右侧,表格支持横向滚动 | | [ ] | |
| 3.10.6 | DevTools Console 全程监控 | 无 `Vue warn`、无未捕获 Promise 异常、无 i18n key 缺失警告 | | [ ] | |
| 3.10.7 | 快速连续点击「新增」→ 「确定」 | 提交按钮 loading 状态阻止重复提交 | | [ ] | |
| 3.10.8 | 设备类别 API 请求失败时展开搜索下拉 | 下拉框为空,页面不崩溃;重试正常 | | [ ] | |
---
## 四、测试结果汇总
| 用例总数 | 通过 | 失败 | 阻塞 | 通过率 |
| --- | --- | --- | --- | --- |
| | | | | |
---
## 五、问题记录区
| 编号 | 用例编号 | 复现步骤 | 实际结果 | 严重程度 | 处理人 | 状态 | 备注 |
| --- | --- | --- | --- | --- | --- | --- | --- |
| 1 | | | | | | | |
| 2 | | | | | | | |
| 3 | | | | | | | |
| 4 | | | | | | | |
| 5 | | | | | | | |
---
## 六、测试结论
| 项目 | 结论 |
| --- | --- |
| 功能完整性 | ☐ 满足 ☐ 部分缺失 ☐ 不满足 |
| 性能表现 | ☐ 良好 ☐ 一般 ☐ 差 |
| 权限控制 | ☐ 正确 ☐ 存在漏洞 |
| 国际化 | ☐ 完整 ☐ 部分缺失 ☐ 缺失 |
| 导入导出 | ☐ 正常 ☐ 部分异常 ☐ 不可用 |
| 是否可发布 | ☐ 是 ☐ 否(请说明阻塞问题) |
测试人员签字__________________ 日期__________
---
*本测试流程文档为【异常不良管理】功能迁移版本专用,请独立归档保存。*

View File

@@ -2848,11 +2848,392 @@
| 工艺流程类别 | 36 | | | |
| 产线设置 | 30 | | | |
| 工序单元 | 36 | | | |
| **合计** | **292** | | | |
| 班组管理 | 35 | | | |
| **合计** | **327** | | | |
---
# 十、工序单元功能测试
# 十、班组管理功能测试
> **迁移日期**2026-06-01
> **对应页面**`src/views/production-master-data/team-model/team-management/index.vue`
> **API 文件**`src/api/production-master-data/team-management.js`
> **路由路径**`/production_configuration/team_model/team_management`
> **页面结构**:搜索区(班组名称 + 所区下拉 + 产线下拉 + 创建时间范围 + 查询/重置/导出按钮)+ 数据表格 + 新增/编辑弹框(含班组信息和成员管理)+ 导入弹框
## 10.1 页面加载与数据展示
### TC-TM-001班组管理页面正常加载
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 登录系统 2. 点击菜单「生产配置 → 班组模型 → 班组管理」 |
| **预期结果** | 页面正常加载,显示班组列表表格,包含序号、班组名称、所属厂区、所属产线、创建时间、修改时间、操作列;搜索区包含班组名称输入框、所区下拉选择器、产线下拉选择器、创建时间范围选择器;底部有分页组件显示总条数 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-002表格列完整显示
| 项目 | 内容 |
|------|------|
| **测试步骤** | 查看班组列表表格的列头 |
| **预期结果** | 表格列依次为:序号、班组名称、所属厂区、所属产线、创建时间、修改时间、操作。各列宽度合理,内容不重叠 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-003工具栏按钮显示
| 项目 | 内容 |
|------|------|
| **测试步骤** | 查看表格上方的工具栏 |
| **预期结果** | 工具栏左侧显示「新增」、「批量删除」、「导入」按钮,右侧显示「导出」下拉按钮;各按钮类型和颜色符合设计规范 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-004行内操作按钮显示
| 项目 | 内容 |
|------|------|
| **测试步骤** | 查看表格每行的操作列 |
| **预期结果** | 每行操作列显示「编辑」按钮(带编辑图标)和「删除」按钮(红色危险按钮,带删除图标) |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
## 10.2 查询与搜索
### TC-TM-005按班组名称搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在「班组名称」输入框输入一个已知的班组名称 2. 点击「查询」按钮或按 Enter 键 |
| **预期结果** | 表格数据按班组名称模糊匹配过滤,仅显示匹配的班组记录;分页回到第 1 页 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-006按所区下拉筛选
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 点击搜索区「所区」下拉框 2. 选择一个具体所区 3. 点击「查询」按钮 |
| **预期结果** | 下拉框显示所有已存在的所区选项;选择某个所区后查询,表格仅显示属于该所区的班组记录 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-007按产线下拉筛选
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 先选择一个所区 2. 点击「所属产线」下拉框 3. 选择一个具体产线 4. 点击「查询」按钮 |
| **预期结果** | 产线下拉框显示所选所区下的所有产线选项;选择产线后查询,表格仅显示属于该产线的班组记录 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-008按创建时间范围搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 点击「最后创建时间」日期范围选择器 2. 选择一个时间范围 3. 点击「查询」按钮 |
| **预期结果** | 表格数据按创建时间范围过滤,仅显示在指定时间范围内创建的班组记录 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-009组合条件搜索
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 输入班组名称关键字 2. 同时选择一个所区和产线 3. 设置时间范围 4. 点击「查询」按钮 |
| **预期结果** | 表格数据按多个条件 AND 逻辑过滤,显示同时满足所有条件的记录 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-010重置搜索条件
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 输入搜索条件并查询 2. 点击「重置」按钮 |
| **预期结果** | 所有搜索条件清空(班组名称、所区、产线、时间范围);表格恢复显示全部数据;分页回到第 1 页 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
## 10.3 分页功能
### TC-TM-011分页切换
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 切换每页显示条数10/20/50/100 2. 点击下一页/上一页 3. 输入页码直接跳转 |
| **预期结果** | 分页切换正常,表格数据按分页正确加载;总条数显示正确;切换每页条数后当前页重置为第 1 页 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
## 10.4 新增班组
### TC-TM-012打开新增弹框
| 项目 | 内容 |
|------|------|
| **测试步骤** | 点击表格上方工具栏「新增」按钮 |
| **预期结果** | 弹出新增班组弹框,标题显示"新增班组";表单包含班组名称输入框、所属厂区下拉选择器、所属产线下拉选择器;成员管理区域显示"班组成员"标题和"添加成员"按钮 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-013新增班组—正常提交
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 输入班组名称(如"测试班组A" 3. 选择所属厂区 4. 选择所属产线 5. 点击"添加成员"按钮 6. 选择成员并设置负责人 7. 点击「确定」按钮 |
| **预期结果** | 弹框关闭,显示"操作成功"提示消息;表格自动刷新,新增的班组出现在列表中 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-014新增班组—表单验证必填项为空
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 不填写任何内容直接点击「确定」按钮 |
| **预期结果** | 班组名称字段提示"请输入班组名称";所属厂区字段提示"请选择所属厂区";所属产线字段提示"请选择所属产线";表单阻止提交 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-015新增班组—名称长度验证
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 在班组名称输入框输入 1 个字符或 21 个字符 3. 点击「确定」按钮 |
| **预期结果** | 提示"长度在 2 到 20 个字符",表单阻止提交 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-016新增班组—取消操作
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开新增弹框 2. 填写部分内容 3. 点击「取消」按钮 |
| **预期结果** | 弹框关闭,表格数据不变;再次打开新增弹框时表单已重置为空 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
## 10.5 编辑班组
### TC-TM-017打开编辑弹框并数据回填
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在表格中找到一条班组记录 2. 点击该行的「编辑」按钮 |
| **预期结果** | 弹出编辑班组弹框,标题显示"编辑班组";表单自动回填该班组的名称、所属厂区、所属产线数据;成员管理区域显示该班组的成员列表 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-018编辑班组—修改名称后提交
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 编辑一条班组 2. 修改班组名称为新值 3. 点击「确定」按钮 |
| **预期结果** | 弹框关闭,显示"操作成功"提示;表格自动刷新,该行显示更新后的班组名称 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-019编辑班组—修改所属厂区和产线后提交
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 编辑一条班组 2. 切换选择另一个厂区和产线 3. 点击「确定」按钮 |
| **预期结果** | 弹框关闭,操作成功;表格刷新后该行的「所属厂区」和「所属产线」列显示更新后的值 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-020编辑班组—修改成员信息
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 编辑一条班组 2. 在成员管理区域添加/删除成员 3. 设置负责人 4. 点击「确定」按钮 |
| **预期结果** | 弹框关闭,操作成功;表格刷新后班组成员信息更新 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
## 10.6 删除班组
### TC-TM-021删除班组—确认删除
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在表格中找到一条班组记录 2. 点击该行的「删除」按钮 3. 在弹出的确认框中点击「确定」 |
| **预期结果** | 弹出确认框,标题为"提示",内容为"确定要执行该操作吗?";点击确定后显示"操作成功"提示;表格自动刷新,该班组不再出现在列表中;分页正确调整 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-022删除班组—取消删除
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 点击某条班组记录的「删除」按钮 2. 在弹出的确认框中点击「取消」 |
| **预期结果** | 确认框关闭,该班组记录仍然保留在表格中,数据不变 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-023批量删除班组
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 勾选多条班组记录的复选框 2. 点击「批量删除」按钮 3. 在确认框中点击「确定」 |
| **预期结果** | 弹出确认框询问"确定要删除所选数据吗?";点击确定后显示"操作成功"提示;表格自动刷新,所选班组不再出现在列表中 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
## 10.7 导入功能
### TC-TM-024打开导入弹框
| 项目 | 内容 |
|------|------|
| **测试步骤** | 点击「导入」按钮 |
| **预期结果** | 弹出"生产班组数据导入"弹框,包含文件上传区域、下载模板按钮、预览表格等组件 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-025下载导入模板
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开导入弹框 2. 点击"下载模板"按钮 |
| **预期结果** | 成功下载Excel格式的导入模板文件文件包含正确的列标题班组名称、所属厂区、所属产线、成员名称、是否负责人等 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-026上传文件并预览
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 打开导入弹框 2. 选择符合模板格式的Excel文件 3. 查看预览表格 |
| **预期结果** | 文件成功上传预览表格正确显示Excel中的数据内容 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-027执行数据导入
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 上传有效数据文件 2. 点击「确定」按钮执行导入 |
| **预期结果** | 显示"导入成功"提示;表格自动刷新,导入的班组数据出现在列表中 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
## 10.8 导出功能
### TC-TM-028直接导出数据
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 点击「导出」下拉箭头 2. 选择"导出"选项 |
| **预期结果** | 成功下载Excel格式的班组数据文件包含当前页面显示的所有数据 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-029创建下载任务
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 点击「导出」下拉箭头 2. 选择"创建下载任务"选项 |
| **预期结果** | 显示"创建下载任务成功"提示;自动跳转到下载任务页面 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
## 10.9 多语言切换
### TC-TM-030切换到英文—页面标签
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 切换到英文语言 2. 查看班组管理页面 |
| **预期结果** | 所有标签、按钮、表头均切换为英文:搜索区标签 "Team Name" / "Area" / "Production Line";表格列头 "No." / "Team Name" / "Plant Area" / "Production Line" / "Create Time" / "Update Time" / "Actions";工具栏 "Add" / "Batch Delete" / "Import" / "Export";行按钮 "Edit" / "Delete" |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-031切换到英文—弹框标题与表单
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 切换到英文 2. 点击「Add」按钮打开新增弹框 3. 查看弹框内容 |
| **预期结果** | 弹框标题为 "Add Team";表单字段标签为英文;底部按钮为 "Cancel" / "Confirm";成员管理区域标签为英文 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-032切换到英文—提示信息
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 切换到英文 2. 执行新增/编辑/删除操作 |
| **预期结果** | 操作成功提示为 "Operation succeeded";删除确认框内容为 "Are you sure to delete?",按钮为 "Confirm" / "Cancel";校验提示为英文(如 "Please enter team name" |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-033英文下所有核心功能正常
| 项目 | 内容 |
|------|------|
| **测试步骤** | 在英文界面下执行完整操作流程:按名称搜索 → 按所区筛选 → 新增班组 → 编辑班组 → 删除班组 → 分页切换 → 导入导出 |
| **预期结果** | 所有功能正常运行,交互逻辑与中文界面一致,无 i18n key 缺失导致的未翻译文本 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
## 10.10 边界与异常场景
### TC-TM-034搜索关键词无匹配结果
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 在班组名称输入框输入一个不存在的名称(如"ZZZZZZZ" 2. 点击「查询」按钮 |
| **预期结果** | 表格显示空数据,分页显示总条数为 0页面无报错 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
### TC-TM-035删除后分页自动调整
| 项目 | 内容 |
|------|------|
| **测试步骤** | 1. 翻到最后一页 2. 如果该页只有 1 条数据,将其删除 |
| **预期结果** | 删除成功后自动跳转到上一页(当前页页码正确调整),不会停留在空页面 |
| **实际结果** | |
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
| **问题描述** | |
---
# 十一、工序单元功能测试
> **迁移日期**2026-06-01
> **对应页面**`src/views/production-master-data/process-model/process-step/index.vue`
@@ -3408,3 +3789,4 @@
> - v1.8 (2026-06-01)追加产线设置功能30 条用例)
> - v1.9 (2026-06-01)追加工序单元功能36 条用例)
> - v1.10 (2026-06-01)追加工序单元预设设定值和预设结果参数功能14 条用例)
> - v1.11 (2026-06-01)追加班组管理功能35 条用例)

View File

@@ -0,0 +1,79 @@
# 工艺流程Process Routing迁移分析方案
## 一、旧代码研读范围
- 旧页面:`/home/james/WEBMAN-VUE-APP-develop/webman-vue-app/src/views/production_configuration/technology_model/technology_flow/process.vue`
- 旧 API`src/api/production_configuration/technology_model/technology_flow.js``technology_flow_process.js``calculation_script.js`
- 旧组件:`components/ProcessPlugin/ResultParam``TemperatureSupp``CalculationScript``components/technology/technology-flow-model.vue`
- V2 页面:`src/views/production-master-data/process-model/process-routing/index.vue``process-routing-card/index.vue`
## 二、旧模块接口清单
| 接口 | 方法 | method 参数 | platform | 主要参数 | 返回数据使用 |
| --- | --- | --- | --- | --- | --- |
| `production_configuration/technology_model/technology_flow/list` | GET | `production_configuration_technology_model_technology_flow_list` | background | `page_no``page_size``code``name``flow_category_id``product_model_id` | 工艺流程主列表 |
| `technology_flow/create` | POST | `production_configuration_technology_model_technology_flow_create` | background | `code``name``flow_category_id``product_model_id``remark` | 新增流程 |
| `technology_flow/edit` | PUT | `production_configuration_technology_model_technology_flow_edit` | background | `id` + 表单字段 | 编辑流程 |
| `technology_flow/delete` | DELETE | `production_configuration_technology_model_technology_flow_delete` | background | `id: []` | 删除流程 |
| `technology_flow/copy` | POST | `production_configuration_technology_model_technology_flow_copy` | background | `id: []` | 复制流程 |
| `technology_flow_process/all` | GET | `production_configuration_technology_model_technology_flow_process_all` | background | `flow_id` | `process``flow_data``is_binding_batch``technology_flow_operate_log` |
| `technology_flow_process/create` | POST | `..._create` | background | `flow_id``workingsubclass_id``code``name``pin_check` | 新增流程工序 |
| `technology_flow_process/edit` | PUT | `..._edit` | background | `id``flow_id`、表单字段 | 编辑流程工序 |
| `technology_flow_process/delete` | DELETE | `..._delete` | background | `id: []``flow_id` | 删除流程工序 |
| `technology_flow_process/move_up` | POST | `..._move_up` | background | `flow_id``move_id``quilt_move_id``move_sort``quilt_move_sort` | 上移排序 |
| `technology_flow_process/move_down` | POST | `..._move_down` | background | 同上 | 下移排序 |
| `technology_flow_process/set_setting` | POST | `..._set_setting` | background | `id``flow_id``setting: JSON.stringify(data)` | 保存设定值插件数据 |
| `technology_flow_process/get_optional_params_details` | GET | `..._get_optional_params_details` | background | `process_id``page_no``page_size``name``code` | 当前流程工序已绑定结果参数 |
| `technology_flow_process/get_all_workingsubclass_params` | GET | `..._get_all_workingsubclass_params` | background | `process_id` | 左右树:全部/已选结果参数 |
| `technology_flow_process/add_optional_params` | POST | `..._add_optional_params` | background | `process_id``optional_params: JSON.stringify(list)` | 保存结果参数绑定 |
| `technology_flow_process/get_step` | GET | `..._get_step` | background | 无 | 温度补偿工步下拉 |
| `technology_flow_process/get_temperature_list` | GET | `..._get_temperature_list` | background | `process_id` | `data``start_work_step_id``end_work_step_id` |
| `technology_flow_process/create_temperature` | POST | `..._create_temperature` | background | `process_id``start_work_step_id``end_work_step_id``temp_data` | 保存温度补偿 |
| `technology_flow_process/get_temperature_template` | POST | `..._get_temperature_template` | background | 无 | blob 模板文件 |
| `calculation_script/all` | GET | `production_configuration_technology_model_calculation_script_all` | background | `process_id` | 当前工序计算脚本列表 |
| `calculation_script/create` | POST | `..._create` | background | `process_id``code``name``interface_code``interface_position``status``remark``calculation_script_content` | 新增脚本 |
| `calculation_script/edit` | PUT | `..._edit` | background | `id` + 新增字段 | 编辑脚本 |
| `calculation_script/delete` | DELETE | `..._delete` | background | `id` | 删除脚本 |
## 三、旧组件清单
| 组件 | 功能 | 关键属性/状态 | 使用场景 |
| --- | --- | --- | --- |
| `SctBaseTable` | 工序明细表格,带上移/下移/操作列插槽 | `columns``data``buttontable``up/down/handle` 插槽 | 流程卡工序列表 |
| `SctBaseDialog` + `SctBaseForm` | 新增/编辑流程工序 | `workingsubclass_id``code``name``pin_check` | 工序新增编辑 |
| `TechnologyFlowModel` | 设定值插件容器 | `type``code``pluginData``rowData``processArr``is_binding_batch` | 依据工序插件类型编辑设定值 |
| `ResultParam` | 查看并绑定流程工序结果参数 | `flow_process_id``workingsubclass_id` | 结果参数弹窗 |
| `TemperatureSupp` | 温度补偿工步范围、补偿值维护、Excel 导入、模板下载 | `flow_process_id` | 化成/分容等工序温度补偿 |
| `CalculationScript` | 计算脚本列表、脚本新增/编辑/删除、接口位置配置 | `flow_process_id` | 流程工序计算脚本配置 |
| 日志抽屉 | 展示 `technology_flow_operate_log` | `nyr_date``week``username``action_name``process_name` | 查看流程卡操作日志 |
## 四、已迁移/本轮补齐内容
| 内容 | 现状 | 本轮处理 |
| --- | --- | --- |
| 工艺流程主表 CRUD/复制 | V2 已实现 | 保留 |
| 流程卡入口 | V2 已实现 | 保留旧路由 `/production_configuration/technology_model/technology_flow/:flow_id/process` |
| 流程卡工序新增/编辑/删除/排序 | V2 已实现 | 保留并修正按钮显示规则 |
| 设定值 | V2 已实现简化 JSON 版本 | 保留,继续使用 `set_setting` |
| 结果参数 | V2 误用工序单元参数组件,缺少 `flow_process_id` 绑定 | 新增流程卡专用 `result-param.vue`,按 `process_id` 查询与绑定 |
| 温度补偿 | V2 仅提示“暂未接入” | 新增 `temperature-compensation.vue`,恢复查询、工步范围、维护、导入和模板下载 |
| 计算脚本 | V2 按钮隐藏,仅提示“暂未接入” | 新增 `calculation-script.vue` 和 API恢复脚本 CRUD |
| 接口封装 | V2 缺少多个旧端点 | 补齐 `process-routing-card.js` 和新增 `calculation-script.js` |
| i18n | V2 缺少插件弹窗文本 | 补齐中英文语言项 |
## 五、迁移优先级与依赖
| 优先级 | 内容 | 依赖 | 原因 |
| --- | --- | --- | --- |
| P0 | 流程卡工序列表、排序、新增编辑删除 | `technology_flow_process/all/create/edit/delete/move_*` | 流程卡核心作业入口 |
| P0 | 结果参数按流程工序绑定 | `get_optional_params_details``get_all_workingsubclass_params``add_optional_params` | 生产下发/报表字段依赖结果参数 |
| P1 | 温度补偿 | `get_step``get_temperature_list``create_temperature``get_temperature_template``xlsx` 工具 | 化成/分容等工序需要温度修正 |
| P1 | 计算脚本 | `calculation_script/all/create/edit/delete` | 工序接口前后置计算依赖 |
| P2 | 设定值插件细分 UI | 旧 `TechnologyFlowModel` 各插件 | 当前 V2 为 JSON 维护,后续可恢复各插件可视化表单 |
| P2 | 日志详情“查看数据” | 操作日志明细接口待确认 | 旧页面仅展示入口文本,实际明细未完整实现 |
## 六、风险与后续建议
- 当前 V2 设定值仍是 JSON 编辑器,不是旧系统按插件类型渲染的专用表单;若业务用户依赖可视化配置,应后续迁移 `SelectionPlugin``FormationPlugin``OcvrPlugin` 等插件。
- 计算脚本编辑器使用文本域替代旧 Ace 包装组件,功能可提交,但代码高亮/格式化体验弱于旧系统。
- 温度补偿 Excel 导入按旧模板中文列名“温度 / 温度补偿值”解析,需要测试真实模板兼容性。

View File

@@ -0,0 +1,580 @@
# 功能测试文档 — 工艺流程 (Process Routing)
> 模块路径:生产配置 → 工艺模型 → **工艺流程**
> 路由:`/production_configuration/technology_model/technology_flow`
> API BASE`production_configuration/technology_model/technology_flow/`
> i18n 前缀:`page.production_master_data.process_model.process_routing`
> 文档版本v1.0
> 适用代码版本:基于 [process-routing/index.vue](file:///d:/code/mes/mes-ui/src/views/production-master-data/process-model/process-routing/index.vue)
> 测试目标:验证工艺流程页面的列表、查询、新增、编辑、删除、流程卡管理入口等核心操作
---
## 0. 文档使用说明
- 测试人员按顺序执行 **T-XX** 编号的测试用例
- 每个用例的 **预期结果** 描述必须与实际界面/接口响应一致才可标记为通过
- 失败的用例在 **问题描述** 列填写具体错误信息、截图编号、操作环境
- 所有"实际结果"必须如实记录,禁止空填或留白
- 整体测试结论位于文末 **测试总结**
---
## 1. 测试环境配置要求
| 项目 | 要求 |
| --- | --- |
| 操作系统 | Windows 10 / 11 64-bit |
| Node.js | **18.16.0**(与项目 `.node-version` / `package.json#engines` 一致) |
| 包管理器 | **pnpm 10.33.0**(与 `package.json#packageManager` 一致) |
| 浏览器 | Chrome 100+ / Edge 100+ |
| 后端服务 | Webman 后端已启动且数据库已初始化 |
| 数据库 | 工艺流程、流程类别、产品、权限等基础数据已存在 |
| 启动命令 | `pnpm install``pnpm dev`,访问 `http://localhost:8080` |
| 测试账号 | 具备「生产配置-工艺模型-工艺流程」读写权限的账号 |
| 浏览器语言 | 中英文均需验证(默认以中文为准) |
---
## 2. 测试前置条件
1. 已使用具备 `production_configuration/technology_model/technology_flow` 下 create / edit / delete 权限的账号登录
2. **流程类别** 至少存在 1 条数据(否则新增时的「流程类别」下拉为空)
3. **产品列表** 至少存在 1 条数据(否则新增时的「关联产品」下拉为空)
4. 浏览器开发者工具 Network 面板可正常观察接口请求
5. 已确认 `src/locales/zh-chs.json``src/locales/en.json` 中存在 `page.production_master_data.process_model.process_routing` 节点
---
## 3. 测试用例
### 3.1 列表与查询
#### T-01页面正常加载
- **操作步骤**
1. 登录系统
2. 进入「生产配置 → 工艺模型 → 工艺流程」
- **预期结果**
- URL 跳转到 `/production_configuration/technology_model/technology_flow`
- 页面顶部展示搜索区(编码、名称、查询、重置)
- 下方展示表格列:序号 / 工艺流程编码 / 工艺流程名称 / 流程类别 / 关联产品 / 版本 / 状态 / 备注 / 操作
- 工具栏右上角显示帮助按钮,鼠标悬停提示「工艺流程用于设置生产工艺流程并管理流程卡…」
- 控制台无报错
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-02默认分页加载列表
- **操作步骤**
1. 访问工艺流程页面
- **预期结果**
- 列表自动加载(无需手动点击查询)
- 加载时表格显示 loading 遮罩
- 加载完成显示数据行(如有数据)
- 分页组件显示「共 X 条」并按 10 条/页 显示
- 发起请求 `GET production_configuration/technology_model/technology_flow/list?method=production_master_data_process_model_process_routing_list&page_no=1&page_size=10&code=&name=`
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-03按编码精确搜索
- **操作步骤**
1. 在「工艺流程编码」输入框输入已存在的完整编码
2. 点击「查询」按钮
- **预期结果**
- 列表仅展示编码完全匹配的数据行
- 列表刷新到第 1 页
- 接口请求参数 `code=<已输入值>`
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-04按名称模糊搜索
- **操作步骤**
1. 在「工艺流程名称」输入框输入名称片段
2. 点击「查询」按钮
- **预期结果**
- 列表仅展示名称包含该片段的数据行
- 接口请求参数 `name=<已输入值>`
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-05按回车键触发查询
- **操作步骤**
1. 在「工艺流程编码」或「工艺流程名称」输入框聚焦
2. 输入关键字后按键盘 `Enter`
- **预期结果**
- 等同于点击「查询」按钮,触发列表刷新
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-06重置搜索条件
- **操作步骤**
1. 在搜索框输入任意条件并点击「查询」
2. 点击「重置」按钮
- **预期结果**
- 两个搜索输入框被清空
- 列表自动以空条件重新加载
- 页码回到第 1 页
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-07分页切换
- **操作步骤**
1. 准备超过 10 条工艺流程数据
2. 在分页器中切换到第 2 页或修改每页条数
- **预期结果**
- 列表按新页码 / 每页条数重新加载
- 接口请求参数 `page_no` / `page_size` 与界面一致
- 分页总数保持正确
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-08空数据展示
- **操作步骤**
1. 在没有任何工艺流程数据时访问页面,或筛选一个不存在的数据
- **预期结果**
- 表格区域显示 Element UI 空数据占位(无红色错误)
- 分页器显示「共 0 条」
- 不会弹出错误提示
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-09i18n 中文切换
- **操作步骤**
1. 在用户设置中切换语言到「简体中文」
2. 访问工艺流程页面
- **预期结果**
- 所有表头、按钮、提示文本为中文("工艺流程编码"、"新增"、"删除"等)
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-10i18n 英文切换
- **操作步骤**
1. 切换语言到「English」
2. 访问工艺流程页面
- **预期结果**
- 所有表头、按钮、提示文本为英文("Routing Code"、"Add"、"Delete" 等)
- 切换瞬间不需要刷新页面即生效
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
---
### 3.2 新增
#### T-11打开新增弹窗
- **操作步骤**
1. 点击工具栏的「新增」按钮
- **预期结果**
- 弹出标题为「新增工艺流程」的对话框(宽 40%
- 表单为空且编码字段可编辑
- 默认值:版本 = `1.0`、状态 = 启用
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-12新增必填校验 — 编码
- **操作步骤**
1. 打开新增弹窗
2. 编码留空,其它字段填写完整
3. 点击「确定」
- **预期结果**
- 编码输入框下方红色提示「请输入工艺流程编码」
- 接口未发起,弹窗保持打开
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-13新增必填校验 — 名称
- **操作步骤**
1. 打开新增弹窗
2. 名称留空,其它字段填写完整
3. 点击「确定」
- **预期结果**
- 名称输入框下方红色提示「请输入工艺流程名称」
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-14新增必填校验 — 流程类别
- **操作步骤**
1. 打开新增弹窗
2. 不选择「流程类别」
3. 点击「确定」
- **预期结果**
- 流程类别下拉框下方红色提示「请选择流程类别」
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-15新增必填校验 — 版本
- **操作步骤**
1. 打开新增弹窗
2. 清空「版本」(默认 `1.0`
3. 点击「确定」
- **预期结果**
- 版本输入框下方红色提示「请输入版本号」
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-16新增字段长度校验
- **操作步骤**
1. 打开新增弹窗
2. 在「编码」输入超过 100 个字符
3. 点击「确定」
- **预期结果**
- 编码输入框下方红色提示「长度在 1 到 100 个字符」
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-17新增成功
- **操作步骤**
1. 打开新增弹窗
2. 填写完整有效数据:编码、名称、流程类别、关联产品、版本、状态、备注
3. 点击「确定」
- **预期结果**
- 接口请求 `POST production_configuration/technology_model/technology_flow/create` 状态码 200`code=0`
- 页面弹出绿色提示「操作成功」
- 弹窗自动关闭
- 列表自动刷新,新数据展示在表格中
- 页码回到第 1 页
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-18新增重复编码
- **操作步骤**
1. 准备一个已存在的编码
2. 在新增弹窗中输入相同编码
3. 点击「确定」
- **预期结果**
- 后端返回业务错误
- 页面弹出红色错误提示(如「编码已存在」)
- 弹窗保持打开,用户可修改后重试
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-19取消新增
- **操作步骤**
1. 打开新增弹窗,填写部分数据
2. 点击「取消」按钮或右上角 X
- **预期结果**
- 弹窗关闭
- 不发起任何接口请求
- 再次打开新增弹窗,表单恢复为空(默认值除外)
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-20新增提交中重复点击防护
- **操作步骤**
1. 打开新增弹窗,填写有效数据
2. 连续快速点击「确定」两次
- **预期结果**
- 第一次点击后按钮进入 loading 状态,禁用重复提交
- 接口仅被调用 1 次
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
---
### 3.3 编辑
#### T-21打开编辑弹窗
- **操作步骤**
1. 在列表中点击某行的「编辑」按钮
- **预期结果**
- 弹出标题为「编辑工艺流程」的对话框
- 表单自动回填该行数据
- 「编码」字段为禁用状态(不可编辑)
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-22编辑必填校验
- **操作步骤**
1. 打开编辑弹窗
2. 清空「名称」
3. 点击「确定」
- **预期结果**
- 名称输入框下方红色提示「请输入工艺流程名称」
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-23编辑成功
- **操作步骤**
1. 打开编辑弹窗
2. 修改名称、流程类别、版本、状态、备注等字段
3. 点击「确定」
- **预期结果**
- 接口请求 `PUT production_configuration/technology_model/technology_flow/edit` 状态码 200`code=0`
- 页面弹出绿色提示「操作成功」
- 弹窗关闭
- 列表自动刷新,目标行显示新值
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-24编辑时编码不可修改
- **操作步骤**
1. 打开编辑弹窗
2. 尝试修改「编码」字段
- **预期结果**
- 编码字段处于禁用状态,无法输入
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-25取消编辑
- **操作步骤**
1. 打开编辑弹窗,修改若干字段
2. 点击「取消」按钮
- **预期结果**
- 弹窗关闭
- 不发起任何接口请求
- 列表数据保持原样
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
---
### 3.4 删除
#### T-26删除二次确认弹窗
- **操作步骤**
1. 点击某行的「删除」按钮
- **预期结果**
- 弹出警告提示「确定要删除该工艺流程吗?」
- 提示框有「确定」与「取消」两个按钮
- 列表中的该行仍存在
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-27删除 — 取消
- **操作步骤**
1. 点击「删除」按钮
2. 在确认弹窗中点击「取消」
- **预期结果**
- 弹窗关闭
- 不发起删除接口
- 数据行保持原样
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-28删除成功
- **操作步骤**
1. 点击「删除」按钮
2. 在确认弹窗中点击「确定」
- **预期结果**
- 接口请求 `DELETE production_configuration/technology_model/technology_flow/delete` 状态码 200`code=0`
- 页面弹出绿色提示「操作成功」
- 列表自动刷新,目标行消失
- 删除当前页最后一行时,自动跳转到合理页码
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-29删除 — 关联数据拒绝
- **操作步骤**
1. 准备一条已被产品、批次或其它模块引用的工艺流程
2. 尝试删除
- **预期结果**
- 后端返回业务错误
- 页面弹出红色错误提示(如「该工艺流程已被引用,不可删除」)
- 列表数据保持原样
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
---
### 3.5 流程卡管理入口
#### T-30流程卡管理按钮存在
- **操作步骤**
1. 在列表中查看任意一行的操作列
- **预期结果**
- 操作列包含「编辑」、「流程卡管理」、「删除」3 个按钮
- 「流程卡管理」按钮为黄色文字 + `el-icon-tickets` 图标
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-31点击流程卡管理
- **操作步骤**
1. 点击某行的「流程卡管理」按钮
- **预期结果**
- 当前阶段:弹出信息提示「流程卡管理: <工艺流程名称>」(占位实现)
- 后续阶段:应打开独立的流程卡管理抽屉 / 弹窗
- 不影响列表状态
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
---
### 3.6 权限控制
#### T-32无「新增」权限
- **操作步骤**
1. 使用无 `/production_configuration/technology_model/technology_flow/create` 权限的账号登录
2. 访问工艺流程页面
- **预期结果**
- 工具栏不显示「新增」按钮
- 列表正常加载
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-33无「编辑」权限
- **操作步骤**
1. 使用无 `…/edit` 权限的账号登录
2. 访问工艺流程页面
- **预期结果**
- 行内「编辑」按钮不显示
- 「新增」与「删除」按钮仍可正常显示(按权限配置)
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-34无「删除」权限
- **操作步骤**
1. 使用无 `…/delete` 权限的账号登录
2. 访问工艺流程页面
- **预期结果**
- 行内「删除」按钮不显示
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-35未登录访问
- **操作步骤**
1. 退出登录后,直接在地址栏访问 `/production_configuration/technology_model/technology_flow`
- **预期结果**
- 自动跳转到登录页
- 不会出现 404 或白屏
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
---
### 3.7 错误处理
#### T-36网络异常
- **操作步骤**
1. 在浏览器开发者工具 Network 面板中离线Offline
2. 刷新工艺流程页面
- **预期结果**
- 页面顶部红色错误提示(如「请求超时」或「网络异常」)
- loading 状态关闭
- 表格维持之前的数据或显示空数据
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-37后端 500 错误
- **操作步骤**
1. 模拟后端列表接口返回 500
2. 刷新工艺流程页面
- **预期结果**
- 拦截器统一弹出红色错误提示
- 表格显示空数据
- 控制台无未捕获异常
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
#### T-38参数缺失
- **操作步骤**
1. 模拟后端创建接口缺参返回 `code=500`
2. 在新增弹窗点击「确定」
- **预期结果**
- 拦截器弹出后端返回的错误信息
- 弹窗不关闭
- 表单数据保持原样
- **实际结果**__________
- **测试状态**:☐ 通过 ☐ 失败
- **问题描述**__________
---
## 4. 测试总结
| 维度 | 统计 |
| --- | --- |
| 用例总数 | 38 |
| 通过数 | __________ |
| 失败数 | __________ |
| 阻塞数 | __________ |
| 跳过数 | __________ |
| 整体结论 | ☐ 通过 ☐ 有条件通过 ☐ 不通过 |
### 4.1 遗留问题清单
| 编号 | 用例编号 | 严重程度 | 描述 | 负责人 | 计划修复日期 |
| --- | --- | --- | --- | --- | --- |
| 1 | | | | | |
| 2 | | | | | |
| 3 | | | | | |
### 4.2 测试执行信息
- **测试执行人**__________
- **测试起止时间**__________
- **测试环境版本**Node `18.16.0` / pnpm `10.33.0` / 浏览器 `__________`
- **后端版本 / 提交**__________
- **测试账号**__________
---
## 5. 附录
### 5.1 关键文件
| 类型 | 路径 |
| --- | --- |
| 主页面 | [process-routing/index.vue](file:///d:/code/mes/mes-ui/src/views/production-master-data/process-model/process-routing/index.vue) |
| API 文件 | [process-routing.js](file:///d:/code/mes/mes-ui/src/api/production-master-data/process-routing.js) |
| 路由模块 | [production-master-data.js](file:///d:/code/mes/mes-ui/src/router/modules/production-master-data.js) |
| 中文语言包 | [zh-chs.json#process_routing](file:///d:/code/mes/mes-ui/src/locales/zh-chs.json) |
| 英文语言包 | [en.json#process_routing](file:///d:/code/mes/mes-ui/src/locales/en.json) |
### 5.2 关键接口
| 操作 | Method | URL |
| --- | --- | --- |
| 查询列表 | GET | `production_configuration/technology_model/technology_flow/list` |
| 新增 | POST | `production_configuration/technology_model/technology_flow/create` |
| 编辑 | PUT | `production_configuration/technology_model/technology_flow/edit` |
| 删除 | DELETE | `production_configuration/technology_model/technology_flow/delete` |
公共参数:`method=production_master_data_process_model_process_routing_<action>``platform=background`
### 5.3 字段说明
| 字段 | 类型 | 必填 | 说明 |
| --- | --- | --- | --- |
| code | string | 是 | 工艺流程编码,唯一,创建后不可修改 |
| name | string | 是 | 工艺流程名称 |
| category_id | int | 是 | 流程类别 ID关联工艺流程类别 |
| product_id | int | 否 | 关联产品 ID关联产品列表 |
| version | string | 是 | 版本号,默认 `1.0` |
| status | int | 是 | 1=启用0=禁用 |
| remark | string | 否 | 备注 |

View File

@@ -0,0 +1,245 @@
# 质量管理功能测试任务列表
## 检验类别管理 (Inspection Type Management)
- [ ] 通过菜单或地址 /quality_control/first_inspection/category 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## 首巡检项目配置 (First Article Inspection Configuration)
- [ ] 通过菜单或地址 /quality_control/first_inspection/setting 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## 首巡检录入 (First Article Inspection Records)
- [ ] 通过菜单或地址 /quality_control/first_inspection/input 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## 首巡检报表 (First Article Inspection Reports)
- [ ] 通过菜单或地址 /quality_control/first_inspection/report 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
## 检验单管理 (Inspection Orders)
- [ ] 通过菜单或地址 /quality_control/xqc/inspection_order_manage 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## 检验标准 (Inspection Standards)
- [ ] 通过菜单或地址 /quality_control/xqc/inspection_standard 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## 接收质量限 (AQL Standards)
- [ ] 通过菜单或地址 /quality_control/xqc/aql_config 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## 检测方案维护 (Inspection Plans)
- [ ] 通过菜单或地址 /quality_control/xqc/inspection_plan 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## 检验项目 (Inspection Items)
- [ ] 通过菜单或地址 /quality_control/xqc/inspection_item 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## 抽样方案配置 (Sampling Plans)
- [ ] 通过菜单或地址 /quality_control/xqc/sampling_plan 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## SPC渲染条件配置 (SPC Configuration)
- [ ] 通过菜单或地址 /spc/management 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 新增一条测试数据,确认必填校验、提交成功提示和列表刷新正常。
- [ ] 编辑刚新增的数据,确认回显、保存和刷新后的字段值正确。
- [ ] 删除测试数据,确认二次确认弹窗、删除请求和列表刷新正常。
## XBar-R (XBar-R Chart)
- [ ] 通过菜单或地址 /spc/chart/XBar-R 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## XBar-S (XBar-S Chart)
- [ ] 通过菜单或地址 /spc/chart/XBar-S 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## I-MR (I-MR Chart)
- [ ] 通过菜单或地址 /spc/chart/I-MR 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## Levey-Jennings (Levey-Jennings Chart)
- [ ] 通过菜单或地址 /spc/chart/Levey-Jennings 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## EWMA (EWMA Chart)
- [ ] 通过菜单或地址 /spc/chart/EWMA 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## CUSUM (CUSUM Chart)
- [ ] 通过菜单或地址 /spc/chart/CUSUM 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## MA (Moving Average Chart)
- [ ] 通过菜单或地址 /spc/chart/MA 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## MAMR (Moving Average MR Chart)
- [ ] 通过菜单或地址 /spc/chart/MAMR 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## MAMS (Moving Average S Chart)
- [ ] 通过菜单或地址 /spc/chart/MAMS 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## CPK (Process Capability Index)
- [ ] 通过菜单或地址 /spc/chart/Cpk 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## DPMO (DPMO)
- [ ] 通过菜单或地址 /spc/chart/DPMO 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## PChart (P Chart)
- [ ] 通过菜单或地址 /spc/chart/PChart 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## NPChart (NP Chart)
- [ ] 通过菜单或地址 /spc/chart/NPChart 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## CChart (C Chart)
- [ ] 通过菜单或地址 /spc/chart/CChart 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
## UChart (U Chart)
- [ ] 通过菜单或地址 /spc/chart/UChart 打开页面,确认页面标题、查询区和列表区域正常显示。
- [ ] 输入主要查询条件后点击查询,确认请求参数和列表刷新符合旧系统字段。
- [ ] 点击重置,确认查询条件清空并回到第一页。
- [ ] 切换分页大小和页码,确认列表数据、总数和加载状态正常。
- [ ] 对照旧系统同一查询条件,确认报表/只读列表的关键字段展示一致。
- [ ] 查询有样本数据的 SPC 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。

View File

@@ -0,0 +1,94 @@
# MES V2 迁移任务列表
> 根据 `后台Webman界面截图对照表.md` 生成。状态以当前 V2 项目中已落地的页面目录为准。
- 总功能数79
- 已迁移79
- 未迁移0
| 状态 | 一级模块 | 二级模块 | 三级模块 | 功能说明 | V2 目标路径 |
|:---:|---|---|---|---|---|
| ✅ | 系统设置 (System Administration) | 用户管理 (User Management) | 角色 (Role) | 设置用户组并分配权限(增删改查用户组,并实现权限分配功能) | `src/views/system-administration/user-management/role/` |
| ✅ | 系统设置 (System Administration) | 用户管理 (User Management) | 用户 (User) | 管理用户账号并绑定对应角色 | `src/views/system-administration/user-management/user/` |
| ✅ | 系统设置 (System Administration) | 菜单管理 (Menu Management) | 菜单配置 (Menu Configuration) | 系统菜单配置 | `src/views/system-administration/menu-management/menu-configuration/` |
| ✅ | 系统设置 (System Administration) | 系统助手 (System Utilities) | 操作日志 (Operation Logs) | 系统操作日志 | `src/views/system-administration/system-utilities/operation-logs/` |
| ✅ | 系统设置 (System Administration) | 系统助手 (System Utilities) | 接口日志 (API Logs) | 与设备对接流程交互日志(支持按 IP 和接口名称查询) | `src/views/system-administration/system-utilities/api-logs/` |
| ✅ | 系统设置 (System Administration) | 系统监控 (System Monitoring) | 监控设置 (Monitoring Configuration) | 系统监控配置 | `src/views/system-administration/system-monitoring/monitoring-configuration/` |
| ✅ | 生产配置 (Production Master Data) | 工厂模型 (Factory Model) | 产线设置 (Production Line) | 管理产线(支持增删改查) | `src/views/production-master-data/factory-model/production-line/` |
| ✅ | 生产配置 (Production Master Data) | 工厂模型 (Factory Model) | 工厂区域 (Factory Area) | 管理工厂区域(支持增删改查) | `src/views/production-master-data/factory-model/factory-area/` |
| ✅ | 生产配置 (Production Master Data) | 工艺模型 (Process Model) | 工艺流程类别 (Process Category) | 工艺流程类别的增删改查 | `src/views/production-master-data/process-model/process-category/` |
| ✅ | 生产配置 (Production Master Data) | 工艺模型 (Process Model) | 工序单元 (Process Step) | 配置工序单元(节点),支持参数预设 | `src/views/production-master-data/process-model/process-step/` |
| ✅ | 生产配置 (Production Master Data) | 工艺模型 (Process Model) | 工艺流程 (Process Routing) | 设置生产工艺流程并管理流程卡 | `src/views/production-master-data/process-model/process-routing/` |
| ✅ | 生产配置 (Production Master Data) | 产品管理 (Product Management) | 产品列表 (Product List) | 产品管理(增删改查) | `src/views/production-master-data/product-management/product-list/` |
| ✅ | 生产配置 (Production Master Data) | 产品管理 (Product Management) | 不良管理 (Defect Management) | 不良代码及描述管理,支持批量导入 | `src/views/production-master-data/product-model/product-ng-info/` |
| ✅ | 生产配置 (Production Master Data) | 物料模型 (Material Model) | 物料类别列表 (Material Category) | 区分原材料和半成品 | `src/views/production-master-data/material-model/material-category/` |
| ✅ | 生产配置 (Production Master Data) | 物料模型 (Material Model) | 物料信息管理 (Material Master) | 维护物料编码、名称、规格等属性 | `src/views/production-master-data/material-model/material-master/` |
| ✅ | 生产配置 (Production Master Data) | 物料模型 (Material Model) | BOM物料清单 (Bill of Materials) | 产品BOM管理 | `src/views/production-master-data/material-model/bill-of-materials/` |
| ✅ | 生产配置 (Production Master Data) | 物料模型 (Material Model) | 计量单位 (Unit of Measure) | 计量单位配置与管理 | `src/views/production-master-data/material-model/material-unit/` |
| ✅ | 生产配置 (Production Master Data) | SPC采集模型 (SPC Configuration) | SPC采集配置 (Data Collection Configuration) | 配置SPC采集参数 | `src/views/production-master-data/spc-configuration/data-collection-configuration/` |
| ✅ | 生产配置 (Production Master Data) | 班组模型 (Team Model) | 班组管理 (Team Management) | 管理生产班组 | `src/views/production-master-data/team-model/team-management/` |
| ✅ | 生产配置 (Production Master Data) | 班组模型 (Team Model) | 班次管理 (Shift Management) | 管理生产班次 | `src/views/production-master-data/team-model/shift-management/` |
| ✅ | 生产配置 (Production Master Data) | 班组模型 (Team Model) | 排班日历 (Scheduling Calendar) | 查看排班日历 | `src/views/production-master-data/team-model/scheduling-calendar/` |
| ✅ | 设备模型 (Equipment Management) | 设备类别 (Equipment Category) | 设备类别 (Equipment Category) | 管理设备类别 | `src/views/equipment-management/equipment-model/equipment-category/` |
| ✅ | 设备模型 (Equipment Management) | 设备信息 (Equipment Management) | 设备信息 (Equipment Registry) | 管理设备信息 | `src/views/equipment-management/equipment-model/equipment-registry/` |
| ✅ | 设备模型 (Equipment Management) | 设备点检 (Inspection Management) | 设备点检项目 (Inspection Items) | 点检项目管理 | `src/views/equipment-management/inspection-management/inspection-items/` |
| ✅ | 设备模型 (Equipment Management) | 设备点检 (Inspection Management) | 设备点检记录 (Inspection Records) | 点检记录管理 | `src/views/equipment-management/inspection-management/inspection-records/` |
| ✅ | 设备模型 (Equipment Management) | 设备点检 (Inspection Management) | 设备点检日志 (Inspection Logs) | 点检日志查询 | `src/views/equipment-management/inspection-management/inspection-logs/` |
| ✅ | 设备模型 (Equipment Management) | 设备保养 (Maintenance Management) | 设备保养项目 (Maintenance Items) | 保养项目管理 | `src/views/equipment-management/maintenance-management/maintenance-items/` |
| ✅ | 设备模型 (Equipment Management) | 设备保养 (Maintenance Management) | 设备保养详情 (Maintenance Details) | 保养详情管理 | `src/views/equipment-management/maintenance-management/maintenance-details/` |
| ✅ | 设备模型 (Equipment Management) | 设备保养 (Maintenance Management) | 设备保养日志 (Maintenance Logs) | 保养日志查询 | `src/views/equipment-management/maintenance-management/maintenance-logs/` |
| ✅ | 设备模型 (Equipment Management) | 设备维修 (Repair Management) | 设备维修管理 (Repair Management) | 维修管理 | `src/views/equipment-management/repair-management/repair-management/` |
| ✅ | 设备模型 (Equipment Management) | 设备维修 (Repair Management) | 设备维修日志 (Repair Logs) | 维修日志查询 | `src/views/equipment-management/repair-management/repair-logs/` |
| ✅ | 设备模型 (Equipment Management) | 设备损耗品 (Consumables Management) | 设备损耗品类别 (Consumables Category) | 损耗品分类管理 | `src/views/equipment-management/consumables-management/consumables-category/` |
| ✅ | 设备模型 (Equipment Management) | 设备损耗品 (Consumables Management) | 设备损耗品项目 (Consumables Items) | 损耗品项目管理 | `src/views/equipment-management/consumables-management/consumables-items/` |
| ✅ | 设备模型 (Equipment Management) | 设备损耗品 (Consumables Management) | 设备损耗品寿命管理 (Consumables Lifecycle Management) | 寿命管理 | `src/views/equipment-management/consumables-management/consumables-lifecycle/` |
| ✅ | 设备模型 (Equipment Management) | 设备损耗品 (Consumables Management) | 设备损耗品更换日志 (Replacement Logs) | 更换记录查询 | `src/views/equipment-management/consumables-management/replacement-logs/` |
| ✅ | 计划与生产 (Planning & Production) | 生产批次管理 (Batch Management) | 批次列表 (Batch List) | 批次管理 | `src/views/planning-production/batch-management/batch-list/` |
| ✅ | 计划与生产 (Planning & Production) | 生产批次管理 (Batch Management) | 批次托盘 (Tray Tracking) | 托盘跟踪与操作 | `src/views/planning-production/batch-management/tray-tracking/` |
| ✅ | 计划与生产 (Planning & Production) | 生产批次管理 (Batch Management) | 生产批次不良报表 (Batch Defect Report) | 不良报表 | `src/views/planning-production/batch-management/batch-defect-report/` |
| ✅ | 计划与生产 (Planning & Production) | 预警中心 (Alert Center) | 预警中心 (Alert Center) | 预警中心 | `src/views/planning-production/alert-center/` |
| ✅ | 计划与生产 (Planning & Production) | 生产监控 (Production Monitoring) | 物料监控 (Material Monitoring) | 物料监控 | `src/views/planning-production/production-monitoring/material-monitoring/` |
| ✅ | 计划与生产 (Planning & Production) | 生产监控 (Production Monitoring) | 电池复投管理 (Rework Management) | 返工管理 | `src/views/planning-production/production-monitoring/rework-management/` |
| ✅ | 计划与生产 (Planning & Production) | 生产监控 (Production Monitoring) | 托盘管理 (Tray Management) | 托盘管理 | `src/views/planning-production/production-monitoring/tray-management/` |
| ✅ | 计划与生产 (Planning & Production) | 生产监控 (Production Monitoring) | 托盘登录 (Tray Registration) | 托盘登记 | `src/views/planning-production/production-monitoring/tray-registration/` |
| ✅ | 计划与生产 (Planning & Production) | 生产监控 (Production Monitoring) | 设备监控 (Equipment Monitoring) | 设备监控 | `src/views/planning-production/production-monitoring/equipment-monitoring/` |
| ✅ | 计划与生产 (Planning & Production) | 生产监控 (Production Monitoring) | 电池工序管理 (Process Execution) | 工序管理 | `src/views/planning-production/production-monitoring/process-execution/` |
| ✅ | 质量管理 (Quality Management) | 过程控制 (Process Control) | 检验类别管理 (Inspection Type Management) | | `src/views/quality-management/process-control/inspection-type-management/` |
| ✅ | 质量管理 (Quality Management) | 过程控制 (Process Control) | 首巡检项目配置 (First Article Inspection Configuration) | | `src/views/quality-management/process-control/first-article-inspection-configuration/` |
| ✅ | 质量管理 (Quality Management) | 过程控制 (Process Control) | 首巡检录入 (First Article Inspection Records) | | `src/views/quality-management/process-control/first-article-inspection-records/` |
| ✅ | 质量管理 (Quality Management) | 过程控制 (Process Control) | 首巡检报表 (First Article Inspection Reports) | | `src/views/quality-management/process-control/first-article-inspection-reports/` |
| ✅ | 质量管理 (Quality Management) | 检验控制 (Inspection Management) | 检验单管理 (Inspection Orders) | | `src/views/quality-management/inspection-management/inspection-orders/` |
| ✅ | 质量管理 (Quality Management) | 检验控制 (Inspection Management) | 检验标准 (Inspection Standards) | | `src/views/quality-management/inspection-management/inspection-standards/` |
| ✅ | 质量管理 (Quality Management) | 检验控制 (Inspection Management) | 接收质量限 (AQL Standards) | | `src/views/quality-management/inspection-management/aql-standards/` |
| ✅ | 质量管理 (Quality Management) | 检验控制 (Inspection Management) | 检测方案维护 (Inspection Plans) | | `src/views/quality-management/inspection-management/inspection-plans/` |
| ✅ | 质量管理 (Quality Management) | 检验控制 (Inspection Management) | 检验项目 (Inspection Items) | | `src/views/quality-management/inspection-management/inspection-items/` |
| ✅ | 质量管理 (Quality Management) | 检验控制 (Inspection Management) | 抽样方案配置 (Sampling Plans) | | `src/views/quality-management/inspection-management/sampling-plans/` |
| ✅ | 质量管理 (Quality Management) | SPC统计过程控制 (SPC Control) | SPC渲染条件配置 (SPC Configuration) | | `src/views/quality-management/spc-control/spc-configuration/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | XBar-R (XBar-R Chart) | | `src/views/quality-management/spc-variable-charts/xbar-r/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | XBar-S (XBar-S Chart) | | `src/views/quality-management/spc-variable-charts/xbar-s/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | I-MR (I-MR Chart) | | `src/views/quality-management/spc-variable-charts/i-mr/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | Levey-Jennings (Levey-Jennings Chart) | | `src/views/quality-management/spc-variable-charts/levey-jennings/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | EWMA (EWMA Chart) | | `src/views/quality-management/spc-variable-charts/ewma/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | CUSUM (CUSUM Chart) | | `src/views/quality-management/spc-variable-charts/cusum/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | MA (Moving Average Chart) | | `src/views/quality-management/spc-variable-charts/ma/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | MAMR (Moving Average MR Chart) | | `src/views/quality-management/spc-variable-charts/mamr/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | MAMS (Moving Average S Chart) | | `src/views/quality-management/spc-variable-charts/mams/` |
| ✅ | 质量管理 (Quality Management) | SPC计量型报表 (SPC Variable Charts) | CPK (Process Capability Index) | | `src/views/quality-management/spc-variable-charts/cpk/` |
| ✅ | 质量管理 (Quality Management) | SPC计数型报表 (SPC Attribute Charts) | DPMO (DPMO) | | `src/views/quality-management/spc-attribute-charts/dpmo/` |
| ✅ | 质量管理 (Quality Management) | SPC计数型报表 (SPC Attribute Charts) | PChart (P Chart) | | `src/views/quality-management/spc-attribute-charts/pchart/` |
| ✅ | 质量管理 (Quality Management) | SPC计数型报表 (SPC Attribute Charts) | NPChart (NP Chart) | | `src/views/quality-management/spc-attribute-charts/npchart/` |
| ✅ | 质量管理 (Quality Management) | SPC计数型报表 (SPC Attribute Charts) | CChart (C Chart) | | `src/views/quality-management/spc-attribute-charts/cchart/` |
| ✅ | 质量管理 (Quality Management) | SPC计数型报表 (SPC Attribute Charts) | UChart (U Chart) | | `src/views/quality-management/spc-attribute-charts/uchart/` |
| ✅ | 数据中台 (Data Platform) | 基础追溯 (Traceability) | 反向追溯 (Backward Traceability) | 反向追溯 | `src/views/data-platform/traceability/backward/` |
| ✅ | 数据中台 (Data Platform) | 基础追溯 (Traceability) | 正向追溯 (Forward Traceability) | 正向追溯 | `src/views/data-platform/traceability/forward/` |
| ✅ | 数据中台 (Data Platform) | 基础追溯 (Traceability) | 电池曲线 (Battery Curve) | 电池曲线 | `src/views/data-platform/traceability/battery-curve/` |
| ✅ | 数据中台 (Data Platform) | 基础追溯 (Traceability) | 托盘追溯 (Tray Traceability) | 托盘追溯 | `src/views/data-platform/traceability/tray/` |
| ✅ | 数据中台 (Data Platform) | 基础追溯 (Traceability) | 电池追溯 (Battery Traceability) | 电池追溯 | `src/views/data-platform/traceability/battery/` |
| ✅ | 数据中台 (Data Platform) | 生产报表 (Production Reports) | 设备履历报表 (Equipment History Report) | 设备履历报表 | `src/views/data-platform/production-reports/equipment-history/` |
| ✅ | 数据中台 (Data Platform) | 生产报表 (Production Reports) | 电池详情报表 (Battery Detail Report) | 电池详情报表 | `src/views/data-platform/production-reports/battery-detail/` |
| ✅ | 数据中台 (Data Platform) | 相关性分析 (Correlation Analysis) | 鹰眼 (Hawkeye) | 鹰眼 | `src/views/data-platform/correlation-analysis/hawkeye/` |
## 状态说明
-V2 项目中已存在对应页面,或本轮已完成转换并通过构建验证。
- ⬜:尚未确认/尚未转换到 V2 页面目录。

View File

@@ -12,7 +12,7 @@
- 使用 `useTableColumns()` 生成列定义(不再手动分配 idx
- 使用 `useTableButtons()` 生成工具栏按钮和行内按钮(不再分开写 buttonList / tableButtonList
- 使用 `i18nMixin(prefix)` 注入 `key()``ckey()` 方法
- 参考文档:[表格组件使用说明.md](file:///d:/code/mes/mes-ui/docs/表格组件使用说明.md)
- 参考文档:[表格组件使用说明.md](/docs/表格组件使用说明.md)
- 参考示例:`src/views/production-master-data/factory-model/factory-area/index.vue`
#### 1.1 特殊弹出框组件迁移(重要)
@@ -47,7 +47,7 @@ setTimeout 1000ms 关闭 → 保留(树渲染需要等待),但抽取
```
##### 第三步:按标准实现
参考 [表格组件使用说明.md 第 13 节](file:///d:/code/mes/mes-ui/docs/表格组件使用说明.md#13-特殊弹出框组件规范),严格遵循:
参考 [表格组件使用说明.md 第 13 节](/docs/表格组件使用说明.md#13-特殊弹出框组件规范),严格遵循:
| 规则 | 说明 |
|------|------|
@@ -59,9 +59,9 @@ setTimeout 1000ms 关闭 → 保留(树渲染需要等待),但抽取
##### 第四步:完整案例
参考角色权限分配抽屉的完整迁移:
- 旧代码:`D:\code\company\SCTMES_MES_V5\vue-app\src\views\system_settings\user_management\role\components\PageMain\index.vue``dialogVisibleGive` + `el-tree`
- 新代码:[`src/views/system-administration/user-management/role/components/PermDrawer/index.vue`](file:///d:/code/mes/mes-ui/src/views/system-administration/user-management/role/components/PermDrawer/index.vue)
- 主页面引用:[`src/views/system-administration/user-management/role/index.vue`](file:///d:/code/mes/mes-ui/src/views/system-administration/user-management/role/index.vue#L79-L87)
- 旧代码:`/home/james/WEBMAN-VUE-APP-develop/src/views/system_settings/user_management/role/components/PageMain/index.vue``dialogVisibleGive` + `el-tree`
- 新代码:[`/home/james/WEBMAN-VUE-APP-V2-develop/mes-ui-d2/src/views/system-administration/user-management/role/components/PermDrawer/index.vue`](/src/views/system-administration/user-management/role/components/PermDrawer/index.vue)
- 主页面引用:[`src/views/system-administration/user-management/role/index.vue`](/src/views/system-administration/user-management/role/index.vue#L79-L87)
---
@@ -70,10 +70,10 @@ setTimeout 1000ms 关闭 → 保留(树渲染需要等待),但抽取
- `data()` 中用 `this.key('xxx')` 传完整 i18n key**不要用 `k()` 提前翻译**(翻译由 page-table / page-dialog-form 内部处理,切换语言自动响应)
- 模板搜索区用 `$t(key('xxx'))`,公共 key 用 `$t(ckey('xxx'))`
- 语言包必须中英文同步添加(`zh-chs.json` + `en.json`
- 参考文档:[国际化规则.md](file:///d:/code/mes/mes-ui/docs/国际化规则.md)
- 参考文档:[国际化规则.md](/docs/国际化规则.md)
#### 3. 文件夹命名(重要)
- 文件夹名称遵循 [后台Webman界面截图对照表](file:///d:/code/mes/mes-ui/后台Webman界面截图对照表.md) 的 snake_case/kebab-case 命名
- 文件夹名称遵循 [后台Webman界面截图对照表](/后台Webman界面截图对照表.md) 的 snake_case/kebab-case 命名
- 目录示例:`src/views/production-master-data/factory-model/factory-area/`
- 路由模块:`src/router/modules/production-master-data.js`
- API 文件:`src/api/production-master-data/factory-area.js`
@@ -121,7 +121,7 @@ setTimeout 1000ms 关闭 → 保留(树渲染需要等待),但抽取
| `page.data_middleground.basic_traceability.*` | `page.data_platform.traceability.*` |
#### 6. 处理流程(每迁移一个页面执行以下步骤)
1. **确定对照表位置**:从 [后台Webman界面截图对照表](file:///d:/code/mes/mes-ui/后台Webman界面截图对照表.md) 找到对应行的英文名,转换为 snake_case
1. **确定对照表位置**:从 [后台Webman界面截图对照表](/后台Webman界面截图对照表.md) 找到对应行的英文名,转换为 snake_case
2. **创建目录结构**`src/views/{一级snake_case}/{二级snake_case}/{三级snake_case}/`
3. **创建 API 文件**`src/api/{一级snake_case}/{二级snake_case}/{三级snake_case}.js`BASE URL 暂用旧值
4. **添加路由模块**`src/router/modules/{一级snake_case}.js`path 暂用旧值
@@ -141,7 +141,7 @@ setTimeout 1000ms 关闭 → 保留(树渲染需要等待),但抽取
- **Columns**`useTableColumns([...])`
- **Methods**`fetchData / onSearch / onReset / onPageChange / openAdd / openEdit / onDialogSubmit / handleDelete`
- **i18n key 模板**(每个页面至少要有这些):`search / reset / add / edit / delete / operation / add_title / edit_title / code / name / remark / enter_code / enter_name / remark_length / operation_success / confirm / cancel / tip / confirm_delete`
- **搜索条件过多时**参考 [表格组件使用说明.md - 场景 8](file:///d:/code/mes/mes-ui/docs/表格组件使用说明.md#场景-8折叠式搜索区搜索条件过多时),使用 `searchExpanded` + `v-show` 实现折叠式搜索区,需额外添加 i18n key`expand`(展开更多/Expand、`collapse`(收起/Collapse
- **搜索条件过多时**参考 [表格组件使用说明.md - 场景 8](/docs/表格组件使用说明.md#场景-8折叠式搜索区搜索条件过多时),使用 `searchExpanded` + `v-show` 实现折叠式搜索区,需额外添加 i18n key`expand`(展开更多/Expand、`collapse`(收起/Collapse
#### 6.1 依赖安装
@@ -150,7 +150,7 @@ setTimeout 1000ms 关闭 → 保留(树渲染需要等待),但抽取
1. **包管理器**:本项目使用 **pnpm**,安装命令为 `pnpm add <package-name>`
2. **安装前检查**:先在 `package.json` 中确认依赖是否已存在,避免重复安装
3. **版本兼容**:确保安装的包支持 Vue 2.x本项目为 Vue 2.7
4. **参考标准**[表格组件使用说明.md - 第 11 节](file:///d:/code/mes/mes-ui/docs/表格组件使用说明.md#11-依赖安装规范)
4. **参考标准**[表格组件使用说明.md - 第 11 节](/docs/表格组件使用说明.md#11-依赖安装规范)
---

25
docs/运行提示词.md Normal file
View File

@@ -0,0 +1,25 @@
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD> Ǩ<><C7A8><EFBFBD><EFBFBD>ʾ<EFBFBD><CABE>.md <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʹ<EFBFBD><CAB9>˵<EFBFBD><CBB5>.md <20><> <20><>̨Webman<61><6E><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͼ<EFBFBD><CDBC><EFBFBD>ձ<EFBFBD>.md <20>е<EFBFBD><D0B5><EFBFBD>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ִ<EFBFBD>С<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ<EFBFBD><CFA2><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>Ǩ<EFBFBD>ƹ<EFBFBD><C6B9><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ǩ<EFBFBD>ƺ<EFBFBD><C6BA><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD>ϸ<EFBFBD>Ĺ<EFBFBD><C4B9>ܲ<EFBFBD><DCB2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ĵ<EFBFBD><C4B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ĵ<EFBFBD><C4B5><EFBFBD><EFBFBD><EFBFBD>Ϊ<EFBFBD><CEAA><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ա<EFBFBD>IJ<EFBFBD><C4B2><EFBFBD>ָ<EFBFBD>ϡ<EFBFBD><CFA1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ա<EFBFBD><EFBFBD><E8B0B4><EFBFBD>ĵ<EFBFBD><C4B5><EFBFBD><EFBFBD><EFBFBD>ִ<EFBFBD>в<EFBFBD><D0B2>ԣ<EFBFBD><D4A3>Բ<EFBFBD><D4B2><EFBFBD>ͨ<EFBFBD><CDA8><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ<EFBFBD><C4BF><EFBFBD>й<EFBFBD>ѡ<EFBFBD><D1A1><EFBFBD>ǣ<EFBFBD><C7A3><EFBFBD>δͨ<CEB4><CDA8><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ<EFBFBD><C4BF>¼<EFBFBD><C2BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
<EFBFBD><EFBFBD>ҪҪ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
1. <20>˲<EFBFBD><CBB2><EFBFBD><EFBFBD>ĵ<EFBFBD><C4B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ĵ<EFBFBD><C4B5>ķ<EFBFBD>ʽ<EFBFBD><CABD>ÿ<EFBFBD><C3BF><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD><C9B9><EFBFBD>Ǩ<EFBFBD>ƺ󣬽<C6BA><F3A3ACBD>¹<EFBFBD><C2B9>ܵIJ<DCB5><C4B2><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݷŵ<DDB7>ÿ<EFBFBD><C3BF><EFBFBD><EFBFBD><EFBFBD>ܵ<EFBFBD><DCB5><EFBFBD><EFBFBD>ĵ<EFBFBD><C4B5>
2. <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݱ<EFBFBD><DDB1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϸҪ<CFB8>أ<EFBFBD>
- <20><><EFBFBD>Ի<EFBFBD><D4BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><D2AA>
- <20><><EFBFBD><EFBFBD>ǰ<EFBFBD><C7B0><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
- <20><>ϸ<EFBFBD>IJ<EFBFBD><C4B2>Բ<EFBFBD><D4B2>裨ÿ<E8A3A8><C3BF><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȷ˵<C8B7><CBB5><EFBFBD><EFBFBD>
- Ԥ<>ڽ<EFBFBD><DABD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><E5A1A2><EFBFBD><EFBFBD>֤<EFBFBD><D6A4>
- ʵ<>ʽ<EFBFBD><CABD><EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><C2BC><EFBFBD><EFBFBD>
- <20><><EFBFBD><EFBFBD>ͨ<EFBFBD><CDA8><><CAA7>״̬<D7B4><CCAC><EFBFBD><EFBFBD>
- <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><C2BC><EFBFBD><EFBFBD>
3. ȷ<><C8B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD≯<EFBFBD><CCB8><EFBFBD><EFBFBD>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ܵ<EFBFBD><DCB5><EFBFBD><EFBFBD>к<EFBFBD><D0BA>IJ<EFBFBD><C4B2><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD><C3BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѯ<EFBFBD><D1AF><EFBFBD><EFBFBD><E0BCAD>ɾ<EFBFBD><C9BE><EFBFBD><EFBFBD>Ȩ<EFBFBD>޷<EFBFBD><DEB7><EFBFBD><EFBFBD><EFBFBD>
4. <20>ĵ<EFBFBD><C4B5><EFBFBD>ʽӦ<CABD><D3A6><EFBFBD><EFBFBD><EFBFBD>׶<EFBFBD><D7B6><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>Ա<EFBFBD><D4B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ִ<EFBFBD>в<EFBFBD><D0B2><EFBFBD>¼<EFBFBD><C2BC><EFBFBD><EFBFBD>

View File

@@ -1,10 +1,15 @@
{
"name": "d2-admin",
"version": "1.25.0",
"packageManager": "pnpm@10.33.0",
"engines": {
"node": ">=20.19.0",
"pnpm": ">=10.33.0 <11"
},
"scripts": {
"serve": "vue-cli-service serve --open",
"start": "npm run serve",
"dev": "npm run serve",
"start": "pnpm run serve",
"dev": "pnpm run serve",
"build": "vue-cli-service build --report",
"build:preview": "NODE_OPTIONS=--max_old_space_size=4096 vue-cli-service build --mode preview",
"lint": "vue-cli-service lint --fix",
@@ -20,6 +25,7 @@
"core-js": "^3.24.1",
"countup.js": "^2.3.2",
"dayjs": "^1.11.5",
"echarts": "5.1.0",
"element-ui": "^2.15.9",
"faker": "^4.1.0",
"flex.css": "^1.1.7",
@@ -27,7 +33,7 @@
"github-markdown-css": "^4.0.0",
"highlight.js": "^10.7.3",
"hotkeys-js": "^3.9.5",
"js-cookie": "^2.2.1",
"js-cookie": "3.0.7",
"lodash": "^4.17.21",
"lowdb": "^1.0.0",
"marked": "^2.1.3",
@@ -35,6 +41,7 @@
"nprogress": "^0.2.0",
"qs": "^6.11.0",
"quill": "^1.3.7",
"relation-graph": "2.2.11",
"screenfull": "^5.2.0",
"sortablejs": "^1.15.0",
"ua-parser-js": "^0.8.1",
@@ -46,7 +53,8 @@
"vue-router": "^3.6.2",
"vue-splitpane": "^1.0.6",
"vue-ueditor-wrap": "^2.5.6",
"vuex": "^3.6.2"
"vuex": "^3.6.2",
"xlsx": "^0.18.5"
},
"devDependencies": {
"@d2-projects/vue-filename-injector": "^1.1.1",
@@ -71,7 +79,7 @@
"eslint-plugin-vue": "^6.2.2",
"less": "^3.13.1",
"less-loader": "^7.3.0",
"sass": "^1.54.5",
"sass": "1.54.5",
"sass-loader": "~10.5.2",
"svg-sprite-loader": "^4.3.0",
"text-loader": "^0.0.1",
@@ -88,5 +96,13 @@
"repository": {
"type": "git",
"url": "https://github.com/d2-projects/d2-admin.git"
},
"volta": {
"node": "20.19.0"
},
"pnpm": {
"overrides": {
"@achrinza/node-ipc": ">=9.2.7"
}
}
}

849
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,43 @@
import { request } from '@/api/_service'
const BASE = 'data_middleground/eagle_eyes/'
function apiParams (method, data = {}) {
return {
method,
platform: 'admin',
...data
}
}
export function getNGWorkstationBatch (data) {
return request({
url: BASE + 'getNGWorkstationBatch',
method: 'get',
params: apiParams('data_middleground_eagle_eyes_getNGWorkstationBatch', data)
})
}
export function getBatchResultParam (data) {
return request({
url: BASE + 'getBatchResultParam',
method: 'get',
params: apiParams('data_middleground_eagle_eyes_getBatchResultParam', data)
})
}
export function analyzeHawkeyeCorrelation (data) {
return request({
url: BASE + 'saveCsvFile',
method: 'get',
params: apiParams('data_middleground_eagle_eyes_saveCsvFile', data)
})
}
export function getDataClassificationByNGCode (data) {
return request({
url: BASE + 'getDataClassificationByNGCode',
method: 'get',
params: apiParams('data_middleground_eagle_eyes_get_data_classification_by_ng_code', data)
})
}

View File

@@ -0,0 +1,23 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/produce/battery_details_report/'
function dataParams (method, data = {}, platform = 'api') {
return { method, platform, ...data }
}
export function getBatteryDetailTitle (data) {
return request({ url: BASE + 'battery_details_title', method: 'post', data: dataParams('production_report_battery_details_title', data) })
}
export function getBatteryDetailList (data) {
return request({ url: BASE + 'battery_details_list', method: 'post', data: dataParams('production_report_battery_details_list', data) })
}
export function getBatteryDetailFlowBatch (data) {
return request({ url: BASE + 'battery_details_flow_batch', method: 'get', params: dataParams('production_report_battery_details_flow_batch', data) })
}
export function createBatteryDetailExportTask (data) {
return request({ url: BASE + 'battery_details_task', method: 'post', data: dataParams('system_exporttask_battery_details_task', data, 'admin') })
}

View File

@@ -0,0 +1,15 @@
import { request } from '@/api/_service'
const BASE = 'report/'
function apiParams (method, data = {}) {
return { method, platform: 'api', ...data }
}
export function getEquipmentHistoryList (data) {
return request({
url: BASE + 'device/log',
method: 'post',
data: apiParams('get.device.status.log', data)
})
}

View File

@@ -0,0 +1,27 @@
import { request } from '@/api/_service'
const BASE = 'data_middleground/basic_traceability/reverse_direction_traceability/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function getBackwardTraceabilityData (data) {
return request({
url: BASE + 'get_data',
method: 'get',
params: apiParams('data_middleground_basic_traceability_reverse_direction_traceability_get_data', data)
})
}
export function exportBackwardTraceabilityTree (data) {
return request({
url: BASE + 'export_tree',
method: 'post',
data: apiParams('data_middleground_basic_traceability_reverse_direction_traceability_export_tree', data)
})
}

View File

@@ -0,0 +1,35 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/produce/traceability/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function getBatteryCurveRecords (data) {
return request({
url: BASE + 'batterytraceability',
method: 'get',
params: apiParams('planning_production_produce_traceability_batterytraceability', data)
})
}
export function getBatteryCurveData (data) {
return request({
url: BASE + 'curveread',
method: 'get',
params: apiParams('planning_production_produce_traceability_batterycurveread', data)
})
}
export function exportBatteryCurveData (data) {
return request({
url: BASE + 'export',
method: 'get',
params: apiParams('planning_production_produce_traceability_export', data)
})
}

View File

@@ -0,0 +1,31 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/produce/traceability/'
function apiParams (method, data = {}) {
return { method, platform: 'background', ...data }
}
export function getBatteryTraceList (data) {
return request({
url: BASE + 'battery',
method: 'get',
params: apiParams('planning_production_produce_traceability_battery', data)
})
}
export function getBatteryProcessData (data) {
return request({
url: BASE + 'batteryProcess',
method: 'get',
params: apiParams('planning_production_produce_traceability_batteryProcess', data)
})
}
export function cancelBatteryActive (data) {
return request({
url: BASE + 'batteryactive',
method: 'get',
params: apiParams('planning_production_produce_traceability_batteryactive', data)
})
}

View File

@@ -0,0 +1,27 @@
import { request } from '@/api/_service'
const BASE = 'data_middleground/basic_traceability/positive_direction_traceability/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function getForwardTraceabilityList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('data_middleground_basic_traceability_positive_direction_traceability_list', data)
})
}
export function createForwardTraceabilityExportTask (data) {
return request({
url: BASE + 'export_task',
method: 'post',
data: apiParams('data_middleground_basic_traceability_positive_direction_traceability_export_task', data)
})
}

View File

@@ -0,0 +1,31 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/produce/traceability/'
function apiParams (method, data = {}) {
return { method, platform: 'background', ...data }
}
export function getTrayTraceList (data) {
return request({
url: BASE + 'tray',
method: 'get',
params: apiParams('planning_production_produce_traceability_tray', data)
})
}
export function getTrayTraceDetail (data) {
return request({
url: BASE + 'traydetail',
method: 'get',
params: apiParams('planning_production_produce_traceability_traydetail', data)
})
}
export function cancelTraceBatteryActive (data) {
return request({
url: BASE + 'batteryactive',
method: 'get',
params: apiParams('planning_production_produce_traceability_batteryactive', data)
})
}

View File

@@ -0,0 +1,29 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_consumables/device_consumables_category/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_consumables_device_consumables_category_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_consumables_device_consumables_category_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('device_management_device_consumables_device_consumables_category_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_consumables_device_consumables_category_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('device_management_device_consumables_device_consumables_category_delete', data) })
}
export function createExportTask (data) {
return request({ url: BASE + 'data_export_task', method: 'post', data: params('device_management_device_consumables_device_consumables_category_data_export_task', data) })
}

View File

@@ -0,0 +1,29 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_consumables/device_consumables_items/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_consumables_device_consumables_items_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_consumables_device_consumables_items_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('device_management_device_consumables_device_consumables_items_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_consumables_device_consumables_items_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('device_management_device_consumables_device_consumables_items_delete', data) })
}
export function createExportTask (data) {
return request({ url: BASE + 'data_export_task', method: 'post', data: params('device_management_device_consumables_device_consumables_items_data_export_task', data) })
}

View File

@@ -0,0 +1,29 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_consumables/device_consumables_lifetime_management/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_consumables_device_consumables_lifetime_management_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_consumables_device_consumables_lifetime_management_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('device_management_device_consumables_device_consumables_lifetime_management_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_consumables_device_consumables_lifetime_management_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('device_management_device_consumables_device_consumables_lifetime_management_delete', data) })
}
export function createExportTask (data) {
return request({ url: BASE + 'data_export_task', method: 'post', data: params('device_management_device_consumables_device_consumables_lifetime_management_data_export_task', data) })
}

View File

@@ -1,6 +1,6 @@
import { request } from '@/api/_service'
const BASE = 'device_management/equipment_model/equipment_category/'
const BASE = 'production_configuration/device_model/device_category/'
function apiParams (method, data = {}) {
return {

View File

@@ -0,0 +1,33 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/device_model/device_management/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('production_configuration_device_model_device_management_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('production_configuration_device_model_device_management_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('production_configuration_device_model_device_management_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('production_configuration_device_model_device_management_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('production_configuration_device_model_device_management_delete', data) })
}
export function batchDeleteItems (data) {
return request({ url: BASE + 'batch_delete', method: 'delete', data: params('production_configuration_device_model_device_management_batch_delete', data) })
}
export function createExportTask (data) {
return request({ url: BASE + 'device_data_export_task', method: 'post', data: params('production_configuration_device_model_device_management_device_export_task', data) })
}

View File

@@ -0,0 +1,29 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_check/device_check_items/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_check_device_check_items_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_check_device_check_items_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('device_management_device_check_device_check_items_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_check_device_check_items_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('device_management_device_check_device_check_items_delete', data) })
}
export function batchDeleteItems (data) {
return request({ url: BASE + 'batch_delete', method: 'delete', data: params('device_management_device_check_device_check_items_batch_delete', data) })
}

View File

@@ -0,0 +1,13 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_check/device_check_items_log/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_check_device_check_items_log_list', data) })
}
export function createExportTask (data) {
return request({ url: BASE + 'export', method: 'post', data: params('device_management_device_check_device_check_items_log_export', data) })
}

View File

@@ -0,0 +1,17 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_check/device_check_record/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_check_device_check_record_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create_record', method: 'post', data: params('device_management_device_check_device_check_create_record', data) })
}
export function editItem (data) {
return request({ url: BASE + 'create_record', method: 'put', data: params('device_management_device_check_device_check_create_record', data) })
}

View File

@@ -0,0 +1,25 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_maintain/device_maintain_items_details/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_maintain_device_maintain_items_details_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_maintain_device_maintain_items_details_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('device_management_device_maintain_device_maintain_items_details_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_maintain_device_maintain_items_details_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('device_management_device_maintain_device_maintain_items_details_delete', data) })
}

View File

@@ -0,0 +1,29 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_maintain/device_maintain_items/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_maintain_device_maintain_items_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_maintain_device_maintain_items_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('device_management_device_maintain_device_maintain_items_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_maintain_device_maintain_items_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('device_management_device_maintain_device_maintain_items_delete', data) })
}
export function batchDeleteItems (data) {
return request({ url: BASE + 'batch_delete', method: 'delete', data: params('device_management_device_maintain_device_maintain_items_batch_delete', data) })
}

View File

@@ -0,0 +1,21 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_maintain/device_maintain_items_log/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_maintain_device_maintain_items_log_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_maintain_device_maintain_items_log_list', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_maintain_device_maintain_items_log_edit', data) })
}
export function createExportTask (data) {
return request({ url: BASE + 'export', method: 'post', data: params('device_management_device_maintain_device_maintain_items_log_export', data) })
}

View File

@@ -0,0 +1,29 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_repair/device_repair_log/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_repair_device_repair_log_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_repair_device_repair_log_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('device_management_device_repair_device_repair_log_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_repair_device_repair_log_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('device_management_device_repair_device_repair_log_delete', data) })
}
export function createExportTask (data) {
return request({ url: BASE + 'create_data_export_task', method: 'post', data: params('device_management_device_repair_device_repair_log_create_data_export_task', data) })
}

View File

@@ -0,0 +1,29 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_repair/device_repair_management/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_repair_device_repair_management_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_repair_device_repair_management_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('device_management_device_repair_device_repair_management_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_repair_device_repair_management_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('device_management_device_repair_device_repair_management_delete', data) })
}
export function createExportTask (data) {
return request({ url: BASE + 'create_data_export_task', method: 'post', data: params('device_management_device_repair_device_repair_management_create_data_export_task', data) })
}

View File

@@ -0,0 +1,29 @@
import { request } from '@/api/_service'
const BASE = 'device_management/device_consumables/device_consumables_replace_log/'
function params (method, data = {}) { return { method, platform: 'background', ...data } }
export function getAll (data) {
return request({ url: BASE + 'all', method: 'get', params: params('device_management_device_consumables_device_consumables_replace_log_all', data) })
}
export function getList (data) {
return request({ url: BASE + 'list', method: 'get', params: params('device_management_device_consumables_device_consumables_replace_log_list', data) })
}
export function createItem (data) {
return request({ url: BASE + 'create', method: 'post', data: params('device_management_device_consumables_device_consumables_replace_log_create', data) })
}
export function editItem (data) {
return request({ url: BASE + 'edit', method: 'put', data: params('device_management_device_consumables_device_consumables_replace_log_edit', data) })
}
export function deleteItem (data) {
return request({ url: BASE + 'delete', method: 'delete', data: params('device_management_device_consumables_device_consumables_replace_log_delete', data) })
}
export function createExportTask (data) {
return request({ url: BASE + 'data_export_task', method: 'post', data: params('device_management_device_consumables_device_consumables_replace_log_data_export_task', data) })
}

View File

@@ -0,0 +1,59 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/produce/pin_check/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function getPincheckWorkstation (data) {
return request({
url: BASE + 'workstation',
method: 'get',
params: apiParams('planning_production_produce_pincheck_workstation', data)
})
}
export function getDevicePinCheckList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('planning_production_produce_pincheck_list', data)
})
}
export function getPinCheckDetail (data) {
return request({
url: BASE + 'detail',
method: 'get',
params: apiParams('planning_production_produce_pincheck_detail', data)
})
}
export function setPinCheckClean (data) {
return request({
url: BASE + 'clean',
method: 'get',
params: apiParams('planning_production_produce_pincheck_clean', data)
})
}
export function setPinCheckCleanSingle (data) {
return request({
url: BASE + 'clean_single_channel',
method: 'get',
params: apiParams('planning_production_produce_pincheck_clean_single_channel', data)
})
}
export function getWorkstationSearch (data) {
return request({
url: BASE + 'search',
method: 'get',
params: apiParams('planning_production_produce_pincheck_search', data)
})
}

View File

@@ -0,0 +1,27 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/production_batch_management/report/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function getBatchDefectReport (data) {
return request({
url: BASE + 'bad',
method: 'get',
params: apiParams('planning_production_production_batch_management_batch_bad', data)
})
}
export function exportBatchDefectReport (data) {
return request({
url: BASE + 'export',
method: 'get',
params: apiParams('planning_production_production_batch_management_batch_export', data)
})
}

View File

@@ -0,0 +1,59 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/production_batch_management/batch/'
function apiParams (method, data = {}) {
return {
method: `planning_production_production_batch_management_batch_${method}`,
platform: 'background',
...data
}
}
export function getBatchAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: apiParams('all', data)
})
}
export function getBatchList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('list', data)
})
}
export function createBatch (data) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams('create', data)
})
}
export function editBatch (data) {
return request({
url: BASE + 'edit',
method: 'put',
data: apiParams('edit', data)
})
}
export function deleteBatch (data) {
return request({
url: BASE + 'delete',
method: 'delete',
data: apiParams('delete', data)
})
}
export function getProcessBatch (data) {
return request({
url: BASE + 'getProcessBatch',
method: 'post',
data: apiParams('getProcessBatch', data)
})
}

View File

@@ -0,0 +1,43 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/production_batch_management/batch_tray/'
function apiParams (method, data = {}) {
return {
method: `planning_production_production_batch_management_batch_tray_${method}`,
platform: 'background',
...data
}
}
export function getBatchTrayList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('list', data)
})
}
export function trayUnbinding (data) {
return request({
url: BASE + 'unbinding',
method: 'get',
params: apiParams('unbinding', data)
})
}
export function trayInactivity (data) {
return request({
url: BASE + 'inactivity',
method: 'get',
params: apiParams('inactivity', data)
})
}
export function getBatteryParam (data) {
return request({
url: BASE + 'get_battery_param',
method: 'get',
params: apiParams('get_battery_param', data)
})
}

View File

@@ -0,0 +1,19 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/device_model/device_management/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function getDeviceAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: apiParams('production_configuration_device_model_device_management_all', data)
})
}

View File

@@ -0,0 +1,27 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/wip/wip_management/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function getWipDataList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('planning_production_wip_wip_management_list', data)
})
}
export function createWipData (data) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams('planning_production_wip_wip_management_create', data)
})
}

View File

@@ -0,0 +1,27 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/produce/change_battery_process/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function verifyBatteryProcessInfo (data) {
return request({
url: BASE + 'verify',
method: 'get',
params: apiParams('planning_production_produce_change_battery_process_verify', data)
})
}
export function changeBatteryProcess (data) {
return request({
url: BASE + 'change',
method: 'get',
params: apiParams('planning_production_produce_change_battery_process_change', data)
})
}

View File

@@ -0,0 +1,19 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/produce/set_battery_rebatch/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function verifyBatteryRebatchInfo (data) {
return request({
url: BASE + 'verify',
method: 'get',
params: apiParams('planning_production_produce_change_battery_process_verify', data)
})
}

View File

@@ -0,0 +1,67 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/produce/tray_manage/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function getTrayManageInfo (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('planning_production_produce_traymanage_list', data)
})
}
export function changeFlowProcess (data) {
return request({
url: BASE + 'change',
method: 'put',
params: apiParams('planning_production_produce_traymanage_change', data)
})
}
export function inactiveTray (data) {
return request({
url: BASE + 'inactive',
method: 'put',
params: apiParams('planning_production_produce_traymanage_inactive', data)
})
}
export function trayNg (data) {
return request({
url: BASE + 'ng',
method: 'put',
params: apiParams('planning_production_produce_traymanage_ng', data)
})
}
export function rangeNgAndRC (data) {
return request({
url: BASE + 'ngrc',
method: 'put',
params: apiParams('planning_production_produce_traymanage_ngrc', data)
})
}
export function rangeFx (data) {
return request({
url: BASE + 'fenx',
method: 'put',
params: apiParams('planning_production_produce_traymanage_fenx', data)
})
}
export function cleanTrayNg (data) {
return request({
url: BASE + 'clean',
method: 'put',
params: apiParams('planning_production_produce_traymanage_clean', data)
})
}

View File

@@ -0,0 +1,51 @@
import { request } from '@/api/_service'
const BASE = 'planning_production/produce/tray_login/'
function apiParams (method, data = {}) {
return {
method,
platform: 'background',
...data
}
}
export function getBatchAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: apiParams('planning_production_produce_traylogin_all', data)
})
}
export function getBatchTrayFormatAll (data) {
return request({
url: BASE + 'trayformat_all',
method: 'get',
params: apiParams('planning_production_produce_trayformat_all', data)
})
}
export function createBatchTrayFormat (data) {
return request({
url: BASE + 'create',
method: 'get',
params: apiParams('planning_production_produce_trayformat_create', data)
})
}
export function deleteBatchTrayFormat (data) {
return request({
url: BASE + 'delete',
method: 'get',
params: apiParams('planning_production_produce_trayformat_delete', data)
})
}
export function checkBatteryid (data) {
return request({
url: BASE + 'check_batteryid',
method: 'get',
params: apiParams('planning_production_produce_trayformat_check_batteryid', data)
})
}

View File

@@ -0,0 +1,56 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/matetial_model/bom/'
const RELATION_BASE = 'production_configuration/matetial_model/bom_relationship/'
function apiParams (method, data = {}) {
return {
method: `production_configuration_matetial_model_bom_${method}`,
platform: 'background',
...data
}
}
function relationApiParams (method, data = {}) {
return {
method: `production_configuration_matetial_model_bom_relationship_${method}`,
platform: 'background',
...data
}
}
export function getBomAll (data) {
return request({ url: BASE + 'all', method: 'get', params: apiParams('all', data) })
}
export function getBomList (data) {
return request({ url: BASE + 'list', method: 'get', params: apiParams('list', data) })
}
export function createBom (data) {
return request({ url: BASE + 'create', method: 'post', data: apiParams('create', data) })
}
export function editBom (data) {
return request({ url: BASE + 'edit', method: 'put', data: apiParams('edit', data) })
}
export function deleteBom (data) {
return request({ url: BASE + 'delete', method: 'delete', data: apiParams('delete', data) })
}
export function getBomRelationshipList (data) {
return request({ url: RELATION_BASE + 'list', method: 'get', params: relationApiParams('list', data) })
}
export function createBomRelationship (data) {
return request({ url: RELATION_BASE + 'create', method: 'post', data: relationApiParams('create', data) })
}
export function editBomRelationship (data) {
return request({ url: RELATION_BASE + 'edit', method: 'put', data: relationApiParams('edit', data) })
}
export function deleteBomRelationship (data) {
return request({ url: RELATION_BASE + 'delete', method: 'delete', data: relationApiParams('delete', data) })
}

View File

@@ -0,0 +1,51 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/technology_model/calculation_script/'
function apiParams (method, data = {}) {
return {
method: `production_configuration_technology_model_calculation_script_${method}`,
platform: 'background',
...data
}
}
export function getCalculationScriptAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: apiParams('all', data)
})
}
export function getCalculationScriptList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('list', data)
})
}
export function createCalculationScript (data) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams('create', data)
})
}
export function editCalculationScript (data) {
return request({
url: BASE + 'edit',
method: 'put',
data: apiParams('edit', data)
})
}
export function deleteCalculationScript (data) {
return request({
url: BASE + 'delete',
method: 'delete',
data: apiParams('delete', data)
})
}

View File

@@ -0,0 +1,43 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/spc_configuration/binding_scada_node/'
function apiParams (method, data = {}) {
return {
method: `production_master_data_spc_configuration_data_collection_configuration_${method}`,
platform: 'background',
...data
}
}
export function getDataCollectionConfigList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('list', data)
})
}
export function createDataCollectionConfig (data) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams('create', data)
})
}
export function editDataCollectionConfig (data) {
return request({
url: BASE + 'edit',
method: 'put',
data: apiParams('edit', data)
})
}
export function deleteDataCollectionConfig (data) {
return request({
url: BASE + 'delete',
method: 'delete',
data: apiParams('delete', data)
})
}

View File

@@ -0,0 +1,19 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/device_model/device_category/'
function apiParams (method, data = {}) {
return {
method: `production_configuration_device_model_device_category_${method}`,
platform: 'background',
...data
}
}
export function getDeviceCategoryAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: apiParams('all', data)
})
}

View File

@@ -18,6 +18,18 @@ export function getProcessCategoryList (data) {
})
}
export function getProcessCategoryAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: {
method: 'production_configuration_technology_model_technology_flow_category_all',
platform: 'background',
...data
}
})
}
export function createProcessCategory (data) {
return request({
url: BASE + 'create',

View File

@@ -0,0 +1,132 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/technology_model/technology_flow_process/'
function apiParams (method, data = {}) {
return {
method: `production_configuration_technology_model_technology_flow_process_${method}`,
platform: 'background',
...data
}
}
export function getProcessCardAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: apiParams('all', data)
})
}
export function createProcessCard (data) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams('create', data)
})
}
export function editProcessCard (data) {
return request({
url: BASE + 'edit',
method: 'put',
data: apiParams('edit', data)
})
}
export function deleteProcessCard (data) {
return request({
url: BASE + 'delete',
method: 'delete',
data: apiParams('delete', data)
})
}
export function setSetting (data) {
return request({
url: BASE + 'set_setting',
method: 'post',
data: apiParams('set_setting', data)
})
}
export function moveUp (data) {
return request({
url: BASE + 'move_up',
method: 'post',
data: apiParams('move_up', data)
})
}
export function moveDown (data) {
return request({
url: BASE + 'move_down',
method: 'post',
data: apiParams('move_down', data)
})
}
export function getOptionalParamsDetails (data) {
return request({
url: BASE + 'get_optional_params_details',
method: 'get',
params: apiParams('get_optional_params_details', data)
})
}
export function getOptionalAllParamsDetails (data) {
return request({
url: BASE + 'get_optional_all_params_details',
method: 'get',
params: apiParams('get_optional_all_params_details', data)
})
}
export function getStep (data) {
return request({
url: BASE + 'get_step',
method: 'get',
params: apiParams('get_step', data)
})
}
export function getTemperatureList (data) {
return request({
url: BASE + 'get_temperature_list',
method: 'get',
params: apiParams('get_temperature_list', data)
})
}
export function createTemperature (data) {
return request({
url: BASE + 'create_temperature',
method: 'post',
data: apiParams('create_temperature', data)
})
}
export function getTemperatureTemplate (data) {
return request({
url: BASE + 'get_temperature_template',
method: 'post',
responseType: 'blob',
data: apiParams('get_temperature_template', data)
})
}
export function getAllWorkingsubclassParams (data) {
return request({
url: BASE + 'get_all_workingsubclass_params',
method: 'get',
params: apiParams('get_all_workingsubclass_params', data)
})
}
export function addOptionalParams (data) {
return request({
url: BASE + 'add_optional_params',
method: 'post',
data: apiParams('add_optional_params', data)
})
}

View File

@@ -0,0 +1,51 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/technology_model/technology_flow/'
function apiParams (method, data = {}) {
return {
method: `production_master_data_process_model_process_routing_${method}`,
platform: 'background',
...data
}
}
export function getProcessRoutingList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('list', data)
})
}
export function createProcessRouting (data) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams('create', data)
})
}
export function editProcessRouting (data) {
return request({
url: BASE + 'edit',
method: 'put',
data: apiParams('edit', data)
})
}
export function deleteProcessRouting (data) {
return request({
url: BASE + 'delete',
method: 'delete',
data: apiParams('delete', data)
})
}
export function copyProcessRouting (data) {
return request({
url: BASE + 'copy',
method: 'post',
data: apiParams('copy', data)
})
}

View File

@@ -18,6 +18,18 @@ export function getProcessStepList (data) {
})
}
export function getWorkingsubclassAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: {
method: 'production_configuration_technology_model_technology_flow_workingsubclass_all',
platform: 'background',
...data
}
})
}
export function createProcessStep (data) {
return request({
url: BASE + 'create',

View File

@@ -2,7 +2,7 @@ import { request } from '@/api/_service'
const BASE = 'production_configuration/product_model/battery_model/'
function apiParams(method, data = {}) {
function apiParams (method, data = {}) {
return {
method: `production_master_data_product_management_product_list_${method}`,
platform: 'background',
@@ -10,7 +10,7 @@ function apiParams(method, data = {}) {
}
}
export function getProductList(data) {
export function getProductList (data) {
return request({
url: BASE + 'list',
method: 'get',
@@ -18,7 +18,19 @@ export function getProductList(data) {
})
}
export function createProduct(data) {
export function getProductBatteryAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: {
method: 'production_configuration_product_model_battery_model_all',
platform: 'background',
...data
}
})
}
export function createProduct (data) {
return request({
url: BASE + 'create',
method: 'post',
@@ -26,7 +38,7 @@ export function createProduct(data) {
})
}
export function editProduct(data) {
export function editProduct (data) {
return request({
url: BASE + 'edit',
method: 'put',
@@ -34,7 +46,7 @@ export function editProduct(data) {
})
}
export function deleteProduct(data) {
export function deleteProduct (data) {
return request({
url: BASE + 'delete',
method: 'delete',

View File

@@ -0,0 +1,76 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/product_model/product_ng_info/'
function apiParams (method, data = {}) {
return {
method: `production_configuration_product_model_product_ng_info_${method}`,
platform: 'background',
...data
}
}
export function getProductNgInfoAll (data) {
return request({
url: BASE + 'all',
method: 'get',
params: { ...data }
})
}
export function getProductNgInfoList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: { ...data }
})
}
export function createProductNgInfo (data) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams('create', data)
})
}
export function editProductNgInfo (data) {
return request({
url: BASE + 'edit',
method: 'put',
data: apiParams('edit', data)
})
}
export function deleteProductNgInfo (data) {
return request({
url: BASE + 'delete',
method: 'delete',
data: apiParams('delete', data)
})
}
export function getImportTemplate (data) {
return request({
url: BASE + 'get_import_template',
method: 'post',
responseType: 'blob',
data: apiParams('get_import_template', data)
})
}
export function productNgInfoImport (data) {
return request({
url: BASE + 'import',
method: 'post',
data: apiParams('import', data)
})
}
export function productNgInfoExportTask (data) {
return request({
url: BASE + 'product_ng_info_export_task',
method: 'post',
data: apiParams('product_ng_info_export_task', data)
})
}

View File

@@ -0,0 +1,17 @@
import { request } from '@/api/_service'
const BASE = 'system_settings/organization/production_shift_management/'
function params (method, data = {}) {
return { method: `system_settings_organization_production_shift_management_${method}`, platform: 'background', ...data }
}
export function getShiftAll (data) { return request({ url: BASE + 'all', method: 'get', params: params('all', data) }) }
export function getShiftList (data) { return request({ url: BASE + 'list', method: 'get', params: params('list', data) }) }
export function createShift (data) { return request({ url: BASE + 'create', method: 'post', data: params('create', data) }) }
export function editShift (data) { return request({ url: BASE + 'edit', method: 'put', data: params('edit', data) }) }
export function deleteShift (data) { return request({ url: BASE + 'delete', method: 'delete', data: params('delete', data) }) }
export function getShiftImportTemplate (data) { return request({ url: BASE + 'get_import_template', method: 'post', responseType: 'blob', data: params('get_import_template', data) }) }
export function importShiftData (data) { return request({ url: BASE + 'data_import', method: 'post', data: params('data_import', data) }) }
export function exportShiftTask (data) { return request({ url: BASE + 'data_export_task', method: 'post', data: params('data_export_task', data) }) }
export function getShiftCalendarByDateRange (data) { return request({ url: BASE + 'get_shift_by_date_range', method: 'get', params: params('get_shift_by_date_range', data) }) }

View File

@@ -0,0 +1,24 @@
import { request } from '@/api/_service'
const BASE = 'system_settings/organization/production_team_manage/'
const MEMBER_BASE = 'system_settings/organization/production_members_manage/'
function params (method, data = {}) {
return { method: `system_settings_organization_production_team_manage_${method}`, platform: 'background', ...data }
}
function memberParams (method, data = {}) {
return { method: `system_settings_organization_production_members_manage_${method}`, platform: 'background', ...data }
}
export function getTeamAll (data) { return request({ url: BASE + 'all', method: 'get', params: params('all', data) }) }
export function getTeamList (data) { return request({ url: BASE + 'list', method: 'get', params: params('list', data) }) }
export function createTeam (data) { return request({ url: BASE + 'create', method: 'post', data: params('create', data) }) }
export function editTeam (data) { return request({ url: BASE + 'edit', method: 'put', data: params('edit', data) }) }
export function deleteTeam (data) { return request({ url: BASE + 'delete', method: 'delete', data: params('delete', data) }) }
export function getTeamImportTemplate (data) { return request({ url: BASE + 'get_import_template', method: 'post', responseType: 'blob', data: params('get_import_template', data) }) }
export function importTeamData (data) { return request({ url: BASE + 'data_import', method: 'post', data: params('data_import', data) }) }
export function exportTeamTask (data) { return request({ url: BASE + 'data_export_task', method: 'post', data: params('data_export_task', data) }) }
export function getTeamMemberList (data) { return request({ url: MEMBER_BASE + 'list', method: 'get', params: memberParams('list', data) }) }
export function deleteTeamMember (data) { return request({ url: MEMBER_BASE + 'delete', method: 'delete', data: memberParams('delete', data) }) }

View File

@@ -0,0 +1,15 @@
import { request } from '@/api/_service'
const BASE = 'production_configuration/workerman/'
export function sendWorkerman (data) {
return request({
url: BASE + 'send',
method: 'get',
params: {
method: 'planning_production_produce_traymanage_send_workerman',
module: 'api',
...data
}
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/xqc/aql_config/'
function apiParams (data = {}, method = 'quality_control_xqc_aql_config_list', platform = 'background') {
return { method, platform, ...data }
}
export function fetchAqlStandardsList (data = {}) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams(data, 'quality_control_xqc_aql_config_list', 'background')
})
}
export function createAqlStandards (data = {}) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams(data, 'quality_control_xqc_aql_config_create', 'api')
})
}
export function editAqlStandards (data = {}) {
return request({
url: BASE + 'edit',
method: 'post',
data: apiParams(data, 'quality_control_xqc_aql_config_edit', 'api')
})
}
export function deleteAqlStandards (data = {}) {
return request({
url: BASE + 'delete',
method: 'post',
data: apiParams(data, 'quality_control_xqc_aql_config_delete', 'api')
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/first_inspection/first_inspection/'
function apiParams (data = {}, method = 'get.setting.list', platform = 'api') {
return { method, platform, ...data }
}
export function fetchFirstArticleInspectionConfigurationList (data = {}) {
return request({
url: BASE + 'list',
method: 'post',
data: apiParams(data, 'get.setting.list', 'api')
})
}
export function createFirstArticleInspectionConfiguration (data = {}) {
return request({
url: BASE + 'add',
method: 'post',
data: apiParams(data, 'add.setting', 'admin')
})
}
export function editFirstArticleInspectionConfiguration (data = {}) {
return request({
url: BASE + 'update',
method: 'post',
data: apiParams(data, 'set.setting', 'admin')
})
}
export function deleteFirstArticleInspectionConfiguration (data = {}) {
return request({
url: BASE + 'delete',
method: 'post',
data: apiParams(data, 'del.setting.list', 'admin')
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/first_inspection/first_inspection/'
function apiParams (data = {}, method = 'get.setting.item.list', platform = 'api') {
return { method, platform, ...data }
}
export function fetchFirstArticleInspectionRecordsList (data = {}) {
return request({
url: BASE + 'item/list',
method: 'post',
data: apiParams(data, 'get.setting.item.list', 'api')
})
}
export function createFirstArticleInspectionRecords (data = {}) {
return request({
url: BASE + 'item/add',
method: 'post',
data: apiParams(data, 'add.setting.item', 'admin')
})
}
export function editFirstArticleInspectionRecords (data = {}) {
return request({
url: BASE + 'item/update',
method: 'post',
data: apiParams(data, 'set.setting.item', 'admin')
})
}
export function deleteFirstArticleInspectionRecords (data = {}) {
return request({
url: BASE + 'item/delete',
method: 'post',
data: apiParams(data, 'del.setting.item', 'admin')
})
}

View File

@@ -0,0 +1,15 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/first_inspection/first_inspection/'
function apiParams (data = {}, method = 'get.setting.item.list', platform = 'api') {
return { method, platform, ...data }
}
export function fetchFirstArticleInspectionReportsList (data = {}) {
return request({
url: BASE + 'item/list',
method: 'post',
data: apiParams(data, 'get.setting.item.list', 'api')
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/xqc/inspection_item/'
function apiParams (data = {}, method = 'get.quality.inspection_item.list', platform = 'api') {
return { method, platform, ...data }
}
export function fetchInspectionItemsList (data = {}) {
return request({
url: BASE + 'list',
method: 'post',
data: apiParams(data, 'get.quality.inspection_item.list', 'api')
})
}
export function createInspectionItems (data = {}) {
return request({
url: BASE + 'add',
method: 'post',
data: apiParams(data, 'add.quality.inspection_item.add', 'api')
})
}
export function editInspectionItems (data = {}) {
return request({
url: BASE + 'set',
method: 'post',
data: apiParams(data, 'set.quality.inspection_item.set', 'api')
})
}
export function deleteInspectionItems (data = {}) {
return request({
url: BASE + 'del',
method: 'post',
data: apiParams(data, 'del.quality.inspection_item.del', 'api')
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/xqc/inspection_order_manage/'
function apiParams (data = {}, method = 'xqc.inspection_order_manage.list', platform = 'api') {
return { method, platform, ...data }
}
export function fetchInspectionOrdersList (data = {}) {
return request({
url: BASE + 'list',
method: 'post',
data: apiParams(data, 'xqc.inspection_order_manage.list', 'api')
})
}
export function createInspectionOrders (data = {}) {
return request({
url: BASE + 'save',
method: 'post',
data: apiParams(data, 'xqc.inspection_order_manage.save', 'api')
})
}
export function editInspectionOrders (data = {}) {
return request({
url: BASE + 'save',
method: 'post',
data: apiParams(data, 'xqc.inspection_order_manage.save', 'api')
})
}
export function deleteInspectionOrders (data = {}) {
return request({
url: BASE + 'revoke',
method: 'post',
data: apiParams(data, 'xqc.inspection_order_manage.revoke', 'api')
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/xqc/inspection_plan/'
function apiParams (data = {}, method = 'quality_control_xqc_inspection_plan_list', platform = 'background') {
return { method, platform, ...data }
}
export function fetchInspectionPlansList (data = {}) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams(data, 'quality_control_xqc_inspection_plan_list', 'background')
})
}
export function createInspectionPlans (data = {}) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams(data, 'quality_control_xqc_inspection_plan_create', 'background')
})
}
export function editInspectionPlans (data = {}) {
return request({
url: BASE + 'edit',
method: 'post',
data: apiParams(data, 'quality_control_xqc_inspection_plan_edit', 'background')
})
}
export function deleteInspectionPlans (data = {}) {
return request({
url: BASE + 'delete',
method: 'post',
data: apiParams(data, 'quality_control_xqc_inspection_plan_delete', 'background')
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/xqc/inspection_standard/'
function apiParams (data = {}, method = 'get.quality.inspection_standard.list', platform = 'api') {
return { method, platform, ...data }
}
export function fetchInspectionStandardsList (data = {}) {
return request({
url: BASE + 'list',
method: 'post',
data: apiParams(data, 'get.quality.inspection_standard.list', 'api')
})
}
export function createInspectionStandards (data = {}) {
return request({
url: BASE + 'add',
method: 'post',
data: apiParams(data, 'add.quality.inspection_standard.add', 'api')
})
}
export function editInspectionStandards (data = {}) {
return request({
url: BASE + 'set',
method: 'post',
data: apiParams(data, 'set.quality.inspection_standard.set', 'api')
})
}
export function deleteInspectionStandards (data = {}) {
return request({
url: BASE + 'del',
method: 'post',
data: apiParams(data, 'del.quality.inspection_standard.del', 'api')
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/first_inspection/first_inspection/'
function apiParams (data = {}, method = 'get.quality.category.list', platform = 'api') {
return { method, platform, ...data }
}
export function fetchInspectionTypeManagementList (data = {}) {
return request({
url: BASE + 'category/list',
method: 'post',
data: apiParams(data, 'get.quality.category.list', 'api')
})
}
export function createInspectionTypeManagement (data = {}) {
return request({
url: BASE + 'category/add',
method: 'post',
data: apiParams(data, 'add.quality.category', 'api')
})
}
export function editInspectionTypeManagement (data = {}) {
return request({
url: BASE + 'category/update',
method: 'post',
data: apiParams(data, 'set.quality.category', 'api')
})
}
export function deleteInspectionTypeManagement (data = {}) {
return request({
url: BASE + 'category/delete',
method: 'post',
data: apiParams(data, 'del.quality.category', 'api')
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'quality_control/xqc/sampling_plan/'
function apiParams (data = {}, method = 'xqc.sampling_plan_config.list', platform = 'api') {
return { method, platform, ...data }
}
export function fetchSamplingPlansList (data = {}) {
return request({
url: BASE + 'list',
method: 'post',
data: apiParams(data, 'xqc.sampling_plan_config.list', 'api')
})
}
export function createSamplingPlans (data = {}) {
return request({
url: BASE + 'save',
method: 'post',
data: apiParams(data, 'xqc.sampling_plan_config.save', 'api')
})
}
export function editSamplingPlans (data = {}) {
return request({
url: BASE + 'save',
method: 'post',
data: apiParams(data, 'xqc.sampling_plan_config.save', 'api')
})
}
export function deleteSamplingPlans (data = {}) {
return request({
url: BASE + 'delete',
method: 'post',
data: apiParams(data, 'xqc.sampling_plan_config.delete', 'api')
})
}

View File

@@ -0,0 +1,39 @@
import { request } from '@/api/_service'
const BASE = 'spc/manager/'
function apiParams (data = {}, method = 'get.spc.create', platform = 'admin') {
return { method, platform, ...data }
}
export function fetchSpcConfigurationList (data = {}) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams(data, 'get.spc.create', 'admin')
})
}
export function createSpcConfiguration (data = {}) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams(data, 'set.spc.create', 'admin')
})
}
export function editSpcConfiguration (data = {}) {
return request({
url: BASE + 'edit',
method: 'put',
data: apiParams(data, 'set.spc.edit', 'admin')
})
}
export function deleteSpcConfiguration (data = {}) {
return request({
url: BASE + 'delete',
method: 'post',
data: apiParams(data, 'set.spc.delete', 'admin')
})
}

View File

@@ -0,0 +1,24 @@
import { request } from '@/api/_service'
const BASE = 'spc/manager/'
function apiParams (data = {}, method = 'get.spc.all') {
return { method, platform: 'admin', ...data }
}
export function getSpcConfigAll (data = {}) {
return request({
url: BASE + 'all',
method: 'get',
params: apiParams(data, 'get.spc.all')
})
}
export function getNodeSubgroupSamplesData (data = {}) {
return request({
baseURL: process.env.VUE_APP_HSLSERVER_API,
url: '',
method: 'post',
data
})
}

View File

@@ -0,0 +1,43 @@
import { request } from '@/api/_service'
const BASE = 'system_settings/system_monitor/setting/'
function apiParams (method, data = {}) {
return {
method: `system_settings_system_monitoring_setting_${method}`,
platform: 'background',
...data
}
}
export function getMonitoringConfigurationList (data) {
return request({
url: BASE + 'list',
method: 'get',
params: apiParams('list', data)
})
}
export function createMonitoringConfiguration (data) {
return request({
url: BASE + 'create',
method: 'post',
data: apiParams('create', data)
})
}
export function editMonitoringConfiguration (data) {
return request({
url: BASE + 'edit',
method: 'post',
data: apiParams('edit', data)
})
}
export function deleteMonitoringConfiguration (data) {
return request({
url: BASE + 'delete',
method: 'post',
data: apiParams('delete', data)
})
}

Some files were not shown because too many files have changed in this diff Show More