From 03d26aca1b656c03dc4280f85acb1132bd87639d Mon Sep 17 00:00:00 2001
From: xuxueyang <xuxy@fengyuntec.com>
Date: 星期一, 09 九月 2024 23:57:43 +0800
Subject: [PATCH] update 会员信息、兑换商品等

---
 sub_pages/customer/shopping/confirm.vue |  124 ++++++++++++++++++++++++++++++++++++++--
 1 files changed, 116 insertions(+), 8 deletions(-)

diff --git a/sub_pages/customer/shopping/confirm.vue b/sub_pages/customer/shopping/confirm.vue
index c9fda51..f496ad4 100644
--- a/sub_pages/customer/shopping/confirm.vue
+++ b/sub_pages/customer/shopping/confirm.vue
@@ -11,11 +11,55 @@
 				address: state => {
 					return state.defaultaddress || {}
 				},
+				cache_coupon: state => {
+					return state.cache.coupon || {}
+				},
+				cache_goods: state => {
+					return state.cache.goods || []
+				},
 			}),
+			coupon_fee() {
+				//优惠券
+				if (this.dto.couponRecordId && this.cache_coupon) {
+					//计算优惠券
+					if (this.cache_coupon.couponDiscountType === 'zero') {
+						return this.cache_coupon.couponDiscountValue || 0
+					} else if (this.cache_coupon.minOrderAmount && this.cache_coupon.minOrderAmount > 0) {
+						var total = ((dto.totalAmount || 0) + (dto.packing || 0) + (current_transport.fee || 0) || 0)
+							.toFixed(2)
+						if (total >= this.cache_coupon.minOrderAmount) {
+							return this.cache_coupon.couponDiscountValue || 0
+						}
+					} else {
+						return this.cache_coupon.couponDiscountValue || 0
+					}
+				}
+
+				return 0
+			}
+
+		},
+		async beforeDestroy() {
+			await this.$store.dispatch('cache_coupon_select', {})
+			await this.$store.dispatch('cache_goods_select', [])
 
 		},
 		async onShow() {
-
+			//优惠券
+			if (this.cache_coupon && this.cache_coupon.id) {
+				this.dto.couponRecordId = this.cache_coupon.id
+				this.dto.couponRecordStr = this.cache_coupon.couponName
+			}
+			//兑换券
+			this.dto.goodsRecordIdListStr = ''
+			if (this.cache_goods && this.cache_goods.length > 0) {
+				this.dto.goodsRecordIdListStr = ''
+				var names = []
+				for (var tmp of this.cache_goods) {
+					names.push(tmp.name || tmp.title || '')
+				}
+				this.dto.goodsRecordIdListStr = names.join(',')
+			}
 		},
 		onLoad(options) {
 			// console.log('dto',options)
@@ -81,6 +125,9 @@
 					transportId: '',
 					addressId: '',
 					flowers: [],
+					couponRecordId: '',
+					couponRecordStr: '',
+					goodsRecordIdListStr: '',
 				},
 				current_transport: {},
 				cacheAddressId: '',
@@ -109,6 +156,18 @@
 			}
 		},
 		methods: {
+			toSelectCoupon() {
+				//跳转去列表页面进行选择
+				uni.navigateTo({
+					url: '/sub_pages/customer/coupon/coupon-self?source=shopping'
+				})
+			},
+			toSelectGood() {
+				//跳转去列表页面进行选择
+				uni.navigateTo({
+					url: '/sub_pages/customer/coupon/good-self?source=shopping'
+				})
+			},
 			select_need(e) {
 				this.show_select_need = false
 				this.dto.specialNeedsStr = e.value[0].label
@@ -157,6 +216,12 @@
 					return
 				}
 				this.dto.addressId = this.address.id
+				var goodsRecordIds = []
+				if (this.dto.goodsRecordIdListStr) {
+					for (var t of this.cache_goods) {
+						t.push(t.goodsId)
+					}
+				}
 
 				let tmp = this
 				wx.login({
@@ -170,16 +235,21 @@
 							} = await tmp.$http.request('post', '/api/customer/flower/order/commit', {
 								data: {
 									...tmp.dto,
-									wxcode: res.code
+									wxcode: res.code,
+									goodsRecordIdList: goodsRecordIds
 								}
 							})
 							tmp.$message.hideLoading()
 							if (code === 0) {
+								//清空优惠券
+								this.$store.dispatch('cache_coupon_select', {})
+								this.$store.dispatch('cache_goods_select', [])
+
 								//提交信息
 								console.log('pay,', data)
 								// /api/pub/init/callback?orderId=
 								// if(env.pro)
-								if (data && (data['_testV2OrderId'] || data['_testOrderId']) &&
+								if (false && data && (data['_testV2OrderId'] || data['_testOrderId']) &&
 									environments.httpBaseUri.startsWith(
 										'http://47.99.58.211/flower')) {
 									//回调
@@ -201,16 +271,23 @@
 										...data,
 										async success(res) {
 											console.log('pay success', res)
-											tmp.$message.showToast('支付成功')
+											// tmp.$message.showToast('支付成功')
 											//返回上一页
 											await tmp.$store.dispatch('sign_add', 'shopping')
-											uni.navigateBack()
+											tmp.$message.showToast('支付成功')
+											setTimeout(() => {
+												uni.navigateBack()
+											}, 500)
+											// await 
+											// uni.navigateBack()
+
+
 										},
 										async fail(err) {
 											console.error('pay fail', err)
 											tmp.$message.showToast('支付失败')
-											await tmp.$store.dispatch('sign_add', 'shopping')
-											uni.navigateBack()
+											// await tmp.$store.dispatch('sign_add', 'shopping')
+											// uni.navigateBack()
 										}
 									})
 
@@ -328,7 +405,19 @@
 			</view>
 
 			<view class="p10 bg-white m-t-20 br-4">
+				<!-- #ifdef PUB_CUSTOMER_DEV -->
 				<view class="form-item  flex ">
+					<view class="label">优惠券</view>
+
+					<view class="m-l-a m-r-0 flex " :class="[!dto.couponRecordId?'desc-gray':'']"
+						@click="toSelectCoupon">
+						<view>{{dto.couponRecordStr||dto.couponRecordId || '请选择'}}</view>
+						<u-icon class="m-l-a" name="arrow-right"></u-icon>
+					</view>
+				</view>
+				<!-- #endif -->
+
+				<view class="form-item  flex m-t-12">
 					<view class="label">特殊需求</view>
 
 					<view class="m-l-a m-r-0 flex " :class="[!dto.specialNeeds?'desc-gray':'']" @click="()=>{
@@ -348,6 +437,18 @@
 						</view>
 					</view>
 				</view>
+				<!-- #ifdef PUB_CUSTOMER_DEV -->
+				<view class="form-item  flex ">
+					<view class="label">兑换券</view>
+
+					<view class="m-l-a m-r-0 flex "
+						:class="[!dto.goodsRecordIdList||dto.goodsRecordIdList.length==0?'desc-gray':'']"
+						@click="toSelectGood">
+						<view>{{dto.goodsRecordIdListStr|| '请选择'}}</view>
+						<u-icon class="m-l-a" name="arrow-right"></u-icon>
+					</view>
+				</view>
+				<!-- #endif -->
 			</view>
 
 		</view>
@@ -370,6 +471,12 @@
 					{{ (current_transport.fee || 0) }}
 				</view>
 			</view>
+			<view class="desc flex">
+				<view>优惠:</view>
+				<view class="m-l-a m-r-0 text-right">
+					-{{ coupon_fee || 0 }}
+				</view>
+			</view>
 		</view>
 
 
@@ -378,7 +485,8 @@
 		<view class="bottom-price flex">
 			<view class="m-t-12 m-l-0 m-r-a">
 				合计 <span class="t-red">¥
-					{{ (dto.totalAmount || 0) + (dto.packing || 0) + (current_transport.fee || 0) || 0 }} </span>元
+					{{ ((dto.totalAmount || 0) + (dto.packing || 0) + (current_transport.fee || 0) - coupon_fee || 0).toFixed(2) }}
+				</span>元
 			</view>
 			<view class="button-green-1 m-l-a m-r-0" style="min-width: 240rpx" @click="submitOrder">
 				提交订单

--
Gitblit v1.9.3