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

@ -10,70 +10,69 @@ use Illuminate\Support\Facades\Auth;
class KasMasukController extends Controller class KasMasukController extends Controller
{ {
// 1. List All Entries
public function index() 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); return response()->json($kasMasuk, Response::HTTP_OK);
} }
// 2. Create New Entry
public function store(Request $request) public function store(Request $request)
{ {
$request->validate([ $request->validate([
'tanggal' => 'required|date', 'tanggal' => 'required|date',
'deskripsi' => 'required|string', 'deskripsi' => 'required|string',
'jumlah' => 'required|numeric|min:0', 'jumlah' => 'required|numeric|min:0',
'coa_id' => 'nullable|exists:coas,id', // Validasi COA
]); ]);
$kasMasuk = KasMasuk::create([ $kasMasuk = KasMasuk::create([
'user_id' => Auth::id(), // Ambil user yang sedang login 'user_id' => Auth::id(),
'tanggal' => $request->tanggal, 'tanggal' => $request->tanggal,
'deskripsi' => $request->deskripsi, 'deskripsi' => $request->deskripsi,
'jumlah' => $request->jumlah, '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) public function update(Request $request, $id)
{ {
$kasMasuk = KasMasuk::find($id); $kasMasuk = KasMasuk::findOrFail($id);
if (!$kasMasuk) {
return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND);
}
$request->validate([ $request->validate([
'tanggal' => 'sometimes|date', 'tanggal' => 'sometimes|date',
'deskripsi' => 'sometimes|string', 'deskripsi' => 'sometimes|string',
'jumlah' => 'sometimes|numeric|min:0', 'jumlah' => 'sometimes|numeric|min:0',
'coa_id' => 'nullable|exists:coas,id', // Validasi COA
]); ]);
$kasMasuk->update($request->all()); $kasMasuk->update($request->all());
return response()->json($kasMasuk, Response::HTTP_OK); return response()->json($kasMasuk, 200);
} }
// 5. Delete Entry
public function destroy($id) public function destroy($id)
{ {
$kasMasuk = KasMasuk::find($id); $kasMasuk = KasMasuk::find($id);
if (!$kasMasuk) { if (!$kasMasuk) {
return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND); return response()->json(['message' => 'Data tidak ditemukan'], Response::HTTP_NOT_FOUND);
} }
$kasMasuk->delete(); $kasMasuk->delete();
return response()->json(['message' => 'Data berhasil dihapus'], Response::HTTP_OK); return response()->json(['message' => 'Data berhasil dihapus'], Response::HTTP_OK);
} }
} }

View File

@ -10,7 +10,7 @@ class KasMasuk extends Model
{ {
use HasFactory; 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). * Relasi ke user (siapa yang membuat transaksi).
@ -19,5 +19,12 @@ class KasMasuk extends Model
{ {
return $this->belongsTo(User::class); 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\Console\Seeds\WithoutModelEvents;
use Illuminate\Database\Seeder; use Illuminate\Database\Seeder;
use App\Models\KasMasuk;
use App\Models\User;
use App\Models\Coa;
class KasMasukSeeder extends Seeder class KasMasukSeeder extends Seeder
{ {
/** /**
* Run the database seeds. * 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,
]);
} }
} }