This commit is contained in:
yuanteng0011 2025-02-19 12:06:34 +08:00
parent 370cc4b6bc
commit a8977e708d
6 changed files with 141 additions and 82 deletions

View File

@ -163,7 +163,7 @@ const getProductCart = async ()=>{
'cookie': wx.getStorageSync('cookie') 'cookie': wx.getStorageSync('cookie')
} }
}) })
// console.log('res--->',res.data); console.log('res--->',res.data);
if(res.data.code === 1) { if(res.data.code === 1) {
products.value = res.data.data products.value = res.data.data
products.value.forEach((item)=>{ products.value.forEach((item)=>{

View File

@ -287,8 +287,4 @@ const showStop =()=>{
bottom: 24.28rpx; bottom: 24.28rpx;
} }
@import url(../../common/css/global.css); @import url(../../common/css/global.css);
// @font-face {
// font-family: "ZhongShanFonts";
// src: url('https://carbon2.obs.cn-north-4.myhuaweicloud.com/fonts/ZhongShanFonts.ttf');
// }
</style> </style>

View File

@ -1,26 +1,28 @@
<template> <template>
<view class="all"> <view class="flex-col items-start relative page">
<view> <view class="section_2"></view>
<view> <image
<!-- <img src="http://110.42.248.235:866/images/system/666/HmCyrnRc-login.png" class="img"> --> class="image"
</view> src="https://ide.code.fun/api/image?token=6784b7164ae84d0012235720&name=4f57dc3a50dc99c58860b6ef6a6aafb0.png"
<view class="text_all"> />
<view class="text_tishi"> <text class="font pos_2"></text>
请完成授权以继续使用 <text class="font pos_4"></text>
</view> <view class="section_3 pos_5"></view>
<button @click="login" class="text_btn">微信账号一键登录</button> <view class="flex-col justify-start items-center text-wrapper pos_6" @click="login">
<!-- <view class="text_no"> <text class="text">微信登陆</text>
请选择手机号登录?
</view> -->
</view>
</view> </view>
</view> </view>
<!-- </view> -->
</template> </template>
<script setup> <script setup>
import { ref } from 'vue' import { ref } from 'vue'
import { baseUrl, testUrl , suiUrl} from '@/api/request'; import { baseUrl, testUrl , suiUrl} from '@/api/request';
import { onMounted } from 'vue';
onMounted(()=>{
getFonts() //
})
const login = () => { const login = () => {
uni.login({ uni.login({
provider: 'weixin', //使 provider: 'weixin', //使
@ -63,53 +65,98 @@ const loginUser = async ( code ) =>{
return; return;
} }
} }
const getFonts =()=>{ //
uni.loadFontFace({
family: 'FangZhengXiaoZhuan',
source: `url("https://carbon2.obs.cn-north-4.myhuaweicloud.com/fonts/FangZhengXiaoZhuan.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);
}
})
}
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.all { .page {
display: flex; padding-left: 118.13rpx;
align-items: center; background-image: url('https://ide.code.fun/api/image?token=6784b7164ae84d0012235720&name=748c723c0b3ea17eb04647d0879f9b81.png');
justify-content: center; background-size: 100% 100%;
width: 750rpx; background-repeat: no-repeat;
height: 1206rpx; width: 100%;
.img { overflow-y: auto;
display: flex; overflow-x: hidden;
width: 480rpx; height: 100%;
height: 380rpx; }
margin:30rpx auto; .section_2 {
margin-left: 256.88rpx;
} background-color: #9d2624;
width: 1.88rpx;
.text_all { height: 388.13rpx;
width: 520rpx; }
height: 400rpx; .image {
margin: 40rpx auto 0; margin-top: 136.88rpx;
opacity: 0.35;
.text_tishi { width: 631.88rpx;
font-size: 28rpx; height: 907.5rpx;
text-align: center; }
margin-bottom: 40rpx; .font {
} font-size: 240rpx;
font-family: FangZhengXiaoZhuan;
.text_btn { line-height: 288.75rpx;
width: 520rpx; color: #9d2624;
height: 90rpx; }
background-color: yellow; .pos_2 {
border-radius: 120rpx; position: absolute;
font-size: 32rpx; right: 257.56rpx;
color: #fff; top: 462.19rpx;
text-align: center; }
line-height: 90rpx; .pos_4 {
margin-bottom: 20rpx; position: absolute;
} left: 50%;
bottom: 414.38rpx;
.text_no { transform: translateX(-50%);
font-size: 28rpx; }
text-align: center; .section_3 {
color: #2493F1; background-color: #9d2624;
width: 1.88rpx;
} height: 418.13rpx;
} }
} .pos_5 {
position: absolute;
left: 50%;
top: 1014.38rpx;
transform: translateX(-50%);
}
.text-wrapper {
padding: 27.54rpx 0 28.82rpx;
background-color: #ffffff;
border-radius: 37.5rpx 0 0 37.5rpx;
width: 204rpx;
}
.pos_6 {
position: absolute;
right: 0;
top: 1348.13rpx;
}
.text {
color: #000000;
font-size: 30rpx;
font-family: FangZhengFonts;
line-height: 28.01rpx;
text-transform: capitalize;
}
@import url(../../common/css/global.css);
</style> </style>

View File

@ -1,4 +1,3 @@
<!-- 单个商品购买页面 -->
<template> <template>
<view class="flex-col justify-start relative page"> <view class="flex-col justify-start relative page">
<view class="flex-col group_1"> <view class="flex-col group_1">
@ -131,7 +130,8 @@
<view class="flex-col section_6"> <view class="flex-col section_6">
<text class="self-start font_7 text_19">订单备注</text> <text class="self-start font_7 text_19">订单备注</text>
<view class="flex-col justify-start items-start self-stretch text-wrapper_2 mt-11"> <view class="flex-col justify-start items-start self-stretch text-wrapper_2 mt-11">
<text class="font_2 text_20">备注建议提前协商250字以内</text> <!-- <text class="font_2 text_20">备注建议提前协商250字以内</text> -->
<textarea @input="textAssign" auto-height style="width: 360px;"></textarea>
</view> </view>
</view> </view>
</view> </view>
@ -174,7 +174,7 @@ const labelList = ref([]) //老套路,商品标签
const userInfo = wx.getStorageSync('userInfo') // const userInfo = wx.getStorageSync('userInfo') //
const orderItemList = ref({}) const orderItemList = ref({})
const totalInfo = ref([]) // const totalInfo = ref([]) //
const note = ref('123') const note = ref('')
const postCartArr = ref([]) const postCartArr = ref([])
onMounted(() => { onMounted(() => {
getFonts() getFonts()
@ -341,6 +341,10 @@ const wxPay = async( oid )=> { //传入订单id
}) })
} }
} }
const textAssign = (e) => { //
note.value = e.detail.value
// console.log('note--->',note.value);
}
// //
const getFonts =()=>{ const getFonts =()=>{
uni.loadFontFace({ uni.loadFontFace({
@ -608,7 +612,7 @@ const getFonts =()=>{
.text-wrapper_2 { .text-wrapper_2 {
margin-left: 3.99rpx; margin-left: 3.99rpx;
margin-right: 3.99rpx; margin-right: 3.99rpx;
padding: 22.35rpx 0 115.22rpx; padding: 22.35rpx 20rpx;
background-color: #ffefef; background-color: #ffefef;
border-radius: 9.38rpx; border-radius: 9.38rpx;
} }

View File

@ -131,7 +131,8 @@
<view class="flex-col section_6"> <view class="flex-col section_6">
<text class="self-start font_7 text_19">订单备注</text> <text class="self-start font_7 text_19">订单备注</text>
<view class="flex-col justify-start items-start self-stretch text-wrapper_2 mt-11"> <view class="flex-col justify-start items-start self-stretch text-wrapper_2 mt-11">
<text class="font_2 text_20">备注建议提前协商250字以内</text> <!-- <text class="font_2 text_20">备注建议提前协商250字以内</text> -->
<textarea @input="textAssign" auto-height style="width: 360px;"></textarea>
</view> </view>
</view> </view>
</view> </view>
@ -175,7 +176,7 @@ const labelList = ref([]) //老套路,商品标签
const userInfo = wx.getStorageSync('userInfo') // const userInfo = wx.getStorageSync('userInfo') //
const orderItemList = ref({}) const orderItemList = ref({})
const totalInfo = ref([]) // const totalInfo = ref([]) //
const note = ref('123') const note = ref('')
const postCartArr = ref([]) const postCartArr = ref([])
const quantity = ref(1) // const quantity = ref(1) //
onMounted(() => { onMounted(() => {
@ -352,6 +353,11 @@ const getFonts =()=>{
} }
}) })
} }
const textAssign = (e) => { //
// console.log(e);
note.value = e.detail.value
console.log('note--->',note.value);
}
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
@ -606,7 +612,7 @@ const getFonts =()=>{
.text-wrapper_2 { .text-wrapper_2 {
margin-left: 3.99rpx; margin-left: 3.99rpx;
margin-right: 3.99rpx; margin-right: 3.99rpx;
padding: 22.35rpx 0 115.22rpx; padding: 22.35rpx 20rpx;
background-color: #ffefef; background-color: #ffefef;
border-radius: 9.38rpx; border-radius: 9.38rpx;
} }

View File

@ -10,9 +10,9 @@
<text class="font text_2"></text> <text class="font text_2"></text>
<text class="text">{{ productInfo.price }}</text> <text class="text">{{ productInfo.price }}</text>
</view> </view>
<text class="font_2 text_3">请选择</text> <!-- <text class="font_2 text_3">请选择</text> -->
<text class="font_2 pos_2">最大人数0</text> <text class="font_2 pos_2">最大人数0</text>
<text class="font_2 pos">场次</text> <!-- <text class="font_2 pos">场次</text> -->
</view> </view>
</view> </view>
<view class="flex-col group_4"> <view class="flex-col group_4">
@ -44,7 +44,7 @@
<text class="self-start font_3 text_7">选择预约时间</text> <text class="self-start font_3 text_7">选择预约时间</text>
<view class="section_1"> <view class="section_1">
<scroll-view scroll-x="true"> <scroll-view scroll-x="true">
<view class="flex-row justify-between items-baseline group_1"> <view class="flex-row items-baseline group_1">
<text :style="{ color: item.color }" class="font_4 text_8" v-for="(item, index) in bookTimeList" :key="index" @click="chooseDate(index)"> <text :style="{ color: item.color }" class="font_4 text_8" v-for="(item, index) in bookTimeList" :key="index" @click="chooseDate(index)">
{{ weekDay(item.specificDate) }}{{ item.specificDate.substring(5,10) }} {{ weekDay(item.specificDate) }}{{ item.specificDate.substring(5,10) }}
</text> </text>
@ -112,8 +112,11 @@ const classNum = ref(1) //课程数量
const flag = ref(0) const flag = ref(0)
onLoad((options)=>{ onLoad((options)=>{
}) })
onMounted(()=>{ onMounted( async ()=>{
getProduct() await getProduct()
//
await chooseDate(0)
await chooseTimeSlot(0)
}) })
const chooseDate = (index) => { // const chooseDate = (index) => { //
selected.value.date = bookTimeList.value[index].specificDate selected.value.date = bookTimeList.value[index].specificDate
@ -226,7 +229,7 @@ const add =()=> { //传入当前课程最大人数
} }
.group_5 { .group_5 {
margin-bottom: 5.29rpx; margin-bottom: 5.29rpx;
padding-bottom: 28.86rpx; padding-bottom: 48.86rpx;
width: 157.8rpx; width: 157.8rpx;
} }
.group_6 { .group_6 {
@ -436,7 +439,7 @@ const add =()=> { //传入当前课程最大人数
line-height: 28.84rpx; line-height: 28.84rpx;
} }
.section_5 { .section_5 {
margin-top: 54.38rpx; margin: 54.38rpx 0 100rpx 0;
padding: 32.23rpx 10.56rpx 91.29rpx 17.57rpx; padding: 32.23rpx 10.56rpx 91.29rpx 17.57rpx;
background-color: #fff2f2f5; background-color: #fff2f2f5;
border-radius: 18.75rpx; border-radius: 18.75rpx;
@ -451,10 +454,13 @@ const add =()=> { //传入当前课程最大人数
margin-left: 2.12rpx; margin-left: 2.12rpx;
} }
.section_6 { .section_6 {
margin-left: 15rpx; position: fixed;
margin-top: 88.13rpx; left: 0;
right: 0;
bottom: 0;
// margin-left: 15rpx;
// margin-top: 88.13rpx;
padding: 16.88rpx 0; padding: 16.88rpx 0;
background-color: #ffffff;
} }
.section_7 { .section_7 {
padding: 26.14rpx 0 25.07rpx; padding: 26.14rpx 0 25.07rpx;