产量和效率
This commit is contained in:
		| @@ -16,7 +16,7 @@ | ||||
| </template> | ||||
|  | ||||
| <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 { | ||||
|   name: "TransformRate", | ||||
|   components: { BarChartBase }, | ||||
| @@ -25,6 +25,14 @@ export default { | ||||
|       type: String, | ||||
|       default: "日", | ||||
|     }, | ||||
|     than: { | ||||
|       type: String, | ||||
|       default: '同比', | ||||
|     }, | ||||
|     transformRate: { | ||||
|       type: Object, | ||||
|       default: {} | ||||
|     } | ||||
|   }, | ||||
|   data() { | ||||
|     // 城市数组的顺序必须是固定的 | ||||
| @@ -35,75 +43,227 @@ export default { | ||||
|   }, | ||||
|   computed: { | ||||
|     legend() { | ||||
|       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() { | ||||
|       const { transformRate } = this.$store.getters.copilot.efficiency; | ||||
|       let dataList = null; | ||||
|       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}日`, 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}年`, color: "#58adfa" }, | ||||
|           { label: `${year}年`, color: "#58adfa" }, | ||||
|  | ||||
|           // { 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) { | ||||
|         case "日": | ||||
|           dataList = []; | ||||
|           dataList[0] = transformRate.previous; | ||||
|           dataList[1] = transformRate.current; | ||||
|         case "周": | ||||
|           dataList = transformRate?.current; | ||||
|           break; | ||||
|           dataList = []; | ||||
|           dataList[0] = transformRate.previous; | ||||
|           dataList[1] = transformRate.current; | ||||
|         default: | ||||
|           dataList = []; | ||||
|           dataList[0] = transformRate?.previous; | ||||
|           dataList[1] = transformRate?.current; | ||||
|           dataList[0] = transformRate.previous; | ||||
|           dataList[1] = transformRate.current | ||||
|           dataList[2] = transformRate.target | ||||
|       } | ||||
|  | ||||
|       return getTemplate(this.period, dataList); | ||||
|       console.log('transformRate', 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: {}, | ||||
| }; | ||||
|  | ||||
| function getTemplate(period, dataList) { | ||||
|   const year = new Date().getFullYear(); | ||||
| 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; | ||||
|   return period == "日" || period == "周" | ||||
|     ? [ | ||||
|         { | ||||
|           name: period == "日" ? "昨日" : "本周", | ||||
|           data: dataList ?? [], | ||||
|         }, | ||||
|       ] | ||||
|     : [ | ||||
|         { | ||||
|           name: period == "年" ? `${year - 1}年` : `${year - 1}年${month}月`, | ||||
|           data: dataList ? dataList[0] : [], | ||||
|         }, | ||||
|         { | ||||
|           name: period == "年" ? `${year}年` : `${year}年${month}月`, | ||||
|           data: dataList ? dataList[1] : [], | ||||
|           // : Array.from({ length: 7 }, () => Math.floor(Math.random() * 1000)), | ||||
|         }, | ||||
|       ]; | ||||
|   const lastMonth = new Date().getMonth() + 1 === 12 ? 1 : new Date().getMonth() + 1 - 1; | ||||
|   const year = new Date().getFullYear(); | ||||
|   if (period === '日' && 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 === '日' && 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> | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user