Compare commits
75 Commits
a0192d9567
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
8ef94ecf2e | ||
|
|
e8e79fcb3f | ||
|
|
c670488c80 | ||
|
|
cf90981c5d | ||
|
|
964cf0b6ad | ||
|
|
7cf7caf31f | ||
|
|
c1e8626289 | ||
|
|
dcc706308b | ||
|
|
f40ff30943 | ||
|
|
5d1fbcc508 | ||
|
|
5a4001ddf7 | ||
|
|
9af7dbf668 | ||
|
|
d984ea6107 | ||
|
|
f817714c56 | ||
|
|
f625f3063d | ||
|
|
9c54df9600 | ||
|
|
7c48d0b7c7 | ||
|
|
ffead080ad | ||
|
|
2739415e35 | ||
|
|
54ba033db6 | ||
|
|
9f349d325a | ||
|
|
cc7e06fdb1 | ||
|
|
15105bc5c7 | ||
|
|
a9c88eb264 | ||
|
|
7125bc4884 | ||
|
|
19f8f18f85 | ||
|
|
9675227702 | ||
|
|
e1111fe6df | ||
|
|
e9faea739a | ||
|
|
be119060f0 | ||
|
|
1e2945d4a3 | ||
|
|
bf493321cb | ||
|
|
2690204ec5 | ||
|
|
8eaa5f90ca | ||
|
|
25bd394f96 | ||
|
|
80ef16f3e5 | ||
|
|
86313d309f | ||
|
|
6a664277a5 | ||
|
|
19050966b4 | ||
|
|
c58525b284 | ||
|
|
bf1365c1ea | ||
|
|
8d1be42ce2 | ||
|
|
0740f82083 | ||
|
|
4714bbabc5 | ||
|
|
8e5127ea88 | ||
|
|
f2ffac4a06 | ||
|
|
41bbe3bf62 | ||
|
|
c07f95a45e | ||
|
|
973c780bf6 | ||
|
|
6768eb9ead | ||
|
|
a1716b0069 | ||
|
|
15526ca6e4 | ||
|
|
264474eced | ||
|
|
fe45390997 | ||
|
|
3c4a665dc3 | ||
|
|
7987d9a085 | ||
|
|
e3fd31e33d | ||
|
|
9863bf1113 | ||
|
|
6bb2d1285c | ||
|
|
eb31da72e0 | ||
|
|
b942d24f2c | ||
|
|
8ef087676f | ||
|
|
45c2ea6e63 | ||
|
|
b44e031e74 | ||
|
|
3f546564cc | ||
| b6c362d906 | |||
| 76b480ece5 | |||
|
|
76f9657fe9 | ||
| e0d2c7c886 | |||
|
|
df11ca0db6 | ||
|
|
8b587163df | ||
|
|
f1e73f3319 | ||
|
|
ddc715e17c | ||
| 87edf1c76f | |||
| 9100f65325 |
1
.node-version
Normal file
1
.node-version
Normal file
@@ -0,0 +1 @@
|
||||
18.16.0
|
||||
8
.npmrc
Normal file
8
.npmrc
Normal file
@@ -0,0 +1,8 @@
|
||||
# pnpm 配置
|
||||
# 强制通过 pnpm 安装,禁止使用 npm / yarn
|
||||
engine-strict=true
|
||||
# 使用 lockfile 锁定依赖版本
|
||||
lockfile=true
|
||||
# 依赖提升模式(兼容旧项目)
|
||||
shamefully-hoist=true
|
||||
# 允许在 package.json 中通过 packageManager 字段指定包管理器版本
|
||||
479
README.md
479
README.md
@@ -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 版本。
|
||||
|
||||
**Windows(PowerShell):**
|
||||
|
||||
```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)。
|
||||
|
||||
### 第二步:启用 pnpm(Volta 内置支持,无需额外安装)
|
||||
|
||||
```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.0(Volta 自动读取切换)
|
||||
```
|
||||
|
||||
- Volta 进入项目目录时自动将 Node.js 切换为 `18.16.0`
|
||||
- 如果该版本未安装,Volta 会自动下载并安装
|
||||
- 传统方案(nvm)也兼容:`nvm use` 读取 `.nvmrc`,本项目同时提供 `.node-version` 供 Volta 使用
|
||||
|
||||
### pnpm 版本锁定
|
||||
|
||||
```
|
||||
package.json
|
||||
├── packageManager → pnpm@10.33.0(Corepack / Volta 识别)
|
||||
├── engines.pnpm → >=10.33.0 <11(npm/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
|
||||
```
|
||||
|
||||
20
docs/功能测试-BOM物料清单.md
Normal file
20
docs/功能测试-BOM物料清单.md
Normal 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权限的账号进入页面 | 对应按钮不显示或不可操作 | ☐ |
|
||||
648
docs/功能测试-SPC采集配置.md
Normal file
648
docs/功能测试-SPC采集配置.md
Normal 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 展示
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 查看列表中状态列的不同取值 |
|
||||
| **预期结果** | 启用状态显示绿色 tag(success 类型),禁用状态显示红色 tag(danger 类型) |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### 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 |
|
||||
| 通过用例数 | |
|
||||
| 未通过用例数 | |
|
||||
| 通过率 | |
|
||||
| 是否达到上线标准 | ⬜ 是 / ⬜ 否 |
|
||||
| 备注 | |
|
||||
|
||||
**测试人员**:________________
|
||||
|
||||
**测试日期**:________________
|
||||
|
||||
**审核人员**:________________
|
||||
|
||||
**审核日期**:________________
|
||||
40
docs/功能测试-反向追溯.md
Normal file
40
docs/功能测试-反向追溯.md
Normal 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` 时,页面应能自动查询对应追溯数据。
|
||||
31
docs/功能测试-托盘追溯.md
Normal file
31
docs/功能测试-托盘追溯.md
Normal 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` 查询参数。
|
||||
14
docs/功能测试-排班日历.md
Normal file
14
docs/功能测试-排班日历.md
Normal file
@@ -0,0 +1,14 @@
|
||||
# 功能测试任务列表 - 排班日历
|
||||
|
||||
> 路由:`/system_settings/organization/production_shift_calender`
|
||||
|
||||
| 序号 | 测试项 | 操作步骤 | 预期结果 | 结果 |
|
||||
|---|---|---|---|---|
|
||||
| 1 | 页面入口 | 从菜单进入“排班日历” | 页面正常打开,展示当前月份日历 | ☐ |
|
||||
| 2 | 初始数据加载 | 打开页面后观察日历单元格 | 系统请求当前日历可视范围的排班数据,并在日期下显示班次计划标签 | ☐ |
|
||||
| 3 | 休息日展示 | 查看包含休息日的日期 | 休息日以灰色标签显示“休” | ☐ |
|
||||
| 4 | 工作日展示 | 查看包含排班的日期 | 日期下展示班次计划标签 | ☐ |
|
||||
| 5 | 明细悬浮 | 鼠标悬浮工作日班次计划标签 | 弹出层展示班次名称、开始/结束时间、绑定班组和跨天标识 | ☐ |
|
||||
| 6 | 跨月切换 | 点击日历上一月/下一月 | 日历切换月份并重新加载新可视范围数据 | ☐ |
|
||||
| 7 | 选择日期 | 点击任意日期 | 日期高亮状态正常,不影响排班数据显示 | ☐ |
|
||||
| 8 | 空数据展示 | 切换到无排班数据的月份 | 日历正常显示,无错误提示或残留旧数据 | ☐ |
|
||||
33
docs/功能测试-正向追溯.md
Normal file
33
docs/功能测试-正向追溯.md
Normal 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`。
|
||||
19
docs/功能测试-班次管理.md
Normal file
19
docs/功能测试-班次管理.md
Normal 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 | 权限按钮 | 使用缺少权限账号进入页面 | 对应新增/编辑/删除/导入/导出按钮隐藏或不可操作 | ☐ |
|
||||
19
docs/功能测试-班组管理.md
Normal file
19
docs/功能测试-班组管理.md
Normal 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 | 权限按钮 | 使用缺少权限账号进入页面 | 对应新增/编辑/删除/导入/导出按钮隐藏或不可操作 | ☐ |
|
||||
36
docs/功能测试-电池复投管理.md
Normal file
36
docs/功能测试-电池复投管理.md
Normal 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` 应与测试输入或勾选行一致。
|
||||
31
docs/功能测试-电池曲线.md
Normal file
31
docs/功能测试-电池曲线.md
Normal 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。
|
||||
23
docs/功能测试-电池详情报表.md
Normal file
23
docs/功能测试-电池详情报表.md
Normal file
@@ -0,0 +1,23 @@
|
||||
# 功能测试 - 电池详情报表
|
||||
|
||||
> 模块:数据中台 / 生产报表 / 电池详情报表 (Battery Detail Report)
|
||||
> 路由:`/data_middleground/produce/report/battery-detail`
|
||||
|
||||
## 测试任务列表
|
||||
|
||||
| 序号 | 测试项 | 操作步骤 | 预期结果 |
|
||||
|---:|---|---|---|
|
||||
| 1 | 页面入口 | 进入电池详情报表页面 | 页面显示工艺流程、批次、工序、托盘、时间筛选项 |
|
||||
| 2 | 工艺选择 | 选择工艺流程 | 批次和工序下拉数据按工艺刷新 |
|
||||
| 3 | 批次必填校验 | 不选批次点击查询 | 页面提示请选择批次 |
|
||||
| 4 | 查询报表 | 选择批次和筛选条件后查询 | 表格按动态表头展示电池详情数据 |
|
||||
| 5 | 分页切换 | 查询出多页数据后切换分页 | 当前页数据刷新,总数正确 |
|
||||
| 6 | 导出任务 | 选择批次后点击导出并确认 | 创建导出任务成功并跳转任务页面 |
|
||||
| 7 | 重置功能 | 点击重置 | 筛选项、动态表头、表格和分页清空 |
|
||||
| 8 | 国际化检查 | 切换中英文语言 | 页面文案随语言切换 |
|
||||
|
||||
## 回归关注点
|
||||
|
||||
- 查询前必须先获取动态表头。
|
||||
- 导出任务 action 必须为 `download`。
|
||||
- 后端返回嵌套表头时需要展开为可展示列。
|
||||
31
docs/功能测试-电池追溯.md
Normal file
31
docs/功能测试-电池追溯.md
Normal 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。
|
||||
15
docs/功能测试-监控设置.md
Normal file
15
docs/功能测试-监控设置.md
Normal file
@@ -0,0 +1,15 @@
|
||||
# 功能测试任务列表 - 监控设置
|
||||
|
||||
> 路由:`/system_settings/system_monitoring/setting`
|
||||
|
||||
| 序号 | 测试项 | 操作步骤 | 预期结果 | 结果 |
|
||||
|---|---|---|---|---|
|
||||
| 1 | 页面入口 | 从菜单进入“监控设置”,或直接访问路由 | 页面正常打开,表格展示监控编码、名称、IP、端口、版本和预警阈值字段 | ☐ |
|
||||
| 2 | 条件查询 | 输入监控编码或监控名称后点击“查询” | 列表按条件刷新,分页回到第一页 | ☐ |
|
||||
| 3 | 重置查询 | 输入查询条件后点击“重置” | 查询条件清空,列表恢复默认数据 | ☐ |
|
||||
| 4 | 新增必填校验 | 点击“新增”,不填写编码、名称、IP 或端口直接确认 | 表单提示对应必填校验,不提交请求 | ☐ |
|
||||
| 5 | 新增监控配置 | 填写编码、名称、IP、端口、刷新间隔、CPU/磁盘/内存阈值和 Python 版本后确认 | 弹窗关闭,提示操作成功,列表出现新增记录 | ☐ |
|
||||
| 6 | 编辑监控配置 | 点击某条记录“编辑”,修改名称或阈值后确认 | 弹窗回显旧值,保存后列表展示新值 | ☐ |
|
||||
| 7 | 删除取消 | 点击“删除”后在确认框选择取消 | 数据不删除,列表保持不变 | ☐ |
|
||||
| 8 | 删除确认 | 点击“删除”后确认 | 提示操作成功,记录从列表移除,分页数量正确刷新 | ☐ |
|
||||
| 9 | 权限按钮 | 使用无新增/编辑/删除权限的账号进入页面 | 对应按钮不显示或不可操作 | ☐ |
|
||||
9
docs/功能测试-设备保养日志.md
Normal file
9
docs/功能测试-设备保养日志.md
Normal file
@@ -0,0 +1,9 @@
|
||||
# 设备保养日志功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备保养 / 设备保养日志`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
10
docs/功能测试-设备保养详情.md
Normal file
10
docs/功能测试-设备保养详情.md
Normal file
@@ -0,0 +1,10 @@
|
||||
# 设备保养详情功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备保养 / 设备保养详情`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
10
docs/功能测试-设备保养项目.md
Normal file
10
docs/功能测试-设备保养项目.md
Normal file
@@ -0,0 +1,10 @@
|
||||
# 设备保养项目功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备保养 / 设备保养项目`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
11
docs/功能测试-设备信息.md
Normal file
11
docs/功能测试-设备信息.md
Normal file
@@ -0,0 +1,11 @@
|
||||
# 设备信息功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备信息 / 设备信息`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 如当前账号有导出权限,点击导出可创建导出任务。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
22
docs/功能测试-设备履历报表.md
Normal file
22
docs/功能测试-设备履历报表.md
Normal 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`。
|
||||
11
docs/功能测试-设备损耗品寿命管理.md
Normal file
11
docs/功能测试-设备损耗品寿命管理.md
Normal file
@@ -0,0 +1,11 @@
|
||||
# 设备损耗品寿命管理功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备损耗品 / 设备损耗品寿命管理`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
11
docs/功能测试-设备损耗品更换日志.md
Normal file
11
docs/功能测试-设备损耗品更换日志.md
Normal file
@@ -0,0 +1,11 @@
|
||||
# 设备损耗品更换日志功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备损耗品 / 设备损耗品更换日志`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
11
docs/功能测试-设备损耗品类别.md
Normal file
11
docs/功能测试-设备损耗品类别.md
Normal file
@@ -0,0 +1,11 @@
|
||||
# 设备损耗品类别功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备损耗品 / 设备损耗品类别`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
11
docs/功能测试-设备损耗品项目.md
Normal file
11
docs/功能测试-设备损耗品项目.md
Normal file
@@ -0,0 +1,11 @@
|
||||
# 设备损耗品项目功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备损耗品 / 设备损耗品项目`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
8
docs/功能测试-设备点检日志.md
Normal file
8
docs/功能测试-设备点检日志.md
Normal file
@@ -0,0 +1,8 @@
|
||||
# 设备点检日志功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备点检 / 设备点检日志`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
9
docs/功能测试-设备点检记录.md
Normal file
9
docs/功能测试-设备点检记录.md
Normal file
@@ -0,0 +1,9 @@
|
||||
# 设备点检记录功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备点检 / 设备点检记录`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
10
docs/功能测试-设备点检项目.md
Normal file
10
docs/功能测试-设备点检项目.md
Normal file
@@ -0,0 +1,10 @@
|
||||
# 设备点检项目功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备点检 / 设备点检项目`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
698
docs/功能测试-设备类别.md
Normal file
698
docs/功能测试-设备类别.md
Normal file
@@ -0,0 +1,698 @@
|
||||
# 设备类别功能测试流程文档
|
||||
|
||||
> **测试对象**:设备管理 → 设备模型 → 设备类别(Equipment Category)
|
||||
> **迁移日期**:2026-06-02
|
||||
> **对应页面**:`src/views/equipment-management/equipment-model/equipment-category/index.vue`
|
||||
> **API 文件**:`src/api/equipment-management/equipment-category.js`
|
||||
> **路由路径**:`/device_management/equipment_model/equipment_category`(旧值暂留)
|
||||
> **i18n 前缀**:`page.equipment_management.equipment_model.equipment_category`
|
||||
|
||||
---
|
||||
|
||||
## 一、测试环境配置
|
||||
|
||||
| 配置项 | 要求 |
|
||||
|--------|------|
|
||||
| 浏览器 | Chrome 最新版、Edge 最新版(兼容 IE 11+) |
|
||||
| 屏幕分辨率 | ≥ 1920×1080 |
|
||||
| Node.js | ≥ 16.x |
|
||||
| 包管理器 | pnpm ≥ 7.x |
|
||||
| 后端服务 | 设备类别相关 API 正常运行(`device_management/equipment_model/equipment_category/*`) |
|
||||
| 测试账号 | 具有设备管理 → 设备类别菜单权限的账号(含 create/edit/delete 权限) |
|
||||
| 测试数据 | 准备至少 5 条测试用设备类别(编码唯一) |
|
||||
| 语言切换 | 先测中文(简体中文),再切到英文验证 i18n |
|
||||
| 权限分配 | 系统管理 → 菜单管理中确认设备类别按钮权限(新增、编辑、删除)已正确配置 |
|
||||
|
||||
---
|
||||
|
||||
## 二、测试前置条件
|
||||
|
||||
1. 后端服务(Webman)已启动,`device_management` 模块的 API 可正常访问
|
||||
2. 前端项目已执行 `pnpm install` 且 `pnpm dev` 正常启动,可访问登录页
|
||||
3. 使用具有「设备管理 → 设备类别」菜单权限的管理员账号登录
|
||||
4. 侧边栏菜单 **设备管理 → 设备模型** 下可见 **设备类别** 子菜单
|
||||
5. 浏览器控制台无 Vue 警告或 i18n key 缺失报错
|
||||
6. 确认 `src/locales/zh-chs.json` 和 `src/locales/en.json` 中存在 `page.equipment_management.equipment_model.equipment_category` 配置
|
||||
7. 数据库中设备类别表为空或仅有少量测试数据,便于验证
|
||||
|
||||
---
|
||||
|
||||
## 三、功能测试用例
|
||||
|
||||
### 3.1 页面加载与数据展示
|
||||
|
||||
#### TC-EC-001:菜单导航与页面加载
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 登录系统 2. 点击侧边栏菜单「设备管理 → 设备模型 → 设备类别」 |
|
||||
| **预期结果** | 页面正常加载,URL 显示 `/device_management/equipment_model/equipment_category`;页面顶部显示搜索栏(设备类别编码、设备类别名称、查询、重置按钮);中部显示设备类别列表表格;底部分页组件显示 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-002:列表表格列头与数据展示
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 查看设备类别列表的表头列与各行数据 |
|
||||
| **预期结果** | 表格列依次为:序号、设备类别编码、设备类别名称、备注、操作;操作列包含「编辑」「删除」两个按钮(带图标);当数据为空时显示空数据占位提示 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-003:工具栏按钮显示
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 查看表格上方的工具栏 |
|
||||
| **预期结果** | 显示蓝色「新增」按钮(含加号图标),右上角显示问号「帮助」按钮(点击跳转 `/help/equipment-category`) |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-004:表格自适应高度
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 加载页面后查看表格高度 2. 缩小/放大浏览器窗口 3. 折叠/展开侧边栏 |
|
||||
| **预期结果** | 表格高度自动填满 d2-container 剩余空间,窗口变化时无空白或滚动条异常 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.2 搜索功能
|
||||
|
||||
#### TC-EC-005:按编码精确搜索
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 在「设备类别编码」输入框输入完整的类别编码(如 `EQ_CAT_001`) 2. 点击「查询」按钮 |
|
||||
| **预期结果** | 表格仅显示编码匹配的数据行;分页总数更新为匹配条数;输入框右侧 X 按钮可清空内容 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-006:按编码模糊搜索
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 在「设备类别编码」输入框输入编码的片段(如 `EQ_`) 2. 点击「查询」按钮 |
|
||||
| **预期结果** | 表格显示所有编码包含 `EQ_` 的数据行 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-007:按名称搜索
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 在「设备类别名称」输入框输入关键字(如「自动化」) 2. 点击「查询」按钮 |
|
||||
| **预期结果** | 表格仅显示名称包含关键字的设备类别 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-008:组合条件搜索
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 同时输入「设备类别编码」和「设备类别名称」搜索条件 2. 点击「查询」按钮 |
|
||||
| **预期结果** | 表格显示同时满足两个条件的数据行(AND 关系) |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-009:回车键触发搜索
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 在搜索输入框中输入关键字 2. 按下键盘回车键 |
|
||||
| **预期结果** | 等同于点击「查询」按钮,表格按搜索条件刷新 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-010:重置搜索
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 输入搜索条件并点击「查询」 2. 点击「重置」按钮 |
|
||||
| **预期结果** | 搜索输入框清空,表格恢复显示全部设备类别数据 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-011:搜索无结果
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 输入不存在的编码或名称 2. 点击「查询」 |
|
||||
| **预期结果** | 表格显示空数据占位提示,分页总数显示 0 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.3 分页功能
|
||||
|
||||
#### TC-EC-012:分页默认显示
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 加载页面后查看分页组件 |
|
||||
| **预期结果** | 分页默认显示第 1 页,每页 10 条记录,总条数显示当前数据库设备类别总数 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-013:切换每页条数
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 在分页组件的「每页显示」下拉中切换为 20、50、100 2. 观察表格变化 |
|
||||
| **预期结果** | 表格按新条数加载数据,分页组件正确显示总页数 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-014:翻页功能
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 准备至少 25 条测试数据 2. 点击「下一页」「上一页」「首页」「末页」按钮 3. 输入页码跳转 |
|
||||
| **预期结果** | 表格按页加载数据,翻页流畅无报错 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.4 新增设备类别
|
||||
|
||||
#### TC-EC-015:打开新增弹框
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 点击表格上方「新增」按钮 |
|
||||
| **预期结果** | 弹出新增设备类别对话框,标题显示"新增设备类别",包含设备类别编码、设备类别名称、备注三个表单项;「确定」「取消」按钮位于底部 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-016:新增表单必填校验
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 不填写任何内容直接点击「确定」 |
|
||||
| **预期结果** | 设备类别编码、设备类别名称输入框下方显示红色校验提示"请输入设备类别编码"、"请输入设备类别名称" |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-017:新增成功 - 正常数据
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 输入编码 `EQ_CAT_TEST_001` 3. 输入名称「测试设备类别001」 4. 输入备注「测试用」 5. 点击「确定」 |
|
||||
| **预期结果** | 弹框关闭,页面右上角显示绿色成功提示"操作成功";表格自动刷新并显示新增的设备类别行 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-018:新增成功 - 仅必填
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 仅填写编码和名称,备注留空 3. 点击「确定」 |
|
||||
| **预期结果** | 新增成功,备注字段允许为空 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-019:新增 - 编码长度校验
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 在编码输入框输入超过 100 个字符 3. 失焦后观察 |
|
||||
| **预期结果** | 输入框下方显示校验提示"长度在 1 到 100 个字符" |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-020:新增 - 编码重复
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 输入已存在的设备类别编码 3. 点击「确定」 |
|
||||
| **预期结果** | 提示后端返回的"编码已存在"等错误信息,新增失败 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-021:取消新增
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 填写部分内容 3. 点击「取消」按钮 |
|
||||
| **预期结果** | 弹框关闭,表格数据无变化,无任何提示 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-022:新增 - 备注多行输入
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 在备注框中输入多行文字(超过 2 行) 3. 观察文本框是否自动扩展 |
|
||||
| **预期结果** | 备注为 textarea 类型,输入多行内容后自动扩展(最少 2 行,最多 6 行) |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.5 编辑设备类别
|
||||
|
||||
#### TC-EC-023:打开编辑弹框
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 点击某一设备类别行操作列的「编辑」按钮 |
|
||||
| **预期结果** | 弹出编辑设备类别对话框,标题显示"编辑设备类别",设备类别编码、设备类别名称、备注三个字段正确回填该行的数据 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-024:编辑成功
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开编辑弹框 2. 修改设备类别名称为"测试设备类别001-改" 3. 点击「确定」 |
|
||||
| **预期结果** | 弹框关闭,提示"操作成功",表格对应行的名称列更新为新值 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-025:编辑后清空必填项
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开编辑弹框 2. 清空设备类别名称输入框 3. 点击「确定」 |
|
||||
| **预期结果** | 设备类别名称下方显示红色校验提示,无法提交 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-026:取消编辑
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开编辑弹框 2. 修改部分字段 3. 点击「取消」按钮 |
|
||||
| **预期结果** | 弹框关闭,表格数据不变 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.6 删除设备类别
|
||||
|
||||
#### TC-EC-027:删除确认弹框
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 点击某一设备类别行操作列的「删除」按钮 |
|
||||
| **预期结果** | 弹出 Element UI 确认提示框,内容为"确定要删除该设备类别吗?",包含「确定」和「取消」按钮,图标为警告三角 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-028:删除成功
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 点击「删除」按钮 2. 在确认框中点击「确定」 |
|
||||
| **预期结果** | 确认框关闭,提示"操作成功",该设备类别从列表中消失,分页总数减 1 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-029:取消删除
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 点击「删除」按钮 2. 在确认框中点击「取消」 |
|
||||
| **预期结果** | 确认框关闭,设备类别数据不变 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-030:删除最后一页最后一条
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 翻到最后一页且只剩 1 条数据 2. 删除该数据 3. 观察分页跳转 |
|
||||
| **预期结果** | 删除成功后自动跳转到新的最后一页,无空白页 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.7 权限控制
|
||||
|
||||
#### TC-EC-031:无新增权限 - 按钮隐藏
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 登录无新增权限(`/device_management/equipment_model/equipment_category/create`)的账号 2. 进入设备类别页面 |
|
||||
| **预期结果** | 工具栏「新增」按钮不显示 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-032:无编辑权限 - 按钮隐藏
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 登录无编辑权限(`/device_management/equipment_model/equipment_category/edit`)的账号 2. 进入设备类别页面 |
|
||||
| **预期结果** | 行操作列「编辑」按钮不显示 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-033:无删除权限 - 按钮隐藏
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 登录无删除权限(`/device_management/equipment_model/equipment_category/delete`)的账号 2. 进入设备类别页面 |
|
||||
| **预期结果** | 行操作列「删除」按钮不显示 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-034:完全无权限 - 仅可查看
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 登录仅有查看权限的账号 2. 进入设备类别页面 |
|
||||
| **预期结果** | 表格正常加载数据;工具栏无「新增」按钮;行操作列无「编辑」「删除」按钮 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.8 国际化(i18n)
|
||||
|
||||
#### TC-EC-035:简体中文 - 页面显示
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 切换系统语言为简体中文 2. 进入设备类别页面 |
|
||||
| **预期结果** | 所有列头、按钮、表单标签、提示信息均显示中文("设备类别编码"、"设备类别名称"、"备注"、"操作"、"新增"、"编辑"、"删除"等) |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-036:英文 - 页面显示
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 切换系统语言为 English 2. 进入设备类别页面 |
|
||||
| **预期结果** | 所有列头、按钮、表单标签、提示信息均显示英文("Equipment Category Code"、"Equipment Category Name"、"Remark"、"Actions"、"Add"、"Edit"、"Delete"等) |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-037:英文 - 弹框显示
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 切换到英文 2. 点击「新增」按钮 |
|
||||
| **预期结果** | 弹框标题显示"Add Equipment Category",表单标签显示"Equipment Category Code"、"Equipment Category Name"、"Remark";底部按钮显示"Confirm"、"Cancel" |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-038:英文 - 删除确认
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 切换到英文 2. 点击某行的「Delete」按钮 |
|
||||
| **预期结果** | 确认框内容显示"Are you sure to delete this equipment category?",按钮显示"Confirm"、"Cancel" |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-039:语言切换实时响应
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 在中文下打开新增弹框 2. 不关闭弹框,直接切换系统语言到英文 |
|
||||
| **预期结果** | 弹框内所有文字立即切换为英文,无需刷新页面 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.9 异常与边界场景
|
||||
|
||||
#### TC-EC-040:网络异常 - 列表加载失败
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 停止后端服务 2. 刷新设备类别页面 |
|
||||
| **预期结果** | 页面显示 loading 结束后,弹出错误提示(如"请求失败"或"数据请求异常"),表格显示空数据 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-041:网络异常 - 新增失败
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 停止后端服务 3. 填写表单并点击「确定」 |
|
||||
| **预期结果** | 提示网络错误信息,弹框不关闭,确定按钮恢复可点击 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-042:特殊字符输入
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 在设备类别名称中输入特殊字符(如 `!@#$%^&*()_+-=[]{}|;':",./<>?`) 3. 点击「确定」 |
|
||||
| **预期结果** | 后端允许特殊字符时新增成功;不允许时显示后端错误提示 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-043:超长备注输入
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 在备注中输入超过 500 字符的文本 3. 点击「确定」 |
|
||||
| **预期结果** | textarea 自动扩展(最多 6 行出现滚动条),新增/编辑成功 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-044:备注包含换行符
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增/编辑弹框 2. 在备注中输入多行文字(含回车换行) 3. 提交后再次编辑查看 |
|
||||
| **预期结果** | 备注正确保存换行符,再次打开编辑时能正确显示多行内容 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-045:浏览器刷新页面
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 在搜索栏输入条件后查询 2. 按 F5 或点击浏览器刷新按钮 |
|
||||
| **预期结果** | 页面重新加载,搜索条件清空,表格显示全部数据 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.10 UI 与交互细节
|
||||
|
||||
#### TC-EC-047:搜索区 - 标签文本正确
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 查看搜索区的标签(label) |
|
||||
| **预期结果** | 显示"设备类别编码"、"设备类别名称";输入框 placeholder 显示"请输入设备类别编码"、"请输入设备类别名称" |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-048:搜索区 - 按钮图标正确
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 查看搜索区的按钮 |
|
||||
| **预期结果** | 「查询」按钮为蓝色 primary 样式,左侧带放大镜图标;「重置」按钮为默认样式,左侧带刷新图标 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-049:操作列 - 按钮样式
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 查看行操作列 |
|
||||
| **预期结果** | 「编辑」按钮为蓝色文字带编辑图标;「删除」按钮为红色文字带删除图标;按钮间有一定间距;操作列固定在右侧 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-050:弹框 - 表单交互
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 观察表单布局 |
|
||||
| **预期结果** | 表单 label 宽度 110px;输入框占 90% 宽度;备注为 textarea,可自适应高度(2-6 行);所有表单项垂直排列;弹框宽度为 35% |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-051:弹框 - 确定按钮 loading
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开新增弹框 2. 填写表单 3. 在网络较慢情况下点击「确定」 |
|
||||
| **预期结果** | 「确定」按钮显示 loading 状态,无法重复点击;接口返回后自动关闭弹框 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-052:空数据占位
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 清空设备类别表(或筛选不存在的条件) 2. 查看表格 |
|
||||
| **预期结果** | 表格区域显示 Element UI 默认的空数据占位("暂无数据" 或类似提示) |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### 3.11 数据一致性
|
||||
|
||||
#### TC-EC-053:新增后分页正确
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 在有 10 条数据时(每页 10 条) 2. 新增 1 条数据 |
|
||||
| **预期结果** | 新增后分页总数变为 11,自动跳转到第 1 页并显示新数据 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-054:编辑后数据刷新
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 编辑某行数据并保存 2. 重新搜索该数据 |
|
||||
| **预期结果** | 搜索结果显示编辑后的最新数据 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
#### TC-EC-055:删除后数据不残留
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 删除某条数据 2. 重新搜索该编码或刷新页面 |
|
||||
| **预期结果** | 搜索结果显示无此数据 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
---
|
||||
|
||||
## 四、兼容性测试
|
||||
|
||||
### TC-EC-056:Chrome 浏览器
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 使用 Chrome 最新版执行 TC-EC-001 ~ TC-EC-055 全部用例 |
|
||||
| **预期结果** | 全部通过 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### TC-EC-057:Edge 浏览器
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 使用 Edge 最新版执行核心用例 TC-EC-001/015/023/027/035/036 |
|
||||
| **预期结果** | 全部通过 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### TC-EC-058:不同分辨率适配
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 切换浏览器窗口分辨率为 1920×1080、1366×768 2. 验证页面布局 |
|
||||
| **预期结果** | 表格、分页、弹框等元素无错位,按钮可正常点击 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
---
|
||||
|
||||
## 五、回归测试
|
||||
|
||||
### TC-EC-059:菜单切换不卡顿
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 在「设备类别」页面停留 5 秒 2. 切换到「设备管理」其他子页面 3. 再切回「设备类别」 |
|
||||
| **预期结果** | 页面切换流畅,无报错,数据正确加载 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
### TC-EC-060:浏览器标签页切换
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试步骤** | 1. 打开「设备类别」页面 2. 切换到其他浏览器标签页 3. 30 秒后切回 |
|
||||
| **预期结果** | 页面数据无丢失,Token 未过期情况下正常显示 |
|
||||
| **实际结果** | |
|
||||
| **测试状态** | ⬜ 通过 / ⬜ 未通过 |
|
||||
| **问题描述** | |
|
||||
|
||||
---
|
||||
|
||||
## 六、测试通过标准
|
||||
|
||||
| 类别 | 描述 |
|
||||
|------|------|
|
||||
| ✅ 全部通过 | 全部测试用例均通过 |
|
||||
| ⚠️ 部分通过 | 个别非核心用例未通过,但不影响主要功能使用 |
|
||||
| ❌ 未通过 | 存在阻塞性缺陷(页面无法加载、核心 CRUD 失败、权限绕过等) |
|
||||
|
||||
---
|
||||
|
||||
## 七、问题记录汇总
|
||||
|
||||
| 问题编号 | 关联测试用例 | 问题描述 | 严重程度 | 处理状态 | 处理人 |
|
||||
|---------|------------|---------|---------|---------|-------|
|
||||
| | | | | | |
|
||||
| | | | | | |
|
||||
|
||||
---
|
||||
|
||||
## 八、测试结论
|
||||
|
||||
| 项目 | 内容 |
|
||||
|------|------|
|
||||
| **测试人员** | |
|
||||
| **测试日期** | |
|
||||
| **测试用例总数** | 60 |
|
||||
| **通过用例数** | |
|
||||
| **未通过用例数** | |
|
||||
| **遗留问题数** | |
|
||||
| **整体结论** | ⬜ 通过 ⬜ 有条件通过 ⬜ 未通过 |
|
||||
| **备注说明** | |
|
||||
|
||||
---
|
||||
|
||||
> **文档维护说明**:本测试文档为设备类别功能独立测试文档。后续该功能代码变更(Bug 修复、新增功能、需求变更)时,需同步更新本测试文档并重新执行相关测试用例。
|
||||
11
docs/功能测试-设备维修日志.md
Normal file
11
docs/功能测试-设备维修日志.md
Normal file
@@ -0,0 +1,11 @@
|
||||
# 设备维修日志功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备维修 / 设备维修日志`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
11
docs/功能测试-设备维修管理.md
Normal file
11
docs/功能测试-设备维修管理.md
Normal file
@@ -0,0 +1,11 @@
|
||||
# 设备维修管理功能测试任务列表
|
||||
|
||||
- [ ] 进入 `设备模型 / 设备维修 / 设备维修管理`,页面正常加载,无控制台报错。
|
||||
- [ ] 点击查询,列表按分页加载数据,表格字段显示完整。
|
||||
- [ ] 输入关键字后点击查询,列表按条件刷新。
|
||||
- [ ] 点击重置,查询条件清空并重新加载列表。
|
||||
- [ ] 点击新增,填写表单并保存,保存成功后列表刷新。
|
||||
- [ ] 点击编辑,表单带出当前行数据,修改后保存成功。
|
||||
- [ ] 点击删除,确认后记录删除并刷新列表。
|
||||
- [ ] 点击导出,系统可创建导出任务或返回成功提示。
|
||||
- [ ] 分页切换页码和每页条数时,列表数据刷新正常。
|
||||
36
docs/功能测试-鹰眼.md
Normal file
36
docs/功能测试-鹰眼.md
Normal file
@@ -0,0 +1,36 @@
|
||||
# 鹰眼功能测试任务列表
|
||||
|
||||
## 基础入口
|
||||
|
||||
- [ ] 进入 `数据中台 / 相关性分析 / 鹰眼`,页面正常加载,无控制台报错。
|
||||
- [ ] 左侧分析条件区域显示生产批次、工序、NG 码三个筛选项和分析按钮。
|
||||
- [ ] 页面右侧显示分析详情区域,未查询时为空状态。
|
||||
|
||||
## 查询条件
|
||||
|
||||
- [ ] 选择生产批次后,工序下拉框自动加载该批次下的不良工序列。
|
||||
- [ ] 选择工序后,NG 码下拉框自动切换为该工序对应的不良代码。
|
||||
- [ ] 点击重置后,批次、工序、NG 码、相关性结果和图表全部清空。
|
||||
|
||||
## 相关性分析
|
||||
|
||||
- [ ] 未选择生产批次时点击分析,系统提示需要选择批次。
|
||||
- [ ] 未选择工序时点击分析,系统提示需要选择工序。
|
||||
- [ ] 选择有效批次、工序和 NG 码后点击分析,Pearson 相关性散点图正常渲染。
|
||||
- [ ] PCC 表格显示工序参数、样本量、相关系数、P 值和相关性判断。
|
||||
- [ ] 卡方表格显示工序参数、样本量、卡方值、P 值和相关性判断。
|
||||
- [ ] 有不能参与分析的数据列时,顶部折叠区域展示对应参数名称。
|
||||
|
||||
## 图表与交互
|
||||
|
||||
- [ ] 散点图鼠标悬停时显示参数名称、相关系数和 P 值。
|
||||
- [ ] P 值大于 0.05 的记录以蓝色相关状态显示。
|
||||
- [ ] P 值小于或等于 0.05 的记录以红色不相关状态显示。
|
||||
- [ ] 已选择 NG 码时点击表格中的相关性文字,弹出分析报告弹窗。
|
||||
- [ ] 分析报告弹窗内按分类展示折线分布图,关闭后再次打开能正常刷新。
|
||||
|
||||
## 兼容性
|
||||
|
||||
- [ ] 页面在 1366px 宽度下表格和图表不重叠。
|
||||
- [ ] 浏览器窗口缩放后图表能自动适配。
|
||||
- [ ] 切换不同批次再次分析,旧批次结果不会残留。
|
||||
140
docs/功能测试流程-工艺流程.md
Normal file
140
docs/功能测试流程-工艺流程.md
Normal 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 | | | | | | | | |
|
||||
|
||||
---
|
||||
|
||||
## 六、测试结论
|
||||
|
||||
| 项目 | 结论 |
|
||||
| --- | --- |
|
||||
| 功能完整性 | ☐ 满足 ☐ 部分缺失 ☐ 不满足 |
|
||||
| 权限控制 | ☐ 正确 ☐ 存在漏洞 |
|
||||
| 国际化 | ☐ 完整 ☐ 部分缺失 ☐ 缺失 |
|
||||
| 是否可发布 | ☐ 是 ☐ 否(请说明阻塞问题) |
|
||||
|
||||
测试人员签字:__________________ 日期:__________
|
||||
210
docs/功能测试流程-异常不良管理.md
Normal file
210
docs/功能测试流程-异常不良管理.md
Normal 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 行导入数据)和一份缺少列的非法文件 |
|
||||
| 浏览器工具 | 打开 DevTools(F12)→ 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 | | | | | | | |
|
||||
|
||||
---
|
||||
|
||||
## 六、测试结论
|
||||
|
||||
| 项目 | 结论 |
|
||||
| --- | --- |
|
||||
| 功能完整性 | ☐ 满足 ☐ 部分缺失 ☐ 不满足 |
|
||||
| 性能表现 | ☐ 良好 ☐ 一般 ☐ 差 |
|
||||
| 权限控制 | ☐ 正确 ☐ 存在漏洞 |
|
||||
| 国际化 | ☐ 完整 ☐ 部分缺失 ☐ 缺失 |
|
||||
| 导入导出 | ☐ 正常 ☐ 部分异常 ☐ 不可用 |
|
||||
| 是否可发布 | ☐ 是 ☐ 否(请说明阻塞问题) |
|
||||
|
||||
测试人员签字:__________________ 日期:__________
|
||||
|
||||
---
|
||||
*本测试流程文档为【异常不良管理】功能迁移版本专用,请独立归档保存。*
|
||||
79
docs/工艺流程迁移分析方案.md
Normal file
79
docs/工艺流程迁移分析方案.md
Normal 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 导入按旧模板中文列名“温度 / 温度补偿值”解析,需要测试真实模板兼容性。
|
||||
580
docs/测试文档-工艺流程.md
Normal file
580
docs/测试文档-工艺流程.md
Normal 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-09:i18n 中文切换
|
||||
- **操作步骤**
|
||||
1. 在用户设置中切换语言到「简体中文」
|
||||
2. 访问工艺流程页面
|
||||
- **预期结果**
|
||||
- 所有表头、按钮、提示文本为中文("工艺流程编码"、"新增"、"删除"等)
|
||||
- **实际结果**:__________
|
||||
- **测试状态**:☐ 通过 ☐ 失败
|
||||
- **问题描述**:__________
|
||||
|
||||
#### T-10:i18n 英文切换
|
||||
- **操作步骤**
|
||||
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 | 否 | 备注 |
|
||||
245
docs/质量管理功能测试任务列表.md
Normal file
245
docs/质量管理功能测试任务列表.md
Normal 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 项目,确认折线图区域和明细表同步展示,并且无样本时页面不报错。
|
||||
|
||||
94
docs/迁移任务列表.md
Normal file
94
docs/迁移任务列表.md
Normal 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 页面目录。
|
||||
@@ -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
25
docs/运行提示词.md
Normal 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>
|
||||
22
package.json
22
package.json
@@ -1,10 +1,15 @@
|
||||
{
|
||||
"name": "d2-admin",
|
||||
"version": "1.25.0",
|
||||
"packageManager": "pnpm@10.33.0",
|
||||
"engines": {
|
||||
"node": ">=18.16.0 <19",
|
||||
"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",
|
||||
@@ -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",
|
||||
@@ -88,5 +96,13 @@
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "https://github.com/d2-projects/d2-admin.git"
|
||||
},
|
||||
"volta": {
|
||||
"node": "18.16.0"
|
||||
},
|
||||
"pnpm": {
|
||||
"overrides": {
|
||||
"@achrinza/node-ipc": ">=9.2.7"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
131
pnpm-lock.yaml
generated
131
pnpm-lock.yaml
generated
@@ -4,6 +4,9 @@ settings:
|
||||
autoInstallPeers: true
|
||||
excludeLinksFromLockfile: false
|
||||
|
||||
overrides:
|
||||
'@achrinza/node-ipc': '>=9.2.7'
|
||||
|
||||
importers:
|
||||
|
||||
.:
|
||||
@@ -35,6 +38,9 @@ importers:
|
||||
dayjs:
|
||||
specifier: ^1.11.5
|
||||
version: 1.11.21
|
||||
echarts:
|
||||
specifier: 5.1.0
|
||||
version: 5.1.0
|
||||
element-ui:
|
||||
specifier: ^2.15.9
|
||||
version: 2.15.14(vue@2.7.16)
|
||||
@@ -80,6 +86,9 @@ importers:
|
||||
quill:
|
||||
specifier: ^1.3.7
|
||||
version: 1.3.7
|
||||
relation-graph:
|
||||
specifier: 2.2.11
|
||||
version: 2.2.11
|
||||
screenfull:
|
||||
specifier: ^5.2.0
|
||||
version: 5.2.0
|
||||
@@ -116,6 +125,9 @@ importers:
|
||||
vuex:
|
||||
specifier: ^3.6.2
|
||||
version: 3.6.2(vue@2.7.16)
|
||||
xlsx:
|
||||
specifier: ^0.18.5
|
||||
version: 0.18.5
|
||||
devDependencies:
|
||||
'@d2-projects/vue-filename-injector':
|
||||
specifier: ^1.1.1
|
||||
@@ -210,9 +222,9 @@ importers:
|
||||
|
||||
packages:
|
||||
|
||||
'@achrinza/node-ipc@9.2.2':
|
||||
resolution: {integrity: sha512-b90U39dx0cU6emsOvy5hxU4ApNXnE3+Tuo8XQZfiKTGelDwpMwBVgBP7QX6dGTcJgu/miyJuNJ/2naFBliNWEw==}
|
||||
engines: {node: 8 || 10 || 12 || 14 || 16 || 17}
|
||||
'@achrinza/node-ipc@9.2.10':
|
||||
resolution: {integrity: sha512-rCkw57K82y1XA9KwBmuMrupFQr9VOS4Rn77vW2UD2j0+HjlP/npSON9COkUIfocd95B4wv5EpfWMr6lGD4lN3A==}
|
||||
engines: {node: 8 || 9 || 10 || 11 || 12 || 13 || 14 || 15 || 16 || 17 || 18 || 19 || 20 || 21 || 22 || 23 || 24 || 25}
|
||||
|
||||
'@babel/code-frame@7.29.7':
|
||||
resolution: {integrity: sha512-Aup7aUOfpbAUg2ROOJN6Iw5f9DMBlzu0mIkm/malLQFN/YQgO48wCj0Kxa3sEHJvPVFg7siR+qRInwXd2qhQKw==}
|
||||
@@ -1861,6 +1873,10 @@ packages:
|
||||
resolution: {integrity: sha512-BLrgEcRTwX2o6gGxGOCNyMvGSp35YofuYzw9h1IMTRmKqttAZZVU67bdb9Pr2vUHA8+j3i2tJfjO6C6+4myGTA==}
|
||||
engines: {node: 18 || 20 || >=22}
|
||||
|
||||
base64-arraybuffer@1.0.2:
|
||||
resolution: {integrity: sha512-I3yl4r9QB5ZRY3XuJVEPfc2XhZO6YweFPI+UovAzn+8/hb3oJ6lnysaFcjVpkCPfVWFUDvoZ8kmVDP7WyRtYtQ==}
|
||||
engines: {node: '>= 0.6.0'}
|
||||
|
||||
base64-js@1.5.1:
|
||||
resolution: {integrity: sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==}
|
||||
|
||||
@@ -2220,6 +2236,10 @@ packages:
|
||||
engines: {node: '>=0.8'}
|
||||
hasBin: true
|
||||
|
||||
codepage@1.15.0:
|
||||
resolution: {integrity: sha512-3g6NUTPd/YtuuGrhMnOMRjFc+LJw/bnMp3+0r/Wcz3IXUuCosKRJvMphm5+Q+bvTVGcJJuRvVLuYba+WojaFaA==}
|
||||
engines: {node: '>=0.8'}
|
||||
|
||||
collection-visit@1.0.0:
|
||||
resolution: {integrity: sha512-lNkKvzEeMBBjUGHZ+q6z9pSJla0KWAQPvtzhEV9+iGyQYG+pBpl7xKDhxoNSOZH2hhv0v5k0y2yAM4o4SjoSkw==}
|
||||
engines: {node: '>=0.10.0'}
|
||||
@@ -2604,6 +2624,9 @@ packages:
|
||||
resolution: {integrity: sha512-BcxQSKTSEEQUftYpBVnsH4SF05NTuBokb19/sBt6asXGKZ/6VP7PLG1CBCkFDYOnhXhPh0jMhO6xZ71oYHXHBA==}
|
||||
engines: {node: '>4'}
|
||||
|
||||
css-line-break@2.1.0:
|
||||
resolution: {integrity: sha512-FHcKFCZcAha3LwfVBhCQbW2nCNbkZXn7KVUJcsT5/P8YmfsVja0FMPJr0B903j/E69HUphKiV9iQArX8SDYA4w==}
|
||||
|
||||
css-loader@3.6.0:
|
||||
resolution: {integrity: sha512-M5lSukoWi1If8dhQAUCvj4H8vUt3vOnwbQBH9DdTm/s4Ym2B/3dPMtYZeJmq7Q3S3Pa+I94DcZ7pc9bP14cWIQ==}
|
||||
engines: {node: '>= 8.9.0'}
|
||||
@@ -2960,6 +2983,9 @@ packages:
|
||||
ecc-jsbn@0.1.2:
|
||||
resolution: {integrity: sha512-eh9O+hwRHNbG4BLTjEl3nw044CkGm5X6LoaCf7LPp7UU8Qrt47JYNi6nPX8xjW97TKGKm1ouctg0QSpZe9qrnw==}
|
||||
|
||||
echarts@5.1.0:
|
||||
resolution: {integrity: sha512-/X2nnN5BXW2tuA/Hv9YY279rDfwcXaBAjK9Azi//llshbKyUXXxBknsug21GJRpwTmLZbE8rjjbhchdm01bZtw==}
|
||||
|
||||
editorconfig@1.0.7:
|
||||
resolution: {integrity: sha512-e0GOtq/aTQhVdNyDU9e02+wz9oDDM+SIOQxWME2QRjzRX5yyLAuHDE+0aE8vHb9XRC8XD37eO2u57+F09JqFhw==}
|
||||
engines: {node: '>=14'}
|
||||
@@ -3818,6 +3844,10 @@ packages:
|
||||
peerDependencies:
|
||||
webpack: ^1.0.0 || ^2.0.0 || ^3.0.0 || ^4.0.0
|
||||
|
||||
html2canvas@1.4.1:
|
||||
resolution: {integrity: sha512-fPU6BHNpsyIhr8yyMpTLLxAbkaK8ArIBcmZIRiBLiDhjeqvXolaEmDGmELFuX9I4xDcaKKcJl+TKZLqruBbmWA==}
|
||||
engines: {node: '>=8.0.0'}
|
||||
|
||||
htmlparser2@3.10.1:
|
||||
resolution: {integrity: sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ==}
|
||||
|
||||
@@ -5783,6 +5813,9 @@ packages:
|
||||
resolution: {integrity: sha512-G08Dxvm4iDN3MLM0EsP62EDV9IuhXPR6blNz6Utcp7zyV3tr4HVNINt6MpaRWbxoOHT3Q7YN2P+jaHX8vUbgog==}
|
||||
engines: {node: '>= 0.10'}
|
||||
|
||||
relation-graph@2.2.11:
|
||||
resolution: {integrity: sha512-k8jrZkkNYMIKqGN0g8ZHhqd0sP9RAvem6xw9UN9FD59TiVlKx1Vsvi7E/Kh9Z1tZGltdrPo0ZERsUn6Ydoc0Sw==}
|
||||
|
||||
remove-trailing-separator@1.1.0:
|
||||
resolution: {integrity: sha512-/hS+Y0u3aOfIETiaiirUFwDBDzmXPvO+jAfKTitUngIPzdKc6Z0LoFjM/CK5PL4C+eKwHohlHAb6H0VFfmmUsw==}
|
||||
|
||||
@@ -6228,6 +6261,10 @@ packages:
|
||||
engines: {node: '>=0.8'}
|
||||
hasBin: true
|
||||
|
||||
ssf@0.11.2:
|
||||
resolution: {integrity: sha512-+idbmIXoYET47hH+d7dfm2epdOMUDjqcB4648sTZ+t2JwoyBFL/insLfB/racrDmsKB3diwsDA696pZMieAC5g==}
|
||||
engines: {node: '>=0.8'}
|
||||
|
||||
sshpk@1.18.0:
|
||||
resolution: {integrity: sha512-2p2KJZTSqQ/I3+HX42EpYOa2l3f8Erv8MWKsy2I9uf4wA7yFIkXRffYdsx86y6z4vHtV8u7g+pPlr8/4ouAxsQ==}
|
||||
engines: {node: '>=0.10.0'}
|
||||
@@ -6464,6 +6501,9 @@ packages:
|
||||
text-loader@0.0.1:
|
||||
resolution: {integrity: sha512-y2GvBFB9hibaHBRWE9xQhdENU1KppXnM9DCf6NueYPB/lnNX8ZzP3JLs1R1p3ObItcs+y8DBiPwelkJf8txe+g==}
|
||||
|
||||
text-segmentation@1.0.3:
|
||||
resolution: {integrity: sha512-iOiPUo/BGnZ6+54OsWxZidGCsdU8YbE4PSpdPinp7DeMtUJNJBoJ/ouUSTJjHkh1KntHaltHl/gDs2FC4i5+Nw==}
|
||||
|
||||
text-table@0.2.0:
|
||||
resolution: {integrity: sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==}
|
||||
|
||||
@@ -6587,6 +6627,9 @@ packages:
|
||||
tslib@1.14.1:
|
||||
resolution: {integrity: sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==}
|
||||
|
||||
tslib@2.0.3:
|
||||
resolution: {integrity: sha512-uZtkfKblCEQtZKBF6EBXVZeQNl82yqtDQdv+eck8u7tdPxjLu2/lp5/uPW+um2tpuxINHWy3GhiccY7QgEaVHQ==}
|
||||
|
||||
tslib@2.8.1:
|
||||
resolution: {integrity: sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==}
|
||||
|
||||
@@ -6788,6 +6831,9 @@ packages:
|
||||
resolution: {integrity: sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==}
|
||||
engines: {node: '>= 0.4.0'}
|
||||
|
||||
utrie@1.0.2:
|
||||
resolution: {integrity: sha512-1MLa5ouZiOmQzUbjbu9VmjLzn1QLXBhwpUa7kdLUQK+KQ5KA9I1vk5U4YHe/X2Ch7PYnJfWuWT+VbuxbGwljhw==}
|
||||
|
||||
uuid@3.4.0:
|
||||
resolution: {integrity: sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==}
|
||||
deprecated: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.
|
||||
@@ -7046,10 +7092,18 @@ packages:
|
||||
engines: {node: '>= 8'}
|
||||
hasBin: true
|
||||
|
||||
wmf@1.0.2:
|
||||
resolution: {integrity: sha512-/p9K7bEh0Dj6WbXg4JG0xvLQmIadrner1bi45VMJTfnbVHsc7yIajZyoSoK60/dtVBs12Fm6WkUI5/3WAVsNMw==}
|
||||
engines: {node: '>=0.8'}
|
||||
|
||||
word-wrap@1.2.5:
|
||||
resolution: {integrity: sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==}
|
||||
engines: {node: '>=0.10.0'}
|
||||
|
||||
word@0.3.0:
|
||||
resolution: {integrity: sha512-OELeY0Q61OXpdUfTp+oweA/vtLVg5VDOXh+3he3PNzLGG/y0oylSOC1xRVj0+l4vQ3tj/bB1HVHv1ocXkQceFA==}
|
||||
engines: {node: '>=0.8'}
|
||||
|
||||
worker-farm@1.7.0:
|
||||
resolution: {integrity: sha512-rvw3QTZc8lAxyVrqcSGVm5yP/IJ2UcB3U0graE3LCFoZ0Yn2x4EoVSqJKdB/T5M+FLcRPjz4TDacRf3OCfNUzw==}
|
||||
|
||||
@@ -7118,6 +7172,11 @@ packages:
|
||||
engines: {node: '>=0.8'}
|
||||
hasBin: true
|
||||
|
||||
xlsx@0.18.5:
|
||||
resolution: {integrity: sha512-dmg3LCjBPHZnQp5/F/+nnTa+miPJxUXB6vtk42YjBBKayDNagxGEeIdWApkYPOf3Z3pm3k62Knjzp7lMeTEtFQ==}
|
||||
engines: {node: '>=0.8'}
|
||||
hasBin: true
|
||||
|
||||
xml-name-validator@3.0.0:
|
||||
resolution: {integrity: sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==}
|
||||
|
||||
@@ -7170,9 +7229,12 @@ packages:
|
||||
resolution: {integrity: sha512-jcKpkthap6x63MB4TxwCyuIGkV0oYP/YRyuQU5UO0Yz/E/ZAu+653/uov+phdmO54n6BcvFRyyt0RRrWdN2mpw==}
|
||||
engines: {node: '>=4'}
|
||||
|
||||
zrender@5.1.0:
|
||||
resolution: {integrity: sha512-c+8VRx52ycbmqwHeHLlo/BAfIHBl/JZNLM6cfDQFgzIH05yb+f5J9F/fbRsP+zGc8dW9XHuhdt8/iqukgMZSeg==}
|
||||
|
||||
snapshots:
|
||||
|
||||
'@achrinza/node-ipc@9.2.2':
|
||||
'@achrinza/node-ipc@9.2.10':
|
||||
dependencies:
|
||||
'@node-ipc/js-queue': 2.0.3
|
||||
event-pubsub: 4.3.0
|
||||
@@ -8180,9 +8242,7 @@ snapshots:
|
||||
source-map: 0.6.1
|
||||
string-length: 2.0.0
|
||||
transitivePeerDependencies:
|
||||
- bufferutil
|
||||
- supports-color
|
||||
- utf-8-validate
|
||||
|
||||
'@jest/source-map@24.9.0':
|
||||
dependencies:
|
||||
@@ -8826,7 +8886,7 @@ snapshots:
|
||||
|
||||
'@vue/cli-shared-utils@4.5.19':
|
||||
dependencies:
|
||||
'@achrinza/node-ipc': 9.2.2
|
||||
'@achrinza/node-ipc': 9.2.10
|
||||
'@hapi/joi': 15.1.1
|
||||
chalk: 2.4.2
|
||||
execa: 1.0.0
|
||||
@@ -9519,6 +9579,8 @@ snapshots:
|
||||
|
||||
balanced-match@4.0.4: {}
|
||||
|
||||
base64-arraybuffer@1.0.2: {}
|
||||
|
||||
base64-js@1.5.1: {}
|
||||
|
||||
base@0.11.2:
|
||||
@@ -10016,6 +10078,8 @@ snapshots:
|
||||
commander: 2.14.1
|
||||
exit-on-epipe: 1.0.1
|
||||
|
||||
codepage@1.15.0: {}
|
||||
|
||||
collection-visit@1.0.0:
|
||||
dependencies:
|
||||
map-visit: 1.0.0
|
||||
@@ -10303,6 +10367,10 @@ snapshots:
|
||||
postcss: 7.0.39
|
||||
timsort: 0.3.0
|
||||
|
||||
css-line-break@2.1.0:
|
||||
dependencies:
|
||||
utrie: 1.0.2
|
||||
|
||||
css-loader@3.6.0(webpack@4.47.0):
|
||||
dependencies:
|
||||
camelcase: 5.3.1
|
||||
@@ -10711,6 +10779,11 @@ snapshots:
|
||||
jsbn: 0.1.1
|
||||
safer-buffer: 2.1.2
|
||||
|
||||
echarts@5.1.0:
|
||||
dependencies:
|
||||
tslib: 2.0.3
|
||||
zrender: 5.1.0
|
||||
|
||||
editorconfig@1.0.7:
|
||||
dependencies:
|
||||
'@one-ini/wasm': 0.1.1
|
||||
@@ -11790,6 +11863,11 @@ snapshots:
|
||||
util.promisify: 1.0.0
|
||||
webpack: 4.47.0
|
||||
|
||||
html2canvas@1.4.1:
|
||||
dependencies:
|
||||
css-line-break: 2.1.0
|
||||
text-segmentation: 1.0.3
|
||||
|
||||
htmlparser2@3.10.1:
|
||||
dependencies:
|
||||
domelementtype: 1.3.1
|
||||
@@ -12437,9 +12515,7 @@ snapshots:
|
||||
pretty-format: 24.9.0
|
||||
throat: 4.1.0
|
||||
transitivePeerDependencies:
|
||||
- bufferutil
|
||||
- supports-color
|
||||
- utf-8-validate
|
||||
|
||||
jest-leak-detector@24.9.0:
|
||||
dependencies:
|
||||
@@ -14167,6 +14243,11 @@ snapshots:
|
||||
|
||||
relateurl@0.2.7: {}
|
||||
|
||||
relation-graph@2.2.11:
|
||||
dependencies:
|
||||
html2canvas: 1.4.1
|
||||
screenfull: 5.2.0
|
||||
|
||||
remove-trailing-separator@1.1.0: {}
|
||||
|
||||
renderkid@2.0.7:
|
||||
@@ -14683,6 +14764,10 @@ snapshots:
|
||||
dependencies:
|
||||
frac: 1.1.2
|
||||
|
||||
ssf@0.11.2:
|
||||
dependencies:
|
||||
frac: 1.1.2
|
||||
|
||||
sshpk@1.18.0:
|
||||
dependencies:
|
||||
asn1: 0.2.6
|
||||
@@ -14983,6 +15068,10 @@ snapshots:
|
||||
|
||||
text-loader@0.0.1: {}
|
||||
|
||||
text-segmentation@1.0.3:
|
||||
dependencies:
|
||||
utrie: 1.0.2
|
||||
|
||||
text-table@0.2.0: {}
|
||||
|
||||
thenify-all@1.6.0:
|
||||
@@ -15116,6 +15205,8 @@ snapshots:
|
||||
|
||||
tslib@1.14.1: {}
|
||||
|
||||
tslib@2.0.3: {}
|
||||
|
||||
tslib@2.8.1: {}
|
||||
|
||||
tty-browserify@0.0.0: {}
|
||||
@@ -15333,6 +15424,10 @@ snapshots:
|
||||
|
||||
utils-merge@1.0.1: {}
|
||||
|
||||
utrie@1.0.2:
|
||||
dependencies:
|
||||
base64-arraybuffer: 1.0.2
|
||||
|
||||
uuid@3.4.0: {}
|
||||
|
||||
uuid@8.3.2: {}
|
||||
@@ -15789,8 +15884,12 @@ snapshots:
|
||||
dependencies:
|
||||
isexe: 2.0.0
|
||||
|
||||
wmf@1.0.2: {}
|
||||
|
||||
word-wrap@1.2.5: {}
|
||||
|
||||
word@0.3.0: {}
|
||||
|
||||
worker-farm@1.7.0:
|
||||
dependencies:
|
||||
errno: 0.1.8
|
||||
@@ -15851,6 +15950,16 @@ snapshots:
|
||||
exit-on-epipe: 1.0.1
|
||||
ssf: 0.10.3
|
||||
|
||||
xlsx@0.18.5:
|
||||
dependencies:
|
||||
adler-32: 1.3.1
|
||||
cfb: 1.2.2
|
||||
codepage: 1.15.0
|
||||
crc-32: 1.2.2
|
||||
ssf: 0.11.2
|
||||
wmf: 1.0.2
|
||||
word: 0.3.0
|
||||
|
||||
xml-name-validator@3.0.0: {}
|
||||
|
||||
xmlchars@2.2.0: {}
|
||||
@@ -15912,3 +16021,7 @@ snapshots:
|
||||
is-ci: 1.2.1
|
||||
normalize-path: 1.0.0
|
||||
strip-indent: 2.0.0
|
||||
|
||||
zrender@5.1.0:
|
||||
dependencies:
|
||||
tslib: 2.0.3
|
||||
|
||||
43
src/api/data-platform/correlation-analysis/hawkeye.js
Normal file
43
src/api/data-platform/correlation-analysis/hawkeye.js
Normal 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)
|
||||
})
|
||||
}
|
||||
23
src/api/data-platform/production-reports/battery-detail.js
Normal file
23
src/api/data-platform/production-reports/battery-detail.js
Normal 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') })
|
||||
}
|
||||
@@ -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)
|
||||
})
|
||||
}
|
||||
27
src/api/data-platform/traceability/backward.js
Normal file
27
src/api/data-platform/traceability/backward.js
Normal 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)
|
||||
})
|
||||
}
|
||||
35
src/api/data-platform/traceability/battery-curve.js
Normal file
35
src/api/data-platform/traceability/battery-curve.js
Normal 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)
|
||||
})
|
||||
}
|
||||
31
src/api/data-platform/traceability/battery.js
Normal file
31
src/api/data-platform/traceability/battery.js
Normal 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)
|
||||
})
|
||||
}
|
||||
27
src/api/data-platform/traceability/forward.js
Normal file
27
src/api/data-platform/traceability/forward.js
Normal 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)
|
||||
})
|
||||
}
|
||||
31
src/api/data-platform/traceability/tray.js
Normal file
31
src/api/data-platform/traceability/tray.js
Normal 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)
|
||||
})
|
||||
}
|
||||
29
src/api/equipment-management/consumables-category.js
Normal file
29
src/api/equipment-management/consumables-category.js
Normal 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) })
|
||||
}
|
||||
29
src/api/equipment-management/consumables-items.js
Normal file
29
src/api/equipment-management/consumables-items.js
Normal 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) })
|
||||
}
|
||||
29
src/api/equipment-management/consumables-lifecycle.js
Normal file
29
src/api/equipment-management/consumables-lifecycle.js
Normal 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) })
|
||||
}
|
||||
51
src/api/equipment-management/equipment-category.js
Normal file
51
src/api/equipment-management/equipment-category.js
Normal file
@@ -0,0 +1,51 @@
|
||||
import { request } from '@/api/_service'
|
||||
|
||||
const BASE = 'production_configuration/device_model/device_category/'
|
||||
|
||||
function apiParams (method, data = {}) {
|
||||
return {
|
||||
method: `equipment_management_equipment_model_equipment_category_${method}`,
|
||||
platform: 'background',
|
||||
...data
|
||||
}
|
||||
}
|
||||
|
||||
export function getEquipmentCategoryList (data) {
|
||||
return request({
|
||||
url: BASE + 'list',
|
||||
method: 'get',
|
||||
params: apiParams('list', data)
|
||||
})
|
||||
}
|
||||
|
||||
export function getEquipmentCategoryALL (data) {
|
||||
return request({
|
||||
url: BASE + 'all',
|
||||
method: 'get',
|
||||
params: apiParams('all', data)
|
||||
})
|
||||
}
|
||||
|
||||
export function createEquipmentCategory (data) {
|
||||
return request({
|
||||
url: BASE + 'create',
|
||||
method: 'post',
|
||||
data: apiParams('create', data)
|
||||
})
|
||||
}
|
||||
|
||||
export function editEquipmentCategory (data) {
|
||||
return request({
|
||||
url: BASE + 'edit',
|
||||
method: 'put',
|
||||
data: apiParams('edit', data)
|
||||
})
|
||||
}
|
||||
|
||||
export function deleteEquipmentCategory (data) {
|
||||
return request({
|
||||
url: BASE + 'delete',
|
||||
method: 'delete',
|
||||
data: apiParams('delete', data)
|
||||
})
|
||||
}
|
||||
33
src/api/equipment-management/equipment-registry.js
Normal file
33
src/api/equipment-management/equipment-registry.js
Normal 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) })
|
||||
}
|
||||
29
src/api/equipment-management/inspection-items.js
Normal file
29
src/api/equipment-management/inspection-items.js
Normal 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) })
|
||||
}
|
||||
13
src/api/equipment-management/inspection-logs.js
Normal file
13
src/api/equipment-management/inspection-logs.js
Normal 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) })
|
||||
}
|
||||
17
src/api/equipment-management/inspection-records.js
Normal file
17
src/api/equipment-management/inspection-records.js
Normal 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) })
|
||||
}
|
||||
25
src/api/equipment-management/maintenance-details.js
Normal file
25
src/api/equipment-management/maintenance-details.js
Normal 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) })
|
||||
}
|
||||
29
src/api/equipment-management/maintenance-items.js
Normal file
29
src/api/equipment-management/maintenance-items.js
Normal 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) })
|
||||
}
|
||||
21
src/api/equipment-management/maintenance-logs.js
Normal file
21
src/api/equipment-management/maintenance-logs.js
Normal 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) })
|
||||
}
|
||||
29
src/api/equipment-management/repair-logs.js
Normal file
29
src/api/equipment-management/repair-logs.js
Normal 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) })
|
||||
}
|
||||
29
src/api/equipment-management/repair-management.js
Normal file
29
src/api/equipment-management/repair-management.js
Normal 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) })
|
||||
}
|
||||
29
src/api/equipment-management/replacement-logs.js
Normal file
29
src/api/equipment-management/replacement-logs.js
Normal 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) })
|
||||
}
|
||||
59
src/api/planning-production/alert-center.js
Normal file
59
src/api/planning-production/alert-center.js
Normal 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)
|
||||
})
|
||||
}
|
||||
27
src/api/planning-production/batch-defect-report.js
Normal file
27
src/api/planning-production/batch-defect-report.js
Normal 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)
|
||||
})
|
||||
}
|
||||
59
src/api/planning-production/batch-list.js
Normal file
59
src/api/planning-production/batch-list.js
Normal 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)
|
||||
})
|
||||
}
|
||||
43
src/api/planning-production/batch-tray.js
Normal file
43
src/api/planning-production/batch-tray.js
Normal 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)
|
||||
})
|
||||
}
|
||||
19
src/api/planning-production/equipment-monitoring.js
Normal file
19
src/api/planning-production/equipment-monitoring.js
Normal 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)
|
||||
})
|
||||
}
|
||||
27
src/api/planning-production/material-monitoring.js
Normal file
27
src/api/planning-production/material-monitoring.js
Normal 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)
|
||||
})
|
||||
}
|
||||
27
src/api/planning-production/process-execution.js
Normal file
27
src/api/planning-production/process-execution.js
Normal 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)
|
||||
})
|
||||
}
|
||||
19
src/api/planning-production/rework-management.js
Normal file
19
src/api/planning-production/rework-management.js
Normal 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)
|
||||
})
|
||||
}
|
||||
67
src/api/planning-production/tray-management.js
Normal file
67
src/api/planning-production/tray-management.js
Normal 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)
|
||||
})
|
||||
}
|
||||
51
src/api/planning-production/tray-registration.js
Normal file
51
src/api/planning-production/tray-registration.js
Normal 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)
|
||||
})
|
||||
}
|
||||
56
src/api/production-master-data/bill-of-materials.js
Normal file
56
src/api/production-master-data/bill-of-materials.js
Normal 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) })
|
||||
}
|
||||
51
src/api/production-master-data/calculation-script.js
Normal file
51
src/api/production-master-data/calculation-script.js
Normal 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)
|
||||
})
|
||||
}
|
||||
@@ -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)
|
||||
})
|
||||
}
|
||||
19
src/api/production-master-data/device-category.js
Normal file
19
src/api/production-master-data/device-category.js
Normal 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)
|
||||
})
|
||||
}
|
||||
@@ -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',
|
||||
|
||||
132
src/api/production-master-data/process-routing-card.js
Normal file
132
src/api/production-master-data/process-routing-card.js
Normal 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)
|
||||
})
|
||||
}
|
||||
51
src/api/production-master-data/process-routing.js
Normal file
51
src/api/production-master-data/process-routing.js
Normal 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)
|
||||
})
|
||||
}
|
||||
@@ -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',
|
||||
|
||||
@@ -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',
|
||||
|
||||
76
src/api/production-master-data/product-ng-info.js
Normal file
76
src/api/production-master-data/product-ng-info.js
Normal 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)
|
||||
})
|
||||
}
|
||||
17
src/api/production-master-data/shift-management.js
Normal file
17
src/api/production-master-data/shift-management.js
Normal 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) }) }
|
||||
24
src/api/production-master-data/team-management.js
Normal file
24
src/api/production-master-data/team-management.js
Normal 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) }) }
|
||||
15
src/api/production-master-data/workerman/index.js
Normal file
15
src/api/production-master-data/workerman/index.js
Normal 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
|
||||
}
|
||||
})
|
||||
}
|
||||
39
src/api/quality-management/aql-standards.js
Normal file
39
src/api/quality-management/aql-standards.js
Normal 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')
|
||||
})
|
||||
}
|
||||
|
||||
@@ -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')
|
||||
})
|
||||
}
|
||||
|
||||
@@ -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')
|
||||
})
|
||||
}
|
||||
|
||||
@@ -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')
|
||||
})
|
||||
}
|
||||
|
||||
39
src/api/quality-management/inspection-items.js
Normal file
39
src/api/quality-management/inspection-items.js
Normal 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')
|
||||
})
|
||||
}
|
||||
|
||||
39
src/api/quality-management/inspection-orders.js
Normal file
39
src/api/quality-management/inspection-orders.js
Normal 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')
|
||||
})
|
||||
}
|
||||
|
||||
39
src/api/quality-management/inspection-plans.js
Normal file
39
src/api/quality-management/inspection-plans.js
Normal 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')
|
||||
})
|
||||
}
|
||||
|
||||
39
src/api/quality-management/inspection-standards.js
Normal file
39
src/api/quality-management/inspection-standards.js
Normal 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')
|
||||
})
|
||||
}
|
||||
|
||||
39
src/api/quality-management/inspection-type-management.js
Normal file
39
src/api/quality-management/inspection-type-management.js
Normal 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')
|
||||
})
|
||||
}
|
||||
|
||||
39
src/api/quality-management/sampling-plans.js
Normal file
39
src/api/quality-management/sampling-plans.js
Normal 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')
|
||||
})
|
||||
}
|
||||
|
||||
39
src/api/quality-management/spc-configuration.js
Normal file
39
src/api/quality-management/spc-configuration.js
Normal 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')
|
||||
})
|
||||
}
|
||||
|
||||
24
src/api/quality-management/spc-sample-report.js
Normal file
24
src/api/quality-management/spc-sample-report.js
Normal 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
|
||||
})
|
||||
}
|
||||
43
src/api/system-administration/monitoring-configuration.js
Normal file
43
src/api/system-administration/monitoring-configuration.js
Normal 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
Reference in New Issue
Block a user