Liuyi
2024-10-12 5c2531930dc7c87d0c39d116c84f87b507394eb9
添加附近站点,添加消费记录,重写用户申请位置权限
已修改24个文件
已删除2个文件
920 ■■■■ 文件已修改
App.vue 77 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
api/index.js 22 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages.json 12 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/addCard/index.vue 22 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/balanceRecord/index.vue 8 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/facilityList/index.vue 69 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/index/index.vue 164 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/recharge/index.vue 58 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/sendWater/index.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
pages/userInfo/index.vue 107 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
static/images/index/card1.png 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/api/index.js 16 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/app.js 72 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/app.json 4 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/common/assets.js 52 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/config/baseUrl.js 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/pages/addCard/index.js 28 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/pages/addCard/index.wxml 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/pages/address/index.js 4 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/pages/index/index.js 75 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/pages/index/index.wxml 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/pages/index/index.wxss 69 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/pages/recharge/index.js 49 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/pages/recharge/index.wxml 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/pages/sendWater/index.js 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
unpackage/dist/dev/mp-weixin/static/images/index/card1.png 补丁 | 查看 | 原始文档 | blame | 历史
App.vue
@@ -1,7 +1,9 @@
<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({
@@ -14,10 +16,83 @@
                  })
                },
                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");
api/index.js
@@ -38,8 +38,28 @@
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')
}
pages.json
@@ -25,6 +25,12 @@
            }
        },
        {
            "path" : "pages/paymentRecord/index",
            "style": {
                "navigationStyle":"custom"
            }
        },
        {
            "path" : "pages/scanWater/index",
            "style": {
                "navigationStyle":"custom"
@@ -77,6 +83,12 @@
            "style": {
                "navigationStyle":"custom"
            }
        },
        {
            "path" : "pages/station/index",
            "style": {
                "navigationStyle":"custom"
            }
        }
    ],
    "globalStyle": {
pages/addCard/index.vue
@@ -8,11 +8,21 @@
    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     
            })
@@ -33,7 +43,7 @@
                    <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>
@@ -43,14 +53,6 @@
                        <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="请输入内容"/>
pages/balanceRecord/index.vue
@@ -1,9 +1,17 @@
<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>
pages/facilityList/index.vue
@@ -10,7 +10,7 @@
                        </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>
@@ -28,47 +28,52 @@
<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>
pages/index/index.vue
@@ -14,6 +14,7 @@
     * 会员卡相关
     */
    const cardInfo = ref({
        id:'',
        userName:'',
        headImg:'',
        
@@ -26,23 +27,26 @@
    //获取会员卡信息
    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))
    }
    /**
     * 扫码取水相关
@@ -52,7 +56,6 @@
        uni.scanCode({
            scanType: ['qrCode'],
            success: function (res) {
                console.log('条码类型:' + res.scanType);
                console.log('条码内容:' + res.result);
                uni.navigateTo({
                    url:'/pages/scanWater/index'
@@ -65,7 +68,7 @@
     */
    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:''},
@@ -80,26 +83,8 @@
            })
        }
    }
    //获取用户地理位置
    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()
@@ -114,8 +99,13 @@
                    <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">
@@ -129,17 +119,14 @@
                        </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>
@@ -181,7 +168,7 @@
            <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>
@@ -206,24 +193,6 @@
                </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>
@@ -250,6 +219,8 @@
                    padding-left:15rpx;
                    box-sizing: border-box;
                    margin-bottom: 14rpx;
                    display:flex;
                    position:relative;
                    .user-img{
                        width:90rpx;
                        height:90rpx;
@@ -263,13 +234,35 @@
                        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%;
@@ -280,12 +273,14 @@
                        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;
@@ -297,13 +292,15 @@
                                        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;
                                }
                            }
                        }
@@ -313,29 +310,26 @@
                            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;
                            }
                        }
                    }
pages/recharge/index.vue
@@ -1,5 +1,6 @@
<script setup>
    import{ ref ,onMounted} from 'vue'
    import { wxPayApi } from '../../api/index.js'
    
    const choosedMoney = ref()
    const disabled = ref(true)
@@ -38,26 +39,51 @@
    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>
@@ -86,10 +112,10 @@
                    </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">
@@ -97,7 +123,7 @@
                                    <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>
pages/sendWater/index.vue
@@ -5,7 +5,7 @@
            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)){
pages/userInfo/index.vue
@@ -1,7 +1,43 @@
<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">
@@ -9,13 +45,16 @@
        <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">
@@ -26,13 +65,16 @@
                    <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>
@@ -47,17 +89,29 @@
            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%;
@@ -70,7 +124,7 @@
                    box-sizing: border-box;
                    font-size: 32rpx;
                    color: #343434;
                    view:first-child{
                    .info-img{
                        width:100%;
                        display: flex;
                        justify-content:space-between;
@@ -81,7 +135,7 @@
                            border-radius: 50rpx;
                        }
                    }
                    view:last-child{
                    .info-name{
                        width:100%;
                        display: flex;
                        justify-content:space-between;
@@ -135,6 +189,31 @@
                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>
static/images/index/card1.png
Binary files differ
unpackage/dist/dev/mp-weixin/api/index.js
@@ -33,14 +33,30 @@
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;
unpackage/dist/dev/mp-weixin/app.js
@@ -7,6 +7,7 @@
  "./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";
@@ -16,11 +17,12 @@
  "./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({
@@ -32,10 +34,78 @@
            });
          },
          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");
unpackage/dist/dev/mp-weixin/app.json
@@ -4,6 +4,7 @@
    "pages/addCard/index",
    "pages/userInfo/index",
    "pages/balanceRecord/index",
    "pages/paymentRecord/index",
    "pages/scanWater/index",
    "pages/recharge/index",
    "pages/sendWater/index",
@@ -12,7 +13,8 @@
    "pages/addressAdd/index",
    "pages/addressLocate/index",
    "pages/success/index",
    "pages/facilityList/index"
    "pages/facilityList/index",
    "pages/station/index"
  ],
  "window": {
    "navigationStyle": "custom"
unpackage/dist/dev/mp-weixin/common/assets.js
@@ -1,39 +1,41 @@
"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;
unpackage/dist/dev/mp-weixin/config/baseUrl.js
@@ -1,3 +1,3 @@
"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;
unpackage/dist/dev/mp-weixin/pages/addCard/index.js
@@ -19,11 +19,20 @@
      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
          });
@@ -40,14 +49,15 @@
        }),
        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())
      };
    };
  }
unpackage/dist/dev/mp-weixin/pages/addCard/index.wxml
@@ -1 +1 @@
<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>
unpackage/dist/dev/mp-weixin/pages/address/index.js
@@ -88,8 +88,8 @@
            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())
      };
    };
unpackage/dist/dev/mp-weixin/pages/index/index.js
@@ -12,6 +12,7 @@
      }
    }
    const cardInfo = common_vendor.ref({
      id: "",
      userName: "",
      headImg: "",
      waterCardNumber: "",
@@ -22,29 +23,31 @@
    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"
@@ -54,7 +57,7 @@
    }
    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: "" },
@@ -80,22 +83,23 @@
        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),
@@ -103,11 +107,12 @@
            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
      };
    };
  }
unpackage/dist/dev/mp-weixin/pages/index/index.wxml
@@ -1 +1 @@
<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>
unpackage/dist/dev/mp-weixin/pages/index/index.wxss
@@ -48,6 +48,8 @@
  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;
@@ -62,12 +64,34 @@
  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%;
@@ -79,6 +103,7 @@
  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%;
@@ -86,6 +111,7 @@
  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;
@@ -100,12 +126,14 @@
  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;
@@ -113,30 +141,27 @@
  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%;
unpackage/dist/dev/mp-weixin/pages/recharge/index.js
@@ -1,5 +1,6 @@
"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();
@@ -42,29 +43,46 @@
      }
    }
    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 {
@@ -88,8 +106,7 @@
            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())
unpackage/dist/dev/mp-weixin/pages/recharge/index.wxml
@@ -1 +1 @@
<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>
unpackage/dist/dev/mp-weixin/pages/sendWater/index.js
@@ -16,7 +16,7 @@
        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)
unpackage/dist/dev/mp-weixin/static/images/index/card1.png
Binary files differ