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