pelunsan piutang full

This commit is contained in:
2024-08-02 09:19:39 +07:00
parent 7f9359656d
commit 569d4e242b
7 changed files with 156 additions and 8 deletions

View File

@@ -0,0 +1,12 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class BayarNonRegister extends Model
{
use HasFactory;
public $timestamps = false;
}

13
app/Models/BayarRajal.php Normal file
View File

@@ -0,0 +1,13 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class BayarRajal extends Model
{
use HasFactory;
public $timestamps = false;
protected $table = 't_bayarranap';
}

13
app/Models/BayarRanap.php Normal file
View File

@@ -0,0 +1,13 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class BayarRanap extends Model
{
use HasFactory;
public $timestamps = false;
protected $table = 't_bayarranap';
}

View File

@@ -0,0 +1,13 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class MaxNomerBayar extends Model
{
use HasFactory;
public $timestamps = false;
protected $table = 'm_maxnobyr';
}

View File

@@ -0,0 +1,12 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class PelunasanPiutang extends Model
{
use HasFactory;
protected $table = 't_pelunasan_piutang';
}

13
app/Models/Piutang.php Normal file
View File

@@ -0,0 +1,13 @@
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class Piutang extends Model
{
use HasFactory;
public $timestamps = false;
protected $table = 't_piutang';
}

View File

@@ -1,4 +1,5 @@
<?php
/**
* Created by PhpStorm.
* User: USER
@@ -8,10 +9,13 @@
namespace App\Services\Va\v1;
use App\Models\BayarRanap;
use App\Models\MaxNomerBayar;
use App\Models\PaymentJatimLogs;
use App\Models\PaymentVirtualAccount;
use App\Models\PaymentVirtualAccountDetail;
use App\Models\PelunasanPiutang;
use App\Models\Piutang;
use App\Models\Va\v1\VirtualAccountJatimRequest;
use App\Models\Va\v1\VirtualAccountJatimResponse;
use GuzzleHttp\Client;
@@ -48,7 +52,7 @@ class VirtualAccountJatimService
public function updatePayment(VirtualAccountJatimRequest $data, VirtualAccountJatimResponse $result)
{
DB::beginTransaction();
try{
try {
$pembayaran = PaymentVirtualAccount::where('virtual_account', $data->getVirtualAccount())->first();
if (!$pembayaran) {
$result->setStatus(array(
@@ -65,6 +69,54 @@ class VirtualAccountJatimService
));
} else {
if ($pembayaran->endpoint == "full") {
if ($pembayaran->type == 'piutang') {
$piutang = Piutang::where('nobilling', $pembayaran->billnumber)->get();
if (count($piutang) > 0) {
$date_now = date('Y-m-d');
foreach ($piutang as $item) {
$no_kwitansi = $this->lastNoBayar($item->nip, $date_now, $item->shift);
$pelunasan['id_piutang'] = $item->id_piutang;
$pelunasan['tgl_pelunasan'] = $date_now;
$pelunasan['jumlah_piutang'] = $item->jumlah_bayar;
$pelunasan['jumlah_bayar'] = $item->jumlah_bayar;
$pelunasan['no_kwitansi'] = $no_kwitansi;
$pelunasan['tgl_entri'] = $date_now;
$pelunasan['petugas_entri'] = $item->nip;
$pelunasan['shift'] = $item->shift;
$save = PelunasanPiutang::insert($pelunasan);
//update status lunas di piutang
$lunas = Piutang::where('id_piutang', $item->id_piutang)->update(['st_piutang' => 'LUNAS']);
$data_piutang = Piutang::where('id_piutang', $item->id_piutang)->first();
if (!empty($data_piutang)) {
$payload['lunas'] = 1;
$payload['status'] = 'LUNAS';
$payload['jmbayar'] = $item->jumlah_bayar;
$payload['tglbayar'] = $date_now;
$payload['jambayar'] = date('H:i:s');
$payload['nobayar'] = $no_kwitansi;
$payload['nip'] = $item->nip;
$payload['shift'] = $item->shift;
if ($data_piutang['st_billing'] == 'IRNA') {
$update_bayar = BayarRanap::where('idxbill', $data_piutang->idxbill)->update($payload);
} else if ($data_piutang['st_billing'] == 'IRNA') {
$update_bayar = BayarRanap::where('idxbill', $data_piutang->idxbill)->update($payload);
} else {
$update_bayar = BayarRanap::where('idxbill', $data_piutang->idxbill)->update($payload);
}
$arr_max['nomor'] = $no_kwitansi;
$arr_max['type'] = 'kuitansi';
$arr_max['petugas'] = $item->nip;
$arr_max['tanggal'] = $date_now;
$arr_max['shift'] = $item->shift;
$update_max = MaxNomerBayar::where(['type' => 'kuitansi', 'petugas' => $item->nip, 'tanggal' => $date_now, 'shift' => $item->shift])->update($arr_max);
}
}
}
}
$pembayaran->bayar = $data->getAmount();
$pembayaran->flags_lunas = "F";
$pembayaran->save();
@@ -89,9 +141,9 @@ class VirtualAccountJatimService
$pembayaran->flags_lunas = ($pembayaran->bayar == $pembayaran->totalamount) ? "F" : "O";
$pembayaran->save();
if (empty($pembayaran->bayar)){
if (empty($pembayaran->bayar)) {
$detail_sisa = $pembayaran->totalamount - $data->getAmount();
}else{
} else {
$detail_sisa = $pembayaran->totalamount - $pembayaran->bayar;
}
@@ -107,14 +159,13 @@ class VirtualAccountJatimService
}
}
}
}
DB::commit();
}catch (\Exception $e){
} catch (\Exception $e) {
dd($e);
DB::rollback();
}
return $result;
}
public function log($type, $request, $response)
@@ -126,4 +177,25 @@ class VirtualAccountJatimService
]);
return $log;
}
}
function lastNoBayar($petugas, $tanggal, $shift)
{
$kwitansi = MaxNomerBayar::where(['type' => 'kwitansi', 'petugas' => $petugas, 'tanggal' => $tanggal, 'shift' => $shift])->first();
$pre_no = $lastNoBayar = $xLastNoBayar = null;
$pre_no = date('Y');
if (isset($kwitansi)) {
$lastNoBayar = ((int)$kwitansi->nomor) + 1;
$xLastNoBayar = str_pad($lastNoBayar, 7, 0, STR_PAD_LEFT);
return $xLastNoBayar;
} else {
$new_nobayar = '0000001';
$payload['nomor'] = $new_nobayar;
$payload['type'] = 'kuitansi';
$payload['petugas'] = $petugas;
$payload['tanggal'] = $tanggal;
$payload['shift'] = $shift;
$nomor = MaxNomerBayar::insert($payload);
return $new_nobayar;
}
}
}