| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2020-06-30 19:05:35 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * IndexController.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-07 11:30:02 +02:00
										 |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers\PiggyBank; | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							|  |  |  | use FireflyIII\Models\PiggyBank; | 
					
						
							| 
									
										
										
										
											2020-06-07 16:38:15 +02:00
										 |  |  | use FireflyIII\Repositories\ObjectGroup\OrganisesObjectGroups; | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  | use FireflyIII\Repositories\PiggyBank\PiggyBankRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Transformers\AccountTransformer; | 
					
						
							|  |  |  | use FireflyIII\Transformers\PiggyBankTransformer; | 
					
						
							|  |  |  | use Illuminate\Contracts\View\Factory; | 
					
						
							|  |  |  | use Illuminate\Http\JsonResponse; | 
					
						
							|  |  |  | use Illuminate\Http\Request; | 
					
						
							|  |  |  | use Illuminate\View\View; | 
					
						
							|  |  |  | use Symfony\Component\HttpFoundation\ParameterBag; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class IndexController | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class IndexController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-06-07 16:38:15 +02:00
										 |  |  |     use OrganisesObjectGroups; | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |     private PiggyBankRepositoryInterface $piggyRepos; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * PiggyBankController constructor. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @codeCoverageIgnore | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							| 
									
										
										
										
											2022-03-29 14:58:06 +02:00
										 |  |  |                 app('view')->share('title', (string) trans('firefly.piggyBanks')); | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |                 app('view')->share('mainTitleIcon', 'fa-bullseye'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 $this->piggyRepos = app(PiggyBankRepositoryInterface::class); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Show overview of all piggy banks. | 
					
						
							| 
									
										
										
										
											2021-09-18 10:26:12 +02:00
										 |  |  |      * See reference nr. 66 | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @param Request $request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Factory|View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function index(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2020-06-07 16:38:15 +02:00
										 |  |  |         $this->cleanupObjectGroups(); | 
					
						
							| 
									
										
										
										
											2021-03-14 06:20:23 +01:00
										 |  |  |         $this->piggyRepos->resetOrder(); | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |         $collection = $this->piggyRepos->getPiggyBanks(); | 
					
						
							|  |  |  |         $accounts   = []; | 
					
						
							|  |  |  |         /** @var Carbon $end */ | 
					
						
							|  |  |  |         $end = session('end', Carbon::now()->endOfMonth()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // transform piggies using the transformer:
 | 
					
						
							|  |  |  |         $parameters = new ParameterBag; | 
					
						
							|  |  |  |         $parameters->set('end', $end); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // make piggy bank groups:
 | 
					
						
							| 
									
										
										
										
											2020-08-02 16:29:33 +02:00
										 |  |  |         $piggyBanks = []; | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** @var PiggyBankTransformer $transformer */ | 
					
						
							|  |  |  |         $transformer = app(PiggyBankTransformer::class); | 
					
						
							|  |  |  |         $transformer->setParameters(new ParameterBag); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** @var AccountTransformer $accountTransformer */ | 
					
						
							|  |  |  |         $accountTransformer = app(AccountTransformer::class); | 
					
						
							|  |  |  |         $accountTransformer->setParameters($parameters); | 
					
						
							|  |  |  |         /** @var PiggyBank $piggy */ | 
					
						
							|  |  |  |         foreach ($collection as $piggy) { | 
					
						
							|  |  |  |             $array      = $transformer->transform($piggy); | 
					
						
							| 
									
										
										
										
											2022-03-29 14:58:06 +02:00
										 |  |  |             $groupOrder = (int) $array['object_group_order']; | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |             // make group array if necessary:
 | 
					
						
							|  |  |  |             $piggyBanks[$groupOrder] = $piggyBanks[$groupOrder] ?? [ | 
					
						
							| 
									
										
										
										
											2020-08-02 16:29:33 +02:00
										 |  |  |                     'object_group_id'    => $array['object_group_id'] ?? 0, | 
					
						
							|  |  |  |                     'object_group_title' => $array['object_group_title'] ?? trans('firefly.default_group_title_name'), | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |                     'piggy_banks'        => [], | 
					
						
							|  |  |  |                 ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $account              = $accountTransformer->transform($piggy->account); | 
					
						
							| 
									
										
										
										
											2022-03-29 14:58:06 +02:00
										 |  |  |             $accountId            = (int) $account['id']; | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |             $array['attachments'] = $this->piggyRepos->getAttachments($piggy); | 
					
						
							| 
									
										
										
										
											2021-04-07 07:28:43 +02:00
										 |  |  |             if (!array_key_exists($accountId, $accounts)) { | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |                 // create new:
 | 
					
						
							|  |  |  |                 $accounts[$accountId] = $account; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 // add some interesting details:
 | 
					
						
							|  |  |  |                 $accounts[$accountId]['left']    = $accounts[$accountId]['current_balance']; | 
					
						
							|  |  |  |                 $accounts[$accountId]['saved']   = 0; | 
					
						
							|  |  |  |                 $accounts[$accountId]['target']  = 0; | 
					
						
							|  |  |  |                 $accounts[$accountId]['to_save'] = 0; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // calculate new interesting fields:
 | 
					
						
							| 
									
										
										
										
											2020-06-20 18:57:20 +02:00
										 |  |  |             $accounts[$accountId]['left']             -= $array['current_amount']; | 
					
						
							|  |  |  |             $accounts[$accountId]['saved']            += $array['current_amount']; | 
					
						
							|  |  |  |             $accounts[$accountId]['target']           += $array['target_amount']; | 
					
						
							|  |  |  |             $accounts[$accountId]['to_save']          += ($array['target_amount'] - $array['current_amount']); | 
					
						
							|  |  |  |             $array['account_name']                    = $account['name']; | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |             $piggyBanks[$groupOrder]['piggy_banks'][] = $array; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-06-20 18:57:20 +02:00
										 |  |  |         // do a bunch of summaries.
 | 
					
						
							|  |  |  |         $piggyBanks = $this->makeSums($piggyBanks); | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-09 10:33:55 +02:00
										 |  |  |         ksort($piggyBanks); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-29 14:11:12 +01:00
										 |  |  |         return view('piggy-banks.index', compact('piggyBanks', 'accounts')); | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-20 18:57:20 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param array $piggyBanks | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function makeSums(array $piggyBanks): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $sums = []; | 
					
						
							|  |  |  |         foreach ($piggyBanks as $groupOrder => $group) { | 
					
						
							|  |  |  |             $groupId = $group['object_group_id']; | 
					
						
							|  |  |  |             foreach ($group['piggy_banks'] as $piggy) { | 
					
						
							|  |  |  |                 $currencyId                  = $piggy['currency_id']; | 
					
						
							|  |  |  |                 $sums[$groupId][$currencyId] = $sums[$groupId][$currencyId] ?? [ | 
					
						
							|  |  |  |                         'target'                  => '0', | 
					
						
							|  |  |  |                         'saved'                   => '0', | 
					
						
							|  |  |  |                         'left_to_save'            => '0', | 
					
						
							|  |  |  |                         'save_per_month'          => '0', | 
					
						
							|  |  |  |                         'currency_id'             => $currencyId, | 
					
						
							|  |  |  |                         'currency_code'           => $piggy['currency_code'], | 
					
						
							|  |  |  |                         'currency_symbol'         => $piggy['currency_symbol'], | 
					
						
							|  |  |  |                         'currency_decimal_places' => $piggy['currency_decimal_places'], | 
					
						
							|  |  |  |                     ]; | 
					
						
							|  |  |  |                 // target_amount
 | 
					
						
							|  |  |  |                 // current_amount
 | 
					
						
							|  |  |  |                 // left_to_save
 | 
					
						
							|  |  |  |                 // save_per_month
 | 
					
						
							| 
									
										
										
										
											2022-03-29 14:58:06 +02:00
										 |  |  |                 $sums[$groupId][$currencyId]['target']         = bcadd($sums[$groupId][$currencyId]['target'], (string) $piggy['target_amount']); | 
					
						
							|  |  |  |                 $sums[$groupId][$currencyId]['saved']          = bcadd($sums[$groupId][$currencyId]['saved'], (string) $piggy['current_amount']); | 
					
						
							|  |  |  |                 $sums[$groupId][$currencyId]['left_to_save']   = bcadd($sums[$groupId][$currencyId]['left_to_save'], (string) $piggy['left_to_save']); | 
					
						
							|  |  |  |                 $sums[$groupId][$currencyId]['save_per_month'] = bcadd($sums[$groupId][$currencyId]['save_per_month'], (string) $piggy['save_per_month']); | 
					
						
							| 
									
										
										
										
											2020-06-20 18:57:20 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         foreach ($piggyBanks as $groupOrder => $group) { | 
					
						
							|  |  |  |             $groupId                         = $group['object_group_id']; | 
					
						
							| 
									
										
										
										
											2020-06-23 15:30:02 +02:00
										 |  |  |             $piggyBanks[$groupOrder]['sums'] = $sums[$groupId] ?? []; | 
					
						
							| 
									
										
										
										
											2020-06-20 18:57:20 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $piggyBanks; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Set the order of a piggy bank. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Request   $request | 
					
						
							|  |  |  |      * @param PiggyBank $piggyBank | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function setOrder(Request $request, PiggyBank $piggyBank): JsonResponse | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2022-03-29 14:58:06 +02:00
										 |  |  |         $objectGroupTitle = (string) $request->get('objectGroupTitle'); | 
					
						
							|  |  |  |         $newOrder         = (int) $request->get('order'); | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  |         $this->piggyRepos->setOrder($piggyBank, $newOrder); | 
					
						
							| 
									
										
										
										
											2020-06-09 17:16:21 +02:00
										 |  |  |         if ('' !== $objectGroupTitle) { | 
					
						
							|  |  |  |             $this->piggyRepos->setObjectGroup($piggyBank, $objectGroupTitle); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ('' === $objectGroupTitle) { | 
					
						
							|  |  |  |             $this->piggyRepos->removeObjectGroup($piggyBank); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-06-07 11:30:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return response()->json(['data' => 'OK']); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |