feat-kasmasuk-with-coa-integrate
WMS API/ERP-API/pipeline/head This commit looks good
Details
WMS API/ERP-API/pipeline/head This commit looks good
Details
This commit is contained in:
parent
b35bca0d71
commit
23e9a6a2f2
|
|
@ -5,75 +5,74 @@ namespace App\Http\Controllers;
|
||||||
use App\Models\KasMasuk;
|
use App\Models\KasMasuk;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Http\Response;
|
use Illuminate\Http\Response;
|
||||||
use Illuminate\Support\Facades\Auth;
|
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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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,
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue