osb/app/Models/Payment.php

135 lines
2.9 KiB
PHP
Raw Permalink Normal View History

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