tearoom/page_shanghu/yunying.vue

790 lines
17 KiB
Vue
Raw Normal View History

2024-12-20 09:02:40 +08:00
<template>
2025-01-08 15:23:53 +08:00
<view class="page" >
2025-02-12 17:59:03 +08:00
<u-navbar :is-back="false" title="运营" :border-bottom="false" :background="bgc" title-color='#fff' @custom-back="btncustom" back-icon-color="#fff"
title-size='36' height='44' id="navbar">
</u-navbar>
<image src="https://api.ccttiot.com/smartmeter/img/static/uAtuf76AiYArdJHLSjhO" class="imgbj" mode=""></image>
<view class="box">
<view class="topding">
<view class="dawz" style="border-right: 1px solid #48893B;">
<view class="shuwz">
{{tjobj.todayIncome == null ? '0.00' : tjobj.todayIncome}}
</view>
<view class="yuwz">
今日营业额/
</view>
</view>
<view class="dawz">
<view class="shuwz">
{{tjobj.todayOrderNum == null ? '0' : tjobj.todayOrderNum}}
</view>
<view class="yuwz">
今日订单/
</view>
</view>
</view>
<view class="shouru">
<view class="tongji">
<view class="one">
<view class="top">
{{tjobj.totalIncome == null ? '0.00' : tjobj.totalIncome}}
</view>
<view class="bot" style="font-size: 24rpx;">
总收入/
</view>
</view>
<view class="one">
<view class="top">
{{tjobj.totalOrderNum == null ? 0 : tjobj.totalOrderNum}}
</view>
<view class="bot" style="font-size: 24rpx;">
总订单/
</view>
</view>
<view class="one">
<view class="top">
{{tjobj.balance == null ? '0.00' : tjobj.balance}}
</view>
<view class="bot" style="font-size: 24rpx;">
账户余额
</view>
</view>
</view>
</view>
2025-01-04 18:05:32 +08:00
<view class="gailan">
<view class="name">
运营概览
</view>
<view class="top">
<view class="lt">
经营概况
</view>
<view class="rt">
2025-02-12 17:59:03 +08:00
<view @click="btntab(2)" :class="tabindex == 2 ? 'actives' : ''">
2025-01-04 18:05:32 +08:00
近30天
</view>
2025-02-12 17:59:03 +08:00
<view @click="btntab(1)" :class="tabindex == 1 ? 'actives' : ''">
近7天
2025-01-04 18:05:32 +08:00
</view>
</view>
</view>
<view class="zhixian">
2025-01-08 15:23:53 +08:00
<view class="echarts" style="padding: 20rpx;">
<uni-ec-canvas class="uni-ec-canvas" id="uni-ec-canvas" ref="canvas" canvas-id="uni-ec-canvas" :ec="ec"></uni-ec-canvas>
</view>
2025-01-04 18:05:32 +08:00
<view class="shuom">
<view class="">
2025-02-12 17:59:03 +08:00
<text style="background-color: #B1A5FF;"></text>
订单营收
2025-01-04 18:05:32 +08:00
</view>
<view class="">
2025-02-12 17:59:03 +08:00
<text style="background-color: #A9D2FF;"></text>
订单数
2025-01-04 18:05:32 +08:00
</view>
</view>
</view>
<view class="bijiao">
<view class="lt" style="border-right: 1px solid #D8D8D8;">
<view class="price">
2025-02-12 17:59:03 +08:00
{{zongprice}}
2025-01-04 18:05:32 +08:00
</view>
<view class="wz">
订单营收()
</view>
</view>
<view class="lt" style="padding-left: 34rpx;box-sizing: border-box;">
<view class="price">
2025-02-12 17:59:03 +08:00
{{zongnum}}
2025-01-04 18:05:32 +08:00
</view>
<view class="wz">
订单数()
</view>
</view>
</view>
</view>
<view class="shebei">
2025-02-12 17:59:03 +08:00
<view class="name" @click="shiyongflag = !shiyongflag">
当前运营情况 <image src="https://api.ccttiot.com/smartmeter/img/static/uZKXk9oAajNnkLiqnLQ9" mode=""></image>
<text v-if="shiyongflag">
使用中/总数
</text>
2025-01-04 18:05:32 +08:00
</view>
<view class="bd">
<view class="one">
<view class="">
2025-02-12 17:59:03 +08:00
房间
2025-01-04 18:05:32 +08:00
</view>
<view class="cu">
2025-02-12 17:59:03 +08:00
<text style="color: #48893B;">{{tjobj.inUseRoomNum == null ? 0 : tjobj.inUseRoomNum}}</text>/{{tjobj.totalRoomNum == null ? 0 : tjobj.totalRoomNum}}
2025-01-04 18:05:32 +08:00
</view>
</view>
<view class="one">
<view class="">
2025-02-12 17:59:03 +08:00
大厅设施
2025-01-04 18:05:32 +08:00
</view>
<view class="cu">
2025-02-12 17:59:03 +08:00
<text style="color: #48893B;">{{tjobj.inUseEquNum == null ? 0 : tjobj.inUseEquNum}}</text>/{{tjobj.totalEquNum == null ? 0 : tjobj.inUseEquNum}}
2025-01-04 18:05:32 +08:00
</view>
</view>
<view class="one" style="border: none;">
<view class="">
2025-02-12 17:59:03 +08:00
设备
2025-01-04 18:05:32 +08:00
</view>
<view class="cu">
2025-02-12 17:59:03 +08:00
<text style="color: #48893B;">{{tjobj.inUseDeviceNum == null ? 0 : tjobj.inUseDeviceNum}}</text>/{{tjobj.totalDeviceNum == null ? 0 : tjobj.totalDeviceNum}}
2025-01-04 18:05:32 +08:00
</view>
</view>
</view>
</view>
</view>
2025-02-12 17:59:03 +08:00
<tab-bars :indexs='1' style=""></tab-bars>
2024-12-20 09:02:40 +08:00
</view>
</template>
<script>
2025-01-08 15:23:53 +08:00
import * as echarts from '@/components/uni-ec-canvas/echarts.js'
let chart = null
2024-12-20 09:02:40 +08:00
export default {
data() {
return {
2025-01-08 15:23:53 +08:00
ec: {
lazyLoad: true
},
2025-02-12 17:59:03 +08:00
params: {
year: true,
month: true,
day: true,
hour: false,
minute: false,
second: false
},
recharge: 0,
2025-01-04 18:05:32 +08:00
bgc: {
backgroundColor: "",
},
2025-02-12 17:59:03 +08:00
show: false,
yeartime: {
year: '',
month: '',
day:''
},
yeartimes: {
year: '',
month: '',
day:''
},
timelist: '',
quantity: 0, //电量
chartData: [],
chartday: [],
loging: true,
deviceId: '',
userType: '',
totalRecharge: 0,
dateday:'',
timelists:'',
monthdui:'',
employId:'',
sceneValue:'',
kstime:'',
jstime:'',
num:'',
tabindex: 1,
smflag:false,
revenuelist:[], //营收
quantitylist:[], //订单数
shoururiqilist:[], //日期
tjobj:{},
formattedCurrentDate:'',
formattedThirtyDaysAgo:'',
zongprice:'',
zongnum:'',
userobj:{},
shiyongflag:false,
timeLimit:2
2024-12-20 09:02:40 +08:00
}
},
2025-01-08 15:23:53 +08:00
// 分享到好友(会话)
onShareAppMessage: function () {
return {
title: '创想物联',
path: '/pages/shouye/index'
}
},
// 分享到朋友圈
onShareTimeline: function () {
return {
title: '创想物联',
query: '',
path: '/pages/shouye/index'
}
},
onLoad(option) {
2025-02-12 17:59:03 +08:00
2025-01-04 18:05:32 +08:00
},
onShow() {
2025-02-12 17:59:03 +08:00
this.tabindex = 1
this.shoururiqilist =[]
this.revenuelist =[]
this.quantitylist = []
this.gettimes()
this.gettj()
2024-12-20 09:02:40 +08:00
},
methods: {
2025-02-12 17:59:03 +08:00
// 订单营收蓝色 订单数紫色
gettimes() {
this.$u.get('/appVerify/index').then((res) => {
if (res.code == 200) {
this.tjobj = res.data
}
2025-01-08 15:23:53 +08:00
})
},
2025-02-12 17:59:03 +08:00
// 统计图
gettj() {
this.$u.get(`/appVerify/getIndexInComeList?timeLimit=${this.tabindex}`).then((res) => {
2025-01-08 15:23:53 +08:00
if (res.code == 200) {
2025-02-12 17:59:03 +08:00
this.zongprice = res.data.totalIncome
this.zongnum = res.data.totalOrderNum
res.data.incomeVoList.reverse().forEach(item => {
this.shoururiqilist.push(item.day.slice(-2) + '日')
this.revenuelist.push(item.orderIncome)
this.quantitylist.push(item.orderNum)
})
console.log('营收',this.revenuelist);
console.log('订单',this.quantitylist);
this.$refs.canvas.init(this.initChart)
2025-01-08 15:23:53 +08:00
}
})
},
2025-02-12 17:59:03 +08:00
// 点击切换周还是月
btntab(num) {
this.tabindex = num
this.shoururiqilist =[]
this.revenuelist =[]
this.quantitylist = []
this.gettj()
},
2025-01-08 15:23:53 +08:00
generateWaveData(length) {
2025-02-12 17:59:03 +08:00
const data = []
for (let i = 0; i < length; i++) {
const y = Math.sin((i / (length - 1)) * Math.PI * 2) // 正弦函数生成波浪形状的y值
data.push((y + 1) * 50) // 映射到0-100的范围
}
return data
},
2025-01-08 15:23:53 +08:00
initChart(canvas, width, height, canvasDpr) {
let that = this
const option = {
grid: {
left: 35,
right: 0,
top: 10,
bottom: 20,
},
2025-01-04 18:05:32 +08:00
xAxis: {
type: 'category',
2025-01-08 15:23:53 +08:00
boundaryGap: false,
2025-01-04 18:05:32 +08:00
axisLine: {
2025-01-08 15:23:53 +08:00
show: false,
2025-01-04 18:05:32 +08:00
},
axisTick: {
show: false,
},
2025-01-08 15:23:53 +08:00
axisLabel: {
show: true,
color: '#808080',
fontSize: 11,
rotate: 0,
},
splitLine: {
show: false,
},
2025-02-12 17:59:03 +08:00
data: that.shoururiqilist,
2025-01-04 18:05:32 +08:00
},
yAxis: {
2025-01-08 15:23:53 +08:00
show: true,
axisLine: {
show: false,
},
axisTick: {
show: false,
},
2025-01-04 18:05:32 +08:00
axisLabel: {
2025-01-08 15:23:53 +08:00
show: true,
color: '#808080',
fontSize: 11,
formatter: function(value) {
// 保留两位小数没有小数时显示00
return value
},
2025-01-04 18:05:32 +08:00
},
splitLine: {
2025-01-08 15:23:53 +08:00
show: false,
},
2025-01-04 18:05:32 +08:00
},
series: [{
2025-01-08 15:23:53 +08:00
type: 'line',
smooth: 0.6,
symbol: 'none',
lineStyle: {
color: '#E0DBFF',
2025-02-12 17:59:03 +08:00
width: 2,
2025-01-08 15:23:53 +08:00
},
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#ECE8FF'
}, ]),
},
},
data: that.chartData,
},{
type: 'line',
smooth: 0.6,
symbol: 'none',
lineStyle: {
color: '#A9D2FF',
2025-02-12 17:59:03 +08:00
width: 2,
2025-01-08 15:23:53 +08:00
},
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#C3E0FF'
}, ]),
},
2025-01-04 18:05:32 +08:00
},
2025-01-08 15:23:53 +08:00
data: that.chartData,
}],
2025-02-12 17:59:03 +08:00
tooltip: {
trigger: 'axis',
triggerOn: 'click',
formatter: '时间:{b} \n营收:{c}元\n订单:{c1}单'
},
2025-01-04 18:05:32 +08:00
}
2025-01-08 15:23:53 +08:00
chart = echarts.init(canvas, null, {
width: width,
height: height,
devicePixelRatio: canvasDpr
2025-01-04 18:05:32 +08:00
})
2025-02-12 17:59:03 +08:00
option.series[0].data = that.revenuelist
option.series[1].data = that.quantitylist
2025-01-08 15:23:53 +08:00
canvas.setChart(chart)
chart.setOption(option)
return chart
},
2024-12-20 09:02:40 +08:00
}
}
</script>
<style lang="scss">
2025-01-08 15:23:53 +08:00
/deep/ .u-title{
padding-bottom: 20rpx;
2025-01-04 18:05:32 +08:00
}
2025-01-08 15:23:53 +08:00
/deep/ .u-icon__icon{
padding-bottom: 20rpx;
2025-01-04 18:05:32 +08:00
}
2025-02-12 17:59:03 +08:00
2025-01-08 15:23:53 +08:00
.uni-ec-canvas {
2025-01-04 18:05:32 +08:00
width: 100%;
2025-01-08 15:23:53 +08:00
height: 320rpx;
display: block;
margin-top: 30rpx;
}
.btnxz {
padding: 0 20rpx;
box-sizing: border-box;
font-size: 28rpx;
font-family: Source Han Sans, Source Han Sans;
font-weight: 400;
color: #FFFFFF;
2025-01-04 18:05:32 +08:00
}
2025-01-08 15:23:53 +08:00
page {
2025-02-12 17:59:03 +08:00
// background-color:#48893B;
2025-01-08 15:23:53 +08:00
}
.actives {
background: #fff !important;
box-shadow: 0rpx 0rpx 4rpx 0rpx rgba(0, 0, 0, 0.15) !important;
}
2025-02-12 17:59:03 +08:00
.topding{
padding: 0 112rpx;
box-sizing: border-box;
display: flex;
.dawz{
width: 50%;
text-align: center;
.shuwz{
font-weight: 600;
font-size: 60rpx;
color: #48893B;
}
.yuwz{
font-size: 28rpx;
color: #7C7C7C;
margin-top: 10rpx;
}
}
}
2025-01-08 15:23:53 +08:00
.box {
width: 100%;
height: 77vh;
overflow: scroll;
}
2025-02-12 17:59:03 +08:00
.imgbj{
width: 100%;
height: 100vh;
position: fixed;
top: 0;
left: 0;
z-index: -1;
}
2025-01-08 15:23:53 +08:00
.shebei{
width: 680rpx;
margin: auto;
margin-top: 34rpx;
.name{
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
display: flex;
align-items: center;
2025-02-12 17:59:03 +08:00
height: 54rpx;
2025-01-08 15:23:53 +08:00
text{
width: 184rpx;
height: 54rpx;
background: #E8E8E8;
border-radius: 8rpx 8rpx 8rpx 8rpx;
line-height: 54rpx;
text-align: center;
font-size: 26rpx;
color: #3D3D3D;
margin-left: 20rpx;
}
image{
margin-left: 10rpx;
width: 30rpx;
height: 30rpx;
}
}
.bd{
width: 680rpx;
height: 172rpx;
background: #FFFFFF;
box-shadow: 0rpx 8rpx 40rpx 0rpx rgba(72,137,59,0.1);
border-radius: 24rpx 24rpx 24rpx 24rpx;
display: flex;
justify-content: space-between;
align-items: center;
text-align: center;
margin-top: 20rpx;
.one{
border-right: 1px solid #C7C7C7;
width: 33%;
view{
font-size: 24rpx;
color: #3D3D3D;
}
.cu{
font-weight: 600;
font-size: 40rpx;
2025-02-12 17:59:03 +08:00
color: #3D3D3D;
2025-01-08 15:23:53 +08:00
margin-top: 8rpx;
text{
2025-02-12 17:59:03 +08:00
color: #48893B;
2025-01-08 15:23:53 +08:00
}
}
}
}
}
.gailan {
width: 680rpx;
max-height: 1868rpx;
background: #FFFFFF;
box-shadow: 0rpx 8rpx 40rpx 0rpx rgba(72, 137, 59, 0.1);
border-radius: 24rpx 24rpx 24rpx 24rpx;
margin: auto;
margin-top: 34rpx;
padding: 0 30rpx;
padding-top: 38rpx;
padding-bottom: 24rpx;
box-sizing: border-box;
.bijiao {
width: 636rpx;
max-height: 204rpx;
background: #DEF1DA;
border-radius: 24rpx 24rpx 24rpx 24rpx;
display: flex;
padding: 24rpx 40rpx;
box-sizing: border-box;
margin-top: 34rpx;
.lt {
width: 50%;
.price {
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
}
.wz {
font-size: 24rpx;
color: #3D3D3D;
display: flex;
align-items: center;
margin-top: 10rpx;
image {
width: 32rpx;
height: 32rpx;
margin-left: 10rpx;
}
}
}
}
.zhixian {
.shuom {
margin-top: 26rpx;
display: flex;
align-items: center;
padding: 0 76rpx;
box-sizing: border-box;
justify-content: space-between;
view {
font-size: 24rpx;
color: #3D3D3D;
2025-02-12 17:59:03 +08:00
text{
display: inline-block;
width: 76rpx;
height: 18rpx;
margin-right: 10rpx;
}
// image {
// width: 76rpx;
// height: 18rpx;
// margin-right: 10rpx;
// }
2025-01-08 15:23:53 +08:00
}
}
}
.top {
display: flex;
justify-content: space-between;
height: 66rpx;
line-height: 66rpx;
align-items: center;
margin-top: 24rpx;
.lt {
border-left: 10rpx solid #48893B;
font-weight: 600;
font-size: 32rpx;
color: #3D3D3D;
height: 50rpx;
line-height: 50rpx;
padding-left: 16rpx;
box-sizing: border-box;
}
.rt {
width: 236rpx;
height: 66rpx;
background: #F6F6F6;
border-radius: 8rpx 8rpx 8rpx 8rpx;
display: flex;
justify-content: space-between;
align-items: center;
view {
width: 116rpx;
height: 58rpx;
border-radius: 8rpx 8rpx 8rpx 8rpx;
text-align: center;
line-height: 58rpx;
}
}
}
.name {
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
text-align: center;
width: 100%;
}
}
.shouru {
width: 680rpx;
max-height: 838rpx;
background: #FFFFFF;
box-shadow: 0rpx 8rpx 40rpx 0rpx rgba(72, 137, 59, 0.1);
border-radius: 24rpx 24rpx 24rpx 24rpx;
margin: auto;
margin-top: 24rpx;
padding: 26rpx 32rpx;
box-sizing: border-box;
.tongji {
display: flex;
text-align: center;
margin-top: 20rpx;
box-sizing: border-box;
justify-content: space-between;
padding:0 50rpx;
.one {
.top {
font-weight: 600;
font-size: 36rpx;
color: #48893B;
margin-bottom: 12rpx;
}
.bot {
font-size: 28rpx;
color: #7C7C7C;
margin-top: 12rpx;
}
}
}
.name {
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
}
}
.page {
// padding: 0 59rpx;
.titles {
padding-left: 32rpx;
font-size: 40rpx;
color: #fff;
padding-top: 104rpx;
height: 200rpx;
text {
padding-left: 33%;
}
}
.name{
2025-01-04 18:05:32 +08:00
font-size: 36rpx;
color: #3D3D3D;
2025-01-08 15:23:53 +08:00
margin-top: 20rpx;
2025-01-04 18:05:32 +08:00
}
2025-01-08 15:23:53 +08:00
.gongneng{
margin-top: 40rpx;
width: 632rpx;
height: 150rpx;
2025-01-04 18:05:32 +08:00
background: #FFFFFF;
2025-01-08 15:23:53 +08:00
box-shadow: 0rpx 16rpx 40rpx 0rpx rgba(42,130,228,0.1);
2025-01-04 18:05:32 +08:00
border-radius: 24rpx 24rpx 24rpx 24rpx;
display: flex;
justify-content: space-between;
2025-01-08 15:23:53 +08:00
padding: 26rpx 50rpx;
box-sizing: border-box;
image{
width: 96rpx;
height: 102rpx;
2025-01-04 18:05:32 +08:00
}
}
2025-01-08 15:23:53 +08:00
.title {
margin-top: 120rpx;
font-size: 48rpx;
font-weight: 400;
letter-spacing: 0rpx;
color: rgba(38, 43, 55, 1);
}
2025-01-04 18:05:32 +08:00
2025-01-08 15:23:53 +08:00
.card {
padding-top: 32rpx;
margin-top: 10rpx;
width: 632rpx;
height: 540rpx;
background: #48893B;
box-shadow: 0rpx 16rpx 40rpx 0rpx rgba(42, 130, 228, 0.1);
opacity: 1;
border-radius: 40rpx;
2025-01-04 18:05:32 +08:00
2025-01-08 15:23:53 +08:00
.month {
2025-01-04 18:05:32 +08:00
2025-01-08 15:23:53 +08:00
margin-left: 22rpx;
font-size: 28rpx;
font-family: Source Han Sans, Source Han Sans;
font-weight: 400;
color: #FFFFFF;
2025-01-04 18:05:32 +08:00
}
2025-01-08 15:23:53 +08:00
.tit {
margin-top: 18rpx;
margin-left: 22rpx;
font-size: 20rpx;
font-family: HarmonyOS Sans SC, HarmonyOS Sans SC;
font-weight: 400;
color: #FFFFFF;
2024-12-20 09:02:40 +08:00
2025-01-04 18:05:32 +08:00
}
2025-01-08 15:23:53 +08:00
.txt {
margin-top: 2rpx;
margin-left: 22rpx;
font-size: 36rpx;
font-family: HarmonyOS Sans SC, HarmonyOS Sans SC;
font-weight: 700;
color: #FFFFFF;
}
2025-01-04 18:05:32 +08:00
2025-01-08 15:23:53 +08:00
.echarts {
margin-left: 22rpx;
margin-top: 60rpx;
width: 588rpx;
height: 320rpx;
2025-01-04 18:05:32 +08:00
}
2025-01-08 15:23:53 +08:00
}
2025-01-04 18:05:32 +08:00
2025-01-08 15:23:53 +08:00
.list {
margin-top: 16rpx;
height: 630rpx;
overflow: auto;
.card_list {
width: 632rpx;
height: 88rpx;
background: #FFFFFF;
opacity: 1;
border-radius: 30rpx;
2025-01-04 18:05:32 +08:00
display: flex;
2025-01-08 15:23:53 +08:00
flex-wrap: nowrap;
2025-01-04 18:05:32 +08:00
justify-content: space-between;
2025-01-08 15:23:53 +08:00
margin-top: 16rpx;
2025-01-04 18:05:32 +08:00
align-items: center;
2025-01-08 15:23:53 +08:00
.left {
margin-left: 52rpx;
font-size: 28rpx;
font-family: HarmonyOS Sans SC, HarmonyOS Sans SC;
font-weight: 400;
color: #808080;
2025-01-04 18:05:32 +08:00
}
2025-01-08 15:23:53 +08:00
.right {
margin-right: 20rpx;
2025-01-04 18:05:32 +08:00
font-size: 28rpx;
2025-01-08 15:23:53 +08:00
font-family: HarmonyOS Sans SC, HarmonyOS Sans SC;
font-weight: 400;
color: #808080;
2025-01-04 18:05:32 +08:00
}
}
}
}
2024-12-20 09:02:40 +08:00
</style>