| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * BudgetController.php | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * Copyright (c) 2017 thegrumpydictator@gmail.com | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * This file is part of Firefly III. | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01: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-10-30 18:29:26 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-04-09 07:44:22 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers\Report; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use FireflyIII\Helpers\Report\BudgetReportHelperInterface; | 
					
						
							|  |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  | use FireflyIII\Repositories\Budget\BudgetRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							| 
									
										
										
										
											2018-08-11 06:39:29 +02:00
										 |  |  | use FireflyIII\Support\Http\Controllers\BasicDataSupport; | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2018-08-07 19:29:40 +02:00
										 |  |  | use Log; | 
					
						
							|  |  |  | use Throwable; | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |  * Class BudgetController. | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | class BudgetController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-08-11 06:39:29 +02:00
										 |  |  |     use BasicDataSupport; | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-02 20:08:11 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:55:32 +02:00
										 |  |  |      * Show partial overview of budgets. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							| 
									
										
										
										
											2016-11-19 07:27:54 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-12-06 07:06:20 +01:00
										 |  |  |      * @return mixed|string | 
					
						
							| 
									
										
										
										
											2016-11-02 20:08:11 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  |     public function general(Collection $accounts, Carbon $start, Carbon $end) | 
					
						
							| 
									
										
										
										
											2016-11-02 20:08:11 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-12-06 07:06:20 +01:00
										 |  |  |         // chart properties for cache:
 | 
					
						
							| 
									
										
										
										
											2016-11-02 20:08:11 +01:00
										 |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							| 
									
										
										
										
											2016-12-06 07:06:20 +01:00
										 |  |  |         $cache->addProperty('budget-report'); | 
					
						
							| 
									
										
										
										
											2016-11-02 20:08:11 +01:00
										 |  |  |         $cache->addProperty($accounts->pluck('id')->toArray()); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2019-08-16 21:21:38 +02:00
										 |  |  |             return $cache->get(); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2016-11-02 20:08:11 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  |         $helper  = app(BudgetReportHelperInterface::class); | 
					
						
							| 
									
										
										
										
											2016-12-06 07:06:20 +01:00
										 |  |  |         $budgets = $helper->getBudgetReport($start, $end, $accounts); | 
					
						
							| 
									
										
										
										
											2019-08-16 21:21:38 +02:00
										 |  |  |         try { | 
					
						
							| 
									
										
										
										
											2018-08-07 19:29:40 +02:00
										 |  |  |             $result = view('reports.partials.budgets', compact('budgets'))->render(); | 
					
						
							| 
									
										
										
										
											2018-09-02 20:13:25 +02:00
										 |  |  |             // @codeCoverageIgnoreStart
 | 
					
						
							| 
									
										
										
										
											2019-08-16 21:21:38 +02:00
										 |  |  |         } catch (Throwable $e) { | 
					
						
							|  |  |  |             Log::debug(sprintf('Could not render reports.partials.budgets: %s', $e->getMessage())); | 
					
						
							|  |  |  |             $result = 'Could not render view.'; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-09-02 20:13:25 +02:00
										 |  |  |         // @codeCoverageIgnoreEnd
 | 
					
						
							| 
									
										
										
										
											2016-11-02 20:08:11 +01:00
										 |  |  |         $cache->store($result); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:55:32 +02:00
										 |  |  |      * Show budget overview for a period. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-12-06 07:06:20 +01:00
										 |  |  |      * @param Collection $accounts | 
					
						
							|  |  |  |      * @param Carbon     $start | 
					
						
							|  |  |  |      * @param Carbon     $end | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-12-06 07:06:20 +01:00
										 |  |  |      * @return mixed|string | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-06 07:06:20 +01:00
										 |  |  |     public function period(Collection $accounts, Carbon $start, Carbon $end) | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($start); | 
					
						
							|  |  |  |         $cache->addProperty($end); | 
					
						
							| 
									
										
										
										
											2016-12-06 07:06:20 +01:00
										 |  |  |         $cache->addProperty('budget-period-report'); | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  |         $cache->addProperty($accounts->pluck('id')->toArray()); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2017-03-04 11:19:44 +01:00
										 |  |  |             return $cache->get(); // @codeCoverageIgnore
 | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-06 07:06:20 +01:00
										 |  |  |         // generate budget report right here.
 | 
					
						
							|  |  |  |         /** @var BudgetRepositoryInterface $repository */ | 
					
						
							|  |  |  |         $repository = app(BudgetRepositoryInterface::class); | 
					
						
							|  |  |  |         $budgets    = $repository->getBudgets(); | 
					
						
							|  |  |  |         $data       = $repository->getBudgetPeriodReport($budgets, $accounts, $start, $end); | 
					
						
							| 
									
										
										
										
											2019-08-27 10:25:23 +02:00
										 |  |  |         $noBudget   = $repository->getNoBudgetPeriodReport($accounts, $start, $end); // append report data for "no budget"
 | 
					
						
							|  |  |  |         $data       = array_merge($data, $noBudget); | 
					
						
							| 
									
										
										
										
											2018-08-11 06:39:29 +02:00
										 |  |  |         $report     = $this->filterPeriodReport($data); | 
					
						
							| 
									
										
										
										
											2019-08-02 05:24:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // depending on the carbon format (a reliable way to determine the general date difference)
 | 
					
						
							|  |  |  |         // change the "listOfPeriods" call so the entire period gets included correctly.
 | 
					
						
							|  |  |  |         $range = app('navigation')->preferredCarbonFormat($start, $end); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ('Y' === $range) { | 
					
						
							|  |  |  |             $start->startOfYear(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ('Y-m' === $range) { | 
					
						
							|  |  |  |             $start->startOfMonth(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-27 10:25:23 +02:00
										 |  |  |         $periods = app('navigation')->listOfPeriods($start, $end); | 
					
						
							| 
									
										
										
										
											2018-08-07 19:29:40 +02:00
										 |  |  |         try { | 
					
						
							|  |  |  |             $result = view('reports.partials.budget-period', compact('report', 'periods'))->render(); | 
					
						
							| 
									
										
										
										
											2018-09-02 20:13:25 +02:00
										 |  |  |             // @codeCoverageIgnoreStart
 | 
					
						
							| 
									
										
										
										
											2018-08-07 19:29:40 +02:00
										 |  |  |         } catch (Throwable $e) { | 
					
						
							|  |  |  |             Log::debug(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | 
					
						
							|  |  |  |             $result = 'Could not render view.'; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-09-02 20:13:25 +02:00
										 |  |  |         // @codeCoverageIgnoreEnd
 | 
					
						
							| 
									
										
										
										
											2016-10-30 18:29:26 +01:00
										 |  |  |         $cache->store($result); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-12-04 18:02:19 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-22 19:42:45 +01:00
										 |  |  | } |