'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
}