PhotosController.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. <?php
  2. namespace App\Http\Controllers\Admin\Base;
  3. use App\Http\Controllers\Admin\Controller;
  4. use App\Services\Base\Attachment;
  5. use App\Models\BaseAttachmentModel;
  6. use App\Models\BaseSettingsModel;
  7. use App\Models\ClassModel;
  8. use Illuminate\Http\Request as HttpRequest;
  9. use Request;
  10. use Storage;
  11. use File;
  12. use Auth;
  13. class PhotosController extends Controller
  14. {
  15. private $_serviceAttachment;
  16. public function __construct()
  17. {
  18. if( !$this->_serviceAttachment ) $this->_serviceAttachment = new Attachment();
  19. }
  20. public function index(HttpRequest $request)
  21. {
  22. $userAuth = Auth::guard('admin')->user();
  23. $classes = ClassModel::all();
  24. $a_class = $request->has('class') ? $request->input('class') : null;
  25. if ($userAuth->is_root == 1) {
  26. if (($a_class = ClassModel::find($a_class)) == null || empty(($a_class = ClassModel::find($a_class))->item)) {
  27. $a_class = ClassModel::first();
  28. }
  29. } else {
  30. $a_class['store_id'] = $this->getStoreId();
  31. if (($a_class = ClassModel::find($a_class)) == null || empty(($a_class = ClassModel::find($a_class))->item)) {
  32. $a_class = ClassModel::where('store_id', $this->getStoreId())->first();
  33. }
  34. }
  35. $photos = null;
  36. $status = 'normal';
  37. if ($request->has('search')) {
  38. $name = '%' . $request->input('search') . '%';
  39. if ($userAuth->is_root == 1) {
  40. $photos = BaseAttachmentModel::where([['name', 'like', $name]])->paginate(24);
  41. } else {
  42. $photos = BaseAttachmentModel::where([['name', 'like', $name],['store_id', $this->getStoreId()]])->paginate(24);
  43. }
  44. $status = 'search';
  45. } else {
  46. if ($a_class) {
  47. if ($userAuth->is_root == 1) {
  48. $photos = BaseAttachmentModel::where([['class', $a_class->class]])->paginate(24);
  49. } else {
  50. $photos = BaseAttachmentModel::where([['class', $a_class->class],['store_id', $this->getStoreId()]])->paginate(24);
  51. }
  52. } else {
  53. $save['store_id'] = $this->getStoreId();
  54. $save['class'] = '未分类';
  55. ClassModel::create($save);
  56. $a_class = ClassModel::where('store_id', $this->getStoreId())->first();
  57. }
  58. }
  59. return view('admin.base.photos.index', compact('photos', 'classes', 'a_class', 'photos', 'status', 'photo_compress_quality'));
  60. }
  61. public function edit(HttpRequest $request)
  62. {
  63. if(Request::method() != 'POST') {
  64. return back();
  65. }
  66. if($request->has('img-name') && $request->has('img-id')) {
  67. $photo = BaseAttachmentModel::find($request->input('img-id'));
  68. $photo->name = $request->input('img-name');
  69. $photo->save();
  70. }
  71. return back();
  72. }
  73. public function move(HttpRequest $request)
  74. {
  75. if(Request::method() != 'POST') {
  76. return back();
  77. }
  78. $ids = explode(',', $request->input('ids'));
  79. $class = ClassModel::find($request->input('class'));
  80. BaseAttachmentModel::whereIn('id', $ids)->update(['class' => $class->class]);
  81. return back();
  82. }
  83. public function delete(HttpRequest $request)
  84. {
  85. if(Request::method() != 'POST') {
  86. return back();
  87. }
  88. $ids = explode(',', $request->input('ids'));
  89. $photos = BaseAttachmentModel::find($ids);
  90. foreach($photos as $photo) {
  91. File::delete($photo->path);
  92. $photo->delete();
  93. }
  94. return back();
  95. }
  96. public function crop(HttpRequest $request)
  97. {
  98. if(Request::method() != 'POST') {
  99. return back();
  100. }
  101. $this->_serviceAttachment->localUpload('file', $request->all());
  102. return response()->json(['status' => 'ok'], 200);
  103. }
  104. }