'admin.dashboard' | jangan lupa diganti private $header = 'Event Organisasi'; private $sub_header = 'Event Organisasi'; private $url = 'admin.raharja.event_organisasi.'; public function __construct() { DB::enableQueryLog(); /** nyalakan jika sudah set rolenya, jika ini dinyalakan halaman ini tidak akan keluar */ } public function index() { Helper::swal(); $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'header' => $this->header, 'sub_header' => $this->sub_header, ]; return view($this->url . 'index', $data); } public function getData($udd_id = null) { $query = EventOrganisasi::query(); return Datatables::of($query) ->addIndexColumn() ->addColumn('start', function($query){ return Carbon::parse($query->start_date)->format('Y-m-d'); }) ->addColumn('end', function($query){ return Carbon::parse($query->end_date)->format('Y-m-d'); }) ->addColumn('aksi', function ($query) { /**cek role */ $aksi = ''; $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-sm btn-primary btn-edit'>Edit"; $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-sm btn-warning btn-edit'>Kelompok Driver"; $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-danger btn-sm btn-delete'>Delete"; return $aksi; }) ->rawColumns(['aksi']) ->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(); $file = $request->file('banner'); /**digunakan untuk set rule validator */ $rules = [ 'banner' => 'required|file|max:1000', 'start_date' => 'required', 'end_date' => 'required', 'deskripsi' => 'required', ]; /**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(); Storage::putFileAs('public/images/event_organisasi/', $file, $nama_file ); $query = new EventOrganisasi(); $query->start_date = $request->start_date; $query->end_date = $request->end_date; $query->deskripsi = $request->deskripsi; $query->banner = $nama_file; $query->save(); if ($query) { 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)) { $cek_data = EventOrganisasi::where('id', $data_id[0])->first(); if ($cek_data) { $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'header' => $this->header, 'sub_header' => $this->sub_header, 'data' => $cek_data ]; 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(); /**digunakan untuk set rule validator */ $rules = [ 'banner' => 'file|max:1000', 'start_date' => 'required', 'end_date' => 'required', 'deskripsi' => '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 ? */ $query = EventOrganisasi::find($data_id[0]); if ($query) { /**cek apakah id data benar" ada di DB ? */ if ($validator->passes()) { /**validatornya */ DB::beginTransaction(); $file = $request->file('banner'); if($file){ $nama_file = time()."_".$file->getClientOriginalName(); Storage::putFileAs('public/images/event_organisasi/', $file, $nama_file ); Storage::delete('public/images/event_organisasi/'.$query->thumbnail); $query->banner = $nama_file; } $query->start_date = $request->start_date; $query->end_date = $request->end_date; $query->deskripsi = $request->deskripsi; $query->save(); if ($query) { 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)) { $cek_data = EventOrganisasi::find($id[0]); if ($cek_data) { DB::beginTransaction(); try { $arr_member = $cek_data->kelompokMember; foreach($arr_member as $like){ $like->delete(); } Storage::delete('public/images/event_organisasi/'.$cek_data->thumbnail); $delete = $cek_data->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); } public function kelompokDriver($data_id) { Helper::swal(); $data_id = Hashids::decode($data_id); if (!empty($data_id)) { $cek_data = EventOrganisasi::where('id', $data_id[0])->first(); if ($cek_data) { $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'header' => $this->header, 'sub_header' => $this->sub_header, 'data' => $cek_data, 'route_get_data' => route($this->route . 'get_data_kelompok_driver', ['data_id' => $cek_data->id]), ]; return view($this->url . 'kelompok_driver_member', $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 getDataKelompokDriver($data_id){ $query = EventOrganisasiMembers::where('event_organisasi_id', $data_id); return Datatables::of($query) ->addIndexColumn() ->addColumn('nama', function ($query){ return $query->kelompokDriver->nama; }) ->filterColumn('nama', function($query, $keyword) { $query->whereHas('kelompokDriver', function ($sub) use ($keyword) { $sub->where('nama', 'like', '%' . $keyword . '%'); });; }) ->addColumn('aksi', function ($query) { /**cek role */ $aksi = ''; $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-danger btn-sm btn-delete'>Delete"; return $aksi; }) ->rawColumns(['aksi']) ->toJson(); } public function deleteKelompokDriver($data_id){ $id = Hashids::decode($data_id); /**cek idnya apakah ada ? */ if (!empty($id)) { $cek_data = EventOrganisasiMembers::find($id[0]); if ($cek_data) { DB::beginTransaction(); try { $delete = $cek_data->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); } public function selectKelompokDriver(Request $request){ if (session('error')) { alert()->html('', session('error'), 'error'); } $term = trim($request['nama']); $arr_organisasi = EventOrganisasiMembers::where('event_organisasi_id', $request['e_o_id'])->get()->pluck('kelompok_driver_id')->toArray(); $kelompok_driver = KelompokDriver::whereNotIn('id', $arr_organisasi)->take(10); if (!empty($request['not_in'])) { $id = collect($request['not_in']); $kelompok_driver = $kelompok_driver->whereNotIn('id', $id); } if (!empty($term)) { $kelompok_driver = $kelompok_driver->where('nama', 'like', '%' . $term . '%'); } $kelompok_driver = $kelompok_driver->get(); $response = []; foreach ($kelompok_driver as $key => $value) { $response[] = ['id' => $value->id, 'text' => $value->nama ]; } return response()->json($response); } public function addKelompokDriver(Request $request){ $query = new EventOrganisasiMembers(); $query->event_organisasi_id = $request->organisasi_id; $query->kelompok_driver_id = $request->kelompok_driver_id; $query->save(); if ($query) { DB::commit(); $message = 'Berhasil'; return redirect(route($this->route . 'kelompok_driver',['data_id' => Hashids::encode($request->organisasi_id)]))->with('success', Helper::parsing_alert($message)); } else { DB::rollback(); $message = 'Gagal'; return redirect()->back()->with('error', Helper::parsing_alert($message)); } } }