105 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\View\Components\Contacts\Show;
 | |
| 
 | |
| use App\Utilities\Date;
 | |
| use App\Abstracts\View\Components\Contacts\Show as Component;
 | |
| use Illuminate\Database\Eloquent\Collection;
 | |
| use Illuminate\Pagination\Paginator;
 | |
| use Illuminate\Pagination\LengthAwarePaginator;
 | |
| 
 | |
| class Content extends Component
 | |
| {
 | |
|     public $counts;
 | |
| 
 | |
|     public $totals;
 | |
| 
 | |
|     public $transactions;
 | |
| 
 | |
|     public $documents;
 | |
| 
 | |
|     /**
 | |
|      * Get the view / contents that represent the component.
 | |
|      *
 | |
|      * @return \Illuminate\Contracts\View\View|string
 | |
|      */
 | |
|     public function render()
 | |
|     {
 | |
|         $totals = [
 | |
|             'paid' => 0,
 | |
|             'open' => 0,
 | |
|             'overdue' => 0,
 | |
|         ];
 | |
| 
 | |
|         $this->counts = [];
 | |
| 
 | |
|         // Handle documents
 | |
|         $docs = $this->contact->isCustomer() ? 'invoices' : 'bills';
 | |
| 
 | |
|         $this->documents = $this->contact->$docs()->with('transactions')->get();
 | |
| 
 | |
|         $this->counts['documents'] = $this->documents->count();
 | |
| 
 | |
|         $today = Date::today()->toDateString();
 | |
| 
 | |
|         foreach ($this->documents as $item) {
 | |
|             // Already in transactions
 | |
|             if ($item->status == 'paid' || $item->status == 'cancelled') {
 | |
|                 continue;
 | |
|             }
 | |
| 
 | |
|             $transactions = 0;
 | |
| 
 | |
|             foreach ($item->transactions as $transaction) {
 | |
|                 $transactions += $transaction->getAmountConvertedToDefault();
 | |
|             }
 | |
| 
 | |
|             // Check if it's open or overdue invoice
 | |
|             if ($item->due_at > $today) {
 | |
|                 $totals['open'] += $item->getAmountConvertedToDefault() - $transactions;
 | |
|             } else {
 | |
|                 $totals['overdue'] += $item->getAmountConvertedToDefault() - $transactions;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         // Handle payments
 | |
|         $this->transactions = $this->contact->transactions()->with('account', 'category')->get();
 | |
| 
 | |
|         $this->counts['transactions'] = $this->transactions->count();
 | |
| 
 | |
|         // Prepare data
 | |
|         $this->transactions->each(function ($item) use (&$totals) {
 | |
|             $totals['paid'] += $item->getAmountConvertedToDefault();
 | |
|         });
 | |
| 
 | |
|         $this->totals = $totals;
 | |
| 
 | |
|         $limit = (int) request('limit', setting('default.list_limit', '25'));
 | |
|         $this->transactions = $this->paginate($this->transactions->sortByDesc('paid_at'), $limit);
 | |
|         $this->documents = $this->paginate($this->documents->sortByDesc('issued_at'), $limit);
 | |
| 
 | |
|         return view('components.contacts.show.content');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Generate a pagination collection.
 | |
|      *
 | |
|      * @param array|Collection $items
 | |
|      * @param int $perPage
 | |
|      * @param int $page
 | |
|      * @param array $options
 | |
|      *
 | |
|      * @return LengthAwarePaginator
 | |
|      */
 | |
|     public function paginate($items, $perPage = 15, $page = null, $options = [])
 | |
|     {
 | |
|         $perPage = $perPage ?: (int) request('limit', setting('default.list_limit', '25'));
 | |
| 
 | |
|         $page = $page ?: (Paginator::resolveCurrentPage() ?: 1);
 | |
| 
 | |
|         $items = $items instanceof Collection ? $items : Collection::make($items);
 | |
| 
 | |
|         return new LengthAwarePaginator($items->forPage($page, $perPage), $items->count(), $perPage, $page, $options);
 | |
|     }
 | |
| }
 |