feat-kasmasuk-with-coa-integrate
WMS API/ERP-API/pipeline/head This commit looks good Details

This commit is contained in:
Hegifebrianto 2025-02-14 18:14:35 +07:00
parent b35bca0d71
commit 23e9a6a2f2
3 changed files with 51 additions and 26 deletions

View File

@ -5,75 +5,74 @@ namespace App\Http\Controllers;
use App\Models\KasMasuk;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Auth;
class KasMasukController extends Controller
{
// 1. List All Entries
public function index()
{
$kasMasuk = KasMasuk::with('user')->get();
$kasMasuk = KasMasuk::with(['user', 'coa'])->get();
return response()->json($kasMasuk, 200);
}
public function show($id)
{
$kasMasuk = KasMasuk::with(['user', 'coa'])->find($id);
if (!$kasMasuk) {
return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND);
}
return response()->json($kasMasuk, Response::HTTP_OK);
}
// 2. Create New Entry
public function store(Request $request)
{
$request->validate([
'tanggal' => 'required|date',
'deskripsi' => 'required|string',
'jumlah' => 'required|numeric|min:0',
'coa_id' => 'nullable|exists:coas,id', // Validasi COA
]);
$kasMasuk = KasMasuk::create([
'user_id' => Auth::id(), // Ambil user yang sedang login
'user_id' => Auth::id(),
'tanggal' => $request->tanggal,
'deskripsi' => $request->deskripsi,
'jumlah' => $request->jumlah,
'coa_id' => $request->coa_id,
]);
return response()->json($kasMasuk, Response::HTTP_CREATED);
return response()->json($kasMasuk, 201);
}
// 3. Show Specific Entry
public function show($id)
{
$kasMasuk = KasMasuk::with('user')->find($id);
if (!$kasMasuk) {
return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND);
}
return response()->json($kasMasuk, Response::HTTP_OK);
}
// 4. Update Entry
public function update(Request $request, $id)
{
$kasMasuk = KasMasuk::find($id);
if (!$kasMasuk) {
return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND);
}
$kasMasuk = KasMasuk::findOrFail($id);
$request->validate([
'tanggal' => 'sometimes|date',
'deskripsi' => 'sometimes|string',
'jumlah' => 'sometimes|numeric|min:0',
'coa_id' => 'nullable|exists:coas,id', // Validasi COA
]);
$kasMasuk->update($request->all());
return response()->json($kasMasuk, Response::HTTP_OK);
return response()->json($kasMasuk, 200);
}
// 5. Delete Entry
public function destroy($id)
{
$kasMasuk = KasMasuk::find($id);
if (!$kasMasuk) {
return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND);
}
$kasMasuk->delete();
return response()->json(['message' => 'Data berhasil dihapus'], Response::HTTP_OK);
}
}

View File

@ -10,7 +10,7 @@ class KasMasuk extends Model
{
use HasFactory;
protected $fillable = ['user_id', 'tanggal', 'deskripsi', 'jumlah'];
protected $fillable = ['user_id', 'tanggal', 'deskripsi', 'jumlah', 'coa_id'];
/**
* Relasi ke user (siapa yang membuat transaksi).
@ -19,5 +19,12 @@ class KasMasuk extends Model
{
return $this->belongsTo(User::class);
}
/**
* Relasi ke COA (Akun Bank).
*/
public function coa(): BelongsTo
{
return $this->belongsTo(Coa::class, 'coa_id');
}
}

View File

@ -4,14 +4,33 @@ namespace Database\Seeders;
use Illuminate\Database\Console\Seeds\WithoutModelEvents;
use Illuminate\Database\Seeder;
use App\Models\KasMasuk;
use App\Models\User;
use App\Models\Coa;
class KasMasukSeeder extends Seeder
{
/**
* Run the database seeds.
*/
public function run(): void
public function run()
{
//
$user = User::first();
if (!$user) {
$user = User::factory()->create(); // Create a test user
}
$coa = Coa::first();
if (!$coa) {
$coa = Coa::factory()->create(); // Create a test COA
}
KasMasuk::create([
'user_id' => $user->id, // Now user_id will never be null
'coa_id' => $coa->id, // Now coa_id will never be null
'tanggal' => now(),
'deskripsi' => 'Pemasukan dari pelanggan',
'jumlah' => 500000.75,
]);
}
}