2月26日完成联系人弹窗,联系人管理

This commit is contained in:
yuanteng0011 2025-02-26 23:56:19 +08:00
parent 935ed9481f
commit 070afad323
20 changed files with 2306 additions and 1297 deletions

View File

@ -9,6 +9,7 @@ onLaunch(()=>{
// console.log('onLaunch');
// getFonts() //
})
// const getFonts = () => { //
// uni.loadFontFace({
// family: 'FangZhengFonts',

View File

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

View File

@ -21,6 +21,13 @@
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/order/component/contactsComponent",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/coupon/CouponMall/CouponMall",
"style" :
@ -234,13 +241,6 @@
"enablePullDownRefresh":true //
}
},
{
"path" : "pages/syy",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/order/singleGoodOrder/singleGoodOrder",
"style" :
@ -283,6 +283,27 @@
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/order/serviceWaitPay/serviceWaitPay",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/mine/Contact/testContact",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/mine/component/contactPop",
"style" :
{
"navigationBarTitleText" : ""
}
},
{
"path" : "pages/coupon/OverDueCoupon/OverDueCoupon",
"style" :

View File

@ -13,7 +13,6 @@
</view>
<view class="mt-14 flex-col items-start self-stretch">
<text class="text_3">{{productBrief.name}}</text>
<!-- <text class="text_4 mt-9">{{已选蓝色发簪}}</text> -->
</view>
</view>
<view class="flex-col shrink-0 ml-5">
@ -37,8 +36,7 @@
</view>
</view>
</view>
<view class="flex-col justify-start items-center text-wrapper_2" @click="addCart"><text
class="text_6">加入购物车</text></view>
<view class="flex-col justify-start items-center text-wrapper_2" @click="addCart"><text class="text_6">加入购物车</text></view>
</view>
</template>
@ -53,9 +51,7 @@
onShow
} from "@dcloudio/uni-app";
import {
baseUrl,
testUrl,
suiUrl
baseUrl
} from '../../../api/request';
const productBrief = ref({}) //
const quantity = ref(1)
@ -206,7 +202,7 @@
.image-wrapper_2 {
padding: 11.25rpx 0;
background-color: #f5f5dc;
background-color: #FBDEDF;
border-radius: 5.63rpx 0rpx 0rpx 5.63rpx;
width: 52.5rpx;
height: 52.5rpx;
@ -219,7 +215,7 @@
.text-wrapper {
padding: 15rpx 0 11.25rpx;
background-color: #f5f5dc;
background-color: #FBDEDF;
width: 52.5rpx;
height: 52.5rpx;
}
@ -233,7 +229,7 @@
.image-wrapper_3 {
padding: 11.25rpx 0;
background-color: #f5f5dc;
background-color: #FBDEDF;
border-radius: 0rpx 5.63rpx 5.63rpx 0rpx;
width: 52.5rpx;
height: 52.5rpx;
@ -242,7 +238,7 @@
.text-wrapper_2 {
margin-right: 15rpx;
padding: 22.5rpx 0;
background-color: #ffd45a;
background-color: #E79EA1;
border-radius: 93.75rpx;
}

View File

@ -1,7 +1,6 @@
<template>
<view class="flex-col page">
<view class="flex-col group">
<text class="self-start font_2 text">收货信息</text>
<view class="flex-col self-stretch section mt-15">
<view class="flex-row items-center group_2">
<text class="font_2">收货人</text>
@ -22,25 +21,24 @@
:disabled="true"/>
</picker>
<image
class="image pos"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FkYDyjpPh-dingwei.png"
class="pos tag"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FeIdxrdNN-dingwei.png"
@click="chooseLocation()"
/>
</view>
</view>
<view class="flex-row items-center group_6">
<text class="font_2 text_7">详细地址</text>
<textarea class="section_2 ml-12" v-model="addressParam.detailAddress" placeholder="输入详细地址" />
<textarea class="section_2 ml-12" v-model="addressParam.detailAddress" placeholder="输入详细地址" auto-height="true"/>
</view>
<!-- 暂时用不了 -->
<view class="flex-row justify-between items-center group_7">
<checkbox-group @change="defaultAddress">
<text class="font_2">设为默认收货地址</text>
<text class="font_2" style="margin-right: 400rpx;">设为默认收货地址</text>
<!-- <image
class="image_2"
:src="selected"
/> -->
<checkbox value="1" />
<checkbox class="round red radius" value="1" />
</checkbox-group>
</view>
</view>
@ -148,9 +146,6 @@ const chooseLocation = () => { //定位获取地址
})
}
const bindTimeChange = (e) => { //picker
// console.log('--->',e.detail.value[0]);
// console.log('--->',e.detail.value[1]);
// console.log('--->',e.detail.value[2]);
addressParam.value.region = e.detail.value[0] + e.detail.value[1] + e.detail.value[2]
}
</script>
@ -170,11 +165,13 @@ const bindTimeChange = (e) => { //picker省市区选择
}
.page {
padding-top: 26.44rpx;
background-color: #fffaf0;
// background-color: #fffaf0;
background-image: url('https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FQfLHXSAU-feiyigongfangbeijin.png');
background-size: 100% 100%;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
// height: 100vh;
height: 100vh;
overflow: hidden;
}
.group {
@ -194,9 +191,9 @@ const bindTimeChange = (e) => { //picker省市区选择
margin-right: 14.1rpx;
padding-left: 20.49rpx;
padding-right: 15.13rpx;
background-color: #fffef8;
background-color: #ffffff;
border-radius: 9.38rpx;
border: solid 1.88rpx #818181;
// border: solid 1.88rpx #818181;
}
.group_2 {
padding: 24.24rpx 4.65rpx 12.19rpx;
@ -218,7 +215,7 @@ const bindTimeChange = (e) => { //picker省市区选择
margin-right: 28.71rpx;
}
.group_4 {
padding: 12.19rpx 4.29rpx 10.31rpx;
padding: 14.06rpx 5.04rpx 12.19rpx;
border-bottom: solid 1.88rpx #efefef;
}
.text_5 {
@ -248,12 +245,12 @@ const bindTimeChange = (e) => { //picker省市区选择
}
.section_2 {
width: 300rpx;
height: 150rpx;
// height: 45rpx;
flex: 1 1 0;
margin-right: 19.57rpx;
}
.group_7 {
padding: 25.31rpx 4.88rpx 32.01rpx;
padding: 14.06rpx 5.04rpx 12.19rpx;
}
.image_2 {
margin-right: 19.5rpx;
@ -265,18 +262,18 @@ const bindTimeChange = (e) => { //picker省市区选择
left: 0;
right: 0;
bottom: 0;
margin-right: 13.13rpx;
// margin-right: 13.13rpx;
padding: 16.88rpx 0;
background-color: #fffef8;
}
.text-wrapper_4 {
padding: 27.24rpx 0 23.61rpx;
background-color: #ffa948;
background-color: #FBDEDF;
border-radius: 46.88rpx;
width: 618.75rpx;
}
.text_8 {
color: #ffffff;
color: #C35C5D;
font-size: 30rpx;
font-family: Open Sans;
line-height: 27.9rpx;
@ -285,6 +282,15 @@ const bindTimeChange = (e) => { //picker省市区选择
height: 100rpx;
width: 450rpx;
margin-left: 50rpx;
}
.tag {
width: 55.75rpx;
height: 55.75rpx;
}
.radius {
transform: scale(0.7);
width: 37.5rpx;
height: 37.5rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -56,6 +56,7 @@
</view>
</view>
<!-- 服务类商品 -->
<view class="flex-col list-item mt-8" v-for="(item, index) in products" :key="index">
<view class="flex-col list-item_2 mt-8" v-if="current == 2">
<view class="flex-row">
<image
@ -105,6 +106,7 @@
</view>
</view>
</view>
</view>
</checkbox-group>
</view>
@ -138,16 +140,19 @@ const current = ref(1) //用于判断是实体类商品还是服务类商品
const allCheck = ref(false) //
const checkedData = ref([]) //
const totalPrice = ref(0)
// const userInfo = wx.getStorageSync('userInfo')
const stateText = ref({
topBtn: '编辑',
bottomBtn: '去结算'
})
//
const serviceProduct = ref([])
onShow(()=>{
getProductCart() //
getServiceCart() //
})
onLoad(()=>{
getProductCart() //
getServiceCart() //
})
//id
const getProductCart = async ()=>{
@ -185,7 +190,7 @@ const deleteProduct = async (idArr) =>{ //删除商品
totalPrice.value = 0
}
}
const getServiceCart =()=>{
const getServiceCart = async () => {
console.log('获取服务类商品方法被触发');
}
//

File diff suppressed because it is too large Load Diff

View File

@ -3,7 +3,7 @@
<view class="section_2"></view>
<image
class="image"
src="https://ide.code.fun/api/image?token=6784b7164ae84d0012235720&name=4f57dc3a50dc99c58860b6ef6a6aafb0.png"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FRAQucIRR-flower.png"
/>
<text class="font pos_2"></text>
<text class="font pos_4"></text>
@ -92,7 +92,7 @@ const getFonts =()=>{ //获取字体
<style lang="scss" scoped>
.page {
padding-left: 118.13rpx;
background-image: url('https://ide.code.fun/api/image?token=6784b7164ae84d0012235720&name=748c723c0b3ea17eb04647d0879f9b81.png');
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%;

View File

@ -54,7 +54,7 @@
</template>
<script setup>
import { ref, onMounted, watch, set } from 'vue'
import { ref, onMounted, watch } from 'vue'
import { baseUrl } from '../../../api/request'
onMounted(() => {
@ -437,5 +437,5 @@ const close1 = () => {
// background-color: #ccc;
// color: #333;
// }
@import url(/common/css/global.css)
@import url(/common/css/global.css);
</style>

View File

@ -0,0 +1,242 @@
<template>
<view class="flex-col page">
<view class="flex-col section">
<view class="flex-col justify-start items-center text-wrapper"><text class="text">联系人列表</text></view>
<view class="mt-10 flex-col list">
<view class="flex-row justify-center items-center relative mt-10 list-item" v-for="(item, index) in ContactArr"
:key="index">
<view class="flex-row items-baseline pos_2">
<text class="font">{{ item.name }}</text>
<text class="ml-10 font_2">{{ item.phone }}</text>
</view>
<view class="flex-col justify-start items-center text-wrapper_2" v-if="item.isDefault == 1"><text
class="text_2">默认</text></view>
<view class="flex-row pos">
<image class="image"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FFeFCTttf-edit.png"
@click="editContact(item)"
/>
<image class="ml-12 image"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FpTAxfBXp-delete.png"
@click="showModal(item.id)" />
</view>
</view>
</view>
</view>
<view class="flex-col justify-start items-center relative section_2">
<view class="flex-col justify-start items-center text-wrapper_3" @click="loadPop()"><text
class="font text_3">新增联系人</text></view>
</view>
</view>
<uni-popup ref="popup" background-color="#fff" :mask-click="false">
<view class="popup-content">
<contactPopVue></contactPopVue>
</view>
</uni-popup>
</template>
<script setup>
import { ref, onMounted, nextTick } from 'vue'
import { baseUrl } from '../../../api/request'
import { onShow, onLoad } from "@dcloudio/uni-app";
import emitter from '../../../utils/emitter';
import contactPopVue from '../component/contactPop.vue'; //
const ContactArr = ref() //
const popup = ref(null) //
onMounted(() => {
getContactInfo() //
emitter.on('close',()=>{
close()
})
emitter.on('updateInfo',()=>{ //
getContactInfo()
})
})
onShow(()=>{
getContactInfo() //
})
const getContactInfo = async () => {
const res = await uni.request({
url: baseUrl + '/contacts/list',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
}
})
// console.log('---->', res.data.data);
if (res.data.code === 1) {
ContactArr.value = res.data.data
} else {
uni.showToast({
icon: 'error',
title: "服务错误"
})
}
}
const deleteContact = async (cid) => { //
const res = await uni.request({
url: baseUrl + '/contacts/delete',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: { id: cid }
})
if (res.data.code === 1) {
getContactInfo()
}
}
const showModal = (cid) => { //
uni.showModal({
title: '提示',
content: '是否删除该联系人',
success: (e) => {
if (e.confirm) {
deleteContact(cid)
} else if (e.cancel)
return;
}
})
}
const loadPop =() => { //
popup.value.open('bottom') //
}
//
const editContact =(value)=>{
console.log('联系人信息--->',value);
emitter.emit('contactInfo',value) //
loadPop() //
}
const close =()=> {
nextTick(()=>{
if(popup.value) {
popup.value.close()
}
})
}
</script>
<style lang="scss" scoped>
.page {
height: 100vh;
width: 100%;
background-image: url('https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FQfLHXSAU-feiyigongfangbeijin.png');
background-size: 100% 100%;
overflow-y: auto;
overflow-x: hidden;
}
.section {
padding-bottom: 20rpx;
background-repeat: no-repeat;
}
.text-wrapper {
position: fixed;
left: 0;
right: 0;
top: 0;
padding: 22.5rpx 0;
background-color: #ffffff;
z-index: 1;
}
.text {
color: #000000;
font-size: 37.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 36.47rpx;
}
.list {
padding: 0 18.75rpx;
margin-bottom: 100rpx;
}
.list-item {
padding: 45.75rpx 18.75rpx 45.75rpx 26.25rpx;
background-color: #ffffff;
border-radius: 9.38rpx;
height: 90rpx;
}
.list-item:first-child {
margin-top: 40px;
}
.pos_2 {
position: absolute;
left: 25.11rpx;
top: 50%;
transform: translateY(-50%);
}
.font {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.89rpx;
color: #323232;
}
.font_2 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 20.04rpx;
color: #323232;
}
.text-wrapper_2 {
padding-bottom: 7.5rpx;
background-color: #ffbe55;
border-radius: 9.38rpx;
width: 71.06rpx;
}
.text_2 {
color: #ffffff;
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 18.71rpx;
margin-top: 8rpx;
}
.pos {
position: absolute;
right: 18.28rpx;
top: 50%;
transform: translateY(-50%);
}
.image {
border-radius: 9.38rpx;
width: 41.25rpx;
height: 39.38rpx;
}
.section_2 {
position: fixed;
left: 0;
right: 0;
bottom: 0;
// margin-top: -35.63rpx;
padding: 16.88rpx 0;
background-color: #ffffff;
}
.text-wrapper_3 {
padding: 26.25rpx 0;
background-color: #fbdedf;
border-radius: 46.88rpx;
width: 639.23rpx;
}
.text_3 {
color: #c35c5d;
line-height: 29.18rpx;
}
.popup-content {
height: 500rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -0,0 +1,225 @@
<template>
<!-- 添加联系人页面 -->
<view class="flex-row relative page">
<text class="text pos_2">添加联系人</text>
<image class="image pos" src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FNWbQGniG-closed.png" @click="closePop()"/>
<view class="flex-col section_2 pos_3">
<view class="flex-row items-center group">
<text class="font_2 text_2">姓名</text>
<input class="section_1 ml-44" placeholder="请输入姓名" v-model="contactParam.name"/>
</view>
<view class="flex-row items-center group_1">
<text class="font_2">手机号码</text>
<input class="view_2 ml-13" placeholder="输入手机号码" v-model="contactParam.phone"/>
</view>
<view class="flex-row justify-between items-center group_2">
<checkbox-group @change="defaultAddress">
<text class="font_2 text_5" style="margin-right: 400rpx;">设为默认联系人</text>
<checkbox class="round red radius" value="1" />
</checkbox-group>
</view>
</view>
<view class="flex-col justify-start items-center text-wrapper_2 pos_4" @click="newContact"><text class="text_6">保存联系人</text></view>
</view>
</template>
<script setup>
import {ref , onMounted} from 'vue'
import { testUrl , baseUrl , suiUrl } from '../../../api/request';
import { onLoad, onShow } from '@dcloudio/uni-app';
import emitter from '../../../utils/emitter';
const contactParam = ref({
name: "",
phone: "",
isDefault: 0
})
//
onLoad(()=>{
})
onShow(()=>{
})
onMounted(()=>{
emitter.on('contactInfo',(val)=>{
console.log('当前编辑的联系人信息',val);
if(val != null) {
contactParam.value.id = val.id
contactParam.value.name = val.name
contactParam.value.phone = val.phone
contactParam.value.isDefault = val.isDefault
}
})
})
//
const defaultAddress =(event)=>{
event.detail.value[0] ? contactParam.value.isDefault = 1 : contactParam.value.isDefault = 0
}
//
const newContact = async () =>{
console.log('按钮联系人信息--->',contactParam.value);
if(contactParam.value.id === "")
delete contactParam.value.id
const values = Object.values(contactParam.value);
// 使some()
if (values.some(value => value === null || value === undefined || value === '')) {
await uni.showToast({
icon: 'error',
title: "字段不能为空"
})
return;
}
console.log(contactParam.value);
if(contactParam.value.id != undefined) {
const res = await uni.request({
url: baseUrl + '/contacts/update',
method: 'POST',
header: {
'cookie': wx.getStorageSync('cookie')
},
data: { ...contactParam.value }
})
console.log('res1==>',res.data);
sucRes(res.data.code)
} else {
const res = await uni.request({
url: baseUrl + '/contacts/add',
method: 'POST',
header: {
'cookie': wx.getStorageSync('cookie')
},
data: {
name: contactParam.value.name,
phone: contactParam.value.phone,
isDefault: contactParam.value.isDefault
}
})
console.log('res2==>',res.data);
sucRes(res.data.code)
}
}
const sucRes =(res)=>{ //
if(res === 1) {
emitter.emit('updateInfo')
closePop()
} else {
uni.showToast({
icon: 'error',
title: '新增联系人失败'
})
return;
}
}
const closePop = () =>{ //
contactParam.value.name = ""
contactParam.value.phone = ""
contactParam.value.isDefault = 0
emitter.emit('closeContactPop')
}
</script>
<style lang="scss" scoped>
.ml-13 {
margin-left: 24.38rpx;
}
.page {
padding: 18.75rpx 24.38rpx 30rpx 31.88rpx;
background-color: #ffffff;
background-image: url('https://ide.code.fun/api/image?token=67be64de4ae84d0012274ced&name=44b4c9443569fdae44bb581d89efdadd.png');
background-size: 100% 100%;
background-repeat: no-repeat;
height: 100vh;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
}
.text {
color: #323232;
font-size: 37.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 36.47rpx;
}
.pos_2 {
position: absolute;
right: 274.86rpx;
top: 28.5rpx;
}
.image {
width: 52.5rpx;
height: 52.5rpx;
}
.pos {
position: absolute;
right: 24.38rpx;
top: 18.75rpx;
}
.section_2 {
padding: 12.19rpx 16.88rpx 0;
background-color: #ffffff;
border-radius: 9.38rpx;
}
.pos_3 {
position: absolute;
left: 31.88rpx;
right: 31.88rpx;
top: 101.25rpx;
}
.group {
padding: 14.06rpx 4.58rpx 12.19rpx;
border-bottom: solid 1.88rpx #efefef;
}
.font_2 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 24.62rpx;
color: #323232;
}
.text_2 {
line-height: 23.17rpx;
}
.section_1 {
flex: 1 1 0;
margin-right: 34.8rpx;
}
.group_1 {
padding: 14.06rpx 4.26rpx 12.19rpx;
border-bottom: solid 1.88rpx #efefef;
}
.view_2 {
flex: 1 1 0;
margin-right: 35.12rpx;
}
.group_2 {
padding: 15.47rpx 5.29rpx 22.03rpx;
}
.text_5 {
line-height: 25.54rpx;
}
.image_2 {
margin-right: 17.63rpx;
width: 33.75rpx;
height: 33.75rpx;
}
.text-wrapper_2 {
padding: 26.03rpx 0 29.27rpx;
background-color: #ffb6b9;
border-radius: 75rpx;
width: 639.38rpx;
}
.pos_4 {
position: absolute;
left: 50%;
top: 370.63rpx;
transform: translateX(-50%);
}
.text_6 {
color: #ffffff;
font-size: 33.75rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 32.83rpx;
}
.radius {
transform: scale(0.7);
width: 37.5rpx;
height: 37.5rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -113,7 +113,7 @@ onMounted(() => {
// }
const goToText = () => { //
uni.navigateTo({
url: '/pages/mine/Contact/Contact'
url: '/pages/mine/Contact/testContact'
})
}
const goTo = ()=>{ //

View File

@ -2,7 +2,7 @@
<view class="flex-col page">
<view class="flex-row justify-center items-center relative group">
<text class="text">收货地址</text>
<image class="image pos" @click="close"
<image class="image pos" @click="closeWindow"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FxSHTnKhk-close.png" />
</view>
<view class="flex-col list">
@ -10,10 +10,6 @@
<view class="flex-col list-item_1" v-for="(item, index) in addressList" :key="index">
<view class="flex-row justify-between items-center self-stretch">
<view class="flex-row items-center">
<!-- <image
class="shrink-0 image_2"
src="https://ide.code.fun/api/image?token=6726d42bc471750012ddd6db&name=77acc0c7f94beb4408728eee129ffe97.png"
/> -->
<radio color="#00ba9c" :value="index" :checked="index === current"></radio>
<text class="font ml-9">{{ item.name }}</text>
<text class="font_2 ml-9">{{ item.phone }}</text>
@ -38,7 +34,7 @@
</template>
<script setup>
import { onMounted , ref } from 'vue'
import {nextTick, onMounted , ref } from 'vue'
import emitter from '../../../utils/emitter'
import { testUrl , baseUrl , suiUrl } from '../../../api/request';
import { onShow } from "@dcloudio/uni-app";
@ -46,7 +42,6 @@ const items = ref([null, null])
const addressList = ref([])
const userInfo = wx.getStorageSync('userInfo')
// onShow
onMounted(() => {
getAddressList()
})
@ -65,17 +60,13 @@ const getAddressList = async () =>{
console.log('组件的地址信息---->',res.data);
addressList.value = res.data.data
}
//
const close = () => {
emitter.emit('closeAddress')
}
//
const radioChange = ( event ) => {
const index = event.detail.value
const temp = addressList.value[index] //emitter
// console.log('temp',temp);
emitter.emit('addressInfo', temp )
emitter.emit('closeAddress')
emitter.emit('addressInfo', temp)
emitter.emit('close')
}
//
const toNewAddress =()=>{
@ -106,6 +97,11 @@ const deleteAddress = async( id ) =>{
// console.log("");
}
}
//
const closeWindow =()=> {
emitter.emit('close')
}
</script>
<style lang="scss" scoped>

View File

@ -0,0 +1,246 @@
<template>
<!-- 订单的联系人选择页面 -->
<view class="flex-col page">
<view class="flex-row justify-between self-end group">
<text class="text">联系人信息</text>
<image
class="image"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FMoAZrjKE-close.png"
@click="closeWindow()"
/>
</view>
<view class="flex-col self-stretch mt-22">
<radio-group @change="radioChange">
<view
class="flex-row justify-between items-center section list-item mt-8"
v-for="(item, index) in ContactArr"
:key="index"
>
<view class="flex-row items-center">
<radio color="#E79EA1" :value="index" :checked="index === current"></radio>
<text class="font ml-9">{{ item.name }}</text>
<text class="font_2 ml-9">{{ item.phone }}</text>
</view>
<view class="flex-row group_2">
<image
class="image_2"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FFeFCTttf-edit.png"
@click="editContact(item)"
/>
<image
class="image_2 ml-12"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FpTAxfBXp-delete.png"
@click="showModal(item.id)"
/>
</view>
</view>
</radio-group>
</view>
<view class="flex-col justify-start items-center self-stretch text-wrapper mt-22">
<text class="text_2" @click="loadPop()">添加联系人</text>
</view>
</view>
<uni-popup ref="popup" background-color="#fff" :mask-click="false">
<view class="popup-content">
<contactPopVue></contactPopVue>
</view>
</uni-popup>
</template>
<script setup>
import { ref, onMounted, nextTick } from 'vue'
import { baseUrl } from '../../../api/request'
import { onShow, onLoad } from "@dcloudio/uni-app";
import emitter from '../../../utils/emitter';
import contactPopVue from '../../mine/component/contactPop.vue'; //
const ContactArr = ref() //
const popup = ref(null) //
onMounted(() => {
getContactInfo() //
emitter.on('closeContactPop',()=>{
closeContactPop()
})
emitter.on('updateInfo',()=>{
getContactInfo()
})
})
onShow(()=>{
getContactInfo() //
})
onLoad(()=>{
getContactInfo()
})
const getContactInfo = async () => {
const res = await uni.request({
url: baseUrl + '/contacts/list',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
}
})
// console.log('---->', res.data.data);
if (res.data.code === 1) {
ContactArr.value = res.data.data
} else {
uni.showToast({
icon: 'error',
title: "服务错误"
})
}
}
const deleteContact = async (cid) => { //
const res = await uni.request({
url: baseUrl + '/contacts/delete',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: { id: cid }
})
if (res.data.code === 1) {
getContactInfo()
}
}
const showModal = (cid) => { //
uni.showModal({
title: '提示',
content: '是否删除该联系人',
success: (e) => {
if (e.confirm) {
deleteContact(cid)
} else if (e.cancel)
return;
}
})
}
const loadPop =() => { //
popup.value.open('bottom') //
}
//
const editContact =(value)=>{
console.log('联系人信息--->',value);
emitter.emit('contactInfo',value) //
loadPop() //
}
//
const radioChange = ( event ) => {
console.log('选中---->',event);
const index = event.detail.value
const temp = ContactArr.value[index]
console.log('联系人是---->',ContactArr.value[index]);
emitter.emit('contactsNowInfo',temp) //
emitter.emit('close')
}
//---
const closeContactPop = () => {
nextTick(() => {
if (popup.value) {
popup.value.close()
}
})
}
const closeWindow =()=> {
emitter.emit('close')
}
</script>
<style lang="scss" scoped>
.ml-9 {
margin-left: 16.88rpx;
}
.page {
padding: 24.75rpx 12.84rpx 33.75rpx 13.13rpx;
background-color: #f5f5dc;
border-radius: 28.13rpx 28.13rpx 0rpx 0rpx;
background-image: url('https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FQfLHXSAU-feiyigongfangbeijin.png');
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100vh;
}
.group {
position: fixed;
left: 0;
right: 0;
top: 0;
// margin-right: 17.16rpx;
width: 100%;
background-color: white;
z-index: 1;
padding: 20rpx 20rpx 20rpx 270rpx;
}
.text {
margin-bottom: 2.53rpx;
color: #323232;
font-size: 37.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 36.47rpx;
}
.image {
width: 37.5rpx;
height: 37.5rpx;
}
.section {
padding: 54.38rpx 16.22rpx 52.5rpx;
background-color: #ffffff;
border-radius: 26.25rpx;
border-bottom: solid 1.88rpx #c8c8c8;
}
.list-item:first-child {
margin-top: 14px;
}
.list-item:last-child {
margin-bottom: 700rpx;
}
.image_3 {
width: 31.88rpx;
height: 33.75rpx;
}
.font {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.89rpx;
color: #323232;
}
.font_2 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 20.04rpx;
color: #323232;
}
.group_2 {
margin-right: 11.12rpx;
}
.image_2 {
width: 37.5rpx;
height: 39.38rpx;
}
.text-wrapper {
position: fixed;
left: 0;
right: 0;
bottom: 20px;
margin-left: 39.38rpx;
margin-right: 45.28rpx;
padding: 26.03rpx 0 29.27rpx;
background-color: #ffb6b9;
border-radius: 75rpx;
}
.text_2 {
color: #ffffff;
font-size: 33.75rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 32.83rpx;
}
.radius {
transform: scale(0.7);
width: 37.5rpx;
height: 37.5rpx;
}
.popup-content {
height: 500rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -156,7 +156,7 @@
</template>
<script setup>
import {onMounted, ref, toRaw} from 'vue'
import {nextTick, onMounted, ref, toRaw} from 'vue'
import emitter from '../../../utils/emitter'
import { onLoad , onShow } from "@dcloudio/uni-app";
import { baseUrl } from '../../../api/request';
@ -184,7 +184,7 @@ onMounted(() => {
close()
})
//
emitter.on('FangZhengFonts', (val) =>{
emitter.on('addressInfo', (val) =>{
addressRealInfo.value = val
})
})
@ -201,7 +201,11 @@ onShow(()=>{
})
//
const close = () => {
popup.value.close()
nextTick(() => {
if (popup.value) {
popup.value.close()
}
})
}
//
const loadPop =() =>{

View File

@ -0,0 +1,638 @@
<template>
<!-- 批量服务类商品购买 -->
<view class="flex-col page">
<view class="flex-row justify-between items-center section_2">
<view class="flex-row items-center">
<image
class="shrink-0 image"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FXymRmdOc-lianxiren.png"
/>
<text class="text ml-10">{{ contactRealInfo.name }} {{ contactRealInfo.phone }}</text>
</view>
<view class="flex-row items-center group" @click="loadPop()">
<image
class="image_2"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FKgDGnwlb-right.png"
/>
<text class="font text_2">更换联系人</text>
</view>
</view>
<view class="flex-col section_3">
<view class="flex-col">
<view class="flex-row items-end list-item mt-13" v-for="(item, index) in productArr" :key="index">
<image
class="shrink-0 image_3"
:src="item.cartExperienceGoodVO.goodImg"
/>
<view class="flex-col flex-1 group_5">
<view class="flex-row self-stretch group_3">
<!-- <text class="font">{{ item.cartExperienceGoodVO }}</text> -->
<text class="font text_3">{{ item.cartExperienceGoodVO.type }} {{item.cartExperienceGoodVO.name}} </text>
</view>
<text class="self-start font_2 text_7 mt-9">已选时间{{ item.reservationDate }}星期二</text>
<text class="self-start font_3 text_8 mt-9">{{ item.timeSlot }}</text>
<view class="flex-row justify-between items-end self-stretch mt-9">
<view class="flex-row items-center">
<!-- <image
class="shrink-0 image_6"
src="https://ide.code.fun/api/image?token=67be64de4ae84d0012274ced&name=4a3c5c3a5c83be7a7b0551c598ed6037.png"
/> -->
<text class="font_5 ml-3">{{ item.cartExperienceGoodVO.price }}</text>
<!-- <text class="font_6 ml-3">00</text> -->
</view>
<image
class="image_4"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FDuKxtYum-short.png"
@click="shortNum(index)"
/>
</view>
</view>
<view class="flex-row shrink-0 group_4">
<view class="flex-col justify-start items-center text-wrapper"><text class="font_4 text_6">{{ item.quantity }}</text></view>
<image
class="image_5 ml-2"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FIOMGjSNx-add.png"
@click="addNum(index)"
/>
</view>
</view>
</view>
<view class="flex-row justify-center items-center group_9 mt-15">
<view class="group_10">
<text class="font_7 text_11">购买商品均视为同意</text>
<text class="font_7 text_12">用户须知</text>
</view>
<image
class="image_7 ml-2"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FcoxrJLJf-quesrion.png"
/>
</view>
</view>
<view class="flex-col section_4">
<view class="flex-row justify-between items-center">
<view class="flex-row">
<text class="font_8 text_13">商品总价</text>
<text class="font_9 ml-7">{{ productArr.length }}件商品</text>
</view>
<view class="flex-row items-center group_11">
<!-- <image
class="shrink-0 image_8"
src="https://ide.code.fun/api/image?token=67be64de4ae84d0012274ced&name=eb4f44af1db8b709d9d4b2aecf5159be.png"
/> -->
<text class="font_10">{{ sumprice.toFixed(2) }}</text>
</view>
</view>
<view class="flex-row justify-between mt-34">
<text class="font_8">优惠券</text>
<view class="flex-row group_12">
<text class="font_9">0张优惠券可用</text>
<image
class="shrink-0 image_9 ml-3"
src="https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FHomvnulG-rightblack.png"
/>
</view>
</view>
<view class="flex-row justify-between items-center mt-34">
<text class="font_8 text_14">合计</text>
<view class="flex-row items-center group_13">
<!-- <image
class="shrink-0 image_8"
src="https://ide.code.fun/api/image?token=67be64de4ae84d0012274ced&name=0f3f4f80197a7b3647f307901f6a3bea.png"
/> -->
<text class="font_10">{{ sumprice.toFixed(2) }}</text>
</view>
</view>
</view>
<view class="flex-col section_5">
<text class="self-start font_8 text_15">订单备注</text>
<view class="flex-col justify-start items-start self-stretch text-wrapper_2 mt-11">
<text class="font_7 text_16">备注建议提前协商250字以内</text>
</view>
</view>
<view class="flex-row justify-between items-center section_6">
<view class="flex-row items-center">
<image
class="shrink-0 image_8 image_10"
src="https://ide.code.fun/api/image?token=67be64de4ae84d0012274ced&name=549b29459342a9a09d24834be40eb53b.png"
/>
<text class="text_17">应付</text>
<text class="text_18">{{ sumprice.toFixed(2) }}</text>
<!-- <text class="text_20">00</text> -->
</view>
<view class="flex-col justify-start items-center text-wrapper_3"><text class="font_8 text_19">微信支付</text></view>
</view>
</view>
<uni-popup ref="popup" background-color="#fff" :mask-click="false">
<view class="popup-content">
<contactsComponentVue></contactsComponentVue>
</view>
</uni-popup>
</template>
<script setup>
import {nextTick, onMounted, ref, toRaw} from 'vue'
import emitter from '../../../utils/emitter'
import { onLoad , onShow } from "@dcloudio/uni-app";
import { baseUrl } from '../../../api/request';
import { stateMap } from '../../../common/global';
import { sum } from 'mathjs';
import contactsComponentVue from '../component/contactsComponent.vue'; //
//
const sumprice = ref(0) //
const popup = ref(null) //
const contactRealInfo = ref({
name: '请选择联系人'
}) //
const productArr = ref([]) //
const labelList = ref([]) //
const userInfo = wx.getStorageSync('userInfo') //
const orderItemList = ref({})
const totalInfo = ref([]) //
const note = ref('')
const postCartArr = ref([])
onMounted(() => {
getFonts()
//
emitter.on('close', () => {
close()
})
//
emitter.on('contactsNowInfo', (val) =>{
contactRealInfo.value = val
})
})
onLoad((options)=>{
totalInfo.value = JSON.parse(options.cartInfo)
console.log('options.cartInfo-->',JSON.parse(options.cartInfo));
console.log('totalInfo.value-->',toRaw(totalInfo.value) );
getProduct() //
})
onShow(()=>{
userInfo.value = wx.getStorageSync('userInfo') //
getDefaultAddress()
// computed()
})
//
const close = () => {
nextTick(() => {
if (popup.value) {
popup.value.close()
}
})
}
//
const loadPop =() =>{
popup.value.open('bottom')
}
//
// const getDefaultAddress = async () =>{
// const res = await uni.request({
// url: baseUrl + '/address/list',
// method: 'POST',
// header: {
// cookie: wx.getStorageSync('cookie')
// }
// })
// //for
// for(let key in res.data.data) {
// if(res.data.data[key].isDefault === 1) {
// contactRealInfo.value = res.data.data[key]
// }
// }
// }
const createOrder = async () => { //
console.log('地址信息-->',contactRealInfo.value);
formatArr()
console.log('postCartArr--->',postCartArr.value);
const resOrder = await uni.request({ //
url: baseUrl + '/order/add/cart',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: {
orderType: productArr.value[0].cartExperienceGoodVO.type === '服务类' ? 'service' : 'product',
userName: userInfo.userName,
addressId: addressRealInfo.value.id, //id
// contactsId: null, //id
couponId: null, //id
note: note.value,
cartOrderItemAddRequestList: toRaw(postCartArr.value)
}
})
console.log('后台返回订单响应==>',resOrder.data);
if(resOrder.data.code === 1) {
wxPay(resOrder.data.data)
}
}
//id
const getProduct = async ()=> {
const res = await uni.request({
url: baseUrl + '/cartExperience/submit/list',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: {
idList: totalInfo.value
}
})
console.log('展示订单页面的商品信息-->',res.data);
if( res.data.code === 1 ) {
dealRes(res)
}
}
const dealRes =(res)=> { //
productArr.value = res.data.data
console.log('productArr--->',productArr.value);
productArr.value.forEach((item)=>{
sumprice.value += item.cartExperienceGoodVO.price * item.quantity //
})
}
//
const shortNum = (index)=>{
if(productArr.value[index].quantity > 1) {
productArr.value[index].quantity -= 1
//
sumprice.value -= productArr.value[index].cartExperienceGoodVO.price * 1
}
}
//
const addNum = (index)=>{
if( productArr.value[index].quantity < productArr.value[index].cartExperienceGoodVO.inventory ) { //
productArr.value[index].quantity += 1
sumprice.value += productArr.value[index].cartExperienceGoodVO.price * 1 //
}
}
const formatArr = () =>{
postCartArr.value.splice(0,postCartArr.value.length)
productArr.value.forEach((item,index)=>{
postCartArr.value.push({
cartRecordId: totalInfo.value[index],
quantity: item.quantity
})
})
}
const wxPay = async( oid )=> { //id
console.log('oid--->',oid);
try {
const res = await uni.request({
url: baseUrl + '/wechat/payment/create',
method: 'POST',
header: {
'cookie': wx.getStorageSync("cookie")
},
data: { id: oid }
})
const paymentData = res.data.data
wx.requestPayment({
appid: paymentData.appId,
nonceStr: paymentData.nonceStr,
package: paymentData.packageVal,
paySign: paymentData.paySign,
timeStamp: paymentData.timeStamp,
signType: paymentData.signType,
success(res) {
uni.showModal({
content: '支付成功',
showCancel: false
})
uni.redirectTo({
url: '/pages/order/product-paysuccess/product-paysuccess?oid=' + JSON.stringify(oid)
})
console.log('支付成功res--->',res);
},
fail(e) {
// uni.showModal({
// content: ':' + e.errMsg,
// showCancel: false
// })
uni.redirectTo({
url: '/pages/order/product-paysuccess/product-paysuccess?oid=' + JSON.stringify(oid)
})
console.log('e.errMsg--->',e.errMsg);
}
})
}catch(error) {
console.error('支付请求失败',error);
uni.showModal({
content: '支付请求失败,请重试。',
showCancel: false
})
}
}
const textAssign = (e) => { //
note.value = e.detail.value
// console.log('note--->',note.value);
}
//
const getFonts =()=>{
uni.loadFontFace({
family: 'FangZhengFonts',
source: `url("https://carbon2.obs.cn-north-4.myhuaweicloud.com/fonts/FangZhengFonts.TTF")`,
success:(res) =>{
console.log('success',res);
},
fail:(err) => {
console.log('err',err);
}
})
}
</script>
<style lang="scss" scoped>
.mt-13 {
margin-top: 24.38rpx;
}
.mt-9 {
margin-top: 16.88rpx;
}
.mt-15 {
margin-top: 28.13rpx;
}
.ml-7 {
margin-left: 13.13rpx;
}
.ml-3 {
margin-left: 5.63rpx;
}
.mt-11 {
margin-top: 20.63rpx;
}
.page {
padding-top: 24.38rpx;
background-color: #f8e8c1;
background-image: url('https://carbon2.obs.cn-north-4.myhuaweicloud.com:443/feiyi%2Ftest%2F0%2FQfLHXSAU-feiyigongfangbeijin.png');
background-size: 100% 100%;
background-repeat: no-repeat;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100vh;
}
.section_2 {
margin-left: 24.38rpx;
margin-right: 22.5rpx;
padding: 20.63rpx 23.08rpx 24.98rpx 27.54rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
}
.image {
width: 65.63rpx;
height: 67.5rpx;
}
.text {
color: #818181;
font-size: 37.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 32.38rpx;
}
.group {
width: 167.03rpx;
}
.image_2 {
margin-left: 129.53rpx;
width: 37.5rpx;
height: 37.5rpx;
}
.font {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.54rpx;
color: #323232;
}
.text_2 {
margin-left: -167.03rpx;
color: #ffaaa5;
}
.section_3 {
margin: 31.27rpx 15rpx 0 16.88rpx;
padding: 20.63rpx 18.75rpx 24.38rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
}
.list-item:first-child {
margin-top: 0;
}
.image_3 {
border-radius: 9.38rpx;
width: 142.5rpx;
height: 166.88rpx;
}
.group_5 {
margin-left: 30.04rpx;
margin-top: 4.2rpx;
}
.group_3 {
padding: 0 3.83rpx;
}
.text_3 {
line-height: 25.01rpx;
}
.font_2 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.54rpx;
color: #818181;
}
.text_7 {
margin-left: 8.01rpx;
line-height: 24.62rpx;
}
.font_3 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 17.53rpx;
color: #818181;
}
.text_8 {
margin-left: 9.21rpx;
}
.image_6 {
width: 35.63rpx;
height: 30rpx;
}
.font_5 {
font-size: 33.75rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 22.54rpx;
color: #323232;
}
.font_6 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 17.53rpx;
color: #323232;
}
.image_4 {
border-radius: 9.38rpx 0rpx 0rpx 9.38rpx;
width: 45rpx;
height: 45rpx;
}
.group_4 {
margin-left: 3.75rpx;
margin-right: 5.63rpx;
}
.text-wrapper {
padding: 11.31rpx 0 16.46rpx;
background-color: #ffaaa5;
width: 58.13rpx;
height: 45rpx;
}
.font_4 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 17.53rpx;
color: #ffffff;
}
.text_6 {
line-height: 17.23rpx;
}
.image_5 {
border-radius: 0rpx 9.38rpx 9.38rpx 0rpx;
width: 45rpx;
height: 45rpx;
}
.group_9 {
padding: 0 138.81rpx;
}
.group_10 {
line-height: 21.71rpx;
height: 21.71rpx;
}
.font_7 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 22.54rpx;
color: #818181;
}
.text_11 {
line-height: 21.71rpx;
}
.text_12 {
color: #ed4845;
line-height: 21rpx;
}
.image_7 {
width: 26.25rpx;
height: 26.25rpx;
}
.section_4 {
margin: 30rpx 16.88rpx 0 16.88rpx;
padding: 30rpx 19.22rpx 20.63rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
}
.font_8 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 29.18rpx;
color: #323232;
}
.text_13 {
line-height: 28.13rpx;
}
.font_9 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 29.18rpx;
color: #818181;
}
.group_11 {
margin-right: 9.38rpx;
}
.image_8 {
width: 33.75rpx;
height: 33.75rpx;
}
.font_10 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 20.04rpx;
color: #323232;
}
.group_12 {
margin-right: 5.16rpx;
}
.image_9 {
width: 30rpx;
height: 30rpx;
}
.text_14 {
line-height: 27.77rpx;
}
.group_13 {
margin-right: 13.37rpx;
}
.section_5 {
margin: 28.13rpx 15rpx 110rpx 18.75rpx;
padding: 17.81rpx 24.13rpx 22.5rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
}
.text_15 {
color: #000000;
line-height: 29.53rpx;
}
.text-wrapper_2 {
margin-left: 3.99rpx;
margin-right: 3.99rpx;
padding: 22.35rpx 0 115.22rpx;
background-color: #ffefef;
border-radius: 9.38rpx;
}
.text_16 {
margin-left: 21.15rpx;
line-height: 21.81rpx;
}
.section_6 {
position: fixed;
left: 0;
right: 0;
bottom: 0;
// margin-top: 333.75rpx;
padding: 16.88rpx 25.31rpx 15rpx;
background-color: #ffffff;
}
.image_10 {
margin-left: 85.31rpx;
}
.text_17 {
margin-left: -119.06rpx;
color: #000000;
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 26.49rpx;
}
.text_18 {
margin-left: 28.5rpx;
color: #ffaaa5;
font-size: 37.5rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 27.62rpx;
}
.text_20 {
color: #ffaaa5;
font-size: 30rpx;
font-family: Open Sans;
font-weight: 700;
line-height: 22.05rpx;
}
.text-wrapper_3 {
padding: 20.51rpx 0 22.97rpx;
background-color: #ffaaa5;
border-radius: 75rpx;
width: 204.38rpx;
height: 71.25rpx;
}
.text_19 {
color: #ffffff;
line-height: 27.77rpx;
}
.popup-content {
height: 800rpx;
}
@import url(../../../common/css/global.css);
</style>

View File

@ -82,7 +82,7 @@
</template>
<script setup >
import {onMounted, ref} from 'vue'
import {nextTick, onMounted, ref} from 'vue'
import { onLoad , onShow } from "@dcloudio/uni-app";
import { baseUrl } from '../../../api/request';
import emitter from '../../../utils/emitter'
@ -134,7 +134,11 @@ const loadPop =()=>{
}
//
const close =()=>{
popup.value.close()
nextTick(() => {
if (popup.value) {
popup.value.close()
}
})
}
//
const jump_buy =()=> {

View File

@ -1,570 +0,0 @@
<template>
<view class="flex-row relative page">
<view class="flex-row justify-center items-center section_2 pos">
<!-- <image class="image"
src="https://ide.code.fun/api/image?token=67610a10797f850011f30392&name=49977e5fbfb65cc3b62ce79b9d6705a2.png" />
<text class="font text ml-4">搜索订单</text> -->
<input style="width: 90%;" class="search-input" placeholder="请输入商品名称" v-model="searchKeyword" @input="handleSearch" />
</view>
<view class="flex-col section_44">
<view class="flex-row justify-between self-stretch groupp">
<view class="font_22" :class="{ active: orderStatus === '全部', selected: isSelected('全部') }"
@click="changeTab('全部')">
全部
</view>
<view class="font_22" :class="{ active: orderStatus === '待支付', selected: isSelected('待支付') }"
@click="changeTab('待支付')">
待支付
</view>
<view class="font_22" :class="{ active: orderStatus === '待发货', selected: isSelected('待发货') }"
@click="changeTab('待发货')">
待发货
</view>
<view class="font_22" :class="{ active: orderStatus === '已发货', selected: isSelected('已发货') }"
@click="changeTab('已发货')">
已发货
</view>
<view class="font_22" :class="{ active: orderStatus === '已退款', selected: isSelected('已退款') }"
@click="changeTab('已退款')">
售后/退款
</view>
</view>
<view class="flex-col pos_8">
<view class="flex-col section_4 list-item_1 mt-14" v-for="(order, index) in Status.displayedOrders"
:key="order.id" @click="goToText(index)">
<view class="flex-col">
<!-- <text class="self-end font_3 text_5">交易关闭</text> -->
<view class="flex-row items-center self-stretch mt-2">
<text class="font_4">订单编号</text>
<text class="font_5 ml-5">{{order.orderNumber}}</text>
</view>
</view>
<view class="flex-col group">
<view class="flex-row justify-between list-item group_3" v-for="item in order.orderItemList"
:key="item.id">
<view class="flex-row">
<image class="image_2" :src="item.goodSnapshot.goodImg" />
<view class="flex-col self-start group_1 ml-18">
<view class="flex-row self-stretch">
<text class="font">{{ item.goodSnapshot.name }}</text>
<text class="font text_10">{{ item.goodSnapshot.type }}</text>
</view>
<text class="self-start font_7 text_12 mt-36">×1</text>
</view>
</view>
<view class="flex-row items-center self-start group_2">
{{ item.goodSnapshot.price }}
</view>
</view>
</view>
<view class="divider view_1"></view>
<view class="flex-row justify-end group_5">
<view v-if="order.orderStatus==='待支付'" class="font text_18">去支付</view>
<view v-if="order.orderStatus==='待发货'" class="font text_18">取消订单</view>
<view v-if="order.orderStatus==='已发货'" class="font text_18">确认收货</view>
<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>
<image class="image_4 image_5"
src="https://ide.code.fun/api/image?token=67610a10797f850011f30392&name=f10bd62afae3562e9d76103ff6fb0f84.png" />
<text class="font_8 text_17">{{order.totalAmount}}</text>
</view>
<view class="flex-row justify-end group_7">
<view class="flex-col justify-start items-center text-wrapper"><text
class="font text_18">删除记录</text></view>
<view class="flex-col justify-start items-center text-wrapper_2 ml-14">
<text class="font_3">联系客服</text>
</view>
</view>
</view>
</view>
</view>
</view>
</template>
<script setup>
import {
ref,
onMounted,
toRaw
} from 'vue';
import {
baseUrl,
testUrl,
suiUrl
} from '@/api/request';
import { onLoad } from "@dcloudio/uni-app";
const Status = ref({
orderStatus: '全部',
orders: [],
displayedOrders: [],
});
const orderStatus = '';
const currentColor = ref(0);
const isSelected = (tab) => Status.value.orderStatus === tab;
const searchKeyword = ref(''); //
onMounted(async () => {
await Getorder();
// tabdisplayedOrders
if (Status.value.orderStatus === '全部') {
Status.value.displayedOrders = Status.value.orders;
} else {
Status.value.displayedOrders = Status.value.orders.filter((order) => {
switch (Status.value.orderStatus) {
case '待支付':
return order.orderStatus === '待支付'
case '待发货':
return order.orderStatus === '待发货'
case '已发货':
return order.orderStatus === '已发货'
case '已退款':
return order.orderStatus === '已退款'
default:
return false;
}
});
}
});
const userInfo = wx.getStorageSync('userInfo');
const Getorder = async () => {
const res = await uni.request({
url: baseUrl + '/order/list',
method: 'POST',
header: {
cookie: wx.getStorageSync('cookie')
},
data: {
id: userInfo.id,
},
});
if (res.data.code === 1) {
Status.value.orders = res.data.data;
} else {
console.log('没拿到用户数据');
}
};
const zt = ref({
tab: ''
});
onLoad((options) => {
if (options.tab) {
zt.value.tab = JSON.parse(options.tab);
changeTab(zt.value.tab);
}
});
const changeTab = (tab) => {
if (tab === '全部') {
Status.value.displayedOrders = Status.value.orders;
Status.value.orderStatus = '全部';
} else {
Status.value.displayedOrders = Status.value.orders.filter((order) => {
switch (tab) {
case '待支付':
return order.orderStatus === '待支付';
case '待发货':
return order.orderStatus === '待发货';
case '已发货':
return order.orderStatus === '已发货';
case '已退款':
return order.orderStatus === '已退款';
default:
return false;
}
});
Status.value.orderStatus = tab;
}
};
//
const handleSearch = () => {
if (searchKeyword.value.trim() === '') {
// tab
if (Status.value.orderStatus === '全部') {
Status.value.displayedOrders = Status.value.orders;
} else {
Status.value.displayedOrders = Status.value.orders.filter((order) => {
switch (Status.value.orderStatus) {
case '待支付':
return order.orderStatus === '待支付'
case '待发货':
return order.orderStatus === '待发货'
case '已发货':
return order.orderStatus === '已发货'
case '已退款':
return order.orderStatus === '已退款'
default:
return false;
}
});
}
return;
}
const keyword = searchKeyword.value.toLowerCase(); // 便
Status.value.displayedOrders = Status.value.orders.filter((order) => {
return order.orderItemList.some((item) => {
return item.goodSnapshot.name.toLowerCase().includes(keyword);
});
});
};
const goToText = (index) => {
uni.navigateTo({
url: '../../../pages/mine/OrderDetails/OrderDetails?info=' + JSON.stringify(Status.value
.displayedOrders[index]),
})
};
</script>
<style lang="scss" scoped>
.groupp {
padding: 22.5rpx 0 18.75rpx;
}
.section_44 {
padding-left: 33.75rpx;
padding-right: 30rpx;
width: 100%;
height: 120rpx;
margin-top: 80rpx;
}
.ml-5 {
margin-left: 9.38rpx;
}
.font_22.selected {
position: relative;
}
.font_22.selected::after {
content: '';
position: absolute;
bottom: -5px; // 线
left: 0;
right: 0;
height: 2px; // 线
background-color: #f6aaa4; // 线
transition: all 0.3s ease; //
}
.page {
padding: 46.88rpx 22.5rpx 401.25rpx;
background-color: #ffffff;
background-image: url('https://ide.code.fun/api/image?token=67610a10797f850011f30392&name=4ba8389730acda4f67d46a7370efec60.png');
background-size: 100% 100%;
background-repeat: no-repeat;
height: 2073.75rpx;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
}
.section_2 {
padding: 9.38rpx 0;
background-color: #ffffff;
border-radius: 75rpx;
}
.pos {
position: absolute;
left: 35.63rpx;
right: 35.63rpx;
top: 46.88rpx;
}
.image {
width: 37.5rpx;
height: 37.5rpx;
}
.font {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.54rpx;
color: #323232;
}
.text {
color: #c0c0c0;
line-height: 25.84rpx;
}
.font_2 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 28.84rpx;
color: #323232;
}
.font_22 {
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 27.81rpx;
color: #323232;
}
.text_2 {
line-height: 28.48rpx;
}
.pos_2 {
position: absolute;
left: 33.99rpx;
top: 146.36rpx;
}
.text_3 {
line-height: 28.24rpx;
}
.pos_3 {
position: absolute;
left: 147.66rpx;
top: 146.14rpx;
}
.pos_4 {
position: absolute;
left: 295.78rpx;
top: 145.78rpx;
}
.pos_5 {
position: absolute;
right: 214.22rpx;
top: 145.78rpx;
}
.text_4 {
line-height: 29.53rpx;
}
.pos_6 {
position: absolute;
right: 34.22rpx;
top: 147.07rpx;
}
.section_3 {
background-color: #ffaaa5;
width: 73.13rpx;
height: 5.63rpx;
}
.pos_7 {
position: absolute;
left: 30rpx;
top: 182.81rpx;
}
.pos_8 {
position: absolute;
left: 22.5rpx;
right: 30rpx;
top: 217.5rpx;
}
.section_4 {
padding: 34.61rpx 15rpx 31.88rpx;
background-color: #ffffff;
border-radius: 31.88rpx;
}
.list-item_1:first-child {
margin-top: 0;
}
.font_3 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.54rpx;
color: #ffaaa5;
}
.text_5 {
margin-right: 8.08rpx;
line-height: 24.62rpx;
}
.font_4 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 22.14rpx;
color: #818181;
}
.font_5 {
font-size: 22.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 15.04rpx;
color: #818181;
}
.group {
margin-top: 29.21rpx;
}
.list-item:first-child {
margin-top: 0;
}
.image_2 {
border-radius: 9.38rpx;
width: 146.25rpx;
height: 144.38rpx;
}
.group_1 {
margin-top: 2.33rpx;
}
.text_10 {
line-height: 25.01rpx;
}
.font_7 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 19.29rpx;
color: #323232;
}
.text_12 {
margin-left: 5.34rpx;
line-height: 18.73rpx;
}
.group_2 {
margin-right: 8.23rpx;
margin-top: 89.19rpx;
}
.font_6 {
font-size: 33.75rpx;
font-family: Open Sans;
line-height: 25.54rpx;
font-weight: 600;
color: #323232;
}
.text_11 {
margin-left: 25.03rpx;
line-height: 24.88rpx;
}
.image_3 {
margin-left: -90.66rpx;
width: 30rpx;
height: 26.25rpx;
}
.font_8 {
font-size: 26.25rpx;
font-family: Open Sans;
line-height: 19.29rpx;
font-weight: 600;
color: #323232;
}
.text_13 {
margin-left: 61.14rpx;
}
.divider {
background-color: #dad2d2;
height: 0.81rpx;
}
.view_1 {
margin: 30.43rpx 28.13rpx 0 39.38rpx;
}
.group_5 {
margin-top: 49.41rpx;
padding: 0 21.21rpx;
color: #ffaaa5;
}
.font_9 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 25.54rpx;
color: #000000;
}
.text_14 {
line-height: 24.62rpx;
}
.text_15 {
margin-top: 2.17rpx;
line-height: 24rpx;
}
.view {
margin-top: 19.93rpx;
padding: 0 19.54rpx;
}
.text_16 {
margin-right: 6.99rpx;
line-height: 24.3rpx;
}
.image_4 {
width: 31.88rpx;
height: 30rpx;
}
.image_5 {
margin-right: -8.29rpx;
}
.text_17 {
color: #ffaaa5;
line-height: 19.39rpx;
}
.group_7 {
margin-top: 52.5rpx;
padding: 0 9.38rpx;
}
.text-wrapper {
padding: 13.86rpx 0 13.52rpx;
background-color: #fffef8;
border-radius: 75rpx;
width: 155.63rpx;
height: 56.25rpx;
border: solid 1.88rpx #cbcbcb;
}
.text_18 {
line-height: 25.13rpx;
}
.text-wrapper_2 {
padding: 13.46rpx 0 13.5rpx;
background-color: #fffef8;
border-radius: 75rpx;
width: 155.63rpx;
height: 56.25rpx;
border: solid 1.88rpx #ffaaa5;
}
.group_3 {
margin-top: 15rpx;
}
@import url("../common/css/global.css");
</style>

View File

@ -13,7 +13,7 @@
src="./images/cha.png"
/>
<view class="flex-col items-start self-stretch mt-58">
<text class="text">99</text>
<text class="text">{{ productObject.price }}</text>
<text class="font text_2 mt-14">请选择</text>
</view>
</view>
@ -66,7 +66,7 @@
</view>
</view>
</view>
<view class="flex-col justify-start items-center text-wrapper_3"><text class="font text_8">下一步</text></view>
<view class="flex-col justify-start items-center text-wrapper_3" @click="addCart"><text class="font text_8">加入购物车</text></view>
</view>
<uni-popup ref="tip" :animation="false" @maskClick="maskClosehandler">
@ -92,7 +92,7 @@
const cookie = wx.getStorageSync("cookie") //
const appIdx = ref(0)
const cnt = ref(1)
const productObject = ref({})
const productObject = ref()
const appointmentDateVOList = ref([])
let appointmentDate = ''
@ -107,6 +107,7 @@
closeyyxzTip()
emitter.on('getGoodData', (val) => {
productObject.value = val
// console.log('');
appointmentDateVOList.value = val.appointmentDateVOList
selectObj.value = new Array(appointmentDateVOList.value.length).fill(null).map(() => ({
backgroundColor: '#fff',
@ -130,9 +131,9 @@
}
})
emitter.on('getBookingNumberMap', (val:any) => {
emitter.on('getBookingNumberMap', (val:any) => { //map
countMap = val
console.log("==============>", val)
console.log("val==============>", val)
appointmentDate = appointmentDateVOList.value[appIdx.value].specificDate;
})
})
@ -141,7 +142,43 @@
const maskClosehandler = () => {
}
const addCart = async () =>{ //
console.log('日期--->',appointmentDate,'时间段--->',timeSlot,'数量--->',cnt.value,'商品id---->',productObject.value.id);
if(appointmentDate === '' || timeSlot === '' ) {
await uni.showToast({
icon: 'error',
title: "字段不能为空"
})
return;
}
const res = await uni.request({
url: baseUrl + '/cartExperience/add',
method: 'POST',
header: {
'cookie': wx.getStorageSync('cookie')
},
data: {
goodId : productObject.value.id,
quantity : cnt.value,
reservationDate : appointmentDate,
timeSlot : timeSlot
}
})
console.log('加入购物车结果',res);
if(res.data.code === 1) {
uni.showToast({
icon: 'success',
title: "加入购物车成功"
})
close() //
} else {
uni.showToast({
icon: 'error',
title: "服务错误"
})
}
}
@ -157,7 +194,7 @@
tip.value.open()
}
const add = () => {
const add = () => { //
if (restNumber.value === '请选择时间段') {
uni.showToast({
title: '请选择时间段',
@ -170,21 +207,22 @@
}
}
const sub = () => {
const sub = () => { //
if (cnt.value > 1) {
cnt.value --
}
}
const close = () => {
const close = () => { //
emitter.emit('closeTimeDialog')
}
const isSelected = (index:any) => {
const isSelected = (index:any) => { //
appIdx.value = index
restNumber.value = '请选择时间段'
appointmentDate = appointmentDateVOList.value[appIdx.value].specificDate;
timeSlot = ''
console.log('appointmentDate===================================>', appointmentDate)
for (var i = 0; i < appointmentDateVOList.value.length; i ++ ) {
if (i == index) {
@ -205,7 +243,7 @@
}
const itemIsSelected = (index:any) => {
const itemIsSelected = (index:any) => { //
timeSlot = appointmentDateVOList.value[appIdx.value].timePeriodVOList[index].timeSlot
restNumber.value = countMap[appointmentDate + '&' + timeSlot]
console.log('timeSlot====================================>', timeSlot)

View File

@ -72,7 +72,7 @@
</template>
<script setup>
import { ref,onMounted } from 'vue'
import { ref,onMounted, nextTick } from 'vue'
import { onLoad } from "@dcloudio/uni-app";
import { baseUrl } from '../../../api/request';
import timeSelectVue from '../component/timeSelect.vue';
@ -132,7 +132,9 @@ const getBookingNumberMap = async () => {
}
const close =()=> { //
popup.value.close()
nextTick(()=>{
popup.value.close()
})
}
const loadPop =()=> {
emitter.emit('getGoodData', productObject.value)