Files
firefly-iii/app/models/LimitRepetition.php

55 lines
1.7 KiB
PHP
Raw Normal View History

<?php
2014-12-06 12:12:55 +01:00
use Watson\Validating\ValidatingTrait;
2014-12-20 15:00:53 +01:00
use \Illuminate\Database\Eloquent\Model as Eloquent;
2014-12-13 21:59:02 +01:00
/**
* Class LimitRepetition
*/
2014-12-06 12:12:55 +01:00
class LimitRepetition extends Eloquent
{
2014-12-06 12:12:55 +01:00
use ValidatingTrait;
public static $rules
2014-11-18 09:47:50 +01:00
= [
2014-12-13 22:54:52 +01:00
'budget_limit_id' => 'required|exists:budgetlimits,id',
2014-12-13 21:59:02 +01:00
'startdate' => 'required|date',
'enddate' => 'required|date',
'amount' => 'numeric|required|min:0.01',
2014-11-18 09:47:50 +01:00
];
2014-08-10 18:22:42 +02:00
/**
2014-12-13 21:59:02 +01:00
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
2014-08-10 18:22:42 +02:00
*/
2014-12-13 21:59:02 +01:00
public function budgetLimit()
{
2014-12-13 21:59:02 +01:00
return $this->belongsTo('BudgetLimit');
}
2014-12-06 12:12:55 +01:00
/**
2014-12-13 21:59:02 +01:00
* @return array
2014-12-06 12:12:55 +01:00
*/
2014-12-13 21:59:02 +01:00
public function getDates()
2014-12-06 12:12:55 +01:00
{
2014-12-13 21:59:02 +01:00
return ['created_at', 'updated_at', 'startdate', 'enddate'];
2014-12-06 12:12:55 +01:00
}
2014-11-17 20:45:55 +01:00
/**
2014-11-18 09:47:50 +01:00
*
2014-11-17 20:45:55 +01:00
* @return float
*/
2014-11-12 22:37:44 +01: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');
2014-11-12 22:37:44 +01:00
return floatval($sum);
}
2015-01-02 06:16:49 +01:00
}