feat: Item Master 하이브리드 구조 전환 및 독립 API 추가
- CASCADE FK → 독립 엔티티 + entity_relationships 링크 테이블 - 독립 API 10개 추가 (섹션/필드/BOM CRUD, clone, usage) - SectionTemplate 모델 제거 → ItemSection.is_template 통합 - 페이지-섹션, 섹션-필드, 섹션-BOM 링크/언링크 API 14개 추가 - Swagger 문서 업데이트
This commit is contained in:
@@ -13,6 +13,7 @@ class ItemPage extends Model
|
||||
|
||||
protected $fillable = [
|
||||
'tenant_id',
|
||||
'group_id',
|
||||
'page_name',
|
||||
'item_type',
|
||||
'absolute_path',
|
||||
@@ -23,6 +24,7 @@ class ItemPage extends Model
|
||||
];
|
||||
|
||||
protected $casts = [
|
||||
'group_id' => 'integer',
|
||||
'is_active' => 'boolean',
|
||||
'created_at' => 'datetime',
|
||||
'updated_at' => 'datetime',
|
||||
@@ -35,10 +37,70 @@ class ItemPage extends Model
|
||||
];
|
||||
|
||||
/**
|
||||
* 페이지의 섹션 목록
|
||||
* 페이지의 섹션 목록 (기존 FK 기반 - 하위 호환성)
|
||||
*/
|
||||
public function sections()
|
||||
{
|
||||
return $this->hasMany(ItemSection::class, 'page_id')->orderBy('order_no');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 페이지와 연결된 섹션 관계 목록 (링크 테이블 기반)
|
||||
*/
|
||||
public function sectionRelationships()
|
||||
{
|
||||
return $this->hasMany(EntityRelationship::class, 'parent_id')
|
||||
->where('parent_type', EntityRelationship::TYPE_PAGE)
|
||||
->where('child_type', EntityRelationship::TYPE_SECTION)
|
||||
->orderBy('order_no');
|
||||
}
|
||||
|
||||
/**
|
||||
* 페이지와 직접 연결된 필드 관계 목록 (링크 테이블 기반)
|
||||
*/
|
||||
public function fieldRelationships()
|
||||
{
|
||||
return $this->hasMany(EntityRelationship::class, 'parent_id')
|
||||
->where('parent_type', EntityRelationship::TYPE_PAGE)
|
||||
->where('child_type', EntityRelationship::TYPE_FIELD)
|
||||
->orderBy('order_no');
|
||||
}
|
||||
|
||||
/**
|
||||
* 페이지에 연결된 섹션들 조회 (링크 테이블 기반)
|
||||
*/
|
||||
public function linkedSections()
|
||||
{
|
||||
return ItemSection::whereIn('id', function ($query) {
|
||||
$query->select('child_id')
|
||||
->from('entity_relationships')
|
||||
->where('parent_type', EntityRelationship::TYPE_PAGE)
|
||||
->where('parent_id', $this->id)
|
||||
->where('child_type', EntityRelationship::TYPE_SECTION);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* 페이지에 직접 연결된 필드들 조회 (링크 테이블 기반)
|
||||
*/
|
||||
public function linkedFields()
|
||||
{
|
||||
return ItemField::whereIn('id', function ($query) {
|
||||
$query->select('child_id')
|
||||
->from('entity_relationships')
|
||||
->where('parent_type', EntityRelationship::TYPE_PAGE)
|
||||
->where('parent_id', $this->id)
|
||||
->where('child_type', EntityRelationship::TYPE_FIELD);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* 페이지의 모든 관계 목록 조회 (섹션 + 직접 연결된 필드)
|
||||
*/
|
||||
public function allRelationships()
|
||||
{
|
||||
return $this->hasMany(EntityRelationship::class, 'parent_id')
|
||||
->where('parent_type', EntityRelationship::TYPE_PAGE)
|
||||
->orderBy('order_no');
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user