2024-12-19 10:16:17 +08:00
|
|
|
|
<template>
|
2024-05-08 23:18:30 +08:00
|
|
|
|
<view class="page">
|
2024-06-25 18:02:39 +08:00
|
|
|
|
<view class="toptit" @click="shows()">
|
2024-12-19 10:16:17 +08:00
|
|
|
|
{{ areaInfo.areaName }}
|
2024-06-25 18:02:39 +08:00
|
|
|
|
</view>
|
|
|
|
|
<!-- <u-navbar :is-back='false' title="工作台" :border-bottom="false" :background="bgc" title-color='#2E4975' title-size='36'
|
|
|
|
|
height='45'></u-navbar> -->
|
2024-12-19 10:16:17 +08:00
|
|
|
|
|
2024-05-08 23:18:30 +08:00
|
|
|
|
<view class="cont_box">
|
|
|
|
|
<view class="top">
|
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/uMlgu6j9jnDqP1ZFL7xj" mode=""></image>
|
|
|
|
|
应用入口
|
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
<view class="app_box" v-if="menuList.length > 0">
|
|
|
|
|
<view class="cont" @click="topage(0)" v-if="hasMenuPermission('运营数据')">
|
2024-05-08 23:18:30 +08:00
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/unnmUkUif2eWNKFq9fdg" mode=""></image>
|
|
|
|
|
<view class="text">
|
|
|
|
|
运营数据
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
|
|
|
|
|
<view class="cont" @click="topage(8)" v-if="hasMenuPermission('财务报表')">
|
2024-08-23 17:55:37 +08:00
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/upJFJIIZ4hbSEuchNQi3" mode=""></image>
|
|
|
|
|
<view class="text">
|
|
|
|
|
财务报表
|
|
|
|
|
</view>
|
2024-05-08 23:18:30 +08:00
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
<view class="cont" @click="topage(2)" v-if="hasMenuPermission('设备管理')">
|
2024-05-08 23:18:30 +08:00
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/uNfRjhtxYmMPKaX4DqTS" mode=""></image>
|
|
|
|
|
<view class="text">
|
|
|
|
|
设备管理
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
|
2024-12-09 09:51:54 +08:00
|
|
|
|
<view class="cont" @click="topage(4)" v-if="hasMenuPermission('用户页面')">
|
2024-05-08 23:18:30 +08:00
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/uM4rBBaXc7b3TmsqQTvz" mode=""></image>
|
|
|
|
|
<view class="text">
|
2024-05-15 18:02:17 +08:00
|
|
|
|
用户页面
|
2024-05-08 23:18:30 +08:00
|
|
|
|
</view>
|
2024-05-15 18:02:17 +08:00
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
<!-- <view class="cont" @click="topage(5)" v-if="hasMenuPermission('车辆绑定')">
|
2024-06-20 18:08:54 +08:00
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/uM4rBBaXc7b3TmsqQTvz" mode=""></image>
|
|
|
|
|
<view class="text">
|
|
|
|
|
车辆绑定
|
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
</view> -->
|
|
|
|
|
<view class="cont" @click="topage(6)" v-if="hasMenuPermission('账户明细')">
|
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/u47okd0YdEQBsyhLlQIt" mode=""
|
|
|
|
|
style="width: 50rpx;height: 50rpx;"></image>
|
2024-07-15 18:01:10 +08:00
|
|
|
|
<view class="text">
|
|
|
|
|
账户明细
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
<view class="cont" @click="topage(7)" v-if="hasMenuPermission('故障审核')">
|
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/u47okd0YdEQBsyhLlQIt" mode=""
|
|
|
|
|
style="width: 50rpx;height: 50rpx;"></image>
|
2024-08-09 18:03:26 +08:00
|
|
|
|
<view class="text">
|
|
|
|
|
故障审核
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-12-09 09:51:54 +08:00
|
|
|
|
<view class="cont" @click="topage(9)" v-if="hasMenuPermission('车型管理')">
|
2024-12-19 10:16:17 +08:00
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/ufE1T9RDOm7OmhLgTzXi" mode=""
|
|
|
|
|
style="width: 100%;height: 100%;"></image>
|
|
|
|
|
|
2024-10-22 18:01:31 +08:00
|
|
|
|
</view>
|
2024-12-09 09:51:54 +08:00
|
|
|
|
<view class="cont" @click="topage(10)" v-if="hasMenuPermission('收费模版')">
|
2024-12-19 10:16:17 +08:00
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/uqG3ZQWu986qU0gU9vbb" mode=""
|
|
|
|
|
style="width: 100%;height: 100%;"></image>
|
|
|
|
|
|
2024-10-22 18:01:31 +08:00
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
<view class="cont" @click="topage(11)" style="width: 96rpx;height: 96rpx;"
|
|
|
|
|
v-if="hasMenuPermission('运营设置')">
|
|
|
|
|
<image src="https://lxnapi.ccttiot.com/bike/img/static/uqCr4GrXEx6irmRNNsfM" mode=""
|
|
|
|
|
style="width: 96rpx;height: 96rpx;"></image>
|
|
|
|
|
|
2024-10-22 18:01:31 +08:00
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
|
2024-05-08 23:18:30 +08:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
<u-select v-model="show" :list="list" title='选择运营区' @confirm="confirm" v-if="list.length <= 5"></u-select>
|
|
|
|
|
<!-- 自定义选择器 -->
|
|
|
|
|
<view class="custom-select" v-if="show && list.length > 5">
|
|
|
|
|
<view class="mask" @click="show = false"></view>
|
|
|
|
|
<view class="select-content">
|
|
|
|
|
<view class="select-header">
|
|
|
|
|
<text>选择运营区</text>
|
|
|
|
|
<text class="close" @click="show = false">×</text>
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
<view class="search-box">
|
|
|
|
|
<input type="text" v-model="searchKey" placeholder="搜索运营区" @input="handleSearch" />
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
<scroll-view scroll-y class="select-list">
|
|
|
|
|
<view class="select-item" v-for="item in displayList" :key="item.value" @click="selectItem(item)"
|
|
|
|
|
:class="{ 'highlight': searchKey && item.label.includes(searchKey) }">
|
|
|
|
|
{{ item.label }}
|
|
|
|
|
<view style="font-size: 24rpx;color: #999;margin-left: auto;"> {{ item.deptName }}</view>
|
|
|
|
|
</view>
|
|
|
|
|
</scroll-view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-09-02 17:13:16 +08:00
|
|
|
|
<TabBar :indexs='0' style=""></TabBar>
|
2024-05-08 23:18:30 +08:00
|
|
|
|
</view>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
2024-12-19 10:16:17 +08:00
|
|
|
|
import TabBar from '@/pages_admin/components/tab-bar/tab-bar.vue';
|
|
|
|
|
export default {
|
|
|
|
|
components: { TabBar },
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
bgc: {
|
|
|
|
|
backgroundColor: "#FFFFFF",
|
|
|
|
|
},
|
|
|
|
|
sn: '',
|
|
|
|
|
areaId: 0,
|
|
|
|
|
areaInfo: {},
|
|
|
|
|
list: [],
|
|
|
|
|
show: false,
|
|
|
|
|
info: {},
|
|
|
|
|
userinfo: {},
|
|
|
|
|
deptId: null,
|
|
|
|
|
menuList: [],
|
|
|
|
|
searchKey: '',
|
|
|
|
|
displayList: [], // 用于显示的列表
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
onShow() {
|
|
|
|
|
this.deptId = uni.getStorageSync('deptId');
|
|
|
|
|
this.$store.dispatch('userInfo', this.$u).then(() => {
|
|
|
|
|
|
|
|
|
|
// 执行其他操作...
|
|
|
|
|
});
|
|
|
|
|
if (uni.getStorageSync('adminAreaid')) {
|
|
|
|
|
this.areaId = uni.getStorageSync('adminAreaid')
|
|
|
|
|
this.getArea()
|
|
|
|
|
this.getinfo()
|
|
|
|
|
this.getareaList()
|
|
|
|
|
this.getareaInfo()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
computed: {
|
|
|
|
|
userId() {
|
|
|
|
|
return this.$store.getters.userId;
|
|
|
|
|
},
|
|
|
|
|
// maskedPhoneNumber() {
|
|
|
|
|
// if (!this.info.phonenumber) return '';
|
|
|
|
|
// return this.info.phonenumber.slice(0, 3) + '****' + this.info.phonenumber.slice(7);
|
|
|
|
|
// },
|
|
|
|
|
// maskedName() {
|
|
|
|
|
// if (!this.info.realName) return '';
|
|
|
|
|
// return this.info.realName.charAt(0) + '*'.repeat(this.info.realName.length - 1);
|
|
|
|
|
// },
|
|
|
|
|
// 添加过滤后的列表计算属性
|
|
|
|
|
filteredList() {
|
|
|
|
|
if (!this.searchKey) return this.list;
|
|
|
|
|
return this.list.filter(item =>
|
|
|
|
|
item.label.toLowerCase().includes(this.searchKey.toLowerCase())
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
handleSearch(e) {
|
|
|
|
|
const value = e.detail.value;
|
|
|
|
|
if (!value) {
|
|
|
|
|
// 搜索框为空时显示全部数据
|
|
|
|
|
this.displayList = this.list;
|
|
|
|
|
} else {
|
|
|
|
|
// 有搜索内容时过滤数据
|
|
|
|
|
this.displayList = this.list.filter(item =>
|
|
|
|
|
item.label.toLowerCase().includes(value.toLowerCase()) ||
|
|
|
|
|
item.deptName.toLowerCase().includes(value.toLowerCase())
|
|
|
|
|
);
|
2024-05-08 23:18:30 +08:00
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
|
2024-12-19 10:16:17 +08:00
|
|
|
|
selectItem(item) {
|
|
|
|
|
this.confirm([item]);
|
|
|
|
|
this.show = false;
|
|
|
|
|
this.searchKey = ''; // 选择后清空搜索框
|
|
|
|
|
this.displayList = this.list; // 重置显示列表
|
|
|
|
|
},
|
|
|
|
|
hasMenuPermission(menuName) {
|
|
|
|
|
return this.menuList.some(item => item.menuName === menuName);
|
|
|
|
|
},
|
|
|
|
|
getinfo() {
|
|
|
|
|
this.$u.get("/getAppInfo").then((res) => {
|
|
|
|
|
|
|
|
|
|
if (res.code == 200) {
|
|
|
|
|
|
|
|
|
|
this.userinfo = res.user
|
|
|
|
|
this.menuList = res.menu
|
|
|
|
|
console.log(this.menuList, 'menuListmenuListmenuListmenuList');
|
|
|
|
|
} else {
|
|
|
|
|
// setTimeout(() => {
|
|
|
|
|
// this.getinfo()
|
|
|
|
|
// }, 200)
|
|
|
|
|
|
|
|
|
|
}
|
2024-05-08 23:18:30 +08:00
|
|
|
|
});
|
|
|
|
|
},
|
2024-12-19 10:16:17 +08:00
|
|
|
|
getareaInfo() {
|
|
|
|
|
this.$u.get('/appVerify/getDept').then((res) => {
|
|
|
|
|
if (res.code == 200) {
|
|
|
|
|
this.info = res.data
|
|
|
|
|
console.log(this.userId, 'userIduserIduserId');
|
|
|
|
|
}
|
|
|
|
|
}).catch(error => {
|
|
|
|
|
console.error("Error fetching area data:", error);
|
|
|
|
|
});
|
2024-05-08 23:18:30 +08:00
|
|
|
|
},
|
2024-12-19 10:16:17 +08:00
|
|
|
|
shows() {
|
|
|
|
|
|
|
|
|
|
if (this.list.length < 2) {
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
this.show = true
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
getareaList() {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
this.$u.get('/appVerify/getAreaList').then((res) => {
|
|
|
|
|
if (res.code == 200) {
|
|
|
|
|
this.list = res.data.map(item => ({
|
|
|
|
|
value: item.areaId,
|
|
|
|
|
label: item.areaName,
|
|
|
|
|
deptName: item.deptName
|
|
|
|
|
}));
|
|
|
|
|
this.displayList = this.list; // 重置显示列表
|
2024-06-25 18:02:39 +08:00
|
|
|
|
}
|
2024-12-19 10:16:17 +08:00
|
|
|
|
}).catch(error => {
|
|
|
|
|
console.error("Error fetching area data:", error);
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
confirm(e) {
|
|
|
|
|
// console.log(e);
|
|
|
|
|
uni.setStorageSync('adminAreaid', e[0].value);
|
|
|
|
|
this.areaId = e[0].value
|
|
|
|
|
this.getArea()
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
getArea() {
|
|
|
|
|
|
|
|
|
|
let id = this.areaId
|
|
|
|
|
this.$u.get("/app/area/" + id).then((res) => {
|
|
|
|
|
|
|
|
|
|
if (res.code == 200) {
|
|
|
|
|
this.areaInfo = res.data
|
|
|
|
|
} else {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: res.msg,
|
|
|
|
|
icon: 'none',
|
|
|
|
|
duration: 2000
|
|
|
|
|
});
|
2024-05-14 18:04:34 +08:00
|
|
|
|
}
|
2024-12-19 10:16:17 +08:00
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
topage(num) {
|
|
|
|
|
if (num == 0) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_admin/worke/worke_Operation'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 1) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_admin/worke/worke_income'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 2) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_admin/worke/woke_deviceMgmt'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 3) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_admin/worke/worke_user'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 4) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages/index/index'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 5) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_admin/worke/bind_sn'
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
} else if (num == 6) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_admin/worke/AccountDetails'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 7) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_adminSet/shgl'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 8) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_adminSet/financialStatement'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 9) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_adminSet/CarModel'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 10) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_adminSet/ChargingTemplate'
|
|
|
|
|
})
|
|
|
|
|
} else if (num == 11) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages_adminSet/sysSet'
|
|
|
|
|
})
|
2024-05-14 18:04:34 +08:00
|
|
|
|
}
|
2024-12-19 10:16:17 +08:00
|
|
|
|
|
2024-05-08 23:18:30 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2024-12-19 10:16:17 +08:00
|
|
|
|
}
|
2024-05-08 23:18:30 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss">
|
2024-12-19 10:16:17 +08:00
|
|
|
|
page {
|
|
|
|
|
background-color: #FFFFFF;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.custom-select {
|
|
|
|
|
.mask {
|
|
|
|
|
position: fixed;
|
|
|
|
|
top: 0;
|
|
|
|
|
left: 0;
|
|
|
|
|
right: 0;
|
|
|
|
|
bottom: 0;
|
|
|
|
|
background: rgba(0, 0, 0, 0.5);
|
|
|
|
|
z-index: 999;
|
2024-05-08 23:18:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
2024-12-19 10:16:17 +08:00
|
|
|
|
.select-content {
|
|
|
|
|
position: fixed;
|
|
|
|
|
left: 0;
|
|
|
|
|
right: 0;
|
|
|
|
|
bottom: 0;
|
|
|
|
|
background: #fff;
|
|
|
|
|
border-radius: 20rpx 20rpx 0 0;
|
|
|
|
|
z-index: 1000;
|
|
|
|
|
height: 50vh; // 最大高度
|
|
|
|
|
// min-height: 400rpx; // 添加最小高度
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
padding-bottom: 20rpx;
|
|
|
|
|
|
|
|
|
|
.select-header {
|
|
|
|
|
padding: 20rpx 30rpx;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
align-items: center;
|
|
|
|
|
border-bottom: 1px solid #eee;
|
|
|
|
|
|
|
|
|
|
.close {
|
|
|
|
|
font-size: 40rpx;
|
|
|
|
|
color: #999;
|
|
|
|
|
}
|
2024-06-25 18:02:39 +08:00
|
|
|
|
}
|
2024-12-19 10:16:17 +08:00
|
|
|
|
|
|
|
|
|
.search-box {
|
|
|
|
|
padding: 15rpx 20rpx;
|
|
|
|
|
border-bottom: 1px solid #eee;
|
|
|
|
|
|
|
|
|
|
input {
|
2024-05-08 23:18:30 +08:00
|
|
|
|
width: 100%;
|
2024-12-19 10:16:17 +08:00
|
|
|
|
height: 60rpx;
|
|
|
|
|
background: #f5f5f5;
|
|
|
|
|
border-radius: 30rpx;
|
|
|
|
|
padding: 0 30rpx;
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.select-list {
|
|
|
|
|
flex: 1;
|
|
|
|
|
max-height: calc(50vh - 140rpx);
|
|
|
|
|
min-height: 260rpx; // 为列表添加最小高度
|
|
|
|
|
|
|
|
|
|
.select-item {
|
2024-05-08 23:18:30 +08:00
|
|
|
|
display: flex;
|
2024-12-19 10:16:17 +08:00
|
|
|
|
// flex-direction: column;
|
|
|
|
|
justify-content: space-between;
|
2024-05-08 23:18:30 +08:00
|
|
|
|
align-items: center;
|
2024-12-19 10:16:17 +08:00
|
|
|
|
padding: 20rpx 30rpx;
|
|
|
|
|
border-bottom: 1px solid #eee;
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
|
|
|
|
|
&.highlight {
|
|
|
|
|
background-color: #f0f9ff;
|
|
|
|
|
color: #2d8cf0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
&:active {
|
|
|
|
|
background: #f5f5f5;
|
2024-05-08 23:18:30 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2024-12-19 10:16:17 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
.page {
|
|
|
|
|
width: 750rpx;
|
|
|
|
|
|
|
|
|
|
.toptit {
|
|
|
|
|
margin-top: 100rpx;
|
|
|
|
|
margin-left: 100rpx;
|
|
|
|
|
font-size: 38rpx;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.cont_box {
|
|
|
|
|
padding: 46rpx 50rpx;
|
|
|
|
|
margin: 68rpx auto;
|
|
|
|
|
width: 680rpx;
|
|
|
|
|
background: #FFFFFF;
|
|
|
|
|
box-shadow: 0rpx 4rpx 22rpx 0rpx rgba(0, 0, 0, 0.07);
|
|
|
|
|
border-radius: 24rpx 24rpx 24rpx 24rpx;
|
|
|
|
|
.top {
|
|
|
|
|
width: 100%;
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-wrap: nowrap;
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
|
|
|
|
image {
|
|
|
|
|
margin-right: 16rpx;
|
|
|
|
|
width: 32rpx;
|
|
|
|
|
height: 32rpx;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
font-size: 32rpx;
|
|
|
|
|
color: #3D3D3D;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.app_box {
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-wrap: wrap;
|
|
|
|
|
|
|
|
|
|
.cont:nth-child(4n) {
|
|
|
|
|
margin-right: 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.cont {
|
|
|
|
|
margin-right: 60rpx;
|
|
|
|
|
margin-top: 70rpx;
|
|
|
|
|
width: 96rpx;
|
2024-05-08 23:18:30 +08:00
|
|
|
|
display: flex;
|
|
|
|
|
flex-wrap: wrap;
|
2024-12-19 10:16:17 +08:00
|
|
|
|
justify-content: center;
|
|
|
|
|
|
|
|
|
|
image {
|
|
|
|
|
width: 54rpx;
|
|
|
|
|
height: 52rpx;
|
2024-05-08 23:18:30 +08:00
|
|
|
|
}
|
2024-12-19 10:16:17 +08:00
|
|
|
|
|
|
|
|
|
.text {
|
|
|
|
|
margin-top: 14rpx;
|
|
|
|
|
font-weight: 400;
|
|
|
|
|
font-size: 24rpx;
|
|
|
|
|
color: #3D3D3D;
|
2024-05-08 23:18:30 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-12-19 10:16:17 +08:00
|
|
|
|
}
|
2024-05-08 23:18:30 +08:00
|
|
|
|
</style>
|