mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-01-21 22:13:11 -06:00
69 lines
2.6 KiB
PHP
69 lines
2.6 KiB
PHP
<?php
|
|
|
|
namespace FireflyIII\Support\Twig;
|
|
|
|
use Auth;
|
|
use DB;
|
|
use FireflyIII\Models\LimitRepetition;
|
|
use Twig_Extension;
|
|
use Twig_SimpleFunction;
|
|
|
|
/**
|
|
* Class Budget
|
|
*
|
|
* @package FireflyIII\Support\Twig
|
|
*/
|
|
class Budget extends Twig_Extension
|
|
{
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function getFunctions()
|
|
{
|
|
$functions[] = new Twig_SimpleFunction(
|
|
'spentInRepetition', function (LimitRepetition $repetition) {
|
|
$sum = DB::table('transactions')
|
|
->leftJoin('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id')
|
|
->leftJoin('budget_transaction_journal', 'budget_transaction_journal.transaction_journal_id', '=', 'transaction_journals.id')
|
|
->leftJoin('budget_limits', 'budget_limits.budget_id', '=', 'budget_transaction_journal.budget_id')
|
|
->leftJoin('limit_repetitions', 'limit_repetitions.budget_limit_id', '=', 'budget_limits.id')
|
|
->where('transaction_journals.date', '>=', $repetition->startdate->format('Y-m-d'))
|
|
->where('transaction_journals.date', '<=', $repetition->enddate->format('Y-m-d'))
|
|
->where('transaction_journals.user_id', Auth::user()->id)
|
|
->whereNull('transactions.deleted_at')
|
|
->where('transactions.amount', '>', 0)
|
|
->where('limit_repetitions.id', '=', $repetition->id)
|
|
->sum('transactions.amount');
|
|
|
|
return floatval($sum);
|
|
}
|
|
);
|
|
|
|
$functions[] = new Twig_SimpleFunction(
|
|
'spentInRepetitionCorrected', function (LimitRepetition $repetition) {
|
|
$sum =
|
|
Auth::user()->transactionjournals()
|
|
->leftJoin('budget_transaction_journal', 'budget_transaction_journal.transaction_journal_id', '=', 'transaction_journals.id')
|
|
->leftJoin('budget_limits', 'budget_limits.budget_id', '=', 'budget_transaction_journal.budget_id')
|
|
->leftJoin('limit_repetitions', 'limit_repetitions.budget_limit_id', '=', 'budget_limits.id')
|
|
->before($repetition->enddate)
|
|
->after($repetition->startdate)
|
|
->where('limit_repetitions.id', '=', $repetition->id)
|
|
->get(['transaction_journals.*'])->sum('amount');
|
|
return floatval($sum);
|
|
}
|
|
);
|
|
|
|
return $functions;
|
|
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
public function getName()
|
|
{
|
|
return 'FireflyIII\Support\Twig\Budget';
|
|
}
|
|
}
|