projects/mes-test #133
							
								
								
									
										8
									
								
								.env.dev
									
									
									
									
									
								
							
							
						
						| @ -1,7 +1,7 @@ | |||||||
| ### | ### | ||||||
|  # @Author: Do not edit |  # @Author: Do not edit | ||||||
|  # @Date: 2023-08-29 09:40:39 |  # @Date: 2023-08-29 09:40:39 | ||||||
|  # @LastEditTime: 2023-10-23 09:19:17 |  # @LastEditTime: 2023-10-30 10:49:39 | ||||||
|  # @LastEditors: zhp |  # @LastEditors: zhp | ||||||
|  # @Description: |  # @Description: | ||||||
| ### | ### | ||||||
| @ -9,14 +9,18 @@ | |||||||
| ENV = 'development' | ENV = 'development' | ||||||
| 
 | 
 | ||||||
| # 页面标题 | # 页面标题 | ||||||
| VUE_APP_TITLE = 产线监控系统 | VUE_APP_TITLE = MES系统 | ||||||
| 
 | 
 | ||||||
| # 芋道管理系统/开发环境 | # 芋道管理系统/开发环境 | ||||||
|  | 
 | ||||||
|  | # VUE_APP_BASE_API = 'http://192.168.0.33:48082' | ||||||
|  | # VUE_APP_BASE_API = 'http://192.168.2.173:48080' | ||||||
| # VUE_APP_BASE_API = 'http://192.168.1.49:48080' | # VUE_APP_BASE_API = 'http://192.168.1.49:48080' | ||||||
| # VUE_APP_BASE_API = 'http://192.168.1.8:48080' | # VUE_APP_BASE_API = 'http://192.168.1.8:48080' | ||||||
| VUE_APP_BASE_API = 'http://192.168.0.33:48082' | VUE_APP_BASE_API = 'http://192.168.0.33:48082' | ||||||
| # VUE_APP_BASE_API = 'http://192.168.1.188:48080' | # VUE_APP_BASE_API = 'http://192.168.1.188:48080' | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| # 路由懒加载 | # 路由懒加载 | ||||||
| VUE_CLI_BABEL_TRANSPILE_MODULES = true | VUE_CLI_BABEL_TRANSPILE_MODULES = true | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -41,6 +41,7 @@ | |||||||
|     "url": "https://github.com/YunaiV/ruoyi-vue-pro" |     "url": "https://github.com/YunaiV/ruoyi-vue-pro" | ||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|  |     "@antv/x6": "^2.15.3", | ||||||
|     "@babel/parser": "7.18.4", |     "@babel/parser": "7.18.4", | ||||||
|     "@riophae/vue-treeselect": "0.4.0", |     "@riophae/vue-treeselect": "0.4.0", | ||||||
|     "axios": "0.27.2", |     "axios": "0.27.2", | ||||||
| @ -70,6 +71,7 @@ | |||||||
|     "screenfull": "5.0.2", |     "screenfull": "5.0.2", | ||||||
|     "sortablejs": "1.10.2", |     "sortablejs": "1.10.2", | ||||||
|     "throttle-debounce": "2.1.0", |     "throttle-debounce": "2.1.0", | ||||||
|  |     "uuid": "^9.0.1", | ||||||
|     "video.js": "^8.5.2", |     "video.js": "^8.5.2", | ||||||
|     "vue": "2.7.14", |     "vue": "2.7.14", | ||||||
|     "vue-count-to": "1.0.13", |     "vue-count-to": "1.0.13", | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								src/api/base/customer.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,8 @@ | |||||||
|  | import request from '@/utils/request' | ||||||
|  | // 获得所有客户列表
 | ||||||
|  | export function getCustomerList() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-customer/listAll', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
| @ -3,7 +3,7 @@ import request from '@/utils/request' | |||||||
| // 创建设备
 | // 创建设备
 | ||||||
| export function createEquipment(data) { | export function createEquipment(data) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment/create', |     url: '/base/core-equipment/create', | ||||||
|     method: 'post', |     method: 'post', | ||||||
|     data: data |     data: data | ||||||
|   }) |   }) | ||||||
| @ -12,7 +12,7 @@ export function createEquipment(data) { | |||||||
| // 更新设备
 | // 更新设备
 | ||||||
| export function updateEquipment(data) { | export function updateEquipment(data) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment/update', |     url: '/base/core-equipment/update', | ||||||
|     method: 'put', |     method: 'put', | ||||||
|     data: data |     data: data | ||||||
|   }) |   }) | ||||||
| @ -21,7 +21,7 @@ export function updateEquipment(data) { | |||||||
| // 删除设备
 | // 删除设备
 | ||||||
| export function deleteEquipment(id) { | export function deleteEquipment(id) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment/delete?id=' + id, |     url: '/base/core-equipment/delete?id=' + id, | ||||||
|     method: 'delete' |     method: 'delete' | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
| @ -29,7 +29,7 @@ export function deleteEquipment(id) { | |||||||
| // 获得设备
 | // 获得设备
 | ||||||
| export function getEquipment(id) { | export function getEquipment(id) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment/get?id=' + id, |     url: '/base/core-equipment/get?id=' + id, | ||||||
|     method: 'get' |     method: 'get' | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
| @ -37,7 +37,7 @@ export function getEquipment(id) { | |||||||
| // 获得设备分页
 | // 获得设备分页
 | ||||||
| export function getEquipmentPage(query) { | export function getEquipmentPage(query) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment/page', |     url: '/base/core-equipment/page', | ||||||
|     method: 'get', |     method: 'get', | ||||||
|     params: query |     params: query | ||||||
|   }) |   }) | ||||||
| @ -46,7 +46,7 @@ export function getEquipmentPage(query) { | |||||||
| // 导出设备 Excel
 | // 导出设备 Excel
 | ||||||
| export function exportEquipmentExcel(query) { | export function exportEquipmentExcel(query) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment/export-excel', |     url: '/base/core-equipment/export-excel', | ||||||
|     method: 'get', |     method: 'get', | ||||||
|     params: query, |     params: query, | ||||||
|     responseType: 'blob' |     responseType: 'blob' | ||||||
| @ -55,7 +55,7 @@ export function exportEquipmentExcel(query) { | |||||||
| // 获得所有设备列表
 | // 获得所有设备列表
 | ||||||
| export function getEquipmentAll() { | export function getEquipmentAll() { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment/listAll', |     url: '/base/core-equipment/listAll', | ||||||
|     method: 'get' |     method: 'get' | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ import request from '@/utils/request' | |||||||
| // 创建设备类型
 | // 创建设备类型
 | ||||||
| export function createEquipmentType(data) { | export function createEquipmentType(data) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment-type/create', |     url: '/base/core-equipment-type/create', | ||||||
|     method: 'post', |     method: 'post', | ||||||
|     data: data |     data: data | ||||||
|   }) |   }) | ||||||
| @ -12,7 +12,7 @@ export function createEquipmentType(data) { | |||||||
| // 更新设备类型
 | // 更新设备类型
 | ||||||
| export function updateEquipmentType(data) { | export function updateEquipmentType(data) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment-type/update', |     url: '/base/core-equipment-type/update', | ||||||
|     method: 'put', |     method: 'put', | ||||||
|     data: data |     data: data | ||||||
|   }) |   }) | ||||||
| @ -21,7 +21,7 @@ export function updateEquipmentType(data) { | |||||||
| // 删除设备类型
 | // 删除设备类型
 | ||||||
| export function deleteEquipmentType(id) { | export function deleteEquipmentType(id) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment-type/delete?id=' + id, |     url: '/base/core-equipment-type/delete?id=' + id, | ||||||
|     method: 'delete' |     method: 'delete' | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
| @ -29,7 +29,7 @@ export function deleteEquipmentType(id) { | |||||||
| // 获得设备类型
 | // 获得设备类型
 | ||||||
| export function getEquipmentType(id) { | export function getEquipmentType(id) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment-type/get?id=' + id, |     url: '/base/core-equipment-type/get?id=' + id, | ||||||
|     method: 'get' |     method: 'get' | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
| @ -37,7 +37,7 @@ export function getEquipmentType(id) { | |||||||
| // 获得设备类型分页
 | // 获得设备类型分页
 | ||||||
| export function getEquipmentTypePage(query) { | export function getEquipmentTypePage(query) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment-type/page', |     url: '/base/core-equipment-type/page', | ||||||
|     method: 'get', |     method: 'get', | ||||||
|     params: query |     params: query | ||||||
|   }) |   }) | ||||||
| @ -46,7 +46,7 @@ export function getEquipmentTypePage(query) { | |||||||
| // 导出设备类型 Excel
 | // 导出设备类型 Excel
 | ||||||
| export function exportEquipmentTypeExcel(query) { | export function exportEquipmentTypeExcel(query) { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/equipment-type/export-excel', |     url: '/base/core-equipment-type/export-excel', | ||||||
|     method: 'get', |     method: 'get', | ||||||
|     params: query, |     params: query, | ||||||
|     responseType: 'blob' |     responseType: 'blob' | ||||||
|  | |||||||
| @ -2,7 +2,7 @@ import request from '@/utils/request' | |||||||
| // 获得工厂产线工段设备树形结构
 | // 获得工厂产线工段设备树形结构
 | ||||||
| export function getTree() { | export function getTree() { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/factory/getTree', |     url: '/base/core-factory/getTree', | ||||||
|     method: 'get' |     method: 'get' | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
| @ -58,3 +58,49 @@ export function listEnabled() { | |||||||
|     method: 'get' |     method: 'get' | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | // 获得班组组员信息分页
 | ||||||
|  | export function groupTeamPage(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/group-team-det/page', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得班组组员信息
 | ||||||
|  | export function groupTeamDet(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/group-team-det/get', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | // 创建班组组员信息
 | ||||||
|  | export function teamDetCreate(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/group-team-det/create', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新班组组员信息
 | ||||||
|  | export function teamDetUpdate(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/group-team-det/update', | ||||||
|  |     method: 'put', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 删除班组组员信息
 | ||||||
|  | export function teamDetDelete(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/group-team-det/delete', | ||||||
|  |     method: 'delete', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | |||||||
| @ -25,4 +25,4 @@ export function autoSet(query) { | |||||||
|     method: 'get', |     method: 'get', | ||||||
|     params: query |     params: query | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										121
									
								
								src/api/base/material.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,121 @@ | |||||||
|  | /* | ||||||
|  |  * @Author: Do not edit | ||||||
|  |  * @Date: 2023-10-21 11:50:46 | ||||||
|  |  * @LastEditTime: 2023-10-24 11:22:28 | ||||||
|  |  * @LastEditors: DY | ||||||
|  |  * @Description:  | ||||||
|  |  */ | ||||||
|  | import request from '@/utils/request' | ||||||
|  | 
 | ||||||
|  | // 创建物料
 | ||||||
|  | export function createMaterial(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material/create', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新物料
 | ||||||
|  | export function updateMaterial(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material/update', | ||||||
|  |     method: 'put', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 删除物料
 | ||||||
|  | export function deleteMaterial(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material/delete?id=' + id, | ||||||
|  |     method: 'delete' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料
 | ||||||
|  | export function getMaterial(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material/get?id=' + id, | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料code
 | ||||||
|  | export function getCode() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material/getMaterialCode', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料分页
 | ||||||
|  | export function getMaterialPage(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material/page', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料列表
 | ||||||
|  | export function getMaterialList(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material/listbyfilter', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得供应商所有列表
 | ||||||
|  | export function getSupplierList(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-supplier/listAll', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料属性列表
 | ||||||
|  | export function getMaterialAttrList(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-attr/page', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 创建物料属性
 | ||||||
|  | export function createMaterialAttr(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-attr/create', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新物料属性
 | ||||||
|  | export function updateMaterialAttr(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-attr/update', | ||||||
|  |     method: 'put', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 删除物料属性
 | ||||||
|  | export function deleteMaterialAttr(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-attr/delete?id=' + id, | ||||||
|  |     method: 'delete' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料属性
 | ||||||
|  | export function getMaterialAttr(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-attr/get', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
							
								
								
									
										68
									
								
								src/api/base/materialDate.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,68 @@ | |||||||
|  | /* | ||||||
|  |  * @Author: Do not edit | ||||||
|  |  * @Date: 2023-10-21 11:50:46 | ||||||
|  |  * @LastEditTime: 2023-10-24 17:09:59 | ||||||
|  |  * @LastEditors: DY | ||||||
|  |  * @Description:  | ||||||
|  |  */ | ||||||
|  | import request from '@/utils/request' | ||||||
|  | 
 | ||||||
|  | // 创建物料批次
 | ||||||
|  | export function createMaterialDate(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-date/create', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新物料批次
 | ||||||
|  | export function updateMaterialDate(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-date/update', | ||||||
|  |     method: 'put', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 删除物料批次
 | ||||||
|  | export function deleteMaterialDate(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-date/delete?id=' + id, | ||||||
|  |     method: 'delete' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料批次
 | ||||||
|  | export function getMaterialDate(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-date/getDetail?id=' + id, | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料批次code
 | ||||||
|  | export function getCode() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-date/getMaterialDateCode', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料批次分页
 | ||||||
|  | export function getMaterDatePage(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-date/page', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料批次列表
 | ||||||
|  | export function getMaterDateList(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-date/listbyfilter', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
							
								
								
									
										112
									
								
								src/api/base/materialProductBom.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,112 @@ | |||||||
|  | /* | ||||||
|  |  * @Author: Do not edit | ||||||
|  |  * @Date: 2023-10-21 11:50:46 | ||||||
|  |  * @LastEditTime: 2023-10-26 20:06:29 | ||||||
|  |  * @LastEditors: DY | ||||||
|  |  * @Description:  | ||||||
|  |  */ | ||||||
|  | import request from '@/utils/request' | ||||||
|  | 
 | ||||||
|  | // 创建产品Bom
 | ||||||
|  | export function createMaterialPB(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom/create', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新产品Bom
 | ||||||
|  | export function updateMaterialPB(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom/update', | ||||||
|  |     method: 'put', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 删除产品Bom
 | ||||||
|  | export function deleteMaterialPB(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom/delete?id=' + id, | ||||||
|  |     method: 'delete' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得产品Bom
 | ||||||
|  | export function getMaterialPB(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom/get?id=' + id, | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得产品Bomcode
 | ||||||
|  | export function getCode() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom/getMaterialProductBomCode', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得产品Bom分页
 | ||||||
|  | export function getMaterialPBPage(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom/page', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得产品Bom列表
 | ||||||
|  | export function getMaterialPBList(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom/listbyfilter', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得产品列表
 | ||||||
|  | export function getProList(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-product/listAll', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得产品Bom详细分页
 | ||||||
|  | export function getProBomList(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom-det/page', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 创建产品Bom详细
 | ||||||
|  | export function createMaterialPBDet(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom-det/create', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新产品Bom详细
 | ||||||
|  | export function updateMaterialPBDet(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom-det/update', | ||||||
|  |     method: 'put', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 删除产品Bom详细
 | ||||||
|  | export function deleteMaterialPBDet(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-product-bom-det/delete?id=' + id, | ||||||
|  |     method: 'delete' | ||||||
|  |   }) | ||||||
|  | } | ||||||
							
								
								
									
										69
									
								
								src/api/base/materialUseLog.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,69 @@ | |||||||
|  | /* | ||||||
|  |  * @Author: Do not edit | ||||||
|  |  * @Date: 2023-10-21 11:50:46 | ||||||
|  |  * @LastEditTime: 2023-10-26 09:32:21 | ||||||
|  |  * @LastEditors: DY | ||||||
|  |  * @Description:  | ||||||
|  |  */ | ||||||
|  | import request from '@/utils/request' | ||||||
|  | 
 | ||||||
|  | // 创建物料使用记录
 | ||||||
|  | export function createMaterialLog(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-use-log/create', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新物料使用记录
 | ||||||
|  | export function updateMaterialLog(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-use-log/update', | ||||||
|  |     method: 'put', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料使用记录
 | ||||||
|  | export function getMaterialLog(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-use-log/getDetail?id=' + id, | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得物料使用记录分页
 | ||||||
|  | export function getMaterialLogPage(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-use-log/page', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得所有设备列表
 | ||||||
|  | export function getEqListAll(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-equipment/listAll', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得所有员工列表
 | ||||||
|  | export function getworkerAll(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-worker/listAll', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 删除物料使用记录
 | ||||||
|  | export function deleteMaterialLog(id) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/material-use-log/delete?id=' + id, | ||||||
|  |     method: 'delete' | ||||||
|  |   }) | ||||||
|  | } | ||||||
							
								
								
									
										96
									
								
								src/api/base/orderManage.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,96 @@ | |||||||
|  | import request from '@/utils/request' | ||||||
|  | // 条件获得订单列表
 | ||||||
|  | export function orderList(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/order/listbyfilter', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 条件获得工单列表
 | ||||||
|  | export function workOrderList(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-work-order/listbyfilter', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得订单分页
 | ||||||
|  | export function getOrderPage(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/order/page', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获取订单code
 | ||||||
|  | export function getOrderCode() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/order/getOrderCode', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获取工单code
 | ||||||
|  | export function getWorkOrderCode() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/order/getWorkOrderCode', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得订单
 | ||||||
|  | export function getOrderById(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/order/get', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得工艺流程列表
 | ||||||
|  | export function getProcessFlowList() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/extend/process-flow/listAll', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 创建订单
 | ||||||
|  | export function orderCreate(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/order/create', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 更新订单
 | ||||||
|  | export function orderUpdate(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/order/update', | ||||||
|  |     method: 'put', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 删除订单
 | ||||||
|  | export function orderDelete(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/order/delete', | ||||||
|  |     method: 'delete', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 下发订单,绑定的穿工单id,新建不传
 | ||||||
|  | export function orderIssue(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/order/issue', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
							
								
								
									
										8
									
								
								src/api/base/product.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,8 @@ | |||||||
|  | import request from '@/utils/request' | ||||||
|  | // 获得产品列表
 | ||||||
|  | export function getProductAll() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-product/listAll', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
| @ -2,7 +2,7 @@ import request from '@/utils/request' | |||||||
| // 获得所有工厂产线列表
 | // 获得所有工厂产线列表
 | ||||||
| export function getLineAll() { | export function getLineAll() { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/production-line/listAll', |     url: '/base/core-production-line/listAll', | ||||||
|     method: 'get' |     method: 'get' | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
							
								
								
									
										8
									
								
								src/api/base/workOrder.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,8 @@ | |||||||
|  | import request from '@/utils/request' | ||||||
|  | // 获得工单列表
 | ||||||
|  | export function workOrderList() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-work-order/listbyfilter', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
							
								
								
									
										17
									
								
								src/api/base/worker.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,17 @@ | |||||||
|  | import request from '@/utils/request' | ||||||
|  | // 获得所有员工列表
 | ||||||
|  | export function getWorkerList() { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-worker/listAll', | ||||||
|  |     method: 'get' | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得员工
 | ||||||
|  | export function getWorker(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/core-worker/get', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
| @ -2,7 +2,7 @@ import request from '@/utils/request' | |||||||
| // 获得所有产线工段列表
 | // 获得所有产线工段列表
 | ||||||
| export function getWorkShopAll() { | export function getWorkShopAll() { | ||||||
|   return request({ |   return request({ | ||||||
|     url: '/base/workshop-section/listAll', |     url: '/base/core-workshop-section/listAll', | ||||||
|     method: 'get' |     method: 'get' | ||||||
|   }) |   }) | ||||||
| } | } | ||||||
							
								
								
									
										27
									
								
								src/api/monitoring/groupTeamView.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,27 @@ | |||||||
|  | import request from '@/utils/request' | ||||||
|  | // 执行班组追溯 根据工单
 | ||||||
|  | export function getByWorkOrder(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/monitoring/schedulingmonitoring/getByWorkOrder', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 执行班组追溯详情 根据工单班组
 | ||||||
|  | export function getByTeam(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/monitoring/schedulingmonitoring/getByTeam', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获取某次排班的生产情况详情
 | ||||||
|  | export function getByScheduling(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/monitoring/schedulingmonitoring/getByScheduling', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
							
								
								
									
										19
									
								
								src/api/monitoring/orderEnergy.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,19 @@ | |||||||
|  | import request from '@/utils/request' | ||||||
|  | // 获取工单信息
 | ||||||
|  | export function getWorkOrderMsg(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/monitoring/energy-work-order/getWorkOrderMsg', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获取工单能源消耗数据
 | ||||||
|  | export function getOrderEnergyData(data) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/monitoring/energy-work-order/getData', | ||||||
|  |     method: 'post', | ||||||
|  |     data: data | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
							
								
								
									
										19
									
								
								src/api/monitoring/teamProduction.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,19 @@ | |||||||
|  | import request from '@/utils/request' | ||||||
|  | 
 | ||||||
|  | // 获得排班信息分页 建议size 150
 | ||||||
|  | export function groupTeamSchedulingPage(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/group-team-scheduling/page', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | // 获得不同产线每小时报废数据,用于班组检测 班组生产情况详情(动态结构)
 | ||||||
|  | export function getSchedulingMonitoringRecord(query) { | ||||||
|  |   return request({ | ||||||
|  |     url: '/base/quality-inspection-record/getSchedulingMonitoringRecord', | ||||||
|  |     method: 'get', | ||||||
|  |     params: query | ||||||
|  |   }) | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								src/assets/icons/svg/icon-upload.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,14 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <svg width="14px" height="14px" viewBox="0 0 14 14" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> | ||||||
|  |     <title>上传</title> | ||||||
|  |     <g id="组件" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" opacity="0.65"> | ||||||
|  |         <g id="上传_Resources/Button" transform="translate(-12.000000, -9.000000)"> | ||||||
|  |             <g id="上传" transform="translate(12.000000, 9.000000)"> | ||||||
|  |                 <g id="upload" transform="translate(0.875000, 0.875000)" fill="currentColor" fill-rule="nonzero"> | ||||||
|  |                     <path d="M5.80371094,0.138085937 C5.8953125,0.046484375 6.01699219,0 6.13867188,0 C6.26035156,0 6.38066406,0.046484375 6.47363281,0.138085937 L8.60371094,2.26953125 C8.78828125,2.45410156 8.78828125,2.75351562 8.60371094,2.93808594 C8.51484375,3.02695312 8.39589844,3.07617188 8.27011719,3.07617188 C8.14433594,3.07617188 8.02539062,3.02695312 7.93652344,2.93808594 L6.61171875,1.61328125 L6.61171875,9.51289062 C6.61171875,9.77402344 6.39980469,9.9859375 6.13867188,9.9859375 C5.87753906,9.9859375 5.665625,9.77402344 5.665625,9.51289062 L5.665625,1.61328125 L4.34082031,2.93808594 C4.15625,3.12265625 3.85683594,3.12265625 3.67363281,2.93808594 C3.4890625,2.75351562 3.4890625,2.45410156 3.67226563,2.26953125 L5.80371094,0.138085937 Z M11.7769531,7.88046875 C11.5158203,7.88046875 11.3039063,8.09238281 11.3039063,8.35351563 L11.3039063,11.025 C11.3039063,11.1794922 11.178125,11.3066406 11.0222656,11.3066406 L1.22636719,11.3066406 C1.071875,11.3066406 0.944726562,11.1808594 0.944726562,11.025 L0.944726562,8.35214844 C0.944726562,8.09101563 0.7328125,7.87910156 0.471679688,7.87910156 C0.210546875,7.87910156 0,8.09238281 0,8.35214844 L0,11.3996094 C0,11.8685547 0.381445313,12.2486328 0.849023437,12.2486328 L11.4009766,12.2486328 C11.8699219,12.2486328 12.25,11.8671875 12.25,11.3996094 L12.25,8.35214844 C12.25,8.09238281 12.0380859,7.88046875 11.7769531,7.88046875 Z" id="Shape"></path> | ||||||
|  |                 </g> | ||||||
|  |                 <rect id="Rectangle-49" x="0" y="0" width="14" height="14"></rect> | ||||||
|  |             </g> | ||||||
|  |         </g> | ||||||
|  |     </g> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 2.1 KiB | 
							
								
								
									
										15
									
								
								src/assets/icons/svg/table_delete.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,15 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8"?> | ||||||
|  | <svg width="14px" height="14px" viewBox="0 0 14 14" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> | ||||||
|  |     <!-- Generator: Sketch 60 (88103) - https://sketch.com --> | ||||||
|  |     <desc>Created with Sketch.</desc> | ||||||
|  |     <g id="11_系统管理" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"> | ||||||
|  |         <g id="11-1用户管理" transform="translate(-1822.000000, -159.000000)" fill="#FF5454" fill-rule="nonzero"> | ||||||
|  |             <g id="编组-10" transform="translate(1821.000000, 158.000000)"> | ||||||
|  |                 <g id="删除"> | ||||||
|  |                     <rect id="矩形" opacity="0" x="0" y="0" width="16" height="16"></rect> | ||||||
|  |                     <path d="M9.39137788,11.7149165 C9.13431614,11.7149165 8.92716929,11.5077697 8.92716929,11.2507079 L8.92716929,6.14191781 C8.92716929,5.88485607 9.13431613,5.67770922 9.39137788,5.67770922 C9.64843963,5.67770922 9.85558647,5.88485606 9.85558647,6.14191781 L9.85558647,11.2482122 C9.85558647,11.5052739 9.64843961,11.7149165 9.39137788,11.7149165 Z M6.60612639,11.7149165 C6.34906466,11.7149165 6.1419178,11.5077697 6.1419178,11.2507079 L6.1419178,6.14191781 C6.1419178,5.88485607 6.34906466,5.67770922 6.60612641,5.67770922 C6.86318814,5.67770922 7.07033499,5.88485606 7.07033499,6.14191781 L7.07033499,11.2482122 C7.07033499,11.5052739 6.86318814,11.7149165 6.60612639,11.7149165 Z M14.0359594,3.82087491 L11.7149165,3.82087491 L11.7149165,2.89245775 C11.7149165,2.12376827 11.0959718,1.499832 10.3322738,1.499832 L5.67770923,1.499832 C4.90901976,1.499832 4.28508349,2.12376827 4.28508349,2.89245775 L4.28508349,3.82087491 L1.96404059,3.82087491 C1.70697885,3.82087491 1.499832,4.02802174 1.499832,4.28508349 C1.499832,4.54214524 1.70697884,4.74929208 1.96404059,4.74929208 L14.0359594,4.74929208 C14.2930211,4.74929208 14.500168,4.54214524 14.500168,4.28508349 C14.500168,4.02802174 14.2930212,3.82087491 14.0359594,3.82087491 Z M5.21350066,2.89245775 C5.21350066,2.63789175 5.42314324,2.42824916 5.67770925,2.42824916 L10.3322738,2.42824916 C10.5868398,2.42824916 10.7864994,2.63290025 10.7864994,2.89245775 L10.7864994,3.82087491 L5.21350066,3.82087491 L5.21350066,2.89245775 L5.21350066,2.89245775 Z M11.2507079,14.500168 L4.75178782,14.500168 C3.98309834,14.500168 3.35916207,13.8762317 3.35916207,13.1075423 L3.35916207,6.13692631 C3.35916207,5.87986457 3.56630891,5.67271772 3.82337066,5.67271772 C4.08043241,5.67271772 4.28757925,5.87986456 4.28757925,6.13692631 L4.28757925,13.1075423 C4.28757925,13.364604 4.49722183,13.5717508 4.75178783,13.5717508 L11.2532037,13.5717508 C11.5102654,13.5717508 11.7174123,13.364604 11.7174123,13.1075423 L11.7174123,6.15439653 C11.7174123,5.89733479 11.9245591,5.69018794 12.1816209,5.69018794 C12.4386826,5.69018794 12.6458294,5.89733478 12.6458294,6.15439653 L12.6458294,13.1075423 C12.6433337,13.873736 12.0193974,14.500168 11.2507079,14.500168 Z" id="形状"></path> | ||||||
|  |                 </g> | ||||||
|  |             </g> | ||||||
|  |         </g> | ||||||
|  |     </g> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 2.9 KiB | 
| @ -47,12 +47,14 @@ | |||||||
| 						type="datetime" | 						type="datetime" | ||||||
| 						:placeholder="`请选择${col.label}`" | 						:placeholder="`请选择${col.label}`" | ||||||
| 						value-format="timestamp" | 						value-format="timestamp" | ||||||
|  | 						@change="$emit('update', form)" | ||||||
| 						v-bind="col.bind"></el-date-picker> | 						v-bind="col.bind"></el-date-picker> | ||||||
| 					<el-switch | 					<el-switch | ||||||
| 						v-if="col.switch" | 						v-if="col.switch" | ||||||
| 						v-model="form[col.prop]" | 						v-model="form[col.prop]" | ||||||
| 						active-color="#0b58ff" | 						active-color="#0b58ff" | ||||||
| 						inactive-color="#e1e1e1" | 						inactive-color="#e1e1e1" | ||||||
|  | 						@change="$emit('update', form)" | ||||||
| 						v-bind="col.bind"></el-switch> | 						v-bind="col.bind"></el-switch> | ||||||
| 					<component | 					<component | ||||||
| 						v-if="col.subcomponent" | 						v-if="col.subcomponent" | ||||||
| @ -83,6 +85,9 @@ | |||||||
| 							:on-success="handleUploadSuccess" | 							:on-success="handleUploadSuccess" | ||||||
| 							v-bind="col.bind"> | 							v-bind="col.bind"> | ||||||
| 							<el-button size="mini" :disabled="col.bind?.disabled || false"> | 							<el-button size="mini" :disabled="col.bind?.disabled || false"> | ||||||
|  | 								<svg-icon | ||||||
|  | 									icon-class="icon-upload" | ||||||
|  | 									style="color: inherit"></svg-icon> | ||||||
| 								上传文件 | 								上传文件 | ||||||
| 							</el-button> | 							</el-button> | ||||||
| 							<div class="el-upload__tip" slot="tip" v-if="col.uploadTips"> | 							<div class="el-upload__tip" slot="tip" v-if="col.uploadTips"> | ||||||
| @ -94,6 +99,7 @@ | |||||||
| 							class="file" | 							class="file" | ||||||
| 							v-for="file in form[col.prop] || []" | 							v-for="file in form[col.prop] || []" | ||||||
| 							:file="file" | 							:file="file" | ||||||
|  | 							:key="file.fileUrl" | ||||||
| 							@delete="handleDeleteFile(file)" /> | 							@delete="handleDeleteFile(file)" /> | ||||||
| 					</div> | 					</div> | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| @ -105,6 +111,7 @@ | |||||||
| <script> | <script> | ||||||
| import { getAccessToken } from '@/utils/auth'; | import { getAccessToken } from '@/utils/auth'; | ||||||
| import tupleImg from '@/assets/images/tuple.png'; | import tupleImg from '@/assets/images/tuple.png'; | ||||||
|  | import cache from '@/utils/cache'; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 找到最长的label |  * 找到最长的label | ||||||
| @ -132,7 +139,6 @@ const uploadedFile = { | |||||||
| 	}, | 	}, | ||||||
| 	methods: { | 	methods: { | ||||||
| 		handleDelete() { | 		handleDelete() { | ||||||
| 			console.log('emit delete event') |  | ||||||
| 			this.$emit('delete', this.file); | 			this.$emit('delete', this.file); | ||||||
| 		}, | 		}, | ||||||
| 	}, | 	}, | ||||||
| @ -187,6 +193,10 @@ export default { | |||||||
| 			type: Boolean, | 			type: Boolean, | ||||||
| 			default: false, | 			default: false, | ||||||
| 		}, | 		}, | ||||||
|  | 		hasFiles: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			default: false, | ||||||
|  | 		}, | ||||||
| 		labelPosition: { | 		labelPosition: { | ||||||
| 			type: String, | 			type: String, | ||||||
| 			default: 'right', | 			default: 'right', | ||||||
| @ -219,7 +229,6 @@ export default { | |||||||
| 	watch: { | 	watch: { | ||||||
| 		rows: { | 		rows: { | ||||||
| 			handler() { | 			handler() { | ||||||
| 				console.log('watch triggered!'); |  | ||||||
| 				this.$nextTick(() => { | 				this.$nextTick(() => { | ||||||
| 					this.handleOptions('watch'); | 					this.handleOptions('watch'); | ||||||
| 				}); | 				}); | ||||||
| @ -230,6 +239,9 @@ export default { | |||||||
| 		dataForm: { | 		dataForm: { | ||||||
| 			handler(val) { | 			handler(val) { | ||||||
| 				this.form = JSON.parse(JSON.stringify(val)); | 				this.form = JSON.parse(JSON.stringify(val)); | ||||||
|  | 				if (this.hasFiles) { | ||||||
|  | 					this.form.files = this.form.files ?? []; | ||||||
|  | 				} | ||||||
| 			}, | 			}, | ||||||
| 			deep: true, | 			deep: true, | ||||||
| 			immediate: true, | 			immediate: true, | ||||||
| @ -267,7 +279,6 @@ export default { | |||||||
| 					} else if (opt.url) { | 					} else if (opt.url) { | ||||||
| 						// 如果有 depends,则暂时先不获取,注册一个watcher | 						// 如果有 depends,则暂时先不获取,注册一个watcher | ||||||
| 						if (opt.depends) { | 						if (opt.depends) { | ||||||
| 							console.log('[handleOptions] setting watch'); |  | ||||||
| 							this.$watch( | 							this.$watch( | ||||||
| 								() => this.form[opt.depends], | 								() => this.form[opt.depends], | ||||||
| 								(id) => { | 								(id) => { | ||||||
| @ -290,7 +301,7 @@ export default { | |||||||
| 									}); | 									}); | ||||||
| 								}, | 								}, | ||||||
| 								{ | 								{ | ||||||
| 									immediate: true, | 									immediate: false, | ||||||
| 								} | 								} | ||||||
| 							); | 							); | ||||||
| 							return; | 							return; | ||||||
| @ -308,6 +319,11 @@ export default { | |||||||
| 										'list' in response.data | 										'list' in response.data | ||||||
| 											? response.data.list | 											? response.data.list | ||||||
| 											: response.data; | 											: response.data; | ||||||
|  | 
 | ||||||
|  | 									if (opt.cache) { | ||||||
|  | 										cache.store(opt.cache, list); | ||||||
|  | 									} | ||||||
|  | 
 | ||||||
| 									this.$set( | 									this.$set( | ||||||
| 										this.optionListOf, | 										this.optionListOf, | ||||||
| 										opt.prop, | 										opt.prop, | ||||||
| @ -367,7 +383,9 @@ export default { | |||||||
| 		}, | 		}, | ||||||
| 
 | 
 | ||||||
| 		handleDeleteFile(file) { | 		handleDeleteFile(file) { | ||||||
| 			this.form.files = this.form.files.filter(item => item.fileUrl != file.fileUrl); | 			this.form.files = this.form.files.filter( | ||||||
|  | 				(item) => item.fileUrl != file.fileUrl | ||||||
|  | 			); | ||||||
| 			this.$emit('update', this.form); | 			this.$emit('update', this.form); | ||||||
| 		}, | 		}, | ||||||
| 	}, | 	}, | ||||||
|  | |||||||
| @ -28,10 +28,56 @@ export default { | |||||||
| 			// tableBtn: [], // 占位
 | 			// tableBtn: [], // 占位
 | ||||||
| 			// searchBarFormConfig: [], // 占位
 | 			// searchBarFormConfig: [], // 占位
 | ||||||
| 			// // 弹窗表单配置
 | 			// // 弹窗表单配置
 | ||||||
| 			// dialogFormConfig: [], // 占位
 | 			// dialogFormConfig: [], // 
 | ||||||
|  | 			updateUrl: '', | ||||||
|  | 			addUrl: '', | ||||||
|  | 			pageUrl: '', | ||||||
|  | 			infoUrl: '', | ||||||
|  | 			basePath: '', | ||||||
|  | 			form: {} | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  | 	computed: { | ||||||
|  | 		addPath() { | ||||||
|  | 			return this.basePath + '/create' | ||||||
|  | 		}, | ||||||
|  | 		updatePath() { | ||||||
|  | 			return this.basePath + '/update' | ||||||
|  | 		}, | ||||||
|  | 		deletePath() { | ||||||
|  | 			return this.basePath + '/delete' | ||||||
|  | 		}, | ||||||
|  | 		infoPath() { | ||||||
|  | 			return this.basePath + '/get' | ||||||
|  | 		}, | ||||||
|  | 		pagePath() { | ||||||
|  | 			return this.basePath + '/page' | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
| 	methods: { | 	methods: { | ||||||
|  | 		// utils
 | ||||||
|  | 		http(url, method, payload) { | ||||||
|  | 			return this.$axios({ | ||||||
|  | 				url, | ||||||
|  | 				method, | ||||||
|  | 				params: method === 'get' ? payload : null, | ||||||
|  | 				data: method !== 'get' ? payload : null, | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 		put(payload) { | ||||||
|  | 			return this.http(this.updateUrl == '' ? this.updatePath : this.updateUrl, 'put', payload); | ||||||
|  | 		}, | ||||||
|  | 		post(payload) { | ||||||
|  | 			return this.http(this.addUrl == '' ? this.addPath : this.addUrl, 'post', payload); | ||||||
|  | 		}, | ||||||
|  | 		recv(payload) { | ||||||
|  | 			return this.http(this.pageUrl == '' ? this.pagePath : this.pageUrl, 'get', payload); | ||||||
|  | 		}, | ||||||
|  | 		info(payload) { | ||||||
|  | 			return this.http(this.infoUrl == '' ? this.infoPath : this.infoUrl, 'get', payload); | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 		// 过滤后端传回的详情数据
 | 		// 过滤后端传回的详情数据
 | ||||||
| 		filterData(data, keys) { | 		filterData(data, keys) { | ||||||
| 			const obj = {}; | 			const obj = {}; | ||||||
|  | |||||||
							
								
								
									
										53
									
								
								src/utils/cache.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,53 @@ | |||||||
|  | let timers = []; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 
 | ||||||
|  |     exists(key) { | ||||||
|  |         const _ = localStorage.getItem('stored_keys'); | ||||||
|  |         return _ ? _.split(',')?.indexOf(key) != -1 : false; | ||||||
|  |     }, | ||||||
|  | 
 | ||||||
|  |     store(key, value, duration = null) { | ||||||
|  |         if (!localStorage.getItem('stored_keys')) localStorage.setItem('stored_keys', key); | ||||||
|  |         else localStorage.setItem('stored_keys', localStorage.getItem('stored_keys') + ',' + key); | ||||||
|  | 
 | ||||||
|  |         localStorage.setItem(key, JSON.stringify(value)); | ||||||
|  |         console.log('store duration', duration) | ||||||
|  |         if (duration) { | ||||||
|  |             if (timers[key]) clearTimeout(timers[key]); | ||||||
|  |             timers[key] = setTimeout(() => { | ||||||
|  |                 console.log("clear cache", key) | ||||||
|  |                 this.clear([key]); | ||||||
|  |             }, duration * 1000); | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      *  | ||||||
|  |      * @param {*} key  | ||||||
|  |      * @param {*} cb  | ||||||
|  |      * @param {*} param2 force 强制更新,调用cb | ||||||
|  |      * @returns  | ||||||
|  |      */ | ||||||
|  |     async getList(key, cb = null, { force = false, duration = null } = {}) { | ||||||
|  |         if (this.exists(key) && !force) { | ||||||
|  |             return JSON.parse(localStorage.getItem(key)) | ||||||
|  |         } else { | ||||||
|  |             const list = await cb(); | ||||||
|  |             this.store(key, list, duration); | ||||||
|  |             return list; | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  | 
 | ||||||
|  |     clear(keys) { | ||||||
|  |         if (keys && keys.length) { | ||||||
|  |             let stored_keys = localStorage.getItem('stored_keys').split(','); | ||||||
|  |             keys.forEach((key) => { | ||||||
|  |                 stored_keys = stored_keys.filter((item) => item != key); | ||||||
|  |             }); | ||||||
|  |             localStorage.setItem('stored_keys', stored_keys); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         localStorage.removeItem('stored_keys'); | ||||||
|  |     }, | ||||||
|  | } | ||||||
| @ -89,13 +89,17 @@ export const DICT_TYPE = { | |||||||
| 
 | 
 | ||||||
|   // ============== ENERGY - 能源模块 =============
 |   // ============== ENERGY - 能源模块 =============
 | ||||||
|   ENERGY_UNIT: 'energy_unit', |   ENERGY_UNIT: 'energy_unit', | ||||||
|    |  | ||||||
|   // ============== ENERGY - 能源模块 =============
 |  | ||||||
|   EQU_ALARM_LEVEL: 'equ_alarm_level', |   EQU_ALARM_LEVEL: 'equ_alarm_level', | ||||||
|   MONITOR_INDEX_TYPE: 'monitor_index_type', |   MONITOR_INDEX_TYPE: 'monitor_index_type', | ||||||
|   OBJECT_TYPE: 'object_type', |   OBJECT_TYPE: 'object_type', | ||||||
|   STATISTIC_TYPE: 'statistic_type', |   STATISTIC_TYPE: 'statistic_type', | ||||||
|   TIME_DIM: 'time_dim' |   TIME_DIM: 'time_dim', | ||||||
|  | 
 | ||||||
|  |   // ============== ORDER - 订单模块 =============
 | ||||||
|  |   ORDER_STATUS: 'order_status', | ||||||
|  |   ORDER_ORIGIN: 'order_Origin', | ||||||
|  |   ORDER_PRIORITY: 'order_priority', | ||||||
|  |   PACK_SPEC: 'pack_spec' | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  | |||||||
| @ -217,7 +217,7 @@ export function getTime(type) { | |||||||
| export function debounce(func, wait, immediate) { | export function debounce(func, wait, immediate) { | ||||||
|   let timeout, args, context, timestamp, result |   let timeout, args, context, timestamp, result | ||||||
| 
 | 
 | ||||||
|   const later = function() { |   const later = function () { | ||||||
|     // 据上一次触发时间间隔
 |     // 据上一次触发时间间隔
 | ||||||
|     const last = +new Date() - timestamp |     const last = +new Date() - timestamp | ||||||
| 
 | 
 | ||||||
| @ -234,7 +234,7 @@ export function debounce(func, wait, immediate) { | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   return function(...args) { |   return function (...args) { | ||||||
|     context = this |     context = this | ||||||
|     timestamp = +new Date() |     timestamp = +new Date() | ||||||
|     const callNow = immediate && !timeout |     const callNow = immediate && !timeout | ||||||
| @ -438,3 +438,7 @@ export function toCamelCase(str, upperCaseFirst) { | |||||||
| 
 | 
 | ||||||
|   return str; |   return str; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | export function IdToName(targetId, source, prop = 'name') { | ||||||
|  |   return source.find(item => item.id === targetId)?.[prop] | ||||||
|  | } | ||||||
| @ -18,7 +18,13 @@ | |||||||
| 				预览 | 				预览 | ||||||
| 			</div> --> | 			</div> --> | ||||||
| 		</section> | 		</section> | ||||||
| 		<section class="file-area"> | 		<section | ||||||
|  | 			class="file-area" | ||||||
|  | 			:style="{ | ||||||
|  | 				height: expand ? 'auto' : isPicMode ? '180px' : '152px', | ||||||
|  | 				gap: isPicMode ? '0 24px' : '24px', | ||||||
|  | 				gridAutoRows: isPicMode ? '180px' : '152px', | ||||||
|  | 			}"> | ||||||
| 			<el-upload | 			<el-upload | ||||||
| 				class="equipment-upload" | 				class="equipment-upload" | ||||||
| 				:disabled="disabled" | 				:disabled="disabled" | ||||||
| @ -56,7 +62,6 @@ | |||||||
| 				v-for="(file, index) in files" | 				v-for="(file, index) in files" | ||||||
| 				:key="file.fileName" | 				:key="file.fileName" | ||||||
| 				:style="{ | 				:style="{ | ||||||
| 					display: index > 3 && !expand ? 'none' : 'block', |  | ||||||
| 					background: isPicMode | 					background: isPicMode | ||||||
| 						? `url(${file.fileUrl}) no-repeat` | 						? `url(${file.fileUrl}) no-repeat` | ||||||
| 						: `url(${defaultBg}) no-repeat`, | 						: `url(${defaultBg}) no-repeat`, | ||||||
| @ -77,7 +82,7 @@ | |||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import { getAccessToken } from '@/utils/auth'; | import { getAccessToken } from '@/utils/auth'; | ||||||
| import defaultBg from '../../../../../assets/images/default-file-icon.png'; | import defaultBg from '../../../../assets/images/default-file-icon.png'; | ||||||
| 
 | 
 | ||||||
| function checkSize(file, message) { | function checkSize(file, message) { | ||||||
| 	const isLt2M = file.size / 1024 / 1024 < 2; | 	const isLt2M = file.size / 1024 / 1024 < 2; | ||||||
| @ -134,56 +139,7 @@ export default { | |||||||
| 			headers: { Authorization: 'Bearer ' + getAccessToken() }, // 设置上传的请求头部 | 			headers: { Authorization: 'Bearer ' + getAccessToken() }, // 设置上传的请求头部 | ||||||
| 			fileList: [], | 			fileList: [], | ||||||
| 			uploadUrl: process.env.VUE_APP_BASE_API + '/admin-api/infra/file/upload', | 			uploadUrl: process.env.VUE_APP_BASE_API + '/admin-api/infra/file/upload', | ||||||
| 			files: [ | 			files: [], | ||||||
| 				// 服务器返回的结构 |  | ||||||
| 				// { |  | ||||||
| 				// 	fileName: 'sf.docs', |  | ||||||
| 				// 	fileType: 'asset', |  | ||||||
| 				// 	fileUrl: |  | ||||||
| 				// 		'https://hbimg.b0.upaiyun.com/cc7475787bd08ed926b68eaf53fa1f2c5473259115e3c-gJdObd_fw658', |  | ||||||
| 				// }, |  | ||||||
| 				// { |  | ||||||
| 				// 	fileName: 'sddf.docs', |  | ||||||
| 				// 	fileType: 'asset', |  | ||||||
| 				// 	fileUrl: 'https://img0.sc115.com/wm/xqx/pic1/1501xofo4ssolji.jpg', |  | ||||||
| 				// }, |  | ||||||
| 				// { |  | ||||||
| 				// 	fileName: 'jjj.docs', |  | ||||||
| 				// 	fileType: 'asset', |  | ||||||
| 				// 	fileUrl: |  | ||||||
| 				// 		'https://www.mms591.com/www.mms591.com-photo/2013081823/1-130QR34544.jpg', |  | ||||||
| 				// }, |  | ||||||
| 				// { |  | ||||||
| 				// 	fileName: 'asdfasdf.docs', |  | ||||||
| 				// 	fileType: 'asset', |  | ||||||
| 				// 	fileUrl: |  | ||||||
| 				// 		'https://hbimg.b0.upaiyun.com/8f6bced5f2e38d3a021b2c48d5a98dfb6317e3e12c6a0-QmhJ5v_fw658', |  | ||||||
| 				// }, |  | ||||||
| 				// { |  | ||||||
| 				// 	fileName: 'asdkj.docs', |  | ||||||
| 				// 	fileType: 'asset', |  | ||||||
| 				// 	fileUrl: |  | ||||||
| 				// 		'https://www.mms591.com/www.mms591.com-photo/2013013021/1-130130212034.jpg', |  | ||||||
| 				// }, |  | ||||||
| 				// { |  | ||||||
| 				// 	fileName: 'lkasjdf.docs', |  | ||||||
| 				// 	fileType: 'asset', |  | ||||||
| 				// 	fileUrl: |  | ||||||
| 				// 		'https://www.mms591.com/www.mms591.com-photo/2013072122/1-130H1223057.jpg', |  | ||||||
| 				// }, |  | ||||||
| 				// { |  | ||||||
| 				// 	fileName: 'asdf.docs', |  | ||||||
| 				// 	fileType: 'asset', |  | ||||||
| 				// 	fileUrl: |  | ||||||
| 				// 		'https://img.1ppt.com/uploads/allimg/1212/1-1212101ZH5A2.jpg', |  | ||||||
| 				// }, |  | ||||||
| 				// { |  | ||||||
| 				// 	fileName: 'afdffff.docs', |  | ||||||
| 				// 	fileType: 'asset', |  | ||||||
| 				// 	fileUrl: |  | ||||||
| 				// 		'https://www.mms591.com/www.mms591.com-photo/2013051721/1-13051H11945.jpg', |  | ||||||
| 				// }, |  | ||||||
| 			], |  | ||||||
| 			updateTimer: null, | 			updateTimer: null, | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
| @ -226,7 +182,7 @@ export default { | |||||||
| 				clearTimeout(this.updateTimer); | 				clearTimeout(this.updateTimer); | ||||||
| 			} | 			} | ||||||
| 			this.updateTimer = setTimeout(() => { | 			this.updateTimer = setTimeout(() => { | ||||||
| 				console.log('[AssetsUpload] 更新上传列表'); | 				// console.log('[AssetsUpload] 更新上传列表'); | ||||||
| 				this.emitFilelist(); | 				this.emitFilelist(); | ||||||
| 				clearTimeout(this.updateTimer); | 				clearTimeout(this.updateTimer); | ||||||
| 				this.updateTimer = null; | 				this.updateTimer = null; | ||||||
| @ -314,7 +270,6 @@ export default { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| :deep(.equipment-upload) { | :deep(.equipment-upload) { | ||||||
| 	background: #ccc4; |  | ||||||
| 	.el-upload-dragger { | 	.el-upload-dragger { | ||||||
| 		width: 188px; | 		width: 188px; | ||||||
| 		height: 128px; | 		height: 128px; | ||||||
| @ -346,6 +301,10 @@ export default { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .equipment-upload { | ||||||
|  | 	margin-bottom: 24px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .file-list { | .file-list { | ||||||
| 	padding: 12px; | 	padding: 12px; | ||||||
| 	border: 1px solid #ccc; | 	border: 1px solid #ccc; | ||||||
| @ -354,13 +313,14 @@ export default { | |||||||
| // custom | // custom | ||||||
| .file-area { | .file-area { | ||||||
| 	display: grid; | 	display: grid; | ||||||
| 	grid-template-columns: repeat(5, 188px); | 	grid-template-columns: repeat(auto-fill, 188px); | ||||||
| 	grid-auto-rows: 128px; | 	grid-auto-rows: 152px; | ||||||
| 	gap: 24px 18px; | 	gap: 48px 24px; | ||||||
| 	place-content: center; | 	overflow: hidden; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .file-list__item { | .file-list__item { | ||||||
|  | 	height: 128px; | ||||||
| 	background-color: #fff; | 	background-color: #fff; | ||||||
| 	border: 1px dashed #d9d9d9; | 	border: 1px dashed #d9d9d9; | ||||||
| 	border-radius: 6px; | 	border-radius: 6px; | ||||||
| @ -405,7 +365,7 @@ export default { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .default-icon { | .default-icon { | ||||||
| 	background: url(../../../../../assets/images/default-file-icon.png) no-repeat; | 	background: url(../../../../assets/images/default-file-icon.png) no-repeat; | ||||||
| 	background-position: center; | 	background-position: center; | ||||||
| 	background-size: 64px; | 	background-size: 64px; | ||||||
| } | } | ||||||
| @ -6,150 +6,105 @@ | |||||||
| --> | --> | ||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
| 	<el-form | 	<el-form class="equipment-info-form" ref="form" :model="form" label-width="200px" label-position="top" | ||||||
| 		class="equipment-info-form" |  | ||||||
| 		ref="form" |  | ||||||
| 		:model="form" |  | ||||||
| 		label-width="200px" |  | ||||||
| 		label-position="top" |  | ||||||
| 		v-loading="formLoading"> | 		v-loading="formLoading"> | ||||||
| 		<el-row :gutter="20"> | 		<el-row :gutter="20"> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item | 				<el-form-item label="设备名称" prop="name" :rules="[{ required: true, message: '不能为空', trigger: 'blur' }]"> | ||||||
| 					label="设备名称" | 					<el-input v-model="form.name" :disabled="disabled" placeholder="请输入设备名称"></el-input> | ||||||
| 					prop="name" |  | ||||||
| 					:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]"> |  | ||||||
| 					<el-input |  | ||||||
| 						v-model="form.name" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						placeholder="请输入设备名称"></el-input> |  | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item label="设备编码" prop="code" :rules="[]"> | 				<el-form-item label="设备编码" prop="code" :rules="[]"> | ||||||
| 					<el-input | 					<el-input v-model="form.code" :disabled="disabled" placeholder="请输入设备编码"></el-input> | ||||||
| 						v-model="form.code" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						placeholder="请输入设备编码"></el-input> |  | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item label="英文名称" prop="enName" :rules="[]"> | 				<el-form-item label="英文名称" prop="enName" :rules="[]"> | ||||||
| 					<el-input | 					<el-input v-model="form.enName" :disabled="disabled" placeholder="请输入英文名称"></el-input> | ||||||
| 						v-model="form.enName" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						placeholder="请输入英文名称"></el-input> |  | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 		</el-row> | 		</el-row> | ||||||
| 		<el-row :gutter="20"> | 		<el-row :gutter="20"> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item label="缩写" prop="abbr" :rules="[]"> | 				<el-form-item label="缩写" prop="abbr" :rules="[]"> | ||||||
| 					<el-input | 					<el-input v-model="form.abbr" :disabled="disabled" placeholder="请输入名称缩写"></el-input> | ||||||
| 						v-model="form.abbr" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						placeholder="请输入名称缩写"></el-input> |  | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item label="设备类型" prop="equipmentTypeId" :rules="[]"> | 				<el-form-item label="设备类型" prop="equipmentTypeId" | ||||||
| 					<el-select | 					:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]"> | ||||||
| 						v-model="form.equipmentTypeId" | 					<el-select v-model="form.equipmentTypeId" :disabled="disabled" filterable placeholder="请选择设备类型"> | ||||||
| 						:disabled="disabled" | 						<el-option v-for="eqType in eqTypeList" :key="eqType.id" :label="eqType.name" | ||||||
| 						filterable |  | ||||||
| 						placeholder="请选择设备类型"> |  | ||||||
| 						<el-option |  | ||||||
| 							v-for="eqType in eqTypeList" |  | ||||||
| 							:key="eqType.id" |  | ||||||
| 							:label="eqType.name" |  | ||||||
| 							:value="eqType.id"></el-option> | 							:value="eqType.id"></el-option> | ||||||
| 					</el-select> | 					</el-select> | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
|  | 
 | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item label="备注" prop="remark" :rules="[]"> | 				<el-form-item label="预计生产时间(min/天)" prop="workTime" :rules="[ | ||||||
| 					<el-input | 					{ required: true, message: '不能为空', trigger: 'blur' }, | ||||||
| 						v-model="form.remark" | 					{ | ||||||
| 						:disabled="disabled" | 						type: 'number', | ||||||
| 						placeholder="请输入备注"></el-input> | 						message: '请输入正确的数字值', | ||||||
|  | 						trigger: 'blur', | ||||||
|  | 						transform: (val) => Number(val), | ||||||
|  | 					}, | ||||||
|  | 				]"> | ||||||
|  | 					<el-input v-model="form.workTime" :disabled="disabled" placeholder="请输入预计生产时间"></el-input> | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
|  | 
 | ||||||
| 		</el-row> | 		</el-row> | ||||||
| 		<el-row :gutter="20"> | 		<el-row :gutter="20"> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item label="生产日期" prop="productionTime" :rules="[]"> | 				<el-form-item label="生产日期" prop="productionTime" :rules="[]"> | ||||||
| 					<el-date-picker | 					<el-date-picker v-model="form.enterTime" :disabled="disabled" type="datetime" placeholder="请选择生产日期" | ||||||
| 						v-model="form.enterTime" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						type="datetime" |  | ||||||
| 						placeholder="请选择生产日期" |  | ||||||
| 						value-format="timestamp"></el-date-picker> | 						value-format="timestamp"></el-date-picker> | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item label="进场日期" prop="enterTime" :rules="[]"> | 				<el-form-item label="进场日期" prop="enterTime" :rules="[]"> | ||||||
| 					<el-date-picker | 					<el-date-picker v-model="form.enterTime" :disabled="disabled" type="datetime" placeholder="请选择进场日期" | ||||||
| 						v-model="form.enterTime" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						type="datetime" |  | ||||||
| 						placeholder="请选择进场日期" |  | ||||||
| 						value-format="timestamp"></el-date-picker> | 						value-format="timestamp"></el-date-picker> | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item | 				<el-form-item label="设备TT值" prop="tvalue" :rules="[ | ||||||
| 					label="设备TT值" | 					{ required: true, message: '不能为空', trigger: 'blur' }, | ||||||
| 					prop="tvalue" | 					{ | ||||||
| 					:rules="[ | 						type: 'number', | ||||||
| 						{ required: true, message: '不能为空', trigger: 'blur' }, | 						message: '请输入正确的数字值', | ||||||
| 						{ | 						trigger: 'blur', | ||||||
| 							type: 'number', | 						transform: (val) => Number(val), | ||||||
| 							message: '请输入正确的数字值', | 					}, | ||||||
| 							trigger: 'blur', | 				]"> | ||||||
| 							transform: (val) => Number(val), | 					<el-input v-model="form.tvalue" :disabled="disabled" placeholder="请输入设备TT值"></el-input> | ||||||
| 						}, |  | ||||||
| 					]"> |  | ||||||
| 					<el-input |  | ||||||
| 						v-model="form.tvalue" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						placeholder="请输入设备TT值"></el-input> |  | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 		</el-row> | 		</el-row> | ||||||
| 		<el-row :gutter="20"> | 		<el-row :gutter="20"> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item | 				<el-form-item label="产品加工时间(s)" prop="processingTime" :rules="[ | ||||||
| 					label="产品加工时间(s)" | 					{ required: true, message: '不能为空', trigger: 'blur' }, | ||||||
| 					prop="processingTime" | 					{ | ||||||
| 					:rules="[ | 						type: 'number', | ||||||
| 						{ required: true, message: '不能为空', trigger: 'blur' }, | 						message: '请输入正确的数字值', | ||||||
| 						{ | 						trigger: 'blur', | ||||||
| 							type: 'number', | 						transform: (val) => Number(val), | ||||||
| 							message: '请输入正确的数字值', | 					}, | ||||||
| 							trigger: 'blur', | 				]"> | ||||||
| 							transform: (val) => Number(val), | 					<el-input v-model="form.processingTime" :disabled="disabled" placeholder="请输入产品加工时间"></el-input> | ||||||
| 						}, |  | ||||||
| 					]"> |  | ||||||
| 					<el-input |  | ||||||
| 						v-model="form.processingTime" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						placeholder="请输入产品加工时间"></el-input> |  | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item label="制造商" prop="manufacturer" :rules="[]"> | 				<el-form-item label="制造商" prop="manufacturer" :rules="[]"> | ||||||
| 					<el-input | 					<el-input v-model="form.manufacturer" :disabled="disabled" placeholder="请输入制造商"></el-input> | ||||||
| 						v-model="form.manufacturer" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						placeholder="请输入制造商"></el-input> |  | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 			<el-col :span="8"> | 			<el-col :span="8"> | ||||||
| 				<el-form-item label="设备规格" prop="spec" :rules="[]"> | 				<el-form-item label="设备规格" prop="spec" :rules="[]"> | ||||||
| 					<el-input | 					<el-input v-model="form.spec" :disabled="disabled" placeholder="请输入设备规格"></el-input> | ||||||
| 						v-model="form.spec" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						placeholder="请输入设备规格"></el-input> |  | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 		</el-row> | 		</el-row> | ||||||
| @ -157,14 +112,19 @@ | |||||||
| 			<!-- 功能描述  --> | 			<!-- 功能描述  --> | ||||||
| 			<el-col> | 			<el-col> | ||||||
| 				<el-form-item label="功能描述" prop="description" :rules="[]"> | 				<el-form-item label="功能描述" prop="description" :rules="[]"> | ||||||
| 					<el-input | 					<el-input type="textarea" :disabled="disabled" v-model="form.description" | ||||||
| 						type="textarea" |  | ||||||
| 						:disabled="disabled" |  | ||||||
| 						v-model="form.description" |  | ||||||
| 						placeholder="请填写功能描述"></el-input> | 						placeholder="请填写功能描述"></el-input> | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 		</el-row> | 		</el-row> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<!-- 功能描述  --> | ||||||
|  | 			<el-col> | ||||||
|  | 				<el-form-item label="备注" prop="remark" :rules="[]"> | ||||||
|  | 					<el-input v-model="form.remark" :disabled="disabled" placeholder="请输入备注"></el-input> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
| 		<el-row :gutter="20"> | 		<el-row :gutter="20"> | ||||||
| 			<!-- 上传资料  --> | 			<!-- 上传资料  --> | ||||||
| 			<el-col> | 			<el-col> | ||||||
| @ -177,10 +137,7 @@ | |||||||
| 			<!-- 上传图片  --> | 			<!-- 上传图片  --> | ||||||
| 			<el-col> | 			<el-col> | ||||||
| 				<el-form-item label="上传图片" prop="pics" :rules="[]"> | 				<el-form-item label="上传图片" prop="pics" :rules="[]"> | ||||||
| 					<AssetsUpload | 					<AssetsUpload :is-pic-mode="true" v-model="form.pics" :disabled="disabled" /> | ||||||
| 						:is-pic-mode="true" |  | ||||||
| 						v-model="form.pics" |  | ||||||
| 						:disabled="disabled" /> |  | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 			</el-col> | 			</el-col> | ||||||
| 		</el-row> | 		</el-row> | ||||||
| @ -229,6 +186,7 @@ export default { | |||||||
| 				equipmentTypeId: '', | 				equipmentTypeId: '', | ||||||
| 				remark: '', | 				remark: '', | ||||||
| 				productionTime: '', | 				productionTime: '', | ||||||
|  | 				workTime: '', | ||||||
| 				enterTime: '', | 				enterTime: '', | ||||||
| 				tvalue: '', | 				tvalue: '', | ||||||
| 				processingTime: '', | 				processingTime: '', | ||||||
| @ -283,7 +241,7 @@ export default { | |||||||
| 		async getEqTypeList() { | 		async getEqTypeList() { | ||||||
| 			this.formLoading = true; | 			this.formLoading = true; | ||||||
| 			const { code, data } = await this.$axios( | 			const { code, data } = await this.$axios( | ||||||
| 				'/base/equipment-type/page?pageNo=1&pageSize=100' | 				'/base/core-equipment-type/page?pageNo=1&pageSize=100' | ||||||
| 			); | 			); | ||||||
| 			// debugger; | 			// debugger; | ||||||
| 			if (code == 0) { | 			if (code == 0) { | ||||||
| @ -305,16 +263,9 @@ export default { | |||||||
| 			return response.data; | 			return response.data; | ||||||
| 		}, | 		}, | ||||||
| 		// 上传成功的特殊处理 | 		// 上传成功的特殊处理 | ||||||
| 		beforeUpload() {}, | 		beforeUpload() { }, | ||||||
| 		// 上传前的验证规则可通过 bind 属性传入 | 		// 上传前的验证规则可通过 bind 属性传入 | ||||||
| 		handleUploadSuccess(response, file, fileList) { | 		handleUploadSuccess(response, file, fileList) { | ||||||
| 			console.log( |  | ||||||
| 				'[dialogForm:handleUploadSuccess]', |  | ||||||
| 				response, |  | ||||||
| 				file, |  | ||||||
| 				fileList, |  | ||||||
| 				this.form |  | ||||||
| 			); |  | ||||||
| 			// 保存原始文件名 | 			// 保存原始文件名 | ||||||
| 			if ('fileNames' in this.form) this.form.fileNames.push(file.name); | 			if ('fileNames' in this.form) this.form.fileNames.push(file.name); | ||||||
| 			// 保存完整地址 | 			// 保存完整地址 | ||||||
| @ -1,113 +1,75 @@ | |||||||
| <template> | <template> | ||||||
| 	<div class="app-container"> | 	<div class="app-container"> | ||||||
| 		<!-- 搜索工作栏 --> | 		<!-- 搜索工作栏 --> | ||||||
| 		<SearchBar | 		<SearchBar :formConfigs="searchBarFormConfig" ref="search-bar" @headBtnClick="handleSearchBarBtnClick" /> | ||||||
| 			:formConfigs="searchBarFormConfig" |  | ||||||
| 			ref="search-bar" |  | ||||||
| 			@headBtnClick="handleSearchBarBtnClick" /> |  | ||||||
| 
 | 
 | ||||||
| 		<!-- 列表 --> | 		<!-- 列表 --> | ||||||
| 		<base-table | 		<base-table :table-props="tableProps" :page="queryParams.pageNo" :limit="queryParams.pageSize" :table-data="list" | ||||||
| 			:table-props="tableProps" |  | ||||||
| 			:page="queryParams.pageNo" |  | ||||||
| 			:limit="queryParams.pageSize" |  | ||||||
| 			:table-data="list" |  | ||||||
| 			@emitFun="handleEmitFun"> | 			@emitFun="handleEmitFun"> | ||||||
| 			<method-btn | 			<method-btn v-if="tableBtn.length" slot="handleBtn" :width="120" label="操作" :method-list="tableBtn" | ||||||
| 				v-if="tableBtn.length" |  | ||||||
| 				slot="handleBtn" |  | ||||||
| 				:width="120" |  | ||||||
| 				label="操作" |  | ||||||
| 				:method-list="tableBtn" |  | ||||||
| 				@clickBtn="handleTableBtnClick" /> | 				@clickBtn="handleTableBtnClick" /> | ||||||
| 		</base-table> | 		</base-table> | ||||||
| 
 | 
 | ||||||
| 		<!-- 分页组件 --> | 		<!-- 分页组件 --> | ||||||
| 		<pagination | 		<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" | ||||||
| 			v-show="total > 0" |  | ||||||
| 			:total="total" |  | ||||||
| 			:page.sync="queryParams.pageNo" |  | ||||||
| 			:limit.sync="queryParams.pageSize" |  | ||||||
| 			@pagination="getList" /> | 			@pagination="getList" /> | ||||||
| 
 | 
 | ||||||
| 		<!-- 对话框(添加) --> | 		<!-- 对话框(添加) --> | ||||||
| 		<base-dialog | 		<base-dialog :dialogTitle="title" :dialogVisible="open" @close="cancel" @cancel="cancel" width="60%" | ||||||
| 			:dialogTitle="title" |  | ||||||
| 			:dialogVisible="open" |  | ||||||
| 			@close="cancel" |  | ||||||
| 			@cancel="cancel" |  | ||||||
| 			width="60%" |  | ||||||
| 			@confirm="submitForm"> | 			@confirm="submitForm"> | ||||||
| 			<DialogForm | 			<DialogForm v-if="open" key="index-dialog-form" ref="form" label-position="top" size="small" :dataForm="form" | ||||||
| 				v-if="open" |  | ||||||
| 				key="index-dialog-form" |  | ||||||
| 				ref="form" |  | ||||||
| 				label-position="top" |  | ||||||
| 				size="small" |  | ||||||
| 				:dataForm="form" |  | ||||||
| 				:rows="computedRows" /> | 				:rows="computedRows" /> | ||||||
| 		</base-dialog> | 		</base-dialog> | ||||||
| 
 | 
 | ||||||
| 		<!-- 设备 详情 - 编辑 --> | 		<!-- 设备 详情 - 编辑 --> | ||||||
| 		<EquipmentDrawer | 		<EquipmentDrawer v-if="editVisible" ref="drawer" :mode="editMode" @update-mode="editMode = $event" | ||||||
| 			v-if="editVisible" | 			:data-id="form.id" :sections="[ | ||||||
| 			ref="drawer" |  | ||||||
| 			:mode="editMode" |  | ||||||
| 			@update-mode="editMode = $event" |  | ||||||
| 			:data-id="form.id" |  | ||||||
| 			:sections="[ |  | ||||||
| 				{ | 				{ | ||||||
| 					name: '基本信息', | 					name: '基本信息', | ||||||
| 					key: 'base', | 					key: 'base', | ||||||
| 					rows: computedRows, | 					rows: computedRows, | ||||||
| 					url: '/base/equipment/get', | 					url: '/base/core-equipment/get', | ||||||
| 					urlUpdate: '/base/equipment/update', | 					urlUpdate: '/base/core-equipment/update', | ||||||
| 					urlCreate: '/base/equipment/create', | 					urlCreate: '/base/core-equipment/create', | ||||||
| 					queryParams: { id: form.id }, | 					queryParams: { id: form.id }, | ||||||
| 				}, | 				}, | ||||||
| 				{ | 				{ | ||||||
| 					name: '属性列表', | 					name: '属性列表', | ||||||
| 					key: 'attrs', | 					key: 'attrs', | ||||||
| 					props: drawerListProps, | 					props: drawerListProps, | ||||||
| 					url: '/base/equipment-attr/page', | 					url: '/base/core-equipment-attr/page', | ||||||
| 					urlCreate: '/base/equipment-attr/create', | 					urlCreate: '/base/core-equipment-attr/create', | ||||||
| 					urlUpdate: '/base/equipment-attr/update', | 					urlUpdate: '/base/core-equipment-attr/update', | ||||||
| 					urlDelete: '/base/equipment-attr/delete', | 					urlDelete: '/base/core-equipment-attr/delete', | ||||||
| 					urlDetail: '/base/equipment-attr/get', | 					urlDetail: '/base/core-equipment-attr/get', | ||||||
| 					queryParams: { | 					queryParams: { | ||||||
| 						equipmentId: form.id, | 						equipmentId: form.id, | ||||||
| 						pageNo: 1, | 						pageNo: 1, | ||||||
| 						pageSize: 10, | 						pageSize: 10, | ||||||
| 					}, | 					}, | ||||||
| 					tableBtn: [ | 					tableBtn: [ | ||||||
| 						this.$auth.hasPermi('base:equipment-attr:update') | 						this.$auth.hasPermi('base:core-equipment-attr:update') | ||||||
| 							? { | 							? { | ||||||
| 									type: 'edit', | 								type: 'edit', | ||||||
| 									btnName: '修改', | 								btnName: '修改', | ||||||
| 							  } | 							} | ||||||
| 							: undefined, | 							: undefined, | ||||||
| 						this.$auth.hasPermi('base:equipment-attr:delete') | 						this.$auth.hasPermi('base:core-equipment-attr:delete') | ||||||
| 							? { | 							? { | ||||||
| 									type: 'delete', | 								type: 'delete', | ||||||
| 									btnName: '删除', | 								btnName: '删除', | ||||||
| 							  } | 							} | ||||||
| 							: undefined, | 							: undefined, | ||||||
| 					].filter((v) => v), | 					].filter((v) => v), | ||||||
| 					allowAdd: true, | 					allowAdd: true, | ||||||
| 				}, | 				}, | ||||||
| 			]" | 			]" @refreshDataList="getList" @cancel="cancelEdit" @destroy="cancelEdit" /> | ||||||
| 			@refreshDataList="getList" |  | ||||||
| 			@cancel="cancelEdit" |  | ||||||
| 			@destroy="cancelEdit" /> |  | ||||||
| 	</div> | 	</div> | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import moment from 'moment'; | import moment from 'moment'; | ||||||
| import basicPageMixin from '@/mixins/lb/basicPageMixin'; | import basicPageMixin from '@/mixins/lb/basicPageMixin'; | ||||||
| import { getAccessToken } from '@/utils/auth'; |  | ||||||
| import EquipmentPics from './components/EquipmentPics'; |  | ||||||
| import EquipmentAssets from './components/EquipmentAssets'; |  | ||||||
| import EquipmentDrawer from './components/EquipmentDrawer'; | import EquipmentDrawer from './components/EquipmentDrawer'; | ||||||
| 
 | 
 | ||||||
| import { | import { | ||||||
| @ -132,23 +94,23 @@ export default { | |||||||
| 		return { | 		return { | ||||||
| 			searchBarKeys: ['name', 'code'], | 			searchBarKeys: ['name', 'code'], | ||||||
| 			tableBtn: [ | 			tableBtn: [ | ||||||
| 				this.$auth.hasPermi('base:equipment:update') | 				this.$auth.hasPermi(`base:core-equipment:update`) | ||||||
| 					? { | 					? { | ||||||
| 							type: 'edit', | 						type: 'detail', | ||||||
| 							btnName: '修改', | 						btnName: '详情', | ||||||
| 					  } | 					} | ||||||
| 					: undefined, | 					: undefined, | ||||||
| 				this.$auth.hasPermi('base:equipment:delete') | 				this.$auth.hasPermi('base:core-equipment:update') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'delete', | 						type: 'edit', | ||||||
| 							btnName: '删除', | 						btnName: '修改', | ||||||
| 					  } | 					} | ||||||
| 					: undefined, | 					: undefined, | ||||||
| 				this.$auth.hasPermi(`base:equipment:update`) | 				this.$auth.hasPermi('base:core-equipment:delete') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'detail', | 						type: 'delete', | ||||||
| 							btnName: '详情', | 						btnName: '删除', | ||||||
| 					  } | 					} | ||||||
| 					: undefined, | 					: undefined, | ||||||
| 			].filter((v) => v), | 			].filter((v) => v), | ||||||
| 			tableProps: [ | 			tableProps: [ | ||||||
| @ -214,18 +176,19 @@ export default { | |||||||
| 					type: 'separate', | 					type: 'separate', | ||||||
| 				}, | 				}, | ||||||
| 				{ | 				{ | ||||||
| 					type: this.$auth.hasPermi('base:equipment:create') ? 'button' : '', | 					type: this.$auth.hasPermi('base:core-equipment:export') ? 'button' : '', | ||||||
|  | 					btnName: '导出', | ||||||
|  | 					name: 'export', | ||||||
|  | 					plain: true, | ||||||
|  | 					color: 'primary', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: this.$auth.hasPermi('base:core-equipment:create') ? 'button' : '', | ||||||
| 					btnName: '新增', | 					btnName: '新增', | ||||||
| 					name: 'add', | 					name: 'add', | ||||||
| 					plain: true, | 					plain: true, | ||||||
| 					color: 'success', | 					color: 'success', | ||||||
| 				}, | 				}, | ||||||
| 				{ |  | ||||||
| 					type: this.$auth.hasPermi('base:equipment:export') ? 'button' : '', |  | ||||||
| 					btnName: '导出', |  | ||||||
| 					name: 'export', |  | ||||||
| 					color: 'warning', |  | ||||||
| 				}, |  | ||||||
| 			], | 			], | ||||||
| 			rows: [ | 			rows: [ | ||||||
| 				[ | 				[ | ||||||
| @ -242,7 +205,7 @@ export default { | |||||||
| 						input: true, | 						input: true, | ||||||
| 						label: '设备编码', | 						label: '设备编码', | ||||||
| 						prop: 'code', | 						prop: 'code', | ||||||
| 						url: '/base/equipment/getCode', | 						url: '/base/core-equipment/getCode', | ||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						input: true, | 						input: true, | ||||||
| @ -269,18 +232,32 @@ export default { | |||||||
| 						select: true, | 						select: true, | ||||||
| 						label: '设备类型', | 						label: '设备类型', | ||||||
| 						prop: 'equipmentTypeId', | 						prop: 'equipmentTypeId', | ||||||
| 						url: '/base/equipment-type/page?pageNo=1&pageSize=100', | 						url: '/base/core-equipment-type/page?pageNo=1&pageSize=100', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
| 						bind: { | 						bind: { | ||||||
| 							filterable: true, | 							filterable: true, | ||||||
| 						}, | 						}, | ||||||
| 					}, | 					}, | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '预计生产时间(min/天)', | ||||||
|  | 						prop: 'workTime', | ||||||
|  | 						rules: [ | ||||||
|  | 							{ required: true, message: '不能为空', trigger: 'blur' }, | ||||||
|  | 							{ | ||||||
|  | 								type: 'number', | ||||||
|  | 								message: '请输入正确的数字值', | ||||||
|  | 								trigger: 'blur', | ||||||
|  | 								transform: (val) => Number(val), | ||||||
|  | 							}, | ||||||
|  | 						], | ||||||
|  | 					}, | ||||||
| 					// { | 					// { | ||||||
| 					// 	select: true, | 					// 	select: true, | ||||||
| 					// 	label: '设备分组', | 					// 	label: '设备分组', | ||||||
| 					// 	prop: 'groupId', | 					// 	prop: 'groupId', | ||||||
| 					// 	url: '/base/equipment-group/page?pageNo=1&pageSize=100', | 					// 	url: '/base/core-equipment-group/page?pageNo=1&pageSize=100', | ||||||
| 					// }, | 					// }, | ||||||
| 					{ input: true, label: '备注', prop: 'remark' }, |  | ||||||
| 				], | 				], | ||||||
| 				[ | 				[ | ||||||
| 					{ | 					{ | ||||||
| @ -311,7 +288,7 @@ export default { | |||||||
| 				[ | 				[ | ||||||
| 					{ | 					{ | ||||||
| 						input: true, | 						input: true, | ||||||
| 						label: '产品加工时间(s)', | 						label: '产品加工时间(s)', | ||||||
| 						prop: 'processingTime', | 						prop: 'processingTime', | ||||||
| 						rules: [ | 						rules: [ | ||||||
| 							{ required: true, message: '不能为空', trigger: 'blur' }, | 							{ required: true, message: '不能为空', trigger: 'blur' }, | ||||||
| @ -332,7 +309,7 @@ export default { | |||||||
| 					}, | 					}, | ||||||
| 					{ | 					{ | ||||||
| 						input: true, | 						input: true, | ||||||
| 						label: '设备规格', | 						label: '规格描述', | ||||||
| 						prop: 'spec', | 						prop: 'spec', | ||||||
| 					}, | 					}, | ||||||
| 				], | 				], | ||||||
| @ -344,6 +321,9 @@ export default { | |||||||
| 						prop: 'description', | 						prop: 'description', | ||||||
| 					}, | 					}, | ||||||
| 				], | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ input: true, label: '备注', prop: 'remark' } | ||||||
|  | 				] | ||||||
| 				// [ | 				// [ | ||||||
| 				// 	{ | 				// 	{ | ||||||
| 				// 		assetUpload: true, | 				// 		assetUpload: true, | ||||||
| @ -455,36 +435,36 @@ export default { | |||||||
| 		computedRows() { | 		computedRows() { | ||||||
| 			return this.showUploadComponents | 			return this.showUploadComponents | ||||||
| 				? [ | 				? [ | ||||||
| 						...this.rows, | 					...this.rows, | ||||||
| 						[ | 					[ | ||||||
| 							{ | 						{ | ||||||
| 								assetUpload: true, | 							assetUpload: true, | ||||||
| 								key: 'eq-assets', // 用于区分不同的上传组件 | 							key: 'eq-assets', // 用于区分不同的上传组件 | ||||||
| 								label: '上传资料', | 							label: '上传资料', | ||||||
| 								fieldName: 'assets', | 							fieldName: 'assets', | ||||||
| 								subcomponent: AssetsUpload, | 							subcomponent: AssetsUpload, | ||||||
| 								prop: 'uploadedAssets', | 							prop: 'uploadedAssets', | ||||||
| 								default: [], | 							default: [], | ||||||
| 								bind: { | 							bind: { | ||||||
| 									'is-pic-mode': false, | 								'is-pic-mode': false, | ||||||
| 								}, |  | ||||||
| 							}, | 							}, | ||||||
| 						], | 						}, | ||||||
| 						[ | 					], | ||||||
| 							{ | 					[ | ||||||
| 								assetUpload: true, | 						{ | ||||||
| 								key: 'eq-pics', // 用于区分不同的上传组件 | 							assetUpload: true, | ||||||
| 								label: '上传图片', | 							key: 'eq-pics', // 用于区分不同的上传组件 | ||||||
| 								fieldName: 'images', | 							label: '上传图片', | ||||||
| 								subcomponent: AssetsUpload, | 							fieldName: 'images', | ||||||
| 								// prop: '', | 							subcomponent: AssetsUpload, | ||||||
| 								// default: [], | 							// prop: '', | ||||||
| 								bind: { | 							// default: [], | ||||||
| 									'is-pic-mode': true, | 							bind: { | ||||||
| 								}, | 								'is-pic-mode': true, | ||||||
| 							}, | 							}, | ||||||
| 						], | 						}, | ||||||
| 				  ] | 					], | ||||||
|  | 				] | ||||||
| 				: this.rows; | 				: this.rows; | ||||||
| 		}, | 		}, | ||||||
| 	}, | 	}, | ||||||
| @ -582,7 +562,7 @@ export default { | |||||||
| 					this.getList(); | 					this.getList(); | ||||||
| 					this.$modal.msgSuccess('删除成功'); | 					this.$modal.msgSuccess('删除成功'); | ||||||
| 				}) | 				}) | ||||||
| 				.catch(() => {}); | 				.catch(() => { }); | ||||||
| 		}, | 		}, | ||||||
| 		/** 导出按钮操作 */ | 		/** 导出按钮操作 */ | ||||||
| 		handleExport() { | 		handleExport() { | ||||||
| @ -600,7 +580,7 @@ export default { | |||||||
| 					this.$download.excel(response, '设备.xls'); | 					this.$download.excel(response, '设备.xls'); | ||||||
| 					this.exportLoading = false; | 					this.exportLoading = false; | ||||||
| 				}) | 				}) | ||||||
| 				.catch(() => {}); | 				.catch(() => { }); | ||||||
| 		}, | 		}, | ||||||
| 		// 查看详情 | 		// 查看详情 | ||||||
| 		viewDetail(id) { | 		viewDetail(id) { | ||||||
							
								
								
									
										360
									
								
								src/views/base/coreEquipmentLineBind/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,360 @@ | |||||||
|  | <template> | ||||||
|  | 	<div class="app-container"> | ||||||
|  | 		<!-- 搜索工作栏 --> | ||||||
|  | 		<SearchBar | ||||||
|  | 			:formConfigs="searchBarFormConfig" | ||||||
|  | 			ref="search-bar" | ||||||
|  | 			@headBtnClick="handleSearchBarBtnClick" /> | ||||||
|  | 
 | ||||||
|  | 		<!-- 列表 --> | ||||||
|  | 		<base-table | ||||||
|  | 			:table-props="tableProps" | ||||||
|  | 			:page="queryParams.pageNo" | ||||||
|  | 			:limit="queryParams.pageSize" | ||||||
|  | 			:table-data="list" | ||||||
|  | 			@emitFun="handleEmitFun"> | ||||||
|  | 			<method-btn | ||||||
|  | 				v-if="tableBtn.length" | ||||||
|  | 				slot="handleBtn" | ||||||
|  | 				label="操作" | ||||||
|  | 				:width="120" | ||||||
|  | 				:method-list="tableBtn" | ||||||
|  | 				@clickBtn="handleTableBtnClick" /> | ||||||
|  | 		</base-table> | ||||||
|  | 
 | ||||||
|  | 		<!-- 分页组件 --> | ||||||
|  | 		<pagination | ||||||
|  | 			v-show="total > 0" | ||||||
|  | 			:total="total" | ||||||
|  | 			:page.sync="queryParams.pageNo" | ||||||
|  | 			:limit.sync="queryParams.pageSize" | ||||||
|  | 			@pagination="getList" /> | ||||||
|  | 
 | ||||||
|  | 		<!-- 对话框(添加 / 修改) --> | ||||||
|  | 		<base-dialog | ||||||
|  | 			:dialogTitle="title" | ||||||
|  | 			:dialogVisible="open" | ||||||
|  | 			@close="cancel" | ||||||
|  | 			@cancel="cancel" | ||||||
|  | 			@confirm="submitForm"> | ||||||
|  | 			<DialogForm | ||||||
|  | 				v-if="open" | ||||||
|  | 				ref="form" | ||||||
|  | 				v-model="form" | ||||||
|  | 				:has-files="false" | ||||||
|  | 				:rows="rows" /> | ||||||
|  | 		</base-dialog> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import moment from 'moment'; | ||||||
|  | import basicPageMixin from '@/mixins/lb/basicPageMixin'; | ||||||
|  | 
 | ||||||
|  | // import { getAccessToken } from '@/utils/auth'; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	name: 'EquipmentLineBind', | ||||||
|  | 	components: {}, | ||||||
|  | 	mixins: [basicPageMixin], | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			basePath: '/base/core-equipment-bind-section', | ||||||
|  | 			searchBarKeys: ['equipmentName', 'productionLineId'], | ||||||
|  | 			tableBtn: [ | ||||||
|  | 				this.$auth.hasPermi('base:core-equipment-bind-section:update') | ||||||
|  | 					? { | ||||||
|  | 							type: 'edit', | ||||||
|  | 							btnName: '修改', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 				this.$auth.hasPermi('base:core-equipment-bind-section:delete') | ||||||
|  | 					? { | ||||||
|  | 							type: 'delete', | ||||||
|  | 							btnName: '删除', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 			].filter((v) => v), | ||||||
|  | 			tableProps: [ | ||||||
|  | 				{ | ||||||
|  | 					prop: 'createTime', | ||||||
|  | 					label: '添加时间', | ||||||
|  | 					fixed: true, | ||||||
|  | 					width: 180, | ||||||
|  | 					filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'), | ||||||
|  | 				}, | ||||||
|  | 				{ prop: 'productionLineName', label: '产线名称' }, | ||||||
|  | 				{ prop: 'workshopSectionName', label: '工段名称' }, | ||||||
|  | 				{ prop: 'equipmentName', label: '设备名称' }, | ||||||
|  | 				{ prop: 'sort', label: '工段中排序' }, | ||||||
|  | 				{ | ||||||
|  | 					prop: 'lineDataType', | ||||||
|  | 					label: '产线统计类型', | ||||||
|  | 					filter: (val) => | ||||||
|  | 						val != null ? ['无类型', '进片数量统计', '出片数量统计'][val] : '', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					prop: 'sectionDataType', | ||||||
|  | 					label: '工段统计类型', | ||||||
|  | 					filter: (val) => | ||||||
|  | 						val != null ? ['无类型', '进片数量统计', '出片数量统计'][val] : '', | ||||||
|  | 				}, | ||||||
|  | 				// { prop: 'remark', label: '备注' }, | ||||||
|  | 			], | ||||||
|  | 			searchBarFormConfig: [ | ||||||
|  | 				{ | ||||||
|  | 					type: 'select', | ||||||
|  | 					label: '产线', | ||||||
|  | 					placeholder: '请选择产线', | ||||||
|  | 					param: 'productionLineId', | ||||||
|  | 					selectOptions: [], | ||||||
|  | 					filterable: true, | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '设备名', | ||||||
|  | 					placeholder: '请输入设备名称', | ||||||
|  | 					param: 'equipmentName', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'button', | ||||||
|  | 					btnName: '查询', | ||||||
|  | 					name: 'search', | ||||||
|  | 					color: 'primary', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'separate', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: this.$auth.hasPermi('base:core-equipment-bind-section:create') | ||||||
|  | 						? 'button' | ||||||
|  | 						: '', | ||||||
|  | 					btnName: '新增', | ||||||
|  | 					name: 'add', | ||||||
|  | 					plain: true, | ||||||
|  | 					color: 'success', | ||||||
|  | 				}, | ||||||
|  | 				// { | ||||||
|  | 				// 	type: this.$auth.hasPermi('base:quality-inspection-type:export') | ||||||
|  | 				// 		? 'button' | ||||||
|  | 				// 		: '', | ||||||
|  | 				// 	btnName: '导出', | ||||||
|  | 				// 	name: 'export', | ||||||
|  | 				// 	color: 'warning', | ||||||
|  | 				// }, | ||||||
|  | 			], | ||||||
|  | 			rows: [ | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						select: true, | ||||||
|  | 						label: '产线', | ||||||
|  | 						prop: 'productionLineId', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 						url: '/base/core-production-line/listAll', | ||||||
|  | 						bind: { clearable: true, filterable: true }, | ||||||
|  | 						// watch: 'workshopSectionId' | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						select: true, | ||||||
|  | 						label: '工段', | ||||||
|  | 						prop: 'workshopSectionId', | ||||||
|  | 						depends: 'productionLineId', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 						bind: { clearable: true, filterable: true }, | ||||||
|  | 						url: '/base/core-workshop-section/listByParentId', | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						select: true, | ||||||
|  | 						label: '设备', | ||||||
|  | 						prop: 'equipmentId', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 						bind: { clearable: true, filterable: true }, | ||||||
|  | 						url: '/base/core-equipment/listAll', | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '工段排序', | ||||||
|  | 						prop: 'sort', | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						select: true, | ||||||
|  | 						options: [ | ||||||
|  | 							{ label: '无类型', value: 0 }, | ||||||
|  | 							{ label: '进片数量统计', value: 1 }, | ||||||
|  | 							{ label: '出片数量统计', value: 2 }, | ||||||
|  | 						], | ||||||
|  | 						label: '产线统计类型', | ||||||
|  | 						prop: 'lineDataType', | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						select: true, | ||||||
|  | 						options: [ | ||||||
|  | 							{ label: '无类型', value: 0 }, | ||||||
|  | 							{ label: '进片数量统计', value: 1 }, | ||||||
|  | 							{ label: '出片数量统计', value: 2 }, | ||||||
|  | 						], | ||||||
|  | 						label: '工段统计类型', | ||||||
|  | 						prop: 'sectionDataType', | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 			], | ||||||
|  | 			// 是否显示弹出层 | ||||||
|  | 			open: false, | ||||||
|  | 			// 查询参数 | ||||||
|  | 			queryParams: { | ||||||
|  | 				pageNo: 1, | ||||||
|  | 				pageSize: 10, | ||||||
|  | 				equipmentName: null, | ||||||
|  | 				productionLineId: null, | ||||||
|  | 			}, | ||||||
|  | 			// 表单参数 | ||||||
|  | 			form: {}, | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	created() { | ||||||
|  | 		this.initSearchOptions(); | ||||||
|  | 		this.getList(); | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		/** 初始化查询条件 */ | ||||||
|  | 		async initSearchOptions() { | ||||||
|  | 			this.http('/base/core-production-line/listAll', 'get').then( | ||||||
|  | 				({ code, data }) => { | ||||||
|  | 					if (code == 0) { | ||||||
|  | 						this.searchBarFormConfig[0].selectOptions = data.map((item) => { | ||||||
|  | 							return { | ||||||
|  | 								name: item.name, | ||||||
|  | 								id: item.id, | ||||||
|  | 							}; | ||||||
|  | 						}); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			); | ||||||
|  | 		}, | ||||||
|  | 		/** 查询列表 */ | ||||||
|  | 		getList() { | ||||||
|  | 			this.loading = true; | ||||||
|  | 			// 执行查询 | ||||||
|  | 			this.recv(this.queryParams).then(({ code, data }) => { | ||||||
|  | 				// if (code == 0) { | ||||||
|  | 				this.list = data.list; | ||||||
|  | 				this.total = data.total; | ||||||
|  | 				this.loading = false; | ||||||
|  | 				// } | ||||||
|  | 			}); | ||||||
|  | 			// .catch(err => { | ||||||
|  | 			// 	this.list = []; | ||||||
|  | 			// 	this.total = 0; | ||||||
|  | 			// 	this.loading = false; | ||||||
|  | 			// }) | ||||||
|  | 		}, | ||||||
|  | 		/** 取消按钮 */ | ||||||
|  | 		cancel() { | ||||||
|  | 			this.open = false; | ||||||
|  | 			this.reset(); | ||||||
|  | 		}, | ||||||
|  | 		/** 表单重置 */ | ||||||
|  | 		reset() { | ||||||
|  | 			this.form = { | ||||||
|  | 				id: undefined, | ||||||
|  | 				productionLineId: undefined, | ||||||
|  | 				// 工段 | ||||||
|  | 				workshopSectionId: undefined, | ||||||
|  | 				// 设备 | ||||||
|  | 				equipmentId: undefined, | ||||||
|  | 				// 工段排序 | ||||||
|  | 				sort: undefined, | ||||||
|  | 				// 产线统计类型 | ||||||
|  | 				lineDataType: undefined, | ||||||
|  | 				// 工段统计类型 | ||||||
|  | 				sectionDataType: undefined, | ||||||
|  | 			}; | ||||||
|  | 			this.resetForm('form'); | ||||||
|  | 		}, | ||||||
|  | 		/** 搜索按钮操作 */ | ||||||
|  | 		handleQuery() { | ||||||
|  | 			this.queryParams.pageNo = 1; | ||||||
|  | 			this.getList(); | ||||||
|  | 		}, | ||||||
|  | 		/** 重置按钮操作 */ | ||||||
|  | 		resetQuery() { | ||||||
|  | 			this.resetForm('queryForm'); | ||||||
|  | 			this.handleQuery(); | ||||||
|  | 		}, | ||||||
|  | 		/** 新增按钮操作 */ | ||||||
|  | 		handleAdd() { | ||||||
|  | 			this.reset(); | ||||||
|  | 			this.open = true; | ||||||
|  | 			this.title = '添加设备工段绑定'; | ||||||
|  | 		}, | ||||||
|  | 		/** 修改按钮操作 */ | ||||||
|  | 		handleUpdate(row) { | ||||||
|  | 			this.reset(); | ||||||
|  | 			const id = row.id; | ||||||
|  | 			this.info({ id }).then(({ code, data }) => { | ||||||
|  | 				this.form = data; | ||||||
|  | 				this.open = true; | ||||||
|  | 				this.title = '修改设备工段绑定'; | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		/** 提交按钮 */ | ||||||
|  | 		submitForm() { | ||||||
|  | 			this.$refs['form'].validate((valid) => { | ||||||
|  | 				if (!valid) { | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				// 修改的提交 | ||||||
|  | 				if (this.form.id != null) { | ||||||
|  | 					this.put(this.form).then(({ code, data }) => { | ||||||
|  | 						this.$modal.msgSuccess('修改成功'); | ||||||
|  | 						this.open = false; | ||||||
|  | 						this.getList(); | ||||||
|  | 					}); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				this.post(this.form).then(({ code, data }) => { | ||||||
|  | 					this.$modal.msgSuccess('修改成功'); | ||||||
|  | 					this.open = false; | ||||||
|  | 					this.getList(); | ||||||
|  | 				}); | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		/** 删除按钮操作 */ | ||||||
|  | 		handleDelete(row) { | ||||||
|  | 			const id = row.id; | ||||||
|  | 			this.$modal | ||||||
|  | 				.confirm('是否确认删除绑定"' + row.name + '"?') | ||||||
|  | 				.then(function () { | ||||||
|  | 					return deleteEquipmentType(id); | ||||||
|  | 				}) | ||||||
|  | 				.then(() => { | ||||||
|  | 					this.getList(); | ||||||
|  | 					this.$modal.msgSuccess('删除成功'); | ||||||
|  | 				}) | ||||||
|  | 				.catch(() => {}); | ||||||
|  | 		}, | ||||||
|  | 		/** 导出按钮操作 */ | ||||||
|  | 		handleExport() { | ||||||
|  | 			// 处理查询参数 | ||||||
|  | 			let params = { ...this.queryParams }; | ||||||
|  | 			params.pageNo = undefined; | ||||||
|  | 			params.pageSize = undefined; | ||||||
|  | 			this.$modal | ||||||
|  | 				.confirm('是否确认导出所有设备工段绑定?') | ||||||
|  | 				.then(() => { | ||||||
|  | 					this.exportLoading = true; | ||||||
|  | 					// return exportEquipmentTypeExcel(params); | ||||||
|  | 				}) | ||||||
|  | 				.then((response) => { | ||||||
|  | 					this.$download.excel(response, '设备工段绑定.xls'); | ||||||
|  | 					this.exportLoading = false; | ||||||
|  | 				}) | ||||||
|  | 				.catch(() => {}); | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
| @ -37,7 +37,12 @@ | |||||||
| 			@close="cancel" | 			@close="cancel" | ||||||
| 			@cancel="cancel" | 			@cancel="cancel" | ||||||
| 			@confirm="submitForm"> | 			@confirm="submitForm"> | ||||||
| 			<DialogForm v-if="open" ref="form" v-model="form" :rows="rows" /> | 			<DialogForm | ||||||
|  | 				v-if="open" | ||||||
|  | 				ref="form" | ||||||
|  | 				v-model="form" | ||||||
|  | 				:has-files="true" | ||||||
|  | 				:rows="rows" /> | ||||||
| 		</base-dialog> | 		</base-dialog> | ||||||
| 	</div> | 	</div> | ||||||
| </template> | </template> | ||||||
| @ -65,13 +70,13 @@ export default { | |||||||
| 		return { | 		return { | ||||||
| 			searchBarKeys: ['name'], | 			searchBarKeys: ['name'], | ||||||
| 			tableBtn: [ | 			tableBtn: [ | ||||||
| 				this.$auth.hasPermi('base:equipment-type:update') | 				this.$auth.hasPermi('base:core-equipment-type:update') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'edit', | 							type: 'edit', | ||||||
| 							btnName: '修改', | 							btnName: '修改', | ||||||
| 					  } | 					  } | ||||||
| 					: undefined, | 					: undefined, | ||||||
| 				this.$auth.hasPermi('base:equipment-type:delete') | 				this.$auth.hasPermi('base:core-equipment-type:delete') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'delete', | 							type: 'delete', | ||||||
| 							btnName: '删除', | 							btnName: '删除', | ||||||
| @ -107,7 +112,7 @@ export default { | |||||||
| 					type: 'separate', | 					type: 'separate', | ||||||
| 				}, | 				}, | ||||||
| 				{ | 				{ | ||||||
| 					type: this.$auth.hasPermi('base:equipment-type:create') | 					type: this.$auth.hasPermi('base:core-equipment-type:create') | ||||||
| 						? 'button' | 						? 'button' | ||||||
| 						: '', | 						: '', | ||||||
| 					btnName: '新增', | 					btnName: '新增', | ||||||
| @ -139,7 +144,7 @@ export default { | |||||||
| 						input: true, | 						input: true, | ||||||
| 						label: '设备类型编码', | 						label: '设备类型编码', | ||||||
| 						prop: 'code', | 						prop: 'code', | ||||||
| 						url: '/base/equipment-type/getCode', | 						url: '/base/core-equipment-type/getCode', | ||||||
| 					}, | 					}, | ||||||
| 				], | 				], | ||||||
| 				[ | 				[ | ||||||
| @ -147,7 +152,7 @@ export default { | |||||||
| 						select: true, | 						select: true, | ||||||
| 						label: '父类', | 						label: '父类', | ||||||
| 						prop: 'parentId', | 						prop: 'parentId', | ||||||
| 						url: '/base/equipment-type/page?pageNo=1&pageSize=100', | 						url: '/base/core-equipment-type/page?pageNo=1&pageSize=100', | ||||||
| 					}, | 					}, | ||||||
| 					{}, | 					{}, | ||||||
| 				], | 				], | ||||||
| @ -207,8 +212,6 @@ export default { | |||||||
| 				name: undefined, | 				name: undefined, | ||||||
| 				parentId: undefined, | 				parentId: undefined, | ||||||
| 				remark: undefined, | 				remark: undefined, | ||||||
| 				fileNames: [], |  | ||||||
| 				fileUrls: [], |  | ||||||
| 			}; | 			}; | ||||||
| 			this.resetForm('form'); | 			this.resetForm('form'); | ||||||
| 		}, | 		}, | ||||||
| @ -234,25 +237,6 @@ export default { | |||||||
| 			const id = row.id; | 			const id = row.id; | ||||||
| 			getEquipmentType(id).then((response) => { | 			getEquipmentType(id).then((response) => { | ||||||
| 				this.form = response.data; | 				this.form = response.data; | ||||||
| 				// this.form = { |  | ||||||
| 				// 	code: 'SBLX20230925184444000041', |  | ||||||
| 				// 	name: '测试131', |  | ||||||
| 				// 	remark: '测试可删除', |  | ||||||
| 				// 	id: '1706258479729336322', |  | ||||||
| 				// 	files: [ |  | ||||||
| 				// 		{ fileName: '1.png', fileUrl: '', fileType: 2 }, |  | ||||||
| 				// 		{ fileName: '1.asdfaslkjfkasdf.png', fileUrl: '', fileType: 2 }, |  | ||||||
| 				// 		{ fileName: '2.txt', fileUrl: '', fileType: 2 }, |  | ||||||
| 				// 		{ fileName: '1.rar', fileUrl: '', fileType: 2 }, |  | ||||||
| 				// 		{ fileName: '1.kkk', fileUrl: '', fileType: 2 }, |  | ||||||
| 				// 		{ fileName: 'test.file', fileUrl: '', fileType: 2 }, |  | ||||||
| 				// 		{ fileName: '222', fileUrl: '', fileType: 2 }, |  | ||||||
| 				// 		{ fileName: 'g', fileUrl: '', fileType: 2 }, |  | ||||||
| 				// 	], |  | ||||||
| 				// 	createTime: 1695638697000, |  | ||||||
| 				// 	parentId: '1701869972319584257', |  | ||||||
| 				// }; |  | ||||||
| 				// debugger; |  | ||||||
| 				this.open = true; | 				this.open = true; | ||||||
| 				this.title = '修改设备类型'; | 				this.title = '修改设备类型'; | ||||||
| 			}); | 			}); | ||||||
| @ -1,214 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="app-container"> |  | ||||||
| 
 |  | ||||||
|     <!-- 搜索工作栏 --> |  | ||||||
|     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |  | ||||||
|       <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|         <el-input v-model="queryParams.equipmentId" placeholder="请输入设备id" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item> |  | ||||||
|         <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button> |  | ||||||
|         <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button> |  | ||||||
|       </el-form-item> |  | ||||||
|     </el-form> |  | ||||||
| 
 |  | ||||||
|     <!-- 操作工具栏 --> |  | ||||||
|     <el-row :gutter="10" class="mb8"> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" |  | ||||||
|                    v-hasPermi="['base:equipment-attr:create']">新增</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading" |  | ||||||
|                    v-hasPermi="['base:equipment-attr:export']">导出</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |  | ||||||
|     </el-row> |  | ||||||
| 
 |  | ||||||
|     <!-- 列表 --> |  | ||||||
|     <el-table v-loading="loading" :data="list"> |  | ||||||
|       <el-table-column label="ID" align="center" prop="id" /> |  | ||||||
|       <el-table-column label="设备id" align="center" prop="equipmentId" /> |  | ||||||
|       <el-table-column label="属性名称" align="center" prop="name" /> |  | ||||||
|       <el-table-column label="属性值" align="center" prop="value" /> |  | ||||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.createTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-attr:update']">修改</el-button> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-attr:delete']">删除</el-button> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|     </el-table> |  | ||||||
|     <!-- 分页组件 --> |  | ||||||
|     <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" |  | ||||||
|                 @pagination="getList"/> |  | ||||||
| 
 |  | ||||||
|     <!-- 对话框(添加 / 修改) --> |  | ||||||
|     <el-dialog :title="title" :visible.sync="open" width="500px" v-dialogDrag append-to-body> |  | ||||||
|       <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |  | ||||||
|         <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|           <el-input v-model="form.equipmentId" placeholder="请输入设备id" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="属性名称" prop="name"> |  | ||||||
|           <el-input v-model="form.name" placeholder="请输入属性名称" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="属性值" prop="value"> |  | ||||||
|           <el-input v-model="form.value" placeholder="请输入属性值" /> |  | ||||||
|         </el-form-item> |  | ||||||
|       </el-form> |  | ||||||
|       <div slot="footer" class="dialog-footer"> |  | ||||||
|         <el-button type="primary" @click="submitForm">确 定</el-button> |  | ||||||
|         <el-button @click="cancel">取 消</el-button> |  | ||||||
|       </div> |  | ||||||
|     </el-dialog> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import { createEquipmentAttr, updateEquipmentAttr, deleteEquipmentAttr, getEquipmentAttr, getEquipmentAttrPage, exportEquipmentAttrExcel } from "@/api/base/equipmentAttr"; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|   name: "EquipmentAttr", |  | ||||||
|   components: { |  | ||||||
|   }, |  | ||||||
|   data() { |  | ||||||
|     return { |  | ||||||
|       // 遮罩层 |  | ||||||
|       loading: true, |  | ||||||
|       // 导出遮罩层 |  | ||||||
|       exportLoading: false, |  | ||||||
|       // 显示搜索条件 |  | ||||||
|       showSearch: true, |  | ||||||
|       // 总条数 |  | ||||||
|       total: 0, |  | ||||||
|       // 设备属性列表 |  | ||||||
|       list: [], |  | ||||||
|       // 弹出层标题 |  | ||||||
|       title: "", |  | ||||||
|       // 是否显示弹出层 |  | ||||||
|       open: false, |  | ||||||
|       // 查询参数 |  | ||||||
|       queryParams: { |  | ||||||
|         pageNo: 1, |  | ||||||
|         pageSize: 10, |  | ||||||
|         equipmentId: null, |  | ||||||
|       }, |  | ||||||
|       // 表单参数 |  | ||||||
|       form: {}, |  | ||||||
|       // 表单校验 |  | ||||||
|       rules: { |  | ||||||
|         equipmentId: [{ required: true, message: "设备id不能为空", trigger: "blur" }], |  | ||||||
|       } |  | ||||||
|     }; |  | ||||||
|   }, |  | ||||||
|   created() { |  | ||||||
|     this.getList(); |  | ||||||
|   }, |  | ||||||
|   methods: { |  | ||||||
|     /** 查询列表 */ |  | ||||||
|     getList() { |  | ||||||
|       this.loading = true; |  | ||||||
|       // 执行查询 |  | ||||||
|       getEquipmentAttrPage(this.queryParams).then(response => { |  | ||||||
|         this.list = response.data.list; |  | ||||||
|         this.total = response.data.total; |  | ||||||
|         this.loading = false; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 取消按钮 */ |  | ||||||
|     cancel() { |  | ||||||
|       this.open = false; |  | ||||||
|       this.reset(); |  | ||||||
|     }, |  | ||||||
|     /** 表单重置 */ |  | ||||||
|     reset() { |  | ||||||
|       this.form = { |  | ||||||
|         id: undefined, |  | ||||||
|         equipmentId: undefined, |  | ||||||
|         name: undefined, |  | ||||||
|         value: undefined, |  | ||||||
|       }; |  | ||||||
|       this.resetForm("form"); |  | ||||||
|     }, |  | ||||||
|     /** 搜索按钮操作 */ |  | ||||||
|     handleQuery() { |  | ||||||
|       this.queryParams.pageNo = 1; |  | ||||||
|       this.getList(); |  | ||||||
|     }, |  | ||||||
|     /** 重置按钮操作 */ |  | ||||||
|     resetQuery() { |  | ||||||
|       this.resetForm("queryForm"); |  | ||||||
|       this.handleQuery(); |  | ||||||
|     }, |  | ||||||
|     /** 新增按钮操作 */ |  | ||||||
|     handleAdd() { |  | ||||||
|       this.reset(); |  | ||||||
|       this.open = true; |  | ||||||
|       this.title = "添加设备属性"; |  | ||||||
|     }, |  | ||||||
|     /** 修改按钮操作 */ |  | ||||||
|     handleUpdate(row) { |  | ||||||
|       this.reset(); |  | ||||||
|       const id = row.id; |  | ||||||
|       getEquipmentAttr(id).then(response => { |  | ||||||
|         this.form = response.data; |  | ||||||
|         this.open = true; |  | ||||||
|         this.title = "修改设备属性"; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 提交按钮 */ |  | ||||||
|     submitForm() { |  | ||||||
|       this.$refs["form"].validate(valid => { |  | ||||||
|         if (!valid) { |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 修改的提交 |  | ||||||
|         if (this.form.id != null) { |  | ||||||
|           updateEquipmentAttr(this.form).then(response => { |  | ||||||
|             this.$modal.msgSuccess("修改成功"); |  | ||||||
|             this.open = false; |  | ||||||
|             this.getList(); |  | ||||||
|           }); |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 添加的提交 |  | ||||||
|         createEquipmentAttr(this.form).then(response => { |  | ||||||
|           this.$modal.msgSuccess("新增成功"); |  | ||||||
|           this.open = false; |  | ||||||
|           this.getList(); |  | ||||||
|         }); |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 删除按钮操作 */ |  | ||||||
|     handleDelete(row) { |  | ||||||
|       const id = row.id; |  | ||||||
|       this.$modal.confirm('是否确认删除设备属性编号为"' + id + '"的数据项?').then(function() { |  | ||||||
|           return deleteEquipmentAttr(id); |  | ||||||
|         }).then(() => { |  | ||||||
|           this.getList(); |  | ||||||
|           this.$modal.msgSuccess("删除成功"); |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     }, |  | ||||||
|     /** 导出按钮操作 */ |  | ||||||
|     handleExport() { |  | ||||||
|       // 处理查询参数 |  | ||||||
|       let params = {...this.queryParams}; |  | ||||||
|       params.pageNo = undefined; |  | ||||||
|       params.pageSize = undefined; |  | ||||||
|       this.$modal.confirm('是否确认导出所有设备属性数据项?').then(() => { |  | ||||||
|           this.exportLoading = true; |  | ||||||
|           return exportEquipmentAttrExcel(params); |  | ||||||
|         }).then(response => { |  | ||||||
|           this.$download.excel(response, '设备属性.xls'); |  | ||||||
|           this.exportLoading = false; |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
| @ -191,7 +191,7 @@ export default { | |||||||
| 		// 获取设备列表 | 		// 获取设备列表 | ||||||
| 		async getEquipmentList() { | 		async getEquipmentList() { | ||||||
| 			const response = await this.$axios( | 			const response = await this.$axios( | ||||||
| 				'/base/equipment/page?pageNo=1&pageSize=100' | 				'/base/core-equipment/page?pageNo=1&pageSize=100' | ||||||
| 			); | 			); | ||||||
| 			this.equipmentList = response.data.list.map((item) => ({ | 			this.equipmentList = response.data.list.map((item) => ({ | ||||||
| 				label: item.name, | 				label: item.name, | ||||||
|  | |||||||
| @ -192,7 +192,7 @@ export default { | |||||||
| 					{ | 					{ | ||||||
| 						select: true, | 						select: true, | ||||||
| 						label: '设备', | 						label: '设备', | ||||||
| 						url: '/base/equipment/page?pageNo=1&pageSize=100', | 						url: '/base/core-equipment/page?pageNo=1&pageSize=100', | ||||||
| 						prop: 'equipmentId', | 						prop: 'equipmentId', | ||||||
| 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
| 					}, | 					}, | ||||||
|  | |||||||
| @ -1,225 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="app-container"> |  | ||||||
| 
 |  | ||||||
|     <!-- 搜索工作栏 --> |  | ||||||
|     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |  | ||||||
|       <el-form-item label="设备ID" prop="equipmentId"> |  | ||||||
|         <el-input v-model="queryParams.equipmentId" placeholder="请输入设备ID" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item> |  | ||||||
|         <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button> |  | ||||||
|         <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button> |  | ||||||
|       </el-form-item> |  | ||||||
|     </el-form> |  | ||||||
| 
 |  | ||||||
|     <!-- 操作工具栏 --> |  | ||||||
|     <el-row :gutter="10" class="mb8"> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" |  | ||||||
|                    v-hasPermi="['base:equipment-file:create']">新增</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading" |  | ||||||
|                    v-hasPermi="['base:equipment-file:export']">导出</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |  | ||||||
|     </el-row> |  | ||||||
| 
 |  | ||||||
|     <!-- 列表 --> |  | ||||||
|     <el-table v-loading="loading" :data="list"> |  | ||||||
|       <el-table-column label="id" align="center" prop="id" /> |  | ||||||
|       <el-table-column label="设备ID" align="center" prop="equipmentId" /> |  | ||||||
|       <el-table-column label="文件类型 1.图片 2.设备资料" align="center" prop="fileType"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <dict-tag :type="DICT_TYPE.EQU_FILE_TYPE" :value="scope.row.fileType" /> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="原始文件名" align="center" prop="fileName" /> |  | ||||||
|       <el-table-column label="文件url" align="center" prop="fileUrl" /> |  | ||||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.createTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-file:update']">修改</el-button> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-file:delete']">删除</el-button> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|     </el-table> |  | ||||||
|     <!-- 分页组件 --> |  | ||||||
|     <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" |  | ||||||
|                 @pagination="getList"/> |  | ||||||
| 
 |  | ||||||
|     <!-- 对话框(添加 / 修改) --> |  | ||||||
|     <el-dialog :title="title" :visible.sync="open" width="500px" v-dialogDrag append-to-body> |  | ||||||
|       <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |  | ||||||
|         <el-form-item label="设备ID" prop="equipmentId"> |  | ||||||
|           <el-input v-model="form.equipmentId" placeholder="请输入设备ID" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="文件类型 1.图片 2.设备资料" prop="fileType"> |  | ||||||
|           <el-select v-model="form.fileType" placeholder="请选择文件类型 1.图片 2.设备资料"> |  | ||||||
|             <el-option v-for="dict in this.getDictDatas(DICT_TYPE.EQU_FILE_TYPE)" |  | ||||||
|                        :key="dict.value" :label="dict.label" :value="dict.value" /> |  | ||||||
|           </el-select> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="原始文件名" prop="fileName"> |  | ||||||
|           <el-input v-model="form.fileName" placeholder="请输入原始文件名" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="文件url" prop="fileUrl"> |  | ||||||
|           <el-input v-model="form.fileUrl" placeholder="请输入文件url" /> |  | ||||||
|         </el-form-item> |  | ||||||
|       </el-form> |  | ||||||
|       <div slot="footer" class="dialog-footer"> |  | ||||||
|         <el-button type="primary" @click="submitForm">确 定</el-button> |  | ||||||
|         <el-button @click="cancel">取 消</el-button> |  | ||||||
|       </div> |  | ||||||
|     </el-dialog> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import { createEquipmentFile, updateEquipmentFile, deleteEquipmentFile, getEquipmentFile, getEquipmentFilePage, exportEquipmentFileExcel } from "@/api/base/equipmentFile"; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|   name: "EquipmentFile", |  | ||||||
|   components: { |  | ||||||
|   }, |  | ||||||
|   data() { |  | ||||||
|     return { |  | ||||||
|       // 遮罩层 |  | ||||||
|       loading: true, |  | ||||||
|       // 导出遮罩层 |  | ||||||
|       exportLoading: false, |  | ||||||
|       // 显示搜索条件 |  | ||||||
|       showSearch: true, |  | ||||||
|       // 总条数 |  | ||||||
|       total: 0, |  | ||||||
|       // 设备文件对应列表 |  | ||||||
|       list: [], |  | ||||||
|       // 弹出层标题 |  | ||||||
|       title: "", |  | ||||||
|       // 是否显示弹出层 |  | ||||||
|       open: false, |  | ||||||
|       // 查询参数 |  | ||||||
|       queryParams: { |  | ||||||
|         pageNo: 1, |  | ||||||
|         pageSize: 10, |  | ||||||
|         equipmentId: null, |  | ||||||
|       }, |  | ||||||
|       // 表单参数 |  | ||||||
|       form: {}, |  | ||||||
|       // 表单校验 |  | ||||||
|       rules: { |  | ||||||
|       } |  | ||||||
|     }; |  | ||||||
|   }, |  | ||||||
|   created() { |  | ||||||
|     this.getList(); |  | ||||||
|   }, |  | ||||||
|   methods: { |  | ||||||
|     /** 查询列表 */ |  | ||||||
|     getList() { |  | ||||||
|       this.loading = true; |  | ||||||
|       // 执行查询 |  | ||||||
|       getEquipmentFilePage(this.queryParams).then(response => { |  | ||||||
|         this.list = response.data.list; |  | ||||||
|         this.total = response.data.total; |  | ||||||
|         this.loading = false; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 取消按钮 */ |  | ||||||
|     cancel() { |  | ||||||
|       this.open = false; |  | ||||||
|       this.reset(); |  | ||||||
|     }, |  | ||||||
|     /** 表单重置 */ |  | ||||||
|     reset() { |  | ||||||
|       this.form = { |  | ||||||
|         id: undefined, |  | ||||||
|         equipmentId: undefined, |  | ||||||
|         fileType: undefined, |  | ||||||
|         fileName: undefined, |  | ||||||
|         fileUrl: undefined, |  | ||||||
|       }; |  | ||||||
|       this.resetForm("form"); |  | ||||||
|     }, |  | ||||||
|     /** 搜索按钮操作 */ |  | ||||||
|     handleQuery() { |  | ||||||
|       this.queryParams.pageNo = 1; |  | ||||||
|       this.getList(); |  | ||||||
|     }, |  | ||||||
|     /** 重置按钮操作 */ |  | ||||||
|     resetQuery() { |  | ||||||
|       this.resetForm("queryForm"); |  | ||||||
|       this.handleQuery(); |  | ||||||
|     }, |  | ||||||
|     /** 新增按钮操作 */ |  | ||||||
|     handleAdd() { |  | ||||||
|       this.reset(); |  | ||||||
|       this.open = true; |  | ||||||
|       this.title = "添加设备文件对应"; |  | ||||||
|     }, |  | ||||||
|     /** 修改按钮操作 */ |  | ||||||
|     handleUpdate(row) { |  | ||||||
|       this.reset(); |  | ||||||
|       const id = row.id; |  | ||||||
|       getEquipmentFile(id).then(response => { |  | ||||||
|         this.form = response.data; |  | ||||||
|         this.open = true; |  | ||||||
|         this.title = "修改设备文件对应"; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 提交按钮 */ |  | ||||||
|     submitForm() { |  | ||||||
|       this.$refs["form"].validate(valid => { |  | ||||||
|         if (!valid) { |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 修改的提交 |  | ||||||
|         if (this.form.id != null) { |  | ||||||
|           updateEquipmentFile(this.form).then(response => { |  | ||||||
|             this.$modal.msgSuccess("修改成功"); |  | ||||||
|             this.open = false; |  | ||||||
|             this.getList(); |  | ||||||
|           }); |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 添加的提交 |  | ||||||
|         createEquipmentFile(this.form).then(response => { |  | ||||||
|           this.$modal.msgSuccess("新增成功"); |  | ||||||
|           this.open = false; |  | ||||||
|           this.getList(); |  | ||||||
|         }); |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 删除按钮操作 */ |  | ||||||
|     handleDelete(row) { |  | ||||||
|       const id = row.id; |  | ||||||
|       this.$modal.confirm('是否确认删除设备文件对应编号为"' + id + '"的数据项?').then(function() { |  | ||||||
|           return deleteEquipmentFile(id); |  | ||||||
|         }).then(() => { |  | ||||||
|           this.getList(); |  | ||||||
|           this.$modal.msgSuccess("删除成功"); |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     }, |  | ||||||
|     /** 导出按钮操作 */ |  | ||||||
|     handleExport() { |  | ||||||
|       // 处理查询参数 |  | ||||||
|       let params = {...this.queryParams}; |  | ||||||
|       params.pageNo = undefined; |  | ||||||
|       params.pageSize = undefined; |  | ||||||
|       this.$modal.confirm('是否确认导出所有设备文件对应数据项?').then(() => { |  | ||||||
|           this.exportLoading = true; |  | ||||||
|           return exportEquipmentFileExcel(params); |  | ||||||
|         }).then(response => { |  | ||||||
|           this.$download.excel(response, '设备文件对应.xls'); |  | ||||||
|           this.exportLoading = false; |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
| @ -247,7 +247,7 @@ export default { | |||||||
| 						select: true, | 						select: true, | ||||||
| 						label: '设备', | 						label: '设备', | ||||||
| 						prop: 'equipmentId', | 						prop: 'equipmentId', | ||||||
| 						url: '/base/equipment/page?pageNo=1&pageSize=99', | 						url: '/base/core-equipment/page?pageNo=1&pageSize=99', | ||||||
| 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
| 						bind: { | 						bind: { | ||||||
| 							filterable: true, | 							filterable: true, | ||||||
| @ -283,7 +283,7 @@ export default { | |||||||
| 						input: true, | 						input: true, | ||||||
| 						label: '关联表名', | 						label: '关联表名', | ||||||
| 						prop: 'plcTableName', | 						prop: 'plcTableName', | ||||||
| 						// url: '/base/equipment/getCode', | 						// url: '/base/core-equipment/getCode', | ||||||
| 					}, | 					}, | ||||||
| 				], | 				], | ||||||
| 			], | 			], | ||||||
| @ -320,7 +320,7 @@ export default { | |||||||
| 	methods: { | 	methods: { | ||||||
| 		async getEquipmentOptions() { | 		async getEquipmentOptions() { | ||||||
| 			const res = await this.$axios({ | 			const res = await this.$axios({ | ||||||
| 				url: '/base/equipment/listAll', | 				url: '/base/core-equipment/listAll', | ||||||
| 				method: 'get', | 				method: 'get', | ||||||
| 			}); | 			}); | ||||||
| 			return res.data; | 			return res.data; | ||||||
|  | |||||||
| @ -1,277 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="app-container"> |  | ||||||
| 
 |  | ||||||
|     <!-- 搜索工作栏 --> |  | ||||||
|     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |  | ||||||
|       <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|         <el-input v-model="queryParams.equipmentId" placeholder="请输入设备id" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="设备名称" prop="equipmentName"> |  | ||||||
|         <el-input v-model="queryParams.equipmentName" placeholder="请输入设备名称" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="进入设备的数量" prop="inQuantity"> |  | ||||||
|         <el-input v-model="queryParams.inQuantity" placeholder="请输入进入设备的数量" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="离开设备的数量,若plc只记录一个生产数量,也写入该字段" prop="outQuantity"> |  | ||||||
|         <el-input v-model="queryParams.outQuantity" placeholder="请输入离开设备的数量,若plc只记录一个生产数量,也写入该字段" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="正常生产量" prop="okQuantity"> |  | ||||||
|         <el-input v-model="queryParams.okQuantity" placeholder="请输入正常生产量" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="设备上报的报废数量" prop="nokQuantity"> |  | ||||||
|         <el-input v-model="queryParams.nokQuantity" placeholder="请输入设备上报的报废数量" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="生产数量的记录时间" prop="recordTime"> |  | ||||||
|         <el-date-picker v-model="queryParams.recordTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange" |  | ||||||
|                         range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" /> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="版本号" prop="version"> |  | ||||||
|         <el-input v-model="queryParams.version" placeholder="请输入版本号" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="创建时间" prop="createTime"> |  | ||||||
|         <el-date-picker v-model="queryParams.createTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange" |  | ||||||
|                         range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" /> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item> |  | ||||||
|         <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button> |  | ||||||
|         <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button> |  | ||||||
|       </el-form-item> |  | ||||||
|     </el-form> |  | ||||||
| 
 |  | ||||||
|     <!-- 操作工具栏 --> |  | ||||||
|     <el-row :gutter="10" class="mb8"> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" |  | ||||||
|                    v-hasPermi="['base:equipment-quantity-log:create']">新增</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading" |  | ||||||
|                    v-hasPermi="['base:equipment-quantity-log:export']">导出</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |  | ||||||
|     </el-row> |  | ||||||
| 
 |  | ||||||
|     <!-- 列表 --> |  | ||||||
|     <el-table v-loading="loading" :data="list"> |  | ||||||
|       <el-table-column label="id" align="center" prop="id" /> |  | ||||||
|       <el-table-column label="设备id" align="center" prop="equipmentId" /> |  | ||||||
|       <el-table-column label="设备名称" align="center" prop="equipmentName" /> |  | ||||||
|       <el-table-column label="进入设备的数量" align="center" prop="inQuantity" /> |  | ||||||
|       <el-table-column label="离开设备的数量,若plc只记录一个生产数量,也写入该字段" align="center" prop="outQuantity" /> |  | ||||||
|       <el-table-column label="正常生产量" align="center" prop="okQuantity" /> |  | ||||||
|       <el-table-column label="设备上报的报废数量" align="center" prop="nokQuantity" /> |  | ||||||
|       <el-table-column label="生产数量的记录时间" align="center" prop="recordTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.recordTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="版本号" align="center" prop="version" /> |  | ||||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.createTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-quantity-log:update']">修改</el-button> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-quantity-log:delete']">删除</el-button> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|     </el-table> |  | ||||||
|     <!-- 分页组件 --> |  | ||||||
|     <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" |  | ||||||
|                 @pagination="getList"/> |  | ||||||
| 
 |  | ||||||
|     <!-- 对话框(添加 / 修改) --> |  | ||||||
|     <el-dialog :title="title" :visible.sync="open" width="500px" v-dialogDrag append-to-body> |  | ||||||
|       <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |  | ||||||
|         <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|           <el-input v-model="form.equipmentId" placeholder="请输入设备id" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="设备名称" prop="equipmentName"> |  | ||||||
|           <el-input v-model="form.equipmentName" placeholder="请输入设备名称" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="进入设备的数量" prop="inQuantity"> |  | ||||||
|           <el-input v-model="form.inQuantity" placeholder="请输入进入设备的数量" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="离开设备的数量,若plc只记录一个生产数量,也写入该字段" prop="outQuantity"> |  | ||||||
|           <el-input v-model="form.outQuantity" placeholder="请输入离开设备的数量,若plc只记录一个生产数量,也写入该字段" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="正常生产量" prop="okQuantity"> |  | ||||||
|           <el-input v-model="form.okQuantity" placeholder="请输入正常生产量" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="设备上报的报废数量" prop="nokQuantity"> |  | ||||||
|           <el-input v-model="form.nokQuantity" placeholder="请输入设备上报的报废数量" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="生产数量的记录时间" prop="recordTime"> |  | ||||||
|           <el-date-picker clearable v-model="form.recordTime" type="date" value-format="timestamp" placeholder="选择生产数量的记录时间" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="版本号" prop="version"> |  | ||||||
|           <el-input v-model="form.version" placeholder="请输入版本号" /> |  | ||||||
|         </el-form-item> |  | ||||||
|       </el-form> |  | ||||||
|       <div slot="footer" class="dialog-footer"> |  | ||||||
|         <el-button type="primary" @click="submitForm">确 定</el-button> |  | ||||||
|         <el-button @click="cancel">取 消</el-button> |  | ||||||
|       </div> |  | ||||||
|     </el-dialog> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import { createEquipmentQuantityLog, updateEquipmentQuantityLog, deleteEquipmentQuantityLog, getEquipmentQuantityLog, getEquipmentQuantityLogPage, exportEquipmentQuantityLogExcel } from "@/api/base/equipmentQuantityLog"; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|   name: "EquipmentQuantityLog", |  | ||||||
|   components: { |  | ||||||
|   }, |  | ||||||
|   data() { |  | ||||||
|     return { |  | ||||||
|       // 遮罩层 |  | ||||||
|       loading: true, |  | ||||||
|       // 导出遮罩层 |  | ||||||
|       exportLoading: false, |  | ||||||
|       // 显示搜索条件 |  | ||||||
|       showSearch: true, |  | ||||||
|       // 总条数 |  | ||||||
|       total: 0, |  | ||||||
|       // 后端用 设备生产数量统计表(按一定时间段写入)列表 |  | ||||||
|       list: [], |  | ||||||
|       // 弹出层标题 |  | ||||||
|       title: "", |  | ||||||
|       // 是否显示弹出层 |  | ||||||
|       open: false, |  | ||||||
|       // 查询参数 |  | ||||||
|       queryParams: { |  | ||||||
|         pageNo: 1, |  | ||||||
|         pageSize: 10, |  | ||||||
|         equipmentId: null, |  | ||||||
|         equipmentName: null, |  | ||||||
|         inQuantity: null, |  | ||||||
|         outQuantity: null, |  | ||||||
|         okQuantity: null, |  | ||||||
|         nokQuantity: null, |  | ||||||
|         recordTime: [], |  | ||||||
|         version: null, |  | ||||||
|         createTime: [], |  | ||||||
|       }, |  | ||||||
|       // 表单参数 |  | ||||||
|       form: {}, |  | ||||||
|       // 表单校验 |  | ||||||
|       rules: { |  | ||||||
|         equipmentName: [{ required: true, message: "设备名称不能为空", trigger: "blur" }], |  | ||||||
|       } |  | ||||||
|     }; |  | ||||||
|   }, |  | ||||||
|   created() { |  | ||||||
|     this.getList(); |  | ||||||
|   }, |  | ||||||
|   methods: { |  | ||||||
|     /** 查询列表 */ |  | ||||||
|     getList() { |  | ||||||
|       this.loading = true; |  | ||||||
|       // 执行查询 |  | ||||||
|       getEquipmentQuantityLogPage(this.queryParams).then(response => { |  | ||||||
|         this.list = response.data.list; |  | ||||||
|         this.total = response.data.total; |  | ||||||
|         this.loading = false; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 取消按钮 */ |  | ||||||
|     cancel() { |  | ||||||
|       this.open = false; |  | ||||||
|       this.reset(); |  | ||||||
|     }, |  | ||||||
|     /** 表单重置 */ |  | ||||||
|     reset() { |  | ||||||
|       this.form = { |  | ||||||
|         id: undefined, |  | ||||||
|         equipmentId: undefined, |  | ||||||
|         equipmentName: undefined, |  | ||||||
|         inQuantity: undefined, |  | ||||||
|         outQuantity: undefined, |  | ||||||
|         okQuantity: undefined, |  | ||||||
|         nokQuantity: undefined, |  | ||||||
|         recordTime: undefined, |  | ||||||
|         version: undefined, |  | ||||||
|       }; |  | ||||||
|       this.resetForm("form"); |  | ||||||
|     }, |  | ||||||
|     /** 搜索按钮操作 */ |  | ||||||
|     handleQuery() { |  | ||||||
|       this.queryParams.pageNo = 1; |  | ||||||
|       this.getList(); |  | ||||||
|     }, |  | ||||||
|     /** 重置按钮操作 */ |  | ||||||
|     resetQuery() { |  | ||||||
|       this.resetForm("queryForm"); |  | ||||||
|       this.handleQuery(); |  | ||||||
|     }, |  | ||||||
|     /** 新增按钮操作 */ |  | ||||||
|     handleAdd() { |  | ||||||
|       this.reset(); |  | ||||||
|       this.open = true; |  | ||||||
|       this.title = "添加后端用 设备生产数量统计表(按一定时间段写入)"; |  | ||||||
|     }, |  | ||||||
|     /** 修改按钮操作 */ |  | ||||||
|     handleUpdate(row) { |  | ||||||
|       this.reset(); |  | ||||||
|       const id = row.id; |  | ||||||
|       getEquipmentQuantityLog(id).then(response => { |  | ||||||
|         this.form = response.data; |  | ||||||
|         this.open = true; |  | ||||||
|         this.title = "修改后端用 设备生产数量统计表(按一定时间段写入)"; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 提交按钮 */ |  | ||||||
|     submitForm() { |  | ||||||
|       this.$refs["form"].validate(valid => { |  | ||||||
|         if (!valid) { |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 修改的提交 |  | ||||||
|         if (this.form.id != null) { |  | ||||||
|           updateEquipmentQuantityLog(this.form).then(response => { |  | ||||||
|             this.$modal.msgSuccess("修改成功"); |  | ||||||
|             this.open = false; |  | ||||||
|             this.getList(); |  | ||||||
|           }); |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 添加的提交 |  | ||||||
|         createEquipmentQuantityLog(this.form).then(response => { |  | ||||||
|           this.$modal.msgSuccess("新增成功"); |  | ||||||
|           this.open = false; |  | ||||||
|           this.getList(); |  | ||||||
|         }); |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 删除按钮操作 */ |  | ||||||
|     handleDelete(row) { |  | ||||||
|       const id = row.id; |  | ||||||
|       this.$modal.confirm('是否确认删除后端用 设备生产数量统计表(按一定时间段写入)编号为"' + id + '"的数据项?').then(function() { |  | ||||||
|           return deleteEquipmentQuantityLog(id); |  | ||||||
|         }).then(() => { |  | ||||||
|           this.getList(); |  | ||||||
|           this.$modal.msgSuccess("删除成功"); |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     }, |  | ||||||
|     /** 导出按钮操作 */ |  | ||||||
|     handleExport() { |  | ||||||
|       // 处理查询参数 |  | ||||||
|       let params = {...this.queryParams}; |  | ||||||
|       params.pageNo = undefined; |  | ||||||
|       params.pageSize = undefined; |  | ||||||
|       this.$modal.confirm('是否确认导出所有后端用 设备生产数量统计表(按一定时间段写入)数据项?').then(() => { |  | ||||||
|           this.exportLoading = true; |  | ||||||
|           return exportEquipmentQuantityLogExcel(params); |  | ||||||
|         }).then(response => { |  | ||||||
|           this.$download.excel(response, '后端用 设备生产数量统计表(按一定时间段写入).xls'); |  | ||||||
|           this.exportLoading = false; |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
| @ -1,276 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="app-container"> |  | ||||||
| 
 |  | ||||||
|     <!-- 搜索工作栏 --> |  | ||||||
|     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |  | ||||||
|       <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|         <el-input v-model="queryParams.equipmentId" placeholder="请输入设备id" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="设备名称" prop="equipmentName"> |  | ||||||
|         <el-input v-model="queryParams.equipmentName" placeholder="请输入设备名称" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="进入设备的基板数量" prop="inQuantity"> |  | ||||||
|         <el-input v-model="queryParams.inQuantity" placeholder="请输入进入设备的基板数量" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="离开设备的基板数量,若plc只记录一个生产数量,也写入该字段" prop="outQuantity"> |  | ||||||
|         <el-input v-model="queryParams.outQuantity" placeholder="请输入离开设备的基板数量,若plc只记录一个生产数量,也写入该字段" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="正常生产量" prop="okQuantity"> |  | ||||||
|         <el-input v-model="queryParams.okQuantity" placeholder="请输入正常生产量" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="设备上报的报废数量" prop="nokQuantity"> |  | ||||||
|         <el-input v-model="queryParams.nokQuantity" placeholder="请输入设备上报的报废数量" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="记录时间" prop="recordTime"> |  | ||||||
|         <el-date-picker v-model="queryParams.recordTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange" |  | ||||||
|                         range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" /> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="版本号" prop="version"> |  | ||||||
|         <el-input v-model="queryParams.version" placeholder="请输入版本号" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="创建时间" prop="createTime"> |  | ||||||
|         <el-date-picker v-model="queryParams.createTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange" |  | ||||||
|                         range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" /> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item> |  | ||||||
|         <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button> |  | ||||||
|         <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button> |  | ||||||
|       </el-form-item> |  | ||||||
|     </el-form> |  | ||||||
| 
 |  | ||||||
|     <!-- 操作工具栏 --> |  | ||||||
|     <el-row :gutter="10" class="mb8"> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" |  | ||||||
|                    v-hasPermi="['base:equipment-quantity-realtime:create']">新增</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading" |  | ||||||
|                    v-hasPermi="['base:equipment-quantity-realtime:export']">导出</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |  | ||||||
|     </el-row> |  | ||||||
| 
 |  | ||||||
|     <!-- 列表 --> |  | ||||||
|     <el-table v-loading="loading" :data="list"> |  | ||||||
|       <el-table-column label="id" align="center" prop="id" /> |  | ||||||
|       <el-table-column label="设备id" align="center" prop="equipmentId" /> |  | ||||||
|       <el-table-column label="设备名称" align="center" prop="equipmentName" /> |  | ||||||
|       <el-table-column label="进入设备的基板数量" align="center" prop="inQuantity" /> |  | ||||||
|       <el-table-column label="离开设备的基板数量,若plc只记录一个生产数量,也写入该字段" align="center" prop="outQuantity" /> |  | ||||||
|       <el-table-column label="正常生产量" align="center" prop="okQuantity" /> |  | ||||||
|       <el-table-column label="设备上报的报废数量" align="center" prop="nokQuantity" /> |  | ||||||
|       <el-table-column label="记录时间" align="center" prop="recordTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.recordTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="版本号" align="center" prop="version" /> |  | ||||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.createTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-quantity-realtime:update']">修改</el-button> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-quantity-realtime:delete']">删除</el-button> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|     </el-table> |  | ||||||
|     <!-- 分页组件 --> |  | ||||||
|     <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" |  | ||||||
|                 @pagination="getList"/> |  | ||||||
| 
 |  | ||||||
|     <!-- 对话框(添加 / 修改) --> |  | ||||||
|     <el-dialog :title="title" :visible.sync="open" width="500px" v-dialogDrag append-to-body> |  | ||||||
|       <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |  | ||||||
|         <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|           <el-input v-model="form.equipmentId" placeholder="请输入设备id" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="设备名称" prop="equipmentName"> |  | ||||||
|           <el-input v-model="form.equipmentName" placeholder="请输入设备名称" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="进入设备的基板数量" prop="inQuantity"> |  | ||||||
|           <el-input v-model="form.inQuantity" placeholder="请输入进入设备的基板数量" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="离开设备的基板数量,若plc只记录一个生产数量,也写入该字段" prop="outQuantity"> |  | ||||||
|           <el-input v-model="form.outQuantity" placeholder="请输入离开设备的基板数量,若plc只记录一个生产数量,也写入该字段" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="正常生产量" prop="okQuantity"> |  | ||||||
|           <el-input v-model="form.okQuantity" placeholder="请输入正常生产量" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="设备上报的报废数量" prop="nokQuantity"> |  | ||||||
|           <el-input v-model="form.nokQuantity" placeholder="请输入设备上报的报废数量" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="记录时间" prop="recordTime"> |  | ||||||
|           <el-date-picker clearable v-model="form.recordTime" type="date" value-format="timestamp" placeholder="选择记录时间" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="版本号" prop="version"> |  | ||||||
|           <el-input v-model="form.version" placeholder="请输入版本号" /> |  | ||||||
|         </el-form-item> |  | ||||||
|       </el-form> |  | ||||||
|       <div slot="footer" class="dialog-footer"> |  | ||||||
|         <el-button type="primary" @click="submitForm">确 定</el-button> |  | ||||||
|         <el-button @click="cancel">取 消</el-button> |  | ||||||
|       </div> |  | ||||||
|     </el-dialog> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import { createEquipmentQuantityRealtime, updateEquipmentQuantityRealtime, deleteEquipmentQuantityRealtime, getEquipmentQuantityRealtime, getEquipmentQuantityRealtimePage, exportEquipmentQuantityRealtimeExcel } from "@/api/base/equipmentQuantityRealtime"; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|   name: "EquipmentQuantityRealtime", |  | ||||||
|   components: { |  | ||||||
|   }, |  | ||||||
|   data() { |  | ||||||
|     return { |  | ||||||
|       // 遮罩层 |  | ||||||
|       loading: true, |  | ||||||
|       // 导出遮罩层 |  | ||||||
|       exportLoading: false, |  | ||||||
|       // 显示搜索条件 |  | ||||||
|       showSearch: true, |  | ||||||
|       // 总条数 |  | ||||||
|       total: 0, |  | ||||||
|       // 后端用 设备生产数量实时列表 |  | ||||||
|       list: [], |  | ||||||
|       // 弹出层标题 |  | ||||||
|       title: "", |  | ||||||
|       // 是否显示弹出层 |  | ||||||
|       open: false, |  | ||||||
|       // 查询参数 |  | ||||||
|       queryParams: { |  | ||||||
|         pageNo: 1, |  | ||||||
|         pageSize: 10, |  | ||||||
|         equipmentId: null, |  | ||||||
|         equipmentName: null, |  | ||||||
|         inQuantity: null, |  | ||||||
|         outQuantity: null, |  | ||||||
|         okQuantity: null, |  | ||||||
|         nokQuantity: null, |  | ||||||
|         recordTime: [], |  | ||||||
|         version: null, |  | ||||||
|         createTime: [], |  | ||||||
|       }, |  | ||||||
|       // 表单参数 |  | ||||||
|       form: {}, |  | ||||||
|       // 表单校验 |  | ||||||
|       rules: { |  | ||||||
|       } |  | ||||||
|     }; |  | ||||||
|   }, |  | ||||||
|   created() { |  | ||||||
|     this.getList(); |  | ||||||
|   }, |  | ||||||
|   methods: { |  | ||||||
|     /** 查询列表 */ |  | ||||||
|     getList() { |  | ||||||
|       this.loading = true; |  | ||||||
|       // 执行查询 |  | ||||||
|       getEquipmentQuantityRealtimePage(this.queryParams).then(response => { |  | ||||||
|         this.list = response.data.list; |  | ||||||
|         this.total = response.data.total; |  | ||||||
|         this.loading = false; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 取消按钮 */ |  | ||||||
|     cancel() { |  | ||||||
|       this.open = false; |  | ||||||
|       this.reset(); |  | ||||||
|     }, |  | ||||||
|     /** 表单重置 */ |  | ||||||
|     reset() { |  | ||||||
|       this.form = { |  | ||||||
|         id: undefined, |  | ||||||
|         equipmentId: undefined, |  | ||||||
|         equipmentName: undefined, |  | ||||||
|         inQuantity: undefined, |  | ||||||
|         outQuantity: undefined, |  | ||||||
|         okQuantity: undefined, |  | ||||||
|         nokQuantity: undefined, |  | ||||||
|         recordTime: undefined, |  | ||||||
|         version: undefined, |  | ||||||
|       }; |  | ||||||
|       this.resetForm("form"); |  | ||||||
|     }, |  | ||||||
|     /** 搜索按钮操作 */ |  | ||||||
|     handleQuery() { |  | ||||||
|       this.queryParams.pageNo = 1; |  | ||||||
|       this.getList(); |  | ||||||
|     }, |  | ||||||
|     /** 重置按钮操作 */ |  | ||||||
|     resetQuery() { |  | ||||||
|       this.resetForm("queryForm"); |  | ||||||
|       this.handleQuery(); |  | ||||||
|     }, |  | ||||||
|     /** 新增按钮操作 */ |  | ||||||
|     handleAdd() { |  | ||||||
|       this.reset(); |  | ||||||
|       this.open = true; |  | ||||||
|       this.title = "添加后端用 设备生产数量实时"; |  | ||||||
|     }, |  | ||||||
|     /** 修改按钮操作 */ |  | ||||||
|     handleUpdate(row) { |  | ||||||
|       this.reset(); |  | ||||||
|       const id = row.id; |  | ||||||
|       getEquipmentQuantityRealtime(id).then(response => { |  | ||||||
|         this.form = response.data; |  | ||||||
|         this.open = true; |  | ||||||
|         this.title = "修改后端用 设备生产数量实时"; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 提交按钮 */ |  | ||||||
|     submitForm() { |  | ||||||
|       this.$refs["form"].validate(valid => { |  | ||||||
|         if (!valid) { |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 修改的提交 |  | ||||||
|         if (this.form.id != null) { |  | ||||||
|           updateEquipmentQuantityRealtime(this.form).then(response => { |  | ||||||
|             this.$modal.msgSuccess("修改成功"); |  | ||||||
|             this.open = false; |  | ||||||
|             this.getList(); |  | ||||||
|           }); |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 添加的提交 |  | ||||||
|         createEquipmentQuantityRealtime(this.form).then(response => { |  | ||||||
|           this.$modal.msgSuccess("新增成功"); |  | ||||||
|           this.open = false; |  | ||||||
|           this.getList(); |  | ||||||
|         }); |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 删除按钮操作 */ |  | ||||||
|     handleDelete(row) { |  | ||||||
|       const id = row.id; |  | ||||||
|       this.$modal.confirm('是否确认删除后端用 设备生产数量实时编号为"' + id + '"的数据项?').then(function() { |  | ||||||
|           return deleteEquipmentQuantityRealtime(id); |  | ||||||
|         }).then(() => { |  | ||||||
|           this.getList(); |  | ||||||
|           this.$modal.msgSuccess("删除成功"); |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     }, |  | ||||||
|     /** 导出按钮操作 */ |  | ||||||
|     handleExport() { |  | ||||||
|       // 处理查询参数 |  | ||||||
|       let params = {...this.queryParams}; |  | ||||||
|       params.pageNo = undefined; |  | ||||||
|       params.pageSize = undefined; |  | ||||||
|       this.$modal.confirm('是否确认导出所有后端用 设备生产数量实时数据项?').then(() => { |  | ||||||
|           this.exportLoading = true; |  | ||||||
|           return exportEquipmentQuantityRealtimeExcel(params); |  | ||||||
|         }).then(response => { |  | ||||||
|           this.$download.excel(response, '后端用 设备生产数量实时.xls'); |  | ||||||
|           this.exportLoading = false; |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
| @ -1,289 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="app-container"> |  | ||||||
| 
 |  | ||||||
|     <!-- 搜索工作栏 --> |  | ||||||
|     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |  | ||||||
|       <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|         <el-input v-model="queryParams.equipmentId" placeholder="请输入设备id" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="设备名称" prop="equipmentName"> |  | ||||||
|         <el-input v-model="queryParams.equipmentName" placeholder="请输入设备名称" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="plc id" prop="plcId"> |  | ||||||
|         <el-input v-model="queryParams.plcId" placeholder="请输入plc id" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="plc" prop="plc"> |  | ||||||
|         <el-input v-model="queryParams.plc" placeholder="请输入plc" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="状态,0正常 1计划停机 2故障" prop="status"> |  | ||||||
|         <el-select v-model="queryParams.status" placeholder="请选择状态,0正常 1计划停机 2故障" clearable size="small"> |  | ||||||
|           <el-option label="请选择字典生成" value="" /> |  | ||||||
|         </el-select> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="记录时间" prop="recordTime"> |  | ||||||
|         <el-date-picker v-model="queryParams.recordTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange" |  | ||||||
|                         range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" /> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="持续时间(分钟),状态变动时记录并更新" prop="duration"> |  | ||||||
|         <el-input v-model="queryParams.duration" placeholder="请输入持续时间(分钟),状态变动时记录并更新" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="备注" prop="remark"> |  | ||||||
|         <el-input v-model="queryParams.remark" placeholder="请输入备注" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="版本号" prop="version"> |  | ||||||
|         <el-input v-model="queryParams.version" placeholder="请输入版本号" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="创建时间" prop="createTime"> |  | ||||||
|         <el-date-picker v-model="queryParams.createTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange" |  | ||||||
|                         range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" /> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item> |  | ||||||
|         <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button> |  | ||||||
|         <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button> |  | ||||||
|       </el-form-item> |  | ||||||
|     </el-form> |  | ||||||
| 
 |  | ||||||
|     <!-- 操作工具栏 --> |  | ||||||
|     <el-row :gutter="10" class="mb8"> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" |  | ||||||
|                    v-hasPermi="['base:equipment-status-log:create']">新增</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading" |  | ||||||
|                    v-hasPermi="['base:equipment-status-log:export']">导出</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |  | ||||||
|     </el-row> |  | ||||||
| 
 |  | ||||||
|     <!-- 列表 --> |  | ||||||
|     <el-table v-loading="loading" :data="list"> |  | ||||||
|       <el-table-column label="id" align="center" prop="id" /> |  | ||||||
|       <el-table-column label="设备id" align="center" prop="equipmentId" /> |  | ||||||
|       <el-table-column label="设备名称" align="center" prop="equipmentName" /> |  | ||||||
|       <el-table-column label="plc id" align="center" prop="plcId" /> |  | ||||||
|       <el-table-column label="plc" align="center" prop="plc" /> |  | ||||||
|       <el-table-column label="状态,0正常 1计划停机 2故障" align="center" prop="status" /> |  | ||||||
|       <el-table-column label="记录时间" align="center" prop="recordTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.recordTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="持续时间(分钟),状态变动时记录并更新" align="center" prop="duration" /> |  | ||||||
|       <el-table-column label="备注" align="center" prop="remark" /> |  | ||||||
|       <el-table-column label="版本号" align="center" prop="version" /> |  | ||||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.createTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-status-log:update']">修改</el-button> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-status-log:delete']">删除</el-button> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|     </el-table> |  | ||||||
|     <!-- 分页组件 --> |  | ||||||
|     <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" |  | ||||||
|                 @pagination="getList"/> |  | ||||||
| 
 |  | ||||||
|     <!-- 对话框(添加 / 修改) --> |  | ||||||
|     <el-dialog :title="title" :visible.sync="open" width="500px" v-dialogDrag append-to-body> |  | ||||||
|       <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |  | ||||||
|         <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|           <el-input v-model="form.equipmentId" placeholder="请输入设备id" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="设备名称" prop="equipmentName"> |  | ||||||
|           <el-input v-model="form.equipmentName" placeholder="请输入设备名称" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="plc id" prop="plcId"> |  | ||||||
|           <el-input v-model="form.plcId" placeholder="请输入plc id" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="plc" prop="plc"> |  | ||||||
|           <el-input v-model="form.plc" placeholder="请输入plc" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="状态,0正常 1计划停机 2故障" prop="status"> |  | ||||||
|           <el-radio-group v-model="form.status"> |  | ||||||
|             <el-radio label="1">请选择字典生成</el-radio> |  | ||||||
|           </el-radio-group> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="记录时间" prop="recordTime"> |  | ||||||
|           <el-date-picker clearable v-model="form.recordTime" type="date" value-format="timestamp" placeholder="选择记录时间" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="持续时间(分钟),状态变动时记录并更新" prop="duration"> |  | ||||||
|           <el-input v-model="form.duration" placeholder="请输入持续时间(分钟),状态变动时记录并更新" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="备注" prop="remark"> |  | ||||||
|           <el-input v-model="form.remark" placeholder="请输入备注" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="版本号" prop="version"> |  | ||||||
|           <el-input v-model="form.version" placeholder="请输入版本号" /> |  | ||||||
|         </el-form-item> |  | ||||||
|       </el-form> |  | ||||||
|       <div slot="footer" class="dialog-footer"> |  | ||||||
|         <el-button type="primary" @click="submitForm">确 定</el-button> |  | ||||||
|         <el-button @click="cancel">取 消</el-button> |  | ||||||
|       </div> |  | ||||||
|     </el-dialog> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import { createEquipmentStatusLog, updateEquipmentStatusLog, deleteEquipmentStatusLog, getEquipmentStatusLog, getEquipmentStatusLogPage, exportEquipmentStatusLogExcel } from "@/api/base/equipmentStatusLog"; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|   name: "EquipmentStatusLog", |  | ||||||
|   components: { |  | ||||||
|   }, |  | ||||||
|   data() { |  | ||||||
|     return { |  | ||||||
|       // 遮罩层 |  | ||||||
|       loading: true, |  | ||||||
|       // 导出遮罩层 |  | ||||||
|       exportLoading: false, |  | ||||||
|       // 显示搜索条件 |  | ||||||
|       showSearch: true, |  | ||||||
|       // 总条数 |  | ||||||
|       total: 0, |  | ||||||
|       // 后端用 设备工作状态列表 |  | ||||||
|       list: [], |  | ||||||
|       // 弹出层标题 |  | ||||||
|       title: "", |  | ||||||
|       // 是否显示弹出层 |  | ||||||
|       open: false, |  | ||||||
|       // 查询参数 |  | ||||||
|       queryParams: { |  | ||||||
|         pageNo: 1, |  | ||||||
|         pageSize: 10, |  | ||||||
|         equipmentId: null, |  | ||||||
|         equipmentName: null, |  | ||||||
|         plcId: null, |  | ||||||
|         plc: null, |  | ||||||
|         status: null, |  | ||||||
|         recordTime: [], |  | ||||||
|         duration: null, |  | ||||||
|         remark: null, |  | ||||||
|         version: null, |  | ||||||
|         createTime: [], |  | ||||||
|       }, |  | ||||||
|       // 表单参数 |  | ||||||
|       form: {}, |  | ||||||
|       // 表单校验 |  | ||||||
|       rules: { |  | ||||||
|       } |  | ||||||
|     }; |  | ||||||
|   }, |  | ||||||
|   created() { |  | ||||||
|     this.getList(); |  | ||||||
|   }, |  | ||||||
|   methods: { |  | ||||||
|     /** 查询列表 */ |  | ||||||
|     getList() { |  | ||||||
|       this.loading = true; |  | ||||||
|       // 执行查询 |  | ||||||
|       getEquipmentStatusLogPage(this.queryParams).then(response => { |  | ||||||
|         this.list = response.data.list; |  | ||||||
|         this.total = response.data.total; |  | ||||||
|         this.loading = false; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 取消按钮 */ |  | ||||||
|     cancel() { |  | ||||||
|       this.open = false; |  | ||||||
|       this.reset(); |  | ||||||
|     }, |  | ||||||
|     /** 表单重置 */ |  | ||||||
|     reset() { |  | ||||||
|       this.form = { |  | ||||||
|         id: undefined, |  | ||||||
|         equipmentId: undefined, |  | ||||||
|         equipmentName: undefined, |  | ||||||
|         plcId: undefined, |  | ||||||
|         plc: undefined, |  | ||||||
|         status: undefined, |  | ||||||
|         recordTime: undefined, |  | ||||||
|         duration: undefined, |  | ||||||
|         remark: undefined, |  | ||||||
|         version: undefined, |  | ||||||
|       }; |  | ||||||
|       this.resetForm("form"); |  | ||||||
|     }, |  | ||||||
|     /** 搜索按钮操作 */ |  | ||||||
|     handleQuery() { |  | ||||||
|       this.queryParams.pageNo = 1; |  | ||||||
|       this.getList(); |  | ||||||
|     }, |  | ||||||
|     /** 重置按钮操作 */ |  | ||||||
|     resetQuery() { |  | ||||||
|       this.resetForm("queryForm"); |  | ||||||
|       this.handleQuery(); |  | ||||||
|     }, |  | ||||||
|     /** 新增按钮操作 */ |  | ||||||
|     handleAdd() { |  | ||||||
|       this.reset(); |  | ||||||
|       this.open = true; |  | ||||||
|       this.title = "添加后端用 设备工作状态"; |  | ||||||
|     }, |  | ||||||
|     /** 修改按钮操作 */ |  | ||||||
|     handleUpdate(row) { |  | ||||||
|       this.reset(); |  | ||||||
|       const id = row.id; |  | ||||||
|       getEquipmentStatusLog(id).then(response => { |  | ||||||
|         this.form = response.data; |  | ||||||
|         this.open = true; |  | ||||||
|         this.title = "修改后端用 设备工作状态"; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 提交按钮 */ |  | ||||||
|     submitForm() { |  | ||||||
|       this.$refs["form"].validate(valid => { |  | ||||||
|         if (!valid) { |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 修改的提交 |  | ||||||
|         if (this.form.id != null) { |  | ||||||
|           updateEquipmentStatusLog(this.form).then(response => { |  | ||||||
|             this.$modal.msgSuccess("修改成功"); |  | ||||||
|             this.open = false; |  | ||||||
|             this.getList(); |  | ||||||
|           }); |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 添加的提交 |  | ||||||
|         createEquipmentStatusLog(this.form).then(response => { |  | ||||||
|           this.$modal.msgSuccess("新增成功"); |  | ||||||
|           this.open = false; |  | ||||||
|           this.getList(); |  | ||||||
|         }); |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 删除按钮操作 */ |  | ||||||
|     handleDelete(row) { |  | ||||||
|       const id = row.id; |  | ||||||
|       this.$modal.confirm('是否确认删除后端用 设备工作状态编号为"' + id + '"的数据项?').then(function() { |  | ||||||
|           return deleteEquipmentStatusLog(id); |  | ||||||
|         }).then(() => { |  | ||||||
|           this.getList(); |  | ||||||
|           this.$modal.msgSuccess("删除成功"); |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     }, |  | ||||||
|     /** 导出按钮操作 */ |  | ||||||
|     handleExport() { |  | ||||||
|       // 处理查询参数 |  | ||||||
|       let params = {...this.queryParams}; |  | ||||||
|       params.pageNo = undefined; |  | ||||||
|       params.pageSize = undefined; |  | ||||||
|       this.$modal.confirm('是否确认导出所有后端用 设备工作状态数据项?').then(() => { |  | ||||||
|           this.exportLoading = true; |  | ||||||
|           return exportEquipmentStatusLogExcel(params); |  | ||||||
|         }).then(response => { |  | ||||||
|           this.$download.excel(response, '后端用 设备工作状态.xls'); |  | ||||||
|           this.exportLoading = false; |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
| @ -1,296 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="app-container"> |  | ||||||
| 
 |  | ||||||
|     <!-- 搜索工作栏 --> |  | ||||||
|     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |  | ||||||
|       <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|         <el-input v-model="queryParams.equipmentId" placeholder="请输入设备id" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="设备名称" prop="equipmentName"> |  | ||||||
|         <el-input v-model="queryParams.equipmentName" placeholder="请输入设备名称" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="状态,0正常 1计划停机 2故障" prop="status"> |  | ||||||
|         <el-select v-model="queryParams.status" placeholder="请选择状态,0正常 1计划停机 2故障" clearable size="small"> |  | ||||||
|           <el-option label="请选择字典生成" value="" /> |  | ||||||
|         </el-select> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="是否运行中" prop="run"> |  | ||||||
|         <el-select v-model="queryParams.run" placeholder="请选择是否运行中" clearable size="small"> |  | ||||||
|           <el-option label="请选择字典生成" value="" /> |  | ||||||
|         </el-select> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="是否发生运行错误" prop="error"> |  | ||||||
|         <el-select v-model="queryParams.error" placeholder="请选择是否发生运行错误" clearable size="small"> |  | ||||||
|           <el-option label="请选择字典生成" value="" /> |  | ||||||
|         </el-select> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="备注" prop="remark"> |  | ||||||
|         <el-input v-model="queryParams.remark" placeholder="请输入备注" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="记录时间" prop="recordTime"> |  | ||||||
|         <el-date-picker v-model="queryParams.recordTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange" |  | ||||||
|                         range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" /> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="版本号" prop="version"> |  | ||||||
|         <el-input v-model="queryParams.version" placeholder="请输入版本号" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="创建时间" prop="createTime"> |  | ||||||
|         <el-date-picker v-model="queryParams.createTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange" |  | ||||||
|                         range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" /> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item> |  | ||||||
|         <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button> |  | ||||||
|         <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button> |  | ||||||
|       </el-form-item> |  | ||||||
|     </el-form> |  | ||||||
| 
 |  | ||||||
|     <!-- 操作工具栏 --> |  | ||||||
|     <el-row :gutter="10" class="mb8"> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" |  | ||||||
|                    v-hasPermi="['base:equipment-status-realtime:create']">新增</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading" |  | ||||||
|                    v-hasPermi="['base:equipment-status-realtime:export']">导出</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |  | ||||||
|     </el-row> |  | ||||||
| 
 |  | ||||||
|     <!-- 列表 --> |  | ||||||
|     <el-table v-loading="loading" :data="list"> |  | ||||||
|       <el-table-column label="id" align="center" prop="id" /> |  | ||||||
|       <el-table-column label="设备id" align="center" prop="equipmentId" /> |  | ||||||
|       <el-table-column label="设备名称" align="center" prop="equipmentName" /> |  | ||||||
|       <el-table-column label="状态,0正常 1计划停机 2故障" align="center" prop="status" /> |  | ||||||
|       <el-table-column label="是否运行中" align="center" prop="run" /> |  | ||||||
|       <el-table-column label="是否发生运行错误" align="center" prop="error" /> |  | ||||||
|       <el-table-column label="描述" align="center" prop="description" /> |  | ||||||
|       <el-table-column label="备注" align="center" prop="remark" /> |  | ||||||
|       <el-table-column label="记录时间" align="center" prop="recordTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.recordTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="版本号" align="center" prop="version" /> |  | ||||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.createTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-status-realtime:update']">修改</el-button> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-status-realtime:delete']">删除</el-button> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|     </el-table> |  | ||||||
|     <!-- 分页组件 --> |  | ||||||
|     <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" |  | ||||||
|                 @pagination="getList"/> |  | ||||||
| 
 |  | ||||||
|     <!-- 对话框(添加 / 修改) --> |  | ||||||
|     <el-dialog :title="title" :visible.sync="open" width="500px" v-dialogDrag append-to-body> |  | ||||||
|       <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |  | ||||||
|         <el-form-item label="设备id" prop="equipmentId"> |  | ||||||
|           <el-input v-model="form.equipmentId" placeholder="请输入设备id" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="设备名称" prop="equipmentName"> |  | ||||||
|           <el-input v-model="form.equipmentName" placeholder="请输入设备名称" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="状态,0正常 1计划停机 2故障" prop="status"> |  | ||||||
|           <el-radio-group v-model="form.status"> |  | ||||||
|             <el-radio label="1">请选择字典生成</el-radio> |  | ||||||
|           </el-radio-group> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="是否运行中" prop="run"> |  | ||||||
|           <el-radio-group v-model="form.run"> |  | ||||||
|             <el-radio label="1">请选择字典生成</el-radio> |  | ||||||
|           </el-radio-group> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="是否发生运行错误" prop="error"> |  | ||||||
|           <el-radio-group v-model="form.error"> |  | ||||||
|             <el-radio label="1">请选择字典生成</el-radio> |  | ||||||
|           </el-radio-group> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="描述"> |  | ||||||
|           <editor v-model="form.description" :min-height="192"/> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="备注" prop="remark"> |  | ||||||
|           <el-input v-model="form.remark" placeholder="请输入备注" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="记录时间" prop="recordTime"> |  | ||||||
|           <el-date-picker clearable v-model="form.recordTime" type="date" value-format="timestamp" placeholder="选择记录时间" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="版本号" prop="version"> |  | ||||||
|           <el-input v-model="form.version" placeholder="请输入版本号" /> |  | ||||||
|         </el-form-item> |  | ||||||
|       </el-form> |  | ||||||
|       <div slot="footer" class="dialog-footer"> |  | ||||||
|         <el-button type="primary" @click="submitForm">确 定</el-button> |  | ||||||
|         <el-button @click="cancel">取 消</el-button> |  | ||||||
|       </div> |  | ||||||
|     </el-dialog> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import { createEquipmentStatusRealtime, updateEquipmentStatusRealtime, deleteEquipmentStatusRealtime, getEquipmentStatusRealtime, getEquipmentStatusRealtimePage, exportEquipmentStatusRealtimeExcel } from "@/api/base/equipmentStatusRealtime"; |  | ||||||
| import Editor from '@/components/Editor'; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|   name: "EquipmentStatusRealtime", |  | ||||||
|   components: { |  | ||||||
|     Editor |  | ||||||
|   }, |  | ||||||
|   data() { |  | ||||||
|     return { |  | ||||||
|       // 遮罩层 |  | ||||||
|       loading: true, |  | ||||||
|       // 导出遮罩层 |  | ||||||
|       exportLoading: false, |  | ||||||
|       // 显示搜索条件 |  | ||||||
|       showSearch: true, |  | ||||||
|       // 总条数 |  | ||||||
|       total: 0, |  | ||||||
|       // 后端用 设备状态实时列表 |  | ||||||
|       list: [], |  | ||||||
|       // 弹出层标题 |  | ||||||
|       title: "", |  | ||||||
|       // 是否显示弹出层 |  | ||||||
|       open: false, |  | ||||||
|       // 查询参数 |  | ||||||
|       queryParams: { |  | ||||||
|         pageNo: 1, |  | ||||||
|         pageSize: 10, |  | ||||||
|         equipmentId: null, |  | ||||||
|         equipmentName: null, |  | ||||||
|         status: null, |  | ||||||
|         run: null, |  | ||||||
|         error: null, |  | ||||||
|         description: null, |  | ||||||
|         remark: null, |  | ||||||
|         recordTime: [], |  | ||||||
|         version: null, |  | ||||||
|         createTime: [], |  | ||||||
|       }, |  | ||||||
|       // 表单参数 |  | ||||||
|       form: {}, |  | ||||||
|       // 表单校验 |  | ||||||
|       rules: { |  | ||||||
|       } |  | ||||||
|     }; |  | ||||||
|   }, |  | ||||||
|   created() { |  | ||||||
|     this.getList(); |  | ||||||
|   }, |  | ||||||
|   methods: { |  | ||||||
|     /** 查询列表 */ |  | ||||||
|     getList() { |  | ||||||
|       this.loading = true; |  | ||||||
|       // 执行查询 |  | ||||||
|       getEquipmentStatusRealtimePage(this.queryParams).then(response => { |  | ||||||
|         this.list = response.data.list; |  | ||||||
|         this.total = response.data.total; |  | ||||||
|         this.loading = false; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 取消按钮 */ |  | ||||||
|     cancel() { |  | ||||||
|       this.open = false; |  | ||||||
|       this.reset(); |  | ||||||
|     }, |  | ||||||
|     /** 表单重置 */ |  | ||||||
|     reset() { |  | ||||||
|       this.form = { |  | ||||||
|         id: undefined, |  | ||||||
|         equipmentId: undefined, |  | ||||||
|         equipmentName: undefined, |  | ||||||
|         status: undefined, |  | ||||||
|         run: undefined, |  | ||||||
|         error: undefined, |  | ||||||
|         description: undefined, |  | ||||||
|         remark: undefined, |  | ||||||
|         recordTime: undefined, |  | ||||||
|         version: undefined, |  | ||||||
|       }; |  | ||||||
|       this.resetForm("form"); |  | ||||||
|     }, |  | ||||||
|     /** 搜索按钮操作 */ |  | ||||||
|     handleQuery() { |  | ||||||
|       this.queryParams.pageNo = 1; |  | ||||||
|       this.getList(); |  | ||||||
|     }, |  | ||||||
|     /** 重置按钮操作 */ |  | ||||||
|     resetQuery() { |  | ||||||
|       this.resetForm("queryForm"); |  | ||||||
|       this.handleQuery(); |  | ||||||
|     }, |  | ||||||
|     /** 新增按钮操作 */ |  | ||||||
|     handleAdd() { |  | ||||||
|       this.reset(); |  | ||||||
|       this.open = true; |  | ||||||
|       this.title = "添加后端用 设备状态实时"; |  | ||||||
|     }, |  | ||||||
|     /** 修改按钮操作 */ |  | ||||||
|     handleUpdate(row) { |  | ||||||
|       this.reset(); |  | ||||||
|       const id = row.id; |  | ||||||
|       getEquipmentStatusRealtime(id).then(response => { |  | ||||||
|         this.form = response.data; |  | ||||||
|         this.open = true; |  | ||||||
|         this.title = "修改后端用 设备状态实时"; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 提交按钮 */ |  | ||||||
|     submitForm() { |  | ||||||
|       this.$refs["form"].validate(valid => { |  | ||||||
|         if (!valid) { |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 修改的提交 |  | ||||||
|         if (this.form.id != null) { |  | ||||||
|           updateEquipmentStatusRealtime(this.form).then(response => { |  | ||||||
|             this.$modal.msgSuccess("修改成功"); |  | ||||||
|             this.open = false; |  | ||||||
|             this.getList(); |  | ||||||
|           }); |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 添加的提交 |  | ||||||
|         createEquipmentStatusRealtime(this.form).then(response => { |  | ||||||
|           this.$modal.msgSuccess("新增成功"); |  | ||||||
|           this.open = false; |  | ||||||
|           this.getList(); |  | ||||||
|         }); |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 删除按钮操作 */ |  | ||||||
|     handleDelete(row) { |  | ||||||
|       const id = row.id; |  | ||||||
|       this.$modal.confirm('是否确认删除后端用 设备状态实时编号为"' + id + '"的数据项?').then(function() { |  | ||||||
|           return deleteEquipmentStatusRealtime(id); |  | ||||||
|         }).then(() => { |  | ||||||
|           this.getList(); |  | ||||||
|           this.$modal.msgSuccess("删除成功"); |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     }, |  | ||||||
|     /** 导出按钮操作 */ |  | ||||||
|     handleExport() { |  | ||||||
|       // 处理查询参数 |  | ||||||
|       let params = {...this.queryParams}; |  | ||||||
|       params.pageNo = undefined; |  | ||||||
|       params.pageSize = undefined; |  | ||||||
|       this.$modal.confirm('是否确认导出所有后端用 设备状态实时数据项?').then(() => { |  | ||||||
|           this.exportLoading = true; |  | ||||||
|           return exportEquipmentStatusRealtimeExcel(params); |  | ||||||
|         }).then(response => { |  | ||||||
|           this.$download.excel(response, '后端用 设备状态实时.xls'); |  | ||||||
|           this.exportLoading = false; |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
| @ -1,229 +0,0 @@ | |||||||
| <template> |  | ||||||
|   <div class="app-container"> |  | ||||||
| 
 |  | ||||||
|     <!-- 搜索工作栏 --> |  | ||||||
|     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px"> |  | ||||||
|       <el-form-item label="设备类型ID" prop="equipmentTypeId"> |  | ||||||
|         <el-input v-model="queryParams.equipmentTypeId" placeholder="请输入设备类型ID" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="原始名称" prop="fileName"> |  | ||||||
|         <el-input v-model="queryParams.fileName" placeholder="请输入原始名称" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="下载地址" prop="fileUrl"> |  | ||||||
|         <el-input v-model="queryParams.fileUrl" placeholder="请输入下载地址" clearable @keyup.enter.native="handleQuery"/> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item label="创建时间" prop="createTime"> |  | ||||||
|         <el-date-picker v-model="queryParams.createTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange" |  | ||||||
|                         range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" /> |  | ||||||
|       </el-form-item> |  | ||||||
|       <el-form-item> |  | ||||||
|         <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button> |  | ||||||
|         <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button> |  | ||||||
|       </el-form-item> |  | ||||||
|     </el-form> |  | ||||||
| 
 |  | ||||||
|     <!-- 操作工具栏 --> |  | ||||||
|     <el-row :gutter="10" class="mb8"> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" |  | ||||||
|                    v-hasPermi="['base:equipment-type-file:create']">新增</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <el-col :span="1.5"> |  | ||||||
|         <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading" |  | ||||||
|                    v-hasPermi="['base:equipment-type-file:export']">导出</el-button> |  | ||||||
|       </el-col> |  | ||||||
|       <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> |  | ||||||
|     </el-row> |  | ||||||
| 
 |  | ||||||
|     <!-- 列表 --> |  | ||||||
|     <el-table v-loading="loading" :data="list"> |  | ||||||
|       <el-table-column label="ID" align="center" prop="id" /> |  | ||||||
|       <el-table-column label="设备类型ID" align="center" prop="equipmentTypeId" /> |  | ||||||
|       <el-table-column label="原始名称" align="center" prop="fileName" /> |  | ||||||
|       <el-table-column label="下载地址" align="center" prop="fileUrl" /> |  | ||||||
|       <el-table-column label="创建时间" align="center" prop="createTime" width="180"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <span>{{ parseTime(scope.row.createTime) }}</span> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|       <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |  | ||||||
|         <template v-slot="scope"> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-type-file:update']">修改</el-button> |  | ||||||
|           <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)" |  | ||||||
|                      v-hasPermi="['base:equipment-type-file:delete']">删除</el-button> |  | ||||||
|         </template> |  | ||||||
|       </el-table-column> |  | ||||||
|     </el-table> |  | ||||||
|     <!-- 分页组件 --> |  | ||||||
|     <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" |  | ||||||
|                 @pagination="getList"/> |  | ||||||
| 
 |  | ||||||
|     <!-- 对话框(添加 / 修改) --> |  | ||||||
|     <el-dialog :title="title" :visible.sync="open" width="500px" v-dialogDrag append-to-body> |  | ||||||
|       <el-form ref="form" :model="form" :rules="rules" label-width="80px"> |  | ||||||
|         <el-form-item label="设备类型ID" prop="equipmentTypeId"> |  | ||||||
|           <el-input v-model="form.equipmentTypeId" placeholder="请输入设备类型ID" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="原始名称" prop="fileName"> |  | ||||||
|           <el-input v-model="form.fileName" placeholder="请输入原始名称" /> |  | ||||||
|         </el-form-item> |  | ||||||
|         <el-form-item label="下载地址" prop="fileUrl"> |  | ||||||
|           <el-input v-model="form.fileUrl" placeholder="请输入下载地址" /> |  | ||||||
|         </el-form-item> |  | ||||||
|       </el-form> |  | ||||||
|       <div slot="footer" class="dialog-footer"> |  | ||||||
|         <el-button type="primary" @click="submitForm">确 定</el-button> |  | ||||||
|         <el-button @click="cancel">取 消</el-button> |  | ||||||
|       </div> |  | ||||||
|     </el-dialog> |  | ||||||
|   </div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| import { createEquipmentTypeFile, updateEquipmentTypeFile, deleteEquipmentTypeFile, getEquipmentTypeFile, getEquipmentTypeFilePage, exportEquipmentTypeFileExcel } from "@/api/base/equipmentTypeFile"; |  | ||||||
| 
 |  | ||||||
| export default { |  | ||||||
|   name: "EquipmentTypeFile", |  | ||||||
|   components: { |  | ||||||
|   }, |  | ||||||
|   data() { |  | ||||||
|     return { |  | ||||||
|       // 遮罩层 |  | ||||||
|       loading: true, |  | ||||||
|       // 导出遮罩层 |  | ||||||
|       exportLoading: false, |  | ||||||
|       // 显示搜索条件 |  | ||||||
|       showSearch: true, |  | ||||||
|       // 总条数 |  | ||||||
|       total: 0, |  | ||||||
|       // 设备类型文件关联列表 |  | ||||||
|       list: [], |  | ||||||
|       // 弹出层标题 |  | ||||||
|       title: "", |  | ||||||
|       // 是否显示弹出层 |  | ||||||
|       open: false, |  | ||||||
|       // 查询参数 |  | ||||||
|       queryParams: { |  | ||||||
|         pageNo: 1, |  | ||||||
|         pageSize: 10, |  | ||||||
|         equipmentTypeId: null, |  | ||||||
|         fileName: null, |  | ||||||
|         fileUrl: null, |  | ||||||
|         createTime: [], |  | ||||||
|       }, |  | ||||||
|       // 表单参数 |  | ||||||
|       form: {}, |  | ||||||
|       // 表单校验 |  | ||||||
|       rules: { |  | ||||||
|         equipmentTypeId: [{ required: true, message: "设备类型ID不能为空", trigger: "blur" }], |  | ||||||
|         fileName: [{ required: true, message: "原始名称不能为空", trigger: "blur" }], |  | ||||||
|         fileUrl: [{ required: true, message: "下载地址不能为空", trigger: "blur" }], |  | ||||||
|       } |  | ||||||
|     }; |  | ||||||
|   }, |  | ||||||
|   created() { |  | ||||||
|     this.getList(); |  | ||||||
|   }, |  | ||||||
|   methods: { |  | ||||||
|     /** 查询列表 */ |  | ||||||
|     getList() { |  | ||||||
|       this.loading = true; |  | ||||||
|       // 执行查询 |  | ||||||
|       getEquipmentTypeFilePage(this.queryParams).then(response => { |  | ||||||
|         this.list = response.data.list; |  | ||||||
|         this.total = response.data.total; |  | ||||||
|         this.loading = false; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 取消按钮 */ |  | ||||||
|     cancel() { |  | ||||||
|       this.open = false; |  | ||||||
|       this.reset(); |  | ||||||
|     }, |  | ||||||
|     /** 表单重置 */ |  | ||||||
|     reset() { |  | ||||||
|       this.form = { |  | ||||||
|         id: undefined, |  | ||||||
|         equipmentTypeId: undefined, |  | ||||||
|         fileName: undefined, |  | ||||||
|         fileUrl: undefined, |  | ||||||
|       }; |  | ||||||
|       this.resetForm("form"); |  | ||||||
|     }, |  | ||||||
|     /** 搜索按钮操作 */ |  | ||||||
|     handleQuery() { |  | ||||||
|       this.queryParams.pageNo = 1; |  | ||||||
|       this.getList(); |  | ||||||
|     }, |  | ||||||
|     /** 重置按钮操作 */ |  | ||||||
|     resetQuery() { |  | ||||||
|       this.resetForm("queryForm"); |  | ||||||
|       this.handleQuery(); |  | ||||||
|     }, |  | ||||||
|     /** 新增按钮操作 */ |  | ||||||
|     handleAdd() { |  | ||||||
|       this.reset(); |  | ||||||
|       this.open = true; |  | ||||||
|       this.title = "添加设备类型文件关联"; |  | ||||||
|     }, |  | ||||||
|     /** 修改按钮操作 */ |  | ||||||
|     handleUpdate(row) { |  | ||||||
|       this.reset(); |  | ||||||
|       const id = row.id; |  | ||||||
|       getEquipmentTypeFile(id).then(response => { |  | ||||||
|         this.form = response.data; |  | ||||||
|         this.open = true; |  | ||||||
|         this.title = "修改设备类型文件关联"; |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 提交按钮 */ |  | ||||||
|     submitForm() { |  | ||||||
|       this.$refs["form"].validate(valid => { |  | ||||||
|         if (!valid) { |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 修改的提交 |  | ||||||
|         if (this.form.id != null) { |  | ||||||
|           updateEquipmentTypeFile(this.form).then(response => { |  | ||||||
|             this.$modal.msgSuccess("修改成功"); |  | ||||||
|             this.open = false; |  | ||||||
|             this.getList(); |  | ||||||
|           }); |  | ||||||
|           return; |  | ||||||
|         } |  | ||||||
|         // 添加的提交 |  | ||||||
|         createEquipmentTypeFile(this.form).then(response => { |  | ||||||
|           this.$modal.msgSuccess("新增成功"); |  | ||||||
|           this.open = false; |  | ||||||
|           this.getList(); |  | ||||||
|         }); |  | ||||||
|       }); |  | ||||||
|     }, |  | ||||||
|     /** 删除按钮操作 */ |  | ||||||
|     handleDelete(row) { |  | ||||||
|       const id = row.id; |  | ||||||
|       this.$modal.confirm('是否确认删除设备类型文件关联编号为"' + id + '"的数据项?').then(function() { |  | ||||||
|           return deleteEquipmentTypeFile(id); |  | ||||||
|         }).then(() => { |  | ||||||
|           this.getList(); |  | ||||||
|           this.$modal.msgSuccess("删除成功"); |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     }, |  | ||||||
|     /** 导出按钮操作 */ |  | ||||||
|     handleExport() { |  | ||||||
|       // 处理查询参数 |  | ||||||
|       let params = {...this.queryParams}; |  | ||||||
|       params.pageNo = undefined; |  | ||||||
|       params.pageSize = undefined; |  | ||||||
|       this.$modal.confirm('是否确认导出所有设备类型文件关联数据项?').then(() => { |  | ||||||
|           this.exportLoading = true; |  | ||||||
|           return exportEquipmentTypeFileExcel(params); |  | ||||||
|         }).then(response => { |  | ||||||
|           this.$download.excel(response, '设备类型文件关联.xls'); |  | ||||||
|           this.exportLoading = false; |  | ||||||
|         }).catch(() => {}); |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
							
								
								
									
										65
									
								
								src/views/base/material/SmallTitle.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,65 @@ | |||||||
|  | <!-- | ||||||
|  |  * @Author: zwq | ||||||
|  |  * @Date: 2023-08-01 15:27:31 | ||||||
|  |  * @LastEditors: zwq | ||||||
|  |  * @LastEditTime: 2023-08-01 16:25:54 | ||||||
|  |  * @Description: | ||||||
|  | --> | ||||||
|  | <template> | ||||||
|  | 	<div :class="[className, { 'p-0': noPadding }]"> | ||||||
|  | 		<slot /> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  | 	props: { | ||||||
|  | 		size: { | ||||||
|  | 			// 取值范围:  xl lg md sm | ||||||
|  | 			type: String, | ||||||
|  | 			default: 'de', | ||||||
|  | 			validator: function (val) { | ||||||
|  | 				return ['xl', 'lg', 'de', 'md', 'sm'].indexOf(val) !== -1; | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		noPadding: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			default: false, | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | 	computed: { | ||||||
|  | 		className: function () { | ||||||
|  | 			return `${this.size}-title`; | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style lang="scss" scoped> | ||||||
|  | $pxls: (xl, 28px) (lg, 24px) (de, 20px) (md, 18px) (sm, 16px); | ||||||
|  | $mgr: 8px; | ||||||
|  | @each $size, $height in $pxls { | ||||||
|  | 	.#{$size}-title { | ||||||
|  | 		font-size: 18px; | ||||||
|  | 		line-height: $height; | ||||||
|  | 		color: #000; | ||||||
|  | 		font-weight: 500; | ||||||
|  | 		font-family: '微软雅黑', 'Microsoft YaHei', Arial, Helvetica, sans-serif; | ||||||
|  | 
 | ||||||
|  | 		&::before { | ||||||
|  | 			content: ''; | ||||||
|  | 			display: inline-block; | ||||||
|  | 			vertical-align: top; | ||||||
|  | 			width: 4px; | ||||||
|  | 			height: $height + 2px; | ||||||
|  | 			border-radius: 1px; | ||||||
|  | 			margin-right: $mgr; | ||||||
|  | 			background-color: #0b58ff; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .p-0 { | ||||||
|  | 	padding: 0; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										421
									
								
								src/views/base/material/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,421 @@ | |||||||
|  | <!-- | ||||||
|  |  * @Author: zwq | ||||||
|  |  * @Date: 2021-11-18 14:16:25 | ||||||
|  |  * @LastEditors: DY | ||||||
|  |  * @LastEditTime: 2023-10-27 15:11:02 | ||||||
|  |  * @Description: | ||||||
|  | --> | ||||||
|  | <template> | ||||||
|  | 	<el-drawer | ||||||
|  | 		:visible.sync="visible" | ||||||
|  | 		:show-close="false" | ||||||
|  | 		:wrapper-closable="false" | ||||||
|  | 		class="drawer" | ||||||
|  | 		size="60%"> | ||||||
|  | 		<small-title slot="title" :no-padding="true"> | ||||||
|  | 			{{ isdetail ? '详情' : !dataForm.id ? '新增' : '编辑' }} | ||||||
|  | 		</small-title> | ||||||
|  | 		<div class="content"> | ||||||
|  | 			<div class="visual-part"> | ||||||
|  | 				<el-form | ||||||
|  | 					:model="dataForm" | ||||||
|  | 					:rules="dataRule" | ||||||
|  | 					ref="dataForm" | ||||||
|  | 					@keyup.enter.native="dataFormSubmit()" | ||||||
|  | 					label-width="100px" | ||||||
|  | 					label-position="top"> | ||||||
|  | 					<el-row :gutter="20"> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="物料编码" prop="code"> | ||||||
|  | 								<el-input | ||||||
|  | 									v-model="dataForm.code" | ||||||
|  | 									clearable | ||||||
|  | 									:disabled="isdetail" | ||||||
|  | 									placeholder="请输入物料编码" /> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="物料名称" prop="name"> | ||||||
|  | 								<el-input v-model="dataForm.name" :disabled="isdetail" clearable placeholder="请输入物料名称" /> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 					</el-row> | ||||||
|  | 					<el-row :gutter="20"> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="英文名称" prop="engName"> | ||||||
|  | 								<el-input | ||||||
|  | 									v-model="dataForm.engName" | ||||||
|  | 									clearable | ||||||
|  | 									:disabled="isdetail" | ||||||
|  | 									placeholder="请输入英文名称" /> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="物料类型" prop="type"> | ||||||
|  | 								<el-select | ||||||
|  | 									v-model="dataForm.type" | ||||||
|  | 									filterable | ||||||
|  | 									:disabled="isdetail" | ||||||
|  | 									placeholder="请选择物料类型"> | ||||||
|  | 									<el-option | ||||||
|  | 										v-for="dict in materialList" | ||||||
|  | 										:key="dict.value" | ||||||
|  | 										:label="dict.label" | ||||||
|  | 										:value="dict.value" /> | ||||||
|  | 								</el-select> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 					</el-row> | ||||||
|  | 					<el-row :gutter="20"> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="规格" prop="spec"> | ||||||
|  | 								<el-input | ||||||
|  | 									v-model="dataForm.spec" | ||||||
|  | 									clearable | ||||||
|  | 									:disabled="isdetail" | ||||||
|  | 									placeholder="请输入规格" /> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="供应商" prop="supplierId"> | ||||||
|  | 								<el-select | ||||||
|  | 									v-model="dataForm.supplierId" | ||||||
|  | 									filterable | ||||||
|  | 									clearable | ||||||
|  | 									:disabled="isdetail" | ||||||
|  | 									placeholder="请选择供应商"> | ||||||
|  | 									<el-option | ||||||
|  | 										v-for="dict in supplierList" | ||||||
|  | 										:key="dict.id" | ||||||
|  | 										:label="dict.name" | ||||||
|  | 										:value="dict.id" /> | ||||||
|  | 								</el-select> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 					</el-row> | ||||||
|  | 					<el-row :gutter="20"> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="单位" prop="unit"> | ||||||
|  | 								<el-select | ||||||
|  | 									v-model="dataForm.unit" | ||||||
|  | 									filterable | ||||||
|  | 									:disabled="isdetail" | ||||||
|  | 									placeholder="请选择物料单位"> | ||||||
|  | 									<el-option | ||||||
|  | 										v-for="dict in unitList" | ||||||
|  | 										:key="dict.value" | ||||||
|  | 										:label="dict.label" | ||||||
|  | 										:value="dict.value" /> | ||||||
|  | 								</el-select> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="备注" prop="remark"> | ||||||
|  | 								<el-input v-model="dataForm.remark" :disabled="isdetail" clearable placeholder="请输入备注" /> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 					</el-row> | ||||||
|  | 				</el-form> | ||||||
|  | 			</div> | ||||||
|  | 			<div class="attr-list" v-if="idAttrShow"> | ||||||
|  | 				<small-title | ||||||
|  | 					style="margin: 16px 0; padding-left: 8px" | ||||||
|  | 					:no-padding="true"> | ||||||
|  | 					物料属性 | ||||||
|  | 				</small-title> | ||||||
|  | 
 | ||||||
|  | 				<base-table | ||||||
|  | 					:table-props="tableProps" | ||||||
|  | 					:page="listQuery.pageNo" | ||||||
|  | 					:limit="listQuery.pageSize" | ||||||
|  | 					:add-button-show="isdetail ? null : '添加属性'" | ||||||
|  | 					@emitButtonClick="addNew()" | ||||||
|  | 					:table-data="materialAttrList"> | ||||||
|  | 					<method-btn | ||||||
|  | 						v-if="!isdetail" | ||||||
|  | 						slot="handleBtn" | ||||||
|  | 						:width="120" | ||||||
|  | 						label="操作" | ||||||
|  | 						:method-list="tableBtn" | ||||||
|  | 						@clickBtn="handleClick" /> | ||||||
|  | 				</base-table> | ||||||
|  | 				<pagination | ||||||
|  | 					v-show="listQuery.total > 0" | ||||||
|  | 					:total="listQuery.total" | ||||||
|  | 					:page.sync="listQuery.pageNo" | ||||||
|  | 					:limit.sync="listQuery.pageSize" | ||||||
|  | 					:page-sizes="[5, 10, 15]" | ||||||
|  | 					@pagination="getList" /> | ||||||
|  | 			</div> | ||||||
|  | 
 | ||||||
|  | 			<div class="drawer-body__footer"> | ||||||
|  | 				<el-button style="" @click="goback()">取消</el-button> | ||||||
|  | 				<el-button v-if="isdetail" type="primary" @click="goEdit()"> | ||||||
|  | 					编辑 | ||||||
|  | 				</el-button> | ||||||
|  | 				<el-button v-else type="primary" @click="dataFormSubmit()">确定</el-button> | ||||||
|  | 			</div> | ||||||
|  | 		</div> | ||||||
|  | 
 | ||||||
|  | 		<attr-add | ||||||
|  | 			v-if="addOrUpdateVisible" | ||||||
|  | 			ref="addOrUpdate" | ||||||
|  | 			:material-id="dataForm.id" | ||||||
|  | 			@refreshDataList="getList" /> | ||||||
|  | 	</el-drawer> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import basicAdd from '../../core/mixins/basic-add'; | ||||||
|  | import { createMaterial, updateMaterial, getMaterial, getCode, getSupplierList, getMaterialAttrList, deleteMaterialAttr } from "@/api/base/material"; | ||||||
|  | import { listData } from "@/api/system/dict/data"; | ||||||
|  | import SmallTitle from './SmallTitle'; | ||||||
|  | import { parseTime } from '../../core/mixins/code-filter'; | ||||||
|  | import attrAdd from './attr-add'; | ||||||
|  | 
 | ||||||
|  | const tableBtn = [ | ||||||
|  | 	{ | ||||||
|  | 		type: 'edit', | ||||||
|  | 		btnName: '编辑', | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		type: 'delete', | ||||||
|  | 		btnName: '删除', | ||||||
|  | 	}, | ||||||
|  | ]; | ||||||
|  | const tableProps = [ | ||||||
|  | 	{ | ||||||
|  | 		prop: 'createTime', | ||||||
|  | 		label: '添加时间', | ||||||
|  | 		filter: parseTime, | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'attrName', | ||||||
|  | 		label: '属性名', | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'attrValue', | ||||||
|  | 		label: '属性值', | ||||||
|  | 	}, | ||||||
|  | ]; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	mixins: [basicAdd], | ||||||
|  | 	components: { SmallTitle, attrAdd }, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			tableBtn, | ||||||
|  | 			tableProps, | ||||||
|  | 			addOrUpdateVisible: false, | ||||||
|  | 			urlOptions: { | ||||||
|  | 			  isGetCode: true, | ||||||
|  |         codeURL: getCode, | ||||||
|  | 				createURL: createMaterial, | ||||||
|  | 				updateURL: updateMaterial, | ||||||
|  | 				infoURL: getMaterial, | ||||||
|  | 			}, | ||||||
|  | 			listQuery: { | ||||||
|  | 				pageSize: 10, | ||||||
|  | 				pageNo: 1, | ||||||
|  | 				total: 0, | ||||||
|  | 			}, | ||||||
|  | 			dataForm: { | ||||||
|  |         id: undefined, | ||||||
|  |         code: undefined, | ||||||
|  |         name: '', | ||||||
|  | 				engName: '', | ||||||
|  | 				type: '', | ||||||
|  |         spec: undefined, | ||||||
|  | 				supplierId: undefined, | ||||||
|  |         remark: undefined, | ||||||
|  | 				unit: '' | ||||||
|  | 			}, | ||||||
|  | 			materialList: [], | ||||||
|  | 			supplierList: [], | ||||||
|  | 			materialAttrList: [], | ||||||
|  | 			unitList: [], | ||||||
|  | 			visible: false, | ||||||
|  | 			isdetail: false, | ||||||
|  | 			idAttrShow: false, | ||||||
|  | 			dataRule: { | ||||||
|  |         code: [{ required: true, message: "物料编码不能为空", trigger: "blur" }], | ||||||
|  |         name: [{ required: true, message: "物料名称不能为空", trigger: "blur" }], | ||||||
|  | 				type: [{ required: true, message: "物料类型不能为空", trigger: "blur" }] | ||||||
|  |       } | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	mounted() { | ||||||
|  | 		this.getDict() | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		async getDict() { | ||||||
|  | 			// 物料类型列表 | ||||||
|  | 			const res = await listData({ | ||||||
|  | 				pageNo: 1, | ||||||
|  |         pageSize: 99, | ||||||
|  |         dictType: 'material_type', | ||||||
|  | 			}); | ||||||
|  | 			this.materialList = res.data.list.map(item => { | ||||||
|  | 				return { | ||||||
|  | 					label: item.label, | ||||||
|  | 					value: Number(item.value) | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 			// 供应商列表 | ||||||
|  | 			const supplierRes = await getSupplierList(); | ||||||
|  | 			this.supplierList = supplierRes.data; | ||||||
|  | 			// 物料单位列表 | ||||||
|  | 			const unitRes = await listData({ | ||||||
|  | 				pageNo: 1, | ||||||
|  |         pageSize: 99, | ||||||
|  |         dictType: 'goods_unit', | ||||||
|  | 			}); | ||||||
|  | 			this.unitList = unitRes.data.list.map(item => { | ||||||
|  | 				return { | ||||||
|  | 					label: item.label, | ||||||
|  | 					value: Number(item.value) | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		initData() { | ||||||
|  | 			this.materialAttrList.splice(0); | ||||||
|  | 			this.listQuery.total = 0; | ||||||
|  | 		}, | ||||||
|  | 		handleClick(raw) { | ||||||
|  | 			if (raw.type === 'delete') { | ||||||
|  | 				this.$confirm( | ||||||
|  | 					`确定对${ | ||||||
|  | 						raw.data.attrName | ||||||
|  | 							? '[名称=' + raw.data.attrName + ']' | ||||||
|  | 							: '[序号=' + raw.data._pageIndex + ']' | ||||||
|  | 					}进行删除操作?`, | ||||||
|  | 					'提示', | ||||||
|  | 					{ | ||||||
|  | 						confirmButtonText: '确定', | ||||||
|  | 						cancelButtonText: '取消', | ||||||
|  | 						type: 'warning', | ||||||
|  | 					} | ||||||
|  | 				) | ||||||
|  | 					.then(() => { | ||||||
|  | 						deleteMaterialAttr(raw.data.id).then(({ data }) => { | ||||||
|  | 							this.$message({ | ||||||
|  | 								message: '操作成功', | ||||||
|  | 								type: 'success', | ||||||
|  | 								duration: 1500, | ||||||
|  | 								onClose: () => { | ||||||
|  | 									this.getList(); | ||||||
|  | 								}, | ||||||
|  | 							}); | ||||||
|  | 						}); | ||||||
|  | 					}) | ||||||
|  | 					.catch(() => {}); | ||||||
|  | 			} else { | ||||||
|  | 				this.addNew(raw.data.id); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		getList() { | ||||||
|  | 			// 获取物料的属性列表 | ||||||
|  | 			getMaterialAttrList({ | ||||||
|  | 				...this.listQuery, | ||||||
|  | 				materialId: this.dataForm.id, | ||||||
|  | 			}).then((response) => { | ||||||
|  | 				this.materialAttrList = response.data.list; | ||||||
|  | 				this.listQuery.total = response.data.total; | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		init(id, isdetail) { | ||||||
|  | 			this.initData(); | ||||||
|  | 			this.isdetail = isdetail || false; | ||||||
|  | 			this.dataForm.id = id || undefined; | ||||||
|  | 			this.visible = true; | ||||||
|  | 			if (id) { | ||||||
|  | 				this.idAttrShow = true | ||||||
|  | 			} else { | ||||||
|  | 				this.idAttrShow = false | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			this.$nextTick(() => { | ||||||
|  | 				this.$refs['dataForm'].resetFields(); | ||||||
|  | 
 | ||||||
|  | 				if (this.dataForm.id) { | ||||||
|  | 					// 获取物料详情 | ||||||
|  | 					this.urlOptions.infoURL(id).then(response => { | ||||||
|  |             this.dataForm = response.data; | ||||||
|  |           }); | ||||||
|  | 					// 获取物料的属性列表 | ||||||
|  | 					this.getList(); | ||||||
|  | 				} else { | ||||||
|  | 					if (this.urlOptions.isGetCode) { | ||||||
|  |             this.getCode() | ||||||
|  |           } | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		goback() { | ||||||
|  | 			this.$emit('refreshDataList'); | ||||||
|  | 			this.visible = false; | ||||||
|  | 			// this.initData(); | ||||||
|  | 		}, | ||||||
|  | 		goEdit() { | ||||||
|  | 			this.isdetail = false; | ||||||
|  | 		}, | ||||||
|  | 		// 新增 / 修改 | ||||||
|  | 		addNew(id) { | ||||||
|  | 			this.addOrUpdateVisible = true; | ||||||
|  | 			this.$nextTick(() => { | ||||||
|  | 				this.$refs.addOrUpdate.init(id); | ||||||
|  | 			}); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | <style scoped> | ||||||
|  | .drawer >>> .el-drawer { | ||||||
|  | 	border-radius: 8px 0 0 8px; | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .el-form-item__label { | ||||||
|  | 	padding: 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .el-drawer__header { | ||||||
|  | 	margin: 0; | ||||||
|  | 	padding: 32px 32px 24px; | ||||||
|  | 	border-bottom: 1px solid #dcdfe6; | ||||||
|  | } | ||||||
|  | .drawer >>> .el-drawer__body { | ||||||
|  | 	flex: 1; | ||||||
|  | 	height: 1px; | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .content { | ||||||
|  | 	padding: 30px 24px; | ||||||
|  | 	flex: 1; | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | 	/* height: 100%; */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .visual-part { | ||||||
|  | 	flex: 1 auto; | ||||||
|  | 	max-height: 76vh; | ||||||
|  | 	overflow: hidden; | ||||||
|  | 	overflow-y: scroll; | ||||||
|  | 	padding-right: 10px; /* 调整滚动条样式 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .el-form, | ||||||
|  | .drawer >>> .attr-list { | ||||||
|  | 	padding: 0 16px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer-body__footer { | ||||||
|  | 	display: flex; | ||||||
|  | 	justify-content: flex-end; | ||||||
|  | 	padding: 18px; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										141
									
								
								src/views/base/material/attr-add.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,141 @@ | |||||||
|  | <template> | ||||||
|  | 	<el-dialog | ||||||
|  | 		:visible.sync="visible" | ||||||
|  | 		:width="'35%'" | ||||||
|  | 		:append-to-body="true" | ||||||
|  | 		:close-on-click-modal="false" | ||||||
|  | 		class="dialog"> | ||||||
|  | 		<template #title> | ||||||
|  | 			<slot name="title"> | ||||||
|  | 				<div class="titleStyle"> | ||||||
|  | 					{{ !dataForm.id ? '新增' : '编辑' }} | ||||||
|  | 				</div> | ||||||
|  | 			</slot> | ||||||
|  | 		</template> | ||||||
|  | 
 | ||||||
|  | 		<el-form | ||||||
|  | 			ref="dataForm" | ||||||
|  | 			:model="dataForm" | ||||||
|  | 			:rules="dataRule" | ||||||
|  | 			label-width="100px" | ||||||
|  | 			@keyup.enter.native="dataFormSubmit()"> | ||||||
|  | 			<el-form-item label="属性名" prop="attrName"> | ||||||
|  | 				<el-input | ||||||
|  | 					v-model="dataForm.attrName" | ||||||
|  | 					placeholder="请输入属性名" | ||||||
|  | 					clearable /> | ||||||
|  | 			</el-form-item> | ||||||
|  | 			<el-form-item label="属性值" prop="attrValue"> | ||||||
|  | 				<el-input | ||||||
|  | 					v-model="dataForm.attrValue" | ||||||
|  | 					placeholder="请输入属性值" | ||||||
|  | 					clearable /> | ||||||
|  | 			</el-form-item> | ||||||
|  | 		</el-form> | ||||||
|  | 
 | ||||||
|  | 		<el-row style="text-align: right"> | ||||||
|  | 			<el-button @click="visible = false">取消</el-button> | ||||||
|  | 			<el-button type="primary" @click="dataFormSubmit()">确定</el-button> | ||||||
|  | 		</el-row> | ||||||
|  | 	</el-dialog> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import { | ||||||
|  | 	createMaterialAttr, | ||||||
|  | 	updateMaterialAttr, | ||||||
|  | 	getMaterialAttr | ||||||
|  | } from '@/api/base/material'; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	props: { | ||||||
|  | 		materialId: { | ||||||
|  | 			type: String, | ||||||
|  | 			default: '', | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			visible: false, | ||||||
|  | 			dataForm: { | ||||||
|  | 				id: undefined, | ||||||
|  | 				attrName: '', | ||||||
|  | 				attrValue: '', | ||||||
|  | 			}, | ||||||
|  | 			dataRule: { | ||||||
|  | 				attrName: [{ required: true, message: '名称不能为空', trigger: 'blur' }], | ||||||
|  | 			}, | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		init(id) { | ||||||
|  | 			this.dataForm.id = id || ''; | ||||||
|  | 			this.visible = true; | ||||||
|  | 			this.$nextTick(() => { | ||||||
|  | 				this.$refs['dataForm'].resetFields(); | ||||||
|  | 				if (this.dataForm.id) { | ||||||
|  | 					getMaterialAttr({ | ||||||
|  | 						id: this.dataForm.id | ||||||
|  | 					}).then((res) => { | ||||||
|  | 						const { attrName, attrValue } = res.data; | ||||||
|  | 						this.dataForm.attrName = attrName; | ||||||
|  | 						this.dataForm.attrValue = attrValue; | ||||||
|  | 					}); | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		// 表单提交 | ||||||
|  | 		dataFormSubmit() { | ||||||
|  | 			this.$refs['dataForm'].validate((valid) => { | ||||||
|  | 				if (valid) { | ||||||
|  | 					// 修改的提交 | ||||||
|  | 					if (this.dataForm.id) { | ||||||
|  | 						updateMaterialAttr({ | ||||||
|  | 							...this.dataForm, | ||||||
|  | 							materialId: this.materialId, | ||||||
|  | 						}).then((response) => { | ||||||
|  | 							this.$modal.msgSuccess('修改成功'); | ||||||
|  | 							this.visible = false; | ||||||
|  | 							this.$emit('refreshDataList'); | ||||||
|  | 						}); | ||||||
|  | 						return; | ||||||
|  | 					} | ||||||
|  | 					// 添加的提交 | ||||||
|  | 					createMaterialAttr({ | ||||||
|  | 						...this.dataForm, | ||||||
|  | 						materialId: this.materialId, | ||||||
|  | 					}).then((response) => { | ||||||
|  | 						this.$modal.msgSuccess('新增成功'); | ||||||
|  | 						this.visible = false; | ||||||
|  | 						this.$emit('refreshDataList'); | ||||||
|  | 					}); | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style scoped> | ||||||
|  | .dialog >>> .el-dialog__body { | ||||||
|  | 	padding: 30px 24px; | ||||||
|  | } | ||||||
|  | .dialog >>> .el-dialog__header { | ||||||
|  | 	font-size: 16px; | ||||||
|  | 	color: rgba(0, 0, 0, 0.85); | ||||||
|  | 	font-weight: 500; | ||||||
|  | 	padding: 13px 24px; | ||||||
|  | 	border-bottom: 1px solid #e9e9e9; | ||||||
|  | } | ||||||
|  | .dialog >>> .el-dialog__header .titleStyle::before { | ||||||
|  | 	content: ''; | ||||||
|  | 	display: inline-block; | ||||||
|  | 	width: 4px; | ||||||
|  | 	height: 16px; | ||||||
|  | 	background-color: #0b58ff; | ||||||
|  | 	border-radius: 1px; | ||||||
|  | 	margin-right: 8px; | ||||||
|  | 	position: relative; | ||||||
|  | 	top: 2px; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										233
									
								
								src/views/base/material/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,233 @@ | |||||||
|  | <template> | ||||||
|  | 	<div class="app-container"> | ||||||
|  | 		<search-bar | ||||||
|  | 			:formConfigs="formConfig" | ||||||
|  | 			ref="searchBarForm" | ||||||
|  | 			@headBtnClick="buttonClick" /> | ||||||
|  | 		<base-table | ||||||
|  | 			v-loading="dataListLoading" | ||||||
|  | 			:table-props="tableProps" | ||||||
|  | 			:page="listQuery.pageNo" | ||||||
|  | 			:limit="listQuery.pageSize" | ||||||
|  | 			:table-data="tableData"> | ||||||
|  | 			<method-btn | ||||||
|  | 				v-if="tableBtn.length" | ||||||
|  | 				slot="handleBtn" | ||||||
|  | 				:width="220" | ||||||
|  | 				label="操作" | ||||||
|  | 				:method-list="tableBtn" | ||||||
|  | 				@clickBtn="handleClick" /> | ||||||
|  | 		</base-table> | ||||||
|  | 		<pagination | ||||||
|  | 			:limit.sync="listQuery.pageSize" | ||||||
|  | 			:page.sync="listQuery.pageNo" | ||||||
|  | 			:total="listQuery.total" | ||||||
|  | 			@pagination="getDataList" /> | ||||||
|  | 		<add-or-update | ||||||
|  | 			v-if="addOrUpdateVisible" | ||||||
|  | 			ref="addOrUpdate" | ||||||
|  | 			@refreshDataList="getDataList" /> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import AddOrUpdate from './add-or-updata'; | ||||||
|  | import basicPage from '../../core/mixins/basic-page'; | ||||||
|  | import { parseTime } from '../../core/mixins/code-filter'; | ||||||
|  | import { | ||||||
|  | 	getMaterialPage, | ||||||
|  | 	deleteMaterial | ||||||
|  | } from '@/api/base/material'; | ||||||
|  | import { listData } from "@/api/system/dict/data"; | ||||||
|  | 
 | ||||||
|  | const tableProps = [ | ||||||
|  | 	{ | ||||||
|  | 		prop: 'createTime', | ||||||
|  | 		label: '添加时间', | ||||||
|  | 		filter: parseTime | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'code', | ||||||
|  | 		label: '物料编码' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'name', | ||||||
|  | 		label: '物料名称' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'engName', | ||||||
|  | 		label: '英文名称' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'abbr', | ||||||
|  | 		label: '缩写' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'materialType', | ||||||
|  | 		label: '物料类型' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'supplierName', | ||||||
|  | 		label: '供应商' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'remark', | ||||||
|  | 		label: '备注' | ||||||
|  | 	} | ||||||
|  | ]; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	mixins: [basicPage], | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			urlOptions: { | ||||||
|  | 				getDataListURL: getMaterialPage, | ||||||
|  | 				deleteURL: deleteMaterial | ||||||
|  | 				// exportURL: exportFactoryExcel, | ||||||
|  | 			}, | ||||||
|  | 			tableProps, | ||||||
|  | 			tableBtn: [ | ||||||
|  | 				this.$auth.hasPermi(`base:material:update`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'edit', | ||||||
|  | 							btnName: '编辑', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 					this.$auth.hasPermi(`base:material:queryAttr`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'search', | ||||||
|  | 							btnName: '查看属性', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 					this.$auth.hasPermi(`base:material:editAttr`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'editAttr', | ||||||
|  | 							btnName: '编辑属性', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  |           this.$auth.hasPermi(`base:material:delete`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'delete', | ||||||
|  | 							btnName: '删除', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 			].filter((v)=>v), | ||||||
|  | 			tableData: [], | ||||||
|  | 			typeList: [], | ||||||
|  | 			formConfig: [ | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '关键字', | ||||||
|  | 					placeholder: '物料名称', | ||||||
|  | 					param: 'name', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '关键字', | ||||||
|  | 					placeholder: '物料编码', | ||||||
|  | 					param: 'code', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'button', | ||||||
|  | 					btnName: '查询', | ||||||
|  | 					name: 'search', | ||||||
|  | 					color: 'primary', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'separate', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: this.$auth.hasPermi('base:material:create') ? 'button' : '', | ||||||
|  | 					btnName: '新增物料', | ||||||
|  | 					name: 'add', | ||||||
|  | 					color: 'success', | ||||||
|  | 					plain: true | ||||||
|  | 				}, | ||||||
|  | 			], | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	components: { | ||||||
|  | 		AddOrUpdate, | ||||||
|  | 	}, | ||||||
|  | 	created() { | ||||||
|  | 		this.getDict() | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		async getDict() { | ||||||
|  | 			// 物料类型列表 | ||||||
|  | 			const res = await listData({ | ||||||
|  | 				pageNo: 1, | ||||||
|  |         pageSize: 99, | ||||||
|  |         dictType: 'material_type', | ||||||
|  | 			}); | ||||||
|  | 			this.typeList = res.data.list.map(item => { | ||||||
|  | 				return { | ||||||
|  | 					label: item.label, | ||||||
|  | 					value: Number(item.value) | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		otherMethods(val) { | ||||||
|  | 			if (val.type === 'search') { | ||||||
|  | 				this.addOrUpdateVisible = true; | ||||||
|  | 				this.addOrEditTitle = '详情'; | ||||||
|  | 				this.$nextTick(() => { | ||||||
|  | 					this.$refs.addOrUpdate.init(val.data.id, true); | ||||||
|  | 				}); | ||||||
|  | 			} else { | ||||||
|  | 				this.addOrEditTitle = '编辑'; | ||||||
|  | 				this.addOrUpdateVisible = true; | ||||||
|  | 				this.$nextTick(() => { | ||||||
|  | 					this.$refs.addOrUpdate.init(val.data.id); | ||||||
|  | 				}); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		// 获取数据列表 | ||||||
|  |     getDataList() { | ||||||
|  |       this.dataListLoading = true; | ||||||
|  |       this.urlOptions.getDataListURL(this.listQuery).then(response => { | ||||||
|  |         this.tableData = response.data.records.map(item => { | ||||||
|  | 					this.typeList.filter(t => { | ||||||
|  | 						if (item.type === t.value) { | ||||||
|  | 							item.materialType = t.label | ||||||
|  | 						} | ||||||
|  | 					}) | ||||||
|  | 					return item | ||||||
|  | 				}); | ||||||
|  |         this.listQuery.total = response.data.total; | ||||||
|  |         this.dataListLoading = false; | ||||||
|  |       }); | ||||||
|  |     }, | ||||||
|  | 		buttonClick(val) { | ||||||
|  | 			switch (val.btnName) { | ||||||
|  | 				case 'search': | ||||||
|  | 					this.listQuery.pageNo = 1; | ||||||
|  | 					this.listQuery.pageSize = 10; | ||||||
|  | 					this.listQuery.name = val.name ? val.name : undefined; | ||||||
|  | 					this.listQuery.code = val.code ? val.code : undefined; | ||||||
|  | 					this.getDataList(); | ||||||
|  | 					break; | ||||||
|  | 				case 'reset': | ||||||
|  | 					this.$refs.searchBarForm.resetForm(); | ||||||
|  | 					this.listQuery = { | ||||||
|  | 						pageSize: 10, | ||||||
|  | 						pageNo: 1, | ||||||
|  | 						total: 1, | ||||||
|  | 					}; | ||||||
|  | 					this.getDataList(); | ||||||
|  | 					break; | ||||||
|  | 				case 'add': | ||||||
|  | 					this.addOrEditTitle = '新增'; | ||||||
|  | 					this.addOrUpdateVisible = true; | ||||||
|  | 					this.addOrUpdateHandle(); | ||||||
|  | 					break; | ||||||
|  | 				case 'export': | ||||||
|  | 					this.handleExport(); | ||||||
|  | 					break; | ||||||
|  | 				default: | ||||||
|  | 					console.log(val); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
							
								
								
									
										107
									
								
								src/views/base/materialDate/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,107 @@ | |||||||
|  | <!-- | ||||||
|  |  * @Author: zwq | ||||||
|  |  * @Date: 2021-11-18 14:16:25 | ||||||
|  |  * @LastEditors: DY | ||||||
|  |  * @LastEditTime: 2023-10-24 18:34:07 | ||||||
|  |  * @Description: | ||||||
|  | --> | ||||||
|  | <template> | ||||||
|  | 	<el-form | ||||||
|  | 		:model="dataForm" | ||||||
|  | 		:rules="dataRule" | ||||||
|  | 		ref="dataForm" | ||||||
|  | 		@keyup.enter.native="dataFormSubmit()" | ||||||
|  | 		label-width="80px"> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="物料名称" prop="materialId"> | ||||||
|  | 					<el-select | ||||||
|  | 						v-model="dataForm.materialId" | ||||||
|  | 						placeholder="请选择物料" | ||||||
|  | 						@change="setMaterialCode"> | ||||||
|  | 						<el-option | ||||||
|  | 							v-for="dict in materialList" | ||||||
|  | 							:key="dict.id" | ||||||
|  | 							:label="dict.name" | ||||||
|  | 							:value="dict.id" /> | ||||||
|  | 					</el-select> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="物料编码" prop="materialCode"> | ||||||
|  | 					<el-input | ||||||
|  | 						v-model="dataForm.materialCode" | ||||||
|  | 						disabled | ||||||
|  | 						placeholder="请输入物料编码" /> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="批次号" prop="code"> | ||||||
|  | 					<el-input v-model="dataForm.code" clearable placeholder="请输入批次号" /> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="批次名称" prop="name"> | ||||||
|  | 					<el-input v-model="dataForm.name" clearable placeholder="请输入批次名称" /> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 		<el-form-item label="备注" prop="remark"> | ||||||
|  | 			<el-input v-model="dataForm.remark" clearable placeholder="请输入备注" /> | ||||||
|  | 		</el-form-item> | ||||||
|  | 	</el-form> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import basicAdd from '../../core/mixins/basic-add'; | ||||||
|  | import { createMaterialDate, updateMaterialDate, getMaterialDate, getCode } from "@/api/base/materialDate"; | ||||||
|  | import { getMaterialList } from "@/api/base/material"; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	mixins: [basicAdd], | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			urlOptions: { | ||||||
|  | 			  isGetCode: true, | ||||||
|  |         codeURL: getCode, | ||||||
|  | 				createURL: createMaterialDate, | ||||||
|  | 				updateURL: updateMaterialDate, | ||||||
|  | 				infoURL: getMaterialDate, | ||||||
|  | 			}, | ||||||
|  | 			dataForm: { | ||||||
|  |         id: undefined, | ||||||
|  |         code: undefined, | ||||||
|  |         name: undefined, | ||||||
|  |         materialId: undefined, | ||||||
|  | 				materialCode: undefined, | ||||||
|  |         remark: undefined, | ||||||
|  | 			}, | ||||||
|  | 			materialList: [], | ||||||
|  | 			dataRule: { | ||||||
|  | 				materialId: [{ required: true, message: "物料不能为空", trigger: "blur" }], | ||||||
|  |         code: [{ required: true, message: "工厂编码不能为空", trigger: "blur" }], | ||||||
|  |         name: [{ required: true, message: "工厂名称不能为空", trigger: "blur" }], | ||||||
|  |       } | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	mounted() { | ||||||
|  | 		this.getDict() | ||||||
|  | 		console.log('我看看', this.dataForm) | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		async getDict() { | ||||||
|  | 			// 物料列表 | ||||||
|  | 			const res = await getMaterialList(); | ||||||
|  | 			this.materialList = res.data; | ||||||
|  | 		}, | ||||||
|  | 		setMaterialCode() { | ||||||
|  | 			const chooseM = this.materialList.filter(item => { | ||||||
|  | 				return item.id === this.dataForm.materialId | ||||||
|  | 			}) | ||||||
|  | 			this.dataForm.materialCode = chooseM[0].code | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
							
								
								
									
										169
									
								
								src/views/base/materialDate/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,169 @@ | |||||||
|  | <template> | ||||||
|  | 	<div class="app-container"> | ||||||
|  | 		<search-bar | ||||||
|  | 			:formConfigs="formConfig" | ||||||
|  | 			ref="searchBarForm" | ||||||
|  | 			@headBtnClick="buttonClick" /> | ||||||
|  | 		<base-table | ||||||
|  | 			v-loading="dataListLoading" | ||||||
|  | 			:table-props="tableProps" | ||||||
|  | 			:page="listQuery.pageNo" | ||||||
|  | 			:limit="listQuery.pageSize" | ||||||
|  | 			:table-data="tableData"> | ||||||
|  | 			<method-btn | ||||||
|  | 				v-if="tableBtn.length" | ||||||
|  | 				slot="handleBtn" | ||||||
|  | 				:width="120" | ||||||
|  | 				label="操作" | ||||||
|  | 				:method-list="tableBtn" | ||||||
|  | 				@clickBtn="handleClick" /> | ||||||
|  | 		</base-table> | ||||||
|  | 		<pagination | ||||||
|  | 			:limit.sync="listQuery.pageSize" | ||||||
|  | 			:page.sync="listQuery.pageNo" | ||||||
|  | 			:total="listQuery.total" | ||||||
|  | 			@pagination="getDataList" /> | ||||||
|  | 		<base-dialog | ||||||
|  | 			:dialogTitle="addOrEditTitle" | ||||||
|  | 			:dialogVisible="addOrUpdateVisible" | ||||||
|  | 			@cancel="handleCancel" | ||||||
|  | 			@confirm="handleConfirm" | ||||||
|  | 			:before-close="handleCancel" | ||||||
|  | 			width="50%"> | ||||||
|  | 			<add-or-update | ||||||
|  | 				ref="addOrUpdate" | ||||||
|  | 				@refreshDataList="successSubmit"></add-or-update> | ||||||
|  | 		</base-dialog> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import AddOrUpdate from './add-or-updata'; | ||||||
|  | import basicPage from '../../core/mixins/basic-page'; | ||||||
|  | import { parseTime } from '../../core/mixins/code-filter'; | ||||||
|  | import { | ||||||
|  | 	getMaterDatePage, | ||||||
|  | 	deleteMaterialDate | ||||||
|  | } from '@/api/base/materialDate'; | ||||||
|  | 
 | ||||||
|  | const tableProps = [ | ||||||
|  | 	{ | ||||||
|  | 		prop: 'createTime', | ||||||
|  | 		label: '添加时间', | ||||||
|  | 		filter: parseTime | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'code', | ||||||
|  | 		label: '批次号' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'name', | ||||||
|  | 		label: '批次名称' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'materialCode', | ||||||
|  | 		label: '物料编码' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'materialName', | ||||||
|  | 		label: '物料名称' | ||||||
|  | 	}, | ||||||
|  | ]; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	mixins: [basicPage], | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			urlOptions: { | ||||||
|  | 				getDataListURL: getMaterDatePage, | ||||||
|  | 				deleteURL: deleteMaterialDate, | ||||||
|  | 				// exportURL: exportFactoryExcel, | ||||||
|  | 			}, | ||||||
|  | 			tableProps, | ||||||
|  | 			tableBtn: [ | ||||||
|  | 				this.$auth.hasPermi(`base:material-date:update`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'edit', | ||||||
|  | 							btnName: '编辑', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  |           this.$auth.hasPermi(`base:material-date:delete`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'delete', | ||||||
|  | 							btnName: '删除', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 			].filter((v)=>v), | ||||||
|  | 			tableData: [], | ||||||
|  | 			formConfig: [ | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '批次名', | ||||||
|  | 					placeholder: '批次名', | ||||||
|  | 					param: 'name', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'button', | ||||||
|  | 					btnName: '查询', | ||||||
|  | 					name: 'search', | ||||||
|  | 					color: 'primary', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'separate', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: this.$auth.hasPermi('base:material-date:create') ? 'button' : '', | ||||||
|  | 					btnName: '新增', | ||||||
|  | 					name: 'add', | ||||||
|  | 					color: 'success', | ||||||
|  | 					plain: true | ||||||
|  | 				}, | ||||||
|  | 			], | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	components: { | ||||||
|  | 		AddOrUpdate, | ||||||
|  | 	}, | ||||||
|  | 	created() {}, | ||||||
|  | 	methods: { | ||||||
|  | 		// 获取数据列表 | ||||||
|  |     getDataList() { | ||||||
|  |       this.dataListLoading = true; | ||||||
|  |       this.urlOptions.getDataListURL(this.listQuery).then(response => { | ||||||
|  |         this.tableData = response.data.records; | ||||||
|  |         this.listQuery.total = response.data.total; | ||||||
|  |         this.dataListLoading = false; | ||||||
|  |       }); | ||||||
|  |     }, | ||||||
|  | 		buttonClick(val) { | ||||||
|  | 			switch (val.btnName) { | ||||||
|  | 				case 'search': | ||||||
|  | 					this.listQuery.pageNo = 1; | ||||||
|  | 					this.listQuery.pageSize = 10; | ||||||
|  | 					this.listQuery.name = val.name ? val.name : undefined; | ||||||
|  | 					this.getDataList(); | ||||||
|  | 					break; | ||||||
|  | 				case 'reset': | ||||||
|  | 					this.$refs.searchBarForm.resetForm(); | ||||||
|  | 					this.listQuery = { | ||||||
|  | 						pageSize: 10, | ||||||
|  | 						pageNo: 1, | ||||||
|  | 						total: 1, | ||||||
|  | 					}; | ||||||
|  | 					this.getDataList(); | ||||||
|  | 					break; | ||||||
|  | 				case 'add': | ||||||
|  | 					this.addOrEditTitle = '新增'; | ||||||
|  | 					this.addOrUpdateVisible = true; | ||||||
|  | 					this.addOrUpdateHandle(); | ||||||
|  | 					break; | ||||||
|  | 				case 'export': | ||||||
|  | 					this.handleExport(); | ||||||
|  | 					break; | ||||||
|  | 				default: | ||||||
|  | 					console.log(val); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
							
								
								
									
										469
									
								
								src/views/base/materialProductBom/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,469 @@ | |||||||
|  | <!-- | ||||||
|  |  * @Author: zwq | ||||||
|  |  * @Date: 2021-11-18 14:16:25 | ||||||
|  |  * @LastEditors: DY | ||||||
|  |  * @LastEditTime: 2023-10-27 16:06:44 | ||||||
|  |  * @Description: | ||||||
|  | --> | ||||||
|  | <template> | ||||||
|  | 	<el-drawer | ||||||
|  | 		:visible.sync="visible" | ||||||
|  | 		:show-close="false" | ||||||
|  | 		:wrapper-closable="false" | ||||||
|  | 		class="drawer" | ||||||
|  | 		size="70%"> | ||||||
|  | 		<small-title slot="title" :no-padding="true"> | ||||||
|  | 			{{ isdetail ? '详情' : !dataForm.id ? '新增' : '编辑' }} | ||||||
|  | 		</small-title> | ||||||
|  | 		<div class="content"> | ||||||
|  | 			<div class="visual-part"> | ||||||
|  | 				<el-form | ||||||
|  | 					:model="dataForm" | ||||||
|  | 					:rules="dataRule" | ||||||
|  | 					ref="dataForm" | ||||||
|  | 					@keyup.enter.native="dataFormSubmit()" | ||||||
|  | 					label-width="100px" | ||||||
|  | 					label-position="top"> | ||||||
|  | 					<el-row :gutter="20"> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="产品名称" prop="productId"> | ||||||
|  | 								<el-select | ||||||
|  | 									v-model="dataForm.productId" | ||||||
|  | 									filterable | ||||||
|  | 									:disabled="isdetail" | ||||||
|  | 									placeholder="请选择产品"> | ||||||
|  | 									<el-option | ||||||
|  | 										v-for="dict in productList" | ||||||
|  | 										:key="dict.id" | ||||||
|  | 										:label="dict.name" | ||||||
|  | 										:value="dict.id" /> | ||||||
|  | 								</el-select> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 						<el-col :span="12"> | ||||||
|  | 							<el-form-item label="产品BOM编码" prop="code"> | ||||||
|  | 								<el-input v-model="dataForm.code" disabled placeholder="请输入产品Bom编码" /> | ||||||
|  | 							</el-form-item> | ||||||
|  | 						</el-col> | ||||||
|  | 					</el-row> | ||||||
|  | 					<el-form-item label="备注" prop="remark"> | ||||||
|  | 						<el-input v-model="dataForm.remark" :disabled="isdetail" clearable placeholder="请输入备注" /> | ||||||
|  | 					</el-form-item> | ||||||
|  | 				</el-form> | ||||||
|  | 			</div> | ||||||
|  | 			<div class="attr-list" v-if="idAttrShow"> | ||||||
|  | 				<small-title | ||||||
|  | 					style="margin: 16px 0; padding-left: 8px" | ||||||
|  | 					:no-padding="true"> | ||||||
|  | 					BOM明细 | ||||||
|  | 				</small-title> | ||||||
|  | 
 | ||||||
|  | 				<!-- <base-table | ||||||
|  | 					:table-props="tableProps" | ||||||
|  | 					:page="listQuery.pageNo" | ||||||
|  | 					:limit="listQuery.pageSize" | ||||||
|  | 					:add-button-show="isdetail ? null : '添加属性'" | ||||||
|  | 					@emitButtonClick="addNew()" | ||||||
|  | 					:table-data="materialAttrList"> | ||||||
|  | 					<method-btn | ||||||
|  | 						v-if="!isdetail" | ||||||
|  | 						slot="handleBtn" | ||||||
|  | 						:width="120" | ||||||
|  | 						label="操作" | ||||||
|  | 						:method-list="tableBtn" | ||||||
|  | 						@clickBtn="handleClick" /> | ||||||
|  | 				</base-table> --> | ||||||
|  | 				<el-button v-show="!isdetail" type="success" size="small" style="float: right" @click="addRow()">添加一行</el-button> | ||||||
|  | 				<el-table | ||||||
|  | 					:data="tableData" | ||||||
|  |       		style="width: 100%"> | ||||||
|  | 					<el-table-column type="index" label="序号" /> | ||||||
|  | 					<el-table-column prop="createTime" label="添加时间"> | ||||||
|  | 						<template slot-scope="scope"> | ||||||
|  | 							<span>{{ parseTime(scope.row.createTime) }}</span> | ||||||
|  | 						</template> | ||||||
|  | 					</el-table-column> | ||||||
|  | 					<el-table-column prop="materialId" label="物料名称"> | ||||||
|  | 						<template slot-scope="scope"> | ||||||
|  | 							<el-select | ||||||
|  | 									v-model="scope.row.materialId" | ||||||
|  | 									filterable | ||||||
|  | 									:disabled="!scope.row.isEdit" | ||||||
|  | 									placeholder="请选择物料" | ||||||
|  | 									@change="setCode(scope.row)"> | ||||||
|  | 									<el-option | ||||||
|  | 										v-for="dict in materialList" | ||||||
|  | 										:key="dict.id" | ||||||
|  | 										:label="dict.name" | ||||||
|  | 										:value="dict.id" /> | ||||||
|  | 								</el-select> | ||||||
|  | 						</template> | ||||||
|  | 					</el-table-column> | ||||||
|  | 					<el-table-column prop="materialCode" label="物料编码" /> | ||||||
|  | 					<el-table-column prop="mUnit" label="单位" /> | ||||||
|  | 					<el-table-column prop="num" label="数量"> | ||||||
|  | 						<template slot-scope="scope"> | ||||||
|  | 							<el-input v-model="scope.row.num" :disabled="!scope.row.isEdit"></el-input> | ||||||
|  | 						</template> | ||||||
|  | 					</el-table-column> | ||||||
|  | 					<el-table-column prop="remark" label="备注"> | ||||||
|  | 						<template slot-scope="scope"> | ||||||
|  | 							<el-input v-model="scope.row.remark" :disabled="!scope.row.isEdit"></el-input> | ||||||
|  | 						</template> | ||||||
|  | 					</el-table-column> | ||||||
|  | 					<el-table-column v-if="!isdetail" label="操作"> | ||||||
|  | 						<template slot-scope="scope"> | ||||||
|  | 							<el-tooltip v-if="!scope.row.isEdit" placement="top" content="编辑"> | ||||||
|  | 								<el-button | ||||||
|  | 									type="text" | ||||||
|  | 									:style="{color:'#0B58FF'}" | ||||||
|  | 									size="mini" | ||||||
|  | 									@click="edit(scope.row)" | ||||||
|  | 								> | ||||||
|  | 									<!-- 此处的icon的名字命名为'table_'加上按钮的type --> | ||||||
|  | 									<svg-icon style="width: 18px; height: 18px" class="item-icon" icon-class="edit" /> | ||||||
|  | 									<!-- <span>{{ item.btnName | i18nFilter }}</span> --> | ||||||
|  | 								</el-button> | ||||||
|  | 							</el-tooltip> | ||||||
|  | 							<el-button v-else type="primary" size="small" @click="saveData(scope.row)">保存</el-button> | ||||||
|  | 							<el-tooltip placement="top" content="删除"> | ||||||
|  | 								<el-button | ||||||
|  | 									type="text" | ||||||
|  | 									:style="{color:'#FF5454'}" | ||||||
|  | 									size="mini" | ||||||
|  | 									@click="deleteDetail(scope.row)" | ||||||
|  | 								> | ||||||
|  | 									<!-- 此处的icon的名字命名为'table_'加上按钮的type --> | ||||||
|  | 									<svg-icon style="width: 18px; height: 18px" class="item-icon" icon-class="table_delete" /> | ||||||
|  | 									<!-- <span>{{ item.btnName | i18nFilter }}</span> --> | ||||||
|  | 								</el-button> | ||||||
|  | 							</el-tooltip> | ||||||
|  | 						</template> | ||||||
|  | 					</el-table-column> | ||||||
|  | 				</el-table> | ||||||
|  | 				<pagination | ||||||
|  | 					v-show="listQuery.total > 0" | ||||||
|  | 					:total="listQuery.total" | ||||||
|  | 					:page.sync="listQuery.pageNo" | ||||||
|  | 					:limit.sync="listQuery.pageSize" | ||||||
|  | 					:page-sizes="[5, 10, 15]" | ||||||
|  | 					@pagination="getList" /> | ||||||
|  | 			</div> | ||||||
|  | 
 | ||||||
|  | 			<div class="drawer-body__footer"> | ||||||
|  | 				<el-button style="" @click="goback()">取消</el-button> | ||||||
|  | 				<el-button v-if="isdetail" type="primary" @click="goEdit()"> | ||||||
|  | 					编辑 | ||||||
|  | 				</el-button> | ||||||
|  | 				<el-button v-else type="primary" @click="dataFormSubmit()">确定</el-button> | ||||||
|  | 			</div> | ||||||
|  | 		</div> | ||||||
|  | 
 | ||||||
|  | 		<!-- <attr-add | ||||||
|  | 			v-if="addOrUpdateVisible" | ||||||
|  | 			ref="addOrUpdate" | ||||||
|  | 			:material-id="dataForm.id" | ||||||
|  | 			@refreshDataList="getList" /> --> | ||||||
|  | 	</el-drawer> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import basicAdd from '../../core/mixins/basic-add'; | ||||||
|  | import { createMaterialPB, updateMaterialPB, getMaterialPB, getCode, getProList, getProBomList, createMaterialPBDet, updateMaterialPBDet, deleteMaterialPBDet } from "@/api/base/materialProductBom"; | ||||||
|  | import { getMaterialList } from "@/api/base/material"; | ||||||
|  | import { listData } from "@/api/system/dict/data"; | ||||||
|  | import SmallTitle from '../material/SmallTitle'; | ||||||
|  | import { parseTime } from '../../core/mixins/code-filter'; | ||||||
|  | // import attrAdd from './attr-add'; | ||||||
|  | 
 | ||||||
|  | const tableBtn = [ | ||||||
|  | 	{ | ||||||
|  | 		type: 'edit', | ||||||
|  | 		btnName: '编辑', | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		type: 'delete', | ||||||
|  | 		btnName: '删除', | ||||||
|  | 	}, | ||||||
|  | ]; | ||||||
|  | const tableProps = [ | ||||||
|  | 	{ | ||||||
|  | 		prop: 'createTime', | ||||||
|  | 		label: '添加时间', | ||||||
|  | 		filter: parseTime, | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'attrName', | ||||||
|  | 		label: '属性名', | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'attrValue', | ||||||
|  | 		label: '属性值', | ||||||
|  | 	}, | ||||||
|  | ]; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	mixins: [basicAdd], | ||||||
|  | 	components: { SmallTitle }, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			tableBtn, | ||||||
|  | 			tableProps, | ||||||
|  | 			addOrUpdateVisible: false, | ||||||
|  | 			urlOptions: { | ||||||
|  | 			  isGetCode: true, | ||||||
|  |         codeURL: getCode, | ||||||
|  | 				createURL: createMaterialPB, | ||||||
|  | 				updateURL: updateMaterialPB, | ||||||
|  | 				infoURL: getMaterialPB, | ||||||
|  | 			}, | ||||||
|  | 			listQuery: { | ||||||
|  | 				pageSize: 10, | ||||||
|  | 				pageNo: 1, | ||||||
|  | 				total: 0, | ||||||
|  | 			}, | ||||||
|  | 			dataForm: { | ||||||
|  |         id: undefined, | ||||||
|  |         code: undefined, | ||||||
|  |         productId: '', | ||||||
|  |         remark: undefined, | ||||||
|  | 			}, | ||||||
|  | 			productList: [], | ||||||
|  | 			materialAttrList: [], | ||||||
|  | 			materialList: [], | ||||||
|  | 			tableData: [], | ||||||
|  | 			unitList: [], | ||||||
|  | 			visible: false, | ||||||
|  | 			isdetail: false, | ||||||
|  | 			idAttrShow: false, | ||||||
|  | 			dataRule: { | ||||||
|  |         productId: [{ required: true, message: "产品不能为空", trigger: "blur" }] | ||||||
|  |       } | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	mounted() { | ||||||
|  | 		this.getDict() | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		async getDict() { | ||||||
|  | 			// 产品列表 | ||||||
|  | 			const proRes = await getProList(); | ||||||
|  | 			this.productList = proRes.data; | ||||||
|  | 			// 物料列表 | ||||||
|  | 			const res = await getMaterialList(); | ||||||
|  | 			this.materialList = res.data; | ||||||
|  | 			// 物料单位列表 | ||||||
|  | 			const unitRes = await listData({ | ||||||
|  | 				pageNo: 1, | ||||||
|  |         pageSize: 99, | ||||||
|  |         dictType: 'goods_unit', | ||||||
|  | 			}); | ||||||
|  | 			this.unitList = unitRes.data.list.map(item => { | ||||||
|  | 				return { | ||||||
|  | 					label: item.label, | ||||||
|  | 					value: Number(item.value) | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		initData() { | ||||||
|  | 			// this.materialAttrList.splice(0); | ||||||
|  | 			this.listQuery.total = 0; | ||||||
|  | 		}, | ||||||
|  | 		deleteDetail(raw) { | ||||||
|  | 			this.$confirm( | ||||||
|  | 				`确定删除关于物料编码为${ | ||||||
|  | 					raw.materialCode}的数据?`, | ||||||
|  | 				'提示', | ||||||
|  | 				{ | ||||||
|  | 					confirmButtonText: '确定', | ||||||
|  | 					cancelButtonText: '取消', | ||||||
|  | 					type: 'warning', | ||||||
|  | 				} | ||||||
|  | 			) | ||||||
|  | 				.then(() => { | ||||||
|  | 					deleteMaterialPBDet(raw.id).then(({ data }) => { | ||||||
|  | 						this.$message({ | ||||||
|  | 							message: '操作成功', | ||||||
|  | 							type: 'success', | ||||||
|  | 							duration: 1500, | ||||||
|  | 							onClose: () => { | ||||||
|  | 								this.getList(); | ||||||
|  | 							}, | ||||||
|  | 						}); | ||||||
|  | 					}); | ||||||
|  | 				}) | ||||||
|  | 				.catch(() => {}); | ||||||
|  | 		}, | ||||||
|  | 		setCode(row) { | ||||||
|  | 			this.materialList.filter(item => { | ||||||
|  | 				if (row.materialId === item.id) { | ||||||
|  | 					row.materialCode = item.code | ||||||
|  | 				} | ||||||
|  | 				this.unitList.filter(u => { | ||||||
|  | 					if (item.unit === u.value) { | ||||||
|  | 						row.unit = u.value | ||||||
|  | 						row.mUnit = u.label | ||||||
|  | 					} | ||||||
|  | 				}) | ||||||
|  | 				// return row.materialId === item.id | ||||||
|  | 			}) | ||||||
|  | 			// row.materialCode = tempList[0].code | ||||||
|  | 			// row.unit = tempList[0].unit | ||||||
|  | 			console.log('row', row) | ||||||
|  | 		}, | ||||||
|  | 		edit(row) { | ||||||
|  | 			row.isEdit = true | ||||||
|  | 		}, | ||||||
|  | 		saveData(row) { | ||||||
|  | 			// this.$refs['dataForm'].validate((valid) => { | ||||||
|  | 				// if (valid) { | ||||||
|  | 				// 	修改的提交 | ||||||
|  | 				if (row.id) { | ||||||
|  | 					updateMaterialPBDet({ | ||||||
|  | 						...row | ||||||
|  | 					}).then((response) => { | ||||||
|  | 						this.$modal.msgSuccess('修改成功'); | ||||||
|  | 						// this.visible = false; | ||||||
|  | 						this.getList(); | ||||||
|  | 					}); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 					// 添加的提交 | ||||||
|  | 			createMaterialPBDet({ | ||||||
|  | 				...row | ||||||
|  | 			}).then((response) => { | ||||||
|  | 				this.$modal.msgSuccess('新增成功'); | ||||||
|  | 				// this.visible = false; | ||||||
|  | 				this.getList(); | ||||||
|  | 			}); | ||||||
|  | 				// } | ||||||
|  | 			// }); | ||||||
|  | 		}, | ||||||
|  | 		getList() { | ||||||
|  | 			// 获取产品Bom详细列表 | ||||||
|  | 			getProBomList({ | ||||||
|  | 				...this.listQuery, | ||||||
|  | 				bomId: this.dataForm.id, | ||||||
|  | 				createTime: ['2023-10-26 00:00:00', '2023-10-27 12:00:00'] | ||||||
|  | 			}).then((response) => { | ||||||
|  | 				this.tableData = response.data.records.map(item => { | ||||||
|  | 					this.unitList.filter(u => { | ||||||
|  | 						if (item.unit === u.value) { | ||||||
|  | 							item.mUnit = u.label | ||||||
|  | 						} | ||||||
|  | 					}) | ||||||
|  | 					item.isEdit = false | ||||||
|  | 					return item | ||||||
|  | 				}); | ||||||
|  | 				this.listQuery.total = response.data.total; | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		// 构造一行 | ||||||
|  | 		addRow() { | ||||||
|  | 			const row = { | ||||||
|  | 				bomId: this.dataForm.id, | ||||||
|  | 				materialId: '', | ||||||
|  | 				num: 0, | ||||||
|  | 				materialCode: undefined, | ||||||
|  | 				unit: undefined, | ||||||
|  | 				remark: '', | ||||||
|  | 				isEdit: true | ||||||
|  | 			} | ||||||
|  | 			this.tableData.push(row) | ||||||
|  | 		}, | ||||||
|  | 		init(id, isdetail) { | ||||||
|  | 			this.initData(); | ||||||
|  | 			this.isdetail = isdetail || false; | ||||||
|  | 			this.dataForm.id = id || undefined; | ||||||
|  | 			this.visible = true; | ||||||
|  | 			if (id) { | ||||||
|  | 				this.idAttrShow = true | ||||||
|  | 			} else { | ||||||
|  | 				this.idAttrShow = false | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			this.$nextTick(() => { | ||||||
|  | 				this.$refs['dataForm'].resetFields(); | ||||||
|  | 
 | ||||||
|  | 				if (this.dataForm.id) { | ||||||
|  | 					// 获取物料详情 | ||||||
|  | 					this.urlOptions.infoURL(id).then(response => { | ||||||
|  |             this.dataForm = response.data; | ||||||
|  |           }); | ||||||
|  | 					// 获取Bom明细 | ||||||
|  | 					this.getList(); | ||||||
|  | 				} else { | ||||||
|  | 					if (this.urlOptions.isGetCode) { | ||||||
|  |             this.getCode() | ||||||
|  |           } | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		goback() { | ||||||
|  | 			this.$emit('refreshDataList'); | ||||||
|  | 			this.visible = false; | ||||||
|  | 			// this.initData(); | ||||||
|  | 		}, | ||||||
|  | 		goEdit() { | ||||||
|  | 			this.isdetail = false; | ||||||
|  | 		}, | ||||||
|  | 		// 新增 / 修改 | ||||||
|  | 		addNew(id) { | ||||||
|  | 			this.addOrUpdateVisible = true; | ||||||
|  | 			this.$nextTick(() => { | ||||||
|  | 				this.$refs.addOrUpdate.init(id); | ||||||
|  | 			}); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | <style scoped> | ||||||
|  | .drawer >>> .el-drawer { | ||||||
|  | 	border-radius: 8px 0 0 8px; | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .el-form-item__label { | ||||||
|  | 	padding: 0; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .el-drawer__header { | ||||||
|  | 	margin: 0; | ||||||
|  | 	padding: 32px 32px 24px; | ||||||
|  | 	border-bottom: 1px solid #dcdfe6; | ||||||
|  | } | ||||||
|  | .drawer >>> .el-drawer__body { | ||||||
|  | 	flex: 1; | ||||||
|  | 	height: 1px; | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .content { | ||||||
|  | 	padding: 30px 24px; | ||||||
|  | 	flex: 1; | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | 	/* height: 100%; */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .visual-part { | ||||||
|  | 	flex: 1 auto; | ||||||
|  | 	max-height: 76vh; | ||||||
|  | 	overflow: hidden; | ||||||
|  | 	overflow-y: scroll; | ||||||
|  | 	padding-right: 10px; /* 调整滚动条样式 */ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer >>> .el-form, | ||||||
|  | .drawer >>> .attr-list { | ||||||
|  | 	padding: 0 16px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .drawer-body__footer { | ||||||
|  | 	display: flex; | ||||||
|  | 	justify-content: flex-end; | ||||||
|  | 	padding: 18px; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										187
									
								
								src/views/base/materialProductBom/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,187 @@ | |||||||
|  | <template> | ||||||
|  | 	<div class="app-container"> | ||||||
|  | 		<search-bar | ||||||
|  | 			:formConfigs="formConfig" | ||||||
|  | 			ref="searchBarForm" | ||||||
|  | 			@headBtnClick="buttonClick" /> | ||||||
|  | 		<base-table | ||||||
|  | 			v-loading="dataListLoading" | ||||||
|  | 			:table-props="tableProps" | ||||||
|  | 			:page="listQuery.pageNo" | ||||||
|  | 			:limit="listQuery.pageSize" | ||||||
|  | 			:table-data="tableData"> | ||||||
|  | 			<method-btn | ||||||
|  | 				v-if="tableBtn.length" | ||||||
|  | 				slot="handleBtn" | ||||||
|  | 				:width="220" | ||||||
|  | 				label="操作" | ||||||
|  | 				:method-list="tableBtn" | ||||||
|  | 				@clickBtn="handleClick" /> | ||||||
|  | 		</base-table> | ||||||
|  | 		<pagination | ||||||
|  | 			:limit.sync="listQuery.pageSize" | ||||||
|  | 			:page.sync="listQuery.pageNo" | ||||||
|  | 			:total="listQuery.total" | ||||||
|  | 			@pagination="getDataList" /> | ||||||
|  | 		<add-or-update | ||||||
|  | 			v-if="addOrUpdateVisible" | ||||||
|  | 			ref="addOrUpdate" | ||||||
|  | 			@refreshDataList="getDataList" /> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import AddOrUpdate from './add-or-updata'; | ||||||
|  | import basicPage from '../../core/mixins/basic-page'; | ||||||
|  | // import { parseTime } from '../../core/mixins/code-filter'; | ||||||
|  | import { | ||||||
|  | 	getMaterialPBPage, | ||||||
|  | 	deleteMaterialPB | ||||||
|  | } from '@/api/base/materialProductBom'; | ||||||
|  | 
 | ||||||
|  | const tableProps = [ | ||||||
|  | 	{ | ||||||
|  | 		prop: 'productName', | ||||||
|  | 		label: '产品名称' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'code', | ||||||
|  | 		label: '产品BOM编码' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'remark', | ||||||
|  | 		label: '备注' | ||||||
|  | 	} | ||||||
|  | ]; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	mixins: [basicPage], | ||||||
|  | 	components: { | ||||||
|  | 		AddOrUpdate, | ||||||
|  | 	}, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			urlOptions: { | ||||||
|  | 				getDataListURL: getMaterialPBPage, | ||||||
|  | 				deleteURL: deleteMaterialPB | ||||||
|  | 				// exportURL: exportFactoryExcel, | ||||||
|  | 			}, | ||||||
|  | 			tableProps, | ||||||
|  | 			tableBtn: [ | ||||||
|  | 				this.$auth.hasPermi(`base:material-product-bom:update`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'edit', | ||||||
|  | 							btnName: '编辑', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 					this.$auth.hasPermi(`base:material-product-bom:queryMaterial`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'search', | ||||||
|  | 							btnName: '查看物料', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 					this.$auth.hasPermi(`base:material-product-bom:editMaterial`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'editMaterial', | ||||||
|  | 							btnName: '编辑物料', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  |           this.$auth.hasPermi(`base:material-product-bom:delete`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'delete', | ||||||
|  | 							btnName: '删除', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 			].filter((v)=>v), | ||||||
|  | 			tableData: [], | ||||||
|  | 			formConfig: [ | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '关键字', | ||||||
|  | 					placeholder: '物料名称', | ||||||
|  | 					param: 'name', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '关键字', | ||||||
|  | 					placeholder: '物料编码', | ||||||
|  | 					param: 'code', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'button', | ||||||
|  | 					btnName: '查询', | ||||||
|  | 					name: 'search', | ||||||
|  | 					color: 'primary', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'separate', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: this.$auth.hasPermi('base:material:create') ? 'button' : '', | ||||||
|  | 					btnName: '新增', | ||||||
|  | 					name: 'add', | ||||||
|  | 					color: 'success', | ||||||
|  | 					plain: true | ||||||
|  | 				}, | ||||||
|  | 			], | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	created() {}, | ||||||
|  | 	methods: { | ||||||
|  | 		otherMethods(val) { | ||||||
|  | 			if (val.type === 'search') { | ||||||
|  | 				this.addOrUpdateVisible = true; | ||||||
|  | 				this.addOrEditTitle = '详情'; | ||||||
|  | 				this.$nextTick(() => { | ||||||
|  | 					this.$refs.addOrUpdate.init(val.data.id, true); | ||||||
|  | 				}); | ||||||
|  | 			} else { | ||||||
|  | 				this.addOrEditTitle = '编辑'; | ||||||
|  | 				this.addOrUpdateVisible = true; | ||||||
|  | 				this.$nextTick(() => { | ||||||
|  | 					this.$refs.addOrUpdate.init(val.data.id); | ||||||
|  | 				}); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		// 获取数据列表 | ||||||
|  |     getDataList() { | ||||||
|  |       this.dataListLoading = true; | ||||||
|  |       this.urlOptions.getDataListURL(this.listQuery).then(response => { | ||||||
|  |         this.tableData = response.data.records; | ||||||
|  |         this.listQuery.total = response.data.total; | ||||||
|  |         this.dataListLoading = false; | ||||||
|  |       }); | ||||||
|  |     }, | ||||||
|  | 		buttonClick(val) { | ||||||
|  | 			switch (val.btnName) { | ||||||
|  | 				case 'search': | ||||||
|  | 					this.listQuery.pageNo = 1; | ||||||
|  | 					this.listQuery.pageSize = 10; | ||||||
|  | 					this.listQuery.name = val.name ? val.name : undefined; | ||||||
|  | 					this.listQuery.code = val.code ? val.code : undefined; | ||||||
|  | 					this.getDataList(); | ||||||
|  | 					break; | ||||||
|  | 				case 'reset': | ||||||
|  | 					this.$refs.searchBarForm.resetForm(); | ||||||
|  | 					this.listQuery = { | ||||||
|  | 						pageSize: 10, | ||||||
|  | 						pageNo: 1, | ||||||
|  | 						total: 1, | ||||||
|  | 					}; | ||||||
|  | 					this.getDataList(); | ||||||
|  | 					break; | ||||||
|  | 				case 'add': | ||||||
|  | 					this.addOrEditTitle = '新增'; | ||||||
|  | 					this.addOrUpdateVisible = true; | ||||||
|  | 					this.addOrUpdateHandle(); | ||||||
|  | 					break; | ||||||
|  | 				case 'export': | ||||||
|  | 					this.handleExport(); | ||||||
|  | 					break; | ||||||
|  | 				default: | ||||||
|  | 					console.log(val); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
							
								
								
									
										258
									
								
								src/views/base/materialUseLog/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,258 @@ | |||||||
|  | <!-- | ||||||
|  |  * @Author: zwq | ||||||
|  |  * @Date: 2021-11-18 14:16:25 | ||||||
|  |  * @LastEditors: DY | ||||||
|  |  * @LastEditTime: 2023-10-26 09:43:51 | ||||||
|  |  * @Description: | ||||||
|  | --> | ||||||
|  | <template> | ||||||
|  | 	<el-form | ||||||
|  | 		:model="dataForm" | ||||||
|  | 		:rules="dataRule" | ||||||
|  | 		ref="dataForm" | ||||||
|  | 		@keyup.enter.native="dataFormSubmit()" | ||||||
|  | 		label-width="80px"> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="物料名称" prop="materialId"> | ||||||
|  | 					<el-select | ||||||
|  | 						v-model="dataForm.materialId" | ||||||
|  | 						placeholder="请选择物料" | ||||||
|  | 						clearable | ||||||
|  | 						filterable | ||||||
|  | 						@change="setCode" | ||||||
|  | 					> | ||||||
|  | 						<el-option | ||||||
|  | 							v-for="dict in materialList" | ||||||
|  | 							:key="dict.id" | ||||||
|  | 							:label="dict.name" | ||||||
|  | 							:value="dict.id" /> | ||||||
|  | 					</el-select> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="物料编码" prop="materialCode"> | ||||||
|  | 					<el-input | ||||||
|  | 						v-model="dataForm.materialCode" | ||||||
|  | 						clearable | ||||||
|  | 						disabled | ||||||
|  | 						placeholder="请输入物料编码" /> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="批次号" prop="materialDateId"> | ||||||
|  | 					<el-select | ||||||
|  | 						v-model="dataForm.materialDateId" | ||||||
|  | 						clearable | ||||||
|  | 						filterable | ||||||
|  | 						placeholder="请选择物料批次" | ||||||
|  | 					> | ||||||
|  | 						<el-option | ||||||
|  | 							v-for="dict in materialDateList" | ||||||
|  | 							:key="dict.id" | ||||||
|  | 							:label="dict.code" | ||||||
|  | 							:value="dict.id" /> | ||||||
|  | 					</el-select> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="使用设备" prop="equipmentId"> | ||||||
|  | 					<el-select | ||||||
|  | 						v-model="dataForm.equipmentId" | ||||||
|  | 						clearable | ||||||
|  | 						filterable | ||||||
|  | 						placeholder="请选择使用设备"> | ||||||
|  | 						<el-option | ||||||
|  | 							v-for="dict in eqList" | ||||||
|  | 							:key="dict.id" | ||||||
|  | 							:label="dict.name" | ||||||
|  | 							:value="dict.id" /> | ||||||
|  | 					</el-select> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="使用时间" prop="useTime"> | ||||||
|  | 					<el-date-picker | ||||||
|  | 						v-model="dataForm.useTime" | ||||||
|  | 						type="datetime" | ||||||
|  | 						format='yyyy-MM-dd HH:mm:ss' | ||||||
|  |          		value-format='timestamp' | ||||||
|  | 						placeholder="选择日期时间" /> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="操作员" prop="userNames"> | ||||||
|  | 					<el-select | ||||||
|  | 						v-model="dataForm.userNames" | ||||||
|  | 						clearable | ||||||
|  | 						filterable | ||||||
|  | 						multiple | ||||||
|  | 						placeholder="请选择操作员"> | ||||||
|  | 						<el-option | ||||||
|  | 							v-for="dict in workersList" | ||||||
|  | 							:key="dict.id" | ||||||
|  | 							:label="dict.name" | ||||||
|  | 							:value="dict.name" /> | ||||||
|  | 					</el-select> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="使用数量" prop="num"> | ||||||
|  | 					<el-input-number v-model="dataForm.num" clearable placeholder="请输入使用数量" /> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item label="数据来源" prop="source"> | ||||||
|  | 					<el-select | ||||||
|  | 						v-model="dataForm.source" | ||||||
|  | 						clearable | ||||||
|  | 						placeholder="请选择数据来源"> | ||||||
|  | 						<el-option | ||||||
|  | 							v-for="dict in this.dataSourceList" | ||||||
|  | 							:key="dict.id" | ||||||
|  | 							:label="dict.name" | ||||||
|  | 							:value="dict.id" /> | ||||||
|  | 					</el-select> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 		<el-form-item label="备注" prop="remark"> | ||||||
|  | 			<el-input v-model="dataForm.remark" clearable placeholder="请输入备注" /> | ||||||
|  | 		</el-form-item> | ||||||
|  | 	</el-form> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import basicAdd from '../../core/mixins/basic-add'; | ||||||
|  | import { createMaterialLog, updateMaterialLog, getMaterialLog, getEqListAll, getworkerAll } from "@/api/base/materialUseLog"; | ||||||
|  | import { getMaterialList } from "@/api/base/material" | ||||||
|  | import { getMaterDateList } from "@/api/base/materialDate" | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	mixins: [basicAdd], | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			urlOptions: { | ||||||
|  | 				createURL: createMaterialLog, | ||||||
|  | 				updateURL: updateMaterialLog, | ||||||
|  | 				infoURL: getMaterialLog | ||||||
|  | 			}, | ||||||
|  | 			dataForm: { | ||||||
|  |         id: undefined, | ||||||
|  | 				materialId: undefined, | ||||||
|  |         materialCode: undefined, | ||||||
|  | 				materialDateId: undefined, | ||||||
|  | 				equipmentId: undefined, | ||||||
|  |         userName: undefined, | ||||||
|  | 				userNames: [], | ||||||
|  | 				useTime: undefined, | ||||||
|  |         address: undefined, | ||||||
|  | 				num: 0, | ||||||
|  | 				source: undefined, | ||||||
|  |         remark: undefined | ||||||
|  | 			}, | ||||||
|  | 			dataSourceList: [ | ||||||
|  | 				{ | ||||||
|  | 					id: 1, | ||||||
|  | 					name: '手动' | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					id: 2, | ||||||
|  | 					name: '自动' | ||||||
|  | 				} | ||||||
|  | 			], | ||||||
|  | 			materialList: [], | ||||||
|  | 			materialDateList: [], | ||||||
|  | 			eqList: [], | ||||||
|  | 			workersList: [], | ||||||
|  | 			dataRule: { | ||||||
|  |         materialId: [{ required: true, message: "物料不能为空", trigger: "blur" }], | ||||||
|  |         materialDateId: [{ required: true, message: "批次号不能为空", trigger: "blur" }], | ||||||
|  | 				useTime: [{ required: true, message: "使用时间不能为空", trigger: "blur" }], | ||||||
|  | 				userNames: [{ required: true, message: "操作员不能为空", trigger: "blur" }], | ||||||
|  | 				num: [{ required: true, message: "使用数量不能为空", trigger: "blur" }] | ||||||
|  |       } | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	mounted() { | ||||||
|  | 		this.getDictData() | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		async getDictData() { | ||||||
|  | 			const materRes = await getMaterialList() | ||||||
|  | 			this.materialList = materRes.data | ||||||
|  | 			console.log('你好', this.materialList) | ||||||
|  | 			const dateRes = await getMaterDateList() | ||||||
|  | 			this.materialDateList = dateRes.data | ||||||
|  | 			const eqRes = await getEqListAll() | ||||||
|  | 			this.eqList = eqRes.data | ||||||
|  | 			const workerRes = await getworkerAll() | ||||||
|  | 			this.workersList = workerRes.data | ||||||
|  | 		}, | ||||||
|  | 		// 表单提交 | ||||||
|  |     dataFormSubmit() { | ||||||
|  | 			this.dataForm.userName = this.dataForm.userNames.join(',') | ||||||
|  |       this.$refs["dataForm"].validate((valid) => { | ||||||
|  |         if (!valid) { | ||||||
|  |           return false; | ||||||
|  |         } | ||||||
|  |         // 修改的提交 | ||||||
|  |         if (this.dataForm.id) { | ||||||
|  |           this.urlOptions.updateURL(this.dataForm).then(response => { | ||||||
|  |             this.$modal.msgSuccess("修改成功"); | ||||||
|  |             this.visible = false; | ||||||
|  |             this.$emit("refreshDataList"); | ||||||
|  |           }); | ||||||
|  |           return; | ||||||
|  |         } | ||||||
|  |         // 添加的提交 | ||||||
|  |         this.urlOptions.createURL(this.dataForm).then(response => { | ||||||
|  |           this.$modal.msgSuccess("新增成功"); | ||||||
|  |           this.visible = false; | ||||||
|  |           this.$emit("refreshDataList"); | ||||||
|  |         }); | ||||||
|  |       }); | ||||||
|  |     }, | ||||||
|  | 		init(id) { | ||||||
|  |       this.dataForm.id = id || undefined; | ||||||
|  |       this.visible = true; | ||||||
|  | 
 | ||||||
|  |       this.$nextTick(() => { | ||||||
|  |         this.$refs["dataForm"].resetFields(); | ||||||
|  |         if (this.dataForm.id) { | ||||||
|  |           this.urlOptions.infoURL(id).then(response => { | ||||||
|  |             this.dataForm.id = response.data.id | ||||||
|  | 						this.dataForm.materialCode = response.data.materialCode | ||||||
|  | 						this.dataForm.materialId = response.data.materialId | ||||||
|  | 						this.dataForm.materialDateId = response.data.materialDateId | ||||||
|  | 						this.dataForm.equipmentId = response.data.equipmentId | ||||||
|  | 						this.dataForm.useTime = response.data.useTime | ||||||
|  | 						// this.dataForm.userName = response.data.userName | ||||||
|  | 						this.dataForm.num = response.data.num | ||||||
|  | 						this.dataForm.source = response.data.source | ||||||
|  | 						this.dataForm.remark = response.data.remark | ||||||
|  | 						this.dataForm.userNames = response.data.userName.split(',') | ||||||
|  | 						console.log('打印', this.dataForm) | ||||||
|  |           }); | ||||||
|  |         } else { | ||||||
|  |           if (this.urlOptions.isGetCode) { | ||||||
|  |             this.getCode() | ||||||
|  |           } | ||||||
|  | 				} | ||||||
|  |       }); | ||||||
|  |     }, | ||||||
|  | 		setCode() { | ||||||
|  | 			const tempMaterial = this.materialList.filter(item =>{ | ||||||
|  | 				return item.id === this.dataForm.materialId | ||||||
|  | 			}) | ||||||
|  | 			this.dataForm.materialCode = tempMaterial[0].code | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
							
								
								
									
										212
									
								
								src/views/base/materialUseLog/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,212 @@ | |||||||
|  | <template> | ||||||
|  | 	<div class="app-container"> | ||||||
|  | 		<search-bar | ||||||
|  | 			:formConfigs="formConfig" | ||||||
|  | 			ref="searchBarForm" | ||||||
|  | 			@headBtnClick="buttonClick" /> | ||||||
|  | 		<base-table | ||||||
|  | 			v-loading="dataListLoading" | ||||||
|  | 			:table-props="tableProps" | ||||||
|  | 			:page="listQuery.pageNo" | ||||||
|  | 			:limit="listQuery.pageSize" | ||||||
|  | 			:table-data="tableData"> | ||||||
|  | 			<method-btn | ||||||
|  | 				v-if="tableBtn.length" | ||||||
|  | 				slot="handleBtn" | ||||||
|  | 				:width="120" | ||||||
|  | 				label="操作" | ||||||
|  | 				:method-list="tableBtn" | ||||||
|  | 				@clickBtn="handleClick" /> | ||||||
|  | 		</base-table> | ||||||
|  | 		<pagination | ||||||
|  | 			:limit.sync="listQuery.pageSize" | ||||||
|  | 			:page.sync="listQuery.pageNo" | ||||||
|  | 			:total="listQuery.total" | ||||||
|  | 			@pagination="getDataList" /> | ||||||
|  | 		<base-dialog | ||||||
|  | 			:dialogTitle="addOrEditTitle" | ||||||
|  | 			:dialogVisible="addOrUpdateVisible" | ||||||
|  | 			@cancel="handleCancel" | ||||||
|  | 			@confirm="handleConfirm" | ||||||
|  | 			:before-close="handleCancel" | ||||||
|  | 			width="50%"> | ||||||
|  | 			<add-or-update | ||||||
|  | 				ref="addOrUpdate" | ||||||
|  | 				@refreshDataList="successSubmit"></add-or-update> | ||||||
|  | 		</base-dialog> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import AddOrUpdate from './add-or-updata'; | ||||||
|  | import basicPage from '../../core/mixins/basic-page'; | ||||||
|  | import { parseTime } from '../../core/mixins/code-filter'; | ||||||
|  | import { | ||||||
|  | 	getMaterialLogPage, | ||||||
|  | 	deleteMaterialLog | ||||||
|  | } from '@/api/base/materialUseLog'; | ||||||
|  | 
 | ||||||
|  | const tableProps = [ | ||||||
|  | 	{ | ||||||
|  | 		prop: 'materialName', | ||||||
|  | 		label: '物料名称' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'materialCode', | ||||||
|  | 		label: '物料编码' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'materialDateId', | ||||||
|  | 		label: '物料批次' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'equipName', | ||||||
|  | 		label: '使用设备' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'num', | ||||||
|  | 		label: '使用数量' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'useTime', | ||||||
|  | 		label: '使用时间', | ||||||
|  | 		filter: parseTime | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'userName', | ||||||
|  | 		label: '操作人' | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'source', | ||||||
|  | 		label: '数据来源', | ||||||
|  | 		filter: (val) => ['未知', '手动', '自动'][val] | ||||||
|  | 	}, | ||||||
|  | 	{ | ||||||
|  | 		prop: 'remark', | ||||||
|  | 		label: '备注' | ||||||
|  | 	} | ||||||
|  | ]; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	mixins: [basicPage], | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			urlOptions: { | ||||||
|  | 				getDataListURL: getMaterialLogPage, | ||||||
|  | 				deleteURL: deleteMaterialLog, | ||||||
|  | 				// exportURL: exportFactoryExcel, | ||||||
|  | 			}, | ||||||
|  | 			tableProps, | ||||||
|  | 			tableBtn: [ | ||||||
|  | 				this.$auth.hasPermi(`base:material-use-log:update`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'edit', | ||||||
|  | 							btnName: '编辑', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  |           this.$auth.hasPermi(`base:material-use-log:delete`) | ||||||
|  | 					? { | ||||||
|  | 							type: 'delete', | ||||||
|  | 							btnName: '删除', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 			].filter((v)=>v), | ||||||
|  | 			tableData: [], | ||||||
|  | 			listQuery: { | ||||||
|  |         pageSize: 10, | ||||||
|  |         pageNo: 1, | ||||||
|  |         total: 1, | ||||||
|  | 				materialName: undefined, | ||||||
|  | 				useTime: [] | ||||||
|  |       }, | ||||||
|  | 			formConfig: [ | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '物料名称', | ||||||
|  | 					placeholder: '物料名称', | ||||||
|  | 					param: 'name', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  |           type: 'datePicker', | ||||||
|  |           label: '使用时间段', | ||||||
|  |           dateType: 'datetimerange', | ||||||
|  |           format: 'yyyy-MM-dd', | ||||||
|  |           valueFormat: 'yyyy-MM-dd HH:mm:ss', | ||||||
|  |           rangeSeparator: '-', | ||||||
|  |           startPlaceholder: '开始时间', | ||||||
|  |           endPlaceholder: '结束时间', | ||||||
|  |           width: 350, | ||||||
|  |           param: 'time', | ||||||
|  |         }, | ||||||
|  | 				{ | ||||||
|  | 					type: 'button', | ||||||
|  | 					btnName: '查询', | ||||||
|  | 					name: 'search', | ||||||
|  | 					color: 'primary' | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'separate', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: this.$auth.hasPermi('base:material-use-log:create') ? 'button' : '', | ||||||
|  | 					btnName: '新增', | ||||||
|  | 					name: 'add', | ||||||
|  | 					color: 'success', | ||||||
|  | 					plain: true | ||||||
|  | 				}, | ||||||
|  | 			], | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	components: { | ||||||
|  | 		AddOrUpdate, | ||||||
|  | 	}, | ||||||
|  | 	created() {}, | ||||||
|  | 	methods: { | ||||||
|  | 		// 获取数据列表 | ||||||
|  |     getDataList() { | ||||||
|  |       this.dataListLoading = true; | ||||||
|  |       this.urlOptions.getDataListURL(this.listQuery).then(response => { | ||||||
|  |         this.tableData = response.data.records; | ||||||
|  |         this.listQuery.total = response.data.total; | ||||||
|  |         this.dataListLoading = false; | ||||||
|  |       }); | ||||||
|  |     }, | ||||||
|  | 		buttonClick(val) { | ||||||
|  | 			switch (val.btnName) { | ||||||
|  | 				case 'search': | ||||||
|  | 					this.listQuery.pageNo = 1; | ||||||
|  | 					this.listQuery.pageSize = 10; | ||||||
|  | 					this.listQuery.materialName = val.name ? val.name : undefined; | ||||||
|  | 					if (val.time) { | ||||||
|  | 						this.listQuery.useTime[0] = val.time[0] | ||||||
|  | 						this.listQuery.useTime[1] = val.time[1] | ||||||
|  | 					} else { | ||||||
|  | 						this.listQuery.useTime = [] | ||||||
|  | 					} | ||||||
|  | 					console.log('222', this.listQuery, val.time) | ||||||
|  | 					this.getDataList(); | ||||||
|  | 					break; | ||||||
|  | 				case 'reset': | ||||||
|  | 					this.$refs.searchBarForm.resetForm(); | ||||||
|  | 					this.listQuery = { | ||||||
|  | 						pageSize: 10, | ||||||
|  | 						pageNo: 1, | ||||||
|  | 						total: 1, | ||||||
|  | 					}; | ||||||
|  | 					this.getDataList(); | ||||||
|  | 					break; | ||||||
|  | 				case 'add': | ||||||
|  | 					this.addOrEditTitle = '新增'; | ||||||
|  | 					this.addOrUpdateVisible = true; | ||||||
|  | 					this.addOrUpdateHandle(); | ||||||
|  | 					break; | ||||||
|  | 				case 'export': | ||||||
|  | 					this.handleExport(); | ||||||
|  | 					break; | ||||||
|  | 				default: | ||||||
|  | 					console.log(val); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
| Before Width: | Height: | Size: 42 KiB | 
| Before Width: | Height: | Size: 50 KiB | 
| Before Width: | Height: | Size: 78 KiB | 
| Before Width: | Height: | Size: 71 KiB | 
| Before Width: | Height: | Size: 41 KiB | 
| Before Width: | Height: | Size: 61 KiB | 
| Before Width: | Height: | Size: 37 KiB | 
| Before Width: | Height: | Size: 69 KiB | 
| Before Width: | Height: | Size: 54 KiB | 
| Before Width: | Height: | Size: 45 KiB | 
| @ -1,32 +0,0 @@ | |||||||
| <!--  |  | ||||||
|     filename: EquipmentAssets.vue |  | ||||||
|     author: liubin |  | ||||||
|     date: 2023-08-22 11:11:18 |  | ||||||
|     description: 设备资产 |  | ||||||
| --> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
|     <div class="equipment-assets"></div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| export default { |  | ||||||
|     name: "EquipmentAssets", |  | ||||||
|     components: {}, |  | ||||||
|     props: {}, |  | ||||||
|     data() { |  | ||||||
|         return {} |  | ||||||
|     }, |  | ||||||
|     computed: {}, |  | ||||||
|     methods: {}, |  | ||||||
| } |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style scoped lang="scss"> |  | ||||||
| .equipment-assets { |  | ||||||
|     background: #f1f1f1; |  | ||||||
|     padding: 12px; |  | ||||||
|     min-height: 128px; |  | ||||||
|     margin-top: 8px; |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| @ -1,111 +0,0 @@ | |||||||
| <!--  |  | ||||||
|     filename: EquipmentPics.vue |  | ||||||
|     author: liubin |  | ||||||
|     date: 2023-08-18 16:29:39 |  | ||||||
|     description:  |  | ||||||
| --> |  | ||||||
| 
 |  | ||||||
| <template> |  | ||||||
| 	<div class="equipment-pics"> |  | ||||||
| 		<div v-for="(url, idx) in images" :key="url"> |  | ||||||
| 			<img :src="url" :alt="url" /> |  | ||||||
| 			<figure class="big-img" :style="inlineStyle"> |  | ||||||
| 				<img :src="url" :alt="url" /> |  | ||||||
| 				<figcaption>{{ desc[idx] }}</figcaption> |  | ||||||
| 			</figure> |  | ||||||
| 		</div> |  | ||||||
| 	</div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| export default { |  | ||||||
| 	name: 'EquipmentPics', |  | ||||||
| 	components: {}, |  | ||||||
| 	props: { |  | ||||||
| 		inlineStyle: { |  | ||||||
| 			type: Object, |  | ||||||
| 			default: () => ({}), |  | ||||||
| 		}, |  | ||||||
| 	}, |  | ||||||
| 	data() { |  | ||||||
| 		return { |  | ||||||
| 			desc: [ |  | ||||||
| 				'车间设备 - 1', |  | ||||||
| 				'车间设备 - 2', |  | ||||||
| 				'车间设备 - 3', |  | ||||||
| 				'车间设备 - 4', |  | ||||||
| 				'车间设备 - 5', |  | ||||||
| 				'车间设备 - 6', |  | ||||||
| 				'车间设备 - 7', |  | ||||||
| 				'车间设备 - 8', |  | ||||||
| 				'车间设备 - 9', |  | ||||||
| 				'车间设备 - 10', |  | ||||||
| 				'车间设备 - 11', |  | ||||||
| 				'车间设备 - 12', |  | ||||||
| 			], |  | ||||||
| 			images: Array(10) |  | ||||||
| 				.fill(1) |  | ||||||
| 				.map((_, index) => require(`../assets/eq${index + 1}.jpg`)), |  | ||||||
| 		}; |  | ||||||
| 	}, |  | ||||||
| 	methods: {}, |  | ||||||
| }; |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style scoped lang="scss"> |  | ||||||
| .equipment-pics { |  | ||||||
| 	// background: #cfcfcf; |  | ||||||
| 	padding: 12px; |  | ||||||
| 	// margin: 8px; |  | ||||||
| 	display: flex; |  | ||||||
| 	overflow-x: auto; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .equipment-pics > div { |  | ||||||
| 	height: 100px; |  | ||||||
| 	position: relative; |  | ||||||
| 	cursor: pointer; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .equipment-pics > div:not(:last-child) { |  | ||||||
| 	margin-right: 12px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .equipment-pics > div > img { |  | ||||||
| 	height: 95%; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .equipment-pics > div > figure { |  | ||||||
| 	display: none; |  | ||||||
| 	position: fixed; |  | ||||||
| 	// inset: 0; |  | ||||||
| 	// margin: auto; |  | ||||||
| 	top: 0; |  | ||||||
| 	right: 0; |  | ||||||
| 	// width: 640px; |  | ||||||
| 	// height: 480px; |  | ||||||
| 	background: #000; |  | ||||||
| 	overflow: hidden; |  | ||||||
| 	padding: 8px 8px 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .equipment-pics > div:hover > figure { |  | ||||||
| 	margin: 0; |  | ||||||
| 	display: flex; |  | ||||||
| 	flex-direction: column; |  | ||||||
| 	align-items: center; |  | ||||||
| 	justify-content: center; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .equipment-pics > div > figure > img { |  | ||||||
| 	flex: 1; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .equipment-pics > div > figure > figcaption { |  | ||||||
| 	height: 24px; |  | ||||||
| 	margin-top: 8px; |  | ||||||
| 	font-size: 18px; |  | ||||||
| 	line-height: 1; |  | ||||||
| 	color: #fff; |  | ||||||
| } |  | ||||||
| </style> |  | ||||||
| @ -20,9 +20,6 @@ | |||||||
|         @change="selectObj" |         @change="selectObj" | ||||||
|         clearable></el-cascader> |         clearable></el-cascader> | ||||||
|     </el-form-item> |     </el-form-item> | ||||||
|     <el-form-item label="对象备注" prop="remark"> |  | ||||||
|       <el-input v-model="form.remark"/> |  | ||||||
|     </el-form-item> |  | ||||||
|   </el-form> |   </el-form> | ||||||
| </template> | </template> | ||||||
| <script> | <script> | ||||||
| @ -42,8 +39,7 @@ export default { | |||||||
|         id: '', |         id: '', | ||||||
|         plcId: '', |         plcId: '', | ||||||
|         bindObjectId: '', |         bindObjectId: '', | ||||||
|         bindObjectType: '', |         bindObjectType: '' | ||||||
|         remark: '' |  | ||||||
|       }, |       }, | ||||||
|       objIds: [],// 回显数组 |       objIds: [],// 回显数组 | ||||||
|       plcList: [], |       plcList: [], | ||||||
| @ -130,7 +126,6 @@ export default { | |||||||
|       this.form.plcId = '' |       this.form.plcId = '' | ||||||
|       this.form.bindObjectId = '' |       this.form.bindObjectId = '' | ||||||
|       this.form.bindObjectType = '' |       this.form.bindObjectType = '' | ||||||
|       this.form.remark = '' |  | ||||||
|       this.objIds = [] |       this.objIds = [] | ||||||
|       this.isEdit = false |       this.isEdit = false | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -61,10 +61,6 @@ const tableProps = [ | |||||||
|     prop: 'objCode', |     prop: 'objCode', | ||||||
|     label: '对象编码' |     label: '对象编码' | ||||||
|   }, |   }, | ||||||
|   { |  | ||||||
|     prop: 'remark', |  | ||||||
|     label: '对象备注' |  | ||||||
|   }, |  | ||||||
|   { |   { | ||||||
|     prop: 'plcTableName',  |     prop: 'plcTableName',  | ||||||
|     label: '关联表名' |     label: '关联表名' | ||||||
|  | |||||||
| @ -38,8 +38,8 @@ const tableProps = [ | |||||||
|     label: '统计对象' |     label: '统计对象' | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'objRemark', |     prop: 'objCode', | ||||||
|     label: '对象备注' |     label: '对象编码' | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'energyTypeName', |     prop: 'energyTypeName', | ||||||
|  | |||||||
| @ -55,9 +55,8 @@ const tableProps = [ | |||||||
|     label: '监控对象' |     label: '监控对象' | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'objectType', |     prop: 'objCode', | ||||||
|     label: '对象备注', |     label: '对象编码' | ||||||
|     filter: publicFormatter('object_type') |  | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'energyType', |     prop: 'energyType', | ||||||
|  | |||||||
| @ -34,8 +34,8 @@ const tableProps = [ | |||||||
|     label: '监控对象' |     label: '监控对象' | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'objRemark', |     prop: 'objCode', | ||||||
|     label: '对象备注' |     label: '对象编码' | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'energyType', |     prop: 'energyType', | ||||||
|  | |||||||
| @ -54,8 +54,8 @@ const tableProps = [ | |||||||
|     label: '所属对象' |     label: '所属对象' | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'objRemark', |     prop: 'objCode', | ||||||
|     label: '对象备注' |     label: '对象编码' | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'paramName', |     prop: 'paramName', | ||||||
|  | |||||||
| @ -41,8 +41,8 @@ const tableProps = [ | |||||||
|     label: '所属对象' |     label: '所属对象' | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'objRemark', |     prop: 'objCode', | ||||||
|     label: '对象备注' |     label: '对象编码' | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     prop: 'paramName', |     prop: 'paramName', | ||||||
|  | |||||||
| @ -0,0 +1,93 @@ | |||||||
|  | <template> | ||||||
|  |   <div  | ||||||
|  |     id="orderEnergyChart" | ||||||
|  |     style="width: 100%" | ||||||
|  |     :style="{ height: chartHeight + 'px' }" | ||||||
|  |   ></div> | ||||||
|  | </template> | ||||||
|  | <script> | ||||||
|  | import * as echarts from 'echarts' | ||||||
|  | import resize from '@/utils/chartMixins/resize' | ||||||
|  | export default { | ||||||
|  |   name: "BarChart", | ||||||
|  |   mixins: [resize], | ||||||
|  |   data() { | ||||||
|  |     return { | ||||||
|  |       chartDom: '', | ||||||
|  |       chart: '', | ||||||
|  |       chartHeight: this.tableHeight(430) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   props: { | ||||||
|  |     chartData: { | ||||||
|  |       type: Array, | ||||||
|  |       required: true, | ||||||
|  |       default: () => { | ||||||
|  |         return [] | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   watch: { | ||||||
|  |     chartData: function () { | ||||||
|  |       this.getChart() | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   mounted() { | ||||||
|  |     window.addEventListener('resize', () => { | ||||||
|  |       this.chartHeight = this.tableHeight(430) | ||||||
|  |     }) | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     getChart() { | ||||||
|  |       if ( | ||||||
|  |         this.chart !== null && | ||||||
|  |         this.chart !== '' && | ||||||
|  |         this.chart !== undefined | ||||||
|  |       ) { | ||||||
|  |         this.chart.dispose() // 页面多次刷新会出现警告,Dom已经初始化了一个实例,这是销毁实例 | ||||||
|  |       } | ||||||
|  |       this.chartDom = document.getElementById('orderEnergyChart') | ||||||
|  |       this.chart = echarts.init(this.chartDom) | ||||||
|  |       console.log(this.chartData) | ||||||
|  |       let xData = [] | ||||||
|  |       let yData = [] | ||||||
|  |       this.chartData && this.chartData.map(item =>{ | ||||||
|  |         xData.push(item.objName) | ||||||
|  |         yData.push(item.useNum) | ||||||
|  |       }) | ||||||
|  |       var option = { | ||||||
|  |         color:['#288AFF'], | ||||||
|  |         grid: { | ||||||
|  |           left: '2%', | ||||||
|  |           right: '1%', | ||||||
|  |           bottom: '1%', | ||||||
|  |           containLabel: true | ||||||
|  |         }, | ||||||
|  |         xAxis: { | ||||||
|  |           type: 'category', | ||||||
|  |           data: xData, | ||||||
|  |           axisLabel: { | ||||||
|  |             rotate: "45" | ||||||
|  |           } | ||||||
|  |         }, | ||||||
|  |         yAxis: { | ||||||
|  |           type: 'value' | ||||||
|  |         }, | ||||||
|  |         series: [ | ||||||
|  |           { | ||||||
|  |             data: yData, | ||||||
|  |             type: 'bar', | ||||||
|  |             barMaxWidth: 20, | ||||||
|  |             label: { | ||||||
|  |               show: true, | ||||||
|  |               position: 'top' | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       option && this.chart.setOption(option); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
							
								
								
									
										271
									
								
								src/views/energy/monitoring/orderEnergy/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,271 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="orderEnergyContainer"> | ||||||
|  |     <div class="box1"> | ||||||
|  |       <!-- 搜索工作栏 --> | ||||||
|  |       <search-bar | ||||||
|  |         :formConfigs="formConfig" | ||||||
|  |         ref="searchBarForm" | ||||||
|  |         @headBtnClick="buttonClick" | ||||||
|  |       /> | ||||||
|  |     </div> | ||||||
|  |     <div class="box2"> | ||||||
|  |       <div class="boxTitle"> | ||||||
|  |         <span class="blueTitle"></span> | ||||||
|  |         <span>工单信息</span> | ||||||
|  |       </div> | ||||||
|  |       <el-row> | ||||||
|  |         <el-col :span='4'> | ||||||
|  |           <div class="blodTip">工单名称</div> | ||||||
|  |           <div class="lightTip">{{ orderMsg.name }}</div> | ||||||
|  |         </el-col> | ||||||
|  |         <el-col :span='4'> | ||||||
|  |           <div class="blodTip">产品名称</div> | ||||||
|  |           <div class="lightTip">{{orderMsg.productName }}</div> | ||||||
|  |         </el-col> | ||||||
|  |         <el-col :span='4'> | ||||||
|  |           <div class="blodTip">计划完成数量</div> | ||||||
|  |           <div class="lightTip">{{orderMsg.planQuantity }}</div> | ||||||
|  |         </el-col> | ||||||
|  |         <el-col :span='4'> | ||||||
|  |           <div class="blodTip">实际开始时间</div> | ||||||
|  |           <div class="lightTip">{{ parseTime(orderMsg.startProduceTime) }}</div> | ||||||
|  |         </el-col> | ||||||
|  |         <el-col :span='4'> | ||||||
|  |           <div class="blodTip">实际完成时间</div> | ||||||
|  |           <div class="lightTip">{{ parseTime(orderMsg.finishProduceTime) }}</div> | ||||||
|  |         </el-col> | ||||||
|  |         <el-col :span='4'> | ||||||
|  |           <div class="blodTip">实际加工数量</div> | ||||||
|  |           <div class="lightTip">{{orderMsg.actualQuantity }}</div> | ||||||
|  |         </el-col> | ||||||
|  |       </el-row> | ||||||
|  |     </div> | ||||||
|  |     <div class="box3"> | ||||||
|  |       <div class="boxTitle"> | ||||||
|  |         <span class="blueTitle"></span> | ||||||
|  |         <span>能耗信息</span> | ||||||
|  |       </div> | ||||||
|  |       <div class="toggleTabBox"> | ||||||
|  |         <div :class="{ active: activeModule === 'dataList' }" @click="toggleTab('dataList')">数据列表</div> | ||||||
|  |         <div :class="{ active: activeModule === 'barChart' }" @click="toggleTab('barChart')">柱状图</div> | ||||||
|  |       </div> | ||||||
|  |       <div> | ||||||
|  |         <div  v-show="activeModule === 'dataList'"> | ||||||
|  |           <!-- 表格 --> | ||||||
|  |           <base-table | ||||||
|  |             :page="queryParams.pageNo" | ||||||
|  |             :limit="queryParams.pageSize" | ||||||
|  |             :table-props="tableProps" | ||||||
|  |             :table-data="tableData" | ||||||
|  |             :max-height="tableH" | ||||||
|  |           /> | ||||||
|  |         </div> | ||||||
|  |         <!-- 图形 --> | ||||||
|  |         <div v-show="activeModule === 'barChart'"> | ||||||
|  |           <bar-chart ref="orderEnergyChart" :chartData="chartData"/> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | <script> | ||||||
|  | const tableProps = [ | ||||||
|  |   { | ||||||
|  |     prop: 'objName', | ||||||
|  |     label: '对象名称' | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     prop: 'objCode', | ||||||
|  |     label: '对象编码' | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     prop: 'energyType', | ||||||
|  |     label: '能源类型' | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     prop: 'startNum', | ||||||
|  |     label: '工单开始值' | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     prop: 'endNum', | ||||||
|  |     label: '工单结束值/当前值' | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     prop: 'useNum', | ||||||
|  |     label: '使用量' | ||||||
|  |   } | ||||||
|  | ] | ||||||
|  | import { getEnergyTypeListAll } from '@/api/base/energyType' | ||||||
|  | import { workOrderList } from '@/api/base/orderManage' | ||||||
|  | import { getWorkOrderMsg, getOrderEnergyData } from '@/api/monitoring/orderEnergy' | ||||||
|  | import BarChart from "./components/barChart" | ||||||
|  | export default { | ||||||
|  |   name: 'OrderEnergy', | ||||||
|  |   data() { | ||||||
|  |     return { | ||||||
|  |       formConfig: [ | ||||||
|  |         { | ||||||
|  |           type: 'select', | ||||||
|  |           label: '工单', | ||||||
|  |           selectOptions: [], | ||||||
|  |           param: 'workOrderId', | ||||||
|  |           clearable: false | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           type: 'select', | ||||||
|  |           label: '能源类型', | ||||||
|  |           selectOptions: [], | ||||||
|  |           param: 'objType', | ||||||
|  |           filterable: true, | ||||||
|  |           width: 120, | ||||||
|  |           clearable: false | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           type: 'select', | ||||||
|  |           label: '对象维度', | ||||||
|  |           selectOptions: this.getDictDatas(this.DICT_TYPE.OBJECT_TYPE), | ||||||
|  |           labelField: 'label', | ||||||
|  |           valueField: 'value', | ||||||
|  |           param: 'energyTypeId', | ||||||
|  |           width: 100, | ||||||
|  |           clearable: false | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |           type: 'button', | ||||||
|  |           btnName: '查询', | ||||||
|  |           name: 'search', | ||||||
|  |           color: 'primary' | ||||||
|  |         } | ||||||
|  |       ], | ||||||
|  |       tableProps, | ||||||
|  |       tableData: [], | ||||||
|  |       tableH: this.tableHeight(400), | ||||||
|  |       // 查询参数 | ||||||
|  |       queryParams: { | ||||||
|  |         workOrderId: '', | ||||||
|  |         objType: '', | ||||||
|  |         energyTypeId: '' | ||||||
|  |       }, | ||||||
|  |       orderMsg: {}, | ||||||
|  |       chartData: [], | ||||||
|  |       activeModule: 'dataList' | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   components: { BarChart }, | ||||||
|  |   mounted() { | ||||||
|  |     window.addEventListener('resize', () => { | ||||||
|  |       this.tableH = this.tableHeight(400) | ||||||
|  |     }) | ||||||
|  |     this.getListArr() | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     getListArr() { | ||||||
|  |       workOrderList().then(res => { | ||||||
|  |         this.formConfig[0].selectOptions = res.data || [] | ||||||
|  |       }) | ||||||
|  |       getEnergyTypeListAll().then(res => { | ||||||
|  |         this.formConfig[1].selectOptions = res.data || [] | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     buttonClick(val) { | ||||||
|  |       if (!val.workOrderId) { | ||||||
|  |         this.$modal.msgWarning('工单不能为空') | ||||||
|  |         return false | ||||||
|  |       } | ||||||
|  |       if (!val.objType) { | ||||||
|  |         this.$modal.msgWarning('能源类型不能为空') | ||||||
|  |         return false | ||||||
|  |       } | ||||||
|  |       if (!val.energyTypeId) { | ||||||
|  |         this.$modal.msgWarning('对象维度不能为空') | ||||||
|  |         return false | ||||||
|  |       } | ||||||
|  |       this.queryParams.workOrderId = val.workOrderId | ||||||
|  |       this.queryParams.objType = val.objType | ||||||
|  |       this.queryParams.energyTypeId = val.energyTypeId | ||||||
|  |       getWorkOrderMsg({ ...this.queryParams }).then(res => { | ||||||
|  |         this.orderMsg = res.data || {} | ||||||
|  |         getOrderEnergyData({ | ||||||
|  |           ...this.queryParams, | ||||||
|  |           startProduceTime: res.data.startProduceTime	 || '', | ||||||
|  |           finishProduceTime: res.data.finishProduceTime || '' | ||||||
|  |         }).then(result => { | ||||||
|  |           this.tableData = result.data || [] | ||||||
|  |           this.chartData = result.data || [] | ||||||
|  |         }) | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     toggleTab(val) { | ||||||
|  |       this.activeModule = val | ||||||
|  |       if (this.activeModule === 'barChart') { | ||||||
|  |         this.$nextTick((res) => { | ||||||
|  |           this.$refs.orderEnergyChart.getChart() | ||||||
|  |         }) | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     headBtnClick() {} | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  | <style lang='scss' scoped> | ||||||
|  | .orderEnergyContainer { | ||||||
|  |   background-color: rgb(242, 244, 249); | ||||||
|  |   .box1, .box2, .box3 { | ||||||
|  |     background-color: #fff; | ||||||
|  |     border-radius: 9px; | ||||||
|  |   } | ||||||
|  |   .box1 { | ||||||
|  |     height: 64px; | ||||||
|  |     padding: 12px 16px 0; | ||||||
|  |   } | ||||||
|  |   .box2 { | ||||||
|  |     height: 122px; | ||||||
|  |     margin: 8px 0; | ||||||
|  |     padding: 16px; | ||||||
|  |     .blodTip { | ||||||
|  |       font-weight: 600; | ||||||
|  |       color: rgba(0,0,0,0.85); | ||||||
|  |       margin-bottom: 8px; | ||||||
|  |     } | ||||||
|  |     .lightTip { | ||||||
|  |       font-weight: 400; | ||||||
|  |       color: rgba(102,102,102,0.75); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   .box3 { | ||||||
|  |     padding: 16px; | ||||||
|  |     height: calc(100vh - 330px); | ||||||
|  |     .toggleTabBox { | ||||||
|  |       display: inline-block; | ||||||
|  |       div { | ||||||
|  |         display: inline-block; | ||||||
|  |         padding:0 8px 4px; | ||||||
|  |         color: rgba(102, 102, 102, 0.5); | ||||||
|  |         border-bottom: 2px solid rgba(242, 244, 249, 1); | ||||||
|  |         cursor: pointer; | ||||||
|  |       } | ||||||
|  |       .active { | ||||||
|  |         color: rgba(0,0,0,0.85); | ||||||
|  |         border-bottom-color: #0B58FF; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   .boxTitle { | ||||||
|  |     display: inline-block; | ||||||
|  |     font-size: 16px; | ||||||
|  |     font-weight: 400; | ||||||
|  |     color: #000000; | ||||||
|  |     margin:0 10px 20px 0; | ||||||
|  |   } | ||||||
|  |   .blueTitle { | ||||||
|  |     content: ''; | ||||||
|  |     display: inline-block; | ||||||
|  |     width: 4px; | ||||||
|  |     height: 18px; | ||||||
|  |     background-color: #0B58FF; | ||||||
|  |     border-radius: 1px; | ||||||
|  |     margin-right: 8px; | ||||||
|  |     vertical-align: bottom; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </style> | ||||||
| @ -21,7 +21,7 @@ | |||||||
| 						:disabled="disabled" | 						:disabled="disabled" | ||||||
| 						v-model="dataForm.code" | 						v-model="dataForm.code" | ||||||
| 						@change="$emit('update', dataForm)" | 						@change="$emit('update', dataForm)" | ||||||
| 						placeholder="请输入工段排序" /> | 						placeholder="请输入报警编码" /> | ||||||
| 				</el-form-item> | 				</el-form-item> | ||||||
| 				<!-- 				 | 				<!-- 				 | ||||||
| 				<el-form-item | 				<el-form-item | ||||||
| @ -58,7 +58,7 @@ | |||||||
| 					queryParams: { id: alarmForm.id }, | 					queryParams: { id: alarmForm.id }, | ||||||
| 				}, | 				}, | ||||||
| 				{ | 				{ | ||||||
| 					name: '属性列表', | 					name: '报警明细', | ||||||
| 					key: 'attrs', | 					key: 'attrs', | ||||||
| 					props: drawerListProps, | 					props: drawerListProps, | ||||||
| 					url: '/base/equipment-group-alarm/page', | 					url: '/base/equipment-group-alarm/page', | ||||||
| @ -72,13 +72,13 @@ | |||||||
| 						pageSize: 10, | 						pageSize: 10, | ||||||
| 					}, | 					}, | ||||||
| 					tableBtn: [ | 					tableBtn: [ | ||||||
| 						this.$auth.hasPermi('base:equipment-group:update') | 						this.$auth.hasPermi('equipment:alarm-group:update') | ||||||
| 							? { | 							? { | ||||||
| 									type: 'edit', | 									type: 'edit', | ||||||
| 									btnName: '修改', | 									btnName: '修改', | ||||||
| 							  } | 							  } | ||||||
| 							: undefined, | 							: undefined, | ||||||
| 						this.$auth.hasPermi('base:equipment-group:delete') | 						this.$auth.hasPermi('equipment:alarm-group:delete') | ||||||
| 							? { | 							? { | ||||||
| 									type: 'delete', | 									type: 'delete', | ||||||
| 									btnName: '删除', | 									btnName: '删除', | ||||||
| @ -119,19 +119,19 @@ export default { | |||||||
| 			editMode: '', | 			editMode: '', | ||||||
| 			searchBarKeys: ['name', 'code'], | 			searchBarKeys: ['name', 'code'], | ||||||
| 			tableBtn: [ | 			tableBtn: [ | ||||||
| 				this.$auth.hasPermi('base:equipment-group:update') | 				this.$auth.hasPermi('equipment:alarm-group:update') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'detail', | 							type: 'detail', | ||||||
| 							btnName: '查看报警', | 							btnName: '查看报警', | ||||||
| 					  } | 					  } | ||||||
| 					: undefined, | 					: undefined, | ||||||
| 				this.$auth.hasPermi('base:equipment-group:update') | 				this.$auth.hasPermi('equipment:alarm-group:update') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'edit', | 							type: 'edit', | ||||||
| 							btnName: '修改', | 							btnName: '修改', | ||||||
| 					  } | 					  } | ||||||
| 					: undefined, | 					: undefined, | ||||||
| 				this.$auth.hasPermi('base:equipment-group:delete') | 				this.$auth.hasPermi('equipment:alarm-group:delete') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'delete', | 							type: 'delete', | ||||||
| 							btnName: '删除', | 							btnName: '删除', | ||||||
| @ -192,9 +192,9 @@ export default { | |||||||
| 						input: true, | 						input: true, | ||||||
| 						label: '设备分组编码', | 						label: '设备分组编码', | ||||||
| 						prop: 'code', | 						prop: 'code', | ||||||
| 						// url: '/base/equipment/getCode', | 						// url: '/base/core-equipment/getCode', | ||||||
| 					} | 					}, | ||||||
| 				] | 				], | ||||||
| 			], | 			], | ||||||
| 			drawerListProps: [ | 			drawerListProps: [ | ||||||
| 				{ | 				{ | ||||||
| @ -250,7 +250,7 @@ export default { | |||||||
| 					type: 'separate', | 					type: 'separate', | ||||||
| 				}, | 				}, | ||||||
| 				{ | 				{ | ||||||
| 					type: this.$auth.hasPermi('base:equipment-group:create') | 					type: this.$auth.hasPermi('equipment:alarm-group:create') | ||||||
| 						? 'button' | 						? 'button' | ||||||
| 						: '', | 						: '', | ||||||
| 					btnName: '新增', | 					btnName: '新增', | ||||||
| @ -259,7 +259,7 @@ export default { | |||||||
| 					color: 'success', | 					color: 'success', | ||||||
| 				}, | 				}, | ||||||
| 				// { | 				// { | ||||||
| 				// 	type: this.$auth.hasPermi('base:equipment-group:export') ? 'button' : '', | 				// 	type: this.$auth.hasPermi('equipment:alarm-group:export') ? 'button' : '', | ||||||
| 				// 	btnName: '导出', | 				// 	btnName: '导出', | ||||||
| 				// 	name: 'export', | 				// 	name: 'export', | ||||||
| 				// 	color: 'warning', | 				// 	color: 'warning', | ||||||
| @ -375,7 +375,7 @@ export default { | |||||||
| 		handleAdd() { | 		handleAdd() { | ||||||
| 			this.reset(); | 			this.reset(); | ||||||
| 			this.open = true; | 			this.open = true; | ||||||
| 			this.title = '添加设备分组(用于同类型不同厂家的设备区分)'; | 			this.title = '添加设备分组'; | ||||||
| 		}, | 		}, | ||||||
| 		/** 修改按钮操作 */ | 		/** 修改按钮操作 */ | ||||||
| 		handleUpdate(row) { | 		handleUpdate(row) { | ||||||
| @ -384,7 +384,7 @@ export default { | |||||||
| 			getEquipmentGroup(id).then((response) => { | 			getEquipmentGroup(id).then((response) => { | ||||||
| 				this.form = response.data; | 				this.form = response.data; | ||||||
| 				this.open = true; | 				this.open = true; | ||||||
| 				this.title = '修改设备分组(用于同类型不同厂家的设备区分)'; | 				this.title = '修改设备分组'; | ||||||
| 			}); | 			}); | ||||||
| 		}, | 		}, | ||||||
| 		/** 提交按钮 */ | 		/** 提交按钮 */ | ||||||
| @ -445,18 +445,13 @@ export default { | |||||||
| 			params.pageNo = undefined; | 			params.pageNo = undefined; | ||||||
| 			params.pageSize = undefined; | 			params.pageSize = undefined; | ||||||
| 			this.$modal | 			this.$modal | ||||||
| 				.confirm( | 				.confirm('是否确认导出所有设备分组数据项?') | ||||||
| 					'是否确认导出所有设备分组(用于同类型不同厂家的设备区分)数据项?' |  | ||||||
| 				) |  | ||||||
| 				.then(() => { | 				.then(() => { | ||||||
| 					this.exportLoading = true; | 					this.exportLoading = true; | ||||||
| 					return exportEquipmentGroupExcel(params); | 					return exportEquipmentGroupExcel(params); | ||||||
| 				}) | 				}) | ||||||
| 				.then((response) => { | 				.then((response) => { | ||||||
| 					this.$download.excel( | 					this.$download.excel(response, '设备分组.xls'); | ||||||
| 						response, |  | ||||||
| 						'设备分组(用于同类型不同厂家的设备区分).xls' |  | ||||||
| 					); |  | ||||||
| 					this.exportLoading = false; | 					this.exportLoading = false; | ||||||
| 				}) | 				}) | ||||||
| 				.catch(() => {}); | 				.catch(() => {}); | ||||||
| @ -118,19 +118,19 @@ export default { | |||||||
| 		return { | 		return { | ||||||
| 			searchBarKeys: ['groupId', 'equipmentName'], | 			searchBarKeys: ['groupId', 'equipmentName'], | ||||||
| 			tableBtn: [ | 			tableBtn: [ | ||||||
| 				this.$auth.hasPermi('base:equipment-bind-group:update') | 				this.$auth.hasPermi('equipment:bind-group:update') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'detail', | 							type: 'detail', | ||||||
| 							btnName: '查看报警', | 							btnName: '查看报警', | ||||||
| 					  } | 					  } | ||||||
| 					: undefined, | 					: undefined, | ||||||
| 				this.$auth.hasPermi('base:equipment-bind-group:update') | 				this.$auth.hasPermi('equipment:bind-group:update') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'edit', | 							type: 'edit', | ||||||
| 							btnName: '修改', | 							btnName: '修改', | ||||||
| 					  } | 					  } | ||||||
| 					: undefined, | 					: undefined, | ||||||
| 				this.$auth.hasPermi('base:equipment-bind-group:delete') | 				this.$auth.hasPermi('equipment:bind-group:delete') | ||||||
| 					? { | 					? { | ||||||
| 							type: 'delete', | 							type: 'delete', | ||||||
| 							btnName: '删除', | 							btnName: '删除', | ||||||
| @ -199,7 +199,7 @@ export default { | |||||||
| 					type: 'separate', | 					type: 'separate', | ||||||
| 				}, | 				}, | ||||||
| 				{ | 				{ | ||||||
| 					type: this.$auth.hasPermi('base:equipment-bind-group:create') | 					type: this.$auth.hasPermi('equipment:bind-group:create') | ||||||
| 						? 'button' | 						? 'button' | ||||||
| 						: '', | 						: '', | ||||||
| 					btnName: '新增', | 					btnName: '新增', | ||||||
| @ -219,7 +219,7 @@ export default { | |||||||
| 					{ | 					{ | ||||||
| 						select: true, | 						select: true, | ||||||
| 						label: '设备', | 						label: '设备', | ||||||
| 						url: '/base/equipment/page?pageNo=1&pageSize=100', | 						url: '/base/core-equipment/page?pageNo=1&pageSize=100', | ||||||
| 						prop: 'equipmentId', | 						prop: 'equipmentId', | ||||||
| 						bind: { | 						bind: { | ||||||
| 							filterable: true, | 							filterable: true, | ||||||
| @ -278,7 +278,7 @@ export default { | |||||||
| 						input: true, | 						input: true, | ||||||
| 						label: '设备分组编码', | 						label: '设备分组编码', | ||||||
| 						prop: 'code', | 						prop: 'code', | ||||||
| 						// url: '/base/equipment/getCode', | 						// url: '/base/core-equipment/getCode', | ||||||
| 					}, | 					}, | ||||||
| 				], | 				], | ||||||
| 			], | 			], | ||||||
| @ -0,0 +1,29 @@ | |||||||
|  | <!--  | ||||||
|  |     filename: CollectionConfig.vue | ||||||
|  |     author: liubin | ||||||
|  |     date: 2023-10-30 10:09:03 | ||||||
|  |     description:  | ||||||
|  | --> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |     <div class="equipment-collection-config"> | ||||||
|  |         collection config | ||||||
|  |     </div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  |     name: "EquipmentCollectionConfig", | ||||||
|  |     components: {}, | ||||||
|  |     props: {}, | ||||||
|  |     data() { | ||||||
|  |         return {} | ||||||
|  |     }, | ||||||
|  |     computed: {}, | ||||||
|  |     methods: {}, | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style scoped lang="scss"> | ||||||
|  | 
 | ||||||
|  | </style> | ||||||
							
								
								
									
										385
									
								
								src/views/equipment/base/config/DataCollection/TableConfig.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,385 @@ | |||||||
|  | <!--  | ||||||
|  |     filename: TableConfig.vue | ||||||
|  |     author: liubin | ||||||
|  |     date: 2023-10-30 10:09:03 | ||||||
|  |     description:  | ||||||
|  | --> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  | 	<div class="app-container"> | ||||||
|  | 		<!-- 搜索工作栏 --> | ||||||
|  | 		<SearchBar | ||||||
|  | 			:formConfigs="searchBarFormConfig" | ||||||
|  | 			ref="search-bar" | ||||||
|  | 			@headBtnClick="handleSearchBarBtnClick" /> | ||||||
|  | 
 | ||||||
|  | 		<!-- 列表 --> | ||||||
|  | 		<base-table | ||||||
|  | 			:table-props="tableProps" | ||||||
|  | 			:page="queryParams.pageNo" | ||||||
|  | 			:limit="queryParams.pageSize" | ||||||
|  | 			:table-data="list" | ||||||
|  | 			ref="pageTable" | ||||||
|  | 			@emitFun="handleEmitFun"> | ||||||
|  | 			<method-btn | ||||||
|  | 				v-if="tableBtn.length" | ||||||
|  | 				slot="handleBtn" | ||||||
|  | 				label="操作" | ||||||
|  | 				:method-list="tableBtn" | ||||||
|  | 				@clickBtn="handleTableBtnClick" /> | ||||||
|  | 		</base-table> | ||||||
|  | 
 | ||||||
|  | 		<!-- 分页组件 --> | ||||||
|  | 		<pagination | ||||||
|  | 			v-show="total > 0" | ||||||
|  | 			:total="total" | ||||||
|  | 			:page.sync="queryParams.pageNo" | ||||||
|  | 			:limit.sync="queryParams.pageSize" | ||||||
|  | 			@pagination="getList" /> | ||||||
|  | 
 | ||||||
|  | 		<!-- 对话框(添加 / 修改) --> | ||||||
|  | 		<base-dialog | ||||||
|  | 			:dialogTitle="title" | ||||||
|  | 			:dialogVisible="open" | ||||||
|  | 			width="700px" | ||||||
|  | 			@close="cancel" | ||||||
|  | 			@cancel="cancel" | ||||||
|  | 			@confirm="submitForm"> | ||||||
|  | 			<DialogForm v-if="open" ref="form" v-model="form" :rows="rows" /> | ||||||
|  | 		</base-dialog> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import { | ||||||
|  | 	createEquipmentPlc, | ||||||
|  | 	updateEquipmentPlc, | ||||||
|  | 	deleteEquipmentPlc, | ||||||
|  | 	getEquipmentPlc, | ||||||
|  | 	getEquipmentPlcPage, | ||||||
|  | 	exportEquipmentPlcExcel, | ||||||
|  | } from '@/api/base/equipmentPlc'; | ||||||
|  | import moment from 'moment'; | ||||||
|  | import basicPageMixin from '@/mixins/lb/basicPageMixin'; | ||||||
|  | 
 | ||||||
|  | const switchBtn = { | ||||||
|  | 	name: 'SwitchBtn', | ||||||
|  | 	props: ['injectData'], | ||||||
|  | 	data() { | ||||||
|  | 		return {}; | ||||||
|  | 	}, | ||||||
|  | 	computed: { | ||||||
|  | 		active() { | ||||||
|  | 			return +this.injectData[this.injectData.prop] == 1 ? true : false; | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | 	methods: {}, | ||||||
|  | 	render: function (h) { | ||||||
|  | 		return h( | ||||||
|  | 			'el-switch', | ||||||
|  | 			{ | ||||||
|  | 				props: { | ||||||
|  | 					value: this.active, | ||||||
|  | 				}, | ||||||
|  | 				on: { | ||||||
|  | 					change: (newVal) => { | ||||||
|  | 						this.$emit('emitData', { | ||||||
|  | 							action: 'update-collect', | ||||||
|  | 							payload: { | ||||||
|  | 								...this.injectData, | ||||||
|  | 								collection: newVal ? 1 : 0, | ||||||
|  | 							}, | ||||||
|  | 						}); | ||||||
|  | 					}, | ||||||
|  | 				}, | ||||||
|  | 			}, | ||||||
|  | 			null | ||||||
|  | 		); | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	name: 'EquipmentPlc', | ||||||
|  | 	mixins: [basicPageMixin], | ||||||
|  | 	components: {}, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			tableKey: Math.random(), | ||||||
|  | 			searchBarKeys: ['name', 'plcTableName'], | ||||||
|  | 			tableBtn: [ | ||||||
|  | 				this.$auth.hasPermi('equipment:realtime-table-config:update') | ||||||
|  | 					? { | ||||||
|  | 							type: 'edit', | ||||||
|  | 							btnName: '修改', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 				this.$auth.hasPermi('equipment:realtime-table-config:delete') | ||||||
|  | 					? { | ||||||
|  | 							type: 'delete', | ||||||
|  | 							btnName: '删除', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 			].filter((v) => v), | ||||||
|  | 			tableProps: [ | ||||||
|  | 				// { | ||||||
|  | 				// 	prop: 'createTime', | ||||||
|  | 				// 	label: '添加时间', | ||||||
|  | 				// 	fixed: true, | ||||||
|  | 				// 	width: 180, | ||||||
|  | 				// 	filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'), | ||||||
|  | 				// }, | ||||||
|  | 				{ prop: 'code', label: '编码' }, | ||||||
|  | 				{ prop: 'plcTableName', label: '关联表名' }, | ||||||
|  | 				{ prop: 'name', label: '标识名称' }, | ||||||
|  | 				{ prop: 'enName', label: '英文名称' }, | ||||||
|  | 				{ | ||||||
|  | 					prop: 'collection', | ||||||
|  | 					label: '是否采集', | ||||||
|  | 					subcomponent: switchBtn, | ||||||
|  | 				}, | ||||||
|  | 				{ prop: 'description', label: '描述' }, | ||||||
|  | 			], | ||||||
|  | 			searchBarFormConfig: [ | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '表名', | ||||||
|  | 					placeholder: '请输入表名', | ||||||
|  | 					param: 'plcTableName', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '标识', | ||||||
|  | 					placeholder: '请输入标识', | ||||||
|  | 					param: 'name', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'button', | ||||||
|  | 					btnName: '查询', | ||||||
|  | 					name: 'search', | ||||||
|  | 					color: 'primary', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'separate', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					// type: this.$auth.hasPermi('equipment:realtime-table-config:create') | ||||||
|  | 					// 	? 'button' | ||||||
|  | 					// 	: '', | ||||||
|  | 					type: 'button', | ||||||
|  | 					btnName: '新增', | ||||||
|  | 					name: 'add', | ||||||
|  | 					plain: true, | ||||||
|  | 					color: 'success', | ||||||
|  | 				}, | ||||||
|  | 				// { | ||||||
|  | 				// 	type: this.$auth.hasPermi('equipment:realtime-table-config:export') ? 'button' : '', | ||||||
|  | 				// 	btnName: '导出', | ||||||
|  | 				// 	name: 'export', | ||||||
|  | 				// 	color: 'warning', | ||||||
|  | 				// }, | ||||||
|  | 			], | ||||||
|  | 			rows: [ | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '关联表名', | ||||||
|  | 						prop: 'plcTableName', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 						// bind: { | ||||||
|  | 						// 	disabled: true, // some condition, like detail mode... | ||||||
|  | 						// } | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '编码', | ||||||
|  | 						prop: 'code', | ||||||
|  | 						url: '/base/equipment-group/getCode', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '标识', | ||||||
|  | 						prop: 'name', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 						// bind: { | ||||||
|  | 						// 	disabled: true, // some condition, like detail mode... | ||||||
|  | 						// } | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '英文名', | ||||||
|  | 						prop: 'enName', | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						switch: true, | ||||||
|  | 						label: '是否采集', // 是否采集 0 代表不采集, 1 代表采集 | ||||||
|  | 						prop: 'collection', | ||||||
|  | 						bind: { | ||||||
|  |                             'active-value': 1, | ||||||
|  | 							'inactive-value': 0, | ||||||
|  |                             value: 1, | ||||||
|  | 						}, | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						textarea: true, | ||||||
|  | 						label: '描述', | ||||||
|  | 						prop: 'description', | ||||||
|  | 						bind: { | ||||||
|  | 							placeholder: '请输入备注', | ||||||
|  | 						}, | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 			], | ||||||
|  | 			// 是否显示弹出 | ||||||
|  | 			open: false, | ||||||
|  | 			// 查询参数 | ||||||
|  | 			queryParams: { | ||||||
|  | 				pageNo: 1, | ||||||
|  | 				pageSize: 10, | ||||||
|  | 				plcTableName: null, | ||||||
|  | 				name: null, | ||||||
|  | 			}, | ||||||
|  | 			// 表单参数 | ||||||
|  | 			form: {}, | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	created() { | ||||||
|  | 		this.getList(); | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		/** 覆盖 handleEmitFun 的默认实现 */ | ||||||
|  | 		handleEmitFun({ action, payload }) { | ||||||
|  | 			switch (action) { | ||||||
|  | 				case 'update-collect': | ||||||
|  | 					this.reset(); | ||||||
|  | 					const tempForm = {}; | ||||||
|  | 					Object.keys(this.form).forEach((key) => { | ||||||
|  | 						tempForm[key] = payload[key]; | ||||||
|  | 					}); | ||||||
|  | 					updateEquipmentPlc(tempForm).then((response) => { | ||||||
|  | 						this.$modal.msgSuccess('修改成功'); | ||||||
|  | 						this.open = false; | ||||||
|  | 						this.getList(); | ||||||
|  | 					}); | ||||||
|  | 					break; | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		/** 查询列表 */ | ||||||
|  | 		getList() { | ||||||
|  | 			this.loading = true; | ||||||
|  | 			// 执行查询 | ||||||
|  | 			getEquipmentPlcPage(this.queryParams).then((response) => { | ||||||
|  | 				this.list = response.data.list; | ||||||
|  | 				this.total = response.data.total; | ||||||
|  | 				this.loading = false; | ||||||
|  | 				// this.tableKey = Math.random(); // method 1 | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		/** 取消按钮 */ | ||||||
|  | 		cancel() { | ||||||
|  | 			this.open = false; | ||||||
|  | 			this.reset(); | ||||||
|  | 		}, | ||||||
|  | 		/** 表单重置 */ | ||||||
|  | 		reset() { | ||||||
|  | 			this.form = { | ||||||
|  | 				id: undefined, | ||||||
|  | 				plcTableName: undefined, | ||||||
|  | 				code: undefined, | ||||||
|  | 				name: undefined, | ||||||
|  | 				enName: undefined, | ||||||
|  | 				description: undefined, | ||||||
|  | 				collection: undefined, | ||||||
|  | 			}; | ||||||
|  | 			this.resetForm('form'); | ||||||
|  | 		}, | ||||||
|  | 		/** 搜索按钮操作 */ | ||||||
|  | 		handleQuery() { | ||||||
|  | 			this.queryParams.pageNo = 1; | ||||||
|  | 			this.getList(); | ||||||
|  | 		}, | ||||||
|  | 		/** 重置按钮操作 */ | ||||||
|  | 		resetQuery() { | ||||||
|  | 			this.resetForm('queryForm'); | ||||||
|  | 			this.handleQuery(); | ||||||
|  | 		}, | ||||||
|  | 		/** 新增按钮操作 */ | ||||||
|  | 		handleAdd() { | ||||||
|  | 			this.reset(); | ||||||
|  | 			this.open = true; | ||||||
|  | 			this.title = '添加实时数据采集配置'; | ||||||
|  | 		}, | ||||||
|  | 		/** 修改按钮操作 */ | ||||||
|  | 		handleUpdate(row) { | ||||||
|  | 			this.reset(); | ||||||
|  | 			const id = row.id; | ||||||
|  | 			getEquipmentPlc(id).then((response) => { | ||||||
|  | 				this.form = response.data; | ||||||
|  | 				this.open = true; | ||||||
|  | 				this.title = '修改实时数据采集配置'; | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		/** 提交按钮 */ | ||||||
|  | 		submitForm() { | ||||||
|  | 			this.$refs['form'].validate((valid) => { | ||||||
|  | 				if (!valid) { | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				// 修改的提交 | ||||||
|  | 				if (this.form.id != null) { | ||||||
|  | 					updateEquipmentPlc(this.form).then((response) => { | ||||||
|  | 						this.$modal.msgSuccess('修改成功'); | ||||||
|  | 						this.open = false; | ||||||
|  | 						this.getList(); | ||||||
|  | 					}); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				// 添加的提交 | ||||||
|  | 				createEquipmentPlc(this.form).then((response) => { | ||||||
|  | 					this.$modal.msgSuccess('新增成功'); | ||||||
|  | 					this.open = false; | ||||||
|  | 					this.getList(); | ||||||
|  | 				}); | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		/** 删除按钮操作 */ | ||||||
|  | 		handleDelete(row) { | ||||||
|  | 			const id = row.id; | ||||||
|  | 			this.$modal | ||||||
|  | 				.confirm('是否确认删除实时数据采集配置编号为"' + id + '"的数据项?') | ||||||
|  | 				.then(function () { | ||||||
|  | 					return deleteEquipmentPlc(id); | ||||||
|  | 				}) | ||||||
|  | 				.then(() => { | ||||||
|  | 					this.getList(); | ||||||
|  | 					this.$modal.msgSuccess('删除成功'); | ||||||
|  | 				}) | ||||||
|  | 				.catch(() => {}); | ||||||
|  | 		}, | ||||||
|  | 		/** 导出按钮操作 */ | ||||||
|  | 		handleExport() { | ||||||
|  | 			// 处理查询参数 | ||||||
|  | 			let params = { ...this.queryParams }; | ||||||
|  | 			params.pageNo = undefined; | ||||||
|  | 			params.pageSize = undefined; | ||||||
|  | 			this.$modal | ||||||
|  | 				.confirm('是否确认导出所有实时数据采集配置数据项?') | ||||||
|  | 				.then(() => { | ||||||
|  | 					this.exportLoading = true; | ||||||
|  | 					return exportEquipmentPlcExcel(params); | ||||||
|  | 				}) | ||||||
|  | 				.then((response) => { | ||||||
|  | 					this.$download.excel(response, '实时数据采集配置.xls'); | ||||||
|  | 					this.exportLoading = false; | ||||||
|  | 				}) | ||||||
|  | 				.catch(() => {}); | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
							
								
								
									
										187
									
								
								src/views/equipment/base/config/deprecated/dialogForm.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,187 @@ | |||||||
|  | <!--  | ||||||
|  |     filename: dialogForm.vue | ||||||
|  |     author: liubin | ||||||
|  |     date: 2023-09-11 15:55:13 | ||||||
|  |     description: DialogForm for equipmentBindSection only | ||||||
|  | --> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  | 	<el-form | ||||||
|  | 		ref="form" | ||||||
|  | 		:model="dataForm" | ||||||
|  | 		label-width="100px" | ||||||
|  | 		v-loading="formLoading"> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item | ||||||
|  | 					label="报警编码" | ||||||
|  | 					prop="code" | ||||||
|  | 					:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]"> | ||||||
|  | 					<el-input | ||||||
|  | 						:disabled="disabled" | ||||||
|  | 						v-model="dataForm.code" | ||||||
|  | 						@change="$emit('update', dataForm)" | ||||||
|  | 						placeholder="请输入工段排序" /> | ||||||
|  | 				</el-form-item> | ||||||
|  | 				<!-- 				 | ||||||
|  | 						<el-form-item | ||||||
|  | 						label="报警编码" | ||||||
|  | 						prop="code" | ||||||
|  | 						:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]"> | ||||||
|  | 						<el-select | ||||||
|  | 						v-model="dataForm.code" | ||||||
|  | 						placeholder="请选择产线" | ||||||
|  | 						@change="handleProductlineChange"> | ||||||
|  | 						<el-option | ||||||
|  | 						v-for="opt in productionLineList" | ||||||
|  | 						:key="opt.value" | ||||||
|  | 						:label="opt.label" | ||||||
|  | 						:value="opt.value" /> | ||||||
|  | 					</el-select> | ||||||
|  | 				</el-form-item> --> | ||||||
|  | 			</el-col> | ||||||
|  | 
 | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item | ||||||
|  | 					label="报警类型" | ||||||
|  | 					prop="type" | ||||||
|  | 					:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]"> | ||||||
|  | 					<el-select | ||||||
|  | 						v-model="dataForm.type" | ||||||
|  | 						:disabled="disabled" | ||||||
|  | 						placeholder="请选择报警类型" | ||||||
|  | 						@change="$emit('update', dataForm)"> | ||||||
|  | 						<el-option | ||||||
|  | 							v-for="opt in [ | ||||||
|  | 								{ label: '布尔型', value: 2 }, | ||||||
|  | 								{ label: '字符型', value: 1 }, | ||||||
|  | 							]" | ||||||
|  | 							:key="opt.value" | ||||||
|  | 							:label="opt.label" | ||||||
|  | 							:value="opt.value" /> | ||||||
|  | 					</el-select> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item | ||||||
|  | 					label="报警级别" | ||||||
|  | 					prop="grade" | ||||||
|  | 					:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]"> | ||||||
|  | 					<el-select | ||||||
|  | 						:disabled="disabled" | ||||||
|  | 						v-model="dataForm.grade" | ||||||
|  | 						placeholder="请选择报警级别" | ||||||
|  | 						@change="$emit('update', dataForm)"> | ||||||
|  | 						<el-option | ||||||
|  | 							v-for="opt in getDictDatas(DICT_TYPE.EQU_ALARM_LEVEL)" | ||||||
|  | 							:key="opt.value" | ||||||
|  | 							:label="opt.label" | ||||||
|  | 							:value="opt.value" /> | ||||||
|  | 					</el-select> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 
 | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item | ||||||
|  | 					v-if="+dataForm.type == 1" | ||||||
|  | 					label="设备报警编码" | ||||||
|  | 					prop="alarmCode"> | ||||||
|  | 					<el-input | ||||||
|  | 						:disabled="disabled" | ||||||
|  | 						v-model="dataForm.alarmCode" | ||||||
|  | 						@change="$emit('update', dataForm)" | ||||||
|  | 						placeholder="请输入设备报警编码" /> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item | ||||||
|  | 					label="参数列名" | ||||||
|  | 					prop="plcParamName" | ||||||
|  | 					:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]"> | ||||||
|  | 					<el-input | ||||||
|  | 						:disabled="disabled" | ||||||
|  | 						v-model="dataForm.plcParamName" | ||||||
|  | 						placeholder="请输入参数列名" | ||||||
|  | 						@change="$emit('update', dataForm)"></el-input> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<el-form-item | ||||||
|  | 					label="报警内容" | ||||||
|  | 					prop="alarmContent" | ||||||
|  | 					:rules="[{ required: true, message: '不能为空', trigger: 'blur' }]"> | ||||||
|  | 					<el-input | ||||||
|  | 						:disabled="disabled" | ||||||
|  | 						v-model="dataForm.alarmContent" | ||||||
|  | 						placeholder="请输入报警内容" | ||||||
|  | 						@change="$emit('update', dataForm)"></el-input> | ||||||
|  | 				</el-form-item> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 	</el-form> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  | 	name: 'DialogForm', | ||||||
|  | 	model: { | ||||||
|  | 		prop: 'dataForm', | ||||||
|  | 		event: 'update', | ||||||
|  | 	}, | ||||||
|  | 	emits: ['update'], | ||||||
|  | 	components: {}, | ||||||
|  | 	props: { | ||||||
|  | 		dataForm: { | ||||||
|  | 			type: Object, | ||||||
|  | 			default: () => ({}), | ||||||
|  | 		}, | ||||||
|  | 		disabled: { | ||||||
|  | 			type: Boolean, | ||||||
|  | 			default: false, | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			formLoading: true, | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	mounted() { | ||||||
|  | 		this.getCode('/base/equipment-group-alarm/getCode').then((code) => { | ||||||
|  | 			this.formLoading = false; | ||||||
|  | 			this.$emit('update', { | ||||||
|  | 				...this.dataForm, | ||||||
|  | 				code, | ||||||
|  | 			}); | ||||||
|  | 		}); | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		/** 模拟透传 ref  */ | ||||||
|  | 		validate(cb) { | ||||||
|  | 			return this.$refs.form.validate(cb); | ||||||
|  | 		}, | ||||||
|  | 		resetFields(args) { | ||||||
|  | 			return this.$refs.form.resetFields(args); | ||||||
|  | 		}, | ||||||
|  | 		async handleProductlineChange(id) { | ||||||
|  | 			await this.getWorksectionList(id); | ||||||
|  | 			this.dataForm.workshopSectionId = null; | ||||||
|  | 			this.$emit('update', this.dataForm); | ||||||
|  | 		}, | ||||||
|  | 		async getCode(url) { | ||||||
|  | 			const response = await this.$axios(url); | ||||||
|  | 			return response.data; | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style scoped lang="scss"> | ||||||
|  | .el-date-editor, | ||||||
|  | .el-select { | ||||||
|  | 	width: 100%; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										361
									
								
								src/views/equipment/base/config/deprecated/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,361 @@ | |||||||
|  | <template> | ||||||
|  | 	<div class="app-container"> | ||||||
|  | 		<!-- 搜索工作栏 --> | ||||||
|  | 		<SearchBar | ||||||
|  | 			:formConfigs="searchBarFormConfig" | ||||||
|  | 			ref="search-bar" | ||||||
|  | 			@headBtnClick="handleSearchBarBtnClick" /> | ||||||
|  | 
 | ||||||
|  | 		<!-- 列表 --> | ||||||
|  | 		<base-table | ||||||
|  | 			:table-props="tableProps" | ||||||
|  | 			:page="queryParams.pageNo" | ||||||
|  | 			:limit="queryParams.pageSize" | ||||||
|  | 			:table-data="list" | ||||||
|  | 			@emitFun="handleEmitFun"> | ||||||
|  | 			<method-btn | ||||||
|  | 				v-if="tableBtn.length" | ||||||
|  | 				slot="handleBtn" | ||||||
|  | 				label="操作" | ||||||
|  | 				:width="120" | ||||||
|  | 				:method-list="tableBtn" | ||||||
|  | 				@clickBtn="handleTableBtnClick" /> | ||||||
|  | 		</base-table> | ||||||
|  | 
 | ||||||
|  | 		<!-- 分页组件 --> | ||||||
|  | 		<pagination | ||||||
|  | 			v-show="total > 0" | ||||||
|  | 			:total="total" | ||||||
|  | 			:page.sync="queryParams.pageNo" | ||||||
|  | 			:limit.sync="queryParams.pageSize" | ||||||
|  | 			@pagination="getList" /> | ||||||
|  | 
 | ||||||
|  | 		<!-- 对话框(添加 / 修改) --> | ||||||
|  | 		<base-dialog | ||||||
|  | 			:dialogTitle="title" | ||||||
|  | 			:dialogVisible="open" | ||||||
|  | 			width="736px" | ||||||
|  | 			@close="cancel" | ||||||
|  | 			@cancel="cancel" | ||||||
|  | 			@confirm="submitForm"> | ||||||
|  | 			<DialogForm v-if="open" ref="form" v-model="form" :rows="rows" /> | ||||||
|  | 		</base-dialog> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import { | ||||||
|  | 	createEquipmentGroupAlarm, | ||||||
|  | 	updateEquipmentGroupAlarm, | ||||||
|  | 	deleteEquipmentGroupAlarm, | ||||||
|  | 	getEquipmentGroupAlarm, | ||||||
|  | 	getEquipmentGroupAlarmPage, | ||||||
|  | 	exportEquipmentGroupAlarmExcel, | ||||||
|  | } from '@/api/base/equipmentGroupAlarm'; | ||||||
|  | import basicPageMixin from '@/mixins/lb/basicPageMixin'; | ||||||
|  | import moment from 'moment'; | ||||||
|  | import { publicFormatter } from '@/utils/dict'; | ||||||
|  | import DialogForm from './dialogForm.vue'; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	name: 'EquipmentGroupAlarm', | ||||||
|  | 	components: { DialogForm }, | ||||||
|  | 	mixins: [basicPageMixin], | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			searchBarKeys: [''], | ||||||
|  | 			tableBtn: [ | ||||||
|  | 				this.$auth.hasPermi('base:equipment-group-alarm:update') | ||||||
|  | 					? { | ||||||
|  | 							type: 'edit', | ||||||
|  | 							btnName: '修改', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 				this.$auth.hasPermi('base:equipment-group-alarm:delete') | ||||||
|  | 					? { | ||||||
|  | 							type: 'delete', | ||||||
|  | 							btnName: '删除', | ||||||
|  | 					  } | ||||||
|  | 					: undefined, | ||||||
|  | 			].filter((v) => v), | ||||||
|  | 			tableProps: [ | ||||||
|  | 				{ | ||||||
|  | 					prop: 'createTime', | ||||||
|  | 					label: '添加时间', | ||||||
|  | 					fixed: true, | ||||||
|  | 					width: 180, | ||||||
|  | 					filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'), | ||||||
|  | 				}, | ||||||
|  | 				{  width: 240, prop: 'code', label: '报警编码' }, | ||||||
|  | 				{ | ||||||
|  | 					prop: 'type', | ||||||
|  | 					label: '报警类型', | ||||||
|  | 					filter: (val) => | ||||||
|  | 						val != null ? ['-', '字符型', '布尔型', '-'][val] : '-', | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					prop: 'grade', | ||||||
|  | 					label: '报警级别', | ||||||
|  | 					filter: publicFormatter(this.DICT_TYPE.EQU_ALARM_LEVEL), | ||||||
|  | 				}, | ||||||
|  | 				{ prop: 'alarmCode', label: '设备报警编码' }, | ||||||
|  | 				{ prop: 'plcParamName', label: '参数列名' }, | ||||||
|  | 				{ prop: 'alarmContent', label: '报警内容' }, | ||||||
|  | 			], | ||||||
|  | 			searchBarFormConfig: [ | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '设备分组编码', | ||||||
|  | 					width: '220', | ||||||
|  | 					placeholder: '/', | ||||||
|  | 					param: 'equipmentGroupCode', | ||||||
|  | 					defaultSelect: null, | ||||||
|  | 					disabled: true, | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: 'input', | ||||||
|  | 					label: '设备分组名称', | ||||||
|  | 					placeholder: '/', | ||||||
|  | 					param: 'equipmentGroupName', | ||||||
|  | 					defaultSelect: null, | ||||||
|  | 					disabled: true, | ||||||
|  | 				}, | ||||||
|  | 				{ | ||||||
|  | 					type: this.$auth.hasPermi('base:equipment-group-alarm:create') | ||||||
|  | 						? 'button' | ||||||
|  | 						: '', | ||||||
|  | 					btnName: '新增', | ||||||
|  | 					name: 'add', | ||||||
|  | 					plain: true, | ||||||
|  | 					color: 'success', | ||||||
|  | 				}, | ||||||
|  | 			], | ||||||
|  | 			rows: [ | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '报警编码', // 自动生成 | ||||||
|  | 						prop: 'code', | ||||||
|  | 						url: '/base/equipment-group-alarm/getCode', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						select: true, | ||||||
|  | 						label: '报警类型', // 固定选项 | ||||||
|  | 						prop: 'type', | ||||||
|  | 						options: [ | ||||||
|  | 							{ label: '布尔型', value: 2 }, | ||||||
|  | 							{ label: '字符型', value: 1 }, | ||||||
|  | 						], | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						select: true, | ||||||
|  | 						label: '报警级别', // 字典 | ||||||
|  | 						prop: 'grade', | ||||||
|  | 						options: this.getDictDatas(this.DICT_TYPE.EQU_ALARM_LEVEL), | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '设备报警编码', // 对应到设备实际的报警编码 | ||||||
|  | 						prop: 'alarmCode', | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '参数列名', // 在实时数据库的列名 | ||||||
|  | 						prop: 'plcParamName', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '报警内容', | ||||||
|  | 						prop: 'alarmContent', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 			], | ||||||
|  | 			// 是否显示弹出层 | ||||||
|  | 			open: false, | ||||||
|  | 			// 查询参数 | ||||||
|  | 			queryParams: { | ||||||
|  | 				pageNo: 1, | ||||||
|  | 				pageSize: 10, | ||||||
|  | 				equipmentGroupId: null, | ||||||
|  | 			}, | ||||||
|  | 			// 表单参数 | ||||||
|  | 			form: { | ||||||
|  | 				id: null, | ||||||
|  | 				equipmentGroupId: null, | ||||||
|  | 				code: null, | ||||||
|  | 				type: null, | ||||||
|  | 				grade: null, | ||||||
|  | 				alarmCode: null, | ||||||
|  | 				alarmContent: null, | ||||||
|  | 				plcParamName: null, | ||||||
|  | 			}, | ||||||
|  | 			// // 表单校验 | ||||||
|  | 			// rules: { | ||||||
|  | 			//   equipmentGroupId: [{ required: true, message: "设备分组ID,关联base_equipment_group不能为空", trigger: "blur" }], | ||||||
|  | 			//   type: [{ required: true, message: "报警类型:1.字符型,2.布尔型不能为空", trigger: "change" }], | ||||||
|  | 			//   alarmContent: [{ required: true, message: "报警内容 该条报警具体的解释不能为空", trigger: "blur" }], | ||||||
|  | 			//   plcParamName: [{ required: true, message: "关联编码,对应到plc_param_name的编码,用于链接数采不能为空", trigger: "blur" }], | ||||||
|  | 			// } | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	// watch: { | ||||||
|  | 	//   $route(value) { | ||||||
|  | 	//     console.log('new route info', value) | ||||||
|  | 	//   } | ||||||
|  | 	// }, | ||||||
|  | 	// created() { | ||||||
|  | 	// 	this.getList(); | ||||||
|  | 	// }, | ||||||
|  | 	activated() { | ||||||
|  | 		// 设置顶部搜索栏信息 | ||||||
|  | 		const { equipmentGroupName, equipmentGroupCode, equipmentGroupId } = | ||||||
|  | 			this.$route.params; | ||||||
|  | 		this.setSearchBarFormValue('equipmentGroupName', equipmentGroupName); | ||||||
|  | 		this.setSearchBarFormValue('equipmentGroupCode', equipmentGroupCode); | ||||||
|  | 		this.queryParams.equipmentGroupId = equipmentGroupId; | ||||||
|  | 		// if (!equipmentGroupId) this.getList(); // 拦截 | ||||||
|  | 		this.getList(); | ||||||
|  | 	}, | ||||||
|  | 	deactivated() { | ||||||
|  | 		this.setSearchBarFormValue('equipmentGroupName', null); | ||||||
|  | 		this.setSearchBarFormValue('equipmentGroupCode', null); | ||||||
|  | 		this.queryParams.equipmentGroupId = null; | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		/** 设置 searchBarForm 的默认值 - 用得比较少 */ | ||||||
|  | 		setSearchBarFormValue(param, value) { | ||||||
|  | 			this.searchBarFormConfig.forEach((config) => { | ||||||
|  | 				if (config.param == param) { | ||||||
|  | 					config.defaultSelect = value; | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		/** 查询列表 */ | ||||||
|  | 		getList() { | ||||||
|  | 			this.loading = true; | ||||||
|  | 			// 执行查询 | ||||||
|  | 			getEquipmentGroupAlarmPage(this.queryParams).then((response) => { | ||||||
|  | 				this.list = response.data.list; | ||||||
|  | 				this.total = response.data.total; | ||||||
|  | 				this.loading = false; | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		/** 取消按钮 */ | ||||||
|  | 		cancel() { | ||||||
|  | 			this.open = false; | ||||||
|  | 			this.reset(); | ||||||
|  | 		}, | ||||||
|  | 		/** 表单重置 */ | ||||||
|  | 		reset() { | ||||||
|  | 			this.form = { | ||||||
|  | 				id: null, | ||||||
|  | 				equipmentGroupId: null, | ||||||
|  | 				code: null, | ||||||
|  | 				type: null, | ||||||
|  | 				grade: null, | ||||||
|  | 				alarmCode: null, | ||||||
|  | 				alarmContent: null, | ||||||
|  | 				plcParamName: null, | ||||||
|  | 			}; | ||||||
|  | 			this.resetForm('form'); | ||||||
|  | 		}, | ||||||
|  | 		/** 搜索按钮操作 */ | ||||||
|  | 		handleQuery() { | ||||||
|  | 			this.queryParams.pageNo = 1; | ||||||
|  | 			this.getList(); | ||||||
|  | 		}, | ||||||
|  | 		/** 重置按钮操作 */ | ||||||
|  | 		resetQuery() { | ||||||
|  | 			this.resetForm('queryForm'); | ||||||
|  | 			this.handleQuery(); | ||||||
|  | 		}, | ||||||
|  | 		/** 新增按钮操作 */ | ||||||
|  | 		handleAdd() { | ||||||
|  | 			if (this.queryParams.equipmentGroupId == null) | ||||||
|  | 				return this.$message.error('没有检测到设备分组信息'); | ||||||
|  | 			this.reset(); | ||||||
|  | 			this.open = true; | ||||||
|  | 			this.title = '添加设备分组报警明细'; | ||||||
|  | 		}, | ||||||
|  | 		/** 修改按钮操作 */ | ||||||
|  | 		handleUpdate(row) { | ||||||
|  | 			this.reset(); | ||||||
|  | 			const id = row.id; | ||||||
|  | 			getEquipmentGroupAlarm(id).then((response) => { | ||||||
|  | 				this.form = response.data; | ||||||
|  | 				this.open = true; | ||||||
|  | 				this.title = '修改设备分组报警明细'; | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		/** 提交按钮 */ | ||||||
|  | 		submitForm() { | ||||||
|  | 			this.$refs['form'].validate((valid) => { | ||||||
|  | 				if (!valid) { | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				// 修改的提交 | ||||||
|  | 				if (this.form.id != null) { | ||||||
|  | 					updateEquipmentGroupAlarm({ | ||||||
|  | 						...this.form, | ||||||
|  | 						equipmentGroupId: this.queryParams.equipmentGroupId, | ||||||
|  | 					}).then((response) => { | ||||||
|  | 						this.$modal.msgSuccess('修改成功'); | ||||||
|  | 						this.open = false; | ||||||
|  | 						this.getList(); | ||||||
|  | 					}); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				// 添加的提交 | ||||||
|  | 				createEquipmentGroupAlarm({ | ||||||
|  | 					...this.form, | ||||||
|  | 					equipmentGroupId: this.queryParams.equipmentGroupId, | ||||||
|  | 				}).then((response) => { | ||||||
|  | 					this.$modal.msgSuccess('新增成功'); | ||||||
|  | 					this.open = false; | ||||||
|  | 					this.getList(); | ||||||
|  | 				}); | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		/** 删除按钮操作 */ | ||||||
|  | 		handleDelete(row) { | ||||||
|  | 			const id = row.id; | ||||||
|  | 			this.$modal | ||||||
|  | 				.confirm('是否确认删除该报警?') | ||||||
|  | 				.then(function () { | ||||||
|  | 					return deleteEquipmentGroupAlarm(id); | ||||||
|  | 				}) | ||||||
|  | 				.then(() => { | ||||||
|  | 					this.getList(); | ||||||
|  | 					this.$modal.msgSuccess('删除成功'); | ||||||
|  | 				}) | ||||||
|  | 				.catch(() => {}); | ||||||
|  | 		}, | ||||||
|  | 		/** 导出按钮操作 */ | ||||||
|  | 		handleExport() { | ||||||
|  | 			// 处理查询参数 | ||||||
|  | 			let params = { ...this.queryParams }; | ||||||
|  | 			params.pageNo = undefined; | ||||||
|  | 			params.pageSize = undefined; | ||||||
|  | 			this.$modal | ||||||
|  | 				.confirm('是否确认导出所有设备分组报警明细数据项?') | ||||||
|  | 				.then(() => { | ||||||
|  | 					this.exportLoading = true; | ||||||
|  | 					return exportEquipmentGroupAlarmExcel(params); | ||||||
|  | 				}) | ||||||
|  | 				.then((response) => { | ||||||
|  | 					this.$download.excel(response, '设备分组报警明细.xls'); | ||||||
|  | 					this.exportLoading = false; | ||||||
|  | 				}) | ||||||
|  | 				.catch(() => {}); | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
| @ -416,7 +416,7 @@ export default { | |||||||
| 		/** 准备设备数据 */ | 		/** 准备设备数据 */ | ||||||
| 		async initEquipment() { | 		async initEquipment() { | ||||||
| 			const { code, data } = await this.$axios({ | 			const { code, data } = await this.$axios({ | ||||||
| 				url: '/base/equipment/listAll', | 				url: '/base/core-equipment/listAll', | ||||||
| 				method: 'get', | 				method: 'get', | ||||||
| 			}); | 			}); | ||||||
| 			if (code == 0) { | 			if (code == 0) { | ||||||
|  | |||||||
| @ -223,7 +223,7 @@ export default { | |||||||
| 		/** 准备设备数据 */ | 		/** 准备设备数据 */ | ||||||
| 		async initEquipment() { | 		async initEquipment() { | ||||||
| 			const { code, data } = await this.$axios({ | 			const { code, data } = await this.$axios({ | ||||||
| 				url: '/base/equipment/listAll', | 				url: '/base/core-equipment/listAll', | ||||||
| 				method: 'get', | 				method: 'get', | ||||||
| 			}); | 			}); | ||||||
| 			if (code == 0) { | 			if (code == 0) { | ||||||
|  | |||||||
							
								
								
									
										367
									
								
								src/views/extend/processFlow/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,367 @@ | |||||||
|  | <!--  | ||||||
|  |     filename: index.vue | ||||||
|  |     author: liubin | ||||||
|  |     date: 2023-10-19 10:03:42 | ||||||
|  |     description:  | ||||||
|  | --> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  | 	<div class="app-container"> | ||||||
|  | 		<!-- 搜索工作栏 --> | ||||||
|  | 		<SearchBar :formConfigs="searchBarFormConfig" ref="search-bar" /> | ||||||
|  | 
 | ||||||
|  | 		<section class="process-flow"> | ||||||
|  | 			<el-button class="process-item__add-btn" @click="handleAdd"> | ||||||
|  | 				+ 新增工艺 | ||||||
|  | 			</el-button> | ||||||
|  | 			<ProcessItem | ||||||
|  | 				v-for="item in list" | ||||||
|  | 				:key="item.id" | ||||||
|  | 				:id="item.id" | ||||||
|  | 				:name="item.name" | ||||||
|  | 				:line="item.lineName" | ||||||
|  | 				:desc="item.remark" | ||||||
|  | 				:isActive="item.enabled" | ||||||
|  | 				@edit="handleUpdate" /> | ||||||
|  | 		</section> | ||||||
|  | 
 | ||||||
|  | 		<base-dialog | ||||||
|  | 			:dialogTitle="title" | ||||||
|  | 			:dialogVisible="open" | ||||||
|  | 			@close="cancel" | ||||||
|  | 			@cancel="cancel" | ||||||
|  | 			width="45%" | ||||||
|  | 			@confirm="submitForm"> | ||||||
|  | 			<DialogForm | ||||||
|  | 				v-if="open" | ||||||
|  | 				key="index-dialog-form" | ||||||
|  | 				ref="form" | ||||||
|  | 				v-model="form" | ||||||
|  | 				:rows="rows" /> | ||||||
|  | 		</base-dialog> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import basicPageMixin from '@/mixins/lb/basicPageMixin'; | ||||||
|  | // import cache from '@/utils/cache'; | ||||||
|  | 
 | ||||||
|  | const ProcessItem = { | ||||||
|  | 	name: 'ProcessItem', | ||||||
|  | 	components: {}, | ||||||
|  | 	props: ['id', 'name', 'line', 'desc', 'isActive'], | ||||||
|  | 	data() { | ||||||
|  | 		return {}; | ||||||
|  | 	}, | ||||||
|  | 	computed: {}, | ||||||
|  | 	methods: { | ||||||
|  | 		handleEdit() { | ||||||
|  | 			this.$emit('edit', this.id); | ||||||
|  | 		}, | ||||||
|  | 		handleViewDetail(e) { | ||||||
|  | 			this.$router.push({ | ||||||
|  | 				name: 'ProcessFlowView', | ||||||
|  | 				params: { | ||||||
|  | 					id: this.id, | ||||||
|  | 				}, | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | 	render: function (h) { | ||||||
|  | 		return ( | ||||||
|  | 			<div | ||||||
|  | 				class={'process-item' + (this.isActive ? ' active' : '')} | ||||||
|  | 				style="display: flex; flex-direction: column; position: relative;"> | ||||||
|  | 				<div | ||||||
|  | 					class="process-item__content" | ||||||
|  | 					style="flex: 1; display: flex; align-items: center; cursor: pointer;" | ||||||
|  | 					title="点击查看详细工序列表" | ||||||
|  | 					onClick={this.handleViewDetail}> | ||||||
|  | 					{this.isActive ? ( | ||||||
|  | 						<span style="display: inline-block; width: 10px; height: 10px; border-radius: 100%; background: #0ebe3a; position: absolute; top: 20px; right: 20px;" /> | ||||||
|  | 					) : ( | ||||||
|  | 						'' | ||||||
|  | 					)} | ||||||
|  | 					<svg-icon | ||||||
|  | 						icon-class="tree-table" | ||||||
|  | 						style="margin-left: 12px; width: 48px; height: 48px; color: #0858ff33" | ||||||
|  | 					/> | ||||||
|  | 					<div | ||||||
|  | 						class="info" | ||||||
|  | 						style="margin-left: 12px; display: flex; flex-direction: column;"> | ||||||
|  | 						<h2 style="margin: 20px 0 0; font-weight: 600; font-size: 18px; "> | ||||||
|  | 							{this.name} | ||||||
|  | 						</h2> | ||||||
|  | 						<h3 style="margin: 0;  font-weight: 400; font-size: 14px; line-height: 2; color: #888;"> | ||||||
|  | 							{this.line || '/'} | ||||||
|  | 						</h3> | ||||||
|  | 						<p style="margin: 0; text-overflow: ellipse; white-space: nowrap; font-weight: 400; font-size: 14px; line-height: 1.25; color: #888;"> | ||||||
|  | 							{this.desc} | ||||||
|  | 						</p> | ||||||
|  | 					</div> | ||||||
|  | 				</div> | ||||||
|  | 				<div | ||||||
|  | 					class="process-item__footer" | ||||||
|  | 					style="background: #f7f9fa; border-top: 1px solid #0001;"> | ||||||
|  | 					<el-row gutter={20}> | ||||||
|  | 						<el-col | ||||||
|  | 							span={8} | ||||||
|  | 							style="text-align: center; border-right: 1px solid #0001"> | ||||||
|  | 							<el-button | ||||||
|  | 								type="text" | ||||||
|  | 								style="color: #0007; line-height: 1.75" | ||||||
|  | 								onClick={this.handleEdit}> | ||||||
|  | 								编辑 | ||||||
|  | 							</el-button> | ||||||
|  | 						</el-col> | ||||||
|  | 						<el-col | ||||||
|  | 							span={8} | ||||||
|  | 							style="text-align: center; border-right: 1px solid #0001"> | ||||||
|  | 							<el-button type="text" style="color: #0007; line-height: 1.75"> | ||||||
|  | 								复制 | ||||||
|  | 							</el-button> | ||||||
|  | 						</el-col> | ||||||
|  | 						<el-col span={8} style="text-align: center;"> | ||||||
|  | 							<el-button type="text" style="color: #0007; line-height: 1.75"> | ||||||
|  | 								删除 | ||||||
|  | 							</el-button> | ||||||
|  | 						</el-col> | ||||||
|  | 					</el-row> | ||||||
|  | 				</div> | ||||||
|  | 			</div> | ||||||
|  | 		); | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	name: 'ProcessFlow', | ||||||
|  | 	components: { ProcessItem }, | ||||||
|  | 	mixins: [basicPageMixin], | ||||||
|  | 	props: {}, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			updateUrl: '/extend/process-flow/update', | ||||||
|  | 			addUrl: '/extend/process-flow/create', | ||||||
|  | 			pageUrl: '/extend/process-flow/page', | ||||||
|  | 			infoUrl: '/extend/process-flow/get', | ||||||
|  | 			searchBarKeys: ['name', 'code', 'lineId', 'productId'], | ||||||
|  | 			searchBarFormConfig: [ | ||||||
|  | 				{ | ||||||
|  | 					label: '工艺流程列表', | ||||||
|  | 				}, | ||||||
|  | 			], | ||||||
|  | 			queryParams: { | ||||||
|  | 				pageNo: 1, | ||||||
|  | 				pageSize: 10, | ||||||
|  | 				code: null, | ||||||
|  | 				name: null, | ||||||
|  | 				productId: null, | ||||||
|  | 				lineId: null, | ||||||
|  | 			}, | ||||||
|  | 			lineList: null, | ||||||
|  | 			list: [], | ||||||
|  | 			rows: [ | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '工艺名称', | ||||||
|  | 						prop: 'name', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 						// bind: { | ||||||
|  | 						// 	disabled: this.editMode == 'detail', // some condition, like detail mode... | ||||||
|  | 						// } | ||||||
|  | 					}, | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '工艺编码', | ||||||
|  | 						prop: 'code', | ||||||
|  | 						// url: '/base/core-equipment/getCode', | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						select: true, | ||||||
|  | 						label: '产线', | ||||||
|  | 						prop: 'lineId', | ||||||
|  | 						// cache: 'processFlow::lineList', | ||||||
|  | 						url: '/base/core-production-line/listAll', | ||||||
|  | 						bind: { | ||||||
|  | 							filterable: true, | ||||||
|  | 						}, | ||||||
|  | 					}, | ||||||
|  | 
 | ||||||
|  | 					{ | ||||||
|  | 						switch: true, | ||||||
|  | 						label: '是否启用', | ||||||
|  | 						prop: 'enabled', | ||||||
|  | 						bind: { | ||||||
|  | 							'active-value': 1, | ||||||
|  | 							'inactive-value': 0, | ||||||
|  | 						}, | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						textarea: true, | ||||||
|  | 						label: '功能描述', | ||||||
|  | 						prop: 'remark', | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 			], | ||||||
|  | 			form: { | ||||||
|  | 				id: null, | ||||||
|  | 				code: null, | ||||||
|  | 				name: null, | ||||||
|  | 				productId: null, | ||||||
|  | 				lineId: null, | ||||||
|  | 				enabled: 1, | ||||||
|  | 				remark: null, | ||||||
|  | 				externalCode: null, | ||||||
|  | 			}, | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	computed: {}, | ||||||
|  | 	mounted() { | ||||||
|  | 		this.getList(); | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		cancel() { | ||||||
|  | 			this.open = false; | ||||||
|  | 			this.reset(); | ||||||
|  | 		}, | ||||||
|  | 		reset() { | ||||||
|  | 			this.form = { | ||||||
|  | 				id: null, | ||||||
|  | 				code: null, | ||||||
|  | 				name: null, | ||||||
|  | 				productId: null, | ||||||
|  | 				lineId: null, | ||||||
|  | 				enabled: 1, | ||||||
|  | 				remark: null, | ||||||
|  | 				externalCode: null, | ||||||
|  | 			}; | ||||||
|  | 			this.resetForm('form'); | ||||||
|  | 		}, | ||||||
|  | 		handleAdd() { | ||||||
|  | 			this.reset(); | ||||||
|  | 			this.open = true; | ||||||
|  | 			this.showUploadComponents = false; | ||||||
|  | 			this.title = '添加工艺'; | ||||||
|  | 		}, | ||||||
|  | 		async handleUpdate(id) { | ||||||
|  | 			this.reset(); | ||||||
|  | 			const { data } = await this.info({ id }); | ||||||
|  | 			this.form = data; | ||||||
|  | 			this.open = true; | ||||||
|  | 			this.title = '修改工艺'; | ||||||
|  | 		}, | ||||||
|  | 		submitForm() { | ||||||
|  | 			this.$refs['form'].validate((valid) => { | ||||||
|  | 				if (!valid) { | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				// 修改的提交 | ||||||
|  | 				if (this.form.id != null) { | ||||||
|  | 					this.put(this.form).then((response) => { | ||||||
|  | 						this.$modal.msgSuccess('修改成功'); | ||||||
|  | 						this.open = false; | ||||||
|  | 						this.getList(); | ||||||
|  | 					}); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				// 添加的提交 | ||||||
|  | 				this.post(this.form).then((response) => { | ||||||
|  | 					this.$modal.msgSuccess('新增成功'); | ||||||
|  | 					this.open = false; | ||||||
|  | 					this.getList(); | ||||||
|  | 				}); | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		async getList() { | ||||||
|  | 			this.loading = true; | ||||||
|  | 			const { code, data } = await this.recv(this.queryParams); | ||||||
|  | 			if (code == 0) { | ||||||
|  | 				this.list = data.list; | ||||||
|  | 				this.total = data.total; | ||||||
|  | 				this.loading = false; | ||||||
|  | 				return; | ||||||
|  | 			} | ||||||
|  | 			this.loading = false; | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		// async getList() { | ||||||
|  | 		// 	this.loading = true; | ||||||
|  | 		// 	const { code, data } = await this.recv(this.queryParams); | ||||||
|  | 		// 	if (code == 0) { | ||||||
|  | 		// 		const list = []; | ||||||
|  | 		// 		for (const item of data.list) { | ||||||
|  | 		// 			const newItem = await this.itemAttachName(item); | ||||||
|  | 		// 			list.push(newItem); | ||||||
|  | 		// 		} | ||||||
|  | 		// 		this.list = list; | ||||||
|  | 		// 		this.total = data.total; | ||||||
|  | 		// 		this.loading = false; | ||||||
|  | 		// 		return; | ||||||
|  | 		// 	} | ||||||
|  | 		// 	this.loading = false; | ||||||
|  | 		// }, | ||||||
|  | 
 | ||||||
|  | 		// async itemAttachName(item) { | ||||||
|  | 		// 	if (!this.lineList) { | ||||||
|  | 		// 		this.lineList = await cache.getList( | ||||||
|  | 		// 			'processFlow::lineList', | ||||||
|  | 		// 			async () => { | ||||||
|  | 		// 				const { code, data } = await this.$axios( | ||||||
|  | 		// 					'/base/core-production-line/listAll' | ||||||
|  | 		// 				); | ||||||
|  | 		// 				if (code == 0) { | ||||||
|  | 		// 					return data; | ||||||
|  | 		// 				} | ||||||
|  | 		// 			} | ||||||
|  | 		// 		); | ||||||
|  | 		// 	} | ||||||
|  | 		// 	return { | ||||||
|  | 		// 		...item, | ||||||
|  | 		// 		lineName: this.lineList.find((line) => line.id == item.lineId)?.name, | ||||||
|  | 		// 	}; | ||||||
|  | 		// }, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style scoped lang="scss"> | ||||||
|  | .process-flow { | ||||||
|  | 	display: grid; | ||||||
|  | 	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); | ||||||
|  | 	grid-auto-rows: 200px; | ||||||
|  | 	gap: 24px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .process-item__add-btn { | ||||||
|  | 	display: grid; | ||||||
|  | 	border: 1px solid #ccc; | ||||||
|  | 	font-size: 20px; | ||||||
|  | 	color: #ccc; | ||||||
|  | 	border-style: dashed; | ||||||
|  | 	border-radius: 6px; | ||||||
|  | 	place-items: center; | ||||||
|  | 	cursor: pointer; | ||||||
|  | 	transition: all 0.2s ease-in; | ||||||
|  | 
 | ||||||
|  | 	&:hover { | ||||||
|  | 		color: #555; | ||||||
|  | 		border-color: #555; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .process-item { | ||||||
|  | 	border-radius: 4px; | ||||||
|  | 	box-shadow: 0 0 6px 1px #ccc; | ||||||
|  | 	overflow: hidden; | ||||||
|  | 
 | ||||||
|  | 	// &.active { | ||||||
|  | 	// 	box-shadow: 0 0 6px 1px #18c8bf66; | ||||||
|  | 	// } | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										138
									
								
								src/views/extend/processFlowView/components/ProcessBomList.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,138 @@ | |||||||
|  | <!--  | ||||||
|  |     filename: ProcessBomList.vue | ||||||
|  |     author: liubin | ||||||
|  |     date: 2023-10-20 15:00:58 | ||||||
|  |     description:  | ||||||
|  | --> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  | 	<section class="process-bom"> | ||||||
|  | 		<SearchBar :formConfigs="searchBarFormConfig" ref="search-bar" /> | ||||||
|  | 
 | ||||||
|  | 		<div class="btns" style=" | ||||||
|  | 				text-align: right; | ||||||
|  | 				position: absolute; | ||||||
|  | 				top: 20px; | ||||||
|  | 				right: 20px; | ||||||
|  | 				display: flex; | ||||||
|  | 			"> | ||||||
|  | 			<el-button type="primary" plain :disabled="currentDet == null" class="btn-create" icon="el-icon-plus"> | ||||||
|  | 				分配设备 | ||||||
|  | 			</el-button> | ||||||
|  | 			<el-input icon="el-icon-search" placeholder="搜索" v-model="searchText"  style="margin-left: 20px"> | ||||||
|  | 				<i slot="prefix" class="el-input__icon el-icon-search"></i> | ||||||
|  | 			</el-input> | ||||||
|  | 		</div> | ||||||
|  | 
 | ||||||
|  | 		<!-- 列表 --> | ||||||
|  | 		<base-table :table-props="tableProps" :page="queryParams.pageNo" :limit="queryParams.pageSize" :table-data="list" | ||||||
|  | 			@emitFun="handleEmitFun"> | ||||||
|  | 			<method-btn v-if="tableBtn.length" slot="handleBtn" label="操作" :width="120" :method-list="tableBtn" | ||||||
|  | 				@clickBtn="handleTableBtnClick" /> | ||||||
|  | 		</base-table> | ||||||
|  | 
 | ||||||
|  | 		<!-- 分页组件 --> | ||||||
|  | 		<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize" | ||||||
|  | 			@pagination="getList" /> | ||||||
|  | 	</section> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  | 	name: 'ProcessBom', | ||||||
|  | 	components: {}, | ||||||
|  | 	props: { | ||||||
|  | 		currentDet: { | ||||||
|  | 			type: Object, | ||||||
|  | 			default: null | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			searchBarFormConfig: [{ label: '工序下设备' }], | ||||||
|  | 			tableProps: [ | ||||||
|  | 				// { | ||||||
|  | 				// 	prop: 'createTime', | ||||||
|  | 				// 	label: '添加时间', | ||||||
|  | 				// 	fixed: true, | ||||||
|  | 				// 	width: 180, | ||||||
|  | 				// 	filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'), | ||||||
|  | 				// }, | ||||||
|  | 				{ prop: 'name', label: '设备名称' }, | ||||||
|  | 				{ prop: 'code', label: '物料BOM' }, | ||||||
|  | 				{ prop: 'remark', label: '参数BOM' }, | ||||||
|  | 			], | ||||||
|  | 			list: [], | ||||||
|  | 			total: 0, | ||||||
|  | 			tableBtn: [], | ||||||
|  | 			queryParams: { | ||||||
|  | 				pageNo: 1, | ||||||
|  | 				pageSize: 10, | ||||||
|  | 			}, | ||||||
|  | 			searchText: '' | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	watch: { | ||||||
|  | 		currentDet: { | ||||||
|  | 			handler(val) { | ||||||
|  | 				if (val != null) { | ||||||
|  | 					this.getList(val); | ||||||
|  | 				} else { | ||||||
|  | 					this.clearList(); | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			immediate: true, | ||||||
|  | 			deep: true | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	methods: { | ||||||
|  | 		handleEmitFun() { }, | ||||||
|  | 		handleTableBtnClick() { }, | ||||||
|  | 		put(payload) { | ||||||
|  | 			return this.http(this.updateUrl, 'put', payload); | ||||||
|  | 		}, | ||||||
|  | 		post(payload) { | ||||||
|  | 			return this.http(this.addUrl, 'post', payload); | ||||||
|  | 		}, | ||||||
|  | 		recv(payload) { | ||||||
|  | 			return this.http(this.pageUrl, 'get', payload); | ||||||
|  | 		}, | ||||||
|  | 		info(payload) { | ||||||
|  | 			return this.http(this.infoUrl, 'get', payload); | ||||||
|  | 		}, | ||||||
|  | 		http(url, method, payload) { | ||||||
|  | 			return this.$axios({ | ||||||
|  | 				url, | ||||||
|  | 				method, | ||||||
|  | 				params: method === 'get' ? payload : null, | ||||||
|  | 				data: method !== 'get' ? payload : null, | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		getList({ detId, detName, detDesc, flowId, sectionName } = {}) { | ||||||
|  | 			console.log('get list') | ||||||
|  | 
 | ||||||
|  | 		}, | ||||||
|  | 		getList() { | ||||||
|  | 			this.list = [ | ||||||
|  | 				{ name: '1', code: 'bomg-1', remark: 'Tochter' }, | ||||||
|  | 				{ name: '2', code: 'bomg-2', remark: 'Bruder' }, | ||||||
|  | 				{ name: '3', code: 'bomg-3', remark: 'Kalt' }, | ||||||
|  | 			] | ||||||
|  | 		}, | ||||||
|  | 		clearList() { | ||||||
|  | 			this.list = []; | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style scoped lang="scss"> | ||||||
|  | .process-bom { | ||||||
|  | 	position: relative; | ||||||
|  | 	flex: 1; | ||||||
|  | 	padding: 12px 20px; | ||||||
|  | 	background: #fff; | ||||||
|  | 	border-radius: 8px; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										482
									
								
								src/views/extend/processFlowView/components/ProcessDetail.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,482 @@ | |||||||
|  | <!--  | ||||||
|  |     filename: ProcessGraph.vue | ||||||
|  |     author: liubin | ||||||
|  |     date: 2023-10-20 15:00:58 | ||||||
|  |     description:  | ||||||
|  | --> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  | 	<section class="process-graph"> | ||||||
|  | 		<SearchBar :formConfigs="searchBarFormConfig" ref="search-bar" /> | ||||||
|  | 
 | ||||||
|  | 		<div class="btns" style="text-align: right; position: absolute; top: 20px; right: 20px"> | ||||||
|  | 			<el-button type="warning" @click="undo" plain v-if="allowUndo" :disabled="!allowUndo" icon="el-icon-back"> | ||||||
|  | 				撤销 | ||||||
|  | 			</el-button> | ||||||
|  | 			<el-button type="warning" @click="redo" plain v-if="allowRedo" :disabled="!allowRedo"> | ||||||
|  | 				下一步 | ||||||
|  | 				<i class="el-icon-right el-icon--right"></i> | ||||||
|  | 			</el-button> | ||||||
|  | 			<el-button class="btn-refresh" @click="handleUpdateLayout" icon="el-icon-refresh"> | ||||||
|  | 				刷新布局</el-button> | ||||||
|  | 			<el-button type="primary" plain class="btn-create" icon="el-icon-plus" @click="handleAdd"> | ||||||
|  | 				新建工序 | ||||||
|  | 			</el-button> | ||||||
|  | 			<el-button class="btn-edit" :disabled="currentDet == null" @click="handleEdit">编辑</el-button> | ||||||
|  | 		</div> | ||||||
|  | 
 | ||||||
|  | 		<div class="process-graph__panel" ref="panel"></div> | ||||||
|  | 
 | ||||||
|  | 		<base-dialog :dialogTitle="title" :dialogVisible="open" width="35%" @close="cancel" @cancel="cancel" | ||||||
|  | 			@confirm="submitForm"> | ||||||
|  | 			<DialogForm v-if="open" ref="form" v-model="form" :rows="rows" /> | ||||||
|  | 		</base-dialog> | ||||||
|  | 	</section> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import { Graph } from '@antv/x6'; | ||||||
|  | import ProcessNode, { createProcessNode, CACHE_NAME, getSectionFrom } from './ProcessNode'; | ||||||
|  | import DialogForm from '@/components/DialogForm'; | ||||||
|  | // import { IdToName } from '@/utils' | ||||||
|  | 
 | ||||||
|  | Graph.registerNode('process-node', ProcessNode); | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	name: 'ProcessGraph', | ||||||
|  | 	components: { DialogForm }, | ||||||
|  | 	props: {}, | ||||||
|  | 	inject: ['getFlowId'], | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			allowRedo: false, | ||||||
|  | 			allowUndo: false, | ||||||
|  | 			graph: null, | ||||||
|  | 			searchBarFormConfig: [{ label: '工序列表' }], | ||||||
|  | 			title: '', | ||||||
|  | 			open: false, | ||||||
|  | 			form: { | ||||||
|  | 				name: '', // 工序名称 | ||||||
|  | 				sectionId: '', // 工段id | ||||||
|  | 				remark: '', // 描述 | ||||||
|  | 			}, | ||||||
|  | 			rows: [ | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						input: true, | ||||||
|  | 						label: '工序名称', | ||||||
|  | 						prop: 'name', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						select: true, | ||||||
|  | 						label: '工段', | ||||||
|  | 						prop: 'sectionId', | ||||||
|  | 						url: '/base/core-workshop-section/listAll', | ||||||
|  | 						rules: [{ required: true, message: '不能为空', trigger: 'blur' }], | ||||||
|  | 						bind: { | ||||||
|  | 							filterable: true, | ||||||
|  | 						}, | ||||||
|  | 						cache: CACHE_NAME | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 				[ | ||||||
|  | 					{ | ||||||
|  | 						textarea: true, | ||||||
|  | 						label: '工序说明', | ||||||
|  | 						prop: 'remark', | ||||||
|  | 					}, | ||||||
|  | 				], | ||||||
|  | 			], | ||||||
|  | 			updateUrl: '/extend/process-flow-det/update', | ||||||
|  | 			deleteUrl: '/extend/process-flow-det/delete', | ||||||
|  | 			addUrl: '/extend/process-flow-det/create', | ||||||
|  | 			// pageUrl: '/extend/process-flow-det/get', | ||||||
|  | 			infoUrl: '/extend/process-flow-view/getByFlowId', | ||||||
|  | 			layout: { | ||||||
|  | 				id: null, | ||||||
|  | 				flowId: null, | ||||||
|  | 				content: '', | ||||||
|  | 				createTime: null | ||||||
|  | 			}, | ||||||
|  | 			currentDet: null, | ||||||
|  | 			currentNode: null | ||||||
|  | 
 | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	watch: { | ||||||
|  | 		'form.sectionId': { | ||||||
|  | 			handler(id) { | ||||||
|  | 			}, | ||||||
|  | 			immediate: false, | ||||||
|  | 		}, | ||||||
|  | 		currentDet: { | ||||||
|  | 			handler(val) { | ||||||
|  | 				this.$emit('det-selected', val) | ||||||
|  | 			}, | ||||||
|  | 			deep: true, | ||||||
|  | 			immediate: true | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	activated() { | ||||||
|  | 		this.loadLayout().then(json => { | ||||||
|  | 			this.initGraph(json) | ||||||
|  | 		}) | ||||||
|  | 	}, | ||||||
|  | 	deactivated() { | ||||||
|  | 		this.graph.dispose(); | ||||||
|  | 		this.$nextTick(() => { | ||||||
|  | 			this.resetLayout(); | ||||||
|  | 			this.graph = null; | ||||||
|  | 		}) | ||||||
|  | 	}, | ||||||
|  | 	computed: {}, | ||||||
|  | 	methods: { | ||||||
|  | 
 | ||||||
|  | 		initGraph(json) { | ||||||
|  | 			const graph = new Graph({ | ||||||
|  | 				container: this.$refs.panel, | ||||||
|  | 				grid: { | ||||||
|  | 					size: 10, | ||||||
|  | 					visible: true, | ||||||
|  | 				}, | ||||||
|  | 				history: true, | ||||||
|  | 				selecting: { | ||||||
|  | 					className: 'my-select' | ||||||
|  | 				}, | ||||||
|  | 				connecting: { | ||||||
|  | 					snap: true, | ||||||
|  | 					allowBlank: false, | ||||||
|  | 					allowLoop: false, | ||||||
|  | 					allowNode: false, | ||||||
|  | 					allowPort: true, | ||||||
|  | 					allowEdge: false, | ||||||
|  | 				}, | ||||||
|  | 				panning: true, | ||||||
|  | 				// scroller: { | ||||||
|  | 				// 	enabled: true, | ||||||
|  | 				// 	pannable: true, | ||||||
|  | 				// 	cursor: '', | ||||||
|  | 				// 	width: 800, | ||||||
|  | 				// 	height: 200 | ||||||
|  | 				// }, | ||||||
|  | 				mousewheel: { | ||||||
|  | 					enabled: true, | ||||||
|  | 					modifiers: ['ctrl', 'meta'] | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 
 | ||||||
|  | 			graph.fromJSON(json) | ||||||
|  | 			this.graph = graph; | ||||||
|  | 			this.$nextTick(() => { | ||||||
|  | 				this.registerGraphEvents(); | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		registerGraphEvents() { | ||||||
|  | 			const reset = () => { | ||||||
|  | 				const nodes = this.graph.getNodes(); | ||||||
|  | 				const edges = this.graph.getEdges(); | ||||||
|  | 				this.currentDet = null; | ||||||
|  | 				this.currentNode = null; | ||||||
|  | 
 | ||||||
|  | 				nodes.forEach(node => { | ||||||
|  | 					node.attr('container/stroke', '#ccc'); | ||||||
|  | 				}); | ||||||
|  | 				edges.forEach(edge => { | ||||||
|  | 					edge.attr('line/stroke', '#ccc') | ||||||
|  | 				}) | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			this.graph.on('node:click', ({ e, x, y, node, view }) => { | ||||||
|  | 				reset(); | ||||||
|  | 				node.attr('container/stroke', '#0b58ff'); | ||||||
|  | 				const { detId, detName, detDesc, processId, sectionId, sectionName } = node.attrs; | ||||||
|  | 				this.currentDet = {} | ||||||
|  | 				this.$set(this.currentDet, 'detId', detId.text) | ||||||
|  | 				this.$set(this.currentDet, 'sectionId', sectionId.text) | ||||||
|  | 				this.$set(this.currentDet, 'detName', detName.text) | ||||||
|  | 				this.$set(this.currentDet, 'detDesc', detDesc.text) | ||||||
|  | 				this.$set(this.currentDet, 'flowId', processId.text) | ||||||
|  | 				this.$set(this.currentDet, 'sectionName', sectionName.text) | ||||||
|  | 				this.currentNode = node | ||||||
|  | 			}); | ||||||
|  | 			this.graph.on('edge:click', ({ e, x, y, edge, view }) => { | ||||||
|  | 				// console.log('edge clicked!', edge) | ||||||
|  | 				reset(); | ||||||
|  | 				edge.attr('line/stroke', '#0b58ff') | ||||||
|  | 			}); | ||||||
|  | 			this.graph.on('blank:click', ({ e, x, y }) => { | ||||||
|  | 				reset(); | ||||||
|  | 			}); | ||||||
|  | 			this.graph.on('node:mouseenter', ({ node }) => { | ||||||
|  | 				node.addTools({ | ||||||
|  | 					name: 'button-remove', | ||||||
|  | 					args: { | ||||||
|  | 						x: '100%', | ||||||
|  | 						y: 0, | ||||||
|  | 						offset: { x: 0, y: 0 }, | ||||||
|  | 						onClick: ({ e, cell, view }) => { | ||||||
|  | 							this.$confirm( | ||||||
|  | 								'确定删除这个工序吗?', | ||||||
|  | 								'提示', | ||||||
|  | 								{ | ||||||
|  | 									confirmButtonText: '确定', | ||||||
|  | 									cancelButtonText: '取消', | ||||||
|  | 									type: 'warning' | ||||||
|  | 								} | ||||||
|  | 							).then(async () => { | ||||||
|  | 								const id = node.attrs.detId.text; | ||||||
|  | 								const status = await this.handleDelete(id); | ||||||
|  | 								if (status) { | ||||||
|  | 									view.cell.remove(); | ||||||
|  | 								} | ||||||
|  | 							}).catch(err => { | ||||||
|  | 								return; | ||||||
|  | 							}) | ||||||
|  | 						} | ||||||
|  | 					} | ||||||
|  | 				}) | ||||||
|  | 			}); | ||||||
|  | 			this.graph.on('node:mouseleave', ({ node }) => { | ||||||
|  | 				node.removeTools(); | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		resetLayout() { | ||||||
|  | 			this.layout = { | ||||||
|  | 				id: null, | ||||||
|  | 				flowId: null, | ||||||
|  | 				content: '', | ||||||
|  | 				createTime: null | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		async loadLayout() { | ||||||
|  | 			const flowId = this.$route.params.id; | ||||||
|  | 			if (!flowId) return { cells: [] } | ||||||
|  | 			const { code, data } = await this.info({ id: flowId }); | ||||||
|  | 			if (code == 0) { | ||||||
|  | 				if (data) { | ||||||
|  | 					this.layout = data; | ||||||
|  | 					return JSON.parse(data?.content) || { cells: [] }; | ||||||
|  | 				} | ||||||
|  | 				return { cells: [] }; | ||||||
|  | 			} | ||||||
|  | 			this.resetLayout(); | ||||||
|  | 			return Promise.reject(this.infoUrl + ' 接口出错!'); | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		handleToJson() { }, | ||||||
|  | 
 | ||||||
|  | 		handleLoadJson() { }, | ||||||
|  | 
 | ||||||
|  | 		handleDumpJson() { | ||||||
|  | 			if (this.graph) { | ||||||
|  | 				console.log(JSON.stringify(this.graph.toJSON(), null, 2)); | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		async handleUpdateLayout() { | ||||||
|  | 			this.layout.content = JSON.stringify(this.graph.toJSON()); | ||||||
|  | 			let code, data; | ||||||
|  | 			console.table([this.layout, this.$route.params.id]) | ||||||
|  | 			// 手动刷新布局 | ||||||
|  | 			if (this.layout.id) { | ||||||
|  | 				({ code, data } = await this.http('/extend/process-flow-view/update', 'put', this.layout)); | ||||||
|  | 			} else { | ||||||
|  | 				this.layout.flowId = this.$route.params.id; | ||||||
|  | 				({ code, data } = await this.http('/extend/process-flow-view/create', 'post', this.layout)); | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			if (code == 0) { | ||||||
|  | 				this.$modal.msgSuccess('布局已刷新!') | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		reset() { | ||||||
|  | 			this.form = { | ||||||
|  | 				name: '', // 工序名称 | ||||||
|  | 				sectionId: '', // 工段id | ||||||
|  | 				remark: '', // 描述 | ||||||
|  | 			}; | ||||||
|  | 			this.resetForm('form'); | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		/** 取消按钮 */ | ||||||
|  | 		cancel() { | ||||||
|  | 			this.open = false; | ||||||
|  | 			this.reset(); | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		handleAdd() { | ||||||
|  | 			this.reset(); | ||||||
|  | 			this.open = true; | ||||||
|  | 			this.title = '添加工序'; | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		handleEdit() { | ||||||
|  | 			this.form.name = this.currentDet.detName; | ||||||
|  | 			this.form.sectionId = this.currentDet.sectionId; | ||||||
|  | 			this.form.remark = this.currentDet.detDesc; | ||||||
|  | 			this.form.id = this.currentDet.detId; | ||||||
|  | 			this.title = '编辑工序'; | ||||||
|  | 			this.$nextTick(() => { | ||||||
|  | 				this.open = true; | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		async handleDelete(id) { | ||||||
|  | 			const { code, data } = await this.delete({ id }); | ||||||
|  | 			debugger; | ||||||
|  | 			if (code == 0) { | ||||||
|  | 				this.$modal.msgSuccess('成功删除一个工序!'); | ||||||
|  | 				return true; | ||||||
|  | 			} | ||||||
|  | 			return false; | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		/** 提交按钮 */ | ||||||
|  | 		submitForm() { | ||||||
|  | 			this.$refs['form'].validate((valid) => { | ||||||
|  | 				if (!valid) { | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 				// 修改的提交 | ||||||
|  | 				if (this.form.id != null) { | ||||||
|  | 					this.updateProcess() | ||||||
|  | 						.then((form) => { | ||||||
|  | 							const { name, sectionId, remark } = form; | ||||||
|  | 							getSectionFrom(sectionId).then(sectionName => { | ||||||
|  | 								// 修改当前node的信息  | ||||||
|  | 								this.currentNode.setAttrs({ | ||||||
|  | 									detName: { text: name }, | ||||||
|  | 									sectionId: { text: sectionId }, | ||||||
|  | 									sectionName: { text: sectionName }, | ||||||
|  | 									detDesc: { text: remark } | ||||||
|  | 								}) | ||||||
|  | 							}) | ||||||
|  | 						}) | ||||||
|  | 						.catch(err => { }); | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  | 
 | ||||||
|  | 				this.createProcess() | ||||||
|  | 					.then(({ id, name, sectionId, remark, flowId }) => { | ||||||
|  | 						if (!id) return null; | ||||||
|  | 						return createProcessNode({ | ||||||
|  | 							flowId: flowId, | ||||||
|  | 							name, sectionId, remark, | ||||||
|  | 							id, | ||||||
|  | 						}) | ||||||
|  | 					}).then(node => { | ||||||
|  | 						if (!node) { | ||||||
|  | 							this.$modal.msgError('创建节点失败'); | ||||||
|  | 							return; | ||||||
|  | 						}; | ||||||
|  | 						this.graph.addNode(node); | ||||||
|  | 					}).catch(err => { | ||||||
|  | 						return; | ||||||
|  | 					}); | ||||||
|  | 
 | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		updateProcess() { | ||||||
|  | 			const flowId = this.getFlowId(); | ||||||
|  | 			if (!flowId) { | ||||||
|  | 				this.$modal.msgError('工艺ID不能为空'); | ||||||
|  | 				return Promise.reject('工艺ID不能为空'); | ||||||
|  | 			} | ||||||
|  | 			return this.put({ flowId, ...this.form }) | ||||||
|  | 				.then(({ code, data }) => { | ||||||
|  | 					if (code == 0) { | ||||||
|  | 						this.$modal.msgSuccess('修改成功'); | ||||||
|  | 					} else { | ||||||
|  | 						this.$modal.msgError('修改失败'); | ||||||
|  | 					} | ||||||
|  | 					const formCopy = { ...this.form } | ||||||
|  | 					this.open = false; | ||||||
|  | 					return formCopy; | ||||||
|  | 				}); | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		createProcess() { | ||||||
|  | 			// const flowId = this.$route.params.id; | ||||||
|  | 			const flowId = this.getFlowId(); // it also works | ||||||
|  | 			if (!flowId) { | ||||||
|  | 				this.$modal.msgError('工艺ID不能为空'); | ||||||
|  | 				return Promise.reject('工艺ID不能为空'); | ||||||
|  | 			} | ||||||
|  | 			console.log('create process', this.form) | ||||||
|  | 			// 添加的提交 | ||||||
|  | 			return this.post({ flowId, ...this.form }).then( | ||||||
|  | 				({ code, data }) => { | ||||||
|  | 					this.$modal.msgSuccess('新增成功'); | ||||||
|  | 					this.open = false; | ||||||
|  | 					// this.getList(); | ||||||
|  | 					return { | ||||||
|  | 						id: data, // 服务器返回的新建的工段id | ||||||
|  | 						...this.form,  // 保存一份 this.form 副本,当 open->false 时 this.form 里的信息就清空了 | ||||||
|  | 						flowId | ||||||
|  | 					}; | ||||||
|  | 				} | ||||||
|  | 			).catch(err => { | ||||||
|  | 				this.$modal.msgError(err) | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 
 | ||||||
|  | 		put(payload) { | ||||||
|  | 			return this.http(this.updateUrl, 'put', payload); | ||||||
|  | 		}, | ||||||
|  | 		post(payload) { | ||||||
|  | 			return this.http(this.addUrl, 'post', payload); | ||||||
|  | 		}, | ||||||
|  | 		recv(payload) { | ||||||
|  | 			return this.http(this.pageUrl, 'get', payload); | ||||||
|  | 		}, | ||||||
|  | 		info(payload) { | ||||||
|  | 			return this.http(this.infoUrl, 'get', payload); | ||||||
|  | 		}, | ||||||
|  | 		delete({ id }) { | ||||||
|  | 			return this.$axios({ | ||||||
|  | 				url: this.deleteUrl + `?id=${id}`, | ||||||
|  | 				method: 'delete', | ||||||
|  | 			}); | ||||||
|  | 		}, | ||||||
|  | 		http(url, method, payload) { | ||||||
|  | 			return this.$axios({ | ||||||
|  | 				url, | ||||||
|  | 				method, | ||||||
|  | 				params: method === 'get' ? payload : null, | ||||||
|  | 				data: method !== 'get' ? payload : null, | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style scoped lang="scss"> | ||||||
|  | .process-graph { | ||||||
|  | 	padding: 12px 20px 20px; | ||||||
|  | 	background: #fff; | ||||||
|  | 	border-radius: 8px; | ||||||
|  | 	position: relative; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .process-graph__panel { | ||||||
|  | 	height: 300px; | ||||||
|  | } | ||||||
|  | </style> | ||||||
|  | 
 | ||||||
|  | <style> | ||||||
|  | .x6-widget-selection-selected { | ||||||
|  | 	border: 1px solid red; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .my-select { | ||||||
|  | 	border: 1px solid red; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										133
									
								
								src/views/extend/processFlowView/components/ProcessInfo.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,133 @@ | |||||||
|  | <!--  | ||||||
|  |     filename: ProcessInfo.vue | ||||||
|  |     author: liubin | ||||||
|  |     date: 2023-10-20 15:00:58 | ||||||
|  |     description:  | ||||||
|  | --> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  | 	<section class="process-info"> | ||||||
|  | 		<SearchBar :formConfigs="searchBarFormConfig" ref="search-bar" /> | ||||||
|  | 
 | ||||||
|  | 		<el-row :gutter="20"> | ||||||
|  | 			<el-col :span="6"> | ||||||
|  | 				<InfoItem label="工艺名称" :value="form.name" /> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="6"> | ||||||
|  | 				<InfoItem label="产线" :value="form.lineName" /> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="12"> | ||||||
|  | 				<InfoItem label="工艺描述" :value="form.remark" /> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 
 | ||||||
|  | 		<el-row :gutter="20" style="margin-top: 12px;"> | ||||||
|  | 			<el-col :span="6"> | ||||||
|  | 				<!-- <InfoItem label="创建人" value="xxse" /> --> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="6"> | ||||||
|  | 				<InfoItem label="创建时间" :value="form.createTime" /> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="6"> | ||||||
|  | 				<!-- <InfoItem label="更新人" value="xxse" /> --> | ||||||
|  | 			</el-col> | ||||||
|  | 			<el-col :span="6"> | ||||||
|  | 				<!-- <InfoItem label="更新时间" value="2023-10-22 10:11:00" /> --> | ||||||
|  | 			</el-col> | ||||||
|  | 		</el-row> | ||||||
|  | 	</section> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | 
 | ||||||
|  | const InfoItem = { | ||||||
|  | 	name: 'InfoItem', | ||||||
|  | 	components: {}, | ||||||
|  | 	props: ['label', 'value'], | ||||||
|  | 	data() { | ||||||
|  | 		return {}; | ||||||
|  | 	}, | ||||||
|  | 	computed: {}, | ||||||
|  | 	methods: {}, | ||||||
|  | 	render: function (h) { | ||||||
|  | 		return ( | ||||||
|  | 			<div style="display: flex; align-items: center; font-size: 14px; line-height: 1.5"> | ||||||
|  | 				<span style="width: 100px; text-align: left; font-weight: 700">{this.label}:</span> | ||||||
|  | 				<span style="width: 200px; text-align: left; text-overflow: ellipse; white-space: nowrap"> | ||||||
|  | 					{this.value} | ||||||
|  | 				</span> | ||||||
|  | 			</div> | ||||||
|  | 		); | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	name: 'ProcessInfo', | ||||||
|  | 	components: { InfoItem }, | ||||||
|  | 	props: {}, | ||||||
|  | 	inject: ['getFlowId'], | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			infoUrl: '/extend/process-flow/get', | ||||||
|  | 			searchBarFormConfig: [{ label: '工艺详情' }], | ||||||
|  | 			form: { | ||||||
|  | 				id: null, | ||||||
|  | 				name: null, | ||||||
|  | 				lineName: null, | ||||||
|  | 				createTime: null, | ||||||
|  | 				remark: null, | ||||||
|  | 				enable: null, | ||||||
|  | 				code: null | ||||||
|  | 			}, | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	activated() { | ||||||
|  | 		this.getInfo() | ||||||
|  | 	}, | ||||||
|  | 	computed: {}, | ||||||
|  | 	methods: { | ||||||
|  | 		// utils | ||||||
|  | 		http(url, method, payload) { | ||||||
|  | 			return this.$axios({ | ||||||
|  | 				url, | ||||||
|  | 				method, | ||||||
|  | 				params: method === 'get' ? payload : null, | ||||||
|  | 				data: method !== 'get' ? payload : null, | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 		put(payload) { | ||||||
|  | 			return this.http(this.updateUrl, 'put', payload); | ||||||
|  | 		}, | ||||||
|  | 		post(payload) { | ||||||
|  | 			return this.http(this.addUrl, 'post', payload); | ||||||
|  | 		}, | ||||||
|  | 		recv(payload) { | ||||||
|  | 			return this.http(this.pageUrl, 'get', payload); | ||||||
|  | 		}, | ||||||
|  | 		info(payload) { | ||||||
|  | 			return this.http(this.infoUrl, 'get', payload); | ||||||
|  | 		}, | ||||||
|  | 		async getInfo() { | ||||||
|  | 			const flowId = this.$route.params.id; | ||||||
|  | 			if (!flowId) this.$router.go(-1); | ||||||
|  | 			const { code, data } = await this.info({ id: flowId }); | ||||||
|  | 			// debugger; | ||||||
|  | 			if (code == 0) { | ||||||
|  | 				this.form = { | ||||||
|  | 					...data | ||||||
|  | 				}; | ||||||
|  | 			} else { | ||||||
|  | 				this.$modal.msgError('工艺信息获取失败') | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style scoped lang="scss"> | ||||||
|  | .process-info { | ||||||
|  | 	padding: 12px 20px 20px; | ||||||
|  | 	background: #fff; | ||||||
|  | 	border-radius: 8px; | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										170
									
								
								src/views/extend/processFlowView/components/ProcessNode.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,170 @@ | |||||||
|  | import { Node, ObjectExt, Shape } from '@antv/x6'; | ||||||
|  | import { IdToName } from '@/utils' | ||||||
|  | import cache from '@/utils/cache' | ||||||
|  | import axios from '@/utils/request' | ||||||
|  | import { v4 } from 'uuid' | ||||||
|  | 
 | ||||||
|  | Shape.Edge.config({ | ||||||
|  |     attrs: { | ||||||
|  |         line: { | ||||||
|  |             stroke: '#ccc', | ||||||
|  |             strokeWidth: 1, | ||||||
|  |             targetMarker: { | ||||||
|  |                 name: 'block', | ||||||
|  |                 width: 1, | ||||||
|  |                 height: 1 | ||||||
|  |             }, | ||||||
|  |         }, | ||||||
|  |     } | ||||||
|  | }) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | export default class ProcessNode extends Node { } | ||||||
|  | ProcessNode.config({ | ||||||
|  |     width: 200, | ||||||
|  |     height: 100, | ||||||
|  |     markup: [ | ||||||
|  |         { | ||||||
|  |             tagName: 'rect', | ||||||
|  |             selector: 'container', | ||||||
|  |             attrs: { | ||||||
|  |                 x: 0, | ||||||
|  |                 y: 0, | ||||||
|  |                 width: 200, | ||||||
|  |                 height: 100, | ||||||
|  |                 fill: 'transparent', | ||||||
|  |                 stroke: '#ccc' | ||||||
|  |             }, | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             tagName: 'rect', | ||||||
|  |             attrs: { | ||||||
|  |                 x: 0, | ||||||
|  |                 y: 0, | ||||||
|  |                 width: 200, | ||||||
|  |                 height: 50, | ||||||
|  |                 fill: '#ffffff', | ||||||
|  |             }, | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             tagName: 'rect', | ||||||
|  |             attrs: { | ||||||
|  |                 x: 0, | ||||||
|  |                 y: 50, | ||||||
|  |                 width: 200, | ||||||
|  |                 height: 50, | ||||||
|  |                 fill: '#f8f8f8', | ||||||
|  |             }, | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             tagName: 'text', | ||||||
|  |             selector: 'detName', | ||||||
|  |             attrs: { | ||||||
|  |                 x: 20, | ||||||
|  |                 y: 30, | ||||||
|  |             }, | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             tagName: 'text', | ||||||
|  |             selector: 'sectionName', | ||||||
|  |             attrs: { | ||||||
|  |                 x: 115, | ||||||
|  |                 y: 30, | ||||||
|  |             }, | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             tagName: 'text', | ||||||
|  |             selector: 'detDesc', | ||||||
|  |             attrs: { | ||||||
|  |                 x: 26, | ||||||
|  |                 y: 80, | ||||||
|  |                 fill: '#777', | ||||||
|  |                 fontSize: 14, | ||||||
|  |                 fill: '#1a90fc', | ||||||
|  |             }, | ||||||
|  |         }, | ||||||
|  |     ], | ||||||
|  |     attrs: { | ||||||
|  |         line: { | ||||||
|  |             fill: 'red' | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     ports: { | ||||||
|  |         groups: { | ||||||
|  |             in: { | ||||||
|  |                 position: 'left', | ||||||
|  |                 attrs: { | ||||||
|  |                     circle: { | ||||||
|  |                         r: 2, | ||||||
|  |                         magnet: true, | ||||||
|  |                         stroke: '#0b58ff', | ||||||
|  |                         strokeWidth: 1, | ||||||
|  |                         fill: '#0b58ff' | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             }, | ||||||
|  |             out: { | ||||||
|  |                 position: 'right', | ||||||
|  |                 attrs: { | ||||||
|  |                     circle: { | ||||||
|  |                         r: 2, | ||||||
|  |                         magnet: true, | ||||||
|  |                         stroke: '#0b58ff', | ||||||
|  |                         strokeWidth: 1, | ||||||
|  |                         fill: '#0b58ff' | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|  |     propHooks(metadata) { | ||||||
|  |         const { detId, detName, detDesc, sectionName, processId, sectionId, ...others } = metadata; | ||||||
|  |         // debugger;
 | ||||||
|  |         if (detName) ObjectExt.setByPath(others, 'attrs/detName/text', detName); | ||||||
|  |         if (detDesc) ObjectExt.setByPath(others, 'attrs/detDesc/text', detDesc); | ||||||
|  |         if (sectionName) ObjectExt.setByPath(others, 'attrs/sectionName/text', sectionName); | ||||||
|  |         if (detId) ObjectExt.setByPath(others, 'attrs/detId/text', detId); | ||||||
|  |         if (processId) ObjectExt.setByPath(others, 'attrs/processId/text', processId); | ||||||
|  |         if (sectionId) ObjectExt.setByPath(others, 'attrs/sectionId/text', sectionId); | ||||||
|  |         return others; | ||||||
|  |     } | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | export const CACHE_NAME = 'ProcessDetail::section'; | ||||||
|  | 
 | ||||||
|  | export async function getSectionFrom(sectionId) { | ||||||
|  |     const sectionList = await cache.getList( | ||||||
|  |         CACHE_NAME, | ||||||
|  |         async () => { | ||||||
|  |             const { code, data } = await axios( | ||||||
|  |                 '/base/core-production-line/listAll' | ||||||
|  |             ); | ||||||
|  |             if (code == 0) { | ||||||
|  |                 return data; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     ); | ||||||
|  |     return IdToName(sectionId, sectionList); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export async function createProcessNode({ flowId, id, name, sectionId, remark }) { | ||||||
|  |     const sectionName = await getSectionFrom(sectionId); | ||||||
|  |     return { | ||||||
|  |         shape: 'process-node', | ||||||
|  |         x: 0, | ||||||
|  |         y: 0, | ||||||
|  |         detName: name, // 工序名称
 | ||||||
|  |         sectionName, // 工段
 | ||||||
|  |         sectionId, | ||||||
|  |         detDesc: remark, // 工序说明
 | ||||||
|  |         processId: flowId, // 工艺ID
 | ||||||
|  |         detId: id, // 工序ID
 | ||||||
|  |         tools: [], | ||||||
|  |         ports: [ | ||||||
|  |             { id: v4(), group: 'in' }, | ||||||
|  |             { id: v4(), group: 'out' }, | ||||||
|  |         ] | ||||||
|  |     }; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export async function createEdge(src, dest) { } | ||||||
							
								
								
									
										63
									
								
								src/views/extend/processFlowView/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,63 @@ | |||||||
|  | <!--  | ||||||
|  |     filename: index.vue | ||||||
|  |     author: liubin | ||||||
|  |     date: 2023-10-18 12:25:46 | ||||||
|  |     description:  | ||||||
|  | --> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  | 	<div class="app-container process-flow-view"> | ||||||
|  | 		<ProcessInfo /> | ||||||
|  | 		<ProcessDetail style="margin-top: 16px" @det-selected="handleDetSelected" /> | ||||||
|  | 		<ProcessBomList style="margin-top: 16px" :current-det="currentDet" /> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | import ProcessInfo from './components/ProcessInfo.vue'; | ||||||
|  | import ProcessBomList from './components/ProcessBomList.vue'; | ||||||
|  | import ProcessDetail from './components/ProcessDetail.vue'; | ||||||
|  | 
 | ||||||
|  | export default { | ||||||
|  | 	name: 'ProcessFlowView', | ||||||
|  | 	components: { ProcessInfo, ProcessDetail, ProcessBomList }, | ||||||
|  | 	props: {}, | ||||||
|  | 	data() { | ||||||
|  | 		return { | ||||||
|  | 			flowId: null, | ||||||
|  | 			currentDet: null | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	provide() { | ||||||
|  | 		const that = this; | ||||||
|  | 		return { | ||||||
|  | 			getFlowId() { | ||||||
|  | 				return that.flowId; | ||||||
|  | 			}, | ||||||
|  | 		}; | ||||||
|  | 	}, | ||||||
|  | 	activated() { | ||||||
|  | 		console.log('activated...', this.$route.params); | ||||||
|  | 		this.flowId = this.$route.params.id; | ||||||
|  | 	}, | ||||||
|  | 	computed: {}, | ||||||
|  | 	methods: { | ||||||
|  | 		handleDetSelected(det) { | ||||||
|  | 			if (det != null) { | ||||||
|  | 				this.currentDet = { ...det } | ||||||
|  | 			} | ||||||
|  | 			else this.currentDet = null; | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style scoped lang="scss"> | ||||||
|  | .process-flow-view { | ||||||
|  | 	padding: 8px; | ||||||
|  | 	flex: 1; | ||||||
|  | 	background: #f2f4f9; | ||||||
|  | 	display: flex; | ||||||
|  | 	flex-direction: column; | ||||||
|  | } | ||||||
|  | </style> | ||||||
| @ -108,20 +108,22 @@ export default { | |||||||
|       ], |       ], | ||||||
|       tableProps, |       tableProps, | ||||||
|       tableBtn: [ |       tableBtn: [ | ||||||
|           { |       this.$auth.hasPermi('base:group-classes:cancel') | ||||||
|             type: 'cancel', |           ? { | ||||||
|             btnName: '作废', |               type: 'cancel', | ||||||
|             showParam: { |               btnName: '作废', | ||||||
|               type: '&', |               showParam: { | ||||||
|               data: [ |                 type: '&', | ||||||
|                 { |                 data: [ | ||||||
|                   type: 'unequal', |                   { | ||||||
|                   name: 'status', |                     type: 'unequal', | ||||||
|                   value: '不可用' |                     name: 'status', | ||||||
|                 } |                     value: '不可用' | ||||||
|               ] |                   } | ||||||
|  |                 ] | ||||||
|  |               } | ||||||
|             } |             } | ||||||
|           }, |           : undefined, | ||||||
|         this.$auth.hasPermi('base:group-classes:update') |         this.$auth.hasPermi('base:group-classes:update') | ||||||
|           ? { |           ? { | ||||||
|               type: 'edit', |               type: 'edit', | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| <template> | <template> | ||||||
|   <el-form ref="form" :rules="rules" label-width="80px" :model="form"> |   <el-form ref="form" :rules="rules" label-width="100px" :model="form"> | ||||||
|     <el-row> |     <el-row> | ||||||
|       <el-col :span="12"> |       <el-col :span="12"> | ||||||
|         <el-form-item label="班组名称" prop="name"> |         <el-form-item label="班组名称" prop="name"> | ||||||
| @ -14,13 +14,20 @@ | |||||||
|     </el-row> |     </el-row> | ||||||
|     <el-row> |     <el-row> | ||||||
|       <el-col :span="12"> |       <el-col :span="12"> | ||||||
|         <el-form-item label="班组人数" prop="num"> |         <el-form-item label="班组组长" prop="leaderId"> | ||||||
|           <el-input-number v-model="form.num" :min="1" :max="99999999" style="width: 100%;"></el-input-number> |           <el-select v-model="form.leaderId" placeholder="请选择" style="width: 100%;" @change="selectLeader"> | ||||||
|  |             <el-option | ||||||
|  |               v-for="item in workerList" | ||||||
|  |               :key="item.id" | ||||||
|  |               :label="item.name" | ||||||
|  |               :value="item.id"> | ||||||
|  |             </el-option> | ||||||
|  |           </el-select> | ||||||
|         </el-form-item> |         </el-form-item> | ||||||
|       </el-col> |       </el-col> | ||||||
|       <el-col :span="12"> |       <el-col :span="12"> | ||||||
|         <el-form-item label="班组组长" prop="leaderName"> |         <el-form-item label="手机号" prop="telephone"> | ||||||
|           <el-input v-model="form.leaderName"></el-input> |           <el-input v-model="form.telephone" disabled></el-input> | ||||||
|         </el-form-item> |         </el-form-item> | ||||||
|       </el-col> |       </el-col> | ||||||
|     </el-row> |     </el-row> | ||||||
| @ -28,6 +35,7 @@ | |||||||
| </template> | </template> | ||||||
| <script> | <script> | ||||||
| import { getGroupTeam, updateGroupTeam, createGroupTeam, getCode } from '@/api/base/groupTeam' | import { getGroupTeam, updateGroupTeam, createGroupTeam, getCode } from '@/api/base/groupTeam' | ||||||
|  | import { getWorkerList } from '@/api/base/worker' | ||||||
| export default { | export default { | ||||||
|   name: 'groupTeamAdd', |   name: 'groupTeamAdd', | ||||||
|   data() { |   data() { | ||||||
| @ -36,23 +44,28 @@ export default { | |||||||
|         id: '', |         id: '', | ||||||
|         name: '', |         name: '', | ||||||
|         code: '', |         code: '', | ||||||
|         num: null, |         leaderId: '', | ||||||
|         leaderName: '' |         telephone: '' | ||||||
|       }, |       }, | ||||||
|       isEdit: false, //是否是编辑 |       isEdit: false, //是否是编辑 | ||||||
|       rules: { |       rules: { | ||||||
|         name: [{ required: true, message: '请输入班组名称', trigger: 'blur' }] |         name: [{ required: true, message: '请输入班组名称', trigger: 'blur' }], | ||||||
|       } |         code: [{ required: true, message: '请输入班组编码', trigger: 'blur' }], | ||||||
|  |         leaderId: [{ required: true, message: '请选择组长', trigger: 'select' }] | ||||||
|  |       }, | ||||||
|  |       workerList: [] | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   methods: { |   methods: { | ||||||
|     init(id) { |     init(id) { | ||||||
|  |       this.getWorkerList() | ||||||
|       if (id) { |       if (id) { | ||||||
|         this.isEdit = true |         this.isEdit = true | ||||||
|         this.form.id = id |         this.form.id = id | ||||||
|         getGroupTeam( id ).then((res) => { |         getGroupTeam( id ).then((res) => { | ||||||
|           if (res.code === 0) { |           if (res.code === 0) { | ||||||
|             this.form = res.data |             this.form = res.data | ||||||
|  |             this.selectLeader() | ||||||
|           } |           } | ||||||
|         }) |         }) | ||||||
|       } else { |       } else { | ||||||
| @ -63,6 +76,24 @@ export default { | |||||||
|         }) |         }) | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  |     // 获取员工list | ||||||
|  |     getWorkerList() { | ||||||
|  |       getWorkerList().then(res => { | ||||||
|  |         this.workerList = res.data | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     // 获取手机号 | ||||||
|  |     selectLeader() { | ||||||
|  |       if (this.form.leaderId) { | ||||||
|  |         this.workerList.map(item => { | ||||||
|  |           if (item.id === this.form.leaderId) { | ||||||
|  |             this.form.telephone = item.telephone || '' | ||||||
|  |           } | ||||||
|  |         }) | ||||||
|  |       } else { | ||||||
|  |         this.form.telephone = '' | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|     submitForm() { |     submitForm() { | ||||||
|       this.$refs['form'].validate((valid) => { |       this.$refs['form'].validate((valid) => { | ||||||
|         if (valid) { |         if (valid) { | ||||||
|  | |||||||
| @ -12,8 +12,7 @@ export default { | |||||||
|   }, |   }, | ||||||
|   data() { |   data() { | ||||||
|     return { |     return { | ||||||
|       state: false, |       state: false | ||||||
|       payload: {} |  | ||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   computed: { |   computed: { | ||||||
| @ -31,9 +30,16 @@ export default { | |||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|     changeHandler() { |     changeHandler() { | ||||||
|       this.payload.id = this.injectData.id |       let params = {} | ||||||
|       this.payload.enabled = this.state ? '1' : '0' |       let payload = {} | ||||||
|       this.$emit('emitData', this.payload) |       params.name = 'state' | ||||||
|  |       payload.id = this.injectData.id | ||||||
|  |       payload.enabled = this.state ? '1' : '0' | ||||||
|  |       payload.code = this.injectData.code | ||||||
|  |       payload.name = this.injectData.name | ||||||
|  |       payload.leaderId = this.injectData.leaderId | ||||||
|  |       params.payload = payload | ||||||
|  |       this.$emit('emitData', params) | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										298
									
								
								src/views/group/base/groupTeam/components/workerEdit.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,298 @@ | |||||||
|  | <template> | ||||||
|  |   <div> | ||||||
|  |     <el-drawer :title="title" :visible.sync="visible" size="70%" @close='closeD'> | ||||||
|  |       <div class="box"> | ||||||
|  |         <el-row class="topBox"> | ||||||
|  |           <el-col :span="6"> | ||||||
|  |             <p class="boldTitle">班组名称</p> | ||||||
|  |             <p class="lightText">{{ teamData.teamName }}</p> | ||||||
|  |           </el-col> | ||||||
|  |           <el-col :span="6"> | ||||||
|  |             <p class="boldTitle">班组长</p> | ||||||
|  |             <p class="lightText">{{ teamData.leaderName }}</p> | ||||||
|  |           </el-col> | ||||||
|  |           <el-col :span="6"> | ||||||
|  |             <p class="boldTitle">班组人数</p> | ||||||
|  |             <p class="lightText">{{ teamData.teamNum }}</p> | ||||||
|  |           </el-col> | ||||||
|  |           <el-col :span="6"> | ||||||
|  |             <p class="boldTitle">手机号</p> | ||||||
|  |             <p class="lightText">{{ teamData.leaderTelephone }}</p> | ||||||
|  |           </el-col> | ||||||
|  |         </el-row> | ||||||
|  |         <div class="bottomBox"> | ||||||
|  |           <!-- 搜索工作栏 --> | ||||||
|  |           <search-bar | ||||||
|  |             v-if="visible" | ||||||
|  |             :formConfigs="formConfig" | ||||||
|  |             @headBtnClick="buttonClick" | ||||||
|  |           /> | ||||||
|  |           <base-table | ||||||
|  |             :page="queryParams.pageNo" | ||||||
|  |             :limit="queryParams.pageSize" | ||||||
|  |             :table-props="tableProps" | ||||||
|  |             :table-data="tableData" | ||||||
|  |             :max-height="tableH" | ||||||
|  |           > | ||||||
|  |             <method-btn | ||||||
|  |               v-if="tableBtn.length" | ||||||
|  |               slot="handleBtn" | ||||||
|  |               :width="100" | ||||||
|  |               label="操作" | ||||||
|  |               :method-list="tableBtn" | ||||||
|  |               @clickBtn="handleClick" | ||||||
|  |             /> | ||||||
|  |           </base-table> | ||||||
|  |           <pagination | ||||||
|  |             :page.sync="queryParams.pageNo" | ||||||
|  |             :limit.sync="queryParams.pageSize" | ||||||
|  |             :total="total" | ||||||
|  |             @pagination="getList" | ||||||
|  |           /> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |     </el-drawer> | ||||||
|  |     <!-- 新增编辑组员 --> | ||||||
|  |     <base-dialog | ||||||
|  |       :dialogTitle="addOrEditTitle" | ||||||
|  |       :dialogVisible="centervisible" | ||||||
|  |       @cancel="handleCancel" | ||||||
|  |       @confirm="handleConfirm" | ||||||
|  |       :before-close="handleCancel" | ||||||
|  |     > | ||||||
|  |       <worker-team-add ref="workerTeamAdd" @successSubmit="successSubmit" /> | ||||||
|  |     </base-dialog> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | <script> | ||||||
|  | const tableProps = [ | ||||||
|  |   { | ||||||
|  |     prop: 'workerName', | ||||||
|  |     label: '人员姓名' | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     prop: 'workerMajorName', | ||||||
|  |     label: '专业' | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     prop: 'workerTelephone', | ||||||
|  |     label: '手机' | ||||||
|  |   }, | ||||||
|  |   { | ||||||
|  |     prop: 'remark', | ||||||
|  |     label: '备注' | ||||||
|  |   } | ||||||
|  | ] | ||||||
|  | import { groupTeamPage, teamDetDelete } from '@/api/base/groupTeam' | ||||||
|  | import { getWorker } from '@/api/base/worker' | ||||||
|  | import WorkerTeamAdd from './workerTeamAdd.vue' | ||||||
|  | export default { | ||||||
|  |   name: 'WorkerEdit', | ||||||
|  |   data() { | ||||||
|  |     return { | ||||||
|  |       visible: false, | ||||||
|  |       title: '', | ||||||
|  |       formConfig: [], | ||||||
|  |       teamData: { | ||||||
|  |         teamName: '', | ||||||
|  |         leaderName: '', | ||||||
|  |         teamNum: '', | ||||||
|  |         leaderTelephone: '-', | ||||||
|  |         teamId: '' | ||||||
|  |       }, | ||||||
|  |       queryParams: { | ||||||
|  |         pageNo: 1, | ||||||
|  |         pageSize: 20, | ||||||
|  |         teamId: '', | ||||||
|  |         workerName: '' | ||||||
|  |       }, | ||||||
|  |       tableProps, | ||||||
|  |       tableData: [], | ||||||
|  |       tableBtn: [], | ||||||
|  |       tableH: this.tableHeight(320), | ||||||
|  |       total: 0, | ||||||
|  |       // 弹出层标题 | ||||||
|  |       addOrEditTitle: "", | ||||||
|  |       // 是否显示弹出层 | ||||||
|  |       centervisible: false | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   components: { WorkerTeamAdd }, | ||||||
|  |   created() { | ||||||
|  |     window.addEventListener('resize', () => { | ||||||
|  |       this.tableH = this.tableHeight(320) | ||||||
|  |     }) | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     init(val) { | ||||||
|  |       this.visible = true | ||||||
|  |       this.teamData.teamName = val.payload.name | ||||||
|  |       this.teamData.leaderName = val.payload.leaderName | ||||||
|  |       this.teamData.teamNum = val.payload.num | ||||||
|  |       this.teamData.teamId = val.payload.teamId | ||||||
|  |       this.queryParams.teamId = val.payload.id | ||||||
|  |       getWorker({id:val.payload.leaderId}).then(res => {// 获取组长手机号 | ||||||
|  |         this.teamData.leaderTelephone = res.data.telephone || '-' | ||||||
|  |       }) | ||||||
|  |       this.getList() | ||||||
|  |       if (val.name === 'view') { | ||||||
|  |         this.title = '查看组员' | ||||||
|  |         this.tableBtn = [] | ||||||
|  |         this.formConfig = [ | ||||||
|  |           { | ||||||
|  |             type: 'input', | ||||||
|  |             label: '关键字', | ||||||
|  |             placeholder: '关键字', | ||||||
|  |             param: 'workerName' | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             type: 'button', | ||||||
|  |             btnName: '查询', | ||||||
|  |             name: 'search', | ||||||
|  |             color: 'primary' | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       }else{ | ||||||
|  |         this.title = '编辑组员' | ||||||
|  |         this.tableBtn = [ | ||||||
|  |             { | ||||||
|  |               type: 'edit', | ||||||
|  |               btnName: '编辑' | ||||||
|  |             }, | ||||||
|  |             { | ||||||
|  |               type: 'delete', | ||||||
|  |               btnName: '删除' | ||||||
|  |             } | ||||||
|  |           ] | ||||||
|  |         this.formConfig = [ | ||||||
|  |           { | ||||||
|  |             type: 'input', | ||||||
|  |             label: '关键字', | ||||||
|  |             placeholder: '关键字', | ||||||
|  |             param: 'workerName' | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             type: 'button', | ||||||
|  |             btnName: '查询', | ||||||
|  |             name: 'search', | ||||||
|  |             color: 'primary' | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             type: 'separate' | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             type: 'button', | ||||||
|  |             btnName: '新增', | ||||||
|  |             name: 'add', | ||||||
|  |             color: 'success', | ||||||
|  |             plain: true | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     getList() { | ||||||
|  |       groupTeamPage({ ...this.queryParams }).then(res => { | ||||||
|  |         if (res.code === 0 && res.data.list.length > 0) { | ||||||
|  |           let arr = [] | ||||||
|  |           res.data.list.map(item => { | ||||||
|  |             let obj = {} | ||||||
|  |             obj.workerName = item.worker.name | ||||||
|  |             obj.workerMajorName = item.worker.majorName | ||||||
|  |             obj.workerTelephone = item.worker.telephone | ||||||
|  |             obj.remark = item.remark | ||||||
|  |             obj.id = item.id | ||||||
|  |             arr.push(obj) | ||||||
|  |           }) | ||||||
|  |           this.tableData = arr | ||||||
|  |           this.total = res.data.total | ||||||
|  |         } else { | ||||||
|  |           this.tableData = [] | ||||||
|  |           this.total = 0 | ||||||
|  |         } | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     buttonClick(val) { | ||||||
|  |       console.log(val) | ||||||
|  |       if (val.btnName === 'search') { | ||||||
|  |         this.queryParams.workerName = val.workerName | ||||||
|  |         this.queryParams.pageNo = 1 | ||||||
|  |         this.getList() | ||||||
|  |       }else if (val.btnName === 'add') { | ||||||
|  |        this.addNew() | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     // 新增 | ||||||
|  |     addNew() { | ||||||
|  |       this.addOrEditTitle = '新增' | ||||||
|  |       this.centervisible = true | ||||||
|  |       this.$nextTick(() => { | ||||||
|  |         this.$refs.workerTeamAdd.init({'teamId': this.queryParams.teamId, id: ''}) | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     handleCancel() { | ||||||
|  |       this.$refs.workerTeamAdd.formClear() | ||||||
|  |       this.centervisible = false | ||||||
|  |       this.addOrEditTitle = '' | ||||||
|  |     }, | ||||||
|  |     handleConfirm() { | ||||||
|  |       this.$refs.workerTeamAdd.submitForm() | ||||||
|  |     }, | ||||||
|  |     successSubmit() { | ||||||
|  |       this.handleCancel() | ||||||
|  |       this.getList() | ||||||
|  |     }, | ||||||
|  |     handleClick(val) { | ||||||
|  |       switch (val.type) { | ||||||
|  |         case 'edit': | ||||||
|  |           this.addOrEditTitle = '编辑' | ||||||
|  |           this.centervisible = true | ||||||
|  |           this.$nextTick(() => { | ||||||
|  |             this.$refs.workerTeamAdd.init({'teamId': this.queryParams.teamId, id: val.data.id}) | ||||||
|  |           }) | ||||||
|  |           break | ||||||
|  |         default: | ||||||
|  |           this.handleDelete(val.data) | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     /** 删除按钮操作 */ | ||||||
|  |     handleDelete(row) { | ||||||
|  |       console.log(row) | ||||||
|  |       this.$modal.confirm('是否确认删除人员"' + row.workerName + '"的数据项?').then(function() { | ||||||
|  |           return teamDetDelete({id: row.id}); | ||||||
|  |         }).then(() => { | ||||||
|  |           this.queryParams.pageNo = 1; | ||||||
|  |           this.getList(); | ||||||
|  |           this.$modal.msgSuccess("删除成功"); | ||||||
|  |         }).catch(() => {}); | ||||||
|  |     }, | ||||||
|  |     closeD() { | ||||||
|  |       this.$emit('closeDrawer') | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  | <style lang='scss' scoped> | ||||||
|  | .box { | ||||||
|  |   padding:0 30px; | ||||||
|  |   .topBox { | ||||||
|  |     padding-bottom: 30px; | ||||||
|  |     border-bottom: 1px solid #E9E9E9; | ||||||
|  |     .boldTitle { | ||||||
|  |       font-size: 14px; | ||||||
|  |       font-weight: 600; | ||||||
|  |       color: rgba(0,0,0,0.85); | ||||||
|  |       margin: 0; | ||||||
|  |       margin-bottom: 10px; | ||||||
|  |     } | ||||||
|  |     .lightText { | ||||||
|  |       font-size: 14px; | ||||||
|  |       font-weight: 400; | ||||||
|  |       color: rgba(102,102,102,0.75); | ||||||
|  |       margin: 0; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   .bottomBox { | ||||||
|  |     padding-top: 30px; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										41
									
								
								src/views/group/base/groupTeam/components/workerOperate.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,41 @@ | |||||||
|  | <template> | ||||||
|  |   <div class="workerOperate"> | ||||||
|  |     <div class="operateBtn"> | ||||||
|  |       <span class="view" v-if="this.$auth.hasPermi('base:group-team:view-worker')" @click="emitParams('view')">查看</span> | ||||||
|  |       <span class="edit" v-if="this.$auth.hasPermi('base:group-team:edit-worker')" @click="emitParams('edit')">编辑</span> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
|  | <script> | ||||||
|  | export default { | ||||||
|  |   name: 'WorkerOperate', | ||||||
|  |   props: { | ||||||
|  |     injectData: { | ||||||
|  |       type: Object, | ||||||
|  |       default: () => ({}) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     emitParams(data) { | ||||||
|  |       let params = {} | ||||||
|  |       params.name = data | ||||||
|  |       params.payload = this.injectData | ||||||
|  |       this.$emit('emitData', params) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||
|  | <style lang='scss' scoped> | ||||||
|  | .workerOperate { | ||||||
|  |   .operateBtn{ | ||||||
|  |     color: #0B58FF; | ||||||
|  |     .view { | ||||||
|  |       margin-right: 10px; | ||||||
|  |       cursor: pointer; | ||||||
|  |     } | ||||||
|  |     .edit { | ||||||
|  |       cursor: pointer; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </style> | ||||||
							
								
								
									
										113
									
								
								src/views/group/base/groupTeam/components/workerTeamAdd.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,113 @@ | |||||||
|  | <template> | ||||||
|  |   <el-form ref="form" :rules="rules" label-width="100px" :model="form"> | ||||||
|  |     <el-form-item label="员工" prop="workerId"> | ||||||
|  |       <el-select v-model="form.workerId" placeholder="请选择" filterable style="width: 100%;" @change="selectWorker()"> | ||||||
|  |         <el-option | ||||||
|  |           v-for="item in workerList" | ||||||
|  |           :key="item.id" | ||||||
|  |           :label="item.name" | ||||||
|  |           :value="item.id"> | ||||||
|  |         </el-option> | ||||||
|  |       </el-select> | ||||||
|  |     </el-form-item> | ||||||
|  |     <el-form-item label="专业" prop="majorName"> | ||||||
|  |       <el-input v-model="form.majorName" disabled></el-input> | ||||||
|  |     </el-form-item> | ||||||
|  |     <el-form-item label="备注" prop="remark"> | ||||||
|  |       <el-input v-model="form.remark"></el-input> | ||||||
|  |     </el-form-item> | ||||||
|  |   </el-form> | ||||||
|  | </template> | ||||||
|  | <script> | ||||||
|  | import { getWorkerList } from '@/api/base/worker' | ||||||
|  | import { teamDetCreate, teamDetUpdate, groupTeamDet } from '@/api/base/groupTeam' | ||||||
|  | export default { | ||||||
|  |   name: 'WorkerTeamAdd', | ||||||
|  |   data() { | ||||||
|  |     return { | ||||||
|  |       workerList: [], | ||||||
|  |       form: { | ||||||
|  |         teamId: '', | ||||||
|  |         workerId: '', | ||||||
|  |         remark: '', | ||||||
|  |         majorName: '', | ||||||
|  |         id: '' | ||||||
|  |       }, | ||||||
|  |       rules: { | ||||||
|  |         workerId: [{ required: true, message: '员工不能为空', trigger: 'change' }] | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     init(param) { | ||||||
|  |       this.form.teamId = param.teamId | ||||||
|  |       getWorkerList().then(res => { | ||||||
|  |         this.workerList = res.data || [] | ||||||
|  |         if (param.id) { | ||||||
|  |           this.isEdit = true | ||||||
|  |           this.form.id = param.id | ||||||
|  |           groupTeamDet({id: this.form.id}).then((res) => { | ||||||
|  |             if (res.code === 0) { | ||||||
|  |               this.form.workerId = res.data.workerId | ||||||
|  |               this.selectWorker() | ||||||
|  |               this.form.remark = res.data.remark | ||||||
|  |             } | ||||||
|  |           }) | ||||||
|  |         } else { | ||||||
|  |           this.isEdit = false | ||||||
|  |           this.form.id = '' | ||||||
|  |         } | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     selectWorker() { | ||||||
|  |       if (this.form.workerId) { | ||||||
|  |         this.workerList.map(item => { | ||||||
|  |           if (item.id === this.form.workerId) { | ||||||
|  |             this.form.majorName = item.majorName | ||||||
|  |           } | ||||||
|  |         }) | ||||||
|  |       }else{ | ||||||
|  |         this.form.majorName = '' | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     // 确定 | ||||||
|  |     submitForm() { | ||||||
|  |       this.$refs['form'].validate((valid) => { | ||||||
|  |         if (valid) { | ||||||
|  |           if (this.isEdit) { | ||||||
|  |             // 编辑 | ||||||
|  |             teamDetUpdate({ | ||||||
|  |               teamId: this.form.teamId, | ||||||
|  |               workerId: this.form.workerId, | ||||||
|  |               remark: this.form.remark, | ||||||
|  |               id: this.form.id | ||||||
|  |             }).then((res) => { | ||||||
|  |               if (res.code === 0) { | ||||||
|  |                 this.$modal.msgSuccess("操作成功"); | ||||||
|  |                 this.$emit('successSubmit') | ||||||
|  |               } | ||||||
|  |             }) | ||||||
|  |           } else { | ||||||
|  |             teamDetCreate({ | ||||||
|  |               teamId: this.form.teamId, | ||||||
|  |               workerId: this.form.workerId, | ||||||
|  |               remark: this.form.remark | ||||||
|  |             }).then((res) => { | ||||||
|  |               if (res.code === 0) { | ||||||
|  |                 this.$modal.msgSuccess("操作成功"); | ||||||
|  |                 this.$emit('successSubmit') | ||||||
|  |               } | ||||||
|  |             }) | ||||||
|  |           } | ||||||
|  |         } else { | ||||||
|  |           return false | ||||||
|  |         } | ||||||
|  |       }) | ||||||
|  |     }, | ||||||
|  |     formClear() { | ||||||
|  |       this.$refs.form.resetFields() | ||||||
|  |       this.isEdit = false | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </script> | ||||||