56 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App;
 | 
						|
 | 
						|
use Illuminate\Database\Eloquent\Model;
 | 
						|
use Illuminate\Support\Str;
 | 
						|
use Spatie\QueryBuilder\QueryBuilder;
 | 
						|
 | 
						|
class Home extends Model
 | 
						|
{
 | 
						|
    protected $fillable = [
 | 
						|
        'title', 'price', 'surface', 'garden_surface', 'rooms', 'energy',
 | 
						|
        'ges', 'description', 'city', 'pictures', 'map', 'url', 'pictures_downloaded',
 | 
						|
    ];
 | 
						|
 | 
						|
    protected $casts = [
 | 
						|
        'map' => 'array',
 | 
						|
        'pictures' => 'array',
 | 
						|
    ];
 | 
						|
 | 
						|
    public function excerpt()
 | 
						|
    {
 | 
						|
        return Str::words($this->description, 10);
 | 
						|
    }
 | 
						|
 | 
						|
    public function scopePriceMax(QueryBuilder $query, $price): QueryBuilder
 | 
						|
    {
 | 
						|
        return $query->where('price', '<=', $price);
 | 
						|
    }
 | 
						|
 | 
						|
    public function scopePriceMin(QueryBuilder $query, $price): QueryBuilder
 | 
						|
    {
 | 
						|
        return $query->where('price', '>=', $price);
 | 
						|
    }
 | 
						|
 | 
						|
    public function scopeSurfaceMax(QueryBuilder $query, $price): QueryBuilder
 | 
						|
    {
 | 
						|
        return $query->where('surface', '<=', $price);
 | 
						|
    }
 | 
						|
 | 
						|
    public function scopeSurfaceMin(QueryBuilder $query, $price): QueryBuilder
 | 
						|
    {
 | 
						|
        return $query->where('surface', '>=', $price);
 | 
						|
    }
 | 
						|
 | 
						|
    public function scopeGardenSurfaceMax(QueryBuilder $query, $price): QueryBuilder
 | 
						|
    {
 | 
						|
        return $query->where('garden_surface', '<=', $price);
 | 
						|
    }
 | 
						|
 | 
						|
    public function scopeGardenSurfaceMin(QueryBuilder $query, $price): QueryBuilder
 | 
						|
    {
 | 
						|
        return $query->where('garden_surface', '>=', $price);
 | 
						|
    }
 | 
						|
}
 |