services.blade.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. @extends('user.layouts')
  2. @section('content')
  3. <div class="page-content">
  4. <div class="row">
  5. <div class="col-xxl-2 col-lg-3">
  6. <div class="card card-shadow">
  7. <div class="card-block p-20">
  8. <button type="button" class="btn btn-floating btn-sm btn-pure">
  9. <i class="icon wb-payment green-500"></i>
  10. </button>
  11. <span class="font-weight-400">{{trans('home.account_balance')}}</span>
  12. <div class="content-text text-center mb-0">
  13. <span class="font-size-40 font-weight-100">{{Auth::user()->balance}}</span>
  14. <br/>
  15. <button class="btn btn-danger float-right mr-15" data-toggle="modal" data-target="#charge_modal">{{trans('home.recharge')}}</button>
  16. </div>
  17. </div>
  18. </div>
  19. @if($renewTraffic)
  20. <div class="card card-shadow">
  21. <div class="card-block p-20">
  22. <button type="button" class="btn btn-floating btn-sm btn-pure">
  23. <i class="icon wb-payment green-500"></i>
  24. </button>
  25. <span class="font-weight-400">流量重置</span>
  26. <div class="content-text text-center mb-0">
  27. <span class="font-size-20 font-weight-100">需要 <code>{{$renewTraffic}}</code> 元</span>
  28. <br/>
  29. <button class="btn btn-danger mt-10" onclick="resetTraffic()">重置</button>
  30. </div>
  31. </div>
  32. </div>
  33. @endif
  34. </div>
  35. <div class="col-xxl-10 col-lg-9">
  36. <div class="panel">
  37. <div class="panel-heading p-20">
  38. <h1 class="panel-title cyan-700"><i class="icon wb-shopping-cart"></i>{{trans('home.services')}}
  39. </h1>
  40. </div>
  41. <div class="panel-body">
  42. <div class="row">
  43. @foreach($goodsList as $goods)
  44. <div class="col-md-6 col-xl-4 col-xxl-3 pb-30">
  45. <div class="pricing-list text-left">
  46. <div class="pricing-header text-white" style="background-color: {{$goods->color}}">
  47. <div class="pricing-title font-size-20">{{$goods->name}}</div>
  48. @if($goods->limit_num)
  49. <div class="ribbon ribbon-vertical ribbon-bookmark ribbon-reverse ribbon-primary mr-10">
  50. <span class="ribbon-inner h-auto">限<br>购</span>
  51. </div>
  52. @elseif($goods->is_hot)
  53. <div class="ribbon ribbon-vertical ribbon-bookmark ribbon-reverse ribbon-danger mr-10">
  54. <span class="ribbon-inner h-auto">热<br>销</span>
  55. </div>
  56. @endif
  57. <div class="pricing-price text-white @if($goods->type == 1) text-center @endif">
  58. <span class="pricing-currency">¥</span>
  59. <span class="pricing-amount">{{$goods->price}}</span>
  60. @if($goods->type == 2)
  61. <span class="pricing-period">/ {{$goods->days}}{{trans('home.day')}}</span>
  62. @endif
  63. </div>
  64. @if($goods->info)
  65. <p class="px-30 pb-25 text-center">{{$goods->desc}}</p>
  66. @endif
  67. </div>
  68. <ul class="pricing-features">
  69. <li>
  70. <strong>{{$goods->traffic_label}}</strong> {{trans('home.bandwidth')}}{!!$goods->type == 1? ' <code>'.$dataPlusDays.'</code> '.trans('home.day'):'/'.trans('home.month')!!}
  71. </li>
  72. <li>
  73. <strong>{{trans('home.service_unlimited')}}</strong> {{trans('home.service_device')}}
  74. </li>
  75. {!!$goods->info!!}
  76. </ul>
  77. <div class="pricing-footer text-center bg-blue-grey-100">
  78. <a href="/buy/{{$goods->id}}" class="btn btn-lg btn-primary"> {{trans('home.service_buy_button')}}</a>
  79. </div>
  80. </div>
  81. </div>
  82. @endforeach
  83. </div>
  84. </div>
  85. </div>
  86. </div>
  87. </div>
  88. </div>
  89. <div id="charge_modal" class="modal fade" aria-labelledby="charge_modal" role="dialog" tabindex="-1" aria-hidden="true">
  90. <div class="modal-dialog modal-simple modal-center">
  91. <div class="modal-content">
  92. <div class="modal-header">
  93. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  94. <span aria-hidden="true">×</span></button>
  95. <h4 class="modal-title">{{trans('home.recharge_balance')}}</h4>
  96. </div>
  97. <div class="modal-body">
  98. <div class="alert alert-danger" id="charge_msg" style="display: none;"></div>
  99. <form action="#" method="post">
  100. @if(\App\Components\Helpers::systemConfig()['alipay_qrcode'] || \App\Components\Helpers::systemConfig()['wechat_qrcode'] || ($chargeGoodsList->isNotEmpty() && (\App\Components\Helpers::systemConfig()['is_alipay'] || \App\Components\Helpers::systemConfig()['is_f2fpay'])))
  101. <div class="mb-15 w-p50">
  102. <select class="form-control" name="charge_type" id="charge_type">
  103. @if($chargeGoodsList->isNotEmpty() && (\App\Components\Helpers::systemConfig()['is_alipay'] || \App\Components\Helpers::systemConfig()['is_f2fpay']))
  104. <option value="1" selected>{{trans('home.online_pay')}}</option>
  105. @endif
  106. @if(\App\Components\Helpers::systemConfig()['alipay_qrcode'] || \App\Components\Helpers::systemConfig()['wechat_qrcode'])
  107. <option value="2" @if($chargeGoodsList->isEmpty()) selected @endif>二维码</option>
  108. @endif
  109. <option value="3">{{trans('home.coupon_code')}}</option>
  110. </select>
  111. </div>
  112. @endif
  113. @if($chargeGoodsList->isNotEmpty() && (\App\Components\Helpers::systemConfig()['is_alipay'] || \App\Components\Helpers::systemConfig()['is_f2fpay']))
  114. <div class="form-group row" id="charge_balance">
  115. <label for="online_pay" class="offset-md-2 col-md-2 col-form-label">充值金额</label>
  116. <div class="col-md-6">
  117. <select class="form-control round" name="online_pay" id="online_pay">
  118. @foreach($chargeGoodsList as $goods)
  119. <option value="{{$goods->id}}">充值{{$goods->price}}元</option>
  120. @endforeach
  121. </select>
  122. </div>
  123. </div>
  124. @endif
  125. @if(\App\Components\Helpers::systemConfig()['alipay_qrcode'] || \App\Components\Helpers::systemConfig()['wechat_qrcode'])
  126. <div class="text-center" id="charge_qrcode" @if($chargeGoodsList->isNotEmpty() && (\App\Components\Helpers::systemConfig()['is_alipay'] || \App\Components\Helpers::systemConfig()['is_f2fpay']))style="display: none;" @endif>
  127. <div class="row">
  128. <p class="col-md-12 mb-10">付款时,请
  129. <mark>备注邮箱账号</mark>
  130. ,充值会在<code>24</code>小时内受理!
  131. </p>
  132. @if(\App\Components\Helpers::systemConfig()['wechat_qrcode'])
  133. <div class="col-md-6">
  134. <img class="w-p75 mb-10" src="{{\App\Components\Helpers::systemConfig()['wechat_qrcode']}}" alt=""/>
  135. <p>微 信 | WeChat</p>
  136. </div>
  137. @endif
  138. @if(\App\Components\Helpers::systemConfig()['alipay_qrcode'])
  139. <div class="col-md-6">
  140. <img class="w-p75 mb-10" src="{{\App\Components\Helpers::systemConfig()['alipay_qrcode']}}" alt=""/>
  141. <p>支 付 宝 | AliPay</p>
  142. </div>
  143. @endif
  144. </div>
  145. </div>
  146. @endif
  147. <div class="form-group row" id="charge_coupon_code" @if(\App\Components\Helpers::systemConfig()['alipay_qrcode'] || \App\Components\Helpers::systemConfig()['wechat_qrcode']|| ($chargeGoodsList->isNotEmpty() && (\App\Components\Helpers::systemConfig()['is_alipay'] || \App\Components\Helpers::systemConfig()['is_f2fpay']))) style="display: none;" @endif>
  148. <label for="charge_coupon" class="offset-md-2 col-md-2 col-form-label"> {{trans('home.coupon_code')}} </label>
  149. <div class="col-md-6">
  150. <input type="text" class="form-control round" name="charge_coupon" id="charge_coupon" placeholder="{{trans('home.please_input_coupon')}}">
  151. </div>
  152. </div>
  153. </form>
  154. </div>
  155. <div class="modal-footer">
  156. <button type="button" class="btn btn-default" data-dismiss="modal">{{trans('home.close')}}</button>
  157. <button type="button" class="btn btn-primary" id="change_btn" onclick="charge()">{{trans('home.recharge')}}</button>
  158. </div>
  159. </div>
  160. </div>
  161. </div>
  162. @endsection @section('script')
  163. <script type="text/javascript">
  164. // 切换充值方式
  165. $("#charge_type").change(function () {
  166. if ($(this).val() === '1') {
  167. $("#charge_balance").show();
  168. $("#change_btn").show();
  169. $("#charge_qrcode").hide();
  170. $("#charge_coupon_code").hide();
  171. } else if ($(this).val() === '2') {
  172. $("#charge_balance").hide();
  173. $("#change_btn").hide();
  174. $("#charge_qrcode").show();
  175. $("#charge_coupon_code").hide();
  176. } else {
  177. $("#charge_balance").hide();
  178. $("#charge_qrcode").hide();
  179. $("#charge_coupon_code").show();
  180. $("#change_btn").show();
  181. }
  182. });
  183. // 重置流量
  184. function resetTraffic() {
  185. swal.fire({
  186. title: '重置流量',
  187. text: '本次重置流量将扣除余额 {{$renewTraffic}} 元?',
  188. type: 'question',
  189. showCancelButton: true,
  190. cancelButtonText: '{{trans('home.ticket_close')}}',
  191. confirmButtonText: '{{trans('home.ticket_confirm')}}',
  192. }).then((result) => {
  193. if (result.value) {
  194. $.post("/resetUserTraffic", {_token: '{{csrf_token()}}'}, function (ret) {
  195. if (ret.status === 'success') {
  196. swal.fire({title: ret.message, type: 'success', timer: 1000, showConfirmButton: false})
  197. .then(() => window.location.reload())
  198. } else {
  199. swal.fire({title: ret.message, text: ret.data, type: "error"}).then(() => window.location.reload())
  200. }
  201. });
  202. }
  203. });
  204. }
  205. // 充值
  206. function charge() {
  207. const paymentType = $('#charge_type').val();
  208. const charge_coupon = $('#charge_coupon').val();
  209. if (paymentType === '1') {
  210. $("#charge_msg").show().html("正在跳转支付界面");
  211. window.location.href = '/buy/' + $('#online_pay').val();
  212. return false;
  213. }
  214. if (paymentType === '3' && charge_coupon.trim() === '') {
  215. $("#charge_msg").show().html("{{trans('home.coupon_not_empty')}}");
  216. $("#charge_coupon").focus();
  217. return false;
  218. }
  219. $.ajax({
  220. type: "POST",
  221. url: '/charge',
  222. data: {_token: '{{csrf_token()}}', coupon_sn: charge_coupon},
  223. beforeSend: function () {
  224. $("#charge_msg").show().html("{{trans('home.recharging')}}");
  225. },
  226. success: function (ret) {
  227. if (ret.status === 'fail') {
  228. $("#charge_msg").show().html(ret.message);
  229. return false;
  230. }
  231. $("#charge_modal").modal("hide");
  232. window.location.reload();
  233. },
  234. error: function () {
  235. $("#charge_msg").show().html("{{trans('home.error_response')}}");
  236. },
  237. complete: function () {
  238. }
  239. });
  240. }
  241. </script>
  242. @endsection