index.blade.php 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422
  1. @extends('admin.layouts.app')
  2. @section('header')
  3. <style type="text/css">
  4. .side-class-bar ul li a {
  5. padding: 5px 10px !important;
  6. }
  7. .side-class-bar .a_selected {
  8. background-color: #eeeeee;
  9. }
  10. #file-upload-modal .modal-dialog {
  11. width: 80%;
  12. }
  13. #crop-file-modal .modal-dialog {
  14. width: 80%;
  15. }
  16. @media (min-width: 768px) {
  17. #file-upload-modal .modal-dialog {
  18. max-width: 1200px;
  19. }
  20. }
  21. .img-check {
  22. position: absolute;
  23. right: 5px;
  24. bottom: 5px;
  25. margin: 0;
  26. padding: 0;
  27. width: 22px;
  28. height: 22px;
  29. background: url(/base/img/check_blue_1.png) no-repeat;
  30. border: none;
  31. background-position: -144px 0;
  32. }
  33. .img-check.checked {
  34. background-position: -168px 0;
  35. }
  36. .img-card .content {
  37. text-align: center;
  38. word-wrap: break-word;
  39. }
  40. .img-card .image {
  41. position: relative;
  42. }
  43. .sg-divider {
  44. margin: 1rem 0rem;
  45. line-height: 1;
  46. height: 0em;
  47. font-weight: bold;
  48. text-transform: uppercase;
  49. letter-spacing: 0.05em;
  50. color: rgba(0, 0, 0, 0.85);
  51. }
  52. #add-class-modal-label {
  53. float: left
  54. }
  55. </style>
  56. <script type="text/javascript" src="/base/neditor-1.5.3/dialogs/image/image.js"></script>
  57. <script type="text/javascript" src="/base/neditor-1.5.3/dialogs/internal.js"></script>
  58. @endsection
  59. @section('content')
  60. <div class="wrapper wrapper-content animated fadeInRight">
  61. <div class="row">
  62. <div class="col-sm-12">
  63. @if(isset($errors) && !$errors->isEmpty())
  64. <div class="alert alert-danger alert-dismissable">
  65. <button type="button" class="close" data-dismiss="alert"
  66. aria-hidden="true">
  67. &times;
  68. </button>
  69. @foreach($errors->keys() as $key)
  70. {{ $errors->first($key) }}
  71. @endforeach
  72. </div>
  73. @endif
  74. <div class="ibox float-e-margins">
  75. <div class="ibox-title" style="padding: 7px 14px 15px;">
  76. <h5 style="margin-top: 8px">图片管理</h5>
  77. <div class="ibox-tools" style="margin-top: 8px">
  78. <a class="collapse-link"> <i class="fa fa-chevron-up"></i>
  79. </a>
  80. </div>
  81. <div class="btn-group pull-right">
  82. <div id="select-toogle" class="btn btn-sm btn-default">全选图片</div>
  83. <div id="upload-btn" class="btn btn-sm btn-primary">上传</div>
  84. <div id="add-class-btn" class="btn btn-sm btn-success">添加分类</div>
  85. <div id="move-file" class="btn btn-sm btn-info">批量移动</div>
  86. <div id="delete-file" class="btn btn-sm btn-warning">删除图片</div>
  87. @if(Request::get('class') >1 )
  88. <div id="delete-class" class="btn btn-sm btn-danger">删除分类</div>
  89. @endif
  90. </div>
  91. </div>
  92. <div class="ibox-content">
  93. <div class="row">
  94. <div class="col-sm-12">
  95. <form method="GET" accept-charset="UTF-8">
  96. <div class="row">
  97. <div class="col-sm-4">
  98. <select class="form-control" name="class" id="search-file-input"required>
  99. <option value="0" @if(!Request::get('class')) selected @endif>全部</option>
  100. @foreach($classes as $class)
  101. <option value="{{$class->id}}"
  102. @if($class->class == $a_class->class && Request::get('class')) selected @endif>{{$class->class}}
  103. </option>
  104. @endforeach
  105. </select>
  106. </div>
  107. <div class="col-sm-3" id="data_1">
  108. <div class="input-group date">
  109. <span class="input-group-addon">
  110. <i class="fa fa-calendar"></i></span>
  111. <input type="text" id="start" class="form-control" placeholder="开始日期" name="start"
  112. value="{{Request::get('start') ? : ''}}">
  113. </div>
  114. </div>
  115. <div class="col-sm-3" id="data_2">
  116. <div class="input-group date">
  117. <span class="input-group-addon">
  118. <i class="fa fa-calendar"></i></span>
  119. <input type="text" id="end" class="form-control" placeholder="结束日期" name="end"
  120. value="{{Request::get('end') ? : ''}}">
  121. </div>
  122. </div>
  123. <div class="col-sm-2">
  124. <button type="submit" class="btn btn-sm btn-primary"
  125. id="search-file">搜索
  126. </button>
  127. </div>
  128. </div>
  129. </form>
  130. <div class="photos"
  131. style="margin-top: 10px;padding-top: 15px;border-top: 1px solid #ddd">
  132. @foreach($photos as $photo)
  133. @if($loop->index % 6 == 0)
  134. <div class="row" style="padding: 0 10px">
  135. @endif
  136. <div class="img-card col-sm-2">
  137. <div class="image">
  138. <img src="{{ $photo->url }}" class="img-thumbnail">
  139. <span class="img-check" data-id="{{ $photo->id }}"
  140. data-name="{{ $photo->name }}"
  141. data-src="{{ $photo->url }}"
  142. data-class="{{ $photo->class }}"
  143. data-md5="{{ $photo->md5 }}"></span>
  144. </div>
  145. <div class="content">
  146. {{ $photo->name }}
  147. </div>
  148. </div>
  149. @if($loop->index % 6 ==5)
  150. </div>
  151. @endif
  152. @endforeach
  153. </div>
  154. </div>
  155. </div>
  156. </div>
  157. <div class="row">
  158. <div class="col-sm-6">
  159. <div class="dataTables_info" id="DataTables_Table_0_info"
  160. role="alert" aria-live="polite" aria-relevant="all">每页{{ $photos->count() }}
  161. 条,共{{ $photos->lastPage() }}页,总{{ $photos->total() }}条。
  162. </div>
  163. </div>
  164. <div class="col-sm-6">
  165. <div class="dataTables_paginate paging_simple_numbers" id="DataTables_Table_0_paginate">
  166. {!! $photos->setPath('')->appends(Request::all())->render() !!}
  167. </div>
  168. </div>
  169. </div>
  170. </div>
  171. </div>
  172. </div>
  173. </div>
  174. <!-- 添加分类 -->
  175. <div class="modal fade" id="add-class-modal" tabindex="-1" role="dialog" aria-labelledby="add-class-modal-label"
  176. aria-hidden="true">
  177. <div class="modal-dialog">
  178. <div class="modal-content">
  179. <div class="modal-header">
  180. <h4 class="modal-title" id="add-class-modal-label">添加分类</h4>
  181. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  182. </div>
  183. <div class="modal-body">
  184. <form class="form-horizontal" role="form" method="POST" id="add-class-form"
  185. action="{{ U('Base/AttachmentClass/add') }}">
  186. {{ csrf_field() }}
  187. <div class="form-group row">
  188. <label for="class" class="col-md-2 col-md-offset-2 col-form-label">分类</label>
  189. <div class="col-md-10">
  190. <input id="class" type="text" class="form-control" name="class" required autofocus>
  191. </div>
  192. </div>
  193. <div class="form-group">
  194. <div class="col-md-12 col-md-offset-4" style="text-align: center">
  195. <button type="submit" class="btn btn-primary btn-lg" id="edit-project-confirm">
  196. 确认添加
  197. </button>
  198. </div>
  199. </div>
  200. </form>
  201. </div>
  202. </div>
  203. </div>
  204. </div>
  205. <!-- 移动图片 -->
  206. <div class="modal fade" id="move-file-modal" tabindex="-1" role="dialog" aria-labelledby="move-file-modal-label"
  207. aria-hidden="true">
  208. <div class="modal-dialog">
  209. <div class="modal-content">
  210. <div class="modal-header">
  211. <h4 class="modal-title" id="move-file-modal-label">移动图片</h4>
  212. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  213. </div>
  214. <div class="modal-body">
  215. <form class="form-horizontal" role="form" method="POST" id="move-file-form"
  216. action="{{ U('Base/Photos/move') }}">
  217. {{ csrf_field() }}
  218. <div class="form-group">
  219. <label for="class" class="col-md-2 col-md-offset-2 control-label">移动到</label>
  220. <div class="col-md-6">
  221. <select class="form-control" name="class">
  222. @foreach($classes as $class)
  223. <option value="{{ $class->id }}">
  224. {{ $class->class }}
  225. </option>
  226. @endforeach
  227. </select>
  228. </div>
  229. </div>
  230. <input class="ids" type="text" name="ids" style="display: none">
  231. <div class="form-group">
  232. <div class="col-md-12 col-md-offset-4" style="text-align: center">
  233. <button type="submit" class="btn btn-primary">
  234. 确认
  235. </button>
  236. </div>
  237. </div>
  238. </form>
  239. </div>
  240. </div>
  241. </div>
  242. </div>
  243. <!-- 删除图片 -->
  244. <div class="modal fade" id="delete-file-modal" tabindex="-1" role="dialog"
  245. aria-labelledby="delete-file-modal-label"
  246. aria-hidden="true">
  247. <div class="modal-dialog">
  248. <div class="modal-content">
  249. <div class="modal-header">
  250. <h4 class="modal-title" id="delete-file-modal-label">确定要删除以下图片吗?</h4>
  251. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  252. </div>
  253. <div class="modal-body">
  254. <div id="delete-files"></div>
  255. <form class="form-horizontal" role="form" method="POST" id="delete-file-form"
  256. action="{{ U('Base/Photos/delete') }}">
  257. {{ csrf_field() }}
  258. <input class="ids" type="text" name="ids" style="display: none">
  259. <div class="form-group">
  260. <div class="col-md-12 col-md-offset-4" style="text-align: center">
  261. <button type="submit" class="btn btn-primary">
  262. 确认
  263. </button>
  264. </div>
  265. </div>
  266. </form>
  267. </div>
  268. </div>
  269. </div>
  270. </div>
  271. <!-- 删除分类 -->
  272. <div class="modal fade" id="delete-class-modal" tabindex="-1" role="dialog"
  273. aria-labelledby="delete-class-modal-label" aria-hidden="true">
  274. <div class="modal-dialog">
  275. <div class="modal-content">
  276. <div class="modal-header">
  277. <h4 class="modal-title" id="delete-class-modal-label">
  278. {{ '确定要删除分类《' . $a_class->class . '》及其分类下所有的图片吗?' }}
  279. </h4>
  280. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  281. </div>
  282. <div class="modal-body">
  283. <form class="form-horizontal" role="form" method="POST" id="delete-class-form"
  284. action="{{ U('Base/AttachmentClass/delete', ['class' => $a_class->id]) }}">
  285. {{ csrf_field() }}
  286. <div class="form-group">
  287. <div class="col-md-12 col-md-offset-4" style="text-align: center">
  288. <button type="submit" class="btn btn-primary btn-lg">
  289. 确认
  290. </button>
  291. </div>
  292. </div>
  293. </form>
  294. </div>
  295. </div>
  296. </div>
  297. </div>
  298. <!-- 上传图片 -->
  299. <div class="modal fade modal-margin-top" id="file-upload-modal" tabindex="-1" role="dialog"
  300. aria-labelledby="file-upload-modal-label" aria-hidden="true">
  301. <div class="modal-dialog">
  302. <div class="modal-content">
  303. <div class="modal-header">
  304. <h4 class="modal-title" id="delete-class-modal-label">
  305. 上传图片
  306. </h4>
  307. <button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
  308. </div>
  309. <div class="modal-body">
  310. {!! widget('Tools.ImgUpload')->upload('file_upload', 'file','default', ['position'=>'local','class' => $a_class->id]) !!}
  311. </div>
  312. </div>
  313. </div>
  314. </div>
  315. @endsection
  316. @section('js')
  317. <script type="text/javascript">
  318. $(function () {
  319. $('#upload-btn').on('click', function () {
  320. $('#file-upload-modal').modal('show');
  321. });
  322. $('#add-class-btn').on('click', function () {
  323. $('#add-class-modal').modal('show');
  324. });
  325. $('#add-class-confirm-btn').on('click', function () {
  326. $('#add-class-form').submit();
  327. });
  328. $('.img-card', '.photos').on('click', function () {
  329. $(this).find('.img-check').toggleClass('checked');
  330. });
  331. $('#select-toogle').on('click', function () {
  332. if ($(this).hasClass('selected')) {
  333. $('.photos .img-check').removeClass('checked');
  334. $(this).removeClass('selected').text('全选图片');
  335. } else {
  336. $('.photos .img-check').removeClass('checked').addClass('checked');
  337. $(this).addClass('selected').text('取消全选');
  338. }
  339. });
  340. $('#move-file').on('click', function () {
  341. photos = $('.photos').find('.checked');
  342. if (photos.length != 0) {
  343. ids = $(photos[0]).attr('data-id');
  344. for (i = 1; i < photos.length; ++i) {
  345. ids += ',' + $(photos[i]).attr('data-id');
  346. }
  347. $('.ids', '#move-file-modal').val(ids);
  348. $('#move-file-modal').modal('show');
  349. }
  350. });
  351. $('#delete-file').on('click', function () {
  352. photos = $('.photos').find('.checked');
  353. info = '';
  354. if (photos.length != 0) {
  355. ids = $(photos[0]).attr('data-id');
  356. info += $(photos[0]).attr('data-name');
  357. for (i = 1; i < photos.length; ++i) {
  358. ids += ',' + $(photos[i]).attr('data-id');
  359. info += '<br>' + $(photos[i]).attr('data-name');
  360. }
  361. $('.ids', '#delete-file-modal').val(ids);
  362. $('#delete-files').html(info);
  363. $('#delete-file-modal').modal('show');
  364. }
  365. });
  366. $('#delete-class').on('click', function () {
  367. $('#delete-class-modal').modal('show');
  368. });
  369. $('#search-file').on('click', function (e) {
  370. e.preventDefault();
  371. $input = $('#search-file-input');
  372. $start = $('#start');
  373. $end = $('#end');
  374. $url = "{{ U('Base/Photos/index') }}" + '?class=' + $input.val().trim();
  375. if($start.val()){
  376. $url =$url + '&start=' + $start.val()
  377. }
  378. if($end.val()){
  379. $url =$url + '&end=' + $end.val();
  380. }
  381. window.location = $url;
  382. });
  383. });
  384. </script>
  385. @endsection