mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-11-04 08:17:32 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			87 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/**
 | 
						|
 * Invoice Ninja (https://invoiceninja.com).
 | 
						|
 *
 | 
						|
 * @link https://github.com/invoiceninja/invoiceninja source repository
 | 
						|
 *
 | 
						|
 * @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
 | 
						|
 *
 | 
						|
 * @license https://www.elastic.co/licensing/elastic-license
 | 
						|
 */
 | 
						|
 | 
						|
namespace App\Services\Client;
 | 
						|
 | 
						|
use App\Models\Client;
 | 
						|
use App\Services\Client\PaymentMethod;
 | 
						|
use App\Utils\Number;
 | 
						|
use Illuminate\Database\Eloquent\Collection;
 | 
						|
 | 
						|
class ClientService
 | 
						|
{
 | 
						|
    private $client;
 | 
						|
 | 
						|
    public function __construct(Client $client)
 | 
						|
    {
 | 
						|
        $this->client = $client;
 | 
						|
    }
 | 
						|
 | 
						|
    public function updateBalance(float $amount)
 | 
						|
    {
 | 
						|
        $this->client->balance += $amount;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    public function updatePaidToDate(float $amount)
 | 
						|
    {
 | 
						|
        $this->client->paid_to_date += $amount;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    public function adjustCreditBalance(float $amount)
 | 
						|
    {
 | 
						|
        $this->client->credit_balance += $amount;
 | 
						|
 | 
						|
        return $this;
 | 
						|
    }
 | 
						|
 | 
						|
    public function getCreditBalance() :float
 | 
						|
    {
 | 
						|
        $credits = $this->client->credits()
 | 
						|
                      ->where('is_deleted', false)
 | 
						|
                      ->where('balance', '>', 0)
 | 
						|
                      ->where(function ($query){
 | 
						|
                            $query->whereDate('due_date', '<=', now()->format('Y-m-d'))
 | 
						|
                                  ->orWhereNull('due_date');
 | 
						|
                      })
 | 
						|
                      ->orderBy('created_at','ASC');
 | 
						|
 | 
						|
        return Number::roundValue($credits->sum('balance'), $this->client->currency()->precision);
 | 
						|
    }
 | 
						|
 | 
						|
    public function getCredits() 
 | 
						|
    {
 | 
						|
        return $this->client->credits()
 | 
						|
                  ->where('is_deleted', false)
 | 
						|
                  ->where('balance', '>', 0)
 | 
						|
                  ->where(function ($query){
 | 
						|
                        $query->whereDate('due_date', '<=', now()->format('Y-m-d'))
 | 
						|
                              ->orWhereNull('due_date');
 | 
						|
                  })
 | 
						|
                  ->orderBy('created_at','ASC')->get();
 | 
						|
    }
 | 
						|
 | 
						|
    public function getPaymentMethods(float $amount)
 | 
						|
    {
 | 
						|
        return (new PaymentMethod($this->client, $amount))->run();
 | 
						|
    }
 | 
						|
 | 
						|
    public function save() :Client
 | 
						|
    {
 | 
						|
        $this->client->save();
 | 
						|
 | 
						|
        return $this->client;
 | 
						|
    }
 | 
						|
}
 |