| Current Path : /home/users/unlimited/www/admin.eclassify.codeskitter.site/app/Models/ |
| Current File : /home/users/unlimited/www/admin.eclassify.codeskitter.site/app/Models/Area.php |
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class Area extends Model {
use HasFactory;
protected $fillable = [
'name',
'country_id',
'state_id',
'city_id',
'state_code',
'latitude',
'longitude'
];
public function city() {
return $this->belongsTo(City::class);
}
public function state() {
return $this->belongsTo(State::class);
}
public function country() {
return $this->belongsTo(Country::class);
}
public function scopeFilter($query, $filterObject) {
if (!empty($filterObject)) {
foreach ($filterObject as $column => $value) {
if ($column == "city.name") {
$query->whereHas('city', function ($query) use ($value) {
$query->where('city_id', $value);
});
} elseif ($column == "state.name") {
$query->whereHas('state', function ($query) use ($value) {
$query->where('state_id', $value);
});
} elseif ($column == "country.name") {
$query->whereHas('country', function ($query) use ($value) {
$query->where('country_id', $value);
});
} else {
$query->where((string)$column, (string)$value);
}
}
}
return $query;
}
public function scopeSearch($query, $search) {
$search = "%" . $search . "%";
$query = $query->where(function ($q) use ($search) {
$q->orWhere('id', 'LIKE', $search)
->orWhere('name', 'LIKE', $search)
->orWhere('city_id', 'LIKE', $search)
->orWhere('state_id', 'LIKE', $search)
->orWhere('state_code', 'LIKE', $search)
->orWhere('country_id', 'LIKE', $search)
->orWhereHas('country', function ($q) use ($search) {
$q->where('name', 'LIKE', $search);
})->orWhereHas('state', function ($q) use ($search) {
$q->where('name', 'LIKE', $search);
})->orWhereHas('city', function ($q) use ($search) {
$q->where('name', 'LIKE', $search);
});
});
return $query;
}
}