index.blade.php 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  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. <h3 class="panel-title">文章列表</h3>
  10. @can('admin.article.create')
  11. <div class="panel-actions">
  12. <a href="{{route('admin.article.create')}}" class="btn btn-primary"><i class="icon wb-plus"></i>添加文章</a>
  13. </div>
  14. @endcan
  15. </div>
  16. <div class="panel-body">
  17. <form class="form-row">
  18. <div class="form-group col-xxl-1 col-lg-1 col-md-1 col-sm-4">
  19. <input type="number" class="form-control" name="id" value="{{Request::query('id')}}" placeholder="ID"/>
  20. </div>
  21. <div class="form-group col-xxl-1 col-lg-3 col-md-3 col-4">
  22. <select class="form-control" id="type" name="type">
  23. <option value="" hidden>类 型</option>
  24. <option value="1">文章</option>
  25. <option value="2">公告</option>
  26. </select>
  27. </div>
  28. <div class="form-group col-xxl-1 col-lg-3 col-md-3 col-4">
  29. <select class="form-control" id="category" name="category">
  30. <option value="" hidden>分 类</option>
  31. @foreach($categories as $category)
  32. <option value="{{$category->category}}">{{$category->category}}</option>
  33. @endforeach
  34. </select>
  35. </div>
  36. <div class="form-group col-xxl-1 col-lg-3 col-md-3 col-4">
  37. <select class="form-control" id="language" name="language">
  38. <option value="" hidden>语 言</option>
  39. @foreach (config('common.language') as $key => $value)
  40. <option value="{{$key}}">
  41. <i class="fi fi-{{$value[1]}}"></i> <span style="padding: inherit;">{{$value[0]}}</span>
  42. </option>
  43. @endforeach
  44. </select>
  45. </div>
  46. <div class="form-group col-xxl-1 col-lg-3 col-md-3 col-4 btn-group">
  47. <button type="submit" class="btn btn-primary">搜 索</button>
  48. <a href="{{route('admin.article.index')}}" class="btn btn-danger">{{trans('common.reset')}}</a>
  49. </div>
  50. </form>
  51. <table class="text-md-center" data-toggle="table" data-mobile-responsive="true">
  52. <thead class="thead-default">
  53. <tr>
  54. <th> #</th>
  55. <th> 类 型</th>
  56. <th> 分 类</th>
  57. <th> 标 题</th>
  58. <th> 语 言</th>
  59. <th> 排 序</th>
  60. <th> 发布日期</th>
  61. <th> {{trans('common.action')}}</th>
  62. </tr>
  63. </thead>
  64. <tbody>
  65. @foreach($articles as $article)
  66. <tr>
  67. <td> {{$article->id}} </td>
  68. @if ($article->type === 1)
  69. <td> 文章</td>
  70. @elseif ($article->type === 2)
  71. <td> 公告</td>
  72. @else
  73. <td> 未知</td>
  74. @endif
  75. <td class="text-left">
  76. {{ Str::limit($article->category, 30) }}
  77. </td>
  78. <td class="text-left">
  79. {{ Str::limit($article->title, 50) }}
  80. </td>
  81. <td>
  82. {!! isset(config('common.language')[$article->language]) ? '<i class="fi fi-'.config('common.language')[$article->language][1].'"></i>
  83. <span style="padding: inherit;">'.config('common.language')[$article->language][0].'</span>': __('user.unknown') !!}
  84. <td> {{$article->sort}} </td>
  85. <td> {{$article->created_at}} </td>
  86. <td>
  87. @canany(['admin.article.edit', 'admin.article.destroy'])
  88. <div class="btn-group">
  89. @can('admin.article.show')
  90. <a href="{{route('admin.article.show',$article)}}" class="btn btn-outline-success">
  91. <i class="icon wb-eye"></i></a>
  92. @endcan
  93. @can('admin.article.edit')
  94. <a href="{{route('admin.article.edit',['article'=>$article->id, 'page'=>Request::query('page')])}}" class="btn btn-outline-primary">
  95. <i class="icon wb-edit"></i></a>
  96. @endcan
  97. @can('admin.article.destroy')
  98. <a class="btn btn-outline-danger" href="javascript:delArticle('{{route('admin.article.destroy',$article->id)}}')">
  99. <i class="icon wb-close"></i></a>
  100. @endcan
  101. </div>
  102. @endcanany
  103. </td>
  104. </tr>
  105. @endforeach
  106. </tbody>
  107. </table>
  108. </div>
  109. <div class="panel-footer">
  110. <div class="row">
  111. <div class="col-sm-4">
  112. 共 <code>{{$articles->total()}}</code> 篇文章
  113. </div>
  114. <div class="col-sm-8">
  115. <nav class="Page navigation float-right">
  116. {{$articles->links()}}
  117. </nav>
  118. </div>
  119. </div>
  120. </div>
  121. </div>
  122. </div>
  123. @endsection
  124. @section('javascript')
  125. <script src="/assets/global/vendor/bootstrap-table/bootstrap-table.min.js"></script>
  126. <script src="/assets/global/vendor/bootstrap-table/extensions/mobile/bootstrap-table-mobile.min.js"></script>
  127. @can('admin.article.destroy')
  128. <script>
  129. $(document).ready(function() {
  130. $('#id').val('{{Request::query('id')}}');
  131. $('#type').val('{{Request::query('type')}}');
  132. $('#category').val('{{Request::query('category')}}');
  133. $('#language').val('{{Request::query('language')}}');
  134. $('select').on('change', function() { this.form.submit(); });
  135. });
  136. // 删除文章
  137. function delArticle(url) {
  138. swal.fire({
  139. title: '确定删除文章?',
  140. icon: 'question',
  141. showCancelButton: true,
  142. cancelButtonText: '{{trans('common.close')}}',
  143. confirmButtonText: '{{trans('common.confirm')}}',
  144. }).then((result) => {
  145. if (result.value) {
  146. $.ajax({
  147. method: 'DELETE',
  148. url: url,
  149. data: {_token: '{{csrf_token()}}'},
  150. dataType: 'json',
  151. success: function(ret) {
  152. if (ret.status === 'success') {
  153. swal.fire({title: ret.message, icon: 'success', timer: 1000, showConfirmButton: false}).then(() => window.location.reload());
  154. } else {
  155. swal.fire({title: ret.message, icon: 'error'}).then(() => window.location.reload());
  156. }
  157. },
  158. });
  159. }
  160. });
  161. }
  162. </script>
  163. @endcan
  164. @endsection