services.blade.php 15 KB

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