Files
sam-api/app/Models/Orders/Client.php
hskwon 5f200054ea feat: clients.is_active CHAR(1) → TINYINT(1) Boolean 마이그레이션
- DB: CHAR(1) 'Y'/'N' → TINYINT(1) 0/1 컬럼 타입 변경
- Model: boolean 캐스트 추가, scopeActive() 수정
- Service: toggle(), index() Boolean 로직 적용
- FormRequest: 'in:Y,N' → 'boolean' 검증 규칙 변경
- Swagger: is_active type string → boolean 변경
2025-12-08 20:25:38 +09:00

87 lines
1.9 KiB
PHP

<?php
namespace App\Models\Orders;
use App\Traits\BelongsToTenant;
use App\Traits\ModelTrait;
use Illuminate\Database\Eloquent\Model;
class Client extends Model
{
use BelongsToTenant, ModelTrait;
protected $fillable = [
'tenant_id',
'client_group_id',
'client_code',
'name',
'contact_person',
'phone',
'mobile',
'fax',
'email',
'address',
'account_id',
'account_password',
'purchase_payment_day',
'sales_payment_day',
'business_no',
'business_type',
'business_item',
'tax_agreement',
'tax_amount',
'tax_start_date',
'tax_end_date',
'bad_debt',
'bad_debt_amount',
'bad_debt_receive_date',
'bad_debt_end_date',
'bad_debt_progress',
'memo',
'is_active',
'client_type',
'manager_name',
'manager_tel',
'system_manager',
];
protected $casts = [
'is_active' => 'boolean',
'tax_agreement' => 'boolean',
'tax_amount' => 'decimal:2',
'tax_start_date' => 'date',
'tax_end_date' => 'date',
'bad_debt' => 'boolean',
'bad_debt_amount' => 'decimal:2',
'bad_debt_receive_date' => 'date',
'bad_debt_end_date' => 'date',
];
protected $hidden = [
'account_password',
];
// ClientGroup 관계
public function clientGroup()
{
return $this->belongsTo(ClientGroup::class, 'client_group_id');
}
// Orders 관계
public function orders()
{
return $this->hasMany(Order::class, 'client_id');
}
// 스코프
public function scopeActive($query)
{
return $query->where('is_active', true);
}
public function scopeCode($query, string $code)
{
return $query->where('client_code', $code);
}
}