| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * BudgetController.php | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * Copyright (c) 2017 thegrumpydictator@gmail.com | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * This file is part of Firefly III. | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * Firefly III is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							| 
									
										
										
										
											2017-12-17 14:41:58 +01:00
										 |  |  |  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-04-09 07:44:22 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers\Chart; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  | use FireflyIII\Generator\Chart\Basic\GeneratorInterface; | 
					
						
							| 
									
										
										
										
											2016-12-28 11:34:00 +01:00
										 |  |  | use FireflyIII\Helpers\Collector\JournalCollectorInterface; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  | use FireflyIII\Models\AccountType; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | use FireflyIII\Models\Budget; | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  | use FireflyIII\Models\BudgetLimit; | 
					
						
							| 
									
										
										
										
											2016-11-05 18:08:44 +01:00
										 |  |  | use FireflyIII\Models\Transaction; | 
					
						
							|  |  |  | use FireflyIII\Models\TransactionType; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  | use FireflyIII\Repositories\Account\AccountRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  | use FireflyIII\Repositories\Category\CategoryRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  | use Illuminate\Http\JsonResponse; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2017-06-02 06:45:38 +02:00
										 |  |  | use Steam; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |  * Class BudgetController. | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class BudgetController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2016-12-15 10:44:06 +01:00
										 |  |  |     /** @var GeneratorInterface */ | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |     protected $generator; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |     /** @var BudgetRepositoryInterface */ | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |     protected $repository; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-09-16 09:09:54 +02:00
										 |  |  |      * BudgetController constructor. | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							|  |  |  |                 $this->generator  = app(GeneratorInterface::class); | 
					
						
							|  |  |  |                 $this->repository = app(BudgetRepositoryInterface::class); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-25 09:57:39 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |      * @param Budget $budget | 
					
						
							| 
									
										
										
										
											2016-04-25 09:57:39 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2016-04-25 09:57:39 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function budget(Budget $budget): JsonResponse | 
					
						
							| 
									
										
										
										
											2016-04-25 09:57:39 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-01-14 16:32:26 +01:00
										 |  |  |         $start = $this->repository->firstUseDate($budget); | 
					
						
							|  |  |  |         $end   = session('end', new Carbon); | 
					
						
							|  |  |  |         $cache = new CacheProperties(); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         $cache->addProperty('chart.budget.budget'); | 
					
						
							| 
									
										
										
										
											2018-02-25 15:09:57 +01:00
										 |  |  |         $cache->addProperty($budget->id); | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |             return response()->json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-14 16:32:26 +01:00
										 |  |  |         // depending on diff, do something with range of chart.
 | 
					
						
							|  |  |  |         $step   = '1D'; | 
					
						
							|  |  |  |         $months = $start->diffInMonths($end); | 
					
						
							|  |  |  |         if ($months > 3) { | 
					
						
							|  |  |  |             $step = '1W'; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ($months > 24) { | 
					
						
							|  |  |  |             $step = '1M'; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ($months > 60) { | 
					
						
							| 
									
										
										
										
											2018-01-29 19:08:49 +01:00
										 |  |  |             $step = '1Y'; // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2018-01-14 16:32:26 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         $budgetCollection = new Collection([$budget]); | 
					
						
							| 
									
										
										
										
											2018-01-14 16:32:26 +01:00
										 |  |  |         $chartData        = []; | 
					
						
							|  |  |  |         $current          = clone $start; | 
					
						
							|  |  |  |         $current          = app('navigation')->startOfPeriod($current, $step); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         while ($end >= $current) { | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |             /** @var Carbon $currentEnd */ | 
					
						
							| 
									
										
										
										
											2018-01-17 10:17:49 +01:00
										 |  |  |             $currentEnd = app('navigation')->endOfPeriod($current, $step); | 
					
						
							| 
									
										
										
										
											2018-07-08 07:59:58 +02:00
										 |  |  |             if ('1Y' === $step) { | 
					
						
							| 
									
										
										
										
											2018-01-29 19:08:49 +01:00
										 |  |  |                 $currentEnd->subDay(); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2018-01-17 10:17:49 +01:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2018-01-14 16:32:26 +01:00
										 |  |  |             $spent             = $this->repository->spentInPeriod($budgetCollection, new Collection, $current, $currentEnd); | 
					
						
							|  |  |  |             $label             = app('navigation')->periodShow($current, $step); | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             $chartData[$label] = (float)bcmul($spent, '-1'); | 
					
						
							| 
									
										
										
										
											2018-01-17 10:17:49 +01:00
										 |  |  |             $current           = clone $currentEnd; | 
					
						
							|  |  |  |             $current->addDay(); | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         $data = $this->generator->singleSet((string)trans('firefly.spent'), $chartData); | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($data); | 
					
						
							| 
									
										
										
										
											2016-04-25 09:57:39 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-16 13:06:38 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Shows the amount left in a specific budget limit. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |      * @param Budget      $budget | 
					
						
							|  |  |  |      * @param BudgetLimit $budgetLimit | 
					
						
							| 
									
										
										
										
											2015-05-16 13:06:38 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2015-05-16 13:06:38 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function budgetLimit(Budget $budget, BudgetLimit $budgetLimit): JsonResponse | 
					
						
							| 
									
										
										
										
											2015-05-16 13:06:38 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-07-15 16:41:07 +02:00
										 |  |  |         if ($budgetLimit->budget->id !== $budget->id) { | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |             throw new FireflyException('This budget limit is not part of this budget.'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $start = clone $budgetLimit->start_date; | 
					
						
							|  |  |  |         $end   = clone $budgetLimit->end_date; | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         $cache = new CacheProperties(); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         $cache->addProperty('chart.budget.budget.limit'); | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |         $cache->addProperty($budgetLimit->id); | 
					
						
							| 
									
										
										
										
											2018-02-25 15:09:57 +01:00
										 |  |  |         $cache->addProperty($budget->id); | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |             return response()->json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         $entries          = []; | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |         $amount           = $budgetLimit->amount; | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         $budgetCollection = new Collection([$budget]); | 
					
						
							|  |  |  |         while ($start <= $end) { | 
					
						
							| 
									
										
										
										
											2017-01-05 09:08:35 +01:00
										 |  |  |             $spent            = $this->repository->spentInPeriod($budgetCollection, new Collection, $start, $start); | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |             $amount           = bcadd($amount, $spent); | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             $format           = $start->formatLocalized((string)trans('config.month_and_day')); | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |             $entries[$format] = $amount; | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             $start->addDay(); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         $data = $this->generator->singleSet((string)trans('firefly.left'), $entries); | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         $cache->store($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 13:06:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 13:06:38 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Budget           $budget | 
					
						
							|  |  |  |      * @param BudgetLimit|null $budgetLimit | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function expenseAsset(Budget $budget, ?BudgetLimit $budgetLimit): JsonResponse | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |         $budgetLimitId = null === $budgetLimit ? 0 : $budgetLimit->id; | 
					
						
							|  |  |  |         $cache         = new CacheProperties; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         $cache->addProperty($budget->id); | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |         $cache->addProperty($budgetLimitId); | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         $cache->addProperty('chart.budget.expense-asset'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |             return response()->json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** @var JournalCollectorInterface $collector */ | 
					
						
							|  |  |  |         $collector = app(JournalCollectorInterface::class); | 
					
						
							| 
									
										
										
										
											2017-10-14 07:58:29 +02:00
										 |  |  |         $collector->setAllAssetAccounts()->setBudget($budget); | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |         if (null !== $budgetLimit) { | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |             $collector->setRange($budgetLimit->start_date, $budgetLimit->end_date); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $transactions = $collector->getJournals(); | 
					
						
							|  |  |  |         $result       = []; | 
					
						
							|  |  |  |         $chartData    = []; | 
					
						
							|  |  |  |         /** @var Transaction $transaction */ | 
					
						
							|  |  |  |         foreach ($transactions as $transaction) { | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             $assetId          = (int)$transaction->account_id; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |             $result[$assetId] = $result[$assetId] ?? '0'; | 
					
						
							|  |  |  |             $result[$assetId] = bcadd($transaction->transaction_amount, $result[$assetId]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $names = $this->getAccountNames(array_keys($result)); | 
					
						
							|  |  |  |         foreach ($result as $assetId => $amount) { | 
					
						
							|  |  |  |             $chartData[$names[$assetId]] = $amount; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $data = $this->generator->pieChart($chartData); | 
					
						
							|  |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($data); | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Budget           $budget | 
					
						
							|  |  |  |      * @param BudgetLimit|null $budgetLimit | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function expenseCategory(Budget $budget, ?BudgetLimit $budgetLimit): JsonResponse | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |         $budgetLimitId = null === $budgetLimit ? 0 : $budgetLimit->id; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($budget->id); | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |         $cache->addProperty($budgetLimitId); | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         $cache->addProperty('chart.budget.expense-category'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |             return response()->json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** @var JournalCollectorInterface $collector */ | 
					
						
							|  |  |  |         $collector = app(JournalCollectorInterface::class); | 
					
						
							| 
									
										
										
										
											2017-10-14 07:58:29 +02:00
										 |  |  |         $collector->setAllAssetAccounts()->setBudget($budget)->withCategoryInformation(); | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |         if (null !== $budgetLimit) { | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |             $collector->setRange($budgetLimit->start_date, $budgetLimit->end_date); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $transactions = $collector->getJournals(); | 
					
						
							|  |  |  |         $result       = []; | 
					
						
							|  |  |  |         $chartData    = []; | 
					
						
							|  |  |  |         /** @var Transaction $transaction */ | 
					
						
							|  |  |  |         foreach ($transactions as $transaction) { | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             $jrnlCatId           = (int)$transaction->transaction_journal_category_id; | 
					
						
							|  |  |  |             $transCatId          = (int)$transaction->transaction_category_id; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |             $categoryId          = max($jrnlCatId, $transCatId); | 
					
						
							|  |  |  |             $result[$categoryId] = $result[$categoryId] ?? '0'; | 
					
						
							|  |  |  |             $result[$categoryId] = bcadd($transaction->transaction_amount, $result[$categoryId]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $names = $this->getCategoryNames(array_keys($result)); | 
					
						
							|  |  |  |         foreach ($result as $categoryId => $amount) { | 
					
						
							|  |  |  |             $chartData[$names[$categoryId]] = $amount; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $data = $this->generator->pieChart($chartData); | 
					
						
							|  |  |  |         $cache->store($data); | 
					
						
							| 
									
										
										
										
											2017-10-15 14:05:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($data); | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Budget           $budget | 
					
						
							|  |  |  |      * @param BudgetLimit|null $budgetLimit | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function expenseExpense(Budget $budget, ?BudgetLimit $budgetLimit): JsonResponse | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |         $budgetLimitId = null === $budgetLimit ? 0 : $budgetLimit->id; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($budget->id); | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |         $cache->addProperty($budgetLimitId); | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         $cache->addProperty('chart.budget.expense-expense'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |             return response()->json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** @var JournalCollectorInterface $collector */ | 
					
						
							|  |  |  |         $collector = app(JournalCollectorInterface::class); | 
					
						
							|  |  |  |         $collector->setAllAssetAccounts()->setTypes([TransactionType::WITHDRAWAL])->setBudget($budget)->withOpposingAccount(); | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |         if (null !== $budgetLimit) { | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |             $collector->setRange($budgetLimit->start_date, $budgetLimit->end_date); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $transactions = $collector->getJournals(); | 
					
						
							|  |  |  |         $result       = []; | 
					
						
							|  |  |  |         $chartData    = []; | 
					
						
							|  |  |  |         /** @var Transaction $transaction */ | 
					
						
							|  |  |  |         foreach ($transactions as $transaction) { | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             $opposingId          = (int)$transaction->opposing_account_id; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |             $result[$opposingId] = $result[$opposingId] ?? '0'; | 
					
						
							|  |  |  |             $result[$opposingId] = bcadd($transaction->transaction_amount, $result[$opposingId]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $names = $this->getAccountNames(array_keys($result)); | 
					
						
							|  |  |  |         foreach ($result as $opposingId => $amount) { | 
					
						
							| 
									
										
										
										
											2017-04-23 18:53:00 +02:00
										 |  |  |             $name             = $names[$opposingId] ?? 'no name'; | 
					
						
							|  |  |  |             $chartData[$name] = $amount; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $data = $this->generator->pieChart($chartData); | 
					
						
							|  |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($data); | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Shows a budget list with spent/left/overspent. | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |      * @return \Symfony\Component\HttpFoundation\Response | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function frontpage(): \Symfony\Component\HttpFoundation\Response | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         $start = session('start', Carbon::now()->startOfMonth()); | 
					
						
							|  |  |  |         $end   = session('end', Carbon::now()->endOfMonth()); | 
					
						
							|  |  |  |         // chart properties for cache:
 | 
					
						
							|  |  |  |         $cache = new CacheProperties(); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         $cache->addProperty('chart.budget.frontpage'); | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |             return response()->json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |         $budgets   = $this->repository->getActiveBudgets(); | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |         $chartData = [ | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             ['label' => (string)trans('firefly.spent_in_budget'), 'entries' => [], 'type' => 'bar'], | 
					
						
							|  |  |  |             ['label' => (string)trans('firefly.left_to_spend'), 'entries' => [], 'type' => 'bar'], | 
					
						
							|  |  |  |             ['label' => (string)trans('firefly.overspent'), 'entries' => [], 'type' => 'bar'], | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         /** @var Budget $budget */ | 
					
						
							|  |  |  |         foreach ($budgets as $budget) { | 
					
						
							|  |  |  |             // get relevant repetitions:
 | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |             $limits   = $this->repository->getBudgetLimits($budget, $start, $end); | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |             $expenses = $this->getExpensesForBudget($limits, $budget, $start, $end); | 
					
						
							| 
									
										
										
										
											2017-06-02 06:45:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |             foreach ($expenses as $name => $row) { | 
					
						
							|  |  |  |                 $chartData[0]['entries'][$name] = $row['spent']; | 
					
						
							|  |  |  |                 $chartData[1]['entries'][$name] = $row['left']; | 
					
						
							|  |  |  |                 $chartData[2]['entries'][$name] = $row['overspent']; | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         // for no budget:
 | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |         $spent = $this->spentInPeriodWithout($start, $end); | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         $name  = (string)trans('firefly.no_budget'); | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if (0 !== bccomp($spent, '0')) { | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |             $chartData[0]['entries'][$name] = bcmul($spent, '-1'); | 
					
						
							|  |  |  |             $chartData[1]['entries'][$name] = '0'; | 
					
						
							|  |  |  |             $chartData[2]['entries'][$name] = '0'; | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 10:44:06 +01:00
										 |  |  |         $data = $this->generator->multiSet($chartData); | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  |     /** @noinspection MoreThanThreeArgumentsInspection */ | 
					
						
							| 
									
										
										
										
											2016-04-24 20:23:17 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @param Budget     $budget | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							|  |  |  |      * @param Collection $accounts | 
					
						
							| 
									
										
										
										
											2016-04-26 09:21:57 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2016-04-24 20:23:17 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function period(Budget $budget, Collection $accounts, Carbon $start, Carbon $end): JsonResponse | 
					
						
							| 
									
										
										
										
											2016-04-24 20:23:17 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-05-06 22:53:08 +02:00
										 |  |  |         // chart properties for cache:
 | 
					
						
							|  |  |  |         $cache = new CacheProperties(); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							|  |  |  |         $cache->addProperty($budget->id); | 
					
						
							| 
									
										
										
										
											2016-12-15 10:41:10 +01:00
										 |  |  |         $cache->addProperty('chart.budget.period'); | 
					
						
							| 
									
										
										
										
											2016-05-06 22:53:08 +02:00
										 |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |             return response()->json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2016-05-06 22:53:08 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  |         $periods  = app('navigation')->listOfPeriods($start, $end); | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |         $entries  = $this->repository->getBudgetPeriodReport(new Collection([$budget]), $accounts, $start, $end); // get the expenses
 | 
					
						
							|  |  |  |         $budgeted = $this->getBudgetedInPeriod($budget, $start, $end); | 
					
						
							| 
									
										
										
										
											2016-05-06 22:53:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 10:41:10 +01:00
										 |  |  |         // join them into one set of data:
 | 
					
						
							|  |  |  |         $chartData = [ | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             ['label' => (string)trans('firefly.spent'), 'type' => 'bar', 'entries' => []], | 
					
						
							|  |  |  |             ['label' => (string)trans('firefly.budgeted'), 'type' => 'bar', 'entries' => []], | 
					
						
							| 
									
										
										
										
											2016-12-15 10:41:10 +01:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2016-11-19 13:37:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 10:41:10 +01:00
										 |  |  |         foreach (array_keys($periods) as $period) { | 
					
						
							|  |  |  |             $label                           = $periods[$period]; | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             $spent                           = $entries[$budget->id]['entries'][$period] ?? '0'; | 
					
						
							|  |  |  |             $limit                           = (int)($budgeted[$period] ?? 0); | 
					
						
							| 
									
										
										
										
											2016-12-30 13:45:02 +01:00
										 |  |  |             $chartData[0]['entries'][$label] = round(bcmul($spent, '-1'), 12); | 
					
						
							| 
									
										
										
										
											2016-12-15 10:41:10 +01:00
										 |  |  |             $chartData[1]['entries'][$label] = $limit; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-15 10:44:06 +01:00
										 |  |  |         $data = $this->generator->multiSet($chartData); | 
					
						
							| 
									
										
										
										
											2016-05-06 22:53:08 +02:00
										 |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function periodNoBudget(Collection $accounts, Carbon $start, Carbon $end): JsonResponse | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         // chart properties for cache:
 | 
					
						
							|  |  |  |         $cache = new CacheProperties(); | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							|  |  |  |         $cache->addProperty($accounts); | 
					
						
							| 
									
										
										
										
											2016-12-15 10:41:10 +01:00
										 |  |  |         $cache->addProperty('chart.budget.no-budget'); | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |             return response()->json($cache->get()); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // the expenses:
 | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  |         $periods   = app('navigation')->listOfPeriods($start, $end); | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |         $entries   = $this->repository->getNoBudgetPeriodReport($accounts, $start, $end); | 
					
						
							| 
									
										
										
										
											2016-12-15 10:41:10 +01:00
										 |  |  |         $chartData = []; | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // join them:
 | 
					
						
							|  |  |  |         foreach (array_keys($periods) as $period) { | 
					
						
							| 
									
										
										
										
											2016-12-15 10:41:10 +01:00
										 |  |  |             $label             = $periods[$period]; | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |             $spent             = $entries['entries'][$period] ?? '0'; | 
					
						
							| 
									
										
										
										
											2016-12-15 10:41:56 +01:00
										 |  |  |             $chartData[$label] = bcmul($spent, '-1'); | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         $data = $this->generator->singleSet((string)trans('firefly.spent'), $chartData); | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  |         $cache->store($data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($data); | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param array $accountIds | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getAccountNames(array $accountIds): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var AccountRepositoryInterface $repository */ | 
					
						
							|  |  |  |         $repository = app(AccountRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2017-10-14 07:58:29 +02:00
										 |  |  |         $accounts   = $repository->getAccountsByType([AccountType::ASSET, AccountType::DEFAULT, AccountType::EXPENSE, AccountType::CASH]); | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |         $grouped    = $accounts->groupBy('id')->toArray(); | 
					
						
							|  |  |  |         $return     = []; | 
					
						
							|  |  |  |         foreach ($accountIds as $accountId) { | 
					
						
							|  |  |  |             if (isset($grouped[$accountId])) { | 
					
						
							|  |  |  |                 $return[$accountId] = $grouped[$accountId][0]['name']; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-04-23 18:53:00 +02:00
										 |  |  |         $return[0] = '(no name)'; | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param Budget $budget | 
					
						
							|  |  |  |      * @param Carbon $start | 
					
						
							|  |  |  |      * @param Carbon $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getBudgetedInPeriod(Budget $budget, Carbon $start, Carbon $end): array | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  |         $key      = app('navigation')->preferredCarbonFormat($start, $end); | 
					
						
							|  |  |  |         $range    = app('navigation')->preferredRangeFormat($start, $end); | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |         $current  = clone $start; | 
					
						
							|  |  |  |         $budgeted = []; | 
					
						
							|  |  |  |         while ($current < $end) { | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |             /** @var Carbon $currentStart */ | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  |             $currentStart     = app('navigation')->startOfPeriod($current, $range); | 
					
						
							| 
									
										
										
										
											2018-07-09 19:24:08 +02:00
										 |  |  |             /** @var Carbon $currentEnd */ | 
					
						
							| 
									
										
										
										
											2017-12-17 14:06:14 +01:00
										 |  |  |             $currentEnd       = app('navigation')->endOfPeriod($current, $range); | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |             $budgetLimits     = $this->repository->getBudgetLimits($budget, $currentStart, $currentEnd); | 
					
						
							|  |  |  |             $index            = $currentStart->format($key); | 
					
						
							|  |  |  |             $budgeted[$index] = $budgetLimits->sum('amount'); | 
					
						
							|  |  |  |             $currentEnd->addDay(); | 
					
						
							|  |  |  |             $current = clone $currentEnd; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $budgeted; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-22 07:04:39 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Small helper function for some of the charts. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param array $categoryIds | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getCategoryNames(array $categoryIds): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /** @var CategoryRepositoryInterface $repository */ | 
					
						
							|  |  |  |         $repository = app(CategoryRepositoryInterface::class); | 
					
						
							|  |  |  |         $categories = $repository->getCategories(); | 
					
						
							|  |  |  |         $grouped    = $categories->groupBy('id')->toArray(); | 
					
						
							|  |  |  |         $return     = []; | 
					
						
							|  |  |  |         foreach ($categoryIds as $categoryId) { | 
					
						
							|  |  |  |             if (isset($grouped[$categoryId])) { | 
					
						
							|  |  |  |                 $return[$categoryId] = $grouped[$categoryId][0]['name']; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $return[0] = trans('firefly.noCategory'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  |     /** @noinspection MoreThanThreeArgumentsInspection */ | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |      * @param Collection $limits | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |      * @param Budget     $budget | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |     private function getExpensesForBudget(Collection $limits, Budget $budget, Carbon $start, Carbon $end): array | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |         $return = []; | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if (0 === $limits->count()) { | 
					
						
							| 
									
										
										
										
											2017-01-05 09:08:35 +01:00
										 |  |  |             $spent = $this->repository->spentInPeriod(new Collection([$budget]), new Collection, $start, $end); | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |             if (0 !== bccomp($spent, '0')) { | 
					
						
							| 
									
										
										
										
											2016-12-29 17:56:12 +01:00
										 |  |  |                 $return[$budget->name]['spent']     = bcmul($spent, '-1'); | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |                 $return[$budget->name]['left']      = 0; | 
					
						
							|  |  |  |                 $return[$budget->name]['overspent'] = 0; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return $return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |         $rows = $this->spentInPeriodMulti($budget, $limits); | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |         foreach ($rows as $name => $row) { | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |             if (0 !== bccomp($row['spent'], '0') || 0 !== bccomp($row['left'], '0')) { | 
					
						
							| 
									
										
										
										
											2017-06-02 06:45:38 +02:00
										 |  |  |                 $return[$name] = $row; | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-07-08 07:59:58 +02:00
										 |  |  |         unset($rows); | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |      * Returns an array with the following values: | 
					
						
							|  |  |  |      * 0 => | 
					
						
							|  |  |  |      *   'name' => name of budget + repetition | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |      *   'left' => left in budget repetition (always zero) | 
					
						
							|  |  |  |      *   'overspent' => spent more than budget repetition? (always zero) | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |      *   'spent' => actually spent in period for budget | 
					
						
							|  |  |  |      * 1 => (etc) | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |      * @param Budget     $budget | 
					
						
							|  |  |  |      * @param Collection $limits | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |      * @return array | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2017-01-02 20:42:29 +01:00
										 |  |  |     private function spentInPeriodMulti(Budget $budget, Collection $limits): array | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         $return = []; | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         $format = (string)trans('config.month_and_day'); | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         $name   = $budget->name; | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |         /** @var BudgetLimit $budgetLimit */ | 
					
						
							|  |  |  |         foreach ($limits as $budgetLimit) { | 
					
						
							| 
									
										
										
										
											2017-01-05 09:08:35 +01:00
										 |  |  |             $expenses = $this->repository->spentInPeriod(new Collection([$budget]), new Collection, $budgetLimit->start_date, $budgetLimit->end_date); | 
					
						
							| 
									
										
										
										
											2017-06-02 06:45:38 +02:00
										 |  |  |             $expenses = Steam::positive($expenses); | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |             if ($limits->count() > 1) { | 
					
						
							| 
									
										
										
										
											2016-09-16 09:09:54 +02:00
										 |  |  |                 $name = $budget->name . ' ' . trans( | 
					
						
							|  |  |  |                         'firefly.between_dates', | 
					
						
							| 
									
										
										
										
											2016-12-30 08:41:48 +01:00
										 |  |  |                         [ | 
					
						
							|  |  |  |                             'start' => $budgetLimit->start_date->formatLocalized($format), | 
					
						
							|  |  |  |                             'end'   => $budgetLimit->end_date->formatLocalized($format), | 
					
						
							|  |  |  |                         ] | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |                     ); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2017-02-23 17:43:29 +01:00
										 |  |  |             /* | 
					
						
							|  |  |  |              * amount: amount of budget limit | 
					
						
							|  |  |  |              * left: amount of budget limit min spent, or 0 when < 0. | 
					
						
							|  |  |  |              * spent: spent, or amount of budget limit when > amount | 
					
						
							|  |  |  |              */ | 
					
						
							| 
									
										
										
										
											2017-06-02 06:45:38 +02:00
										 |  |  |             $amount       = $budgetLimit->amount; | 
					
						
							|  |  |  |             $leftInLimit  = bcsub($amount, $expenses); | 
					
						
							|  |  |  |             $hasOverspent = bccomp($leftInLimit, '0') === -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $left      = $hasOverspent ? '0' : bcsub($amount, $expenses); | 
					
						
							|  |  |  |             $spent     = $hasOverspent ? $amount : $expenses; | 
					
						
							|  |  |  |             $overspent = $hasOverspent ? Steam::positive($leftInLimit) : '0'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |             $return[$name] = [ | 
					
						
							|  |  |  |                 'left'      => $left, | 
					
						
							|  |  |  |                 'overspent' => $overspent, | 
					
						
							|  |  |  |                 'spent'     => $spent, | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |             ]; | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |         return $return; | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |      * Returns an array with the following values: | 
					
						
							|  |  |  |      * 'name' => "no budget" in local language | 
					
						
							|  |  |  |      * 'repetition_left' => left in budget repetition (always zero) | 
					
						
							|  |  |  |      * 'repetition_overspent' => spent more than budget repetition? (always zero) | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |      * 'spent' => actually spent in period for budget. | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-11-05 18:08:44 +01:00
										 |  |  |      * @param Carbon $start | 
					
						
							|  |  |  |      * @param Carbon $end | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |      * @return string | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |     private function spentInPeriodWithout(Carbon $start, Carbon $end): string | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-11-05 18:08:44 +01:00
										 |  |  |         // collector
 | 
					
						
							| 
									
										
										
										
											2016-12-28 11:34:00 +01:00
										 |  |  |         /** @var JournalCollectorInterface $collector */ | 
					
						
							| 
									
										
										
										
											2017-02-05 16:16:15 +01:00
										 |  |  |         $collector = app(JournalCollectorInterface::class); | 
					
						
							| 
									
										
										
										
											2016-11-19 13:37:44 +01:00
										 |  |  |         $types     = [TransactionType::WITHDRAWAL]; | 
					
						
							| 
									
										
										
										
											2016-11-05 18:08:44 +01:00
										 |  |  |         $collector->setAllAssetAccounts()->setTypes($types)->setRange($start, $end)->withoutBudget(); | 
					
						
							|  |  |  |         $journals = $collector->getJournals(); | 
					
						
							|  |  |  |         $sum      = '0'; | 
					
						
							|  |  |  |         /** @var Transaction $entry */ | 
					
						
							|  |  |  |         foreach ($journals as $entry) { | 
					
						
							|  |  |  |             $sum = bcadd($entry->transaction_amount, $sum); | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-12-15 09:49:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-29 17:42:46 +01:00
										 |  |  |         return $sum; | 
					
						
							| 
									
										
										
										
											2016-07-30 16:29:04 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-20 19:56:14 +02:00
										 |  |  | } |