- ItemsBomController 생성 (code 기반 BOM 관리)
- 기존 ProductBomService 100% 재사용 (Adapter 패턴)
- Code → ID 변환 후 기존 비즈니스 로직 활용
- 프론트엔드 요구사항 완벽 대응 (itemCode 기반 API)
- 10개 엔드포인트 추가:
* GET /items/{code}/bom - BOM 목록 (flat)
* GET /items/{code}/bom/tree - BOM 트리 (계층)
* POST /items/{code}/bom - BOM 추가 (bulk upsert)
* PUT /items/{code}/bom/{lineId} - BOM 수정
* DELETE /items/{code}/bom/{lineId} - BOM 삭제
* GET /items/{code}/bom/summary - BOM 요약
* GET /items/{code}/bom/validate - BOM 검증
* POST /items/{code}/bom/replace - BOM 전체 교체
* POST /items/{code}/bom/reorder - BOM 정렬
* GET /items/{code}/bom/categories - 카테고리 목록
- Swagger 문서 완성 (ItemsBomApi.php)
- i18n 메시지 키 추가 (message.bom.created/updated/deleted)
- Hybrid 구조 지원 (quantity_formula, condition, attributes)
181 lines
7.4 KiB
PHP
181 lines
7.4 KiB
PHP
<?php
|
|
|
|
/**
|
|
* 성공/안내/일반 메시지 (비에러)
|
|
* - API 정상 응답의 message 필드용
|
|
* - 도메인 공통 키와 리소스별 하위 그룹을 혼합 사용
|
|
* - 예: return ApiResponse::success($data, __('message.created'));
|
|
*/
|
|
return [
|
|
|
|
// 공통 (CRUD/편의)
|
|
'fetched' => '조회 성공',
|
|
'created' => '등록 성공',
|
|
'updated' => '수정 성공',
|
|
'deleted' => '삭제 성공',
|
|
'restored' => '복구 성공',
|
|
'toggled' => '상태 변경 성공',
|
|
'bulk_upsert' => '대량 저장 성공',
|
|
'reordered' => '정렬 변경 성공',
|
|
'no_changes' => '변경 사항이 없습니다.',
|
|
|
|
// 인증/세션
|
|
'login_success' => '로그인 성공',
|
|
'logout_success' => '로그아웃 되었습니다.',
|
|
'signup_success' => '회원가입이 완료되었습니다.',
|
|
'registered' => '회원가입 처리',
|
|
'token_refreshed' => '토큰이 갱신되었습니다',
|
|
|
|
// 테넌트/컨텍스트
|
|
'tenant_switched' => '활성 테넌트가 전환되었습니다.',
|
|
|
|
// 리소스별 세부 (필요 시)
|
|
'item' => [
|
|
'fetched' => '품목을 조회했습니다.',
|
|
'created' => '품목이 등록되었습니다.',
|
|
'updated' => '품목이 수정되었습니다.',
|
|
'deleted' => '품목이 삭제되었습니다.',
|
|
],
|
|
|
|
'product' => [
|
|
'fetched' => '제품을 조회했습니다.',
|
|
'category_fetched' => '제품 카테고리를 조회했습니다.',
|
|
'created' => '제품이 등록되었습니다.',
|
|
'updated' => '제품이 수정되었습니다.',
|
|
'deleted' => '제품이 삭제되었습니다.',
|
|
'toggled' => '제품 상태가 변경되었습니다.',
|
|
'searched' => '제품을 검색했습니다.',
|
|
],
|
|
|
|
'bom' => [
|
|
'fetched' => 'BOM 항목을 조회했습니다.',
|
|
'created' => 'BOM 항목이 등록되었습니다.',
|
|
'updated' => 'BOM 항목이 수정되었습니다.',
|
|
'deleted' => 'BOM 항목이 삭제되었습니다.',
|
|
'bulk_upsert' => 'BOM 항목이 저장되었습니다.',
|
|
'reordered' => 'BOM 정렬이 변경되었습니다.',
|
|
'fetch' => 'BOM 항목 조회',
|
|
'create' => 'BOM 항목 등록',
|
|
'update' => 'BOM 항목 수정',
|
|
'delete' => 'BOM 항목 삭제',
|
|
'restore' => 'BOM 항목 복구',
|
|
],
|
|
|
|
'category' => [
|
|
'fetched' => '카테고리를 조회했습니다.',
|
|
'created' => '카테고리가 등록되었습니다.',
|
|
'updated' => '카테고리가 수정되었습니다.',
|
|
'deleted' => '카테고리가 삭제되었습니다.',
|
|
'toggled' => '카테고리 상태가 변경되었습니다.',
|
|
'moved' => '카테고리가 이동되었습니다.',
|
|
'reordered' => '카테고리 정렬순서가 변경되었습니다.',
|
|
'tree_fetched' => '카테고리 트리를 조회했습니다.',
|
|
'fields_saved' => '카테고리 필드가 저장되었습니다.',
|
|
'template_saved' => '카테고리 템플릿이 저장되었습니다.',
|
|
'template_applied' => '카테고리 템플릿이 적용되었습니다.',
|
|
],
|
|
|
|
'category_field' => [
|
|
'fetched' => '카테고리 필드를 조회했습니다.',
|
|
'created' => '카테고리 필드가 생성되었습니다.',
|
|
'updated' => '카테고리 필드가 수정되었습니다.',
|
|
'deleted' => '카테고리 필드가 삭제되었습니다.',
|
|
'reordered' => '카테고리 필드 정렬이 변경되었습니다.',
|
|
'bulk_upsert' => '카테고리 필드가 일괄 저장되었습니다.',
|
|
],
|
|
|
|
'design' => [
|
|
'template_cloned' => 'BOM 템플릿이 복제되었습니다.',
|
|
'template_diff' => 'BOM 템플릿 차이를 계산했습니다.',
|
|
],
|
|
|
|
'model_set' => [
|
|
'cloned' => '모델셋이 복제되었습니다.',
|
|
'calculated' => 'BOM 계산이 완료되었습니다.',
|
|
],
|
|
|
|
'estimate' => [
|
|
'cloned' => '견적이 복제되었습니다.',
|
|
'status_changed' => '견적 상태가 변경되었습니다.',
|
|
],
|
|
|
|
// 계산 관련
|
|
'calculated' => '계산 완료',
|
|
|
|
// 설정 관리 (Settings & Configuration 통합)
|
|
'settings' => [
|
|
'fields_updated' => '필드 설정이 업데이트되었습니다.',
|
|
'fields_bulk_saved' => '필드 설정 일괄 저장이 완료되었습니다.',
|
|
'options_saved' => '옵션 그룹이 저장되었습니다.',
|
|
'options_reordered' => '옵션 값 정렬이 변경되었습니다.',
|
|
'common_code_saved' => '공통 코드가 저장되었습니다.',
|
|
],
|
|
|
|
// 자재 관리 (Products & Materials 통합)
|
|
'material' => [
|
|
'fetched' => '자재를 조회했습니다.',
|
|
'created' => '자재가 등록되었습니다.',
|
|
'updated' => '자재가 수정되었습니다.',
|
|
'deleted' => '자재가 삭제되었습니다.',
|
|
],
|
|
|
|
// 거래처 관리
|
|
'client' => [
|
|
'fetched' => '거래처를 조회했습니다.',
|
|
'created' => '거래처가 등록되었습니다.',
|
|
'updated' => '거래처가 수정되었습니다.',
|
|
'deleted' => '거래처가 삭제되었습니다.',
|
|
'toggled' => '거래처 상태가 변경되었습니다.',
|
|
],
|
|
|
|
// 사용자 관리
|
|
'user' => [
|
|
'fetched' => '사용자를 조회했습니다.',
|
|
'me_fetched' => '나의 정보를 조회했습니다.',
|
|
'me_updated' => '나의 정보가 수정되었습니다.',
|
|
'password_changed' => '비밀번호가 변경되었습니다.',
|
|
'tenants_fetched' => '나의 테넌트 목록을 조회했습니다.',
|
|
'tenant_switched' => '활성 테넌트가 전환되었습니다.',
|
|
],
|
|
|
|
// 테넌트 관리
|
|
'tenant' => [
|
|
'fetched' => '테넌트를 조회했습니다.',
|
|
'created' => '테넌트가 등록되었습니다.',
|
|
'updated' => '테넌트가 수정되었습니다.',
|
|
'deleted' => '테넌트가 삭제되었습니다.',
|
|
'restored' => '테넌트가 복구되었습니다.',
|
|
],
|
|
|
|
'tenant_stat_field' => [
|
|
'fetched' => '통계 필드를 조회했습니다.',
|
|
'created' => '통계 필드가 생성되었습니다.',
|
|
'updated' => '통계 필드가 수정되었습니다.',
|
|
'deleted' => '통계 필드가 삭제되었습니다.',
|
|
'reordered' => '통계 필드 정렬이 변경되었습니다.',
|
|
'bulk_upsert' => '통계 필드가 일괄 저장되었습니다.',
|
|
],
|
|
|
|
// 파일 관리
|
|
'file' => [
|
|
'uploaded' => '파일이 업로드되었습니다.',
|
|
'deleted' => '파일이 삭제되었습니다.',
|
|
'fetched' => '파일 목록을 조회했습니다.',
|
|
],
|
|
|
|
// 파일 저장소
|
|
'file_uploaded' => '파일이 업로드되었습니다.',
|
|
'files_moved' => '파일이 이동되었습니다.',
|
|
'file_deleted' => '파일이 삭제되었습니다.',
|
|
'file_restored' => '파일이 복구되었습니다.',
|
|
'file_permanently_deleted' => '파일이 영구 삭제되었습니다.',
|
|
'share_link_created' => '공유 링크가 생성되었습니다.',
|
|
'storage_exceeded_grace_period' => '저장소 용량이 초과되었습니다. 유예 기간이 적용됩니다.',
|
|
|
|
// 폴더 관리
|
|
'folder_created' => '폴더가 생성되었습니다.',
|
|
'folder_updated' => '폴더가 수정되었습니다.',
|
|
'folder_deleted' => '폴더가 비활성화되었습니다.',
|
|
'folders_reordered' => '폴더 순서가 변경되었습니다.',
|
|
];
|