pay.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. <template>
  2. <div class="brand">
  3. <scroller>
  4. <h2>收银台</h2>
  5. <group>
  6. <div class="order-info">订单类型:<span>{{orderType}}</span></div>
  7. <div class="order-info">微信支付:<span>{{orderPayValue}}</span></div>
  8. </group>
  9. <group>
  10. <div class="pay-type">支付方式</div>
  11. </group>
  12. <group>
  13. <a href="javascript:void(0)" class="pay-option checked" data-value="wx_pub"> <i class="icon-weixin"></i>
  14. 微信支付 </a>
  15. </group>
  16. <div class="btn" @click="btnPay">确认支付</div>
  17. </scroller>
  18. </div>
  19. </template>
  20. <script>
  21. import {CheckIcon, Group} from 'vux'
  22. import axios from 'axios'
  23. import config from '../config/config'
  24. // import api from '../config/api'
  25. import qs from 'qs'
  26. export default {
  27. data () {
  28. return {
  29. orderType: '', // 订单类型
  30. orderCoupon: '', // 代金券支付
  31. orderBalance: '', // 余额支付
  32. orderPayValue: '' // 微信支付
  33. }
  34. },
  35. components: {
  36. CheckIcon,
  37. Group
  38. },
  39. created () {
  40. if (this.$route.query.payRecharge !== undefined) {
  41. // 订单类型
  42. this.orderType = this.$route.query.payRecharge.products
  43. // 微信支付
  44. this.orderPayValue = this.$route.query.payRecharge.final_price
  45. } else if (this.$route.query.orderInfo !== undefined) {
  46. // 订单类型 orderType
  47. this.orderType = this.$route.query.orderInfo.products_str
  48. // 代金券支付 orderCoupon
  49. this.orderCoupon = this.$route.query.orderInfo.final_price
  50. // 余额支付 orderBalance
  51. this.orderBalance = this.$route.query.orderInfo.final_price
  52. // 微信支付 orderPayValue
  53. this.orderPayValue = this.$route.query.orderInfo.final_price
  54. console.log(this.$route.query.orderInfo)
  55. if (this.$route.query.orderInfo.coupons && this.$route.query.orderInfo.coupons.length) {
  56. for (let i in this.$route.query.orderInfo.coupons) {
  57. this.orderCoupon += parseInt(this.$route.query.orderInfo.coupons[i].coupon.value)
  58. }
  59. }
  60. if (this.$route.query.orderInfo.pay_price && this.$route.query.orderInfo.pay_price !== 0) {
  61. this.orderBalance = this.$route.query.orderInfo.final_price - this.$route.query.orderInfo.pay_price
  62. }
  63. if (this.$route.query.orderInfo.pay_price && this.$route.query.orderInfo.pay_price !== 0) {
  64. this.orderPayValue = this.$route.query.orderInfo.pay_price
  65. } else {
  66. this.orderPayValue = this.$route.query.orderInfo.final_price
  67. }
  68. }
  69. },
  70. methods: {
  71. btnPay () {
  72. if (this.$route.query.payRecharge !== {}) {
  73. let payRecharge = {
  74. user_id: config.userId,
  75. order_id: this.$route.query.payRecharge.order_id,
  76. pay_channel: 'wx_pub'
  77. }
  78. axios.post('o2o/recharge/payRecharge', qs.stringify(payRecharge)).then(res => {
  79. this.pay(res.data, payRecharge.order_id)
  80. })
  81. } else if (config.orderInfo.length !== 0) {
  82. axios.post('o2o/order/pay', qs.stringify(config.orderInfo)).then(res => {
  83. this.pay(res.data)
  84. })
  85. }
  86. },
  87. pay (res, orderId, charge) {
  88. let orderInfo = {}
  89. console.log(orderId)
  90. // window.location.href = 'http://common.yiguanjia.me/webapp/o2o/module/pay/index.html?appId=' +
  91. // option.appId + '&nonceStr=' + option.nonceStr +
  92. // '&package=' + prepay + '&signType=' +
  93. // option.signType + '&timeStamp=' +
  94. // option.timeStamp + '&paySign=' +
  95. // option.paySign + '&amount=' + wxPay.amount +
  96. // '&created=' + wxPay.created + '&body=' +
  97. // wxPay.body + '&bookingTime=' + bookingTime
  98. if (res.success) {
  99. let orderList = {user_id: config.userId, type: 1}
  100. axios.post('o2o/order/list', qs.stringify(orderList)).then(res => {
  101. for (let i in res.data.data) {
  102. if (orderId === res.data.data[i].id) {
  103. orderInfo = res.data.data[i]
  104. }
  105. }
  106. })
  107. console.log(orderInfo)
  108. // var orderInfo = user.getOrderInfo(orderID);
  109. // var params = {
  110. // orderInfo: orderInfo,
  111. // charge: res.data
  112. // }
  113. // 调用native中pay方法,传值orderInfo,charge并做回调,返回充值结果
  114. // native.pay(params, function (resA) {
  115. // if (resA.success) {
  116. // $doc.trigger('spa:navigate', {
  117. // hash: 'paySuccess'
  118. // });
  119. // } else {
  120. // $doc.trigger('spa:openpanel', ['simpleAlert', {
  121. // message: resA.message
  122. // }]);
  123. // }
  124. // });
  125. }
  126. }
  127. }
  128. }
  129. </script>
  130. <style lang="less" scoped>
  131. h2 {
  132. line-height: 2em;
  133. margin-bottom: -15px;
  134. }
  135. .btn {
  136. display: block;
  137. width: 95%;
  138. color: white;
  139. margin: 15px auto 0;
  140. padding: 15px 0;
  141. font-size: 18px;
  142. background-color: rgba(146, 118, 3, 1);
  143. transition: all .5s;
  144. &:active {
  145. color: #0b0b0b;
  146. background-color: rgba(146, 118, 3, 0.86);
  147. }
  148. }
  149. .order-info {
  150. text-align: left;
  151. padding: 15px;
  152. &:nth-child(1) {
  153. padding-bottom: 0;
  154. }
  155. &:nth-child(2) {
  156. padding-top: 0;
  157. }
  158. }
  159. .pay-type {
  160. text-align: left;
  161. line-height: 50px;
  162. font-size: 18px;
  163. padding-left: 15px;
  164. font-weight: 600;
  165. }
  166. .pay-option {
  167. color: black;
  168. position: relative;
  169. display: block;
  170. overflow: hidden;
  171. text-align: left;
  172. padding: 15px 0 15px 15px;
  173. &:before {
  174. content: '';
  175. width: 18px;
  176. height: 18px;
  177. display: inline-block;
  178. vertical-align: middle;
  179. background: url() no-repeat;
  180. background-size: cover;
  181. }
  182. .icon-weixin {
  183. width: 24px;
  184. height: 24px;
  185. color: black;
  186. display: inline-block;
  187. vertical-align: middle;
  188. margin-left: 7px;
  189. margin-right: 7px;
  190. background: url() no-repeat;
  191. background-size: cover;
  192. }
  193. }
  194. .checked:before {
  195. background: url() no-repeat;
  196. background-size: cover;
  197. }
  198. </style>