<template>
|
<v-scale-screen width="1920" height="960">
|
<div class="main_app">
|
<img src="@/assets/images/energy_ef/bg@2x.png" class="main_bg" alt="" />
|
<div class="main_header">
|
<!-- <img src="@/assets/images/maintitle.gif" class="main_header_bg" alt="" /> -->
|
<div class="title">安泰智慧物流园区-调度能效跟踪</div>
|
<div class="time_wrap">
|
<span class="date">{{ date }}</span>
|
<span class="week">{{ week }}</span>
|
<span class="time">{{ time }}</span>
|
</div>
|
</div>
|
<div class="main_content">
|
<div class="left_box">
|
<div class="left_box_one">
|
<div class="com_header">
|
<div class="title">
|
<img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
|
<div>累计出库量统计</div>
|
</div>
|
<div class="tabs">
|
<div class="tab" :class="{ active: activeTab1 == 0 }" @click="tabClick1(0)">本月</div>
|
<div class="separate"></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" v-if="data1.monthOutTotal || data1.yearOutTotal">{{ activeTab1 == 0 ?
|
data1.monthOutTotal.toLocaleString() : data1.yearOutTotal.toLocaleString() }}</div>
|
<div class="unit_wrap">
|
<span style="color: #869CC9;">{{ activeTab1 == 0 ? '同比' : '环比' }}</span>
|
<template v-if="activeTab1 == 0 && data1.monthLastOutTotal">
|
<img v-if="data1.monthOutTotal > data1.monthLastOutTotal" src="@/assets/images/ic_up.png"
|
class="icon" alt="">
|
<img v-else src="@/assets/images/ic_down.png" class="icon" alt="">
|
</template>
|
<template v-if="activeTab1 == 1 && data1.yearLastOutTotal">
|
<img v-if="data1.yearOutTotal > data1.yearLastOutTotal" src="@/assets/images/ic_up.png"
|
class="icon" alt="">
|
<img v-else src="@/assets/images/ic_down.png" class="icon" alt="">
|
</template>
|
|
<span v-if="activeTab1 == 0 && data1.monthLastOutTotal">{{ Math.abs((((data1.monthOutTotal - data1.monthLastOutTotal)/data1.monthLastOutTotal) * 100).toFixed(1)) }}%</span>
|
<span v-else-if="activeTab1 == 1 && data1.yearLastOutTotal">{{ Math.abs((((data1.yearOutTotal - data1.yearLastOutTotal)/data1.yearLastOutTotal) * 100).toFixed(1)) }}%</span>
|
<span v-else>-</span>
|
</div>
|
</div>
|
<div class="train_wrap">
|
<div class="icon_wrap">
|
<img src="@/assets//images/energy_ef/chuku_ic_car@2x.png" alt="">
|
</div>
|
<div class="total">
|
<span>累计出库车次</span>
|
<span><strong>{{ activeTab1 == 0 ? data1.monthOutTimes : data1.yearOutTimes }}</strong><span
|
class="unit">次</span></span>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="left_box_two">
|
<div class="com_header">
|
<div class="title">
|
<img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
|
<div>运输任务分析</div>
|
</div>
|
<div class="tabs">
|
<div class="tab" :class="{ active: activeTab2 == 0 }" @click="tabClick2(0)">近7日</div>
|
<div class="separate"></div>
|
<div class="tab" :class="{ active: activeTab2 == 1 }" @click="tabClick2(1)">本月</div>
|
<div class="separate"></div>
|
<div class="tab" :class="{ active: activeTab2 == 2 }" @click="tabClick2(2)">本年</div>
|
</div>
|
<img src="@/assets/images/title@2x.png" class="bg" alt="" />
|
</div>
|
<div class="energy_wrap">
|
<div class="energyRef"></div>
|
</div>
|
</div>
|
<div class="left_box_three">
|
<div class="com_header">
|
<div class="title">
|
<img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
|
<div>当前运输任务</div>
|
</div>
|
<img src="@/assets/images/title@2x.png" class="bg" alt="" />
|
</div>
|
<div class="list_wrap">
|
<div class="list">
|
<div class="header line">
|
<span class="item flag">标识</span>
|
<span class="item order">运输单号</span>
|
<span class="item id_card">运输车辆</span>
|
<span class="item status">作业状态</span>
|
<span class="item addr">收货单位</span>
|
<span class="item time">任务开始时间</span>
|
</div>
|
<div class="one-swiper list_temp">
|
<div class="swiper-wrapper">
|
<div class="line swiper-slide one-swiper-slide" @click="showModal = true" 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">{{ item.confirmTaskDate ? item.confirmTaskDate.slice(5, 16) : '-'
|
}}</span>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="center_box">
|
<div class="center_box_one">
|
<div class="tabs">
|
<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" :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>
|
<div class="static_wrap">
|
<div class="item">
|
<img src="@/assets/images/energy_ef/ic_renwuzongliang@2x.png" alt="">
|
<div class="content">
|
<div class="name">当前任务量</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">{{ 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" v-if="data4.finishTaskNum && data4.planTaskNum"><span class="finish">{{ ((
|
data4.finishTaskNum / data4.planTaskNum) * 100).toFixed(1) }}%</span>万支</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="center_box_two">
|
<div class="list">
|
<div class="item">
|
<img src="@/assets/images/LogisticsCenter/car_zaitu@2x.png" alt="">
|
<span>在途:{{ data7.busyNum }}</span>
|
</div>
|
<div class="item">
|
<img src="@/assets/images/LogisticsCenter/car_kongxian@2x.png" alt="">
|
<span>空闲:{{ data7.idleNum }}</span>
|
</div>
|
<div class="item">
|
<img src="@/assets/images/LogisticsCenter/car_lixian@2x.png" alt="">
|
<span>离线:{{ data7.offlineNum }}</span>
|
</div>
|
</div>
|
<div class="echart_wrap">
|
<div ref="echartMap" class="echart_map" id="echartMap"></div>
|
</div>
|
<div class="warnning_info">
|
<div class="head" @click="isShowCarW = !isShowCarW">
|
<img src="../assets/images/FireFighting/fire_right.png" alt="">
|
<span>车辆报警</span>
|
</div>
|
<div v-if="isShowCarW" class="war_list">
|
<div class="line" v-for="item in data7.eventList">
|
<div class="id_card">{{ item.carCode }}</div>
|
<div class="title">{{ item.title }}</div>
|
<div v-if="item.time">{{ item.time.slice(11) }}</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="right_box">
|
<div class="right_box_one">
|
<div class="com_header">
|
<div class="title">
|
<img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
|
<div>出入库效率</div>
|
</div>
|
<div class="tabs">
|
<div class="tab" :class="{ active: activeTab12 == 0 }" @click="tabClick12(0)">今日</div>
|
<div class="separate"></div>
|
<div class="tab" :class="{ active: activeTab12 == 1 }" @click="tabClick12(1)">本月</div>
|
</div>
|
<img src="@/assets/images/title@2x.png" class="bg" alt="" />
|
</div>
|
<div class="static_wrap">
|
<div class="item">
|
<img src="@/assets/images/energy_ef/ic_chukuxiaolv@2x.png" alt="">
|
<div class="content">
|
<div class="name">出库效率</div>
|
<div class="num"><span>{{ activeTab12 == 0 ? data1.todayOutRate : data1.monthOutRate }}</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">{{ activeTab12 == 0 ? data1.todayInRate : data1.monthInRate
|
}}</span>万支/小时</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="right_box_two">
|
<div class="com_header">
|
<div class="title">
|
<img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
|
<div>今日入库量统计</div>
|
</div>
|
<img src="@/assets/images/title@2x.png" class="bg" alt="" />
|
</div>
|
<div class="content">
|
<div class="echart_wrap">
|
<div class="pie_text">
|
<div class="fs30"><strong>{{ data5 }}</strong></div>
|
<div>入库数量</div>
|
</div>
|
<div class="echart" id="echart1"></div>
|
</div>
|
<div class="list">
|
<div class="item" v-for="item, i in dataList5">
|
<div class="line">
|
<div :style="{ background: colors[i] }" class="icon"></div>
|
<div class="text">{{ item.name }}</div>
|
</div>
|
<div :style="{ color: colors[i] }" class="num">{{ item.value }}万支 | {{ item.rate }}%</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="right_box_three">
|
<div class="com_header">
|
<div class="title">
|
<img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
|
<div>库存情况</div>
|
</div>
|
<img src="@/assets/images/title@2x.png" class="bg" alt="" />
|
</div>
|
<div class="repertory">
|
<div class="use_ratio">
|
<div class="header">
|
<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 v-if="data1.stockTotal && data1.stockMax"
|
:rate="((data1.stockTotal / data1.stockMax) * 100).toFixed(0)" />
|
</div>
|
<div class="list two-swiper">
|
<div class="swiper-wrapper">
|
<div class="item two-swiper-slide swiper-slide" v-for="item in dataList6">
|
<div class="la">{{ item.name }}</div>
|
<div class="val">{{ item.num }}万支</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<!-- -->
|
<div class="modal" v-if="activeCar && activeCar.phone">
|
<div class="title_head">
|
<img src="@/assets/images/energy_ef/chuku_ic_car@2x.png" alt="">
|
<span>皖a222</span>
|
</div>
|
<div class="info">
|
<div class="item">
|
<div class="dian"></div>
|
<div class="la">运输单号:</div>
|
<div class="val">22</div>
|
</div>
|
<div class="item">
|
<div class="dian"></div>
|
<div class="la">司机信息:</div>
|
<div class="val">22</div>
|
</div>
|
<div class="item">
|
<div class="dian"></div>
|
<div class="la">总运输量:</div>
|
<div class="val">22 万支</div>
|
</div>
|
</div>
|
<div class="tabs">
|
<div :class="{ active: modalTab == 0 }" @click="modalTabClick(0)" class="tab">作业信息</div>
|
<div :class="{ active: modalTab == 1 }" @click="modalTabClick(1)" class="tab">合同列表</div>
|
</div>
|
<div class="tab1" v-if="modalTab == 0">
|
<div class="item" v-for="item, i in 3">
|
<div class="icon_wrap">
|
<img v-if="i === 0" class="dian" src="@/assets/images/ic_dangqian@2x.png" alt="">
|
<img v-else src="@/assets/images/ic_jindu@2x.png" class="dian_ac" alt="">
|
<div class="line"></div>
|
</div>
|
<div class="content">
|
<div class="status">作业中</div>
|
<div class="text">作业任务在【入库去1号月台】开始作业</div>
|
<div class="time">2024-04-02 12:00</div>
|
</div>
|
</div>
|
</div>
|
<div class="tab2" v-if="modalTab == 1">
|
<div class="list">
|
<div class="item">
|
<div class="head">
|
<div class="code">合同号:12312312</div>
|
<div class="addr">收货地:江门烟草物流中心</div>
|
</div>
|
<div class="line" v-for="i in 3">
|
<div class="name">物料名称:<span class="val">黄山</span></div>
|
<div class="num">数量:<span class="val">100万支</span></div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="modal_mask" v-if="activeCar && activeCar.phone" @click="activeCar = {}"></div>
|
</div>
|
</v-scale-screen>
|
</template>
|
|
<script setup>
|
import { ref, onMounted } from 'vue'
|
import VScaleScreen from 'v-scale-screen'
|
import Percent from '@/components/percent.vue'
|
import dayjs from 'dayjs'
|
import * as echarts from 'echarts'
|
import ahJSON from '@/assets/anhui.json'
|
import icKongxian from '@/assets/images/LogisticsCenter/map_car_kongxian@2x.png'
|
import icLixian from '@/assets/images/LogisticsCenter/map_car_lixian@2x.png'
|
import icZaitu from '@/assets/images/LogisticsCenter/map_car_zaitu@2x.png'
|
import {
|
wlcenterData,
|
wljobData,
|
wlplatformJobList,
|
wlstockList,
|
wltotalInList,
|
wltransportMeasure,
|
carsListPost,
|
getCarsJobDetails
|
} from '@/api'
|
import 'swiper/css/swiper.min.css'
|
import Swiper from 'swiper'
|
|
const colors = ['#FEAF01', '#01ABFE', '#51F9E4']
|
const weekMap = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六',]
|
const date = ref(dayjs().format('YYYY.MM.DD'))
|
const week = ref(weekMap[new Date().getDay()])
|
const time = ref(dayjs().format('HH:mm:ss'))
|
setInterval(() => {
|
date.value = dayjs().format('YYYY-MM-DD')
|
week.value = weekMap[new Date().getDay()]
|
time.value = dayjs().format('HH:mm:ss')
|
|
}, 1000)
|
|
|
const initEnergy = () => {
|
var myChart = echarts.init(document.querySelector('.energyRef'))
|
// 绘制图表
|
myChart.setOption({
|
legend: {
|
itemGap: 12,
|
// icon: 'circle',
|
right: '12px',
|
top: '10px',
|
data: ['计划任务量', '任务完成量', '计划任务数'],
|
itemWidth: 12,
|
itemHeight: 4,
|
textStyle: {
|
color: '#fff',
|
borderColor: '#fff'
|
},
|
},
|
grid: {
|
left: '3%',
|
right: '4%',
|
bottom: '3%',
|
top: '26%',
|
containLabel: true
|
},
|
tooltip: {
|
trigger: 'axis'
|
},
|
xAxis: [
|
{
|
nameGap: 5,
|
type: 'category',
|
axisLine: {
|
show: true,
|
lineStyle: {
|
color: '#999'
|
},
|
},
|
axisLabel: {
|
color: '#869CC9'
|
// fontSize: 24,
|
},
|
axisTick: {
|
show: false,
|
},
|
data: dataList2.value.map(i => i.planDateStrT),
|
}
|
],
|
yAxis: [
|
{
|
type: 'value',
|
name: '个',
|
min: 0,
|
axisLabel: {
|
show: true,
|
color: "#869CC9",
|
},
|
splitLine: {
|
show: true,
|
lineStyle: {
|
width: 1,
|
color: "rgba(49,105,129,0.4)",
|
type: 'dashed'
|
}
|
},
|
// interval: 5,
|
axisLabel: {
|
formatter: '{value}'
|
}
|
},
|
{
|
type: 'value',
|
name: '万支',
|
nameTextStyle: {
|
color: '#869CC9',
|
},
|
offset: 0,
|
type: 'value',
|
axisLine: {
|
show: true,
|
},
|
splitLine: {
|
show: true,
|
lineStyle: {
|
width: 1,
|
color: "rgba(49,105,129,0.4)",
|
type: 'dashed'
|
}
|
},
|
axisLabel: {
|
formatter: '{value}'
|
}
|
},
|
],
|
series: [
|
{
|
name: '计划任务量',
|
type: 'bar',
|
barWidth: 10,
|
barGap: '60%',
|
label: {
|
show: false,
|
position: 'top',
|
color: '#fff',
|
},
|
yAxisIndex: 1,
|
itemStyle: {
|
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
|
{
|
offset: 0,
|
color: '#5bc7d5'
|
},
|
{
|
offset: 1,
|
color: '#1a3f55'
|
}
|
], false),
|
lineStyle: {
|
width: 1,
|
type: 'solid'
|
},
|
barBorderRadius: [3, 3, 0, 0],
|
},
|
data: dataList2.value.map(i => i.planTaskNum)
|
},
|
{
|
name: '任务完成量',
|
type: 'bar',
|
barWidth: 10,
|
yAxisIndex: 1,
|
label: {
|
show: false,
|
position: 'top',
|
color: '#fff',
|
},
|
itemStyle: {
|
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
|
{
|
offset: 0,
|
color: '#edaf3d'
|
},
|
{
|
offset: 1,
|
color: '#323522'
|
}
|
], false),
|
lineStyle: {
|
width: 1,
|
type: 'solid'
|
},
|
barBorderRadius: [3, 3, 0, 0],
|
},
|
data: dataList2.value.map(i => i.finishTaskNum)
|
},
|
{
|
name: '计划任务数',
|
type: 'line',
|
smooth: false,
|
showAllSymbol: true,
|
yAxisIndex: 0,
|
symbol: 'none',
|
lineStyle: {
|
color: "#1a43bc"
|
},
|
label: {
|
show: false,
|
position: 'top',
|
color: '#fff',
|
},
|
data: dataList2.value.map(i => i.planTimes)
|
}
|
]
|
})
|
|
window.addEventListener('resize', function () {//执行
|
myChart.resize()
|
})
|
}
|
const initEchart1 = () => {
|
const myChart = echarts.init(document.getElementById('echart1'))
|
const option = {
|
series: [
|
{
|
type: 'pie',
|
radius: ['86%', '100%'],
|
label: {
|
show: false,
|
position: 'center'
|
},
|
padAngle: 5,
|
itemStyle: {
|
borderRadius: 10
|
},
|
color: colors,
|
labelLine: {
|
show: false
|
},
|
data: dataList5.value
|
}
|
]
|
}
|
myChart.setOption(option)
|
window.addEventListener('resize', function () { // 执行
|
myChart.resize()
|
})
|
}
|
|
const echartMap = ref()
|
const initMap = () => {
|
var myChart = echarts.init(echartMap.value)
|
echarts.registerMap('js', ahJSON)
|
const scatterData = data7.value.carsList.map(item => {
|
return {
|
name: item.terminalId,
|
img: item.status == 0 ? icLixian : item.status == 1 || item.status == 2 ? icZaitu : icKongxian,
|
data: [{ code: item.plateNum, value: [item.longitude, item.latitude] }]
|
}
|
})
|
// var scatterData = [
|
// {
|
// name: '幼儿园',
|
// num: 15,
|
// // color: ['#1984ff', '#184b8d'],
|
// img: icKongxian,
|
// data: [
|
// { name: 'asdasdas ', value: [117.25, 31.49] },
|
// ],
|
// },
|
// ]
|
let serData = []
|
scatterData.forEach((item) => {
|
serData.push({
|
name: `${item.name}`,
|
type: 'effectScatter',
|
coordinateSystem: 'geo',
|
effectType: 'ripple',
|
showEffectOn: 'render',
|
// 散点样式
|
rippleEffect: {
|
period: 1,
|
scale: 1,
|
brushType: 'fill'
|
},
|
// 散点大小 自定义散点图片
|
// symbol: `image://${item.img}`,
|
symbol: `image://${item.img}`,
|
label: {
|
show: true,
|
formatter: '{b|{b}}',
|
position: 'top',
|
distance: -1,
|
rich: {
|
b: {
|
color: "#fff",
|
fontSize: 14,
|
height: 30,
|
// width: 200,
|
padding: 5,
|
},
|
}
|
},
|
symbolSize: [32, 40],
|
hoverAnimation: true,
|
zlevel: 99,
|
data: item.data,
|
})
|
}
|
)
|
var data = [
|
{ name: "合肥市", value: 3 },
|
{ name: "滁州市", value: 0 },
|
{ name: "芜湖市", value: 1 },
|
{ name: "阜阳市", value: 0 },
|
{ name: "蚌埠市", value: 4 },
|
{ name: "淮南市", value: 0 },
|
{ name: "马鞍山市", value: 6 },
|
{ name: "安庆市", value: 2 },
|
{ name: "黄山市", value: 0 },
|
{ name: "铜陵市", value: 40 },
|
{ name: "宿州市", value: 0 },
|
{ name: "淮北市", value: 0 },
|
{ name: "六安市", value: 0 },
|
{ name: "池州市", value: 1 },
|
{ name: "宣城市", value: 0 },
|
{ name: "亳州市", value: 0 },
|
]
|
const option = {
|
title: {
|
top: 20,
|
text: '',
|
subtext: '',
|
x: 'center',
|
textStyle: {
|
color: '#ffffff'
|
}
|
},
|
visualMap: {
|
show: false,
|
max: 100,
|
seriesIndex: [3],
|
inRange: {
|
color: ['#A5DCF4', '#006edd']
|
}
|
},
|
geo: [{
|
map: 'js',
|
roam: false, //是否允许缩放
|
zoom: 1.2, //默认显示级别
|
scaleLimit: {
|
min: 0,
|
max: 3
|
}, //缩放级别
|
itemStyle: {
|
normal: {
|
areaColor: 'transparent',
|
borderColor: '#3fdaff',
|
borderWidth: 2,
|
shadowColor: 'rgba(63, 218, 255, 0.5)',
|
shadowBlur: 30
|
},
|
emphasis: {
|
areaColor: '#2B91B7',
|
}
|
},
|
tooltip: {
|
show: false
|
}
|
}],
|
series: [
|
{
|
type: 'effectScatter',
|
coordinateSystem: 'geo',
|
z: 5,
|
data,
|
symbolSize: 14,
|
label: {
|
normal: {
|
show: false,
|
formatter: function (params) {
|
return '{fline|地点:' + params.data.city + '}\n{tline|' + (params.data.info || '发生xx集件') + '}'
|
},
|
position: 'top',
|
backgroundColor: 'rgba(233,63,66,.9)',
|
padding: [0, 0],
|
borderRadius: 3,
|
lineHeight: 32,
|
color: '#ffffff',
|
rich: {
|
fline: {
|
padding: [0, 10, 10, 10],
|
color: '#ffffff'
|
},
|
tline: {
|
padding: [10, 10, 0, 10],
|
color: '#ffffff'
|
}
|
}
|
},
|
emphasis: {
|
show: true
|
}
|
},
|
itemStyle: {
|
color: '#e93f42',
|
}
|
},
|
|
//地图
|
{
|
type: 'map',
|
mapType: 'js',
|
geoIndex: -1,
|
zoom: 1.2, //默认显示级别
|
label: {
|
show: true,
|
color: '#ffffff',
|
|
},
|
itemStyle: {
|
normal: {
|
borderColor: '#428598',
|
borderWidth: 1,
|
areaColor: '#1d3b60'
|
},
|
emphasis: {
|
disabled: true,
|
// areaColor: '#FA8C16',
|
// borderWidth: 1,
|
// color: '#428598',
|
label: {
|
show: true, // 始终显示文字
|
color: '#fff' // 设置文字颜色
|
},
|
areaColor: null
|
}
|
},
|
data: data
|
},
|
...serData,
|
]
|
}
|
|
myChart.setOption(option)
|
myChart.on('click', function (params) {
|
const item = params.data
|
getCarsJobDetails({ carCode: item.code }).then(res => {
|
activeCar.value = res.data
|
})
|
})
|
window.addEventListener('resize', function () {//执行
|
myChart.resize()
|
})
|
}
|
const activeCar = ref({})
|
const modalTab = ref(0)
|
const modalTabClick = (val) => {
|
modalTab.value = val
|
}
|
|
|
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.data
|
data1.value = result
|
})
|
}
|
|
const dataList2 = ref([])
|
const activeTab2 = ref(0)
|
const tabClick2 = (val) => {
|
activeTab2.value = val
|
getData2()
|
}
|
const getData2 = () => {
|
wltransportMeasure({ queryType: activeTab2.value }).then(res => {
|
const result = res.data || []
|
dataList2.value = result
|
dataList2.value.forEach(item => {
|
item.planDateStrT = activeTab2.value == 2 ? dayjs(item.planDate).format('M') : dayjs(item.planDate).format('M.D')
|
})
|
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 = () => {
|
wlplatformJobList().then(res => {
|
const result = res.data
|
dataList3.value = result
|
})
|
}
|
const data4 = ref({})
|
const activeTab4 = ref(0)
|
const tabClick4 = (val) => {
|
activeTab4.value = val
|
getData4()
|
}
|
const getData4 = () => {
|
wljobData({ queryType: activeTab4.value }).then(res => {
|
const result = res.data
|
data4.value = result
|
})
|
}
|
const dataList5 = ref([])
|
const data5 = ref(0)
|
const getData5 = () => {
|
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 = count == 0 ? 0 : ((i.num / count) * 100).toFixed(0)
|
})
|
data5.value = count
|
initEchart1()
|
})
|
}
|
const dataList6 = ref([])
|
const getData6 = () => {
|
wlstockList().then(res => {
|
const result = res.data.stockList || []
|
dataList6.value = result
|
})
|
}
|
|
const isShowCarW = ref(false)
|
const data7 = ref({})
|
const getData7 = () => {
|
carsListPost().then(res => {
|
const result = res.data || {}
|
data7.value = result
|
initMap()
|
})
|
}
|
|
const autoplayFlag = (list = [], leng = 4, time = 2000) => {
|
if (list.length > leng) {
|
return { delay: time, disableOnInteraction: false }
|
} else {
|
return false
|
}
|
}
|
const loopFn1 = () => {
|
var newSwiper1 = new Swiper('.one-swiper', {
|
initialSlide: 0,
|
direction: 'vertical', //竖直方向
|
slidesPerView: 7,
|
autoplay: autoplayFlag(dataList3.value, 7, 2000),
|
observer: true, //修改swiper自己或子元素时,自动初始化swiperiper
|
})
|
}
|
const loopFn2 = () => {
|
var newSwiper1 = new Swiper('.two-swiper', {
|
initialSlide: 0,
|
direction: 'vertical', //竖直方向
|
slidesPerView: 7,
|
autoplay: autoplayFlag(dataList6.value, 7, 2000),
|
observer: true, //修改swiper自己或子元素时,自动初始化swiperiper
|
})
|
}
|
onMounted(() => {
|
getData1()
|
getData2()
|
getData3()
|
getData4()
|
getData5()
|
getData6()
|
getData7()
|
|
setTimeout(() => {
|
loopFn1()
|
loopFn2()
|
}, 12000)
|
})
|
|
|
</script>
|
|
<style lang="scss" scoped>
|
div {
|
box-sizing: border-box;
|
}
|
|
.swiper-wrapper {
|
display: block !important;
|
}
|
|
.main_content {
|
display: flex;
|
padding: 20px 25px 0;
|
|
.left_box {
|
width: 440px;
|
|
.left_box_one {
|
width: 100%;
|
position: relative;
|
margin-bottom: 20px;
|
|
.content_wrap {
|
height: 164px;
|
padding: 22px 20px 0;
|
|
.content {
|
display: flex;
|
align-items: flex-end;
|
margin: 10px 0 22px;
|
|
.num {
|
margin-right: 10px;
|
font-weight: bold;
|
font-size: 46px;
|
height: 44px;
|
line-height: 52px;
|
font-weight: bold;
|
color: #00F2F3;
|
letter-spacing: 3px;
|
background-image: -webkit-linear-gradient(top,
|
#01D9FE 0%,
|
#0177FE 60%,
|
#0177FE 100%);
|
-webkit-background-clip: text;
|
-webkit-text-fill-color: transparent;
|
}
|
|
.unit_wrap {
|
display: flex;
|
align-items: center;
|
}
|
|
.icon {
|
width: 10px;
|
height: 12px;
|
margin-right: 6px;
|
margin-left: 4px;
|
}
|
}
|
|
.train_wrap {
|
display: flex;
|
height: 40px;
|
margin-top: 18px;
|
|
.icon_wrap {
|
width: 40px;
|
height: 40px;
|
display: flex;
|
justify-content: center;
|
align-items: center;
|
margin-right: 4px;
|
border: 1px solid;
|
background: linear-gradient(180deg, rgba(0, 148, 235, 0.68) 0%, rgba(0, 148, 235, 0) 100%);
|
border-image: linear-gradient(180deg, rgba(177, 210, 255, 0.64), rgba(0, 171, 255, 0.7)) 1 1;
|
|
img {
|
width: 26px;
|
}
|
}
|
|
.total {
|
flex: 1;
|
display: flex;
|
align-items: center;
|
justify-content: space-between;
|
padding: 0 20px;
|
font-size: 16px;
|
border: 1px solid;
|
border-image: linear-gradient(180deg, rgba(177, 210, 255, 0.64), rgba(0, 171, 255, 0.7)) 1 1;
|
background: linear-gradient(180deg, rgba(0, 148, 235, 0.68) 0%, rgba(0, 148, 235, 0) 100%);
|
|
.unit {
|
margin-left: 5px;
|
font-size: 13px;
|
}
|
}
|
}
|
}
|
}
|
|
.left_box_two {
|
margin-bottom: 20px;
|
|
.energy_wrap {
|
width: 100%;
|
height: 250px;
|
|
.energyRef {
|
width: 100%;
|
height: 100%;
|
}
|
}
|
}
|
|
.left_box_three {
|
.list_wrap {
|
padding: 10px 0;
|
|
.list_temp {
|
height: 210px !important;
|
overflow: hidden;
|
}
|
|
.list {
|
.line {
|
display: flex;
|
height: 30px !important;
|
align-items: center;
|
padding: 0 10px;
|
font-size: 12px;
|
|
&:nth-of-type(2n) {
|
background: rgba(27, 64, 97, 0.52);
|
}
|
|
.item {
|
flex: 5;
|
white-space: nowrap;
|
overflow: hidden;
|
text-overflow: ellipsis;
|
}
|
|
.flag {
|
flex: 3;
|
display: flex;
|
|
span {
|
width: 22px;
|
height: 22px;
|
display: flex;
|
justify-content: center;
|
align-items: center;
|
border-radius: 50%;
|
background: #00F2F3;
|
font-weight: 500;
|
color: #001B3C;
|
}
|
|
.flag_bg {
|
background: #4eacf6;
|
}
|
}
|
|
.status {
|
color: #FEAF01;
|
}
|
|
.addr {
|
flex: 8;
|
|
}
|
|
.time {
|
flex: 6;
|
margin-left: 6px;
|
}
|
}
|
}
|
}
|
}
|
}
|
|
.center_box {
|
flex: 1;
|
padding: 16px 60px;
|
display: flex;
|
flex-direction: column;
|
|
.center_box_one {
|
height: 190px;
|
|
.tabs {
|
display: flex;
|
align-items: center;
|
|
.tab {
|
display: flex;
|
align-items: center;
|
margin-right: 30px;
|
cursor: pointer;
|
|
img {
|
width: 20px;
|
height: 20px;
|
margin-right: 8px;
|
}
|
|
font-size: 20px;
|
font-weight: 600;
|
color: #D2E0FF;
|
}
|
|
.active {
|
background-image: -webkit-linear-gradient(top,
|
#fff 0%,
|
#eec05f 60%,
|
#eec05f 100%);
|
-webkit-background-clip: text;
|
-webkit-text-fill-color: transparent;
|
}
|
}
|
|
.static_wrap {
|
display: flex;
|
align-items: center;
|
margin: 30px 0 54px;
|
|
.item {
|
display: flex;
|
justify-content: center;
|
flex: 1;
|
|
img {
|
width: 68px;
|
height: 71px;
|
margin-right: 15px;
|
}
|
|
.content {
|
font-size: 15px;
|
|
.num {
|
font-size: 12px;
|
color: #D2E0FF;
|
|
span {
|
font-weight: bold;
|
font-size: 30px;
|
margin-right: 5px;
|
font-weight: 600;
|
background-image: -webkit-linear-gradient(top,
|
#01D9FE 0%,
|
#01D9FE 60%,
|
#fff 100%);
|
-webkit-background-clip: text;
|
-webkit-text-fill-color: transparent;
|
}
|
|
.today {
|
background-image: -webkit-linear-gradient(top,
|
#fff 0%,
|
#20FFC5 50%,
|
#20FFC5 100%);
|
}
|
|
.finish {
|
background-image: -webkit-linear-gradient(top,
|
#fff 0%,
|
#FFB120 50%,
|
#FFB120 100%);
|
}
|
}
|
}
|
}
|
}
|
}
|
|
.center_box_two {
|
flex: 1;
|
width: 100%;
|
position: relative;
|
|
.list {
|
position: absolute;
|
top: 10px;
|
left: 20px;
|
|
.item {
|
display: flex;
|
align-items: center;
|
font-weight: 500;
|
font-size: 20px;
|
margin-bottom: 18px;
|
|
img {
|
width: 36px;
|
height: 36px;
|
margin-right: 15px;
|
}
|
}
|
}
|
|
.echart_wrap {
|
width: 86%;
|
height: 100%;
|
|
.echart_map {
|
width: 100%;
|
height: 100%;
|
/* transform: rotate(60deg); */
|
}
|
}
|
|
.warnning_info {
|
position: absolute;
|
right: 0;
|
bottom: 0;
|
border-top: 1px solid #5ecbce;
|
border-bottom: 1px solid #5ecbce;
|
|
.head {
|
display: flex;
|
width: 280px;
|
height: 57px;
|
background: rgba(0, 30, 63, 0.4);
|
backdrop-filter: blur(5px);
|
display: flex;
|
align-items: center;
|
padding-left: 10px;
|
font-weight: bold;
|
font-size: 16px;
|
cursor: pointer;
|
|
img {
|
width: 14px;
|
margin-right: 10px;
|
}
|
}
|
|
.war_list {
|
max-height: 300px;
|
overflow: auto;
|
|
.line {
|
font-size: 13px;
|
color: #D2E0FF;
|
display: flex;
|
align-items: center;
|
height: 30px;
|
|
div {
|
flex: 3;
|
}
|
|
.id_card {
|
color: #00F2F3;
|
}
|
|
.title {
|
flex: 4;
|
}
|
}
|
}
|
}
|
}
|
}
|
|
.right_box {
|
width: 440px;
|
|
.right_box_one {
|
margin-bottom: 20px;
|
|
.static_wrap {
|
display: flex;
|
justify-content: space-evenly;
|
align-items: center;
|
height: 140px;
|
|
.item {
|
display: flex;
|
align-items: center;
|
|
img {
|
width: 80px;
|
height: 80px;
|
margin-right: 5px;
|
}
|
|
.content {
|
font-size: 14px;
|
|
.num {
|
font-size: 12px;
|
color: #D2E0FF;
|
margin-top: 8px;
|
|
span {
|
font-weight: bold;
|
font-size: 24px;
|
margin-right: 4px;
|
font-weight: 600;
|
background-image: -webkit-linear-gradient(top,
|
#01D9FE 0%,
|
#01D9FE 60%,
|
#fff 100%);
|
-webkit-background-clip: text;
|
-webkit-text-fill-color: transparent;
|
}
|
|
.today {
|
background-image: -webkit-linear-gradient(top,
|
#fff 0%,
|
#20FFC5 50%,
|
#20FFC5 100%);
|
}
|
|
.finish {
|
background-image: -webkit-linear-gradient(top,
|
#fff 0%,
|
#FFB120 50%,
|
#FFB120 100%);
|
}
|
}
|
}
|
}
|
}
|
}
|
|
.right_box_two {
|
.content {
|
display: flex;
|
justify-content: center;
|
align-items: center;
|
height: 200px;
|
|
.echart_wrap {
|
position: relative;
|
|
.pie_text {
|
width: 104px;
|
height: 104px;
|
border: 1px dashed;
|
border-radius: 50%;
|
position: absolute;
|
|
left: 50%;
|
top: 50%;
|
transform: translate(-50%, -50%);
|
z-index: 999;
|
display: flex;
|
flex-direction: column;
|
justify-content: center;
|
align-items: center;
|
font-size: 14px;
|
|
.fs30 {
|
font-size: 30px;
|
}
|
}
|
}
|
|
.echart {
|
width: 140px;
|
height: 140px;
|
}
|
|
.list {
|
margin-left: 36px;
|
|
.item {
|
margin-bottom: 14px;
|
font-size: 14px;
|
|
&:nth-last-child(1) {
|
margin: 0;
|
}
|
|
.line {
|
display: flex;
|
align-items: center;
|
margin-bottom: 6px;
|
|
.icon {
|
width: 12px;
|
height: 12px;
|
border-radius: 50%;
|
margin-right: 10px;
|
background: linear-gradient(270deg, #29aeff 0%, #207ff7 100%);
|
}
|
}
|
|
.num {
|
margin-left: 20px;
|
}
|
}
|
}
|
}
|
}
|
|
.right_box_three {
|
.repertory {
|
.header {
|
padding: 15px;
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
font-size: 14px;
|
color: #D2E0FF;
|
margin-bottom: 11px;
|
|
.num {
|
font-weight: 500;
|
font-size: 16px;
|
color: #FFFFFF;
|
}
|
}
|
|
.list {
|
margin-top: 22px;
|
height: 240px;
|
overflow: hidden;
|
scrollbar-width: none;
|
|
.item {
|
width: 100%;
|
height: 36px !important;
|
display: flex;
|
align-items: center;
|
|
&:nth-of-type(2n+1) {
|
background: rgba(0, 152, 255, 0.13);
|
}
|
|
.la {
|
flex: 5;
|
padding-left: 20px;
|
}
|
|
.val {
|
flex: 2;
|
}
|
}
|
}
|
}
|
}
|
}
|
}
|
|
.main_header {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
height: 90px;
|
position: relative;
|
padding: 0px 40px 16px;
|
font-weight: 600;
|
font-size: 36px;
|
|
.title {
|
background-image: -webkit-linear-gradient(top,
|
#ffffff 0%,
|
#c8ddff 70%,
|
#85b4ff 80%,
|
#74a9ff 100%);
|
-webkit-background-clip: text;
|
-webkit-text-fill-color: transparent;
|
}
|
|
.time_wrap {
|
font-size: 26px;
|
font-weight: 600;
|
background-image: -webkit-linear-gradient(top,
|
#ffffff 0%,
|
#c8ddff 50%,
|
#85b4ff 80%,
|
#74a9ff 100%);
|
-webkit-background-clip: text;
|
-webkit-text-fill-color: transparent;
|
display: flex;
|
align-items: center;
|
|
.time {
|
width: 130px;
|
display: flex;
|
justify-content: flex-end;
|
font-size: 30px;
|
}
|
|
.week {
|
margin-left: 20px;
|
}
|
}
|
|
.main_header_bg {
|
position: absolute;
|
left: 0;
|
top: 0;
|
width: 100%;
|
height: 100%;
|
object-fit: cover;
|
z-index: -1;
|
}
|
}
|
|
.com_header {
|
height: 40px;
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
padding: 0 15px 0 13px;
|
position: relative;
|
|
.title {
|
display: flex;
|
align-items: center;
|
font-weight: bold;
|
font-size: 16px;
|
background-image: -webkit-linear-gradient(top,
|
#ffffff 0%,
|
#c8ddff 66%,
|
#85b4ff 72%,
|
#74a9ff 100%);
|
-webkit-background-clip: text;
|
-webkit-text-fill-color: transparent;
|
|
.icon {
|
width: 16px;
|
height: 16px;
|
margin-right: 14px;
|
}
|
}
|
|
.tabs {
|
display: flex;
|
align-items: center;
|
font-size: 14px;
|
color: #d2e0ff;
|
|
.separate {
|
width: 1px;
|
height: 14px;
|
background-color: #d2e0ff;
|
margin: 0 6px;
|
}
|
|
.tab {
|
cursor: pointer;
|
}
|
|
.active {
|
color: #0094eb;
|
}
|
}
|
}
|
|
.main_app {
|
width: 1920px;
|
height: 960px;
|
/* width: 100%;
|
height: 100vh; */
|
background: #0b2539;
|
color: #FFFFFF;
|
position: relative;
|
z-index: -2;
|
font-size: 14px;
|
|
.main_bg {
|
position: absolute;
|
left: 0;
|
top: 0;
|
width: 100%;
|
height: 100%;
|
object-fit: cover;
|
z-index: -1;
|
}
|
}
|
|
.modal {
|
width: 600px;
|
height: 556px;
|
background: rgba(0, 30, 63, 0.5);
|
backdrop-filter: blur(5px);
|
position: fixed;
|
top: 20%;
|
left: 50%;
|
transform: translate(-50%, 0);
|
z-index: 999;
|
padding: 24px;
|
|
.title_head {
|
display: flex;
|
align-items: center;
|
font-weight: bold;
|
font-size: 17px;
|
margin-bottom: 20px;
|
|
img {
|
width: 20px;
|
margin-right: 4px;
|
}
|
}
|
|
.info {
|
display: flex;
|
flex-wrap: wrap;
|
|
.item {
|
display: flex;
|
align-items: center;
|
font-size: 13px;
|
width: 55%;
|
margin-bottom: 8px;
|
|
&:nth-of-type(2n+1) {
|
width: 45%;
|
}
|
|
.dian {
|
width: 4px;
|
height: 4px;
|
background-color: #fff;
|
border-radius: 50%;
|
margin-right: 4px;
|
}
|
|
.la {
|
color: #01D9FE;
|
}
|
}
|
}
|
|
.tabs {
|
display: flex;
|
border-bottom: 1px solid rgba(255, 255, 255, 0.16);
|
margin: 0 -24px;
|
margin-bottom: 20px;
|
padding-left: 12px;
|
|
.tab {
|
color: #869CC9;
|
font-size: 14px;
|
margin-right: 12px;
|
width: 80px;
|
height: 42px;
|
display: flex;
|
align-items: center;
|
justify-content: center;
|
border-bottom: 2px solid #06182e;
|
cursor: pointer;
|
}
|
|
.active {
|
font-weight: 500;
|
font-size: 15px;
|
color: #00F2F3;
|
border-bottom: 2px solid #00F2F3;
|
}
|
}
|
|
.tab1 {
|
.item {
|
display: flex;
|
|
&:nth-last-child(1) {
|
.content {
|
.time {
|
padding-bottom: 0;
|
}
|
}
|
}
|
|
.icon_wrap {
|
width: 24px;
|
margin-right: 10px;
|
display: flex;
|
flex-direction: column;
|
align-items: center;
|
|
.dian {
|
width: 12px;
|
height: 12px;
|
}
|
|
.dian_ac {
|
width: 24px;
|
height: 24px;
|
}
|
|
.line {
|
width: 1px;
|
height: 100%;
|
border: 1px dashed #8a9bc5;
|
}
|
}
|
|
.content {
|
font-size: 13px;
|
color: #D2E0FF;
|
|
.status {
|
font-weight: 500;
|
font-size: 14px;
|
margin-bottom: 5px;
|
color: #fff;
|
}
|
|
.text {
|
margin-bottom: 4px;
|
}
|
|
.time {
|
font-size: 12px;
|
padding-bottom: 12px;
|
}
|
}
|
}
|
}
|
|
.tab2 {
|
.list {
|
.item {
|
width: 560px;
|
background: rgba(1, 171, 254, 0.1);
|
font-size: 12px;
|
color: #D2E0FF;
|
padding: 10px;
|
margin-bottom: 10px;
|
|
.head {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
height: 36px;
|
line-height: 36px;
|
border-bottom: 1px solid rgba(255, 255, 255, 0.16);
|
margin-bottom: 10px;
|
|
.code {
|
font-weight: 500;
|
font-size: 14px;
|
color: #00F2F3;
|
}
|
}
|
|
.line {
|
display: flex;
|
align-items: center;
|
margin-bottom: 8px;
|
|
&:nth-last-child(1) {
|
margin-bottom: 0;
|
}
|
|
.name {
|
flex: 4;
|
}
|
|
.num {
|
flex: 3;
|
}
|
|
.val {
|
color: #fff;
|
}
|
}
|
}
|
}
|
}
|
}
|
|
.modal_mask {
|
position: fixed;
|
width: 100%;
|
height: 100%;
|
top: 0;
|
left: 0;
|
z-index: 99;
|
background-color: rgba(0, 0, 0, 0.1);
|
/* background-color: red; */
|
}
|
|
.bg {
|
position: absolute;
|
left: 0;
|
top: 0;
|
width: 100%;
|
height: 100%;
|
object-fit: cover;
|
z-index: -1;
|
}
|
</style>
|