| 
									
										
										
										
											2020-07-21 06:09:24 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2024-11-25 04:18:55 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-21 06:09:24 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * PiggyBankController.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/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Api\V1\Controllers\Autocomplete; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use FireflyIII\Api\V1\Controllers\Controller; | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  | use FireflyIII\Api\V1\Requests\Autocomplete\AutocompleteRequest; | 
					
						
							| 
									
										
										
										
											2025-08-15 19:50:12 +02:00
										 |  |  | use FireflyIII\Enums\UserRoleEnum; | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  | use FireflyIII\Models\PiggyBank; | 
					
						
							| 
									
										
										
										
											2025-09-27 05:57:58 +02:00
										 |  |  | use FireflyIII\Models\TransactionCurrency; | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  | use FireflyIII\Repositories\Account\AccountRepositoryInterface; | 
					
						
							|  |  |  | use FireflyIII\Repositories\PiggyBank\PiggyBankRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2025-09-27 05:57:58 +02:00
										 |  |  | use FireflyIII\Support\Facades\Amount; | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  | use Illuminate\Http\JsonResponse; | 
					
						
							| 
									
										
										
										
											2020-07-21 06:09:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class PiggyBankController | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class PiggyBankController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-09-18 05:26:31 +02:00
										 |  |  |     private AccountRepositoryInterface   $accountRepository; | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |     private PiggyBankRepositoryInterface $piggyRepository; | 
					
						
							| 
									
										
										
										
											2025-08-15 19:50:12 +02:00
										 |  |  |     protected array $acceptedRoles = [UserRoleEnum::READ_PIGGY_BANKS]; | 
					
						
							| 
									
										
										
										
											2020-07-31 09:42:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * PiggyBankController constructor. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							| 
									
										
										
										
											2025-08-15 19:50:12 +02:00
										 |  |  |                 $this->validateUserGroup($request); | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |                 $this->piggyRepository   = app(PiggyBankRepositoryInterface::class); | 
					
						
							|  |  |  |                 $this->accountRepository = app(AccountRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2025-08-15 19:50:12 +02:00
										 |  |  |                 $this->piggyRepository->setUser($this->user); | 
					
						
							|  |  |  |                 $this->piggyRepository->setUserGroup($this->userGroup); | 
					
						
							|  |  |  |                 $this->accountRepository->setUser($this->user); | 
					
						
							|  |  |  |                 $this->accountRepository->setUserGroup($this->userGroup); | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function piggyBanks(AutocompleteRequest $request): JsonResponse | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-12-14 05:45:54 +01:00
										 |  |  |         $data     = $request->getData(); | 
					
						
							|  |  |  |         $piggies  = $this->piggyRepository->searchPiggyBank($data['query'], $this->parameters->get('limit')); | 
					
						
							|  |  |  |         $response = []; | 
					
						
							| 
									
										
										
										
											2020-07-23 06:19:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |         /** @var PiggyBank $piggy */ | 
					
						
							|  |  |  |         foreach ($piggies as $piggy) { | 
					
						
							| 
									
										
										
										
											2024-12-01 18:16:48 +01:00
										 |  |  |             $currency    = $piggy->transactionCurrency; | 
					
						
							| 
									
										
										
										
											2023-02-12 06:53:36 +01:00
										 |  |  |             $objectGroup = $piggy->objectGroups()->first(); | 
					
						
							|  |  |  |             $response[]  = [ | 
					
						
							| 
									
										
										
										
											2024-12-22 08:43:12 +01:00
										 |  |  |                 'id'                      => (string) $piggy->id, | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |                 'name'                    => $piggy->name, | 
					
						
							| 
									
										
										
										
											2024-12-22 08:43:12 +01:00
										 |  |  |                 'currency_id'             => (string) $currency->id, | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |                 'currency_name'           => $currency->name, | 
					
						
							|  |  |  |                 'currency_code'           => $currency->code, | 
					
						
							| 
									
										
										
										
											2021-09-18 05:26:31 +02:00
										 |  |  |                 'currency_symbol'         => $currency->symbol, | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |                 'currency_decimal_places' => $currency->decimal_places, | 
					
						
							| 
									
										
										
										
											2024-12-22 08:43:12 +01:00
										 |  |  |                 'object_group_id'         => null === $objectGroup ? null : (string) $objectGroup->id, | 
					
						
							| 
									
										
										
										
											2023-02-12 06:53:36 +01:00
										 |  |  |                 'object_group_title'      => $objectGroup?->title, | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |             ]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-25 04:48:51 +01:00
										 |  |  |         return response()->api($response); | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function piggyBanksWithBalance(AutocompleteRequest $request): JsonResponse | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-12-14 05:45:54 +01:00
										 |  |  |         $data     = $request->getData(); | 
					
						
							|  |  |  |         $piggies  = $this->piggyRepository->searchPiggyBank($data['query'], $this->parameters->get('limit')); | 
					
						
							|  |  |  |         $response = []; | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |         /** @var PiggyBank $piggy */ | 
					
						
							|  |  |  |         foreach ($piggies as $piggy) { | 
					
						
							| 
									
										
										
										
											2025-09-27 05:57:58 +02:00
										 |  |  |             /** @var TransactionCurrency $currency */ | 
					
						
							| 
									
										
										
										
											2024-12-01 18:16:48 +01:00
										 |  |  |             $currency      = $piggy->transactionCurrency; | 
					
						
							| 
									
										
										
										
											2024-12-15 08:50:57 +01:00
										 |  |  |             $currentAmount = $this->piggyRepository->getCurrentAmount($piggy); | 
					
						
							| 
									
										
										
										
											2023-02-12 06:53:36 +01:00
										 |  |  |             $objectGroup   = $piggy->objectGroups()->first(); | 
					
						
							| 
									
										
										
										
											2021-03-22 06:45:13 +01:00
										 |  |  |             $response[]    = [ | 
					
						
							| 
									
										
										
										
											2024-12-22 08:43:12 +01:00
										 |  |  |                 'id'                      => (string) $piggy->id, | 
					
						
							| 
									
										
										
										
											2024-01-01 14:36:31 +01:00
										 |  |  |                 'name'                    => $piggy->name, | 
					
						
							|  |  |  |                 'name_with_balance'       => sprintf( | 
					
						
							| 
									
										
										
										
											2022-10-30 14:23:00 +01:00
										 |  |  |                     '%s (%s / %s)', | 
					
						
							|  |  |  |                     $piggy->name, | 
					
						
							| 
									
										
										
										
											2025-09-27 05:57:58 +02:00
										 |  |  |                     Amount::formatAnything($currency, $currentAmount, false), | 
					
						
							|  |  |  |                     Amount::formatAnything($currency, $piggy->target_amount, false), | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |                 ), | 
					
						
							| 
									
										
										
										
											2024-12-22 08:43:12 +01:00
										 |  |  |                 'currency_id'             => (string) $currency->id, | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |                 'currency_name'           => $currency->name, | 
					
						
							|  |  |  |                 'currency_code'           => $currency->code, | 
					
						
							| 
									
										
										
										
											2021-09-18 05:26:31 +02:00
										 |  |  |                 'currency_symbol'         => $currency->symbol, | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |                 'currency_decimal_places' => $currency->decimal_places, | 
					
						
							| 
									
										
										
										
											2024-12-22 08:43:12 +01:00
										 |  |  |                 'object_group_id'         => null === $objectGroup ? null : (string) $objectGroup->id, | 
					
						
							| 
									
										
										
										
											2023-02-12 06:53:36 +01:00
										 |  |  |                 'object_group_title'      => $objectGroup?->title, | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |             ]; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-25 04:48:51 +01:00
										 |  |  |         return response()->api($response); | 
					
						
							| 
									
										
										
										
											2020-07-22 20:17:20 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-07-21 06:09:24 +02:00
										 |  |  | } |