You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
			
				
					1281 lines
				
				29 KiB
			
		
		
			
		
	
	
					1281 lines
				
				29 KiB
			| 
											4 months ago
										 | <template> | ||
|  | 	<!-- 解决滚动穿透 --> | ||
|  | 	<page-meta :page-style="'overflow:'+(popShow?'hidden':'visible')"></page-meta> | ||
|  | 	<view class="bg" v-if="info"> | ||
|  | 		<!-- <view class="sendwayArea" :style="{'width': isPost==3?'340rpx':'170rpx'}" v-if="isPost>=1&&isPost<=3"> | ||
|  | 			<view v-if="isPost==1||isPost==3" :class="['sendway-item',info.is_post==1?'active':'']" | ||
|  | 			 @click="info.is_post=1" style="left: -2rpx;">邮寄配送</view> | ||
|  | 			<view v-if="isPost==2||isPost==3" :class="['sendway-item',info.is_post==2?'active':'']"  | ||
|  | 			@click="info.is_post=2" style="right: -2rpx;">到店自提</view> | ||
|  | 			 | ||
|  | 		</view> --> | ||
|  | 		 | ||
|  | 		<!-- 邮寄 --> | ||
|  | 		<view class="address" style="margin-bottom: 36rpx;"> | ||
|  | 			<view class="a-title"> | ||
|  | 				<view>收货地址</view> | ||
|  | 				<view> | ||
|  | 					<view class="more-person flex-center" v-if="addressList.length>0" @click="changeAddressPopup('open', '', null)"> | ||
|  | 						更多<uni-icons style="width: 14rpx;" type="right" size="14"></uni-icons> | ||
|  | 					</view> | ||
|  | 				</view> | ||
|  | 			</view> | ||
|  | 
 | ||
|  | 			<view class="btn-box"> | ||
|  | 				<view class="contacts box" v-if="contacts"> | ||
|  | 					<view class="contacts-left"> | ||
|  | 						<view class="name-phone"> | ||
|  | 							<view class="name">{{ contacts.name }}</view> | ||
|  | 							<view class="phone">{{ contacts.tel }}</view> | ||
|  | 						</view> | ||
|  | 						<view class="adds text-overflowRows">{{ contacts.province_text + contacts.city_text + contacts.district_text + contacts.detail_addr }}</view> | ||
|  | 					</view> | ||
|  | 					<image @click="changeAddressAddPopup('open', '', contacts)" :src="showImg('/uploads/20250514/dd77d7706bc9bffd2bb928d1772e8413.png')" mode="aspectFill"></image> | ||
|  | 				</view> | ||
|  | 				<view v-else class="a-img flex-center" @click.stop="changeAddressAddPopup('open','',{})"> | ||
|  | 					<uni-icons style="width: 32rpx;" type="plusempty" size="14"></uni-icons>添加 | ||
|  | 				</view> | ||
|  | 			</view> | ||
|  | 		</view> | ||
|  | 		 | ||
|  | 		<!-- 自提 --> | ||
|  | <!-- 		<view v-if="info.is_post==2 && info.goods[0]"> | ||
|  | 
 | ||
|  | 			<view class="pickself" > | ||
|  | 				<navigator :url="`/subPackages/techan/selfPickUpPoint?pickupId=${pickupAddress.id}&goodsId=${info.goods[0].skuInfo.goods_id}`"> | ||
|  | 					<view class="pickpoint"> | ||
|  | 						<view class="flex-shrink-0">自提点</view> | ||
|  | 						<view class="pickpointAddress"> | ||
|  | 							<view class="pointAddressText text-overflow">{{pickupAddress.extract_name||'选择提货地址'}}</view> | ||
|  | 							<uni-icons style="height: 36rpx;" type="right" size="18"></uni-icons> | ||
|  | 						</view> | ||
|  | 					</view> | ||
|  | 				</navigator> | ||
|  | 			</view> | ||
|  | 			 | ||
|  | 			<view class="pickup-person-area"> | ||
|  | 				<view class="pickpoint"> | ||
|  | 					<view>提货人信息</view> | ||
|  | 					<view></view> | ||
|  | 				</view> | ||
|  | 
 | ||
|  | 				<view class="btn-box flex-column"> | ||
|  | 					<view class="p_name line flex-between w-full"> | ||
|  | 						<view class="left">姓名</view> | ||
|  | 						<input class="input" type="text" placeholder="请输入提货人姓名" v-model="pickupPerson.name" /> | ||
|  | 					</view> | ||
|  | 					<view class="p_tel flex-between w-full"> | ||
|  | 						<view class="left">手机号</view> | ||
|  | 						<view class="flex flex-items-center"> | ||
|  | 							<input class="input" type="text" placeholder="请输入手机号" v-model="pickupPerson.phone" /> | ||
|  | 							<uni-icons v-if="pickupPerson.phone.length>0" style="margin-left: 30rpx;" | ||
|  | 								type="closeempty" size="14" @click="pickupPerson.phone = ''"></uni-icons> | ||
|  | 						</view> | ||
|  | 						 | ||
|  | 					</view> | ||
|  | 				</view> | ||
|  | 			</view> | ||
|  | 		</view> --> | ||
|  | 		 | ||
|  | 		<template v-for="(merchantGroup,merchantIndex) in orderGoods"> | ||
|  | 		<view class="new-box" v-for="(sku,index) in merchantGroup" :key="index"> | ||
|  | 			<view class="box shop-name text-overflow" v-if="sku.goodsInfo.merchant_name"> | ||
|  | 				{{sku.goodsInfo.merchant_name}} | ||
|  | 			</view> | ||
|  | 			<view class="commodity box"> | ||
|  | 				<image class="img" :src="showImg(sku.goodsInfo.image)" mode="aspectFill"></image> | ||
|  | 				<view class="title flex-c"> | ||
|  | 					<view class="commodity-info"> | ||
|  | 						<view class="text-overflowRows">{{ sku.goodsInfo.title }}</view> | ||
|  | 						<view class="commodity-price"> | ||
|  | 							{{sku.skuInfo.money/100}} | ||
|  | 						</view> | ||
|  | 					</view> | ||
|  | 					<view class="commodity-info"> | ||
|  | 						<view class="text-overflowRows">{{ sku.skuInfo.title }}</view> | ||
|  | 						<view class="commodity-num"> | ||
|  | 							x{{sku.skuInfo.buyNum}} | ||
|  | 						</view> | ||
|  | 					</view> | ||
|  | 				</view> | ||
|  | 			</view> | ||
|  | 			<view class="commodity box sb" style="padding-left: 10rpx;"> | ||
|  | 				<view class="title" style="font-weight: bold;"> | ||
|  | 					购买数量 | ||
|  | 				</view> | ||
|  | 				<view class="num-box"> | ||
|  | 					<!-- <image src="https://yjdtadmin.sz-trip.com/uploads/20231225/4b61998e657784d08c8dfdb08da84553.png" mode="aspectFill" class="ctrl" @click="reduce()"></image> --> | ||
|  | 					<view :class="['ctrl',sku.skuInfo.buyNum>1||info.goods.length>1?'':'disabled']" @click="reduce(sku.skuInfo,index)">-</view> | ||
|  | 					<input class="num" type="text" v-model="sku.skuInfo.buyNum" :disabled='true' /> | ||
|  | 					<view :class="['ctrl']" @click="plus(sku.skuInfo)">+</view> | ||
|  | 				</view> | ||
|  | 				 | ||
|  | 			</view> | ||
|  | 			<view class="post top-line flex-between" v-show="info.is_post==1"> | ||
|  | 				<view class=""> | ||
|  | 					运费 | ||
|  | 				</view> | ||
|  | 				<view style="font-weight: 500;" > | ||
|  | 					{{!sku.post?'免邮':sku.post/100}} | ||
|  | 				</view> | ||
|  | 			</view> | ||
|  | 
 | ||
|  | 			 | ||
|  | 		</view> | ||
|  | 		</template> | ||
|  | 		 | ||
|  | 		<!-- <view  class="tickets-box flex-between"> | ||
|  | 		<view class="remark"> | ||
|  | 			<view class="remark-title" >订单备注:</view> | ||
|  | 			<input style="z-index:0;text-align: right;" type="text" placeholder="选填" v-model="remark" maxlength="50"/> | ||
|  | 		</view> | ||
|  | 		</view> --> | ||
|  | 		 | ||
|  | 		<!-- 优惠券 --> | ||
|  | 
 | ||
|  | 		<!-- <view @click="goOrderCoupon" class="tickets-box flex-between"> | ||
|  | 			<view class="order-title">优惠券</view> | ||
|  | 			<view class="coupon-btn" v-if="coupon==''"> | ||
|  | 				<view class="select">选择优惠券</view> | ||
|  | 				<uni-icons style="height: 42rpx;" color="#999999" type="right" size="18"></uni-icons> | ||
|  | 			</view> | ||
|  | 			<div class="coupon-price" v-else> | ||
|  | 				<span v-if="coupon.percent == 0">-¥{{coupon.discounts/100}}</span> | ||
|  | 				<span v-else>-{{coupon.percent}}%</span> | ||
|  | 				<span style="margin:0 31rpx 0 8rpx;color: #6C7A94;">></span> | ||
|  | 			</div> | ||
|  | 		 </view> --> | ||
|  | 
 | ||
|  | 		 | ||
|  | 
 | ||
|  | 
 | ||
|  | 		 | ||
|  | 		<view class="btn-list"> | ||
|  | 			<view class="price-box"> | ||
|  | 				<view class="text">合计:</view> | ||
|  | 				<view class="price">{{ total() }}</view> | ||
|  | 				<view class="post-text" v-if="info.is_post==1&&post">含邮费:¥{{ post / 100 }}</view> | ||
|  | 			</view> | ||
|  | 			<view class="btn" @click="order()">立即支付</view> | ||
|  | 		</view> | ||
|  | 
 | ||
|  | 		<!-- 选择收货地址弹窗 --> | ||
|  | 		<uni-popup ref="addressPopup" type="bottom" backgroundColor="#F4F4F4" @change="changPopShow"> | ||
|  | 			<view class="people-popup"> | ||
|  | 				<view class="top-box"> | ||
|  | 					<view class="top flex-between"> | ||
|  | 						<text class="text-overflow" @click="changeAddressPopup('close')">取消</text> | ||
|  | 						<text class="confirm" @click="changeAddressPopup('close', 'confirm')">确定</text> | ||
|  | 					</view> | ||
|  | 				</view> | ||
|  | 				<!-- <navigator url="/subPackages/user/myAddressAdd" class="button">添加收货地址</navigator> --> | ||
|  | 				<view class="button" @click="changeAddressAddPopup('open','',{})">添加收货地址</view> | ||
|  | 				<view class="popup-list" v-if="addressList.length > 0"> | ||
|  | 					<view :class="['popup-item',contacts.id==item.id?'active':'']" v-for="(item, index) in addressList" :key="index" @click="seldThisAddress(item)"> | ||
|  | 						<view class="item-top flex-between"> | ||
|  | 							<view style="padding-right: 71rpx;"> | ||
|  | 								<view class="name flex-start"> | ||
|  | 									{{ item.name }} | ||
|  | 									<text>{{ item.tel }}</text> | ||
|  | 									<text class="tag" v-if="item.is_default == 1">默认</text> | ||
|  | 								</view> | ||
|  | 								<view class="subtitle text-overflowRows">{{ item.province_text + item.city_text + item.district_text + item.detail_addr }}</view> | ||
|  | 							</view> | ||
|  | 							<view> | ||
|  | 								<img @click.stop="changeAddressAddPopup('open', '', item)" :src="showImg('/uploads/20250514/dd77d7706bc9bffd2bb928d1772e8413.png')" alt="" /> | ||
|  | 							</view> | ||
|  | 						</view> | ||
|  | 					</view> | ||
|  | 				</view> | ||
|  | 			</view> | ||
|  | 		</uni-popup> | ||
|  | 		<!-- 新增编辑收货地址弹窗 --> | ||
|  | 		<uni-popup ref="addressAddPopup" type="bottom" backgroundColor="#F4F4F4"  | ||
|  | 			@change="changPopShow" style="border-radius: 13rpx 13rpx 0 0;"> | ||
|  | 			<view class="people-popup"> | ||
|  | 				<view class="top-box"> | ||
|  | 					<view class="top flex-between" style="height: fit-content;"> | ||
|  | 						<text class="text-overflow" @click="changeAddressAddPopup('close')">取消</text> | ||
|  | 						<text style="font-size: 35rpx;font-weight: 600;">{{addressTitle}}</text> | ||
|  | 						<text style="color: #515150;" class="confirm" @click="saveAddress">保存</text> | ||
|  | 					</view> | ||
|  | 				</view> | ||
|  | 				 | ||
|  | 				<view class="add-edit-content"> | ||
|  | 					<addressAddVue ref="addressAddVueRef"></addressAddVue> | ||
|  | 				</view> | ||
|  | 				 | ||
|  | 				 | ||
|  | 			</view> | ||
|  | 		</uni-popup> | ||
|  | 		 | ||
|  | 		 | ||
|  | 
 | ||
|  | 	</view> | ||
|  | </template> | ||
|  | 
 | ||
|  | <script> | ||
|  | import addressAddVue from '../../components/addressAdd.vue'; | ||
|  | export default { | ||
|  | 	components: {addressAddVue}, | ||
|  | 	data() { | ||
|  | 		return { | ||
|  | 			contacts: null, | ||
|  | 			info: null,//规格的信息
 | ||
|  | 			detail:null,//商品的信息
 | ||
|  | 			 | ||
|  | 			orderGoods: [], | ||
|  | 			 | ||
|  | 			post: 0, | ||
|  | 			flag: true, | ||
|  | 			addressList: [], | ||
|  | 			reserve_name: '', | ||
|  | 			reserve_idcard: '', | ||
|  | 			reserve_phone: '', | ||
|  | 			remark: '', | ||
|  | 			coupon: "", | ||
|  | 			allprice: 0, | ||
|  | 			 | ||
|  | 			isPost: "1", //0=核销,1=邮寄,2=自取,3=邮寄/自提
 | ||
|  | 			sendType: 1, // 0=核销,1=邮寄,2=自取,3=邮寄/自提
 | ||
|  | 			pickupAddress: {id: null, address:''}, | ||
|  | 			pickupPerson: {name:'',phone:''}, | ||
|  | 			popShow: false, // 解决滚动穿透
 | ||
|  | 			 | ||
|  | 			addressTitle: '添加收货地址' | ||
|  | 			 | ||
|  | 		}; | ||
|  | 	}, | ||
|  | 	onLoad() { | ||
|  | 		this.$store.commit("choseCoupon", ""); | ||
|  | 		this.info = JSON.parse(uni.getStorageSync('teChanOrder')); | ||
|  | 		 | ||
|  | 		 | ||
|  | 		if (!this.info) { | ||
|  | 			uni.navigateBack(); | ||
|  | 			return | ||
|  | 		} | ||
|  | 		console.log(this.info); | ||
|  | 		 | ||
|  | 		// 根据规格信息 记录发货方式 is_post  ,使用方式:0=核销,1=邮寄,2=自取,3=邮寄/自提
 | ||
|  | 		if (this.info) { | ||
|  | 			this.isPost = this.info.is_post || "1" | ||
|  | 			// this.info.is_post = this.isPost==3?1:this.isPost
 | ||
|  | 		} | ||
|  | 		this.handleOrderGoods() | ||
|  | 		console.log(this.isPost) | ||
|  | 	}, | ||
|  | 	onShow() { | ||
|  | 		// this.coupon = this.$store.state.user.coupon
 | ||
|  | 		this.getAllAddressList(); | ||
|  | 		 | ||
|  | 		// 更新自提点
 | ||
|  | 		uni.$on("updateDataByConnect",this.getDataByConnect) | ||
|  | 	}, | ||
|  | 	onUnload(){ | ||
|  | 		uni.$off("updateDataByConnect",this.getDataByConnect) | ||
|  | 	}, | ||
|  | 	onReady () { | ||
|  | 		this.$nextTick(()=>{ | ||
|  | 			setTimeout(()=>{ | ||
|  | 				// this.getMaxCouponData()
 | ||
|  | 			},1000) | ||
|  | 		}) | ||
|  | 		 | ||
|  | 		 | ||
|  | 	}, | ||
|  | 	methods: { | ||
|  | 		handleOrderGoods () { | ||
|  | 			let merchantArray = new Set(this.info.goods.map(v=>v.goodsInfo.merchant_name)) | ||
|  | 			this.orderGoods = [] | ||
|  | 			merchantArray.forEach(x=>{ | ||
|  | 				// let tempArray = this.info.goods.filter(v=>v.goodsInfo.merchant_name==x)
 | ||
|  | 				// this.orderGoods.push(tempArray)
 | ||
|  | 				 | ||
|  | 				// 不用filter 用for循环一个个找 可以用引用对象地址修改this.info的goods 这样下面的代码不用改
 | ||
|  | 				let tempArray = [] | ||
|  | 				this.info.goods.forEach(v=>{ | ||
|  | 					if(v.goodsInfo.merchant_name == x) { | ||
|  | 						tempArray.push(v) | ||
|  | 					} | ||
|  | 				}) | ||
|  | 				this.orderGoods.push(tempArray) | ||
|  | 				 | ||
|  | 			}) | ||
|  | 			console.log(this.orderGoods) | ||
|  | 		}, | ||
|  | 		 | ||
|  | 		 | ||
|  | 		goOrderCoupon () { | ||
|  | 			let allPrice = 0 | ||
|  | 			let skuIds= [] | ||
|  | 			this.info.goods.forEach(v=>{ | ||
|  | 				allPrice+= v.skuInfo.money*v.skuInfo.buyNum | ||
|  | 				if (v.skuInfo.buyNum>0) { | ||
|  | 					skuIds.push(v.skuInfo.id) | ||
|  | 				} | ||
|  | 			}) | ||
|  | 			uni.navigateTo({ | ||
|  | 				url: `/subPackages/order/orderCoupon?allprice=${allPrice}&sku_ids=${skuIds.join(',')}` | ||
|  | 			}) | ||
|  | 		}, | ||
|  | 		 | ||
|  | 		getContacts() { | ||
|  | 			if (this.info.is_post == 0) { | ||
|  | 				return; | ||
|  | 			} | ||
|  | 			 | ||
|  | 			this.Post({}, '/api/user/getDefaultConsignee').then(res => { | ||
|  | 				if (res) { | ||
|  | 					this.contacts = res.data; | ||
|  | 					this.getPost(); | ||
|  | 				} | ||
|  | 			}); | ||
|  | 		}, | ||
|  | 		getPost() { | ||
|  | 			if (this.info.is_post == 0 || !this.contacts) { | ||
|  | 				return; | ||
|  | 			} | ||
|  | 			this.flag = false; | ||
|  | 			 | ||
|  | 			let param = [] | ||
|  | 			this.info.goods.forEach(v=>{ | ||
|  | 				param.push({specifications_id: v.skuInfo.id, num: v.skuInfo.buyNum, consignee_id:this.contacts.id}) | ||
|  | 			}) | ||
|  | 			 | ||
|  | 			let data = JSON.stringify(param); | ||
|  | 			// console.log(data);
 | ||
|  | 			this.Post({ data: data }, '/api/order/getNewPost').then(res => { | ||
|  | 				if (res) { | ||
|  | 					for(let i=0;i<this.info.goods.length;i++) { | ||
|  | 						this.info.goods[i].post = res.data[i].post_money; | ||
|  | 					} | ||
|  | 					this.flag = true; | ||
|  | 				} | ||
|  | 			}).catch(err=>{ | ||
|  | 				console.log(err,'aaaaaaa'); | ||
|  | 				this.flag = true; | ||
|  | 			}); | ||
|  | 		}, | ||
|  | 
 | ||
|  | 		plus(sku) { | ||
|  | 			this.$nextTick(() => { | ||
|  | 				this.$store.commit("choseCoupon",""); | ||
|  | 				this.coupon = this.$store.state.user.coupon | ||
|  | 				sku.buyNum += 1; | ||
|  | 				if (this.flag) { | ||
|  | 					this.getPost(); | ||
|  | 				} | ||
|  | 			}); | ||
|  | 		}, | ||
|  | 		reduce(sku,index) { | ||
|  | 			if (sku.buyNum > 1) { | ||
|  | 				this.$store.commit("choseCoupon",""); | ||
|  | 				this.coupon = this.$store.state.user.coupon | ||
|  | 				this.$nextTick(() => { | ||
|  | 					sku.buyNum -= 1; | ||
|  | 					if (this.flag) { | ||
|  | 						this.getPost(); | ||
|  | 					} | ||
|  | 				}); | ||
|  | 			} else if (sku.buyNum == 1&&this.info.goods.length>1) { | ||
|  | 				this.$store.commit("choseCoupon",""); | ||
|  | 				this.coupon = this.$store.state.user.coupon | ||
|  | 				this.$nextTick(() => { | ||
|  | 					this.info.goods.splice(index,1) | ||
|  | 					if (this.flag) { | ||
|  | 						this.getPost(); | ||
|  | 					} | ||
|  | 					this.handleOrderGoods() | ||
|  | 				}); | ||
|  | 				 | ||
|  | 			} | ||
|  | 		}, | ||
|  | 		// 选择收货地址弹窗
 | ||
|  | 		changeAddressPopup(type, confirm, index) { | ||
|  | 			if (type == 'open') this.$refs.addressPopup.open('bottom'); | ||
|  | 			else this.$refs.addressPopup.close(); | ||
|  | 			this.$forceUpdate(); | ||
|  | 		}, | ||
|  | 		// 获取收货地址列表
 | ||
|  | 		getAllAddressList() { | ||
|  | 			this.Post({}, '/api/user/consigneeList').then(res => { | ||
|  | 				let oldId = (this.contacts || {}).id | ||
|  | 				console.log(this.contacts) | ||
|  | 				if (res.code == 200) this.addressList = res.data || []; | ||
|  | 				if (this.addressList.some(v=>v.id==oldId)) { | ||
|  | 					this.contacts = this.addressList.find(v=>v.id==oldId) | ||
|  | 					this.getPost(); | ||
|  | 				} else if (this.addressList.some(v=>v.is_default==1)) { | ||
|  | 					this.contacts = this.addressList.find(v=>v.is_default==1) | ||
|  | 					this.getPost(); | ||
|  | 				} else if (this.addressList.length>0) { | ||
|  | 					this.contacts = this.addressList[0] | ||
|  | 					this.getPost() | ||
|  | 				} | ||
|  | 			}); | ||
|  | 		}, | ||
|  | 		// 选择收货地址
 | ||
|  | 		seldThisAddress(item) { | ||
|  | 			if (!this.contacts) this.contacts = {}; | ||
|  | 			this.contacts = item | ||
|  | 			console.log(this.flag,1111111); | ||
|  | 			if (this.flag) { | ||
|  | 				this.getPost(); | ||
|  | 			} | ||
|  | 			this.$refs.addressPopup.close(); | ||
|  | 			this.$forceUpdate(); | ||
|  | 		}, | ||
|  | 		// 收货地址新增弹窗
 | ||
|  | 		changeAddressAddPopup(type, confirm, item) { | ||
|  | 			if (type == 'open') { | ||
|  | 				this.addressTitle = '新增收货地址' | ||
|  | 				if (item.id) { this.addressTitle = '编辑收货地址' } | ||
|  | 				// this.id = item.id
 | ||
|  | 
 | ||
|  | 				this.$refs.addressAddPopup.open('bottom'); | ||
|  | 				 | ||
|  | 				this.$nextTick(()=>{ | ||
|  | 					this.$refs.addressAddVueRef.init(item) | ||
|  | 				}) | ||
|  | 			} | ||
|  | 			else {this.$refs.addressAddPopup.close();} | ||
|  | 			this.$forceUpdate(); | ||
|  | 		}, | ||
|  | 		 | ||
|  | 		// 保存地址
 | ||
|  | 		async saveAddress () { | ||
|  | 			let res = await this.$refs.addressAddVueRef.postSave() | ||
|  | 			if (res && (res.code == 1 || res.code==200)) { | ||
|  | 				this.contacts = res.data | ||
|  | 				this.getAllAddressList(); | ||
|  | 				this.changeAddressAddPopup('close') | ||
|  | 			} | ||
|  | 		}, | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 		// 总价
 | ||
|  | 		total() { | ||
|  | 			let price = 0 | ||
|  | 			let postPrice = 0 | ||
|  | 			let allPrice = 0 | ||
|  | 			 | ||
|  | 			if (this.info && Array.isArray(this.info.goods)) { | ||
|  | 				this.info.goods.forEach(v=>{ | ||
|  | 					allPrice += v.skuInfo.money*v.skuInfo.buyNum | ||
|  | 					if (this.info.is_post == 1) { | ||
|  | 						postPrice+=(v.post || 0) | ||
|  | 					} | ||
|  | 				}) | ||
|  | 			} | ||
|  | 			console.log(postPrice) | ||
|  | 			this.allprice = allPrice + postPrice | ||
|  | 			if (this.coupon) { | ||
|  | 				if (this.coupon.percent == 0) { | ||
|  | 					if (this.coupon.discounts>allPrice) { | ||
|  | 						price =postPrice | ||
|  | 					}else{ | ||
|  | 						price = allPrice + postPrice - (this.coupon.discounts) | ||
|  | 					} | ||
|  | 					 | ||
|  | 				} else{ | ||
|  | 					// 有bug折扣券不加邮费
 | ||
|  | 					price = (allPrice + postPrice) - (allPrice * this.coupon.percent/100) | ||
|  | 				} | ||
|  | 			} else { | ||
|  | 				price = allPrice + postPrice | ||
|  | 			} | ||
|  | 			return price < 0 ? 0 : (price/100).toFixed(2) | ||
|  | 		}, | ||
|  | 		// 预定
 | ||
|  | 		order() { | ||
|  | 			if (this.info.is_post == 1 || this.info.is_post == 3) { | ||
|  | 				console.log(this.info.is_post) | ||
|  | 				if (this.info.is_post == 1 && !this.contacts) { | ||
|  | 					uni.showToast({ | ||
|  | 						title: '请选择收货地址', | ||
|  | 						icon: 'none' | ||
|  | 					}); | ||
|  | 					return; | ||
|  | 				} | ||
|  | 				 | ||
|  | 				if (this.info.is_post == 2) { | ||
|  | 					if (!this.pickupAddress.id) { | ||
|  | 						uni.showToast({title: '请选择自提点',icon: 'none'}); | ||
|  | 						return; | ||
|  | 					} | ||
|  | 
 | ||
|  | 					if (this.pickupPerson.name.trim().length<0) { | ||
|  | 						uni.showToast({ | ||
|  | 							title: '请输入自提人姓名', | ||
|  | 							icon: 'none' | ||
|  | 						}); | ||
|  | 						return; | ||
|  | 					} | ||
|  | 					if (!this.IsTel(this.pickupPerson.phone)) { | ||
|  | 						uni.showToast({ | ||
|  | 							title: '请输入自提人手机号', | ||
|  | 							icon: 'none' | ||
|  | 						}); | ||
|  | 						return; | ||
|  | 					} | ||
|  | 					 | ||
|  | 
 | ||
|  | 				} | ||
|  | 			} | ||
|  | 
 | ||
|  | 			let goods = []; | ||
|  | 			this.info.goods.forEach(v=>{ | ||
|  | 				let goodsItem = { | ||
|  | 					specifications_id: v.skuInfo.id, | ||
|  | 					num: v.skuInfo.buyNum, | ||
|  | 					// consignee_id: this.info.is_post == 1 ? this.contacts.id : null
 | ||
|  | 				}; | ||
|  | 				 | ||
|  | 				if (this.info.is_post == 2) { | ||
|  | 					goodsItem.extract_id = this.pickupAddress.id; | ||
|  | 				} else if (this.info.is_post == 1){ | ||
|  | 					goodsItem.consignee_id = this.contacts.id  | ||
|  | 				} | ||
|  | 				goods.push(goodsItem); | ||
|  | 			}) | ||
|  | 			 | ||
|  | 			 | ||
|  | 			 | ||
|  | 			let data = { | ||
|  | 				goods: goods, | ||
|  | 				coupon: this.coupon ? this.coupon.id : "", | ||
|  | 				remark: this.remark, | ||
|  | 				is_post: this.info.is_post, | ||
|  | 				reserve_name: this.pickupPerson.name, | ||
|  | 				reserve_phone: this.pickupPerson.phone, | ||
|  | 			}; | ||
|  | 			this.Post( | ||
|  | 				{ | ||
|  | 					method: 'POST', | ||
|  | 					data: JSON.stringify(data) | ||
|  | 				}, | ||
|  | 				'/api/order/place' | ||
|  | 			).then(res => { | ||
|  | 				uni.removeStorageSync('teChanOrder') | ||
|  | 				uni.removeStorageSync('teChanInfo') | ||
|  | 				if (res.code == 1 || res.code==200) { | ||
|  | 					this.Post( | ||
|  | 						{ | ||
|  | 							order_id: res.data.order_id, | ||
|  | 							type: 'miniprogram', | ||
|  | 							platform: 'miniprogram' | ||
|  | 						}, | ||
|  | 						'/api/pay/unify' | ||
|  | 					).then(res => { | ||
|  | 						if (res.data) { | ||
|  | 							uni.requestPayment({ | ||
|  | 								nonceStr: res.data.nonceStr, | ||
|  | 								package: res.data.package, | ||
|  | 								paySign: res.data.paySign, | ||
|  | 								signType: res.data.signType, | ||
|  | 								timeStamp: res.data.timeStamp, | ||
|  | 								success: () => { | ||
|  | 									this.getSubscribeMessage() | ||
|  | 								}, | ||
|  | 								fail() { | ||
|  | 									uni.navigateTo({ | ||
|  | 										url: '/subPackages/order/trades' | ||
|  | 									}) | ||
|  | 								} | ||
|  | 							}); | ||
|  | 						} | ||
|  | 					}); | ||
|  | 				} | ||
|  | 			}); | ||
|  | 		}, | ||
|  | 		 | ||
|  | 		// ---------------自提-----------------------
 | ||
|  | 		changPopShow (e) { | ||
|  | 			this.popShow = e.show | ||
|  | 		}, | ||
|  | 		 | ||
|  | 		getDataByConnect(data) { | ||
|  | 			if (data.msgType == "updatePickUpPoint") { | ||
|  | 				this.pickupAddress = data.data | ||
|  | 			} | ||
|  | 		}, | ||
|  | 		 | ||
|  | 		// 获取最大优惠券
 | ||
|  | 		async getMaxCouponData () { | ||
|  | 			let allPrice =0 | ||
|  | 			let skuIds = [] | ||
|  | 			if (this.info && Array.isArray(this.info.goods)) { | ||
|  | 				this.info.goods.forEach(v=>{ | ||
|  | 					allPrice += v.skuInfo.money*v.skuInfo.buyNum | ||
|  | 					if (v.skuInfo.buyNum>0) { | ||
|  | 						skuIds.push(v.skuInfo.id) | ||
|  | 					} | ||
|  | 				}) | ||
|  | 			} | ||
|  | 			let param = {money:allPrice,sku_ids:skuIds.join(',')} | ||
|  | 			let res = await this.getMaxCoupon(param) | ||
|  | 			if (res.id) { | ||
|  | 				this.coupon = res | ||
|  | 			} | ||
|  | 		} | ||
|  | 		 | ||
|  | 		 | ||
|  | 		 | ||
|  | 	} | ||
|  | }; | ||
|  | </script> | ||
|  | 
 | ||
|  | <style lang="scss" scoped> | ||
|  | .bg { | ||
|  | 	min-height: 100vh; | ||
|  | 	overflow-x: hidden; | ||
|  | 	background: #f2f4f7; | ||
|  | 	padding-bottom: 200rpx; | ||
|  | } | ||
|  | view { | ||
|  | 	box-sizing: border-box; | ||
|  | } | ||
|  | .flex-shrink-0{ | ||
|  | 	flex-shrink: 0; | ||
|  | } | ||
|  | .box { | ||
|  | 	width: 100%; | ||
|  | 	min-height: 100rpx; | ||
|  | 	padding: 20rpx; | ||
|  | 	background: #ffffff; | ||
|  | 	border-radius: 16rpx; | ||
|  | } | ||
|  | .address { | ||
|  | 	width: 697rpx; | ||
|  | 	height: 291rpx; | ||
|  | 	background: #FFFFFF; | ||
|  | 	border-radius: 13rpx; | ||
|  | 	margin: 0 auto; | ||
|  | 	margin-top: 26rpx; | ||
|  | 	.a-title{ | ||
|  | 		font-size: 31rpx; | ||
|  | 		font-family: PingFang SC; | ||
|  | 		font-weight: bold; | ||
|  | 		color: #000000; | ||
|  | 		padding: 30rpx 18rpx; | ||
|  | 		justify-content: space-between; | ||
|  | 		align-items: center; | ||
|  | 		display: flex; | ||
|  | 		width: 100%; | ||
|  | 		.more-person{ | ||
|  | 			width: 133rpx; | ||
|  | 			height: 60rpx; | ||
|  | 			border-radius: 30rpx; | ||
|  | 			border: 1px solid #999999; | ||
|  | 			font-family: PingFang SC; | ||
|  | 			font-weight: 400; | ||
|  | 			font-size: 28rpx; | ||
|  | 			color: #000000; | ||
|  | 			line-height: 16rpx; | ||
|  | 		} | ||
|  | 	} | ||
|  | 	.btn-box{ | ||
|  | 		display: flex; | ||
|  | 		align-items: center; | ||
|  | 		justify-content: center; | ||
|  | 		border-top:1rpx solid rgba(216, 216, 216, 1) ; | ||
|  | 		height: 176rpx; | ||
|  | 		.a-img{ | ||
|  | 			width: 219rpx; | ||
|  | 			height: 73rpx; | ||
|  | 			border-radius: 37rpx; | ||
|  | 			border: 1px solid #333333; | ||
|  | 			font-family: PingFang SC; | ||
|  | 			font-weight: 400; | ||
|  | 			font-size: 29rpx; | ||
|  | 			color: #000000; | ||
|  | 		} | ||
|  | 	} | ||
|  | } | ||
|  | 
 | ||
|  | .pickself{ | ||
|  | 	width: 697rpx; | ||
|  | 	height: 120rpx; | ||
|  | 	background: #FFFFFF; | ||
|  | 	border-radius: 13rpx; | ||
|  | 	margin: 0 auto; | ||
|  | 	margin-top: 26rpx; | ||
|  | 	.pickpoint{ | ||
|  | 		display: flex; | ||
|  | 		width: 100%; | ||
|  | 		font-size: 31rpx; | ||
|  | 		font-weight: bold; | ||
|  | 		padding: 40rpx 18rpx; | ||
|  | 	} | ||
|  | 	.pickpointAddress{ | ||
|  | 		display: flex; | ||
|  | 		font-weight: 500; | ||
|  | 		flex: 1; | ||
|  | 		width: 10rpx; | ||
|  | 		align-items: center; | ||
|  | 		justify-content: flex-end; | ||
|  | 	} | ||
|  | 	.pickpointImg{ | ||
|  | 		width: 20rpx; | ||
|  | 		height: 20rpx; | ||
|  | 	} | ||
|  | 	.pointAddressText{ | ||
|  | 		padding: 0 20rpx 0 40rpx; | ||
|  | 		flex: 1; | ||
|  | 		text-align: right; | ||
|  | 		width: 10rpx; | ||
|  | 	} | ||
|  | 
 | ||
|  | } | ||
|  | 
 | ||
|  | .pickup-person-area{ | ||
|  | 	width: 697rpx; | ||
|  | 	background: #FFFFFF; | ||
|  | 	border-radius: 13rpx; | ||
|  | 	margin: 0 auto; | ||
|  | 	margin-top: 26rpx; | ||
|  | 	margin-bottom: 30rpx; | ||
|  | 	.pickpoint{ | ||
|  | 		display: flex; | ||
|  | 		width: 100%; | ||
|  | 		font-size: 31rpx; | ||
|  | 		font-weight: bold; | ||
|  | 		padding: 40rpx 18rpx; | ||
|  | 		justify-content: space-between; | ||
|  | 		align-items: center; | ||
|  | 	} | ||
|  | 	.more-person{ | ||
|  | 		width: 140rpx; | ||
|  | 		height: 58rpx; | ||
|  | 	} | ||
|  | 	.btn-box{ | ||
|  | 		display: flex; | ||
|  | 		align-items: center; | ||
|  | 		justify-content: center; | ||
|  | 		padding: 0 20rpx; | ||
|  | 		border-top:1rpx solid rgba(216, 216, 216, 1) ; | ||
|  | 	} | ||
|  | 	.pickup-person-list{ | ||
|  | 		border-top: 1rpx solid #d8d8d8; | ||
|  | 		.person-list-area{ | ||
|  | 			display: flex; | ||
|  | 			flex-wrap: wrap; | ||
|  | 			padding: 40rpx 21rpx; | ||
|  | 			.person-item{ | ||
|  | 				width: 160rpx; | ||
|  | 				height: 74rpx; | ||
|  | 				line-height: 68rpx; | ||
|  | 				background: rgba(153,153,153,0.1); | ||
|  | 				border-radius: 11rpx; | ||
|  | 				border: 1px solid #999999; | ||
|  | 				position: relative; | ||
|  | 				font-size: 29rpx; | ||
|  | 				font-weight: 400; | ||
|  | 				font-size: 29rpx; | ||
|  | 				color: #000000; | ||
|  | 				text-align: center; | ||
|  | 				padding:0 22rpx; | ||
|  | 				text-overflow: ellipsis; | ||
|  | 				overflow: hidden; | ||
|  | 				white-space: nowrap; | ||
|  | 				font-weight: bold; | ||
|  | 				margin-right: 24rpx; | ||
|  | 				margin-bottom: 24rpx; | ||
|  | 			} | ||
|  | 			.person-item.active{ | ||
|  | 				background: rgba(254,180,25,0.1); | ||
|  | 				border: 2px solid #FEB419; | ||
|  | 			} | ||
|  | 			.person-item-active-img{ | ||
|  | 				width: 24rpx; | ||
|  | 				height: 24rpx; | ||
|  | 				position: absolute; | ||
|  | 				right: 0; | ||
|  | 				bottom: 0; | ||
|  | 				background-color: #FEB419; | ||
|  | 				color: white; | ||
|  | 				font-size: 20rpx; | ||
|  | 				line-height: 1.2; | ||
|  | 				border-radius:  10rpx 0rpx 10rpx 0rpx; | ||
|  | 			} | ||
|  | 		} | ||
|  | 		.current-person{ | ||
|  | 			display: flex; | ||
|  | 			align-items: center; | ||
|  | 			padding:0 44rpx 22rpx; | ||
|  | 			image{ | ||
|  | 				width: 44rpx; | ||
|  | 				height: 44rpx; | ||
|  | 			} | ||
|  | 			.name{ | ||
|  | 				 text{ | ||
|  | 					padding-left: 20rpx; | ||
|  | 					font-size: 25rpx; | ||
|  | 					color: #666666; | ||
|  | 				} | ||
|  | 			} | ||
|  | 		} | ||
|  | 	} | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | .commodity { | ||
|  | 	display: flex; | ||
|  | 	// align-items: center;
 | ||
|  | 	.img { | ||
|  | 		width: 174rpx; | ||
|  | 		height: 142rpx; | ||
|  | 		background: #f2f4f7; | ||
|  | 		border-radius: 10rpx; | ||
|  | 		flex-shrink: 0; | ||
|  | 	} | ||
|  | 	.title { | ||
|  | 		flex: 1; | ||
|  | 		margin-left: 20rpx; | ||
|  | 		font-size: 31rpx; | ||
|  | 		font-family: PingFangSC-Medium, PingFang SC; | ||
|  | 		font-weight: 500; | ||
|  | 		color: #000000; | ||
|  | 
 | ||
|  | 	} | ||
|  | 	.num-box { | ||
|  | 		display: flex; | ||
|  | 		align-items: center; | ||
|  | 		margin-left: 20rpx; | ||
|  | 		width: 160rpx; | ||
|  | 		justify-content: space-between; | ||
|  | 		.num { | ||
|  | 			text-align: center; | ||
|  | 			width: 50rpx; | ||
|  | 		} | ||
|  | 		.ctrl { | ||
|  | 			width: 47rpx; | ||
|  | 			height: 47rpx; | ||
|  | 			background: #74A5AA; | ||
|  | 			border-radius: 50%; | ||
|  | 			font-family: PingFang SC; | ||
|  | 			font-weight: 400; | ||
|  | 			font-size: 34rpx; | ||
|  | 			color: #FFFFFF; | ||
|  | 			line-height: 47rpx; | ||
|  | 			text-align: center; | ||
|  | 		} | ||
|  | 		.ctrl.disabled{ | ||
|  | 			background: #E8E8E8; | ||
|  | 			color: #999999; | ||
|  | 		} | ||
|  | 	} | ||
|  | } | ||
|  | .btn-list { | ||
|  | 	width: 100%; | ||
|  | 	height: 166rpx; | ||
|  | 	background: #ffffff; | ||
|  | 	box-shadow: 0rpx -3rpx 9rpx 1rpx rgba(227, 229, 232, 0.5); | ||
|  | 	display: flex; | ||
|  | 	position: fixed; | ||
|  | 	bottom: 0; | ||
|  | 	padding: 20rpx 20rpx 40rpx; | ||
|  | 	align-items: center; | ||
|  | 	justify-content: space-between; | ||
|  | 	.btn { | ||
|  | 			width: 250rpx; | ||
|  | 			height: 80rpx; | ||
|  | 			background: #74A5AA; | ||
|  | 			border-radius: 40rpx; | ||
|  | 			text-align: center; | ||
|  | 			line-height: 80rpx; | ||
|  | 
 | ||
|  | 			font-weight: bold; | ||
|  | 			font-size: 32rpx; | ||
|  | 			color: #FFFFFF; | ||
|  | 	 | ||
|  | 	} | ||
|  | 	.price-box { | ||
|  | 		display: flex; | ||
|  | 		align-items: flex-end; | ||
|  | 		.text { | ||
|  | 			font-size: 29rpx; | ||
|  | 			font-family: PingFangSC-Regular, PingFang SC; | ||
|  | 			font-weight: 500; | ||
|  | 			color: #333; | ||
|  | 		} | ||
|  | 		.price { | ||
|  | 			margin-left: 15rpx; | ||
|  | 			font-size: 48rpx; | ||
|  | 			font-family: PingFangSC-Regular, PingFang SC; | ||
|  | 			font-weight: bold; | ||
|  | 			color: #FC5109; | ||
|  | 			line-height: 1; | ||
|  | 			&:before { | ||
|  | 				content: '¥'; | ||
|  | 				display: inline-block; | ||
|  | 				font-size: 24rpx; | ||
|  | 			} | ||
|  | 		} | ||
|  | 		.post-text { | ||
|  | 			margin-left: 15rpx; | ||
|  | 			color: #fc5109; | ||
|  | 			font-size: 24rpx; | ||
|  | 		} | ||
|  | 	} | ||
|  | } | ||
|  | .contacts { | ||
|  | 	display: flex; | ||
|  | 	align-items: center; | ||
|  | 	justify-content: space-between; | ||
|  | 	height: 100%; | ||
|  | 	image { | ||
|  | 		width: 36rpx; | ||
|  | 		height: 36rpx; | ||
|  | 	} | ||
|  | 	.contacts-left { | ||
|  | 		.name-phone { | ||
|  | 			display: flex; | ||
|  | 			align-items: baseline; | ||
|  | 			.name { | ||
|  | 				font-size: 32rpx; | ||
|  | 				font-family:  PingFang SC; | ||
|  | 				font-weight: 400; | ||
|  | 				color: #222222; | ||
|  | 			} | ||
|  | 			.phone { | ||
|  | 				margin-left: 27rpx; | ||
|  | 				font-size: 25rpx; | ||
|  | 				font-family:  PingFang SC; | ||
|  | 				font-weight: 400; | ||
|  | 				color: #666666; | ||
|  | 			} | ||
|  | 		} | ||
|  | 		.adds { | ||
|  | 			font-size: 27rpx; | ||
|  | 			font-family: PingFang SC; | ||
|  | 			font-weight: 400; | ||
|  | 			color: #6C7A94; | ||
|  | 			margin-top: 20rpx; | ||
|  | 			max-width: 500rpx; | ||
|  | 		} | ||
|  | 	} | ||
|  | } | ||
|  | .people-popup { | ||
|  | 	padding: 26rpx; | ||
|  | 	min-height: 800rpx; | ||
|  | 
 | ||
|  | 	.top-box { | ||
|  | 		height: 80rpx; | ||
|  | 
 | ||
|  | 		.top { | ||
|  | 			position: fixed; | ||
|  | 			left: 0; | ||
|  | 			right: 0; | ||
|  | 			color: #000; | ||
|  | 			height: 80rpx; | ||
|  | 			font-size: 0; | ||
|  | 			overflow: hidden; | ||
|  | 			padding: 0 26rpx; | ||
|  | 
 | ||
|  | 			text { | ||
|  | 				text-align: left; | ||
|  | 				font-size: 31rpx; | ||
|  | 				font-weight: 400; | ||
|  | 				color: #000000; | ||
|  | 			} | ||
|  | 
 | ||
|  | 			.confirm { | ||
|  | 				font-weight: 400; | ||
|  | 				color: #000000; | ||
|  | 			} | ||
|  | 		} | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.popup-list { | ||
|  | 		height: 666rpx; | ||
|  | 		overflow: scroll; | ||
|  | 
 | ||
|  | 		.popup-item { | ||
|  | 			border-radius: 12rpx; | ||
|  | 			padding: 2rpx; | ||
|  | 			margin-top: 24rpx; | ||
|  | 			font-size: 24rpx; | ||
|  | 			color: #333333; | ||
|  | 			font-weight: 400; | ||
|  | 			background-color: #ffffff; | ||
|  | 
 | ||
|  | 			.item-top { | ||
|  | 				border-radius: 12rpx; | ||
|  | 				padding: 30rpx 40rpx; | ||
|  | 				background-color: #ffffff; | ||
|  | 				 | ||
|  | 				img { | ||
|  | 					color: #666666; | ||
|  | 					width: 40rpx; | ||
|  | 					height: 40rpx; | ||
|  | 				} | ||
|  | 
 | ||
|  | 				.name { | ||
|  | 					overflow: hidden; | ||
|  | 					font-family: PingFang SC; | ||
|  | 					font-weight: 400; | ||
|  | 					font-size: 32rpx; | ||
|  | 					display: flex; | ||
|  | 					align-items: baseline; | ||
|  | 
 | ||
|  | 					text { | ||
|  | 						color: #666; | ||
|  | 						font-size: 25rpx; | ||
|  | 						padding: 0 24rpx; | ||
|  | 					} | ||
|  | 
 | ||
|  | 					.tag { | ||
|  | 						padding: 0 8rpx; | ||
|  | 						height: 32rpx; | ||
|  | 						border-radius: 7rpx; | ||
|  | 						line-height: 30rpx; | ||
|  | 						text-align: center; | ||
|  | 						font-size: 23rpx; | ||
|  | 						font-family: PingFang SC; | ||
|  | 						font-weight: 500; | ||
|  | 						color: #ffffff; | ||
|  | 						background: #74A5AA; | ||
|  | 
 | ||
|  | 					} | ||
|  | 				} | ||
|  | 
 | ||
|  | 				.com-flex-start { | ||
|  | 					margin: 0 0 30rpx; | ||
|  | 				} | ||
|  | 
 | ||
|  | 				.subtitle { | ||
|  | 					font-weight: 400; | ||
|  | 					flex: 1; | ||
|  | 					text-align: left; | ||
|  | 					margin-top: 33rpx; | ||
|  | 					color: #333333; | ||
|  | 					font-size: 25rpx; | ||
|  | 
 | ||
|  | 				} | ||
|  | 			} | ||
|  | 
 | ||
|  | 		} | ||
|  | 		 | ||
|  | 		.popup-item.active{ | ||
|  | 			background: #60989E; | ||
|  | 		} | ||
|  | 	} | ||
|  | 
 | ||
|  | 	.button { | ||
|  | 
 | ||
|  | 		text-align: center; | ||
|  | 		width: 100%; | ||
|  | 		height: 80rpx; | ||
|  | 		line-height: 80rpx; | ||
|  | 		background-color: #ffffff; | ||
|  | 		border-radius: 40rpx; | ||
|  | 		font-family: PingFang SC; | ||
|  | 		font-weight: 400; | ||
|  | 		font-size: 33rpx; | ||
|  | 		color: #000000; | ||
|  | 
 | ||
|  | 	} | ||
|  | } | ||
|  | 
 | ||
|  | .person-info { | ||
|  | 	padding: 30rpx 30rpx 15rpx 30rpx; | ||
|  | 	background: #fff; | ||
|  | 	margin-top: 30rpx; | ||
|  | 	border-radius: 16rpx; | ||
|  | } | ||
|  | .person-title { | ||
|  | 	font-size: 32rpx; | ||
|  | 	font-weight: bold; | ||
|  | 	color: #000; | ||
|  | } | ||
|  | .line { | ||
|  | 	border-bottom: 1px solid #e3e5e8; | ||
|  | } | ||
|  | .flex { | ||
|  | 	display: flex; | ||
|  | 	align-items: center; | ||
|  | } | ||
|  | .left { | ||
|  | 	width: 140rpx; | ||
|  | 	height: 104rpx; | ||
|  | 	line-height: 104rpx; | ||
|  | 	font-family: PingFang; | ||
|  | 	font-weight: bold; | ||
|  | 	font-size: 31rpx; | ||
|  | 	color: #000000; | ||
|  | } | ||
|  | .input { | ||
|  | 	font-size: 31rpx; | ||
|  | 	font-weight: 400; | ||
|  | 	text-align: right; | ||
|  | } | ||
|  | .remark { | ||
|  | 	padding:30rpx; | ||
|  | 	display: flex; | ||
|  | 	align-items: center; | ||
|  | 	width: 698rpx; | ||
|  | 	min-height: 120rpx; | ||
|  | 	background: #ffffff; | ||
|  | 	margin: 0 auto; | ||
|  | 	border-radius: 14rpx; | ||
|  | 	.remark-title{ | ||
|  | 
 | ||
|  | 		font-size: 31rpx; | ||
|  | 		font-family: PingFang SC; | ||
|  | 		font-weight: bold; | ||
|  | 		color: #000000; | ||
|  | 		flex-shrink: 0; | ||
|  | 
 | ||
|  | 	} | ||
|  | 	input { | ||
|  | 		margin-left: 64rpx; | ||
|  | 		width: 500rpx; | ||
|  | 		font-size: 31rpx; | ||
|  | 	} | ||
|  | } | ||
|  | .sb{ | ||
|  | 	justify-content: space-between; | ||
|  | } | ||
|  | 	.tag { | ||
|  | 		margin-top: 10rpx; | ||
|  | 		// display: flex;
 | ||
|  | 		// align-items: center;
 | ||
|  | 		.tag-item { | ||
|  | 			background: rgba(252, 81, 9, .08); | ||
|  | 			border-radius: 4rpx; | ||
|  | 			padding: 2rpx 6rpx; | ||
|  | 			font-size: 20rpx; | ||
|  | 			font-family: PingFangSC-Regular, PingFang SC; | ||
|  | 			font-weight: 400; | ||
|  | 			color: rgba(252, 81, 9, 1); | ||
|  | 			margin-right: 18rpx; | ||
|  | 		} | ||
|  | 	} | ||
|  | 	.flex-c{ | ||
|  | 		display: flex; | ||
|  | 		flex-direction: column; | ||
|  | 		// justify-content: space-between;
 | ||
|  | 	} | ||
|  | 	.new-box{ | ||
|  | 		background: #fff; | ||
|  | 		width: 698rpx; | ||
|  | 		margin: 0 auto 20rpx; | ||
|  | 		border-radius: 14rpx; | ||
|  | 	} | ||
|  | 	 | ||
|  | 	.tickets-box { | ||
|  | 		width: 698rpx; | ||
|  | 		margin: 26rpx auto 0; | ||
|  | 		border-radius: 13rpx; | ||
|  | 		background: #fff; | ||
|  | 		height: 120rpx; | ||
|  | 		.order-title { | ||
|  | 			margin: 31rpx 0 31rpx 30rpx; | ||
|  | 			font-size: 31rpx; | ||
|  | 			font-family: PingFang SC; | ||
|  | 			font-weight: bold; | ||
|  | 			color: #000000; | ||
|  | 		} | ||
|  | 
 | ||
|  | 		.coupon-price { | ||
|  | 			color:#DD0000; | ||
|  | 			font-size: 30rpx; | ||
|  | 			font-weight: bold; | ||
|  | 		} | ||
|  | 	} | ||
|  | 	.commodity-info{ | ||
|  | 		display: flex; | ||
|  | 		justify-content: space-between; | ||
|  | 		align-items: center; | ||
|  | 		font-size: 32rpx; | ||
|  | 		&:last-child{ | ||
|  | 			font-size: 24rpx; | ||
|  | 			font-family: PingFang SC; | ||
|  | 			font-weight: 400; | ||
|  | 			color: #666666; | ||
|  | 			padding-top: 20rpx; | ||
|  | 		} | ||
|  | 		.commodity-price{ | ||
|  | 			&:before{ | ||
|  | 				 | ||
|  | 				content:"¥"; | ||
|  | 				font-size: 24rpx; | ||
|  | 			} | ||
|  | 		} | ||
|  | 	} | ||
|  | 	.top-line{ | ||
|  | 		border-top:rgba(216, 216, 216, 1) solid 2rpx ; | ||
|  | 	} | ||
|  | 	.post{ | ||
|  | 		height: 120rpx; | ||
|  | 		padding: 0 30rpx; | ||
|  | 
 | ||
|  | 		font-size: 32rpx; | ||
|  | 		font-family: PingFang SC; | ||
|  | 		font-weight: bold; | ||
|  | 		color: #000000; | ||
|  | 
 | ||
|  | 	} | ||
|  | 
 | ||
|  | .sendwayArea{ | ||
|  | 	margin: 26rpx; | ||
|  | 	display: flex; | ||
|  | 	border: 1px solid #515150; | ||
|  | 	border-radius: 13rpx; | ||
|  | 	width: fit-content; | ||
|  | 	background-color: white; | ||
|  | 	height: 94rpx; | ||
|  | 	position: relative; | ||
|  | 	.sendway-item{ | ||
|  | 		padding: 26rpx; | ||
|  | 		width: 170rpx; | ||
|  | 		font-size: 28rpx; | ||
|  | 		border-radius: 13rpx; | ||
|  | 		font-weight: 500; | ||
|  | 		position: absolute; | ||
|  | 		top: -2rpx; | ||
|  | 		bottom: -2rpx; | ||
|  | 	} | ||
|  | 	.sendway-item.active{ | ||
|  | 		background-image: linear-gradient(135deg, #9EE4FE, #7FD491); | ||
|  | 	} | ||
|  | 
 | ||
|  | } | ||
|  | 
 | ||
|  | .add-edit-content{ | ||
|  | 	background-color: white; | ||
|  | 	padding: 0 20rpx; | ||
|  | 	border-radius: 20rpx; | ||
|  | } | ||
|  | 
 | ||
|  | 		.coupon-btn { | ||
|  | 			color: #999999;; | ||
|  | 			display: flex; | ||
|  | 			align-items: center; | ||
|  | 			.select { | ||
|  | 				display: block; | ||
|  | 				width: 153rpx; | ||
|  | 				height: 40rpx; | ||
|  | 				background: #C3282E; | ||
|  | 				border-radius: 9rpx; | ||
|  | 				font-weight: 500; | ||
|  | 				font-size: 24rpx; | ||
|  | 				color: #FFFFFF; | ||
|  | 				text-align: center; | ||
|  | 				line-height: 40rpx; | ||
|  | 				font-family: PingFang SC; | ||
|  | 				margin-right: 20rpx; | ||
|  | 		 | ||
|  | 			} | ||
|  | 		} | ||
|  | .shop-name{ | ||
|  | 	font-weight: bold; | ||
|  | 	font-size: 31rpx; | ||
|  | 	color: #333333; | ||
|  | 	padding-bottom: 12rpx; | ||
|  | 	min-height: fit-content; | ||
|  | } | ||
|  | </style> |