. */ declare(strict_types=1); namespace FireflyIII\Helpers\Report; use FireflyIII\Helpers\Collector\GroupCollectorInterface; use FireflyIII\Models\Account; use FireflyIII\Models\Budget; use FireflyIII\Models\Category; use FireflyIII\Models\TransactionType; use FireflyIII\Repositories\Account\AccountRepositoryInterface; use FireflyIII\Repositories\Currency\CurrencyRepositoryInterface; use FireflyIII\Repositories\Journal\JournalRepositoryInterface; use Illuminate\Support\Collection; use Log; /** * Class PopupReport. * * @codeCoverageIgnore */ class PopupReport implements PopupReportInterface { /** * Collect the transactions for one account and one budget. * * @param Budget $budget * @param Account $account * @param array $attributes * * @return array */ public function balanceForBudget(Budget $budget, Account $account, array $attributes): array { /** @var GroupCollectorInterface $collector */ $collector = app(GroupCollectorInterface::class); $collector->setAccounts(new Collection([$account])) ->withAccountInformation() ->withBudgetInformation() ->withCategoryInformation() ->setRange($attributes['startDate'], $attributes['endDate'])->setBudget($budget); return $collector->getExtractedJournals(); } /** * Collect the transactions for one account and no budget. * * @param Account $account * @param array $attributes * * @return array */ public function balanceForNoBudget(Account $account, array $attributes): array { // filter by currency, if set. $currencyId = $attributes['currencyId'] ?? null; $currency = null; if (null !== $currencyId) { /** @var CurrencyRepositoryInterface $repos */ $repos = app(CurrencyRepositoryInterface::class); $currency = $repos->find((int) $currencyId); } /** @var GroupCollectorInterface $collector */ $collector = app(GroupCollectorInterface::class); $collector ->setAccounts(new Collection([$account])) ->setTypes([TransactionType::WITHDRAWAL]) ->withAccountInformation() ->withCategoryInformation() ->setRange($attributes['startDate'], $attributes['endDate']) ->withoutBudget(); if (null !== $currency) { $collector->setCurrency($currency); } return $collector->getExtractedJournals(); } /** * Collect the transactions for a budget. * * @param Budget $budget * @param array $attributes * * @return array */ public function byBudget(Budget $budget, array $attributes): array { // filter by currency, if set. $currencyId = $attributes['currencyId'] ?? null; $currency = null; if (null !== $currencyId) { /** @var CurrencyRepositoryInterface $repos */ $repos = app(CurrencyRepositoryInterface::class); $currency = $repos->find((int) $currencyId); } /** @var GroupCollectorInterface $collector */ $collector = app(GroupCollectorInterface::class); $collector->setAccounts($attributes['accounts']) ->withAccountInformation() ->withBudgetInformation() ->withCategoryInformation() ->setRange($attributes['startDate'], $attributes['endDate']); if (null !== $currency) { $collector->setCurrency($currency); } if (null === $budget->id) { $collector->setTypes([TransactionType::WITHDRAWAL])->withoutBudget(); } if (null !== $budget->id) { $collector->setBudget($budget); } return $collector->getExtractedJournals(); } /** * Collect journals by a category. * * @param Category|null $category * @param array $attributes * * @return array */ public function byCategory(?Category $category, array $attributes): array { // filter by currency, if set. $currencyId = $attributes['currencyId'] ?? null; $currency = null; if (null !== $currencyId) { /** @var CurrencyRepositoryInterface $repos */ $repos = app(CurrencyRepositoryInterface::class); $currency = $repos->find((int) $currencyId); } /** @var GroupCollectorInterface $collector */ $collector = app(GroupCollectorInterface::class); $collector->setAccounts($attributes['accounts']) ->setTypes([TransactionType::WITHDRAWAL, TransactionType::TRANSFER, TransactionType::DEPOSIT]) ->withAccountInformation() ->withBudgetInformation() ->withCategoryInformation() ->setRange($attributes['startDate'], $attributes['endDate'])->withAccountInformation(); if (null !== $category) { $collector->setCategory($category); } if (null === $category) { $collector->withoutCategory(); } if (null !== $currency) { $collector->setCurrency($currency); } return $collector->getExtractedJournals(); } /** * Group transactions by expense. * * @param Account $account * @param array $attributes * * @return array */ public function byExpenses(Account $account, array $attributes): array { // filter by currency, if set. $currencyId = $attributes['currencyId'] ?? null; $currency = null; if (null !== $currencyId) { /** @var CurrencyRepositoryInterface $repos */ $repos = app(CurrencyRepositoryInterface::class); $currency = $repos->find((int) $currencyId); } /** @var JournalRepositoryInterface $repository */ $repository = app(JournalRepositoryInterface::class); $repository->setUser($account->user); $accountRepository = app(AccountRepositoryInterface::class); $accountRepository->setUser($account->user); /** @var GroupCollectorInterface $collector */ $collector = app(GroupCollectorInterface::class); // set report accounts + the request accounts: $set = $attributes['accounts'] ?? new Collection; $set->push($account); $collector->setBothAccounts($set) ->setRange($attributes['startDate'], $attributes['endDate']) ->withAccountInformation() ->withBudgetInformation() ->withCategoryInformation() ->setTypes([TransactionType::WITHDRAWAL, TransactionType::TRANSFER]); if (null !== $currency) { $collector->setCurrency($currency); } return $collector->getExtractedJournals(); } /** * Collect transactions by income. * * @param Account $account * @param array $attributes * * @return array */ public function byIncome(Account $account, array $attributes): array { /** @var JournalRepositoryInterface $repository */ $repository = app(JournalRepositoryInterface::class); $repository->setUser($account->user); /** @var GroupCollectorInterface $collector */ $collector = app(GroupCollectorInterface::class); $collector ->setSourceAccounts(new Collection([$account])) ->setDestinationAccounts($attributes['accounts']) ->setRange($attributes['startDate'], $attributes['endDate']) ->setTypes([TransactionType::DEPOSIT, TransactionType::TRANSFER]) ->withAccountInformation() ->withBudgetInformation() ->withCategoryInformation() ->withAccountInformation(); return $collector->getExtractedJournals(); } }