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
|
|
@ -10,70 +10,69 @@ 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);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -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');
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -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,
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue