2025-02-28 03:34:36 +00:00
|
|
|
|
<template>
|
|
|
|
|
<!-- 批量服务类商品购买 -->
|
|
|
|
|
<view class="flex-col page">
|
|
|
|
|
<view class="flex-row justify-between items-center section_2">
|
|
|
|
|
<view class="flex-row items-center">
|
|
|
|
|
<image
|
|
|
|
|
class="shrink-0 image"
|
|
|
|
|
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FXymRmdOc-lianxiren.png"
|
|
|
|
|
/>
|
2025-03-11 14:04:30 +00:00
|
|
|
|
<text class="text ml-10" style="font-size: 30rpx;">{{ contactRealInfo.name }} {{ contactRealInfo.phone }}</text>
|
2025-02-28 03:34:36 +00:00
|
|
|
|
</view>
|
2025-03-01 05:33:28 +00:00
|
|
|
|
<view class="flex-row items-center group" @click="loadPop" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }">
|
2025-02-28 03:34:36 +00:00
|
|
|
|
<image
|
|
|
|
|
class="image_2"
|
|
|
|
|
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FKgDGnwlb-right.png"
|
|
|
|
|
/>
|
|
|
|
|
<text class="font text_2">更换联系人</text>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="flex-col section_3">
|
|
|
|
|
<view class="flex-col">
|
|
|
|
|
<view class="flex-row items-end list-item mt-13">
|
|
|
|
|
<image
|
|
|
|
|
class="shrink-0 image_3"
|
|
|
|
|
:src="singleService.goodImg"
|
|
|
|
|
/>
|
|
|
|
|
<view class="flex-col flex-1 group_5">
|
|
|
|
|
<view class="flex-row self-stretch group_3">
|
|
|
|
|
<!-- <text class="font">{{ item.cartExperienceGoodVO }}</text> -->
|
|
|
|
|
<text class="font text_3">【 服务类 】 {{singleService.name}} </text>
|
|
|
|
|
</view>
|
2025-03-11 14:04:30 +00:00
|
|
|
|
<text class="self-start font_2 text_7 mt-9">已选时间:{{ bookDate }} {{ getWeekday(bookDate) }}</text>
|
2025-02-28 03:34:36 +00:00
|
|
|
|
<text class="self-start font_3 text_8 mt-9">{{ timeSlot }}</text>
|
|
|
|
|
<view class="flex-row justify-between items-end self-stretch mt-9">
|
|
|
|
|
<view class="flex-row items-center">
|
|
|
|
|
<!-- <image
|
|
|
|
|
class="shrink-0 image_6"
|
|
|
|
|
src="https://ide.code.fun/api/image?token=67be64de4ae84d0012274ced&name=4a3c5c3a5c83be7a7b0551c598ed6037.png"
|
|
|
|
|
/> -->
|
|
|
|
|
<text class="font_5 ml-3">¥{{ singleService.price }}</text>
|
|
|
|
|
<!-- <text class="font_6 ml-3">00</text> -->
|
|
|
|
|
</view>
|
|
|
|
|
<image
|
|
|
|
|
class="image_4"
|
|
|
|
|
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FDuKxtYum-short.png"
|
|
|
|
|
@click="shortNum(index)"
|
|
|
|
|
/>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="flex-row shrink-0 group_4">
|
|
|
|
|
<view class="flex-col justify-start items-center text-wrapper"><text class="font_4 text_6">{{ cnt }}</text></view>
|
|
|
|
|
<image
|
|
|
|
|
class="image_5 ml-2"
|
|
|
|
|
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FIOMGjSNx-add.png"
|
|
|
|
|
@click="addNum(index)"
|
|
|
|
|
/>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2025-03-12 09:47:22 +00:00
|
|
|
|
<!-- <view class="flex-row justify-center items-center group_9 mt-15">
|
2025-02-28 03:34:36 +00:00
|
|
|
|
<view class="group_10">
|
|
|
|
|
<text class="font_7 text_11">注:购买课程均视为同意</text>
|
|
|
|
|
<text class="font_7 text_12">用户须知</text>
|
|
|
|
|
</view>
|
|
|
|
|
<image
|
|
|
|
|
class="image_7 ml-2"
|
|
|
|
|
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FcoxrJLJf-quesrion.png"
|
|
|
|
|
/>
|
2025-03-12 09:47:22 +00:00
|
|
|
|
</view> -->
|
2025-02-28 03:34:36 +00:00
|
|
|
|
</view>
|
|
|
|
|
<view class="flex-col section_4">
|
2025-03-01 05:33:28 +00:00
|
|
|
|
<view class="flex-row justify-between items-center my-coupon">
|
2025-02-28 03:34:36 +00:00
|
|
|
|
<view class="flex-row">
|
|
|
|
|
<text class="font_8 text_13">课程总价</text>
|
|
|
|
|
<text class="font_9 ml-7">共{{ cnt }}件商品</text>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="flex-row items-center group_11">
|
|
|
|
|
<!-- <image
|
|
|
|
|
class="shrink-0 image_8"
|
|
|
|
|
src="https://ide.code.fun/api/image?token=67be64de4ae84d0012274ced&name=eb4f44af1db8b709d9d4b2aecf5159be.png"
|
|
|
|
|
/> -->
|
|
|
|
|
<text class="font_10">¥{{ sumprice.toFixed(2) }}</text>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2025-03-01 05:33:28 +00:00
|
|
|
|
<view class="flex-row justify-between my-coupon" @click="openCoupon" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }">
|
2025-02-28 03:34:36 +00:00
|
|
|
|
<text class="font_8">优惠券</text>
|
|
|
|
|
<view class="flex-row group_12">
|
2025-03-01 05:33:28 +00:00
|
|
|
|
<text class="font_9" :style="{color: textColor}">{{ templateString }}</text>
|
2025-02-28 03:34:36 +00:00
|
|
|
|
<image
|
|
|
|
|
class="shrink-0 image_9 ml-3"
|
|
|
|
|
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FHomvnulG-rightblack.png"
|
|
|
|
|
/>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2025-03-01 05:33:28 +00:00
|
|
|
|
<view class="flex-row justify-between items-center my-coupon">
|
2025-02-28 03:34:36 +00:00
|
|
|
|
<text class="font_8 text_14">合计</text>
|
|
|
|
|
<view class="flex-row items-center group_13">
|
|
|
|
|
<!-- <image
|
|
|
|
|
class="shrink-0 image_8"
|
|
|
|
|
src="https://ide.code.fun/api/image?token=67be64de4ae84d0012274ced&name=0f3f4f80197a7b3647f307901f6a3bea.png"
|
|
|
|
|
/> -->
|
2025-03-01 05:33:28 +00:00
|
|
|
|
<text class="font_10">¥{{ sfAmount.toFixed(2) }}</text>
|
2025-02-28 03:34:36 +00:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="flex-col section_5">
|
2025-03-11 14:04:30 +00:00
|
|
|
|
<text class="self-start font_8 text_15" style="margin: 10rpx 0 0 5rpx">订单备注</text>
|
2025-03-12 09:47:22 +00:00
|
|
|
|
<textarea maxlength="250" placeholder-style="font-size: 25rpx;" v-model="note" placeholder="备注建议提前协商(250字以内)" class="flex-col justify-start items-start self-stretch text-wrapper_2 mt-11">
|
2025-03-11 14:04:30 +00:00
|
|
|
|
</textarea>
|
2025-02-28 03:34:36 +00:00
|
|
|
|
</view>
|
|
|
|
|
<view class="flex-row justify-between items-center section_6">
|
|
|
|
|
<view class="flex-row items-center">
|
|
|
|
|
<image
|
|
|
|
|
class="shrink-0 image_8 image_10"
|
|
|
|
|
src="https://ide.code.fun/api/image?token=67be64de4ae84d0012274ced&name=549b29459342a9a09d24834be40eb53b.png"
|
|
|
|
|
/>
|
|
|
|
|
<text class="text_17">应付:</text>
|
2025-03-01 05:33:28 +00:00
|
|
|
|
<text class="text_18">{{ sfAmount.toFixed(2) }}</text>
|
2025-02-28 03:34:36 +00:00
|
|
|
|
<!-- <text class="text_20">00</text> -->
|
|
|
|
|
</view>
|
2025-03-01 05:33:28 +00:00
|
|
|
|
<view class="flex-col justify-start items-center text-wrapper_3" @click="wxPayFd" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }"><text class="font_8 text_19">微信支付</text></view>
|
2025-02-28 03:34:36 +00:00
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<uni-popup ref="popup" background-color="#fff" :mask-click="false">
|
|
|
|
|
<view class="popup-content">
|
|
|
|
|
<contactsComponentVue></contactsComponentVue>
|
|
|
|
|
</view>
|
|
|
|
|
</uni-popup>
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
|
|
|
|
<uni-popup ref="coupon">
|
|
|
|
|
<view class="coupon-popup">
|
|
|
|
|
<couponPopupVue></couponPopupVue>
|
|
|
|
|
</view>
|
|
|
|
|
</uni-popup>
|
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
<!-- 遮罩层 -->
|
|
|
|
|
<view v-if="isShow" class="overlay"></view>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script setup>
|
2025-03-09 10:55:38 +00:00
|
|
|
|
import {nextTick, onMounted, onUnmounted, ref, toRaw} from 'vue'
|
2025-02-28 03:34:36 +00:00
|
|
|
|
import emitter from '../../../utils/emitter'
|
2025-03-12 13:15:24 +00:00
|
|
|
|
import { onShow, onLoad } from "@dcloudio/uni-app";
|
|
|
|
|
import { getFonts } from '../../../common/globalFont';
|
2025-02-28 03:34:36 +00:00
|
|
|
|
import { baseUrl } from '../../../api/request';
|
|
|
|
|
import { stateMap } from '../../../common/global';
|
2025-03-01 05:33:28 +00:00
|
|
|
|
import * as math from 'mathjs'
|
2025-02-28 03:34:36 +00:00
|
|
|
|
import contactsComponentVue from '../component/contactsComponent.vue'; //联系人弹窗\
|
|
|
|
|
import contactPopVue from '../../mine/component/contactPop.vue'; //新增联系人弹窗
|
2025-03-01 05:33:28 +00:00
|
|
|
|
import couponPopupVue from '../../coupon/component/couponPopup.vue';
|
2025-03-12 13:15:24 +00:00
|
|
|
|
import { dealResult } from '../../../common/globalFunction';
|
2025-02-28 03:34:36 +00:00
|
|
|
|
const sumprice = ref(0) //总价格
|
|
|
|
|
const popup = ref(null) //弹窗对象
|
|
|
|
|
const contactRealInfo = ref({
|
|
|
|
|
name: '请选择联系人'
|
|
|
|
|
}) //地址页 选择地址传过来的值 进入页面首先是默认地址,若无默认地址,则为空
|
|
|
|
|
const userInfo = wx.getStorageSync('userInfo') //用户信息
|
|
|
|
|
const totalInfo = ref([]) //购物车传过来的批量商品
|
|
|
|
|
const note = ref('')
|
|
|
|
|
const postCartArr = ref([])
|
|
|
|
|
const singleService = ref({}) //单个服务类商品
|
|
|
|
|
const cnt = ref(1) //单个服务类商品的商品数量
|
|
|
|
|
const timeSlot = ref('') //时间段信息
|
|
|
|
|
const bookDate = ref('') //日期信息
|
|
|
|
|
const restNumber = ref(0) //最大预约人数信息
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const coupon = ref(null)
|
|
|
|
|
const couponObj = ref({})
|
|
|
|
|
const templateString = ref('')
|
|
|
|
|
const sfAmount = ref(0)
|
|
|
|
|
const conditionAmount = ref(0)
|
|
|
|
|
const myCouponList = ref([])
|
|
|
|
|
const cookie = wx.getStorageSync("cookie") //请求头
|
|
|
|
|
|
|
|
|
|
const useCouponId = ref(null)
|
|
|
|
|
const textColor = ref('')
|
|
|
|
|
|
2025-03-09 10:55:38 +00:00
|
|
|
|
const closeHandler = () => {
|
|
|
|
|
close()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const contactsNowInfoHandler = (val) => {
|
|
|
|
|
contactRealInfo.value = val
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const closeCouponHandler = () => {
|
|
|
|
|
nextTick(() => {
|
|
|
|
|
if (coupon.value) {
|
|
|
|
|
coupon.value.close()
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const cancelCouponHandler = () => {
|
|
|
|
|
templateString.value = myCouponList.value.length + '张优惠券可用'
|
|
|
|
|
sfAmount.value = sumprice.value
|
|
|
|
|
useCouponId.value = null
|
|
|
|
|
textColor.value = '#818181'
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const getCouponObjHandler = (val) => {
|
|
|
|
|
couponObj.value = val
|
|
|
|
|
templateString.value = "-¥" + val.couponVO.conditionAmount.toFixed(2)
|
|
|
|
|
conditionAmount.value = val.couponVO.conditionAmount
|
|
|
|
|
sfAmount.value = sumprice.value - conditionAmount.value
|
|
|
|
|
useCouponId.value = val.id
|
|
|
|
|
textColor.value = '#FFB6B9'
|
|
|
|
|
console.log(val)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
onMounted(() => {
|
|
|
|
|
//将关闭弹窗方法传入弹窗页面,绑定弹窗按钮可关闭弹窗
|
2025-03-09 10:55:38 +00:00
|
|
|
|
emitter.on('close', closeHandler)
|
2025-02-28 03:34:36 +00:00
|
|
|
|
//获取联系人信息
|
2025-03-09 10:55:38 +00:00
|
|
|
|
emitter.on('contactsNowInfo', contactsNowInfoHandler)
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
2025-03-09 10:55:38 +00:00
|
|
|
|
emitter.on('closeCoupon', closeCouponHandler)
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
2025-03-09 10:55:38 +00:00
|
|
|
|
emitter.on('cancelCoupon', cancelCouponHandler)
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
2025-03-09 10:55:38 +00:00
|
|
|
|
emitter.on('getCouponObj', getCouponObjHandler)
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
onUnmounted(() => {
|
|
|
|
|
emitter.off('close', closeHandler)
|
|
|
|
|
//获取联系人信息
|
|
|
|
|
emitter.off('contactsNowInfo', contactsNowInfoHandler)
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
2025-03-09 10:55:38 +00:00
|
|
|
|
emitter.off('closeCoupon', closeCouponHandler)
|
|
|
|
|
|
|
|
|
|
emitter.off('cancelCoupon', cancelCouponHandler)
|
|
|
|
|
|
|
|
|
|
emitter.off('getCouponObj', getCouponObjHandler)
|
|
|
|
|
})
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
onLoad((options)=>{
|
2025-03-12 13:15:24 +00:00
|
|
|
|
getFonts()
|
2025-02-28 03:34:36 +00:00
|
|
|
|
singleService.value = JSON.parse(options.obj)
|
|
|
|
|
cnt.value = JSON.parse(options.cnt)
|
|
|
|
|
restNumber.value = JSON.parse(options.rest)
|
2025-03-04 06:07:24 +00:00
|
|
|
|
bookDate.value = options.appointmentDate
|
|
|
|
|
timeSlot.value = options.timeSlot
|
2025-02-28 03:34:36 +00:00
|
|
|
|
sumprice.value = cnt.value * singleService.value.price
|
2025-03-01 05:33:28 +00:00
|
|
|
|
sfAmount.value = cnt.value * singleService.value.price
|
2025-02-28 03:34:36 +00:00
|
|
|
|
console.log('单个服务类--->',singleService.value);
|
|
|
|
|
console.log('商品数量---->',cnt.value);
|
|
|
|
|
console.log('时间段---->',timeSlot.value);
|
|
|
|
|
console.log('日期---->',bookDate.value);
|
|
|
|
|
console.log('剩余人数---->',restNumber.value);
|
2025-03-01 05:33:28 +00:00
|
|
|
|
getMyCouponList()
|
2025-02-28 03:34:36 +00:00
|
|
|
|
})
|
|
|
|
|
onShow(()=>{
|
|
|
|
|
userInfo.value = wx.getStorageSync('userInfo') //从微信缓存中获取用户信息
|
|
|
|
|
getDefaultContact()
|
|
|
|
|
// computed()
|
|
|
|
|
})
|
|
|
|
|
//关闭弹窗
|
|
|
|
|
const close = () => {
|
|
|
|
|
nextTick(() => {
|
2025-03-01 05:33:28 +00:00
|
|
|
|
if (popup.value) {
|
|
|
|
|
popup.value.close()
|
|
|
|
|
}
|
|
|
|
|
})
|
2025-02-28 03:34:36 +00:00
|
|
|
|
}
|
|
|
|
|
//加载弹窗。默认从底部弹出
|
|
|
|
|
const loadPop =() =>{
|
|
|
|
|
popup.value.open('bottom')
|
|
|
|
|
}
|
|
|
|
|
//获取用户默认联系人
|
|
|
|
|
const getDefaultContact = async () =>{
|
|
|
|
|
const res = await uni.request({
|
|
|
|
|
url: baseUrl + '/contacts/list',
|
|
|
|
|
method: 'POST',
|
|
|
|
|
header: {
|
|
|
|
|
cookie: wx.getStorageSync('cookie')
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
if(res.data.code === 1) {
|
|
|
|
|
console.log('联系人数组---->',res.data.data);
|
|
|
|
|
}
|
|
|
|
|
//根据for循环遍历默认地址
|
|
|
|
|
for(let key in res.data.data) {
|
|
|
|
|
if(res.data.data[key].isDefault === 1) {
|
|
|
|
|
contactRealInfo.value = res.data.data[key]
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
const createOrder = async () => { //单个服务类的购买方法
|
|
|
|
|
console.log('联系人信息-->',contactRealInfo.value);
|
|
|
|
|
formatArr()
|
|
|
|
|
// console.log('postCartArr--->',postCartArr.value);
|
2025-03-12 16:46:53 +00:00
|
|
|
|
const res = await uni.request({ //向后端发送生成订单请求
|
2025-02-28 03:34:36 +00:00
|
|
|
|
url: baseUrl + '/order/add',
|
|
|
|
|
method: 'POST',
|
|
|
|
|
header: {
|
|
|
|
|
cookie: wx.getStorageSync('cookie')
|
|
|
|
|
},
|
|
|
|
|
data: {
|
|
|
|
|
orderType: 'service',
|
|
|
|
|
userName: userInfo.userName,
|
|
|
|
|
contactsId: contactRealInfo.value.id, //联系人信息id
|
2025-03-04 08:27:54 +00:00
|
|
|
|
couponId: useCouponId.value, //优惠卷id
|
2025-02-28 03:34:36 +00:00
|
|
|
|
note: note.value,
|
|
|
|
|
orderItemMainInfoAddRequestList: toRaw(postCartArr.value)
|
|
|
|
|
}
|
|
|
|
|
})
|
2025-03-12 16:46:53 +00:00
|
|
|
|
if (!dealResult(res)) {
|
2025-03-11 14:04:30 +00:00
|
|
|
|
hideLoading()
|
|
|
|
|
isShow.value = false
|
|
|
|
|
return
|
2025-02-28 03:34:36 +00:00
|
|
|
|
}
|
2025-03-12 16:46:53 +00:00
|
|
|
|
wxPay(res.data.data)
|
2025-02-28 03:34:36 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//减少当前商品数量
|
|
|
|
|
const shortNum = (index)=>{
|
|
|
|
|
if(cnt.value > 1) {
|
|
|
|
|
cnt.value -= 1
|
|
|
|
|
//计算商品价格
|
2025-03-01 05:33:28 +00:00
|
|
|
|
sumprice.value = math.round(sumprice.value - singleService.value.price, 2)
|
|
|
|
|
sfAmount.value = sumprice.value
|
|
|
|
|
useCouponId.value = null
|
|
|
|
|
textColor.value = '#818181'
|
|
|
|
|
fd()
|
2025-02-28 03:34:36 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
//增加当前商品数量
|
|
|
|
|
const addNum = (index)=>{
|
|
|
|
|
if( cnt.value < restNumber.value ) { //数量肯定不能大于库存
|
|
|
|
|
cnt.value += 1
|
2025-03-01 05:33:28 +00:00
|
|
|
|
sumprice.value = math.round(sumprice.value + singleService.value.price, 2)
|
|
|
|
|
sfAmount.value = sumprice.value
|
|
|
|
|
useCouponId.value = null
|
|
|
|
|
textColor.value = '#818181'
|
|
|
|
|
fd()
|
2025-02-28 03:34:36 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
const formatArr = () =>{ //格式化
|
|
|
|
|
postCartArr.value.splice(0,postCartArr.value.length)
|
|
|
|
|
postCartArr.value.push({
|
|
|
|
|
goodId: singleService.value.id,
|
|
|
|
|
quantity: cnt.value,
|
|
|
|
|
reservationDate: bookDate.value,
|
|
|
|
|
timeSlot: timeSlot.value
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
const wxPay = async( oid )=> { //传入订单id
|
|
|
|
|
console.log('oid--->',oid);
|
|
|
|
|
try {
|
|
|
|
|
const res = await uni.request({
|
|
|
|
|
url: baseUrl + '/wechat/payment/create',
|
|
|
|
|
method: 'POST',
|
|
|
|
|
header: {
|
|
|
|
|
'cookie': wx.getStorageSync("cookie")
|
|
|
|
|
},
|
|
|
|
|
data: { id: oid }
|
|
|
|
|
})
|
|
|
|
|
const paymentData = res.data.data
|
|
|
|
|
wx.requestPayment({
|
|
|
|
|
appid: paymentData.appId,
|
|
|
|
|
nonceStr: paymentData.nonceStr,
|
|
|
|
|
package: paymentData.packageVal,
|
|
|
|
|
paySign: paymentData.paySign,
|
|
|
|
|
timeStamp: paymentData.timeStamp,
|
|
|
|
|
signType: paymentData.signType,
|
|
|
|
|
success(res) {
|
|
|
|
|
uni.showModal({
|
|
|
|
|
content: '支付成功',
|
|
|
|
|
showCancel: false
|
|
|
|
|
})
|
|
|
|
|
uni.redirectTo({
|
2025-03-11 14:04:30 +00:00
|
|
|
|
url: '/pages/my-order/myServiceOrderDetail/myServiceOrderDetail?id=' + oid
|
2025-02-28 03:34:36 +00:00
|
|
|
|
})
|
|
|
|
|
console.log('支付成功res--->',res);
|
|
|
|
|
},
|
|
|
|
|
fail(e) {
|
|
|
|
|
uni.redirectTo({
|
2025-03-11 14:04:30 +00:00
|
|
|
|
url: '/pages/my-order/myServiceOrderDetail/myServiceOrderDetail?id=' + oid
|
2025-02-28 03:34:36 +00:00
|
|
|
|
})
|
|
|
|
|
console.log('e.errMsg--->',e.errMsg);
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}catch(error) {
|
|
|
|
|
console.error('支付请求失败',error);
|
|
|
|
|
uni.showModal({
|
|
|
|
|
content: '支付请求失败,请重试。',
|
|
|
|
|
showCancel: false
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-03-12 13:15:24 +00:00
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
//防抖相关变量
|
|
|
|
|
let debounceTimer = null;
|
|
|
|
|
let wxPayTimer = null;
|
|
|
|
|
let loading = false;
|
|
|
|
|
let isLoading = ref(false)
|
|
|
|
|
let isShow = ref(false)
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const fd = () => { //防抖
|
|
|
|
|
clearTimeout(debounceTimer)
|
|
|
|
|
showLoading()
|
|
|
|
|
debounceTimer = setTimeout(async () => {
|
|
|
|
|
await getMyCouponList()
|
|
|
|
|
hideLoading()
|
|
|
|
|
}, 1000)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
const wxPayFd = () => { //微信支付按钮防抖
|
2025-03-04 06:07:24 +00:00
|
|
|
|
if (contactRealInfo.value.phone === null || contactRealInfo.value.phone === '' || contactRealInfo.value.phone === undefined) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: '请选择联系人',
|
|
|
|
|
icon: 'error'
|
|
|
|
|
})
|
|
|
|
|
return ;
|
|
|
|
|
}
|
2025-02-28 03:34:36 +00:00
|
|
|
|
clearTimeout(wxPayTimer)
|
|
|
|
|
showLoading()
|
|
|
|
|
isShow.value = true
|
|
|
|
|
wxPayTimer = setTimeout(async () => {
|
|
|
|
|
await createOrder()
|
|
|
|
|
}, 1000)
|
|
|
|
|
}
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
function showLoading() { //加载弹窗
|
|
|
|
|
if (!loading) {
|
|
|
|
|
wx.showLoading({
|
|
|
|
|
title: '加载中...',
|
|
|
|
|
});
|
|
|
|
|
loading = true;
|
2025-03-01 05:33:28 +00:00
|
|
|
|
isLoading.value = true
|
2025-02-28 03:34:36 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
function hideLoading() { //关闭弹窗
|
|
|
|
|
if (loading) {
|
|
|
|
|
wx.hideLoading();
|
|
|
|
|
loading = false;
|
|
|
|
|
isLoading.value = false
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const openCoupon = () => {
|
|
|
|
|
emitter.emit('getTotalPrice', sumprice.value)
|
|
|
|
|
coupon.value.open('bottom')
|
|
|
|
|
}
|
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
const getMyCouponList = async () => { //获取优惠卷列表
|
|
|
|
|
const res = await uni.request({
|
|
|
|
|
url: baseUrl + '/coupon/list/use',
|
|
|
|
|
method: 'POST',
|
|
|
|
|
header: {
|
|
|
|
|
cookie
|
|
|
|
|
},
|
|
|
|
|
data: {
|
|
|
|
|
currentAmount: sumprice.value,
|
|
|
|
|
isAvailable: true
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
myCouponList.value = res.data.data
|
|
|
|
|
templateString.value = myCouponList.value.length + '张优惠券可用'
|
|
|
|
|
console.log('============================>', myCouponList.value)
|
|
|
|
|
}
|
|
|
|
|
|
2025-03-11 14:04:30 +00:00
|
|
|
|
|
|
|
|
|
function getWeekday(dateStr) {
|
|
|
|
|
const date = new Date(dateStr);
|
|
|
|
|
const weekdays = ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"];
|
|
|
|
|
return weekdays[date.getDay()];
|
|
|
|
|
}
|
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
.overlay {
|
|
|
|
|
position: fixed;
|
|
|
|
|
top: 0;
|
|
|
|
|
left: 0;
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
background-color: rgba(0, 0, 0, 0.4); /* 半透明黑色背景 */
|
|
|
|
|
z-index: 999;
|
|
|
|
|
}
|
2025-03-01 05:33:28 +00:00
|
|
|
|
|
|
|
|
|
.coupon-popup {
|
|
|
|
|
height: 1200rpx;
|
|
|
|
|
justify-content: center;
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
border-radius: 20rpx 20rpx 0 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.my-coupon {
|
|
|
|
|
padding: 25rpx 3.75rpx 25rpx 22.97rpx;
|
|
|
|
|
}
|
|
|
|
|
|
2025-02-28 03:34:36 +00:00
|
|
|
|
.mt-13 {
|
|
|
|
|
margin-top: 24.38rpx;
|
|
|
|
|
}
|
|
|
|
|
.mt-9 {
|
|
|
|
|
margin-top: 16.88rpx;
|
|
|
|
|
}
|
|
|
|
|
.mt-15 {
|
|
|
|
|
margin-top: 28.13rpx;
|
|
|
|
|
}
|
|
|
|
|
.ml-7 {
|
|
|
|
|
margin-left: 13.13rpx;
|
|
|
|
|
}
|
|
|
|
|
.ml-3 {
|
|
|
|
|
margin-left: 5.63rpx;
|
|
|
|
|
}
|
|
|
|
|
.mt-11 {
|
|
|
|
|
margin-top: 20.63rpx;
|
|
|
|
|
}
|
|
|
|
|
.page {
|
|
|
|
|
padding-top: 24.38rpx;
|
|
|
|
|
background-color: #f8e8c1;
|
|
|
|
|
background-image: url('https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FQfLHXSAU-feiyigongfangbeijin.png');
|
|
|
|
|
background-size: 100% 100%;
|
|
|
|
|
background-repeat: no-repeat;
|
|
|
|
|
width: 100%;
|
|
|
|
|
overflow-y: auto;
|
|
|
|
|
overflow-x: hidden;
|
|
|
|
|
height: 100vh;
|
|
|
|
|
}
|
|
|
|
|
.section_2 {
|
|
|
|
|
margin-left: 24.38rpx;
|
|
|
|
|
margin-right: 22.5rpx;
|
|
|
|
|
padding: 20.63rpx 23.08rpx 24.98rpx 27.54rpx;
|
|
|
|
|
background-color: #ffffff;
|
|
|
|
|
border-radius: 18.75rpx;
|
|
|
|
|
}
|
|
|
|
|
.image {
|
|
|
|
|
width: 65.63rpx;
|
|
|
|
|
height: 67.5rpx;
|
|
|
|
|
}
|
|
|
|
|
.text {
|
|
|
|
|
color: #818181;
|
|
|
|
|
font-size: 37.5rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 32.38rpx;
|
|
|
|
|
}
|
|
|
|
|
.group {
|
|
|
|
|
width: 167.03rpx;
|
|
|
|
|
}
|
|
|
|
|
.image_2 {
|
|
|
|
|
margin-left: 129.53rpx;
|
|
|
|
|
width: 37.5rpx;
|
|
|
|
|
height: 37.5rpx;
|
|
|
|
|
}
|
|
|
|
|
.font {
|
|
|
|
|
font-size: 26.25rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 25.54rpx;
|
|
|
|
|
color: #323232;
|
|
|
|
|
}
|
|
|
|
|
.text_2 {
|
|
|
|
|
margin-left: -167.03rpx;
|
|
|
|
|
color: #ffaaa5;
|
|
|
|
|
}
|
|
|
|
|
.section_3 {
|
|
|
|
|
margin: 31.27rpx 15rpx 0 16.88rpx;
|
|
|
|
|
padding: 20.63rpx 18.75rpx 24.38rpx;
|
|
|
|
|
background-color: #ffffff;
|
|
|
|
|
border-radius: 18.75rpx;
|
|
|
|
|
}
|
|
|
|
|
.list-item:first-child {
|
|
|
|
|
margin-top: 0;
|
|
|
|
|
}
|
|
|
|
|
.image_3 {
|
|
|
|
|
border-radius: 9.38rpx;
|
|
|
|
|
width: 142.5rpx;
|
|
|
|
|
height: 166.88rpx;
|
|
|
|
|
}
|
|
|
|
|
.group_5 {
|
|
|
|
|
margin-left: 30.04rpx;
|
|
|
|
|
margin-top: 4.2rpx;
|
|
|
|
|
}
|
|
|
|
|
.group_3 {
|
|
|
|
|
padding: 0 3.83rpx;
|
|
|
|
|
}
|
|
|
|
|
.text_3 {
|
|
|
|
|
line-height: 25.01rpx;
|
|
|
|
|
}
|
|
|
|
|
.font_2 {
|
|
|
|
|
font-size: 26.25rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 25.54rpx;
|
|
|
|
|
color: #818181;
|
|
|
|
|
}
|
|
|
|
|
.text_7 {
|
|
|
|
|
margin-left: 8.01rpx;
|
|
|
|
|
line-height: 24.62rpx;
|
|
|
|
|
}
|
|
|
|
|
.font_3 {
|
|
|
|
|
font-size: 26.25rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 17.53rpx;
|
|
|
|
|
color: #818181;
|
|
|
|
|
}
|
|
|
|
|
.text_8 {
|
|
|
|
|
margin-left: 9.21rpx;
|
|
|
|
|
}
|
|
|
|
|
.image_6 {
|
|
|
|
|
width: 35.63rpx;
|
|
|
|
|
height: 30rpx;
|
|
|
|
|
}
|
|
|
|
|
.font_5 {
|
|
|
|
|
font-size: 33.75rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 22.54rpx;
|
|
|
|
|
color: #323232;
|
|
|
|
|
}
|
|
|
|
|
.font_6 {
|
|
|
|
|
font-size: 26.25rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 17.53rpx;
|
|
|
|
|
color: #323232;
|
|
|
|
|
}
|
|
|
|
|
.image_4 {
|
|
|
|
|
border-radius: 9.38rpx 0rpx 0rpx 9.38rpx;
|
|
|
|
|
width: 45rpx;
|
|
|
|
|
height: 45rpx;
|
|
|
|
|
}
|
|
|
|
|
.group_4 {
|
|
|
|
|
margin-left: 3.75rpx;
|
|
|
|
|
margin-right: 5.63rpx;
|
|
|
|
|
}
|
|
|
|
|
.text-wrapper {
|
|
|
|
|
padding: 11.31rpx 0 16.46rpx;
|
|
|
|
|
background-color: #ffaaa5;
|
|
|
|
|
width: 58.13rpx;
|
|
|
|
|
height: 45rpx;
|
|
|
|
|
}
|
|
|
|
|
.font_4 {
|
|
|
|
|
font-size: 26.25rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 17.53rpx;
|
|
|
|
|
color: #ffffff;
|
|
|
|
|
}
|
|
|
|
|
.text_6 {
|
|
|
|
|
line-height: 17.23rpx;
|
|
|
|
|
}
|
|
|
|
|
.image_5 {
|
|
|
|
|
border-radius: 0rpx 9.38rpx 9.38rpx 0rpx;
|
|
|
|
|
width: 45rpx;
|
|
|
|
|
height: 45rpx;
|
|
|
|
|
}
|
|
|
|
|
.group_9 {
|
|
|
|
|
padding: 0 138.81rpx;
|
|
|
|
|
}
|
|
|
|
|
.group_10 {
|
|
|
|
|
line-height: 21.71rpx;
|
|
|
|
|
height: 21.71rpx;
|
|
|
|
|
}
|
|
|
|
|
.font_7 {
|
2025-03-11 14:04:30 +00:00
|
|
|
|
font-size: 25.5rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 22.54rpx;
|
|
|
|
|
color: #818181;
|
|
|
|
|
}
|
|
|
|
|
.text_11 {
|
|
|
|
|
line-height: 21.71rpx;
|
|
|
|
|
}
|
|
|
|
|
.text_12 {
|
|
|
|
|
color: #ed4845;
|
|
|
|
|
line-height: 21rpx;
|
|
|
|
|
}
|
|
|
|
|
.image_7 {
|
|
|
|
|
width: 26.25rpx;
|
|
|
|
|
height: 26.25rpx;
|
|
|
|
|
}
|
|
|
|
|
.section_4 {
|
|
|
|
|
margin: 30rpx 16.88rpx 0 16.88rpx;
|
2025-03-01 05:33:28 +00:00
|
|
|
|
padding: 20rpx 19.22rpx 20.63rpx;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
background-color: #ffffff;
|
|
|
|
|
border-radius: 18.75rpx;
|
|
|
|
|
}
|
|
|
|
|
.font_8 {
|
|
|
|
|
font-size: 30rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 29.18rpx;
|
|
|
|
|
color: #323232;
|
|
|
|
|
}
|
|
|
|
|
.text_13 {
|
|
|
|
|
line-height: 28.13rpx;
|
|
|
|
|
}
|
|
|
|
|
.font_9 {
|
|
|
|
|
font-size: 30rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 29.18rpx;
|
|
|
|
|
color: #818181;
|
|
|
|
|
}
|
|
|
|
|
.group_11 {
|
|
|
|
|
margin-right: 9.38rpx;
|
|
|
|
|
}
|
|
|
|
|
.image_8 {
|
|
|
|
|
width: 33.75rpx;
|
|
|
|
|
height: 33.75rpx;
|
|
|
|
|
}
|
|
|
|
|
.font_10 {
|
|
|
|
|
font-size: 30rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 20.04rpx;
|
|
|
|
|
color: #323232;
|
|
|
|
|
}
|
|
|
|
|
.group_12 {
|
|
|
|
|
margin-right: 5.16rpx;
|
|
|
|
|
}
|
|
|
|
|
.image_9 {
|
|
|
|
|
width: 30rpx;
|
|
|
|
|
height: 30rpx;
|
|
|
|
|
}
|
|
|
|
|
.text_14 {
|
|
|
|
|
line-height: 27.77rpx;
|
|
|
|
|
}
|
|
|
|
|
.group_13 {
|
|
|
|
|
margin-right: 13.37rpx;
|
|
|
|
|
}
|
|
|
|
|
.section_5 {
|
|
|
|
|
margin: 28.13rpx 15rpx 110rpx 18.75rpx;
|
2025-03-11 14:04:30 +00:00
|
|
|
|
padding: 17.81rpx 24.13rpx 32.5rpx;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
background-color: #ffffff;
|
|
|
|
|
border-radius: 18.75rpx;
|
|
|
|
|
}
|
|
|
|
|
.text_15 {
|
|
|
|
|
color: #000000;
|
|
|
|
|
line-height: 29.53rpx;
|
|
|
|
|
}
|
|
|
|
|
.text-wrapper_2 {
|
2025-03-11 14:04:30 +00:00
|
|
|
|
height: 200rpx;
|
|
|
|
|
width: 650rpx;
|
|
|
|
|
padding: 22.35rpx;
|
|
|
|
|
box-sizing: border-box;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
background-color: #ffefef;
|
|
|
|
|
border-radius: 9.38rpx;
|
2025-03-11 14:04:30 +00:00
|
|
|
|
margin: 20rpx auto 0;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
}
|
|
|
|
|
.text_16 {
|
|
|
|
|
margin-left: 21.15rpx;
|
|
|
|
|
line-height: 21.81rpx;
|
|
|
|
|
}
|
|
|
|
|
.section_6 {
|
|
|
|
|
position: fixed;
|
|
|
|
|
left: 0;
|
|
|
|
|
right: 0;
|
|
|
|
|
bottom: 0;
|
|
|
|
|
// margin-top: 333.75rpx;
|
|
|
|
|
padding: 16.88rpx 25.31rpx 15rpx;
|
|
|
|
|
background-color: #ffffff;
|
|
|
|
|
}
|
|
|
|
|
.image_10 {
|
|
|
|
|
margin-left: 85.31rpx;
|
|
|
|
|
}
|
|
|
|
|
.text_17 {
|
|
|
|
|
margin-left: -119.06rpx;
|
|
|
|
|
color: #000000;
|
|
|
|
|
font-size: 30rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
line-height: 26.49rpx;
|
|
|
|
|
}
|
|
|
|
|
.text_18 {
|
|
|
|
|
margin-left: 28.5rpx;
|
|
|
|
|
color: #ffaaa5;
|
|
|
|
|
font-size: 37.5rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
font-weight: 700;
|
|
|
|
|
line-height: 27.62rpx;
|
|
|
|
|
}
|
|
|
|
|
.text_20 {
|
|
|
|
|
color: #ffaaa5;
|
|
|
|
|
font-size: 30rpx;
|
2025-03-12 13:15:24 +00:00
|
|
|
|
font-family: FangZhengFonts;
|
2025-02-28 03:34:36 +00:00
|
|
|
|
font-weight: 700;
|
|
|
|
|
line-height: 22.05rpx;
|
|
|
|
|
}
|
|
|
|
|
.text-wrapper_3 {
|
|
|
|
|
padding: 20.51rpx 0 22.97rpx;
|
|
|
|
|
background-color: #ffaaa5;
|
|
|
|
|
border-radius: 75rpx;
|
|
|
|
|
width: 204.38rpx;
|
|
|
|
|
height: 71.25rpx;
|
|
|
|
|
}
|
|
|
|
|
.text_19 {
|
|
|
|
|
color: #ffffff;
|
|
|
|
|
line-height: 27.77rpx;
|
|
|
|
|
}
|
|
|
|
|
.popup-content {
|
|
|
|
|
height: 800rpx;
|
|
|
|
|
}
|
|
|
|
|
@import url(../../../common/css/global.css);
|
|
|
|
|
</style>
|