From 143b8e2ec209a703c21c0f87709e90f0d752f016 Mon Sep 17 00:00:00 2001 From: schangxiang@126.com <schangxiang@126.com> Date: 周二, 10 12月 2024 14:51:04 +0800 Subject: [PATCH] Merge branch 'master' of http://222.71.245.114:9086/r/LA24030-LuLI_PackageLine --- LA24030_LuLiPackageLine_Web/src/views/home/index.vue | 390 ++++++++++++++++++++++++++----------------------------- 1 files changed, 184 insertions(+), 206 deletions(-) diff --git a/LA24030_LuLiPackageLine_Web/src/views/home/index.vue b/LA24030_LuLiPackageLine_Web/src/views/home/index.vue index 6ae4a8f..0571968 100644 --- a/LA24030_LuLiPackageLine_Web/src/views/home/index.vue +++ b/LA24030_LuLiPackageLine_Web/src/views/home/index.vue @@ -5,13 +5,33 @@ <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">鏈懆涓嬬嚎璁㈠崟鏁�</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" 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" 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 }"> <div class="home-card-item flex"> <div class="flex-margin flex w100" :class="` home-one-animation${k}`"> <div class="flex-auto"> @@ -24,37 +44,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 +78,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'; @@ -94,6 +89,61 @@ const router = useRouter(); // 鎺ュ彛鏁版嵁 const loadingwms = ref(false); +const pieChartRef = ref(null); +let myChart = null; +const optionPie = { + title: { + text: '缂撳瓨宀涚粺璁�', + left: 'center', + textStyle: { + color: '#333', + }, + }, + tooltip: { + trigger: 'item', + }, + legend: { + orient: 'vertical', + left: 'left', + }, + series: [ + { + name: '搴撲綅鐘舵��', + type: 'pie', + radius: ['50%', '70%'], + 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}%)', + }, + }, + ], +}; + +onMounted(() => { + nextTick(() => { + myChart = echarts.init(document.getElementById('homePieChart') as HTMLDivElement); + const data = [ + { name: '鎬诲簱浣�360', value: 120 }, + { name: '鏈夎揣搴撲綅', value: 90 }, + { name: '鏃犺揣搴撲綅', value: 60 }, + { name: '閿佸畾搴撲綅', value: 30 }, + ]; + myChart.setOption(optionPie); + }); +}); + // 鏌ヨ const handleQuery1 = async () => { loadingwms.value = true; @@ -107,7 +157,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; }; @@ -245,77 +294,7 @@ // 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,92 +386,92 @@ 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, @@ -671,18 +650,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); //閿�姣� @@ -708,12 +686,12 @@ 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(() => { + initLineChart(null, null, null); + }, 500); + setTimeout(() => { + initPieChart(null); + }, 700); // setTimeout(() => { // initBarChart(null,null,null,null); // }, 1000); -- Gitblit v1.9.3