mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 13:36:15 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			194 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			194 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * BulkController.php
 | |
|  * Copyright (c) 2019 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\Http\Controllers\Transaction;
 | |
| 
 | |
| use FireflyIII\Events\UpdatedTransactionGroup;
 | |
| use FireflyIII\Http\Controllers\Controller;
 | |
| use FireflyIII\Http\Requests\BulkEditJournalRequest;
 | |
| use FireflyIII\Models\TransactionJournal;
 | |
| use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
 | |
| use FireflyIII\Repositories\Journal\JournalRepositoryInterface;
 | |
| use Illuminate\Contracts\Foundation\Application;
 | |
| use Illuminate\Contracts\View\Factory;
 | |
| use Illuminate\Http\RedirectResponse;
 | |
| use Illuminate\Routing\Redirector;
 | |
| use Illuminate\Support\Collection;
 | |
| use Illuminate\View\View;
 | |
| 
 | |
| /**
 | |
|  * Class BulkController
 | |
|  */
 | |
| class BulkController extends Controller
 | |
| {
 | |
|     /** @var JournalRepositoryInterface Journals and transactions overview */
 | |
|     private $repository;
 | |
| 
 | |
|     /**
 | |
|      * BulkController constructor.
 | |
|      *
 | |
| 
 | |
|      */
 | |
|     public function __construct()
 | |
|     {
 | |
|         parent::__construct();
 | |
| 
 | |
|         $this->middleware(
 | |
|             function ($request, $next) {
 | |
|                 $this->repository = app(JournalRepositoryInterface::class);
 | |
|                 app('view')->share('title', (string)trans('firefly.transactions'));
 | |
|                 app('view')->share('mainTitleIcon', 'fa-exchange');
 | |
| 
 | |
|                 return $next($request);
 | |
|             }
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Edit a set of journals in bulk.
 | |
|      *
 | |
|      * TODO user wont be able to tell if the journal is part of a split.
 | |
|      *
 | |
|      * @param array $journals
 | |
|      *
 | |
|      * @return Factory|View
 | |
|      */
 | |
|     public function edit(array $journals)
 | |
|     {
 | |
|         $subTitle = (string)trans('firefly.mass_bulk_journals');
 | |
| 
 | |
|         $this->rememberPreviousUrl('transactions.bulk-edit.url');
 | |
| 
 | |
|         // make amounts positive.
 | |
| 
 | |
|         // get list of budgets:
 | |
|         /** @var BudgetRepositoryInterface $budgetRepos */
 | |
|         $budgetRepos = app(BudgetRepositoryInterface::class);
 | |
|         $budgetList  = app('expandedform')->makeSelectListWithEmpty($budgetRepos->getActiveBudgets());
 | |
| 
 | |
|         return view('transactions.bulk.edit', compact('journals', 'subTitle', 'budgetList'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Update all journals.
 | |
|      *
 | |
|      * @param BulkEditJournalRequest $request
 | |
|      *
 | |
|      * @return Application|RedirectResponse|Redirector
 | |
|      */
 | |
|     public function update(BulkEditJournalRequest $request)
 | |
|     {
 | |
|         $journalIds     = $request->get('journals');
 | |
|         $journalIds     = is_array($journalIds) ? $journalIds : [];
 | |
|         $ignoreCategory = 1 === (int)$request->get('ignore_category');
 | |
|         $ignoreBudget   = 1 === (int)$request->get('ignore_budget');
 | |
|         $tagsAction     = $request->get('tags_action');
 | |
|         $collection     = new Collection();
 | |
|         $count          = 0;
 | |
| 
 | |
|         foreach ($journalIds as $journalId) {
 | |
|             $journalId = (int)$journalId;
 | |
|             $journal   = $this->repository->find($journalId);
 | |
|             if (null !== $journal) {
 | |
|                 $resultA = $this->updateJournalBudget($journal, $ignoreBudget, $request->integer('budget_id'));
 | |
|                 $resultB = $this->updateJournalTags($journal, $tagsAction, explode(',', $request->convertString('tags')));
 | |
|                 $resultC = $this->updateJournalCategory($journal, $ignoreCategory, $request->convertString('category'));
 | |
|                 if ($resultA || $resultB || $resultC) {
 | |
|                     $count++;
 | |
|                     $collection->push($journal);
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         // run rules on changed journals:
 | |
|         /** @var TransactionJournal $journal */
 | |
|         foreach ($collection as $journal) {
 | |
|             event(new UpdatedTransactionGroup($journal->transactionGroup, true, true));
 | |
|         }
 | |
| 
 | |
|         app('preferences')->mark();
 | |
|         $request->session()->flash('success', trans_choice('firefly.mass_edited_transactions_success', $count));
 | |
| 
 | |
|         // redirect to previous URL:
 | |
|         return redirect($this->getPreviousUrl('transactions.bulk-edit.url'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param TransactionJournal $journal
 | |
|      * @param bool               $ignoreUpdate
 | |
|      * @param int                $budgetId
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     private function updateJournalBudget(TransactionJournal $journal, bool $ignoreUpdate, int $budgetId): bool
 | |
|     {
 | |
|         if (true === $ignoreUpdate) {
 | |
|             return false;
 | |
|         }
 | |
|         app('log')->debug(sprintf('Set budget to %d', $budgetId));
 | |
|         $this->repository->updateBudget($journal, $budgetId);
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param TransactionJournal $journal
 | |
|      * @param string             $action
 | |
|      * @param array              $tags
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     private function updateJournalTags(TransactionJournal $journal, string $action, array $tags): bool
 | |
|     {
 | |
|         if ('do_replace' === $action) {
 | |
|             app('log')->debug(sprintf('Set tags to %s', implode(',', $tags)));
 | |
|             $this->repository->updateTags($journal, $tags);
 | |
|         }
 | |
|         if ('do_append' === $action) {
 | |
|             $existing = $journal->tags->pluck('tag')->toArray();
 | |
|             $new      = array_unique(array_merge($tags, $existing));
 | |
|             $this->repository->updateTags($journal, $new);
 | |
|         }
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @param TransactionJournal $journal
 | |
|      * @param bool               $ignoreUpdate
 | |
|      * @param string             $category
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     private function updateJournalCategory(TransactionJournal $journal, bool $ignoreUpdate, string $category): bool
 | |
|     {
 | |
|         if (true === $ignoreUpdate) {
 | |
|             return false;
 | |
|         }
 | |
|         app('log')->debug(sprintf('Set budget to %s', $category));
 | |
|         $this->repository->updateCategory($journal, $category);
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| }
 |