<template>
|
<v-scale-screen width="1920" height="960">
|
<div class="main_app">
|
<img src="@/assets/images/LogisticsCenter/bg@2x.png" class="main_bg" alt="" />
|
<div class="main_header">
|
<img src="@/assets/images/maintitle@2x.png" 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="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="left_box_one">
|
<div class="second_title">
|
<div class="title">
|
<img src="@/assets/images/LogisticsCenter/ic_title@2x.png" class="icon" alt="" />
|
<div>本年累计出库量</div>
|
</div>
|
</div>
|
<div class="content_wrap">
|
<div class="num_wrap">
|
<div class="num_list">
|
<div class="num" v-for="i in '200000'">
|
{{ i }}
|
<img class="bg" src="@/assets/images/LogisticsCenter/bg_number@2x.png" alt="">
|
</div>
|
</div>
|
<div class="content">
|
<div class="unit_wrap">
|
<span class="la">同比</span>
|
<img src="@/assets/images/ic_up.png" class="icon" alt="">
|
<span>10.2%</span>
|
<span class="la" style="margin-left: 30px;margin-right: 10px;">累计出库车次</span>
|
<span>3900</span>
|
</div>
|
|
</div>
|
</div>
|
<div class="echart_wrap">
|
<div class="echart1" id="echart1"></div>
|
<div class="list">
|
<div class="item" v-for="item, i in StockOutData" :key="i">
|
<div :style="{ background: colors[i] }" class="icon"></div>
|
<div class="text">{{ item.name }}</div>
|
<div class="num">{{ item.value }}</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="left_box_two">
|
<div class="second_title">
|
<div class="title">
|
<img src="@/assets/images/LogisticsCenter/ic_title@2x.png" class="icon" alt="" />
|
<div>近7日到货情况</div>
|
</div>
|
</div>
|
<div class="energy_wrap">
|
<div class="energyRef"></div>
|
</div>
|
</div>
|
<div class="left_box_three">
|
<div class="second_title">
|
<div class="title">
|
<img src="@/assets/images/LogisticsCenter/ic_title@2x.png" class="icon" alt="" />
|
<div>当前运输任务</div>
|
</div>
|
<div class="search_wrap">
|
<img src="@/assets/images/LogisticsCenter/ic_search@2x.png" alt="">
|
<span>订单查询</span>
|
</div>
|
</div>
|
<div class="list_wrap">
|
<div class="header line">
|
<span class="item">运输车辆</span>
|
<span class="item">状态</span>
|
<span class="item">位置</span>
|
<span class="item">任务下达时间</span>
|
</div>
|
<div class="line" v-for="i in 5">
|
<span class="item">皖A23bbb</span>
|
<span class="item">11</span>
|
<span class="item">11</span>
|
<span class="item">11</span>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div class="center_box">
|
<div class="center_box_one">
|
<div class="header_wrap">
|
<div class="left">
|
<img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
|
<span>出库能力</span>
|
</div>
|
<div class="right">
|
<img src="@/assets/images/LogisticsCenter/position.png" class="posi" alt="">
|
<span>全省</span>
|
<img src="@/assets/images/LogisticsCenter/bottom.png" class="icon" alt="">
|
</div>
|
</div>
|
<div class="static_wrap">
|
<div class="item">
|
<img src="@/assets/images/LogisticsCenter/ic_jinrijihua@2x.png" alt="">
|
<div class="content">
|
<div class="name">今日计划量</div>
|
<div class="num"><span>1000</span>万支</div>
|
<div class="unit">车次:10</div>
|
</div>
|
</div>
|
<div class="item">
|
<img src="@/assets/images/LogisticsCenter/ic_jinrichuku@2x.png" alt="">
|
<div class="content">
|
<div class="name">今日出库量</div>
|
<div class="num"><span class="today">1000</span>万支</div>
|
<div class="unit">车次:10</div>
|
</div>
|
</div>
|
<div class="item">
|
<img src="@/assets/images/LogisticsCenter/ic_jinriweichu@2x.png" alt="">
|
<div class="content">
|
<div class="name">今日未出库量</div>
|
<div class="num"><span class="finish">1000</span>万支</div>
|
<div class="unit">车次:10</div>
|
</div>
|
</div>
|
</div>
|
<div class="footer">
|
<span>占出库能力</span>
|
<span class="num">80%</span>
|
</div>
|
</div>
|
<div class="center_box_two"></div>
|
</div>
|
<div class="right_box">
|
<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="right_box_one">
|
<div class="second_title">
|
<div class="title">
|
<img src="@/assets/images/LogisticsCenter/ic_title@2x.png" class="icon" alt="" />
|
<div>本年累计入库量</div>
|
</div>
|
</div>
|
<div class="content_wrap">
|
<div class="num_wrap">
|
<div class="num_list">
|
<div class="num" v-for="i in '200000'">
|
{{ i }}
|
<img class="bg" src="@/assets/images/LogisticsCenter/bg_number@2x.png" alt="">
|
</div>
|
</div>
|
<div class="content">
|
<div class="unit_wrap">
|
<span class="la">同比</span>
|
<img src="@/assets/images/ic_up.png" class="icon" alt="">
|
<span>10.2%</span>
|
<span class="la" style="margin-left: 30px;margin-right: 10px;">累计出库车次</span>
|
<span>3900</span>
|
</div>
|
|
</div>
|
</div>
|
<div class="static_wrap">
|
<div class="echart_wrap">
|
<div class="echart3" id="echart3"></div>
|
<div class="pie_text">
|
<div class="fs30">30%</div>
|
</div>
|
</div>
|
<div class="text">计划完成量</div>
|
</div>
|
</div>
|
</div>
|
<div class="right_box_two">
|
<div class="second_title">
|
<div class="title">
|
<img src="@/assets/images/LogisticsCenter/ic_title@2x.png" class="icon" alt="" />
|
<div>进销存运营</div>
|
</div>
|
<div class="tabs">
|
<div class="tab active">7天</div>
|
<div class="separate"></div>
|
<div class="tab">30天</div>
|
<div class="separate"></div>
|
<div class="tab">1年</div>
|
</div>
|
</div>
|
<div class="echart4_wrap">
|
<div class="echart4" id="echart4"></div>
|
</div>
|
</div>
|
<div class="right_box_three">
|
<div class="second_title">
|
<div class="title">
|
<img src="@/assets/images/LogisticsCenter/ic_title@2x.png" class="icon" alt="" />
|
<div>库存利用率</div>
|
</div>
|
</div>
|
<div class="echart5_wrap">
|
<div class="echart5" id="echart5"></div>
|
</div>
|
</div>
|
</div>
|
</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'
|
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 colors = ['#0193FE', '#FFB642', '#5fc6d5']
|
const StockOutData = ref([])
|
const getStockOut = () => {
|
let arr = []
|
arr.push({ name: '访客', value: 20 })
|
arr.push({ name: '关方', value: 30 })
|
arr.sort((a, b) => b.value - a.value)
|
StockOutData.value = arr
|
initEchart1()
|
}
|
const initEchart1 = () => {
|
const myChart = echarts.init(document.getElementById('echart1'))
|
const option = {
|
tooltip: {
|
trigger: 'item'
|
},
|
series: [
|
{
|
type: 'pie',
|
radius: ['72%', '96%'],
|
label: {
|
show: false,
|
position: 'center'
|
},
|
color: colors,
|
labelLine: {
|
show: false
|
},
|
data: StockOutData.value
|
}
|
]
|
}
|
myChart.setOption(option)
|
window.addEventListener('resize', function () { // 执行
|
myChart.resize()
|
})
|
}
|
const initEchart3 = () => {
|
const myChart = echarts.init(document.getElementById('echart3'))
|
const option = {
|
tooltip: {
|
trigger: 'item'
|
},
|
series: [
|
{
|
type: 'pie',
|
radius: ['80%', '96%'],
|
label: {
|
show: false,
|
position: 'center'
|
},
|
color: ['#72ecc5', '#19373a'],
|
labelLine: {
|
show: false
|
},
|
data: StockOutData.value
|
}
|
]
|
}
|
myChart.setOption(option)
|
window.addEventListener('resize', function () { // 执行
|
myChart.resize()
|
})
|
}
|
const initEchart4 = () => {
|
// 基于准备好的dom,初始化echarts实例
|
const myChart = echarts.init(document.getElementById('echart4'))
|
// 绘制图表
|
myChart.setOption({
|
tooltip: {
|
trigger: 'axis',
|
axisPointer: {
|
type: 'line'
|
},
|
formatter: function (params) {
|
setTimeout(() => {
|
console.log('params', params)
|
})
|
return `
|
<div style="background-color: #091123;margin: -12px;padding: 14px;border: 2px solid rgba(1,217,254,0.5);color: #fff;">
|
<div>${params[0].name}总销售额(万元)</div>
|
<div style="display: flex;align-items: center;">
|
<div style="width: 10px;height: 10px;border-radius: 50%;background-color: #ebbf40;"></div>
|
<div style="margin: 0 4px 0 6px;">总销售</div>
|
<span style="color: #ebbf40;">${params[0].value}</span>
|
</div>
|
</div>
|
`
|
}
|
},
|
xAxis: {
|
type: 'category',
|
boundaryGap: false,
|
data: [1, 2, 3, 4, 5, 5]
|
},
|
yAxis: {
|
type: 'value',
|
name: '万支',
|
nameTextStyle: {
|
padding: [0, 0, 0, -16] // 四个数字分别为上右下左与原位置距离
|
},
|
splitLine: {
|
show: true,
|
lineStyle: {
|
//这里输入线条的样式
|
color: 'rgba(255,255,255,0.14)',
|
type: 'dashed',
|
},
|
splitNumber: 4
|
}
|
},
|
grid: {
|
top: '18%',
|
left: '0%',
|
right: '2%',
|
bottom: '2%',
|
containLabel: true
|
},
|
legend: {
|
data: ['总入库量', '总出库量']
|
},
|
series: [
|
{
|
name: '总入库量',
|
data: [10, 2, 30, 4, 4, 30].map(i => {
|
return {
|
name: i,
|
value: i,
|
}
|
}),
|
type: 'line',
|
areaStyle: {
|
normal: {
|
color: {
|
x: 0,
|
y: 0,
|
x2: 0,
|
y2: 1,
|
colorStops: [
|
{
|
offset: 0,
|
color: "#4191f6" // 0% 处的颜色
|
},
|
{
|
offset: .4,
|
color: "#203d79" // 0% 处的颜色
|
},
|
{
|
offset: 1,
|
color: "#1b1b12" // 100% 处的颜色
|
}],
|
globalCoord: false // 缺省为 false
|
}
|
}
|
},
|
lineStyle: { // 线条样式
|
color: {
|
type: 'linear',
|
x: 0,
|
y: 0,
|
x2: 0,
|
y2: 1,
|
colorStops: [{
|
offset: 0, color: '#4191f6' // 0% 处的颜色
|
}, {
|
offset: 1, color: '#4191f6' // 100% 处的颜色
|
}],
|
},
|
width: 1.5, // 线条粗细
|
},
|
symbol: 'circle',
|
symbolSize: 10,
|
itemStyle: {
|
normal: {
|
color: '#4191f6', //折线点的颜色
|
},
|
},
|
smooth: true
|
},
|
{
|
name: '总出库量',
|
data: [30, 2, 10, 4, 4, 20].map(i => {
|
return {
|
name: i,
|
value: i,
|
}
|
}),
|
type: 'line',
|
areaStyle: {
|
normal: {
|
color: {
|
x: 0,
|
y: 0,
|
x2: 0,
|
y2: 1,
|
colorStops: [{
|
offset: 0,
|
color: "rgba(192, 156, 53,.7)" // 0% 处的颜色
|
}, {
|
offset: 1,
|
color: "#1b1b12" // 100% 处的颜色
|
}],
|
globalCoord: false // 缺省为 false
|
}
|
}
|
},
|
lineStyle: { // 线条样式
|
color: {
|
type: 'linear',
|
x: 0,
|
y: 0,
|
x2: 0,
|
y2: 1,
|
colorStops: [{
|
offset: 0, color: '#F3BD00' // 0% 处的颜色
|
}, {
|
offset: 1, color: '#F3BD00' // 100% 处的颜色
|
}],
|
},
|
width: 2, // 线条粗细
|
},
|
symbol: 'circle',
|
symbolSize: 10,
|
itemStyle: {
|
normal: {
|
color: '#F3BD00', //折线点的颜色
|
},
|
},
|
smooth: true
|
}
|
]
|
})
|
|
window.addEventListener('resize', function () {//执行
|
myChart.resize()
|
})
|
}
|
const initEchart5 = () => {
|
// 基于准备好的dom,初始化echarts实例
|
const myChart = echarts.init(document.getElementById('echart5'))
|
// 绘制图表
|
myChart.setOption({
|
tooltip: {
|
trigger: 'axis',
|
axisPointer: {
|
type: 'cross',
|
crossStyle: {
|
color: '#999'
|
}
|
}
|
},
|
toolbox: {
|
feature: {
|
dataView: { show: true, readOnly: false },
|
magicType: { show: true, type: ['line', 'bar'] },
|
restore: { show: true },
|
saveAsImage: { show: true }
|
}
|
},
|
legend: {
|
data: ['Evaporation', 'Precipitation', 'Temperature']
|
},
|
xAxis: [
|
{
|
type: 'category',
|
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
|
axisPointer: {
|
type: 'shadow'
|
}
|
}
|
],
|
yAxis: [
|
{
|
type: 'value',
|
name: 'Precipitation',
|
min: 0,
|
max: 250,
|
interval: 50,
|
axisLabel: {
|
formatter: '{value} ml'
|
}
|
},
|
{
|
type: 'value',
|
name: 'Temperature',
|
min: 0,
|
max: 25,
|
interval: 5,
|
axisLabel: {
|
formatter: '{value} °C'
|
}
|
}
|
],
|
series: [
|
{
|
name: 'Evaporation',
|
type: 'bar',
|
tooltip: {
|
valueFormatter: function (value) {
|
return value + ' ml'
|
}
|
},
|
data: [
|
2.0, 4.9, 7.0, 23.2, 25.6, 76.7, 135.6, 162.2, 32.6, 20.0, 6.4, 3.3
|
]
|
},
|
{
|
name: 'Precipitation',
|
type: 'bar',
|
tooltip: {
|
valueFormatter: function (value) {
|
return value + ' ml'
|
}
|
},
|
data: [
|
2.6, 5.9, 9.0, 26.4, 28.7, 70.7, 175.6, 182.2, 48.7, 18.8, 6.0, 2.3
|
]
|
},
|
{
|
name: 'Temperature',
|
type: 'line',
|
yAxisIndex: 1,
|
tooltip: {
|
valueFormatter: function (value) {
|
return value + ' °C'
|
}
|
},
|
data: [2.0, 2.2, 3.3, 4.5, 6.3, 10.2, 20.3, 23.4, 23.0, 16.5, 12.0, 6.2]
|
}
|
]
|
})
|
|
window.addEventListener('resize', function () {//执行
|
myChart.resize()
|
})
|
}
|
|
const arr = ['#68e2e3', '#50afd3', '#377cdb', '#d5ae3a']
|
const initEnergy = () => {
|
var myChart = echarts.init(document.querySelector('.energyRef'))
|
// 绘制图表
|
const arr = ['#68e2e3', '#50afd3', '#377cdb', '#d5ae3a']
|
myChart.setOption({
|
grid: {
|
top: '20%',
|
left: '2%',
|
right: '2%',
|
bottom: '4%',
|
containLabel: true
|
},
|
tooltip: {
|
trigger: 'axis',
|
axisPointer: {
|
type: 'line'
|
},
|
},
|
xAxis: {
|
type: 'category',
|
data: [1, 2, 3, 4, 4, 5]
|
},
|
yAxis: {
|
type: 'value',
|
name: 'kw·h',
|
nameTextStyle: {
|
padding: [0, 0, 4, -30] // 四个数字分别为上右下左与原位置距离
|
},
|
splitLine: {
|
show: true,
|
lineStyle: {
|
//这里输入线条的样式
|
color: 'rgba(255,255,255,0.14)',
|
}
|
}
|
},
|
series: [
|
{
|
data: [1, 2, 3, 4, 5],
|
type: 'bar',
|
barWidth: 10,
|
itemStyle: {
|
normal: {
|
color: new echarts.graphic.LinearGradient(
|
0, 0, 0, 1,
|
[
|
{ offset: 0, color: arr[1] },
|
{ offset: 1, color: '#080807' }
|
]
|
),
|
barBorderRadius: [10, 10, 0, 0]
|
}
|
}
|
}
|
]
|
})
|
window.addEventListener('resize', function () {//执行
|
myChart.resize()
|
})
|
}
|
const initEchart2 = () => {
|
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: [
|
{ value: 1048, name: 'Search Engine' },
|
{ value: 735, name: 'Direct' },
|
{ value: 580, name: 'Email' }
|
]
|
}
|
]
|
}
|
myChart.setOption(option)
|
window.addEventListener('resize', function () { // 执行
|
myChart.resize()
|
})
|
}
|
|
onMounted(() => {
|
initEnergy()
|
getStockOut()
|
initEchart2()
|
initEchart3()
|
initEchart4()
|
initEchart5()
|
})
|
|
|
</script>
|
|
<style lang="scss" scoped>
|
div {
|
box-sizing: border-box;
|
}
|
|
.main_content {
|
display: flex;
|
padding: 20px 25px 0;
|
|
.left_box {
|
width: 440px;
|
|
.left_box_one {
|
margin-top: 20px;
|
padding: 0px 10px 30px 20px;
|
border: 1px solid;
|
|
.content_wrap {
|
display: flex;
|
justify-content: space-between;
|
|
.num_wrap {
|
width: 272px;
|
|
.num_list {
|
display: flex;
|
margin-bottom: 20px;
|
|
.num {
|
width: 30px;
|
height: 46px;
|
display: flex;
|
justify-content: center;
|
align-items: center;
|
position: relative;
|
font-weight: 600;
|
font-size: 32px;
|
margin-right: 5px;
|
}
|
}
|
|
.content {
|
display: flex;
|
color: #D2E0FF;
|
|
.la {
|
color: #869CC9;
|
}
|
|
.unit_wrap {
|
display: flex;
|
align-items: center;
|
}
|
|
.icon {
|
width: 10px;
|
height: 12px;
|
margin-right: 6px;
|
margin-left: 4px;
|
}
|
}
|
}
|
|
.echart_wrap {
|
flex: 1;
|
display: flex;
|
align-items: center;
|
height: 48px;
|
|
.echart1 {
|
width: 46px;
|
height: 46px;
|
margin-right: 8px;
|
}
|
|
.list {
|
flex: 1;
|
font-size: 13px;
|
|
.item {
|
display: flex;
|
align-items: center;
|
margin: 8px 0;
|
|
.icon {
|
width: 10px;
|
height: 10px;
|
border-radius: 50%;
|
margin-right: 4px;
|
background: linear-gradient(270deg, #29aeff 0%, #207ff7 100%);
|
}
|
|
.text {
|
margin-right: 6px;
|
}
|
}
|
}
|
}
|
}
|
}
|
|
.left_box_two {
|
margin-bottom: 20px;
|
border: 1px solid;
|
|
.energy_wrap {
|
width: 100%;
|
height: 250px;
|
|
.energyRef {
|
width: 100%;
|
height: 100%;
|
}
|
}
|
}
|
|
.left_box_three {
|
width: 440px;
|
padding: 0 15px;
|
border: 1px solid;
|
|
.second_title {
|
margin-bottom: 10px;
|
}
|
|
.list_wrap {
|
.line {
|
display: flex;
|
height: 40px;
|
align-items: center;
|
font-size: 14px;
|
color: #D2E0FF;
|
|
&:nth-of-type(2n) {
|
background: rgba(134, 156, 201, 0.05);
|
}
|
|
.item {
|
flex: 1;
|
white-space: nowrap;
|
overflow: hidden;
|
text-overflow: ellipsis;
|
}
|
}
|
|
.header {
|
font-weight: 500;
|
color: #01D9FE;
|
}
|
}
|
}
|
}
|
|
.center_box {
|
flex: 1;
|
padding: 0 20px;
|
margin: 0 40px;
|
|
.center_box_one {
|
background: rgba(255, 255, 255, 0.02);
|
height: 230px;
|
border-top: 2px solid #306ba1;
|
padding-top: 20px;
|
|
.header_wrap {
|
display: flex;
|
justify-content: space-between;
|
margin-bottom: 28px;
|
font-weight: bold;
|
font-size: 18px;
|
background-image: -webkit-linear-gradient(top,
|
#ffffff 0%,
|
#c8ddff 66%,
|
#85b4ff 72%,
|
#74a9ff 100%);
|
-webkit-background-clip: text;
|
-webkit-text-fill-color: transparent;
|
|
.left {
|
display: flex;
|
align-items: center;
|
|
img {
|
width: 16px;
|
margin-right: 6px;
|
}
|
}
|
|
.right {
|
display: flex;
|
align-items: center;
|
cursor: pointer;
|
|
.posi {
|
width: 16px;
|
margin-right: 8px;
|
}
|
|
.icon {
|
width: 14px;
|
margin-left: 2px;
|
}
|
}
|
}
|
|
.static_wrap {
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
margin: 30px 0 14px;
|
|
.item {
|
display: flex;
|
|
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%);
|
}
|
}
|
|
.unit {
|
font-size: 13px;
|
color: #D2E0FF;
|
margin-top: 2px;
|
}
|
}
|
}
|
}
|
|
.footer {
|
font-weight: 500;
|
font-size: 16px;
|
display: flex;
|
align-items: center;
|
|
.num {
|
font-weight: bold;
|
font-size: 24px;
|
color: #01D9FE;
|
margin-left: 8px;
|
}
|
}
|
}
|
|
.center_box_two {
|
width: 100%;
|
border: 1px solid;
|
}
|
}
|
|
.right_box {
|
width: 440px;
|
|
.right_box_one {
|
margin-top: 20px;
|
padding: 0px 10px 30px 20px;
|
border: 1px solid;
|
|
.content_wrap {
|
display: flex;
|
justify-content: space-between;
|
|
.num_wrap {
|
width: 280px;
|
|
.num_list {
|
display: flex;
|
margin-bottom: 20px;
|
|
.num {
|
width: 30px;
|
height: 46px;
|
display: flex;
|
justify-content: center;
|
align-items: center;
|
position: relative;
|
font-weight: 600;
|
font-size: 32px;
|
margin-right: 5px;
|
}
|
}
|
|
.content {
|
display: flex;
|
color: #D2E0FF;
|
|
.la {
|
color: #869CC9;
|
}
|
|
.unit_wrap {
|
display: flex;
|
align-items: center;
|
}
|
|
.icon {
|
width: 10px;
|
height: 12px;
|
margin-right: 6px;
|
margin-left: 4px;
|
}
|
}
|
}
|
|
.static_wrap {
|
flex: 1;
|
|
.echart_wrap {
|
width: 54px;
|
height: 54px;
|
position: relative;
|
margin-bottom: 12px;
|
|
.echart3 {
|
width: 54px;
|
height: 54px;
|
}
|
|
.pie_text {
|
width: 38px;
|
height: 38px;
|
border: 1px dashed rgba(210, 224, 255, 0.48);
|
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: 12px;
|
|
.fs30 {
|
font-weight: 600;
|
font-size: 14px;
|
color: #28F0C4;
|
}
|
}
|
|
}
|
|
.text {
|
font-size: 13px;
|
color: #869CC9;
|
}
|
}
|
}
|
}
|
|
.right_box_two {
|
border: 1px solid;
|
padding: 10px 15px;
|
|
.echart4_wrap {
|
width: 410px;
|
height: 216px;
|
|
.echart4 {
|
width: 410px;
|
height: 216px;
|
}
|
}
|
}
|
|
.right_box_three {
|
border: 1px solid;
|
|
.echart5_wrap {
|
height: 240px;
|
width: 410px;
|
|
.echart5 {
|
height: 240px;
|
width: 410px;
|
}
|
}
|
}
|
}
|
}
|
|
.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: 18px;
|
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;
|
}
|
|
.active {
|
color: #0094eb;
|
}
|
}
|
}
|
|
.second_title {
|
height: 24px;
|
display: flex;
|
justify-content: space-between;
|
align-items: center;
|
position: relative;
|
font-size: 16px;
|
margin-bottom: 20px;
|
|
.title {
|
display: flex;
|
align-items: center;
|
font-weight: 500;
|
font-size: 16px;
|
color: #FFFFFF;
|
|
.icon {
|
width: 16px;
|
height: 16px;
|
margin-right: 10px;
|
}
|
}
|
|
.num_wrap {
|
font-weight: 400;
|
font-size: 14px;
|
color: #D2E0FF;
|
display: flex;
|
align-items: center;
|
|
.val {
|
font-weight: bold;
|
font-size: 16px;
|
color: #FFFFFF;
|
}
|
}
|
|
.search_wrap {
|
display: flex;
|
justify-content: center;
|
align-items: center;
|
font-size: 14px;
|
color: #869CC9;
|
width: 96px;
|
height: 28px;
|
border-radius: 14px;
|
border: 1px solid #869CC9;
|
|
img {
|
width: 14px;
|
height: 14px;
|
margin-right: 3px;
|
}
|
}
|
|
.tabs {
|
display: flex;
|
align-items: center;
|
font-size: 14px;
|
color: #d2e0ff;
|
|
.separate {
|
width: 1px;
|
height: 14px;
|
background-color: #d2e0ff;
|
margin: 0 6px;
|
}
|
|
.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;
|
}
|
}
|
|
.bg {
|
position: absolute;
|
left: 0;
|
top: 0;
|
width: 100%;
|
height: 100%;
|
object-fit: cover;
|
z-index: -1;
|
}
|
</style>
|