mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 13:10:35 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			427 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			427 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * RenderPartialViews.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\Support\Http\Controllers;
 | |
| 
 | |
| use FireflyIII\Helpers\Report\PopupReportInterface;
 | |
| use FireflyIII\Models\Account;
 | |
| use FireflyIII\Models\AccountType;
 | |
| use FireflyIII\Models\Budget;
 | |
| use FireflyIII\Models\Rule;
 | |
| use FireflyIII\Models\RuleAction;
 | |
| use FireflyIII\Models\RuleTrigger;
 | |
| use FireflyIII\Repositories\Account\AccountRepositoryInterface;
 | |
| use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
 | |
| use FireflyIII\Repositories\Category\CategoryRepositoryInterface;
 | |
| use FireflyIII\Repositories\Tag\TagRepositoryInterface;
 | |
| use Log;
 | |
| use Throwable;
 | |
| 
 | |
| /**
 | |
|  * Trait RenderPartialViews
 | |
|  *
 | |
|  */
 | |
| trait RenderPartialViews
 | |
| {
 | |
| 
 | |
|     /**
 | |
|      * Get options for double report.
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function doubleReportOptions(): string // render a view
 | |
|     {
 | |
|         /** @var AccountRepositoryInterface $repository */
 | |
|         $repository = app(AccountRepositoryInterface::class);
 | |
|         $expense    = $repository->getActiveAccountsByType([AccountType::EXPENSE, AccountType::LOAN, AccountType::DEBT, AccountType::MORTGAGE]);
 | |
|         $revenue    = $repository->getActiveAccountsByType([AccountType::REVENUE, AccountType::LOAN, AccountType::DEBT, AccountType::MORTGAGE]);
 | |
|         $set        = [];
 | |
| 
 | |
|         /** @var Account $account */
 | |
|         foreach ($expense as $account) {
 | |
|             // loop revenue, find same account:
 | |
|             /** @var Account $otherAccount */
 | |
|             foreach ($revenue as $otherAccount) {
 | |
|                 if (
 | |
|                     (
 | |
|                     ($otherAccount->name === $account->name)
 | |
|                     ||
 | |
|                     (null !== $account->iban && null !== $otherAccount->iban && $otherAccount->iban === $account->iban)
 | |
|                     )
 | |
|                     && $otherAccount->id !== $account->id
 | |
|                 ) {
 | |
|                     $set[] = $account;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $result = view('reports.options.double', compact('set'))->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Cannot render reports.options.tag: %s', $e->getMessage()));
 | |
|             $result = 'Could not render view.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $result;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * View for transactions in a budget for an account.
 | |
|      *
 | |
|      * @param array $attributes
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function budgetEntry(array $attributes): string // generate view for report.
 | |
|     {
 | |
|         /** @var PopupReportInterface $popupHelper */
 | |
|         $popupHelper = app(PopupReportInterface::class);
 | |
| 
 | |
|         /** @var BudgetRepositoryInterface $budgetRepository */
 | |
|         $budgetRepository = app(BudgetRepositoryInterface::class);
 | |
|         $budget           = $budgetRepository->findNull((int)$attributes['budgetId']);
 | |
| 
 | |
|         $accountRepos = app(AccountRepositoryInterface::class);
 | |
|         $account      = $accountRepos->findNull((int)$attributes['accountId']);
 | |
| 
 | |
|         $journals = $popupHelper->balanceForBudget($budget, $account, $attributes);
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $view = view('popup.report.balance-amount', compact('journals', 'budget', 'account'))->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Could not render: %s', $e->getMessage()));
 | |
|             $view = 'Firefly III could not render the view. Please see the log files.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $view;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get options for budget report.
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function budgetReportOptions(): string // render a view
 | |
|     {
 | |
|         /** @var BudgetRepositoryInterface $repository */
 | |
|         $repository = app(BudgetRepositoryInterface::class);
 | |
|         $budgets    = $repository->getBudgets();
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $result = view('reports.options.budget', compact('budgets'))->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Cannot render reports.options.tag: %s', $e->getMessage()));
 | |
|             $result = 'Could not render view.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $result;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * View for spent in a single budget.
 | |
|      *
 | |
|      * @param array $attributes
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function budgetSpentAmount(array $attributes): string // generate view for report.
 | |
|     {
 | |
|         /** @var BudgetRepositoryInterface $budgetRepository */
 | |
|         $budgetRepository = app(BudgetRepositoryInterface::class);
 | |
| 
 | |
|         /** @var PopupReportInterface $popupHelper */
 | |
|         $popupHelper = app(PopupReportInterface::class);
 | |
| 
 | |
|         $budget = $budgetRepository->findNull((int)$attributes['budgetId']);
 | |
|         if (null === $budget) {
 | |
|             $budget = new Budget;
 | |
|         }
 | |
|         $journals = $popupHelper->byBudget($budget, $attributes);
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $view = view('popup.report.budget-spent-amount', compact('journals', 'budget'))->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Could not render: %s', $e->getMessage()));
 | |
|             $view = 'Firefly III could not render the view. Please see the log files.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $view;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * View for transactions in a category.
 | |
|      *
 | |
|      * @param array $attributes
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function categoryEntry(array $attributes): string // generate view for report.
 | |
|     {
 | |
|         /** @var PopupReportInterface $popupHelper */
 | |
|         $popupHelper = app(PopupReportInterface::class);
 | |
| 
 | |
|         /** @var CategoryRepositoryInterface $categoryRepository */
 | |
|         $categoryRepository = app(CategoryRepositoryInterface::class);
 | |
|         $category           = $categoryRepository->findNull((int)$attributes['categoryId']);
 | |
|         $journals           = $popupHelper->byCategory($category, $attributes);
 | |
|         if (null === $category) {
 | |
|             return 'This is an unknown category. Apologies.';
 | |
|         }
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $view = view('popup.report.category-entry', compact('journals', 'category'))->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Could not render: %s', $e->getMessage()));
 | |
|             $view = 'Firefly III could not render the view. Please see the log files.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $view;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get options for category report.
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function categoryReportOptions(): string // render a view
 | |
|     {
 | |
|         /** @var CategoryRepositoryInterface $repository */
 | |
|         $repository = app(CategoryRepositoryInterface::class);
 | |
|         $categories = $repository->getCategories();
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $result = view('reports.options.category', compact('categories'))->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Cannot render reports.options.category: %s', $e->getMessage()));
 | |
|             $result = 'Could not render view.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $result;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns all the expenses that went to the given expense account.
 | |
|      *
 | |
|      * @param array $attributes
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function expenseEntry(array $attributes): string // generate view for report.
 | |
|     {
 | |
|         /** @var AccountRepositoryInterface $accountRepository */
 | |
|         $accountRepository = app(AccountRepositoryInterface::class);
 | |
| 
 | |
|         /** @var PopupReportInterface $popupHelper */
 | |
|         $popupHelper = app(PopupReportInterface::class);
 | |
| 
 | |
|         $account = $accountRepository->findNull((int)$attributes['accountId']);
 | |
| 
 | |
|         if (null === $account) {
 | |
|             return 'This is an unknown account. Apologies.';
 | |
|         }
 | |
| 
 | |
|         $journals = $popupHelper->byExpenses($account, $attributes);
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $view = view('popup.report.expense-entry', compact('journals', 'account'))->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Could not render: %s', $e->getMessage()));
 | |
|             $view = 'Firefly III could not render the view. Please see the log files.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $view;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get current (from system) rule actions.
 | |
|      *
 | |
|      * @param Rule $rule
 | |
|      *
 | |
|      * @return array
 | |
|      */
 | |
|     protected function getCurrentActions(Rule $rule): array // get info from object and present.
 | |
|     {
 | |
|         $index   = 0;
 | |
|         $actions = [];
 | |
|         // todo must be repos
 | |
|         $currentActions = $rule->ruleActions()->orderBy('order', 'ASC')->get();
 | |
|         /** @var RuleAction $entry */
 | |
|         foreach ($currentActions as $entry) {
 | |
|             $count = ($index + 1);
 | |
|             try {
 | |
|                 $actions[] = view(
 | |
|                     'rules.partials.action',
 | |
|                     [
 | |
|                         'oldAction'  => $entry->action_type,
 | |
|                         'oldValue'   => $entry->action_value,
 | |
|                         'oldChecked' => $entry->stop_processing,
 | |
|                         'count'      => $count,
 | |
|                     ]
 | |
|                 )->render();
 | |
|                 // @codeCoverageIgnoreStart
 | |
|             } catch (Throwable $e) {
 | |
|                 Log::debug(sprintf('Throwable was thrown in getCurrentActions(): %s', $e->getMessage()));
 | |
|                 Log::error($e->getTraceAsString());
 | |
|             }
 | |
|             // @codeCoverageIgnoreEnd
 | |
|             ++$index;
 | |
|         }
 | |
| 
 | |
|         return $actions;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get current (from DB) rule triggers.
 | |
|      *
 | |
|      * @param Rule $rule
 | |
|      *
 | |
|      * @return array
 | |
|      *
 | |
|      */
 | |
|     protected function getCurrentTriggers(Rule $rule): array // get info from object and present.
 | |
|     {
 | |
|         $index    = 0;
 | |
|         $triggers = [];
 | |
|         // todo must be repos
 | |
|         $currentTriggers = $rule->ruleTriggers()->orderBy('order', 'ASC')->get();
 | |
|         /** @var RuleTrigger $entry */
 | |
|         foreach ($currentTriggers as $entry) {
 | |
|             if ('user_action' !== $entry->trigger_type) {
 | |
|                 $count = ($index + 1);
 | |
|                 try {
 | |
|                     $triggers[] = view(
 | |
|                         'rules.partials.trigger',
 | |
|                         [
 | |
|                             'oldTrigger' => $entry->trigger_type,
 | |
|                             'oldValue'   => $entry->trigger_value,
 | |
|                             'oldChecked' => $entry->stop_processing,
 | |
|                             'count'      => $count,
 | |
|                         ]
 | |
|                     )->render();
 | |
|                     // @codeCoverageIgnoreStart
 | |
|                 } catch (Throwable $e) {
 | |
|                     Log::debug(sprintf('Throwable was thrown in getCurrentTriggers(): %s', $e->getMessage()));
 | |
|                     Log::error($e->getTraceAsString());
 | |
|                 }
 | |
|                 // @codeCoverageIgnoreEnd
 | |
|                 ++$index;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return $triggers;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns all the incomes that went to the given asset account.
 | |
|      *
 | |
|      * @param array $attributes
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function incomeEntry(array $attributes): string // generate view for report.
 | |
|     {
 | |
|         /** @var AccountRepositoryInterface $accountRepository */
 | |
|         $accountRepository = app(AccountRepositoryInterface::class);
 | |
| 
 | |
|         /** @var PopupReportInterface $popupHelper */
 | |
|         $popupHelper = app(PopupReportInterface::class);
 | |
|         $account     = $accountRepository->findNull((int)$attributes['accountId']);
 | |
| 
 | |
|         if (null === $account) {
 | |
|             return 'This is an unknown category. Apologies.';
 | |
|         }
 | |
| 
 | |
|         $journals = $popupHelper->byIncome($account, $attributes);
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $view = view('popup.report.income-entry', compact('journals', 'account'))->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Could not render: %s', $e->getMessage()));
 | |
|             $view = 'Firefly III could not render the view. Please see the log files.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $view;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get options for default report.
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function noReportOptions(): string // render a view
 | |
|     {
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $result = view('reports.options.no-options')->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Cannot render reports.options.no-options: %s', $e->getMessage()));
 | |
|             $result = 'Could not render view.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $result;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get options for tag report.
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function tagReportOptions(): string // render a view
 | |
|     {
 | |
|         /** @var TagRepositoryInterface $repository */
 | |
|         $repository = app(TagRepositoryInterface::class);
 | |
|         $tags       = $repository->get();
 | |
| 
 | |
|         // @codeCoverageIgnoreStart
 | |
|         try {
 | |
|             $result = view('reports.options.tag', compact('tags'))->render();
 | |
|         } catch (Throwable $e) {
 | |
|             Log::error(sprintf('Cannot render reports.options.tag: %s', $e->getMessage()));
 | |
|             $result = 'Could not render view.';
 | |
|         }
 | |
| 
 | |
|         // @codeCoverageIgnoreEnd
 | |
| 
 | |
|         return $result;
 | |
|     }
 | |
| }
 |