1727 lines
41 KiB
Vue
1727 lines
41 KiB
Vue
<template>
|
||
<view class="content">
|
||
<view class="content-head">
|
||
<view class="padding-top-sm flex align-center" style="padding-bottom: 9px;">
|
||
<view v-if="XCXIsSelect != '否'" class="flex align-center justify-between margin-right-sm"
|
||
@tap="showCityList" style="line-height: 68rpx;">
|
||
<image src="../../static/liliao-1.png" class="dingwei-img"></image>
|
||
<view class="localName">{{ city }}</view>
|
||
</view>
|
||
<u-search class="flex-sub" placeholder="请输入技师名字" :focus="false" shape="square" v-model="artificerName"
|
||
:show-action="true" :animation="true" bg-color="#f5f5f5" color="#1A1A1A" @search="onSearch()"
|
||
action-text="搜索" @custom="onSearch()"></u-search>
|
||
</view>
|
||
</view>
|
||
<view class="liebiao" v-show="current === 0">
|
||
<view v-if="orderList.length" class="flex text-center flex-wrap list-view">
|
||
<view class="margin-bottom-sm radius touxiang-left">
|
||
<view class="flex align-center touxiang-left-view" v-if="item.status=='1'" v-for="(item, index) in orderList" :key='index'
|
||
@click="goOrder(item)">
|
||
<view class="touxiang-left-content">
|
||
<image class="touxiang-left-content-img" :src="item.artificerImg ? item.artificerImg : '../../static/logo.png'"
|
||
@click.stop="saveImgs(item.artificerImg)" mode="aspectFill"></image>
|
||
<image class="touxiang-frame" :src="item.technicianType=='3'?'../../static/vip/grade1.gif':item.technicianType=='4'?'../../static/vip/grade2.gif':'../../static/vip/grade3.gif'"></image>
|
||
|
||
</view>
|
||
<view class="list-right">
|
||
<view class="flex align-center" style="justify-content: start;">
|
||
<view class="flex align-center list-right-top">
|
||
<view class="list-right-top-view">
|
||
<view class="list-right-top-name">
|
||
{{ item.artificerName }}
|
||
</view>
|
||
<view class="keyuyue">
|
||
<view class="flex">
|
||
<view class="timea-fu">{{item.status == 1?"可服务":"休息中"}}</view>
|
||
<view class="timea-time" v-if="item.status == 1">{{item.time}}</view>
|
||
</view>
|
||
</view>
|
||
<!--<view class="keyuyue">
|
||
<view>
|
||
{{item.state == 1?"可服务":item.state == 2?"今日可约":"休息中"}}
|
||
</view>
|
||
<view v-if="item.status == 1 && item.time">{{ item.time
|
||
}}</view>
|
||
-->
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="flex align-center">
|
||
<image class="therapist-bottom-dingwei" src="../../static/dituzhaoren6.png"></image>
|
||
<view class="therapist-bottom-dingwei-text">
|
||
{{ item.distance }}
|
||
</view>
|
||
</view>
|
||
<view class="therapist-mian">
|
||
<view class="therapist-mian-top">
|
||
<view class="therap-pin">
|
||
<!--<image src="../../static/dituzhaoren3.png" mode="">
|
||
</image>-->
|
||
<span>评论</span>
|
||
<span class="therapist-mian-view-text">
|
||
{{ item.commentCount ? item.commentCount : 0 }}
|
||
</span>
|
||
</view>
|
||
<view class="therap-pin" >
|
||
<!--<image src="../../static/dituzhaoren4.png" mode="">
|
||
</image>-->
|
||
<span>收藏</span>
|
||
<span class="therapist-mian-view-text">
|
||
{{ item.collectCount ? item.collectCount : 0 }}
|
||
</span>
|
||
</view>
|
||
</view>
|
||
<view class="therapist-mian-bottom">
|
||
<view class="flex flex-wrap align-center" >
|
||
<image class="therapist-bottom-img" src="../../static/dituzhaoren5.png">
|
||
</image>
|
||
<view v-if="item.consortiaName" class="therapist-mian-bottom-text">{{item.consortiaName}}</view>
|
||
</view>
|
||
<view>
|
||
<view class="terap-button" v-if="item.status == 1" @click.stop="goOrder(item)">
|
||
确认
|
||
</view>
|
||
<view class="text-center text-sm" @click.stop="showTips()" v-else
|
||
style="background: #d9d9d9;color: #ffffff;width: 100%;border-radius: 30upx;height: 60upx;line-height: 60upx;margin-top: 10rpx;">
|
||
确认
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<empty v-if="orderList.length == 0"></empty>
|
||
</view>
|
||
<!-- 经验筛选 -->
|
||
<u-select v-model="Cityshow" :list="cityList" @confirm="getCity"></u-select>
|
||
</view>
|
||
</template>
|
||
<script>
|
||
import selectSwitchDitu from "@/components/xuan-switch/xuan-switch-ditu.vue";
|
||
import meTabs from "@/components/mescroll-uni/me-tabs/me-tabs.vue";
|
||
import empty from '@/components/empty.vue'
|
||
|
||
import RenDropdownFilter from '@/components/ren-dropdown-filter/ren-dropdown-filter.vue'
|
||
import commonConfig from 'common/config.js';
|
||
|
||
import * as webMap from 'utils/webMap.js';
|
||
import permision from "@/components/permission.js";
|
||
// 调用手机系统权限
|
||
// #ifdef APP-PLUS
|
||
// import permision from "@/components/permission.js";
|
||
// #endif
|
||
export default {
|
||
components: {
|
||
meTabs,
|
||
empty,
|
||
RenDropdownFilter,
|
||
selectSwitchDitu
|
||
},
|
||
data() {
|
||
return {
|
||
artificerName: '',
|
||
tpSel: 0,
|
||
tpCount: 0,
|
||
showTP: false,
|
||
Cityshow: false,
|
||
loading: true, // 是否显示骨架屏组件
|
||
defaultSelected: [],
|
||
value1: '',
|
||
value2: '',
|
||
value3: '',
|
||
game: [],
|
||
defaultIndex: [0, 0, 0],
|
||
filterData: [
|
||
[{
|
||
label: '推荐',
|
||
value: '',
|
||
}],
|
||
[{
|
||
label: '服务热度',
|
||
value: '0',
|
||
},
|
||
|
||
{
|
||
label: '从高到低',
|
||
value: '1',
|
||
},
|
||
{
|
||
label: '从低到高',
|
||
value: '2',
|
||
}
|
||
],
|
||
[{
|
||
label: '距离',
|
||
value: '0',
|
||
},
|
||
{
|
||
label: '从远到近',
|
||
value: '2',
|
||
},
|
||
{
|
||
label: '从近到远',
|
||
value: '1',
|
||
}
|
||
],
|
||
],
|
||
list: [{
|
||
name: '综合',
|
||
id: 1
|
||
}, {
|
||
name: '距离',
|
||
id: 2
|
||
}, {
|
||
name: '销量',
|
||
id: 3
|
||
}, {
|
||
name: '好评',
|
||
id: 4
|
||
}],
|
||
listIndex: 0,
|
||
city: '请选择城市',
|
||
orderList: [],
|
||
page: 1,
|
||
limit: 10,
|
||
token: '',
|
||
XCXIsSelect: '否',
|
||
isVip: false,
|
||
showModal: true,
|
||
arr: [],
|
||
tab: '',
|
||
cityList: [],
|
||
tablist: [],
|
||
tabIndex: 0,
|
||
orderIndex: 0,
|
||
current: 0,
|
||
|
||
myId: uni.getStorageSync('userId') ? uni.getStorageSync('userId') : '',
|
||
//地图相关
|
||
latitude: '43.86487',
|
||
longitude: '',
|
||
address: '',
|
||
mapScale: 16, // 地图默认放大倍数
|
||
markers: [], // 地图上markers列表
|
||
cmap: null, //当前的map对象
|
||
amap: null,
|
||
infoWindow: null,
|
||
marker: null,
|
||
socketConnect: null,
|
||
pointMap: {}, //点map
|
||
pointThread: null,
|
||
currentMarkerIndex: -1,
|
||
showPopup: false,
|
||
dataIndex:'',
|
||
technicianType:''
|
||
}
|
||
},
|
||
|
||
onLoad(e) {
|
||
let that = this
|
||
that.technicianType=e.technicianType
|
||
that.massageTypeId=e.massageTypeId
|
||
// that.getLocation();//低精度,快就完事了
|
||
// that.getLocation(true);//高精度,慢慢查询
|
||
uni.getStorage({
|
||
key: 'taocanDd',
|
||
success: (res) => {
|
||
that.dataIndex = res.data;
|
||
}
|
||
});
|
||
that.getTypeList();
|
||
uni.getLocation({
|
||
type: 'gcj02',
|
||
geocode: true, //设置该参数为true可直接获取经纬度及城市信息
|
||
highAccuracyExpireTime: 500,
|
||
success: function(res) {
|
||
console.log(res, '地理位置-----------------------》')
|
||
that.latitude = res.latitude
|
||
that.longitude = res.longitude
|
||
|
||
uni.setStorageSync('latitude', res.latitude)
|
||
uni.setStorageSync('longitude', res.longitude)
|
||
if (that.amap) {
|
||
that.amap.setCenter(new AMap.LngLat(res.latitude, res.longitude));
|
||
}
|
||
if (that.infoWindow) {
|
||
that.infoWindow.setPosition(new TMap.LatLng(res.latitude, res.longitude));
|
||
}
|
||
that.page = 1
|
||
that.getTypeList();
|
||
},
|
||
fail: function(e) {
|
||
console.log('获取地址失败1', e)
|
||
// #ifdef APP-PLUS
|
||
that.checkPermission();
|
||
// #endif
|
||
}
|
||
})
|
||
|
||
// 获取邀请码保存到本地
|
||
if (e.invitation) {
|
||
that.$queue.setData('inviterCode', e.invitation);
|
||
}
|
||
|
||
if (this.myId) {
|
||
that.$Request.getT('/app/common/type/235').then(res => { //报名成功通知
|
||
if (res.code == 0) {
|
||
if (res.data && res.data.value) {
|
||
that.arr.push(res.data.value)
|
||
}
|
||
}
|
||
})
|
||
that.$Request.getT('/app/common/type/236').then(res => { //活动即将开始提醒
|
||
if (res.code == 0) {
|
||
if (res.data && res.data.value) {
|
||
that.arr.push(res.data.value)
|
||
}
|
||
}
|
||
})
|
||
}
|
||
},
|
||
onShow() {
|
||
let that = this
|
||
that.getKTCityList();
|
||
that.XCXIsSelect = this.$queue.getData("XCXIsSelect");
|
||
that.city = uni.getStorageSync('city') ? uni.getStorageSync('city') : '请选择城市'
|
||
that.getTpCount();
|
||
that.getTpMy();
|
||
|
||
that.token = uni.getStorageSync('token')
|
||
if (uni.getStorageSync('token')) {
|
||
if (that.latitude && that.longitude) {
|
||
that.page = 1
|
||
that.getlist()
|
||
} else {
|
||
uni.getLocation({
|
||
type: 'gcj02',
|
||
highAccuracyExpireTime: 500,
|
||
geocode: true, //设置该参数为true可直接获取经纬度及城市信息
|
||
success: function(res) {
|
||
console.log(res, '地理位置')
|
||
that.latitude = res.latitude
|
||
that.longitude = res.longitude
|
||
that.page = 1
|
||
that.getTypeList();
|
||
that.getlist()
|
||
},
|
||
fail: function() {
|
||
console.log('获取地址失败2')
|
||
}
|
||
})
|
||
}
|
||
}
|
||
that.myId = uni.getStorageSync('userId')
|
||
// console.log(that.showModal, '------', that.myId)
|
||
// #ifdef MP-WEIXIN
|
||
//订阅
|
||
if (that.myId) {
|
||
that.getIsVip()
|
||
if (this.showModal) {
|
||
// this.openMsg()
|
||
}
|
||
}
|
||
// #endif
|
||
},
|
||
onReady() {
|
||
console.log('this ->', this, uni);
|
||
this.initMap();
|
||
//this.initMapPointThread();
|
||
},
|
||
methods: {
|
||
// 跳转订单
|
||
goOrder(e) {
|
||
console.log('授权', uni.getStorageSync('sendMsg'))
|
||
if (uni.getStorageSync('sendMsg')) {
|
||
console.log('授权+1')
|
||
wx.requestSubscribeMessage({
|
||
tmplIds: this.arr,
|
||
success(re) {
|
||
console.log(JSON.stringify(re), 111111111111)
|
||
var datas = JSON.stringify(re);
|
||
if (datas.indexOf("accept") != -1) {
|
||
console.log(re)
|
||
}
|
||
},
|
||
fail: (res) => {
|
||
console.log(res)
|
||
}
|
||
})
|
||
}else if (!this.token) {
|
||
uni.navigateTo({
|
||
url: '/pages/public/login'
|
||
});
|
||
} else if(this.dataIndex=='待支付'){
|
||
this.$queue.setData('getJishi',e);
|
||
uni.reLaunch({
|
||
url:'/my/order/payModifyDzhifu'
|
||
})
|
||
|
||
}else if(this.dataIndex=='支付'){
|
||
this.$queue.setData('getJishi',e);
|
||
uni.reLaunch({
|
||
url:'/my/order/payModify'
|
||
})
|
||
}else if(this.dataIndex=='充值'){
|
||
this.$queue.setData('getJishi',e);
|
||
uni.reLaunch({
|
||
url:'/my/wallet/index?artificerId='+e.artificerId+'&text='+'my'
|
||
})
|
||
}else if(this.dataIndex=='订单支付'){
|
||
this.$queue.setData('getJishi',e);
|
||
uni.reLaunch({
|
||
url:'/my/order/payModifyDd?artificerId='+e.artificerId+'&text='+'my'
|
||
})
|
||
}else if(this.dataIndex=='修改'){
|
||
this.$queue.setData('getJishi',e);
|
||
uni.reLaunch({
|
||
url:'/my/order/payModifyDzhifu?artificerId='+e.artificerId+'&text='+'my'
|
||
})
|
||
}else if(this.dataIndex=='我的套餐'){
|
||
this.$queue.setData('getJishi',e);
|
||
uni.reLaunch({
|
||
url:'/my/order/payModifyTcMy?artificerId='+e.artificerId+'&text='+'my'
|
||
})
|
||
}
|
||
},
|
||
switch1Change: function (e) {//地图和列表切换
|
||
var num= Number(e)
|
||
if(e==false){
|
||
this.current = 1;
|
||
}else{
|
||
this.current = 0;
|
||
}
|
||
console.log('switch1 发生 change 事件,携带值为', Number(e),e)
|
||
},
|
||
showTips() {
|
||
uni.showToast({
|
||
title: '技师已下线',
|
||
icon: 'none'
|
||
})
|
||
},
|
||
onClickItem(e) {
|
||
if (this.current != e) {
|
||
this.current = e;
|
||
}
|
||
},
|
||
showCityList() {
|
||
// #ifdef APP-PLUS
|
||
if (this.latitude === '' || this.longitude === '') {
|
||
this.checkPermission();
|
||
return;
|
||
}
|
||
// #endif
|
||
this.Cityshow = true;
|
||
},
|
||
async checkPermission() {
|
||
let status = permision.isIOS ? await permision.requestIOS('location') : await permision.requestAndroid(
|
||
'android.permission.ACCESS_FINE_LOCATION');
|
||
if (status === null || status === 1) {
|
||
status = 1;
|
||
} else if (status === 2) {
|
||
uni.showModal({
|
||
content: "系统定位已关闭",
|
||
confirmText: "确定",
|
||
showCancel: false,
|
||
success: function(res) {}
|
||
})
|
||
} else if (status.code) {
|
||
uni.showModal({
|
||
content: status.message
|
||
})
|
||
} else {
|
||
uni.showModal({
|
||
title: '定位服务已关闭',
|
||
content: "您需要打开定位权限,否则我们将无法获得到您附近的项目服务,导致我们无法为您提供服务,请到>设置>隐私>定位服务>中开启【盛安到家】定位权限",
|
||
confirmText: "设置",
|
||
success: function(res) {
|
||
if (res.confirm) {
|
||
permision.gotoAppSetting();
|
||
}
|
||
}
|
||
})
|
||
}
|
||
return status;
|
||
},
|
||
saveImgss(imgs, index) {
|
||
console.log(imgs, index)
|
||
// let that = this
|
||
let imgArr = imgs
|
||
// this.imgArr.push(imgs);
|
||
// console.log(this.imgArr)
|
||
// //预览图片
|
||
uni.previewImage({
|
||
urls: imgArr,
|
||
current: imgArr[index]
|
||
});
|
||
},
|
||
saveImgs(imgs) {
|
||
let imgArr = [];
|
||
imgArr.push(imgs);
|
||
// //预览图片
|
||
uni.previewImage({
|
||
urls: imgArr,
|
||
current: 0
|
||
});
|
||
},
|
||
saveTP() {
|
||
if (!this.token) {
|
||
uni.navigateTo({
|
||
url: '/pages/public/login'
|
||
});
|
||
return;
|
||
}
|
||
let userId = this.$queue.getData('userId');
|
||
let userName = this.$queue.getData('userName');
|
||
this.$queue.showLoading('投票中...');
|
||
this.$Request.postJson('/app/message/insertMessage', {
|
||
state: 11,
|
||
content: this.city,
|
||
userName: userName,
|
||
userId: userId
|
||
})
|
||
.then(res => {
|
||
if (res.code === 0) {
|
||
uni.showToast({
|
||
title: '投票成功!'
|
||
});
|
||
this.getTpCount();
|
||
this.getTpMy();
|
||
} else {
|
||
uni.hideLoading();
|
||
uni.showModal({
|
||
showCancel: false,
|
||
title: '投票失败',
|
||
content: res.msg
|
||
});
|
||
}
|
||
});
|
||
},
|
||
getTpMy() {
|
||
this.$Request.getT('/app/message/selectMessageByUserId?page=1&limit=1&state=11').then(res => {
|
||
if (res.code == 0) {
|
||
if (res.data && res.data.list && res.data.list.length > 0) {
|
||
this.tpSel = 1;
|
||
} else {
|
||
this.tpSel = 2;
|
||
}
|
||
}
|
||
});
|
||
},
|
||
getTpCount() {
|
||
this.$Request.getT('/app/message/selectCityCount?city=' + this.city).then(res => {
|
||
if (res.code == 0) {
|
||
this.tpCount = res.data ? res.data : 0;
|
||
}
|
||
});
|
||
},
|
||
getCity(e) {
|
||
console.log("得到的城市-------------》",e[0].label);
|
||
this.city = e[0].label;
|
||
uni.setStorageSync('city', this.city)
|
||
this.getKTCityList();
|
||
this.page = 1
|
||
this.getlist()
|
||
},
|
||
getKTCityList() {
|
||
let cityName;
|
||
// let cityName = uni.getStorageSync('city') ? uni.getStorageSync('city') : '请选择城市'
|
||
// if (cityName === '请选择城市') {
|
||
// return;
|
||
// }
|
||
this.$Request.getT('/app/trip/selectTripList').then(res => {
|
||
if (res.code == 0) {
|
||
this.cityList = [];
|
||
let isOpen = false
|
||
res.data.forEach((d, index) => {
|
||
if (cityName === d.city) {
|
||
isOpen = true;
|
||
}
|
||
let data = {}
|
||
data.label = d.city
|
||
data.value = index
|
||
this.cityList.push(data);
|
||
});
|
||
console.log("请求-----------------请求>",this.cityList)
|
||
if (!isOpen) {
|
||
// debugger;
|
||
this.orderList = []
|
||
this.showTP = true;
|
||
// uni.showToast({
|
||
// title: '当前城市暂未开通,请切换城市',
|
||
// duration: 2000,
|
||
// icon: 'none'
|
||
// });
|
||
} else {
|
||
this.showTP = false;
|
||
}
|
||
}
|
||
});
|
||
},
|
||
getTypeList() {
|
||
this.$Request.get("/app/dict/list", {
|
||
type: '服务类型'
|
||
}).then(res => {
|
||
if (res.code == 0) {
|
||
if (res.data) {
|
||
this.tablist = res.data
|
||
this.tabIndex = res.data[0].id;
|
||
this.page = 1;
|
||
this.getlist()
|
||
//开启地图线程
|
||
this.initMapPointThread();
|
||
}
|
||
}
|
||
});
|
||
},
|
||
|
||
// 开启订阅消息
|
||
openMsg() {
|
||
console.log('订阅消息')
|
||
var that = this
|
||
uni.getSetting({
|
||
withSubscriptions: true, //是否获取用户订阅消息的订阅状态,默认false不返回
|
||
success(ret) {
|
||
if (ret.subscriptionsSetting.itemSettings) {
|
||
uni.setStorageSync('sendMsg', true)
|
||
uni.openSetting({ // 打开设置页
|
||
success(rea) {
|
||
console.log(rea.authSetting)
|
||
}
|
||
});
|
||
} else { // 用户没有点击“总是保持以上,不再询问”则每次都会调起订阅消息
|
||
console.log(99999)
|
||
uni.setStorageSync('sendMsg', false)
|
||
uni.showModal({
|
||
title: '提示',
|
||
content: '为了更好的体验,请绑定消息推送',
|
||
confirmText: '确定',
|
||
cancelText: '取消',
|
||
success: function(res) {
|
||
if (res.confirm) {
|
||
wx.requestSubscribeMessage({
|
||
tmplIds: that.arr,
|
||
success(re) {
|
||
var datas = JSON.stringify(re);
|
||
if (datas.indexOf("accept") != -1) {
|
||
console.log(re)
|
||
// uni.setStorageSync('sendMsg', true)
|
||
}
|
||
},
|
||
fail: (res) => {
|
||
console.log(res)
|
||
}
|
||
})
|
||
// uni.setStorageSync('sendMsg', true)
|
||
console.log('确认')
|
||
that.showModal = false
|
||
} else if (res.cancel) {
|
||
console.log('取消')
|
||
// uni.setStorageSync('sendMsg', false)
|
||
that.showModal = true
|
||
}
|
||
}
|
||
})
|
||
}
|
||
}
|
||
})
|
||
},
|
||
getIsVip() {
|
||
this.$Request.get("/app/UserVip/isUserVip").then(res => {
|
||
if (res.code == 0) {
|
||
this.isVip = res.data
|
||
uni.setStorageSync('isVIP', res.data)
|
||
}
|
||
});
|
||
},
|
||
onSearch(e) {
|
||
// this.artificerName = e;
|
||
this.page = 1;
|
||
this.getlist()
|
||
},
|
||
getlist() {
|
||
let index = 2
|
||
let data = {
|
||
// id: curTab,
|
||
artificerName: this.artificerName,
|
||
classifyId: this.tabIndex,
|
||
page: this.page,
|
||
limit: this.limit,
|
||
massageTypeId: this.massageTypeId,
|
||
// condition: this.value1, //智能优选
|
||
// authentication: this.value2, //不限男女
|
||
by: index, //价格
|
||
latitude: this.latitude,
|
||
longitude: this.longitude,
|
||
city: this.city,
|
||
technicianType:this.technicianType
|
||
}
|
||
// console.log(data)
|
||
this.$Request.get("/app/artificer/selectArtificerList", data).then(res => {
|
||
this.loading = false;
|
||
if (res.code == 0) {
|
||
for (var i = 0; i < res.data.list.length; i++) {
|
||
if (res.data.list[i].lifePhoto) {
|
||
res.data.list[i].lifePhoto = res.data.list[i].lifePhoto.split(',')
|
||
}
|
||
if (res.data.list[i].distance > 1000) {
|
||
res.data.list[i].distance = (res.data.list[i].distance / 1000).toFixed(1) +
|
||
'km'
|
||
} else {
|
||
res.data.list[i].distance = (res.data.list[i].distance).toFixed(1) + 'm'
|
||
}
|
||
|
||
}
|
||
if (this.page == 1) {
|
||
this.orderList = res.data.list
|
||
} else {
|
||
this.orderList = [...this.orderList, ...res.data.list]
|
||
}
|
||
}
|
||
uni.stopPullDownRefresh();
|
||
})
|
||
},
|
||
// 切换菜单
|
||
tabChange() {
|
||
if (uni.getStorageSync('sendMsg')) {
|
||
console.log('授权+1')
|
||
wx.requestSubscribeMessage({
|
||
tmplIds: this.arr,
|
||
success(re) {
|
||
console.log(JSON.stringify(re), 111111111111)
|
||
var datas = JSON.stringify(re);
|
||
if (datas.indexOf("accept") != -1) {
|
||
// console.log(re)
|
||
}
|
||
},
|
||
fail: (res) => {
|
||
// console.log(res)
|
||
}
|
||
})
|
||
}
|
||
this.defaultIndex = [0, 0, 0]
|
||
// this.$refs.uDropdown.close();
|
||
this.page = 1
|
||
this.getlist()
|
||
},
|
||
|
||
// 筛选
|
||
change(index) {
|
||
|
||
// this.value1 = e[0][0].value
|
||
// this.value2 = e[1][0].value
|
||
// this.value3 = e[2][0].value
|
||
this.listIndex = index
|
||
this.page = 1
|
||
this.getlist()
|
||
},
|
||
// 选择城市
|
||
goSelectCity() {
|
||
// uni.navigateTo({
|
||
// url: '/pages/index/citys/citys'
|
||
// });
|
||
let that = this
|
||
uni.chooseLocation({
|
||
success: function(res) {
|
||
console.log('位置名称:' + res.name);
|
||
console.log('详细地址:' + res.address);
|
||
console.log('纬度:' + res.latitude);
|
||
console.log('经度:' + res.longitude);
|
||
that.latitude = res.latitude
|
||
that.longitude = res.longitude
|
||
uni.setStorageSync('latitude', res.latitude)
|
||
uni.setStorageSync('longitude', res.longitude)
|
||
that.selectCity(that.longitude, that.latitude);
|
||
}
|
||
});
|
||
},
|
||
selectCity(longitude, latitude) {
|
||
this.$Request.get('/app/Login/selectCity?lat=' + latitude + '&lng=' + longitude).then(res => {
|
||
if (res.code == 0) {
|
||
this.city = res.data.city ? res.data.city : '未知'
|
||
uni.setStorageSync('city', res.data.city)
|
||
this.page = 1
|
||
this.getlist()
|
||
}
|
||
});
|
||
},
|
||
// 乐享低价
|
||
goLowTaking() {
|
||
uni.navigateTo({
|
||
url: '/pages/index/order/lowTaking'
|
||
});
|
||
},
|
||
// 跳转游戏列表
|
||
goNav(url) {
|
||
if (uni.getStorageSync('sendMsg')) {
|
||
console.log('授权+1')
|
||
wx.requestSubscribeMessage({
|
||
tmplIds: this.arr,
|
||
success(re) {
|
||
console.log(JSON.stringify(re), 111111111111)
|
||
var datas = JSON.stringify(re);
|
||
if (datas.indexOf("accept") != -1) {
|
||
console.log(re)
|
||
}
|
||
},
|
||
fail: (res) => {
|
||
console.log(res)
|
||
}
|
||
})
|
||
}
|
||
if (url.indexOf('/pages/') !== -1) {
|
||
uni.navigateTo({
|
||
url
|
||
});
|
||
} else {
|
||
//#ifndef H5
|
||
uni.navigateTo({
|
||
url: '/pages/index/webView?url=' + url
|
||
});
|
||
//#endif
|
||
//#ifdef H5
|
||
window.location.href = url;
|
||
//#endif
|
||
}
|
||
},
|
||
// 跳转搜索
|
||
goSearch(index) {
|
||
if (uni.getStorageSync('sendMsg')) {
|
||
console.log('授权+1')
|
||
wx.requestSubscribeMessage({
|
||
tmplIds: this.arr,
|
||
success(re) {
|
||
// console.log(JSON.stringify(re), 111111111111)
|
||
var datas = JSON.stringify(re);
|
||
if (datas.indexOf("accept") != -1) {
|
||
console.log(re)
|
||
}
|
||
},
|
||
fail: (res) => {
|
||
console.log(res)
|
||
}
|
||
})
|
||
}
|
||
uni.navigateTo({
|
||
url: '/pages/index/search/index?index=' + index
|
||
});
|
||
},
|
||
|
||
//地图初始化,
|
||
getLocation(isHighAccuracy = false) {
|
||
console.log('获取地理位置,精度:', isHighAccuracy);
|
||
let that = this;
|
||
//获取地理坐标
|
||
uni.getLocation({
|
||
// type: 'wgs84',
|
||
type: 'gcj02',
|
||
highAccuracyExpireTime: isHighAccuracy ? 5000 : 500,
|
||
isHighAccuracy,
|
||
success: function(res) {
|
||
let longitude = res.longitude;
|
||
let latitude = res.latitude;
|
||
console.log('当前位置的经度:' + longitude);
|
||
console.log('当前位置的纬度:' + latitude);
|
||
getApp().globalData['longitude'] = longitude;
|
||
getApp().globalData['latitude'] = latitude;
|
||
console.log('定位成功', latitude, longitude);
|
||
if (that.amap) {
|
||
uni.amap.setCenter([longitude, latitude])
|
||
}
|
||
},
|
||
fail(res) {
|
||
console.log('定位失败!', res);
|
||
}
|
||
});
|
||
//读取缓存里面的经纬度
|
||
let longitude = getApp().globalData['longitude'] || 0;
|
||
let latitude = getApp().globalData['latitude'] || 0;
|
||
return {
|
||
latitude,
|
||
longitude
|
||
};
|
||
},
|
||
initMap() {
|
||
let amap = webMap.creatAMap('txMapContainer');
|
||
uni.amap = amap;
|
||
this.amap = amap;
|
||
let that = this;
|
||
setTimeout(() => {
|
||
uni.hideLoading();
|
||
this.current = 0;
|
||
uni.getLocation({
|
||
// type: 'wgs84',
|
||
type: 'gcj02',
|
||
highAccuracyExpireTime: 3000,
|
||
isHighAccuracy: true,
|
||
success: function(res) {
|
||
let longitude = res.longitude;
|
||
let latitude = res.latitude;
|
||
console.log('当前位置的经度:' + longitude);
|
||
console.log('当前位置的纬度:' + latitude);
|
||
console.log('定位成功', latitude, longitude);
|
||
if (amap) {
|
||
uni.amap.setCenter([longitude, latitude])
|
||
}
|
||
},
|
||
fail(res) {
|
||
console.log('定位失败!', res);
|
||
}
|
||
});
|
||
if (that.orderList.length > 0) {
|
||
let rmap = {};
|
||
let onLineArtificerList = this.orderList.filter((item) => item.status == 1);
|
||
onLineArtificerList.forEach(x => {
|
||
rmap[x.userId] = x.latitude + ',' + x.longitude; //没有给个签到坐标
|
||
});
|
||
console.log('在initMap初始化:', JSON.parse(JSON.stringify(rmap)));
|
||
this.pointMap = rmap;
|
||
that.creatMarker(rmap);
|
||
}
|
||
}, 500);
|
||
},
|
||
creatMarker(map) {
|
||
let that = this;
|
||
webMap.addMarker(uni.amap, map, this.orderList, (e, udata) => {
|
||
that.currentMarkerIndex = udata.userId;
|
||
that.showPopup = true;
|
||
});
|
||
},
|
||
updateMarker(map) {
|
||
this.creatMarker(map);
|
||
},
|
||
getUserId() {
|
||
return this.myId;
|
||
},
|
||
getBusinessId() {
|
||
// return '12345678900987654321';
|
||
//return this.massageTypeId;
|
||
return this.tabIndex;
|
||
// return '98';
|
||
},
|
||
getOrderByCurrentMarkerIndex(key = this.currentMarkerIndex) {
|
||
return ((this.orderList || []).find(x => x.userId == key) || {});
|
||
},
|
||
creatSocket() {
|
||
let deviceId = this.getBusinessId();
|
||
let socketConnect = uni.connectSocket({
|
||
url: commonConfig.WS_UPLOAD_MAP_PATH + deviceId,
|
||
data() {
|
||
return {
|
||
msg: ''
|
||
}
|
||
},
|
||
header: {
|
||
'content-type': 'application/json',
|
||
// 'token': token
|
||
},
|
||
method: 'GET',
|
||
success(res) {
|
||
// 这里是接口调用成功的回调,不是连接成功的回调,请注意
|
||
// uni.showLoading({
|
||
// title: '连接成功!'
|
||
// });
|
||
},
|
||
fail(err) {
|
||
// 这里是接口调用失败的回调,不是连接失败的回调,请注意
|
||
// uni.showLoading({
|
||
// title: '连接失败!'
|
||
// });
|
||
}
|
||
});
|
||
uni.onSocketOpen((res) => {
|
||
// uni.hideLoading()
|
||
// uni.showToast({
|
||
// icon: 'none',
|
||
// title: '连接成功'
|
||
// })
|
||
console.log('onOpen', res);
|
||
});
|
||
uni.onSocketError((err) => {
|
||
// this.connecting = false
|
||
// this.connected = false
|
||
// uni.hideLoading()
|
||
// uni.showModal({
|
||
// content: '网络较差,请稍后再试',
|
||
// showCancel: false
|
||
// })
|
||
console.log('onError', err);
|
||
});
|
||
uni.onSocketMessage((res) => {
|
||
let that = this;
|
||
console.log('onMessage', res)
|
||
let datas = JSON.parse(res.data)
|
||
// let data = {
|
||
// chat: {
|
||
// userHead: '../../static/logo.png'
|
||
// },
|
||
// content: datas.content,
|
||
// type: datas.type,
|
||
// sendType: datas.sendType
|
||
// }
|
||
// that.ListItem.push(data);
|
||
//解析点
|
||
this.pointMap = {};
|
||
switch (datas.type) {
|
||
case 'getCoordinate': {
|
||
console.log('坐标包:', JSON.parse(JSON.stringify(datas.data)));
|
||
let map = {};
|
||
let rmap = {};
|
||
let onLineArtificerList = this.orderList.filter((item) => item.status == 1);
|
||
onLineArtificerList.forEach(x => {
|
||
map[x.userId] = x;
|
||
let zb = datas.data[x.userId];
|
||
if (!zb) {
|
||
//datas.data[x.userId] = x.latitude + ',' + x.longitude; //没有给个签到坐标
|
||
rmap[x.userId] = x.latitude + ',' + x.longitude; //没有给个签到坐标
|
||
} else {
|
||
rmap[x.userId] = zb;
|
||
}
|
||
});
|
||
// let data = datas.data;
|
||
// let rdata = {};
|
||
|
||
// data.forEach(x => rdata[x.userId]);
|
||
|
||
//rmap = datas.data; //debug
|
||
console.log('坐标最终结果:', JSON.parse(JSON.stringify(rmap)));
|
||
this.pointMap = rmap;
|
||
that.creatMarker(rmap);
|
||
break;
|
||
}
|
||
default: {
|
||
|
||
}
|
||
}
|
||
|
||
});
|
||
uni.onSocketClose((res) => {
|
||
console.log('onClose', res)
|
||
console.log('2 - 关闭触发', uni.pointThread)
|
||
//this.closeSocket();
|
||
this.socketConnect = null;
|
||
this.pointThread = null;
|
||
uni.pointThread = null;
|
||
uni.userSocketConnect = null;
|
||
});
|
||
|
||
this.socketConnect = socketConnect;
|
||
uni.userSocketConnect = socketConnect;
|
||
},
|
||
sendMsg(msg) {
|
||
uni.sendSocketMessage({
|
||
data: JSON.stringify(msg),
|
||
success: (...e) => {
|
||
console.log('发送成功!', ...e);
|
||
},
|
||
fail: (...e) => {
|
||
console.log('发送失败!', ...e);
|
||
},
|
||
});
|
||
},
|
||
closeSocket() {
|
||
console.log('2-关闭 - closeSocket')
|
||
uni.closeSocket();
|
||
//temp1.pointThread
|
||
clearInterval(uni.pointThread);
|
||
},
|
||
initMapPointThread() {
|
||
let that = this;
|
||
//创建连接
|
||
if (!that.socketConnect) {
|
||
this.closeSocket();
|
||
//that.socketConnect = uni.userSocketConnect;
|
||
}
|
||
if (uni.userSocketConnect) {
|
||
this.closeSocket()
|
||
//that.socketConnect = uni.userSocketConnect;
|
||
}
|
||
setTimeout(x => {
|
||
console.log('重新开始');
|
||
that.creatSocket();
|
||
//开始循环
|
||
setTimeout(x => {
|
||
that.forSendMsg();
|
||
}, 500);
|
||
}, 500)
|
||
},
|
||
forSendMsg() {
|
||
let that = this;
|
||
if (!that.mapPointThreadIsRun) {
|
||
that.sendMsgFn();
|
||
let pointThread = setInterval(() => {
|
||
that.sendMsgFn();
|
||
}, 3 * 60 * 1000); //3 * 60 * 1000
|
||
this.pointThread = pointThread;
|
||
uni.pointThread = pointThread;
|
||
}
|
||
},
|
||
sendMsgFn() {
|
||
let that = this;
|
||
let userId = that.getUserId();
|
||
let businessId = that.getBusinessId();
|
||
let msg = {
|
||
sendType: "getCoordinate",
|
||
userId,
|
||
businessId,
|
||
rkey: `map:location:${businessId}:*`
|
||
}
|
||
that.sendMsg(msg);
|
||
},
|
||
},
|
||
onReachBottom: function() {
|
||
this.page = this.page + 1;
|
||
this.getlist()
|
||
},
|
||
onPullDownRefresh: function() {
|
||
this.page = 1;
|
||
this.getlist()
|
||
},
|
||
}
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
/deep/.u-drawer,/deep/.u-mask-show{
|
||
z-index:11 !important;
|
||
}
|
||
/deep/.u-drawer-content-visible{
|
||
z-index:99 !important;
|
||
}
|
||
.item-view-jianjie{
|
||
font-weight: 400;
|
||
font-size: 22rpx;
|
||
color: #848484;
|
||
margin:5px 0px;
|
||
display: -webkit-box;
|
||
-webkit-box-orient: vertical;
|
||
-webkit-line-clamp: 2; /* 显示的行数,可以根据需要修改 */
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
text-align: left;
|
||
}
|
||
.touxiang-frame{
|
||
position: absolute;
|
||
width: 100rpx;
|
||
height: 38rpx;
|
||
left: 44rpx;
|
||
top:140rpx;
|
||
}
|
||
.dituList{
|
||
width: 85%;
|
||
height: 173px;
|
||
display: flex;
|
||
flex-direction: column;
|
||
justify-content: space-around;
|
||
}
|
||
.liebiao{
|
||
height: 100vh;
|
||
margin-top: 55px;
|
||
display: flex;
|
||
flex-direction: column;
|
||
}
|
||
.content-head{
|
||
position: fixed;
|
||
top: 0rpx;
|
||
z-index: 999;
|
||
width: 100%;
|
||
background: #fff;
|
||
//background-image: url('../../static/topimg.png');
|
||
// background-image: linear-gradient(to bottom, rgba(255, 255, 255, 0), #f7f7f7), url('../../static/background-img.png');
|
||
// background-position: center center;
|
||
// background-repeat: no-repeat;
|
||
background-size: cover;
|
||
// overflow: auto;
|
||
}
|
||
.therapist-bottom-dingwei-text{
|
||
font-size: 29rpx;
|
||
color: #848485;
|
||
}
|
||
.therapist-bottom-dingwei{
|
||
width: 17.36rpx;
|
||
height: 20.14rpx;
|
||
margin-right:3px;
|
||
}
|
||
.therapist-bottom-img{
|
||
width: 22.22rpx;
|
||
height: 22.22rpx;
|
||
margin-right:3px;
|
||
}
|
||
.therapist-mian-bottom-text{
|
||
font-weight: bold;
|
||
font-size: 30rpx;
|
||
color: #222222;
|
||
}
|
||
.therapist-mian-bottom{
|
||
width: 100%;
|
||
display: flex;
|
||
flex-direction: row;
|
||
justify-content: space-between;
|
||
align-items: center;
|
||
margin: 5px 0px 3px 0px;
|
||
}
|
||
.therapist-mian-view-text span{
|
||
font-weight: 500;
|
||
font-size: 26rpx;
|
||
color: #222222;
|
||
}
|
||
.therapist-mian-view span{
|
||
font-weight: 400;
|
||
font-size: 26rpx;
|
||
color: #7C8187;
|
||
margin-right: 10px;
|
||
}
|
||
.therapist-mian-view image{
|
||
width: 28rpx;
|
||
height: 28rpx;
|
||
margin-right: 2px;
|
||
}
|
||
.therapist-mian-view{
|
||
display: flex;
|
||
flex-direction:row;
|
||
align-items: center;
|
||
}
|
||
.therapist-mian-top{
|
||
width: 100%;
|
||
display: flex;
|
||
flex-direction:row;
|
||
}
|
||
.therapist-mian{
|
||
width: 100%;
|
||
display: flex;
|
||
flex-direction:column;
|
||
}
|
||
.list-right-top-bottom{
|
||
width: 100%;
|
||
text-align: left;
|
||
font-weight: 400;
|
||
font-size: 25rpx;
|
||
color: #333333;
|
||
display: -webkit-box;
|
||
-webkit-box-orient: vertical;
|
||
-webkit-line-clamp: 2; /* 显示的行数,可以根据需要修改 */
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
}
|
||
.list-right-top-name{
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
white-space: nowrap;
|
||
text-align: left;
|
||
font-weight: bold;
|
||
font-size: 32rpx;
|
||
color: #13141A;
|
||
}
|
||
.keyuyue{
|
||
padding: 0rpx 10rpx;
|
||
height: 44rpx;
|
||
display: flex;
|
||
flex-direction: row;
|
||
align-items: center;
|
||
background: #eefdf8;
|
||
border-radius: 30rpx 20rpx 20rpx 30rpx ;
|
||
color:#8d500f;
|
||
font-size: 24rpx;
|
||
}
|
||
.timea-img{
|
||
background:#2dbe93 url('../../static/timea.png') 2rpx 1rpx;
|
||
background-size: 28rpx 28rpx;
|
||
background-repeat: no-repeat;
|
||
width: 30rpx;
|
||
height: 30rpx;
|
||
border-radius:8rpx;
|
||
margin-top: 8rpx;
|
||
}
|
||
.timea-fu{
|
||
font-size: 24rpx;
|
||
color: #2dbe93;
|
||
line-height: 44rpx;
|
||
margin-left: 8rpx;
|
||
margin-right: 5rpx;
|
||
}
|
||
.timea-time{
|
||
font-size: 25rpx;
|
||
color: #2dbe93;
|
||
line-height: 44rpx;
|
||
padding-right: 10rpx;
|
||
}
|
||
.keyuyue .keyuyue-btn{
|
||
width: 50%;
|
||
height: 100%;
|
||
font-weight: 400;
|
||
font-size: 17rpx;
|
||
text-align: center;
|
||
display: flex;
|
||
flex-direction: row;
|
||
align-items: center;
|
||
justify-content: center;
|
||
}
|
||
.keyuyue-jinri{
|
||
border-top-left-radius: 7rpx;
|
||
border-bottom-left-radius: 7rpx;
|
||
border-radius: 7rpx;
|
||
color: #fff;
|
||
background: linear-gradient(90deg, #019C88, #28BA92, #35C495);
|
||
}
|
||
.keyuyue-time{
|
||
border-top-right-radius: 7rpx;
|
||
border-bottom-right-radius: 7rpx;
|
||
color: #039E89;
|
||
background: #EBEBEB;
|
||
}
|
||
.list-right-top-view image{
|
||
width: 168.75rpx;
|
||
height: 40.97rpx;
|
||
}
|
||
.list-right-top-view{
|
||
width: 100%;
|
||
display: flex;
|
||
flex-direction: row;
|
||
align-items: center;
|
||
justify-content: space-between;
|
||
}
|
||
.list-right-top{
|
||
width: 100%;
|
||
display: flex;
|
||
flex-direction: column;
|
||
align-items: center;
|
||
}
|
||
.list-right{
|
||
width: 72%;
|
||
height: 100%;
|
||
display: flex;
|
||
flex-direction: column;
|
||
justify-content: space-between;
|
||
padding: 16rpx;
|
||
}
|
||
.zpmore_view {
|
||
position: absolute;
|
||
bottom: -20rpx;
|
||
left: 14rpx;
|
||
color: #f9f3d3;
|
||
background: linear-gradient(to right, #0a0c16, #4d4d53);
|
||
width: 130upx;
|
||
text-align: center;
|
||
border-radius: 30rpx;
|
||
height: 42rpx;
|
||
line-height: 42rpx;
|
||
font-size: 24rpx;
|
||
margin-left: 10rpx;
|
||
}
|
||
.zpmore_view_left{
|
||
width: 68.75rpx;
|
||
height: 29.86rpx;
|
||
}
|
||
.img-span{
|
||
padding: 1px 5px;
|
||
font-weight: 400;
|
||
font-size: 8px;
|
||
color: #FFFFFF;
|
||
background: linear-gradient(-90deg, #FF6F48, #FF9E69);
|
||
border-radius: 7px 0px 7px 0px;
|
||
position: absolute;
|
||
bottom: 0px;
|
||
right: 0;
|
||
margin-bottom: 5px;
|
||
margin-right: 5px;
|
||
}
|
||
// .zpmore_view_left image{
|
||
// position: absolute;
|
||
// bottom: 0px;
|
||
// right: 0px;
|
||
// margin: 0px 5px -16px 0px;
|
||
// width: 68.75rpx;
|
||
// height: 29.86rpx;
|
||
// }
|
||
.touxiang{
|
||
width: 202.08rpx;
|
||
height: 306.94rpx;
|
||
}
|
||
.touxiang-left-content{
|
||
width: 180rpx;
|
||
//width: 235.08rpx;
|
||
height: auto;
|
||
border-radius: 10rpx;
|
||
position: relative;
|
||
}
|
||
.touxiang-left-content-img{
|
||
width: 150rpx;
|
||
height: 150rpx;
|
||
border-radius:120rpx;
|
||
margin: 14rpx 22rpx;
|
||
}
|
||
.touxiang-left-view{
|
||
width: 100%;
|
||
height: 126px;
|
||
border-radius: 18rpx;
|
||
align-items: flex-start;
|
||
background: #fff;
|
||
margin-bottom: 12px;
|
||
padding-bottom: 10px;
|
||
justify-content: space-between;
|
||
padding: 10rpx;
|
||
}
|
||
|
||
.touxiang-left{
|
||
width: 100%;
|
||
/* padding: 10px; */
|
||
display: flex;
|
||
flex-direction: column;
|
||
// justify-content: space-between;
|
||
align-items: baseline;
|
||
}
|
||
.list-view{
|
||
// margin-top: 52px;
|
||
padding: 0 20rpx;
|
||
height: 100%;
|
||
justify-content: space-between;
|
||
}
|
||
|
||
/deep/.justify-between{
|
||
// width: 100px;
|
||
// height: 32px;
|
||
line-height: 32px;
|
||
border-radius: 4px;
|
||
margin-left: 10px;
|
||
}
|
||
.padding-top-sm{
|
||
width: 95%;
|
||
margin: 0 auto;
|
||
display: flex;
|
||
flex-direction: row;
|
||
align-items: center;
|
||
justify-content: space-between;
|
||
}
|
||
/deep/.page-box{
|
||
background: none !important;
|
||
}
|
||
/deep/.u-action{
|
||
display: none;
|
||
}
|
||
.content{
|
||
width: 100%;
|
||
height: 100vh;
|
||
background-position: center center;
|
||
background-repeat: no-repeat;
|
||
background-size: cover;
|
||
// overflow: auto;
|
||
}
|
||
/deep/.u-content{
|
||
border-radius: 30px !important;
|
||
}
|
||
.flex-sub{
|
||
width: 353rpx;
|
||
height: 63rpx !important;
|
||
}
|
||
.localName{
|
||
margin-left: 4rpx;
|
||
font-weight: bold;
|
||
font-size: 33rpx;
|
||
color: #333333;
|
||
}
|
||
.dingwei-img{
|
||
width:33.33rpx;
|
||
height:37.5rpx;
|
||
}
|
||
page {
|
||
background-color: #F7F7F7;
|
||
}
|
||
|
||
.jishi_name {
|
||
max-width: 80rpx;
|
||
text-overflow: ellipsis;
|
||
white-space: nowrap;
|
||
overflow: hidden;
|
||
}
|
||
|
||
.zz_view {
|
||
color: #333333;
|
||
font-size: 24rpx;
|
||
padding: 6rpx 10rpx;
|
||
border-radius: 10rpx;
|
||
}
|
||
|
||
.zpmore_view {
|
||
position: absolute;
|
||
bottom: -20rpx;
|
||
left: 14rpx;
|
||
color: #f9f3d3;
|
||
background: linear-gradient(to right, #0a0c16, #4d4d53);
|
||
width: 130upx;
|
||
text-align: center;
|
||
border-radius: 30rpx;
|
||
height: 42rpx;
|
||
line-height: 42rpx;
|
||
font-size: 24rpx;
|
||
margin-left: 10rpx;
|
||
}
|
||
|
||
.byy_view {
|
||
background: #ebebeb;
|
||
width: 100upx;
|
||
text-align: center;
|
||
border-radius: 50rpx;
|
||
height: 40rpx;
|
||
line-height: 40rpx;
|
||
font-size: 24rpx;
|
||
color: #000000;
|
||
// border: 3upx solid #999999;
|
||
margin-top: 6rpx;
|
||
margin-left: 40rpx;
|
||
}
|
||
|
||
.kfw_view {
|
||
background: #ffaa00;
|
||
width: 100upx;
|
||
text-align: center;
|
||
border-radius: 50rpx;
|
||
height: 40rpx;
|
||
line-height: 40rpx;
|
||
font-size: 24rpx;
|
||
color: #FFFFFF;
|
||
margin-top: 6rpx;
|
||
margin-left: 40rpx;
|
||
}
|
||
|
||
.kyy_view {
|
||
background: #096f4b;
|
||
width: 100upx;
|
||
text-align: center;
|
||
border-radius: 50rpx;
|
||
height: 40rpx;
|
||
line-height: 40rpx;
|
||
font-size: 24rpx;
|
||
color: #FFFFFF;
|
||
margin-top: 6rpx;
|
||
margin-left: 40rpx;
|
||
}
|
||
|
||
.bg {
|
||
background: #FFFFFF;
|
||
}
|
||
|
||
.ytp_view {
|
||
background: #e3e3e3;
|
||
width: 400rpx;
|
||
border-radius: 10rpx;
|
||
font-size: 28rpx;
|
||
text-align: center;
|
||
height: 80rpx;
|
||
line-height: 80rpx;
|
||
color: #848484;
|
||
margin-top: 40rpx;
|
||
}
|
||
|
||
.tp_view {
|
||
background: #ee6c54;
|
||
width: 400rpx;
|
||
border-radius: 10rpx;
|
||
font-size: 28rpx;
|
||
text-align: center;
|
||
height: 80rpx;
|
||
line-height: 80rpx;
|
||
color: #FFFFFF;
|
||
margin-top: 40rpx;
|
||
}
|
||
|
||
.sticky-tabs {
|
||
z-index: 990;
|
||
position: sticky;
|
||
top: var(--window-top);
|
||
// background-color: #fff;
|
||
}
|
||
|
||
/* // 使用mescroll-uni,则top为0 */
|
||
.mescroll-uni,
|
||
/deep/.mescroll-uni {
|
||
.sticky-tabs {
|
||
top: 0;
|
||
}
|
||
}
|
||
|
||
.demo-tip {
|
||
padding: 18upx;
|
||
font-size: 24upx;
|
||
text-align: center;
|
||
}
|
||
|
||
.line_s {
|
||
display: inline-flex;
|
||
width: 10rpx;
|
||
height: 10rpx;
|
||
background: #1AD566;
|
||
border-radius: 50%;
|
||
margin-right: 10rpx;
|
||
}
|
||
|
||
.line_x {
|
||
display: inline-flex;
|
||
width: 10rpx;
|
||
height: 10rpx;
|
||
background: #000000;
|
||
border-radius: 50%;
|
||
margin-right: 10rpx;
|
||
}
|
||
|
||
.box {
|
||
// border: 3rpx solid #005dff;
|
||
background: #E8FAE1;
|
||
color: #096f4b;
|
||
padding: 5rpx 15rpx;
|
||
font-size: 26rpx;
|
||
letter-spacing: 2rpx;
|
||
border-radius: 8rpx;
|
||
// margin-top: 10rpx;
|
||
margin-right: 8upx;
|
||
}
|
||
|
||
.actve {
|
||
font-size: 30rpx;
|
||
font-family: PingFang SC;
|
||
font-weight: 800;
|
||
color: #20C675;
|
||
}
|
||
|
||
.tabview1 {
|
||
// width: 686upx;
|
||
// height: 100upx;
|
||
background: #FFFFFF;
|
||
// z-index: 99;
|
||
// display: flex;
|
||
// line-height: 100upx;
|
||
|
||
.tabview {
|
||
// width: 686upx;
|
||
// // height: 100upx;
|
||
border-radius: 24rpx 24rpx 0 0;
|
||
// margin-top: -50upx;
|
||
// z-index: 99;
|
||
display: flex;
|
||
line-height: 100upx;
|
||
|
||
.tabItem_sel {
|
||
font-size: 32upx;
|
||
font-family: PingFang SC;
|
||
font-weight: 800;
|
||
color: #ffffff;
|
||
background: linear-gradient(to right, #223845, #00a85b);
|
||
flex: 1;
|
||
text-align: center;
|
||
}
|
||
|
||
.tabItem {
|
||
font-size: 32upx;
|
||
font-family: PingFang SC;
|
||
color: #333333;
|
||
flex: 1;
|
||
text-align: center;
|
||
}
|
||
}
|
||
|
||
.tabsx {
|
||
width: 686upx;
|
||
border-radius: 24rpx;
|
||
padding-bottom: 10rpx;
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: space-between;
|
||
padding: 20rpx 30rpx;
|
||
font-size: 26rpx;
|
||
|
||
.active {
|
||
color: #20C675;
|
||
font-size: 30rpx;
|
||
font-weight: bold;
|
||
}
|
||
}
|
||
}
|
||
|
||
.aa {
|
||
background: linear-gradient(to right, #223845, #00a85b);
|
||
width: 46px;
|
||
text-align: center;
|
||
height: 24px;
|
||
line-height: 24px;
|
||
margin-left: 4px;
|
||
color: #ffffff;
|
||
box-shadow: 0 0 3px #dddddd;
|
||
border-radius: 4px;
|
||
}
|
||
|
||
.bb {
|
||
width: 46px;
|
||
text-align: center;
|
||
height: 24px;
|
||
line-height: 24px;
|
||
margin-left: 4px;
|
||
color: #666666;
|
||
border-radius: 4px;
|
||
background-color: #f7f7f7;
|
||
}
|
||
|
||
//地图标点样式
|
||
/deep/.custom-content-marker {
|
||
width: 70px;
|
||
height: 70px;
|
||
|
||
|
||
.marker_border {
|
||
//border: black solid;
|
||
width: 20px;
|
||
height: 20px;
|
||
padding: 5px;
|
||
background: white;
|
||
box-shadow: 0px 5px 10px #888888;
|
||
border-radius: 50%;
|
||
}
|
||
|
||
.marker_foot {
|
||
// height: 50px;
|
||
// width: 50px;
|
||
// background: black;
|
||
// transform: rotate(45deg);
|
||
// position: absolute;
|
||
// top: 50px;
|
||
// overflow: hidden;
|
||
}
|
||
}
|
||
|
||
/deep/.custom-content-marker img {
|
||
width: 100%;
|
||
height: 100%;
|
||
border-radius: 50%;
|
||
}
|
||
.make-now{
|
||
background: linear-gradient(90deg, rgb(1, 156, 136), rgb(15, 167, 139), rgb(53, 196, 149));
|
||
color: rgb(255, 255, 255);
|
||
width: 200rpx;
|
||
border-radius: 15px;
|
||
height: 30px;
|
||
line-height: 30px;
|
||
margin-top: 5px;
|
||
}
|
||
.therap-pin{
|
||
display: flex;
|
||
align-items: flex-end;
|
||
margin-right: 10rpx;
|
||
}
|
||
.therap-pin span:nth-child(2){
|
||
color: #019c88;
|
||
}
|
||
.therap-pin span:nth-child(1){
|
||
color: #666;
|
||
margin-right: 10rpx;
|
||
}
|
||
.terap-button{
|
||
background: linear-gradient(90deg, #019C88, #0FA78B, #35C495);
|
||
color: #ffffff;
|
||
width:130rpx;
|
||
height: 60rpx;
|
||
border-radius: 10upx;
|
||
line-height: 58rpx;
|
||
}
|
||
</style>
|