From a88527e8ced879d68307547bfa83901122a30361 Mon Sep 17 00:00:00 2001
From: schangxiang@126.com <schangxiang@126.com>
Date: 周五, 20 12月 2024 19:48:47 +0800
Subject: [PATCH] 222
---
LA24030_LuLiPackageLine_Web/src/views/home/index.vue | 571 +++++++++++++++++++++++++++++----------------------------
1 files changed, 290 insertions(+), 281 deletions(-)
diff --git a/LA24030_LuLiPackageLine_Web/src/views/home/index.vue b/LA24030_LuLiPackageLine_Web/src/views/home/index.vue
index 6ae4a8f..0a05a8c 100644
--- a/LA24030_LuLiPackageLine_Web/src/views/home/index.vue
+++ b/LA24030_LuLiPackageLine_Web/src/views/home/index.vue
@@ -1,17 +1,28 @@
<template>
<div class="home-container layout-pd">
<el-row :gutter="15" class="home-card-one mb15">
- <el-col :xs="24" :sm="8" :md="8" :lg="8" :xl="8" class="home-media home-media-lg">
+ <el-col :xs="24" :sm="8" :md="8" :lg="8" :xl="8" class="home-media home-media-lg" v-for="(v, k) in offOrderInfo" >
<div class="home-card-item flex">
<div class="flex-margin flex w100" :class="` home-one-animation${1}`">
<div class="flex-auto">
- <span class="ml5 font16">褰撴棩璁㈠崟鎬绘暟</span>
+ <span class="ml5 font16">{{ v.name }}</span>
+ <div class="font30">{{ v.value }}</div>
+ </div>
+ </div>
+ </div>
+ </el-col>
+ <!-- <el-col :xs="24" :sm="8" :md="8" :lg="8" :xl="8" class="home-media home-media-lg">
+ <div class="home-card-item flex">
+ <div class="flex-margin flex w100" :class="` home-one-animation${1}`">
+ <div class="flex-auto">
+ <span class="ml5 font16">涓嬬嚎鍖呮暟</span>
<div class="font30">{{ state.orderNum }}</div>
</div>
</div>
</div>
</el-col>
- <el-col :xs="24" :sm="8" :md="8" :lg="8" :xl="8" v-for="(v, k) in state.homeOne" :key="k" :class="{ 'home-media home-media-lg': k > 1, 'home-media-sm': k === 1 }">
+ -->
+ <!-- <el-col :xs="24" :sm="8" :md="8" :lg="8" :xl="8" v-for="(v, k) in state.homeOne" :key="k" :class="{ 'home-media home-media-lg': k > 1, 'home-media-sm': k === 1 }">
<div class="home-card-item flex">
<div class="flex-margin flex w100" :class="` home-one-animation${k}`">
<div class="flex-auto">
@@ -24,37 +35,12 @@
</div>
</div>
</div>
- </el-col>
- </el-row>
- <el-row :gutter="15" class="home-card-two mb15">
- <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16">
- <div class="home-card-item">
- <div style="height: 100%" ref="homeLineRef"></div>
- </div>
- </el-col>
- <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8" class="home-media">
- <div class="home-card-item">
- <div class="home-card-item-title">蹇嵎瀵艰埅宸ュ叿</div>
- <div class="home-monitor">
- <div class="flex-warp">
- <div class="flex-warp-item" v-for="(v, k) in state.homeThree" :key="k" @click="routerJupm(v)">
- <div class="flex-warp-item-box" :class="`home-animation${k}`">
- <div class="flex-margin">
- <i :class="v.icon" :style="{ color: v.iconColor }"></i>
- <span class="pl5">{{ v.label }}</span>
- <div class="mt10">{{ v.value }}</div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </el-col>
+ </el-col> -->
</el-row>
<el-row :gutter="15" class="home-card-three">
<el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8">
<div class="home-card-item">
- <div style="height: 100%" ref="homePieRef"></div>
+ <div style="height: 100%" id="homePieChart"></div>
</div>
</el-col>
<el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16" class="home-media">
@@ -83,7 +69,7 @@
</template>
<script setup lang="ts" name="home">
-import { reactive, onMounted, ref, watch, nextTick, onActivated, markRaw, onUnmounted } from 'vue';
+import { reactive, onMounted, ref, watch, nextTick, onActivated, markRaw, onUnmounted, onBeforeUnmount } from 'vue';
import * as echarts from 'echarts';
import { storeToRefs } from 'pinia';
import { useThemeConfig } from '/@/stores/themeConfig';
@@ -91,9 +77,114 @@
import { wmsStockPassMap, wmsHomePageQuery, wmsHomePlaceQuery, wmsTransitionDiagramQuery } from '/@/api/main/inventoryWarning/inventoryWarning';
import type { TabsPaneContext } from 'element-plus';
import { useRoute, useRouter } from 'vue-router';
+import { getQueryOffOrderList, getStorageView } from '/@/api/main/ReportCenter/storageView';
const router = useRouter();
// 鎺ュ彛鏁版嵁
const loadingwms = ref(false);
+const pieChartRef = ref(null);
+let myChart = null;
+let countList = ref([
+ {
+ type: 0,
+ name: '鎬诲簱浣�',
+ value: 0,
+ },
+ {
+ type: 1,
+ name: '鏈夎揣搴撲綅',
+ value: 0,
+ },
+ {
+ type: 2,
+ name: '鏃犺揣搴撲綅',
+ value: 0,
+ },
+ {
+ type: 3,
+ name: '閿佸畾搴撲綅',
+ value: 0,
+ },
+]);
+const optionPie = {
+ title: {
+ text: '缂撳瓨宀涘簱瀛�',
+ // left: 'center',
+ textStyle: {
+ color: '#333',
+ },
+ },
+ tooltip: {
+ trigger: 'item',
+ },
+ legend: {
+ orient: 'vertical',
+ left: 'right',
+ },
+ series: [
+ {
+ name: '搴撲綅鐘舵��',
+ type: 'pie',
+ radius: ['35%', '55%'],
+ data: [],
+ // data: [
+ // { name: '鎬诲簱浣�360', value: 120 },
+ // { name: '鏈夎揣搴撲綅', value: 90 },
+ // { name: '鏃犺揣搴撲綅', value: 60 },
+ // { name: '閿佸畾搴撲綅', value: 30 },
+ // ],
+ emphasis: {
+ itemStyle: {
+ shadowBlur: 10,
+ shadowOffsetX: 0,
+ shadowColor: 'rgba(0, 0, 0, 0.5)',
+ },
+ },
+ label: {
+ // formatter: '{b}: {c} ({d}%)',
+ formatter: '{b}: {c}',
+ },
+ },
+ ],
+};
+
+var offOrderInfo = ref([])
+onMounted(() => {
+ nextTick(async () => {
+ var res = await getStorageView();
+ debugger;
+ if (res.data.code == 200) {
+ const { data } = res;
+ const result = data.result;
+ // 缁熻
+ var hasMaterialCount = result.filter((item: any) => item.stockStatus == 1).length || 0;
+ var noMaterialCount = result.length - hasMaterialCount;
+ countList.value = [
+ {
+ type: 1,
+ name: '鏈夎揣搴撲綅',
+ value: hasMaterialCount || 0,
+ },
+ {
+ type: 18,
+ name: '鏃犺揣搴撲綅',
+ value: noMaterialCount || 0,
+ },
+ ];
+ optionPie.series[0].data = countList.value;
+ myChart = echarts.init(document.getElementById('homePieChart') as HTMLDivElement);
+ myChart.setOption(optionPie);
+ }
+
+ var res = await getQueryOffOrderList();
+ // WmsCommonnQuery/QueryOffOrderList
+ if (res.data.code == 200) {
+ //debugger;
+ offOrderInfo.value = res.data.result || [];
+ }
+ });
+ handleQuery3('1');
+});
+
// 鏌ヨ
const handleQuery1 = async () => {
loadingwms.value = true;
@@ -107,7 +198,6 @@
// state.homeOne[1].num1 = result.warehousingNumber || 0
// state.homeOne[1].num2 = result.allWarehousingNumber || 0
// state.homeOne[1].numA = Math.round((result.warehousingNumber || 0) / (result.allWarehousingNumber || 0)* 10000) / 100 || 0
-
// }
loadingwms.value = false;
};
@@ -181,7 +271,7 @@
};
// handleQuery1();
// handleQuery2();
-// handleQuery3('1');
+//
// handleQuery4();
const activeName = ref('1');
const handleClick = (tab: TabsPaneContext, event: Event) => {
@@ -226,96 +316,8 @@
color2: '--next-color-success-lighter',
color3: '--el-color-success',
},
- // {
- // num1: '125,65',
- // num2: '+17.32',
- // num3: '骞村害璁″垝淇℃伅',
- // num4: 'iconfont icon-zaosheng',
- // color1: '#6690F9',
- // color2: '--next-color-warning-lighter',
- // color3: '--el-color-warning',
- // },
- // {
- // num1: '520,43',
- // num2: '-10.01',
- // num3: '璁块棶缁熻淇℃伅',
- // num4: 'fa fa-github-alt',
- // color1: '#FF6462',
- // color2: '--next-color-danger-lighter',
- // color3: '--el-color-danger',
- // },
],
- homeThree: [
- {
- icon: 'iconfont icon-yangan',
- // label: '娴呯矇绾�',
- label: '鍩虹鏁版嵁',
- value: '搴撲綅淇℃伅',
- route: '/wmsbase/wmsplace',
- // value: '2.1%OBS/M',
- iconColor: '#F72B3F',
- },
- {
- icon: 'iconfont icon-wendu',
- // label: '娣辩孩(鐚╃孩)',
- label: '鍗曟嵁绠$悊',
- value: '涓婃灦鍗�',
- route: '/wmsOrder/wmsordermovement',
- // value: '30鈩�',
- iconColor: '#91BFF8',
- },
- {
- icon: 'iconfont icon-shidu',
- label: '鎶ヨ〃涓績',
- // label: '娣$传绾�',
- // value: '57%RH',
- value: '搴撲綅瑙嗗浘',
- route: '/reportCenter/storageView',
- iconColor: '#88D565',
- },
- {
- icon: 'iconfont icon-shidu',
- // label: '寮辩传缃楀叞绾�',
- label: '鐩樼偣绠$悊',
- value: '鐩樼偣鍗曟嵁',
- // value: '107w',
- route: '/Check/wmsinventorycheckorder',
- iconColor: '#88D565',
- },
- {
- icon: 'iconfont icon-zaosheng',
- label: '鎵撳嵃涓績',
- // label: '涓传缃楀叞绾�',
- value: '璺熻釜鐮佹墦鍗�',
- // value: '57DB',
- route: '/printCenter/wmsstockquanPrint',
- iconColor: '#FBD4A0',
- },
- // {
- // icon: 'iconfont icon-zaosheng',
- // label: '绱綏鍏�',
- // value: '57PV',
- // iconColor: '#FBD4A0',
- // },
- // {
- // icon: 'iconfont icon-zaosheng',
- // label: '鏆楃传缃楀叞',
- // value: '517Cpd',
- // iconColor: '#FBD4A0',
- // },
- // {
- // icon: 'iconfont icon-zaosheng',
- // label: '骞界伒鐧�',
- // value: '12kg',
- // iconColor: '#FBD4A0',
- // },
- // {
- // icon: 'iconfont icon-zaosheng',
- // label: '娴峰啗钃�',
- // value: '64fm',
- // iconColor: '#FBD4A0',
- // },
- ],
+
myCharts: [] as EmptyArrayType,
charts: {
theme: '',
@@ -407,103 +409,103 @@
state.myCharts.push(state.global.homeChartOne);
};
// 楗煎浘
-const initPieChart = (arr: any) => {
- if (arr == null) return false;
- if (!state.global.dispose.some((b: any) => b === state.global.homeChartTwo)) state.global.homeChartTwo.dispose();
- state.global.homeChartTwo = markRaw(echarts.init(homePieRef.value, state.charts.theme));
- var getname = ['绌哄簱浣嶆暟閲�', '绌哄鍣ㄥ簱浣嶆暟閲�', '瀛樿揣鏁伴噺', '鎬诲簱浣嶏細1000'];
- var getvalue = [arr.emptyPlaceNumber, arr.containerPlaceNumber, arr.stockPlaceNumber];
- var data = [];
- for (var i = 0; i < getname.length - 1; i++) {
- data.push({ name: getname[i], value: getvalue[i] });
- }
- const colorList = ['#51A3FC', '#36C78B', '#FEC279', '#968AF5', '#E790E8'];
- const option = {
- backgroundColor: state.charts.bgColor,
- title: {
- text: '搴撲綅鍗犳瘮 鎬诲簱浣嶏細' + arr.allPlaceNumber,
- x: 'left',
- textStyle: { fontSize: '15', color: state.charts.color },
- },
- tooltip: { trigger: 'item' },
- // tooltip: { trigger: 'item', formatter: '{b} <br/> {c}%' },
- graphic: {
- elements: [
- {
- type: 'image',
- z: -1,
- style: {
- image: themeConfig.value.isIsDark
- ? ''
- : '',
- width: 230,
- height: 230,
- },
- left: '16.5%',
- top: 'center',
- },
- ],
- },
- legend: {
- type: 'scroll',
- orient: 'vertical',
- right: '0%',
- left: '65%',
- top: 'center',
- itemWidth: 14,
- itemHeight: 14,
- data: getname,
- textStyle: {
- rich: {
- name: {
- fontSize: 14,
- fontWeight: 400,
- width: 200,
- height: 35,
- padding: [0, 0, 0, 60],
- color: state.charts.color,
- },
- rate: {
- fontSize: 15,
- fontWeight: 500,
- height: 35,
- width: 40,
- padding: [0, 0, 0, 30],
- color: state.charts.color,
- },
- },
- },
- },
- series: [
- {
- type: 'pie',
- radius: ['82', themeConfig.value.isIsDark ? '50' : '102'],
- center: ['32%', '50%'],
- itemStyle: {
- color: function (params: any) {
- return colorList[params.dataIndex];
- },
- },
- label: { show: true },
- labelLine: { show: true },
- data: data,
- },
- ],
- };
- state.global.homeChartTwo.setOption(option);
- state.myCharts.push(state.global.homeChartTwo);
-};
+// const initPieChart = (arr: any) => {
+// if (arr == null) return false;
+// if (!state.global.dispose.some((b: any) => b === state.global.homeChartTwo)) state.global.homeChartTwo.dispose();
+// state.global.homeChartTwo = markRaw(echarts.init(homePieRef.value, state.charts.theme));
+// var getname = ['鎬诲簱浣�360', '鏈夎揣搴撲綅', '鏃犺揣搴撲綅', '閿佸畾搴撲綅'];
+// var getvalue = [arr.emptyPlaceNumber, arr.containerPlaceNumber, arr.stockPlaceNumber];
+// var data = [];
+// for (var i = 0; i < getname.length - 1; i++) {
+// data.push({ name: getname[i], value: getvalue[i] });
+// }
+// const colorList = ['#51A3FC', '#36C78B', '#FEC279', '#968AF5'];
+// const option = {
+// backgroundColor: state.charts.bgColor,
+// title: {
+// text: '搴撲綅鍗犳瘮 鎬诲簱浣嶏細' + arr.allPlaceNumber,
+// x: 'left',
+// textStyle: { fontSize: '15', color: state.charts.color },
+// },
+// tooltip: { trigger: 'item' },
+// // tooltip: { trigger: 'item', formatter: '{b} <br/> {c}%' },
+// graphic: {
+// elements: [
+// {
+// type: 'image',
+// z: -1,
+// style: {
+// image: themeConfig.value.isIsDark
+// ? ''
+// : '',
+// width: 230,
+// height: 230,
+// },
+// left: '16.5%',
+// top: 'center',
+// },
+// ],
+// },
+// legend: {
+// type: 'scroll',
+// orient: 'vertical',
+// right: '0%',
+// left: '65%',
+// top: 'center',
+// itemWidth: 14,
+// itemHeight: 14,
+// data: getname,
+// textStyle: {
+// rich: {
+// name: {
+// fontSize: 14,
+// fontWeight: 400,
+// width: 200,
+// height: 35,
+// padding: [0, 0, 0, 60],
+// color: state.charts.color,
+// },
+// rate: {
+// fontSize: 15,
+// fontWeight: 500,
+// height: 35,
+// width: 40,
+// padding: [0, 0, 0, 30],
+// color: state.charts.color,
+// },
+// },
+// },
+// },
+// series: [
+// {
+// type: 'pie',
+// radius: ['82', themeConfig.value.isIsDark ? '50' : '102'],
+// center: ['32%', '50%'],
+// itemStyle: {
+// color: function (params: any) {
+// return colorList[params.dataIndex];
+// },
+// },
+// label: { show: true },
+// labelLine: { show: true },
+// data: data,
+// },
+// ],
+// };
+// state.global.homeChartTwo.setOption(option);
+// state.myCharts.push(state.global.homeChartTwo);
+// };
// 鏌辩姸鍥�
const option = {
backgroundColor: state.charts.bgColor,
title: {
- text: '涓婁笅鏋舵帹绉诲浘',
+ text: '鐢熶骇璁㈠崟鎺ㄧЩ鍥�',
x: 'left',
textStyle: { fontSize: '12', color: state.charts.color },
},
tooltip: { trigger: 'axis' },
//legend: { data: ['鍏ュ簱','鍑哄簱', '搴撳瓨', '骞冲潎'], right: 0 },
- legend: { data: ['涓婃灦', '涓嬫灦'], right: 0 },
+ legend: { data: ['鐢熶骇璁㈠崟'], right: 0 },
grid: { top: 50, right: 80, bottom: 100, left: 60 },
// grid: { top: 70, right: 80, bottom: 30, left: 80 },
xAxis: [
@@ -537,38 +539,38 @@
// },
],
series: [
+ // {
+ // name: '涓婄嚎',
+ // type: 'line',
+ // smooth: true,
+ // showSymbol: true,
+ // // 鐭㈤噺鐢讳簲瑙掓槦
+ // symbol: 'path://M150 0 L80 175 L250 75 L50 75 L220 175 Z',
+ // symbolSize: 12,
+ // yAxisIndex: 0,
+ // areaStyle: {
+ // color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
+ // { offset: 0, color: 'rgba(250,180,101,0.3)' },
+ // { offset: 1, color: 'rgba(250,180,101,0)' },
+ // ]),
+ // shadowColor: 'rgba(250,180,101,0.2)',
+ // shadowBlur: 20,
+ // },
+ // itemStyle: { color: '#FF8000' },
+ // // data涓彲浠ヤ娇鐢ㄥ璞★紝value浠h〃鐩稿簲鐨勫�硷紝鍙﹀鍙姞鍏ヨ嚜瀹氫箟鐨勫睘鎬�
+ // // data: [
+ // // { value: 1, stationName: 's1' },
+ // // { value: 3, stationName: 's2' },
+ // // { value: 4, stationName: 's3' },
+ // // { value: 9, stationName: 's4' },
+ // // { value: 3, stationName: 's5' },
+ // // { value: 2, stationName: 's6' },
+ // // ],
+ // // data:dataAll.value.arr1
+ // data: [],
+ // },
{
- name: '涓婃灦',
- type: 'line',
- smooth: true,
- showSymbol: true,
- // 鐭㈤噺鐢讳簲瑙掓槦
- symbol: 'path://M150 0 L80 175 L250 75 L50 75 L220 175 Z',
- symbolSize: 12,
- yAxisIndex: 0,
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- { offset: 0, color: 'rgba(250,180,101,0.3)' },
- { offset: 1, color: 'rgba(250,180,101,0)' },
- ]),
- shadowColor: 'rgba(250,180,101,0.2)',
- shadowBlur: 20,
- },
- itemStyle: { color: '#FF8000' },
- // data涓彲浠ヤ娇鐢ㄥ璞★紝value浠h〃鐩稿簲鐨勫�硷紝鍙﹀鍙姞鍏ヨ嚜瀹氫箟鐨勫睘鎬�
- // data: [
- // { value: 1, stationName: 's1' },
- // { value: 3, stationName: 's2' },
- // { value: 4, stationName: 's3' },
- // { value: 9, stationName: 's4' },
- // { value: 3, stationName: 's5' },
- // { value: 2, stationName: 's6' },
- // ],
- // data:dataAll.value.arr1
- data: [],
- },
- {
- name: '涓嬫灦',
+ name: '鐢熶骇璁㈠崟',
type: 'line',
smooth: true,
showSymbol: true,
@@ -639,8 +641,8 @@
state.global.homeCharThree = markRaw(echarts.init(chart, state.charts.theme));
//鎵嬪姩璧嬪��
option.xAxis[0].data = dataAll.value.arr5;
- option.series[0].data = dataAll.value.arr1;
- option.series[1].data = dataAll.value.arr2;
+ option.series[0].data = dataAll.value.arr2;
+ //option.series[1].data = dataAll.value.arr2;
// option.series[2].data = dataAll.value.arr3
// option.series[3].data = dataAll.value.arr4
// 缁樺埗鍥捐〃
@@ -671,18 +673,17 @@
// 瀹氭椂鍣�
let timeInter: any = null;
// 椤甸潰鍔犺浇鏃�
-onMounted(() => {
- // initEchartsResize();
-
- // timeInter = setInterval(() => {
- // nextTick(() => {
- // handleQuery1();
- // handleQuery2();
- // handleQuery3('1');
- // handleQuery4();
- // });
- // }, 15000); //璋冪敤棰戠巼鏀逛负 15绉掍竴娆℃煡璇€��
-});
+// onMounted(() => {
+// // initEchartsResize();
+// // timeInter = setInterval(() => {
+// // nextTick(() => {
+// // handleQuery1();
+// // handleQuery2();
+// // handleQuery3('1');
+// // handleQuery4();
+// // });
+// // }, 15000); //璋冪敤棰戠巼鏀逛负 15绉掍竴娆℃煡璇€��
+// });
onUnmounted(() => {
clearInterval(timeInter); //閿�姣�
@@ -700,30 +701,30 @@
initEchartsResizeFun();
}
);
-// 鐩戝惉 pinia 涓槸鍚﹀紑鍚繁鑹蹭富棰�
-watch(
- () => themeConfig.value.isIsDark,
- (isIsDark) => {
- nextTick(() => {
- state.charts.theme = isIsDark ? 'dark' : '';
- state.charts.bgColor = isIsDark ? 'transparent' : '';
- state.charts.color = isIsDark ? '#dadada' : '#303133';
- // setTimeout(() => {
- // initLineChart(null,null,null);
- // }, 500);
- // setTimeout(() => {
- // initPieChart(null);
- // }, 700);
- // setTimeout(() => {
- // initBarChart(null,null,null,null);
- // }, 1000);
- });
- },
- {
- deep: true,
- immediate: true,
- }
-);
+// // 鐩戝惉 pinia 涓槸鍚﹀紑鍚繁鑹蹭富棰�
+// watch(
+// () => themeConfig.value.isIsDark,
+// (isIsDark) => {
+// nextTick(() => {
+// state.charts.theme = isIsDark ? 'dark' : '';
+// state.charts.bgColor = isIsDark ? 'transparent' : '';
+// state.charts.color = isIsDark ? '#dadada' : '#303133';
+// setTimeout(() => {
+// initLineChart(null, null, null);
+// }, 500);
+// setTimeout(() => {
+// initPieChart(null);
+// }, 700);
+// // setTimeout(() => {
+// // initBarChart(null,null,null,null);
+// // }, 1000);
+// });
+// },
+// {
+// deep: true,
+// immediate: true,
+// }
+// );
</script>
<style scoped lang="scss">
@@ -735,7 +736,7 @@
.home-card-three {
.home-card-item {
width: 100%;
- height: 130px;
+ height: 160px;
border-radius: 4px;
transition: all ease 0.3s;
padding: 20px;
@@ -777,7 +778,7 @@
.home-card-two,
.home-card-three {
.home-card-item {
- height: 400px;
+ height: 500px;
width: 100%;
overflow: hidden;
.home-monitor {
@@ -827,4 +828,12 @@
color: var(--el-text-color-primary);
border: 1px solid var(--next-border-color-light);
}
+.font30{
+ font-size: 39px !important;
+ margin: 24px 0;
+ color: orange;
+}
+.font16{
+ font-size: 24px !important;
+}
</style>
--
Gitblit v1.9.3