shop.blade.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. @extends('user.layouts')
  2. @section('css')
  3. <link href="assets/global/vendor/ionrangeslider/ionrangeslider.min.css" rel="stylesheet">
  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. <h4 class="card-title"><i class="icon wb-briefcase green-500"></i> {{ trans('user.account.credit') }}</h4>
  12. <div class="content-text text-center mb-0">
  13. <span class="font-size-40 font-weight-100">{{ auth()->user()->credit_tag }}</span>
  14. <br />
  15. <button class="btn btn-danger float-right mr-15" data-toggle="modal" data-target="#charge_modal">{{ trans('user.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. <h4 class="card-title"><i class="icon wb-payment grey-500"></i> {{ trans('user.reset_data.action') }}</h4>
  23. <div class="content-text text-center mb-0">
  24. <span class="font-size-20 font-weight-100">{!! trans('user.reset_data.cost', ['amount' => $renewTraffic]) !!}</span>
  25. <br />
  26. <button class="btn btn-danger mt-10" onclick="resetTraffic()">{{ trans('common.reset') }}</button>
  27. </div>
  28. </div>
  29. </div>
  30. @endif
  31. </div>
  32. <div class="col-xxl-10 col-lg-9">
  33. <div class="panel">
  34. <div class="panel-heading p-20">
  35. <h1 class="panel-title cyan-700">
  36. <i class="icon wb-shopping-cart"></i>{{ trans('user.menu.shop') }}
  37. </h1>
  38. </div>
  39. <div class="panel-body">
  40. <div class="row">
  41. @foreach ($goodsList as $goods)
  42. <div class="col-md-6 col-xl-4 col-xxl-3">
  43. <div class="position-relative">
  44. @if ($goods->limit_num)
  45. <div class="ribbon ribbon-badge ribbon-danger ribbon-reverse">
  46. <span class="ribbon-inner">{{ trans('user.shop.limited') }}</span>
  47. </div>
  48. @elseif($goods->is_hot)
  49. <div class="ribbon ribbon-badge ribbon-danger ribbon-reverse">
  50. <span class="ribbon-inner">{{ trans('user.shop.hot') }}</span>
  51. </div>
  52. @endif
  53. </div>
  54. <div class="pricing-list text-left">
  55. <div class="pricing-header text-white" style="background-color: {{ $goods->color }}">
  56. <div class="pricing-title font-size-20">{{ $goods->name }}</div>
  57. <div class="pricing-price text-white @if ($goods->type === 1) text-center @endif">
  58. <span class="pricing-amount">{{ $goods->price_tag }}</span>
  59. @if ($goods->type === 2)
  60. <span class="pricing-period">/ {{ $goods->days . trans_choice('common.days.attribute', 1) }}</span>
  61. @endif
  62. </div>
  63. @if ($goods->description)
  64. <p class="px-30 pb-25 text-center">{{ $goods->description }}</p>
  65. @endif
  66. </div>
  67. <ul class="pricing-features">
  68. <li>
  69. <strong>{{ $goods->traffic_label }}</strong>{{ trans('user.attribute.data') }}
  70. {!! $goods->type === 1 ? "<code> $dataPlusDays </code>" . trans_choice('common.days.attribute', 1) : '/' . ucfirst(trans('validation.attributes.month')) !!}
  71. </li>
  72. <li>
  73. {!! trans('user.service.node_count', ['num' => $goods->node_count]) !!}
  74. </li>
  75. <li>
  76. {!! trans('user.service.country_count', ['num' => $goods->node_countries->count()]) !!}
  77. </li>
  78. <li>
  79. {{ trans('user.account.speed_limit') }}
  80. <strong> {{ $goods->speed_limit ? $goods->speed_limit . ' Mbps' : trans('user.service.unlimited') }} </strong>
  81. </li>
  82. {!! $goods->info !!}
  83. </ul>
  84. <div class="pricing-footer text-center bg-blue-grey-100">
  85. <a class="btn btn-lg btn-primary" href="{{ route('shop.show', $goods) }}"> {{ trans('user.shop.buy') }}</a>
  86. </div>
  87. </div>
  88. </div>
  89. @endforeach
  90. </div>
  91. </div>
  92. </div>
  93. </div>
  94. </div>
  95. </div>
  96. <div class="modal fade" id="charge_modal" role="dialog" aria-labelledby="charge_modal" aria-hidden="true" tabindex="-1">
  97. <div class="modal-dialog modal-simple modal-center">
  98. <div class="modal-content">
  99. <div class="modal-header">
  100. <button class="close" data-dismiss="modal" type="button" aria-label="{{ trans('common.close') }}">
  101. <span aria-hidden="true">×</span></button>
  102. <h4 class="modal-title">{{ trans('user.recharge_credit') }}</h4>
  103. </div>
  104. <div class="modal-body">
  105. <div class="alert alert-danger" id="charge_msg" style="display: none;"></div>
  106. <form action="#" method="post">
  107. @if (sysConfig('is_onlinePay') || sysConfig('alipay_qrcode') || sysConfig('wechat_qrcode'))
  108. <div class="mb-15 w-p50">
  109. <select class="form-control" id="charge_type" name="charge_type">
  110. @if (sysConfig('is_onlinePay') || sysConfig('alipay_qrcode') || sysConfig('wechat_qrcode'))
  111. <option value="1">{{ trans('user.shop.pay_online') }}</option>
  112. @endif
  113. <option value="2">{{ trans('admin.coupon.type.charge') }}</option>
  114. </select>
  115. </div>
  116. @endif
  117. @if (sysConfig('is_onlinePay') || sysConfig('alipay_qrcode') || sysConfig('wechat_qrcode'))
  118. <div class="form-group row charge_credit">
  119. <label class="offset-md-1 col-md-2 col-form-label" for="amount">{{ trans('user.shop.change_amount') }}</label>
  120. <div class="col-md-8">
  121. <input id="amount" name="amount" data-plugin="ionRangeSlider" data-min=1 data-max=300 data-from=40
  122. data-prefix="{{ array_column(config('common.currency'), 'symbol', 'code')[session('currency') ?? sysConfig('standard_currency')] }}"
  123. type="text" />
  124. </div>
  125. </div>
  126. @endif
  127. <div class="form-group row" id="charge_coupon_code">
  128. <label class="offset-md-2 col-md-2 col-form-label" for="charge_coupon"> {{ trans('admin.coupon.type.charge') }} </label>
  129. <div class="col-md-6">
  130. <input class="form-control round" id="charge_coupon" name="charge_coupon" type="text"
  131. placeholder="{{ trans('user.coupon.input') }}">
  132. </div>
  133. </div>
  134. </form>
  135. </div>
  136. <div class="modal-footer">
  137. <div class="charge_credit">
  138. @include('user.components.purchase')
  139. </div>
  140. <button class="btn btn-primary" id="change_btn" type="button" onclick="pay()">{{ trans('user.recharge') }}</button>
  141. </div>
  142. </div>
  143. </div>
  144. </div>
  145. @endsection
  146. @section('javascript')
  147. <script src="assets/global/vendor/ionrangeslider/ion.rangeSlider.min.js"></script>
  148. <script src="assets/global/js/Plugin/ionrangeslider.js"></script>
  149. <script>
  150. function itemControl(value) {
  151. const control = value === 1;
  152. $('.charge_credit').toggle(control);
  153. $('#change_btn').toggle(!control);
  154. $('#charge_coupon_code').toggle(!control);
  155. }
  156. $(document).ready(function() {
  157. let which_selected = 2;
  158. @if (sysConfig('is_onlinePay') || sysConfig('alipay_qrcode') || sysConfig('wechat_qrcode'))
  159. which_selected = 1;
  160. @endif
  161. itemControl(which_selected);
  162. $('#charge_type').val(which_selected);
  163. });
  164. // 切换充值方式
  165. $('#charge_type').change(function() {
  166. itemControl(parseInt($(this).val()));
  167. });
  168. // 重置流量
  169. function resetTraffic() {
  170. showConfirm({
  171. title: '{{ trans('user.reset_data.action') }}',
  172. text: '{{ trans('user.reset_data.cost_tips', ['amount' => $renewTraffic]) }}',
  173. onConfirm: function() {
  174. ajaxPost('{{ route('shop.resetTraffic') }}');
  175. }
  176. });
  177. }
  178. // 充值
  179. function pay(method, pay_type) {
  180. const paymentType = parseInt($('#charge_type').val() ?? 2);
  181. const charge_coupon = $('#charge_coupon').val().trim();
  182. const amount = parseInt($('#amount').val());
  183. if (paymentType === 1) {
  184. if (amount <= 0) {
  185. showMessage({
  186. title: '{{ trans('common.error') }}',
  187. text: '{{ trans('user.payment.error') }}',
  188. icon: 'warning',
  189. showConfirmButton: false,
  190. });
  191. return false;
  192. }
  193. ajaxPost('{{ route('purchase') }}', {
  194. amount: amount,
  195. method: method,
  196. pay_type: pay_type
  197. }, {
  198. beforeSend: function() {
  199. $('#charge_msg').show().html('{{ trans('user.payment.creating') }}');
  200. },
  201. success: function(ret) {
  202. $('#charge_msg').show().html(ret.message);
  203. if (ret.status === 'fail') {
  204. return false;
  205. } else {
  206. if (ret.data) {
  207. window.location.href = jsRoute('{{ route('orderDetail', 'PLACEHOLDER') }}', ret.data);
  208. } else if (ret.url) {
  209. window.location.href = ret.url;
  210. }
  211. }
  212. },
  213. error: function() {
  214. $('#charge_msg').show().html("{{ trans('user.error_response') }}");
  215. },
  216. });
  217. } else if (paymentType === 2) {
  218. if (charge_coupon === '') {
  219. $('#charge_msg').show().html("{{ trans('validation.required', ['attribute' => trans('model.coupon.attribute')]) }}");
  220. $('#charge_coupon').focus();
  221. return false;
  222. }
  223. ajaxPost('{{ route('shop.coupon.redeem') }}', {
  224. coupon_sn: charge_coupon
  225. }, {
  226. beforeSend: function() {
  227. $('#charge_msg').show().html("{{ trans('user.recharging') }}");
  228. },
  229. success: function(ret) {
  230. if (ret.status === 'fail') {
  231. $('#charge_msg').show().html(ret.message);
  232. return false;
  233. }
  234. $('#charge_modal').modal('hide');
  235. window.location.reload();
  236. },
  237. error: function() {
  238. $('#charge_msg').show().html("{{ trans('user.error_response') }}");
  239. },
  240. });
  241. }
  242. }
  243. </script>
  244. @endsection