'admin.dashboard' | jangan lupa diganti private $namespace_controller = 'Admin\User_management'; private $url_prefix = 'user-management/rumah-sakit/'; public function __construct() { DB::enableQueryLog(); /** nyalakan jika sudah set rolenya, jika ini dinyalakan halaman ini tidak akan keluar */ $this->middleware('permission:rumah_sakit-list|rumah_sakit-create|rumah_sakit-update|rumah_sakit-delete', ['only' => ['index', 'create', 'update']]); $this->middleware('permission:rumah_sakit-create', ['only' => ['create', 'create_action']]); $this->middleware('permission:rumah_sakit-update', ['only' => ['update', 'update_action']]); $this->middleware('permission:rumah_sakit-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 * user_rs:: => dengan model anda * $rumah_sakit_id => ganti dengan id di model anda * rumah_sakit_id => jangan lupa disesuaikan dengan yang dideclare di route */ public function index() { if (session('success')) { alert()->html('', session('success'), 'success'); } if (session('error')) { alert()->html('', session('error'), 'error'); } $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, ]; // dd($data); return view($this->route . 'index', $data); } /** *digunakan untuk datatable yajra *querynya bisa ganti" sesuai hati */ public function getData() { $query = user_rs::All(); foreach ($query as $key => $value) { $value->no = ($key + 1); $value->email = $value->user->email ?? null; } return Datatables::of($query) ->addColumn('aksi', function ($query) { $aksi = ''; if (Auth::user()->can('rumah_sakit-update')) { $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-sm btn-primary btn-edit'>Edit"; } if (Auth::user()->can('rumah_sakit-delete')) { // $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-danger btn-sm btn-delete'>Delete"; } return $aksi; }) ->rawColumns(['aksi']) ->toJson(); } /** * create digunakan untuk menampilkan tampilan buat */ public function create() { $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'roles' => Role::where('id',5)->get(), ]; if (session('success')) { alert()->html('', session('success'), 'success'); } if (session('error')) { alert()->html('', session('error'), 'error'); } 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(); // dd($post); /**digunakan untuk set rule validator */ $rules = [ 'role_id' => 'required', 'nama' => 'required', 'deskripsi' => 'required', 'email' => 'required|unique:users,email', 'password' => 'required:min:6', 'alamat' => 'required', 'nama_bank_darah' => 'required', 'kode_rumah_sakit' => 'required', 'jenis' => 'required', 'kepemilikan' => 'required', ]; /**digunakan untuk set message dari validatornya yang akan keluar gimna, :attribue itu udah langsung mendeteksi inputtan dari name="attribue" */ $alert = [ 'required' => ':attribute', 'unique' => ':attribute telah terpakai', 'min' => ':attribute :min karakter', ]; $validator = Validator::make($post, $rules, $alert); if ($validator->passes()) { /**menggunakan transaction */ DB::beginTransaction(); $user_rs = [ 'email' => $post['email'], 'name' => $post['nama'], 'password' => Hash::make($post['password']), ]; $insert_user = User::create($user_rs); $insert_user->assignRole($request['role_id']); $data_user_rs = $request->only(['nama', 'deskripsi', 'alamat', 'nama_bank_darah', 'kode_rumah_sakit']); $data_user_rs['user_login_id'] = $insert_user->id; $data_user_rs['type_id'] = $post['jenis']; $data_user_rs['kepemilikan_id'] = $post['kepemilikan']; $insert_user_rs = user_rs::create($data_user_rs); if ($insert_user_rs) { 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($rumah_sakit_id) { if (session('success')) { alert()->html('', session('success'), 'success'); } if (session('error')) { alert()->html('', session('error'), 'error'); } $rumah_sakit_id = Hashids::decode($rumah_sakit_id); if (!empty($rumah_sakit_id)) { $cek_data = user_rs::where('id', $rumah_sakit_id[0])->first(); if ($cek_data) { $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'data' => $cek_data, 'roles' => Role::where('id',5)->get() ]; 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 */ // dd($post); $rules = [ 'role_id' => 'required', 'nama' => 'required', 'deskripsi' => 'required', 'email' => 'required', 'alamat' => 'required', 'nama_bank_darah' => 'required', 'jenis' => 'required', 'kepemilikan' => 'required', ]; /**digunakan untuk set message dari validatornya yang akan keluar gimna, :attribue itu udah langsung mendeteksi inputtan dari name="attribue" */ $alert = [ 'required' => ':attribute', ]; $validator = Validator::make($post, $rules, $alert); $rumah_sakit_id = Hashids::decode($request['id']); if (!empty($rumah_sakit_id)) { /**cek apakah data_idnya ada ? */ $cek_data = user_rs::where('id', $rumah_sakit_id[0])->first(); if ($cek_data) { /**cek apakah id data benar" ada di DB ? */ if ($validator->passes()) { // dd($post); /**validatornya */ DB::beginTransaction(); $data_user = [ 'name' => $request['nama'], 'email' => $request['email'], ]; if ($request['password']) { $length = Str::of($request['password'])->length(); if ($length < 6) { $message = 'Password minimal 6 karakter'; return redirect()->back()->withInput()->with('error', $message); } $data_user['password'] = Hash::make($request['password']); } /**delete roles */ ModelHasRoles::where('model_id', $cek_data->user->id)->delete(); $find_user = User::findOrFail($cek_data->user->id); $update_user = $find_user->update($data_user); $find_user->assignRole($request['role_id']); $data_rs = $request->only(['nama', 'deskripsi', 'alamat', 'nama_bank_darah','kode_rumah_sakit']); $data_rs['type_id'] = $post['jenis']; $data_rs['kepemilikan_id'] = $post['kepemilikan']; $update_rs = $cek_data->update($data_rs); if ($update_user && $update_rs) { 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($rumah_sakit_id) { $rumah_sakit_id = Hashids::decode($rumah_sakit_id); /**cek idnya apakah ada ? */ if (!empty($rumah_sakit_id)) { $cek_data = user_rs::where('id', $rumah_sakit_id[0])->first(); if ($cek_data) { DB::beginTransaction(); $delete = $cek_data->delete(); if ($delete) { DB::commit(); $message = 'Succesfully'; $response = [ 'message' => $message, 'status' => true, ]; return response()->json($response); } else { 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 selectJenisRs(Request $request){ if (session('error')) { alert()->html('', session('error'), 'error'); } $term = trim($request['petugas']); $query = MasterRumahSakitType::take(5); if (!empty($request['not_in'])) { $query = $query->whereNotIn('id', [$request['not_in']]); } if (!empty($term)) { $query = $query->where('nama', 'like', '%' . $term . '%'); } $query = $query->get(); $response = []; foreach ($query as $key => $value) { $response[] = ['id' => $value->id, 'text' => $value->nama]; } return response()->json($response); } public function selectKepemilikanRs(Request $request){ if (session('error')) { alert()->html('', session('error'), 'error'); } $term = trim($request['petugas']); $query = MasterRumahSakitKepememilikans::take(5); if (!empty($request['not_in'])) { $query = $query->whereNotIn('id', [$request['not_in']]); } if (!empty($term)) { $query = $query->where('nama', 'like', '%' . $term . '%'); } $query = $query->get(); $response = []; foreach ($query as $key => $value) { $response[] = ['id' => $value->id, 'text' => $value->nama]; } return response()->json($response); } //custom route public function route() { return Route::group([ 'as' => $this->route, 'prefix' => $this->url_prefix, 'namespace' => $this->namespace_controller ], function () { Route::get('/', ['as' => 'index', 'uses' => 'RumahSakitController@index']); Route::get('/create', ['as' => 'create', 'uses' => 'RumahSakitController@create']); Route::get('/update/{rumah_sakit_id}', ['as' => 'update', 'uses' => 'RumahSakitController@update']); Route::get('/delete-action/{rumah_sakit_id}', ['as' => 'delete_action', 'uses' => 'RumahSakitController@delete_action']); Route::get('/get-data', ['as' => 'get_data', 'uses' => 'RumahSakitController@getData']); Route::get('/select_jenis_rs', ['as' => 'select_jenis_rs', 'uses' => 'RumahSakitController@selectJenisRs']); Route::get('/select_jenis_kepemilikan', ['as' => 'select_jenis_kepemilikan', 'uses' => 'RumahSakitController@selectKepemilikanRs']); Route::post('/create-action', ['as' => 'create_action', 'uses' => 'RumahSakitController@create_action']); Route::post('/update-action', ['as' => 'update_action', 'uses' => 'RumahSakitController@update_action']); }); } //end custom route }