| | |
| | | <script setup> |
| | | import { onLaunch, onShow, onHide } from "@dcloudio/uni-app"; |
| | | import { wxLoginApi } from './api/index.js' |
| | | onLaunch(() => { |
| | | |
| | | //用户打开小程序默认授权 |
| | | function wxLogin(){ |
| | | uni.removeStorageSync('openId'); |
| | | if(!uni.getStorageSync('openId')){ |
| | | wx.login({ |
| | |
| | | }) |
| | | }, |
| | | fail:(e) =>{ |
| | | uni.showToast({ |
| | | title: '登录失败,请退出重试!', |
| | | duration: 2000 |
| | | }); |
| | | console.log(e) |
| | | } |
| | | }) |
| | | } |
| | | } |
| | | |
| | | //申请获取用户位置权限 |
| | | let userLocation = { |
| | | lat:'', |
| | | lon:'', |
| | | } |
| | | function getUserLocation(){ |
| | | // 请求用户授权,第一次进入会有位置授权的提示 |
| | | uni.authorize({ |
| | | scope: 'scope.userLocation', |
| | | success() { |
| | | console.log("成功授权位置信息1") |
| | | storageLocation() |
| | | }, |
| | | fail() { |
| | | console.log("用户拒绝授权位置信息,再次提示用户授权") |
| | | showToast() |
| | | } |
| | | }) |
| | | //获取用户位置并存储 |
| | | function storageLocation(){ |
| | | uni.getLocation({ |
| | | type:'gcj02', |
| | | isHighAccuracy:true, |
| | | success:(res) =>{ |
| | | userLocation.lat = res.latitude |
| | | userLocation.lon = res.longitude |
| | | uni.setStorageSync('userLocation',JSON.stringify(userLocation)) |
| | | }, |
| | | fail:() =>{ |
| | | showToast() |
| | | } |
| | | }) |
| | | } |
| | | //用户拒绝授权 |
| | | function showToast(){ |
| | | uni.showModal({ |
| | | title: "请求授权当前位置", |
| | | content: "我们需要获取地理位置信息,为您获取附近站点信息!", |
| | | confirmText: "前往设置", |
| | | success: (res) => { |
| | | if (res.confirm) { |
| | | uni.openSetting({ |
| | | success:(res1) =>{ //打开设置成功 |
| | | if (res1.authSetting['scope.userLocation']){ |
| | | console.log('用户二次授权成功') |
| | | storageLocation() |
| | | }else{ |
| | | showToast() |
| | | console.log('用户拒绝授权') |
| | | } |
| | | }, |
| | | }) |
| | | }else{ |
| | | uni.showToast({ |
| | | title: '请先授权!', |
| | | duration: 2000, |
| | | icon:'none' |
| | | }); |
| | | showToast() |
| | | } |
| | | }, |
| | | }); |
| | | } |
| | | } |
| | | onLaunch(async() => { |
| | | await wxLogin() |
| | | await getUserLocation() |
| | | }); |
| | | onShow(() => { |
| | | console.log("App Show"); |
| | |
| | | export function setAddressDefaultApi(id){ |
| | | return request(`/userAddress/editDefault?id=${id}`,{},'GET') |
| | | } |
| | | //获取设备站点列表 |
| | | //获取设备列表 |
| | | export function searchFacilityApi(data){ |
| | | return request('/waterFacility/search',data,'POST') |
| | | } |
| | | //获取设备站点、营业网点列表 |
| | | export function siteApi(data){ |
| | | return request('/waterDrinkingSite/getSearchList',data,'POST') |
| | | } |
| | | //修改用户信息 |
| | | export function editUserInfoApi(data){ |
| | | return request('/userArchives/modify',data,'POST') |
| | | } |
| | | //微信支付 |
| | | export function wxPayApi(data){ |
| | | return request('/pay/service/wxPay',data,'POST') |
| | | } |
| | | //余额记录 |
| | | export function balanceChangeApi(data){ |
| | | return request('/userCapitalChange/search',data,'POST') |
| | | } |
| | | //消费记录 |
| | | export function paymentChangeApi(date){ |
| | | return request(`/paymentRecords/getListByUser?date=${date}`,{},'GET') |
| | | } |
| | | |
| | |
| | | } |
| | | }, |
| | | { |
| | | "path" : "pages/paymentRecord/index", |
| | | "style": { |
| | | "navigationStyle":"custom" |
| | | } |
| | | }, |
| | | { |
| | | "path" : "pages/scanWater/index", |
| | | "style": { |
| | | "navigationStyle":"custom" |
| | |
| | | "style": { |
| | | "navigationStyle":"custom" |
| | | } |
| | | }, |
| | | { |
| | | "path" : "pages/station/index", |
| | | "style": { |
| | | "navigationStyle":"custom" |
| | | } |
| | | } |
| | | ], |
| | | "globalStyle": { |
| | |
| | | userPhone:'', |
| | | remark:'', |
| | | }) |
| | | function toScan(){ |
| | | // 调用二维码扫描接口 |
| | | uni.scanCode({ |
| | | scanType: ['qrCode'], |
| | | success: function (res) { |
| | | console.log('条码内容:' + res.result); |
| | | form.value.waterCardNumber = res.result |
| | | } |
| | | }); |
| | | } |
| | | async function submit(){ |
| | | await creatUserArchive(form.value).then((res) =>{ |
| | | if(res.code == 200){ |
| | | uni.showToast({ |
| | | title: '绑定成功', |
| | | title: '添加成功!', |
| | | image: '../../static/images/other/success.svg', |
| | | duration:500 |
| | | }) |
| | |
| | | <view class="form-item card-item"> |
| | | <text>卡号:</text> |
| | | <input v-model="form.waterCardNumber" placeholder="请输入卡号"/> |
| | | <image src="../../static/images/addCard/code.png" alt=""></image> |
| | | <image @click="toScan()" src="../../static/images/addCard/code.png" alt=""></image> |
| | | </view> |
| | | <view class="form-item"> |
| | | <text>姓名:</text> |
| | |
| | | <text>联系方式:</text> |
| | | <input v-model="form.userPhone" placeholder="请输入手机号"/> |
| | | </view> |
| | | <!-- <view class="form-item"> |
| | | <text>区域:</text> |
| | | <input v-model="form.waterCardNumber" placeholder="请选择区域"/> |
| | | </view> |
| | | <view class="form-item"> |
| | | <text>地址:</text> |
| | | <input v-model="form.waterCardNumber" placeholder="请输入地址"/> |
| | | </view> --> |
| | | <view class="form-item"> |
| | | <text>备注:</text> |
| | | <input v-model="form.remark" placeholder="请输入内容"/> |
| | |
| | | <script setup> |
| | | import { ref } from 'vue' |
| | | import { balanceChangeApi } from '../../api/index.js' |
| | | //返回 |
| | | function navBackTo(){ |
| | | uni.navigateBack() |
| | | } |
| | | async function getBalanceList(){ |
| | | await balanceChangeApi().then((res) =>{ |
| | | if(res.code == 200){ |
| | | // banlanceList.value = res.data.list |
| | | } |
| | | }) |
| | | } |
| | | const banlanceList = ref([1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]) |
| | | </script> |
| | | <template> |
| | |
| | | </view> |
| | | <view class="item-info"> |
| | | <view class="info-name">{{item.facilityName}}</view> |
| | | <view class="info-addr"> |
| | | <view class="info-addr" @click="openMap(item.lat,item.lon)"> |
| | | <text class="addr-text">地址:{{item.address}}</text> |
| | | <view> |
| | | <image src="../../static/images/index/icon22.png" alt=''></image> |
| | |
| | | <script setup> |
| | | import { onMounted, ref } from 'vue' |
| | | import { searchFacilityApi } from '../../api/index.js' |
| | | const deviceList = ref([ |
| | | {facilityName:'清源直饮水',address:'重庆市北碚区蔡家岗街道工业互联网产业园',distance:'30.12'}, |
| | | {facilityName:'清源直饮水',address:'重庆市北碚区蔡家岗街道',distance:'30.12'}, |
| | | {facilityName:'清源直饮水',address:'重庆市北碚区蔡家岗街道',distance:'30.12'}, |
| | | ]) |
| | | const latitudeUser = ref() |
| | | const longitudeUser = ref() |
| | | // 根据经纬度计算距离,根据经纬度计算距离,参数分别为第一点的纬度,经度;第二点的纬度,经度 |
| | | function getDistances(lat1, lng1, lat2, lng2) { |
| | | const deviceList = ref([]) |
| | | const userLocation = ref() |
| | | //获取设备信息 |
| | | async function getFacilityList(){ |
| | | await searchFacilityApi({limit:20,page:1}).then((res1) =>{ |
| | | if(res1.code == 200){ |
| | | deviceList.value = [] |
| | | res1.data.list.forEach((item) =>{ |
| | | //计算用户与饮水设备距离 |
| | | let preDistance = getDistances(userLocation.value.lat,userLocation.value.lon,item.latitude,item.longitude) |
| | | deviceList.value.push({ |
| | | facilityName:item.facilityName, |
| | | address:item.address, |
| | | distance:preDistance.km, |
| | | lat:item.latitude, |
| | | lon:item.longitude, |
| | | }) |
| | | }) |
| | | console.log('deviceList.value',deviceList.value) |
| | | } |
| | | }) |
| | | } |
| | | // 根据经纬度计算距离,根据经纬度计算距离,参数分别为第一点的纬度,经度(用户);第二点的纬度,经度(设备) |
| | | function getDistances(lat1, lon1, lat2, lon2) { |
| | | let EARTH_RADIUS = 6378.137;// 地球半径 |
| | | let radLat1 = lat1 * Math.PI / 180.0; //lat1 * Math.PI / 180.0=>弧度计算 |
| | | let radLat2 = lat2 * Math.PI / 180.0; |
| | | let a = radLat1 - radLat2; |
| | | let b = lng1 * Math.PI / 180.0 - lng2 * Math.PI / 180.0; |
| | | let b = lon1 * Math.PI / 180.0 - lon2 * Math.PI / 180.0; |
| | | let s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) + Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2))); |
| | | s = s * EARTH_RADIUS; |
| | | s = Math.round(s * 10000) / 10000;// 输出为公里 |
| | | return { m: s * 1000, km: Number(s.toFixed(2)) } |
| | | } |
| | | onMounted(async() =>{ |
| | | uni.getLocation({type: 'gcj02'}).then(async(res) =>{ |
| | | console.log('位置',res) |
| | | latitudeUser.value = res.latitude |
| | | longitudeUser.value = res.longitude |
| | | |
| | | await searchFacilityApi({limit:20,page:1}).then((res) =>{ |
| | | if(res.code == 200){ |
| | | // deviceList.value = [] |
| | | res.data.list.forEach((item) =>{ |
| | | |
| | | let preDistance = getDistances(latitudeUser.value,106.4003121,item.latitude,item.longitude) |
| | | deviceList.value.push({ |
| | | facilityName:item.facilityName, |
| | | address:item.address, |
| | | distance:preDistance.km |
| | | }) |
| | | }) |
| | | console.log('deviceList.value',deviceList.value) |
| | | } |
| | | }) |
| | | //打开地图导航 |
| | | function openMap(lat,lon){ |
| | | uni.openLocation({ |
| | | latitude: parseFloat(lat), |
| | | longitude: parseFloat(lon), |
| | | scale:18 |
| | | }) |
| | | } |
| | | onMounted(async() =>{ |
| | | userLocation.value = JSON.parse(uni.getStorageSync('userLocation')) |
| | | console.log('storage',userLocation.value) |
| | | await getFacilityList() |
| | | }) |
| | | </script> |
| | | |
| | |
| | | * 会员卡相关 |
| | | */ |
| | | const cardInfo = ref({ |
| | | id:'', |
| | | userName:'', |
| | | headImg:'', |
| | | |
| | |
| | | //获取会员卡信息 |
| | | async function getInfo(){ |
| | | let res = await getUserInfo() |
| | | console.log('res',res.data) |
| | | cardInfo.value.userName = res.data.userInfo.userName |
| | | cardInfo.value.headImg = res.data.userInfo.headImg |
| | | cardInfo.value.userPhone = res.data.userInfo.userPhone |
| | | if(res.data.userInfo.waterCardNumber){ |
| | | let res1 = await getVipInfoApi() |
| | | cardInfo.value.waterCardNumber = res1.data.cardNumber |
| | | if(res1.data.cardType == 1){ |
| | | cardInfo.value.balance = res1.data.balance |
| | | }else if(res1.data.cardType == 2){ |
| | | cardInfo.value.count = res1.data.count |
| | | if(res.code == 200){ |
| | | console.log('res',res.data) |
| | | cardInfo.value.userName = res.data.userInfo.userName |
| | | cardInfo.value.headImg = res.data.userInfo.headImg |
| | | cardInfo.value.userPhone = res.data.userInfo.userPhone |
| | | cardInfo.value.id = res.data.userInfo.id |
| | | if(res.data.userInfo.waterCardNumber){ |
| | | let res1 = await getVipInfoApi() |
| | | cardInfo.value.waterCardNumber = res1.data.cardNumber |
| | | if(res1.data.cardType == 1){ |
| | | cardInfo.value.balance = res1.data.balance |
| | | }else if(res1.data.cardType == 2){ |
| | | cardInfo.value.count = res1.data.count |
| | | } |
| | | isVip.value = true |
| | | }else{ |
| | | isVip.value = false |
| | | } |
| | | isVip.value = true |
| | | }else{ |
| | | isVip.value = false |
| | | uni.setStorageSync('userInfo',JSON.stringify(cardInfo.value)) |
| | | } |
| | | uni.setStorageSync('userInfo',JSON.stringify(cardInfo.value)) |
| | | } |
| | | /** |
| | | * 扫码取水相关 |
| | |
| | | uni.scanCode({ |
| | | scanType: ['qrCode'], |
| | | success: function (res) { |
| | | console.log('条码类型:' + res.scanType); |
| | | console.log('条码内容:' + res.result); |
| | | uni.navigateTo({ |
| | | url:'/pages/scanWater/index' |
| | |
| | | */ |
| | | const functionList = ref([ |
| | | {text:'余额记录',icon:'../../static/images/index/icon31.png',url:'/pages/balanceRecord/index'}, |
| | | {text:'消费记录',icon:'../../static/images/index/icon32.png',url:''}, |
| | | {text:'消费记录',icon:'../../static/images/index/icon32.png',url:'/pages/paymentRecord/index'}, |
| | | {text:'充值记录',icon:'../../static/images/index/icon33.png',url:''}, |
| | | {text:'账户共享',icon:'../../static/images/index/icon34.png',url:''}, |
| | | {text:'优惠卷',icon:'../../static/images/index/icon35.png',url:''}, |
| | |
| | | }) |
| | | } |
| | | } |
| | | //获取用户地理位置 |
| | | async function getUserLocation(){ |
| | | wx.getLocation({ |
| | | type: 'wgs84', |
| | | success(res){ |
| | | const latitude = res.latitude |
| | | const longitude = res.longitude |
| | | const speed = res.speed |
| | | const accuracy = res.accuracy |
| | | }, |
| | | fail(e){ |
| | | console.log('e',e) |
| | | } |
| | | }) |
| | | console.log('location') |
| | | } |
| | | onMounted( async() =>{ |
| | | getTopHeight() |
| | | // await getInfo() |
| | | // await getUserLocation() |
| | | }) |
| | | onShow(async() =>{ |
| | | await getInfo() |
| | |
| | | <image class="user-img" src='../../static/images/index/hend1.png' alt=''></image> |
| | | <text>{{cardInfo.userName}}</text> |
| | | <image class="user-more"src="../../static/images/index/back.png"></image> |
| | | <view class="user-add-card" @click="navTo('/pages/addCard/index')"> |
| | | <image src='../../static/images/index/vip-add.png' alt=''></image> |
| | | <text>添加会员卡</text> |
| | | </view> |
| | | </view> |
| | | <view class="card"> |
| | | <image class="card-bg" src="../../static/images/index/card11.png" alt=""></image> |
| | | <view class="card-content"> |
| | | <view class="card-left"> |
| | | <view class="left-top"> |
| | |
| | | </view> |
| | | <view class="card-right"> |
| | | <view class="card-right-top"> |
| | | <view @click="navTo('/pages/addCard/index')"> |
| | | <!-- <view @click="navTo('/pages/addCard/index')"> |
| | | <image src='../../static/images/index/vip-add.png' alt=''></image> |
| | | <span>添加会员卡</span> |
| | | </view> |
| | | <span>金额卡</span> |
| | | <text>添加会员卡</text> |
| | | </view> --> |
| | | <text>金额卡</text> |
| | | <text>{{cardInfo.balance}}元</text> |
| | | </view> |
| | | <view @click="navTo('/pages/recharge/index')"> |
| | | <span>余额:</span> |
| | | <span class="card-balance">{{cardInfo.balance}}</span> |
| | | <span>元</span> |
| | | </view> |
| | | <view class="card-right-bottom" @click="navTo('/pages/recharge/index')">充值</view> |
| | | </view> |
| | | </view> |
| | | </view> |
| | |
| | | <view class="service-box"> |
| | | <view class="service-title"><text>服务指南</text></view> |
| | | <view class="service-content"> |
| | | <view class="service-bg"> |
| | | <view class="service-bg" @click="navTo('/pages/station/index')"> |
| | | <view> |
| | | <image src="../../static/images/index/icon51.png" alt=""></image> |
| | | <text>附近站点</text> |
| | |
| | | </view> |
| | | </view> |
| | | </view> |
| | | |
| | | <!-- 微信授权弹窗 --> |
| | | <!-- <uni-popup ref="popupRef" background-color="#fff"> |
| | | <view class="popup-content"> |
| | | <text class="popup-title">微信登录</text> |
| | | <view class="hr"></view> |
| | | <view class="img-box"><img src="../../static/images/login/logo.png" alt="" class="img"/></view> |
| | | <view class="info-box"> |
| | | <view class="info-text1">青源直饮水平台申请获取以下权限:</view> |
| | | <view class="hr2"></view> |
| | | <view class="info-text2">· 获得你的公开信息(昵称、头像、地区及性别)</view> |
| | | <view class="button-box"> |
| | | <button class="button1" @click="popupRef.close('bottom')">取消</button> |
| | | <button class="button2" @click="wxLoginFn()">确定</button> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | </uni-popup> --> |
| | | </view> |
| | | </template> |
| | | <style lang="scss" scoped> |
| | |
| | | padding-left:15rpx; |
| | | box-sizing: border-box; |
| | | margin-bottom: 14rpx; |
| | | display:flex; |
| | | position:relative; |
| | | .user-img{ |
| | | width:90rpx; |
| | | height:90rpx; |
| | |
| | | width: 12rpx; |
| | | height: 28rpx; |
| | | } |
| | | .user-add-card{ |
| | | display:flex; |
| | | align-items:center; |
| | | height:40rpx; |
| | | font-size:22rpx; |
| | | background:linear-gradient(to right,#B1D9FD,#65A7FD); |
| | | border-radius:50rpx; |
| | | padding: 0 8rpx; |
| | | position: absolute; |
| | | bottom:0; |
| | | right:0; |
| | | image{ |
| | | width:28rpx; |
| | | height:28rpx; |
| | | margin-right:10rpx; |
| | | } |
| | | } |
| | | } |
| | | .card{ |
| | | width: 100%; |
| | | height: 290rpx; |
| | | background-image: url("../../static/images/index/card1.png"); |
| | | background-repeat: no-repeat; |
| | | background-size: 100% 100%; |
| | | position:relative; |
| | | .card-bg{ |
| | | height:290rpx; |
| | | width:100%; |
| | | top:0; |
| | | position: absolute; |
| | | z-index:1; |
| | | } |
| | | .card-content{ |
| | | width: 100%; |
| | | height: 100%; |
| | |
| | | font-weight: 300; |
| | | font-size: 30rpx; |
| | | color: #FFFFFF; |
| | | z-index:100; |
| | | .card-left{ |
| | | height:100%; |
| | | display: flex; |
| | | justify-content:space-between; |
| | | flex-direction:column; |
| | | align-items:flex-start; |
| | | z-index:100; |
| | | .left-top{ |
| | | display: flex; |
| | | flex-direction: column; |
| | |
| | | height:70rpx; |
| | | } |
| | | text{ |
| | | font-weight: 300; |
| | | font-weight:400; |
| | | font-size: 36rpx; |
| | | color: #FFFFFF; |
| | | } |
| | | } |
| | | view:last-child{ |
| | | margin-left:10rpx; |
| | | font-size: 26rpx; |
| | | font-weight:500; |
| | | } |
| | | } |
| | | } |
| | |
| | | align-items:flex-end; |
| | | flex-direction: column; |
| | | height:100%; |
| | | z-index:100; |
| | | .card-right-top{ |
| | | align-items: center; |
| | | align-items:flex-end; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | view{ |
| | | background-color: #fff; |
| | | color: #5EA1FA; |
| | | border-radius:20rpx; |
| | | padding: 5rpx 8rpx; |
| | | align-items: center; |
| | | display: flex; |
| | | justify-content: space-around; |
| | | font-size:24rpx; |
| | | margin-right:10rpx; |
| | | image{ |
| | | width:28rpx; |
| | | height:28rpx; |
| | | margin-right:10rpx; |
| | | } |
| | | flex-direction: column; |
| | | font-size:34rpx; |
| | | text:last-child{ |
| | | font-weight:500; |
| | | } |
| | | } |
| | | .card-balance{ |
| | | font-weight:600; |
| | | .card-right-bottom{ |
| | | width:137rpx; |
| | | height:56rpx; |
| | | background:linear-gradient(to right,#65A7FD ,#B1D9FD); |
| | | border-radius:50rpx; |
| | | text-align: center; |
| | | line-height: 56rpx; |
| | | color:#212DDE; |
| | | font-weight: 400; |
| | | } |
| | | } |
| | | } |
| | |
| | | <script setup> |
| | | import{ ref ,onMounted} from 'vue' |
| | | import { wxPayApi } from '../../api/index.js' |
| | | |
| | | const choosedMoney = ref() |
| | | const disabled = ref(true) |
| | |
| | | const payMethod = ref() |
| | | const payList = ref([ |
| | | // {text:"支付宝支付",value:1,checked:true,img:'../../static/images/recharge/pay.png'}, |
| | | {text:"微信支付",value:2,checked:false,img:'../../static/images/recharge/wx.png'}, |
| | | {text:"余额",value:3,checked:false,img:'../../static/images/recharge/balance.png'}, |
| | | {text:"微信支付",value:2,checked:true,img:'../../static/images/recharge/wx.png'}, |
| | | // {text:"余额",value:3,checked:false,img:'../../static/images/recharge/balance.png'}, |
| | | ]) |
| | | function choosePay(index1){ |
| | | payList.value.forEach((item,index) =>{ |
| | | if(item.checked == true){ |
| | | item.checked = false |
| | | } |
| | | }) |
| | | payList.value[index1].checked = true |
| | | payMethod.value = payList.value[index1].value |
| | | } |
| | | function submit(){ |
| | | // function choosePay(index1){ |
| | | // payList.value.forEach((item,index) =>{ |
| | | // if(item.checked == true){ |
| | | // item.checked = false |
| | | // } |
| | | // }) |
| | | // payList.value[index1].checked = true |
| | | // payMethod.value = payList.value[index1].value |
| | | // } |
| | | async function submit(){ |
| | | let money = '' |
| | | if(disabled.value){ |
| | | money = choosedMoney.value |
| | | }else{ |
| | | money = otherMoney.value |
| | | } |
| | | console.log('money',money) |
| | | await wxPayApi({businessType:1,tradeAmount:money}).then((res) =>{ |
| | | console.log('reswxpay',res) |
| | | |
| | | //调用微信官方支付接口弹出付款界面,输入密码扣款 |
| | | wx.requestPayment({ |
| | | //预支付订单信息 |
| | | // appId: res.data.appId, |
| | | timeStamp: res.data.timeStamp, //时间戳 |
| | | nonceStr: res.data.nonceStr, //随机串 |
| | | package: res.data.package, //prepay_id |
| | | signType: res.data.signType, //签名算法MD5 |
| | | paySign: res.data.paySign ,//微信签名 |
| | | success (res) { |
| | | if (res.errMsg == "requestPayment:ok"){ |
| | | console.log('支付成功', res) |
| | | }else{ |
| | | console.log('支付失败') |
| | | } |
| | | }, |
| | | fail (res) { |
| | | console.log('支付失败', res) |
| | | } |
| | | }) |
| | | }) |
| | | |
| | | |
| | | } |
| | | </script> |
| | | <template> |
| | |
| | | </view> |
| | | </view> |
| | | <view class="pay-methods"> |
| | | <view class="money-title"> |
| | | <!-- <view class="money-title"> |
| | | <view class="title-icon"></view> |
| | | <view class="title-text">请选择支付方式</view> |
| | | </view> |
| | | </view> --> |
| | | <view class="methods-list"> |
| | | <block v-for="(item,index) in payList"> |
| | | <view class="pay-item"> |
| | |
| | | <image :src="item.img" alt=""></image> |
| | | <view>{{item.text}}</view> |
| | | </view> |
| | | <radio :value="item.value" :checked="item.checked" @click="choosePay(index)"/> |
| | | <radio :value="item.value" :checked="item.checked"/> |
| | | </view> |
| | | </block> |
| | | </view> |
| | |
| | | url:'/pages/preSendWater/index' |
| | | }) |
| | | } |
| | | const isComplete = ref(true) |
| | | const isComplete = ref(false) |
| | | const isActive = ref({borderBottom:`3px solid #226AC9`}) |
| | | function swatch(val){ |
| | | if((val == 1 && !isComplete.value) || (val == 2 && isComplete.value)){ |
| | |
| | | <script setup> |
| | | import { onMounted, ref } from 'vue' |
| | | |
| | | import { editUserInfoApi,getUserInfo } from '../../api/index.js' |
| | | const isEdit = ref(false) |
| | | const editForm = ref({id:'',userName:'',userPhone:''}) |
| | | const userInfo = ref(JSON.parse(uni.getStorageSync('userInfo'))) |
| | | function edit(){ |
| | | editForm.value.id = userInfo.value.id |
| | | editForm.value.userName = userInfo.value.userName |
| | | editForm.value.userPhone = userInfo.value.userPhone |
| | | isEdit.value = true |
| | | } |
| | | function cancel(){ |
| | | isEdit.value = false |
| | | editForm.vlaue = {id:'',userName:'',userPhone:''} |
| | | } |
| | | async function submitEdit(){ |
| | | await editUserInfoApi(editForm.value).then(async(res) =>{ |
| | | |
| | | if(res.code == 200){ |
| | | uni.showToast({ |
| | | title: '修改成功!', |
| | | duration: 2000, |
| | | }); |
| | | await getUserInfo().then((res) =>{ |
| | | userInfo.value.userName = res.data.userInfo.userName |
| | | userInfo.value.userPhone = res.data.userInfo.userPhone |
| | | uni.setStorageSync('userInfo',JSON.stringify(userInfo.value)) |
| | | }) |
| | | }else{ |
| | | uni.showToast({ |
| | | title: '请求错误!请重试', |
| | | duration: 2000, |
| | | icon:'none' |
| | | }); |
| | | } |
| | | isEdit.value = false |
| | | editForm.vlaue = {id:'',userName:'',userPhone:''} |
| | | }) |
| | | } |
| | | </script> |
| | | <template> |
| | | <view class="container"> |
| | |
| | | <view class="content"> |
| | | <view class="info-box"> |
| | | <view class="info-up"> |
| | | <view> |
| | | <view class="info-img"> |
| | | <text>头像</text> |
| | | <image src='../../static/logo.png' alt=''></image> |
| | | </view> |
| | | <view> |
| | | <view class="info-name"> |
| | | <text>用户名称</text> |
| | | <text class="info-value">{{userInfo.userName}}</text> |
| | | <view> |
| | | <input v-if="isEdit" v-model="editForm.userName" placeholder="请输入新用户名"/> |
| | | <text v-else class="info-value">{{userInfo.userName}}</text> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | <view class="info-list"> |
| | |
| | | <view class="item"> |
| | | <text>联系方式</text> |
| | | <view> |
| | | <text>{{userInfo.userPhone}}</text> |
| | | <image class="edit"src="../../static/images//other/more.png" alt=''></image> |
| | | <input v-if="isEdit" v-model="editForm.userPhone" placeholder="请输入新联系方式"/> |
| | | <text v-else>{{userInfo.userPhone}}</text> |
| | | <!-- <image class="edit"src="../../static/images//other/more.png" alt=''></image> --> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | <view class="subBtn">确认修改</view> |
| | | <view v-if="!isEdit" @click="edit()" class="subBtn">修改</view> |
| | | <view v-if="isEdit" @click="cancel()" class="btn btn1">取消</view> |
| | | <view v-if="isEdit" @click="submitEdit()" class="btn btn2">确认修改</view> |
| | | </view> |
| | | </view> |
| | | </template> |
| | |
| | | background:linear-gradient(to top,#FFFFFF,#E8EFFF); |
| | | padding-top:36rpx; |
| | | position: relative; |
| | | box-sizing: border-box; |
| | | .info-value{ |
| | | font-size:32rpx; |
| | | color: #777777; |
| | | } |
| | | .edit{ |
| | | margin-left:15rpx; |
| | | width: 20rpx; |
| | | height:28rpx; |
| | | } |
| | | // .edit{ |
| | | // margin-left:15rpx; |
| | | // width: 20rpx; |
| | | // height:28rpx; |
| | | // } |
| | | .info-box{ |
| | | width: 100%; |
| | | //该页面公用input样式 |
| | | input{ |
| | | border-radius: 10rpx; |
| | | border:1px solid rgba(101, 156, 244, 0.2); |
| | | padding:5rpx 10rpx; |
| | | box-shadow: 0 0 12rpx 1rpx rgba(101, 156, 244, 0.2); |
| | | color: #777777; |
| | | height:50rpx; |
| | | line-height:50rpx; |
| | | width:300rpx; |
| | | } |
| | | .info-up{ |
| | | height:308rpx; |
| | | width:100%; |
| | |
| | | box-sizing: border-box; |
| | | font-size: 32rpx; |
| | | color: #343434; |
| | | view:first-child{ |
| | | .info-img{ |
| | | width:100%; |
| | | display: flex; |
| | | justify-content:space-between; |
| | |
| | | border-radius: 50rpx; |
| | | } |
| | | } |
| | | view:last-child{ |
| | | .info-name{ |
| | | width:100%; |
| | | display: flex; |
| | | justify-content:space-between; |
| | |
| | | bottom:100rpx; |
| | | left:32rpx; |
| | | } |
| | | .btn{ |
| | | width: 200rpx; |
| | | height: 70rpx; |
| | | border-radius: 32rpx; |
| | | text-align: center; |
| | | line-height: 70rpx; |
| | | letter-spacing:3rpx; |
| | | font-weight: 300; |
| | | font-size: 36rpx; |
| | | position: absolute; |
| | | bottom:100rpx; |
| | | } |
| | | .btn1{ |
| | | color:#5EA1FA; |
| | | background:#FFFFFF; |
| | | position: absolute; |
| | | left:130rpx; |
| | | border:2rpx solid #5EA1FA; |
| | | } |
| | | .btn2{ |
| | | color: #FFFFFF; |
| | | background:#5EA1FA; |
| | | position: absolute; |
| | | right:130rpx; |
| | | } |
| | | } |
| | | } |
| | | </style> |
| | |
| | | function searchFacilityApi(data) { |
| | | return util_request.request("/waterFacility/search", data, "POST"); |
| | | } |
| | | function siteApi(data) { |
| | | return util_request.request("/waterDrinkingSite/getSearchList", data, "POST"); |
| | | } |
| | | function editUserInfoApi(data) { |
| | | return util_request.request("/userArchives/modify", data, "POST"); |
| | | } |
| | | function wxPayApi(data) { |
| | | return util_request.request("/pay/service/wxPay", data, "POST"); |
| | | } |
| | | function paymentChangeApi(date) { |
| | | return util_request.request(`/paymentRecords/getListByUser?date=${date}`, {}, "GET"); |
| | | } |
| | | exports.creatUserArchive = creatUserArchive; |
| | | exports.deleteAddressApi = deleteAddressApi; |
| | | exports.editAddressApi = editAddressApi; |
| | | exports.editUserInfoApi = editUserInfoApi; |
| | | exports.getAddressApi = getAddressApi; |
| | | exports.getRegionApi = getRegionApi; |
| | | exports.getUserInfo = getUserInfo; |
| | | exports.getVipInfoApi = getVipInfoApi; |
| | | exports.paymentChangeApi = paymentChangeApi; |
| | | exports.searchAddress = searchAddress; |
| | | exports.searchFacilityApi = searchFacilityApi; |
| | | exports.setAddressDefaultApi = setAddressDefaultApi; |
| | | exports.siteApi = siteApi; |
| | | exports.wxLoginApi = wxLoginApi; |
| | | exports.wxPayApi = wxPayApi; |
| | |
| | | "./pages/addCard/index.js"; |
| | | "./pages/userInfo/index.js"; |
| | | "./pages/balanceRecord/index.js"; |
| | | "./pages/paymentRecord/index.js"; |
| | | "./pages/scanWater/index.js"; |
| | | "./pages/recharge/index.js"; |
| | | "./pages/sendWater/index.js"; |
| | |
| | | "./pages/addressLocate/index.js"; |
| | | "./pages/success/index.js"; |
| | | "./pages/facilityList/index.js"; |
| | | "./pages/station/index.js"; |
| | | } |
| | | const _sfc_main = { |
| | | __name: "App", |
| | | setup(__props) { |
| | | common_vendor.onLaunch(() => { |
| | | function wxLogin() { |
| | | common_vendor.index.removeStorageSync("openId"); |
| | | if (!common_vendor.index.getStorageSync("openId")) { |
| | | common_vendor.wx$1.login({ |
| | |
| | | }); |
| | | }, |
| | | fail: (e) => { |
| | | common_vendor.index.showToast({ |
| | | title: "登录失败,请退出重试!", |
| | | duration: 2e3 |
| | | }); |
| | | console.log(e); |
| | | } |
| | | }); |
| | | } |
| | | } |
| | | let userLocation = { |
| | | lat: "", |
| | | lon: "" |
| | | }; |
| | | function getUserLocation() { |
| | | common_vendor.index.authorize({ |
| | | scope: "scope.userLocation", |
| | | success() { |
| | | console.log("成功授权位置信息1"); |
| | | storageLocation(); |
| | | }, |
| | | fail() { |
| | | console.log("用户拒绝授权位置信息,再次提示用户授权"); |
| | | showToast(); |
| | | } |
| | | }); |
| | | function storageLocation() { |
| | | common_vendor.index.getLocation({ |
| | | type: "gcj02", |
| | | isHighAccuracy: true, |
| | | success: (res) => { |
| | | userLocation.lat = res.latitude; |
| | | userLocation.lon = res.longitude; |
| | | common_vendor.index.setStorageSync("userLocation", JSON.stringify(userLocation)); |
| | | }, |
| | | fail: () => { |
| | | showToast(); |
| | | } |
| | | }); |
| | | } |
| | | function showToast() { |
| | | common_vendor.index.showModal({ |
| | | title: "请求授权当前位置", |
| | | content: "我们需要获取地理位置信息,为您获取附近站点信息!", |
| | | confirmText: "前往设置", |
| | | success: (res) => { |
| | | if (res.confirm) { |
| | | common_vendor.index.openSetting({ |
| | | success: (res1) => { |
| | | if (res1.authSetting["scope.userLocation"]) { |
| | | console.log("用户二次授权成功"); |
| | | storageLocation(); |
| | | } else { |
| | | showToast(); |
| | | console.log("用户拒绝授权"); |
| | | } |
| | | } |
| | | }); |
| | | } else { |
| | | common_vendor.index.showToast({ |
| | | title: "请先授权!", |
| | | duration: 2e3, |
| | | icon: "none" |
| | | }); |
| | | showToast(); |
| | | } |
| | | } |
| | | }); |
| | | } |
| | | } |
| | | common_vendor.onLaunch(async () => { |
| | | await wxLogin(); |
| | | await getUserLocation(); |
| | | }); |
| | | common_vendor.onShow(() => { |
| | | console.log("App Show"); |
| | |
| | | "pages/addCard/index", |
| | | "pages/userInfo/index", |
| | | "pages/balanceRecord/index", |
| | | "pages/paymentRecord/index", |
| | | "pages/scanWater/index", |
| | | "pages/recharge/index", |
| | | "pages/sendWater/index", |
| | |
| | | "pages/addressAdd/index", |
| | | "pages/addressLocate/index", |
| | | "pages/success/index", |
| | | "pages/facilityList/index" |
| | | "pages/facilityList/index", |
| | | "pages/station/index" |
| | | ], |
| | | "window": { |
| | | "navigationStyle": "custom" |
| | |
| | | "use strict"; |
| | | const _imports_0$6 = "/static/images/index/hend1.png"; |
| | | const _imports_1$3 = "/static/images/index/back.png"; |
| | | const _imports_2 = "/static/images/index/code1.png"; |
| | | const _imports_3 = "/static/images/index/vip-add.png"; |
| | | const _imports_4 = "/static/images/index/home21.png"; |
| | | const _imports_1$2 = "/static/images/index/icon22.png"; |
| | | const _imports_6 = "/static/images/index/icon23.png"; |
| | | const _imports_7 = "/static/images/index/bg4.png"; |
| | | const _imports_8 = "/static/images/index/icon51.png"; |
| | | const _imports_9 = "/static/images/index/more-info5.png"; |
| | | const _imports_10 = "/static/images/index/notice5.png"; |
| | | const _imports_0$5 = "/static/images/addCard/code.png"; |
| | | const _imports_0$4 = "/static/logo.png"; |
| | | const _imports_1$1 = "/static/images/other/more.png"; |
| | | const _imports_0$7 = "/static/images/index/hend1.png"; |
| | | const _imports_1$2 = "/static/images/index/back.png"; |
| | | const _imports_2 = "/static/images/index/vip-add.png"; |
| | | const _imports_3 = "/static/images/index/card11.png"; |
| | | const _imports_4 = "/static/images/index/code1.png"; |
| | | const _imports_5 = "/static/images/index/home21.png"; |
| | | const _imports_1$1 = "/static/images/index/icon22.png"; |
| | | const _imports_7 = "/static/images/index/icon23.png"; |
| | | const _imports_8 = "/static/images/index/bg4.png"; |
| | | const _imports_9 = "/static/images/index/icon51.png"; |
| | | const _imports_10 = "/static/images/index/more-info5.png"; |
| | | const _imports_11 = "/static/images/index/notice5.png"; |
| | | const _imports_0$6 = "/static/images/addCard/code.png"; |
| | | const _imports_0$5 = "/static/logo.png"; |
| | | const _imports_0$4 = "/static/images/other/more.png"; |
| | | const _imports_0$3 = "/static/images/address/edit.png"; |
| | | const _imports_1 = "/static/images/address/delete.png"; |
| | | const _imports_0$2 = "/static/images/address/expand.png"; |
| | | const _imports_0$1 = "/static/images/other/success.svg"; |
| | | const _imports_0 = "/static/images/addCard/back.png"; |
| | | exports._imports_0 = _imports_0; |
| | | exports._imports_0$1 = _imports_0$6; |
| | | exports._imports_0$2 = _imports_0$5; |
| | | exports._imports_0$3 = _imports_0$4; |
| | | exports._imports_0$4 = _imports_0$3; |
| | | exports._imports_0$5 = _imports_0$2; |
| | | exports._imports_0$6 = _imports_0$1; |
| | | exports._imports_1 = _imports_1$3; |
| | | exports._imports_1$1 = _imports_1$2; |
| | | exports._imports_1$2 = _imports_1$1; |
| | | exports._imports_1$3 = _imports_1; |
| | | exports._imports_0$1 = _imports_0$7; |
| | | exports._imports_0$2 = _imports_0$6; |
| | | exports._imports_0$3 = _imports_0$5; |
| | | exports._imports_0$4 = _imports_0$4; |
| | | exports._imports_0$5 = _imports_0$3; |
| | | exports._imports_0$6 = _imports_0$2; |
| | | exports._imports_0$7 = _imports_0$1; |
| | | exports._imports_1 = _imports_1$2; |
| | | exports._imports_1$1 = _imports_1$1; |
| | | exports._imports_1$2 = _imports_1; |
| | | exports._imports_10 = _imports_10; |
| | | exports._imports_11 = _imports_11; |
| | | exports._imports_2 = _imports_2; |
| | | exports._imports_3 = _imports_3; |
| | | exports._imports_4 = _imports_4; |
| | | exports._imports_6 = _imports_6; |
| | | exports._imports_5 = _imports_5; |
| | | exports._imports_7 = _imports_7; |
| | | exports._imports_8 = _imports_8; |
| | | exports._imports_9 = _imports_9; |
| | |
| | | "use strict"; |
| | | const BASE_URL = "http://192.168.0.105:8031"; |
| | | const BASE_URL = "http://113.250.189.120:8031"; |
| | | exports.BASE_URL = BASE_URL; |
| | |
| | | userPhone: "", |
| | | remark: "" |
| | | }); |
| | | function toScan() { |
| | | common_vendor.index.scanCode({ |
| | | scanType: ["qrCode"], |
| | | success: function(res) { |
| | | console.log("条码内容:" + res.result); |
| | | form.value.waterCardNumber = res.result; |
| | | } |
| | | }); |
| | | } |
| | | async function submit() { |
| | | await api_index.creatUserArchive(form.value).then((res) => { |
| | | if (res.code == 200) { |
| | | common_vendor.index.showToast({ |
| | | title: "绑定成功", |
| | | title: "添加成功!", |
| | | image: "../../static/images/other/success.svg", |
| | | duration: 500 |
| | | }); |
| | |
| | | }), |
| | | b: form.value.waterCardNumber, |
| | | c: common_vendor.o(($event) => form.value.waterCardNumber = $event.detail.value), |
| | | d: common_assets._imports_0$2, |
| | | e: form.value.userName, |
| | | f: common_vendor.o(($event) => form.value.userName = $event.detail.value), |
| | | g: form.value.userPhone, |
| | | h: common_vendor.o(($event) => form.value.userPhone = $event.detail.value), |
| | | i: form.value.remark, |
| | | j: common_vendor.o(($event) => form.value.remark = $event.detail.value), |
| | | k: common_vendor.o(($event) => submit()) |
| | | d: common_vendor.o(($event) => toScan()), |
| | | e: common_assets._imports_0$2, |
| | | f: form.value.userName, |
| | | g: common_vendor.o(($event) => form.value.userName = $event.detail.value), |
| | | h: form.value.userPhone, |
| | | i: common_vendor.o(($event) => form.value.userPhone = $event.detail.value), |
| | | j: form.value.remark, |
| | | k: common_vendor.o(($event) => form.value.remark = $event.detail.value), |
| | | l: common_vendor.o(($event) => submit()) |
| | | }; |
| | | }; |
| | | } |
| | |
| | | <view class="container data-v-4c5e7c86"><view class="content data-v-4c5e7c86"><navbar wx:if="{{a}}" class="data-v-4c5e7c86" u-i="4c5e7c86-0" bind:__l="__l" u-p="{{a}}"></navbar><view class="main data-v-4c5e7c86"><view class="title data-v-4c5e7c86">请填写卡及个人信息</view><view class="form data-v-4c5e7c86"><view class="form-item card-item data-v-4c5e7c86"><text class="data-v-4c5e7c86">卡号:</text><input class="data-v-4c5e7c86" placeholder="请输入卡号" value="{{b}}" bindinput="{{c}}"/><image class="data-v-4c5e7c86" src="{{d}}" alt=""></image></view><view class="form-item data-v-4c5e7c86"><text class="data-v-4c5e7c86">姓名:</text><input class="data-v-4c5e7c86" placeholder="请输入姓名" value="{{e}}" bindinput="{{f}}"/></view><view class="form-item data-v-4c5e7c86"><text class="data-v-4c5e7c86">联系方式:</text><input class="data-v-4c5e7c86" placeholder="请输入手机号" value="{{g}}" bindinput="{{h}}"/></view><view class="form-item data-v-4c5e7c86"><text class="data-v-4c5e7c86">备注:</text><input class="data-v-4c5e7c86" placeholder="请输入内容" value="{{i}}" bindinput="{{j}}"/></view></view><view class="tips data-v-4c5e7c86"><text class="data-v-4c5e7c86">1、完成实名认证,方便遗失挂失及补卡等。</text><text class="data-v-4c5e7c86">2、绑卡后,运营商可以看到您实名时填写的 姓名和电话。</text></view><view class="subBtn data-v-4c5e7c86" bindtap="{{k}}">提交信息</view></view></view></view> |
| | | <view class="container data-v-4c5e7c86"><view class="content data-v-4c5e7c86"><navbar wx:if="{{a}}" class="data-v-4c5e7c86" u-i="4c5e7c86-0" bind:__l="__l" u-p="{{a}}"></navbar><view class="main data-v-4c5e7c86"><view class="title data-v-4c5e7c86">请填写卡及个人信息</view><view class="form data-v-4c5e7c86"><view class="form-item card-item data-v-4c5e7c86"><text class="data-v-4c5e7c86">卡号:</text><input class="data-v-4c5e7c86" placeholder="请输入卡号" value="{{b}}" bindinput="{{c}}"/><image class="data-v-4c5e7c86" bindtap="{{d}}" src="{{e}}" alt=""></image></view><view class="form-item data-v-4c5e7c86"><text class="data-v-4c5e7c86">姓名:</text><input class="data-v-4c5e7c86" placeholder="请输入姓名" value="{{f}}" bindinput="{{g}}"/></view><view class="form-item data-v-4c5e7c86"><text class="data-v-4c5e7c86">联系方式:</text><input class="data-v-4c5e7c86" placeholder="请输入手机号" value="{{h}}" bindinput="{{i}}"/></view><view class="form-item data-v-4c5e7c86"><text class="data-v-4c5e7c86">备注:</text><input class="data-v-4c5e7c86" placeholder="请输入内容" value="{{j}}" bindinput="{{k}}"/></view></view><view class="tips data-v-4c5e7c86"><text class="data-v-4c5e7c86">1、完成实名认证,方便遗失挂失及补卡等。</text><text class="data-v-4c5e7c86">2、绑卡后,运营商可以看到您实名时填写的 姓名和电话。</text></view><view class="subBtn data-v-4c5e7c86" bindtap="{{l}}">提交信息</view></view></view></view> |
| | |
| | | h: common_vendor.o(($event) => deleteAddress(item.id)) |
| | | }; |
| | | }), |
| | | c: common_assets._imports_0$4, |
| | | d: common_assets._imports_1$3, |
| | | c: common_assets._imports_0$5, |
| | | d: common_assets._imports_1$2, |
| | | e: common_vendor.o(($event) => navToAdd()) |
| | | }; |
| | | }; |
| | |
| | | } |
| | | } |
| | | const cardInfo = common_vendor.ref({ |
| | | id: "", |
| | | userName: "", |
| | | headImg: "", |
| | | waterCardNumber: "", |
| | |
| | | const isVip = common_vendor.ref(false); |
| | | async function getInfo() { |
| | | let res = await api_index.getUserInfo(); |
| | | console.log("res", res.data); |
| | | cardInfo.value.userName = res.data.userInfo.userName; |
| | | cardInfo.value.headImg = res.data.userInfo.headImg; |
| | | cardInfo.value.userPhone = res.data.userInfo.userPhone; |
| | | if (res.data.userInfo.waterCardNumber) { |
| | | let res1 = await api_index.getVipInfoApi(); |
| | | cardInfo.value.waterCardNumber = res1.data.cardNumber; |
| | | if (res1.data.cardType == 1) { |
| | | cardInfo.value.balance = res1.data.balance; |
| | | } else if (res1.data.cardType == 2) { |
| | | cardInfo.value.count = res1.data.count; |
| | | if (res.code == 200) { |
| | | console.log("res", res.data); |
| | | cardInfo.value.userName = res.data.userInfo.userName; |
| | | cardInfo.value.headImg = res.data.userInfo.headImg; |
| | | cardInfo.value.userPhone = res.data.userInfo.userPhone; |
| | | cardInfo.value.id = res.data.userInfo.id; |
| | | if (res.data.userInfo.waterCardNumber) { |
| | | let res1 = await api_index.getVipInfoApi(); |
| | | cardInfo.value.waterCardNumber = res1.data.cardNumber; |
| | | if (res1.data.cardType == 1) { |
| | | cardInfo.value.balance = res1.data.balance; |
| | | } else if (res1.data.cardType == 2) { |
| | | cardInfo.value.count = res1.data.count; |
| | | } |
| | | isVip.value = true; |
| | | } else { |
| | | isVip.value = false; |
| | | } |
| | | isVip.value = true; |
| | | } else { |
| | | isVip.value = false; |
| | | common_vendor.index.setStorageSync("userInfo", JSON.stringify(cardInfo.value)); |
| | | } |
| | | common_vendor.index.setStorageSync("userInfo", JSON.stringify(cardInfo.value)); |
| | | } |
| | | function toScan() { |
| | | common_vendor.index.scanCode({ |
| | | scanType: ["qrCode"], |
| | | success: function(res) { |
| | | console.log("条码类型:" + res.scanType); |
| | | console.log("条码内容:" + res.result); |
| | | common_vendor.index.navigateTo({ |
| | | url: "/pages/scanWater/index" |
| | |
| | | } |
| | | const functionList = common_vendor.ref([ |
| | | { text: "余额记录", icon: "../../static/images/index/icon31.png", url: "/pages/balanceRecord/index" }, |
| | | { text: "消费记录", icon: "../../static/images/index/icon32.png", url: "" }, |
| | | { text: "消费记录", icon: "../../static/images/index/icon32.png", url: "/pages/paymentRecord/index" }, |
| | | { text: "充值记录", icon: "../../static/images/index/icon33.png", url: "" }, |
| | | { text: "账户共享", icon: "../../static/images/index/icon34.png", url: "" }, |
| | | { text: "优惠卷", icon: "../../static/images/index/icon35.png", url: "" }, |
| | |
| | | a: common_assets._imports_0$1, |
| | | b: common_vendor.t(cardInfo.value.userName), |
| | | c: common_assets._imports_1, |
| | | d: common_vendor.o(($event) => navTo("/pages/userInfo/index")), |
| | | e: common_assets._imports_2, |
| | | f: common_vendor.t(cardInfo.value.waterCardNumber), |
| | | g: common_vendor.t(cardInfo.value.userPhone), |
| | | h: common_assets._imports_3, |
| | | i: common_vendor.o(($event) => navTo("/pages/addCard/index")), |
| | | j: common_vendor.t(cardInfo.value.balance), |
| | | k: common_vendor.o(($event) => navTo("/pages/recharge/index")), |
| | | l: topHeight.value + "rpx", |
| | | m: common_assets._imports_4, |
| | | n: common_vendor.o(($event) => navTo("/pages/sendWater/index")), |
| | | o: common_assets._imports_1$1, |
| | | p: common_vendor.o(($event) => navTo("/pages/facilityList/index")), |
| | | q: common_assets._imports_6, |
| | | r: common_vendor.o(($event) => toScan()), |
| | | s: common_vendor.f(functionList.value, (item, index, i0) => { |
| | | d: common_assets._imports_2, |
| | | e: common_vendor.o(($event) => navTo("/pages/addCard/index")), |
| | | f: common_vendor.o(($event) => navTo("/pages/userInfo/index")), |
| | | g: common_assets._imports_3, |
| | | h: common_assets._imports_4, |
| | | i: common_vendor.t(cardInfo.value.waterCardNumber), |
| | | j: common_vendor.t(cardInfo.value.userPhone), |
| | | k: common_vendor.t(cardInfo.value.balance), |
| | | l: common_vendor.o(($event) => navTo("/pages/recharge/index")), |
| | | m: topHeight.value + "rpx", |
| | | n: common_assets._imports_5, |
| | | o: common_vendor.o(($event) => navTo("/pages/sendWater/index")), |
| | | p: common_assets._imports_1$1, |
| | | q: common_vendor.o(($event) => navTo("/pages/facilityList/index")), |
| | | r: common_assets._imports_7, |
| | | s: common_vendor.o(($event) => toScan()), |
| | | t: common_vendor.f(functionList.value, (item, index, i0) => { |
| | | return { |
| | | a: item.icon, |
| | | b: common_vendor.t(item.text), |
| | |
| | | d: index |
| | | }; |
| | | }), |
| | | t: common_assets._imports_7, |
| | | v: common_assets._imports_8, |
| | | w: common_assets._imports_9, |
| | | x: common_assets._imports_10, |
| | | y: common_assets._imports_9 |
| | | y: common_vendor.o(($event) => navTo("/pages/station/index")), |
| | | z: common_assets._imports_11, |
| | | A: common_assets._imports_10 |
| | | }; |
| | | }; |
| | | } |
| | |
| | | <view class="container data-v-1cf27b2a"><view class="content data-v-1cf27b2a"><view class="card-box data-v-1cf27b2a" style="{{'padding-top:' + l}}"><view class="user-info data-v-1cf27b2a" bindtap="{{d}}"><image class="user-img data-v-1cf27b2a" src="{{a}}" alt=""></image><text class="data-v-1cf27b2a">{{b}}</text><image class="user-more data-v-1cf27b2a" src="{{c}}"></image></view><view class="card data-v-1cf27b2a"><view class="card-content data-v-1cf27b2a"><view class="card-left data-v-1cf27b2a"><view class="left-top data-v-1cf27b2a"><view class="data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{e}}" alt=""></image><text class="data-v-1cf27b2a">会员卡</text></view><view class="data-v-1cf27b2a">ID:{{f}}</view></view><view class="left-bottom data-v-1cf27b2a">电话:{{g}}</view></view><view class="card-right data-v-1cf27b2a"><view class="card-right-top data-v-1cf27b2a"><view class="data-v-1cf27b2a" bindtap="{{i}}"><image class="data-v-1cf27b2a" src="{{h}}" alt=""></image><label class="data-v-1cf27b2a">添加会员卡</label></view><label class="data-v-1cf27b2a">金额卡</label></view><view class="data-v-1cf27b2a" bindtap="{{k}}"><label class="data-v-1cf27b2a">余额:</label><label class="card-balance data-v-1cf27b2a">{{j}}</label><label class="data-v-1cf27b2a">元</label></view></view></view></view></view><view class="function-box1 data-v-1cf27b2a"><view class="box1-bg box1-one data-v-1cf27b2a" bindtap="{{n}}"><image class="data-v-1cf27b2a" src="{{m}}" alt=""></image><view class="data-v-1cf27b2a">送水到家</view></view><view bindtap="{{p}}" class="box1-bg box1-two data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{o}}" alt=""></image><view class="data-v-1cf27b2a">附近设备</view></view><view class="box1-bg box1-three data-v-1cf27b2a" bindtap="{{r}}"><image class="data-v-1cf27b2a" src="{{q}}" alt=""></image><view class="data-v-1cf27b2a">扫码取水</view></view></view><view class="function-box2 data-v-1cf27b2a"><view class="box2-title data-v-1cf27b2a"><text class="data-v-1cf27b2a">功能列表</text></view><view class="box2-content data-v-1cf27b2a"><block wx:for="{{s}}" wx:for-item="item" wx:key="d"><view class="box2-item data-v-1cf27b2a" bindtap="{{item.c}}"><image class="data-v-1cf27b2a" src="{{item.a}}" alt=""></image><view class="box2-item-text data-v-1cf27b2a">{{item.b}}</view></view></block></view></view><view class="advertisement-box data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{t}}" alt=""></image></view><view class="service-box data-v-1cf27b2a"><view class="service-title data-v-1cf27b2a"><text class="data-v-1cf27b2a">服务指南</text></view><view class="service-content data-v-1cf27b2a"><view class="service-bg data-v-1cf27b2a"><view class="data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{v}}" alt=""></image><text class="data-v-1cf27b2a">附近站点</text></view><view class="service-info data-v-1cf27b2a">蔡家供水服务中心正在营业中……</view><view class="data-v-1cf27b2a"><text class="data-v-1cf27b2a">查看更多</text><image class="data-v-1cf27b2a" src="{{w}}" alt=""></image></view></view><view class="service-bg data-v-1cf27b2a"><view class="data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{x}}" alt=""></image><text class="data-v-1cf27b2a">公示公告</text></view><view class="service-info data-v-1cf27b2a">停水公告的部分摘要的内容展示……</view><view class="data-v-1cf27b2a"><text class="data-v-1cf27b2a">查看更多</text><image class="data-v-1cf27b2a" src="{{y}}" alt=""></image></view></view></view></view></view></view> |
| | | <view class="container data-v-1cf27b2a"><view class="content data-v-1cf27b2a"><view class="card-box data-v-1cf27b2a" style="{{'padding-top:' + m}}"><view class="user-info data-v-1cf27b2a" bindtap="{{f}}"><image class="user-img data-v-1cf27b2a" src="{{a}}" alt=""></image><text class="data-v-1cf27b2a">{{b}}</text><image class="user-more data-v-1cf27b2a" src="{{c}}"></image><view class="user-add-card data-v-1cf27b2a" bindtap="{{e}}"><image class="data-v-1cf27b2a" src="{{d}}" alt=""></image><text class="data-v-1cf27b2a">添加会员卡</text></view></view><view class="card data-v-1cf27b2a"><image class="card-bg data-v-1cf27b2a" src="{{g}}" alt=""></image><view class="card-content data-v-1cf27b2a"><view class="card-left data-v-1cf27b2a"><view class="left-top data-v-1cf27b2a"><view class="data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{h}}" alt=""></image><text class="data-v-1cf27b2a">会员卡</text></view><view class="data-v-1cf27b2a">ID:{{i}}</view></view><view class="left-bottom data-v-1cf27b2a">电话:{{j}}</view></view><view class="card-right data-v-1cf27b2a"><view class="card-right-top data-v-1cf27b2a"><text class="data-v-1cf27b2a">金额卡</text><text class="data-v-1cf27b2a">{{k}}元</text></view><view class="card-right-bottom data-v-1cf27b2a" bindtap="{{l}}">充值</view></view></view></view></view><view class="function-box1 data-v-1cf27b2a"><view class="box1-bg box1-one data-v-1cf27b2a" bindtap="{{o}}"><image class="data-v-1cf27b2a" src="{{n}}" alt=""></image><view class="data-v-1cf27b2a">送水到家</view></view><view bindtap="{{q}}" class="box1-bg box1-two data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{p}}" alt=""></image><view class="data-v-1cf27b2a">附近设备</view></view><view class="box1-bg box1-three data-v-1cf27b2a" bindtap="{{s}}"><image class="data-v-1cf27b2a" src="{{r}}" alt=""></image><view class="data-v-1cf27b2a">扫码取水</view></view></view><view class="function-box2 data-v-1cf27b2a"><view class="box2-title data-v-1cf27b2a"><text class="data-v-1cf27b2a">功能列表</text></view><view class="box2-content data-v-1cf27b2a"><block wx:for="{{t}}" wx:for-item="item" wx:key="d"><view class="box2-item data-v-1cf27b2a" bindtap="{{item.c}}"><image class="data-v-1cf27b2a" src="{{item.a}}" alt=""></image><view class="box2-item-text data-v-1cf27b2a">{{item.b}}</view></view></block></view></view><view class="advertisement-box data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{v}}" alt=""></image></view><view class="service-box data-v-1cf27b2a"><view class="service-title data-v-1cf27b2a"><text class="data-v-1cf27b2a">服务指南</text></view><view class="service-content data-v-1cf27b2a"><view class="service-bg data-v-1cf27b2a" bindtap="{{y}}"><view class="data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{w}}" alt=""></image><text class="data-v-1cf27b2a">附近站点</text></view><view class="service-info data-v-1cf27b2a">蔡家供水服务中心正在营业中……</view><view class="data-v-1cf27b2a"><text class="data-v-1cf27b2a">查看更多</text><image class="data-v-1cf27b2a" src="{{x}}" alt=""></image></view></view><view class="service-bg data-v-1cf27b2a"><view class="data-v-1cf27b2a"><image class="data-v-1cf27b2a" src="{{z}}" alt=""></image><text class="data-v-1cf27b2a">公示公告</text></view><view class="service-info data-v-1cf27b2a">停水公告的部分摘要的内容展示……</view><view class="data-v-1cf27b2a"><text class="data-v-1cf27b2a">查看更多</text><image class="data-v-1cf27b2a" src="{{A}}" alt=""></image></view></view></view></view></view></view> |
| | |
| | | padding-left: 15rpx; |
| | | box-sizing: border-box; |
| | | margin-bottom: 14rpx; |
| | | display: flex; |
| | | position: relative; |
| | | } |
| | | .container .content .card-box .user-info .user-img.data-v-1cf27b2a { |
| | | width: 90rpx; |
| | |
| | | width: 12rpx; |
| | | height: 28rpx; |
| | | } |
| | | .container .content .card-box .user-info .user-add-card.data-v-1cf27b2a { |
| | | display: flex; |
| | | align-items: center; |
| | | height: 40rpx; |
| | | font-size: 22rpx; |
| | | background: linear-gradient(to right, #B1D9FD, #65A7FD); |
| | | border-radius: 50rpx; |
| | | padding: 0 8rpx; |
| | | position: absolute; |
| | | bottom: 0; |
| | | right: 0; |
| | | } |
| | | .container .content .card-box .user-info .user-add-card image.data-v-1cf27b2a { |
| | | width: 28rpx; |
| | | height: 28rpx; |
| | | margin-right: 10rpx; |
| | | } |
| | | .container .content .card-box .card.data-v-1cf27b2a { |
| | | width: 100%; |
| | | height: 290rpx; |
| | | background-image: url(""); |
| | | background-repeat: no-repeat; |
| | | background-size: 100% 100%; |
| | | position: relative; |
| | | } |
| | | .container .content .card-box .card .card-bg.data-v-1cf27b2a { |
| | | height: 290rpx; |
| | | width: 100%; |
| | | top: 0; |
| | | position: absolute; |
| | | z-index: 1; |
| | | } |
| | | .container .content .card-box .card .card-content.data-v-1cf27b2a { |
| | | width: 100%; |
| | |
| | | font-weight: 300; |
| | | font-size: 30rpx; |
| | | color: #FFFFFF; |
| | | z-index: 100; |
| | | } |
| | | .container .content .card-box .card .card-content .card-left.data-v-1cf27b2a { |
| | | height: 100%; |
| | |
| | | justify-content: space-between; |
| | | flex-direction: column; |
| | | align-items: flex-start; |
| | | z-index: 100; |
| | | } |
| | | .container .content .card-box .card .card-content .card-left .left-top.data-v-1cf27b2a { |
| | | display: flex; |
| | |
| | | height: 70rpx; |
| | | } |
| | | .container .content .card-box .card .card-content .card-left .left-top view:first-child text.data-v-1cf27b2a { |
| | | font-weight: 300; |
| | | font-weight: 400; |
| | | font-size: 36rpx; |
| | | color: #FFFFFF; |
| | | } |
| | | .container .content .card-box .card .card-content .card-left .left-top view.data-v-1cf27b2a:last-child { |
| | | margin-left: 10rpx; |
| | | font-size: 26rpx; |
| | | font-weight: 500; |
| | | } |
| | | .container .content .card-box .card .card-content .card-right.data-v-1cf27b2a { |
| | | display: flex; |
| | |
| | | align-items: flex-end; |
| | | flex-direction: column; |
| | | height: 100%; |
| | | z-index: 100; |
| | | } |
| | | .container .content .card-box .card .card-content .card-right .card-right-top.data-v-1cf27b2a { |
| | | align-items: center; |
| | | align-items: flex-end; |
| | | display: flex; |
| | | justify-content: space-between; |
| | | flex-direction: column; |
| | | font-size: 34rpx; |
| | | } |
| | | .container .content .card-box .card .card-content .card-right .card-right-top view.data-v-1cf27b2a { |
| | | background-color: #fff; |
| | | color: #5EA1FA; |
| | | border-radius: 20rpx; |
| | | padding: 5rpx 8rpx; |
| | | align-items: center; |
| | | display: flex; |
| | | justify-content: space-around; |
| | | font-size: 24rpx; |
| | | margin-right: 10rpx; |
| | | .container .content .card-box .card .card-content .card-right .card-right-top text.data-v-1cf27b2a:last-child { |
| | | font-weight: 500; |
| | | } |
| | | .container .content .card-box .card .card-content .card-right .card-right-top view image.data-v-1cf27b2a { |
| | | width: 28rpx; |
| | | height: 28rpx; |
| | | margin-right: 10rpx; |
| | | } |
| | | .container .content .card-box .card .card-content .card-right .card-balance.data-v-1cf27b2a { |
| | | font-weight: 600; |
| | | .container .content .card-box .card .card-content .card-right .card-right-bottom.data-v-1cf27b2a { |
| | | width: 137rpx; |
| | | height: 56rpx; |
| | | background: linear-gradient(to right, #65A7FD, #B1D9FD); |
| | | border-radius: 50rpx; |
| | | text-align: center; |
| | | line-height: 56rpx; |
| | | color: #212DDE; |
| | | font-weight: 400; |
| | | } |
| | | .container .content .function-box1.data-v-1cf27b2a { |
| | | width: 100%; |
| | |
| | | "use strict"; |
| | | const common_vendor = require("../../common/vendor.js"); |
| | | const api_index = require("../../api/index.js"); |
| | | if (!Array) { |
| | | const _easycom_navbar2 = common_vendor.resolveComponent("navbar"); |
| | | _easycom_navbar2(); |
| | |
| | | } |
| | | } |
| | | const otherMoney = common_vendor.ref(); |
| | | const payMethod = common_vendor.ref(); |
| | | common_vendor.ref(); |
| | | const payList = common_vendor.ref([ |
| | | // {text:"支付宝支付",value:1,checked:true,img:'../../static/images/recharge/pay.png'}, |
| | | { text: "微信支付", value: 2, checked: false, img: "../../static/images/recharge/wx.png" }, |
| | | { text: "余额", value: 3, checked: false, img: "../../static/images/recharge/balance.png" } |
| | | { text: "微信支付", value: 2, checked: true, img: "../../static/images/recharge/wx.png" } |
| | | // {text:"余额",value:3,checked:false,img:'../../static/images/recharge/balance.png'}, |
| | | ]); |
| | | function choosePay(index1) { |
| | | payList.value.forEach((item, index) => { |
| | | if (item.checked == true) { |
| | | item.checked = false; |
| | | } |
| | | }); |
| | | payList.value[index1].checked = true; |
| | | payMethod.value = payList.value[index1].value; |
| | | } |
| | | function submit() { |
| | | async function submit() { |
| | | let money = ""; |
| | | if (disabled.value) { |
| | | money = choosedMoney.value; |
| | | } else { |
| | | money = otherMoney.value; |
| | | } |
| | | console.log("money", money); |
| | | await api_index.wxPayApi({ businessType: 1, tradeAmount: money }).then((res) => { |
| | | console.log("reswxpay", res); |
| | | common_vendor.wx$1.requestPayment({ |
| | | //预支付订单信息 |
| | | // appId: res.data.appId, |
| | | timeStamp: res.data.timeStamp, |
| | | //时间戳 |
| | | nonceStr: res.data.nonceStr, |
| | | //随机串 |
| | | package: res.data.package, |
| | | //prepay_id |
| | | signType: res.data.signType, |
| | | //签名算法MD5 |
| | | paySign: res.data.paySign, |
| | | //微信签名 |
| | | success(res2) { |
| | | if (res2.errMsg == "requestPayment:ok") { |
| | | console.log("支付成功", res2); |
| | | } else { |
| | | console.log("支付失败"); |
| | | } |
| | | }, |
| | | fail(res2) { |
| | | console.log("支付失败", res2); |
| | | } |
| | | }); |
| | | }); |
| | | } |
| | | return (_ctx, _cache) => { |
| | | return { |
| | |
| | | a: item.img, |
| | | b: common_vendor.t(item.text), |
| | | c: item.value, |
| | | d: item.checked, |
| | | e: common_vendor.o(($event) => choosePay(index)) |
| | | d: item.checked |
| | | }; |
| | | }), |
| | | h: common_vendor.o(($event) => submit()) |
| | |
| | | <view class="container data-v-f06186df"><navbar wx:if="{{a}}" class="data-v-f06186df" u-i="f06186df-0" bind:__l="__l" u-p="{{a}}"></navbar><view class="content data-v-f06186df"><view class="main data-v-f06186df"><view class="money data-v-f06186df"><view class="money-title data-v-f06186df"><view class="title-icon data-v-f06186df"></view><view class="title-text data-v-f06186df">充值金额</view></view><view class="money-list data-v-f06186df"><block wx:for="{{b}}" wx:for-item="item" wx:key="d"><view class="money-box data-v-f06186df" style="{{item.b}}" bindtap="{{item.c}}">¥{{item.a}}</view></block></view></view><view class="other-money data-v-f06186df"><view class="money-title data-v-f06186df"><view class="title-icon data-v-f06186df"></view><view class="title-text data-v-f06186df">其他金额</view></view><view class="money-input data-v-f06186df"><input class="data-v-f06186df" disabled="{{c}}" focus="{{d}}" placeholder="请输入其他金额" value="{{e}}" bindinput="{{f}}"/></view></view><view class="pay-methods data-v-f06186df"><view class="money-title data-v-f06186df"><view class="title-icon data-v-f06186df"></view><view class="title-text data-v-f06186df">请选择支付方式</view></view><view class="methods-list data-v-f06186df"><block wx:for="{{g}}" wx:for-item="item"><view class="pay-item data-v-f06186df"><view class="pay-item-right data-v-f06186df"><image class="data-v-f06186df" src="{{item.a}}" alt=""></image><view class="data-v-f06186df">{{item.b}}</view></view><radio class="data-v-f06186df" value="{{item.c}}" checked="{{item.d}}" bindtap="{{item.e}}"/></view></block></view></view></view><view class="submit-btn data-v-f06186df" bindtap="{{h}}">立即充值</view></view></view> |
| | | <view class="container data-v-f06186df"><navbar wx:if="{{a}}" class="data-v-f06186df" u-i="f06186df-0" bind:__l="__l" u-p="{{a}}"></navbar><view class="content data-v-f06186df"><view class="main data-v-f06186df"><view class="money data-v-f06186df"><view class="money-title data-v-f06186df"><view class="title-icon data-v-f06186df"></view><view class="title-text data-v-f06186df">充值金额</view></view><view class="money-list data-v-f06186df"><block wx:for="{{b}}" wx:for-item="item" wx:key="d"><view class="money-box data-v-f06186df" style="{{item.b}}" bindtap="{{item.c}}">¥{{item.a}}</view></block></view></view><view class="other-money data-v-f06186df"><view class="money-title data-v-f06186df"><view class="title-icon data-v-f06186df"></view><view class="title-text data-v-f06186df">其他金额</view></view><view class="money-input data-v-f06186df"><input class="data-v-f06186df" disabled="{{c}}" focus="{{d}}" placeholder="请输入其他金额" value="{{e}}" bindinput="{{f}}"/></view></view><view class="pay-methods data-v-f06186df"><view class="methods-list data-v-f06186df"><block wx:for="{{g}}" wx:for-item="item"><view class="pay-item data-v-f06186df"><view class="pay-item-right data-v-f06186df"><image class="data-v-f06186df" src="{{item.a}}" alt=""></image><view class="data-v-f06186df">{{item.b}}</view></view><radio class="data-v-f06186df" value="{{item.c}}" checked="{{item.d}}"/></view></block></view></view></view><view class="submit-btn data-v-f06186df" bindtap="{{h}}">立即充值</view></view></view> |
| | |
| | | url: "/pages/preSendWater/index" |
| | | }); |
| | | } |
| | | const isComplete = common_vendor.ref(true); |
| | | const isComplete = common_vendor.ref(false); |
| | | const isActive = common_vendor.ref({ borderBottom: `3px solid #226AC9` }); |
| | | function swatch(val) { |
| | | if (val == 1 && !isComplete.value || val == 2 && isComplete.value) |