1
0

invite.blade.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. @extends('user.layouts')
  2. @section('css')
  3. <link href="/assets/global/vendor/bootstrap-table/bootstrap-table.min.css" rel="stylesheet">
  4. @endsection
  5. @section('content')
  6. <div class="page-header">
  7. <h1 class="page-title cyan-600">
  8. <i class="icon wb-extension"></i>{{ trans('user.menu.invites') }}
  9. </h1>
  10. </div>
  11. <div class="page-content container-fluid">
  12. <x-alert type="info" :message="trans('user.invite.promotion', ['traffic' => $referral_traffic, 'referral_percent' => $referral_percent * 100])" />
  13. <div class="row">
  14. <div class="col-xxl-3 col-lg-4">
  15. <div class="card">
  16. <div class="card-block">
  17. <h4 class="card-title cyan-600">
  18. <i class="icon wb-plus"></i> {{ trans('common.generate_item', ['attribute' => trans('user.invite.attribute')]) }}
  19. </h4>
  20. <x-alert type="info" :message="trans('user.invite.tips', ['num' => $num, 'days' => sysConfig('user_invite_days')])" />
  21. <button class="btn btn-primary btn-animate btn-animate-side" type="button" onclick="makeInvite()"
  22. @if (!$num) disabled @endif>
  23. <i class="icon wb-plus"></i> {{ trans('common.generate') }}
  24. </button>
  25. </div>
  26. </div>
  27. </div>
  28. <div class="col-xxl-9 col-lg-8">
  29. <div class="card">
  30. <div class="card-block">
  31. <h4 class="card-title cyan-600">
  32. <i class="icon wb-extension"></i>{{ trans('user.invite.attribute') }}
  33. </h4>
  34. <table class="text-md-center" data-toggle="table" data-mobile-responsive="true">
  35. <thead class="thead-default">
  36. <tr>
  37. <th data-cell-style="cellStyle"> #</th>
  38. <th> {{ trans('user.invite.attribute') }} </th>
  39. <th> {{ trans('common.available_date') }} </th>
  40. <th> {{ trans('common.status.attribute') }} </th>
  41. <th> {{ trans('user.invitee') }} </th>
  42. </tr>
  43. </thead>
  44. <tbody>
  45. @foreach ($inviteList as $invite)
  46. <tr>
  47. <td> {{ $loop->iteration }} </td>
  48. <td>
  49. <a class="mt-clipboard" data-clipboard-action="copy"
  50. data-clipboard-text="{{ route('register', ['code' => $invite->code]) }}"
  51. href="javascript:void(0)">{{ $invite->code }}</a>
  52. </td>
  53. <td> {{ $invite->dateline }} </td>
  54. <td>
  55. {!! $invite->status_label !!}
  56. </td>
  57. {{ $invite->status === 1 ? $invite->invitee->username ?? '【' . trans('common.deleted_item', ['attribute' => trans('common.account')]) . '】' : '' }}
  58. </tr>
  59. @endforeach
  60. </tbody>
  61. </table>
  62. </div>
  63. <div class="card-footer card-footer-transparent">
  64. <div class="row">
  65. <div class="col-md-4">
  66. {!! trans('user.invite.counts', ['num' => $inviteList->total()]) !!}
  67. </div>
  68. <div class="col-md-8">
  69. <nav class="Page navigation float-right">
  70. {{ $inviteList->links() }}
  71. </nav>
  72. </div>
  73. </div>
  74. </div>
  75. </div>
  76. </div>
  77. </div>
  78. </div>
  79. @endsection
  80. @section('javascript')
  81. <script src="/assets/custom/clipboardjs/clipboard.min.js"></script>
  82. <script src="/assets/global/vendor/bootstrap-table/bootstrap-table.min.js"></script>
  83. <script src="/assets/global/vendor/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js"></script>
  84. <script>
  85. // 生成邀请码
  86. function makeInvite() {
  87. $.ajax({
  88. method: 'POST',
  89. dataType: 'json',
  90. url: '{{ route('createInvite') }}',
  91. data: {
  92. _token: '{{ csrf_token() }}'
  93. },
  94. success: function(ret) {
  95. if (ret.status === 'success') {
  96. swal.fire({
  97. title: ret.message,
  98. icon: 'success'
  99. }).then(() => window.location.reload());
  100. } else {
  101. swal.fire({
  102. title: ret.message,
  103. icon: 'error'
  104. }).then(() => window.location.reload());
  105. }
  106. },
  107. });
  108. return false;
  109. }
  110. const clipboard = new ClipboardJS('.mt-clipboard');
  111. clipboard.on('success', function() {
  112. swal.fire({
  113. title: '{{ trans('common.copy.success') }}',
  114. icon: 'success',
  115. timer: 1300,
  116. showConfirmButton: false,
  117. });
  118. });
  119. clipboard.on('error', function() {
  120. swal.fire({
  121. title: '{{ trans('common.copy.failed') }}',
  122. icon: 'error',
  123. timer: 1500,
  124. showConfirmButton: false,
  125. });
  126. });
  127. </script>
  128. @endsection