Commit 093c4a1e authored by 张恒's avatar 张恒

调整容器组件UI

parent 480e1b1b
:root { :root {
--global-background-color: #020042; /* 全局背景色 */ --global-background-color: #020042; /* 全局背景色 */
--container-background-color: #020046; /* 容器背景色 */ --container-background-color: #020046; /* 容器背景色 */
--container-border-color: #0d53b7; /* 容器边框色 */
--container-shadow-color: #0930A9; /* 容器阴影色 */
--corner-background-color: #0E5FFF; /* 容器角标色 */
--card-background-color: #04175566; /* 卡片背景色 */
--card-border1-color: #3673A3; /* 卡片边框色1 */
--card-border2-color: #19EBFF; /* 卡片边框色2 */
--white-text-color: white; /* 白色文本 */
--lightblue-text-color: #75FEFF; /* 亮蓝色文本 */
--darkblue-text-color: #47AAFF; /* 深蓝色文本 */
--lightyellow-text-color: #FEE165; /* 亮黄色文本 */
} }
.page { .page {
position: relative; height: 100%;
height: 1080px;
width: 100%; width: 100%;
min-width: 1920px;
overflow: hidden;
/*background: url(./img/SketchPng1d2d7c804f3d192d29ad3750c138064d493e3f502f79253a3bfa266fbdda7488.png) 100% no-repeat;*/
background-color: var(--global-background-color); background-color: var(--global-background-color);
background-size: 100% 100% background-size: 100% 100%
} }
.head { .head {
height: 10%; height: 10%;
}
.head_content {
background: url(./img/top_img.png) no-repeat center;
width: 100%; width: 100%;
height: 100%; background-repeat: no-repeat;
display: flex; background-position: center;
justify-content: space-between; background-image: url(./img/top_img_2x.png);
text-align: center; background-size: cover;
white-space: nowrap;
}
.text_date {
overflow-wrap: break-word;
color: rgba(255, 255, 255, 1);
font-size: 20.00px;
letter-spacing: 1.6666666269302368px;
text-align: left;
margin: 1% 0 0 6%
}
.text_time {
overflow-wrap: break-word;
color: rgba(255, 255, 255, 1);
font-size: 20.00px;
letter-spacing: 1.6666666269302368px;
text-align: left;
margin: 1% 0 0 1%
} }
.head span {
.text_week { margin-left: 1rem;
overflow-wrap: break-word; color: var(--lightblue-text-color);
color: rgba(255, 255, 255, 1); font-size: 20px;
font-size: 20.00px; font-family: AlimamaShuHeiTi, serif;
letter-spacing: 1.6666666269302368px; font-weight: bold;
text-align: left; letter-spacing: 2px;
margin: 1% 0 0 1%
} }
.text_left {
.text_title { height: 50%;
text-shadow: 0px 2px 6px rgba(121, 179, 255, 0.600000); width: 25%;
overflow-wrap: break-word; float: left;
color: rgba(255, 255, 255, 1); display: flex;
font-size: 40.00px; justify-content: flex-end;
letter-spacing: 8px; align-items: center;
font-family: AlimamaShuHeiTi;
text-align: center;
white-space: nowrap; white-space: nowrap;
margin: 1% 0 0 19%
}
.text_car {
overflow-wrap: break-word;
color: rgba(255, 255, 255, 1);
font-size: 20.00px;
letter-spacing: 1.6666666269302368px;
font-family: Helvetica;
text-align: left;
margin: 1% 0 0 20%
}
/**边框**/
.l_t_line {
width: 5px;
height: 24px;
left: -3px;
top: -3px;
} }
.t_l_line { .text_right {
height: 5px; height: 50%;
width: 26px; width: 25%;
left: -3px; float: right;
top: -3px; display: flex;
} justify-content: flex-start;
align-items: center;
.t_line_box { white-space: nowrap;
position: absolute;
width: 100%;
height: 100%;
}
.t_line_box i {
background-color: #4788fb;
box-shadow: 0px 0px 10px #4788fb;
position: absolute;
}
.t_r_line {
height: 5px;
width: 26px;
right: -3px;
top: -3px;
}
.r_t_line {
width: 5px;
height: 24px;
right: -3px;
top: -3px;
}
.l_b_line {
width: 5px;
height: 24px;
left: -3px;
bottom: -3px;
}
.b_l_line {
height: 5px;
width: 26px;
left: -3px;
bottom: -3px;
}
.r_b_line {
width: 5px;
height: 24px;
right: -3px;
bottom: -3px;
}
.b_r_line {
height: 5px;
width: 26px;
right: -3px;
bottom: -3px;
}
.middle > div {
box-sizing: border-box;
border: 1px solid #2C58A6;
position: relative;
box-shadow: 0 0 10px #2C58A6;
} }
.middle { .middle {
height: 45%; height: 49%;
justify-content: center; justify-content: space-around;
display: flex; display: flex;
padding: 1rem;
} }
.content { .content {
...@@ -170,20 +70,15 @@ ...@@ -170,20 +70,15 @@
} }
.trade_left { .trade_left {
margin-bottom: 50px; width: 25%;
width: 20%;
} }
.trade_middle { .trade_middle {
margin-bottom: 50px; width: 45%;
width: 50%;
margin-left: 1%;
} }
.trade_right { .trade_right {
margin-bottom: 50px; width: 25%;
width: 20%;
margin-left: 1%;
} }
<template>
<info-card :style="cStyle">
<template v-slot:title>
{{title}}
</template>
<template v-slot:content>
<div class="card">
<div class="left">
<div class="left-top">
{{lt}}
</div>
<div class="left-bottom">
{{lb}}
</div>
</div>
<div class="right">
<div class="r_l c_top">{{rtl}}</div>
<div class="r_m c_top">{{rtm}}</div>
<div class="r_r c_top c_green">{{rtr}}</div>
<div class="r_l c_bottom">{{rbl}}</div>
<div class="r_m c_bottom ">{{rbm}}</div>
<div class="r_r c_bottom c_red">{{rbr}}</div>
</div>
</div>
</template>
</info-card>
</template>
<script>
import InfoCard from "./info-card.vue";
export default {
name:"ContrastCard",
components: {InfoCard},
data() {
return {
};
},
props: {
cStyle: {
type: Object,
default: function(){return {height:"110px"};}
},
title: {
type: String,
},
lt: {
type: String,
},
lb: {
type: String,
},
rtl: {
type: String,
},
rtm: {
type: String,
},
rtr: {
type: String,
},
rbl: {
type: String,
},
rbm: {
type: String,
},
rbr: {
type: String,
},
},
methods: {}
};
</script>
<style scoped>
.card{
width: 90%;
height: 100%;
margin: auto;
}
.left{
height: 100%;
width: 40%;
float:left;
}
.right{
height: 100%;
width: 60%;
float:left;
}
.c_top{
height: 60%;
line-height: 46px;
}
.c_bottom{
height: 40%;
}
.left-top{
color: #a2ef5c;
font-size: 32px;
text-align: center;
line-height: 46px;
height: 60%;
width: 100%;
}
.left-bottom{
text-align: right;
height: 40%;
width: 100%;
}
.right > div{
float: left;
text-align: center;
font-size: 16px;
}
.r_l{
width: 24%;
}
.r_m,.r_r{
width: 38%;
}
.c_red{
color: red;
}
.c_green{
color: #a2ef5c;
}
</style>
<template> <template>
<info-card :style="cStyle"> <div class="contrast_card">
<template v-slot:title> <div class="top_border"></div>
{{title}} <div class="top_side_dot"/>
</template> <div class="bottom_side_dot"/>
<template v-slot:content> <div class="bottom_border"></div>
<div class="card"> <div class="card_content">
<div class="left"> <slot></slot>
<div class="left-top">
{{lt}}
</div> </div>
<div class="left-bottom">
{{lb}}
</div> </div>
</div>
<div class="right">
<div class="r_l c_top">{{rtl}}</div>
<div class="r_m c_top">{{rtm}}</div>
<div class="r_r c_top c_green">{{rtr}}</div>
<div class="r_l c_bottom">{{rbl}}</div>
<div class="r_m c_bottom ">{{rbm}}</div>
<div class="r_r c_bottom c_red">{{rbr}}</div>
</div>
</div>
</template>
</info-card>
</template> </template>
<script> <script>
import InfoCard from "./info-card.vue";
export default { export default {
name:"ContrastCard", name: "ContrastCard"
components: {InfoCard},
data() {
return {
};
},
props: {
cStyle: {
type: Object,
default: function(){return {height:"110px"};}
},
title: {
type: String,
},
lt: {
type: String,
},
lb: {
type: String,
},
rtl: {
type: String,
},
rtm: {
type: String,
},
rtr: {
type: String,
},
rbl: {
type: String,
},
rbm: {
type: String,
},
rbr: {
type: String,
},
},
methods: {}
}; };
</script> </script>
<style scoped> <style scoped>
.card{
width: 90%; .contrast_card {
height: 100%; position: relative;
margin: auto; background-color: var(--card-background-color);
} }
.left{
height: 100%; .top_border {
width: 40%; height: 33%;
float:left; border-top: 2px solid var(--card-border1-color);
} border-left: 2px solid var(--card-border1-color);
.right{ border-right: 2px solid var(--card-border1-color);
}
.top_side_dot {
position: relative;
height: 17%;
}
.top_side_dot::before {
content: "";
position: absolute;
left: -2px;
height: 6px;
width: 6px;
border-radius: 50%;
background-color: var(--card-border2-color);
}
.top_side_dot::after {
content: "";
position: absolute;
right: -2px;
height: 6px;
width: 6px;
border-radius: 50%;
background-color: var(--card-border2-color);
}
.bottom_side_dot {
position: relative;
height: 17%;
}
.bottom_side_dot::before {
content: "";
position: absolute;
left: -2px;
bottom: 0;
height: 6px;
width: 6px;
border-radius: 50%;
background-color: var(--card-border2-color);
}
.bottom_side_dot::after {
content: "";
position: absolute;
right: -2px;
bottom: 0;
height: 6px;
width: 6px;
border-radius: 50%;
background-color: var(--card-border2-color);
}
.bottom_border {
height: 33%;
border-left: 2px solid var(--card-border1-color);
border-right: 2px solid var(--card-border1-color);
border-bottom: 2px solid var(--card-border1-color);
}
.card_content {
position: absolute;
top: 0;
height: 100%; height: 100%;
width: 60%;
float:left;
}
.c_top{
height: 60%;
line-height: 46px;
}
.c_bottom{
height: 40%;
}
.left-top{
color: #a2ef5c;
font-size: 32px;
text-align: center;
line-height: 46px;
height: 60%;
width: 100%;
}
.left-bottom{
text-align: right;
height: 40%;
width: 100%; width: 100%;
} padding: 0.5rem;
.right > div{ }
float: left;
text-align: center;
font-size: 16px;
}
.r_l{
width: 24%;
}
.r_m,.r_r{
width: 38%;
}
.c_red{
color: red;
}
.c_green{
color: #a2ef5c;
}
</style> </style>
<template>
<div class="simple_card">
<div class="top_corner_mark"/>
<div class="bottom_corner_mark"/>
<div class="card_content">
<slot></slot>
</div>
</div>
</template>
<script>
export default {
name: "SimpleCard"
};
</script>
<style scoped>
.simple_card {
position: relative;
margin: 0;
background-color: var(--card-background-color);
border: 0.05rem solid var(--card-border1-color);
}
.top_corner_mark {
position: absolute;
height: 10px;
width: 100%;
}
.top_corner_mark::before {
content: "";
position: absolute;
top: -1px;
left: -1px;
height: 10px;
width: 10px;
border-top: 2px solid var(--card-border2-color);
border-left: 2px solid var(--card-border2-color);
}
.top_corner_mark::after {
content: "";
position: absolute;
top: -1px;
right: -1px;
height: 10px;
width: 10px;
border-top: 2px solid var(--card-border2-color);
border-right: 2px solid var(--card-border2-color);
}
.bottom_corner_mark {
position: absolute;
bottom: 0;
height: 10px;
width: 100%;
}
.bottom_corner_mark::before {
content: "";
position: absolute;
bottom: -1px;
left: -1px;
height: 10px;
width: 10px;
border-bottom: 2px solid var(--card-border2-color);
border-left: 2px solid var(--card-border2-color);
}
.bottom_corner_mark::after {
content: "";
position: absolute;
bottom: -1px;
right: -1px;
height: 10px;
width: 10px;
border-bottom: 2px solid var(--card-border2-color);
border-right: 2px solid var(--card-border2-color);
}
.card_content {
height: 100%;
width: 100%;
padding: 0.5rem;
}
</style>
<template> <template>
<div style="height: 100%"> <div class="winner_list">
<div class="main_table t_btn8">
<table> <table>
<tbody> <tbody>
<tr v-for="(row, idx) in rows" :key="idx" :style="{height: 100 / rows.length + '%'}"> <tr v-for="(row, idx) in rows" :key="idx" :style="{height: 100 / rows.length + '%'}">
<td> <td><div class="col_number">{{ idx + 1 }}</div></td>
<div class="col_box"> <td class="winner_span" @click="goWinnerList">{{ row.title }}</td>
<span class="winner_span">{{ row.title }}</span> <td v-for="(col, idz) in row.column" :key="idz">
<span class="number_span">NO.{{ idx + 1 }}</span>
</div>
<div class="col_box">
<div v-for="(col, idz) in row.column" :key="idz">
<p class="key_span">{{ col.key }}</p> <p class="key_span">{{ col.key }}</p>
<p class="value_span">{{ col.value }}</p> <p class="value_span">{{ col.value }}</p>
</div>
</div>
</td> </td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
</div> </div>
</div>
</template> </template>
<script> <script>
import DisplayBoard from "../container/display-board.vue";
export default { export default {
name: "WinnersList", name: "WinnersList",
components: {DisplayBoard},
props: {}, props: {},
data() { data() {
return { return {
rows: [ rows: [
{ {
title: "上海欧冶股份有限公司", title: "XX有限公司",
column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}] column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}]
}, },
{ {
title: "上海欧冶股份有限公司", title: "XXXX有限公司",
column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}] column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}]
}, },
{ {
title: "上海欧冶股份有限公司", title: "XXXXX有限公司",
column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}] column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}]
}, },
{ {
title: "上海欧冶股份有限公司", title: "XXX有限公司",
column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}] column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}]
}, },
{ {
title: "上海欧冶股份有限公司", title: "XXXXXX有限公司",
column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}] column: [{key: "结算量(万吨)", value: 202012}, {key: "未收款(万元)", value: 202012}]
} }
] ]
}; };
}, },
methods: {} methods: {
goWinnerList() {
this.$router.push({path: '/winner_list'})
}
}
}; };
</script> </script>
<style scoped> <style scoped>
.main_table { .winner_list {
width: 95%;
height: 84%;
}
.main_table table {
width: 100%;
height: 100%;
}
.main_table tr {
height: 20%;
}
.main_table td {
padding: 0;
color: #fff;
font-size: 10px;
text-align: center;
} }
.main_table tbody tr:nth-child(odd) { table {
background-color: #04136B; height: 100%;
font-size: 12px;
color: white;
} }
.main_table tbody tr:nth-child(even) { tr:nth-child(odd) {
background-color: #051D7D; background-color: #0E5FFF20;
} }
.t_btn8, .t_btn2, .t_btn3 { tr:nth-child(even) {
position: relative; background-color: #0E5FFF30;
z-index: 100;
cursor: pointer;
} }
.col_box { td {
display: flex; padding: 0 0 0 1rem;
justify-content: space-around;
} }
.winner_span { .col_number {
height: 38px;
min-width: 38px;
color: #19EBFF;
font-weight: bold; font-weight: bold;
text-align: center;
line-height: 38px;
background: url(../../assets/img/number_bg.png) no-repeat center;
} }
.number_span { .winner_span {
color: #bf360c; color: white;
font-weight: bold; font-size: 14px;
} }
.key_span { .key_span {
color: darkgrey;
font-weight: bold;
} }
.value_span { .value_span {
color: #00c853; color: lightblue;
font-weight: bold; font-weight: bold;
} }
</style> </style>
<template>
<div id="main_bar_chart" @click="goChart"/>
</template>
<script>
import * as echarts from "echarts";
export default {
name: "MainBarChart",
data() {
return {
barChart: {
textStyle: {
color: "#FFFFFF",
fontSize: "12"
},
tooltip: {},
grid: {
top: "10%",
bottom: "10%"
},
xAxis: {
data: ['未结算未开票', '已结算未开票', '已开票未收款', '应收款', '已开票已收款'],
axisLabel: {
color: "#FFFFFF",
fontSize: "12",
margin: "15"
},
axisTick: {
show: false
}
},
yAxis: [{
type: "value",
splitLine: {
lineStyle: {
color: "#1E2C58"
}
},
axisLabel: {
show: false,
color: "#FFFFFFAA",
fontSize: "16"
}
}],
series: [
{
name: '应收账款',
type: 'bar',
data: [5002, 57873, 1987, 71168, 41098],
barWidth: "40%",
showBackground: true,
backgroundStyle: {
color: 'rgba(255, 255, 255, 0.1)'
},
itemStyle: {
barBorderRadius: 10,
},
color: {
type: 'linear',
x: 0, y: 0, x2: 0, y2: 1,
colorStops: [
{offset: 0, color: '#00CCD2'},
{offset: 1, color: '#00A2FF'}
]
},
label: {
show: true,
position: 'top',
color: "#FFFFFF",
},
}
]
},
myChart: null
}
},
methods: {
resizeChart() {
if (this.myChart) {
this.myChart.resize();
}
},
goChart() {
this.$router.push({path: "/chart"})
}
},
mounted() {
// 设置500毫秒延迟执行,解决组件没有渲染完成就开始绘制图表的问题
setTimeout(() => {
let mainBarChart = document.getElementById('main_bar_chart')
this.myChart = echarts.init(mainBarChart)
this.myChart.setOption(this.barChart);
// 监听窗口大小变化,重绘图表
window.addEventListener('resize', this.resizeChart);
}, 500)
},
beforeDestroy() {
window.removeEventListener("resize", this.resizeChart);
}
}
</script>
<template> <template>
<div class="trapezoid"> <div class="board_title">
<div class="trapezoid1"/> <div class="trapezoid1"/>
<div class="trapezoid2"/> <div class="trapezoid2"/>
<div class="trapezoid3"> <div class="trapezoid3">
<div class="left-half-trapezoid"/> <div class="left_half_trapezoid"/>
<div class="right-half-trapezoid"/> <div class="right_half_trapezoid"/>
<div class="title"> <div class="title">
<slot></slot> <slot></slot>
</div> </div>
...@@ -13,17 +13,17 @@ ...@@ -13,17 +13,17 @@
</template> </template>
<script> <script>
export default { export default {
name: "CardTitleLarge" name: "BoardTitleLarge"
}; };
</script> </script>
<style scoped> <style scoped>
.trapezoid { .board_title {
width: 100%; width: 100%;
height: 36px; height: 54px;
margin-bottom: 10px;
} }
.trapezoid1::before { .trapezoid1::before {
...@@ -31,9 +31,9 @@ export default { ...@@ -31,9 +31,9 @@ export default {
position: absolute; position: absolute;
top: -4px; top: -4px;
left: 50%; left: 50%;
margin-left: -50px; margin-left: -75px;
height: 6px; height: 6px;
width: 100px; width: 150px;
background-image: radial-gradient(#00F6F0, transparent 60%); background-image: radial-gradient(#00F6F0, transparent 60%);
} }
...@@ -41,64 +41,64 @@ export default { ...@@ -41,64 +41,64 @@ export default {
position: absolute; position: absolute;
top: -2px; top: -2px;
left: 50%; left: 50%;
margin-left: -78px; margin-left: -108px;
width: 156px; width: 216px;
border-top: 36px solid #0D53B7; border-top: 54px solid #0D53B7;
border-left: 14px solid transparent; border-left: 22px solid transparent;
border-right: 14px solid transparent; border-right: 22px solid transparent;
} }
.trapezoid2 { .trapezoid2 {
position: absolute; position: absolute;
top: -2px; top: -2px;
left: 50%; left: 50%;
margin-left: -75px; margin-left: -105px;
width: 150px; width: 210px;
border-top: 34px solid var(--global-background-color); border-top: 52px solid var(--global-background-color);
border-left: 12px solid transparent; border-left: 21px solid transparent;
border-right: 12px solid transparent; border-right: 21px solid transparent;
} }
.trapezoid3 { .trapezoid3 {
position: absolute; position: absolute;
top: -2px; top: -2px;
left: 50%; left: 50%;
margin-left: -70px; margin-left: -100px;
height: 30px; height: 50px;
width: 140px; width: 200px;
} }
.title { .title {
position: absolute; position: absolute;
width: 100%; width: 100%;
font-size: 12px; font-size: 18px;
font-family: 黑体,serif; font-family: 黑体,serif;
font-weight: 700; font-weight: 700;
text-align: center; text-align: center;
letter-spacing: 0.2rem; letter-spacing: 0.2rem;
white-space: nowrap; white-space: nowrap;
line-height: 30px; line-height: 50px;
color: #19ECFF; color: var(--lightblue-text-color);
} }
.left-half-trapezoid { .left_half_trapezoid {
position: absolute; position: absolute;
width: 50%; width: 50%;
height: 100%; height: 100%;
overflow: hidden; overflow: hidden;
} }
.left-half-trapezoid::after { .left_half_trapezoid::after {
content: ""; content: "";
position: absolute; position: absolute;
height: 100%; height: 100%;
width: 110%; width: 110%;
left: 5px; left: 10px;
background-image: linear-gradient(to bottom, #0933AD, transparent); background-image: linear-gradient(to bottom, #0933AD, transparent);
transform: skewX(20deg); transform: skewX(20deg);
} }
.right-half-trapezoid { .right_half_trapezoid {
position: absolute; position: absolute;
right: 0; right: 0;
width: 50%; width: 50%;
...@@ -106,13 +106,13 @@ export default { ...@@ -106,13 +106,13 @@ export default {
overflow: hidden; overflow: hidden;
} }
.right-half-trapezoid::after { .right_half_trapezoid::after {
content: ""; content: "";
position: absolute; position: absolute;
height: 100%; height: 100%;
width: 110%; width: 110%;
right: 5px; right: 10px;
background-image: linear-gradient(to bottom, #0933AD88, transparent); background-image: linear-gradient(to bottom, #0933AD, transparent);
transform: skewX(-20deg); transform: skewX(-20deg);
} }
......
<template> <template>
<div class="trapezoid"> <div class="board_title">
<div class="trapezoid1"/> <div class="trapezoid1"/>
<div class="trapezoid2"/> <div class="trapezoid2"/>
<div class="trapezoid3"> <div class="trapezoid3">
<div class="left-half-trapezoid"/> <div class="left_half_trapezoid"/>
<div class="right-half-trapezoid"/> <div class="right_half_trapezoid"/>
<div class="title"> <div class="title">
<slot></slot> <slot></slot>
</div> </div>
...@@ -14,16 +14,15 @@ ...@@ -14,16 +14,15 @@
<script> <script>
export default { export default {
name: "CardTitleSmall" name: "BoardTitleSmall"
}; };
</script> </script>
<style scoped> <style scoped>
.trapezoid { .board_title {
width: 100%; width: 100%;
height: 36px; height: 36px;
margin-bottom: 10px;
} }
.trapezoid1::before { .trapezoid1::before {
...@@ -71,24 +70,24 @@ export default { ...@@ -71,24 +70,24 @@ export default {
.title { .title {
position: absolute; position: absolute;
width: 100%; width: 100%;
font-size: 12px; font-size: 1rem;
font-family: 黑体,serif; font-family: 黑体,serif;
font-weight: 700; font-weight: 700;
text-align: center; text-align: center;
letter-spacing: 0.2rem; letter-spacing: 0.2rem;
white-space: nowrap; white-space: nowrap;
line-height: 30px; line-height: 30px;
color: #19ECFF; color: var(--lightblue-text-color);
} }
.left-half-trapezoid { .left_half_trapezoid {
position: absolute; position: absolute;
width: 50%; width: 50%;
height: 100%; height: 100%;
overflow: hidden; overflow: hidden;
} }
.left-half-trapezoid::after { .left_half_trapezoid::after {
content: ""; content: "";
position: absolute; position: absolute;
height: 100%; height: 100%;
...@@ -98,7 +97,7 @@ export default { ...@@ -98,7 +97,7 @@ export default {
transform: skewX(20deg); transform: skewX(20deg);
} }
.right-half-trapezoid { .right_half_trapezoid {
position: absolute; position: absolute;
right: 0; right: 0;
width: 50%; width: 50%;
...@@ -106,7 +105,7 @@ export default { ...@@ -106,7 +105,7 @@ export default {
overflow: hidden; overflow: hidden;
} }
.right-half-trapezoid::after { .right_half_trapezoid::after {
content: ""; content: "";
position: absolute; position: absolute;
height: 100%; height: 100%;
......
<template>
<div class="content container-with-bord" style="cursor: pointer; position: relative;">
<!--角标组件-->
<corner-mark-small></corner-mark-small>
<!--标题组件-->
<card-title-small v-if="$slots.title">
<slot name="title"></slot>
</card-title-small>
<slot></slot>
</div>
</template>
<script>
import CornerMarkSmall from "../icon/corner_mark_small.vue";
import CornerMarkLarge from "../icon/corner_mark_large.vue";
import CardTitleSmall from "../card/card_title_small.vue"
export default {
name: "ContainerWithBord",
components: {CornerMarkSmall, CornerMarkLarge, CardTitleSmall},
data() {
return {};
},
methods: {}
};
</script>
<style scoped>
div {
color: white;
}
.container-with-bord {
background-color: var(--container-background-color);
position: relative;
box-sizing: border-box;
border-radius: 15px;
box-shadow: 0 0 40px 10px #051E82 inset;
border: 2px solid #0D53B7;
}
</style>
<template>
<div class="display_board">
<!--角标组件-->
<corner-mark-large v-if="$props.corner_size === 'large'"/>
<corner-mark-small v-else/>
<!--标题组件-->
<board-title-large v-if="$props.title && $props.title_size === 'large'">{{ $props.title }}</board-title-large>
<board-title-small v-else-if="$props.title">{{ $props.title }}</board-title-small>
<!--内容插槽-->
<div class="board_content" ref="boardContent">
<slot></slot>
</div>
</div>
</template>
<script>
import CornerMarkSmall from "../icon/corner-mark-small.vue";
import CornerMarkLarge from "../icon/corner-mark-large.vue";
import BoardTitleSmall from "./board-title-small.vue"
import BoardTitleLarge from "./board-title-large.vue"
export default {
name: "DisplayBoard",
components: {CornerMarkSmall, CornerMarkLarge, BoardTitleSmall, BoardTitleLarge},
props: {
title: {
type: String,
default: null
},
corner_size: {
type: String,
default: "small"
},
title_size: {
type: String,
default: "small"
},
},
data() {
return {};
},
methods: {},
mounted() {
// 根据标题大小动态控制内容高度
if (this.$props.title) {
this.$refs.boardContent.style.height = this.$props.title_size === "large" ? "calc(100% - 54px)" : "calc(100% - 36px)"
}
}
};
</script>
<style scoped>
.display_board {
cursor: pointer;
position: relative;
box-sizing: border-box;
border-radius: 1.5rem;
border: 0.2rem solid var(--container-border-color);
background-color: var(--container-background-color);
box-shadow: 0 0 3rem var(--container-shadow-color) inset;
}
.board_content {
position: absolute;
height: 100%;
width: 100%;
padding: 1rem;
}
</style>
<template>
<div class="showcase">
<div class="showcase_cover"/>
<div class="show_content">
<slot></slot>
</div>
<div class="showcase_base">
<div class="showcase_title">{{ $props.title }}</div>
</div>
</div>
</template>
<script>
export default {
name: "Showcase",
props: {
title: String
}
};
</script>
<style scoped>
.showcase {
height: 100%;
background: var(--container-background-color);
border-radius: 500% / 100%;
box-shadow: 0 0 30px -2px var(--card-border2-color) inset;
overflow: hidden;
}
.showcase_cover {
width: 100%;
height: 15%;
border-radius: 50% / 50%;
background: radial-gradient(#19EBFF66, transparent);
}
.show_content {
height: 40%;
width: 100%;
color: var(--lightblue-text-color);
}
.showcase_base {
position: relative;
bottom: 0;
width: 100%;
height: 50%;
background-color: rgba(29, 58, 197, 0.64);
border-radius: 50% / 15% 15% 0 0;
display: flex;
align-items: center;
justify-content: center;
}
.showcase_base::after {
content: "";
position: absolute;
top: 0;
width: 100%;
height: 30%;
border-radius: 50% / 50%;
background: radial-gradient(#19EBFF66, transparent);
}
.showcase_title {
position: absolute;
height: 0;
color: var(--white-text-color);
font-size: 12px;
font-family: 黑体, serif;
font-weight: 700;
letter-spacing: 0.2rem;
}
</style>
<template> <template>
<div> <div>
<div class="content-title"> <div class="content-title">{{ $props.title }}</div>
<slot name="title"></slot>
</div>
<div> <div>
<slot name="content"></slot> <slot name="content"></slot>
</div> </div>
...@@ -11,6 +9,9 @@ ...@@ -11,6 +9,9 @@
<script> <script>
export default { export default {
name:"TitleContent", name:"TitleContent",
props: {
title: String
},
data() { data() {
return { return {
}; };
......
...@@ -25,51 +25,51 @@ export default { ...@@ -25,51 +25,51 @@ export default {
.conner_mark_left1 { .conner_mark_left1 {
position: absolute; position: absolute;
left: -2px; left: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 32px solid #0D53B7; border-top: 3.1rem solid var(--container-border-color);
border-right: 32px solid transparent; border-right: 3.1rem solid transparent;
} }
.conner_mark_left2 { .conner_mark_left2 {
position: absolute; position: absolute;
left: -2px; left: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 28px solid var(--global-background-color); border-top: 2.8rem solid var(--global-background-color);
border-right: 28px solid transparent; border-right: 2.8rem solid transparent;
} }
.conner_mark_left3 { .conner_mark_left3 {
position: absolute; position: absolute;
left: -2px; left: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 24px solid #0E5FFF; border-top: 2.4rem solid var(--corner-background-color);
border-right: 24px solid transparent; border-right: 2.4rem solid transparent;
} }
.conner_mark_right1 { .conner_mark_right1 {
position: absolute; position: absolute;
right: -2px; right: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 32px solid #0D53B7; border-top: 3.1rem solid var(--container-border-color);
border-left: 32px solid transparent; border-left: 3.1rem solid transparent;
} }
.conner_mark_right2 { .conner_mark_right2 {
position: absolute; position: absolute;
right: -2px; right: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 28px solid var(--global-background-color); border-top: 2.8rem solid var(--global-background-color);
border-left: 28px solid transparent; border-left: 2.8rem solid transparent;
} }
.conner_mark_right3 { .conner_mark_right3 {
position: absolute; position: absolute;
right: -2px; right: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 24px solid #0E5FFF; border-top: 2.4rem solid var(--corner-background-color);
border-left: 24px solid transparent; border-left: 2.4rem solid transparent;
} }
</style> </style>
......
...@@ -25,51 +25,51 @@ export default { ...@@ -25,51 +25,51 @@ export default {
.conner_mark_left1 { .conner_mark_left1 {
position: absolute; position: absolute;
left: -2px; left: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 36px solid #0D53B7; border-top: 3.5rem solid var(--container-border-color);
border-right: 18px solid transparent; border-right: 1.7rem solid transparent;
} }
.conner_mark_left2 { .conner_mark_left2 {
position: absolute; position: absolute;
left: -2px; left: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 30px solid var(--global-background-color); border-top: 3rem solid var(--global-background-color);
border-right: 15px solid transparent; border-right: 1.5rem solid transparent;
} }
.conner_mark_left3 { .conner_mark_left3 {
position: absolute; position: absolute;
left: -2px; left: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 20px solid #0E5FFF; border-top: 2rem solid var(--corner-background-color);
border-right: 10px solid transparent; border-right: 1rem solid transparent;
} }
.conner_mark_right1 { .conner_mark_right1 {
position: absolute; position: absolute;
right: -2px; right: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 36px solid #0D53B7; border-top: 3.5rem solid var(--container-border-color);
border-left: 18px solid transparent; border-left: 1.7rem solid transparent;
} }
.conner_mark_right2 { .conner_mark_right2 {
position: absolute; position: absolute;
right: -2px; right: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 30px solid var(--global-background-color); border-top: 3rem solid var(--global-background-color);
border-left: 15px solid transparent; border-left: 1.5rem solid transparent;
} }
.conner_mark_right3 { .conner_mark_right3 {
position: absolute; position: absolute;
right: -2px; right: -0.2rem;
top: -2px; top: -0.2rem;
border-top: 20px solid #0E5FFF; border-top: 2rem solid var(--corner-background-color);
border-left: 10px solid transparent; border-left: 1rem solid transparent;
} }
</style> </style>
......
<template>
<button class="click-button" @click.right.prevent="count++">鼠标右键点击{{ count }}</button>
</template>
<script>
export default {
name: "CounterButton",
data() {
return {
count: 0
};
},
props: {},
methods: {}
};
</script>
<style scoped>
.click-button {
height: 4rem;
width: 12rem;
}
</style>
<template>
<ul>
<li class="optionItem" v-for="(option, i) in options" :key="i" @click="handleSelect(option)">{{ i }}-{{ option }}</li>
</ul>
</template>
<script>
export default {
props: {
options: {
type: String,
default: () => [],
required: true,
validate: value => {
return value.length >= 0
}
},
},
data() {
return {}
},
methods: {
handleSelect(option) {
this.$emit("selected", option)
}
}
};
</script>
<style scoped>
.optionItem{
background-color: #00b8d4;
}
</style>
<template>
<div style="background-color: whitesmoke">
<div>{{ setupName }}: {{ counter }}: {{ obj.title }}</div>
<div>{{ twiceTheCounter }}</div>
<button @click="action" style="height: 4rem;width: 8rem">按钮</button>
</div>
</template>
<script>
import {computed, onMounted, reactive, ref, watch} from "vue";
export default {
props: {
setupName: String
},
setup() {
// 获取响应式变量:基本类型,获取的变量需要.value获取值
const counter = ref(0);
// 获取响应式变量:引用类型
const obj = reactive({title: "这是个标题"});
const twiceTheCounter = computed(() => counter.value * 2);
watch(counter, (newValue, oldValue) => {
console.log(newValue, oldValue);
});
onMounted(() => {
console.log("mounted");
});
const action = () => {
counter.value = counter.value + 3;
obj.title = "我改名字了";
};
return {
counter,
obj,
twiceTheCounter,
action
};
}
};
</script>
<style scoped>
</style>
<template> <template>
<div class="page"> <div class="main">
<div class="head"> <div class="middle">
<div class="head_content"> <display-board class="trade_left" title="营业情况">
<div> <div style="height: 100%; display: flex; flex-direction: column; justify-content: space-around; padding: 0 1rem 0 1rem;">
<span class="text_date">2023-08-01</span> <contrast-card style="height: 28%;">content</contrast-card>
<span class="text_time">17:18:29</span> <contrast-card style="height: 28%;">content</contrast-card>
<span class="text_week">星期三</span> <contrast-card style="height: 28%;">content</contrast-card>
</div>
<div>
<span class="text_car">刷新时间:10s</span>
</div> </div>
</display-board>
<display-board class="trade_middle" corner_size="large">
<div style="height: 36%;display: flex;justify-content: space-evenly;padding-top: 1.5rem">
<simple-card style="width: 30%;height: 100%">content</simple-card>
<simple-card style="width: 30%;height: 100%">content</simple-card>
<simple-card style="width: 30%;height: 100%">content</simple-card>
</div> </div>
<main-bar-chart style="width: 100%; height: 64%;"></main-bar-chart>
</display-board>
<display-board class="trade_right" title="账款情况">
<div style="height: 100%; display: flex; flex-direction: column; justify-content: space-around; padding: 0 1rem 0 1rem;">
<contrast-card style="height: 28%;">content</contrast-card>
<contrast-card style="height: 28%;">content</contrast-card>
<contrast-card style="height: 28%;">content</contrast-card>
</div> </div>
<div class="middle"> </display-board>
<container-with-bord class="trade_left">
<template v-slot:title>营业情况</template>
<contrast-card v-for="data in mockData.yyqk" :title="data.title"
:lt="data.amount"
:lb="data.unit"
:rtl="data.title1"
:rtm="data.amount1"
:rtr="data.rate1"
:rbl="data.title2"
:rbm="data.amount2"
:rbr="data.rate2"/>
</container-with-bord>
<container-with-bord class="trade_middle">
<card style="margin-top: 10px; width: 80%; height: 20%; position: relative;">
<template>
<title-content v-for="data in mockData.sr" style="width: 33.3%; text-align: center; float:left;">
<template v-slot:title>{{ data.title }}</template>
<num-with-r-b-mark>
<template v-slot:num>{{ data.value }}</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</title-content>
</template>
</card>
<div id="main_bar_chart" style="width: 897px; margin: auto; height: 350px;"/>
</container-with-bord>
<container-with-bord class="trade_right">
<template v-slot:title>账款情况</template>
<contrast-card v-for="data in mockData.zkqk" :title="data.title"
:lt="data.amount"
:lb="data.unit"
:rtl="data.title1"
:rtm="data.amount1"
:rtr="data.rate1"
:rbl="data.title2"
:rbm="data.amount2"
:rbr="data.rate2"/>
</container-with-bord>
</div> </div>
<div class="middle"> <div class="middle">
<container-with-bord class="trade_left"> <display-board class="trade_left" title="已开票未收款">
<template v-slot:title>已开票未收款</template> <winners-list style="height: 96%"/>
<winners-list/> </display-board>
</container-with-bord>
<div class="trade_middle" style="border: none;box-shadow: none;"> <div class="trade_middle" style="border: none;box-shadow: none;">
<div style="display: flex;justify-content: space-between;height: 50%;margin-bottom: 12px;"> <div style="display: flex; justify-content: space-between; height: 50%;">
<container-with-bord style="width: 32%;"> <display-board style="width: 32%;" title="每日目标情况">content</display-board>
<template v-slot:title>每日目标情况</template> <display-board style="width: 32%;" title="月度目标情况">content</display-board>
</container-with-bord> <display-board style="width: 32%;" title="年度目标情况">content</display-board>
<container-with-bord style="width: 32%;">
<template v-slot:title>月度目标情况</template>
</container-with-bord>
<container-with-bord style="width: 32%;">
<template v-slot:title>年度目标情况</template>
</container-with-bord>
</div> </div>
<div style="height: 50%; width: 100%;"> <div style="display: flex; justify-content: space-between; height: 50%; padding-top: 2rem;">
<div style="width: 100%; height: 50%;"> <showcase style="width: 18%;" title="当日订单量">content</showcase>
<card <showcase style="width: 18%;" title="当日完成量">content</showcase>
style="width: 32%; margin: 5px calc(4%/6); height: calc(100% - 10px); position: relative; float: left"> <showcase style="width: 18%;" title="余量">content</showcase>
<title-content style="text-align: center; float:left; width: 100%;"> <showcase style="width: 18%;" title="流失客户">content</showcase>
<template v-slot:title> <showcase style="width: 18%;" title="新增客户">content</showcase>
当日订单
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
<card
style="width: 32%; margin: 5px calc(4%/6); height: calc(100% - 10px); position: relative; float: left">
<title-content style="text-align: center; float:left; width: 100%;">
<template v-slot:title>
当日完成量
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
<card
style="width: 32%; margin: 5px calc(4%/6); height: calc(100% - 10px); position: relative; float: left">
<title-content style="text-align: center; float:left; width: 100%;">
<template v-slot:title>
余量
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
</div> </div>
<div style="width: 100%; height: 50%;">
<card style="width: 32%; margin: 5px 9%; height: calc(100% - 10px); position: relative; float: left">
<title-content style="text-align: center; float:left; width: 100%;">
<template v-slot:title>
消失客户
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
<card style="width: 32%; margin: 5px 9%; height: calc(100% - 10px); position: relative; float: left">
<title-content style="text-align: center; float:left; width: 100%;">
<template v-slot:title>
新增客户
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
</div> </div>
</div> <display-board class="trade_right" title="当日订单量占比">content</display-board>
</div>
<container-with-bord class="trade_right">
<template v-slot:title>货运收入</template>
</container-with-bord>
</div> </div>
</div> </div>
</template> </template>
<script> <script>
import TitleContentWithBord from "./components/container/title-content-with-bord.vue"; import DisplayBoard from "./components/container/display-board.vue";
import InfoCard from "./components/card/info-card.vue"; import Showcase from "./components/container/showcase.vue";
import ContrastCard from "./components/card/contrast-card.vue"; import ContrastCard from "./components/card/contrast-card.vue";
import * as echarts from "echarts"; import SimpleCard from "./components/card/simple-card.vue";
import TitleContent from "./components/container/title-content.vue"; import MainBarChart from "./components/chart/main-bar-chart.vue";
import NumWithRBMark from "./components/layout/num-with-r-b-mark.vue";
import Card from "./components/card/card.vue";
import ContainerWithBord from "./components/container/container-with-bord.vue";
import WinnersList from "./components/card/winners-list.vue"; import WinnersList from "./components/card/winners-list.vue";
export default { export default {
components: { components: {
ContainerWithBord, Showcase,
TitleContentWithBord, DisplayBoard,
Card,
NumWithRBMark,
TitleContent,
ContrastCard, ContrastCard,
InfoCard, SimpleCard,
MainBarChart,
WinnersList WinnersList
}, },
data() { data() {
return { return {
constants: {},
mockData: {
yyqk: {
yye: {
title: "营业额",
amount: "20,303",
unit: "万元",
title1: "昨天",
amount1: "21,000",
rate1: "-3.32%",
title2: "上月",
amount2: "20,000",
rate2: "+4.92%",
},
cb: {
title: "成本",
amount: "10,303",
unit: "万元",
title1: "昨日",
amount1: "11,000",
rate1: "-2.68%",
title2: "上月",
amount2: "10,000",
rate2: "+5.71%",
},
ml: {
title: "毛利",
amount: "10,000",
unit: "万元",
title1: "昨日",
amount1: "10,000",
rate1: "0.00%",
title2: "上月",
amount2: "10,000",
rate2: "0.00%",
},
},
zkqk: {
yszk: {
title: "应收账款",
amount: "20,303",
unit: "万元",
title1: "昨天",
amount1: "21,000",
rate1: "-3.32%",
title2: "上月",
amount2: "20,000",
rate2: "+4.92%",
},
yfzk: {
title: "应付账款",
amount: "10,303",
unit: "万元",
title1: "昨日",
amount1: "11,000",
rate1: "-2.68%",
title2: "上月",
amount2: "10,000",
rate2: "+5.71%",
},
zsye: {
title: "账上余额",
amount: "10,000",
unit: "万元",
title1: "昨日",
amount1: "10,000",
rate1: "0.00%",
title2: "上月",
amount2: "10,000",
rate2: "0.00%",
},
},
sr: [
{
title: '累计营业收入(当年)',
value: '20,303',
},
{
title: '应收款(财务)',
value: '20,303',
},
{
title: '应收款(营销)',
value: '20,303',
},
],
barChart: {
textStyle: {color: "#fff"},
tooltip: {},
xAxis: {
data: ['未结算未开票', '已结算未开票', '已开票未收款', '应收款', '已开票已收款']
},
yAxis: {},
series: [
{
name: '开票详情',
type: 'bar',
data: [500, 300, 500, 1001, 319],
color: "#7f83f7",
label: {
show: true,
position: 'top',
color: "#fff",
},
}
]
},
} }
};
}, },
methods: { methods: {
drawMainBarChart() {
let myChart = echarts.init(document.getElementById('main_bar_chart'));
myChart.setOption(this.mockData.barChart);
}
}, },
mounted() {
this.drawMainBarChart();
}
}; };
</script> </script>
<template>
<div class="page">
<div class="head">
<div class="head_content">
<span class="text_date">2023-08-01</span>
<span class="text_time">17:18:29</span>
<span class="text_week">星期三</span>
<span class="text_title">联达供应链数据大屏</span>
<span class="text_car">刷新时间:10s</span>
</div>
</div>
<div class="middle">
<title-content-with-bord class="trade_left">
<template v-slot:title>营业情况</template >
<template v-slot:content>
<contrast-card v-for="data in mockData.yyqk" :title="data.title"
:lt="data.amount"
:lb="data.unit"
:rtl="data.title1"
:rtm="data.amount1"
:rtr="data.rate1"
:rbl="data.title2"
:rbm="data.amount2"
:rbr="data.rate2"/>
</template >
</title-content-with-bord>
<container-with-bord class="trade_middle">
<card style="margin-top: 10px; width: 80%; height: 20%; position: relative;">
<template>
<title-content v-for="data in mockData.sr" style="width: 33.3%; text-align: center; float:left;">
<template v-slot:title>
{{ data.title }}
</template>
<template v-slot:content>
<num-with-r-b-mark>
<template v-slot:num>{{ data.value }}</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</template>
</card>
<div id="main_bar_chart" style="width: 897px; margin: auto; height: 350px;"/>
</container-with-bord>
<title-content-with-bord class="trade_right">
<template v-slot:title>账款情况</template >
<template v-slot:content>
<contrast-card v-for="data in mockData.zkqk" :title="data.title"
:lt="data.amount"
:lb="data.unit"
:rtl="data.title1"
:rtm="data.amount1"
:rtr="data.rate1"
:rbl="data.title2"
:rbm="data.amount2"
:rbr="data.rate2"/>
</template >
</title-content-with-bord>
</div>
<div class="middle">
<div class="content trade_left" style="cursor: pointer;">
<!--左上边框-->
<div class="t_line_box">
<i class="t_l_line"></i>
<i class="l_t_line"></i>
</div>
<!--右上边框-->
<div class="t_line_box">
<i class="t_r_line"></i>
<i class="r_t_line"></i>
</div>
<!--左下边框-->
<div class="t_line_box">
<i class="l_b_line"></i>
<i class="b_l_line"></i>
</div>
<!--右下边框-->
<div class="t_line_box">
<i class="r_b_line"></i>
<i class="b_r_line"></i>
</div>
<div class="main_title">
<img src="img/t_1.png" alt="">
湖南省货运收入
</div>
<div id="chart_1" class="chart" style="width:100%;height: 280px;"></div>
</div>
<div class="trade_middle" style="border: none;box-shadow: none;">
<container-with-bord style="height: calc(50% - 6px); width: 100%; margin-bottom: 12px;"></container-with-bord>
<container-with-bord style="height: calc(50% - 6px); width: 100%;">
<div style="width: 100%; height: 50%;">
<card style="width: 32%; margin: 5px calc(4%/6); height: calc(100% - 10px); position: relative; float: left">
<title-content style="text-align: center; float:left; width: 100%;">
<template v-slot:title>
当日订单
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
<card style="width: 32%; margin: 5px calc(4%/6); height: calc(100% - 10px); position: relative; float: left">
<title-content style="text-align: center; float:left; width: 100%;">
<template v-slot:title>
当日完成量
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
<card style="width: 32%; margin: 5px calc(4%/6); height: calc(100% - 10px); position: relative; float: left">
<title-content style="text-align: center; float:left; width: 100%;">
<template v-slot:title>
余量
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
</div>
<div style="width: 100%; height: 50%;">
<card style="width: 32%; margin: 5px 9%; height: calc(100% - 10px); position: relative; float: left">
<title-content style="text-align: center; float:left; width: 100%;">
<template v-slot:title>
消失客户
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
<card style="width: 32%; margin: 5px 9%; height: calc(100% - 10px); position: relative; float: left">
<title-content style="text-align: center; float:left; width: 100%;">
<template v-slot:title>
新增客户
</template>
<template v-slot:content>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>2,000</template>
<template v-slot:unit>万吨</template>
</num-with-r-b-mark>
<num-with-r-b-mark style="width: 48%; float: left; line-height: 64px;">
<template v-slot:num>20,000</template>
<template v-slot:unit>万元</template>
</num-with-r-b-mark>
</template>
</title-content>
</card>
</div>
</container-with-bord>
</div>
<div class="content trade_right"><!--左上边框-->
<div class="t_line_box">
<i class="t_l_line"></i>
<i class="l_t_line"></i>
</div>
<!--右上边框-->
<div class="t_line_box">
<i class="t_r_line"></i>
<i class="r_t_line"></i>
</div>
<!--左下边框-->
<div class="t_line_box">
<i class="l_b_line"></i>
<i class="b_l_line"></i>
</div>
<!--右下边框-->
<div class="t_line_box">
<i class="r_b_line"></i>
<i class="b_r_line"></i>
</div>
<div class="main_title">
<img src="img/t_1.png" alt="">
湖南省货运收入
</div>
<div id="chart_1" class="chart" style="width:100%;height: 280px;"></div>
</div>
</div>
</div>
</template>
<script>
import TitleContentWithBord from "./components/container/title-content-with-bord.vue";
import InfoCard from "./components/card/info-card.vue";
import ContrastCard from "./components/card/contrast-card.vue";
import * as echarts from "echarts";
import TitleContent from "./components/container/title-content.vue";
import NumWithRBMark from "./components/layout/num-with-r-b-mark.vue";
import Card from "./components/card/card.vue";
import ContainerWithBord from "./components/container/container-with-bord.vue";
export default {
components: {ContainerWithBord, TitleContentWithBord, Card, NumWithRBMark, TitleContent, ContrastCard, InfoCard},
data() {
return {
constants: {},
mockData:{
yyqk:{
yye:{
title:"营业额",
amount:"20,303",
unit:"万元",
title1:"昨天",
amount1:"21,000",
rate1:"-3.32%",
title2:"上月",
amount2:"20,000",
rate2:"+4.92%",
},
cb:{
title:"成本",
amount:"10,303",
unit:"万元",
title1:"昨日",
amount1:"11,000",
rate1:"-2.68%",
title2:"上月",
amount2:"10,000",
rate2:"+5.71%",
},
ml:{
title:"毛利",
amount:"10,000",
unit:"万元",
title1:"昨日",
amount1:"10,000",
rate1:"0.00%",
title2:"上月",
amount2:"10,000",
rate2:"0.00%",
},
},
zkqk:{
yszk:{
title:"应收账款",
amount:"20,303",
unit:"万元",
title1:"昨天",
amount1:"21,000",
rate1:"-3.32%",
title2:"上月",
amount2:"20,000",
rate2:"+4.92%",
},
yfzk:{
title:"应付账款",
amount:"10,303",
unit:"万元",
title1:"昨日",
amount1:"11,000",
rate1:"-2.68%",
title2:"上月",
amount2:"10,000",
rate2:"+5.71%",
},
zsye:{
title:"账上余额",
amount:"10,000",
unit:"万元",
title1:"昨日",
amount1:"10,000",
rate1:"0.00%",
title2:"上月",
amount2:"10,000",
rate2:"0.00%",
},
},
sr:[
{
title:'累计营业收入(当年)',
value:'20,303',
},
{
title:'应收款(财务)',
value:'20,303',
},
{
title:'应收款(营销)',
value:'20,303',
},
],
barChart:{
textStyle: {color: "#fff"},
tooltip: {},
xAxis: {
data: ['未结算未开票', '已结算未开票', '已开票未收款', '应收款', '已开票已收款']
},
yAxis: {},
series: [
{
name: '开票详情',
type: 'bar',
data: [500, 300, 500, 1001, 319],
color: "#7f83f7",
label: {
show: true,
position: 'top',
color: "#fff",
},
}
]
},
}
};
},
methods: {
drawMainBarChart(){
let myChart = echarts.init(document.getElementById('main_bar_chart'));
myChart.setOption(this.mockData.barChart);
}
},
mounted() {
this.drawMainBarChart();
}
};
</script>
<style scoped lang="css" src="./assets/index.css"/>
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>开尔维</title> <title>联达供应链数据大屏</title>
<!-- Google MD图标 --> <!-- Google MD图标 -->
<link href="https://cdn.bootcss.com/material-design-icons/3.0.1/iconfont/material-icons.min.css" rel="stylesheet"> <link href="https://cdn.bootcss.com/material-design-icons/3.0.1/iconfont/material-icons.min.css" rel="stylesheet">
...@@ -21,15 +21,14 @@ ...@@ -21,15 +21,14 @@
} }
body{ body{
min-height: 1080.00px; min-height: 900px;
max-height: 1080.00px; min-width: 1440px;
min-width: 1920px;
max-width: 1920px;
} }
body, html { body, html {
margin: 0; margin: 0;
padding: 0; padding: 0;
width: 100%;
height: 100%; height: 100%;
overflow-y: hidden; overflow-y: hidden;
} }
......
<template> <template>
<router-view></router-view> <div class="page">
<div class="head">
<div class="text_left">
<span>2023-08-01</span>
<span>17:18:29</span>
<span>星期三</span>
</div>
<div class="text_right">
<span>刷新时间:10s</span>
</div>
</div>
<router-view style="height: 90%"></router-view>
</div>
</template> </template>
<script> <script>
window.$ = window.jQuery = require('materialize-css/node_modules/jquery/dist/jquery.js') window.$ = window.jQuery = require('materialize-css/node_modules/jquery/dist/jquery.js')
require('materialize-css') require('materialize-css')
export default { export default {
name: 'app', name: 'app',
// 页面加载之前 // 页面加载之前
created() { created() {
}, },
// 页面加载后 // 页面加载后
mounted() { mounted() {
console.log(this.$router)
this.$router.push("/index"); this.$router.push("/index");
} }
} }
</script> </script>
<style> <style>
@import "../../../node_modules/materialize-css/bin/materialize.css"; @import "../../../node_modules/materialize-css/bin/materialize.css";
#app {
}
/*侧边栏头部背景*/
.side-nav .userView .background img {
width: 100%;
}
/*导航名字*/
.nav-name {
margin: 0 15px;
padding: 0;
font-size: 16px;
}
/*右侧导航栏图标*/
.nav-wrapper .right li a i {
padding: 0;
margin: 0;
font-size: 16px;
}
/*右侧导航栏文字*/
.nav-wrapper .right li a span {
margin-left: 8px;
}
/*为大屏幕的侧边栏提供空间*/
header, main, footer {
padding-left: 300px;
}
/*主干区域*/ #app {
main { }
position: fixed;
width: 100%;
height: calc(100% - 64px);
z-index: -1;
}
@media only screen and (max-width: 992px) { @media only screen and (max-width: 992px) {
header, main, footer { header, main, footer {
padding-left: 0; padding-left: 0;
} }
} }
</style> </style>
...@@ -2,6 +2,8 @@ import Vue from 'vue' ...@@ -2,6 +2,8 @@ import Vue from 'vue'
import Router from 'vue-router' import Router from 'vue-router'
import Main from '../index.vue' import Main from '../index.vue'
import index from '../../databoard/index.vue' import index from '../../databoard/index.vue'
import MainBarChart from "../../databoard/components/chart/main-bar-chart.vue";
import WinnersList from "../../databoard/components/card/winners-list.vue";
Vue.use(Router) Vue.use(Router)
...@@ -17,5 +19,15 @@ export default new Router({ ...@@ -17,5 +19,15 @@ export default new Router({
name: 'index', name: 'index',
component: index component: index
}, },
{
path: '/chart',
name: 'chart',
component: MainBarChart
},
{
path: '/winner_list',
name: 'winnerList',
component: WinnersList
}
] ]
}) })
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment