Menerapkan sistem model, migrasi dan seeder
This commit is contained in:
parent
c0a3a693da
commit
a0ab44bdb4
|
@ -1,32 +1,19 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace App\Http\Controllers;
|
namespace App\Http\Controllers;
|
||||||
|
|
||||||
|
use App\Models\Karyawan;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Support\Facades\Cache;
|
|
||||||
|
|
||||||
class KaryawanController extends Controller
|
class KaryawanController extends Controller
|
||||||
{
|
{
|
||||||
// public function init()
|
|
||||||
// {
|
|
||||||
// $karyawan = [
|
|
||||||
// 1 => ['nama' => 'Budi', 'umur' => 20, 'jabatan' => 'Manager'],
|
|
||||||
// 2 => ['nama' => 'Siti', 'umur' => 21, 'jabatan' => 'Staff'],
|
|
||||||
// 3 => ['nama' => 'Andi', 'umur' => 22, 'jabatan' => 'Staff'],
|
|
||||||
// 4 => ['nama' => 'Caca', 'umur' => 23, 'jabatan' => 'Staff'],
|
|
||||||
// 5 => ['nama' => 'Rudy', 'umur' => 24, 'jabatan' => 'Staff'],
|
|
||||||
// ];
|
|
||||||
|
|
||||||
// Cache::put('karyawan', $karyawan, now()->addMinutes(60));
|
|
||||||
// return 'Data karyawan berhasil dimasukkan ke cache';
|
|
||||||
// }
|
|
||||||
|
|
||||||
public function index()
|
public function index()
|
||||||
{
|
{
|
||||||
$karyawan = Cache::get('karyawan', []);
|
$karyawan = Karyawan::all();
|
||||||
return view('karyawan.index', compact('karyawan'));
|
return view('karyawan.index', compact('karyawan'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function create()
|
public function create()
|
||||||
{
|
{
|
||||||
return view('karyawan.create');
|
return view('karyawan.create');
|
||||||
}
|
}
|
||||||
|
@ -39,43 +26,27 @@ class KaryawanController extends Controller
|
||||||
'jabatan' => 'required',
|
'jabatan' => 'required',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$karyawanBaru = [
|
Karyawan::create([
|
||||||
'nama' => $request->nama,
|
'nama' => $request->nama,
|
||||||
'umur' => $request->umur,
|
'umur' => $request->umur,
|
||||||
'jabatan' => $request->jabatan,
|
'jabatan' => $request->jabatan,
|
||||||
];
|
]);
|
||||||
|
|
||||||
$karyawan = Cache::get('karyawan', []);
|
|
||||||
$karyawan[] = $karyawanBaru;
|
|
||||||
Cache::put('karyawan', $karyawan, now()->addMinutes(60));
|
|
||||||
|
|
||||||
return redirect()->route('karyawan.index')->with('success', 'Data berhasil ditambahkan!');
|
return redirect()->route('karyawan.index')->with('success', 'Data berhasil ditambahkan!');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function show($id)
|
public function show($id)
|
||||||
{
|
{
|
||||||
$karyawan = Cache::get('karyawan', []);
|
$karyawan = Karyawan::findOrFail($id);
|
||||||
$data = $karyawan[$id] ?? null;
|
return view('karyawan.show', compact('karyawan'));
|
||||||
|
|
||||||
if (!$data) {
|
|
||||||
abort(404, 'Karyawan tidak ditemukan');
|
|
||||||
}
|
|
||||||
return view('karyawan.show', compact('data'));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function edit($id)
|
public function edit($id)
|
||||||
{
|
{
|
||||||
$karyawan = Cache::get('karyawan', []);
|
$karyawan = Karyawan::findOrFail($id);
|
||||||
if (!isset($karyawan[$id])) {
|
return view('karyawan.edit', compact('karyawan', 'id'));
|
||||||
return redirect()->route('karyawan.index')->with('error', 'Data tidak ditemukan');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$data = $karyawan[$id];
|
|
||||||
|
|
||||||
return view('karyawan.edit', compact('data', 'id'));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public function update(Request $request, $id)
|
public function update(Request $request, $id)
|
||||||
{
|
{
|
||||||
$request->validate([
|
$request->validate([
|
||||||
|
@ -84,35 +55,21 @@ class KaryawanController extends Controller
|
||||||
'jabatan' => 'required',
|
'jabatan' => 'required',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$karyawan = Cache::get('karyawan', []);
|
$karyawan = Karyawan::findOrFail($id);
|
||||||
if (!isset($karyawan[$id])) return redirect()->route('karyawan.index')->with('error', 'Data tidak ditemukan');
|
$karyawan->update([
|
||||||
|
|
||||||
$karyawan[$id] = [
|
|
||||||
'nama' => $request->nama,
|
'nama' => $request->nama,
|
||||||
'umur' => $request->umur,
|
'umur' => $request->umur,
|
||||||
'jabatan' => $request->jabatan,
|
'jabatan' => $request->jabatan,
|
||||||
];
|
]);
|
||||||
|
|
||||||
Cache::put('karyawan', $karyawan, now()->addMinutes(60));
|
|
||||||
|
|
||||||
return redirect()->route('karyawan.index')->with('success', 'Data berhasil diperbarui!');
|
return redirect()->route('karyawan.index')->with('success', 'Data berhasil diperbarui!');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function destroy($id)
|
public function destroy($id)
|
||||||
{
|
{
|
||||||
$karyawan = Cache::get('karyawan', []);
|
$karyawan = Karyawan::findOrFail($id);
|
||||||
|
$karyawan->delete();
|
||||||
|
|
||||||
if (!isset($karyawan[$id])) {
|
return redirect()->route('karyawan.index')->with('success', 'Data berhasil dihapus!');
|
||||||
return redirect()->route('karyawan.index')->with('error', 'Data tidak ditemukan');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
unset($karyawan[$id]);
|
|
||||||
|
|
||||||
// Simpan ulang ke cache di sini
|
|
||||||
Cache::put('karyawan', $karyawan, now()->addMinutes(60));
|
|
||||||
|
|
||||||
return redirect()->route('karyawan.index')->with('success', 'Data berhasil dihapus!');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,10 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
|
||||||
|
class karyawan extends Model
|
||||||
|
{
|
||||||
|
protected $fillable = ['nama', 'umur', 'jabatan'];
|
||||||
|
}
|
|
@ -0,0 +1,30 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('karyawans', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->string('nama');
|
||||||
|
$table->integer('umur');
|
||||||
|
$table->string('jabatan');
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('karyawans');
|
||||||
|
}
|
||||||
|
};
|
|
@ -13,11 +13,10 @@ class DatabaseSeeder extends Seeder
|
||||||
*/
|
*/
|
||||||
public function run(): void
|
public function run(): void
|
||||||
{
|
{
|
||||||
// User::factory(10)->create();
|
|
||||||
|
|
||||||
User::factory()->create([
|
$this->call(KaryawanSeeder::class);
|
||||||
'name' => 'Test User',
|
|
||||||
'email' => 'test@example.com',
|
|
||||||
]);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,33 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Database\Seeders;
|
||||||
|
|
||||||
|
use Illuminate\Database\Console\Seeds\WithoutModelEvents;
|
||||||
|
use Illuminate\Database\Seeder;
|
||||||
|
use App\Models\Karyawan;
|
||||||
|
|
||||||
|
class KaryawanSeeder extends Seeder
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the database seeds.
|
||||||
|
*/
|
||||||
|
public function run(): void
|
||||||
|
{
|
||||||
|
Karyawan::create([
|
||||||
|
'nama' => 'John Doe',
|
||||||
|
'umur' => 30,
|
||||||
|
'jabatan' => 'Manager',
|
||||||
|
]);
|
||||||
|
Karyawan::create([
|
||||||
|
'nama' => 'Ethy Amph la',
|
||||||
|
'umur' => 28,
|
||||||
|
'jabatan' => 'staff',
|
||||||
|
]);
|
||||||
|
Karyawan::create([
|
||||||
|
'nama' => 'Neige Saary',
|
||||||
|
'umur' => 20,
|
||||||
|
'jabatan' => 'staff',
|
||||||
|
]);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -77,24 +77,24 @@
|
||||||
|
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<h1>Edit Data Karyawan</h1>
|
<h1>Edit Data Karyawan</h1>
|
||||||
|
|
||||||
|
<form action="{{ route('karyawan.update', $karyawan->id) }}" method="POST">
|
||||||
|
@csrf
|
||||||
|
@method('PUT')
|
||||||
|
|
||||||
<form action="{{ route('karyawan.update', $id) }}" method="POST">
|
<label>Nama:</label>
|
||||||
@csrf
|
<input type="text" name="nama" value="{{ $karyawan->nama }}" required>
|
||||||
@method('PUT')
|
|
||||||
|
|
||||||
<label>Nama:</label>
|
<label>Umur:</label>
|
||||||
<input type="text" name="nama" value="{{ $data['nama'] }}" required>
|
<input type="number" name="umur" value="{{ $karyawan->umur }}" required>
|
||||||
|
|
||||||
<label>Umur:</label>
|
<label>Jabatan:</label>
|
||||||
<input type="number" name="umur" value="{{ $data['umur'] }}" required>
|
<input type="text" name="jabatan" value="{{ $karyawan->jabatan }}" required>
|
||||||
|
|
||||||
<Label>Jabatan:</label>
|
|
||||||
<input type="text" name="jabatan" value="{{ $data['jabatan'] }}" required>
|
|
||||||
|
|
||||||
<button type="submit" class="button">Update</button>
|
|
||||||
</form>
|
|
||||||
|
|
||||||
|
<button type="submit" class="button">Update</button>
|
||||||
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
|
@ -122,25 +122,25 @@
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
@foreach($karyawan as $id => $item)
|
@foreach ($karyawan as $row)
|
||||||
<tr>
|
<tr>
|
||||||
<td>{{ $loop->iteration }}</td>
|
<td>{{ $row->id }}</td>
|
||||||
<td>{{ $item['nama'] }}</td>
|
<td>{{ $row->nama }}</td>
|
||||||
<td>{{ $item['umur'] }}</td>
|
<td>{{ $row->umur }}</td>
|
||||||
<td>{{ $item['jabatan'] }}</td>
|
<td>{{ $row->jabatan }}</td>
|
||||||
<td>
|
<td>
|
||||||
<a href="{{ route('karyawan.show', $id) }}" class="button-opsi">Lihat</a>
|
<a href="{{ route('karyawan.edit', $row->id) }}" class="button-opsi">Edit</a>
|
||||||
<a href="{{ route('karyawan.edit', $id) }}" class="button-opsi">Edit</a>
|
<!-- <a href="{{ route('karyawan.show', $row->id) }}" class="button-opsi">Lihat</a> -->
|
||||||
<form action="{{ route('karyawan.destroy', $id) }}" method="POST" style="display: inline;">
|
<form action="{{ route('karyawan.destroy', $row->id) }}" method="POST">
|
||||||
@csrf
|
@csrf
|
||||||
@method('DELETE')
|
@method('DELETE')
|
||||||
<button type="submit" class="button-opsi">Hapus</button>
|
<button class="button-opsi" display: inline;>Hapus</button>
|
||||||
</form>
|
</form>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@endforeach
|
@endforeach
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
@else
|
@else
|
||||||
<p>Belum ada data karyawan yang terdaftar.</p>
|
<p>Belum ada data karyawan yang terdaftar.</p>
|
||||||
@endif
|
@endif
|
||||||
|
|
|
@ -70,15 +70,15 @@
|
||||||
<table>
|
<table>
|
||||||
<tr>
|
<tr>
|
||||||
<th>Nama</th>
|
<th>Nama</th>
|
||||||
<td>{{ $data['nama'] }}</td>
|
<td>{{ $karyawan['nama'] }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th>Umur</th>
|
<th>Umur</th>
|
||||||
<td>{{ $data['umur'] }}</td>
|
<td>{{ $karyawan['umur'] }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th>jabatan</th>
|
<th>jabatan</th>
|
||||||
<td>{{ $data['jabatan'] }}</td>
|
<td>{{ $karyawan['jabatan'] }}</td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue