2014-07-20 11:24:27 -05:00
|
|
|
<?php
|
|
|
|
|
2014-11-12 07:38:32 -06:00
|
|
|
use FireflyIII\Exception\FireflyException;
|
2014-07-20 11:24:27 -05:00
|
|
|
use LaravelBook\Ardent\Ardent as Ardent;
|
|
|
|
|
2014-11-17 00:33:18 -06:00
|
|
|
|
2014-07-20 11:24:27 -05:00
|
|
|
/**
|
|
|
|
* LimitRepetition
|
|
|
|
*
|
2014-11-18 02:47:50 -06:00
|
|
|
* @property integer $id
|
2014-07-20 11:24:27 -05:00
|
|
|
* @property \Carbon\Carbon $created_at
|
|
|
|
* @property \Carbon\Carbon $updated_at
|
2014-11-18 02:47:50 -06:00
|
|
|
* @property integer $limit_id
|
2014-07-20 11:24:27 -05:00
|
|
|
* @property \Carbon\Carbon $startdate
|
|
|
|
* @property \Carbon\Carbon $enddate
|
2014-11-18 02:47:50 -06:00
|
|
|
* @property float $amount
|
|
|
|
* @property-read \Limit $limit
|
2014-11-17 15:32:55 -06:00
|
|
|
* @method static \Illuminate\Database\Query\Builder|\LimitRepetition whereId($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\LimitRepetition whereCreatedAt($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\LimitRepetition whereUpdatedAt($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\LimitRepetition whereLimitId($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\LimitRepetition whereStartdate($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\LimitRepetition whereEnddate($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\LimitRepetition whereAmount($value)
|
2014-07-20 11:24:27 -05:00
|
|
|
*/
|
|
|
|
class LimitRepetition extends Ardent
|
|
|
|
{
|
|
|
|
public static $rules
|
2014-11-18 02:47:50 -06:00
|
|
|
= [
|
|
|
|
'limit_id' => 'required|exists:limits,id',
|
|
|
|
'startdate' => 'required|date',
|
|
|
|
'enddate' => 'required|date',
|
|
|
|
'amount' => 'numeric|required|min:0.01',
|
|
|
|
];
|
2014-07-20 11:24:27 -05:00
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
2014-07-20 11:24:27 -05:00
|
|
|
public function getDates()
|
|
|
|
{
|
|
|
|
return ['created_at', 'updated_at', 'startdate', 'enddate'];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-11-18 02:47:50 -06:00
|
|
|
* TODO see if this scope is still used.
|
|
|
|
*
|
2014-07-20 11:24:27 -05:00
|
|
|
* How much money is left in this?
|
|
|
|
*/
|
2014-09-26 23:06:31 -05:00
|
|
|
public function leftInRepetition()
|
2014-07-20 11:24:27 -05:00
|
|
|
{
|
2014-11-08 12:11:51 -06:00
|
|
|
return floatval($this->amount - $this->spentInRepetition());
|
2014-07-20 11:24:27 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2014-11-17 13:45:55 -06:00
|
|
|
/**
|
|
|
|
* TODO remove this method in favour of something in the FireflyIII libraries.
|
2014-11-18 02:47:50 -06:00
|
|
|
*
|
2014-11-17 13:45:55 -06:00
|
|
|
* @return float
|
|
|
|
*/
|
2014-11-12 15:37:44 -06:00
|
|
|
public function spentInRepetition()
|
|
|
|
{
|
|
|
|
$sum = \DB::table('transactions')->leftJoin('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id')->leftJoin(
|
2014-11-17 00:33:18 -06:00
|
|
|
'component_transaction_journal', 'component_transaction_journal.transaction_journal_id', '=', 'transaction_journals.id'
|
|
|
|
)->leftJoin('components', 'components.id', '=', 'component_transaction_journal.component_id')->leftJoin(
|
|
|
|
'limits', 'limits.component_id', '=', 'components.id'
|
|
|
|
)->leftJoin('limit_repetitions', 'limit_repetitions.limit_id', '=', '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 15:37:44 -06:00
|
|
|
|
|
|
|
return floatval($sum);
|
|
|
|
}
|
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
|
|
|
*/
|
2014-07-27 13:29:58 -05:00
|
|
|
public function limit()
|
|
|
|
{
|
|
|
|
return $this->belongsTo('Limit');
|
|
|
|
}
|
|
|
|
|
2014-11-21 04:11:52 -06:00
|
|
|
|
2014-07-28 14:33:32 -05:00
|
|
|
/**
|
2014-11-17 13:45:55 -06:00
|
|
|
* TODO remove this method in favour of something in the FireflyIII libraries.
|
|
|
|
*
|
2014-07-28 14:33:32 -05:00
|
|
|
* Returns a string used to sort this particular repetition
|
|
|
|
* based on the date and period it falls into. Ie. the limit
|
|
|
|
* repeats monthly and the start date is 12 dec 2012, this will
|
|
|
|
* return 2012-12.
|
|
|
|
*/
|
|
|
|
public function periodOrder()
|
|
|
|
{
|
|
|
|
if (is_null($this->repeat_freq)) {
|
|
|
|
$this->repeat_freq = $this->limit->repeat_freq;
|
|
|
|
}
|
|
|
|
switch ($this->repeat_freq) {
|
|
|
|
default:
|
2014-11-12 07:38:32 -06:00
|
|
|
throw new FireflyException('No date formats for frequency "' . $this->repeat_freq . '"!');
|
2014-07-28 14:33:32 -05:00
|
|
|
break;
|
|
|
|
case 'daily':
|
2014-07-30 00:14:00 -05:00
|
|
|
return $this->startdate->format('Ymd') . '-5';
|
2014-07-28 14:33:32 -05:00
|
|
|
break;
|
|
|
|
case 'weekly':
|
2014-07-30 15:31:35 -05:00
|
|
|
return $this->startdate->format('Ymd') . '-4';
|
2014-07-28 14:33:32 -05:00
|
|
|
break;
|
|
|
|
case 'monthly':
|
|
|
|
return $this->startdate->format('Ymd') . '-3';
|
|
|
|
break;
|
|
|
|
case 'quarterly':
|
|
|
|
return $this->startdate->format('Ymd') . '-2';
|
|
|
|
break;
|
|
|
|
case 'half-year':
|
|
|
|
return $this->startdate->format('Ymd') . '-1';
|
|
|
|
break;
|
|
|
|
case 'yearly':
|
2014-07-30 00:14:00 -05:00
|
|
|
return $this->startdate->format('Ymd') . '-0';
|
2014-07-28 14:33:32 -05:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-11-17 13:45:55 -06:00
|
|
|
* TODO remove this method in favour of something in the FireflyIII libraries.
|
|
|
|
*
|
2014-07-28 14:33:32 -05:00
|
|
|
* Same as above, just with a more natural view. So "March 2012".
|
|
|
|
*/
|
|
|
|
public function periodShow()
|
|
|
|
{
|
|
|
|
if (is_null($this->repeat_freq)) {
|
|
|
|
$this->repeat_freq = $this->limit->repeat_freq;
|
|
|
|
}
|
|
|
|
switch ($this->repeat_freq) {
|
|
|
|
default:
|
2014-11-12 07:38:32 -06:00
|
|
|
throw new FireflyException('No date formats for frequency "' . $this->repeat_freq . '"!');
|
2014-07-28 14:33:32 -05:00
|
|
|
break;
|
|
|
|
case 'daily':
|
|
|
|
return $this->startdate->format('j F Y');
|
|
|
|
break;
|
|
|
|
case 'weekly':
|
|
|
|
return $this->startdate->format('\W\e\e\k W, Y');
|
|
|
|
break;
|
|
|
|
case 'monthly':
|
|
|
|
return $this->startdate->format('F Y');
|
|
|
|
break;
|
|
|
|
case 'half-year':
|
|
|
|
case 'quarterly':
|
|
|
|
return $this->startdate->format('M Y') . ' - ' . $this->enddate->format('M Y');
|
|
|
|
break;
|
|
|
|
case 'yearly':
|
|
|
|
return $this->startdate->format('Y');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-20 11:24:27 -05:00
|
|
|
|
|
|
|
}
|