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.

71 lines
1.6 KiB

<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
class City extends Model
{
use HasFactory;
protected $fillable = [
'uuid',
'name',
'url',
];
public function companies(): BelongsToMany
{
return $this->belongsToMany(Company::class, 'cities_companies', 'city_id', 'company_id');
}
public function getCompanyIds(): array
{
return $this->companies()->pluck('company_id')->toArray();
}
public function addCompanyId(int $company_id)
{
$this->addCompanyIds([$company_id]);
}
public function addCompanyIds(array $company_ids)
{
$companyIDs = array_merge($this->getCompanyIds(), $company_ids);
$this->companies()->sync($companyIDs);
}
public function removeCompanyID(int $company_id)
{
$this->companies()->detach($company_id);
}
public function removeCompanyIds(array $company_ids)
{
$this->companies()->detach($company_ids);
}
public static function validate_with_name(string $name)
{
$name = $name ?? '';
if($name == '')
return [
'error' => 'The city name is empty, please, write the name!!!'
];
$city = City::where('name', $name)->first();
if(!$city)
return [
'error' => 'A city with the name does not exist!!!'
];
return [
'ok' => 'A city with the name is valid.'
];
}
}