| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-04-01 16:44:46 +02:00
										 |  |  | declare(strict_types = 1); | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  | /** | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  |  * TransactionJournalSupport.php | 
					
						
							| 
									
										
										
										
											2016-04-01 16:44:46 +02:00
										 |  |  |  * Copyright (C) 2016 thegrumpydictator@gmail.com | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This software may be modified and distributed under the terms | 
					
						
							|  |  |  |  * of the MIT license.  See the LICENSE file for details. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  | namespace FireflyIII\Support\Models; | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-20 17:12:34 +01:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2016-04-29 17:26:59 +02:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  | use FireflyIII\Models\Transaction; | 
					
						
							|  |  |  | use FireflyIII\Models\TransactionJournal; | 
					
						
							|  |  |  | use FireflyIII\Support\CacheProperties; | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  | use Illuminate\Database\Eloquent\Builder; | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  | use Illuminate\Database\Eloquent\Model; | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  | use Illuminate\Support\Collection; | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  | /** | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  |  * Class TransactionJournalSupport | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  |  * @package FireflyIII\Support\Models | 
					
						
							| 
									
										
										
										
											2016-03-12 07:36:23 +01:00
										 |  |  |  * @mixin \Eloquent | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  | class TransactionJournalSupport extends Model | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							| 
									
										
										
										
											2016-04-29 21:36:59 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public static function amount(TransactionJournal $journal): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($journal->id); | 
					
						
							| 
									
										
										
										
											2016-03-02 20:19:39 +01:00
										 |  |  |         $cache->addProperty('transaction-journal'); | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |         $cache->addProperty('amount'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |             return $cache->get(); | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-05 18:59:46 +02:00
										 |  |  |         // saves on queries:
 | 
					
						
							| 
									
										
										
										
											2016-05-11 17:33:22 +02:00
										 |  |  |         $amount = $journal->transactions()->where('amount', '>', 0)->get()->sum('amount'); | 
					
						
							| 
									
										
										
										
											2016-05-05 18:59:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if ($journal->isWithdrawal()) { | 
					
						
							| 
									
										
										
										
											2016-04-30 19:50:42 +02:00
										 |  |  |             $amount = $amount * -1; | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-04-30 19:50:42 +02:00
										 |  |  |         $amount = strval($amount); | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |         $cache->store($amount); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $amount; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function amountPositive(TransactionJournal $journal): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($journal->id); | 
					
						
							| 
									
										
										
										
											2016-03-02 20:19:39 +01:00
										 |  |  |         $cache->addProperty('transaction-journal'); | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |         $cache->addProperty('amount-positive'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |             return $cache->get(); | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-12 10:38:44 +02:00
										 |  |  |         // saves on queries:
 | 
					
						
							|  |  |  |         $amount = $journal->transactions()->where('amount', '>', 0)->get()->sum('amount'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $amount = strval($amount); | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |         $cache->store($amount); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $amount; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-20 17:12:34 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function budgetId(TransactionJournal $journal): int | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $budget = $journal->budgets()->first(); | 
					
						
							|  |  |  |         if (!is_null($budget)) { | 
					
						
							|  |  |  |             return $budget->id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function categoryAsString(TransactionJournal $journal): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $category = $journal->categories()->first(); | 
					
						
							|  |  |  |         if (!is_null($category)) { | 
					
						
							|  |  |  |             return $category->name; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return ''; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * @param string             $dateField | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function dateAsString(TransactionJournal $journal, string $dateField = ''): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($dateField === '') { | 
					
						
							|  |  |  |             return $journal->date->format('Y-m-d'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (!is_null($journal->$dateField) && $journal->$dateField instanceof Carbon) { | 
					
						
							|  |  |  |             return $journal->$dateField->format('Y-m-d'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return ''; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function destinationAccountList(TransactionJournal $journal): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($journal->id); | 
					
						
							|  |  |  |         $cache->addProperty('transaction-journal'); | 
					
						
							|  |  |  |         $cache->addProperty('destination-account-list'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							|  |  |  |             return $cache->get(); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-05-20 08:09:53 +02:00
										 |  |  |         $transactions = $journal->transactions()->where('amount', '>', 0)->orderBy('transactions.account_id')->with('account')->get(); | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         $list         = new Collection; | 
					
						
							|  |  |  |         /** @var Transaction $t */ | 
					
						
							|  |  |  |         foreach ($transactions as $t) { | 
					
						
							|  |  |  |             $list->push($t->account); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $cache->store($list); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $list; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-15 15:24:23 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function destinationTransactionList(TransactionJournal $journal): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($journal->id); | 
					
						
							|  |  |  |         $cache->addProperty('transaction-journal'); | 
					
						
							|  |  |  |         $cache->addProperty('destination-transaction-list'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							|  |  |  |             return $cache->get(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $list = $journal->transactions()->where('amount', '>', 0)->with('account')->get(); | 
					
						
							|  |  |  |         $cache->store($list); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $list; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  |      * @param Builder $query | 
					
						
							|  |  |  |      * @param string  $table | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  |     public static function isJoined(Builder $query, string $table):bool | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         $joins = $query->getQuery()->joins; | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  |         if (is_null($joins)) { | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         foreach ($joins as $join) { | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  |             if ($join->table === $table) { | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |                 return true; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 12:52:36 +01:00
										 |  |  |         return false; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-02 19:41:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-20 17:12:34 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return int | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function piggyBankId(TransactionJournal $journal): int | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($journal->piggyBankEvents()->count() > 0) { | 
					
						
							|  |  |  |             return $journal->piggyBankEvents()->orderBy('date', 'DESC')->first()->piggy_bank_id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-29 21:36:59 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function queryFields(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return [ | 
					
						
							|  |  |  |             'transaction_journals.*', | 
					
						
							|  |  |  |             'transaction_types.type AS transaction_type_type', // the other field is called "transaction_type_id" so this is pretty consistent.
 | 
					
						
							|  |  |  |             'transaction_currencies.code AS transaction_currency_code', | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function sourceAccountList(TransactionJournal $journal): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($journal->id); | 
					
						
							|  |  |  |         $cache->addProperty('transaction-journal'); | 
					
						
							|  |  |  |         $cache->addProperty('source-account-list'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							|  |  |  |             return $cache->get(); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-05-20 08:09:53 +02:00
										 |  |  |         $transactions = $journal->transactions()->where('amount', '<', 0)->orderBy('transactions.account_id')->with('account')->get(); | 
					
						
							| 
									
										
										
										
											2016-05-06 10:32:26 +02:00
										 |  |  |         $list         = new Collection; | 
					
						
							|  |  |  |         /** @var Transaction $t */ | 
					
						
							|  |  |  |         foreach ($transactions as $t) { | 
					
						
							|  |  |  |             $list->push($t->account); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $cache->store($list); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $list; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-14 13:51:33 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Collection | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function sourceTransactionList(TransactionJournal $journal): Collection | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($journal->id); | 
					
						
							|  |  |  |         $cache->addProperty('transaction-journal'); | 
					
						
							|  |  |  |         $cache->addProperty('source-transaction-list'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							|  |  |  |             return $cache->get(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $list = $journal->transactions()->where('amount', '<', 0)->with('account')->get(); | 
					
						
							|  |  |  |         $cache->store($list); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $list; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param TransactionJournal $journal | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function transactionTypeStr(TransactionJournal $journal): string | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-03-02 20:19:39 +01:00
										 |  |  |         $cache = new CacheProperties; | 
					
						
							|  |  |  |         $cache->addProperty($journal->id); | 
					
						
							|  |  |  |         $cache->addProperty('transaction-journal'); | 
					
						
							|  |  |  |         $cache->addProperty('type-string'); | 
					
						
							|  |  |  |         if ($cache->has()) { | 
					
						
							| 
									
										
										
										
											2016-04-06 09:27:45 +02:00
										 |  |  |             return $cache->get(); | 
					
						
							| 
									
										
										
										
											2016-03-02 20:19:39 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $typeStr = $journal->transaction_type_type ?? $journal->transactionType->type; | 
					
						
							|  |  |  |         $cache->store($typeStr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $typeStr; | 
					
						
							| 
									
										
										
										
											2016-03-02 20:11:28 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 09:38:16 +01:00
										 |  |  | } |