payment.blade.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. @extends('user.layouts')
  2. @section('content')
  3. <div class="page-content container">
  4. <div class="panel panel-bordered">
  5. <div class="panel-heading">
  6. <h1 class="panel-title cyan-600"><i class="icon wb-payment"></i>{{\App\Components\Helpers::systemConfig()['website_name']}}{{trans('home.online_pay')}}
  7. </h1>
  8. </div>
  9. <div class="panel-body border-primary">
  10. <div class="row">
  11. <div class="col-2"></div>
  12. <div class="alert alert-info col-8 text-center">
  13. 请使用<strong class="red-600"> 支付宝 </strong>扫描二维码进行支付
  14. </div>
  15. <div class="col-2"></div>
  16. <div class="col-2"></div>
  17. <div class="row col-8">
  18. <div class="col-md-6">
  19. <ul class="list-group list-group-dividered">
  20. <li class="list-group-item">服务名称:{{$name}}</li>
  21. <li class="list-group-item">支付金额:{{$payment->amount}}元</li>
  22. @if($days != 0)
  23. <li class="list-group-item">有效期:{{$days}} 天</li>
  24. @endif
  25. <li class="list-group-item"> 请在<code>15分钟</code>内完成支付,否者订单将会自动关闭</li>
  26. </ul>
  27. </div>
  28. <div class="col-md-6 text-center mb-15">
  29. <img class="h-250 w-250" src="{{$payment->qr_code}}" alt="支付二维码">
  30. </div>
  31. </div>
  32. <div class="col-2"></div>
  33. <div class="col-2"></div>
  34. <div class="alert alert-danger col-8 text-center">
  35. <strong>手机用户</strong>:长按二维码 -> 保存图片 ->打开支付软件 -> 扫一扫 -> 选择相册 进行付款
  36. </div>
  37. <div class="col-2"></div>
  38. </div>
  39. </div>
  40. </div>
  41. </div>
  42. @endsection
  43. @section('script')
  44. <script type="text/javascript">
  45. // 检查支付单状态
  46. const r = window.setInterval(function () {
  47. $.ajax({
  48. type: 'GET',
  49. url: '/payment/getStatus',
  50. data: {sn: '{{$payment->sn}}'},
  51. dataType: 'json',
  52. success: function (ret) {
  53. window.clearInterval();
  54. if (ret.status === 'success') {
  55. swal.fire({title: ret.message, type: 'success', timer: 1500, showConfirmButton: false})
  56. .then(() => {
  57. window.location.href = '/invoices'
  58. });
  59. } else if (ret.status === 'error') {
  60. swal.fire({title: ret.message, type: "error", timer: 1500, showConfirmButton: false})
  61. .then(() => {
  62. window.location.href = '/invoices'
  63. })
  64. }
  65. }
  66. });
  67. }, 3000);
  68. // 还原html脚本 < > & " '
  69. function unescapeHTML(str) {
  70. str = "" + str;
  71. return str.replace(/&lt;/g, "<").replace(/&gt;/g, ">").replace(/&amp;/g, "&").replace(/&quot;/g, '"').replace(/&#039;/g, "'");
  72. }
  73. </script>
  74. @endsection