mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 08:39:24 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			243 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			243 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Invoice Ninja (https://invoiceninja.com)
 | |
|  *
 | |
|  * @link https://github.com/invoiceninja/invoiceninja source repository
 | |
|  *
 | |
|  * @copyright Copyright (c) 2020. Invoice Ninja LLC (https://invoiceninja.com)
 | |
|  *
 | |
|  * @license https://opensource.org/licenses/AAL
 | |
|  */
 | |
| 
 | |
| namespace App\Services\Invoice;
 | |
| 
 | |
| use App\Models\CompanyGateway;
 | |
| use App\Models\Invoice;
 | |
| use App\Models\Payment;
 | |
| use App\Services\Client\ClientService;
 | |
| use App\Services\Invoice\ApplyNumber;
 | |
| use App\Services\Invoice\ApplyPayment;
 | |
| use App\Services\Invoice\AutoBillInvoice;
 | |
| use App\Services\Invoice\CreateInvitations;
 | |
| use App\Services\Invoice\GetInvoicePdf;
 | |
| use App\Services\Invoice\HandleCancellation;
 | |
| use App\Services\Invoice\HandleReversal;
 | |
| use App\Services\Invoice\MarkInvoicePaid;
 | |
| use App\Services\Invoice\MarkSent;
 | |
| use App\Services\Invoice\TriggeredActions;
 | |
| use App\Services\Invoice\UpdateBalance;
 | |
| use Illuminate\Support\Carbon;
 | |
| 
 | |
| class InvoiceService
 | |
| {
 | |
|     private $invoice;
 | |
| 
 | |
|     protected $client_service;
 | |
| 
 | |
|     public function __construct($invoice)
 | |
|     {
 | |
|         $this->invoice = $invoice;
 | |
| 
 | |
|         $this->client_service = new ClientService($invoice->client);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Marks as invoice as paid
 | |
|      * and executes child sub functions
 | |
|      * @return $this InvoiceService object
 | |
|      */
 | |
|     public function markPaid()
 | |
|     {
 | |
|         $this->invoice = (new MarkPaid($this->client_service, $this->invoice))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Applies the invoice number
 | |
|      * @return $this InvoiceService object
 | |
|      */
 | |
|     public function applyNumber()
 | |
|     {
 | |
|         $this->invoice = (new ApplyNumber($this->invoice->client, $this->invoice))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Apply a payment amount to an invoice.
 | |
|      * @param  Payment $payment        The Payment
 | |
|      * @param  float   $payment_amount The Payment amount
 | |
|      * @return InvoiceService          Parent class object
 | |
|      */
 | |
|     public function applyPayment(Payment $payment, float $payment_amount)
 | |
|     {
 | |
|         $this->invoice = (new ApplyPayment($this->invoice, $payment, $payment_amount))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function addGatewayFee(CompanyGateway $company_gateway, float $amount)
 | |
|     {
 | |
|         $this->invoice = (new AddGatewayFee($company_gateway, $this->invoice, $amount))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
|     /**
 | |
|      * Update an invoice balance
 | |
|      * @param  float $balance_adjustment The amount to adjust the invoice by
 | |
|      * a negative amount will REDUCE the invoice balance, a positive amount will INCREASE
 | |
|      * the invoice balance
 | |
|      * @return InvoiceService                     Parent class object
 | |
|      */
 | |
|     public function updateBalance($balance_adjustment)
 | |
|     {
 | |
|         $this->invoice = (new UpdateBalance($this->invoice, $balance_adjustment))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function createInvitations()
 | |
|     {
 | |
|         $this->invoice = (new CreateInvitations($this->invoice))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function markSent()
 | |
|     {
 | |
|         $this->invoice = (new MarkSent($this->invoice->client, $this->invoice))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function getInvoicePdf($contact = null)
 | |
|     {
 | |
|         return (new GetInvoicePdf($this->invoice, $contact))->run();
 | |
|     }
 | |
| 
 | |
|     public function sendEmail($contact = null)
 | |
|     {
 | |
|         $send_email = new SendEmail($this->invoice, null, $contact);
 | |
| 
 | |
|         return $send_email->run();
 | |
|     }
 | |
| 
 | |
|     public function handleReversal()
 | |
|     {
 | |
|         $this->invoice = (new HandleReversal($this->invoice))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function handleCancellation()
 | |
|     {
 | |
|         $this->invoice = (new HandleCancellation($this->invoice))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function reverseCancellation()
 | |
|     {
 | |
|         $this->invoice = (new HandleCancellation($this->invoice))->reverse();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function triggeredActions($request)
 | |
|     {
 | |
|         $this->invoice = (new TriggeredActions($this->invoice, $request))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function autoBill()
 | |
|     {
 | |
|         $this->invoice = (new AutoBillInvoice($this->invoice))->run();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function markViewed()
 | |
|     {
 | |
|         $this->invoice->last_viewed = Carbon::now()->format('Y-m-d H:i');
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /* One liners */
 | |
|     public function setDueDate()
 | |
|     {
 | |
|         if($this->invoice->due_date != '' || $this->invoice->client->getSetting('payment_terms') == '')
 | |
|             return $this;
 | |
| 
 | |
|         $this->invoice->due_date = Carbon::parse($this->invoice->date)->addDays($this->invoice->client->getSetting('payment_terms'));
 | |
|         
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function setStatus($status)
 | |
|     {
 | |
|         $this->invoice->status_id = $status;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function toggleFeesPaid()
 | |
|     {
 | |
| 
 | |
|         $this->invoice->line_items = collect($this->invoice->line_items)
 | |
|                                      ->map(function ($item) {
 | |
| 
 | |
|                                             if($item->type_id == 3)
 | |
|                                                 $item->type_id = 4;
 | |
|                                             
 | |
|                                             return $item;
 | |
| 
 | |
|                                       })->toArray();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function removeUnpaidGatewayFees()
 | |
|     {
 | |
| 
 | |
|         $this->invoice->line_items = collect($this->invoice->line_items)
 | |
|                                      ->reject(function ($item) {
 | |
| 
 | |
|                                             return $item->type_id == 3;
 | |
| 
 | |
|                                       })->toArray();
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function clearPartial()
 | |
|     {
 | |
|         $this->invoice->partial = null;
 | |
|         $this->invoice->partial_due_date = null;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     public function updatePartial($amount)
 | |
|     {
 | |
|         $this->invoice->partial += $amount;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
| 
 | |
| 
 | |
|     /**
 | |
|      * Saves the invoice
 | |
|      * @return Invoice object
 | |
|      */
 | |
|     public function save() :?Invoice
 | |
|     {
 | |
|         $this->invoice->save();
 | |
| 
 | |
|         return $this->invoice;
 | |
|     }
 | |
| }
 |