Files
sam-api/app/Http/Controllers/Api/V1/ItemMaster/ItemFieldController.php
hskwon bccfa19791 feat: Item Master 하이브리드 구조 전환 및 독립 API 추가
- CASCADE FK → 독립 엔티티 + entity_relationships 링크 테이블
- 독립 API 10개 추가 (섹션/필드/BOM CRUD, clone, usage)
- SectionTemplate 모델 제거 → ItemSection.is_template 통합
- 페이지-섹션, 섹션-필드, 섹션-BOM 링크/언링크 API 14개 추가
- Swagger 문서 업데이트
2025-11-26 14:09:31 +09:00

117 lines
3.2 KiB
PHP

<?php
namespace App\Http\Controllers\Api\V1\ItemMaster;
use App\Helpers\ApiResponse;
use App\Http\Controllers\Controller;
use App\Http\Requests\ItemMaster\IndependentFieldStoreRequest;
use App\Http\Requests\ItemMaster\ItemFieldStoreRequest;
use App\Http\Requests\ItemMaster\ItemFieldUpdateRequest;
use App\Http\Requests\ItemMaster\ReorderRequest;
use App\Services\ItemMaster\ItemFieldService;
class ItemFieldController extends Controller
{
public function __construct(private ItemFieldService $service) {}
/**
* 독립 필드 목록 조회
*
* GET /api/v1/item-master/fields
*/
public function index()
{
return ApiResponse::handle(function () {
return $this->service->index();
}, __('message.fetched'));
}
/**
* 독립 필드 생성 (섹션 연결 없음)
*
* POST /api/v1/item-master/fields
*/
public function storeIndependent(IndependentFieldStoreRequest $request)
{
return ApiResponse::handle(function () use ($request) {
return $this->service->storeIndependent($request->validated());
}, __('message.created'));
}
/**
* 필드 복제
*
* POST /api/v1/item-master/fields/{id}/clone
*/
public function clone(int $id)
{
return ApiResponse::handle(function () use ($id) {
return $this->service->clone($id);
}, __('message.created'));
}
/**
* 필드 사용처 조회
*
* GET /api/v1/item-master/fields/{id}/usage
*/
public function getUsage(int $id)
{
return ApiResponse::handle(function () use ($id) {
return $this->service->getUsage($id);
}, __('message.fetched'));
}
/**
* 필드 생성 (섹션에 연결)
*
* POST /api/v1/item-master/sections/{sectionId}/fields
*/
public function store(int $sectionId, ItemFieldStoreRequest $request)
{
return ApiResponse::handle(function () use ($sectionId, $request) {
return $this->service->store($sectionId, $request->validated());
}, __('message.created'));
}
/**
* 필드 수정
*
* PUT /api/v1/item-master/fields/{id}
*/
public function update(int $id, ItemFieldUpdateRequest $request)
{
return ApiResponse::handle(function () use ($id, $request) {
return $this->service->update($id, $request->validated());
}, __('message.updated'));
}
/**
* 필드 삭제 (Soft Delete)
*
* DELETE /api/v1/item-master/fields/{id}
*/
public function destroy(int $id)
{
return ApiResponse::handle(function () use ($id) {
$this->service->destroy($id);
return 'success';
}, __('message.deleted'));
}
/**
* 필드 순서 변경
*
* PUT /api/v1/item-master/sections/{sectionId}/fields/reorder
*/
public function reorder(int $sectionId, ReorderRequest $request)
{
return ApiResponse::handle(function () use ($sectionId, $request) {
$this->service->reorder($sectionId, $request->validated()['items']);
return 'success';
}, __('message.reordered'));
}
}