| 
									
										
										
										
											2020-03-21 14:50:54 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2020-06-30 19:05:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 14:50:54 +01:00
										 |  |  | /** | 
					
						
							|  |  |  |  * BudgetController.php | 
					
						
							|  |  |  |  * Copyright (c) 2020 james@firefly-iii.org | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program 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 Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-30 19:05:35 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 14:50:54 +01:00
										 |  |  | namespace FireflyIII\Http\Controllers\Json; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							|  |  |  | use FireflyIII\Models\TransactionCurrency; | 
					
						
							|  |  |  | use FireflyIII\Repositories\Budget\AvailableBudgetRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Repositories\Budget\BudgetLimitRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Repositories\Budget\OperationsRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Repositories\Currency\CurrencyRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Support\Http\Controllers\DateCalculation; | 
					
						
							|  |  |  | use Illuminate\Http\JsonResponse; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class BudgetController | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class BudgetController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     use DateCalculation; | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 14:50:54 +01:00
										 |  |  |     /** @var AvailableBudgetRepositoryInterface */ | 
					
						
							|  |  |  |     private $abRepository; | 
					
						
							|  |  |  |     /** @var BudgetLimitRepositoryInterface */ | 
					
						
							|  |  |  |     private $blRepository; | 
					
						
							|  |  |  |     /** @var CurrencyRepositoryInterface */ | 
					
						
							|  |  |  |     private $currencyRepository; | 
					
						
							|  |  |  |     /** @var OperationsRepositoryInterface */ | 
					
						
							|  |  |  |     private $opsRepository; | 
					
						
							|  |  |  |     /** @var BudgetRepositoryInterface The budget repository */ | 
					
						
							|  |  |  |     private $repository; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * IndexController constructor. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @codeCoverageIgnore | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							| 
									
										
										
										
											2021-03-21 09:15:40 +01:00
										 |  |  |                 app('view')->share('title', (string)trans('firefly.budgets')); | 
					
						
							| 
									
										
										
										
											2020-05-01 17:29:50 -03:00
										 |  |  |                 app('view')->share('mainTitleIcon', 'fa-pie-chart'); | 
					
						
							| 
									
										
										
										
											2020-03-21 14:50:54 +01: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); | 
					
						
							|  |  |  |                 $this->repository->cleanupBudgets(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function getBudgetInformation(TransactionCurrency $currency, Carbon $start, Carbon $end): JsonResponse | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-03-21 15:12:23 +01:00
										 |  |  |         $budgeted        = $this->blRepository->budgeted($start, $end, $currency,); | 
					
						
							|  |  |  |         $availableBudget = $this->abRepository->getByCurrencyDate($start, $end, $currency); | 
					
						
							|  |  |  |         $available       = '0'; | 
					
						
							|  |  |  |         $percentage      = '0'; | 
					
						
							| 
									
										
										
										
											2020-03-21 14:50:54 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-21 15:12:23 +01:00
										 |  |  |         if (null !== $availableBudget) { | 
					
						
							|  |  |  |             $available  = $availableBudget->amount; | 
					
						
							|  |  |  |             $percentage = bcmul(bcdiv($budgeted, $available), '100'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // if available, get the AB for this period + currency, so the bar can be redrawn.
 | 
					
						
							| 
									
										
										
										
											2020-03-21 14:50:54 +01:00
										 |  |  |         return response()->json( | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 'budgeted'                => $budgeted, | 
					
						
							|  |  |  |                 'budgeted_formatted'      => app('amount')->formatAnything($currency, $budgeted, true), | 
					
						
							| 
									
										
										
										
											2020-03-21 15:12:23 +01:00
										 |  |  |                 'available'               => app('amount')->formatAnything($currency, $available, true), | 
					
						
							|  |  |  |                 'available_formatted'     => $available, | 
					
						
							|  |  |  |                 'percentage'              => $percentage, | 
					
						
							| 
									
										
										
										
											2020-03-21 14:50:54 +01:00
										 |  |  |                 'currency_id'             => $currency->id, | 
					
						
							|  |  |  |                 'currency_code'           => $currency->code, | 
					
						
							|  |  |  |                 'currency_symbol'         => $currency->symbol, | 
					
						
							|  |  |  |                 'currency_name'           => $currency->name, | 
					
						
							|  |  |  |                 'currency_decimal_places' => $currency->decimal_places, | 
					
						
							|  |  |  |             ] | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-30 07:33:06 +02:00
										 |  |  | } |