ll
liukangdong
2024-10-31 a030368330d5a6bf1d0ed42b6121b53d13b587d0
screen/src/views/LogisticsEfficiency.vue
@@ -20,19 +20,23 @@
                <div>累计出库量统计</div>
              </div>
              <div class="tabs">
                <div class="tab active">本月</div>
                <div class="tab" :class="{ active: activeTab1 == 0 }" @click="tabClick1(0)">本月</div>
                <div class="separate"></div>
                <div class="tab">本年</div>
                <div class="tab" :class="{ active: activeTab1 == 1 }" @click="tabClick1(1)">本年</div>
              </div>
              <img src="@/assets/images/title@2x.png" class="bg" alt="" />
            </div>
            <div class="content_wrap">
              <div class="content">
                <div class="num">1000000</div>
                <div class="unit_wrap">
                <div class="num">{{ activeTab1 == 0 ? data1.monthOutTotal : data1.yearOutTotal }}</div>
                <div class="unit_wrap" v-if="data1.monthOutTotalOnYear || data1.yearOutTotalOnYear">
                  <span style="color: #869CC9;">同比</span>
                  <img src="@/assets/images/ic_up.png" class="icon" alt="">
                  <span>10.2%</span>
                  <img
                    v-if="(activeTab1 == 0 && data1.monthOutTotalOnYear > 0) || (activeTab1 == 1 && data1.yearOutTotalOnYear > 0)"
                    src="@/assets/images/ic_up.png" class="icon" alt="">
                  <img v-else src="@/assets/images/ic_down.png" class="icon" alt="">
                  <span>{{ activeTab1 == 0 ? Math.abs(data1.monthOutTotalOnYear) : Math.abs(data1.yearOutTotalOnYear)
                    }}%</span>
                </div>
              </div>
              <div class="train_wrap">
@@ -41,7 +45,8 @@
                </div>
                <div class="total">
                  <span>累计出库车次</span>
                  <span><strong>3900</strong><span class="unit">次</span></span>
                  <span><strong>{{ activeTab1 == 0 ? data1.monthOutTimes : data1.yearOutTimes }}</strong><span
                      class="unit">次</span></span>
                </div>
              </div>
            </div>
@@ -50,14 +55,14 @@
            <div class="com_header">
              <div class="title">
                <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
                <div>月能耗分析</div>
                <div>运输任务分析</div>
              </div>
              <div class="tabs">
                <div class="tab active">近7日</div>
                <div class="tab" :class="{ active: activeTab2 == 0 }" @click="tabClick2(0)">近7日</div>
                <div class="separate"></div>
                <div class="tab">本月</div>
                <div class="tab" :class="{ active: activeTab2 == 1 }" @click="tabClick2(1)">本月</div>
                <div class="separate"></div>
                <div class="tab">本年</div>
                <div class="tab" :class="{ active: activeTab2 == 2 }" @click="tabClick2(2)">本年</div>
              </div>
              <img src="@/assets/images/title@2x.png" class="bg" alt="" />
            </div>
@@ -83,13 +88,14 @@
                  <span class="item addr">收货单位</span>
                  <span class="item time">任务开始时间</span>
                </div>
                <div class="line" v-for="i in 7">
                  <span class="item flag"><span class="flag_bg">出</span></span>
                  <span class="item order">11</span>
                  <span class="item id_card">11</span>
                  <span class="item status">11</span>
                  <span class="item addr">11</span>
                  <span class="item time">11</span>
                <div class="line" v-for="item in dataList3">
                  <span class="item flag"><span :class="{ flag_bg: item.type == 1 || item.type == 3 }">{{ item.type == 1
                    || item.type == 3 ? '出' : '入' }}</span></span>
                  <span class="item order">{{ item.billCode || item.contractNum }}</span>
                  <span class="item id_card">{{ item.carCodeFront }}</span>
                  <span class="item status">{{ statusMap[item.status].label }}</span>
                  <span class="item addr">{{ item.repertotyAddress }}</span>
                  <span class="item time" v-if="item.confirmTaskDate">{{ item.confirmTaskDate.slice(5, 16) }}</span>
                </div>
              </div>
            </div>
@@ -98,12 +104,14 @@
        <div class="center_box">
          <div class="center_box_one">
            <div class="tabs">
              <div class="tab active">
                <img src="@/assets/images/energy_ef/chuku_task_ac.png" alt="">
              <div class="tab" :class="{ active: activeTab4 == 0 }" @click="tabClick4(0)">
                <img v-if="activeTab4 == 0" src="@/assets/images/energy_ef/chuku_task_ac.png" alt="">
                <img v-else src="@/assets/images/energy_ef/chuku_task.png" alt="">
                <span>出库任务</span>
              </div>
              <div class="tab">
                <img src="@/assets/images/energy_ef/ruku_task.png" alt="">
              <div class="tab" :style="{ color: activeTab4 == 1 ? '#387df0' : '#d8e4f8' }" @click="tabClick4(1)">
                <img v-if="activeTab4 == 1" src="@/assets/images/energy_ef/ruku_task_ac.png" alt="">
                <img v-if="activeTab4 == 0" src="@/assets/images/energy_ef/ruku_task.png" alt="">
                <span>入库任务</span>
              </div>
            </div>
@@ -112,21 +120,22 @@
                <img src="@/assets/images/energy_ef/ic_renwuzongliang@2x.png" alt="">
                <div class="content">
                  <div class="name">当前任务量</div>
                  <div class="num"><span>1000</span>万支</div>
                  <div class="num"><span>{{ data4.planTaskNum }}</span>万支</div>
                </div>
              </div>
              <div class="item">
                <img src="@/assets/images/energy_ef/ic_wanchengrenwu@2x.png" alt="">
                <div class="content">
                  <div class="name">当日完成任务总量</div>
                  <div class="num"><span class="today">1000</span>万支</div>
                  <div class="num"><span class="today">{{ data4.finishTaskNum }}</span>万支</div>
                </div>
              </div>
              <div class="item">
                <img src="@/assets/images/energy_ef/ic_bili@2x.png" alt="">
                <div class="content">
                  <div class="name">已完成比例</div>
                  <div class="num"><span class="finish">1000</span>万支</div>
                  <div class="num" v-if="data4.finishTaskNum && data4.planTaskNum"><span class="finish">{{ ((
                    data4.finishTaskNum / data4.planTaskNum) * 100).toFixed(1) }}%</span>万支</div>
                </div>
              </div>
            </div>
@@ -143,9 +152,9 @@
                <div>出入库效率</div>
              </div>
              <div class="tabs">
                <div class="tab active">今日</div>
                <div class="tab" :class="{ active: activeTab12 == 0 }" @click="tabClick12(0)">今日</div>
                <div class="separate"></div>
                <div class="tab">本月</div>
                <div class="tab" :class="{ active: activeTab12 == 1 }" @click="tabClick12(1)">本月</div>
              </div>
              <img src="@/assets/images/title@2x.png" class="bg" alt="" />
            </div>
@@ -154,14 +163,16 @@
                <img src="@/assets/images/energy_ef/ic_chukuxiaolv@2x.png" alt="">
                <div class="content">
                  <div class="name">出库效率</div>
                  <div class="num"><span>1000</span>万支/小时</div>
                  <div class="num"><span>{{ activeTab12 == 0 ? data1.todayInRata : data1.monthInRata }}</span>万支/小时
                  </div>
                </div>
              </div>
              <div class="item">
                <img src="@/assets/images/energy_ef/ic_rukuxiaolv@2x.png" alt="">
                <div class="content">
                  <div class="name">入库效率</div>
                  <div class="num"><span class="today">1000</span>万支/小时</div>
                  <div class="num"><span class="today">{{ activeTab12 == 0 ? data1.monthOutTotal : data1.yearOutTotal
                      }}</span>万支/小时</div>
                </div>
              </div>
            </div>
@@ -177,32 +188,18 @@
            <div class="content">
              <div class="echart_wrap">
                <div class="pie_text">
                  <div class="fs30"><strong>300</strong></div>
                  <div class="fs30"><strong>{{ data5 }}</strong></div>
                  <div>入库数量</div>
                </div>
                <div class="echart" id="echart1"></div>
              </div>
              <div class="list">
                <div class="item">
                <div class="item" v-for="item, i in dataList5">
                  <div class="line">
                    <div :style="{ background: colors[0] }" class="icon"></div>
                    <div class="text">合肥厂</div>
                    <div :style="{ background: colors[i] }" class="icon"></div>
                    <div class="text">{{ item.name }}</div>
                  </div>
                  <div :style="{ color: colors[0] }" class="num">100万支 | 55%</div>
                </div>
                <div class="item">
                  <div class="line">
                    <div :style="{ background: colors[1] }" class="icon"></div>
                    <div class="text">集散中心</div>
                  </div>
                  <div :style="{ color: colors[1] }" class="num">100万支 | 55%</div>
                </div>
                <div class="item">
                  <div class="line">
                    <div :style="{ background: colors[2] }" class="icon"></div>
                    <div class="text">市公司</div>
                  </div>
                  <div :style="{ color: colors[2] }" class="num">100万支 | 55%</div>
                  <div :style="{ color: colors[i] }" class="num">{{ item.value }}万支 | {{ item.rate }}%</div>
                </div>
              </div>
            </div>
@@ -218,19 +215,15 @@
            <div class="repertory">
              <div class="use_ratio">
                <div class="header">
                  <div>库存量 <span class="num">80/100</span></div>
                  <div>利用率 88%</div>
                  <div>库存量 <span class="num">{{data1.stockTotal}}/{{data1.stockMax}}</span></div>
                  <div v-if="data1.stockTotal && data1.stockMax">利用率{{ ((data1.stockTotal / data1.stockMax) * 100).toFixed(0) }}%</div>
                </div>
                <Percent :rate="80" />
                <Percent v-if="data1.stockTotal && data1.stockMax" :rate="((data1.stockTotal / data1.stockMax) * 100).toFixed(0)" />
              </div>
              <div class="list">
                <div class="item">
                  <div class="la">黄山(新制皖烟)</div>
                  <div class="val">400万支</div>
                </div>
                <div class="item">
                  <div class="la">黄山(新制皖烟)</div>
                  <div class="val">400万支</div>
                <div class="item" v-for="item in dataList6">
                  <div class="la">{{ item.name }}</div>
                  <div class="val">{{item.num}}万支</div>
                </div>
              </div>
            </div>
@@ -278,10 +271,10 @@
      itemGap: 12,
      // icon: 'circle',
      right: '12px',
      top: '0',
      data: ['总库存', '当前库存', '库存利用率'],
      itemWidth: 20,
      itemHeight: 10,
      top: '10px',
      data: ['计划任务量', '任务完成量', '计划任务数'],
      itemWidth: 12,
      itemHeight: 4,
      textStyle: {
        color: '#fff',
        borderColor: '#fff'
@@ -291,7 +284,7 @@
      left: '3%',
      right: '4%',
      bottom: '3%',
      top: '16%',
      top: '18%',
      containLabel: true
    },
    tooltip: {
@@ -313,7 +306,7 @@
      axisTick: {
        show: false,
      },
      data: ['7.1', '7.1', '7.1', '7.1', '7.1'],
      data: dataList2.value.map(i => i.planDate),
    }],
    yAxis: [
      {
@@ -353,7 +346,7 @@
    ],
    series: [
      {
        name: '计划完成数量',
        name: '计划任务量',
        type: 'bar',
        barWidth: 10,
        barGap: '60%',
@@ -379,7 +372,7 @@
          },
          barBorderRadius: [3, 3, 0, 0],
        },
        data: [900, 438, 485, 631, 689]
        data: dataList2.value.map(i => i.planTaskNum)
      },
      {
        name: '任务完成量',
@@ -407,7 +400,7 @@
          },
          barBorderRadius: [3, 3, 0, 0],
        },
        data: [438, 485, 631, 689, 900]
        data: dataList2.value.map(i => i.finishTaskNum)
      },
      {
        name: '计划任务数',
@@ -423,7 +416,7 @@
          position: 'top',
          color: '#fff',
        },
        data: [485, 631, 389, 224, 287]
        data: dataList2.value.map(i => i.planTimes)
      }
    ]
  })
@@ -451,11 +444,7 @@
        labelLine: {
          show: false
        },
        data: [
          { value: 1048, name: 'Search Engine' },
          { value: 735, name: 'Direct' },
          { value: 580, name: 'Email' }
        ]
        data: dataList5.value
      }
    ]
  }
@@ -634,40 +623,87 @@
  })
}
const dataList1 = ref([])
const data1 = ref({})
const activeTab1 = ref(0)
const activeTab12 = ref(0)
const tabClick1 = (val) => {
  activeTab1.value = val
}
const tabClick12 = (val) => {
  activeTab12.value = val
}
const getData1 = () => {
  wlcenterData().then(res => {
    const result = res
    const result = res.data
    data1.value = result
  })
}
const dataList2 = ref([])
const activeTab2 = ref(0)
const tabClick2 = (val) => { activeTab2.value = val }
const getData2 = () => {
  wlcenterData().then(res => {
    const result = res
  wltransportMeasure({ queryType: activeTab2.value }).then(res => {
    const result = res.data
    dataList2.value = result
    initEnergy()
  })
}
const dataList3 = ref([])
const statusMap = [
  { value: 0, label: '待确认' },
  { value: 1, label: '待签到' },
  { value: 2, label: '等待叫号' },
  { value: 3, label: '入园等待' },
  { value: 4, label: '月台等待' },
  { value: 5, label: '作业中' },
  { value: 6, label: '作业完成' },
  { value: 7, label: '转移中' },
  { value: 8, label: '异常挂起' },
  { value: 9, label: '已授权离园' },
  { value: 10, label: '已离园' },
  { value: 11, label: '已过号' },
  { value: 12, label: '已取消' },
]
const getData3 = () => {
  wlcenterData().then(res => {
    const result = res
  wlplatformJobList().then(res => {
    const result = res.data
    dataList3.value = result
  })
}
const dataList4 = ref([])
const data4 = ref({})
const activeTab4 = ref(0)
const tabClick4 = (val) => { activeTab4.value = val }
const getData4 = () => {
  wlcenterData().then(res => {
    const result = res
  wljobData({ queryType: activeTab4.value }).then(res => {
    const result = res.data
    data4.value = result
  })
}
const dataList5 = ref([])
const data5 = ref(0)
const getData5 = () => {
  wlcenterData().then(res => {
    const result = res
  wltotalInList().then(res => {
    const result = res.data || []
    let count = 0
    dataList5.value = result.map(i => {
      i.value = i.num
      count += i.num
      return i
    })
    dataList5.value.forEach(i => {
      i.rate = ((i.num / count) * 100).toFixed(0)
    })
    data5.value = count
    initEchart1()
  })
}
const dataList6 = ref([])
const getData6 = () => {
  wlcenterData().then(res => {
    const result = res
  wlstockList().then(res => {
    const result = res.data
    dataList6.value = result
  })
}
onMounted(() => {
@@ -677,9 +713,7 @@
  getData4()
  getData5()
  getData6()
  return
  initEnergy()
  initEchart1()
  initMap()
})
@@ -811,10 +845,6 @@
            &:nth-of-type(2n) {
              background: rgba(27, 64, 97, 0.52);
              .flag_bg {
                background: #01ABFE !important;
              }
            }
            .item {
@@ -828,7 +858,7 @@
              flex: 3;
              display: flex;
              .flag_bg {
              span {
                width: 22px;
                height: 22px;
                display: flex;
@@ -838,6 +868,10 @@
                background: #00F2F3;
                font-weight: 500;
                color: #001B3C;
              }
              .flag_bg {
                background: #4eacf6;
              }
            }
@@ -876,6 +910,7 @@
          display: flex;
          align-items: center;
          margin-right: 30px;
          cursor: pointer;
          img {
            width: 20px;
@@ -900,12 +935,13 @@
      .static_wrap {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin: 30px 0 54px;
        .item {
          display: flex;
          justify-content: center;
          flex: 1;
          img {
            width: 68px;
@@ -959,7 +995,6 @@
      .echart_map {
        width: 100%;
        height: 100%;
        border: 1px solid;
      }
    }
  }
@@ -1032,7 +1067,6 @@
        justify-content: center;
        align-items: center;
        height: 200px;
        border: 1px solid;
        .echart_wrap {
          position: relative;
@@ -1118,7 +1152,9 @@
        .list {
          margin-top: 22px;
          height: 240px;
          overflow: auto;
          scrollbar-width: none;
          .item {
            width: 100%;
            height: 36px;
@@ -1241,6 +1277,10 @@
      margin: 0 6px;
    }
    .tab {
      cursor: pointer;
    }
    .active {
      color: #0094eb;
    }