mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 05:03:13 +00:00 
			
		
		
		
	This makes the expense chart on the frontpage multi-currency.
This commit is contained in:
		| @@ -31,6 +31,7 @@ use FireflyIII\Repositories\Account\AccountRepositoryInterface; | ||||
| use Illuminate\Contracts\Encryption\DecryptException; | ||||
| use Illuminate\Support\Collection; | ||||
| use Log; | ||||
| use stdClass; | ||||
|  | ||||
| /** | ||||
|  * Class Steam. | ||||
| @@ -211,6 +212,38 @@ class Steam | ||||
|         return $balances; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param \FireflyIII\Models\Account $account | ||||
|      * @param \Carbon\Carbon             $date | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function balancePerCurrency(Account $account, Carbon $date): array | ||||
|     { | ||||
|  | ||||
|         // abuse chart properties: | ||||
|         $cache = new CacheProperties; | ||||
|         $cache->addProperty($account->id); | ||||
|         $cache->addProperty('balance-per-currency'); | ||||
|         $cache->addProperty($date); | ||||
|         if ($cache->has()) { | ||||
|             return $cache->get(); // @codeCoverageIgnore | ||||
|         } | ||||
|         $query    = $account->transactions() | ||||
|                             ->leftJoin('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id') | ||||
|                             ->where('transaction_journals.date', '<=', $date->format('Y-m-d 23:59:59')) | ||||
|                             ->groupBy('transactions.transaction_currency_id'); | ||||
|         $balances = $query->get(['transactions.transaction_currency_id', DB::raw('SUM(transactions.amount) as sum_for_currency')]); | ||||
|         $return   = []; | ||||
|         /** @var stdClass $entry */ | ||||
|         foreach ($balances as $entry) { | ||||
|             $return[(int)$entry->transaction_currency_id] = $entry->sum_for_currency; | ||||
|         } | ||||
|         $cache->store($return); | ||||
|  | ||||
|         return $return; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * This method always ignores the virtual balance. | ||||
|      * | ||||
| @@ -243,6 +276,38 @@ class Steam | ||||
|         return $result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Same as above, but also groups per currency. | ||||
|      * | ||||
|      * @param \Illuminate\Support\Collection $accounts | ||||
|      * @param \Carbon\Carbon                 $date | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function balancesPerCurrencyByAccounts(Collection $accounts, Carbon $date): array | ||||
|     { | ||||
|         $ids = $accounts->pluck('id')->toArray(); | ||||
|         // cache this property. | ||||
|         $cache = new CacheProperties; | ||||
|         $cache->addProperty($ids); | ||||
|         $cache->addProperty('balances-per-currency'); | ||||
|         $cache->addProperty($date); | ||||
|         if ($cache->has()) { | ||||
|             return $cache->get(); // @codeCoverageIgnore | ||||
|         } | ||||
|  | ||||
|         // need to do this per account. | ||||
|         $result = []; | ||||
|         /** @var Account $account */ | ||||
|         foreach ($accounts as $account) { | ||||
|             $result[$account->id] = $this->balancePerCurrency($account, $date); | ||||
|         } | ||||
|  | ||||
|         $cache->store($result); | ||||
|  | ||||
|         return $result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param int $isEncrypted | ||||
|      * @param     $value | ||||
|   | ||||
		Reference in New Issue
	
	Block a user