projects/mesxc-zhp #161
							
								
								
									
										2
									
								
								.env.dev
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								.env.dev
									
									
									
									
									
								
							@@ -20,7 +20,7 @@ VUE_APP_BASE_API = 'http://10.70.2.2:8080'
 | 
			
		||||
# VUE_APP_BASE_API = 'http://192.168.1.8:48082'
 | 
			
		||||
# VUE_APP_BASE_API = 'http://192.168.4.159:48080'
 | 
			
		||||
# VUE_APP_BASE_API = 'http://192.168.1.56:48082'
 | 
			
		||||
# VUE_APP_BASE_API = 'http://192.168.4.159:48080'
 | 
			
		||||
# VUE_APP_BASE_API = 'http://192.168.1.62:48082'
 | 
			
		||||
 | 
			
		||||
# 积木报表指向地址
 | 
			
		||||
VUE_APP_JIMU_API = 'http://192.168.0.33:48082'
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										78
									
								
								src/api/cost/costEneryAutoReport.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								src/api/cost/costEneryAutoReport.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,78 @@
 | 
			
		||||
/*
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2023-11-23 14:57:00
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-12-07 09:37:18
 | 
			
		||||
 * @Description:
 | 
			
		||||
 */
 | 
			
		||||
import request from '@/utils/request'
 | 
			
		||||
 | 
			
		||||
// 创建能源自动记录报
 | 
			
		||||
export function createCostEneryAutoReport(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-enery-auto-report/create',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 更新能源自动记录报
 | 
			
		||||
export function updateCostEneryAutoReport(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-enery-auto-report/update',
 | 
			
		||||
    method: 'put',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 删除能源自动记录报
 | 
			
		||||
export function deleteCostEneryAutoReport(id) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-enery-auto-report/delete?id=' + id,
 | 
			
		||||
    method: 'delete'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得能源自动记录报
 | 
			
		||||
export function getCostEneryAutoReport(id) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-enery-auto-report/get?id=' + id,
 | 
			
		||||
    method: 'get'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得能源自动记录报分页历史
 | 
			
		||||
export function getCostEneryAutoReportPage(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-enery-auto-report/page',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
// 获得能源查询
 | 
			
		||||
export function getCostEneryAutoPage(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-energy-search/getData',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
// 导出能源自动记录报 Excel
 | 
			
		||||
export function exportCostEneryAutoReportExcel(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-enery-auto-report/export-excel',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data,
 | 
			
		||||
    responseType: 'blob'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 导出能源自动记录报 Excel 查询
 | 
			
		||||
export function exportCostEneryExcel(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-energy-search/export-excel',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data,
 | 
			
		||||
    responseType: 'blob'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										73
									
								
								src/api/cost/costMaterialAutoReport.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								src/api/cost/costMaterialAutoReport.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,73 @@
 | 
			
		||||
import request from '@/utils/request'
 | 
			
		||||
 | 
			
		||||
// 创建原料成本自动统计报
 | 
			
		||||
export function createCostMaterialAutoReport(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-auto-report/create',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 更新原料成本自动统计报
 | 
			
		||||
export function updateCostMaterialAutoReport(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-auto-report/update',
 | 
			
		||||
    method: 'put',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 删除原料成本自动统计报
 | 
			
		||||
export function deleteCostMaterialAutoReport(id) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-auto-report/delete?id=' + id,
 | 
			
		||||
    method: 'delete'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得原料成本自动统计报
 | 
			
		||||
export function getCostMaterialAutoReport(id) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-auto-report/get?id=' + id,
 | 
			
		||||
    method: 'get'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得原料成本自动统计报分页历史
 | 
			
		||||
export function getCostMaterialAutoReportPage(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-auto-report/page',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得原料成本查询
 | 
			
		||||
export function getCostMaterialSearchPage(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-search/getData',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 导出原料成本自动统计报 Excel
 | 
			
		||||
export function exportCostMaterialAutoReportExcel(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-auto-report/export-excel',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data,
 | 
			
		||||
    responseType: 'blob'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 导出原料成本自动统计报 Excel查询
 | 
			
		||||
export function exportCostMaterialSearch(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-search/export-excel',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data,
 | 
			
		||||
    responseType: 'blob'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										61
									
								
								src/api/cost/costMaterialSet.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								src/api/cost/costMaterialSet.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,61 @@
 | 
			
		||||
/*
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2023-11-15 09:24:30
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-12-05 14:38:48
 | 
			
		||||
 * @Description:
 | 
			
		||||
 */
 | 
			
		||||
import request from '@/utils/request'
 | 
			
		||||
 | 
			
		||||
// 创建原料价位配置
 | 
			
		||||
export function createCostMaterialSet(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-set/create',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 更新原料价位配置
 | 
			
		||||
export function updateCostMaterialSet(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-set/update',
 | 
			
		||||
    method: 'put',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 删除原料价位配置
 | 
			
		||||
export function deleteCostMaterialSet(id) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-set/delete?id=' + id,
 | 
			
		||||
    method: 'delete'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得原料价位配置
 | 
			
		||||
export function getCostMaterialSet(id) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-set/get?id=' + id,
 | 
			
		||||
    method: 'get'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得原料价位配置分页
 | 
			
		||||
export function getCostMaterialSetPage(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-set/page',
 | 
			
		||||
    method: 'POST',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 导出原料价位配置 Excel
 | 
			
		||||
export function exportCostMaterialSetExcel(query) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/extend/cost-material-set/export-excel',
 | 
			
		||||
    method: 'get',
 | 
			
		||||
    params: query,
 | 
			
		||||
    responseType: 'blob'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										92
									
								
								src/api/safetyEnvironmental/environmental.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								src/api/safetyEnvironmental/environmental.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,92 @@
 | 
			
		||||
import request from '@/utils/request'
 | 
			
		||||
 | 
			
		||||
// 获得环保检测指标实时数据
 | 
			
		||||
export function environmentalCheckRealtime(query) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check/realtime',
 | 
			
		||||
    method: 'get',
 | 
			
		||||
    params: query
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得环保检测指标趋势数据
 | 
			
		||||
export function environmentalCheckRealtimeTrend(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check-record/trend',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得环保检测指标分页
 | 
			
		||||
export function environmentalCheckPage(query) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check/page',
 | 
			
		||||
    method: 'get',
 | 
			
		||||
    params: query
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 创建环保检测指标
 | 
			
		||||
export function environmentalCheckCreate(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check/create',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 更新环保检测指标
 | 
			
		||||
export function environmentalCheckUpdate(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check/update',
 | 
			
		||||
    method: 'put',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得环保检测指标
 | 
			
		||||
export function environmentalCheckGet(query) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check/get',
 | 
			
		||||
    method: 'get',
 | 
			
		||||
    params: query
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 删除环保检测指标
 | 
			
		||||
export function environmentalCheckDelete(query) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check/delete',
 | 
			
		||||
    method: 'delete',
 | 
			
		||||
    params: query
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获得环保检测记录分页
 | 
			
		||||
export function environmentalCheckRecordPage(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check-record/page',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 导出环保检测记录 Excel
 | 
			
		||||
export function environmentalCheckRecordExport(data) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check-record/export-excel',
 | 
			
		||||
    method: 'post',
 | 
			
		||||
    data: data,
 | 
			
		||||
    responseType: 'blob'
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 获取环保检测指标code
 | 
			
		||||
export function getEnvironmentalCheckCode(query) {
 | 
			
		||||
  return request({
 | 
			
		||||
    url: '/base/environmental-check/getCode',
 | 
			
		||||
    method: 'get',
 | 
			
		||||
    params: query
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								src/assets/images/choicepart/Cost.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/assets/images/choicepart/Cost.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 15 KiB  | 
							
								
								
									
										
											BIN
										
									
								
								src/assets/images/choicepart/Databoard.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/assets/images/choicepart/Databoard.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 12 KiB  | 
							
								
								
									
										
											BIN
										
									
								
								src/assets/images/choicepart/SafetyEnvironmental.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/assets/images/choicepart/SafetyEnvironmental.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 15 KiB  | 
							
								
								
									
										
											BIN
										
									
								
								src/assets/images/detectionData.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/assets/images/detectionData.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 1.6 KiB  | 
@@ -106,6 +106,9 @@ export const DICT_TYPE = {
 | 
			
		||||
  // ============== EQUIPMENT - 设备模块 =============
 | 
			
		||||
  MAINTAIN_TYPE: 'maintain_type',
 | 
			
		||||
  FAULT_LEVEL: 'fault-level',
 | 
			
		||||
 | 
			
		||||
  // ============== ENVIRONMENTAL - 环保模块 =============
 | 
			
		||||
  ENVIRONMENT_CHECK_UNIT: 'environment_check_unit'
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
  <div class="choicepart-container">
 | 
			
		||||
    <navbar />
 | 
			
		||||
    <div class="choicepart-wrapper">
 | 
			
		||||
      <div class="choicepart-box" id="choicepartBox" :style="'transform:scale('+scale+');width:1574px;height:538px;'" v-show="showItem">
 | 
			
		||||
      <div class="choicepart-box" id="choicepartBox" :style="'transform:scale('+scale+');width:1710px;height:538px;'" v-show="showItem">
 | 
			
		||||
      <div class="choicepart-line1">
 | 
			
		||||
        <div
 | 
			
		||||
          v-for="(item, index) in menuArr1"
 | 
			
		||||
@@ -102,9 +102,7 @@ export default {
 | 
			
		||||
          meta: {
 | 
			
		||||
            title: ''
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
      ],
 | 
			
		||||
      menuArr2: [
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          name: 'Packaging',
 | 
			
		||||
          title: '包装管理',
 | 
			
		||||
@@ -112,7 +110,9 @@ export default {
 | 
			
		||||
          meta: {
 | 
			
		||||
            title: ''
 | 
			
		||||
          }
 | 
			
		||||
        },
 | 
			
		||||
        }
 | 
			
		||||
      ],
 | 
			
		||||
      menuArr2: [
 | 
			
		||||
        {
 | 
			
		||||
          name: 'Material',
 | 
			
		||||
          title: '物料管理',
 | 
			
		||||
@@ -129,17 +129,41 @@ export default {
 | 
			
		||||
            title: ''
 | 
			
		||||
          }
 | 
			
		||||
        },
 | 
			
		||||
        // {
 | 
			
		||||
        //   name: 'Delivery',
 | 
			
		||||
        //   title: '成品发货',
 | 
			
		||||
        //   visible: false,
 | 
			
		||||
        //   meta: {
 | 
			
		||||
        //     title: ''
 | 
			
		||||
        //   }
 | 
			
		||||
        // },
 | 
			
		||||
        {
 | 
			
		||||
          name: 'Delivery',
 | 
			
		||||
          title: '成品发货',
 | 
			
		||||
          name: 'Report',
 | 
			
		||||
          title: '报表管理',
 | 
			
		||||
          visible: false,
 | 
			
		||||
          meta: {
 | 
			
		||||
            title: ''
 | 
			
		||||
          }
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          name: 'Report',
 | 
			
		||||
          title: '报表管理',
 | 
			
		||||
          name: 'Cost',
 | 
			
		||||
          title: '成本管理',
 | 
			
		||||
          visible: false,
 | 
			
		||||
          meta: {
 | 
			
		||||
            title: ''
 | 
			
		||||
          }
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          name: 'SafetyEnvironmental',
 | 
			
		||||
          title: '安环管理',
 | 
			
		||||
          visible: false,
 | 
			
		||||
          meta: {
 | 
			
		||||
            title: ''
 | 
			
		||||
          }
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          name: 'Databoard',
 | 
			
		||||
          title: '数据驾驶舱',
 | 
			
		||||
          visible: false,
 | 
			
		||||
          meta: {
 | 
			
		||||
            title: ''
 | 
			
		||||
@@ -176,7 +200,7 @@ export default {
 | 
			
		||||
      console.log(menuList)
 | 
			
		||||
      if (menuList.length > 0) {
 | 
			
		||||
        for (let i = 0; i < menuList.length; i ++) {
 | 
			
		||||
          for (let k = 0; k < 7; k++) {
 | 
			
		||||
          for (let k = 0; k < 8; k++) {
 | 
			
		||||
            if (menuList[i].name === this.menuArr1[k].name) {
 | 
			
		||||
              this.menuArr1[k].visible = true
 | 
			
		||||
              this.menuArr1[k].id = menuList[i].id
 | 
			
		||||
@@ -185,7 +209,7 @@ export default {
 | 
			
		||||
              this.menuArr1[k].meta = menuList[i].meta
 | 
			
		||||
            }
 | 
			
		||||
          }
 | 
			
		||||
          for (let j = 0; j < 6; j++) {
 | 
			
		||||
          for (let j = 0; j < 7; j++) {
 | 
			
		||||
            if (menuList[i].name === this.menuArr2[j].name) {
 | 
			
		||||
              this.menuArr2[j].visible = true
 | 
			
		||||
              this.menuArr2[j].id = menuList[i].id
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										162
									
								
								src/views/cost/energyCost/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										162
									
								
								src/views/cost/energyCost/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,162 @@
 | 
			
		||||
<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"></base-table>
 | 
			
		||||
		<pagination
 | 
			
		||||
			:limit.sync="listQuery.pageSize"
 | 
			
		||||
			:page.sync="listQuery.pageNo"
 | 
			
		||||
			:total="listQuery.total"
 | 
			
		||||
			@pagination="getDataList" />
 | 
			
		||||
	</div>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
import basicPage from '../mixins/basic-page';
 | 
			
		||||
import codeFilter from '../mixins/code-filter';
 | 
			
		||||
import {
 | 
			
		||||
	getCostEneryAutoPage,
 | 
			
		||||
	exportCostEneryExcel,
 | 
			
		||||
} from '@/api/cost/costEneryAutoReport';
 | 
			
		||||
import { getEnergyTypeListAll } from '@/api/base/energyType';
 | 
			
		||||
import { publicFormatter } from '@/utils/dict';
 | 
			
		||||
 | 
			
		||||
const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'energyTypeName',
 | 
			
		||||
		label: '能源类型',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'objName',
 | 
			
		||||
		label: '监控对象',
 | 
			
		||||
		filter: (val) => (val != null ? val : '--'),
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'tableName',
 | 
			
		||||
		label: '水/气表名',
 | 
			
		||||
		filter: (val) => (val != null ? val : '--'),
 | 
			
		||||
		filter: publicFormatter('table_name'),
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'totalUsed',
 | 
			
		||||
		label: '累计使用量',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'totalCost',
 | 
			
		||||
		label: '总价',
 | 
			
		||||
		align: 'right',
 | 
			
		||||
	},
 | 
			
		||||
];
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
	mixins: [basicPage],
 | 
			
		||||
	data() {
 | 
			
		||||
		return {
 | 
			
		||||
			urlOptions: {
 | 
			
		||||
				getDataListURL: getCostEneryAutoPage,
 | 
			
		||||
        exportURL: exportCostEneryExcel
 | 
			
		||||
			},
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			tableProps,
 | 
			
		||||
			drawerVisible: false,
 | 
			
		||||
			formConfig: [
 | 
			
		||||
				{
 | 
			
		||||
					type: 'select',
 | 
			
		||||
					label: '能源类型',
 | 
			
		||||
					selectOptions: [],
 | 
			
		||||
					param: 'energyTypeId',
 | 
			
		||||
					filterable: true,
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'datePicker',
 | 
			
		||||
					label: '时间范围',
 | 
			
		||||
					dateType: 'daterange',
 | 
			
		||||
					format: 'yyyy-MM-dd',
 | 
			
		||||
					valueFormat: 'timestamp',
 | 
			
		||||
					rangeSeparator: '-',
 | 
			
		||||
					startPlaceholder: '开始时间',
 | 
			
		||||
					endPlaceholder: '结束时间',
 | 
			
		||||
					param: 'searchTime',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'button',
 | 
			
		||||
					btnName: '查询',
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('cost:energyCost:export')
 | 
			
		||||
						? 'button'
 | 
			
		||||
						: '',
 | 
			
		||||
					btnName: '导出',
 | 
			
		||||
					name: 'export',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
	components: {},
 | 
			
		||||
	created() {
 | 
			
		||||
		getEnergyTypeListAll().then((response) => {
 | 
			
		||||
			this.formConfig[0].selectOptions = response.data;
 | 
			
		||||
		});
 | 
			
		||||
	},
 | 
			
		||||
	methods: {
 | 
			
		||||
    // 获取数据列表
 | 
			
		||||
    getDataList() {
 | 
			
		||||
      if(this.listQuery.searchTime){
 | 
			
		||||
      this.dataListLoading = true;
 | 
			
		||||
      this.urlOptions.getDataListURL(this.listQuery).then(response => {
 | 
			
		||||
        if(response.hasOwnProperty('data')){
 | 
			
		||||
          this.tableData = response.data.list;
 | 
			
		||||
          this.listQuery.total = response.data.total;
 | 
			
		||||
        }
 | 
			
		||||
        this.dataListLoading = false;
 | 
			
		||||
      });
 | 
			
		||||
    }else{
 | 
			
		||||
      this.$message.warning('请选择时间范围')
 | 
			
		||||
    }
 | 
			
		||||
    },
 | 
			
		||||
		buttonClick(val) {
 | 
			
		||||
			switch (val.btnName) {
 | 
			
		||||
				case 'search':
 | 
			
		||||
					this.listQuery.pageNo = 1;
 | 
			
		||||
					this.listQuery.pageSize = 10;
 | 
			
		||||
					this.listQuery.energyTypeId = val.energyTypeId;
 | 
			
		||||
          this.listQuery.searchTime = val.searchTime ? val.searchTime[0] : null;
 | 
			
		||||
					this.listQuery.startTime = val.searchTime ? val.searchTime[0] : null;
 | 
			
		||||
					this.listQuery.endTime = val.searchTime ? val.searchTime[1] : null;
 | 
			
		||||
					this.getDataList();
 | 
			
		||||
					break;
 | 
			
		||||
				case 'export':
 | 
			
		||||
          const data = {
 | 
			
		||||
            energyTypeId:val.energyTypeId,
 | 
			
		||||
            startTime : val.searchTime ? val.searchTime[0] : null,
 | 
			
		||||
            endTime : val.searchTime ? val.searchTime[1] : null,
 | 
			
		||||
          }
 | 
			
		||||
					this.handleExport(data);
 | 
			
		||||
					break;
 | 
			
		||||
				default:
 | 
			
		||||
					console.log(val);
 | 
			
		||||
			}
 | 
			
		||||
		},
 | 
			
		||||
	},
 | 
			
		||||
};
 | 
			
		||||
</script>
 | 
			
		||||
<style>
 | 
			
		||||
.app-container .el-table .el-table__cell {
 | 
			
		||||
	padding: 0;
 | 
			
		||||
	height: 35px;
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
							
								
								
									
										173
									
								
								src/views/cost/energyCostHis/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										173
									
								
								src/views/cost/energyCostHis/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,173 @@
 | 
			
		||||
<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"></base-table>
 | 
			
		||||
		<pagination
 | 
			
		||||
			:limit.sync="listQuery.pageSize"
 | 
			
		||||
			:page.sync="listQuery.pageNo"
 | 
			
		||||
			:total="listQuery.total"
 | 
			
		||||
			@pagination="getDataList" />
 | 
			
		||||
	</div>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
import basicPage from '../mixins/basic-page';
 | 
			
		||||
import codeFilter from '../mixins/code-filter';
 | 
			
		||||
import {
 | 
			
		||||
	getCostEneryAutoReportPage,
 | 
			
		||||
	exportCostEneryAutoReportExcel,
 | 
			
		||||
} from '@/api/cost/costEneryAutoReport';
 | 
			
		||||
import { getEnergyTypeListAll } from '@/api/base/energyType';
 | 
			
		||||
import { publicFormatter } from '@/utils/dict';
 | 
			
		||||
 | 
			
		||||
const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'reportType',
 | 
			
		||||
		label: '维度',
 | 
			
		||||
		filter: codeFilter('reportType'),
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'reportName',
 | 
			
		||||
		label: '时间',
 | 
			
		||||
		minWidth: 150,
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'energyType',
 | 
			
		||||
		label: '能源类型',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'objName',
 | 
			
		||||
		label: '监控对象',
 | 
			
		||||
		filter: (val) => (val != null ? val : '--'),
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'tableName',
 | 
			
		||||
		label: '水/气表名',
 | 
			
		||||
		filter: (val) => (val != null ? val : '--'),
 | 
			
		||||
		filter: publicFormatter('table_name'),
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'totalUsed',
 | 
			
		||||
		label: '累计使用量',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'totalCost',
 | 
			
		||||
		label: '总价',
 | 
			
		||||
		align: 'right',
 | 
			
		||||
	},
 | 
			
		||||
];
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
	mixins: [basicPage],
 | 
			
		||||
	data() {
 | 
			
		||||
		return {
 | 
			
		||||
			urlOptions: {
 | 
			
		||||
				getDataListURL: getCostEneryAutoReportPage,
 | 
			
		||||
				exportURL: exportCostEneryAutoReportExcel,
 | 
			
		||||
			},
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			tableProps,
 | 
			
		||||
			drawerVisible: false,
 | 
			
		||||
			listQuery: {
 | 
			
		||||
				reportType: 2,
 | 
			
		||||
			},
 | 
			
		||||
			formConfig: [
 | 
			
		||||
				{
 | 
			
		||||
					type: 'select',
 | 
			
		||||
					label: '维度',
 | 
			
		||||
					selectOptions: [
 | 
			
		||||
						{ id: 2, name: '日' },
 | 
			
		||||
						{ id: 3, name: '周' },
 | 
			
		||||
						{ id: 4, name: '月' },
 | 
			
		||||
						{ id: 5, name: '年' },
 | 
			
		||||
					],
 | 
			
		||||
					param: 'reportType',
 | 
			
		||||
					filterable: true,
 | 
			
		||||
					defaultSelect: 2, // 默认值
 | 
			
		||||
					clearable: false,
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'select',
 | 
			
		||||
					label: '能源类型',
 | 
			
		||||
					selectOptions: [],
 | 
			
		||||
					param: 'energyTypeId',
 | 
			
		||||
					filterable: true,
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'datePicker',
 | 
			
		||||
					label: '时间范围',
 | 
			
		||||
					dateType: 'daterange',
 | 
			
		||||
					format: 'yyyy-MM-dd',
 | 
			
		||||
					valueFormat: 'timestamp',
 | 
			
		||||
					rangeSeparator: '-',
 | 
			
		||||
					startPlaceholder: '开始时间',
 | 
			
		||||
					endPlaceholder: '结束时间',
 | 
			
		||||
					param: 'searchTime',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'button',
 | 
			
		||||
					btnName: '查询',
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('cost:energyCostHis:export')
 | 
			
		||||
						? 'button'
 | 
			
		||||
						: '',
 | 
			
		||||
					btnName: '导出',
 | 
			
		||||
					name: 'export',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
	components: {},
 | 
			
		||||
	created() {
 | 
			
		||||
		getEnergyTypeListAll().then((response) => {
 | 
			
		||||
			this.formConfig[1].selectOptions = response.data;
 | 
			
		||||
		});
 | 
			
		||||
	},
 | 
			
		||||
	methods: {
 | 
			
		||||
		buttonClick(val) {
 | 
			
		||||
			switch (val.btnName) {
 | 
			
		||||
				case 'search':
 | 
			
		||||
					this.listQuery.pageNo = 1;
 | 
			
		||||
					this.listQuery.pageSize = 10;
 | 
			
		||||
					this.listQuery.reportType = val.reportType;
 | 
			
		||||
					this.listQuery.energyTypeId = val.energyTypeId;
 | 
			
		||||
					this.listQuery.reportTime = val.searchTime ? val.searchTime : null;
 | 
			
		||||
					this.getDataList();
 | 
			
		||||
					break;
 | 
			
		||||
				case 'export':
 | 
			
		||||
          const data = {
 | 
			
		||||
            reportType: val.reportType,
 | 
			
		||||
            energyTypeId: val.energyTypeId,
 | 
			
		||||
            reportTime: val.searchTime ? val.searchTime : null
 | 
			
		||||
          }
 | 
			
		||||
					this.handleExport(data);
 | 
			
		||||
					break;
 | 
			
		||||
				default:
 | 
			
		||||
					console.log(val);
 | 
			
		||||
			}
 | 
			
		||||
		},
 | 
			
		||||
	},
 | 
			
		||||
};
 | 
			
		||||
</script>
 | 
			
		||||
<style>
 | 
			
		||||
.app-container .el-table .el-table__cell {
 | 
			
		||||
	padding: 0;
 | 
			
		||||
	height: 35px;
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
							
								
								
									
										121
									
								
								src/views/cost/mixins/basic-add.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										121
									
								
								src/views/cost/mixins/basic-add.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,121 @@
 | 
			
		||||
/*
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2022-08-24 11:19:43
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-02 15:33:39
 | 
			
		||||
 * @Description:
 | 
			
		||||
 */
 | 
			
		||||
import { listData } from "@/api/system/dict/data";
 | 
			
		||||
export default {
 | 
			
		||||
  data() {
 | 
			
		||||
    /* eslint-disable */
 | 
			
		||||
    return {
 | 
			
		||||
      urlOptions: {
 | 
			
		||||
        createURL: '',
 | 
			
		||||
        updateURL: '',
 | 
			
		||||
        infoURL: '',
 | 
			
		||||
        codeURL: '',
 | 
			
		||||
        getOption: false, //是否加载获取下拉框方法
 | 
			
		||||
        isGetCode: false, //是否加载获取code方法
 | 
			
		||||
        getDictList: false, //是否加载获取数据字典方法
 | 
			
		||||
        optionArrUrl: [], //需要获取下拉框的方法数组
 | 
			
		||||
        optionArr: {}, //需要获取下拉框的方法数组的返回结果
 | 
			
		||||
        dictList: {}, //需要获取数据字典的方法数组的返回结果
 | 
			
		||||
      },
 | 
			
		||||
      visible: false,
 | 
			
		||||
      setData: false
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  created() {
 | 
			
		||||
  },
 | 
			
		||||
  activated() {
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    init(id) {
 | 
			
		||||
      this.dataForm.id = id || "";
 | 
			
		||||
      this.visible = true;
 | 
			
		||||
      if (this.urlOptions.getOption) {
 | 
			
		||||
        this.getArr()
 | 
			
		||||
      }
 | 
			
		||||
      if (this.urlOptions.getDictList) {
 | 
			
		||||
        this.getDict()
 | 
			
		||||
      }
 | 
			
		||||
      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(() => {
 | 
			
		||||
          });
 | 
			
		||||
      });
 | 
			
		||||
    },
 | 
			
		||||
    /** 查询字典数据列表 */
 | 
			
		||||
    getDict() {
 | 
			
		||||
      this.nameList.forEach((item,index)=>{
 | 
			
		||||
        const queryParams = {
 | 
			
		||||
          pageNo: 1,
 | 
			
		||||
          pageSize: 99,
 | 
			
		||||
          dictType: item,
 | 
			
		||||
        }
 | 
			
		||||
        listData(queryParams).then(response => {
 | 
			
		||||
          this.$set(this.urlOptions.dictList, `dict${index}`, response.data.list)
 | 
			
		||||
        });
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    // 表单提交
 | 
			
		||||
    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() {
 | 
			
		||||
      if (this.$refs.dataForm!==undefined) {
 | 
			
		||||
          this.$refs.dataForm.resetFields();
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										172
									
								
								src/views/cost/mixins/basic-page.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										172
									
								
								src/views/cost/mixins/basic-page.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,172 @@
 | 
			
		||||
/*
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2022-08-24 11:19:43
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-12-07 09:35:33
 | 
			
		||||
 * @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,
 | 
			
		||||
      addOrUpdate:'addOrUpdate'
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  created() {
 | 
			
		||||
  },
 | 
			
		||||
  mounted() {
 | 
			
		||||
    this.getDataList()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    // 获取数据列表
 | 
			
		||||
    getDataList() {
 | 
			
		||||
      this.dataListLoading = true;
 | 
			
		||||
      this.urlOptions.getDataListURL(this.listQuery).then(response => {
 | 
			
		||||
        if(response.hasOwnProperty('data')){
 | 
			
		||||
          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[this.addOrUpdate].formClear()
 | 
			
		||||
      this.addOrUpdateVisible = false
 | 
			
		||||
      this.addOrEditTitle = ''
 | 
			
		||||
      this.addOrUpdate = 'addOrUpdate'
 | 
			
		||||
    },
 | 
			
		||||
    handleConfirm() {
 | 
			
		||||
      this.$refs[this.addOrUpdate].dataFormSubmit()
 | 
			
		||||
    },
 | 
			
		||||
    successSubmit() {
 | 
			
		||||
      this.handleCancel()
 | 
			
		||||
      this.getDataList()
 | 
			
		||||
    },
 | 
			
		||||
    /** 导出按钮操作 */
 | 
			
		||||
    handleExport(data) {
 | 
			
		||||
      // 处理查询参数
 | 
			
		||||
      let params = data?{ ...data }:{ ...this.listQuery };
 | 
			
		||||
      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(() => { });
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										79
									
								
								src/views/cost/mixins/code-filter.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								src/views/cost/mixins/code-filter.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,79 @@
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * @Date: 2020-12-29 16:49:28
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-12-07 10:00:51
 | 
			
		||||
 * @FilePath: \basic-admin\src\filters\basicData\index.js
 | 
			
		||||
 * @Description:
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
const table = {
 | 
			
		||||
  lineStatus: {
 | 
			
		||||
    1: '生产中',
 | 
			
		||||
    2: '停止',
 | 
			
		||||
    3: '未知',
 | 
			
		||||
  },
 | 
			
		||||
  deactivate: {
 | 
			
		||||
    1: '启用',
 | 
			
		||||
    0: '停用',
 | 
			
		||||
  },
 | 
			
		||||
  wareType: {
 | 
			
		||||
    1: '缓存',
 | 
			
		||||
    2: '活动',
 | 
			
		||||
    3: '其它',
 | 
			
		||||
  },
 | 
			
		||||
  reportType: {
 | 
			
		||||
    2: '日',
 | 
			
		||||
    3: '周',
 | 
			
		||||
    4: '月',
 | 
			
		||||
    5: '年',
 | 
			
		||||
  },
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 日期格式化
 | 
			
		||||
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]
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										23
									
								
								src/views/cost/mixins/connectTime.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								src/views/cost/mixins/connectTime.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,23 @@
 | 
			
		||||
<!--
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2023-12-05 13:45:59
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:54:40
 | 
			
		||||
 * @Description
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
	<div>
 | 
			
		||||
		<span>{{ parseTime(injectData.enableTime,'{y}年{m}月{d}日') + '-' + (parseTime(injectData.disableTime)?parseTime(injectData.disableTime,'{y}年{m}月{d}日'):'永久') }}</span>
 | 
			
		||||
	</div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
export default {
 | 
			
		||||
	name: '',
 | 
			
		||||
	props: {
 | 
			
		||||
		injectData: {
 | 
			
		||||
			type: Object,
 | 
			
		||||
			default: () => ({}),
 | 
			
		||||
		},
 | 
			
		||||
	},
 | 
			
		||||
};
 | 
			
		||||
</script>
 | 
			
		||||
							
								
								
									
										166
									
								
								src/views/cost/rawMaterialConfig/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								src/views/cost/rawMaterialConfig/add-or-updata.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,166 @@
 | 
			
		||||
<!--
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2023-08-01 13:52:10
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-12-05 15:41:39
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
	<el-form
 | 
			
		||||
		:model="dataForm"
 | 
			
		||||
		:rules="dataRule"
 | 
			
		||||
		ref="dataForm"
 | 
			
		||||
		v-if="visible"
 | 
			
		||||
		@keyup.enter.native="dataFormSubmit()"
 | 
			
		||||
		label-width="100px"
 | 
			
		||||
		label-position="top">
 | 
			
		||||
		<el-row :gutter="20">
 | 
			
		||||
			<el-col :span="12">
 | 
			
		||||
				<el-form-item label="原料名称" prop="materialId">
 | 
			
		||||
					<el-select
 | 
			
		||||
						v-model="dataForm.materialId"
 | 
			
		||||
						filterable
 | 
			
		||||
						clearable
 | 
			
		||||
						@change="setCode"
 | 
			
		||||
						:style="{ width: '100%' }"
 | 
			
		||||
						placeholder="请选择原料名称">
 | 
			
		||||
						<el-option
 | 
			
		||||
							v-for="item in MaterialList"
 | 
			
		||||
							:key="item.id"
 | 
			
		||||
							:label="item.name"
 | 
			
		||||
							:value="item.id"></el-option>
 | 
			
		||||
					</el-select>
 | 
			
		||||
				</el-form-item>
 | 
			
		||||
			</el-col>
 | 
			
		||||
			<el-col :span="12">
 | 
			
		||||
				<el-form-item label="原料等级" prop="grade">
 | 
			
		||||
					<el-select
 | 
			
		||||
						v-model="dataForm.grade"
 | 
			
		||||
						filterable
 | 
			
		||||
						clearable
 | 
			
		||||
						:style="{ width: '100%' }"
 | 
			
		||||
						placeholder="请选择原料等级">
 | 
			
		||||
						<el-option
 | 
			
		||||
							v-for="item in urlOptions.dictList.dict0"
 | 
			
		||||
							:key="item.id"
 | 
			
		||||
							:label="item.label"
 | 
			
		||||
							:value="parseInt(item.value)"></el-option>
 | 
			
		||||
					</el-select>
 | 
			
		||||
				</el-form-item>
 | 
			
		||||
			</el-col>
 | 
			
		||||
			<el-col :span="12">
 | 
			
		||||
				<el-form-item label="原料编码" prop="code">
 | 
			
		||||
					<el-input v-model="dataForm.code" clearable readonly />
 | 
			
		||||
				</el-form-item>
 | 
			
		||||
			</el-col>
 | 
			
		||||
			<el-col :span="12">
 | 
			
		||||
				<el-form-item label="单价" prop="price">
 | 
			
		||||
					<el-input-number
 | 
			
		||||
						:min="0"
 | 
			
		||||
						style="width: 80%"
 | 
			
		||||
						v-model="dataForm.price"
 | 
			
		||||
						clearable
 | 
			
		||||
						placeholder="请输入允许留存时间" />
 | 
			
		||||
					(元/吨)
 | 
			
		||||
				</el-form-item>
 | 
			
		||||
			</el-col>
 | 
			
		||||
			<el-col :span="12">
 | 
			
		||||
				<el-form-item label="生效开始时间" prop="enabledTime">
 | 
			
		||||
					<el-date-picker
 | 
			
		||||
						v-model="dataForm.enabledTime"
 | 
			
		||||
						type="datetime"
 | 
			
		||||
						value-format="timestamp"
 | 
			
		||||
						:style="{ width: '100%' }"
 | 
			
		||||
						placeholder="选择开始时间"></el-date-picker>
 | 
			
		||||
				</el-form-item>
 | 
			
		||||
			</el-col>
 | 
			
		||||
			<el-col :span="12">
 | 
			
		||||
				<el-form-item label="生效结束时间" prop="disabledTime">
 | 
			
		||||
					<el-date-picker
 | 
			
		||||
						v-model="dataForm.disabledTime"
 | 
			
		||||
						type="datetime"
 | 
			
		||||
						value-format="timestamp"
 | 
			
		||||
						:style="{ width: '100%' }"
 | 
			
		||||
						placeholder="选择结束时间"></el-date-picker>
 | 
			
		||||
				</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-form>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
import basicAdd from '../mixins/basic-add';
 | 
			
		||||
import {
 | 
			
		||||
	createCostMaterialSet,
 | 
			
		||||
	updateCostMaterialSet,
 | 
			
		||||
	getCostMaterialSet,
 | 
			
		||||
} from '@/api/cost/costMaterialSet';
 | 
			
		||||
import { getHotMaterialList } from '@/api/base/coreHotMaterial';
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
	mixins: [basicAdd],
 | 
			
		||||
	data() {
 | 
			
		||||
		return {
 | 
			
		||||
			urlOptions: {
 | 
			
		||||
				getDictList: true,
 | 
			
		||||
				createURL: createCostMaterialSet,
 | 
			
		||||
				updateURL: updateCostMaterialSet,
 | 
			
		||||
				infoURL: getCostMaterialSet,
 | 
			
		||||
				getOption: true,
 | 
			
		||||
			},
 | 
			
		||||
			nameList: ['material_grade'],
 | 
			
		||||
			dataForm: {
 | 
			
		||||
				id: undefined,
 | 
			
		||||
				code: '',
 | 
			
		||||
				materialId: '',
 | 
			
		||||
				price: '',
 | 
			
		||||
				grade: '',
 | 
			
		||||
				enabledTime: new Date().getTime(),
 | 
			
		||||
				disabledTime: null,
 | 
			
		||||
				remark: '',
 | 
			
		||||
			},
 | 
			
		||||
			setData: true,
 | 
			
		||||
			MaterialList: [],
 | 
			
		||||
			dataRule: {
 | 
			
		||||
				materialId: [
 | 
			
		||||
					{ required: true, message: '原料不能为空', trigger: 'change' },
 | 
			
		||||
				],
 | 
			
		||||
				price: [{ required: true, message: '单价不能为空', trigger: 'blur' }],
 | 
			
		||||
				enabledTime: [
 | 
			
		||||
					{
 | 
			
		||||
						required: true,
 | 
			
		||||
						message: '生效开始时间不能为空',
 | 
			
		||||
						trigger: 'change',
 | 
			
		||||
					},
 | 
			
		||||
				],
 | 
			
		||||
			},
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
	created() {},
 | 
			
		||||
	methods: {
 | 
			
		||||
		getArr() {
 | 
			
		||||
			getHotMaterialList().then((response) => {
 | 
			
		||||
				this.MaterialList = response.data;
 | 
			
		||||
			});
 | 
			
		||||
		},
 | 
			
		||||
		setDataForm() {
 | 
			
		||||
			this.setCode();
 | 
			
		||||
		},
 | 
			
		||||
		setCode() {
 | 
			
		||||
			this.MaterialList.forEach((item) => {
 | 
			
		||||
				if (item.id === this.dataForm.materialId) {
 | 
			
		||||
					this.dataForm.code = item.code;
 | 
			
		||||
				}
 | 
			
		||||
			});
 | 
			
		||||
		},
 | 
			
		||||
	},
 | 
			
		||||
};
 | 
			
		||||
</script>
 | 
			
		||||
							
								
								
									
										186
									
								
								src/views/cost/rawMaterialConfig/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										186
									
								
								src/views/cost/rawMaterialConfig/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,186 @@
 | 
			
		||||
<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="80"
 | 
			
		||||
				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="40%">
 | 
			
		||||
			<add-or-update
 | 
			
		||||
				ref="addOrUpdate"
 | 
			
		||||
				@refreshDataList="successSubmit"></add-or-update>
 | 
			
		||||
		</base-dialog>
 | 
			
		||||
	</div>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
import AddOrUpdate from './add-or-updata';
 | 
			
		||||
import basicPage from '../mixins/basic-page';
 | 
			
		||||
import { parseTime } from '../mixins/code-filter';
 | 
			
		||||
import {
 | 
			
		||||
	deleteCostMaterialSet,
 | 
			
		||||
	getCostMaterialSetPage,
 | 
			
		||||
} from '@/api/cost/costMaterialSet';
 | 
			
		||||
import { getHotMaterialList } from '@/api/base/coreHotMaterial';
 | 
			
		||||
import { publicFormatter } from '@/utils/dict';
 | 
			
		||||
 | 
			
		||||
const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'rawMaterialName',
 | 
			
		||||
		label: '原料名称',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'code',
 | 
			
		||||
		label: '原料编码',
 | 
			
		||||
		width: 190,
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'grade',
 | 
			
		||||
		label: '原料等级',
 | 
			
		||||
		filter: publicFormatter('material_grade'),
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'dailyUse',
 | 
			
		||||
		label: '单日消耗量(天)吨',
 | 
			
		||||
		width: 130,
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'price',
 | 
			
		||||
		label: '单价(元/吨)',
 | 
			
		||||
		align: 'right',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'enabledTime',
 | 
			
		||||
		label: '生效时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
		width: 150,
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
		label: '备注',
 | 
			
		||||
	},
 | 
			
		||||
];
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
	mixins: [basicPage],
 | 
			
		||||
	data() {
 | 
			
		||||
		return {
 | 
			
		||||
			urlOptions: {
 | 
			
		||||
				getDataListURL: getCostMaterialSetPage,
 | 
			
		||||
				deleteURL: deleteCostMaterialSet,
 | 
			
		||||
			},
 | 
			
		||||
			tableProps,
 | 
			
		||||
			tableBtn: [
 | 
			
		||||
				this.$auth.hasPermi(`cost:rawMaterialConfig:update`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'edit',
 | 
			
		||||
							btnName: '编辑',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`cost:rawMaterialConfig:delete`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'delete',
 | 
			
		||||
							btnName: '删除',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
			].filter((v) => v),
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			formConfig: [
 | 
			
		||||
				{
 | 
			
		||||
					type: 'select',
 | 
			
		||||
					label: '原料名称',
 | 
			
		||||
					selectOptions: [],
 | 
			
		||||
					param: 'name',
 | 
			
		||||
					filterable: true,
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'button',
 | 
			
		||||
					btnName: '查询',
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'separate',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('cost:rawMaterialConfig:create')
 | 
			
		||||
						? 'button'
 | 
			
		||||
						: '',
 | 
			
		||||
					btnName: '新增',
 | 
			
		||||
					name: 'add',
 | 
			
		||||
					color: 'success',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
	components: {
 | 
			
		||||
		AddOrUpdate,
 | 
			
		||||
	},
 | 
			
		||||
	created() {
 | 
			
		||||
		getHotMaterialList().then((response) => {
 | 
			
		||||
			this.formConfig[0].selectOptions = response.data;
 | 
			
		||||
		});
 | 
			
		||||
	},
 | 
			
		||||
	methods: {
 | 
			
		||||
		buttonClick(val) {
 | 
			
		||||
			switch (val.btnName) {
 | 
			
		||||
				case 'search':
 | 
			
		||||
					this.listQuery.pageNo = 1;
 | 
			
		||||
					this.listQuery.pageSize = 10;
 | 
			
		||||
					this.listQuery.materialId = val.name;
 | 
			
		||||
					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>
 | 
			
		||||
							
								
								
									
										166
									
								
								src/views/cost/rawMaterialCost/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										166
									
								
								src/views/cost/rawMaterialCost/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,166 @@
 | 
			
		||||
<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"></base-table>
 | 
			
		||||
		<pagination
 | 
			
		||||
			:limit.sync="listQuery.pageSize"
 | 
			
		||||
			:page.sync="listQuery.pageNo"
 | 
			
		||||
			:total="listQuery.total"
 | 
			
		||||
			@pagination="getDataList" />
 | 
			
		||||
	</div>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
import basicPage from '../mixins/basic-page';
 | 
			
		||||
import connectTime from '../mixins/connectTime';
 | 
			
		||||
import {
 | 
			
		||||
	getCostMaterialSearchPage,
 | 
			
		||||
	exportCostMaterialSearch,
 | 
			
		||||
} from '@/api/cost/costMaterialAutoReport';
 | 
			
		||||
import { getHotMaterialList } from '@/api/base/coreHotMaterial';
 | 
			
		||||
import { publicFormatter } from '@/utils/dict';
 | 
			
		||||
 | 
			
		||||
const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'rawMaterialName',
 | 
			
		||||
		label: '原料名称',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'grade',
 | 
			
		||||
		label: '原料等级',
 | 
			
		||||
		filter: publicFormatter('material_grade'),
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'price',
 | 
			
		||||
		label: '单价(元/吨)',
 | 
			
		||||
		align: 'right',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'reportName',
 | 
			
		||||
		label: '单价生效时间',
 | 
			
		||||
		minWidth: 190,
 | 
			
		||||
		subcomponent: connectTime,
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'totalUsed',
 | 
			
		||||
		label: '累计使用量(吨)',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'totalCost',
 | 
			
		||||
		label: '总价(元)',
 | 
			
		||||
		align: 'right',
 | 
			
		||||
	},
 | 
			
		||||
];
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
	mixins: [basicPage],
 | 
			
		||||
	data() {
 | 
			
		||||
		return {
 | 
			
		||||
			urlOptions: {
 | 
			
		||||
				getDataListURL: getCostMaterialSearchPage,
 | 
			
		||||
				exportURL: exportCostMaterialSearch,
 | 
			
		||||
			},
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			tableProps,
 | 
			
		||||
			drawerVisible: false,
 | 
			
		||||
			formConfig: [
 | 
			
		||||
				{
 | 
			
		||||
					type: 'select',
 | 
			
		||||
					label: '原料名称',
 | 
			
		||||
					selectOptions: [],
 | 
			
		||||
					param: 'materialId',
 | 
			
		||||
					filterable: true,
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'datePicker',
 | 
			
		||||
					label: '时间范围',
 | 
			
		||||
					dateType: 'daterange',
 | 
			
		||||
					format: 'yyyy-MM-dd',
 | 
			
		||||
					valueFormat: 'timestamp',
 | 
			
		||||
					rangeSeparator: '-',
 | 
			
		||||
					startPlaceholder: '开始时间',
 | 
			
		||||
					endPlaceholder: '结束时间',
 | 
			
		||||
					param: 'searchTime',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'button',
 | 
			
		||||
					btnName: '查询',
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('cost:rawMaterialCost:export')
 | 
			
		||||
						? 'button'
 | 
			
		||||
						: '',
 | 
			
		||||
					btnName: '导出',
 | 
			
		||||
					name: 'export',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
	components: {},
 | 
			
		||||
	created() {
 | 
			
		||||
		getHotMaterialList().then((response) => {
 | 
			
		||||
			this.formConfig[0].selectOptions = response.data;
 | 
			
		||||
		});
 | 
			
		||||
	},
 | 
			
		||||
	methods: {
 | 
			
		||||
		// 获取数据列表
 | 
			
		||||
		getDataList() {
 | 
			
		||||
			if (this.listQuery.searchTime) {
 | 
			
		||||
				this.dataListLoading = true;
 | 
			
		||||
				this.urlOptions.getDataListURL(this.listQuery).then((response) => {
 | 
			
		||||
					if (response.hasOwnProperty('data')) {
 | 
			
		||||
						this.tableData = response.data.list;
 | 
			
		||||
						this.listQuery.total = response.data.total;
 | 
			
		||||
					}
 | 
			
		||||
					this.dataListLoading = false;
 | 
			
		||||
				});
 | 
			
		||||
			} else {
 | 
			
		||||
				this.$message.warning('请选择时间范围');
 | 
			
		||||
			}
 | 
			
		||||
		},
 | 
			
		||||
		buttonClick(val) {
 | 
			
		||||
			switch (val.btnName) {
 | 
			
		||||
				case 'search':
 | 
			
		||||
					this.listQuery.pageNo = 1;
 | 
			
		||||
					this.listQuery.pageSize = 10;
 | 
			
		||||
					this.listQuery.materialId = val.materialId;
 | 
			
		||||
					this.listQuery.searchTime = val.searchTime ? val.searchTime[0] : null;
 | 
			
		||||
					this.listQuery.startTime = val.searchTime ? val.searchTime[0] : null;
 | 
			
		||||
					this.listQuery.endTime = val.searchTime ? val.searchTime[1] : null;
 | 
			
		||||
					this.getDataList();
 | 
			
		||||
					break;
 | 
			
		||||
				case 'export':
 | 
			
		||||
					this.listQuery.materialId = val.materialId;
 | 
			
		||||
					this.listQuery.searchTime = val.searchTime ? val.searchTime[0] : null;
 | 
			
		||||
					this.listQuery.startTime = val.searchTime ? val.searchTime[0] : null;
 | 
			
		||||
					this.listQuery.endTime = val.searchTime ? val.searchTime[1] : null;
 | 
			
		||||
					this.handleExport();
 | 
			
		||||
					break;
 | 
			
		||||
				default:
 | 
			
		||||
					console.log(val);
 | 
			
		||||
			}
 | 
			
		||||
		},
 | 
			
		||||
	},
 | 
			
		||||
};
 | 
			
		||||
</script>
 | 
			
		||||
<style>
 | 
			
		||||
.app-container .el-table .el-table__cell {
 | 
			
		||||
	padding: 0;
 | 
			
		||||
	height: 35px;
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
							
								
								
									
										170
									
								
								src/views/cost/rawMaterialCostHis/index.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										170
									
								
								src/views/cost/rawMaterialCostHis/index.vue
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,170 @@
 | 
			
		||||
<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"></base-table>
 | 
			
		||||
		<pagination
 | 
			
		||||
			:limit.sync="listQuery.pageSize"
 | 
			
		||||
			:page.sync="listQuery.pageNo"
 | 
			
		||||
			:total="listQuery.total"
 | 
			
		||||
			@pagination="getDataList" />
 | 
			
		||||
	</div>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script>
 | 
			
		||||
import basicPage from '../mixins/basic-page';
 | 
			
		||||
import codeFilter from '../mixins/code-filter';
 | 
			
		||||
import {
 | 
			
		||||
	getCostMaterialAutoReportPage,
 | 
			
		||||
	exportCostMaterialAutoReportExcel,
 | 
			
		||||
} from '@/api/cost/costMaterialAutoReport';
 | 
			
		||||
import { getHotMaterialList } from '@/api/base/coreHotMaterial';
 | 
			
		||||
import { publicFormatter } from '@/utils/dict';
 | 
			
		||||
 | 
			
		||||
const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'reportType',
 | 
			
		||||
		label: '维度',
 | 
			
		||||
		filter: codeFilter('reportType'),
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'reportName',
 | 
			
		||||
		label: '时间',
 | 
			
		||||
		minWidth: 150,
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'rawMaterialName',
 | 
			
		||||
		label: '原料名称',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'grade',
 | 
			
		||||
		label: '原料等级',
 | 
			
		||||
		filter: publicFormatter('material_grade'),
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'price',
 | 
			
		||||
		label: '单价(元/吨)',
 | 
			
		||||
		align: 'right',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'totalUsed',
 | 
			
		||||
		label: '累计使用量(吨)',
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'totalCost',
 | 
			
		||||
		label: '总价(元)',
 | 
			
		||||
		align: 'right',
 | 
			
		||||
	},
 | 
			
		||||
];
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
	mixins: [basicPage],
 | 
			
		||||
	data() {
 | 
			
		||||
		return {
 | 
			
		||||
			urlOptions: {
 | 
			
		||||
				getDataListURL: getCostMaterialAutoReportPage,
 | 
			
		||||
        exportURL: exportCostMaterialAutoReportExcel
 | 
			
		||||
			},
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			tableProps,
 | 
			
		||||
			drawerVisible: false,
 | 
			
		||||
			listQuery: {
 | 
			
		||||
				reportType: 2,
 | 
			
		||||
			},
 | 
			
		||||
			formConfig: [
 | 
			
		||||
				{
 | 
			
		||||
					type: 'select',
 | 
			
		||||
					label: '维度',
 | 
			
		||||
					selectOptions: [
 | 
			
		||||
						{ id: 2, name: '日' },
 | 
			
		||||
						{ id: 3, name: '周' },
 | 
			
		||||
						{ id: 4, name: '月' },
 | 
			
		||||
						{ id: 5, name: '年' },
 | 
			
		||||
					],
 | 
			
		||||
					param: 'reportType',
 | 
			
		||||
					filterable: true,
 | 
			
		||||
					defaultSelect: 2, // 默认值
 | 
			
		||||
					clearable: false,
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'select',
 | 
			
		||||
					label: '原料名称',
 | 
			
		||||
					selectOptions: [],
 | 
			
		||||
					param: 'materialId',
 | 
			
		||||
					filterable: true,
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'datePicker',
 | 
			
		||||
					label: '时间范围',
 | 
			
		||||
					dateType: 'daterange',
 | 
			
		||||
					format: 'yyyy-MM-dd',
 | 
			
		||||
					valueFormat: 'timestamp',
 | 
			
		||||
					rangeSeparator: '-',
 | 
			
		||||
					startPlaceholder: '开始时间',
 | 
			
		||||
					endPlaceholder: '结束时间',
 | 
			
		||||
					param: 'searchTime',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'button',
 | 
			
		||||
					btnName: '查询',
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('cost:rawMaterialCostHis:export')
 | 
			
		||||
						? 'button'
 | 
			
		||||
						: '',
 | 
			
		||||
					btnName: '导出',
 | 
			
		||||
					name: 'export',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
	components: {},
 | 
			
		||||
	created() {
 | 
			
		||||
		getHotMaterialList().then((response) => {
 | 
			
		||||
			this.formConfig[1].selectOptions = response.data;
 | 
			
		||||
		});
 | 
			
		||||
	},
 | 
			
		||||
	methods: {
 | 
			
		||||
		buttonClick(val) {
 | 
			
		||||
			switch (val.btnName) {
 | 
			
		||||
				case 'search':
 | 
			
		||||
					this.listQuery.pageNo = 1;
 | 
			
		||||
					this.listQuery.pageSize = 10;
 | 
			
		||||
					this.listQuery.reportType = val.reportType;
 | 
			
		||||
					this.listQuery.materialId = val.materialId;
 | 
			
		||||
					this.listQuery.times = val.searchTime ? val.searchTime : null;
 | 
			
		||||
					this.getDataList();
 | 
			
		||||
					break;
 | 
			
		||||
				case 'export':
 | 
			
		||||
					this.listQuery.reportType = val.reportType;
 | 
			
		||||
					this.listQuery.materialId = val.materialId;
 | 
			
		||||
					this.listQuery.times = val.searchTime ? val.searchTime : null;
 | 
			
		||||
					this.handleExport();
 | 
			
		||||
					break;
 | 
			
		||||
				default:
 | 
			
		||||
					console.log(val);
 | 
			
		||||
			}
 | 
			
		||||
		},
 | 
			
		||||
	},
 | 
			
		||||
};
 | 
			
		||||
</script>
 | 
			
		||||
<style>
 | 
			
		||||
.app-container .el-table .el-table__cell {
 | 
			
		||||
	padding: 0;
 | 
			
		||||
	height: 35px;
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
@@ -221,18 +221,30 @@ export default {
 | 
			
		||||
    timeSelect() {
 | 
			
		||||
      switch (this.queryParams.timeDim) {
 | 
			
		||||
        case '1':
 | 
			
		||||
          if (!this.timeValue) {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          if (this.timeValue[1] - this.timeValue[0] > 7*24*3600000) {
 | 
			
		||||
            this.$modal.msgError('最大时间范围为7天,请重新选择')
 | 
			
		||||
            this.timeValue = []
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '2':
 | 
			
		||||
          if (!this.dateValue) {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          if (this.dateValue[1] - this.dateValue[0] > 29*24*3600000) {
 | 
			
		||||
            this.$modal.msgError('最大时间范围为30天,请重新选择') // 自动选择默认是0:00:00要求是23:59:59
 | 
			
		||||
            this.dateValue = []
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '4':
 | 
			
		||||
          if (!this.monthValue) {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          if (this.monthValue[1] - this.monthValue[0] > 729*24*3600000) {
 | 
			
		||||
            this.$modal.msgError('最大时间范围为24个月,请重新选择')// 同理上面
 | 
			
		||||
            this.monthValue = []
 | 
			
		||||
@@ -338,7 +350,7 @@ export default {
 | 
			
		||||
      }
 | 
			
		||||
      switch (this.queryParams.timeDim) {
 | 
			
		||||
        case '1':
 | 
			
		||||
          if (this.timeValue.length > 0) {
 | 
			
		||||
          if (this.timeValue && this.timeValue.length > 0) {
 | 
			
		||||
            this.queryParams.startTime = this.timeValue[0]
 | 
			
		||||
            this.queryParams.endTime = this.timeValue[1] // 不用转
 | 
			
		||||
          } else {
 | 
			
		||||
 
 | 
			
		||||
@@ -8,7 +8,6 @@
 | 
			
		||||
<script>
 | 
			
		||||
import * as echarts from 'echarts'
 | 
			
		||||
import resize from '@/utils/chartMixins/resize'
 | 
			
		||||
import moment from 'moment'
 | 
			
		||||
export default {
 | 
			
		||||
  name: "LineChart",
 | 
			
		||||
  mixins: [resize],
 | 
			
		||||
 
 | 
			
		||||
@@ -207,18 +207,30 @@ export default {
 | 
			
		||||
    timeSelect() {
 | 
			
		||||
      switch (this.queryParams.timeDim) {
 | 
			
		||||
        case '1':
 | 
			
		||||
          if (!this.timeValue) {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          if (this.timeValue[1] - this.timeValue[0] > 7*24*3600000) {
 | 
			
		||||
            this.$modal.msgError('最大时间范围为7天,请重新选择')
 | 
			
		||||
            this.timeValue = []
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '2':
 | 
			
		||||
          if (!this.dateValue) {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          if (this.dateValue[1] - this.dateValue[0] > 29*24*3600000) {
 | 
			
		||||
            this.$modal.msgError('最大时间范围为30天,请重新选择') // 自动选择默认是0:00:00要求是23:59:59
 | 
			
		||||
            this.dateValue = []
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '4':
 | 
			
		||||
          if (!this.monthValue) {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          if (this.monthValue[1] - this.monthValue[0] > 729*24*3600000) {
 | 
			
		||||
            this.$modal.msgError('最大时间范围为24个月,请重新选择')// 同理上面
 | 
			
		||||
            this.monthValue = []
 | 
			
		||||
@@ -307,7 +319,7 @@ export default {
 | 
			
		||||
      }
 | 
			
		||||
      switch (this.queryParams.timeDim) {
 | 
			
		||||
        case '1':
 | 
			
		||||
          if (this.timeValue.length > 0) {
 | 
			
		||||
          if (this.timeValue && this.timeValue.length > 0) {
 | 
			
		||||
            this.queryParams.startTime = this.timeValue[0]
 | 
			
		||||
            this.queryParams.endTime = this.timeValue[1] // 不用转
 | 
			
		||||
          } else {
 | 
			
		||||
@@ -316,7 +328,7 @@ export default {
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '2':
 | 
			
		||||
          if (this.dateValue.length > 0) {
 | 
			
		||||
          if (this.dateValue && this.dateValue.length > 0) {
 | 
			
		||||
            this.queryParams.startTime = this.dateValue[0]
 | 
			
		||||
            this.queryParams.endTime = this.dateValue[1] + 86399000 // 转为23:59:59
 | 
			
		||||
          } else {
 | 
			
		||||
@@ -336,7 +348,7 @@ export default {
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '4':// 转为本月最后一天的最后一秒
 | 
			
		||||
          if (this.monthValue.length > 0) {
 | 
			
		||||
          if (this.monthValue && this.monthValue.length > 0) {
 | 
			
		||||
            this.queryParams.startTime = this.monthValue[0]
 | 
			
		||||
            this.queryParams.endTime = this.transformTime(this.monthValue[1])
 | 
			
		||||
          } else {
 | 
			
		||||
 
 | 
			
		||||
@@ -175,7 +175,7 @@ export default {
 | 
			
		||||
              btnName: '删除'
 | 
			
		||||
            }
 | 
			
		||||
          : undefined
 | 
			
		||||
      ],
 | 
			
		||||
      ].filter((v)=>v),
 | 
			
		||||
      // 查询参数
 | 
			
		||||
      queryParams: {
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
 
 | 
			
		||||
@@ -0,0 +1,150 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div
 | 
			
		||||
    id="wasteWaterLine"
 | 
			
		||||
    style="width: 100%"
 | 
			
		||||
    :style="{ height: chartHeight + 'px' }"
 | 
			
		||||
  ></div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import * as echarts from 'echarts'
 | 
			
		||||
import resize from '@/utils/chartMixins/resize'
 | 
			
		||||
export default {
 | 
			
		||||
  name: "LineChart",
 | 
			
		||||
  mixins: [resize],
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      chartDom: '',
 | 
			
		||||
      chart: '',
 | 
			
		||||
      chartHeight: this.tableHeight(420)
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  props: {
 | 
			
		||||
    chartData: {
 | 
			
		||||
      type: Object,
 | 
			
		||||
      required: true,
 | 
			
		||||
      default: () => {
 | 
			
		||||
        return {}
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    timeDim: {
 | 
			
		||||
      type: String,
 | 
			
		||||
      default: ''
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  mounted() {
 | 
			
		||||
    window.addEventListener('resize', () => {
 | 
			
		||||
      this.chartHeight = this.tableHeight(420)
 | 
			
		||||
    })
 | 
			
		||||
    this.getChart()
 | 
			
		||||
  },
 | 
			
		||||
  watch: {
 | 
			
		||||
    chartData: function () {
 | 
			
		||||
      this.getChart()
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    getChart() {
 | 
			
		||||
      if (
 | 
			
		||||
        this.chart !== null &&
 | 
			
		||||
        this.chart !== '' &&
 | 
			
		||||
        this.chart !== undefined
 | 
			
		||||
      ) {
 | 
			
		||||
        this.chart.dispose() // 页面多次刷新会出现警告,Dom已经初始化了一个实例,这是销毁实例
 | 
			
		||||
      }
 | 
			
		||||
      this.chartDom = document.getElementById('wasteWaterLine');
 | 
			
		||||
      this.chart = echarts.init(this.chartDom);
 | 
			
		||||
      if (Object.keys(this.chartData).length === 0) {
 | 
			
		||||
        return false
 | 
			
		||||
      }
 | 
			
		||||
      let legendData = []
 | 
			
		||||
      let xData = []
 | 
			
		||||
      let seriesData = []
 | 
			
		||||
      for (let item in this.chartData) {
 | 
			
		||||
        legendData.push(item)
 | 
			
		||||
        let obj = {}
 | 
			
		||||
        let data = []
 | 
			
		||||
        for (let subItem in this.chartData[item]) {
 | 
			
		||||
          data.push(this.chartData[item][subItem].checkValue)
 | 
			
		||||
        }
 | 
			
		||||
        obj.name = item
 | 
			
		||||
        obj.type = 'line'
 | 
			
		||||
        obj.stack = 'Total'
 | 
			
		||||
        obj.symbol = 'none'
 | 
			
		||||
        obj.data = data
 | 
			
		||||
        seriesData.push(obj)
 | 
			
		||||
      }
 | 
			
		||||
      for (let i = 0; i < this.chartData[legendData[0]].length; i++) {
 | 
			
		||||
        let time = ""
 | 
			
		||||
        if (this.timeDim === '3') {
 | 
			
		||||
          let year = this.chartData[legendData[0]][i].axisTime.slice(0,4)
 | 
			
		||||
          let weak = this.chartData[legendData[0]][i].axisTime.slice(6,8)
 | 
			
		||||
          time = year+' 第 '+weak+' 周'
 | 
			
		||||
        } else {
 | 
			
		||||
          time = this.chartData[legendData[0]][i].axisTime
 | 
			
		||||
        }
 | 
			
		||||
        xData.push(time)
 | 
			
		||||
      }
 | 
			
		||||
      var option = {
 | 
			
		||||
        color: ['#63BDFF', '#7164FF', '#FF6860', '#FF9747', '#B0EB42', '#D680FF', '#0043D2'],
 | 
			
		||||
          tooltip: {
 | 
			
		||||
            trigger: 'axis',
 | 
			
		||||
            formatter: function (params) {
 | 
			
		||||
              return (
 | 
			
		||||
                params[0].axisValue +
 | 
			
		||||
                `<br>` +
 | 
			
		||||
                params
 | 
			
		||||
                  .map((item) => {
 | 
			
		||||
                    let str = `<span style="display:inline-block;width:8px;height:8px;margin: 0 8px 0 -3px;border-radius:2px;background-color:${item.color};"></span>`;
 | 
			
		||||
                    let seriesNameStr = `<span style="display:inline-block;">${item.seriesName}</span>`;
 | 
			
		||||
                    let value = item.value ? item.value : '-';
 | 
			
		||||
                    let valueStr = `<span style="display:inline-block;margin-left:10px;color:rgba(0,0,0,0.45);">${value}</span>`;
 | 
			
		||||
                    return `<span style="display:flex; justify-content:space-between; margin-bottom: 2px">
 | 
			
		||||
                    <span>${str}${seriesNameStr}</span>
 | 
			
		||||
                    <span>${valueStr}</span>
 | 
			
		||||
                  </span>`;
 | 
			
		||||
                  })
 | 
			
		||||
                  .join(``)
 | 
			
		||||
              );
 | 
			
		||||
            }
 | 
			
		||||
          },
 | 
			
		||||
          legend: {
 | 
			
		||||
            data: legendData,
 | 
			
		||||
            right: '2%',
 | 
			
		||||
            icon: 'rect',
 | 
			
		||||
            itemHeight: 8,
 | 
			
		||||
            itemWidth: 8,
 | 
			
		||||
            textStyle: {
 | 
			
		||||
              color: 'auto'
 | 
			
		||||
            }
 | 
			
		||||
          },
 | 
			
		||||
          grid: {
 | 
			
		||||
            left: '3%',
 | 
			
		||||
            right: '2%',
 | 
			
		||||
            bottom: '3%',
 | 
			
		||||
            containLabel: true
 | 
			
		||||
          },
 | 
			
		||||
          xAxis: {
 | 
			
		||||
            type: 'category',
 | 
			
		||||
            boundaryGap: false,
 | 
			
		||||
            data: xData,
 | 
			
		||||
            axisLabel: {
 | 
			
		||||
              rotate: "45"
 | 
			
		||||
            }
 | 
			
		||||
          },
 | 
			
		||||
          yAxis: {
 | 
			
		||||
            type: 'value'
 | 
			
		||||
          },
 | 
			
		||||
          axisPointer: {
 | 
			
		||||
            type: 'line',
 | 
			
		||||
            lineStyle: {
 | 
			
		||||
              color: 'rgba(11, 88, 255, 1)'
 | 
			
		||||
            }
 | 
			
		||||
          },
 | 
			
		||||
          series: seriesData
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        option && this.chart.setOption(option);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
@@ -0,0 +1,378 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div class="searchBarBox divHeight" ref="searchBarRef">
 | 
			
		||||
    <el-form :inline="true" class="demo-form-inline">
 | 
			
		||||
      <el-form-item label="时间维度" required>
 | 
			
		||||
        <el-select v-model="queryParams.timeDim" placeholder="请选择" style="width: 80px;" size="small">
 | 
			
		||||
          <el-option
 | 
			
		||||
            v-for="item in getDictDatas(this.DICT_TYPE.TIME_DIM)"
 | 
			
		||||
            :key="item.value"
 | 
			
		||||
            :label="item.label"
 | 
			
		||||
            :value="item.value"
 | 
			
		||||
            size="small">
 | 
			
		||||
          </el-option>
 | 
			
		||||
        </el-select>
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
      <el-form-item label="时间范围" required>
 | 
			
		||||
        <div v-show="queryParams.timeDim === '1'">
 | 
			
		||||
          <el-date-picker
 | 
			
		||||
            v-model="timeValue"
 | 
			
		||||
            type="datetimerange"
 | 
			
		||||
            range-separator="至"
 | 
			
		||||
            start-placeholder="开始日期"
 | 
			
		||||
            end-placeholder="结束日期"
 | 
			
		||||
            format="yyyy-MM-dd HH:mm"
 | 
			
		||||
            value-format="timestamp"
 | 
			
		||||
            :picker-options="pickerOptions"
 | 
			
		||||
            popper-class="noneMinute"
 | 
			
		||||
            @change="timeSelect"
 | 
			
		||||
            size="small"
 | 
			
		||||
            style='width:350px;'
 | 
			
		||||
            >
 | 
			
		||||
          </el-date-picker>
 | 
			
		||||
        </div>
 | 
			
		||||
        <div v-show="queryParams.timeDim === '2'">
 | 
			
		||||
          <el-date-picker
 | 
			
		||||
            v-model="dateValue"
 | 
			
		||||
            type="daterange"
 | 
			
		||||
            range-separator="至"
 | 
			
		||||
            start-placeholder="开始日期"
 | 
			
		||||
            end-placeholder="结束日期"
 | 
			
		||||
            value-format="timestamp"
 | 
			
		||||
            :picker-options="pickerOptions"
 | 
			
		||||
            @change="timeSelect"
 | 
			
		||||
            size="small"
 | 
			
		||||
            style='width:350px;'
 | 
			
		||||
            >
 | 
			
		||||
          </el-date-picker>
 | 
			
		||||
        </div>
 | 
			
		||||
        <div v-show="queryParams.timeDim === '3'">
 | 
			
		||||
          <el-date-picker
 | 
			
		||||
            v-model="weekValue1"
 | 
			
		||||
            type="week"
 | 
			
		||||
            format="yyyy 第 WW 周"
 | 
			
		||||
            style='width:170px;'
 | 
			
		||||
            :picker-options="pickerOptionsWeek"
 | 
			
		||||
            @change="startWeek"
 | 
			
		||||
            size="small"
 | 
			
		||||
            placeholder="选择周">
 | 
			
		||||
          </el-date-picker>-
 | 
			
		||||
          <el-date-picker
 | 
			
		||||
            v-model="weekValue2"
 | 
			
		||||
            type="week"
 | 
			
		||||
            format="yyyy 第 WW 周"
 | 
			
		||||
            :picker-options="pickerOptionsWeek"
 | 
			
		||||
            style='width:170px;'
 | 
			
		||||
            @change="endWeek"
 | 
			
		||||
            size="small"
 | 
			
		||||
            placeholder="选择周">
 | 
			
		||||
          </el-date-picker>
 | 
			
		||||
        </div>
 | 
			
		||||
        <div v-show="queryParams.timeDim === '4'">
 | 
			
		||||
          <el-date-picker
 | 
			
		||||
            v-model="monthValue"
 | 
			
		||||
            type="monthrange"
 | 
			
		||||
            range-separator="至"
 | 
			
		||||
            start-placeholder="开始日期"
 | 
			
		||||
            end-placeholder="结束日期"
 | 
			
		||||
            value-format="timestamp"
 | 
			
		||||
            :picker-options="pickerOptions"
 | 
			
		||||
            size="small"
 | 
			
		||||
            style='width:350px;'
 | 
			
		||||
            @change="timeSelect"
 | 
			
		||||
            >
 | 
			
		||||
          </el-date-picker>
 | 
			
		||||
        </div>
 | 
			
		||||
        <div v-show="queryParams.timeDim === '5'">
 | 
			
		||||
          <el-date-picker
 | 
			
		||||
            style='width:170px;'
 | 
			
		||||
            v-model="yearValue1"
 | 
			
		||||
            type="year"
 | 
			
		||||
            :picker-options="pickerOptions"
 | 
			
		||||
            value-format="timestamp"
 | 
			
		||||
            placeholder="选择年"
 | 
			
		||||
            size="small"
 | 
			
		||||
            @change="startYear"
 | 
			
		||||
          >
 | 
			
		||||
          </el-date-picker>-
 | 
			
		||||
          <el-date-picker
 | 
			
		||||
            style='width:170px;'
 | 
			
		||||
            v-model="yearValue2"
 | 
			
		||||
            type="year"
 | 
			
		||||
            :picker-options="pickerOptions"
 | 
			
		||||
            value-format="timestamp"
 | 
			
		||||
            placeholder="选择年"
 | 
			
		||||
            size="small"
 | 
			
		||||
            @change="endYear"
 | 
			
		||||
          >
 | 
			
		||||
          </el-date-picker>
 | 
			
		||||
        </div>
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
      <el-form-item>
 | 
			
		||||
        <el-button type="primary" size="small" @click="search">查询</el-button>
 | 
			
		||||
      </el-form-item>
 | 
			
		||||
    </el-form>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import moment from 'moment'
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'SearchArea',
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      // 查询参数
 | 
			
		||||
      queryParams: {
 | 
			
		||||
        timeDim: null,
 | 
			
		||||
        startTime: null,
 | 
			
		||||
        endTime: null
 | 
			
		||||
      },
 | 
			
		||||
      timeValue: [],// 最大7天只能整点
 | 
			
		||||
      dateValue: [],// 最大30天
 | 
			
		||||
      weekValue1: null,//最多24周
 | 
			
		||||
      weekValue2: null,
 | 
			
		||||
      monthValue: [],//最多24月
 | 
			
		||||
      yearValue1: null,//最多10年
 | 
			
		||||
      yearValue2: null,
 | 
			
		||||
      pickerOptions: {
 | 
			
		||||
        disabledDate(date) {
 | 
			
		||||
          return date.getTime() > Date.now()
 | 
			
		||||
        }
 | 
			
		||||
      },
 | 
			
		||||
      pickerOptionsWeek: {
 | 
			
		||||
        disabledDate(time) {
 | 
			
		||||
          let day = Date.now()
 | 
			
		||||
          let limitTime = moment(day).day(-1)
 | 
			
		||||
          return time.getTime() > new Date(limitTime).getTime()
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  mounted() {
 | 
			
		||||
    this.queryParams.timeDim = this.getDictDatas(this.DICT_TYPE.TIME_DIM)[0].value // 默认时
 | 
			
		||||
    this.timeValue = [moment().startOf('day'), moment().endOf('day')-59*61*1000]
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    // 范围选择器
 | 
			
		||||
    timeSelect() {
 | 
			
		||||
      switch (this.queryParams.timeDim) {
 | 
			
		||||
        case '1':
 | 
			
		||||
          if (!this.timeValue) {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          if (this.timeValue[1] - this.timeValue[0] > 7*24*3600000) {
 | 
			
		||||
            this.$modal.msgError('最大时间范围为7天,请重新选择')
 | 
			
		||||
            this.timeValue = []
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '2':
 | 
			
		||||
          if (!this.dateValue) {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          if (this.dateValue[1] - this.dateValue[0] > 29*24*3600000) {
 | 
			
		||||
            this.$modal.msgError('最大时间范围为30天,请重新选择') // 自动选择默认是0:00:00要求是23:59:59
 | 
			
		||||
            this.dateValue = []
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '4':
 | 
			
		||||
          if (!this.monthValue) {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          if (this.monthValue[1] - this.monthValue[0] > 729*24*3600000) {
 | 
			
		||||
            this.$modal.msgError('最大时间范围为24个月,请重新选择')// 同理上面
 | 
			
		||||
            this.monthValue = []
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
          default:
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    // 年选择器
 | 
			
		||||
    startYear() {
 | 
			
		||||
      if (this.yearValue2 && this.yearValue2 < this.yearValue1) {
 | 
			
		||||
        this.$modal.msgError('开始时间不能晚于结束时间,请重新选择')
 | 
			
		||||
        this.yearValue1 = null
 | 
			
		||||
        return false
 | 
			
		||||
      }
 | 
			
		||||
      if (this.yearValue1 && this.yearValue2) {
 | 
			
		||||
        if (this.yearValue2 - this.yearValue1 > 10*365*24*3600000) {
 | 
			
		||||
          this.$modal.msgError('最大时间范围为10年,请重新选择')
 | 
			
		||||
          this.yearValue1 = null
 | 
			
		||||
          return false
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    endYear() {
 | 
			
		||||
      if (this.yearValue2 && this.yearValue2 < this.yearValue1) {
 | 
			
		||||
        this.$modal.msgError('结束时间不能早于开始时间,请重新选择')
 | 
			
		||||
        this.yearValue2 = null
 | 
			
		||||
        return false
 | 
			
		||||
      }
 | 
			
		||||
      if (this.yearValue1 && this.yearValue2) {
 | 
			
		||||
        if (this.yearValue2 - this.yearValue1 > 10*365*24*3600000) {
 | 
			
		||||
          this.$modal.msgError('最大时间范围为10年,请重新选择')
 | 
			
		||||
          this.yearValue2 = null
 | 
			
		||||
          return false
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    // 周选择器
 | 
			
		||||
    startWeek() {
 | 
			
		||||
      if (this.weekValue1 && this.weekValue2) {
 | 
			
		||||
        let a = new Date(this.weekValue1).getTime()
 | 
			
		||||
        let b = new Date(this.weekValue2).getTime()
 | 
			
		||||
        if (a > b) {
 | 
			
		||||
          this.$modal.msgError('开始时间不能晚于结束时间,请重新选择')
 | 
			
		||||
          this.weekValue1 = null
 | 
			
		||||
          return false
 | 
			
		||||
        }
 | 
			
		||||
        if (b - a > 167*24*3600000) {
 | 
			
		||||
          this.$modal.msgError('最大时间范围为24周,请重新选择')
 | 
			
		||||
          this.weekValue1 = null
 | 
			
		||||
          return false
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    endWeek() {
 | 
			
		||||
      if (this.weekValue1 && this.weekValue2) {
 | 
			
		||||
        let a = new Date(this.weekValue1).getTime()
 | 
			
		||||
        let b = new Date(this.weekValue2).getTime()
 | 
			
		||||
        if (a > b) {
 | 
			
		||||
          this.$modal.msgError('结束时间不能早于开始时间,请重新选择')
 | 
			
		||||
          this.weekValue2 = null
 | 
			
		||||
          return false
 | 
			
		||||
        }
 | 
			
		||||
        if (b - a > 167*24*3600000) {
 | 
			
		||||
          this.$modal.msgError('最大时间范围为24周,请重新选择')
 | 
			
		||||
          this.weekValue2 = null
 | 
			
		||||
          return false
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    // 查询
 | 
			
		||||
    search() {
 | 
			
		||||
      if (!this.queryParams.timeDim) {
 | 
			
		||||
        this.$modal.msgError('请选择时间维度')
 | 
			
		||||
        return false
 | 
			
		||||
      }
 | 
			
		||||
      switch (this.queryParams.timeDim) {
 | 
			
		||||
        case '1':
 | 
			
		||||
          if (this.timeValue && this.timeValue.length > 0) {
 | 
			
		||||
            this.queryParams.startTime = this.timeValue[0]
 | 
			
		||||
            this.queryParams.endTime = this.timeValue[1] // 不用转
 | 
			
		||||
          } else {
 | 
			
		||||
            this.$modal.msgError('时间范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '2':
 | 
			
		||||
          if (this.dateValue && this.dateValue.length > 0) {
 | 
			
		||||
            this.queryParams.startTime = this.dateValue[0]
 | 
			
		||||
            this.queryParams.endTime = this.dateValue[1] + 86399000 // 转为23:59:59
 | 
			
		||||
          } else {
 | 
			
		||||
            this.$modal.msgError('日范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '3':
 | 
			
		||||
          if (this.weekValue1 && this.weekValue2) {
 | 
			
		||||
            let a = moment(this.weekValue1).day(0).format('YYYY-MM-DD') + ' 00:00:00'
 | 
			
		||||
            let b = moment(this.weekValue2).day(6).format('YYYY-MM-DD') + ' 23:59:59'
 | 
			
		||||
            this.queryParams.startTime = new Date(a).getTime()
 | 
			
		||||
            this.queryParams.endTime = new Date(b).getTime()
 | 
			
		||||
          } else {
 | 
			
		||||
            this.$modal.msgError('周范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        case '4':// 转为本月最后一天的最后一秒
 | 
			
		||||
          if (this.monthValue && this.monthValue.length > 0) {
 | 
			
		||||
            this.queryParams.startTime = this.monthValue[0]
 | 
			
		||||
            this.queryParams.endTime = this.transformTime(this.monthValue[1])
 | 
			
		||||
          } else {
 | 
			
		||||
            this.$modal.msgError('月范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          break
 | 
			
		||||
        default://本年最后一天
 | 
			
		||||
          if (this.yearValue1 && this.yearValue2) {
 | 
			
		||||
            if (this.yearValue2 < this.yearValue1) {
 | 
			
		||||
              this.$modal.msgError('结束时间不能早于开始时间')
 | 
			
		||||
              return false
 | 
			
		||||
            } else {
 | 
			
		||||
              this.queryParams.startTime = this.yearValue1
 | 
			
		||||
              this.queryParams.endTime = this.transformYear(this.yearValue2)
 | 
			
		||||
            }
 | 
			
		||||
          } else {
 | 
			
		||||
            this.$modal.msgError('年范围不能为空')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
      }
 | 
			
		||||
      this.queryParams.startTime = this.queryParams.startTime + ''
 | 
			
		||||
      this.queryParams.endTime = this.queryParams.endTime + ''
 | 
			
		||||
      this.$emit('submit', this.queryParams)
 | 
			
		||||
    },
 | 
			
		||||
    transformTime(timeStamp) {// 本月最后一天
 | 
			
		||||
      let year = moment(timeStamp).format('YYYY')
 | 
			
		||||
      let month = moment(timeStamp).format('MM')
 | 
			
		||||
      let newData = moment(new Date(year,month,0)).format('YYYY-MM-DD') + ' 23:59:59'
 | 
			
		||||
      let value = new Date(newData).getTime()
 | 
			
		||||
      return value
 | 
			
		||||
    },
 | 
			
		||||
    transformYear(timeStamp) {// 本年最后一天
 | 
			
		||||
      let year = moment(timeStamp).format('YYYY')
 | 
			
		||||
      let newData = year+'-12-31 23:59:59'
 | 
			
		||||
      let value = new Date(newData).getTime()
 | 
			
		||||
      return value
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
<style lang='scss'>
 | 
			
		||||
/* 级联选择器 */
 | 
			
		||||
.cascaderParent .el-cascader-panel .el-scrollbar:first-child .el-radio {
 | 
			
		||||
  display: none;
 | 
			
		||||
}
 | 
			
		||||
/* 时间整点 */
 | 
			
		||||
.noneMinute .el-time-spinner__wrapper {
 | 
			
		||||
  width: 100%;
 | 
			
		||||
}
 | 
			
		||||
.noneMinute .el-scrollbar:nth-of-type(2) {
 | 
			
		||||
  display: none;
 | 
			
		||||
}
 | 
			
		||||
.demo-form-inline {
 | 
			
		||||
  .el-date-editor .el-range__icon {
 | 
			
		||||
    font-size: 16px;
 | 
			
		||||
    color: #0B58FF;
 | 
			
		||||
  }
 | 
			
		||||
  .el-input__prefix .el-icon-date {
 | 
			
		||||
    font-size: 16px;
 | 
			
		||||
    color: #0B58FF;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
<style lang="scss" scoped>
 | 
			
		||||
.searchBarBox .foldClass {
 | 
			
		||||
  position: absolute;
 | 
			
		||||
  top: 14px;
 | 
			
		||||
  right: 0;
 | 
			
		||||
  cursor: pointer;
 | 
			
		||||
  font-size: 12px;
 | 
			
		||||
  color:#0B58FF;
 | 
			
		||||
}
 | 
			
		||||
.searchBarBox .foldClass .iconfont {
 | 
			
		||||
  font-size: 14px;
 | 
			
		||||
}
 | 
			
		||||
.divHeight {
 | 
			
		||||
  height: 45px;
 | 
			
		||||
  overflow: hidden;
 | 
			
		||||
}
 | 
			
		||||
.separateStyle {
 | 
			
		||||
  display: inline-block;
 | 
			
		||||
  width: 1px;
 | 
			
		||||
  height: 24px;
 | 
			
		||||
  background: #E8E8E8;
 | 
			
		||||
  vertical-align: middle;
 | 
			
		||||
  margin: 0 10px;
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
@@ -1,8 +1,185 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div>vocDetectionHistory</div>
 | 
			
		||||
  <div class="app-container vocHis">
 | 
			
		||||
    <!-- 搜索工作栏 -->
 | 
			
		||||
    <search-bar
 | 
			
		||||
      :formConfigs="formConfig"
 | 
			
		||||
      ref="searchBarForm"
 | 
			
		||||
      @headBtnClick="buttonClick"
 | 
			
		||||
    />
 | 
			
		||||
    <!-- 列表 -->
 | 
			
		||||
    <base-table
 | 
			
		||||
      :page="queryParams.pageNo"
 | 
			
		||||
      :limit="queryParams.pageSize"
 | 
			
		||||
      :table-props="tableProps"
 | 
			
		||||
      :table-data="list"
 | 
			
		||||
      :max-height="tableH"
 | 
			
		||||
      :row-class-name="tableRowClassName"
 | 
			
		||||
    />
 | 
			
		||||
    <pagination
 | 
			
		||||
      :page.sync="queryParams.pageNo"
 | 
			
		||||
      :limit.sync="queryParams.pageSize"
 | 
			
		||||
      :total="total"
 | 
			
		||||
      @pagination="getList"
 | 
			
		||||
    />
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { publicFormatter } from '@/utils/dict'
 | 
			
		||||
import { parseTime } from '@/utils/ruoyi'
 | 
			
		||||
import { environmentalCheckRecordPage, environmentalCheckRecordExport, environmentalCheckPage } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
import moment from 'moment'
 | 
			
		||||
const tableProps = [
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'checkName',
 | 
			
		||||
    label: '指标名称'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'checkValue',
 | 
			
		||||
    label: '检测数值'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'unit',
 | 
			
		||||
    label: '单位',
 | 
			
		||||
    filter: publicFormatter('environment_check_unit')
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'checkTime',
 | 
			
		||||
    label: '检测时间',
 | 
			
		||||
    filter: parseTime,
 | 
			
		||||
    minWidth: 160
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'origin',
 | 
			
		||||
    label: '来源',
 | 
			
		||||
    filter: (val) => ['手动', '自动'][val]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'recordPerson',
 | 
			
		||||
    label: '录入人'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'recordTime',
 | 
			
		||||
    label: '录入时间',
 | 
			
		||||
    filter: parseTime,
 | 
			
		||||
    minWidth: 160
 | 
			
		||||
  }
 | 
			
		||||
]
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'VocDetectionHistory'
 | 
			
		||||
  name: 'VocDetectionHistory',
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      formConfig: [
 | 
			
		||||
        {
 | 
			
		||||
          type: 'select',
 | 
			
		||||
          label: '指标名称',
 | 
			
		||||
          selectOptions: [],
 | 
			
		||||
          param: 'checkId',
 | 
			
		||||
          filterable: true
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: 'datePicker',
 | 
			
		||||
          label: '时间',
 | 
			
		||||
          dateType: 'datetimerange',
 | 
			
		||||
          format: 'yyyy-MM-dd HH:mm:ss',
 | 
			
		||||
          valueFormat: "timestamp",
 | 
			
		||||
          rangeSeparator: '-',
 | 
			
		||||
          startPlaceholder: '开始时间',
 | 
			
		||||
          endPlaceholder: '结束时间',
 | 
			
		||||
          param: 'timeVal',
 | 
			
		||||
          defaultSelect: [],
 | 
			
		||||
          width: 350
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: 'button',
 | 
			
		||||
          btnName: '查询',
 | 
			
		||||
          name: 'search',
 | 
			
		||||
          color: 'primary'
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:voc:export') ? 'separate' : '',
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:voc:export') ? 'button' : '',
 | 
			
		||||
          btnName: '导出',
 | 
			
		||||
          name: 'export',
 | 
			
		||||
          color: 'primary',
 | 
			
		||||
          plain: true
 | 
			
		||||
        }
 | 
			
		||||
      ],
 | 
			
		||||
      // 查询参数
 | 
			
		||||
      queryParams: {
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 20,
 | 
			
		||||
        checkId: null,
 | 
			
		||||
        checkType: 3,
 | 
			
		||||
        startTime: null,
 | 
			
		||||
        endTime: null
 | 
			
		||||
      },
 | 
			
		||||
      tableProps,
 | 
			
		||||
      list: [],
 | 
			
		||||
      total: 0,
 | 
			
		||||
      tableH: this.tableHeight(260)
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  created() {
 | 
			
		||||
    window.addEventListener('resize', () => {
 | 
			
		||||
      this.tableH = this.tableHeight(260)
 | 
			
		||||
    })
 | 
			
		||||
    let end = moment(moment().format('YYYY-MM-DD 23:59:59')).valueOf()
 | 
			
		||||
    let start = moment(moment().format('YYYY-MM-DD 00:00:00')).valueOf()
 | 
			
		||||
    this.formConfig[1].defaultSelect = [start, end]
 | 
			
		||||
    this.queryParams.startTime = start
 | 
			
		||||
    this.queryParams.endTime = end
 | 
			
		||||
    this.getSelectList()
 | 
			
		||||
    this.getList()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    buttonClick(val) {
 | 
			
		||||
      this.queryParams.pageNo = 1;
 | 
			
		||||
      this.queryParams.checkId = val.checkId
 | 
			
		||||
      this.queryParams.startTime = val.timeVal ? val.timeVal[0] : null
 | 
			
		||||
      this.queryParams.endTime = val.timeVal ? val.timeVal[1] : null
 | 
			
		||||
      if (val.btnName === 'search') {
 | 
			
		||||
        this.getList()
 | 
			
		||||
      } else {
 | 
			
		||||
        this.$modal.confirm('是否确认导出').then(() => {
 | 
			
		||||
            return environmentalCheckRecordExport({...this.queryParams});
 | 
			
		||||
          }).then(response => {
 | 
			
		||||
            this.$download.excel(response, '废水检测历史记录.xls');
 | 
			
		||||
          }).catch(() => {})
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    getList() {
 | 
			
		||||
      environmentalCheckRecordPage({...this.queryParams}).then(res => {
 | 
			
		||||
        this.list = res.data.list || []
 | 
			
		||||
        this.total = res.data.total || 0
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    getSelectList() {
 | 
			
		||||
      environmentalCheckPage({
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 100,
 | 
			
		||||
        checkType: 3
 | 
			
		||||
      }).then(res => {
 | 
			
		||||
        console.log(res)
 | 
			
		||||
        this.formConfig[0].selectOptions = res.data.list || []
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    tableRowClassName({row, rowIndex}) {
 | 
			
		||||
      console.log(row)
 | 
			
		||||
      if (row.markRed) {
 | 
			
		||||
        return 'warning-row'
 | 
			
		||||
      }else {
 | 
			
		||||
        return ''
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
</script>
 | 
			
		||||
<style lang='scss'>
 | 
			
		||||
.vocHis {
 | 
			
		||||
  .el-table .warning-row {
 | 
			
		||||
    background: #fee1e1;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
@@ -0,0 +1,124 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <el-form ref="vocAddForm" :rules="rules" label-width="80px" :model="form">
 | 
			
		||||
    <el-row :gutter="20">
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="指标名称" prop="name">
 | 
			
		||||
          <el-input v-model="form.name" :disabled='isEdit'></el-input>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="指标编码" prop="code">
 | 
			
		||||
          <el-input v-model="form.code"></el-input>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="单位" prop="unit">
 | 
			
		||||
          <el-select v-model="form.unit" placeholder="请选择" style="width: 100%;" :disabled='form.method == 2'>
 | 
			
		||||
            <el-option
 | 
			
		||||
              v-for="item in getDictDatas(DICT_TYPE.ENVIRONMENT_CHECK_UNIT)"
 | 
			
		||||
              :key="item.value"
 | 
			
		||||
              :label="item.label"
 | 
			
		||||
              :value="item.value">
 | 
			
		||||
            </el-option>
 | 
			
		||||
          </el-select>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="最小值" prop="minValue">
 | 
			
		||||
          <el-input-number v-model="form.minValue" placeholder="最小值" :max="9999999" style="width: 100%;"></el-input-number>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="最大值" prop="maxValue">
 | 
			
		||||
          <el-input-number v-model="form.maxValue" placeholder="最大值" :max="9999999" style="width: 100%;"></el-input-number>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="备注" prop="remark">
 | 
			
		||||
          <el-input v-model="form.remark"></el-input>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
    </el-row>
 | 
			
		||||
  </el-form>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { environmentalCheckGet, environmentalCheckUpdate, environmentalCheckCreate, getEnvironmentalCheckCode } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'VocAdd',
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      form: {
 | 
			
		||||
        id: '',
 | 
			
		||||
        name: '',
 | 
			
		||||
        code: '',
 | 
			
		||||
        unit: '',
 | 
			
		||||
        minValue: null,
 | 
			
		||||
        maxValue: null,
 | 
			
		||||
        remark: '',
 | 
			
		||||
        checkType: 3
 | 
			
		||||
      },
 | 
			
		||||
      isEdit: false,
 | 
			
		||||
      rules: {
 | 
			
		||||
        name: [{ required: true, message: "指标名称不能为空", trigger: "blur" }],
 | 
			
		||||
        code: [{ required: true, message: "指标编码不能为空", trigger: "blur" }],
 | 
			
		||||
        // unit: [{ required: true, message: "unit不能为空", trigger: "change" }],
 | 
			
		||||
        minValue: [{ required: true, message: "最小值不能为空", trigger: "blur" }],
 | 
			
		||||
        maxValue: [{ required: true, message: "最大值不能为空", trigger: "blur" }]
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    init(id) {
 | 
			
		||||
      if (id) {
 | 
			
		||||
        this.isEdit = true
 | 
			
		||||
        this.form.id = id
 | 
			
		||||
        environmentalCheckGet({id: this.form.id}).then(res => {
 | 
			
		||||
          if (res.code === 0) {
 | 
			
		||||
            this.form = res.data
 | 
			
		||||
          }
 | 
			
		||||
        })
 | 
			
		||||
      } else {
 | 
			
		||||
        this.isEdit = false
 | 
			
		||||
        this.form.id = ''
 | 
			
		||||
        // 编码
 | 
			
		||||
        getEnvironmentalCheckCode().then(res => {
 | 
			
		||||
          this.form.code = res.data || ''
 | 
			
		||||
        })
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    submitForm() {
 | 
			
		||||
      this.$refs['vocAddForm'].validate((valid) => {
 | 
			
		||||
        if (valid) {
 | 
			
		||||
          if (this.form.minValue > this.form.maxValue) {
 | 
			
		||||
            this.$modal.msgError('最小值不能大于最大值')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          console.log(this.form)
 | 
			
		||||
          if (this.isEdit) {
 | 
			
		||||
            //编辑
 | 
			
		||||
            environmentalCheckUpdate({ ...this.form }).then((res) => {
 | 
			
		||||
              if (res.code === 0) {
 | 
			
		||||
                this.$modal.msgSuccess("操作成功");
 | 
			
		||||
                this.$emit('successSubmit')
 | 
			
		||||
              }
 | 
			
		||||
            })
 | 
			
		||||
          } else {
 | 
			
		||||
            environmentalCheckCreate({ ...this.form }).then((res) => {
 | 
			
		||||
              if (res.code === 0) {
 | 
			
		||||
                this.$modal.msgSuccess("操作成功");
 | 
			
		||||
                this.$emit('successSubmit')
 | 
			
		||||
              }
 | 
			
		||||
            })
 | 
			
		||||
          }
 | 
			
		||||
        } else {
 | 
			
		||||
          return false
 | 
			
		||||
        }
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    formClear() {
 | 
			
		||||
      this.$refs.vocAddForm.resetFields()
 | 
			
		||||
      this.isEdit = false
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
@@ -1,8 +1,205 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div>vocDetectionIndication</div>
 | 
			
		||||
  <div class="app-container">
 | 
			
		||||
    <!-- 搜索工作栏 -->
 | 
			
		||||
    <search-bar
 | 
			
		||||
      :formConfigs="formConfig"
 | 
			
		||||
      ref="searchBarForm"
 | 
			
		||||
      @headBtnClick="buttonClick"
 | 
			
		||||
    />
 | 
			
		||||
    <!-- 列表 -->
 | 
			
		||||
    <base-table
 | 
			
		||||
      :page="queryParams.pageNo"
 | 
			
		||||
      :limit="queryParams.pageSize"
 | 
			
		||||
      :table-props="tableProps"
 | 
			
		||||
      :table-data="list"
 | 
			
		||||
      :max-height="tableH"
 | 
			
		||||
    >
 | 
			
		||||
      <method-btn
 | 
			
		||||
        v-if="tableBtn.length"
 | 
			
		||||
        slot="handleBtn"
 | 
			
		||||
        :width="80"
 | 
			
		||||
        label="操作"
 | 
			
		||||
        :method-list="tableBtn"
 | 
			
		||||
        @clickBtn="handleClick"
 | 
			
		||||
      />
 | 
			
		||||
    </base-table>
 | 
			
		||||
    <pagination
 | 
			
		||||
      :page.sync="queryParams.pageNo"
 | 
			
		||||
      :limit.sync="queryParams.pageSize"
 | 
			
		||||
      :total="total"
 | 
			
		||||
      @pagination="getList"
 | 
			
		||||
    />
 | 
			
		||||
    <!-- 新增&编辑 -->
 | 
			
		||||
    <base-dialog
 | 
			
		||||
      :dialogTitle="addOrEditTitle"
 | 
			
		||||
      :dialogVisible="centervisible"
 | 
			
		||||
      @cancel="handleCancel"
 | 
			
		||||
      @confirm="handleConfirm"
 | 
			
		||||
      :before-close="handleCancel"
 | 
			
		||||
      width='60%'
 | 
			
		||||
    >
 | 
			
		||||
      <voc-add ref="vocAdd" @successSubmit="successSubmit" />
 | 
			
		||||
    </base-dialog>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { parseTime } from '@/utils/ruoyi'
 | 
			
		||||
import VocAdd from './components/vocAdd'
 | 
			
		||||
import { publicFormatter } from '@/utils/dict'
 | 
			
		||||
import { environmentalCheckPage, environmentalCheckDelete } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
const tableProps = [
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'name',
 | 
			
		||||
    label: '指标名称',
 | 
			
		||||
    minWidth: 120,
 | 
			
		||||
    showOverflowtooltip: true
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'code',
 | 
			
		||||
    label: '指示编码',
 | 
			
		||||
    minWidth: 120
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'unit',
 | 
			
		||||
    label: '单位',
 | 
			
		||||
    filter: publicFormatter('environment_check_unit')
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'minValue',
 | 
			
		||||
    label: '最小值'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'maxValue',
 | 
			
		||||
    label: '最大值'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'creator',
 | 
			
		||||
    label: '创建人'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'createTime',
 | 
			
		||||
    label: '创建时间',
 | 
			
		||||
    filter: parseTime,
 | 
			
		||||
    minWidth: 160
 | 
			
		||||
  }
 | 
			
		||||
]
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'VocDetectionIndication'
 | 
			
		||||
  name: 'VocDetectionIndication',
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      formConfig: [
 | 
			
		||||
        {
 | 
			
		||||
          type: 'input',
 | 
			
		||||
          label: '指标名称',
 | 
			
		||||
          placeholder: '指标名称',
 | 
			
		||||
          param: 'name'
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: 'button',
 | 
			
		||||
          btnName: '查询',
 | 
			
		||||
          name: 'search',
 | 
			
		||||
          color: 'primary'
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:voc:create') ? 'separate' : '',
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:voc:create') ? 'button' : '',
 | 
			
		||||
          btnName: '新增',
 | 
			
		||||
          name: 'add',
 | 
			
		||||
          color: 'success',
 | 
			
		||||
          plain: true
 | 
			
		||||
        }
 | 
			
		||||
      ],
 | 
			
		||||
      // 查询参数
 | 
			
		||||
      queryParams: {
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 20,
 | 
			
		||||
        checkType: 3,
 | 
			
		||||
        name: null
 | 
			
		||||
      },
 | 
			
		||||
      total: 0,
 | 
			
		||||
      tableProps,
 | 
			
		||||
      list: [],
 | 
			
		||||
      tableH: this.tableHeight(260),
 | 
			
		||||
      tableBtn: [
 | 
			
		||||
        this.$auth.hasPermi('base:voc:update')
 | 
			
		||||
          ? {
 | 
			
		||||
              type: 'edit',
 | 
			
		||||
              btnName: '编辑'
 | 
			
		||||
            }
 | 
			
		||||
          : undefined,
 | 
			
		||||
        this.$auth.hasPermi('base:voc:delete')
 | 
			
		||||
          ? {
 | 
			
		||||
              type: 'delete',
 | 
			
		||||
              btnName: '删除'
 | 
			
		||||
            }
 | 
			
		||||
          : undefined
 | 
			
		||||
      ].filter((v)=>v),
 | 
			
		||||
      addOrEditTitle: '',
 | 
			
		||||
      centervisible: false
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  components: { VocAdd },
 | 
			
		||||
  mounted() {
 | 
			
		||||
    this.getList()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    getList() {
 | 
			
		||||
      environmentalCheckPage({...this.queryParams}).then(res => {
 | 
			
		||||
        this.list = res.data.list || []
 | 
			
		||||
        this.total = res.data.total || 0
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    buttonClick(val) {
 | 
			
		||||
      console.log(val)
 | 
			
		||||
      if (val.btnName === 'search') {
 | 
			
		||||
        this.queryParams.name = val.name
 | 
			
		||||
        this.getList()
 | 
			
		||||
      } else {
 | 
			
		||||
        this.addOrEditTitle = '新增'
 | 
			
		||||
        this.centervisible = true
 | 
			
		||||
        this.$nextTick(() => {
 | 
			
		||||
          this.$refs.vocAdd.init()
 | 
			
		||||
        })
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    handleClick(val) {
 | 
			
		||||
      console.log(val)
 | 
			
		||||
      switch (val.type) {
 | 
			
		||||
        case 'edit':
 | 
			
		||||
          this.addOrEditTitle = '编辑'
 | 
			
		||||
          this.centervisible = true
 | 
			
		||||
          this.$nextTick(() => {
 | 
			
		||||
            this.$refs.vocAdd.init(val.data.id)
 | 
			
		||||
          })
 | 
			
		||||
          break
 | 
			
		||||
        default:
 | 
			
		||||
          this.handleDelete(val.data)
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    // 删除
 | 
			
		||||
    handleDelete(val) {
 | 
			
		||||
      this.$modal.confirm('是否确认删除"' + val.name + '"的数据项?').then(function() {
 | 
			
		||||
        return environmentalCheckDelete({ id: val.id })
 | 
			
		||||
      }).then(() => {
 | 
			
		||||
        this.getList();
 | 
			
		||||
        this.$modal.msgSuccess("操作成功");
 | 
			
		||||
      }).catch(() => {});
 | 
			
		||||
    },
 | 
			
		||||
    // 新增
 | 
			
		||||
    handleCancel() {
 | 
			
		||||
      this.$refs.vocAdd.formClear()
 | 
			
		||||
      this.centervisible = false
 | 
			
		||||
      this.addOrEditTitle = ''
 | 
			
		||||
    },
 | 
			
		||||
    handleConfirm() {
 | 
			
		||||
      this.$refs.vocAdd.submitForm()
 | 
			
		||||
    },
 | 
			
		||||
    successSubmit() {
 | 
			
		||||
      this.handleCancel()
 | 
			
		||||
      this.getList()
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
@@ -1,8 +1,152 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div>voc</div>
 | 
			
		||||
  <div class="voc">
 | 
			
		||||
    <div class="box1">
 | 
			
		||||
      <div class="boxTitle">
 | 
			
		||||
        <span class="blueTitle"></span>
 | 
			
		||||
        <span>检测指标实时数据</span>
 | 
			
		||||
      </div>
 | 
			
		||||
      <div class="itemBox">
 | 
			
		||||
        <div class="itemBox">
 | 
			
		||||
          <div class="itemClass" v-for="(item, index) in realtimeList" :key='index'>
 | 
			
		||||
            <div class="itemSub">
 | 
			
		||||
              <p class="itemNum">{{item.checkValue}}</p>
 | 
			
		||||
              <p class="itemDescribe">
 | 
			
		||||
                <img src="./../../../../../assets/images/detectionData.png" alt="">
 | 
			
		||||
              {{item.name}}</p>
 | 
			
		||||
            </div>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div>
 | 
			
		||||
    </div>
 | 
			
		||||
    <div class="box2">
 | 
			
		||||
      <div class="boxTitle">
 | 
			
		||||
        <span class="blueTitle"></span>
 | 
			
		||||
        <span>检测指标趋势图</span>
 | 
			
		||||
      </div>
 | 
			
		||||
      <!-- 搜索工作栏 -->
 | 
			
		||||
      <search-area @submit="getTrend"/>
 | 
			
		||||
      <line-chart :chartData="chartData" v-show='Object.keys(chartData).length !== 0' :timeDim="queryParams.timeDim"/>
 | 
			
		||||
      <!-- 没有数据 -->
 | 
			
		||||
      <div class="no-data-bg" v-show='Object.keys(chartData).length === 0'></div>
 | 
			
		||||
    </div>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { environmentalCheckRealtime, environmentalCheckRealtimeTrend } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
import LineChart from './../../components/lineChart'
 | 
			
		||||
import SearchArea from './../../components/searchArea'
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'Voc'
 | 
			
		||||
  name: 'Voc',
 | 
			
		||||
  data(){
 | 
			
		||||
    return {
 | 
			
		||||
      realtimeList:[],
 | 
			
		||||
      queryParams:{
 | 
			
		||||
        checkType: 1,
 | 
			
		||||
        timeDim: null,
 | 
			
		||||
        timeRange: []
 | 
			
		||||
      },
 | 
			
		||||
      chartData: {}
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  components: { LineChart, SearchArea },
 | 
			
		||||
  mounted() {
 | 
			
		||||
    this.getMsg()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    getMsg() {
 | 
			
		||||
      environmentalCheckRealtime({checkType: 3}).then(res => {
 | 
			
		||||
        console.log(res)
 | 
			
		||||
        this.realtimeList = res.data || []
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    getTrend(params) {
 | 
			
		||||
      console.log(params)
 | 
			
		||||
      this.queryParams.timeDim = params.timeDim
 | 
			
		||||
      this.queryParams.timeRange[0] = params.startTime
 | 
			
		||||
      this.queryParams.timeRange[1] = params.endTime
 | 
			
		||||
      environmentalCheckRealtimeTrend({...this.queryParams}).then(res => {
 | 
			
		||||
        console.log(res)
 | 
			
		||||
        if (res.code === 0) {
 | 
			
		||||
          this.chartData = res.data
 | 
			
		||||
        } else {
 | 
			
		||||
          this.chartData = {}
 | 
			
		||||
        }
 | 
			
		||||
      })
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
</script>
 | 
			
		||||
<style lang='scss' scoped>
 | 
			
		||||
.voc {
 | 
			
		||||
  background-color: #f2f4f9;
 | 
			
		||||
  .box1 {
 | 
			
		||||
    height: 172px;
 | 
			
		||||
    padding: 12px 16px 0;
 | 
			
		||||
    margin-bottom: 8px;
 | 
			
		||||
    background-color: #fff;
 | 
			
		||||
    border-radius: 9px;
 | 
			
		||||
    .itemBox {
 | 
			
		||||
      display: flex;
 | 
			
		||||
      flex-flow: row nowrap;
 | 
			
		||||
      overflow: auto;
 | 
			
		||||
      .itemClass {
 | 
			
		||||
        width: 198px;
 | 
			
		||||
        height: 88px;
 | 
			
		||||
        // border: 1px solid green;
 | 
			
		||||
        padding: 12px 0px 12px 18px;
 | 
			
		||||
        .itemSub {
 | 
			
		||||
          width: 176px;
 | 
			
		||||
          height: 65px;
 | 
			
		||||
          padding-right: 26px;
 | 
			
		||||
          border-right: 1px solid #E8E8E8;
 | 
			
		||||
          P{
 | 
			
		||||
            margin: 0;
 | 
			
		||||
            img {
 | 
			
		||||
              width: 24px;
 | 
			
		||||
              height: 24px;
 | 
			
		||||
              vertical-align: middle;
 | 
			
		||||
            }
 | 
			
		||||
          }
 | 
			
		||||
          .itemNum {
 | 
			
		||||
            font-size: 32px;
 | 
			
		||||
            font-weight: 600;
 | 
			
		||||
            height: 43px;
 | 
			
		||||
            color: #3E6AF7;
 | 
			
		||||
            text-align: right;
 | 
			
		||||
          }
 | 
			
		||||
          .itemDescribe {
 | 
			
		||||
            font-size: 16px;
 | 
			
		||||
            text-align: right;
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    .itemClass:last-child > .itemSub{
 | 
			
		||||
      border: none !important;
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
  .box2 {
 | 
			
		||||
    background-color: #fff;
 | 
			
		||||
    border-radius: 9px;
 | 
			
		||||
    padding: 16px;
 | 
			
		||||
    height: calc(100vh - 308px);
 | 
			
		||||
  }
 | 
			
		||||
  .boxTitle {
 | 
			
		||||
    display: inline-block;
 | 
			
		||||
    font-size: 16px;
 | 
			
		||||
    font-weight: 400;
 | 
			
		||||
    color: #000000;
 | 
			
		||||
    margin:0 10px 20px 0;
 | 
			
		||||
  }
 | 
			
		||||
  .blueTitle {
 | 
			
		||||
    content: '';
 | 
			
		||||
    display: inline-block;
 | 
			
		||||
    width: 4px;
 | 
			
		||||
    height: 18px;
 | 
			
		||||
    background-color: #0B58FF;
 | 
			
		||||
    border-radius: 1px;
 | 
			
		||||
    margin-right: 8px;
 | 
			
		||||
    vertical-align: bottom;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
@@ -1,8 +1,185 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div>wasteGasDetectionHistory</div>
 | 
			
		||||
  <div class="app-container wasteGasHis">
 | 
			
		||||
    <!-- 搜索工作栏 -->
 | 
			
		||||
    <search-bar
 | 
			
		||||
      :formConfigs="formConfig"
 | 
			
		||||
      ref="searchBarForm"
 | 
			
		||||
      @headBtnClick="buttonClick"
 | 
			
		||||
    />
 | 
			
		||||
    <!-- 列表 -->
 | 
			
		||||
    <base-table
 | 
			
		||||
      :page="queryParams.pageNo"
 | 
			
		||||
      :limit="queryParams.pageSize"
 | 
			
		||||
      :table-props="tableProps"
 | 
			
		||||
      :table-data="list"
 | 
			
		||||
      :max-height="tableH"
 | 
			
		||||
      :row-class-name="tableRowClassName"
 | 
			
		||||
    />
 | 
			
		||||
    <pagination
 | 
			
		||||
      :page.sync="queryParams.pageNo"
 | 
			
		||||
      :limit.sync="queryParams.pageSize"
 | 
			
		||||
      :total="total"
 | 
			
		||||
      @pagination="getList"
 | 
			
		||||
    />
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { publicFormatter } from '@/utils/dict'
 | 
			
		||||
import { parseTime } from '@/utils/ruoyi'
 | 
			
		||||
import { environmentalCheckRecordPage, environmentalCheckRecordExport, environmentalCheckPage } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
import moment from 'moment'
 | 
			
		||||
const tableProps = [
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'checkName',
 | 
			
		||||
    label: '指标名称'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'checkValue',
 | 
			
		||||
    label: '检测数值'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'unit',
 | 
			
		||||
    label: '单位',
 | 
			
		||||
    filter: publicFormatter('environment_check_unit')
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'checkTime',
 | 
			
		||||
    label: '检测时间',
 | 
			
		||||
    filter: parseTime,
 | 
			
		||||
    minWidth: 160
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'origin',
 | 
			
		||||
    label: '来源',
 | 
			
		||||
    filter: (val) => ['手动', '自动'][val]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'recordPerson',
 | 
			
		||||
    label: '录入人'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'recordTime',
 | 
			
		||||
    label: '录入时间',
 | 
			
		||||
    filter: parseTime,
 | 
			
		||||
    minWidth: 160
 | 
			
		||||
  }
 | 
			
		||||
]
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'WasteGasDetectionHistory'
 | 
			
		||||
  name: 'WasteGasDetectionHistory',
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      formConfig: [
 | 
			
		||||
        {
 | 
			
		||||
          type: 'select',
 | 
			
		||||
          label: '指标名称',
 | 
			
		||||
          selectOptions: [],
 | 
			
		||||
          param: 'checkId',
 | 
			
		||||
          filterable: true
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: 'datePicker',
 | 
			
		||||
          label: '时间',
 | 
			
		||||
          dateType: 'datetimerange',
 | 
			
		||||
          format: 'yyyy-MM-dd HH:mm:ss',
 | 
			
		||||
          valueFormat: "timestamp",
 | 
			
		||||
          rangeSeparator: '-',
 | 
			
		||||
          startPlaceholder: '开始时间',
 | 
			
		||||
          endPlaceholder: '结束时间',
 | 
			
		||||
          param: 'timeVal',
 | 
			
		||||
          defaultSelect: [],
 | 
			
		||||
          width: 350
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: 'button',
 | 
			
		||||
          btnName: '查询',
 | 
			
		||||
          name: 'search',
 | 
			
		||||
          color: 'primary'
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:waste-gas:export') ? 'separate' : '',
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:waste-gas:export') ? 'button' : '',
 | 
			
		||||
          btnName: '导出',
 | 
			
		||||
          name: 'export',
 | 
			
		||||
          color: 'primary',
 | 
			
		||||
          plain: true
 | 
			
		||||
        }
 | 
			
		||||
      ],
 | 
			
		||||
      // 查询参数
 | 
			
		||||
      queryParams: {
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 20,
 | 
			
		||||
        checkId: null,
 | 
			
		||||
        checkType: 2,
 | 
			
		||||
        startTime: null,
 | 
			
		||||
        endTime: null
 | 
			
		||||
      },
 | 
			
		||||
      tableProps,
 | 
			
		||||
      list: [],
 | 
			
		||||
      total: 0,
 | 
			
		||||
      tableH: this.tableHeight(260)
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  created() {
 | 
			
		||||
    window.addEventListener('resize', () => {
 | 
			
		||||
      this.tableH = this.tableHeight(260)
 | 
			
		||||
    })
 | 
			
		||||
    let end = moment(moment().format('YYYY-MM-DD 23:59:59')).valueOf()
 | 
			
		||||
    let start = moment(moment().format('YYYY-MM-DD 00:00:00')).valueOf()
 | 
			
		||||
    this.formConfig[1].defaultSelect = [start, end]
 | 
			
		||||
    this.queryParams.startTime = start
 | 
			
		||||
    this.queryParams.endTime = end
 | 
			
		||||
    this.getSelectList()
 | 
			
		||||
    this.getList()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    buttonClick(val) {
 | 
			
		||||
      this.queryParams.pageNo = 1;
 | 
			
		||||
      this.queryParams.checkId = val.checkId
 | 
			
		||||
      this.queryParams.startTime = val.timeVal ? val.timeVal[0] : null
 | 
			
		||||
      this.queryParams.endTime = val.timeVal ? val.timeVal[1] : null
 | 
			
		||||
      if (val.btnName === 'search') {
 | 
			
		||||
        this.getList()
 | 
			
		||||
      } else {
 | 
			
		||||
        this.$modal.confirm('是否确认导出').then(() => {
 | 
			
		||||
            return environmentalCheckRecordExport({...this.queryParams});
 | 
			
		||||
          }).then(response => {
 | 
			
		||||
            this.$download.excel(response, '废气检测历史记录.xls');
 | 
			
		||||
          }).catch(() => {})
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    getList() {
 | 
			
		||||
      environmentalCheckRecordPage({...this.queryParams}).then(res => {
 | 
			
		||||
        this.list = res.data.list || []
 | 
			
		||||
        this.total = res.data.total || 0
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    getSelectList() {
 | 
			
		||||
      environmentalCheckPage({
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 100,
 | 
			
		||||
        checkType: 2
 | 
			
		||||
      }).then(res => {
 | 
			
		||||
        console.log(res)
 | 
			
		||||
        this.formConfig[0].selectOptions = res.data.list || []
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    tableRowClassName({row, rowIndex}) {
 | 
			
		||||
      console.log(row)
 | 
			
		||||
      if (row.markRed) {
 | 
			
		||||
        return 'warning-row'
 | 
			
		||||
      }else {
 | 
			
		||||
        return ''
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
</script>
 | 
			
		||||
<style lang='scss'>
 | 
			
		||||
.wasteGasHis {
 | 
			
		||||
  .el-table .warning-row {
 | 
			
		||||
    background: #fee1e1;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
@@ -0,0 +1,124 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <el-form ref="wasteGasAddForm" :rules="rules" label-width="80px" :model="form">
 | 
			
		||||
    <el-row :gutter="20">
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="指标名称" prop="name">
 | 
			
		||||
          <el-input v-model="form.name" :disabled='isEdit'></el-input>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="指标编码" prop="code">
 | 
			
		||||
          <el-input v-model="form.code"></el-input>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="单位" prop="unit">
 | 
			
		||||
          <el-select v-model="form.unit" placeholder="请选择" style="width: 100%;" :disabled='form.method == 2'>
 | 
			
		||||
            <el-option
 | 
			
		||||
              v-for="item in getDictDatas(DICT_TYPE.ENVIRONMENT_CHECK_UNIT)"
 | 
			
		||||
              :key="item.value"
 | 
			
		||||
              :label="item.label"
 | 
			
		||||
              :value="item.value">
 | 
			
		||||
            </el-option>
 | 
			
		||||
          </el-select>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="最小值" prop="minValue">
 | 
			
		||||
          <el-input-number v-model="form.minValue" placeholder="最小值" :max="9999999" style="width: 100%;"></el-input-number>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="最大值" prop="maxValue">
 | 
			
		||||
          <el-input-number v-model="form.maxValue" placeholder="最大值" :max="9999999" style="width: 100%;"></el-input-number>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="备注" prop="remark">
 | 
			
		||||
          <el-input v-model="form.remark"></el-input>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
    </el-row>
 | 
			
		||||
  </el-form>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { environmentalCheckGet, environmentalCheckUpdate, environmentalCheckCreate, getEnvironmentalCheckCode } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'WasteGasAdd',
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      form: {
 | 
			
		||||
        id: '',
 | 
			
		||||
        name: '',
 | 
			
		||||
        code: '',
 | 
			
		||||
        unit: '',
 | 
			
		||||
        minValue: null,
 | 
			
		||||
        maxValue: null,
 | 
			
		||||
        remark: '',
 | 
			
		||||
        checkType: 2
 | 
			
		||||
      },
 | 
			
		||||
      isEdit: false,
 | 
			
		||||
      rules: {
 | 
			
		||||
        name: [{ required: true, message: "指标名称不能为空", trigger: "blur" }],
 | 
			
		||||
        code: [{ required: true, message: "指标编码不能为空", trigger: "blur" }],
 | 
			
		||||
        // unit: [{ required: true, message: "unit不能为空", trigger: "change" }],
 | 
			
		||||
        minValue: [{ required: true, message: "最小值不能为空", trigger: "blur" }],
 | 
			
		||||
        maxValue: [{ required: true, message: "最大值不能为空", trigger: "blur" }]
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    init(id) {
 | 
			
		||||
      if (id) {
 | 
			
		||||
        this.isEdit = true
 | 
			
		||||
        this.form.id = id
 | 
			
		||||
        environmentalCheckGet({id: this.form.id}).then(res => {
 | 
			
		||||
          if (res.code === 0) {
 | 
			
		||||
            this.form = res.data
 | 
			
		||||
          }
 | 
			
		||||
        })
 | 
			
		||||
      } else {
 | 
			
		||||
        this.isEdit = false
 | 
			
		||||
        this.form.id = ''
 | 
			
		||||
        // 编码
 | 
			
		||||
        getEnvironmentalCheckCode().then(res => {
 | 
			
		||||
          this.form.code = res.data || ''
 | 
			
		||||
        })
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    submitForm() {
 | 
			
		||||
      this.$refs['wasteGasAddForm'].validate((valid) => {
 | 
			
		||||
        if (valid) {
 | 
			
		||||
          if (this.form.minValue > this.form.maxValue) {
 | 
			
		||||
            this.$modal.msgError('最小值不能大于最大值')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          console.log(this.form)
 | 
			
		||||
          if (this.isEdit) {
 | 
			
		||||
            //编辑
 | 
			
		||||
            environmentalCheckUpdate({ ...this.form }).then((res) => {
 | 
			
		||||
              if (res.code === 0) {
 | 
			
		||||
                this.$modal.msgSuccess("操作成功");
 | 
			
		||||
                this.$emit('successSubmit')
 | 
			
		||||
              }
 | 
			
		||||
            })
 | 
			
		||||
          } else {
 | 
			
		||||
            environmentalCheckCreate({ ...this.form }).then((res) => {
 | 
			
		||||
              if (res.code === 0) {
 | 
			
		||||
                this.$modal.msgSuccess("操作成功");
 | 
			
		||||
                this.$emit('successSubmit')
 | 
			
		||||
              }
 | 
			
		||||
            })
 | 
			
		||||
          }
 | 
			
		||||
        } else {
 | 
			
		||||
          return false
 | 
			
		||||
        }
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    formClear() {
 | 
			
		||||
      this.$refs.wasteGasAddForm.resetFields()
 | 
			
		||||
      this.isEdit = false
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
@@ -1,8 +1,205 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div>wasteGasDetectionIndication</div>
 | 
			
		||||
  <div class="app-container">
 | 
			
		||||
    <!-- 搜索工作栏 -->
 | 
			
		||||
    <search-bar
 | 
			
		||||
      :formConfigs="formConfig"
 | 
			
		||||
      ref="searchBarForm"
 | 
			
		||||
      @headBtnClick="buttonClick"
 | 
			
		||||
    />
 | 
			
		||||
    <!-- 列表 -->
 | 
			
		||||
    <base-table
 | 
			
		||||
      :page="queryParams.pageNo"
 | 
			
		||||
      :limit="queryParams.pageSize"
 | 
			
		||||
      :table-props="tableProps"
 | 
			
		||||
      :table-data="list"
 | 
			
		||||
      :max-height="tableH"
 | 
			
		||||
    >
 | 
			
		||||
      <method-btn
 | 
			
		||||
        v-if="tableBtn.length"
 | 
			
		||||
        slot="handleBtn"
 | 
			
		||||
        :width="80"
 | 
			
		||||
        label="操作"
 | 
			
		||||
        :method-list="tableBtn"
 | 
			
		||||
        @clickBtn="handleClick"
 | 
			
		||||
      />
 | 
			
		||||
    </base-table>
 | 
			
		||||
    <pagination
 | 
			
		||||
      :page.sync="queryParams.pageNo"
 | 
			
		||||
      :limit.sync="queryParams.pageSize"
 | 
			
		||||
      :total="total"
 | 
			
		||||
      @pagination="getList"
 | 
			
		||||
    />
 | 
			
		||||
    <!-- 新增&编辑 -->
 | 
			
		||||
    <base-dialog
 | 
			
		||||
      :dialogTitle="addOrEditTitle"
 | 
			
		||||
      :dialogVisible="centervisible"
 | 
			
		||||
      @cancel="handleCancel"
 | 
			
		||||
      @confirm="handleConfirm"
 | 
			
		||||
      :before-close="handleCancel"
 | 
			
		||||
      width='60%'
 | 
			
		||||
    >
 | 
			
		||||
      <waste-gas-add ref="wasteGasAdd" @successSubmit="successSubmit" />
 | 
			
		||||
    </base-dialog>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { parseTime } from '@/utils/ruoyi'
 | 
			
		||||
import WasteGasAdd from './components/wasteGasAdd'
 | 
			
		||||
import { publicFormatter } from '@/utils/dict'
 | 
			
		||||
import { environmentalCheckPage, environmentalCheckDelete } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
const tableProps = [
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'name',
 | 
			
		||||
    label: '指标名称',
 | 
			
		||||
    minWidth: 120,
 | 
			
		||||
    showOverflowtooltip: true
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'code',
 | 
			
		||||
    label: '指示编码',
 | 
			
		||||
    minWidth: 120
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'unit',
 | 
			
		||||
    label: '单位',
 | 
			
		||||
    filter: publicFormatter('environment_check_unit')
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'minValue',
 | 
			
		||||
    label: '最小值'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'maxValue',
 | 
			
		||||
    label: '最大值'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'creator',
 | 
			
		||||
    label: '创建人'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'createTime',
 | 
			
		||||
    label: '创建时间',
 | 
			
		||||
    filter: parseTime,
 | 
			
		||||
    minWidth: 160
 | 
			
		||||
  }
 | 
			
		||||
]
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'WasteGasDetectionIndication'
 | 
			
		||||
  name: 'WasteGasDetectionIndication',
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      formConfig: [
 | 
			
		||||
        {
 | 
			
		||||
          type: 'input',
 | 
			
		||||
          label: '指标名称',
 | 
			
		||||
          placeholder: '指标名称',
 | 
			
		||||
          param: 'name'
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: 'button',
 | 
			
		||||
          btnName: '查询',
 | 
			
		||||
          name: 'search',
 | 
			
		||||
          color: 'primary'
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:waste-gas:create') ? 'separate' : '',
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:waste-gas:create') ? 'button' : '',
 | 
			
		||||
          btnName: '新增',
 | 
			
		||||
          name: 'add',
 | 
			
		||||
          color: 'success',
 | 
			
		||||
          plain: true
 | 
			
		||||
        }
 | 
			
		||||
      ],
 | 
			
		||||
      // 查询参数
 | 
			
		||||
      queryParams: {
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 20,
 | 
			
		||||
        checkType: 2,
 | 
			
		||||
        name: null
 | 
			
		||||
      },
 | 
			
		||||
      total: 0,
 | 
			
		||||
      tableProps,
 | 
			
		||||
      list: [],
 | 
			
		||||
      tableH: this.tableHeight(260),
 | 
			
		||||
      tableBtn: [
 | 
			
		||||
        this.$auth.hasPermi('base:waste-gas:update')
 | 
			
		||||
          ? {
 | 
			
		||||
              type: 'edit',
 | 
			
		||||
              btnName: '编辑'
 | 
			
		||||
            }
 | 
			
		||||
          : undefined,
 | 
			
		||||
        this.$auth.hasPermi('base:waste-gas:delete')
 | 
			
		||||
          ? {
 | 
			
		||||
              type: 'delete',
 | 
			
		||||
              btnName: '删除'
 | 
			
		||||
            }
 | 
			
		||||
          : undefined
 | 
			
		||||
      ].filter((v)=>v),
 | 
			
		||||
      addOrEditTitle: '',
 | 
			
		||||
      centervisible: false
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  components: { WasteGasAdd },
 | 
			
		||||
  mounted() {
 | 
			
		||||
    this.getList()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    getList() {
 | 
			
		||||
      environmentalCheckPage({...this.queryParams}).then(res => {
 | 
			
		||||
        this.list = res.data.list || []
 | 
			
		||||
        this.total = res.data.total || 0
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    buttonClick(val) {
 | 
			
		||||
      console.log(val)
 | 
			
		||||
      if (val.btnName === 'search') {
 | 
			
		||||
        this.queryParams.name = val.name
 | 
			
		||||
        this.getList()
 | 
			
		||||
      } else {
 | 
			
		||||
        this.addOrEditTitle = '新增'
 | 
			
		||||
        this.centervisible = true
 | 
			
		||||
        this.$nextTick(() => {
 | 
			
		||||
          this.$refs.wasteGasAdd.init()
 | 
			
		||||
        })
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    handleClick(val) {
 | 
			
		||||
      console.log(val)
 | 
			
		||||
      switch (val.type) {
 | 
			
		||||
        case 'edit':
 | 
			
		||||
          this.addOrEditTitle = '编辑'
 | 
			
		||||
          this.centervisible = true
 | 
			
		||||
          this.$nextTick(() => {
 | 
			
		||||
            this.$refs.wasteGasAdd.init(val.data.id)
 | 
			
		||||
          })
 | 
			
		||||
          break
 | 
			
		||||
        default:
 | 
			
		||||
          this.handleDelete(val.data)
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    // 删除
 | 
			
		||||
    handleDelete(val) {
 | 
			
		||||
      this.$modal.confirm('是否确认删除"' + val.name + '"的数据项?').then(function() {
 | 
			
		||||
        return environmentalCheckDelete({ id: val.id })
 | 
			
		||||
      }).then(() => {
 | 
			
		||||
        this.getList();
 | 
			
		||||
        this.$modal.msgSuccess("操作成功");
 | 
			
		||||
      }).catch(() => {});
 | 
			
		||||
    },
 | 
			
		||||
    // 新增
 | 
			
		||||
    handleCancel() {
 | 
			
		||||
      this.$refs.wasteGasAdd.formClear()
 | 
			
		||||
      this.centervisible = false
 | 
			
		||||
      this.addOrEditTitle = ''
 | 
			
		||||
    },
 | 
			
		||||
    handleConfirm() {
 | 
			
		||||
      this.$refs.wasteGasAdd.submitForm()
 | 
			
		||||
    },
 | 
			
		||||
    successSubmit() {
 | 
			
		||||
      this.handleCancel()
 | 
			
		||||
      this.getList()
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
@@ -1,8 +1,152 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div>wasteGas</div>
 | 
			
		||||
  <div class="wasteGasManagement">
 | 
			
		||||
    <div class="box1">
 | 
			
		||||
      <div class="boxTitle">
 | 
			
		||||
        <span class="blueTitle"></span>
 | 
			
		||||
        <span>检测指标实时数据</span>
 | 
			
		||||
      </div>
 | 
			
		||||
      <div class="itemBox">
 | 
			
		||||
        <div class="itemBox">
 | 
			
		||||
          <div class="itemClass" v-for="(item, index) in realtimeList" :key='index'>
 | 
			
		||||
            <div class="itemSub">
 | 
			
		||||
              <p class="itemNum">{{item.checkValue}}</p>
 | 
			
		||||
              <p class="itemDescribe">
 | 
			
		||||
                <img src="./../../../../../assets/images/detectionData.png" alt="">
 | 
			
		||||
              {{item.name}}</p>
 | 
			
		||||
            </div>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div>
 | 
			
		||||
    </div>
 | 
			
		||||
    <div class="box2">
 | 
			
		||||
      <div class="boxTitle">
 | 
			
		||||
        <span class="blueTitle"></span>
 | 
			
		||||
        <span>检测指标趋势图</span>
 | 
			
		||||
      </div>
 | 
			
		||||
      <!-- 搜索工作栏 -->
 | 
			
		||||
      <search-area @submit="getTrend"/>
 | 
			
		||||
      <line-chart :chartData="chartData" v-show='Object.keys(chartData).length !== 0' :timeDim="queryParams.timeDim"/>
 | 
			
		||||
      <!-- 没有数据 -->
 | 
			
		||||
      <div class="no-data-bg" v-show='Object.keys(chartData).length === 0'></div>
 | 
			
		||||
    </div>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { environmentalCheckRealtime, environmentalCheckRealtimeTrend } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
import LineChart from './../../components/lineChart'
 | 
			
		||||
import SearchArea from './../../components/searchArea'
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'WasteGas'
 | 
			
		||||
  name: 'WasteGasManagement',
 | 
			
		||||
  data(){
 | 
			
		||||
    return {
 | 
			
		||||
      realtimeList:[],
 | 
			
		||||
      queryParams:{
 | 
			
		||||
        checkType: 2,
 | 
			
		||||
        timeDim: null,
 | 
			
		||||
        timeRange: []
 | 
			
		||||
      },
 | 
			
		||||
      chartData: {}
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  components: { LineChart, SearchArea },
 | 
			
		||||
  mounted() {
 | 
			
		||||
    this.getMsg()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    getMsg() {
 | 
			
		||||
      environmentalCheckRealtime({checkType: 2}).then(res => {
 | 
			
		||||
        console.log(res)
 | 
			
		||||
        this.realtimeList = res.data || []
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    getTrend(params) {
 | 
			
		||||
      console.log(params)
 | 
			
		||||
      this.queryParams.timeDim = params.timeDim
 | 
			
		||||
      this.queryParams.timeRange[0] = params.startTime
 | 
			
		||||
      this.queryParams.timeRange[1] = params.endTime
 | 
			
		||||
      environmentalCheckRealtimeTrend({...this.queryParams}).then(res => {
 | 
			
		||||
        console.log(res)
 | 
			
		||||
        if (res.code === 0) {
 | 
			
		||||
          this.chartData = res.data
 | 
			
		||||
        } else {
 | 
			
		||||
          this.chartData = {}
 | 
			
		||||
        }
 | 
			
		||||
      })
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
</script>
 | 
			
		||||
<style lang='scss' scoped>
 | 
			
		||||
.wasteGasManagement {
 | 
			
		||||
  background-color: #f2f4f9;
 | 
			
		||||
  .box1 {
 | 
			
		||||
    height: 172px;
 | 
			
		||||
    padding: 12px 16px 0;
 | 
			
		||||
    margin-bottom: 8px;
 | 
			
		||||
    background-color: #fff;
 | 
			
		||||
    border-radius: 9px;
 | 
			
		||||
    .itemBox {
 | 
			
		||||
      display: flex;
 | 
			
		||||
      flex-flow: row nowrap;
 | 
			
		||||
      overflow: auto;
 | 
			
		||||
      .itemClass {
 | 
			
		||||
        width: 198px;
 | 
			
		||||
        height: 88px;
 | 
			
		||||
        // border: 1px solid green;
 | 
			
		||||
        padding: 12px 0px 12px 18px;
 | 
			
		||||
        .itemSub {
 | 
			
		||||
          width: 176px;
 | 
			
		||||
          height: 65px;
 | 
			
		||||
          padding-right: 26px;
 | 
			
		||||
          border-right: 1px solid #E8E8E8;
 | 
			
		||||
          P{
 | 
			
		||||
            margin: 0;
 | 
			
		||||
            img {
 | 
			
		||||
              width: 24px;
 | 
			
		||||
              height: 24px;
 | 
			
		||||
              vertical-align: middle;
 | 
			
		||||
            }
 | 
			
		||||
          }
 | 
			
		||||
          .itemNum {
 | 
			
		||||
            font-size: 32px;
 | 
			
		||||
            font-weight: 600;
 | 
			
		||||
            height: 43px;
 | 
			
		||||
            color: #3E6AF7;
 | 
			
		||||
            text-align: right;
 | 
			
		||||
          }
 | 
			
		||||
          .itemDescribe {
 | 
			
		||||
            font-size: 16px;
 | 
			
		||||
            text-align: right;
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    .itemClass:last-child > .itemSub{
 | 
			
		||||
      border: none !important;
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
  .box2 {
 | 
			
		||||
    background-color: #fff;
 | 
			
		||||
    border-radius: 9px;
 | 
			
		||||
    padding: 16px;
 | 
			
		||||
    height: calc(100vh - 308px);
 | 
			
		||||
  }
 | 
			
		||||
  .boxTitle {
 | 
			
		||||
    display: inline-block;
 | 
			
		||||
    font-size: 16px;
 | 
			
		||||
    font-weight: 400;
 | 
			
		||||
    color: #000000;
 | 
			
		||||
    margin:0 10px 20px 0;
 | 
			
		||||
  }
 | 
			
		||||
  .blueTitle {
 | 
			
		||||
    content: '';
 | 
			
		||||
    display: inline-block;
 | 
			
		||||
    width: 4px;
 | 
			
		||||
    height: 18px;
 | 
			
		||||
    background-color: #0B58FF;
 | 
			
		||||
    border-radius: 1px;
 | 
			
		||||
    margin-right: 8px;
 | 
			
		||||
    vertical-align: bottom;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
@@ -1,8 +1,185 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div>wasteWaterDetectionHistory</div>
 | 
			
		||||
  <div class="app-container wasteWaterHis">
 | 
			
		||||
    <!-- 搜索工作栏 -->
 | 
			
		||||
    <search-bar
 | 
			
		||||
      :formConfigs="formConfig"
 | 
			
		||||
      ref="searchBarForm"
 | 
			
		||||
      @headBtnClick="buttonClick"
 | 
			
		||||
    />
 | 
			
		||||
    <!-- 列表 -->
 | 
			
		||||
    <base-table
 | 
			
		||||
      :page="queryParams.pageNo"
 | 
			
		||||
      :limit="queryParams.pageSize"
 | 
			
		||||
      :table-props="tableProps"
 | 
			
		||||
      :table-data="list"
 | 
			
		||||
      :max-height="tableH"
 | 
			
		||||
      :row-class-name="tableRowClassName"
 | 
			
		||||
    />
 | 
			
		||||
    <pagination
 | 
			
		||||
      :page.sync="queryParams.pageNo"
 | 
			
		||||
      :limit.sync="queryParams.pageSize"
 | 
			
		||||
      :total="total"
 | 
			
		||||
      @pagination="getList"
 | 
			
		||||
    />
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { publicFormatter } from '@/utils/dict'
 | 
			
		||||
import { parseTime } from '@/utils/ruoyi'
 | 
			
		||||
import { environmentalCheckRecordPage, environmentalCheckRecordExport, environmentalCheckPage } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
import moment from 'moment'
 | 
			
		||||
const tableProps = [
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'checkName',
 | 
			
		||||
    label: '指标名称'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'checkValue',
 | 
			
		||||
    label: '检测数值'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'unit',
 | 
			
		||||
    label: '单位',
 | 
			
		||||
    filter: publicFormatter('environment_check_unit')
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'checkTime',
 | 
			
		||||
    label: '检测时间',
 | 
			
		||||
    filter: parseTime,
 | 
			
		||||
    minWidth: 160
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'origin',
 | 
			
		||||
    label: '来源',
 | 
			
		||||
    filter: (val) => ['手动', '自动'][val]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'recordPerson',
 | 
			
		||||
    label: '录入人'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'recordTime',
 | 
			
		||||
    label: '录入时间',
 | 
			
		||||
    filter: parseTime,
 | 
			
		||||
    minWidth: 160
 | 
			
		||||
  }
 | 
			
		||||
]
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'WasteWaterDetectionHistory'
 | 
			
		||||
  name: 'WasteWaterDetectionHistory',
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      formConfig: [
 | 
			
		||||
        {
 | 
			
		||||
          type: 'select',
 | 
			
		||||
          label: '指标名称',
 | 
			
		||||
          selectOptions: [],
 | 
			
		||||
          param: 'checkId',
 | 
			
		||||
          filterable: true
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: 'datePicker',
 | 
			
		||||
          label: '检测时间',
 | 
			
		||||
          dateType: 'datetimerange',
 | 
			
		||||
          format: 'yyyy-MM-dd HH:mm:ss',
 | 
			
		||||
          valueFormat: "timestamp",
 | 
			
		||||
          rangeSeparator: '-',
 | 
			
		||||
          startPlaceholder: '开始时间',
 | 
			
		||||
          endPlaceholder: '结束时间',
 | 
			
		||||
          param: 'timeVal',
 | 
			
		||||
          defaultSelect: [],
 | 
			
		||||
          width: 350
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: 'button',
 | 
			
		||||
          btnName: '查询',
 | 
			
		||||
          name: 'search',
 | 
			
		||||
          color: 'primary'
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:waste-water:export') ? 'separate' : '',
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:waste-water:export') ? 'button' : '',
 | 
			
		||||
          btnName: '导出',
 | 
			
		||||
          name: 'export',
 | 
			
		||||
          color: 'primary',
 | 
			
		||||
          plain: true
 | 
			
		||||
        }
 | 
			
		||||
      ],
 | 
			
		||||
      // 查询参数
 | 
			
		||||
      queryParams: {
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 20,
 | 
			
		||||
        checkId: null,
 | 
			
		||||
        checkType: 1,
 | 
			
		||||
        startTime: null,
 | 
			
		||||
        endTime: null
 | 
			
		||||
      },
 | 
			
		||||
      tableProps,
 | 
			
		||||
      list: [],
 | 
			
		||||
      total: 0,
 | 
			
		||||
      tableH: this.tableHeight(260)
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  created() {
 | 
			
		||||
    window.addEventListener('resize', () => {
 | 
			
		||||
      this.tableH = this.tableHeight(260)
 | 
			
		||||
    })
 | 
			
		||||
    let end = moment(moment().format('YYYY-MM-DD 23:59:59')).valueOf()
 | 
			
		||||
    let start = moment(moment().format('YYYY-MM-DD 00:00:00')).valueOf()
 | 
			
		||||
    this.formConfig[1].defaultSelect = [start, end]
 | 
			
		||||
    this.queryParams.startTime = start
 | 
			
		||||
    this.queryParams.endTime = end
 | 
			
		||||
    this.getSelectList()
 | 
			
		||||
    this.getList()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    buttonClick(val) {
 | 
			
		||||
      this.queryParams.pageNo = 1;
 | 
			
		||||
      this.queryParams.checkId = val.checkId
 | 
			
		||||
      this.queryParams.startTime = val.timeVal ? val.timeVal[0] : null
 | 
			
		||||
      this.queryParams.endTime = val.timeVal ? val.timeVal[1] : null
 | 
			
		||||
      if (val.btnName === 'search') {
 | 
			
		||||
        this.getList()
 | 
			
		||||
      } else {
 | 
			
		||||
        this.$modal.confirm('是否确认导出').then(() => {
 | 
			
		||||
            return environmentalCheckRecordExport({...this.queryParams});
 | 
			
		||||
          }).then(response => {
 | 
			
		||||
            this.$download.excel(response, '废水检测历史记录.xls');
 | 
			
		||||
          }).catch(() => {})
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    getList() {
 | 
			
		||||
      environmentalCheckRecordPage({...this.queryParams}).then(res => {
 | 
			
		||||
        this.list = res.data.list || []
 | 
			
		||||
        this.total = res.data.total || 0
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    getSelectList() {
 | 
			
		||||
      environmentalCheckPage({
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 100,
 | 
			
		||||
        checkType: 1
 | 
			
		||||
      }).then(res => {
 | 
			
		||||
        console.log(res)
 | 
			
		||||
        this.formConfig[0].selectOptions = res.data.list || []
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    tableRowClassName({row, rowIndex}) {
 | 
			
		||||
      console.log(row)
 | 
			
		||||
      if (row.markRed) {
 | 
			
		||||
        return 'warning-row'
 | 
			
		||||
      }else {
 | 
			
		||||
        return ''
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
</script>
 | 
			
		||||
<style lang='scss'>
 | 
			
		||||
.wasteWaterHis {
 | 
			
		||||
  .el-table .warning-row {
 | 
			
		||||
    background: #fee1e1;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
@@ -1,9 +1,9 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <el-form ref="wasteWaterAddForm" :rules="rules" label-width="130px" :model="form">
 | 
			
		||||
  <el-form ref="wasteWaterAddForm" :rules="rules" label-width="80px" :model="form">
 | 
			
		||||
    <el-row :gutter="20">
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="指标名称" prop="name">
 | 
			
		||||
          <el-input v-model="form.name"></el-input>
 | 
			
		||||
          <el-input v-model="form.name" :disabled='isEdit'></el-input>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
@@ -12,150 +12,113 @@
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="指标名称" prop="name1">
 | 
			
		||||
          <el-input v-model="form.name"></el-input>
 | 
			
		||||
        <el-form-item label="单位" prop="unit">
 | 
			
		||||
          <el-select v-model="form.unit" placeholder="请选择" style="width: 100%;" :disabled='form.method == 2'>
 | 
			
		||||
            <el-option
 | 
			
		||||
              v-for="item in getDictDatas(DICT_TYPE.ENVIRONMENT_CHECK_UNIT)"
 | 
			
		||||
              :key="item.value"
 | 
			
		||||
              :label="item.label"
 | 
			
		||||
              :value="item.value">
 | 
			
		||||
            </el-option>
 | 
			
		||||
          </el-select>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="最小值" prop="code11">
 | 
			
		||||
          <el-input v-model="form.code"></el-input>
 | 
			
		||||
        <el-form-item label="最小值" prop="minValue">
 | 
			
		||||
          <el-input-number v-model="form.minValue" placeholder="最小值" :max="9999999" style="width: 100%;"></el-input-number>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="最大值" prop="name12">
 | 
			
		||||
          <el-input v-model="form.name"></el-input>
 | 
			
		||||
        <el-form-item label="最大值" prop="maxValue">
 | 
			
		||||
          <el-input-number v-model="form.maxValue" placeholder="最大值" :max="9999999" style="width: 100%;"></el-input-number>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
      <el-col :span='12'>
 | 
			
		||||
        <el-form-item label="备注" prop="code1122">
 | 
			
		||||
          <el-input v-model="form.code"></el-input>
 | 
			
		||||
        <el-form-item label="备注" prop="remark">
 | 
			
		||||
          <el-input v-model="form.remark"></el-input>
 | 
			
		||||
        </el-form-item>
 | 
			
		||||
      </el-col>
 | 
			
		||||
    </el-row>
 | 
			
		||||
  </el-form>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { environmentalCheckGet, environmentalCheckUpdate, environmentalCheckCreate, getEnvironmentalCheckCode } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'WasteWaterAdd',
 | 
			
		||||
  data() {
 | 
			
		||||
    return {
 | 
			
		||||
      // rules: {
 | 
			
		||||
      //   name: [{ required: true, message: "订单名称不能为空", trigger: "blur" }],
 | 
			
		||||
      //   code: [{ required: true, message: "订单号不能为空", trigger: "blur" }],
 | 
			
		||||
      //   planQuantity: [{ required: true, message: "计划加工数量不能为空", trigger: "blur" }],
 | 
			
		||||
      //   planProductId: [{ required: true, message: "产品名称不能为空", trigger: "change" }]
 | 
			
		||||
      // }
 | 
			
		||||
      form: {
 | 
			
		||||
        id: '',
 | 
			
		||||
        name: '',
 | 
			
		||||
        code: '',
 | 
			
		||||
        unit: '',
 | 
			
		||||
        minValue: null,
 | 
			
		||||
        maxValue: null,
 | 
			
		||||
        remark: '',
 | 
			
		||||
        checkType: 1
 | 
			
		||||
      },
 | 
			
		||||
      isEdit: false,
 | 
			
		||||
      rules: {
 | 
			
		||||
        name: [{ required: true, message: "指标名称不能为空", trigger: "blur" }],
 | 
			
		||||
        code: [{ required: true, message: "指标编码不能为空", trigger: "blur" }],
 | 
			
		||||
        // unit: [{ required: true, message: "unit不能为空", trigger: "change" }],
 | 
			
		||||
        minValue: [{ required: true, message: "最小值不能为空", trigger: "blur" }],
 | 
			
		||||
        maxValue: [{ required: true, message: "最大值不能为空", trigger: "blur" }]
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
  //   init(id) {
 | 
			
		||||
  //     this.getList()
 | 
			
		||||
  //     if (id) {
 | 
			
		||||
  //       this.isEdit = true
 | 
			
		||||
  //       this.form.id = id
 | 
			
		||||
  //       getOrderById({id: this.form.id}).then(res => {
 | 
			
		||||
  //         if (res.code === 0) {
 | 
			
		||||
  //           this.form.name = res.data.name
 | 
			
		||||
  //           this.form.code = res.data.code
 | 
			
		||||
  //           this.form.planQuantity = res.data.planQuantity
 | 
			
		||||
  //           this.form.planProductId = res.data.planProductId
 | 
			
		||||
  //           this.form.price = res.data.price
 | 
			
		||||
  //           this.form.customerId = res.data.customerId
 | 
			
		||||
  //           this.form.priority = res.data.priority ? res.data.priority + '' : ''
 | 
			
		||||
  //           this.form.planStartTime = res.data.planStartTime ? res.data.planStartTime : null
 | 
			
		||||
  //           this.form.packSpec = res.data.packSpec ? res.data.packSpec+'' : ''
 | 
			
		||||
  //           this.form.workers = res.data.workers
 | 
			
		||||
  //           this.form.processFlowId = res.data.processFlowId
 | 
			
		||||
  //           this.form.materialMethod = res.data.materialMethod
 | 
			
		||||
  //           this.form.planFinishTime = res.data.planFinishTime ? res.data.planFinishTime : null
 | 
			
		||||
  //           this.form.remark = res.data.remark
 | 
			
		||||
  //           // this.form.description = res.data.description
 | 
			
		||||
  //         }
 | 
			
		||||
  //       })
 | 
			
		||||
  //     } else {
 | 
			
		||||
  //       this.isEdit = false
 | 
			
		||||
  //       this.form.id = ''
 | 
			
		||||
  //       // 订单号
 | 
			
		||||
  //       getOrderCode().then(res => {
 | 
			
		||||
  //         this.form.code = res.data || ''
 | 
			
		||||
  //       })
 | 
			
		||||
  //     }
 | 
			
		||||
  //   },
 | 
			
		||||
  //   getList() {
 | 
			
		||||
  //     // 产品
 | 
			
		||||
  //     getProductAll().then(res => {
 | 
			
		||||
  //       this.productList = res.data || []
 | 
			
		||||
  //     })
 | 
			
		||||
  //     // 客户
 | 
			
		||||
  //     getCustomerList().then(res => {
 | 
			
		||||
  //       this.customerList = res.data || []
 | 
			
		||||
  //     })
 | 
			
		||||
  //     // 工艺
 | 
			
		||||
  //     getProcessFlowList().then(res => {
 | 
			
		||||
  //       this.processFlowList = res.data || []
 | 
			
		||||
  //     })
 | 
			
		||||
  //   },
 | 
			
		||||
  //   timeChange() {
 | 
			
		||||
  //     if (this.form.planStartTime && this.form.planFinishTime) {
 | 
			
		||||
  //       if (this.form.planStartTime > this.form.planFinishTime) {
 | 
			
		||||
  //         this.$modal.msgError('计划开始时间不能大于结束时间')
 | 
			
		||||
  //       }
 | 
			
		||||
  //     }
 | 
			
		||||
  //   },
 | 
			
		||||
  //   // 工艺变更
 | 
			
		||||
  //   materialMethodChange(val) {
 | 
			
		||||
  //     if (val === 2 && !this.form.processFlowId) {
 | 
			
		||||
  //       this.form.materialMethod = 1
 | 
			
		||||
  //       this.$modal.msgError("请先选择关联工艺");
 | 
			
		||||
  //     }
 | 
			
		||||
  //   },
 | 
			
		||||
  //   // 工艺变更
 | 
			
		||||
  //   processFlowIdChange(val) {
 | 
			
		||||
  //     console.log(val)
 | 
			
		||||
  //     if (!val) {
 | 
			
		||||
  //       this.form.materialMethod = 1
 | 
			
		||||
  //     }
 | 
			
		||||
  //   },
 | 
			
		||||
  //   submitForm() {
 | 
			
		||||
  //     this.$refs['orderAddForm'].validate((valid) => {
 | 
			
		||||
  //       if (valid) {
 | 
			
		||||
  //         if (this.form.planStartTime && this.form.planFinishTime) {
 | 
			
		||||
  //           if (this.form.planStartTime > this.form.planFinishTime) {
 | 
			
		||||
  //             this.$modal.msgError('计划开始时间不能大于结束时间')
 | 
			
		||||
  //             return false
 | 
			
		||||
  //           }
 | 
			
		||||
  //         }
 | 
			
		||||
  //         // console.log(this.form)
 | 
			
		||||
  //         if (this.isEdit) {
 | 
			
		||||
  //           //编辑
 | 
			
		||||
  //           orderUpdate({ ...this.form }).then((res) => {
 | 
			
		||||
  //             if (res.code === 0) {
 | 
			
		||||
  //               this.$modal.msgSuccess("操作成功");
 | 
			
		||||
  //               this.$emit('successSubmit')
 | 
			
		||||
  //             }
 | 
			
		||||
  //           })
 | 
			
		||||
  //         } else {
 | 
			
		||||
  //           this.form.status = 1
 | 
			
		||||
  //           this.form.triggerOrigin = 1
 | 
			
		||||
  //           orderCreate({ ...this.form }).then((res) => {
 | 
			
		||||
  //             if (res.code === 0) {
 | 
			
		||||
  //               this.$modal.msgSuccess("操作成功");
 | 
			
		||||
  //               this.$emit('successSubmit')
 | 
			
		||||
  //             }
 | 
			
		||||
  //           })
 | 
			
		||||
  //         }
 | 
			
		||||
  //       } else {
 | 
			
		||||
  //         return false
 | 
			
		||||
  //       }
 | 
			
		||||
  //     })
 | 
			
		||||
  //   },
 | 
			
		||||
  //   formClear() {
 | 
			
		||||
  //     this.$refs.orderAddForm.resetFields()
 | 
			
		||||
  //     this.form.materialMethod = 1
 | 
			
		||||
  //     this.form.price = 0.00
 | 
			
		||||
  //     this.form.planQuantity = 0
 | 
			
		||||
  //     this.isEdit = false
 | 
			
		||||
  //   }
 | 
			
		||||
    init(id) {
 | 
			
		||||
      if (id) {
 | 
			
		||||
        this.isEdit = true
 | 
			
		||||
        this.form.id = id
 | 
			
		||||
        environmentalCheckGet({id: this.form.id}).then(res => {
 | 
			
		||||
          if (res.code === 0) {
 | 
			
		||||
            this.form = res.data
 | 
			
		||||
          }
 | 
			
		||||
        })
 | 
			
		||||
      } else {
 | 
			
		||||
        this.isEdit = false
 | 
			
		||||
        this.form.id = ''
 | 
			
		||||
        // 编码
 | 
			
		||||
        getEnvironmentalCheckCode().then(res => {
 | 
			
		||||
          this.form.code = res.data || ''
 | 
			
		||||
        })
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    submitForm() {
 | 
			
		||||
      this.$refs['wasteWaterAddForm'].validate((valid) => {
 | 
			
		||||
        if (valid) {
 | 
			
		||||
          if (this.form.minValue > this.form.maxValue) {
 | 
			
		||||
            this.$modal.msgError('最小值不能大于最大值')
 | 
			
		||||
            return false
 | 
			
		||||
          }
 | 
			
		||||
          console.log(this.form)
 | 
			
		||||
          if (this.isEdit) {
 | 
			
		||||
            //编辑
 | 
			
		||||
            environmentalCheckUpdate({ ...this.form }).then((res) => {
 | 
			
		||||
              if (res.code === 0) {
 | 
			
		||||
                this.$modal.msgSuccess("操作成功");
 | 
			
		||||
                this.$emit('successSubmit')
 | 
			
		||||
              }
 | 
			
		||||
            })
 | 
			
		||||
          } else {
 | 
			
		||||
            environmentalCheckCreate({ ...this.form }).then((res) => {
 | 
			
		||||
              if (res.code === 0) {
 | 
			
		||||
                this.$modal.msgSuccess("操作成功");
 | 
			
		||||
                this.$emit('successSubmit')
 | 
			
		||||
              }
 | 
			
		||||
            })
 | 
			
		||||
          }
 | 
			
		||||
        } else {
 | 
			
		||||
          return false
 | 
			
		||||
        }
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    formClear() {
 | 
			
		||||
      this.$refs.wasteWaterAddForm.resetFields()
 | 
			
		||||
      this.isEdit = false
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
@@ -17,7 +17,7 @@
 | 
			
		||||
      <method-btn
 | 
			
		||||
        v-if="tableBtn.length"
 | 
			
		||||
        slot="handleBtn"
 | 
			
		||||
        :width="120"
 | 
			
		||||
        :width="80"
 | 
			
		||||
        label="操作"
 | 
			
		||||
        :method-list="tableBtn"
 | 
			
		||||
        @clickBtn="handleClick"
 | 
			
		||||
@@ -44,11 +44,13 @@
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { parseTime } from '@/utils/ruoyi'
 | 
			
		||||
// import { publicFormatter } from '@/utils/dict'
 | 
			
		||||
import WasteWaterAdd from './components/wasteWaterAdd'
 | 
			
		||||
import { publicFormatter } from '@/utils/dict'
 | 
			
		||||
import { environmentalCheckPage, environmentalCheckDelete } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
const tableProps = [
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'name',
 | 
			
		||||
    label: '指示名称',
 | 
			
		||||
    label: '指标名称',
 | 
			
		||||
    minWidth: 120,
 | 
			
		||||
    showOverflowtooltip: true
 | 
			
		||||
  },
 | 
			
		||||
@@ -58,26 +60,22 @@ const tableProps = [
 | 
			
		||||
    minWidth: 120
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'customerId',
 | 
			
		||||
    label: '单位'
 | 
			
		||||
    prop: 'unit',
 | 
			
		||||
    label: '单位',
 | 
			
		||||
    filter: publicFormatter('environment_check_unit')
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'customerId1',
 | 
			
		||||
    prop: 'minValue',
 | 
			
		||||
    label: '最小值'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'customerId2',
 | 
			
		||||
    prop: 'maxValue',
 | 
			
		||||
    label: '最大值'
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'customerId3',
 | 
			
		||||
    prop: 'creator',
 | 
			
		||||
    label: '创建人'
 | 
			
		||||
  },
 | 
			
		||||
  // {
 | 
			
		||||
  //   prop: 'triggerOrigin',
 | 
			
		||||
  //   label: '来源',
 | 
			
		||||
  //   filter: publicFormatter('order_Origin')
 | 
			
		||||
  // },
 | 
			
		||||
  {
 | 
			
		||||
    prop: 'createTime',
 | 
			
		||||
    label: '创建时间',
 | 
			
		||||
@@ -91,11 +89,9 @@ export default {
 | 
			
		||||
    return {
 | 
			
		||||
      formConfig: [
 | 
			
		||||
        {
 | 
			
		||||
          type: 'select',
 | 
			
		||||
          type: 'input',
 | 
			
		||||
          label: '指标名称',
 | 
			
		||||
          selectOptions: this.getDictDatas(this.DICT_TYPE.ORDER_STATUS),
 | 
			
		||||
          labelField: 'label',
 | 
			
		||||
          valueField: 'value',
 | 
			
		||||
          placeholder: '指标名称',
 | 
			
		||||
          param: 'name'
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
@@ -105,10 +101,10 @@ export default {
 | 
			
		||||
          color: 'primary'
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:order-manage:create') ? 'separate' : '',
 | 
			
		||||
          type: this.$auth.hasPermi('base:waste-water:create') ? 'separate' : '',
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
          type: this.$auth.hasPermi('base:order-manage:create') ? 'button' : '',
 | 
			
		||||
          type: this.$auth.hasPermi('base:waste-water:create') ? 'button' : '',
 | 
			
		||||
          btnName: '新增',
 | 
			
		||||
          name: 'add',
 | 
			
		||||
          color: 'success',
 | 
			
		||||
@@ -119,35 +115,42 @@ export default {
 | 
			
		||||
      queryParams: {
 | 
			
		||||
        pageNo: 1,
 | 
			
		||||
        pageSize: 20,
 | 
			
		||||
        name: null,
 | 
			
		||||
        status: null
 | 
			
		||||
        checkType: 1,
 | 
			
		||||
        name: null
 | 
			
		||||
      },
 | 
			
		||||
      total: 0,
 | 
			
		||||
      tableProps,
 | 
			
		||||
      list: [
 | 
			
		||||
        {name:'1111'}
 | 
			
		||||
      ],
 | 
			
		||||
      list: [],
 | 
			
		||||
      tableH: this.tableHeight(260),
 | 
			
		||||
      tableBtn: [
 | 
			
		||||
        this.$auth.hasPermi('base:order-manage:edit')
 | 
			
		||||
        this.$auth.hasPermi('base:waste-water:update')
 | 
			
		||||
          ? {
 | 
			
		||||
              type: 'edit',
 | 
			
		||||
              btnName: '编辑'
 | 
			
		||||
            }
 | 
			
		||||
          : undefined,
 | 
			
		||||
        this.$auth.hasPermi('base:order-manage:delete')
 | 
			
		||||
        this.$auth.hasPermi('base:waste-water:delete')
 | 
			
		||||
          ? {
 | 
			
		||||
              type: 'delete',
 | 
			
		||||
              btnName: '删除'
 | 
			
		||||
            }
 | 
			
		||||
          : undefined
 | 
			
		||||
      ],
 | 
			
		||||
      ].filter((v)=>v),
 | 
			
		||||
      addOrEditTitle: '',
 | 
			
		||||
      centervisible: false
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  components: { WasteWaterAdd },
 | 
			
		||||
  mounted() {
 | 
			
		||||
    this.getList()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    getList() {},
 | 
			
		||||
    getList() {
 | 
			
		||||
      environmentalCheckPage({...this.queryParams}).then(res => {
 | 
			
		||||
        this.list = res.data.list || []
 | 
			
		||||
        this.total = res.data.total || 0
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    buttonClick(val) {
 | 
			
		||||
      console.log(val)
 | 
			
		||||
      if (val.btnName === 'search') {
 | 
			
		||||
@@ -178,7 +181,7 @@ export default {
 | 
			
		||||
    // 删除
 | 
			
		||||
    handleDelete(val) {
 | 
			
		||||
      this.$modal.confirm('是否确认删除"' + val.name + '"的数据项?').then(function() {
 | 
			
		||||
        // return wasteWaterDelete({ id: val.id })
 | 
			
		||||
        return environmentalCheckDelete({ id: val.id })
 | 
			
		||||
      }).then(() => {
 | 
			
		||||
        this.getList();
 | 
			
		||||
        this.$modal.msgSuccess("操作成功");
 | 
			
		||||
 
 | 
			
		||||
@@ -1,8 +1,150 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div>wasteWater</div>
 | 
			
		||||
  <div class="wasteWaterManagement">
 | 
			
		||||
    <div class="box1">
 | 
			
		||||
      <div class="boxTitle">
 | 
			
		||||
        <span class="blueTitle"></span>
 | 
			
		||||
        <span>检测指标实时数据</span>
 | 
			
		||||
      </div>
 | 
			
		||||
      <div class="itemBox">
 | 
			
		||||
        <div class="itemClass" v-for="(item, index) in realtimeList" :key='index'>
 | 
			
		||||
          <div class="itemSub">
 | 
			
		||||
            <p class="itemNum">{{item.checkValue}}</p>
 | 
			
		||||
            <p class="itemDescribe">
 | 
			
		||||
              <img src="./../../../../../assets/images/detectionData.png" alt="">
 | 
			
		||||
            {{item.name}}</p>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
      </div>
 | 
			
		||||
    </div>
 | 
			
		||||
    <div class="box2">
 | 
			
		||||
      <div class="boxTitle">
 | 
			
		||||
        <span class="blueTitle"></span>
 | 
			
		||||
        <span>检测指标趋势图</span>
 | 
			
		||||
      </div>
 | 
			
		||||
      <!-- 搜索工作栏 -->
 | 
			
		||||
      <search-area @submit="getTrend"/>
 | 
			
		||||
      <line-chart :chartData="chartData" v-show='Object.keys(chartData).length !== 0' :timeDim="queryParams.timeDim"/>
 | 
			
		||||
      <!-- 没有数据 -->
 | 
			
		||||
      <div class="no-data-bg" v-show='Object.keys(chartData).length === 0'></div>
 | 
			
		||||
    </div>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
<script>
 | 
			
		||||
import { environmentalCheckRealtime, environmentalCheckRealtimeTrend } from '@/api/safetyEnvironmental/environmental'
 | 
			
		||||
import LineChart from './../../components/lineChart'
 | 
			
		||||
import SearchArea from './../../components/searchArea'
 | 
			
		||||
export default {
 | 
			
		||||
  name: 'WasteWater'
 | 
			
		||||
  name: 'WasteWaterManagement',
 | 
			
		||||
  data(){
 | 
			
		||||
    return {
 | 
			
		||||
      realtimeList:[],
 | 
			
		||||
      queryParams:{
 | 
			
		||||
        checkType: 1,
 | 
			
		||||
        timeDim: null,
 | 
			
		||||
        timeRange: []
 | 
			
		||||
      },
 | 
			
		||||
      chartData: {}
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  components: { LineChart, SearchArea },
 | 
			
		||||
  mounted() {
 | 
			
		||||
    this.getMsg()
 | 
			
		||||
  },
 | 
			
		||||
  methods: {
 | 
			
		||||
    getMsg() {
 | 
			
		||||
      environmentalCheckRealtime({checkType: 1}).then(res => {
 | 
			
		||||
        console.log(res)
 | 
			
		||||
        this.realtimeList = res.data || []
 | 
			
		||||
      })
 | 
			
		||||
    },
 | 
			
		||||
    getTrend(params) {
 | 
			
		||||
      console.log(params)
 | 
			
		||||
      this.queryParams.timeDim = params.timeDim
 | 
			
		||||
      this.queryParams.timeRange[0] = params.startTime
 | 
			
		||||
      this.queryParams.timeRange[1] = params.endTime
 | 
			
		||||
      environmentalCheckRealtimeTrend({...this.queryParams}).then(res => {
 | 
			
		||||
        console.log(res)
 | 
			
		||||
        if (res.code === 0) {
 | 
			
		||||
          this.chartData = res.data
 | 
			
		||||
        } else {
 | 
			
		||||
          this.chartData = {}
 | 
			
		||||
        }
 | 
			
		||||
      })
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
</script>
 | 
			
		||||
<style lang='scss' scoped>
 | 
			
		||||
.wasteWaterManagement {
 | 
			
		||||
  background-color: #f2f4f9;
 | 
			
		||||
  .box1 {
 | 
			
		||||
    height: 172px;
 | 
			
		||||
    padding: 12px 16px 0;
 | 
			
		||||
    margin-bottom: 8px;
 | 
			
		||||
    background-color: #fff;
 | 
			
		||||
    border-radius: 9px;
 | 
			
		||||
    .itemBox {
 | 
			
		||||
      display: flex;
 | 
			
		||||
      flex-flow: row nowrap;
 | 
			
		||||
      overflow: auto;
 | 
			
		||||
      .itemClass {
 | 
			
		||||
        width: 198px;
 | 
			
		||||
        height: 88px;
 | 
			
		||||
        // border: 1px solid green;
 | 
			
		||||
        padding: 12px 0px 12px 18px;
 | 
			
		||||
        .itemSub {
 | 
			
		||||
          width: 176px;
 | 
			
		||||
          height: 65px;
 | 
			
		||||
          padding-right: 26px;
 | 
			
		||||
          border-right: 1px solid #E8E8E8;
 | 
			
		||||
          P{
 | 
			
		||||
            margin: 0;
 | 
			
		||||
            img {
 | 
			
		||||
              width: 24px;
 | 
			
		||||
              height: 24px;
 | 
			
		||||
              vertical-align: middle;
 | 
			
		||||
            }
 | 
			
		||||
          }
 | 
			
		||||
          .itemNum {
 | 
			
		||||
            font-size: 32px;
 | 
			
		||||
            font-weight: 600;
 | 
			
		||||
            height: 43px;
 | 
			
		||||
            color: #3E6AF7;
 | 
			
		||||
            text-align: right;
 | 
			
		||||
          }
 | 
			
		||||
          .itemDescribe {
 | 
			
		||||
            font-size: 16px;
 | 
			
		||||
            text-align: right;
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    .itemClass:last-child > .itemSub{
 | 
			
		||||
      border: none !important;
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
  .box2 {
 | 
			
		||||
    background-color: #fff;
 | 
			
		||||
    border-radius: 9px;
 | 
			
		||||
    padding: 16px;
 | 
			
		||||
    height: calc(100vh - 308px);
 | 
			
		||||
  }
 | 
			
		||||
  .boxTitle {
 | 
			
		||||
    display: inline-block;
 | 
			
		||||
    font-size: 16px;
 | 
			
		||||
    font-weight: 400;
 | 
			
		||||
    color: #000000;
 | 
			
		||||
    margin:0 10px 20px 0;
 | 
			
		||||
  }
 | 
			
		||||
  .blueTitle {
 | 
			
		||||
    content: '';
 | 
			
		||||
    display: inline-block;
 | 
			
		||||
    width: 4px;
 | 
			
		||||
    height: 18px;
 | 
			
		||||
    background-color: #0B58FF;
 | 
			
		||||
    border-radius: 1px;
 | 
			
		||||
    margin-right: 8px;
 | 
			
		||||
    vertical-align: bottom;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
@@ -62,6 +62,7 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'code',
 | 
			
		||||
		label: '物品编码',
 | 
			
		||||
    width: 200
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'spec',
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2023-11-03 16:37:06
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-24 14:35:01
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:31:23
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -42,7 +42,7 @@
 | 
			
		||||
					<span>{{ parseTime(scope.row.latestOutTime) }}</span>
 | 
			
		||||
				</template>
 | 
			
		||||
			</el-table-column>
 | 
			
		||||
			<el-table-column label="操作" width="100">
 | 
			
		||||
			<el-table-column label="操作" width="100" v-if="false">
 | 
			
		||||
				<template v-slot="scope">
 | 
			
		||||
					<el-button
 | 
			
		||||
						size="mini"
 | 
			
		||||
@@ -134,16 +134,16 @@ export default {
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'separate',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('end-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
					btnName: '入库',
 | 
			
		||||
					name: 'add',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: 'separate',
 | 
			
		||||
				// },
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: this.$auth.hasPermi('end-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
				// 	btnName: '入库',
 | 
			
		||||
				// 	name: 'add',
 | 
			
		||||
				// 	color: 'primary',
 | 
			
		||||
				// 	plain: true,
 | 
			
		||||
				// },
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2021-11-18 14:16:25
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-23 16:08:09
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:15:52
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -41,21 +41,23 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'num',
 | 
			
		||||
		label: '数量',
 | 
			
		||||
    width: 50
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'allowTime',
 | 
			
		||||
		label: '允许留存时长(天)',
 | 
			
		||||
    width: 150
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'leftTime',
 | 
			
		||||
		label: '剩余留存时长(天)',
 | 
			
		||||
    width: 150
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
 
 | 
			
		||||
@@ -16,7 +16,7 @@
 | 
			
		||||
			<method-btn
 | 
			
		||||
				v-if="tableBtn.length"
 | 
			
		||||
				slot="handleBtn"
 | 
			
		||||
				:width="140"
 | 
			
		||||
				:width="70"
 | 
			
		||||
				label="操作"
 | 
			
		||||
				:method-list="tableBtn"
 | 
			
		||||
				@clickBtn="handleClick" />
 | 
			
		||||
@@ -36,7 +36,7 @@
 | 
			
		||||
			:dialogTitle="addOrEditTitle"
 | 
			
		||||
			:dialogVisible="addOrUpdateVisible"
 | 
			
		||||
			:before-close="handleCancel"
 | 
			
		||||
			width="50%">
 | 
			
		||||
			width="60%">
 | 
			
		||||
			<add-or-update
 | 
			
		||||
				ref="addOrUpdate"
 | 
			
		||||
				@refreshDataList="successSubmit"></add-or-update>
 | 
			
		||||
@@ -99,7 +99,7 @@ const tableProps = [
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
		minWidth: 100,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
@@ -124,18 +124,18 @@ export default {
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			tableProps,
 | 
			
		||||
			tableBtn: [
 | 
			
		||||
				this.$auth.hasPermi(`end-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'out',
 | 
			
		||||
							btnName: '出库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`end-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'in',
 | 
			
		||||
							btnName: '入库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`end-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'out',
 | 
			
		||||
				// 			btnName: '出库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`end-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'in',
 | 
			
		||||
				// 			btnName: '入库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`end-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'detail',
 | 
			
		||||
 
 | 
			
		||||
@@ -62,6 +62,7 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'code',
 | 
			
		||||
		label: '物品编码',
 | 
			
		||||
    width: 200
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'spec',
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2023-11-03 16:37:06
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-24 14:36:24
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:31:06
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -42,7 +42,7 @@
 | 
			
		||||
					<span>{{ parseTime(scope.row.latestOutTime) }}</span>
 | 
			
		||||
				</template>
 | 
			
		||||
			</el-table-column>
 | 
			
		||||
			<el-table-column label="操作" width="100">
 | 
			
		||||
			<el-table-column label="操作" width="100" v-if="false">
 | 
			
		||||
				<template v-slot="scope">
 | 
			
		||||
					<el-button
 | 
			
		||||
						size="mini"
 | 
			
		||||
@@ -134,16 +134,16 @@ export default {
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'separate',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('out-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
					btnName: '入库',
 | 
			
		||||
					name: 'add',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: 'separate',
 | 
			
		||||
				// },
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: this.$auth.hasPermi('out-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
				// 	btnName: '入库',
 | 
			
		||||
				// 	name: 'add',
 | 
			
		||||
				// 	color: 'primary',
 | 
			
		||||
				// 	plain: true,
 | 
			
		||||
				// },
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2021-11-18 14:16:25
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-23 16:07:43
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:15:40
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -41,21 +41,23 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'num',
 | 
			
		||||
		label: '数量',
 | 
			
		||||
    width: 50
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'allowTime',
 | 
			
		||||
		label: '允许留存时长(天)',
 | 
			
		||||
		width: 150,
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'leftTime',
 | 
			
		||||
		label: '剩余留存时长(天)',
 | 
			
		||||
		width: 150,
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
 
 | 
			
		||||
@@ -16,7 +16,7 @@
 | 
			
		||||
			<method-btn
 | 
			
		||||
				v-if="tableBtn.length"
 | 
			
		||||
				slot="handleBtn"
 | 
			
		||||
				:width="140"
 | 
			
		||||
				:width="70"
 | 
			
		||||
				label="操作"
 | 
			
		||||
				:method-list="tableBtn"
 | 
			
		||||
				@clickBtn="handleClick" />
 | 
			
		||||
@@ -36,7 +36,7 @@
 | 
			
		||||
			:dialogTitle="addOrEditTitle"
 | 
			
		||||
			:dialogVisible="addOrUpdateVisible"
 | 
			
		||||
			:before-close="handleCancel"
 | 
			
		||||
			width="50%">
 | 
			
		||||
			width="60%">
 | 
			
		||||
			<add-or-update
 | 
			
		||||
				ref="addOrUpdate"
 | 
			
		||||
				@refreshDataList="successSubmit"></add-or-update>
 | 
			
		||||
@@ -99,7 +99,7 @@ const tableProps = [
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
		minWidth: 100,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
@@ -124,18 +124,18 @@ export default {
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			tableProps,
 | 
			
		||||
			tableBtn: [
 | 
			
		||||
				this.$auth.hasPermi(`out-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'out',
 | 
			
		||||
							btnName: '出库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`out-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'in',
 | 
			
		||||
							btnName: '入库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`out-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'out',
 | 
			
		||||
				// 			btnName: '出库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`out-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'in',
 | 
			
		||||
				// 			btnName: '入库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`out-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'detail',
 | 
			
		||||
 
 | 
			
		||||
@@ -62,6 +62,7 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'code',
 | 
			
		||||
		label: '物品编码',
 | 
			
		||||
    width: 200
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'spec',
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2023-11-03 16:37:06
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-24 14:36:08
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:30:52
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -42,7 +42,7 @@
 | 
			
		||||
					<span>{{ parseTime(scope.row.latestOutTime) }}</span>
 | 
			
		||||
				</template>
 | 
			
		||||
			</el-table-column>
 | 
			
		||||
			<el-table-column label="操作" width="100">
 | 
			
		||||
			<el-table-column label="操作" width="100" v-if="false">
 | 
			
		||||
				<template v-slot="scope">
 | 
			
		||||
					<el-button
 | 
			
		||||
						size="mini"
 | 
			
		||||
@@ -134,16 +134,16 @@ export default {
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'separate',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('pack-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
					btnName: '入库',
 | 
			
		||||
					name: 'add',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: 'separate',
 | 
			
		||||
				// },
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: this.$auth.hasPermi('pack-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
				// 	btnName: '入库',
 | 
			
		||||
				// 	name: 'add',
 | 
			
		||||
				// 	color: 'primary',
 | 
			
		||||
				// 	plain: true,
 | 
			
		||||
				// },
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2021-11-18 14:16:25
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-23 16:08:22
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:15:26
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -41,21 +41,23 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'num',
 | 
			
		||||
		label: '数量',
 | 
			
		||||
    width: 50
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'allowTime',
 | 
			
		||||
		label: '允许留存时长(天)',
 | 
			
		||||
    width: 150
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'leftTime',
 | 
			
		||||
		label: '剩余留存时长(天)',
 | 
			
		||||
    width: 150
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
 
 | 
			
		||||
@@ -16,7 +16,7 @@
 | 
			
		||||
			<method-btn
 | 
			
		||||
				v-if="tableBtn.length"
 | 
			
		||||
				slot="handleBtn"
 | 
			
		||||
				:width="140"
 | 
			
		||||
				:width="70"
 | 
			
		||||
				label="操作"
 | 
			
		||||
				:method-list="tableBtn"
 | 
			
		||||
				@clickBtn="handleClick" />
 | 
			
		||||
@@ -36,7 +36,7 @@
 | 
			
		||||
			:dialogTitle="addOrEditTitle"
 | 
			
		||||
			:dialogVisible="addOrUpdateVisible"
 | 
			
		||||
			:before-close="handleCancel"
 | 
			
		||||
			width="50%">
 | 
			
		||||
			width="60%">
 | 
			
		||||
			<add-or-update
 | 
			
		||||
				ref="addOrUpdate"
 | 
			
		||||
				@refreshDataList="successSubmit"></add-or-update>
 | 
			
		||||
@@ -99,7 +99,7 @@ const tableProps = [
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
		minWidth: 100,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
@@ -124,18 +124,18 @@ export default {
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			tableProps,
 | 
			
		||||
			tableBtn: [
 | 
			
		||||
				this.$auth.hasPermi(`pack-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'out',
 | 
			
		||||
							btnName: '出库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`pack-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'in',
 | 
			
		||||
							btnName: '入库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`pack-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'out',
 | 
			
		||||
				// 			btnName: '出库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`pack-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'in',
 | 
			
		||||
				// 			btnName: '入库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`pack-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'detail',
 | 
			
		||||
 
 | 
			
		||||
@@ -62,6 +62,7 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'code',
 | 
			
		||||
		label: '物品编码',
 | 
			
		||||
    width: 200
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'spec',
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2023-11-03 16:37:06
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-24 14:35:51
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:30:39
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -42,7 +42,7 @@
 | 
			
		||||
					<span>{{ parseTime(scope.row.latestOutTime) }}</span>
 | 
			
		||||
				</template>
 | 
			
		||||
			</el-table-column>
 | 
			
		||||
			<el-table-column label="操作" width="100">
 | 
			
		||||
			<el-table-column label="操作" width="100" v-if="false">
 | 
			
		||||
				<template v-slot="scope">
 | 
			
		||||
					<el-button
 | 
			
		||||
						size="mini"
 | 
			
		||||
@@ -134,16 +134,16 @@ export default {
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'separate',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('part-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
					btnName: '入库',
 | 
			
		||||
					name: 'add',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: 'separate',
 | 
			
		||||
				// },
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: this.$auth.hasPermi('part-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
				// 	btnName: '入库',
 | 
			
		||||
				// 	name: 'add',
 | 
			
		||||
				// 	color: 'primary',
 | 
			
		||||
				// 	plain: true,
 | 
			
		||||
				// },
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2021-11-18 14:16:25
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-23 16:08:31
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:15:11
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -41,21 +41,23 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'num',
 | 
			
		||||
		label: '数量',
 | 
			
		||||
    width: 50
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'allowTime',
 | 
			
		||||
		label: '允许留存时长(天)',
 | 
			
		||||
    width: 150
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'leftTime',
 | 
			
		||||
		label: '剩余留存时长(天)',
 | 
			
		||||
    width: 150
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
 
 | 
			
		||||
@@ -16,7 +16,7 @@
 | 
			
		||||
			<method-btn
 | 
			
		||||
				v-if="tableBtn.length"
 | 
			
		||||
				slot="handleBtn"
 | 
			
		||||
				:width="140"
 | 
			
		||||
				:width="70"
 | 
			
		||||
				label="操作"
 | 
			
		||||
				:method-list="tableBtn"
 | 
			
		||||
				@clickBtn="handleClick" />
 | 
			
		||||
@@ -36,7 +36,7 @@
 | 
			
		||||
			:dialogTitle="addOrEditTitle"
 | 
			
		||||
			:dialogVisible="addOrUpdateVisible"
 | 
			
		||||
			:before-close="handleCancel"
 | 
			
		||||
			width="50%">
 | 
			
		||||
			width="60%">
 | 
			
		||||
			<add-or-update
 | 
			
		||||
				ref="addOrUpdate"
 | 
			
		||||
				@refreshDataList="successSubmit"></add-or-update>
 | 
			
		||||
@@ -99,7 +99,7 @@ const tableProps = [
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
		minWidth: 100,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
@@ -124,18 +124,18 @@ export default {
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			tableProps,
 | 
			
		||||
			tableBtn: [
 | 
			
		||||
				this.$auth.hasPermi(`part-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'out',
 | 
			
		||||
							btnName: '出库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`part-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'in',
 | 
			
		||||
							btnName: '入库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`part-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'out',
 | 
			
		||||
				// 			btnName: '出库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`part-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'in',
 | 
			
		||||
				// 			btnName: '入库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`part-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'detail',
 | 
			
		||||
 
 | 
			
		||||
@@ -62,6 +62,7 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'code',
 | 
			
		||||
		label: '物品编码',
 | 
			
		||||
    width: 200
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'spec',
 | 
			
		||||
 
 | 
			
		||||
@@ -42,7 +42,7 @@
 | 
			
		||||
					<span>{{ parseTime(scope.row.latestOutTime) }}</span>
 | 
			
		||||
				</template>
 | 
			
		||||
			</el-table-column>
 | 
			
		||||
			<el-table-column label="操作" width="100">
 | 
			
		||||
			<el-table-column label="操作" width="100" v-if="false">
 | 
			
		||||
				<template v-slot="scope">
 | 
			
		||||
					<el-button
 | 
			
		||||
						size="mini"
 | 
			
		||||
@@ -134,16 +134,16 @@ export default {
 | 
			
		||||
					name: 'search',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: 'separate',
 | 
			
		||||
				},
 | 
			
		||||
				{
 | 
			
		||||
					type: this.$auth.hasPermi('raw-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
					btnName: '入库',
 | 
			
		||||
					name: 'add',
 | 
			
		||||
					color: 'primary',
 | 
			
		||||
					plain: true,
 | 
			
		||||
				},
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: 'separate',
 | 
			
		||||
				// },
 | 
			
		||||
				// {
 | 
			
		||||
				// 	type: this.$auth.hasPermi('raw-material:warehouse-realtime:create') ? 'button' : '',
 | 
			
		||||
				// 	btnName: '入库',
 | 
			
		||||
				// 	name: 'add',
 | 
			
		||||
				// 	color: 'primary',
 | 
			
		||||
				// 	plain: true,
 | 
			
		||||
				// },
 | 
			
		||||
			],
 | 
			
		||||
		};
 | 
			
		||||
	},
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2021-11-18 14:16:25
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-23 16:08:41
 | 
			
		||||
 * @LastEditTime: 2023-12-06 15:14:12
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -41,21 +41,23 @@ const tableProps = [
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'num',
 | 
			
		||||
		label: '数量',
 | 
			
		||||
    width: 50
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'allowTime',
 | 
			
		||||
		label: '允许留存时长(天)',
 | 
			
		||||
    width: 150
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'leftTime',
 | 
			
		||||
		label: '剩余留存时长(天)',
 | 
			
		||||
    width: 150
 | 
			
		||||
    width: 130
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
 
 | 
			
		||||
@@ -16,7 +16,7 @@
 | 
			
		||||
			<method-btn
 | 
			
		||||
				v-if="tableBtn.length"
 | 
			
		||||
				slot="handleBtn"
 | 
			
		||||
				:width="140"
 | 
			
		||||
				:width="70"
 | 
			
		||||
				label="操作"
 | 
			
		||||
				:method-list="tableBtn"
 | 
			
		||||
				@clickBtn="handleClick" />
 | 
			
		||||
@@ -36,7 +36,7 @@
 | 
			
		||||
			:dialogTitle="addOrEditTitle"
 | 
			
		||||
			:dialogVisible="addOrUpdateVisible"
 | 
			
		||||
			:before-close="handleCancel"
 | 
			
		||||
			width="50%">
 | 
			
		||||
			width="60%">
 | 
			
		||||
			<add-or-update
 | 
			
		||||
				ref="addOrUpdate"
 | 
			
		||||
				@refreshDataList="successSubmit"></add-or-update>
 | 
			
		||||
@@ -99,7 +99,7 @@ const tableProps = [
 | 
			
		||||
		prop: 'inTime',
 | 
			
		||||
		label: '入库时间',
 | 
			
		||||
		filter: parseTime,
 | 
			
		||||
		minWidth: 100,
 | 
			
		||||
    width: 150
 | 
			
		||||
	},
 | 
			
		||||
	{
 | 
			
		||||
		prop: 'remark',
 | 
			
		||||
@@ -124,18 +124,18 @@ export default {
 | 
			
		||||
			tableData: [],
 | 
			
		||||
			tableProps,
 | 
			
		||||
			tableBtn: [
 | 
			
		||||
				this.$auth.hasPermi(`raw-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'out',
 | 
			
		||||
							btnName: '出库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`raw-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'in',
 | 
			
		||||
							btnName: '入库',
 | 
			
		||||
					  }
 | 
			
		||||
					: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`raw-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'out',
 | 
			
		||||
				// 			btnName: '出库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				// this.$auth.hasPermi(`raw-material:warehouse-realtime-location:query`)
 | 
			
		||||
				// 	? {
 | 
			
		||||
				// 			type: 'in',
 | 
			
		||||
				// 			btnName: '入库',
 | 
			
		||||
				// 	  }
 | 
			
		||||
				// 	: undefined,
 | 
			
		||||
				this.$auth.hasPermi(`raw-material:warehouse-realtime-location:query`)
 | 
			
		||||
					? {
 | 
			
		||||
							type: 'detail',
 | 
			
		||||
 
 | 
			
		||||
@@ -2,7 +2,7 @@
 | 
			
		||||
 * @Author: zwq
 | 
			
		||||
 * @Date: 2023-08-01 13:52:10
 | 
			
		||||
 * @LastEditors: zwq
 | 
			
		||||
 * @LastEditTime: 2023-11-23 15:20:31
 | 
			
		||||
 * @LastEditTime: 2023-12-05 14:05:08
 | 
			
		||||
 * @Description:
 | 
			
		||||
-->
 | 
			
		||||
<template>
 | 
			
		||||
@@ -92,7 +92,7 @@ export default {
 | 
			
		||||
				updateURL: updateWarehouse,
 | 
			
		||||
				infoURL: getWarehouse,
 | 
			
		||||
			},
 | 
			
		||||
			nameList: ['warehouse_type', 'warehouse_good_type'],
 | 
			
		||||
			nameList: ['warehouse_type', 'material_type'],
 | 
			
		||||
			dataForm: {
 | 
			
		||||
				id: undefined,
 | 
			
		||||
				name: undefined,
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user