2018-05-20 22:53:14 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models;
|
|
|
|
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
2021-07-23 17:25:26 +10:00
|
|
|
use Illuminate\Support\Facades\DB;
|
|
|
|
use Leenooks\Traits\ScopeActive;
|
2021-10-01 14:59:04 +10:00
|
|
|
|
|
|
|
use App\Interfaces\IDs;
|
2024-08-10 10:14:47 +10:00
|
|
|
use App\Traits\{ProviderRef,PushNew,SiteID};
|
2019-06-07 16:54:27 +10:00
|
|
|
|
2021-06-29 16:36:34 +10:00
|
|
|
/**
|
|
|
|
* Class Payment
|
|
|
|
* Payments that belong to an account
|
|
|
|
*
|
|
|
|
* Attributes for payments:
|
|
|
|
* + lid : Local ID for payment
|
2022-06-13 15:46:38 +10:00
|
|
|
* + paid_at : Date payment received
|
2021-06-29 16:36:34 +10:00
|
|
|
* + sid : System ID for payment
|
|
|
|
* + total : Payment total
|
2021-07-23 17:25:26 +10:00
|
|
|
* + balance : Remaining credit on payment
|
2021-06-29 16:36:34 +10:00
|
|
|
*
|
|
|
|
* @package App\Models
|
|
|
|
*/
|
|
|
|
class Payment extends Model implements IDs
|
2018-05-20 22:53:14 +10:00
|
|
|
{
|
2024-08-10 10:14:47 +10:00
|
|
|
use PushNew,ScopeActive,ProviderRef,SiteID;
|
2019-06-07 16:54:27 +10:00
|
|
|
|
2024-07-04 15:03:11 +10:00
|
|
|
protected $casts = [
|
|
|
|
'paid_at'=>'datetime:Y-m-d',
|
2022-04-22 15:23:08 +10:00
|
|
|
];
|
2018-05-20 22:53:14 +10:00
|
|
|
|
2020-07-27 14:49:59 +10:00
|
|
|
// Array of items that can be updated with PushNew
|
|
|
|
protected $pushable = ['items'];
|
|
|
|
|
2021-07-23 17:25:26 +10:00
|
|
|
// Any balance below this we'll assume its all used.
|
|
|
|
private const threshold = 0.05;
|
|
|
|
|
2022-05-12 09:09:49 +10:00
|
|
|
/* INTERFACES */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Payment Local ID
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getLIDattribute(): string
|
|
|
|
{
|
|
|
|
return sprintf('%06s',$this->id);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Payment System ID
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getSIDAttribute(): string
|
|
|
|
{
|
|
|
|
return sprintf('%02s-%04s#%s',$this->site_id,$this->account_id,$this->getLIDattribute());
|
|
|
|
}
|
|
|
|
|
2021-06-29 16:36:34 +10:00
|
|
|
/* RELATIONS */
|
|
|
|
|
2018-06-19 22:31:49 +10:00
|
|
|
public function account()
|
|
|
|
{
|
2018-07-13 14:53:44 +10:00
|
|
|
return $this->belongsTo(Account::class);
|
2018-06-19 22:31:49 +10:00
|
|
|
}
|
|
|
|
|
2021-07-23 17:25:26 +10:00
|
|
|
public function checkout()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Checkout::class);
|
|
|
|
}
|
|
|
|
|
2018-06-19 22:31:49 +10:00
|
|
|
public function items()
|
|
|
|
{
|
|
|
|
return $this->hasMany(PaymentItem::class);
|
|
|
|
}
|
|
|
|
|
2023-05-13 21:20:56 +10:00
|
|
|
public function providers()
|
|
|
|
{
|
|
|
|
return $this->belongsToMany(ProviderOauth::class,'payment__provider')
|
|
|
|
->where('payment__provider.site_id',$this->site_id)
|
|
|
|
->withPivot('ref','synctoken','created_at','updated_at');
|
|
|
|
}
|
|
|
|
|
2021-07-23 17:25:26 +10:00
|
|
|
/* SCOPES */
|
2021-06-29 16:36:34 +10:00
|
|
|
|
|
|
|
/**
|
2021-07-23 17:25:26 +10:00
|
|
|
* Search for a record
|
|
|
|
*
|
|
|
|
* @param $query
|
|
|
|
* @param string $term
|
2021-06-29 16:36:34 +10:00
|
|
|
* @return mixed
|
|
|
|
*/
|
2021-07-23 17:25:26 +10:00
|
|
|
public function scopeSearch($query,string $term)
|
|
|
|
{
|
|
|
|
// Build our where clause
|
|
|
|
$query->where('id','like','%'.$term.'%');
|
|
|
|
|
|
|
|
return $query;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function scopeUnapplied($query)
|
|
|
|
{
|
|
|
|
return $query
|
2022-06-13 18:01:29 +10:00
|
|
|
->select(['payments.id','paid_at','account_id','checkout_id','total_amt',DB::raw("SUM(ABS(amount)) as allocated")])
|
2021-07-29 13:11:14 +10:00
|
|
|
->leftJoin('payment_items',['payment_items.payment_id'=>'payments.id'])
|
2022-06-13 15:46:38 +10:00
|
|
|
->groupBy(['payments.id','paid_at','total_amt','account_id','checkout_id'])
|
2024-08-10 10:14:47 +10:00
|
|
|
->having(DB::raw('ROUND(CAST(total_amt-COALESCE(SUM(ABS(amount)),0) AS NUMERIC),2)'),'>',self::threshold);
|
2021-07-23 17:25:26 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ATTRIBUTES */
|
|
|
|
|
2022-05-12 09:09:49 +10:00
|
|
|
/**
|
|
|
|
* Work out the remaining amount from this payment that has not been allocated.
|
|
|
|
*
|
|
|
|
* @return float
|
|
|
|
*/
|
2021-07-23 17:25:26 +10:00
|
|
|
public function getBalanceAttribute(): float
|
2018-05-20 22:53:14 +10:00
|
|
|
{
|
2022-04-22 15:23:08 +10:00
|
|
|
$balance = $this->getTotalAttribute()-$this->items->sum('amount');
|
2021-07-23 17:25:26 +10:00
|
|
|
|
|
|
|
return ($balance < self::threshold) ? 0 : $balance;
|
2018-05-20 22:53:14 +10:00
|
|
|
}
|
2018-06-19 22:31:49 +10:00
|
|
|
|
2021-06-29 16:36:34 +10:00
|
|
|
/**
|
2022-05-12 09:09:49 +10:00
|
|
|
* The total of the payment.
|
2021-06-29 16:36:34 +10:00
|
|
|
*
|
2022-05-12 09:09:49 +10:00
|
|
|
* @return float
|
|
|
|
* @todo Change the DB column to total
|
2021-06-29 16:36:34 +10:00
|
|
|
*/
|
2021-07-23 17:25:26 +10:00
|
|
|
public function getTotalAttribute(): float
|
2018-06-19 22:31:49 +10:00
|
|
|
{
|
2021-07-23 17:25:26 +10:00
|
|
|
return sprintf('%3.2f',$this->total_amt);
|
2018-06-19 22:31:49 +10:00
|
|
|
}
|
2018-05-20 22:53:14 +10:00
|
|
|
}
|