停车场管理系统
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

<?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['name']) {
$item['name'] = AdminTranslationService::getTranslationTypeName(
$id,
6,
$item['name']
);
}
return $item;
}
}