22
schangxiang@126.com
2024-12-16 842b40ba0afed53b69cdb34b3e5ec27b8ca26f66
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代表相应的值,另外可加入自定义的属性
      //    // 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代表相应的值,另外可加入自定义的属性
         // 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>