服务类单个、批量购买、订单状态、联系人信息、地址信息、支付防抖完成

This commit is contained in:
yuanteng0011 2025-02-28 11:34:36 +08:00
parent 5868e94f4b
commit 2d6e8703be
15 changed files with 1384 additions and 1178 deletions

View File

@ -4,4 +4,4 @@ export const suiUrl = 'http://154.8.193.216:9092/api' //隋宇霏的接口地
export const domain = 'https://www.carboner.cn/api'
export const myIp = 'http://8.130.119.119:9092/api'
export const baseUrl = Url
export const baseUrl = testUrl

View File

@ -47,6 +47,42 @@ export const stateMap = new Map()
stateList.forEach((item)=>{
stateMap.set(item.state,item)
})
export const serviceStateList = [
{
state: '待支付',
img: 'https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FFybMDtHR-dengdaifukuan.png',
msg: '等待买家付款',
tips: '请于15分钟内付款超时订单将自动关闭'
},
{
state: '待发货',
img: 'https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FEOzVqolp-fahuo.png',
msg: '待到店体验',
tips: '等待您的光临体验~'
},
{
state: '已退款',
img: 'https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FlPnvgqCp-yituikuan.png',
msg: '订单已经退款',
tips: '希望下次能让君满意'
},
{
state: '已完成',
img: '',
msg: '订单完成,感谢您的支持',
tips: '感谢您的支持'
},
{
state: '交易关闭',
img: 'https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FaHDhacaI-dengdaifukuan.png',
msg: '您的订单已关闭',
tips: '下次看好了之后再买哦'
}
]
export const serviceStateMap = new Map()
serviceStateList.forEach((item)=>{
serviceStateMap.set(item.state,item)
})
//获取选中日期是星期几方法
export const weekDay = function(time) {
let datelist = ['周日','周一','周二','周三','周四','周五','周六',]

View File

@ -1,5 +1,14 @@
{
"pages": [
{
"path" : "pages/home/home",
"style" :
{
"navigationBarTitleText" : "首页",
"enablePullDownRefresh":true, //
"navigationBarBackgroundColor": "#ede8e7"
}
},
{
"path" : "pages/order/service-paystatus/service-paystatus",
"style" :
@ -63,15 +72,6 @@
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/home/home",
"style" :
{
"navigationBarTitleText" : "首页",
"enablePullDownRefresh":true, //
"navigationBarBackgroundColor": "#ede8e7"
}
},
{
"path" : "pages/store-home/main/main",
"style" :
@ -198,13 +198,6 @@
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/mine/OrderDetails/OrderDetails",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/workshop/index/index",
"style" :
@ -269,13 +262,6 @@
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/workshop/component/testTimePopUp",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/mine/addressList/addressList",
"style" :
@ -324,6 +310,13 @@
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/order/singleServiceWait/singleServiceWait",
"style" :
{
"navigationBarTitleText" : ""
}
}
],
"plugins" : {

View File

@ -1,492 +0,0 @@
<template>
<view class="flex-col page">
<view class="flex-col">
<view class="flex-col justify-start items-start image-wrapper">
<image class="image"
src="https://ide.code.fun/api/image?token=672dbef4c471750012de4bf6&name=c450ffa87845363012613b1e0f522a87.png" />
</view>
<view class="flex-col group">
<view class="flex-row items-center section">
<image class="image_2"
src="https://ide.code.fun/api/image?token=672dbef4c471750012de4bf6&name=d7c7e8f082bbf68fe1e60091fa650fcd.png" />
<view class="ml-6 flex-col items-start flex-1">
<text class="font text">等待买家付款</text>
<text class="font_2 text_2 mt-5">请于13分51秒内付款超时订单将自动关闭</text>
</view>
</view>
<view class="mt-8 flex-row items-center section_2">
<image class="shrink-0 image_3"
src="https://ide.code.fun/api/image?token=672dbef4c471750012de4bf6&name=19ebf0fd3bd190ff882354f39ef52d3e.png" />
<view class="ml-8 flex-col items-start flex-1">
<!-- <text class="font text_3">张三 15888610253</text> -->
<view class="font text_3">{{Status.addressSnapshot.name+Status.addressSnapshot.phone}}</view>
<!-- <text class="mt-12 font_2 text_4">黑龙江省哈尔滨市呼兰区学院路街道288号哈尔滨华德学院</text> -->
<view class="mt-12 font_2 text_4">{{Status.addressSnapshot.region+Status.addressSnapshot.detailAddress}}
</view>
</view>
</view>
<view class="mt-8 flex-col section_3">
<view class="flex-row justify-between self-stretch group_2">
<view class="flex-row self-center">
<!-- <image
class="image_4"
src="https://ide.code.fun/api/image?token=672dbef4c471750012de4bf6&name=be4a0c4089866e086291773796509ef4.png"
/> -->
<view v-for="i in Status.orderItemList" :key="i">
<image :src="i.goodSnapshot.goodImg" style="height: 50px;width: 50px;" class="image_4"></image>
</view>
<view class="flex-col group_3 ml-17">
<view class="flex-col">
<view class="flex-row self-stretch">
<!-- <text class="font">非遗绒花</text> -->
<view v-for="i in Status.orderItemList" :key="i" class="font">
{{i.goodSnapshot.name}}
</view>
<!-- <text class="ml-4 font">材料包</text> -->
<view v-for="i in Status.orderItemList" :key="i" class="ml-4 font">
{{i.goodSnapshot.type}}
</view>
</view>
<text class="self-start font_2 text_5 mt-11">已选种类紫色</text>
</view>
<view class="mt-38 flex-row items-center">
<view class="flex-row items-center group_4">
<!-- <text class="text_6">138.</text> -->
<view v-for="i in Status.orderItemList" :key="i" class="text_6">
{{i.goodSnapshot.price}}
</view>
<image class="image_5 image_6"
src="https://ide.code.fun/api/image?token=672dbef4c471750012de4bf6&name=53a8efcd2031289983433ba21eb70050.png" />
</view>
</view>
</view>
</view>
<text class="self-start font_3 text_8">×1</text>
</view>
<view class="flex-row justify-between items-center self-stretch group_5">
<text class="font_4 text_9">商品金额</text>
<view class="flex-row items-center">
<!-- <text class="font_3">138.00</text> -->
<view v-for="i in Status.orderItemList" :key="i" class="font_3">
{{i.goodSnapshot.price}}
</view>
</view>
</view>
<view class="flex-row justify-between items-center self-stretch group_6">
<text class="font_4 text_10">优惠券</text>
<view class="flex-row items-center">
<text class="font_3">-50.00</text>
</view>
</view>
<view class="flex-row justify-end items-center self-stretch group_7">
<view class="flex-row items-center group_8">
<image class="image_5 image_8"
src="https://ide.code.fun/api/image?token=672dbef4c471750012de4bf6&name=4713f88f0f01fcb4c33fac4a8eba7f0f.png" />
<text class="font text_11">合计</text>
</view>
<text class="font_3 text_12">88.00</text>
</view>
<view class="self-stretch divider view"></view>
<text class="self-start font_4 text_13">买家留言</text>
<view class="flex-col justify-start self-stretch text-wrapper">
<text class="font_2 text_14">
希望所使用的材料是可持续来源的并且制作工艺要精细以确保每一朵花瓣都能生动地展现出绒花的质感和美感
</text>
</view>
<view class="self-stretch divider view_2"></view>
<view class="flex-row justify-between self-stretch group_9">
<text class="font_2 text_15">订单编号</text>
<view class="flex-row items-center">
<!-- <text class="font_5 text_16">E20241005095840091406189</text> -->
<text class="font_5 text_16">{{Status.orderNumber}}</text>
<view class="ml-2 flex-col justify-start items-center shrink-0 text-wrapper_2">
<text class="text_17">复制</text>
</view>
</view>
</view>
<view class="flex-row justify-between items-center self-stretch group_10">
<text class="font_2 text_18">创建时间</text>
<text class="font_5 text_19">2024-10-05 09:58:41</text>
</view>
</view>
</view>
</view>
<view class="flex-row justify-between items-center section_4 mt-284">
<view class="flex-row items-center" style="margin-left:80px;">
<!-- <text class="text_21">88.</text> -->
<text class="font_6 text_20"> 合计</text>
<!-- <text class="text_23">00</text> -->
<view v-for="i in Status.orderItemList" :key="i" class="text_21">
{{i.goodSnapshot.price}}
</view>
</view>
<view class="flex-col justify-start items-center text-wrapper_3">
<!-- <text class="font_6 text_22">去支付</text> -->
<view v-if="Status.orderStatus==='待支付'" class="font_6 text_22">去支付</view>
<view v-if="Status.orderStatus==='待发货'" class="font_6 text_22">取消订单</view>
<view v-if="Status.orderStatus==='待收货'" class="font_6 text_22">查看物流</view>
<view v-if="Status.orderStatus==='待收货'" class="font_6 text_22">确认收货</view>
<view v-if="Status.orderStatus==='售后'" class="font_6 text_22">售后详情</view>
</view>
</view>
</view>
</template>
<script setup>
import { onMounted, ref } from 'vue'
import { onLoad } from "@dcloudio/uni-app";
const Status = ref({})
console.log(Status.value, 34)
onLoad((options) => {
Status.value = JSON.parse(options.info);
console.log(Status.value, 111)
console.log(Status.value.orderStatus, 222)
})
</script>
<style lang="scss" scoped>
.mt-5 {
margin-top: 9.38rpx;
}
.ml-17 {
margin-left: 31.88rpx;
}
.mt-11 {
margin-top: 20.63rpx;
}
.mt-284 {
margin-top: 532.5rpx;
}
.page {
background-color: #f8e8c1;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
}
.image-wrapper {
padding: 15rpx 0;
background-color: #fffef8;
}
.image {
margin-left: 16.88rpx;
width: 37.5rpx;
height: 37.5rpx;
}
.group {
padding: 15rpx 15rpx 0;
}
.section {
padding: 16.88rpx 18.75rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.image_2 {
width: 75rpx;
height: 75rpx;
}
.section_2 {
padding: 33.75rpx 18.75rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.image_3 {
width: 43.13rpx;
height: 43.13rpx;
}
.font_2 {
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 19.39rpx;
color: #818181;
}
.text_2 {
color: #6b6e72;
line-height: 21.34rpx;
}
.text_4 {
line-height: 20.91rpx;
}
.section_3 {
padding: 0 18.75rpx 26.25rpx 24.38rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.group_2 {
padding: 22.5rpx 0;
border-bottom: solid 1.88rpx #dfdfdf;
}
.image_4 {
margin-bottom: 5.63rpx;
border-radius: 9.38rpx;
width: 146.25rpx;
height: 165rpx;
}
.group_3 {
margin-top: 3.75rpx;
}
.font {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 24.43rpx;
color: #323232;
}
.text_3 {
line-height: 23.77rpx;
}
.text {
color: #323233;
font-size: 28.13rpx;
line-height: 26.08rpx;
}
.text_5 {
line-height: 20.79rpx;
}
.group_4 {
width: 90.66rpx;
}
.text_6 {
margin-left: 26.25rpx;
color: #323232;
font-size: 33.75rpx;
font-family: Open Sans;
font-weight: 600;
line-height: 24.88rpx;
}
.image_5 {
width: 30rpx;
height: 30rpx;
}
.image_6 {
margin-left: -90rpx;
}
.font_3 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 19.39rpx;
color: #323232;
}
.text_7 {
font-weight: 600;
line-height: 19.29rpx;
}
.text_8 {
margin-right: 7.5rpx;
margin-top: 146.25rpx;
line-height: 18.73rpx;
}
.group_5 {
margin-top: 26.25rpx;
}
.font_4 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 24.43rpx;
color: #818181;
}
.text_9 {
line-height: 24.28rpx;
}
.group_6 {
margin-top: 13.13rpx;
}
.text_10 {
line-height: 24.26rpx;
}
.image_7 {
width: 41.25rpx;
height: 30rpx;
}
.group_7 {
margin-top: 16.88rpx;
}
.group_8 {
width: 102.26rpx;
}
.image_8 {
margin-left: 71.25rpx;
}
.text_11 {
margin-left: -101.25rpx;
line-height: 24.09rpx;
}
.text_12 {
color: #fb8b05;
}
.divider {
background-color: #dfdfdf;
height: 1.88rpx;
}
.view {
margin-top: 16.88rpx;
}
.text_13 {
margin-top: 30rpx;
line-height: 24.21rpx;
}
.text-wrapper {
margin-top: 15rpx;
padding: 15rpx 0 11.25rpx;
background-color: #fffef8;
border-radius: 9.38rpx;
border-left: solid 1.88rpx #f0f0b5;
border-right: solid 1.88rpx #f0f0b5;
border-top: solid 1.88rpx #f0f0b5;
border-bottom: solid 1.88rpx #f0f0b5;
}
.text_14 {
margin-left: 15rpx;
margin-right: 18.75rpx;
line-height: 26.25rpx;
}
.view_2 {
margin-top: 18.75rpx;
}
.group_9 {
margin-top: 22.5rpx;
}
.text_15 {
line-height: 20.85rpx;
}
.font_5 {
font-size: 22.5rpx;
font-family: Open Sans;
color: #323232;
}
.text_16 {
line-height: 16.54rpx;
}
.text-wrapper_2 {
background-color: #fffef8;
width: 50.63rpx;
height: 22.5rpx;
border-left: solid 0.94rpx #d1d1d1;
border-right: solid 0.94rpx #d1d1d1;
border-top: solid 0.94rpx #d1d1d1;
border-bottom: solid 0.94rpx #d1d1d1;
}
.text_17 {
color: #323232;
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 17.38rpx;
}
.group_10 {
margin-top: 11.25rpx;
}
.text_18 {
line-height: 20.7rpx;
}
.text_19 {
margin-right: 157.5rpx;
line-height: 16.63rpx;
}
.section_4 {
padding: 15rpx 26.25rpx;
background-color: #fffef8;
}
.image_9 {
margin-left: 86.25rpx;
width: 33.75rpx;
height: 33.75rpx;
}
.text_21 {
color: #fbb612;
font-size: 37.5rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 27.62rpx;
}
.font_6 {
font-size: 30rpx;
font-family: Open Sans;
line-height: 27.62rpx;
}
.text_20 {
margin-left: -172.5rpx;
color: #000000;
line-height: 27.54rpx;
}
.text_23 {
margin-left: 78.75rpx;
color: #fbb612;
font-size: 30rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 22.05rpx;
}
.text-wrapper_3 {
padding: 22.5rpx 0;
background-color: #fbb612;
border-radius: 75rpx;
width: 204.38rpx;
height: 71.25rpx;
}
.text_22 {
color: #ffffff;
line-height: 27.86rpx;
}
@import url(/common/css/global.css);
</style>

View File

@ -91,7 +91,7 @@
<view class="flex-row justify-end group_7" v-if="order.orderStatus==='待支付'">
<view class="flex-col justify-start items-center text-wrapper" @click="cancelOrder(order)"><text
class="font text_18">取消订单</text></view>
<view class="flex-col justify-start items-center text-wrapper_2 ml-14" @click="goToPay(order)">
<view class="flex-col justify-start items-center text-wrapper_2 ml-14" @click="wxPayFd(order)">
<text class="font_3">去支付</text>
</view>
</view>
@ -117,6 +117,8 @@
</view>
</view>
</view>
<!-- 遮罩层 -->
<view v-if="isShow" class="overlay"></view>
</template>
<script setup>
@ -203,10 +205,16 @@ const isSelected = (tab) => Status.value.orderStatus === tab
}
}
const goToText = (orderInfo) => {
console.log(orderInfo);
uni.navigateTo({
url: '../../../pages/order/product-paysuccess/product-paysuccess?oid=' + JSON.stringify(orderInfo.id)
})
console.log('订单信息--->',orderInfo);
if(orderInfo.orderType === 'product') {
uni.navigateTo({
url: '../../../pages/order/product-paysuccess/product-paysuccess?oid=' + JSON.stringify(orderInfo.id)
})
} else {
uni.navigateTo({
url: '../../../pages/order/service-paystatus/service-paystatus?oid=' + JSON.stringify(orderInfo.id)
})
}
}
const cancelOrder = async (order) => { //
console.log(order);
@ -222,9 +230,6 @@ const cancelOrder = async (order) => { //取消订单
}
})
}
const goToPay = async (order) => {
wxPay(order.id) //
}
const wxPay = async( oid )=> { //id
try {
const res = await uni.request({
@ -270,20 +275,38 @@ const wxPay = async( oid )=> { //传入订单id
}
}
const postCancelOrder = async(order)=>{ //
const res = await uni.request({
url: baseUrl + '/order/cancel/id',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: { id: order.id }
})
console.log('取消订单的信息--->',res.data);
if(res.data.code === 1) {
Getorder() //
uni.redirectTo({
url: '/pages/mine/mineorders/mineorders?zt=' + JSON.stringify(Status.value.orderStatus)
if(order.addressSnapshot != null) {
const res = await uni.request({
url: baseUrl + '/order/cancel/id',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: { id: order.id }
})
console.log('取消订单的信息--->',res.data);
if(res.data.code === 1) {
Getorder() //
uni.redirectTo({
url: '/pages/mine/mineorders/mineorders?zt=' + JSON.stringify(Status.value.orderStatus)
})
}
} else {
const res = await uni.request({
url: baseUrl + '/order/cancel/service/id',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: { id: order.id }
})
console.log('取消订单的信息--->',res.data);
if(res.data.code === 1) {
Getorder() //
uni.redirectTo({
url: '/pages/mine/mineorders/mineorders?zt=' + JSON.stringify(Status.value.orderStatus)
})
}
}
}
//
@ -326,9 +349,52 @@ const getFonts =()=>{
const confirm =()=> { //
console.log('确认收货方法');
}
//
let debounceTimer = null;
let wxPayTimer = null;
let loading = false;
let isLoading = ref(false)
let isShow = ref(false)
const wxPayFd = (order) => { //
clearTimeout(wxPayTimer)
showLoading()
isShow.value = true //
wxPayTimer = setTimeout(async () => {
await wxPay(order.id)
}, 1000)
setTimeout(()=>{
hideLoading()
isShow.value = false //
},2000)
}
function showLoading() { //
if (!loading) {
wx.showLoading({
title: '加载中...',
});
loading = true;
isLoading.value = true
}
}
function hideLoading() { //
if (loading) {
wx.hideLoading();
loading = false;
isLoading.value = false
}
}
</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;
}
.groupp {
padding: 22.5rpx 0 18.75rpx;
}

View File

@ -1,36 +1,43 @@
<template>
<view class="flex-col page">
<view class="flex-row justify-center items-center relative group">
<text class="text">收货地址</text>
<image class="image pos" @click="closeWindow"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FxSHTnKhk-close.png" />
</view>
<view class="flex-col list">
<radio-group @change="radioChange">
<view class="flex-col list-item_1" v-for="(item, index) in addressList" :key="index">
<view class="flex-row justify-between items-center self-stretch">
<view class="flex-row items-center">
<radio color="#00ba9c" :value="index" :checked="item.isDefault === 1"></radio>
<text class="font ml-9">{{ item.name }}</text>
<text class="font_2 ml-9">{{ item.phone }}</text>
</view>
<view class="flex-row group_3">
<image class="image_3"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FKNXwmQrO-edit.png" @click="editAddress(item)"/>
<image class="image_3 ml-12"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FXPhhJFpx-delete.png" @click="deleteAddress(item.id)" />
</view>
</view>
<text class="self-center font_3 text_2 mt-12">{{ item.detailAddress }}</text>
</view>
</radio-group>
</view>
<view class="flex-col justify-start items-center section" @click="toNewAddress">
<view class="flex-col justify-start items-center text-wrapper"><text class="text_3">添加新地址</text></view>
</view>
</view>
<view class="flex-col page">
<view class="flex-row justify-center items-center self-stretch relative section_2">
<text class="text">收货地址</text>
<image
@click="closeWindow"
class="image pos_2"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FxSHTnKhk-close.png"
/>
</view>
<view class="flex-col self-stretch list">
<radio-group @change="radioChange">
<view class="flex-col list-item mt-10" v-for="(item, index) in addressList" :key="index">
<view class="flex-row justify-between items-center self-stretch">
<view class="flex-row items-center">
<radio color="#E79EA1" :value="index" :checked="item.isDefault === 1"></radio>
<text class="font ml-8">{{ item.name }}</text>
<text class="font_2 ml-8">{{ item.phone }}</text>
</view>
<view class="flex-row group">
<image
class="image_2"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FKNXwmQrO-edit.png"
@click="editAddress(item)"
/>
<image
class="image_2 ml-11"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FXPhhJFpx-delete.png"
@click="confirmDelete(item.id)"
/>
</view>
</view>
<text class="self-center font_3 text_2 mt-14">{{ item.region }}{{ item.detailAddress }}</text>
</view>
</radio-group>
</view>
<view class="flex-col justify-start items-center self-center text-wrapper" @click="toNewAddress">
<text class="text_3">添加新地址</text>
</view>
</view>
</template>
<script setup>
@ -38,7 +45,7 @@ import {nextTick, onMounted , ref } from 'vue'
import emitter from '../../../utils/emitter'
import { testUrl , baseUrl , suiUrl } from '../../../api/request';
import { onShow } from "@dcloudio/uni-app";
const items = ref([null, null])
const items = ref([null, null,null,null,null,null, null,null,null,null])
const addressList = ref([])
const userInfo = wx.getStorageSync('userInfo')
// onShow
@ -81,6 +88,18 @@ const editAddress =(value)=>{
url: '/pages/Shopping-cart/newaddress_Info/newaddress_Info?editInfo=' + JSON.stringify(value)
})
}
const confirmDelete =(id)=> { //
uni.showModal({
title: '提示',
content: '是否删除地址?',
success: (e) => {
if (e.confirm) {
deleteAddress(id)
} else if (e.cancel)
return;
}
})
}
//
const deleteAddress = async( id ) =>{
const res = await uni.request({
@ -105,121 +124,103 @@ const closeWindow =()=> {
</script>
<style lang="scss" scoped>
.ml-9 {
margin-left: 16.88rpx;
}
.page {
padding-top: 18.75rpx;
background-color: #f5f5dc;
border-radius: 28.13rpx 28.13rpx 0rpx 0rpx;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
}
.group {
position: fixed;
top: 0;
left: 0;
right: 0;
height: 60rpx;
background-color: #fbc27b;
padding: 11.47rpx 24.38rpx 6.26rpx;
}
.text {
color: #323232;
font-size: 37.5rpx;
font-family: Open Sans;
line-height: 34.76rpx;
}
.image {
width: 52.5rpx;
height: 52.5rpx;
}
.pos {
position: absolute;
right: 24.38rpx;
top: 50%;
transform: translateY(-50%);
}
.list {
margin-top: 30rpx;
margin-bottom: 30rpx;
}
.list-item_1 {
padding: 26.27rpx 16.8rpx 24.98rpx;
background-color: #fffef8;
border-bottom: solid 1.88rpx #c8c8c8;
}
.image_2 {
width: 33.75rpx;
height: 33.75rpx;
}
.font {
font-size: 30rpx;
font-family: Open Sans;
line-height: 27.19rpx;
color: #323232;
}
.font_2 {
font-size: 30rpx;
font-family: Open Sans;
line-height: 22.05rpx;
color: #323232;
}
.group_3 {
margin-right: 10.97rpx;
}
.image_3 {
width: 39.38rpx;
height: 39.38rpx;
}
.font_3 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 31.88rpx;
color: #818181;
}
.text_2 {
width: 601.88rpx;
}
.section {
position: fixed;
left: 0;
bottom: 0;
right: 0;
margin-top: 202.5rpx;
padding: 18.75rpx 0;
background-color: #fffef8;
}
.text-wrapper {
padding: 27.9rpx 0 29.01rpx;
background-color: #fbb612;
border-radius: 75rpx;
width: 639.38rpx;
}
.text_3 {
color: #ffffff;
font-size: 33.75rpx;
font-family: Open Sans;
line-height: 31.22rpx;
}
.ml-11 {
margin-left: 20.57rpx;
}
.page {
padding-bottom: 29.93rpx;
background-color: #f5f5dc;
border-radius: 28.05rpx 28.05rpx 0rpx 0rpx;
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: 100%;
}
.section_2 {
position: fixed;
left: 0;
right: 0;
top: 0;
z-index: 1;
padding: 28.88rpx 26.18rpx 21.21rpx;
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;
}
.text {
color: #323232;
font-size: 37.41rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 35.95rpx;
}
.image {
width: 52.37rpx;
height: 52.37rpx;
}
.pos_2 {
position: absolute;
right: 26.18rpx;
top: 50%;
transform: translateY(-50%);
}
.list {
margin: 100.96rpx 14.96rpx 0 16.83rpx;
}
.list-item {
padding: 26.18rpx 16.01rpx 30.41rpx 16.03rpx;
background-color: #ffffff;
border-radius: 28.05rpx;
}
.list-item:first-child {
margin-top: 0;
}
.image_3 {
width: 31.8rpx;
height: 33.67rpx;
}
.font {
font-size: 29.93rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.83rpx;
color: #323232;
}
.font_2 {
font-size: 29.93rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 19.99rpx;
color: #323232;
}
.group {
margin-right: 10.72rpx;
}
.image_2 {
width: 37.41rpx;
height: 39.28rpx;
}
.font_3 {
font-size: 26.18rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 31.8rpx;
color: #818181;
}
.text_2 {
width: 572.32rpx;
}
.text-wrapper {
margin-top: 80.72rpx;
padding: 26.75rpx 0 29.61rpx;
background-color: #ffb6b9;
border-radius: 74.81rpx;
width: 637.78rpx;
}
.text_3 {
color: #ffffff;
font-size: 33.67rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 31.57rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -100,7 +100,7 @@
class="shrink-0 image_8"
src="https://ide.code.fun/api/image?token=6764d712797f850011f38d7b&name=549b29459342a9a09d24834be40eb53b.png"
/>
<text class="text_31">{{ orderObject.totalAmount }}</text>
<text class="text_31">{{ orderObject.totalAmount }}</text>
<!-- <text class="text_33">00</text> -->
</view>
<view class="flex-col justify-start items-center text-wrapper_2" @click="stateSubmit(orderObject)" v-if="bottomBtn != '联系客服'">
@ -114,6 +114,8 @@
</button>
</view>
</view>
<!-- 遮罩层 -->
<view v-if="isShow" class="overlay"></view>
</template>
<script setup>
@ -168,7 +170,7 @@ const setBottomText =()=>{ //更改按钮的字体
const stateSubmit = (obj) => { //
// console.log('obj--->',obj);
if(bottomBtn.value === '立即支付') { //
wxPay(oid.value)
wxPayFd(oid.value)
} else if(bottomBtn.value === '删除订单') {
console.log('订单被删除');
} else if(bottomBtn.value === '查看物流') {
@ -204,10 +206,10 @@ const wxPay = async( oid )=> { //传入订单id
buffer()
},
fail(e) {
uni.showModal({
content: '支付失败,原因为:' + e.errMsg,
showCancel: false
})
// uni.showModal({
// content: ':' + e.errMsg,
// showCancel: false
// })
}
})
}catch(error) {
@ -255,9 +257,58 @@ const copy = ( orderNumber ) => {
}
})
}
//
let debounceTimer = null;
let wxPayTimer = null;
let loading = false;
let isLoading = ref(false)
let isShow = ref(false)
const fd = () => { //
clearTimeout(debounceTimer)
showLoading()
debounceTimer = setTimeout(async () => {
await getMyCouponList()
hideLoading()
}, 1000)
}
const wxPayFd = (oid) => { //
clearTimeout(wxPayTimer)
isShow.value = true
showLoading()
wxPayTimer = setTimeout(async () => {
await wxPay(oid)
hideLoading()
}, 1000)
}
function showLoading() { //
if (!loading) {
wx.showLoading({
title: '加载中...',
});
loading = true;
isLoading.value = true
}
}
function hideLoading() { //
if (loading) {
wx.hideLoading();
loading = false;
isLoading.value = false
isShow.value = false
}
}
</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;
}
.goodsBox {
margin-bottom: 20rpx;
}

View File

@ -145,7 +145,7 @@
<text class="text_22">{{ sumprice.toFixed(2) }}</text>
<!-- <text class="text_24">00</text> -->
</view>
<view class="flex-col justify-start items-center text-wrapper_3" @click="createOrder"><text class="font_7 text_23">微信支付</text></view>
<view class="flex-col justify-start items-center text-wrapper_3" @click="wxPayFd()"><text class="font_7 text_23">微信支付</text></view>
</view>
</view>
<uni-popup ref="popup" background-color="#fff">
@ -153,6 +153,8 @@
<addressComponentVue></addressComponentVue>
</view>
</uni-popup>
<!-- 遮罩层 -->
<view v-if="isShow" class="overlay"></view>
</template>
<script setup>
@ -366,11 +368,60 @@ const getFonts =()=>{
}
})
}
//
let debounceTimer = null;
let wxPayTimer = null;
let loading = false;
let isLoading = ref(false)
let isShow = ref(false)
const fd = () => { //
clearTimeout(debounceTimer)
showLoading()
debounceTimer = setTimeout(async () => {
await getMyCouponList()
hideLoading()
}, 1000)
}
const wxPayFd = () => { //
clearTimeout(wxPayTimer)
showLoading()
isShow.value = true
wxPayTimer = setTimeout(async () => {
await createOrder()
hideLoading()
}, 1000)
}
function showLoading() { //
if (!loading) {
wx.showLoading({
title: '加载中...',
});
loading = true;
isLoading.value = true
}
}
function hideLoading() { //
if (loading) {
wx.hideLoading();
loading = false;
isLoading.value = false
isShow.value = false
}
}
</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;
}
.popup-content {
height: 392px;
height: 300px;
align-items: center;
justify-content: center;
background-color: #fff;

View File

@ -3,135 +3,298 @@
<view class="flex-row items-center section_2">
<image
class="image"
src="https://ide.code.fun/api/image?token=67c001c94ae84d0012277299&name=43f9d33cbaf7205072a2e1cd43931990.png"
:src="stateObject.img"
/>
<view class="flex-col items-start flex-1 ml-6">
<text class="font text">等待买家付款</text>
<text class="text_2 mt-4">请于13分51秒内付款超时订单将自动关闭</text>
<text class="font text">{{ stateObject.msg }}</text>
<text class="text_2 mt-4">{{ stateObject.tips }}</text>
</view>
</view>
<view class="flex-row items-center section_3">
<image
class="image_2"
src="https://ide.code.fun/api/image?token=67c001c94ae84d0012277299&name=d96aebb563e235fbf33e14d78237c796.png"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FIwOnPxNs-contact.png"
/>
<text class="text_3 ml-10">张三 15888610253</text>
<text class="text_3 ml-10">{{ contactInfo.name }} {{ contactInfo.phone }}</text>
</view>
<view class="flex-col section_4">
<view class="flex-col">
<view class="flex-row items-end list-item group mt-17" v-for="(item, index) in items" :key="index">
<view class="flex-row items-end list-item group mt-17" v-for="(item, index) in productList" :key="index">
<image
class="shrink-0 image_3"
src="https://ide.code.fun/api/image?token=67c001c94ae84d0012277299&name=5b1e63a77141ce1c8fc2514061052c99.png"
:src="item.goodSnapshot.goodImg"
/>
<view class="flex-col flex-1 group_5">
<view class="flex-row self-stretch group_3">
<text class="font_2">非遗绒花</text>
<text class="font_2 text_8">材料包手工教程课</text>
<text class="font_2">{{ item.goodSnapshot.name }}</text>
<text class="font_2 text_8">{{ item.goodSnapshot.type }}</text>
</view>
<text class="self-start font text_9">已选时间12月9号星期二</text>
<text class="self-start font_3 text_10">10:00-12:00</text>
<text class="self-start font text_9">已选时间{{ item.reservationDate }}星期二</text>
<text class="self-start font_3 text_10">{{ item.timeSlot }}</text>
<view class="flex-row items-center self-stretch group_23">
<image
<!-- <image
class="image_4"
src="https://ide.code.fun/api/image?token=67c001c94ae84d0012277299&name=4a3c5c3a5c83be7a7b0551c598ed6037.png"
/>
<text class="font_4 ml-3">138.</text>
<text class="font_5 ml-3">00</text>
/> -->
<text class="font_4 ml-3">{{ item.goodSnapshot.price }}</text>
<!-- <text class="font_5 ml-3">00</text> -->
</view>
</view>
<text class="font_6 text_11 text_1">×1</text>
<text class="font_6 text_11 text_1">×{{ item.quantity }}</text>
</view>
</view>
<view class="flex-row justify-between items-center group_8">
<text class="font text_16">商品金额</text>
<view class="flex-row items-center">
<image
<!-- <image
class="shrink-0 image_5"
src="https://ide.code.fun/api/image?token=67c001c94ae84d0012277299&name=4223cdafed72fca52c442dae885cee9c.png"
/>
<text class="font_7 text_17">138.00</text>
/> -->
<text class="font_7 text_17">{{ orderObject.totalAmount }}</text>
</view>
</view>
<view class="flex-row justify-between items-center group_9">
<text class="font">优惠券</text>
<view class="flex-row items-center">
<image
<!-- <image
class="shrink-0 image_6"
src="https://ide.code.fun/api/image?token=67c001c94ae84d0012277299&name=shortmoney.png"
/>
<text class="font_7 text_18">50.00</text>
/> -->
<text class="font_7 text_18">-0</text>
</view>
</view>
<view class="flex-row justify-end items-center group_10">
<view class="flex-row items-center group_11">
<image
<!-- <image
class="image_5 image_7"
src="https://ide.code.fun/api/image?token=67c001c94ae84d0012277299&name=15c19bceb4f8bbcc0ed72958e3788b20.png"
/>
/> -->
<text class="font_2 text_19">合计</text>
</view>
<text class="font_7 text_20">88.00</text>
<text class="font_7 text_20">{{ orderObject.totalAmount }}</text>
</view>
<view class="flex-col group_12">
<text class="self-start font text_21">买家留言</text>
<view class="flex-col justify-start self-stretch relative group_13 mt-5">
<view class="group_14"></view>
<view class="group_14" v-if="orderObject.note != ''">
<text class="font text_22 pos_4">
希望所使用的材料是可持续来源的并且制作工艺要精细以确保每一朵花瓣都能生动地展现出绒花的质感和美感
{{ orderObject.note }}
</text>
</view>
</view>
</view>
<view class="flex-row justify-between items-center group_15">
<text class="font text_23">订单编号</text>
<view class="flex-row items-center group_16">
<view class="flex-col justify-start items-center text-wrapper"><text class="text_25">复制</text></view>
<text class="font_5 text_24">E20241005095840091406189</text>
<view class="flex-col justify-start items-center text-wrapper" @click="copy(orderObject.orderNumber)"><text class="text_25">复制</text></view>
<text class="font_5 text_24">{{ orderObject.orderNumber }}</text>
</view>
</view>
<view class="flex-row justify-between items-center group_17">
<text class="font text_26">创建时间</text>
<text class="font_5 text_27">2024-10-05 09:58:41</text>
<text class="font_5 text_27">{{ orderObject.createTime }}</text>
</view>
<view class="flex-col group_18">
<view class="flex-row justify-between items-baseline group_21">
<view class="flex-row justify-between items-baseline group_21"
v-if="stateObject.state === '已退款'"
>
<text class="font text_28">退款时间</text>
<text class="font_5 text_29">2024-10-05 11:47:08</text>
<text class="font_5 text_29">{{ orderObject.updateTime }}</text>
</view>
<view class="flex-row justify-between items-baseline mt-3">
<text class="font text_30">成交时间</text>
<text class="font_5 text_31">2024-10-05 11:47:08</text>
<view class="flex-row justify-between items-baseline mt-3"
v-if="stateObject.state === '已完成'"
>
<text class="font text_30">完成时间</text>
<text class="font_5 text_31">{{ orderObject.updateTime }}</text>
</view>
</view>
</view>
<view class="flex-row items-center section_5">
<view class="flex-row items-center shrink-0">
<text class="font_8 text_32">合计</text>
<image
<!-- <image
class="shrink-0 image_8"
src="https://ide.code.fun/api/image?token=67c001c94ae84d0012277299&name=549b29459342a9a09d24834be40eb53b.png"
/>
<text class="text_33">88.</text>
<text class="font_6 text_36">00</text>
/> -->
<text class="text_33">{{ orderObject.totalAmount }}</text>
<!-- <text class="font_6 text_36">00</text> -->
</view>
<view class="flex-row flex-1 ml-46">
<view class="flex-col justify-start items-center text-wrapper_2">
<text class="font_8 text_34">联系客服</text>
</view>
<view class="flex-col justify-start items-center text-wrapper_3 ml-6">
<text class="font_8 text_35">去支付</text>
<button class="text-wrapper_9" open-type="contact" bindcontact="handleContact" session-from="sessionFrom">
<text class="font_9 text_64">联系客服</text>
</button>
<view class="flex-col justify-start items-center text-wrapper_3 ml-6" @click="stateSubmit(orderObject)" v-if="orderObject.orderStatus == '待支付' ">
<text class="font_8 text_35">{{ bottomBtn }}</text>
</view>
</view>
</view>
</view>
<!-- 遮罩层 -->
<view v-if="isShow" class="overlay"></view>
</template>
<script setup>
const items = [null,null,null,null,null,null]
import { onMounted, ref } from 'vue';
import { onLoad , onShow } from "@dcloudio/uni-app";
import { serviceStateMap } from '../../../common/global';
import { baseUrl } from '../../../api/request';
const orderObject = ref({}) //
const contactInfo = ref({}) //
const productList = ref([]) //
const stateObject = ref({}) //
const bottomBtn = ref('去支付') //
const oid = ref(0)
onMounted(()=>{
getOrderItem()
})
onLoad((options)=>{
oid.value = JSON.parse(options.oid) //
console.log('当前订单ID为',oid.value);
})
onShow( async ()=>{
await getOrderItem()
await setBottomText()
})
const getOrderItem = async ()=>{ //
const res = await uni.request({
url: baseUrl + '/order/get/id',
method: 'POST',
header: {
'cookie': wx.getStorageSync("cookie")
},
data: { id: oid.value }
})
if(res.data.code === 1) {
orderObject.value = res.data.data,
contactInfo.value = res.data.data.contactsSnapshot,
productList.value = res.data.data.orderItemList
stateObject.value = serviceStateMap.get(res.data.data.orderStatus)
}
console.log('联系人--->',contactInfo.value);
console.log('商品信息为--->',productList.value);
console.log('此订单信息为',res.data);
console.log('订单状态---->',stateObject.value);
}
const setBottomText =()=>{ //
switch(stateObject.value.state) {
case '待支付': bottomBtn.value = '立即支付';break;
case '已退款': bottomBtn.value = '删除订单';break;
case '交易成功': bottomBtn.value = '删除订单';break;
}
}
const stateSubmit = (obj) => { //
// console.log('obj--->',obj);
if(bottomBtn.value === '立即支付') { //
wxPayFd(oid.value)
} else if(bottomBtn.value === '删除订单') {
console.log('订单被删除');
}
}
const confirm =()=> { //
console.log('确认收货方法');
}
const wxPay = async( oid )=> { //id
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
})
buffer()
},
fail(e) {
// uni.showModal({
// content: ':' + e.errMsg,
// showCancel: false
// })
}
})
}catch(error) {
console.error('支付请求失败',error);
uni.showModal({
content: '支付请求失败,请重试。',
showCancel: false
})
}
}
const buffer = async ()=>{ //
await getOrderItem();
await setBottomText();
}
//
const copy = ( orderNumber ) => {
console.log('订单编号为--->',orderNumber);
uni.setClipboardData({
data: orderNumber,
success: () => {
uni.showToast({
title: '成功复制到剪贴板'
})
}
})
}
//
let debounceTimer = null;
let wxPayTimer = null;
let loading = false;
let isLoading = ref(false)
let isShow = ref(false)
const wxPayFd = (oid) => { //
clearTimeout(wxPayTimer)
showLoading()
isShow.value = true //
wxPayTimer = setTimeout(async () => {
await wxPay(oid)
}, 1000)
setTimeout(()=>{
hideLoading()
isShow.value = false //
},2000)
}
function showLoading() { //
if (!loading) {
wx.showLoading({
title: '加载中...',
});
loading = true;
isLoading.value = true
}
}
function hideLoading() { //
if (loading) {
wx.hideLoading();
loading = false;
isLoading.value = false
}
}
</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;
}
.ml-3 {
margin-left: 5.63rpx;
}
@ -200,7 +363,7 @@
line-height: 32.38rpx;
}
.section_4 {
margin: 25.65rpx 15rpx 0 16.88rpx;
margin: 25.65rpx 15rpx 70px 16.88rpx;
padding: 20.63rpx 22.63rpx 9.79rpx 24.38rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
@ -322,7 +485,7 @@
margin-left: 72.3rpx;
}
.text_19 {
margin-left: -102.3rpx;
// margin-left: -102.3rpx;
line-height: 24.3rpx;
}
.text_20 {
@ -385,7 +548,7 @@
line-height: 17.36rpx;
}
.text_24 {
margin-left: -368.34rpx;
margin-left: -404.34rpx;
}
.group_17 {
margin-top: 10.24rpx;
@ -469,5 +632,20 @@
.text_35 {
color: #ffffff;
}
.text-wrapper_9 {
// position: relative;
// left: 326rpx;
background-color: #ffffff;
border-radius: 75rpx;
width: 214rpx;
// height: 71rpx;
font-size: unset;
}
.ml-46 {
margin-left: 141.25rpx;
}
.text_64 {
color: #ffaaa5;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -147,12 +147,13 @@
name: '请选择联系人'
}) //
const productArr = ref([]) //
const labelList = ref([]) //
const userInfo = wx.getStorageSync('userInfo') //
const orderItemList = ref({})
const totalInfo = ref([]) //
const note = ref('')
const postCartArr = ref([])
const singleService = ref({}) //
const cnt = ref(1) //
onMounted(() => {
getFonts()
//
@ -165,10 +166,17 @@
})
})
onLoad((options)=>{
totalInfo.value = JSON.parse(options.cartInfo)
console.log('options.cartInfo-->',JSON.parse(options.cartInfo));
console.log('totalInfo.value-->',toRaw(totalInfo.value) );
getProduct() //
if(options.cartInfo === undefined) {
singleService.value = JSON.parse(options.obj)
cnt.value = JSON.parse(options.cnt)
console.log('单个服务类--->',singleService.value);
console.log('商品数量---->',cnt.value);
} else {
totalInfo.value = JSON.parse(options.cartInfo)
console.log('options.cartInfo-->',JSON.parse(options.cartInfo));
console.log('totalInfo.value-->',toRaw(totalInfo.value) );
getProduct() //
}
})
onShow(()=>{
userInfo.value = wx.getStorageSync('userInfo') //

View File

@ -548,10 +548,10 @@ const textAssign = (e) => { //文本输入框赋值方法
}
.popup-content {
height: 392px;
height: 300px;
align-items: center;
justify-content: center;
background-color: #fff;
// background-color: #fff;
border-radius: 20rpx 20rpx 0 0;
}

View File

@ -0,0 +1,687 @@
<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"
/>
<text class="text ml-10">{{ contactRealInfo.name }} {{ contactRealInfo.phone }}</text>
</view>
<view class="flex-row items-center group" @click="loadPop()">
<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>
<text class="self-start font_2 text_7 mt-9">已选时间{{ bookDate }}星期二</text>
<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>
<view class="flex-row justify-center items-center group_9 mt-15">
<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"
/>
</view>
</view>
<view class="flex-col section_4">
<view class="flex-row justify-between items-center">
<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>
<view class="flex-row justify-between mt-34">
<text class="font_8">优惠券</text>
<view class="flex-row group_12">
<text class="font_9">0张优惠券可用</text>
<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>
<view class="flex-row justify-between items-center mt-34">
<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"
/> -->
<text class="font_10">{{ sumprice.toFixed(2) }}</text>
</view>
</view>
</view>
<view class="flex-col section_5">
<text class="self-start font_8 text_15">订单备注</text>
<view class="flex-col justify-start items-start self-stretch text-wrapper_2 mt-11">
<text class="font_7 text_16">备注建议提前协商250字以内</text>
</view>
</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>
<text class="text_18">{{ sumprice.toFixed(2) }}</text>
<!-- <text class="text_20">00</text> -->
</view>
<view class="flex-col justify-start items-center text-wrapper_3" @click="wxPayFd()"><text class="font_8 text_19">微信支付</text></view>
</view>
</view>
<uni-popup ref="popup" background-color="#fff" :mask-click="false">
<view class="popup-content">
<contactsComponentVue></contactsComponentVue>
</view>
</uni-popup>
<!-- 遮罩层 -->
<view v-if="isShow" class="overlay"></view>
</template>
<script setup>
import {nextTick, onMounted, ref, toRaw} from 'vue'
import emitter from '../../../utils/emitter'
import { onLoad , onShow } from "@dcloudio/uni-app";
import { baseUrl } from '../../../api/request';
import { stateMap } from '../../../common/global';
import { sum } from 'mathjs';
import contactsComponentVue from '../component/contactsComponent.vue'; //\
import contactPopVue from '../../mine/component/contactPop.vue'; //
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) //
onMounted(() => {
getFonts()
//
emitter.on('close', () => {
close()
})
//
emitter.on('contactsNowInfo', (val) =>{
contactRealInfo.value = val
})
})
onLoad((options)=>{
singleService.value = JSON.parse(options.obj)
cnt.value = JSON.parse(options.cnt)
restNumber.value = JSON.parse(options.rest)
bookDate.value = singleService.value.appointmentDateVOList[0].specificDate
timeSlot.value = singleService.value.appointmentDateVOList[0].timePeriodVOList[0].timeSlot
sumprice.value = cnt.value * singleService.value.price
console.log('单个服务类--->',singleService.value);
console.log('商品数量---->',cnt.value);
console.log('时间段---->',timeSlot.value);
console.log('日期---->',bookDate.value);
console.log('剩余人数---->',restNumber.value);
})
onShow(()=>{
userInfo.value = wx.getStorageSync('userInfo') //
getDefaultContact()
// computed()
})
//
const close = () => {
nextTick(() => {
if (popup.value) {
popup.value.close()
}
})
}
//
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);
const resOrder = await uni.request({ //
url: baseUrl + '/order/add',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: {
orderType: 'service',
userName: userInfo.userName,
contactsId: contactRealInfo.value.id, //id
couponId: null, //id
note: note.value,
orderItemMainInfoAddRequestList: toRaw(postCartArr.value)
}
})
console.log('后台返回订单响应==>',resOrder.data);
if(resOrder.data.code === 1) {
wxPay(resOrder.data.data)
}
}
//
const shortNum = (index)=>{
if(cnt.value > 1) {
cnt.value -= 1
//
sumprice.value -= singleService.value.price * 1
}
}
//
const addNum = (index)=>{
if( cnt.value < restNumber.value ) { //
cnt.value += 1
sumprice.value += singleService.value.price * 1 //
}
}
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({
url: '/pages/order/service-paystatus/service-paystatus?oid=' + JSON.stringify(oid)
})
console.log('支付成功res--->',res);
},
fail(e) {
uni.redirectTo({
url: '/pages/order/service-paystatus/service-paystatus?oid=' + JSON.stringify(oid)
})
console.log('e.errMsg--->',e.errMsg);
}
})
}catch(error) {
console.error('支付请求失败',error);
uni.showModal({
content: '支付请求失败,请重试。',
showCancel: false
})
}
}
const textAssign = (e) => { //
note.value = e.detail.value
// console.log('note--->',note.value);
}
//
const getFonts =()=>{
uni.loadFontFace({
family: 'FangZhengFonts',
source: `url("https://carbon2.obs.cn-north-4.myhuaweicloud.com/fonts/FangZhengFonts.TTF")`,
success:(res) =>{
console.log('success',res);
},
fail:(err) => {
console.log('err',err);
}
})
}
//
let debounceTimer = null;
let wxPayTimer = null;
let loading = false;
let isLoading = ref(false)
let isShow = ref(false)
// const fd = () => { //
// clearTimeout(debounceTimer)
// showLoading()
// debounceTimer = setTimeout(async () => {
// await getMyCouponList()
// hideLoading()
// }, 1000)
// }
const wxPayFd = () => { //
clearTimeout(wxPayTimer)
showLoading()
isShow.value = true
wxPayTimer = setTimeout(async () => {
await createOrder()
}, 1000)
}
function showLoading() { //
if (!loading) {
wx.showLoading({
title: '加载中...',
});
loading = true;
isLoading.value = true
}
}
function hideLoading() { //
if (loading) {
wx.hideLoading();
loading = false;
isLoading.value = false
}
}
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)
}
</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;
}
.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;
font-family: FZSongKeBenXiuKaiS-R-GB;
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;
font-family: FZSongKeBenXiuKaiS-R-GB;
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;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.54rpx;
color: #818181;
}
.text_7 {
margin-left: 8.01rpx;
line-height: 24.62rpx;
}
.font_3 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
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;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 22.54rpx;
color: #323232;
}
.font_6 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
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;
font-family: FZSongKeBenXiuKaiS-R-GB;
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 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
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;
padding: 30rpx 19.22rpx 20.63rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
}
.font_8 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 29.18rpx;
color: #323232;
}
.text_13 {
line-height: 28.13rpx;
}
.font_9 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
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;
font-family: FZSongKeBenXiuKaiS-R-GB;
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;
padding: 17.81rpx 24.13rpx 22.5rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
}
.text_15 {
color: #000000;
line-height: 29.53rpx;
}
.text-wrapper_2 {
margin-left: 3.99rpx;
margin-right: 3.99rpx;
padding: 22.35rpx 0 115.22rpx;
background-color: #ffefef;
border-radius: 9.38rpx;
}
.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;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 26.49rpx;
}
.text_18 {
margin-left: 28.5rpx;
color: #ffaaa5;
font-size: 37.5rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 27.62rpx;
}
.text_20 {
color: #ffaaa5;
font-size: 30rpx;
font-family: Open Sans;
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>

View File

@ -1,418 +0,0 @@
<template>
<view class="flex-col justify-start page">
<view class="flex-col section">
<view class="flex-row justify-between group">
<view class="flex-row items-end">
<image
class="image"
:src="productInfo.goodImg"
/>
<view class="flex-col items-start relative group_2 ml-13">
<view class="group_3">
<text class="font text_2"></text>
<text class="text">{{ productInfo.price }}</text>
</view>
<text class="font_2 text_3">请选择</text>
<!-- <text class="font_2 pos_2">数量20</text> -->
<text class="font_2 pos">场次</text>
</view>
</view>
<image
class="self-start image_2"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FTZQhzAYT-close.png"
/>
</view>
<view class="flex-col mt-2">
<view class="flex-col">
<view class="flex-row justify-between items-center section_2">
<text class="font text_4">参加日期2024年11月</text>
<text class="font_2 text_5">当前预约人数10</text>
</view>
<view class="flex-col group_4 mt-5">
<view class="flex-col self-stretch group_5">
<text class="self-start font_3 text_6">选择预约时间</text>
<view class="flex-col justify-start self-stretch view mt-14">
<scroll-view class="group_10" :scroll-x="true">
<view class="flex-row justify-between items-baseline">
<text :style="{color: textColor[index]}" class="font_4 text_7" v-for="(item, index) in items" :key="index" @click="choose(index)">
今天12-09
</text>
</view>
</scroll-view>
</view>
</view>
<view class="flex-row self-center relative grid">
<view class="flex-col justify-start grid-item pos_1">
<view class="section_4"></view>
<text class="font_5 text_11 pos_3">10:00-12:00</text>
<text class="font_3 pos_5">可预约</text>
</view>
<view class="flex-col justify-start grid-item_2 pos_14">
<view class="section_4"></view>
<text class="font_5 pos_4">12:00-14:00</text>
<text class="font_3 pos_6">可预约</text>
</view>
<view class="flex-col justify-start items-center grid-item_3 pos_15">
<text class="font_3">可预约</text>
<view class="flex-col justify-start items-center text-wrapper pos_7">
<text class="font_5">14:00-16:00</text>
</view>
</view>
<view class="flex-col justify-start grid-item_2 pos_11">
<view class="section_4"></view>
<text class="font_5 pos_8">16:00-18:00</text>
<text class="font_3 pos_9">可预约</text>
</view>
</view>
<view class="flex-col justify-start self-stretch group_6">
<view class="flex-row justify-between section_5">
<text class="font_3 text_12">预约时间</text>
<view class="flex-row items-center group_7">
<text class="font_5">2024-12-09</text>
<text class="font_5 ml-22">暂未选择</text>
</view>
</view>
</view>
<view class="flex-col items-start self-stretch section_6">
<text class="font">购买须知本次课程活动最少需要到</text>
<text class="font">达5人才能进行授课</text>
</view>
</view>
</view>
<view class="flex-col justify-start items-center section_7">
<view class="flex-row section_8">
<text class="font_4 text_13">加入购物车</text>
<!-- <text class="font_4 text_14 ml-21"></text> -->
</view>
</view>
</view>
</view>
</view>
</template>
<script setup>
import { onMounted, ref } from 'vue'
import { onLoad } from "@dcloudio/uni-app";
import { baseUrl } from '../../../api/request';
const cookie = wx.getStorageSync("cookie") //
const items = ref([null,null,null,null,null,null,null])
const father = defineProps(['pid'])
const pid = ref(0) //id
const productInfo = ref({}) //
const bookTimeList = ref([]) //
const textColor = ref(['#000', '#000', '#000', '#000', '#000', '#000', '#000'])
onLoad((options)=>{
})
onMounted(()=>{
// console.log('onMounted--->',father.pid);
getProduct()
})
const choose = (index) => { //
console.log(textColor.value[index]);
textColor.value[index] = '#C35C5D'
}
const getProduct = async ()=>{
pid.value = father.pid //id
const res = await uni.request({
url: baseUrl + '/goods/service/list/id',
method: 'POST',
data:{ id: pid.value },
header: { cookie }
})
console.log('后端传来的商品信息--->',res.data.data);
if(res.data.code === 1 ) {
productInfo.value = res.data.data
bookTimeList.value = res.data.data.appointmentDateVOList
}
console.log('商品信息--->',productInfo.value);
console.log('时间段信息--->',bookTimeList.value);
}
</script>
<style lang="scss" scoped>
.ml-13 {
margin-left: 24.38rpx;
}
.mt-5 {
margin-top: 9.38rpx;
}
.ml-21 {
margin-left: 39.38rpx;
}
.page {
padding-bottom: 18.75rpx;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
}
.section {
padding: 28.13rpx 0;
background-color: #ffffff;
border-radius: 37.5rpx 37.5rpx 0rpx 0rpx;
}
.group {
padding: 0 30rpx;
}
.image {
border-radius: 5.63rpx;
width: 195rpx;
height: 204.38rpx;
}
.group_2 {
margin-bottom: 5.29rpx;
padding-bottom: 28.86rpx;
width: 157.8rpx;
}
.group_3 {
margin-left: 17.51rpx;
line-height: 29.7rpx;
}
.font {
font-size: 37.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 45rpx;
color: #323232;
}
.text_2 {
color: #c35c5d;
line-height: 24.17rpx;
}
.text {
color: #c35c5d;
font-size: 45rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 29.7rpx;
}
.font_2 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 31.88rpx;
color: #818181;
}
.text_3 {
margin-top: 21.26rpx;
}
.pos_2 {
position: absolute;
left: 0;
bottom: 0;
}
.pos {
position: absolute;
right: 0;
bottom: 28.03rpx;
}
.image_2 {
margin-right: 20.63rpx;
margin-top: 5.63rpx;
width: 37.5rpx;
height: 37.5rpx;
}
.section_2 {
padding: 30.53rpx 21.86rpx 30.36rpx;
background-color: #ffffff;
border-radius: 28.13rpx;
}
.text_4 {
color: #000000;
line-height: 36.62rpx;
}
.text_5 {
margin-right: 16.14rpx;
line-height: 25.43rpx;
}
.group_4 {
padding: 0 20.63rpx 35.63rpx;
}
.group_5 {
padding: 31.76rpx 7.5rpx 0;
border-top: solid 1.88rpx #d9d9d9;
}
.font_3 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 27.07rpx;
color: #000000;
}
.text_6 {
line-height: 28.01rpx;
}
.view {
margin-right: 7.5rpx;
padding: 35.98rpx 0 35.87rpx 20rpx;
background-color: #faddde;
border-radius: 18.75rpx;
}
.group_10 {
// margin-left: 11.78rpx;
margin-right: 14.83rpx;
}
.font_4 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 27.07rpx;
color: #c35c5d;
}
.text_7 {
// border: 1px solid red;
margin-right: 20rpx;
line-height: 27.3rpx;
}
.grid {
margin-top: 75rpx;
width: 605.63rpx;
height: 228.75rpx;
}
.grid-item {
background-color: #fbdedf;
border-radius: 18.75rpx;
background-image: url('https://ide.code.fun/api/image?token=67582be6797f850011f1edb7&name=5f9759dd4fc5b6049913f513ad7248f2.png');
background-size: 100% 100%;
background-repeat: no-repeat;
width: 253.13rpx;
}
.pos_1 {
position: absolute;
left: 3.75rpx;
top: 0;
}
.section_4 {
background-image: url('https://ide.code.fun/api/image?token=67582be6797f850011f1edb7&name=5f9759dd4fc5b6049913f513ad7248f2.png');
background-size: 100% 100%;
background-repeat: no-repeat;
height: 90rpx;
}
.font_5 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 20.04rpx;
color: #000000;
}
.text_11 {
width: 150rpx;
}
.pos_3 {
position: absolute;
left: 50%;
top: 16.99rpx;
transform: translateX(-50%);
}
.pos_5 {
position: absolute;
left: 74.53rpx;
bottom: 12.06rpx;
}
.grid-item_2 {
background-color: #ffffff;
border-radius: 18.75rpx;
background-image: url('https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FVQSWQJrq-selectbox.png');
background-size: 100% 100%;
background-repeat: no-repeat;
width: 253.13rpx;
}
.pos_14 {
position: absolute;
right: 0;
top: 0;
}
.pos_4 {
position: absolute;
right: 42.83rpx;
top: 20.74rpx;
}
.pos_6 {
position: absolute;
left: 50%;
bottom: 13.93rpx;
transform: translateX(-50%);
}
.grid-item_3 {
padding: 54.62rpx 0 8.31rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
width: 253.13rpx;
}
.pos_15 {
position: absolute;
left: 0;
top: 138.75rpx;
}
.text-wrapper {
padding: 22.61rpx 0 47.34rpx;
background-image: url('https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FVQSWQJrq-selectbox.png');
background-size: 100% 100%;
background-repeat: no-repeat;
width: 256.88rpx;
}
.pos_7 {
position: absolute;
left: 3.75rpx;
right: -7.5rpx;
top: 0;
}
.pos_11 {
position: absolute;
right: 0;
top: 138.75rpx;
}
.pos_8 {
position: absolute;
right: 39.67rpx;
top: 18.86rpx;
}
.pos_9 {
position: absolute;
left: 50%;
bottom: 8.31rpx;
transform: translateX(-50%);
}
.group_6 {
margin-top: 97.5rpx;
padding-bottom: 9.38rpx;
border-bottom: solid 1.88rpx #d9d9d9;
}
.section_5 {
margin-left: 22.5rpx;
margin-right: 11.27rpx;
padding: 12.66rpx 14.42rpx 27.9rpx;
background-color: #ffffff;
}
.text_12 {
line-height: 28.01rpx;
}
.group_7 {
margin-right: 13.74rpx;
}
.section_6 {
margin: 43.13rpx 46.88rpx 0 41.25rpx;
padding: 25.28rpx 6.62rpx 38.19rpx 12.13rpx;
background-color: #fff2f2f5;
border-radius: 18.75rpx;
}
.section_7 {
position: fixed;
left: 0;
right: 0;
bottom: 0;
// border: 1px solid red;
margin-left: 7.5rpx;
margin-right: 5.63rpx;
padding: 16.88rpx 0;
background-color: #ffffff;
}
.section_8 {
padding: 26.14rpx 0 25.07rpx;
background-color: #fbdedf;
border-radius: 46.88rpx;
width: 618.75rpx;
}
.text_13 {
margin-left: 240.94rpx;
line-height: 27.54rpx;
}
.text_14 {
line-height: 27.54rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -66,7 +66,7 @@
</view>
</view>
</view>
<view class="flex-col justify-start items-center text-wrapper_3" @click="addCart"><text class="font text_8">加入购物车</text></view>
<view class="flex-col justify-start items-center text-wrapper_3" @click="selectStatus()"><text class="font text_8">{{ btnText }}</text></view>
</view>
<uni-popup ref="tip" :animation="false" @maskClick="maskClosehandler">
@ -77,7 +77,7 @@
</template>
<script setup lang="ts">
<script setup>
import tipVue from './tip.vue';
import {onMounted, ref} from 'vue'
import emitter from '../../../utils/emitter';
@ -94,7 +94,6 @@
const cnt = ref(1)
const productObject = ref()
const appointmentDateVOList = ref([])
let appointmentDate = ''
let timeSlot = ''
@ -131,11 +130,17 @@
}
})
emitter.on('getBookingNumberMap', (val:any) => { //map
emitter.on('getBookingNumberMap', (val) => { //map
countMap = val
console.log("val==============>", val)
appointmentDate = appointmentDateVOList.value[appIdx.value].specificDate;
})
emitter.on('count',(val)=>{
nowSelected.value = val
console.log('现在选择的是---->',nowSelected.value);
statusChange() //
})
})
@ -218,7 +223,7 @@
}
const isSelected = (index:any) => { //
const isSelected = (index) => { //
appIdx.value = index
restNumber.value = '请选择时间段'
appointmentDate = appointmentDateVOList.value[appIdx.value].specificDate;
@ -243,7 +248,7 @@
}
const itemIsSelected = (index:any) => { //
const itemIsSelected = (index) => { //
timeSlot = appointmentDateVOList.value[appIdx.value].timePeriodVOList[index].timeSlot
restNumber.value = countMap[appointmentDate + '&' + timeSlot]
console.log('timeSlot====================================>', timeSlot)
@ -258,7 +263,39 @@
}
}
}
const nowSelected = ref(0) //
const btnText = ref('加入购物车')
const statusChange = () => {
if(nowSelected.value === 2) {
btnText.value = '立即预约'
} else {
btnText.value = '加入购物车'
}
}
const selectStatus = () => {
if(btnText.value === '加入购物车') {
addCart()
} else {
goToBook()
}
}
const goToBook =()=> { //
console.log('日期--->',appointmentDate,'时间段--->',timeSlot,'数量--->',cnt.value,'商品id---->',productObject.value.id);
if(appointmentDate === '' || timeSlot === '' ) {
uni.showToast({
icon: 'error',
title: "字段不能为空"
})
return;
}
console.log('productObj--->',productObject.value);
console.log('数量--->',cnt.value);
uni.navigateTo({ //
//+
url: '/pages/order/singleServiceWait/singleServiceWait?obj=' + JSON.stringify(productObject.value) + '&cnt=' + JSON.stringify(cnt.value) + '&rest=' + JSON.stringify(restNumber.value)
})
}
</script>
<style lang="scss" scoped>

View File

@ -48,10 +48,10 @@
<text class="text_13 mt-3">客服</text>
</view>
<view class="flex-row flex-1 self-center ml-26">
<view class="flex-col justify-start items-center text-wrapper" @click="loadPop">
<view class="flex-col justify-start items-center text-wrapper" @click="loadPopCart">
<text class="font_3 text_11">加入购物车</text>
</view>
<view class="flex-col justify-start items-center text-wrapper_2 ml-31">
<view class="flex-col justify-start items-center text-wrapper_2 ml-31" @click="loadPopBook">
<text class="font text_12">立即预约</text>
</view>
</view>
@ -103,6 +103,7 @@ const getProduct = async () =>{
cookie
}
})
console.log('单个服务类商品信息---->',res.data.data);
if(res.data.code === 1) {
productObject.value = res.data.data
} else {
@ -136,10 +137,17 @@ const close =()=> { //关闭弹窗
popup.value.close()
})
}
const loadPop =()=> {
const loadPopCart =()=> {
emitter.emit('getGoodData', productObject.value)
emitter.emit('getBookingNumberMap', countMap)
popup.value.open('bottom') //
emitter.emit('count',1) //
}
const loadPopBook = ()=> {
emitter.emit('getGoodData', productObject.value)
emitter.emit('getBookingNumberMap', countMap)
popup.value.open('bottom') //
emitter.emit('count',2) //
}