| Current Path : /home/users/unlimited/www/admin.brosiper.codeskitter.site/app/Models/ |
| Current File : /home/users/unlimited/www/admin.brosiper.codeskitter.site/app/Models/Vendor.php |
<?php
namespace App\Models;
use App\CentralLogics\Helpers;
use Illuminate\Database\Eloquent\Relations\MorphOne;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
use App\Models\Store;
use Carbon\Carbon;
use Illuminate\Support\Facades\DB;
class Vendor extends Authenticatable
{
use Notifiable;
protected $guarded = ['id'];
protected $casts = [
'created_at' => 'datetime',
'updated_at' => 'datetime'
];
protected $hidden = [
'password',
'auth_token',
'remember_token',
];
protected $appends = ['image_full_url'];
public function getImageFullUrlAttribute(){
$value = $this->image;
if (count($this->storage) > 0) {
foreach ($this->storage as $storage) {
if ($storage['key'] == 'image') {
return Helpers::get_full_url('vendor',$value,$storage['value']);
}
}
}
return Helpers::get_full_url('vendor',$value,'public');
}
public function scopeOfStatus($query, $status): void
{
$query->where('status', '=', $status);
}
public function order_transaction()
{
return $this->hasMany(OrderTransaction::class);
}
public function todays_earning()
{
return $this->hasMany(OrderTransaction::class)->whereDate('created_at',now());
}
public function this_week_earning()
{
return $this->hasMany(OrderTransaction::class)->whereBetween('created_at', [Carbon::now()->startOfWeek(), Carbon::now()->endOfWeek()]);
}
public function this_month_earning()
{
return $this->hasMany(OrderTransaction::class)->whereMonth('created_at', date('m'))->whereYear('created_at', date('Y'));
}
public function todaysorders()
{
return $this->hasManyThrough(Order::class, Store::class)->whereDate('orders.created_at',now());
}
public function this_week_orders()
{
return $this->hasManyThrough(Order::class, Store::class)->whereBetween('orders.created_at', [Carbon::now()->startOfWeek(), Carbon::now()->endOfWeek()]);
}
public function this_month_orders()
{
return $this->hasManyThrough(Order::class, Store::class)->whereMonth('orders.created_at', date('m'))->whereYear('orders.created_at', date('Y'));
}
public function orders()
{
return $this->hasManyThrough(Order::class, Store::class);
}
public function stores()
{
return $this->hasMany(Store::class);
}
public function store()
{
return $this->hasOne(Store::class);
}
public function withdrawrequests()
{
return $this->hasMany(WithdrawRequest::class);
}
public function wallet()
{
return $this->hasOne(StoreWallet::class);
}
public function userinfo()
{
return $this->hasOne(UserInfo::class,'vendor_id', 'id');
}
public function storage()
{
return $this->morphMany(Storage::class, 'data');
}
protected static function booted()
{
static::addGlobalScope('storage', function ($builder) {
$builder->with('storage');
});
}
protected static function boot()
{
parent::boot();
static::saved(function ($model) {
if($model->isDirty('image')){
$value = Helpers::getDisk();
DB::table('storages')->updateOrInsert([
'data_type' => get_class($model),
'data_id' => $model->id,
'key' => 'image',
], [
'value' => $value,
'created_at' => now(),
'updated_at' => now(),
]);
}
});
}
}