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.
98 lines
2.3 KiB
98 lines
2.3 KiB
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use App\Services\AdminTranslationService;
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
class ParkingChannel extends Model
|
|
{
|
|
use HasFactory, SoftDeletes;
|
|
|
|
protected $table = 'parking_channel';
|
|
|
|
protected $fillable
|
|
= [
|
|
'name',
|
|
'type',
|
|
'position',
|
|
'parking_id',
|
|
'guard_booth_id',
|
|
'third_party_channel'
|
|
];
|
|
|
|
protected $hidden
|
|
= [
|
|
'updated_at',
|
|
'deleted_at'
|
|
];
|
|
|
|
public static function getData()
|
|
{
|
|
return self::query()->select(['id', 'name'])->get()->each(
|
|
function ($item) {
|
|
$item['name'] = AdminTranslationService::getTranslationTypeName(
|
|
$item['id'],
|
|
6,
|
|
$item['name']
|
|
);
|
|
return $item;
|
|
}
|
|
);
|
|
}
|
|
|
|
|
|
public static function getChannelData($ids)
|
|
{
|
|
return self::query()->whereIn('id', $ids)->select(
|
|
['id', 'name']
|
|
)->get()->each(function ($item) {
|
|
$item['name'] = AdminTranslationService::getTranslationTypeName(
|
|
$item['id'],
|
|
6,
|
|
$item['name']
|
|
);
|
|
return $item;
|
|
});
|
|
}
|
|
|
|
public static function getIds($parking_id)
|
|
{
|
|
return self::query()->where('parking_id', $parking_id)->pluck('id');
|
|
}
|
|
|
|
public static function getParkingId($id)
|
|
{
|
|
return self::query()->where('id', $id)->value('parking_id');
|
|
}
|
|
|
|
public static function getName($id)
|
|
{
|
|
$name = self::query()->where('id', $id)->value('name');
|
|
return AdminTranslationService::getTranslationTypeName(
|
|
$id,
|
|
6,
|
|
$name
|
|
);
|
|
}
|
|
|
|
public function getCreatedAtAttribute($value): string
|
|
{
|
|
return $value ? date("Y-m-d H:i:s", strtotime($value)) : $value;
|
|
}
|
|
|
|
public static function getFirst($id)
|
|
{
|
|
$item = self::query()->where('id', $id)->first();
|
|
if ($item) {
|
|
$item['name'] = AdminTranslationService::getTranslationTypeName(
|
|
$id,
|
|
6,
|
|
$item['name']
|
|
);
|
|
}
|
|
return $item;
|
|
}
|
|
}
|
|
|