export.blade.php 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. @extends('admin.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-content container-fluid">
  7. <div class="panel">
  8. <div class="panel-heading">
  9. <h2 class="panel-title"> {{ trans('admin.user.proxies_config', ['username' => $user->username]) }}</h2>
  10. </div>
  11. <div class="panel-body">
  12. <table class="text-md-center" data-toggle="table" data-mobile-responsive="true">
  13. <thead class="thead-default">
  14. <tr>
  15. <th>#</th>
  16. <th>{{ trans('model.node.attribute') }}</th>
  17. <th>{{ trans('admin.node.info.extend') }}</th>
  18. <th>{{ trans('model.node.domain') }}</th>
  19. <th>{{ trans('model.node.ipv4') }}</th>
  20. <th>{{ trans('admin.user.proxy_info') }}</th>
  21. </tr>
  22. </thead>
  23. <tbody>
  24. @foreach ($nodeList as $node)
  25. <tr>
  26. <td>{{ $loop->iteration }}</td>
  27. <td>
  28. @can('admin.node.edit')
  29. <a href="{{ route('admin.node.edit', $node) }}" target="_blank"> {{ $node->name }} </a>
  30. @else
  31. {{ $node->name }}
  32. @endcan
  33. </td>
  34. <td>
  35. @isset($node->profile['passwd'])
  36. {{-- 单端口 --}}
  37. <span class="badge badge-lg badge-info"><i class="fa-solid fa-arrows-left-right-to-line" aria-hidden="true"></i></span>
  38. @endisset
  39. @if ($node->is_display === 0)
  40. {{-- 节点完全不可见 --}}
  41. <span class="badge badge-lg badge-danger"><i class="icon wb-eye-close" aria-hidden="true"></i></span>
  42. @elseif($node->is_display === 1)
  43. {{-- 节点只在页面中显示 --}}
  44. <span class="badge badge-lg badge-danger"><i class="fa-solid fa-link-slash" aria-hidden="true"></i></span>
  45. @elseif($node->is_display === 2)
  46. {{-- 节点只可被订阅到 --}}
  47. <span class="badge badge-lg badge-danger"><i class="fa-solid fa-store-slash" aria-hidden="true"></i></span>
  48. @endif
  49. </td>
  50. <td>{{ $node->server }}</td>
  51. <td>{{ $node->ip }}</td>
  52. <td>
  53. @can('admin.user.exportProxy')
  54. <div class="btn-group">
  55. <button class="btn btn-sm btn-outline-info" onclick="getInfo('{{ $node->id }}','code')"><i
  56. class="fa-solid fa-code"></i>
  57. </button>
  58. <button class="btn btn-sm btn-outline-info" onclick="getInfo('{{ $node->id }}','qrcode')"><i
  59. class="fa-solid fa-qrcode"></i>
  60. </button>
  61. <button class="btn btn-sm btn-outline-info" onclick="getInfo('{{ $node->id }}','text')"><i
  62. class="fa-solid fa-list"></i>
  63. </button>
  64. </div>
  65. @endcan
  66. </td>
  67. </tr>
  68. @endforeach
  69. </tbody>
  70. </table>
  71. </div>
  72. <div class="panel-footer">
  73. <div class="row">
  74. <div class="col-sm-4">
  75. {!! trans('admin.node.counts', ['num' => $nodeList->total()]) !!}
  76. </div>
  77. <div class="col-sm-8">
  78. <nav class="Page navigation float-right">
  79. {{ $nodeList->links() }}
  80. </nav>
  81. </div>
  82. </div>
  83. </div>
  84. </div>
  85. </div>
  86. @endsection
  87. @section('javascript')
  88. <script src="/assets/global/vendor/bootstrap-table/bootstrap-table.min.js"></script>
  89. <script src="/assets/global/vendor/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js"></script>
  90. <script src="/assets/custom/easy.qrcode.min.js" type="text/javascript"></script>
  91. @can('admin.user.exportProxy')
  92. <script>
  93. function getInfo(id, type) {
  94. $.post("{{ route('admin.user.exportProxy', $user) }}", {
  95. _token: '{{ csrf_token() }}',
  96. id: id,
  97. type: type
  98. },
  99. function(ret) {
  100. if (ret.status === 'success') {
  101. switch (type) {
  102. case 'code':
  103. swal.fire({
  104. html: '<textarea class="form-control" rows="8" readonly="readonly">' + ret.data +
  105. '</textarea>' +
  106. '<a href="' + ret.data +
  107. '" class="btn btn-block btn-danger mt-4">{{ trans('common.open') }} ' +
  108. ret.title + '</a>',
  109. showConfirmButton: false,
  110. });
  111. break;
  112. case 'qrcode':
  113. swal.fire({
  114. title: '{{ trans('user.scan_qrcode') }}',
  115. html: '<div id="qrcode"></div><button class="btn btn-block btn-outline-primary mt-4" onclick="Download()"> <i class="icon wb-download"></i> {{ trans('common.download') }}</button>',
  116. onBeforeOpen: () => {
  117. new QRCode(document.getElementById('qrcode'), {
  118. text: ret.data
  119. });
  120. },
  121. showConfirmButton: false,
  122. });
  123. break;
  124. case 'text':
  125. swal.fire({
  126. title: '{{ trans('user.node.info') }}',
  127. html: '<textarea class="form-control" rows="12" readonly="readonly">' + ret.data +
  128. '</textarea>',
  129. showConfirmButton: false,
  130. });
  131. break;
  132. default:
  133. swal.fire({
  134. title: ret.title,
  135. text: ret.data
  136. });
  137. }
  138. }
  139. });
  140. }
  141. function Download() {
  142. const canvas = document.getElementsByTagName('canvas')[0];
  143. canvas.toBlob((blob) => {
  144. let link = document.createElement('a');
  145. link.download = 'qr.png';
  146. let reader = new FileReader();
  147. reader.readAsDataURL(blob);
  148. reader.onload = () => {
  149. link.href = reader.result;
  150. link.click();
  151. };
  152. }, 'image/png');
  153. }
  154. </script>
  155. @endcan
  156. @endsection