123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- <?php
- namespace App\Http\Controllers\Admin\Base;
- use App\Http\Controllers\Admin\Controller;
- use App\Services\Base\Attachment;
- use App\Models\BaseAttachmentModel;
- use App\Models\ClassModel;
- use App\Services\OSS;
- use Illuminate\Http\Request as HttpRequest;
- use Request;
- use File;
- class PhotosController extends Controller
- {
- private $_serviceAttachment;
- public function __construct()
- {
- if( !$this->_serviceAttachment ) $this->_serviceAttachment = new Attachment();
- }
- public function index(HttpRequest $request)
- {
- $classes = ClassModel::all();
- $a_class = $request->has('class') ? $request->input('class') : null;
- if(($a_class = ClassModel::find($a_class)) == null) {
- $a_class = ClassModel::first();
- }
- $photos = null;
- $status = 'normal';
- if($request->has('search')){
- $currentQuery = new BaseAttachmentModel();
- if ($request->has('search') && !empty($request->has('search'))) {
- $name = '%' . $request->input('search') . '%';
- $currentQuery = $currentQuery->where(function ($query) use ($name) {
- $query->where('name', 'like', $name);
- });
- }
- if($request->has('start') && !empty($request->get('start')))
- {
- $start = $request->get('start');
- $currentQuery = $currentQuery->where(function ($query) use ($start) {
- $query->where('created_at', '>=', $start);
- });
- }
- if($request->has('end') && !empty($request->get('end')))
- {
- $end = $request->get('end');
- $currentQuery = $currentQuery->where(function ($query) use ($end) {
- $query->where('created_at', '<=', $end);
- });
- }
- $photos = $currentQuery->paginate(24);
- } else{
- $photos = BaseAttachmentModel::where('class',$a_class->class)->paginate(24);
- }
- return view('admin.base.photos.index', compact('photos', 'classes', 'a_class', 'status', 'photo_compress_quality'));
- }
- public function edit(HttpRequest $request)
- {
- if(Request::method() != 'POST') {
- return back();
- }
- if($request->has('img-name') && $request->has('img-id')) {
- $photo = BaseAttachmentModel::find($request->input('img-id'));
- $photo->name = $request->input('img-name');
- $photo->save();
- }
- return back();
- }
- public function move(HttpRequest $request)
- {
- if(Request::method() != 'POST') {
- return back();
- }
- $ids = explode(',', $request->input('ids'));
- $class = ClassModel::find($request->input('class'));
- BaseAttachmentModel::whereIn('id', $ids)->update(['class' => $class->class]);
- return back();
- }
- public function delete(HttpRequest $request)
- {
- if(Request::method() != 'POST') {
- return back();
- }
- $ids = explode(',', $request->input('ids'));
- $photos = BaseAttachmentModel::find($ids);
- foreach($photos as $photo) {
- if($photo->path == $photo->url){
- $key = explode('/',$photo->path);
- OSS::publicDeleteObject(config('alioss.BucketName'),end($key));
- }else{
- File::delete($photo->path);
- }
- $photo->delete();
- }
- return back();
- }
- public function crop(HttpRequest $request)
- {
- if(Request::method() != 'POST') {
- return back();
- }
- $this->_serviceAttachment->localUpload('file', $request->all());
- return response()->json(['status' => 'ok'], 200);
- }
- }
|