SmartBeehive/pages/index/index.vue

877 lines
19 KiB
Vue
Raw Normal View History

2023-11-27 09:57:03 +08:00
<template>
2024-01-27 16:37:52 +08:00
<view class="page">
2024-06-11 18:02:55 +08:00
<view class="backImg">
<image src="https://api.ccttiot.com/smartmeter/img/static/utkroSMjT09nmCYaA7FT" mode=""></image>
</view>
2024-07-01 10:06:13 +08:00
<view class="tipbox" v-if="haveApiary">
2024-06-11 18:02:55 +08:00
<view class="tip_cont">
<image src="https://api.ccttiot.com/smartmeter/img/static/uKW514Tl8TVUiaJW2ygl" mode=""></image>
2024-04-27 17:20:50 +08:00
<view class="txt">
2024-07-03 18:03:01 +08:00
蜂箱数量:{{tjobj.beehiveCount == undefined ? '' : tjobj.beehiveCount}}
2024-04-27 17:20:50 +08:00
</view>
</view>
2024-06-11 18:02:55 +08:00
<view class="tip_cont" style="margin-top: 48rpx;">
<image src="https://api.ccttiot.com/smartmeter/img/static/uBEd8suIZ2vdqOGI8rP6" mode=""></image>
<view class="txt">
2024-07-03 18:03:01 +08:00
蜂场数量:{{tjobj.apiaryCount == undefined ? '' : tjobj.apiaryCount}}
2024-04-27 17:20:50 +08:00
</view>
2024-06-11 18:02:55 +08:00
</view>
<view class="tip_cont" style="margin-top: 48rpx;">
<image src="https://api.ccttiot.com/smartmeter/img/static/ufgkE5w8AND4eLZD94RR" mode=""></image>
<view class="txt">
2024-07-03 18:03:01 +08:00
预警数量:{{tjobj.warnCount == undefined ? '' : tjobj.warnCount}}
2024-04-27 17:20:50 +08:00
</view>
</view>
</view>
2024-07-04 18:02:46 +08:00
<view class="no_cont" @click="addApiary()" v-if="haveApiary == false">
2024-07-03 18:03:01 +08:00
<view class="img" >
2024-07-01 10:06:13 +08:00
<image src="https://api.ccttiot.com/smartmeter/img/static/uUZ3MF84e3bKgwAei8Rz" mode=""></image>
</view>
<view class="txt">
当前还没有添加蜂场哦,点击跳转添加蜂场
</view>
</view>
2024-06-11 18:02:55 +08:00
<u-loadmore :status="status" :icon-type="iconType" :load-text="loadText" v-if="isLoading" />
2024-07-01 10:06:13 +08:00
<view class="warp_box" v-if="haveApiary">
2024-06-11 18:02:55 +08:00
<swiper class="swiper" :style="{ height: swiperHeight + 'rpx' }" :current='curtitidx'
previous-margin='50rpx' next-margin='50rpx' :circular='true' @change="swiperchange">
2024-07-01 10:06:13 +08:00
<swiper-item>
2024-06-11 18:02:55 +08:00
<view class="swiper-item">
<view class="card_box">
<view class="card">
2024-07-01 10:06:13 +08:00
<view class="card_top">
<view class="top_left">
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
<image src="https://api.ccttiot.com/smartmeter/img/static/uhsU6Y1K35jxA4aRauzy"
mode=""></image>
2024-07-03 18:03:01 +08:00
近7天蜜蜂总出勤变化
2024-07-01 10:06:13 +08:00
</view>
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
<view class="top_right">
<view style="width: 1rpx;">
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
</view>
<view class="txt">
<view class="iconfont icon-xiangyou1"></view>
</view>
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
</view>
</view>
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
<view class="echarts">
<uni-ec-canvas class="uni-ec-canvas" id="uni-ec-canvas" ref="canvas4"
canvas-id="uni-ec-canvas" :ec="ec">
</uni-ec-canvas>
</view>
2024-01-27 16:37:52 +08:00
</view>
2024-07-01 10:06:13 +08:00
</view>
</view>
</swiper-item>
<swiper-item>
<view class="swiper-item">
<view class="card_box">
<view class="card">
<view class="card_top">
<view class="top_left">
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
<image src="https://api.ccttiot.com/smartmeter/img/static/uk7CvwzeU0ukxvS9cBtD"
mode=""></image>
2024-07-03 18:03:01 +08:00
近7天蜂箱总重量变化
2024-07-01 10:06:13 +08:00
</view>
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
<view class="top_right">
<view style="width: 1rpx;">
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
</view>
<view class="txt">
<view class="iconfont icon-xiangyou1"></view>
</view>
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
</view>
</view>
<view class="echarts">
<uni-ec-canvas class="uni-ec-canvas" id="uni-ec-canvas" ref="canvas3"
canvas-id="uni-ec-canvas" :ec="ec">
</uni-ec-canvas>
</view>
</view>
2024-01-27 16:37:52 +08:00
</view>
</view>
2024-06-11 18:02:55 +08:00
</swiper-item>
</swiper>
</view>
2024-07-01 10:06:13 +08:00
<view class="info_cont" v-if="haveApiary">
2024-06-11 18:02:55 +08:00
<view class="cont">
<view class="cont_top">
电量不足
2024-01-27 16:37:52 +08:00
</view>
2024-06-11 18:02:55 +08:00
<view class="cont_bot">
2024-07-03 18:03:01 +08:00
{{yjobj[4].count == undefined ? '' : yjobj[4].count}}
2024-01-27 16:37:52 +08:00
</view>
</view>
2024-06-11 18:02:55 +08:00
<view class="cont">
<view class="cont_top">
2024-07-01 10:06:13 +08:00
出勤异常
2024-06-11 18:02:55 +08:00
</view>
<view class="cont_bot">
2024-07-03 18:03:01 +08:00
{{yjobj[5].count == undefined ? '' : yjobj[5].count}}
2024-01-27 16:37:52 +08:00
</view>
</view>
2024-06-11 18:02:55 +08:00
<view class="cont">
<view class="cont_top">
2024-07-01 10:06:13 +08:00
重量异常
2024-03-13 10:54:22 +08:00
</view>
2024-06-11 18:02:55 +08:00
<view class="cont_bot">
2024-07-03 18:03:01 +08:00
{{yjobj[3].count == undefined ? '' : yjobj[3].count}}
2024-04-27 17:20:50 +08:00
</view>
</view>
2024-06-11 18:02:55 +08:00
<view class="cont">
<view class="cont_top">
2024-07-01 10:06:13 +08:00
温度异常
2024-04-27 17:20:50 +08:00
</view>
2024-06-11 18:02:55 +08:00
<view class="cont_bot">
2024-07-03 18:03:01 +08:00
{{yjobj[1].count == undefined ? '' : yjobj[1].count}}
2024-03-13 10:54:22 +08:00
</view>
</view>
2024-06-11 18:02:55 +08:00
<view class="cont">
<view class="cont_top">
2024-07-01 10:06:13 +08:00
湿度异常
2024-06-11 18:02:55 +08:00
</view>
<view class="cont_bot">
2024-07-03 18:03:01 +08:00
{{yjobj[2].count == undefined ? '' : yjobj[2].count}}
2024-03-13 10:54:22 +08:00
</view>
</view>
2024-06-11 18:02:55 +08:00
<view class="cont">
<view class="cont_top">
2024-07-01 10:06:13 +08:00
声音异常
2024-06-11 18:02:55 +08:00
</view>
<view class="cont_bot">
2024-07-03 18:03:01 +08:00
{{yjobj[6].count == undefined ? '' : yjobj[6].count}}
2024-06-11 18:02:55 +08:00
</view>
2024-03-13 10:54:22 +08:00
</view>
</view>
2024-07-03 18:03:01 +08:00
<view v-if="logoflag" class="" style="text-align: right;padding-right: 30rpx;color: #FFCC25;">
<text style="border-bottom: 1px solid #FFCC25;" @click="btnlogo">暂未登录去登录</text>
</view>
<tab-bar :indexs='0'></tab-bar>
2023-11-27 09:57:03 +08:00
</view>
</template>
2024-06-11 18:02:55 +08:00
2023-11-27 09:57:03 +08:00
<script>
2024-05-21 18:01:46 +08:00
import uniEcCanvas from '@/components/uni-ec-canvas/uni-ec-canvas.vue'
import * as echarts from '@/components/uni-ec-canvas/echarts'
let chart = null
2023-11-27 09:57:03 +08:00
export default {
2024-05-21 18:01:46 +08:00
components: {
uniEcCanvas
},
2023-11-27 09:57:03 +08:00
data() {
return {
2024-07-03 18:03:01 +08:00
logoflag: false,
2024-05-21 18:01:46 +08:00
ec: {
lazyLoad: true
},
2024-01-27 16:37:52 +08:00
bgc: {
backgroundColor: "#F7FAFE",
2024-03-25 19:46:07 +08:00
2024-01-27 16:37:52 +08:00
},
2024-05-21 18:01:46 +08:00
iconType: 'flower',
status: 'loadmore',
loadText: {
loadmore: '轻轻上拉',
loading: '努力加载中',
nomore: '实在没有了'
},
2024-07-01 10:06:13 +08:00
curtitidx: 0,
2024-06-11 18:02:55 +08:00
swiperHeight: 426,
activeSwiperHeight: 500, // 激活的swiper高度
2024-07-01 10:06:13 +08:00
swiperItems: [1, 2, ], // Placeholder for swiper items
2024-07-03 18:03:01 +08:00
numdata: [],
numdatas: [],
haveApiary: true,
2024-07-02 18:07:56 +08:00
yeartime: {
year: '',
month: '',
2024-07-03 18:03:01 +08:00
day: ''
2024-07-02 18:07:56 +08:00
},
yeartimes: {
year: '',
month: '',
2024-07-03 18:03:01 +08:00
day: ''
2024-07-02 18:07:56 +08:00
},
2024-07-03 18:03:01 +08:00
chartData3: [],
chartData4: [],
tjobj: {},
yjobj: []
2024-03-13 10:54:22 +08:00
}
},
2024-05-21 18:01:46 +08:00
2024-06-11 18:02:55 +08:00
onShow() {
2024-07-05 14:07:51 +08:00
this.getuserinfo()
2024-07-02 18:07:56 +08:00
setTimeout(() => {
2024-07-05 14:07:51 +08:00
2024-07-03 18:03:01 +08:00
}, 1500);
2024-07-02 18:07:56 +08:00
const now = new Date();
const previousDay = new Date(now)
this.yeartime.year = now.getFullYear()
this.yeartime.month = String(previousDay.getMonth() + 1).padStart(2, '0')
this.yeartime.day = String(now.getDate()).padStart(2, '0')
2024-07-03 18:03:01 +08:00
2024-07-02 18:07:56 +08:00
previousDay.setDate(now.getDate() - 7)
this.yeartimes.year = previousDay.getFullYear()
this.yeartimes.month = String(previousDay.getMonth() + 1).padStart(2, '0')
this.yeartimes.day = String(previousDay.getDate()).padStart(2, '0')
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
},
2024-07-03 18:03:01 +08:00
onPullDownRefresh() {},
2024-04-27 17:20:50 +08:00
2024-06-11 18:02:55 +08:00
methods: {
2024-07-03 18:03:01 +08:00
// 点击跳转登录页
btnlogo(){
uni.navigateTo({
url:'/pages/login/login'
})
},
// 未登录调静默获取token
jmlogin() {
let taht = this
wx.login({
success(res) {
if (res.code) {
console.log(res.code);
let data = {
loginCode: res.code,
deptId: 100
}
taht.$u.post('/app/auth/wxLogin', data).then(res => {
if (res.code == 200) {
taht.logoflag = false
uni.setStorageSync('token', res.token);
taht.getchartData3()
taht.getchartData4()
taht.gettj()
taht.getyj()
}else if(res.code == 10003){
taht.logoflag = true
}
// console.log(res,10003);
})
}
},
})
},
2024-07-05 14:07:51 +08:00
getuserinfo(){
this.$u.get(`/app/user/userInfo`).then(res => {
if (res.code == 200) {
if(res.data.type==1){
this.ishave()
this.getchartData3()
this.getchartData4()
this.gettj()
this.getyj()
}else{
// uni.navigateTo({
// url:
// })
}
}else{
setTimeout(()=>{
let code= uni.getStorageSync('code');
console.log(code,'codecodecode');
if(code==200){
this.getuserinfo()
}else{
this.logoflag = true
}
},500)
}
})
},
2024-07-02 18:07:56 +08:00
// 统计
2024-07-03 18:03:01 +08:00
gettj() {
2024-07-02 18:07:56 +08:00
this.$u.get(`/farmer/report/statistic`).then(res => {
2024-07-03 18:03:01 +08:00
if (res.code == 200) {
2024-07-02 18:07:56 +08:00
this.tjobj = res.data
}
})
},
// 预警
2024-07-03 18:03:01 +08:00
getyj() {
2024-07-02 18:07:56 +08:00
this.$u.get(`/farmer/report/warnCount`).then(res => {
2024-07-03 18:03:01 +08:00
if (res.code == 200) {
2024-07-02 18:07:56 +08:00
this.yjobj = res.data
}
})
},
2024-07-03 18:03:01 +08:00
2024-07-02 18:07:56 +08:00
// 重量图表
2024-07-03 18:03:01 +08:00
getchartData3() {
let time = this.yeartime.year + '-' + this.yeartime.month + '-' + this.yeartime.day
2024-07-02 18:07:56 +08:00
let times = this.yeartimes.year + '-' + this.yeartimes.month + '-' + this.yeartimes.day
this.$u.get(`/farmer/report/weightDay?dateRange=${times},${time}&beehiveId=${''}`).then(res => {
2024-07-03 18:03:01 +08:00
if (res.code == 200) {
2024-07-02 18:07:56 +08:00
this.chartData3 = res.data.map(item => item.value)
2024-07-05 14:07:51 +08:00
this.$refs.canvas3.init(this.initChart3)
2024-07-02 18:07:56 +08:00
}
})
},
// 出勤图表
2024-07-03 18:03:01 +08:00
getchartData4() {
let time = this.yeartime.year + '-' + this.yeartime.month + '-' + this.yeartime.day
2024-07-02 18:07:56 +08:00
let times = this.yeartimes.year + '-' + this.yeartimes.month + '-' + this.yeartimes.day
this.$u.get(`/farmer/report/ioCount?dateRange=${times},${time}&beehiveId=${''}`).then(res => {
2024-07-03 18:03:01 +08:00
if (res.code == 200) {
2024-07-02 18:07:56 +08:00
this.chartData4 = res.data.map(item => item.value)
2024-07-05 14:07:51 +08:00
this.$refs.canvas4.init(this.initChart4)
2024-07-02 18:07:56 +08:00
}
})
},
2024-07-03 18:03:01 +08:00
addApiary() {
2024-07-01 10:06:13 +08:00
uni.navigateTo({
2024-07-03 18:03:01 +08:00
url: '/pages/Apiary/AddApiary'
2024-07-01 10:06:13 +08:00
})
},
2024-07-03 18:03:01 +08:00
ishave() {
let data = {
pageNum: 1,
pageSize: 10
2024-07-01 10:06:13 +08:00
}
2024-07-03 18:03:01 +08:00
this.$u.get('/farm/apiary/list?', data).then((res) => {
2024-07-04 18:02:46 +08:00
if (res.code == 200) {
if (res.total >= 1) {
2024-07-05 11:32:33 +08:00
// this.getnum()
// this.getnums()
2024-07-04 18:02:46 +08:00
this.haveApiary = true
2024-07-03 18:03:01 +08:00
} else {
this.haveApiary = false
2024-07-01 10:06:13 +08:00
}
2024-07-04 18:02:46 +08:00
}
2024-07-03 18:03:01 +08:00
})
},
swiperchange(e) {
this.curtitidx = e.detail.current
// console.log(e, 'aaaa');
},
getnum() {
const currentDate = new Date();
// 获取前七天的日期
const sevenDaysAgoDate = new Date();
sevenDaysAgoDate.setDate(currentDate.getDate() - 7);
// 格式化日期为 'YYYY-MM-DD'
const formatDate = (date) => {
const year = date.getFullYear();
const month = (date.getMonth() + 1).toString().padStart(2, '0');
const day = date.getDate().toString().padStart(2, '0');
return `${year}-${month}-${day}`;
};
const currentDateString = formatDate(currentDate);
const sevenDaysAgoDateString = formatDate(sevenDaysAgoDate);
// 赋值给 data 中的 dateRange
let data = {
dateRange: `${sevenDaysAgoDateString},${currentDateString}`
};
this.$u.get('/farmer/report/ioCount?', data).then((res) => {
if (res.code === 200) {
this.numdata = res.data
this.$refs.canvas4.init(this.initChart4)
2024-07-01 10:06:13 +08:00
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
}
})
},
2024-07-03 18:03:01 +08:00
getnums() {
2024-07-01 10:06:13 +08:00
const currentDate = new Date();
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
// 获取前七天的日期
const sevenDaysAgoDate = new Date();
sevenDaysAgoDate.setDate(currentDate.getDate() - 7);
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
// 格式化日期为 'YYYY-MM-DD'
const formatDate = (date) => {
2024-07-03 18:03:01 +08:00
const year = date.getFullYear();
const month = (date.getMonth() + 1).toString().padStart(2, '0');
const day = date.getDate().toString().padStart(2, '0');
return `${year}-${month}-${day}`;
2024-07-01 10:06:13 +08:00
};
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
const currentDateString = formatDate(currentDate);
const sevenDaysAgoDateString = formatDate(sevenDaysAgoDate);
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
// 赋值给 data 中的 dateRange
let data = {
2024-07-03 18:03:01 +08:00
dateRange: `${sevenDaysAgoDateString},${currentDateString}`
2024-07-01 10:06:13 +08:00
};
2024-07-03 18:03:01 +08:00
this.$u.get('/farmer/report/weightDay?', data).then((res) => {
2024-07-01 10:06:13 +08:00
if (res.code === 200) {
2024-07-03 18:03:01 +08:00
this.numdatas = res.data
this.$refs.canvas3.init(this.initChart3)
2024-07-01 10:06:13 +08:00
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
});
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
}
})
},
// 进出量
initChart4(canvas, width, height, canvasDpr) {
let that = this
const option = {
grid: {
left: '4%',
right: '4%',
bottom: '3%',
top: '4%',
containLabel: true
},
xAxis: {
show: true,
type: 'category',
boundaryGap: false,
axisLine: {
show: false // 隐藏X轴线
},
axisTick: {
show: false // 隐藏X轴刻度
},
axisLabel: {
show: false // 隐藏X轴标签
},
axisLabel: {
show: true,
color: '#ccc',
fontSize: 11,
rotate: 0,
},
splitLine: {
show: false,
},
// data: that.chartday,
},
yAxis: {
show: true,
axisLine: {
show: false,
},
axisTick: {
show: false,
},
axisLabel: {
show: true,
color: '#ccc',
fontSize: 11,
formatter: function(value) {
// 保留两位小数没有小数时显示00
return value + '只'
},
},
splitLine: {
show: true, // 显示X轴网格线
lineStyle: {
type: 'dashed', // 设置网格线为虚线
color: '#ccc', // 可以设置虚线的颜色
width: 1 // 可以设置虚线的宽度
}
}
},
visualMap: {
type: 'piecewise',
show: false,
dimension: 0,
seriesIndex: 0,
pieces: [{
gt: 1,
lt: 3,
color: 'RGBA(255, 241, 201, 1)',
},
{
gt: 5,
lt: 7,
color: 'RGBA(255, 241, 201, 1)',
},
],
},
series: [{
type: 'line',
smooth: 0.6,
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
},
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#FFF1C9'
}, ]),
},
},
2024-07-03 18:03:01 +08:00
data: that.chartData4,
2024-07-01 10:06:13 +08:00
}],
};
chart = echarts.init(canvas, null, {
width: width,
height: height,
devicePixelRatio: canvasDpr
})
2024-07-03 18:03:01 +08:00
option.series[0].data = that.chartData4
2024-07-01 10:06:13 +08:00
canvas.setChart(chart)
chart.setOption(option)
return chart
},
//重量
initChart3(canvas, width, height, canvasDpr) {
2024-05-21 18:01:46 +08:00
let that = this
2024-07-01 10:06:13 +08:00
2024-03-13 10:54:22 +08:00
const option = {
2024-07-01 10:06:13 +08:00
grid: {
left: '2%',
right: '10%',
bottom: '3%',
top: '4%',
containLabel: true
},
xAxis: {
show: true,
type: 'category',
boundaryGap: false,
axisLine: {
show: false // 隐藏X轴线
},
axisTick: {
show: false // 隐藏X轴刻度
},
axisLabel: {
show: false // 隐藏X轴标签
},
axisLabel: {
show: true,
color: '#ccc',
fontSize: 11,
rotate: 0,
},
splitLine: {
show: false,
},
// data: that.chartday,
2024-07-03 18:03:01 +08:00
// data: that.numdata.map(item => item.date)
2024-07-01 10:06:13 +08:00
},
yAxis: {
show: true,
axisLine: {
show: false,
},
axisTick: {
show: false,
},
axisLabel: {
show: true,
color: '#ccc',
fontSize: 11,
formatter: function(value) {
// 保留两位小数没有小数时显示00
return value + 'Kg'
},
},
splitLine: {
show: true, // 显示X轴网格线
lineStyle: {
type: 'dashed', // 设置网格线为虚线
color: '#ccc', // 可以设置虚线的颜色
width: 1 // 可以设置虚线的宽度
}
}
},
visualMap: {
type: 'piecewise',
show: false,
dimension: 0,
seriesIndex: 0,
pieces: [{
gt: 1,
lt: 3,
color: 'RGBA(255, 241, 201, 1)',
},
{
gt: 5,
lt: 7,
color: 'RGBA(255, 241, 201, 1)',
},
],
},
2024-03-13 10:54:22 +08:00
series: [{
2024-07-01 10:06:13 +08:00
type: 'line',
smooth: 0.6,
symbol: 'none',
lineStyle: {
color: '#FFE28C',
width: 4,
2024-03-13 10:54:22 +08:00
},
2024-07-01 10:06:13 +08:00
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#FFF1C9'
}, ]),
},
},
2024-07-02 18:07:56 +08:00
data: that.chartData3,
2024-07-01 10:06:13 +08:00
}],
2024-03-13 10:54:22 +08:00
};
2024-05-21 18:01:46 +08:00
chart = echarts.init(canvas, null, {
width: width,
height: height,
devicePixelRatio: canvasDpr
})
2024-07-01 10:06:13 +08:00
2024-07-03 18:03:01 +08:00
option.series[0].data = that.chartData3
2024-05-21 18:01:46 +08:00
canvas.setChart(chart)
2024-01-27 16:37:52 +08:00
chart.setOption(option)
return chart
},
2024-03-13 10:54:22 +08:00
// 获取设备详情
2024-03-25 19:46:07 +08:00
2023-11-27 09:57:03 +08:00
}
}
</script>
2024-01-27 16:37:52 +08:00
<style lang="scss">
2024-03-13 10:54:22 +08:00
page {
background-color: #F7FAFE;
}
.page {
2024-06-11 18:02:55 +08:00
width: 750rpx;
2024-05-21 18:01:46 +08:00
2024-06-11 18:02:55 +08:00
.backImg {
position: fixed;
top: 0;
z-index: -1;
2024-05-21 18:01:46 +08:00
2024-06-11 18:02:55 +08:00
image {
width: 750rpx;
height: 870rpx;
2024-04-27 17:20:50 +08:00
}
}
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
.no_cont {
margin: 500rpx auto 0;
width: 432rpx;
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
.img {
image {
width: 432rpx;
height: 432rpx;
}
}
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
.txt {
margin-top: 50rpx;
width: 100%;
text-align: center;
font-weight: 500;
font-size: 32rpx;
color: #808080;
}
}
2024-07-03 18:03:01 +08:00
2024-06-11 18:02:55 +08:00
.info_cont {
2024-03-13 10:54:22 +08:00
display: flex;
flex-wrap: wrap;
2024-06-11 18:02:55 +08:00
// justify-content: space-around;
padding: 38rpx 74rpx 28rpx 74rpx;
margin: 32rpx auto;
width: 638rpx;
height: 256rpx;
background: #FFFFFF;
box-shadow: 0rpx 0rpx 8rpx 0rpx rgba(0, 0, 0, 0.15);
border-radius: 20rpx 20rpx 20rpx 20rpx;
2024-07-01 10:06:13 +08:00
.cont:nth-child(3n) {
2024-06-11 18:02:55 +08:00
margin-right: 0rpx;
}
2024-07-01 10:06:13 +08:00
.cont {
2024-06-11 18:02:55 +08:00
margin-right: 100rpx;
width: 96rpx;
2024-01-27 16:37:52 +08:00
display: flex;
2024-03-13 10:54:22 +08:00
flex-wrap: wrap;
justify-content: center;
2024-07-01 10:06:13 +08:00
.cont_top {
2024-06-11 18:02:55 +08:00
font-weight: 400;
font-size: 24rpx;
color: #808080;
2024-07-01 10:06:13 +08:00
2024-01-27 16:37:52 +08:00
}
2024-07-01 10:06:13 +08:00
.cont_bot {
2024-03-13 10:54:22 +08:00
margin-top: 4rpx;
2024-06-11 18:02:55 +08:00
width: 96rpx;
2024-03-13 10:54:22 +08:00
text-align: center;
2024-06-11 18:02:55 +08:00
font-weight: 500;
2024-03-13 10:54:22 +08:00
font-size: 32rpx;
2024-06-11 18:02:55 +08:00
color: #3D3D3D;
2024-01-27 16:37:52 +08:00
}
}
2024-03-13 10:54:22 +08:00
}
2024-03-25 19:46:07 +08:00
2024-06-11 18:02:55 +08:00
.warp_box {
2024-07-01 10:06:13 +08:00
margin-top: 128rpx;
.swiper {
.swiper-item {
display: flex;
justify-content: center;
transition: height 0.3s ease-in-out;
&.active {
height: 500rpx; // 激活状态的高度
}
&:not(.active) {
height: 426rpx; // 非激活状态的高度
}
.card_box {
2024-03-13 10:54:22 +08:00
display: flex;
2024-07-01 10:06:13 +08:00
flex-wrap: wrap;
.card {
padding: 18rpx;
width: 638rpx;
height: 426rpx;
background: #FFFFFF;
box-shadow: 0rpx 0rpx 8rpx 0rpx rgba(0, 0, 0, 0.15);
border-radius: 28rpx 28rpx 28rpx 28rpx;
.card_top {
display: flex;
align-items: center;
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
.top_left {
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
display: flex;
align-items: center;
font-weight: 400;
font-size: 36rpx;
color: #3D3D3D;
image {
margin-right: 24rpx;
margin-left: 28rpx;
width: 25.03rpx;
height: 34rpx;
}
2024-06-11 18:02:55 +08:00
}
2024-07-01 10:06:13 +08:00
.top_cont {
width: 33.33%;
text-align: center;
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
}
.top_right {
margin-left: auto;
display: flex;
align-items: center;
.txt {
display: flex;
align-items: center;
flex-wrap: nowrap;
margin-left: auto;
font-weight: 400;
font-size: 32rpx;
color: #4D4D4D;
.icon-xiangyou1 {
margin-top: 4rpx;
margin-left: 8rpx;
}
}
}
}
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
.echarts {
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
margin-top: 24rpx;
width: 100%;
// height: 80%;
2024-07-03 18:03:01 +08:00
2024-07-01 10:06:13 +08:00
height: 344rpx;
2024-03-13 10:54:22 +08:00
}
}
2024-07-01 10:06:13 +08:00
2024-01-27 16:37:52 +08:00
}
}
}
2024-07-01 10:06:13 +08:00
}
2024-03-13 10:54:22 +08:00
2024-06-11 18:02:55 +08:00
.tipbox {
width: 300rpx;
display: flex;
flex-wrap: wrap;
// position: relative;
margin-top: 186rpx;
margin-left: 56rpx;
2024-04-27 17:20:50 +08:00
2024-06-11 18:02:55 +08:00
.tip_cont {
2024-01-27 16:37:52 +08:00
display: flex;
flex-wrap: nowrap;
2024-03-13 10:54:22 +08:00
align-items: center;
2024-03-25 19:46:07 +08:00
2024-06-11 18:02:55 +08:00
image {
margin-right: 6rpx;
width: 38rpx;
height: 38rpx;
2024-03-13 10:54:22 +08:00
}
2024-04-27 17:20:50 +08:00
2024-06-11 18:02:55 +08:00
// display: inline-flexbox;
flex-wrap: nowrap;
padding: 8rpx 22rpx;
background: rgba(61, 61, 61, 0.5);
box-shadow: 0rpx 0rpx 8rpx 0rpx rgba(0, 0, 0, 0.15);
border-radius: 20rpx 20rpx 20rpx 20rpx;
2024-03-25 19:46:07 +08:00
2024-06-11 18:02:55 +08:00
font-weight: 500;
font-size: 32rpx;
color: #FAFDFD;
2024-03-25 19:46:07 +08:00
2024-01-27 16:37:52 +08:00
}
}
}
2024-03-13 10:54:22 +08:00
</style>