xmrmemes/app/Models/User.php
dev 4c1b493943 Add tips count to leaderboard
Also rename memes_total to memes_count to make it more consistent
2021-08-10 21:55:34 -07:00

73 lines
1.5 KiB
PHP

<?php
namespace App\Models;
use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
class User extends Authenticatable
{
use HasFactory, Notifiable;
protected $appends = ['tips_count', 'tips_total', 'memes_count'];
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name',
'email',
'address',
'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password',
'remember_token',
];
/**
* The attributes that should be cast to native types.
*
* @var array
*/
protected $casts = [
'email_verified_at' => 'datetime',
];
public function memes()
{
return $this->hasMany(Meme::class)->orderByDesc('created_at');
}
public function tips()
{
return $this->hasManyThrough(Tip::class, Meme::class, 'user_id');
}
public function getMemesCountAttribute()
{
return $this->memes->count();
}
public function getTipsCountAttribute()
{
return $this->tips->where('is_deposit', 1)->count();
}
public function getTipsTotalAttribute()
{
return $this->tips->where('is_deposit', 1)->sum('amount_formatted');
}
}