316 lines
8.5 KiB
Vue
316 lines
8.5 KiB
Vue
<template>
|
||
<view class="page">
|
||
<u-navbar title="下级店铺" :border-bottom="false" :background="bgc" title-color='#000' title-size='36'
|
||
height='58'></u-navbar>
|
||
<view class="box">
|
||
<view class="top">
|
||
<u-search placeholder="搜索" input-align="center" v-model="keyword" @custom="searchs"></u-search>
|
||
</view>
|
||
|
||
<view class="list">
|
||
<view class="listitem" @scrolltolower="onReachBottom" v-for="(item,index) in wateringList" :key="index">
|
||
<view class="toptit">
|
||
<u-icon name="calendar-fill" size="36"></u-icon>
|
||
<view class="tit">
|
||
{{item.name}}
|
||
</view>
|
||
<!-- <view class="bd">
|
||
绑定设备
|
||
</view> -->
|
||
<view class="bd" @click="btnjif(item.storeId)">
|
||
计费规则
|
||
</view>
|
||
<view class="yuan" @click="btnxq(item)">
|
||
<text
|
||
style="width: 9rpx;height: 9rpx;border-radius: 50%;margin-right: 5rpx;background-color: #000;display: inline-block;"></text>
|
||
<text
|
||
style="width: 9rpx;height: 9rpx;border-radius: 50%;margin-right: 5rpx;background-color: #000;display: inline-block;"></text>
|
||
<text
|
||
style="width: 9rpx;height: 9rpx;border-radius: 50%;margin-right: 5rpx;background-color: #000;display: inline-block;"></text>
|
||
</view>
|
||
</view>
|
||
<view class="rishou">
|
||
<view class="rishouwz">
|
||
<text>日收</text><text>月收</text><text>上月收</text><text>在线</text><text>离线</text>
|
||
</view>
|
||
<view class="rishouje">
|
||
<text>{{item.todayIncome == null ? 0 :item.todayIncome}}¥</text>
|
||
<text>{{item.monthIncome == null ? 0 :item.monthIncome}}¥</text>
|
||
<text>{{item.lastMonthIncome == null ? 0 :item.lastMonthIncome}}¥</text>
|
||
<text>{{item.onlineCount == null ? 0 :item.onlineCount}}台</text>
|
||
<text>{{item.offlineCount == null ? 0 :item.offlineCount}}台</text>
|
||
</view>
|
||
</view>
|
||
<view class="gzlist">
|
||
<view class="jfgz">
|
||
<text>计费规则:</text>{{item.feePrice}}元/小时,前{{item.feeFreeTime}}分钟免费,日封顶{{item.feeMaxPrice}}元
|
||
</view>
|
||
<view class="phone">
|
||
<text>联系电话:</text>{{item.contactMobile}}
|
||
</view>
|
||
<view class="phones">
|
||
<text>联系人员:</text>{{item.contactName}}
|
||
</view>
|
||
</view>
|
||
<view class="yunxing">
|
||
<text>已运营{{item.daysDifference + 1}}天</text> <text>{{item.createTime}}</text>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="" style="width: 448rpx;height: 448rpx;margin: auto;margin-top: 100rpx;text-align: center;"
|
||
v-if="showflag">
|
||
<image style="width: 448rpx;height: 448rpx;"
|
||
src="https://api.ccttiot.com/smartmeter/img/static/ufLi6IZd5kh1MIEZFYTo" mode=""></image>
|
||
<view class="" style="font-size: 30rpx;color: #ccc;margin-top: 30rpx;">暂无更多店铺...</view>
|
||
</view>
|
||
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
export default {
|
||
data() {
|
||
return {
|
||
pagenum: 1,
|
||
wateringList: [],
|
||
pagesize: 10, // 一页多少数据
|
||
isLoading: false, // 是否正在加载数据
|
||
noMoreData: false, // 是否没有更多数据
|
||
total: 0,
|
||
agentId:'',
|
||
keyword:'',
|
||
bgc: {
|
||
background: '#25CE88'
|
||
},
|
||
showflag: false
|
||
}
|
||
},
|
||
onLoad() {
|
||
this.agentId = uni.getStorageSync('userdata').agentId
|
||
// this.getlist()
|
||
},
|
||
onShow() {
|
||
this.pagenum = 1
|
||
this.wateringList = []
|
||
this.getlist()
|
||
},
|
||
methods: {
|
||
getlist() {
|
||
this.$u.get("/agent/store/listChildren?pageNum=" + this.pagenum + '&pageSize=' + this.pagesize +'&excludeAgents=' +this.agentId + '&keyword=' + this.keyword).then(res => {
|
||
if (res.code == 200) {
|
||
this.total = res.total
|
||
if (this.total > 0) {
|
||
this.showflag = false
|
||
} else {
|
||
this.showflag = true
|
||
}
|
||
if (res.rows.length > 0) {
|
||
// 有数据,追加到列表
|
||
this.wateringList = this.wateringList.concat(res.rows)
|
||
this.pagenum++
|
||
|
||
// 计算创建到现在运行了多少天
|
||
this.wateringList.forEach((item, index) => {
|
||
var dateTime = new Date(item.createTime);
|
||
if (isNaN(dateTime.getTime())) {
|
||
console.error(`无法解析日期时间字符串: ${item.createTime}`);
|
||
return;
|
||
}
|
||
var now = new Date().getTime();
|
||
var differenceInMilliseconds = now - dateTime.getTime();
|
||
var differenceInDays = Math.floor(differenceInMilliseconds / (1000 * 60 * 60 * 24));
|
||
// 直接修改原数组中的对象,添加daysDifference属性
|
||
item.daysDifference = differenceInDays;
|
||
})
|
||
|
||
} else {
|
||
// 没有更多数据
|
||
this.noMoreData = true;
|
||
}
|
||
this.isLoading = false;
|
||
}
|
||
})
|
||
},
|
||
searchs(){
|
||
this.wateringList = []
|
||
this.getlist()
|
||
},
|
||
onReachBottom() {
|
||
let sum = this.total / this.pagesize
|
||
if (this.pagenum-1 < sum) {
|
||
this.getlist(); // 上拉加载更多
|
||
} else {
|
||
uni.showToast({
|
||
title: '没有更多店铺了',
|
||
icon: 'none',
|
||
duration: 1000
|
||
});
|
||
}
|
||
},
|
||
|
||
btnjif(storeId){
|
||
uni.navigateTo({
|
||
url:'/page_user/jifei?storeId=' + storeId
|
||
})
|
||
},
|
||
btnxq(item){
|
||
uni.navigateTo({
|
||
url:'/page_user/xiajispxq?storeId=' + item.storeId
|
||
})
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
<style lang="scss">
|
||
/deep/ .u-title,
|
||
/deep/ .uicon-nav-back {
|
||
padding-bottom: 40rpx;
|
||
}
|
||
|
||
page {
|
||
// background: linear-gradient(180deg, #25CE88 0%, rgba(255, 255, 255, 0) 100%);
|
||
}
|
||
|
||
.page {
|
||
width: 750rpx;
|
||
|
||
.box{
|
||
width: 750rpx;
|
||
height: 100%;
|
||
background: #F4F5F7;
|
||
border-radius: 0rpx 0rpx 0rpx 0rpx;
|
||
.list{
|
||
overflow-y: scroll;
|
||
height: 100%;
|
||
padding-bottom: 400rpx;
|
||
margin-top: 170rpx;
|
||
.listitem{
|
||
margin-bottom: 28rpx !important;
|
||
padding: 12rpx 38rpx;
|
||
box-sizing: border-box;
|
||
width: 680rpx;
|
||
height: 460rpx;
|
||
background: #FFFFFF;
|
||
border-radius: 38rpx 38rpx 38rpx 38rpx;
|
||
margin: auto;
|
||
.yunxing{
|
||
display: flex;
|
||
justify-content: space-between;
|
||
font-size: 24rpx;
|
||
color: #808080;
|
||
margin-top: 26rpx;
|
||
}
|
||
.phones{
|
||
margin-top: 16rpx;
|
||
font-size: 24rpx;
|
||
color: #1DBE7B;
|
||
border-bottom: 1px solid #ccc;
|
||
padding-bottom: 26rpx;
|
||
box-sizing: border-box;
|
||
text{
|
||
color: #808080;
|
||
}
|
||
}
|
||
.phone{
|
||
margin-top: 16rpx;
|
||
font-size: 24rpx;
|
||
color: #3D3D3D;
|
||
text{
|
||
color: #808080;
|
||
}
|
||
}
|
||
.gzlist{
|
||
margin-top: 30rpx;
|
||
.jfgz{
|
||
font-size: 24rpx;
|
||
color: #3D3D3D;
|
||
text{
|
||
color: #808080;
|
||
}
|
||
}
|
||
}
|
||
.rishou{
|
||
margin-top: 26rpx;
|
||
padding: 0 28rpx;
|
||
box-sizing: border-box;
|
||
.rishouwz{
|
||
display: flex;
|
||
justify-content: space-between;
|
||
text{
|
||
font-size: 24rpx;
|
||
color: #808080;
|
||
}
|
||
}
|
||
.rishouje{
|
||
display: flex;
|
||
justify-content: space-between;
|
||
margin-top: 10rpx;
|
||
text{
|
||
font-weight: 500;
|
||
font-size: 32rpx;
|
||
color: #3D3D3D;
|
||
}
|
||
}
|
||
}
|
||
.toptit{
|
||
border-bottom: 1px solid #ccc;
|
||
display: flex;
|
||
justify-content: space-between;
|
||
padding-bottom: 12rpx;
|
||
box-sizing: border-box;
|
||
.tit{
|
||
width: 350rpx;
|
||
background: #DBFAED;
|
||
border-radius: 16rpx 16rpx 16rpx 16rpx;
|
||
font-weight: 600;
|
||
font-size: 30rpx;
|
||
color: #3D3D3D;
|
||
padding: 10rpx 12rpx;
|
||
box-sizing: border-box;
|
||
}
|
||
.bd{
|
||
margin-top: 18rpx;
|
||
height:100%;
|
||
font-size: 20rpx;
|
||
color: #FFFFFF;
|
||
padding: 4rpx 12rpx;
|
||
box-sizing: border-box;
|
||
background: #1DBE7B;
|
||
border-radius: 6rpx 6rpx 6rpx 6rpx;
|
||
}
|
||
.yuan{
|
||
margin-top: 10rpx;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
.top{
|
||
width: 750rpx;
|
||
height: 136rpx;
|
||
background: #FFFFFF;
|
||
padding: 32rpx 36rpx;
|
||
box-sizing: border-box;
|
||
position: fixed;
|
||
top: 200rpx;
|
||
z-index: 99;
|
||
/deep/ .u-content{
|
||
border: 1px solid #ccc;
|
||
border-radius: 50rpx 0 0 50rpx !important;
|
||
}
|
||
/deep/ .u-action{
|
||
border-radius: 0 50rpx 50rpx 0 !important;
|
||
width: 112rpx;
|
||
height: 65rpx;
|
||
line-height: 65rpx;
|
||
border: 2rpx solid #ccc;
|
||
margin-left: 0;
|
||
color: #3D3D3D;
|
||
background-color: #f2f2f2;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
</style> |