134 lines
3.5 KiB
PHP
134 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Models\Admin;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Hash;
|
|
use App\Models\Setting;
|
|
|
|
class AdminController extends Controller
|
|
{
|
|
public function __construct()
|
|
{
|
|
$this->middleware(['auth', 'role:admin']);
|
|
}
|
|
|
|
/**
|
|
* Menampilkan halaman daftar admin
|
|
*
|
|
* @return \Illuminate\View\View
|
|
*/
|
|
public function index()
|
|
{
|
|
$admins = Admin::all();
|
|
return view('admin', compact('admins'));
|
|
}
|
|
|
|
/**
|
|
* Menampilkan form tambah admin
|
|
*
|
|
* @return \Illuminate\View\View
|
|
*/
|
|
public function create()
|
|
{
|
|
return view('tambah-admin');
|
|
}
|
|
|
|
/**
|
|
* Menyimpan admin baru
|
|
*
|
|
* @param \Illuminate\Http\Request $request
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function store(Request $request)
|
|
{
|
|
$validated = $request->validate([
|
|
'username' => 'required|string|max:255',
|
|
'email' => 'required|string|email|max:255|unique:admins',
|
|
'no_telp' => 'required|string|max:20',
|
|
'alamat' => 'required|string',
|
|
'password' => 'required|string|min:8'
|
|
]);
|
|
|
|
$validated['password'] = Hash::make($validated['password']);
|
|
|
|
Admin::create($validated);
|
|
|
|
return redirect()->route('admin')->with('success', 'Admin berhasil ditambahkan');
|
|
}
|
|
|
|
/**
|
|
* Menampilkan form edit admin
|
|
*
|
|
* @param int $id
|
|
* @return \Illuminate\View\View
|
|
*/
|
|
public function edit($id)
|
|
{
|
|
$admin = Admin::findOrFail($id);
|
|
return view('edit-admin', compact('admin'));
|
|
}
|
|
|
|
/**
|
|
* Update data admin
|
|
*
|
|
* @param \Illuminate\Http\Request $request
|
|
* @param int $id
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function update(Request $request, $id)
|
|
{
|
|
$admin = Admin::findOrFail($id);
|
|
|
|
$validated = $request->validate([
|
|
'username' => 'required|string|max:255',
|
|
'email' => 'required|string|email|max:255|unique:admins,email,' . $id,
|
|
'no_telp' => 'required|string|max:20',
|
|
'alamat' => 'required|string',
|
|
'password' => 'nullable|string|min:8'
|
|
]);
|
|
|
|
if (!empty($validated['password'])) {
|
|
$validated['password'] = Hash::make($validated['password']);
|
|
} else {
|
|
unset($validated['password']);
|
|
}
|
|
|
|
$admin->update($validated);
|
|
|
|
return redirect()->route('admin')->with('success', 'Data admin berhasil diperbarui');
|
|
}
|
|
|
|
/**
|
|
* Menghapus admin
|
|
*
|
|
* @param int $id
|
|
* @return \Illuminate\Http\RedirectResponse
|
|
*/
|
|
public function destroy($id)
|
|
{
|
|
$admin = Admin::findOrFail($id);
|
|
$admin->delete();
|
|
|
|
return redirect()->route('admin')->with('success', 'Admin berhasil dihapus');
|
|
}
|
|
|
|
public function dashboard()
|
|
{
|
|
$nomor_rekening = Setting::where('key', 'nomor_rekening')->first()->value ?? '';
|
|
return view('admin.dashboard', compact('nomor_rekening'));
|
|
}
|
|
|
|
public function saveRekening(Request $request)
|
|
{
|
|
$request->validate([
|
|
'nomor_rekening' => 'required|string|max:100',
|
|
]);
|
|
Setting::updateOrCreate(
|
|
['key' => 'nomor_rekening'],
|
|
['value' => $request->nomor_rekening]
|
|
);
|
|
return redirect()->route('admin.dashboard')->with('success_rekening', 'Nomor rekening berhasil disimpan!');
|
|
}
|
|
}
|