mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 21:16:47 +00:00 
			
		
		
		
	New method of collecting balance.
This commit is contained in:
		| @@ -43,8 +43,8 @@ class OtherCurrenciesCorrections extends Command | ||||
|     use ShowsFriendlyMessages; | ||||
| 
 | ||||
|     public const string CONFIG_NAME = '480_other_currencies'; | ||||
|     protected $description          = 'Update all journal currency information.'; | ||||
|     protected $signature            = 'firefly-iii:other-currencies {--F|force : Force the execution of this command.}'; | ||||
|     protected                             $description = 'Update all journal currency information.'; | ||||
|     protected                             $signature   = 'firefly-iii:other-currencies {--F|force : Force the execution of this command.}'; | ||||
|     private array                         $accountCurrencies; | ||||
|     private AccountRepositoryInterface    $accountRepos; | ||||
|     private JournalCLIRepositoryInterface $cliRepos; | ||||
| @@ -90,7 +90,7 @@ class OtherCurrenciesCorrections extends Command | ||||
|     { | ||||
|         $configVar = app('fireflyconfig')->get(self::CONFIG_NAME, false); | ||||
|         if (null !== $configVar) { | ||||
|             return (bool)$configVar->data; | ||||
|             return (bool) $configVar->data; | ||||
|         } | ||||
| 
 | ||||
|         return false; | ||||
| @@ -120,7 +120,7 @@ class OtherCurrenciesCorrections extends Command | ||||
|         $this->journalRepos->setUser($journal->user); | ||||
|         $this->cliRepos->setUser($journal->user); | ||||
| 
 | ||||
|         $leadTransaction                  = $this->getLeadTransaction($journal); | ||||
|         $leadTransaction = $this->getLeadTransaction($journal); | ||||
| 
 | ||||
|         if (null === $leadTransaction) { | ||||
|             $this->friendlyError(sprintf('Could not reliably determine which transaction is in the lead for transaction journal #%d.', $journal->id)); | ||||
| @@ -128,8 +128,9 @@ class OtherCurrenciesCorrections extends Command | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         $account                          = $leadTransaction->account; | ||||
|         $currency                         = $this->getCurrency($account); | ||||
|         $account         = $leadTransaction->account; | ||||
|         $currency        = $this->getCurrency($account); | ||||
|         $isMultiCurrency = $this->isMultiCurrency($account); | ||||
|         if (null === $currency) { | ||||
|             $this->friendlyError( | ||||
|                 sprintf( | ||||
| @@ -145,14 +146,14 @@ class OtherCurrenciesCorrections extends Command | ||||
|         } | ||||
|         // fix each transaction:
 | ||||
|         $journal->transactions->each( | ||||
|             static function (Transaction $transaction) use ($currency): void { | ||||
|             static function (Transaction $transaction) use ($currency, $isMultiCurrency): void { | ||||
|                 if (null === $transaction->transaction_currency_id) { | ||||
|                     $transaction->transaction_currency_id = $currency->id; | ||||
|                     $transaction->save(); | ||||
|                 } | ||||
| 
 | ||||
|                 // when mismatch in transaction:
 | ||||
|                 if ($transaction->transaction_currency_id !== $currency->id) { | ||||
|                 if ($transaction->transaction_currency_id !== $currency->id && !$isMultiCurrency) { | ||||
|                     $transaction->foreign_currency_id     = $transaction->transaction_currency_id; | ||||
|                     $transaction->foreign_amount          = $transaction->amount; | ||||
|                     $transaction->transaction_currency_id = $currency->id; | ||||
| @@ -161,7 +162,9 @@ class OtherCurrenciesCorrections extends Command | ||||
|             } | ||||
|         ); | ||||
|         // also update the journal, of course:
 | ||||
|         $journal->transaction_currency_id = $currency->id; | ||||
|         if (!$isMultiCurrency) { | ||||
|             $journal->transaction_currency_id = $currency->id; | ||||
|         } | ||||
|         ++$this->count; | ||||
|         $journal->save(); | ||||
|     } | ||||
| @@ -217,14 +220,14 @@ class OtherCurrenciesCorrections extends Command | ||||
| 
 | ||||
|     private function getCurrency(Account $account): ?TransactionCurrency | ||||
|     { | ||||
|         $accountId                           = $account->id; | ||||
|         $accountId = $account->id; | ||||
|         if (array_key_exists($accountId, $this->accountCurrencies) && 0 === $this->accountCurrencies[$accountId]) { | ||||
|             return null; | ||||
|         } | ||||
|         if (array_key_exists($accountId, $this->accountCurrencies) && $this->accountCurrencies[$accountId] instanceof TransactionCurrency) { | ||||
|             return $this->accountCurrencies[$accountId]; | ||||
|         } | ||||
|         $currency                            = $this->accountRepos->getAccountCurrency($account); | ||||
|         $currency = $this->accountRepos->getAccountCurrency($account); | ||||
|         if (null === $currency) { | ||||
|             $this->accountCurrencies[$accountId] = 0; | ||||
| 
 | ||||
| @@ -239,4 +242,13 @@ class OtherCurrenciesCorrections extends Command | ||||
|     { | ||||
|         app('fireflyconfig')->set(self::CONFIG_NAME, true); | ||||
|     } | ||||
| 
 | ||||
|     private function isMultiCurrency(Account $account): bool | ||||
|     { | ||||
|         $value = $this->accountRepos->getMetaValue($account, 'is_multi_currency', false); | ||||
|         if (false === $value || null === $value) { | ||||
|             return false; | ||||
|         } | ||||
|         return '1' === $value; | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user