'admin.dashboard' | jangan lupa diganti private $header = 'Trivia'; private $sub_header = 'Trivia'; private $url = 'admin.trivia.'; public function __construct() { DB::enableQueryLog(); /** nyalakan jika sudah set rolenya, jika ini dinyalakan halaman ini tidak akan keluar */ // $this->middleware('permission:searching-list|searching-create|searching-update|searching-delete', ['only' => ['index', 'create', 'update']]); // $this->middleware('permission:searching-create', ['only' => ['create', 'create_action']]); // $this->middleware('permission:searching-update', ['only' => ['update', 'update_action']]); // $this->middleware('permission:searching-delete', ['only' => ['delete']]); } /** * Ini contoh crud yang sudah jalan * index digunakna untuk tampilan awal dari menu yang akan dibuat * Untuk CRUD Biar cepat * Silahkan ganti * EloquentMu:: => dengan model anda * $id_modelmu => ganti dengan id di model anda * id_di_routenya => jangan lupa disesuaikan dengan yang dideclare di route */ public function index() { Helper::swal(); $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'header' => $this->header, 'sub_header' => $this->sub_header, ]; // dd($data); return view($this->url . 'index', $data); } public function getData($udd_id = null) { // $query = Trivia::query(); $query = Trivia::leftJoin('trivia_answer', 'trivia.id', '=', 'trivia_answer.trivia_id') ->select(['trivia.question', 'trivia.id', 'trivia.image', 'trivia_answer.answer', 'trivia_answer.is_right']) ->where('trivia_answer.is_right', 't'); // dd($query); return Datatables::of($query) ->addIndexColumn() ->addColumn('image', function ($query) { $image = ''.$query->image.''; return $image; }) ->addColumn('aksi', function ($query) { /**cek role */ $aksi = ''; // if (Auth::user()->can('master-jenis-kantong-update')) { $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-sm btn-primary btn-edit'>Edit"; // } // if (Auth::user()->can('master-jenis-kantong-delete')) { $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-danger btn-sm btn-delete'>Delete"; // } return $aksi; }) ->rawColumns(['aksi', 'image']) ->toJson(); } public function create() { $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'header' => $this->header, 'sub_header' => $this->sub_header, ]; Helper::swal(); return view($this->url . 'create', $data); } public function create_action(Request $request) { //declare post untuk simpan semua request yang diinputkan oleh form name="" $post = $request->all(); // dd($post); $file = $request->file('image'); //dd($post); /**digunakan untuk set rule validator */ $rules = [ 'question' => 'required', 'image' => 'required|file|max:1000', ]; /**digunakan untuk set message dari validatornya yang akan keluar gimna, :attribue itu udah langsung mendeteksi inputtan dari name="attribue" */ $alert = [ 'file' => 'File maksimal 1MB' ]; $validator = Validator::make($post, $rules, $alert); if ($validator->passes()) { /**menggunakan transaction */ DB::beginTransaction(); $nama_file = time()."_".$file->getClientOriginalName(); $tujuan_upload = 'image'; //$file->move($tujuan_upload,$nama_file); Storage::putFileAs('public/images/trivia/', $file, $nama_file ); $trivia = new Trivia(); $trivia->question = $request->question; $trivia->image = $nama_file; $trivia->save(); foreach ($request->answer as $key => $value) { $trivia_answer = new TriviaAnswer(); $trivia_answer->answer = $value; $trivia_answer->trivia_id = $trivia->id; $trivia_answer->is_right = ($key==0)?"t":"f"; $trivia_answer->save(); } if ($trivia) { DB::commit(); $message = 'Berhasil'; return redirect(route($this->route . 'index'))->with('success', Helper::parsing_alert($message)); } else { DB::rollback(); $message = 'Gagal'; return redirect()->back()->with('error', Helper::parsing_alert($message)); } } /**kenapa menggunakan back ? karena baliknya pasti ke halaman sebelumnya */ $message = Helper::parsing_alert($validator->errors()->all()); return redirect()->back()->with('error', $message)->withInput(); } public function update($data_id) { Helper::swal(); $data_id = Hashids::decode($data_id); if (!empty($data_id)) { $trivia = Trivia::where('id', $data_id[0])->first(); $trivia_answer = TriviaAnswer::where('trivia_id', $data_id[0])->get(); if ($trivia) { $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'header' => $this->header, 'sub_header' => $this->sub_header, 'trivia' => $trivia, 'trivia_answer' => $trivia_answer ]; return view($this->url . 'update', $data); } $message = 'Id tidak ditemukan atau sudah dihapus'; return redirect()->back()->with('error', $message); } $message = 'Id tdak ditemukan'; return redirect()->back()->with('error', $message); } public function update_action(Request $request) { $post = $request->all(); // dd($post); /**digunakan untuk set rule validator */ $rules = [ 'question' => 'required', ]; /**digunakan untuk set message dari validatornya yang akan keluar gimna, :attribue itu udah langsung mendeteksi inputtan dari name="attribue" */ $alert = []; $validator = Validator::make($post, $rules, $alert); $data_id = Hashids::decode($request['id']); if (!empty($data_id)) { /**cek apakah data_idnya ada ? */ $trivia = Trivia::find($data_id[0]); if ($trivia) { /**cek apakah id data benar" ada di DB ? */ if ($validator->passes()) { /**validatornya */ DB::beginTransaction(); $file = $request->file('image'); if($file){ $nama_file = time()."_".$file->getClientOriginalName(); $tujuan_upload = 'image'; //$file->move($tujuan_upload,$nama_file); Storage::putFileAs('public/images/trivia/', $file, $nama_file ); //File::delete('image/'.$trivia->image); Storage::delete('public/images/trivia/'.$trivia->image); $trivia->image = $nama_file; } $trivia->question = $request->question; $trivia->save(); $counter=0; foreach ($request->answer as $key => $value) { // dd(($key==0)?"t":"f"); $trivia_answer = TriviaAnswer::find($key); $trivia_answer->answer = $value; $trivia_answer->trivia_id = $trivia->id; $trivia_answer->is_right = ($counter==0)?"t":"f"; $trivia_answer->save(); $counter += 1; } if ($trivia) { DB::commit(); $message = 'Berhasil'; return redirect(route($this->route . 'index'))->with('success', Helper::parsing_alert($message)); } else { DB::rollback(); $message = 'Gagal'; return redirect()->back()->with('error', Helper::parsing_alert($message)); } } $message = Helper::parsing_alert($validator->errors()->all()); return redirect()->back()->with('error', $message); } else { $message = 'Id tdak ditemukan'; return redirect()->back()->with('error', $message); } } else { $message = 'Id tidak boleh kosong'; return redirect()->back()->with('error', $message); } } public function delete_action($id_modelmu) { $id = Hashids::decode($id_modelmu); /**cek idnya apakah ada ? */ if (!empty($id)) { $trivia = Trivia::find($id[0]); $trivia_answer = TriviaAnswer::where('trivia_id', $id[0])->firstOrFail(); if ($trivia) { DB::beginTransaction(); try { //File::delete('image/'.$trivia->image); Storage::delete('public/images/trivia/'.$trivia->image); $delete = $trivia->delete(); $delete2 = $trivia_answer->delete(); DB::commit(); $message = 'Sukses'; $response = [ 'message' => $message, 'status' => true, ]; return response()->json($response); } catch (Exception $e) { DB::rollback(); $message = 'Gagal'; $response = [ 'message' => $message, 'status' => false, ]; return response()->json($response); } } $message = 'Id tidak ditemukan atau sudah dihapus'; $response = [ 'message' => $message, 'status' => false, ]; return response()->json($response); } $message = 'Id tdak ditemukan'; $response = [ 'message' => $message, 'status' => false, ]; return response()->json($response); } }