services.blade.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. <!--@extends('user.layouts')-->
  2. @section('css')
  3. <link rel="stylesheet" href="assets/global/vendor/ionrangeslider/ionrangeslider.min.css">
  4. @endsection
  5. @section('content')
  6. <div class="page-content">
  7. <!--<div class="row">-->
  8. <!-- <div class="col-xxl-2 col-lg-3">-->
  9. <!-- <div class="card card-shadow">-->
  10. <!-- <div class="card-block p-20">-->
  11. <!-- <div class="font-weight-400">{{$username}}</div>-->
  12. <!-- <button type="button" class="btn btn-floating btn-sm btn-pure">-->
  13. <!-- <i class="icon wb-payment green-500"></i>-->
  14. <!-- </button>-->
  15. <!-- <span class="font-weight-400">{{trans('user.account.credit')}}</span>-->
  16. <!-- <div class="content-text text-center mb-0">-->
  17. <!-- <span class="font-size-40 font-weight-100">{{Auth::getUser()->credit}}</span>-->
  18. <!-- <br/>-->
  19. <!-- <button class="btn btn-danger float-right mr-15" data-toggle="modal" data-target="#charge_modal">{{trans('user.recharge')}}</button>-->
  20. <!-- </div>-->
  21. <!-- </div>-->
  22. <!--<li>-->
  23. <!-- 使用余额购买下面的vip套餐才会开通服务!-->
  24. <!-- </li>-->
  25. <!--</div>-->
  26. <!--</div>-->
  27. <div class="col-xxl-10 col-lg-9">
  28. <div class="panel">
  29. <div class="panel-heading p-20">
  30. <h1 class="panel-title cyan-700">
  31. <i class="icon wb-shopping-cart"></i>购买VIP套餐(购买后48小时内可申请退款)
  32. </h1>
  33. <!--<div class="font-weight-400">{{$username}}</div>-->
  34. </div>
  35. <div class="panel-body">
  36. <div class="row">
  37. @foreach($goodsList as $goods)
  38. <div class="col-md-6 col-xl-4 col-xxl-3">
  39. <div class="position-relative">
  40. @if($goods->limit_num)
  41. <div class="ribbon ribbon-badge ribbon-danger ribbon-reverse">
  42. <span class="ribbon-inner">{{trans('user.shop.limited')}}</span>
  43. </div>
  44. @elseif($goods->is_hot)
  45. <div class="ribbon ribbon-badge ribbon-danger ribbon-reverse">
  46. <span class="ribbon-inner">{{trans('user.shop.hot')}}</span>
  47. </div>
  48. @endif
  49. </div>
  50. <div class="pricing-list text-left">
  51. <div class="pricing-header text-white" style="background-color: {{$goods->color}}">
  52. <div class="pricing-title font-size-20">{{$goods->name}}</div>
  53. <div class="pricing-price text-white @if($goods->type === 1) text-center @endif">
  54. <span class="pricing-period">¥</span>
  55. <span class="pricing-amount">{{$goods->price}}</span>
  56. @if($goods->type === 2)
  57. <span class="pricing-period">/ {{$goods->days.trans('validation.attributes.day')}}</span>
  58. @endif
  59. </div>
  60. @if($goods->info)
  61. <p class="px-30 pb-25 text-center">{{$goods->description}}</p>
  62. @endif
  63. </div>
  64. <ul class="pricing-features">
  65. <li>
  66. <strong>{{$goods->traffic_label}}</strong>{{trans('user.attribute.data')}}
  67. {!!$goods->type === 1? ' <code>'.$dataPlusDays.'</code> '.trans('validation.attributes.day'):''.trans('')!!}
  68. </li>
  69. {!!$goods->info!!}
  70. </ul>
  71. <div class="pricing-footer text-center bg-blue-grey-100">
  72. <a href="{{route('buy', $goods)}}" class="btn btn-lg btn-primary"> {{trans('user.shop.buy')}}</a>
  73. </div>
  74. </div>
  75. </div>
  76. @endforeach
  77. </div>
  78. </div>
  79. </div>
  80. </div>
  81. </div>
  82. </div>
  83. <div id="charge_modal" class="modal fade" aria-labelledby="charge_modal" role="dialog" tabindex="-1"
  84. aria-hidden="true">
  85. <div class="modal-dialog modal-simple modal-center">
  86. <div class="modal-content">
  87. <div class="modal-header">
  88. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  89. <span aria-hidden="true">×</span></button>
  90. <h4 class="modal-title">{{trans('user.recharge_credit')}}</h4>
  91. </div>
  92. <div class="modal-body">
  93. <div class="alert alert-danger" id="charge_msg" style="display: none;"></div>
  94. <form action="#" method="post">
  95. @if(sysConfig('is_onlinePay') || sysConfig('alipay_qrcode') || sysConfig('wechat_qrcode'))
  96. <div class="mb-15 w-p50">
  97. <select class="form-control" name="charge_type" id="charge_type">
  98. @if(sysConfig('is_onlinePay'))
  99. <option value="1">{{trans('user.shop.pay_online')}}</option>
  100. @endif
  101. @if(sysConfig('alipay_qrcode') || sysConfig('wechat_qrcode'))
  102. <option value="2">{{trans('common.qrcode', ['attribute' => ''])}}</option>
  103. @endif
  104. <option value="3">{{trans('user.coupon.recharge')}}</option>
  105. </select>
  106. </div>
  107. @endif
  108. @if(sysConfig('is_onlinePay'))
  109. <div class="form-group row charge_credit">
  110. <label for="amount" class="offset-md-1 col-md-2 col-form-label">{{trans('user.shop.change_amount')}}</label>
  111. <div class="col-md-8">
  112. <input type="text" name="amount" id="amount" data-plugin="ionRangeSlider" data-min=1 data-max=300 data-from=75 data-prefix="¥"/>
  113. </div>
  114. </div>
  115. @endif
  116. @if(sysConfig('alipay_qrcode') || sysConfig('wechat_qrcode'))
  117. <div class="text-center" id="charge_qrcode">
  118. <div class="row">
  119. <p class="col-md-12 mb-10">付款时,请
  120. <mark>备注邮箱账号</mark>
  121. ,充值会在<code>24</code>小时内受理!
  122. </p>
  123. @if(sysConfig('wechat_qrcode'))
  124. <div class="col-md-6">
  125. <img class="w-p75 mb-10" src="{{sysConfig('wechat_qrcode')}}" alt=""/>
  126. <p>{{trans('common.payment.wechat')}}</p>
  127. </div>
  128. @endif
  129. @if(sysConfig('alipay_qrcode'))
  130. <div class="col-md-6">
  131. <img class="w-p75 mb-10" src="{{sysConfig('alipay_qrcode')}}" alt=""/>
  132. <p>{{trans('common.payment.alipay')}}</p>
  133. </div>
  134. @endif
  135. </div>
  136. </div>
  137. @endif
  138. <div class="form-group row" id="charge_coupon_code">
  139. <label for="charge_coupon"
  140. class="offset-md-2 col-md-2 col-form-label"> {{trans('user.coupon.recharge')}} </label>
  141. <div class="col-md-6">
  142. <input type="text" class="form-control round" name="charge_coupon" id="charge_coupon" placeholder="{{trans('user.input_coupon')}}">
  143. </div>
  144. </div>
  145. </form>
  146. </div>
  147. <div class="modal-footer">
  148. <div class="charge_credit">
  149. @include('user.components.purchase')
  150. </div>
  151. <button type="button" class="btn btn-primary" id="change_btn" onclick="pay()">{{trans('user.recharge')}}</button>
  152. </div>
  153. </div>
  154. </div>
  155. </div>
  156. @endsection
  157. @section('javascript')
  158. <script src="assets/global/vendor/ionrangeslider/ion.rangeSlider.min.js"></script>
  159. <script src="assets/global/js/Plugin/ionrangeslider.js"></script>
  160. <script>
  161. function itemControl(value) {
  162. if (value === 1) {
  163. $('.charge_credit').show();
  164. $('#change_btn').hide();
  165. $('#charge_qrcode').hide();
  166. $('#charge_coupon_code').hide();
  167. } else if (value === 2) {
  168. $('.charge_credit').hide();
  169. $('#change_btn').hide();
  170. $('#charge_qrcode').show();
  171. $('#charge_coupon_code').hide();
  172. } else {
  173. $('.charge_credit').hide();
  174. $('#charge_qrcode').hide();
  175. $('#charge_coupon_code').show();
  176. $('#change_btn').show();
  177. }
  178. }
  179. $(document).ready(function() {
  180. let which_selected = 3;
  181. @if(sysConfig('is_onlinePay'))
  182. which_selected = 1;
  183. @elseif(sysConfig('alipay_qrcode') || sysConfig('wechat_qrcode'))
  184. which_selected = 2;
  185. @endif
  186. itemControl(which_selected);
  187. $('charge_type').val(which_selected);
  188. });
  189. // 切换充值方式
  190. $('#charge_type').change(function() {
  191. itemControl(parseInt($(this).val()));
  192. });
  193. // 重置流量
  194. function resetTraffic() {
  195. swal.fire({
  196. title: '{{trans('user.reset_data.')}}',
  197. text: '{{trans('user.reset_data.cost_tips', ['amount' => $renewTraffic])}}',
  198. icon: 'question',
  199. showCancelButton: true,
  200. cancelButtonText: '{{trans('common.close')}}',
  201. confirmButtonText: '{{trans('common.confirm')}}',
  202. }).then((result) => {
  203. if (result.value) {
  204. $.post('{{route('resetTraffic')}}', {_token: '{{csrf_token()}}'}, function(ret) {
  205. if (ret.status === 'success') {
  206. swal.fire({title: ret.message, icon: 'success', timer: 1000, showConfirmButton: false}).then(() => window.location.reload());
  207. } else {
  208. swal.fire({
  209. title: ret.message,
  210. text: ret.data,
  211. icon: 'error',
  212. }).then(() => window.location.reload());
  213. }
  214. });
  215. }
  216. });
  217. }
  218. // 充值
  219. function pay(method, pay_type) {
  220. const paymentType = parseInt($('#charge_type').val() ?? 3);
  221. const charge_coupon = $('#charge_coupon').val().trim();
  222. const amount = parseInt($('#amount').val());
  223. if (paymentType === 1) {
  224. if (amount <= 0) {
  225. swal.fire({title: '{{trans('common.error')}}', text: '{{trans('user.payment.error')}}', icon: 'warning', timer: 1000, showConfirmButton: false});
  226. return false;
  227. }
  228. $.ajax({
  229. method: 'POST',
  230. url: '{{route('purchase')}}',
  231. data: {_token: '{{csrf_token()}}', amount: amount, method: method, pay_type: pay_type},
  232. dataType: 'json',
  233. beforeSend: function() {
  234. $('#charge_msg').show().html('{{trans('user.payment.creating')}}');
  235. },
  236. success: function(ret) {
  237. if (ret.status === 'fail') {
  238. return false;
  239. } else {
  240. $('#charge_msg').show().html(ret.message);
  241. if (ret.data) {
  242. window.location.href = '{{route('orderDetail' , '')}}/' + ret.data;
  243. } else if (ret.url) {
  244. window.location.href = ret.url;
  245. }
  246. }
  247. },
  248. error: function() {
  249. $('#charge_msg').show().html("{{trans('user.error_response')}}");
  250. },
  251. });
  252. } else if (paymentType === 3) {
  253. if (charge_coupon === '') {
  254. $('#charge_msg').show().html("{{trans('validation.required', ['attribute' => trans('user.coupon.attribute')])}}");
  255. $('#charge_coupon').focus();
  256. return false;
  257. }
  258. $.ajax({
  259. method: 'POST',
  260. url: '{{route('recharge')}}',
  261. data: {_token: '{{csrf_token()}}', coupon_sn: charge_coupon},
  262. beforeSend: function() {
  263. $('#charge_msg').show().html("{{trans('user.recharging')}}");
  264. },
  265. success: function(ret) {
  266. if (ret.status === 'fail') {
  267. $('#charge_msg').show().html(ret.message);
  268. return false;
  269. }
  270. $('#charge_modal').modal('hide');
  271. window.location.reload();
  272. },
  273. error: function() {
  274. $('#charge_msg').show().html("{{trans('user.error_response')}}");
  275. },
  276. });
  277. }
  278. }
  279. </script>
  280. @endsection