mirror of
				https://github.com/invoiceninja/invoiceninja.git
				synced 2025-10-25 21:52:51 -04:00 
			
		
		
		
	Merge pull request #7940 from turbo124/v5-develop
Update invoice notifications
This commit is contained in:
		
						commit
						f92dbe34bb
					
				| @ -823,7 +823,7 @@ class BaseController extends Controller | ||||
|             //06-10-2022 - some entities do not have assigned_user_id - this becomes an issue when we have a large company and low permission users
 | ||||
|             if(lcfirst(class_basename(Str::snake($this->entity_type))) == 'user') | ||||
|                 $query->where('id', auth()->user()->id); | ||||
|             elseif(in_array(lcfirst(class_basename(Str::snake($this->entity_type))),['design','group_setting','payment_term'])){ | ||||
|             elseif(in_array(lcfirst(class_basename(Str::snake($this->entity_type))),['design','group_setting','payment_term','bank_transaction'])){ | ||||
|                 //need to pass these back regardless
 | ||||
|             } | ||||
|             else | ||||
|  | ||||
| @ -214,9 +214,8 @@ class MatchBankTransactions implements ShouldQueue | ||||
|              | ||||
|                 $this->invoice = Invoice::withTrashed()->where('id', $invoice->id)->lockForUpdate()->first(); | ||||
| 
 | ||||
|                 // if($invoices->count() == 1){
 | ||||
|                 //     $_amount = $this->available_balance;
 | ||||
|                 // }
 | ||||
|                     $_amount = false; | ||||
| 
 | ||||
|                     if(floatval($this->invoice->balance) < floatval($this->available_balance) && $this->available_balance > 0) | ||||
|                     { | ||||
|                         $_amount = $this->invoice->balance; | ||||
| @ -230,6 +229,9 @@ class MatchBankTransactions implements ShouldQueue | ||||
|                         $this->available_balance = 0; | ||||
|                     } | ||||
| 
 | ||||
|                     if($_amount) | ||||
|                     { | ||||
| 
 | ||||
|                         $this->attachable_invoices[] = ['id' => $this->invoice->id, 'amount' => $_amount]; | ||||
| 
 | ||||
|                         $this->invoice | ||||
| @ -239,6 +241,7 @@ class MatchBankTransactions implements ShouldQueue | ||||
|                             ->updatePaidToDate($_amount) | ||||
|                             ->setCalculatedStatus() | ||||
|                             ->save(); | ||||
|                     } | ||||
| 
 | ||||
|                 }); | ||||
| 
 | ||||
|  | ||||
| @ -27,6 +27,8 @@ class TriggeredActions extends AbstractService | ||||
| 
 | ||||
|     private $invoice; | ||||
| 
 | ||||
|     private bool $updated = false; | ||||
| 
 | ||||
|     public function __construct(Invoice $invoice, Request $request) | ||||
|     { | ||||
|         $this->request = $request; | ||||
| @ -37,30 +39,38 @@ class TriggeredActions extends AbstractService | ||||
|     public function run() | ||||
|     { | ||||
|         if ($this->request->has('auto_bill') && $this->request->input('auto_bill') == 'true') { | ||||
|             $this->invoice->service()->autoBill(); | ||||
|             $this->invoice->service()->autoBill(); //update notification sends automatically for this.
 | ||||
|         } | ||||
| 
 | ||||
|         if ($this->request->has('paid') && $this->request->input('paid') == 'true') { | ||||
|             $this->invoice = $this->invoice->service()->markPaid()->save(); | ||||
|             $this->invoice = $this->invoice->service()->markPaid()->save(); //update notification sends automatically for this.
 | ||||
|         } | ||||
| 
 | ||||
|         if ($this->request->has('mark_sent') && $this->request->input('mark_sent') == 'true') { | ||||
|             $this->invoice = $this->invoice->service()->markSent()->save(); | ||||
|         if ($this->request->has('mark_sent') && $this->request->input('mark_sent') == 'true' && $this->invoice->status_id == Invoice::STATUS_DRAFT) { | ||||
|             $this->invoice = $this->invoice->service()->markSent()->save(); //update notification NOT sent
 | ||||
|             $this->updated = true; | ||||
|         } | ||||
|          | ||||
|         if ($this->request->has('amount_paid') && is_numeric($this->request->input('amount_paid'))) { | ||||
|             $this->invoice = $this->invoice->service()->applyPaymentAmount($this->request->input('amount_paid'))->save(); | ||||
|             $this->updated = false; | ||||
|         } | ||||
| 
 | ||||
|         if ($this->request->has('send_email') && $this->request->input('send_email') == 'true') { | ||||
|             $this->invoice->service()->markSent()->touchPdf()->save(); | ||||
|             $this->sendEmail(); | ||||
|             $this->updated = false; | ||||
|         } | ||||
| 
 | ||||
|         if ($this->request->has('cancel') && $this->request->input('cancel') == 'true') { | ||||
|             $this->invoice = $this->invoice->service()->handleCancellation()->save(); | ||||
|             $this->updated = false; | ||||
|         } | ||||
| 
 | ||||
|         if($this->updated) | ||||
|             event('eloquent.updated: App\Models\Invoice', $this->invoice); | ||||
| 
 | ||||
| 
 | ||||
|         return $this->invoice; | ||||
|     } | ||||
| 
 | ||||
|  | ||||
| @ -7,10 +7,10 @@ | ||||
|                     @foreach ($entity->documents as $document) | ||||
|                         <div class="inline-flex items-center space-x-1"> | ||||
|                             @if($entity instanceof App\Models\PurchaseOrder) | ||||
|                             <a href="{{ route('vendor.documents.show', $document->hashed_id) }}" target="_blank" | ||||
|                             <a href="{{ route('vendor.documents.download', $document->hashed_id) }}" target="_blank" | ||||
|                                 class="block text-sm button-link text-primary">{{ Illuminate\Support\Str::limit($document->name, 40) }}</a> | ||||
|                             @else | ||||
|                             <a href="{{ route('client.documents.show', $document->hashed_id) }}" target="_blank" | ||||
|                             <a href="{{ route('client.documents.download', $document->hashed_id) }}" target="_blank" | ||||
|                                 class="block text-sm button-link text-primary">{{ Illuminate\Support\Str::limit($document->name, 40) }}</a>  | ||||
|                             @endif | ||||
|                             <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" | ||||
| @ -30,10 +30,10 @@ | ||||
|                     @foreach ($entity->company->documents as $document) | ||||
|                         <div class="inline-flex items-center space-x-1"> | ||||
|                             @if($entity instanceof App\Models\PurchaseOrder) | ||||
|                             <a href="{{ route('vendor.documents.show', $document->hashed_id) }}" target="_blank" | ||||
|                             <a href="{{ route('vendor.documents.download', $document->hashed_id) }}" target="_blank" | ||||
|                                 class="block text-sm button-link text-primary">{{ Illuminate\Support\Str::limit($document->name, 40) }}</a> | ||||
|                             @else | ||||
|                             <a href="{{ route('client.documents.show', $document->hashed_id) }}" target="_blank" | ||||
|                             <a href="{{ route('client.documents.download', $document->hashed_id) }}" target="_blank" | ||||
|                                 class="block text-sm button-link text-primary">{{ Illuminate\Support\Str::limit($document->name, 40) }}</a> | ||||
|                             @endif | ||||
|                             <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" | ||||
| @ -54,7 +54,7 @@ | ||||
|                         @foreach ($entity->expense_documents() as $expense) | ||||
|                             @foreach($expense->documents as $document) | ||||
|                                 <div class="inline-flex items-center space-x-1"> | ||||
|                                     <a href="{{ route('client.documents.show', $document->hashed_id) }}" target="_blank" | ||||
|                                     <a href="{{ route('client.documents.download', $document->hashed_id) }}" target="_blank" | ||||
|                                         class="block text-sm button-link text-primary">{{ Illuminate\Support\Str::limit($document->name, 40) }}</a> | ||||
| 
 | ||||
|                                     <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" | ||||
| @ -77,7 +77,7 @@ | ||||
|                         @foreach ($entity->task_documents() as $task) | ||||
|                             @foreach($task->documents as $document) | ||||
|                                 <div class="inline-flex items-center space-x-1"> | ||||
|                                     <a href="{{ route('client.documents.show', $document->hashed_id) }}" target="_blank" | ||||
|                                     <a href="{{ route('client.documents.download', $document->hashed_id) }}" target="_blank" | ||||
|                                         class="block text-sm button-link text-primary">{{ Illuminate\Support\Str::limit($document->name, 40) }}</a> | ||||
| 
 | ||||
|                                     <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user