CRUD ruangan
This commit is contained in:
parent
0b96fd767e
commit
98f6829669
|
@ -2,13 +2,56 @@
|
|||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\Jurusan;
|
||||
use App\Models\Kelas;
|
||||
use App\Models\Ruangan;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class RuanganController extends Controller
|
||||
{
|
||||
public function index(){
|
||||
$ruangan = Ruangan::select('id', 'nama_ruangan')->with(['kelas:id,nama_kelas', 'jurusan:id,nama_jurusan'])->get();
|
||||
return view('admin.ruangan', compact('ruangan'));
|
||||
$ruangan = Ruangan::with('jurusan', 'kelas')->get();
|
||||
return view('admin.ruangan.index', compact('ruangan'));
|
||||
}
|
||||
}
|
||||
|
||||
public function create(){
|
||||
$kelas = Kelas::all();
|
||||
$jurusan = Jurusan::all();
|
||||
return view('admin.ruangan.create', compact('kelas', 'jurusan'));
|
||||
}
|
||||
|
||||
public function store(Request $request){
|
||||
$request->validate([
|
||||
'nama_ruangan' => 'required|string|max:255',
|
||||
'id_kelas' => 'required|exists:kelas,id',
|
||||
'id_jurusan' => 'required|exists:jurusan,id',
|
||||
]);
|
||||
|
||||
Ruangan::create($request->all());
|
||||
|
||||
return redirect()->route('admin.ruangan.index')->with('success', 'Data ruangan berhasil ditambahkan');
|
||||
}
|
||||
|
||||
public function edit(Ruangan $ruangan){
|
||||
$kelas = Kelas::all();
|
||||
$jurusan = Jurusan::all();
|
||||
return view('admin.ruangan.edit', compact('ruangan', 'kelas', 'jurusan'));
|
||||
}
|
||||
|
||||
public function update(Request $request, Ruangan $ruangan){
|
||||
$request->validate([
|
||||
'nama_ruangan' => 'required|string|max:255',
|
||||
'id_kelas' => 'required|exists:kelas,id',
|
||||
'id_jurusan' => 'required|exists:jurusan,id',
|
||||
]);
|
||||
|
||||
$ruangan->update($request->all());
|
||||
|
||||
return redirect()->route('admin.ruangan.index')->with('success', 'Data ruangan berhasil diperbarui');
|
||||
}
|
||||
|
||||
public function destroy(Ruangan $ruangan){
|
||||
$ruangan->delete();
|
||||
return redirect()->route('admin.ruangan.index')->with('success', 'Data ruangan berhasil dihapus');
|
||||
}
|
||||
}
|
|
@ -13,8 +13,8 @@ class Ruangan extends Model
|
|||
|
||||
protected $fillable = [
|
||||
'nama_ruangan',
|
||||
'kelas_id',
|
||||
'jurusan_id'
|
||||
'id_kelas',
|
||||
'id_jurusan'
|
||||
];
|
||||
|
||||
/**
|
||||
|
@ -22,7 +22,7 @@ class Ruangan extends Model
|
|||
*/
|
||||
public function kelas()
|
||||
{
|
||||
return $this->belongsTo(Kelas::class, 'kelas_id');
|
||||
return $this->belongsTo(Kelas::class, 'id_kelas');
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -30,7 +30,7 @@ public function kelas()
|
|||
*/
|
||||
public function jurusan()
|
||||
{
|
||||
return $this->belongsTo(Jurusan::class, 'jurusan_id');
|
||||
return $this->belongsTo(Jurusan::class, 'id_jurusan');
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -13,22 +13,22 @@ public function up(): void
|
|||
$table->string('nama_ruangan');
|
||||
|
||||
// Foreign keys
|
||||
$table->foreignId('kelas_id')->constrained('kelas')->onDelete('cascade');
|
||||
$table->foreignId('jurusan_id')->constrained('jurusan')->onDelete('cascade');
|
||||
$table->foreignId('id_kelas')->constrained('kelas')->onDelete('cascade');
|
||||
$table->foreignId('id_jurusan')->constrained('jurusan')->onDelete('cascade');
|
||||
|
||||
$table->timestamps();
|
||||
|
||||
// Tambahkan index untuk pencarian
|
||||
$table->index('nama_ruangan');
|
||||
$table->index(['kelas_id', 'jurusan_id']);
|
||||
$table->index(['id_kelas', 'id_jurusan']);
|
||||
});
|
||||
}
|
||||
|
||||
public function down(): void
|
||||
{
|
||||
Schema::table('ruangan', function (Blueprint $table) {
|
||||
$table->dropForeign(['kelas_id']);
|
||||
$table->dropForeign(['jurusan_id']);
|
||||
$table->dropForeign(['id_kelas']);
|
||||
$table->dropForeign(['id_jurusan']);
|
||||
});
|
||||
|
||||
Schema::dropIfExists('ruangan');
|
||||
|
|
|
@ -49,8 +49,8 @@ class="block p-2 rounded-lg {{ request()->is('admin/kelas/index') ? 'bg-blue-100
|
|||
<li><a href="{{ route('admin.jurusan.index') }}"
|
||||
class="block p-2 rounded-lg {{ request()->is('admin/jurusan/index') ? 'bg-blue-100 text-blue-600' : 'bg-gray-50 text-gray-800' }}">Jurusan</a>
|
||||
</li>
|
||||
<li><a href="{{ route('admin.ruangan') }}"
|
||||
class="block p-2 rounded-lg {{ request()->is('admin/ruangan') ? 'bg-blue-100 text-blue-600' : 'bg-gray-50 text-gray-800' }}">Ruangan</a>
|
||||
<li><a href="{{ route('admin.ruangan.index') }}"
|
||||
class="block p-2 rounded-lg {{ request()->is('admin/ruangan/index') ? 'bg-blue-100 text-blue-600' : 'bg-gray-50 text-gray-800' }}">Ruangan</a>
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
|
|
|
@ -0,0 +1,45 @@
|
|||
@extends('layouts.dashboard')
|
||||
|
||||
@section('title', 'Smart School | Tambah Ruangan')
|
||||
|
||||
@section('content')
|
||||
|
||||
<div class="bg-white shadow-md rounded-lg p-6 max-w-xl mx-auto">
|
||||
<h1 class="text-2xl font-semibold mb-4">Tambah Ruangan</h1>
|
||||
|
||||
<form action="{{ route('admin.ruangan.store') }}" method="POST">
|
||||
@csrf
|
||||
|
||||
<div class="mb-4">
|
||||
<label for="nama_ruangan" class="block font-medium">Nama Ruangan</label>
|
||||
<input type="text" name="nama_ruangan" id="nama_ruangan" class="w-full border px-4 py-2 rounded-lg" required value="{{ old('nama_ruangan') }}">
|
||||
</div>
|
||||
|
||||
<div class="mb-4">
|
||||
<label for="id_kelas" class="block font-medium">Kelas</label>
|
||||
<select name="id_kelas" id="id_kelas" class="w-full border px-4 py-2 rounded-lg" required>
|
||||
<option value="">-- Pilih Kelas --</option>
|
||||
@foreach ($kelas as $k)
|
||||
<option value="{{ $k->id }}" {{ old('id_kelas') == $k->id ? 'selected' : '' }}>{{ $k->nama_kelas }}</option>
|
||||
@endforeach
|
||||
</select>
|
||||
</div>
|
||||
|
||||
<div class="mb-4">
|
||||
<label for="id_jurusan" class="block font-medium">Jurusan</label>
|
||||
<select name="id_jurusan" id="id_jurusan" class="w-full border px-4 py-2 rounded-lg" required>
|
||||
<option value="">-- Pilih Jurusan --</option>
|
||||
@foreach ($jurusan as $j)
|
||||
<option value="{{ $j->id }}" {{ old('id_jurusan') == $j->id ? 'selected' : '' }}>{{ $j->nama_jurusan }}</option>
|
||||
@endforeach
|
||||
</select>
|
||||
</div>
|
||||
|
||||
<div class="flex justify-end">
|
||||
<a href="{{ route('admin.ruangan.index') }}" class="mr-2 px-4 py-2 bg-gray-300 rounded-lg">Batal</a>
|
||||
<button type="submit" class="bg-blue-500 hover:bg-blue-600 text-white px-4 py-2 rounded-lg">Simpan</button>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
|
||||
@endsection
|
|
@ -0,0 +1,46 @@
|
|||
@extends('layouts.dashboard')
|
||||
|
||||
@section('title', 'Smart School | Edit Ruangan')
|
||||
|
||||
@section('content')
|
||||
|
||||
<div class="bg-white shadow-md rounded-lg p-6 max-w-xl mx-auto">
|
||||
<h1 class="text-2xl font-semibold mb-4">Edit Ruangan</h1>
|
||||
|
||||
<form action="{{ route('admin.ruangan.update', $ruangan->id) }}" method="POST">
|
||||
@csrf
|
||||
@method('PUT')
|
||||
|
||||
<div class="mb-4">
|
||||
<label for="nama_ruangan" class="block font-medium">Nama Ruangan</label>
|
||||
<input type="text" name="nama_ruangan" id="nama_ruangan" class="w-full border px-4 py-2 rounded-lg" value="{{ old('nama_ruangan', $ruangan->nama_ruangan) }}" required>
|
||||
</div>
|
||||
|
||||
<div class="mb-4">
|
||||
<label for="kelas_id" class="block font-medium">Kelas</label>
|
||||
<select name="kelas_id" id="kelas_id" class="w-full border px-4 py-2 rounded-lg" required>
|
||||
<option value="">-- Pilih Kelas --</option>
|
||||
@foreach ($kelas as $k)
|
||||
<option value="{{ $k->id }}" {{ $ruangan->kelas_id == $k->id ? 'selected' : '' }}>{{ $k->nama_kelas }}</option>
|
||||
@endforeach
|
||||
</select>
|
||||
</div>
|
||||
|
||||
<div class="mb-4">
|
||||
<label for="jurusan_id" class="block font-medium">Jurusan</label>
|
||||
<select name="jurusan_id" id="jurusan_id" class="w-full border px-4 py-2 rounded-lg" required>
|
||||
<option value="">-- Pilih Jurusan --</option>
|
||||
@foreach ($jurusan as $j)
|
||||
<option value="{{ $j->id }}" {{ $ruangan->jurusan_id == $j->id ? 'selected' : '' }}>{{ $j->nama_jurusan }}</option>
|
||||
@endforeach
|
||||
</select>
|
||||
</div>
|
||||
|
||||
<div class="flex justify-end">
|
||||
<a href="{{ route('admin.ruangan.index') }}" class="mr-2 px-4 py-2 bg-gray-300 rounded-lg">Batal</a>
|
||||
<button type="submit" class="bg-blue-500 hover:bg-blue-600 text-white px-4 py-2 rounded-lg">Update</button>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
|
||||
@endsection
|
|
@ -7,7 +7,7 @@
|
|||
<div class="bg-white shadow-md rounded-lg p-6">
|
||||
<div class="flex justify-between items-center mb-4">
|
||||
<h1 class="text-2xl font-semibold">Data Ruangan</h1>
|
||||
<a href="{{ route('siswa.create') }}" class="bg-blue-500 hover:bg-blue-600 text-white px-4 py-2 rounded-lg">
|
||||
<a href="{{ route('admin.ruangan.create') }}" class="bg-blue-500 hover:bg-blue-600 text-white px-4 py-2 rounded-lg">
|
||||
+ Tambah Ruangan
|
||||
</a>
|
||||
</div>
|
||||
|
@ -18,8 +18,8 @@
|
|||
<tr class="text-left text-gray-700">
|
||||
<th class="border px-4 py-2">No</th>
|
||||
<th class="border px-4 py-2">Nama Ruangan</th>
|
||||
<th class="border px-4 py-2">Nama Kelas</th>
|
||||
<th class="border px-4 py-2">Nama Jurusan</th>
|
||||
<th class="border px-4 py-2">Kelas</th>
|
||||
<th class="border px-4 py-2">Jurusan</th>
|
||||
<th class="border px-4 py-2 text-center">Aksi</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
@ -28,11 +28,11 @@
|
|||
<tr class="border hover:bg-gray-50">
|
||||
<td class="border px-4 py-2">{{ $index + 1 }}</td>
|
||||
<td class="border px-4 py-2">{{ $item->nama_ruangan }}</td>
|
||||
<td class="border px-4 py-2">{{ $item->nama_kelas }}</td>
|
||||
<td class="border px-4 py-2">{{ $item->nama_jurusan }}</td>
|
||||
<td class="border px-4 py-2">{{ $item->kelas->nama_kelas ?? '-' }}</td>
|
||||
<td class="border px-4 py-2">{{ $item->jurusan->nama_jurusan ?? '-' }}</td>
|
||||
<td class="border px-4 py-2 text-center">
|
||||
<a href="{{ route('kelas.edit', $item->id) }}" class="bg-yellow-400 hover:bg-yellow-500 text-white px-3 py-1 rounded">Edit</a>
|
||||
<form action="{{ route('kelas.destroy', $item->id) }}" method="POST" class="inline-block">
|
||||
<a href="{{ route('admin.ruangan.edit', $item->id) }}" class="bg-yellow-400 hover:bg-yellow-500 text-white px-3 py-1 rounded">Edit</a>
|
||||
<form action="{{ route('admin.ruangan.destroy', $item->id) }}" method="POST" class="inline-block">
|
||||
@csrf
|
||||
@method('DELETE')
|
||||
<button type="submit" onclick="return confirm('Yakin ingin menghapus?')" class="bg-red-500 hover:bg-red-600 text-white px-3 py-1 rounded">
|
||||
|
@ -47,4 +47,4 @@
|
|||
</div>
|
||||
</div>
|
||||
|
||||
@endsection
|
||||
@endsection
|
|
@ -65,8 +65,14 @@
|
|||
'destroy' => 'admin.jurusan.destroy',
|
||||
]);
|
||||
// Ruangan
|
||||
Route::get('/ruangan', [RuanganController::class, 'index'])->name('admin.ruangan');
|
||||
|
||||
Route::resource('ruangan', RuanganController::class)->names([
|
||||
'index' => 'admin.ruangan.index',
|
||||
'create' => 'admin.ruangan.create',
|
||||
'store' => 'admin.ruangan.store',
|
||||
'edit' => 'admin.ruangan.edit',
|
||||
'update' => 'admin.ruangan.update',
|
||||
'destroy' => 'admin.ruangan.destroy',
|
||||
]);
|
||||
// Presensi
|
||||
Route::controller(PresensiController::class)->group(function () {
|
||||
Route::get('/presensi/siswa', 'indexSiswa')->name('admin.presensi.siswa');
|
||||
|
|
Loading…
Reference in New Issue