Fixed Offline Payment method for Customer
This commit is contained in:
67
app/Listeners/Incomes/Invoice/Paid.php
Normal file
67
app/Listeners/Incomes/Invoice/Paid.php
Normal file
@@ -0,0 +1,67 @@
|
||||
<?php
|
||||
|
||||
namespace App\Listeners\Incomes\Invoice;
|
||||
|
||||
use App\Events\InvoicePaid;
|
||||
|
||||
class Paid extends Listener
|
||||
{
|
||||
|
||||
/**
|
||||
* Handle the event.
|
||||
*
|
||||
* @param $event
|
||||
* @return void
|
||||
*/
|
||||
public function handle(InvoicePaid $event)
|
||||
{
|
||||
$invoice = $event->invoice;
|
||||
$request = $event->request;
|
||||
|
||||
$request['invoice_id'] = $invoice->id;
|
||||
$request['account_id'] = setting('general.default_account');
|
||||
|
||||
if (!isset($request['amount'])) {
|
||||
$request['amount'] = $invoice->amount;
|
||||
}
|
||||
|
||||
$request['currency_code'] = $invoice->currency_code;
|
||||
$request['currency_rate'] = $invoice->currency_rate;
|
||||
|
||||
$request['paid_at'] = Date::parse('now')->format('Y-m-d');
|
||||
|
||||
if ($request['amount'] > $invoice->amount) {
|
||||
$message = trans('messages.error.added', ['type' => trans_choice('general.payment', 1)]);
|
||||
|
||||
return response()->json([
|
||||
'success' => false,
|
||||
'error' => $message,
|
||||
]);
|
||||
} elseif ($request['amount'] == $invoice->amount) {
|
||||
$invoice->invoice_status_code = 'paid';
|
||||
} else {
|
||||
$invoice->invoice_status_code = 'partial';
|
||||
}
|
||||
|
||||
$invoice->save();
|
||||
|
||||
InvoicePayment::create($request->input());
|
||||
|
||||
$request['status_code'] = $invoice->invoice_status_code;
|
||||
|
||||
$request['notify'] = 0;
|
||||
|
||||
$desc_date = Date::parse($request['paid_at'])->format($this->getCompanyDateFormat());
|
||||
|
||||
$desc_amount = money((float) $request['amount'], $request['currency_code'], true)->format();
|
||||
|
||||
$request['description'] = $desc_date . ' ' . $desc_amount;
|
||||
|
||||
InvoiceHistory::create($request->input());
|
||||
|
||||
return response()->json([
|
||||
'success' => true,
|
||||
'error' => false,
|
||||
]);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user