开关
This commit is contained in:
parent
172b902132
commit
50a612a61f
|
@ -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;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -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;
|
||||
|
|
|
@ -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}}
|
||||
|
|
|
@ -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)
|
||||
|
|
Loading…
Reference in New Issue
Block a user