From cb623fcefa72d5b54b1e536aa84c3f3851743975 Mon Sep 17 00:00:00 2001 From: xuxueyang <xuxy@fengyuntec.com> Date: 星期三, 20 十一月 2024 11:01:43 +0800 Subject: [PATCH] update 打印可能的空白(不能确定是不是纸张大小超出还是空数据的问题,已经提交了 --- sub_pages/customer/shopping/confirm.vue | 147 +++++++++++++++++++++++++------------------------ 1 files changed, 75 insertions(+), 72 deletions(-) diff --git a/sub_pages/customer/shopping/confirm.vue b/sub_pages/customer/shopping/confirm.vue index 662ac88..bed5b0a 100644 --- a/sub_pages/customer/shopping/confirm.vue +++ b/sub_pages/customer/shopping/confirm.vue @@ -17,9 +17,50 @@ cache_goods: state => { return state.cache.goods || [] }, + cache_coupon_select_cancel: state => { + return state.cache.cache_coupon_select_cancel==1?1:0 + }, }), coupon_fee() { //优惠券 + // 查看当前有没有优惠券 + if(!this.dto.couponRecordId || !this.cache_coupon ){ + // 根据优惠券的列表,查找到最合适的优惠券 + // 遍历优惠券的使用金额大于当前金额的,获取面值最大的优惠券取最大值couponDiscountValue + var total = (this.dto.totalMemberAmount || this.dto.totalAmount || 0).toFixed(2) + if(total && total>0){ + // 获取当前用户最合适的优惠券 + let res= this.$http.request('get', '/api/v2/coupon/app/mine/unused/fit', { + params: {orderAmount:total} + }).then(async res => { + let tmpCoupon = res.data; + if (tmpCoupon) { + if(this.cache_coupon_select_cancel==0){ + console.log("自动为您选择优惠最大的优惠券") + await this.$store.dispatch('cache_coupon_select', tmpCoupon); + this.dto.couponRecordId = tmpCoupon.id; + this.dto.couponRecordStr = tmpCoupon.couponName; + setTimeout(() => { + this.$message.showToast('自动为您选择优惠最大的优惠券') + }, 2000) + + }else{ + console.log("清空") + await this.$store.dispatch('cache_coupon_select', {}); + this.dto.couponRecordId =""; + this.dto.couponRecordStr = ""; + } + + } + + }).catch(error => { + console.error('获取优惠券失败:', error); + }); + + } + + } + if (this.dto.couponRecordId && this.cache_coupon) { //计算优惠券 if (this.cache_coupon.couponDiscountType === 'zero') { @@ -44,9 +85,14 @@ return 0 }, order_fee() { + // 如果订单-优惠券<0,就等于0 +打包+运费,如果还等于0,那么就0.01 var m1 = parseFloat(this.dto.totalMemberAmount || this.dto.totalAmount || 0) var m2 = parseFloat((this.dto.packing || 0) + (this.current_transport.fee || 0)) + + // 统一处理 Promise 和普通值 + // var couponFee = await this.coupon_fee; + if (m1 <= parseFloat(this.coupon_fee)) { if (m2 > 0) { @@ -64,47 +110,12 @@ async beforeDestroy() { await this.$store.dispatch('cache_coupon_select', {}) await this.$store.dispatch('cache_goods_select', []) + await this.$store.dispatch('cache_coupon_select_cancel', 0) }, - async onShow() { - // 支付回调 - // #ifdef PUB_CUSTOMER_DEV - let options = wx.getEnterOptionsSync(); - if (options.scene == '1038' && options.referrerInfo.appId=='wxef277996acc166c3') { - // 代表从收银台小程序返回 - let extraData = options.referrerInfo.extraData; - // if (!extraData) { - // // "当前通过物理按键返回,未接收到返参,建议自行查询交易结果"; - // } else { - // if (extraData.code == 'success') { - // // "支付成功"; - // } else if (extraData.code == 'cancel') { - // // "支付已取消"; - // this.$message.showToast("支付已取消" + extraData.errmsg) - // } else { - // // "支付失败:" + extraData.errmsg; - // this.$message.showToast("支付失败:" + extraData.errmsg) - // } - // } - // - //只要是进入了这个支付页面,都算是支付了,不管成功与否都返回 - console.log('pay success options.referrerInfo', options.referrerInfo) - //返回上一页 - let tmp = this - await tmp.$store.dispatch('sign_add', 'shopping') - //清空优惠券 - tmp.$store.dispatch('cache_coupon_select', {}) - tmp.$store.dispatch('cache_goods_select', []) - - await tmp.$message.showToast('支付成功',{ - duration:500 - }) - uni.navigateBack() - return - } - - - // #endif + onShow() { + // 获取当前用户为使用的优惠券 + // this.getSuitableCouponAuto() //优惠券 if (this.cache_coupon && this.cache_coupon.id) { this.dto.couponRecordId = this.cache_coupon.id @@ -191,6 +202,7 @@ couponRecordId: '', couponRecordStr: '', goodsRecordIdListStr: '', + unusedCouponList:[], }, current_transport: {}, cacheAddressId: '', @@ -200,6 +212,7 @@ [] ], partnerInfo: {}, + isShowFlag:true, } }, @@ -219,6 +232,20 @@ } }, methods: { + + async getSuitableCouponAuto(){ + //1.提交订单后,根据订单的商品金额,判断是否达到优惠券使用条件,如果达到,自动选择面值最大的优惠券,用户也可以在优惠券自己切换优惠券或不使用优惠券 + await this.$http.request('get', '/api/v2/coupon/app/mine/unused/list', { + params: {} + }).then(res => { + var data = res.data + this.unusedCouponList = data.list || [] + + }) + + + }, + toSelectCoupon() { //跳转去列表页面进行选择 var total = ((this.dto.totalMemberAmount || this.dto.totalAmount || 0) + (this.dto.packing || 0) + (this @@ -335,7 +362,6 @@ await tmp.$store.dispatch('sign_add', 'shopping') uni.navigateBack() } else if (data) { - // #ifndef PUB_CUSTOMER_DEV wx.requestPayment({ ...data, async success(res) { @@ -363,33 +389,6 @@ // uni.navigateBack() } }) - // #endif - // openEmbeddedMiniProgram,需要小程序基础库版本不低于 2.26.2 - - // #ifdef PUB_CUSTOMER_DEV - var param = { - // cusid: "平台分配的商户号", - // appid: "平台分配的appid", - // orgid: "平台分配的机构号", - // version: "12", - // trxamt: "1", - // reqsn: "商户唯一订单号", - // notify_url: "服务器异步通知页面路径", - // body: "标题", - // remark: "备注", - // validtime: "订单有效时间", - // limit_pay: "no_credit", - // randomstr: "随机字符串", - // paytype: "W06", - // signtype: "签名方式", - // sign: "签名,参考2.1", - ...data, - } - wx.openEmbeddedMiniProgram({ - appId: 'wxef277996acc166c3', - extraData: param - }) - // #endif } } @@ -507,12 +506,12 @@ <view class="p10 bg-white m-t-20 br-4"> <view class="form-item flex "> - <view class="label">优惠券</view> + <view class="label t-red">优惠券</view> - <view class="m-l-a m-r-0 flex " :class="[!dto.couponRecordId?'desc-gray':'']" + <view class="m-l-a m-r-0 flex t-red" :class="[!dto.couponRecordId?'desc-gray':'']" @click="toSelectCoupon"> <view>{{dto.couponRecordStr||dto.couponRecordId || '请选择'}}</view> - <u-icon class="m-l-a" name="arrow-right"></u-icon> + <u-icon class="m-l-a t-red" name="arrow-right"></u-icon> </view> </view> @@ -573,10 +572,10 @@ </view> </view> <view class="desc flex" v-if="cache_coupon&&cache_coupon.id"> - <view> + <view class="t-red"> 优惠({{cache_coupon.couponDiscountType=='zero'?'无门槛':(cache_coupon.minOrderAmount?(`满¥${cache_coupon.minOrderAmount}可用`):'无门槛')}},优惠¥{{cache_coupon.couponDiscountValue||'0'}}): </view> - <view class="m-l-a m-r-0 text-right"> + <view class="m-l-a m-r-0 text-right t-red"> -{{ coupon_fee || 0 }} </view> </view> @@ -605,6 +604,10 @@ .page-confirm { padding: 20rpx 30rpx; + .border-red { + border: 1px solid red; + } + .bottom-price { position: fixed; background-color: #ffffff; -- Gitblit v1.9.3