osb/app/User.php

112 lines
2.2 KiB
PHP
Raw Normal View History

2017-11-03 16:26:07 +11:00
<?php
namespace App;
2018-06-05 21:13:57 +10:00
use Laravel\Passport\HasApiTokens;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
2017-11-03 16:26:07 +11:00
class User extends Authenticatable
2017-11-03 16:26:07 +11:00
{
2018-05-20 22:53:14 +10:00
protected $table = 'ab_account';
2018-06-05 21:13:57 +10:00
// @todo We cannot use timestamps - we should create the normal timestamps columns under laravel.
public $timestamps = FALSE;
2018-05-20 22:53:14 +10:00
2018-06-05 21:13:57 +10:00
use HasApiTokens, Notifiable;
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'email', 'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
/**
* Return the country the user belongs to
*/
public function country()
{
2018-05-20 22:53:14 +10:00
return $this->belongsTo(Models\Country::class);
}
/**
* This users invoices
*/
public function invoices()
{
2018-06-05 21:13:57 +10:00
return $this->hasMany(Models\Invoice::class,'account_id');
2018-05-20 22:53:14 +10:00
}
public function language()
{
2018-06-05 21:13:57 +10:00
return $this->belongsTo(Models\Language::class);
2018-05-20 22:53:14 +10:00
}
public function payments()
{
2018-06-05 21:13:57 +10:00
return $this->hasMany(Models\Payment::class,'account_id');
2018-05-20 22:53:14 +10:00
}
/**
* This users invoices
*/
public function services()
{
2018-06-05 21:13:57 +10:00
return $this->hasMany(Models\Service::class,'account_id');
}
/**
* Only query active categories
*/
public function scopeActive()
{
return $this->where('active',TRUE);
}
/**
* Return the user's full name
*/
2018-05-20 22:53:14 +10:00
public function getFullNameAttribute()
{
return $this->first_name.' '.$this->last_name;
}
public function getInvoicesDueAttribute()
{
2018-06-05 21:13:57 +10:00
return $this->invoices
->where('active',TRUE)
->sortBy('id')
->transform(function ($item) { if ((float) $item->due) return $item; })
2018-06-05 21:13:57 +10:00
->reverse()
->filter();
2018-05-20 22:53:14 +10:00
}
public function getPaymentHistoryAttribute()
{
2018-06-05 21:13:57 +10:00
return $this->payments
->sortBy('date_payment')
->reverse();
2018-05-20 22:53:14 +10:00
}
public function getNameAttribute()
{
2018-06-05 21:13:57 +10:00
return $this->full_name;
2018-05-20 22:53:14 +10:00
}
public function getServicesActiveAttribute()
{
return $this->services
2018-06-05 21:13:57 +10:00
->where('active',TRUE);
}
}