Files
sam-api/app/Http/Controllers/Api/V1/StockController.php
권혁성 4208ca3010 feat: [HR/기타] 캘린더/배차/설비/재고 + DB 마이그레이션
- 캘린더 CRUD API, 배차차량 관리 API (CRUD + options)
- 배차정보 다중 행 시스템 (shipment_vehicle_dispatches)
- 설비 다중점검주기 + 부 담당자 스키마 추가
- TodayIssue 날짜 기반 조회, Stock/Client 날짜 필터
- i18n 메시지 추가

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-07 02:59:30 +09:00

75 lines
1.7 KiB
PHP

<?php
namespace App\Http\Controllers\Api\V1;
use App\Helpers\ApiResponse;
use App\Http\Controllers\Controller;
use App\Services\StockService;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
class StockController extends Controller
{
public function __construct(
private readonly StockService $service
) {}
/**
* 재고 목록 조회
*/
public function index(Request $request): JsonResponse
{
$params = $request->only([
'search',
'item_type',
'item_category',
'status',
'location',
'sort_by',
'sort_dir',
'per_page',
'page',
'start_date',
'end_date',
]);
$stocks = $this->service->index($params);
return ApiResponse::success($stocks, __('message.fetched'));
}
/**
* 재고 통계 조회
*/
public function stats(): JsonResponse
{
$stats = $this->service->stats();
return ApiResponse::success($stats, __('message.fetched'));
}
/**
* 재고 상세 조회 (LOT 포함)
*/
public function show(int $id): JsonResponse
{
try {
$stock = $this->service->show($id);
return ApiResponse::success($stock, __('message.fetched'));
} catch (\Illuminate\Database\Eloquent\ModelNotFoundException $e) {
return ApiResponse::error(__('error.stock.not_found'), 404);
}
}
/**
* 품목유형별 통계 조회
*/
public function statsByItemType(): JsonResponse
{
$stats = $this->service->statsByItemType();
return ApiResponse::success($stats, __('message.fetched'));
}
}