export.blade.php 7.9 KB

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