2014-06-29 15:12:33 -05:00
|
|
|
<?php
|
|
|
|
|
2014-07-15 10:09:59 -05:00
|
|
|
use LaravelBook\Ardent\Ardent;
|
2014-06-29 15:12:33 -05:00
|
|
|
|
2014-07-15 10:09:59 -05:00
|
|
|
|
2014-08-17 14:17:31 -05:00
|
|
|
/**
|
|
|
|
* TransactionJournal
|
|
|
|
*
|
2014-08-21 14:00:02 -05:00
|
|
|
* @property integer $id
|
|
|
|
* @property \Carbon\Carbon $created_at
|
|
|
|
* @property \Carbon\Carbon $updated_at
|
|
|
|
* @property integer $user_id
|
|
|
|
* @property integer $transaction_type_id
|
|
|
|
* @property integer $transaction_currency_id
|
|
|
|
* @property string $description
|
|
|
|
* @property boolean $completed
|
|
|
|
* @property \Carbon\Carbon $date
|
2014-08-17 14:17:31 -05:00
|
|
|
* @property-read \Illuminate\Database\Eloquent\Collection|\
|
|
|
|
* 'Budget[] $budgets
|
|
|
|
* @property-read \Illuminate\Database\Eloquent\Collection|\
|
|
|
|
* 'Category[] $categories
|
2014-08-21 14:00:02 -05:00
|
|
|
* @property-read \Illuminate\Database\Eloquent\Collection|\Component[] $components
|
|
|
|
* @property-read \TransactionCurrency $transactionCurrency
|
|
|
|
* @property-read \TransactionType $transactionType
|
2014-08-17 14:17:31 -05:00
|
|
|
* @property-read \Illuminate\Database\Eloquent\Collection|\Transaction[] $transactions
|
2014-08-21 14:00:02 -05:00
|
|
|
* @property-read \User $user
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\TransactionJournal whereId($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\TransactionJournal whereCreatedAt($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\TransactionJournal whereUpdatedAt($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\TransactionJournal whereUserId($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\TransactionJournal whereTransactionTypeId($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\TransactionJournal whereTransactionCurrencyId($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\TransactionJournal whereDescription($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\TransactionJournal whereCompleted($value)
|
|
|
|
* @method static \Illuminate\Database\Query\Builder|\TransactionJournal whereDate($value)
|
|
|
|
* @method static \TransactionJournal after($date)
|
|
|
|
* @method static \TransactionJournal before($date)
|
2014-08-17 14:17:31 -05:00
|
|
|
*/
|
2014-07-15 10:09:59 -05:00
|
|
|
class TransactionJournal extends Ardent
|
2014-07-03 14:31:32 -05:00
|
|
|
{
|
2014-06-29 15:12:33 -05:00
|
|
|
|
2014-07-03 14:31:32 -05:00
|
|
|
public static $rules
|
|
|
|
= [
|
|
|
|
'transaction_type_id' => 'required|exists:transaction_types,id',
|
|
|
|
'transaction_currency_id' => 'required|exists:transaction_currencies,id',
|
2014-07-15 10:09:59 -05:00
|
|
|
'description' => 'required|between:1,255',
|
|
|
|
'date' => 'required|date',
|
2014-07-05 09:19:15 -05:00
|
|
|
'completed' => 'required|between:0,1'
|
2014-07-03 14:31:32 -05:00
|
|
|
];
|
|
|
|
|
2014-07-09 06:35:33 -05:00
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
|
2014-08-10 11:22:42 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function budgets()
|
2014-07-03 14:31:32 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return $this->belongsToMany(
|
|
|
|
'Budget', 'component_transaction_journal', 'transaction_journal_id', 'component_id'
|
|
|
|
);
|
2014-06-29 15:12:33 -05:00
|
|
|
}
|
2014-07-03 14:31:32 -05:00
|
|
|
|
2014-07-16 14:11:43 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
|
2014-07-16 14:11:43 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function categories()
|
2014-07-16 14:11:43 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return $this->belongsToMany(
|
|
|
|
'Category', 'component_transaction_journal', 'transaction_journal_id', 'component_id'
|
|
|
|
);
|
2014-07-16 14:11:43 -05:00
|
|
|
}
|
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsToMany
|
2014-08-10 11:22:42 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function components()
|
2014-07-03 14:31:32 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return $this->belongsToMany('Component');
|
2014-06-29 15:12:33 -05:00
|
|
|
}
|
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* @return array
|
2014-08-10 11:22:42 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function getDates()
|
2014-07-03 14:31:32 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return ['created_at', 'updated_at', 'date'];
|
2014-06-29 15:12:33 -05:00
|
|
|
}
|
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* @param $query
|
|
|
|
* @param \Carbon\Carbon $date
|
|
|
|
*
|
|
|
|
* @return mixed
|
2014-08-10 11:22:42 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function scopeAfter($query, \Carbon\Carbon $date)
|
2014-07-05 12:44:26 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return $query->where('date', '>=', $date->format('Y-m-d'));
|
2014-07-05 12:44:26 -05:00
|
|
|
}
|
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* @param $query
|
|
|
|
* @param \Carbon\Carbon $date
|
|
|
|
*
|
|
|
|
* @return mixed
|
2014-08-10 11:22:42 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function scopeBefore($query, \Carbon\Carbon $date)
|
2014-07-05 12:44:26 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return $query->where('date', '<=', $date->format('Y-m-d'));
|
2014-07-05 12:44:26 -05:00
|
|
|
}
|
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
2014-08-10 11:22:42 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function transactionCurrency()
|
2014-07-05 12:44:26 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return $this->belongsTo('TransactionCurrency');
|
2014-07-05 12:44:26 -05:00
|
|
|
}
|
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
2014-08-10 11:22:42 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function transactionType()
|
2014-07-03 14:31:32 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return $this->belongsTo('TransactionType');
|
2014-07-03 14:31:32 -05:00
|
|
|
}
|
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\HasMany
|
2014-08-10 11:22:42 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function transactions()
|
2014-07-09 06:35:33 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return $this->hasMany('Transaction');
|
2014-07-09 05:56:06 -05:00
|
|
|
}
|
2014-07-09 06:35:33 -05:00
|
|
|
|
2014-08-10 11:22:42 -05:00
|
|
|
/**
|
2014-08-16 05:13:50 -05:00
|
|
|
* User
|
2014-08-10 11:22:42 -05:00
|
|
|
*
|
2014-08-16 05:13:50 -05:00
|
|
|
* @return \Illuminate\Database\Eloquent\Relations\BelongsTo
|
2014-08-10 11:22:42 -05:00
|
|
|
*/
|
2014-08-16 05:13:50 -05:00
|
|
|
public function user()
|
2014-07-09 06:35:33 -05:00
|
|
|
{
|
2014-08-16 05:13:50 -05:00
|
|
|
return $this->belongsTo('User');
|
2014-07-09 05:56:06 -05:00
|
|
|
}
|
|
|
|
|
2014-06-29 15:12:33 -05:00
|
|
|
}
|