diff --git a/.env.dev b/.env.dev
index be00ebe..5c07452 100644
--- a/.env.dev
+++ b/.env.dev
@@ -1,7 +1,7 @@
###
# @Author: zhp
# @Date: 2024-04-28 13:42:51
- # @LastEditTime: 2024-05-31 17:09:48
+ # @LastEditTime: 2024-06-03 08:44:09
# @LastEditors: DY
# @Description:
###
diff --git a/src/assets/images/homeindex/info.png b/src/assets/images/homeindex/info.png
new file mode 100644
index 0000000..1845b41
Binary files /dev/null and b/src/assets/images/homeindex/info.png differ
diff --git a/src/assets/images/homeindex/page-title-two.png b/src/assets/images/homeindex/page-title-two.png
new file mode 100644
index 0000000..76a121e
Binary files /dev/null and b/src/assets/images/homeindex/page-title-two.png differ
diff --git a/src/assets/images/homeindex/page-title.png b/src/assets/images/homeindex/page-title.png
new file mode 100644
index 0000000..f2e2024
Binary files /dev/null and b/src/assets/images/homeindex/page-title.png differ
diff --git a/src/mixins/chart.js b/src/mixins/chart.js
index b356201..0901d53 100644
--- a/src/mixins/chart.js
+++ b/src/mixins/chart.js
@@ -4,16 +4,16 @@ function __resizeHandler(entries) {
console.log(entries)
for (const entry of entries) {
if (entry.contentBoxSize) {
- // const contentBoxSize = Array.isArray(entry.contentBoxSize)
- // ? entry.contentBoxSize[0]
- // : entry.contentBoxSize;
- // this.chart_mixin_chartInstance.resize({
- // width:
- // contentBoxSize.inlineSize < this.MIN_WIDTH
- // ? this.MIN_WIDTH
- // : contentBoxSize.inlineSize,
- // height: contentBoxSize.blockSize,
- // });
+ const contentBoxSize = Array.isArray(entry.contentBoxSize)
+ ? entry.contentBoxSize[0]
+ : entry.contentBoxSize;
+ this.chart_mixin_chartInstance.resize({
+ width:
+ contentBoxSize.inlineSize < this.MIN_WIDTH
+ ? this.MIN_WIDTH
+ : contentBoxSize.inlineSize,
+ height: contentBoxSize.blockSize,
+ });
} else {
// manipulate contentRect
this.chart_mixin_chartInstance.resize({
diff --git a/src/store/modules/home.js b/src/store/modules/home.js
index 4c278cd..d1171c0 100644
--- a/src/store/modules/home.js
+++ b/src/store/modules/home.js
@@ -1,4 +1,3 @@
-
import axios from "@/utils/request";
import { deepClone } from "../../utils";
@@ -25,10 +24,12 @@ const state = {
chipOee: {
current: [],
previous: [],
+ target:[]
},
transformRate: {
current: [],
previous: [],
+ target:[]
},
chipRate: {
target: [],
@@ -39,6 +40,7 @@ const state = {
stdRate: {
target: [],
current: [],
+ previous: [],
outputNumber:[]
},
},
@@ -77,7 +79,7 @@ const mutations = {
state.copilot.energy.elecList = payload.elecList;
break;
case "efficiency":
- state.copilot.efficiency.chipOee = payload.chipOee;
+ state.copilot.efficiency.chipOeeRate = payload.chipOeeRate;
state.copilot.efficiency.transformRate = payload.transformRate;
state.copilot.efficiency.chipRate = payload.chipRate;
state.copilot.efficiency.stdRate = payload.stdRate;
@@ -97,7 +99,7 @@ const actions = {
commit("SET_HOME_INFO", payload);
},
/** 初始化驾驶舱数据 */
- async initCopilot({ commit }, { period, source }) {
+ async initCopilot({ commit }, { period,source,than}) {
// if (source == "energy") return;
const fetcher = {
@@ -111,25 +113,27 @@ const actions = {
efficiency: splitCurrentAndPreviousA,
}[source]
// 获取产量数据
- let { data: factoryList, type } = await fetcher(period)
- let targetList = null;
- if (source === "yield" || source === "efficiency") {
- // 获取目标数据
- let { data } = await fetcher(period, true)
- targetList = data
- }
- if (source == "energy") {
- let factoryData = factoryList
- const payload = handler(factoryData)
- commit("SET_COPILOT_INFO", { type, payload });
- } else {
+ let { data: factoryList, type } = await fetcher(period,than)
+ // let targetList = null;
+ // if (source === "yield" || source === "efficiency") {
+ // // 获取目标数据
+ // let { data } = await fetcher(period,than, true)
+ // targetList = data
+ // }
+ // if (source == "energy") {
+ // let factoryData = factoryList
+ // const payload = handler(factoryData)
+ // commit("SET_COPILOT_INFO", { type, payload });
+ // } else {
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 targetData = targetList.prodTargetDO ? targetList.prodTargetDO : targetList.prodTargetDO
- const payload = handler(factoryData, targetData,prodOutputFtoDO)
+ let targetData = factoryList.prodTargetOutputDO ? factoryList.prodTargetOutputDO : factoryList.prodTargetRateDO
+ const payload = handler(factoryData,targetData,prodOutputFtoDO,preData,preFtoData)
commit("SET_COPILOT_INFO", { type, payload });
- }
+ // }
},
};
@@ -281,11 +285,11 @@ function splitCurrentAndPreviousB(factoryListResponse) {
}
}
-function splitCurrentAndPreviousA(factoryListResponse, targetListResponse) {
- // console.log('工厂',factoryListResponse);
+function splitCurrentAndPreviousA(factoryListResponse, targetListResponse, prodOutputFtoListRes,preData,preFtoData) {
+ console.log('工厂',targetListResponse);
// 初始数据
- const { chipOee, transformRate, chipRate, stdRate } = initA();
+ const { chipOeeRate, transformRate, chipRate, stdRate } = initA();
// factoryListResponse = [
// {
// factory: 0,
@@ -336,6 +340,23 @@ function splitCurrentAndPreviousA(factoryListResponse, targetListResponse) {
// 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) {
for (const factory of factoryListResponse) {
const fId = getFactoryId(factory);
@@ -347,27 +368,27 @@ function splitCurrentAndPreviousA(factoryListResponse, targetListResponse) {
chipOee,
componentConversionEfficiency,
componentYield
- } = getFactoryTargetValueA(targetListResponse, fId);
+ } = getFactoryTargetValueA(targetListResponse, fId)
stdRate.target[fId] = componentYieldRate
chipRate.target[fId] = chipYieldRate
+ chipOeeRate.target[fId] = chipOee
+ transformRate.target[fId] = componentConversionEfficiency
}
// 芯片OEE
- chipOee.current[fId] = factory.oee * 100 ;
- chipOee.previous[fId] = factory.previousYearOee * 100 ;
+ chipOeeRate.current[fId] = factory.oee;
+ // chipOeeRate.previous[fId] = factory.previousYearOee;
// 转化效率
- transformRate.current[fId] =
- factory.componentConversionEfficiency * 100 ;
- transformRate.previous[fId] =
- factory.previousYearComponentConversionEfficiency * 100 ;
+ transformRate.current[fId] = factory.componentConversionEfficiency;
+ // 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 ;
+ // _t.previous[fId] = factory.previousYearYieldRate ;
}
-
+ // console.log('chipOeeRate',chipOeeRate);
return {
- chipOee,
+ chipOeeRate,
transformRate,
chipRate,
stdRate,
@@ -375,21 +396,57 @@ function splitCurrentAndPreviousA(factoryListResponse, targetListResponse) {
}
}
-function splitCurrentAndPrevious(factoryListResponse, targetListResponse, prodOutputFtoListRes) {
- console.log('prodOutputFtoListRes',prodOutputFtoListRes);
+function splitCurrentAndPrevious(factoryListResponse, targetListResponse, prodOutputFtoListRes,preData,preFtoData) {
+ console.log('prodOutputFtoListRes',preData);
// 初始数据
const { chipInvest, ftoInvest, chipOutput, stdOutput, bipvOutput } = init()
if (prodOutputFtoListRes) {
for (const factory of prodOutputFtoListRes) {
console.log(factory);
const fId = getFactoryId(factory);
+ // const preFId = getPreFactoryId(factory);
+ // if (fId) {
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;
+ // }
+ // if (preFId) {
+ // ftoInvest.previous[fId] = factory.previousYearChipInput;
+ // }
+ }
+ }
+ 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;
}
}
- if (factoryListResponse) {
+ // console.log('ftoInvest',ftoInvest)
+ if (factoryListResponse && factoryListResponse[0] != null) {
for (const factory of factoryListResponse) {
const fId = getFactoryId(factory);
+ // const preFId = getPreFactoryId(factory);
+
// 获取目标值
if (targetListResponse) {
const { chipYield, componentYield, bipvProductOutput } =
@@ -399,23 +456,14 @@ function splitCurrentAndPrevious(factoryListResponse, targetListResponse, prodOu
bipvOutput.target[fId] = bipvProductOutput;
}
// 芯片投入
- 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;
- // }
+ chipInvest.current[fId] = factory.inputNumber;
// 产出数据, 0 - (玻璃)芯片产出, 1 - 标准组件产出, 2 - BIPV产出
// 因为后端写的垃圾数据,所以这里要做一下判断
if (![0, 1, 2].includes(factory.glassType)) continue;
const _t = [chipOutput, stdOutput, bipvOutput][factory.glassType];
- _t.current[fId] = factory.outputNumber;
- _t.previous[fId] = factory.previousYearOutputNumber;
- // debugger;
+ _t.current[fId] = factory.outputNumber;
}
-
return {
chipInvest,
// ftoInvest,
@@ -424,27 +472,39 @@ function splitCurrentAndPrevious(factoryListResponse, targetListResponse, prodOu
stdOutput,
bipvOutput,
};
+ }else{
+ return {
+ chipInvest,
+ // ftoInvest,
+ ftoInvest,
+ chipOutput,
+ stdOutput,
+ bipvOutput,
+ }
}
}
function getFactoryId(factory) {
return factory.factory;
}
+function getPreFactoryId(factory) {
+ return factory.previousFactory;
+}
function getFactoryTargetValue(targetList, factoryId) {
const target = targetList.find((item) => item.factory === factoryId);
if (target) {
return {
// 自带模拟数据了.... random_default
- chipYield: target.chipYield ?? random_default(),
- componentYield: target.componentYield ?? random_default(),
- bipvProductOutput: target.bipvProductOutput ?? random_default(),
+ chipYield: target.chipYield ?? 0,
+ componentYield: target.componentYield ?? 0,
+ bipvProductOutput: target.bipvProductOutput ?? 0,
};
}
return {
- chipYield: random_default(),
- componentYield: random_default(),
- bipvProductOutput: random_default(),
+ chipYield: 0,
+ componentYield: 0,
+ bipvProductOutput: 0,
};
}
@@ -458,15 +518,18 @@ function getFactoryTargetValueA(targetList, factoryId) {
const target = targetList.find((item) => item.factory === factoryId)
if (target) {
return {
- chipYieldRate: target.chipYieldRate ?? random_default(),
- componentYieldRate: target.componentYieldRate ?? random_default(),
- componentYield: target.componentYield ?? random_default(),
+ chipYieldRate: target.chipYieldRate ?? 0,
+ componentYieldRate: target.componentYieldRate ?? 0,
+ componentYield: target.componentYield ?? 0,
+ // componentYield: target.componentYield ?? 0,
+ chipOee: target.chipOee ?? 0,
};
}
return {
chipYieldRate:0,
componentYieldRate:0,
- componentYield:0 ,
+ componentYield: 0,
+ chipOee:0,
};
}
@@ -480,18 +543,18 @@ function initA() {
previous: Array(7).fill(0),
};
// 芯片OEE
- const chipOee = deepClone(t_);
// 转化效率
- const transformRate = deepClone(t_);
// 标准组件良率
const stdRate = {
...deepClone(t_),
target: Array(7).fill(0),
};
// 芯片良率
+ const transformRate = deepClone(stdRate);
const chipRate = deepClone(stdRate);
+ const chipOeeRate = deepClone(stdRate);
return {
- chipOee,
+ chipOeeRate,
transformRate,
chipRate,
stdRate,
@@ -544,6 +607,7 @@ async function getHomeInfo() {
const { code, data } = await axios.post("ip/prod-output/cockpitData", {
factorys: [],
date: 4,
+ mode:0
});
if (code == 0) {
return data;
@@ -609,16 +673,16 @@ async function doFetch(copilot_module = "yield", fetch_target, params) {
* @param {*} target 是否获取目标数据
* @returns
*/
-function getCopilotYield(period, target = false) {
- return getCopilotData("yield", period, target);
+function getCopilotYield(period,than,target = false) {
+ return getCopilotData("yield", period,than, target);
}
function getCopilotEnergy(period, target = false) {
- return getCopilotData("energy", period, target);
+ return getCopilotData("energy", period,than, target);
}
-function getCopilotEfficiency(period, target = false) {
- return getCopilotData("efficiency", period, target);
+function getCopilotEfficiency(period,than, target = false) {
+ return getCopilotData("efficiency", period,than, target);
}
/**
@@ -627,12 +691,13 @@ function getCopilotEfficiency(period, target = false) {
* @param {*} target 是否获取目标数据:默认 否
* @returns
*/
-async function getCopilotData(copilot_module, period, target = false) {
+async function getCopilotData(copilot_module, period,than, target = false) {
if (!copilot_module) copilot_module = "yield";
// 请求参数,直接一次性获取所有工厂
let queryParams = {
factorys: [],
date: 4,
+ mode:0
};
switch (period) {
@@ -652,7 +717,14 @@ async function getCopilotData(copilot_module, period, target = false) {
queryParams.date = 1;
break;
}
-
+ switch (than) {
+ case "同比":
+ queryParams.mode = 0;
+ break;
+ case "环比":
+ queryParams.mode = 1;
+ break;
+ }
return {
data: await doFetch(copilot_module, target ? true : false, queryParams),
type: copilot_module,
diff --git a/src/utils/dict.js b/src/utils/dict.js
index 6019cdc..f70461a 100644
--- a/src/utils/dict.js
+++ b/src/utils/dict.js
@@ -139,3 +139,15 @@ export function getDictDataLabel(dictType, value) {
const dict = getDictData(dictType, value);
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]
+ }
+}
diff --git a/src/views/copilot/components/BarChartBase.vue b/src/views/copilot/components/BarChartBase.vue
index 8be1bdc..c70d1bf 100644
--- a/src/views/copilot/components/BarChartBase.vue
+++ b/src/views/copilot/components/BarChartBase.vue
@@ -11,7 +11,7 @@
{{ item.label }}
-
+
@@ -51,7 +51,7 @@ export default {
},
data() {
return {
- width: '',
+ width: '100%',
isFullscreen: false,
actualOptions: null,
options: {
@@ -184,16 +184,7 @@ export default {
/** 全屏状态切换时,对柱子粗细和字体大小进行相应调整 */
isOpen(val) {
// console.log(val)
- if (val === true) {
- console.log('ztl')
- this.width = 95 + '%'
- this.canvasReset()
-
- console.log(this.width)
- } else {
- this.watch = 100 + '%'
- this.canvasReset()
- }
+ this.canvasReset()
},
isFullscreen(val) {
this.actualOptions.series.map((item) => {
@@ -203,21 +194,14 @@ export default {
this.actualOptions.yAxis.axisLabel.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.watch = 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.initChart(this.actualOptions);
+ this.canvasReset()
},
series(val) {
if (!val) {
diff --git a/src/views/copilot/components/CopilotHeader.vue b/src/views/copilot/components/CopilotHeader.vue
index 659a686..7752828 100644
--- a/src/views/copilot/components/CopilotHeader.vue
+++ b/src/views/copilot/components/CopilotHeader.vue
@@ -8,33 +8,23 @@
@@ -52,14 +42,61 @@ export default {
period: {
type: String,
},
+ than: {
+ type: String,
+ },
},
data() {
return {
+ times:'',
isFullscreen: false,
};
},
+ mounted () {
+ this.getTimes()
+ this.getTimesInterval();
+ },
computed: {},
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() {
this.isFullscreen = !this.isFullscreen;
screenfull.toggle(document.querySelector(".copilot-layout"))
@@ -82,10 +119,11 @@ export default {
display: flex;
gap: 12px;
align-items: center;
+ justify-content: space-between;
}
.copilot-header > section {
- width: 24vw;
+ width: 26vw;
display: flex;
align-items: center;
gap: 8px;
@@ -99,6 +137,17 @@ export default {
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 {
background: url(../../../assets/images/export-icon.png) 0 0 / 100% 100%
no-repeat;
@@ -112,15 +161,27 @@ export default {
background: url(../../../assets/images/homeindex/exit-fullscreen.png) 0 0 / 100% 100%
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 {
- flex: 1;
+ width: 25vw;
font-size: 54px;
line-height: 70px;
letter-spacing: 5px;
font-family: 优设标题黑;
color: #6db6ff;
- text-align: right;
+ text-align: center;
user-select: none;
+ background: url(../../../assets/images/homeindex/page-title.png) 0 0 / 100% 100% no-repeat;
}
diff --git a/src/views/copilot/components/FactoryDataHeader.vue b/src/views/copilot/components/FactoryDataHeader.vue
index bab2967..4d477d9 100644
--- a/src/views/copilot/components/FactoryDataHeader.vue
+++ b/src/views/copilot/components/FactoryDataHeader.vue
@@ -1,39 +1,30 @@
+
+
diff --git a/src/views/copilot/components/gasBarChartBase.vue b/src/views/copilot/components/gasBarChartBase.vue
index b9ec720..99a2771 100644
--- a/src/views/copilot/components/gasBarChartBase.vue
+++ b/src/views/copilot/components/gasBarChartBase.vue
@@ -1,7 +1,7 @@
@@ -191,7 +191,7 @@ export default {
console.log(this.width)
} else {
console.log('ryf')
- this.watch = 100 + '%'
+ this.width = 100 + '%'
this.canvasReset()
}
},
@@ -201,7 +201,7 @@ export default {
this.width = 97 + '%'
this.canvasReset()
} else if (val === false && this.isOpen === false) {
- this.watch = 100 + '%'
+ this.width = 100 + '%'
this.canvasReset()
}
// this.actualOptions.series.map((item) => {
diff --git a/src/views/copilot/container.vue b/src/views/copilot/container.vue
index 3a17b4a..9441df5 100644
--- a/src/views/copilot/container.vue
+++ b/src/views/copilot/container.vue
@@ -1,4 +1,3 @@
-
-
-
+
+
-
-
-
+
+
+
@@ -21,24 +21,55 @@
diff --git a/src/views/copilot/efficiency/components/sub/chip/ChipRateItem.vue b/src/views/copilot/efficiency/components/sub/chip/ChipRateItem.vue
index f4b1592..edbd12a 100644
--- a/src/views/copilot/efficiency/components/sub/chip/ChipRateItem.vue
+++ b/src/views/copilot/efficiency/components/sub/chip/ChipRateItem.vue
@@ -13,7 +13,7 @@
-
+
{{ lgd.value }}
{{ lgd.label }}
@@ -46,6 +46,10 @@ export default {
type: String,
default: "日",
},
+ than: {
+ type: String,
+ default: '同比',
+ }
},
data() {
return {
@@ -103,21 +107,72 @@ export default {
return t;
},
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;
- return [
- {
- 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) + "%"
- },
- ];
+ 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}日良率`, value: isNaN(this.valueTuple[1]) || this.valueTuple[1] == null ? 0 + "%" : (this.valueTuple[1]) + "%" },
+ { label: `去年${month}月${today}日良率`, value: isNaN(this.valueTuple[0]) || this.valueTuple[0] == null ? 0 + "%" : (this.valueTuple[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() {
@@ -163,7 +218,9 @@ export default {
// width: 290px;
align-self: stretch;
// flex: 1 1 auto;
- // padding: 0 10%;
+ // align-items: center;
+ // margin:0 auto;
+ // padding: 0 10%;;
/* margin: 10%; */
/* min-width: 300px; */
height: 200px;
diff --git a/src/views/copilot/efficiency/components/sub/std/ProgressBar.vue b/src/views/copilot/efficiency/components/sub/std/ProgressBar.vue
index 6586f16..8692f01 100644
--- a/src/views/copilot/efficiency/components/sub/std/ProgressBar.vue
+++ b/src/views/copilot/efficiency/components/sub/std/ProgressBar.vue
@@ -6,7 +6,7 @@
-->
-
+
@@ -20,52 +20,25 @@ export default {
type: Number,
default: 0,
},
- target: {
- type: Number,
- default: 0,
- },
- goodNumber: {
- type: Number,
- default:0
- },
- componentYield: {
- type: Number,
- default:0
- },
- period: {
- type: String,
- default:'日',
- },
+ // total: {
+ // type: Number,
+ // default: 0,
+ // },
title: {
type: String,
default: "",
},
- city: {
- type: String,
- default:""
- }
},
data() {
- return {
- number: 0,
- titleYear:'',
- };
+ return {};
},
computed: {
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
? "-"
- : this.value >1 ? 100 + '%' :`${(this.value * 100).toFixed(0)}%`
+ : this.value > 1
+ ? 100 + '%'
+ : `${(parseFloat(this.value)).toFixed(0)}%`;
},
},
methods: {},
@@ -95,7 +68,7 @@ export default {
color: #fff;
position: absolute;
bottom: -200%;
- right: 10px;
+ right: 0;
font-size: 12px;
}
@@ -104,6 +77,7 @@ export default {
color: #11eae3;
}
}
+
&:nth-child(2) {
&:after {
color: #0e65fd;
@@ -116,17 +90,20 @@ export default {
height: 100%;
width: 0;
border-radius: 4px;
+ background: linear-gradient(to right,
+ #004c5e11 10%,
+ #004c5e,
+ #0ac0c0,
+ #11eae3);
}
&:first-child {
.progress-bar__rate {
- background: linear-gradient(
- to right,
- #004c5e11 10%,
- #004c5e,
- #0ac0c0,
- #11eae3
- );
+ background: linear-gradient(to right,
+ #004c5e11 10%,
+ #004c5e,
+ #0ac0c0,
+ #11eae3);
}
}
diff --git a/src/views/copilot/efficiency/components/sub/std/StdRateItem.vue b/src/views/copilot/efficiency/components/sub/std/StdRateItem.vue
index 83e07be..4f9f3ba 100644
--- a/src/views/copilot/efficiency/components/sub/std/StdRateItem.vue
+++ b/src/views/copilot/efficiency/components/sub/std/StdRateItem.vue
@@ -1,7 +1,7 @@
@@ -11,28 +11,30 @@
@@ -52,7 +54,11 @@ export default {
period: {
type: String,
default: "日",
- }
+ },
+ than: {
+ type: String,
+ default: "同比",
+ },
},
data() {
return {
@@ -60,44 +66,65 @@ export default {
};
},
computed: {
- title() {
- switch (this.period) {
- case "日":
- return "今日"
- case "周":
- return "本周"
- case "月":
- const year = new Date().getFullYear();
- const month = new Date().getMonth() + 1;
- return `${year - 1}年${month}月累计`
- case "年": {
- const year = new Date().getFullYear();
- // return [
- return `${year - 1}年累计`
- // ];
- }
- default:
- return "今日"
+ titlePre() {
+ console.log(this.city);
+ var day1 = new Date();
+ day1.setTime(day1.getTime() - 24 * 60 * 60 * 1000);
+ var yesterday = (day1.getMonth() + 1) + "月" + day1.getDate()
+ const today = new Date().getDate();
+ 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 === '同比') {
+ return `去年${month}月${today}日`
+ } else if (this.period === '日' && this.than === '环比') {
+ return `${yesterday}日`
+ } 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 `${lastMonth}月`
+ } else {
+ return `${year - 1}年`
}
},
- titleEnd() {
- switch (this.period) {
- // case "日":
- // return "今日"
- // case "周":
- // return "本周"
- case "月":
- const year = new Date().getFullYear();
- const month = new Date().getMonth() + 1;
- return `${year}年${month}月目标`
- case "年": {
- const year = new Date().getFullYear();
- // return [
- return `${year}年目标`
- // ];
- }
+ title() {
+ 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 === '日' && 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}年目标`
+ }
+ },
},
};
diff --git a/src/views/copilot/efficiency/index.vue b/src/views/copilot/efficiency/index.vue
index badefb1..371b71b 100644
--- a/src/views/copilot/efficiency/index.vue
+++ b/src/views/copilot/efficiency/index.vue
@@ -1,7 +1,7 @@
@@ -9,16 +9,16 @@
-
+
-
+
-
+
-
+
@@ -44,25 +44,45 @@ export default {
type: String,
default: "日",
},
+ than: {
+ type: String,
+ default: "同比",
+ },
},
data() {
- return {};
+ return {
+ chipOeeRate: {},
+ transformRate:{}
+ };
},
watch: {
period: {
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,
},
},
methods: {
- fetchData(period = "日") {
+ fetchData(period = "日",than) {
console.log(`效率驾驶舱,获取${period}数据`);
this.$store.dispatch("copilot/initCopilot", {
period,
source: "efficiency",
- });
+ than
+ }).then(() => {
+ this.$nextTick(() => {
+ this.chipOeeRate = this.$store.getters.copilot.efficiency.chipOeeRate
+ this.transformRate = this.$store.getters.copilot.efficiency.transformRate
+ })
+ })
},
},
};
diff --git a/src/views/copilot/efficiency/options/double-ring-chart-options.js b/src/views/copilot/efficiency/options/double-ring-chart-options.js
index 743f820..bbd6d65 100644
--- a/src/views/copilot/efficiency/options/double-ring-chart-options.js
+++ b/src/views/copilot/efficiency/options/double-ring-chart-options.js
@@ -6,7 +6,7 @@ export default ({
targetSum,
}) => ({
grid: {
- left: 0,
+ left: '50%',
right: 0,
bottom: 0,
top: 0,
diff --git a/src/views/copilot/efficiencyContainer.vue b/src/views/copilot/efficiencyContainer.vue
new file mode 100644
index 0000000..e004cec
--- /dev/null
+++ b/src/views/copilot/efficiencyContainer.vue
@@ -0,0 +1,131 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/bbIndex.vue b/src/views/copilot/factoryData/bbIndex.vue
new file mode 100644
index 0000000..e746fdd
--- /dev/null
+++ b/src/views/copilot/factoryData/bbIndex.vue
@@ -0,0 +1,216 @@
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/cdIndex.vue b/src/views/copilot/factoryData/cdIndex.vue
new file mode 100644
index 0000000..7ae82bb
--- /dev/null
+++ b/src/views/copilot/factoryData/cdIndex.vue
@@ -0,0 +1,216 @@
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/components/BarChartBase.vue b/src/views/copilot/factoryData/components/BarChartBase.vue
new file mode 100644
index 0000000..5d62d34
--- /dev/null
+++ b/src/views/copilot/factoryData/components/BarChartBase.vue
@@ -0,0 +1,417 @@
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/components/BarChartChipOEE.vue b/src/views/copilot/factoryData/components/BarChartChipOEE.vue
new file mode 100644
index 0000000..fb6bb44
--- /dev/null
+++ b/src/views/copilot/factoryData/components/BarChartChipOEE.vue
@@ -0,0 +1,343 @@
+
+
+
+
+ {{ item.label }}
+
+
+
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/components/ChartContainer.vue b/src/views/copilot/factoryData/components/ChartContainer.vue
new file mode 100644
index 0000000..a36ffb6
--- /dev/null
+++ b/src/views/copilot/factoryData/components/ChartContainer.vue
@@ -0,0 +1,69 @@
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/components/ChipOee.vue b/src/views/copilot/factoryData/components/ChipOee.vue
new file mode 100644
index 0000000..b872b9f
--- /dev/null
+++ b/src/views/copilot/factoryData/components/ChipOee.vue
@@ -0,0 +1,278 @@
+
+
+
+
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/components/Order.vue b/src/views/copilot/factoryData/components/Order.vue
index 8cec3dc..fa4d22c 100644
--- a/src/views/copilot/factoryData/components/Order.vue
+++ b/src/views/copilot/factoryData/components/Order.vue
@@ -1,27 +1,38 @@
-
+
+
+
diff --git a/src/views/copilot/factoryData/components/ProdMonitor.vue b/src/views/copilot/factoryData/components/ProdMonitor.vue
index a0e7619..2c8002b 100644
--- a/src/views/copilot/factoryData/components/ProdMonitor.vue
+++ b/src/views/copilot/factoryData/components/ProdMonitor.vue
@@ -1,146 +1,143 @@
-
-
-
+
+
+
+
+
+
+
+ 玻璃类型
+ FTO投入
+
+
+ 投入数量
+ {{ prodFto[0] ? prodFto[0].chipInput : 0 }}
+
-
- 玻璃类型
- FTO投入
-
-
- 投入数量
- {{ prodFto[0] ? prodFto[0].chipInput : 0 }}
-
-
-
-
-
-
-
-
-
- 玻璃类型
- 标准组检产量
-
-
-
良品数量
-
{{
+
+
+
+
+
+
+
+ 玻璃类型
+ 标准组检产量
+
+
+ 良品数量
+ {{
msgObj.stand.goodNumber ? msgObj.stand.goodNumber : 0
- }}
+ }}
+
-
-
-
-
-
生产数量
-
{{
+
+
+
+ 生产数量
+ {{
msgObj.stand.outputNumber ? msgObj.stand.outputNumber : 0
- }}
-
-
- 良品率
- {{ msgObj.stand.yieldRate ? msgObj.stand.yieldRate : 0 }}%
+ }}
+
+
+ 良品率
+ {{ msgObj.stand.yieldRate ? msgObj.stand.yieldRate : 0 }}%
+
-
-
-
-
-
-
-
-
- 玻璃类型
- 芯片产量
-
-
-
良品数量
-
{{
+
+
+
+
+
+
+
+ 玻璃类型
+ 芯片产量
+
+
+ 良品数量
+ {{
msgObj.chip.goodNumber ? msgObj.chip.goodNumber : 0
- }}
+ }}
+
+
+
+
+
+
+ 生产数量
+ {{
+ msgObj.chip.outputNumber ? msgObj.chip.outputNumber : 0
+ }}
+
+
+ 良品率
+ {{ msgObj.chip.yieldRate ? msgObj.chip.yieldRate : 0 }}%
+
-
-
-
-
生产数量
-
{{
- msgObj.chip.outputNumber ? msgObj.chip.outputNumber : 0
- }}
+
+
+
+
+
+
+
+ 玻璃类型
+ BIPV产量
+
+
+ 良品数量
+ {{
+ msgObj.bipv.goodNumber ? msgObj.bipv.goodNumber : 0
+ }}
+
-
- 良品率
- {{ msgObj.chip.yieldRate ? msgObj.chip.yieldRate : 0 }}%
+
+
+
+
+ 生产数量
+ {{
+ msgObj.bipv.outputNumber ? msgObj.bipv.outputNumber : 0
+ }}
+
+
+ 良品率
+ {{ msgObj.bipv.yieldRate ? msgObj.bipv.yieldRate : 0 }}%
+
-
-
-
-
-
-
-
- 玻璃类型
- BIPV产量
-
-
- 良品数量
- {{
- msgObj.bipv.goodNumber ? msgObj.bipv.goodNumber : 0
- }}
-
-
-
-
-
-
- 生产数量
- {{
- msgObj.bipv.outputNumber ? msgObj.bipv.outputNumber : 0
- }}
-
-
- 良品率
- {{ msgObj.bipv.yieldRate ? msgObj.bipv.yieldRate : 0 }}%
-
-
+
+
diff --git a/src/views/copilot/factoryData/hdIndex.vue b/src/views/copilot/factoryData/hdIndex.vue
new file mode 100644
index 0000000..70fcbf0
--- /dev/null
+++ b/src/views/copilot/factoryData/hdIndex.vue
@@ -0,0 +1,216 @@
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/index.vue b/src/views/copilot/factoryData/index.vue
index 190e464..d55657b 100644
--- a/src/views/copilot/factoryData/index.vue
+++ b/src/views/copilot/factoryData/index.vue
@@ -1,29 +1,25 @@
@@ -32,8 +28,9 @@
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 { 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 {
@@ -42,8 +39,8 @@ export default {
FactoryDataHeader,
DbContainer: Container,
ProdMonitor,
- Store,
- Energy,
+ // Store,
+ // Energy,
Order,
},
data() {
@@ -51,10 +48,18 @@ export default {
companyId: 0,
companyName: "瑞昌中建材光电材料有限公司",
period: 1,
+ show:false,
+ than: '同比',
+ data:{},
// 接口获取的数据
prodOutPut: [], //生产
prodFto: [], //生产
stock: {}, //仓库
+ factoryData: {
+ preDataDetail: [],
+ currentDataDetail: {},
+ targetDataDetail: [],
+ },
energyCockpits: [], //能源
prodOrder: [], //订单
energyLegend: [
@@ -73,6 +78,11 @@ export default {
this.companyName = obj.companyName;
this.getMes();
},
+ updateThan(val) {
+ console.log(val);
+ this.than = val;
+ // this.getMes();
+ },
updatePeriod(val) {
this.period = val;
this.getMes();
@@ -81,13 +91,74 @@ export default {
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.stock = res.data.stockDO || {};
- this.energyCockpits = res.data.energyCockpitsDO || [];
- this.prodOrder = res.data.prodOrderMonitorDO || [];
+ 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);
});
},
},
diff --git a/src/views/copilot/factoryData/jmsIndex.vue b/src/views/copilot/factoryData/jmsIndex.vue
new file mode 100644
index 0000000..efec17a
--- /dev/null
+++ b/src/views/copilot/factoryData/jmsIndex.vue
@@ -0,0 +1,216 @@
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/ksIndex.vue b/src/views/copilot/factoryData/ksIndex.vue
new file mode 100644
index 0000000..3eaec0f
--- /dev/null
+++ b/src/views/copilot/factoryData/ksIndex.vue
@@ -0,0 +1,216 @@
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/oldIndex.vue b/src/views/copilot/factoryData/oldIndex.vue
new file mode 100644
index 0000000..7b0a815
--- /dev/null
+++ b/src/views/copilot/factoryData/oldIndex.vue
@@ -0,0 +1,146 @@
+
+
+
+
+
+
diff --git a/src/views/copilot/factoryData/zzIndex.vue b/src/views/copilot/factoryData/zzIndex.vue
new file mode 100644
index 0000000..a6580ad
--- /dev/null
+++ b/src/views/copilot/factoryData/zzIndex.vue
@@ -0,0 +1,216 @@
+
+
+
+
+
diff --git a/src/views/copilot/yield/components/BipvOutput.vue b/src/views/copilot/yield/components/BipvOutput.vue
index 1f77c21..15b6a64 100644
--- a/src/views/copilot/yield/components/BipvOutput.vue
+++ b/src/views/copilot/yield/components/BipvOutput.vue
@@ -1,28 +1,37 @@
-
-
+
diff --git a/src/views/copilot/yield/components/ChipInvest.vue b/src/views/copilot/yield/components/ChipInvest.vue
index f82d49a..70bfac4 100644
--- a/src/views/copilot/yield/components/ChipInvest.vue
+++ b/src/views/copilot/yield/components/ChipInvest.vue
@@ -33,74 +33,215 @@ export default {
type: String,
default: "日",
},
+ than: {
+ type: String,
+ 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" },
- ];
+ 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}月目标`, 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}年`, 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() {
const { chipInvest } = this.$store.getters.copilot.yield;
let dataList = null;
switch (this.period) {
case "日":
+ dataList = [];
+ dataList[0] = chipInvest?.previous;
+ dataList[1] = chipInvest?.current;
case "周":
- dataList = chipInvest?.current;
+ dataList = []
+ dataList[0] = chipInvest?.previous;
+ dataList[1] = chipInvest?.current;
break;
default:
dataList = [];
dataList[0] = chipInvest?.previous;
dataList[1] = chipInvest?.current;
}
- return getTemplate(this.period, dataList);
+ return getTemplate(this.period, dataList,this.than);
},
},
};
-function getTemplate(period, dataList) {
- const year = new Date().getFullYear();
+function getTemplate(period, dataList,than) {
+ 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)),
+ },
+ ];
+ } 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
}
diff --git a/src/views/copilot/yield/components/ChipOutput.vue b/src/views/copilot/yield/components/ChipOutput.vue
index 9286c61..b1a6937 100644
--- a/src/views/copilot/yield/components/ChipOutput.vue
+++ b/src/views/copilot/yield/components/ChipOutput.vue
@@ -1,12 +1,13 @@
-
-
+
diff --git a/src/views/copilot/yield/components/StdOutput.vue b/src/views/copilot/yield/components/StdOutput.vue
index ca0a8f2..f3dc18d 100644
--- a/src/views/copilot/yield/components/StdOutput.vue
+++ b/src/views/copilot/yield/components/StdOutput.vue
@@ -1,12 +1,13 @@
-
-
+
@@ -191,6 +281,7 @@ function calculateItems(period, valueTuple) {
padding: 0 10%;
/* margin: 10%; */
/* min-width: 300px; */
+ align-self: stretch;
height: 0;
}
diff --git a/src/views/copilot/yield/components/sub/ring/DoubleRingWrapper.vue b/src/views/copilot/yield/components/sub/ring/DoubleRingWrapper.vue
index e98250b..101d370 100644
--- a/src/views/copilot/yield/components/sub/ring/DoubleRingWrapper.vue
+++ b/src/views/copilot/yield/components/sub/ring/DoubleRingWrapper.vue
@@ -7,22 +7,12 @@
@@ -43,6 +33,10 @@ export default {
type: String,
default: "日",
},
+ than: {
+ type: String,
+ default: "同比",
+ },
},
data() {
return {
diff --git a/src/views/copilot/yield/components/sub/ring/noDoubleRingWrapper.vue b/src/views/copilot/yield/components/sub/ring/noDoubleRingWrapper.vue
new file mode 100644
index 0000000..64ac8fb
--- /dev/null
+++ b/src/views/copilot/yield/components/sub/ring/noDoubleRingWrapper.vue
@@ -0,0 +1,91 @@
+
+
+
+
+
+
+
+
+
diff --git a/src/views/copilot/yield/index.vue b/src/views/copilot/yield/index.vue
index 6a0d042..3583fac 100644
--- a/src/views/copilot/yield/index.vue
+++ b/src/views/copilot/yield/index.vue
@@ -1,29 +1,30 @@
@@ -52,22 +53,40 @@ export default {
type: String,
default: "日",
},
+ than: {
+ type: String,
+ default: "同比",
+ },
},
data() {
- return {};
+ return {
+ show:false,
+ };
},
watch: {
period: {
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,
},
},
methods: {
- fetchData(period = "日") {
+ fetchData(period = "日", than) {
+ // this.$store.commit('copilot/clearState')
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
+ })
+ })
},
},
};
diff --git a/src/views/copilot/yield/options/double-ring-chart-options.js b/src/views/copilot/yield/options/double-ring-chart-options.js
index 88c7d0d..54072b6 100644
--- a/src/views/copilot/yield/options/double-ring-chart-options.js
+++ b/src/views/copilot/yield/options/double-ring-chart-options.js
@@ -4,6 +4,8 @@ export default ({
previousSum,
currentSum,
targetSum,
+ currentName,
+ preName,
}) => ({
grid: {
left: 0,
@@ -57,7 +59,7 @@ export default ({
data: [
{
value: currentSum,
- name: "当前累计产出",
+ name: currentName,
selected: false,
itemStyle: {
borderJoin: "round",
@@ -108,7 +110,7 @@ export default ({
data: [
{
value: previousSum,
- name: "上期累计产出",
+ name: preName,
selected: false,
itemStyle: {
borderJoin: "round",
diff --git a/src/views/dashboard/components/CompanyInfo.vue b/src/views/dashboard/components/CompanyInfo.vue
index 98557d8..a74722f 100644
--- a/src/views/dashboard/components/CompanyInfo.vue
+++ b/src/views/dashboard/components/CompanyInfo.vue
@@ -1,12 +1,12 @@
-
-
+
{{ info.companyName }}
@@ -31,7 +31,7 @@ export default {
position: {
type: Object,
required: true,
- default: () => ({ x: 0, y: 0 }),
+ default: () => ({ tx: 0, ty: 0 }),
},
},
filters: {
@@ -49,16 +49,23 @@ export default {
computed: {
styles() {
return {
- left: `${this.position.x}%`,
- top: `${this.position.y}%`,
+ left: `${this.position.tx}%`,
+ top: `${this.position.ty}%`,
};
},
},
- methods: {},
+ methods: {
+ handleChangeRoute() {
+ this.$router.push({
+ path: this.position.path
+ })
+ }
+ },
};
diff --git a/src/views/system/components/statusBtn3.vue b/src/views/system/components/statusBtn3.vue
new file mode 100644
index 0000000..7b70fe1
--- /dev/null
+++ b/src/views/system/components/statusBtn3.vue
@@ -0,0 +1,41 @@
+
+
+
+ {{ state }}
+
+
+
+
diff --git a/src/views/system/components/statusBtn4.vue b/src/views/system/components/statusBtn4.vue
new file mode 100644
index 0000000..2f335b9
--- /dev/null
+++ b/src/views/system/components/statusBtn4.vue
@@ -0,0 +1,38 @@
+
+
+
+ {{ state }}
+
+
+
+
diff --git a/src/views/system/components/statusBtn5.vue b/src/views/system/components/statusBtn5.vue
new file mode 100644
index 0000000..6986341
--- /dev/null
+++ b/src/views/system/components/statusBtn5.vue
@@ -0,0 +1,39 @@
+
+
+
+
+
diff --git a/src/views/system/loginlog/index.vue b/src/views/system/loginlog/index.vue
index e98e8e4..073e993 100644
--- a/src/views/system/loginlog/index.vue
+++ b/src/views/system/loginlog/index.vue
@@ -1,137 +1,26 @@
-
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 搜索
- 重置
-
-
+
-
-
- 导出
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {{ parseTime(scope.row.createTime) }}
-
-
-
+
+
@@ -139,17 +28,117 @@