You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							83 lines
						
					
					
						
							2.1 KiB
						
					
					
				
			
		
		
	
	
							83 lines
						
					
					
						
							2.1 KiB
						
					
					
				| <?php
 | |
| 
 | |
| namespace App\Models;
 | |
| 
 | |
| use Illuminate\Foundation\Auth\User as Authenticatable;
 | |
| use Illuminate\Notifications\Notifiable;
 | |
| use App\Models\Restaurant;
 | |
| use Carbon\Carbon;
 | |
| 
 | |
| class Vendor extends Authenticatable
 | |
| {
 | |
|     use Notifiable;
 | |
| 
 | |
|     protected $casts = [
 | |
|         'created_at' => 'datetime',
 | |
|         'updated_at' => 'datetime'
 | |
|     ];
 | |
| 
 | |
|     protected $hidden = [
 | |
|         'password',
 | |
|         'auth_token',
 | |
|         'remember_token',
 | |
|     ];
 | |
| 
 | |
|     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, Restaurant::class)->whereDate('orders.created_at',now());
 | |
|     }
 | |
| 
 | |
|     public function this_week_orders()
 | |
|     {
 | |
|         return $this->hasManyThrough(Order::class, Restaurant::class)->whereBetween('orders.created_at', [Carbon::now()->startOfWeek(), Carbon::now()->endOfWeek()]);
 | |
|     }
 | |
| 
 | |
|     public function this_month_orders()
 | |
|     {
 | |
|         return $this->hasManyThrough(Order::class, Restaurant::class)->whereMonth('orders.created_at', date('m'))->whereYear('orders.created_at', date('Y'));
 | |
|     }
 | |
| 
 | |
|     public function userinfo()
 | |
|     {
 | |
|         return $this->hasOne(UserInfo::class,'vendor_id', 'id');
 | |
|     }
 | |
| 
 | |
|     public function orders()
 | |
|     {
 | |
|         return $this->hasManyThrough(Order::class, Restaurant::class);
 | |
|     }
 | |
| 
 | |
|     public function restaurants()
 | |
|     {
 | |
|         return $this->hasMany(Restaurant::class);
 | |
|     }
 | |
|     public function withdrawrequests()
 | |
|     {
 | |
|         return $this->hasMany(WithdrawRequest::class);
 | |
|     }
 | |
|     public function wallet()
 | |
|     {
 | |
|         return $this->hasOne(RestaurantWallet::class);
 | |
|     }
 | |
| 
 | |
| }
 | |
| 
 |