写真产品已完成

This commit is contained in:
chen-xin-zhi 2025-03-01 13:33:28 +08:00
parent d9b53b20bb
commit f9ab182053
37 changed files with 683 additions and 4133 deletions

24
common/globalFont.js Normal file
View File

@ -0,0 +1,24 @@
export const getFonts =()=>{
//首页
uni.loadFontFace({
family: 'ZhongShanFonts',
source: `url("https://carbon2.obs.cn-north-4.myhuaweicloud.com/fonts/ZhongShanFonts.ttf")`,
success:(res) =>{
console.log('success',res);
},
fail:(err) => {
console.log('err',err);
}
})
//其他页面
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);
}
})
}

View File

@ -101,27 +101,6 @@
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/booking/AppointmentHome",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/booking/ContactInformation",
"style" :
{
"navigationBarTitleText" : "联系人信息"
}
},
{
"path" : "pages/booking/date",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/store-home/ProductDetails/ProductDetails",
"style" :
@ -136,27 +115,6 @@
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/booking/BillingOfFees/BillingOfFees",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/booking/ReservationInstructions/ReservationInstructions",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/booking/respectable/respectable",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/Shopping-cart/newaddress_Info/newaddress_Info",
"style" :
@ -171,19 +129,6 @@
"navigationBarTitleText" : ""
}
},
{
"path": "pages/booking/Simple/Simple",
"style": {
"navigationBarTitleText": ""
}
},
{
"path" : "pages/booking/bookingpay/bookingpay",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/login/login",
"style" :
@ -205,20 +150,6 @@
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/booking/CostumeDisplay/CostumeDisplay",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/booking/CostumeDetails/CostumeDetails",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/mine/Contact/Contact",
"style" :

View File

@ -11,8 +11,14 @@
</view>
<view class="flex-col section_5">
<view class="flex-row justify-between self-stretch group">
<text class="font_2 text_3" :style="getTextStyle(1)" @click="changeType(1)">商品类</text>
<text class="font_2 text_4" :style="getTextStyle(2)" @click="changeType(2)">服务类</text>
<view @click="changeType(1)">
<text class="font_2 text_3">商品类</text>
<view class="flex-col justify-start items-center" v-if="isShowLine" style="border: 1.88rpx solid #E79EA1; width: 90rpx; margin-top: 10rpx;"></view>
</view>
<view @click="changeType(2)">
<text class="font_2 text_4">服务类</text>
<view class="flex-col justify-start items-center" v-if="!isShowLine" style="border: 1.88rpx solid #E79EA1; width: 90rpx; margin-top: 10rpx;"></view>
</view>
</view>
</view>
<view class="flex-col list">
@ -109,6 +115,8 @@
</view>
</view>
</view>
<!-- 遮罩层 -->
<view v-if="isShow" class="overlay"></view>
</template>
@ -139,6 +147,7 @@
onLoad(() => {
getProductCart() //
getFonts()
// console.log(current.value)
})
//
const getEntityPro = async () => {
@ -207,17 +216,27 @@
})
}
}
const isShowLine = ref(true)
//
const changeType = async (num) => {
if (num == 1) {
if (!isShowLine.value) {
isShowLine.value = true
}
} else {
if (isShowLine.value) {
isShowLine.value = false
}
}
current.value = num;
console.log('current状态--->',current.value);
getProductCart()
totalPrice.value = 0
}
//线
const getTextStyle = (num) => ({
'border-bottom': current.value === num ? '2px solid orange' : '2px solid #ffffff'
});
// //线
// const getTextStyle = (num) => ({
// 'border-bottom': current.value === num ? '2px solid orange' : '2px solid #ffffff'
// });
//
const checkBoxChange = (event) => {
console.log('服务类打印出来是---->', event); //
@ -638,7 +657,7 @@
}
.group {
padding: 27.06rpx 4.33rpx 23.08rpx 10.89rpx;
padding: 20.06rpx 4.33rpx 0 4.33rpx;
z-index: 1;
}

View File

@ -5,7 +5,7 @@
<text class="font text">请选择拍摄人数和场地</text>
<image
class="image"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=72844e3602883267485f6c9dfe89862b.png"
:src="bookUrl + '/component/cha.png'"
@click="closePopup"
/>
</view>
@ -19,24 +19,24 @@
<view class="flex-row items-center relative section">
<image
class="image_5"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=c0ebdfc7cf144c161a3ad237d317f463.png"
:src="bookUrl + '/component/sub.png'"
@click="sub"
/>
<view class="flex-col justify-start items-center text-wrapper"><text class="text_4">{{ number }}</text></view>
<image
class="image_6"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=d8e6dd5d8dea22188afc18c9b7822b49.png"
:src="bookUrl + '/component/add.png'"
@click="add"
/>
<text class="text_3"></text>
</view>
<image
class="image_3 pos"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=025aa63cb7deb0cf1fa7cf4aeda1bef1.png"
:src="bookUrl + '/component/duoren.png'"
/>
<image
class="image_4 pos_2"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=455931695b5f0c7008d1859ccaae1cb8.png"
:src="bookUrl + '/component/danren.png'"
/>
</view>
<view class="flex-col group_3">
@ -48,9 +48,9 @@
<view class="flex-row justify-between items-end self-stretch">
<image
class="image_7"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=1ad61435fde7f073544e2d6f400f1ac9.png"
:src="bookUrl + '/component/shinei.png'"
/>
<radio class="section_3" color="#FFB6B9" :checked="true" value="室内"></radio>
<radio class="section_3" color="#FFB6B9" value="室内" :checked="checked1" :disabled="disabled1"></radio>
</view>
<text class="self-start font_2 text_6 mt-5">室内</text>
</view>
@ -59,9 +59,9 @@
<view class="flex-row justify-between items-end self-stretch">
<image
class="image_8"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=556966367522af83972375c476406b0b.png"
:src="bookUrl + '/component/shiwai.png'"
/>
<radio class="section_3" color="#FFB6B9" value="室外"></radio>
<radio class="section_3" color="#FFB6B9" value="室外" :checked="checked2" :disabled="disabled2"></radio>
</view>
<text class="self-start font_2 text_6 mt-5">室外</text>
</view>
@ -93,11 +93,18 @@
import {nextTick, onMounted, ref} from 'vue'
import emitter from '../../../utils/emitter';
import feeTipsVue from './feeTips.vue';
import { bookUrl } from '../../../common/globalImagesUrl';
const number = ref(1)
const field = ref('室内')
const field = ref('')
const feeTips = ref(null)
const obj = ref('')
const totalPrice = ref(0)
const shotScene = ref('')
const disabled1 = ref(false)
const disabled2 = ref(false)
const checked1 = ref(false)
const checked2 = ref(false)
const type = ref('')
onMounted(() => {
emitter.on('closeFeeTips', () => {
@ -108,15 +115,31 @@
})
})
emitter.on('getProductsType', (val:any) => {
type.value = val
console.log('=================================================>', type.value)
})
emitter.on('getProductObj', (val:any) => {
obj.value = val
totalPrice.value = val.price
totalPrice.value = val.price * val.minNumber
number.value = obj.value.minNumber
shotScene.value = obj.value.shotScene
if (shotScene.value === '室内') {
disabled1.value = true
checked2.value = true
field.value = '室内'
} else {
disabled2.value = true
checked1.value = true
field.value = '室外'
}
console.log(totalPrice.value)
})
})
const sub = () => {
if (number.value > 1) {
if (number.value > obj.value.minNumber) {
number.value --
totalPrice.value = number.value * obj.value.price
}
@ -142,8 +165,15 @@
}
const jumpToOrder = () => {
if (field.value === '' || field.value === undefined || field.value === null) {
uni.showToast({
title: '请选择场地',
icon: 'error'
})
return ;
}
uni.navigateTo({
url: '/pages/book/photoProductsOrder/photoProductsOrder?field=' + field.value + '&number=' + number.value + '&id=' + obj.value.id
url: '/pages/book/photoProductsOrder/photoProductsOrder?field=' + field.value + '&number=' + number.value + '&id=' + obj.value.id + '&type=' + type.value
})
}

View File

@ -19,6 +19,8 @@ const cookie = wx.getStorageSync("cookie") //请求头
const orderObj = ref({})
const isIndoors = ref(0)
const isMakeup = ref(1)
const isPhotography = ref(1)
onMounted(() => {
emitter.on('getBookingOrderData', (val:any) => {
orderObj.value = val
@ -37,6 +39,12 @@ const cookie = wx.getStorageSync("cookie") //请求头
if (orderObj.value.field === '室内') {
isIndoors.value = 1
}
if (orderObj.value.type === '妆造') {
isPhotography.value = 0
} else if (orderObj.value.type === '摄影') {
isMakeup.value = 0
}
const res = await uni.request({
url: baseUrl + '/advanceOrder/add',
method: 'POST',
@ -49,8 +57,8 @@ const cookie = wx.getStorageSync("cookie") //请求头
specificDate: orderObj.value.bookingDate,
timePoint: orderObj.value.bookingTime,
isIndoors: isIndoors.value,
isMakeup: 1,
isPhotography: 1,
isMakeup: isMakeup.value,
isPhotography: isPhotography.value,
quantity: orderObj.value.number
}
})

View File

@ -7,28 +7,28 @@
/>
<view class="flex-col items-start section_2 pos_2">
<text class="font text">{{ obj.name }}</text>
<text class="mt-18 font text_2">{{ obj.price.toFixed(2) }}</text>
<text class="mt-18 font text_2">{{ obj.totalAmountPrice.toFixed(2) }}</text>
</view>
<text class="font_2 pos_3">服务&交付标准</text>
<view class="flex-row equal-division">
<view class="flex-col items-center group equal-division-item">
<image
class="image_2"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=38dcf3c1e2244e5a085c6cab2d3e9782.png"
:src="bookUrl + '/photoProductDetail/zx.png'"
/>
<text class="font_3 mt-11">1组造型</text>
</view>
<view class="ml-38 flex-col items-center group equal-division-item">
<image
class="image_2"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=3ee14e25cc9badbf556ce47b1b3fae40.png"
:src="bookUrl + '/photoProductDetail/fz.png'"
/>
<text class="font_3 mt-11">1套服装</text>
</view>
<view class="ml-38 flex-col items-center group equal-division-item">
<image
class="image_2"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=ad428b849d260407680f59d5f75d6f06.png"
:src="bookUrl + '/photoProductDetail/bj.png'"
/>
<text class="font_3 mt-11">1种背景</text>
</view>
@ -64,13 +64,20 @@
import emitter from "../../../utils/emitter";
import bookingSelectedVue from "../component/bookingSelected.vue";
import { baseUrl } from "../../../api/request";
import { bookUrl } from "../../../common/globalImagesUrl";
const cookie = wx.getStorageSync("cookie") //
const id = ref({})
const bookingSelected = ref(null)
const obj = ref({})
const type = ref('')
const bookingDateVOList =ref([])
onLoad((options) => {
console.log(options)
id.value = options.id
if (options.type) {
type.value = options.type
}
getPhotoProductsById()
})
@ -99,11 +106,22 @@
})
console.log(res.data.data)
obj.value = res.data.data
obj.value.totalAmountPrice = obj.value.minNumber * obj.value.price
bookingDateVOList.value = res.data.data.bookingDateVOList
}
const openBookingPopup = () => {
if (bookingDateVOList.value.length === 0) {
uni.showModal({
title: '提示',
content: '当前写真产品的所有时段已约满',
showCancel: false
})
return ;
}
emitter.emit('getProductObj', obj.value)
emitter.emit('getProductsType', type.value)
bookingSelected.value.open('bottom')
}
@ -122,7 +140,7 @@
}
.page {
background-color: #ffffff;
background-image: url('https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=8a8617bd8ea20ecda3f731825ed1b080.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/book/photoProductDetail/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
@ -131,7 +149,7 @@
height: 100%;
}
.section {
background-image: url('https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=8a8617bd8ea20ecda3f731825ed1b080.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/book/photoProductDetail/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;

View File

@ -5,21 +5,21 @@
<view class="flex-col items-center equal-division-item">
<image
class="image"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=98d92598fa059f35ed92af5a9439c9c0.png"
:src="bookUrl + '/photoProducts/type1.png'"
/>
<text class="font text_1 mt-7">写真专区</text>
</view>
<view class="flex-col items-center equal-division-item_2 ml-48" @click="jumpToDetail(item)">
<view class="flex-col items-center equal-division-item_2 ml-48" @click="jumpNextToDetail('摄影')">
<image
class="image"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=96be13306d195949440e67325578de26.png"
:src="bookUrl + '/photoProducts/type2.png'"
/>
<text class="font mt-7">摄影服务</text>
</view>
<view class="flex-col items-center equal-division-item_3 ml-48" @click="jumpToDetail(item)">
<view class="flex-col items-center equal-division-item_3 ml-48" @click="jumpNextToDetail('妆造')">
<image
class="image"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=57485239f24eb48a22be8fce00be610d.png"
:src="bookUrl + '/photoProducts/type3.png'"
/>
<text class="font mt-4">妆造服务</text>
</view>
@ -47,7 +47,7 @@
/>
<view class="flex-col items-start ml-12">
<text class="font_2 text_3">{{ item.name }}</text>
<text class="font_2 text_4 mt-32">{{ item.price.toFixed(2) }}元起</text>
<text class="font_2 text_4 mt-32">{{ item.totalAmountPrice.toFixed(2) }}元起</text>
</view>
</view>
<view class="flex-col justify-start items-center self-start text-wrapper_2">
@ -61,6 +61,7 @@
<script setup lang="ts">
import {onMounted, ref} from 'vue'
import { baseUrl } from '../../../api/request';
import { bookUrl } from '../../../common/globalImagesUrl';
const cookie = wx.getStorageSync("cookie") //
const categoryList = ref([])
@ -118,6 +119,11 @@
})
photoProducts.value = res.data.data
console.log(photoProducts.value)
for (var i = 0; i < photoProducts.value.length; i ++ ) {
let minNumber = photoProducts.value[i].minNumber
let price = photoProducts.value[i].price
photoProducts.value[i].totalAmountPrice = minNumber * price
}
}
const jumpToDetail = (val:any) => {
@ -126,6 +132,12 @@
})
}
const jumpNextToDetail = (type:any) => {
uni.navigateTo({
url: '../photoProductDetail/photoProductDetail?id=' + 76 + "&type=" + type
})
}
</script>
@ -138,7 +150,7 @@
margin-top: 24.38rpx;
}
.page {
background-image: url('https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=039df2fe261116bd1bd408f287b060bc.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/book/photoProducts/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
@ -147,7 +159,7 @@
height: 100vh;
}
.section {
background-image: url('https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=039df2fe261116bd1bd408f287b060bc.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/book/photoProducts/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;

View File

@ -4,7 +4,7 @@
<text class="font text pos_2">选择联系人</text>
<image
class="image pos"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=255ef950c2652260141b1b6866847d29.png"
:src="bookUrl + '/photoProductsOrder/yyxz.png'"
@click="openTipsPopup"
/>
<text class="font_2 text_2 pos_3" @click="openTipsPopup">预约须知</text>
@ -12,14 +12,14 @@
<view class="flex-row items-center">
<image
class="shrink-0 image_2"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=d756fec34c69604dfbd42c6d155690f0.png"
:src="bookUrl + '/photoProductsOrder/lxr.png'"
/>
<text class="font text_3 ml-10">{{ contactTemplateString }}</text>
</view>
<view class="flex-row items-center group">
<image
class="image_3"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=3e51d655e35c3c3fd7fbdfab51592143.png"
:src="bookUrl + '/photoProductsOrder/yjt.png'"
/>
<text class="font_3 text_4">更换联系人</text>
</view>
@ -67,7 +67,7 @@
<view class="flex-col items-center group_3" @click="nav">
<image
class="image"
src="https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=d52c7b6dae8656c06b3be0bbcd17f959.png"
:src="bookUrl + '/photoProductsOrder/nav.png'"
/>
<text class="text_11 mt-3">导航</text>
</view>
@ -111,6 +111,7 @@
import contactsComponentVue from '../../order/component/contactsComponent.vue';
import confirmBookingInfoVue from '../component/confirmBookingInfo.vue';
import { onLoad } from "@dcloudio/uni-app";
import { bookUrl } from '../../../common/globalImagesUrl';
const cookie = wx.getStorageSync("cookie") //
const photoProduct = ref({})
@ -139,6 +140,7 @@
const isShow = ref(false)
let loading = false;
const type = ref('')
const contactTemplateString = ref('请选择')
@ -191,7 +193,8 @@
contactId: contactInfo.value.id,
name: photoProduct.value.name,
bookingDate: bookingDate.value,
bookingTime: bookingTime.value
bookingTime: bookingTime.value,
type: type.value
})
confirmBookingInfo.value.open('center')
}
@ -201,6 +204,7 @@
field.value = options.field
number.value = options.number
id.value = options.id
type.value = options.type
})
@ -429,7 +433,7 @@
}
.page {
background-color: #ffffff;
background-image: url('https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=c07af569900e34d63f1e91cbbae55df7.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/book/photoProductsOrder/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
@ -438,7 +442,7 @@
height: 100%;
}
.section {
background-image: url('https://ide.code.fun/api/image?token=67be7f674ae84d0012275313&name=c07af569900e34d63f1e91cbbae55df7.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/book/photoProductsOrder/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;

View File

@ -57,7 +57,7 @@
<text class="font_7 text_11">到店时间{{ item.specificDate }} {{ item.timePoint }}</text>
<image
class="image_2"
src="https://ide.code.fun/api/image?token=67bfb6134ae84d0012276837&name=d52c7b6dae8656c06b3be0bbcd17f959.png"
:src="bookUrl + '/photoProductsOrderDetail/nav.png'"
@click="nav"
/>
</view>
@ -116,11 +116,13 @@
<script setup lang="ts">
import {computed, nextTick, onBeforeUnmount, onMounted, onUnmounted, ref} from 'vue'
import { bookUrl } from '../../../common/globalImagesUrl';
import emitter from '../../../utils/emitter';
import cancelOrderVue from '../component/cancelOrder.vue';
import deleteOrderVue from '../component/deleteOrder.vue';
import { onLoad } from "@dcloudio/uni-app";
import { baseUrl } from '../../../api/request';
import { getFonts } from '../../../common/globalFont';
const cookie = wx.getStorageSync("cookie") //
const isShow = ref([true, false, false])
const cancelBookingOrder = ref(null)
@ -128,6 +130,10 @@
const advanceOrderList = ref([])
const isShowMask = ref(false)
onLoad((options) => {
getFonts()
})
onMounted( async () => {
await getAdvanceOrder()
emitter.on('closeCancelOrderPopup', () => {
@ -318,11 +324,11 @@
order.countdown = '00:00';
clearInterval(order.countdownInterval); //
getAdvanceOrder()
uni.showModal({
title: '提示',
content: '订单超时未支付,交易关闭',
showCancel: false
})
// uni.showModal({
// title: '',
// content: '',
// showCancel: false
// })
} else {
const minutes = Math.floor(remainingTime / 60); //
@ -365,13 +371,42 @@
const routerJump = (val:any) => {
let pages = getCurrentPages();
var num = pages.length
if (num == 1) return ;
console.log(pages)
//
var backnum = num
for( var i = 0; i < num; i ++ ) {
//
if(pages[i].route == val){
//'pages/mypage/mypage'A
backnum = num - i - 1
//--1
}
}
uni.navigateBack({
delta:backnum
// delta
})
}
onUnmounted(() => {
routerJump('pages/book/photoProducts/photoProducts')
})
@ -421,7 +456,7 @@
.page {
background-color: #ffffff;
overflow: hidden;
background-image: url('https://ide.code.fun/api/image?token=67bfb6134ae84d0012276837&name=629e4a3490be730bb94900bbb4f3ab0a.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/book/photoProductsOrderDetail/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
@ -430,7 +465,7 @@
height: 100%;
}
.section {
background-image: url('https://ide.code.fun/api/image?token=67bfb6134ae84d0012276837&name=629e4a3490be730bb94900bbb4f3ab0a.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/book/photoProductsOrderDetail/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;
@ -456,7 +491,7 @@
}
.font {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
color: #000000;
}
.text {
@ -504,7 +539,7 @@
}
.font_2 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
line-height: 25.84rpx;
color: #323232;
}
@ -519,7 +554,7 @@
}
.font_4 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
line-height: 17.53rpx;
color: #323232;
}
@ -529,7 +564,7 @@
}
.font_5 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
line-height: 17.53rpx;
color: #e79ea1;
}
@ -538,7 +573,7 @@
}
.font_6 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
line-height: 25.84rpx;
color: #e79ea1;
}
@ -558,7 +593,7 @@
}
.font_8 {
font-size: 33.75rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
line-height: 22.54rpx;
color: #e79ea1;
}
@ -570,7 +605,7 @@
}
.font_7 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
line-height: 25.84rpx;
color: #000000;
}
@ -598,13 +633,13 @@
}
.font_9 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
line-height: 23.79rpx;
color: #000000;
}
.font_10 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
line-height: 21.09rpx;
color: #000000;
}
@ -648,7 +683,7 @@
}
.font_11 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
font-family: FangZhengFonts;
line-height: 25.84rpx;
color: #ffffff;
}

View File

@ -1,543 +0,0 @@
<template>
<view class="flex-col justify-start page">
<view class="flex-col section">
<view class="flex-col group">
<view class="flex-col justify-start items-start relative group_2">
<view class="section_2"></view>
<text class="font text pos">填写预约信息</text>
<view class="flex-col section_3 pos_2">
<navigator url="/pages/booking/ContactInformation">
<view class="flex-row justify-between items-center group_3">
<view class="flex-row items-center">
<image class="shrink-0 image"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=31a410ede6797f73e60922316e512a5e.png" />
<text class="font_2 text_2 ml-7">联系人张三</text>
<text class="font_2 text_3 ml-7">15888610253</text>
</view>
<image class="image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=6f325d022e16b19acc81dad350dbd524.png" />
</view>
</navigator>
<navigator url="/pages/booking/date">
<view class="flex-row justify-between items-center group_4">
<view class="flex-row items-center">
<image class="image"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=c6dac3074d9c4e4d6286c07f0ea03db5.png" />
<view class="flex-col items-start ml-9">
<text class="font_3">到店日期2024-10-15</text>
<text class="font_3 mt-2">具体场次上午场09:30-12:00</text>
</view>
</view>
<image class="image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=6f325d022e16b19acc81dad350dbd524.png" />
</view>
</navigator>
</view>
</view>
<view class="flex-col group_5 mt-14">
<view class="flex-col self-stretch">
<text class="self-start font text_4">选择预约类别</text>
<view class="flex-col justify-start self-stretch section_4 mt-14">
<view class="flex-row equal-division">
<view class="flex-col items-center equal-division-item_1 section_5">
<image class="image_3"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=b6725d0c7dfe22679472bb9a47e9e39b.png" />
<text class="font_4 mt-11">租赁服装</text>
</view>
<view class="flex-col items-center equal-division-item_2 equal-division-item ml-23">
<image class="image_3"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=81f08e7f1a4104921b651e672383b3d9.png" />
<text class="font_4 text_5">自带服装</text>
<view class="section_7 pos_3"></view>
</view>
</view>
</view>
</view>
<text class="self-start font text_6 mt-23">选择服装价位</text>
</view>
<view class="flex-col section_8 mt-14">
<view class="flex-col">
<view class="flex-row justify-between items-center section_1">
<view class="flex-row items-center">
<image class="image_4"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=c58ffae9f1ef4340291223163c7a8297.png" />
<view class="flex-col ml-13">
<text class="self-start font_2 text_7">简约风尚</text>
<view class="flex-row items-baseline self-stretch mt-11">
<text class="font_2">价位</text>
<text class="font_5 text_1 ml-1">100-200</text>
</view>
<text class="self-stretch font_6 mt-11">传承非遗之美简约演绎经典</text>
</view>
</view>
<image class="image_5"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=7d16fc8dfa328fc97ff273ebeab9bc18.png" />
</view>
<view class="flex-row items-center section_13 mt-9">
<image class="shrink-0 image_4"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=bc0e955304da0a2ccafe3a66ac1f3aca.png" />
<view class="flex-col flex-1 group_6">
<text class="self-start font_2 text_9">时尚精选</text>
<view class="flex-row items-baseline self-stretch mt-11">
<text class="font_2">价位</text>
<text class="font_5 text_10 ml-1">200-400</text>
</view>
<text class="self-stretch font_6 text_11 mt-11">融合时尚与传统精选非遗华章</text>
</view>
<image class="shrink-0 image_5 image_6"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=7d16fc8dfa328fc97ff273ebeab9bc18.png" />
</view>
<view class="flex-row justify-between items-center section_13 mt-9">
<view class="flex-row items-center">
<image class="image_7"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=4c1c758fda92536b923ec745cb077f5a.png" />
<view class="flex-col ml-13">
<text class="self-start font_2 text_12">奢华专属</text>
<view class="flex-row items-baseline self-stretch mt-11">
<text class="font_2">价位</text>
<text class="font_5 text_20 ml-1">400-800</text>
</view>
<text class="self-stretch font_6 mt-11">非遗匠心独运奢华专属定制</text>
</view>
</view>
<image class="image_5"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=7d16fc8dfa328fc97ff273ebeab9bc18.png" />
</view>
</view>
<view class="flex-row justify-center items-center mt-15">
<image class="image_8"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=18dd2fa44538df4392850f46b9b3550e.png" />
<text class="font_6 text_13 ml-4">预约须知</text>
</view>
</view>
</view>
<view class="flex-row items-center section_9 mt-19">
<view class="flex-row items-center shrink-0 group_7">
<view class="flex-col justify-start items-start shrink-0 relative group_8">
<text class="text_14">预约费用</text>
<image class="image_2 pos_4"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=3393d3563afcfe7dedbadba1ea5328a0.png" />
</view>
<text class="font_5 text_15">88.</text>
<text class="text_17">00</text>
</view>
<view class="flex-row items-center flex-1 ml-51">
<!-- <navigator url="../booking/BillingOfFees/BillingOfFees"> -->
<view class="flex-row shrink-0 section_10" @click="goto">
<text class="text_18">费用说明</text>
<image class="shrink-0 image_9 ml-3"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=0455b173571a47fdc438588e788f26c5.png" />
</view>
<!-- </navigator> -->
<view class="flex-col justify-start items-center flex-1 text-wrapper ml-10">
<text class="font_4 text_16">确定预约</text>
</view>
</view>
</view>
</view>
</view>
</template>
<script setup lang="ts">
// import { ref} from 'vue';
const goto=()=>{
uni.navigateTo({
url:'/pages/booking/BillingOfFees/BillingOfFees'
})
}
</script>
<style lang="scss" scoped>
.ml-7 {
margin-left: 13.13rpx;
}
.ml-9 {
margin-left: 16.88rpx;
}
.ml-23 {
margin-left: 43.13rpx;
}
.mt-23 {
margin-top: 43.13rpx;
}
.ml-13 {
margin-left: 24.38rpx;
}
.mt-9 {
margin-top: 16.88rpx;
}
.mt-11 {
margin-top: 20.63rpx;
}
.ml-1 {
margin-left: 1.88rpx;
}
.mt-15 {
margin-top: 28.13rpx;
}
.mt-19 {
position: fixed;
bottom: 0;
width: 100%;
}
.ml-51 {
margin-left: 95.63rpx;
}
.ml-3 {
margin-left: 5.63rpx;
}
.page {
background-color: #ffffff;
height: 100%;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
}
.section {
background-color: #f5f5dc;
}
.group {
padding: 45.75rpx 0;
}
.group_2 {
padding-top: 12.38rpx;
}
.section_2 {
margin-left: 71.25rpx;
background-color: #ffffff00;
border-radius: 18.75rpx;
width: 281.25rpx;
height: 281.25rpx;
}
.font {
font-size: 30rpx;
font-family: Open Sans;
line-height: 27.75rpx;
color: #323232;
}
.text {
line-height: 27.96rpx;
}
.pos {
position: absolute;
left: 21.62rpx;
top: 0;
}
.section_3 {
padding-left: 33.75rpx;
padding-right: 28.13rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.pos_2 {
position: absolute;
left: 20.63rpx;
right: 20.63rpx;
top: 53.63rpx;
}
.group_3 {
padding: 31.88rpx 0 15.94rpx;
border-bottom: solid 1.88rpx #e2e0e0;
}
.image {
width: 43.13rpx;
height: 43.13rpx;
}
.font_2 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 24.3rpx;
color: #323232;
}
.text_2 {
line-height: 24rpx;
}
.text_3 {
line-height: 24rpx;
}
.image_2 {
width: 33.75rpx;
height: 33.75rpx;
}
.group_4 {
padding: 22.97rpx 0 36.51rpx;
}
.font_3 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 31.88rpx;
color: #323232;
}
.group_5 {
padding: 0 30rpx;
}
.text_4 {
line-height: 27.69rpx;
}
.section_4 {
padding: 31.88rpx 0;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.equal-division {
margin-left: 41.25rpx;
margin-right: 41.27rpx;
}
.equal-division-item_1 {
flex: 1 1 281.25rpx;
}
.section_5 {
padding: 31.57rpx 0 40.58rpx;
background-color: #fff291;
border-radius: 18.75rpx;
height: 281.25rpx;
}
.image_3 {
width: 159.99rpx;
height: 159.99rpx;
}
.font_4 {
font-size: 30rpx;
font-family: Inter;
line-height: 27.75rpx;
color: #323232;
}
.equal-division-item_2 {
position: relative;
flex: 1 1 281.25rpx;
}
.equal-division-item {
padding: 31.56rpx 0 42.49rpx;
background-color: #fff291;
border-radius: 18.75rpx;
height: 281.25rpx;
}
.text_5 {
margin-top: 19.46rpx;
}
.section_7 {
background-color: #ffffff99;
border-radius: 18.75rpx;
width: 281.25rpx;
height: 281.25rpx;
}
.pos_3 {
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
}
.text_6 {
line-height: 27.86rpx;
}
.section_8 {
padding: 30rpx 30rpx 26.25rpx;
background-color: #fff3c3;
}
.section_1 {
padding: 24.38rpx 26.25rpx 26.25rpx 39.38rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.image_4 {
border-radius: 9.38rpx;
width: 118.13rpx;
height: 151.88rpx;
}
.text_7 {
line-height: 24.26rpx;
}
.font_5 {
font-size: 33.75rpx;
font-family: Open Sans;
line-height: 24.3rpx;
color: #ff3c3c;
}
.text_1 {
line-height: 24.81rpx;
}
.font_6 {
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 21.36rpx;
color: #898989;
}
.image_5 {
width: 37.5rpx;
height: 37.5rpx;
}
.section_13 {
padding: 26.27rpx 26.25rpx 24.36rpx 39.38rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.group_6 {
margin-left: 24.77rpx;
}
.text_9 {
line-height: 24.15rpx;
}
.text_10 {
line-height: 24.81rpx;
}
.text_11 {
line-height: 21.38rpx;
}
.image_6 {
margin-left: 39.99rpx;
}
.image_7 {
width: 118.13rpx;
height: 151.88rpx;
}
.text_12 {
line-height: 24.23rpx;
}
.text_20 {
line-height: 24.81rpx;
}
.image_8 {
width: 28.13rpx;
height: 28.13rpx;
}
.text_13 {
color: #000000;
line-height: 20.77rpx;
}
.section_9 {
padding: 16.88rpx 20.63rpx 15rpx 21.6rpx;
background-color: #fffef8;
}
.group_7 {
width: 236.23rpx;
}
.group_8 {
padding: 4.22rpx 0 5.25rpx;
}
.text_14 {
color: #000000;
font-size: 26.25rpx;
font-family: Inter;
line-height: 24.28rpx;
}
.pos_4 {
position: absolute;
right: 0;
bottom: 0;
}
.text_15 {
color: #fbb612;
font-weight: 700;
line-height: 24.84rpx;
}
.text_17 {
margin-left: 3.52rpx;
color: #fbb612;
font-size: 26.25rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 19.29rpx;
}
.section_10 {
padding: 9.38rpx 9.38rpx 9.38rpx 10.18rpx;
background-color: #d9d9d9;
border-radius: 9.38rpx;
height: 37.5rpx;
}
.text_18 {
color: #323232;
font-size: 18.75rpx;
font-family: Inter;
line-height: 17.36rpx;
}
.image_9 {
width: 18.75rpx;
height: 18.75rpx;
}
.text-wrapper {
padding: 27.3rpx 0 27.45rpx;
background-color: #fbb612;
border-radius: 75rpx;
height: 82.5rpx;
}
.text_16 {
color: #ffffff;
}
@import url(../../common/css/global.css);
</style>

View File

@ -1,151 +0,0 @@
<template>
<view class="flex-col page">
<text class="self-center text">费用说明</text>
<view class="flex-col self-stretch group">
<text class="self-start font text_2">费用支付流程</text>
<text class="self-stretch font_2 text_3">
确定等级您将根据个人需求选择合适的服装价位区间并完成预约操作
<br />
预约成功预约成功后您需前往店铺挑选对应等级的服装
<br />
</text>
<text class="self-stretch font_2 text_4">
补缴尾款及押金在挑选服装时您需要补缴尾款扣除已支付定金后的剩余服务或商品费用以及押金用于保障服装归还时的完好
</text>
</view>
<view class="flex-col self-stretch group_2">
<text class="self-start font">尾款具体事项</text>
<text class="mt-18 self-stretch font_3 text_5">
租赁服装若您选择租赁我们店铺没有的服装租赁费用将在您支付尾款时一并结算无论拍摄是否进行租赁费用均不予退还
<br />
购买服装如您希望购买我们店铺的服装且我们同意购买将按照服装的稀有程度分等级定价您需按照所选等级支付尾款
<br />
定制服务若您自带衣服我们提供妆发及摄影服务若需我们额外购买服装将按照上述等级定价您需支付相应的尾款
</text>
</view>
<view class="flex-col self-stretch group_3">
<text class="self-start font text_6">定金与押金说明</text>
<text class="self-stretch font_3 text_7 mt-15">
定金预约时支付的定金用于确认您的预约意向定金 不予退还
<br />
押金拍摄完成后我们将根据服装的归还情况决定是否扣除押金若服装无损坏押金将全额退还
</text>
</view>
<view class="flex-col self-stretch group_4">
<text class="self-start font text_8">特殊情况处理</text>
<text class="mt-18 self-stretch font_3 text_9">
若因特殊情况您需要取消预约请及时与我们联系未拍摄情况下定金不予退还已支付的租赁费用亦不退还
<br />
</text>
</view>
<view class="flex-col justify-start items-center self-stretch text-wrapper" @click="jump_pay">
<text class="text_10">我知道了</text>
</view>
</view>
</template>
<script setup>
import {ref} from 'vue'
const jump_pay =()=>{
uni.navigateTo({
url: '../../../pages/booking/bookingpay/bookingpay'
})
}
</script>
<style lang="scss" scoped>
.mt-15 {
margin-top: 28.13rpx;
}
.page {
padding: 48.75rpx 11.75rpx 61.88rpx;
background-color: #fffef8;
border-radius: 37.5rpx 37.5rpx 0rpx 0rpx;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
}
.text {
color: #323232;
font-size: 37.5rpx;
font-family: Open Sans;
line-height: 34.73rpx;
}
.group {
margin-right: 11.25rpx;
margin-top: 67.5rpx;
}
.font {
font-size: 30rpx;
font-family: Open Sans;
line-height: 27.71rpx;
color: #323232;
}
.text_2 {
line-height: 35.63rpx;
}
.font_2 {
font-size: 26.25rpx;
font-family: Inter;
line-height: 31.88rpx;
color: #323232;
}
.text_3 {
margin-left: 22.5rpx;
margin-top: 15rpx;
}
.text_4 {
margin-left: 18.75rpx;
margin-right: 15rpx;
}
.group_2 {
margin-right: 18.75rpx;
margin-top: 63.75rpx;
}
.font_3 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 31.88rpx;
color: #323232;
}
.text_5 {
margin-left: 15rpx;
}
.group_3 {
margin-right: 18.75rpx;
margin-top: 63.75rpx;
}
.text_6 {
line-height: 27.84rpx;
}
.text_7 {
margin-left: 15rpx;
}
.group_4 {
margin-right: 22.5rpx;
margin-top: 56.25rpx;
}
.text_8 {
line-height: 27.75rpx;
}
.text_9 {
margin-left: 3.75rpx;
}
.text-wrapper {
display: flex;
justify-content: center;
align-items: center;
margin: 75rpx 22.5rpx 0;
padding: 30rpx 0;
background-color: #fbb612;
border-radius: 75rpx;
}
.text_10 {
color: #ffffff;
font-size: 30rpx;
font-family: Inter;
line-height: 27.71rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -1,162 +0,0 @@
<template>
<view class="flex-col page">
<view class="flex-col flex-1 group_2">
<view class="flex-col">
<view class="flex-row justify-between items-center section">
<view class="flex-row items-center">
<image
class="shrink-0 image_3"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=3a9304082db1a0ce59900947da89bfaf.png"
/>
<text class="font ml-9">张三</text>
<text class="font_2 ml-9">15888610253</text>
</view>
<view class="flex-row group_3">
<image
class="image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=4ea2c3040a66adfdc3cd18d7fe9fea60.png"
/>
<image
class="ml-12 image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=6184b59dfc6e09773e972bd085509877.png"
/>
</view>
</view>
<view class="flex-row justify-between items-center section">
<view class="flex-row items-center">
<image
class="shrink-0 image_3"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=3a9304082db1a0ce59900947da89bfaf.png"
/>
<text class="font ml-9">张三</text>
<text class="font_2 ml-9">15888610253</text>
</view>
<view class="flex-row group_3">
<image
class="image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=4ea2c3040a66adfdc3cd18d7fe9fea60.png"
/>
<image
class="ml-12 image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=6184b59dfc6e09773e972bd085509877.png"
/>
</view>
</view>
<view class="flex-row justify-between items-center section">
<view class="flex-row items-center">
<image
class="shrink-0 image_3"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=3a9304082db1a0ce59900947da89bfaf.png"
/>
<text class="font ml-9">张三</text>
<text class="font_2 ml-9">15888610253</text>
</view>
<view class="flex-row group_3">
<image
class="image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=4ea2c3040a66adfdc3cd18d7fe9fea60.png"
/>
<image
class="ml-12 image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=6184b59dfc6e09773e972bd085509877.png"
/>
</view>
</view>
<view class="flex-row justify-between items-center section">
<view class="flex-row items-center">
<image
class="shrink-0 image_3"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=3a9304082db1a0ce59900947da89bfaf.png"
/>
<text class="font ml-9">张三</text>
<text class="font_2 ml-9">15888610253</text>
</view>
<view class="flex-row group_3">
<image
class="image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=4ea2c3040a66adfdc3cd18d7fe9fea60.png"
/>
<image
class="ml-12 image_2"
src="https://ide.code.fun/api/image?token=6710a29d1511d900114ac910&name=6184b59dfc6e09773e972bd085509877.png"
/>
</view>
</view>
</view>
<view class="flex-col justify-start items-center section_2 mt-251">
<view class="flex-col justify-start items-center button"><text class="font text_2">添加新联系人</text></view>
</view>
</view>
</view>
</template>
<script>
import {ref} from 'vue';
const items = ([null,null,null,null])
</script>
<style lang="scss" scoped>
.ml-9 {
margin-left: 16.88rpx;
}
.mt-251 {
position: fixed;
bottom: 0;
width: 100%;
}
.page {
background-color: #f5f5dc;
border-radius: 28.13rpx 28.13rpx 0rpx 0rpx;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
}
.group_2 {
overflow-y: auto;
}
.section {
padding: 52.5rpx 15rpx;
background-color: #fffef8;
border-bottom: solid 1.88rpx #c8c8c8;
}
.image_3 {
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: 11.25rpx;
}
.image_2 {
width: 39.38rpx;
height: 39.38rpx;
}
.section_2 {
padding: 22.5rpx 0 15rpx;
background-color: #fffef8;
}
.button {
padding: 30rpx 0;
background-color: #fbb612;
border-radius: 75rpx;
width: 639.38rpx;
}
.text_2 {
color: #ffffff;
line-height: 27.75rpx;
}
@import url(../../common/css/global.css);
</style>

View File

@ -1,46 +0,0 @@
<template>
<view>{{details.name}}</view>
<image :src="details.image"></image>
<image :src="details.effectImg"></image>
<view>{{details.intro}}</view>
<view>{{details.price}}</view>
<view>{{details.clothesType}}</view>
</template>
<script setup>
import {ref,onMounted} from 'vue'
import { onLoad } from '@dcloudio/uni-app'
import { baseUrl } from '../../../api/request';
const id = ref([{}])
const details = ref([{}])
onLoad((options)=>{
id.value = JSON.parse(options.info)
console.log(id.value,1111111111)
})
onMounted(()=>{
getDetails()
})
const getDetails = async ()=>{
const res = await uni.request({
url:baseUrl + '/clothesInfo/list/detail',
method:'POST',
header:{
cookie:wx.getAccountInfoSync('cookie')
},
data:{
id:id.value
}
})
if(res.data.code === 1){
details.value = res.data.data
}else{
uin.showtoast({
icon:'error',
title:'获取失败'
})
}
}
</script>
<style>
</style>

View File

@ -1,442 +0,0 @@
<!-- <template>
<view class="flex-col page">
<view class="flex-col section">
<text class="self-start text">服装展示</text>
<view class="flex-col self-stretch mt-21">
<view class="flex-row items-center mt-10 list-item" v-for="(item, index) in label" :key="index"
@click="goToText(index)">
<image class="shrink-0 image_2" :src="item.image" />
<view class="flex-col flex-1 ml-11">
<view class="flex-col self-stretch">
<view class="flex-row justify-end self-stretch group">
<text class="font">详细信息</text>
<image class="image" :src="item.image" />
</view>
<text class="self-start font_2 text_2 mt-3">{{item.name}}</text>
</view>
<view class="self-stretch group_2 mt-5">
<text class="font_4">服装简介</text>
<text class="font_3">
{{item.intro}}
</text>
</view>
<text class="self-end font_5 mt-5">{{item.price}}</text>
</view>
</view>
</view>
</view>
<view class="mt-48 flex-row items-center section_2">
<view class="flex-col items-center shrink-0 section_3">
<image class="image_3"
src="https://ide.code.fun/api/image?token=674eb236797f850011f0c44a&name=4b56fed14a39630ca2312edf6e34c024.png" />
<text class="mt-2 text_4">客服</text>
</view>
<view class="ml-34 flex-col justify-start items-center flex-1 text-wrapper">
<text class="text_3">现在去预约</text>
</view>
</view>
</view>
</template>
<script setup>
import {
ref,
onMounted
} from 'vue'
import {
onLoad
} from '@dcloudio/uni-app'
import {
baseUrl
} from '../../../api/request';
const list = ref([{}])
const label = ref([{}])
onMounted(() => {
getLabel()
})
onLoad((options) => {
list.value = JSON.parse(options.info)
console.log(list.value, 'id')
})
const getLabel = async () => {
const res = await uni.request({
url: baseUrl + '/clothesInfo/list/label',
method: 'POST',
header: {
cookie: wx.getAccountInfoSync('cookie')
},
data: {
id: list.value
}
})
console.log(res)
if (res.data.code === 1) {
label.value = res.data.data
} else {
uin.showtoast({
icon: 'error',
title: '获取失败'
})
}
}
const goToText = (index) => {
uni.navigateTo({
url: "/pages/booking/CostumeDetails/CostumeDetails?info=" + JSON.stringify(label.value[index].id)
})
console.log(label.value[index].id)
}
</script>
<style lang="scss" scoped>
.mt-21 {
margin-top: 39.38rpx;
}
.ml-11 {
margin-left: 20.63rpx;
}
.mt-3 {
margin-top: 5.63rpx;
}
.mt-5 {
margin-top: 9.38rpx;
}
.page {
padding-top: 69.38rpx;
background-color: #f5f5dc;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
}
.section {
margin: 0 18.75rpx;
padding: 37.5rpx 30rpx 129.38rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.text {
color: #000000;
font-size: 30rpx;
font-family: Open Sans;
line-height: 27.71rpx;
}
.list-item {
padding: 22.5rpx 22.5rpx 22.5rpx 30rpx;
background-color: #fff3c3;
border-radius: 9.38rpx;
}
.list-item:first-child {
margin-top: 0;
}
.image_2 {
border-radius: 9.38rpx;
width: 148.13rpx;
height: 165rpx;
}
.group {
padding: 0 3.75rpx;
}
.font {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 17.44rpx;
color: #323232;
}
.image {
width: 15rpx;
height: 15rpx;
}
.font_2 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #323232;
}
.text_2 {
line-height: 24.26rpx;
}
.group_2 {
line-height: 22.5rpx;
}
.font_4 {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #323232;
}
.font_3 {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #828282;
}
.font_5 {
font-size: 33.75rpx;
font-family: Times New Roman;
line-height: 24.73rpx;
color: #ff3c3c;
}
.section_2 {
background-color: #fffef8;
position: fixed;
bottom: 0;
width: 100%;
}
.section_3 {
padding: 15rpx 0;
background-color: #ffc470;
width: 118.13rpx;
height: 114.38rpx;
}
.image_3 {
width: 52.5rpx;
height: 52.5rpx;
}
.text_4 {
color: #fffef8;
font-size: 26.25rpx;
font-family: Inter;
line-height: 24.17rpx;
}
.text-wrapper {
margin-right: 26.25rpx;
padding: 26.25rpx 0;
background-color: #fbb612;
border-radius: 75rpx;
height: 82.5rpx;
}
.text_3 {
color: #ffffff;
font-size: 30rpx;
font-family: Inter;
line-height: 27.86rpx;
}
@import url("../../../common/css/global.css");
</style> -->
<template>
<view class="flex-col justify-start relative page">
<view class="shrink-0 section"></view>
<view class="flex-col justify-start items-center text-wrapper pos"><text class="text">服装详情</text></view>
<view class="flex-col pos_2">
<view class="flex-row items-center list-item" v-for="(item, index) in label" :key="index" @click="goToText(index)">
<image class="shrink-0 image"
:src="item.image" />
<view class="flex-col flex-1 ml-5">
<text class="self-start font">{{item.name}}</text>
<text class="self-start font_2 text_2">
{{item.intro}}
</text>
<text class="self-end font_3 text_3">{{item.price}}</text>
</view>
</view>
</view>
<view class="flex-row justify-between items-center section_4 pos_3">
<view class="flex-col items-center">
<image class="image_2"
src="https://ide.code.fun/api/image?token=67610a10797f850011f30392&name=a18599a262f28b8e3d504092795de649.png" />
<text class="text_5 mt-3">客服</text>
</view>
<view class="flex-col justify-start items-center text-wrapper_2"><text class="font text_4">现在去预约</text>
</view>
</view>
</view>
</template>
<script setup>
import {
ref,
onMounted
} from 'vue'
import {
onLoad
} from '@dcloudio/uni-app'
import {
baseUrl
} from '../../../api/request';
const list = ref([{}])
const label = ref([{}])
onMounted(() => {
getLabel()
})
onLoad((options) => {
list.value = JSON.parse(options.info)
console.log(list.value, 'id')
})
const getLabel = async () => {
const res = await uni.request({
url: baseUrl + '/clothesInfo/list/label',
method: 'POST',
header: {
cookie: wx.getAccountInfoSync('cookie')
},
data: {
id: list.value
}
})
console.log(res)
if (res.data.code === 1) {
label.value = res.data.data
} else {
uin.showtoast({
icon: 'error',
title: '获取失败'
})
}
}
const goToText = (index) => {
uni.navigateTo({
url: "/pages/booking/CostumeDetails/CostumeDetails?info=" + JSON.stringify(label.value[index].id)
})
console.log(label.value[index].id)
}
</script>
<style lang="scss" scoped>
.ml-5 {
margin-left: 9.38rpx;
}
.mt-3 {
margin-top: 5.63rpx;
}
.page {
background-color: #ffffff;
overflow: hidden;
background-image: url('https://ide.code.fun/api/image?token=67610a10797f850011f30392&name=7f5f6eb3a306f1097a8541736adfb354.png');
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
}
.section {
background-image: url('https://ide.code.fun/api/image?token=67610a10797f850011f30392&name=7f5f6eb3a306f1097a8541736adfb354.png');
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;
height: 1659.38rpx;
}
.text-wrapper {
padding: 26.25rpx 0 22.5rpx;
background-color: #ebe7e480;
}
.pos {
position: absolute;
left: 0;
right: 0;
top: 0;
}
.text {
color: #000000;
font-size: 37.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 36.34rpx;
}
.pos_2 {
position: absolute;
left: 45rpx;
right: 37.5rpx;
top: 150rpx;
}
.list-item {
padding: 0 7.5rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
}
.image {
width: 161.25rpx;
height: 219.38rpx;
}
.font {
font-size: 28.13rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 27.69rpx;
color: #000000;
}
.font_2 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 27.69rpx;
color: #00000099;
}
.text_2 {
margin-top: 18.75rpx;
line-height: 26.25rpx;
width: 427.5rpx;
}
.font_3 {
font-size: 28.13rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 18.79rpx;
color: #ff0707;
}
.text_3 {
margin-right: 18.75rpx;
}
.section_4 {
padding: 15rpx 45rpx;
background-color: #ffffff;
}
.pos_3 {
position: absolute;
left: 0;
right: 0;
position: fixed;
bottom: 0;
}
.image_2 {
width: 46.88rpx;
height: 46.88rpx;
}
.text_5 {
color: #9d2624;
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 20.72rpx;
}
.text-wrapper_2 {
margin-right: 22.5rpx;
padding: 30rpx 0 26.25rpx;
background-color: #e79ea1;
border-radius: 75rpx;
width: 466.14rpx;
height: 82.5rpx;
}
.text_4 {
color: #ffffff;
font-size: 30rpx;
line-height: 27.43rpx;
}
@import url("../../../common/css/global.css");
// </style>

View File

@ -1,72 +0,0 @@
<template>
<view class="flex-col justify-start items-center page">
<view class="flex-col section">
<view class="flex-col self-stretch group">
<text class="self-center font text">预约须知</text>
<view class="mt-12 flex-col self-stretch">
<text class="font_2">
1.成功预约的顾客需按照预定时间前往店内挑选相应级别的服装为确保衣物在体验过程中的完好无损顾客需根据所选服装的级别补缴尾款以及相应的押金拍摄结束后店铺将依据衣物的实际状况评估是否扣除押金
</text>
<text class="mt-16 font_2 text_2">
2.其中部分物品商家可提供属于增值服务如一次性隐形眼镜
一次性粉扑等属于服务费以外的赠送服务买家可选择自带用品不影响服务价格需要买家自己准备的客服需要提前告诉买家如胸贴等贴身物品
</text>
</view>
</view>
<view class="flex-col justify-start items-center self-center text-wrapper">
<text class="font text_3">我知道了</text>
</view>
</view>
</view>
</template>
<script>
</script>
<style lang="scss" scoped>
.page {
padding: 298.13rpx 0 708.75rpx;
background-color: #f5f5dc;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
}
.section {
padding: 0 15rpx 31.88rpx 37.5rpx;
background-color: #fffef8;
border-radius: 37.5rpx;
width: 609.38rpx;
}
.group {
padding: 37.5rpx 0 48.75rpx;
}
.font {
font-size: 30rpx;
font-family: Inter;
line-height: 27.69rpx;
}
.text {
color: #323232;
}
.font_2 {
font-size: 26.25rpx;
font-family: Inter;
line-height: 31.88rpx;
color: #323232;
}
.text_2 {
margin-left: 3.75rpx;
}
.text-wrapper {
padding: 22.5rpx 0;
background-color: #fbb612;
border-radius: 75rpx;
width: 450rpx;
}
.text_3 {
color: #ffffff;
line-height: 27.71rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -1,250 +0,0 @@
<template>
<view class="flex-col justify-start page">
<view class="flex-col section">
<view class="flex-col group">
<view class="flex-col relative section_2">
<view class="flex-row items-baseline self-stretch">
<text class="font text">简约风尚</text>
<text class="font_2 text_2 ml-19">传承非遗之美简约演绎经典</text>
</view>
<text class="self-start font_3 text_3">服装特点</text>
<view class="flex-col items-start self-stretch group_2">
<text class="font_2">提供多样化的经典汉服款式如基础款曲裾直裾等</text>
<text class="mt-2 font_2">服装面料舒适适合日常拍摄体验</text>
<text class="mt-2 font_2">配饰简约适合初次尝试传统服饰的用户</text>
</view>
<text class="self-start font_3 text_4">服务内容</text>
<view class="flex-col items-start self-stretch group_3">
<text class="font_2">专业化妆及基础发型设计</text>
<text class="mt-2 font_2">服装租赁服务</text>
<text class="mt-2 font_2">基础摄影服务不含精修</text>
</view>
<image
class="image pos"
src="https://ide.code.fun/api/image?token=6711f04f38a7c1001587de59&name=d6d88e3f45498775df202023e1df0871.png"
/>
</view>
<view class="mt-12 flex-col section_3">
<text class="self-start font text_5">服装选择</text>
<view class="flex-col self-stretch mt-11">
<view class="flex-row items-center mt-10 list-item" v-for="(item, index) in items" :key="index">
<image
class="shrink-0 image_3"
src="https://ide.code.fun/api/image?token=6711f04f38a7c1001587de59&name=1c18c9d6f08498ff9a0cf7a598a0d271.png"
/>
<view class="ml-10 flex-col flex-1">
<view class="flex-row justify-end self-stretch group_4">
<text class="font_4">详细信息</text>
<image
class="image_2"
src="https://ide.code.fun/api/image?token=6711f04f38a7c1001587de59&name=1484e0cc6274180ba7c91cddf1ec833b.png"
/>
</view>
<text class="self-start font_5 text_6">彩绣菊花纹刺绣长袍</text>
<view class="self-stretch group_5">
<text class="font_7">服装简介</text>
<text class="font_6">
用上等丝绸质地细腻柔软且富有光泽触感极佳统手工刺绣技艺每一针每一线都凝聚着匠人的心血与智慧图案精美绝伦色彩丰富和谐...
</text>
</view>
<text class="self-end font_8">150</text>
</view>
</view>
</view>
</view>
</view>
<view class="mt-26 flex-row">
<view class="flex-col items-center shrink-0 section_4">
<image
class="image_4"
src="https://ide.code.fun/api/image?token=6711f04f38a7c1001587de59&name=4b56fed14a39630ca2312edf6e34c024.png"
/>
<text class="mt-2 text_8">客服</text>
</view>
<view class="flex-col justify-start items-end flex-1 section_5">
<view class="flex-col justify-start items-center text-wrapper"><text class="text_7">现在去预约</text></view>
</view>
</view>
</view>
</view>
</template>
<script>
</script>
<style lang="scss" scoped>
.ml-19 {
margin-left: 35.63rpx;
}
.mt-11 {
margin-top: 20.63rpx;
}
.page {
background-color: #ffffff;
height: 100%;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
}
.section {
padding-top: 22.5rpx;
background-color: #f5f5dc;
}
.group {
padding: 0 16.88rpx;
}
.section_2 {
padding: 37.5rpx 41.25rpx 30rpx;
background-color: #f3fff3;
border-radius: 18.75rpx 18.75rpx 0rpx 0rpx;
}
.font {
font-size: 30rpx;
font-family: Open Sans;
line-height: 27.71rpx;
}
.text {
color: #323232;
}
.font_3 {
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #323232;
}
.text_3 {
margin-top: 22.5rpx;
line-height: 20.79rpx;
}
.group_2 {
margin-top: 15rpx;
padding: 0 22.5rpx;
}
.font_2 {
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 26.25rpx;
color: #696969;
}
.text_2 {
line-height: 21.36rpx;
}
.text_4 {
margin-top: 26.25rpx;
line-height: 20.77rpx;
}
.group_3 {
margin-top: 15rpx;
padding: 0 24.38rpx;
}
.image {
width: 127.5rpx;
height: 127.5rpx;
}
.pos {
position: absolute;
right: 0;
bottom: 13.13rpx;
}
.section_3 {
padding: 37.5rpx 30rpx 52.5rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.text_5 {
color: #000000;
}
.list-item {
padding: 22.5rpx;
background-color: #fff3c3;
border-radius: 9.38rpx;
}
.list-item:first-child {
margin-top: 0;
}
.image_3 {
border-radius: 9.38rpx;
width: 148.13rpx;
height: 165rpx;
}
.group_4 {
padding: 0 3.75rpx;
}
.font_4 {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 17.44rpx;
color: #323232;
}
.image_2 {
width: 15rpx;
height: 15rpx;
}
.font_5 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #323232;
}
.text_6 {
margin-top: 15rpx;
line-height: 24.23rpx;
}
.group_5 {
margin-top: 11.25rpx;
line-height: 22.5rpx;
}
.font_7 {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #323232;
}
.font_6 {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #828282;
}
.font_8 {
font-size: 33.75rpx;
font-family: Times New Roman;
line-height: 24.73rpx;
color: #ff3c3c;
}
.section_4 {
padding: 15rpx 0;
background-color: #ffc470;
width: 118.13rpx;
height: 114.38rpx;
}
.image_4 {
width: 52.5rpx;
height: 52.5rpx;
}
.text_8 {
color: #fffef8;
font-size: 26.25rpx;
font-family: Inter;
line-height: 24.17rpx;
}
.section_5 {
padding: 15rpx 0;
background-color: #fffef8;
height: 114.38rpx;
}
.text-wrapper {
margin-right: 20.63rpx;
padding: 26.25rpx 0;
background-color: #fbb612;
border-radius: 75rpx;
width: 457.5rpx;
}
.text_7 {
color: #ffffff;
font-size: 30rpx;
font-family: Inter;
line-height: 27.86rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -1,443 +0,0 @@
<template>
<view class="flex-col justify-start page">
<view class="flex-col section">
<view class="flex-col justify-start items-start relative group">
<view class="section_2"></view>
<text class="font text pos">填写预约信息</text>
<view class="flex-col section_3 pos_2">
<view class="flex-row justify-between items-center group_2">
<view class="flex-row items-center">
<image
class="shrink-0 image"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=bb513bb96b7e8c5705f06c4bfc640618.png"
/>
<text class="font_2 ml-7">联系人张三</text>
<text class="font_2 ml-7">15888610253</text>
</view>
<image
class="image_2"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=6a472e2ad5dc2aec534bd3b852a38986.png"
/>
</view>
<view class="flex-row justify-between items-center group_3">
<view class="flex-row items-center">
<image
class="image"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=62c3ebe2e0dfac0ba2ddec26fdcb54ec.png"
/>
<view class="flex-col items-start ml-9">
<text class="font_3">到店日期2024-10-15</text>
<text class="mt-2 font_3">具体场次上午场09:30-12:00</text>
</view>
</view>
<image
class="image_2"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=6a472e2ad5dc2aec534bd3b852a38986.png"
/>
</view>
</view>
</view>
<view class="flex-col group_4">
<view class="flex-col self-stretch">
<text class="self-start font text_2">选择预约类别</text>
<view class="mt-14 flex-col justify-start self-stretch section_4">
<view class="flex-row equal-division">
<view class="flex-col items-center section_5 equal-division-item">
<image
class="image_3"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=b5db39327852641a550d033d1026764f.png"
/>
<text class="font_4 text_3 mt-11">租赁服装</text>
</view>
<view class="flex-col items-center section_6 equal-division-item ml-23">
<image
class="image_3"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=ee3cc136b2309fda20df9a345ce1ef05.png"
/>
<text class="font_4 text_3 text_4">自带服装</text>
<view class="section_7 pos_3"></view>
</view>
</view>
</view>
</view>
<text class="self-start font text_5 mt-23">提供免费的服务</text>
</view>
<view class="flex-col section_8">
<view class="flex-row items-center section_9">
<image
class="shrink-0 image_4"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=0ee5b9f55ce6aef46d889234d99afe33.png"
/>
<view class="flex-col flex-1 ml-7">
<text class="self-start font_2 text_6">妆发服务</text>
<text class="mt-6 self-stretch font_5">
包括底妆眉毛眼妆腮红和唇妆根据您的肤色和服装风格进行个性化设计
</text>
<text class="mt-6 self-stretch font_5">
根据您的脸型和服装风格提供合适的发型设计包括但不限于编发盘发吹风造型等
</text>
</view>
</view>
<view class="flex-row items-center section_10">
<image
class="shrink-0 image_4"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=e853d682e2b7bbba7c02051808f75a0b.png"
/>
<view class="flex-col flex-1 ml-7">
<text class="self-start font_2 text_7">摄影服务</text>
<text class="mt-6 self-stretch font_5">
提供专业的摄影棚和灯光设备为客户打造舒适的拍摄环境
<br />
</text>
<text class="mt-6 self-stretch font_5">
拍摄完成后摄影师将精选照片进行后期处理包括色彩调整亮度优化瑕疵去除等
</text>
</view>
</view>
<view class="divider"></view>
<view class="flex-row section_11">
<image
class="shrink-0 self-center image_5"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=ca917a0e9fb6b228f113a8850988a754.png"
/>
<view class="flex-col shrink-0 self-start group_5">
<text class="self-start font_2 text_8">联系客服</text>
<text class="mt-10 self-stretch font_5">请提供详细的问题描述以便我们更快地为您解决问题</text>
</view>
<image
class="shrink-0 self-center image image_6"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=a36c51a83d47fe9c04ecc0b3af4443ad.png"
/>
</view>
<view class="flex-row justify-center items-center group_6">
<image
class="image_7"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=7857ecaca482cebbdd382382920634a0.png"
/>
<text class="ml-4 font_5 text_9">预约须知</text>
</view>
</view>
<view class="flex-row items-center section_12">
<view class="flex-row items-center shrink-0 group_7">
<view class="flex-col justify-start items-start shrink-0 relative">
<text class="text_10">预约费用</text>
</view>
<text class="text_11">88.</text>
<text class="text_13">00</text>
</view>
<view class="flex-row items-center flex-1 ml-51">
<view class="flex-row shrink-0 section_13">
<text class="text_14">费用说明</text>
<image
class="shrink-0 image_8 ml-3"
src="https://ide.code.fun/api/image?token=6714723d38a7c1001587fbb0&name=1a5714d6e445a76940d6217416bffd25.png"
/>
</view>
<view class="ml-10 flex-col justify-start items-center flex-1 text-wrapper">
<text class="font_4 text_12">确定预约</text>
</view>
</view>
</view>
</view>
</view>
</template>
<script setup>
</script>
<style lang="scss" scoped>
.ml-7 {
margin-left: 13.13rpx;
}
.ml-9 {
margin-left: 16.88rpx;
}
.mt-11 {
margin-top: 20.63rpx;
}
.ml-23 {
margin-left: 43.13rpx;
}
.mt-23 {
margin-top: 43.13rpx;
}
.ml-51 {
margin-left: 95.63rpx;
}
.ml-3 {
margin-left: 5.63rpx;
}
.page {
background-color: #ffffff;
height: 100%;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
}
.section {
padding-top: 45rpx;
background-color: #f5f5dc;
}
.group {
padding-top: 11.25rpx;
}
.section_2 {
margin-left: 71.25rpx;
background-color: #ffffff00;
border-radius: 18.75rpx;
width: 281.25rpx;
height: 281.25rpx;
}
.font {
font-size: 30rpx;
font-family: Open Sans;
line-height: 26.25rpx;
color: #323232;
}
.text {
line-height: 27.96rpx;
}
.pos {
position: absolute;
left: 21.62rpx;
top: 0;
}
.section_3 {
padding-left: 33.75rpx;
padding-right: 28.13rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.pos_2 {
position: absolute;
left: 20.63rpx;
right: 20.63rpx;
top: 53.63rpx;
}
.group_2 {
padding: 31.88rpx 0 15rpx;
border-bottom: solid 1.88rpx #e2e0e0;
}
.image {
width: 43.13rpx;
height: 43.13rpx;
}
.font_2 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 24rpx;
color: #323232;
}
.image_2 {
width: 33.75rpx;
height: 33.75rpx;
}
.group_3 {
padding: 22.5rpx 0 37.5rpx;
}
.font_3 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 31.88rpx;
color: #323232;
}
.group_4 {
margin-top: 26.25rpx;
padding: 0 30rpx;
}
.text_2 {
line-height: 27.69rpx;
}
.section_4 {
padding: 31.88rpx 0;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.equal-division {
margin: 0 41.25rpx;
}
.section_5 {
flex: 1 1 281.25rpx;
}
.image_3 {
width: 159.99rpx;
height: 159.99rpx;
}
.font_4 {
font-size: 30rpx;
font-family: Inter;
line-height: 26.25rpx;
color: #323232;
}
.text_3 {
line-height: 27.75rpx;
}
.section_6 {
position: relative;
flex: 1 1 281.25rpx;
}
.equal-division-item {
padding: 30rpx 0 41.25rpx;
background-color: #fff291;
border-radius: 18.75rpx;
height: 281.25rpx;
}
.text_4 {
margin-top: 18.75rpx;
}
.section_7 {
background-color: #ffffff99;
border-radius: 18.75rpx;
width: 281.25rpx;
height: 281.25rpx;
}
.pos_3 {
position: absolute;
left: 0;
right: 0;
top: 0;
bottom: 0;
}
.text_5 {
line-height: 27.79rpx;
}
.section_8 {
margin: 26.25rpx 0 100rpx 0;
padding: 28.13rpx 24.38rpx 0;
background-color: #fff3c3;
}
.section_9 {
margin: 0 7.5rpx;
padding: 33.75rpx 30rpx 26.25rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.image_4 {
border-radius: 9.38rpx;
width: 129.38rpx;
height: 166.88rpx;
}
.text_6 {
line-height: 24.3rpx;
}
.section_10 {
margin: 18.75rpx 7.5rpx 0;
padding: 30rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.text_7 {
line-height: 24.23rpx;
}
.divider {
margin-top: 39.38rpx;
background-color: #e3e3e3;
height: 1.88rpx;
}
.section_11 {
margin: 31.88rpx 7.5rpx 0;
padding: 15rpx 26.25rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.image_5 {
border-radius: 9.38rpx;
width: 93.75rpx;
height: 118.13rpx;
}
.group_5 {
margin-left: 22.5rpx;
margin-top: 15rpx;
width: 405rpx;
}
.text_8 {
line-height: 24.36rpx;
}
.image_6 {
margin-left: 48.75rpx;
}
.group_6 {
margin-top: 37.5rpx;
padding: 22.5rpx 0;
}
.image_7 {
width: 28.13rpx;
height: 28.13rpx;
}
.font_5 {
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 26.25rpx;
color: #898989;
}
.text_9 {
color: #000000;
line-height: 20.77rpx;
}
.section_12 {
position: fixed;
bottom: 0;
left: 0;
right: 0;
padding: 15rpx 22.5rpx;
background-color: #fffef8;
}
.group_7 {
width: 236.23rpx;
}
.text_10 {
color: #000000;
font-size: 26.25rpx;
font-family: Inter;
line-height: 24.28rpx;
}
.pos_4 {
position: absolute;
right: 0;
bottom: 0;
}
.text_11 {
color: #fbb612;
font-size: 33.75rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 24.84rpx;
}
.text_13 {
color: #fbb612;
font-size: 26.25rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 19.29rpx;
}
.section_13 {
padding: 9.38rpx 11.25rpx;
background-color: #d9d9d9;
border-radius: 9.38rpx;
height: 37.5rpx;
}
.text_14 {
color: #323232;
font-size: 18.75rpx;
font-family: Inter;
line-height: 17.36rpx;
}
.image_8 {
width: 18.75rpx;
height: 18.75rpx;
}
.text-wrapper {
padding: 26.25rpx 0;
background-color: #fbb612;
border-radius: 75rpx;
height: 82.5rpx;
}
.text_12 {
color: #ffffff;
line-height: 27.75rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -1,475 +0,0 @@
<template>
<view class="flex-col page">
<view class="flex-col flex-1 group_3">
<view class="flex-col relative group">
<view class="flex-col">
<view class="flex-col group_2">
<text class="self-start font text">场次</text>
<view class="mt-20 flex-col items-start self-stretch group_4">
<view class="flex-col justify-start text-wrapper">
<text class="font_2 text_2">上午场09:30-12:00</text>
</view>
<view class="mt-14 flex-col justify-start text-wrapper_2">
<text class="text_3">下午场13:00-16:00</text>
</view>
</view>
<view class="mt-20 self-stretch divider"></view>
<text class="mt-20 self-start font text_4">日期</text>
</view>
<view class="mt-22 flex-col">
<view class="flex-col justify-start self-start section">
<view class="flex-row equal-division">
<view class="flex-col items-center group_5 equal-division-item">
<text class="font_2 text_5">9</text>
<text class="font_3 mt-9">68.00</text>
</view>
<view class="flex-col items-center group_5 equal-division-item">
<text class="font_2 text_5">10</text>
<text class="font_3 mt-9">68.00</text>
</view>
<view class="flex-col items-center group_5 equal-division-item">
<text class="font_2 text_5">11</text>
<text class="font_3 mt-9">68.00</text>
</view>
<view class="flex-col items-center group_5 equal-division-item">
<text class="font_2 text_5">12</text>
<text class="font_3 mt-9">68.00</text>
</view>
</view>
</view>
<view class="mt-10 flex-row justify-between items-center self-stretch section_2">
<text class="font_4 text_6"></text>
<text class="font_5 text_12"></text>
<text class="font_5 text_7"></text>
<text class="font_5 text_8"></text>
<text class="font_5 text_9"></text>
<text class="font_5 text_10"></text>
<text class="font_4 text_11"></text>
</view>
</view>
</view>
<view class="flex-col">
<view class="grid">
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">1</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">2</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">3</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">4</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">5</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">6</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">7</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">8</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">9</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">10</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">11</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">12</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">13</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">14</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">15</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">16</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">17</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">18</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">19</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">20</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">21</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">22</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">23</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">24</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">25</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">26</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">27</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center grid-item">
<text class="font_6">余99</text>
<text class="font_7 mt-7">28</text>
<text class="font_8 mt-7">68.00</text>
</view>
</view>
<view class="flex-row mt-5">
<view class="flex-col items-center section_3">
<text class="font_6">余99</text>
<text class="font_7 text_13 mt-7">29</text>
<text class="font_8 mt-7">68.00</text>
</view>
<view class="flex-col items-center section_3 ml-5">
<text class="font_6">余99</text>
<text class="font_7 text_14 mt-7">30</text>
<text class="font_8 mt-7">68.00</text>
</view>
</view>
</view>
<view class="flex-row justify-between items-center group_6">
<text class="font">数量</text>
<view class="flex-row items-center">
<text class="text_15">一次限购100件</text>
<image
class="shrink-0 image_2"
src="https://codefun-proj-user-res-1256085488.cos.ap-guangzhou.myqcloud.com/66d02802d54496f19fd8b116/6705182d1511d900114a0a46/bd83ec79ae6ad0d4932c2e9d97aef3ef.png"
/>
<view class="flex-col justify-start items-center shrink-0 text-wrapper_3">
<text class="font_7 text_16">1</text>
</view>
<image
class="shrink-0 image_3"
src="https://codefun-proj-user-res-1256085488.cos.ap-guangzhou.myqcloud.com/66d02802d54496f19fd8b116/6705182d1511d900114a0a46/3d7428683bada7a94b84917c1f260b0e.png"
/>
</view>
</view>
</view>
<view class="flex-col justify-start section_4 mt-55">
<view class="flex-col justify-start items-center button text-wrapper_4"><text class="text_17">下一步</text></view>
</view>
</view>
</view>
</template>
<script>
</script>
<style lang="scss" scoped>
.mt-9 {
margin-top: 16.88rpx;
}
.mt-5 {
margin-top: 9.38rpx;
}
.ml-5 {
margin-left: 9.38rpx;
}
.mt-7 {
margin-top: 13.13rpx;
}
.mt-55 {
margin-top: 103.13rpx;
}
.page {
background-color: #fffef8;
border-radius: 37.5rpx 37.5rpx 0rpx 0rpx;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
}
.group_3 {
padding-bottom: 16.88rpx;
overflow-y: auto;
}
.group {
margin-top: -15rpx;
}
.group_2 {
padding: 0 31.88rpx;
}
.font {
font-size: 30rpx;
font-family: Times New Roman;
line-height: 27.69rpx;
color: #323233;
}
.text {
margin-left: 3.75rpx;
line-height: 27.51rpx;
}
.group_4 {
padding: 0 3.75rpx;
}
.text-wrapper {
padding: 18.75rpx 0;
background-color: #f3f3f3;
border-radius: 5.63rpx;
}
.font_2 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 22.01rpx;
color: #323233;
}
.text_2 {
margin-left: 15rpx;
margin-right: 11.25rpx;
line-height: 24.96rpx;
}
.text-wrapper_2 {
padding: 18.75rpx 0;
background-color: #fff4cd;
border-radius: 5.63rpx;
}
.text_3 {
margin-left: 15rpx;
margin-right: 11.25rpx;
color: #fcc600;
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 24.96rpx;
}
.divider {
background-color: #eaeaea;
height: 1.88rpx;
}
.text_4 {
margin-left: 7.5rpx;
line-height: 27.39rpx;
}
.section {
padding: 22.5rpx 0 15rpx;
background-color: #fffef8;
width: 538.13rpx;
}
.equal-division {
padding: 0 26.25rpx;
}
.group_5 {
flex: 1 1 120rpx;
}
.equal-division-item {
padding: 11.25rpx 0;
}
.text_5 {
line-height: 22.78rpx;
}
.font_3 {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 17.38rpx;
color: #fcc600;
}
.section_2 {
padding: 30rpx 41.25rpx 30rpx 45rpx;
background-color: #f5f5dc;
}
.font_4 {
font-size: 26.25rpx;
font-family: Times New Roman;
line-height: 22.01rpx;
color: #fcc600;
}
.text_6 {
line-height: 22.07rpx;
}
.font_5 {
font-size: 26.25rpx;
font-family: Times New Roman;
line-height: 22.01rpx;
color: #323233;
}
.text_12 {
line-height: 2.16rpx;
}
.text_7 {
line-height: 17.78rpx;
}
.text_8 {
line-height: 19.69rpx;
}
.text_9 {
line-height: 21rpx;
}
.text_10 {
line-height: 20.16rpx;
}
.text_11 {
line-height: 23.81rpx;
}
.grid {
height: 455.63rpx;
display: grid;
grid-template-rows: repeat(4, minmax(0, 1fr));
grid-template-columns: repeat(7, minmax(0, 1fr));
row-gap: 11.38rpx;
column-gap: 0;
}
.grid-item {
padding: 18.75rpx 0;
background-color: #fffef8;
border-radius: 5.63rpx;
}
.font_6 {
font-size: 15rpx;
font-family: Open Sans;
line-height: 13.76rpx;
color: #323233;
}
.font_7 {
font-size: 30rpx;
font-family: Open Sans;
line-height: 22.01rpx;
color: #323233;
}
.font_8 {
font-size: 15rpx;
font-family: Open Sans;
line-height: 11.08rpx;
color: #323233;
}
.section_3 {
padding: 15rpx 0;
background-color: #fffef8;
border-radius: 5.63rpx;
width: 101.25rpx;
height: 106.88rpx;
}
.text_13 {
line-height: 22.03rpx;
}
.text_14 {
line-height: 22.05rpx;
}
.group_6 {
margin-top: 52.5rpx;
padding-left: 37.5rpx;
padding-right: 28.13rpx;
}
.text_15 {
color: #818181;
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 20.72rpx;
}
.image_2 {
margin-left: 11.25rpx;
border-radius: 5.63rpx 0rpx 0rpx 5.63rpx;
width: 52.5rpx;
height: 52.5rpx;
}
.text-wrapper_3 {
padding: 15rpx 0;
background-color: #f5f5dc;
width: 52.5rpx;
height: 52.5rpx;
}
.text_16 {
color: #000000;
line-height: 21.41rpx;
}
.image_3 {
border-radius: 0rpx 5.63rpx 5.63rpx 0rpx;
width: 52.5rpx;
height: 52.5rpx;
}
.section_4 {
padding: 22.5rpx 0;
background-color: #ffffff;
}
.button {
margin: 0 45rpx;
}
.text-wrapper_4 {
padding: 22.5rpx 0;
background-color: #fbb612;
border-radius: 93.75rpx;
}
.text_17 {
color: #ffffff;
font-size: 30rpx;
font-family: Inter;
font-weight: 700;
line-height: 28.2rpx;
}
@import url(../../common/css/global.css);
</style>

View File

@ -1,266 +0,0 @@
<template>
<view class="flex-col justify-start page">
<view class="flex-col section">
<view class="flex-col group">
<view class="flex-col relative section_2">
<view class="flex-row justify-center items-baseline self-stretch relative group_2">
<text class="font text pos">精致体验</text>
<text class="font_2 text_2">融合时尚与传统精选非遗华章</text>
</view>
<text class="self-start font_3 text_3">服装特点</text>
<view class="flex-col items-start self-stretch group_3">
<text class="font_2">提供更为精致的汉服款式如刺绣襦裙改良旗袍等</text>
<text class="mt-2 font_2">服装细节丰富面料上乘适合追求品质的用户</text>
<text class="mt-2 font_2">配饰精美增添拍摄效果</text>
</view>
<text class="self-start font_3 text_4">服务内容</text>
<view class="flex-col items-start self-stretch group_4">
<text class="font_2">高级化妆及发型设计</text>
<text class="mt-2 font_2">服装租赁服务</text>
<text class="mt-2 font_2">专业摄影服务含5张精修照片</text>
</view>
<image
class="image pos_2"
src="https://ide.code.fun/api/image?token=6711f04f38a7c1001587de59&name=9462be138086344171b159fb470bb8e3.png"
/>
</view>
<view class="mt-12 flex-col section_3">
<text class="self-start font text_5">服装选择</text>
<view class="flex-col self-stretch mt-11">
<view class="flex-row items-center mt-10 list-item" v-for="(item, index) in items" :key="index">
<image
class="shrink-0 image_3"
src="https://ide.code.fun/api/image?token=6711f04f38a7c1001587de59&name=45ad24ebaf7ffeee80d7804168b1c012.png"
/>
<view class="flex-col flex-1 ml-11">
<view class="flex-col self-stretch">
<view class="flex-row justify-end self-stretch group_5">
<text class="font_4">详细信息</text>
<image
class="image_2"
src="https://ide.code.fun/api/image?token=6711f04f38a7c1001587de59&name=1484e0cc6274180ba7c91cddf1ec833b.png"
/>
</view>
<text class="self-start font_5 text_6 mt-3">锦绣中华系列汉服</text>
</view>
<view class="self-stretch group_6 mt-5">
<text class="font_7">服装简介</text>
<text class="font_6">
瑞凤呈祥以凤凰为主题象征着吉祥和谐与美好交领的设计端庄大气展现东方女性的温婉气质直裾流畅行走间尽显风华衣襟上的凤凰图案...
</text>
</view>
<text class="self-end font_8 mt-5">350</text>
</view>
</view>
</view>
</view>
</view>
<view class="mt-48 flex-row">
<view class="flex-col items-center shrink-0 section_4">
<image
class="image_4"
src="https://ide.code.fun/api/image?token=6711f04f38a7c1001587de59&name=4b56fed14a39630ca2312edf6e34c024.png"
/>
<text class="mt-2 text_8">客服</text>
</view>
<view class="flex-col justify-start items-end flex-1 section_5">
<view class="flex-col justify-start items-center text-wrapper"><text class="text_7">现在去预约</text></view>
</view>
</view>
</view>
</view>
</template>
<script>
</script>
<style lang="scss" scoped>
.mt-11 {
margin-top: 20.63rpx;
}
.ml-11 {
margin-left: 20.63rpx;
}
.mt-3 {
margin-top: 5.63rpx;
}
.mt-5 {
margin-top: 9.38rpx;
}
.page {
background-color: #ffffff;
height: 100%;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
}
.section {
padding-top: 22.5rpx;
background-color: #f5f5dc;
}
.group {
padding: 0 16.88rpx;
}
.section_2 {
padding: 37.5rpx 41.25rpx 30rpx;
background-color: #ffe8e8;
border-radius: 18.75rpx 18.75rpx 0rpx 0rpx;
}
.group_2 {
padding-top: 7.5rpx;
}
.font {
font-size: 30rpx;
font-family: Open Sans;
}
.text {
color: #323232;
line-height: 27.9rpx;
}
.pos {
position: absolute;
left: 0.13rpx;
top: 50%;
transform: translateY(-50%);
}
.font_3 {
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #323232;
}
.text_3 {
margin-top: 22.5rpx;
line-height: 20.79rpx;
}
.group_3 {
margin-top: 15rpx;
padding: 0 22.5rpx;
}
.font_2 {
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 26.25rpx;
color: #696969;
}
.text_2 {
line-height: 21.38rpx;
}
.text_4 {
margin-top: 24.38rpx;
line-height: 20.77rpx;
}
.group_4 {
margin-top: 15rpx;
padding: 0 24.38rpx;
}
.image {
width: 127.5rpx;
height: 127.5rpx;
}
.pos_2 {
position: absolute;
right: 7.5rpx;
bottom: 15rpx;
}
.section_3 {
padding: 37.5rpx 30rpx;
background-color: #fffef8;
border-radius: 18.75rpx;
}
.text_5 {
color: #000000;
line-height: 27.71rpx;
}
.list-item {
padding: 22.5rpx 22.5rpx 22.5rpx 30rpx;
background-color: #fff3c3;
border-radius: 9.38rpx;
}
.list-item:first-child {
margin-top: 0;
}
.image_3 {
border-radius: 9.38rpx;
width: 148.13rpx;
height: 165rpx;
}
.group_5 {
padding: 0 3.75rpx;
}
.font_4 {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 17.44rpx;
color: #323232;
}
.image_2 {
width: 15rpx;
height: 15rpx;
}
.font_5 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #323232;
}
.text_6 {
line-height: 24.26rpx;
}
.group_6 {
line-height: 22.5rpx;
}
.font_7 {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #323232;
}
.font_6 {
font-size: 18.75rpx;
font-family: Open Sans;
line-height: 22.5rpx;
color: #828282;
}
.font_8 {
font-size: 33.75rpx;
font-family: Times New Roman;
line-height: 24.73rpx;
color: #ff3c3c;
}
.section_4 {
padding: 15rpx 0;
background-color: #ffc470;
width: 118.13rpx;
height: 114.38rpx;
}
.image_4 {
width: 52.5rpx;
height: 52.5rpx;
}
.text_8 {
color: #fffef8;
font-size: 26.25rpx;
font-family: Inter;
line-height: 24.17rpx;
}
.section_5 {
padding: 15rpx 0;
background-color: #fffef8;
height: 114.38rpx;
}
.text-wrapper {
margin-right: 20.63rpx;
padding: 26.25rpx 0;
background-color: #fbb612;
border-radius: 75rpx;
width: 457.5rpx;
}
.text_7 {
color: #ffffff;
font-size: 30rpx;
font-family: Inter;
line-height: 27.86rpx;
}
@import url(@import url(../../../common/css/global.css););
</style>

View File

@ -1,501 +0,0 @@
<template>
<view class="flex-row relative page">
<image
class="image pos"
:src="good.url"
/>
<view class="flex-col section pos_2">
<view class="flex-row items-baseline self-stretch group">
<text class="text">{{good.price}}</text>
<text class="text_2">积分</text>
</view>
<text class="mt-10 self-start font text_3">{{good.name}}</text>
<text class="mt-10 self-start text_4">{{good.type}}</text>
<view class="mt-10 flex-row justify-between self-stretch group_2">
<view class="flex-row group_3">
<text class="font_2 text_6">创客实验室</text>
<text class="font_2 text_5">权益提供方-</text>
</view>
<view class="flex-row items-baseline group_4">
<text class="font_2 text_7">已兑换</text>
<text class="ml-4 font_2 text_8">{{good.sales}}</text>
<text class="ml-4 font_2 text_9"></text>
</view>
</view>
</view>
<view class="flex-col section_2 pos_3">
<view class="flex-row justify-between items-center" @click="jumpToChange">
<view class="flex-row items-baseline">
<text class="font_3">已选 :</text>
<text class="font text_10">{{good.name}},</text>
<text class="font text_11">{{changeCnt}}</text>
<text class="font"></text>
</view>
<image
class="image_2"
:src="PointsMallImgUrl + 'payOrder/yjt.png'"
/>
</view>
<view class="flex-row justify-between items-center mt-27" @click="jumpToAddress">
<view class="flex-row">
<text class="font_3 text_12">送至 :</text>
<text class="ml-14 font_3 text_13">{{tempAddress}}</text>
</view>
<image
class="image_2"
:src="PointsMallImgUrl + 'payOrder/yjt.png'"
/>
</view>
</view>
<view class="flex-col section_3 pos_4">
<text class="self-start font text_14">商品详情</text>
<view class="mt-12 flex-col self-stretch group_5">
<text class="self-stretch font text_15">
{{good.detail}}
</text>
<image
mode="aspectFit"
class="shrink-0 self-center image_3"
:src="good.url"
/>
</view>
</view>
<view class="flex-col justify-start section_4 pos_5">
<view class="flex-row justify-center items-center button section_5" @click="cPop">
<text class="text_16">{{changePrice}}</text>
<text class="ml-4 font text_17">积分兑换</text>
</view>
</view>
</view>
<uni-popup ref="popup" background-color="#fff" @change="change">
<view class="popup-content">
<addressVue></addressVue>
</view>
</uni-popup>
<uni-popup ref="change" background-color="#fff" @change="change">
<view class="popup-content">
<changeVue :good="good"></changeVue>
</view>
</uni-popup>
<uni-popup ref="alertDialog" type="dialog">
<view class="pop">
<popupVue></popupVue>
</view>
</uni-popup>
<uni-popup ref="cAlertDialog" type="dialog">
<view class="pop">
<cPopupVue :changePrice="changePrice"></cPopupVue>
</view>
</uni-popup>
<uni-popup ref="success" type="dialog">
<view class="pop">
<changeSuccessVue></changeSuccessVue>
</view>
</uni-popup>
</template>
<script lang="ts" setup>
import { DomainName, PointsMallImgUrl } from '../../../common/global';
import {onMounted, ref} from 'vue'
import addressVue from '../component/address.vue'
import emitter from '../../../utils/emitter'
import popupVue from '../component/popup.vue';
import changeVue from '../component/change.vue';
import cPopupVue from '../component/cPopup.vue';
import changeSuccessVue from '../component/changeSuccess.vue';
import { onLoad } from "@dcloudio/uni-app";
import { userInfoStore } from '../../../store/user';
const userStore = userInfoStore()
const good = ref([])
const changePrice = ref(0)
const changeCnt = ref(1)
const tempAddress = ref('请输入/选择地址')
const realAddress = ref('')
const addId = ref(0)
onLoad((options) => {
good.value = JSON.parse(options.good)
changePrice.value = good.value.price
console.log(good.value)
})
const getDefaultAddress = async () => {
const res = await uni.request({
url: DomainName + '/change/queryUserDefaultAddress',
method: 'GET',
data: {
id: userStore.user.id
}
})
if(res.data.data != null){
addId.value = res.data.data.id
realAddress.value = (res.data.data.region + ' ' + res.data.data.detailAddress).split('/').join('')
tempAddress.value = (res.data.data.region + ' ' + res.data.data.detailAddress).split('/').join('')
if(tempAddress.value.length > 14)
tempAddress.value = tempAddress.value.slice(0, 14) + '...'
}
}
const pointsChangeGoods = async () => {
if(tempAddress.value == '请输入/选择地址'){
uni.showToast({
title: '请选择地址',
icon: 'fail'
})
return ;
}
const res = await uni.request({
url: DomainName + '/change/pointsChangeGoods',
method: 'POST',
data: {
orderDate: getDate(),
goodId: good.value.id,
addressId: addId.value,
quantity: changeCnt.value,
userId: userStore.user.id
}
})
console.log(res)
if(res.data.code == '200'){
successPop()
}else{
uni.showToast({
title: '积分不足',
icon: 'fail'
})
}
}
onMounted(() => {
emitter.on('open', () => {
open()
})
emitter.on('close', () => {
close()
})
emitter.on('pop', () => {
pop()
})
emitter.on('cClose', (obj:any) => {
cClose(obj)
})
emitter.on('cPopClose', () => {
cPopClose()
})
emitter.on('successPop', () => {
successPop()
})
emitter.on('popClose', () => {
popClose()
})
emitter.on('cPop', () => {
cPop()
})
emitter.on('changeGoods', () => {
pointsChangeGoods()
})
emitter.on('addId', (val:any) => {
addId.value = val
})
emitter.on('addAddressOrder', (val:any) => {
realAddress.value = val
tempAddress.value = val
if(tempAddress.value.length > 14)
tempAddress.value = tempAddress.value.slice(0, 14) + '...'
})
getDefaultAddress()
})
const jumpToAddress = () => {
open()
}
const popup = ref(null)
const open = () => {
popup.value.open('bottom')
}
const close = () => {
popup.value.close()
}
const jumpToChange = () => {
cOpen()
}
const change = ref(null)
const cOpen = () => {
change.value.open('bottom')
}
const cClose = (obj:any) => {
if(obj.confirm){
changePrice.value = obj.cnt * good.value.price
changeCnt.value = obj.cnt
}
change.value.close()
}
const alertDialog = ref(null)
const cAlertDialog = ref(null)
const success = ref(null)
const successPop = () => {
success.value.open()
}
const pop = () => {
alertDialog.value.open()
}
const popClose = () => {
alertDialog.value.close()
}
const cPop = () => {
cAlertDialog.value.open()
}
const cPopClose = () => {
cAlertDialog.value.close()
}
const getDate = () => {
let now = new Date()
let year = now.getFullYear()
let month = (now.getMonth() + 1).toString().padStart(2, 0)
let date = now.getDate().toString().padStart(2, 0)
return year + '-' + month + '-' + date
}
</script>
<style lang="scss" scoped>
.pop{
height: 500rpx;
}
.popup-content {
height: 392px;
align-items: center;
justify-content: center;
padding: 30rpx;
background-color: #fff;
}
.section, .section_2, .section_3{
margin-top: 50rpx;
}
.mt-27 {
margin-top: 63.28rpx;
}
.page {
padding: 614.06rpx 37.5rpx 173.44rpx;
background-color: #f3f3f6;
mix-blend-mode: LUMINOSITY;
height: 2135.16rpx;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
.image {
width: 100vw;
height: 81.875vw;
}
.pos {
position: absolute;
left: 0;
right: -2.34rpx;
top: 0;
}
.section {
padding-top: 37.5rpx;
background-color: #ffffff;
border-radius: 23.44rpx;
.group {
padding: 0 37.5rpx;
.text {
color: #00ba9c;
font-size: 56.25rpx;
font-family: Times New Roman;
font-weight: 700;
line-height: 38.79rpx;
}
.text_2 {
color: #00ba9c;
font-size: 30.47rpx;
font-family: Rockwell Condensed;
line-height: 27.91rpx;
}
}
.text_3 {
margin-left: 28.13rpx;
line-height: 34.64rpx;
}
.text_4 {
margin-left: 28.13rpx;
color: #454e6c;
font-size: 32.81rpx;
font-family: Open Sans;
line-height: 30.33rpx;
}
.group_2 {
padding: 37.5rpx 18.75rpx;
border-top: solid 2.34rpx #e5e5e5;
.group_3 {
width: 295.29rpx;
margin-top: 0;
.text_6 {
margin-left: 150rpx;
color: #000000;
}
.text_5 {
margin-left: -295.31rpx;
}
}
.group_4 {
margin-right: 9.38rpx;
.text_7 {
line-height: 25.97rpx;
}
.text_8 {
line-height: 20.67rpx;
}
.text_9 {
line-height: 25.76rpx;
}
}
.font_2 {
font-size: 28.13rpx;
font-family: Open Sans;
line-height: 26.04rpx;
color: #454e6c;
}
}
}
.pos_2 {
position: absolute;
left: 37.5rpx;
right: 35.16rpx;
top: 614.06rpx;
}
.section_2 {
padding: 28.13rpx 23.44rpx 32.81rpx 32.81rpx;
background-color: #ffffff;
border-radius: 23.44rpx;
.font_3 {
font-size: 30.5rpx;
font-family: Open Sans;
line-height: 34.36rpx;
color: #9ca1b1;
}
.text_10 {
margin-left: 23.44rpx;
line-height: 36.49rpx;
}
.text_11 {
margin-left: 9.38rpx;
line-height: 27.16rpx;
}
.image_2 {
width: 30.47rpx;
height: 30.47rpx;
}
.text_12 {
line-height: 34.2rpx;
}
.text_13 {
line-height: 34.69rpx;
}
}
.pos_3 {
position: absolute;
left: 37.5rpx;
right: 35.16rpx;
top: 50%;
transform: translateY(-50%);
}
.font {
// font-size: 37.5rpx;
font-family: Open Sans;
line-height: 34.36rpx;
color: #000000;
}
.section_3 {
padding: 37.5rpx 37.5rpx 42.19rpx;
background-color: #ffffff;
border-radius: 23.44rpx;
.text_14 {
line-height: 34.62rpx;
}
.group_5 {
margin-right: 14.06rpx;
.text_15 {
line-height: 46.88rpx;
word-break: break-all;
}
.image_3 {
margin-top: -9.38rpx;
width: 349.22rpx;
height: 339.84rpx;
}
}
}
.pos_4 {
position: absolute;
left: 37.5rpx;
right: 35.16rpx;
top: 1200rpx;
}
.section_4 {
padding: 25.78rpx 0 39.84rpx;
background-color: #ffffff;
.button {
margin: 0 46.88rpx;
.text_16 {
color: #ffffff;
font-size: 37.5rpx;
font-family: Times New Roman;
font-weight: 700;
line-height: 25.85rpx;
}
.text_17 {
color: #ffffff;
font-weight: 700;
line-height: 35.55rpx;
}
}
.section_5 {
padding: 23.44rpx 0;
background-color: #00ba9c;
border-radius: 117.19rpx;
}
}
.pos_5 {
position: fixed;
left: 0;
right: -2.34rpx;
bottom: 0;
}
}
@import url('../css/global2.css');
</style>

View File

@ -1,561 +0,0 @@
<template>
<!-- 弹窗 -->
<uni-popup ref="popup1" v-if="showPopup1" :mask-click="false" background-color="white">
<view style="text-align: center;margin: 10px;font-size: 18px;">预约须知</view>
<view style="margin: 0 20px;">1.成功预约的顾客需按照预定时间前往店内挑选相应级别的服装
为确保衣物在体验过程中的完好无损顾客需根据所选服装的级别补缴尾款以及相应的押金
拍摄结束后店铺将依据衣物的实际状况评估是否扣除押金</view>
<view style="margin: 0 20px;">
2.其中部分物品商家可提供属于增值服务如一次性隐形眼镜
一次性粉扑等属于服务费以外的赠送服务买家可选择自带用品不影响服务价格
需要买家自己准备的客服需要提前告诉买家如胸贴等贴身物品
</view>
<button @click="close1" style="width: 50%;background-color:#f2b600;border-radius: 30px;margin-top: 20px;
margin-bottom: 20px;">我知道了</button>
</uni-popup>
<uni-popup ref="popup2" v-if="showPopup2" :mask-click="false" background-color="white">
<scroll-view style="height: 400px;width: 100%;" scroll-y="true">
<view style="text-align: center;margin: 10px;font-size: 18px;">费用说明</view>
<view style="margin: 10px;"> 费用支付流程</view>
<view style="margin: 0 20px;">
<view>1.确定等级您将根据个人需求选择合适的服装价位区间并完成预约操作</view>
<view>2.预约成功预约成功后您需前往店铺挑选对应等级的服装</view>
<view>3.补缴尾款及押金在挑选服装时您需要补缴尾款扣除已支付定金后的剩余服务或商品费用以及押金用于保障服装归还时的完好</view>
</view>
<view style="margin: 10px;"> 尾款具体事项</view>
<view style="margin: 0 20px;">
<view>1.租赁服装若您选择租赁我们店铺没有的服装租赁费用将在您支付尾款时一并结算无论拍摄是否进行租赁费用均不予退还</view>
<view>2.购买服装如您希望购买我们店铺的服装且我们同意购买将按照服装的稀有程度分等级定价您需按照所选等级支付尾款</view>
<view>3.定制服务若您自带衣服我们提供妆发及摄影服务若需我们额外购买服装将按照上述等级定价您需支付相应的尾款</view>
</view>
<view style="margin: 10px;"> 定金与押金说明</view>
<view style="margin: 0 20px;">
<view>1.定金预约时支付的定金用于确认您的预约意向定金不予退还</view>
<view>2.押金拍摄完成后我们将根据服装的归还情况决定是否扣除押金若服装无损坏押金将全额退还</view>
</view>
<view style="margin: 10px;"> 特殊情况处理</view>
<view style="margin: 0 20px;">
<view> 若因特殊情况您需要取消预约请及时与我们联系未拍摄情况下定金不予退还已支付的租赁费用亦不退还</view>
</view>
</scroll-view>
<button @click="close2" style="width: 50%;background-color:#f2b600;border-radius: 30px;margin-top: 20px;
margin-bottom: 20px;">我知道了</button>
</uni-popup>
<view class="flex-col justify-start relative page">
<view class="section"></view>
<text class="font text pos">选择预约类别</text>
<view class="flex-row equal-division group">
<view class="flex-col equal-division-item section_2" @click="showWhole('0')">
<image class="self-start image"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FQrbJhlbu-zhengtaoyuepai.png" />
<text class="self-center font mt-7">整套约拍</text>
</view>
<view class="ml-48 flex-col equal-division-item section_3" @click="showWhole('1')">
<image class="self-start image"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FvEBBpzOI-zidaifuzhuang.png" />
<text class="mt-8 self-center font text_2">自带服装</text>
</view>
</view>
<template v-if="zhi === '0'">
<text class="font text_3 pos_2">选择服装类别</text>
<view class="flex-col section_4 pos_3">
<view class="flex-col list">
<view class="flex-row justify-between section_5" v-for="(item,index) in Whole" :key="item"
@click="goToText(index)">
<view class="flex-row items-end self-center">
<image class="image_2" :src="item.image" />
<view class="ml-20 flex-col group_2">
<text class="self-start font_2 text_4">{{item.clothesType}}</text>
<view class="flex-row items-center self-stretch group_3">
<view class="group_4">
<text class="font_2">价位</text>
<text class="font_4"></text>
</view>
<text class="ml-6 font_3 text_5">{{item.minPrice}}-{{item.maxPrice}}</text>
</view>
<text class="self-stretch font_5 text_6">{{item.brief}}</text>
</view>
</view>
<image class="self-start image_3 image_4"
src="https://ide.code.fun/api/image?token=675fbf94797f850011f2bedf&name=eee721f36de3196113485ea7e5c6b5ad.png" />
</view>
</view>
</view>
</template>
<template v-if="zhi === '1'">
<text class="font text_3 pos_2">选择服务</text>
<view class="flex-col section_4 pos_3">
<view class="flex-col list">
<view class="flex-row justify-between section_5"v-for="(item,index) in Own" :key="item">
<view class="flex-row items-end self-center">
<image class="image_2" :src="item.img" />
<view class="ml-20 flex-col group_2">
<text class="self-start font_2 text_4">{{item.name}}</text>
<text class="font_33 text_55">{{item.title}}</text>
</view>
</view>
<!-- <view style="background-color: #f2b600;width: 200rpx;"> -->
<view class="flex-row self-stretch mt-104" style="width: 150rpx;">
<view class="flex-col justify-start items-center image-wrapper_2" @click="add(index)">
-
</view>
<view class="ml-2 flex-col justify-start items-center text-wrapper-6" style="margin-left: 8px;margin-right: 8px;">
{{ item.num }}</view>
<view class="ml-2 flex-col justify-start items-center image-wrapper_3" @click="jian(index)">
+
</view>
</view>
<!-- </view> -->
</view>
</view>
</view>
</template>
<view class="mt-22 flex-row justify-between items-center section_9">
<view class="flex-row">
<image class="shrink-0 self-center image_9"
src="https://ide.code.fun/api/image?token=675fbf94797f850011f2bedf&name=0ed6323496056f793bd3c25b3dcd9eb6.png" />
<text class="self-start text_15">88.</text>
<text class="self-center font_2 text_14">定金</text>
<text class="self-center text_17">00</text>
<view class="flex-row shrink-0 section_10" @click="openPopup2">
<text class="text_18">费用说明</text>
<image class="shrink-0 image_10 ml-3"
src="https://ide.code.fun/api/image?token=675fbf94797f850011f2bedf&name=0455b173571a47fdc438588e788f26c5.png" />
</view>
</view>
<view class="flex-col justify-start items-center text-wrapper"><text class="font text_16">确定预约</text>
</view>
</view>
</view>
</template>
<script setup>
import {
ref,
onMounted
} from 'vue'
import {
baseUrl
} from '@/api/request'
const items = ref([null, null, null, null]);
onMounted(() => {
getWhole()
})
const displayItem = ref([])
const Whole = ref([{}])
const getWhole = async () => {
const res = await uni.request({
url: baseUrl + '/clothesGrade/list',
method: 'POST',
header: {
cookie: wx.getAccountInfoSync('cookie')
},
data: {
}
})
if (res.data.code === 1) {
Whole.value = res.data.data
} else {
uin.showtoast({
icon: 'error',
title: '获取失败'
})
}
}
const Own = ref([{
img: 'https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FObQGBPnJ-zhuangfa.png',
name: '妆发预约',
num:0,
title: '包括底妆,眉毛,眼妆,腮红和唇妆,根据您的肤色和服装风格进行个性化设计'
},
{
img: 'https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FDFNymmCN-sheying.png',
name: '摄影服务',
num:0,
title: '提供专业的摄影棚和灯光设备,为客户打造舒适的拍摄环境'
}
])
const zhi = ref('0')
const showWhole = (zhiValue) => {
zhi.value = zhiValue
// console.log(zhi.value)
}
const showOwn = (zhiValue) => {
zhi.value = zhiValue
// console.log(zhi.value)
}
const close1 = () => {
popup1.value.close()
}
const close2 = () => {
popup2.value.close()
}
const popup1 = ref(null)
const popup2 = ref(null)
const showPopup1 = ref(false)
const showPopup2 = ref(false)
const openPopup1 = () => {
showPopup1.value = true;
popup1.value.open('center');
}
const openPopup2 = () => {
showPopup2.value = true;
popup2.value.open('center');
}
const closePopup1 = () => {
showPopup1.value = false;
}
const closePopup2 = () => {
showPopup2.value = false;
}
const selectedLocation = ref(null)
const handleFormSubmit = () => {
selectedLocation.value = null
}
//
const handleLocationChange = (e) => {
selectedLocation.value = e.detail.value
console.log(selectedLocation.value)
}
const goToText = (index) => {
console.log(index)
uni.navigateTo({
url: "/pages/booking/CostumeDisplay/CostumeDisplay?info=" + JSON.stringify(Whole.value[index].id)
});
console.log(Whole.value[index].id)
}
const goToContact = () => {
uni.navigateTo({
url: '/pages/mine/Contact/Contact'
})
}
//
const add = (index) => {
if(Own.value[index].num >0){
Own.value[index].num -= 1
}
}
const jian = (index) => {
Own.value[index].num += 1
}
</script>
<style lang="scss" scoped>
.mt-104 {
margin-top: 60rpx;
margin-right: 10rpx;
}
.image-wrapper_2 {
padding: 11.25rpx 0;
background-color: #f8dedf;
border-radius: 5.63rpx 0rpx 0rpx 5.63rpx;
width: 52.5rpx;
height: 52.5rpx;
}
.text-wrapper_6 {
padding: 15rpx 0 11.25rpx;
background-color: #f5f5dc;
width: 52.5rpx;
height: 52.5rpx;
}
.image-wrapper_3 {
padding: 11.25rpx 0;
background-color: #f8dedf;
border-radius: 0rpx 5.63rpx 5.63rpx 0rpx;
width: 52.5rpx;
height: 52.5rpx;
}
.image_33 {
width: 33.75rpx;
height: 33.75rpx;
}
.mt-7 {
margin-top: 13.13rpx;
}
.ml-3 {
margin-left: 5.63rpx;
}
.font_33 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.13rpx;
color: #8a8a8a;
}
.text_55 {
margin-top: 26.25rpx;
line-height: 26.25rpx;
width: 280rpx;
}
.font_7 {
font-size: 22.5rpx;
font-family: Open Sans;
line-height: 20.72rpx;
color: #8a8a8a;
}
.text_9 {
line-height: 21.36rpx;
}
.mt-11 {
margin-top: 20.63rpx;
}
.page {
background-color: #ffffff;
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 {
background-image: url('https://ide.code.fun/api/image?token=675fbf94797f850011f2bedf&name=17e1ca160ffb13e8723517aa1cebf07e.png');
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;
height: 1728.75rpx;
}
.equal-division {
position: absolute;
left: 50%;
top: 136.88rpx;
transform: translateX(-50%);
}
.group {
width: 650.63rpx;
}
.image {
width: 192rpx;
height: 192rpx;
}
.equal-division-item {
flex: 1 1 279.38rpx;
}
.section_2 {
padding: 7.5rpx 26.25rpx 41.25rpx;
opacity: 0.85;
background-color: #ffffff;
border-radius: 18.75rpx;
height: 281.25rpx;
}
.section_3 {
padding: 7.5rpx 22.5rpx 41.25rpx;
background-color: #ffffffcc;
border-radius: 18.75rpx;
height: 281.25rpx;
}
.font {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 28.59rpx;
color: #323232;
}
.text {
line-height: 27.69rpx;
}
.pos {
position: absolute;
left: 31.35rpx;
top: 49.84rpx;
}
.text_2 {
line-height: 29.42rpx;
}
.text_3 {
line-height: 28.84rpx;
}
.pos_2 {
position: absolute;
left: 48.06rpx;
top: 537.66rpx;
}
.section_4 {
background-color: #ffffff6c;
border-radius: 37.5rpx 37.5rpx 0 0;
}
.pos_3 {
position: absolute;
left: 0;
right: 0;
top: 581.25rpx;
}
.list {
padding: 50.63rpx 45rpx;
}
.section_5 {
margin-right: 15rpx;
padding: 13.13rpx 3.75rpx 37.5rpx 43.13rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
margin: 5px;
}
.image_2 {
border-radius: 9.38rpx;
width: 118.13rpx;
height: 151.88rpx;
}
.group_2 {
margin-bottom: 3.75rpx;
}
.font_2 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 24.3rpx;
color: #323232;
}
.text_4 {
line-height: 25.43rpx;
}
.group_3 {
margin-top: 26.25rpx;
}
.group_4 {
line-height: 24.3rpx;
height: 24.3rpx;
}
.font_4 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 16.8rpx;
color: #323232;
}
.font_3 {
font-size: 33.75rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 24.3rpx;
color: #ff3c3c;
}
.text_5 {
line-height: 22.54rpx;
}
.image_3 {
width: 35.63rpx;
height: 37.5rpx;
}
.image_4 {
margin-top: 67.5rpx;
}
.font_5 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 21.98rpx;
color: #898989;
}
.text_6 {
margin-top: 7.5rpx;
line-height: 22.24rpx;
}
.section_9 {
padding: 39.38rpx 30rpx 13.13rpx;
background-color: #ffffff;
position: fixed;
bottom: 0;
width: 100%;
}
.image_9 {
margin-left: 67.5rpx;
width: 33.75rpx;
height: 33.75rpx;
}
.text_15 {
color: #fb1212;
font-size: 33.75rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 24.84rpx;
}
.text_14 {
margin-left: -146.25rpx;
color: #000000;
line-height: 24.09rpx;
}
.text_17 {
margin-left: 75rpx;
color: #fb1212;
font-size: 26.25rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 19.29rpx;
}
.section_10 {
margin-left: 26.25rpx;
padding: 7.5rpx 11.25rpx;
background-color: #d9d9d9;
border-radius: 9.38rpx;
height: 37.5rpx;
}
.text_18 {
color: #323232;
font-size: 18.75rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 18.32rpx;
}
.image_10 {
width: 18.75rpx;
height: 18.75rpx;
}
.text-wrapper {
padding: 26.25rpx 0;
background-color: #e79ea1;
border-radius: 75rpx;
width: 238.13rpx;
height: 82.5rpx;
}
.text_16 {
color: #ffffff;
line-height: 28.01rpx;
}
@import url(/common/css/global.css);
</style>

View File

@ -12,7 +12,7 @@
<view class="flex-col items-center group" @click="jumpToTips">
<image
class="image"
src="https://ide.code.fun/api/image?token=67bd70bf4ae84d0012272c1a&name=91726e3d2a00b43be59bc02bdb123c41.png"
:src="couponUrl + '/CouponMall/jf.png'"
/>
<text class="text_4 mt-7">规则</text>
</view>
@ -52,7 +52,9 @@
import confirmPopupVue from '../component/confirmPopup.vue';
import popupVue from '../../popup.vue';
import emitter from '../../../utils/emitter';
import { couponUrl } from '../../../common/globalImagesUrl';
const cookie = wx.getStorageSync("cookie") //
const couponList = ref([])
const points = ref(0)
const exchange = ref(null)
@ -175,7 +177,7 @@
}
.page {
background-color: #ffffff;
background-image: url('https://ide.code.fun/api/image?token=67bd70bf4ae84d0012272c1a&name=776298fdb18de84cb191f66e4d22ba7a.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/coupon/CouponMall/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
@ -184,7 +186,7 @@
height: 100%;
}
.section {
background-image: url('https://ide.code.fun/api/image?token=67bd70bf4ae84d0012272c1a&name=776298fdb18de84cb191f66e4d22ba7a.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/coupon/CouponMall/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;

View File

@ -27,7 +27,7 @@
<style scoped lang="scss">
.page {
background-color: #ffffff;
background-image: url('https://ide.code.fun/api/image?token=67bd70bf4ae84d0012272c1a&name=776298fdb18de84cb191f66e4d22ba7a.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/coupon/CouponTips/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
@ -41,7 +41,7 @@
}
.section {
background-image: url('https://ide.code.fun/api/image?token=67bd70bf4ae84d0012272c1a&name=776298fdb18de84cb191f66e4d22ba7a.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/coupon/CouponTips/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;

View File

@ -79,7 +79,7 @@
}
.page {
overflow: hidden;
background-image: url('https://ide.code.fun/api/image?token=67bd70bf4ae84d0012272c1a&name=a3720d519620e205ede7e141952573f4.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/coupon/MyCoupon/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
@ -88,7 +88,7 @@
height: 100%;
}
.section {
background-image: url('https://ide.code.fun/api/image?token=67bd70bf4ae84d0012272c1a&name=a3720d519620e205ede7e141952573f4.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/coupon/MyCoupon/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;

View File

@ -67,7 +67,7 @@
}
.page {
overflow: hidden;
background-image: url('https://ide.code.fun/api/image?token=67bd70bf4ae84d0012272c1a&name=a3720d519620e205ede7e141952573f4.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/coupon/OverDueCoupon/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
@ -76,7 +76,7 @@
height: 100%;
}
.section {
background-image: url('https://ide.code.fun/api/image?token=67bd70bf4ae84d0012272c1a&name=a3720d519620e205ede7e141952573f4.png');
background-image: url(https://carbon2.obs.cn-north-4.myhuaweicloud.com/feiyi/miniProgram/coupon/OverDueCoupon/bkg.png);
background-size: 100% 100%;
background-repeat: no-repeat;
width: 750rpx;

View File

@ -10,7 +10,7 @@
<script setup lang="ts">
import {nextTick, onMounted, ref} from 'vue'
import emitter from '../../../utils/emitter';
import emitter from '../../../utils/emitter'
const cancel = () => {
emitter.emit('closeConfirmPopup')

View File

@ -6,7 +6,7 @@
<text class="text">请选择优惠券</text>
<image
class="image pos"
src="../images/cha.png"
src=""
@click="closeCoupon"
/>
</view>
@ -25,7 +25,7 @@
<text class="font_2 text_2">优惠券商城</text>
<image
class="image_2"
src="../images/yjt.png"
src=""
/>
</view>
</view>

Binary file not shown.

Before

Width:  |  Height:  |  Size: 449 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 507 B

View File

@ -128,6 +128,7 @@ const showStop =()=>{
</script>
<style lang="scss" scoped>
.ml-7 {
margin-left: 4.13rpx;
}
@ -286,5 +287,11 @@ const showStop =()=>{
right: 18.14rpx;
bottom: 24.28rpx;
}
/* 隐藏滚动条 */
::-webkit-scrollbar {
display: none;
}
@import url(../../common/css/global.css);
</style>

View File

@ -188,13 +188,13 @@
.text-wrapper_2 {
padding-bottom: 7.5rpx;
background-color: #ffbe55;
background-color: #fbdedf;
border-radius: 9.38rpx;
width: 71.06rpx;
}
.text_2 {
color: #ffffff;
color: #c35c5d;
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 18.71rpx;

View File

@ -34,10 +34,15 @@
<view class="flex-col section_4 list-item_1 mt-14" v-for="(order, index) in Status.displayedOrders"
:key="order.id" @click="goToText(order)">
<view class="flex-col">
<view class="flex-row items-center self-stretch mt-2">
<text class="font_4">订单编号</text>
<text class="font_5 ml-5">{{order.orderNumber}}</text>
<text class="font_status text_5">{{ order.orderStatus }}</text>
<view class="flex-row items-center self-stretch mt-2" style="display: flex; justify-content: space-between;">
<view>
<text class="font_4">订单编号</text>
<text class="font_5 ml-5">{{order.orderNumber}}</text>
</view>
<view style="width: 150rpx; display: flex; justify-content: space-between;">
<!-- <view><text v-if="order.orderStatus === '待支付'" class="font_status text_5">{{ order.countdown }}</text></view> -->
<view><text class="font_status text_5">{{ order.orderStatus }}</text></view>
</view>
</view>
</view>
<view class="flex-col group">
@ -66,7 +71,7 @@
<view v-if="order.orderStatus==='已退款'" class="font text_18">售后详情</view>
</view> -->
<view class="flex-row justify-end items-center view">
<text class="font_9 text_16"> 金额</text>
<text class="font_9 text_16">金额</text>
<image class="image_4 image_5"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FJmxvlQvD-rmbpink.png" />
<text class="font_8 text_17">{{order.totalAmount}}</text>
@ -122,7 +127,7 @@
</template>
<script setup>
import { ref,onMounted,toRaw } from 'vue';
import { ref,onMounted,toRaw, onBeforeUnmount } from 'vue';
import { baseUrl } from '@/api/request';
import { onLoad } from "@dcloudio/uni-app";
const Status = ref({
@ -170,6 +175,9 @@ const isSelected = (tab) => Status.value.orderStatus === tab
})
if (res.data.code === 1) {
Status.value.orders = res.data.data
Status.value.orders.forEach((order) => {
startCountdown(order)
})
console.log('Status.value.orders--->',Status.value.orders);
} else {
console.log('没拿到用户数据')
@ -383,6 +391,77 @@ const confirm =()=> { //确认收货方法
isLoading.value = false
}
}
//
const parseDate = (dateString) => {
const [date, time] = dateString.split(' ');
const [year, month, day] = date.split('-').map(Number);
const [hour, minute, second] = time.split(':').map(Number);
return new Date(year, month - 1, day, hour, minute, second); // JavaScript Date0
};
// 30
const add30Minutes = (createdTime) => {
const date = parseDate(createdTime);
date.setMinutes(date.getMinutes() + 31); // 30
return Math.floor(date.getTime() / 1000); //
};
//
const startCountdown = (order) => {
if (order.orderStatus === '待支付') {
order.endTime = add30Minutes(order.createTime); //
order.countdownInterval = setInterval(() => {
const now = Math.floor(Date.now() / 1000); //
const remainingTime = order.endTime - now;
if (remainingTime <= 0) {
order.countdown = '00:00';
clearInterval(order.countdownInterval); //
Getorder()
// uni.showModal({
// title: '',
// content: '',
// showCancel: false
// })
} else {
const minutes = Math.floor(remainingTime / 60); //
const seconds = remainingTime % 60; //
order.countdown = `${String(minutes).padStart(2, '0')}:${String(seconds).padStart(2, '0')}`;
}
}, 1000);
}
};
//
//
onBeforeUnmount(() => {
Status.value.orders.forEach(order => {
if (order.countdownInterval) {
clearInterval(order.countdownInterval);
}
});
});
</script>
<style lang="scss" scoped>
@ -520,7 +599,7 @@ const confirm =()=> { //确认收货方法
top: 217.5rpx;
}
.section_4 {
padding: 34.61rpx 15rpx 31.88rpx;
padding: 34.61rpx 31rpx 31.88rpx;
background-color: #ffffff;
border-radius: 31.88rpx;
}
@ -543,7 +622,6 @@ const confirm =()=> { //确认收货方法
color: #ffaaa5;
}
.text_5 {
margin: 0 8.08rpx 0 180rpx;
line-height: 24.62rpx;
}
.font_4 {

View File

@ -14,7 +14,7 @@
<text class="font_2 text_2 ml-8">{{ addressRealInfo.detailAddress }}</text>
</view>
</view>
<view class="flex-row self-start group" @click="loadPop">
<view class="flex-row self-start group" @click="loadPop" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }">
<text class="font_3 text_3">更换地址</text>
<image
class="shrink-0 image_2"
@ -92,10 +92,10 @@
</view>
</view>
<view class="flex-col mt-25">
<view class="flex-row justify-between group_10">
<view class="flex-row justify-between group_10" @click="openCoupon" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }">
<text class="font_7">优惠券</text>
<view class="flex-row">
<text class="font_8">0张优惠券可用</text>
<text class="font_8" :style="{color: textColor}"> {{ templateString }}</text>
<image
class="shrink-0 image_7 ml-3"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FTrywtERT-right.png"
@ -103,7 +103,7 @@
</view>
</view>
<view class="flex-col mt-9">
<view class="flex-row justify-between items-center group_11">
<!-- <view class="flex-row justify-between items-center group_11">
<text class="font_7 text_15">满120减0优惠</text>
<view class="flex-row items-center">
<image
@ -113,7 +113,7 @@
<text class="font_3 text_16"></text>
<text class="font_9 text_17">0.00</text>
</view>
</view>
</view> -->
<view class="flex-row justify-between items-center group_12">
<text class="font_7 text_18">合计</text>
<view class="flex-row items-center">
@ -121,7 +121,7 @@
class="shrink-0 image_9"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FjIVFaWXA-rmb.png"
/>
<text class="font_9">{{ sumprice.toFixed(2) }}</text>
<text class="font_9">{{ sfAmount.toFixed(2) }}</text>
</view>
</view>
</view>
@ -142,10 +142,10 @@
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FJmxvlQvD-rmbpink.png"
/>
<text class="text_21">应付</text>
<text class="text_22">{{ sumprice.toFixed(2) }}</text>
<text class="text_22">{{ sfAmount.toFixed(2) }}</text>
<!-- <text class="text_24">00</text> -->
</view>
<view class="flex-col justify-start items-center text-wrapper_3" @click="wxPayFd()"><text class="font_7 text_23">微信支付</text></view>
<view class="flex-col justify-start items-center text-wrapper_3" @click="wxPayFd" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }"><text class="font_7 text_23">微信支付</text></view>
</view>
</view>
<uni-popup ref="popup" background-color="#fff">
@ -153,6 +153,13 @@
<addressComponentVue></addressComponentVue>
</view>
</uni-popup>
<uni-popup ref="coupon">
<view class="coupon-popup">
<couponPopupVue></couponPopupVue>
</view>
</uni-popup>
<!-- 遮罩层 -->
<view v-if="isShow" class="overlay"></view>
</template>
@ -163,8 +170,9 @@ import emitter from '../../../utils/emitter'
import { onLoad , onShow } from "@dcloudio/uni-app";
import { baseUrl } from '../../../api/request';
import addressComponentVue from '../component/addressComponent.vue'; //
import couponPopupVue from '../../coupon/component/couponPopup.vue';
import { stateMap } from '../../../common/global';
import { sum } from 'mathjs';
import * as math from 'mathjs'
//
const sumprice = ref(0) //
//11.4
@ -179,6 +187,17 @@ const orderItemList = ref({})
const totalInfo = ref([]) //
const note = ref('')
const postCartArr = ref([])
const useCouponId = ref(null)
const sfAmount = ref(0)
const templateString = ref(null)
const myCouponList = ref([])
const couponObj = ref({})
const cookie = wx.getStorageSync("cookie") //
const textColor = ref('')
const coupon = ref(null)
const conditionAmount = ref(0)
onMounted(() => {
getFonts()
//
@ -189,12 +208,41 @@ onMounted(() => {
emitter.on('addressInfo', (val) =>{
addressRealInfo.value = val
})
emitter.on('closeCoupon', () => {
nextTick(() => {
if (coupon.value) {
coupon.value.close()
}
})
})
emitter.on('cancelCoupon', () => {
templateString.value = myCouponList.value.length + '张优惠券可用'
sfAmount.value = sumprice.value
useCouponId.value = null
textColor.value = '#818181'
})
emitter.on('getCouponObj', (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)
})
console.log('===============start===============')
})
onLoad((options)=>{
onLoad( async (options)=>{
totalInfo.value = JSON.parse(options.cartInfo)
console.log('options.cartInfo-->',JSON.parse(options.cartInfo));
console.log('totalInfo.value-->',toRaw(totalInfo.value) );
getProduct() //
await getProduct()
await getMyCouponList()
})
onShow(()=>{
userInfo.value = wx.getStorageSync('userInfo') //
@ -243,7 +291,7 @@ const createOrder = async () => { //购物车的购买方法
orderType: productArr.value[0].cartGoodVO.type === '服务类' ? 'service' : 'product',
userName: userInfo.userName,
addressId: addressRealInfo.value.id, //id
// contactsId: null, //id
contactsId: useCouponId.value, //id
couponId: null, //id
note: note.value,
cartOrderItemAddRequestList: toRaw(postCartArr.value)
@ -278,6 +326,7 @@ const dealRes =(res)=> { //处理来自后端的数据
productArr.value.forEach((item)=>{
sumprice.value += item.cartGoodVO.price * item.quantity //
})
sfAmount.value = sumprice.value
}
//
const shortNum = (index)=>{
@ -285,6 +334,10 @@ const shortNum = (index)=>{
productArr.value[index].quantity -= 1
//
sumprice.value -= productArr.value[index].cartGoodVO.price * 1
sfAmount.value = sumprice.value
useCouponId.value = null
textColor.value = '#818181'
fd()
}
}
//
@ -292,6 +345,10 @@ const addNum = (index)=>{
if( productArr.value[index].quantity < productArr.value[index].cartGoodVO.inventory ) { //
productArr.value[index].quantity += 1
sumprice.value += productArr.value[index].cartGoodVO.price * 1 //
sfAmount.value = sumprice.value
useCouponId.value = null
textColor.value = '#818181'
fd()
}
}
const formatArr = () =>{
@ -388,7 +445,6 @@ const getFonts =()=>{
isShow.value = true
wxPayTimer = setTimeout(async () => {
await createOrder()
hideLoading()
}, 1000)
}
function showLoading() { //
@ -405,12 +461,65 @@ const getFonts =()=>{
wx.hideLoading();
loading = false;
isLoading.value = false
isShow.value = false
}
}
const openCoupon = () => {
emitter.emit('getTotalPrice', sumprice.value)
coupon.value.open('bottom')
}
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>
.coupon-popup {
height: 1200rpx;
justify-content: center;
background-color: #fff;
border-radius: 20rpx 20rpx 0 0;
}
.overlay {
position: fixed;
top: 0;
@ -420,12 +529,17 @@ const getFonts =()=>{
background-color: rgba(0, 0, 0, 0.4); /* 半透明黑色背景 */
z-index: 999;
}
.popup-content {
height: 300px;
align-items: center;
justify-content: center;
background-color: #fff;
}
.ml-17 {
margin-left: 31.88rpx;
}
@ -631,8 +745,7 @@ const getFonts =()=>{
color: #323232;
}
.group_10 {
padding-left: 22.97rpx;
padding-right: 3.75rpx;
padding: 25rpx 3.75rpx 25rpx 22.97rpx;
}
.group_11 {
padding: 26.25rpx 10.42rpx 28.13rpx 24.62rpx;

View File

@ -9,7 +9,7 @@
/>
<text class="text ml-10">{{ contactRealInfo.name }} {{ contactRealInfo.phone }}</text>
</view>
<view class="flex-row items-center group" @click="loadPop()">
<view class="flex-row items-center group" @click="loadPop" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }">
<image
class="image_2"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FKgDGnwlb-right.png"
@ -69,7 +69,7 @@
</view>
</view>
<view class="flex-col section_4">
<view class="flex-row justify-between items-center">
<view class="flex-row justify-between items-center my-coupon">
<view class="flex-row">
<text class="font_8 text_13">商品总价</text>
<text class="font_9 ml-7">{{ productArr.length }}件商品</text>
@ -82,24 +82,24 @@
<text class="font_10">{{ sumprice.toFixed(2) }}</text>
</view>
</view>
<view class="flex-row justify-between mt-34">
<view class="flex-row justify-between my-coupon" @click="openCoupon" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }">
<text class="font_8">优惠券</text>
<view class="flex-row group_12">
<text class="font_9">0张优惠券可用</text>
<text class="font_9" :style="{color: textColor}">{{ templateString }}</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">
<view class="flex-row justify-between items-center my-coupon">
<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>
<text class="font_10">{{ sfAmount.toFixed(2) }}</text>
</view>
</view>
</view>
@ -116,10 +116,11 @@
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_18">{{ sfAmount.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 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>
</view>
</view>
<uni-popup ref="popup" background-color="#fff" :mask-click="false">
@ -127,6 +128,13 @@
<contactsComponentVue></contactsComponentVue>
</view>
</uni-popup>
<uni-popup ref="coupon">
<view class="coupon-popup">
<couponPopupVue></couponPopupVue>
</view>
</uni-popup>
<!-- 遮罩层 -->
<view v-if="isShow" class="overlay"></view>
</template>
@ -138,8 +146,10 @@
import { baseUrl } from '../../../api/request';
import { stateMap } from '../../../common/global';
import { sum } from 'mathjs';
import couponPopupVue from '../../coupon/component/couponPopup.vue';
import contactsComponentVue from '../component/contactsComponent.vue'; //\
import contactPopVue from '../../mine/component/contactPop.vue'; //
import * as math from 'mathjs'
//
const sumprice = ref(0) //
const popup = ref(null) //
@ -154,6 +164,20 @@
const postCartArr = ref([])
const singleService = ref({}) //
const cnt = ref(1) //
const coupon = ref(null)
const couponObj = ref({})
const templateString = ref('')
const conditionAmount = ref(0)
const sfAmount = ref(0)
const myCouponList = ref([])
const cookie = wx.getStorageSync("cookie") //
const useCouponId = ref(null)
const textColor = ref('')
onMounted(() => {
getFonts()
//
@ -164,8 +188,37 @@
emitter.on('contactsNowInfo', (val) =>{
contactRealInfo.value = val
})
emitter.on('closeCoupon', () => {
nextTick(() => {
if (coupon.value) {
coupon.value.close()
}
})
})
emitter.on('cancelCoupon', () => {
templateString.value = myCouponList.value.length + '张优惠券可用'
sfAmount.value = sumprice.value
useCouponId.value = null
textColor.value = '#818181'
})
emitter.on('getCouponObj', (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)
})
console.log('===============start===============')
})
onLoad((options)=>{
onLoad( async (options)=>{
if(options.cartInfo === undefined) {
singleService.value = JSON.parse(options.obj)
cnt.value = JSON.parse(options.cnt)
@ -175,8 +228,9 @@
totalInfo.value = JSON.parse(options.cartInfo)
console.log('options.cartInfo-->',JSON.parse(options.cartInfo));
console.log('totalInfo.value-->',toRaw(totalInfo.value) );
getProduct() //
await getProduct() //
}
await getMyCouponList()
})
onShow(()=>{
userInfo.value = wx.getStorageSync('userInfo') //
@ -186,10 +240,10 @@
//
const close = () => {
nextTick(() => {
if (popup.value) {
popup.value.close()
}
})
if (popup.value) {
popup.value.close()
}
})
}
//
const loadPop =() =>{
@ -228,7 +282,7 @@
orderType: productArr.value[0].cartExperienceGoodVO.type === '服务类' ? 'service' : 'product',
userName: userInfo.userName,
contactsId: contactRealInfo.value.id, //id
couponId: null, //id
couponId: useCouponId.value, //id
note: note.value,
cartOrderItemAddRequestList: toRaw(postCartArr.value)
}
@ -262,20 +316,28 @@
productArr.value.forEach((item)=>{
sumprice.value += item.cartExperienceGoodVO.price * item.quantity //
})
sfAmount.value = sumprice.value
}
//
const shortNum = (index)=>{
if(productArr.value[index].quantity > 1) {
productArr.value[index].quantity -= 1
//
sumprice.value -= productArr.value[index].cartExperienceGoodVO.price * 1
}
sumprice.value = math.round(sumprice.value - productArr.value[index].cartExperienceGoodVO.price)
} sfAmount.value = sumprice.value
useCouponId.value = null
textColor.value = '#818181'
fd()
}
//
const addNum = (index)=>{
if( productArr.value[index].quantity < productArr.value[index].restNumber ) { //
productArr.value[index].quantity += 1
sumprice.value += productArr.value[index].cartExperienceGoodVO.price * 1 //
sumprice.value = math.round(sumprice.value + productArr.value[index].cartExperienceGoodVO.price) //
sfAmount.value = sumprice.value
useCouponId.value = null
textColor.value = '#818181'
fd()
}
}
const formatArr = () =>{ //
@ -386,6 +448,13 @@
isLoading.value = false
}
}
const openCoupon = () => {
emitter.emit('getTotalPrice', sumprice.value)
coupon.value.open('bottom')
}
const getMyCouponList = async () => { //
const res = await uni.request({
url: baseUrl + '/coupon/list/use',
@ -415,6 +484,26 @@
background-color: rgba(0, 0, 0, 0.4); /* 半透明黑色背景 */
z-index: 999;
}
.popup-content {
height: 300px;
align-items: center;
justify-content: center;
// background-color: #fff;
border-radius: 20rpx 20rpx 0 0;
}
.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;
}
.mt-13 {
margin-top: 24.38rpx;
}
@ -593,7 +682,7 @@
}
.section_4 {
margin: 30rpx 16.88rpx 0 16.88rpx;
padding: 30rpx 19.22rpx 20.63rpx;
padding: 20rpx 19.22rpx 20.63rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
}

View File

@ -195,8 +195,6 @@ const quantity = ref(1) //商品数量
const couponIsShow = ref(false)
const coupon = ref(null)
const couponObj = ref({})
const templateString = ref('')
const conditionAmount = ref(0)

View File

@ -9,7 +9,7 @@
/>
<text class="text ml-10">{{ contactRealInfo.name }} {{ contactRealInfo.phone }}</text>
</view>
<view class="flex-row items-center group" @click="loadPop()">
<view class="flex-row items-center group" @click="loadPop" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }">
<image
class="image_2"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FKgDGnwlb-right.png"
@ -69,7 +69,7 @@
</view>
</view>
<view class="flex-col section_4">
<view class="flex-row justify-between items-center">
<view class="flex-row justify-between items-center my-coupon">
<view class="flex-row">
<text class="font_8 text_13">课程总价</text>
<text class="font_9 ml-7">{{ cnt }}件商品</text>
@ -82,24 +82,24 @@
<text class="font_10">{{ sumprice.toFixed(2) }}</text>
</view>
</view>
<view class="flex-row justify-between mt-34">
<view class="flex-row justify-between my-coupon" @click="openCoupon" :style="{ pointerEvents: isLoading ? 'none' : 'auto' }">
<text class="font_8">优惠券</text>
<view class="flex-row group_12">
<text class="font_9">0张优惠券可用</text>
<text class="font_9" :style="{color: textColor}">{{ templateString }}</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">
<view class="flex-row justify-between items-center my-coupon">
<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>
<text class="font_10">{{ sfAmount.toFixed(2) }}</text>
</view>
</view>
</view>
@ -116,10 +116,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_18">{{ sfAmount.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 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>
</view>
</view>
<uni-popup ref="popup" background-color="#fff" :mask-click="false">
@ -127,6 +127,13 @@
<contactsComponentVue></contactsComponentVue>
</view>
</uni-popup>
<uni-popup ref="coupon">
<view class="coupon-popup">
<couponPopupVue></couponPopupVue>
</view>
</uni-popup>
<!-- 遮罩层 -->
<view v-if="isShow" class="overlay"></view>
</template>
@ -137,9 +144,10 @@
import { onLoad , onShow } from "@dcloudio/uni-app";
import { baseUrl } from '../../../api/request';
import { stateMap } from '../../../common/global';
import { sum } from 'mathjs';
import * as math from 'mathjs'
import contactsComponentVue from '../component/contactsComponent.vue'; //\
import contactPopVue from '../../mine/component/contactPop.vue'; //
import couponPopupVue from '../../coupon/component/couponPopup.vue';
const sumprice = ref(0) //
const popup = ref(null) //
const contactRealInfo = ref({
@ -154,6 +162,19 @@
const timeSlot = ref('') //
const bookDate = ref('') //
const restNumber = ref(0) //
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('')
onMounted(() => {
getFonts()
//
@ -164,7 +185,37 @@
emitter.on('contactsNowInfo', (val) =>{
contactRealInfo.value = val
})
})
emitter.on('closeCoupon', () => {
nextTick(() => {
if (coupon.value) {
coupon.value.close()
}
})
})
emitter.on('cancelCoupon', () => {
templateString.value = myCouponList.value.length + '张优惠券可用'
sfAmount.value = sumprice.value
useCouponId.value = null
textColor.value = '#818181'
})
emitter.on('getCouponObj', (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)
})
console.log('===============start===============')
})
onLoad((options)=>{
singleService.value = JSON.parse(options.obj)
cnt.value = JSON.parse(options.cnt)
@ -172,11 +223,13 @@
bookDate.value = singleService.value.appointmentDateVOList[0].specificDate
timeSlot.value = singleService.value.appointmentDateVOList[0].timePeriodVOList[0].timeSlot
sumprice.value = cnt.value * singleService.value.price
sfAmount.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);
getMyCouponList()
})
onShow(()=>{
userInfo.value = wx.getStorageSync('userInfo') //
@ -186,10 +239,10 @@
//
const close = () => {
nextTick(() => {
if (popup.value) {
popup.value.close()
}
})
if (popup.value) {
popup.value.close()
}
})
}
//
const loadPop =() =>{
@ -244,14 +297,22 @@
if(cnt.value > 1) {
cnt.value -= 1
//
sumprice.value -= singleService.value.price * 1
sumprice.value = math.round(sumprice.value - singleService.value.price, 2)
sfAmount.value = sumprice.value
useCouponId.value = null
textColor.value = '#818181'
fd()
}
}
//
const addNum = (index)=>{
if( cnt.value < restNumber.value ) { //
cnt.value += 1
sumprice.value += singleService.value.price * 1 //
sumprice.value = math.round(sumprice.value + singleService.value.price, 2)
sfAmount.value = sumprice.value
useCouponId.value = null
textColor.value = '#818181'
fd()
}
}
const formatArr = () =>{ //
@ -330,14 +391,19 @@
let loading = false;
let isLoading = ref(false)
let isShow = ref(false)
// const fd = () => { //
// clearTimeout(debounceTimer)
// showLoading()
// debounceTimer = setTimeout(async () => {
// await getMyCouponList()
// hideLoading()
// }, 1000)
// }
const fd = () => { //
clearTimeout(debounceTimer)
showLoading()
debounceTimer = setTimeout(async () => {
await getMyCouponList()
hideLoading()
}, 1000)
}
const wxPayFd = () => { //
clearTimeout(wxPayTimer)
showLoading()
@ -346,15 +412,17 @@
await createOrder()
}, 1000)
}
function showLoading() { //
if (!loading) {
wx.showLoading({
title: '加载中...',
});
loading = true;
isLoading.value = true
isLoading.value = true
}
}
function hideLoading() { //
if (loading) {
wx.hideLoading();
@ -362,6 +430,13 @@
isLoading.value = false
}
}
const openCoupon = () => {
emitter.emit('getTotalPrice', sumprice.value)
coupon.value.open('bottom')
}
const getMyCouponList = async () => { //
const res = await uni.request({
url: baseUrl + '/coupon/list/use',
@ -391,6 +466,18 @@
background-color: rgba(0, 0, 0, 0.4); /* 半透明黑色背景 */
z-index: 999;
}
.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;
}
.mt-13 {
margin-top: 24.38rpx;
}
@ -569,7 +656,7 @@
}
.section_4 {
margin: 30rpx 16.88rpx 0 16.88rpx;
padding: 30rpx 19.22rpx 20.63rpx;
padding: 20rpx 19.22rpx 20.63rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
}

View File

@ -17,7 +17,7 @@
<!-- 类别列表 -->
<view class="flex-col justify-start items-center section_4 pos_3">
<!-- <view class="flex-col"> -->
<scroll-view scroll-y class="scrollable-contentType">
<view style="overflow: auto;" class="my-aside">
<view class="flex-col items-center self-stretch group"
v-for="(item, index) in sort"
:key="index"
@ -30,7 +30,7 @@
/>
<text class="font_2 text_4" :style="FontsStyle(index)">{{ item.name }}</text>
</view>
</scroll-view>
</view>
<!-- </view> -->
</view>
<!-- 商品列表 -->
@ -170,9 +170,16 @@ const getFonts = () => { //导入字体
</script>
<style lang="scss" scoped>
.scrollable-contentType {
height: 56vh;
::-webkit-scrollbar {
display: none;
}
.my-aside {
height: 100vh;
}
.mt-9 {
margin-top: 16.88rpx;
}
@ -230,7 +237,7 @@ const getFonts = () => { //导入字体
.section_4 {
padding: 7.5rpx 0 0rpx;
background-color: #f4f3f1;
width: 109.75rpx;
width: 119.75rpx;
}
.pos_3 {
position: absolute;