feat: ItemService 동적 테이블 라우팅 구현
- item_type → ItemPage.source_table → Model 클래스 동적 라우팅 - getModelInfoByItemType(): item_type으로 Model 정보 조회 (캐싱) - newQuery(): 동적 Query Builder 생성 - 모든 CRUD 메서드 item_type 필수 파라미터로 변경 - ItemsController item_type 전달 로직 수정 - 에러 메시지 추가 (item_type_required, invalid_source_table) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -7,57 +7,73 @@
|
||||
use App\Http\Requests\Item\ItemBatchDeleteRequest;
|
||||
use App\Http\Requests\Item\ItemStoreRequest;
|
||||
use App\Http\Requests\Item\ItemUpdateRequest;
|
||||
use App\Services\ItemsService;
|
||||
use App\Services\ItemService;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class ItemsController extends Controller
|
||||
{
|
||||
public function __construct(private ItemsService $service) {}
|
||||
public function __construct(private ItemService $service) {}
|
||||
|
||||
/**
|
||||
* 통합 품목 목록 조회 (materials + products)
|
||||
* 통합 품목 목록 조회 (items 테이블)
|
||||
*
|
||||
* GET /api/v1/items
|
||||
*/
|
||||
public function index(Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
$filters = $request->only(['type', 'search', 'q', 'category_id', 'is_active']);
|
||||
$perPage = (int) ($request->input('size') ?? 20);
|
||||
$includeDeleted = filter_var($request->input('include_deleted', false), FILTER_VALIDATE_BOOLEAN);
|
||||
$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'),
|
||||
'active' => $request->input('is_active') ?? $request->input('active'),
|
||||
];
|
||||
|
||||
return $this->service->getItems($filters, $perPage, $includeDeleted);
|
||||
return $this->service->index($params);
|
||||
}, __('message.fetched'));
|
||||
}
|
||||
|
||||
/**
|
||||
* 단일 품목 조회
|
||||
* 단일 품목 조회 (동적 테이블 라우팅)
|
||||
*
|
||||
* GET /api/v1/items/{id}?item_type=FG|PT|SM|RM|CS&include_price=true&client_id=1&price_date=2025-01-10
|
||||
* GET /api/v1/items/{id}?item_type=FG&include_price=true&client_id=1&price_date=2025-01-10
|
||||
*
|
||||
* @param string item_type 품목 유형 (필수 - 동적 테이블 라우팅)
|
||||
*/
|
||||
public function show(Request $request, int $id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request, $id) {
|
||||
$itemType = strtoupper($request->input('item_type', 'FG'));
|
||||
// item_type 필수 (동적 테이블 라우팅에 사용)
|
||||
$itemType = strtoupper($request->input('item_type', ''));
|
||||
$includePrice = filter_var($request->input('include_price', false), FILTER_VALIDATE_BOOLEAN);
|
||||
$clientId = $request->input('client_id') ? (int) $request->input('client_id') : null;
|
||||
$priceDate = $request->input('price_date');
|
||||
|
||||
return $this->service->getItem($id, $itemType, $includePrice, $clientId, $priceDate);
|
||||
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 포함 옵션)
|
||||
* 품목 상세 조회 (동적 테이블 라우팅, code 기반, BOM 포함 옵션)
|
||||
*
|
||||
* GET /api/v1/items/code/{code}?include_bom=true
|
||||
* 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->getItemByCode($code, $includeBom);
|
||||
return $this->service->showByCode($code, $itemType, $includeBom);
|
||||
}, __('message.item.fetched'));
|
||||
}
|
||||
|
||||
@@ -69,7 +85,7 @@ public function showByCode(Request $request, string $code)
|
||||
public function store(ItemStoreRequest $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
return $this->service->createItem($request->all());
|
||||
return $this->service->store($request->all());
|
||||
}, __('message.item.created'));
|
||||
}
|
||||
|
||||
@@ -81,38 +97,44 @@ public function store(ItemStoreRequest $request)
|
||||
public function update(int $id, ItemUpdateRequest $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return $this->service->updateItem($id, $request->all());
|
||||
return $this->service->update($id, $request->all());
|
||||
}, __('message.item.updated'));
|
||||
}
|
||||
|
||||
/**
|
||||
* 품목 삭제 (Soft Delete)
|
||||
* 품목 삭제 (동적 테이블 라우팅, Soft Delete)
|
||||
*
|
||||
* DELETE /api/v1/items/{id}?item_type=FG|PT|SM|RM|CS
|
||||
* 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) {
|
||||
$itemType = strtoupper($request->input('item_type', 'FG'));
|
||||
$this->service->deleteItem($id, $itemType);
|
||||
// item_type 필수 (동적 테이블 라우팅에 사용)
|
||||
$itemType = strtoupper($request->input('item_type', ''));
|
||||
$this->service->destroy($id, $itemType);
|
||||
|
||||
return 'success';
|
||||
}, __('message.item.deleted'));
|
||||
}
|
||||
|
||||
/**
|
||||
* 품목 일괄 삭제 (Soft Delete)
|
||||
* 품목 일괄 삭제 (동적 테이블 라우팅, Soft Delete)
|
||||
*
|
||||
* DELETE /api/v1/items/batch
|
||||
* 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();
|
||||
$itemType = strtoupper($validated['item_type'] ?? 'FG');
|
||||
$this->service->batchDeleteItems($validated['ids'], $itemType);
|
||||
// item_type 필수 (동적 테이블 라우팅에 사용)
|
||||
$itemType = strtoupper($validated['item_type'] ?? '');
|
||||
$deletedCount = $this->service->batchDestroy($validated['ids'], $itemType);
|
||||
|
||||
return 'success';
|
||||
return ['deleted_count' => $deletedCount];
|
||||
}, __('message.item.batch_deleted'));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user