From 7e738f69cf7b353492edefa1768005f19ea7e7ee Mon Sep 17 00:00:00 2001
From: xuxueyang <xuxy@fengyuntec.com>
Date: 星期三, 28 八月 2024 10:25:11 +0800
Subject: [PATCH] update上线更新

---
 sub_pages/customer/shopping/confirm.vue |  170 ++++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 145 insertions(+), 25 deletions(-)

diff --git a/sub_pages/customer/shopping/confirm.vue b/sub_pages/customer/shopping/confirm.vue
index 776d98d..4ea2671 100644
--- a/sub_pages/customer/shopping/confirm.vue
+++ b/sub_pages/customer/shopping/confirm.vue
@@ -2,6 +2,7 @@
 	import {
 		mapState
 	} from 'vuex'
+	import environments from '@/environments'
 
 	export default {
 		name: "订单详情",
@@ -25,11 +26,50 @@
 				...this.dto,
 				...item
 			}
+			this.$http.request('get', '/api/code/value', {
+				params: {
+					type: 'SPEC_REQ'
+				}
+			}).then(res => {
+				var data = res.data
+				this.need_columns = [data || []]
+				this.need_columns[0].unshift({
+					label: '暂无',
+					value: ''
+				})
+			})
+			if (this.address.id) {
+				this.loadTransportList()
+				this.cacheAddressId = this.address.id
+			}
+			// 
 			//先获取直接的全部地址
 			// @ApiModelProperty(value = "订单商品")
 			//   private List<FlowerCartListDTO> flowers;
 			// @ApiModelProperty(value = "打包费")
 			//   private BigDecimal packing;
+
+			// 两种情况,我合伙人是A,我进入页面前改成了B,我进去后还是获取了A——可以通过
+
+			if (this.currentInfo.customerDTO && this.currentInfo.customerDTO.partnerId) {
+				// 考虑一下,由后台实时获取,如果获取的合伙人id不一样,那么就刷新当前用户信息。
+
+				this.$http.request('get', '/api/current/customer/partner', {
+					params: {
+						// id: this.currentInfo.customerDTO.partnerId
+					}
+				}).then(async res => {
+					if (res.code == 0) {
+						this.partnerInfo = res.data || {}
+						if (this.partnerInfo.id !== this.currentInfo.customerDTO.partnerId) {
+							//刷新用户信息
+							await this.$store.dispatch('getCurrentInfo')
+						}
+					}
+				})
+
+
+			}
 
 		},
 		data() {
@@ -37,6 +77,7 @@
 				dto: {
 					remarks: '',
 					specialNeeds: '',
+					specialNeedsStr: '',
 					transportId: '',
 					addressId: '',
 					flowers: [],
@@ -44,7 +85,11 @@
 				current_transport: {},
 				cacheAddressId: '',
 				transportList: [],
-
+				show_select_need: false,
+				need_columns: [
+					[]
+				],
+				partnerInfo: {},
 
 			}
 		},
@@ -54,13 +99,27 @@
 					this.loadTransportList()
 					this.cacheAddressId = nv.id
 
+				} else if (!nv.id) {
+					//说明id清空了
+					if (!this.cacheAddressId) {
+						transportList = []
+						this.cacheAddressId = ''
+					}
 				}
 			}
 		},
 		methods: {
+			select_need(e) {
+				this.show_select_need = false
+				this.dto.specialNeedsStr = e.value[0].label
+				this.dto.specialNeeds = e.value[0].value
+			},
 			async loadTransportList() {
+				if (this.currentInfo.customerDTO && this.currentInfo.customerDTO.partnerId) {
+					return
+				}
 				let that = this;
-				console.log('address', that.address, that.cacheAddressId)
+				// console.log('address', that.address, that.cacheAddressId)
 				if (that.address && that.address.id && that.cacheAddressId !== that.address.id) {
 					that.$message.showLoading()
 					const {
@@ -82,12 +141,19 @@
 			},
 			async submitOrder() {
 				console.log('submitOrder', this.dto)
-				if (!this.dto.transportId) {
-					this.$message.showToast('请选择配送方式')
-					return
+				if (this.currentInfo.customerDTO && this.currentInfo.customerDTO.partnerId) {
+
+				} else {
+					if (!this.dto.transportId) {
+						this.$message.showToast('请选择配送方式')
+						return
+					}
 				}
+
 				if (!this.address.id) {
-					this.$message.showToast('请选择收货地址')
+					this.$message.showToast('请选择收货地址', {
+						duration: 2000
+					})
 					return
 				}
 				this.dto.addressId = this.address.id
@@ -111,16 +177,25 @@
 							if (code === 0) {
 								//提交信息
 								console.log('pay,', data)
-								if (data && data['_testOrderId']) {
+								// /api/pub/init/callback?orderId=
+								// if(env.pro)
+								if (false && data && (data['_testV2OrderId'] || data['_testOrderId']) &&
+									environments.httpBaseUri.startsWith(
+										'http://47.99.58.211/flower')) {
 									//回调
 									tmp.$message.showLoading()
 									const res2 = await tmp.$http.request('get',
-										'/api/customer/flower/order/callback/tmp', {
+										'/api/pub/init/callback', {
 											params: {
-												id: res2.data['_testOrderId']
+												orderId: data['_testV2OrderId'] || data[
+													'_testOrderId'] || ''
 											}
 										})
 									tmp.$message.hideLoading()
+									tmp.$message.showToast('支付成功')
+									//返回上一页
+									await tmp.$store.dispatch('sign_add', 'shopping')
+									uni.navigateBack()
 								} else if (data) {
 									wx.requestPayment({
 										...data,
@@ -131,9 +206,11 @@
 											await tmp.$store.dispatch('sign_add', 'shopping')
 											uni.navigateBack()
 										},
-										fail(err) {
+										async fail(err) {
 											console.error('pay fail', err)
 											tmp.$message.showToast('支付失败')
+											await tmp.$store.dispatch('sign_add', 'shopping')
+											uni.navigateBack()
 										}
 									})
 
@@ -162,8 +239,8 @@
 		</view>
 		<view>
 			<view class="flower-container m-t-12 br-4 p10">
-				<view class="shopping-item m-b-20" v-for="(item,index) of dto.flowers" :key="index">
-					<u-divider v-if="index>0"></u-divider>
+				<view class="shopping-item " v-for="(item,index) of dto.flowers" :key="index">
+					<!-- <view class="line-gray" v-if></view> -->
 					<view class="sup-title flex">
 						<image class="icon-dp img100 m-r-10" src="/static/common/icon-dp.png"></image>
 						<view>{{ item.supplierName || '-' }}</view>
@@ -191,8 +268,38 @@
 					</view>
 				</view>
 			</view>
+			<view class="p10 bg-white m-t-20 br-4" v-if="partnerInfo&&partnerInfo.id">
+				<view class="form-item  flex ">
+					<view class="label">仓位名称</view>
+					<view class="m-l-a m-r-0 flex desc-gray">
+						<view>{{partnerInfo.cityWarehouse|| '-'}}</view>
+					</view>
+				</view>
+				<view class="form-item  flex ">
+					<view class="label">合伙人名称</view>
+					<view class="m-l-a m-r-0 flex desc-gray">
+						<view>{{partnerInfo.name|| '-'}}</view>
+					</view>
+				</view>
+				<view class="form-item  flex ">
+					<view class="label">联系方式</view>
+					<view class="m-l-a m-r-0 flex desc-gray">
+						<view>{{partnerInfo.contactTel|| '-'}}</view>
+					</view>
+				</view>
+				<view class="form-item  flex ">
+					<view class="label">提货地址</view>
+					<view class="m-l-a m-r-0 flex desc-gray">
+						{{ partnerInfo['province'] || '' }}{{ partnerInfo['city'] && ('/' + partnerInfo['city']) || '' }}{{
+						  partnerInfo['region'] && ('/' + partnerInfo['region']) || ''
+						}}{{partnerInfo.address|| '-'}}
+					</view>
+				</view>
+			</view>
+
 			<!--    查看商品列表,和选择运费 -->
-			<view class="br-4 transform-container m-t-12 p10">
+			<view class="br-4 transform-container m-t-12 p10"
+				v-if="!currentInfo.customerDTO||!currentInfo.customerDTO.partnerId">
 				<view class="title">
 					<view>运输方式:</view>
 					<view class="flex transform-list flex-wrap-normal">
@@ -207,34 +314,35 @@
 						</view>
 					</view>
 				</view>
-				<view class="m-t-20" v-if="false">
+				<view class="m-t-20" v-if="true">
 					<view class="desc-red">
 						10kg以下的零买订单将收取打包费,花店建议购满20kg, 可选冷链物流
 					</view>
 					<view class="desc">
-						预计装1Mini件,运费约18.00元(5公斤内18元,不满5公斤按5公斤计费,每件货不能超过5公斤),第一汤下单预计次日凌晨发货,备货高峰期除外,冷链汽车运输,发货后72小时左右到货,三线城市会推迟6-12小时,顺丰送货到店。
-						优势:价格便宜,顺丰配送
-						弊端:订单必须是5kg以内
+						<!-- 预计装1Mini件,运费约18.00元(5公斤内18元,不满5公斤按5公斤计费,每件货不能超过5公斤), -->
+						第一次下单预计次日凌晨发货,备货高峰期除外,冷链汽车运输,发货后72小时左右到货,三线城市会推迟6-12小时送货到店。
+						<!-- 优势:价格便宜,顺丰配送 -->
+						<!-- 弊端:订单必须是5kg以内 -->
 					</view>
 				</view>
 			</view>
 
 			<view class="p10 bg-white m-t-20 br-4">
-				<view class="form-item  ">
+				<view class="form-item  flex ">
 					<view class="label">特殊需求</view>
-					<view class="m-l-a m-r-0 flex1">
-						<view class="m-t-12 m-b-12">
-							<u-textarea v-model="dto.specialNeeds" placeholder="请输入特殊需求">
 
-							</u-textarea>
-						</view>
+					<view class="m-l-a m-r-0 flex " :class="[!dto.specialNeeds?'desc-gray':'']" @click="()=>{
+						show_select_need=true
+					}">
+						<view>{{dto.specialNeedsStr||dto.specialNeeds || '请选择'}}</view>
+						<u-icon class="m-l-a" name="arrow-right"></u-icon>
 					</view>
 				</view>
 				<view class="form-item  m-t-12 ">
 					<view class="label">留言</view>
 					<view class="m-l-a m-r-0 flex1">
 						<view class="m-t-12 m-b-12">
-							<u-textarea v-model="dto.remarks" placeholder="填写内容需与卖家协商并确认">
+							<u-textarea v-model="dto.remarks" clearable placeholder="填写内容需与卖家协商并确认">
 
 							</u-textarea>
 						</view>
@@ -276,6 +384,9 @@
 				提交订单
 			</view>
 		</view>
+
+		<u-picker :show="show_select_need" @confirm="select_need" keyName="label" :columns="need_columns"
+			@cancel="show_select_need=false"></u-picker>
 	</view>
 </template>
 
@@ -288,6 +399,8 @@
 			background-color: #ffffff;
 			left: 0rpx;
 			padding: 20rpx;
+			z-index: 99;
+			z-index: 11;
 			right: 0rpx;
 			bottom: 0rpx;
 		}
@@ -296,7 +409,7 @@
 			background-color: #ffffff;
 
 			.shopping-item {
-				padding: 28rpx 22rpx;
+				padding: 10rpx 22rpx;
 				position: relative;
 
 				.sup-title {
@@ -372,6 +485,8 @@
 			background-color: #ffffff;
 
 			.transform-list {
+				overflow-x: scroll;
+
 				.transform-item {
 					background: rgba(225, 240, 231, 0.38);
 					border-radius: 8rpx;
@@ -385,6 +500,7 @@
 					margin-right: auto;
 					max-width: 32%;
 					width: 130rpx;
+					min-width: 130rpx;
 
 					.title {
 						font-weight: 400;
@@ -392,6 +508,7 @@
 						color: #000000;
 						line-height: 40rpx;
 						word-break: break-word;
+						min-height: 90rpx
 					}
 
 					.price {
@@ -417,6 +534,9 @@
 				margin-right: 0;
 			}
 
+			.desc-red {}
+
+			.desc {}
 		}
 
 	}

--
Gitblit v1.9.3