liuying
2024-12-10 de04aec9646c29f3995965fcc0ae7f0e4dfe960b
首页
已修改1个文件
388 ■■■■ 文件已修改
LA24030_LuLiPackageLine_Web/src/views/home/index.vue 388 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
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();
// onMounted(() => {
//     // initEchartsResize();
//     // timeInter = setInterval(() => {
//     //     nextTick(() => {
//     //         handleQuery1();
//     //         handleQuery2();
//     //         handleQuery3('1');
//     //         handleQuery4();
//     //     });
//     // }, 15000); //调用频率改为 15秒一次查询。
    //     });
    // }, 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);