Files
sam-api/app/Http/Controllers/Api/V1/ItemsController.php
hskwon 2862015605 feat: Items show() API 개선 - files 로딩 및 item_type 선택적 처리
- Item 모델 files() 관계를 document_id/document_type 기반으로 변경
- show() 메서드에 files 로딩 및 field_key별 그룹화 추가
- item_type 파라미터 선택적 처리 (ID만으로 조회 가능)
- showWithPrice() 메서드 반환 타입 변경에 맞게 수정
2025-12-15 19:27:36 +09:00

143 lines
5.0 KiB
PHP

<?php
namespace App\Http\Controllers\Api\V1;
use App\Helpers\ApiResponse;
use App\Http\Controllers\Controller;
use App\Http\Requests\Item\ItemBatchDeleteRequest;
use App\Http\Requests\Item\ItemStoreRequest;
use App\Http\Requests\Item\ItemUpdateRequest;
use App\Services\ItemService;
use Illuminate\Http\Request;
class ItemsController extends Controller
{
public function __construct(private ItemService $service) {}
/**
* 통합 품목 목록 조회 (items 테이블)
*
* GET /api/v1/items
*/
public function index(Request $request)
{
return ApiResponse::handle(function () use ($request) {
$params = [
'size' => $request->input('size', 20),
'q' => $request->input('q') ?? $request->input('search'),
'category_id' => $request->input('category_id'),
'item_type' => $request->input('type') ?? $request->input('item_type'),
'group_id' => $request->input('group_id'),
'active' => $request->input('is_active') ?? $request->input('active'),
];
return $this->service->index($params);
}, __('message.fetched'));
}
/**
* 단일 품목 조회 (동적 테이블 라우팅)
*
* GET /api/v1/items/{id}?item_type=FG&include_price=true&client_id=1&price_date=2025-01-10
*
* @param string|null item_type 품목 유형 (선택적 - 없으면 ID만으로 조회)
*/
public function show(Request $request, int $id)
{
return ApiResponse::handle(function () use ($request, $id) {
// item_type 선택적 (없으면 ID만으로 items 테이블에서 조회)
$itemType = $request->input('item_type');
$itemType = $itemType ? strtoupper($itemType) : null;
$includePrice = filter_var($request->input('include_price', false), FILTER_VALIDATE_BOOLEAN);
if ($includePrice) {
$clientId = $request->input('client_id') ? (int) $request->input('client_id') : null;
$priceDate = $request->input('price_date');
return $this->service->showWithPrice($id, $itemType, $clientId, $priceDate);
}
return $this->service->show($id, $itemType);
}, __('message.fetched'));
}
/**
* 품목 상세 조회 (동적 테이블 라우팅, code 기반, BOM 포함 옵션)
*
* GET /api/v1/items/code/{code}?item_type=FG&include_bom=true
*
* @param string item_type 품목 유형 (필수 - 동적 테이블 라우팅)
*/
public function showByCode(Request $request, string $code)
{
return ApiResponse::handle(function () use ($request, $code) {
// item_type 필수 (동적 테이블 라우팅에 사용)
$itemType = strtoupper($request->input('item_type', ''));
$includeBom = filter_var($request->input('include_bom', false), FILTER_VALIDATE_BOOLEAN);
return $this->service->showByCode($code, $itemType, $includeBom);
}, __('message.item.fetched'));
}
/**
* 품목 생성
*
* POST /api/v1/items
*/
public function store(ItemStoreRequest $request)
{
return ApiResponse::handle(function () use ($request) {
return $this->service->store($request->all());
}, __('message.item.created'));
}
/**
* 품목 수정
*
* PUT /api/v1/items/{id}
*/
public function update(int $id, ItemUpdateRequest $request)
{
return ApiResponse::handle(function () use ($id, $request) {
return $this->service->update($id, $request->all());
}, __('message.item.updated'));
}
/**
* 품목 삭제 (동적 테이블 라우팅, Soft Delete)
*
* DELETE /api/v1/items/{id}?item_type=FG
*
* @param string item_type 품목 유형 (필수 - 동적 테이블 라우팅)
*/
public function destroy(Request $request, int $id)
{
return ApiResponse::handle(function () use ($request, $id) {
// item_type 필수 (동적 테이블 라우팅에 사용)
$itemType = strtoupper($request->input('item_type', ''));
$this->service->destroy($id, $itemType);
return 'success';
}, __('message.item.deleted'));
}
/**
* 품목 일괄 삭제 (동적 테이블 라우팅, Soft Delete)
*
* DELETE /api/v1/items/batch?item_type=FG
*
* @param string item_type 품목 유형 (필수 - 동적 테이블 라우팅)
*/
public function batchDestroy(ItemBatchDeleteRequest $request)
{
return ApiResponse::handle(function () use ($request) {
$validated = $request->validated();
// item_type 필수 (동적 테이블 라우팅에 사용)
$itemType = strtoupper($validated['item_type'] ?? '');
$deletedCount = $this->service->batchDestroy($validated['ids'], $itemType);
return ['deleted_count' => $deletedCount];
}, __('message.item.batch_deleted'));
}
}