2017-11-04 01:10:21 -05:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Transaction.php
|
|
|
|
* Copyright (c) 2017 thegrumpydictator@gmail.com
|
|
|
|
*
|
|
|
|
* This file is part of Firefly III.
|
|
|
|
*
|
|
|
|
* Firefly III is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* Firefly III is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
2017-12-17 07:44:05 -06:00
|
|
|
* along with Firefly III. If not, see <http://www.gnu.org/licenses/>.
|
2017-11-04 01:10:21 -05:00
|
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace FireflyIII\Support\Twig\Extension;
|
|
|
|
|
|
|
|
use FireflyIII\Models\AccountType;
|
|
|
|
use FireflyIII\Models\Attachment;
|
|
|
|
use FireflyIII\Models\Transaction as TransactionModel;
|
|
|
|
use FireflyIII\Models\TransactionCurrency;
|
|
|
|
use FireflyIII\Models\TransactionType;
|
|
|
|
use FireflyIII\Support\SingleCacheProperties;
|
|
|
|
use Lang;
|
|
|
|
use Twig_Extension;
|
|
|
|
|
|
|
|
/**
|
2017-11-15 05:25:49 -06:00
|
|
|
* Class Transaction.
|
2017-11-04 01:10:21 -05:00
|
|
|
*/
|
|
|
|
class Transaction extends Twig_Extension
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Can show the amount of a transaction, if that transaction has been collected by the journal collector.
|
|
|
|
*
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function amount(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('transaction-amount');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
|
|
|
|
$amount = bcmul(app('steam')->positive(strval($transaction->transaction_amount)), '-1');
|
|
|
|
$format = '%s';
|
|
|
|
$coloured = true;
|
|
|
|
|
2017-11-22 13:20:44 -06:00
|
|
|
// at this point amount is always negative.
|
2017-11-22 14:12:27 -06:00
|
|
|
if (TransactionType::RECONCILIATION === $transaction->transaction_type_type && 1 === bccomp(strval($transaction->transaction_amount), '0')) {
|
2017-11-22 13:20:44 -06:00
|
|
|
$amount = bcmul($amount, '-1');
|
|
|
|
}
|
|
|
|
|
2017-11-15 05:25:49 -06:00
|
|
|
if (TransactionType::DEPOSIT === $transaction->transaction_type_type) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$amount = bcmul($amount, '-1');
|
|
|
|
}
|
|
|
|
|
2017-11-15 05:25:49 -06:00
|
|
|
if (TransactionType::TRANSFER === $transaction->transaction_type_type) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$amount = app('steam')->positive($amount);
|
|
|
|
$coloured = false;
|
|
|
|
$format = '<span class="text-info">%s</span>';
|
|
|
|
}
|
2017-11-15 05:25:49 -06:00
|
|
|
if (TransactionType::OPENING_BALANCE === $transaction->transaction_type_type) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$amount = strval($transaction->transaction_amount);
|
|
|
|
}
|
|
|
|
|
|
|
|
$currency = new TransactionCurrency;
|
|
|
|
$currency->symbol = $transaction->transaction_currency_symbol;
|
|
|
|
$currency->decimal_places = $transaction->transaction_currency_dp;
|
|
|
|
$str = sprintf($format, app('amount')->formatAnything($currency, $amount, $coloured));
|
|
|
|
|
2017-11-15 05:25:49 -06:00
|
|
|
if (null !== $transaction->transaction_foreign_amount) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$amount = bcmul(app('steam')->positive(strval($transaction->transaction_foreign_amount)), '-1');
|
2017-11-15 05:25:49 -06:00
|
|
|
if (TransactionType::DEPOSIT === $transaction->transaction_type_type) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$amount = bcmul($amount, '-1');
|
|
|
|
}
|
|
|
|
|
2017-11-15 05:25:49 -06:00
|
|
|
if (TransactionType::TRANSFER === $transaction->transaction_type_type) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$amount = app('steam')->positive($amount);
|
|
|
|
$coloured = false;
|
|
|
|
$format = '<span class="text-info">%s</span>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$currency = new TransactionCurrency;
|
|
|
|
$currency->symbol = $transaction->foreign_currency_symbol;
|
|
|
|
$currency->decimal_places = $transaction->foreign_currency_dp;
|
|
|
|
$str .= ' (' . sprintf($format, app('amount')->formatAnything($currency, $amount, $coloured)) . ')';
|
|
|
|
}
|
|
|
|
$cache->store($str);
|
|
|
|
|
|
|
|
return $str;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function amountArray(array $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('transaction-array-amount');
|
|
|
|
$cache->addProperty($transaction['source_id']);
|
|
|
|
$cache->addProperty($transaction['destination_id']);
|
|
|
|
$cache->addProperty($transaction['updated_at']);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
|
|
|
|
// first display amount:
|
2017-11-15 05:25:49 -06:00
|
|
|
$amount = TransactionType::WITHDRAWAL === $transaction['journal_type'] ? $transaction['source_amount']
|
2017-11-04 01:10:21 -05:00
|
|
|
: $transaction['destination_amount'];
|
|
|
|
$fakeCurrency = new TransactionCurrency;
|
|
|
|
$fakeCurrency->decimal_places = $transaction['transaction_currency_dp'];
|
|
|
|
$fakeCurrency->symbol = $transaction['transaction_currency_symbol'];
|
|
|
|
$string = app('amount')->formatAnything($fakeCurrency, $amount, true);
|
|
|
|
|
|
|
|
// then display (if present) the foreign amount:
|
2017-11-15 05:25:49 -06:00
|
|
|
if (null !== $transaction['foreign_source_amount']) {
|
|
|
|
$amount = TransactionType::WITHDRAWAL === $transaction['journal_type'] ? $transaction['foreign_source_amount']
|
2017-11-04 01:10:21 -05:00
|
|
|
: $transaction['foreign_destination_amount'];
|
|
|
|
$fakeCurrency = new TransactionCurrency;
|
|
|
|
$fakeCurrency->decimal_places = $transaction['foreign_currency_dp'];
|
|
|
|
$fakeCurrency->symbol = $transaction['foreign_currency_symbol'];
|
2017-11-05 12:48:43 -06:00
|
|
|
$string .= ' (' . app('amount')->formatAnything($fakeCurrency, $amount, true) . ')';
|
2017-11-04 01:10:21 -05:00
|
|
|
}
|
|
|
|
$cache->store($string);
|
|
|
|
|
|
|
|
return $string;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function budgets(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('transaction-budgets');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
|
|
|
|
// journal has a budget:
|
|
|
|
if (isset($transaction->transaction_journal_budget_id)) {
|
|
|
|
$name = app('steam')->tryDecrypt($transaction->transaction_journal_budget_name);
|
|
|
|
$txt = sprintf('<a href="%s" title="%s">%s</a>', route('budgets.show', [$transaction->transaction_journal_budget_id]), $name, $name);
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
// transaction has a budget
|
|
|
|
if (isset($transaction->transaction_budget_id)) {
|
|
|
|
$name = app('steam')->tryDecrypt($transaction->transaction_budget_name);
|
|
|
|
$txt = sprintf('<a href="%s" title="%s">%s</a>', route('budgets.show', [$transaction->transaction_budget_id]), $name, $name);
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
// see if the transaction has a budget:
|
|
|
|
$budgets = $transaction->budgets()->get();
|
2017-11-15 05:25:49 -06:00
|
|
|
if (0 === $budgets->count()) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$budgets = $transaction->transactionJournal()->first()->budgets()->get();
|
|
|
|
}
|
|
|
|
if ($budgets->count() > 0) {
|
|
|
|
$str = [];
|
|
|
|
foreach ($budgets as $budget) {
|
|
|
|
$str[] = sprintf('<a href="%s" title="%s">%s</a>', route('budgets.show', [$budget->id]), $budget->name, $budget->name);
|
|
|
|
}
|
|
|
|
|
|
|
|
$txt = join(', ', $str);
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
$txt = '';
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function categories(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('transaction-categories');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
|
|
|
|
// journal has a category:
|
|
|
|
if (isset($transaction->transaction_journal_category_id)) {
|
|
|
|
$name = app('steam')->tryDecrypt($transaction->transaction_journal_category_name);
|
|
|
|
$txt = sprintf('<a href="%s" title="%s">%s</a>', route('categories.show', [$transaction->transaction_journal_category_id]), $name, $name);
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
// transaction has a category:
|
|
|
|
if (isset($transaction->transaction_category_id)) {
|
|
|
|
$name = app('steam')->tryDecrypt($transaction->transaction_category_name);
|
|
|
|
$txt = sprintf('<a href="%s" title="%s">%s</a>', route('categories.show', [$transaction->transaction_category_id]), $name, $name);
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
// see if the transaction has a category:
|
|
|
|
$categories = $transaction->categories()->get();
|
2017-11-15 05:25:49 -06:00
|
|
|
if (0 === $categories->count()) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$categories = $transaction->transactionJournal()->first()->categories()->get();
|
|
|
|
}
|
|
|
|
if ($categories->count() > 0) {
|
|
|
|
$str = [];
|
|
|
|
foreach ($categories as $category) {
|
|
|
|
$str[] = sprintf('<a href="%s" title="%s">%s</a>', route('categories.show', [$category->id]), $category->name, $category->name);
|
|
|
|
}
|
|
|
|
|
|
|
|
$txt = join(', ', $str);
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
$txt = '';
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function description(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('description');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
$description = $transaction->description;
|
|
|
|
if (strlen(strval($transaction->transaction_description)) > 0) {
|
|
|
|
$description = $transaction->transaction_description . '(' . $transaction->description . ')';
|
|
|
|
}
|
|
|
|
|
|
|
|
$cache->store($description);
|
|
|
|
|
|
|
|
return $description;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function destinationAccount(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('transaction-destination');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
|
2017-11-22 14:12:27 -06:00
|
|
|
if (TransactionType::RECONCILIATION === $transaction->transaction_type_type) {
|
2017-11-22 13:20:44 -06:00
|
|
|
return '—';
|
|
|
|
}
|
|
|
|
|
2017-11-04 01:10:21 -05:00
|
|
|
$name = app('steam')->tryDecrypt($transaction->account_name);
|
|
|
|
$transactionId = intval($transaction->account_id);
|
|
|
|
$type = $transaction->account_type;
|
|
|
|
|
|
|
|
// name is present in object, use that one:
|
2017-11-15 05:25:49 -06:00
|
|
|
if (bccomp($transaction->transaction_amount, '0') === -1 && null !== $transaction->opposing_account_id) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$name = $transaction->opposing_account_name;
|
|
|
|
$transactionId = intval($transaction->opposing_account_id);
|
|
|
|
$type = $transaction->opposing_account_type;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Find the opposing account and use that one:
|
2017-11-15 05:25:49 -06:00
|
|
|
if (bccomp($transaction->transaction_amount, '0') === -1 && null === $transaction->opposing_account_id) {
|
2017-11-04 01:10:21 -05:00
|
|
|
// if the amount is negative, find the opposing account and use that one:
|
|
|
|
$journalId = $transaction->journal_id;
|
|
|
|
/** @var TransactionModel $other */
|
|
|
|
$other = TransactionModel::where('transaction_journal_id', $journalId)->where('transactions.id', '!=', $transaction->id)
|
|
|
|
->where('amount', '=', bcmul($transaction->transaction_amount, '-1'))->where(
|
2017-11-15 03:52:29 -06:00
|
|
|
'identifier',
|
2017-11-15 04:33:07 -06:00
|
|
|
$transaction->identifier
|
2017-11-04 01:10:21 -05:00
|
|
|
)
|
|
|
|
->leftJoin('accounts', 'accounts.id', '=', 'transactions.account_id')
|
|
|
|
->leftJoin('account_types', 'account_types.id', '=', 'accounts.account_type_id')
|
|
|
|
->first(['transactions.account_id', 'accounts.encrypted', 'accounts.name', 'account_types.type']);
|
|
|
|
$name = app('steam')->tryDecrypt($other->name);
|
|
|
|
$transactionId = $other->account_id;
|
|
|
|
$type = $other->type;
|
|
|
|
}
|
|
|
|
|
2017-11-15 05:25:49 -06:00
|
|
|
if (AccountType::CASH === $type) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$txt = '<span class="text-success">(' . trans('firefly.cash') . ')</span>';
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
$txt = sprintf('<a title="%1$s" href="%2$s">%1$s</a>', e($name), route('accounts.show', [$transactionId]));
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function hasAttachments(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('attachments');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
$journalId = intval($transaction->journal_id);
|
|
|
|
$count = Attachment::whereNull('deleted_at')
|
|
|
|
->where('attachable_type', 'FireflyIII\Models\TransactionJournal')
|
|
|
|
->where('attachable_id', $journalId)
|
|
|
|
->count();
|
|
|
|
if ($count > 0) {
|
|
|
|
$res = sprintf('<i class="fa fa-paperclip" title="%s"></i>', Lang::choice('firefly.nr_of_attachments', $count, ['count' => $count]));
|
|
|
|
$cache->store($res);
|
|
|
|
|
|
|
|
return $res;
|
|
|
|
}
|
|
|
|
|
|
|
|
$res = '';
|
|
|
|
$cache->store($res);
|
|
|
|
|
|
|
|
return $res;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function icon(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('icon');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ($transaction->transaction_type_type) {
|
|
|
|
case TransactionType::WITHDRAWAL:
|
|
|
|
$txt = sprintf('<i class="fa fa-long-arrow-left fa-fw" title="%s"></i>', trans('firefly.withdrawal'));
|
|
|
|
break;
|
|
|
|
case TransactionType::DEPOSIT:
|
|
|
|
$txt = sprintf('<i class="fa fa-long-arrow-right fa-fw" title="%s"></i>', trans('firefly.deposit'));
|
|
|
|
break;
|
|
|
|
case TransactionType::TRANSFER:
|
|
|
|
$txt = sprintf('<i class="fa fa-fw fa-exchange" title="%s"></i>', trans('firefly.transfer'));
|
|
|
|
break;
|
|
|
|
case TransactionType::OPENING_BALANCE:
|
2017-12-10 14:12:04 -06:00
|
|
|
$txt = sprintf('<i class="fa-fw fa fa-star-o" title="%s"></i>', trans('firefly.opening_balance'));
|
2017-11-04 01:10:21 -05:00
|
|
|
break;
|
2017-11-22 13:20:44 -06:00
|
|
|
case TransactionType::RECONCILIATION:
|
|
|
|
$txt = sprintf('<i class="fa-fw fa fa-calculator" title="%s"></i>', trans('firefly.reconciliation_transaction'));
|
|
|
|
break;
|
2017-11-04 01:10:21 -05:00
|
|
|
default:
|
|
|
|
$txt = '';
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
2017-11-05 12:48:43 -06:00
|
|
|
/**
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function isReconciled(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('transaction-reconciled');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
2017-11-08 02:47:38 -06:00
|
|
|
$cache->addProperty($transaction->reconciled);
|
2017-11-05 12:48:43 -06:00
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
$icon = '';
|
2017-11-15 05:25:49 -06:00
|
|
|
if (1 === intval($transaction->reconciled)) {
|
2017-11-05 12:48:43 -06:00
|
|
|
$icon = '<i class="fa fa-check"></i>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$cache->store($icon);
|
|
|
|
|
|
|
|
return $icon;
|
|
|
|
}
|
|
|
|
|
2017-11-04 01:10:21 -05:00
|
|
|
/**
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function isSplit(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('split');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
|
|
|
$journalId = intval($transaction->journal_id);
|
|
|
|
$count = TransactionModel::where('transaction_journal_id', $journalId)->whereNull('deleted_at')->count();
|
|
|
|
if ($count > 2) {
|
|
|
|
$res = '<i class="fa fa-fw fa-share-alt" aria-hidden="true"></i>';
|
|
|
|
$cache->store($res);
|
|
|
|
|
|
|
|
return $res;
|
|
|
|
}
|
|
|
|
|
|
|
|
$res = '';
|
|
|
|
$cache->store($res);
|
|
|
|
|
|
|
|
return $res;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param TransactionModel $transaction
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function sourceAccount(TransactionModel $transaction): string
|
|
|
|
{
|
|
|
|
$cache = new SingleCacheProperties;
|
|
|
|
$cache->addProperty('transaction-source');
|
|
|
|
$cache->addProperty($transaction->id);
|
|
|
|
$cache->addProperty($transaction->updated_at);
|
|
|
|
if ($cache->has()) {
|
|
|
|
return $cache->get();
|
|
|
|
}
|
2017-11-22 14:12:27 -06:00
|
|
|
if (TransactionType::RECONCILIATION === $transaction->transaction_type_type) {
|
2017-11-22 13:20:44 -06:00
|
|
|
return '—';
|
|
|
|
}
|
2017-11-04 01:10:21 -05:00
|
|
|
|
|
|
|
// if the amount is negative, assume that the current account (the one in $transaction) is indeed the source account.
|
|
|
|
$name = app('steam')->tryDecrypt($transaction->account_name);
|
|
|
|
$transactionId = intval($transaction->account_id);
|
|
|
|
$type = $transaction->account_type;
|
|
|
|
|
|
|
|
// name is present in object, use that one:
|
2017-11-15 05:25:49 -06:00
|
|
|
if (1 === bccomp($transaction->transaction_amount, '0') && null !== $transaction->opposing_account_id) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$name = $transaction->opposing_account_name;
|
|
|
|
$transactionId = intval($transaction->opposing_account_id);
|
|
|
|
$type = $transaction->opposing_account_type;
|
|
|
|
}
|
|
|
|
// Find the opposing account and use that one:
|
2017-11-15 05:25:49 -06:00
|
|
|
if (1 === bccomp($transaction->transaction_amount, '0') && null === $transaction->opposing_account_id) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$journalId = $transaction->journal_id;
|
|
|
|
/** @var TransactionModel $other */
|
|
|
|
$other = TransactionModel::where('transaction_journal_id', $journalId)->where('transactions.id', '!=', $transaction->id)
|
|
|
|
->where('amount', '=', bcmul($transaction->transaction_amount, '-1'))->where(
|
2017-11-15 03:52:29 -06:00
|
|
|
'identifier',
|
2017-11-15 04:33:07 -06:00
|
|
|
$transaction->identifier
|
2017-11-04 01:10:21 -05:00
|
|
|
)
|
|
|
|
->leftJoin('accounts', 'accounts.id', '=', 'transactions.account_id')
|
|
|
|
->leftJoin('account_types', 'account_types.id', '=', 'accounts.account_type_id')
|
|
|
|
->first(['transactions.account_id', 'accounts.encrypted', 'accounts.name', 'account_types.type']);
|
2017-11-08 01:28:04 -06:00
|
|
|
$name = app('steam')->tryDecrypt($other->name);
|
2017-11-04 01:10:21 -05:00
|
|
|
$transactionId = $other->account_id;
|
|
|
|
$type = $other->type;
|
|
|
|
}
|
|
|
|
|
2017-11-15 05:25:49 -06:00
|
|
|
if (AccountType::CASH === $type) {
|
2017-11-04 01:10:21 -05:00
|
|
|
$txt = '<span class="text-success">(' . trans('firefly.cash') . ')</span>';
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
|
|
|
|
$txt = sprintf('<a title="%1$s" href="%2$s">%1$s</a>', e($name), route('accounts.show', [$transactionId]));
|
|
|
|
$cache->store($txt);
|
|
|
|
|
|
|
|
return $txt;
|
|
|
|
}
|
2017-11-08 02:05:10 -06:00
|
|
|
}
|