✨ 收银台:接入收银结果界面
							parent
							
								
									072f6a15a9
								
							
						
					
					
						commit
						4245164cae
					
				|  | @ -87,10 +87,11 @@ | ||||||
| 
 | 
 | ||||||
|   // 检测支付环境 |   // 检测支付环境 | ||||||
|   const state = reactive({ |   const state = reactive({ | ||||||
|     payment: '', |     orderType: 'goods', // 订单类型; goods - 商品订单, recharge - 充值订单 | ||||||
|     orderInfo: {}, |     orderInfo: {}, // 支付单信息 | ||||||
|     payStatus: 0, // 0=检测支付环境, -2=未查询到支付单信息, -1=支付已过期, 1=待支付,2=订单已支付 |     payStatus: 0, // 0=检测支付环境, -2=未查询到支付单信息, -1=支付已过期, 1=待支付,2=订单已支付 | ||||||
|     payMethods: [], |     payMethods: [], // 可选的支付方式 | ||||||
|  |     payment: '', // 选中的支付方式 | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   const onPay = () => { |   const onPay = () => { | ||||||
|  | @ -104,12 +105,12 @@ | ||||||
|         content: '确定要支付吗?', |         content: '确定要支付吗?', | ||||||
|         success: function (res) { |         success: function (res) { | ||||||
|           if (res.confirm) { |           if (res.confirm) { | ||||||
|             sheep.$platform.pay(state.payment, state.orderType, state.orderInfo.order_sn); |             sheep.$platform.pay(state.payment, state.orderType, state.orderInfo.id); | ||||||
|           } |           } | ||||||
|         }, |         }, | ||||||
|       }); |       }); | ||||||
|     } else { |     } else { | ||||||
|       sheep.$platform.pay(state.payment, state.orderType, state.orderInfo.order_sn); |       sheep.$platform.pay(state.payment, state.orderType, state.orderInfo.id); | ||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|  | @ -134,15 +135,16 @@ | ||||||
| 
 | 
 | ||||||
|   // 状态转换:payOrder.status => payStatus |   // 状态转换:payOrder.status => payStatus | ||||||
|   function checkPayStatus() { |   function checkPayStatus() { | ||||||
|     if (state.orderInfo.status === 10) { |     if (state.orderInfo.status === 10 | ||||||
|  |       || state.orderInfo.status === 20 ) { // 支付成功 | ||||||
|       state.payStatus = 2; |       state.payStatus = 2; | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     if (state.orderInfo.status === 20) { |     if (state.orderInfo.status === 30) { // 支付关闭 | ||||||
|       state.payStatus = -1; |       state.payStatus = -1; | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     state.payStatus = 1; |     state.payStatus = 1; // 待支付 | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   // 切换支付方式 |   // 切换支付方式 | ||||||
|  | @ -167,24 +169,25 @@ | ||||||
| 
 | 
 | ||||||
|   // 获得支付方式 |   // 获得支付方式 | ||||||
|   async function setPayMethods() { |   async function setPayMethods() { | ||||||
|     const { data, code } = await PayChannelApi.getEnableChannelCodeList(state.orderInfo.appId); |     const { data, code } = await PayChannelApi.getEnableChannelCodeList(state.orderInfo.appId) | ||||||
|     if (code !== 0) { |     if (code !== 0) { | ||||||
|       return; |       return | ||||||
|     } |     } | ||||||
|     state.payMethods = getPayMethods(data); |     state.payMethods = getPayMethods(data) | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   onLoad((options) => { |   onLoad((options) => { | ||||||
|     if ( |     if (sheep.$platform.name === 'WechatOfficialAccount' | ||||||
|       sheep.$platform.name === 'WechatOfficialAccount' && |       && sheep.$platform.os === 'ios' | ||||||
|       sheep.$platform.os === 'ios' && |       && !sheep.$platform.landingPage.includes('pages/pay/index')) { | ||||||
|       !sheep.$platform.landingPage.includes('pages/pay/index') |  | ||||||
|     ) { |  | ||||||
|       location.reload(); |       location.reload(); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     // 获得支付订单信息 |     // 获得支付订单信息 | ||||||
|     let id = options.id; |     let id = options.id; | ||||||
|  |     if (options.orderType) { | ||||||
|  |       state.orderType = options.orderType; | ||||||
|  |     } | ||||||
|     setOrder(id); |     setOrder(id); | ||||||
|   }); |   }); | ||||||
| </script> | </script> | ||||||
|  | @ -203,6 +206,7 @@ | ||||||
|       position: relative; |       position: relative; | ||||||
|       padding: 60rpx 20rpx 40rpx; |       padding: 60rpx 20rpx 40rpx; | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|       .money-text { |       .money-text { | ||||||
|         color: $red; |         color: $red; | ||||||
|         font-size: 46rpx; |         font-size: 46rpx; | ||||||
|  |  | ||||||
|  | @ -2,34 +2,27 @@ | ||||||
| <template> | <template> | ||||||
|   <s-layout title="支付结果" :bgStyle="{ color: '#FFF' }"> |   <s-layout title="支付结果" :bgStyle="{ color: '#FFF' }"> | ||||||
|     <view class="pay-result-box ss-flex-col ss-row-center ss-col-center"> |     <view class="pay-result-box ss-flex-col ss-row-center ss-col-center"> | ||||||
|       <view class="pay-waiting ss-m-b-30" v-if="payResult === 'waiting'"> </view> |       <!-- 信息展示 --> | ||||||
|  |       <view class="pay-waiting ss-m-b-30" v-if="payResult === 'waiting'" /> | ||||||
|       <image |       <image | ||||||
|         class="pay-img ss-m-b-30" |         class="pay-img ss-m-b-30" | ||||||
|         v-if="payResult === 'success'" |         v-if="payResult === 'success'" | ||||||
|         :src="sheep.$url.static('/static/img/shop/order/order_pay_success.gif')" |         :src="sheep.$url.static('/static/img/shop/order/order_pay_success.gif')" | ||||||
|       ></image> |       /> | ||||||
|       <image |       <image | ||||||
|         class="pay-img ss-m-b-30" |         class="pay-img ss-m-b-30" | ||||||
|         v-if="['failed', 'closed'].includes(payResult)" |         v-if="['failed', 'closed'].includes(payResult)" | ||||||
|         :src="sheep.$url.static('/static/img/shop/order/order_paty_fail.gif')" |         :src="sheep.$url.static('/static/img/shop/order/order_paty_fail.gif')" | ||||||
|       ></image> |       /> | ||||||
|       <view class="tip-text ss-m-b-30" v-if="payResult == 'success'">{{ |       <view class="tip-text ss-m-b-30" v-if="payResult === 'success'">支付成功</view> | ||||||
|         state.orderInfo.pay_mode === 'offline' ? '下单成功' : '支付成功' |       <view class="tip-text ss-m-b-30" v-if="payResult === 'failed'">支付失败</view> | ||||||
|       }}</view> |       <view class="tip-text ss-m-b-30" v-if="payResult === 'closed'">该订单已关闭</view> | ||||||
|       <view class="tip-text ss-m-b-30" v-if="payResult == 'failed'">支付失败</view> |       <view class="tip-text ss-m-b-30" v-if="payResult === 'waiting'">检测支付结果...</view> | ||||||
|       <view class="tip-text ss-m-b-30" v-if="payResult == 'closed'">该订单已关闭</view> |  | ||||||
|       <view class="tip-text ss-m-b-30" v-if="payResult == 'waiting'">检测支付结果...</view> |  | ||||||
|       <view class="pay-total-num ss-flex" v-if="payResult === 'success'"> |       <view class="pay-total-num ss-flex" v-if="payResult === 'success'"> | ||||||
|         <view v-if="Number(state.orderInfo.pay_fee) > 0">¥{{ state.orderInfo.pay_fee }}</view> |         <view>¥{{ fen2yuan(state.orderInfo.price) }}</view> | ||||||
|         <view v-if="state.orderInfo.score_amount && Number(state.orderInfo.pay_fee) > 0">+</view> |  | ||||||
|         <view class="price-text ss-flex ss-col-center" v-if="state.orderInfo.score_amount"> |  | ||||||
|           <image |  | ||||||
|             :src="sheep.$url.static('/static/img/shop/goods/score1.svg')" |  | ||||||
|             class="score-img" |  | ||||||
|           ></image> |  | ||||||
|           <view>{{ state.orderInfo.score_amount }}</view> |  | ||||||
|         </view> |  | ||||||
|       </view> |       </view> | ||||||
|  | 
 | ||||||
|  |       <!-- 操作区 --> | ||||||
|       <view class="btn-box ss-flex ss-row-center ss-m-t-50"> |       <view class="btn-box ss-flex ss-row-center ss-m-t-50"> | ||||||
|         <button class="back-btn ss-reset-button" @tap="sheep.$router.go('/pages/index/index')"> |         <button class="back-btn ss-reset-button" @tap="sheep.$router.go('/pages/index/index')"> | ||||||
|           返回首页 |           返回首页 | ||||||
|  | @ -37,30 +30,29 @@ | ||||||
|         <button |         <button | ||||||
|           class="check-btn ss-reset-button" |           class="check-btn ss-reset-button" | ||||||
|           v-if="payResult === 'failed'" |           v-if="payResult === 'failed'" | ||||||
|           @tap="sheep.$router.redirect('/pages/pay/index', { orderSN: state.orderId })" |           @tap=" | ||||||
|  |             sheep.$router.redirect('/pages/pay/index', { id: state.id, orderType: state.orderType }) | ||||||
|  |           " | ||||||
|         > |         > | ||||||
|           重新支付 |           重新支付 | ||||||
|         </button> |         </button> | ||||||
|         <button class="check-btn ss-reset-button" v-if="payResult === 'success'" @tap="onOrder"> |         <button class="check-btn ss-reset-button" v-if="payResult === 'success'" @tap="onOrder"> | ||||||
|           查看订单 |           查看订单 | ||||||
|         </button> |         </button> | ||||||
|  |         <!-- TODO 芋艿:拼团接入 --> | ||||||
|         <button |         <button | ||||||
|           class="check-btn ss-reset-button" |           class="check-btn ss-reset-button" | ||||||
|           v-if=" |           v-if="payResult === 'success' && state.tradeOrder.type === 3" | ||||||
|             payResult === 'success' && |  | ||||||
|             ['groupon', 'groupon_ladder'].includes(state.orderInfo.activity_type) |  | ||||||
|           " |  | ||||||
|           @tap="sheep.$router.redirect('/pages/activity/groupon/order')" |           @tap="sheep.$router.redirect('/pages/activity/groupon/order')" | ||||||
|         > |         > | ||||||
|           我的拼团 |           我的拼团 | ||||||
|         </button> |         </button> | ||||||
|       </view> |       </view> | ||||||
|  | 
 | ||||||
|  |       <!-- TODO 芋艿:订阅 --> | ||||||
|       <!-- #ifdef MP --> |       <!-- #ifdef MP --> | ||||||
|       <view class="subscribe-box ss-flex ss-m-t-44"> |       <view class="subscribe-box ss-flex ss-m-t-44"> | ||||||
|         <image |         <image class="subscribe-img" :src="sheep.$url.static('/static/img/shop/order/cargo.png')" /> | ||||||
|           class="subscribe-img" |  | ||||||
|           :src="sheep.$url.static('/static/img/shop/order/cargo.png')" |  | ||||||
|         ></image> |  | ||||||
|         <view class="subscribe-title ss-m-r-48 ss-m-l-16">获取实时发货信息与订单状态</view> |         <view class="subscribe-title ss-m-r-48 ss-m-l-16">获取实时发货信息与订单状态</view> | ||||||
|         <view class="subscribe-start" @tap="subscribeMessage">立即订阅</view> |         <view class="subscribe-start" @tap="subscribeMessage">立即订阅</view> | ||||||
|       </view> |       </view> | ||||||
|  | @ -74,15 +66,20 @@ | ||||||
|   import { reactive, computed } from 'vue'; |   import { reactive, computed } from 'vue'; | ||||||
|   import { isEmpty } from 'lodash'; |   import { isEmpty } from 'lodash'; | ||||||
|   import sheep from '@/sheep'; |   import sheep from '@/sheep'; | ||||||
|  |   import PayOrderApi from '@/sheep/api/pay/order'; | ||||||
|  |   import { fen2yuan } from '../../sheep/hooks/useGoods'; | ||||||
|  |   import OrderApi from '@/sheep/api/trade/order'; | ||||||
| 
 | 
 | ||||||
|   const state = reactive({ |   const state = reactive({ | ||||||
|     orderId: 0, |     id: 0, // 支付单号 | ||||||
|     orderType: 'goods', |     orderType: 'goods', // 订单类型 | ||||||
|     result: 'unpaid', // 支付状态 |     result: 'unpaid', // 支付状态 | ||||||
|     orderInfo: {}, // 订单详情 |     orderInfo: {}, // 支付订单信息 | ||||||
|  |     tradeOrder: {}, // 商品订单信息,只有在 orderType 为 goods 才会请求。目的:【我的拼团】按钮的展示 | ||||||
|     counter: 0, // 获取结果次数 |     counter: 0, // 获取结果次数 | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|  |   // 支付结果 result => payResult | ||||||
|   const payResult = computed(() => { |   const payResult = computed(() => { | ||||||
|     if (state.result === 'unpaid') { |     if (state.result === 'unpaid') { | ||||||
|       return 'waiting'; |       return 'waiting'; | ||||||
|  | @ -93,57 +90,65 @@ | ||||||
|     if (state.result === 'failed') { |     if (state.result === 'failed') { | ||||||
|       return 'failed'; |       return 'failed'; | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     if (state.result === 'closed') { |     if (state.result === 'closed') { | ||||||
|       return 'closed'; |       return 'closed'; | ||||||
|     } |     } | ||||||
|   }); |   }); | ||||||
|   async function getOrderInfo(orderId) { | 
 | ||||||
|     let checkPayResult; |   // 获得订单信息 | ||||||
|  |   async function getOrderInfo(id) { | ||||||
|     state.counter++; |     state.counter++; | ||||||
|     if (state.orderType === 'recharge') { |     // 1. 加载订单信息 | ||||||
|       checkPayResult = sheep.$api.trade.order; |     const { data, code } = await PayOrderApi.getOrder(id); | ||||||
|     } else { |     if (code === 0) { | ||||||
|       checkPayResult = sheep.$api.order.detail; |  | ||||||
|     } |  | ||||||
|     const { data, error } = await checkPayResult(orderId); |  | ||||||
|     if (error === 0) { |  | ||||||
|       state.orderInfo = data; |       state.orderInfo = data; | ||||||
|       if (state.orderInfo.status === 'closed') { |       if (!state.orderInfo || state.orderInfo.status === 30) { | ||||||
|  |         // 支付关闭 | ||||||
|         state.result = 'closed'; |         state.result = 'closed'; | ||||||
|         return; |         return; | ||||||
|       } |       } | ||||||
|       if (state.orderInfo.status !== 'unpaid') { |       if (state.orderInfo.status !== 0) { | ||||||
|  |         // 非待支付,可能是已支付,可能是已退款 | ||||||
|         state.result = 'paid'; |         state.result = 'paid'; | ||||||
|         // #ifdef MP |         // #ifdef MP | ||||||
|         subscribeMessage(); |         subscribeMessage(); | ||||||
|         // #endif |         // #endif | ||||||
|  |         // 特殊:获得商品订单信息 | ||||||
|  |         if (state.orderType === 'goods') { | ||||||
|  |           const { data, code } = await OrderApi.getOrder(state.orderInfo.merchantOrderId); | ||||||
|  |           if (code === 0) { | ||||||
|  |             state.tradeOrder = data; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|         return; |         return; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  |     // 2.1 情况三一:未支付,且轮询次数小于三次,则继续轮询 | ||||||
|     if (state.counter < 3 && state.result === 'unpaid') { |     if (state.counter < 3 && state.result === 'unpaid') { | ||||||
|       setTimeout(() => { |       setTimeout(() => { | ||||||
|         getOrderInfo(orderId); |         getOrderInfo(id); | ||||||
|       }, 1500); |       }, 1500); | ||||||
|     } |     } | ||||||
|     // 超过三次检测才判断为支付失败 |     // 2.2 情况二:超过三次检测才判断为支付失败 | ||||||
|     if (state.counter >= 3) { |     if (state.counter >= 3) { | ||||||
|       state.result = 'failed'; |       state.result = 'failed'; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   function onOrder() { |   function onOrder() { | ||||||
|     if ((state.orderType === 'recharge')) { |     // TODO 芋艿:待测试 | ||||||
|  |     if (state.orderType === 'recharge') { | ||||||
|       sheep.$router.redirect('/pages/pay/recharge-log'); |       sheep.$router.redirect('/pages/pay/recharge-log'); | ||||||
|     } else { |     } else { | ||||||
|       sheep.$router.redirect('/pages/order/list'); |       sheep.$router.redirect('/pages/order/list'); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  |   // TODO 芋艿:待测试 | ||||||
|   // #ifdef MP |   // #ifdef MP | ||||||
|   function subscribeMessage() { |   function subscribeMessage() { | ||||||
|     let event = ['order_dispatched']; |     let event = ['order_dispatched']; | ||||||
|     if (['groupon', 'groupon_ladder'].includes(state.orderInfo.activity_type)) { |     if (state.tradeOrder.type === 3) { | ||||||
|       event.push('groupon_finish'); |       event.push('groupon_finish'); | ||||||
|       event.push('groupon_fail'); |       event.push('groupon_fail'); | ||||||
|     } |     } | ||||||
|  | @ -152,18 +157,13 @@ | ||||||
|   // #endif |   // #endif | ||||||
| 
 | 
 | ||||||
|   onLoad(async (options) => { |   onLoad(async (options) => { | ||||||
|     let id = ''; |  | ||||||
|     // 支付订单号 |     // 支付订单号 | ||||||
|     if (options.orderSN) { |  | ||||||
|       id = options.orderSN; |  | ||||||
|     } |  | ||||||
|     if (options.id) { |     if (options.id) { | ||||||
|       id = options.id; |       state.id = options.id; | ||||||
|     } |     } | ||||||
|     state.orderId = id; |     // 订单类型 | ||||||
| 
 |     if (options.orderType) { | ||||||
|     if (options.orderType === 'recharge') { |       state.orderType = options.orderType; | ||||||
|       state.orderType = 'recharge'; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // 支付结果传值过来是失败,则直接显示失败界面 |     // 支付结果传值过来是失败,则直接显示失败界面 | ||||||
|  | @ -171,14 +171,16 @@ | ||||||
|       state.result = 'failed'; |       state.result = 'failed'; | ||||||
|     } else { |     } else { | ||||||
|       // 轮询三次检测订单支付结果 |       // 轮询三次检测订单支付结果 | ||||||
|       getOrderInfo(state.orderId); |       await getOrderInfo(state.id); | ||||||
|     } |     } | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   onShow(() => { |   onShow(() => { | ||||||
|     if(isEmpty(state.orderInfo)) return; |     if (isEmpty(state.orderInfo)) { | ||||||
|     getOrderInfo(state.orderId); |       return; | ||||||
|   }) |     } | ||||||
|  |     getOrderInfo(state.id); | ||||||
|  |   }); | ||||||
| 
 | 
 | ||||||
|   onHide(() => { |   onHide(() => { | ||||||
|     state.result = 'unpaid'; |     state.result = 'unpaid'; | ||||||
|  |  | ||||||
|  | @ -9,6 +9,14 @@ const PayOrderApi = { | ||||||
|       params: { id } |       params: { id } | ||||||
|     }); |     }); | ||||||
|   }, |   }, | ||||||
|  |   // 提交支付订单
 | ||||||
|  |   submitOrder: (data) => { | ||||||
|  |     return request({ | ||||||
|  |       url: '/app-api/pay/order/submit', | ||||||
|  |       method: 'POST', | ||||||
|  |       data | ||||||
|  |     }); | ||||||
|  |   } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export default PayOrderApi; | export default PayOrderApi; | ||||||
|  |  | ||||||
|  | @ -5,16 +5,16 @@ const OrderApi = { | ||||||
|   settlementOrder: (data) => { |   settlementOrder: (data) => { | ||||||
|     const data2 = { |     const data2 = { | ||||||
|       ...data, |       ...data, | ||||||
|     } |     }; | ||||||
|     // 移除多余字段
 |     // 移除多余字段
 | ||||||
|     if (!(data.couponId > 0)) { |     if (!(data.couponId > 0)) { | ||||||
|       delete data2.couponId |       delete data2.couponId; | ||||||
|     } |     } | ||||||
|     if (!(data.addressId > 0)) { |     if (!(data.addressId > 0)) { | ||||||
|       delete data2.addressId |       delete data2.addressId; | ||||||
|     } |     } | ||||||
|     // 解决 SpringMVC 接受 List<Item> 参数的问题
 |     // 解决 SpringMVC 接受 List<Item> 参数的问题
 | ||||||
|     delete data2.items |     delete data2.items; | ||||||
|     for (let i = 0; i < data.items.length; i++) { |     for (let i = 0; i < data.items.length; i++) { | ||||||
|       data2[encodeURIComponent('items[' + i + '' + '].skuId')] = data.items[i].skuId + ''; |       data2[encodeURIComponent('items[' + i + '' + '].skuId')] = data.items[i].skuId + ''; | ||||||
|       data2[encodeURIComponent('items[' + i + '' + '].count')] = data.items[i].count + ''; |       data2[encodeURIComponent('items[' + i + '' + '].count')] = data.items[i].count + ''; | ||||||
|  | @ -22,20 +22,32 @@ const OrderApi = { | ||||||
|         data2[encodeURIComponent('items[' + i + '' + '].cartId')] = data.items[i].cartId + ''; |         data2[encodeURIComponent('items[' + i + '' + '].cartId')] = data.items[i].cartId + ''; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     const queryString= Object.keys(data2).map(key => key + '=' + data2[key]).join('&') |     const queryString = Object.keys(data2) | ||||||
|  |       .map((key) => key + '=' + data2[key]) | ||||||
|  |       .join('&'); | ||||||
|     return request2({ |     return request2({ | ||||||
|       url: `trade/order/settlement?${queryString}`, |       url: `trade/order/settlement?${queryString}`, | ||||||
|       method: 'GET' |       method: 'GET', | ||||||
|     }) |     }); | ||||||
|   }, |   }, | ||||||
|   // 创建订单
 |   // 创建订单
 | ||||||
|   createOrder: (data) => { |   createOrder: (data) => { | ||||||
|     return request2({ |     return request2({ | ||||||
|       url: `trade/order/create`, |       url: `trade/order/create`, | ||||||
|       method: 'POST', |       method: 'POST', | ||||||
|       data |       data, | ||||||
|     }) |     }); | ||||||
|   } |   }, | ||||||
|  |   // 获得订单
 | ||||||
|  |   getOrder: (id) => { | ||||||
|  |     return request2({ | ||||||
|  |       url: `trade/order/get-detail`, | ||||||
|  |       method: 'GET', | ||||||
|  |       params: { | ||||||
|  |         id, | ||||||
|  |       }, | ||||||
|  |     }); | ||||||
|  |   }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export default OrderApi; | export default OrderApi; | ||||||
|  | @ -3,19 +3,20 @@ import sheep from '@/sheep'; | ||||||
| import $wxsdk from '@/sheep/libs/sdk-h5-weixin'; | import $wxsdk from '@/sheep/libs/sdk-h5-weixin'; | ||||||
| // #endif
 | // #endif
 | ||||||
| import { getRootUrl } from '@/sheep/helper'; | import { getRootUrl } from '@/sheep/helper'; | ||||||
|  | import PayOrderApi from '@/sheep/api/pay/order'; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 支付 |  * 支付 | ||||||
|  * |  * | ||||||
|  * @param {String} payment = ['wechat','alipay','wallet','offline']  	- 支付方式 |  * @param {String} payment = ['wechat','alipay','wallet','offline']  	- 支付方式 | ||||||
|  * @param {String} orderType = ['goods','recharge','groupon']  	- 订单类型 |  * @param {String} orderType = ['goods','recharge','groupon']  	- 订单类型 | ||||||
|  * @param {String} orderSN					- 订单号 |  * @param {String} id					- 订单号 | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| export default class SheepPay { | export default class SheepPay { | ||||||
|   constructor(payment, orderType, orderSN) { |   constructor(payment, orderType, id) { | ||||||
|     this.payment = payment; |     this.payment = payment; | ||||||
|     this.orderSN = orderSN; |     this.id = id; | ||||||
|     this.orderType = orderType; |     this.orderType = orderType; | ||||||
|     this.payAction(); |     this.payAction(); | ||||||
|   } |   } | ||||||
|  | @ -83,18 +84,21 @@ export default class SheepPay { | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   // 预支付
 |   // 预支付
 | ||||||
|   prepay() { |   prepay(channel) { | ||||||
|     return new Promise((resolve, reject) => { |     return new Promise((resolve, reject) => { | ||||||
|       let data = { |       let data = { | ||||||
|         order_sn: this.orderSN, |         id: this.id, | ||||||
|         payment: this.payment, |         channelCode: channel, | ||||||
|  |         channelExtras: {} | ||||||
|       }; |       }; | ||||||
|       if (uni.getStorageSync('openid')) { |       if (uni.getStorageSync('openid')) { | ||||||
|         data.openid = uni.getStorageSync('openid'); |         data.openid = uni.getStorageSync('openid'); | ||||||
|       } |       } | ||||||
|       sheep.$api.pay.prepay(data).then((res) => { |       PayOrderApi.submitOrder(data).then((res) => { | ||||||
|         res.error === 0 && resolve(res); |         // 成功时
 | ||||||
|         if (res.error === -1 && res.msg === 'miss_openid') { |         res.code === 0 && resolve(res); | ||||||
|  |         // 失败时
 | ||||||
|  |         if (res.code !== 0 && res.msg === 'miss_openid') { | ||||||
|           uni.showModal({ |           uni.showModal({ | ||||||
|             title: '微信支付', |             title: '微信支付', | ||||||
|             content: '请先绑定微信再使用微信支付', |             content: '请先绑定微信再使用微信支付', | ||||||
|  | @ -134,7 +138,7 @@ export default class SheepPay { | ||||||
|   async wechatWapPay() { |   async wechatWapPay() { | ||||||
|     const { error, data } = await this.prepay(); |     const { error, data } = await this.prepay(); | ||||||
|     if (error === 0) { |     if (error === 0) { | ||||||
|       const redirect_url = `${getRootUrl()}pages/pay/result?orderSN=${this.orderSN}&payment=${this.payment |       const redirect_url = `${getRootUrl()}pages/pay/result?id=${this.id}&payment=${this.payment | ||||||
|         }&orderType=${this.orderType}`;
 |         }&orderType=${this.orderType}`;
 | ||||||
|       location.href = `${data.pay_data.h5_url}&redirect_url=${encodeURIComponent(redirect_url)}`; |       location.href = `${data.pay_data.h5_url}&redirect_url=${encodeURIComponent(redirect_url)}`; | ||||||
|     } |     } | ||||||
|  | @ -144,7 +148,7 @@ export default class SheepPay { | ||||||
|   async redirectPay() { |   async redirectPay() { | ||||||
|     let { error, data } = await this.prepay(); |     let { error, data } = await this.prepay(); | ||||||
|     if (error === 0) { |     if (error === 0) { | ||||||
|       const redirect_url = `${getRootUrl()}pages/pay/result?orderSN=${this.orderSN}&payment=${this.payment |       const redirect_url = `${getRootUrl()}pages/pay/result?id=${this.id}&payment=${this.payment | ||||||
|         }&orderType=${this.orderType}`;
 |         }&orderType=${this.orderType}`;
 | ||||||
|       location.href = data.pay_data + encodeURIComponent(redirect_url); |       location.href = data.pay_data + encodeURIComponent(redirect_url); | ||||||
|     } |     } | ||||||
|  | @ -172,10 +176,10 @@ export default class SheepPay { | ||||||
|     }); |     }); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   // 余额支付  TODO 芋艿:待接入
 |   // 余额支付
 | ||||||
|   async walletPay() { |   async walletPay() { | ||||||
|     const { error } = await this.prepay(); |     const { code } = await this.prepay('wallet'); | ||||||
|     error === 0 && this.payResult('success'); |     code === 0 && this.payResult('success'); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   // 货到付款  TODO 芋艿:待接入
 |   // 货到付款  TODO 芋艿:待接入
 | ||||||
|  | @ -246,10 +250,9 @@ export default class SheepPay { | ||||||
|   // 支付结果跳转,success:成功,fail:失败
 |   // 支付结果跳转,success:成功,fail:失败
 | ||||||
|   payResult(resultType) { |   payResult(resultType) { | ||||||
|     sheep.$router.redirect('/pages/pay/result', { |     sheep.$router.redirect('/pages/pay/result', { | ||||||
|       orderSN: this.orderSN, |       id: this.id, | ||||||
|       payment: this.payment, //重新支付的时候使用
 |  | ||||||
|       payState: resultType, |  | ||||||
|       orderType: this.orderType, |       orderType: this.orderType, | ||||||
|  |       payState: resultType | ||||||
|     }); |     }); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 YunaiV
						YunaiV