'admin.dashboard' | jangan lupa diganti private $header = 'Headermu'; private $sub_header = 'Sub Headermu'; /**khusus namespace ambil pathnya aja contoh : App\Http\Controllers\Admin\Simdondar\DonorDarah -> Admin\Simdondar\DonorDarah*/ private $namespace_controller = '{{ namespace }}'; private $url_prefix = 'urlnya routenya'; public function __construct() { DB::enableQueryLog(); /** nyalakan jika sudah set rolenya, jika ini dinyalakan halaman ini tidak akan keluar */ //$this->middleware('permission:Nama_Role_yang_dibuat-list|Nama_Role_yang_dibuat-create|Nama_Role_yang_dibuat-update|Nama_Role_yang_dibuat-delete', ['only' => ['index', 'create', 'update']]); //$this->middleware('permission:Nama_Role_yang_dibuat-create', ['only' => ['create', 'create_action']]); //$this->middleware('permission:Nama_Role_yang_dibuat-update', ['only' => ['update', 'update_action']]); //$this->middleware('permission:Nama_Role_yang_dibuat-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->route . 'index', $data); } /** *digunakan untuk datatable yajra *querynya bisa ganti" sesuai hati */ public function getData() { $query = EloquentMu::All(); $data_table = Datatables::of($query) ->addColumn('aksi', function ($query) { /**cek role */ $aksi = ''; if (Auth::user()->can('Nama_Role_yang_dibuat-update')) { $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-sm btn-primary btn-edit'>Edit"; } if (Auth::user()->can('Nama_Role_yang_dibuat-delete')) { $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-danger btn-sm btn-delete'>Delete"; } return $aksi; }) ->rawColumns(['aksi']) ->escapeColumns([]) //digunakan untuk render html ->toJson(); return $data_table; } /** * create digunakan untuk menampilkan tampilan buat */ public function create() { $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'header' => $this->header, 'sub_header' => $this->sub_header, ]; Helper::swal(); return view($this->route . 'create', $data); } /** * create_action digunakan untuk aksi post * lengkap dengan validatornya */ public function create_action(Request $request) { //declare post untuk simpan semua request yang diinputkan oleh form name="" $post = $request->all(); /**digunakan untuk set rule validator */ $rules = []; /**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); if ($validator->passes()) { /**menggunakan transaction */ DB::beginTransaction(); $query = EloquentMu::create($post); 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(); } /** update sama seperti create hanya saja digunakan untuk update (viewnya saja) */ public function update($id_modelmu) { Helper::swal(); $id_modelmu = Hashids::decode($id_modelmu); if (!empty($id_modelmu)) { $cek_data = EloquentMu::where('id', $id_modelmu[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->route . '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); } /**update_action POST * Logikanya : * 1. Cek Hashids::decode dari data_id apalah benar" di hash ? * -iya * 2. Cek ID yang didapatkan dari hash apakah benar adanya ? * -iya * 3. proses validate * -iya * 4. Proses update * - iya benar * - tidak salah * - tidak return error * - tidak return Id tdak ditemukan * -tidak skip reutrn id null */ public function update_action(Request $request) { $post = $request->all(); /**digunakan untuk set rule validator */ $rules = []; /**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); $id_modelmu = Hashids::decode($request['id']); if (!empty($id_modelmu)) { /**cek apakah data_idnya ada ? */ $cek_data = EloquentMu::where('id', $id_modelmu[0])->first(); if ($cek_data) { /**cek apakah id data benar" ada di DB ? */ if ($validator->passes()) { /**validatornya */ DB::beginTransaction(); $query = $cek_data->update($post); 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); } } /**digunakan untuk delete * Logikanya : * 1. Cek hash id * -ya * 2. Cek id dari hash * - ya * 3. Proses delete * -Ya * -Tidak * - tidak return Id tidak ditemukan atau sudah dihapus * -tidak reutrn Id tdak ditemukan */ public function delete_action($id_modelmu) { $id_modelmu = Hashids::decode($id_modelmu); /**cek idnya apakah ada ? */ if (!empty($id_modelmu)) { $cek_data = EloquentMu::where('id', $id_modelmu[0])->first(); if ($cek_data) { DB::beginTransaction(); $delete = $cek_data->delete(); if ($delete) { DB::commit(); $message = 'Succesfully'; return redirect()->back()->with('success', $message); } else { DB::rollback(); $message = 'Gagal'; return redirect()->back()->with('error', $message); } } $message = 'Id tidak ditemukan atau sudah dihapus'; return redirect()->back()->with('error', $message); } $message = 'Id tdak ditemukan'; return redirect()->back()->with('error', $message); } /**declare routenya disni*/ public function route(){ $route = Route::namespace($this->namespace_controller) ->prefix($this->url_prefix) ->name($this->route) ->group(function () { Route::get('/', ['as' => 'index', 'uses' => '{{ class }}@index']); Route::get('/get-data/{udd_id?}', ['as' => 'get_data', 'uses' => '{{ class }}@getData']); Route::get('/datatables', ['as' => 'datatables', 'uses' => '{{ class }}@datatables']); Route::get('/create', ['as' => 'create', 'uses' => '{{ class }}@create']); Route::get('/update/{id_di_routenya}', ['as' => 'update', 'uses' => '{{ class }}@update']); Route::get('/delete-action/{id_di_routenya}', ['as' => 'delete_action', 'uses' => '{{ class }}@delete_action']); Route::post('/create-action', ['as' => 'create_action', 'uses' => '{{ class }}@create_action']); Route::post('/update-action', ['as' => 'update_action', 'uses' => '{{ class }}@update_action']); }); return $route; } /**end declare route */ }