traffic.blade.php 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. @extends('admin.layouts')
  2. @section('css')
  3. <link href="/assets/global/vendor/bootstrap-table/bootstrap-table.min.css" rel="stylesheet">
  4. <link href="/assets/global/vendor/bootstrap-datepicker/bootstrap-datepicker.min.css" rel="stylesheet">
  5. @endsection
  6. @section('content')
  7. <div class="page-content container-fluid">
  8. <div class="panel">
  9. <div class="panel-heading">
  10. <h2 class="panel-title">流量日志</h2>
  11. </div>
  12. <div class="panel-body">
  13. <form class="form-row">
  14. <div class="form-group col-lg-2 col-sm-4">
  15. <input type="number" class="form-control" name="user_id" value="{{Request::query('user_id')}}" placeholder="用户ID"/>
  16. </div>
  17. <div class="form-group col-lg-3 col-sm-8">
  18. <input type="text" class="form-control" name="email" value="{{Request::query('email')}}" placeholder="用户账号"/>
  19. </div>
  20. <div class="form-group col-lg-2 col-sm-4">
  21. <input type="number" class="form-control" name="port" value="{{Request::query('port')}}" placeholder="用户端口"/>
  22. </div>
  23. <div class="form-group col-lg-3 col-sm-8">
  24. <select class="form-control" name="node_id" id="node_id" onchange="this.form.submit()">
  25. <option value="" hidden>选择节点</option>
  26. @foreach($nodes as $node)
  27. <option value="{{$node->id}}">{{$node->name}}</option>
  28. @endforeach
  29. </select>
  30. </div>
  31. <div class="form-group col-lg-6 col-sm-12">
  32. <div class="input-group input-daterange" data-plugin="datepicker">
  33. <div class="input-group-prepend">
  34. <span class="input-group-text">
  35. <i class="icon wb-calendar" aria-hidden="true"></i>
  36. </span>
  37. </div>
  38. <input type="text" class="form-control" name="start" value="{{Request::query('start')}}" autocomplete="off"/>
  39. <div class="input-group-prepend">
  40. <span class="input-group-text">至</span>
  41. </div>
  42. <input type="text" class="form-control" name="end" value="{{Request::query('end')}}" autocomplete="off"/>
  43. </div>
  44. </div>
  45. <div class="form-group col-lg-2 col-sm-4 btn-group">
  46. <button type="submit" class="btn btn-primary">搜 索</button>
  47. <a href="{{route('admin.log.traffic')}}" class="btn btn-danger">{{trans('common.reset')}}</a>
  48. </div>
  49. </form>
  50. <table class="text-md-center" data-toggle="table" data-mobile-responsive="true">
  51. <thead class="thead-default">
  52. <tr>
  53. <th> #</th>
  54. <th> 用户</th>
  55. <th> 节点</th>
  56. <th> 流量比例</th>
  57. <th> 上传流量</th>
  58. <th> 下载流量</th>
  59. <th> 总流量</th>
  60. <th> 记录时间</th>
  61. </tr>
  62. </thead>
  63. <tbody>
  64. @foreach($dataFlowLogs as $log)
  65. <tr>
  66. <td> {{$log->id}} </td>
  67. <td>
  68. @if(empty($log->user))
  69. 【{{trans('common.deleted_item', ['attribute' => trans('common.account')])}}】
  70. @else
  71. @can('admin.user.index')
  72. <a href="{{route('admin.user.index', ['id' => $log->user->id])}}" target="_blank"> {{$log->user->email}} </a>
  73. @else
  74. {{$log->user->email}}
  75. @endcan
  76. @endif
  77. </td>
  78. <td> {{$log->node->name ?? '【节点已删除】'}} </td>
  79. <td> {{$log->rate}} </td>
  80. <td> {{$log->u}} </td>
  81. <td> {{$log->d}} </td>
  82. <td><span class="badge badge-danger"> {{$log->traffic}} </span></td>
  83. <td> {{$log->log_time}} </td>
  84. </tr>
  85. @endforeach
  86. </tbody>
  87. </table>
  88. </div>
  89. <div class="panel-footer">
  90. <div class="row">
  91. <div class="col-sm-6">
  92. 共 <code>{{$dataFlowLogs->total()}} 条记录</code>,合计 <code>{{$totalTraffic}}</code>
  93. </div>
  94. <div class="col-sm-6">
  95. <nav class="Page navigation float-right">
  96. {{$dataFlowLogs->links()}}
  97. </nav>
  98. </div>
  99. </div>
  100. </div>
  101. </div>
  102. </div>
  103. @endsection
  104. @section('javascript')
  105. <script src="/assets/global/vendor/bootstrap-table/bootstrap-table.min.js"></script>
  106. <script src="/assets/global/vendor/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js"></script>
  107. <script src="/assets/global/vendor/bootstrap-datepicker/bootstrap-datepicker.min.js"></script>
  108. <script src="/assets/global/js/Plugin/bootstrap-datepicker.js"></script>
  109. <script>
  110. $('.input-daterange').datepicker({
  111. format: 'yyyy-mm-dd',
  112. });
  113. $(document).ready(function() {
  114. $('#node_id').val({{Request::query('node_id')}});
  115. });
  116. </script>
  117. @endsection