firefly-iii/app/Models/LimitRepetition.php

46 lines
1.5 KiB
PHP
Raw Normal View History

2015-02-05 21:52:16 -06:00
<?php namespace FireflyIII\Models;
use Illuminate\Database\Eloquent\Model;
2015-02-11 00:35:10 -06:00
/**
* Class LimitRepetition
*
* @package FireflyIII\Models
*/
2015-02-05 22:04:06 -06:00
class LimitRepetition extends Model
{
2015-02-05 21:52:16 -06:00
2015-02-11 00:35:10 -06:00
/**
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
*/
2015-02-05 22:14:27 -06:00
public function budgetLimit()
{
2015-02-05 22:35:00 -06:00
return $this->belongsTo('FireflyIII\Models\BudgetLimit');
2015-02-05 22:14:27 -06:00
}
2015-02-07 06:15:40 -06:00
2015-02-11 00:35:10 -06:00
/**
* @return array
*/
2015-02-07 05:15:53 -06:00
public function getDates()
{
2015-02-07 06:15:40 -06:00
return ['created_at', 'updated_at', 'startdate', 'enddate'];
2015-02-07 05:15:53 -06:00
}
2015-02-05 21:52:16 -06:00
2015-02-22 08:40:13 -06:00
public function spentInRepetition()
{
$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', '>=', $this->startdate->format('Y-m-d'))
->where('transaction_journals.date', '<=', $this->enddate->format('Y-m-d'))
->where('transactions.amount', '>', 0)
->where('limit_repetitions.id', '=', $this->id)
->sum('transactions.amount');
return floatval($sum);
}
2015-02-05 21:52:16 -06:00
}