| | |
| | | <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"> |
| | |
| | | </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"> |
| | |
| | | </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'; |
| | |
| | | import { wmsStockPassMap, wmsHomePageQuery, wmsHomePlaceQuery, wmsTransitionDiagramQuery } from '/@/api/main/inventoryWarning/inventoryWarning'; |
| | | import type { TabsPaneContext } from 'element-plus'; |
| | | import { useRoute, useRouter } from 'vue-router'; |
| | | import { 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}', |
| | | }, |
| | | }, |
| | | ], |
| | | }; |
| | | |
| | | 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: '', |
| | | name: '总库位', |
| | | value: result.length || 0, |
| | | }, |
| | | { |
| | | type: 1, |
| | | name: '有货库位', |
| | | value: hasMaterialCount || 0, |
| | | }, |
| | | { |
| | | type: 18, |
| | | name: '无货库位', |
| | | value: noMaterialCount || 0, |
| | | }, |
| | | { |
| | | type: 2, |
| | | name: '锁定库位', |
| | | value: result.filter((item: any) => item.stockStatus == 2).length || 0, |
| | | }, |
| | | ]; |
| | | optionPie.series[0].data = countList.value; |
| | | myChart = echarts.init(document.getElementById('homePieChart') as HTMLDivElement); |
| | | myChart.setOption(optionPie); |
| | | |
| | | |
| | | } |
| | | }); |
| | | }); |
| | | |
| | | // 查询 |
| | | const handleQuery1 = async () => { |
| | | loadingwms.value = true; |
| | |
| | | // 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; |
| | | }; |
| | |
| | | // 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: '', |
| | |
| | | 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, |
| | |
| | | // 定时器 |
| | | 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); //销毁 |
| | |
| | | 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"> |