- FK 컬럼 제거: item_sections.page_id, item_fields.section_id, item_bom_items.section_id - entity_relationships 테이블로 전환하여 독립 엔티티 구조 확립 - ItemMasterField 관련 파일 삭제 (Controller, Service, Model, Requests) - destroy 메서드 독립 엔티티 아키텍처 적용 (관계 링크만 삭제) - Swagger 스키마에서 FK 참조 제거 - FormRequest 및 Swagger에 group_id(계층번호) 필드 추가
91 lines
2.4 KiB
PHP
91 lines
2.4 KiB
PHP
<?php
|
|
|
|
namespace App\Models\ItemMaster;
|
|
|
|
use App\Traits\BelongsToTenant;
|
|
use App\Traits\ModelTrait;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
class ItemField extends Model
|
|
{
|
|
use BelongsToTenant, ModelTrait, SoftDeletes;
|
|
|
|
protected $fillable = [
|
|
'tenant_id',
|
|
'group_id',
|
|
'field_name',
|
|
'field_type',
|
|
'order_no',
|
|
'is_required',
|
|
'default_value',
|
|
'placeholder',
|
|
'display_condition',
|
|
'validation_rules',
|
|
'options',
|
|
'properties',
|
|
'category',
|
|
'description',
|
|
'is_common',
|
|
'created_by',
|
|
'updated_by',
|
|
'deleted_by',
|
|
];
|
|
|
|
protected $casts = [
|
|
'group_id' => 'integer',
|
|
'order_no' => 'integer',
|
|
'is_required' => 'boolean',
|
|
'is_common' => 'boolean',
|
|
'display_condition' => 'array',
|
|
'validation_rules' => 'array',
|
|
'options' => 'array',
|
|
'properties' => 'array',
|
|
'created_at' => 'datetime',
|
|
'updated_at' => 'datetime',
|
|
'deleted_at' => 'datetime',
|
|
];
|
|
|
|
protected $hidden = [
|
|
'deleted_by',
|
|
'deleted_at',
|
|
];
|
|
|
|
/**
|
|
* 이 필드가 연결된 섹션들 조회 (entity_relationships 기반)
|
|
*/
|
|
public function linkedSections()
|
|
{
|
|
return ItemSection::whereIn('id', function ($query) {
|
|
$query->select('parent_id')
|
|
->from('entity_relationships')
|
|
->where('parent_type', EntityRelationship::TYPE_SECTION)
|
|
->where('child_type', EntityRelationship::TYPE_FIELD)
|
|
->where('child_id', $this->id);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* 이 필드가 직접 연결된 페이지들 조회 (링크 테이블 기반)
|
|
*/
|
|
public function linkedPages()
|
|
{
|
|
return ItemPage::whereIn('id', function ($query) {
|
|
$query->select('parent_id')
|
|
->from('entity_relationships')
|
|
->where('parent_type', EntityRelationship::TYPE_PAGE)
|
|
->where('child_type', EntityRelationship::TYPE_FIELD)
|
|
->where('child_id', $this->id);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* 이 필드의 모든 부모 관계 목록 조회
|
|
*/
|
|
public function allParentRelationships()
|
|
{
|
|
return EntityRelationship::where('child_type', EntityRelationship::TYPE_FIELD)
|
|
->where('child_id', $this->id);
|
|
}
|
|
}
|