| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- @extends('user.layouts')
- @section('css')
- <link href="/assets/global/vendor/bootstrap-table/bootstrap-table.min.css" rel="stylesheet">
- @endsection
- @section('content')
- <div class="page-header">
- <h1 class="page-title cyan-600">
- <i class="icon wb-extension"></i>{{ trans('user.menu.invites') }}
- </h1>
- </div>
- <div class="page-content container-fluid">
- <x-alert type="info" :message="trans('user.invite.promotion', ['traffic' => $referral_traffic, 'referral_percent' => $referral_percent * 100])" />
- <div class="row">
- <div class="col-xxl-3 col-lg-4">
- <div class="card">
- <div class="card-block">
- <h4 class="card-title cyan-600">
- <i class="icon wb-plus"></i> {{ trans('common.generate_item', ['attribute' => trans('user.invite.attribute')]) }}
- </h4>
- <x-alert type="info" :message="trans('user.invite.tips', ['num' => $num, 'days' => sysConfig('user_invite_days')])" />
- <button class="btn btn-primary btn-animate btn-animate-side" type="button" onclick="makeInvite()"
- @if (!$num) disabled @endif>
- <i class="icon wb-plus"></i> {{ trans('common.generate') }}
- </button>
- </div>
- </div>
- </div>
- <div class="col-xxl-9 col-lg-8">
- <div class="card">
- <div class="card-block">
- <h4 class="card-title cyan-600">
- <i class="icon wb-extension"></i>{{ trans('user.invite.attribute') }}
- </h4>
- <table class="text-md-center" data-toggle="table" data-mobile-responsive="true">
- <thead class="thead-default">
- <tr>
- <th data-cell-style="cellStyle"> #</th>
- <th> {{ trans('user.invite.attribute') }} </th>
- <th> {{ trans('common.available_date') }} </th>
- <th> {{ trans('common.status.attribute') }} </th>
- <th> {{ trans('user.invitee') }} </th>
- </tr>
- </thead>
- <tbody>
- @foreach ($inviteList as $invite)
- <tr>
- <td> {{ $loop->iteration }} </td>
- <td>
- <a class="mt-clipboard" data-clipboard-action="copy"
- data-clipboard-text="{{ route('register', ['code' => $invite->code]) }}"
- href="javascript:void(0)">{{ $invite->code }}</a>
- </td>
- <td> {{ $invite->dateline }} </td>
- <td>
- {!! $invite->status_label !!}
- </td>
- {{ $invite->status === 1 ? $invite->invitee->username ?? '【' . trans('common.deleted_item', ['attribute' => trans('common.account')]) . '】' : '' }}
- </tr>
- @endforeach
- </tbody>
- </table>
- </div>
- <div class="card-footer card-footer-transparent">
- <div class="row">
- <div class="col-md-4">
- {!! trans('user.invite.counts', ['num' => $inviteList->total()]) !!}
- </div>
- <div class="col-md-8">
- <nav class="Page navigation float-right">
- {{ $inviteList->links() }}
- </nav>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- @endsection
- @section('javascript')
- <script src="/assets/custom/clipboardjs/clipboard.min.js"></script>
- <script src="/assets/global/vendor/bootstrap-table/bootstrap-table.min.js"></script>
- <script src="/assets/global/vendor/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js"></script>
- <script>
- // 生成邀请码
- function makeInvite() {
- $.ajax({
- method: 'POST',
- dataType: 'json',
- url: '{{ route('createInvite') }}',
- data: {
- _token: '{{ csrf_token() }}'
- },
- success: function(ret) {
- if (ret.status === 'success') {
- swal.fire({
- title: ret.message,
- icon: 'success'
- }).then(() => window.location.reload());
- } else {
- swal.fire({
- title: ret.message,
- icon: 'error'
- }).then(() => window.location.reload());
- }
- },
- });
- return false;
- }
- const clipboard = new ClipboardJS('.mt-clipboard');
- clipboard.on('success', function() {
- swal.fire({
- title: '{{ trans('common.copy.success') }}',
- icon: 'success',
- timer: 1300,
- showConfirmButton: false,
- });
- });
- clipboard.on('error', function() {
- swal.fire({
- title: '{{ trans('common.copy.failed') }}',
- icon: 'error',
- timer: 1500,
- showConfirmButton: false,
- });
- });
- </script>
- @endsection
|