| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * IndexController.php | 
					
						
							|  |  |  |  * Copyright (c) 2018 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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 | 
					
						
							|  |  |  |  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers\Budget; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  | use FireflyIII\Models\AvailableBudget; | 
					
						
							| 
									
										
										
										
											2019-08-31 21:47:55 +02:00
										 |  |  | use FireflyIII\Models\Budget; | 
					
						
							|  |  |  | use FireflyIII\Models\BudgetLimit; | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  | use FireflyIII\Models\TransactionCurrency; | 
					
						
							| 
									
										
										
										
											2019-08-30 08:00:52 +02:00
										 |  |  | use FireflyIII\Repositories\Budget\AvailableBudgetRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  | use FireflyIII\Repositories\Budget\BudgetLimitRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  | use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2019-08-29 21:42:55 +02:00
										 |  |  | use FireflyIII\Repositories\Budget\OperationsRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  | use FireflyIII\Repositories\Currency\CurrencyRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2018-07-14 16:08:34 +02:00
										 |  |  | use FireflyIII\Support\Http\Controllers\DateCalculation; | 
					
						
							| 
									
										
										
										
											2018-10-17 15:18:09 +02:00
										 |  |  | use Illuminate\Http\JsonResponse; | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  | use Illuminate\Http\Request; | 
					
						
							| 
									
										
										
										
											2019-08-31 21:47:55 +02:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Class IndexController | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class IndexController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-14 16:08:34 +02:00
										 |  |  |     use DateCalculation; | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  |     /** @var AvailableBudgetRepositoryInterface */ | 
					
						
							|  |  |  |     private $abRepository; | 
					
						
							|  |  |  |     /** @var BudgetLimitRepositoryInterface */ | 
					
						
							|  |  |  |     private $blRepository; | 
					
						
							|  |  |  |     /** @var CurrencyRepositoryInterface */ | 
					
						
							|  |  |  |     private $currencyRepository; | 
					
						
							| 
									
										
										
										
											2019-08-29 21:42:55 +02:00
										 |  |  |     /** @var OperationsRepositoryInterface */ | 
					
						
							|  |  |  |     private $opsRepository; | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |     /** @var BudgetRepositoryInterface The budget repository */ | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  |     private $repository; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * IndexController constructor. | 
					
						
							| 
									
										
										
										
											2019-08-29 21:42:55 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-06-23 11:13:36 +02:00
										 |  |  |      * @codeCoverageIgnore | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							| 
									
										
										
										
											2018-07-15 09:38:49 +02:00
										 |  |  |                 app('view')->share('title', (string)trans('firefly.budgets')); | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  |                 app('view')->share('mainTitleIcon', 'fa-tasks'); | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  |                 $this->repository         = app(BudgetRepositoryInterface::class); | 
					
						
							|  |  |  |                 $this->opsRepository      = app(OperationsRepositoryInterface::class); | 
					
						
							|  |  |  |                 $this->abRepository       = app(AvailableBudgetRepositoryInterface::class); | 
					
						
							|  |  |  |                 $this->currencyRepository = app(CurrencyRepositoryInterface::class); | 
					
						
							|  |  |  |                 $this->blRepository       = app(BudgetLimitRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-08-07 17:34:43 +02:00
										 |  |  |                 $this->repository->cleanupBudgets(); | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * Show all budgets. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  |      * @param Request     $request | 
					
						
							| 
									
										
										
										
											2018-08-08 17:53:40 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @param Carbon|null $start | 
					
						
							|  |  |  |      * @param Carbon|null $end | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-08-08 17:53:40 +02:00
										 |  |  |     public function index(Request $request, Carbon $start = null, Carbon $end = null) | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-08-07 17:34:43 +02:00
										 |  |  |         // collect some basic vars:
 | 
					
						
							|  |  |  |         $range           = app('preferences')->get('viewRange', '1M')->data; | 
					
						
							| 
									
										
										
										
											2018-08-08 17:53:40 +02:00
										 |  |  |         $start           = $start ?? session('start', Carbon::now()->startOfMonth()); | 
					
						
							|  |  |  |         $end             = $end ?? app('navigation')->endOfPeriod($start, $range); | 
					
						
							| 
									
										
										
										
											2018-08-07 17:34:43 +02:00
										 |  |  |         $defaultCurrency = app('amount')->getDefaultCurrency(); | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  |         $budgeted        = '0'; | 
					
						
							|  |  |  |         $spent           = '0'; | 
					
						
							| 
									
										
										
										
											2019-08-31 21:47:55 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  |         // new period stuff:
 | 
					
						
							|  |  |  |         $periodTitle = app('navigation')->periodShow($start, $range); | 
					
						
							| 
									
										
										
										
											2019-08-31 21:47:55 +02:00
										 |  |  |         $prevLoop    = $this->getPreviousPeriods($start, $range); | 
					
						
							|  |  |  |         $nextLoop    = $this->getNextPeriods($start, $range); | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // get all available budgets.
 | 
					
						
							|  |  |  |         $ab               = $this->abRepository->get($start, $end); | 
					
						
							|  |  |  |         $availableBudgets = []; | 
					
						
							|  |  |  |         // for each, complement with spent amount:
 | 
					
						
							|  |  |  |         /** @var AvailableBudget $entry */ | 
					
						
							|  |  |  |         foreach ($ab as $entry) { | 
					
						
							|  |  |  |             $array               = $entry->toArray(); | 
					
						
							|  |  |  |             $array['start_date'] = $entry->start_date; | 
					
						
							|  |  |  |             $array['end_date']   = $entry->end_date; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // spent in period:
 | 
					
						
							|  |  |  |             $spentArr       = $this->opsRepository->sumExpenses($entry->start_date, $entry->end_date, null, null, $entry->transactionCurrency); | 
					
						
							|  |  |  |             $array['spent'] = $spentArr[$entry->transaction_currency_id]['sum'] ?? '0'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // budgeted in period:
 | 
					
						
							|  |  |  |             $budgeted           = $this->blRepository->budgeted($entry->start_date, $entry->end_date, $entry->transactionCurrency,); | 
					
						
							|  |  |  |             $array['budgeted']  = $budgeted; | 
					
						
							|  |  |  |             $availableBudgets[] = $array; | 
					
						
							|  |  |  |             unset($spentArr); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-08-07 17:34:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  |         if (0 === count($availableBudgets)) { | 
					
						
							|  |  |  |             // get budgeted for default currency:
 | 
					
						
							|  |  |  |             $budgeted = $this->blRepository->budgeted($start, $end, $defaultCurrency,); | 
					
						
							|  |  |  |             $spentArr = $this->opsRepository->sumExpenses($start, $end, null, null, $defaultCurrency); | 
					
						
							|  |  |  |             $spent    = $spentArr[$defaultCurrency->id]['sum'] ?? '0'; | 
					
						
							|  |  |  |             unset($spentArr); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // count the number of enabled currencies. This determines if we display a "+" button.
 | 
					
						
							|  |  |  |         $currencies      = $this->currencyRepository->getEnabled(); | 
					
						
							|  |  |  |         $enableAddButton = $currencies->count() > count($availableBudgets); | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-07 17:34:43 +02:00
										 |  |  |         // number of days for consistent budgeting.
 | 
					
						
							|  |  |  |         $activeDaysPassed = $this->activeDaysPassed($start, $end); // see method description.
 | 
					
						
							|  |  |  |         $activeDaysLeft   = $this->activeDaysLeft($start, $end); // see method description.
 | 
					
						
							| 
									
										
										
										
											2019-09-01 10:48:18 +02:00
										 |  |  |         Log::debug(sprintf('Start: %s, end: %s', $start->format('Y-m-d H:i:s'), $end->format('Y-m-d H:i:s'))); | 
					
						
							| 
									
										
										
										
											2018-08-07 17:34:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // get all budgets, and paginate them into $budgets.
 | 
					
						
							|  |  |  |         $collection = $this->repository->getActiveBudgets(); | 
					
						
							| 
									
										
										
										
											2019-08-31 21:47:55 +02:00
										 |  |  |         $budgets    = []; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // complement budget with budget limits in range, and expenses in currency X in range.
 | 
					
						
							|  |  |  |         /** @var Budget $current */ | 
					
						
							|  |  |  |         foreach ($collection as $current) { | 
					
						
							|  |  |  |             $array             = $current->toArray(); | 
					
						
							|  |  |  |             $array['spent']    = []; | 
					
						
							|  |  |  |             $array['budgeted'] = []; | 
					
						
							|  |  |  |             $budgetLimits      = $this->blRepository->getBudgetLimits($current, $start, $end); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /** @var BudgetLimit $limit */ | 
					
						
							|  |  |  |             foreach ($budgetLimits as $limit) { | 
					
						
							|  |  |  |                 $array['budgeted'][] = [ | 
					
						
							|  |  |  |                     'id'                      => $limit->id, | 
					
						
							|  |  |  |                     'amount'                  => $limit->amount, | 
					
						
							|  |  |  |                     'currency_id'             => $limit->transactionCurrency->id, | 
					
						
							|  |  |  |                     'currency_symbol'         => $limit->transactionCurrency->symbol, | 
					
						
							|  |  |  |                     'currency_name'           => $limit->transactionCurrency->name, | 
					
						
							|  |  |  |                     'currency_decimal_places' => $limit->transactionCurrency->decimal_places, | 
					
						
							|  |  |  |                 ]; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /** @var TransactionCurrency $currency */ | 
					
						
							|  |  |  |             foreach ($currencies as $currency) { | 
					
						
							|  |  |  |                 $spentArr = $this->opsRepository->sumExpenses($start, $end, null, new Collection([$current]), $currency); | 
					
						
							|  |  |  |                 if (isset($spentArr[$currency->id]['sum'])) { | 
					
						
							|  |  |  |                     $array['spent'][$currency->id]['spent']                   = $spentArr[$currency->id]['sum']; | 
					
						
							|  |  |  |                     $array['spent'][$currency->id]['currency_id']             = $currency->id; | 
					
						
							|  |  |  |                     $array['spent'][$currency->id]['currency_symbol']         = $currency->symbol; | 
					
						
							|  |  |  |                     $array['spent'][$currency->id]['currency_decimal_places'] = $currency->decimal_places; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $budgets[] = $array; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-08-07 17:34:43 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // get all inactive budgets, and simply list them:
 | 
					
						
							|  |  |  |         $inactive = $this->repository->getInactiveBudgets(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  |         return view( | 
					
						
							|  |  |  |             'budgets.index', compact( | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  |                                'availableBudgets', | 
					
						
							|  |  |  |                                //'available',
 | 
					
						
							|  |  |  |                                //'currentMonth', 'next', 'nextText', 'prev',
 | 
					
						
							|  |  |  |                                //'prevText', 'previousLoop', 'nextLoop',
 | 
					
						
							|  |  |  |                                'budgeted', 'spent', | 
					
						
							|  |  |  |                                'prevLoop', 'nextLoop', | 
					
						
							| 
									
										
										
										
											2019-08-31 21:47:55 +02:00
										 |  |  |                                'budgets', | 
					
						
							|  |  |  |                                'currencies', | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  |                                'enableAddButton', | 
					
						
							|  |  |  |                                'periodTitle', | 
					
						
							|  |  |  |                                'defaultCurrency', | 
					
						
							| 
									
										
										
										
											2019-08-31 21:47:55 +02:00
										 |  |  |                                'activeDaysPassed', 'activeDaysLeft', | 
					
						
							| 
									
										
										
										
											2019-08-31 09:35:35 +02:00
										 |  |  |                                'inactive', 'budgets', 'start', 'end' | 
					
						
							| 
									
										
										
										
											2018-07-14 15:22:21 +02:00
										 |  |  |                            ) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-17 15:18:09 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-02-13 17:38:41 +01:00
										 |  |  |      * @param Request                   $request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param BudgetRepositoryInterface $repository | 
					
						
							| 
									
										
										
										
											2018-10-17 15:18:09 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function reorder(Request $request, BudgetRepositoryInterface $repository): JsonResponse | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $budgetIds = $request->get('budgetIds'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-01 10:48:18 +02:00
										 |  |  |         foreach ($budgetIds as $index => $budgetId) { | 
					
						
							| 
									
										
										
										
											2018-10-17 15:18:09 +02:00
										 |  |  |             $budgetId = (int)$budgetId; | 
					
						
							|  |  |  |             $budget   = $repository->findNull($budgetId); | 
					
						
							|  |  |  |             if (null !== $budget) { | 
					
						
							| 
									
										
										
										
											2019-09-01 10:48:18 +02:00
										 |  |  |                 Log::debug(sprintf('Set budget #%d ("%s") to position %d', $budget->id, $budget->name, $index + 1)); | 
					
						
							|  |  |  |                 $repository->setBudgetOrder($budget, $index + 1); | 
					
						
							| 
									
										
										
										
											2018-10-17 15:18:09 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return response()->json(['OK']); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-14 16:08:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-22 20:32:02 +02:00
										 |  |  | } |