Compare commits
	
		
			21 Commits
		
	
	
		
			ee35987b0a
			...
			projects/m
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 8e1d420ffb | |||
| edade214af | |||
| 
						 | 
					91fd1b09d5 | ||
| 
						 | 
					4569d047d7 | ||
| 
						 | 
					dc1667cdb7 | ||
| 9bd4ac5066 | |||
| 4b0e8dfab6 | |||
| 71a428f034 | |||
| 05c170ba5e | |||
| 
						 | 
					8fd8c36b8a | ||
| 
						 | 
					fe39f72045 | ||
| 
						 | 
					5c05e6c2e4 | ||
| ab4d7a8e4b | |||
| 3228987c40 | |||
| e16915450b | |||
| 
						 | 
					2061384d96 | ||
| f84355b673 | |||
| 
						 | 
					14fa1823f2 | ||
| aec811827d | |||
| 18e50722b0 | |||
| 34bf9f91cf | 
							
								
								
									
										4
									
								
								.env.dev
									
									
									
									
									
								
							
							
						
						@@ -1,7 +1,7 @@
 | 
				
			|||||||
###
 | 
					###
 | 
				
			||||||
 # @Author: zhp
 | 
					 # @Author: zhp
 | 
				
			||||||
 # @Date: 2024-04-28 13:42:51
 | 
					 # @Date: 2024-04-28 13:42:51
 | 
				
			||||||
 # @LastEditTime: 2024-05-20 08:31:10
 | 
					 # @LastEditTime: 2024-05-29 17:06:55
 | 
				
			||||||
 # @LastEditors: zhp
 | 
					 # @LastEditors: zhp
 | 
				
			||||||
 # @Description:
 | 
					 # @Description:
 | 
				
			||||||
###
 | 
					###
 | 
				
			||||||
@@ -14,7 +14,7 @@ VUE_APP_TITLE = 芋道管理系统
 | 
				
			|||||||
# 芋道管理系统/开发环境
 | 
					# 芋道管理系统/开发环境
 | 
				
			||||||
VUE_APP_BASE_API = 'http://192.168.1.61:48080'
 | 
					VUE_APP_BASE_API = 'http://192.168.1.61:48080'
 | 
				
			||||||
# VUE_APP_BASE_API = 'http://glass.kszny.picaiba.com'
 | 
					# VUE_APP_BASE_API = 'http://glass.kszny.picaiba.com'
 | 
				
			||||||
#
 | 
					
 | 
				
			||||||
# 路由懒加载
 | 
					# 路由懒加载
 | 
				
			||||||
VUE_CLI_BABEL_TRANSPILE_MODULES = true
 | 
					VUE_CLI_BABEL_TRANSPILE_MODULES = true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +1,8 @@
 | 
				
			|||||||
/*
 | 
					/*
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2024-05-07 08:54:59
 | 
					 * @Date: 2024-05-07 08:54:59
 | 
				
			||||||
 * @LastEditTime: 2024-05-14 15:43:50
 | 
					 * @LastEditTime: 2024-05-22 16:31:08
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
import request from '@/utils/request'
 | 
					import request from '@/utils/request'
 | 
				
			||||||
@@ -16,11 +16,110 @@ export function getProduceDataPage(data) {
 | 
				
			|||||||
  })
 | 
					  })
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export function getProduceDataDetail(data){
 | 
					export function getProduceDataDetail(id){
 | 
				
			||||||
  return request({
 | 
					  return request({
 | 
				
			||||||
     url: '/ip/prod-output/get=' + id,
 | 
					     url: '/ip/prod-output/get?id=' + id,
 | 
				
			||||||
    method: 'get',
 | 
					    method: 'get'
 | 
				
			||||||
    query: data
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 导出生产数据
 | 
				
			||||||
 | 
					export function exportOutPutExcel(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-output/output-export-excel',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data,
 | 
				
			||||||
 | 
					    responseType: 'blob'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获取生产管理生产目标管理碲化镉工厂分页
 | 
				
			||||||
 | 
					export function prodTargetDiPage(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-target/prodTargetDiPage',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获取生产管理生产目标管理铜铟镓硒工厂分页
 | 
				
			||||||
 | 
					export function prodTargetToPage(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-target/prodTargetToPage',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 创建生产目标
 | 
				
			||||||
 | 
					export function createProduce(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-target/create',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 获得生产目标
 | 
				
			||||||
 | 
					export function getProduceTargetDetail(id){
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					     url: '/ip/prod-target/get?id=' + id,
 | 
				
			||||||
 | 
					    method: 'get'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 修改生产目标
 | 
				
			||||||
 | 
					export function updateProduceTarget(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-target/update',
 | 
				
			||||||
 | 
					    method: 'put',
 | 
				
			||||||
 | 
					    data: data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 导出碲化镉生产目标数据
 | 
				
			||||||
 | 
					export function exportDiTargetExcel(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-target/di-target-export-excel',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data,
 | 
				
			||||||
 | 
					    responseType: 'blob'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 导出铜铟镓硒生产目标数据
 | 
				
			||||||
 | 
					export function exportToTargetExcel(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-target/to-target-export-excel',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data: data,
 | 
				
			||||||
 | 
					    responseType: 'blob'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 删除生产目标
 | 
				
			||||||
 | 
					export function delTarget(id) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-target/delete?id=' + id,
 | 
				
			||||||
 | 
					    method: 'delete'
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 导入铜铟镓硒工厂
 | 
				
			||||||
 | 
					export function importToTarget(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-target/to-target-import-excel',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data
 | 
				
			||||||
 | 
					  })
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 导入碲化镉工厂
 | 
				
			||||||
 | 
					export function importDiTarget(data) {
 | 
				
			||||||
 | 
					  return request({
 | 
				
			||||||
 | 
					    url: '/ip/prod-target/di-target-import-excel',
 | 
				
			||||||
 | 
					    method: 'post',
 | 
				
			||||||
 | 
					    data
 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -32,10 +131,10 @@ export function getProduceDataDetail(data){
 | 
				
			|||||||
//   })
 | 
					//   })
 | 
				
			||||||
// }
 | 
					// }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export function cockpitDataMonitor(query) {
 | 
					export function cockpitDataMonitor(data) {
 | 
				
			||||||
  return request({
 | 
					  return request({
 | 
				
			||||||
    url: 'https://restapi.amap.com/v3/weather/weatherInfo?key=95bdbdc1c387a170105f84cd416c4c9f&city=110108',
 | 
					    url: '/ip/prod-output/cockpitDataMonitor',
 | 
				
			||||||
    method: 'get',
 | 
					    method: 'post',
 | 
				
			||||||
    query: query
 | 
					    data: data
 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										14
									
								
								src/assets/icons/svg/orgTreeIcon.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,14 @@
 | 
				
			|||||||
 | 
					<?xml version="1.0" encoding="UTF-8"?>
 | 
				
			||||||
 | 
					<svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
 | 
				
			||||||
 | 
					    <title>菜单</title>
 | 
				
			||||||
 | 
					    <g id="10系统管理" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
 | 
				
			||||||
 | 
					        <g id="用户管理" transform="translate(-284.000000, -164.000000)" fill-rule="nonzero">
 | 
				
			||||||
 | 
					            <g id="编组-7" transform="translate(284.000000, 162.000000)">
 | 
				
			||||||
 | 
					                <g id="菜单" transform="translate(0.000000, 2.000000)">
 | 
				
			||||||
 | 
					                    <rect id="矩形" fill="#000000" opacity="0" x="0" y="0" width="16" height="16"></rect>
 | 
				
			||||||
 | 
					                    <path d="M3.00057813,4.49926562 L13.0025156,4.49926562 C13.2786563,4.49926562 13.5025156,4.27540625 13.5025156,3.99926563 C13.5025156,3.723125 13.2786563,3.49926563 13.0025156,3.49926563 L3.00057813,3.49926563 C2.7244375,3.49926563 2.50057813,3.723125 2.50057813,3.99926563 C2.50057813,4.27540625 2.7244375,4.49926562 3.00057813,4.49926562 Z M3.0004375,8.48703125 L12.9786875,8.48703125 C13.2548281,8.48703125 13.4786875,8.26317187 13.4786875,7.98703125 C13.4786875,7.71089062 13.2548281,7.48703125 12.9786875,7.48703125 L3.0004375,7.48703125 C2.72429687,7.48703125 2.5004375,7.71089062 2.5004375,7.98703125 C2.5004375,8.26317187 2.72429687,8.48703125 3.0004375,8.48703125 Z M13.0025156,11.4969063 L3.00057813,11.4969063 C2.7244375,11.4969063 2.50057813,11.7207656 2.50057813,11.9969063 C2.50057813,12.2730469 2.7244375,12.4969063 3.00057813,12.4969063 L13.0025156,12.4969063 C13.2786563,12.4969063 13.5025156,12.2730469 13.5025156,11.9969063 C13.5025156,11.7207656 13.2786563,11.4969063 13.0025156,11.4969063 L13.0025156,11.4969063 Z" id="形状" fill="#373738"></path>
 | 
				
			||||||
 | 
					                </g>
 | 
				
			||||||
 | 
					            </g>
 | 
				
			||||||
 | 
					        </g>
 | 
				
			||||||
 | 
					    </g>
 | 
				
			||||||
 | 
					</svg>
 | 
				
			||||||
| 
		 After Width: | Height: | Size: 1.8 KiB  | 
							
								
								
									
										15
									
								
								src/assets/icons/svg/orgTreeIcon2.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,15 @@
 | 
				
			|||||||
 | 
					<?xml version="1.0" standalone="no"?>
 | 
				
			||||||
 | 
					<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 20010904//EN"
 | 
				
			||||||
 | 
					 "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd">
 | 
				
			||||||
 | 
					<svg version="1.0" xmlns="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					 width="127.000000pt" height="127.000000pt" viewBox="0 0 127.000000 127.000000"
 | 
				
			||||||
 | 
					 preserveAspectRatio="xMidYMid meet">
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<g transform="translate(0.000000,127.000000) scale(0.100000,-0.100000)"
 | 
				
			||||||
 | 
					fill="#000000" stroke="none">
 | 
				
			||||||
 | 
					<path d="M520 831 c-19 -10 -48 -35 -64 -55 -25 -30 -31 -48 -34 -100 -8 -122
 | 
				
			||||||
 | 
					69 -206 188 -206 119 0 196 84 188 205 -5 74 -36 123 -98 155 -51 26 -133 26
 | 
				
			||||||
 | 
					-180 1z m137 -32 c67 -25 111 -99 98 -165 -8 -45 -57 -100 -101 -114 -100 -33
 | 
				
			||||||
 | 
					-209 62 -190 165 12 62 82 124 143 125 12 0 34 -5 50 -11z"/>
 | 
				
			||||||
 | 
					</g>
 | 
				
			||||||
 | 
					</svg>
 | 
				
			||||||
| 
		 After Width: | Height: | Size: 725 B  | 
							
								
								
									
										
											BIN
										
									
								
								src/assets/images/homeindex/info.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| 
		 After Width: | Height: | Size: 257 KiB  | 
							
								
								
									
										
											BIN
										
									
								
								src/assets/images/homeindex/page-title-two.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| 
		 After Width: | Height: | Size: 12 KiB  | 
							
								
								
									
										
											BIN
										
									
								
								src/assets/images/homeindex/page-title.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| 
		 After Width: | Height: | Size: 9.5 KiB  | 
@@ -123,7 +123,7 @@ aside {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
//main-container全局样式
 | 
					//main-container全局样式
 | 
				
			||||||
.app-container {
 | 
					.app-container {
 | 
				
			||||||
  padding: 16px;
 | 
					  // padding: 16px;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.components-container {
 | 
					.components-container {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -82,6 +82,8 @@ export default {
 | 
				
			|||||||
    border: none;
 | 
					    border: none;
 | 
				
			||||||
    background: #fff;
 | 
					    background: #fff;
 | 
				
			||||||
    border-radius: 8px;
 | 
					    border-radius: 8px;
 | 
				
			||||||
 | 
					    border-bottom-left-radius: 5px;
 | 
				
			||||||
 | 
					    border-bottom-right-radius: 5px;
 | 
				
			||||||
    padding: 20px;
 | 
					    padding: 20px;
 | 
				
			||||||
    color: #888;
 | 
					    color: #888;
 | 
				
			||||||
    letter-spacing: 2px;
 | 
					    letter-spacing: 2px;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -17,20 +17,20 @@
 | 
				
			|||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import iframeToggle from "./IframeToggle/index"
 | 
					import iframeToggle from "./IframeToggle/index";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: 'AppMain',
 | 
					  name: "AppMain",
 | 
				
			||||||
  components: { iframeToggle },
 | 
					  components: { iframeToggle },
 | 
				
			||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    cachedViews() {
 | 
					    cachedViews() {
 | 
				
			||||||
      return this.$store.state.tagsView.cachedViews
 | 
					      return this.$store.state.tagsView.cachedViews;
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    key() {
 | 
					    key() {
 | 
				
			||||||
      return this.$route.path
 | 
					      return this.$route.path;
 | 
				
			||||||
    }
 | 
					    },
 | 
				
			||||||
  }
 | 
					  },
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<style lang="scss" scoped>
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
@@ -45,7 +45,7 @@ export default {
 | 
				
			|||||||
  // background-color: #fff;
 | 
					  // background-color: #fff;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.fixed-header+.app-main {
 | 
					.fixed-header + .app-main {
 | 
				
			||||||
  padding-top: 56px;
 | 
					  padding-top: 56px;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -57,7 +57,7 @@ export default {
 | 
				
			|||||||
    flex-direction: column;
 | 
					    flex-direction: column;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .fixed-header+.app-main {
 | 
					  .fixed-header + .app-main {
 | 
				
			||||||
    padding-top: 90px;
 | 
					    padding-top: 90px;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -56,6 +56,9 @@ Vue.prototype.DICT_TYPE = DICT_TYPE;
 | 
				
			|||||||
Vue.prototype.handleTree = handleTree;
 | 
					Vue.prototype.handleTree = handleTree;
 | 
				
			||||||
Vue.prototype.addBeginAndEndTime = addBeginAndEndTime;
 | 
					Vue.prototype.addBeginAndEndTime = addBeginAndEndTime;
 | 
				
			||||||
Vue.prototype.divide = divide;
 | 
					Vue.prototype.divide = divide;
 | 
				
			||||||
 | 
					Vue.prototype.tableHeight = function (n) {
 | 
				
			||||||
 | 
						return window.innerHeight - n;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// 全局组件挂载
 | 
					// 全局组件挂载
 | 
				
			||||||
Vue.component("DictTag", DictTag);
 | 
					Vue.component("DictTag", DictTag);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,16 +4,16 @@ function __resizeHandler(entries) {
 | 
				
			|||||||
  console.log(entries)
 | 
					  console.log(entries)
 | 
				
			||||||
  for (const entry of entries) {
 | 
					  for (const entry of entries) {
 | 
				
			||||||
    if (entry.contentBoxSize) {
 | 
					    if (entry.contentBoxSize) {
 | 
				
			||||||
    // const contentBoxSize = Array.isArray(entry.contentBoxSize)
 | 
					    const contentBoxSize = Array.isArray(entry.contentBoxSize)
 | 
				
			||||||
    //       ? entry.contentBoxSize[0]
 | 
					          ? entry.contentBoxSize[0]
 | 
				
			||||||
    //       : entry.contentBoxSize;
 | 
					          : entry.contentBoxSize;
 | 
				
			||||||
    //     this.chart_mixin_chartInstance.resize({
 | 
					        this.chart_mixin_chartInstance.resize({
 | 
				
			||||||
    //       width:
 | 
					          width:
 | 
				
			||||||
    //         contentBoxSize.inlineSize < this.MIN_WIDTH
 | 
					            contentBoxSize.inlineSize < this.MIN_WIDTH
 | 
				
			||||||
    //           ? this.MIN_WIDTH
 | 
					              ? this.MIN_WIDTH
 | 
				
			||||||
    //           : contentBoxSize.inlineSize,
 | 
					              : contentBoxSize.inlineSize,
 | 
				
			||||||
    //       height: contentBoxSize.blockSize,
 | 
					          height: contentBoxSize.blockSize,
 | 
				
			||||||
    //     });
 | 
					        });
 | 
				
			||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
      // manipulate contentRect
 | 
					      // manipulate contentRect
 | 
				
			||||||
      this.chart_mixin_chartInstance.resize({
 | 
					      this.chart_mixin_chartInstance.resize({
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										20
									
								
								src/mixins/tableHeightMixin.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,20 @@
 | 
				
			|||||||
 | 
					export default {
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
								tableH: this.tableHeight(260),
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						created() {
 | 
				
			||||||
 | 
							this.tableH = this?.heightNum ? this.tableHeight(this.heightNum) : this.tableHeight(260);
 | 
				
			||||||
 | 
							window.addEventListener('resize', this._setTableHeight);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						destroyed() {
 | 
				
			||||||
 | 
							window.removeEventListener('resize', this._setTableHeight);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						methods: {
 | 
				
			||||||
 | 
							_setTableHeight() {
 | 
				
			||||||
 | 
								this.tableH = this?.heightNum ? this.tableHeight(this.heightNum) : this.tableHeight(260);
 | 
				
			||||||
 | 
								// this.tableH = this.tableHeight(260);
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
@@ -1,4 +1,3 @@
 | 
				
			|||||||
 | 
					 | 
				
			||||||
import axios from "@/utils/request";
 | 
					import axios from "@/utils/request";
 | 
				
			||||||
import { deepClone } from "../../utils";
 | 
					import { deepClone } from "../../utils";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -25,10 +24,12 @@ const state = {
 | 
				
			|||||||
      chipOee: {
 | 
					      chipOee: {
 | 
				
			||||||
        current: [],
 | 
					        current: [],
 | 
				
			||||||
        previous: [],
 | 
					        previous: [],
 | 
				
			||||||
 | 
					        target:[]
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      transformRate: {
 | 
					      transformRate: {
 | 
				
			||||||
        current: [],
 | 
					        current: [],
 | 
				
			||||||
        previous: [],
 | 
					        previous: [],
 | 
				
			||||||
 | 
					        target:[]
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      chipRate: {
 | 
					      chipRate: {
 | 
				
			||||||
        target: [],
 | 
					        target: [],
 | 
				
			||||||
@@ -39,6 +40,7 @@ const state = {
 | 
				
			|||||||
      stdRate: {
 | 
					      stdRate: {
 | 
				
			||||||
        target: [],
 | 
					        target: [],
 | 
				
			||||||
        current: [],
 | 
					        current: [],
 | 
				
			||||||
 | 
					        previous: [],
 | 
				
			||||||
        outputNumber:[]
 | 
					        outputNumber:[]
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -77,7 +79,7 @@ const mutations = {
 | 
				
			|||||||
        state.copilot.energy.elecList = payload.elecList;
 | 
					        state.copilot.energy.elecList = payload.elecList;
 | 
				
			||||||
        break;
 | 
					        break;
 | 
				
			||||||
      case "efficiency":
 | 
					      case "efficiency":
 | 
				
			||||||
        state.copilot.efficiency.chipOee = payload.chipOee;
 | 
					        state.copilot.efficiency.chipOeeRate = payload.chipOeeRate;
 | 
				
			||||||
        state.copilot.efficiency.transformRate = payload.transformRate;
 | 
					        state.copilot.efficiency.transformRate = payload.transformRate;
 | 
				
			||||||
        state.copilot.efficiency.chipRate = payload.chipRate;
 | 
					        state.copilot.efficiency.chipRate = payload.chipRate;
 | 
				
			||||||
        state.copilot.efficiency.stdRate = payload.stdRate;
 | 
					        state.copilot.efficiency.stdRate = payload.stdRate;
 | 
				
			||||||
@@ -97,7 +99,7 @@ const actions = {
 | 
				
			|||||||
    commit("SET_HOME_INFO", payload);
 | 
					    commit("SET_HOME_INFO", payload);
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  /** 初始化驾驶舱数据 */
 | 
					  /** 初始化驾驶舱数据 */
 | 
				
			||||||
  async initCopilot({ commit }, { period, source }) {
 | 
					  async initCopilot({ commit }, { period,source,than}) {
 | 
				
			||||||
    // if (source == "energy") return;
 | 
					    // if (source == "energy") return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    const fetcher = {
 | 
					    const fetcher = {
 | 
				
			||||||
@@ -111,25 +113,27 @@ const actions = {
 | 
				
			|||||||
      efficiency: splitCurrentAndPreviousA,
 | 
					      efficiency: splitCurrentAndPreviousA,
 | 
				
			||||||
    }[source]
 | 
					    }[source]
 | 
				
			||||||
    // 获取产量数据
 | 
					    // 获取产量数据
 | 
				
			||||||
    let { data: factoryList, type } = await fetcher(period)
 | 
					    let { data: factoryList, type } = await fetcher(period,than)
 | 
				
			||||||
    let targetList = null;
 | 
					    // let targetList = null;
 | 
				
			||||||
    if (source === "yield" || source === "efficiency") {
 | 
					    // if (source === "yield" || source === "efficiency") {
 | 
				
			||||||
      // 获取目标数据
 | 
					    //   // 获取目标数据
 | 
				
			||||||
      let { data } = await fetcher(period, true)
 | 
					    //   let { data } = await fetcher(period,than, true)
 | 
				
			||||||
      targetList = data
 | 
					    //   targetList = data
 | 
				
			||||||
    }
 | 
					    // }
 | 
				
			||||||
    if (source == "energy") {
 | 
					    // if (source == "energy") {
 | 
				
			||||||
      let factoryData = factoryList
 | 
					    //   let factoryData = factoryList
 | 
				
			||||||
      const payload = handler(factoryData)
 | 
					    //   const payload = handler(factoryData)
 | 
				
			||||||
      commit("SET_COPILOT_INFO", { type, payload });
 | 
					    //   commit("SET_COPILOT_INFO", { type, payload });
 | 
				
			||||||
    } else {
 | 
					    // } else {
 | 
				
			||||||
      let factoryData = factoryList.prodOutputOutDO ? factoryList.prodOutputOutDO : factoryList.prodOutputRateDO
 | 
					      let factoryData = factoryList.prodOutputOutDO ? factoryList.prodOutputOutDO : factoryList.prodOutputRateDO
 | 
				
			||||||
 | 
					      let preData = factoryList.previousProdOutputOutDO ? factoryList.previousProdOutputOutDO : factoryList.previousProdOutputRateDO
 | 
				
			||||||
 | 
					      let preFtoData = factoryList.previousProdOutputFtoDO ? factoryList.previousProdOutputFtoDO : []
 | 
				
			||||||
      let prodOutputFtoDO = factoryList.prodOutputFtoDO ? factoryList.prodOutputFtoDO : []
 | 
					      let prodOutputFtoDO = factoryList.prodOutputFtoDO ? factoryList.prodOutputFtoDO : []
 | 
				
			||||||
      let targetData = targetList.prodTargetDO ? targetList.prodTargetDO : targetList.prodTargetDO
 | 
					      let targetData = factoryList.prodTargetOutputDO ? factoryList.prodTargetOutputDO : factoryList.prodTargetRateDO
 | 
				
			||||||
      const payload = handler(factoryData, targetData,prodOutputFtoDO)
 | 
					      const payload = handler(factoryData,targetData,prodOutputFtoDO,preData,preFtoData)
 | 
				
			||||||
    commit("SET_COPILOT_INFO", { type, payload });
 | 
					    commit("SET_COPILOT_INFO", { type, payload });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    }
 | 
					    // }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
@@ -281,11 +285,11 @@ function splitCurrentAndPreviousB(factoryListResponse) {
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function splitCurrentAndPreviousA(factoryListResponse, targetListResponse) {
 | 
					function splitCurrentAndPreviousA(factoryListResponse, targetListResponse, prodOutputFtoListRes,preData,preFtoData) {
 | 
				
			||||||
  // console.log('工厂',factoryListResponse);
 | 
					  console.log('工厂',targetListResponse);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  // 初始数据
 | 
					  // 初始数据
 | 
				
			||||||
  const { chipOee, transformRate, chipRate, stdRate } = initA();
 | 
					  const { chipOeeRate, transformRate, chipRate, stdRate } = initA();
 | 
				
			||||||
  // factoryListResponse = [
 | 
					  // factoryListResponse = [
 | 
				
			||||||
  //   {
 | 
					  //   {
 | 
				
			||||||
  //     factory: 0,
 | 
					  //     factory: 0,
 | 
				
			||||||
@@ -336,6 +340,23 @@ function splitCurrentAndPreviousA(factoryListResponse, targetListResponse) {
 | 
				
			|||||||
  //     componentYieldRate: 0.73,
 | 
					  //     componentYieldRate: 0.73,
 | 
				
			||||||
  //   },
 | 
					  //   },
 | 
				
			||||||
  // ];
 | 
					  // ];
 | 
				
			||||||
 | 
					  if (preData && preData[0] != null) {
 | 
				
			||||||
 | 
					    for (const factory of preData) {
 | 
				
			||||||
 | 
					      const fId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					         chipInvest.previous[fId] = factory.previousYearInputNumber;
 | 
				
			||||||
 | 
					      // chipOeeRate.current[fId] = factory.oee;
 | 
				
			||||||
 | 
					      chipOeeRate.previous[fId] = factory.previousYearOee;
 | 
				
			||||||
 | 
					      // 转化效率
 | 
				
			||||||
 | 
					      transformRate.previous[fId] =factory.previousYearComponentConversionEfficiency ;
 | 
				
			||||||
 | 
					      // 芯片良率 与 标准组件良率
 | 
				
			||||||
 | 
					      if (![0, 1].includes(factory.glassType)) continue;
 | 
				
			||||||
 | 
					      const _t = [chipRate, stdRate][factory.glassType]
 | 
				
			||||||
 | 
					      // _t.current[fId] = factory.yieldRate ;
 | 
				
			||||||
 | 
					      _t.previous[fId] = factory.previousYearYieldRate ;
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      // debugger;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
  if (factoryListResponse) {
 | 
					  if (factoryListResponse) {
 | 
				
			||||||
    for (const factory of factoryListResponse) {
 | 
					    for (const factory of factoryListResponse) {
 | 
				
			||||||
      const fId = getFactoryId(factory);
 | 
					      const fId = getFactoryId(factory);
 | 
				
			||||||
@@ -347,27 +368,27 @@ function splitCurrentAndPreviousA(factoryListResponse, targetListResponse) {
 | 
				
			|||||||
          chipOee,
 | 
					          chipOee,
 | 
				
			||||||
          componentConversionEfficiency,
 | 
					          componentConversionEfficiency,
 | 
				
			||||||
          componentYield
 | 
					          componentYield
 | 
				
			||||||
        } = getFactoryTargetValueA(targetListResponse, fId);
 | 
					        } = getFactoryTargetValueA(targetListResponse, fId)
 | 
				
			||||||
        stdRate.target[fId] =  componentYieldRate
 | 
					        stdRate.target[fId] =  componentYieldRate
 | 
				
			||||||
        chipRate.target[fId] = chipYieldRate
 | 
					        chipRate.target[fId] = chipYieldRate
 | 
				
			||||||
 | 
					        chipOeeRate.target[fId] = chipOee
 | 
				
			||||||
 | 
					        transformRate.target[fId] = componentConversionEfficiency
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      // 芯片OEE
 | 
					      // 芯片OEE
 | 
				
			||||||
      chipOee.current[fId] = factory.oee * 100 ;
 | 
					      chipOeeRate.current[fId] = factory.oee;
 | 
				
			||||||
      chipOee.previous[fId] = factory.previousYearOee * 100 ;
 | 
					      // chipOeeRate.previous[fId] = factory.previousYearOee;
 | 
				
			||||||
      // 转化效率
 | 
					      // 转化效率
 | 
				
			||||||
      transformRate.current[fId] =
 | 
					      transformRate.current[fId] = factory.componentConversionEfficiency;
 | 
				
			||||||
        factory.componentConversionEfficiency * 100 ;
 | 
					      // transformRate.previous[fId] = factory.previousYearComponentConversionEfficiency ;
 | 
				
			||||||
      transformRate.previous[fId] =
 | 
					 | 
				
			||||||
        factory.previousYearComponentConversionEfficiency * 100 ;
 | 
					 | 
				
			||||||
      // 芯片良率 与 标准组件良率
 | 
					      // 芯片良率 与 标准组件良率
 | 
				
			||||||
      if (![0, 1].includes(factory.glassType)) continue;
 | 
					      if (![0, 1].includes(factory.glassType)) continue;
 | 
				
			||||||
      const _t = [chipRate, stdRate][factory.glassType]
 | 
					      const _t = [chipRate, stdRate][factory.glassType]
 | 
				
			||||||
      _t.current[fId] = factory.yieldRate ;
 | 
					      _t.current[fId] = factory.yieldRate ;
 | 
				
			||||||
      _t.previous[fId] = factory.previousYearYieldRate ;
 | 
					      // _t.previous[fId] = factory.previousYearYieldRate ;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					    // console.log('chipOeeRate',chipOeeRate);
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      chipOee,
 | 
					      chipOeeRate,
 | 
				
			||||||
      transformRate,
 | 
					      transformRate,
 | 
				
			||||||
      chipRate,
 | 
					      chipRate,
 | 
				
			||||||
      stdRate,
 | 
					      stdRate,
 | 
				
			||||||
@@ -375,21 +396,57 @@ function splitCurrentAndPreviousA(factoryListResponse, targetListResponse) {
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function splitCurrentAndPrevious(factoryListResponse, targetListResponse, prodOutputFtoListRes) {
 | 
					function splitCurrentAndPrevious(factoryListResponse, targetListResponse, prodOutputFtoListRes,preData,preFtoData) {
 | 
				
			||||||
  console.log('prodOutputFtoListRes',prodOutputFtoListRes);
 | 
					  console.log('prodOutputFtoListRes',preData);
 | 
				
			||||||
  // 初始数据
 | 
					  // 初始数据
 | 
				
			||||||
  const { chipInvest, ftoInvest, chipOutput, stdOutput, bipvOutput } = init()
 | 
					  const { chipInvest, ftoInvest, chipOutput, stdOutput, bipvOutput } = init()
 | 
				
			||||||
   if (prodOutputFtoListRes) {
 | 
					   if (prodOutputFtoListRes) {
 | 
				
			||||||
    for (const factory of prodOutputFtoListRes) {
 | 
					    for (const factory of prodOutputFtoListRes) {
 | 
				
			||||||
      console.log(factory);
 | 
					      console.log(factory);
 | 
				
			||||||
      const fId = getFactoryId(factory);
 | 
					      const fId = getFactoryId(factory);
 | 
				
			||||||
 | 
					      // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					      // if (fId) {
 | 
				
			||||||
      ftoInvest.current[fId] = factory.chipInput;
 | 
					      ftoInvest.current[fId] = factory.chipInput;
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      // if (preFId) {
 | 
				
			||||||
 | 
					      // ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					   }
 | 
				
			||||||
 | 
					   if (preFtoData) {
 | 
				
			||||||
 | 
					    for (const factory of preFtoData) {
 | 
				
			||||||
 | 
					      console.log(factory);
 | 
				
			||||||
 | 
					      const fId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					      // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					      // if (fId) {
 | 
				
			||||||
      ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
					      ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      // if (preFId) {
 | 
				
			||||||
 | 
					      // ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
   }
 | 
					   }
 | 
				
			||||||
  if (factoryListResponse) {
 | 
					    if (preData && preData[0] != null) {
 | 
				
			||||||
 | 
					    for (const factory of preData) {
 | 
				
			||||||
 | 
					      const fId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					         chipInvest.previous[fId] = factory.previousYearInputNumber;
 | 
				
			||||||
 | 
					      if (![0, 1, 2].includes(factory.previousGlassType)) continue;
 | 
				
			||||||
 | 
					      const _t = [chipOutput, stdOutput, bipvOutput][factory.previousGlassType];
 | 
				
			||||||
 | 
					      // if (fId) {
 | 
				
			||||||
 | 
					        // _t.current[fId] = factory.outputNumber;
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      // if (preFId) {
 | 
				
			||||||
 | 
					          _t.previous[fId] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      // debugger;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					    // console.log('ftoInvest',ftoInvest)
 | 
				
			||||||
 | 
					  if (factoryListResponse && factoryListResponse[0] != null) {
 | 
				
			||||||
    for (const factory of factoryListResponse) {
 | 
					    for (const factory of factoryListResponse) {
 | 
				
			||||||
      const fId = getFactoryId(factory);
 | 
					      const fId = getFactoryId(factory);
 | 
				
			||||||
 | 
					      // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      // 获取目标值
 | 
					      // 获取目标值
 | 
				
			||||||
      if (targetListResponse) {
 | 
					      if (targetListResponse) {
 | 
				
			||||||
        const { chipYield, componentYield, bipvProductOutput } =
 | 
					        const { chipYield, componentYield, bipvProductOutput } =
 | 
				
			||||||
@@ -400,22 +457,13 @@ function splitCurrentAndPrevious(factoryListResponse, targetListResponse, prodOu
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
      // 芯片投入
 | 
					      // 芯片投入
 | 
				
			||||||
          chipInvest.current[fId] = factory.inputNumber;
 | 
					          chipInvest.current[fId] = factory.inputNumber;
 | 
				
			||||||
      chipInvest.previous[fId] = factory.previousYearInputNumber;
 | 
					 | 
				
			||||||
      // FTO投入
 | 
					 | 
				
			||||||
      // if (factory.chipInput || factory.previousYearChipInput) {
 | 
					 | 
				
			||||||
      //     ftoInvest.current[fId] = factory.chipInput;
 | 
					 | 
				
			||||||
      //     ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
					 | 
				
			||||||
      // }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
      // 产出数据, 0 - (玻璃)芯片产出, 1 - 标准组件产出, 2 - BIPV产出
 | 
					      // 产出数据, 0 - (玻璃)芯片产出, 1 - 标准组件产出, 2 - BIPV产出
 | 
				
			||||||
      // 因为后端写的垃圾数据,所以这里要做一下判断
 | 
					      // 因为后端写的垃圾数据,所以这里要做一下判断
 | 
				
			||||||
      if (![0, 1, 2].includes(factory.glassType)) continue;
 | 
					      if (![0, 1, 2].includes(factory.glassType)) continue;
 | 
				
			||||||
      const _t = [chipOutput, stdOutput, bipvOutput][factory.glassType];
 | 
					      const _t = [chipOutput, stdOutput, bipvOutput][factory.glassType];
 | 
				
			||||||
        _t.current[fId] = factory.outputNumber;
 | 
					        _t.current[fId] = factory.outputNumber;
 | 
				
			||||||
      _t.previous[fId] = factory.previousYearOutputNumber;
 | 
					 | 
				
			||||||
      // debugger;
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      chipInvest,
 | 
					      chipInvest,
 | 
				
			||||||
      // ftoInvest,
 | 
					      // ftoInvest,
 | 
				
			||||||
@@ -424,27 +472,39 @@ function splitCurrentAndPrevious(factoryListResponse, targetListResponse, prodOu
 | 
				
			|||||||
      stdOutput,
 | 
					      stdOutput,
 | 
				
			||||||
      bipvOutput,
 | 
					      bipvOutput,
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
 | 
					  }else{
 | 
				
			||||||
 | 
					      return {
 | 
				
			||||||
 | 
					      chipInvest,
 | 
				
			||||||
 | 
					      // ftoInvest,
 | 
				
			||||||
 | 
					      ftoInvest,
 | 
				
			||||||
 | 
					      chipOutput,
 | 
				
			||||||
 | 
					      stdOutput,
 | 
				
			||||||
 | 
					      bipvOutput,
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function getFactoryId(factory) {
 | 
					function getFactoryId(factory) {
 | 
				
			||||||
  return factory.factory;
 | 
					  return factory.factory;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					function getPreFactoryId(factory) {
 | 
				
			||||||
 | 
					  return factory.previousFactory;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function getFactoryTargetValue(targetList, factoryId) {
 | 
					function getFactoryTargetValue(targetList, factoryId) {
 | 
				
			||||||
  const target = targetList.find((item) => item.factory === factoryId);
 | 
					  const target = targetList.find((item) => item.factory === factoryId);
 | 
				
			||||||
  if (target) {
 | 
					  if (target) {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      // 自带模拟数据了.... random_default
 | 
					      // 自带模拟数据了.... random_default
 | 
				
			||||||
      chipYield: target.chipYield ?? random_default(),
 | 
					      chipYield: target.chipYield ?? 0,
 | 
				
			||||||
      componentYield: target.componentYield ?? random_default(),
 | 
					      componentYield: target.componentYield ?? 0,
 | 
				
			||||||
      bipvProductOutput: target.bipvProductOutput ?? random_default(),
 | 
					      bipvProductOutput: target.bipvProductOutput ?? 0,
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  return {
 | 
					  return {
 | 
				
			||||||
    chipYield: random_default(),
 | 
					    chipYield: 0,
 | 
				
			||||||
    componentYield: random_default(),
 | 
					    componentYield: 0,
 | 
				
			||||||
    bipvProductOutput: random_default(),
 | 
					    bipvProductOutput: 0,
 | 
				
			||||||
  };
 | 
					  };
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -458,15 +518,18 @@ function getFactoryTargetValueA(targetList, factoryId) {
 | 
				
			|||||||
  const target = targetList.find((item) => item.factory === factoryId)
 | 
					  const target = targetList.find((item) => item.factory === factoryId)
 | 
				
			||||||
  if (target) {
 | 
					  if (target) {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      chipYieldRate: target.chipYieldRate ?? random_default(),
 | 
					      chipYieldRate: target.chipYieldRate ?? 0,
 | 
				
			||||||
      componentYieldRate: target.componentYieldRate ?? random_default(),
 | 
					      componentYieldRate: target.componentYieldRate ?? 0,
 | 
				
			||||||
      componentYield: target.componentYield ?? random_default(),
 | 
					      componentYield: target.componentYield ?? 0,
 | 
				
			||||||
 | 
					      // componentYield: target.componentYield ?? 0,
 | 
				
			||||||
 | 
					      chipOee: target.chipOee ?? 0,
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
  return {
 | 
					  return {
 | 
				
			||||||
    chipYieldRate:0,
 | 
					    chipYieldRate:0,
 | 
				
			||||||
    componentYieldRate:0,
 | 
					    componentYieldRate:0,
 | 
				
			||||||
    componentYield:0 ,
 | 
					    componentYield: 0,
 | 
				
			||||||
 | 
					    chipOee:0,
 | 
				
			||||||
  };
 | 
					  };
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -480,18 +543,18 @@ function initA() {
 | 
				
			|||||||
    previous: Array(7).fill(0),
 | 
					    previous: Array(7).fill(0),
 | 
				
			||||||
  };
 | 
					  };
 | 
				
			||||||
  // 芯片OEE
 | 
					  // 芯片OEE
 | 
				
			||||||
  const chipOee = deepClone(t_);
 | 
					 | 
				
			||||||
  // 转化效率
 | 
					  // 转化效率
 | 
				
			||||||
  const transformRate = deepClone(t_);
 | 
					 | 
				
			||||||
  // 标准组件良率
 | 
					  // 标准组件良率
 | 
				
			||||||
  const stdRate = {
 | 
					  const stdRate = {
 | 
				
			||||||
    ...deepClone(t_),
 | 
					    ...deepClone(t_),
 | 
				
			||||||
    target: Array(7).fill(0),
 | 
					    target: Array(7).fill(0),
 | 
				
			||||||
  };
 | 
					  };
 | 
				
			||||||
  // 芯片良率
 | 
					  // 芯片良率
 | 
				
			||||||
 | 
					  const transformRate = deepClone(stdRate);
 | 
				
			||||||
  const chipRate = deepClone(stdRate);
 | 
					  const chipRate = deepClone(stdRate);
 | 
				
			||||||
 | 
					  const chipOeeRate = deepClone(stdRate);
 | 
				
			||||||
  return {
 | 
					  return {
 | 
				
			||||||
    chipOee,
 | 
					    chipOeeRate,
 | 
				
			||||||
    transformRate,
 | 
					    transformRate,
 | 
				
			||||||
    chipRate,
 | 
					    chipRate,
 | 
				
			||||||
    stdRate,
 | 
					    stdRate,
 | 
				
			||||||
@@ -544,6 +607,7 @@ async function getHomeInfo() {
 | 
				
			|||||||
  const { code, data } = await axios.post("ip/prod-output/cockpitData", {
 | 
					  const { code, data } = await axios.post("ip/prod-output/cockpitData", {
 | 
				
			||||||
    factorys: [],
 | 
					    factorys: [],
 | 
				
			||||||
    date: 4,
 | 
					    date: 4,
 | 
				
			||||||
 | 
					    mode:0
 | 
				
			||||||
  });
 | 
					  });
 | 
				
			||||||
  if (code == 0) {
 | 
					  if (code == 0) {
 | 
				
			||||||
    return data;
 | 
					    return data;
 | 
				
			||||||
@@ -609,16 +673,16 @@ async function doFetch(copilot_module = "yield", fetch_target, params) {
 | 
				
			|||||||
 * @param {*} target 是否获取目标数据
 | 
					 * @param {*} target 是否获取目标数据
 | 
				
			||||||
 * @returns
 | 
					 * @returns
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
function getCopilotYield(period, target = false) {
 | 
					function getCopilotYield(period,than,target = false) {
 | 
				
			||||||
  return getCopilotData("yield", period, target);
 | 
					  return getCopilotData("yield", period,than, target);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function getCopilotEnergy(period, target = false) {
 | 
					function getCopilotEnergy(period, target = false) {
 | 
				
			||||||
  return getCopilotData("energy", period, target);
 | 
					  return getCopilotData("energy", period,than, target);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function getCopilotEfficiency(period, target = false) {
 | 
					function getCopilotEfficiency(period,than, target = false) {
 | 
				
			||||||
  return getCopilotData("efficiency", period, target);
 | 
					  return getCopilotData("efficiency", period,than, target);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
@@ -627,12 +691,13 @@ function getCopilotEfficiency(period, target = false) {
 | 
				
			|||||||
 * @param {*} target 是否获取目标数据:默认 否
 | 
					 * @param {*} target 是否获取目标数据:默认 否
 | 
				
			||||||
 * @returns
 | 
					 * @returns
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
async function getCopilotData(copilot_module, period, target = false) {
 | 
					async function getCopilotData(copilot_module, period,than, target = false) {
 | 
				
			||||||
  if (!copilot_module) copilot_module = "yield";
 | 
					  if (!copilot_module) copilot_module = "yield";
 | 
				
			||||||
  // 请求参数,直接一次性获取所有工厂
 | 
					  // 请求参数,直接一次性获取所有工厂
 | 
				
			||||||
  let queryParams = {
 | 
					  let queryParams = {
 | 
				
			||||||
    factorys: [],
 | 
					    factorys: [],
 | 
				
			||||||
    date: 4,
 | 
					    date: 4,
 | 
				
			||||||
 | 
					    mode:0
 | 
				
			||||||
  };
 | 
					  };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  switch (period) {
 | 
					  switch (period) {
 | 
				
			||||||
@@ -652,7 +717,14 @@ async function getCopilotData(copilot_module, period, target = false) {
 | 
				
			|||||||
      queryParams.date = 1;
 | 
					      queryParams.date = 1;
 | 
				
			||||||
      break;
 | 
					      break;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					 switch (than) {
 | 
				
			||||||
 | 
					    case "同比":
 | 
				
			||||||
 | 
					      queryParams.mode = 0;
 | 
				
			||||||
 | 
					      break;
 | 
				
			||||||
 | 
					    case "环比":
 | 
				
			||||||
 | 
					      queryParams.mode = 1;
 | 
				
			||||||
 | 
					      break;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
  return {
 | 
					  return {
 | 
				
			||||||
    data: await doFetch(copilot_module, target ? true : false, queryParams),
 | 
					    data: await doFetch(copilot_module, target ? true : false, queryParams),
 | 
				
			||||||
    type: copilot_module,
 | 
					    type: copilot_module,
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -71,6 +71,45 @@ export const SystemDataScopeEnum = {
 | 
				
			|||||||
  DEPT_SELF: 5 // 仅本人数据权限
 | 
					  DEPT_SELF: 5 // 仅本人数据权限
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * 工厂名称
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					export const factoryList =['瑞昌中建材光电材料有限公司', '邯郸中建材光电材料有限公司', '中建材株洲光电材料有限公司', '佳木斯中建材光电材料有限公司', '成都中建材光电材料有限公司', '凯盛光伏材料有限公司', '蚌埠兴科玻璃有限公司']
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export const dhgfactoryList =[
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    name: '瑞昌中建材光电材料有限公司',
 | 
				
			||||||
 | 
					    id: 0
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    name: '邯郸中建材光电材料有限公司',
 | 
				
			||||||
 | 
					    id: 1
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    name: '中建材株洲光电材料有限公司',
 | 
				
			||||||
 | 
					    id: 2
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    name: '佳木斯中建材光电材料有限公司',
 | 
				
			||||||
 | 
					    id: 3
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    name: '成都中建材光电材料有限公司',
 | 
				
			||||||
 | 
					    id: 4
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    name: '蚌埠兴科玻璃有限公司',
 | 
				
			||||||
 | 
					    id: 6
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export const tyjxfactoryList =[
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    name: '凯盛光伏材料有限公司',
 | 
				
			||||||
 | 
					    id: 5
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * 代码生成模板类型
 | 
					 * 代码生成模板类型
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -139,3 +139,15 @@ export function getDictDataLabel(dictType, value) {
 | 
				
			|||||||
  const dict = getDictData(dictType, value);
 | 
					  const dict = getDictData(dictType, value);
 | 
				
			||||||
  return dict ? dict.label : '';
 | 
					  return dict ? dict.label : '';
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// table中用来过滤字典
 | 
				
			||||||
 | 
					export function publicFormatter(dictTable) {
 | 
				
			||||||
 | 
					  const dictDatas = getDictDatas(dictTable)
 | 
				
			||||||
 | 
					  return function (val) {
 | 
				
			||||||
 | 
					    const arr = {}
 | 
				
			||||||
 | 
					    dictDatas.map((item) => {
 | 
				
			||||||
 | 
					      arr[item.value] = item.label
 | 
				
			||||||
 | 
					    })
 | 
				
			||||||
 | 
					    return arr?.[val]
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -11,7 +11,7 @@
 | 
				
			|||||||
      <span v-for="item in legend" :key="item.label" class="legend-item"
 | 
					      <span v-for="item in legend" :key="item.label" class="legend-item"
 | 
				
			||||||
        :style="{ fontSize: isFullscreen ? '0.58vw' : '0.54vw' }">{{ item.label }}</span>
 | 
					        :style="{ fontSize: isFullscreen ? '0.58vw' : '0.54vw' }">{{ item.label }}</span>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <div ref="chart" :style="{ height: '95%',width: width}"></div>
 | 
					    <div ref="chart" style="height:94%;width:100%"></div>
 | 
				
			||||||
  </chart-container>
 | 
					  </chart-container>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -51,7 +51,7 @@ export default {
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      width: '',
 | 
					      width: '100%',
 | 
				
			||||||
      isFullscreen: false,
 | 
					      isFullscreen: false,
 | 
				
			||||||
      actualOptions: null,
 | 
					      actualOptions: null,
 | 
				
			||||||
      options: {
 | 
					      options: {
 | 
				
			||||||
@@ -184,16 +184,7 @@ export default {
 | 
				
			|||||||
    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
					    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
				
			||||||
    isOpen(val) {
 | 
					    isOpen(val) {
 | 
				
			||||||
      // console.log(val)
 | 
					      // console.log(val)
 | 
				
			||||||
      if (val === true) {
 | 
					 | 
				
			||||||
        console.log('ztl')
 | 
					 | 
				
			||||||
        this.width = 95 + '%'
 | 
					 | 
				
			||||||
      this.canvasReset()
 | 
					      this.canvasReset()
 | 
				
			||||||
 | 
					 | 
				
			||||||
        console.log(this.width)
 | 
					 | 
				
			||||||
      } else {
 | 
					 | 
				
			||||||
        this.watch = 100 + '%'
 | 
					 | 
				
			||||||
        this.canvasReset()
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    isFullscreen(val) {
 | 
					    isFullscreen(val) {
 | 
				
			||||||
      this.actualOptions.series.map((item) => {
 | 
					      this.actualOptions.series.map((item) => {
 | 
				
			||||||
@@ -203,21 +194,14 @@ export default {
 | 
				
			|||||||
      this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
					      this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
      this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
					      this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
      this.initChart(this.actualOptions);
 | 
					      this.initChart(this.actualOptions);
 | 
				
			||||||
      if (val === false && this.isOpen === true) {
 | 
					 | 
				
			||||||
        console.log(val)
 | 
					 | 
				
			||||||
        this.width = 97 + '%'
 | 
					 | 
				
			||||||
        this.canvasReset()
 | 
					 | 
				
			||||||
      } else if (val === false && this.isOpen === false) {
 | 
					 | 
				
			||||||
        this.watch = 100 + '%'
 | 
					 | 
				
			||||||
        this.canvasReset()
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      // this.actualOptions.series.map((item) => {
 | 
					      // this.actualOptions.series.map((item) => {
 | 
				
			||||||
      //   item.barWidth = val ? 18 : 12;
 | 
					      //   item.barWidth = val ? 18 : 12;
 | 
				
			||||||
      // });
 | 
					      // });
 | 
				
			||||||
      // this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
					      // this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
      // this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
					      // this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
      // this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
					      // this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
      this.initChart(this.actualOptions);
 | 
					      // this.initChart(this.actualOptions);
 | 
				
			||||||
 | 
					      this.canvasReset()
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    series(val) {
 | 
					    series(val) {
 | 
				
			||||||
      if (!val) {
 | 
					      if (!val) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -8,33 +8,23 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="copilot-header">
 | 
					  <div class="copilot-header">
 | 
				
			||||||
    <section class="menu">
 | 
					    <section class="menu">
 | 
				
			||||||
      <CopilotButton
 | 
					      <CopilotButton v-for="i in ['产量', '效率']" :key="i" :label="i" :active="i === active"
 | 
				
			||||||
        v-for="i in ['产量', '效率', '综合']"
 | 
					        @click="() => $emit('update:active', i)" />
 | 
				
			||||||
        :key="i"
 | 
					      <div class="type-name"></div>
 | 
				
			||||||
        :label="i"
 | 
					      <CopilotButton v-for="i in ['同比', '环比']" :key="i" :label="i" :active="i === than"
 | 
				
			||||||
        :active="i === active"
 | 
					        @click="() => $emit('update:than', i)" />
 | 
				
			||||||
        @click="() => $emit('update:active', i)"
 | 
					 | 
				
			||||||
      />
 | 
					 | 
				
			||||||
    </section>
 | 
					 | 
				
			||||||
    <section class="menu">
 | 
					 | 
				
			||||||
      <CopilotButton
 | 
					 | 
				
			||||||
        v-for="i in ['日', '周', '月', '年']"
 | 
					 | 
				
			||||||
        :key="i"
 | 
					 | 
				
			||||||
        :label="i"
 | 
					 | 
				
			||||||
        :active="i === period"
 | 
					 | 
				
			||||||
        @click="() => $emit('update:period', i)"
 | 
					 | 
				
			||||||
      />
 | 
					 | 
				
			||||||
      <div class="btn-group">
 | 
					 | 
				
			||||||
        <button type="button" class="export-btn" />
 | 
					 | 
				
			||||||
        <button
 | 
					 | 
				
			||||||
          type="button"
 | 
					 | 
				
			||||||
          class="fullscreen-btn"
 | 
					 | 
				
			||||||
          :class="[isFullscreen ? 'exit-fullscreen' : '']"
 | 
					 | 
				
			||||||
          @click="toggleFullScreen"
 | 
					 | 
				
			||||||
        />
 | 
					 | 
				
			||||||
      </div>
 | 
					 | 
				
			||||||
    </section>
 | 
					    </section>
 | 
				
			||||||
    <div class="page-title">{{ active }}驾驶舱</div>
 | 
					    <div class="page-title">{{ active }}驾驶舱</div>
 | 
				
			||||||
 | 
					    <section class="menu" style="width: 24vw;float: right;">
 | 
				
			||||||
 | 
					      <CopilotButton v-for="i in ['日', '周', '月', '年']" :key="i" :label="i" :active="i === period"
 | 
				
			||||||
 | 
					        @click="() => $emit('update:period', i)" />
 | 
				
			||||||
 | 
					      <div class="btn-group">
 | 
				
			||||||
 | 
					        <button type="button" class="export-btn" />
 | 
				
			||||||
 | 
					        <button type="button" class="fullscreen-btn" :class="[isFullscreen ? 'exit-fullscreen' : '']"
 | 
				
			||||||
 | 
					          @click="toggleFullScreen" />
 | 
				
			||||||
 | 
					        <!-- <button class="times-btn"> {{ times }} </button> -->
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </section>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -52,14 +42,61 @@ export default {
 | 
				
			|||||||
    period: {
 | 
					    period: {
 | 
				
			||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
 | 
					      times:'',
 | 
				
			||||||
      isFullscreen: false,
 | 
					      isFullscreen: false,
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					  mounted () {
 | 
				
			||||||
 | 
					    this.getTimes()
 | 
				
			||||||
 | 
					    this.getTimesInterval();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
  computed: {},
 | 
					  computed: {},
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
 | 
					    getTimes() {
 | 
				
			||||||
 | 
					      setInterval(this.getTimesInterval, 60000);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getTimesInterval() {
 | 
				
			||||||
 | 
					      var now = new Date();
 | 
				
			||||||
 | 
					      var weekDay = now.getDay();
 | 
				
			||||||
 | 
					      var weeks = new Array("星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六");
 | 
				
			||||||
 | 
					      var week = weeks[weekDay]
 | 
				
			||||||
 | 
					      let _this = this;
 | 
				
			||||||
 | 
					      let year = new Date().getFullYear(); //获取当前时间的年份
 | 
				
			||||||
 | 
					      let month = new Date().getMonth() + 1; //获取当前时间的月份
 | 
				
			||||||
 | 
					      let day = new Date().getDate(); //获取当前时间的天数
 | 
				
			||||||
 | 
					      let hours = new Date().getHours(); //获取当前时间的小时
 | 
				
			||||||
 | 
					      let minutes = new Date().getMinutes(); //获取当前时间的分数
 | 
				
			||||||
 | 
					      // let seconds = new Date().getSeconds(); //获取当前时间的秒数
 | 
				
			||||||
 | 
					      //当小于 10 的是时候,在前面加 0
 | 
				
			||||||
 | 
					      if (hours < 10) {
 | 
				
			||||||
 | 
					        hours = '0' + hours;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      if (minutes < 10) {
 | 
				
			||||||
 | 
					        minutes = '0' + minutes;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      // if (seconds < 10) {
 | 
				
			||||||
 | 
					      //   seconds = '0' + seconds;
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      //拼接格式化当前时间
 | 
				
			||||||
 | 
					      this.times =
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        year +
 | 
				
			||||||
 | 
					        '.' +
 | 
				
			||||||
 | 
					        month +
 | 
				
			||||||
 | 
					        '.' +
 | 
				
			||||||
 | 
					      day +
 | 
				
			||||||
 | 
					      "  " + hours +
 | 
				
			||||||
 | 
					      '.' +
 | 
				
			||||||
 | 
					      minutes +
 | 
				
			||||||
 | 
					      '.' +
 | 
				
			||||||
 | 
					      week
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    toggleFullScreen() {
 | 
					    toggleFullScreen() {
 | 
				
			||||||
      this.isFullscreen = !this.isFullscreen;
 | 
					      this.isFullscreen = !this.isFullscreen;
 | 
				
			||||||
      screenfull.toggle(document.querySelector(".copilot-layout"))
 | 
					      screenfull.toggle(document.querySelector(".copilot-layout"))
 | 
				
			||||||
@@ -82,10 +119,11 @@ export default {
 | 
				
			|||||||
  display: flex;
 | 
					  display: flex;
 | 
				
			||||||
  gap: 12px;
 | 
					  gap: 12px;
 | 
				
			||||||
  align-items: center;
 | 
					  align-items: center;
 | 
				
			||||||
 | 
					  justify-content: space-between;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.copilot-header > section {
 | 
					.copilot-header > section {
 | 
				
			||||||
  width: 24vw;
 | 
					  width: 26vw;
 | 
				
			||||||
  display: flex;
 | 
					  display: flex;
 | 
				
			||||||
  align-items: center;
 | 
					  align-items: center;
 | 
				
			||||||
  gap: 8px;
 | 
					  gap: 8px;
 | 
				
			||||||
@@ -99,6 +137,17 @@ export default {
 | 
				
			|||||||
  cursor: pointer;
 | 
					  cursor: pointer;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.times-btn {
 | 
				
			||||||
 | 
					  width: 240px;
 | 
				
			||||||
 | 
					  height: 32px;
 | 
				
			||||||
 | 
					  margin-left: 24px;
 | 
				
			||||||
 | 
					  cursor: pointer;
 | 
				
			||||||
 | 
					  color: white;
 | 
				
			||||||
 | 
					  font-size: 20px;
 | 
				
			||||||
 | 
					  line-height: 30px;
 | 
				
			||||||
 | 
					  float: right;
 | 
				
			||||||
 | 
					  /* margin-bottom: 20px; */
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
.export-btn {
 | 
					.export-btn {
 | 
				
			||||||
  background: url(../../../assets/images/export-icon.png) 0 0 / 100% 100%
 | 
					  background: url(../../../assets/images/export-icon.png) 0 0 / 100% 100%
 | 
				
			||||||
    no-repeat;
 | 
					    no-repeat;
 | 
				
			||||||
@@ -112,15 +161,27 @@ export default {
 | 
				
			|||||||
  background: url(../../../assets/images/homeindex/exit-fullscreen.png) 0 0 / 100% 100%
 | 
					  background: url(../../../assets/images/homeindex/exit-fullscreen.png) 0 0 / 100% 100%
 | 
				
			||||||
    no-repeat;
 | 
					    no-repeat;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					    .type-name {
 | 
				
			||||||
 | 
					      /* content: ""; */
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      width: 1px;
 | 
				
			||||||
 | 
					    height: 59px;
 | 
				
			||||||
 | 
					    border: 1px solid;
 | 
				
			||||||
 | 
					    opacity: 0.9;
 | 
				
			||||||
 | 
					    border-image: linear-gradient(180deg, rgba(0, 176, 243, 0), rgba(88, 194, 255, 1), rgba(0, 120, 228, 0)) 2 2;
 | 
				
			||||||
 | 
					      /* position: absolute; */
 | 
				
			||||||
 | 
					      /* left: 0; */
 | 
				
			||||||
 | 
					      /* top: 10px; */
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
.page-title {
 | 
					.page-title {
 | 
				
			||||||
  flex: 1;
 | 
					  width: 25vw;
 | 
				
			||||||
  font-size: 54px;
 | 
					  font-size: 54px;
 | 
				
			||||||
  line-height: 70px;
 | 
					  line-height: 70px;
 | 
				
			||||||
  letter-spacing: 5px;
 | 
					  letter-spacing: 5px;
 | 
				
			||||||
  font-family: 优设标题黑;
 | 
					  font-family: 优设标题黑;
 | 
				
			||||||
  color: #6db6ff;
 | 
					  color: #6db6ff;
 | 
				
			||||||
  text-align: right;
 | 
					  text-align: center;
 | 
				
			||||||
  user-select: none;
 | 
					  user-select: none;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/homeindex/page-title.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</style>
 | 
					</style>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,39 +1,30 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="factory-header">
 | 
					  <div class="factory-header">
 | 
				
			||||||
    <section class="menu1">
 | 
					    <section class="menu1">
 | 
				
			||||||
      <FactorySelect
 | 
					      <!-- <CopilotButton v-for="i in ['产量', '效率']" :key="i" :label="i" :active="i === active"
 | 
				
			||||||
        :companyName="companyName"
 | 
					        @click="() => $emit('update:active', i)" />
 | 
				
			||||||
        :companyId="companyId"
 | 
					      <div class="type-name"></div> -->
 | 
				
			||||||
        @updateCompany="updateCompany"
 | 
					      <CopilotButton v-for="i in ['同比', '环比']" :key="i" :label="i" :active="i === than"
 | 
				
			||||||
      />
 | 
					        @click="() => $emit('update:than', i)" />
 | 
				
			||||||
    </section>
 | 
					 | 
				
			||||||
    <section class="menu2">
 | 
					 | 
				
			||||||
      <CopilotButton
 | 
					 | 
				
			||||||
        v-for="i in ['日', '周', '月', '年']"
 | 
					 | 
				
			||||||
        :key="i"
 | 
					 | 
				
			||||||
        :label="i"
 | 
					 | 
				
			||||||
        :active="i === period"
 | 
					 | 
				
			||||||
        @click="() => $emit('update:period', i)"
 | 
					 | 
				
			||||||
      />
 | 
					 | 
				
			||||||
      <div class="btn-group">
 | 
					      <div class="btn-group">
 | 
				
			||||||
        <button type="button" class="export-btn" />
 | 
					        <button type="button" class="export-btn" />
 | 
				
			||||||
        <button
 | 
					        <button type="button" class="fullscreen-btn" :class="[isFullscreen ? 'exit-fullscreen' : '']"
 | 
				
			||||||
          type="button"
 | 
					          @click="toggleFullScreen" />
 | 
				
			||||||
          class="fullscreen-btn"
 | 
					 | 
				
			||||||
          :class="[isFullscreen ? 'exit-fullscreen' : '']"
 | 
					 | 
				
			||||||
          @click="toggleFullScreen"
 | 
					 | 
				
			||||||
        />
 | 
					 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </section>
 | 
					    </section>
 | 
				
			||||||
    <div class="page-title">{{ companyName }}</div>
 | 
					    <div class="page-title">{{ companyName }}</div>
 | 
				
			||||||
 | 
					    <section class="menu2">
 | 
				
			||||||
 | 
					      <CopilotButton v-for="i in dataList" :key="i.id" :label="i.name" :active="i.id === period"
 | 
				
			||||||
 | 
					        @click="() => $emit('update:period', i.id)" />
 | 
				
			||||||
 | 
					    </section>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import CopilotButton from "./button.vue";
 | 
					// import CopilotButton from "./button.vue";
 | 
				
			||||||
import FactorySelect from "./FactorySelect.vue";
 | 
					import FactorySelect from "./FactorySelect.vue";
 | 
				
			||||||
import screenfull from "screenfull";
 | 
					import screenfull from "screenfull";
 | 
				
			||||||
 | 
					import CopilotButton from "./button.vue";
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "FactoryDataHeader",
 | 
					  name: "FactoryDataHeader",
 | 
				
			||||||
  components: { CopilotButton, FactorySelect },
 | 
					  components: { CopilotButton, FactorySelect },
 | 
				
			||||||
@@ -42,15 +33,24 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    companyId: {
 | 
					    companyId: {
 | 
				
			||||||
      type: String,
 | 
					      type: Number,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    period: {
 | 
					    period: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      isFullscreen: false,
 | 
					      isFullscreen: false,
 | 
				
			||||||
 | 
					      dataList: [
 | 
				
			||||||
 | 
					        { id: 1, name: "日" },
 | 
				
			||||||
 | 
					        { id: 2, name: "周" },
 | 
				
			||||||
 | 
					        { id: 3, name: "月" },
 | 
				
			||||||
 | 
					        { id: 4, name: "年" },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {},
 | 
					  computed: {},
 | 
				
			||||||
@@ -84,13 +84,13 @@ export default {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.factory-header > .menu1 {
 | 
					.factory-header > .menu1 {
 | 
				
			||||||
  width: 24vw;
 | 
					  width: 20vw;
 | 
				
			||||||
  /* display: flex;
 | 
					  display: flex;
 | 
				
			||||||
  align-items: center;
 | 
					  align-items: center;
 | 
				
			||||||
  gap: 8px; */
 | 
					  gap: 8px;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.factory-header > .menu2 {
 | 
					.factory-header > .menu2 {
 | 
				
			||||||
  width: 30vw;
 | 
					  width: 26vw;
 | 
				
			||||||
  display: flex;
 | 
					  display: flex;
 | 
				
			||||||
  align-items: center;
 | 
					  align-items: center;
 | 
				
			||||||
  gap: 8px;
 | 
					  gap: 8px;
 | 
				
			||||||
@@ -119,13 +119,14 @@ export default {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.page-title {
 | 
					.page-title {
 | 
				
			||||||
  flex: 1;
 | 
					  flex: 1 1 auto;
 | 
				
			||||||
  font-size: 40px;
 | 
					  font-size: 40px;
 | 
				
			||||||
  line-height: 70px;
 | 
					  line-height: 70px;
 | 
				
			||||||
  letter-spacing: 5px;
 | 
					  letter-spacing: 5px;
 | 
				
			||||||
  font-family: 优设标题黑;
 | 
					  font-family: 优设标题黑;
 | 
				
			||||||
  color: #6db6ff;
 | 
					  color: #6db6ff;
 | 
				
			||||||
  text-align: right;
 | 
					  text-align: center;
 | 
				
			||||||
  user-select: none;
 | 
					  user-select: none;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/homeindex/page-title-two.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</style>
 | 
					</style>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -26,20 +26,20 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    companyId: {
 | 
					    companyId: {
 | 
				
			||||||
      type: String,
 | 
					      type: Number,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      isOpen: false,
 | 
					      isOpen: false,
 | 
				
			||||||
      company: [
 | 
					      company: [
 | 
				
			||||||
        { id: "1", name: "瑞昌中建材光电材料有限公司" },
 | 
					        { id: 0, name: "瑞昌中建材光电材料有限公司" },
 | 
				
			||||||
        { id: "2", name: "邯郸中建材光电材料有限公司" },
 | 
					        { id: 1, name: "邯郸中建材光电材料有限公司" },
 | 
				
			||||||
        { id: "3", name: "株洲中建材光电材料有限公司" },
 | 
					        { id: 2, name: "株洲中建材光电材料有限公司" },
 | 
				
			||||||
        { id: "4", name: "佳木斯中建材光电材料有限公司" },
 | 
					        { id: 3, name: "佳木斯中建材光电材料有限公司" },
 | 
				
			||||||
        { id: "5", name: "成都中建材光电材料有限公司" },
 | 
					        { id: 4, name: "成都中建材光电材料有限公司" },
 | 
				
			||||||
        { id: "6", name: "凯盛中建材光电材料有限公司" },
 | 
					        { id: 5, name: "凯盛中建材光电材料有限公司" },
 | 
				
			||||||
        { id: "7", name: "蚌埠中建材光电材料有限公司" },
 | 
					        { id: 6, name: "蚌埠中建材光电材料有限公司" },
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -367,7 +367,7 @@ export default {
 | 
				
			|||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
        console.log(this.width)
 | 
					        console.log(this.width)
 | 
				
			||||||
      } else {
 | 
					      } else {
 | 
				
			||||||
        this.watch = 100 + '%'
 | 
					        this.width = 100 + '%'
 | 
				
			||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
@@ -378,7 +378,7 @@ export default {
 | 
				
			|||||||
        this.width = 97 + '%'
 | 
					        this.width = 97 + '%'
 | 
				
			||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
      } else if (val === false && this.isOpen === false) {
 | 
					      } else if (val === false && this.isOpen === false) {
 | 
				
			||||||
        this.watch = 100 + '%'
 | 
					        this.width = 100 + '%'
 | 
				
			||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -365,7 +365,7 @@ export default {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
        console.log(this.width)
 | 
					        console.log(this.width)
 | 
				
			||||||
      } else {
 | 
					      } else {
 | 
				
			||||||
        this.watch = 100 + '%'
 | 
					        this.width = 100 + '%'
 | 
				
			||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -376,7 +376,7 @@ export default {
 | 
				
			|||||||
        this.width = 97 + '%'
 | 
					        this.width = 97 + '%'
 | 
				
			||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
      } else if(val === false && this.isOpen === false) {
 | 
					      } else if(val === false && this.isOpen === false) {
 | 
				
			||||||
        this.watch = 100 + '%'
 | 
					        this.width = 100 + '%'
 | 
				
			||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      // this.actualOptions.series.map((item) => {
 | 
					      // this.actualOptions.series.map((item) => {
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										27
									
								
								src/views/copilot/components/NotMsg.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,27 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
						<div class="notmsg">暂无数据</div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
						name: 'NotMsg',
 | 
				
			||||||
 | 
						components: {},
 | 
				
			||||||
 | 
						data() {
 | 
				
			||||||
 | 
							return {
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						computed: {
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						methods: {
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					.notmsg {
 | 
				
			||||||
 | 
						padding-top: 72px;
 | 
				
			||||||
 | 
						color: rgba(255, 255, 255, 0.4);
 | 
				
			||||||
 | 
						text-align: center;
 | 
				
			||||||
 | 
						font-size: 24px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										298
									
								
								src/views/copilot/components/ftoBarChartBase.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,298 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2024-05-23 15:49:14
 | 
				
			||||||
 | 
					 * @LastEditTime: 2024-05-29 10:56:21
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<!--
 | 
				
			||||||
 | 
					    filename: BarChartBase.vue
 | 
				
			||||||
 | 
					    author: liubin
 | 
				
			||||||
 | 
					    date: 2024-04-10 08:59:28
 | 
				
			||||||
 | 
					    description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <chart-container class="bar-chart-base">
 | 
				
			||||||
 | 
					    <div class="legend">
 | 
				
			||||||
 | 
					      <span v-for="item in legend" :key="item.label" class="legend-item"
 | 
				
			||||||
 | 
					        :style="{ fontSize: isFullscreen ? '0.58vw' : '0.54vw' }">{{ item.label }}</span>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div ref="ftoChart" style="height:94%;width:100%"></div>
 | 
				
			||||||
 | 
					  </chart-container>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import screenfull from "screenfull";
 | 
				
			||||||
 | 
					import ChartContainer from "./ChartContainer.vue";
 | 
				
			||||||
 | 
					import { debounce } from "@/utils/debounce";
 | 
				
			||||||
 | 
					// import chartMixin from "@/mixins/chart.js";
 | 
				
			||||||
 | 
					import * as echarts from "echarts";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "BarChartBase",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    ChartContainer,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  // mixins: [chartMixin],
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    vHeight: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default: 34,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    legend: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    xAxis: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    series: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    in: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      width: '100%',
 | 
				
			||||||
 | 
					      isFullscreen: false,
 | 
				
			||||||
 | 
					      actualOptions: null,
 | 
				
			||||||
 | 
					      options: {
 | 
				
			||||||
 | 
					        grid: {
 | 
				
			||||||
 | 
					          left: "5%",
 | 
				
			||||||
 | 
					          right: "4%",
 | 
				
			||||||
 | 
					          bottom: "3%",
 | 
				
			||||||
 | 
					          top: "15%",
 | 
				
			||||||
 | 
					          containLabel: true,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        tooltip: {},
 | 
				
			||||||
 | 
					        xAxis: {
 | 
				
			||||||
 | 
					          axisTick: {
 | 
				
			||||||
 | 
					            show: false,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLine: {
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLabel: {
 | 
				
			||||||
 | 
					            color: "#fff",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          data: this.xAxis,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        yAxis: {
 | 
				
			||||||
 | 
					          name: "单位/片",
 | 
				
			||||||
 | 
					          nameTextStyle: {
 | 
				
			||||||
 | 
					            color: "#fff",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisTick: {
 | 
				
			||||||
 | 
					            show: false,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLabel: {
 | 
				
			||||||
 | 
					            color: "#fff",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLine: {
 | 
				
			||||||
 | 
					            show: true,
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          splitLine: {
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        series: [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "", // this.series[0].name,
 | 
				
			||||||
 | 
					            type: "bar",
 | 
				
			||||||
 | 
					            barWidth: 12,
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              borderRadius: [10, 10, 0, 0],
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#12f7f1", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0.35,
 | 
				
			||||||
 | 
					                    color: "#12f7f177", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0.75,
 | 
				
			||||||
 | 
					                    color: "#12f7f133", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "transparent", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            data: [], // this.series[0].data,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "", // this.series[1].name,
 | 
				
			||||||
 | 
					            type: "bar",
 | 
				
			||||||
 | 
					            barWidth: 12,
 | 
				
			||||||
 | 
					            // tooltip: {
 | 
				
			||||||
 | 
					            //   valueFormatter: function (value) {
 | 
				
			||||||
 | 
					            //     return value + " ml";
 | 
				
			||||||
 | 
					            //   },
 | 
				
			||||||
 | 
					            // },
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              borderRadius: [10, 10, 0, 0],
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#57abf8", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "#364BFE66", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            data: [], // this.series[1].data,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    isOpen() {
 | 
				
			||||||
 | 
					      return this.$store.getters.sidebar.opened
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  watch: {
 | 
				
			||||||
 | 
					    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
				
			||||||
 | 
					    isOpen(val) {
 | 
				
			||||||
 | 
					      // console.log(val)
 | 
				
			||||||
 | 
					      this.canvasReset()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    isFullscreen(val) {
 | 
				
			||||||
 | 
					      this.actualOptions.series.map((item) => {
 | 
				
			||||||
 | 
					        item.barWidth = val ? 18 : 12;
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					      this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.initChart(this.actualOptions);
 | 
				
			||||||
 | 
					      // this.actualOptions.series.map((item) => {
 | 
				
			||||||
 | 
					      //   item.barWidth = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // });
 | 
				
			||||||
 | 
					      // this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // this.initChart(this.actualOptions);
 | 
				
			||||||
 | 
					      this.canvasReset()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    series(val) {
 | 
				
			||||||
 | 
					      if (!val) {
 | 
				
			||||||
 | 
					        this.initChart(this.options);
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      const actualOptions = JSON.parse(JSON.stringify(this.options));
 | 
				
			||||||
 | 
					      console.log('actualOptions', this.options)
 | 
				
			||||||
 | 
					      actualOptions.series[0].data = val[0].data;
 | 
				
			||||||
 | 
					      actualOptions.series[0].name = val[0].name;
 | 
				
			||||||
 | 
					      actualOptions.series[1].data = val[1].data;
 | 
				
			||||||
 | 
					      actualOptions.series[1].name = val[1].name;
 | 
				
			||||||
 | 
					      this.actualOptions = actualOptions;
 | 
				
			||||||
 | 
					      this.initChart(actualOptions);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    if (screenfull.isEnabled) {
 | 
				
			||||||
 | 
					      screenfull.on("change", () => {
 | 
				
			||||||
 | 
					        this.isFullscreen = screenfull.isFullscreen;
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    this.actualOptions = this.options
 | 
				
			||||||
 | 
					    this.canvasReset();
 | 
				
			||||||
 | 
					    window.addEventListener("resize", this.canvasReset);
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  beforeDestroy() {
 | 
				
			||||||
 | 
					    if (this.chart) {
 | 
				
			||||||
 | 
					      this.chart.dispose();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  destroyed() {
 | 
				
			||||||
 | 
					    window.removeEventListener("resize", this.canvasReset);
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    canvasReset() {
 | 
				
			||||||
 | 
					      debounce(() => {
 | 
				
			||||||
 | 
					        this.initChart();
 | 
				
			||||||
 | 
					      }, 500)();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    initChart() {
 | 
				
			||||||
 | 
					      if (this.chart) {
 | 
				
			||||||
 | 
					        this.chart.dispose();
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.chart = echarts.init(this.$refs.ftoChart);
 | 
				
			||||||
 | 
					      this.chart.setOption(this.actualOptions);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					.bar-chart-base {
 | 
				
			||||||
 | 
					  // position: relative;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend {
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    top: 5.2vh;
 | 
				
			||||||
 | 
					    right: 1vw;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item {
 | 
				
			||||||
 | 
					    position: relative;
 | 
				
			||||||
 | 
					    // font-size: 12px;
 | 
				
			||||||
 | 
					    margin-right: 0.67vw;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    &::before {
 | 
				
			||||||
 | 
					      content: "";
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      width: 0.531vw;
 | 
				
			||||||
 | 
					      height: 0.531vw;
 | 
				
			||||||
 | 
					      background-color: #ccc;
 | 
				
			||||||
 | 
					      border-radius: 2px;
 | 
				
			||||||
 | 
					      margin-right: 0.22vw;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(1):before {
 | 
				
			||||||
 | 
					    background-color: #12f7f1;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(2):before {
 | 
				
			||||||
 | 
					    background-color: #58adfa;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
@@ -1,7 +1,7 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2024-05-13 14:08:51
 | 
					 * @Date: 2024-05-13 14:08:51
 | 
				
			||||||
 * @LastEditTime: 2024-05-17 09:37:01
 | 
					 * @LastEditTime: 2024-05-23 15:18:53
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
@@ -191,7 +191,7 @@ export default {
 | 
				
			|||||||
        console.log(this.width)
 | 
					        console.log(this.width)
 | 
				
			||||||
      } else {
 | 
					      } else {
 | 
				
			||||||
        console.log('ryf')
 | 
					        console.log('ryf')
 | 
				
			||||||
        this.watch = 100 + '%'
 | 
					        this.width = 100 + '%'
 | 
				
			||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -201,7 +201,7 @@ export default {
 | 
				
			|||||||
        this.width = 97 + '%'
 | 
					        this.width = 97 + '%'
 | 
				
			||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
      } else if (val === false && this.isOpen === false) {
 | 
					      } else if (val === false && this.isOpen === false) {
 | 
				
			||||||
        this.watch = 100 + '%'
 | 
					        this.width = 100 + '%'
 | 
				
			||||||
        this.canvasReset()
 | 
					        this.canvasReset()
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      // this.actualOptions.series.map((item) => {
 | 
					      // this.actualOptions.series.map((item) => {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,4 +1,3 @@
 | 
				
			|||||||
 | 
					 | 
				
			||||||
<!--
 | 
					<!--
 | 
				
			||||||
    filename: container.vue
 | 
					    filename: container.vue
 | 
				
			||||||
    author: liubin
 | 
					    author: liubin
 | 
				
			||||||
@@ -8,12 +7,13 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <!-- <div class="copilot-layout" ref="copilot-layout"> -->
 | 
					  <!-- <div class="copilot-layout" ref="copilot-layout"> -->
 | 
				
			||||||
  <div class="copilot-layout" ref="copilot-layout" :class="[page == '效率' ? 'other' : 'produce' ]">
 | 
					  <div class="copilot-layout produce" ref="copilot-layout">
 | 
				
			||||||
    <CopilotHeaderVue :active="page" :period="period" @update:active="page = $event" @update:period="period = $event" />
 | 
					    <CopilotHeaderVue :than="than" :active="page" :period="period" @update:active="updateActive" @update:period="period = $event"
 | 
				
			||||||
 | 
					      @update:than="updateThan" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <YieldCopilot v-if="page == '产量'" :period="period" />
 | 
					    <YieldCopilot :period="period"  :than="than"  />
 | 
				
			||||||
    <EnergyCopilot v-if="page == '综合'" :period="period" />
 | 
					    <!-- <EnergyCopilot v-if="page == '综合'" :period="period" /> -->
 | 
				
			||||||
    <EfficiencyCopilot v-if="page == '效率'" :period="period" />
 | 
					    <!-- <EfficiencyCopilot v-if="page == '效率'" :period="period" /> -->
 | 
				
			||||||
    <div class="copilot-footer">© 中建材智能自动化研究院有限公司</div>
 | 
					    <div class="copilot-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
@@ -21,24 +21,55 @@
 | 
				
			|||||||
<script>
 | 
					<script>
 | 
				
			||||||
import CopilotHeaderVue from "./components/CopilotHeader.vue";
 | 
					import CopilotHeaderVue from "./components/CopilotHeader.vue";
 | 
				
			||||||
import YieldCopilot from "./yield/index.vue";
 | 
					import YieldCopilot from "./yield/index.vue";
 | 
				
			||||||
import EnergyCopilot from "./energy/index.vue";
 | 
					// import EnergyCopilot from "./energy/index.vue";
 | 
				
			||||||
import EfficiencyCopilot from "./efficiency/index.vue";
 | 
					// import EfficiencyCopilot from "./efficiency/index.vue";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "CopilotContainer",
 | 
					  name: "CopilotContainer",
 | 
				
			||||||
  components: {
 | 
					  components: {
 | 
				
			||||||
    CopilotHeaderVue,
 | 
					    CopilotHeaderVue,
 | 
				
			||||||
    YieldCopilot,
 | 
					    YieldCopilot,
 | 
				
			||||||
    EnergyCopilot,
 | 
					    // EnergyCopilot,
 | 
				
			||||||
    EfficiencyCopilot,
 | 
					    // EfficiencyCopilot,
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      page: "产量",
 | 
					      page: "产量",
 | 
				
			||||||
      period: "日",
 | 
					      period: "日",
 | 
				
			||||||
 | 
					      than:'同比',
 | 
				
			||||||
      currentsStyles: '',
 | 
					      currentsStyles: '',
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    updateThan(val) {
 | 
				
			||||||
 | 
					      console.log(val);
 | 
				
			||||||
 | 
					      this.than = val;
 | 
				
			||||||
 | 
					      // this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updateActive(val, oldVal) {
 | 
				
			||||||
 | 
					      console.log(val)
 | 
				
			||||||
 | 
					      if (val === '效率') {
 | 
				
			||||||
 | 
					        this.$router.push({
 | 
				
			||||||
 | 
					          path: 'efficiency-container',
 | 
				
			||||||
 | 
					          query: {
 | 
				
			||||||
 | 
					            name: '效率'
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        // this.page = oldVal
 | 
				
			||||||
 | 
					      } else if (val === '产量') {
 | 
				
			||||||
 | 
					        this.$router.push({
 | 
				
			||||||
 | 
					          path: 'main',
 | 
				
			||||||
 | 
					          query: {
 | 
				
			||||||
 | 
					            name: '产量'
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        // this.page = oldVal
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  // mounted() {
 | 
				
			||||||
 | 
					  //   this.page = this.$route.query.name
 | 
				
			||||||
 | 
					  // },
 | 
				
			||||||
  // watch: {
 | 
					  // watch: {
 | 
				
			||||||
  //   page(val) {
 | 
					  //   page(val) {
 | 
				
			||||||
  //     if (val === '产量') {
 | 
					  //     if (val === '产量') {
 | 
				
			||||||
@@ -65,7 +96,6 @@ export default {
 | 
				
			|||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
<style>
 | 
					<style>
 | 
				
			||||||
 | 
					 | 
				
			||||||
.copilot-layout {
 | 
					.copilot-layout {
 | 
				
			||||||
  padding: 16px;
 | 
					  padding: 16px;
 | 
				
			||||||
  background: url(../../assets/images/copilot-bg.png) 0 0 / 100% 100% no-repeat;
 | 
					  background: url(../../assets/images/copilot-bg.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
@@ -81,12 +111,14 @@ export default {
 | 
				
			|||||||
  gap: 8px;
 | 
					  gap: 8px;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.produce{
 | 
					.produce {
 | 
				
			||||||
  height: calc(100% + 38px);
 | 
					  height: calc(100% + 38px);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.other {
 | 
					.other {
 | 
				
			||||||
  height: calc(100% + 240px);
 | 
					  height: calc(100% + 240px);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.copilot-footer {
 | 
					.copilot-footer {
 | 
				
			||||||
  /** position: absolute;
 | 
					  /** position: absolute;
 | 
				
			||||||
  bottom: 10px; **/
 | 
					  bottom: 10px; **/
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -25,6 +25,14 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    chipOeeRate: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      default:{}
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    // 城市数组的顺序必须是固定的
 | 
					    // 城市数组的顺序必须是固定的
 | 
				
			||||||
@@ -35,78 +43,236 @@ export default {
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    legend() {
 | 
					    legend() {
 | 
				
			||||||
      switch (this.period) {
 | 
					      let items = [];
 | 
				
			||||||
        case "日":
 | 
					      var day1 = new Date();
 | 
				
			||||||
          return [{ label: "昨日", color: "#12f7f1" }];
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
        case "周":
 | 
					      var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
          return [{ label: "本周", color: "#12f7f1" }];
 | 
					      //今天的时间
 | 
				
			||||||
        case "月": {
 | 
					      // var day2 = new Date();
 | 
				
			||||||
          const year = new Date().getFullYear();
 | 
					      // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					      // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
 | 
					      // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
      const month = new Date().getMonth() + 1;
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
          return [
 | 
					      const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
            { label: `${year - 1}年${month}月`, color: "#12f7f1" },
 | 
					 | 
				
			||||||
            { label: `${year}年${month}月`, color: "#58adfa" },
 | 
					 | 
				
			||||||
          ];
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        case "年": {
 | 
					 | 
				
			||||||
      const year = new Date().getFullYear();
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
          return [
 | 
					      if (this.period === '日' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年${month}月${today}日`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '日' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${yesterday}日`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年本周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `上周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年${month}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          { label: `${month}月目标`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${lastMonth}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          { label: `${month}月目标`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
          { label: `${year - 1}年`, color: "#12f7f1" },
 | 
					          { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
          { label: `${year}年`, color: "#58adfa" },
 | 
					          { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
          ];
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        default:
 | 
					 | 
				
			||||||
          return [
 | 
					 | 
				
			||||||
            { label: `${year - 1}年`, color: "#12f7f1" },
 | 
					 | 
				
			||||||
          { label:  `${year}年`, color: "#58adfa" },
 | 
					          { label:  `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          // { label: `${year}年目标`, value: valueTuple[2] },
 | 
				
			||||||
        ];
 | 
					        ];
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					      return items
 | 
				
			||||||
 | 
					      // switch (this.period) {
 | 
				
			||||||
 | 
					      //   case "日":
 | 
				
			||||||
 | 
					      //     return [{ label: "昨日", color: "#12f7f1" }];
 | 
				
			||||||
 | 
					      //   case "周":
 | 
				
			||||||
 | 
					      //     return [{ label: "本周", color: "#12f7f1" }];
 | 
				
			||||||
 | 
					      //   case "月": {
 | 
				
			||||||
 | 
					      //     const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      //     const month = new Date().getMonth() + 1;
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年${month}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      //   case "年": {
 | 
				
			||||||
 | 
					      //     const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      //   default:
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    // chipOeeRate() {
 | 
				
			||||||
 | 
					    //    return  this.$store.getters.copilot.efficiency.chipOeeRate
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
    series() {
 | 
					    series() {
 | 
				
			||||||
      // console.log('aaaaaaaa', this.$store.getters.copilot.efficiency.chipOee);
 | 
					      // console.log('aaaaaaaa', this.$store.getters.copilot.efficiency.chipOee);
 | 
				
			||||||
      const { chipOee } = this.$store.getters.copilot.efficiency;
 | 
					      const chipOeeRate = this.chipOeeRate
 | 
				
			||||||
      let dataList = null;
 | 
					      // console.log('chipOee', chipOeeRate)
 | 
				
			||||||
 | 
					      let dataList = null
 | 
				
			||||||
      switch (this.period) {
 | 
					      switch (this.period) {
 | 
				
			||||||
        case "日":
 | 
					        case "日":
 | 
				
			||||||
 | 
					          dataList = [];
 | 
				
			||||||
 | 
					          dataList[0] = chipOeeRate?.previous;
 | 
				
			||||||
 | 
					          dataList[1] = chipOeeRate?.current;
 | 
				
			||||||
        case "周":
 | 
					        case "周":
 | 
				
			||||||
          dataList = chipOee?.current;
 | 
					          dataList = [];
 | 
				
			||||||
        case "周":
 | 
					          dataList[0] = chipOeeRate?.previous;
 | 
				
			||||||
          dataList = chipOee?.current;
 | 
					          dataList[1] = chipOeeRate?.current;
 | 
				
			||||||
          break;
 | 
					 | 
				
			||||||
          default:
 | 
					          default:
 | 
				
			||||||
          dataList = [];
 | 
					          dataList = [];
 | 
				
			||||||
          dataList[0] = chipOee?.previous;
 | 
					          dataList[0] = chipOeeRate?.previous;
 | 
				
			||||||
          dataList[1] = chipOee?.current;
 | 
					          dataList[1] = chipOeeRate?.current
 | 
				
			||||||
 | 
					          dataList[2] = chipOeeRate?.target
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      // console.log(dataList)
 | 
					      console.log(dataList)
 | 
				
			||||||
      return getTemplate(this.period, dataList);
 | 
					      return getTemplate(this.period, dataList,this.than);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {},
 | 
					  methods: {},
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function getTemplate(period, dataList) {
 | 
					function getTemplate(period, dataList, than) {
 | 
				
			||||||
  const year = new Date().getFullYear();
 | 
					  // console.log('dataList',dataList);
 | 
				
			||||||
 | 
					  let items = [];
 | 
				
			||||||
 | 
					  var day1 = new Date();
 | 
				
			||||||
 | 
					  day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					  var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
 | 
					  //今天的时间
 | 
				
			||||||
 | 
					  // var day2 = new Date();
 | 
				
			||||||
 | 
					  // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					  // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					  const today = new Date().getDate();
 | 
				
			||||||
 | 
					  // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
  const month = new Date().getMonth() + 1;
 | 
					  const month = new Date().getMonth() + 1;
 | 
				
			||||||
  // console.log('11111', dataList);
 | 
					  const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
  return period == "日" || period == "周"
 | 
					  const year = new Date().getFullYear();
 | 
				
			||||||
    ? [
 | 
					  if (period === '日' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
          name: period == "日" ? "昨日" : "本周",
 | 
					        name: `去年${month}月${today}日`,
 | 
				
			||||||
          data: dataList ?? [],
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      ]
 | 
					 | 
				
			||||||
    : [
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: period == "年" ? `${year - 1}年` : `${year - 1}年${month}月`,
 | 
					 | 
				
			||||||
        data: dataList ? dataList[0] : [],
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
          name: period == "年" ? `${year}年` : `${year}年${month}月`,
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
        data: dataList ? dataList[1] : [],
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
    ];
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '日' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${yesterday}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '周' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '周' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `上周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '月' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}目标`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[2] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '月' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${lastMonth}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}目标`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[2] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year - 1}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year}目标`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[2] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return items
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,22 +1,15 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
    filename: ChipRate.vue
 | 
					 * @Author: zhp
 | 
				
			||||||
    author: liubin
 | 
					 * @Date: 2024-05-10 11:10:54
 | 
				
			||||||
    date: 2024-04-29 08:50:54
 | 
					 * @LastEditTime: 2024-05-30 13:23:03
 | 
				
			||||||
    description: 芯片良率
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="chip-rate">
 | 
					  <div class="chip-rate">
 | 
				
			||||||
    <ChipRateItem
 | 
					    <ChipRateItem :period="period" :than="than" :cities="['成都', '邯郸', '株洲', '瑞昌']" :color="1" />
 | 
				
			||||||
      :period="period"
 | 
					    <ChipRateItem :period="period" :than="than" :cities="['佳木斯', '凯盛光伏', '蚌埠兴科']" :color="2" />
 | 
				
			||||||
      :cities="['成都', '邯郸', '株洲', '瑞昌']"
 | 
					 | 
				
			||||||
      :color="1"
 | 
					 | 
				
			||||||
    />
 | 
					 | 
				
			||||||
    <ChipRateItem
 | 
					 | 
				
			||||||
      :period="period"
 | 
					 | 
				
			||||||
      :cities="['佳木斯', '凯盛光伏', '蚌埠兴科']"
 | 
					 | 
				
			||||||
      :color="2"
 | 
					 | 
				
			||||||
    />
 | 
					 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -30,6 +23,10 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: '同比',
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {};
 | 
					    return {};
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,18 +1,19 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2024-05-07 10:25:10
 | 
					 * @Date: 2024-05-07 10:25:10
 | 
				
			||||||
 * @LastEditTime: 2024-05-20 10:04:03
 | 
					 * @LastEditTime: 2024-05-30 11:19:51
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="std-rate">
 | 
					  <!-- <div class="order"> -->
 | 
				
			||||||
 | 
					    <div class="std-rate" style="width: 100%; overflow: hidden scroll; height: 400px">
 | 
				
			||||||
      <div class="span-2">
 | 
					      <div class="span-2">
 | 
				
			||||||
        <StdRateItem :period="period" :city="cities[5]" />
 | 
					        <StdRateItem :period="period" :city="cities[5]" />
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div class="flex-item" v-for="item in cities.filter((val, index) => index != 5)" :key="item.name">
 | 
					      <div class="flex-item" v-for="item in cities.filter((val, index) => index != 5)" :key="item.name">
 | 
				
			||||||
      <StdRateItem :period="period" :city="item" />
 | 
					        <StdRateItem :period="period" :than="than" :city="item" />
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
@@ -27,6 +28,10 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    cities() {
 | 
					    cities() {
 | 
				
			||||||
@@ -99,7 +104,7 @@ export default {
 | 
				
			|||||||
.std-rate {
 | 
					.std-rate {
 | 
				
			||||||
  display: flex;
 | 
					  display: flex;
 | 
				
			||||||
  // gap: 1px;
 | 
					  // gap: 1px;
 | 
				
			||||||
  flex: 1 1 auto;
 | 
					  // flex: 1 1 auto;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  // display: -webkit-box;
 | 
					  // display: -webkit-box;
 | 
				
			||||||
  flex-wrap: wrap;
 | 
					  flex-wrap: wrap;
 | 
				
			||||||
@@ -107,6 +112,9 @@ export default {
 | 
				
			|||||||
  // grid-template-columns: repeat(2, 1fr);
 | 
					  // grid-template-columns: repeat(2, 1fr);
 | 
				
			||||||
  // grid-template-rows: repeat(4, 1fr);
 | 
					  // grid-template-rows: repeat(4, 1fr);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					.std-rate::-webkit-scrollbar {
 | 
				
			||||||
 | 
					  display: none;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
.flex-item{
 | 
					.flex-item{
 | 
				
			||||||
  // flex: 1 1 auto;
 | 
					  // flex: 1 1 auto;
 | 
				
			||||||
  width: 50%;
 | 
					  width: 50%;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,7 +16,7 @@
 | 
				
			|||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import BarChartBase from "@/views/copilot/efficiency/components/sub/bar/BarChartChipOEE.vue";
 | 
					import BarChartBase from "@/views/copilot/efficiency/components/sub/bar/BarChartChipTrans.vue";
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "TransformRate",
 | 
					  name: "TransformRate",
 | 
				
			||||||
  components: { BarChartBase },
 | 
					  components: { BarChartBase },
 | 
				
			||||||
@@ -25,6 +25,14 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: '同比',
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    transformRate: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      default: {}
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    // 城市数组的顺序必须是固定的
 | 
					    // 城市数组的顺序必须是固定的
 | 
				
			||||||
@@ -35,75 +43,227 @@ export default {
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    legend() {
 | 
					    legend() {
 | 
				
			||||||
      switch (this.period) {
 | 
					      let items = [];
 | 
				
			||||||
        case "日":
 | 
					      var day1 = new Date();
 | 
				
			||||||
          return [{ label: "昨日", color: "#12f7f1" }];
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
        case "周":
 | 
					      var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
          return [{ label: "本周", color: "#12f7f1" }];
 | 
					      //今天的时间
 | 
				
			||||||
        case "月": {
 | 
					      // var day2 = new Date();
 | 
				
			||||||
          const year = new Date().getFullYear();
 | 
					      // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					      // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
 | 
					      // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
      const month = new Date().getMonth() + 1;
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
          return [
 | 
					      const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
            { label: `${year - 1}年${month}月`, color: "#12f7f1" },
 | 
					 | 
				
			||||||
            { label: `${year}年${month}月`, color: "#58adfa" },
 | 
					 | 
				
			||||||
          ];
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        case "年": {
 | 
					 | 
				
			||||||
      const year = new Date().getFullYear();
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
          return [
 | 
					      if (this.period === '日' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年${month}月${today}日`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '日' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${yesterday}日`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年本周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `上周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年${month}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          { label: `${month}月目标`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${lastMonth}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          { label: `${month}月目标`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
          { label: `${year - 1}年`, color: "#12f7f1" },
 | 
					          { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
          { label: `${year}年`, color: "#58adfa" },
 | 
					          { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
          ];
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        default:
 | 
					 | 
				
			||||||
          return [
 | 
					 | 
				
			||||||
            { label: `${year - 1}年`, color: "#12f7f1" },
 | 
					 | 
				
			||||||
          { label: `${year}年`, color: "#58adfa" },
 | 
					          { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
          ];
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    series() {
 | 
					 | 
				
			||||||
      const { transformRate } = this.$store.getters.copilot.efficiency;
 | 
					 | 
				
			||||||
      let dataList = null;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          // { label: `${year}年目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      return items
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // transformRate() {
 | 
				
			||||||
 | 
					    //   return this.$store.getters.copilot.efficiency.transformRate
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
 | 
					    series() {
 | 
				
			||||||
 | 
					      // console.log('aaaaaaaa', this.$store.getters.copilot.efficiency.chipOee);
 | 
				
			||||||
 | 
					      const transformRate = this.transformRate
 | 
				
			||||||
 | 
					      // console.log('chipOee', chipOeeRate)
 | 
				
			||||||
 | 
					      let dataList = null;
 | 
				
			||||||
      switch (this.period) {
 | 
					      switch (this.period) {
 | 
				
			||||||
        case "日":
 | 
					        case "日":
 | 
				
			||||||
 | 
					          dataList = [];
 | 
				
			||||||
 | 
					          dataList[0] = transformRate.previous;
 | 
				
			||||||
 | 
					          dataList[1] = transformRate.current;
 | 
				
			||||||
        case "周":
 | 
					        case "周":
 | 
				
			||||||
          dataList = transformRate?.current;
 | 
					          dataList = [];
 | 
				
			||||||
          break;
 | 
					          dataList[0] = transformRate.previous;
 | 
				
			||||||
 | 
					          dataList[1] = transformRate.current;
 | 
				
			||||||
        default:
 | 
					        default:
 | 
				
			||||||
          dataList = [];
 | 
					          dataList = [];
 | 
				
			||||||
          dataList[0] = transformRate?.previous;
 | 
					          dataList[0] = transformRate.previous;
 | 
				
			||||||
          dataList[1] = transformRate?.current;
 | 
					          dataList[1] = transformRate.current
 | 
				
			||||||
 | 
					          dataList[2] = transformRate.target
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					      console.log('transformRate', dataList)
 | 
				
			||||||
      return getTemplate(this.period, dataList);
 | 
					      return getTemplate(this.period, dataList, this.than);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    // series() {
 | 
				
			||||||
 | 
					    //   const { transformRate } = this.$store.getters.copilot.efficiency;
 | 
				
			||||||
 | 
					    //   let dataList = null;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //   switch (this.period) {
 | 
				
			||||||
 | 
					    //     case "日":
 | 
				
			||||||
 | 
					    //     case "周":
 | 
				
			||||||
 | 
					    //       dataList = transformRate?.current;
 | 
				
			||||||
 | 
					    //       break;
 | 
				
			||||||
 | 
					    //     default:
 | 
				
			||||||
 | 
					    //       dataList = [];
 | 
				
			||||||
 | 
					    //       dataList[0] = transformRate?.previous;
 | 
				
			||||||
 | 
					    //       dataList[1] = transformRate?.current;
 | 
				
			||||||
 | 
					    //   }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //   return getTemplate(this.period, dataList);
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {},
 | 
					  methods: {},
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function getTemplate(period, dataList) {
 | 
					function getTemplate(period, dataList,than) {
 | 
				
			||||||
  const year = new Date().getFullYear();
 | 
					  // console.log('dataList',dataList);
 | 
				
			||||||
 | 
					  let items = [];
 | 
				
			||||||
 | 
					  var day1 = new Date();
 | 
				
			||||||
 | 
					  day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					  var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
 | 
					  //今天的时间
 | 
				
			||||||
 | 
					  // var day2 = new Date();
 | 
				
			||||||
 | 
					  // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					  // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					  const today = new Date().getDate();
 | 
				
			||||||
 | 
					  // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
  const month = new Date().getMonth() + 1;
 | 
					  const month = new Date().getMonth() + 1;
 | 
				
			||||||
  return period == "日" || period == "周"
 | 
					  const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
    ? [
 | 
					  const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					  if (period === '日' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
          name: period == "日" ? "昨日" : "本周",
 | 
					        name: `去年${month}月${today}日`,
 | 
				
			||||||
          data: dataList ?? [],
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      ]
 | 
					 | 
				
			||||||
    : [
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: period == "年" ? `${year - 1}年` : `${year - 1}年${month}月`,
 | 
					 | 
				
			||||||
        data: dataList ? dataList[0] : [],
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
          name: period == "年" ? `${year}年` : `${year}年${month}月`,
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
        data: dataList ? dataList[1] : [],
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
    ];
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '日' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${yesterday}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '周' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '周' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `上周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '月' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}目标`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[2] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '月' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${lastMonth}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}目标`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[2] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year - 1}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year}目标`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[2] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return items
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,17 +1,17 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2024-05-07 13:22:43
 | 
					 * @Date: 2024-05-07 13:22:43
 | 
				
			||||||
 * @LastEditTime: 2024-05-14 08:32:44
 | 
					 * @LastEditTime: 2024-05-29 14:09:08
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <chart-container class="bar-chart-base">
 | 
					  <chart-container class="bar-chart-base">
 | 
				
			||||||
    <div class="legend">
 | 
					    <div class="legend">
 | 
				
			||||||
      <span v-for="item in legend" :key="item.label" class="legend-item"
 | 
					      <span v-for="(item,index) in legend" :key="index" class="legend-item"
 | 
				
			||||||
        :style="{ fontSize: isFullscreen ? '0.58vw' : '0.54vw' }">{{ item.label }}</span>
 | 
					        :style="{ fontSize: isFullscreen ? '0.58vw' : '0.54vw' }">{{ item.label }}</span>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <div ref="chart" :style="{ height: '100%',width: width}"></div>
 | 
					    <div ref="oeeChart" style="height:96%;width:100%"></div>
 | 
				
			||||||
  </chart-container>
 | 
					  </chart-container>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -171,6 +171,41 @@ export default {
 | 
				
			|||||||
            },
 | 
					            },
 | 
				
			||||||
            data: [], // this.series[1].data,
 | 
					            data: [], // this.series[1].data,
 | 
				
			||||||
          },
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "", // "2024年目标值",
 | 
				
			||||||
 | 
					            type: "line",
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#f3c000",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              color: "#f3c000",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            areaStyle: {
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#f3c000", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0.55,
 | 
				
			||||||
 | 
					                    color: "#f3c00033",
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "transparent", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            data: [], // this.series[0].data,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
        ],
 | 
					        ],
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
@@ -182,13 +217,7 @@ export default {
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  watch: {
 | 
					  watch: {
 | 
				
			||||||
    isOpen(val) {
 | 
					    isOpen(val) {
 | 
				
			||||||
      if (val === true) {
 | 
					 | 
				
			||||||
        this.width = '100%-128px'
 | 
					 | 
				
			||||||
      this.canvasReset()
 | 
					      this.canvasReset()
 | 
				
			||||||
      } else {
 | 
					 | 
				
			||||||
        this.watch = 100 + '%'
 | 
					 | 
				
			||||||
        this.canvasReset()
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
					    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
				
			||||||
    isFullscreen(val) {
 | 
					    isFullscreen(val) {
 | 
				
			||||||
@@ -198,24 +227,47 @@ export default {
 | 
				
			|||||||
      this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
					      this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
      this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
					      this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
      this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
					      this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
      this.initChart(this.actualOptions);
 | 
					      // if (val === false && this.isOpen === true) {
 | 
				
			||||||
 | 
					      //   console.log(val)
 | 
				
			||||||
 | 
					      //   this.width = 97 + '%'
 | 
				
			||||||
 | 
					      //   this.canvasReset()
 | 
				
			||||||
 | 
					      // } else if (val === false && this.isOpen === false) {
 | 
				
			||||||
 | 
					      //   this.width = 100 + '%'
 | 
				
			||||||
 | 
					      //   this.canvasReset()
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      // this.actualOptions.series.map((item) => {
 | 
				
			||||||
 | 
					      //   item.barWidth = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // });
 | 
				
			||||||
 | 
					      // this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.initChart(this.actualOptions)
 | 
				
			||||||
 | 
					      this.canvasReset()
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    series(val) {
 | 
					    series(val) {
 | 
				
			||||||
      if (!val) {
 | 
					      if (!val) {
 | 
				
			||||||
        this.initChart(this.options);
 | 
					        this.initChart(this.options);
 | 
				
			||||||
        return;
 | 
					        return;
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      console.log(val)
 | 
					      // console.log('val', val)
 | 
				
			||||||
      const actualOptions = JSON.parse(JSON.stringify(this.options))
 | 
					      const actualOptions = JSON.parse(JSON.stringify(this.options))
 | 
				
			||||||
 | 
					      console.log(actualOptions)
 | 
				
			||||||
      actualOptions.series[0].data = val[0].data;
 | 
					      actualOptions.series[0].data = val[0].data;
 | 
				
			||||||
      actualOptions.series[0].name = val[0].name;
 | 
					      actualOptions.series[0].name = val[0].name;
 | 
				
			||||||
      actualOptions.series[1].data = val?.[1]?.data || [];
 | 
					      actualOptions.series[1].data = val?.[1]?.data;
 | 
				
			||||||
      actualOptions.series[1].name = val?.[1]?.name || "";
 | 
					      actualOptions.series[1].name = val?.[1]?.name;
 | 
				
			||||||
 | 
					      actualOptions.series[2].data = val?.[2]?.data || [];
 | 
				
			||||||
 | 
					      actualOptions.series[2].name = val?.[2]?.name || "";
 | 
				
			||||||
      this.actualOptions = actualOptions;
 | 
					      this.actualOptions = actualOptions;
 | 
				
			||||||
      this.initChart(actualOptions);
 | 
					      this.initChart(actualOptions);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  mounted() {
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    // if (screenfull.isEnabled) {
 | 
				
			||||||
 | 
					    //   screenfull.on("change", () => {
 | 
				
			||||||
 | 
					    //     this.isFullscreen = screenfull.isFullscreen;
 | 
				
			||||||
 | 
					    //   });
 | 
				
			||||||
 | 
					    // }
 | 
				
			||||||
    // if (screenfull.isEnabled) {
 | 
					    // if (screenfull.isEnabled) {
 | 
				
			||||||
    //   screenfull.on("change", () => {
 | 
					    //   screenfull.on("change", () => {
 | 
				
			||||||
    //     this.isFullscreen = screenfull.isFullscreen;
 | 
					    //     this.isFullscreen = screenfull.isFullscreen;
 | 
				
			||||||
@@ -243,7 +295,7 @@ export default {
 | 
				
			|||||||
      if (this.chart) {
 | 
					      if (this.chart) {
 | 
				
			||||||
        this.chart.dispose();
 | 
					        this.chart.dispose();
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      this.chart = echarts.init(this.$refs.chart);
 | 
					      this.chart = echarts.init(this.$refs.oeeChart);
 | 
				
			||||||
      this.chart.setOption(this.actualOptions);
 | 
					      this.chart.setOption(this.actualOptions);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
@@ -263,7 +315,7 @@ export default {
 | 
				
			|||||||
  .legend-item {
 | 
					  .legend-item {
 | 
				
			||||||
    position: relative;
 | 
					    position: relative;
 | 
				
			||||||
    // font-size: 12px;
 | 
					    // font-size: 12px;
 | 
				
			||||||
    margin-right: 0.67vw;
 | 
					    margin-right: 1.3vw;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    &::before {
 | 
					    &::before {
 | 
				
			||||||
      content: "";
 | 
					      content: "";
 | 
				
			||||||
@@ -275,7 +327,34 @@ export default {
 | 
				
			|||||||
      margin-right: 0.22vw;
 | 
					      margin-right: 0.22vw;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					 .legend-item:nth-child(3):before {
 | 
				
			||||||
 | 
					   // width: 12px;
 | 
				
			||||||
 | 
					   // height: 2px;
 | 
				
			||||||
 | 
					   width: 1vw;
 | 
				
			||||||
 | 
					   height: 0.1064vw;
 | 
				
			||||||
 | 
					   background-color: #f3c000;
 | 
				
			||||||
 | 
					   position: absolute;
 | 
				
			||||||
 | 
					   top: 50%;
 | 
				
			||||||
 | 
					   // left: -16px;
 | 
				
			||||||
 | 
					   left: -0.951vw;
 | 
				
			||||||
 | 
					   transform: translateY(-50%);
 | 
				
			||||||
 | 
					 }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 .legend-item:nth-child(3):after {
 | 
				
			||||||
 | 
					   background-color: #f3c000;
 | 
				
			||||||
 | 
					   content: "";
 | 
				
			||||||
 | 
					   display: inline-block;
 | 
				
			||||||
 | 
					   position: absolute;
 | 
				
			||||||
 | 
					   // width: 6px;
 | 
				
			||||||
 | 
					   // height: 6px;
 | 
				
			||||||
 | 
					   width: 0.3191vw;
 | 
				
			||||||
 | 
					   height: 0.3191vw;
 | 
				
			||||||
 | 
					   border-radius: 100%;
 | 
				
			||||||
 | 
					   top: 50%;
 | 
				
			||||||
 | 
					   left: -0.851vw;
 | 
				
			||||||
 | 
					   // left: -16px;
 | 
				
			||||||
 | 
					   transform: translateY(-50%) translateX(50%);
 | 
				
			||||||
 | 
					 }
 | 
				
			||||||
  .legend-item:nth-child(1):before {
 | 
					  .legend-item:nth-child(1):before {
 | 
				
			||||||
    background-color: #12f7f1;
 | 
					    background-color: #12f7f1;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,366 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2024-05-23 15:50:44
 | 
				
			||||||
 | 
					 * @LastEditTime: 2024-05-29 14:25:10
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <chart-container class="bar-chart-base">
 | 
				
			||||||
 | 
					    <div class="legend">
 | 
				
			||||||
 | 
					      <span v-for="(item,index) in legend" :key="index" class="legend-item"
 | 
				
			||||||
 | 
					        :style="{ fontSize: isFullscreen ? '0.58vw' : '0.54vw' }">{{ item.label }}</span>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div ref="oeeChart" style="height:96%;width:100%"></div>
 | 
				
			||||||
 | 
					  </chart-container>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import screenfull from "screenfull";
 | 
				
			||||||
 | 
					import ChartContainer from "../../../../components/ChartContainer.vue";
 | 
				
			||||||
 | 
					// import chartMixin from "@/mixins/chart.js";
 | 
				
			||||||
 | 
					import { debounce } from "@/utils/debounce";
 | 
				
			||||||
 | 
					import * as echarts from "echarts";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "BarChartBase",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    ChartContainer,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  // mixins: [chartMixin],
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    vHeight: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default: 36,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    legend: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    xAxis: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    series: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    in: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      width: '100%',
 | 
				
			||||||
 | 
					      isFullscreen: false,
 | 
				
			||||||
 | 
					      actualOptions: null,
 | 
				
			||||||
 | 
					      options: {
 | 
				
			||||||
 | 
					        grid: {
 | 
				
			||||||
 | 
					          left: "5%",
 | 
				
			||||||
 | 
					          right: "0%",
 | 
				
			||||||
 | 
					          bottom: "3%",
 | 
				
			||||||
 | 
					          top: "15%",
 | 
				
			||||||
 | 
					          containLabel: true,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        tooltip: {},
 | 
				
			||||||
 | 
					        xAxis: {
 | 
				
			||||||
 | 
					          axisTick: {
 | 
				
			||||||
 | 
					            show: false,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLine: {
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLabel: {
 | 
				
			||||||
 | 
					            color: "#fff",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          data: this.xAxis,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        yAxis: {
 | 
				
			||||||
 | 
					          name: "单位/%",
 | 
				
			||||||
 | 
					          nameTextStyle: {
 | 
				
			||||||
 | 
					            color: "#fff",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisTick: {
 | 
				
			||||||
 | 
					            show: false,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLabel: {
 | 
				
			||||||
 | 
					            color: "#fff",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLine: {
 | 
				
			||||||
 | 
					            show: true,
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          splitLine: {
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        series: [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "", // this.series[0].name,
 | 
				
			||||||
 | 
					            type: "bar",
 | 
				
			||||||
 | 
					            barWidth: 12,
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              borderRadius: [10, 10, 0, 0],
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#12f7f1", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0.35,
 | 
				
			||||||
 | 
					                    color: "#12f7f177", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0.75,
 | 
				
			||||||
 | 
					                    color: "#12f7f133", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "transparent", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            data: [], // this.series[0].data,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "", // this.series[1].name,
 | 
				
			||||||
 | 
					            type: "bar",
 | 
				
			||||||
 | 
					            barWidth: 12,
 | 
				
			||||||
 | 
					            // tooltip: {
 | 
				
			||||||
 | 
					            //   valueFormatter: function (value) {
 | 
				
			||||||
 | 
					            //     return value + " ml";
 | 
				
			||||||
 | 
					            //   },
 | 
				
			||||||
 | 
					            // },
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              borderRadius: [10, 10, 0, 0],
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#57abf8", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "#364BFE66", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            data: [], // this.series[1].data,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "", // "2024年目标值",
 | 
				
			||||||
 | 
					            type: "line",
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#f3c000",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              color: "#f3c000",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            areaStyle: {
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#f3c000", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0.55,
 | 
				
			||||||
 | 
					                    color: "#f3c00033",
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "transparent", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            data: [], // this.series[0].data,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    isOpen() {
 | 
				
			||||||
 | 
					      return this.$store.getters.sidebar.opened
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  watch: {
 | 
				
			||||||
 | 
					    isOpen(val) {
 | 
				
			||||||
 | 
					      this.canvasReset()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
				
			||||||
 | 
					    isFullscreen(val) {
 | 
				
			||||||
 | 
					      this.actualOptions.series.map((item) => {
 | 
				
			||||||
 | 
					        item.barWidth = val ? 18 : 12;
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					      this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // if (val === false && this.isOpen === true) {
 | 
				
			||||||
 | 
					      //   console.log(val)
 | 
				
			||||||
 | 
					      //   this.width = 97 + '%'
 | 
				
			||||||
 | 
					      //   this.canvasReset()
 | 
				
			||||||
 | 
					      // } else if (val === false && this.isOpen === false) {
 | 
				
			||||||
 | 
					      //   this.width = 100 + '%'
 | 
				
			||||||
 | 
					      //   this.canvasReset()
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      // this.actualOptions.series.map((item) => {
 | 
				
			||||||
 | 
					      //   item.barWidth = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // });
 | 
				
			||||||
 | 
					      // this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.initChart(this.actualOptions)
 | 
				
			||||||
 | 
					      // this.canvasReset()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    series(val) {
 | 
				
			||||||
 | 
					      if (!val) {
 | 
				
			||||||
 | 
					        this.initChart(this.options);
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      console.log(val)
 | 
				
			||||||
 | 
					      const actualOptions = JSON.parse(JSON.stringify(this.options))
 | 
				
			||||||
 | 
					      actualOptions.series[0].data = val[0].data;
 | 
				
			||||||
 | 
					      actualOptions.series[0].name = val[0].name;
 | 
				
			||||||
 | 
					      actualOptions.series[1].data = val?.[1]?.data || [];
 | 
				
			||||||
 | 
					      actualOptions.series[1].name = val?.[1]?.name || "";
 | 
				
			||||||
 | 
					      actualOptions.series[2].data = val?.[2]?.data || [];
 | 
				
			||||||
 | 
					      actualOptions.series[2].name = val?.[2]?.name || "";
 | 
				
			||||||
 | 
					      this.actualOptions = actualOptions;
 | 
				
			||||||
 | 
					      this.initChart(actualOptions);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    // if (screenfull.isEnabled) {
 | 
				
			||||||
 | 
					    //   screenfull.on("change", () => {
 | 
				
			||||||
 | 
					    //     this.isFullscreen = screenfull.isFullscreen;
 | 
				
			||||||
 | 
					    //   });
 | 
				
			||||||
 | 
					    // }
 | 
				
			||||||
 | 
					    // if (screenfull.isEnabled) {
 | 
				
			||||||
 | 
					    //   screenfull.on("change", () => {
 | 
				
			||||||
 | 
					    //     this.isFullscreen = screenfull.isFullscreen;
 | 
				
			||||||
 | 
					    //   });
 | 
				
			||||||
 | 
					    // }
 | 
				
			||||||
 | 
					    this.actualOptions = this.options
 | 
				
			||||||
 | 
					    this.canvasReset();
 | 
				
			||||||
 | 
					    window.addEventListener("resize", this.canvasReset);
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  beforeDestroy() {
 | 
				
			||||||
 | 
					    if (this.chart) {
 | 
				
			||||||
 | 
					      this.chart.dispose();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  destroyed() {
 | 
				
			||||||
 | 
					    window.removeEventListener("resize", this.canvasReset);
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    canvasReset() {
 | 
				
			||||||
 | 
					      debounce(() => {
 | 
				
			||||||
 | 
					        this.initChart();
 | 
				
			||||||
 | 
					      }, 500)();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    initChart() {
 | 
				
			||||||
 | 
					      if (this.chart) {
 | 
				
			||||||
 | 
					        this.chart.dispose();
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.chart = echarts.init(this.$refs.oeeChart);
 | 
				
			||||||
 | 
					      this.chart.setOption(this.actualOptions);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					.bar-chart-base {
 | 
				
			||||||
 | 
					  // position: relative;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend {
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    top: 5.2vh;
 | 
				
			||||||
 | 
					    right: 1vw;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item {
 | 
				
			||||||
 | 
					    position: relative;
 | 
				
			||||||
 | 
					    // font-size: 12px;
 | 
				
			||||||
 | 
					    margin-right:1.3vw;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    &::before {
 | 
				
			||||||
 | 
					      content: "";
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      width: 0.531vw;
 | 
				
			||||||
 | 
					      height: 0.531vw;
 | 
				
			||||||
 | 
					      background-color: #ccc;
 | 
				
			||||||
 | 
					      border-radius: 2px;
 | 
				
			||||||
 | 
					      margin-right: 0.22vw;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(1):before {
 | 
				
			||||||
 | 
					    background-color: #12f7f1;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(2):before {
 | 
				
			||||||
 | 
					    background-color: #58adfa;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					    .legend-item:nth-child(3):before {
 | 
				
			||||||
 | 
					      // width: 12px;
 | 
				
			||||||
 | 
					      // height: 2px;
 | 
				
			||||||
 | 
					      width: 1vw;
 | 
				
			||||||
 | 
					      height: 0.1064vw;
 | 
				
			||||||
 | 
					      background-color: #f3c000;
 | 
				
			||||||
 | 
					      position: absolute;
 | 
				
			||||||
 | 
					      top: 50%;
 | 
				
			||||||
 | 
					      // left: -16px;
 | 
				
			||||||
 | 
					      left: -0.951vw;
 | 
				
			||||||
 | 
					      transform: translateY(-50%);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .legend-item:nth-child(3):after {
 | 
				
			||||||
 | 
					      background-color: #f3c000;
 | 
				
			||||||
 | 
					      content: "";
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      position: absolute;
 | 
				
			||||||
 | 
					      // width: 6px;
 | 
				
			||||||
 | 
					      // height: 6px;
 | 
				
			||||||
 | 
					      width: 0.3191vw;
 | 
				
			||||||
 | 
					      height: 0.3191vw;
 | 
				
			||||||
 | 
					      border-radius: 100%;
 | 
				
			||||||
 | 
					      top: 50%;
 | 
				
			||||||
 | 
					      left: -0.851vw;
 | 
				
			||||||
 | 
					      // left: -16px;
 | 
				
			||||||
 | 
					      transform: translateY(-50%) translateX(50%);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
@@ -13,7 +13,7 @@
 | 
				
			|||||||
    <!-- <div style="flex:1;padding: 0 20%;"> -->
 | 
					    <!-- <div style="flex:1;padding: 0 20%;"> -->
 | 
				
			||||||
    <div class="chart" ref="chart"></div>
 | 
					    <div class="chart" ref="chart"></div>
 | 
				
			||||||
    <!-- </div> -->
 | 
					    <!-- </div> -->
 | 
				
			||||||
    <div class="legend" v-if="period == '月' || period == '年'">
 | 
					    <div class="legend" >
 | 
				
			||||||
      <div class="legend-item" v-for="lgd in legend" :key="lgd.label">
 | 
					      <div class="legend-item" v-for="lgd in legend" :key="lgd.label">
 | 
				
			||||||
        <span class="legend-item__value">{{ lgd.value }}</span>
 | 
					        <span class="legend-item__value">{{ lgd.value }}</span>
 | 
				
			||||||
        <span class="legend-item__label">{{ lgd.label }}</span>
 | 
					        <span class="legend-item__label">{{ lgd.label }}</span>
 | 
				
			||||||
@@ -46,6 +46,10 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: '同比',
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
@@ -103,21 +107,72 @@ export default {
 | 
				
			|||||||
      return t;
 | 
					      return t;
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    legend() {
 | 
					    legend() {
 | 
				
			||||||
      const year = new Date().getFullYear();
 | 
					      let items = [];
 | 
				
			||||||
 | 
					      var day1 = new Date();
 | 
				
			||||||
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					      var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
 | 
					      //今天的时间
 | 
				
			||||||
 | 
					      // var day2 = new Date();
 | 
				
			||||||
 | 
					      // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					      // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
 | 
					      // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
      const month = new Date().getMonth() + 1;
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
      return [
 | 
					      const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
        {
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
          label:
 | 
					      if (this.period === '日' && this.than === '同比') {
 | 
				
			||||||
            this.period == "月"
 | 
					        items = [
 | 
				
			||||||
              ? `${year - 1}年${month}月良率`
 | 
					          { label: `${month}月${today}日良率`, value: isNaN(this.valueTuple[1]) || this.valueTuple[1] == null ? 0 + "%" : (this.valueTuple[1]) + "%" },
 | 
				
			||||||
              : `${year - 1}年良率`,
 | 
					          { label: `去年${month}月${today}日良率`, value: isNaN(this.valueTuple[0]) || this.valueTuple[0] == null ? 0 + "%" : (this.valueTuple[0]) + "%" },
 | 
				
			||||||
          value: isNaN((this.valueTuple[0] * 100).toFixed(0)) ? 0 + "%" : (this.valueTuple[0] * 100).toFixed(0) + "%"
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          label: this.period == "月" ? `${month}月良率` : `${year}年良率`,
 | 
					 | 
				
			||||||
          value: isNaN((this.valueTuple[1] * 100).toFixed(0)) ? 0 + "%" : (this.valueTuple[1] * 100).toFixed(0) + "%"
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        ];
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '日' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日良率`, value: isNaN(this.valueTuple[1]) || this.valueTuple[1] == null ? 0 + "%" : (this.valueTuple[1]) + "%" },
 | 
				
			||||||
 | 
					          { label: `${yesterday}日良率`, value: isNaN(this.valueTuple[0]) || this.valueTuple[0] == null ? 0 + "%" : (this.valueTuple[0]) + "%" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `本周良率`, value: isNaN(this.valueTuple[1]) || this.valueTuple[1] == null ? 0 + "%" : (this.valueTuple[1]) + "%" },
 | 
				
			||||||
 | 
					          { label: `去年本周良率`, value: isNaN(this.valueTuple[0]) || this.valueTuple[0] == null ? 0 + "%" : (this.valueTuple[0]) + "%" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `本周良率`, value: isNaN(this.valueTuple[1]) || this.valueTuple[1] == null ? 0 + "%" : (this.valueTuple[1]) + "%" },
 | 
				
			||||||
 | 
					          { label: `上周良率`, value: isNaN(this.valueTuple[0]) || this.valueTuple[0] == null ? 0 + "%" : (this.valueTuple[0]) + "%" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${month}月良率`, value: isNaN(this.valueTuple[1]) || this.valueTuple[1] == null ? 0 + "%" : (this.valueTuple[1]) + "%" },
 | 
				
			||||||
 | 
					          { label: `去年${month}月良率`, value: isNaN(this.valueTuple[0]) || this.valueTuple[0] == null ? 0 + "%" : (this.valueTuple[0]) + "%" },
 | 
				
			||||||
 | 
					          { label: `${month}月目标良率`, value: isNaN(this.valueTuple[2]) || this.valueTuple[2] == null ? 0 + "%" : (this.valueTuple[2]) + "%" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${month}月良率`, value: isNaN(this.valueTuple[1]) || this.valueTuple[1] == null ? 0 + "%" : (this.valueTuple[1]) + "%" },
 | 
				
			||||||
 | 
					          { label: `${lastMonth}月良率`, value: isNaN(this.valueTuple[0]) || this.valueTuple[0] == null ? 0 + "%" : (this.valueTuple[0]) + "%" },
 | 
				
			||||||
 | 
					          { label: `${month}月目标良率`, value: isNaN(this.valueTuple[2]) || this.valueTuple[2] == null ? 0 + "%" : (this.valueTuple[2]) + "%" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${year}年良率`, value: isNaN(this.valueTuple[1]) || this.valueTuple[1] == null ? 0 + "%" : (this.valueTuple[1]) + "%" },
 | 
				
			||||||
 | 
					          { label: `${year - 1}年良率`, value: isNaN(this.valueTuple[0]) || this.valueTuple[0] == null  ? 0 + "%" : (this.valueTuple[0]) + "%" },
 | 
				
			||||||
 | 
					          { label: `${year}年目标良率`, value: isNaN(this.valueTuple[2]) || this.valueTuple[2] == null ? 0 + "%" : (this.valueTuple[2]) + "%" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      return items
 | 
				
			||||||
 | 
					      // [
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     label:
 | 
				
			||||||
 | 
					      //       this.period == "月"
 | 
				
			||||||
 | 
					      //         ? `${year - 1}年${month}月良率`
 | 
				
			||||||
 | 
					      //         : `${year - 1}年良率`,
 | 
				
			||||||
 | 
					      //     value: isNaN((this.valueTuple[0] * 100).toFixed(0)) ? 0 + "%" : (this.valueTuple[0] * 100).toFixed(0) + "%"
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     label: this.period == "月" ? `${month}月良率` : `${year}年良率`,
 | 
				
			||||||
 | 
					      //     value: isNaN((this.valueTuple[1] * 100).toFixed(0)) ? 0 + "%" : (this.valueTuple[1] * 100).toFixed(0) + "%"
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      // ];
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  mounted() {
 | 
					  mounted() {
 | 
				
			||||||
@@ -163,7 +218,9 @@ export default {
 | 
				
			|||||||
      // width: 290px;
 | 
					      // width: 290px;
 | 
				
			||||||
      align-self: stretch;
 | 
					      align-self: stretch;
 | 
				
			||||||
      // flex: 1 1 auto;
 | 
					      // flex: 1 1 auto;
 | 
				
			||||||
      // padding: 0 10%;
 | 
					    // align-items: center;
 | 
				
			||||||
 | 
					      // margin:0 auto;
 | 
				
			||||||
 | 
					      // padding: 0 10%;;
 | 
				
			||||||
      /* margin: 10%; */
 | 
					      /* margin: 10%; */
 | 
				
			||||||
      /* min-width: 300px; */
 | 
					      /* min-width: 300px; */
 | 
				
			||||||
      height: 200px;
 | 
					      height: 200px;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -6,7 +6,7 @@
 | 
				
			|||||||
-->
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="progress-bar" :data-title="titleYear" :data-rate="number">
 | 
					  <div class="progress-bar" :data-title="title" :data-rate="value + '%'">
 | 
				
			||||||
    <div class="progress-bar__rate" :style="{ width: dataRate == '-' ? 0 : dataRate }"></div>
 | 
					    <div class="progress-bar__rate" :style="{ width: dataRate == '-' ? 0 : dataRate }"></div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
@@ -20,52 +20,25 @@ export default {
 | 
				
			|||||||
      type: Number,
 | 
					      type: Number,
 | 
				
			||||||
      default: 0,
 | 
					      default: 0,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    target: {
 | 
					    // total: {
 | 
				
			||||||
      type: Number,
 | 
					    //   type: Number,
 | 
				
			||||||
      default: 0,
 | 
					    //   default: 0,
 | 
				
			||||||
    },
 | 
					    // },
 | 
				
			||||||
    goodNumber: {
 | 
					 | 
				
			||||||
      type: Number,
 | 
					 | 
				
			||||||
      default:0
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    componentYield: {
 | 
					 | 
				
			||||||
      type: Number,
 | 
					 | 
				
			||||||
      default:0
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    period: {
 | 
					 | 
				
			||||||
      type: String,
 | 
					 | 
				
			||||||
      default:'日',
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    title: {
 | 
					    title: {
 | 
				
			||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "",
 | 
					      default: "",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    city: {
 | 
					 | 
				
			||||||
      type: String,
 | 
					 | 
				
			||||||
      default:""
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {};
 | 
				
			||||||
      number: 0,
 | 
					 | 
				
			||||||
      titleYear:'',
 | 
					 | 
				
			||||||
    };
 | 
					 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    dataRate() {
 | 
					    dataRate() {
 | 
				
			||||||
      if ((this.period === '年' || this.period === '月') && this.target != 0) {
 | 
					 | 
				
			||||||
        // console.log(this.componentYield)
 | 
					 | 
				
			||||||
        this.titleYear = this.title + '  ' + `${(this.target * 100).toFixed(0)}%`
 | 
					 | 
				
			||||||
      } else {
 | 
					 | 
				
			||||||
        this.titleYear = this.title
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      this.number = this.value == 0
 | 
					 | 
				
			||||||
        ? "-"
 | 
					 | 
				
			||||||
        : `${(this.value * 100).toFixed(0)}%`
 | 
					 | 
				
			||||||
      // console.log(this.period)
 | 
					 | 
				
			||||||
      return this.value == 0
 | 
					      return this.value == 0
 | 
				
			||||||
        ? "-"
 | 
					        ? "-"
 | 
				
			||||||
        : this.value >1 ? 100 + '%' :`${(this.value * 100).toFixed(0)}%`
 | 
					        : this.value > 1
 | 
				
			||||||
 | 
					          ?  100 + '%'
 | 
				
			||||||
 | 
					          : `${(parseFloat(this.value)).toFixed(0)}%`;
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {},
 | 
					  methods: {},
 | 
				
			||||||
@@ -95,7 +68,7 @@ export default {
 | 
				
			|||||||
    color: #fff;
 | 
					    color: #fff;
 | 
				
			||||||
    position: absolute;
 | 
					    position: absolute;
 | 
				
			||||||
    bottom: -200%;
 | 
					    bottom: -200%;
 | 
				
			||||||
    right: 10px;
 | 
					    right: 0;
 | 
				
			||||||
    font-size: 12px;
 | 
					    font-size: 12px;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -104,6 +77,7 @@ export default {
 | 
				
			|||||||
      color: #11eae3;
 | 
					      color: #11eae3;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  &:nth-child(2) {
 | 
					  &:nth-child(2) {
 | 
				
			||||||
    &:after {
 | 
					    &:after {
 | 
				
			||||||
      color: #0e65fd;
 | 
					      color: #0e65fd;
 | 
				
			||||||
@@ -116,17 +90,20 @@ export default {
 | 
				
			|||||||
    height: 100%;
 | 
					    height: 100%;
 | 
				
			||||||
    width: 0;
 | 
					    width: 0;
 | 
				
			||||||
    border-radius: 4px;
 | 
					    border-radius: 4px;
 | 
				
			||||||
 | 
					     background: linear-gradient(to right,
 | 
				
			||||||
 | 
					          #004c5e11 10%,
 | 
				
			||||||
 | 
					          #004c5e,
 | 
				
			||||||
 | 
					          #0ac0c0,
 | 
				
			||||||
 | 
					          #11eae3);
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  &:first-child {
 | 
					  &:first-child {
 | 
				
			||||||
    .progress-bar__rate {
 | 
					    .progress-bar__rate {
 | 
				
			||||||
      background: linear-gradient(
 | 
					      background: linear-gradient(to right,
 | 
				
			||||||
        to right,
 | 
					 | 
				
			||||||
          #004c5e11 10%,
 | 
					          #004c5e11 10%,
 | 
				
			||||||
          #004c5e,
 | 
					          #004c5e,
 | 
				
			||||||
          #0ac0c0,
 | 
					          #0ac0c0,
 | 
				
			||||||
        #11eae3
 | 
					          #11eae3);
 | 
				
			||||||
      );
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,7 +1,7 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2024-05-07 10:25:10
 | 
					 * @Date: 2024-05-07 10:25:10
 | 
				
			||||||
 * @LastEditTime: 2024-05-20 09:46:19
 | 
					 * @LastEditTime: 2024-05-29 17:03:00
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
@@ -11,28 +11,30 @@
 | 
				
			|||||||
    <CityName :value="city.name" />
 | 
					    <CityName :value="city.name" />
 | 
				
			||||||
    <div class="std-rate-item__value">
 | 
					    <div class="std-rate-item__value">
 | 
				
			||||||
      <ProgressBar :period="period" :title="title" :value="city.current" />
 | 
					      <ProgressBar :period="period" :title="title" :value="city.current" />
 | 
				
			||||||
      <!-- <ProgressBar title="24年累计" :total="city.target" :value="city.thisYear" /> -->
 | 
					      <ProgressBar :period="period" :title="titlePre" :value="city.previous" />
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
  <div v-else-if="period == '周'" class="std-rate-item">
 | 
					  <div v-else-if="period == '周'" class="std-rate-item">
 | 
				
			||||||
    <CityName :value="city.name" />
 | 
					    <CityName :value="city.name" />
 | 
				
			||||||
    <div class="std-rate-item__value">
 | 
					    <div class="std-rate-item__value">
 | 
				
			||||||
      <ProgressBar :period="period" :title="title" :value="city.current" />
 | 
					      <ProgressBar :period="period" :title="title" :value="city.current" />
 | 
				
			||||||
      <!-- <ProgressBar title="24年累计" :total="city.target" :value="city.thisYear" /> -->
 | 
					      <ProgressBar :period="period" :title="titlePre" :value="city.previous" />
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
  <div v-else-if="period == '月'" class="std-rate-item">
 | 
					  <div v-else-if="period == '月'" class="std-rate-item">
 | 
				
			||||||
    <CityName :value="city.name" />
 | 
					    <CityName :value="city.name" />
 | 
				
			||||||
    <div class="std-rate-item__value">
 | 
					    <div class="std-rate-item__value">
 | 
				
			||||||
      <ProgressBar :period="period" :title="titleEnd" :target="city.target" :value="city.current" />
 | 
					      <ProgressBar :period="period" :title="titleTarget" :value="city.target" />
 | 
				
			||||||
      <ProgressBar :period="period" :title="title" :value="city.previous" />
 | 
					      <ProgressBar :period="period" :title="titlePre" :value="city.previous" />
 | 
				
			||||||
 | 
					      <ProgressBar :period="period" :title="title" :value="city.current" />
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
  <div v-else="period == '年'" class="std-rate-item">
 | 
					  <div v-else="period == '年'" class="std-rate-item">
 | 
				
			||||||
    <CityName :value="city.name" />
 | 
					    <CityName :value="city.name" />
 | 
				
			||||||
    <div class="std-rate-item__value">
 | 
					    <div class="std-rate-item__value">
 | 
				
			||||||
      <ProgressBar :period="period" :title="titleEnd" :target="city.target" :value="city.current" />
 | 
					      <ProgressBar :period="period" :title="titleTarget" :value="city.target" />
 | 
				
			||||||
      <ProgressBar :period="period" :title="title" :value="city.previous" />
 | 
					      <ProgressBar :period="period" :title="titlePre" :value="city.previous" />
 | 
				
			||||||
 | 
					      <ProgressBar :period="period" :title="title" :value="city.current" />
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
@@ -52,7 +54,11 @@ export default {
 | 
				
			|||||||
    period: {
 | 
					    period: {
 | 
				
			||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    }
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
@@ -60,45 +66,66 @@ export default {
 | 
				
			|||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    title() {
 | 
					    titlePre() {
 | 
				
			||||||
      switch (this.period) {
 | 
					      console.log(this.city);
 | 
				
			||||||
        case "日":
 | 
					      var day1 = new Date();
 | 
				
			||||||
          return "今日"
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
        case "周":
 | 
					      var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
          return  "本周"
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
        case "月":
 | 
					 | 
				
			||||||
          const year = new Date().getFullYear();
 | 
					 | 
				
			||||||
      const month = new Date().getMonth() + 1;
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
          return `${year - 1}年${month}月累计`
 | 
					      const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
        case "年": {
 | 
					 | 
				
			||||||
      const year = new Date().getFullYear();
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
          // return [
 | 
					      if (this.period === '日' && this.than === '同比') {
 | 
				
			||||||
           return `${year - 1}年累计`
 | 
					        return `去年${month}月${today}日`
 | 
				
			||||||
          // ];
 | 
					      } else if (this.period === '日' && this.than === '环比') {
 | 
				
			||||||
        }
 | 
					        return `${yesterday}日`
 | 
				
			||||||
        default:
 | 
					      } else if (this.period === '周' && this.than === '同比') {
 | 
				
			||||||
         return "今日"
 | 
					        return `去年本周`
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '环比') {
 | 
				
			||||||
 | 
					        return `上周`
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '同比') {
 | 
				
			||||||
 | 
					        return `去年${month}月`
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '环比') {
 | 
				
			||||||
 | 
					        return `${lastMonth}月`
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        return `${year - 1}年`
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    titleEnd() {
 | 
					    title() {
 | 
				
			||||||
      switch (this.period) {
 | 
					      var day1 = new Date();
 | 
				
			||||||
        // case "日":
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
        //   return "今日"
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
        // case "周":
 | 
					 | 
				
			||||||
        //   return "本周"
 | 
					 | 
				
			||||||
        case "月":
 | 
					 | 
				
			||||||
          const year = new Date().getFullYear();
 | 
					 | 
				
			||||||
      const month = new Date().getMonth() + 1;
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
          return  `${year}年${month}月目标`
 | 
					 | 
				
			||||||
        case "年": {
 | 
					 | 
				
			||||||
      const year = new Date().getFullYear();
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
          // return [
 | 
					      if (this.period === '日' && this.than === '同比') {
 | 
				
			||||||
 | 
					        return `${month}月${today}日`
 | 
				
			||||||
 | 
					      } else if (this.period === '日' && this.than === '环比') {
 | 
				
			||||||
 | 
					        return `${month}月${today}日`
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '同比') {
 | 
				
			||||||
 | 
					        return `本周`
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '环比') {
 | 
				
			||||||
 | 
					        return `本周`
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '同比') {
 | 
				
			||||||
 | 
					        return `${month}月`
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '环比') {
 | 
				
			||||||
 | 
					        return `${month}月`
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        return `${year}年`
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    titleTarget() {
 | 
				
			||||||
 | 
					      var day1 = new Date();
 | 
				
			||||||
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      if (this.period === '月') {
 | 
				
			||||||
 | 
					        return `${month}月目标`
 | 
				
			||||||
 | 
					      } else if (this.period === '年') {
 | 
				
			||||||
        return `${year}年目标`
 | 
					        return `${year}年目标`
 | 
				
			||||||
          // ];
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,7 +1,7 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2024-05-07 10:04:53
 | 
					 * @Date: 2024-05-07 10:04:53
 | 
				
			||||||
 * @LastEditTime: 2024-05-17 17:05:36
 | 
					 * @LastEditTime: 2024-05-30 11:13:01
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
@@ -9,16 +9,16 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="efficiency-copilot">
 | 
					  <div class="efficiency-copilot">
 | 
				
			||||||
    <Container title="芯片良率" icon="chip2">
 | 
					    <Container title="芯片良率" icon="chip2">
 | 
				
			||||||
      <ChipRate :period="period" />
 | 
					      <ChipRate :period="period" :than="than" />
 | 
				
			||||||
    </Container>
 | 
					    </Container>
 | 
				
			||||||
    <Container title="标准组件良率" icon="std">
 | 
					    <Container title="标准组件良率" icon="std">
 | 
				
			||||||
      <StdRate :period="period" />
 | 
					      <StdRate :period="period" :than="than" />
 | 
				
			||||||
    </Container>
 | 
					    </Container>
 | 
				
			||||||
    <Container title="芯片OEE" icon="chip">
 | 
					    <Container title="芯片OEE" icon="chip">
 | 
				
			||||||
      <ChipOee :period="period" />
 | 
					      <ChipOee :chipOeeRate="chipOeeRate" :period="period" :than="than" />
 | 
				
			||||||
    </Container>
 | 
					    </Container>
 | 
				
			||||||
    <Container title="转化效率" icon="cube">
 | 
					    <Container title="转化效率" icon="cube">
 | 
				
			||||||
      <TransformRate :period="period" />
 | 
					      <TransformRate :transformRate="transformRate" :period="period" :than="than" />
 | 
				
			||||||
    </Container>
 | 
					    </Container>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
@@ -44,25 +44,45 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {};
 | 
					    return {
 | 
				
			||||||
 | 
					      chipOeeRate: {},
 | 
				
			||||||
 | 
					      transformRate:{}
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  watch: {
 | 
					  watch: {
 | 
				
			||||||
    period: {
 | 
					    period: {
 | 
				
			||||||
      handler(val) {
 | 
					      handler(val) {
 | 
				
			||||||
        val && this.fetchData(val);
 | 
					        val && this.fetchData(val,this.than);
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      immediate: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      handler(val) {
 | 
				
			||||||
 | 
					        console.log(val)
 | 
				
			||||||
 | 
					        val && this.fetchData(this.period, val);
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      immediate: true,
 | 
					      immediate: true,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    fetchData(period = "日") {
 | 
					    fetchData(period = "日",than) {
 | 
				
			||||||
      console.log(`效率驾驶舱,获取${period}数据`);
 | 
					      console.log(`效率驾驶舱,获取${period}数据`);
 | 
				
			||||||
      this.$store.dispatch("copilot/initCopilot", {
 | 
					      this.$store.dispatch("copilot/initCopilot", {
 | 
				
			||||||
        period,
 | 
					        period,
 | 
				
			||||||
        source: "efficiency",
 | 
					        source: "efficiency",
 | 
				
			||||||
      });
 | 
					        than
 | 
				
			||||||
 | 
					      }).then(() => {
 | 
				
			||||||
 | 
					        this.$nextTick(() => {
 | 
				
			||||||
 | 
					          this.chipOeeRate = this.$store.getters.copilot.efficiency.chipOeeRate
 | 
				
			||||||
 | 
					          this.transformRate = this.$store.getters.copilot.efficiency.transformRate
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -6,7 +6,7 @@ export default ({
 | 
				
			|||||||
  targetSum,
 | 
					  targetSum,
 | 
				
			||||||
}) => ({
 | 
					}) => ({
 | 
				
			||||||
  grid: {
 | 
					  grid: {
 | 
				
			||||||
    left: 0,
 | 
					    left: '50%',
 | 
				
			||||||
    right: 0,
 | 
					    right: 0,
 | 
				
			||||||
    bottom: 0,
 | 
					    bottom: 0,
 | 
				
			||||||
    top: 0,
 | 
					    top: 0,
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										131
									
								
								src/views/copilot/efficiencyContainer.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,131 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2024-05-20 16:04:18
 | 
				
			||||||
 | 
					 * @LastEditTime: 2024-05-30 11:14:17
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <!-- <div class="copilot-layout" ref="copilot-layout"> -->
 | 
				
			||||||
 | 
					  <div class="copilot-layout other" ref="copilot-layout">
 | 
				
			||||||
 | 
					    <CopilotHeaderVue :than="than" :active="page" :period="period" @update:active="updateActive"
 | 
				
			||||||
 | 
					      @update:period="period = $event" @update:than="updateThan" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <!-- <YieldCopilot v-if="page == '产量'" :period="period" /> -->
 | 
				
			||||||
 | 
					    <!-- <EnergyCopilot v-if="page == '综合'" :period="period" /> -->
 | 
				
			||||||
 | 
					    <EfficiencyCopilot :period="period"  :than="than" />
 | 
				
			||||||
 | 
					    <div class="copilot-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import CopilotHeaderVue from "./components/CopilotHeader.vue";
 | 
				
			||||||
 | 
					// import YieldCopilot from "./yield/index.vue";
 | 
				
			||||||
 | 
					// import EnergyCopilot from "./energy/index.vue";
 | 
				
			||||||
 | 
					import EfficiencyCopilot from "./efficiency/index.vue";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "CopilotContainer",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    CopilotHeaderVue,
 | 
				
			||||||
 | 
					    EfficiencyCopilot,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      than:'同比',
 | 
				
			||||||
 | 
					      page: "效率",
 | 
				
			||||||
 | 
					      period: "日",
 | 
				
			||||||
 | 
					      currentsStyles: '',
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    updateThan(val) {
 | 
				
			||||||
 | 
					      console.log(val);
 | 
				
			||||||
 | 
					      this.than = val;
 | 
				
			||||||
 | 
					      // this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updateActive(val, oldVal) {
 | 
				
			||||||
 | 
					      console.log(val)
 | 
				
			||||||
 | 
					      if (val === '效率') {
 | 
				
			||||||
 | 
					        this.$router.push({
 | 
				
			||||||
 | 
					          path: 'efficiency-container',
 | 
				
			||||||
 | 
					          query: {
 | 
				
			||||||
 | 
					            name: '效率'
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        // this.page = oldVal
 | 
				
			||||||
 | 
					      } else if (val === '产量') {
 | 
				
			||||||
 | 
					        this.$router.push({
 | 
				
			||||||
 | 
					          path: 'main',
 | 
				
			||||||
 | 
					          query: {
 | 
				
			||||||
 | 
					            name: '产量'
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        // this.page = oldVal
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  // mounted() {
 | 
				
			||||||
 | 
					  //   this.page = this.$route.query.name
 | 
				
			||||||
 | 
					  // },
 | 
				
			||||||
 | 
					  // watch: {
 | 
				
			||||||
 | 
					  //   page(val) {
 | 
				
			||||||
 | 
					  //     if (val === '产量') {
 | 
				
			||||||
 | 
					  //       console.log(val)
 | 
				
			||||||
 | 
					  //       this.currentsStyles =
 | 
				
			||||||
 | 
					  //         'height: calc(100% + 38px)'
 | 
				
			||||||
 | 
					  //       console.log(this.currentsStyles)
 | 
				
			||||||
 | 
					  //     } else {
 | 
				
			||||||
 | 
					  //       console.log(val)
 | 
				
			||||||
 | 
					  //       this.currentsStyles = 'height:100%+38px'
 | 
				
			||||||
 | 
					  //       console.log(this.currentsStyles)
 | 
				
			||||||
 | 
					  //     }
 | 
				
			||||||
 | 
					  //     immediate: true
 | 
				
			||||||
 | 
					  //   }
 | 
				
			||||||
 | 
					  // }
 | 
				
			||||||
 | 
					  // mounted() {
 | 
				
			||||||
 | 
					  //   document.body.style.minHeight = "1024px";
 | 
				
			||||||
 | 
					  //   document.body.style.minWidth = "1550px";
 | 
				
			||||||
 | 
					  // },
 | 
				
			||||||
 | 
					  // destroyed() {
 | 
				
			||||||
 | 
					  //   document.body.style.minHeight = "1024px";
 | 
				
			||||||
 | 
					  //   document.body.style.minWidth = "1550px";
 | 
				
			||||||
 | 
					  // },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.copilot-layout {
 | 
				
			||||||
 | 
					  padding: 16px;
 | 
				
			||||||
 | 
					  background: url(../../assets/images/copilot-bg.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: -16px;
 | 
				
			||||||
 | 
					  /* top: -8px; */
 | 
				
			||||||
 | 
					  /* height: calc(100% + 38px); */
 | 
				
			||||||
 | 
					  width: calc(100% + 30px);
 | 
				
			||||||
 | 
					  z-index: 1001;
 | 
				
			||||||
 | 
					  color: #fff;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  gap: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.produce{
 | 
				
			||||||
 | 
					  height: calc(100% + 38px);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.other {
 | 
				
			||||||
 | 
					  height: calc(100% + 240px);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.copilot-footer {
 | 
				
			||||||
 | 
					  /** position: absolute;
 | 
				
			||||||
 | 
					  bottom: 10px; **/
 | 
				
			||||||
 | 
					  height: 10px;
 | 
				
			||||||
 | 
					  width: 100%;
 | 
				
			||||||
 | 
					  color: rgb(80, 80, 80);
 | 
				
			||||||
 | 
					  user-select: none;
 | 
				
			||||||
 | 
					  font-size: 14px;
 | 
				
			||||||
 | 
					  letter-spacing: 1px;
 | 
				
			||||||
 | 
					  display: grid;
 | 
				
			||||||
 | 
					  place-content: center;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										216
									
								
								src/views/copilot/factoryData/bbIndex.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,216 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="factory-layout">
 | 
				
			||||||
 | 
					    <FactoryDataHeader :than="than" :companyName="companyName" :companyId="companyId" :period="period"
 | 
				
			||||||
 | 
					      @update:than="updateThan" @update:period="updatePeriod" />
 | 
				
			||||||
 | 
					    <div class="factory-section">
 | 
				
			||||||
 | 
					      <section class="top flex">
 | 
				
			||||||
 | 
					        <db-container title="生产监控" icon="prod">
 | 
				
			||||||
 | 
					          <prod-monitor :companyId="companyId" :factoryData="factoryData" :than="than" :period="period" :data="data"
 | 
				
			||||||
 | 
					            :prodOutPut="prodOutPut" :prodFto="prodFto" :showBipv="show" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <db-container title="工单监控" icon="order">
 | 
				
			||||||
 | 
					          <order :prodOrder="prodOrder" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <!-- <db-container title="" icon="store"> -->
 | 
				
			||||||
 | 
					        <!-- <store :stock="stock" /> -->
 | 
				
			||||||
 | 
					        <!-- </db-container> -->
 | 
				
			||||||
 | 
					      </section>
 | 
				
			||||||
 | 
					      <!-- <section class="bottom flex"> -->
 | 
				
			||||||
 | 
					      <!-- <db-container title="" icon="energy"> -->
 | 
				
			||||||
 | 
					      <!-- <energy :legend="energyLegend" :energyCockpits="energyCockpits" /> -->
 | 
				
			||||||
 | 
					      <!-- </db-container> -->
 | 
				
			||||||
 | 
					      <!-- </section> -->
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="factory-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import FactoryDataHeader from "./../components/FactoryDataHeader.vue";
 | 
				
			||||||
 | 
					import Container from "./components/Container.vue";
 | 
				
			||||||
 | 
					import ProdMonitor from "./components/ProdMonitor.vue";
 | 
				
			||||||
 | 
					import { deepClone } from "@/utils";
 | 
				
			||||||
 | 
					// import Store from "./components/Store.vue";
 | 
				
			||||||
 | 
					// import Energy from "./components/Energy.vue";
 | 
				
			||||||
 | 
					import Order from "./components/Order.vue";
 | 
				
			||||||
 | 
					import { cockpitDataMonitor } from "@/api/produceData";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "factoryData",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    FactoryDataHeader,
 | 
				
			||||||
 | 
					    DbContainer: Container,
 | 
				
			||||||
 | 
					    ProdMonitor,
 | 
				
			||||||
 | 
					    // Store,
 | 
				
			||||||
 | 
					    // Energy,
 | 
				
			||||||
 | 
					    Order,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      companyId: 6,
 | 
				
			||||||
 | 
					      companyName: "蚌埠中建材光电材料有限公司",
 | 
				
			||||||
 | 
					      period: 1,
 | 
				
			||||||
 | 
					      show: false,
 | 
				
			||||||
 | 
					      than: '同比',
 | 
				
			||||||
 | 
					      data: {},
 | 
				
			||||||
 | 
					      // 接口获取的数据
 | 
				
			||||||
 | 
					      prodOutPut: [], //生产
 | 
				
			||||||
 | 
					      prodFto: [], //生产
 | 
				
			||||||
 | 
					      stock: {}, //仓库
 | 
				
			||||||
 | 
					      factoryData: {
 | 
				
			||||||
 | 
					        preDataDetail: [],
 | 
				
			||||||
 | 
					        currentDataDetail: {},
 | 
				
			||||||
 | 
					        targetDataDetail: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      energyCockpits: [], //能源
 | 
				
			||||||
 | 
					      prodOrder: [], //订单
 | 
				
			||||||
 | 
					      energyLegend: [
 | 
				
			||||||
 | 
					        { label: "电", color: "#FFD160" },
 | 
				
			||||||
 | 
					        { label: "水", color: "#2760FF" },
 | 
				
			||||||
 | 
					        { label: "气", color: "#12FFF5" },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.getMes();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    updateCompany(obj) {
 | 
				
			||||||
 | 
					      this.companyId = obj.companyId;
 | 
				
			||||||
 | 
					      this.companyName = obj.companyName;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updateThan(val) {
 | 
				
			||||||
 | 
					      console.log(val);
 | 
				
			||||||
 | 
					      this.than = val;
 | 
				
			||||||
 | 
					      // this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updatePeriod(val) {
 | 
				
			||||||
 | 
					      this.period = val;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getMes() {
 | 
				
			||||||
 | 
					      cockpitDataMonitor({
 | 
				
			||||||
 | 
					        factorys: [this.companyId],
 | 
				
			||||||
 | 
					        date: this.period,
 | 
				
			||||||
 | 
					        mode: this.than === '同比' ? 0 : 1
 | 
				
			||||||
 | 
					      }).then((res) => {
 | 
				
			||||||
 | 
					        console.log(res);
 | 
				
			||||||
 | 
					        this.prodOutPut = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        this.prodFto = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        this.prodOrder = res.data.prodWorkOrderDO || [];
 | 
				
			||||||
 | 
					        let prodOutputFtoListRes = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preFtoData = res.data.previousProdOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preData = res.data.previousProdOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let factoryListResponse = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let targetListResponse = res.data.prodTargetMonitorDO || [];
 | 
				
			||||||
 | 
					        let preDataDetail = []
 | 
				
			||||||
 | 
					        let currentDataDetail = []
 | 
				
			||||||
 | 
					        let targetDataDetail = []
 | 
				
			||||||
 | 
					        if (prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					          for (const factory of prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            currentDataDetail[0] = factory.chipInput
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preFtoData) {
 | 
				
			||||||
 | 
					          for (const factory of preFtoData) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            // const fId = this.getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // if (fId) {
 | 
				
			||||||
 | 
					            preDataDetail[0] = factory.previousYearChipInput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					            // if (preFId) {
 | 
				
			||||||
 | 
					            // ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preData && preData[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of preData) {
 | 
				
			||||||
 | 
					            if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					              preDataDetail[1] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					              preDataDetail[2] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousYearOutputNumber === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (targetListResponse && targetListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of targetListResponse) {
 | 
				
			||||||
 | 
					            targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            // if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					            targetDataDetail[1] = factory.chipYield
 | 
				
			||||||
 | 
					            // } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					            targetDataDetail[2] = factory.componentYield
 | 
				
			||||||
 | 
					            targetDataDetail[3] = factory.bipvProductoutput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // console.log('ftoInvest',ftoInvest)
 | 
				
			||||||
 | 
					        if (factoryListResponse && factoryListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of factoryListResponse) {
 | 
				
			||||||
 | 
					            // targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            if (factory.glassType === 0) {
 | 
				
			||||||
 | 
					              currentDataDetail[1] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 1) {
 | 
				
			||||||
 | 
					              currentDataDetail[2] = factory.outputNumber
 | 
				
			||||||
 | 
					            }else if (factory.glassType === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.factoryData.preDataDetail = preDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.currentDataDetail = currentDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.targetDataDetail = targetDataDetail
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.factory-layout {
 | 
				
			||||||
 | 
					  padding: 16px;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/copilot-bg.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  height: calc(100% + 38px);
 | 
				
			||||||
 | 
					  left: -16px;
 | 
				
			||||||
 | 
					  top: -8px;
 | 
				
			||||||
 | 
					  width: calc(100% + 30px);
 | 
				
			||||||
 | 
					  z-index: 1001;
 | 
				
			||||||
 | 
					  color: #fff;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  gap: 8px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-section {
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					    display: flex;
 | 
				
			||||||
 | 
					    flex-direction: column;
 | 
				
			||||||
 | 
					    gap: 16px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .flex {
 | 
				
			||||||
 | 
					      display: flex;
 | 
				
			||||||
 | 
					      gap: 16px;
 | 
				
			||||||
 | 
					      flex: 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .top>div,
 | 
				
			||||||
 | 
					    .bottom>div {
 | 
				
			||||||
 | 
					      height: 100%;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-footer {
 | 
				
			||||||
 | 
					    /** position: absolute;
 | 
				
			||||||
 | 
					  bottom: 10px; **/
 | 
				
			||||||
 | 
					    height: 10px;
 | 
				
			||||||
 | 
					    width: 100%;
 | 
				
			||||||
 | 
					    color: rgb(80, 80, 80);
 | 
				
			||||||
 | 
					    user-select: none;
 | 
				
			||||||
 | 
					    font-size: 14px;
 | 
				
			||||||
 | 
					    letter-spacing: 1px;
 | 
				
			||||||
 | 
					    display: grid;
 | 
				
			||||||
 | 
					    place-content: center;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										216
									
								
								src/views/copilot/factoryData/cdIndex.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,216 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="factory-layout">
 | 
				
			||||||
 | 
					    <FactoryDataHeader :than="than" :companyName="companyName" :companyId="companyId" :period="period"
 | 
				
			||||||
 | 
					      @update:than="updateThan" @update:period="updatePeriod" />
 | 
				
			||||||
 | 
					    <div class="factory-section">
 | 
				
			||||||
 | 
					      <section class="top flex">
 | 
				
			||||||
 | 
					        <db-container title="生产监控" icon="prod">
 | 
				
			||||||
 | 
					          <prod-monitor :companyId="companyId" :factoryData="factoryData" :than="than" :period="period" :data="data"
 | 
				
			||||||
 | 
					            :prodOutPut="prodOutPut" :prodFto="prodFto" :showBipv="show" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <db-container title="工单监控" icon="order">
 | 
				
			||||||
 | 
					          <order :prodOrder="prodOrder" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <!-- <db-container title="" icon="store"> -->
 | 
				
			||||||
 | 
					        <!-- <store :stock="stock" /> -->
 | 
				
			||||||
 | 
					        <!-- </db-container> -->
 | 
				
			||||||
 | 
					      </section>
 | 
				
			||||||
 | 
					      <!-- <section class="bottom flex"> -->
 | 
				
			||||||
 | 
					      <!-- <db-container title="" icon="energy"> -->
 | 
				
			||||||
 | 
					      <!-- <energy :legend="energyLegend" :energyCockpits="energyCockpits" /> -->
 | 
				
			||||||
 | 
					      <!-- </db-container> -->
 | 
				
			||||||
 | 
					      <!-- </section> -->
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="factory-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import FactoryDataHeader from "./../components/FactoryDataHeader.vue";
 | 
				
			||||||
 | 
					import Container from "./components/Container.vue";
 | 
				
			||||||
 | 
					import ProdMonitor from "./components/ProdMonitor.vue";
 | 
				
			||||||
 | 
					import { deepClone } from "@/utils";
 | 
				
			||||||
 | 
					// import Store from "./components/Store.vue";
 | 
				
			||||||
 | 
					// import Energy from "./components/Energy.vue";
 | 
				
			||||||
 | 
					import Order from "./components/Order.vue";
 | 
				
			||||||
 | 
					import { cockpitDataMonitor } from "@/api/produceData";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "factoryData",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    FactoryDataHeader,
 | 
				
			||||||
 | 
					    DbContainer: Container,
 | 
				
			||||||
 | 
					    ProdMonitor,
 | 
				
			||||||
 | 
					    // Store,
 | 
				
			||||||
 | 
					    // Energy,
 | 
				
			||||||
 | 
					    Order,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      companyId: 4,
 | 
				
			||||||
 | 
					      companyName: "成都中建材光电材料有限公司",
 | 
				
			||||||
 | 
					      period: 1,
 | 
				
			||||||
 | 
					      show: false,
 | 
				
			||||||
 | 
					      than: '同比',
 | 
				
			||||||
 | 
					      data: {},
 | 
				
			||||||
 | 
					      // 接口获取的数据
 | 
				
			||||||
 | 
					      prodOutPut: [], //生产
 | 
				
			||||||
 | 
					      prodFto: [], //生产
 | 
				
			||||||
 | 
					      stock: {}, //仓库
 | 
				
			||||||
 | 
					      factoryData: {
 | 
				
			||||||
 | 
					        preDataDetail: [],
 | 
				
			||||||
 | 
					        currentDataDetail: {},
 | 
				
			||||||
 | 
					        targetDataDetail: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      energyCockpits: [], //能源
 | 
				
			||||||
 | 
					      prodOrder: [], //订单
 | 
				
			||||||
 | 
					      energyLegend: [
 | 
				
			||||||
 | 
					        { label: "电", color: "#FFD160" },
 | 
				
			||||||
 | 
					        { label: "水", color: "#2760FF" },
 | 
				
			||||||
 | 
					        { label: "气", color: "#12FFF5" },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.getMes();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    updateCompany(obj) {
 | 
				
			||||||
 | 
					      this.companyId = obj.companyId;
 | 
				
			||||||
 | 
					      this.companyName = obj.companyName;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updateThan(val) {
 | 
				
			||||||
 | 
					      console.log(val);
 | 
				
			||||||
 | 
					      this.than = val;
 | 
				
			||||||
 | 
					      // this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updatePeriod(val) {
 | 
				
			||||||
 | 
					      this.period = val;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getMes() {
 | 
				
			||||||
 | 
					      cockpitDataMonitor({
 | 
				
			||||||
 | 
					        factorys: [this.companyId],
 | 
				
			||||||
 | 
					        date: this.period,
 | 
				
			||||||
 | 
					        mode: this.than === '同比' ? 0 : 1
 | 
				
			||||||
 | 
					      }).then((res) => {
 | 
				
			||||||
 | 
					        console.log(res);
 | 
				
			||||||
 | 
					        this.prodOutPut = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        this.prodFto = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        this.prodOrder = res.data.prodWorkOrderDO || [];
 | 
				
			||||||
 | 
					        let prodOutputFtoListRes = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preFtoData = res.data.previousProdOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preData = res.data.previousProdOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let factoryListResponse = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let targetListResponse = res.data.prodTargetMonitorDO || [];
 | 
				
			||||||
 | 
					        let preDataDetail = []
 | 
				
			||||||
 | 
					        let currentDataDetail = []
 | 
				
			||||||
 | 
					        let targetDataDetail = []
 | 
				
			||||||
 | 
					        if (prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					          for (const factory of prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            currentDataDetail[0] = factory.chipInput
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preFtoData) {
 | 
				
			||||||
 | 
					          for (const factory of preFtoData) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            // const fId = this.getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // if (fId) {
 | 
				
			||||||
 | 
					            preDataDetail[0] = factory.previousYearChipInput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					            // if (preFId) {
 | 
				
			||||||
 | 
					            // ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preData && preData[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of preData) {
 | 
				
			||||||
 | 
					            if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					              preDataDetail[1] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					              preDataDetail[2] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousYearOutputNumber === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (targetListResponse && targetListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of targetListResponse) {
 | 
				
			||||||
 | 
					            targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            // if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					            targetDataDetail[1] = factory.chipYield
 | 
				
			||||||
 | 
					            // } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					            targetDataDetail[2] = factory.componentYield
 | 
				
			||||||
 | 
					            targetDataDetail[3] = factory.bipvProductoutput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // console.log('ftoInvest',ftoInvest)
 | 
				
			||||||
 | 
					        if (factoryListResponse && factoryListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of factoryListResponse) {
 | 
				
			||||||
 | 
					            // targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            if (factory.glassType === 0) {
 | 
				
			||||||
 | 
					              currentDataDetail[1] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 1) {
 | 
				
			||||||
 | 
					              currentDataDetail[2] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.factoryData.preDataDetail = preDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.currentDataDetail = currentDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.targetDataDetail = targetDataDetail
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.factory-layout {
 | 
				
			||||||
 | 
					  padding: 16px;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/copilot-bg.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  height: calc(100% + 38px);
 | 
				
			||||||
 | 
					  left: -16px;
 | 
				
			||||||
 | 
					  top: -8px;
 | 
				
			||||||
 | 
					  width: calc(100% + 30px);
 | 
				
			||||||
 | 
					  z-index: 1001;
 | 
				
			||||||
 | 
					  color: #fff;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  gap: 8px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-section {
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					    display: flex;
 | 
				
			||||||
 | 
					    flex-direction: column;
 | 
				
			||||||
 | 
					    gap: 16px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .flex {
 | 
				
			||||||
 | 
					      display: flex;
 | 
				
			||||||
 | 
					      gap: 16px;
 | 
				
			||||||
 | 
					      flex: 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .top>div,
 | 
				
			||||||
 | 
					    .bottom>div {
 | 
				
			||||||
 | 
					      height: 100%;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-footer {
 | 
				
			||||||
 | 
					    /** position: absolute;
 | 
				
			||||||
 | 
					  bottom: 10px; **/
 | 
				
			||||||
 | 
					    height: 10px;
 | 
				
			||||||
 | 
					    width: 100%;
 | 
				
			||||||
 | 
					    color: rgb(80, 80, 80);
 | 
				
			||||||
 | 
					    user-select: none;
 | 
				
			||||||
 | 
					    font-size: 14px;
 | 
				
			||||||
 | 
					    letter-spacing: 1px;
 | 
				
			||||||
 | 
					    display: grid;
 | 
				
			||||||
 | 
					    place-content: center;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										417
									
								
								src/views/copilot/factoryData/components/BarChartBase.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,417 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="left-chart-base">
 | 
				
			||||||
 | 
					    <!-- <div class="legend">
 | 
				
			||||||
 | 
					      <span v-for="item in legend" :key="item.label" class="legend-item"
 | 
				
			||||||
 | 
					        :style="{ fontSize: isFullscreen ? '0.85vw' : '0.73vw' }">{{ item.label }}</span>
 | 
				
			||||||
 | 
					    </div> -->
 | 
				
			||||||
 | 
					    <div id="factoryEnergyChart" style="width: 100%; height: 100%"></div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import { debounce } from "@/utils/debounce";
 | 
				
			||||||
 | 
					import * as echarts from "echarts";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "Energy",
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    // legend: {
 | 
				
			||||||
 | 
					    //   type: Array,
 | 
				
			||||||
 | 
					    //   required: true,
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
 | 
					    energyCockpits: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      isFullscreen: false,
 | 
				
			||||||
 | 
					      actualOptions: null,
 | 
				
			||||||
 | 
					      chart: "",
 | 
				
			||||||
 | 
					      options: {
 | 
				
			||||||
 | 
					        color: ["#FFD160", "#2760FF", "#12FFF5"],
 | 
				
			||||||
 | 
					        grid: {
 | 
				
			||||||
 | 
					          left: "7%",
 | 
				
			||||||
 | 
					          right: "7%",
 | 
				
			||||||
 | 
					          bottom: "8%",
 | 
				
			||||||
 | 
					          top: "15%",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        tooltip: {
 | 
				
			||||||
 | 
					          trigger: "axis",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        xAxis: {
 | 
				
			||||||
 | 
					          axisTick: {
 | 
				
			||||||
 | 
					            show: false,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLine: {
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLabel: {
 | 
				
			||||||
 | 
					            color: "rgba(255, 255, 255, 0.7)",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          data: [],
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        yAxis: {
 | 
				
			||||||
 | 
					            type: "value",
 | 
				
			||||||
 | 
					            name: "单位/片",
 | 
				
			||||||
 | 
					            nameTextStyle: {
 | 
				
			||||||
 | 
					              color: "rgba(255, 255, 255, 0.7)",
 | 
				
			||||||
 | 
					              fontSize: 12,
 | 
				
			||||||
 | 
					              align: "right",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            axisTick: {
 | 
				
			||||||
 | 
					              show: false,
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            axisLabel: {
 | 
				
			||||||
 | 
					              color: "rgba(255, 255, 255, 0.7)",
 | 
				
			||||||
 | 
					              fontSize: 12,
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            axisLine: {
 | 
				
			||||||
 | 
					              show: true,
 | 
				
			||||||
 | 
					              lineStyle: {
 | 
				
			||||||
 | 
					                color: "#4561AE",
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            splitLine: {
 | 
				
			||||||
 | 
					              lineStyle: {
 | 
				
			||||||
 | 
					                color: "#4561AE",
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        series: [
 | 
				
			||||||
 | 
					          // {
 | 
				
			||||||
 | 
					          //   name: "",
 | 
				
			||||||
 | 
					          //   data: [],
 | 
				
			||||||
 | 
					          //   type: "line",
 | 
				
			||||||
 | 
					          //   areaStyle: {
 | 
				
			||||||
 | 
					          //     color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
 | 
				
			||||||
 | 
					          //       { offset: 0, color: "#FFD160" + "80" },
 | 
				
			||||||
 | 
					          //       { offset: 0.5, color: "#FFD160" + "20" },
 | 
				
			||||||
 | 
					          //       { offset: 1, color: "#FFD160" + "00" },
 | 
				
			||||||
 | 
					          //     ]),
 | 
				
			||||||
 | 
					          //   },
 | 
				
			||||||
 | 
					          //   lineStyle: {
 | 
				
			||||||
 | 
					          //     width: 2,
 | 
				
			||||||
 | 
					          //   },
 | 
				
			||||||
 | 
					          //   symbol: "circle",
 | 
				
			||||||
 | 
					          //   symbolSize: 8,
 | 
				
			||||||
 | 
					          //   emphasis: {
 | 
				
			||||||
 | 
					          //     focus: "series",
 | 
				
			||||||
 | 
					          //   },
 | 
				
			||||||
 | 
					          // },
 | 
				
			||||||
 | 
					          // {
 | 
				
			||||||
 | 
					          //   name: "",
 | 
				
			||||||
 | 
					          //   data: [],
 | 
				
			||||||
 | 
					          //   type: "line",
 | 
				
			||||||
 | 
					          //   yAxisIndex: 1,
 | 
				
			||||||
 | 
					          //   areaStyle: {
 | 
				
			||||||
 | 
					          //     color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
 | 
				
			||||||
 | 
					          //       { offset: 0, color: "#2760FF" + "80" },
 | 
				
			||||||
 | 
					          //       { offset: 0.5, color: "#2760FF" + "20" },
 | 
				
			||||||
 | 
					          //       { offset: 1, color: "#2760FF" + "00" },
 | 
				
			||||||
 | 
					          //     ]),
 | 
				
			||||||
 | 
					          //   },
 | 
				
			||||||
 | 
					          //   lineStyle: {
 | 
				
			||||||
 | 
					          //     width: 2,
 | 
				
			||||||
 | 
					          //   },
 | 
				
			||||||
 | 
					          //   symbol: "circle",
 | 
				
			||||||
 | 
					          //   symbolSize: 8,
 | 
				
			||||||
 | 
					          //   emphasis: {
 | 
				
			||||||
 | 
					          //     focus: "series",
 | 
				
			||||||
 | 
					          //   },
 | 
				
			||||||
 | 
					          // },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "",
 | 
				
			||||||
 | 
					            data: [],
 | 
				
			||||||
 | 
					            type: "bar",
 | 
				
			||||||
 | 
					            // yAxisIndex: 1,
 | 
				
			||||||
 | 
					            // areaStyle: {
 | 
				
			||||||
 | 
					            //   color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
 | 
				
			||||||
 | 
					            //     { offset: 0, color: "#12FFF5" + "80" },
 | 
				
			||||||
 | 
					            //     { offset: 0.5, color: "#12FFF5" + "20" },
 | 
				
			||||||
 | 
					            //     { offset: 1, color: "#12FFF5" + "00" },
 | 
				
			||||||
 | 
					            //   ]),
 | 
				
			||||||
 | 
					            // },
 | 
				
			||||||
 | 
					            barWidth: 12,
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              borderRadius: [10, 10, 0, 0],
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#57abf8", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "#364BFE66", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            symbol: "circle",
 | 
				
			||||||
 | 
					            symbolSize: 8,
 | 
				
			||||||
 | 
					            emphasis: {
 | 
				
			||||||
 | 
					              focus: "series",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    isOpen() {
 | 
				
			||||||
 | 
					      return this.$store.getters.sidebar.opened;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  watch: {
 | 
				
			||||||
 | 
					    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
				
			||||||
 | 
					    // isFullscreen(val) {
 | 
				
			||||||
 | 
					    //   this.actualOptions.series.map((item) => {
 | 
				
			||||||
 | 
					    //     item.barWidth = val ? 18 : 12;
 | 
				
			||||||
 | 
					    //   });
 | 
				
			||||||
 | 
					    //   this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					    //   this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					    //   this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					    //   this.initOptions(this.actualOptions);
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
 | 
					    // series(val) {
 | 
				
			||||||
 | 
					    //   if (!val) {
 | 
				
			||||||
 | 
					    //     this.initOptions(this.options);
 | 
				
			||||||
 | 
					    //     return;
 | 
				
			||||||
 | 
					    //   }
 | 
				
			||||||
 | 
					    //   const actualOptions = JSON.parse(JSON.stringify(this.options));
 | 
				
			||||||
 | 
					    //   actualOptions.series[0].data = val[0].data;
 | 
				
			||||||
 | 
					    //   actualOptions.series[0].name = val[0].name;
 | 
				
			||||||
 | 
					    //   actualOptions.series[1].data = val[1].data;
 | 
				
			||||||
 | 
					    //   actualOptions.series[1].name = val[1].name;
 | 
				
			||||||
 | 
					    //   actualOptions.series[2].data = val[2].data;
 | 
				
			||||||
 | 
					    //   actualOptions.series[2].name = val[2].name;
 | 
				
			||||||
 | 
					    //   this.actualOptions = actualOptions;
 | 
				
			||||||
 | 
					    //   this.initOptions(actualOptions);
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
 | 
					    energyCockpits() {
 | 
				
			||||||
 | 
					      this.initChart();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    isOpen(val) {
 | 
				
			||||||
 | 
					      this.canvasReset();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    // if (screenfull.isEnabled) {
 | 
				
			||||||
 | 
					    //   screenfull.on("change", () => {
 | 
				
			||||||
 | 
					    //     this.isFullscreen = screenfull.isFullscreen;
 | 
				
			||||||
 | 
					    //   });
 | 
				
			||||||
 | 
					    // }
 | 
				
			||||||
 | 
					    this.canvasReset();
 | 
				
			||||||
 | 
					    window.addEventListener("resize", this.canvasReset);
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  beforeDestroy() {
 | 
				
			||||||
 | 
					    if (this.chart) {
 | 
				
			||||||
 | 
					      this.chart.dispose();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  destroyed() {
 | 
				
			||||||
 | 
					    window.removeEventListener("resize", this.canvasReset);
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    canvasReset() {
 | 
				
			||||||
 | 
					      debounce(() => {
 | 
				
			||||||
 | 
					        this.initChart();
 | 
				
			||||||
 | 
					      }, 500)();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    initChart() {
 | 
				
			||||||
 | 
					      console.log("this.energyCockpits", this.energyCockpits);
 | 
				
			||||||
 | 
					      let orderXAxis = ['目标产量', '计划投入量', '实际投入量', '实际产出量', '废品数量', '待再加工数量'];
 | 
				
			||||||
 | 
					      // let n = 0;
 | 
				
			||||||
 | 
					      let seriesArr =[]
 | 
				
			||||||
 | 
					      seriesArr[0] = this.energyCockpits.length != 0 && this.energyCockpits[0].targetProduction ? this.energyCockpits[0].targetProduction :0
 | 
				
			||||||
 | 
					      seriesArr[1] = this.energyCockpits.length != 0 && this.energyCockpits[0].plannedInvestment ? this.energyCockpits[0].plannedInvestment : 0
 | 
				
			||||||
 | 
					      seriesArr[2] = this.energyCockpits.length != 0 && this.energyCockpits[0].actualInvestment ? this.energyCockpits[0].actualInvestment : 0
 | 
				
			||||||
 | 
					      seriesArr[3] = this.energyCockpits.length != 0 && this.energyCockpits[0].actualProduction ? this.energyCockpits[0].actualProduction : 0
 | 
				
			||||||
 | 
					      seriesArr[4] = this.energyCockpits.length != 0 && this.energyCockpits[0].wasteNum ? this.energyCockpits[0].wasteNum : 0
 | 
				
			||||||
 | 
					      seriesArr[5] = this.energyCockpits.length != 0 && this.energyCockpits[0].reworkNum ? this.energyCockpits[0].reworkNum : 0
 | 
				
			||||||
 | 
					      console.log(seriesArr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // let seriesArr = [
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: "水",
 | 
				
			||||||
 | 
					      //     energyType: 1,
 | 
				
			||||||
 | 
					      //     data: [],
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: "电",
 | 
				
			||||||
 | 
					      //     energyType: 2,
 | 
				
			||||||
 | 
					      //     data: [],
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: "气",
 | 
				
			||||||
 | 
					      //     energyType: 3,
 | 
				
			||||||
 | 
					      //     data: [],
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      // ];
 | 
				
			||||||
 | 
					      // if (this.energyCockpits.length > 0) {
 | 
				
			||||||
 | 
					      //   let dataArr = this.energyCockpits.map((item) => {
 | 
				
			||||||
 | 
					      //     return item.groupName;
 | 
				
			||||||
 | 
					      //   });
 | 
				
			||||||
 | 
					      //   energyxAxis = Array.from(new Set(dataArr));
 | 
				
			||||||
 | 
					      //   n = energyxAxis.length;
 | 
				
			||||||
 | 
					      //   seriesArr[0].data = Array.from({ length: n }, () => 0);
 | 
				
			||||||
 | 
					      //   seriesArr[1].data = Array.from({ length: n }, () => 0);
 | 
				
			||||||
 | 
					      //   seriesArr[2].data = Array.from({ length: n }, () => 0);
 | 
				
			||||||
 | 
					      //   for (let i = 0; i < this.energyCockpits.length; i++) {
 | 
				
			||||||
 | 
					      //     for (let j = 0; j < energyxAxis.length; j++) {
 | 
				
			||||||
 | 
					      //       if (this.energyCockpits[i].groupName === energyxAxis[j]) {
 | 
				
			||||||
 | 
					      //         if (this.energyCockpits[i].energyType === 1) {
 | 
				
			||||||
 | 
					      //           seriesArr[0].data[j] = this.energyCockpits[i].totalEnergyValue;
 | 
				
			||||||
 | 
					      //         } else if (this.energyCockpits[i].energyType === 2) {
 | 
				
			||||||
 | 
					      //           seriesArr[1].data[j] = this.energyCockpits[i].totalEnergyValue;
 | 
				
			||||||
 | 
					      //         } else if (this.energyCockpits[i].energyType === 3) {
 | 
				
			||||||
 | 
					      //           seriesArr[2].data[j] = this.energyCockpits[i].totalEnergyValue;
 | 
				
			||||||
 | 
					      //         }
 | 
				
			||||||
 | 
					      //       }
 | 
				
			||||||
 | 
					      //     }
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      if (this.chart) {
 | 
				
			||||||
 | 
					        this.chart.dispose();
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.chart = echarts.init(document.getElementById("factoryEnergyChart"));
 | 
				
			||||||
 | 
					      const actualOptions = JSON.parse(JSON.stringify(this.options));
 | 
				
			||||||
 | 
					      actualOptions.xAxis.data = orderXAxis;
 | 
				
			||||||
 | 
					      actualOptions.series[0].data = seriesArr;
 | 
				
			||||||
 | 
					      // actualOptions.series[0].name = seriesArr[0].name;
 | 
				
			||||||
 | 
					      // actualOptions.series[1].data = seriesArr[1].data;
 | 
				
			||||||
 | 
					      // actualOptions.series[1].name = seriesArr[1].name;
 | 
				
			||||||
 | 
					      // actualOptions.series[2].data = seriesArr[2].data;
 | 
				
			||||||
 | 
					      // actualOptions.series[2].name = seriesArr[2].name;
 | 
				
			||||||
 | 
					      this.actualOptions = actualOptions;
 | 
				
			||||||
 | 
					      this.chart.setOption(actualOptions);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					.left-chart-base {
 | 
				
			||||||
 | 
					  // position: relative;
 | 
				
			||||||
 | 
					  height: 100%;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend {
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    top: 5.2vh;
 | 
				
			||||||
 | 
					    right: 4vw;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item {
 | 
				
			||||||
 | 
					    position: relative;
 | 
				
			||||||
 | 
					    // font-size: 12px;
 | 
				
			||||||
 | 
					    margin-right: 1.34vw;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    &::before {
 | 
				
			||||||
 | 
					      content: "";
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      // width: 10px;
 | 
				
			||||||
 | 
					      // height: 10px;
 | 
				
			||||||
 | 
					      width: 0.531vw;
 | 
				
			||||||
 | 
					      height: 0.531vw;
 | 
				
			||||||
 | 
					      background-color: #ccc;
 | 
				
			||||||
 | 
					      border-radius: 2px;
 | 
				
			||||||
 | 
					      margin-right: 0.22vw;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(1):before {
 | 
				
			||||||
 | 
					    // width: 12px;
 | 
				
			||||||
 | 
					    // height: 2px;
 | 
				
			||||||
 | 
					    width: 0.638vw;
 | 
				
			||||||
 | 
					    height: 0.1064vw;
 | 
				
			||||||
 | 
					    background-color: #ffd160;
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    top: 50%;
 | 
				
			||||||
 | 
					    // left: -16px;
 | 
				
			||||||
 | 
					    left: -0.851vw;
 | 
				
			||||||
 | 
					    transform: translateY(-50%);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(1):after {
 | 
				
			||||||
 | 
					    background-color: #ffd160;
 | 
				
			||||||
 | 
					    content: "";
 | 
				
			||||||
 | 
					    display: inline-block;
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    // width: 6px;
 | 
				
			||||||
 | 
					    // height: 6px;
 | 
				
			||||||
 | 
					    width: 0.3191vw;
 | 
				
			||||||
 | 
					    height: 0.3191vw;
 | 
				
			||||||
 | 
					    border-radius: 100%;
 | 
				
			||||||
 | 
					    top: 50%;
 | 
				
			||||||
 | 
					    left: -0.851vw;
 | 
				
			||||||
 | 
					    // left: -16px;
 | 
				
			||||||
 | 
					    transform: translateY(-50%) translateX(50%);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(2):before {
 | 
				
			||||||
 | 
					    // width: 12px;
 | 
				
			||||||
 | 
					    // height: 2px;
 | 
				
			||||||
 | 
					    width: 0.638vw;
 | 
				
			||||||
 | 
					    height: 0.1064vw;
 | 
				
			||||||
 | 
					    background-color: #2760ff;
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    top: 50%;
 | 
				
			||||||
 | 
					    // left: -16px;
 | 
				
			||||||
 | 
					    left: -0.851vw;
 | 
				
			||||||
 | 
					    transform: translateY(-50%);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(2):after {
 | 
				
			||||||
 | 
					    background-color: #2760ff;
 | 
				
			||||||
 | 
					    content: "";
 | 
				
			||||||
 | 
					    display: inline-block;
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    // width: 6px;
 | 
				
			||||||
 | 
					    // height: 6px;
 | 
				
			||||||
 | 
					    width: 0.3191vw;
 | 
				
			||||||
 | 
					    height: 0.3191vw;
 | 
				
			||||||
 | 
					    border-radius: 100%;
 | 
				
			||||||
 | 
					    top: 50%;
 | 
				
			||||||
 | 
					    left: -0.851vw;
 | 
				
			||||||
 | 
					    // left: -16px;
 | 
				
			||||||
 | 
					    transform: translateY(-50%) translateX(50%);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(3):before {
 | 
				
			||||||
 | 
					    // width: 12px;
 | 
				
			||||||
 | 
					    // height: 2px;
 | 
				
			||||||
 | 
					    width: 0.638vw;
 | 
				
			||||||
 | 
					    height: 0.1064vw;
 | 
				
			||||||
 | 
					    background-color: #12fff5;
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    top: 50%;
 | 
				
			||||||
 | 
					    // left: -16px;
 | 
				
			||||||
 | 
					    left: -0.851vw;
 | 
				
			||||||
 | 
					    transform: translateY(-50%);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(3):after {
 | 
				
			||||||
 | 
					    background-color: #12fff5;
 | 
				
			||||||
 | 
					    content: "";
 | 
				
			||||||
 | 
					    display: inline-block;
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    // width: 6px;
 | 
				
			||||||
 | 
					    // height: 6px;
 | 
				
			||||||
 | 
					    width: 0.3191vw;
 | 
				
			||||||
 | 
					    height: 0.3191vw;
 | 
				
			||||||
 | 
					    border-radius: 100%;
 | 
				
			||||||
 | 
					    top: 50%;
 | 
				
			||||||
 | 
					    left: -0.851vw;
 | 
				
			||||||
 | 
					    // left: -16px;
 | 
				
			||||||
 | 
					    transform: translateY(-50%) translateX(50%);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										343
									
								
								src/views/copilot/factoryData/components/BarChartChipOEE.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,343 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2024-05-30 08:58:39
 | 
				
			||||||
 | 
					 * @LastEditTime: 2024-05-30 10:38:32
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <chart-container class="bar-chart-base">
 | 
				
			||||||
 | 
					    <div class="legend">
 | 
				
			||||||
 | 
					      <span v-for="(item,index) in legend" :key="index" class="legend-item"
 | 
				
			||||||
 | 
					        :style="{ fontSize: isFullscreen ? '0.58vw' : '0.54vw' }">{{ item.label }}</span>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div ref="oeeChart" style="height:96%;width:100%"></div>
 | 
				
			||||||
 | 
					  </chart-container>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import screenfull from "screenfull";
 | 
				
			||||||
 | 
					import ChartContainer from "./ChartContainer.vue";
 | 
				
			||||||
 | 
					// import chartMixin from "@/mixins/chart.js";
 | 
				
			||||||
 | 
					import { debounce } from "@/utils/debounce";
 | 
				
			||||||
 | 
					import * as echarts from "echarts";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "BarChartBase",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    ChartContainer,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  // mixins: [chartMixin],
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    vHeight: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default: 36,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    legend: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    xAxis: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    series: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      required: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    in: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      width: '100%',
 | 
				
			||||||
 | 
					      isFullscreen: false,
 | 
				
			||||||
 | 
					      actualOptions: null,
 | 
				
			||||||
 | 
					      options: {
 | 
				
			||||||
 | 
					        grid: {
 | 
				
			||||||
 | 
					          left: "5%",
 | 
				
			||||||
 | 
					          right: "0%",
 | 
				
			||||||
 | 
					          bottom: "3%",
 | 
				
			||||||
 | 
					          top: "15%",
 | 
				
			||||||
 | 
					          containLabel: true,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        tooltip: {},
 | 
				
			||||||
 | 
					        xAxis: {
 | 
				
			||||||
 | 
					          axisTick: {
 | 
				
			||||||
 | 
					            show: false,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLine: {
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLabel: {
 | 
				
			||||||
 | 
					            color: "#fff",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          data: this.xAxis,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        yAxis: {
 | 
				
			||||||
 | 
					          name: "单位/%",
 | 
				
			||||||
 | 
					          nameTextStyle: {
 | 
				
			||||||
 | 
					            color: "#fff",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisTick: {
 | 
				
			||||||
 | 
					            show: false,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLabel: {
 | 
				
			||||||
 | 
					            color: "#fff",
 | 
				
			||||||
 | 
					            fontSize: 12,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          axisLine: {
 | 
				
			||||||
 | 
					            show: true,
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          splitLine: {
 | 
				
			||||||
 | 
					            lineStyle: {
 | 
				
			||||||
 | 
					              color: "#4561AE",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        series: [
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "fto", // this.series[0].name,
 | 
				
			||||||
 | 
					            type: "bar",
 | 
				
			||||||
 | 
					            barWidth: 12,
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              borderRadius: [10, 10, 0, 0],
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#12f7f1", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0.35,
 | 
				
			||||||
 | 
					                    color: "#12f7f177", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0.75,
 | 
				
			||||||
 | 
					                    color: "#12f7f133", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "transparent", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            data: [], // this.series[0].data,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "", // this.series[1].name,
 | 
				
			||||||
 | 
					            type: "bar",
 | 
				
			||||||
 | 
					            barWidth: 12,
 | 
				
			||||||
 | 
					            // tooltip: {
 | 
				
			||||||
 | 
					            //   valueFormatter: function (value) {
 | 
				
			||||||
 | 
					            //     return value + " ml";
 | 
				
			||||||
 | 
					            //   },
 | 
				
			||||||
 | 
					            // },
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              borderRadius: [10, 10, 0, 0],
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#57abf8", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "#364BFE66", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            data: [], // this.series[1].data,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          {
 | 
				
			||||||
 | 
					            name: "", // "2024年目标值",
 | 
				
			||||||
 | 
					            type: "bar",
 | 
				
			||||||
 | 
					            barWidth: 12,
 | 
				
			||||||
 | 
					            itemStyle: {
 | 
				
			||||||
 | 
					              borderRadius: [10, 10, 0, 0],
 | 
				
			||||||
 | 
					              color: {
 | 
				
			||||||
 | 
					                type: "linear",
 | 
				
			||||||
 | 
					                x: 0,
 | 
				
			||||||
 | 
					                y: 0,
 | 
				
			||||||
 | 
					                x2: 0,
 | 
				
			||||||
 | 
					                y2: 1,
 | 
				
			||||||
 | 
					                colorStops: [
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 0,
 | 
				
			||||||
 | 
					                    color: "#f3c000", // 0% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "#f3c00033",
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                  {
 | 
				
			||||||
 | 
					                    offset: 1,
 | 
				
			||||||
 | 
					                    color: "transparent", // 100% 处的颜色
 | 
				
			||||||
 | 
					                  },
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                global: false, // 缺省为 false
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            data: [], // this.series[0].data,
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    isOpen() {
 | 
				
			||||||
 | 
					      return this.$store.getters.sidebar.opened
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  watch: {
 | 
				
			||||||
 | 
					    xAxis(val) {
 | 
				
			||||||
 | 
					      this.options.xAxis.data = val
 | 
				
			||||||
 | 
					      this.canvasReset()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    isOpen(val) {
 | 
				
			||||||
 | 
					      this.canvasReset()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
				
			||||||
 | 
					    isFullscreen(val) {
 | 
				
			||||||
 | 
					      this.actualOptions.series.map((item) => {
 | 
				
			||||||
 | 
					        item.barWidth = val ? 18 : 12;
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					      this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // if (val === false && this.isOpen === true) {
 | 
				
			||||||
 | 
					      //   console.log(val)
 | 
				
			||||||
 | 
					      //   this.width = 97 + '%'
 | 
				
			||||||
 | 
					      //   this.canvasReset()
 | 
				
			||||||
 | 
					      // } else if (val === false && this.isOpen === false) {
 | 
				
			||||||
 | 
					      //   this.width = 100 + '%'
 | 
				
			||||||
 | 
					      //   this.canvasReset()
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      // this.actualOptions.series.map((item) => {
 | 
				
			||||||
 | 
					      //   item.barWidth = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // });
 | 
				
			||||||
 | 
					      // this.actualOptions.xAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // this.actualOptions.yAxis.axisLabel.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      // this.actualOptions.yAxis.nameTextStyle.fontSize = val ? 18 : 12;
 | 
				
			||||||
 | 
					      this.initChart(this.actualOptions)
 | 
				
			||||||
 | 
					      this.canvasReset()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    series(val) {
 | 
				
			||||||
 | 
					      if (!val) {
 | 
				
			||||||
 | 
					        this.initChart(this.options);
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      // console.log('val', val)
 | 
				
			||||||
 | 
					      const actualOptions = JSON.parse(JSON.stringify(this.options))
 | 
				
			||||||
 | 
					      // actualOptions.xAxis.data = val
 | 
				
			||||||
 | 
					      console.log(actualOptions)
 | 
				
			||||||
 | 
					      actualOptions.series[0].data = val[0].data;
 | 
				
			||||||
 | 
					      actualOptions.series[0].name = val[0].name;
 | 
				
			||||||
 | 
					      actualOptions.series[1].data = val?.[1]?.data;
 | 
				
			||||||
 | 
					      actualOptions.series[1].name = val?.[1]?.name;
 | 
				
			||||||
 | 
					      actualOptions.series[2].data = val?.[2]?.data || [];
 | 
				
			||||||
 | 
					      actualOptions.series[2].name = val?.[2]?.name || "";
 | 
				
			||||||
 | 
					      this.actualOptions = actualOptions;
 | 
				
			||||||
 | 
					      this.initChart(actualOptions);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    // if (screenfull.isEnabled) {
 | 
				
			||||||
 | 
					    //   screenfull.on("change", () => {
 | 
				
			||||||
 | 
					    //     this.isFullscreen = screenfull.isFullscreen;
 | 
				
			||||||
 | 
					    //   });
 | 
				
			||||||
 | 
					    // }
 | 
				
			||||||
 | 
					    // if (screenfull.isEnabled) {
 | 
				
			||||||
 | 
					    //   screenfull.on("change", () => {
 | 
				
			||||||
 | 
					    //     this.isFullscreen = screenfull.isFullscreen;
 | 
				
			||||||
 | 
					    //   });
 | 
				
			||||||
 | 
					    // }
 | 
				
			||||||
 | 
					    this.actualOptions = this.options
 | 
				
			||||||
 | 
					    this.canvasReset();
 | 
				
			||||||
 | 
					    window.addEventListener("resize", this.canvasReset);
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  beforeDestroy() {
 | 
				
			||||||
 | 
					    if (this.chart) {
 | 
				
			||||||
 | 
					      this.chart.dispose();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  destroyed() {
 | 
				
			||||||
 | 
					    window.removeEventListener("resize", this.canvasReset);
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    canvasReset() {
 | 
				
			||||||
 | 
					      debounce(() => {
 | 
				
			||||||
 | 
					        this.initChart();
 | 
				
			||||||
 | 
					      }, 500)();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    initChart() {
 | 
				
			||||||
 | 
					      if (this.chart) {
 | 
				
			||||||
 | 
					        this.chart.dispose();
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.chart = echarts.init(this.$refs.oeeChart);
 | 
				
			||||||
 | 
					      this.chart.setOption(this.actualOptions);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					.bar-chart-base {
 | 
				
			||||||
 | 
					  // position: relative;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend {
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    top: 5.2vh;
 | 
				
			||||||
 | 
					    right: 1vw;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item {
 | 
				
			||||||
 | 
					    position: relative;
 | 
				
			||||||
 | 
					    // font-size: 12px;
 | 
				
			||||||
 | 
					    margin-right: 1.3vw;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    &::before {
 | 
				
			||||||
 | 
					      content: "";
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      width: 0.531vw;
 | 
				
			||||||
 | 
					      height: 0.531vw;
 | 
				
			||||||
 | 
					      background-color: #ccc;
 | 
				
			||||||
 | 
					      border-radius: 2px;
 | 
				
			||||||
 | 
					      margin-right: 0.22vw;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(1):before {
 | 
				
			||||||
 | 
					    background-color: #12f7f1;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .legend-item:nth-child(2):before {
 | 
				
			||||||
 | 
					    background-color: #58adfa;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .legend-item:nth-child(3):before {
 | 
				
			||||||
 | 
					    background-color: #f3c000;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										69
									
								
								src/views/copilot/factoryData/components/ChartContainer.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,69 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2024-05-30 09:00:01
 | 
				
			||||||
 | 
					 * @LastEditTime: 2024-05-30 09:50:02
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="chart-container" :class="{ 'no-scroll': noScroll }">
 | 
				
			||||||
 | 
					    <slot />
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "ChartContainer",
 | 
				
			||||||
 | 
					  components: {},
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    noScroll: {
 | 
				
			||||||
 | 
					      type: Boolean,
 | 
				
			||||||
 | 
					      default: false,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {};
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {},
 | 
				
			||||||
 | 
					  methods: {},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					.chart-container {
 | 
				
			||||||
 | 
					  height: 0;
 | 
				
			||||||
 | 
					  flex: 1;
 | 
				
			||||||
 | 
					  overflow-x: scroll;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.no-scroll::-webkit-scrollbar {
 | 
				
			||||||
 | 
					  width: 0;
 | 
				
			||||||
 | 
					  height: 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					::-webkit-scrollbar {
 | 
				
			||||||
 | 
					  width: 8px;
 | 
				
			||||||
 | 
					  height: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					::-webkit-scrollbar-button {
 | 
				
			||||||
 | 
					  width: 0;
 | 
				
			||||||
 | 
					  height: 0;
 | 
				
			||||||
 | 
					  //   width: 10px;
 | 
				
			||||||
 | 
					  //   height: 10px;
 | 
				
			||||||
 | 
					  //   background: #14305f;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					::-webkit-scrollbar-track {
 | 
				
			||||||
 | 
					  background: #14305f;
 | 
				
			||||||
 | 
					  border: 0 none;
 | 
				
			||||||
 | 
					  border-radius: 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					::-webkit-scrollbar-thumb {
 | 
				
			||||||
 | 
					  background: #004798;
 | 
				
			||||||
 | 
					  border: 0 none;
 | 
				
			||||||
 | 
					  border-radius: 6px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										278
									
								
								src/views/copilot/factoryData/components/ChipOee.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,278 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2024-05-29 14:48:06
 | 
				
			||||||
 | 
					 * @LastEditTime: 2024-05-30 10:54:00
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <BarChartBase
 | 
				
			||||||
 | 
					    :legend="legend"
 | 
				
			||||||
 | 
					    :series="series"
 | 
				
			||||||
 | 
					    :xAxis="xAxis"
 | 
				
			||||||
 | 
					    in="chipOEE"
 | 
				
			||||||
 | 
					    class="chip-oee"
 | 
				
			||||||
 | 
					  />
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import BarChartBase from "./BarChartChipOEE.vue";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "ChipOEE",
 | 
				
			||||||
 | 
					  components: { BarChartBase },
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    period: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default:1,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    companyId: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default: 0
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    data: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      default:{}
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    // 城市数组的顺序必须是固定的
 | 
				
			||||||
 | 
					    const cities = ["fto投入", "芯片产量", "标准组件产量"];
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      // xAxis: cities,
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    xAxis() {
 | 
				
			||||||
 | 
					      console.log(' this.companyId', this.companyId);
 | 
				
			||||||
 | 
					      return this.companyId === 0 ? ["fto投入", "芯片产量", "标准组件产量"] : ["fto投入", "芯片产量", "标准组件产量", 'BIPV产量'];
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    legend() {
 | 
				
			||||||
 | 
					      let items = [];
 | 
				
			||||||
 | 
					      var day1 = new Date();
 | 
				
			||||||
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					      var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
 | 
					      //今天的时间
 | 
				
			||||||
 | 
					      // var day2 = new Date();
 | 
				
			||||||
 | 
					      // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					      // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
 | 
					      // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
 | 
					      const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      if (this.period === 1  && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年${month}月${today}日`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period ===1 && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${yesterday}日`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === 2 && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年本周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === 2 && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `上周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === 3 && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年${month}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          { label: `${month}月目标`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === 3 && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${lastMonth}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          { label: `${month}月目标`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          { label:  `${year}年目标`, color: "#58adfa" },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          // { label: `${year}年目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      return items
 | 
				
			||||||
 | 
					      // switch (this.period) {
 | 
				
			||||||
 | 
					      //   case "日":
 | 
				
			||||||
 | 
					      //     return [{ label: "昨日", color: "#12f7f1" }];
 | 
				
			||||||
 | 
					      //   case "周":
 | 
				
			||||||
 | 
					      //     return [{ label: "本周", color: "#12f7f1" }];
 | 
				
			||||||
 | 
					      //   case "月": {
 | 
				
			||||||
 | 
					      //     const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      //     const month = new Date().getMonth() + 1;
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年${month}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      //   case "年": {
 | 
				
			||||||
 | 
					      //     const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      //   default:
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // chipOeeRate() {
 | 
				
			||||||
 | 
					    //    return  this.$store.getters.copilot.efficiency.chipOeeRate
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
 | 
					    series() {
 | 
				
			||||||
 | 
					      // console.log('aaaaaaaa', this.$store.getters.copilot.efficiency.chipOee);
 | 
				
			||||||
 | 
					      // const chipOeeRate = this.data
 | 
				
			||||||
 | 
					      // console.log('chipOee', chipOeeRate)
 | 
				
			||||||
 | 
					      let dataList = []
 | 
				
			||||||
 | 
					      dataList[0] = this.data.preDataDetail
 | 
				
			||||||
 | 
					      dataList[1] = this.data.currentDataDetail
 | 
				
			||||||
 | 
					      dataList[2] = this.data.targetDataDetail
 | 
				
			||||||
 | 
					      console.log(dataList)
 | 
				
			||||||
 | 
					      return getTemplate(this.period, dataList,this.than);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function getTemplate(period, dataList, than) {
 | 
				
			||||||
 | 
					  // console.log('dataList',dataList);
 | 
				
			||||||
 | 
					  let items = [];
 | 
				
			||||||
 | 
					  var day1 = new Date();
 | 
				
			||||||
 | 
					  day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					  var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
 | 
					  //今天的时间
 | 
				
			||||||
 | 
					  // var day2 = new Date();
 | 
				
			||||||
 | 
					  // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					  // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					  const today = new Date().getDate();
 | 
				
			||||||
 | 
					  // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
 | 
					  const month = new Date().getMonth() + 1;
 | 
				
			||||||
 | 
					  const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
 | 
					  const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					  if (period === 1 && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年${month}月${today}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period ===1 && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${yesterday}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === 2 && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === 2&& than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `上周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === 3 && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}目标`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[2] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === 3 && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${lastMonth}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}目标`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[2] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year - 1}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year}目标`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[2] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return items
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
@@ -18,19 +18,11 @@ import * as echarts from "echarts";
 | 
				
			|||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "Energy",
 | 
					  name: "Energy",
 | 
				
			||||||
  props: {
 | 
					  props: {
 | 
				
			||||||
    vHeight: {
 | 
					 | 
				
			||||||
      type: Number,
 | 
					 | 
				
			||||||
      default: 34,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    legend: {
 | 
					    legend: {
 | 
				
			||||||
      type: Array,
 | 
					      type: Array,
 | 
				
			||||||
      required: true,
 | 
					      required: true,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    xAxis: {
 | 
					    energyCockpits: {
 | 
				
			||||||
      type: Array,
 | 
					 | 
				
			||||||
      required: true,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    series: {
 | 
					 | 
				
			||||||
      type: Array,
 | 
					      type: Array,
 | 
				
			||||||
      required: true,
 | 
					      required: true,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -43,11 +35,10 @@ export default {
 | 
				
			|||||||
      options: {
 | 
					      options: {
 | 
				
			||||||
        color: ["#FFD160", "#2760FF", "#12FFF5"],
 | 
					        color: ["#FFD160", "#2760FF", "#12FFF5"],
 | 
				
			||||||
        grid: {
 | 
					        grid: {
 | 
				
			||||||
          left: "3%",
 | 
					          left: "7%",
 | 
				
			||||||
          right: "4%",
 | 
					          right: "7%",
 | 
				
			||||||
          bottom: "0",
 | 
					          bottom: "8%",
 | 
				
			||||||
          top: "15%",
 | 
					          top: "15%",
 | 
				
			||||||
          containLabel: true,
 | 
					 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        tooltip: {
 | 
					        tooltip: {
 | 
				
			||||||
          trigger: "axis",
 | 
					          trigger: "axis",
 | 
				
			||||||
@@ -65,7 +56,7 @@ export default {
 | 
				
			|||||||
            color: "rgba(255, 255, 255, 0.7)",
 | 
					            color: "rgba(255, 255, 255, 0.7)",
 | 
				
			||||||
            fontSize: 12,
 | 
					            fontSize: 12,
 | 
				
			||||||
          },
 | 
					          },
 | 
				
			||||||
          data: this.xAxis,
 | 
					          data: [],
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        yAxis: [
 | 
					        yAxis: [
 | 
				
			||||||
          {
 | 
					          {
 | 
				
			||||||
@@ -190,6 +181,11 @@ export default {
 | 
				
			|||||||
      },
 | 
					      },
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    isOpen() {
 | 
				
			||||||
 | 
					      return this.$store.getters.sidebar.opened;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
  watch: {
 | 
					  watch: {
 | 
				
			||||||
    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
					    /** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
 | 
				
			||||||
    // isFullscreen(val) {
 | 
					    // isFullscreen(val) {
 | 
				
			||||||
@@ -216,6 +212,12 @@ export default {
 | 
				
			|||||||
    //   this.actualOptions = actualOptions;
 | 
					    //   this.actualOptions = actualOptions;
 | 
				
			||||||
    //   this.initOptions(actualOptions);
 | 
					    //   this.initOptions(actualOptions);
 | 
				
			||||||
    // },
 | 
					    // },
 | 
				
			||||||
 | 
					    energyCockpits() {
 | 
				
			||||||
 | 
					      this.initChart();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    isOpen(val) {
 | 
				
			||||||
 | 
					      this.canvasReset();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  mounted() {
 | 
					  mounted() {
 | 
				
			||||||
    // if (screenfull.isEnabled) {
 | 
					    // if (screenfull.isEnabled) {
 | 
				
			||||||
@@ -241,17 +243,60 @@ export default {
 | 
				
			|||||||
      }, 500)();
 | 
					      }, 500)();
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    initChart() {
 | 
					    initChart() {
 | 
				
			||||||
 | 
					      let energyxAxis = [];
 | 
				
			||||||
 | 
					      let n = 0;
 | 
				
			||||||
 | 
					      let seriesArr = [
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          name: "水",
 | 
				
			||||||
 | 
					          energyType: 1,
 | 
				
			||||||
 | 
					          data: [],
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          name: "电",
 | 
				
			||||||
 | 
					          energyType: 2,
 | 
				
			||||||
 | 
					          data: [],
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          name: "气",
 | 
				
			||||||
 | 
					          energyType: 3,
 | 
				
			||||||
 | 
					          data: [],
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      ];
 | 
				
			||||||
 | 
					      if (this.energyCockpits.length > 0) {
 | 
				
			||||||
 | 
					        let dataArr = this.energyCockpits.map((item) => {
 | 
				
			||||||
 | 
					          return item.groupName;
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					        energyxAxis = Array.from(new Set(dataArr));
 | 
				
			||||||
 | 
					        n = energyxAxis.length;
 | 
				
			||||||
 | 
					        seriesArr[0].data = Array.from({ length: n }, () => 0);
 | 
				
			||||||
 | 
					        seriesArr[1].data = Array.from({ length: n }, () => 0);
 | 
				
			||||||
 | 
					        seriesArr[2].data = Array.from({ length: n }, () => 0);
 | 
				
			||||||
 | 
					        for (let i = 0; i < this.energyCockpits.length; i++) {
 | 
				
			||||||
 | 
					          for (let j = 0; j < energyxAxis.length; j++) {
 | 
				
			||||||
 | 
					            if (this.energyCockpits[i].groupName === energyxAxis[j]) {
 | 
				
			||||||
 | 
					              if (this.energyCockpits[i].energyType === 1) {
 | 
				
			||||||
 | 
					                seriesArr[0].data[j] = this.energyCockpits[i].totalEnergyValue;
 | 
				
			||||||
 | 
					              } else if (this.energyCockpits[i].energyType === 2) {
 | 
				
			||||||
 | 
					                seriesArr[1].data[j] = this.energyCockpits[i].totalEnergyValue;
 | 
				
			||||||
 | 
					              } else if (this.energyCockpits[i].energyType === 3) {
 | 
				
			||||||
 | 
					                seriesArr[2].data[j] = this.energyCockpits[i].totalEnergyValue;
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
      if (this.chart) {
 | 
					      if (this.chart) {
 | 
				
			||||||
        this.chart.dispose();
 | 
					        this.chart.dispose();
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      this.chart = echarts.init(document.getElementById("factoryEnergyChart"));
 | 
					      this.chart = echarts.init(document.getElementById("factoryEnergyChart"));
 | 
				
			||||||
      const actualOptions = JSON.parse(JSON.stringify(this.options));
 | 
					      const actualOptions = JSON.parse(JSON.stringify(this.options));
 | 
				
			||||||
      actualOptions.series[0].data = this.series[0].data;
 | 
					      actualOptions.xAxis.data = energyxAxis;
 | 
				
			||||||
      actualOptions.series[0].name = this.series[0].name;
 | 
					      actualOptions.series[0].data = seriesArr[0].data;
 | 
				
			||||||
      actualOptions.series[1].data = this.series[1].data;
 | 
					      actualOptions.series[0].name = seriesArr[0].name;
 | 
				
			||||||
      actualOptions.series[1].name = this.series[1].name;
 | 
					      actualOptions.series[1].data = seriesArr[1].data;
 | 
				
			||||||
      actualOptions.series[2].data = this.series[2].data;
 | 
					      actualOptions.series[1].name = seriesArr[1].name;
 | 
				
			||||||
      actualOptions.series[2].name = this.series[2].name;
 | 
					      actualOptions.series[2].data = seriesArr[2].data;
 | 
				
			||||||
 | 
					      actualOptions.series[2].name = seriesArr[2].name;
 | 
				
			||||||
      this.actualOptions = actualOptions;
 | 
					      this.actualOptions = actualOptions;
 | 
				
			||||||
      this.chart.setOption(actualOptions);
 | 
					      this.chart.setOption(actualOptions);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,77 +1,189 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <dv-scroll-board
 | 
					  <div class="order-container">
 | 
				
			||||||
    v-if="aa"
 | 
					    <div class="table">
 | 
				
			||||||
    :config="config"
 | 
					      <dv-scroll-board v-if="showTable" :config="config" style="width: 100%; height: 100%" ref="orderScrollBoard" />
 | 
				
			||||||
    style="width: 100%; height: 100%"
 | 
					    </div>
 | 
				
			||||||
  />
 | 
					    <div class="chart">
 | 
				
			||||||
 | 
					      <div class="chart-title">
 | 
				
			||||||
 | 
					        <span class="title">生产情况</span>
 | 
				
			||||||
 | 
					        <span class="line"></span>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <barChartBase :energyCockpits="prodOrder" ref="barChart" style="height: 0;flex:1"></barChartBase>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import { debounce } from "@/utils/debounce";
 | 
					import { debounce } from "@/utils/debounce";
 | 
				
			||||||
 | 
					import barChartBase from './BarChartBase'
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "Order",
 | 
					  name: "Order",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    barChartBase,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      aa: true,
 | 
					      showTable: true,
 | 
				
			||||||
      config: {
 | 
					      config: {
 | 
				
			||||||
        header: ["序号", "客户名称", "产品名称", "计划加工数量", "加工进度"],
 | 
					        header: ["工单号", "工单状态", "计划投入", "实际投入", "目标产量", "实际产量", "生产进度"],
 | 
				
			||||||
        headerBGC: "rgba(0, 106, 205, 0.22)",
 | 
					        headerBGC: "rgba(0, 106, 205, 0.22)",
 | 
				
			||||||
        oddRowBGC: "rgba(0, 106, 205, 0.22)",
 | 
					        oddRowBGC: "rgba(0, 106, 205, 0.22)",
 | 
				
			||||||
        evenRowBGC: "rgba(rgba(2, 13, 45, 0.18)",
 | 
					        evenRowBGC: "rgba(rgba(2, 13, 45, 0.18)",
 | 
				
			||||||
        data: [],
 | 
					        data: [],
 | 
				
			||||||
        rowNum: 12,
 | 
					        rowNum: 12,
 | 
				
			||||||
        waitTime: 3000,
 | 
					        waitTime: 3000,
 | 
				
			||||||
        columnWidth: [50],
 | 
					        columnWidth: [100],
 | 
				
			||||||
        align: ["center"],
 | 
					        align: ["center"],
 | 
				
			||||||
        carousel: "page",
 | 
					        carousel: "page",
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  mounted() {
 | 
					  props: {
 | 
				
			||||||
    this.getTableList();
 | 
					    prodOrder: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      default: [],
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    isOpen() {
 | 
				
			||||||
 | 
					      return this.$store.getters.sidebar.opened;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  watch: {
 | 
				
			||||||
 | 
					    isOpen(val) {
 | 
				
			||||||
      this.tableReset();
 | 
					      this.tableReset();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    prodOrder() {
 | 
				
			||||||
 | 
					      this.getTableList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
    window.addEventListener("resize", this.tableReset);
 | 
					    window.addEventListener("resize", this.tableReset);
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    tableReset() {
 | 
					    tableReset() {
 | 
				
			||||||
      this.aa = false;
 | 
					      this.showTable = false;
 | 
				
			||||||
      debounce(() => {
 | 
					      debounce(() => {
 | 
				
			||||||
        this.initTable();
 | 
					        this.initTable();
 | 
				
			||||||
      }, 500)();
 | 
					      }, 500)();
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    initTable() {
 | 
					    initTable() {
 | 
				
			||||||
      this.aa = true;
 | 
					      this.showTable = true;
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    getTableList() {
 | 
					    getTableList() {
 | 
				
			||||||
      let _this = this;
 | 
					      let outArr = [];
 | 
				
			||||||
      setTimeout(
 | 
					      if (this.prodOrder.length > 0) {
 | 
				
			||||||
        (function name() {
 | 
					        for (let i = 0; i < this.prodOrder.length; i++) {
 | 
				
			||||||
          _this.config.data = [
 | 
					          let arr = [];
 | 
				
			||||||
            ["1", "行1列1", "行1列2", "行1列3", "50%"],
 | 
					          // arr.push(i + 1);
 | 
				
			||||||
            ["2", "行2列1", "行2列2", "行2列3", "50%"],
 | 
					          arr.push(
 | 
				
			||||||
            ["3", "行3列1", "行3列2", "行3列3", "50%"],
 | 
					            `<span title=${this.prodOrder[i].workOrderNumber || ""}>${
 | 
				
			||||||
            ["4", "行4列1", "行4列2", "行4列3", "50%"],
 | 
					            this.prodOrder[i].workOrderNumber || ""
 | 
				
			||||||
            ["5", "行5列1", "行5列2", "行5列3", "50%"],
 | 
					            }</span>`
 | 
				
			||||||
            ["6", "行6列1", "行6列2", "行6列3", "50%"],
 | 
					 | 
				
			||||||
            ["7", "行7列1", "行7列2", "行7列3", "50%"],
 | 
					 | 
				
			||||||
            ["8", "行8列1", "行8列2", "行8列3", "50%"],
 | 
					 | 
				
			||||||
            ["9", "行9列1", "行9列2", "行9列3", "50%"],
 | 
					 | 
				
			||||||
            ["10", "行10列1", "行10列2", "行10列3", "50%"],
 | 
					 | 
				
			||||||
            ["11", "行11列1", "行11列2", "行11列3", "50%"],
 | 
					 | 
				
			||||||
            ["12", "行12列1", "行12列2", "行12列3", "50%"],
 | 
					 | 
				
			||||||
            ["13", "行13列1", "行13列2", "行13列3", "50%"],
 | 
					 | 
				
			||||||
            ["14", "行14列1", "行14列2", "行14列3", "50%"],
 | 
					 | 
				
			||||||
            ["15", "行15列1", "行15列2", "行15列3", "50%"],
 | 
					 | 
				
			||||||
            ["16", "行16列1", "行16列2", "行16列3", "50%"],
 | 
					 | 
				
			||||||
            ["17", "行17列1", "行17列2", "行17列3", "50%"],
 | 
					 | 
				
			||||||
            ["18", "行18列1", "行18列2", "行18列3", "50%"],
 | 
					 | 
				
			||||||
            ["19", "行19列1", "行19列2", "行19列3", "50%"],
 | 
					 | 
				
			||||||
            ["20", "行20列1", "行20列2", "行20列3", "50%"],
 | 
					 | 
				
			||||||
          ];
 | 
					 | 
				
			||||||
        })(),
 | 
					 | 
				
			||||||
        2000
 | 
					 | 
				
			||||||
          );
 | 
					          );
 | 
				
			||||||
      this.initTable();
 | 
					          arr.push(
 | 
				
			||||||
 | 
					            `<span title=${this.prodOrder[i].inStatus || ""}>${
 | 
				
			||||||
 | 
					            this.prodOrder[i].inStatus || ""
 | 
				
			||||||
 | 
					            }</span>`
 | 
				
			||||||
 | 
					          );
 | 
				
			||||||
 | 
					          arr.push(
 | 
				
			||||||
 | 
					            `<span title=${this.prodOrder[i].plannedInvestment || ""}>${
 | 
				
			||||||
 | 
					            this.prodOrder[i].plannedInvestment || ""
 | 
				
			||||||
 | 
					            }</span>`
 | 
				
			||||||
 | 
					          );
 | 
				
			||||||
 | 
					          arr.push(
 | 
				
			||||||
 | 
					            `<span title=${this.prodOrder[i].actualInvestment || ""}>${this.prodOrder[i].actualInvestment || ""
 | 
				
			||||||
 | 
					            }</span>`
 | 
				
			||||||
 | 
					          );
 | 
				
			||||||
 | 
					          arr.push(
 | 
				
			||||||
 | 
					            `<span title=${this.prodOrder[i].targetProduction || ""}>${this.prodOrder[i].targetProduction || ""
 | 
				
			||||||
 | 
					            }</span>`
 | 
				
			||||||
 | 
					          );
 | 
				
			||||||
 | 
					          arr.push(
 | 
				
			||||||
 | 
					            `<span title=${this.prodOrder[i].actualProduction || ""}>${this.prodOrder[i].actualProduction || ""
 | 
				
			||||||
 | 
					            }</span>`
 | 
				
			||||||
 | 
					          );
 | 
				
			||||||
 | 
					          arr.push(`<span style="display:inline-block;width:45px;">${
 | 
				
			||||||
 | 
					            this.prodOrder[i].productionProgress
 | 
				
			||||||
 | 
					            ? this.prodOrder[i].productionProgress.toFixed(0) + "%"
 | 
				
			||||||
 | 
					              : "0%"
 | 
				
			||||||
 | 
					          }</span>
 | 
				
			||||||
 | 
					            <div style="display:inline-block;height:20px;margin-top:-5px;vertical-align:middle;">
 | 
				
			||||||
 | 
					            <svg xmlns="http://www.w3.org/200/svg" height="20" width="20">
 | 
				
			||||||
 | 
					              <circle cx="10" cy="10" r="6" fill="none" stroke="#283851" stroke-width="4" stroke-linecap="round"/>
 | 
				
			||||||
 | 
					              <circle style="transform-origin: center;transform: rotate(-90deg);" id="J_progress_bar" cx="10" cy="10" r="6" fill="none" stroke="#47FF27" stroke-width="4" stroke-dasharray="${
 | 
				
			||||||
 | 
					            this.prodOrder[i].productionProgress
 | 
				
			||||||
 | 
					            ? this.prodOrder[i].productionProgress.toFixed(0) *
 | 
				
			||||||
 | 
					                      37.68 *
 | 
				
			||||||
 | 
					                      0.01 +
 | 
				
			||||||
 | 
					                    "," +
 | 
				
			||||||
 | 
					                    (1 -
 | 
				
			||||||
 | 
					              this.prodOrder[i].productionProgress.toFixed(0) * 0.01) *
 | 
				
			||||||
 | 
					                      37.68
 | 
				
			||||||
 | 
					                  : 0 + "," + 37.68
 | 
				
			||||||
 | 
					              }"/>
 | 
				
			||||||
 | 
					            </svg>
 | 
				
			||||||
 | 
					          </div>`);
 | 
				
			||||||
 | 
					          outArr.push(arr);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.config.data = outArr;
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.config.data = [];
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.$refs["orderScrollBoard"].updateRows(outArr);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.order-container{
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  height: 100%;
 | 
				
			||||||
 | 
					  .table{
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					        .chart {
 | 
				
			||||||
 | 
					          flex: 1;
 | 
				
			||||||
 | 
					          display: flex;
 | 
				
			||||||
 | 
					          flex-direction: column;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          // gap: 6px;
 | 
				
			||||||
 | 
					          .chart-title {
 | 
				
			||||||
 | 
					            margin-top: 5px;
 | 
				
			||||||
 | 
					            // flex: 1;
 | 
				
			||||||
 | 
					            // gap: 6px;
 | 
				
			||||||
 | 
					            height: 1.5vw;
 | 
				
			||||||
 | 
					            width: 100%;
 | 
				
			||||||
 | 
					            display: flex;
 | 
				
			||||||
 | 
					            align-items: center;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            // flex-direction: column;
 | 
				
			||||||
 | 
					            // flex-wrap: nowrap;
 | 
				
			||||||
 | 
					            // justify-content: end
 | 
				
			||||||
 | 
					            // margin-top: 10px;
 | 
				
			||||||
 | 
					            .title {
 | 
				
			||||||
 | 
					              // flex: 1;
 | 
				
			||||||
 | 
					              font-weight: 400;
 | 
				
			||||||
 | 
					              font-size: 24px;
 | 
				
			||||||
 | 
					              // width: 5vw;
 | 
				
			||||||
 | 
					              color: #FFFFFF;
 | 
				
			||||||
 | 
					              line-height: 24px;
 | 
				
			||||||
 | 
					              text-align: left;
 | 
				
			||||||
 | 
					              font-style: normal;
 | 
				
			||||||
 | 
					              display: inline-block;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            .line {
 | 
				
			||||||
 | 
					              flex: 1;
 | 
				
			||||||
 | 
					              // width: 80%;
 | 
				
			||||||
 | 
					              height: 1px; // display: inline-block;
 | 
				
			||||||
 | 
					              border: 1px solid;
 | 
				
			||||||
 | 
					              // display: inline-block;
 | 
				
			||||||
 | 
					              border-image: linear-gradient(90deg, rgba(25, 146, 255, 0) 10%, rgba(95, 190, 249, 1), rgba(0, 120, 228, 0) 90%, ) 2 2;
 | 
				
			||||||
 | 
					              backdrop-filter: blur(3px);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,10 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="prod-monitor">
 | 
					  <div class="prod-monitor">
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <div class="data">
 | 
				
			||||||
      <div class="fto-box">
 | 
					      <div class="fto-box">
 | 
				
			||||||
        <div class="icon">
 | 
					        <div class="icon">
 | 
				
			||||||
        <img
 | 
					          <img src="./../assets/images/fto.png" alt="" style="width: 2.1875vw; height: 2.2875vw" />
 | 
				
			||||||
          src="./../assets/images/fto.png"
 | 
					 | 
				
			||||||
          alt=""
 | 
					 | 
				
			||||||
          style="width: 2.1875vw; height: 2.2875vw"
 | 
					 | 
				
			||||||
        />
 | 
					 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="middle-box">
 | 
					        <div class="middle-box">
 | 
				
			||||||
          <span class="type">玻璃类型</span>
 | 
					          <span class="type">玻璃类型</span>
 | 
				
			||||||
@@ -14,16 +12,12 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="right-box">
 | 
					        <div class="right-box">
 | 
				
			||||||
          <span class="type">投入数量</span>
 | 
					          <span class="type">投入数量</span>
 | 
				
			||||||
        <span class="num">8391222</span>
 | 
					          <span class="num">{{ prodFto[0] ? prodFto[0].chipInput : 0 }}</span>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div class="std-box">
 | 
					      <div class="std-box">
 | 
				
			||||||
        <div class="icon">
 | 
					        <div class="icon">
 | 
				
			||||||
        <img
 | 
					          <img src="./../assets/images/std.png" alt="" style="width: 2.1875vw; height: 2.1875vw" />
 | 
				
			||||||
          src="./../assets/images/std.png"
 | 
					 | 
				
			||||||
          alt=""
 | 
					 | 
				
			||||||
          style="width: 2.1875vw; height: 2.1875vw"
 | 
					 | 
				
			||||||
        />
 | 
					 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="middle-box">
 | 
					        <div class="middle-box">
 | 
				
			||||||
          <div class="separate">
 | 
					          <div class="separate">
 | 
				
			||||||
@@ -33,7 +27,9 @@
 | 
				
			|||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div>
 | 
					            <div>
 | 
				
			||||||
              <span class="type">良品数量</span>
 | 
					              <span class="type">良品数量</span>
 | 
				
			||||||
            <span class="type-name">740</span>
 | 
					              <span class="type-name">{{
 | 
				
			||||||
 | 
					              msgObj.stand.goodNumber ? msgObj.stand.goodNumber : 0
 | 
				
			||||||
 | 
					              }}</span>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
@@ -41,22 +37,20 @@
 | 
				
			|||||||
          <div class="separate">
 | 
					          <div class="separate">
 | 
				
			||||||
            <div>
 | 
					            <div>
 | 
				
			||||||
              <span class="type">生产数量</span>
 | 
					              <span class="type">生产数量</span>
 | 
				
			||||||
            <span class="num">783</span>
 | 
					              <span class="num">{{
 | 
				
			||||||
 | 
					              msgObj.stand.outputNumber ? msgObj.stand.outputNumber : 0
 | 
				
			||||||
 | 
					              }}</span>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div>
 | 
					            <div>
 | 
				
			||||||
              <span class="type1">良品率</span>
 | 
					              <span class="type1">良品率</span>
 | 
				
			||||||
            <span class="num">96%</span>
 | 
					              <span class="num">{{ msgObj.stand.yieldRate ? msgObj.stand.yieldRate : 0 }}%</span>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div class="chip-box">
 | 
					      <div class="chip-box">
 | 
				
			||||||
        <div class="icon">
 | 
					        <div class="icon">
 | 
				
			||||||
        <img
 | 
					          <img src="./../assets/images/chip.png" alt="" style="width: 2.1875vw; height: 2.1875vw" />
 | 
				
			||||||
          src="./../assets/images/chip.png"
 | 
					 | 
				
			||||||
          alt=""
 | 
					 | 
				
			||||||
          style="width: 2.1875vw; height: 2.1875vw"
 | 
					 | 
				
			||||||
        />
 | 
					 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="middle-box">
 | 
					        <div class="middle-box">
 | 
				
			||||||
          <div class="separate">
 | 
					          <div class="separate">
 | 
				
			||||||
@@ -66,7 +60,9 @@
 | 
				
			|||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div>
 | 
					            <div>
 | 
				
			||||||
              <span class="type">良品数量</span>
 | 
					              <span class="type">良品数量</span>
 | 
				
			||||||
            <span class="type-name">740</span>
 | 
					              <span class="type-name">{{
 | 
				
			||||||
 | 
					              msgObj.chip.goodNumber ? msgObj.chip.goodNumber : 0
 | 
				
			||||||
 | 
					              }}</span>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
@@ -74,22 +70,20 @@
 | 
				
			|||||||
          <div class="separate">
 | 
					          <div class="separate">
 | 
				
			||||||
            <div>
 | 
					            <div>
 | 
				
			||||||
              <span class="type">生产数量</span>
 | 
					              <span class="type">生产数量</span>
 | 
				
			||||||
            <span class="num">783</span>
 | 
					              <span class="num">{{
 | 
				
			||||||
 | 
					              msgObj.chip.outputNumber ? msgObj.chip.outputNumber : 0
 | 
				
			||||||
 | 
					              }}</span>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div>
 | 
					            <div>
 | 
				
			||||||
              <span class="type1">良品率</span>
 | 
					              <span class="type1">良品率</span>
 | 
				
			||||||
            <span class="num">96%</span>
 | 
					              <span class="num">{{ msgObj.chip.yieldRate ? msgObj.chip.yieldRate : 0 }}%</span>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    <div class="bipv-box">
 | 
					      <div class="bipv-box" v-if="companyId != 0">
 | 
				
			||||||
        <div class="icon">
 | 
					        <div class="icon">
 | 
				
			||||||
        <img
 | 
					          <img src="./../assets/images/bipv.png" alt="" style="width: 2.1875vw; height: 2.1875vw" />
 | 
				
			||||||
          src="./../assets/images/bipv.png"
 | 
					 | 
				
			||||||
          alt=""
 | 
					 | 
				
			||||||
          style="width: 2.1875vw; height: 2.1875vw"
 | 
					 | 
				
			||||||
        />
 | 
					 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="middle-box">
 | 
					        <div class="middle-box">
 | 
				
			||||||
          <div class="separate">
 | 
					          <div class="separate">
 | 
				
			||||||
@@ -99,7 +93,9 @@
 | 
				
			|||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div>
 | 
					            <div>
 | 
				
			||||||
              <span class="type">良品数量</span>
 | 
					              <span class="type">良品数量</span>
 | 
				
			||||||
            <span class="type-name">740</span>
 | 
					              <span class="type-name">{{
 | 
				
			||||||
 | 
					              msgObj.bipv.goodNumber ? msgObj.bipv.goodNumber : 0
 | 
				
			||||||
 | 
					              }}</span>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
@@ -107,25 +103,154 @@
 | 
				
			|||||||
          <div class="separate">
 | 
					          <div class="separate">
 | 
				
			||||||
            <div>
 | 
					            <div>
 | 
				
			||||||
              <span class="type">生产数量</span>
 | 
					              <span class="type">生产数量</span>
 | 
				
			||||||
            <span class="num">783</span>
 | 
					              <span class="num">{{
 | 
				
			||||||
 | 
					              msgObj.bipv.outputNumber ? msgObj.bipv.outputNumber : 0
 | 
				
			||||||
 | 
					              }}</span>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div>
 | 
					            <div>
 | 
				
			||||||
              <span class="type1">良品率</span>
 | 
					              <span class="type1">良品率</span>
 | 
				
			||||||
            <span class="num">96%</span>
 | 
					              <span class="num">{{ msgObj.bipv.yieldRate ? msgObj.bipv.yieldRate : 0 }}%</span>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="chart">
 | 
				
			||||||
 | 
					      <div class="chart-title">
 | 
				
			||||||
 | 
					        <span class="title">生产情况</span>
 | 
				
			||||||
 | 
					        <span class="line"></span>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <barChartBase :companyId="companyId" :than="than" :period="period" :data="factoryData" ref="barChart"
 | 
				
			||||||
 | 
					        style="height: 0;flex:1">
 | 
				
			||||||
 | 
					      </barChartBase>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
 | 
					import { number } from 'echarts';
 | 
				
			||||||
 | 
					import barChartBase from './ChipOee'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "ProdMonitor",
 | 
					  name: "ProdMonitor",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    barChartBase,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      bipvVis:false,
 | 
				
			||||||
 | 
					      msgObj: {
 | 
				
			||||||
 | 
					        stand: {},
 | 
				
			||||||
 | 
					        chip: {},
 | 
				
			||||||
 | 
					        bipv: {},
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    period: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default: 1,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    companyId: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default:0
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: '同比',
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    prodOutPut: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      default: [],
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    prodFto: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      default: [],
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    factoryData: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      default: {},
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    showBipv: {
 | 
				
			||||||
 | 
					      type: Boolean,
 | 
				
			||||||
 | 
					      default:true,
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  watch: {
 | 
				
			||||||
 | 
					    prodOutPut() {
 | 
				
			||||||
 | 
					      this.makeData();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.makeData();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    makeData() {
 | 
				
			||||||
 | 
					      console.log('msgObj', this.msgObj);
 | 
				
			||||||
 | 
					      this.msgObj.chip = {};
 | 
				
			||||||
 | 
					      this.msgObj.stand = {};
 | 
				
			||||||
 | 
					      this.msgObj.bipv = {};
 | 
				
			||||||
 | 
					      if (this.prodOutPut.length > 0) {
 | 
				
			||||||
 | 
					        this.prodOutPut.map((item) => {
 | 
				
			||||||
 | 
					          if (item.glassType === 0) {
 | 
				
			||||||
 | 
					            this.msgObj.chip = item;
 | 
				
			||||||
 | 
					          } else if (item.glassType === 1) {
 | 
				
			||||||
 | 
					            this.msgObj.stand = item;
 | 
				
			||||||
 | 
					          } else if (item.glassType === 2) {
 | 
				
			||||||
 | 
					            this.msgObj.bipv = item;
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
<style lang="scss" scoped>
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
.prod-monitor {
 | 
					.prod-monitor {
 | 
				
			||||||
  height: 100%;
 | 
					  height: 100%;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  .chart{
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					    display: flex;
 | 
				
			||||||
 | 
					    flex-direction: column;
 | 
				
			||||||
 | 
					    position: relative;
 | 
				
			||||||
 | 
					    // gap: 6px;
 | 
				
			||||||
 | 
					    .chart-title{
 | 
				
			||||||
 | 
					      margin-top: 5px;
 | 
				
			||||||
 | 
					      // flex: 1;
 | 
				
			||||||
 | 
					      // gap: 6px;
 | 
				
			||||||
 | 
					      height: 1.5vw;
 | 
				
			||||||
 | 
					      width: 100%;
 | 
				
			||||||
 | 
					      display: flex;
 | 
				
			||||||
 | 
					      align-items: center;
 | 
				
			||||||
 | 
					      // flex-direction: column;
 | 
				
			||||||
 | 
					      // flex-wrap: nowrap;
 | 
				
			||||||
 | 
					      // justify-content: end
 | 
				
			||||||
 | 
					      // margin-top: 10px;
 | 
				
			||||||
 | 
					      .title{
 | 
				
			||||||
 | 
					        // flex: 1;
 | 
				
			||||||
 | 
					         font-weight: 400;
 | 
				
			||||||
 | 
					          font-size: 24px;
 | 
				
			||||||
 | 
					          // width: 5vw;
 | 
				
			||||||
 | 
					          color: #FFFFFF;
 | 
				
			||||||
 | 
					          line-height: 24px;
 | 
				
			||||||
 | 
					          text-align: left;
 | 
				
			||||||
 | 
					          font-style: normal;
 | 
				
			||||||
 | 
					          display: inline-block;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      .line{
 | 
				
			||||||
 | 
					        flex: 1;
 | 
				
			||||||
 | 
					        // width: 80%;
 | 
				
			||||||
 | 
					        height: 1px;        // display: inline-block;
 | 
				
			||||||
 | 
					        border: 1px solid;
 | 
				
			||||||
 | 
					        // display: inline-block;
 | 
				
			||||||
 | 
					        border-image: linear-gradient(90deg, rgba(25, 146, 255, 0) 10%, rgba(95, 190, 249, 1), rgba(0, 120, 228, 0) 90%,) 2 2;
 | 
				
			||||||
 | 
					        backdrop-filter: blur(3px);
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .data{
 | 
				
			||||||
 | 
					      flex: 1;
 | 
				
			||||||
      display: flex;
 | 
					      display: flex;
 | 
				
			||||||
        gap: 6px;
 | 
					        gap: 6px;
 | 
				
			||||||
        flex-direction: column;
 | 
					        flex-direction: column;
 | 
				
			||||||
@@ -137,18 +262,22 @@ export default {
 | 
				
			|||||||
          border-radius: 4px;
 | 
					          border-radius: 4px;
 | 
				
			||||||
          display: flex;
 | 
					          display: flex;
 | 
				
			||||||
          align-items: center;
 | 
					          align-items: center;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .icon {
 | 
					          .icon {
 | 
				
			||||||
            flex: 1;
 | 
					            flex: 1;
 | 
				
			||||||
            text-align: center;
 | 
					            text-align: center;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .middle-box {
 | 
					          .middle-box {
 | 
				
			||||||
            flex: 2.086;
 | 
					            flex: 2.086;
 | 
				
			||||||
            position: relative;
 | 
					            position: relative;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .right-box {
 | 
					          .right-box {
 | 
				
			||||||
            flex: 2.424;
 | 
					            flex: 2.424;
 | 
				
			||||||
            position: relative;
 | 
					            position: relative;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .type {
 | 
					          .type {
 | 
				
			||||||
            display: inline-block;
 | 
					            display: inline-block;
 | 
				
			||||||
            font-size: 0.9375vw;
 | 
					            font-size: 0.9375vw;
 | 
				
			||||||
@@ -159,6 +288,7 @@ export default {
 | 
				
			|||||||
            letter-spacing: 2px;
 | 
					            letter-spacing: 2px;
 | 
				
			||||||
            width: 6.25vw;
 | 
					            width: 6.25vw;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .type1 {
 | 
					          .type1 {
 | 
				
			||||||
            display: inline-block;
 | 
					            display: inline-block;
 | 
				
			||||||
            font-size: 0.9375vw;
 | 
					            font-size: 0.9375vw;
 | 
				
			||||||
@@ -171,6 +301,7 @@ export default {
 | 
				
			|||||||
            text-align: justify;
 | 
					            text-align: justify;
 | 
				
			||||||
            text-align-last: justify;
 | 
					            text-align-last: justify;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .type-name {
 | 
					          .type-name {
 | 
				
			||||||
            font-size: 1.042vw;
 | 
					            font-size: 1.042vw;
 | 
				
			||||||
            color: #fff;
 | 
					            color: #fff;
 | 
				
			||||||
@@ -178,22 +309,21 @@ export default {
 | 
				
			|||||||
            text-align: left;
 | 
					            text-align: left;
 | 
				
			||||||
            padding-left: 0.573vw;
 | 
					            padding-left: 0.573vw;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .type-name::before {
 | 
					          .type-name::before {
 | 
				
			||||||
            content: "";
 | 
					            content: "";
 | 
				
			||||||
            display: inline-block;
 | 
					            display: inline-block;
 | 
				
			||||||
            width: 1px;
 | 
					            width: 1px;
 | 
				
			||||||
            height: 1.042vw;
 | 
					            height: 1.042vw;
 | 
				
			||||||
            border: 1px solid;
 | 
					            border: 1px solid;
 | 
				
			||||||
      border-image: linear-gradient(
 | 
					            border-image: linear-gradient(180deg,
 | 
				
			||||||
          180deg,
 | 
					 | 
				
			||||||
                rgba(0, 176, 243, 0),
 | 
					                rgba(0, 176, 243, 0),
 | 
				
			||||||
          rgba(31, 143, 255, 1)
 | 
					                rgba(31, 143, 255, 1)) 2 2;
 | 
				
			||||||
        )
 | 
					 | 
				
			||||||
        2 2;
 | 
					 | 
				
			||||||
            position: absolute;
 | 
					            position: absolute;
 | 
				
			||||||
            left: 0;
 | 
					            left: 0;
 | 
				
			||||||
            top: 4px;
 | 
					            top: 4px;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .num {
 | 
					          .num {
 | 
				
			||||||
            font-size: 1.042vw;
 | 
					            font-size: 1.042vw;
 | 
				
			||||||
            color: #fff;
 | 
					            color: #fff;
 | 
				
			||||||
@@ -201,52 +331,53 @@ export default {
 | 
				
			|||||||
            text-align: left;
 | 
					            text-align: left;
 | 
				
			||||||
            padding-left: 0.573vw;
 | 
					            padding-left: 0.573vw;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .num::before {
 | 
					          .num::before {
 | 
				
			||||||
            content: "";
 | 
					            content: "";
 | 
				
			||||||
            display: inline-block;
 | 
					            display: inline-block;
 | 
				
			||||||
            width: 1px;
 | 
					            width: 1px;
 | 
				
			||||||
            height: 1.042vw;
 | 
					            height: 1.042vw;
 | 
				
			||||||
            border: 1px solid;
 | 
					            border: 1px solid;
 | 
				
			||||||
      border-image: linear-gradient(
 | 
					            border-image: linear-gradient(180deg,
 | 
				
			||||||
          180deg,
 | 
					 | 
				
			||||||
                rgba(0, 176, 243, 0),
 | 
					                rgba(0, 176, 243, 0),
 | 
				
			||||||
          rgba(31, 143, 255, 1)
 | 
					                rgba(31, 143, 255, 1)) 2 2;
 | 
				
			||||||
        )
 | 
					 | 
				
			||||||
        2 2;
 | 
					 | 
				
			||||||
            position: absolute;
 | 
					            position: absolute;
 | 
				
			||||||
            left: 0;
 | 
					            left: 0;
 | 
				
			||||||
            top: 4px;
 | 
					            top: 4px;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        .fto-box {
 | 
					        .fto-box {
 | 
				
			||||||
          flex: 1;
 | 
					          flex: 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          .type::before {
 | 
					          .type::before {
 | 
				
			||||||
            content: "";
 | 
					            content: "";
 | 
				
			||||||
            display: inline-block;
 | 
					            display: inline-block;
 | 
				
			||||||
            width: 1px;
 | 
					            width: 1px;
 | 
				
			||||||
            height: 1.6146vw;
 | 
					            height: 1.6146vw;
 | 
				
			||||||
            border: 1px solid;
 | 
					            border: 1px solid;
 | 
				
			||||||
      border-image: linear-gradient(
 | 
					            border-image: linear-gradient(135deg,
 | 
				
			||||||
          135deg,
 | 
					 | 
				
			||||||
                rgba(0, 176, 243, 0),
 | 
					                rgba(0, 176, 243, 0),
 | 
				
			||||||
                rgba(31, 143, 255, 1),
 | 
					                rgba(31, 143, 255, 1),
 | 
				
			||||||
          rgba(31, 143, 255, 0)
 | 
					                rgba(31, 143, 255, 0)) 2 2;
 | 
				
			||||||
        )
 | 
					 | 
				
			||||||
        2 2;
 | 
					 | 
				
			||||||
            position: absolute;
 | 
					            position: absolute;
 | 
				
			||||||
            left: 0;
 | 
					            left: 0;
 | 
				
			||||||
            top: -2px;
 | 
					            top: -2px;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        .std-box {
 | 
					        .std-box {
 | 
				
			||||||
          flex: 1.3;
 | 
					          flex: 1.3;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        .chip-box {
 | 
					        .chip-box {
 | 
				
			||||||
          flex: 1.3;
 | 
					          flex: 1.3;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        .bipv-box {
 | 
					        .bipv-box {
 | 
				
			||||||
          flex: 1.3;
 | 
					          flex: 1.3;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        .std-box,
 | 
					        .std-box,
 | 
				
			||||||
        .chip-box,
 | 
					        .chip-box,
 | 
				
			||||||
        .bipv-box {
 | 
					        .bipv-box {
 | 
				
			||||||
@@ -256,17 +387,16 @@ export default {
 | 
				
			|||||||
            width: 1px;
 | 
					            width: 1px;
 | 
				
			||||||
            height: 3.125vw;
 | 
					            height: 3.125vw;
 | 
				
			||||||
            border: 1px solid;
 | 
					            border: 1px solid;
 | 
				
			||||||
      border-image: linear-gradient(
 | 
					            border-image: linear-gradient(135deg,
 | 
				
			||||||
          135deg,
 | 
					 | 
				
			||||||
                rgba(0, 176, 243, 0),
 | 
					                rgba(0, 176, 243, 0),
 | 
				
			||||||
                rgba(31, 143, 255, 1),
 | 
					                rgba(31, 143, 255, 1),
 | 
				
			||||||
          rgba(31, 143, 255, 0)
 | 
					                rgba(31, 143, 255, 0)) 2 2;
 | 
				
			||||||
        )
 | 
					 | 
				
			||||||
        2 2;
 | 
					 | 
				
			||||||
            position: absolute;
 | 
					            position: absolute;
 | 
				
			||||||
            left: 0;
 | 
					            left: 0;
 | 
				
			||||||
            top: -2px;
 | 
					            top: -2px;
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</style>
 | 
					</style>
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										342
									
								
								src/views/copilot/factoryData/components/ProdMonitorOld.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,342 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2024-05-21 14:25:19
 | 
				
			||||||
 | 
					 * @LastEditTime: 2024-05-21 14:25:19
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="prod-monitor">
 | 
				
			||||||
 | 
					    <div class="fto-box">
 | 
				
			||||||
 | 
					      <div class="icon">
 | 
				
			||||||
 | 
					        <img
 | 
				
			||||||
 | 
					          src="./../assets/images/fto.png"
 | 
				
			||||||
 | 
					          alt=""
 | 
				
			||||||
 | 
					          style="width: 2.1875vw; height: 2.2875vw"
 | 
				
			||||||
 | 
					        />
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="middle-box">
 | 
				
			||||||
 | 
					        <span class="type">玻璃类型</span>
 | 
				
			||||||
 | 
					        <span class="type-name">FTO投入</span>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="right-box">
 | 
				
			||||||
 | 
					        <span class="type">投入数量</span>
 | 
				
			||||||
 | 
					        <span class="num">{{ prodFto[0] ? prodFto[0].chipInput : 0 }}</span>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="std-box">
 | 
				
			||||||
 | 
					      <div class="icon">
 | 
				
			||||||
 | 
					        <img
 | 
				
			||||||
 | 
					          src="./../assets/images/std.png"
 | 
				
			||||||
 | 
					          alt=""
 | 
				
			||||||
 | 
					          style="width: 2.1875vw; height: 2.1875vw"
 | 
				
			||||||
 | 
					        />
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="middle-box">
 | 
				
			||||||
 | 
					        <div class="separate">
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type">玻璃类型</span>
 | 
				
			||||||
 | 
					            <span class="type-name">标准组检产量</span>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type">良品数量</span>
 | 
				
			||||||
 | 
					            <span class="type-name">{{
 | 
				
			||||||
 | 
					              msgObj.stand.goodNumber ? msgObj.stand.goodNumber : 0
 | 
				
			||||||
 | 
					            }}</span>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="right-box">
 | 
				
			||||||
 | 
					        <div class="separate">
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type">生产数量</span>
 | 
				
			||||||
 | 
					            <span class="num">{{
 | 
				
			||||||
 | 
					              msgObj.stand.outputNumber ? msgObj.stand.outputNumber : 0
 | 
				
			||||||
 | 
					            }}</span>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type1">良品率</span>
 | 
				
			||||||
 | 
					            <span class="num"
 | 
				
			||||||
 | 
					              >{{ msgObj.stand.yieldRate ? msgObj.stand.yieldRate : 0 }}%</span
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="chip-box">
 | 
				
			||||||
 | 
					      <div class="icon">
 | 
				
			||||||
 | 
					        <img
 | 
				
			||||||
 | 
					          src="./../assets/images/chip.png"
 | 
				
			||||||
 | 
					          alt=""
 | 
				
			||||||
 | 
					          style="width: 2.1875vw; height: 2.1875vw"
 | 
				
			||||||
 | 
					        />
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="middle-box">
 | 
				
			||||||
 | 
					        <div class="separate">
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type">玻璃类型</span>
 | 
				
			||||||
 | 
					            <span class="type-name">芯片产量</span>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type">良品数量</span>
 | 
				
			||||||
 | 
					            <span class="type-name">{{
 | 
				
			||||||
 | 
					              msgObj.chip.goodNumber ? msgObj.chip.goodNumber : 0
 | 
				
			||||||
 | 
					            }}</span>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="right-box">
 | 
				
			||||||
 | 
					        <div class="separate">
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type">生产数量</span>
 | 
				
			||||||
 | 
					            <span class="num">{{
 | 
				
			||||||
 | 
					              msgObj.chip.outputNumber ? msgObj.chip.outputNumber : 0
 | 
				
			||||||
 | 
					            }}</span>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type1">良品率</span>
 | 
				
			||||||
 | 
					            <span class="num"
 | 
				
			||||||
 | 
					              >{{ msgObj.chip.yieldRate ? msgObj.chip.yieldRate : 0 }}%</span
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="bipv-box">
 | 
				
			||||||
 | 
					      <div class="icon">
 | 
				
			||||||
 | 
					        <img
 | 
				
			||||||
 | 
					          src="./../assets/images/bipv.png"
 | 
				
			||||||
 | 
					          alt=""
 | 
				
			||||||
 | 
					          style="width: 2.1875vw; height: 2.1875vw"
 | 
				
			||||||
 | 
					        />
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="middle-box">
 | 
				
			||||||
 | 
					        <div class="separate">
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type">玻璃类型</span>
 | 
				
			||||||
 | 
					            <span class="type-name">BIPV产量</span>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type">良品数量</span>
 | 
				
			||||||
 | 
					            <span class="type-name">{{
 | 
				
			||||||
 | 
					              msgObj.bipv.goodNumber ? msgObj.bipv.goodNumber : 0
 | 
				
			||||||
 | 
					            }}</span>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					      <div class="right-box">
 | 
				
			||||||
 | 
					        <div class="separate">
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type">生产数量</span>
 | 
				
			||||||
 | 
					            <span class="num">{{
 | 
				
			||||||
 | 
					              msgObj.bipv.outputNumber ? msgObj.bipv.outputNumber : 0
 | 
				
			||||||
 | 
					            }}</span>
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					          <div>
 | 
				
			||||||
 | 
					            <span class="type1">良品率</span>
 | 
				
			||||||
 | 
					            <span class="num"
 | 
				
			||||||
 | 
					              >{{ msgObj.bipv.yieldRate ? msgObj.bipv.yieldRate : 0 }}%</span
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					          </div>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "ProdMonitor",
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      msgObj: {
 | 
				
			||||||
 | 
					        stand: {},
 | 
				
			||||||
 | 
					        chip: {},
 | 
				
			||||||
 | 
					        bipv: {},
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    prodOutPut: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      default: [],
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    prodFto: {
 | 
				
			||||||
 | 
					      type: Array,
 | 
				
			||||||
 | 
					      default: [],
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  watch: {
 | 
				
			||||||
 | 
					    prodOutPut() {
 | 
				
			||||||
 | 
					      this.makeData();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.makeData();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    makeData() {
 | 
				
			||||||
 | 
					      this.msgObj.chip = {};
 | 
				
			||||||
 | 
					      this.msgObj.stand = {};
 | 
				
			||||||
 | 
					      this.msgObj.bipv = {};
 | 
				
			||||||
 | 
					      if (this.prodOutPut.length > 0) {
 | 
				
			||||||
 | 
					        this.prodOutPut.map((item) => {
 | 
				
			||||||
 | 
					          if (item.glassType === 0) {
 | 
				
			||||||
 | 
					            this.msgObj.chip = item;
 | 
				
			||||||
 | 
					          } else if (item.glassType === 1) {
 | 
				
			||||||
 | 
					            this.msgObj.stand = item;
 | 
				
			||||||
 | 
					          } else if (item.glassType === 2) {
 | 
				
			||||||
 | 
					            this.msgObj.bipv = item;
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.prod-monitor {
 | 
				
			||||||
 | 
					  height: 100%;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  gap: 6px;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  .fto-box,
 | 
				
			||||||
 | 
					  .std-box,
 | 
				
			||||||
 | 
					  .chip-box,
 | 
				
			||||||
 | 
					  .bipv-box {
 | 
				
			||||||
 | 
					    box-shadow: inset 0 0 12px 2px #fff3;
 | 
				
			||||||
 | 
					    border-radius: 4px;
 | 
				
			||||||
 | 
					    display: flex;
 | 
				
			||||||
 | 
					    align-items: center;
 | 
				
			||||||
 | 
					    .icon {
 | 
				
			||||||
 | 
					      flex: 1;
 | 
				
			||||||
 | 
					      text-align: center;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    .middle-box {
 | 
				
			||||||
 | 
					      flex: 2.086;
 | 
				
			||||||
 | 
					      position: relative;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    .right-box {
 | 
				
			||||||
 | 
					      flex: 2.424;
 | 
				
			||||||
 | 
					      position: relative;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    .type {
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      font-size: 0.9375vw;
 | 
				
			||||||
 | 
					      color: #6db6ff;
 | 
				
			||||||
 | 
					      position: relative;
 | 
				
			||||||
 | 
					      text-align: right;
 | 
				
			||||||
 | 
					      padding-right: 0.417vw;
 | 
				
			||||||
 | 
					      letter-spacing: 2px;
 | 
				
			||||||
 | 
					      width: 6.25vw;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    .type1 {
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      font-size: 0.9375vw;
 | 
				
			||||||
 | 
					      color: #6db6ff;
 | 
				
			||||||
 | 
					      position: relative;
 | 
				
			||||||
 | 
					      text-align: right;
 | 
				
			||||||
 | 
					      padding-right: 0.6vw;
 | 
				
			||||||
 | 
					      width: 6.25vw;
 | 
				
			||||||
 | 
					      padding-left: 1.6vw;
 | 
				
			||||||
 | 
					      text-align: justify;
 | 
				
			||||||
 | 
					      text-align-last: justify;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    .type-name {
 | 
				
			||||||
 | 
					      font-size: 1.042vw;
 | 
				
			||||||
 | 
					      color: #fff;
 | 
				
			||||||
 | 
					      position: relative;
 | 
				
			||||||
 | 
					      text-align: left;
 | 
				
			||||||
 | 
					      padding-left: 0.573vw;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    .type-name::before {
 | 
				
			||||||
 | 
					      content: "";
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      width: 1px;
 | 
				
			||||||
 | 
					      height: 1.042vw;
 | 
				
			||||||
 | 
					      border: 1px solid;
 | 
				
			||||||
 | 
					      border-image: linear-gradient(
 | 
				
			||||||
 | 
					          180deg,
 | 
				
			||||||
 | 
					          rgba(0, 176, 243, 0),
 | 
				
			||||||
 | 
					          rgba(31, 143, 255, 1)
 | 
				
			||||||
 | 
					        )
 | 
				
			||||||
 | 
					        2 2;
 | 
				
			||||||
 | 
					      position: absolute;
 | 
				
			||||||
 | 
					      left: 0;
 | 
				
			||||||
 | 
					      top: 4px;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    .num {
 | 
				
			||||||
 | 
					      font-size: 1.042vw;
 | 
				
			||||||
 | 
					      color: #fff;
 | 
				
			||||||
 | 
					      position: relative;
 | 
				
			||||||
 | 
					      text-align: left;
 | 
				
			||||||
 | 
					      padding-left: 0.573vw;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    .num::before {
 | 
				
			||||||
 | 
					      content: "";
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      width: 1px;
 | 
				
			||||||
 | 
					      height: 1.042vw;
 | 
				
			||||||
 | 
					      border: 1px solid;
 | 
				
			||||||
 | 
					      border-image: linear-gradient(
 | 
				
			||||||
 | 
					          180deg,
 | 
				
			||||||
 | 
					          rgba(0, 176, 243, 0),
 | 
				
			||||||
 | 
					          rgba(31, 143, 255, 1)
 | 
				
			||||||
 | 
					        )
 | 
				
			||||||
 | 
					        2 2;
 | 
				
			||||||
 | 
					      position: absolute;
 | 
				
			||||||
 | 
					      left: 0;
 | 
				
			||||||
 | 
					      top: 4px;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .fto-box {
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					    .type::before {
 | 
				
			||||||
 | 
					      content: "";
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      width: 1px;
 | 
				
			||||||
 | 
					      height: 1.6146vw;
 | 
				
			||||||
 | 
					      border: 1px solid;
 | 
				
			||||||
 | 
					      border-image: linear-gradient(
 | 
				
			||||||
 | 
					          135deg,
 | 
				
			||||||
 | 
					          rgba(0, 176, 243, 0),
 | 
				
			||||||
 | 
					          rgba(31, 143, 255, 1),
 | 
				
			||||||
 | 
					          rgba(31, 143, 255, 0)
 | 
				
			||||||
 | 
					        )
 | 
				
			||||||
 | 
					        2 2;
 | 
				
			||||||
 | 
					      position: absolute;
 | 
				
			||||||
 | 
					      left: 0;
 | 
				
			||||||
 | 
					      top: -2px;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .std-box {
 | 
				
			||||||
 | 
					    flex: 1.3;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .chip-box {
 | 
				
			||||||
 | 
					    flex: 1.3;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .bipv-box {
 | 
				
			||||||
 | 
					    flex: 1.3;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .std-box,
 | 
				
			||||||
 | 
					  .chip-box,
 | 
				
			||||||
 | 
					  .bipv-box {
 | 
				
			||||||
 | 
					    .separate::before {
 | 
				
			||||||
 | 
					      content: "";
 | 
				
			||||||
 | 
					      display: inline-block;
 | 
				
			||||||
 | 
					      width: 1px;
 | 
				
			||||||
 | 
					      height: 3.125vw;
 | 
				
			||||||
 | 
					      border: 1px solid;
 | 
				
			||||||
 | 
					      border-image: linear-gradient(
 | 
				
			||||||
 | 
					          135deg,
 | 
				
			||||||
 | 
					          rgba(0, 176, 243, 0),
 | 
				
			||||||
 | 
					          rgba(31, 143, 255, 1),
 | 
				
			||||||
 | 
					          rgba(31, 143, 255, 0)
 | 
				
			||||||
 | 
					        )
 | 
				
			||||||
 | 
					        2 2;
 | 
				
			||||||
 | 
					      position: absolute;
 | 
				
			||||||
 | 
					      left: 0;
 | 
				
			||||||
 | 
					      top: -2px;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
@@ -7,17 +7,14 @@ import * as echarts from "echarts";
 | 
				
			|||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "Store",
 | 
					  name: "Store",
 | 
				
			||||||
  props: {
 | 
					  props: {
 | 
				
			||||||
    vHeight: {
 | 
					    stock: {
 | 
				
			||||||
      type: Number,
 | 
					      type: Object,
 | 
				
			||||||
      default: 34,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    xAxis: {
 | 
					 | 
				
			||||||
      type: Array,
 | 
					 | 
				
			||||||
      required: true,
 | 
					      required: true,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    series: {
 | 
					  },
 | 
				
			||||||
      type: Array,
 | 
					  computed: {
 | 
				
			||||||
      required: true,
 | 
					    isOpen() {
 | 
				
			||||||
 | 
					      return this.$store.getters.sidebar.opened;
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
@@ -27,11 +24,10 @@ export default {
 | 
				
			|||||||
      chart: "",
 | 
					      chart: "",
 | 
				
			||||||
      options: {
 | 
					      options: {
 | 
				
			||||||
        grid: {
 | 
					        grid: {
 | 
				
			||||||
          left: "3%",
 | 
					          left: "8%",
 | 
				
			||||||
          right: "1%",
 | 
					          right: "1%",
 | 
				
			||||||
          bottom: "0",
 | 
					          bottom: "8%",
 | 
				
			||||||
          top: "10%",
 | 
					          top: "15%",
 | 
				
			||||||
          containLabel: true,
 | 
					 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        tooltip: {},
 | 
					        tooltip: {},
 | 
				
			||||||
        xAxis: {
 | 
					        xAxis: {
 | 
				
			||||||
@@ -47,7 +43,7 @@ export default {
 | 
				
			|||||||
            color: "rgba(255, 255, 255, 0.7)",
 | 
					            color: "rgba(255, 255, 255, 0.7)",
 | 
				
			||||||
            fontSize: 12,
 | 
					            fontSize: 12,
 | 
				
			||||||
          },
 | 
					          },
 | 
				
			||||||
          data: this.xAxis,
 | 
					          data: [],
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        yAxis: {
 | 
					        yAxis: {
 | 
				
			||||||
          name: "单位/片",
 | 
					          name: "单位/片",
 | 
				
			||||||
@@ -116,18 +112,11 @@ export default {
 | 
				
			|||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  watch: {
 | 
					  watch: {
 | 
				
			||||||
    series(val) {
 | 
					    stock(val) {
 | 
				
			||||||
      if (!val) {
 | 
					      this.initChart();
 | 
				
			||||||
        this.initOptions(this.options);
 | 
					    },
 | 
				
			||||||
        return;
 | 
					    isOpen(val) {
 | 
				
			||||||
      }
 | 
					      this.canvasReset();
 | 
				
			||||||
      const actualOptions = JSON.parse(JSON.stringify(this.options));
 | 
					 | 
				
			||||||
      actualOptions.series[0].data = val[0].data;
 | 
					 | 
				
			||||||
      actualOptions.series[0].name = val[0].name;
 | 
					 | 
				
			||||||
      actualOptions.series[1].data = val[1].data;
 | 
					 | 
				
			||||||
      actualOptions.series[1].name = val[1].name;
 | 
					 | 
				
			||||||
      this.actualOptions = actualOptions;
 | 
					 | 
				
			||||||
      this.initOptions(actualOptions);
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  mounted() {
 | 
					  mounted() {
 | 
				
			||||||
@@ -154,13 +143,20 @@ export default {
 | 
				
			|||||||
      }, 500)();
 | 
					      }, 500)();
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    initChart() {
 | 
					    initChart() {
 | 
				
			||||||
 | 
					      let xAxis = Object.keys(this.stock) || [];
 | 
				
			||||||
 | 
					      let data = [];
 | 
				
			||||||
 | 
					      if (xAxis.length > 0) {
 | 
				
			||||||
 | 
					        data = xAxis.map((item) => {
 | 
				
			||||||
 | 
					          return this.stock[item].total;
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
      if (this.chart) {
 | 
					      if (this.chart) {
 | 
				
			||||||
        this.chart.dispose();
 | 
					        this.chart.dispose();
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      this.chart = echarts.init(document.getElementById("factoryStoreChart"));
 | 
					      this.chart = echarts.init(document.getElementById("factoryStoreChart"));
 | 
				
			||||||
      const actualOptions = JSON.parse(JSON.stringify(this.options));
 | 
					      const actualOptions = JSON.parse(JSON.stringify(this.options));
 | 
				
			||||||
      actualOptions.series[0].data = this.series[0].data;
 | 
					      actualOptions.xAxis.data = xAxis;
 | 
				
			||||||
      actualOptions.series[0].name = this.series[0].name;
 | 
					      actualOptions.series[0].data = data;
 | 
				
			||||||
      this.actualOptions = actualOptions;
 | 
					      this.actualOptions = actualOptions;
 | 
				
			||||||
      this.chart.setOption(actualOptions);
 | 
					      this.chart.setOption(actualOptions);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										216
									
								
								src/views/copilot/factoryData/hdIndex.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,216 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="factory-layout">
 | 
				
			||||||
 | 
					    <FactoryDataHeader :than="than" :companyName="companyName" :companyId="companyId" :period="period"
 | 
				
			||||||
 | 
					      @update:than="updateThan" @update:period="updatePeriod" />
 | 
				
			||||||
 | 
					    <div class="factory-section">
 | 
				
			||||||
 | 
					      <section class="top flex">
 | 
				
			||||||
 | 
					        <db-container title="生产监控" icon="prod">
 | 
				
			||||||
 | 
					          <prod-monitor :companyId="companyId" :factoryData="factoryData" :than="than" :period="period" :data="data"
 | 
				
			||||||
 | 
					            :prodOutPut="prodOutPut" :prodFto="prodFto" :showBipv="show" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <db-container title="工单监控" icon="order">
 | 
				
			||||||
 | 
					          <order :prodOrder="prodOrder" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <!-- <db-container title="" icon="store"> -->
 | 
				
			||||||
 | 
					        <!-- <store :stock="stock" /> -->
 | 
				
			||||||
 | 
					        <!-- </db-container> -->
 | 
				
			||||||
 | 
					      </section>
 | 
				
			||||||
 | 
					      <!-- <section class="bottom flex"> -->
 | 
				
			||||||
 | 
					      <!-- <db-container title="" icon="energy"> -->
 | 
				
			||||||
 | 
					      <!-- <energy :legend="energyLegend" :energyCockpits="energyCockpits" /> -->
 | 
				
			||||||
 | 
					      <!-- </db-container> -->
 | 
				
			||||||
 | 
					      <!-- </section> -->
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="factory-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import FactoryDataHeader from "./../components/FactoryDataHeader.vue";
 | 
				
			||||||
 | 
					import Container from "./components/Container.vue";
 | 
				
			||||||
 | 
					import ProdMonitor from "./components/ProdMonitor.vue";
 | 
				
			||||||
 | 
					import { deepClone } from "@/utils";
 | 
				
			||||||
 | 
					// import Store from "./components/Store.vue";
 | 
				
			||||||
 | 
					// import Energy from "./components/Energy.vue";
 | 
				
			||||||
 | 
					import Order from "./components/Order.vue";
 | 
				
			||||||
 | 
					import { cockpitDataMonitor } from "@/api/produceData";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "factoryData",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    FactoryDataHeader,
 | 
				
			||||||
 | 
					    DbContainer: Container,
 | 
				
			||||||
 | 
					    ProdMonitor,
 | 
				
			||||||
 | 
					    // Store,
 | 
				
			||||||
 | 
					    // Energy,
 | 
				
			||||||
 | 
					    Order,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      companyId: 1,
 | 
				
			||||||
 | 
					      companyName: "邯郸中建材光电材料有限公司",
 | 
				
			||||||
 | 
					      period: 1,
 | 
				
			||||||
 | 
					      show: false,
 | 
				
			||||||
 | 
					      than: '同比',
 | 
				
			||||||
 | 
					      data: {},
 | 
				
			||||||
 | 
					      // 接口获取的数据
 | 
				
			||||||
 | 
					      prodOutPut: [], //生产
 | 
				
			||||||
 | 
					      prodFto: [], //生产
 | 
				
			||||||
 | 
					      stock: {}, //仓库
 | 
				
			||||||
 | 
					      factoryData: {
 | 
				
			||||||
 | 
					        preDataDetail: [],
 | 
				
			||||||
 | 
					        currentDataDetail: {},
 | 
				
			||||||
 | 
					        targetDataDetail: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      energyCockpits: [], //能源
 | 
				
			||||||
 | 
					      prodOrder: [], //订单
 | 
				
			||||||
 | 
					      energyLegend: [
 | 
				
			||||||
 | 
					        { label: "电", color: "#FFD160" },
 | 
				
			||||||
 | 
					        { label: "水", color: "#2760FF" },
 | 
				
			||||||
 | 
					        { label: "气", color: "#12FFF5" },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.getMes();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    updateCompany(obj) {
 | 
				
			||||||
 | 
					      this.companyId = obj.companyId;
 | 
				
			||||||
 | 
					      this.companyName = obj.companyName;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updateThan(val) {
 | 
				
			||||||
 | 
					      console.log(val);
 | 
				
			||||||
 | 
					      this.than = val;
 | 
				
			||||||
 | 
					      // this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updatePeriod(val) {
 | 
				
			||||||
 | 
					      this.period = val;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getMes() {
 | 
				
			||||||
 | 
					      cockpitDataMonitor({
 | 
				
			||||||
 | 
					        factorys: [this.companyId],
 | 
				
			||||||
 | 
					        date: this.period,
 | 
				
			||||||
 | 
					        mode: this.than === '同比' ? 0 : 1
 | 
				
			||||||
 | 
					      }).then((res) => {
 | 
				
			||||||
 | 
					        console.log(res);
 | 
				
			||||||
 | 
					        this.prodOutPut = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        this.prodFto = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        this.prodOrder = res.data.prodWorkOrderDO || [];
 | 
				
			||||||
 | 
					        let prodOutputFtoListRes = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preFtoData = res.data.previousProdOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preData = res.data.previousProdOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let factoryListResponse = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let targetListResponse = res.data.prodTargetMonitorDO || [];
 | 
				
			||||||
 | 
					        let preDataDetail = []
 | 
				
			||||||
 | 
					        let currentDataDetail = []
 | 
				
			||||||
 | 
					        let targetDataDetail = []
 | 
				
			||||||
 | 
					        if (prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					          for (const factory of prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            currentDataDetail[0] = factory.chipInput
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preFtoData) {
 | 
				
			||||||
 | 
					          for (const factory of preFtoData) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            // const fId = this.getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // if (fId) {
 | 
				
			||||||
 | 
					            preDataDetail[0] = factory.previousYearChipInput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					            // if (preFId) {
 | 
				
			||||||
 | 
					            // ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preData && preData[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of preData) {
 | 
				
			||||||
 | 
					            if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					              preDataDetail[1] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					              preDataDetail[2] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousYearOutputNumber === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (targetListResponse && targetListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of targetListResponse) {
 | 
				
			||||||
 | 
					            targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            // if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					            targetDataDetail[1] = factory.chipYield
 | 
				
			||||||
 | 
					            // } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					            targetDataDetail[2] = factory.componentYield
 | 
				
			||||||
 | 
					            targetDataDetail[3] = factory.bipvProductoutput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // console.log('ftoInvest',ftoInvest)
 | 
				
			||||||
 | 
					        if (factoryListResponse && factoryListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of factoryListResponse) {
 | 
				
			||||||
 | 
					            // targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            if (factory.glassType === 0) {
 | 
				
			||||||
 | 
					              currentDataDetail[1] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 1) {
 | 
				
			||||||
 | 
					              currentDataDetail[2] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.factoryData.preDataDetail = preDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.currentDataDetail = currentDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.targetDataDetail = targetDataDetail
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.factory-layout {
 | 
				
			||||||
 | 
					  padding: 16px;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/copilot-bg.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  height: calc(100% + 38px);
 | 
				
			||||||
 | 
					  left: -16px;
 | 
				
			||||||
 | 
					  top: -8px;
 | 
				
			||||||
 | 
					  width: calc(100% + 30px);
 | 
				
			||||||
 | 
					  z-index: 1001;
 | 
				
			||||||
 | 
					  color: #fff;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  gap: 8px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-section {
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					    display: flex;
 | 
				
			||||||
 | 
					    flex-direction: column;
 | 
				
			||||||
 | 
					    gap: 16px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .flex {
 | 
				
			||||||
 | 
					      display: flex;
 | 
				
			||||||
 | 
					      gap: 16px;
 | 
				
			||||||
 | 
					      flex: 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .top>div,
 | 
				
			||||||
 | 
					    .bottom>div {
 | 
				
			||||||
 | 
					      height: 100%;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-footer {
 | 
				
			||||||
 | 
					    /** position: absolute;
 | 
				
			||||||
 | 
					  bottom: 10px; **/
 | 
				
			||||||
 | 
					    height: 10px;
 | 
				
			||||||
 | 
					    width: 100%;
 | 
				
			||||||
 | 
					    color: rgb(80, 80, 80);
 | 
				
			||||||
 | 
					    user-select: none;
 | 
				
			||||||
 | 
					    font-size: 14px;
 | 
				
			||||||
 | 
					    letter-spacing: 1px;
 | 
				
			||||||
 | 
					    display: grid;
 | 
				
			||||||
 | 
					    place-content: center;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
@@ -1,33 +1,25 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="factory-layout">
 | 
					  <div class="factory-layout">
 | 
				
			||||||
    <FactoryDataHeader
 | 
					    <FactoryDataHeader :than="than" :companyName="companyName" :companyId="companyId" :period="period"
 | 
				
			||||||
      :companyName="companyName"
 | 
					      @update:than="updateThan" @update:period="updatePeriod" />
 | 
				
			||||||
      :companyId="companyId"
 | 
					 | 
				
			||||||
      :period="period"
 | 
					 | 
				
			||||||
      @updateCompany="updateCompany"
 | 
					 | 
				
			||||||
      @update:period="period = $event"
 | 
					 | 
				
			||||||
    />
 | 
					 | 
				
			||||||
    <div class="factory-section">
 | 
					    <div class="factory-section">
 | 
				
			||||||
      <section class="top flex">
 | 
					      <section class="top flex">
 | 
				
			||||||
        <db-container title="生产监控" icon="prod">
 | 
					        <db-container title="生产监控" icon="prod">
 | 
				
			||||||
          <prod-monitor />
 | 
					          <prod-monitor :companyId="companyId" :factoryData="factoryData" :than="than" :period="period" :data="data"
 | 
				
			||||||
 | 
					            :prodOutPut="prodOutPut" :prodFto="prodFto" :showBipv="show" />
 | 
				
			||||||
        </db-container>
 | 
					        </db-container>
 | 
				
			||||||
        <db-container title="仓库监控.当前" icon="store">
 | 
					        <db-container title="工单监控" icon="order">
 | 
				
			||||||
          <store :series="series" :xAxis="xAxis" />
 | 
					          <order :prodOrder="prodOrder" />
 | 
				
			||||||
        </db-container>
 | 
					 | 
				
			||||||
      </section>
 | 
					 | 
				
			||||||
      <section class="bottom flex">
 | 
					 | 
				
			||||||
        <db-container title="能源监控" icon="energy">
 | 
					 | 
				
			||||||
          <energy
 | 
					 | 
				
			||||||
            :legend="energyLegend"
 | 
					 | 
				
			||||||
            :series="energySeries"
 | 
					 | 
				
			||||||
            :xAxis="energyxAxis"
 | 
					 | 
				
			||||||
          />
 | 
					 | 
				
			||||||
        </db-container>
 | 
					 | 
				
			||||||
        <db-container title="订单监控" icon="order">
 | 
					 | 
				
			||||||
          <order />
 | 
					 | 
				
			||||||
        </db-container>
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <!-- <db-container title="" icon="store"> -->
 | 
				
			||||||
 | 
					        <!-- <store :stock="stock" /> -->
 | 
				
			||||||
 | 
					        <!-- </db-container> -->
 | 
				
			||||||
      </section>
 | 
					      </section>
 | 
				
			||||||
 | 
					      <!-- <section class="bottom flex"> -->
 | 
				
			||||||
 | 
					      <!-- <db-container title="" icon="energy"> -->
 | 
				
			||||||
 | 
					      <!-- <energy :legend="energyLegend" :energyCockpits="energyCockpits" /> -->
 | 
				
			||||||
 | 
					      <!-- </db-container> -->
 | 
				
			||||||
 | 
					      <!-- </section> -->
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <div class="factory-footer">© 中建材智能自动化研究院有限公司</div>
 | 
					    <div class="factory-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
@@ -36,106 +28,138 @@
 | 
				
			|||||||
import FactoryDataHeader from "./../components/FactoryDataHeader.vue";
 | 
					import FactoryDataHeader from "./../components/FactoryDataHeader.vue";
 | 
				
			||||||
import Container from "./components/Container.vue";
 | 
					import Container from "./components/Container.vue";
 | 
				
			||||||
import ProdMonitor from "./components/ProdMonitor.vue";
 | 
					import ProdMonitor from "./components/ProdMonitor.vue";
 | 
				
			||||||
import Store from "./components/Store.vue";
 | 
					import { deepClone } from "@/utils";
 | 
				
			||||||
import Energy from "./components/Energy.vue";
 | 
					// import Store from "./components/Store.vue";
 | 
				
			||||||
 | 
					// import Energy from "./components/Energy.vue";
 | 
				
			||||||
import Order from "./components/Order.vue";
 | 
					import Order from "./components/Order.vue";
 | 
				
			||||||
import { cockpitDataMonitor } from "@/api/produceData";
 | 
					import { cockpitDataMonitor } from "@/api/produceData";
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "FactoryData",
 | 
					  name: "factoryData",
 | 
				
			||||||
  components: {
 | 
					  components: {
 | 
				
			||||||
    FactoryDataHeader,
 | 
					    FactoryDataHeader,
 | 
				
			||||||
    DbContainer: Container,
 | 
					    DbContainer: Container,
 | 
				
			||||||
    ProdMonitor,
 | 
					    ProdMonitor,
 | 
				
			||||||
    Store,
 | 
					    // Store,
 | 
				
			||||||
    Energy,
 | 
					    // Energy,
 | 
				
			||||||
    Order,
 | 
					    Order,
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    const year = new Date().getFullYear();
 | 
					 | 
				
			||||||
    const cities = ["瑞昌", "邯郸", "株洲", "佳木斯", "成都", "凯盛", "蚌埠"];
 | 
					 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      companyId: "1",
 | 
					      companyId: 0,
 | 
				
			||||||
      companyName: "瑞昌中建材光电材料有限公司",
 | 
					      companyName: "瑞昌中建材光电材料有限公司",
 | 
				
			||||||
      period: "日",
 | 
					      period: 1,
 | 
				
			||||||
 | 
					      show:false,
 | 
				
			||||||
 | 
					      than: '同比',
 | 
				
			||||||
 | 
					      data:{},
 | 
				
			||||||
 | 
					      // 接口获取的数据
 | 
				
			||||||
 | 
					      prodOutPut: [], //生产
 | 
				
			||||||
 | 
					      prodFto: [], //生产
 | 
				
			||||||
 | 
					      stock: {}, //仓库
 | 
				
			||||||
 | 
					      factoryData: {
 | 
				
			||||||
 | 
					        preDataDetail: [],
 | 
				
			||||||
 | 
					        currentDataDetail: {},
 | 
				
			||||||
 | 
					        targetDataDetail: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      energyCockpits: [], //能源
 | 
				
			||||||
 | 
					      prodOrder: [], //订单
 | 
				
			||||||
      energyLegend: [
 | 
					      energyLegend: [
 | 
				
			||||||
        { label: "电", color: "#FFD160" },
 | 
					        { label: "电", color: "#FFD160" },
 | 
				
			||||||
        { label: "水", color: "#2760FF" },
 | 
					        { label: "水", color: "#2760FF" },
 | 
				
			||||||
        { label: "气", color: "#12FFF5" },
 | 
					        { label: "气", color: "#12FFF5" },
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      energyxAxis: [3.1, 3.2, 3.3, 3.4, 3.5, 3.6, 3.7],
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      legend: [
 | 
					 | 
				
			||||||
        { label: `${year - 1}年`, color: "#12f7f1" },
 | 
					 | 
				
			||||||
        // { label: `${year}年`, color: "#58adfa" },
 | 
					 | 
				
			||||||
      ],
 | 
					 | 
				
			||||||
      xAxis: cities,
 | 
					 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					 | 
				
			||||||
    energySeries() {
 | 
					 | 
				
			||||||
      return [
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: "电",
 | 
					 | 
				
			||||||
          data: Array.from({ length: 7 }, () =>
 | 
					 | 
				
			||||||
            Math.floor(Math.random() * 1000)
 | 
					 | 
				
			||||||
          ),
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: "水",
 | 
					 | 
				
			||||||
          data: Array.from({ length: 7 }, () =>
 | 
					 | 
				
			||||||
            Math.floor(Math.random() * 1000)
 | 
					 | 
				
			||||||
          ),
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: "气",
 | 
					 | 
				
			||||||
          data: Array.from({ length: 7 }, () =>
 | 
					 | 
				
			||||||
            Math.floor(Math.random() * 1000)
 | 
					 | 
				
			||||||
          ),
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      ];
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    series() {
 | 
					 | 
				
			||||||
      // const ftoInvest = this.$store.getters.home.ftoInvest;
 | 
					 | 
				
			||||||
      // if (!ftoInvest || !ftoInvest.current || !ftoInvest.previous) {
 | 
					 | 
				
			||||||
      return [
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: "2023年",
 | 
					 | 
				
			||||||
          data: Array.from({ length: 7 }, () =>
 | 
					 | 
				
			||||||
            Math.floor(Math.random() * 1000)
 | 
					 | 
				
			||||||
          ),
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      ];
 | 
					 | 
				
			||||||
      // }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      // return [
 | 
					 | 
				
			||||||
      //   {
 | 
					 | 
				
			||||||
      //     name: `${new Date().getFullYear() - 1}年`,
 | 
					 | 
				
			||||||
      //     data: ftoInvest.previous,
 | 
					 | 
				
			||||||
      //   },
 | 
					 | 
				
			||||||
      //   {
 | 
					 | 
				
			||||||
      //     name: `${new Date().getFullYear()}年`,
 | 
					 | 
				
			||||||
      //     data: ftoInvest.current,
 | 
					 | 
				
			||||||
      //   },
 | 
					 | 
				
			||||||
      // ];
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
  mounted() {
 | 
					  mounted() {
 | 
				
			||||||
    this.getMes1();
 | 
					    this.getMes();
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    updateCompany(obj) {
 | 
					    updateCompany(obj) {
 | 
				
			||||||
      this.companyId = obj.companyId;
 | 
					      this.companyId = obj.companyId;
 | 
				
			||||||
      this.companyName = obj.companyName;
 | 
					      this.companyName = obj.companyName;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    getMes1() {
 | 
					    updateThan(val) {
 | 
				
			||||||
      // cockpitDataMonitor({
 | 
					      console.log(val);
 | 
				
			||||||
      //   factorys: ["1"],
 | 
					      this.than = val;
 | 
				
			||||||
      //   date: 4,
 | 
					      // this.getMes();
 | 
				
			||||||
      // }).then((res) => {
 | 
					    },
 | 
				
			||||||
      //   console.log(res);
 | 
					    updatePeriod(val) {
 | 
				
			||||||
      // });
 | 
					      this.period = val;
 | 
				
			||||||
      cockpitDataMonitor().then((res) => {});
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getMes() {
 | 
				
			||||||
 | 
					      cockpitDataMonitor({
 | 
				
			||||||
 | 
					        factorys: [this.companyId],
 | 
				
			||||||
 | 
					        date: this.period,
 | 
				
			||||||
 | 
					        mode:this.than === '同比' ? 0 : 1
 | 
				
			||||||
 | 
					      }).then((res) => {
 | 
				
			||||||
 | 
					        console.log(res);
 | 
				
			||||||
 | 
					        this.prodOutPut = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        this.prodFto = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        this.prodOrder = res.data.prodWorkOrderDO || [];
 | 
				
			||||||
 | 
					        let prodOutputFtoListRes = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preFtoData = res.data.previousProdOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preData = res.data.previousProdOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let factoryListResponse = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let targetListResponse = res.data.prodTargetMonitorDO || [];
 | 
				
			||||||
 | 
					        let preDataDetail = []
 | 
				
			||||||
 | 
					        let currentDataDetail = []
 | 
				
			||||||
 | 
					        let targetDataDetail = []
 | 
				
			||||||
 | 
					        if (prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					          for (const factory of prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            currentDataDetail[0] = factory.chipInput
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preFtoData) {
 | 
				
			||||||
 | 
					          for (const factory of preFtoData) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            // const fId = this.getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // if (fId) {
 | 
				
			||||||
 | 
					            preDataDetail[0] = factory.previousYearChipInput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					            // if (preFId) {
 | 
				
			||||||
 | 
					            // ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preData && preData[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of preData) {
 | 
				
			||||||
 | 
					            if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					              preDataDetail[1] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					              preDataDetail[2] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (targetListResponse && targetListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of targetListResponse) {
 | 
				
			||||||
 | 
					            targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            // if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					              targetDataDetail[1] = factory.chipYield
 | 
				
			||||||
 | 
					            // } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					            targetDataDetail[2] = factory.componentYield
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // console.log('ftoInvest',ftoInvest)
 | 
				
			||||||
 | 
					        if (factoryListResponse && factoryListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of factoryListResponse) {
 | 
				
			||||||
 | 
					            // targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            if (factory.glassType === 0) {
 | 
				
			||||||
 | 
					              currentDataDetail[1] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 1) {
 | 
				
			||||||
 | 
					              currentDataDetail[2] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.factoryData.preDataDetail = preDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.currentDataDetail = currentDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.targetDataDetail = targetDataDetail
 | 
				
			||||||
 | 
					        console.log(' this.factoryData', this.factoryData);
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										216
									
								
								src/views/copilot/factoryData/jmsIndex.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,216 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="factory-layout">
 | 
				
			||||||
 | 
					    <FactoryDataHeader :than="than" :companyName="companyName" :companyId="companyId" :period="period"
 | 
				
			||||||
 | 
					      @update:than="updateThan" @update:period="updatePeriod" />
 | 
				
			||||||
 | 
					    <div class="factory-section">
 | 
				
			||||||
 | 
					      <section class="top flex">
 | 
				
			||||||
 | 
					        <db-container title="生产监控" icon="prod">
 | 
				
			||||||
 | 
					          <prod-monitor :companyId="companyId" :factoryData="factoryData" :than="than" :period="period" :data="data"
 | 
				
			||||||
 | 
					            :prodOutPut="prodOutPut" :prodFto="prodFto" :showBipv="show" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <db-container title="工单监控" icon="order">
 | 
				
			||||||
 | 
					          <order :prodOrder="prodOrder" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <!-- <db-container title="" icon="store"> -->
 | 
				
			||||||
 | 
					        <!-- <store :stock="stock" /> -->
 | 
				
			||||||
 | 
					        <!-- </db-container> -->
 | 
				
			||||||
 | 
					      </section>
 | 
				
			||||||
 | 
					      <!-- <section class="bottom flex"> -->
 | 
				
			||||||
 | 
					      <!-- <db-container title="" icon="energy"> -->
 | 
				
			||||||
 | 
					      <!-- <energy :legend="energyLegend" :energyCockpits="energyCockpits" /> -->
 | 
				
			||||||
 | 
					      <!-- </db-container> -->
 | 
				
			||||||
 | 
					      <!-- </section> -->
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="factory-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import FactoryDataHeader from "./../components/FactoryDataHeader.vue";
 | 
				
			||||||
 | 
					import Container from "./components/Container.vue";
 | 
				
			||||||
 | 
					import ProdMonitor from "./components/ProdMonitor.vue";
 | 
				
			||||||
 | 
					import { deepClone } from "@/utils";
 | 
				
			||||||
 | 
					// import Store from "./components/Store.vue";
 | 
				
			||||||
 | 
					// import Energy from "./components/Energy.vue";
 | 
				
			||||||
 | 
					import Order from "./components/Order.vue";
 | 
				
			||||||
 | 
					import { cockpitDataMonitor } from "@/api/produceData";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "factoryData",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    FactoryDataHeader,
 | 
				
			||||||
 | 
					    DbContainer: Container,
 | 
				
			||||||
 | 
					    ProdMonitor,
 | 
				
			||||||
 | 
					    // Store,
 | 
				
			||||||
 | 
					    // Energy,
 | 
				
			||||||
 | 
					    Order,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      companyId: 3,
 | 
				
			||||||
 | 
					      companyName: "佳木斯中建材光电材料有限公司",
 | 
				
			||||||
 | 
					      period: 1,
 | 
				
			||||||
 | 
					      show: false,
 | 
				
			||||||
 | 
					      than: '同比',
 | 
				
			||||||
 | 
					      data: {},
 | 
				
			||||||
 | 
					      // 接口获取的数据
 | 
				
			||||||
 | 
					      prodOutPut: [], //生产
 | 
				
			||||||
 | 
					      prodFto: [], //生产
 | 
				
			||||||
 | 
					      stock: {}, //仓库
 | 
				
			||||||
 | 
					      factoryData: {
 | 
				
			||||||
 | 
					        preDataDetail: [],
 | 
				
			||||||
 | 
					        currentDataDetail: {},
 | 
				
			||||||
 | 
					        targetDataDetail: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      energyCockpits: [], //能源
 | 
				
			||||||
 | 
					      prodOrder: [], //订单
 | 
				
			||||||
 | 
					      energyLegend: [
 | 
				
			||||||
 | 
					        { label: "电", color: "#FFD160" },
 | 
				
			||||||
 | 
					        { label: "水", color: "#2760FF" },
 | 
				
			||||||
 | 
					        { label: "气", color: "#12FFF5" },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.getMes();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    updateCompany(obj) {
 | 
				
			||||||
 | 
					      this.companyId = obj.companyId;
 | 
				
			||||||
 | 
					      this.companyName = obj.companyName;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updateThan(val) {
 | 
				
			||||||
 | 
					      console.log(val);
 | 
				
			||||||
 | 
					      this.than = val;
 | 
				
			||||||
 | 
					      // this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updatePeriod(val) {
 | 
				
			||||||
 | 
					      this.period = val;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getMes() {
 | 
				
			||||||
 | 
					      cockpitDataMonitor({
 | 
				
			||||||
 | 
					        factorys: [this.companyId],
 | 
				
			||||||
 | 
					        date: this.period,
 | 
				
			||||||
 | 
					        mode: this.than === '同比' ? 0 : 1
 | 
				
			||||||
 | 
					      }).then((res) => {
 | 
				
			||||||
 | 
					        console.log(res);
 | 
				
			||||||
 | 
					        this.prodOutPut = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        this.prodFto = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        this.prodOrder = res.data.prodWorkOrderDO || [];
 | 
				
			||||||
 | 
					        let prodOutputFtoListRes = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preFtoData = res.data.previousProdOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preData = res.data.previousProdOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let factoryListResponse = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let targetListResponse = res.data.prodTargetMonitorDO || [];
 | 
				
			||||||
 | 
					        let preDataDetail = []
 | 
				
			||||||
 | 
					        let currentDataDetail = []
 | 
				
			||||||
 | 
					        let targetDataDetail = []
 | 
				
			||||||
 | 
					        if (prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					          for (const factory of prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            currentDataDetail[0] = factory.chipInput
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preFtoData) {
 | 
				
			||||||
 | 
					          for (const factory of preFtoData) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            // const fId = this.getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // if (fId) {
 | 
				
			||||||
 | 
					            preDataDetail[0] = factory.previousYearChipInput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					            // if (preFId) {
 | 
				
			||||||
 | 
					            // ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preData && preData[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of preData) {
 | 
				
			||||||
 | 
					            if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					              preDataDetail[1] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					              preDataDetail[2] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousYearOutputNumber === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (targetListResponse && targetListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of targetListResponse) {
 | 
				
			||||||
 | 
					            targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            // if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					            targetDataDetail[1] = factory.chipYield
 | 
				
			||||||
 | 
					            // } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					            targetDataDetail[2] = factory.componentYield
 | 
				
			||||||
 | 
					            targetDataDetail[3] = factory.bipvProductoutput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // console.log('ftoInvest',ftoInvest)
 | 
				
			||||||
 | 
					        if (factoryListResponse && factoryListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of factoryListResponse) {
 | 
				
			||||||
 | 
					            // targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            if (factory.glassType === 0) {
 | 
				
			||||||
 | 
					              currentDataDetail[1] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 1) {
 | 
				
			||||||
 | 
					              currentDataDetail[2] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.factoryData.preDataDetail = preDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.currentDataDetail = currentDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.targetDataDetail = targetDataDetail
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.factory-layout {
 | 
				
			||||||
 | 
					  padding: 16px;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/copilot-bg.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  height: calc(100% + 38px);
 | 
				
			||||||
 | 
					  left: -16px;
 | 
				
			||||||
 | 
					  top: -8px;
 | 
				
			||||||
 | 
					  width: calc(100% + 30px);
 | 
				
			||||||
 | 
					  z-index: 1001;
 | 
				
			||||||
 | 
					  color: #fff;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  gap: 8px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-section {
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					    display: flex;
 | 
				
			||||||
 | 
					    flex-direction: column;
 | 
				
			||||||
 | 
					    gap: 16px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .flex {
 | 
				
			||||||
 | 
					      display: flex;
 | 
				
			||||||
 | 
					      gap: 16px;
 | 
				
			||||||
 | 
					      flex: 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .top>div,
 | 
				
			||||||
 | 
					    .bottom>div {
 | 
				
			||||||
 | 
					      height: 100%;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-footer {
 | 
				
			||||||
 | 
					    /** position: absolute;
 | 
				
			||||||
 | 
					  bottom: 10px; **/
 | 
				
			||||||
 | 
					    height: 10px;
 | 
				
			||||||
 | 
					    width: 100%;
 | 
				
			||||||
 | 
					    color: rgb(80, 80, 80);
 | 
				
			||||||
 | 
					    user-select: none;
 | 
				
			||||||
 | 
					    font-size: 14px;
 | 
				
			||||||
 | 
					    letter-spacing: 1px;
 | 
				
			||||||
 | 
					    display: grid;
 | 
				
			||||||
 | 
					    place-content: center;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										216
									
								
								src/views/copilot/factoryData/ksIndex.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,216 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="factory-layout">
 | 
				
			||||||
 | 
					    <FactoryDataHeader :than="than" :companyName="companyName" :companyId="companyId" :period="period"
 | 
				
			||||||
 | 
					      @update:than="updateThan" @update:period="updatePeriod" />
 | 
				
			||||||
 | 
					    <div class="factory-section">
 | 
				
			||||||
 | 
					      <section class="top flex">
 | 
				
			||||||
 | 
					        <db-container title="生产监控" icon="prod">
 | 
				
			||||||
 | 
					          <prod-monitor :companyId="companyId" :factoryData="factoryData" :than="than" :period="period" :data="data"
 | 
				
			||||||
 | 
					            :prodOutPut="prodOutPut" :prodFto="prodFto" :showBipv="show" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <db-container title="工单监控" icon="order">
 | 
				
			||||||
 | 
					          <order :prodOrder="prodOrder" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <!-- <db-container title="" icon="store"> -->
 | 
				
			||||||
 | 
					        <!-- <store :stock="stock" /> -->
 | 
				
			||||||
 | 
					        <!-- </db-container> -->
 | 
				
			||||||
 | 
					      </section>
 | 
				
			||||||
 | 
					      <!-- <section class="bottom flex"> -->
 | 
				
			||||||
 | 
					      <!-- <db-container title="" icon="energy"> -->
 | 
				
			||||||
 | 
					      <!-- <energy :legend="energyLegend" :energyCockpits="energyCockpits" /> -->
 | 
				
			||||||
 | 
					      <!-- </db-container> -->
 | 
				
			||||||
 | 
					      <!-- </section> -->
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="factory-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import FactoryDataHeader from "./../components/FactoryDataHeader.vue";
 | 
				
			||||||
 | 
					import Container from "./components/Container.vue";
 | 
				
			||||||
 | 
					import ProdMonitor from "./components/ProdMonitor.vue";
 | 
				
			||||||
 | 
					import { deepClone } from "@/utils";
 | 
				
			||||||
 | 
					// import Store from "./components/Store.vue";
 | 
				
			||||||
 | 
					// import Energy from "./components/Energy.vue";
 | 
				
			||||||
 | 
					import Order from "./components/Order.vue";
 | 
				
			||||||
 | 
					import { cockpitDataMonitor } from "@/api/produceData";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "factoryData",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    FactoryDataHeader,
 | 
				
			||||||
 | 
					    DbContainer: Container,
 | 
				
			||||||
 | 
					    ProdMonitor,
 | 
				
			||||||
 | 
					    // Store,
 | 
				
			||||||
 | 
					    // Energy,
 | 
				
			||||||
 | 
					    Order,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      companyId: 5,
 | 
				
			||||||
 | 
					      companyName: "凯盛中建材光电材料有限公司",
 | 
				
			||||||
 | 
					      period: 1,
 | 
				
			||||||
 | 
					      show: false,
 | 
				
			||||||
 | 
					      than: '同比',
 | 
				
			||||||
 | 
					      data: {},
 | 
				
			||||||
 | 
					      // 接口获取的数据
 | 
				
			||||||
 | 
					      prodOutPut: [], //生产
 | 
				
			||||||
 | 
					      prodFto: [], //生产
 | 
				
			||||||
 | 
					      stock: {}, //仓库
 | 
				
			||||||
 | 
					      factoryData: {
 | 
				
			||||||
 | 
					        preDataDetail: [],
 | 
				
			||||||
 | 
					        currentDataDetail: {},
 | 
				
			||||||
 | 
					        targetDataDetail: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      energyCockpits: [], //能源
 | 
				
			||||||
 | 
					      prodOrder: [], //订单
 | 
				
			||||||
 | 
					      energyLegend: [
 | 
				
			||||||
 | 
					        { label: "电", color: "#FFD160" },
 | 
				
			||||||
 | 
					        { label: "水", color: "#2760FF" },
 | 
				
			||||||
 | 
					        { label: "气", color: "#12FFF5" },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.getMes();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    updateCompany(obj) {
 | 
				
			||||||
 | 
					      this.companyId = obj.companyId;
 | 
				
			||||||
 | 
					      this.companyName = obj.companyName;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updateThan(val) {
 | 
				
			||||||
 | 
					      console.log(val);
 | 
				
			||||||
 | 
					      this.than = val;
 | 
				
			||||||
 | 
					      // this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updatePeriod(val) {
 | 
				
			||||||
 | 
					      this.period = val;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getMes() {
 | 
				
			||||||
 | 
					      cockpitDataMonitor({
 | 
				
			||||||
 | 
					        factorys: [this.companyId],
 | 
				
			||||||
 | 
					        date: this.period,
 | 
				
			||||||
 | 
					        mode: this.than === '同比' ? 0 : 1
 | 
				
			||||||
 | 
					      }).then((res) => {
 | 
				
			||||||
 | 
					        console.log(res);
 | 
				
			||||||
 | 
					        this.prodOutPut = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        this.prodFto = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        this.prodOrder = res.data.prodWorkOrderDO || [];
 | 
				
			||||||
 | 
					        let prodOutputFtoListRes = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preFtoData = res.data.previousProdOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preData = res.data.previousProdOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let factoryListResponse = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let targetListResponse = res.data.prodTargetMonitorDO || [];
 | 
				
			||||||
 | 
					        let preDataDetail = []
 | 
				
			||||||
 | 
					        let currentDataDetail = []
 | 
				
			||||||
 | 
					        let targetDataDetail = []
 | 
				
			||||||
 | 
					        if (prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					          for (const factory of prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            currentDataDetail[0] = factory.chipInput
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preFtoData) {
 | 
				
			||||||
 | 
					          for (const factory of preFtoData) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            // const fId = this.getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // if (fId) {
 | 
				
			||||||
 | 
					            preDataDetail[0] = factory.previousYearChipInput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					            // if (preFId) {
 | 
				
			||||||
 | 
					            // ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preData && preData[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of preData) {
 | 
				
			||||||
 | 
					            if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					              preDataDetail[1] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					              preDataDetail[2] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousYearOutputNumber === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (targetListResponse && targetListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of targetListResponse) {
 | 
				
			||||||
 | 
					            targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            // if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					            targetDataDetail[1] = factory.chipYield
 | 
				
			||||||
 | 
					            // } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					            targetDataDetail[2] = factory.componentYield
 | 
				
			||||||
 | 
					            targetDataDetail[3] = factory.bipvProductoutput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // console.log('ftoInvest',ftoInvest)
 | 
				
			||||||
 | 
					        if (factoryListResponse && factoryListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of factoryListResponse) {
 | 
				
			||||||
 | 
					            // targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            if (factory.glassType === 0) {
 | 
				
			||||||
 | 
					              currentDataDetail[1] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 1) {
 | 
				
			||||||
 | 
					              currentDataDetail[2] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.factoryData.preDataDetail = preDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.currentDataDetail = currentDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.targetDataDetail = targetDataDetail
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.factory-layout {
 | 
				
			||||||
 | 
					  padding: 16px;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/copilot-bg.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  height: calc(100% + 38px);
 | 
				
			||||||
 | 
					  left: -16px;
 | 
				
			||||||
 | 
					  top: -8px;
 | 
				
			||||||
 | 
					  width: calc(100% + 30px);
 | 
				
			||||||
 | 
					  z-index: 1001;
 | 
				
			||||||
 | 
					  color: #fff;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  gap: 8px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-section {
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					    display: flex;
 | 
				
			||||||
 | 
					    flex-direction: column;
 | 
				
			||||||
 | 
					    gap: 16px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .flex {
 | 
				
			||||||
 | 
					      display: flex;
 | 
				
			||||||
 | 
					      gap: 16px;
 | 
				
			||||||
 | 
					      flex: 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .top>div,
 | 
				
			||||||
 | 
					    .bottom>div {
 | 
				
			||||||
 | 
					      height: 100%;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-footer {
 | 
				
			||||||
 | 
					    /** position: absolute;
 | 
				
			||||||
 | 
					  bottom: 10px; **/
 | 
				
			||||||
 | 
					    height: 10px;
 | 
				
			||||||
 | 
					    width: 100%;
 | 
				
			||||||
 | 
					    color: rgb(80, 80, 80);
 | 
				
			||||||
 | 
					    user-select: none;
 | 
				
			||||||
 | 
					    font-size: 14px;
 | 
				
			||||||
 | 
					    letter-spacing: 1px;
 | 
				
			||||||
 | 
					    display: grid;
 | 
				
			||||||
 | 
					    place-content: center;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										146
									
								
								src/views/copilot/factoryData/oldIndex.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,146 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2024-05-21 13:24:03
 | 
				
			||||||
 | 
					 * @LastEditTime: 2024-05-21 13:24:03
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="factory-layout">
 | 
				
			||||||
 | 
					    <FactoryDataHeader
 | 
				
			||||||
 | 
					      :companyName="companyName"
 | 
				
			||||||
 | 
					      :companyId="companyId"
 | 
				
			||||||
 | 
					      :period="period"
 | 
				
			||||||
 | 
					      @updateCompany="updateCompany"
 | 
				
			||||||
 | 
					      @update:period="updatePeriod"
 | 
				
			||||||
 | 
					    />
 | 
				
			||||||
 | 
					    <div class="factory-section">
 | 
				
			||||||
 | 
					      <section class="top flex">
 | 
				
			||||||
 | 
					        <db-container title="生产监控" icon="prod">
 | 
				
			||||||
 | 
					          <prod-monitor :prodOutPut="prodOutPut" :prodFto="prodFto" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <db-container title="仓库监控.当前" icon="store">
 | 
				
			||||||
 | 
					          <store :stock="stock" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					      </section>
 | 
				
			||||||
 | 
					      <section class="bottom flex">
 | 
				
			||||||
 | 
					        <db-container title="能源监控" icon="energy">
 | 
				
			||||||
 | 
					          <energy :legend="energyLegend" :energyCockpits="energyCockpits" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <db-container title="订单监控" icon="order">
 | 
				
			||||||
 | 
					          <order :prodOrder="prodOrder" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					      </section>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="factory-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import FactoryDataHeader from "./../components/FactoryDataHeader.vue";
 | 
				
			||||||
 | 
					import Container from "./components/Container.vue";
 | 
				
			||||||
 | 
					import ProdMonitor from "./components/ProdMonitor.vue";
 | 
				
			||||||
 | 
					import Store from "./components/Store.vue";
 | 
				
			||||||
 | 
					import Energy from "./components/Energy.vue";
 | 
				
			||||||
 | 
					import Order from "./components/Order.vue";
 | 
				
			||||||
 | 
					import { cockpitDataMonitor } from "@/api/produceData";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "factoryData",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    FactoryDataHeader,
 | 
				
			||||||
 | 
					    DbContainer: Container,
 | 
				
			||||||
 | 
					    ProdMonitor,
 | 
				
			||||||
 | 
					    Store,
 | 
				
			||||||
 | 
					    Energy,
 | 
				
			||||||
 | 
					    Order,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      companyId: 0,
 | 
				
			||||||
 | 
					      companyName: "邯郸中建材光电材料有限公司",
 | 
				
			||||||
 | 
					      period: 1,
 | 
				
			||||||
 | 
					      // 接口获取的数据
 | 
				
			||||||
 | 
					      prodOutPut: [], //生产
 | 
				
			||||||
 | 
					      prodFto: [], //生产
 | 
				
			||||||
 | 
					      stock: {}, //仓库
 | 
				
			||||||
 | 
					      energyCockpits: [], //能源
 | 
				
			||||||
 | 
					      prodOrder: [], //订单
 | 
				
			||||||
 | 
					      energyLegend: [
 | 
				
			||||||
 | 
					        { label: "电", color: "#FFD160" },
 | 
				
			||||||
 | 
					        { label: "水", color: "#2760FF" },
 | 
				
			||||||
 | 
					        { label: "气", color: "#12FFF5" },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.getMes();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    updateCompany(obj) {
 | 
				
			||||||
 | 
					      this.companyId = obj.companyId;
 | 
				
			||||||
 | 
					      this.companyName = obj.companyName;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updatePeriod(val) {
 | 
				
			||||||
 | 
					      this.period = val;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getMes() {
 | 
				
			||||||
 | 
					      cockpitDataMonitor({
 | 
				
			||||||
 | 
					        factorys: [this.companyId],
 | 
				
			||||||
 | 
					        date: this.period,
 | 
				
			||||||
 | 
					      }).then((res) => {
 | 
				
			||||||
 | 
					        console.log(res);
 | 
				
			||||||
 | 
					        this.prodOutPut = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        this.prodFto = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        this.stock = res.data.stockDO || {};
 | 
				
			||||||
 | 
					        this.energyCockpits = res.data.energyCockpitsDO || [];
 | 
				
			||||||
 | 
					        this.prodOrder = res.data.prodOrderMonitorDO || [];
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.factory-layout {
 | 
				
			||||||
 | 
					  padding: 16px;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/copilot-bg.png) 0 0 / 100% 100%
 | 
				
			||||||
 | 
					    no-repeat;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  height: calc(100% + 38px);
 | 
				
			||||||
 | 
					  left: -16px;
 | 
				
			||||||
 | 
					  top: -8px;
 | 
				
			||||||
 | 
					  width: calc(100% + 30px);
 | 
				
			||||||
 | 
					  z-index: 1001;
 | 
				
			||||||
 | 
					  color: #fff;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  gap: 8px;
 | 
				
			||||||
 | 
					  .factory-section {
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					    display: flex;
 | 
				
			||||||
 | 
					    flex-direction: column;
 | 
				
			||||||
 | 
					    gap: 16px;
 | 
				
			||||||
 | 
					    .flex {
 | 
				
			||||||
 | 
					      display: flex;
 | 
				
			||||||
 | 
					      gap: 16px;
 | 
				
			||||||
 | 
					      flex: 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    .top > div,
 | 
				
			||||||
 | 
					    .bottom > div {
 | 
				
			||||||
 | 
					      height: 100%;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .factory-footer {
 | 
				
			||||||
 | 
					    /** position: absolute;
 | 
				
			||||||
 | 
					  bottom: 10px; **/
 | 
				
			||||||
 | 
					    height: 10px;
 | 
				
			||||||
 | 
					    width: 100%;
 | 
				
			||||||
 | 
					    color: rgb(80, 80, 80);
 | 
				
			||||||
 | 
					    user-select: none;
 | 
				
			||||||
 | 
					    font-size: 14px;
 | 
				
			||||||
 | 
					    letter-spacing: 1px;
 | 
				
			||||||
 | 
					    display: grid;
 | 
				
			||||||
 | 
					    place-content: center;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										216
									
								
								src/views/copilot/factoryData/zzIndex.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,216 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="factory-layout">
 | 
				
			||||||
 | 
					    <FactoryDataHeader :than="than" :companyName="companyName" :companyId="companyId" :period="period"
 | 
				
			||||||
 | 
					      @update:than="updateThan" @update:period="updatePeriod" />
 | 
				
			||||||
 | 
					    <div class="factory-section">
 | 
				
			||||||
 | 
					      <section class="top flex">
 | 
				
			||||||
 | 
					        <db-container title="生产监控" icon="prod">
 | 
				
			||||||
 | 
					          <prod-monitor :companyId="companyId" :factoryData="factoryData" :than="than" :period="period" :data="data"
 | 
				
			||||||
 | 
					            :prodOutPut="prodOutPut" :prodFto="prodFto" :showBipv="show" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <db-container title="工单监控" icon="order">
 | 
				
			||||||
 | 
					          <order :prodOrder="prodOrder" />
 | 
				
			||||||
 | 
					        </db-container>
 | 
				
			||||||
 | 
					        <!-- <db-container title="" icon="store"> -->
 | 
				
			||||||
 | 
					        <!-- <store :stock="stock" /> -->
 | 
				
			||||||
 | 
					        <!-- </db-container> -->
 | 
				
			||||||
 | 
					      </section>
 | 
				
			||||||
 | 
					      <!-- <section class="bottom flex"> -->
 | 
				
			||||||
 | 
					      <!-- <db-container title="" icon="energy"> -->
 | 
				
			||||||
 | 
					      <!-- <energy :legend="energyLegend" :energyCockpits="energyCockpits" /> -->
 | 
				
			||||||
 | 
					      <!-- </db-container> -->
 | 
				
			||||||
 | 
					      <!-- </section> -->
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="factory-footer">© 中建材智能自动化研究院有限公司</div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import FactoryDataHeader from "./../components/FactoryDataHeader.vue";
 | 
				
			||||||
 | 
					import Container from "./components/Container.vue";
 | 
				
			||||||
 | 
					import ProdMonitor from "./components/ProdMonitor.vue";
 | 
				
			||||||
 | 
					import { deepClone } from "@/utils";
 | 
				
			||||||
 | 
					// import Store from "./components/Store.vue";
 | 
				
			||||||
 | 
					// import Energy from "./components/Energy.vue";
 | 
				
			||||||
 | 
					import Order from "./components/Order.vue";
 | 
				
			||||||
 | 
					import { cockpitDataMonitor } from "@/api/produceData";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "factoryData",
 | 
				
			||||||
 | 
					  components: {
 | 
				
			||||||
 | 
					    FactoryDataHeader,
 | 
				
			||||||
 | 
					    DbContainer: Container,
 | 
				
			||||||
 | 
					    ProdMonitor,
 | 
				
			||||||
 | 
					    // Store,
 | 
				
			||||||
 | 
					    // Energy,
 | 
				
			||||||
 | 
					    Order,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      companyId: 2,
 | 
				
			||||||
 | 
					      companyName: "株洲中建材光电材料有限公司",
 | 
				
			||||||
 | 
					      period: 1,
 | 
				
			||||||
 | 
					      show: false,
 | 
				
			||||||
 | 
					      than: '同比',
 | 
				
			||||||
 | 
					      data: {},
 | 
				
			||||||
 | 
					      // 接口获取的数据
 | 
				
			||||||
 | 
					      prodOutPut: [], //生产
 | 
				
			||||||
 | 
					      prodFto: [], //生产
 | 
				
			||||||
 | 
					      stock: {}, //仓库
 | 
				
			||||||
 | 
					      factoryData: {
 | 
				
			||||||
 | 
					        preDataDetail: [],
 | 
				
			||||||
 | 
					        currentDataDetail: {},
 | 
				
			||||||
 | 
					        targetDataDetail: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      energyCockpits: [], //能源
 | 
				
			||||||
 | 
					      prodOrder: [], //订单
 | 
				
			||||||
 | 
					      energyLegend: [
 | 
				
			||||||
 | 
					        { label: "电", color: "#FFD160" },
 | 
				
			||||||
 | 
					        { label: "水", color: "#2760FF" },
 | 
				
			||||||
 | 
					        { label: "气", color: "#12FFF5" },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.getMes();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    updateCompany(obj) {
 | 
				
			||||||
 | 
					      this.companyId = obj.companyId;
 | 
				
			||||||
 | 
					      this.companyName = obj.companyName;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updateThan(val) {
 | 
				
			||||||
 | 
					      console.log(val);
 | 
				
			||||||
 | 
					      this.than = val;
 | 
				
			||||||
 | 
					      // this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    updatePeriod(val) {
 | 
				
			||||||
 | 
					      this.period = val;
 | 
				
			||||||
 | 
					      this.getMes();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    getMes() {
 | 
				
			||||||
 | 
					      cockpitDataMonitor({
 | 
				
			||||||
 | 
					        factorys: [this.companyId],
 | 
				
			||||||
 | 
					        date: this.period,
 | 
				
			||||||
 | 
					        mode: this.than === '同比' ? 0 : 1
 | 
				
			||||||
 | 
					      }).then((res) => {
 | 
				
			||||||
 | 
					        console.log(res);
 | 
				
			||||||
 | 
					        this.prodOutPut = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        this.prodFto = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        this.prodOrder = res.data.prodWorkOrderDO || [];
 | 
				
			||||||
 | 
					        let prodOutputFtoListRes = res.data.prodOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preFtoData = res.data.previousProdOutputFtoDO || [];
 | 
				
			||||||
 | 
					        let preData = res.data.previousProdOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let factoryListResponse = res.data.prodOutputMonitorShDO || [];
 | 
				
			||||||
 | 
					        let targetListResponse = res.data.prodTargetMonitorDO || [];
 | 
				
			||||||
 | 
					        let preDataDetail = []
 | 
				
			||||||
 | 
					        let currentDataDetail = []
 | 
				
			||||||
 | 
					        let targetDataDetail = []
 | 
				
			||||||
 | 
					        if (prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					          for (const factory of prodOutputFtoListRes) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            currentDataDetail[0] = factory.chipInput
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preFtoData) {
 | 
				
			||||||
 | 
					          for (const factory of preFtoData) {
 | 
				
			||||||
 | 
					            console.log(factory);
 | 
				
			||||||
 | 
					            // const fId = this.getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // const preFId = getPreFactoryId(factory);
 | 
				
			||||||
 | 
					            // if (fId) {
 | 
				
			||||||
 | 
					            preDataDetail[0] = factory.previousYearChipInput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					            // if (preFId) {
 | 
				
			||||||
 | 
					            // ftoInvest.previous[fId] = factory.previousYearChipInput;
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (preData && preData[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of preData) {
 | 
				
			||||||
 | 
					            if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					              preDataDetail[1] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					              preDataDetail[2] = factory.previousYearOutputNumber
 | 
				
			||||||
 | 
					            } else if (factory.previousYearOutputNumber === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        if (targetListResponse && targetListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of targetListResponse) {
 | 
				
			||||||
 | 
					            targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            // if (factory.previousGlassType === 0) {
 | 
				
			||||||
 | 
					            targetDataDetail[1] = factory.chipYield
 | 
				
			||||||
 | 
					            // } else if (factory.previousGlassType === 1) {
 | 
				
			||||||
 | 
					            targetDataDetail[2] = factory.componentYield
 | 
				
			||||||
 | 
					            targetDataDetail[3] = factory.bipvProductoutput
 | 
				
			||||||
 | 
					            // }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        // console.log('ftoInvest',ftoInvest)
 | 
				
			||||||
 | 
					        if (factoryListResponse && factoryListResponse[0] != null) {
 | 
				
			||||||
 | 
					          for (const factory of factoryListResponse) {
 | 
				
			||||||
 | 
					            // targetDataDetail[0] = factory.ftoInput
 | 
				
			||||||
 | 
					            if (factory.glassType === 0) {
 | 
				
			||||||
 | 
					              currentDataDetail[1] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 1) {
 | 
				
			||||||
 | 
					              currentDataDetail[2] = factory.outputNumber
 | 
				
			||||||
 | 
					            } else if (factory.glassType === 2) {
 | 
				
			||||||
 | 
					              currentDataDetail[3] = factory.outputNumber
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.factoryData.preDataDetail = preDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.currentDataDetail = currentDataDetail
 | 
				
			||||||
 | 
					        this.factoryData.targetDataDetail = targetDataDetail
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.factory-layout {
 | 
				
			||||||
 | 
					  padding: 16px;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/copilot-bg.png) 0 0 / 100% 100% no-repeat;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  height: calc(100% + 38px);
 | 
				
			||||||
 | 
					  left: -16px;
 | 
				
			||||||
 | 
					  top: -8px;
 | 
				
			||||||
 | 
					  width: calc(100% + 30px);
 | 
				
			||||||
 | 
					  z-index: 1001;
 | 
				
			||||||
 | 
					  color: #fff;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  gap: 8px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-section {
 | 
				
			||||||
 | 
					    flex: 1;
 | 
				
			||||||
 | 
					    display: flex;
 | 
				
			||||||
 | 
					    flex-direction: column;
 | 
				
			||||||
 | 
					    gap: 16px;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .flex {
 | 
				
			||||||
 | 
					      display: flex;
 | 
				
			||||||
 | 
					      gap: 16px;
 | 
				
			||||||
 | 
					      flex: 1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .top>div,
 | 
				
			||||||
 | 
					    .bottom>div {
 | 
				
			||||||
 | 
					      height: 100%;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .factory-footer {
 | 
				
			||||||
 | 
					    /** position: absolute;
 | 
				
			||||||
 | 
					  bottom: 10px; **/
 | 
				
			||||||
 | 
					    height: 10px;
 | 
				
			||||||
 | 
					    width: 100%;
 | 
				
			||||||
 | 
					    color: rgb(80, 80, 80);
 | 
				
			||||||
 | 
					    user-select: none;
 | 
				
			||||||
 | 
					    font-size: 14px;
 | 
				
			||||||
 | 
					    letter-spacing: 1px;
 | 
				
			||||||
 | 
					    display: grid;
 | 
				
			||||||
 | 
					    place-content: center;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
@@ -1,28 +1,37 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
    filename: BipvOutput.vue
 | 
					 * @Author: zhp
 | 
				
			||||||
    author: liubin
 | 
					 * @Date: 2024-05-07 10:04:53
 | 
				
			||||||
    date: 2024-04-17 09:55:12
 | 
					 * @LastEditTime: 2024-05-29 13:17:38
 | 
				
			||||||
    description: 
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <DoubleRingWrapperVue data-source="BIPV产出" :period="period" />
 | 
					  <noDoubleRingWrapper data-source="BIPV产出" :period="period" :than="than" />
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import DoubleRingWrapperVue from "./sub/ring/DoubleRingWrapper.vue";
 | 
					// import DoubleRingWrapperVue from "./sub/ring/DoubleRingWrapper.vue";
 | 
				
			||||||
 | 
					import noDoubleRingWrapper from "./sub/ring/noDoubleRingWrapper.vue";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "BipvOutput",
 | 
					  name: "BipvOutput",
 | 
				
			||||||
  components: { DoubleRingWrapperVue },
 | 
					  components: { noDoubleRingWrapper },
 | 
				
			||||||
  props: {
 | 
					  props: {
 | 
				
			||||||
    period: {
 | 
					    period: {
 | 
				
			||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {};
 | 
					    return {
 | 
				
			||||||
 | 
					      show: false,
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -33,74 +33,215 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    legend() {
 | 
					    legend() {
 | 
				
			||||||
      switch (this.period) {
 | 
					      let items = [];
 | 
				
			||||||
        case "日":
 | 
					      var day1 = new Date();
 | 
				
			||||||
          return [{ label: "昨日", color: "#12f7f1" }];
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
        case "周":
 | 
					      var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
          return [{ label: "本周", color: "#12f7f1" }];
 | 
					      //今天的时间
 | 
				
			||||||
        case "月": {
 | 
					      // var day2 = new Date();
 | 
				
			||||||
          const year = new Date().getFullYear();
 | 
					      // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					      // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
 | 
					      // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
      const month = new Date().getMonth() + 1;
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
          return [
 | 
					      const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
            { label: `${year - 1}年${month}月`, color: "#12f7f1" },
 | 
					 | 
				
			||||||
            { label: `${year}年${month}月`, color: "#58adfa" },
 | 
					 | 
				
			||||||
          ];
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        case "年": {
 | 
					 | 
				
			||||||
      const year = new Date().getFullYear();
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
          return [
 | 
					      if (this.period === '日' && this.than === '同比') {
 | 
				
			||||||
            { label: `${year - 1}年`, color: "#12f7f1" },
 | 
					        items = [
 | 
				
			||||||
            { label: `${year}年`, color: "#58adfa" },
 | 
					          { label: `去年${month}月${today}日`, color: "#12f7f1" },
 | 
				
			||||||
          ];
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
        }
 | 
					        ];
 | 
				
			||||||
        default:
 | 
					      } else if (this.period === '日' && this.than === '环比') {
 | 
				
			||||||
          return [
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${yesterday}日`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年本周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `上周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年${month}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${lastMonth}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
          { label: `${year - 1}年`, color: "#12f7f1" },
 | 
					          { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
          { label: `${year}年`, color: "#58adfa" },
 | 
					          { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${year}年目标`, value: valueTuple[2] },
 | 
				
			||||||
        ];
 | 
					        ];
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					      return items
 | 
				
			||||||
 | 
					      // switch (this.period) {
 | 
				
			||||||
 | 
					      //   case "日":
 | 
				
			||||||
 | 
					      //     return [{ label: "昨日", color: "#12f7f1" }];
 | 
				
			||||||
 | 
					      //   case "周":
 | 
				
			||||||
 | 
					      //     return [{ label: "本周", color: "#12f7f1" }];
 | 
				
			||||||
 | 
					      //   case "月": {
 | 
				
			||||||
 | 
					      //     const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      //     const month = new Date().getMonth() + 1;
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年${month}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      //   case "年": {
 | 
				
			||||||
 | 
					      //     const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      //   default:
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    series() {
 | 
					    series() {
 | 
				
			||||||
      const { chipInvest } = this.$store.getters.copilot.yield;
 | 
					      const { chipInvest } = this.$store.getters.copilot.yield;
 | 
				
			||||||
      let dataList = null;
 | 
					      let dataList = null;
 | 
				
			||||||
      switch (this.period) {
 | 
					      switch (this.period) {
 | 
				
			||||||
        case "日":
 | 
					        case "日":
 | 
				
			||||||
 | 
					          dataList = [];
 | 
				
			||||||
 | 
					          dataList[0] = chipInvest?.previous;
 | 
				
			||||||
 | 
					          dataList[1] = chipInvest?.current;
 | 
				
			||||||
        case "周":
 | 
					        case "周":
 | 
				
			||||||
          dataList = chipInvest?.current;
 | 
					          dataList = []
 | 
				
			||||||
 | 
					          dataList[0] = chipInvest?.previous;
 | 
				
			||||||
 | 
					          dataList[1] = chipInvest?.current;
 | 
				
			||||||
          break;
 | 
					          break;
 | 
				
			||||||
        default:
 | 
					        default:
 | 
				
			||||||
          dataList = [];
 | 
					          dataList = [];
 | 
				
			||||||
          dataList[0] = chipInvest?.previous;
 | 
					          dataList[0] = chipInvest?.previous;
 | 
				
			||||||
          dataList[1] = chipInvest?.current;
 | 
					          dataList[1] = chipInvest?.current;
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      return getTemplate(this.period, dataList);
 | 
					      return getTemplate(this.period, dataList,this.than);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function getTemplate(period, dataList) {
 | 
					function getTemplate(period, dataList,than) {
 | 
				
			||||||
  const year = new Date().getFullYear();
 | 
					  let items = [];
 | 
				
			||||||
 | 
					  var day1 = new Date();
 | 
				
			||||||
 | 
					  day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					  var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
 | 
					  //今天的时间
 | 
				
			||||||
 | 
					  // var day2 = new Date();
 | 
				
			||||||
 | 
					  // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					  // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					  const today = new Date().getDate();
 | 
				
			||||||
 | 
					  // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
  const month = new Date().getMonth() + 1;
 | 
					  const month = new Date().getMonth() + 1;
 | 
				
			||||||
  return period == "日" || period == "周"
 | 
					  const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
    ? [
 | 
					  const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					  if (period === '日' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
          name: period == "日" ? "昨日" : "本周",
 | 
					        name: `去年${month}月${today}日`,
 | 
				
			||||||
          data: dataList ?? [],
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      ]
 | 
					 | 
				
			||||||
    : [
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: period == "年" ? `${year - 1}年` : `${year - 1}年${month}月`,
 | 
					 | 
				
			||||||
        data: dataList ? dataList[0] : [],
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
          name: period == "年" ? `${year}年` : `${year}年${month}月`,
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
        data: dataList ? dataList[1] : [],
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
    ];
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '日' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${yesterday}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '周' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '周' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `上周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '月' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '月' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${lastMonth}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year - 1}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return items
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,13 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
    filename: ChipOutput.vue
 | 
					 * @Author: zhp
 | 
				
			||||||
    author: liubin
 | 
					 * @Date: 2024-05-07 10:04:53
 | 
				
			||||||
    date: 2024-04-17 09:55:12
 | 
					 * @LastEditTime: 2024-05-27 16:36:29
 | 
				
			||||||
    description: 
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <DoubleRingWrapperVue data-source="芯片产出" :period="period" />
 | 
					  <DoubleRingWrapperVue data-source="芯片产出" :period="period" :than="than" />
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
@@ -20,6 +21,10 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {};
 | 
					    return {};
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,7 +16,7 @@
 | 
				
			|||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import BarChartBase from "@/views/copilot/components/BarChartBase.vue";
 | 
					import BarChartBase from "@/views/copilot/components/ftoBarChartBase.vue";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "FtoInvest",
 | 
					  name: "FtoInvest",
 | 
				
			||||||
@@ -33,77 +33,217 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    legend() {
 | 
					    legend() {
 | 
				
			||||||
      switch (this.period) {
 | 
					      let items = [];
 | 
				
			||||||
        case "日":
 | 
					      var day1 = new Date();
 | 
				
			||||||
          return [{ label: "昨日", color: "#12f7f1" }];
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
        case "周":
 | 
					      var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
          return [{ label: "本周", color: "#12f7f1" }];
 | 
					      //今天的时间
 | 
				
			||||||
        case "月": {
 | 
					      // var day2 = new Date();
 | 
				
			||||||
          const year = new Date().getFullYear();
 | 
					      // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					      // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
 | 
					      // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
      const month = new Date().getMonth() + 1;
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
          return [
 | 
					      const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
            { label: `${year - 1}年${month}月`, color: "#12f7f1" },
 | 
					 | 
				
			||||||
            { label: `${year}年${month}月`, color: "#58adfa" },
 | 
					 | 
				
			||||||
          ];
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        case "年": {
 | 
					 | 
				
			||||||
      const year = new Date().getFullYear();
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
          return [
 | 
					      if (this.period === '日' && this.than === '同比') {
 | 
				
			||||||
            { label: `${year - 1}年`, color: "#12f7f1" },
 | 
					        items = [
 | 
				
			||||||
            { label: `${year}年`, color: "#58adfa" },
 | 
					          { label: `去年${month}月${today}日`, color: "#12f7f1" },
 | 
				
			||||||
          ];
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
        }
 | 
					        ];
 | 
				
			||||||
        default:
 | 
					      } else if (this.period === '日' && this.than === '环比') {
 | 
				
			||||||
          return [
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${yesterday}日`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年本周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `上周`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `本周`, color: "#58adfa" },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `去年${month}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${lastMonth}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					          { label: `${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
          { label: `${year - 1}年`, color: "#12f7f1" },
 | 
					          { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
          { label: `${year}年`, color: "#58adfa" },
 | 
					          { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					          // { label: `${year}年目标`, value: valueTuple[2] },
 | 
				
			||||||
        ];
 | 
					        ];
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					      return items
 | 
				
			||||||
 | 
					      // switch (this.period) {
 | 
				
			||||||
 | 
					      //   case "日":
 | 
				
			||||||
 | 
					      //     return [{ label: "昨日", color: "#12f7f1" }];
 | 
				
			||||||
 | 
					      //   case "周":
 | 
				
			||||||
 | 
					      //     return [{ label: "本周", color: "#12f7f1" }];
 | 
				
			||||||
 | 
					      //   case "月": {
 | 
				
			||||||
 | 
					      //     const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      //     const month = new Date().getMonth() + 1;
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年${month}月`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年${month}月`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      //   case "年": {
 | 
				
			||||||
 | 
					      //     const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      //   default:
 | 
				
			||||||
 | 
					      //     return [
 | 
				
			||||||
 | 
					      //       { label: `${year - 1}年`, color: "#12f7f1" },
 | 
				
			||||||
 | 
					      //       { label: `${year}年`, color: "#58adfa" },
 | 
				
			||||||
 | 
					      //     ];
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    series() {
 | 
					    series() {
 | 
				
			||||||
      const { ftoInvest } = this.$store.getters.copilot.yield;
 | 
					      const { ftoInvest } = this.$store.getters.copilot.yield;
 | 
				
			||||||
      console.log('ftoInvest', this.$store.getters.copilot.yield);
 | 
					      // console.log('ftoInvest', this.$store.getters.copilot.yield);
 | 
				
			||||||
      let dataList = null;
 | 
					      let dataList = null;
 | 
				
			||||||
 | 
					      // console.log(ftoInvest)
 | 
				
			||||||
      switch (this.period) {
 | 
					      switch (this.period) {
 | 
				
			||||||
        case "日":
 | 
					        case "日":
 | 
				
			||||||
 | 
					          dataList = [];
 | 
				
			||||||
 | 
					          dataList[0] = ftoInvest?.previous;
 | 
				
			||||||
 | 
					          dataList[1] = ftoInvest?.current;
 | 
				
			||||||
        case "周":
 | 
					        case "周":
 | 
				
			||||||
          dataList = ftoInvest?.current;
 | 
					          dataList = [];
 | 
				
			||||||
 | 
					          dataList[0] = ftoInvest?.previous;
 | 
				
			||||||
 | 
					          dataList[1] = ftoInvest?.current;
 | 
				
			||||||
          break;
 | 
					          break;
 | 
				
			||||||
        default:
 | 
					        default:
 | 
				
			||||||
          dataList = [];
 | 
					          dataList = [];
 | 
				
			||||||
          dataList[0] = ftoInvest?.previous;
 | 
					          dataList[0] = ftoInvest?.previous;
 | 
				
			||||||
          dataList[1] = ftoInvest?.current;
 | 
					          dataList[1] = ftoInvest?.current;
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					      return getTemplate(this.period, dataList,this.than);
 | 
				
			||||||
      return getTemplate(this.period, dataList);
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function getTemplate(period, dataList) {
 | 
					function getTemplate(period, dataList,than) {
 | 
				
			||||||
  const year = new Date().getFullYear();
 | 
					  let items = [];
 | 
				
			||||||
 | 
					  var day1 = new Date();
 | 
				
			||||||
 | 
					  day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					  var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
 | 
					  //今天的时间
 | 
				
			||||||
 | 
					  // var day2 = new Date();
 | 
				
			||||||
 | 
					  // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					  // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					  const today = new Date().getDate();
 | 
				
			||||||
 | 
					  // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
  const month = new Date().getMonth() + 1;
 | 
					  const month = new Date().getMonth() + 1;
 | 
				
			||||||
  return period == "日" || period == "周"
 | 
					  const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
    ? [
 | 
					  const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					  if (period === '日' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
          name: period == "日" ? "昨日" : "本周",
 | 
					        name: `去年${month}月${today}日`,
 | 
				
			||||||
          data: dataList ?? [],
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      ]
 | 
					 | 
				
			||||||
    : [
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: period == "年" ? `${year - 1}年` : `${year - 1}年${month}月`,
 | 
					 | 
				
			||||||
        data: dataList ? dataList[0] : [],
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      {
 | 
					      {
 | 
				
			||||||
          name: period == "年" ? `${year}年` : `${year}年${month}月`,
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
        data: dataList ? dataList[1] : [],
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
    ];
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '日' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${yesterday}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月${today}日`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '周' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '周' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `上周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `本周`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '月' && than === '同比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `去年${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '月' && than === '环比') {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${lastMonth}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${month}月`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    items = [
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year - 1}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[0] : [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      {
 | 
				
			||||||
 | 
					        name: `${year}年`,
 | 
				
			||||||
 | 
					        data: dataList ? dataList[1] : [],
 | 
				
			||||||
 | 
					        // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)),
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  return items
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,13 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
    filename: StdOutput.vue
 | 
					 * @Author: zhp
 | 
				
			||||||
    author: liubin
 | 
					 * @Date: 2024-05-07 10:04:53
 | 
				
			||||||
    date: 2024-04-17 09:55:12
 | 
					 * @LastEditTime: 2024-05-27 14:25:57
 | 
				
			||||||
    description: 
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <DoubleRingWrapperVue data-source="标准组件产出" :period="period" />
 | 
					  <DoubleRingWrapperVue data-source="标准组件产出" :period="period" :than="than" />
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
@@ -20,6 +21,10 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {};
 | 
					    return {};
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +1,9 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
    filename: DoubleRingChart.vue
 | 
					 * @Author: zhp
 | 
				
			||||||
    author: liubin
 | 
					 * @Date: 2024-05-20 13:32:59
 | 
				
			||||||
    date: 2024-04-17 11:01:55
 | 
					 * @LastEditTime: 2024-05-30 13:35:00
 | 
				
			||||||
    description:
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
@@ -45,6 +46,10 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: null,
 | 
					      default: null,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
@@ -89,27 +94,83 @@ export default {
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    options() {
 | 
					    options() {
 | 
				
			||||||
 | 
					      const today = new Date().getDate();
 | 
				
			||||||
      const year = new Date().getFullYear();
 | 
					      const year = new Date().getFullYear();
 | 
				
			||||||
      const month = new Date().getMonth() + 1;
 | 
					      const month = new Date().getMonth() + 1;
 | 
				
			||||||
      const vt = this.valueTuple;
 | 
					      const vt = this.valueTuple;
 | 
				
			||||||
 | 
					      let items = [];
 | 
				
			||||||
 | 
					      var day1 = new Date();
 | 
				
			||||||
 | 
					      day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					      var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
 | 
					      //今天的时间
 | 
				
			||||||
 | 
					      // var day2 = new Date();
 | 
				
			||||||
 | 
					      // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					      // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
 | 
					      // const today = new Date().getDate();
 | 
				
			||||||
 | 
					      // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
 | 
					      // const month = new Date().getMonth() + 1;
 | 
				
			||||||
 | 
					      const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1;
 | 
				
			||||||
 | 
					      // const year = new Date().getFullYear();
 | 
				
			||||||
 | 
					      if (this.period === '日' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日累计`,},
 | 
				
			||||||
 | 
					          { label: `去年${month}月${today}日累计` },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '日' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${month}月${today}日累计`},
 | 
				
			||||||
 | 
					          { label: `${yesterday}日累计`},
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `本周累计`,},
 | 
				
			||||||
 | 
					          { label: `去年本周累计`},
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '周' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `本周累计`,},
 | 
				
			||||||
 | 
					          { label: `上周累计`,},
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '同比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${month}月累计`,},
 | 
				
			||||||
 | 
					          { label: `去年${month}月累计`, },
 | 
				
			||||||
 | 
					          { label: `${month}月目标`,},
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else if (this.period === '月' && this.than === '环比') {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${month}月累计`,  },
 | 
				
			||||||
 | 
					          { label: `${lastMonth}月累计`,},
 | 
				
			||||||
 | 
					          { label: `${month}月目标`, },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        items = [
 | 
				
			||||||
 | 
					          { label: `${year}年累计`, },
 | 
				
			||||||
 | 
					          { label: `${year - 1}年累计` },
 | 
				
			||||||
 | 
					          { label: `${year}年目标` },
 | 
				
			||||||
 | 
					        ];
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
      let titleValue =
 | 
					      let titleValue =
 | 
				
			||||||
          vt[0] != null && vt[2] != null && vt[2] !== 0
 | 
					          vt[0] != null && vt[2] != null && vt[2] !== 0
 | 
				
			||||||
            ? `${vt[1] / vt[2]}%`
 | 
					            ? `${vt[1] / vt[2]}%`
 | 
				
			||||||
            : "0%",
 | 
					            : "0%",
 | 
				
			||||||
        subtitle =
 | 
					        subtitle =
 | 
				
			||||||
          this.period == "月" ? `${month}月累计产出` : `${year}年累计产出`;
 | 
					      this.period == "日" ? `${month}月${today}日累计` : this.period == "周" ? `本周` : this.period == "月" ? `${month}月累计产出` : `${year}年累计产出`;
 | 
				
			||||||
 | 
					      console.log(this.valueTuple[0], this.valueTuple[1], this.valueTuple[2],)
 | 
				
			||||||
 | 
					      console.log(items)
 | 
				
			||||||
      return getOptions({
 | 
					      return getOptions({
 | 
				
			||||||
        titleValue,
 | 
					        titleValue,
 | 
				
			||||||
        subtitle,
 | 
					        subtitle,
 | 
				
			||||||
 | 
					        currentName: items[0].label,
 | 
				
			||||||
 | 
					        preName: items[1].label,
 | 
				
			||||||
        previousSum: this.valueTuple[0],
 | 
					        previousSum: this.valueTuple[0],
 | 
				
			||||||
        currentSum: this.valueTuple[1],
 | 
					        currentSum: this.valueTuple[1],
 | 
				
			||||||
        targetSum: this.valueTuple[2],
 | 
					        targetSum: this.valueTuple[2] ? this.valueTuple[2] :0 ,
 | 
				
			||||||
      });
 | 
					      });
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    legendItems() {
 | 
					    legendItems() {
 | 
				
			||||||
      return calculateItems(this.period, this.valueTuple);
 | 
					      return calculateItems(this.period, this.valueTuple,this.than);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  watch: {
 | 
					  watch: {
 | 
				
			||||||
@@ -142,39 +203,68 @@ export default {
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function calculateItems(period, valueTuple) {
 | 
					function calculateItems(period, valueTuple,than) {
 | 
				
			||||||
  let items = [];
 | 
					  let items = [];
 | 
				
			||||||
 | 
					  var day1 = new Date();
 | 
				
			||||||
 | 
					  day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
 | 
				
			||||||
 | 
					  var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
 | 
				
			||||||
 | 
					  //今天的时间
 | 
				
			||||||
 | 
					  // var day2 = new Date();
 | 
				
			||||||
 | 
					  // day2.setTime(day2.getTime());
 | 
				
			||||||
 | 
					  // var s2 = (day2.getMonth() + 1) + "月" + day2.getDate() + '日';
 | 
				
			||||||
  const today = new Date().getDate();
 | 
					  const today = new Date().getDate();
 | 
				
			||||||
 | 
					  // let yesterday = new Date().getDate() -1;
 | 
				
			||||||
  const month = new Date().getMonth() + 1;
 | 
					  const month = new Date().getMonth() + 1;
 | 
				
			||||||
 | 
					  const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 -1;
 | 
				
			||||||
  const year = new Date().getFullYear();
 | 
					  const year = new Date().getFullYear();
 | 
				
			||||||
  switch (period) {
 | 
					  if (period === '日' && than === '同比') {
 | 
				
			||||||
    case "日":
 | 
					 | 
				
			||||||
    items = [
 | 
					    items = [
 | 
				
			||||||
      { label: `${month}月${today}日累计`, value: valueTuple[1] },
 | 
					      { label: `${month}月${today}日累计`, value: valueTuple[1] },
 | 
				
			||||||
      { label: `去年${month}月${today}日累计`, value: valueTuple[0] },
 | 
					      { label: `去年${month}月${today}日累计`, value: valueTuple[0] },
 | 
				
			||||||
    ];
 | 
					    ];
 | 
				
			||||||
      break;
 | 
					  } else if (period === '日' && than === '环比') {
 | 
				
			||||||
    case "周":
 | 
					    items = [
 | 
				
			||||||
 | 
					      { label: `${month}月${today}日累计`, value: valueTuple[1] },
 | 
				
			||||||
 | 
					      { label: `${yesterday}日累计`, value: valueTuple[0] },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '周' && than === '同比') {
 | 
				
			||||||
    items = [
 | 
					    items = [
 | 
				
			||||||
      { label: `本周累计`, value: valueTuple[1] },
 | 
					      { label: `本周累计`, value: valueTuple[1] },
 | 
				
			||||||
      { label: `去年本周累计`, value: valueTuple[0] },
 | 
					      { label: `去年本周累计`, value: valueTuple[0] },
 | 
				
			||||||
    ];
 | 
					    ];
 | 
				
			||||||
      break;
 | 
					  } else if (period === '周' && than === '环比') {
 | 
				
			||||||
    case "月":
 | 
					    items = [
 | 
				
			||||||
 | 
					      { label: `本周累计`, value: valueTuple[1] },
 | 
				
			||||||
 | 
					      { label: `上周累计`, value: valueTuple[0] },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else if (period === '月' && than === '同比') {
 | 
				
			||||||
    items = [
 | 
					    items = [
 | 
				
			||||||
      { label: `${month}月累计`, value: valueTuple[1] },
 | 
					      { label: `${month}月累计`, value: valueTuple[1] },
 | 
				
			||||||
      { label: `去年${month}月累计`, value: valueTuple[0] },
 | 
					      { label: `去年${month}月累计`, value: valueTuple[0] },
 | 
				
			||||||
      { label: `${month}月目标`, value: valueTuple[2] },
 | 
					      { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
    ];
 | 
					    ];
 | 
				
			||||||
      break;
 | 
					  } else if (period === '月' && than === '环比') {
 | 
				
			||||||
    case "年":
 | 
					    items = [
 | 
				
			||||||
 | 
					      { label: `${month}月累计`, value: valueTuple[1] },
 | 
				
			||||||
 | 
					      { label: `${lastMonth}月累计`, value: valueTuple[0] },
 | 
				
			||||||
 | 
					      { label: `${month}月目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
    items = [
 | 
					    items = [
 | 
				
			||||||
      { label: `${year}年累计`, value: valueTuple[1] },
 | 
					      { label: `${year}年累计`, value: valueTuple[1] },
 | 
				
			||||||
      { label: `${year - 1}年累计`, value: valueTuple[0] },
 | 
					      { label: `${year - 1}年累计`, value: valueTuple[0] },
 | 
				
			||||||
      { label: `${year}年目标`, value: valueTuple[2] },
 | 
					      { label: `${year}年目标`, value: valueTuple[2] },
 | 
				
			||||||
    ];
 | 
					    ];
 | 
				
			||||||
      break;
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					  // switch (period) {
 | 
				
			||||||
 | 
					  //   case "年":
 | 
				
			||||||
 | 
					  //     items = [
 | 
				
			||||||
 | 
					  //       { label: `${year}年累计`, value: valueTuple[1] },
 | 
				
			||||||
 | 
					  //       { label: `${year - 1}年累计`, value: valueTuple[0] },
 | 
				
			||||||
 | 
					  //       { label: `${year}年目标`, value: valueTuple[2] },
 | 
				
			||||||
 | 
					  //     ];
 | 
				
			||||||
 | 
					  //     break;
 | 
				
			||||||
 | 
					  // }
 | 
				
			||||||
  return items;
 | 
					  return items;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
@@ -191,6 +281,7 @@ function calculateItems(period, valueTuple) {
 | 
				
			|||||||
  padding: 0 10%;
 | 
					  padding: 0 10%;
 | 
				
			||||||
  /* margin: 10%; */
 | 
					  /* margin: 10%; */
 | 
				
			||||||
  /* min-width: 300px; */
 | 
					  /* min-width: 300px; */
 | 
				
			||||||
 | 
					  align-self: stretch;
 | 
				
			||||||
  height: 0;
 | 
					  height: 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -7,22 +7,12 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="double-ring-wrapper">
 | 
					  <div class="double-ring-wrapper">
 | 
				
			||||||
    <template v-if="period == '月' || period == '年'">
 | 
					    <template>
 | 
				
			||||||
      <copilot-select
 | 
					      <copilot-select @update:active="handleActiveUpdate" :options="cityOptions" />
 | 
				
			||||||
        @update:active="handleActiveUpdate"
 | 
					 | 
				
			||||||
        :options="cityOptions"
 | 
					 | 
				
			||||||
      />
 | 
					 | 
				
			||||||
      <div class="flex-1 stretch">
 | 
					      <div class="flex-1 stretch">
 | 
				
			||||||
        <DoubleRingChartVue
 | 
					        <DoubleRingChartVue :data-source="dataSource" :period="period" :than="than" :factoryId="factoryId" />
 | 
				
			||||||
          :data-source="dataSource"
 | 
					 | 
				
			||||||
          :period="period"
 | 
					 | 
				
			||||||
          :factoryId="factoryId"
 | 
					 | 
				
			||||||
        />
 | 
					 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </template>
 | 
					    </template>
 | 
				
			||||||
    <template v-else>
 | 
					 | 
				
			||||||
      <CityData :data-source="dataSource" :period="period" />
 | 
					 | 
				
			||||||
    </template>
 | 
					 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -43,6 +33,10 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,91 @@
 | 
				
			|||||||
 | 
					<!--
 | 
				
			||||||
 | 
					 * @Author: zhp
 | 
				
			||||||
 | 
					 * @Date: 2024-05-24 15:15:00
 | 
				
			||||||
 | 
					 * @LastEditTime: 2024-05-28 08:42:36
 | 
				
			||||||
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="double-ring-wrapper">
 | 
				
			||||||
 | 
					    <template >
 | 
				
			||||||
 | 
					      <copilot-select
 | 
				
			||||||
 | 
					        @update:active="handleActiveUpdate"
 | 
				
			||||||
 | 
					        :options="cityOptions"
 | 
				
			||||||
 | 
					      />
 | 
				
			||||||
 | 
					      <div class="flex-1 stretch">
 | 
				
			||||||
 | 
					        <DoubleRingChartVue
 | 
				
			||||||
 | 
					          :data-source="dataSource"
 | 
				
			||||||
 | 
					          :than="than"
 | 
				
			||||||
 | 
					          :period="period"
 | 
				
			||||||
 | 
					          :factoryId="factoryId"
 | 
				
			||||||
 | 
					        />
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </template>
 | 
				
			||||||
 | 
					    <!-- <template v-else>
 | 
				
			||||||
 | 
					      <CityData :data-source="dataSource" :period="period" />
 | 
				
			||||||
 | 
					    </template> -->
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import CopilotSelect from "@/views/copilot/components/select.vue";
 | 
				
			||||||
 | 
					import DoubleRingChartVue from "./DoubleRingChart.vue";
 | 
				
			||||||
 | 
					import CityData from "../city/CityData.vue";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "DoubleRingWrapper",
 | 
				
			||||||
 | 
					  components: { CopilotSelect, DoubleRingChartVue, CityData },
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    dataSource: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: null,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    period: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "日",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      factoryId: 4, // 默认成都
 | 
				
			||||||
 | 
					      cityOptions: [
 | 
				
			||||||
 | 
					        "成都",
 | 
				
			||||||
 | 
					        "邯郸",
 | 
				
			||||||
 | 
					        "株洲",
 | 
				
			||||||
 | 
					        "佳木斯",
 | 
				
			||||||
 | 
					        "凯盛光伏",
 | 
				
			||||||
 | 
					        "蚌埠兴科",
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    handleActiveUpdate(index) {
 | 
				
			||||||
 | 
					      this.factoryId = index;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					.double-ring-wrapper {
 | 
				
			||||||
 | 
					  height: 100%;
 | 
				
			||||||
 | 
					  padding: 12px 24px;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  gap: 12px;
 | 
				
			||||||
 | 
					  flex-direction: column;
 | 
				
			||||||
 | 
					  align-items: center;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.flex-1 {
 | 
				
			||||||
 | 
					  flex: 1;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.stretch {
 | 
				
			||||||
 | 
					  align-self: stretch;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
@@ -1,29 +1,30 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
    filename: index.vue
 | 
					 * @Author: zhp
 | 
				
			||||||
    author: liubin
 | 
					 * @Date: 2024-05-10 11:10:54
 | 
				
			||||||
    date: 2024-04-16 14:40:15
 | 
					 * @LastEditTime: 2024-05-28 13:36:07
 | 
				
			||||||
    description: 产量驾驶舱
 | 
					 * @LastEditors: zhp
 | 
				
			||||||
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="yield-copilot">
 | 
					  <div class="yield-copilot">
 | 
				
			||||||
    <section class="top flex">
 | 
					    <section class="top flex">
 | 
				
			||||||
      <db-container class="std-yield" title="标准组件产出" icon="std">
 | 
					      <db-container class="std-yield" title="标准组件产出" icon="std">
 | 
				
			||||||
        <std-output :period="period" />
 | 
					        <std-output v-if="show" :period="period" :than="than" />
 | 
				
			||||||
      </db-container>
 | 
					      </db-container>
 | 
				
			||||||
      <db-container class="chip-yield" title="芯片产出" icon="chip2">
 | 
					      <db-container class="chip-yield" title="芯片产出" icon="chip2">
 | 
				
			||||||
        <chip-output :period="period" />
 | 
					        <chip-output v-if="show" :period="period" :than="than" />
 | 
				
			||||||
      </db-container>
 | 
					      </db-container>
 | 
				
			||||||
      <db-container class="bipv-yield" title="BIPV产出" icon="bipv">
 | 
					      <db-container class="bipv-yield" title="BIPV产出" icon="bipv">
 | 
				
			||||||
        <bipv-output :period="period" />
 | 
					        <bipv-output v-if="show" :period="period" :than="than" />
 | 
				
			||||||
      </db-container>
 | 
					      </db-container>
 | 
				
			||||||
    </section>
 | 
					    </section>
 | 
				
			||||||
    <section class="bottom flex">
 | 
					    <section class="bottom flex">
 | 
				
			||||||
      <db-container class="fto-involve" title="FTO投入">
 | 
					      <db-container class="fto-involve" title="FTO投入">
 | 
				
			||||||
        <fto-invest :period="period" />
 | 
					        <fto-invest :period="period" :than="than" />
 | 
				
			||||||
      </db-container>
 | 
					      </db-container>
 | 
				
			||||||
      <db-container class="chip-involve" title="芯片投入" icon="chip">
 | 
					      <db-container class="chip-involve" title="芯片投入" icon="chip">
 | 
				
			||||||
        <chip-invest :period="period" />
 | 
					        <chip-invest :period="period" :than="than" />
 | 
				
			||||||
      </db-container>
 | 
					      </db-container>
 | 
				
			||||||
    </section>
 | 
					    </section>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
@@ -52,22 +53,40 @@ export default {
 | 
				
			|||||||
      type: String,
 | 
					      type: String,
 | 
				
			||||||
      default: "日",
 | 
					      default: "日",
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      type: String,
 | 
				
			||||||
 | 
					      default: "同比",
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {};
 | 
					    return {
 | 
				
			||||||
 | 
					      show:false,
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  watch: {
 | 
					  watch: {
 | 
				
			||||||
    period: {
 | 
					    period: {
 | 
				
			||||||
      handler(val) {
 | 
					      handler(val) {
 | 
				
			||||||
        val && this.fetchData(val);
 | 
					        val && this.fetchData(val,this.than);
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      immediate: true,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    than: {
 | 
				
			||||||
 | 
					      handler(val) {
 | 
				
			||||||
 | 
					        console.log(val)
 | 
				
			||||||
 | 
					        val && this.fetchData(this.period,val);
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      immediate: true,
 | 
					      immediate: true,
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    fetchData(period = "日") {
 | 
					    fetchData(period = "日", than) {
 | 
				
			||||||
 | 
					      // this.$store.commit('copilot/clearState')
 | 
				
			||||||
      console.log(`产量驾驶舱,获取${period}数据`);
 | 
					      console.log(`产量驾驶舱,获取${period}数据`);
 | 
				
			||||||
      this.$store.dispatch("copilot/initCopilot", { period, source: "yield" });
 | 
					      this.$store.dispatch("copilot/initCopilot", { period, source: "yield", than }).then(() => {
 | 
				
			||||||
 | 
					        this.$nextTick(() => {
 | 
				
			||||||
 | 
					          this.show = true
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,6 +4,8 @@ export default ({
 | 
				
			|||||||
  previousSum,
 | 
					  previousSum,
 | 
				
			||||||
  currentSum,
 | 
					  currentSum,
 | 
				
			||||||
  targetSum,
 | 
					  targetSum,
 | 
				
			||||||
 | 
					  currentName,
 | 
				
			||||||
 | 
					  preName,
 | 
				
			||||||
}) => ({
 | 
					}) => ({
 | 
				
			||||||
  grid: {
 | 
					  grid: {
 | 
				
			||||||
    left: 0,
 | 
					    left: 0,
 | 
				
			||||||
@@ -57,7 +59,7 @@ export default ({
 | 
				
			|||||||
      data: [
 | 
					      data: [
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          value: currentSum,
 | 
					          value: currentSum,
 | 
				
			||||||
          name: "当前累计产出",
 | 
					          name: currentName,
 | 
				
			||||||
          selected: false,
 | 
					          selected: false,
 | 
				
			||||||
          itemStyle: {
 | 
					          itemStyle: {
 | 
				
			||||||
            borderJoin: "round",
 | 
					            borderJoin: "round",
 | 
				
			||||||
@@ -108,7 +110,7 @@ export default ({
 | 
				
			|||||||
      data: [
 | 
					      data: [
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          value: previousSum,
 | 
					          value: previousSum,
 | 
				
			||||||
          name: "上期累计产出",
 | 
					          name: preName,
 | 
				
			||||||
          selected: false,
 | 
					          selected: false,
 | 
				
			||||||
          itemStyle: {
 | 
					          itemStyle: {
 | 
				
			||||||
            borderJoin: "round",
 | 
					            borderJoin: "round",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -6,7 +6,7 @@
 | 
				
			|||||||
-->
 | 
					-->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="company-info" :style="styles">
 | 
					  <div class="company-info" @click="handleChangeRoute()" :style="styles">
 | 
				
			||||||
    <div class="corner bl"></div>
 | 
					    <div class="corner bl"></div>
 | 
				
			||||||
    <div class="corner br"></div>
 | 
					    <div class="corner br"></div>
 | 
				
			||||||
    <h2>{{ info.companyName }}</h2>
 | 
					    <h2>{{ info.companyName }}</h2>
 | 
				
			||||||
@@ -31,7 +31,7 @@ export default {
 | 
				
			|||||||
    position: {
 | 
					    position: {
 | 
				
			||||||
      type: Object,
 | 
					      type: Object,
 | 
				
			||||||
      required: true,
 | 
					      required: true,
 | 
				
			||||||
      default: () => ({ x: 0, y: 0 }),
 | 
					      default: () => ({ tx: 0, ty: 0 }),
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  filters: {
 | 
					  filters: {
 | 
				
			||||||
@@ -49,16 +49,23 @@ export default {
 | 
				
			|||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    styles() {
 | 
					    styles() {
 | 
				
			||||||
      return {
 | 
					      return {
 | 
				
			||||||
        left: `${this.position.x}%`,
 | 
					        left: `${this.position.tx}%`,
 | 
				
			||||||
        top: `${this.position.y}%`,
 | 
					        top: `${this.position.ty}%`,
 | 
				
			||||||
      };
 | 
					      };
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {},
 | 
					  methods: {
 | 
				
			||||||
 | 
					    handleChangeRoute() {
 | 
				
			||||||
 | 
					      this.$router.push({
 | 
				
			||||||
 | 
					        path: this.position.path
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<style scoped lang="scss">
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@font-face {
 | 
					@font-face {
 | 
				
			||||||
  font-family: 优设标题黑;
 | 
					  font-family: 优设标题黑;
 | 
				
			||||||
  src: url(../../../assets/YouSheBiaoTiHei-2.ttf);
 | 
					  src: url(../../../assets/YouSheBiaoTiHei-2.ttf);
 | 
				
			||||||
@@ -71,18 +78,25 @@ export default {
 | 
				
			|||||||
  z-index: 9999;
 | 
					  z-index: 9999;
 | 
				
			||||||
  // padding: 14px;
 | 
					  // padding: 14px;
 | 
				
			||||||
  padding: 0.745vw;
 | 
					  padding: 0.745vw;
 | 
				
			||||||
  backdrop-filter: blur(2px);
 | 
					  // padding: 0 vw;
 | 
				
			||||||
  border-radius: 4px;
 | 
					  cursor: pointer;
 | 
				
			||||||
 | 
					  // backdrop-filter: blur(2px);
 | 
				
			||||||
 | 
					  // border-radius: 4px;
 | 
				
			||||||
  transform: translate(-50%, -100%);
 | 
					  transform: translate(-50%, -100%);
 | 
				
			||||||
  box-shadow: inset 0 0 12px 2px #fff3;
 | 
					  box-shadow: inset 0 0 12px 2px #fff3;
 | 
				
			||||||
 | 
					  background: url(../../../assets/images/homeindex/info.png) no-repeat 0 0 / 100% 100%;
 | 
				
			||||||
 | 
					    // background: radial-gradient(circle farthest-corner at bottom center,rgba(255,239,162,.7)  10%, #021842 30%);
 | 
				
			||||||
  // 在这里设置一个总的字体大小 不失为一个好的选择
 | 
					  // 在这里设置一个总的字体大小 不失为一个好的选择
 | 
				
			||||||
  font-size: 1vw;
 | 
					  font-size: 1vw;
 | 
				
			||||||
 | 
					  // filter: blur(13);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
h2 {
 | 
					h2 {
 | 
				
			||||||
 | 
					  padding: 0 1vw;
 | 
				
			||||||
  margin: 6px 0;
 | 
					  margin: 6px 0;
 | 
				
			||||||
  font-family: 优设标题黑;
 | 
					  font-family: 优设标题黑;
 | 
				
			||||||
  color: #fff;
 | 
					  color: #fff;
 | 
				
			||||||
 | 
					  letter-spacing:5px;
 | 
				
			||||||
  // font-size: 24px;
 | 
					  // font-size: 24px;
 | 
				
			||||||
  font-size: 1.276em;
 | 
					  font-size: 1.276em;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,60 +1,50 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="dashboard-factory-all">
 | 
					  <div class="dashboard-factory-all">
 | 
				
			||||||
    <div id="map-container">
 | 
					    <div id="map-container">
 | 
				
			||||||
 | 
					      <div v-if="visible" class="cdLine"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="zzLine"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="rcLine"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="rcLineTwo"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="hdLine"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="hdLineTwo"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="ksLine"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="bbLine"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="bbLineTwo"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="bbLineThree"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="jmsLine"></div>
 | 
				
			||||||
 | 
					      <div v-if="visible" class="jmsLineTwo"></div>
 | 
				
			||||||
      <div class="databoard">
 | 
					      <div class="databoard">
 | 
				
			||||||
        <db-header class="db-header"></db-header>
 | 
					        <db-header class="db-header"></db-header>
 | 
				
			||||||
        <div class="db-body">
 | 
					        <div class="db-body">
 | 
				
			||||||
          <div class="db-left">
 | 
					          <div class="db-left">
 | 
				
			||||||
            <db-container
 | 
					            <db-container icon="cube" title="FTO投入" @refresh="() => (ftoKey = Math.random())">
 | 
				
			||||||
              icon="cube"
 | 
					 | 
				
			||||||
              title="FTO投入"
 | 
					 | 
				
			||||||
              @refresh="() => (ftoKey = Math.random())"
 | 
					 | 
				
			||||||
            >
 | 
					 | 
				
			||||||
              <fto-chart :key="ftoKey" />
 | 
					              <fto-chart :key="ftoKey" />
 | 
				
			||||||
            </db-container>
 | 
					            </db-container>
 | 
				
			||||||
            <db-container
 | 
					            <db-container icon="chip2" title="芯片投入" @refresh="() => (chipInvestKey = Math.random())">
 | 
				
			||||||
              icon="chip2"
 | 
					 | 
				
			||||||
              title="芯片投入"
 | 
					 | 
				
			||||||
              @refresh="() => (chipInvestKey = Math.random())"
 | 
					 | 
				
			||||||
            >
 | 
					 | 
				
			||||||
              <chip-invest-chart :key="chipInvestKey" />
 | 
					              <chip-invest-chart :key="chipInvestKey" />
 | 
				
			||||||
            </db-container>
 | 
					            </db-container>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
          <div class="db-right">
 | 
					          <div class="db-right">
 | 
				
			||||||
            <db-container
 | 
					            <db-container side="right" icon="chip" title="芯片产出" @refresh="() => (chipYieldKey = Math.random())">
 | 
				
			||||||
              side="right"
 | 
					 | 
				
			||||||
              icon="chip"
 | 
					 | 
				
			||||||
              title="芯片产出"
 | 
					 | 
				
			||||||
              @refresh="() => (chipYieldKey = Math.random())"
 | 
					 | 
				
			||||||
            >
 | 
					 | 
				
			||||||
              <chip-yield-chart :key="chipYieldKey" />
 | 
					              <chip-yield-chart :key="chipYieldKey" />
 | 
				
			||||||
            </db-container>
 | 
					            </db-container>
 | 
				
			||||||
            <db-container
 | 
					            <db-container side="right" icon="std" title="标准组件产出" @refresh="() => (stdKey = Math.random())">
 | 
				
			||||||
              side="right"
 | 
					 | 
				
			||||||
              icon="std"
 | 
					 | 
				
			||||||
              title="标准组件产出"
 | 
					 | 
				
			||||||
              @refresh="() => (stdKey = Math.random())"
 | 
					 | 
				
			||||||
            >
 | 
					 | 
				
			||||||
              <std-chart :key="stdKey" />
 | 
					              <std-chart :key="stdKey" />
 | 
				
			||||||
            </db-container>
 | 
					            </db-container>
 | 
				
			||||||
            <db-container
 | 
					            <db-container side="right" icon="bipv" title="BIPV产出" @refresh="() => (bipvKey = Math.random())">
 | 
				
			||||||
              side="right"
 | 
					 | 
				
			||||||
              icon="bipv"
 | 
					 | 
				
			||||||
              title="BIPV产出"
 | 
					 | 
				
			||||||
              @refresh="() => (bipvKey = Math.random())"
 | 
					 | 
				
			||||||
            >
 | 
					 | 
				
			||||||
              <bipv-chart :key="bipvKey" />
 | 
					              <bipv-chart :key="bipvKey" />
 | 
				
			||||||
            </db-container>
 | 
					            </db-container>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <company-info
 | 
					    <company-info v-if="visible" :info="info" :position="rcHintPosition" />
 | 
				
			||||||
      v-if="visible"
 | 
					    <ks-company-info v-if="visible" :info="ksInfo" :position="ksHintPosition" />
 | 
				
			||||||
      :info="info"
 | 
					    <jms-company-info v-if="visible" :info="jmsInfo" :position="jmsHintPosition" />
 | 
				
			||||||
      :position="hintPosition"
 | 
					    <hd-company-info v-if="visible" :info="hdInfo" :position="hdHintPosition" />
 | 
				
			||||||
      @close="closeHint"
 | 
					    <bb-company-info v-if="visible" :info="bbInfo" :position="bbHintPosition" />
 | 
				
			||||||
    />
 | 
					    <cd-company-info v-if="visible" :info="cdInfo" :position="cdHintPosition" />
 | 
				
			||||||
 | 
					    <zz-company-info v-if="visible" :info="zzInfo" :position="zzHintPosition" />
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -71,25 +61,31 @@ import StdChart from "./dashboard/charts/StdChart.vue";
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
const LOCATIONS = [
 | 
					const LOCATIONS = [
 | 
				
			||||||
  // 佳木斯
 | 
					  // 佳木斯
 | 
				
			||||||
  { x: 67, y: 20 },
 | 
					  { x: 67, y: 20, tx: 60, ty: 29,  path: 'copilot/jmsIndex' },
 | 
				
			||||||
  // 成都
 | 
					  // 成都
 | 
				
			||||||
  { x: 46, y: 56 },
 | 
					  { x: 46, y: 56,tx:46,ty:93, path: 'copilot/cdIndex' },
 | 
				
			||||||
  // 蚌埠1
 | 
					  // 蚌埠1
 | 
				
			||||||
  { x: 60, y: 52 },
 | 
					  { x: 60, y: 52, tx: 35.5, ty: 48.3, path: 'copilot/bbIndex' },
 | 
				
			||||||
  // 蚌埠2
 | 
					  // 蚌埠2
 | 
				
			||||||
  { x: 61, y: 53 },
 | 
					  { x: 61, y: 53,tx:39,ty:68, path: 'copilot/ksIndex' },
 | 
				
			||||||
  // 江西 瑞昌
 | 
					  // 江西 瑞昌
 | 
				
			||||||
  { x: 60, y: 58 },
 | 
					  { x: 60, y: 58, tx: 68, ty: 52, path: 'copilot/factory-data' },
 | 
				
			||||||
  // 湖南 株洲
 | 
					  // 湖南 株洲
 | 
				
			||||||
  { x: 56, y: 60 },
 | 
					  { x: 56, y: 60, tx: 60, ty: 95, path: 'copilot/zzIndex' },
 | 
				
			||||||
  // 邯郸
 | 
					  // 邯郸
 | 
				
			||||||
  { x: 58, y: 45 },
 | 
					  { x: 58, y: 45, tx: 47, ty: 34, path: 'copilot/hdIndex' },
 | 
				
			||||||
];
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "Index",
 | 
					  name: "Index",
 | 
				
			||||||
  components: {
 | 
					  components: {
 | 
				
			||||||
    CompanyInfo,
 | 
					    CompanyInfo,
 | 
				
			||||||
 | 
					    ksCompanyInfo: CompanyInfo,
 | 
				
			||||||
 | 
					    hdCompanyInfo: CompanyInfo,
 | 
				
			||||||
 | 
					    bbCompanyInfo: CompanyInfo,
 | 
				
			||||||
 | 
					    cdCompanyInfo: CompanyInfo,
 | 
				
			||||||
 | 
					    zzCompanyInfo: CompanyInfo,
 | 
				
			||||||
 | 
					    jmsCompanyInfo: CompanyInfo,
 | 
				
			||||||
    DbHeader: DashboardHeader,
 | 
					    DbHeader: DashboardHeader,
 | 
				
			||||||
    DbContainer: Container,
 | 
					    DbContainer: Container,
 | 
				
			||||||
    FtoChart,
 | 
					    FtoChart,
 | 
				
			||||||
@@ -100,8 +96,15 @@ export default {
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
 | 
					      // homeStore:undefined,
 | 
				
			||||||
      visible: false,
 | 
					      visible: false,
 | 
				
			||||||
      hintPosition: null,
 | 
					      hintPosition: null,
 | 
				
			||||||
 | 
					      zzHintPosition: null,
 | 
				
			||||||
 | 
					      ksHintPosition: null,
 | 
				
			||||||
 | 
					      bbHintPosition: null,
 | 
				
			||||||
 | 
					      hdHintPosition: null,
 | 
				
			||||||
 | 
					      cdHintPosition: null,
 | 
				
			||||||
 | 
					      jmsHintPosition: null,
 | 
				
			||||||
      ftoKey: Math.random(),
 | 
					      ftoKey: Math.random(),
 | 
				
			||||||
      chipInvestKey: Math.random(),
 | 
					      chipInvestKey: Math.random(),
 | 
				
			||||||
      chipYieldKey: Math.random(),
 | 
					      chipYieldKey: Math.random(),
 | 
				
			||||||
@@ -109,15 +112,28 @@ export default {
 | 
				
			|||||||
      bipvKey: Math.random(),
 | 
					      bipvKey: Math.random(),
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    homeStore() {
 | 
				
			||||||
 | 
					      return this.$store.getters.home
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
  mounted() {
 | 
					  mounted() {
 | 
				
			||||||
    this.$store.dispatch("copilot/initHome");
 | 
					    // var w = window.screen.width;
 | 
				
			||||||
 | 
					    // var zoom = w / 1920;
 | 
				
			||||||
 | 
					    // let screen = document.getElementById("map-container")
 | 
				
			||||||
 | 
					    // console.log(screen);
 | 
				
			||||||
 | 
					    // screen.style.zoom = zoom
 | 
				
			||||||
 | 
					    //   // "zoom": ,
 | 
				
			||||||
 | 
					    // screen.style.transform = `scale(" + ${zoom} + ")`
 | 
				
			||||||
 | 
					    // };
 | 
				
			||||||
 | 
					    this.$store.dispatch("copilot/initHome").then((res) => {
 | 
				
			||||||
      this.$nextTick(() => {
 | 
					      this.$nextTick(() => {
 | 
				
			||||||
        this.initPins();
 | 
					        this.initPins();
 | 
				
			||||||
 | 
					 | 
				
			||||||
        // 调整 echarts 大小
 | 
					        // 调整 echarts 大小
 | 
				
			||||||
      window.onresize = () => {};
 | 
					        window.onresize = () => { };
 | 
				
			||||||
    });
 | 
					      })
 | 
				
			||||||
 | 
					    })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  beforeRouteEnter(to, from, next) {
 | 
					  beforeRouteEnter(to, from, next) {
 | 
				
			||||||
    next((vm) => {
 | 
					    next((vm) => {
 | 
				
			||||||
@@ -126,17 +142,60 @@ export default {
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    initPins() {
 | 
					    initPins() {
 | 
				
			||||||
 | 
					      // const cdLine = document.createElement("div");
 | 
				
			||||||
 | 
					      // const zzLine = document.createElement("div");
 | 
				
			||||||
 | 
					      // const rcLine = document.createElement("div");
 | 
				
			||||||
 | 
					      // const rcLineTwo = document.createElement("div");
 | 
				
			||||||
 | 
					      // const hdLine = document.createElement("div");
 | 
				
			||||||
 | 
					      // const ksLine = document.createElement("div");
 | 
				
			||||||
 | 
					      // const bbLine = document.createElement("div");
 | 
				
			||||||
 | 
					      // const bbLineTwo = document.createElement("div");
 | 
				
			||||||
 | 
					      // const bbLineThree = document.createElement("div");
 | 
				
			||||||
 | 
					      // cdLine.className = "cdLine";
 | 
				
			||||||
 | 
					      // cdLine.style.left = `46.71%`;
 | 
				
			||||||
 | 
					      // cdLine.style.top = `59%`;
 | 
				
			||||||
 | 
					      // zzLine.className = "zzLine";
 | 
				
			||||||
 | 
					      // zzLine.style.left = `56.8%`;
 | 
				
			||||||
 | 
					      // zzLine.style.top = `60.8%`;
 | 
				
			||||||
 | 
					      // rcLine.className = "rcLine";
 | 
				
			||||||
 | 
					      // rcLine.style.left = `66.8%`;
 | 
				
			||||||
 | 
					      // rcLine.style.top = `52%`;
 | 
				
			||||||
 | 
					      // rcLineTwo.className = "rcLineTwo";
 | 
				
			||||||
 | 
					      // rcLineTwo.style.left = `58.7%`;
 | 
				
			||||||
 | 
					      // rcLineTwo.style.top = `34%`;
 | 
				
			||||||
 | 
					      // hdLine.className = "hdLine";
 | 
				
			||||||
 | 
					      // ksLine.className = "ksLine";
 | 
				
			||||||
 | 
					      // bbLine.className = "bbLine";
 | 
				
			||||||
 | 
					      // bbLineTwo.className = "bbLineTwo";
 | 
				
			||||||
 | 
					      // bbLineThree.className = "bbLineThree";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      // document.getElementById("map-container").appendChild(cdLine);
 | 
				
			||||||
 | 
					      // document.getElementById("map-container").appendChild(zzLine);
 | 
				
			||||||
 | 
					      // document.getElementById("map-container").appendChild(rcLine);
 | 
				
			||||||
 | 
					      // document.getElementById("map-container").appendChild(rcLineTwo);
 | 
				
			||||||
 | 
					      // document.getElementById("map-container").appendChild(hdLine);
 | 
				
			||||||
 | 
					      // document.getElementById("map-container").appendChild(ksLine);
 | 
				
			||||||
 | 
					      // document.getElementById("map-container").appendChild(bbLine);
 | 
				
			||||||
 | 
					      // document.getElementById("map-container").appendChild(bbLineTwo);
 | 
				
			||||||
 | 
					      // document.getElementById("map-container").appendChild(bbLineThree);
 | 
				
			||||||
 | 
					      // console.log(" this.homeStore", this.$store.getters.home);
 | 
				
			||||||
      LOCATIONS.map((loc) => {
 | 
					      LOCATIONS.map((loc) => {
 | 
				
			||||||
 | 
					        console.log("loc", loc);
 | 
				
			||||||
        const pin = document.createElement("div");
 | 
					        const pin = document.createElement("div");
 | 
				
			||||||
        pin.className = "pin";
 | 
					        pin.className = "pin";
 | 
				
			||||||
        pin.style.left = `${loc.x}%`;
 | 
					        pin.style.left = `${loc.x}%`;
 | 
				
			||||||
        pin.style.top = `${loc.y}%`;
 | 
					        pin.style.top = `${loc.y}%`;
 | 
				
			||||||
        pin.addEventListener("mouseenter", () => {
 | 
					        // pin.addEventListener("mouseenter", () => {
 | 
				
			||||||
          this.showHint(loc);
 | 
					          this.showHint(loc);
 | 
				
			||||||
        });
 | 
					        // });
 | 
				
			||||||
        pin.addEventListener("mouseleave", () => {
 | 
					        // pin.addEventListener("mouseleave", () => {
 | 
				
			||||||
          this.closeHint();
 | 
					        //   this.closeHint();
 | 
				
			||||||
        });
 | 
					        // });
 | 
				
			||||||
 | 
					        // pin.addEventListener("click", () => {
 | 
				
			||||||
 | 
					        //   this.$router.push({
 | 
				
			||||||
 | 
					        //     path:loc.path
 | 
				
			||||||
 | 
					        //   })
 | 
				
			||||||
 | 
					        // });
 | 
				
			||||||
        document.getElementById("map-container").appendChild(pin);
 | 
					        document.getElementById("map-container").appendChild(pin);
 | 
				
			||||||
      });
 | 
					      });
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -145,8 +204,6 @@ export default {
 | 
				
			|||||||
      this.hintPosition = null;
 | 
					      this.hintPosition = null;
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    showHint(position) {
 | 
					    showHint(position) {
 | 
				
			||||||
      const homeStore = this.$store.getters.home;
 | 
					 | 
				
			||||||
      this.hintPosition = position;
 | 
					 | 
				
			||||||
      const templateInfo = {
 | 
					      const templateInfo = {
 | 
				
			||||||
        companyName: "",
 | 
					        companyName: "",
 | 
				
			||||||
        items: [
 | 
					        items: [
 | 
				
			||||||
@@ -156,53 +213,63 @@ export default {
 | 
				
			|||||||
          { label: "标准组件产出", value: 0 }, // Math.floor(Math.random() * 1000000) },
 | 
					          { label: "标准组件产出", value: 0 }, // Math.floor(Math.random() * 1000000) },
 | 
				
			||||||
        ],
 | 
					        ],
 | 
				
			||||||
      };
 | 
					      };
 | 
				
			||||||
 | 
					 | 
				
			||||||
      if (position === LOCATIONS[0]) {
 | 
					      if (position === LOCATIONS[0]) {
 | 
				
			||||||
        templateInfo.companyName = "佳木斯中建材光电材料有限公司";
 | 
					        templateInfo.companyName = "佳木斯中建材";
 | 
				
			||||||
        templateInfo.items[0].value = homeStore.ftoInvest.current[3];
 | 
					        this.jmsHintPosition = position;
 | 
				
			||||||
        templateInfo.items[2].value = homeStore.chipInvest.current[3];
 | 
					        templateInfo.items[0].value = this.homeStore.ftoInvest.current[3];
 | 
				
			||||||
        templateInfo.items[1].value = homeStore.chipOutput.current[3];
 | 
					        templateInfo.items[2].value = this.homeStore.chipInvest.current[3];
 | 
				
			||||||
        templateInfo.items[3].value = homeStore.stdOutput.current[3];
 | 
					        templateInfo.items[1].value = this.homeStore.chipOutput.current[3];
 | 
				
			||||||
 | 
					        templateInfo.items[3].value = this.homeStore.stdOutput.current[3];
 | 
				
			||||||
 | 
					        this.jmsInfo = templateInfo;
 | 
				
			||||||
      } else if (position === LOCATIONS[1]) {
 | 
					      } else if (position === LOCATIONS[1]) {
 | 
				
			||||||
        templateInfo.companyName = "成都中建材光电材料有限公司";
 | 
					        this.cdHintPosition = position;
 | 
				
			||||||
        templateInfo.items[0].value = homeStore.ftoInvest.current[4];
 | 
					        templateInfo.companyName = "成都中建材";
 | 
				
			||||||
        templateInfo.items[2].value = homeStore.chipInvest.current[4];
 | 
					        templateInfo.items[0].value = this.homeStore.ftoInvest?.current[4];
 | 
				
			||||||
        templateInfo.items[1].value = homeStore.chipOutput.current[4];
 | 
					        templateInfo.items[2].value = this.homeStore.chipInvest.current[4];
 | 
				
			||||||
        templateInfo.items[3].value = homeStore.stdOutput.current[4];
 | 
					        templateInfo.items[1].value = this.homeStore.chipOutput.current[4];
 | 
				
			||||||
 | 
					        templateInfo.items[3].value = this.homeStore.stdOutput.current[4];
 | 
				
			||||||
 | 
					        this.cdInfo = templateInfo;
 | 
				
			||||||
      } else if (position === LOCATIONS[2]) {
 | 
					      } else if (position === LOCATIONS[2]) {
 | 
				
			||||||
        templateInfo.companyName = "蚌埠兴科玻璃有限公司";
 | 
					        this.bbHintPosition = position;
 | 
				
			||||||
        templateInfo.items[0].value = homeStore.ftoInvest.current[6];
 | 
					        templateInfo.companyName = "蚌埠兴科";
 | 
				
			||||||
        templateInfo.items[2].value = homeStore.chipInvest.current[6];
 | 
					        templateInfo.items[0].value = this.homeStore.ftoInvest?.current[6];
 | 
				
			||||||
        templateInfo.items[1].value = homeStore.chipOutput.current[6];
 | 
					        templateInfo.items[2].value = this.homeStore.chipInvest.current[6];
 | 
				
			||||||
        templateInfo.items[3].value = homeStore.stdOutput.current[6];
 | 
					        templateInfo.items[1].value = this.homeStore.chipOutput?.current[6];
 | 
				
			||||||
 | 
					        templateInfo.items[3].value = this.homeStore.stdOutput.current[6];
 | 
				
			||||||
 | 
					        this.bbInfo = templateInfo;
 | 
				
			||||||
      } else if (position === LOCATIONS[3]) {
 | 
					      } else if (position === LOCATIONS[3]) {
 | 
				
			||||||
        templateInfo.companyName = "凯盛光伏材料有限公司(本部)";
 | 
					        this.ksHintPosition = position;
 | 
				
			||||||
        templateInfo.items[0].value = homeStore.ftoInvest.current[5];
 | 
					        templateInfo.companyName = "凯盛光伏";
 | 
				
			||||||
        templateInfo.items[2].value = homeStore.chipInvest.current[5];
 | 
					        templateInfo.items[0].value = this.homeStore.ftoInvest?.current[5];
 | 
				
			||||||
        templateInfo.items[1].value = homeStore.chipOutput.current[5];
 | 
					        templateInfo.items[2].value = this.homeStore.chipInvest.current[5];
 | 
				
			||||||
        templateInfo.items[3].value = homeStore.stdOutput.current[5];
 | 
					        templateInfo.items[1].value = this.homeStore.chipOutput.current[5];
 | 
				
			||||||
 | 
					        templateInfo.items[3].value = this.homeStore.stdOutput.current[5];
 | 
				
			||||||
 | 
					        this.ksInfo = templateInfo;
 | 
				
			||||||
      } else if (position === LOCATIONS[4]) {
 | 
					      } else if (position === LOCATIONS[4]) {
 | 
				
			||||||
        templateInfo.companyName = "瑞昌中建材光电材料有限公司";
 | 
					        this.rcHintPosition = position;
 | 
				
			||||||
        templateInfo.items[0].value = homeStore.ftoInvest.current[0];
 | 
					        templateInfo.companyName = "瑞昌中建材";
 | 
				
			||||||
        templateInfo.items[2].value = homeStore.chipInvest.current[0];
 | 
					        templateInfo.items[0].value = this.homeStore.ftoInvest?.current[0];
 | 
				
			||||||
        templateInfo.items[1].value = homeStore.chipOutput.current[0];
 | 
					        templateInfo.items[2].value = this.homeStore.chipInvest.current[0];
 | 
				
			||||||
        templateInfo.items[3].value = homeStore.stdOutput.current[0];
 | 
					        templateInfo.items[1].value = this.homeStore.chipOutput.current[0];
 | 
				
			||||||
      } else if (position === LOCATIONS[5]) {
 | 
					        templateInfo.items[3].value = this.homeStore.stdOutput.current[0];
 | 
				
			||||||
        templateInfo.companyName = "中建材(株洲)光电材料有限公司";
 | 
					 | 
				
			||||||
        templateInfo.items[0].value = homeStore.ftoInvest.current[2];
 | 
					 | 
				
			||||||
        templateInfo.items[2].value = homeStore.chipInvest.current[2];
 | 
					 | 
				
			||||||
        templateInfo.items[1].value = homeStore.chipOutput.current[2];
 | 
					 | 
				
			||||||
        templateInfo.items[3].value = homeStore.stdOutput.current[2];
 | 
					 | 
				
			||||||
      } else if (position === LOCATIONS[6]) {
 | 
					 | 
				
			||||||
        templateInfo.companyName = "中建材(邯郸)光电材料有限公司";
 | 
					 | 
				
			||||||
        templateInfo.items[0].value = homeStore.ftoInvest.current[1];
 | 
					 | 
				
			||||||
        templateInfo.items[2].value = homeStore.chipInvest.current[1];
 | 
					 | 
				
			||||||
        templateInfo.items[1].value = homeStore.chipOutput.current[1];
 | 
					 | 
				
			||||||
        templateInfo.items[3].value = homeStore.stdOutput.current[1];
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        this.info = templateInfo;
 | 
					        this.info = templateInfo;
 | 
				
			||||||
 | 
					      } else if (position === LOCATIONS[5]) {
 | 
				
			||||||
 | 
					        this.zzHintPosition = position;
 | 
				
			||||||
 | 
					        templateInfo.companyName = "株洲中建材";
 | 
				
			||||||
 | 
					        templateInfo.items[0].value = this.homeStore.ftoInvest?.current[2];
 | 
				
			||||||
 | 
					        templateInfo.items[2].value = this.homeStore.chipInvest.current[2];
 | 
				
			||||||
 | 
					        templateInfo.items[1].value = this.homeStore.chipOutput.current[2];
 | 
				
			||||||
 | 
					        templateInfo.items[3].value = this.homeStore.stdOutput.current[2];
 | 
				
			||||||
 | 
					        this.zzInfo = templateInfo;
 | 
				
			||||||
 | 
					      } else if (position === LOCATIONS[6]) {
 | 
				
			||||||
 | 
					        this.hdHintPosition = position;
 | 
				
			||||||
 | 
					        templateInfo.companyName = "邯郸中建材";
 | 
				
			||||||
 | 
					        templateInfo.items[0].value = this.homeStore.ftoInvest?.current[1];
 | 
				
			||||||
 | 
					        templateInfo.items[2].value = this.homeStore.chipInvest.current[1];
 | 
				
			||||||
 | 
					        templateInfo.items[1].value = this.homeStore.chipOutput.current[1];
 | 
				
			||||||
 | 
					        templateInfo.items[3].value = this.homeStore.stdOutput.current[1];
 | 
				
			||||||
 | 
					        this.hdInfo = templateInfo
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
      this.$nextTick(() => {
 | 
					      this.$nextTick(() => {
 | 
				
			||||||
        this.visible = true;
 | 
					        this.visible = true;
 | 
				
			||||||
      });
 | 
					      });
 | 
				
			||||||
@@ -225,8 +292,8 @@ export default {
 | 
				
			|||||||
#map-container {
 | 
					#map-container {
 | 
				
			||||||
  height: 100%;
 | 
					  height: 100%;
 | 
				
			||||||
  background: url(../assets/bgearth.png) no-repeat 0 0 / 100% 100%;
 | 
					  background: url(../assets/bgearth.png) no-repeat 0 0 / 100% 100%;
 | 
				
			||||||
 | 
					  // background-size: cover;
 | 
				
			||||||
  position: relative;
 | 
					  position: relative;
 | 
				
			||||||
 | 
					 | 
				
			||||||
  .databoard {
 | 
					  .databoard {
 | 
				
			||||||
    position: absolute;
 | 
					    position: absolute;
 | 
				
			||||||
    top: 0;
 | 
					    top: 0;
 | 
				
			||||||
@@ -257,6 +324,133 @@ export default {
 | 
				
			|||||||
</style>
 | 
					</style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<style>
 | 
					<style>
 | 
				
			||||||
 | 
					.cdLine {
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 46.71%;
 | 
				
			||||||
 | 
					  width: 2px;
 | 
				
			||||||
 | 
					  top: 59%;
 | 
				
			||||||
 | 
					  height: 148px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.zzLine {
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 56.8%;
 | 
				
			||||||
 | 
					  width: 2px;
 | 
				
			||||||
 | 
					  top: 60.8%;
 | 
				
			||||||
 | 
					  /* x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 148px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.rcLine {
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 61%;
 | 
				
			||||||
 | 
					  width: 100px;
 | 
				
			||||||
 | 
					  top: 61.5%;
 | 
				
			||||||
 | 
					  /* x: 60, y: 58, */
 | 
				
			||||||
 | 
					    height: 1px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.rcLineTwo {
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 66.8%;
 | 
				
			||||||
 | 
					  width: 1px;
 | 
				
			||||||
 | 
					  top: 52%;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  /* // x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 90px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.hdLine {
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 58.7%;
 | 
				
			||||||
 | 
					  width: 1px;
 | 
				
			||||||
 | 
					  top: 34%;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  /* // x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 100px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.hdLineTwo {
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 53%;
 | 
				
			||||||
 | 
					  width: 90px;
 | 
				
			||||||
 | 
					  top: 34%;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  /* // x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 1px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.ksLine {
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 43.2%;
 | 
				
			||||||
 | 
					  width: 350px;
 | 
				
			||||||
 | 
					  top: 56.8%;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  /* // x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 1px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.bbLine {
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 42.4%;
 | 
				
			||||||
 | 
					  width: 350px;
 | 
				
			||||||
 | 
					  top: 55.5%;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  /* // x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 1px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.bbLineTwo {
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 42.4%;
 | 
				
			||||||
 | 
					  width: 1px;
 | 
				
			||||||
 | 
					  top: 48%;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  /* // x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 70px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.jmsLine {
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 67.8%;
 | 
				
			||||||
 | 
					  width: 1px;
 | 
				
			||||||
 | 
					  top: 24%;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  /* // x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 40px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.jmsLineTwo {
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 65.4%;
 | 
				
			||||||
 | 
					  width: 50px;
 | 
				
			||||||
 | 
					  top: 28.5%;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					    /* // x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 1px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.bbLineThree {
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  left: 40%;
 | 
				
			||||||
 | 
					  width: 40px;
 | 
				
			||||||
 | 
					  top: 48%;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  /* // x: 60, y: 58, */
 | 
				
			||||||
 | 
					  height: 1px;
 | 
				
			||||||
 | 
					  border: 2px dashed #FFCF00;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
.pin {
 | 
					.pin {
 | 
				
			||||||
  display: inline-block;
 | 
					  display: inline-block;
 | 
				
			||||||
  position: absolute;
 | 
					  position: absolute;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,12 +1,12 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2023-11-06 15:15:30
 | 
					 * @Date: 2023-11-06 15:15:30
 | 
				
			||||||
 * @LastEditTime: 2024-05-07 09:31:54
 | 
					 * @LastEditTime: 2024-05-20 18:02:10
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <el-drawer class="drawer" :visible.sync="visible" size="50%">
 | 
					  <el-drawer class="drawer" :visible.sync="visible" size="55%" @closed="$emit('destroy')">
 | 
				
			||||||
    <small-title slot="title" :no-padding="true">
 | 
					    <small-title slot="title" :no-padding="true">
 | 
				
			||||||
      {{ '碲化镉工厂生产数据详情' }}
 | 
					      {{ '碲化镉工厂生产数据详情' }}
 | 
				
			||||||
    </small-title>
 | 
					    </small-title>
 | 
				
			||||||
@@ -14,15 +14,15 @@
 | 
				
			|||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="8">
 | 
					        <el-col :span="8">
 | 
				
			||||||
          <p class="title">工厂名称</p>
 | 
					          <p class="title">工厂名称</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ dataForm.factory }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="8">
 | 
					        <el-col :span="8">
 | 
				
			||||||
          <p class="title">时间维度</p>
 | 
					          <p class="title">时间维度</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ date }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="8">
 | 
					        <el-col :span="8">
 | 
				
			||||||
          <p class="title">时间</p>
 | 
					          <p class="title">时间</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.reportDate.length > 0 ? dataForm.reportDate[0] + '年' + dataForm.reportDate[1] + '月' + dataForm.reportDate[2] + '日' : '' }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <el-divider></el-divider>
 | 
					      <el-divider></el-divider>
 | 
				
			||||||
@@ -36,43 +36,43 @@
 | 
				
			|||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片良率</p>
 | 
					          <p class="title">芯片良率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.yieldRate }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片良率</p>
 | 
					          <p class="title">芯片BOM</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.bom }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片总功率</p>
 | 
					          <p class="title">芯片总功率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.totalPower }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">FTO投入量</p>
 | 
					          <p class="title">FTO投入量</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ dataForm.chipInput }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">CSS稼动率</p>
 | 
					          <p class="title">CSS稼动率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.marriageRate }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片段OEE</p>
 | 
					          <p class="title">芯片段OEE</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.oee }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片平均功率</p>
 | 
					          <p class="title">芯片平均功率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.averagePower }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片人均产量</p>
 | 
					          <p class="title">芯片人均产量</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ dataForm.annualAverageProduction }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片产能利用率</p>
 | 
					          <p class="title">芯片产能利用率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.capacityUtilizationRate }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <small-title style=" margin: 0;padding: 26px 32px 24px;margin-bottom: 22px;" :no-padding="false">
 | 
					      <small-title style=" margin: 0;padding: 26px 32px 24px;margin-bottom: 22px;" :no-padding="false">
 | 
				
			||||||
@@ -81,19 +81,20 @@
 | 
				
			|||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">封装BOM</p>
 | 
					          <p class="title">封装BOM</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <!-- 没参数 -->
 | 
				
			||||||
 | 
					          <!-- <p class="text">{{ dataForm.bom }}</p> -->
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">封装线OEE</p>
 | 
					          <p class="title">封装线OEE</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <!-- <p class="text">{{ dataForm.code }}</p> -->
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">标准组件良率</p>
 | 
					          <p class="title">标准组件良率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <!-- <p class="text">{{ dataForm.productName }}</p> -->
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">标准组件产量</p>
 | 
					          <p class="title">标准组件产量</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <!-- <p class="text">{{ dataForm.productName }}</p> -->
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
@@ -103,15 +104,15 @@
 | 
				
			|||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">封装产能利用率</p>
 | 
					          <p class="title">封装产能利用率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <!-- <p class="text">{{ dataForm.code }}</p> -->
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">标准组件人均产量</p>
 | 
					          <p class="title">标准组件人均产量</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <!-- <p class="text">{{ dataForm.productName }}</p> -->
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">标准组件人均产量</p>
 | 
					          <p class="title">标准组件平均功率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <!-- <p class="text">{{ dataForm.productName }}</p> -->
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <small-title style=" margin: 0;padding: 26px 32px 24px;margin-bottom: 22px;" :no-padding="false">
 | 
					      <small-title style=" margin: 0;padding: 26px 32px 24px;margin-bottom: 22px;" :no-padding="false">
 | 
				
			||||||
@@ -166,6 +167,12 @@ export default {
 | 
				
			|||||||
    SmallTitle,
 | 
					    SmallTitle,
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  // mixins: [basicAdd],
 | 
					  // mixins: [basicAdd],
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    date: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default: 0
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      urlOptions: {
 | 
					      urlOptions: {
 | 
				
			||||||
@@ -224,8 +231,12 @@ export default {
 | 
				
			|||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    init(id) {
 | 
					    init(id) {
 | 
				
			||||||
      this.visible = true
 | 
					      this.visible = true
 | 
				
			||||||
 | 
					      console.log('打印', id)
 | 
				
			||||||
      if (id) {
 | 
					      if (id) {
 | 
				
			||||||
        getProduceDataDetail()
 | 
					        getProduceDataDetail(id).then(res => {
 | 
				
			||||||
 | 
					          this.dataForm = res.data
 | 
				
			||||||
 | 
					          console.log('你好', res.data)
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    // getCurrentTime() {
 | 
					    // getCurrentTime() {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,53 +1,53 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2024-04-15 10:49:13
 | 
					 * @Date: 2024-04-15 10:49:13
 | 
				
			||||||
 * @LastEditTime: 2024-05-07 09:18:01
 | 
					 * @LastEditTime: 2024-05-22 15:25:11
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div style="display: flex; flex-direction: column; min-height: calc(100vh - 96px - 31px)">
 | 
					  <div style="display: flex; flex-direction: column; min-height: calc(100vh - 96px - 31px)">
 | 
				
			||||||
    <div class="app-container" style="padding: 16px 24px 0;height: auto; flex-grow: 1;">
 | 
					    <div class="app-container" style="padding: 16px 24px 0;height: auto; flex-grow: 1;">
 | 
				
			||||||
      <el-form :model="listQuery" :inline="true" ref="dataForm" class="blueTip">
 | 
					      <el-form :model="listQuery" :inline="true" ref="dataForm" class="blueTip">
 | 
				
			||||||
        <el-form-item label="时间维度" prop="reportTime">
 | 
					        <el-form-item label="时间维度" prop="date">
 | 
				
			||||||
          <el-select clearable v-model="listQuery.date" placeholder="请选择">
 | 
					          <el-select size="small" clearable v-model="listQuery.date" placeholder="请选择">
 | 
				
			||||||
            <el-option v-for="item in timeList" :key="item.value" :label="item.label" :value="item.value">
 | 
					            <el-option v-for="item in timeList" :key="item.value" :label="item.label" :value="item.value">
 | 
				
			||||||
            </el-option>
 | 
					            </el-option>
 | 
				
			||||||
          </el-select>
 | 
					          </el-select>
 | 
				
			||||||
        </el-form-item>
 | 
					        </el-form-item>
 | 
				
			||||||
        <el-form-item v-show="listQuery.date === 0" label="时间范围" prop="reportTime">
 | 
					        <el-form-item v-show="listQuery.date === 0 || listQuery.date === ''" label="时间范围" prop="reportTime">
 | 
				
			||||||
          <el-date-picker clearable v-model="listQuery.reportTime" type="datetimerange" range-separator="至"
 | 
					          <el-date-picker size="small" clearable v-model="listQuery.reportTime" type="datetimerange" range-separator="至"
 | 
				
			||||||
            start-placeholder="开始日期" value-format="yyyy-MM-dd HH:mm:ss" @change="changeDayTime" end-placeholder="结束日期">
 | 
					            start-placeholder="开始日期" value-format="timestamp" @change="changeDayTime" end-placeholder="结束日期">
 | 
				
			||||||
          </el-date-picker>
 | 
					          </el-date-picker>
 | 
				
			||||||
        </el-form-item>
 | 
					        </el-form-item>
 | 
				
			||||||
        <el-form-item v-show="listQuery.date === 1" label="时间范围" prop="reportTime">
 | 
					        <el-form-item v-show="listQuery.date === 1" label="时间范围" prop="reportTime">
 | 
				
			||||||
          <el-date-picker clearable v-model="listQuery.reportTime[0]" type="week" format="yyyy 第 WW 周" placeholder="选择周"
 | 
					          <el-date-picker size="small" clearable v-model="listQuery.start" type="week" format="yyyy 第 WW 周" placeholder="选择周"
 | 
				
			||||||
            style="width: 180px" @change="onValueChange">
 | 
					            style="width: 180px" @change="onValueChange">
 | 
				
			||||||
          </el-date-picker>
 | 
					          </el-date-picker>
 | 
				
			||||||
          至
 | 
					          至
 | 
				
			||||||
          <el-date-picker clearable v-model="listQuery.reportTime[1]" type="week" format="yyyy 第 WW 周" placeholder="选择周"
 | 
					          <el-date-picker size="small" clearable v-model="listQuery.end" type="week" format="yyyy 第 WW 周" placeholder="选择周"
 | 
				
			||||||
            style="width: 180px" @change="onValueChange">
 | 
					            style="width: 180px" @change="onValueChange">
 | 
				
			||||||
          </el-date-picker>
 | 
					          </el-date-picker>
 | 
				
			||||||
          <span v-if="listQuery.reportTime[0] && listQuery.reportTime[1]" style="margin-left: 10px">
 | 
					          <span v-if="listQuery.start && listQuery.end" style="margin-left: 10px">
 | 
				
			||||||
            {{ date1 }} 至 {{ date2 }},共 {{ weekNum }} 周
 | 
					            {{ date1 }} 至 {{ date2 }},共 {{ weekNum }} 周
 | 
				
			||||||
          </span>
 | 
					          </span>
 | 
				
			||||||
        </el-form-item>
 | 
					        </el-form-item>
 | 
				
			||||||
        <el-form-item v-show="listQuery.date === 2" label="时间范围" prop="reportTime">
 | 
					        <el-form-item v-show="listQuery.date === 2" label="时间范围" prop="reportTime">
 | 
				
			||||||
          <el-date-picker clearable v-model="listQuery.reportTime" type="monthrange" range-separator="至"
 | 
					          <el-date-picker size="small" clearable v-model="listQuery.reportTime" type="monthrange" value-format="timestamp" range-separator="至"
 | 
				
			||||||
            start-placeholder="开始月份" end-placeholder="结束月份" @change="changeTime">
 | 
					            start-placeholder="开始月份" end-placeholder="结束月份" @change="changeTime">
 | 
				
			||||||
          </el-date-picker>
 | 
					          </el-date-picker>
 | 
				
			||||||
        </el-form-item>
 | 
					        </el-form-item>
 | 
				
			||||||
        <el-form-item v-show="listQuery.date === 3" label="时间范围" prop="reportTime">
 | 
					        <el-form-item v-show="listQuery.date === 3" label="时间范围" prop="reportTime">
 | 
				
			||||||
          <el-date-picker clearable v-model="listQuery.reportTime[0]" value-format="yyyy" type="year"
 | 
					          <el-date-picker size="small" clearable v-model="listQuery.start" format="yyyy-MM-dd" value-format="timestamp" type="year"
 | 
				
			||||||
            placeholder="开始时间">
 | 
					            placeholder="开始时间">
 | 
				
			||||||
          </el-date-picker>
 | 
					          </el-date-picker>
 | 
				
			||||||
          ~
 | 
					          ~
 | 
				
			||||||
          <el-date-picker clearable v-model="listQuery.reportTime[1]" value-format="yyyy" type="year" placeholder="结束时间"
 | 
					          <el-date-picker size="small" clearable v-model="listQuery.end" format="yyyy-MM-dd" value-format="timestamp" type="year" placeholder="结束时间"
 | 
				
			||||||
            @change="getYear">
 | 
					            @change="getYear">
 | 
				
			||||||
          </el-date-picker>
 | 
					          </el-date-picker>
 | 
				
			||||||
        </el-form-item>
 | 
					        </el-form-item>
 | 
				
			||||||
        <el-form-item label="工厂名称" prop="factorys">
 | 
					        <el-form-item label="工厂名称" prop="factorys">
 | 
				
			||||||
          <el-select clearable v-model="listQuery.factorys" placeholder="请选择工厂名称" multiple >
 | 
					          <el-select size="small" clearable v-model="listQuery.factorys" placeholder="请选择工厂名称" multiple >
 | 
				
			||||||
            <el-option v-for="item in factoryList" :key="item.id" :label="item.name" :value="item.id">
 | 
					            <el-option v-for="item in factoryList" :key="item.id" :label="item.name" :value="item.id">
 | 
				
			||||||
            </el-option>
 | 
					            </el-option>
 | 
				
			||||||
          </el-select>
 | 
					          </el-select>
 | 
				
			||||||
@@ -59,7 +59,7 @@
 | 
				
			|||||||
          </el-select>
 | 
					          </el-select>
 | 
				
			||||||
        </el-form-item> -->
 | 
					        </el-form-item> -->
 | 
				
			||||||
        <el-form-item label="玻璃类型" prop="type">
 | 
					        <el-form-item label="玻璃类型" prop="type">
 | 
				
			||||||
          <el-select clearable v-model="listQuery.type" placeholder="请选择玻璃类型">
 | 
					          <el-select size="small" clearable v-model="listQuery.type" placeholder="请选择玻璃类型">
 | 
				
			||||||
            <el-option v-for="item in typeList" :key="item.id" :label="item.name" :value="item.id">
 | 
					            <el-option v-for="item in typeList" :key="item.id" :label="item.name" :value="item.id">
 | 
				
			||||||
            </el-option>
 | 
					            </el-option>
 | 
				
			||||||
          </el-select>
 | 
					          </el-select>
 | 
				
			||||||
@@ -69,23 +69,32 @@
 | 
				
			|||||||
          <el-button type="primary" size="small" plain @click="handleExport">导出</el-button>
 | 
					          <el-button type="primary" size="small" plain @click="handleExport">导出</el-button>
 | 
				
			||||||
        </el-form-item>
 | 
					        </el-form-item>
 | 
				
			||||||
      </el-form>
 | 
					      </el-form>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <div class="app-container" style="margin-top: 8px;padding: 16px; height: auto; flex-grow: 1;">
 | 
				
			||||||
      <!-- <el-row :gutter="24"> -->
 | 
					      <!-- <el-row :gutter="24"> -->
 | 
				
			||||||
      <!-- <el-col :span="12" v-for="item in  dataList" :key="item.id"> -->
 | 
					      <!-- <el-col :span="12" v-for="item in  dataList" :key="item.id"> -->
 | 
				
			||||||
 | 
					      <search-bar :formConfigs="formConfig1" ref="searchBarForm1" style="margin-bottom: 0" />
 | 
				
			||||||
      <line-chart class="yearChart" ref="lineChart" style="height: 40vh;width: 100%"></line-chart>
 | 
					      <line-chart class="yearChart" ref="lineChart" style="height: 40vh;width: 100%"></line-chart>
 | 
				
			||||||
      <!-- </el-col> -->
 | 
					      <!-- </el-col> -->
 | 
				
			||||||
      <!-- <el-col :span="12">
 | 
					      <!-- <el-col :span="12">
 | 
				
			||||||
            <line-chart :id=" 'second' " class="yearChart" ref="lineChart" style="height: 40vh;width: 100%"></line-chart>
 | 
					            <line-chart :id=" 'second' " class="yearChart" ref="lineChart" style="height: 40vh;width: 100%"></line-chart>
 | 
				
			||||||
          </el-col> -->
 | 
					          </el-col> -->
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <div class="app-container" style="margin-top: 18px;flex-grow: 1; height: auto; padding: 16px;">
 | 
					    <div class="app-container" style="margin-top: 8px;flex-grow: 1; height: auto; padding: 16px;">
 | 
				
			||||||
      <search-bar :formConfigs="formConfig" ref="searchBarForm" @headBtnClick="buttonClick" />
 | 
					      <search-bar :formConfigs="formConfig" ref="searchBarForm" @headBtnClick="buttonClick" style="margin-bottom: 0" />
 | 
				
			||||||
      <base-table :table-props="tableProps" :page="listQuery.pageNo" :limit="listQuery.pageSize"
 | 
					      <base-table :table-props="tableProps" :page="listQuery.current" :limit="listQuery.size"
 | 
				
			||||||
        :table-data="tableData">
 | 
					        :table-data="tableData">
 | 
				
			||||||
        <method-btn v-if="tableBtn.length" slot="handleBtn" label="操作" :width="120" fixed="right"
 | 
					        <method-btn v-if="tableBtn.length" slot="handleBtn" label="操作" :width="120" fixed="right"
 | 
				
			||||||
          :method-list="tableBtn" @clickBtn="handleClick" />
 | 
					          :method-list="tableBtn" @clickBtn="handleClick" />
 | 
				
			||||||
      </base-table>
 | 
					      </base-table>
 | 
				
			||||||
 | 
					      <pagination
 | 
				
			||||||
 | 
					        :limit.sync="listQuery.size"
 | 
				
			||||||
 | 
					        :page.sync="listQuery.current"
 | 
				
			||||||
 | 
					        :total="listQuery.total"
 | 
				
			||||||
 | 
					        @pagination="getDataList"
 | 
				
			||||||
 | 
					      />
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <add-or-update v-if="detailOrUpdateVisible" ref="detailOrUpdate" @refreshDataList="successSubmit" />
 | 
					    <add-or-update v-if="detailOrUpdateVisible" ref="detailOrUpdate" :date="listQuery.date" @refreshDataList="successSubmit" @destroy="detailOrUpdateVisible = false" />
 | 
				
			||||||
    <!-- <inputTable :date="date" :data="tableData" :time="[startTimeStamp, endTimeStamp]" :sum="all"
 | 
					    <!-- <inputTable :date="date" :data="tableData" :time="[startTimeStamp, endTimeStamp]" :sum="all"
 | 
				
			||||||
      :type="listQuery.reportType" @refreshDataList="getDataList" /> -->
 | 
					      :type="listQuery.reportType" @refreshDataList="getDataList" /> -->
 | 
				
			||||||
    <!-- <pagination
 | 
					    <!-- <pagination
 | 
				
			||||||
@@ -98,7 +107,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
// import { parseTime } from '../../core/mixins/code-filter';
 | 
					// import { parseTime } from '../../core/mixins/code-filter';
 | 
				
			||||||
import { getProduceDataPage } from '@/api/produceData';
 | 
					import { getProduceDataPage, exportOutPutExcel } from '@/api/produceData';
 | 
				
			||||||
// import inputTable from './inputTable.vue';
 | 
					// import inputTable from './inputTable.vue';
 | 
				
			||||||
import lineChart from './lineChart';
 | 
					import lineChart from './lineChart';
 | 
				
			||||||
import moment from 'moment'
 | 
					import moment from 'moment'
 | 
				
			||||||
@@ -114,7 +123,7 @@ export default {
 | 
				
			|||||||
	data() {
 | 
						data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      listQuery: {
 | 
					      listQuery: {
 | 
				
			||||||
        size: 10,
 | 
					        size: 20,
 | 
				
			||||||
        current: 1,
 | 
					        current: 1,
 | 
				
			||||||
        factorys: [],
 | 
					        factorys: [],
 | 
				
			||||||
        total: 0,
 | 
					        total: 0,
 | 
				
			||||||
@@ -123,7 +132,9 @@ export default {
 | 
				
			|||||||
        // reportType: 2,
 | 
					        // reportType: 2,
 | 
				
			||||||
        beginTime: undefined,
 | 
					        beginTime: undefined,
 | 
				
			||||||
        endTime:undefined,
 | 
					        endTime:undefined,
 | 
				
			||||||
        reportTime: []
 | 
					        reportTime: [],
 | 
				
			||||||
 | 
					        start: undefined,
 | 
				
			||||||
 | 
					        end: undefined
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      detailOrUpdateVisible:false,
 | 
					      detailOrUpdateVisible:false,
 | 
				
			||||||
      date1: undefined,
 | 
					      date1: undefined,
 | 
				
			||||||
@@ -177,88 +188,16 @@ export default {
 | 
				
			|||||||
				// getDataListURL: getGlassPage,
 | 
									// getDataListURL: getGlassPage,
 | 
				
			||||||
				// exportURL: exportGlasscExcel
 | 
									// exportURL: exportGlasscExcel
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      mainFormConfig: [
 | 
					 | 
				
			||||||
      	{
 | 
					 | 
				
			||||||
          type: 'select',
 | 
					 | 
				
			||||||
          label: '工单',
 | 
					 | 
				
			||||||
          placeholder: '请选择工单',
 | 
					 | 
				
			||||||
          param: 'workOrderId',
 | 
					 | 
				
			||||||
          selectOptions: [],
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        // {
 | 
					 | 
				
			||||||
        // 	type: 'select',
 | 
					 | 
				
			||||||
        // 	label: '产线',
 | 
					 | 
				
			||||||
        // 	placeholder: '请选择产线',
 | 
					 | 
				
			||||||
        // 	param: 'lineId',
 | 
					 | 
				
			||||||
        // 	selectOptions: [],
 | 
					 | 
				
			||||||
        // },
 | 
					 | 
				
			||||||
        // 选项切换
 | 
					 | 
				
			||||||
        // {
 | 
					 | 
				
			||||||
        // 	type: 'select',
 | 
					 | 
				
			||||||
        // 	label: '时间类型',
 | 
					 | 
				
			||||||
        // 	param: 'dateFilterType',
 | 
					 | 
				
			||||||
        // 	defaultSelect: 0,
 | 
					 | 
				
			||||||
        // 	selectOptions: [
 | 
					 | 
				
			||||||
        // 		{ id: 0, name: '按时间段' },
 | 
					 | 
				
			||||||
        // 		{ id: 1, name: '按日期' },
 | 
					 | 
				
			||||||
        // 	],
 | 
					 | 
				
			||||||
        // 	index: 2,
 | 
					 | 
				
			||||||
        // 	extraOptions: [
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          // parent: 'dateFilterType',
 | 
					 | 
				
			||||||
          // 时间段选择
 | 
					 | 
				
			||||||
          type: 'datePicker',
 | 
					 | 
				
			||||||
          label: '时间段',
 | 
					 | 
				
			||||||
          // dateType: 'datetimerange',
 | 
					 | 
				
			||||||
          dateType: 'datetimerange',
 | 
					 | 
				
			||||||
          format: 'yyyy-MM-dd HH:mm:ss',
 | 
					 | 
				
			||||||
          valueFormat: 'yyyy-MM-ddTHH:mm:ss',
 | 
					 | 
				
			||||||
          rangeSeparator: '-',
 | 
					 | 
				
			||||||
          rangeSeparator: '-',
 | 
					 | 
				
			||||||
          startPlaceholder: '开始时间',
 | 
					 | 
				
			||||||
          endPlaceholder: '结束时间',
 | 
					 | 
				
			||||||
          param: 'recordTime',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        // 		{
 | 
					 | 
				
			||||||
        // 			parent: 'dateFilterType',
 | 
					 | 
				
			||||||
        // 			// 日期选择
 | 
					 | 
				
			||||||
        // 			type: 'datePicker',
 | 
					 | 
				
			||||||
        // 			// label: '日期',
 | 
					 | 
				
			||||||
        // 			dateType: 'date',
 | 
					 | 
				
			||||||
        // 			placeholder: '选择日期',
 | 
					 | 
				
			||||||
        // 			format: 'yyyy-MM-dd',
 | 
					 | 
				
			||||||
        // 			valueFormat: 'yyyy-MM-dd',
 | 
					 | 
				
			||||||
        // 			param: 'timeday',
 | 
					 | 
				
			||||||
        // 		},
 | 
					 | 
				
			||||||
        // 	],
 | 
					 | 
				
			||||||
        // },
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          type:'button',
 | 
					 | 
				
			||||||
          btnName: '查询',
 | 
					 | 
				
			||||||
          name: 'search',
 | 
					 | 
				
			||||||
          color: 'primary',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
         {
 | 
					 | 
				
			||||||
          type:'separate'
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        // {
 | 
					 | 
				
			||||||
        //   type: this.$auth.hasPermi(
 | 
					 | 
				
			||||||
        //     'analysis:equipment:export'
 | 
					 | 
				
			||||||
        //   )
 | 
					 | 
				
			||||||
        //     ? 'separate'
 | 
					 | 
				
			||||||
        //     : '',
 | 
					 | 
				
			||||||
        // },
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          type:'button',
 | 
					 | 
				
			||||||
          btnName: '导出',
 | 
					 | 
				
			||||||
          name: 'export',
 | 
					 | 
				
			||||||
          color: 'warning',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      ],
 | 
					 | 
				
			||||||
      formConfig: [
 | 
					      formConfig: [
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          type: 'title',
 | 
					          type: 'title',
 | 
				
			||||||
          label: '生产数据管理',
 | 
					          label: '工厂信息',
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					      formConfig1: [
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: 'title',
 | 
				
			||||||
 | 
					          label: '良品数量',
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      timeList: [
 | 
					      timeList: [
 | 
				
			||||||
@@ -281,24 +220,52 @@ export default {
 | 
				
			|||||||
      ],
 | 
					      ],
 | 
				
			||||||
      factoryList: [
 | 
					      factoryList: [
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          name: '测试',
 | 
					          name: '瑞昌中建材光电材料有限公司',
 | 
				
			||||||
          id:1
 | 
					          id: 0
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          name: '邯郸中建材光电材料有限公司',
 | 
				
			||||||
 | 
					          id: 1
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          name: '中建材株洲光电材料有限公司',
 | 
				
			||||||
 | 
					          id: 2
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          name:  '佳木斯中建材光电材料有限公司',
 | 
				
			||||||
 | 
					          id: 3
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          name:  '成都中建材光电材料有限公司',
 | 
				
			||||||
 | 
					          id: 4
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          name:  '凯盛光伏材料有限公司',
 | 
				
			||||||
 | 
					          id: 5
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          name:  '蚌埠兴科玻璃有限公司',
 | 
				
			||||||
 | 
					          id: 6
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      tableProps: [
 | 
					      tableProps: [
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'createTime',
 | 
					          prop: 'tableTime',
 | 
				
			||||||
          label: '日期',
 | 
					          label: '日期',
 | 
				
			||||||
 | 
					          minWidth: 100,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'factory',
 | 
					          prop: 'factory',
 | 
				
			||||||
          label: '工厂名称',
 | 
					          label: '工厂名称',
 | 
				
			||||||
          filter: (val) => ['瑞昌中建材光电材料有限公司', '邯郸中建材光电材料有限公司', '中建材株洲光电材料有限公司', '佳木斯中建材光电材料有限公司', '成都中建材光电材料有限公司', '凯盛光伏材料有限公司', '蚌埠兴科玻璃有限公司'][val]
 | 
					          filter: (val) => ['瑞昌中建材光电材料有限公司', '邯郸中建材光电材料有限公司', '中建材株洲光电材料有限公司', '佳木斯中建材光电材料有限公司', '成都中建材光电材料有限公司', '凯盛光伏材料有限公司', '蚌埠兴科玻璃有限公司'][val],
 | 
				
			||||||
 | 
					          minWidth: 200,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'glassType',
 | 
					          prop: 'glassType',
 | 
				
			||||||
          label: '玻璃类型',
 | 
					          label: '玻璃类型',
 | 
				
			||||||
          filter: (val) => ['玻璃芯片', '标准组件', 'BIPV'][val]
 | 
					          filter: (val) => ['玻璃芯片', '标准组件', 'BIPV', '定制组件'][val]
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'inputNumber',
 | 
					          prop: 'inputNumber',
 | 
				
			||||||
@@ -318,19 +285,18 @@ export default {
 | 
				
			|||||||
        },
 | 
					        },
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      tableData: [],
 | 
					      tableData: [],
 | 
				
			||||||
 | 
					      xAxis: []
 | 
				
			||||||
			// proLineList: [],
 | 
								// proLineList: [],
 | 
				
			||||||
			// all: {}
 | 
								// all: {}
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					  computed: {
 | 
				
			||||||
    weekNum() {
 | 
					    weekNum() {
 | 
				
			||||||
      return Math.round((this.listQuery.reportTime[1] - this.listQuery.reportTime[0]) / (24 * 60 * 60 * 1000 * 7)) + 1
 | 
					      return Math.round((this.listQuery.end - this.listQuery.start) / (24 * 60 * 60 * 1000 * 7)) + 1
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
	mounted() {
 | 
						mounted() {
 | 
				
			||||||
    this.getDict()
 | 
					    this.getDataList()
 | 
				
			||||||
    // this.getCurrentYearFirst()
 | 
					 | 
				
			||||||
    // this.getDataList()
 | 
					 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    otherMethods(val) {
 | 
					    otherMethods(val) {
 | 
				
			||||||
@@ -340,32 +306,41 @@ export default {
 | 
				
			|||||||
        this.$refs.detailOrUpdate.init(val.data.id);
 | 
					        this.$refs.detailOrUpdate.init(val.data.id);
 | 
				
			||||||
      });
 | 
					      });
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    buttonClick() {
 | 
					    // buttonClick() {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    },
 | 
					    // },
 | 
				
			||||||
    getYear(e) {
 | 
					    getYear(e) {
 | 
				
			||||||
      if (this.listQuery.reportTime[0] && e - this.listQuery.reportTime[0] > 10) {
 | 
					      if (this.listQuery.end - this.listQuery.start > 10*365*24*60*60*1000) {
 | 
				
			||||||
        this.$message({
 | 
					        this.$message({
 | 
				
			||||||
          message: '年份起止时间不能超过十年',
 | 
					          message: '年份起止时间不能超过十年',
 | 
				
			||||||
          type: 'warning'
 | 
					          type: 'warning'
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
 | 
					        this.listQuery.reportTime = []
 | 
				
			||||||
 | 
					        this.listQuery.start = undefined
 | 
				
			||||||
 | 
					        this.listQuery.end = undefined
 | 
				
			||||||
        // console.log();
 | 
					        // console.log();
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.listQuery.beginTime = this.listQuery.start
 | 
				
			||||||
 | 
					        this.listQuery.endTime = this.listQuery.end
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      // console.log(e);
 | 
					      // console.log(e);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    onValueChange(picker, k) { // 选中近k周后触发的操作
 | 
					    onValueChange(picker, k) { // 选中近k周后触发的操作
 | 
				
			||||||
      if (this.listQuery.reportTime[0] && this.listQuery.reportTime[1]) {
 | 
					      // console.log(this.listQuery.reportTime[0], this.listQuery.reportTime[1])
 | 
				
			||||||
        console.log(this.listQuery.reportTime[0].getTime() - 24 * 60 * 60 * 1000)
 | 
					      if (this.listQuery.start && this.listQuery.end) {
 | 
				
			||||||
        this.date1 = moment(this.listQuery.reportTime[0].getTime() - 24 * 60 * 60 * 1000).format('YYYY-MM-DD HH:mm:ss')
 | 
					        console.log(this.listQuery.reportTime)
 | 
				
			||||||
        // this.onValueChange()   // 这里为我们希望value改变时触发的方法
 | 
					        this.date1 = moment(this.listQuery.start.getTime() - 24 * 60 * 60 * 1000).format('YYYY-MM-DD HH:mm:ss')
 | 
				
			||||||
        this.date2 = moment(this.listQuery.reportTime[1].getTime() + 5 * 24 * 60 * 60 * 1000).format('YYYY-MM-DD HH:mm:ss')
 | 
					        this.date2 = moment(this.listQuery.end.getTime() + 5 * 24 * 60 * 60 * 1000).format('YYYY-MM-DD HH:mm:ss')
 | 
				
			||||||
        const numDays = (new Date(this.date2).getTime() - new Date(this.date1).getTime()) / (24 * 3600 * 1000); if (numDays > 168) {
 | 
					        const numDays = (new Date(this.date2).getTime() - new Date(this.date1).getTime()) / (24 * 3600 * 1000);
 | 
				
			||||||
 | 
					        if (numDays > 168) {
 | 
				
			||||||
          console.log(numDays)
 | 
					          console.log(numDays)
 | 
				
			||||||
          this.$message({
 | 
					          this.$message({
 | 
				
			||||||
            message: '周范围不能超过24周',
 | 
					            message: '周范围不能超过24周',
 | 
				
			||||||
            type: 'warning'
 | 
					            type: 'warning'
 | 
				
			||||||
          });
 | 
					          });
 | 
				
			||||||
          // this.onValueChange()
 | 
					        } else {
 | 
				
			||||||
 | 
					          this.listQuery.beginTime = this.listQuery.start.getTime() - 24 * 60 * 60 * 1000
 | 
				
			||||||
 | 
					          this.listQuery.endTime = this.listQuery.end.getTime() + 5 * 24 * 60 * 60 * 1000
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
@@ -374,103 +349,42 @@ export default {
 | 
				
			|||||||
        // this.createStartDate = moment(new Date(this.listQuery.reportTime[0]), 'yyyy-MM-dd hh:mm:ss');
 | 
					        // this.createStartDate = moment(new Date(this.listQuery.reportTime[0]), 'yyyy-MM-dd hh:mm:ss');
 | 
				
			||||||
        // this.createEndDate = moment(new Date(this.listQuery.reportTime[1]), 'yyyy-MM-dd hh:mm:ss');
 | 
					        // this.createEndDate = moment(new Date(this.listQuery.reportTime[1]), 'yyyy-MM-dd hh:mm:ss');
 | 
				
			||||||
        console.log(this.listQuery.reportTime[1])
 | 
					        console.log(this.listQuery.reportTime[1])
 | 
				
			||||||
        const numDays = (new Date(this.listQuery.reportTime[1]).getTime() - new Date(this.listQuery.reportTime[0]).getTime()) / (24 * 3600 * 1000); if (numDays > 30) {
 | 
					        const numDays = (this.listQuery.reportTime[1] - this.listQuery.reportTime[0]) / (24 * 3600 * 1000);
 | 
				
			||||||
 | 
					        if (numDays > 30) {
 | 
				
			||||||
          this.$message({
 | 
					          this.$message({
 | 
				
			||||||
            message: '时间范围不能超过30天',
 | 
					            message: '时间范围不能超过30天',
 | 
				
			||||||
            type: 'warning'
 | 
					            type: 'warning'
 | 
				
			||||||
          });
 | 
					          });
 | 
				
			||||||
          this.listQuery.reportTime = [];
 | 
					          this.listQuery.reportTime = [];
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          this.listQuery.beginTime = this.listQuery.reportTime[0]
 | 
				
			||||||
 | 
					          this.listQuery.endTime = this.listQuery.reportTime[1]
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      } else {
 | 
					      } else {
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    changeTime(value) {
 | 
					    changeTime(value) {
 | 
				
			||||||
      if (this.listQuery.reportTime) {
 | 
					      if (this.listQuery.reportTime) {
 | 
				
			||||||
        const timeStamp = this.listQuery.reportTime[1].getMonth(); //标准时间转为时间戳,毫秒级别
 | 
					        const numDays = this.listQuery.reportTime[1] - this.listQuery.reportTime[0];
 | 
				
			||||||
        const fullyear = this.listQuery.reportTime[1].getFullYear()
 | 
					        if (numDays > 2*365*24*60*60*1000) {
 | 
				
			||||||
        let days = 0
 | 
					 | 
				
			||||||
        switch (timeStamp) {
 | 
					 | 
				
			||||||
          case 0:
 | 
					 | 
				
			||||||
          case 2:
 | 
					 | 
				
			||||||
          case 4:
 | 
					 | 
				
			||||||
          case 6:
 | 
					 | 
				
			||||||
          case 7:
 | 
					 | 
				
			||||||
          case 9:
 | 
					 | 
				
			||||||
          case 11:
 | 
					 | 
				
			||||||
            days = 31
 | 
					 | 
				
			||||||
            break
 | 
					 | 
				
			||||||
          case 3:
 | 
					 | 
				
			||||||
          case 4:
 | 
					 | 
				
			||||||
          case 8:
 | 
					 | 
				
			||||||
          case 10:
 | 
					 | 
				
			||||||
            days = 30
 | 
					 | 
				
			||||||
            break
 | 
					 | 
				
			||||||
          case 1:
 | 
					 | 
				
			||||||
            if ((fullyear % 400 === 0) || (fullyear % 4 === 0 && fullyear % 100 !== 0)) {
 | 
					 | 
				
			||||||
              days = 29
 | 
					 | 
				
			||||||
            } else {
 | 
					 | 
				
			||||||
              days = 28
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            break
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        let startTime = moment(new Date(this.listQuery.reportTime[0]).setDate(1, 0, 0, 0)).format('YYYY-MM-DD HH:mm:ss')
 | 
					 | 
				
			||||||
        // this.startTimeStamp = this.timeFun(new Date(fullyear, timeStamp, 1, 7, 0, 1).getTime()); //开始时间
 | 
					 | 
				
			||||||
        let endTime = this.timeFun(new Date(fullyear, timeStamp, days).getTime()) + ' 23:59:59'; //结束时间
 | 
					 | 
				
			||||||
        // console.log(endTimeStamp);
 | 
					 | 
				
			||||||
        // let endTime = moment(this.listQuery.reportTime[1]).month(monthNum - 1).date(1).endOf("month").format("YYYY-MM-DD");
 | 
					 | 
				
			||||||
        // console.log(endTime);
 | 
					 | 
				
			||||||
        // console.log(moment(new Date(this.listQuery.reportTime[1]).setDate(31, 23, 59, 59)).format('YYYY-MM-DD HH:mm:ss'))
 | 
					 | 
				
			||||||
        // console.log(moment(new Date(this.listQuery.reportTime[1]).getTime()).format('YYYY-MM-DD HH:mm:ss'))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        // this.createStartDate = moment(new Date(this.listQuery.reportTime[0]), 'yyyy-MM-dd hh:mm:ss');
 | 
					 | 
				
			||||||
        // this.createEndDate = moment(new Date(this.listQuery.reportTime[1]), 'yyyy-MM-dd hh:mm:ss');
 | 
					 | 
				
			||||||
        const numDays = (new Date(endTime).getTime() - new Date(startTime).getTime()) / (24 * 3600 * 1000); if (numDays > 730) {
 | 
					 | 
				
			||||||
          this.$message({
 | 
					          this.$message({
 | 
				
			||||||
            message: '时间范围不能超过24个月',
 | 
					            message: '时间范围不能超过24个月',
 | 
				
			||||||
            type: 'warning'
 | 
					            type: 'warning'
 | 
				
			||||||
          });
 | 
					          });
 | 
				
			||||||
          this.listQuery.reportTime = [];
 | 
					          this.listQuery.reportTime = [];
 | 
				
			||||||
        } else {
 | 
					        } else {
 | 
				
			||||||
          this.listQuery.reportTime[0] = startTime
 | 
					          this.listQuery.beginTime = this.listQuery.reportTime[0]
 | 
				
			||||||
          this.listQuery.reportTime[1] = endTime
 | 
					          this.listQuery.endTime = this.listQuery.reportTime[1]
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      } else {
 | 
					      } else {
 | 
				
			||||||
        console.log(this.listQuery.reportTime[0])
 | 
					        console.log(this.listQuery.reportTime[0])
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    // handleTime() {
 | 
					    // async getDict() {
 | 
				
			||||||
    //   this.$forceUpdate()
 | 
					 | 
				
			||||||
    //   // this.$nextTick(() => [
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    //   // ])
 | 
					 | 
				
			||||||
    // },
 | 
					 | 
				
			||||||
    // getCurrentYearFirst() {
 | 
					 | 
				
			||||||
    //   let date = new Date();
 | 
					 | 
				
			||||||
    //   date.setDate(1);
 | 
					 | 
				
			||||||
    //   date.setMonth(0);
 | 
					 | 
				
			||||||
    //   this.reportTime = date;
 | 
					 | 
				
			||||||
    //   this.startTimeStamp = this.timeFun(new Date(new Date().getFullYear(), 0, 1, 7, 0, 1).getTime()); //开始时间
 | 
					 | 
				
			||||||
    //   this.endTimeStamp = this.timeFun(new Date(new Date().getFullYear(), 11, 31, 7, 0, 0).getTime()); //结束时间
 | 
					 | 
				
			||||||
    //   this.listQuery.reportTime[0] = parseTime(new Date(new Date().getFullYear(), 0, 1, 7, 0, 1).getTime()) //+ ' 00:00:00' //new Date(this.startTimeStamp + ' 00:00:00').getTime() / 1000
 | 
					 | 
				
			||||||
    //   this.listQuery.reportTime[1] = parseTime(new Date(new Date().getFullYear(), 11, 31, 7, 0, 0).getTime()) //+ ' 23:59:59' //new Date(this.endTimeStamp + ' 23:59:59').getTime() / 100
 | 
					 | 
				
			||||||
    // },
 | 
					 | 
				
			||||||
    // changeTime(val) {
 | 
					 | 
				
			||||||
    //   if (val) {
 | 
					 | 
				
			||||||
    //     // let timeStamp = val.getTime(); //标准时间转为时间戳,毫秒级别
 | 
					 | 
				
			||||||
    //     // this.endTimeStamp = this.timeFun(new Date(val.getFullYear(), 11, 31, 7, 0, 0).getTime()); //开始时间
 | 
					 | 
				
			||||||
    //     // this.startTimeStamp = this.timeFun(new Date(val.getFullYear(), 0, 1, 7, 0, 1).getTime()); //结束时间
 | 
					 | 
				
			||||||
    //     // this.listQuery.reportTime[0] = parseTime(new Date(val.getFullYear(), 0, 1, 7, 0, 1).getTime()) //+ ' 00:00:00' //new Date(this.startTimeStamp + ' 00:00:00').getTime() / 1000
 | 
					 | 
				
			||||||
    //     // this.listQuery.reportTime[1] = parseTime(new Date(val.getFullYear(), 11, 31, 7, 0, 0).getTime()) //+ ' 23:59:59' //new Date(this.endTimeStamp + ' 23:59:59').getTime() / 1000
 | 
					 | 
				
			||||||
    //   } else {
 | 
					 | 
				
			||||||
    //     this.listQuery.reportTime = []
 | 
					 | 
				
			||||||
    //   }
 | 
					 | 
				
			||||||
    // },
 | 
					 | 
				
			||||||
    async getDict() {
 | 
					 | 
				
			||||||
      this.$refs.lineChart.initChart()
 | 
					 | 
				
			||||||
			// 产线列表
 | 
								// 产线列表
 | 
				
			||||||
			// const res = await getCorePLList();
 | 
								// const res = await getCorePLList();
 | 
				
			||||||
			// this.proLineList = res.data;
 | 
								// this.proLineList = res.data;
 | 
				
			||||||
		},
 | 
							// },
 | 
				
			||||||
    // 获取数据列表
 | 
					    // 获取数据列表
 | 
				
			||||||
    multipliedByHundred(str) {
 | 
					    multipliedByHundred(str) {
 | 
				
			||||||
      console.log(str);
 | 
					      console.log(str);
 | 
				
			||||||
@@ -498,36 +412,50 @@ export default {
 | 
				
			|||||||
      const res = await getProduceDataPage(this.listQuery)
 | 
					      const res = await getProduceDataPage(this.listQuery)
 | 
				
			||||||
      console.log(res)
 | 
					      console.log(res)
 | 
				
			||||||
      this.tableData = res.data.records
 | 
					      this.tableData = res.data.records
 | 
				
			||||||
 | 
					      this.tableData.forEach(item => {
 | 
				
			||||||
 | 
					        item.tableTime = item?.reportDate?.length > 0 ? item.reportDate[0] + '-' + item.reportDate[1] + '-' + item.reportDate[2] : '--'
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					      this.listQuery.total = res.data.total
 | 
				
			||||||
 | 
					      this.buildChart(this.tableData)
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    add0(m) {
 | 
					    buildChart(list) {
 | 
				
			||||||
      return m < 10 ? '0' + m : m
 | 
					      const chartList = Object.groupBy(list, (item) => item.tableTime)
 | 
				
			||||||
 | 
					      this.xAxis = []
 | 
				
			||||||
 | 
					      this.seriesList = []
 | 
				
			||||||
 | 
					      for (const keyIndex in chartList) {
 | 
				
			||||||
 | 
					        // X坐标轴数据
 | 
				
			||||||
 | 
					        this.xAxis.push(keyIndex)
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      // y轴数据
 | 
				
			||||||
 | 
					      for (const y of this.factoryList) {
 | 
				
			||||||
 | 
					        // y: {name: , id: }
 | 
				
			||||||
 | 
					        const seriesItem = {
 | 
				
			||||||
 | 
					          name: y.name,
 | 
				
			||||||
 | 
					            type: 'bar',
 | 
				
			||||||
 | 
					            emphasis: {
 | 
				
			||||||
 | 
					              focus: 'series'
 | 
				
			||||||
            },
 | 
					            },
 | 
				
			||||||
    format(shijianchuo) {
 | 
					          data: Array(this.xAxis.length).fill(0)
 | 
				
			||||||
      //shijianchuo是整数,否则要parseInt转换
 | 
					        }
 | 
				
			||||||
      var time = moment(new Date(shijianchuo)).format('YYYY-MM-DD HH:mm:ss')
 | 
					        for (const a in chartList) {
 | 
				
			||||||
      // console.log(time)
 | 
					          for (const z of chartList[a]) {
 | 
				
			||||||
      // var y = time.getFullYear();
 | 
					            this.xAxis.forEach((item, index) => {
 | 
				
			||||||
      // var m = time.getMonth() + 1;
 | 
					              if (z.factory === y.id && a === item) {
 | 
				
			||||||
      // var d = time.getDate();
 | 
					                seriesItem.data[index] = z.goodNumber
 | 
				
			||||||
      // var h = time.getHours();
 | 
					              }
 | 
				
			||||||
      // var mm = time.getMinutes();
 | 
					            })
 | 
				
			||||||
      // var s = time.getSeconds();
 | 
					          }
 | 
				
			||||||
      return time
 | 
					        }
 | 
				
			||||||
    },
 | 
					        this.seriesList.push(seriesItem)
 | 
				
			||||||
		//时间戳转为yy-mm-dd hh:mm:ss
 | 
					      }
 | 
				
			||||||
		timeFun(unixtimestamp) {
 | 
					      this.$refs.lineChart.initChart(this.xAxis, this.seriesList)
 | 
				
			||||||
				var unixtimestamp = new Date(unixtimestamp);
 | 
					 | 
				
			||||||
				var year = 1900 + unixtimestamp.getYear();
 | 
					 | 
				
			||||||
				var month = "0" + (unixtimestamp.getMonth() + 1);
 | 
					 | 
				
			||||||
				var date = "0" + unixtimestamp.getDate();
 | 
					 | 
				
			||||||
				return year + "-" + month.substring(month.length - 2, month.length) + "-" + date.substring(date.length - 2, date.length)
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
		buttonClick(val) {
 | 
							buttonClick(val) {
 | 
				
			||||||
			this.listQuery.reportTime = val.reportTime ? val.reportTime : undefined;
 | 
								this.listQuery.reportTime = val.reportTime ? val.reportTime : undefined;
 | 
				
			||||||
			switch (val.btnName) {
 | 
								switch (val.btnName) {
 | 
				
			||||||
				case 'search':
 | 
									case 'search':
 | 
				
			||||||
					this.listQuery.pageNo = 1;
 | 
										this.listQuery.current = 1;
 | 
				
			||||||
					this.listQuery.pageSize = 10;
 | 
										this.listQuery.size = 20;
 | 
				
			||||||
					this.getDataList();
 | 
										this.getDataList();
 | 
				
			||||||
					break;
 | 
										break;
 | 
				
			||||||
				case 'export':
 | 
									case 'export':
 | 
				
			||||||
@@ -539,6 +467,17 @@ export default {
 | 
				
			|||||||
		},
 | 
							},
 | 
				
			||||||
		/** 导出按钮操作 */
 | 
							/** 导出按钮操作 */
 | 
				
			||||||
    handleExport() {
 | 
					    handleExport() {
 | 
				
			||||||
 | 
					      this.$modal.confirm('是否确认导出生产数据?').then(() => {
 | 
				
			||||||
 | 
					        // 处理查询参数
 | 
				
			||||||
 | 
					        let params = {...this.listQuery};
 | 
				
			||||||
 | 
					        params.current = 1;
 | 
				
			||||||
 | 
					        params.size = 999;
 | 
				
			||||||
 | 
					        this.exportLoading = true;
 | 
				
			||||||
 | 
					        return exportOutPutExcel(params);
 | 
				
			||||||
 | 
					      }).then(response => {
 | 
				
			||||||
 | 
					        this.$download.excel(response, '生产数据.xls');
 | 
				
			||||||
 | 
					        this.exportLoading = false;
 | 
				
			||||||
 | 
					      }).catch(() => {});
 | 
				
			||||||
      // 处理查询参数
 | 
					      // 处理查询参数
 | 
				
			||||||
      // var xlsxParam = { raw: true };
 | 
					      // var xlsxParam = { raw: true };
 | 
				
			||||||
      // /* 从表生成工作簿对象 */
 | 
					      // /* 从表生成工作簿对象 */
 | 
				
			||||||
@@ -591,7 +530,7 @@ export default {
 | 
				
			|||||||
  margin-top: 8px;
 | 
					  margin-top: 8px;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.app-container {
 | 
					.app-container {
 | 
				
			||||||
  margin: 0 16px 0;
 | 
					  margin: 0 0px 0;
 | 
				
			||||||
  background-color: #fff;
 | 
					  background-color: #fff;
 | 
				
			||||||
  border-radius: 4px;
 | 
					  border-radius: 4px;
 | 
				
			||||||
  padding: 16px 16px 0;
 | 
					  padding: 16px 16px 0;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,8 +1,8 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zwq
 | 
					 * @Author: zwq
 | 
				
			||||||
 * @Date: 2022-01-21 14:43:06
 | 
					 * @Date: 2022-01-21 14:43:06
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 * @LastEditTime: 2024-04-17 10:03:39
 | 
					 * @LastEditTime: 2024-05-22 13:48:58
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
@@ -58,11 +58,11 @@ export default {
 | 
				
			|||||||
      chart: null
 | 
					      chart: null
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  mounted() {
 | 
					  // mounted() {
 | 
				
			||||||
    this.$nextTick(() => {
 | 
					  //   this.$nextTick(() => {
 | 
				
			||||||
      this.initChart()
 | 
					  //     this.initChart()
 | 
				
			||||||
    })
 | 
					  //   })
 | 
				
			||||||
  },
 | 
					  // },
 | 
				
			||||||
  beforeDestroy() {
 | 
					  beforeDestroy() {
 | 
				
			||||||
    if (!this.chart) {
 | 
					    if (!this.chart) {
 | 
				
			||||||
      return
 | 
					      return
 | 
				
			||||||
@@ -71,8 +71,7 @@ export default {
 | 
				
			|||||||
    this.chart = null
 | 
					    this.chart = null
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    initChart() {
 | 
					    initChart(xAxis, seriesList) {
 | 
				
			||||||
      console.log(1111)
 | 
					 | 
				
			||||||
      this.chart = echarts.init(document.getElementById(this.id))
 | 
					      this.chart = echarts.init(document.getElementById(this.id))
 | 
				
			||||||
      console.log(this.$parent);
 | 
					      console.log(this.$parent);
 | 
				
			||||||
      this.chart.setOption({
 | 
					      this.chart.setOption({
 | 
				
			||||||
@@ -85,7 +84,7 @@ export default {
 | 
				
			|||||||
        },
 | 
					        },
 | 
				
			||||||
        grid: { top: 100, right: 90, bottom: 10, left: 10, containLabel: true },
 | 
					        grid: { top: 100, right: 90, bottom: 10, left: 10, containLabel: true },
 | 
				
			||||||
        legend: {
 | 
					        legend: {
 | 
				
			||||||
          data: ['工厂1', '工厂2'],
 | 
					          // data: ['工厂1', '工厂2'],
 | 
				
			||||||
          right: '90px',
 | 
					          right: '90px',
 | 
				
			||||||
          top: '0%',
 | 
					          top: '0%',
 | 
				
			||||||
          icon: 'rect',
 | 
					          icon: 'rect',
 | 
				
			||||||
@@ -107,7 +106,7 @@ export default {
 | 
				
			|||||||
          {
 | 
					          {
 | 
				
			||||||
            type: 'category',
 | 
					            type: 'category',
 | 
				
			||||||
            // prettier-ignore
 | 
					            // prettier-ignore
 | 
				
			||||||
            data: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
 | 
					            data: xAxis
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        ],
 | 
					        ],
 | 
				
			||||||
        yAxis: [
 | 
					        yAxis: [
 | 
				
			||||||
@@ -122,39 +121,8 @@ export default {
 | 
				
			|||||||
          bottom: "1%",
 | 
					          bottom: "1%",
 | 
				
			||||||
          containLabel: true
 | 
					          containLabel: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        series: [
 | 
					        series: seriesList
 | 
				
			||||||
          {
 | 
					      }, true)
 | 
				
			||||||
            name: '工厂1',
 | 
					 | 
				
			||||||
            type: 'bar',
 | 
					 | 
				
			||||||
            itemStyle: {
 | 
					 | 
				
			||||||
              normal: {
 | 
					 | 
				
			||||||
                color: 'rgba(99, 189, 255, 1)', //改变折线点的颜色
 | 
					 | 
				
			||||||
                lineStyle: {
 | 
					 | 
				
			||||||
                  color: 'rgba(99, 189, 255, 1)' //改变折线颜色
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
              }
 | 
					 | 
				
			||||||
            },
 | 
					 | 
				
			||||||
            data: [
 | 
					 | 
				
			||||||
              2.0, 4.9, 7.0, 23.2, 25.6, 76.7, 135.6, 162.2, 32.6, 20.0, 6.4, 3.3
 | 
					 | 
				
			||||||
            ],
 | 
					 | 
				
			||||||
          },
 | 
					 | 
				
			||||||
          {
 | 
					 | 
				
			||||||
            name: '工厂2',
 | 
					 | 
				
			||||||
            type: 'bar',
 | 
					 | 
				
			||||||
            itemStyle: {
 | 
					 | 
				
			||||||
              normal: {
 | 
					 | 
				
			||||||
                color: 'rgba(142, 240, 171, 1)', //改变折线点的颜色
 | 
					 | 
				
			||||||
                lineStyle: {
 | 
					 | 
				
			||||||
                  color: 'rgba(142, 240, 171, 1)' //改变折线颜色
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
              }
 | 
					 | 
				
			||||||
            },
 | 
					 | 
				
			||||||
            data: [
 | 
					 | 
				
			||||||
              2.6, 5.9, 9.0, 26.4, 28.7, 70.7, 175.6, 182.2, 48.7, 18.8, 6.0, 2.3
 | 
					 | 
				
			||||||
            ],
 | 
					 | 
				
			||||||
          },
 | 
					 | 
				
			||||||
        ]
 | 
					 | 
				
			||||||
      })
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,40 +1,49 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2024-04-17 16:31:51
 | 
					 * @Date: 2024-04-17 16:31:51
 | 
				
			||||||
 * @LastEditTime: 2024-04-17 17:01:14
 | 
					 * @LastEditTime: 2024-05-20 18:09:09
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <el-drawer class="drawer" :visible.sync="visible" size="50%">
 | 
					  <el-drawer class="drawer" :visible.sync="visible" size="55%" @closed="$emit('destroy')">
 | 
				
			||||||
    <small-title slot="title" :no-padding="true">
 | 
					    <small-title slot="title" :no-padding="true">
 | 
				
			||||||
      {{ '新增' }}
 | 
					      {{ dataForm.id ? '编辑' : '新增' }}
 | 
				
			||||||
    </small-title>
 | 
					    </small-title>
 | 
				
			||||||
    <div class="detailBox">
 | 
					    <div class="detailBox">
 | 
				
			||||||
      <el-form ref="form" :model="dataForm" label-width="80px" label-position="top">
 | 
					      <el-form ref="form" :model="dataForm" label-width="80px" label-position="top">
 | 
				
			||||||
        <el-row :gutter="24" style="padding: 0 32px;">
 | 
					        <el-row :gutter="24" style="padding: 0 32px;">
 | 
				
			||||||
          <el-col :span="8">
 | 
					          <el-col :span="8">
 | 
				
			||||||
            <el-form-item label="工厂名称" prop="factoryId">
 | 
					            <el-form-item v-if="ftype === 0" label="工厂名称" prop="factory">
 | 
				
			||||||
              <el-select v-model="dataForm.factoryId" placeholder="请选择工厂名称" multiple="true" clearable>
 | 
					              <el-select v-model="dataForm.factory" placeholder="请选择工厂名称" clearable>
 | 
				
			||||||
                <el-option v-for="item in factoryList" :key="item.id" :label="item.name" :value="item.id">
 | 
					                <el-option v-for="(item, index) in dhgfactoryList" :key="index" :label="item.name" :value="item.id">
 | 
				
			||||||
 | 
					                </el-option>
 | 
				
			||||||
 | 
					              </el-select>
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					            <el-form-item v-else label="工厂名称" prop="factory">
 | 
				
			||||||
 | 
					              <el-select v-model="dataForm.factory" placeholder="请选择工厂名称" clearable>
 | 
				
			||||||
 | 
					                <el-option v-for="(item, index) in tyjxfactoryList" :key="index" :label="item.name" :value="item.id">
 | 
				
			||||||
                </el-option>
 | 
					                </el-option>
 | 
				
			||||||
              </el-select>
 | 
					              </el-select>
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="8">
 | 
					          <el-col :span="8">
 | 
				
			||||||
            <el-form-item label="工厂名称" prop="factoryId">
 | 
					            <el-form-item label="时间维度" prop="targetType">
 | 
				
			||||||
              <el-select v-model="dataForm.factoryId" placeholder="请选择工厂名称" multiple="true" clearable>
 | 
					              <el-select v-model="dataForm.targetType" placeholder="请选择时间维度" clearable @change="clearTime">
 | 
				
			||||||
                <el-option v-for="item in factoryList" :key="item.id" :label="item.name" :value="item.id">
 | 
					                <!-- <el-option v-for="item in factoryList" :key="item.id" :label="item.name" :value="item.id"> -->
 | 
				
			||||||
                </el-option>
 | 
					                <el-option label="月" :value="0" />
 | 
				
			||||||
 | 
					                <el-option label="年" :value="1" />
 | 
				
			||||||
              </el-select>
 | 
					              </el-select>
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="8">
 | 
					          <el-col :span="8">
 | 
				
			||||||
            <el-form-item label="工厂名称" prop="factoryId">
 | 
					            <el-form-item v-show="dataForm.targetType !== 1" label="时间" prop="reportTime">
 | 
				
			||||||
              <el-select v-model="dataForm.factoryId" placeholder="请选择工厂名称" multiple="true" clearable>
 | 
					              <el-date-picker v-model="dataForm.reportTime" value-format="yyyy-MM" type="month" placeholder="选择月份">
 | 
				
			||||||
                <el-option v-for="item in factoryList" :key="item.id" :label="item.name" :value="item.id">
 | 
					              </el-date-picker>
 | 
				
			||||||
                </el-option>
 | 
					            </el-form-item>
 | 
				
			||||||
              </el-select>
 | 
					            <el-form-item v-show="dataForm.targetType === 1" label="时间" prop="targetYear">
 | 
				
			||||||
 | 
					              <el-date-picker clearable v-model="dataForm.showYear" value-format="yyyy" type="year" placeholder="开始时间">
 | 
				
			||||||
 | 
					              </el-date-picker>
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
        </el-row>
 | 
					        </el-row>
 | 
				
			||||||
@@ -44,59 +53,63 @@
 | 
				
			|||||||
        </small-title>
 | 
					        </small-title>
 | 
				
			||||||
        <el-row :gutter="24" style="padding: 0 32px;">
 | 
					        <el-row :gutter="24" style="padding: 0 32px;">
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片产量" prop="factoryId">
 | 
					            <el-form-item label="芯片产量" prop="chipYield">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片产量"></el-input>
 | 
					              <el-input-number v-model="dataForm.chipYield" :precision="0" controls-position="right" placeholder="请输入芯片产量" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片良率" prop="factoryId">
 | 
					            <el-form-item label="芯片良率" prop="chipYieldRate">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片良率"></el-input>
 | 
					              <el-input-number v-model="dataForm.chipYieldRate" :precision="2" :max="100" controls-position="right" placeholder="请输入芯片良率" style="width: 100%" />
 | 
				
			||||||
 | 
					 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片BOM" prop="factoryId">
 | 
					            <el-form-item label="芯片BOM" prop="chipBom">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片BOM"></el-input>
 | 
					              <el-input-number v-model="dataForm.chipBom" :precision="2" controls-position="right" placeholder="请输入芯片BOM" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片总功率" prop="factoryId">
 | 
					            <el-form-item label="芯片总功率" prop="chipTotalPower">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片总功率"></el-input>
 | 
					              <el-input-number v-model="dataForm.chipTotalPower" :precision="2" controls-position="right" placeholder="请输入芯片总功率" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
        </el-row>
 | 
					        </el-row>
 | 
				
			||||||
        <el-row :gutter="24" style="padding: 0 32px;">
 | 
					        <el-row :gutter="24" style="padding: 0 32px;">
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="FTO投入量" prop="factoryId">
 | 
					            <el-form-item v-if="ftype === 0" label="FTO投入量" prop="ftoInput">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入FTO投入量"></el-input>
 | 
					              <el-input-number v-model="dataForm.ftoInput" :precision="0" controls-position="right" placeholder="请输入FTO投入量" style="width: 100%" />
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					            <el-form-item v-else label="钼电极投入量" prop="molybdenumElectrodeInput">
 | 
				
			||||||
 | 
					              <el-input-number v-model="dataForm.molybdenumElectrodeInput" :precision="0" controls-position="right" placeholder="请输入钼电极投入量" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="CSS稼动率" prop="factoryId">
 | 
					            <el-form-item v-if="ftype === 0" label="CSS稼动率" prop="chipCssMarriageRate">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入CSS稼动率"></el-input>
 | 
					              <el-input-number v-model="dataForm.chipCssMarriageRate" :precision="2" controls-position="right" placeholder="请输入CSS稼动率" style="width: 100%" />
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
 | 
					            <el-form-item v-else label="PID6稼动率" prop="chipCssMarriageRate">
 | 
				
			||||||
 | 
					              <el-input-number v-model="dataForm.chipCssMarriageRate" :precision="2" controls-position="right" placeholder="请输入PID6稼动率" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片段OEE" prop="factoryId">
 | 
					            <el-form-item label="芯片段OEE" prop="chipOee">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片段OEE"></el-input>
 | 
					              <el-input-number v-model="dataForm.chipOee" :precision="2" controls-position="right" placeholder="请输入芯片段OEE" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片平均功率" prop="factoryId">
 | 
					            <el-form-item label="芯片平均功率" prop="chipAveragePower">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片平均功率"></el-input>
 | 
					              <el-input-number v-model="dataForm.chipAveragePower" :precision="2" controls-position="right" placeholder="请输入芯片平均功率" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
        </el-row>
 | 
					        </el-row>
 | 
				
			||||||
        <el-row :gutter="24" style="padding: 0 32px;">
 | 
					        <el-row :gutter="24" style="padding: 0 32px;">
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片人均产量" prop="factoryId">
 | 
					            <el-form-item label="芯片人均产量" prop="chipAnnualAverageProduction">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片人均产量"></el-input>
 | 
					              <el-input-number v-model="dataForm.chipAnnualAverageProduction" :precision="2" controls-position="right" placeholder="请输入芯片人均产量" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片人均产量" prop="factoryId">
 | 
					            <el-form-item label="芯片产能利用率" prop="chipCapacityUtilizationRate">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片人均产量"></el-input>
 | 
					              <el-input-number v-model="dataForm.chipCapacityUtilizationRate" :precision="2" controls-position="right" placeholder="请输入芯片产能利用率" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
        </el-row>
 | 
					        </el-row>
 | 
				
			||||||
@@ -106,45 +119,45 @@
 | 
				
			|||||||
        </small-title>
 | 
					        </small-title>
 | 
				
			||||||
        <el-row :gutter="24" style="padding: 0 32px;">
 | 
					        <el-row :gutter="24" style="padding: 0 32px;">
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="封装BOM" prop="factoryId">
 | 
					            <el-form-item label="封装BOM" prop="componentBom">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入封装BOM"></el-input>
 | 
					              <el-input-number v-model="dataForm.componentBom" :precision="2" controls-position="right" placeholder="请输入封装BOM" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="封装线OEE" prop="factoryId">
 | 
					            <el-form-item label="封装线OEE" prop="componentOee">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入封装线OEE"></el-input>
 | 
					              <el-input-number v-model="dataForm.componentOee" :precision="2" controls-position="right" placeholder="请输入封装线OEE" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="标准组件良率" prop="factoryId">
 | 
					            <el-form-item label="标准组件良率" prop="componentYieldRate">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入标准组件良率"></el-input>
 | 
					              <el-input-number v-model="dataForm.componentYieldRate" :precision="2" controls-position="right" placeholder="请输入标准组件良率" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="标准组件良率" prop="factoryId">
 | 
					            <el-form-item label="标准组件产量" prop="componentYield">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入标准组件良率"></el-input>
 | 
					              <el-input-number v-model="dataForm.componentYield" :precision="0" controls-position="right" placeholder="请输入标准组件产量" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
        </el-row>
 | 
					        </el-row>
 | 
				
			||||||
        <el-row :gutter="24" style="padding: 0 32px;">
 | 
					        <el-row :gutter="24" style="padding: 0 32px;">
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="标准组件总功率" prop="factoryId">
 | 
					            <el-form-item label="标准组件总功率" prop="componentTotalPower">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入标准组件总功率"></el-input>
 | 
					              <el-input-number v-model="dataForm.componentTotalPower" :precision="2" controls-position="right" placeholder="请输入标准组件总功率" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="标准组件总功率" prop="factoryId">
 | 
					            <el-form-item label="封装产能利用率" prop="componentCapacityUtilizationRate">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入标准组件总功率"></el-input>
 | 
					              <el-input-number v-model="dataForm.componentCapacityUtilizationRate" :precision="2" controls-position="right" placeholder="请输入封装产能利用率" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="标准组件人均产量" prop="factoryId">
 | 
					            <el-form-item label="标准组件人均产量" prop="componentAnnualAverageProduction">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入标准组件人均产量"></el-input>
 | 
					              <el-input-number v-model="dataForm.componentAnnualAverageProduction" :precision="2" controls-position="right" placeholder="请输入标准组件人均产量" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="标准组件平均功率" prop="factoryId">
 | 
					            <el-form-item label="标准组件平均功率" prop="componentAveragePower">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入标准组件平均功率"></el-input>
 | 
					              <el-input-number v-model="dataForm.componentAveragePower" :precision="2" controls-position="right" placeholder="请输入标准组件平均功率" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
        </el-row>
 | 
					        </el-row>
 | 
				
			||||||
@@ -155,47 +168,47 @@
 | 
				
			|||||||
        </small-title>
 | 
					        </small-title>
 | 
				
			||||||
        <el-row :gutter="24" style="padding: 0 32px;">
 | 
					        <el-row :gutter="24" style="padding: 0 32px;">
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="产品产量" prop="factoryId">
 | 
					            <el-form-item label="产品产量" prop="bipvProductOutput">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入产品产量"></el-input>
 | 
					              <el-input-number v-model="dataForm.bipvProductOutput" :precision="0" controls-position="right" placeholder="请输入产品产量" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="人均产量" prop="factoryId">
 | 
					            <el-form-item label="人均产量" prop="bipvAnnualAverageProduction">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入人均产量"></el-input>
 | 
					              <el-input-number v-model="dataForm.bipvAnnualAverageProduction" :precision="2" controls-position="right" placeholder="请输入人均产量" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片使用量" prop="factoryId">
 | 
					            <el-form-item label="芯片使用量" prop="bipvChipUsage">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片使用量"></el-input>
 | 
					              <el-input-number v-model="dataForm.bipvChipUsage" :precision="0" controls-position="right" placeholder="请输入芯片使用量" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="芯片利用率" prop="factoryId">
 | 
					            <el-form-item label="芯片利用率" prop="bipvChipUtilizationRate">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入芯片利用率"></el-input>
 | 
					              <el-input-number v-model="dataForm.bipvChipUtilizationRate" :precision="2" controls-position="right" placeholder="请输入芯片利用率" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
        </el-row>
 | 
					        </el-row>
 | 
				
			||||||
        <el-row :gutter="24" style="padding: 0 32px;">
 | 
					        <el-row :gutter="24" style="padding: 0 32px;">
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="内部材料成本" prop="factoryId">
 | 
					            <el-form-item label="内部材料成本" prop="bipvInsideMaterialCost">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入内部材料成本"></el-input>
 | 
					              <el-input-number v-model="dataForm.bipvInsideMaterialCost" :precision="2" controls-position="right" placeholder="请输入内部材料成本" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="OEM及委外材料成本" prop="factoryId">
 | 
					            <el-form-item label="OEM及委外材料成本" prop="bipvOeeMaterialCost">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入OEM及委外材料成本"></el-input>
 | 
					              <el-input-number v-model="dataForm.bipvOeeMaterialCost" :precision="2" controls-position="right" placeholder="请输入OEM及委外材料成本" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="6">
 | 
					          <el-col :span="6">
 | 
				
			||||||
            <el-form-item label="综合材料成本" prop="factoryId">
 | 
					            <el-form-item label="综合材料成本" prop="bipvComprehensiveMaterialCost">
 | 
				
			||||||
              <el-input v-model="dataForm.factoryId" placeholder="请输入综合材料成本"></el-input>
 | 
					              <el-input-number v-model="dataForm.bipvComprehensiveMaterialCost" :precision="2" controls-position="right" placeholder="请输入综合材料成本" style="width: 100%" />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
        </el-row>
 | 
					        </el-row>
 | 
				
			||||||
      </el-form>
 | 
					      </el-form>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <div class="footer">
 | 
					    <div class="footer">
 | 
				
			||||||
      <el-button @click="cancelForm">取 消</el-button>
 | 
					      <el-button @click="visible = false">取 消</el-button>
 | 
				
			||||||
      <el-button type="primary" @click="handleClose()">确 定</el-button>
 | 
					      <el-button type="primary" @click="handleClose()">确 定</el-button>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </el-drawer>
 | 
					  </el-drawer>
 | 
				
			||||||
@@ -210,20 +223,25 @@
 | 
				
			|||||||
// } from "@/api/base/qualityScrapLog";
 | 
					// } from "@/api/base/qualityScrapLog";
 | 
				
			||||||
// import { getList, } from "@/api/base/qualityScrapType";
 | 
					// import { getList, } from "@/api/base/qualityScrapType";
 | 
				
			||||||
import SmallTitle from './SmallTitle';
 | 
					import SmallTitle from './SmallTitle';
 | 
				
			||||||
 | 
					import { createProduce, getProduceTargetDetail, updateProduceTarget } from '@/api/produceData';
 | 
				
			||||||
 | 
					import { factoryList, tyjxfactoryList, dhgfactoryList } from "@/utils/constants";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  components: {
 | 
					  components: {
 | 
				
			||||||
    SmallTitle,
 | 
					    SmallTitle,
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  // mixins: [basicAdd],
 | 
					  // mixins: [basicAdd],
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    ftype: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default: 0
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      urlOptions: {
 | 
					      factoryList,
 | 
				
			||||||
        isGetCode: false,
 | 
					      dhgfactoryList,
 | 
				
			||||||
        // codeURL: getCode,
 | 
					      tyjxfactoryList,
 | 
				
			||||||
        // createURL: createQualityScrapLog,
 | 
					 | 
				
			||||||
        // updateURL: updateQualityScrapLog,
 | 
					 | 
				
			||||||
        // infoURL: getQualityScrapLog,
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      lineList: [],
 | 
					      lineList: [],
 | 
				
			||||||
      typeList: [],
 | 
					      typeList: [],
 | 
				
			||||||
      workOrderList: [],
 | 
					      workOrderList: [],
 | 
				
			||||||
@@ -239,138 +257,166 @@ export default {
 | 
				
			|||||||
          name: '自动',
 | 
					          name: '自动',
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      factoryList:[],
 | 
					      // factoryList: [
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: '瑞昌中建材光电材料有限公司',
 | 
				
			||||||
 | 
					      //     id: 0
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: '邯郸中建材光电材料有限公司',
 | 
				
			||||||
 | 
					      //     id: 1
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: '中建材株洲光电材料有限公司',
 | 
				
			||||||
 | 
					      //     id: 2
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: '佳木斯中建材光电材料有限公司',
 | 
				
			||||||
 | 
					      //     id: 3
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: '成都中建材光电材料有限公司',
 | 
				
			||||||
 | 
					      //     id: 4
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: '凯盛光伏材料有限公司',
 | 
				
			||||||
 | 
					      //     id: 5
 | 
				
			||||||
 | 
					      //   },
 | 
				
			||||||
 | 
					      //   {
 | 
				
			||||||
 | 
					      //     name: '蚌埠兴科玻璃有限公司',
 | 
				
			||||||
 | 
					      //     id: 6
 | 
				
			||||||
 | 
					      //   }
 | 
				
			||||||
 | 
					      // ],
 | 
				
			||||||
      sectionList: [],
 | 
					      sectionList: [],
 | 
				
			||||||
      visible: false,
 | 
					      visible: false,
 | 
				
			||||||
      dataForm: {
 | 
					      dataForm: {
 | 
				
			||||||
 | 
					        factoryType: 0,
 | 
				
			||||||
        id: undefined,
 | 
					        id: undefined,
 | 
				
			||||||
        logTime: undefined,
 | 
					        reportTime: undefined, // 月时间
 | 
				
			||||||
        source: 1,
 | 
					        factory: undefined,
 | 
				
			||||||
        detId: undefined,
 | 
					        targetType: undefined,
 | 
				
			||||||
        workOrderId: null,
 | 
					        targetYear: undefined,
 | 
				
			||||||
        teamId: undefined,
 | 
					        showYear: undefined,
 | 
				
			||||||
        num: undefined,
 | 
					        targetMonth: undefined,
 | 
				
			||||||
        lineId: undefined,
 | 
					        chipYield: undefined,
 | 
				
			||||||
        description: undefined,
 | 
					        chipYieldRate: undefined,
 | 
				
			||||||
        // description: undefined,
 | 
					        chipBom: undefined,
 | 
				
			||||||
        remark: undefined,
 | 
					        chipTotalPower: undefined,
 | 
				
			||||||
 | 
					        ftoInput: undefined,
 | 
				
			||||||
 | 
					        chipCssMarriageRate: undefined,
 | 
				
			||||||
 | 
					        chipOee: undefined,
 | 
				
			||||||
 | 
					        chipAveragePower: undefined,
 | 
				
			||||||
 | 
					        chipAnnualAverageProduction: undefined,
 | 
				
			||||||
 | 
					        chipCapacityUtilizationRate: undefined,
 | 
				
			||||||
 | 
					        componentBom: undefined,
 | 
				
			||||||
 | 
					        componentOee: undefined,
 | 
				
			||||||
 | 
					        componentYieldRate: undefined,
 | 
				
			||||||
 | 
					        componentYield: undefined,
 | 
				
			||||||
 | 
					        componentTotalPower: undefined,
 | 
				
			||||||
 | 
					        componentCapacityUtilizationRate: undefined,
 | 
				
			||||||
 | 
					        componentAnnualAverageProduction: undefined,
 | 
				
			||||||
 | 
					        componentAveragePower: undefined,
 | 
				
			||||||
 | 
					        bipvProductOutput: undefined,
 | 
				
			||||||
 | 
					        bipvAnnualAverageProduction: undefined,
 | 
				
			||||||
 | 
					        bipvChipUsage: undefined,
 | 
				
			||||||
 | 
					        bipvChipUtilizationRate: undefined,
 | 
				
			||||||
 | 
					        bipvInsideMaterialCost: undefined,
 | 
				
			||||||
 | 
					        bipvOeeMaterialCost: undefined,
 | 
				
			||||||
 | 
					        bipvComprehensiveMaterialCost: undefined,
 | 
				
			||||||
 | 
					        molybdenumElectrodeInput: undefined
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      // materialList: [],
 | 
					      // materialList: [],
 | 
				
			||||||
      dataRule: {
 | 
					      dataRule: {
 | 
				
			||||||
        // materialId: [{ required: true, message: "", trigger: "blur" }],
 | 
					        // materialId: [{ required: true, message: "", trigger: "blur" }],
 | 
				
			||||||
        workOrderId: [{ required: true, message: "工单号不能为空", trigger: "change" }],
 | 
					        // workOrderId: [{ required: true, message: "工单号不能为空", trigger: "change" }],
 | 
				
			||||||
        num: [{ required: true, message: "数量不能为空", trigger: "blur" }],
 | 
					        // num: [{ required: true, message: "数量不能为空", trigger: "blur" }],
 | 
				
			||||||
        detId: [{ required: true, message: "报废原因不能为空", trigger: "change" }],
 | 
					        // detId: [{ required: true, message: "报废原因不能为空", trigger: "change" }],
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        logTime: [{ required: true, message: "报废时间不能为空", trigger: "change" }],
 | 
					        // logTime: [{ required: true, message: "报废时间不能为空", trigger: "change" }],
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  mounted() {
 | 
					  mounted() {
 | 
				
			||||||
    this.getDict()
 | 
					 | 
				
			||||||
    console.log('我看看', this.dataForm)
 | 
					 | 
				
			||||||
    // this.getCurrentTime()
 | 
					    // this.getCurrentTime()
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    init() {
 | 
					    formClear() {
 | 
				
			||||||
      this.visible = true
 | 
					      if (this.$refs.dataForm !== undefined) {
 | 
				
			||||||
 | 
					        this.$refs.dataForm.resetFields()
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    // getCurrentTime() {
 | 
					    clearTime() {
 | 
				
			||||||
    //   // new Date().Format("yyyy-MM-dd HH:mm:ss")
 | 
					      this.dataForm.targetYear = undefined
 | 
				
			||||||
    //   this.dataForm.logTime = new Date()
 | 
					      this.dataForm.targetMonth = undefined
 | 
				
			||||||
    //   // this.dataForm.logTime = year + "-" + month + "-" + day;
 | 
					    },
 | 
				
			||||||
    //   console.log(this.dataForm.logTime);
 | 
					    handleClose() {
 | 
				
			||||||
    // },
 | 
					      // 新增
 | 
				
			||||||
    async getDict() {
 | 
					      if (this.dataForm.targetType === 0) {
 | 
				
			||||||
    //   // 物料列表
 | 
					        const timeArray = this.dataForm.reportTime.split('-')
 | 
				
			||||||
    //   const res = await getList()
 | 
					        this.dataForm.targetYear = Number(timeArray[0])
 | 
				
			||||||
    //   this.typeList = res.data
 | 
					        this.dataForm.targetMonth = Number(timeArray[1])
 | 
				
			||||||
    //   getWorkOrderList().then((res) => {
 | 
					      }
 | 
				
			||||||
    //     console.log(res);
 | 
					      if (this.dataForm.targetType === 1) {
 | 
				
			||||||
    //     // console.log(response);
 | 
					        this.dataForm.targetYear = Number(this.dataForm.showYear)
 | 
				
			||||||
    //     this.workOrderList = res.data.map((item) => {
 | 
					      }
 | 
				
			||||||
    //       return {
 | 
					      // if (this.dataForm.factory === 5) {
 | 
				
			||||||
    //         name: item.name,
 | 
					      //   this.dataForm.factoryType = 1
 | 
				
			||||||
    //         id: item.id
 | 
					 | 
				
			||||||
    //       }
 | 
					 | 
				
			||||||
    //     })
 | 
					 | 
				
			||||||
    //     // console.log(this.formConfig[0].selectOptions);
 | 
					 | 
				
			||||||
    //     // this.listQuery.total = response.data.total;
 | 
					 | 
				
			||||||
    //   })
 | 
					 | 
				
			||||||
    //   getLineList().then((res) => {
 | 
					 | 
				
			||||||
    //     console.log(res);
 | 
					 | 
				
			||||||
    //     // console.log(response);
 | 
					 | 
				
			||||||
    //     this.lineList = res.data.map((item) => {
 | 
					 | 
				
			||||||
    //       return {
 | 
					 | 
				
			||||||
    //         name: item.name,
 | 
					 | 
				
			||||||
    //         id: item.id
 | 
					 | 
				
			||||||
    //       }
 | 
					 | 
				
			||||||
    //     })
 | 
					 | 
				
			||||||
    //     // console.log(this.formConfig[0].selectOptions);
 | 
					 | 
				
			||||||
    //     // this.listQuery.total = response.data.total;
 | 
					 | 
				
			||||||
    //   })
 | 
					 | 
				
			||||||
    //   getDetList().then((res) => {
 | 
					 | 
				
			||||||
    //     console.log(res);
 | 
					 | 
				
			||||||
    //     // console.log(response);
 | 
					 | 
				
			||||||
    //     this.detList = res.data.map((item) => {
 | 
					 | 
				
			||||||
    //       return {
 | 
					 | 
				
			||||||
    //         name: item.content,
 | 
					 | 
				
			||||||
    //         id: item.id
 | 
					 | 
				
			||||||
    //       }
 | 
					 | 
				
			||||||
    //     })
 | 
					 | 
				
			||||||
    //     // console.log(this.formConfig[0].selectOptions);
 | 
					 | 
				
			||||||
    //     // this.listQuery.total = response.data.total;
 | 
					 | 
				
			||||||
    //   })
 | 
					 | 
				
			||||||
    //   getTeamList().then((res) => {
 | 
					 | 
				
			||||||
    //     console.log(res);
 | 
					 | 
				
			||||||
    //     // console.log(response);
 | 
					 | 
				
			||||||
    //     this.teamList = res.data.map((item) => {
 | 
					 | 
				
			||||||
    //       return {
 | 
					 | 
				
			||||||
    //         name: item.name,
 | 
					 | 
				
			||||||
    //         id: item.id
 | 
					 | 
				
			||||||
    //       }
 | 
					 | 
				
			||||||
    //     })
 | 
					 | 
				
			||||||
    //     // console.log(this.formConfig[0].selectOptions);
 | 
					 | 
				
			||||||
    //     // this.listQuery.total = response.data.total;
 | 
					 | 
				
			||||||
    //   })
 | 
					 | 
				
			||||||
    // },
 | 
					 | 
				
			||||||
    // async getWorksectionById(lineId) {
 | 
					 | 
				
			||||||
    //   if (lineId) {
 | 
					 | 
				
			||||||
    //     const { code, data } = await this.$axios({
 | 
					 | 
				
			||||||
    //       url: '/base/core-workshop-section/listByParentId',
 | 
					 | 
				
			||||||
    //       method: 'get',
 | 
					 | 
				
			||||||
    //       params: {
 | 
					 | 
				
			||||||
    //         id: lineId,
 | 
					 | 
				
			||||||
    //       },
 | 
					 | 
				
			||||||
    //     });
 | 
					 | 
				
			||||||
    //     if (code == 0) {
 | 
					 | 
				
			||||||
    //       console.log(data)
 | 
					 | 
				
			||||||
    //       this.sectionList = data.map((item) => {
 | 
					 | 
				
			||||||
    //         return {
 | 
					 | 
				
			||||||
    //           name: item.name,
 | 
					 | 
				
			||||||
    //           id: item.id,
 | 
					 | 
				
			||||||
    //         };
 | 
					 | 
				
			||||||
    //       });
 | 
					 | 
				
			||||||
    //     }
 | 
					 | 
				
			||||||
      // } else {
 | 
					      // } else {
 | 
				
			||||||
    //     this.$axios({
 | 
					      //   this.dataForm.factoryType = 0
 | 
				
			||||||
    //       url: '/base/core-workshop-section/listAll',
 | 
					 | 
				
			||||||
    //       method: 'get',
 | 
					 | 
				
			||||||
    //       // params: {
 | 
					 | 
				
			||||||
    //       //   id: lineId,
 | 
					 | 
				
			||||||
    //       // },
 | 
					 | 
				
			||||||
    //     }).then((res) => {
 | 
					 | 
				
			||||||
    //       // console.log(data)
 | 
					 | 
				
			||||||
    //       this.sectionList = res.data.map((item) => {
 | 
					 | 
				
			||||||
    //         return {
 | 
					 | 
				
			||||||
    //           name: item.name,
 | 
					 | 
				
			||||||
    //           id: item.id,
 | 
					 | 
				
			||||||
    //         };
 | 
					 | 
				
			||||||
    //       });
 | 
					 | 
				
			||||||
    //     })
 | 
					 | 
				
			||||||
      // }
 | 
					      // }
 | 
				
			||||||
 | 
					      if (this.dataForm.id) {
 | 
				
			||||||
 | 
					        // 修改
 | 
				
			||||||
 | 
					        updateProduceTarget({
 | 
				
			||||||
 | 
					          ...this.dataForm,
 | 
				
			||||||
 | 
					          showYear: undefined,
 | 
				
			||||||
 | 
					          reportTime: undefined
 | 
				
			||||||
 | 
					        }).then(res => {
 | 
				
			||||||
 | 
					          if (res.code === 0) {
 | 
				
			||||||
 | 
					            this.$message.success('修改成功!')
 | 
				
			||||||
 | 
					            this.visible = false
 | 
				
			||||||
 | 
					            this.$emit('refreshDataList')
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        // 新增
 | 
				
			||||||
 | 
					        createProduce({
 | 
				
			||||||
 | 
					          ...this.dataForm,
 | 
				
			||||||
 | 
					          showYear: undefined,
 | 
				
			||||||
 | 
					          reportTime: undefined
 | 
				
			||||||
 | 
					        }).then(res => {
 | 
				
			||||||
 | 
					          if (res.code === 0) {
 | 
				
			||||||
 | 
					            this.$message.success('新增成功!')
 | 
				
			||||||
 | 
					            this.visible = false
 | 
				
			||||||
 | 
					            this.$emit('refreshDataList')
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  },
 | 
					    init(id) {
 | 
				
			||||||
 | 
					      this.dataForm.id = id || undefined
 | 
				
			||||||
 | 
					      this.dataForm.factoryType = this.ftype
 | 
				
			||||||
 | 
					      this.visible = true
 | 
				
			||||||
 | 
					      if (this.dataForm.id) {
 | 
				
			||||||
 | 
					        getProduceTargetDetail(this.dataForm.id).then(res => {
 | 
				
			||||||
 | 
					          this.dataForm = res.data
 | 
				
			||||||
 | 
					          if (this.dataForm.targetType === 1) {
 | 
				
			||||||
 | 
					            if (this.dataForm.targetYear) {
 | 
				
			||||||
 | 
					              this.$set(this.dataForm, 'showYear', String(this.dataForm.targetYear))
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					          if (this.dataForm.targetType === 0) {
 | 
				
			||||||
 | 
					            if (this.dataForm.targetYear && this.dataForm.targetMonth !== null) {
 | 
				
			||||||
 | 
					              if (this.dataForm.targetMonth < 10) {
 | 
				
			||||||
 | 
					                this.$set(this.dataForm, 'reportTime', String(this.dataForm.targetYear) + '-0' + String(this.dataForm.targetMonth))
 | 
				
			||||||
 | 
					              } else {
 | 
				
			||||||
 | 
					                this.$set(this.dataForm, 'reportTime', String(this.dataForm.targetYear) + '-' + String(this.dataForm.targetMonth))
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
<style scoped>
 | 
					<style scoped>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,28 +1,28 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2023-11-06 15:15:30
 | 
					 * @Date: 2023-11-06 15:15:30
 | 
				
			||||||
 * @LastEditTime: 2024-04-17 16:40:01
 | 
					 * @LastEditTime: 2024-05-22 15:29:18
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <el-drawer class="drawer" :visible.sync="visible" size="50%">
 | 
					  <el-drawer class="drawer" :visible.sync="visible" size="58%" @closed="$emit('destroy')">
 | 
				
			||||||
    <small-title slot="title" :no-padding="true">
 | 
					    <small-title slot="title" :no-padding="true">
 | 
				
			||||||
      {{ '碲化镉工厂生产数据详情' }}
 | 
					      {{ ftype === 0 ? '碲化镉工厂生产数据详情' : '铜铟镓硒工厂生产数据详情' }}
 | 
				
			||||||
    </small-title>
 | 
					    </small-title>
 | 
				
			||||||
    <div class="detailBox">
 | 
					    <div class="detailBox">
 | 
				
			||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="8">
 | 
					        <el-col :span="8">
 | 
				
			||||||
          <p class="title">工厂名称</p>
 | 
					          <p class="title">工厂名称</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ factoryList[dataForm.factory] }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="8">
 | 
					        <el-col :span="8">
 | 
				
			||||||
          <p class="title">时间维度</p>
 | 
					          <p class="title">时间维度</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.targetType === 0 ? '月' : '年' }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="8">
 | 
					        <el-col :span="8">
 | 
				
			||||||
          <p class="title">时间</p>
 | 
					          <p class="title">时间</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.targetType === 1 ? dataForm.targetYear + '年' : dataForm.targetYear + '年' + dataForm.targetMonth + '月'}}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <el-divider></el-divider>
 | 
					      <el-divider></el-divider>
 | 
				
			||||||
@@ -32,47 +32,47 @@
 | 
				
			|||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片产量</p>
 | 
					          <p class="title">芯片产量</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ dataForm.chipYield }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片良率</p>
 | 
					          <p class="title">芯片良率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.chipYieldRate }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片良率</p>
 | 
					          <p class="title">芯片BOM</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.chipBom }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片总功率</p>
 | 
					          <p class="title">芯片总功率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.chipTotalPower }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">FTO投入量</p>
 | 
					          <p class="title">{{ ftype === 0 ? 'FTO投入量' : '钼电极投入量' }}</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ ftype === 0 ? dataForm.ftoInput : dataForm.molybdenumElectrodeInput }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">CSS稼动率</p>
 | 
					          <p class="title">{{ ftype === 0 ? 'CSS稼动率' : 'PID6稼动率' }}</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.chipCssMarriageRate }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片段OEE</p>
 | 
					          <p class="title">芯片段OEE</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.chipOee }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片平均功率</p>
 | 
					          <p class="title">芯片平均功率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.chipAveragePower }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片人均产量</p>
 | 
					          <p class="title">芯片人均产量</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ dataForm.chipAnnualAverageProduction }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片产能利用率</p>
 | 
					          <p class="title">芯片产能利用率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.chipCapacityUtilizationRate }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <small-title style=" margin: 0;padding: 26px 32px 24px;margin-bottom: 22px;" :no-padding="false">
 | 
					      <small-title style=" margin: 0;padding: 26px 32px 24px;margin-bottom: 22px;" :no-padding="false">
 | 
				
			||||||
@@ -81,37 +81,37 @@
 | 
				
			|||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">封装BOM</p>
 | 
					          <p class="title">封装BOM</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ dataForm.componentBom }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">封装线OEE</p>
 | 
					          <p class="title">封装线OEE</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.componentOee }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">标准组件良率</p>
 | 
					          <p class="title">标准组件良率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.componentYieldRate }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">标准组件产量</p>
 | 
					          <p class="title">标准组件产量</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.componentYield }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">标准组件总功率</p>
 | 
					          <p class="title">标准组件总功率</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ dataForm.componentTotalPower }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">封装产能利用率</p>
 | 
					          <p class="title">封装产能利用率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.componentCapacityUtilizationRate }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">标准组件人均产量</p>
 | 
					          <p class="title">标准组件人均产量</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.componentAnnualAverageProduction }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">标准组件人均产量</p>
 | 
					          <p class="title">标准组件平均功率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.componentAveragePower }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <small-title style=" margin: 0;padding: 26px 32px 24px;margin-bottom: 22px;" :no-padding="false">
 | 
					      <small-title style=" margin: 0;padding: 26px 32px 24px;margin-bottom: 22px;" :no-padding="false">
 | 
				
			||||||
@@ -120,33 +120,33 @@
 | 
				
			|||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">产品产量</p>
 | 
					          <p class="title">产品产量</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ dataForm.bipvProductOutput }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">人均产量</p>
 | 
					          <p class="title">人均产量</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.bipvAnnualAverageProduction }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片使用量</p>
 | 
					          <p class="title">芯片使用量</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.bipvChipUsage }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">芯片使用量</p>
 | 
					          <p class="title">芯片利用率</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.bipvChipUtilizationRate }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
      <el-row :gutter="24">
 | 
					      <el-row :gutter="24">
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">内部材料成本</p>
 | 
					          <p class="title">内部材料成本</p>
 | 
				
			||||||
          <p class="text">{{ }}</p>
 | 
					          <p class="text">{{ dataForm.bipvInsideMaterialCost }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">内部材料成本</p>
 | 
					          <p class="title">OEM及委外材料成本</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.code }}</p>
 | 
					          <p class="text">{{ dataForm.bipvOeeMaterialCost }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
        <el-col :span="6">
 | 
					        <el-col :span="6">
 | 
				
			||||||
          <p class="title">内部材料成本</p>
 | 
					          <p class="title">综合材料成本</p>
 | 
				
			||||||
          <p class="text">{{ dataForm.productName }}</p>
 | 
					          <p class="text">{{ dataForm.bipvComprehensiveMaterialCost }}</p>
 | 
				
			||||||
        </el-col>
 | 
					        </el-col>
 | 
				
			||||||
      </el-row>
 | 
					      </el-row>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
@@ -155,20 +155,24 @@
 | 
				
			|||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
// import basicAdd from './basic-add';
 | 
					import { getProduceTargetDetail } from '@/api/produceData';
 | 
				
			||||||
// import {
 | 
					 | 
				
			||||||
//   createQualityScrapLog, updateQualityScrapLog, getQualityScrapLog, getWorkOrderList,
 | 
					 | 
				
			||||||
//   getTeamList, getDetList, getLineList
 | 
					 | 
				
			||||||
// } from "@/api/base/qualityScrapLog";
 | 
					 | 
				
			||||||
// import { getList, } from "@/api/base/qualityScrapType";
 | 
					 | 
				
			||||||
import SmallTitle from './SmallTitle';
 | 
					import SmallTitle from './SmallTitle';
 | 
				
			||||||
 | 
					import { factoryList } from "@/utils/constants";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  components: {
 | 
					  components: {
 | 
				
			||||||
    SmallTitle,
 | 
					    SmallTitle,
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    ftype: {
 | 
				
			||||||
 | 
					      type: Number,
 | 
				
			||||||
 | 
					      default: 0
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
  // mixins: [basicAdd],
 | 
					  // mixins: [basicAdd],
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
 | 
					      factoryList,
 | 
				
			||||||
      urlOptions: {
 | 
					      urlOptions: {
 | 
				
			||||||
        isGetCode: false,
 | 
					        isGetCode: false,
 | 
				
			||||||
        // codeURL: getCode,
 | 
					        // codeURL: getCode,
 | 
				
			||||||
@@ -223,8 +227,14 @@ export default {
 | 
				
			|||||||
    // this.getCurrentTime()
 | 
					    // this.getCurrentTime()
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    init() {
 | 
					    init(id) {
 | 
				
			||||||
      this.visible = true
 | 
					      this.visible = true
 | 
				
			||||||
 | 
					      console.log('打印', id)
 | 
				
			||||||
 | 
					      if (id) {
 | 
				
			||||||
 | 
					        getProduceTargetDetail(id).then(res => {
 | 
				
			||||||
 | 
					          this.dataForm = res.data
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    // getCurrentTime() {
 | 
					    // getCurrentTime() {
 | 
				
			||||||
    //   // new Date().Format("yyyy-MM-dd HH:mm:ss")
 | 
					    //   // new Date().Format("yyyy-MM-dd HH:mm:ss")
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,18 +1,30 @@
 | 
				
			|||||||
<!--
 | 
					<!--
 | 
				
			||||||
 * @Author: zhp
 | 
					 * @Author: zhp
 | 
				
			||||||
 * @Date: 2024-04-15 10:49:13
 | 
					 * @Date: 2024-04-15 10:49:13
 | 
				
			||||||
 * @LastEditTime: 2024-04-17 16:37:35
 | 
					 * @LastEditTime: 2024-05-22 16:22:57
 | 
				
			||||||
 * @LastEditors: zhp
 | 
					 * @LastEditors: DY
 | 
				
			||||||
 * @Description:
 | 
					 * @Description:
 | 
				
			||||||
-->
 | 
					-->
 | 
				
			||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div style="display: flex; flex-direction: column; min-height: calc(100vh - 96px - 31px)">
 | 
					  <div style="display: flex; flex-direction: column; min-height: calc(100vh - 96px - 31px)">
 | 
				
			||||||
    <div class="app-container" style="padding: 16px 24px 0;height: auto; flex-grow: 1;">
 | 
					    <ButtonNav :menus="['碲化镉工厂', '铜铟镓硒工厂']" :button-mode="true" @change="changeFactory" style="margin-top: -10px">
 | 
				
			||||||
      <ButtonNav :menus="['碲化镉工厂', '铜铟镓硒工厂']" :button-mode="true" @change="currentMenu = $event">
 | 
					 | 
				
			||||||
    </ButtonNav>
 | 
					    </ButtonNav>
 | 
				
			||||||
 | 
					    <div class="app-container" style="padding: 16px 24px 0;height: auto; flex-grow: 1;">
 | 
				
			||||||
      <el-form :model="listQuery" :inline="true" ref="dataForm" class="blueTip">
 | 
					      <el-form :model="listQuery" :inline="true" ref="dataForm" class="blueTip">
 | 
				
			||||||
        <el-form-item label="时间维度" prop="reportTime">
 | 
					        <el-form-item v-if="facType === 0" label="工厂名称" prop="factorys">
 | 
				
			||||||
          <el-select clearable v-model="timeSelect" placeholder="请选择">
 | 
					          <el-select size="small" v-model="listQuery.factorys" placeholder="请选择工厂名称" multiple clearable>
 | 
				
			||||||
 | 
					            <el-option v-for="item in dhgfactoryList" :key="item.id" :label="item.name" :value="item.id">
 | 
				
			||||||
 | 
					            </el-option>
 | 
				
			||||||
 | 
					          </el-select>
 | 
				
			||||||
 | 
					        </el-form-item>
 | 
				
			||||||
 | 
					        <el-form-item v-else label="工厂名称" prop="factorys">
 | 
				
			||||||
 | 
					          <el-select size="small" v-model="listQuery.factorys" placeholder="请选择工厂名称" multiple clearable>
 | 
				
			||||||
 | 
					            <el-option v-for="item in tyjxfactoryList" :key="item.id" :label="item.name" :value="item.id">
 | 
				
			||||||
 | 
					            </el-option>
 | 
				
			||||||
 | 
					          </el-select>
 | 
				
			||||||
 | 
					        </el-form-item>
 | 
				
			||||||
 | 
					        <el-form-item label="时间维度" prop="date">
 | 
				
			||||||
 | 
					          <el-select size="small" clearable v-model="listQuery.date" placeholder="请选择">
 | 
				
			||||||
            <el-option v-for="item in timeList" :key="item.value" :label="item.label" :value="item.value">
 | 
					            <el-option v-for="item in timeList" :key="item.value" :label="item.label" :value="item.value">
 | 
				
			||||||
            </el-option>
 | 
					            </el-option>
 | 
				
			||||||
          </el-select>
 | 
					          </el-select>
 | 
				
			||||||
@@ -34,26 +46,20 @@
 | 
				
			|||||||
            {{ date1 }} 至 {{ date2 }},共 {{ weekNum }} 周
 | 
					            {{ date1 }} 至 {{ date2 }},共 {{ weekNum }} 周
 | 
				
			||||||
          </span>
 | 
					          </span>
 | 
				
			||||||
        </el-form-item> -->
 | 
					        </el-form-item> -->
 | 
				
			||||||
        <el-form-item v-show="timeSelect === 'month'" label="时间范围" prop="reportTime">
 | 
					        <el-form-item v-show="listQuery.date !== 4" label="时间值" prop="reportTime">
 | 
				
			||||||
          <el-date-picker v-model="listQuery.reportTime" type="monthrange" range-separator="至" start-placeholder="开始月份"
 | 
					          <el-date-picker size="small" v-model="listQuery.reportTime" type="monthrange" value-format="timestamp" range-separator="至" start-placeholder="开始月份"
 | 
				
			||||||
            end-placeholder="结束月份" @change="changeTime">
 | 
					            end-placeholder="结束月份" @change="changeTime">
 | 
				
			||||||
          </el-date-picker>
 | 
					          </el-date-picker>
 | 
				
			||||||
        </el-form-item>
 | 
					        </el-form-item>
 | 
				
			||||||
        <el-form-item v-show="timeSelect === 'year'" label="时间范围" prop="reportTime">
 | 
					        <el-form-item v-show="listQuery.date === 4" label="时间值" prop="reportTime">
 | 
				
			||||||
          <el-date-picker clearable v-model="listQuery.reportTime[0]" value-format="yyyy" type="year"
 | 
					          <el-date-picker size="small" clearable v-model="start" value-format="timestamp" type="year"
 | 
				
			||||||
            placeholder="开始时间">
 | 
					            placeholder="开始时间">
 | 
				
			||||||
          </el-date-picker>
 | 
					          </el-date-picker>
 | 
				
			||||||
          ~
 | 
					          ~
 | 
				
			||||||
          <el-date-picker clearable v-model="listQuery.reportTime[1]" value-format="yyyy" type="year" placeholder="结束时间"
 | 
					          <el-date-picker size="small" clearable v-model="end" value-format="timestamp" type="year" placeholder="结束时间"
 | 
				
			||||||
            @change="getYear">
 | 
					            @change="getYear">
 | 
				
			||||||
          </el-date-picker>
 | 
					          </el-date-picker>
 | 
				
			||||||
        </el-form-item>
 | 
					        </el-form-item>
 | 
				
			||||||
        <el-form-item label="工厂名称" prop="factoryId">
 | 
					 | 
				
			||||||
          <el-select v-model="listQuery.factoryId" placeholder="请选择工厂名称" multiple="true" clearable>
 | 
					 | 
				
			||||||
            <el-option v-for="item in factoryList" :key="item.id" :label="item.name" :value="item.id">
 | 
					 | 
				
			||||||
            </el-option>
 | 
					 | 
				
			||||||
          </el-select>
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
        <!-- <el-form-item label="玻璃类型" prop="type">
 | 
					        <!-- <el-form-item label="玻璃类型" prop="type">
 | 
				
			||||||
          <el-select v-model="listQuery.type" placeholder="请选择玻璃类型">
 | 
					          <el-select v-model="listQuery.type" placeholder="请选择玻璃类型">
 | 
				
			||||||
            <el-option v-for="item in typeList" :key="item.id" :label="item.name" :value="item.id">
 | 
					            <el-option v-for="item in typeList" :key="item.id" :label="item.name" :value="item.id">
 | 
				
			||||||
@@ -68,28 +74,62 @@
 | 
				
			|||||||
        </el-form-item> -->
 | 
					        </el-form-item> -->
 | 
				
			||||||
        <el-form-item>
 | 
					        <el-form-item>
 | 
				
			||||||
          <el-button type="primary" size="small" @click="getDataList">查询</el-button>
 | 
					          <el-button type="primary" size="small" @click="getDataList">查询</el-button>
 | 
				
			||||||
 | 
					          <el-divider direction="vertical"></el-divider>
 | 
				
			||||||
 | 
					          <el-button type="primary" size="small" plain @click="handleImport">导入</el-button>
 | 
				
			||||||
          <el-button type="primary" size="small" plain @click="handleExport">导出</el-button>
 | 
					          <el-button type="primary" size="small" plain @click="handleExport">导出</el-button>
 | 
				
			||||||
 | 
					          <el-button type="success" size="small" plain @click="addFactory">新增</el-button>
 | 
				
			||||||
        </el-form-item>
 | 
					        </el-form-item>
 | 
				
			||||||
      </el-form>
 | 
					      </el-form>
 | 
				
			||||||
      <!-- <search-bar :formConfigs="formConfig" ref="searchBarForm" @headBtnClick="buttonClick" /> -->
 | 
					      <!-- <search-bar :formConfigs="formConfig" ref="searchBarForm" @headBtnClick="buttonClick" /> -->
 | 
				
			||||||
      <base-table :table-props="tableProps" :page="listQuery.pageNo" :limit="listQuery.pageSize"
 | 
					      <base-table :table-props="tableProps" :page="listQuery.current" :limit="listQuery.size"
 | 
				
			||||||
        :table-data="tableData">
 | 
					        :table-data="tableData">
 | 
				
			||||||
        <method-btn v-if="tableBtn.length" slot="handleBtn" label="操作" :width="120" fixed="right"
 | 
					        <method-btn v-if="tableBtn.length" slot="handleBtn" label="操作" :width="120" fixed="right"
 | 
				
			||||||
          :method-list="tableBtn" @clickBtn="handleClick" />
 | 
					          :method-list="tableBtn" @clickBtn="handleClick" />
 | 
				
			||||||
      </base-table>
 | 
					      </base-table>
 | 
				
			||||||
      <detail-or-update v-if="detailOrUpdateVisible" ref="detailOrUpdate" @refreshDataList="successSubmit" />
 | 
					      <pagination
 | 
				
			||||||
      <add-or-update v-if="addOrUpdateVisible" ref="addOrUpdate" @refreshDataList="successSubmit" />
 | 
					        :limit.sync="listQuery.size"
 | 
				
			||||||
 | 
					        :page.sync="listQuery.current"
 | 
				
			||||||
      <!-- <el-row :gutter="24"> -->
 | 
					        :total="listQuery.total"
 | 
				
			||||||
      <!-- <el-col :span="12" v-for="item in  dataList" :key="item.id"> -->
 | 
					        @pagination="getDataList"
 | 
				
			||||||
      <!-- <line-chart class="yearChart" ref="lineChart" style="height: 40vh;width: 100%"></line-chart> -->
 | 
					      />
 | 
				
			||||||
      <!-- </el-col> -->
 | 
					      <detail-or-update v-if="detailOrUpdateVisible" ref="detailOrUpdate" :ftype="facType" @destroy="detailOrUpdateVisible = false" />
 | 
				
			||||||
      <!-- <el-col :span="12">
 | 
					      <add-or-update v-if="addOrUpdateVisible" ref="addOrUpdate" :ftype="facType" @refreshDataList="getDataList" @destroy="addOrUpdateVisible = false" />
 | 
				
			||||||
            <line-chart :id=" 'second' " class="yearChart" ref="lineChart" style="height: 40vh;width: 100%"></line-chart>
 | 
					 | 
				
			||||||
          </el-col> -->
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <!-- 用户导入对话框 -->
 | 
				
			||||||
 | 
					    <el-dialog :title="upload.title" :visible.sync="upload.open" width="400px" append-to-body>
 | 
				
			||||||
 | 
					      <el-upload ref="upload" :limit="1" accept=".xlsx, .xls"
 | 
				
			||||||
 | 
					        :headers="upload.headers"
 | 
				
			||||||
 | 
					        :action="upload.url"
 | 
				
			||||||
 | 
					        :file-list="fileList"
 | 
				
			||||||
 | 
					        :disabled="upload.isUploading"
 | 
				
			||||||
 | 
					        :on-success="handleFileSuccess"
 | 
				
			||||||
 | 
					        :on-progress="handleFileUploadProgress"
 | 
				
			||||||
 | 
					        :auto-upload="false" drag>
 | 
				
			||||||
 | 
					        <i class="el-icon-upload"></i>
 | 
				
			||||||
 | 
					        <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
 | 
				
			||||||
 | 
					        <div class="el-upload__tip text-center" slot="tip">
 | 
				
			||||||
 | 
					          <span>仅允许导入xls、xlsx格式文件。</span>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </el-upload>
 | 
				
			||||||
 | 
					      <!-- <el-upload
 | 
				
			||||||
 | 
					        ref="upload"
 | 
				
			||||||
 | 
					        class="upload-demo"
 | 
				
			||||||
 | 
					        action="#"
 | 
				
			||||||
 | 
					        :limit="1"
 | 
				
			||||||
 | 
					        :file-list="fileList"
 | 
				
			||||||
 | 
					        :auto-upload="false"
 | 
				
			||||||
 | 
					        :http-request="handleFileSuccess"> -->
 | 
				
			||||||
 | 
					        <!-- <el-button size="small" type="primary">点击上传</el-button>
 | 
				
			||||||
 | 
					        <div slot="tip" class="el-upload__tip">只能上传.xlsx, .xls文件,且不超过500kb</div>
 | 
				
			||||||
 | 
					      </el-upload> -->
 | 
				
			||||||
 | 
					      <div slot="footer" class="dialog-footer">
 | 
				
			||||||
 | 
					        <el-button type="primary" @click="submitFileForm">确 定</el-button>
 | 
				
			||||||
 | 
					        <el-button @click="upload.open = false">取 消</el-button>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </el-dialog>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- <inputTable :date="date" :data="tableData" :time="[startTimeStamp, endTimeStamp]" :sum="all"
 | 
					    <!-- <inputTable :date="date" :data="tableData" :time="[startTimeStamp, endTimeStamp]" :sum="all"
 | 
				
			||||||
      :type="listQuery.reportType" @refreshDataList="getDataList" /> -->
 | 
					      :type="listQuery.reportType" @refreshDataList="getDataList" /> -->
 | 
				
			||||||
    <!-- <pagination
 | 
					    <!-- <pagination
 | 
				
			||||||
@@ -101,8 +141,8 @@
 | 
				
			|||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
// import { parseTime } from '../../core/mixins/code-filter';
 | 
					import { parseTime } from '@/utils/ruoyi';
 | 
				
			||||||
// import { getGlassPage, exportGlasscExcel } from '@/api/report/glass';
 | 
					import { prodTargetDiPage, prodTargetToPage, exportDiTargetExcel, exportToTargetExcel, delTarget, importToTarget, importDiTarget } from '@/api/produceData';
 | 
				
			||||||
// import inputTable from './inputTable.vue';
 | 
					// import inputTable from './inputTable.vue';
 | 
				
			||||||
import lineChart from './lineChart';
 | 
					import lineChart from './lineChart';
 | 
				
			||||||
import moment from 'moment'
 | 
					import moment from 'moment'
 | 
				
			||||||
@@ -110,28 +150,53 @@ import ButtonNav from '@/components/ButtonNav'
 | 
				
			|||||||
import basicPage from '@/mixins/basic-page'
 | 
					import basicPage from '@/mixins/basic-page'
 | 
				
			||||||
import detailOrUpdate from './detail-or-updata';
 | 
					import detailOrUpdate from './detail-or-updata';
 | 
				
			||||||
import addOrUpdate from './add-or-updata';
 | 
					import addOrUpdate from './add-or-updata';
 | 
				
			||||||
 | 
					import { factoryList, dhgfactoryList, tyjxfactoryList } from "@/utils/constants";
 | 
				
			||||||
 | 
					import {getBaseHeader} from "@/utils/request";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// import FileSaver from 'file-saver'
 | 
					// import FileSaver from 'file-saver'
 | 
				
			||||||
// import * as XLSX from 'xlsx'
 | 
					// import * as XLSX from 'xlsx'
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  components: { lineChart, ButtonNav, detailOrUpdate,addOrUpdate },
 | 
					  components: { lineChart, ButtonNav, detailOrUpdate, addOrUpdate },
 | 
				
			||||||
  mixins: [basicPage],
 | 
					  mixins: [basicPage],
 | 
				
			||||||
	data() {
 | 
						data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
 | 
					      factoryList,
 | 
				
			||||||
 | 
					      dhgfactoryList,
 | 
				
			||||||
 | 
					      tyjxfactoryList,
 | 
				
			||||||
 | 
					      currentMenu: '碲化镉工厂',
 | 
				
			||||||
 | 
					      fileList: [],
 | 
				
			||||||
 | 
					      start: undefined,
 | 
				
			||||||
 | 
					      end: undefined,
 | 
				
			||||||
      listQuery: {
 | 
					      listQuery: {
 | 
				
			||||||
        pageSize: 10,
 | 
					        size: 10,
 | 
				
			||||||
        pageNo: 1,
 | 
					        current: 1,
 | 
				
			||||||
        factoryId: null,
 | 
					        factorys: null,
 | 
				
			||||||
        total: 0,
 | 
					        total: 0,
 | 
				
			||||||
        type: null,
 | 
					        date: undefined,
 | 
				
			||||||
        // reportType: 2,
 | 
					        beginTime: undefined,
 | 
				
			||||||
 | 
					        endTime: undefined,
 | 
				
			||||||
        reportTime: []
 | 
					        reportTime: []
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      detailOrUpdateVisible: false,
 | 
					      detailOrUpdateVisible: false,
 | 
				
			||||||
      addOrUpdateVisible:false,
 | 
					      addOrUpdateVisible:false,
 | 
				
			||||||
      date1: undefined,
 | 
					      date1: undefined,
 | 
				
			||||||
      date2: undefined,
 | 
					      date2: undefined,
 | 
				
			||||||
 | 
					      // 用户导入参数
 | 
				
			||||||
 | 
					      upload: {
 | 
				
			||||||
 | 
					        // 是否显示弹出层(用户导入)
 | 
				
			||||||
 | 
					        open: false,
 | 
				
			||||||
 | 
					        // 弹出层标题(用户导入)
 | 
				
			||||||
 | 
					        title: "导入",
 | 
				
			||||||
 | 
					        // 是否禁用上传
 | 
				
			||||||
 | 
					        isUploading: false,
 | 
				
			||||||
 | 
					        // 是否更新已经存在的用户数据
 | 
				
			||||||
 | 
					        // updateSupport: 0,
 | 
				
			||||||
 | 
					        // 设置上传的请求头部
 | 
				
			||||||
 | 
					        headers: getBaseHeader(),
 | 
				
			||||||
 | 
					        // 上传的地址
 | 
				
			||||||
 | 
					        url: process.env.VUE_APP_BASE_API + '/admin-api/ip/prod-target/di-target-import-excel'
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
      tableBtn: [
 | 
					      tableBtn: [
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
            type: 'detail',
 | 
					            type: 'detail',
 | 
				
			||||||
@@ -144,7 +209,7 @@ export default {
 | 
				
			|||||||
        {
 | 
					        {
 | 
				
			||||||
          type: 'delete',
 | 
					          type: 'delete',
 | 
				
			||||||
          btnName: '删除',
 | 
					          btnName: '删除',
 | 
				
			||||||
          },
 | 
					        }
 | 
				
			||||||
      ].filter((v) => v),
 | 
					      ].filter((v) => v),
 | 
				
			||||||
      typeList: [
 | 
					      typeList: [
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
@@ -159,27 +224,6 @@ export default {
 | 
				
			|||||||
          name: 'BIPV产品',
 | 
					          name: 'BIPV产品',
 | 
				
			||||||
          id: 2,
 | 
					          id: 2,
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
      ],
 | 
					 | 
				
			||||||
      // weekNum: undefined,
 | 
					 | 
				
			||||||
      dataList: [
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          id:'first',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
         {
 | 
					 | 
				
			||||||
          id: 'second',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
         {
 | 
					 | 
				
			||||||
          id: 'third',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
         {
 | 
					 | 
				
			||||||
          id: 'fourth',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
         {
 | 
					 | 
				
			||||||
          id: 'fifth',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
         {
 | 
					 | 
				
			||||||
          id: 'sixth',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
			urlOptions: {
 | 
								urlOptions: {
 | 
				
			||||||
				// getDataListURL: getGlassPage,
 | 
									// getDataListURL: getGlassPage,
 | 
				
			||||||
@@ -270,135 +314,220 @@ export default {
 | 
				
			|||||||
        },
 | 
					        },
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      timeList: [
 | 
					      timeList: [
 | 
				
			||||||
        // {
 | 
					 | 
				
			||||||
        //   value: 'day',
 | 
					 | 
				
			||||||
        //   label: '日'
 | 
					 | 
				
			||||||
        // },
 | 
					 | 
				
			||||||
        // {
 | 
					 | 
				
			||||||
        //   value: 'week',
 | 
					 | 
				
			||||||
        //   label: '周'
 | 
					 | 
				
			||||||
        // },
 | 
					 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          value: 'month',
 | 
					          value: 3,
 | 
				
			||||||
          label:'月'
 | 
					          label:'月'
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          value: 'year',
 | 
					          value: 4,
 | 
				
			||||||
          label: '年'
 | 
					          label: '年'
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      factoryList: [
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: '测试',
 | 
					 | 
				
			||||||
          id:1
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          name: '测试2',
 | 
					 | 
				
			||||||
          id: 2
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      ],
 | 
					 | 
				
			||||||
      tableProps: [
 | 
					      tableProps: [
 | 
				
			||||||
        // {
 | 
					 | 
				
			||||||
        // 	prop: 'createTime',
 | 
					 | 
				
			||||||
        // 	label: '添加时间',
 | 
					 | 
				
			||||||
        // 	fixed: true,
 | 
					 | 
				
			||||||
        // 	width: 180,
 | 
					 | 
				
			||||||
        // 	filter: (val) => moment(val).format('yyyy-MM-DD HH:mm:ss'),
 | 
					 | 
				
			||||||
        // },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'nickName',
 | 
					          prop: 'factory',
 | 
				
			||||||
          label: '工厂名称',
 | 
					          label: '工厂名称',
 | 
				
			||||||
 | 
					          filter: (val) => factoryList[val],
 | 
				
			||||||
 | 
					          minWidth: 200,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'userName',
 | 
					          prop: 'tagertTime',
 | 
				
			||||||
          label: '目标时间',
 | 
					          label: '目标时间',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'type',
 | 
					          prop: 'createTime',
 | 
				
			||||||
          label: '提交时间',
 | 
					          label: '提交时间',
 | 
				
			||||||
 | 
					          filter: parseTime,
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'inNum',
 | 
					          prop: 'ftoInput',
 | 
				
			||||||
          label: '钼电极投入量(片)',
 | 
					          label: 'FTO投入量(片)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'putNum',
 | 
					          prop: 'chipYield',
 | 
				
			||||||
          label: '芯片产量(片)',
 | 
					          label: '芯片产量(片)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'goodNum',
 | 
					          prop: 'chipAveragePower',
 | 
				
			||||||
          label: '芯片平均功率(W)',
 | 
					          label: '芯片平均功率(W)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'goodYelid',
 | 
					          prop: 'chipYieldRate',
 | 
				
			||||||
          label: '芯片良率(%)',
 | 
					          label: '芯片良率(%)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'goodYelid',
 | 
					          prop: 'chipTotalPower',
 | 
				
			||||||
          label: '芯片总功率(KW)',
 | 
					          label: '芯片总功率(KW)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'goodYelid',
 | 
					          prop: 'chipCssMarriageRate',
 | 
				
			||||||
          label: 'PID6稼动率(%)',
 | 
					          label: 'CSS稼动率(%)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'goodYelid',
 | 
					          prop: 'chipOee',
 | 
				
			||||||
          label: '芯片段OEE(%)',
 | 
					          label: '芯片段OEE(%)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'goodYelid',
 | 
					          prop: 'chipCapacityUtilizationRate',
 | 
				
			||||||
          label: '芯片产能利用率(%)',
 | 
					          label: '芯片产能利用率(%)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'goodYelid',
 | 
					          prop: 'chipAnnualAverageProduction',
 | 
				
			||||||
          label: '芯片人均产量(片/人)',
 | 
					          label: '芯片人均产量(片/人)',
 | 
				
			||||||
 | 
					          minWidth: 180,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
          prop: 'goodYelid',
 | 
					          prop: 'chipBom',
 | 
				
			||||||
          label: '芯片BOM',
 | 
					          label: '芯片BOM',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
      ],
 | 
					      ],
 | 
				
			||||||
      timeSelect:'month',
 | 
					      // timeSelect:'month',
 | 
				
			||||||
      startTimeStamp:null, //开始时间
 | 
					      startTimeStamp:null, //开始时间
 | 
				
			||||||
      endTimeStamp:null, //结束时间
 | 
					      endTimeStamp:null, //结束时间
 | 
				
			||||||
      // date:'凯盛玻璃控股成员企业2024生产数据',
 | 
					      // date:'凯盛玻璃控股成员企业2024生产数据',
 | 
				
			||||||
			// reportTime: '',
 | 
								// reportTime: '',
 | 
				
			||||||
			startTimeStamp: '',
 | 
								startTimeStamp: '',
 | 
				
			||||||
			endTimeStamp: '',
 | 
								endTimeStamp: '',
 | 
				
			||||||
      tableData: [
 | 
					      tableData: [],
 | 
				
			||||||
        {
 | 
					      facType: 0
 | 
				
			||||||
          userName: 'userName',
 | 
					 | 
				
			||||||
          nickName: '用户名',
 | 
					 | 
				
			||||||
          datas:'111111'
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          userName: 'userName',
 | 
					 | 
				
			||||||
          nickName: '用户名',
 | 
					 | 
				
			||||||
          datas: '111111'
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        {
 | 
					 | 
				
			||||||
          userName: 'userName',
 | 
					 | 
				
			||||||
          nickName: '用户名',
 | 
					 | 
				
			||||||
          datas: '111111'
 | 
					 | 
				
			||||||
          // subcomponent: row
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      ],
 | 
					 | 
				
			||||||
			// proLineList: [],
 | 
								// proLineList: [],
 | 
				
			||||||
			// all: {}
 | 
								// all: {}
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  computed: {
 | 
					  // computed: {
 | 
				
			||||||
    weekNum() {
 | 
					  //   weekNum() {
 | 
				
			||||||
      return Math.round((this.listQuery.reportTime[1] - this.listQuery.reportTime[0]) / (24 * 60 * 60 * 1000 * 7)) + 1
 | 
					  //     return Math.round((this.listQuery.reportTime[1] - this.listQuery.reportTime[0]) / (24 * 60 * 60 * 1000 * 7)) + 1
 | 
				
			||||||
    },
 | 
					  //   },
 | 
				
			||||||
 | 
					  // },
 | 
				
			||||||
 | 
					  watch: {
 | 
				
			||||||
 | 
					    facType(value) {
 | 
				
			||||||
 | 
					      if (value === 0) {
 | 
				
			||||||
 | 
					        this.$set(this.tableProps, 3, {
 | 
				
			||||||
 | 
					          prop: 'ftoInput',
 | 
				
			||||||
 | 
					          label: 'FTO投入量(片)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        this.upload.url = process.env.VUE_APP_BASE_API + '/admin-api/ip/prod-target/di-target-import-excel'
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.$set(this.tableProps, 3, {
 | 
				
			||||||
 | 
					          prop: 'molybdenumElectrodeInput',
 | 
				
			||||||
 | 
					          label: '钼电极投入量(片)',
 | 
				
			||||||
 | 
					          minWidth: 150,
 | 
				
			||||||
 | 
					          showOverflowtooltip: true
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        this.upload.url = process.env.VUE_APP_BASE_API + '/admin-api/ip/prod-target/to-target-import-excel'
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      console.log(112, this.tableProps)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
	mounted() {
 | 
						mounted() {
 | 
				
			||||||
    this.getDict()
 | 
					    // this.getDict()
 | 
				
			||||||
    // this.getCurrentYearFirst()
 | 
					    // this.getCurrentYearFirst()
 | 
				
			||||||
    // this.getDataList()
 | 
					    this.getDataList()
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
 | 
					    handleImport() {
 | 
				
			||||||
 | 
					      this.upload.title = "生产目标导入";
 | 
				
			||||||
 | 
					      this.upload.open = true;
 | 
				
			||||||
 | 
					      this.fileList = []
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 文件上传中处理
 | 
				
			||||||
 | 
					    handleFileUploadProgress(event, file, fileList) {
 | 
				
			||||||
 | 
					      this.upload.isUploading = true;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 文件上传成功处理
 | 
				
			||||||
 | 
					    // handleFileSuccess(param, type) {
 | 
				
			||||||
 | 
					    //   console.log('带的', param.file)
 | 
				
			||||||
 | 
					    //   const formData = new FormData()
 | 
				
			||||||
 | 
					    //   formData.append('multipartFile', param.file)
 | 
				
			||||||
 | 
					    //   console.log('送送', param)
 | 
				
			||||||
 | 
					    //   importDiTarget(formData).then(res => {
 | 
				
			||||||
 | 
					    //     console.log(res)
 | 
				
			||||||
 | 
					    //     if (res.code !== 0) {
 | 
				
			||||||
 | 
					    //       this.$modal.msgError(response.msg)
 | 
				
			||||||
 | 
					    //       return;
 | 
				
			||||||
 | 
					    //     }
 | 
				
			||||||
 | 
					    //     this.upload.open = false;
 | 
				
			||||||
 | 
					    //     this.upload.isUploading = false;
 | 
				
			||||||
 | 
					    //     this.$refs.upload.clearFiles();
 | 
				
			||||||
 | 
					    //   }).catch(() => {
 | 
				
			||||||
 | 
					    //     this.upload.open = false
 | 
				
			||||||
 | 
					    //     this.upload.isUploading = false
 | 
				
			||||||
 | 
					    //   })
 | 
				
			||||||
 | 
					    //   // 拼接提示语
 | 
				
			||||||
 | 
					    //   // let data = response.data;
 | 
				
			||||||
 | 
					    //   // let text = '创建成功数量:' + data.createUsernames.length;
 | 
				
			||||||
 | 
					    //   // for (const username of data.createUsernames) {
 | 
				
			||||||
 | 
					    //   //   text += '<br />    ' + username;
 | 
				
			||||||
 | 
					    //   // }
 | 
				
			||||||
 | 
					    //   // text += '<br />更新成功数量:' + data.updateUsernames.length;
 | 
				
			||||||
 | 
					    //   // for (const username of data.updateUsernames) {
 | 
				
			||||||
 | 
					    //   //   text += '<br />    ' + username;
 | 
				
			||||||
 | 
					    //   // }
 | 
				
			||||||
 | 
					    //   // text += '<br />更新失败数量:' + Object.keys(data.failureUsernames).length;
 | 
				
			||||||
 | 
					    //   // for (const username in data.failureUsernames) {
 | 
				
			||||||
 | 
					    //   //   text += '<br />    ' + username + ':' + data.failureUsernames[username];
 | 
				
			||||||
 | 
					    //   // }
 | 
				
			||||||
 | 
					    //   this.$message.success('导入成功!');
 | 
				
			||||||
 | 
					    //   this.getDataList();
 | 
				
			||||||
 | 
					    // },
 | 
				
			||||||
 | 
					        // 文件上传成功处理
 | 
				
			||||||
 | 
					    handleFileSuccess(response, file, fileList) {
 | 
				
			||||||
 | 
					      if (response.code !== 0) {
 | 
				
			||||||
 | 
					        this.$modal.msgError(response.msg)
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.upload.open = false;
 | 
				
			||||||
 | 
					      this.upload.isUploading = false;
 | 
				
			||||||
 | 
					      this.$refs.upload.clearFiles();
 | 
				
			||||||
 | 
					      this.$message.success('导入成功!')
 | 
				
			||||||
 | 
					      this.getDataList()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 提交上传文件
 | 
				
			||||||
 | 
					    submitFileForm() {
 | 
				
			||||||
 | 
					      this.$refs.upload.submit();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    addFactory() {
 | 
				
			||||||
 | 
					      this.addOrUpdateVisible = true;
 | 
				
			||||||
 | 
					      this.$nextTick(() => {
 | 
				
			||||||
 | 
					        this.$refs.addOrUpdate.init();
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    changeFactory($event) {
 | 
				
			||||||
 | 
					      this.currentMenu = $event
 | 
				
			||||||
 | 
					      this.facType = this.currentMenu === '碲化镉工厂' ? 0 : 1
 | 
				
			||||||
 | 
					      // if (this.facType === 0) {
 | 
				
			||||||
 | 
					      //   this.upload.url = process.env.VUE_APP_BASE_API + '/admin-api/ip/prod-target/di-target-import-excel'
 | 
				
			||||||
 | 
					      // } else {
 | 
				
			||||||
 | 
					      //   this.upload.url = process.env.VUE_APP_BASE_API + '/admin-api/ip/prod-target/to-target-import-excel'
 | 
				
			||||||
 | 
					      // }
 | 
				
			||||||
 | 
					      this.getDataList()
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    handleClick(val) {
 | 
					    handleClick(val) {
 | 
				
			||||||
      if (val.type === "edit") {
 | 
					      if (val.type === "edit") {
 | 
				
			||||||
        this.addOrUpdateVisible = true;
 | 
					        this.addOrUpdateVisible = true;
 | 
				
			||||||
@@ -407,11 +536,33 @@ export default {
 | 
				
			|||||||
          this.$refs.addOrUpdate.init(val.data.id);
 | 
					          this.$refs.addOrUpdate.init(val.data.id);
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
      } else if (val.type === "delete") {
 | 
					      } else if (val.type === "delete") {
 | 
				
			||||||
        this.deleteHandle(val.data.id, val.data.name, val.data._pageIndex)
 | 
					        console.log('啊啊', val)
 | 
				
			||||||
 | 
					        this.deleteHandle(val.data.id, val.data.factory, val.data._pageIndex)
 | 
				
			||||||
      } else {
 | 
					      } else {
 | 
				
			||||||
        this.otherMethods(val)
 | 
					        this.otherMethods(val)
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    // 删除
 | 
				
			||||||
 | 
					    deleteHandle(id, name, index) {
 | 
				
			||||||
 | 
					      this.$confirm('是否确认删除工厂名称为' + factoryList[name] + '的数据项?', "系统提示", {
 | 
				
			||||||
 | 
					        confirmButtonText: "确定",
 | 
				
			||||||
 | 
					        cancelButtonText: "取消",
 | 
				
			||||||
 | 
					        type: "warning",
 | 
				
			||||||
 | 
					      })
 | 
				
			||||||
 | 
					        .then(() => {
 | 
				
			||||||
 | 
					          delTarget(id).then(({ data }) => {
 | 
				
			||||||
 | 
					            this.$message({
 | 
				
			||||||
 | 
					              message: "操作成功",
 | 
				
			||||||
 | 
					              type: "success",
 | 
				
			||||||
 | 
					              duration: 1500,
 | 
				
			||||||
 | 
					              onClose: () => {
 | 
				
			||||||
 | 
					                this.getDataList();
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        .catch(() => { });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    otherMethods(val) {
 | 
					    otherMethods(val) {
 | 
				
			||||||
      this.detailOrUpdateVisible = true;
 | 
					      this.detailOrUpdateVisible = true;
 | 
				
			||||||
      this.addOrEditTitle = "详情";
 | 
					      this.addOrEditTitle = "详情";
 | 
				
			||||||
@@ -423,133 +574,34 @@ export default {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    getYear(e) {
 | 
					    getYear(e) {
 | 
				
			||||||
      if (this.listQuery.reportTime[0] && e - this.listQuery.reportTime[0] > 10) {
 | 
					      if (this.end && e - this.start > 10 * 365*24*60*60*1000) {
 | 
				
			||||||
        this.$message({
 | 
					        this.$message({
 | 
				
			||||||
          message: '年份起止时间不能超过十年',
 | 
					          message: '年份起止时间不能超过十年',
 | 
				
			||||||
          type: 'warning'
 | 
					          type: 'warning'
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
        // console.log();
 | 
					        // console.log();
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        if (this.end < this.start) {
 | 
				
			||||||
 | 
					          this.$message({
 | 
				
			||||||
 | 
					            message: '结束年份不能小于开始年份',
 | 
				
			||||||
 | 
					            type: 'warning'
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      // console.log(e);
 | 
					      // console.log(e);
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    onValueChange(picker, k) { // 选中近k周后触发的操作
 | 
					    changeTime() {
 | 
				
			||||||
      if (this.listQuery.reportTime[0] && this.listQuery.reportTime[1]) {
 | 
					 | 
				
			||||||
        console.log(this.listQuery.reportTime[0].getTime() - 24 * 60 * 60 * 1000)
 | 
					 | 
				
			||||||
        this.date1 = moment(this.listQuery.reportTime[0].getTime() - 24 * 60 * 60 * 1000).format('YYYY-MM-DD HH:mm:ss')
 | 
					 | 
				
			||||||
        // this.onValueChange()   // 这里为我们希望value改变时触发的方法
 | 
					 | 
				
			||||||
        this.date2 = moment(this.listQuery.reportTime[1].getTime() + 5 * 24 * 60 * 60 * 1000).format('YYYY-MM-DD HH:mm:ss')
 | 
					 | 
				
			||||||
        const numDays = (new Date(this.date2).getTime() - new Date(this.date1).getTime()) / (24 * 3600 * 1000); if (numDays > 168) {
 | 
					 | 
				
			||||||
          console.log(numDays)
 | 
					 | 
				
			||||||
          this.$message({
 | 
					 | 
				
			||||||
            message: '周范围不能超过24周',
 | 
					 | 
				
			||||||
            type: 'warning'
 | 
					 | 
				
			||||||
          });
 | 
					 | 
				
			||||||
          // this.onValueChange()
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    changeDayTime() {
 | 
					 | 
				
			||||||
      if (this.listQuery.reportTime) {
 | 
					      if (this.listQuery.reportTime) {
 | 
				
			||||||
        // this.createStartDate = moment(new Date(this.listQuery.reportTime[0]), 'yyyy-MM-dd hh:mm:ss');
 | 
					        const numDays = this.listQuery.reportTime[1] - this.listQuery.reportTime[0]
 | 
				
			||||||
        // this.createEndDate = moment(new Date(this.listQuery.reportTime[1]), 'yyyy-MM-dd hh:mm:ss');
 | 
					        if (numDays > 2*365*24*60*60*1000) {
 | 
				
			||||||
        console.log(this.listQuery.reportTime[1])
 | 
					 | 
				
			||||||
        const numDays = (new Date(this.listQuery.reportTime[1]).getTime() - new Date(this.listQuery.reportTime[0]).getTime()) / (24 * 3600 * 1000); if (numDays > 30) {
 | 
					 | 
				
			||||||
          this.$message({
 | 
					 | 
				
			||||||
            message: '时间范围不能超过30天',
 | 
					 | 
				
			||||||
            type: 'warning'
 | 
					 | 
				
			||||||
          });
 | 
					 | 
				
			||||||
          this.listQuery.reportTime = [];
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      } else {
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    changeTime(value) {
 | 
					 | 
				
			||||||
      if (this.listQuery.reportTime) {
 | 
					 | 
				
			||||||
        const timeStamp = this.listQuery.reportTime[1].getMonth(); //标准时间转为时间戳,毫秒级别
 | 
					 | 
				
			||||||
        const fullyear = this.listQuery.reportTime[1].getFullYear()
 | 
					 | 
				
			||||||
        let days = 0
 | 
					 | 
				
			||||||
        switch (timeStamp) {
 | 
					 | 
				
			||||||
          case 0:
 | 
					 | 
				
			||||||
          case 2:
 | 
					 | 
				
			||||||
          case 4:
 | 
					 | 
				
			||||||
          case 6:
 | 
					 | 
				
			||||||
          case 7:
 | 
					 | 
				
			||||||
          case 9:
 | 
					 | 
				
			||||||
          case 11:
 | 
					 | 
				
			||||||
            days = 31
 | 
					 | 
				
			||||||
            break
 | 
					 | 
				
			||||||
          case 3:
 | 
					 | 
				
			||||||
          case 4:
 | 
					 | 
				
			||||||
          case 8:
 | 
					 | 
				
			||||||
          case 10:
 | 
					 | 
				
			||||||
            days = 30
 | 
					 | 
				
			||||||
            break
 | 
					 | 
				
			||||||
          case 1:
 | 
					 | 
				
			||||||
            if ((fullyear % 400 === 0) || (fullyear % 4 === 0 && fullyear % 100 !== 0)) {
 | 
					 | 
				
			||||||
              days = 29
 | 
					 | 
				
			||||||
            } else {
 | 
					 | 
				
			||||||
              days = 28
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            break
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        let startTime = moment(new Date(this.listQuery.reportTime[0]).setDate(1, 0, 0, 0)).format('YYYY-MM-DD HH:mm:ss')
 | 
					 | 
				
			||||||
        // this.startTimeStamp = this.timeFun(new Date(fullyear, timeStamp, 1, 7, 0, 1).getTime()); //开始时间
 | 
					 | 
				
			||||||
        let endTime = this.timeFun(new Date(fullyear, timeStamp, days).getTime()) + ' 23:59:59'; //结束时间
 | 
					 | 
				
			||||||
        // console.log(endTimeStamp);
 | 
					 | 
				
			||||||
        // let endTime = moment(this.listQuery.reportTime[1]).month(monthNum - 1).date(1).endOf("month").format("YYYY-MM-DD");
 | 
					 | 
				
			||||||
        // console.log(endTime);
 | 
					 | 
				
			||||||
        // console.log(moment(new Date(this.listQuery.reportTime[1]).setDate(31, 23, 59, 59)).format('YYYY-MM-DD HH:mm:ss'))
 | 
					 | 
				
			||||||
        // console.log(moment(new Date(this.listQuery.reportTime[1]).getTime()).format('YYYY-MM-DD HH:mm:ss'))
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        // this.createStartDate = moment(new Date(this.listQuery.reportTime[0]), 'yyyy-MM-dd hh:mm:ss');
 | 
					 | 
				
			||||||
        // this.createEndDate = moment(new Date(this.listQuery.reportTime[1]), 'yyyy-MM-dd hh:mm:ss');
 | 
					 | 
				
			||||||
        const numDays = (new Date(endTime).getTime() - new Date(startTime).getTime()) / (24 * 3600 * 1000); if (numDays > 730) {
 | 
					 | 
				
			||||||
          this.$message({
 | 
					          this.$message({
 | 
				
			||||||
            message: '时间范围不能超过24个月',
 | 
					            message: '时间范围不能超过24个月',
 | 
				
			||||||
            type: 'warning'
 | 
					            type: 'warning'
 | 
				
			||||||
          });
 | 
					          });
 | 
				
			||||||
          this.listQuery.reportTime = [];
 | 
					          this.listQuery.reportTime = [];
 | 
				
			||||||
        } else {
 | 
					 | 
				
			||||||
          this.listQuery.reportTime[0] = startTime
 | 
					 | 
				
			||||||
          this.listQuery.reportTime[1] = endTime
 | 
					 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
      } else {
 | 
					 | 
				
			||||||
        console.log(this.listQuery.reportTime[0])
 | 
					 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    // handleTime() {
 | 
					 | 
				
			||||||
    //   this.$forceUpdate()
 | 
					 | 
				
			||||||
    //   // this.$nextTick(() => [
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    //   // ])
 | 
					 | 
				
			||||||
    // },
 | 
					 | 
				
			||||||
    // getCurrentYearFirst() {
 | 
					 | 
				
			||||||
    //   let date = new Date();
 | 
					 | 
				
			||||||
    //   date.setDate(1);
 | 
					 | 
				
			||||||
    //   date.setMonth(0);
 | 
					 | 
				
			||||||
    //   this.reportTime = date;
 | 
					 | 
				
			||||||
    //   this.startTimeStamp = this.timeFun(new Date(new Date().getFullYear(), 0, 1, 7, 0, 1).getTime()); //开始时间
 | 
					 | 
				
			||||||
    //   this.endTimeStamp = this.timeFun(new Date(new Date().getFullYear(), 11, 31, 7, 0, 0).getTime()); //结束时间
 | 
					 | 
				
			||||||
    //   this.listQuery.reportTime[0] = parseTime(new Date(new Date().getFullYear(), 0, 1, 7, 0, 1).getTime()) //+ ' 00:00:00' //new Date(this.startTimeStamp + ' 00:00:00').getTime() / 1000
 | 
					 | 
				
			||||||
    //   this.listQuery.reportTime[1] = parseTime(new Date(new Date().getFullYear(), 11, 31, 7, 0, 0).getTime()) //+ ' 23:59:59' //new Date(this.endTimeStamp + ' 23:59:59').getTime() / 100
 | 
					 | 
				
			||||||
    // },
 | 
					 | 
				
			||||||
    // changeTime(val) {
 | 
					 | 
				
			||||||
    //   if (val) {
 | 
					 | 
				
			||||||
    //     // let timeStamp = val.getTime(); //标准时间转为时间戳,毫秒级别
 | 
					 | 
				
			||||||
    //     // this.endTimeStamp = this.timeFun(new Date(val.getFullYear(), 11, 31, 7, 0, 0).getTime()); //开始时间
 | 
					 | 
				
			||||||
    //     // this.startTimeStamp = this.timeFun(new Date(val.getFullYear(), 0, 1, 7, 0, 1).getTime()); //结束时间
 | 
					 | 
				
			||||||
    //     // this.listQuery.reportTime[0] = parseTime(new Date(val.getFullYear(), 0, 1, 7, 0, 1).getTime()) //+ ' 00:00:00' //new Date(this.startTimeStamp + ' 00:00:00').getTime() / 1000
 | 
					 | 
				
			||||||
    //     // this.listQuery.reportTime[1] = parseTime(new Date(val.getFullYear(), 11, 31, 7, 0, 0).getTime()) //+ ' 23:59:59' //new Date(this.endTimeStamp + ' 23:59:59').getTime() / 1000
 | 
					 | 
				
			||||||
    //   } else {
 | 
					 | 
				
			||||||
    //     this.listQuery.reportTime = []
 | 
					 | 
				
			||||||
    //   }
 | 
					 | 
				
			||||||
    // },
 | 
					 | 
				
			||||||
    async getDict() {
 | 
					 | 
				
			||||||
      this.$refs.lineChart.initChart()
 | 
					 | 
				
			||||||
			// 产线列表
 | 
					 | 
				
			||||||
			// const res = await getCorePLList();
 | 
					 | 
				
			||||||
			// this.proLineList = res.data;
 | 
					 | 
				
			||||||
		},
 | 
					 | 
				
			||||||
    // 获取数据列表
 | 
					    // 获取数据列表
 | 
				
			||||||
    multipliedByHundred(str) {
 | 
					    multipliedByHundred(str) {
 | 
				
			||||||
      console.log(str);
 | 
					      console.log(str);
 | 
				
			||||||
@@ -574,36 +626,50 @@ export default {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    async getDataList() {
 | 
					    async getDataList() {
 | 
				
			||||||
    },
 | 
					      if (this.listQuery.date === 3) {
 | 
				
			||||||
    add0(m) {
 | 
					        if (this.listQuery.reportTime?.length > 0) {
 | 
				
			||||||
      return m < 10 ? '0' + m : m
 | 
					          this.listQuery.beginTime = this.listQuery.reportTime[0] ? this.listQuery.reportTime[0] : undefined
 | 
				
			||||||
    },
 | 
					          this.listQuery.endTime = this.listQuery.reportTime[1] ? this.listQuery.reportTime[1] : undefined
 | 
				
			||||||
    format(shijianchuo) {
 | 
					        }
 | 
				
			||||||
      //shijianchuo是整数,否则要parseInt转换
 | 
					      }
 | 
				
			||||||
      var time = moment(new Date(shijianchuo)).format('YYYY-MM-DD HH:mm:ss')
 | 
					      if (this.listQuery.date === 4) {
 | 
				
			||||||
      // console.log(time)
 | 
					        if (this.listQuery.reportTime?.length > 0) {
 | 
				
			||||||
      // var y = time.getFullYear();
 | 
					          this.listQuery.beginTime = this.start ? this.start : undefined
 | 
				
			||||||
      // var m = time.getMonth() + 1;
 | 
					          this.listQuery.endTime = this.end ? this.end : undefined
 | 
				
			||||||
      // var d = time.getDate();
 | 
					        }
 | 
				
			||||||
      // var h = time.getHours();
 | 
					      }
 | 
				
			||||||
      // var mm = time.getMinutes();
 | 
					      if (this.currentMenu === '碲化镉工厂') {
 | 
				
			||||||
      // var s = time.getSeconds();
 | 
					        await prodTargetDiPage(this.listQuery).then(res => {
 | 
				
			||||||
      return time
 | 
					          if (res.code === 0) {
 | 
				
			||||||
    },
 | 
					            this.tableData = res.data.records
 | 
				
			||||||
		//时间戳转为yy-mm-dd hh:mm:ss
 | 
					            this.tableData.forEach(item => {
 | 
				
			||||||
		timeFun(unixtimestamp) {
 | 
					                const year = item.targetYear ? item.targetYear + '年' : ''
 | 
				
			||||||
				var unixtimestamp = new Date(unixtimestamp);
 | 
					                const month = item.targetMonth ? item.targetMonth + '月' : ''
 | 
				
			||||||
				var year = 1900 + unixtimestamp.getYear();
 | 
					                item.tagertTime = year + month
 | 
				
			||||||
				var month = "0" + (unixtimestamp.getMonth() + 1);
 | 
					            })
 | 
				
			||||||
				var date = "0" + unixtimestamp.getDate();
 | 
					            this.listQuery.total = res.data.total
 | 
				
			||||||
				return year + "-" + month.substring(month.length - 2, month.length) + "-" + date.substring(date.length - 2, date.length)
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        await prodTargetToPage(this.listQuery).then(res => {
 | 
				
			||||||
 | 
					          if (res.code === 0) {
 | 
				
			||||||
 | 
					            this.tableData = res.data.records
 | 
				
			||||||
 | 
					            this.tableData.forEach(item => {
 | 
				
			||||||
 | 
					              const year = item.targetYear ? item.targetYear + '年' : ''
 | 
				
			||||||
 | 
					              const month = item.targetMonth ? item.targetMonth + '月' : ''
 | 
				
			||||||
 | 
					              item.tagertTime = year + month
 | 
				
			||||||
 | 
					            })
 | 
				
			||||||
 | 
					            this.listQuery.total = res.data.total
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
		buttonClick(val) {
 | 
							buttonClick(val) {
 | 
				
			||||||
			this.listQuery.reportTime = val.reportTime ? val.reportTime : undefined;
 | 
								this.listQuery.reportTime = val.reportTime ? val.reportTime : undefined;
 | 
				
			||||||
			switch (val.btnName) {
 | 
								switch (val.btnName) {
 | 
				
			||||||
				case 'search':
 | 
									case 'search':
 | 
				
			||||||
					this.listQuery.pageNo = 1;
 | 
										this.listQuery.current = 1;
 | 
				
			||||||
					this.listQuery.pageSize = 10;
 | 
										this.listQuery.size = 10;
 | 
				
			||||||
					this.getDataList();
 | 
										this.getDataList();
 | 
				
			||||||
					break;
 | 
										break;
 | 
				
			||||||
				case 'export':
 | 
									case 'export':
 | 
				
			||||||
@@ -615,38 +681,27 @@ export default {
 | 
				
			|||||||
		},
 | 
							},
 | 
				
			||||||
		/** 导出按钮操作 */
 | 
							/** 导出按钮操作 */
 | 
				
			||||||
    handleExport() {
 | 
					    handleExport() {
 | 
				
			||||||
      // 处理查询参数
 | 
					      const queryParams = this.listQuery;
 | 
				
			||||||
      // var xlsxParam = { raw: true };
 | 
					      queryParams.current = 1
 | 
				
			||||||
      // /* 从表生成工作簿对象 */
 | 
					      queryParams.size = 999
 | 
				
			||||||
      // import('xlsx').then(excel => {
 | 
					      if (this.facType === 0) {
 | 
				
			||||||
      //   var wb = excel.utils.table_to_book(
 | 
					        this.$modal.confirm('是否确认导出所有数据项?').then(() => {
 | 
				
			||||||
      //     document.querySelector("#exportTable"),
 | 
					          this.exportLoading = true;
 | 
				
			||||||
      //     xlsxParam
 | 
					          return exportDiTargetExcel(queryParams);
 | 
				
			||||||
      //   );
 | 
					        }).then(response => {
 | 
				
			||||||
      //   /* 获取二进制字符串作为输出 */
 | 
					          this.$download.excel(response, '碲化镉工厂生产目标数据.xls');
 | 
				
			||||||
      //   var wbout = excel.write(wb, {
 | 
					          this.exportLoading = false;
 | 
				
			||||||
      //     bookType: "xlsx",
 | 
					        }).catch(() => {});
 | 
				
			||||||
      //     bookSST: true,
 | 
					      } else {
 | 
				
			||||||
      //     type: "array",
 | 
					        this.$modal.confirm('是否确认导出所有数据项?').then(() => {
 | 
				
			||||||
      //   });
 | 
					          this.exportLoading = true;
 | 
				
			||||||
      //   try {
 | 
					          return exportToTargetExcel(queryParams);
 | 
				
			||||||
      //     FileSaver.saveAs(
 | 
					        }).then(response => {
 | 
				
			||||||
      //       //Blob 对象表示一个不可变、原始数据的类文件对象。
 | 
					          this.$download.excel(response, '铜铟镓硒工厂生产目标数据.xls');
 | 
				
			||||||
      //       //Blob 表示的不一定是JavaScript原生格式的数据。
 | 
					          this.exportLoading = false;
 | 
				
			||||||
      //       //File 接口基于Blob,继承了 blob 的功能并将其扩展使其支持用户系统上的文件。
 | 
					        }).catch(() => {});
 | 
				
			||||||
      //       //返回一个新创建的 Blob 对象,其内容由参数中给定的数组串联组成。
 | 
					      }
 | 
				
			||||||
      //       new Blob([wbout], { type: "application/octet-stream" }),
 | 
					    }
 | 
				
			||||||
      //       //设置导出文件名称
 | 
					 | 
				
			||||||
      //       "许昌安彩日原片生产汇总.xlsx"
 | 
					 | 
				
			||||||
      //     );
 | 
					 | 
				
			||||||
      //   } catch (e) {
 | 
					 | 
				
			||||||
      //     if (typeof console !== "undefined") console.log(e, wbout);
 | 
					 | 
				
			||||||
      //   }
 | 
					 | 
				
			||||||
      //   return wbout;
 | 
					 | 
				
			||||||
      //   //do something......
 | 
					 | 
				
			||||||
      // })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
@@ -667,7 +722,7 @@ export default {
 | 
				
			|||||||
  margin-top: 8px;
 | 
					  margin-top: 8px;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
.app-container {
 | 
					.app-container {
 | 
				
			||||||
  margin: 0 16px 0;
 | 
					  margin: 0;
 | 
				
			||||||
  background-color: #fff;
 | 
					  background-color: #fff;
 | 
				
			||||||
  border-radius: 4px;
 | 
					  border-radius: 4px;
 | 
				
			||||||
  padding: 16px 16px 0;
 | 
					  padding: 16px 16px 0;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										38
									
								
								src/views/system/components/statusBtn.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,38 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div>
 | 
				
			||||||
 | 
					    <span class="dot" :class="injectData.status === 1 ? 'red' : 'green'"></span>
 | 
				
			||||||
 | 
					    <span>{{ state }}</span>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "StatusBtn",
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    injectData: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      default: () => ({}),
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    state() {
 | 
				
			||||||
 | 
					      return this.injectData.status === 1 ? "停用" : "启用";
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style scoped>
 | 
				
			||||||
 | 
					.dot {
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  width: 6px;
 | 
				
			||||||
 | 
					  height: 6px;
 | 
				
			||||||
 | 
					  border-radius: 3px;
 | 
				
			||||||
 | 
					  vertical-align: middle;
 | 
				
			||||||
 | 
					  margin-right: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.green {
 | 
				
			||||||
 | 
					  background: #10dc76;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.red {
 | 
				
			||||||
 | 
					  background: #ff5656;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										38
									
								
								src/views/system/components/statusBtn2.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,38 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div>
 | 
				
			||||||
 | 
					    <span class="dot" :class="injectData.status === 1 ? 'red' : 'green'"></span>
 | 
				
			||||||
 | 
					    <span>{{ state }}</span>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "StatusBtn2",
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    injectData: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      default: () => ({}),
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    state() {
 | 
				
			||||||
 | 
					      return this.injectData.status === 1 ? "关闭" : "开启";
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style scoped>
 | 
				
			||||||
 | 
					.dot {
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  width: 6px;
 | 
				
			||||||
 | 
					  height: 6px;
 | 
				
			||||||
 | 
					  border-radius: 3px;
 | 
				
			||||||
 | 
					  vertical-align: middle;
 | 
				
			||||||
 | 
					  margin-right: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.green {
 | 
				
			||||||
 | 
					  background: #10dc76;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.red {
 | 
				
			||||||
 | 
					  background: #ff5656;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										41
									
								
								src/views/system/components/statusBtn3.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,41 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div>
 | 
				
			||||||
 | 
					    <span
 | 
				
			||||||
 | 
					      class="dot"
 | 
				
			||||||
 | 
					      :class="injectData.resultCode === 0 ? 'green' : 'red'"
 | 
				
			||||||
 | 
					    ></span>
 | 
				
			||||||
 | 
					    <span>{{ state }}</span>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "StatusBtn3",
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    injectData: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      default: () => ({}),
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    state() {
 | 
				
			||||||
 | 
					      return this.injectData.resultCode === 0 ? "成功" : "失败";
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style scoped>
 | 
				
			||||||
 | 
					.dot {
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  width: 6px;
 | 
				
			||||||
 | 
					  height: 6px;
 | 
				
			||||||
 | 
					  border-radius: 3px;
 | 
				
			||||||
 | 
					  vertical-align: middle;
 | 
				
			||||||
 | 
					  margin-right: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.green {
 | 
				
			||||||
 | 
					  background: #10dc76;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.red {
 | 
				
			||||||
 | 
					  background: #ff5656;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										38
									
								
								src/views/system/components/statusBtn4.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,38 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div>
 | 
				
			||||||
 | 
					    <span class="dot" :class="injectData.result === 0 ? 'green' : 'red'"></span>
 | 
				
			||||||
 | 
					    <span>{{ state }}</span>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "StatusBtn3",
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    injectData: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      default: () => ({}),
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    state() {
 | 
				
			||||||
 | 
					      return this.injectData.result === 0 ? "成功" : "失败";
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style scoped>
 | 
				
			||||||
 | 
					.dot {
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  width: 6px;
 | 
				
			||||||
 | 
					  height: 6px;
 | 
				
			||||||
 | 
					  border-radius: 3px;
 | 
				
			||||||
 | 
					  vertical-align: middle;
 | 
				
			||||||
 | 
					  margin-right: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.green {
 | 
				
			||||||
 | 
					  background: #10dc76;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.red {
 | 
				
			||||||
 | 
					  background: #ff5656;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										39
									
								
								src/views/system/components/statusBtn5.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,39 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <el-switch
 | 
				
			||||||
 | 
					    v-model="status"
 | 
				
			||||||
 | 
					    type="text"
 | 
				
			||||||
 | 
					    size="small"
 | 
				
			||||||
 | 
					    @change="changeHandler"
 | 
				
			||||||
 | 
					  />
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  props: {
 | 
				
			||||||
 | 
					    injectData: {
 | 
				
			||||||
 | 
					      type: Object,
 | 
				
			||||||
 | 
					      default: () => ({}),
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      status: false,
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.mapToState();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    mapToState() {
 | 
				
			||||||
 | 
					      this.status = this.injectData.status === 0 ? true : false;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    changeHandler() {
 | 
				
			||||||
 | 
					      let params = {};
 | 
				
			||||||
 | 
					      params.id = this.injectData.id;
 | 
				
			||||||
 | 
					      params.status = this.status ? "0" : "1";
 | 
				
			||||||
 | 
					      params.username = this.injectData.username;
 | 
				
			||||||
 | 
					      this.$emit("emitData", params);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
@@ -1,80 +1,144 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="app-container">
 | 
					  <div class="app-container">
 | 
				
			||||||
    <doc-alert title="系统日志" url="https://doc.iocoder.cn/system-log/" />
 | 
					    <!-- <doc-alert title="系统日志" url="https://doc.iocoder.cn/system-log/" /> -->
 | 
				
			||||||
    <!-- 搜索工作栏 -->
 | 
					    <!-- 搜索工作栏 -->
 | 
				
			||||||
    <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
 | 
					    <search-bar
 | 
				
			||||||
      <el-form-item label="登录地址" prop="userIp">
 | 
					      :formConfigs="formConfig"
 | 
				
			||||||
        <el-input v-model="queryParams.userIp" placeholder="请输入登录地址" clearable style="width: 240px;"
 | 
					      ref="searchBarForm"
 | 
				
			||||||
                  @keyup.enter.native="handleQuery"/>
 | 
					      @headBtnClick="buttonClick"
 | 
				
			||||||
      </el-form-item>
 | 
					    />
 | 
				
			||||||
      <el-form-item label="用户名称" prop="username">
 | 
					 | 
				
			||||||
        <el-input v-model="queryParams.username" placeholder="请输入用户名称" clearable style="width: 240px;"
 | 
					 | 
				
			||||||
                  @keyup.enter.native="handleQuery"/>
 | 
					 | 
				
			||||||
      </el-form-item>
 | 
					 | 
				
			||||||
      <el-form-item label="状态" prop="status">
 | 
					 | 
				
			||||||
        <el-select v-model="queryParams.status" placeholder="结果" clearable style="width: 240px">
 | 
					 | 
				
			||||||
          <el-option :key="true" label="成功" :value="true"/>
 | 
					 | 
				
			||||||
          <el-option :key="false" label="失败" :value="false"/>
 | 
					 | 
				
			||||||
        </el-select>
 | 
					 | 
				
			||||||
      </el-form-item>
 | 
					 | 
				
			||||||
      <el-form-item label="登录时间" prop="createTime">
 | 
					 | 
				
			||||||
        <el-date-picker v-model="queryParams.createTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange"
 | 
					 | 
				
			||||||
                        range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" />
 | 
					 | 
				
			||||||
      </el-form-item>
 | 
					 | 
				
			||||||
      <el-form-item>
 | 
					 | 
				
			||||||
        <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
 | 
					 | 
				
			||||||
        <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
 | 
					 | 
				
			||||||
      </el-form-item>
 | 
					 | 
				
			||||||
    </el-form>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <el-row :gutter="10" class="mb8">
 | 
					    <!-- 列表 -->
 | 
				
			||||||
      <el-col :span="1.5">
 | 
					    <base-table
 | 
				
			||||||
        <el-button type="warning" icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading"
 | 
					      :page="queryParams.pageNo"
 | 
				
			||||||
                   v-hasPermi="['system:login-log:export']">导出</el-button>
 | 
					      :limit="queryParams.pageSize"
 | 
				
			||||||
      </el-col>
 | 
					      :table-props="tableProps"
 | 
				
			||||||
      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
 | 
					      :table-data="list"
 | 
				
			||||||
    </el-row>
 | 
					      :max-height="tableH"
 | 
				
			||||||
 | 
					    />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <el-table v-loading="loading" :data="list">
 | 
					    <pagination
 | 
				
			||||||
      <el-table-column label="访问编号" align="center" prop="id" />
 | 
					      :page.sync="queryParams.pageNo"
 | 
				
			||||||
      <el-table-column label="日志类型" align="center" prop="logType" width="120">
 | 
					      :limit.sync="queryParams.pageSize"
 | 
				
			||||||
        <template v-slot="scope">
 | 
					      :total="total"
 | 
				
			||||||
          <dict-tag :type="DICT_TYPE.SYSTEM_LOGIN_TYPE" :value="scope.row.logType" />
 | 
					      @pagination="getList"
 | 
				
			||||||
        </template>
 | 
					    />
 | 
				
			||||||
      </el-table-column>
 | 
					 | 
				
			||||||
      <el-table-column label="用户名称" align="center" prop="username" />
 | 
					 | 
				
			||||||
      <el-table-column label="登录地址" align="center" prop="userIp" width="130" :show-overflow-tooltip="true" />
 | 
					 | 
				
			||||||
      <el-table-column label="userAgent" align="center" prop="userAgent" width="400" :show-overflow-tooltip="true" />
 | 
					 | 
				
			||||||
      <el-table-column label="结果" align="center" prop="status">
 | 
					 | 
				
			||||||
        <template v-slot="scope">
 | 
					 | 
				
			||||||
          <dict-tag :type="DICT_TYPE.SYSTEM_LOGIN_RESULT" :value="scope.row.result" />
 | 
					 | 
				
			||||||
        </template>
 | 
					 | 
				
			||||||
      </el-table-column>
 | 
					 | 
				
			||||||
      <el-table-column label="登录日期" align="center" prop="loginTime" width="180">
 | 
					 | 
				
			||||||
        <template v-slot="scope">
 | 
					 | 
				
			||||||
          <span>{{ parseTime(scope.row.createTime) }}</span>
 | 
					 | 
				
			||||||
        </template>
 | 
					 | 
				
			||||||
      </el-table-column>
 | 
					 | 
				
			||||||
    </el-table>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    <pagination v-show="total>0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize"
 | 
					 | 
				
			||||||
                @pagination="getList"/>
 | 
					 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import { list, exportLoginLog } from "@/api/system/loginlog";
 | 
					import { list, exportLoginLog } from "@/api/system/loginlog";
 | 
				
			||||||
 | 
					import tableHeightMixin from "@/mixins/tableHeightMixin";
 | 
				
			||||||
 | 
					import { parseTime } from "@/utils/ruoyi";
 | 
				
			||||||
 | 
					import { DICT_TYPE, publicFormatter } from "@/utils/dict";
 | 
				
			||||||
 | 
					import statusBtn4 from "./../components/statusBtn4.vue";
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "id",
 | 
				
			||||||
 | 
					    label: "访问编号",
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "logType",
 | 
				
			||||||
 | 
					    label: "日志类型",
 | 
				
			||||||
 | 
					    filter: publicFormatter(DICT_TYPE.SYSTEM_LOGIN_TYPE),
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "username",
 | 
				
			||||||
 | 
					    label: "用户名称",
 | 
				
			||||||
 | 
					    minWidth: 120,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "userIp",
 | 
				
			||||||
 | 
					    label: "登录地址",
 | 
				
			||||||
 | 
					    minWidth: 150,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "userAgent",
 | 
				
			||||||
 | 
					    label: "userAgent",
 | 
				
			||||||
 | 
					    minWidth: 300,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "result",
 | 
				
			||||||
 | 
					    label: "结果",
 | 
				
			||||||
 | 
					    minWidth: 80,
 | 
				
			||||||
 | 
					    // filter: publicFormatter(DICT_TYPE.SYSTEM_LOGIN_RESULT),
 | 
				
			||||||
 | 
					    subcomponent: statusBtn4,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "createTime",
 | 
				
			||||||
 | 
					    label: "登录日期",
 | 
				
			||||||
 | 
					    minWidth: 150,
 | 
				
			||||||
 | 
					    filter: parseTime,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "SystemLoginLog",
 | 
					  name: "SystemLoginLog",
 | 
				
			||||||
 | 
					  mixins: [tableHeightMixin],
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      // 遮罩层
 | 
					      formConfig: [
 | 
				
			||||||
      loading: true,
 | 
					        {
 | 
				
			||||||
 | 
					          type: "input",
 | 
				
			||||||
 | 
					          label: "登录地址",
 | 
				
			||||||
 | 
					          placeholder: "登录地址",
 | 
				
			||||||
 | 
					          param: "userIp",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "input",
 | 
				
			||||||
 | 
					          label: "用户名称",
 | 
				
			||||||
 | 
					          placeholder: "用户名称",
 | 
				
			||||||
 | 
					          param: "username",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "select",
 | 
				
			||||||
 | 
					          label: "状态",
 | 
				
			||||||
 | 
					          selectOptions: [
 | 
				
			||||||
 | 
					            { id: true, name: "成功" },
 | 
				
			||||||
 | 
					            { id: false, name: "失败" },
 | 
				
			||||||
 | 
					          ],
 | 
				
			||||||
 | 
					          param: "status",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "datePicker",
 | 
				
			||||||
 | 
					          label: "登录时间",
 | 
				
			||||||
 | 
					          dateType: "daterange",
 | 
				
			||||||
 | 
					          format: "yyyy-MM-dd",
 | 
				
			||||||
 | 
					          valueFormat: "yyyy-MM-dd HH:mm:ss",
 | 
				
			||||||
 | 
					          rangeSeparator: "-",
 | 
				
			||||||
 | 
					          startPlaceholder: "开始日期",
 | 
				
			||||||
 | 
					          endPlaceholder: "结束日期",
 | 
				
			||||||
 | 
					          param: "createTime",
 | 
				
			||||||
 | 
					          defaultSelect: [],
 | 
				
			||||||
 | 
					          defaultTime: ["00:00:00", "23:59:59"],
 | 
				
			||||||
 | 
					          width: 250,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "button",
 | 
				
			||||||
 | 
					          btnName: "查询",
 | 
				
			||||||
 | 
					          name: "search",
 | 
				
			||||||
 | 
					          color: "primary",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: this.$auth.hasPermi("system:login-log:export")
 | 
				
			||||||
 | 
					            ? "separate"
 | 
				
			||||||
 | 
					            : "",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: this.$auth.hasPermi("system:login-log:export") ? "button" : "",
 | 
				
			||||||
 | 
					          btnName: "导出",
 | 
				
			||||||
 | 
					          name: "export",
 | 
				
			||||||
 | 
					          color: "primary",
 | 
				
			||||||
 | 
					          plain: true,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					      tableProps,
 | 
				
			||||||
      // 导出遮罩层
 | 
					      // 导出遮罩层
 | 
				
			||||||
      exportLoading: false,
 | 
					      exportLoading: false,
 | 
				
			||||||
      // 显示搜索条件
 | 
					 | 
				
			||||||
      showSearch: true,
 | 
					 | 
				
			||||||
      // 总条数
 | 
					      // 总条数
 | 
				
			||||||
      total: 0,
 | 
					      total: 0,
 | 
				
			||||||
      // 表格数据
 | 
					      // 表格数据
 | 
				
			||||||
@@ -82,12 +146,12 @@ export default {
 | 
				
			|||||||
      // 查询参数
 | 
					      // 查询参数
 | 
				
			||||||
      queryParams: {
 | 
					      queryParams: {
 | 
				
			||||||
        pageNo: 1,
 | 
					        pageNo: 1,
 | 
				
			||||||
        pageSize: 10,
 | 
					        pageSize: 20,
 | 
				
			||||||
        userIp: undefined,
 | 
					        userIp: undefined,
 | 
				
			||||||
        username: undefined,
 | 
					        username: undefined,
 | 
				
			||||||
        status: undefined,
 | 
					        status: undefined,
 | 
				
			||||||
        createTime: []
 | 
					        createTime: [],
 | 
				
			||||||
      }
 | 
					      },
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  created() {
 | 
					  created() {
 | 
				
			||||||
@@ -96,39 +160,50 @@ export default {
 | 
				
			|||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    /** 查询登录日志列表 */
 | 
					    /** 查询登录日志列表 */
 | 
				
			||||||
    getList() {
 | 
					    getList() {
 | 
				
			||||||
      this.loading = true;
 | 
					      list(this.queryParams).then((response) => {
 | 
				
			||||||
      list(this.queryParams).then(response => {
 | 
					 | 
				
			||||||
        this.list = response.data.list;
 | 
					        this.list = response.data.list;
 | 
				
			||||||
        this.total = response.data.total;
 | 
					        this.total = response.data.total;
 | 
				
			||||||
          this.loading = false;
 | 
					      });
 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      );
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 搜索按钮操作 */
 | 
					    buttonClick(val) {
 | 
				
			||||||
    handleQuery() {
 | 
					      this.queryParams.userIp = val.userIp;
 | 
				
			||||||
 | 
					      this.queryParams.username = val.username;
 | 
				
			||||||
 | 
					      this.queryParams.status = val.status;
 | 
				
			||||||
 | 
					      this.queryParams.createTime = val.createTime;
 | 
				
			||||||
 | 
					      if (val.btnName === "search") {
 | 
				
			||||||
        this.queryParams.pageNo = 1;
 | 
					        this.queryParams.pageNo = 1;
 | 
				
			||||||
        this.getList();
 | 
					        this.getList();
 | 
				
			||||||
    },
 | 
					      } else {
 | 
				
			||||||
    /** 重置按钮操作 */
 | 
					        this.handleExport();
 | 
				
			||||||
    resetQuery() {
 | 
					      }
 | 
				
			||||||
      this.resetForm("queryForm");
 | 
					 | 
				
			||||||
      this.handleQuery();
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 导出按钮操作 */
 | 
					    /** 导出按钮操作 */
 | 
				
			||||||
    handleExport() {
 | 
					    handleExport() {
 | 
				
			||||||
      this.$modal.confirm('是否确认导出所有操作日志数据项?').then(() => {
 | 
					      this.$modal
 | 
				
			||||||
 | 
					        .confirm("是否确认导出所有操作日志数据项?")
 | 
				
			||||||
 | 
					        .then(() => {
 | 
				
			||||||
          // 处理查询参数
 | 
					          // 处理查询参数
 | 
				
			||||||
          let params = {...this.queryParams};
 | 
					          let params = { ...this.queryParams };
 | 
				
			||||||
          params.pageNo = undefined;
 | 
					          params.pageNo = undefined;
 | 
				
			||||||
          params.pageSize = undefined;
 | 
					          params.pageSize = undefined;
 | 
				
			||||||
          this.exportLoading = true;
 | 
					          this.exportLoading = true;
 | 
				
			||||||
          return exportLoginLog(params);
 | 
					          return exportLoginLog(params);
 | 
				
			||||||
        }).then(response => {
 | 
					        })
 | 
				
			||||||
          this.$download.excel(response, '登录日志.xls');
 | 
					        .then((response) => {
 | 
				
			||||||
 | 
					          this.$download.excel(response, "登录日志.xls");
 | 
				
			||||||
          this.exportLoading = false;
 | 
					          this.exportLoading = false;
 | 
				
			||||||
      }).catch(() => {});
 | 
					        })
 | 
				
			||||||
    }
 | 
					        .catch(() => {});
 | 
				
			||||||
  }
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.app-container {
 | 
				
			||||||
 | 
					  width: 100%;
 | 
				
			||||||
 | 
					  height: calc(100vh - 120px - 8px);
 | 
				
			||||||
 | 
					  background-color: #fff;
 | 
				
			||||||
 | 
					  border-radius: 8px;
 | 
				
			||||||
 | 
					  padding: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,93 +1,199 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="app-container">
 | 
					  <div class="app-container">
 | 
				
			||||||
    <doc-alert title="功能权限" url="https://doc.iocoder.cn/resource-permission" />
 | 
					    <!-- <doc-alert
 | 
				
			||||||
    <doc-alert title="菜单路由" url="https://doc.iocoder.cn/vue2/route/" />
 | 
					      title="功能权限"
 | 
				
			||||||
 | 
					      url="https://doc.iocoder.cn/resource-permission"
 | 
				
			||||||
 | 
					    />
 | 
				
			||||||
 | 
					    <doc-alert title="菜单路由" url="https://doc.iocoder.cn/vue2/route/" /> -->
 | 
				
			||||||
    <!-- 搜索工作栏 -->
 | 
					    <!-- 搜索工作栏 -->
 | 
				
			||||||
    <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch">
 | 
					    <search-bar
 | 
				
			||||||
      <el-form-item label="菜单名称" prop="name">
 | 
					      :formConfigs="formConfig"
 | 
				
			||||||
        <el-input v-model="queryParams.name" placeholder="请输入菜单名称" clearable @keyup.enter.native="handleQuery"/>
 | 
					      ref="searchBarForm"
 | 
				
			||||||
      </el-form-item>
 | 
					      @headBtnClick="buttonClick"
 | 
				
			||||||
      <el-form-item label="状态" prop="status">
 | 
					    />
 | 
				
			||||||
        <el-select v-model="queryParams.status" placeholder="菜单状态" clearable>
 | 
					 | 
				
			||||||
          <el-option v-for="dict in statusDictDatas" :key="parseInt(dict.value)" :label="dict.label" :value="parseInt(dict.value)"/>
 | 
					 | 
				
			||||||
        </el-select>
 | 
					 | 
				
			||||||
      </el-form-item>
 | 
					 | 
				
			||||||
      <el-form-item>
 | 
					 | 
				
			||||||
        <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
 | 
					 | 
				
			||||||
        <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
 | 
					 | 
				
			||||||
      </el-form-item>
 | 
					 | 
				
			||||||
    </el-form>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <el-row :gutter="10" class="mb8">
 | 
					    <!-- 列表 -->
 | 
				
			||||||
 | 
					    <base-table
 | 
				
			||||||
 | 
					      v-if="refreshTable"
 | 
				
			||||||
 | 
					      v-loading="loading"
 | 
				
			||||||
 | 
					      :table-props="tableProps"
 | 
				
			||||||
 | 
					      :table-data="menuList"
 | 
				
			||||||
 | 
					      :row-key="'id'"
 | 
				
			||||||
 | 
					      :default-expand-all="isExpandAll"
 | 
				
			||||||
 | 
					      :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
 | 
				
			||||||
 | 
					      :max-height="tableH"
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
 | 
					      <method-btn
 | 
				
			||||||
 | 
					        v-if="tableBtn.length"
 | 
				
			||||||
 | 
					        slot="handleBtn"
 | 
				
			||||||
 | 
					        :width="120"
 | 
				
			||||||
 | 
					        label="操作"
 | 
				
			||||||
 | 
					        :method-list="tableBtn"
 | 
				
			||||||
 | 
					        @clickBtn="handleClick"
 | 
				
			||||||
 | 
					      />
 | 
				
			||||||
 | 
					    </base-table>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    <!-- <el-row :gutter="10" class="mb8">
 | 
				
			||||||
      <el-col :span="1.5">
 | 
					      <el-col :span="1.5">
 | 
				
			||||||
        <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
 | 
					        <el-button
 | 
				
			||||||
                   v-hasPermi="['system:menu:create']">新增</el-button>
 | 
					          type="primary"
 | 
				
			||||||
 | 
					          plain
 | 
				
			||||||
 | 
					          icon="el-icon-plus"
 | 
				
			||||||
 | 
					          size="mini"
 | 
				
			||||||
 | 
					          @click="handleAdd"
 | 
				
			||||||
 | 
					          v-hasPermi="['system:menu:create']"
 | 
				
			||||||
 | 
					          >新增</el-button
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
      </el-col>
 | 
					      </el-col>
 | 
				
			||||||
      <el-col :span="1.5">
 | 
					      <el-col :span="1.5">
 | 
				
			||||||
        <el-button type="info" plain icon="el-icon-sort" size="mini" @click="toggleExpandAll">展开/折叠</el-button>
 | 
					        <el-button
 | 
				
			||||||
 | 
					          type="info"
 | 
				
			||||||
 | 
					          plain
 | 
				
			||||||
 | 
					          icon="el-icon-sort"
 | 
				
			||||||
 | 
					          size="mini"
 | 
				
			||||||
 | 
					          @click="toggleExpandAll"
 | 
				
			||||||
 | 
					          >展开/折叠</el-button
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
      </el-col>
 | 
					      </el-col>
 | 
				
			||||||
      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
 | 
					      <right-toolbar
 | 
				
			||||||
    </el-row>
 | 
					        :showSearch.sync="showSearch"
 | 
				
			||||||
 | 
					        @queryTable="getList"
 | 
				
			||||||
 | 
					      ></right-toolbar>
 | 
				
			||||||
 | 
					    </el-row> -->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <el-table v-if="refreshTable" v-loading="loading" :data="menuList" row-key="id" :default-expand-all="isExpandAll"
 | 
					    <!-- <el-table
 | 
				
			||||||
              :tree-props="{children: 'children', hasChildren: 'hasChildren'}">
 | 
					      v-if="refreshTable"
 | 
				
			||||||
      <el-table-column prop="name" label="菜单名称" :show-overflow-tooltip="true" width="250"></el-table-column>
 | 
					      v-loading="loading"
 | 
				
			||||||
 | 
					      :data="menuList"
 | 
				
			||||||
 | 
					      row-key="id"
 | 
				
			||||||
 | 
					      :default-expand-all="isExpandAll"
 | 
				
			||||||
 | 
					      :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
 | 
					      <el-table-column
 | 
				
			||||||
 | 
					        prop="name"
 | 
				
			||||||
 | 
					        label="菜单名称"
 | 
				
			||||||
 | 
					        :show-overflow-tooltip="true"
 | 
				
			||||||
 | 
					        width="250"
 | 
				
			||||||
 | 
					      ></el-table-column>
 | 
				
			||||||
      <el-table-column prop="icon" label="图标" align="center" width="100">
 | 
					      <el-table-column prop="icon" label="图标" align="center" width="100">
 | 
				
			||||||
        <template v-slot="scope">
 | 
					        <template v-slot="scope">
 | 
				
			||||||
          <svg-icon :icon-class="scope.row.icon" />
 | 
					          <svg-icon :icon-class="scope.row.icon" />
 | 
				
			||||||
        </template>
 | 
					        </template>
 | 
				
			||||||
      </el-table-column>
 | 
					      </el-table-column>
 | 
				
			||||||
      <el-table-column prop="sort" label="排序" width="60"></el-table-column>
 | 
					      <el-table-column prop="sort" label="排序" width="60"></el-table-column>
 | 
				
			||||||
      <el-table-column prop="permission" label="权限标识" :show-overflow-tooltip="true" />
 | 
					      <el-table-column
 | 
				
			||||||
      <el-table-column prop="component" label="组件路径" :show-overflow-tooltip="true" />
 | 
					        prop="permission"
 | 
				
			||||||
      <el-table-column prop="componentName" label="组件名称" :show-overflow-tooltip="true" />
 | 
					        label="权限标识"
 | 
				
			||||||
 | 
					        :show-overflow-tooltip="true"
 | 
				
			||||||
 | 
					      />
 | 
				
			||||||
 | 
					      <el-table-column
 | 
				
			||||||
 | 
					        prop="component"
 | 
				
			||||||
 | 
					        label="组件路径"
 | 
				
			||||||
 | 
					        :show-overflow-tooltip="true"
 | 
				
			||||||
 | 
					      />
 | 
				
			||||||
 | 
					      <el-table-column
 | 
				
			||||||
 | 
					        prop="componentName"
 | 
				
			||||||
 | 
					        label="组件名称"
 | 
				
			||||||
 | 
					        :show-overflow-tooltip="true"
 | 
				
			||||||
 | 
					      />
 | 
				
			||||||
      <el-table-column prop="status" label="状态" width="80">
 | 
					      <el-table-column prop="status" label="状态" width="80">
 | 
				
			||||||
        <template v-slot="scope">
 | 
					        <template v-slot="scope">
 | 
				
			||||||
          <dict-tag :type="DICT_TYPE.COMMON_STATUS" :value="scope.row.status"/>
 | 
					          <dict-tag :type="DICT_TYPE.COMMON_STATUS" :value="scope.row.status" />
 | 
				
			||||||
        </template>
 | 
					        </template>
 | 
				
			||||||
      </el-table-column>
 | 
					      </el-table-column>
 | 
				
			||||||
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
 | 
					      <el-table-column
 | 
				
			||||||
 | 
					        label="操作"
 | 
				
			||||||
 | 
					        align="center"
 | 
				
			||||||
 | 
					        class-name="small-padding fixed-width"
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
        <template v-slot="scope">
 | 
					        <template v-slot="scope">
 | 
				
			||||||
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
 | 
					          <el-button
 | 
				
			||||||
                     v-hasPermi="['system:menu:update']">修改</el-button>
 | 
					            size="mini"
 | 
				
			||||||
          <el-button size="mini" type="text" icon="el-icon-plus" @click="handleAdd(scope.row)"
 | 
					            type="text"
 | 
				
			||||||
                     v-hasPermi="['system:menu:create']">新增</el-button>
 | 
					            icon="el-icon-edit"
 | 
				
			||||||
          <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
 | 
					            @click="handleUpdate(scope.row)"
 | 
				
			||||||
                     v-hasPermi="['system:menu:delete']">删除</el-button>
 | 
					            v-hasPermi="['system:menu:update']"
 | 
				
			||||||
 | 
					            >修改</el-button
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					          <el-button
 | 
				
			||||||
 | 
					            size="mini"
 | 
				
			||||||
 | 
					            type="text"
 | 
				
			||||||
 | 
					            icon="el-icon-plus"
 | 
				
			||||||
 | 
					            @click="handleAdd(scope.row)"
 | 
				
			||||||
 | 
					            v-hasPermi="['system:menu:create']"
 | 
				
			||||||
 | 
					            >新增</el-button
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					          <el-button
 | 
				
			||||||
 | 
					            size="mini"
 | 
				
			||||||
 | 
					            type="text"
 | 
				
			||||||
 | 
					            icon="el-icon-delete"
 | 
				
			||||||
 | 
					            @click="handleDelete(scope.row)"
 | 
				
			||||||
 | 
					            v-hasPermi="['system:menu:delete']"
 | 
				
			||||||
 | 
					            >删除</el-button
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
        </template>
 | 
					        </template>
 | 
				
			||||||
      </el-table-column>
 | 
					      </el-table-column>
 | 
				
			||||||
    </el-table>
 | 
					    </el-table> -->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- 添加或修改菜单对话框 -->
 | 
					    <!-- 添加或修改菜单对话框 -->
 | 
				
			||||||
    <el-dialog :title="title" :visible.sync="open" width="800px" append-to-body>
 | 
					    <base-dialog :dialogTitle="title" :dialogVisible="open" width="50%">
 | 
				
			||||||
      <el-form ref="form" :model="form" :rules="rules" label-width="100px">
 | 
					      <el-form ref="form" :model="form" :rules="rules" label-width="100px">
 | 
				
			||||||
        <el-row>
 | 
					        <el-row>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <el-col :span="24">
 | 
				
			||||||
            <el-form-item label="上级菜单">
 | 
					            <el-form-item label="上级菜单">
 | 
				
			||||||
              <treeselect v-model="form.parentId" :options="menuOptions" :normalizer="normalizer" :show-count="true"
 | 
					              <treeselect
 | 
				
			||||||
                          placeholder="选择上级菜单"/>
 | 
					                v-model="form.parentId"
 | 
				
			||||||
 | 
					                :options="menuOptions"
 | 
				
			||||||
 | 
					                :normalizer="normalizer"
 | 
				
			||||||
 | 
					                :show-count="true"
 | 
				
			||||||
 | 
					                placeholder="选择上级菜单"
 | 
				
			||||||
 | 
					              />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <el-col :span="24">
 | 
				
			||||||
            <el-form-item label="菜单类型" prop="type">
 | 
					            <el-form-item label="菜单类型" prop="type">
 | 
				
			||||||
              <el-radio-group v-model="form.type">
 | 
					              <el-radio-group v-model="form.type">
 | 
				
			||||||
                <el-radio v-for="dict in menuTypeDictDatas" :key="parseInt(dict.value)" :label="parseInt(dict.value)">
 | 
					                <el-radio
 | 
				
			||||||
                  {{dict.label}}</el-radio>
 | 
					                  v-for="dict in menuTypeDictDatas"
 | 
				
			||||||
 | 
					                  :key="parseInt(dict.value)"
 | 
				
			||||||
 | 
					                  :label="parseInt(dict.value)"
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
 | 
					                  {{ dict.label }}</el-radio
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
              </el-radio-group>
 | 
					              </el-radio-group>
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <!-- <el-col :span="24">
 | 
				
			||||||
            <el-form-item v-if="form.type !== 3" label="菜单图标">
 | 
					            <el-form-item v-if="form.type !== 3" label="菜单图标">
 | 
				
			||||||
              <el-popover placement="bottom-start" width="460" trigger="click" @show="$refs['iconSelect'].reset()">
 | 
					              <el-popover
 | 
				
			||||||
 | 
					                placement="bottom-start"
 | 
				
			||||||
 | 
					                width="460"
 | 
				
			||||||
 | 
					                trigger="click"
 | 
				
			||||||
 | 
					                @show="$refs['iconSelect'].reset()"
 | 
				
			||||||
 | 
					              >
 | 
				
			||||||
                <IconSelect ref="iconSelect" @selected="selected" />
 | 
					                <IconSelect ref="iconSelect" @selected="selected" />
 | 
				
			||||||
                <el-input slot="reference" v-model="form.icon" placeholder="点击选择图标" readonly>
 | 
					                <el-input
 | 
				
			||||||
                  <svg-icon v-if="form.icon" slot="prefix" :icon-class="form.icon" class="el-input__icon"
 | 
					                  slot="reference"
 | 
				
			||||||
                            style="height: 32px;width: 16px;"/>
 | 
					                  v-model="form.icon"
 | 
				
			||||||
                  <i v-else slot="prefix" class="el-icon-search el-input__icon" />
 | 
					                  placeholder="点击选择图标"
 | 
				
			||||||
 | 
					                  readonly
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
 | 
					                  <svg-icon
 | 
				
			||||||
 | 
					                    v-if="form.icon"
 | 
				
			||||||
 | 
					                    slot="prefix"
 | 
				
			||||||
 | 
					                    :icon-class="form.icon"
 | 
				
			||||||
 | 
					                    class="el-input__icon"
 | 
				
			||||||
 | 
					                    style="height: 32px; width: 16px"
 | 
				
			||||||
 | 
					                  />
 | 
				
			||||||
 | 
					                  <i
 | 
				
			||||||
 | 
					                    v-else
 | 
				
			||||||
 | 
					                    slot="prefix"
 | 
				
			||||||
 | 
					                    class="el-icon-search el-input__icon"
 | 
				
			||||||
 | 
					                  />
 | 
				
			||||||
                </el-input>
 | 
					                </el-input>
 | 
				
			||||||
              </el-popover>
 | 
					              </el-popover>
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col> -->
 | 
				
			||||||
          <el-col :span="12">
 | 
					          <el-col :span="12">
 | 
				
			||||||
            <el-form-item label="菜单名称" prop="name">
 | 
					            <el-form-item label="菜单名称" prop="name">
 | 
				
			||||||
              <el-input v-model="form.name" placeholder="请输入菜单名称" />
 | 
					              <el-input v-model="form.name" placeholder="请输入菜单名称" />
 | 
				
			||||||
@@ -95,13 +201,20 @@
 | 
				
			|||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="12">
 | 
					          <el-col :span="12">
 | 
				
			||||||
            <el-form-item label="显示排序" prop="sort">
 | 
					            <el-form-item label="显示排序" prop="sort">
 | 
				
			||||||
              <el-input-number v-model="form.sort" controls-position="right" :min="0" />
 | 
					              <el-input-number
 | 
				
			||||||
 | 
					                v-model="form.sort"
 | 
				
			||||||
 | 
					                controls-position="right"
 | 
				
			||||||
 | 
					                :min="0"
 | 
				
			||||||
 | 
					              />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="12">
 | 
					          <el-col :span="12">
 | 
				
			||||||
            <el-form-item v-if="form.type !== 3" label="路由地址" prop="path">
 | 
					            <el-form-item v-if="form.type !== 3" label="路由地址" prop="path">
 | 
				
			||||||
              <span slot="label">
 | 
					              <span slot="label">
 | 
				
			||||||
                <el-tooltip content="访问的路由地址,如:`user`。如需外网地址时,则以 `http(s)://` 开头" placement="top">
 | 
					                <el-tooltip
 | 
				
			||||||
 | 
					                  content="访问的路由地址,如:`user`。如需外网地址时,则以 `http(s)://` 开头"
 | 
				
			||||||
 | 
					                  placement="top"
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
                  <i class="el-icon-question" />
 | 
					                  <i class="el-icon-question" />
 | 
				
			||||||
                </el-tooltip>
 | 
					                </el-tooltip>
 | 
				
			||||||
                路由地址
 | 
					                路由地址
 | 
				
			||||||
@@ -112,42 +225,65 @@
 | 
				
			|||||||
          <el-col :span="12">
 | 
					          <el-col :span="12">
 | 
				
			||||||
            <el-form-item v-if="form.type !== 1" label="权限标识">
 | 
					            <el-form-item v-if="form.type !== 1" label="权限标识">
 | 
				
			||||||
              <span slot="label">
 | 
					              <span slot="label">
 | 
				
			||||||
                <el-tooltip content="Controller 方法上的权限字符,如:@PreAuthorize(`@ss.hasPermission('system:user:list')`)" placement="top">
 | 
					                <el-tooltip
 | 
				
			||||||
 | 
					                  content="Controller 方法上的权限字符,如:@PreAuthorize(`@ss.hasPermission('system:user:list')`)"
 | 
				
			||||||
 | 
					                  placement="top"
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
                  <i class="el-icon-question" />
 | 
					                  <i class="el-icon-question" />
 | 
				
			||||||
                </el-tooltip>
 | 
					                </el-tooltip>
 | 
				
			||||||
                权限字符
 | 
					                权限字符
 | 
				
			||||||
              </span>
 | 
					              </span>
 | 
				
			||||||
							<el-input v-model="form.permission" placeholder="请权限标识" maxlength="50" />
 | 
					              <el-input
 | 
				
			||||||
 | 
					                v-model="form.permission"
 | 
				
			||||||
 | 
					                placeholder="请权限标识"
 | 
				
			||||||
 | 
					                maxlength="50"
 | 
				
			||||||
 | 
					              />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="12" v-if="form.type === 2">
 | 
					          <el-col :span="12" v-if="form.type === 2">
 | 
				
			||||||
            <el-form-item label="组件路径" prop="component">
 | 
					            <el-form-item label="组件路径" prop="component">
 | 
				
			||||||
              <el-input v-model="form.component" placeholder="例如说:system/user/index" />
 | 
					              <el-input
 | 
				
			||||||
 | 
					                v-model="form.component"
 | 
				
			||||||
 | 
					                placeholder="例如说:system/user/index"
 | 
				
			||||||
 | 
					              />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="12" v-if="form.type === 2">
 | 
					          <el-col :span="12" v-if="form.type === 2">
 | 
				
			||||||
            <el-form-item label="组件名称" prop="componentName">
 | 
					            <el-form-item label="组件名称" prop="componentName">
 | 
				
			||||||
							<el-input v-model="form.componentName" placeholder="例如说:SystemUser" />
 | 
					              <el-input
 | 
				
			||||||
 | 
					                v-model="form.componentName"
 | 
				
			||||||
 | 
					                placeholder="例如说:SystemUser"
 | 
				
			||||||
 | 
					              />
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="12">
 | 
					          <el-col :span="12">
 | 
				
			||||||
            <el-form-item label="菜单状态" prop="status">
 | 
					            <el-form-item label="菜单状态" prop="status">
 | 
				
			||||||
              <span slot="label">
 | 
					              <span slot="label">
 | 
				
			||||||
                <el-tooltip content="选择停用时,路由将不会出现在侧边栏,也不能被访问" placement="top">
 | 
					                <el-tooltip
 | 
				
			||||||
 | 
					                  content="选择停用时,路由将不会出现在侧边栏,也不能被访问"
 | 
				
			||||||
 | 
					                  placement="top"
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
                  <i class="el-icon-question" />
 | 
					                  <i class="el-icon-question" />
 | 
				
			||||||
                </el-tooltip>
 | 
					                </el-tooltip>
 | 
				
			||||||
                菜单状态
 | 
					                菜单状态
 | 
				
			||||||
              </span>
 | 
					              </span>
 | 
				
			||||||
              <el-radio-group v-model="form.status">
 | 
					              <el-radio-group v-model="form.status">
 | 
				
			||||||
                <el-radio v-for="dict in this.getDictDatas(DICT_TYPE.COMMON_STATUS)"
 | 
					                <el-radio
 | 
				
			||||||
                          :key="dict.value" :label="parseInt(dict.value)">{{dict.label}}</el-radio>
 | 
					                  v-for="dict in this.getDictDatas(DICT_TYPE.COMMON_STATUS)"
 | 
				
			||||||
 | 
					                  :key="dict.value"
 | 
				
			||||||
 | 
					                  :label="parseInt(dict.value)"
 | 
				
			||||||
 | 
					                  >{{ dict.label }}</el-radio
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
              </el-radio-group>
 | 
					              </el-radio-group>
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="12">
 | 
					          <el-col :span="12">
 | 
				
			||||||
            <el-form-item v-if="form.type !== 3" label="显示状态">
 | 
					            <el-form-item v-if="form.type !== 3" label="显示状态">
 | 
				
			||||||
              <span slot="label">
 | 
					              <span slot="label">
 | 
				
			||||||
                <el-tooltip content="选择隐藏时,路由将不会出现在侧边栏,但仍然可以访问" placement="top">
 | 
					                <el-tooltip
 | 
				
			||||||
 | 
					                  content="选择隐藏时,路由将不会出现在侧边栏,但仍然可以访问"
 | 
				
			||||||
 | 
					                  placement="top"
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
                  <i class="el-icon-question" />
 | 
					                  <i class="el-icon-question" />
 | 
				
			||||||
                </el-tooltip>
 | 
					                </el-tooltip>
 | 
				
			||||||
                是否显示
 | 
					                是否显示
 | 
				
			||||||
@@ -161,7 +297,10 @@
 | 
				
			|||||||
          <el-col :span="12">
 | 
					          <el-col :span="12">
 | 
				
			||||||
            <el-form-item v-if="form.type !== 3" label="总是显示">
 | 
					            <el-form-item v-if="form.type !== 3" label="总是显示">
 | 
				
			||||||
              <span slot="label">
 | 
					              <span slot="label">
 | 
				
			||||||
                <el-tooltip content="选择不是时,当该菜单只有一个子菜单时,不展示自己,直接展示子菜单" placement="top">
 | 
					                <el-tooltip
 | 
				
			||||||
 | 
					                  content="选择不是时,当该菜单只有一个子菜单时,不展示自己,直接展示子菜单"
 | 
				
			||||||
 | 
					                  placement="top"
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
                  <i class="el-icon-question" />
 | 
					                  <i class="el-icon-question" />
 | 
				
			||||||
                </el-tooltip>
 | 
					                </el-tooltip>
 | 
				
			||||||
                总是显示
 | 
					                总是显示
 | 
				
			||||||
@@ -175,7 +314,10 @@
 | 
				
			|||||||
          <el-col :span="12">
 | 
					          <el-col :span="12">
 | 
				
			||||||
            <el-form-item v-if="form.type === 2" label="是否缓存">
 | 
					            <el-form-item v-if="form.type === 2" label="是否缓存">
 | 
				
			||||||
              <span slot="label">
 | 
					              <span slot="label">
 | 
				
			||||||
                <el-tooltip content="选择缓存时,则会被 `keep-alive` 缓存,必须填写「组件名称」字段" placement="top">
 | 
					                <el-tooltip
 | 
				
			||||||
 | 
					                  content="选择缓存时,则会被 `keep-alive` 缓存,必须填写「组件名称」字段"
 | 
				
			||||||
 | 
					                  placement="top"
 | 
				
			||||||
 | 
					                >
 | 
				
			||||||
                  <i class="el-icon-question" />
 | 
					                  <i class="el-icon-question" />
 | 
				
			||||||
                </el-tooltip>
 | 
					                </el-tooltip>
 | 
				
			||||||
                是否缓存
 | 
					                是否缓存
 | 
				
			||||||
@@ -192,25 +334,130 @@
 | 
				
			|||||||
        <el-button type="primary" @click="submitForm">确 定</el-button>
 | 
					        <el-button type="primary" @click="submitForm">确 定</el-button>
 | 
				
			||||||
        <el-button @click="cancel">取 消</el-button>
 | 
					        <el-button @click="cancel">取 消</el-button>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </el-dialog>
 | 
					    </base-dialog>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import { listMenu, getMenu, delMenu, addMenu, updateMenu } from "@/api/system/menu";
 | 
					import {
 | 
				
			||||||
 | 
					  listMenu,
 | 
				
			||||||
 | 
					  getMenu,
 | 
				
			||||||
 | 
					  delMenu,
 | 
				
			||||||
 | 
					  addMenu,
 | 
				
			||||||
 | 
					  updateMenu,
 | 
				
			||||||
 | 
					} from "@/api/system/menu";
 | 
				
			||||||
import Treeselect from "@riophae/vue-treeselect";
 | 
					import Treeselect from "@riophae/vue-treeselect";
 | 
				
			||||||
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
 | 
					import "@riophae/vue-treeselect/dist/vue-treeselect.css";
 | 
				
			||||||
import IconSelect from "@/components/IconSelect";
 | 
					import IconSelect from "@/components/IconSelect";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import { SystemMenuTypeEnum, CommonStatusEnum } from '@/utils/constants'
 | 
					import { SystemMenuTypeEnum, CommonStatusEnum } from "@/utils/constants";
 | 
				
			||||||
import { getDictDatas, DICT_TYPE } from '@/utils/dict'
 | 
					import { getDictDatas, DICT_TYPE, publicFormatter } from "@/utils/dict";
 | 
				
			||||||
import {isExternal} from "@/utils/validate";
 | 
					import { isExternal } from "@/utils/validate";
 | 
				
			||||||
 | 
					import tableHeightMixin from "@/mixins/tableHeightMixin";
 | 
				
			||||||
 | 
					import statusBtn2 from "./../components/statusBtn2.vue";
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "name",
 | 
				
			||||||
 | 
					    label: "菜单名称",
 | 
				
			||||||
 | 
					    minWidth: 200,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "sort",
 | 
				
			||||||
 | 
					    label: "排序",
 | 
				
			||||||
 | 
					    width: 100,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "permission",
 | 
				
			||||||
 | 
					    label: "权限标识",
 | 
				
			||||||
 | 
					    minWidth: 80,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "component",
 | 
				
			||||||
 | 
					    label: "组件路径",
 | 
				
			||||||
 | 
					    minWidth: 80,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "componentName",
 | 
				
			||||||
 | 
					    label: "组件名称",
 | 
				
			||||||
 | 
					    minWidth: 80,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "status",
 | 
				
			||||||
 | 
					    label: "状态",
 | 
				
			||||||
 | 
					    // filter: publicFormatter(DICT_TYPE.COMMON_STATUS),
 | 
				
			||||||
 | 
					    subcomponent: statusBtn2,
 | 
				
			||||||
 | 
					    width: 100,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "SystemMenu",
 | 
					  name: "SystemMenu",
 | 
				
			||||||
 | 
					  mixins: [tableHeightMixin],
 | 
				
			||||||
  components: { Treeselect, IconSelect },
 | 
					  components: { Treeselect, IconSelect },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
 | 
					      formConfig: [
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "input",
 | 
				
			||||||
 | 
					          label: "菜单名称",
 | 
				
			||||||
 | 
					          placeholder: "菜单名称",
 | 
				
			||||||
 | 
					          param: "name",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "select",
 | 
				
			||||||
 | 
					          label: "菜单状态",
 | 
				
			||||||
 | 
					          selectOptions: this.getDictDatas(this.DICT_TYPE.COMMON_STATUS),
 | 
				
			||||||
 | 
					          labelField: "label",
 | 
				
			||||||
 | 
					          valueField: "value",
 | 
				
			||||||
 | 
					          param: "status",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "button",
 | 
				
			||||||
 | 
					          btnName: "查询",
 | 
				
			||||||
 | 
					          name: "search",
 | 
				
			||||||
 | 
					          color: "primary",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "separate",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: this.$auth.hasPermi("system:menu:create") ? "button" : "",
 | 
				
			||||||
 | 
					          btnName: "新增",
 | 
				
			||||||
 | 
					          name: "addNew",
 | 
				
			||||||
 | 
					          color: "success",
 | 
				
			||||||
 | 
					          plain: true,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "button",
 | 
				
			||||||
 | 
					          btnName: "展开/折叠",
 | 
				
			||||||
 | 
					          name: "expandAll",
 | 
				
			||||||
 | 
					          color: "primary",
 | 
				
			||||||
 | 
					          plain: true,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					      tableBtn: [
 | 
				
			||||||
 | 
					        this.$auth.hasPermi("system:menu:update")
 | 
				
			||||||
 | 
					          ? {
 | 
				
			||||||
 | 
					              type: "edit",
 | 
				
			||||||
 | 
					              btnName: "编辑",
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					        this.$auth.hasPermi("system:menu:delete")
 | 
				
			||||||
 | 
					          ? {
 | 
				
			||||||
 | 
					              type: "delete",
 | 
				
			||||||
 | 
					              btnName: "删除",
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					        this.$auth.hasPermi("system:menu:create")
 | 
				
			||||||
 | 
					          ? {
 | 
				
			||||||
 | 
					              type: "add",
 | 
				
			||||||
 | 
					              btnName: "新增",
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					      ].filter((v) => v),
 | 
				
			||||||
 | 
					      tableProps,
 | 
				
			||||||
 | 
					      heightNum: 210,
 | 
				
			||||||
      // 遮罩层
 | 
					      // 遮罩层
 | 
				
			||||||
      loading: true,
 | 
					      loading: true,
 | 
				
			||||||
      // 显示搜索条件
 | 
					      // 显示搜索条件
 | 
				
			||||||
@@ -230,24 +477,22 @@ export default {
 | 
				
			|||||||
      // 查询参数
 | 
					      // 查询参数
 | 
				
			||||||
      queryParams: {
 | 
					      queryParams: {
 | 
				
			||||||
        name: undefined,
 | 
					        name: undefined,
 | 
				
			||||||
        visible: undefined
 | 
					        status: undefined,
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      // 表单参数
 | 
					      // 表单参数
 | 
				
			||||||
      form: {},
 | 
					      form: {},
 | 
				
			||||||
      // 表单校验
 | 
					      // 表单校验
 | 
				
			||||||
      rules: {
 | 
					      rules: {
 | 
				
			||||||
        name: [
 | 
					        name: [
 | 
				
			||||||
          { required: true, message: "菜单名称不能为空", trigger: "blur" }
 | 
					          { required: true, message: "菜单名称不能为空", trigger: "blur" },
 | 
				
			||||||
        ],
 | 
					        ],
 | 
				
			||||||
        sort: [
 | 
					        sort: [
 | 
				
			||||||
          { required: true, message: "菜单顺序不能为空", trigger: "blur" }
 | 
					          { required: true, message: "菜单顺序不能为空", trigger: "blur" },
 | 
				
			||||||
        ],
 | 
					        ],
 | 
				
			||||||
        path: [
 | 
					        path: [
 | 
				
			||||||
          { required: true, message: "路由地址不能为空", trigger: "blur" }
 | 
					          { required: true, message: "路由地址不能为空", trigger: "blur" },
 | 
				
			||||||
        ],
 | 
					        ],
 | 
				
			||||||
        status: [
 | 
					        status: [{ required: true, message: "状态不能为空", trigger: "blur" }],
 | 
				
			||||||
          { required: true, message: "状态不能为空", trigger: "blur" }
 | 
					 | 
				
			||||||
        ]
 | 
					 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      // 枚举
 | 
					      // 枚举
 | 
				
			||||||
@@ -255,13 +500,34 @@ export default {
 | 
				
			|||||||
      CommonStatusEnum: CommonStatusEnum,
 | 
					      CommonStatusEnum: CommonStatusEnum,
 | 
				
			||||||
      // 数据字典
 | 
					      // 数据字典
 | 
				
			||||||
      menuTypeDictDatas: getDictDatas(DICT_TYPE.SYSTEM_MENU_TYPE),
 | 
					      menuTypeDictDatas: getDictDatas(DICT_TYPE.SYSTEM_MENU_TYPE),
 | 
				
			||||||
      statusDictDatas: getDictDatas(DICT_TYPE.COMMON_STATUS)
 | 
					      statusDictDatas: getDictDatas(DICT_TYPE.COMMON_STATUS),
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  created() {
 | 
					  created() {
 | 
				
			||||||
    this.getList();
 | 
					    this.getList();
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
 | 
					    handleClick(val) {
 | 
				
			||||||
 | 
					      console.log(val);
 | 
				
			||||||
 | 
					      if (val.type === "edit") {
 | 
				
			||||||
 | 
					        this.handleUpdate(val.data);
 | 
				
			||||||
 | 
					      } else if (val.type === "delete") {
 | 
				
			||||||
 | 
					        this.handleDelete(val.data);
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.handleAdd(val.data);
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    buttonClick(val) {
 | 
				
			||||||
 | 
					      this.queryParams.name = val.name;
 | 
				
			||||||
 | 
					      this.queryParams.status = val.status;
 | 
				
			||||||
 | 
					      if (val.btnName === "search") {
 | 
				
			||||||
 | 
					        this.getList();
 | 
				
			||||||
 | 
					      } else if (val.btnName === "addNew") {
 | 
				
			||||||
 | 
					        this.handleAdd();
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.toggleExpandAll();
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    // 选择图标
 | 
					    // 选择图标
 | 
				
			||||||
    selected(name) {
 | 
					    selected(name) {
 | 
				
			||||||
      this.form.icon = name;
 | 
					      this.form.icon = name;
 | 
				
			||||||
@@ -269,7 +535,7 @@ export default {
 | 
				
			|||||||
    /** 查询菜单列表 */
 | 
					    /** 查询菜单列表 */
 | 
				
			||||||
    getList() {
 | 
					    getList() {
 | 
				
			||||||
      this.loading = true;
 | 
					      this.loading = true;
 | 
				
			||||||
      listMenu(this.queryParams).then(response => {
 | 
					      listMenu(this.queryParams).then((response) => {
 | 
				
			||||||
        this.menuList = this.handleTree(response.data, "id");
 | 
					        this.menuList = this.handleTree(response.data, "id");
 | 
				
			||||||
        this.loading = false;
 | 
					        this.loading = false;
 | 
				
			||||||
      });
 | 
					      });
 | 
				
			||||||
@@ -282,14 +548,14 @@ export default {
 | 
				
			|||||||
      return {
 | 
					      return {
 | 
				
			||||||
        id: node.id,
 | 
					        id: node.id,
 | 
				
			||||||
        label: node.name,
 | 
					        label: node.name,
 | 
				
			||||||
        children: node.children
 | 
					        children: node.children,
 | 
				
			||||||
      };
 | 
					      };
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 查询菜单下拉树结构 */
 | 
					    /** 查询菜单下拉树结构 */
 | 
				
			||||||
    getTreeselect() {
 | 
					    getTreeselect() {
 | 
				
			||||||
      listMenu().then(response => {
 | 
					      listMenu().then((response) => {
 | 
				
			||||||
        this.menuOptions = [];
 | 
					        this.menuOptions = [];
 | 
				
			||||||
        const menu = { id: 0, name: '主类目', children: [] };
 | 
					        const menu = { id: 0, name: "主类目", children: [] };
 | 
				
			||||||
        menu.children = this.handleTree(response.data, "id");
 | 
					        menu.children = this.handleTree(response.data, "id");
 | 
				
			||||||
        this.menuOptions.push(menu);
 | 
					        this.menuOptions.push(menu);
 | 
				
			||||||
      });
 | 
					      });
 | 
				
			||||||
@@ -315,15 +581,6 @@ export default {
 | 
				
			|||||||
      };
 | 
					      };
 | 
				
			||||||
      this.resetForm("form");
 | 
					      this.resetForm("form");
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 搜索按钮操作 */
 | 
					 | 
				
			||||||
    handleQuery() {
 | 
					 | 
				
			||||||
      this.getList();
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 重置按钮操作 */
 | 
					 | 
				
			||||||
    resetQuery() {
 | 
					 | 
				
			||||||
      this.resetForm("queryForm");
 | 
					 | 
				
			||||||
      this.handleQuery();
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 展开/折叠操作 */
 | 
					    /** 展开/折叠操作 */
 | 
				
			||||||
    toggleExpandAll() {
 | 
					    toggleExpandAll() {
 | 
				
			||||||
      this.refreshTable = false;
 | 
					      this.refreshTable = false;
 | 
				
			||||||
@@ -348,42 +605,44 @@ export default {
 | 
				
			|||||||
    handleUpdate(row) {
 | 
					    handleUpdate(row) {
 | 
				
			||||||
      this.reset();
 | 
					      this.reset();
 | 
				
			||||||
      this.getTreeselect();
 | 
					      this.getTreeselect();
 | 
				
			||||||
      getMenu(row.id).then(response => {
 | 
					      getMenu(row.id).then((response) => {
 | 
				
			||||||
        this.form = response.data;
 | 
					        this.form = response.data;
 | 
				
			||||||
        this.open = true;
 | 
					        this.open = true;
 | 
				
			||||||
        this.title = "修改菜单";
 | 
					        this.title = "修改菜单";
 | 
				
			||||||
      });
 | 
					      });
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 提交按钮 */
 | 
					    /** 提交按钮 */
 | 
				
			||||||
    submitForm: function() {
 | 
					    submitForm: function () {
 | 
				
			||||||
      this.$refs["form"].validate(valid => {
 | 
					      this.$refs["form"].validate((valid) => {
 | 
				
			||||||
        if (valid) {
 | 
					        if (valid) {
 | 
				
			||||||
          // 若权限类型为目录或者菜单时,进行 path 的校验,避免后续拼接出来的路由无法跳转
 | 
					          // 若权限类型为目录或者菜单时,进行 path 的校验,避免后续拼接出来的路由无法跳转
 | 
				
			||||||
          if (this.form.type === SystemMenuTypeEnum.DIR
 | 
					          if (
 | 
				
			||||||
            || this.form.type === SystemMenuTypeEnum.MENU) {
 | 
					            this.form.type === SystemMenuTypeEnum.DIR ||
 | 
				
			||||||
 | 
					            this.form.type === SystemMenuTypeEnum.MENU
 | 
				
			||||||
 | 
					          ) {
 | 
				
			||||||
            // 如果是外链,则不进行校验
 | 
					            // 如果是外链,则不进行校验
 | 
				
			||||||
            const path = this.form.path
 | 
					            const path = this.form.path;
 | 
				
			||||||
            if (!isExternal(path)) {
 | 
					            if (!isExternal(path)) {
 | 
				
			||||||
              // 父权限为根节点,path 必须以 / 开头
 | 
					              // 父权限为根节点,path 必须以 / 开头
 | 
				
			||||||
              if (this.form.parentId === 0 && path.charAt(0) !== '/') {
 | 
					              if (this.form.parentId === 0 && path.charAt(0) !== "/") {
 | 
				
			||||||
                this.$modal.msgSuccess('前端必须以 / 开头')
 | 
					                this.$modal.msgSuccess("前端必须以 / 开头");
 | 
				
			||||||
                return
 | 
					                return;
 | 
				
			||||||
              } else if (this.form.parentId !== 0 && path.charAt(0) === '/') {
 | 
					              } else if (this.form.parentId !== 0 && path.charAt(0) === "/") {
 | 
				
			||||||
                this.$modal.msgSuccess('前端不能以 / 开头')
 | 
					                this.$modal.msgSuccess("前端不能以 / 开头");
 | 
				
			||||||
                return
 | 
					                return;
 | 
				
			||||||
              }
 | 
					              }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          // 提交
 | 
					          // 提交
 | 
				
			||||||
          if (this.form.id !== undefined) {
 | 
					          if (this.form.id !== undefined) {
 | 
				
			||||||
            updateMenu(this.form).then(response => {
 | 
					            updateMenu(this.form).then((response) => {
 | 
				
			||||||
              this.$modal.msgSuccess("修改成功");
 | 
					              this.$modal.msgSuccess("修改成功");
 | 
				
			||||||
              this.open = false;
 | 
					              this.open = false;
 | 
				
			||||||
              this.getList();
 | 
					              this.getList();
 | 
				
			||||||
            });
 | 
					            });
 | 
				
			||||||
          } else {
 | 
					          } else {
 | 
				
			||||||
            addMenu(this.form).then(response => {
 | 
					            addMenu(this.form).then((response) => {
 | 
				
			||||||
              this.$modal.msgSuccess("新增成功");
 | 
					              this.$modal.msgSuccess("新增成功");
 | 
				
			||||||
              this.open = false;
 | 
					              this.open = false;
 | 
				
			||||||
              this.getList();
 | 
					              this.getList();
 | 
				
			||||||
@@ -394,13 +653,26 @@ export default {
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 删除按钮操作 */
 | 
					    /** 删除按钮操作 */
 | 
				
			||||||
    handleDelete(row) {
 | 
					    handleDelete(row) {
 | 
				
			||||||
      this.$modal.confirm('是否确认删除名称为"' + row.name + '"的数据项?').then(function() {
 | 
					      this.$modal
 | 
				
			||||||
 | 
					        .confirm('是否确认删除名称为"' + row.name + '"的数据项?')
 | 
				
			||||||
 | 
					        .then(function () {
 | 
				
			||||||
          return delMenu(row.id);
 | 
					          return delMenu(row.id);
 | 
				
			||||||
        }).then(() => {
 | 
					        })
 | 
				
			||||||
 | 
					        .then(() => {
 | 
				
			||||||
          this.getList();
 | 
					          this.getList();
 | 
				
			||||||
          this.$modal.msgSuccess("删除成功");
 | 
					          this.$modal.msgSuccess("删除成功");
 | 
				
			||||||
      }).catch(() => {});
 | 
					        })
 | 
				
			||||||
    }
 | 
					        .catch(() => {});
 | 
				
			||||||
  }
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.app-container {
 | 
				
			||||||
 | 
					  width: 100%;
 | 
				
			||||||
 | 
					  height: calc(100vh - 120px - 8px);
 | 
				
			||||||
 | 
					  background-color: #fff;
 | 
				
			||||||
 | 
					  border-radius: 8px;
 | 
				
			||||||
 | 
					  padding: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,84 +1,44 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="app-container">
 | 
					  <div class="app-container">
 | 
				
			||||||
    <doc-alert title="系统日志" url="https://doc.iocoder.cn/system-log/" />
 | 
					    <!-- <doc-alert title="系统日志" url="https://doc.iocoder.cn/system-log/" /> -->
 | 
				
			||||||
    <!-- 搜索工作栏 -->
 | 
					    <!-- 搜索工作栏 -->
 | 
				
			||||||
    <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
 | 
					    <search-bar
 | 
				
			||||||
      <el-form-item label="系统模块" prop="module">
 | 
					      :formConfigs="formConfig"
 | 
				
			||||||
        <el-input v-model="queryParams.module" placeholder="请输入系统模块" clearable style="width: 240px;"
 | 
					      ref="searchBarForm"
 | 
				
			||||||
                  @keyup.enter.native="handleQuery"/>
 | 
					      @headBtnClick="buttonClick"
 | 
				
			||||||
      </el-form-item>
 | 
					    />
 | 
				
			||||||
      <el-form-item label="操作人员" prop="userNickname">
 | 
					    <!-- 列表 -->
 | 
				
			||||||
        <el-input v-model="queryParams.userNickname" placeholder="请输入操作人员" clearable style="width: 240px;"
 | 
					    <base-table
 | 
				
			||||||
                  @keyup.enter.native="handleQuery"/>
 | 
					      :page="queryParams.pageNo"
 | 
				
			||||||
      </el-form-item>
 | 
					      :limit="queryParams.pageSize"
 | 
				
			||||||
      <el-form-item label="类型" prop="type">
 | 
					      :table-props="tableProps"
 | 
				
			||||||
        <el-select v-model="queryParams.type" placeholder="操作类型" clearable style="width: 240px">
 | 
					      :table-data="list"
 | 
				
			||||||
          <el-option v-for="dict in this.getDictDatas(DICT_TYPE.SYSTEM_OPERATE_TYPE)" :key="parseInt(dict.value)"
 | 
					      :max-height="tableH"
 | 
				
			||||||
                     :label="dict.label" :value="parseInt(dict.value)"/>
 | 
					    >
 | 
				
			||||||
        </el-select>
 | 
					      <method-btn
 | 
				
			||||||
      </el-form-item>
 | 
					        v-if="tableBtn.length"
 | 
				
			||||||
      <el-form-item label="状态" prop="status">
 | 
					        slot="handleBtn"
 | 
				
			||||||
        <el-select v-model="queryParams.success" placeholder="操作状态" clearable style="width: 240px">
 | 
					        :width="80"
 | 
				
			||||||
          <el-option :key="true" label="成功" :value="true"/>
 | 
					        label="操作"
 | 
				
			||||||
          <el-option :key="false" label="失败" :value="false"/>
 | 
					        :method-list="tableBtn"
 | 
				
			||||||
        </el-select>
 | 
					        @clickBtn="handleClick"
 | 
				
			||||||
      </el-form-item>
 | 
					      />
 | 
				
			||||||
      <el-form-item label="操作时间" prop="startTime">
 | 
					    </base-table>
 | 
				
			||||||
        <el-date-picker v-model="queryParams.startTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange"
 | 
					 | 
				
			||||||
                        range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" />
 | 
					 | 
				
			||||||
      </el-form-item>
 | 
					 | 
				
			||||||
      <el-form-item>
 | 
					 | 
				
			||||||
        <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
 | 
					 | 
				
			||||||
        <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
 | 
					 | 
				
			||||||
      </el-form-item>
 | 
					 | 
				
			||||||
    </el-form>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <el-row :gutter="10" class="mb8">
 | 
					    <pagination
 | 
				
			||||||
      <el-col :span="1.5">
 | 
					      :page.sync="queryParams.pageNo"
 | 
				
			||||||
        <el-button type="warning" icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading"
 | 
					      :limit.sync="queryParams.pageSize"
 | 
				
			||||||
                   v-hasPermi="['system:operate-log:export']">导出</el-button>
 | 
					      :total="total"
 | 
				
			||||||
      </el-col>
 | 
					      @pagination="getList"
 | 
				
			||||||
      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
 | 
					    />
 | 
				
			||||||
    </el-row>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    <el-table v-loading="loading" :data="list">
 | 
					 | 
				
			||||||
      <el-table-column label="日志编号" align="center" prop="id" />
 | 
					 | 
				
			||||||
      <el-table-column label="操作模块" align="center" prop="module" />
 | 
					 | 
				
			||||||
      <el-table-column label="操作名" align="center" prop="name" width="180" />
 | 
					 | 
				
			||||||
      <el-table-column label="操作类型" align="center" prop="type">
 | 
					 | 
				
			||||||
        <template v-slot="scope">
 | 
					 | 
				
			||||||
          <dict-tag :type="DICT_TYPE.SYSTEM_OPERATE_TYPE" :value="scope.row.type"/>
 | 
					 | 
				
			||||||
        </template>
 | 
					 | 
				
			||||||
      </el-table-column>
 | 
					 | 
				
			||||||
      <el-table-column label="操作人" align="center" prop="userNickname" />
 | 
					 | 
				
			||||||
      <el-table-column label="操作结果" align="center" prop="status">
 | 
					 | 
				
			||||||
        <template v-slot="scope">
 | 
					 | 
				
			||||||
          <span>{{ scope.row.resultCode === 0 ? '成功' : '失败' }}</span>
 | 
					 | 
				
			||||||
        </template>
 | 
					 | 
				
			||||||
      </el-table-column>
 | 
					 | 
				
			||||||
      <el-table-column label="操作日期" align="center" prop="startTime" width="180">
 | 
					 | 
				
			||||||
        <template v-slot="scope">
 | 
					 | 
				
			||||||
          <span>{{ parseTime(scope.row.startTime) }}</span>
 | 
					 | 
				
			||||||
        </template>
 | 
					 | 
				
			||||||
      </el-table-column>
 | 
					 | 
				
			||||||
      <el-table-column label="执行时长" align="center" prop="startTime">
 | 
					 | 
				
			||||||
        <template v-slot="scope">
 | 
					 | 
				
			||||||
          <span>{{ scope.row.duration }}  ms</span>
 | 
					 | 
				
			||||||
        </template>
 | 
					 | 
				
			||||||
      </el-table-column>
 | 
					 | 
				
			||||||
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
 | 
					 | 
				
			||||||
        <template v-slot="scope">
 | 
					 | 
				
			||||||
          <el-button size="mini" type="text" icon="el-icon-view" @click="handleView(scope.row,scope.index)"
 | 
					 | 
				
			||||||
                     v-hasPermi="['system:operate-log:query']">详细</el-button>
 | 
					 | 
				
			||||||
        </template>
 | 
					 | 
				
			||||||
      </el-table-column>
 | 
					 | 
				
			||||||
    </el-table>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    <pagination v-show="total>0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize"
 | 
					 | 
				
			||||||
                @pagination="getList" />
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- 操作日志详细 -->
 | 
					    <!-- 操作日志详细 -->
 | 
				
			||||||
    <el-dialog title="访问日志详细" :visible.sync="open" width="700px" append-to-body>
 | 
					    <base-dialog
 | 
				
			||||||
 | 
					      dialogTitle="访问日志详细"
 | 
				
			||||||
 | 
					      :dialogVisible="open"
 | 
				
			||||||
 | 
					      width="50%"
 | 
				
			||||||
 | 
					      @close="open = false"
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      <el-form ref="form" :model="form" label-width="100px" size="mini">
 | 
					      <el-form ref="form" :model="form" label-width="100px" size="mini">
 | 
				
			||||||
        <el-row>
 | 
					        <el-row>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <el-col :span="24">
 | 
				
			||||||
@@ -88,24 +48,35 @@
 | 
				
			|||||||
            <el-form-item label="链路追踪:">{{ form.traceId }}</el-form-item>
 | 
					            <el-form-item label="链路追踪:">{{ form.traceId }}</el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <el-col :span="24">
 | 
				
			||||||
            <el-form-item label="用户信息:">{{ form.userId }} | {{ form.userNickname }} | {{ form.userIp }} | {{ form.userAgent}} </el-form-item>
 | 
					            <el-form-item label="用户信息:"
 | 
				
			||||||
 | 
					              >{{ form.userId }} | {{ form.userNickname }} | {{ form.userIp }} |
 | 
				
			||||||
 | 
					              {{ form.userAgent }}
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <el-col :span="24">
 | 
				
			||||||
            <el-form-item label="操作信息:">
 | 
					            <el-form-item label="操作信息:">
 | 
				
			||||||
              {{ form.module }} | {{ form.name }}
 | 
					              {{ form.module }} | {{ form.name }}
 | 
				
			||||||
              <dict-tag :type="DICT_TYPE.SYSTEM_OPERATE_TYPE" :value="form.type"/>
 | 
					              <dict-tag
 | 
				
			||||||
              <br /> {{ form.content }}
 | 
					                :type="DICT_TYPE.SYSTEM_OPERATE_TYPE"
 | 
				
			||||||
              <br /> {{ form.exts }}
 | 
					                :value="form.type"
 | 
				
			||||||
 | 
					              />
 | 
				
			||||||
 | 
					              <br />
 | 
				
			||||||
 | 
					              {{ form.content }} <br />
 | 
				
			||||||
 | 
					              {{ form.exts }}
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <el-col :span="24">
 | 
				
			||||||
            <el-form-item label="请求信息:">{{ form.requestMethod }} | {{ form.requestUrl }} </el-form-item>
 | 
					            <el-form-item label="请求信息:"
 | 
				
			||||||
 | 
					              >{{ form.requestMethod }} | {{ form.requestUrl }}
 | 
				
			||||||
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <el-col :span="24">
 | 
				
			||||||
            <el-form-item label="方法名:">{{ form.javaMethod }}</el-form-item>
 | 
					            <el-form-item label="方法名:">{{ form.javaMethod }}</el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <el-col :span="24">
 | 
				
			||||||
            <el-form-item label="方法参数:">{{ form.javaMethodArgs }}</el-form-item>
 | 
					            <el-form-item label="方法参数:">{{
 | 
				
			||||||
 | 
					              form.javaMethodArgs
 | 
				
			||||||
 | 
					            }}</el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="24">
 | 
					          <el-col :span="24">
 | 
				
			||||||
            <el-form-item label="开始时间:">
 | 
					            <el-form-item label="开始时间:">
 | 
				
			||||||
@@ -114,8 +85,12 @@
 | 
				
			|||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
          <el-col :span="12">
 | 
					          <el-col :span="12">
 | 
				
			||||||
            <el-form-item label="操作结果:">
 | 
					            <el-form-item label="操作结果:">
 | 
				
			||||||
              <div v-if="form.resultCode === 0">正常 | {{ form.resultData}} </div>
 | 
					              <div v-if="form.resultCode === 0">
 | 
				
			||||||
              <div v-else-if="form.resultCode > 0">失败 | {{ form.resultCode }} || {{ form.resultMsg}}</div>
 | 
					                正常 | {{ form.resultData }}
 | 
				
			||||||
 | 
					              </div>
 | 
				
			||||||
 | 
					              <div v-else-if="form.resultCode > 0">
 | 
				
			||||||
 | 
					                失败 | {{ form.resultCode }} || {{ form.resultMsg }}
 | 
				
			||||||
 | 
					              </div>
 | 
				
			||||||
            </el-form-item>
 | 
					            </el-form-item>
 | 
				
			||||||
          </el-col>
 | 
					          </el-col>
 | 
				
			||||||
        </el-row>
 | 
					        </el-row>
 | 
				
			||||||
@@ -123,19 +98,120 @@
 | 
				
			|||||||
      <div slot="footer" class="dialog-footer">
 | 
					      <div slot="footer" class="dialog-footer">
 | 
				
			||||||
        <el-button @click="open = false">关 闭</el-button>
 | 
					        <el-button @click="open = false">关 闭</el-button>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </el-dialog>
 | 
					    </base-dialog>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import { listOperateLog, exportOperateLog } from "@/api/system/operatelog";
 | 
					import { listOperateLog, exportOperateLog } from "@/api/system/operatelog";
 | 
				
			||||||
 | 
					import tableHeightMixin from "@/mixins/tableHeightMixin";
 | 
				
			||||||
 | 
					import statusBtn3 from "./../components/statusBtn3.vue";
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "id",
 | 
				
			||||||
 | 
					    label: "日志编号",
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "module",
 | 
				
			||||||
 | 
					    label: "操作模块",
 | 
				
			||||||
 | 
					    minWidth: 150,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "name",
 | 
				
			||||||
 | 
					    label: "操作名",
 | 
				
			||||||
 | 
					    minWidth: 200,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "userNickname",
 | 
				
			||||||
 | 
					    label: "操作人",
 | 
				
			||||||
 | 
					    minWidth: 80,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "resultCode",
 | 
				
			||||||
 | 
					    label: "操作结果",
 | 
				
			||||||
 | 
					    subcomponent: statusBtn3,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "duration",
 | 
				
			||||||
 | 
					    label: "执行时长",
 | 
				
			||||||
 | 
					    minWidth: 80,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "SystemOperateLog",
 | 
					  name: "SystemOperateLog",
 | 
				
			||||||
 | 
					  mixins: [tableHeightMixin],
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      // 遮罩层
 | 
					      formConfig: [
 | 
				
			||||||
      loading: true,
 | 
					        {
 | 
				
			||||||
 | 
					          type: "input",
 | 
				
			||||||
 | 
					          label: "系统模块",
 | 
				
			||||||
 | 
					          placeholder: "系统模块",
 | 
				
			||||||
 | 
					          param: "module",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "input",
 | 
				
			||||||
 | 
					          label: "操作人员",
 | 
				
			||||||
 | 
					          placeholder: "操作人员",
 | 
				
			||||||
 | 
					          param: "userNickname",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "select",
 | 
				
			||||||
 | 
					          label: "类型",
 | 
				
			||||||
 | 
					          selectOptions: this.getDictDatas(this.DICT_TYPE.SYSTEM_OPERATE_TYPE),
 | 
				
			||||||
 | 
					          labelField: "label",
 | 
				
			||||||
 | 
					          valueField: "value",
 | 
				
			||||||
 | 
					          param: "type",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "select",
 | 
				
			||||||
 | 
					          label: "状态",
 | 
				
			||||||
 | 
					          selectOptions: [
 | 
				
			||||||
 | 
					            { id: true, name: "成功" },
 | 
				
			||||||
 | 
					            { id: false, name: "失败" },
 | 
				
			||||||
 | 
					          ],
 | 
				
			||||||
 | 
					          param: "success",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "datePicker",
 | 
				
			||||||
 | 
					          label: "操作时间",
 | 
				
			||||||
 | 
					          dateType: "daterange",
 | 
				
			||||||
 | 
					          format: "yyyy-MM-dd",
 | 
				
			||||||
 | 
					          valueFormat: "yyyy-MM-dd HH:mm:ss",
 | 
				
			||||||
 | 
					          rangeSeparator: "-",
 | 
				
			||||||
 | 
					          startPlaceholder: "开始日期",
 | 
				
			||||||
 | 
					          endPlaceholder: "结束日期",
 | 
				
			||||||
 | 
					          param: "startTime",
 | 
				
			||||||
 | 
					          defaultSelect: [],
 | 
				
			||||||
 | 
					          defaultTime: ["00:00:00", "23:59:59"],
 | 
				
			||||||
 | 
					          width: 250,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "button",
 | 
				
			||||||
 | 
					          btnName: "查询",
 | 
				
			||||||
 | 
					          name: "search",
 | 
				
			||||||
 | 
					          color: "primary",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: this.$auth.hasPermi("system:operate-log:export")
 | 
				
			||||||
 | 
					            ? "separate"
 | 
				
			||||||
 | 
					            : "",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: this.$auth.hasPermi("system:operate-log:export")
 | 
				
			||||||
 | 
					            ? "button"
 | 
				
			||||||
 | 
					            : "",
 | 
				
			||||||
 | 
					          btnName: "导出",
 | 
				
			||||||
 | 
					          name: "export",
 | 
				
			||||||
 | 
					          color: "primary",
 | 
				
			||||||
 | 
					          plain: true,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					      tableProps,
 | 
				
			||||||
      // 导出遮罩层
 | 
					      // 导出遮罩层
 | 
				
			||||||
      exportLoading: false,
 | 
					      exportLoading: false,
 | 
				
			||||||
      // 显示搜索条件
 | 
					      // 显示搜索条件
 | 
				
			||||||
@@ -144,6 +220,12 @@ export default {
 | 
				
			|||||||
      total: 0,
 | 
					      total: 0,
 | 
				
			||||||
      // 表格数据
 | 
					      // 表格数据
 | 
				
			||||||
      list: [],
 | 
					      list: [],
 | 
				
			||||||
 | 
					      tableBtn: [
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "detail",
 | 
				
			||||||
 | 
					          btnName: "详情",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
      // 是否显示弹出层
 | 
					      // 是否显示弹出层
 | 
				
			||||||
      open: false,
 | 
					      open: false,
 | 
				
			||||||
      // 类型数据字典
 | 
					      // 类型数据字典
 | 
				
			||||||
@@ -153,12 +235,12 @@ export default {
 | 
				
			|||||||
      // 查询参数
 | 
					      // 查询参数
 | 
				
			||||||
      queryParams: {
 | 
					      queryParams: {
 | 
				
			||||||
        pageNo: 1,
 | 
					        pageNo: 1,
 | 
				
			||||||
        pageSize: 10,
 | 
					        pageSize: 20,
 | 
				
			||||||
        module: undefined,
 | 
					        module: undefined,
 | 
				
			||||||
        userNickname: undefined,
 | 
					        userNickname: undefined,
 | 
				
			||||||
        businessType: undefined,
 | 
					        businessType: undefined,
 | 
				
			||||||
        status: undefined,
 | 
					        success: undefined,
 | 
				
			||||||
        startTime: []
 | 
					        startTime: [],
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
@@ -168,24 +250,16 @@ export default {
 | 
				
			|||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    /** 查询登录日志 */
 | 
					    /** 查询登录日志 */
 | 
				
			||||||
    getList() {
 | 
					    getList() {
 | 
				
			||||||
      this.loading = true;
 | 
					      listOperateLog(this.queryParams).then((response) => {
 | 
				
			||||||
      listOperateLog(this.queryParams).then( response => {
 | 
					 | 
				
			||||||
        this.list = response.data.list;
 | 
					        this.list = response.data.list;
 | 
				
			||||||
        this.total = response.data.total;
 | 
					        this.total = response.data.total;
 | 
				
			||||||
          this.loading = false;
 | 
					      });
 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      );
 | 
					 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 搜索按钮操作 */
 | 
					    /** 搜索按钮操作 */
 | 
				
			||||||
    handleQuery() {
 | 
					    handleQuery() {
 | 
				
			||||||
      this.queryParams.pageNo = 1;
 | 
					      this.queryParams.pageNo = 1;
 | 
				
			||||||
      this.getList();
 | 
					      this.getList();
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 重置按钮操作 */
 | 
					 | 
				
			||||||
    resetQuery() {
 | 
					 | 
				
			||||||
      this.resetForm("queryForm");
 | 
					 | 
				
			||||||
      this.handleQuery();
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 详细按钮操作 */
 | 
					    /** 详细按钮操作 */
 | 
				
			||||||
    handleView(row) {
 | 
					    handleView(row) {
 | 
				
			||||||
      this.open = true;
 | 
					      this.open = true;
 | 
				
			||||||
@@ -193,19 +267,47 @@ export default {
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 导出按钮操作 */
 | 
					    /** 导出按钮操作 */
 | 
				
			||||||
    handleExport() {
 | 
					    handleExport() {
 | 
				
			||||||
      this.$modal.confirm('是否确认导出所有操作日志数据项?').then(() => {
 | 
					      this.$modal
 | 
				
			||||||
 | 
					        .confirm("是否确认导出所有操作日志数据项?")
 | 
				
			||||||
 | 
					        .then(() => {
 | 
				
			||||||
          // 处理查询参数
 | 
					          // 处理查询参数
 | 
				
			||||||
          let params = {...this.queryParams};
 | 
					          let params = { ...this.queryParams };
 | 
				
			||||||
          params.pageNo = undefined;
 | 
					          params.pageNo = undefined;
 | 
				
			||||||
          params.pageSize = undefined;
 | 
					          params.pageSize = undefined;
 | 
				
			||||||
          this.exportLoading = true;
 | 
					          this.exportLoading = true;
 | 
				
			||||||
          return exportOperateLog(params);
 | 
					          return exportOperateLog(params);
 | 
				
			||||||
        }).then(response => {
 | 
					        })
 | 
				
			||||||
          this.$download.excel(response, '操作日志.xls');
 | 
					        .then((response) => {
 | 
				
			||||||
 | 
					          this.$download.excel(response, "操作日志.xls");
 | 
				
			||||||
          this.exportLoading = false;
 | 
					          this.exportLoading = false;
 | 
				
			||||||
      }).catch(() => {});
 | 
					        })
 | 
				
			||||||
    }
 | 
					        .catch(() => {});
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    buttonClick(val) {
 | 
				
			||||||
 | 
					      this.queryParams.module = val.module;
 | 
				
			||||||
 | 
					      this.queryParams.userNickname = val.userNickname;
 | 
				
			||||||
 | 
					      this.queryParams.type = val.type;
 | 
				
			||||||
 | 
					      this.queryParams.success = val.success;
 | 
				
			||||||
 | 
					      this.queryParams.startTime = val.startTime;
 | 
				
			||||||
 | 
					      if (val.btnName === "search") {
 | 
				
			||||||
 | 
					        this.queryParams.pageNo = 1;
 | 
				
			||||||
 | 
					        this.getList();
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.handleExport();
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleClick(val) {
 | 
				
			||||||
 | 
					      this.handleView(val.data);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.app-container {
 | 
				
			||||||
 | 
					  width: 100%;
 | 
				
			||||||
 | 
					  height: calc(100vh - 120px - 8px);
 | 
				
			||||||
 | 
					  background-color: #fff;
 | 
				
			||||||
 | 
					  border-radius: 8px;
 | 
				
			||||||
 | 
					  padding: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										
											BIN
										
									
								
								src/views/system/post/assets/images/Qian.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| 
		 After Width: | Height: | Size: 612 B  | 
							
								
								
									
										
											BIN
										
									
								
								src/views/system/post/assets/images/arrow.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| 
		 After Width: | Height: | Size: 181 B  | 
							
								
								
									
										
											BIN
										
									
								
								src/views/system/post/assets/images/factory-icon.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| 
		 After Width: | Height: | Size: 710 B  | 
							
								
								
									
										
											BIN
										
									
								
								src/views/system/post/assets/images/tree-icon-2.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| 
		 After Width: | Height: | Size: 3.2 KiB  | 
							
								
								
									
										445
									
								
								src/views/system/post/components/InPageLeftNav.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,445 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="in-page-left-nav" style="overflow: hidden">
 | 
				
			||||||
 | 
					    <div
 | 
				
			||||||
 | 
					      class="factory-list__selector"
 | 
				
			||||||
 | 
					      style="margin: 20px 12px"
 | 
				
			||||||
 | 
					      title="株洲中建材光电材料有限公司"
 | 
				
			||||||
 | 
					      @mouseenter="factoryListOpen = true"
 | 
				
			||||||
 | 
					      @mouseleave="factoryListOpen = false"
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
 | 
					      <img src="./../assets/images/arrow.png" class="arrow" alt="" />
 | 
				
			||||||
 | 
					      <div class="factory-list__content">{{ currentFactory.label }}</div>
 | 
				
			||||||
 | 
					      <div class="factory-list__wrapper" :class="{ open: factoryListOpen }">
 | 
				
			||||||
 | 
					        <ul
 | 
				
			||||||
 | 
					          class="factory-list"
 | 
				
			||||||
 | 
					          v-if="sidebarContent.length"
 | 
				
			||||||
 | 
					          @click.capture="factoryClickHandler"
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					          <li
 | 
				
			||||||
 | 
					            v-for="fc in sidebarContent"
 | 
				
			||||||
 | 
					            :key="fc.id"
 | 
				
			||||||
 | 
					            class="factory-list__item"
 | 
				
			||||||
 | 
					            :class="{ 'is-current': fc.id == currentFactory?.id }"
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					            <span :data-value="fc.id">
 | 
				
			||||||
 | 
					              {{ fc.label }}
 | 
				
			||||||
 | 
					            </span>
 | 
				
			||||||
 | 
					            <svg-icon
 | 
				
			||||||
 | 
					              v-if="fc.id == currentFactory?.id"
 | 
				
			||||||
 | 
					              icon-class="Confirm"
 | 
				
			||||||
 | 
					              style="height: 14px; width: 14px"
 | 
				
			||||||
 | 
					            />
 | 
				
			||||||
 | 
					          </li>
 | 
				
			||||||
 | 
					        </ul>
 | 
				
			||||||
 | 
					        <div v-else style="color: #0008; width: 128px; text-align: center">
 | 
				
			||||||
 | 
					          - 无 -
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					    <!-- side bar  -->
 | 
				
			||||||
 | 
					    <div class="side-bar__left" style="width: 100%; height: 100%">
 | 
				
			||||||
 | 
					      <!-- <el-tree
 | 
				
			||||||
 | 
					        class="custom-tree-class"
 | 
				
			||||||
 | 
					        :data="currentFactory?.children"
 | 
				
			||||||
 | 
					        :props="treeProps"
 | 
				
			||||||
 | 
					        :empty-text="''"
 | 
				
			||||||
 | 
					        icon-class="custom-icon-class"
 | 
				
			||||||
 | 
					        @node-click="handleSidebarItemClick"
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					      </el-tree> -->
 | 
				
			||||||
 | 
					      <el-menu
 | 
				
			||||||
 | 
					        default-active="2"
 | 
				
			||||||
 | 
					        class="el-menu-vertical-demo"
 | 
				
			||||||
 | 
					        @open="handleOpen"
 | 
				
			||||||
 | 
					        @close="handleClose"
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					        <el-submenu index="1">
 | 
				
			||||||
 | 
					          <template slot="title">
 | 
				
			||||||
 | 
					            <svg-icon
 | 
				
			||||||
 | 
					              style="
 | 
				
			||||||
 | 
					                font-size: 18px;
 | 
				
			||||||
 | 
					                margin-right: 10px;
 | 
				
			||||||
 | 
					                vertical-align: middle;
 | 
				
			||||||
 | 
					              "
 | 
				
			||||||
 | 
					              icon-class="orgTreeIcon"
 | 
				
			||||||
 | 
					            />
 | 
				
			||||||
 | 
					            <span>导航一</span>
 | 
				
			||||||
 | 
					          </template>
 | 
				
			||||||
 | 
					          <el-menu-item index="1-1"
 | 
				
			||||||
 | 
					            ><svg-icon
 | 
				
			||||||
 | 
					              style="
 | 
				
			||||||
 | 
					                font-size: 18px;
 | 
				
			||||||
 | 
					                margin-right: 10px;
 | 
				
			||||||
 | 
					                vertical-align: middle;
 | 
				
			||||||
 | 
					              "
 | 
				
			||||||
 | 
					              icon-class="orgTreeIcon2"
 | 
				
			||||||
 | 
					            />选项1</el-menu-item
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					          <el-menu-item index="1-2"
 | 
				
			||||||
 | 
					            ><svg-icon
 | 
				
			||||||
 | 
					              style="
 | 
				
			||||||
 | 
					                font-size: 18px;
 | 
				
			||||||
 | 
					                margin-right: 10px;
 | 
				
			||||||
 | 
					                vertical-align: middle;
 | 
				
			||||||
 | 
					              "
 | 
				
			||||||
 | 
					              icon-class="orgTreeIcon2"
 | 
				
			||||||
 | 
					            />选项2</el-menu-item
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					          <el-menu-item index="1-3"
 | 
				
			||||||
 | 
					            ><svg-icon
 | 
				
			||||||
 | 
					              style="
 | 
				
			||||||
 | 
					                font-size: 18px;
 | 
				
			||||||
 | 
					                margin-right: 10px;
 | 
				
			||||||
 | 
					                vertical-align: middle;
 | 
				
			||||||
 | 
					              "
 | 
				
			||||||
 | 
					              icon-class="orgTreeIcon2"
 | 
				
			||||||
 | 
					            />选项3</el-menu-item
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					          <el-submenu index="1-4">
 | 
				
			||||||
 | 
					            <template slot="title">
 | 
				
			||||||
 | 
					              <svg-icon
 | 
				
			||||||
 | 
					                style="
 | 
				
			||||||
 | 
					                  font-size: 18px;
 | 
				
			||||||
 | 
					                  margin-right: 10px;
 | 
				
			||||||
 | 
					                  vertical-align: middle;
 | 
				
			||||||
 | 
					                "
 | 
				
			||||||
 | 
					                icon-class="orgTreeIcon"
 | 
				
			||||||
 | 
					              />选项4</template
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					            <el-menu-item index="1-4-1">
 | 
				
			||||||
 | 
					              <svg-icon
 | 
				
			||||||
 | 
					                style="
 | 
				
			||||||
 | 
					                  font-size: 18px;
 | 
				
			||||||
 | 
					                  margin-right: 10px;
 | 
				
			||||||
 | 
					                  vertical-align: middle;
 | 
				
			||||||
 | 
					                "
 | 
				
			||||||
 | 
					                icon-class="orgTreeIcon2"
 | 
				
			||||||
 | 
					              />选项1</el-menu-item
 | 
				
			||||||
 | 
					            >
 | 
				
			||||||
 | 
					          </el-submenu>
 | 
				
			||||||
 | 
					        </el-submenu>
 | 
				
			||||||
 | 
					        <el-menu-item index="2">
 | 
				
			||||||
 | 
					          <svg-icon
 | 
				
			||||||
 | 
					            style="font-size: 18px; margin-right: 10px; vertical-align: middle"
 | 
				
			||||||
 | 
					            icon-class="orgTreeIcon"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					          <span slot="title">导航二</span>
 | 
				
			||||||
 | 
					        </el-menu-item>
 | 
				
			||||||
 | 
					      </el-menu>
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "InpageLeftNav",
 | 
				
			||||||
 | 
					  components: {},
 | 
				
			||||||
 | 
					  props: {},
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      factoryListOpen: false,
 | 
				
			||||||
 | 
					      currentFactory: {
 | 
				
			||||||
 | 
					        label: "点我选择设备",
 | 
				
			||||||
 | 
					        id: null,
 | 
				
			||||||
 | 
					        children: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      treeProps: {
 | 
				
			||||||
 | 
					        children: "children",
 | 
				
			||||||
 | 
					        label: "label",
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      sidebarContent: [
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          id: 1,
 | 
				
			||||||
 | 
					          label: "招商局",
 | 
				
			||||||
 | 
					          children: [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					              label: "招商局地产",
 | 
				
			||||||
 | 
					              children: [
 | 
				
			||||||
 | 
					                {
 | 
				
			||||||
 | 
					                  label: 1,
 | 
				
			||||||
 | 
					                },
 | 
				
			||||||
 | 
					              ],
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					              label: "招商局商业",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					              label: "招商局物流",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          ],
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          id: 2,
 | 
				
			||||||
 | 
					          label: "株洲中建材光电材料有限公司",
 | 
				
			||||||
 | 
					          children: [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					              label: "保利地产",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					              label: "保利投资",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          ],
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          id: 3,
 | 
				
			||||||
 | 
					          label: "中国建材集团",
 | 
				
			||||||
 | 
					          children: [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					              label: "凯盛集团",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					              label: "蚌埠研究院",
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          ],
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					      queryParams: {
 | 
				
			||||||
 | 
					        equipmentId: null,
 | 
				
			||||||
 | 
					        lineId: null,
 | 
				
			||||||
 | 
					        sectionId: null,
 | 
				
			||||||
 | 
					        productId: null,
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  computed: {},
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    /** 暴露给外部,用于更新sidebarContent */
 | 
				
			||||||
 | 
					    async updateSidebarContent(id, url) {
 | 
				
			||||||
 | 
					      // TODO
 | 
				
			||||||
 | 
					      const { code, data } = await this.$axios({
 | 
				
			||||||
 | 
					        url: (url || "/api/quality/deviceParameters") + `/${id}`,
 | 
				
			||||||
 | 
					        method: "get",
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					      if (code === 0) {
 | 
				
			||||||
 | 
					        this.getTree(data);
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    /** 点击工厂名称 */
 | 
				
			||||||
 | 
					    factoryClickHandler(event) {
 | 
				
			||||||
 | 
					      this.currentFactory = {
 | 
				
			||||||
 | 
					        label: "加载中...",
 | 
				
			||||||
 | 
					        id: null,
 | 
				
			||||||
 | 
					        children: [],
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					      this.factoryListOpen = false;
 | 
				
			||||||
 | 
					      const fcId = event.target.dataset.value;
 | 
				
			||||||
 | 
					      this.handleSidebarItemClick({ id: fcId, type: "工厂" });
 | 
				
			||||||
 | 
					      this.currentFactory = this.sidebarContent.find((item) => item.id == fcId);
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    /** 点击某一具体工厂或产线,或工段或设备 */
 | 
				
			||||||
 | 
					    handleSidebarItemClick({ label, id, type }) {
 | 
				
			||||||
 | 
					      this.equipmentId = id;
 | 
				
			||||||
 | 
					      console.log("label clicked!", label, id, type);
 | 
				
			||||||
 | 
					      switch (type) {
 | 
				
			||||||
 | 
					        case "设备":
 | 
				
			||||||
 | 
					          this.queryParams.equipmentId = id;
 | 
				
			||||||
 | 
					          break;
 | 
				
			||||||
 | 
					        case "工段":
 | 
				
			||||||
 | 
					          this.queryParams.equipmentId = null;
 | 
				
			||||||
 | 
					          this.queryParams.sectionId = id;
 | 
				
			||||||
 | 
					          break;
 | 
				
			||||||
 | 
					        case "产线":
 | 
				
			||||||
 | 
					          this.queryParams.equipmentId = null;
 | 
				
			||||||
 | 
					          this.queryParams.sectionId = null;
 | 
				
			||||||
 | 
					          this.queryParams.lineId = id;
 | 
				
			||||||
 | 
					          break;
 | 
				
			||||||
 | 
					        case "工厂":
 | 
				
			||||||
 | 
					          this.queryParams.equipmentId = null;
 | 
				
			||||||
 | 
					          this.queryParams.sectionId = null;
 | 
				
			||||||
 | 
					          this.queryParams.lineId = null;
 | 
				
			||||||
 | 
					          break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    buildTree(data) {
 | 
				
			||||||
 | 
					      data.forEach((factory) => {
 | 
				
			||||||
 | 
					        this.$set(factory, "label", factory.name);
 | 
				
			||||||
 | 
					        this.$set(factory, "type", "工厂");
 | 
				
			||||||
 | 
					        delete factory.name;
 | 
				
			||||||
 | 
					        factory.children?.forEach((line) => {
 | 
				
			||||||
 | 
					          this.$set(line, "label", line.name);
 | 
				
			||||||
 | 
					          this.$set(line, "type", "产线");
 | 
				
			||||||
 | 
					          delete line.name;
 | 
				
			||||||
 | 
					          line.children?.forEach((ws) => {
 | 
				
			||||||
 | 
					            this.$set(ws, "label", ws.name);
 | 
				
			||||||
 | 
					            this.$set(ws, "type", "工段");
 | 
				
			||||||
 | 
					            delete ws.name;
 | 
				
			||||||
 | 
					            ws.children?.forEach((eq) => {
 | 
				
			||||||
 | 
					              this.$set(eq, "label", eq.name);
 | 
				
			||||||
 | 
					              this.$set(eq, "type", "设备");
 | 
				
			||||||
 | 
					              delete eq.name;
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    async getTree(data) {
 | 
				
			||||||
 | 
					      // '@/api/quality/deviceParameters'
 | 
				
			||||||
 | 
					      // const res = await getTreeData({ id: id });
 | 
				
			||||||
 | 
					      this.buildTree(data);
 | 
				
			||||||
 | 
					      this.sidebarContent = data;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style scoped lang="scss">
 | 
				
			||||||
 | 
					.in-page-left-nav {
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  background: #fff;
 | 
				
			||||||
 | 
					  height: calc(100vh - 120px - 8px);
 | 
				
			||||||
 | 
					  width: 256px;
 | 
				
			||||||
 | 
					  border-radius: 8px;
 | 
				
			||||||
 | 
					  padding: 0;
 | 
				
			||||||
 | 
					  vertical-align: top;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.factory-list__selector {
 | 
				
			||||||
 | 
					  position: relative;
 | 
				
			||||||
 | 
					  height: 36px;
 | 
				
			||||||
 | 
					  font-size: 16px;
 | 
				
			||||||
 | 
					  line-height: 36px;
 | 
				
			||||||
 | 
					  padding-left: 28px;
 | 
				
			||||||
 | 
					  background: url(../assets/images/factory-icon.png) 0px 4px no-repeat;
 | 
				
			||||||
 | 
					  background-size: 26px 26px;
 | 
				
			||||||
 | 
					  padding-right: 16px;
 | 
				
			||||||
 | 
					  .arrow {
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    right: 0;
 | 
				
			||||||
 | 
					    top: 13px;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.factory-list__selector:hover {
 | 
				
			||||||
 | 
					  cursor: pointer;
 | 
				
			||||||
 | 
					  color: #0008;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.factory-list__selector::after {
 | 
				
			||||||
 | 
					  /* content: ''; */
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  top: 16px;
 | 
				
			||||||
 | 
					  right: 12px;
 | 
				
			||||||
 | 
					  display: inline-block;
 | 
				
			||||||
 | 
					  width: 8px;
 | 
				
			||||||
 | 
					  height: 8px;
 | 
				
			||||||
 | 
					  /* background: #5c5c5c; */
 | 
				
			||||||
 | 
					  border-color: #000;
 | 
				
			||||||
 | 
					  border-width: 4px;
 | 
				
			||||||
 | 
					  border-style: solid;
 | 
				
			||||||
 | 
					  border-top-color: transparent;
 | 
				
			||||||
 | 
					  border-right-color: transparent;
 | 
				
			||||||
 | 
					  border-bottom-color: transparent;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.factory-list__selector:hover::after {
 | 
				
			||||||
 | 
					  /* cursor: pointer; */
 | 
				
			||||||
 | 
					  border-left-color: #0008;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.factory-list__content {
 | 
				
			||||||
 | 
					  height: 36px;
 | 
				
			||||||
 | 
					  overflow: hidden; /* 确保超出容器的内容会被隐藏 */
 | 
				
			||||||
 | 
					  white-space: nowrap; /* 防止文本自动换行 */
 | 
				
			||||||
 | 
					  text-overflow: ellipsis; /* 使用省略号表示文本被截断 */
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					.factory-list__wrapper {
 | 
				
			||||||
 | 
					  visibility: hidden;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					  background: #fff;
 | 
				
			||||||
 | 
					  box-shadow: 0 0 32px 10px #0002;
 | 
				
			||||||
 | 
					  border-radius: 8px;
 | 
				
			||||||
 | 
					  top: 36px;
 | 
				
			||||||
 | 
					  // left: 90px;
 | 
				
			||||||
 | 
					  /* max-width: 128px; */
 | 
				
			||||||
 | 
					  height: auto;
 | 
				
			||||||
 | 
					  width: 200px;
 | 
				
			||||||
 | 
					  white-space: nowrap;
 | 
				
			||||||
 | 
					  overflow: hidden;
 | 
				
			||||||
 | 
					  /* transition: all 0.3s ease-out; */
 | 
				
			||||||
 | 
					  z-index: 1000;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.factory-list__wrapper.open {
 | 
				
			||||||
 | 
					  visibility: visible;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ul,
 | 
				
			||||||
 | 
					li {
 | 
				
			||||||
 | 
					  margin: 0;
 | 
				
			||||||
 | 
					  padding: 0;
 | 
				
			||||||
 | 
					  list-style: none;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.factory-list {
 | 
				
			||||||
 | 
					  color: #0008;
 | 
				
			||||||
 | 
					  max-height: 240px;
 | 
				
			||||||
 | 
					  overflow-y: auto;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.factory-list__item {
 | 
				
			||||||
 | 
					  font-size: 16px;
 | 
				
			||||||
 | 
					  line-height: 1;
 | 
				
			||||||
 | 
					  padding: 8px 16px 8px 16px;
 | 
				
			||||||
 | 
					  min-width: 128px;
 | 
				
			||||||
 | 
					  position: relative;
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  align-items: center;
 | 
				
			||||||
 | 
					  justify-content: space-between;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.factory-list__item:hover,
 | 
				
			||||||
 | 
					.factory-list__item.is-current {
 | 
				
			||||||
 | 
					  background: #e3efff;
 | 
				
			||||||
 | 
					  color: #0b58ff;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* .factory-list__item.is-current::after {
 | 
				
			||||||
 | 
						content: '√';
 | 
				
			||||||
 | 
						position: absolute;
 | 
				
			||||||
 | 
						top: 8px;
 | 
				
			||||||
 | 
						right: 16px;
 | 
				
			||||||
 | 
						font-weight: bold;
 | 
				
			||||||
 | 
					} */
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<style>
 | 
				
			||||||
 | 
					.custom-tree-class .el-tree-node__content {
 | 
				
			||||||
 | 
					  width: 100%;
 | 
				
			||||||
 | 
					  height: auto !important;
 | 
				
			||||||
 | 
					  padding: 8px 12px !important;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.custom-tree-class .el-tree-node__content:hover {
 | 
				
			||||||
 | 
					  background: #e3efff;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.custom-tree-class .el-tree-node__children .el-tree-node__content {
 | 
				
			||||||
 | 
					  padding: 8px 18px !important;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.custom-tree-class
 | 
				
			||||||
 | 
					  .el-tree-node__children
 | 
				
			||||||
 | 
					  .el-tree-node__children
 | 
				
			||||||
 | 
					  .el-tree-node__content {
 | 
				
			||||||
 | 
					  padding: 8px 24px !important;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.custom-icon-class {
 | 
				
			||||||
 | 
					  margin-right: 8px;
 | 
				
			||||||
 | 
					  width: 20px;
 | 
				
			||||||
 | 
					  height: 20px;
 | 
				
			||||||
 | 
					  background: url("../assets/images/Qian.png") center center / contain no-repeat;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.custom-icon-class.el-tree-node__expand-icon.expanded {
 | 
				
			||||||
 | 
					  transform: unset;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.el-tree-node__children .custom-icon-class {
 | 
				
			||||||
 | 
					  background: url("../assets/images/tree-icon-2.png") 100% / contain no-repeat;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					.el-tree-node__children .el-tree-node__children .custom-icon-class {
 | 
				
			||||||
 | 
					  background: unset;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										78
									
								
								src/views/system/post/components/SearchBarTop.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,78 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="search-bar-top">
 | 
				
			||||||
 | 
					    <el-form :inline="true">
 | 
				
			||||||
 | 
					      <span class="blue-block"></span>
 | 
				
			||||||
 | 
					      <span class="org-name">组织名称</span>
 | 
				
			||||||
 | 
					      <el-form-item label="用户名">
 | 
				
			||||||
 | 
					        <el-input placeholder="用户名" size="small"></el-input>
 | 
				
			||||||
 | 
					      </el-form-item>
 | 
				
			||||||
 | 
					      <el-form-item>
 | 
				
			||||||
 | 
					        <el-button type="primary" size="small" @click="onSearch"
 | 
				
			||||||
 | 
					          >查询</el-button
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					        <span class="separateStyle"></span>
 | 
				
			||||||
 | 
					        <el-button type="success" size="small" plain @click="addNew"
 | 
				
			||||||
 | 
					          >新增</el-button
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					      </el-form-item>
 | 
				
			||||||
 | 
					    </el-form>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "SearchBarTop",
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      userName: "",
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  mounted() {},
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    onSearch() {
 | 
				
			||||||
 | 
					      console.log("查询");
 | 
				
			||||||
 | 
					      this.$emit("emitFun", { btn: "onSearch", userName: this.userName });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    addNew() {
 | 
				
			||||||
 | 
					      console.log("新增");
 | 
				
			||||||
 | 
					      this.$emit("emitFun", { btn: "addNew" });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.search-bar-top {
 | 
				
			||||||
 | 
					  font-size: 14px;
 | 
				
			||||||
 | 
					  .blue-block {
 | 
				
			||||||
 | 
					    display: inline-block;
 | 
				
			||||||
 | 
					    width: 4px;
 | 
				
			||||||
 | 
					    height: 15px;
 | 
				
			||||||
 | 
					    background-color: #0b58ff;
 | 
				
			||||||
 | 
					    border-radius: 1px;
 | 
				
			||||||
 | 
					    margin-right: 8px;
 | 
				
			||||||
 | 
					    vertical-align: middle;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .org-name {
 | 
				
			||||||
 | 
					    display: inline-block;
 | 
				
			||||||
 | 
					    height: 36px;
 | 
				
			||||||
 | 
					    line-height: 36px;
 | 
				
			||||||
 | 
					    margin-right: 10px;
 | 
				
			||||||
 | 
					    font-size: 14px;
 | 
				
			||||||
 | 
					    color: #606266;
 | 
				
			||||||
 | 
					    font-weight: 700;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .el-form--inline .el-form-item {
 | 
				
			||||||
 | 
					    display: inline-block;
 | 
				
			||||||
 | 
					    margin-right: 10px;
 | 
				
			||||||
 | 
					    vertical-align: top;
 | 
				
			||||||
 | 
					    margin-bottom: 16px;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .separateStyle {
 | 
				
			||||||
 | 
					    display: inline-block;
 | 
				
			||||||
 | 
					    width: 1px;
 | 
				
			||||||
 | 
					    height: 24px;
 | 
				
			||||||
 | 
					    background: #e8e8e8;
 | 
				
			||||||
 | 
					    vertical-align: middle;
 | 
				
			||||||
 | 
					    margin: 0 8px;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										162
									
								
								src/views/system/post/index2.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,162 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <div class="user-manager">
 | 
				
			||||||
 | 
					    <InPageLeftNav />
 | 
				
			||||||
 | 
					    <div
 | 
				
			||||||
 | 
					      class="table-area"
 | 
				
			||||||
 | 
					      :class="{
 | 
				
			||||||
 | 
					        'table-area-w': sidebar.opened,
 | 
				
			||||||
 | 
					        'table-area-ws': !sidebar.opened,
 | 
				
			||||||
 | 
					      }"
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
 | 
					      <SearchBarTop @emitFun="emitFun" />
 | 
				
			||||||
 | 
					      <!-- 列表 -->
 | 
				
			||||||
 | 
					      <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="120"
 | 
				
			||||||
 | 
					          label="操作"
 | 
				
			||||||
 | 
					          :method-list="tableBtn"
 | 
				
			||||||
 | 
					          @clickBtn="handleClick"
 | 
				
			||||||
 | 
					        />
 | 
				
			||||||
 | 
					      </base-table>
 | 
				
			||||||
 | 
					      <pagination
 | 
				
			||||||
 | 
					        :page.sync="queryParams.pageNo"
 | 
				
			||||||
 | 
					        :limit.sync="queryParams.pageSize"
 | 
				
			||||||
 | 
					        :total="total"
 | 
				
			||||||
 | 
					        @pagination="getList"
 | 
				
			||||||
 | 
					      />
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
 | 
					  </div>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import { mapGetters } from "vuex";
 | 
				
			||||||
 | 
					import InPageLeftNav from "./components/InPageLeftNav";
 | 
				
			||||||
 | 
					import SearchBarTop from "./components/SearchBarTop";
 | 
				
			||||||
 | 
					import tableHeightMixin from "@/mixins/tableHeightMixin";
 | 
				
			||||||
 | 
					import { listUser } from "@/api/system/user";
 | 
				
			||||||
 | 
					const tableProps = [
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "username",
 | 
				
			||||||
 | 
					    label: "用户名",
 | 
				
			||||||
 | 
					    minWidth: 120,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "email",
 | 
				
			||||||
 | 
					    label: "邮箱",
 | 
				
			||||||
 | 
					    minWidth: 150,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "mobile",
 | 
				
			||||||
 | 
					    label: "手机号",
 | 
				
			||||||
 | 
					    minWidth: 120,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "deptName",
 | 
				
			||||||
 | 
					    label: "组织",
 | 
				
			||||||
 | 
					    minWidth: 120,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "role",
 | 
				
			||||||
 | 
					    label: "角色名称",
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "workno",
 | 
				
			||||||
 | 
					    label: "工号",
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "status",
 | 
				
			||||||
 | 
					    label: "状态",
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "remark",
 | 
				
			||||||
 | 
					    label: "备注",
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "SystemPost",
 | 
				
			||||||
 | 
					  components: { InPageLeftNav, SearchBarTop },
 | 
				
			||||||
 | 
					  mixins: [tableHeightMixin],
 | 
				
			||||||
 | 
					  computed: {
 | 
				
			||||||
 | 
					    ...mapGetters(["sidebar"]),
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      // 查询参数
 | 
				
			||||||
 | 
					      queryParams: {
 | 
				
			||||||
 | 
					        pageNo: 1,
 | 
				
			||||||
 | 
					        pageSize: 20,
 | 
				
			||||||
 | 
					        name: null,
 | 
				
			||||||
 | 
					        status: null,
 | 
				
			||||||
 | 
					        planFinishTime: [],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      total: 0,
 | 
				
			||||||
 | 
					      tableProps,
 | 
				
			||||||
 | 
					      list: [{ username: "111" }],
 | 
				
			||||||
 | 
					      tableBtn: [
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "authorization",
 | 
				
			||||||
 | 
					          btnName: "授权",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "edit",
 | 
				
			||||||
 | 
					          btnName: "编辑",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					          type: "delete",
 | 
				
			||||||
 | 
					          btnName: "删除",
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      ],
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  created() {
 | 
				
			||||||
 | 
					    this.getList();
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    /** 查询用户列表 */
 | 
				
			||||||
 | 
					    getList() {
 | 
				
			||||||
 | 
					      listUser(this.queryParams).then((response) => {
 | 
				
			||||||
 | 
					        this.list = response.data.list;
 | 
				
			||||||
 | 
					        this.total = response.data.total;
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    emitFun(val) {
 | 
				
			||||||
 | 
					      if (val.btn === "onSearch") {
 | 
				
			||||||
 | 
					        this.queryParams.pageNo = 1;
 | 
				
			||||||
 | 
					        this.getList();
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleClick() {},
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.user-manager {
 | 
				
			||||||
 | 
					  display: flex;
 | 
				
			||||||
 | 
					  .table-area {
 | 
				
			||||||
 | 
					    display: inline-block;
 | 
				
			||||||
 | 
					    height: calc(100vh - 120px - 8px);
 | 
				
			||||||
 | 
					    background-color: #fff;
 | 
				
			||||||
 | 
					    margin-left: 8px;
 | 
				
			||||||
 | 
					    border-radius: 8px;
 | 
				
			||||||
 | 
					    padding: 8px;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .table-area-w {
 | 
				
			||||||
 | 
					    width: calc(100vw - 542px);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  .table-area-ws {
 | 
				
			||||||
 | 
					    width: calc(100vw - 348px);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
							
								
								
									
										162
									
								
								src/views/system/role/components/dataAuth.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,162 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <el-form :model="form" label-width="80px">
 | 
				
			||||||
 | 
					    <el-form-item label="角色名称">
 | 
				
			||||||
 | 
					      <el-input v-model="form.name" :disabled="true" />
 | 
				
			||||||
 | 
					    </el-form-item>
 | 
				
			||||||
 | 
					    <el-form-item label="角色标识">
 | 
				
			||||||
 | 
					      <el-input v-model="form.code" :disabled="true" />
 | 
				
			||||||
 | 
					    </el-form-item>
 | 
				
			||||||
 | 
					    <el-form-item label="权限范围">
 | 
				
			||||||
 | 
					      <el-select v-model="form.dataScope" style="width: 100%">
 | 
				
			||||||
 | 
					        <el-option
 | 
				
			||||||
 | 
					          v-for="item in dataScopeDictDatas"
 | 
				
			||||||
 | 
					          :key="parseInt(item.value)"
 | 
				
			||||||
 | 
					          :label="item.label"
 | 
				
			||||||
 | 
					          :value="parseInt(item.value)"
 | 
				
			||||||
 | 
					        ></el-option>
 | 
				
			||||||
 | 
					      </el-select>
 | 
				
			||||||
 | 
					    </el-form-item>
 | 
				
			||||||
 | 
					    <el-form-item
 | 
				
			||||||
 | 
					      label="数据权限"
 | 
				
			||||||
 | 
					      v-show="form.dataScope === SysDataScopeEnum.DEPT_CUSTOM"
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
 | 
					      <el-checkbox
 | 
				
			||||||
 | 
					        :checked="!form.deptCheckStrictly"
 | 
				
			||||||
 | 
					        @change="handleCheckedTreeConnect($event, 'dept')"
 | 
				
			||||||
 | 
					        >父子联动(选中父节点,自动选择子节点)</el-checkbox
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					      <el-checkbox
 | 
				
			||||||
 | 
					        v-model="deptExpand"
 | 
				
			||||||
 | 
					        @change="handleCheckedTreeExpand($event, 'dept')"
 | 
				
			||||||
 | 
					        >展开/折叠</el-checkbox
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					      <el-checkbox
 | 
				
			||||||
 | 
					        v-model="deptNodeAll"
 | 
				
			||||||
 | 
					        @change="handleCheckedTreeNodeAll($event, 'dept')"
 | 
				
			||||||
 | 
					        >全选/全不选</el-checkbox
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					      <el-tree
 | 
				
			||||||
 | 
					        class="tree-border"
 | 
				
			||||||
 | 
					        :data="deptOptions"
 | 
				
			||||||
 | 
					        show-checkbox
 | 
				
			||||||
 | 
					        default-expand-all
 | 
				
			||||||
 | 
					        ref="dept"
 | 
				
			||||||
 | 
					        node-key="id"
 | 
				
			||||||
 | 
					        :check-strictly="form.deptCheckStrictly"
 | 
				
			||||||
 | 
					        empty-text="加载中,请稍后"
 | 
				
			||||||
 | 
					        :props="defaultProps"
 | 
				
			||||||
 | 
					      ></el-tree>
 | 
				
			||||||
 | 
					    </el-form-item>
 | 
				
			||||||
 | 
					  </el-form>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import { SystemDataScopeEnum } from "@/utils/constants";
 | 
				
			||||||
 | 
					import { getRole } from "@/api/system/role";
 | 
				
			||||||
 | 
					import { listSimpleDepts } from "@/api/system/dept";
 | 
				
			||||||
 | 
					import { DICT_TYPE, getDictDatas } from "@/utils/dict";
 | 
				
			||||||
 | 
					import { assignRoleDataScope } from "@/api/system/permission";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "DataAuth",
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      form: {
 | 
				
			||||||
 | 
					        id: undefined,
 | 
				
			||||||
 | 
					        name: undefined,
 | 
				
			||||||
 | 
					        code: undefined,
 | 
				
			||||||
 | 
					        deptIds: [],
 | 
				
			||||||
 | 
					        dataScope: undefined,
 | 
				
			||||||
 | 
					        deptCheckStrictly: false,
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      deptExpand: true,
 | 
				
			||||||
 | 
					      deptNodeAll: false,
 | 
				
			||||||
 | 
					      // 部门列表
 | 
				
			||||||
 | 
					      deptOptions: [], // 部门属性结构
 | 
				
			||||||
 | 
					      depts: [], // 部门列表
 | 
				
			||||||
 | 
					      defaultProps: {
 | 
				
			||||||
 | 
					        label: "name",
 | 
				
			||||||
 | 
					        children: "children",
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      // 枚举
 | 
				
			||||||
 | 
					      SysDataScopeEnum: SystemDataScopeEnum,
 | 
				
			||||||
 | 
					      // 数据字典
 | 
				
			||||||
 | 
					      dataScopeDictDatas: getDictDatas(DICT_TYPE.SYSTEM_DATA_SCOPE),
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    init(id) {
 | 
				
			||||||
 | 
					      this.form.id = id;
 | 
				
			||||||
 | 
					      getRole(id).then((res) => {
 | 
				
			||||||
 | 
					        this.form.name = res.data.name;
 | 
				
			||||||
 | 
					        this.form.code = res.data.code;
 | 
				
			||||||
 | 
					        this.form.dataScope = res.data.dataScope;
 | 
				
			||||||
 | 
					        // 获得部门列表
 | 
				
			||||||
 | 
					        listSimpleDepts().then((response) => {
 | 
				
			||||||
 | 
					          // 处理 deptOptions 参数
 | 
				
			||||||
 | 
					          this.deptOptions = [];
 | 
				
			||||||
 | 
					          this.deptOptions.push(...this.handleTree(response.data, "id"));
 | 
				
			||||||
 | 
					          this.depts = response.data;
 | 
				
			||||||
 | 
					          this.$refs.dept.setCheckedKeys(res.data.dataScopeDeptIds, false);
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    submitForm() {
 | 
				
			||||||
 | 
					      if (this.form.id !== undefined) {
 | 
				
			||||||
 | 
					        assignRoleDataScope({
 | 
				
			||||||
 | 
					          roleId: this.form.id,
 | 
				
			||||||
 | 
					          dataScope: this.form.dataScope,
 | 
				
			||||||
 | 
					          dataScopeDeptIds:
 | 
				
			||||||
 | 
					            this.form.dataScope !== SystemDataScopeEnum.DEPT_CUSTOM
 | 
				
			||||||
 | 
					              ? []
 | 
				
			||||||
 | 
					              : this.$refs.dept.getCheckedKeys(),
 | 
				
			||||||
 | 
					        }).then((response) => {
 | 
				
			||||||
 | 
					          this.$modal.msgSuccess("修改成功");
 | 
				
			||||||
 | 
					          this.$emit("successSubmitd");
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    formClear() {
 | 
				
			||||||
 | 
					      this.deptExpand = true;
 | 
				
			||||||
 | 
					      this.deptNodeAll = false;
 | 
				
			||||||
 | 
					      this.form = {
 | 
				
			||||||
 | 
					        id: undefined,
 | 
				
			||||||
 | 
					        name: undefined,
 | 
				
			||||||
 | 
					        code: undefined,
 | 
				
			||||||
 | 
					        deptIds: [],
 | 
				
			||||||
 | 
					        dataScope: undefined,
 | 
				
			||||||
 | 
					        deptCheckStrictly: false,
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 树权限(父子联动)
 | 
				
			||||||
 | 
					    handleCheckedTreeConnect(value, type) {
 | 
				
			||||||
 | 
					      if (type === "menu") {
 | 
				
			||||||
 | 
					        this.form.menuCheckStrictly = value;
 | 
				
			||||||
 | 
					      } else if (type === "dept") {
 | 
				
			||||||
 | 
					        this.form.deptCheckStrictly = !value;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 树权限(展开/折叠)
 | 
				
			||||||
 | 
					    handleCheckedTreeExpand(value, type) {
 | 
				
			||||||
 | 
					      if (type === "menu") {
 | 
				
			||||||
 | 
					        let treeList = this.menuOptions;
 | 
				
			||||||
 | 
					        for (let i = 0; i < treeList.length; i++) {
 | 
				
			||||||
 | 
					          this.$refs.menu.store.nodesMap[treeList[i].id].expanded = value;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      } else if (type === "dept") {
 | 
				
			||||||
 | 
					        let treeList = this.deptOptions;
 | 
				
			||||||
 | 
					        for (let i = 0; i < treeList.length; i++) {
 | 
				
			||||||
 | 
					          this.$refs.dept.store.nodesMap[treeList[i].id].expanded = value;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 树权限(全选/全不选)
 | 
				
			||||||
 | 
					    handleCheckedTreeNodeAll(value, type) {
 | 
				
			||||||
 | 
					      if (type === "menu") {
 | 
				
			||||||
 | 
					        this.$refs.menu.setCheckedNodes(value ? this.menuOptions : []);
 | 
				
			||||||
 | 
					      } else if (type === "dept") {
 | 
				
			||||||
 | 
					        // this.$refs.dept.setCheckedNodes(value ? this.deptOptions: []);
 | 
				
			||||||
 | 
					        this.$refs.dept.setCheckedNodes(value ? this.depts : []);
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										146
									
								
								src/views/system/role/components/menuAuth.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,146 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <el-form :model="form" label-width="80px">
 | 
				
			||||||
 | 
					    <el-form-item label="角色名称">
 | 
				
			||||||
 | 
					      <el-input v-model="form.name" :disabled="true" />
 | 
				
			||||||
 | 
					    </el-form-item>
 | 
				
			||||||
 | 
					    <el-form-item label="角色标识">
 | 
				
			||||||
 | 
					      <el-input v-model="form.code" :disabled="true" />
 | 
				
			||||||
 | 
					    </el-form-item>
 | 
				
			||||||
 | 
					    <el-form-item label="菜单权限">
 | 
				
			||||||
 | 
					      <el-checkbox
 | 
				
			||||||
 | 
					        v-model="menuExpand"
 | 
				
			||||||
 | 
					        @change="handleCheckedTreeExpand($event, 'menu')"
 | 
				
			||||||
 | 
					        >展开/折叠</el-checkbox
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					      <el-checkbox
 | 
				
			||||||
 | 
					        v-model="menuNodeAll"
 | 
				
			||||||
 | 
					        @change="handleCheckedTreeNodeAll($event, 'menu')"
 | 
				
			||||||
 | 
					        >全选/全不选</el-checkbox
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					      <el-tree
 | 
				
			||||||
 | 
					        class="tree-border"
 | 
				
			||||||
 | 
					        :data="menuOptions"
 | 
				
			||||||
 | 
					        show-checkbox
 | 
				
			||||||
 | 
					        ref="menu"
 | 
				
			||||||
 | 
					        node-key="id"
 | 
				
			||||||
 | 
					        :check-strictly="form.menuCheckStrictly"
 | 
				
			||||||
 | 
					        empty-text="加载中,请稍后"
 | 
				
			||||||
 | 
					        :props="defaultProps"
 | 
				
			||||||
 | 
					      ></el-tree>
 | 
				
			||||||
 | 
					    </el-form-item>
 | 
				
			||||||
 | 
					  </el-form>
 | 
				
			||||||
 | 
					</template>
 | 
				
			||||||
 | 
					<script>
 | 
				
			||||||
 | 
					import { getRole } from "@/api/system/role";
 | 
				
			||||||
 | 
					import { SystemDataScopeEnum } from "@/utils/constants";
 | 
				
			||||||
 | 
					import { assignRoleMenu, listRoleMenus } from "@/api/system/permission";
 | 
				
			||||||
 | 
					import { DICT_TYPE, getDictDatas } from "@/utils/dict";
 | 
				
			||||||
 | 
					import { listSimpleMenus } from "@/api/system/menu";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "MenuAuth",
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      form: {
 | 
				
			||||||
 | 
					        id: undefined,
 | 
				
			||||||
 | 
					        name: undefined,
 | 
				
			||||||
 | 
					        code: undefined,
 | 
				
			||||||
 | 
					        menuIds: [],
 | 
				
			||||||
 | 
					        menuCheckStrictly: true,
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      // 菜单列表
 | 
				
			||||||
 | 
					      menuOptions: [],
 | 
				
			||||||
 | 
					      menuExpand: false,
 | 
				
			||||||
 | 
					      menuNodeAll: false,
 | 
				
			||||||
 | 
					      SysDataScopeEnum: SystemDataScopeEnum,
 | 
				
			||||||
 | 
					      // 数据字典
 | 
				
			||||||
 | 
					      dataScopeDictDatas: getDictDatas(DICT_TYPE.SYSTEM_DATA_SCOPE),
 | 
				
			||||||
 | 
					      defaultProps: {
 | 
				
			||||||
 | 
					        label: "name",
 | 
				
			||||||
 | 
					        children: "children",
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    init(id) {
 | 
				
			||||||
 | 
					      this.form.id = id;
 | 
				
			||||||
 | 
					      getRole(id).then((res) => {
 | 
				
			||||||
 | 
					        this.form.name = res.data.name;
 | 
				
			||||||
 | 
					        this.form.code = res.data.code;
 | 
				
			||||||
 | 
					        listSimpleMenus().then((response) => {
 | 
				
			||||||
 | 
					          // 处理 menuOptions 参数
 | 
				
			||||||
 | 
					          this.menuOptions = [];
 | 
				
			||||||
 | 
					          this.menuOptions.push(...this.handleTree(response.data, "id"));
 | 
				
			||||||
 | 
					          // 获取角色拥有的菜单权限
 | 
				
			||||||
 | 
					          listRoleMenus(id).then((response) => {
 | 
				
			||||||
 | 
					            // 设置为严格,避免设置父节点自动选中子节点,解决半选中问题
 | 
				
			||||||
 | 
					            this.form.menuCheckStrictly = true;
 | 
				
			||||||
 | 
					            // 设置选中
 | 
				
			||||||
 | 
					            this.$refs.menu.setCheckedKeys(response.data);
 | 
				
			||||||
 | 
					            // 设置为非严格,继续使用半选中
 | 
				
			||||||
 | 
					            this.form.menuCheckStrictly = false;
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    submitForm() {
 | 
				
			||||||
 | 
					      if (this.form.id !== undefined) {
 | 
				
			||||||
 | 
					        assignRoleMenu({
 | 
				
			||||||
 | 
					          roleId: this.form.id,
 | 
				
			||||||
 | 
					          menuIds: [
 | 
				
			||||||
 | 
					            ...this.$refs.menu.getCheckedKeys(),
 | 
				
			||||||
 | 
					            ...this.$refs.menu.getHalfCheckedKeys(),
 | 
				
			||||||
 | 
					          ],
 | 
				
			||||||
 | 
					        }).then((response) => {
 | 
				
			||||||
 | 
					          this.$modal.msgSuccess("修改成功");
 | 
				
			||||||
 | 
					          this.$emit("successSubmitm");
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    formClear() {
 | 
				
			||||||
 | 
					      if (this.$refs.menu !== undefined) {
 | 
				
			||||||
 | 
					        this.$refs.menu.setCheckedKeys([]);
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      this.menuExpand = false;
 | 
				
			||||||
 | 
					      this.menuNodeAll = false;
 | 
				
			||||||
 | 
					      this.form = {
 | 
				
			||||||
 | 
					        id: undefined,
 | 
				
			||||||
 | 
					        name: undefined,
 | 
				
			||||||
 | 
					        code: undefined,
 | 
				
			||||||
 | 
					        menuIds: [],
 | 
				
			||||||
 | 
					        menuCheckStrictly: true,
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 树权限(父子联动)
 | 
				
			||||||
 | 
					    handleCheckedTreeConnect(value, type) {
 | 
				
			||||||
 | 
					      if (type === "menu") {
 | 
				
			||||||
 | 
					        this.form.menuCheckStrictly = value;
 | 
				
			||||||
 | 
					      } else if (type === "dept") {
 | 
				
			||||||
 | 
					        this.form.deptCheckStrictly = !value;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 树权限(展开/折叠)
 | 
				
			||||||
 | 
					    handleCheckedTreeExpand(value, type) {
 | 
				
			||||||
 | 
					      if (type === "menu") {
 | 
				
			||||||
 | 
					        let treeList = this.menuOptions;
 | 
				
			||||||
 | 
					        for (let i = 0; i < treeList.length; i++) {
 | 
				
			||||||
 | 
					          this.$refs.menu.store.nodesMap[treeList[i].id].expanded = value;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      } else if (type === "dept") {
 | 
				
			||||||
 | 
					        let treeList = this.deptOptions;
 | 
				
			||||||
 | 
					        for (let i = 0; i < treeList.length; i++) {
 | 
				
			||||||
 | 
					          this.$refs.dept.store.nodesMap[treeList[i].id].expanded = value;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 树权限(全选/全不选)
 | 
				
			||||||
 | 
					    handleCheckedTreeNodeAll(value, type) {
 | 
				
			||||||
 | 
					      if (type === "menu") {
 | 
				
			||||||
 | 
					        this.$refs.menu.setCheckedNodes(value ? this.menuOptions : []);
 | 
				
			||||||
 | 
					      } else if (type === "dept") {
 | 
				
			||||||
 | 
					        // this.$refs.dept.setCheckedNodes(value ? this.deptOptions: []);
 | 
				
			||||||
 | 
					        this.$refs.dept.setCheckedNodes(value ? this.depts : []);
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
							
								
								
									
										129
									
								
								src/views/system/role/components/roleAdd.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						@@ -0,0 +1,129 @@
 | 
				
			|||||||
 | 
					<template>
 | 
				
			||||||
 | 
					  <el-form ref="form" :rules="rules" label-width="100px" :model="form">
 | 
				
			||||||
 | 
					    <el-row>
 | 
				
			||||||
 | 
					      <el-col :span="24">
 | 
				
			||||||
 | 
					        <el-form-item label="角色编码" prop="code">
 | 
				
			||||||
 | 
					          <el-input v-model="form.code"></el-input>
 | 
				
			||||||
 | 
					        </el-form-item>
 | 
				
			||||||
 | 
					      </el-col>
 | 
				
			||||||
 | 
					      <el-col :span="24">
 | 
				
			||||||
 | 
					        <el-form-item label="角色名称" prop="name">
 | 
				
			||||||
 | 
					          <el-input v-model="form.name"></el-input>
 | 
				
			||||||
 | 
					        </el-form-item>
 | 
				
			||||||
 | 
					      </el-col>
 | 
				
			||||||
 | 
					    </el-row>
 | 
				
			||||||
 | 
					    <el-row>
 | 
				
			||||||
 | 
					      <el-col :span="12">
 | 
				
			||||||
 | 
					        <el-form-item label="角色顺序" prop="sort">
 | 
				
			||||||
 | 
					          <el-input-number
 | 
				
			||||||
 | 
					            v-model="form.sort"
 | 
				
			||||||
 | 
					            controls-position="right"
 | 
				
			||||||
 | 
					            :min="1"
 | 
				
			||||||
 | 
					            :max="999999999"
 | 
				
			||||||
 | 
					            style="width: 100%"
 | 
				
			||||||
 | 
					          ></el-input-number>
 | 
				
			||||||
 | 
					        </el-form-item>
 | 
				
			||||||
 | 
					      </el-col>
 | 
				
			||||||
 | 
					      <el-col :span="12">
 | 
				
			||||||
 | 
					        <el-form-item label="状态" prop="status" v-if="isEdit">
 | 
				
			||||||
 | 
					          <el-switch v-model="form.status"> </el-switch>
 | 
				
			||||||
 | 
					        </el-form-item>
 | 
				
			||||||
 | 
					      </el-col>
 | 
				
			||||||
 | 
					      <el-col :span="24">
 | 
				
			||||||
 | 
					        <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 { addRole, getRole, updateRole } from "@/api/system/role";
 | 
				
			||||||
 | 
					export default {
 | 
				
			||||||
 | 
					  name: "RoleAdd",
 | 
				
			||||||
 | 
					  data() {
 | 
				
			||||||
 | 
					    return {
 | 
				
			||||||
 | 
					      form: {
 | 
				
			||||||
 | 
					        id: "",
 | 
				
			||||||
 | 
					        code: "",
 | 
				
			||||||
 | 
					        name: "",
 | 
				
			||||||
 | 
					        sort: 1,
 | 
				
			||||||
 | 
					        status: 0,
 | 
				
			||||||
 | 
					        remark: "",
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      isEdit: false, //是否是编辑
 | 
				
			||||||
 | 
					      rules: {
 | 
				
			||||||
 | 
					        code: [
 | 
				
			||||||
 | 
					          { required: true, message: "角色编码不能为空", trigger: "blur" },
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        name: [
 | 
				
			||||||
 | 
					          { required: true, message: "角色名称不能为空", trigger: "blur" },
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        sort: [{ required: true }],
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  methods: {
 | 
				
			||||||
 | 
					    init(id) {
 | 
				
			||||||
 | 
					      if (id) {
 | 
				
			||||||
 | 
					        this.isEdit = true;
 | 
				
			||||||
 | 
					        this.form.id = id;
 | 
				
			||||||
 | 
					        getRole(id).then((res) => {
 | 
				
			||||||
 | 
					          if (res.code === 0) {
 | 
				
			||||||
 | 
					            this.form.id = res.data.id;
 | 
				
			||||||
 | 
					            this.form.code = res.data.code;
 | 
				
			||||||
 | 
					            this.form.name = res.data.name;
 | 
				
			||||||
 | 
					            this.form.sort = res.data.sort;
 | 
				
			||||||
 | 
					            this.form.remark = res.data.remark;
 | 
				
			||||||
 | 
					            this.form.status = res.data.status ? false : true;
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        });
 | 
				
			||||||
 | 
					      } else {
 | 
				
			||||||
 | 
					        this.isEdit = false;
 | 
				
			||||||
 | 
					        this.form.id = "";
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    submitForm() {
 | 
				
			||||||
 | 
					      this.$refs["form"].validate((valid) => {
 | 
				
			||||||
 | 
					        if (valid) {
 | 
				
			||||||
 | 
					          if (this.isEdit) {
 | 
				
			||||||
 | 
					            //编辑
 | 
				
			||||||
 | 
					            updateRole({
 | 
				
			||||||
 | 
					              id: this.form.id,
 | 
				
			||||||
 | 
					              code: this.form.code,
 | 
				
			||||||
 | 
					              name: this.form.name,
 | 
				
			||||||
 | 
					              sort: this.form.sort,
 | 
				
			||||||
 | 
					              remark: this.form.remark,
 | 
				
			||||||
 | 
					              status: this.form.status ? 0 : 1,
 | 
				
			||||||
 | 
					            }).then((res) => {
 | 
				
			||||||
 | 
					              if (res.code === 0) {
 | 
				
			||||||
 | 
					                this.$modal.msgSuccess("操作成功");
 | 
				
			||||||
 | 
					                this.$emit("successSubmit");
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					          } else {
 | 
				
			||||||
 | 
					            addRole({
 | 
				
			||||||
 | 
					              code: this.form.code,
 | 
				
			||||||
 | 
					              name: this.form.name,
 | 
				
			||||||
 | 
					              sort: this.form.sort,
 | 
				
			||||||
 | 
					              remark: this.form.remark,
 | 
				
			||||||
 | 
					              status: 0,
 | 
				
			||||||
 | 
					            }).then((res) => {
 | 
				
			||||||
 | 
					              if (res.code === 0) {
 | 
				
			||||||
 | 
					                this.$modal.msgSuccess("操作成功");
 | 
				
			||||||
 | 
					                this.$emit("successSubmit");
 | 
				
			||||||
 | 
					              }
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        } else {
 | 
				
			||||||
 | 
					          return false;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    formClear() {
 | 
				
			||||||
 | 
					      this.$refs.form.resetFields();
 | 
				
			||||||
 | 
					      this.isEdit = false;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					</script>
 | 
				
			||||||
@@ -1,250 +1,181 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="app-container">
 | 
					  <div class="app-container">
 | 
				
			||||||
    <doc-alert title="功能权限" url="https://doc.iocoder.cn/resource-permission" />
 | 
					    <!-- <doc-alert
 | 
				
			||||||
    <doc-alert title="数据权限" url="https://doc.iocoder.cn/data-permission" />
 | 
					      title="功能权限"
 | 
				
			||||||
    <el-form :model="queryParams" ref="queryForm" v-show="showSearch" :inline="true">
 | 
					      url="https://doc.iocoder.cn/resource-permission"
 | 
				
			||||||
      <el-form-item label="角色名称" prop="name">
 | 
					    />
 | 
				
			||||||
        <el-input v-model="queryParams.name" placeholder="请输入角色名称" clearable size="small" style="width: 240px"
 | 
					    <doc-alert title="数据权限" url="https://doc.iocoder.cn/data-permission" /> -->
 | 
				
			||||||
                  @keyup.enter.native="handleQuery"/>
 | 
					    <!-- 搜索工作栏 -->
 | 
				
			||||||
      </el-form-item>
 | 
					    <search-bar
 | 
				
			||||||
      <el-form-item label="角色标识" prop="code">
 | 
					      :formConfigs="formConfig"
 | 
				
			||||||
        <el-input v-model="queryParams.code" placeholder="请输入角色标识" clearable size="small" style="width: 240px"
 | 
					      ref="searchBarForm"
 | 
				
			||||||
                  @keyup.enter.native="handleQuery"/>
 | 
					      @headBtnClick="buttonClick"
 | 
				
			||||||
      </el-form-item>
 | 
					    />
 | 
				
			||||||
      <el-form-item label="状态" prop="status">
 | 
					    <!-- 列表 -->
 | 
				
			||||||
        <el-select v-model="queryParams.status" placeholder="角色状态" clearable size="small" style="width: 240px">
 | 
					    <base-table
 | 
				
			||||||
          <el-option v-for="dict in statusDictDatas" :key="parseInt(dict.value)" :label="dict.label" :value="parseInt(dict.value)"/>
 | 
					      :page="queryParams.pageNo"
 | 
				
			||||||
        </el-select>
 | 
					      :limit="queryParams.pageSize"
 | 
				
			||||||
      </el-form-item>
 | 
					      :table-props="tableProps"
 | 
				
			||||||
      <el-form-item label="创建时间" prop="createTime">
 | 
					      :table-data="list"
 | 
				
			||||||
        <el-date-picker v-model="queryParams.createTime" style="width: 240px" value-format="yyyy-MM-dd HH:mm:ss" type="daterange"
 | 
					      :max-height="tableH"
 | 
				
			||||||
                        range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" :default-time="['00:00:00', '23:59:59']" />
 | 
					    >
 | 
				
			||||||
      </el-form-item>
 | 
					      <method-btn
 | 
				
			||||||
      <el-form-item>
 | 
					        v-if="tableBtn.length"
 | 
				
			||||||
        <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
 | 
					        slot="handleBtn"
 | 
				
			||||||
        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
 | 
					        :width="230"
 | 
				
			||||||
      </el-form-item>
 | 
					        label="操作"
 | 
				
			||||||
    </el-form>
 | 
					        :method-list="tableBtn"
 | 
				
			||||||
 | 
					        @clickBtn="handleClick"
 | 
				
			||||||
 | 
					      />
 | 
				
			||||||
 | 
					    </base-table>
 | 
				
			||||||
 | 
					    <pagination
 | 
				
			||||||
 | 
					      :page.sync="queryParams.pageNo"
 | 
				
			||||||
 | 
					      :limit.sync="queryParams.pageSize"
 | 
				
			||||||
 | 
					      :total="total"
 | 
				
			||||||
 | 
					      @pagination="getList"
 | 
				
			||||||
 | 
					    />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <el-row :gutter="10" class="mb8">
 | 
					    <!-- 新增&编辑 -->
 | 
				
			||||||
      <el-col :span="1.5">
 | 
					    <base-dialog
 | 
				
			||||||
        <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
 | 
					      :dialogTitle="addOrEditTitle"
 | 
				
			||||||
                   v-hasPermi="['system:role:create']">新增</el-button>
 | 
					      :dialogVisible="centervisible"
 | 
				
			||||||
      </el-col>
 | 
					      @cancel="handleCancel"
 | 
				
			||||||
      <el-col :span="1.5">
 | 
					      @confirm="handleConfirm"
 | 
				
			||||||
        <el-button type="warning" icon="el-icon-download" size="mini" @click="handleExport" :loading="exportLoading"
 | 
					      :before-close="handleCancel"
 | 
				
			||||||
                   v-hasPermi="['system:role:export']">导出</el-button>
 | 
					      width="50%"
 | 
				
			||||||
      </el-col>
 | 
					    >
 | 
				
			||||||
      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
 | 
					      <role-add ref="roleAdd" @successSubmit="successSubmit" />
 | 
				
			||||||
    </el-row>
 | 
					    </base-dialog>
 | 
				
			||||||
 | 
					    <!-- 菜单权限 -->
 | 
				
			||||||
    <el-table v-loading="loading" :data="roleList">
 | 
					    <base-dialog
 | 
				
			||||||
      <el-table-column label="角色编号" prop="id" width="120" />
 | 
					      dialogTitle="分配菜单权限"
 | 
				
			||||||
      <el-table-column label="角色名称" prop="name" :show-overflow-tooltip="true" width="150" />
 | 
					      :dialogVisible="menuVisible"
 | 
				
			||||||
      <el-table-column label="角色标识" prop="code" :show-overflow-tooltip="true" width="150" />
 | 
					      @cancel="handleCancelm"
 | 
				
			||||||
      <el-table-column label="角色类型" prop="type" width="80">
 | 
					      @confirm="handleConfirmm"
 | 
				
			||||||
        <template v-slot="scope">
 | 
					      :before-close="handleCancelm"
 | 
				
			||||||
          <dict-tag :type="DICT_TYPE.SYSTEM_ROLE_TYPE" :value="scope.row.type"/>
 | 
					      width="50%"
 | 
				
			||||||
        </template>
 | 
					    >
 | 
				
			||||||
      </el-table-column>
 | 
					      <menu-auth ref="menuAuth" @successSubmitm="successSubmitm" />
 | 
				
			||||||
      <el-table-column label="显示顺序" prop="sort" width="100" />
 | 
					    </base-dialog>
 | 
				
			||||||
      <el-table-column label="状态" align="center" width="100">
 | 
					    <!-- 数据权限 -->
 | 
				
			||||||
        <template v-slot="scope">
 | 
					    <base-dialog
 | 
				
			||||||
          <el-switch v-model="scope.row.status" :active-value="0" :inactive-value="1" @change="handleStatusChange(scope.row)"/>
 | 
					      dialogTitle="分配数据权限"
 | 
				
			||||||
        </template>
 | 
					      :dialogVisible="dataVisible"
 | 
				
			||||||
      </el-table-column>
 | 
					      @cancel="handleCanceld"
 | 
				
			||||||
      <el-table-column label="创建时间" align="center" prop="createTime" width="180">
 | 
					      @confirm="handleConfirmd"
 | 
				
			||||||
        <template v-slot="scope">
 | 
					      :before-close="handleCanceld"
 | 
				
			||||||
          <span>{{ parseTime(scope.row.createTime) }}</span>
 | 
					      width="50%"
 | 
				
			||||||
        </template>
 | 
					    >
 | 
				
			||||||
      </el-table-column>
 | 
					      <data-auth ref="dataAuth" @successSubmitd="successSubmitd" />
 | 
				
			||||||
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
 | 
					    </base-dialog>
 | 
				
			||||||
        <template v-slot="scope">
 | 
					 | 
				
			||||||
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
 | 
					 | 
				
			||||||
                     v-hasPermi="['system:role:update']">修改</el-button>
 | 
					 | 
				
			||||||
          <el-button size="mini" type="text" icon="el-icon-circle-check" @click="handleMenu(scope.row)"
 | 
					 | 
				
			||||||
                     v-hasPermi="['system:permission:assign-role-menu']">菜单权限</el-button>
 | 
					 | 
				
			||||||
          <el-button size="mini" type="text" icon="el-icon-circle-check" @click="handleDataScope(scope.row)"
 | 
					 | 
				
			||||||
                     v-hasPermi="['system:permission:assign-role-data-scope']">数据权限</el-button>
 | 
					 | 
				
			||||||
          <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
 | 
					 | 
				
			||||||
                     v-hasPermi="['system:role:delete']">删除</el-button>
 | 
					 | 
				
			||||||
        </template>
 | 
					 | 
				
			||||||
      </el-table-column>
 | 
					 | 
				
			||||||
    </el-table>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    <pagination v-show="total>0" :total="total" :page.sync="queryParams.pageNo" :limit.sync="queryParams.pageSize"
 | 
					 | 
				
			||||||
                @pagination="getList"/>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    <!-- 添加或修改角色配置对话框 -->
 | 
					 | 
				
			||||||
    <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
 | 
					 | 
				
			||||||
      <el-form ref="form" :model="form" :rules="rules" label-width="80px">
 | 
					 | 
				
			||||||
        <el-form-item label="角色名称" prop="name">
 | 
					 | 
				
			||||||
          <el-input v-model="form.name" placeholder="请输入角色名称" />
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
        <el-form-item label="角色标识" prop="code">
 | 
					 | 
				
			||||||
          <el-input v-model="form.code" placeholder="请输入角色标识" />
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
        <el-form-item label="角色顺序" prop="sort">
 | 
					 | 
				
			||||||
          <el-input-number v-model="form.sort" controls-position="right" :min="0" />
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
        <el-form-item label="备注">
 | 
					 | 
				
			||||||
          <el-input v-model="form.remark" type="textarea" placeholder="请输入内容"></el-input>
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
      </el-form>
 | 
					 | 
				
			||||||
      <div slot="footer" class="dialog-footer">
 | 
					 | 
				
			||||||
        <el-button type="primary" @click="submitForm">确 定</el-button>
 | 
					 | 
				
			||||||
        <el-button @click="cancel">取 消</el-button>
 | 
					 | 
				
			||||||
      </div>
 | 
					 | 
				
			||||||
    </el-dialog>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    <!-- 分配角色的数据权限对话框 -->
 | 
					 | 
				
			||||||
    <el-dialog title="分配数据权限" :visible.sync="openDataScope" width="500px" append-to-body>
 | 
					 | 
				
			||||||
      <el-form :model="form" label-width="80px">
 | 
					 | 
				
			||||||
        <el-form-item label="角色名称">
 | 
					 | 
				
			||||||
          <el-input v-model="form.name" :disabled="true" />
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
        <el-form-item label="角色标识">
 | 
					 | 
				
			||||||
          <el-input v-model="form.code" :disabled="true" />
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
        <el-form-item label="权限范围">
 | 
					 | 
				
			||||||
          <el-select v-model="form.dataScope">
 | 
					 | 
				
			||||||
            <el-option
 | 
					 | 
				
			||||||
              v-for="item in dataScopeDictDatas"
 | 
					 | 
				
			||||||
              :key="parseInt(item.value)"
 | 
					 | 
				
			||||||
              :label="item.label"
 | 
					 | 
				
			||||||
              :value="parseInt(item.value)"
 | 
					 | 
				
			||||||
            ></el-option>
 | 
					 | 
				
			||||||
          </el-select>
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
        <el-form-item label="数据权限" v-show="form.dataScope === SysDataScopeEnum.DEPT_CUSTOM">
 | 
					 | 
				
			||||||
          <el-checkbox :checked="!form.deptCheckStrictly" @change="handleCheckedTreeConnect($event, 'dept')">父子联动(选中父节点,自动选择子节点)</el-checkbox>
 | 
					 | 
				
			||||||
          <el-checkbox v-model="deptExpand" @change="handleCheckedTreeExpand($event, 'dept')">展开/折叠</el-checkbox>
 | 
					 | 
				
			||||||
          <el-checkbox v-model="deptNodeAll" @change="handleCheckedTreeNodeAll($event, 'dept')">全选/全不选</el-checkbox>
 | 
					 | 
				
			||||||
          <el-tree
 | 
					 | 
				
			||||||
            class="tree-border"
 | 
					 | 
				
			||||||
            :data="deptOptions"
 | 
					 | 
				
			||||||
            show-checkbox
 | 
					 | 
				
			||||||
            default-expand-all
 | 
					 | 
				
			||||||
            ref="dept"
 | 
					 | 
				
			||||||
            node-key="id"
 | 
					 | 
				
			||||||
            :check-strictly="form.deptCheckStrictly"
 | 
					 | 
				
			||||||
            empty-text="加载中,请稍后"
 | 
					 | 
				
			||||||
            :props="defaultProps"
 | 
					 | 
				
			||||||
          ></el-tree>
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
      </el-form>
 | 
					 | 
				
			||||||
      <div slot="footer" class="dialog-footer">
 | 
					 | 
				
			||||||
        <el-button type="primary" @click="submitDataScope">确 定</el-button>
 | 
					 | 
				
			||||||
        <el-button @click="cancelDataScope">取 消</el-button>
 | 
					 | 
				
			||||||
      </div>
 | 
					 | 
				
			||||||
    </el-dialog>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    <!-- 分配角色的菜单权限对话框 -->
 | 
					 | 
				
			||||||
    <el-dialog :title="title" :visible.sync="openMenu" width="500px" append-to-body>
 | 
					 | 
				
			||||||
      <el-form :model="form" label-width="80px">
 | 
					 | 
				
			||||||
        <el-form-item label="角色名称">
 | 
					 | 
				
			||||||
          <el-input v-model="form.name" :disabled="true" />
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
        <el-form-item label="角色标识">
 | 
					 | 
				
			||||||
          <el-input v-model="form.code" :disabled="true" />
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
        <el-form-item label="菜单权限">
 | 
					 | 
				
			||||||
          <el-checkbox v-model="menuExpand" @change="handleCheckedTreeExpand($event, 'menu')">展开/折叠</el-checkbox>
 | 
					 | 
				
			||||||
          <el-checkbox v-model="menuNodeAll" @change="handleCheckedTreeNodeAll($event, 'menu')">全选/全不选</el-checkbox>
 | 
					 | 
				
			||||||
          <el-tree class="tree-border" :data="menuOptions" show-checkbox ref="menu" node-key="id"
 | 
					 | 
				
			||||||
              :check-strictly="form.menuCheckStrictly" empty-text="加载中,请稍后" :props="defaultProps"></el-tree>
 | 
					 | 
				
			||||||
        </el-form-item>
 | 
					 | 
				
			||||||
      </el-form>
 | 
					 | 
				
			||||||
      <div slot="footer" class="dialog-footer">
 | 
					 | 
				
			||||||
        <el-button type="primary" @click="submitMenu">确 定</el-button>
 | 
					 | 
				
			||||||
        <el-button @click="cancelMenu">取 消</el-button>
 | 
					 | 
				
			||||||
      </div>
 | 
					 | 
				
			||||||
    </el-dialog>
 | 
					 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
import {
 | 
					import { delRole, listRole } from "@/api/system/role";
 | 
				
			||||||
  addRole,
 | 
					import tableHeightMixin from "@/mixins/tableHeightMixin";
 | 
				
			||||||
  changeRoleStatus,
 | 
					import RoleAdd from "./components/roleAdd";
 | 
				
			||||||
  delRole,
 | 
					import MenuAuth from "./components/menuAuth";
 | 
				
			||||||
  exportRole,
 | 
					import DataAuth from "./components/dataAuth";
 | 
				
			||||||
  getRole,
 | 
					import statusBtn from "./../components/statusBtn.vue";
 | 
				
			||||||
  listRole,
 | 
					const tableProps = [
 | 
				
			||||||
  updateRole
 | 
					  {
 | 
				
			||||||
} from "@/api/system/role";
 | 
					    prop: "code",
 | 
				
			||||||
import {listSimpleMenus} from "@/api/system/menu";
 | 
					    label: "角色编码",
 | 
				
			||||||
import {assignRoleMenu, listRoleMenus, assignRoleDataScope} from "@/api/system/permission";
 | 
					    minWidth: 140,
 | 
				
			||||||
import {listSimpleDepts} from "@/api/system/dept";
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
import {CommonStatusEnum, SystemDataScopeEnum} from "@/utils/constants";
 | 
					  },
 | 
				
			||||||
import {DICT_TYPE, getDictDatas} from "@/utils/dict";
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "name",
 | 
				
			||||||
 | 
					    label: "角色名称",
 | 
				
			||||||
 | 
					    minWidth: 140,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "status",
 | 
				
			||||||
 | 
					    label: "状态",
 | 
				
			||||||
 | 
					    minWidth: 100,
 | 
				
			||||||
 | 
					    subcomponent: statusBtn,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    prop: "remark",
 | 
				
			||||||
 | 
					    label: "角色描述",
 | 
				
			||||||
 | 
					    minWidth: 140,
 | 
				
			||||||
 | 
					    showOverflowtooltip: true,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
export default {
 | 
					export default {
 | 
				
			||||||
  name: "SystemRole",
 | 
					  name: "SystemRole",
 | 
				
			||||||
 | 
					  mixins: [tableHeightMixin],
 | 
				
			||||||
 | 
					  components: { RoleAdd, MenuAuth, DataAuth },
 | 
				
			||||||
  data() {
 | 
					  data() {
 | 
				
			||||||
    return {
 | 
					    return {
 | 
				
			||||||
      // 遮罩层
 | 
					      formConfig: [
 | 
				
			||||||
      loading: true,
 | 
					        {
 | 
				
			||||||
      // 导出遮罩层
 | 
					          type: "input",
 | 
				
			||||||
      exportLoading: false,
 | 
					          label: "角色名称",
 | 
				
			||||||
      // 显示搜索条件
 | 
					          placeholder: "角色名称",
 | 
				
			||||||
      showSearch: true,
 | 
					          param: "name",
 | 
				
			||||||
      // 总条数
 | 
					        },
 | 
				
			||||||
      total: 0,
 | 
					        {
 | 
				
			||||||
      // 角色表格数据
 | 
					          type: "button",
 | 
				
			||||||
      roleList: [],
 | 
					          btnName: "查询",
 | 
				
			||||||
      // 弹出层标题
 | 
					          name: "search",
 | 
				
			||||||
      title: "",
 | 
					          color: "primary",
 | 
				
			||||||
      // 是否显示弹出层
 | 
					        },
 | 
				
			||||||
      open: false,
 | 
					        {
 | 
				
			||||||
      // 是否显示弹出层(数据权限)
 | 
					          type: this.$auth.hasPermi("system:role:create") ? "separate" : "",
 | 
				
			||||||
      openDataScope: false,
 | 
					        },
 | 
				
			||||||
      // 是否显示弹出层(菜单权限)
 | 
					        {
 | 
				
			||||||
      openMenu: false,
 | 
					          type: this.$auth.hasPermi("system:role:create") ? "button" : "",
 | 
				
			||||||
      menuExpand: false,
 | 
					          btnName: "新增",
 | 
				
			||||||
      menuNodeAll: false,
 | 
					          name: "add",
 | 
				
			||||||
      deptExpand: true,
 | 
					          color: "success",
 | 
				
			||||||
      deptNodeAll: false,
 | 
					          plain: true,
 | 
				
			||||||
      // 菜单列表
 | 
					        },
 | 
				
			||||||
      menuOptions: [],
 | 
					      ],
 | 
				
			||||||
      // 部门列表
 | 
					 | 
				
			||||||
      deptOptions: [], // 部门属性结构
 | 
					 | 
				
			||||||
      depts: [], // 部门列表
 | 
					 | 
				
			||||||
      // 查询参数
 | 
					 | 
				
			||||||
      queryParams: {
 | 
					      queryParams: {
 | 
				
			||||||
        pageNo: 1,
 | 
					        pageNo: 1,
 | 
				
			||||||
        pageSize: 10,
 | 
					        pageSize: 20,
 | 
				
			||||||
        name: undefined,
 | 
					        name: "",
 | 
				
			||||||
        code: undefined,
 | 
					 | 
				
			||||||
        status: undefined,
 | 
					 | 
				
			||||||
        createTime: []
 | 
					 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
      // 表单参数
 | 
					      tableProps,
 | 
				
			||||||
      form: {},
 | 
					      list: [],
 | 
				
			||||||
      defaultProps: {
 | 
					      tableBtn: [
 | 
				
			||||||
        label: "name",
 | 
					        this.$auth.hasPermi("system:permission:assign-role-menu")
 | 
				
			||||||
        children: "children"
 | 
					          ? {
 | 
				
			||||||
      },
 | 
					              type: "menuAuth",
 | 
				
			||||||
      // 表单校验
 | 
					              btnName: "菜单权限",
 | 
				
			||||||
      rules: {
 | 
					            }
 | 
				
			||||||
        name: [
 | 
					          : undefined,
 | 
				
			||||||
          { required: true, message: "角色名称不能为空", trigger: "blur" }
 | 
					        this.$auth.hasPermi("system:permission:assign-role-data-scope")
 | 
				
			||||||
        ],
 | 
					          ? {
 | 
				
			||||||
        code: [
 | 
					              type: "dataAuth",
 | 
				
			||||||
          { required: true, message: "角色标识不能为空", trigger: "blur" }
 | 
					              btnName: "数据权限",
 | 
				
			||||||
        ],
 | 
					              // showTip: "新增工单",
 | 
				
			||||||
        sort: [
 | 
					            }
 | 
				
			||||||
          { required: true, message: "角色顺序不能为空", trigger: "blur" }
 | 
					          : undefined,
 | 
				
			||||||
        ]
 | 
					        this.$auth.hasPermi("system:role:update")
 | 
				
			||||||
      },
 | 
					          ? {
 | 
				
			||||||
 | 
					              type: "edit",
 | 
				
			||||||
      // 枚举
 | 
					              btnName: "编辑",
 | 
				
			||||||
      SysCommonStatusEnum: CommonStatusEnum,
 | 
					            }
 | 
				
			||||||
      SysDataScopeEnum: SystemDataScopeEnum,
 | 
					          : undefined,
 | 
				
			||||||
      // 数据字典
 | 
					        this.$auth.hasPermi("system:role:delete")
 | 
				
			||||||
      roleTypeDictDatas: getDictDatas(DICT_TYPE.SYSTEM_ROLE_TYPE),
 | 
					          ? {
 | 
				
			||||||
      statusDictDatas: getDictDatas(DICT_TYPE.COMMON_STATUS),
 | 
					              type: "delete",
 | 
				
			||||||
      dataScopeDictDatas: getDictDatas(DICT_TYPE.SYSTEM_DATA_SCOPE)
 | 
					              btnName: "删除",
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					          : undefined,
 | 
				
			||||||
 | 
					      ].filter((v) => v),
 | 
				
			||||||
 | 
					      addOrEditTitle: "",
 | 
				
			||||||
 | 
					      centervisible: false,
 | 
				
			||||||
 | 
					      // 菜单权限
 | 
				
			||||||
 | 
					      menuVisible: false,
 | 
				
			||||||
 | 
					      // 数据权限
 | 
				
			||||||
 | 
					      dataVisible: false,
 | 
				
			||||||
 | 
					      // 总条数
 | 
				
			||||||
 | 
					      total: 0,
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  created() {
 | 
					  created() {
 | 
				
			||||||
@@ -253,243 +184,109 @@ export default {
 | 
				
			|||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
    /** 查询角色列表 */
 | 
					    /** 查询角色列表 */
 | 
				
			||||||
    getList() {
 | 
					    getList() {
 | 
				
			||||||
      this.loading = true;
 | 
					      listRole(this.queryParams).then((response) => {
 | 
				
			||||||
      listRole(this.queryParams).then(
 | 
					        this.list = response.data.list;
 | 
				
			||||||
        response => {
 | 
					 | 
				
			||||||
          this.roleList = response.data.list;
 | 
					 | 
				
			||||||
        this.total = response.data.total;
 | 
					        this.total = response.data.total;
 | 
				
			||||||
          this.loading = false;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      );
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    // 角色状态修改
 | 
					 | 
				
			||||||
    handleStatusChange(row) {
 | 
					 | 
				
			||||||
      // 此时,row 已经变成目标状态了,所以可以直接提交请求和提示
 | 
					 | 
				
			||||||
      let text = row.status === CommonStatusEnum.ENABLE ? "启用" : "停用";
 | 
					 | 
				
			||||||
      this.$modal.confirm('确认要"' + text + '""' + row.name + '"角色吗?').then(function() {
 | 
					 | 
				
			||||||
          return changeRoleStatus(row.id, row.status);
 | 
					 | 
				
			||||||
        }).then(() => {
 | 
					 | 
				
			||||||
          this.$modal.msgSuccess(text + "成功");
 | 
					 | 
				
			||||||
        }).catch(function() {
 | 
					 | 
				
			||||||
          // 异常时,需要将 row.status 状态重置回之前的
 | 
					 | 
				
			||||||
          row.status = row.status === CommonStatusEnum.ENABLE ? CommonStatusEnum.DISABLE
 | 
					 | 
				
			||||||
              : CommonStatusEnum.ENABLE;
 | 
					 | 
				
			||||||
      });
 | 
					      });
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    // 取消按钮
 | 
					    buttonClick(val) {
 | 
				
			||||||
    cancel() {
 | 
					      console.log(val);
 | 
				
			||||||
      this.open = false;
 | 
					      if (val.btnName === "search") {
 | 
				
			||||||
      this.reset();
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    // 取消按钮(数据权限)
 | 
					 | 
				
			||||||
    cancelDataScope() {
 | 
					 | 
				
			||||||
      this.openDataScope = false;
 | 
					 | 
				
			||||||
      this.reset();
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    // 取消按钮(菜单权限)
 | 
					 | 
				
			||||||
    cancelMenu() {
 | 
					 | 
				
			||||||
      this.openMenu = false;
 | 
					 | 
				
			||||||
      this.reset();
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    // 表单重置
 | 
					 | 
				
			||||||
    reset() {
 | 
					 | 
				
			||||||
      if (this.$refs.menu !== undefined) {
 | 
					 | 
				
			||||||
        this.$refs.menu.setCheckedKeys([]);
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      this.menuExpand = false;
 | 
					 | 
				
			||||||
      this.menuNodeAll = false;
 | 
					 | 
				
			||||||
      this.deptExpand = true;
 | 
					 | 
				
			||||||
      this.deptNodeAll = false;
 | 
					 | 
				
			||||||
      this.form = {
 | 
					 | 
				
			||||||
        id: undefined,
 | 
					 | 
				
			||||||
        name: undefined,
 | 
					 | 
				
			||||||
        code: undefined,
 | 
					 | 
				
			||||||
        sort: 0,
 | 
					 | 
				
			||||||
        deptIds: [],
 | 
					 | 
				
			||||||
        menuIds: [],
 | 
					 | 
				
			||||||
        dataScope: undefined,
 | 
					 | 
				
			||||||
        deptCheckStrictly: false,
 | 
					 | 
				
			||||||
        menuCheckStrictly: true,
 | 
					 | 
				
			||||||
        remark: undefined
 | 
					 | 
				
			||||||
      };
 | 
					 | 
				
			||||||
      this.resetForm("form");
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 搜索按钮操作 */
 | 
					 | 
				
			||||||
    handleQuery() {
 | 
					 | 
				
			||||||
        this.queryParams.pageNo = 1;
 | 
					        this.queryParams.pageNo = 1;
 | 
				
			||||||
        this.getList();
 | 
					        this.getList();
 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 重置按钮操作 */
 | 
					 | 
				
			||||||
    resetQuery() {
 | 
					 | 
				
			||||||
      this.resetForm("queryForm");
 | 
					 | 
				
			||||||
      this.handleQuery();
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    // 树权限(展开/折叠)
 | 
					 | 
				
			||||||
    handleCheckedTreeExpand(value, type) {
 | 
					 | 
				
			||||||
      if (type === 'menu') {
 | 
					 | 
				
			||||||
        let treeList = this.menuOptions;
 | 
					 | 
				
			||||||
        for (let i = 0; i < treeList.length; i++) {
 | 
					 | 
				
			||||||
          this.$refs.menu.store.nodesMap[treeList[i].id].expanded = value;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      } else if (type === 'dept') {
 | 
					 | 
				
			||||||
        let treeList = this.deptOptions;
 | 
					 | 
				
			||||||
        for (let i = 0; i < treeList.length; i++) {
 | 
					 | 
				
			||||||
          this.$refs.dept.store.nodesMap[treeList[i].id].expanded = value;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    // 树权限(全选/全不选)
 | 
					 | 
				
			||||||
    handleCheckedTreeNodeAll(value, type) {
 | 
					 | 
				
			||||||
      if (type === 'menu') {
 | 
					 | 
				
			||||||
        this.$refs.menu.setCheckedNodes(value ? this.menuOptions: []);
 | 
					 | 
				
			||||||
      } else if (type === 'dept') {
 | 
					 | 
				
			||||||
        // this.$refs.dept.setCheckedNodes(value ? this.deptOptions: []);
 | 
					 | 
				
			||||||
        this.$refs.dept.setCheckedNodes(value ? this.depts: []);
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    // 树权限(父子联动)
 | 
					 | 
				
			||||||
    handleCheckedTreeConnect(value, type) {
 | 
					 | 
				
			||||||
      if (type === 'menu') {
 | 
					 | 
				
			||||||
        this.form.menuCheckStrictly = value;
 | 
					 | 
				
			||||||
      } else if (type === 'dept') {
 | 
					 | 
				
			||||||
        this.form.deptCheckStrictly = !value;
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 新增按钮操作 */
 | 
					 | 
				
			||||||
    handleAdd() {
 | 
					 | 
				
			||||||
      this.reset();
 | 
					 | 
				
			||||||
      this.open = true;
 | 
					 | 
				
			||||||
      this.title = "添加角色";
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 修改按钮操作 */
 | 
					 | 
				
			||||||
    handleUpdate(row) {
 | 
					 | 
				
			||||||
      this.reset();
 | 
					 | 
				
			||||||
      const id = row.id
 | 
					 | 
				
			||||||
      getRole(id).then(response => {
 | 
					 | 
				
			||||||
        this.form = response.data;
 | 
					 | 
				
			||||||
        this.open = true;
 | 
					 | 
				
			||||||
        this.title = "修改角色";
 | 
					 | 
				
			||||||
      });
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 分配菜单权限操作 */
 | 
					 | 
				
			||||||
    handleMenu(row) {
 | 
					 | 
				
			||||||
      this.reset();
 | 
					 | 
				
			||||||
      const id = row.id
 | 
					 | 
				
			||||||
      // 处理了 form 的角色 name 和 code 的展示
 | 
					 | 
				
			||||||
      this.form.id = id;
 | 
					 | 
				
			||||||
      this.form.name = row.name;
 | 
					 | 
				
			||||||
      this.form.code = row.code;
 | 
					 | 
				
			||||||
      // 打开弹窗
 | 
					 | 
				
			||||||
      this.openMenu = true;
 | 
					 | 
				
			||||||
      // 获得菜单列表
 | 
					 | 
				
			||||||
      listSimpleMenus().then(response => {
 | 
					 | 
				
			||||||
        // 处理 menuOptions 参数
 | 
					 | 
				
			||||||
        this.menuOptions = [];
 | 
					 | 
				
			||||||
        this.menuOptions.push(...this.handleTree(response.data, "id"));
 | 
					 | 
				
			||||||
        // 获取角色拥有的菜单权限
 | 
					 | 
				
			||||||
        listRoleMenus(id).then(response => {
 | 
					 | 
				
			||||||
          // 设置为严格,避免设置父节点自动选中子节点,解决半选中问题
 | 
					 | 
				
			||||||
          this.form.menuCheckStrictly = true
 | 
					 | 
				
			||||||
          // 设置选中
 | 
					 | 
				
			||||||
          this.$refs.menu.setCheckedKeys(response.data);
 | 
					 | 
				
			||||||
          // 设置为非严格,继续使用半选中
 | 
					 | 
				
			||||||
          this.form.menuCheckStrictly = false
 | 
					 | 
				
			||||||
        })
 | 
					 | 
				
			||||||
      });
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 分配数据权限操作 */
 | 
					 | 
				
			||||||
    handleDataScope(row) {
 | 
					 | 
				
			||||||
      this.reset();
 | 
					 | 
				
			||||||
      // 处理了 form 的角色 name 和 code 的展示
 | 
					 | 
				
			||||||
      this.form.id = row.id;
 | 
					 | 
				
			||||||
      this.form.name = row.name;
 | 
					 | 
				
			||||||
      this.form.code = row.code;
 | 
					 | 
				
			||||||
      // 打开弹窗
 | 
					 | 
				
			||||||
      this.openDataScope = true;
 | 
					 | 
				
			||||||
      // 获得部门列表
 | 
					 | 
				
			||||||
      listSimpleDepts().then(response => {
 | 
					 | 
				
			||||||
        // 处理 deptOptions 参数
 | 
					 | 
				
			||||||
        this.deptOptions = [];
 | 
					 | 
				
			||||||
        this.deptOptions.push(...this.handleTree(response.data, "id"));
 | 
					 | 
				
			||||||
        this.depts = response.data;
 | 
					 | 
				
			||||||
        // this.deptIds = response.data.map(x => x.id);
 | 
					 | 
				
			||||||
        // 获得角色拥有的数据权限
 | 
					 | 
				
			||||||
        getRole(row.id).then(response => {
 | 
					 | 
				
			||||||
          this.form.dataScope = response.data.dataScope;
 | 
					 | 
				
			||||||
          this.$refs.dept.setCheckedKeys(response.data.dataScopeDeptIds, false);
 | 
					 | 
				
			||||||
        });
 | 
					 | 
				
			||||||
      });
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 提交按钮 */
 | 
					 | 
				
			||||||
    submitForm: function() {
 | 
					 | 
				
			||||||
      this.$refs["form"].validate(valid => {
 | 
					 | 
				
			||||||
        if (valid) {
 | 
					 | 
				
			||||||
          if (this.form.id !== undefined) {
 | 
					 | 
				
			||||||
            updateRole(this.form).then(response => {
 | 
					 | 
				
			||||||
              this.$modal.msgSuccess("修改成功");
 | 
					 | 
				
			||||||
              this.open = false;
 | 
					 | 
				
			||||||
              this.getList();
 | 
					 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
      } else {
 | 
					      } else {
 | 
				
			||||||
            addRole(this.form).then(response => {
 | 
					        this.addOrEditTitle = "新增";
 | 
				
			||||||
              this.$modal.msgSuccess("新增成功");
 | 
					        this.centervisible = true;
 | 
				
			||||||
              this.open = false;
 | 
					        this.$nextTick(() => {
 | 
				
			||||||
              this.getList();
 | 
					          this.$refs.roleAdd.init();
 | 
				
			||||||
            });
 | 
					 | 
				
			||||||
          }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      });
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    /** 提交按钮(数据权限) */
 | 
					 | 
				
			||||||
    submitDataScope: function() {
 | 
					 | 
				
			||||||
      if (this.form.id !== undefined) {
 | 
					 | 
				
			||||||
        assignRoleDataScope({
 | 
					 | 
				
			||||||
          roleId: this.form.id,
 | 
					 | 
				
			||||||
          dataScope: this.form.dataScope,
 | 
					 | 
				
			||||||
          dataScopeDeptIds: this.form.dataScope !== SystemDataScopeEnum.DEPT_CUSTOM ? [] :
 | 
					 | 
				
			||||||
              this.$refs.dept.getCheckedKeys()
 | 
					 | 
				
			||||||
        }).then(response => {
 | 
					 | 
				
			||||||
          this.$modal.msgSuccess("修改成功");
 | 
					 | 
				
			||||||
          this.openDataScope = false;
 | 
					 | 
				
			||||||
          this.getList();
 | 
					 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 提交按钮(菜单权限) */
 | 
					    handleClick(val) {
 | 
				
			||||||
    submitMenu: function() {
 | 
					      switch (val.type) {
 | 
				
			||||||
      if (this.form.id !== undefined) {
 | 
					        case "edit":
 | 
				
			||||||
        assignRoleMenu({
 | 
					          this.addOrEditTitle = "编辑";
 | 
				
			||||||
          roleId: this.form.id,
 | 
					          this.centervisible = true;
 | 
				
			||||||
          menuIds: [...this.$refs.menu.getCheckedKeys(), ...this.$refs.menu.getHalfCheckedKeys()]
 | 
					          this.$nextTick(() => {
 | 
				
			||||||
        }).then(response => {
 | 
					            this.$refs.roleAdd.init(val.data.id);
 | 
				
			||||||
          this.$modal.msgSuccess("修改成功");
 | 
					          });
 | 
				
			||||||
          this.openMenu = false;
 | 
					          break;
 | 
				
			||||||
          this.getList();
 | 
					        case "delete":
 | 
				
			||||||
 | 
					          this.handleDelete(val.data);
 | 
				
			||||||
 | 
					          break;
 | 
				
			||||||
 | 
					        case "menuAuth":
 | 
				
			||||||
 | 
					          this.menuVisible = true;
 | 
				
			||||||
 | 
					          this.$nextTick(() => {
 | 
				
			||||||
 | 
					            this.$refs.menuAuth.init(val.data.id);
 | 
				
			||||||
 | 
					          });
 | 
				
			||||||
 | 
					          break;
 | 
				
			||||||
 | 
					        default:
 | 
				
			||||||
 | 
					          this.dataVisible = true;
 | 
				
			||||||
 | 
					          this.$nextTick(() => {
 | 
				
			||||||
 | 
					            this.$refs.dataAuth.init(val.data.id);
 | 
				
			||||||
          });
 | 
					          });
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    /** 删除按钮操作 */
 | 
					    /** 删除按钮操作 */
 | 
				
			||||||
    handleDelete(row) {
 | 
					    handleDelete(row) {
 | 
				
			||||||
      const ids = row.id || this.ids;
 | 
					      this.$modal
 | 
				
			||||||
      this.$modal.confirm('是否确认删除角色编号为"' + ids + '"的数据项?').then(function() {
 | 
					        .confirm('是否确认删除角色名称为"' + row.name + '"的数据项?')
 | 
				
			||||||
          return delRole(ids);
 | 
					        .then(function () {
 | 
				
			||||||
        }).then(() => {
 | 
					          return delRole(row.id);
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					        .then(() => {
 | 
				
			||||||
 | 
					          this.queryParams.pageNo = 1;
 | 
				
			||||||
          this.getList();
 | 
					          this.getList();
 | 
				
			||||||
          this.$modal.msgSuccess("删除成功");
 | 
					          this.$modal.msgSuccess("删除成功");
 | 
				
			||||||
      }).catch(() => {});
 | 
					        })
 | 
				
			||||||
 | 
					        .catch(() => {});
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 新增取消
 | 
				
			||||||
 | 
					    handleCancel() {
 | 
				
			||||||
 | 
					      this.$refs.roleAdd.formClear();
 | 
				
			||||||
 | 
					      this.centervisible = false;
 | 
				
			||||||
 | 
					      this.addOrEditTitle = "";
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleConfirm() {
 | 
				
			||||||
 | 
					      this.$refs.roleAdd.submitForm();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    successSubmit() {
 | 
				
			||||||
 | 
					      this.handleCancel();
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 菜单权限
 | 
				
			||||||
 | 
					    handleCancelm() {
 | 
				
			||||||
 | 
					      this.$refs.menuAuth.formClear();
 | 
				
			||||||
 | 
					      this.menuVisible = false;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleConfirmm() {
 | 
				
			||||||
 | 
					      this.$refs.menuAuth.submitForm();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    successSubmitm() {
 | 
				
			||||||
 | 
					      this.handleCancelm();
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    // 数据权限
 | 
				
			||||||
 | 
					    handleCanceld() {
 | 
				
			||||||
 | 
					      this.$refs.dataAuth.formClear();
 | 
				
			||||||
 | 
					      this.dataVisible = false;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    handleConfirmd() {
 | 
				
			||||||
 | 
					      this.$refs.dataAuth.submitForm();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    successSubmitd() {
 | 
				
			||||||
 | 
					      this.handleCanceld();
 | 
				
			||||||
 | 
					      this.getList();
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
    /** 导出按钮操作 */
 | 
					 | 
				
			||||||
    handleExport() {
 | 
					 | 
				
			||||||
      const queryParams = this.queryParams;
 | 
					 | 
				
			||||||
      this.$modal.confirm('是否确认导出所有角色数据项?').then(function() {
 | 
					 | 
				
			||||||
          this.exportLoading = true;
 | 
					 | 
				
			||||||
          return exportRole(queryParams);
 | 
					 | 
				
			||||||
        }).then(response => {
 | 
					 | 
				
			||||||
          this.$download.excel(response, '角色数据.xls');
 | 
					 | 
				
			||||||
          this.exportLoading = false;
 | 
					 | 
				
			||||||
      }).catch(() => {});
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
					<style lang="scss" scoped>
 | 
				
			||||||
 | 
					.app-container {
 | 
				
			||||||
 | 
					  width: 100%;
 | 
				
			||||||
 | 
					  height: calc(100vh - 120px - 8px);
 | 
				
			||||||
 | 
					  background-color: #fff;
 | 
				
			||||||
 | 
					  border-radius: 8px;
 | 
				
			||||||
 | 
					  padding: 8px;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					</style>
 | 
				
			||||||
 
 | 
				
			|||||||