feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
<?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',
|
2025-11-26 14:09:31 +09:00
|
|
|
'group_id',
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
'field_name',
|
2025-11-28 17:39:14 +09:00
|
|
|
'field_key',
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
'field_type',
|
|
|
|
|
'order_no',
|
|
|
|
|
'is_required',
|
|
|
|
|
'default_value',
|
|
|
|
|
'placeholder',
|
|
|
|
|
'display_condition',
|
|
|
|
|
'validation_rules',
|
|
|
|
|
'options',
|
|
|
|
|
'properties',
|
2025-11-27 10:28:51 +09:00
|
|
|
'category',
|
|
|
|
|
'description',
|
|
|
|
|
'is_common',
|
2025-12-05 14:40:09 +09:00
|
|
|
'is_active',
|
2025-11-28 17:39:14 +09:00
|
|
|
'is_locked',
|
|
|
|
|
'locked_by',
|
|
|
|
|
'locked_at',
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
'created_by',
|
|
|
|
|
'updated_by',
|
|
|
|
|
'deleted_by',
|
2025-12-09 09:39:16 +09:00
|
|
|
// 내부용 매핑 컬럼
|
|
|
|
|
'source_table',
|
|
|
|
|
'source_column',
|
|
|
|
|
'storage_type',
|
|
|
|
|
'json_path',
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
];
|
|
|
|
|
|
|
|
|
|
protected $casts = [
|
2025-11-26 14:09:31 +09:00
|
|
|
'group_id' => 'integer',
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
'order_no' => 'integer',
|
|
|
|
|
'is_required' => 'boolean',
|
2025-11-27 10:28:51 +09:00
|
|
|
'is_common' => 'boolean',
|
2025-12-05 14:40:09 +09:00
|
|
|
'is_active' => 'boolean',
|
2025-11-28 17:39:14 +09:00
|
|
|
'is_locked' => 'boolean',
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
'display_condition' => 'array',
|
|
|
|
|
'validation_rules' => 'array',
|
|
|
|
|
'options' => 'array',
|
|
|
|
|
'properties' => 'array',
|
|
|
|
|
'created_at' => 'datetime',
|
|
|
|
|
'updated_at' => 'datetime',
|
|
|
|
|
'deleted_at' => 'datetime',
|
2025-11-28 17:39:14 +09:00
|
|
|
'locked_at' => 'datetime',
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
];
|
|
|
|
|
|
2025-12-09 09:39:16 +09:00
|
|
|
/**
|
|
|
|
|
* API 응답에서 제외할 컬럼 (내부용)
|
|
|
|
|
*/
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
protected $hidden = [
|
|
|
|
|
'deleted_by',
|
|
|
|
|
'deleted_at',
|
2025-12-09 09:39:16 +09:00
|
|
|
// 내부용 매핑 컬럼 - API 응답에서 제외
|
|
|
|
|
'source_table',
|
|
|
|
|
'source_column',
|
|
|
|
|
'storage_type',
|
|
|
|
|
'json_path',
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
];
|
|
|
|
|
|
|
|
|
|
/**
|
2025-11-27 10:28:51 +09:00
|
|
|
* 이 필드가 연결된 섹션들 조회 (entity_relationships 기반)
|
2025-11-26 14:09:31 +09:00
|
|
|
*/
|
|
|
|
|
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);
|
|
|
|
|
}
|
2025-12-09 09:39:16 +09:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 시스템 필드 여부 확인 (DB 컬럼과 매핑된 필드)
|
|
|
|
|
*/
|
|
|
|
|
public function isSystemField(): bool
|
|
|
|
|
{
|
|
|
|
|
return ! is_null($this->source_table) && ! is_null($this->source_column);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 컬럼 저장 방식 여부 확인
|
|
|
|
|
*/
|
|
|
|
|
public function isColumnStorage(): bool
|
|
|
|
|
{
|
|
|
|
|
return $this->storage_type === 'column';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* JSON 저장 방식 여부 확인
|
|
|
|
|
*/
|
|
|
|
|
public function isJsonStorage(): bool
|
|
|
|
|
{
|
|
|
|
|
return $this->storage_type === 'json';
|
|
|
|
|
}
|
feat: ItemMaster 데이터베이스 구조 구축 (9개 테이블)
- 마이그레이션 9개 생성 (unit_options, section_templates, item_master_fields, item_pages, item_sections, item_fields, item_bom_items, custom_tabs, tab_columns)
- Eloquent 모델 9개 구현 (ItemMaster 네임스페이스)
- ItemMasterSeeder 작성 및 테스트 데이터 생성
주요 특징:
- Multi-tenant 지원 (BelongsToTenant trait)
- Soft Delete 적용 (deleted_at, deleted_by)
- 감사 로그 지원 (created_by, updated_by)
- JSON 필드로 동적 속성 지원 (display_condition, validation_rules, options, properties)
- FK 제약조건 및 Composite Index 설정
- 계층 구조 (ItemPage → ItemSection → ItemField/ItemBomItem)
SAM API Development Rules 준수
2025-11-20 16:36:55 +09:00
|
|
|
}
|