mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 05:26:17 +00:00 
			
		
		
		
	Auto commit for release 'v6.2.1' on 2025-02-01
This commit is contained in:
		| @@ -67,7 +67,7 @@ abstract class Controller extends BaseController | ||||
|     protected array        $allowedSort; | ||||
|     protected ParameterBag $parameters; | ||||
|     protected bool        $convertToNative   = false; | ||||
|     protected array $accepts                 = ['application/json','application/vnd.api+json']; | ||||
|     protected array $accepts                 = ['application/json', 'application/vnd.api+json']; | ||||
|     protected TransactionCurrency $nativeCurrency; | ||||
| 
 | ||||
|     /** | ||||
|   | ||||
| @@ -54,7 +54,7 @@ class CorrectsNativeAmounts extends Command | ||||
| 
 | ||||
|     protected $description = 'Recalculate native amounts for all objects.'; | ||||
| 
 | ||||
|     protected $signature = 'correction:recalculate-native-amounts'; | ||||
|     protected $signature   = 'correction:recalculate-native-amounts'; | ||||
| 
 | ||||
|     /** | ||||
|      * Execute the console command. | ||||
| @@ -121,13 +121,13 @@ class CorrectsNativeAmounts extends Command | ||||
| 
 | ||||
|     private function recalculatePiggyBanks(UserGroup $userGroup, TransactionCurrency $currency): void | ||||
|     { | ||||
|         $converter = new ExchangeRateConverter(); | ||||
|         $converter  = new ExchangeRateConverter(); | ||||
|         $converter->setUserGroup($userGroup); | ||||
|         $converter->setIgnoreSettings(true); | ||||
|         $repository = app(PiggyBankRepositoryInterface::class); | ||||
|         $repository->setUserGroup($userGroup); | ||||
|         $set = $repository->getPiggyBanks(); | ||||
|         $set = $set->filter( | ||||
|         $set        = $repository->getPiggyBanks(); | ||||
|         $set        = $set->filter( | ||||
|             static function (PiggyBank $piggyBank) use ($currency) { | ||||
|                 return $currency->id !== $piggyBank->transaction_currency_id; | ||||
|             } | ||||
| @@ -223,21 +223,22 @@ class CorrectsNativeAmounts extends Command | ||||
|     { | ||||
|         // custom query because of the potential size of this update.
 | ||||
|         $set                              = DB::table('transactions') | ||||
|                                               ->join('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id') | ||||
|                                               ->where('transaction_journals.user_group_id', $userGroup->id) | ||||
|                                               ->where(function (DatabaseBuilder $q1) use ($currency): void { | ||||
|                                                   $q1->where(function (DatabaseBuilder $q2) use ($currency): void { | ||||
|                                                       $q2->whereNot('transactions.transaction_currency_id', $currency->id)->whereNull('transactions.foreign_currency_id'); | ||||
|                                                   })->orWhere(function (DatabaseBuilder $q3) use ($currency): void { | ||||
|                                                       $q3->whereNot('transactions.transaction_currency_id', $currency->id)->whereNot('transactions.foreign_currency_id', $currency->id); | ||||
|                                                   }); | ||||
|                                               }) | ||||
|             ->join('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id') | ||||
|             ->where('transaction_journals.user_group_id', $userGroup->id) | ||||
|             ->where(function (DatabaseBuilder $q1) use ($currency): void { | ||||
|                 $q1->where(function (DatabaseBuilder $q2) use ($currency): void { | ||||
|                     $q2->whereNot('transactions.transaction_currency_id', $currency->id)->whereNull('transactions.foreign_currency_id'); | ||||
|                 })->orWhere(function (DatabaseBuilder $q3) use ($currency): void { | ||||
|                     $q3->whereNot('transactions.transaction_currency_id', $currency->id)->whereNot('transactions.foreign_currency_id', $currency->id); | ||||
|                 }); | ||||
|             }) | ||||
| //            ->where(static function (DatabaseBuilder $q) use ($currency): void {
 | ||||
| //                $q->whereNot('transactions.transaction_currency_id', $currency->id)
 | ||||
| //                    ->whereNot('transactions.foreign_currency_id', $currency->id)
 | ||||
| //                ;
 | ||||
| //            })
 | ||||
|                                               ->get(['transactions.id']); | ||||
|             ->get(['transactions.id']) | ||||
|         ; | ||||
|         TransactionObserver::$recalculate = false; | ||||
|         foreach ($set as $item) { | ||||
|             // here we are.
 | ||||
|   | ||||
| @@ -63,6 +63,7 @@ class PreferencesEventHandler | ||||
|         if (Amount::convertToNative()) { | ||||
|             Log::debug('Will now convert to native.'); | ||||
|             Artisan::call('correction:recalculate-native-amounts'); | ||||
| 
 | ||||
|             return; | ||||
|         } | ||||
|         Log::debug('Will NOT convert to native.'); | ||||
|   | ||||
| @@ -710,7 +710,7 @@ class GroupCollector implements GroupCollectorInterface | ||||
|         foreach ($groups as $groudId => $group) { | ||||
|             /** @var array $transaction */ | ||||
|             foreach ($group['transactions'] as $transaction) { | ||||
|                 $currencyId                                      = (int) $transaction['currency_id']; | ||||
|                 $currencyId                                             = (int) $transaction['currency_id']; | ||||
|                 if (null === $transaction['amount']) { | ||||
|                     throw new FireflyException(sprintf('Amount is NULL for a transaction in group #%d, please investigate.', $groudId)); | ||||
|                 } | ||||
| @@ -722,14 +722,14 @@ class GroupCollector implements GroupCollectorInterface | ||||
|                     $groups[$groudId]['sums'][$currencyId]['currency_symbol']         = $transaction['currency_symbol']; | ||||
|                     $groups[$groudId]['sums'][$currencyId]['currency_decimal_places'] = $transaction['currency_decimal_places']; | ||||
|                     $groups[$groudId]['sums'][$currencyId]['amount']                  = '0'; | ||||
|                     $groups[$groudId]['sums'][$currencyId]['native_amount']                  = '0'; | ||||
|                     $groups[$groudId]['sums'][$currencyId]['native_amount']           = '0'; | ||||
|                 } | ||||
|                 $transaction['native_amount'] = null === $transaction['native_amount'] ? '0' : $transaction['native_amount']; | ||||
|                 $groups[$groudId]['sums'][$currencyId]['amount'] = bcadd($groups[$groudId]['sums'][$currencyId]['amount'], $transaction['amount']); | ||||
|                 $transaction['native_amount']                           = null === $transaction['native_amount'] ? '0' : $transaction['native_amount']; | ||||
|                 $groups[$groudId]['sums'][$currencyId]['amount']        = bcadd($groups[$groudId]['sums'][$currencyId]['amount'], $transaction['amount']); | ||||
|                 $groups[$groudId]['sums'][$currencyId]['native_amount'] = bcadd($groups[$groudId]['sums'][$currencyId]['native_amount'], $transaction['native_amount']); | ||||
| 
 | ||||
|                 if (null !== $transaction['foreign_amount'] && null !== $transaction['foreign_currency_id']) { | ||||
|                     $currencyId                                      = (int) $transaction['foreign_currency_id']; | ||||
|                     $currencyId                                             = (int) $transaction['foreign_currency_id']; | ||||
| 
 | ||||
|                     // set default:
 | ||||
|                     if (!array_key_exists($currencyId, $groups[$groudId]['sums'])) { | ||||
| @@ -738,10 +738,10 @@ class GroupCollector implements GroupCollectorInterface | ||||
|                         $groups[$groudId]['sums'][$currencyId]['currency_symbol']         = $transaction['foreign_currency_symbol']; | ||||
|                         $groups[$groudId]['sums'][$currencyId]['currency_decimal_places'] = $transaction['foreign_currency_decimal_places']; | ||||
|                         $groups[$groudId]['sums'][$currencyId]['amount']                  = '0'; | ||||
|                         $groups[$groudId]['sums'][$currencyId]['save_amount']                  = '0'; | ||||
|                         $groups[$groudId]['sums'][$currencyId]['save_amount']             = '0'; | ||||
|                     } | ||||
|                     $transaction['native_foreign_amount'] = null === $transaction['native_foreign_amount'] ? '0' : $transaction['native_foreign_amount']; | ||||
|                     $groups[$groudId]['sums'][$currencyId]['amount'] = bcadd($groups[$groudId]['sums'][$currencyId]['amount'], $transaction['foreign_amount']); | ||||
|                     $transaction['native_foreign_amount']                   = null === $transaction['native_foreign_amount'] ? '0' : $transaction['native_foreign_amount']; | ||||
|                     $groups[$groudId]['sums'][$currencyId]['amount']        = bcadd($groups[$groudId]['sums'][$currencyId]['amount'], $transaction['foreign_amount']); | ||||
|                     $groups[$groudId]['sums'][$currencyId]['native_amount'] = bcadd($groups[$groudId]['sums'][$currencyId]['amount'], $transaction['native_foreign_amount']); | ||||
|                 } | ||||
|             } | ||||
|   | ||||
| @@ -69,7 +69,7 @@ class AmountController extends Controller | ||||
|     public function add(PiggyBank $piggyBank) | ||||
|     { | ||||
|         /** @var Carbon $date */ | ||||
|         $date     = session('end', today(config('app.timezone'))); | ||||
|         $date       = session('end', today(config('app.timezone'))); | ||||
|         $accounts   = []; | ||||
|         $total      = '0'; | ||||
|         $totalSaved = $this->piggyRepos->getCurrentAmount($piggyBank); | ||||
| @@ -77,7 +77,7 @@ class AmountController extends Controller | ||||
|             $leftOnAccount = $this->piggyRepos->leftOnAccount($piggyBank, $account, $date); | ||||
|             $savedSoFar    = $this->piggyRepos->getCurrentAmount($piggyBank, $account); | ||||
|             $leftToSave    = bcsub($piggyBank->target_amount, $savedSoFar); | ||||
|             $maxAmount = 0 === bccomp($piggyBank->target_amount, '0') ? $leftOnAccount : min($leftOnAccount, $leftToSave); | ||||
|             $maxAmount     = 0 === bccomp($piggyBank->target_amount, '0') ? $leftOnAccount : min($leftOnAccount, $leftToSave); | ||||
|             $accounts[]    = [ | ||||
|                 'account'         => $account, | ||||
|                 'left_on_account' => $leftOnAccount, | ||||
| @@ -107,7 +107,7 @@ class AmountController extends Controller | ||||
|             $leftOnAccount = $this->piggyRepos->leftOnAccount($piggyBank, $account, $date); | ||||
|             $savedSoFar    = $this->piggyRepos->getCurrentAmount($piggyBank, $account); | ||||
|             $leftToSave    = bcsub($piggyBank->target_amount, $savedSoFar); | ||||
|             $maxAmount = 0 === bccomp($piggyBank->target_amount, '0') ? $leftOnAccount : min($leftOnAccount, $leftToSave); | ||||
|             $maxAmount     = 0 === bccomp($piggyBank->target_amount, '0') ? $leftOnAccount : min($leftOnAccount, $leftToSave); | ||||
|             $accounts[]    = [ | ||||
|                 'account'         => $account, | ||||
|                 'left_on_account' => $leftOnAccount, | ||||
|   | ||||
| @@ -204,7 +204,7 @@ trait PeriodOverview | ||||
|             $currencyDecimalPlaces         = $journal['currency_decimal_places']; | ||||
|             $foreignCurrencyId             = $journal['foreign_currency_id']; | ||||
|             $amount                        = $journal['amount'] ?? '0'; | ||||
|              | ||||
| 
 | ||||
|             if ($this->convertToNative && $currencyId !== $this->defaultCurrency->id && $foreignCurrencyId !== $this->defaultCurrency->id) { | ||||
|                 $amount                = $journal['native_amount'] ?? '0'; | ||||
|                 $currencyId            = $this->defaultCurrency->id; | ||||
|   | ||||
| @@ -132,10 +132,10 @@ class PiggyBankTransformer extends AbstractTransformer | ||||
|         $return = []; | ||||
|         foreach ($piggyBank->accounts()->get() as $account) { | ||||
|             $return[] = [ | ||||
|                 'id'             => $account->id, | ||||
|                 'name'           => $account->name, | ||||
|                 'current_amount' => (string) $account->pivot->current_amount, | ||||
|                 'native_current_amount'=> (string) $account->pivot->native_current_amount, | ||||
|                 'id'                    => $account->id, | ||||
|                 'name'                  => $account->name, | ||||
|                 'current_amount'        => (string) $account->pivot->current_amount, | ||||
|                 'native_current_amount' => (string) $account->pivot->native_current_amount, | ||||
|                 // TODO add balance, add left to save.
 | ||||
|             ]; | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user