trafficLog.blade.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. @extends('admin.layouts')
  2. @section('css')
  3. <link href="/assets/global/vendor/bootstrap-table/bootstrap-table.min.css" type="text/css" rel="stylesheet">
  4. <link href="/assets/global/vendor/bootstrap-datepicker/bootstrap-datepicker.min.css" type="text/css"
  5. rel="stylesheet">
  6. @endsection
  7. @section('content')
  8. <div class="page-content container-fluid">
  9. <div class="panel">
  10. <div class="panel-heading">
  11. <h2 class="panel-title">流量日志</h2>
  12. </div>
  13. <div class="panel-body">
  14. <div class="form-row">
  15. <div class="form-group col-lg-2 col-sm-4">
  16. <input type="number" class="form-control" name="user_id" id="user_id"
  17. value="{{Request::get('user_id')}}" placeholder="用户ID"/>
  18. </div>
  19. <div class="form-group col-lg-3 col-sm-8">
  20. <input type="text" class="form-control" name="email" id="email"
  21. value="{{Request::get('email')}}" placeholder="用户名"/>
  22. </div>
  23. <div class="form-group col-lg-2 col-sm-4">
  24. <input type="number" class="form-control" name="port" id="port" value="{{Request::get('port')}}"
  25. placeholder="用户端口"/>
  26. </div>
  27. <div class="form-group col-lg-3 col-sm-8">
  28. <select class="form-control" name="nodeId" id="nodeId" onChange="Search()">
  29. <option value="" @if(Request::get('nodeId') == '') selected @endif hidden>选择节点</option>
  30. @foreach($nodeList as $node)
  31. <option value="{{$node->id}}"
  32. @if(Request::get('nodeId') == $node->id) selected @endif>{{$node->name}}</option>
  33. @endforeach
  34. </select>
  35. </div>
  36. <div class="form-group col-lg-6 col-sm-12">
  37. <div class="input-group input-daterange" data-plugin="datepicker">
  38. <div class="input-group-prepend">
  39. <span class="input-group-text"><i class="icon wb-calendar"
  40. aria-hidden="true"></i></span>
  41. </div>
  42. <input type="text" class="form-control" name="start" id="start"
  43. value="{{Request::get('startTime')}}" placeholder="{{date("Y-m-d")}}"/>
  44. <div class="input-group-prepend">
  45. <span class="input-group-text">至</span>
  46. </div>
  47. <input type="text" class="form-control" name="end" id="end"
  48. value="{{Request::get('endTime')}}"
  49. placeholder="{{date("Y-m-d",strtotime("+1 month"))}}"/>
  50. </div>
  51. </div>
  52. <div class="form-group col-lg-2 col-sm-4 btn-group">
  53. <button class="btn btn-primary" onclick="Search()">搜 索</button>
  54. <a href="/admin/trafficLog" class="btn btn-danger">重 置</a>
  55. </div>
  56. </div>
  57. <table class="text-md-center" data-toggle="table" data-mobile-responsive="true">
  58. <thead class="thead-default">
  59. <tr>
  60. <th> #</th>
  61. <th> 用户</th>
  62. <th> 节点</th>
  63. <th> 流量比例</th>
  64. <th> 上传流量</th>
  65. <th> 下载流量</th>
  66. <th> 总流量</th>
  67. <th> 记录时间</th>
  68. </tr>
  69. </thead>
  70. <tbody>
  71. @foreach($list as $vo)
  72. <tr>
  73. <td> {{$vo->id}} </td>
  74. <td>
  75. @if(empty($vo->user))
  76. 【账号已删除】
  77. @else
  78. <a href="/admin/userList?id={{$vo->user->id}}"
  79. target="_blank"> {{$vo->user->email}} </a>
  80. @endif
  81. </td>
  82. <td> {{$vo->node ? $vo->node->name : '【节点已删除】'}} </td>
  83. <td> {{$vo->rate}} </td>
  84. <td> {{$vo->u}} </td>
  85. <td> {{$vo->d}} </td>
  86. <td><span class="badge badge-danger"> {{$vo->traffic}} </span></td>
  87. <td> {{$vo->log_time}} </td>
  88. </tr>
  89. @endforeach
  90. </tbody>
  91. </table>
  92. </div>
  93. <div class="panel-footer">
  94. <div class="row">
  95. <div class="col-sm-6">
  96. 共 <code>{{$list->total()}} 条记录</code>,合计 <code>{{$totalTraffic}}</code>
  97. </div>
  98. <div class="col-sm-6">
  99. <nav class="Page navigation float-right">
  100. {{$list->links()}}
  101. </nav>
  102. </div>
  103. </div>
  104. </div>
  105. </div>
  106. </div>
  107. @endsection
  108. @section('script')
  109. <script src="/assets/global/vendor/bootstrap-table/bootstrap-table.min.js" type="text/javascript"></script>
  110. <script src="/assets/global/vendor/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js"
  111. type="text/javascript"></script>
  112. <script src="/assets/global/vendor/bootstrap-datepicker/bootstrap-datepicker.min.js"
  113. type="text/javascript"></script>
  114. <script src="/assets/global/js/Plugin/bootstrap-datepicker.js" type="text/javascript"></script>
  115. <script type="text/javascript">
  116. $('.input-daterange').datepicker({
  117. format: "yyyy-mm-dd",
  118. });
  119. //回车检测
  120. $(document).on("keypress", "input", function (e) {
  121. if (e.which === 13) {
  122. Search();
  123. return false;
  124. }
  125. });
  126. // 搜索
  127. function Search() {
  128. window.location.href = '/admin/trafficLog' + '?port=' + $("#port").val() + '&user_id=' + $("#user_id").val() + '&email=' + $("#email").val() + '&nodeId=' + $("#nodeId option:selected").val() + '&startTime=' + $("#start").val() + '&endTime=' + $("#end").val();
  129. }
  130. </script>
  131. @endsection