| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2022-12-29 19:41:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * PiggyBankController.php | 
					
						
							| 
									
										
										
										
											2020-01-31 07:32:04 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2016-05-20 12:41:23 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * 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. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * GNU Affero General Public License for more details. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * 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/>. | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-15 19:20:04 +02:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2022-12-29 19:41:57 +01:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2016-12-15 14:05:50 +01:00
										 |  |  | use FireflyIII\Generator\Chart\Basic\GeneratorInterface; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							|  |  |  | use FireflyIII\Models\PiggyBank; | 
					
						
							| 
									
										
										
										
											2016-05-01 07:09:58 +02:00
										 |  |  | use FireflyIII\Models\PiggyBankEvent; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | use FireflyIII\Repositories\PiggyBank\PiggyBankRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							| 
									
										
										
										
											2018-07-14 23:22:08 +02:00
										 |  |  | use FireflyIII\Support\Http\Controllers\DateCalculation; | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  | use Illuminate\Http\JsonResponse; | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |  * Class PiggyBankController. | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | class PiggyBankController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-07-14 23:22:08 +02:00
										 |  |  |     use DateCalculation; | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |     /** @var GeneratorInterface Chart generation methods. */ | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |     protected $generator; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * PiggyBankController constructor. | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  |         // create chart generator:
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:05:50 +01:00
										 |  |  |         $this->generator = app(GeneratorInterface::class); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Shows the piggy bank history. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2022-10-30 11:43:17 +01:00
										 |  |  |      * TODO this chart is not multi currency aware. | 
					
						
							| 
									
										
										
										
											2018-08-27 18:59:30 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2022-12-29 19:41:57 +01:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function history(PiggyBankRepositoryInterface $repository, PiggyBank $piggyBank): JsonResponse | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         // chart properties for cache:
 | 
					
						
							| 
									
										
										
										
											2022-10-30 14:24:28 +01:00
										 |  |  |         $cache = new CacheProperties(); | 
					
						
							| 
									
										
										
										
											2016-12-15 14:05:50 +01:00
										 |  |  |         $cache->addProperty('chart.piggy-bank.history'); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         $cache->addProperty($piggyBank->id); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2021-09-18 10:26:12 +02:00
										 |  |  |             return response()->json($cache->get()); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  |         $set    = $repository->getEvents($piggyBank); | 
					
						
							|  |  |  |         $set    = $set->reverse(); | 
					
						
							|  |  |  |         $locale = app('steam')->getLocale(); | 
					
						
							| 
									
										
										
										
											2018-04-15 19:20:04 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // get first event or start date of piggy bank or today
 | 
					
						
							| 
									
										
										
										
											2021-04-27 06:23:16 +02:00
										 |  |  |         $startDate = $piggyBank->startdate ?? today(config('app.timezone')); | 
					
						
							| 
									
										
										
										
											2018-04-15 19:20:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |         /** @var null|PiggyBankEvent $firstEvent */ | 
					
						
							| 
									
										
										
										
											2018-04-15 19:20:04 +02:00
										 |  |  |         $firstEvent = $set->first(); | 
					
						
							| 
									
										
										
										
											2022-10-30 14:24:28 +01:00
										 |  |  |         $firstDate  = null === $firstEvent ? new Carbon() : $firstEvent->date; | 
					
						
							| 
									
										
										
										
											2018-04-15 19:20:04 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // which ever is older:
 | 
					
						
							|  |  |  |         $oldest = $startDate->lt($firstDate) ? $startDate : $firstDate; | 
					
						
							| 
									
										
										
										
											2020-09-11 07:12:33 +02:00
										 |  |  |         $today  = today(config('app.timezone')); | 
					
						
							| 
									
										
										
										
											2018-04-15 19:20:04 +02:00
										 |  |  |         // depending on diff, do something with range of chart.
 | 
					
						
							| 
									
										
										
										
											2018-07-14 23:22:08 +02:00
										 |  |  |         $step = $this->calculateStep($oldest, $today); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:05:50 +01:00
										 |  |  |         $chartData = []; | 
					
						
							| 
									
										
										
										
											2018-04-15 19:20:04 +02:00
										 |  |  |         while ($oldest <= $today) { | 
					
						
							|  |  |  |             $filtered          = $set->filter( | 
					
						
							| 
									
										
										
										
											2023-11-04 14:18:49 +01:00
										 |  |  |                 static function (PiggyBankEvent $event) use ($oldest) { | 
					
						
							| 
									
										
										
										
											2018-04-15 19:20:04 +02:00
										 |  |  |                     return $event->date->lte($oldest); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  |             $currentSum        = $filtered->sum('amount'); | 
					
						
							| 
									
										
										
										
											2022-12-29 19:41:57 +01:00
										 |  |  |             $label             = $oldest->isoFormat((string)trans('config.month_and_day_js', [], $locale)); | 
					
						
							| 
									
										
										
										
											2018-04-15 19:20:04 +02:00
										 |  |  |             $chartData[$label] = $currentSum; | 
					
						
							|  |  |  |             $oldest            = app('navigation')->addPeriod($oldest, $step, 0); | 
					
						
							| 
									
										
										
										
											2016-05-01 07:09:58 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-15 19:24:20 +02:00
										 |  |  |         $finalFiltered          = $set->filter( | 
					
						
							| 
									
										
										
										
											2023-11-04 14:18:49 +01:00
										 |  |  |             static function (PiggyBankEvent $event) use ($today) { | 
					
						
							| 
									
										
										
										
											2018-04-15 19:24:20 +02:00
										 |  |  |                 return $event->date->lte($today); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2018-07-08 07:59:58 +02:00
										 |  |  |         $finalSum               = $finalFiltered->sum('amount'); | 
					
						
							| 
									
										
										
										
											2022-12-29 19:41:57 +01:00
										 |  |  |         $finalLabel             = $today->isoFormat((string)trans('config.month_and_day_js', [], $locale)); | 
					
						
							| 
									
										
										
										
											2018-04-15 19:24:20 +02:00
										 |  |  |         $chartData[$finalLabel] = $finalSum; | 
					
						
							| 
									
										
										
										
											2016-05-01 07:09:58 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-15 14:05:50 +01:00
										 |  |  |         $data = $this->generator->singleSet($piggyBank->name, $chartData); | 
					
						
							| 
									
										
										
										
											2015-06-27 11:44:18 +02:00
										 |  |  |         $cache->store($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($data); | 
					
						
							| 
									
										
										
										
											2015-05-16 09:41:14 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-05-20 19:56:14 +02:00
										 |  |  | } |