bike/pages_admin/worke/worke_Operation.vue

525 lines
11 KiB
Vue
Raw Normal View History

2024-05-10 18:00:23 +08:00
<template>
<view class="page">
<u-navbar title="运营数据" :border-bottom="false" :background="bgc" title-color='#000' title-size='36'
2024-06-07 18:08:55 +08:00
height='45'></u-navbar>
2024-05-10 18:00:23 +08:00
<view class="top_box">
<view class="left_text">
时间范围
</view>
<view class="timebox">
<view class="left_time" @click="time1=true">
{{firsTime}}
</view>
-
<view class="right_time" @click="time2=true">
{{lasTime}}
</view>
</view>
</view>
<view class="data_box">
2024-05-14 18:04:34 +08:00
<view class="data_cont " :class="cutidx==0?'act1':''" @click="changeTime(0)">
2024-05-10 18:00:23 +08:00
今日
</view>
2024-05-14 18:04:34 +08:00
<view class="data_cont" :class="cutidx==1?'act1':''" @click="changeTime(1)">
2024-05-10 18:00:23 +08:00
昨日
</view>
2024-05-14 18:04:34 +08:00
<view class="data_cont" :class="cutidx==2?'act1':''" @click="changeTime(2)">
2024-05-10 18:00:23 +08:00
本月
</view>
2024-05-14 18:04:34 +08:00
<view class="data_cont" :class="cutidx==3?'act1':''" @click="changeTime(3)">
2024-05-10 18:00:23 +08:00
上个月
</view>
</view>
<view class="top_card">
<view class="tit">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uR7EhQMLnjuRoi0G3tA6" mode=""></image>
收入相关
</view>
<view class="info">
<view class="info_li">
2024-05-14 18:04:34 +08:00
总营收 <span style="color: #4C97E7;">{{info.income.totalIncome}}</span>
2024-05-10 18:00:23 +08:00
</view>
<view class="info_li">
2024-05-14 18:04:34 +08:00
累计待支付 <span style="color: #4C97E7;">{{info.income.totalIncome}}</span>
2024-05-10 18:00:23 +08:00
</view>
</view>
<view class="info">
<view class="info_li">
2024-05-14 18:04:34 +08:00
已支付 <span style="color: #3D3D3D ;">{{info.income.totalPaid}}</span>
2024-05-10 18:00:23 +08:00
</view>
<view class="info_li">
2024-05-14 18:04:34 +08:00
已退款 <span style="color: #3D3D3D ;">{{info.income.totalRefund}}</span>
2024-05-10 18:00:23 +08:00
</view>
</view>
</view>
<view class="cont_box">
<view class="cont_info">
<view class="info_li" style="color:#4C97E7 ;">
租赁费
</view>
<view class="info_li" style="color:#4C97E7 ;">
调度费
</view>
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
</view>
<view class="cont_info">
<view class="info_li">
2024-05-14 18:04:34 +08:00
已支付{{info.income.totalRidingFee}}
2024-05-10 18:00:23 +08:00
</view>
<view class="info_li">
2024-05-14 18:04:34 +08:00
已支付{{info.income.totalRidingRefund}}
2024-05-10 18:00:23 +08:00
</view>
</view>
<view class="cont_info">
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
<view class="info_li">
2024-05-14 18:04:34 +08:00
已退款{{info.income.totalDispatchFee}}
2024-05-10 18:00:23 +08:00
</view>
<view class="info_li">
2024-05-14 18:04:34 +08:00
已退款{{info.income.totalDispatchRefund}}
2024-05-10 18:00:23 +08:00
</view>
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
</view>
<view class="cont_info">
<view class="info_li" style="color:#4C97E7 ;">
2024-05-14 18:04:34 +08:00
预约费
2024-05-10 18:00:23 +08:00
</view>
<view class="info_li" style="color:#4C97E7 ;">
2024-05-14 18:04:34 +08:00
管理费
2024-05-10 18:00:23 +08:00
</view>
</view>
<view class="cont_info">
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
<view class="info_li">
2024-05-14 18:04:34 +08:00
已支付{{info.income.totalAppointmentFee}}
2024-05-10 18:00:23 +08:00
</view>
<view class="info_li">
2024-05-14 18:04:34 +08:00
已支付{{info.income.totalAppointmentRefund}}
2024-05-10 18:00:23 +08:00
</view>
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
</view>
<view class="cont_info">
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
<view class="info_li">
2024-05-14 18:04:34 +08:00
已退款{{info.income.totalManageFee}}
2024-05-10 18:00:23 +08:00
</view>
<view class="info_li">
2024-05-14 18:04:34 +08:00
已退款{{info.income.totalManageRefund}}
2024-05-10 18:00:23 +08:00
</view>
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
</view>
</view>
<view class="card">
<view class="tit">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uGs0Ayq797AurrBpU8xm" mode=""></image>
订单相关
</view>
<view class="info_box">
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.order.ridingOrder}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
新增行程订单
</view>
</view>
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.order.paidOrder}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
已支付订单
</view>
</view>
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.order.refundOrder}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
已退款订单
</view>
</view>
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.order.unpaidOrder}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
2024-05-14 18:04:34 +08:00
待支付订单
2024-05-10 18:00:23 +08:00
</view>
</view>
</view>
</view>
<view class="lines"></view>
<view class="card">
<view class="tit">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uBgz6OZvl3KHGGGJ16vy" mode=""></image>
车辆相关
</view>
<view class="info_box">
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.device.inOperationDevice}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
运营中车辆
</view>
</view>
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.device.inOrderDevice}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
有订单车辆
</view>
</view>
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.device.noOrderDevice}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
无订单车辆
</view>
</view>
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
</view>
</view>
<view class="lines"></view>
<view class="card">
<view class="tit">
<image src="https://lxnapi.ccttiot.com/bike/img/static/uCpE3kS6X0uD9q6pWzUu" mode=""></image>
用户相关
</view>
<view class="info_box">
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.user.totalUser}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
用户总数
</view>
</view>
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.user.newUser}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
新增用户
</view>
</view>
<view class="one_cont">
<view class="text">
2024-05-14 18:04:34 +08:00
{{info.user.leaseUser}}
2024-05-10 18:00:23 +08:00
</view>
<view class="text">
租赁用户
</view>
</view>
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
</view>
</view>
<u-picker mode="time" v-model="time1" :params="params" @confirm="confirm1"
2024-05-14 18:04:34 +08:00
:default-time='firsTime'></u-picker>
2024-05-10 18:00:23 +08:00
<u-picker mode="time" v-model="time2" :params="params" @confirm="confirm2"
2024-05-14 18:04:34 +08:00
:default-time='lasTime'></u-picker>
2024-05-10 18:00:23 +08:00
</view>
</template>
<script>
export default {
data() {
return {
bgc: {
backgroundColor: "#fff",
},
time1: false,
time2: false,
2024-05-14 18:04:34 +08:00
lasTime: '',
firsTime: '',
2024-05-10 18:00:23 +08:00
params: {
year: true,
month: true,
day: true,
hour: false,
minute: false,
second: false
},
2024-05-14 18:04:34 +08:00
cutidx: 0,
info:{}
2024-05-10 18:00:23 +08:00
}
},
2024-05-14 18:04:34 +08:00
onLoad() {
let today = new Date();
// 获取七天前的日期
// 格式化日期为 yyyy-MM-dd
this.firsTime = this.formatDate(today);
this.lasTime = this.formatDate(today);
this.operatingData()
},
methods:{
changeTime(num) {
if (num == 0) {
this.cutidx = num;
let today = new Date();
this.firsTime = this.formatDate(today);
this.lasTime = this.formatDate(today);
this.operatingData()
} else if (num == 1) {
this.cutidx = num;
let yesterday = new Date();
yesterday.setDate(yesterday.getDate() - 1);
this.firsTime = this.formatDate(yesterday);
this.lasTime = this.formatDate(new Date());
this.operatingData()
} else if (num == 2) {
this.cutidx = num;
let today = new Date();
let firstDayOfMonth = new Date(today.getFullYear(), today.getMonth(), 1);
this.firsTime = this.formatDate(firstDayOfMonth);
this.lasTime = this.formatDate(new Date());
this.operatingData()
} else if (num == 3) {
this.cutidx = num;
let today = new Date();
let firstDayOfLastMonth = new Date(today.getFullYear(), today.getMonth() - 1, 1);
let lastDayOfLastMonth = new Date(today.getFullYear(), today.getMonth(), 0);
this.firsTime = this.formatDate(firstDayOfLastMonth);
this.lasTime = this.formatDate(lastDayOfLastMonth);
this.operatingData()
}
},
formatDate(date) {
let year = date.getFullYear();
let month = String(date.getMonth() + 1).padStart(2, '0');
let day = String(date.getDate()).padStart(2, '0');
return `${year}-${month}-${day}`;
},
operatingData() {
let data = {
timeStart: this.firsTime,
timeEnd: this.lasTime,
}
this.$u.get('/appVerify/operatingData', data).then((res) => {
if (res.code === 200) {
// 处理接口返回的数据,将边界数据转换为地图组件需要的折线结构
this.info=res.data
}
}).catch(error => {
console.error("Error fetching area data:", error);
});
},
2024-05-10 18:00:23 +08:00
confirm1(e) {
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
this.firsTime = e.year + '-' + e.month + '-' + e.day
2024-05-14 18:04:34 +08:00
this.cutidx=-1
2024-05-10 18:00:23 +08:00
},
confirm2(e) {
this.lasTime = e.year + '-' + e.month + '-' + e.day
2024-05-14 18:04:34 +08:00
this.cutidx=-1
2024-05-10 18:00:23 +08:00
},
}
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
}
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
</script>
<style lang="scss">
page {
background-color: #fff;
}
.page {
width: 750rpx;
2024-05-14 18:04:34 +08:00
.lines {
2024-05-10 18:00:23 +08:00
width: 748rpx;
height: 22rpx;
background: #F6F6F6;
border-radius: 0rpx 0rpx 0rpx 0rpx;
}
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
.cont_box {
padding: 14rpx 30rpx;
width: 750rpx;
background: #F6F6F6;
border-radius: 0rpx 0rpx 0rpx 0rpx;
.cont_info {
margin-top: 8rpx;
display: flex;
flex-wrap: nowrap;
.info_li {
width: 50%;
font-weight: 400;
font-size: 28rpx;
color: #3D3D3D;
}
}
}
2024-05-14 18:04:34 +08:00
.card {
2024-05-10 18:00:23 +08:00
padding: 30rpx 30rpx;
background: #FFFFFF;
// box-shadow: 0rpx 4rpx 22rpx 0rpx rgba(0, 0, 0, 0.2);
width: 750rpx;
// border-radius: 40rpx 40rpx 0 0;
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
.tit {
display: flex;
flex-wrap: nowrap;
align-items: center;
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
image {
margin-right: 18rpx;
width: 38rpx;
height: 38rpx;
}
2024-05-14 18:04:34 +08:00
2024-05-10 18:00:23 +08:00
font-weight: 500;
font-size: 32rpx;
color: #3D3D3D;
}
2024-05-14 18:04:34 +08:00
.info_box {
2024-05-10 18:00:23 +08:00
display: flex;
flex-wrap: nowrap;
2024-05-14 18:04:34 +08:00
.one_cont {
2024-05-10 18:00:23 +08:00
display: flex;
flex-wrap: wrap;
2024-05-14 18:04:34 +08:00
.text {
2024-05-10 18:00:23 +08:00
margin-top: 12rpx;
text-align: center;
width: 170rpx;
}
}
}
}
.top_card {
padding: 30rpx 30rpx;
background: #FFFFFF;
box-shadow: 0rpx 4rpx 22rpx 0rpx rgba(0, 0, 0, 0.2);
width: 750rpx;
border-radius: 40rpx 40rpx 0 0;
.info {
margin-top: 28rpx;
display: flex;
flex-wrap: nowrap;
align-items: center;
.info_li {
width: 50%;
}
}
.tit {
display: flex;
flex-wrap: nowrap;
align-items: center;
image {
margin-right: 18rpx;
width: 38rpx;
height: 38rpx;
}
font-weight: 500;
font-size: 32rpx;
color: #3D3D3D;
}
}
.data_box {
width: 672rpx;
margin: 36rpx auto;
display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: space-between;
.data_cont {
display: flex;
align-items: center;
justify-content: center;
width: 150rpx;
height: 60rpx;
background: #FFFFFF;
box-shadow: 0rpx 4rpx 22rpx 0rpx rgba(0, 0, 0, 0.07);
border-radius: 10rpx 10rpx 10rpx 10rpx;
font-weight: 400;
font-size: 32rpx;
color: #3D3D3D;
border: 2rpx solid #fff;
}
.act1 {
background: #E2F2FF;
box-shadow: 0rpx 4rpx 22rpx 0rpx rgba(0, 0, 0, 0.07);
color: #4C97E7;
border: 2rpx solid #4C97E7;
}
}
.top_box {
display: flex;
flex-wrap: nowrap;
align-items: center;
padding: 28rpx 30rpx;
margin: 20rpx auto;
width: 672rpx;
height: 100rpx;
background: #FFFFFF;
box-shadow: 0rpx 4rpx 22rpx 0rpx rgba(0, 0, 0, 0.07);
border-radius: 10rpx 10rpx 10rpx 10rpx;
.left_text {
width: 25%;
font-weight: 400;
font-size: 32rpx;
color: #3D3D3D;
}
.timebox {
width: 75%;
display: flex;
flex-wrap: nowrap;
align-items: center;
margin-left: 34rpx;
.left_time {
text-align: center;
margin-right: 6rpx;
height: 50rpx;
width: 45%;
border: 2rpx solid #ccc;
border-radius: 12rpx;
font-weight: 400;
font-size: 32rpx;
color: #979797;
}
.right_time {
text-align: center;
margin-left: 6rpx;
height: 50rpx;
width: 45%;
border: 2rpx solid #ccc;
border-radius: 12rpx;
font-weight: 400;
font-size: 32rpx;
color: #979797;
}
}
}
}
</style>