| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * BudgetReportController.php | 
					
						
							|  |  |  |  * Copyright (C) 2016 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This software may be modified and distributed under the terms of the | 
					
						
							|  |  |  |  * Creative Commons Attribution-ShareAlike 4.0 International License. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * See the LICENSE file for details. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types = 1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers\Chart; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use FireflyIII\Generator\Chart\Basic\GeneratorInterface; | 
					
						
							|  |  |  | use FireflyIII\Generator\Report\Category\MonthReportGenerator; | 
					
						
							|  |  |  | use FireflyIII\Helpers\Collector\JournalCollector; | 
					
						
							|  |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							|  |  |  | use FireflyIII\Models\Budget; | 
					
						
							| 
									
										
										
										
											2016-12-23 17:50:26 +01:00
										 |  |  | use FireflyIII\Models\LimitRepetition; | 
					
						
							| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  | use FireflyIII\Models\Transaction; | 
					
						
							|  |  |  | use FireflyIII\Models\TransactionType; | 
					
						
							|  |  |  | use FireflyIII\Repositories\Account\AccountRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							|  |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2016-12-23 17:50:26 +01:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  | use Navigation; | 
					
						
							|  |  |  | use Response; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Separate controller because many helper functions are shared. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Class BudgetReportController | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Http\Controllers\Chart | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class BudgetReportController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** @var AccountRepositoryInterface */ | 
					
						
							|  |  |  |     private $accountRepository; | 
					
						
							|  |  |  |     /** @var BudgetRepositoryInterface */ | 
					
						
							|  |  |  |     private $budgetRepository; | 
					
						
							|  |  |  |     /** @var  GeneratorInterface */ | 
					
						
							|  |  |  |     private $generator; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							|  |  |  |                 $this->generator         = app(GeneratorInterface::class); | 
					
						
							|  |  |  |                 $this->budgetRepository  = app(BudgetRepositoryInterface::class); | 
					
						
							|  |  |  |                 $this->accountRepository = app(AccountRepositoryInterface::class); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * @param Collection $budgets | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							|  |  |  |      * @param string     $others | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function accountExpense(Collection $accounts, Collection $budgets, Carbon $start, Carbon $end, string $others) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var bool $others */ | 
					
						
							|  |  |  |         $others = intval($others) === 1; | 
					
						
							|  |  |  |         $cache  = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty('chart.budget.report.account-expense'); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							|  |  |  |         $cache->addProperty($budgets); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							|  |  |  |             return Response::json($cache->get()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $names     = []; | 
					
						
							|  |  |  |         $set       = $this->getExpenses($accounts, $budgets, $start, $end); | 
					
						
							|  |  |  |         $grouped   = $this->groupByOpposingAccount($set); | 
					
						
							|  |  |  |         $chartData = []; | 
					
						
							|  |  |  |         $total     = '0'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach ($grouped as $accountId => $amount) { | 
					
						
							|  |  |  |             if (!isset($names[$accountId])) { | 
					
						
							|  |  |  |                 $account           = $this->accountRepository->find(intval($accountId)); | 
					
						
							|  |  |  |                 $names[$accountId] = $account->name; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $amount                        = bcmul($amount, '-1'); | 
					
						
							|  |  |  |             $total                         = bcadd($total, $amount); | 
					
						
							|  |  |  |             $chartData[$names[$accountId]] = $amount; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // also collect all transactions NOT in these budgets.
 | 
					
						
							|  |  |  |         if ($others) { | 
					
						
							|  |  |  |             $collector = new JournalCollector(auth()->user()); | 
					
						
							|  |  |  |             $collector->setAccounts($accounts)->setRange($start, $end)->setTypes([TransactionType::WITHDRAWAL]); | 
					
						
							|  |  |  |             $journals                                            = $collector->getJournals(); | 
					
						
							|  |  |  |             $sum                                                 = strval($journals->sum('transaction_amount')); | 
					
						
							|  |  |  |             $sum                                                 = bcmul($sum, '-1'); | 
					
						
							|  |  |  |             $sum                                                 = bcsub($sum, $total); | 
					
						
							|  |  |  |             $chartData[strval(trans('firefly.everything_else'))] = $sum; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $data = $this->generator->pieChart($chartData); | 
					
						
							|  |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json($data); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * @param Collection $budgets | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							|  |  |  |      * @param string     $others | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function budgetExpense(Collection $accounts, Collection $budgets, Carbon $start, Carbon $end, string $others) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var bool $others */ | 
					
						
							|  |  |  |         $others = intval($others) === 1; | 
					
						
							|  |  |  |         $cache  = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty('chart.budget.report.budget-expense'); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							|  |  |  |         $cache->addProperty($budgets); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							|  |  |  |             return Response::json($cache->get()); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $names     = []; | 
					
						
							|  |  |  |         $set       = $this->getExpenses($accounts, $budgets, $start, $end); | 
					
						
							|  |  |  |         $grouped   = $this->groupByBudget($set); | 
					
						
							|  |  |  |         $total     = '0'; | 
					
						
							|  |  |  |         $chartData = []; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach ($grouped as $budgetId => $amount) { | 
					
						
							|  |  |  |             if (!isset($names[$budgetId])) { | 
					
						
							|  |  |  |                 $budget           = $this->budgetRepository->find(intval($budgetId)); | 
					
						
							|  |  |  |                 $names[$budgetId] = $budget->name; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $amount                       = bcmul($amount, '-1'); | 
					
						
							|  |  |  |             $total                        = bcadd($total, $amount); | 
					
						
							|  |  |  |             $chartData[$names[$budgetId]] = $amount; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // also collect all transactions NOT in these budgets.
 | 
					
						
							|  |  |  |         if ($others) { | 
					
						
							|  |  |  |             $collector = new JournalCollector(auth()->user()); | 
					
						
							|  |  |  |             $collector->setAccounts($accounts)->setRange($start, $end)->setTypes([TransactionType::WITHDRAWAL]); | 
					
						
							|  |  |  |             $journals                                            = $collector->getJournals(); | 
					
						
							|  |  |  |             $sum                                                 = strval($journals->sum('transaction_amount')); | 
					
						
							|  |  |  |             $sum                                                 = bcmul($sum, '-1'); | 
					
						
							|  |  |  |             $sum                                                 = bcsub($sum, $total); | 
					
						
							|  |  |  |             $chartData[strval(trans('firefly.everything_else'))] = $sum; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $data = $this->generator->pieChart($chartData); | 
					
						
							|  |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json($data); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * @param Collection $budgets | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function mainChart(Collection $accounts, Collection $budgets, Carbon $start, Carbon $end) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty('chart.budget.report.main'); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							|  |  |  |         $cache->addProperty($budgets); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							|  |  |  |             return Response::json($cache->get()); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-23 17:50:26 +01:00
										 |  |  |         /** @var BudgetRepositoryInterface $repository */ | 
					
						
							|  |  |  |         $repository   = app(BudgetRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  |         $format       = Navigation::preferredCarbonLocalizedFormat($start, $end); | 
					
						
							|  |  |  |         $function     = Navigation::preferredEndOfPeriod($start, $end); | 
					
						
							|  |  |  |         $chartData    = []; | 
					
						
							|  |  |  |         $currentStart = clone $start; | 
					
						
							| 
									
										
										
										
											2016-12-23 17:50:26 +01:00
										 |  |  |         $limits       = $repository->getAllBudgetLimitRepetitions($start, $end); // also for ALL budgets.
 | 
					
						
							| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // prep chart data:
 | 
					
						
							|  |  |  |         foreach ($budgets as $budget) { | 
					
						
							| 
									
										
										
										
											2016-12-23 17:50:26 +01:00
										 |  |  |             $chartData[$budget->id]           = [ | 
					
						
							|  |  |  |                 'label'   => strval(trans('firefly.spent_in_specific_budget', ['budget' => $budget->name])), | 
					
						
							| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  |                 'type'    => 'bar', | 
					
						
							|  |  |  |                 'entries' => [], | 
					
						
							|  |  |  |             ]; | 
					
						
							| 
									
										
										
										
											2016-12-23 17:50:26 +01:00
										 |  |  |             $chartData[$budget->id . '-sum']  = [ | 
					
						
							|  |  |  |                 'label'   => strval(trans('firefly.sum_of_expenses_in_budget', ['budget' => $budget->name])), | 
					
						
							|  |  |  |                 'type'    => 'line', | 
					
						
							|  |  |  |                 'fill'    => false, | 
					
						
							|  |  |  |                 'entries' => [], | 
					
						
							|  |  |  |             ]; | 
					
						
							|  |  |  |             $chartData[$budget->id . '-left'] = [ | 
					
						
							|  |  |  |                 'label'   => strval(trans('firefly.left_in_budget_limit', ['budget' => $budget->name])), | 
					
						
							|  |  |  |                 'type'    => 'line', | 
					
						
							|  |  |  |                 'fill'    => false, | 
					
						
							|  |  |  |                 'entries' => [], | 
					
						
							|  |  |  |             ]; | 
					
						
							| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-23 17:50:26 +01:00
										 |  |  |         $sumOfExpenses = []; | 
					
						
							|  |  |  |         $leftOfLimits  = []; | 
					
						
							| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  |         while ($currentStart < $end) { | 
					
						
							|  |  |  |             $currentEnd = clone $currentStart; | 
					
						
							|  |  |  |             $currentEnd = $currentEnd->$function(); | 
					
						
							|  |  |  |             $expenses   = $this->groupByBudget($this->getExpenses($accounts, $budgets, $currentStart, $currentEnd)); | 
					
						
							|  |  |  |             $label      = $currentStart->formatLocalized($format); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /** @var Budget $budget */ | 
					
						
							|  |  |  |             foreach ($budgets as $budget) { | 
					
						
							| 
									
										
										
										
											2016-12-23 17:50:26 +01:00
										 |  |  |                 $currentExpenses                                    = $expenses[$budget->id] ?? '0'; | 
					
						
							|  |  |  |                 $sumOfExpenses[$budget->id]                         = $sumOfExpenses[$budget->id] ?? '0'; | 
					
						
							|  |  |  |                 $sumOfExpenses[$budget->id]                         = bcadd($currentExpenses, $sumOfExpenses[$budget->id]); | 
					
						
							|  |  |  |                 $chartData[$budget->id]['entries'][$label]          = round(bcmul($currentExpenses, '-1'), 2); | 
					
						
							|  |  |  |                 $chartData[$budget->id . '-sum']['entries'][$label] = round(bcmul($sumOfExpenses[$budget->id], '-1'), 2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 $limit = $this->filterLimits($limits, $budget, $currentStart); | 
					
						
							|  |  |  |                 if (!is_null($limit->id)) { | 
					
						
							|  |  |  |                     $leftOfLimits[$limit->id]                            = $leftOfLimits[$limit->id] ?? strval($limit->amount); | 
					
						
							|  |  |  |                     $leftOfLimits[$limit->id]                            = bcadd($leftOfLimits[$limit->id], $currentExpenses); | 
					
						
							|  |  |  |                     $chartData[$budget->id . '-left']['entries'][$label] = round($leftOfLimits[$limit->id], 2); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |             $currentStart = clone $currentEnd; | 
					
						
							|  |  |  |             $currentStart->addDay(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $data = $this->generator->multiSet($chartData); | 
					
						
							|  |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json($data); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-23 17:50:26 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param $limits | 
					
						
							|  |  |  |      * @param $budget | 
					
						
							|  |  |  |      * @param $currentStart | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return LimitRepetition | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function filterLimits(Collection $limits, Budget $budget, Carbon $date): LimitRepetition | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         Log::debug(sprintf('Start of filterLimits with %d limits.', $limits->count())); | 
					
						
							|  |  |  |         $filtered = $limits->filter( | 
					
						
							|  |  |  |             function (LimitRepetition $limit) use ($budget, $date) { | 
					
						
							|  |  |  |                 if ($limit->budget_id !== $budget->id) { | 
					
						
							|  |  |  |                     Log::debug(sprintf('LimitRepetition has budget #%d but expecting #%d', $limit->budget_id, $budget->id)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     return false; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 if ($date < $limit->startdate || $date > $limit->enddate) { | 
					
						
							|  |  |  |                     Log::debug( | 
					
						
							|  |  |  |                         sprintf( | 
					
						
							|  |  |  |                             'Date %s is not between %s and %s', | 
					
						
							|  |  |  |                             $date->format('Y-m-d'), $limit->startdate->format('Y-m-d'), $limit->enddate->format('Y-m-d') | 
					
						
							|  |  |  |                         ) | 
					
						
							|  |  |  |                     ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     return false; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $limit; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |         if ($filtered->count() === 1) { | 
					
						
							|  |  |  |             return $filtered->first(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return new LimitRepetition; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-16 08:07:31 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * @param Collection $budgets | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getExpenses(Collection $accounts, Collection $budgets, Carbon $start, Carbon $end): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $collector = new JournalCollector(auth()->user()); | 
					
						
							|  |  |  |         $collector->setAccounts($accounts)->setRange($start, $end)->setTypes([TransactionType::WITHDRAWAL, TransactionType::TRANSFER]) | 
					
						
							|  |  |  |                   ->setBudgets($budgets)->withOpposingAccount()->disableFilter(); | 
					
						
							|  |  |  |         $accountIds   = $accounts->pluck('id')->toArray(); | 
					
						
							|  |  |  |         $transactions = $collector->getJournals(); | 
					
						
							|  |  |  |         $set          = MonthReportGenerator::filterExpenses($transactions, $accountIds); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $set; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Collection $set | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function groupByBudget(Collection $set): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // group by category ID:
 | 
					
						
							|  |  |  |         $grouped = []; | 
					
						
							|  |  |  |         /** @var Transaction $transaction */ | 
					
						
							|  |  |  |         foreach ($set as $transaction) { | 
					
						
							|  |  |  |             $jrnlBudId          = intval($transaction->transaction_journal_budget_id); | 
					
						
							|  |  |  |             $transBudId         = intval($transaction->transaction_budget_id); | 
					
						
							|  |  |  |             $budgetId           = max($jrnlBudId, $transBudId); | 
					
						
							|  |  |  |             $grouped[$budgetId] = $grouped[$budgetId] ?? '0'; | 
					
						
							|  |  |  |             $grouped[$budgetId] = bcadd($transaction->transaction_amount, $grouped[$budgetId]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $grouped; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Collection $set | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function groupByOpposingAccount(Collection $set): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $grouped = []; | 
					
						
							|  |  |  |         /** @var Transaction $transaction */ | 
					
						
							|  |  |  |         foreach ($set as $transaction) { | 
					
						
							|  |  |  |             $accountId           = $transaction->opposing_account_id; | 
					
						
							|  |  |  |             $grouped[$accountId] = $grouped[$accountId] ?? '0'; | 
					
						
							|  |  |  |             $grouped[$accountId] = bcadd($transaction->transaction_amount, $grouped[$accountId]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $grouped; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-12-22 19:42:45 +01:00
										 |  |  | } |