mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 13:10:35 +00:00 
			
		
		
		
	Merge branch 'develop' of github.com:firefly-iii/firefly-iii into develop
# Conflicts: # app/Support/Http/Controllers/PeriodOverview.php
This commit is contained in:
		| @@ -94,12 +94,12 @@ trait PeriodOverview | ||||
|         $this->accountRepository->setUser($account->user); | ||||
|         $this->periodStatisticRepo = app(PeriodStatisticRepositoryInterface::class); | ||||
|         $range                     = Navigation::getViewRange(true); | ||||
|         [$start, $end] = $end < $start ? [$end, $start] : [$start, $end]; | ||||
|         [$start, $end]             = $end < $start ? [$end, $start] : [$start, $end]; | ||||
| 
 | ||||
|         /** @var array $dates */ | ||||
|         $dates = Navigation::blockPeriods($start, $end, $range); | ||||
|         [$start, $end] = $this->getPeriodFromBlocks($dates, $start, $end); | ||||
|         $this->statistics = $this->periodStatisticRepo->allInRangeForModel($account, $start, $end); | ||||
|         $dates                     = Navigation::blockPeriods($start, $end, $range); | ||||
|         [$start, $end]             = $this->getPeriodFromBlocks($dates, $start, $end); | ||||
|         $this->statistics          = $this->periodStatisticRepo->allInRangeForModel($account, $start, $end); | ||||
| 
 | ||||
|         // TODO needs to be re-arranged:
 | ||||
|         // get all period stats for entire range.
 | ||||
| @@ -107,7 +107,7 @@ trait PeriodOverview | ||||
|         // create new ones, or use collected.
 | ||||
| 
 | ||||
| 
 | ||||
|         $entries = []; | ||||
|         $entries                   = []; | ||||
|         Log::debug(sprintf('Count of loops: %d', count($dates))); | ||||
|         foreach ($dates as $currentDate) { | ||||
|             $entries[] = $this->getSingleAccountPeriod($account, $currentDate['period'], $currentDate['start'], $currentDate['end']); | ||||
| @@ -164,30 +164,29 @@ trait PeriodOverview | ||||
| 
 | ||||
|         return $entries; | ||||
| 
 | ||||
| 
 | ||||
|         // collect all expenses in this period:
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector     = app(GroupCollectorInterface::class); | ||||
|         $collector->setCategory($category); | ||||
|         $collector->setRange($start, $end); | ||||
|         $collector->setTypes([TransactionTypeEnum::DEPOSIT->value]); | ||||
|         $earnedSet = $collector->getExtractedJournals(); | ||||
|         $earnedSet     = $collector->getExtractedJournals(); | ||||
| 
 | ||||
|         // collect all income in this period:
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector     = app(GroupCollectorInterface::class); | ||||
|         $collector->setCategory($category); | ||||
|         $collector->setRange($start, $end); | ||||
|         $collector->setTypes([TransactionTypeEnum::WITHDRAWAL->value]); | ||||
|         $spentSet = $collector->getExtractedJournals(); | ||||
|         $spentSet      = $collector->getExtractedJournals(); | ||||
| 
 | ||||
|         // collect all transfers in this period:
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector     = app(GroupCollectorInterface::class); | ||||
|         $collector->setCategory($category); | ||||
|         $collector->setRange($start, $end); | ||||
|         $collector->setTypes([TransactionTypeEnum::TRANSFER->value]); | ||||
|         $transferSet = $collector->getExtractedJournals(); | ||||
|         $transferSet   = $collector->getExtractedJournals(); | ||||
|         foreach ($dates as $currentDate) { | ||||
|             $spent       = $this->filterJournalsByDate($spentSet, $currentDate['start'], $currentDate['end']); | ||||
|             $earned      = $this->filterJournalsByDate($earnedSet, $currentDate['start'], $currentDate['end']); | ||||
| @@ -195,17 +194,17 @@ trait PeriodOverview | ||||
|             $title       = Navigation::periodShow($currentDate['end'], $currentDate['period']); | ||||
|             $entries[] | ||||
|                          = [ | ||||
|                 'transactions'       => 0, | ||||
|                 'title'              => $title, | ||||
|                 'route'              => route( | ||||
|                     'categories.show', | ||||
|                     [$category->id, $currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')] | ||||
|                 ), | ||||
|                 'total_transactions' => count($spent) + count($earned) + count($transferred), | ||||
|                 'spent'              => $this->groupByCurrency($spent), | ||||
|                 'earned'             => $this->groupByCurrency($earned), | ||||
|                 'transferred'        => $this->groupByCurrency($transferred), | ||||
|             ]; | ||||
|                              'transactions'       => 0, | ||||
|                              'title'              => $title, | ||||
|                              'route'              => route( | ||||
|                                  'categories.show', | ||||
|                                  [$category->id, $currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')] | ||||
|                              ), | ||||
|                              'total_transactions' => count($spent) + count($earned) + count($transferred), | ||||
|                              'spent'              => $this->groupByCurrency($spent), | ||||
|                              'earned'             => $this->groupByCurrency($earned), | ||||
|                              'transferred'        => $this->groupByCurrency($transferred), | ||||
|                          ]; | ||||
|         } | ||||
| 
 | ||||
|         return $entries; | ||||
| @@ -220,11 +219,11 @@ trait PeriodOverview | ||||
|      */ | ||||
|     protected function getNoBudgetPeriodOverview(Carbon $start, Carbon $end): array | ||||
|     { | ||||
|         $range = Navigation::getViewRange(true); | ||||
|         $range         = Navigation::getViewRange(true); | ||||
| 
 | ||||
|         [$start, $end] = $end < $start ? [$end, $start] : [$start, $end]; | ||||
| 
 | ||||
|         $cache = new CacheProperties(); | ||||
|         $cache         = new CacheProperties(); | ||||
|         $cache->addProperty($start); | ||||
|         $cache->addProperty($end); | ||||
|         $cache->addProperty($this->convertToPrimary); | ||||
| @@ -235,28 +234,28 @@ trait PeriodOverview | ||||
|         } | ||||
| 
 | ||||
|         /** @var array $dates */ | ||||
|         $dates   = Navigation::blockPeriods($start, $end, $range); | ||||
|         $entries = []; | ||||
|         $dates         = Navigation::blockPeriods($start, $end, $range); | ||||
|         $entries       = []; | ||||
| 
 | ||||
|         // get all expenses without a budget.
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector     = app(GroupCollectorInterface::class); | ||||
|         $collector->setRange($start, $end)->withoutBudget()->withAccountInformation()->setTypes([TransactionTypeEnum::WITHDRAWAL->value]); | ||||
|         $journals = $collector->getExtractedJournals(); | ||||
|         $journals      = $collector->getExtractedJournals(); | ||||
| 
 | ||||
|         foreach ($dates as $currentDate) { | ||||
|             $set   = $this->filterJournalsByDate($journals, $currentDate['start'], $currentDate['end']); | ||||
|             $title = Navigation::periodShow($currentDate['end'], $currentDate['period']); | ||||
|             $entries[] | ||||
|                    = [ | ||||
|                 'title'              => $title, | ||||
|                 'route'              => route('budgets.no-budget', [$currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')]), | ||||
|                 'total_transactions' => count($set), | ||||
|                 'spent'              => $this->groupByCurrency($set), | ||||
|                 'earned'             => [], | ||||
|                 'transferred_away'   => [], | ||||
|                 'transferred_in'     => [], | ||||
|             ]; | ||||
|                        'title'              => $title, | ||||
|                        'route'              => route('budgets.no-budget', [$currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')]), | ||||
|                        'total_transactions' => count($set), | ||||
|                        'spent'              => $this->groupByCurrency($set), | ||||
|                        'earned'             => [], | ||||
|                        'transferred_away'   => [], | ||||
|                        'transferred_in'     => [], | ||||
|                    ]; | ||||
|         } | ||||
|         $cache->store($entries); | ||||
| 
 | ||||
| @@ -273,38 +272,38 @@ trait PeriodOverview | ||||
|     protected function getNoCategoryPeriodOverview(Carbon $theDate): array | ||||
|     { | ||||
|         Log::debug(sprintf('Now in getNoCategoryPeriodOverview(%s)', $theDate->format('Y-m-d'))); | ||||
|         $range = Navigation::getViewRange(true); | ||||
|         $first = $this->journalRepos->firstNull(); | ||||
|         $start = null === $first ? new Carbon() : $first->date; | ||||
|         $end   = clone $theDate; | ||||
|         $end   = Navigation::endOfPeriod($end, $range); | ||||
|         $range       = Navigation::getViewRange(true); | ||||
|         $first       = $this->journalRepos->firstNull(); | ||||
|         $start       = null === $first ? new Carbon() : $first->date; | ||||
|         $end         = clone $theDate; | ||||
|         $end         = Navigation::endOfPeriod($end, $range); | ||||
| 
 | ||||
|         Log::debug(sprintf('Start for getNoCategoryPeriodOverview() is %s', $start->format('Y-m-d'))); | ||||
|         Log::debug(sprintf('End for getNoCategoryPeriodOverview() is %s', $end->format('Y-m-d'))); | ||||
| 
 | ||||
|         // properties for cache
 | ||||
|         $dates   = Navigation::blockPeriods($start, $end, $range); | ||||
|         $entries = []; | ||||
|         $dates       = Navigation::blockPeriods($start, $end, $range); | ||||
|         $entries     = []; | ||||
| 
 | ||||
|         // collect all expenses in this period:
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector   = app(GroupCollectorInterface::class); | ||||
|         $collector->withoutCategory(); | ||||
|         $collector->setRange($start, $end); | ||||
|         $collector->setTypes([TransactionTypeEnum::DEPOSIT->value]); | ||||
|         $earnedSet = $collector->getExtractedJournals(); | ||||
|         $earnedSet   = $collector->getExtractedJournals(); | ||||
| 
 | ||||
|         // collect all income in this period:
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector   = app(GroupCollectorInterface::class); | ||||
|         $collector->withoutCategory(); | ||||
|         $collector->setRange($start, $end); | ||||
|         $collector->setTypes([TransactionTypeEnum::WITHDRAWAL->value]); | ||||
|         $spentSet = $collector->getExtractedJournals(); | ||||
|         $spentSet    = $collector->getExtractedJournals(); | ||||
| 
 | ||||
|         // collect all transfers in this period:
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector   = app(GroupCollectorInterface::class); | ||||
|         $collector->withoutCategory(); | ||||
|         $collector->setRange($start, $end); | ||||
|         $collector->setTypes([TransactionTypeEnum::TRANSFER->value]); | ||||
| @@ -318,13 +317,13 @@ trait PeriodOverview | ||||
|             $title       = Navigation::periodShow($currentDate['end'], $currentDate['period']); | ||||
|             $entries[] | ||||
|                          = [ | ||||
|                 'title'              => $title, | ||||
|                 'route'              => route('categories.no-category', [$currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')]), | ||||
|                 'total_transactions' => count($spent) + count($earned) + count($transferred), | ||||
|                 'spent'              => $this->groupByCurrency($spent), | ||||
|                 'earned'             => $this->groupByCurrency($earned), | ||||
|                 'transferred'        => $this->groupByCurrency($transferred), | ||||
|             ]; | ||||
|                              'title'              => $title, | ||||
|                              'route'              => route('categories.no-category', [$currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')]), | ||||
|                              'total_transactions' => count($spent) + count($earned) + count($transferred), | ||||
|                              'spent'              => $this->groupByCurrency($spent), | ||||
|                              'earned'             => $this->groupByCurrency($earned), | ||||
|                              'transferred'        => $this->groupByCurrency($transferred), | ||||
|                          ]; | ||||
|         } | ||||
|         Log::debug('End of loops'); | ||||
| 
 | ||||
| @@ -343,7 +342,7 @@ trait PeriodOverview | ||||
|         ]; | ||||
|         $this->transactions = []; | ||||
|         foreach ($types as $type) { | ||||
|             $set                          = $this->getSingleAccountPeriodByType($account, $start, $end, $type); | ||||
|             $set           = $this->getSingleAccountPeriodByType($account, $start, $end, $type); | ||||
|             $return['total_transactions'] += $set['count']; | ||||
|             unset($set['count']); | ||||
|             $return[$type] = $set; | ||||
| @@ -437,15 +436,15 @@ trait PeriodOverview | ||||
| 
 | ||||
|             return $grouped; | ||||
|         } | ||||
|         $grouped = [ | ||||
|         $grouped    = [ | ||||
|             'count' => 0, | ||||
|         ]; | ||||
| 
 | ||||
|         /** @var PeriodStatistic $statistic */ | ||||
|         foreach ($statistics as $statistic) { | ||||
|             $id               = (int)$statistic->transaction_currency_id; | ||||
|             $currency         = Amount::getTransactionCurrencyById($id); | ||||
|             $grouped[$id]     = [ | ||||
|             $id           = (int)$statistic->transaction_currency_id; | ||||
|             $currency     = Amount::getTransactionCurrencyById($id); | ||||
|             $grouped[$id] = [ | ||||
|                 'amount'                  => (string)$statistic->amount, | ||||
|                 'count'                   => (int)$statistic->count, | ||||
|                 'currency_id'             => $currency->id, | ||||
| @@ -534,11 +533,11 @@ trait PeriodOverview | ||||
|      */ | ||||
|     protected function getTagPeriodOverview(Tag $tag, Carbon $start, Carbon $end): array // period overview for tags.
 | ||||
|     { | ||||
|         $range = Navigation::getViewRange(true); | ||||
|         $range         = Navigation::getViewRange(true); | ||||
|         [$start, $end] = $end < $start ? [$end, $start] : [$start, $end]; | ||||
| 
 | ||||
|         // properties for cache
 | ||||
|         $cache = new CacheProperties(); | ||||
|         $cache         = new CacheProperties(); | ||||
|         $cache->addProperty($start); | ||||
|         $cache->addProperty($end); | ||||
|         $cache->addProperty('tag-period-entries'); | ||||
| @@ -548,37 +547,37 @@ trait PeriodOverview | ||||
|         } | ||||
| 
 | ||||
|         /** @var array $dates */ | ||||
|         $dates   = Navigation::blockPeriods($start, $end, $range); | ||||
|         $entries = []; | ||||
|         $dates         = Navigation::blockPeriods($start, $end, $range); | ||||
|         $entries       = []; | ||||
| 
 | ||||
|         // collect all expenses in this period:
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector     = app(GroupCollectorInterface::class); | ||||
|         $collector->setTag($tag); | ||||
|         $collector->setRange($start, $end); | ||||
|         $collector->setTypes([TransactionTypeEnum::DEPOSIT->value]); | ||||
|         $earnedSet = $collector->getExtractedJournals(); | ||||
|         $earnedSet     = $collector->getExtractedJournals(); | ||||
| 
 | ||||
|         // collect all income in this period:
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector     = app(GroupCollectorInterface::class); | ||||
|         $collector->setTag($tag); | ||||
|         $collector->setRange($start, $end); | ||||
|         $collector->setTypes([TransactionTypeEnum::WITHDRAWAL->value]); | ||||
|         $spentSet = $collector->getExtractedJournals(); | ||||
|         $spentSet      = $collector->getExtractedJournals(); | ||||
| 
 | ||||
|         // collect all transfers in this period:
 | ||||
|         /** @var GroupCollectorInterface $collector */ | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector     = app(GroupCollectorInterface::class); | ||||
|         $collector->setTag($tag); | ||||
|         $collector->setRange($start, $end); | ||||
|         $collector->setTypes([TransactionTypeEnum::TRANSFER->value]); | ||||
|         $transferSet = $collector->getExtractedJournals(); | ||||
|         $transferSet   = $collector->getExtractedJournals(); | ||||
| 
 | ||||
|         // filer all of them:
 | ||||
|         $earnedSet   = $this->filterJournalsByTag($earnedSet, $tag); | ||||
|         $spentSet    = $this->filterJournalsByTag($spentSet, $tag); | ||||
|         $transferSet = $this->filterJournalsByTag($transferSet, $tag); | ||||
|         $earnedSet     = $this->filterJournalsByTag($earnedSet, $tag); | ||||
|         $spentSet      = $this->filterJournalsByTag($spentSet, $tag); | ||||
|         $transferSet   = $this->filterJournalsByTag($transferSet, $tag); | ||||
| 
 | ||||
|         foreach ($dates as $currentDate) { | ||||
|             $spent       = $this->filterJournalsByDate($spentSet, $currentDate['start'], $currentDate['end']); | ||||
| @@ -587,17 +586,17 @@ trait PeriodOverview | ||||
|             $title       = Navigation::periodShow($currentDate['end'], $currentDate['period']); | ||||
|             $entries[] | ||||
|                          = [ | ||||
|                 'transactions'       => 0, | ||||
|                 'title'              => $title, | ||||
|                 'route'              => route( | ||||
|                     'tags.show', | ||||
|                     [$tag->id, $currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')] | ||||
|                 ), | ||||
|                 'total_transactions' => count($spent) + count($earned) + count($transferred), | ||||
|                 'spent'              => $this->groupByCurrency($spent), | ||||
|                 'earned'             => $this->groupByCurrency($earned), | ||||
|                 'transferred'        => $this->groupByCurrency($transferred), | ||||
|             ]; | ||||
|                              'transactions'       => 0, | ||||
|                              'title'              => $title, | ||||
|                              'route'              => route( | ||||
|                                  'tags.show', | ||||
|                                  [$tag->id, $currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')] | ||||
|                              ), | ||||
|                              'total_transactions' => count($spent) + count($earned) + count($transferred), | ||||
|                              'spent'              => $this->groupByCurrency($spent), | ||||
|                              'earned'             => $this->groupByCurrency($earned), | ||||
|                              'transferred'        => $this->groupByCurrency($transferred), | ||||
|                          ]; | ||||
|         } | ||||
| 
 | ||||
|         return $entries; | ||||
| @@ -608,12 +607,12 @@ trait PeriodOverview | ||||
|      */ | ||||
|     protected function getTransactionPeriodOverview(string $transactionType, Carbon $start, Carbon $end): array | ||||
|     { | ||||
|         $range = Navigation::getViewRange(true); | ||||
|         $types = config(sprintf('firefly.transactionTypesByType.%s', $transactionType)); | ||||
|         $range         = Navigation::getViewRange(true); | ||||
|         $types         = config(sprintf('firefly.transactionTypesByType.%s', $transactionType)); | ||||
|         [$start, $end] = $end < $start ? [$end, $start] : [$start, $end]; | ||||
| 
 | ||||
|         // properties for cache
 | ||||
|         $cache = new CacheProperties(); | ||||
|         $cache         = new CacheProperties(); | ||||
|         $cache->addProperty($start); | ||||
|         $cache->addProperty($end); | ||||
|         $cache->addProperty('transactions-period-entries'); | ||||
| @@ -623,16 +622,16 @@ trait PeriodOverview | ||||
|         } | ||||
| 
 | ||||
|         /** @var array $dates */ | ||||
|         $dates       = Navigation::blockPeriods($start, $end, $range); | ||||
|         $entries     = []; | ||||
|         $spent       = []; | ||||
|         $earned      = []; | ||||
|         $transferred = []; | ||||
|         $dates         = Navigation::blockPeriods($start, $end, $range); | ||||
|         $entries       = []; | ||||
|         $spent         = []; | ||||
|         $earned        = []; | ||||
|         $transferred   = []; | ||||
|         // collect all journals in this period (regardless of type)
 | ||||
|         $collector = app(GroupCollectorInterface::class); | ||||
|         $collector     = app(GroupCollectorInterface::class); | ||||
|         $collector->setTypes($types)->setRange($start, $end); | ||||
|         $genericSet = $collector->getExtractedJournals(); | ||||
|         $loops      = 0; | ||||
|         $genericSet    = $collector->getExtractedJournals(); | ||||
|         $loops         = 0; | ||||
| 
 | ||||
|         foreach ($dates as $currentDate) { | ||||
|             $title = Navigation::periodShow($currentDate['end'], $currentDate['period']); | ||||
| @@ -650,14 +649,14 @@ trait PeriodOverview | ||||
|                 } | ||||
|             } | ||||
|             $entries[] | ||||
|                 = [ | ||||
|                 'title'              => $title, | ||||
|                 'route'              => route('transactions.index', [$transactionType, $currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')]), | ||||
|                 'total_transactions' => count($spent) + count($earned) + count($transferred), | ||||
|                 'spent'              => $this->groupByCurrency($spent), | ||||
|                 'earned'             => $this->groupByCurrency($earned), | ||||
|                 'transferred'        => $this->groupByCurrency($transferred), | ||||
|             ]; | ||||
|                    = [ | ||||
|                     'title'              => $title, | ||||
|                     'route'              => route('transactions.index', [$transactionType, $currentDate['start']->format('Y-m-d'), $currentDate['end']->format('Y-m-d')]), | ||||
|                     'total_transactions' => count($spent) + count($earned) + count($transferred), | ||||
|                     'spent'              => $this->groupByCurrency($spent), | ||||
|                     'earned'             => $this->groupByCurrency($earned), | ||||
|                     'transferred'        => $this->groupByCurrency($transferred), | ||||
|                 ]; | ||||
|             ++$loops; | ||||
|         } | ||||
| 
 | ||||
| @@ -698,7 +697,7 @@ trait PeriodOverview | ||||
|     { | ||||
|         $return = []; | ||||
|         foreach ($set as $entry) { | ||||
|             $found = false; | ||||
|             $found    = false; | ||||
| 
 | ||||
|             /** @var array $localTag */ | ||||
|             foreach ($entry['tags'] as $localTag) { | ||||
| @@ -810,13 +809,13 @@ trait PeriodOverview | ||||
|                 exit; | ||||
|             } | ||||
| 
 | ||||
|             $currencyId            = (int)$journal['currency_id']; | ||||
|             $currencyCode          = $journal['currency_code']; | ||||
|             $currencyName          = $journal['currency_name']; | ||||
|             $currencySymbol        = $journal['currency_symbol']; | ||||
|             $currencyDecimalPlaces = $journal['currency_decimal_places']; | ||||
|             $foreignCurrencyId     = $journal['foreign_currency_id']; | ||||
|             $amount                = $journal['amount'] ?? '0'; | ||||
|             $currencyId                    = (int)$journal['currency_id']; | ||||
|             $currencyCode                  = $journal['currency_code']; | ||||
|             $currencyName                  = $journal['currency_name']; | ||||
|             $currencySymbol                = $journal['currency_symbol']; | ||||
|             $currencyDecimalPlaces         = $journal['currency_decimal_places']; | ||||
|             $foreignCurrencyId             = $journal['foreign_currency_id']; | ||||
|             $amount                        = $journal['amount'] ?? '0'; | ||||
| 
 | ||||
|             if ($this->convertToPrimary && $currencyId !== $this->primaryCurrency->id && $foreignCurrencyId !== $this->primaryCurrency->id) { | ||||
|                 $amount                = $journal['pc_amount'] ?? '0'; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user