Compare commits
	
		
			51 Commits
		
	
	
		
			master
			...
			5695c3db90
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 5695c3db90 | |||
| 14d426b020 | |||
| 046a5eea32 | |||
| b468204f88 | |||
| 
						 | 
					e5978d1700 | ||
| 
						 | 
					91eb13af26 | ||
| fe29043ab1 | |||
| 2075b42427 | |||
| c851188989 | |||
| 
						 | 
					0fa310609e | ||
| 57a4ca96e7 | |||
| af868a7cd7 | |||
| cb1ad9edec | |||
| 
						 | 
					34e8178ddc | ||
| 
						 | 
					6c094b2a2e | ||
| 4a796130d0 | |||
| 60f65e6f85 | |||
| 3bf8150764 | |||
| bacf2eab0b | |||
| 8155a78649 | |||
| 013c08710c | |||
| 00fba0a83b | |||
| c71613f3fc | |||
| 
						 | 
					4615e975e8 | ||
| 
						 | 
					e961bf6cfa | ||
| 216aa6291d | |||
| 66660bfef7 | |||
| d25261b256 | |||
| 583b934511 | |||
| 55e023d0a8 | |||
| 503e988f7b | |||
| 06e8a72f80 | |||
| 6c348202a1 | |||
| 5ba186b0c6 | |||
| e153d7e077 | |||
| 3c31e5d63a | |||
| 619cf9e1ce | |||
| 392c1ea09b | |||
| ac4565e587 | |||
| 6006ae13d9 | |||
| 74d5646d65 | |||
| 
						 | 
					2c3bdde403 | ||
| 106d0ed89c | |||
| cfbd00b560 | |||
| a787935263 | |||
| 15da20fac7 | |||
| 6b4e906e75 | |||
| d121e408af | |||
| f8baaa8955 | |||
| 416d4bb390 | |||
| fe7821cbd8 | 
							
								
								
									
										14
									
								
								.env.dev
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								.env.dev
									
									
									
									
									
								
							@@ -1,21 +1,25 @@
 | 
				
			|||||||
###
 | 
					###
 | 
				
			||||||
 # @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-16 09:22:52
 | 
					 # @LastEditTime: 2023-11-03 11:16:12
 | 
				
			||||||
 # @LastEditors: DY
 | 
					 # @LastEditors: DY
 | 
				
			||||||
 # @Description: 
 | 
					 # @Description:
 | 
				
			||||||
### 
 | 
					###
 | 
				
			||||||
# 开发环境配置
 | 
					# 开发环境配置
 | 
				
			||||||
ENV = 'development'
 | 
					ENV = 'development'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# 页面标题
 | 
					# 页面标题
 | 
				
			||||||
VUE_APP_TITLE = 产线监控系统
 | 
					VUE_APP_TITLE = MES系统
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# 芋道管理系统/开发环境
 | 
					# 芋道管理系统/开发环境
 | 
				
			||||||
 | 
					# VUE_APP_BASE_API = 'http://100.64.0.26:48082'
 | 
				
			||||||
 | 
					# VUE_APP_BASE_API = 'http://192.168.0.33:48082'
 | 
				
			||||||
 | 
					VUE_APP_BASE_API = 'http://192.168.4.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:48080'
 | 
					# VUE_APP_BASE_API = 'http://192.168.1.56:48080'
 | 
				
			||||||
# VUE_APP_BASE_API = 'http://192.168.1.188:48080'
 | 
					# VUE_APP_BASE_API = 'http://192.168.1.188:48080'
 | 
				
			||||||
 | 
					# VUE_APP_BASE_API = 'http://192.168.2.159: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",
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										68
									
								
								src/api/base/coreCustomer.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								src/api/base/coreCustomer.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,68 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: Do not edit
 | 
				
			||||||
 | 
					 * @Date: 2023-10-21 11:50:46
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-11-02 20:25:36
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @Description: 
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					import request from '@/utils/request'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建客户
 | 
				
			||||||
 | 
					export function createCustomer(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-customer/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 更新客户
 | 
				
			||||||
 | 
					export function updateCustomer(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-customer/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除客户
 | 
				
			||||||
 | 
					export function deleteCustomer(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-customer/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得客户
 | 
				
			||||||
 | 
					export function getCustomer(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-customer/get?id=' + id,
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得客户code
 | 
				
			||||||
 | 
					export function getCode() {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-customer/getCode',
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得客户分页
 | 
				
			||||||
 | 
					export function getCustomerPage(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-customer/page',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得所有列表
 | 
				
			||||||
 | 
					export function getCustomerList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-customer/listAll',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										68
									
								
								src/api/base/coreDepartment.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								src/api/base/coreDepartment.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,68 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: Do not edit
 | 
				
			||||||
 | 
					 * @Date: 2023-10-21 11:50:46
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-30 14:37:28
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @Description: 
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					import request from '@/utils/request'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建部门
 | 
				
			||||||
 | 
					export function createCoreDepartment(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-department/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 更新部门
 | 
				
			||||||
 | 
					export function updateCoreDepartment(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-department/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除部门
 | 
				
			||||||
 | 
					export function deleteCoreDepartment(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-department/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得部门
 | 
				
			||||||
 | 
					export function getCoreDepartment(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-department/get?id=' + id,
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得部门code
 | 
				
			||||||
 | 
					export function getCode() {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-department/getCode',
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得部门分页
 | 
				
			||||||
 | 
					export function getCoreDepartmentPage(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-department/page',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得所有列表
 | 
				
			||||||
 | 
					export function getCoreDepartmentList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-department/listAll',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										68
									
								
								src/api/base/coreMajor.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								src/api/base/coreMajor.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,68 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: Do not edit
 | 
				
			||||||
 | 
					 * @Date: 2023-10-21 11:50:46
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-31 15:11:25
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @Description: 
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					import request from '@/utils/request'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建专业
 | 
				
			||||||
 | 
					export function createCoreMajor(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-major/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 更新专业
 | 
				
			||||||
 | 
					export function updateCoreMajor(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-major/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除专业
 | 
				
			||||||
 | 
					export function deleteCoreMajor(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-major/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得专业
 | 
				
			||||||
 | 
					export function getCoreMajor(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-major/get?id=' + id,
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得专业code
 | 
				
			||||||
 | 
					export function getCode() {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-major/getCode',
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得专业分页
 | 
				
			||||||
 | 
					export function getCoreMajorPage(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-major/page',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得所有列表
 | 
				
			||||||
 | 
					export function getCoreMajorList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-major/listAll',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										68
									
								
								src/api/base/coreSupplier.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								src/api/base/coreSupplier.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,68 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: Do not edit
 | 
				
			||||||
 | 
					 * @Date: 2023-10-21 11:50:46
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-11-03 10:39:44
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @Description: 
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					import request from '@/utils/request'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建供应商
 | 
				
			||||||
 | 
					export function createCoreSupplier(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-supplier/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 更新供应商
 | 
				
			||||||
 | 
					export function updateCoreSupplier(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-supplier/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除供应商
 | 
				
			||||||
 | 
					export function deleteCoreSupplier(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-supplier/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得供应商
 | 
				
			||||||
 | 
					export function getCoreSupplier(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-supplier/get?id=' + id,
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得供应商code
 | 
				
			||||||
 | 
					export function getCode() {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-supplier/getCode',
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得供应商分页
 | 
				
			||||||
 | 
					export function getCoreSupplierPage(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-supplier/page',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得所有列表
 | 
				
			||||||
 | 
					export function getCoreSupplierList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-supplier/listAll',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										103
									
								
								src/api/base/coreWorker.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								src/api/base/coreWorker.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,103 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: Do not edit
 | 
				
			||||||
 | 
					 * @Date: 2023-10-21 11:50:46
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-11-02 19:49:52
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @Description: 
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					import request from '@/utils/request'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建员工
 | 
				
			||||||
 | 
					export function createCoreWorker(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 更新员工
 | 
				
			||||||
 | 
					export function updateCoreWorker(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除员工
 | 
				
			||||||
 | 
					export function deleteCoreWorker(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得员工
 | 
				
			||||||
 | 
					export function getCoreWorker(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker/get?id=' + id,
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得员工code
 | 
				
			||||||
 | 
					export function getCode() {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker/getCode',
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得员工分页
 | 
				
			||||||
 | 
					export function getCoreWorkerPage(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker/page',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得所有列表
 | 
				
			||||||
 | 
					export function getCoreWorkerList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker/listAll',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建员工--专业
 | 
				
			||||||
 | 
					export function createWoBindMa(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker-bind-major/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 更新员工--专业
 | 
				
			||||||
 | 
					export function updateWoBindMa(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker-bind-major/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除员工--专业
 | 
				
			||||||
 | 
					export function deleteWoBindMa(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker-bind-major/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得员工--专业分页
 | 
				
			||||||
 | 
					export function getWoBindMaPage(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-worker-bind-major/page',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										8
									
								
								src/api/base/customer.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										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'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										73
									
								
								src/api/base/delivery.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								src/api/base/delivery.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,73 @@
 | 
				
			|||||||
 | 
					// 成品发货
 | 
				
			||||||
 | 
					import request from '@/utils/request'
 | 
				
			||||||
 | 
					// 获得成品发货清单分页
 | 
				
			||||||
 | 
					export function deliveryLogPage(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/extend/delivery-log/page',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获取发货进度分页
 | 
				
			||||||
 | 
					export function deliveryProgressPage(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/extend/delivery-progress/page',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获取发货进度分页
 | 
				
			||||||
 | 
					export function deliveryLogDetPage(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/extend/delivery-log-det/page',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建成品发货清单
 | 
				
			||||||
 | 
					export function deliveryLogCreate(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/extend/delivery-log/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 更新成品发货清单
 | 
				
			||||||
 | 
					export function deliveryLogUpdate(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/extend/delivery-log/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得成品发货清单
 | 
				
			||||||
 | 
					export function getDeliveryLog(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/extend/delivery-log/get',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除成品发货清单
 | 
				
			||||||
 | 
					export function deliveryLogDelete(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/extend/delivery-log/delete',
 | 
				
			||||||
 | 
					    method: 'delete',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 装车
 | 
				
			||||||
 | 
					export function deliveryLogDetCreate(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/extend/delivery-log-det/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										68
									
								
								src/api/base/modelType.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								src/api/base/modelType.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,68 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2023-10-18 09:33:57
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-18 16:02:09
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					import request from '@/utils/request'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建包装
 | 
				
			||||||
 | 
					export function createPackingType(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-type/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得包装code
 | 
				
			||||||
 | 
					export function getCode() {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-log/getPackagingSerialCode',
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					// 更新包装
 | 
				
			||||||
 | 
					export function updatePackingType(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-type/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除包装
 | 
				
			||||||
 | 
					export function deletePackingType(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-type/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得包装
 | 
				
			||||||
 | 
					export function getPackingType(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-type/get?id=' + id,
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得包装分页
 | 
				
			||||||
 | 
					export function getPackingTypePage(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-type/page',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 导出包装 Excel
 | 
				
			||||||
 | 
					export function exportPackingExcel(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-type/export-excel',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query,
 | 
				
			||||||
 | 
					    responseType: 'blob'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										140
									
								
								src/api/base/orderManage.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										140
									
								
								src/api/base/orderManage.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,140 @@
 | 
				
			|||||||
 | 
					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
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得工单
 | 
				
			||||||
 | 
					export function getWorkOrderById(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-work-order/get',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 订单监控
 | 
				
			||||||
 | 
					export function orderMonitor(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/order/orderMonitor',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得所有客户列表
 | 
				
			||||||
 | 
					export function customerList() {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-customer/listAll',
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得订单详情
 | 
				
			||||||
 | 
					export function orderDetail(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/order/getDetail',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 产品bom消耗信息
 | 
				
			||||||
 | 
					export function bomUseNum(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/material-product-bom/bomUseNum',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										92
									
								
								src/api/base/packingInfo.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								src/api/base/packingInfo.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,92 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2023-10-18 09:33:57
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-18 16:18:12
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					import request from '@/utils/request'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建包装
 | 
				
			||||||
 | 
					export function createPacking(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-log/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得包装code
 | 
				
			||||||
 | 
					export function getCode() {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-log/getPackagingSerialCode',
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					// 更新包装
 | 
				
			||||||
 | 
					export function updatePacking(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-log/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除包装
 | 
				
			||||||
 | 
					export function deletePacking(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-log/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得包装
 | 
				
			||||||
 | 
					export function getPacking(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-log/get?id=' + id,
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得包装分页
 | 
				
			||||||
 | 
					export function getPackingPage(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-log/page',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 导出包装 Excel
 | 
				
			||||||
 | 
					export function exportPackingExcel(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-log/export-excel',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query,
 | 
				
			||||||
 | 
					    responseType: 'blob'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export function getWorkOrderList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-work-order/listbyfilter',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query,
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export function getCustomerList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/core-customer/listAll',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query,
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export function getModelList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-model/listbyfilter',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query,
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										92
									
								
								src/api/base/printModel.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								src/api/base/printModel.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,92 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2023-10-18 09:33:57
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-19 15:28:00
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					import request from '@/utils/request'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建包装
 | 
				
			||||||
 | 
					export function createPackingModel(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-model/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得包装code
 | 
				
			||||||
 | 
					// export function getCode() {
 | 
				
			||||||
 | 
					//   return request({
 | 
				
			||||||
 | 
					//     url: '/base/packaging-print-log/getPackagingSerialCode',
 | 
				
			||||||
 | 
					//     method: 'get'
 | 
				
			||||||
 | 
					//   })
 | 
				
			||||||
 | 
					// }
 | 
				
			||||||
 | 
					// 更新包装
 | 
				
			||||||
 | 
					export function updatePackingModel(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-model/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除包装
 | 
				
			||||||
 | 
					export function deletePackingModel(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-model/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得包装
 | 
				
			||||||
 | 
					export function getPackingModel(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-model/get?id=' + id,
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得包装分页
 | 
				
			||||||
 | 
					export function getPackingModelPage(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-model/page',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 导出包装 Excel
 | 
				
			||||||
 | 
					// export function exportPackingExcel(query) {
 | 
				
			||||||
 | 
					//   return request({
 | 
				
			||||||
 | 
					//     url: '/base/packaging-print-log/export-excel',
 | 
				
			||||||
 | 
					//     method: 'get',
 | 
				
			||||||
 | 
					//     params: query,
 | 
				
			||||||
 | 
					//     responseType: 'blob'
 | 
				
			||||||
 | 
					//   })
 | 
				
			||||||
 | 
					// }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// export function getWorkOrderList(query) {
 | 
				
			||||||
 | 
					//   return request({
 | 
				
			||||||
 | 
					//     url: '/base/core-work-order/listbyfilter',
 | 
				
			||||||
 | 
					//     method: 'get',
 | 
				
			||||||
 | 
					//     params: query,
 | 
				
			||||||
 | 
					//   })
 | 
				
			||||||
 | 
					// }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// export function getCustomerList(query) {
 | 
				
			||||||
 | 
					//   return request({
 | 
				
			||||||
 | 
					//     url: '/base/core-customer/listAll',
 | 
				
			||||||
 | 
					//     method: 'get',
 | 
				
			||||||
 | 
					//     params: query,
 | 
				
			||||||
 | 
					//   })
 | 
				
			||||||
 | 
					// }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export function getTypeList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/packaging-print-type/listbyfilter',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query,
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										8
									
								
								src/api/base/product.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										26
									
								
								src/api/base/worker.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/api/base/worker.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,26 @@
 | 
				
			|||||||
 | 
					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
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得该班组其他可选组员列表(除去现有组员)
 | 
				
			||||||
 | 
					export function otherWorkerList(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/group-team-det/otherWorkerList',
 | 
				
			||||||
 | 
					    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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										28
									
								
								src/api/monitoring/teamProduction.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								src/api/monitoring/teamProduction.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,28 @@
 | 
				
			|||||||
 | 
					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
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得所有列表
 | 
				
			||||||
 | 
					export function groupClassesListAll(query) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/base/group-classes/listAll',
 | 
				
			||||||
 | 
					    method: 'get',
 | 
				
			||||||
 | 
					    params: query
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										14
									
								
								src/assets/icons/svg/icon-upload.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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  | 
@@ -21,11 +21,13 @@
 | 
				
			|||||||
						v-model="form[col.prop]"
 | 
											v-model="form[col.prop]"
 | 
				
			||||||
						@change="$emit('update', form)"
 | 
											@change="$emit('update', form)"
 | 
				
			||||||
						:placeholder="`请输入${col.label}`"
 | 
											:placeholder="`请输入${col.label}`"
 | 
				
			||||||
 | 
											:disabled="disabled"
 | 
				
			||||||
						v-bind="col.bind" />
 | 
											v-bind="col.bind" />
 | 
				
			||||||
					<el-input
 | 
										<el-input
 | 
				
			||||||
						v-if="col.textarea"
 | 
											v-if="col.textarea"
 | 
				
			||||||
						type="textarea"
 | 
											type="textarea"
 | 
				
			||||||
						v-model="form[col.prop]"
 | 
											v-model="form[col.prop]"
 | 
				
			||||||
 | 
											:disabled="disabled"
 | 
				
			||||||
						@change="$emit('update', form)"
 | 
											@change="$emit('update', form)"
 | 
				
			||||||
						:placeholder="`请输入${col.label}`"
 | 
											:placeholder="`请输入${col.label}`"
 | 
				
			||||||
						v-bind="col.bind" />
 | 
											v-bind="col.bind" />
 | 
				
			||||||
@@ -33,6 +35,7 @@
 | 
				
			|||||||
						v-if="col.select"
 | 
											v-if="col.select"
 | 
				
			||||||
						v-model="form[col.prop]"
 | 
											v-model="form[col.prop]"
 | 
				
			||||||
						:placeholder="`请选择${col.label}`"
 | 
											:placeholder="`请选择${col.label}`"
 | 
				
			||||||
 | 
											:disabled="disabled"
 | 
				
			||||||
						@change="$emit('update', form)"
 | 
											@change="$emit('update', form)"
 | 
				
			||||||
						v-bind="col.bind">
 | 
											v-bind="col.bind">
 | 
				
			||||||
						<el-option
 | 
											<el-option
 | 
				
			||||||
@@ -45,18 +48,23 @@
 | 
				
			|||||||
						v-if="col.datetime"
 | 
											v-if="col.datetime"
 | 
				
			||||||
						v-model="form[col.prop]"
 | 
											v-model="form[col.prop]"
 | 
				
			||||||
						type="datetime"
 | 
											type="datetime"
 | 
				
			||||||
 | 
											:disabled="disabled"
 | 
				
			||||||
						: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]"
 | 
				
			||||||
 | 
											:disabled="disabled"
 | 
				
			||||||
						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"
 | 
				
			||||||
						:key="col.key"
 | 
											:key="col.key"
 | 
				
			||||||
 | 
											:disabled="disabled"
 | 
				
			||||||
						:is="col.subcomponent"
 | 
											:is="col.subcomponent"
 | 
				
			||||||
						:inlineStyle="col.style"></component>
 | 
											:inlineStyle="col.style"></component>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -79,10 +87,14 @@
 | 
				
			|||||||
							:headers="uploadHeaders"
 | 
												:headers="uploadHeaders"
 | 
				
			||||||
							:show-file-list="false"
 | 
												:show-file-list="false"
 | 
				
			||||||
							icon="el-icon-upload2"
 | 
												icon="el-icon-upload2"
 | 
				
			||||||
 | 
												:disabled="disabled"
 | 
				
			||||||
							:before-upload="beforeUpload"
 | 
												:before-upload="beforeUpload"
 | 
				
			||||||
							: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,7 +106,8 @@
 | 
				
			|||||||
							class="file"
 | 
												class="file"
 | 
				
			||||||
							v-for="file in form[col.prop] || []"
 | 
												v-for="file in form[col.prop] || []"
 | 
				
			||||||
							:file="file"
 | 
												:file="file"
 | 
				
			||||||
							@delete="handleDeleteFile(file)" />
 | 
												:key="file.fileUrl"
 | 
				
			||||||
 | 
												@delete="!disabled && handleDeleteFile(file)" />
 | 
				
			||||||
					</div>
 | 
										</div>
 | 
				
			||||||
				</el-form-item>
 | 
									</el-form-item>
 | 
				
			||||||
			</el-col>
 | 
								</el-col>
 | 
				
			||||||
@@ -105,6 +118,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 +146,6 @@ const uploadedFile = {
 | 
				
			|||||||
	},
 | 
						},
 | 
				
			||||||
	methods: {
 | 
						methods: {
 | 
				
			||||||
		handleDelete() {
 | 
							handleDelete() {
 | 
				
			||||||
			console.log('emit delete event')
 | 
					 | 
				
			||||||
			this.$emit('delete', this.file);
 | 
								this.$emit('delete', this.file);
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
@@ -187,6 +200,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 +236,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 +246,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 +286,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 +308,7 @@ export default {
 | 
				
			|||||||
									});
 | 
														});
 | 
				
			||||||
								},
 | 
													},
 | 
				
			||||||
								{
 | 
													{
 | 
				
			||||||
									immediate: true,
 | 
														immediate: false,
 | 
				
			||||||
								}
 | 
													}
 | 
				
			||||||
							);
 | 
												);
 | 
				
			||||||
							return;
 | 
												return;
 | 
				
			||||||
@@ -308,6 +326,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 +390,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);
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -71,7 +71,9 @@ import DocAlert from '@/components/DocAlert';
 | 
				
			|||||||
// 头部标签插件
 | 
					// 头部标签插件
 | 
				
			||||||
import VueMeta from 'vue-meta';
 | 
					import VueMeta from 'vue-meta';
 | 
				
			||||||
import CodeBrickZj from 'code-brick-zj';
 | 
					import CodeBrickZj from 'code-brick-zj';
 | 
				
			||||||
 | 
					import { hiPrintPlugin,disAutoConnect } from 'vue-plugin-hiprint'
 | 
				
			||||||
 | 
					disAutoConnect();
 | 
				
			||||||
 | 
					Vue.use(hiPrintPlugin)
 | 
				
			||||||
Vue.use(CodeBrickZj)
 | 
					Vue.use(CodeBrickZj)
 | 
				
			||||||
Vue.use(directive);
 | 
					Vue.use(directive);
 | 
				
			||||||
Vue.use(plugins);
 | 
					Vue.use(plugins);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -28,10 +28,59 @@ 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);
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							del(payload) {
 | 
				
			||||||
 | 
								return this.http(this.deleteUrl == '' ? this.deletePath : this.deleteUrl, 'delete', payload);
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		// 过滤后端传回的详情数据
 | 
							// 过滤后端传回的详情数据
 | 
				
			||||||
		filterData(data, keys) {
 | 
							filterData(data, keys) {
 | 
				
			||||||
			const obj = {};
 | 
								const obj = {};
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -72,7 +72,7 @@ export const constantRoutes = [
 | 
				
			|||||||
  {
 | 
					  {
 | 
				
			||||||
    path: '/',
 | 
					    path: '/',
 | 
				
			||||||
    component: Layout,
 | 
					    component: Layout,
 | 
				
			||||||
    redirect: 'core/base/factory',
 | 
					    // redirect: 'core/base/factory',
 | 
				
			||||||
    // children: [{
 | 
					    // children: [{
 | 
				
			||||||
    //   path: 'index',
 | 
					    //   path: 'index',
 | 
				
			||||||
    //   redirect: 'core/base/factory',
 | 
					    //   redirect: 'core/base/factory',
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -180,6 +180,7 @@ input, textarea{
 | 
				
			|||||||
// 抽屉head区域---start
 | 
					// 抽屉head区域---start
 | 
				
			||||||
.el-drawer__header {
 | 
					.el-drawer__header {
 | 
				
			||||||
  padding-bottom: 20px;
 | 
					  padding-bottom: 20px;
 | 
				
			||||||
 | 
					  padding-left: 30px;
 | 
				
			||||||
  margin-bottom: 23px;
 | 
					  margin-bottom: 23px;
 | 
				
			||||||
  font-size: 20px;
 | 
					  font-size: 20px;
 | 
				
			||||||
  font-weight: 500;
 | 
					  font-weight: 500;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										53
									
								
								src/utils/cache.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										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,21 @@ 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',
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
 | 
					  // ============== EQUIPMENT - 设备模块 =============
 | 
				
			||||||
 | 
					  MAINTAIN_TYPE: 'maintain_type',
 | 
				
			||||||
 | 
					  FAULT_LEVEL: 'fault-level',
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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]
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										103
									
								
								src/views/base/coreCustomer/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								src/views/base/coreCustomer/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,103 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2021-11-18 14:16:25
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-11-03 10:53:43
 | 
				
			||||||
 | 
					 * @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="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-row :gutter="20">
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="联系人" prop="contact">
 | 
				
			||||||
 | 
										<el-input v-model="dataForm.contact" clearable placeholder="请输入联系人" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="联系电话" prop="telephone">
 | 
				
			||||||
 | 
										<el-input
 | 
				
			||||||
 | 
											v-model="dataForm.telephone"
 | 
				
			||||||
 | 
											maxlength="11"
 | 
				
			||||||
 | 
											placeholder="请输入联系电话" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
							<el-form-item label="地址" prop="address">
 | 
				
			||||||
 | 
								<el-input
 | 
				
			||||||
 | 
									v-model="dataForm.address"
 | 
				
			||||||
 | 
									placeholder="请输入地址" />
 | 
				
			||||||
 | 
							</el-form-item>
 | 
				
			||||||
 | 
							<el-form-item label="备注" prop="remark">
 | 
				
			||||||
 | 
								<el-input
 | 
				
			||||||
 | 
									v-model="dataForm.remark"
 | 
				
			||||||
 | 
									placeholder="请输入备注" />
 | 
				
			||||||
 | 
							</el-form-item>
 | 
				
			||||||
 | 
						</el-form>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import basicAdd from '../../core/mixins/basic-add';
 | 
				
			||||||
 | 
					import { createCustomer, updateCustomer, getCustomer, getCode } from "@/api/base/coreCustomer";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicAdd],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
								  isGetCode: true,
 | 
				
			||||||
 | 
					        codeURL: getCode,
 | 
				
			||||||
 | 
									createURL: createCustomer,
 | 
				
			||||||
 | 
									updateURL: updateCustomer,
 | 
				
			||||||
 | 
									infoURL: getCustomer
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								dataForm: {
 | 
				
			||||||
 | 
					        id: undefined,
 | 
				
			||||||
 | 
					        code: undefined,
 | 
				
			||||||
 | 
					        name: undefined,
 | 
				
			||||||
 | 
					        telephone: undefined,
 | 
				
			||||||
 | 
									contact: undefined,
 | 
				
			||||||
 | 
									address: undefined,
 | 
				
			||||||
 | 
					        remark: undefined
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								dataRule: {
 | 
				
			||||||
 | 
					        code: [{ required: true, message: "专业编码不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
					        name: [{ required: true, message: "专业名称不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
									contact: [{ required: true, message: "联系人不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
									telephone: [
 | 
				
			||||||
 | 
										{ required: false, trigger: "blur", message: "手机号不能为空" },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            validator: function (rule, value, callback) {
 | 
				
			||||||
 | 
					              if (value) {
 | 
				
			||||||
 | 
													if (/^(?:(?:\+|00)86)?1(?:3[\d]|4[5-79]|5[0-35-9]|6[5-7]|7[0-8]|8[\d]|9[189])\d{8}$/.test(value) === false) {
 | 
				
			||||||
 | 
														callback(new Error("手机号格式错误"));
 | 
				
			||||||
 | 
													}
 | 
				
			||||||
 | 
												} else {
 | 
				
			||||||
 | 
					                callback();
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					            }, trigger: "blur"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						mounted() {},
 | 
				
			||||||
 | 
						methods: {}
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										176
									
								
								src/views/base/coreCustomer/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								src/views/base/coreCustomer/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,176 @@
 | 
				
			|||||||
 | 
					<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 {
 | 
				
			||||||
 | 
						getCustomerPage,
 | 
				
			||||||
 | 
						deleteCustomer
 | 
				
			||||||
 | 
					} from '@/api/base/coreCustomer';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'createTime',
 | 
				
			||||||
 | 
							label: '添加时间',
 | 
				
			||||||
 | 
							filter: parseTime
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'name',
 | 
				
			||||||
 | 
							label: '客户名称'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'code',
 | 
				
			||||||
 | 
							label: '客户编码'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'contact',
 | 
				
			||||||
 | 
							label: '联系人'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'telephone',
 | 
				
			||||||
 | 
							label: '联系电话'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'address',
 | 
				
			||||||
 | 
							label: '地址'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'remark',
 | 
				
			||||||
 | 
							label: '备注'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicPage],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
									getDataListURL: getCustomerPage,
 | 
				
			||||||
 | 
									deleteURL: deleteCustomer
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								tableProps,
 | 
				
			||||||
 | 
								tableBtn: [
 | 
				
			||||||
 | 
									this.$auth.hasPermi(`base:core-customer:update`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'edit',
 | 
				
			||||||
 | 
												btnName: '编辑',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
										: undefined,
 | 
				
			||||||
 | 
					          this.$auth.hasPermi(`base:core-customer: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:core-customer: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.list;
 | 
				
			||||||
 | 
					    //     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>
 | 
				
			||||||
							
								
								
									
										107
									
								
								src/views/base/coreDepartment/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								src/views/base/coreDepartment/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,107 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2021-11-18 14:16:25
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-11-02 14:16:30
 | 
				
			||||||
 | 
					 * @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="name">
 | 
				
			||||||
 | 
										<el-input v-model="dataForm.name" clearable placeholder="请输入部门名称" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="部门编码" prop="code">
 | 
				
			||||||
 | 
										<el-input v-model="dataForm.code" clearable placeholder="请输入部门编码" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
							<el-row :gutter="20">
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="上级部门" prop="parentId">
 | 
				
			||||||
 | 
										<treeselect v-model="dataForm.parentId" :options="menuOptions" :normalizer="normalizer" :show-count="true" placeholder="选择上级部门"/>
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="备注" prop="remark">
 | 
				
			||||||
 | 
										<el-input
 | 
				
			||||||
 | 
											v-model="dataForm.remark"
 | 
				
			||||||
 | 
											placeholder="请输入备注" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
						</el-form>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import basicAdd from '../../core/mixins/basic-add';
 | 
				
			||||||
 | 
					import { createCoreDepartment, updateCoreDepartment, getCoreDepartment, getCode, getCoreDepartmentList } from "@/api/base/coreDepartment";
 | 
				
			||||||
 | 
					import Treeselect from "@riophae/vue-treeselect";
 | 
				
			||||||
 | 
					import "@riophae/vue-treeselect/dist/vue-treeselect.css";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicAdd],
 | 
				
			||||||
 | 
						components: { Treeselect },
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
								  isGetCode: true,
 | 
				
			||||||
 | 
					        codeURL: getCode,
 | 
				
			||||||
 | 
									createURL: createCoreDepartment,
 | 
				
			||||||
 | 
									updateURL: updateCoreDepartment,
 | 
				
			||||||
 | 
									infoURL: getCoreDepartment,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								dataForm: {
 | 
				
			||||||
 | 
					        id: undefined,
 | 
				
			||||||
 | 
					        code: undefined,
 | 
				
			||||||
 | 
					        name: undefined,
 | 
				
			||||||
 | 
					        parentId: undefined,
 | 
				
			||||||
 | 
					        remark: undefined,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								departmentlList: [],
 | 
				
			||||||
 | 
								menuOptions: [],
 | 
				
			||||||
 | 
								dataRule: {
 | 
				
			||||||
 | 
					        code: [{ required: true, message: "部门编码不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
					        name: [{ required: true, message: "部门名称不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						mounted() {
 | 
				
			||||||
 | 
							this.getDict()
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						methods: {
 | 
				
			||||||
 | 
							async getDict() {
 | 
				
			||||||
 | 
								// 部门列表
 | 
				
			||||||
 | 
								this.menuOptions = []
 | 
				
			||||||
 | 
								const res = await getCoreDepartmentList();
 | 
				
			||||||
 | 
								this.departmentlList = res.data.map(item => {
 | 
				
			||||||
 | 
									item.parentId = item.parentId ? item.parentId : 0
 | 
				
			||||||
 | 
									return item
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
								const menu = { id: 0, name: '总部门', children: [] };
 | 
				
			||||||
 | 
								menu.children = this.handleTree(this.departmentlList, "id")
 | 
				
			||||||
 | 
								this.menuOptions.push(menu)
 | 
				
			||||||
 | 
								console.log('你好', this.menuOptions)
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							/** 转换菜单数据结构 */
 | 
				
			||||||
 | 
					    normalizer(node) {
 | 
				
			||||||
 | 
					      if (node.children && !node.children.length) {
 | 
				
			||||||
 | 
					        delete node.children;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      return {
 | 
				
			||||||
 | 
					        id: node.id,
 | 
				
			||||||
 | 
					        label: node.name,
 | 
				
			||||||
 | 
					        children: node.children
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										168
									
								
								src/views/base/coreDepartment/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								src/views/base/coreDepartment/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,168 @@
 | 
				
			|||||||
 | 
					<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 {
 | 
				
			||||||
 | 
						getCoreDepartmentPage,
 | 
				
			||||||
 | 
						deleteCoreDepartment
 | 
				
			||||||
 | 
					} from '@/api/base/coreDepartment';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'createTime',
 | 
				
			||||||
 | 
							label: '添加时间',
 | 
				
			||||||
 | 
							filter: parseTime
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'name',
 | 
				
			||||||
 | 
							label: '部门名称'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'code',
 | 
				
			||||||
 | 
							label: '部门编码'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'parentName',
 | 
				
			||||||
 | 
							label: '上级部门'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'remark',
 | 
				
			||||||
 | 
							label: '备注'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicPage],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
									getDataListURL: getCoreDepartmentPage,
 | 
				
			||||||
 | 
									deleteURL: deleteCoreDepartment
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								tableProps,
 | 
				
			||||||
 | 
								tableBtn: [
 | 
				
			||||||
 | 
									this.$auth.hasPermi(`base:core-department:update`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'edit',
 | 
				
			||||||
 | 
												btnName: '编辑',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
										: undefined,
 | 
				
			||||||
 | 
					          this.$auth.hasPermi(`base:core-department: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:core-department: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.list;
 | 
				
			||||||
 | 
					    //     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>
 | 
				
			||||||
@@ -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
									
								
							
							
						
						
									
										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 = '修改设备类型';
 | 
				
			||||||
			});
 | 
								});
 | 
				
			||||||
							
								
								
									
										77
									
								
								src/views/base/coreMajor/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								src/views/base/coreMajor/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,77 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2021-11-18 14:16:25
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-11-02 14:24:12
 | 
				
			||||||
 | 
					 * @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="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-row :gutter="20">
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="缩写" prop="abbreviation">
 | 
				
			||||||
 | 
										<el-input v-model="dataForm.abbreviation" clearable placeholder="请输入缩写" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="备注" prop="remark">
 | 
				
			||||||
 | 
										<el-input
 | 
				
			||||||
 | 
											v-model="dataForm.remark"
 | 
				
			||||||
 | 
											placeholder="请输入备注" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
						</el-form>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import basicAdd from '../../core/mixins/basic-add';
 | 
				
			||||||
 | 
					import { createCoreMajor, updateCoreMajor, getCoreMajor, getCode } from "@/api/base/coreMajor";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicAdd],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
								  isGetCode: true,
 | 
				
			||||||
 | 
					        codeURL: getCode,
 | 
				
			||||||
 | 
									createURL: createCoreMajor,
 | 
				
			||||||
 | 
									updateURL: updateCoreMajor,
 | 
				
			||||||
 | 
									infoURL: getCoreMajor,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								dataForm: {
 | 
				
			||||||
 | 
					        id: undefined,
 | 
				
			||||||
 | 
					        code: undefined,
 | 
				
			||||||
 | 
					        name: undefined,
 | 
				
			||||||
 | 
					        abbreviation: undefined,
 | 
				
			||||||
 | 
					        remark: undefined,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								departmentlList: [],
 | 
				
			||||||
 | 
								menuOptions: [],
 | 
				
			||||||
 | 
								dataRule: {
 | 
				
			||||||
 | 
					        code: [{ required: true, message: "专业编码不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
					        name: [{ required: true, message: "专业名称不能为空", trigger: "blur" }]
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						mounted() {},
 | 
				
			||||||
 | 
						methods: {}
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										168
									
								
								src/views/base/coreMajor/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								src/views/base/coreMajor/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,168 @@
 | 
				
			|||||||
 | 
					<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 {
 | 
				
			||||||
 | 
						getCoreMajorPage,
 | 
				
			||||||
 | 
						deleteCoreMajor
 | 
				
			||||||
 | 
					} from '@/api/base/coreMajor';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'createTime',
 | 
				
			||||||
 | 
							label: '添加时间',
 | 
				
			||||||
 | 
							filter: parseTime
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'code',
 | 
				
			||||||
 | 
							label: '专业编码'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'name',
 | 
				
			||||||
 | 
							label: '专业名称'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'abbreviation',
 | 
				
			||||||
 | 
							label: '缩写'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'remark',
 | 
				
			||||||
 | 
							label: '备注'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicPage],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
									getDataListURL: getCoreMajorPage,
 | 
				
			||||||
 | 
									deleteURL: deleteCoreMajor
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								tableProps,
 | 
				
			||||||
 | 
								tableBtn: [
 | 
				
			||||||
 | 
									this.$auth.hasPermi(`base:core-major:update`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'edit',
 | 
				
			||||||
 | 
												btnName: '编辑',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
										: undefined,
 | 
				
			||||||
 | 
					          this.$auth.hasPermi(`base:core-major: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:core-major: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.list;
 | 
				
			||||||
 | 
					    //     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>
 | 
				
			||||||
							
								
								
									
										103
									
								
								src/views/base/coreSupplier/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								src/views/base/coreSupplier/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,103 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2021-11-18 14:16:25
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-11-03 11:00:47
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
						<el-form
 | 
				
			||||||
 | 
							:model="dataForm"
 | 
				
			||||||
 | 
							:rules="dataRule"
 | 
				
			||||||
 | 
							ref="dataForm"
 | 
				
			||||||
 | 
							@keyup.enter.native="dataFormSubmit()"
 | 
				
			||||||
 | 
							label-width="100px">
 | 
				
			||||||
 | 
							<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-row :gutter="20">
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="联系人" prop="contact">
 | 
				
			||||||
 | 
										<el-input v-model="dataForm.contact" clearable placeholder="请输入联系人" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="联系电话" prop="telephone">
 | 
				
			||||||
 | 
										<el-input
 | 
				
			||||||
 | 
											v-model="dataForm.telephone"
 | 
				
			||||||
 | 
											maxlength="11"
 | 
				
			||||||
 | 
											placeholder="请输入联系电话" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
							<el-form-item label="地址" prop="address">
 | 
				
			||||||
 | 
								<el-input
 | 
				
			||||||
 | 
									v-model="dataForm.address"
 | 
				
			||||||
 | 
									placeholder="请输入地址" />
 | 
				
			||||||
 | 
							</el-form-item>
 | 
				
			||||||
 | 
							<el-form-item label="备注" prop="remark">
 | 
				
			||||||
 | 
								<el-input
 | 
				
			||||||
 | 
									v-model="dataForm.remark"
 | 
				
			||||||
 | 
									placeholder="请输入备注" />
 | 
				
			||||||
 | 
							</el-form-item>
 | 
				
			||||||
 | 
						</el-form>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import basicAdd from '../../core/mixins/basic-add';
 | 
				
			||||||
 | 
					import { createCoreSupplier, updateCoreSupplier, getCoreSupplier, getCode } from "@/api/base/coreSupplier";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicAdd],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
								  isGetCode: true,
 | 
				
			||||||
 | 
					        codeURL: getCode,
 | 
				
			||||||
 | 
									createURL: createCoreSupplier,
 | 
				
			||||||
 | 
									updateURL: updateCoreSupplier,
 | 
				
			||||||
 | 
									infoURL: getCoreSupplier
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								dataForm: {
 | 
				
			||||||
 | 
					        id: undefined,
 | 
				
			||||||
 | 
					        code: undefined,
 | 
				
			||||||
 | 
					        name: undefined,
 | 
				
			||||||
 | 
					        telephone: undefined,
 | 
				
			||||||
 | 
									contact: undefined,
 | 
				
			||||||
 | 
									address: undefined,
 | 
				
			||||||
 | 
					        remark: undefined
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								dataRule: {
 | 
				
			||||||
 | 
					        code: [{ required: true, message: "专业编码不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
					        name: [{ required: true, message: "专业名称不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
									contact: [{ required: true, message: "联系人不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
									telephone: [
 | 
				
			||||||
 | 
										{ required: false, trigger: "blur", message: "手机号不能为空" },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            validator: function (rule, value, callback) {
 | 
				
			||||||
 | 
												if (value) {
 | 
				
			||||||
 | 
													if (/^(?:(?:\+|00)86)?1(?:3[\d]|4[5-79]|5[0-35-9]|6[5-7]|7[0-8]|8[\d]|9[189])\d{8}$/.test(value) === false) {
 | 
				
			||||||
 | 
														callback(new Error("手机号格式错误"));
 | 
				
			||||||
 | 
													}
 | 
				
			||||||
 | 
												} else {
 | 
				
			||||||
 | 
					                callback();
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					            }, trigger: "blur"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						mounted() {},
 | 
				
			||||||
 | 
						methods: {}
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										176
									
								
								src/views/base/coreSupplier/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								src/views/base/coreSupplier/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,176 @@
 | 
				
			|||||||
 | 
					<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 {
 | 
				
			||||||
 | 
						getCoreSupplierPage,
 | 
				
			||||||
 | 
						deleteCoreSupplier
 | 
				
			||||||
 | 
					} from '@/api/base/coreSupplier';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'createTime',
 | 
				
			||||||
 | 
							label: '添加时间',
 | 
				
			||||||
 | 
							filter: parseTime
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'code',
 | 
				
			||||||
 | 
							label: '供应商编码'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'name',
 | 
				
			||||||
 | 
							label: '供应商名称'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'contact',
 | 
				
			||||||
 | 
							label: '联系人'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'telephone',
 | 
				
			||||||
 | 
							label: '联系电话'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'address',
 | 
				
			||||||
 | 
							label: '地址'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'remark',
 | 
				
			||||||
 | 
							label: '备注'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicPage],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
									getDataListURL: getCoreSupplierPage,
 | 
				
			||||||
 | 
									deleteURL: deleteCoreSupplier
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								tableProps,
 | 
				
			||||||
 | 
								tableBtn: [
 | 
				
			||||||
 | 
									this.$auth.hasPermi(`base:core-supplier:update`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'edit',
 | 
				
			||||||
 | 
												btnName: '编辑',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
										: undefined,
 | 
				
			||||||
 | 
					          this.$auth.hasPermi(`base:core-supplier: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:core-supplier: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.list;
 | 
				
			||||||
 | 
					    //     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>
 | 
				
			||||||
							
								
								
									
										339
									
								
								src/views/base/coreWorker/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										339
									
								
								src/views/base/coreWorker/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,339 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2021-11-18 14:16:25
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-11-03 11:01:24
 | 
				
			||||||
 | 
					 * @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="name">
 | 
				
			||||||
 | 
										<el-input v-model="dataForm.name" clearable placeholder="请输入员工姓名" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="员工照片" prop="fileUrl">
 | 
				
			||||||
 | 
										<imageUpload v-model="dataForm.fileUrl" :limit="1"/>
 | 
				
			||||||
 | 
									</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-row>
 | 
				
			||||||
 | 
							<el-row :gutter="20">
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="性别" prop="sex">
 | 
				
			||||||
 | 
										<el-select
 | 
				
			||||||
 | 
											v-model="dataForm.sex"
 | 
				
			||||||
 | 
											filterable
 | 
				
			||||||
 | 
											placeholder="请选择性别">
 | 
				
			||||||
 | 
											<el-option
 | 
				
			||||||
 | 
												v-for="dict in sexList"
 | 
				
			||||||
 | 
												: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="telephone">
 | 
				
			||||||
 | 
										<el-input v-model="dataForm.telephone" maxlength="11" clearable placeholder="请输入电话" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
							<el-row :gutter="20">
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="部门" prop="departmentId">
 | 
				
			||||||
 | 
										<treeselect v-model="dataForm.departmentId" :options="menuOptions" :normalizer="normalizer" :show-count="true" placeholder="选择部门"/>
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="职位" prop="position">
 | 
				
			||||||
 | 
										<el-input v-model="dataForm.position" clearable placeholder="请输入职位" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
							<el-row :gutter="20">
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="专业" prop="majorIdList">
 | 
				
			||||||
 | 
										<el-select
 | 
				
			||||||
 | 
											v-model="majorIdList"
 | 
				
			||||||
 | 
											filterable
 | 
				
			||||||
 | 
											multiple
 | 
				
			||||||
 | 
											placeholder="请选择专业">
 | 
				
			||||||
 | 
											<el-option
 | 
				
			||||||
 | 
												v-for="dict in majorList"
 | 
				
			||||||
 | 
												: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="entryTime">
 | 
				
			||||||
 | 
										<el-date-picker
 | 
				
			||||||
 | 
											v-model="dataForm.entryTime"
 | 
				
			||||||
 | 
											type="date"
 | 
				
			||||||
 | 
											format='yyyy-MM-dd'
 | 
				
			||||||
 | 
					         		value-format='timestamp'
 | 
				
			||||||
 | 
											placeholder="选择入职时间" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
							<el-row :gutter="20">
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="状态" prop="status">
 | 
				
			||||||
 | 
										<el-radio-group v-model="dataForm.status" @input="setOut">
 | 
				
			||||||
 | 
											<el-radio :label="1">在职</el-radio>
 | 
				
			||||||
 | 
											<el-radio :label="2">离职</el-radio>
 | 
				
			||||||
 | 
										</el-radio-group>
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="离职时间" prop="outTime">
 | 
				
			||||||
 | 
										<el-date-picker
 | 
				
			||||||
 | 
											v-model="dataForm.outTime"
 | 
				
			||||||
 | 
											type="date"
 | 
				
			||||||
 | 
											:disabled="isOut"
 | 
				
			||||||
 | 
											format='yyyy-MM-dd'
 | 
				
			||||||
 | 
					         		value-format='timestamp'
 | 
				
			||||||
 | 
											placeholder="选择离职时间" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
							<el-row :gutter="20">
 | 
				
			||||||
 | 
								<el-col :span="12">
 | 
				
			||||||
 | 
									<el-form-item label="教育程度" prop="education">
 | 
				
			||||||
 | 
										<el-select
 | 
				
			||||||
 | 
											v-model="dataForm.education"
 | 
				
			||||||
 | 
											filterable
 | 
				
			||||||
 | 
											placeholder="请选择教育程度">
 | 
				
			||||||
 | 
											<el-option
 | 
				
			||||||
 | 
												v-for="dict in educationList"
 | 
				
			||||||
 | 
												: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="workCost">
 | 
				
			||||||
 | 
										<el-input type="number" v-model.number="dataForm.workCost" clearable placeholder="请输入劳务成本" />
 | 
				
			||||||
 | 
									</el-form-item>
 | 
				
			||||||
 | 
								</el-col>
 | 
				
			||||||
 | 
							</el-row>
 | 
				
			||||||
 | 
							<el-form-item label="备注" prop="remark">
 | 
				
			||||||
 | 
								<el-input
 | 
				
			||||||
 | 
									v-model="dataForm.remark"
 | 
				
			||||||
 | 
									placeholder="请输入备注" />
 | 
				
			||||||
 | 
							</el-form-item>
 | 
				
			||||||
 | 
						</el-form>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import basicAdd from '../../core/mixins/basic-add';
 | 
				
			||||||
 | 
					import { createCoreWorker, updateCoreWorker, getCoreWorker, getCode, createWoBindMa, getWoBindMaPage, deleteWoBindMa } from "@/api/base/coreWorker";
 | 
				
			||||||
 | 
					import { getCoreDepartmentList } from "@/api/base/coreDepartment";
 | 
				
			||||||
 | 
					import { getCoreMajorList } from "@/api/base/coreMajor";
 | 
				
			||||||
 | 
					import ImageUpload from '@/components/ImageUpload';
 | 
				
			||||||
 | 
					import Treeselect from "@riophae/vue-treeselect";
 | 
				
			||||||
 | 
					import "@riophae/vue-treeselect/dist/vue-treeselect.css";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicAdd],
 | 
				
			||||||
 | 
						components: {
 | 
				
			||||||
 | 
					    ImageUpload,
 | 
				
			||||||
 | 
							Treeselect
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
								  isGetCode: true,
 | 
				
			||||||
 | 
					        codeURL: getCode,
 | 
				
			||||||
 | 
									createURL: createCoreWorker,
 | 
				
			||||||
 | 
									updateURL: updateCoreWorker,
 | 
				
			||||||
 | 
									infoURL: getCoreWorker,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								sexList: [
 | 
				
			||||||
 | 
									{ id: 0, name: '男' },
 | 
				
			||||||
 | 
									{ id: 1, name: '女' }
 | 
				
			||||||
 | 
								],
 | 
				
			||||||
 | 
								educationList: [
 | 
				
			||||||
 | 
									{ id: '1', name: '初中' },
 | 
				
			||||||
 | 
									{ id: '2', name: '高中' },
 | 
				
			||||||
 | 
									{ id: '3', name: '中专' },
 | 
				
			||||||
 | 
									{ id: '5', name: '大专' },
 | 
				
			||||||
 | 
									{ id: '6', name: '大学本科' },
 | 
				
			||||||
 | 
									{ id: '7', name: '研究生及以上' }
 | 
				
			||||||
 | 
								],
 | 
				
			||||||
 | 
								departmentList: [],
 | 
				
			||||||
 | 
								majorList: [],
 | 
				
			||||||
 | 
								isOut: true,
 | 
				
			||||||
 | 
								dataForm: {
 | 
				
			||||||
 | 
					        id: undefined,
 | 
				
			||||||
 | 
					        code: undefined,
 | 
				
			||||||
 | 
					        name: undefined,
 | 
				
			||||||
 | 
									fileUrl: undefined,
 | 
				
			||||||
 | 
									sex: 0,
 | 
				
			||||||
 | 
									telephone: undefined,
 | 
				
			||||||
 | 
									departmentId: undefined,
 | 
				
			||||||
 | 
									position: undefined,
 | 
				
			||||||
 | 
									entryTime: new Date().getTime(),
 | 
				
			||||||
 | 
									status: 1,
 | 
				
			||||||
 | 
									outTime: undefined,
 | 
				
			||||||
 | 
									education: undefined,
 | 
				
			||||||
 | 
									workCost: undefined,
 | 
				
			||||||
 | 
					        remark: undefined,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								majorIdList: undefined,
 | 
				
			||||||
 | 
								departmentlList: [],
 | 
				
			||||||
 | 
								menuOptions: [],
 | 
				
			||||||
 | 
								bindIds: [],
 | 
				
			||||||
 | 
								workerId: '',
 | 
				
			||||||
 | 
								dataRule: {
 | 
				
			||||||
 | 
					        code: [{ required: true, message: "员工编码不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
					        name: [{ required: true, message: "员工姓名不能为空", trigger: "blur" }],
 | 
				
			||||||
 | 
									telephone: [
 | 
				
			||||||
 | 
										{ required: false, trigger: "blur", message: "手机号不能为空" },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            validator: function (rule, value, callback) {
 | 
				
			||||||
 | 
					              if (value) {
 | 
				
			||||||
 | 
													if (/^(?:(?:\+|00)86)?1(?:3[\d]|4[5-79]|5[0-35-9]|6[5-7]|7[0-8]|8[\d]|9[189])\d{8}$/.test(value) === false) {
 | 
				
			||||||
 | 
														callback(new Error("手机号格式错误"));
 | 
				
			||||||
 | 
													}
 | 
				
			||||||
 | 
												} else {
 | 
				
			||||||
 | 
					                callback();
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					            }, trigger: "blur"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						mounted() {
 | 
				
			||||||
 | 
							this.getDict()
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						methods: {
 | 
				
			||||||
 | 
							async getDict() {
 | 
				
			||||||
 | 
								// 部门列表
 | 
				
			||||||
 | 
								this.menuOptions = []
 | 
				
			||||||
 | 
								const res = await getCoreDepartmentList();
 | 
				
			||||||
 | 
								this.departmentlList = res.data.map(item => {
 | 
				
			||||||
 | 
									item.parentId = item.parentId ? item.parentId : 0
 | 
				
			||||||
 | 
									return item
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
								// const menu = { id: 0, name: '总部门', children: [] };
 | 
				
			||||||
 | 
								// menu.children = this.handleTree(this.departmentlList, "id")
 | 
				
			||||||
 | 
								this.menuOptions = this.handleTree(this.departmentlList, "id")
 | 
				
			||||||
 | 
								// 专业列表
 | 
				
			||||||
 | 
								const majorRes = await getCoreMajorList();
 | 
				
			||||||
 | 
								this.majorList = majorRes.data;
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							setOut(val) {
 | 
				
			||||||
 | 
								if (val === 1) {
 | 
				
			||||||
 | 
									this.isOut = true
 | 
				
			||||||
 | 
								} else {
 | 
				
			||||||
 | 
									this.isOut = false
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							// 表单提交
 | 
				
			||||||
 | 
					    dataFormSubmit() {
 | 
				
			||||||
 | 
								console.log('111', this.dataForm)
 | 
				
			||||||
 | 
					      this.$refs["dataForm"].validate((valid) => {
 | 
				
			||||||
 | 
					        if (!valid) {
 | 
				
			||||||
 | 
					          return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									// 把员工--专业关系全删
 | 
				
			||||||
 | 
									this.bindIds.forEach(id => {
 | 
				
			||||||
 | 
										deleteWoBindMa(id).then(res => {})
 | 
				
			||||||
 | 
									});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        // 修改的提交
 | 
				
			||||||
 | 
					        if (this.dataForm.id) {
 | 
				
			||||||
 | 
					          this.urlOptions.updateURL(this.dataForm).then(response => {
 | 
				
			||||||
 | 
					            this.$modal.msgSuccess("修改成功");
 | 
				
			||||||
 | 
					            this.visible = false;
 | 
				
			||||||
 | 
					            this.$emit("refreshDataList");
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
										this.majorIdList.forEach(majorId => {
 | 
				
			||||||
 | 
											createWoBindMa({
 | 
				
			||||||
 | 
												workerId: this.dataForm.id,
 | 
				
			||||||
 | 
												majorId: majorId
 | 
				
			||||||
 | 
											}).then(res => {})
 | 
				
			||||||
 | 
										});
 | 
				
			||||||
 | 
					          return;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // 添加的提交
 | 
				
			||||||
 | 
					        this.urlOptions.createURL(this.dataForm).then(response => {
 | 
				
			||||||
 | 
										// response.data = id
 | 
				
			||||||
 | 
										this.workerId = response.data
 | 
				
			||||||
 | 
										this.majorIdList.forEach(majorId => {
 | 
				
			||||||
 | 
											createWoBindMa({
 | 
				
			||||||
 | 
												workerId: this.workerId,
 | 
				
			||||||
 | 
												majorId: majorId
 | 
				
			||||||
 | 
											}).then(res => {})
 | 
				
			||||||
 | 
										});
 | 
				
			||||||
 | 
					          this.$modal.msgSuccess("新增成功");
 | 
				
			||||||
 | 
					          this.visible = false;
 | 
				
			||||||
 | 
					          this.$emit("refreshDataList");
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
							init(id) {
 | 
				
			||||||
 | 
					      this.dataForm.id = id || "";
 | 
				
			||||||
 | 
					      this.visible = true;
 | 
				
			||||||
 | 
					      if (this.urlOptions.getOption) {
 | 
				
			||||||
 | 
					        this.getArr()
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.$nextTick(() => {
 | 
				
			||||||
 | 
					        this.$refs["dataForm"].resetFields();
 | 
				
			||||||
 | 
					        if (this.dataForm.id) {
 | 
				
			||||||
 | 
					          this.urlOptions.infoURL(id).then(response => {
 | 
				
			||||||
 | 
					            this.dataForm = response.data;
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
										// 获取员工--专业
 | 
				
			||||||
 | 
										getWoBindMaPage({
 | 
				
			||||||
 | 
											pageSize: 99,
 | 
				
			||||||
 | 
											pageNo: 1,
 | 
				
			||||||
 | 
											workerId: id
 | 
				
			||||||
 | 
										}).then(res => {
 | 
				
			||||||
 | 
											this.majorIdList = res.data.list.map(item => {
 | 
				
			||||||
 | 
												return item.majorId
 | 
				
			||||||
 | 
											})
 | 
				
			||||||
 | 
											this.bindIds = res.data.list.map(item => {
 | 
				
			||||||
 | 
												return item.id
 | 
				
			||||||
 | 
											})
 | 
				
			||||||
 | 
										})
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          if (this.urlOptions.isGetCode) {
 | 
				
			||||||
 | 
					            this.getCode()
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
							/** 转换菜单数据结构 */
 | 
				
			||||||
 | 
					    normalizer(node) {
 | 
				
			||||||
 | 
					      if (node.children && !node.children.length) {
 | 
				
			||||||
 | 
					        delete node.children;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      return {
 | 
				
			||||||
 | 
					        id: node.id,
 | 
				
			||||||
 | 
					        label: node.name,
 | 
				
			||||||
 | 
					        children: node.children
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										204
									
								
								src/views/base/coreWorker/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										204
									
								
								src/views/base/coreWorker/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,204 @@
 | 
				
			|||||||
 | 
					<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 {
 | 
				
			||||||
 | 
						getCoreWorkerPage,
 | 
				
			||||||
 | 
						deleteCoreWorker
 | 
				
			||||||
 | 
					} from '@/api/base/coreWorker';
 | 
				
			||||||
 | 
					import moment from 'moment';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'createTime',
 | 
				
			||||||
 | 
							label: '创建时间',
 | 
				
			||||||
 | 
							filter: parseTime
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'name',
 | 
				
			||||||
 | 
							label: '姓名'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'code',
 | 
				
			||||||
 | 
							label: '员工号'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'sex',
 | 
				
			||||||
 | 
							label: '性别',
 | 
				
			||||||
 | 
							filter: (val) => ['男', '女'][val]
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'entryTime',
 | 
				
			||||||
 | 
							label: '入职时间',
 | 
				
			||||||
 | 
							filter: (val) => val ? moment(val).format('yyyy-MM-DD') : '',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'telephone',
 | 
				
			||||||
 | 
							label: '联系电话'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'status',
 | 
				
			||||||
 | 
							label: '状态',
 | 
				
			||||||
 | 
							filter: (val) => ['', '在职', '离职'][val]
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'departmentName',
 | 
				
			||||||
 | 
							label: '部门'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'majorName',
 | 
				
			||||||
 | 
							label: '专业'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'remark',
 | 
				
			||||||
 | 
							label: '备注'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicPage],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
									getDataListURL: getCoreWorkerPage,
 | 
				
			||||||
 | 
									deleteURL: deleteCoreWorker
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								tableProps,
 | 
				
			||||||
 | 
								tableBtn: [
 | 
				
			||||||
 | 
									this.$auth.hasPermi(`base:core-worker:update`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'edit',
 | 
				
			||||||
 | 
												btnName: '编辑',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
										: undefined,
 | 
				
			||||||
 | 
					          this.$auth.hasPermi(`base:core-worker:delete`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'delete',
 | 
				
			||||||
 | 
												btnName: '删除',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
										: undefined,
 | 
				
			||||||
 | 
								].filter((v)=>v),
 | 
				
			||||||
 | 
								tableData: [],
 | 
				
			||||||
 | 
								formConfig: [
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'input',
 | 
				
			||||||
 | 
										label: '员工姓名',
 | 
				
			||||||
 | 
										placeholder: '员工姓名',
 | 
				
			||||||
 | 
										param: 'name',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'select',
 | 
				
			||||||
 | 
										label: '状态',
 | 
				
			||||||
 | 
										placeholder: '请选择状态',
 | 
				
			||||||
 | 
										param: 'status',
 | 
				
			||||||
 | 
										selectOptions: [
 | 
				
			||||||
 | 
											{ id: 1, name: '在职' },
 | 
				
			||||||
 | 
											{ id: 2, name: '离职' }
 | 
				
			||||||
 | 
										],
 | 
				
			||||||
 | 
										filterable: true
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'button',
 | 
				
			||||||
 | 
										btnName: '查询',
 | 
				
			||||||
 | 
										name: 'search',
 | 
				
			||||||
 | 
										color: 'primary',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'separate',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: this.$auth.hasPermi('base:core-worker: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.list;
 | 
				
			||||||
 | 
					    //     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.status = val.status ? val.status : 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>
 | 
				
			||||||
							
								
								
									
										65
									
								
								src/views/base/custom/SmallTitle.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/views/base/custom/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>
 | 
				
			||||||
							
								
								
									
										411
									
								
								src/views/base/custom/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										411
									
								
								src/views/base/custom/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,411 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <el-drawer :visible.sync="drawer" :append-to-body="true" size="80%">
 | 
				
			||||||
 | 
					    <small-title slot="title" :no-padding="true">
 | 
				
			||||||
 | 
					      <!-- <template v-for="demo in demoList"> -->
 | 
				
			||||||
 | 
					      <!-- <el-button :key="demo.name" :type="demo.name === curDemo ? 'primary' : ' '" @click="curDemo = demo.name"> -->
 | 
				
			||||||
 | 
					      <!-- {{ $t('module.packingManage.printModelDesign') }} -->
 | 
				
			||||||
 | 
					      模板设计
 | 
				
			||||||
 | 
					      <!-- </el-button> -->
 | 
				
			||||||
 | 
					      <!-- </template> -->
 | 
				
			||||||
 | 
					    </small-title>
 | 
				
			||||||
 | 
					    <el-card>
 | 
				
			||||||
 | 
					      <el-row style="margin-bottom: 10px">
 | 
				
			||||||
 | 
					        <el-col :span="4">
 | 
				
			||||||
 | 
					          <!-- 模板选择 -->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          <!-- <el-select
 | 
				
			||||||
 | 
					          v-model="mode"
 | 
				
			||||||
 | 
					          filterable
 | 
				
			||||||
 | 
					          :default-value="0"
 | 
				
			||||||
 | 
					          option-label-prop="label"
 | 
				
			||||||
 | 
					          style="width: 100%;"
 | 
				
			||||||
 | 
					          @change="changeMode"
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					          <el-option v-for="(opt,idx) in modeList" :key="idx" :label="opt.name" :value="idx">
 | 
				
			||||||
 | 
					            {{ opt.name }}
 | 
				
			||||||
 | 
					          </el-option>
 | 
				
			||||||
 | 
					        </el-select> -->
 | 
				
			||||||
 | 
					        </el-col>
 | 
				
			||||||
 | 
					        <el-col :span="20">
 | 
				
			||||||
 | 
					          <!-- 纸张设置 -->
 | 
				
			||||||
 | 
					          <el-button-group style="margin:0 10px">
 | 
				
			||||||
 | 
					            <el-button
 | 
				
			||||||
 | 
					              v-for="(value,type) in paperTypes"
 | 
				
			||||||
 | 
					              :key="type"
 | 
				
			||||||
 | 
					              :type="curPaperType === type ? 'primary' : ' '"
 | 
				
			||||||
 | 
					              @click="setPaper(type,value)"
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					              {{ type }}
 | 
				
			||||||
 | 
					            </el-button>
 | 
				
			||||||
 | 
					          </el-button-group>
 | 
				
			||||||
 | 
					          <el-input-number
 | 
				
			||||||
 | 
					            style="margin:0 10px"
 | 
				
			||||||
 | 
					            :value="scaleValue "
 | 
				
			||||||
 | 
					            :precision="2"
 | 
				
			||||||
 | 
					            :step="0.1"
 | 
				
			||||||
 | 
					            :min="scaleMin"
 | 
				
			||||||
 | 
					            :max="scaleMax"
 | 
				
			||||||
 | 
					            @change="changeScale"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					          <el-popover v-model="paperPopVisible" placement="bottom" width="300" title="设置纸张宽高(mm)">
 | 
				
			||||||
 | 
					            <div style="display: flex;align-items: center;justify-content: space-between;margin-bottom: 10px">
 | 
				
			||||||
 | 
					              <el-input v-model="paperWidth" type="number" style=" width: 100px; text-align: center" place="宽(mm)" />~
 | 
				
			||||||
 | 
					              <el-input v-model="paperHeight" type="number" style=" width: 100px; text-align: center" place="高(mm)" />
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
 | 
					            <div>
 | 
				
			||||||
 | 
					              <el-button type="primary" style="width: 100%" size="mini" @click="otherPaper">确定</el-button>
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
 | 
					            <el-button slot="reference" type="primary" style="margin:0 10px">自定义宽高</el-button>
 | 
				
			||||||
 | 
					          </el-popover>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          <!--          <a-button-group>-->
 | 
				
			||||||
 | 
					          <!--            <template v-for="(value,type) in paperTypes">-->
 | 
				
			||||||
 | 
					          <!--              <a-button :type="curPaperType === type ? 'primary' : 'info'" @click="setPaper(type,value)" :key="type">-->
 | 
				
			||||||
 | 
					          <!--                {{ type }}-->
 | 
				
			||||||
 | 
					          <!--              </a-button>-->
 | 
				
			||||||
 | 
					          <!--            </template>-->
 | 
				
			||||||
 | 
					          <!--            <a-popover v-model="paperPopVisible" title="设置纸张宽高(mm)" trigger="click">-->
 | 
				
			||||||
 | 
					          <!--              <div slot="content">-->
 | 
				
			||||||
 | 
					          <!--                <a-input-group compact style="margin: 10px 10px">-->
 | 
				
			||||||
 | 
					          <!--                  <a-input type="number" v-model="paperWidth" style=" width: 100px; text-align: center"-->
 | 
				
			||||||
 | 
					          <!--                           placeholder="宽(mm)"/>-->
 | 
				
			||||||
 | 
					          <!--                  <a-input style=" width: 30px; border-left: 0; pointer-events: none; backgroundColor: #fff"-->
 | 
				
			||||||
 | 
					          <!--                           placeholder="~" disabled-->
 | 
				
			||||||
 | 
					          <!--                  />-->
 | 
				
			||||||
 | 
					          <!--                  <a-input type="number" v-model="paperHeight" style="width: 100px; text-align: center; border-left: 0"-->
 | 
				
			||||||
 | 
					          <!--                           placeholder="高(mm)"/>-->
 | 
				
			||||||
 | 
					          <!--                </a-input-group>-->
 | 
				
			||||||
 | 
					          <!--                <a-button type="primary" style="width: 100%" @click="otherPaper">确定</a-button>-->
 | 
				
			||||||
 | 
					          <!--              </div>-->
 | 
				
			||||||
 | 
					          <!--              <a-button :type="'other'==curPaperType?'primary':''">自定义纸张</a-button>-->
 | 
				
			||||||
 | 
					          <!--            </a-popover>-->
 | 
				
			||||||
 | 
					          <!--          </a-button-group>-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          <!-- 预览/打印 -->
 | 
				
			||||||
 | 
					          <el-button-group>
 | 
				
			||||||
 | 
					            <el-button type="primary" icon="redo" @click="rotatePaper()">旋转</el-button>
 | 
				
			||||||
 | 
					            <el-button type="primary" icon="el-icon-view" @click="preView">
 | 
				
			||||||
 | 
					              预览
 | 
				
			||||||
 | 
					            </el-button>
 | 
				
			||||||
 | 
					            <!-- <el-button type="primary" icon="el-icon-printer" @click="print">
 | 
				
			||||||
 | 
					            直接打印
 | 
				
			||||||
 | 
					          </el-button> -->
 | 
				
			||||||
 | 
					            <el-button type="primary" icon="el-icon-s-management" @click="save">
 | 
				
			||||||
 | 
					              保存
 | 
				
			||||||
 | 
					            </el-button>
 | 
				
			||||||
 | 
					            <el-button type="danger" icon="el-icon-delete" @click="clearPaper">
 | 
				
			||||||
 | 
					              清空
 | 
				
			||||||
 | 
					            </el-button>
 | 
				
			||||||
 | 
					          </el-button-group>
 | 
				
			||||||
 | 
					          <!-- 保存/清空 -->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        </el-col>
 | 
				
			||||||
 | 
					      </el-row>
 | 
				
			||||||
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
 | 
					        <el-col :span="4">
 | 
				
			||||||
 | 
					          <el-card style="height: 100vh">
 | 
				
			||||||
 | 
					            <el-row>
 | 
				
			||||||
 | 
					              <el-col :span="24" class="rect-printElement-types hiprintEpContainer" />
 | 
				
			||||||
 | 
					            </el-row>
 | 
				
			||||||
 | 
					          </el-card>
 | 
				
			||||||
 | 
					        </el-col>
 | 
				
			||||||
 | 
					        <el-col :span="16">
 | 
				
			||||||
 | 
					          <el-card class="card-design">
 | 
				
			||||||
 | 
					            <div id="hiprint-printTemplate" class="hiprint-printTemplate" />
 | 
				
			||||||
 | 
					          </el-card>
 | 
				
			||||||
 | 
					        </el-col>
 | 
				
			||||||
 | 
					        <el-col :span="4" class="params_setting_container">
 | 
				
			||||||
 | 
					          <el-card>
 | 
				
			||||||
 | 
					            <el-row class="hinnn-layout-sider">
 | 
				
			||||||
 | 
					              <div id="PrintElementOptionSetting" />
 | 
				
			||||||
 | 
					            </el-row>
 | 
				
			||||||
 | 
					          </el-card>
 | 
				
			||||||
 | 
					        </el-col>
 | 
				
			||||||
 | 
					      </el-row>
 | 
				
			||||||
 | 
					      <!-- 预览 -->
 | 
				
			||||||
 | 
					      <print-preview ref="preView" />
 | 
				
			||||||
 | 
					    </el-card>
 | 
				
			||||||
 | 
					  </el-drawer>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import printPreview from './preview'
 | 
				
			||||||
 | 
					import { MessageBox } from 'element-ui'
 | 
				
			||||||
 | 
					import { hiprint } from 'vue-plugin-hiprint'
 | 
				
			||||||
 | 
					import providers from './providers'
 | 
				
			||||||
 | 
					import printData from './print-data'
 | 
				
			||||||
 | 
					import $ from 'jquery'
 | 
				
			||||||
 | 
					import SmallTitle from './SmallTitle.vue'
 | 
				
			||||||
 | 
					let hiprintTemplate = null
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: 'PrintCustom',
 | 
				
			||||||
 | 
					  components: { printPreview, SmallTitle },
 | 
				
			||||||
 | 
					  // props: {
 | 
				
			||||||
 | 
					  //   modelData: {
 | 
				
			||||||
 | 
					  //     type: String,
 | 
				
			||||||
 | 
					  //     default: ''
 | 
				
			||||||
 | 
					  //   }
 | 
				
			||||||
 | 
					  // },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      // paperPopVisible: false,
 | 
				
			||||||
 | 
					      // 模板选择
 | 
				
			||||||
 | 
					      mode: 0,
 | 
				
			||||||
 | 
					      template: null,
 | 
				
			||||||
 | 
					      modeList: [],
 | 
				
			||||||
 | 
					      // 当前纸张
 | 
				
			||||||
 | 
					      curPaper: {
 | 
				
			||||||
 | 
					        // type: 'other',
 | 
				
			||||||
 | 
					        // width: 220,
 | 
				
			||||||
 | 
					        // height: 80
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      drawer: false,
 | 
				
			||||||
 | 
					      // 纸张类型
 | 
				
			||||||
 | 
					      paperTypes: {
 | 
				
			||||||
 | 
					        'A3': {
 | 
				
			||||||
 | 
					          width: 420,
 | 
				
			||||||
 | 
					          height: 296.6
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        'A4': {
 | 
				
			||||||
 | 
					          width: 210,
 | 
				
			||||||
 | 
					          height: 297
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        'A5': {
 | 
				
			||||||
 | 
					          width: 210,
 | 
				
			||||||
 | 
					          height: 147.6
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        'B3': {
 | 
				
			||||||
 | 
					          width: 500,
 | 
				
			||||||
 | 
					          height: 352.6
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        'B4': {
 | 
				
			||||||
 | 
					          width: 250,
 | 
				
			||||||
 | 
					          height: 352.6
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        'B5': {
 | 
				
			||||||
 | 
					          width: 250,
 | 
				
			||||||
 | 
					          height: 175.6
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      scaleValue: 1,
 | 
				
			||||||
 | 
					      scaleMax: 5,
 | 
				
			||||||
 | 
					      scaleMin: 0.5,
 | 
				
			||||||
 | 
					      // 自定义纸张
 | 
				
			||||||
 | 
					      paperPopVisible: false,
 | 
				
			||||||
 | 
					      paperWidth: '210',
 | 
				
			||||||
 | 
					      paperHeight: '297'
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    curPaperType() {
 | 
				
			||||||
 | 
					      let type = 'other'
 | 
				
			||||||
 | 
					      const types = this.paperTypes
 | 
				
			||||||
 | 
					      for (const key in types) {
 | 
				
			||||||
 | 
					        const item = types[key]
 | 
				
			||||||
 | 
					        const { width, height } = this.curPaper
 | 
				
			||||||
 | 
					        if (item.width === width && item.height === height) {
 | 
				
			||||||
 | 
					          type = key
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      return type
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.init()
 | 
				
			||||||
 | 
					    // console.log('aaaaaa')
 | 
				
			||||||
 | 
					    // this.otherPaper()
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  destroyed () {
 | 
				
			||||||
 | 
					    $('.hiprintEpContainer').empty()
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    // handleClose() {
 | 
				
			||||||
 | 
					    //   $('.hiprintEpContainer').empty()
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
 | 
					    init(data) {
 | 
				
			||||||
 | 
					      this.drawer = true
 | 
				
			||||||
 | 
					      this.modelData = data
 | 
				
			||||||
 | 
					      this.modeList = providers.map((e) => {
 | 
				
			||||||
 | 
					        return { type: e.type, name: e.name, value: e.value }
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					      this.changeMode()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    changeMode() {
 | 
				
			||||||
 | 
					      // hiprintTemplate.clear()
 | 
				
			||||||
 | 
					      // console.log(this.modelData)
 | 
				
			||||||
 | 
					      const { mode } = this
 | 
				
			||||||
 | 
					      const provider = providers[mode]
 | 
				
			||||||
 | 
					      hiprint.init({
 | 
				
			||||||
 | 
					        providers: [provider.f]
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // $('#hiprint-printTemplate').empty()
 | 
				
			||||||
 | 
					      // console.log(JSON.parse(this.modelData))
 | 
				
			||||||
 | 
					      hiprint.setConfig()
 | 
				
			||||||
 | 
					      // 替换配置
 | 
				
			||||||
 | 
					      hiprint.setConfig({
 | 
				
			||||||
 | 
					        movingDistance: 2.5,
 | 
				
			||||||
 | 
					        text: {
 | 
				
			||||||
 | 
					          supportOptions: [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					              name: 'styler',
 | 
				
			||||||
 | 
					              hidden: true
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					              name: 'formatter',
 | 
				
			||||||
 | 
					              hidden: true
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          ]
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // console.log(this.modelData)
 | 
				
			||||||
 | 
					      // console.log($('#hiprint-printTemplate').empty())
 | 
				
			||||||
 | 
					      if (this.modelData) {
 | 
				
			||||||
 | 
					        $('.hiprintEpContainer').empty()
 | 
				
			||||||
 | 
					        hiprint.PrintElementTypeManager.build('.hiprintEpContainer', provider.value)
 | 
				
			||||||
 | 
					        $('.hiprint-printTemplate').empty()
 | 
				
			||||||
 | 
					        hiprintTemplate = new hiprint.PrintTemplate({
 | 
				
			||||||
 | 
					          template: JSON.parse(this.modelData),
 | 
				
			||||||
 | 
					          settingContainer: '#PrintElementOptionSetting',
 | 
				
			||||||
 | 
					          paginationContainer: '.hiprint-printPagination'
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        $('.hiprintEpContainer').empty()
 | 
				
			||||||
 | 
					        hiprint.PrintElementTypeManager.build('.hiprintEpContainer', provider.value)
 | 
				
			||||||
 | 
					        $('.hiprint-printTemplate').empty()
 | 
				
			||||||
 | 
					        // const templates = this.$ls.get('KEY_TEMPLATES', {})
 | 
				
			||||||
 | 
					        const template = provider.value
 | 
				
			||||||
 | 
					        console.log(template)
 | 
				
			||||||
 | 
					        hiprintTemplate = new hiprint.PrintTemplate({
 | 
				
			||||||
 | 
					          template: template,
 | 
				
			||||||
 | 
					          settingContainer: '#PrintElementOptionSetting',
 | 
				
			||||||
 | 
					          paginationContainer: '.hiprint-printPagination'
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      // hiprintTemplate.design('#hiprint-printTemplate')
 | 
				
			||||||
 | 
					      // console.log(hiprintTemplate)
 | 
				
			||||||
 | 
					      hiprintTemplate.design('#hiprint-printTemplate', { grid: true })
 | 
				
			||||||
 | 
					      // 获取当前放大比例, 当zoom时传true 才会有
 | 
				
			||||||
 | 
					      this.scaleValue = hiprintTemplate.editingPanel.scale || 1
 | 
				
			||||||
 | 
					      // this.scaleValue = hiprintTemplate.editingPanel.scale || 1
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    /**
 | 
				
			||||||
 | 
					     * 设置纸张大小
 | 
				
			||||||
 | 
					     * @param type [A3, A4, A5, B3, B4, B5, other]
 | 
				
			||||||
 | 
					     * @param value {width,height} mm
 | 
				
			||||||
 | 
					     */
 | 
				
			||||||
 | 
					    setPaper(type, value) {
 | 
				
			||||||
 | 
					      try {
 | 
				
			||||||
 | 
					        if (Object.keys(this.paperTypes).includes(type)) {
 | 
				
			||||||
 | 
					          this.curPaper = { type: type, width: value.width, height: value.height }
 | 
				
			||||||
 | 
					          hiprintTemplate.setPaper(value.width, value.height)
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          this.curPaper = { type: 'other', width: value.width, height: value.height }
 | 
				
			||||||
 | 
					          hiprintTemplate.setPaper(value.width, value.height)
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      } catch (error) {
 | 
				
			||||||
 | 
					        this.$message.error(`操作失败: ${error}`)
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    changeScale(currentValue, oldValue) {
 | 
				
			||||||
 | 
					      let big = false
 | 
				
			||||||
 | 
					      currentValue <= oldValue ? big = false : big = true
 | 
				
			||||||
 | 
					      let scaleValue = this.scaleValue
 | 
				
			||||||
 | 
					      if (big) {
 | 
				
			||||||
 | 
					        scaleValue += 0.1
 | 
				
			||||||
 | 
					        if (scaleValue > this.scaleMax) scaleValue = 5
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        scaleValue -= 0.1
 | 
				
			||||||
 | 
					        if (scaleValue < this.scaleMin) scaleValue = 0.5
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      if (hiprintTemplate) {
 | 
				
			||||||
 | 
					        // scaleValue: 放大缩小值, false: 不保存(不传也一样), 如果传 true, 打印时也会放大
 | 
				
			||||||
 | 
					        hiprintTemplate.zoom(scaleValue)
 | 
				
			||||||
 | 
					        this.scaleValue = scaleValue
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    clearPaper() {
 | 
				
			||||||
 | 
					      MessageBox.confirm('是否确认清空模板信息?', '警告', {
 | 
				
			||||||
 | 
					        confirmButtonText: '确定',
 | 
				
			||||||
 | 
					        cancelButtonText: '取消',
 | 
				
			||||||
 | 
					        type: 'warning'
 | 
				
			||||||
 | 
					      }).then(() => {
 | 
				
			||||||
 | 
					        try {
 | 
				
			||||||
 | 
					          hiprintTemplate.clear()
 | 
				
			||||||
 | 
					        } catch (error) {
 | 
				
			||||||
 | 
					          this.$message.error(`操作失败: ${error}`)
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }).catch((err) => {
 | 
				
			||||||
 | 
					        console.log(err)
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    otherPaper() {
 | 
				
			||||||
 | 
					      const value = {}
 | 
				
			||||||
 | 
					      value.width = this.paperWidth
 | 
				
			||||||
 | 
					      value.height = this.paperHeight
 | 
				
			||||||
 | 
					      this.paperPopVisible = false
 | 
				
			||||||
 | 
					      this.setPaper('other', value)
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    rotatePaper() {
 | 
				
			||||||
 | 
					      if (hiprintTemplate) {
 | 
				
			||||||
 | 
					        hiprintTemplate.rotatePaper()
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    preView() {
 | 
				
			||||||
 | 
					      const { width } = this.curPaper
 | 
				
			||||||
 | 
					      this.$refs.preView.show(hiprintTemplate, printData, width)
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    print() {
 | 
				
			||||||
 | 
					      // if (window.hiwebSocket.opened) {
 | 
				
			||||||
 | 
					      const printerList = hiprintTemplate.getPrinterList()
 | 
				
			||||||
 | 
					      console.log(printerList)
 | 
				
			||||||
 | 
					      hiprintTemplate.print2(printData, { printer: '', title: '预览打印' })
 | 
				
			||||||
 | 
					      // return
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      // this.$message.error('客户端未连接,无法直接打印')
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    save() {
 | 
				
			||||||
 | 
					      // console.log(hiprintTemplate.getJson())
 | 
				
			||||||
 | 
					      const { mode } = this
 | 
				
			||||||
 | 
					      const provider = providers[mode]
 | 
				
			||||||
 | 
					      // console.log(hiprintTemplate.getJson())
 | 
				
			||||||
 | 
					      this.setTemplate({
 | 
				
			||||||
 | 
					        name: provider.value,
 | 
				
			||||||
 | 
					        json: hiprintTemplate.getJson()
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    setTemplate(payload) {
 | 
				
			||||||
 | 
					      // const templates = this.$ls.get('KEY_TEMPLATES', {})
 | 
				
			||||||
 | 
					      // console.log(payload.json)
 | 
				
			||||||
 | 
					      // templates[payload.name] = payload.json
 | 
				
			||||||
 | 
					      // this.$ls.set('KEY_TEMPLATES', templates)
 | 
				
			||||||
 | 
					      this.$message.info('保存成功')
 | 
				
			||||||
 | 
					      // console.log(JSON.stringify(payload.json))
 | 
				
			||||||
 | 
					      this.drawer = false
 | 
				
			||||||
 | 
					      this.$emit('saveData', payload.json)
 | 
				
			||||||
 | 
					      $('.hiprintEpContainer').empty()
 | 
				
			||||||
 | 
					      // this.$parent.$parent.getModelData(payload.json)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					// build 拖拽
 | 
				
			||||||
 | 
					::v-deep .hiprint-printElement-type >li>ul>li>a {
 | 
				
			||||||
 | 
					  padding: 4px 4px;
 | 
				
			||||||
 | 
					  color: #1296db;
 | 
				
			||||||
 | 
					  line-height: 1;
 | 
				
			||||||
 | 
					  height: auto;
 | 
				
			||||||
 | 
					  text-overflow: ellipsis;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					// 设计容器
 | 
				
			||||||
 | 
					.card-design {
 | 
				
			||||||
 | 
					  // overflow: hidden;
 | 
				
			||||||
 | 
					  overflow-x: auto;
 | 
				
			||||||
 | 
					  overflow-y: auto;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										89
									
								
								src/views/base/custom/preview.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								src/views/base/custom/preview.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,89 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2023-09-27 14:23:54
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-19 11:20:36
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <el-dialog :visible="visible" :mask-closable="false" width="50%" @close="hideModal" :append-to-body="true">
 | 
				
			||||||
 | 
					    <div id="preview_content" />
 | 
				
			||||||
 | 
					    <template slot="title">
 | 
				
			||||||
 | 
					      <div style="margin-right: 20px">打印预览</div>
 | 
				
			||||||
 | 
					      <el-button :loading="waitShowPrinter" type="primary" icon="printer" @click.stop="print">打印</el-button>
 | 
				
			||||||
 | 
					      <el-button type="primary" icon="printer" @click.stop="toPdf">pdf</el-button>
 | 
				
			||||||
 | 
					    </template>
 | 
				
			||||||
 | 
					    <template slot="footer">
 | 
				
			||||||
 | 
					      <el-button key="close" type="info" @click="hideModal">
 | 
				
			||||||
 | 
					        关闭
 | 
				
			||||||
 | 
					      </el-button>
 | 
				
			||||||
 | 
					    </template>
 | 
				
			||||||
 | 
					  </el-dialog>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: 'PrintPreview',
 | 
				
			||||||
 | 
					  props: {},
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      visible: false,
 | 
				
			||||||
 | 
					      spinning: true,
 | 
				
			||||||
 | 
					      waitShowPrinter: false,
 | 
				
			||||||
 | 
					      // 纸张宽 mm
 | 
				
			||||||
 | 
					      width: 0,
 | 
				
			||||||
 | 
					      // 模板
 | 
				
			||||||
 | 
					      hiprintTemplate: {},
 | 
				
			||||||
 | 
					      // 数据
 | 
				
			||||||
 | 
					      printData: {}
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {},
 | 
				
			||||||
 | 
					  watch: {},
 | 
				
			||||||
 | 
					  created() {
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    hideModal() {
 | 
				
			||||||
 | 
					      this.visible = false
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    show(hiprintTemplate, printData, width = '210') {
 | 
				
			||||||
 | 
					      this.visible = true
 | 
				
			||||||
 | 
					      this.spinning = true
 | 
				
			||||||
 | 
					      this.width = width
 | 
				
			||||||
 | 
					      this.hiprintTemplate = hiprintTemplate
 | 
				
			||||||
 | 
					      this.printData = printData
 | 
				
			||||||
 | 
					      console.log(hiprintTemplate)
 | 
				
			||||||
 | 
					      console.log(printData)
 | 
				
			||||||
 | 
					      setTimeout(() => {
 | 
				
			||||||
 | 
					        // eslint-disable-next-line no-undef
 | 
				
			||||||
 | 
					        $('#preview_content').html(hiprintTemplate.getHtml(printData))
 | 
				
			||||||
 | 
					        this.spinning = false
 | 
				
			||||||
 | 
					      }, 500)
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    print() {
 | 
				
			||||||
 | 
					      this.waitShowPrinter = true
 | 
				
			||||||
 | 
					      this.hiprintTemplate.print(this.printData, {}, {
 | 
				
			||||||
 | 
					        callback: () => {
 | 
				
			||||||
 | 
					          console.log('callback')
 | 
				
			||||||
 | 
					          this.waitShowPrinter = false
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    toPdf() {
 | 
				
			||||||
 | 
					      this.hiprintTemplate.toPdf({}, '打印预览')
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<!-- <style lang="less" scoped>
 | 
				
			||||||
 | 
					/deep/ .ant-modal-body {
 | 
				
			||||||
 | 
					  padding: 0px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/deep/ .ant-modal-content {
 | 
				
			||||||
 | 
					  margin-bottom: 24px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style> -->
 | 
				
			||||||
							
								
								
									
										90
									
								
								src/views/base/custom/print-data.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										90
									
								
								src/views/base/custom/print-data.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										447
									
								
								src/views/base/custom/providers.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										447
									
								
								src/views/base/custom/providers.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,447 @@
 | 
				
			|||||||
 | 
					/* eslint-disable */
 | 
				
			||||||
 | 
					import {hiprint} from 'vue-plugin-hiprint'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* eslint-disable */
 | 
				
			||||||
 | 
					// import {hiprint} from '../../index'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 自定义设计元素1
 | 
				
			||||||
 | 
					export const aProvider = function (ops) {
 | 
				
			||||||
 | 
					  var addElementTypes = function (context) {
 | 
				
			||||||
 | 
					    context.removePrintElementTypes("aProviderModule");
 | 
				
			||||||
 | 
					    context.addPrintElementTypes(
 | 
				
			||||||
 | 
					      "aProviderModule",
 | 
				
			||||||
 | 
					      [
 | 
				
			||||||
 | 
					        new hiprint.PrintElementTypeGroup("平台", [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.header', title: '单据表头', data: '单据表头', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              testData: '单据表头',
 | 
				
			||||||
 | 
					              height: 17,
 | 
				
			||||||
 | 
					              fontSize: 16.5,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "center",
 | 
				
			||||||
 | 
					              hideTitle: true
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.type', title: '单据类型', data: '单据类型', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              testData: '单据类型',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 15,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "center",
 | 
				
			||||||
 | 
					              hideTitle: true
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.order', title: '订单编号', data: 'XS888888888', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'orderId',
 | 
				
			||||||
 | 
					              testData: 'XS888888888',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 6.75,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "left",
 | 
				
			||||||
 | 
					              textContentVerticalAlign: "middle"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.date', title: '业务日期', data: '2020-01-01', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'date',
 | 
				
			||||||
 | 
					              testData: '2020-01-01',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 6.75,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "left",
 | 
				
			||||||
 | 
					              textContentVerticalAlign: "middle"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.barcode', title: '条形码', data: 'XS888888888', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'barcode',
 | 
				
			||||||
 | 
					              testData: 'XS888888888',
 | 
				
			||||||
 | 
					              height: 32,
 | 
				
			||||||
 | 
					              fontSize: 12,
 | 
				
			||||||
 | 
					              lineHeight: 18,
 | 
				
			||||||
 | 
					              textType: "barcode"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.qrcode', title: '二维码', data: 'XS888888888', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'qrcode',
 | 
				
			||||||
 | 
					              testData: 'XS888888888',
 | 
				
			||||||
 | 
					              height: 32,
 | 
				
			||||||
 | 
					              fontSize: 12,
 | 
				
			||||||
 | 
					              lineHeight: 18,
 | 
				
			||||||
 | 
					              textType: "qrcode"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.platform', title: '平台名称', data: '平台名称', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              testData: '平台名称',
 | 
				
			||||||
 | 
					              height: 17,
 | 
				
			||||||
 | 
					              fontSize: 16.5,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "center",
 | 
				
			||||||
 | 
					              hideTitle: true
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {tid: 'aProviderModule.logo', title: 'Logo', data: '', type: 'image'},
 | 
				
			||||||
 | 
					        ]),
 | 
				
			||||||
 | 
					        new hiprint.PrintElementTypeGroup("库管", [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.creater', title: '制单人', data: '李四', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'creater',
 | 
				
			||||||
 | 
					              testData: '李四',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 6.75,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "left",
 | 
				
			||||||
 | 
					              textContentVerticalAlign: "middle"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.printDate', title: '打印时间', data: '2022-01-01 09:00', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'printDate',
 | 
				
			||||||
 | 
					              testData: '2022-01-01 09:00',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 6.75,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "left",
 | 
				
			||||||
 | 
					              textContentVerticalAlign: "middle"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.signer', title: '库管签字', data: '', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              title: '库管签字:',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 6.75,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "left",
 | 
				
			||||||
 | 
					              textContentVerticalAlign: "middle"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        ]),
 | 
				
			||||||
 | 
					        new hiprint.PrintElementTypeGroup("表格/其他", [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.table', title: '订单数据',
 | 
				
			||||||
 | 
					            type: 'table',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'table',
 | 
				
			||||||
 | 
					              tableHeaderRepeat: 'first',
 | 
				
			||||||
 | 
					              tableFooterRepeat: 'last',
 | 
				
			||||||
 | 
					              fields: [
 | 
				
			||||||
 | 
					                {text: '名称', field: 'NAME'},
 | 
				
			||||||
 | 
					                {text: '数量', field: 'SL'},
 | 
				
			||||||
 | 
					                {text: '规格', field: 'GG'},
 | 
				
			||||||
 | 
					                {text: '条码', field: 'TM'},
 | 
				
			||||||
 | 
					                {text: '单价', field: 'DJ'},
 | 
				
			||||||
 | 
					                {text: '金额', field: 'JE'},
 | 
				
			||||||
 | 
					              ],
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            editable: true,
 | 
				
			||||||
 | 
					            columnDisplayEditable: true,//列显示是否能编辑
 | 
				
			||||||
 | 
					            columnDisplayIndexEditable: true,//列顺序显示是否能编辑
 | 
				
			||||||
 | 
					            columnTitleEditable: true,//列标题是否能编辑
 | 
				
			||||||
 | 
					            columnResizable: true, //列宽是否能调整
 | 
				
			||||||
 | 
					            columnAlignEditable: true,//列对齐是否调整
 | 
				
			||||||
 | 
					            isEnableEditField: true, //编辑字段
 | 
				
			||||||
 | 
					            isEnableContextMenu: true, //开启右键菜单 默认true
 | 
				
			||||||
 | 
					            isEnableInsertRow: true, //插入行
 | 
				
			||||||
 | 
					            isEnableDeleteRow: true, //删除行
 | 
				
			||||||
 | 
					            isEnableInsertColumn: true, //插入列
 | 
				
			||||||
 | 
					            isEnableDeleteColumn: true, //删除列
 | 
				
			||||||
 | 
					            isEnableMergeCell: true, //合并单元格
 | 
				
			||||||
 | 
					            columns: [
 | 
				
			||||||
 | 
					              [
 | 
				
			||||||
 | 
					                {title: '名称', align: 'center', field: 'NAME', width: 150},
 | 
				
			||||||
 | 
					                {title: '数量', align: 'center', field: 'SL', width: 80},
 | 
				
			||||||
 | 
					                {title: '规格', align: 'center', field: 'GG', width: 80, checked: false},
 | 
				
			||||||
 | 
					                {title: '条码', align: 'center', field: 'TM', width: 100, checked: false},
 | 
				
			||||||
 | 
					                {title: '单价', align: 'center', field: 'DJ', width: 100},
 | 
				
			||||||
 | 
					                {title: '金额', align: 'center', field: 'JE', width: 100, checked: false},
 | 
				
			||||||
 | 
					              ],
 | 
				
			||||||
 | 
					            ],
 | 
				
			||||||
 | 
					            rowsColumnsMerge: function (data, col, index) {
 | 
				
			||||||
 | 
					              // 返回一个数组,参数一为行(rowspan)合并数,参数二为列(colspan)合并数, 被合并的行或者列值设为0
 | 
				
			||||||
 | 
					              if (index == 0) {
 | 
				
			||||||
 | 
					                return [1, data.INDEX % 2 == 1 ? 2 : 1]
 | 
				
			||||||
 | 
					              } else if (index > 0 && index < 2) {
 | 
				
			||||||
 | 
					                return [data.INDEX % 2 == 1 ? 0 : 1, 1]
 | 
				
			||||||
 | 
					              } else {
 | 
				
			||||||
 | 
					                return [data.INDEX % 2 == 1 ? 2 : 0, 1]
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            footerFormatter: function (options, rows, data, currentPageGridRowsData) {
 | 
				
			||||||
 | 
					              if (data && data['totalCap']) {
 | 
				
			||||||
 | 
					                return `<td style="padding:0 10px" colspan="100">${'应收金额大写: ' + data['totalCap']}</td>`
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					              return '<td style="padding:0 10px" colspan="100">应收金额大写: </td>'
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {tid: 'aProviderModule.customText', title: '文本', customText: '自定义文本', custom: true, type: 'text'},
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.longText', title: '长文本', type: 'longText', options: {
 | 
				
			||||||
 | 
					              field: 'test.longText',
 | 
				
			||||||
 | 
					              width: 200,
 | 
				
			||||||
 | 
					              testData: '长文本分页/不分页测试'
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        ]),
 | 
				
			||||||
 | 
					        new hiprint.PrintElementTypeGroup("辅助", [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.hline',
 | 
				
			||||||
 | 
					            title: '横线',
 | 
				
			||||||
 | 
					            type: 'hline'
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.vline',
 | 
				
			||||||
 | 
					            title: '竖线',
 | 
				
			||||||
 | 
					            type: 'vline'
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.rect',
 | 
				
			||||||
 | 
					            title: '矩形',
 | 
				
			||||||
 | 
					            type: 'rect'
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.oval',
 | 
				
			||||||
 | 
					            title: '椭圆',
 | 
				
			||||||
 | 
					            type: 'oval'
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.barcode',
 | 
				
			||||||
 | 
					            title: '条形码',
 | 
				
			||||||
 | 
					            type: 'barcode',
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'aProviderModule.qrcode',
 | 
				
			||||||
 | 
					            title: '二维码',
 | 
				
			||||||
 | 
					            type: 'qrcode',
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        ])
 | 
				
			||||||
 | 
					      ]
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					  return {
 | 
				
			||||||
 | 
					    addElementTypes: addElementTypes
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 自定义设计元素2
 | 
				
			||||||
 | 
					export const bProvider = function (ops) {
 | 
				
			||||||
 | 
					  var addElementTypes = function (context) {
 | 
				
			||||||
 | 
					    context.removePrintElementTypes("bProviderModule");
 | 
				
			||||||
 | 
					    context.addPrintElementTypes(
 | 
				
			||||||
 | 
					      "bProviderModule",
 | 
				
			||||||
 | 
					      [
 | 
				
			||||||
 | 
					        new hiprint.PrintElementTypeGroup("常规", [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.header', title: '单据表头', data: '单据表头', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              testData: '单据表头',
 | 
				
			||||||
 | 
					              height: 17,
 | 
				
			||||||
 | 
					              fontSize: 16.5,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "center",
 | 
				
			||||||
 | 
					              hideTitle: true
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.type', title: '单据类型', data: '单据类型', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              testData: '单据类型',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 15,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "center",
 | 
				
			||||||
 | 
					              hideTitle: true
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.order', title: '订单编号', data: 'XS888888888', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'orderId',
 | 
				
			||||||
 | 
					              testData: 'XS888888888',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 6.75,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "left",
 | 
				
			||||||
 | 
					              textContentVerticalAlign: "middle"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.date', title: '业务日期', data: '2020-01-01', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'date',
 | 
				
			||||||
 | 
					              testData: '2020-01-01',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 6.75,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "left",
 | 
				
			||||||
 | 
					              textContentVerticalAlign: "middle"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.barcode', title: '条形码', data: 'XS888888888', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'barcode',
 | 
				
			||||||
 | 
					              testData: 'XS888888888',
 | 
				
			||||||
 | 
					              height: 32,
 | 
				
			||||||
 | 
					              fontSize: 12,
 | 
				
			||||||
 | 
					              lineHeight: 18,
 | 
				
			||||||
 | 
					              textType: "barcode"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.qrcode', title: '二维码', data: 'XS888888888', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'qrcode',
 | 
				
			||||||
 | 
					              testData: 'XS888888888',
 | 
				
			||||||
 | 
					              height: 32,
 | 
				
			||||||
 | 
					              fontSize: 12,
 | 
				
			||||||
 | 
					              lineHeight: 18,
 | 
				
			||||||
 | 
					              textType: "qrcode"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.platform', title: '平台名称', data: '平台名称', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              testData: '平台名称',
 | 
				
			||||||
 | 
					              height: 17,
 | 
				
			||||||
 | 
					              fontSize: 16.5,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "center",
 | 
				
			||||||
 | 
					              hideTitle: true
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {tid: 'bProviderModule.image',  title: 'Logo', data: 'data: image/png;base64iVBORw0KGgoAAAANSUhEUgAAAGQAAABkCAYAAABw4pVUAAAHVklEQVR4nO2dT2wUVRzHv2/2T5eSAlvFilwgQUH+eLACaUxEiJLAxdh44MDZi2ChUIrSFtoCgbbSP4GDdwgeEA8kRTAI0iIGBL1ITLxgLAlCsCKBYndnx7zd35pl2+7On/de387OJ9l00515/z7z/szMmzfs7869mD0yCjw2gZAB4VhAiln4/dUaRGdU18aOnzw9dn24ioGJj0soFsJr1z2yNm+qN2/fvRFL8XyMYqTmFfxZ+TwMc1xKDsL/f2Ms8xGeLwuIRpCKx99MHf/i4uPrw5GQ9jIAfsCMXfw2HkuOX03Wb1qLh4+uIGFJjzecPoS5iEhUTg1hDMaM2GuRk6cGMTQUCYmPQQq86CMAkkPDkQirGAzXf7Du34ejN9IHmETCRjQGPL6D+4NnYDEJDQmXbaY6on/dm2Vm/jHdZe0Almm6Ll+YNQbzasX7765BNHI1o0sOYRghwExg7MG9dDQSiqsdwHuZmlFKMjLwQ3QcFtjlSxHTenLO3Lp7vfU09AOS41Ka+HC6CjIDIaqmguvIPgBtIgOcDhjVlMTQtarKOScumR/teCdpxoeNZGJCapjFt7Rcywrb2MYtnQBatCpZTzCkYCF+5suKRXf+6EvOmv0GSzwrhB/QpmGkBYZSpqvIZAlp8ZeMLFwKUH3z2gqWyd/+3F/5b1yRQQMCN8gQspeaKt+SAItSCxCiPjIjhDEkjRAMxmCZSbgZkYke537qdxl57KM8C0OkkD0ADohMXIlwgPIuBFFC9uS3p2XGflFSRAgpdxlZeBl84jUQr0ImjDTKGWZZBwE0eCkCL0J20UgjgGCwEDHNPjB86PbiilshfGRxOBCRD0tLCSWTnzMLO9yE4EbIzjIdTdmGpc8/rB4qK0c4FcKbqe7pyWZJ0k1lZhsnQnZq3EzV00dHDjupKXaFNGtcM7YA+Io+WzRIz2R0UxkWxY6QJgCHlCbfPlzAsZytj2ks5RCVZUGKCdkOoEt+Wl3RkCcjyzGv5wIS6aIynZJCQni7d0TTjPFaMFDg9wGNa8qRQn3KVEI+1rjPmKpm5KNzTemmMp7AZEK2AehXmz7bbC1SM/IZoH10pJ/K+hnyhXBrvZpmoBHAURf7HaV9daQ3v6Zk7hhWVr4AYDOAzzRNeKPHAyW7r459Yj/deUynMcyqqpY9/fXW+RTwkiF/ms5pADcd7nMbwAkBcfMM3wOwwOF+rys46TxCt+T72d2NG0YSg2fnC58ANDkbAZyVH41QNgAYVBTXNiMxeLYG6qawvagmGqGoTHOfwcAe6T8TvWwYlTC7OsALgRDNCIRoRiBEMwIhmhEI0YxAiGYEQjRDtZCY9iUyEaVpVi3kvuL4RKA0zSqF8Ad5TimMTxSnKO1KUCWEZ6hDVaYk0KFKigohbSUuI0uHiieKZQtp89kM+U7ZUmQKafHp4wpSH/eWJaTT5zPkD8g62GQI8cXqDTZok/HEsWgh+3Of2y4D2kU/0idKyEOaJdgqKLxSotXlfLFJESXkicKZGTrys6g0iRIyD8AvAFYLCq+UWC1yACOyD+Hrf1wAUCcwTN2pozzXiEqn6E59JoBvANQKDldHaimvM0WmTcawlydw2Oc1pY7yKFQGJJ4YxqiTXyEp/OlkBeVNyn0SmZdO5gC47rOOfjXlaY6sCGRfXKwA8LVP+pRaykuFzEhUXH7nR9P3AFYqiEsWKykP0mpGFlU3qKI0IlmlKD6RrKK0R1VEpvIW7uwSHXnVUdqVoHqSwz+K4xOB0jQH87I0IxCiGYEQzQiEaEYgRDMCIZoRCNGMQIhmBEI0gwuJK0xScKZemHiY1mzqUxThYgBLHO7zQOAzGnMBPOdwn8WC4rbDNjaSWVajQaEUp9wBsB7ALY/hLAVwHsB89VmwRXrhuGwf0q/xIl/z6f6105qVyxIKQ1cZjdlV/HI79V6N1yjk/dxlAMtc7LuM9lXZVzqhIXdxtvxR1kCxZUynkbl0o2ihgyQspH3mapqn7flrSE427O3TuKbwGZI/AlhuY9vltO08Belyw6T99lTnIQN2VmGeJqppskGhpfoW0DbVmuahaarVVQudGPZo3tH/RCOnfJbSbzp34D1T/VjsTL3X6esWFMJngJwDsCgnykX0P+mzQ1yyq9jqqtnzkGI0a7wgPz9pfJm+/6ZxB77bzus+7L7pkwdkarr8OBdwJee7jjQVaqZysVtDsuwK3j3lmGYnb5hwerW3S+PRl440OX3dh5vL7z0iXzXqY/bYbaZycXs/5KDdV/iUKc1URo7xcoOqq0yfui1Gq5e3EoUava1qzS/aJQGs8xKIj2jx+gCoVyGcoUBKGs8yIEgIAiliZEDwJAehL3ovIYS+2F9UDckyRH/fFhmoxuwTvdaJaCGc7+gyi9+br1YZSzTJEAIaffHrZG/JCFwDpK16JEsI5yK9uMdvzVe7zAUxZQrhXKKBwxqZkSikQ8aiZbnIFgKS4oea0i5bBhQJgQ+kKJEBhUJAUkqxo+cduJqVrQH8B6xBgBhvJFNDAAAAAElFTkSuQmCC', type: 'image',   options: {
 | 
				
			||||||
 | 
					            src: 'data: image/png;base64iVBORw0KGgoAAAANSUhEUgAAAGQAAABkCAYAAABw4pVUAAAHVklEQVR4nO2dT2wUVRzHv2/2T5eSAlvFilwgQUH+eLACaUxEiJLAxdh44MDZi2ChUIrSFtoCgbbSP4GDdwgeEA8kRTAI0iIGBL1ITLxgLAlCsCKBYndnx7zd35pl2+7On/de387OJ9l00515/z7z/szMmzfs7869mD0yCjw2gZAB4VhAiln4/dUaRGdU18aOnzw9dn24ioGJj0soFsJr1z2yNm+qN2/fvRFL8XyMYqTmFfxZ+TwMc1xKDsL/f2Ms8xGeLwuIRpCKx99MHf/i4uPrw5GQ9jIAfsCMXfw2HkuOX03Wb1qLh4+uIGFJjzecPoS5iEhUTg1hDMaM2GuRk6cGMTQUCYmPQQq86CMAkkPDkQirGAzXf7Du34ejN9IHmETCRjQGPL6D+4NnYDEJDQmXbaY6on/dm2Vm/jHdZe0Almm6Ll+YNQbzasX7765BNHI1o0sOYRghwExg7MG9dDQSiqsdwHuZmlFKMjLwQ3QcFtjlSxHTenLO3Lp7vfU09AOS41Ka+HC6CjIDIaqmguvIPgBtIgOcDhjVlMTQtarKOScumR/teCdpxoeNZGJCapjFt7Rcywrb2MYtnQBatCpZTzCkYCF+5suKRXf+6EvOmv0GSzwrhB/QpmGkBYZSpqvIZAlp8ZeMLFwKUH3z2gqWyd/+3F/5b1yRQQMCN8gQspeaKt+SAItSCxCiPjIjhDEkjRAMxmCZSbgZkYke537qdxl57KM8C0OkkD0ADohMXIlwgPIuBFFC9uS3p2XGflFSRAgpdxlZeBl84jUQr0ImjDTKGWZZBwE0eCkCL0J20UgjgGCwEDHNPjB86PbiilshfGRxOBCRD0tLCSWTnzMLO9yE4EbIzjIdTdmGpc8/rB4qK0c4FcKbqe7pyWZJ0k1lZhsnQnZq3EzV00dHDjupKXaFNGtcM7YA+Io+WzRIz2R0UxkWxY6QJgCHlCbfPlzAsZytj2ks5RCVZUGKCdkOoEt+Wl3RkCcjyzGv5wIS6aIynZJCQni7d0TTjPFaMFDg9wGNa8qRQn3KVEI+1rjPmKpm5KNzTemmMp7AZEK2AehXmz7bbC1SM/IZoH10pJ/K+hnyhXBrvZpmoBHAURf7HaV9daQ3v6Zk7hhWVr4AYDOAzzRNeKPHAyW7r459Yj/deUynMcyqqpY9/fXW+RTwkiF/ms5pADcd7nMbwAkBcfMM3wOwwOF+rys46TxCt+T72d2NG0YSg2fnC58ANDkbAZyVH41QNgAYVBTXNiMxeLYG6qawvagmGqGoTHOfwcAe6T8TvWwYlTC7OsALgRDNCIRoRiBEMwIhmhEI0YxAiGYEQjRDtZCY9iUyEaVpVi3kvuL4RKA0zSqF8Ad5TimMTxSnKO1KUCWEZ6hDVaYk0KFKigohbSUuI0uHiieKZQtp89kM+U7ZUmQKafHp4wpSH/eWJaTT5zPkD8g62GQI8cXqDTZok/HEsWgh+3Of2y4D2kU/0idKyEOaJdgqKLxSotXlfLFJESXkicKZGTrys6g0iRIyD8AvAFYLCq+UWC1yACOyD+Hrf1wAUCcwTN2pozzXiEqn6E59JoBvANQKDldHaimvM0WmTcawlydw2Oc1pY7yKFQGJJ4YxqiTXyEp/OlkBeVNyn0SmZdO5gC47rOOfjXlaY6sCGRfXKwA8LVP+pRaykuFzEhUXH7nR9P3AFYqiEsWKykP0mpGFlU3qKI0IlmlKD6RrKK0R1VEpvIW7uwSHXnVUdqVoHqSwz+K4xOB0jQH87I0IxCiGYEQzQiEaEYgRDMCIZoRCNGMQIhmBEI0gwuJK0xScKZemHiY1mzqUxThYgBLHO7zQOAzGnMBPOdwn8WC4rbDNjaSWVajQaEUp9wBsB7ALY/hLAVwHsB89VmwRXrhuGwf0q/xIl/z6f6105qVyxIKQ1cZjdlV/HI79V6N1yjk/dxlAMtc7LuM9lXZVzqhIXdxtvxR1kCxZUynkbl0o2ihgyQspH3mapqn7flrSE427O3TuKbwGZI/AlhuY9vltO08Belyw6T99lTnIQN2VmGeJqppskGhpfoW0DbVmuahaarVVQudGPZo3tH/RCOnfJbSbzp34D1T/VjsTL3X6esWFMJngJwDsCgnykX0P+mzQ1yyq9jqqtnzkGI0a7wgPz9pfJm+/6ZxB77bzus+7L7pkwdkarr8OBdwJee7jjQVaqZysVtDsuwK3j3lmGYnb5hwerW3S+PRl440OX3dh5vL7z0iXzXqY/bYbaZycXs/5KDdV/iUKc1URo7xcoOqq0yfui1Gq5e3EoUava1qzS/aJQGs8xKIj2jx+gCoVyGcoUBKGs8yIEgIAiliZEDwJAehL3ovIYS+2F9UDckyRH/fFhmoxuwTvdaJaCGc7+gyi9+br1YZSzTJEAIaffHrZG/JCFwDpK16JEsI5yK9uMdvzVe7zAUxZQrhXKKBwxqZkSikQ8aiZbnIFgKS4oea0i5bBhQJgQ+kKJEBhUJAUkqxo+cduJqVrQH8B6xBgBhvJFNDAAAAAElFTkSuQmCC',
 | 
				
			||||||
 | 
					            fit: 'none'
 | 
				
			||||||
 | 
					            }},
 | 
				
			||||||
 | 
					        ]),
 | 
				
			||||||
 | 
					        new hiprint.PrintElementTypeGroup("客户", [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.khname', title: '客户名称', data: '高级客户', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'name',
 | 
				
			||||||
 | 
					              testData: '高级客户',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 6.75,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "left",
 | 
				
			||||||
 | 
					              textContentVerticalAlign: "middle"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.tel', title: '客户电话', data: '18888888888', type: 'text',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'tel',
 | 
				
			||||||
 | 
					              testData: '18888888888',
 | 
				
			||||||
 | 
					              height: 16,
 | 
				
			||||||
 | 
					              fontSize: 6.75,
 | 
				
			||||||
 | 
					              fontWeight: "700",
 | 
				
			||||||
 | 
					              textAlign: "left",
 | 
				
			||||||
 | 
					              textContentVerticalAlign: "middle"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        ]),
 | 
				
			||||||
 | 
					        new hiprint.PrintElementTypeGroup("表格/其他", [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.table', title: '订单数据',
 | 
				
			||||||
 | 
					            type: 'table',
 | 
				
			||||||
 | 
					            options: {
 | 
				
			||||||
 | 
					              field: 'table',
 | 
				
			||||||
 | 
					              fields: [
 | 
				
			||||||
 | 
					                {text: '名称', field: 'NAME'},
 | 
				
			||||||
 | 
					                {text: '数量', field: 'SL'},
 | 
				
			||||||
 | 
					                {text: '规格', field: 'GG'},
 | 
				
			||||||
 | 
					                {text: '条码', field: 'TM'},
 | 
				
			||||||
 | 
					                {text: '单价', field: 'DJ'},
 | 
				
			||||||
 | 
					                {text: '金额', field: 'JE'},
 | 
				
			||||||
 | 
					                {text: '备注', field: 'DETAIL'},
 | 
				
			||||||
 | 
					              ],
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            editable: true,
 | 
				
			||||||
 | 
					            columnDisplayEditable: true,//列显示是否能编辑
 | 
				
			||||||
 | 
					            columnDisplayIndexEditable: true,//列顺序显示是否能编辑
 | 
				
			||||||
 | 
					            columnTitleEditable: true,//列标题是否能编辑
 | 
				
			||||||
 | 
					            columnResizable: true, //列宽是否能调整
 | 
				
			||||||
 | 
					            columnAlignEditable: true,//列对齐是否调整
 | 
				
			||||||
 | 
					            columns: [
 | 
				
			||||||
 | 
					              [
 | 
				
			||||||
 | 
					                {title: '名称', align: 'center', field: 'NAME', width: 100},
 | 
				
			||||||
 | 
					                {title: '数量', align: 'center', field: 'SL', width: 100},
 | 
				
			||||||
 | 
					                {title: '条码', align: 'center', field: 'TM', width: 100},
 | 
				
			||||||
 | 
					                {title: '规格', align: 'center', field: 'GG', width: 100},
 | 
				
			||||||
 | 
					                {title: '单价', align: 'center', field: 'DJ', width: 100},
 | 
				
			||||||
 | 
					                {title: '金额', align: 'center', field: 'JE', width: 100},
 | 
				
			||||||
 | 
					                {title: '备注', align: 'center', field: 'DETAIL', width: 100},
 | 
				
			||||||
 | 
					              ]
 | 
				
			||||||
 | 
					            ],
 | 
				
			||||||
 | 
					            footerFormatter: function (options, rows, data, currentPageGridRowsData) {
 | 
				
			||||||
 | 
					              if (data && data['totalCap']) {
 | 
				
			||||||
 | 
					                return `<td style="padding:0 10px" colspan="100">${'应收金额大写: ' + data['totalCap']}</td>`
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					              return '<td style="padding:0 10px" colspan="100">应收金额大写: </td>'
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {tid: 'bProviderModule.customText', title: '文本', customText: '自定义文本', custom: true, type: 'text'},
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.longText', title: '长文本', type: 'longText', options: {
 | 
				
			||||||
 | 
					              field: 'test.longText',
 | 
				
			||||||
 | 
					              width: 200,
 | 
				
			||||||
 | 
					              testData: '长文本分页/不分页测试'
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        ]),
 | 
				
			||||||
 | 
					        new hiprint.PrintElementTypeGroup("辅助", [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.hline',
 | 
				
			||||||
 | 
					            title: '横线',
 | 
				
			||||||
 | 
					            type: 'hline'
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.vline',
 | 
				
			||||||
 | 
					            title: '竖线',
 | 
				
			||||||
 | 
					            type: 'vline'
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.rect',
 | 
				
			||||||
 | 
					            title: '矩形',
 | 
				
			||||||
 | 
					            type: 'rect'
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            tid: 'bProviderModule.oval',
 | 
				
			||||||
 | 
					            title: '椭圆',
 | 
				
			||||||
 | 
					            type: 'oval'
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        ])
 | 
				
			||||||
 | 
					      ]
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					  return {
 | 
				
			||||||
 | 
					    addElementTypes: addElementTypes
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// type: 1供货商 2经销商
 | 
				
			||||||
 | 
					export default [{
 | 
				
			||||||
 | 
					  name: 'A设计',
 | 
				
			||||||
 | 
					  value: 'aProviderModule',
 | 
				
			||||||
 | 
					  type: 1,
 | 
				
			||||||
 | 
					  f: aProvider()
 | 
				
			||||||
 | 
					}, {
 | 
				
			||||||
 | 
					  name: 'B设计',
 | 
				
			||||||
 | 
					  value: 'bProviderModule',
 | 
				
			||||||
 | 
					  type: 2,
 | 
				
			||||||
 | 
					  f: bProvider()
 | 
				
			||||||
 | 
					}]
 | 
				
			||||||
@@ -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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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>
 | 
				
			||||||
							
								
								
									
										100
									
								
								src/views/base/mixins/basic-add.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								src/views/base/mixins/basic-add.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,100 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2022-08-24 11:19:43
 | 
				
			||||||
 | 
					 * @LastEditors: zwq
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-08-03 14:21:04
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    /* eslint-disable */
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      urlOptions: {
 | 
				
			||||||
 | 
					        createURL: '',
 | 
				
			||||||
 | 
					        updateURL: '',
 | 
				
			||||||
 | 
					        infoURL: '',
 | 
				
			||||||
 | 
					        codeURL: '',
 | 
				
			||||||
 | 
					        getOption: false,
 | 
				
			||||||
 | 
					        isGetCode: false,
 | 
				
			||||||
 | 
					        optionArrUrl: [],
 | 
				
			||||||
 | 
					        optionArr: {}
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      visible: false,
 | 
				
			||||||
 | 
					      setData: false
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  created() {
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  activated() {
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    init(id) {
 | 
				
			||||||
 | 
					      this.dataForm.id = id || "";
 | 
				
			||||||
 | 
					      this.visible = true;
 | 
				
			||||||
 | 
					      if (this.urlOptions.getOption) {
 | 
				
			||||||
 | 
					        this.getArr()
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.$nextTick(() => {
 | 
				
			||||||
 | 
					        this.$refs["dataForm"].resetFields();
 | 
				
			||||||
 | 
					        if (this.dataForm.id) {
 | 
				
			||||||
 | 
					          this.urlOptions.infoURL(id).then(response => {
 | 
				
			||||||
 | 
					            this.dataForm = response.data;
 | 
				
			||||||
 | 
					            if (this.setData) {
 | 
				
			||||||
 | 
					              this.setDataForm()
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          if (this.urlOptions.isGetCode) {
 | 
				
			||||||
 | 
					            this.getCode()
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
							getCode() {
 | 
				
			||||||
 | 
								this.urlOptions.codeURL()
 | 
				
			||||||
 | 
									.then(({ data: res }) => {
 | 
				
			||||||
 | 
										this.dataForm.code = res;
 | 
				
			||||||
 | 
									})
 | 
				
			||||||
 | 
									.catch(() => {});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					    getArr() {
 | 
				
			||||||
 | 
					      const params = {
 | 
				
			||||||
 | 
					        pageSize: 100,
 | 
				
			||||||
 | 
					        pageNo: 1,
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.urlOptions.optionArrUrl.forEach((item, index) => {
 | 
				
			||||||
 | 
					        item(params).then(({ data: res }) => {
 | 
				
			||||||
 | 
					          this.$set(this.urlOptions.optionArr, `arr${index}`, res.list)
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					          .catch(() => {
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 表单提交
 | 
				
			||||||
 | 
					    dataFormSubmit() {
 | 
				
			||||||
 | 
					      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");
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    formClear() {
 | 
				
			||||||
 | 
					      this.$refs.dataForm.resetFields()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										168
									
								
								src/views/base/mixins/basic-page.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								src/views/base/mixins/basic-page.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,168 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2022-08-24 11:19:43
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-09-21 16:02:07
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    /* eslint-disable */
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      urlOptions: {
 | 
				
			||||||
 | 
					        getDataListURL: '',
 | 
				
			||||||
 | 
					        deleteURL: '',
 | 
				
			||||||
 | 
					        statusUrl: '',
 | 
				
			||||||
 | 
					        exportURL: ''
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      tableData: [],
 | 
				
			||||||
 | 
					      listQuery: {
 | 
				
			||||||
 | 
					        pageSize: 10,
 | 
				
			||||||
 | 
					        pageNo: 1,
 | 
				
			||||||
 | 
					        total: 1,
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      exportLoading: false,
 | 
				
			||||||
 | 
					      dataListLoading: false,
 | 
				
			||||||
 | 
					      addOrEditTitle: '',
 | 
				
			||||||
 | 
					      addOrUpdateVisible: false,
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  created() {
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.getDataList()
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    // 获取数据列表
 | 
				
			||||||
 | 
					    getDataList() {
 | 
				
			||||||
 | 
					      this.dataListLoading = true;
 | 
				
			||||||
 | 
					      this.urlOptions.getDataListURL(this.listQuery).then(response => {
 | 
				
			||||||
 | 
					        this.tableData = response.data.list;
 | 
				
			||||||
 | 
					        this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
					        this.dataListLoading = false;
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 每页数
 | 
				
			||||||
 | 
					    sizeChangeHandle(val) {
 | 
				
			||||||
 | 
					      this.listQuery.pageSize = val;
 | 
				
			||||||
 | 
					      this.listQuery.pageNo = 1;
 | 
				
			||||||
 | 
					      this.getDataList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 当前页
 | 
				
			||||||
 | 
					    currentChangeHandle(val) {
 | 
				
			||||||
 | 
					      this.listQuery.pageNo = val;
 | 
				
			||||||
 | 
					      this.getDataList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 新增 / 修改
 | 
				
			||||||
 | 
					    addOrUpdateHandle(id) {
 | 
				
			||||||
 | 
					      this.addOrUpdateVisible = true;
 | 
				
			||||||
 | 
					      this.$nextTick(() => {
 | 
				
			||||||
 | 
					        this.$refs.addOrUpdate.init(id);
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    cancel(id) {
 | 
				
			||||||
 | 
					      this.$refs["popover-" + id].showPopper = false;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    //改变状态
 | 
				
			||||||
 | 
					    changeStatus(id) {
 | 
				
			||||||
 | 
					      this.$http
 | 
				
			||||||
 | 
					        .post(this.urlOptions.statusUrl, { id })
 | 
				
			||||||
 | 
					        .then(({ data: res }) => {
 | 
				
			||||||
 | 
					          if (res.code !== 0) {
 | 
				
			||||||
 | 
					            return this.$message.error(res.msg);
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					          this.$refs["popover-" + id].showPopper = false;
 | 
				
			||||||
 | 
					          this.$message({
 | 
				
			||||||
 | 
					            message: this.$t("prompt.success"),
 | 
				
			||||||
 | 
					            type: "success",
 | 
				
			||||||
 | 
					            duration: 500,
 | 
				
			||||||
 | 
					            onClose: () => {
 | 
				
			||||||
 | 
					              this.getDataList();
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        .catch(() => { });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    //tableBtn点击
 | 
				
			||||||
 | 
					    handleClick(val) {
 | 
				
			||||||
 | 
					      if (val.type === "edit") {
 | 
				
			||||||
 | 
					        this.addOrUpdateVisible = true;
 | 
				
			||||||
 | 
					        this.addOrEditTitle = "编辑";
 | 
				
			||||||
 | 
					        this.$nextTick(() => {
 | 
				
			||||||
 | 
					          this.$refs.addOrUpdate.init(val.data.id);
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      } else if (val.type === "delete") {
 | 
				
			||||||
 | 
					        this.deleteHandle(val.data.id, val.data.name, val.data._pageIndex)
 | 
				
			||||||
 | 
					      } else if (val.type === "change") {
 | 
				
			||||||
 | 
					        this.changeStatus(val.data.id)
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.otherMethods(val)
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 删除
 | 
				
			||||||
 | 
					    deleteHandle(id, name, index) {
 | 
				
			||||||
 | 
					      this.$confirm(`确定对${name ? '[名称=' + name + ']' : '[序号=' + index + ']'}进行删除操作?`, "提示", {
 | 
				
			||||||
 | 
					        confirmButtonText: "确定",
 | 
				
			||||||
 | 
					        cancelButtonText: "取消",
 | 
				
			||||||
 | 
					        type: "warning",
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					        .then(() => {
 | 
				
			||||||
 | 
					          this.urlOptions.deleteURL(id).then(({ data }) => {
 | 
				
			||||||
 | 
					            this.$message({
 | 
				
			||||||
 | 
					              message: "操作成功",
 | 
				
			||||||
 | 
					              type: "success",
 | 
				
			||||||
 | 
					              duration: 1500,
 | 
				
			||||||
 | 
					              onClose: () => {
 | 
				
			||||||
 | 
					                this.getDataList();
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        .catch(() => { });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    //search-bar点击
 | 
				
			||||||
 | 
					    buttonClick(val) {
 | 
				
			||||||
 | 
					      switch (val.btnName) {
 | 
				
			||||||
 | 
					        case "search":
 | 
				
			||||||
 | 
					          this.listQuery.xm1 = val.xm1;
 | 
				
			||||||
 | 
					          this.listQuery.xm2 = val.xm2;
 | 
				
			||||||
 | 
					          this.listQuery.pageNo = 1;
 | 
				
			||||||
 | 
					          this.getDataList();
 | 
				
			||||||
 | 
					          break;
 | 
				
			||||||
 | 
					        case "add":
 | 
				
			||||||
 | 
					          this.addOrEditTitle = '新增'
 | 
				
			||||||
 | 
					          this.addOrUpdateVisible = true;
 | 
				
			||||||
 | 
					          this.addOrUpdateHandle()
 | 
				
			||||||
 | 
					          break;
 | 
				
			||||||
 | 
					        default:
 | 
				
			||||||
 | 
					          console.log(val)
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleCancel() {
 | 
				
			||||||
 | 
					      this.$refs.addOrUpdate.formClear()
 | 
				
			||||||
 | 
					      this.addOrUpdateVisible = false
 | 
				
			||||||
 | 
					      this.addOrEditTitle = ''
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleConfirm() {
 | 
				
			||||||
 | 
					      this.$refs.addOrUpdate.dataFormSubmit()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    successSubmit() {
 | 
				
			||||||
 | 
					      this.handleCancel()
 | 
				
			||||||
 | 
					      this.getDataList()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    /** 导出按钮操作 */
 | 
				
			||||||
 | 
					    handleExport() {
 | 
				
			||||||
 | 
					      // 处理查询参数
 | 
				
			||||||
 | 
					      let params = { ...this.queryParams };
 | 
				
			||||||
 | 
					      params.pageNo = undefined;
 | 
				
			||||||
 | 
					      params.pageSize = undefined;
 | 
				
			||||||
 | 
					      this.$modal.confirm('是否确认导出所有数据项?').then(() => {
 | 
				
			||||||
 | 
					        this.exportLoading = true;
 | 
				
			||||||
 | 
					        return this.urlOptions.exportURL(params);
 | 
				
			||||||
 | 
					      }).then(response => {
 | 
				
			||||||
 | 
					        this.$download.excel(response, '工厂.xls');
 | 
				
			||||||
 | 
					        this.exportLoading = false;
 | 
				
			||||||
 | 
					      }).catch(() => { });
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										69
									
								
								src/views/base/mixins/code-filter.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								src/views/base/mixins/code-filter.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,69 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * @Date: 2020-12-29 16:49:28
 | 
				
			||||||
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-09-12 11:13:34
 | 
				
			||||||
 | 
					 * @FilePath: \basic-admin\src\filters\basicData\index.js
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const table = {
 | 
				
			||||||
 | 
					  lineStatus: {
 | 
				
			||||||
 | 
					    1: '生产中',
 | 
				
			||||||
 | 
					    2: '停止',
 | 
				
			||||||
 | 
					    3: '未知',
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  reportType: {
 | 
				
			||||||
 | 
					    1: '日',
 | 
				
			||||||
 | 
					    2: '周',
 | 
				
			||||||
 | 
					    3: '月'
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 日期格式化
 | 
				
			||||||
 | 
					export function parseTime(time, pattern) {
 | 
				
			||||||
 | 
					  if (arguments.length === 0 || !time) {
 | 
				
			||||||
 | 
					    return null
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  const format = pattern || '{y}-{m}-{d} {h}:{i}:{s}'
 | 
				
			||||||
 | 
					  let date
 | 
				
			||||||
 | 
					  if (typeof time === 'object') {
 | 
				
			||||||
 | 
					    date = time
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    if ((typeof time === 'string') && (/^[0-9]+$/.test(time))) {
 | 
				
			||||||
 | 
					      time = parseInt(time)
 | 
				
			||||||
 | 
					    } else if (typeof time === 'string') {
 | 
				
			||||||
 | 
					      time = time.replace(new RegExp(/-/gm), '/').replace('T', ' ').replace(new RegExp(/\.\d{3}/gm),'');
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    if ((typeof time === 'number') && (time.toString().length === 10)) {
 | 
				
			||||||
 | 
					      time = time * 1000
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    date = new Date(time)
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  const formatObj = {
 | 
				
			||||||
 | 
					    y: date.getFullYear(),
 | 
				
			||||||
 | 
					    m: date.getMonth() + 1,
 | 
				
			||||||
 | 
					    d: date.getDate(),
 | 
				
			||||||
 | 
					    h: date.getHours(),
 | 
				
			||||||
 | 
					    i: date.getMinutes(),
 | 
				
			||||||
 | 
					    s: date.getSeconds(),
 | 
				
			||||||
 | 
					    a: date.getDay()
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  const time_str = format.replace(/{([ymdhisa])+}/g, (result, key) => {
 | 
				
			||||||
 | 
					    let value = formatObj[key]
 | 
				
			||||||
 | 
					    // Note: getDay() returns 0 on Sunday
 | 
				
			||||||
 | 
					    if (key === 'a') {
 | 
				
			||||||
 | 
					      return ['日', '一', '二', '三', '四', '五', '六'][value]
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    if (result.length > 0 && value < 10) {
 | 
				
			||||||
 | 
					      value = '0' + value
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    return value || 0
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					  return time_str
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					export default function (dictTable) {
 | 
				
			||||||
 | 
					  return function (val) {
 | 
				
			||||||
 | 
					    return table?.[dictTable]?.[val]
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										65
									
								
								src/views/base/packagingPrintLog/SmallTitle.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/views/base/packagingPrintLog/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>
 | 
				
			||||||
							
								
								
									
										418
									
								
								src/views/base/packagingPrintLog/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										418
									
								
								src/views/base/packagingPrintLog/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,418 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2023-10-17 16:50:19
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-30 10:47:13
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <el-dialog :visible.sync="visible" :show-close="false" :wrapper-closable="false" width="40%">
 | 
				
			||||||
 | 
					    <small-title slot="title" :no-padding="true">
 | 
				
			||||||
 | 
					      {{ !dataForm.id ? '新增' : '编辑' }}
 | 
				
			||||||
 | 
					    </small-title>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <div class="content">
 | 
				
			||||||
 | 
					      <div class="visual-part">
 | 
				
			||||||
 | 
					        <el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="100px"
 | 
				
			||||||
 | 
					          @keyup.enter.native="dataFormSubmit">
 | 
				
			||||||
 | 
					          <el-row :gutter="20">
 | 
				
			||||||
 | 
					            <el-col :span="12">
 | 
				
			||||||
 | 
					              <el-form-item label="包装流水号" prop="packagingCode">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.packagingCode" clearable placeholder="请输入包装流水号" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					            <el-col :span="12">
 | 
				
			||||||
 | 
					              <el-form-item label="内容" prop="content">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.content" clearable placeholder="请输入内容" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					          </el-row>
 | 
				
			||||||
 | 
					          <el-row :gutter="20">
 | 
				
			||||||
 | 
					            <el-col :span="12">
 | 
				
			||||||
 | 
					              <el-form-item label="所属工单" prop="workOrderId">
 | 
				
			||||||
 | 
					                <el-select v-model="dataForm.workOrderId" style="width: 100%;" placeholder="请选择所属工单" clearable>
 | 
				
			||||||
 | 
					                  <el-option v-for="dict in workOrderList" :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="customerId">
 | 
				
			||||||
 | 
					                <el-select v-model="dataForm.customerId" style="width: 100%;" placeholder="请选择客户" clearable>
 | 
				
			||||||
 | 
					                  <el-option v-for="dict in customerList" :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="modelId">
 | 
				
			||||||
 | 
					                <el-select v-model="dataForm.modelId" style="width: 100%;" placeholder="请选择标签模板" clearable>
 | 
				
			||||||
 | 
					                  <el-option v-for="dict in modelList" :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="area">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.area" placeholder="请输入单位平方数" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col> -->
 | 
				
			||||||
 | 
					          </el-row>
 | 
				
			||||||
 | 
					          <!-- <el-row :gutter="20">
 | 
				
			||||||
 | 
					            <el-col :span="24">
 | 
				
			||||||
 | 
					              <el-form-item label="完成单位产品用时" prop="processTime">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.processTime" placeholder="请输入完成单位产品用时" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					          </el-row> -->
 | 
				
			||||||
 | 
					        </el-form>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        <!-- <small-title
 | 
				
			||||||
 | 
										style="margin: 16px 0; padding-left: 8px"
 | 
				
			||||||
 | 
										:no-padding="true">
 | 
				
			||||||
 | 
										产品属性列表
 | 
				
			||||||
 | 
									</small-title>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									<div class="attr-list">
 | 
				
			||||||
 | 
										<base-table
 | 
				
			||||||
 | 
											:table-props="tableProps"
 | 
				
			||||||
 | 
											:page="listQuery.pageNo"
 | 
				
			||||||
 | 
											:limit="listQuery.pageSize"
 | 
				
			||||||
 | 
											:add-button-show="isdetail ? null : '添加属性'"
 | 
				
			||||||
 | 
											@emitButtonClick="addNew()"
 | 
				
			||||||
 | 
											:table-data="productAttributeList">
 | 
				
			||||||
 | 
											<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>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <!-- <div style="position: absolute; bottom: 24px; right: 24px">
 | 
				
			||||||
 | 
								<el-button style="margin-right: 10px" @click="goback()">返回</el-button>
 | 
				
			||||||
 | 
								<el-button v-if="isdetail" type="primary" @click="goEdit()">
 | 
				
			||||||
 | 
									编辑
 | 
				
			||||||
 | 
								</el-button>
 | 
				
			||||||
 | 
								<span v-if="!isdetail">
 | 
				
			||||||
 | 
									<el-button type="primary" @click="dataFormSubmit()">保存</el-button>
 | 
				
			||||||
 | 
									<el-button
 | 
				
			||||||
 | 
										v-if="dataForm.id && !isdetail"
 | 
				
			||||||
 | 
										type="primary"
 | 
				
			||||||
 | 
										@click="addNew()">
 | 
				
			||||||
 | 
										添加属性
 | 
				
			||||||
 | 
									</el-button>
 | 
				
			||||||
 | 
								</span>
 | 
				
			||||||
 | 
							</div> -->
 | 
				
			||||||
 | 
					    <template slot="footer">
 | 
				
			||||||
 | 
					      <el-button style="" @click="goback()">取消</el-button>
 | 
				
			||||||
 | 
					      <!-- <el-button v-if="isdetail" type="primary" @click="goEdit()">
 | 
				
			||||||
 | 
									编辑
 | 
				
			||||||
 | 
								</el-button> -->
 | 
				
			||||||
 | 
					      <el-button type="primary" @click="dataFormSubmit()">确定</el-button>
 | 
				
			||||||
 | 
					    </template>
 | 
				
			||||||
 | 
					  </el-dialog>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
						createPacking,
 | 
				
			||||||
 | 
						updatePacking,
 | 
				
			||||||
 | 
					  getPacking,
 | 
				
			||||||
 | 
					  getWorkOrderList,
 | 
				
			||||||
 | 
					  getCode,
 | 
				
			||||||
 | 
					  getCustomerList,
 | 
				
			||||||
 | 
					  getModelList
 | 
				
			||||||
 | 
					} from '@/api/base/packingInfo.js';
 | 
				
			||||||
 | 
					// import productAttrAdd from './attr-add';
 | 
				
			||||||
 | 
					import { parseTime } from '../mixins/code-filter';
 | 
				
			||||||
 | 
					import SmallTitle from './SmallTitle';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableBtn = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							type: 'edit',
 | 
				
			||||||
 | 
							btnName: '编辑',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							type: 'delete',
 | 
				
			||||||
 | 
							btnName: '删除',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'createTime',
 | 
				
			||||||
 | 
							label: '添加时间',
 | 
				
			||||||
 | 
							filter: parseTime,
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'name',
 | 
				
			||||||
 | 
							label: '属性名',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'value',
 | 
				
			||||||
 | 
							label: '属性值',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						components: { SmallTitle },
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								visible: false,
 | 
				
			||||||
 | 
								addOrUpdateVisible: false,
 | 
				
			||||||
 | 
								tableBtn,
 | 
				
			||||||
 | 
					      tableProps,
 | 
				
			||||||
 | 
					      customerList: [],
 | 
				
			||||||
 | 
					      modelList:[],
 | 
				
			||||||
 | 
					      workOrderList:[],
 | 
				
			||||||
 | 
								productAttributeList: [],
 | 
				
			||||||
 | 
								dataForm: {
 | 
				
			||||||
 | 
									id: null,
 | 
				
			||||||
 | 
									// name: '', // 产品名称
 | 
				
			||||||
 | 
					        packagingCode: '', // 产品编码
 | 
				
			||||||
 | 
									// area: 0, // 单位平方数(float only)
 | 
				
			||||||
 | 
					        modelId: null, // 产品类型id
 | 
				
			||||||
 | 
					        workOrderId: null, // 单位产品用时 (s)
 | 
				
			||||||
 | 
					        customerId: '', // 规格
 | 
				
			||||||
 | 
					        content: '', // 单位id
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								listQuery: {
 | 
				
			||||||
 | 
									pageSize: 10,
 | 
				
			||||||
 | 
									pageNo: 1,
 | 
				
			||||||
 | 
									total: 0,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								dataRule: {
 | 
				
			||||||
 | 
					        content: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											required: true,
 | 
				
			||||||
 | 
											message: '内容不能为空',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
										// {
 | 
				
			||||||
 | 
										// 	type: 'number',
 | 
				
			||||||
 | 
										// 	message: '产品编码为数字类型',
 | 
				
			||||||
 | 
										// 	trigger: 'blur',
 | 
				
			||||||
 | 
										// 	transfom: 'val => Number(val)',
 | 
				
			||||||
 | 
										// },
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
					        workOrderId: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											required: true,
 | 
				
			||||||
 | 
											message: '所属工单不能为空',
 | 
				
			||||||
 | 
											trigger: 'change',
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
									typeDictValue: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											required: true,
 | 
				
			||||||
 | 
											message: '产品类型不能为空',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
									area: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											type: 'number',
 | 
				
			||||||
 | 
											message: '请输入正确的数值',
 | 
				
			||||||
 | 
											trigger: 'change',
 | 
				
			||||||
 | 
											transform: (val) => Number(val),
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
									processTime: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											required: true,
 | 
				
			||||||
 | 
											message: '完成单位产品用时不能为空',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											type: 'number',
 | 
				
			||||||
 | 
											message: '请输入正确的数值',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
											transform: (val) => Number(val),
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								// isdetail: false,
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
						methods: {
 | 
				
			||||||
 | 
							// initData() {
 | 
				
			||||||
 | 
							// 	this.productAttributeList.splice(0);
 | 
				
			||||||
 | 
							// 	this.listQuery.total = 0;
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
					    init(id) {
 | 
				
			||||||
 | 
					      this.getDict()
 | 
				
			||||||
 | 
								// this.initData();
 | 
				
			||||||
 | 
								// this.isdetail = isdetail || false;
 | 
				
			||||||
 | 
								this.dataForm.id = id || null;
 | 
				
			||||||
 | 
								this.visible = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								this.$nextTick(() => {
 | 
				
			||||||
 | 
									this.$refs['dataForm'].resetFields();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if (this.dataForm.id) {
 | 
				
			||||||
 | 
										// 获取产品详情
 | 
				
			||||||
 | 
										getPacking(id).then((response) => {
 | 
				
			||||||
 | 
											this.dataForm = response.data;
 | 
				
			||||||
 | 
										});
 | 
				
			||||||
 | 
										// 获取产品的属性列表
 | 
				
			||||||
 | 
										// this.getList();
 | 
				
			||||||
 | 
									} else {
 | 
				
			||||||
 | 
										getCode().then((res) => {
 | 
				
			||||||
 | 
					            this.dataForm.packagingCode = res.data;
 | 
				
			||||||
 | 
										});
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							getDict() {
 | 
				
			||||||
 | 
					      // 获取产品的属性列表
 | 
				
			||||||
 | 
					      getCustomerList().then((response) => {
 | 
				
			||||||
 | 
					        console.log(response);
 | 
				
			||||||
 | 
					        this.customerList = response.data
 | 
				
			||||||
 | 
					        // this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					      getModelList().then((response) => {
 | 
				
			||||||
 | 
					        console.log(response);
 | 
				
			||||||
 | 
					        this.modelList = response.data
 | 
				
			||||||
 | 
					        // this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					      getWorkOrderList().then((response) => {
 | 
				
			||||||
 | 
					        // console.log(response);
 | 
				
			||||||
 | 
					        this.workOrderList = response.data
 | 
				
			||||||
 | 
									// this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
								})
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							// handleClick(raw) {
 | 
				
			||||||
 | 
							// 	if (raw.type === 'delete') {
 | 
				
			||||||
 | 
							// 		this.$confirm(
 | 
				
			||||||
 | 
							// 			`确定对${
 | 
				
			||||||
 | 
							// 				raw.data.name
 | 
				
			||||||
 | 
							// 					? '[名称=' + raw.data.name + ']'
 | 
				
			||||||
 | 
							// 					: '[序号=' + raw.data._pageIndex + ']'
 | 
				
			||||||
 | 
							// 			}进行删除操作?`,
 | 
				
			||||||
 | 
							// 			'提示',
 | 
				
			||||||
 | 
							// 			{
 | 
				
			||||||
 | 
							// 				confirmButtonText: '确定',
 | 
				
			||||||
 | 
							// 				cancelButtonText: '取消',
 | 
				
			||||||
 | 
							// 				type: 'warning',
 | 
				
			||||||
 | 
							// 			}
 | 
				
			||||||
 | 
							// 		)
 | 
				
			||||||
 | 
							// 			.then(() => {
 | 
				
			||||||
 | 
							// 				deleteProductAttr(raw.data.id).then(({ data }) => {
 | 
				
			||||||
 | 
							// 					this.$message({
 | 
				
			||||||
 | 
							// 						message: '操作成功',
 | 
				
			||||||
 | 
							// 						type: 'success',
 | 
				
			||||||
 | 
							// 						duration: 1500,
 | 
				
			||||||
 | 
							// 						onClose: () => {
 | 
				
			||||||
 | 
							// 							this.getList();
 | 
				
			||||||
 | 
							// 						},
 | 
				
			||||||
 | 
							// 					});
 | 
				
			||||||
 | 
							// 				});
 | 
				
			||||||
 | 
							// 			})
 | 
				
			||||||
 | 
							// 			.catch(() => {});
 | 
				
			||||||
 | 
							// 	} else {
 | 
				
			||||||
 | 
							// 		this.addNew(raw.data.id);
 | 
				
			||||||
 | 
							// 	}
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							// 表单提交
 | 
				
			||||||
 | 
							dataFormSubmit() {
 | 
				
			||||||
 | 
								this.$refs['dataForm'].validate((valid) => {
 | 
				
			||||||
 | 
									if (valid) {
 | 
				
			||||||
 | 
										// 修改的提交
 | 
				
			||||||
 | 
										if (this.dataForm.id) {
 | 
				
			||||||
 | 
											updatePacking(this.dataForm).then((response) => {
 | 
				
			||||||
 | 
												this.$modal.msgSuccess('修改成功');
 | 
				
			||||||
 | 
												this.visible = false;
 | 
				
			||||||
 | 
												this.$emit('refreshDataList');
 | 
				
			||||||
 | 
											});
 | 
				
			||||||
 | 
											return;
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
										// 添加的提交
 | 
				
			||||||
 | 
										createPacking(this.dataForm).then((response) => {
 | 
				
			||||||
 | 
											this.$modal.msgSuccess('新增成功');
 | 
				
			||||||
 | 
											this.visible = false;
 | 
				
			||||||
 | 
											this.$emit('refreshDataList');
 | 
				
			||||||
 | 
										});
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							// goEdit() {
 | 
				
			||||||
 | 
							// 	this.isdetail = false;
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							// // 新增 / 修改
 | 
				
			||||||
 | 
							// addNew(id) {
 | 
				
			||||||
 | 
							// 	this.addOrUpdateVisible = true;
 | 
				
			||||||
 | 
							// 	this.$nextTick(() => {
 | 
				
			||||||
 | 
							// 		this.$refs.addOrUpdate.init(id);
 | 
				
			||||||
 | 
							// 	});
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							goback() {
 | 
				
			||||||
 | 
								this.$emit('refreshDataList');
 | 
				
			||||||
 | 
								this.visible = false;
 | 
				
			||||||
 | 
								// this.initData();
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</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> -->
 | 
				
			||||||
							
								
								
									
										298
									
								
								src/views/base/packagingPrintLog/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										298
									
								
								src/views/base/packagingPrintLog/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,298 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2023-08-01 14:55:51
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-30 10:44:48
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
						<div class="app-container">
 | 
				
			||||||
 | 
							<search-bar
 | 
				
			||||||
 | 
								:formConfigs="formConfig"
 | 
				
			||||||
 | 
								ref="searchBarForm"
 | 
				
			||||||
 | 
								@headBtnClick="buttonClick" />
 | 
				
			||||||
 | 
							<base-table
 | 
				
			||||||
 | 
								: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" />
 | 
				
			||||||
 | 
							<add-or-update
 | 
				
			||||||
 | 
								v-if="addOrUpdateVisible"
 | 
				
			||||||
 | 
								ref="addOrUpdate"
 | 
				
			||||||
 | 
								@refreshDataList="getDataList" />
 | 
				
			||||||
 | 
						</div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import AddOrUpdate from './add-or-updata';
 | 
				
			||||||
 | 
					// import unitDict from './unitDict';
 | 
				
			||||||
 | 
					import basicPage from '../mixins/basic-page';
 | 
				
			||||||
 | 
					import { parseTime } from '../mixins/code-filter';
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
					  getPackingModel,
 | 
				
			||||||
 | 
					} from '@/api/base/printModel.js'
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
						deletePacking,
 | 
				
			||||||
 | 
					  getPackingPage,
 | 
				
			||||||
 | 
						exportPackingExcel,
 | 
				
			||||||
 | 
					} from '@/api/base/packingInfo';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'packagingCode',
 | 
				
			||||||
 | 
					    label: '包装流水号'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'workOrderName',
 | 
				
			||||||
 | 
							label: '所属工单'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'customerName',
 | 
				
			||||||
 | 
							label: '客户'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'content',
 | 
				
			||||||
 | 
							label: '内容',
 | 
				
			||||||
 | 
							// subcomponent: unitDict,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: 'modelName',
 | 
				
			||||||
 | 
					    label: '标签模板',
 | 
				
			||||||
 | 
					    // subcomponent: unitDict,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: 'printStatus',
 | 
				
			||||||
 | 
					    label: '打印状态',
 | 
				
			||||||
 | 
					    // subcomponent: unitDict,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'createTime',
 | 
				
			||||||
 | 
							label: '生成日期',
 | 
				
			||||||
 | 
							filter: parseTime
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicPage],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
					        getDataListURL: getPackingPage,
 | 
				
			||||||
 | 
									deleteURL: deletePacking,
 | 
				
			||||||
 | 
									exportURL: exportPackingExcel,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								tableProps,
 | 
				
			||||||
 | 
								tableBtn: [
 | 
				
			||||||
 | 
					        this.$auth.hasPermi(`base:packaging-print-log:update`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'edit',
 | 
				
			||||||
 | 
												btnName: '编辑',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: 'print',
 | 
				
			||||||
 | 
					          btnName: '打印',
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        this.$auth.hasPermi(`base:packaging-print-log:delete`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'delete',
 | 
				
			||||||
 | 
												btnName: '删除',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								].filter((v) => v),
 | 
				
			||||||
 | 
								tableData: [],
 | 
				
			||||||
 | 
								formConfig: [
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'input',
 | 
				
			||||||
 | 
					          label: '工单',
 | 
				
			||||||
 | 
					          placeholder: '工单',
 | 
				
			||||||
 | 
					          param: 'workOrderId',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
					          // parent: 'dateFilterType',
 | 
				
			||||||
 | 
					          // 日期选择
 | 
				
			||||||
 | 
					          type: 'datePicker',
 | 
				
			||||||
 | 
					          label: '时间',
 | 
				
			||||||
 | 
					          dateType: 'date',
 | 
				
			||||||
 | 
					          placeholder: '选择日期',
 | 
				
			||||||
 | 
					          format: 'yyyy-MM-dd',
 | 
				
			||||||
 | 
					          valueFormat: 'yyyy-MM-dd',
 | 
				
			||||||
 | 
					          param: 'createTime',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'button',
 | 
				
			||||||
 | 
										btnName: '搜索',
 | 
				
			||||||
 | 
										name: 'search',
 | 
				
			||||||
 | 
										color: 'primary',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'separate',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'button',
 | 
				
			||||||
 | 
									// 	btnName: '重置',
 | 
				
			||||||
 | 
									// 	name: 'reset',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'separate',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
					          type: this.$auth.hasPermi('base:packaging-print-log:create') ? 'button' : '',
 | 
				
			||||||
 | 
										btnName: '新增',
 | 
				
			||||||
 | 
										name: 'add',
 | 
				
			||||||
 | 
										color: 'success',
 | 
				
			||||||
 | 
										plain: true,
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'separate',
 | 
				
			||||||
 | 
									// 	type: this.$auth.hasPermi('base:product:create') ? 'separate' : '',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: this.$auth.hasPermi('base:product:export') ? 'button' : '',
 | 
				
			||||||
 | 
									// 	btnName: '导出',
 | 
				
			||||||
 | 
									// 	name: 'export',
 | 
				
			||||||
 | 
									// 	color: 'warning',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
								],
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						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;
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handlePrint(id) {
 | 
				
			||||||
 | 
					      if (id) {
 | 
				
			||||||
 | 
					        getPackingModel(id).then(res => {
 | 
				
			||||||
 | 
					          var obj = {
 | 
				
			||||||
 | 
					            code: '11111222',
 | 
				
			||||||
 | 
					            test: '11111',
 | 
				
			||||||
 | 
					            test2: '3333333',
 | 
				
			||||||
 | 
					            test1: '222222',
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					          console.log(res);
 | 
				
			||||||
 | 
					          // getPackingListInfo({
 | 
				
			||||||
 | 
					          //   size: 20,
 | 
				
			||||||
 | 
					          //   current: 1,
 | 
				
			||||||
 | 
					          //   boxNo: printModel.boxNo
 | 
				
			||||||
 | 
					          // }).then(result => {
 | 
				
			||||||
 | 
					          //   this.substrateList = result.data.records
 | 
				
			||||||
 | 
					          //   var obj = {
 | 
				
			||||||
 | 
					          //     // time: this.getNewDate(),
 | 
				
			||||||
 | 
					          //     boxNo: this.currentData.boxNo,
 | 
				
			||||||
 | 
					          //     orderNum: this.currentData.orderNum,
 | 
				
			||||||
 | 
					          //     powerLevel: this.currentData.powerLevel,
 | 
				
			||||||
 | 
					          //     sapMaterial: this.currentData.sapMaterial,
 | 
				
			||||||
 | 
					          //     img: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGQAAABkCAYAAABw4pVUAAAHVklEQVR4nO2dT2wUVRzHv2/2T5eSAlvFilwgQUH+eLACaUxEiJLAxdh44MDZi2ChUIrSFtoCgbbSP4GDdwgeEA8kRTAI0iIGBL1ITLxgLAlCsCKBYndnx7zd35pl2+7On/de387OJ9l00515/z7z/szMmzfs7869mD0yCjw2gZAB4VhAiln4/dUaRGdU18aOnzw9dn24ioGJj0soFsJr1z2yNm+qN2/fvRFL8XyMYqTmFfxZ+TwMc1xKDsL/f2Ms8xGeLwuIRpCKx99MHf/i4uPrw5GQ9jIAfsCMXfw2HkuOX03Wb1qLh4+uIGFJjzecPoS5iEhUTg1hDMaM2GuRk6cGMTQUCYmPQQq86CMAkkPDkQirGAzXf7Du34ejN9IHmETCRjQGPL6D+4NnYDEJDQmXbaY6on/dm2Vm/jHdZe0Almm6Ll+YNQbzasX7765BNHI1o0sOYRghwExg7MG9dDQSiqsdwHuZmlFKMjLwQ3QcFtjlSxHTenLO3Lp7vfU09AOS41Ka+HC6CjIDIaqmguvIPgBtIgOcDhjVlMTQtarKOScumR/teCdpxoeNZGJCapjFt7Rcywrb2MYtnQBatCpZTzCkYCF+5suKRXf+6EvOmv0GSzwrhB/QpmGkBYZSpqvIZAlp8ZeMLFwKUH3z2gqWyd/+3F/5b1yRQQMCN8gQspeaKt+SAItSCxCiPjIjhDEkjRAMxmCZSbgZkYke537qdxl57KM8C0OkkD0ADohMXIlwgPIuBFFC9uS3p2XGflFSRAgpdxlZeBl84jUQr0ImjDTKGWZZBwE0eCkCL0J20UgjgGCwEDHNPjB86PbiilshfGRxOBCRD0tLCSWTnzMLO9yE4EbIzjIdTdmGpc8/rB4qK0c4FcKbqe7pyWZJ0k1lZhsnQnZq3EzV00dHDjupKXaFNGtcM7YA+Io+WzRIz2R0UxkWxY6QJgCHlCbfPlzAsZytj2ks5RCVZUGKCdkOoEt+Wl3RkCcjyzGv5wIS6aIynZJCQni7d0TTjPFaMFDg9wGNa8qRQn3KVEI+1rjPmKpm5KNzTemmMp7AZEK2AehXmz7bbC1SM/IZoH10pJ/K+hnyhXBrvZpmoBHAURf7HaV9daQ3v6Zk7hhWVr4AYDOAzzRNeKPHAyW7r459Yj/deUynMcyqqpY9/fXW+RTwkiF/ms5pADcd7nMbwAkBcfMM3wOwwOF+rys46TxCt+T72d2NG0YSg2fnC58ANDkbAZyVH41QNgAYVBTXNiMxeLYG6qawvagmGqGoTHOfwcAe6T8TvWwYlTC7OsALgRDNCIRoRiBEMwIhmhEI0YxAiGYEQjRDtZCY9iUyEaVpVi3kvuL4RKA0zSqF8Ad5TimMTxSnKO1KUCWEZ6hDVaYk0KFKigohbSUuI0uHiieKZQtp89kM+U7ZUmQKafHp4wpSH/eWJaTT5zPkD8g62GQI8cXqDTZok/HEsWgh+3Of2y4D2kU/0idKyEOaJdgqKLxSotXlfLFJESXkicKZGTrys6g0iRIyD8AvAFYLCq+UWC1yACOyD+Hrf1wAUCcwTN2pozzXiEqn6E59JoBvANQKDldHaimvM0WmTcawlydw2Oc1pY7yKFQGJJ4YxqiTXyEp/OlkBeVNyn0SmZdO5gC47rOOfjXlaY6sCGRfXKwA8LVP+pRaykuFzEhUXH7nR9P3AFYqiEsWKykP0mpGFlU3qKI0IlmlKD6RrKK0R1VEpvIW7uwSHXnVUdqVoHqSwz+K4xOB0jQH87I0IxCiGYEQzQiEaEYgRDMCIZoRCNGMQIhmBEI0gwuJK0xScKZemHiY1mzqUxThYgBLHO7zQOAzGnMBPOdwn8WC4rbDNjaSWVajQaEUp9wBsB7ALY/hLAVwHsB89VmwRXrhuGwf0q/xIl/z6f6105qVyxIKQ1cZjdlV/HI79V6N1yjk/dxlAMtc7LuM9lXZVzqhIXdxtvxR1kCxZUynkbl0o2ihgyQspH3mapqn7flrSE427O3TuKbwGZI/AlhuY9vltO08Belyw6T99lTnIQN2VmGeJqppskGhpfoW0DbVmuahaarVVQudGPZo3tH/RCOnfJbSbzp34D1T/VjsTL3X6esWFMJngJwDsCgnykX0P+mzQ1yyq9jqqtnzkGI0a7wgPz9pfJm+/6ZxB77bzus+7L7pkwdkarr8OBdwJee7jjQVaqZysVtDsuwK3j3lmGYnb5hwerW3S+PRl440OX3dh5vL7z0iXzXqY/bYbaZycXs/5KDdV/iUKc1URo7xcoOqq0yfui1Gq5e3EoUava1qzS/aJQGs8xKIj2jx+gCoVyGcoUBKGs8yIEgIAiliZEDwJAehL3ovIYS+2F9UDckyRH/fFhmoxuwTvdaJaCGc7+gyi9+br1YZSzTJEAIaffHrZG/JCFwDpK16JEsI5yK9uMdvzVe7zAUxZQrhXKKBwxqZkSikQ8aiZbnIFgKS4oea0i5bBhQJgQ+kKJEBhUJAUkqxo+cduJqVrQH8B6xBgBhvJFNDAAAAAElFTkSuQmCC',
 | 
				
			||||||
 | 
					          //     // lineBody: this.currentData.lineBody == 1 ? 'F ' : 'S',
 | 
				
			||||||
 | 
					          //     createTime: moment(this.currentData.createTime).format('YYYY-MM-DD HH:mm:ss')
 | 
				
			||||||
 | 
					          //     // modul1: '20210320000012',
 | 
				
			||||||
 | 
					          //     // modul2: '20210320000012',
 | 
				
			||||||
 | 
					          //     // modul3: '20210320000012'
 | 
				
			||||||
 | 
					          //   }
 | 
				
			||||||
 | 
					          //   for (var i = 0; i < this.substrateList.length; i++) {
 | 
				
			||||||
 | 
					          //     var model = 'model' + Number(i + 1)
 | 
				
			||||||
 | 
					          //     var pmpp = 'PMPP' + Number(i + 1)
 | 
				
			||||||
 | 
					          //     var m = 'm' + Number(i + 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          //     console.log(model)
 | 
				
			||||||
 | 
					          //     // console.log(this.list[i].woSubstrateId)
 | 
				
			||||||
 | 
					          //     // console.log(this.list[i].woSubstrateId)
 | 
				
			||||||
 | 
					          //     obj['' + model + ''] = this.substrateList[i].woSubstrateId
 | 
				
			||||||
 | 
					          //     obj['' + pmpp + ''] = this.substrateList[i].pmpp
 | 
				
			||||||
 | 
					          //     obj['' + m + ''] = i + 1
 | 
				
			||||||
 | 
					          //   }
 | 
				
			||||||
 | 
					          //   console.log(obj)
 | 
				
			||||||
 | 
					          // this.printPreview('预览', res.data)
 | 
				
			||||||
 | 
					          const hiprintTemplate = this.$print(undefined, JSON.parse(res.data.content), obj, {}, {
 | 
				
			||||||
 | 
					            // styleHandler: () => {
 | 
				
			||||||
 | 
					            //   const css = '<link href="http://hiprint.io/Content/hiprint/css/print-lock.css" media="print" rel="stylesheet">'
 | 
				
			||||||
 | 
					            //   return css
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          hiprintTemplate.on('printSuccess', function () {
 | 
				
			||||||
 | 
					            console.log(1111);
 | 
				
			||||||
 | 
					            // that.$notification.success({
 | 
				
			||||||
 | 
					            //   // key: key,
 | 
				
			||||||
 | 
					            //   placement: 'topRight',
 | 
				
			||||||
 | 
					            //   message: key + ' 打印成功',
 | 
				
			||||||
 | 
					            //   description: 'Api单独直接打印回调',
 | 
				
			||||||
 | 
					            // });
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					          console.log(hiprintTemplate)
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.$message({
 | 
				
			||||||
 | 
					          message: '请选择打印标签模板',
 | 
				
			||||||
 | 
					          type: 'warning'
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    closeCallback(vue) {
 | 
				
			||||||
 | 
					      console.log('关闭了打印工具')
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
							buttonClick(val) {
 | 
				
			||||||
 | 
								switch (val.btnName) {
 | 
				
			||||||
 | 
									case 'search':
 | 
				
			||||||
 | 
										this.listQuery.pageNo = 1;
 | 
				
			||||||
 | 
										this.listQuery.pageSize = 10;
 | 
				
			||||||
 | 
					          this.listQuery.packagingCode = val.packagingCode;
 | 
				
			||||||
 | 
					          this.listQuery.createTime = val.createTime;
 | 
				
			||||||
 | 
					          this.getDataList();
 | 
				
			||||||
 | 
					          console.log(this.tableData)
 | 
				
			||||||
 | 
										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);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					    otherMethods(val) {
 | 
				
			||||||
 | 
					      this.handlePrint(val.data.modelId)
 | 
				
			||||||
 | 
								// this.addOrUpdateVisible = true;
 | 
				
			||||||
 | 
								// this.addOrEditTitle = '详情';
 | 
				
			||||||
 | 
								// this.$nextTick(() => {
 | 
				
			||||||
 | 
								// 	this.$refs.addOrUpdate.init(val.data.id, true);
 | 
				
			||||||
 | 
								// });
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										15
									
								
								src/views/base/packagingPrintLog/unitDict.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/views/base/packagingPrintLog/unitDict.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,15 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <dict-tag
 | 
				
			||||||
 | 
					    :type="DICT_TYPE.UNIT_DICT"
 | 
				
			||||||
 | 
					    :value="injectData.unitDictValue" />
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						props: {
 | 
				
			||||||
 | 
							injectData: {
 | 
				
			||||||
 | 
								type: Object,
 | 
				
			||||||
 | 
								default: () => ({}),
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										65
									
								
								src/views/base/packagingPrintModel/SmallTitle.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/views/base/packagingPrintModel/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>
 | 
				
			||||||
							
								
								
									
										441
									
								
								src/views/base/packagingPrintModel/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										441
									
								
								src/views/base/packagingPrintModel/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,441 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2023-10-17 16:50:19
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-30 10:41:07
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <el-dialog :visible.sync="visible" :show-close="false" :wrapper-closable="false" width="30%">
 | 
				
			||||||
 | 
					    <small-title slot="title" :no-padding="true">
 | 
				
			||||||
 | 
					      {{ !dataForm.id ? '新增' : '编辑' }}
 | 
				
			||||||
 | 
					    </small-title>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <div class="content">
 | 
				
			||||||
 | 
					      <div class="visual-part">
 | 
				
			||||||
 | 
					        <el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="100px"
 | 
				
			||||||
 | 
					          @keyup.enter.native="dataFormSubmit">
 | 
				
			||||||
 | 
					          <el-row :gutter="20">
 | 
				
			||||||
 | 
					            <el-col :span="12">
 | 
				
			||||||
 | 
					              <el-form-item label="模板名称" prop="name">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.name" clearable placeholder="请输入模板名称" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					            <el-col :span="12">
 | 
				
			||||||
 | 
					              <el-form-item label="标签类型" prop="typeId">
 | 
				
			||||||
 | 
					                <el-select v-model="dataForm.typeId" style="width: 100%;" placeholder="请选择打印方式" clearable>
 | 
				
			||||||
 | 
					                  <el-option v-for="dict in typeList" :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="printModel">
 | 
				
			||||||
 | 
					                <el-select v-model="dataForm.printModel" style="width: 100%;" placeholder="请选择打印方式" clearable>
 | 
				
			||||||
 | 
					                  <el-option v-for="dict in printModelList" :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="remark">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.remark" clearable placeholder="请输入标签备注" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					          </el-row>
 | 
				
			||||||
 | 
					          <el-row :gutter="20">
 | 
				
			||||||
 | 
					            <el-col :span="12">
 | 
				
			||||||
 | 
					              <el-form-item label="模板设计" prop="content">
 | 
				
			||||||
 | 
					                <el-button type="primary" @click="btnClickDesign()">模板设计</el-button>
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					            <!-- <el-col :span="12">
 | 
				
			||||||
 | 
					              <el-form-item label="单位平方数" prop="area">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.area" placeholder="请输入单位平方数" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col> -->
 | 
				
			||||||
 | 
					          </el-row>
 | 
				
			||||||
 | 
					          <!-- <el-row :gutter="20">
 | 
				
			||||||
 | 
					            <el-col :span="24">
 | 
				
			||||||
 | 
					              <el-form-item label="完成单位产品用时" prop="processTime">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.processTime" placeholder="请输入完成单位产品用时" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					          </el-row> -->
 | 
				
			||||||
 | 
					        </el-form>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        <!-- <small-title
 | 
				
			||||||
 | 
										style="margin: 16px 0; padding-left: 8px"
 | 
				
			||||||
 | 
										:no-padding="true">
 | 
				
			||||||
 | 
										产品属性列表
 | 
				
			||||||
 | 
									</small-title>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									<div class="attr-list">
 | 
				
			||||||
 | 
										<base-table
 | 
				
			||||||
 | 
											:table-props="tableProps"
 | 
				
			||||||
 | 
											:page="listQuery.pageNo"
 | 
				
			||||||
 | 
											:limit="listQuery.pageSize"
 | 
				
			||||||
 | 
											:add-button-show="isdetail ? null : '添加属性'"
 | 
				
			||||||
 | 
											@emitButtonClick="addNew()"
 | 
				
			||||||
 | 
											:table-data="productAttributeList">
 | 
				
			||||||
 | 
											<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>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <!-- <div style="position: absolute; bottom: 24px; right: 24px">
 | 
				
			||||||
 | 
								<el-button style="margin-right: 10px" @click="goback()">返回</el-button>
 | 
				
			||||||
 | 
								<el-button v-if="isdetail" type="primary" @click="goEdit()">
 | 
				
			||||||
 | 
									编辑
 | 
				
			||||||
 | 
								</el-button>
 | 
				
			||||||
 | 
								<span v-if="!isdetail">
 | 
				
			||||||
 | 
									<el-button type="primary" @click="dataFormSubmit()">保存</el-button>
 | 
				
			||||||
 | 
									<el-button
 | 
				
			||||||
 | 
										v-if="dataForm.id && !isdetail"
 | 
				
			||||||
 | 
										type="primary"
 | 
				
			||||||
 | 
										@click="addNew()">
 | 
				
			||||||
 | 
										添加属性
 | 
				
			||||||
 | 
									</el-button>
 | 
				
			||||||
 | 
								</span>
 | 
				
			||||||
 | 
							</div> -->
 | 
				
			||||||
 | 
					    <template slot="footer">
 | 
				
			||||||
 | 
					      <el-button style="" @click="goback()">取消</el-button>
 | 
				
			||||||
 | 
					      <!-- <el-button v-if="isdetail" type="primary" @click="goEdit()">
 | 
				
			||||||
 | 
									编辑
 | 
				
			||||||
 | 
								</el-button> -->
 | 
				
			||||||
 | 
					      <el-button type="primary" @click="dataFormSubmit()">确定</el-button>
 | 
				
			||||||
 | 
					    </template>
 | 
				
			||||||
 | 
					    <print-model-design v-if="modelShow" ref="printModelDesign" @saveData="getModelData" />
 | 
				
			||||||
 | 
					  </el-dialog>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
					  createPackingModel,
 | 
				
			||||||
 | 
					  updatePackingModel,
 | 
				
			||||||
 | 
					  getPackingModel,
 | 
				
			||||||
 | 
					  // getWorkOrderList,
 | 
				
			||||||
 | 
					  // getCode,
 | 
				
			||||||
 | 
					  // getCustomerList,
 | 
				
			||||||
 | 
					  getTypeList
 | 
				
			||||||
 | 
					} from '@/api/base/printModel.js';
 | 
				
			||||||
 | 
					// import productAttrAdd from './attr-add';
 | 
				
			||||||
 | 
					import { parseTime } from '../mixins/code-filter';
 | 
				
			||||||
 | 
					import SmallTitle from './SmallTitle';
 | 
				
			||||||
 | 
					import printModelDesign from '../custom/index'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableBtn = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							type: 'edit',
 | 
				
			||||||
 | 
							btnName: '编辑',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							type: 'delete',
 | 
				
			||||||
 | 
							btnName: '删除',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'createTime',
 | 
				
			||||||
 | 
							label: '添加时间',
 | 
				
			||||||
 | 
							filter: parseTime,
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'name',
 | 
				
			||||||
 | 
							label: '属性名',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'value',
 | 
				
			||||||
 | 
							label: '属性值',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  components: { SmallTitle, printModelDesign },
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								visible: false,
 | 
				
			||||||
 | 
								addOrUpdateVisible: false,
 | 
				
			||||||
 | 
								tableBtn,
 | 
				
			||||||
 | 
					      tableProps,
 | 
				
			||||||
 | 
					      modelShow:false,
 | 
				
			||||||
 | 
					      typeList:[],
 | 
				
			||||||
 | 
								dataForm: {
 | 
				
			||||||
 | 
									id: null,
 | 
				
			||||||
 | 
									// name: '', // 产品名称
 | 
				
			||||||
 | 
					        name: '', // 产品编码
 | 
				
			||||||
 | 
									// area: 0, // 单位平方数(float only)
 | 
				
			||||||
 | 
					        typeId: null, // 产品类型id
 | 
				
			||||||
 | 
					        printModel: null, // 单位产品用时 (s)
 | 
				
			||||||
 | 
					        content: '', // 规格
 | 
				
			||||||
 | 
					        remark: '', // 单位id
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      printModelList: [
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          id: 1,
 | 
				
			||||||
 | 
					          name:'自动'
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          id: 2,
 | 
				
			||||||
 | 
					          name: '手动'
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
								listQuery: {
 | 
				
			||||||
 | 
									pageSize: 10,
 | 
				
			||||||
 | 
									pageNo: 1,
 | 
				
			||||||
 | 
									total: 0,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								dataRule: {
 | 
				
			||||||
 | 
					        typeId: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											required: true,
 | 
				
			||||||
 | 
											message: '打印类型不能为空',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
										// {
 | 
				
			||||||
 | 
										// 	type: 'number',
 | 
				
			||||||
 | 
										// 	message: '产品编码为数字类型',
 | 
				
			||||||
 | 
										// 	trigger: 'blur',
 | 
				
			||||||
 | 
										// 	transfom: 'val => Number(val)',
 | 
				
			||||||
 | 
										// },
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
									name: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											required: true,
 | 
				
			||||||
 | 
											message: '模板名称不能为空',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
					        printModel: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											required: true,
 | 
				
			||||||
 | 
											message: '模板类型不能为空',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
									content: [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            required: true,
 | 
				
			||||||
 | 
					            message: '模板不能为空',
 | 
				
			||||||
 | 
					            trigger: 'blur',
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
									processTime: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											required: true,
 | 
				
			||||||
 | 
											message: '完成单位产品用时不能为空',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											type: 'number',
 | 
				
			||||||
 | 
											message: '请输入正确的数值',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
											transform: (val) => Number(val),
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								// isdetail: false,
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    getModelData(data) {
 | 
				
			||||||
 | 
					      console.log(data)
 | 
				
			||||||
 | 
					      this.content = JSON.stringify(data)
 | 
				
			||||||
 | 
					      this.dataForm.content = JSON.stringify(data)
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    btnClickDesign() {
 | 
				
			||||||
 | 
					      console.log(11111)
 | 
				
			||||||
 | 
					      this.modelShow = true
 | 
				
			||||||
 | 
					      this.$nextTick(() => {
 | 
				
			||||||
 | 
					        this.$refs.printModelDesign.init(this.dataForm.content)
 | 
				
			||||||
 | 
					        console.log(this.dataForm.content)
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					      // this.$router.push({
 | 
				
			||||||
 | 
					      //   path: '/printModelDesign'
 | 
				
			||||||
 | 
					      // })
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
							// initData() {
 | 
				
			||||||
 | 
							// 	this.productAttributeList.splice(0);
 | 
				
			||||||
 | 
							// 	this.listQuery.total = 0;
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
					    init(id) {
 | 
				
			||||||
 | 
					      this.getDict()
 | 
				
			||||||
 | 
								// this.initData();
 | 
				
			||||||
 | 
								// this.isdetail = isdetail || false;
 | 
				
			||||||
 | 
								this.dataForm.id = id || null;
 | 
				
			||||||
 | 
								this.visible = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								this.$nextTick(() => {
 | 
				
			||||||
 | 
									this.$refs['dataForm'].resetFields();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if (this.dataForm.id) {
 | 
				
			||||||
 | 
										// 获取产品详情
 | 
				
			||||||
 | 
					          getPackingModel(id).then((response) => {
 | 
				
			||||||
 | 
											this.dataForm = response.data;
 | 
				
			||||||
 | 
										});
 | 
				
			||||||
 | 
										// 获取产品的属性列表
 | 
				
			||||||
 | 
										// this.getList();
 | 
				
			||||||
 | 
									} else {
 | 
				
			||||||
 | 
										// getCode().then((res) => {
 | 
				
			||||||
 | 
					          //   this.dataForm.packagingCode = res.data;
 | 
				
			||||||
 | 
										// });
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							getDict() {
 | 
				
			||||||
 | 
					      // 获取产品的属性列表
 | 
				
			||||||
 | 
					      // getCustomerList().then((response) => {
 | 
				
			||||||
 | 
					      //   console.log(response);
 | 
				
			||||||
 | 
					      //   this.customerList = response.data
 | 
				
			||||||
 | 
					      //   // this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
					      // })
 | 
				
			||||||
 | 
					      getTypeList().then((response) => {
 | 
				
			||||||
 | 
					        console.log(response);
 | 
				
			||||||
 | 
					        this.typeList = response.data
 | 
				
			||||||
 | 
					        // this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					      // getWorkOrderList().then((response) => {
 | 
				
			||||||
 | 
					      //   // console.log(response);
 | 
				
			||||||
 | 
					      //   this.workOrderList = response.data
 | 
				
			||||||
 | 
								// 	// this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
								// })
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							// handleClick(raw) {
 | 
				
			||||||
 | 
							// 	if (raw.type === 'delete') {
 | 
				
			||||||
 | 
							// 		this.$confirm(
 | 
				
			||||||
 | 
							// 			`确定对${
 | 
				
			||||||
 | 
							// 				raw.data.name
 | 
				
			||||||
 | 
							// 					? '[名称=' + raw.data.name + ']'
 | 
				
			||||||
 | 
							// 					: '[序号=' + raw.data._pageIndex + ']'
 | 
				
			||||||
 | 
							// 			}进行删除操作?`,
 | 
				
			||||||
 | 
							// 			'提示',
 | 
				
			||||||
 | 
							// 			{
 | 
				
			||||||
 | 
							// 				confirmButtonText: '确定',
 | 
				
			||||||
 | 
							// 				cancelButtonText: '取消',
 | 
				
			||||||
 | 
							// 				type: 'warning',
 | 
				
			||||||
 | 
							// 			}
 | 
				
			||||||
 | 
							// 		)
 | 
				
			||||||
 | 
							// 			.then(() => {
 | 
				
			||||||
 | 
							// 				deleteProductAttr(raw.data.id).then(({ data }) => {
 | 
				
			||||||
 | 
							// 					this.$message({
 | 
				
			||||||
 | 
							// 						message: '操作成功',
 | 
				
			||||||
 | 
							// 						type: 'success',
 | 
				
			||||||
 | 
							// 						duration: 1500,
 | 
				
			||||||
 | 
							// 						onClose: () => {
 | 
				
			||||||
 | 
							// 							this.getList();
 | 
				
			||||||
 | 
							// 						},
 | 
				
			||||||
 | 
							// 					});
 | 
				
			||||||
 | 
							// 				});
 | 
				
			||||||
 | 
							// 			})
 | 
				
			||||||
 | 
							// 			.catch(() => {});
 | 
				
			||||||
 | 
							// 	} else {
 | 
				
			||||||
 | 
							// 		this.addNew(raw.data.id);
 | 
				
			||||||
 | 
							// 	}
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							// 表单提交
 | 
				
			||||||
 | 
							dataFormSubmit() {
 | 
				
			||||||
 | 
								this.$refs['dataForm'].validate((valid) => {
 | 
				
			||||||
 | 
									if (valid) {
 | 
				
			||||||
 | 
										// 修改的提交
 | 
				
			||||||
 | 
										if (this.dataForm.id) {
 | 
				
			||||||
 | 
					            updatePackingModel(this.dataForm).then((response) => {
 | 
				
			||||||
 | 
												this.$modal.msgSuccess('修改成功');
 | 
				
			||||||
 | 
												this.visible = false;
 | 
				
			||||||
 | 
												this.$emit('refreshDataList');
 | 
				
			||||||
 | 
											});
 | 
				
			||||||
 | 
											return;
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
										// 添加的提交
 | 
				
			||||||
 | 
					          createPackingModel(this.dataForm).then((response) => {
 | 
				
			||||||
 | 
											this.$modal.msgSuccess('新增成功');
 | 
				
			||||||
 | 
											this.visible = false;
 | 
				
			||||||
 | 
											this.$emit('refreshDataList');
 | 
				
			||||||
 | 
										});
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							// goEdit() {
 | 
				
			||||||
 | 
							// 	this.isdetail = false;
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							// // 新增 / 修改
 | 
				
			||||||
 | 
							// addNew(id) {
 | 
				
			||||||
 | 
							// 	this.addOrUpdateVisible = true;
 | 
				
			||||||
 | 
							// 	this.$nextTick(() => {
 | 
				
			||||||
 | 
							// 		this.$refs.addOrUpdate.init(id);
 | 
				
			||||||
 | 
							// 	});
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							goback() {
 | 
				
			||||||
 | 
								this.$emit('refreshDataList');
 | 
				
			||||||
 | 
								this.visible = false;
 | 
				
			||||||
 | 
								// this.initData();
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</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> -->
 | 
				
			||||||
							
								
								
									
										210
									
								
								src/views/base/packagingPrintModel/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										210
									
								
								src/views/base/packagingPrintModel/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,210 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2023-08-01 14:55:51
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-30 10:45:23
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="app-container">
 | 
				
			||||||
 | 
					    <search-bar :formConfigs="formConfig" ref="searchBarForm" @headBtnClick="buttonClick" />
 | 
				
			||||||
 | 
					    <base-table :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" />
 | 
				
			||||||
 | 
					    <add-or-update v-if="addOrUpdateVisible" ref="addOrUpdate" @refreshDataList="getDataList" />
 | 
				
			||||||
 | 
					    <print-model-design v-if="modelShow" ref="printModelDesign" @saveData="getModelData" />
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import AddOrUpdate from './add-or-updata';
 | 
				
			||||||
 | 
					// import unitDict from './unitDict';
 | 
				
			||||||
 | 
					import basicPage from '../mixins/basic-page';
 | 
				
			||||||
 | 
					import { parseTime } from '../mixins/code-filter';
 | 
				
			||||||
 | 
					import printModelDesign from '../custom/index'
 | 
				
			||||||
 | 
					import { updatePackingModel,} from '@/api/base/printModel.js';
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
					  deletePackingModel,
 | 
				
			||||||
 | 
					  getPackingModelPage,
 | 
				
			||||||
 | 
						// exportPackingExcel,
 | 
				
			||||||
 | 
					} from '@/api/base/printModel';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'name',
 | 
				
			||||||
 | 
					    label: '模板名称'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'typeName',
 | 
				
			||||||
 | 
							label: '标签类型'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'printModel',
 | 
				
			||||||
 | 
					    label: '打印方式',
 | 
				
			||||||
 | 
					    filter: (val) => val ==1 ? '自动打印' : '自动打印',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'remark',
 | 
				
			||||||
 | 
							label: '备注',
 | 
				
			||||||
 | 
							// subcomponent: unitDict,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicPage],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
					        getDataListURL: getPackingModelPage,
 | 
				
			||||||
 | 
					        deleteURL: deletePackingModel,
 | 
				
			||||||
 | 
									// exportURL: exportPackingExcel,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
					      tableProps,
 | 
				
			||||||
 | 
					      modelShow:false,
 | 
				
			||||||
 | 
								tableBtn: [
 | 
				
			||||||
 | 
					        this.$auth.hasPermi(`base:packaging-print-model:update`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'edit',
 | 
				
			||||||
 | 
												btnName: '编辑',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: 'print',
 | 
				
			||||||
 | 
					          btnName: '打印',
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        this.$auth.hasPermi(`base:packaging-print-model:delete`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'delete',
 | 
				
			||||||
 | 
												btnName: '删除',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								].filter((v) => v),
 | 
				
			||||||
 | 
								tableData: [],
 | 
				
			||||||
 | 
								formConfig: [
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'input',
 | 
				
			||||||
 | 
					        //   label: '工单',
 | 
				
			||||||
 | 
					        //   placeholder: '工单',
 | 
				
			||||||
 | 
					        //   param: 'workOrderId',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
					        //   // parent: 'dateFilterType',
 | 
				
			||||||
 | 
					        //   // 日期选择
 | 
				
			||||||
 | 
					        //   type: 'datePicker',
 | 
				
			||||||
 | 
					        //   label: '时间',
 | 
				
			||||||
 | 
					        //   dateType: 'date',
 | 
				
			||||||
 | 
					        //   placeholder: '选择日期',
 | 
				
			||||||
 | 
					        //   format: 'yyyy-MM-dd',
 | 
				
			||||||
 | 
					        //   valueFormat: 'yyyy-MM-dd',
 | 
				
			||||||
 | 
					        //   param: 'createTime',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'button',
 | 
				
			||||||
 | 
										btnName: '搜索',
 | 
				
			||||||
 | 
										name: 'search',
 | 
				
			||||||
 | 
										color: 'primary',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'separate',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'button',
 | 
				
			||||||
 | 
									// 	btnName: '重置',
 | 
				
			||||||
 | 
									// 	name: 'reset',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'separate',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
					          type: this.$auth.hasPermi('base:packaging-print-model:create') ? 'button' : '',
 | 
				
			||||||
 | 
										btnName: '新增',
 | 
				
			||||||
 | 
										name: 'add',
 | 
				
			||||||
 | 
										color: 'success',
 | 
				
			||||||
 | 
										plain: true,
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'separate',
 | 
				
			||||||
 | 
									// 	type: this.$auth.hasPermi('base:product:create') ? 'separate' : '',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: this.$auth.hasPermi('base:product:export') ? 'button' : '',
 | 
				
			||||||
 | 
									// 	btnName: '导出',
 | 
				
			||||||
 | 
									// 	name: 'export',
 | 
				
			||||||
 | 
									// 	color: 'warning',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
								],
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						components: {
 | 
				
			||||||
 | 
					    AddOrUpdate,
 | 
				
			||||||
 | 
					    printModelDesign
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						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.packagingCode = val.packagingCode;
 | 
				
			||||||
 | 
					          this.listQuery.createTime = val.createTime;
 | 
				
			||||||
 | 
										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);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getModelData(data) {
 | 
				
			||||||
 | 
					      // console.log(data)
 | 
				
			||||||
 | 
					      // this.content = JSON.stringify(data)
 | 
				
			||||||
 | 
					      // this.dataForm.content = JSON.stringify(data)
 | 
				
			||||||
 | 
					      console.log(data)
 | 
				
			||||||
 | 
					      // this.content = JSON.stringify(data)
 | 
				
			||||||
 | 
					      this.obj.content = JSON.stringify(data)
 | 
				
			||||||
 | 
					      updatePackingModel(this.obj).then((response) => {
 | 
				
			||||||
 | 
					        // this.$modal.msgSuccess('修改成功');
 | 
				
			||||||
 | 
					        // this.visible = false;
 | 
				
			||||||
 | 
					        // this.$emit('refreshDataList');
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    otherMethods(val) {
 | 
				
			||||||
 | 
					      console.log(val)
 | 
				
			||||||
 | 
					      this.modelShow = true
 | 
				
			||||||
 | 
					      this.$nextTick(() => {
 | 
				
			||||||
 | 
					        this.obj = val.data
 | 
				
			||||||
 | 
					        this.$refs.printModelDesign.init(val.data.content)
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										15
									
								
								src/views/base/packagingPrintModel/unitDict.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/views/base/packagingPrintModel/unitDict.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,15 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <dict-tag
 | 
				
			||||||
 | 
					    :type="DICT_TYPE.UNIT_DICT"
 | 
				
			||||||
 | 
					    :value="injectData.unitDictValue" />
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						props: {
 | 
				
			||||||
 | 
							injectData: {
 | 
				
			||||||
 | 
								type: Object,
 | 
				
			||||||
 | 
								default: () => ({}),
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										65
									
								
								src/views/base/packagingPrintType/SmallTitle.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/views/base/packagingPrintType/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>
 | 
				
			||||||
							
								
								
									
										347
									
								
								src/views/base/packagingPrintType/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										347
									
								
								src/views/base/packagingPrintType/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,347 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2023-10-17 16:50:19
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-18 16:07:39
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <el-dialog :visible.sync="visible" :show-close="false" :wrapper-closable="false" width="40%">
 | 
				
			||||||
 | 
					    <small-title slot="title" :no-padding="true">
 | 
				
			||||||
 | 
					      {{ !dataForm.id ? '新增' : '编辑' }}
 | 
				
			||||||
 | 
					    </small-title>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <div class="content">
 | 
				
			||||||
 | 
					      <div class="visual-part">
 | 
				
			||||||
 | 
					        <el-form ref="dataForm" :model="dataForm" :rules="dataRule" label-width="100px"
 | 
				
			||||||
 | 
					          @keyup.enter.native="dataFormSubmit">
 | 
				
			||||||
 | 
					          <el-row :gutter="20">
 | 
				
			||||||
 | 
					            <el-col :span="12">
 | 
				
			||||||
 | 
					              <el-form-item label="名称" prop="name">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.name" clearable placeholder="名称" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					            <el-col :span="12">
 | 
				
			||||||
 | 
					              <el-form-item label="类型描述" prop="description">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.description" clearable placeholder="类型描述" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					          </el-row>
 | 
				
			||||||
 | 
					          <!-- <el-row :gutter="20">
 | 
				
			||||||
 | 
					            <el-col :span="24">
 | 
				
			||||||
 | 
					              <el-form-item label="完成单位产品用时" prop="processTime">
 | 
				
			||||||
 | 
					                <el-input v-model="dataForm.processTime" placeholder="请输入完成单位产品用时" />
 | 
				
			||||||
 | 
					              </el-form-item>
 | 
				
			||||||
 | 
					            </el-col>
 | 
				
			||||||
 | 
					          </el-row> -->
 | 
				
			||||||
 | 
					        </el-form>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        <!-- <small-title
 | 
				
			||||||
 | 
										style="margin: 16px 0; padding-left: 8px"
 | 
				
			||||||
 | 
										:no-padding="true">
 | 
				
			||||||
 | 
										产品属性列表
 | 
				
			||||||
 | 
									</small-title>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									<div class="attr-list">
 | 
				
			||||||
 | 
										<base-table
 | 
				
			||||||
 | 
											:table-props="tableProps"
 | 
				
			||||||
 | 
											:page="listQuery.pageNo"
 | 
				
			||||||
 | 
											:limit="listQuery.pageSize"
 | 
				
			||||||
 | 
											:add-button-show="isdetail ? null : '添加属性'"
 | 
				
			||||||
 | 
											@emitButtonClick="addNew()"
 | 
				
			||||||
 | 
											:table-data="productAttributeList">
 | 
				
			||||||
 | 
											<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>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <!-- <div style="position: absolute; bottom: 24px; right: 24px">
 | 
				
			||||||
 | 
								<el-button style="margin-right: 10px" @click="goback()">返回</el-button>
 | 
				
			||||||
 | 
								<el-button v-if="isdetail" type="primary" @click="goEdit()">
 | 
				
			||||||
 | 
									编辑
 | 
				
			||||||
 | 
								</el-button>
 | 
				
			||||||
 | 
								<span v-if="!isdetail">
 | 
				
			||||||
 | 
									<el-button type="primary" @click="dataFormSubmit()">保存</el-button>
 | 
				
			||||||
 | 
									<el-button
 | 
				
			||||||
 | 
										v-if="dataForm.id && !isdetail"
 | 
				
			||||||
 | 
										type="primary"
 | 
				
			||||||
 | 
										@click="addNew()">
 | 
				
			||||||
 | 
										添加属性
 | 
				
			||||||
 | 
									</el-button>
 | 
				
			||||||
 | 
								</span>
 | 
				
			||||||
 | 
							</div> -->
 | 
				
			||||||
 | 
					    <template slot="footer">
 | 
				
			||||||
 | 
					      <el-button style="" @click="goback()">取消</el-button>
 | 
				
			||||||
 | 
					      <!-- <el-button v-if="isdetail" type="primary" @click="goEdit()">
 | 
				
			||||||
 | 
									编辑
 | 
				
			||||||
 | 
								</el-button> -->
 | 
				
			||||||
 | 
					      <el-button type="primary" @click="dataFormSubmit()">确定</el-button>
 | 
				
			||||||
 | 
					    </template>
 | 
				
			||||||
 | 
					  </el-dialog>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
					  createPackingType,
 | 
				
			||||||
 | 
					  updatePackingType,
 | 
				
			||||||
 | 
					  getPackingType,
 | 
				
			||||||
 | 
					  // getWorkOrderList,
 | 
				
			||||||
 | 
					  // getCode,
 | 
				
			||||||
 | 
					  // getCustomerList,
 | 
				
			||||||
 | 
					  // getModelList
 | 
				
			||||||
 | 
					} from '@/api/base/modelType.js';
 | 
				
			||||||
 | 
					// import productAttrAdd from './attr-add';
 | 
				
			||||||
 | 
					import { parseTime } from '../mixins/code-filter';
 | 
				
			||||||
 | 
					import SmallTitle from './SmallTitle';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableBtn = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							type: 'edit',
 | 
				
			||||||
 | 
							btnName: '编辑',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							type: 'delete',
 | 
				
			||||||
 | 
							btnName: '删除',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'createTime',
 | 
				
			||||||
 | 
							label: '添加时间',
 | 
				
			||||||
 | 
							filter: parseTime,
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'name',
 | 
				
			||||||
 | 
							label: '属性名',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							prop: 'value',
 | 
				
			||||||
 | 
							label: '属性值',
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						components: { SmallTitle },
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								visible: false,
 | 
				
			||||||
 | 
								addOrUpdateVisible: false,
 | 
				
			||||||
 | 
								tableBtn,
 | 
				
			||||||
 | 
					      tableProps,
 | 
				
			||||||
 | 
					      customerList: [],
 | 
				
			||||||
 | 
					      modelList:[],
 | 
				
			||||||
 | 
					      workOrderList:[],
 | 
				
			||||||
 | 
								productAttributeList: [],
 | 
				
			||||||
 | 
								dataForm: {
 | 
				
			||||||
 | 
									id: null,
 | 
				
			||||||
 | 
									// name: '', // 产品名称
 | 
				
			||||||
 | 
					        name: '', // 产品编码
 | 
				
			||||||
 | 
									// area: 0, // 单位平方数(float only)
 | 
				
			||||||
 | 
					        description: null, // 产品类型id
 | 
				
			||||||
 | 
					        // workOrderId: null, // 单位产品用时 (s)
 | 
				
			||||||
 | 
					        // customerId: '', // 规格
 | 
				
			||||||
 | 
					        // content: '', // 单位id
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								listQuery: {
 | 
				
			||||||
 | 
									pageSize: 10,
 | 
				
			||||||
 | 
									pageNo: 1,
 | 
				
			||||||
 | 
									total: 0,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								dataRule: {
 | 
				
			||||||
 | 
									name: [
 | 
				
			||||||
 | 
										{
 | 
				
			||||||
 | 
											required: true,
 | 
				
			||||||
 | 
											message: '名称不能为空',
 | 
				
			||||||
 | 
											trigger: 'blur',
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									],
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								// isdetail: false,
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
						methods: {
 | 
				
			||||||
 | 
							// initData() {
 | 
				
			||||||
 | 
							// 	this.productAttributeList.splice(0);
 | 
				
			||||||
 | 
							// 	this.listQuery.total = 0;
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
					    init(id) {
 | 
				
			||||||
 | 
					      // this.getDict()
 | 
				
			||||||
 | 
								// this.initData();
 | 
				
			||||||
 | 
								// this.isdetail = isdetail || false;
 | 
				
			||||||
 | 
								this.dataForm.id = id || null;
 | 
				
			||||||
 | 
								this.visible = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								this.$nextTick(() => {
 | 
				
			||||||
 | 
									this.$refs['dataForm'].resetFields();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if (this.dataForm.id) {
 | 
				
			||||||
 | 
										// 获取产品详情
 | 
				
			||||||
 | 
					          getPackingType(id).then((response) => {
 | 
				
			||||||
 | 
											this.dataForm = response.data;
 | 
				
			||||||
 | 
										});
 | 
				
			||||||
 | 
										// 获取产品的属性列表
 | 
				
			||||||
 | 
										// this.getList();
 | 
				
			||||||
 | 
									} else {
 | 
				
			||||||
 | 
										// getCode().then((res) => {
 | 
				
			||||||
 | 
					          //   this.dataForm.packagingCode = res.data;
 | 
				
			||||||
 | 
										// });
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							// getDict() {
 | 
				
			||||||
 | 
					    //   // 获取产品的属性列表
 | 
				
			||||||
 | 
					    //   getCustomerList().then((response) => {
 | 
				
			||||||
 | 
					    //     console.log(response);
 | 
				
			||||||
 | 
					    //     this.customerList = response.data
 | 
				
			||||||
 | 
					    //     // this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
					    //   })
 | 
				
			||||||
 | 
					    //   getModelList().then((response) => {
 | 
				
			||||||
 | 
					    //     console.log(response);
 | 
				
			||||||
 | 
					    //     this.modelList = response.data
 | 
				
			||||||
 | 
					    //     // this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
					    //   })
 | 
				
			||||||
 | 
					    //   getWorkOrderList().then((response) => {
 | 
				
			||||||
 | 
					    //     // console.log(response);
 | 
				
			||||||
 | 
					    //     this.workOrderList = response.data
 | 
				
			||||||
 | 
							// 		// this.listQuery.total = response.data.total;
 | 
				
			||||||
 | 
							// 	})
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							// handleClick(raw) {
 | 
				
			||||||
 | 
							// 	if (raw.type === 'delete') {
 | 
				
			||||||
 | 
							// 		this.$confirm(
 | 
				
			||||||
 | 
							// 			`确定对${
 | 
				
			||||||
 | 
							// 				raw.data.name
 | 
				
			||||||
 | 
							// 					? '[名称=' + raw.data.name + ']'
 | 
				
			||||||
 | 
							// 					: '[序号=' + raw.data._pageIndex + ']'
 | 
				
			||||||
 | 
							// 			}进行删除操作?`,
 | 
				
			||||||
 | 
							// 			'提示',
 | 
				
			||||||
 | 
							// 			{
 | 
				
			||||||
 | 
							// 				confirmButtonText: '确定',
 | 
				
			||||||
 | 
							// 				cancelButtonText: '取消',
 | 
				
			||||||
 | 
							// 				type: 'warning',
 | 
				
			||||||
 | 
							// 			}
 | 
				
			||||||
 | 
							// 		)
 | 
				
			||||||
 | 
							// 			.then(() => {
 | 
				
			||||||
 | 
							// 				deleteProductAttr(raw.data.id).then(({ data }) => {
 | 
				
			||||||
 | 
							// 					this.$message({
 | 
				
			||||||
 | 
							// 						message: '操作成功',
 | 
				
			||||||
 | 
							// 						type: 'success',
 | 
				
			||||||
 | 
							// 						duration: 1500,
 | 
				
			||||||
 | 
							// 						onClose: () => {
 | 
				
			||||||
 | 
							// 							this.getList();
 | 
				
			||||||
 | 
							// 						},
 | 
				
			||||||
 | 
							// 					});
 | 
				
			||||||
 | 
							// 				});
 | 
				
			||||||
 | 
							// 			})
 | 
				
			||||||
 | 
							// 			.catch(() => {});
 | 
				
			||||||
 | 
							// 	} else {
 | 
				
			||||||
 | 
							// 		this.addNew(raw.data.id);
 | 
				
			||||||
 | 
							// 	}
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							// 表单提交
 | 
				
			||||||
 | 
							dataFormSubmit() {
 | 
				
			||||||
 | 
								this.$refs['dataForm'].validate((valid) => {
 | 
				
			||||||
 | 
									if (valid) {
 | 
				
			||||||
 | 
										// 修改的提交
 | 
				
			||||||
 | 
										if (this.dataForm.id) {
 | 
				
			||||||
 | 
					            updatePackingType(this.dataForm).then((response) => {
 | 
				
			||||||
 | 
												this.$modal.msgSuccess('修改成功');
 | 
				
			||||||
 | 
												this.visible = false;
 | 
				
			||||||
 | 
												this.$emit('refreshDataList');
 | 
				
			||||||
 | 
											});
 | 
				
			||||||
 | 
											return;
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
										// 添加的提交
 | 
				
			||||||
 | 
					          createPackingType(this.dataForm).then((response) => {
 | 
				
			||||||
 | 
											this.$modal.msgSuccess('新增成功');
 | 
				
			||||||
 | 
											this.visible = false;
 | 
				
			||||||
 | 
											this.$emit('refreshDataList');
 | 
				
			||||||
 | 
										});
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							// goEdit() {
 | 
				
			||||||
 | 
							// 	this.isdetail = false;
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							// // 新增 / 修改
 | 
				
			||||||
 | 
							// addNew(id) {
 | 
				
			||||||
 | 
							// 	this.addOrUpdateVisible = true;
 | 
				
			||||||
 | 
							// 	this.$nextTick(() => {
 | 
				
			||||||
 | 
							// 		this.$refs.addOrUpdate.init(id);
 | 
				
			||||||
 | 
							// 	});
 | 
				
			||||||
 | 
							// },
 | 
				
			||||||
 | 
							goback() {
 | 
				
			||||||
 | 
								this.$emit('refreshDataList');
 | 
				
			||||||
 | 
								this.visible = false;
 | 
				
			||||||
 | 
								// this.initData();
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</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> -->
 | 
				
			||||||
							
								
								
									
										191
									
								
								src/views/base/packagingPrintType/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										191
									
								
								src/views/base/packagingPrintType/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,191 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zwq
 | 
				
			||||||
 | 
					 * @Date: 2023-08-01 14:55:51
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @LastEditTime: 2023-10-18 16:11:22
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
						<div class="app-container">
 | 
				
			||||||
 | 
							<search-bar
 | 
				
			||||||
 | 
								:formConfigs="formConfig"
 | 
				
			||||||
 | 
								ref="searchBarForm"
 | 
				
			||||||
 | 
								@headBtnClick="buttonClick" />
 | 
				
			||||||
 | 
							<base-table
 | 
				
			||||||
 | 
								: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" />
 | 
				
			||||||
 | 
							<add-or-update
 | 
				
			||||||
 | 
								v-if="addOrUpdateVisible"
 | 
				
			||||||
 | 
								ref="addOrUpdate"
 | 
				
			||||||
 | 
								@refreshDataList="getDataList" />
 | 
				
			||||||
 | 
						</div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import AddOrUpdate from './add-or-updata';
 | 
				
			||||||
 | 
					// import unitDict from './unitDict';
 | 
				
			||||||
 | 
					import basicPage from '../mixins/basic-page';
 | 
				
			||||||
 | 
					import { parseTime } from '../mixins/code-filter';
 | 
				
			||||||
 | 
					import {
 | 
				
			||||||
 | 
						deletePackingType,
 | 
				
			||||||
 | 
					  getPackingTypePage,
 | 
				
			||||||
 | 
						// exportPackingExcel,
 | 
				
			||||||
 | 
					} from '@/api/base/modelType';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'name',
 | 
				
			||||||
 | 
					    label: '名称'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'description',
 | 
				
			||||||
 | 
							label: '描述'
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					    prop: 'createTime',
 | 
				
			||||||
 | 
							label: '生成日期',
 | 
				
			||||||
 | 
							filter: parseTime
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						mixins: [basicPage],
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								urlOptions: {
 | 
				
			||||||
 | 
					        getDataListURL: getPackingTypePage,
 | 
				
			||||||
 | 
									deleteURL: deletePackingType,
 | 
				
			||||||
 | 
									// exportURL: exportPackingExcel,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								tableProps,
 | 
				
			||||||
 | 
								tableBtn: [
 | 
				
			||||||
 | 
					        this.$auth.hasPermi(`base:packaging-print-log:update`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'edit',
 | 
				
			||||||
 | 
												btnName: '编辑',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					        this.$auth.hasPermi(`base:packaging-print-log:delete`)
 | 
				
			||||||
 | 
										? {
 | 
				
			||||||
 | 
												type: 'delete',
 | 
				
			||||||
 | 
												btnName: '删除',
 | 
				
			||||||
 | 
										  }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								].filter((v) => v),
 | 
				
			||||||
 | 
								tableData: [],
 | 
				
			||||||
 | 
								formConfig: [
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'input',
 | 
				
			||||||
 | 
					        //   label: '工单',
 | 
				
			||||||
 | 
					        //   placeholder: '工单',
 | 
				
			||||||
 | 
					        //   param: 'workOrderId',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
					        //   // parent: 'dateFilterType',
 | 
				
			||||||
 | 
					        //   // 日期选择
 | 
				
			||||||
 | 
					        //   type: 'datePicker',
 | 
				
			||||||
 | 
					        //   label: '时间',
 | 
				
			||||||
 | 
					        //   dateType: 'date',
 | 
				
			||||||
 | 
					        //   placeholder: '选择日期',
 | 
				
			||||||
 | 
					        //   format: 'yyyy-MM-dd',
 | 
				
			||||||
 | 
					        //   valueFormat: 'yyyy-MM-dd',
 | 
				
			||||||
 | 
					        //   param: 'createTime',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'button',
 | 
				
			||||||
 | 
										btnName: '搜索',
 | 
				
			||||||
 | 
										name: 'search',
 | 
				
			||||||
 | 
										color: 'primary',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'separate',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'button',
 | 
				
			||||||
 | 
									// 	btnName: '重置',
 | 
				
			||||||
 | 
									// 	name: 'reset',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										type: 'separate',
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
					          type: this.$auth.hasPermi('base:packaging-print-log:create') ? 'button' : '',
 | 
				
			||||||
 | 
										btnName: '新增',
 | 
				
			||||||
 | 
										name: 'add',
 | 
				
			||||||
 | 
										color: 'success',
 | 
				
			||||||
 | 
										plain: true,
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: 'separate',
 | 
				
			||||||
 | 
									// 	type: this.$auth.hasPermi('base:product:create') ? 'separate' : '',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
									// {
 | 
				
			||||||
 | 
									// 	type: this.$auth.hasPermi('base:product:export') ? 'button' : '',
 | 
				
			||||||
 | 
									// 	btnName: '导出',
 | 
				
			||||||
 | 
									// 	name: 'export',
 | 
				
			||||||
 | 
									// 	color: 'warning',
 | 
				
			||||||
 | 
									// },
 | 
				
			||||||
 | 
								],
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						components: {
 | 
				
			||||||
 | 
							AddOrUpdate,
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						created() {},
 | 
				
			||||||
 | 
						methods: {
 | 
				
			||||||
 | 
							buttonClick(val) {
 | 
				
			||||||
 | 
								switch (val.btnName) {
 | 
				
			||||||
 | 
									case 'search':
 | 
				
			||||||
 | 
										this.listQuery.pageNo = 1;
 | 
				
			||||||
 | 
										this.listQuery.pageSize = 10;
 | 
				
			||||||
 | 
					          this.listQuery.packagingCode = val.packagingCode;
 | 
				
			||||||
 | 
					          this.listQuery.createTime = val.createTime;
 | 
				
			||||||
 | 
										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);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							otherMethods(val) {
 | 
				
			||||||
 | 
								this.addOrUpdateVisible = true;
 | 
				
			||||||
 | 
								this.addOrEditTitle = '详情';
 | 
				
			||||||
 | 
								this.$nextTick(() => {
 | 
				
			||||||
 | 
									this.$refs.addOrUpdate.init(val.data.id, true);
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										15
									
								
								src/views/base/packagingPrintType/unitDict.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								src/views/base/packagingPrintType/unitDict.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,15 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <dict-tag
 | 
				
			||||||
 | 
					    :type="DICT_TYPE.UNIT_DICT"
 | 
				
			||||||
 | 
					    :value="injectData.unitDictValue" />
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						props: {
 | 
				
			||||||
 | 
							injectData: {
 | 
				
			||||||
 | 
								type: Object,
 | 
				
			||||||
 | 
								default: () => ({}),
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
										
											Binary file not shown.
										
									
								
							| 
		 Before Width: | Height: | Size: 42 KiB  | 
										
											Binary file not shown.
										
									
								
							| 
		 Before Width: | Height: | Size: 50 KiB  | 
										
											Binary file not shown.
										
									
								
							| 
		 Before Width: | Height: | Size: 78 KiB  | 
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user