Brak opisu
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.

shop_wechat_pay_select.htm 9.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. <!DOCTYPE HTML>
  2. <html>
  3. <head>
  4. <meta charset="utf-8" />
  5. <title>选择支付方式-{eyou:global name='web_name' /}</title>
  6. <meta name="renderer" content="webkit">
  7. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  8. <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" name="viewport" />
  9. <link href="{eyou:global name='web_cmspath' /}/favicon.ico" rel="shortcut icon" type="image/x-icon" />
  10. {eyou:static file="users/skin/css/basic.css" /}
  11. {eyou:static file="users/skin/css/eyoucms.css" /}
  12. {eyou:include file="users/skin/css/diy_css.htm" /}
  13. {eyou:static file="/public/static/common/js/jquery.min.js"/}
  14. {eyou:static file="/public/plugins/layer-v3.1.0/layer.js"/}
  15. {eyou:static file="/public/static/common/js/tag_global.js"/}
  16. </head>
  17. <body class="reg">
  18. <div class="register_index ey-member">
  19. <div class="container">
  20. <input type="hidden" id="unified_id" value='{$eyou.field.unified_id}'>
  21. <input type="hidden" id="unified_number" value='{$eyou.field.unified_number}'>
  22. <input type="hidden" id="transaction_type" value='{$eyou.field.transaction_type}'>
  23. <input type="hidden" id="order_source" value="{$eyou.field.order_source}">
  24. 商品价格:{$eyou.field.order_total_amount} &nbsp; &nbsp; &nbsp; &nbsp; 余额:{$users.users_money}
  25. {eyou:notempty name='$users.open_id'}
  26. <button class="btn btn-lg btn-primary btn-block" style="width: 100%;" onclick="WeChatInternal(this);" >
  27. 微信支付
  28. </button>
  29. {/eyou:notempty}
  30. <br/>
  31. <button class="btn btn-lg btn-primary btn-block" style="width: 100%;" id="BalancePayment" onclick="BalancePayment(this);">
  32. 余额支付
  33. </button>
  34. </div>
  35. </div>
  36. <script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.3.2.js"></script>
  37. <script type="text/javascript">
  38. $(function(){
  39. wx.miniProgram.getEnv( function(res) {
  40. if(res.miniprogram) {
  41. // 小程序
  42. var i = 0;
  43. i = setInterval('AppletsPay()', 1000);
  44. }
  45. });
  46. });
  47. // 小程序后查询
  48. function AppletsPay(){
  49. var unified_id = $('#unified_id').val();
  50. var unified_number = $('#unified_number').val();
  51. var transaction_type = $('#transaction_type').val();
  52. if (unified_id && unified_number && transaction_type) {
  53. $.ajax({
  54. url: "{eyou:url link='user/Pay/ajax_applets_pay'/}",
  55. data: {unified_id:unified_id, unified_number:unified_number, transaction_type:transaction_type},
  56. type:'post',
  57. dataType:'json',
  58. success:function(res){
  59. if (1 == res.code) {
  60. if (!res.data.mobile && !res.data.email) window.location.href = res.url;
  61. if (res.data.mobile) SendMobile(res.data.mobile);
  62. if (res.data.email) SendEmail(res.data.email);
  63. window.location.href = res.url;
  64. }
  65. }
  66. });
  67. }
  68. }
  69. // 微信内部中进行支付
  70. function WeChatInternal()
  71. {
  72. var unified_id = $('#unified_id').val();
  73. var unified_number = $('#unified_number').val();
  74. var transaction_type = $('#transaction_type').val();
  75. wx.miniProgram.getEnv( function(res) {
  76. if(res.miniprogram) {
  77. // 小程序
  78. wx.miniProgram.navigateTo({
  79. url: '/pages/pay/pay?unified_id='+ unified_id +'&unified_number=' + unified_number + '&type=' + transaction_type
  80. });
  81. } else {
  82. $.ajax({
  83. url: "{eyou:url link='user/Pay/wechat_pay'/}",
  84. data: {unified_id:unified_id,unified_number:unified_number,transaction_type:transaction_type},
  85. type:'post',
  86. dataType:'json',
  87. success:function(res){
  88. if (1 == res.code) {
  89. callpay(res.msg);
  90. }else{
  91. showErrorAlert(res.msg);
  92. }
  93. }
  94. });
  95. }
  96. });
  97. }
  98. //调用微信JS api 支付
  99. function jsApiCall(data)
  100. {
  101. WeixinJSBridge.invoke(
  102. 'getBrandWCPayRequest',data,
  103. function(res){
  104. if(res.err_msg == "get_brand_wcpay_request:ok"){
  105. layer.msg('微信支付完成!', {time: 1000}, function(){
  106. pay_deal_with();
  107. });
  108. }else if(res.err_msg == "get_brand_wcpay_request:cancel"){
  109. var order_source = $('#order_source').val();
  110. if (2 == order_source) {
  111. showErrorAlert('用户取消支付,请选择支付方式!');
  112. }else{
  113. layer.alert('用户取消支付,跳转至订单列表!', {icon:5, title: false, closeBtn: false},function(){
  114. var OrderUrl = "{eyou:url link='user/Shop/shop_centre'/}";
  115. window.location.href = OrderUrl;
  116. });
  117. }
  118. }else{
  119. showErrorAlert('支付失败');
  120. }
  121. }
  122. );
  123. }
  124. // 微信内部支付时,先进行数据判断
  125. function callpay(data)
  126. {
  127. if (typeof WeixinJSBridge == "undefined"){
  128. if( document.addEventListener ){
  129. document.addEventListener('WeixinJSBridgeReady', jsApiCall, false);
  130. }else if (document.attachEvent){
  131. document.attachEvent('WeixinJSBridgeReady', jsApiCall);
  132. document.attachEvent('onWeixinJSBridgeReady', jsApiCall);
  133. }
  134. }else{
  135. jsApiCall(data);
  136. }
  137. }
  138. // 余额支付,仅用于购买商品时支付
  139. function BalancePayment(){
  140. var unified_id = $('#unified_id').val();
  141. var unified_number = $('#unified_number').val();
  142. // 禁止再次点击余额支付
  143. $('#BalancePayment').prop("disabled",true).css("pointer-events","none");
  144. $.ajax({
  145. url: "{eyou:url link='user/Pay/balance_payment'/}",
  146. data: {unified_id:unified_id,unified_number:unified_number},
  147. type:'post',
  148. dataType:'json',
  149. success:function(res){
  150. if (1 == res.code) {
  151. layer.msg(res.msg, {time: 2000}, function(){
  152. window.location.href = res.url;
  153. });
  154. }else{
  155. IsRecharge(res.msg,res.url);
  156. }
  157. }
  158. });
  159. }
  160. // 是否要去充值
  161. function IsRecharge(msg='',url=''){
  162. layer.confirm(msg, {
  163. title:false,
  164. btn: ['去充值','其他方式支付'],
  165. cancel: function(index, layero){
  166. $('#BalancePayment').prop("disabled",false).css("pointer-events","");
  167. }
  168. }, function(){
  169. window.location.href = url;
  170. // layer.confirm('充值成功,是否立即支付?', {
  171. // title:false,
  172. // btn: ['立即支付','其他方式支付']
  173. // },function(){
  174. // BalancePayment();
  175. // },function(index){
  176. // // 选择其他方式支付时,恢复禁用的余额支付按钮
  177. // $('#BalancePayment').prop("disabled",false).css("pointer-events","");
  178. // layer.closeAll(index);
  179. // });
  180. }, function(index){
  181. // 选择其他方式支付时,恢复禁用的余额支付按钮
  182. $('#BalancePayment').prop("disabled",false).css("pointer-events","");
  183. layer.closeAll(index);
  184. });
  185. }
  186. // 支付后跳转
  187. function pay_deal_with(){
  188. var unified_number = $('#unified_number').val();
  189. var transaction_type = $('#transaction_type').val();
  190. $.ajax({
  191. url: "{eyou:url link='user/Pay/pay_deal_with'/}",
  192. data: {unified_number:unified_number,transaction_type:transaction_type},
  193. type:'post',
  194. dataType:'json',
  195. success:function(res){
  196. if (1 == res.data.status) {
  197. if (!res.data.mobile && !res.data.email) window.location.href = res.url;
  198. if (res.data.mobile) SendMobile(res.data.mobile);
  199. if (res.data.email) SendEmail(res.data.email);
  200. window.location.href = res.url;
  201. }
  202. }
  203. });
  204. }
  205. // 发送短信
  206. function SendMobile(result) {
  207. if (result) {
  208. $.ajax({
  209. url: result.url,
  210. data: result.data,
  211. type:'post',
  212. dataType:'json'
  213. });
  214. }
  215. }
  216. // 发送邮件
  217. function SendEmail(result) {
  218. if (result) {
  219. $.ajax({
  220. url: result.url,
  221. data: result.data,
  222. type:'post',
  223. dataType:'json'
  224. });
  225. }
  226. }
  227. </script>
  228. </body>
  229. </html>