mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 21:16:47 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			265 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			265 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * AutoCompleteController.php
 | |
|  * Copyright (c) 2017 thegrumpydictator@gmail.com
 | |
|  *
 | |
|  * This file is part of Firefly III.
 | |
|  *
 | |
|  * 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
 | |
|  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| declare(strict_types=1);
 | |
| 
 | |
| namespace FireflyIII\Http\Controllers\Json;
 | |
| 
 | |
| use FireflyIII\Helpers\Collector\JournalCollectorInterface;
 | |
| use FireflyIII\Http\Controllers\Controller;
 | |
| use FireflyIII\Models\Account;
 | |
| use FireflyIII\Models\AccountType;
 | |
| use FireflyIII\Models\TransactionJournal;
 | |
| use FireflyIII\Repositories\Account\AccountRepositoryInterface;
 | |
| use FireflyIII\Repositories\Bill\BillRepositoryInterface;
 | |
| use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
 | |
| use FireflyIII\Repositories\Category\CategoryRepositoryInterface;
 | |
| use FireflyIII\Repositories\Currency\CurrencyRepositoryInterface;
 | |
| use FireflyIII\Repositories\Journal\JournalRepositoryInterface;
 | |
| use FireflyIII\Repositories\Tag\TagRepositoryInterface;
 | |
| use FireflyIII\Support\CacheProperties;
 | |
| use Illuminate\Http\JsonResponse;
 | |
| 
 | |
| /**
 | |
|  * Class AutoCompleteController.
 | |
|  */
 | |
| class AutoCompleteController extends Controller
 | |
| {
 | |
| 
 | |
|     /**
 | |
|      * Returns a JSON list of all accounts.
 | |
|      *
 | |
|      * @param AccountRepositoryInterface $repository
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function allAccounts(AccountRepositoryInterface $repository)
 | |
|     {
 | |
|         $return = array_unique(
 | |
|             $repository->getAccountsByType(
 | |
|                 [AccountType::REVENUE, AccountType::EXPENSE, AccountType::BENEFICIARY, AccountType::DEFAULT, AccountType::ASSET]
 | |
|             )->pluck('name')->toArray()
 | |
|         );
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param JournalCollectorInterface $collector
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function allTransactionJournals(JournalCollectorInterface $collector): JsonResponse
 | |
|     {
 | |
|         $collector->setLimit(250)->setPage(1);
 | |
|         $return = array_unique($collector->getJournals()->pluck('description')->toArray());
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns a JSON list of all bills.
 | |
|      *
 | |
|      * @param BillRepositoryInterface $repository
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function bills(BillRepositoryInterface $repository): JsonResponse
 | |
|     {
 | |
|         $return = array_unique(
 | |
|             $repository->getActiveBills()->pluck('name')->toArray()
 | |
|         );
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param BudgetRepositoryInterface $repository
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function budgets(BudgetRepositoryInterface $repository)
 | |
|     {
 | |
|         $return = array_unique($repository->getBudgets()->pluck('name')->toArray());
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns a list of categories.
 | |
|      *
 | |
|      * @param CategoryRepositoryInterface $repository
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function categories(CategoryRepositoryInterface $repository)
 | |
|     {
 | |
|         $return = array_unique($repository->getCategories()->pluck('name')->toArray());
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param CurrencyRepositoryInterface $repository
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function currencyNames(CurrencyRepositoryInterface $repository)
 | |
|     {
 | |
|         $return = $repository->get()->pluck('name')->toArray();
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns a JSON list of all beneficiaries.
 | |
|      *
 | |
|      * @param AccountRepositoryInterface $repository
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function expenseAccounts(AccountRepositoryInterface $repository)
 | |
|     {
 | |
|         $set      = $repository->getAccountsByType([AccountType::EXPENSE, AccountType::BENEFICIARY]);
 | |
|         $filtered = $set->filter(
 | |
|             function (Account $account) {
 | |
|                 if ($account->active === true) {
 | |
|                     return $account;
 | |
|                 }
 | |
| 
 | |
|                 return false;
 | |
|             }
 | |
|         );
 | |
|         $return   = array_unique($filtered->pluck('name')->toArray());
 | |
| 
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param JournalCollectorInterface $collector
 | |
|      * @param TransactionJournal        $except
 | |
|      *
 | |
|      * @return JsonResponse|mixed
 | |
|      */
 | |
|     public function journalsWithId(JournalCollectorInterface $collector, TransactionJournal $except)
 | |
|     {
 | |
|         $cache = new CacheProperties;
 | |
|         $cache->addProperty('recent-journals-id');
 | |
| 
 | |
|         if ($cache->has()) {
 | |
|             return $cache->get(); // @codeCoverageIgnore
 | |
|         }
 | |
| 
 | |
|         $collector->setLimit(400)->setPage(1);
 | |
|         $set    = $collector->getJournals()->pluck('description', 'journal_id')->toArray();
 | |
|         $return = [];
 | |
|         foreach ($set as $id => $description) {
 | |
|             $id = (int)$id;
 | |
|             if ($id !== $except->id) {
 | |
|                 $return[] = [
 | |
|                     'id'   => $id,
 | |
|                     'name' => $id . ': ' . $description,
 | |
|                 ];
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         $cache->store($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param AccountRepositoryInterface $repository
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function revenueAccounts(AccountRepositoryInterface $repository)
 | |
|     {
 | |
|         $set      = $repository->getAccountsByType([AccountType::REVENUE]);
 | |
|         $filtered = $set->filter(
 | |
|             function (Account $account) {
 | |
|                 if ($account->active === true) {
 | |
|                     return $account;
 | |
|                 }
 | |
| 
 | |
|                 return false;
 | |
|             }
 | |
|         );
 | |
|         $return   = array_unique($filtered->pluck('name')->toArray());
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns a JSON list of all beneficiaries.
 | |
|      *
 | |
|      * @param TagRepositoryInterface $tagRepository
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function tags(TagRepositoryInterface $tagRepository)
 | |
|     {
 | |
|         $return = array_unique($tagRepository->get()->pluck('tag')->toArray());
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param JournalCollectorInterface $collector
 | |
|      * @param string                    $what
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function transactionJournals(JournalCollectorInterface $collector, string $what)
 | |
|     {
 | |
|         $type  = config('firefly.transactionTypesByWhat.' . $what);
 | |
|         $types = [$type];
 | |
| 
 | |
|         $collector->setTypes($types)->setLimit(250)->setPage(1);
 | |
|         $return = array_unique($collector->getJournals()->pluck('description')->toArray());
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param JournalRepositoryInterface $repository
 | |
|      *
 | |
|      * @return JsonResponse
 | |
|      */
 | |
|     public function transactionTypes(JournalRepositoryInterface $repository)
 | |
|     {
 | |
|         $return = array_unique($repository->getTransactionTypes()->pluck('type')->toArray());
 | |
|         sort($return);
 | |
| 
 | |
|         return response()->json($return);
 | |
|     }
 | |
| }
 |