'admin.dashboard' private $namespace_controller = 'Admin\User_management'; private $url_prefix = 'user-management/role/'; public function __construct() { // DB::getQueryLog(); // $this->middleware('permission:role-list|role-create|role-update|role-delete', ['only' => ['index', 'create', 'update']]); // $this->middleware('permission:role-create', ['only' => ['create', 'create_action']]); // $this->middleware('permission:role-update', ['only' => ['update', 'update_action']]); // $this->middleware('permission:role-delete', ['only' => ['delete']]); } /** * Ini contoh crud yang sudah jalan * index digunakna untuk tampilan awal dari menu yang akan dibuat * session" itu ambil dari sweetalert langsung jadi udah langsung digunakan * untuk yang index susuannya begitu, kalau mau menambahkan silahkan */ 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, ]; return view($this->route . 'index', $data); } public function getData() { $query = Role::query(); return Datatables::of($query) ->addIndexColumn() ->addColumn('aksi', function ($query) { /**cek role */ $aksi = ''; if (Auth::user()->can('role-update')) { $aksi .= " Hashids::encode($query->id)]) . "' class='btn btn-sm btn-primary btn-edit'>Edit"; } if (Auth::user()->can('role-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() { /**set permission dengan cara dibagi 4 - 4 */ $permission = Helper::get_permission_by_role(); // if() $jumlah_permission = $permission->count(); $limit = 4; $take = 0; $jumlah_looping = ceil($jumlah_permission / $limit); $arr_permission = []; for ($i = 0; $i < $jumlah_looping; $i++) { // $cek_limit[] = $limit; // $cek_take[] = $take; $limit_data = 4; $permission = Permission::take($limit_data)->skip($take)->get(); $cek_permission[] = $permission; $arr_permission[$i] = $permission; $take = $limit; $limit += 4; } // dd($arr_permission); /**end set permission */ $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'data' => $arr_permission, ]; 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) { /**digunakan untuk set rule validator */ $cek_permission_id = !empty($request['permission_id']); // dd($cek_permission_id); if ($cek_permission_id) { $rules = [ 'name' => 'required|min:2|unique:roles,name', ]; /**digunakan untuk set message dari validatornya yang akan keluar gimna, :attribue itu udah langsung mendeteksi inputtan dari name="attribue" */ $alert = [ 'required' => 'The :attribute is required', 'min' => ':attribute Min 2 Char' ]; $validator = Validator::make($request->all(), $rules, $alert); if ($validator->passes()) { /**menggunakan transaction */ DB::beginTransaction(); $insert_role = Role::create($request->only('name')); $data_has_role = []; foreach ($request['permission_id'] as $key => $value) { $data_has_role[] = [ 'permission_id' => $value, 'role_id' => $insert_role->id, ]; } $insert_has_role = RoleHasPermission::insert($data_has_role); if ($insert_role && $insert_has_role) { 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(); } $message = 'Please filled the permission least one'; return redirect()->back()->with('error', $message)->withInput(); } /** update sama seperti create hanya saja digunakan untuk update (viewnya saja) */ public function update($role_id) { if (session('success')) { alert()->html('', session('success'), 'success'); } if (session('error')) { alert()->html('', session('error'), 'error'); } $role_id = Hashids::decode($role_id); if (!empty($role_id)) { $cek_role = Role::where('id', $role_id[0])->first(); /**set permission dengan cara dibagi 4 - 4 */ $permission = Permission::get(); $jumlah_permission = $permission->count(); $limit = 4; $take = 0; $jumlah_looping = ceil($jumlah_permission / $limit); $arr_permission = []; for ($i = 0; $i < $jumlah_looping; $i++) { // $cek_limit[] = $limit; // $cek_take[] = $take; $limit_data = 4; $permission = Permission::take($limit_data)->skip($take)->get(); $cek_permission[] = $permission; $arr_permission[$i] = $permission; $take = $limit; $limit += 4; } /**end set permission */ /**menambahkan object permission di dalam role, digunakan untuk cek diviewnya nanti permissionnya mana aja yang dipilih */ $cek_role->permission = RoleHasPermission::where('role_id', $cek_role->id) ->get() ->pluck('permission_id') ->toArray(); if ($cek_role) { $data = [ //bawaan 'title' => $this->title, 'route' => $this->route, 'data' => $cek_role, 'permission' => $arr_permission, ]; return view($this->route . 'update', $data); } $message = 'Id role not found or has been deleted'; 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 role_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) { $rules = [ 'name' => 'required|min:2', ]; $alert = [ 'required' => 'The :attribute is required', 'min' => ':attribute Min 2 Char' ]; $validator = Validator::make($request->all(), $rules, $alert); $role_id = Hashids::decode($request['id']); $cek_permission_id = !empty($request['permission_id']); if ($cek_permission_id) { if (!empty($role_id)) { /**cek apakah role_idnya ada ? */ $cek_role = Role::where('id', $role_id[0])->first(); if ($cek_role) { /**cek apakah id rolenya benar" ada di DB ? */ if ($validator->passes()) { /**validatornya */ DB::beginTransaction(); $update_role = $cek_role->update($request->only('name')); /**delete has role dlu */ RoleHasPermission::where('role_id', $cek_role->id)->delete(); /**proses input has role */ $data_has_role = []; foreach ($request['permission_id'] as $key => $value) { $data_has_role[] = [ 'permission_id' => $value, 'role_id' => $cek_role->id ]; } $insert_has_role = RoleHasPermission::insert($data_has_role); if ($update_role && $insert_has_role) { 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); } } $message = 'Permission must be filled least one'; 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($role_id) { $role_id = Hashids::decode($role_id); /**cek role idnya apakah ada ? */ if (!empty($role_id)) { $cek_role = Role::where('id', $role_id[0])->first(); if ($cek_role) { DB::beginTransaction(); $delete = $cek_role->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 di temukan atau sudah di hapus'; $response = [ 'message' => $message, 'status' => false, ]; return response()->json($response); } $message = 'Id tdak ditemukan'; $response = [ 'message' => $message, 'status' => false, ]; 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' => 'RoleController@index']); Route::get('/create', ['as' => 'create', 'uses' => 'RoleController@create']); Route::get('/update/{role_id}', ['as' => 'update', 'uses' => 'RoleController@update']); Route::get('/delete-action/{role_id}', ['as' => 'delete_action', 'uses' => 'RoleController@delete_action']); Route::get('/get-data', ['as' => 'get_data', 'uses' => 'RoleController@getData']); Route::post('/create-action', ['as' => 'create_action', 'uses' => 'RoleController@create_action']); Route::post('/update-action', ['as' => 'update_action', 'uses' => 'RoleController@update_action']); }); } //end custom route }