This commit is contained in:
3321822538@qq.com 2025-01-06 15:08:47 +08:00
parent 172b902132
commit 50a612a61f
4 changed files with 607 additions and 233 deletions

View File

@ -1,23 +1,64 @@
<template>
<view class="page">
<u-navbar title="附近共享" :border-bottom="false" :background="bgc" title-color='#fff' back-icon-color="#fff"
title-size='44' height='50'></u-navbar>
<u-navbar title="门店选择" :border-bottom="false" :background="bgc" title-color='#000' back-icon-color="#000"
title-size='44' height='40'></u-navbar>
<view class="serch">
<input type="text" v-model="keyword" @confirm="confirmss" placeholder="搜索门店"/>
<view class="dt" v-if="!dtlbflag" @click="btnlbtop">
<image src="https://api.ccttiot.com/smartmeter/img/static/u2uM05aGZDeVxrdrNmoh" mode=""></image>
地图
</view>
<view class="lb" v-else @click="btndttop">
<image src="https://api.ccttiot.com/smartmeter/img/static/ubAi251bnYEIdAkwJXcA" mode=""></image>
列表
</view>
</view>
<view class="dtxs">
<map class='map' id="map" :latitude="latitude" :longitude="longitude" @markertap="handleMarkerClick"
:show-location="true" :markers="covers" :scale="mapScale" @regionchange="regionchange"/>
<image class="picimg" v-if="iconflag"
src="https://api.ccttiot.com/smartmeter/img/static/uEAmNMMt65U10qwijrsJ" mode=""></image>
</view>
<view class="listbox">
<view class="moshi">
<image src="https://api.ccttiot.com/smartmeter/img/static/uWpZzKBmhjKwSEkO3vcH" mode="aspectFit" style="height: 80rpx;"
@click="btndt(1)" class="img"></image>
<image @click="onControltap" style="width: 76rpx;height: 76rpx;position: absolute;right: 50rpx;"
src="https://api.ccttiot.com/smartmeter/img/static/uOS9p7Sy1K9WpVQgD3b9" mode="aspectFit"></image>
<!-- 0000000000000000000000000000000000000000000 -->
<!-- <view class="listbox" style="background: transparent;" > -->
<view class="list" v-if="listobj.name" @click="btnxqstore">
<view class="pic">
<image :src="listobj.picture" mode="aspectFill"></image>
</view>
<view class="cen">
<view class="cena" style="font-weight: 600;">
{{listobj.name}}
</view>
<view class="cenb">
<image src="https://api.ccttiot.com/smartmeter/img/static/uHK2aJHvzEm3nbOPwpdr" mode="aspectFit"></image>
{{listobj.address}}
</view>
<view class="cenc">
营业时间{{listobj.businessTimeStart}}-{{listobj.businessTimeEnd}}
</view>
<view class="" style=" display: flex;
align-items: center;
justify-content: space-between;
width: 100%;margin-top: 24rpx;">
<view class="juli">
据我{{listobj.distance}}
</view>
<view class="right">
<image src="https://api.ccttiot.com/smartmeter/img/static/u4Q5lajsFuAv7YEzBFib" mode="aspectFit"
@click.stop="mapFuns(item)"></image>
<image src="https://api.ccttiot.com/smartmeter/img/static/uPeCVStFHIF0rAhMKhlK" mode="aspectFit"
@click.stop="btntel(item)"></image>
</view>
</view>
</view>
</view>
<!-- </view> -->
<!-- 0000000000000000000000000000000000000000000 -->
<view class="listbox" v-if="!dtlbflag">
<view class="list" v-for="(item,index) in gxlist" :key="index">
<view class="pic" @click="btndts(item)">
<image :src="item.picture" mode="aspectFit"></image>
<image :src="item.picture" mode="aspectFill"></image>
</view>
<view class="cen" @click="btndts(item)">
<view class="cena" style="font-weight: 600;">
@ -28,13 +69,22 @@
{{item.address}}
</view>
<view class="cenc">
共享时间{{item.businessTimeStart}}-{{item.businessTimeEnd}}<text class="bu">可共享</text>
营业时间{{item.businessTimeStart}}-{{item.businessTimeEnd}}
</view>
<view class="" style=" display: flex;
align-items: center;
justify-content: space-between;
width: 100%;margin-top: 24rpx;">
<view class="juli">
据我{{item.distance}}
</view>
<view class="right">
<image src="https://api.ccttiot.com/smartmeter/img/static/u4Q5lajsFuAv7YEzBFib" mode="aspectFit"
@click.stop="mapFun(item)"></image>
<image src="https://api.ccttiot.com/smartmeter/img/static/uPeCVStFHIF0rAhMKhlK" mode="aspectFit"
@click.stop="btntel(item)"></image>
</view>
</view>
</view>
<view class="right">
<image src="https://api.ccttiot.com/smartmeter/img/static/uraUDWkEx5OvJB29kMnS" mode="aspectFit"
@click="mapFun(item)"></image>
<text>{{item.distance}}</text>
</view>
</view>
<view class="" v-if="gxlist.length == 0" style="width: 100%;height: 200rpx;margin: auto;margin-top: 230rpx;text-align: center;">
@ -42,7 +92,12 @@
<view class="" style="font-size: 28rpx;color: #808080;margin-top: 30rpx;">该区域暂无店铺...</view>
</view>
</view>
<view class="saoma" @click="scanQRCode">
<view>
<image src="https://api.ccttiot.com/smartmeter/img/static/uBh15vzRx6gV0wRQj7gi" mode="aspectFit"></image>
扫一扫
</view>
</view>
</view>
</template>
@ -57,13 +112,16 @@
isMch: false,
gxlist: [],
bgc: {
backgroundColor: " #8883F0",
backgroundColor: " #fff",
},
mapScale: 15,
mapContext: null,
mapScaleInterval: null,
listmap: [],
iconflag: false,
dtlbflag:true,
listobj:{},
keyword:''
}
},
onLoad() {
@ -100,6 +158,177 @@
}
},
methods: {
confirmss(){
this.covers = []
this.gxlist = []
this.$u.get("/app/store/listNearBy?center=" + this.jinweidu + '&radius=' + 20000 + '&keyword=' + this.keyword).then(
response => {
if (response.code == 200) {
this.listmap = response.data
let gxlist = response.data
gxlist.forEach(item => {
const distance = this.getDistance(this.latitude, this.longitude, item.lat, item.lng)
item.distance = distance
const shopCover = {
id: parseFloat(item.storeId),
latitude: item.lat,
longitude: item.lng,
width: 25,
height: 30,
iconPath: 'https://api.ccttiot.com/smartmeter/img/static/uZXgsJE6hXbRSwbKILB4',
distance: distance, //
label: {
content: item.name,
anchorX: (() => {
if (item.name.length <= 2) {
return -12
} else if (item.name.length <=
3) {
return -20
} else if (item.name.length <=
4) {
return -25
} else if (item.name.length <=
5) {
return -30
} else if (item.name.length <=
6) {
return -35
} else if (item.name.length <=
8) {
return -40
} else if (item.name.length <=
10) {
return -45
} else {
return -item.name.length *
5
}
})(),
fontWeight: 700,
color: '#8883F0',
textShadow: '2px 2px 0px white, -2px -2px 0px white, 2px -2px 0px white, -2px 2px 0px white',
borderRadius:5,
bgColor: '#fff'
}
}
this.covers.push(shopCover)
this.gxlist.push(item)
})
}
})
},
//
scanQRCode() {
uni.scanCode({
onlyFromCamera: true,
scanType: ['qrCode'],
success: res => {
function getQueryParam(url, paramName) {
let regex = new RegExp(`[?&]${paramName}=([^&]*)`)
let results = regex.exec(url);
return results ? decodeURIComponent(results[1].replace(/\+/g, ' ')) : null
}
let sceneValue = res.result
let decodedValue = decodeURIComponent(sceneValue)
let id = getQueryParam(decodedValue, 's')
let that = this
let data = {
deviceNo: id
}
that.$u.get(`/app/device/isBind?deviceNo=${id}`).then(res => {
if (res.data == 2) {
that.$u.get(`/app/device/${id}/withSuitList`).then((res) => {
if (res.code == 200) {
uni.navigateTo({
url: '/page_components/fuwu/index?id=' + id
})
}
})
} else if (res.data == 1) {
console.log(1);
if(that.phonenumber == ''){
that.huoqutelflag = true
that.xuanzeflag = false
console.log(11);
}else{
console.log(12);
that.xuanzeflag = false
uni.showModal({
title: '提示',
content: '该设备未绑定,你需进行绑定吗?',
success: function(res) {
if (res.confirm) {
that.$u.put("/app/device/bind", data).then(res => {
if (res.code == 200) {
that.$u.get(`/app/device/${id}/bySn`).then((res) => {
if (res.code == 200) {
uni.navigateTo({
url: '/page_components/bindsz?id=' + res.data.deviceId
})
}
})
}
})
}
}
})
}
} else if (res.data == 0) {
uni.showModal({
title: '提示',
content: '该设备未录入,请先进行录入',
success: function(res) {
if (res.confirm) {
// uni.navigateTo({
// url: '/page_fenbao/zhuce?sn=' + id
// })
} else if (res.cancel) {
}
}
})
}
})
},
fail: err => {
console.error('扫描失败:', err)
uni.showToast({
title: '扫描失败',
icon: 'none'
})
}
})
},
//
btnlbtop(){
this.dtlbflag = true
this.listobj = {}
},
//
btndttop(){
this.dtlbflag = false
this.listobj = {}
},
//
btntel(item){
uni.makePhoneCall({
phoneNumber: this.listobj.contactMobile,
success: function(res) {
console.log('拨打电话成功', res)
},
fail: function(err) {
console.error('拨打电话失败', err)
uni.showToast({
title: '取消拨打电话',
icon: 'none'
})
}
})
},
//
regionchange(e) {
this.iconflag = true
@ -258,6 +487,14 @@
address: item.address
})
},
mapFuns() {
uni.openLocation({
latitude: this.listobj.lat,
longitude: this.listobj.lng,
name: this.listobj.county,
address: this.listobj.address
})
},
getshanghu() {
this.$u.get("/app/user/userInfo").then((res) => {
if (res.code == 200) {
@ -369,9 +606,15 @@
handleMarkerClick(event) {
const markerId = event.markerId
uni.navigateTo({
url: '/page_user/mapditu/index?markerId=' + markerId
})
// uni.navigateTo({
// url: '/page_user/mapditu/index?markerId=' + markerId
// })
this.$u.get("/app/store/" + markerId).then(res => {
if(res.code == 200){
const distance = this.getDistance(this.latitude, this.longitude, res.data.lat, res.data.lng)
this.listobj = { ...res.data, distance: distance }
}
})
},
btndts(item) {
const markerId = item.storeId
@ -379,6 +622,12 @@
url: '/page_user/mapditu/index?markerId=' + markerId
})
},
//
btnxqstore(){
uni.navigateTo({
url: '/page_user/mapditu/index?markerId=' + this.listobj.storeId
})
},
btntab(num) {
this.index = num
@ -405,23 +654,79 @@
<style lang="scss">
/deep/ .u-title {
padding-bottom: 22rpx;
padding-bottom: 2rpx;
}
/deep/ .u-icon__icon {
padding-bottom: 22rpx;
padding-bottom: 2rpx;
}
/deep/ .map {
width: 100%;
height: 100%;
}
.serch{
width: 100%;
height: 130rpx;
background: #FFFFFF;
padding: 0 18rpx;
box-sizing: border-box;
display: flex;
align-items: center;
justify-content: space-between;
input{
width: 650rpx;
height: 78rpx;
line-height: 78rpx;
box-sizing: border-box;
padding-left: 20rpx;
background-color: #F2F3F5;
}
view{
text-align: center;
font-size: 22rpx;
color: #3D3D3D;
width: 60rpx;
image{
width: 42rpx;
height: 42rpx;
}
}
}
page {
background: linear-gradient(180deg, #D9D8FF 0%, rgba(255, 255, 255, 0) 100%);
border-radius: 0rpx 0rpx 0rpx 0rpx;
}
.saoma {
width: 750rpx;
height: 166rpx;
background: #FFFFFF;
position: fixed;
left: 0;
bottom: 0;
padding-top: 22rpx;
border-radius: 54rpx 54rpx 0 0;
margin-top: 20rpx;
view {
text-align: center;
width: 676rpx;
height: 102rpx;
background: linear-gradient(270deg, #8883F0 0%, #8883F0 100%);
border-radius: 54rpx 54rpx 54rpx 54rpx;
font-weight: 500;
font-size: 40rpx;
color: #FFFFFF;
margin: auto;
line-height: 102rpx;
}
image {
width: 56rpx;
height: 56rpx;
vertical-align: middle;
margin-right: 10rpx;
margin-bottom: 10rpx;
}
}
.page {
width: 750rpx;
position: fixed;
@ -443,16 +748,116 @@
top: 50%;
}
}
.list {
display: flex;
margin-top: 10px;
border-bottom: 1px solid #eee;
padding: 16rpx 14rpx;
box-sizing: border-box;
background-color: #fff;
width: 710rpx;
margin: auto;
margin-top: 20rpx;
height: 250rpx;
border-radius: 12rpx;
.pic {
width: 210rpx;
height: 210rpx;
border-radius: 10rpx;
margin-right: 20rpx;
border-radius: 20rpx;
image {
width: 210rpx;
height: 210rpx;
border-radius: 20rpx;
}
}
.cen {
width: 488rpx;
.cena {
font-weight: 700 !important;
font-size: 28rpx;
color: #3D3D3D;
line-height: 38rpx;
}
.cenb {
font-weight: 400;
font-size: 26rpx;
color: #3D3D3D;
line-height: 32rpx;
margin-top: 14rpx;
padding-right: 30rpx;
box-sizing: border-box;
image {
display: inline-block;
width: 22rpx;
height: 22rpx;
margin-right: 6rpx;
}
}
.juli{
font-size: 24rpx;
padding: 6rpx 10rpx;
box-sizing: border-box;
border: 1px solid #4D48B5;
color: #4D48B5;
width: 160rpx;
text-align: center;
background: #EFEEFF;
border-radius: 10rpx;
}
.cenc {
font-weight: 400;
font-size: 26rpx;
color: #3D3D3D;
line-height: 32rpx;
margin-top: 14rpx;
text {
display: inline-block;
padding: 4rpx 18rpx;
box-sizing: border-box;
border-radius: 20rpx;
}
.bu {
margin-left: 32rpx;
background: #D9D8FF;
color: #4D48B5;
font-size: 20rpx;
}
}
}
.right {
image {
width: 48rpx;
height: 48rpx;
margin-right: 10rpx;
}
text {
display: block;
font-weight: 400;
font-size: 20rpx;
color: #808080;
line-height: 28rpx;
width: 100rpx;
}
}
}
.listbox {
margin-top: 850rpx;
background: #FFFFFF;
border-radius: 64rpx 64rpx 0 0;
background: #eee;
box-shadow: 0rpx 10rpx 64rpx 0rpx rgba(0, 0, 0, 0.08);
padding-left: 32rpx;
padding-right: 32rpx;
box-sizing: border-box;
height: 40vh;
height: 81vh;
overflow-y: scroll;
padding-bottom: 400rpx;
.moshi {
@ -490,99 +895,6 @@
left: 0;
padding-bottom: 20rpx;
}
.list {
display: flex;
// justify-content: space-between;
margin-top: 44rpx;
border-bottom: 1px solid #eee;
padding-bottom: 16rpx;
.pic {
width: 134rpx;
height: 134rpx;
background-color: #D9D8FF;
border-radius: 10rpx;
margin-right: 20rpx;
border-radius: 20rpx;
image {
width: 100%;
height: 100%;
border-radius: 20rpx;
}
}
.cen {
width: 488rpx;
.cena {
font-weight: 700 !important;
font-size: 28rpx;
color: #3D3D3D;
line-height: 38rpx;
}
.cenb {
font-weight: 400;
font-size: 26rpx;
color: #3D3D3D;
line-height: 32rpx;
margin-top: 14rpx;
padding-right: 30rpx;
box-sizing: border-box;
image {
display: inline-block;
width: 22rpx;
height: 22rpx;
margin-right: 6rpx;
}
}
.cenc {
font-weight: 400;
font-size: 26rpx;
color: #3D3D3D;
line-height: 32rpx;
margin-top: 14rpx;
text {
display: inline-block;
padding: 4rpx 18rpx;
box-sizing: border-box;
border-radius: 20rpx;
}
.bu {
margin-left: 32rpx;
background: #D9D8FF;
color: #4D48B5;
font-size: 20rpx;
}
}
}
.right {
padding-top: 40rpx;
text-align: center;
image {
width: 48rpx;
height: 48rpx;
margin-bottom: 8rpx;
}
text {
display: block;
font-weight: 400;
font-size: 20rpx;
color: #808080;
line-height: 28rpx;
width: 100rpx;
}
}
}
}
}

View File

@ -1,13 +1,8 @@
<template>
<view class="page">
<u-navbar title="地图模式" :border-bottom="false" :background="bgc" title-color='#fff' back-icon-color="#fff"
<u-navbar title="门店详情" :border-bottom="false" :background="bgc" title-color='#000' back-icon-color="#000"
title-size='44' height='50'></u-navbar>
<view class="dtxs">
<map class='map' id="map" :latitude="latitude" :longitude="longitude" @markertap="handleMarkerClick"
:show-location="true" :markers="covers" :scale="mapScale" @regionchange="regionchange"/>
<image class="picimg" v-if="iconflag"
src="https://api.ccttiot.com/smartmeter/img/static/uEAmNMMt65U10qwijrsJ" mode=""></image>
</view>
<image src="https://api.ccttiot.com/smartmeter/img/static/usAJ4tIRtLh7lOQy5Ij6" class="bjimg" mode=""></image>
<view class="listbox" v-if="falga">
<view class="moshi">
<image src="https://api.ccttiot.com/smartmeter/img/static/uqv3e5ThWL8DqrRNBfoA" mode="aspectFit"
@ -22,40 +17,47 @@
</view>
</view>
</view>
<view class="pic">
<image :src="listobj.picture" mode="aspectFill"></image>
</view>
<view class="list_item" v-if="falgb">
<view class="list">
<view class="pic">
<image :src="listobj.picture" mode="aspectFill"></image>
</view>
<view class="cen">
<view class="cena" style="font-weight: 600;">
{{listobj.name == undefined ? '--' : listobj.name}}
<view class="" style="display: flex;justify-content: space-between;width: 100%;">
<view class="cena" style="font-weight: 600;">
<image src="https://api.ccttiot.com/smartmeter/img/static/uG3yQ6rqronIihzq1HaB" mode="aspectFit"></image> {{listobj.name == undefined ? '--' : listobj.name}}
</view>
<view class="right">
<image src="https://api.ccttiot.com/smartmeter/img/static/u4Q5lajsFuAv7YEzBFib" mode="aspectFit"
@click.stop="mapFun(item)"></image>
<image src="https://api.ccttiot.com/smartmeter/img/static/uPeCVStFHIF0rAhMKhlK" mode="aspectFit"
@click.stop="btntel(item)"></image>
</view>
</view>
<view class="cenb">
<image src="https://api.ccttiot.com/smartmeter/img/static/uHK2aJHvzEm3nbOPwpdr" mode="aspectFit"></image>
{{listobj.address == undefined ? '--' : listobj.address}}
</view>
<view class="cenc">
共享时间{{listobj.businessTimeStart == undefined ? '--' : listobj.businessTimeStart}}-{{listobj.businessTimeEnd == undefined ? '--' : listobj.businessTimeEnd}} <text
class="bu">{{listobj.availableDeviceCount == undefined ? '--' : listobj.availableDeviceCount}}台可共享</text>
营业时间{{listobj.businessTimeStart == undefined ? '--' : listobj.businessTimeStart}}-{{listobj.businessTimeEnd == undefined ? '--' : listobj.businessTimeEnd}}
</view>
</view>
</view>
<!-- <view class="chakan" @click="btnchak(listobj.storeId)">
<view class="">
本店共有{{listobj.deviceCount == undefined ? '--' : listobj.deviceCount}}台共享设备
</view>
<view class="">
查看 <u-icon name="arrow-right" color="#6863D9" size="24" style="margin-left: 10rpx;"></u-icon>
</view>
</view> -->
<view class="warp_box" style="width: 100%;height: 1040rpx;overflow: scroll;">
<view class="warp_box" style="width: 100%;
height: 540px;
overflow: scroll;
position: relative;
top: -100rpx;">
<view class="swiper" :current='curtitidx' @change="swiperchange" @scrolltolower="onReachBottom">
<view>
<view class="swiper-item ">
<view class="card_box" v-for="(item,index) in wateringList" :key="index">
<view class="card" @click="btnxq(item.deviceNo)">
<view class="card_right">
<image v-if="item.customPicture" :src="item.customPicture" mode="aspectFit"></image>
<image v-else :src="item.picture" mode="aspectFit"></image>
</view>
<view class="card_left">
<view class="card_left_tit">
{{item.deviceName}}
@ -78,10 +80,6 @@
S/N码{{item.deviceNo}}
</view>
</view>
<view class="card_right">
<image v-if="item.customPicture" :src="item.customPicture" mode="aspectFit"></image>
<image v-else :src="item.picture" mode="aspectFit"></image>
</view>
</view>
</view>
</view>
@ -95,14 +93,10 @@
</view>
</view>
<view class="anniu">
<view class="" @click="mapFun">
<image style="height: 41rpx;width: 38rpx;" class="picsm"
src="https://api.ccttiot.com/smartmeter/img/static/u9Z7DXlWfjJtIrq5OEty" mode="aspectFit"></image> 到这去
</view>
<view class="" style="color: #fff;background-color: #8883F0;" @click="scanQRCode">
<image class="picsm" src="https://api.ccttiot.com/smartmeter/img/static/uvrsmSxGunHTI9S51ujn"
mode="aspectFit"></image> 扫一扫
<view class="saoma" @click="scanQRCode">
<view>
<image src="https://api.ccttiot.com/smartmeter/img/static/uBh15vzRx6gV0wRQj7gi" mode="aspectFit"></image>
扫一扫
</view>
</view>
</view>
@ -126,7 +120,7 @@
mapaddress: '',
isMch: '',
bgc: {
backgroundColor: " #8883F0",
backgroundColor: "",
},
mapScale: 15,
mapContext: null,
@ -179,6 +173,22 @@
}
},
methods: {
//
btntel(){
uni.makePhoneCall({
phoneNumber: this.listobj.contactMobile,
success: function(res) {
console.log('拨打电话成功', res)
},
fail: function(err) {
console.error('拨打电话失败', err)
uni.showToast({
title: '未配置客服电话',
icon: 'none'
})
}
})
},
getlist() {
this.$u.get(`/app/device/listByStore/${this.storeId}?pageNum=${this.pagenum}&pageSize=${this.pagesize}`)
.then((res) => {
@ -536,12 +546,27 @@
background:#D9D8FF;
border-radius: 0rpx 0rpx 0rpx 0rpx;
}
.page {
width: 750rpx;
.bjimg{
width: 100%;
height: 176rpx;
position: fixed;
top: 0;
left: 0;
}
.pic {
width: 100%;
height: 434rpx;
image {
width: 100%;
height: 434rpx;
mode: "aspectFill";
}
}
.page {
// width: 750rpx;
// position: fixed;
// top: 0;
// left: 0;
.swiper {
.swiper-item {
height: 100%;
@ -553,6 +578,7 @@
.card {
display: flex;
justify-content:space-between;
margin-top: 20rpx;
width: 672rpx;
height: 250rpx;
@ -605,8 +631,7 @@
.card_right {
margin-top: 30rpx;
margin-left: auto;
margin-right: 40rpx;
margin-left: 40rpx;
image {
width: 180rpx;
@ -619,16 +644,15 @@
}
}
.list_item {
position: fixed;
top: 160rpx;
left: 50%;
-webkit-transform: translateX(-50%);
transform: translateX(-50%);
// position: fixed;
// top: 160rpx;
// left: 50%;
// -webkit-transform: translateX(-50%);
// transform: translateX(-50%);
width: 100%;
height: 91vh;
background: #f8f8f8;
box-shadow: 0rpx 10rpx 64rpx 0rpx rgba(0, 0, 0, 0.08);
border-radius: 20rpx;
margin: auto;
padding: 46rpx 40rpx;
box-sizing: border-box;
@ -675,43 +699,52 @@
;
}
}
.list {
display: flex;
padding-bottom: 16rpx;
justify-content: space-between;
align-items: center;
.pic {
width: 150rpx;
height: 150rpx;
border-radius: 20rpx;
image {
width: 150rpx;
height: 150rpx;
mode: "aspectFill";
margin-top: 10rpx;
border-radius: 20rpx;
}
}
width:100%;
height: 210rpx;
box-sizing: border-box;
border-radius: 20rpx;
padding: 0 20rpx;
background: #FFFFFF;
box-shadow: 0px 2px 12px 0px rgba(0, 0, 0, 0.15);
position: relative;
top: -100rpx;
left: 50%;
transform: translateX(-50%);
.cen {
margin-left: 20rpx;
margin-top: 30rpx;
width: 100%;
.right{
padding-top: 0;
image{
margin-right: 10rpx;
width: 58rpx;
height: 58rpx;
}
}
.cena {
image{
width: 44rpx;
height: 42rpx;
margin-right: 10rpx;
}
display: flex;
align-items: center;
font-weight: 500;
font-size: 30rpx;
color: #3D3D3D;
line-height: 38rpx;
}
.cenb {
font-weight: 400;
font-size: 26rpx;
color: #3D3D3D;
line-height: 32rpx;
margin-top: 14rpx;
image {
display: inline-block;
width: 22rpx;
@ -719,21 +752,18 @@
margin-right: 6rpx;
}
}
.cenc {
font-weight: 400;
font-size: 26rpx;
color: #3D3D3D;
line-height: 32rpx;
margin-top: 14rpx;
text {
display: inline-block;
padding: 4rpx 18rpx;
box-sizing: border-box;
border-radius: 20rpx;
}
.bu {
margin-left: 22rpx;
background: #D9D8FF;
@ -741,15 +771,12 @@
}
}
}
.right {
padding-top: 40rpx;
image {
width: 40rpx;
height: 40rpx;
}
text {
display: block;
font-weight: 400;
@ -773,10 +800,10 @@
.dtxs {
width: 100%;
height: 100vh;
position: fixed;
top: 0;
left: 0;
z-index: -1;
// position: fixed;
// top: 0;
// left: 0;
// z-index: -1;
.picimg {
width: 120rpx;
height: 120rpx;
@ -794,9 +821,9 @@
height: 186rpx;
width: 100%;
overflow-y: scroll;
position: fixed;
bottom: 0;
left: 0;
// position: fixed;
// bottom: 0;
// left: 0;
.saoyisao {
margin-top: 44rpx;
@ -850,16 +877,45 @@
padding: 0 76rpx;
width: 100%;
background-color: #fff;
position: fixed;
height: 160rpx;
top: 40vh;
left: 0;
// position: fixed;
// height: 160rpx;
// top: 40vh;
// left: 0;
padding-bottom: 20rpx;
}
}
}
.saoma {
width: 750rpx;
height: 166rpx;
background: #FFFFFF;
position: fixed;
left: 0;
bottom: 0;
padding-top: 22rpx;
border-radius: 54rpx 54rpx 0 0;
margin-top: 20rpx;
view {
text-align: center;
width: 676rpx;
height: 102rpx;
background: linear-gradient(270deg, #8883F0 0%, #8883F0 100%);
border-radius: 54rpx 54rpx 54rpx 54rpx;
font-weight: 500;
font-size: 40rpx;
color: #FFFFFF;
margin: auto;
line-height: 102rpx;
}
image {
width: 56rpx;
height: 56rpx;
vertical-align: middle;
margin-right: 10rpx;
margin-bottom: 10rpx;
}
}
.active {
border-bottom: 10rpx solid #D9D8FF;
border-radius: 7rpx;

View File

@ -61,7 +61,7 @@
<text v-if="detailobj.suitFeeType == 4">分时段计时收费</text></text>
</view>
<view class="nav" v-if="detailobj.suitFeeType == 2 || detailobj.suitFeeType == 3">
<text class="shen">使用度数</text><text class="qian">{{Number(detailobj.suitEndEle).toFixed(2) - Number(detailobj.suitStartEle),toFixed(2)}}</text>
<text class="shen">使用度数</text><text class="qian">{{Number(detailobj.suitEndEle).toFixed(2) - Number(detailobj.suitStartEle).toFixed(2)}}</text>
</view>
<view class="nav" v-else>
<text class="shen">套餐时长</text><text class="qian">{{detailobj.suitTime == undefined ? '--' : detailobj.suitTime}}

View File

@ -173,7 +173,8 @@
phonenumber:'',
iconflag: false,
xuanzeflag:false,
isStaff:null
isStaff:null,
dlflag:false
};
},
onLoad(option) {
@ -245,6 +246,7 @@
}
},
onShow() {
this.logins()
wx.openBluetoothAdapter({
success: function (res) {
console.log('蓝牙适配器初始化成功');
@ -254,7 +256,6 @@
console.error('蓝牙适配器初始化失败,可能是因为没有权限', err);
}
})
this.logins()
this.getad()
this.getzf()
this.gethuidaio()
@ -594,34 +595,38 @@
url: '/page_fenbao/statulist/nearby/index'
})
} else if (num == 6) {
if((this.type == 2 || this.type == 3) && this.isStaff == true){
this.xuanzeflag = true
}else if((this.type == 2 || this.type == 3) && this.isStaff != true){
if(this.phonenumber == ''){
this.huoqutelflag = true
this.xuanzeflag = false
if(this.dlflag == true){
if((this.type == 2 || this.type == 3) && this.isStaff == true){
this.xuanzeflag = true
}else if((this.type == 2 || this.type == 3) && this.isStaff != true){
if(this.phonenumber == ''){
this.huoqutelflag = true
this.xuanzeflag = false
}else{
this.xuanzeflag = false
uni.switchTab({
url: '/pages/index/index'
})
}
}else if(this.isStaff == true){
if(this.phonenumber == ''){
this.huoqutelflag = true
this.xuanzeflag = false
}else{
this.xuanzeflag = false
uni.navigateTo({
url: '/page_fenbao/hehuoren/shouye'
})
}
}else{
this.xuanzeflag = false
uni.switchTab({
url: '/pages/index/index'
})
}
}else if(this.isStaff == true){
if(this.phonenumber == ''){
this.huoqutelflag = true
this.xuanzeflag = false
}else{
this.xuanzeflag = false
uni.navigateTo({
url: '/page_fenbao/hehuoren/shouye'
uni.showToast({
title: '您当前没有权限进入',
icon: 'none',
duration: 1000
})
}
}else{
uni.showToast({
title: '您当前没有权限进入',
icon: 'none',
duration: 1000
})
}
} else if (num == 7) {
uni.navigateTo({
@ -841,6 +846,7 @@
if (res.code == 200) {
this.phonenumber = res.data.phonenumber
this.type = res.data.type
this.dlflag = true
this.isStaff = res.data.isStaff
this.isMch = res.data.isMch
uni.setStorageSync('userType', res.data)