- feat: [barobill] 바로빌 카드/은행/홈택스 REST API 구현 - feat: [equipment] 설비관리 API 백엔드 구현 - feat: [payroll] 급여관리 계산 엔진 및 일괄 처리 API - feat: [QMS] 점검표 템플릿 관리 + 로트심사 개선 - feat: [생산/출하] 수주 단위 출하 자동생성 + 상태 흐름 개선 - feat: [receiving] 입고 성적서 파일 연결 - feat: [견적] 제어기 타입 체계 변경 - feat: [email] 테넌트 메일 설정 마이그레이션 및 모델 - feat: [pmis] 시공관리 테이블 마이그레이션 - feat: [R2] 파일 업로드 커맨드 + filesystems 설정 - feat: [배포] Jenkinsfile 롤백 기능 추가 - fix: [approval] SAM API 규칙 준수 코드 개선 - fix: [account-codes] 계정과목 중복 데이터 정리 - fix: [payroll] 일괄 생성 시 삭제된 사용자 건너뛰기 - fix: [db] codebridge DB 분리 후 깨진 FK 제약조건 제거 - refactor: [barobill] 바로빌 연동 코드 전면 개선
93 lines
2.7 KiB
PHP
93 lines
2.7 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\V1;
|
|
|
|
use App\Helpers\ApiResponse;
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\Quality\SaveChecklistTemplateRequest;
|
|
use App\Services\ChecklistTemplateService;
|
|
use Illuminate\Http\Request;
|
|
|
|
class ChecklistTemplateController extends Controller
|
|
{
|
|
public function __construct(private ChecklistTemplateService $service) {}
|
|
|
|
/**
|
|
* 템플릿 조회 (type별)
|
|
*/
|
|
public function show(Request $request)
|
|
{
|
|
return ApiResponse::handle(function () use ($request) {
|
|
$type = $request->query('type', 'day1_audit');
|
|
|
|
return $this->service->getByType($type);
|
|
}, __('message.fetched'));
|
|
}
|
|
|
|
/**
|
|
* 템플릿 저장 (전체 덮어쓰기)
|
|
*/
|
|
public function update(SaveChecklistTemplateRequest $request, int $id)
|
|
{
|
|
return ApiResponse::handle(function () use ($request, $id) {
|
|
return $this->service->save($id, $request->validated());
|
|
}, __('message.updated'));
|
|
}
|
|
|
|
/**
|
|
* 항목 완료 토글
|
|
*/
|
|
public function toggleItem(int $id, string $subItemId)
|
|
{
|
|
return ApiResponse::handle(function () use ($id, $subItemId) {
|
|
return $this->service->toggleItem($id, $subItemId);
|
|
}, __('message.updated'));
|
|
}
|
|
|
|
/**
|
|
* 항목별 파일 목록 조회
|
|
*/
|
|
public function documents(Request $request)
|
|
{
|
|
return ApiResponse::handle(function () use ($request) {
|
|
$templateId = (int) $request->query('template_id');
|
|
$subItemId = $request->query('sub_item_id');
|
|
|
|
return $this->service->getDocuments($templateId, $subItemId);
|
|
}, __('message.fetched'));
|
|
}
|
|
|
|
/**
|
|
* 파일 업로드
|
|
*/
|
|
public function uploadDocument(Request $request)
|
|
{
|
|
$request->validate([
|
|
'template_id' => ['required', 'integer'],
|
|
'sub_item_id' => ['required', 'string', 'max:50'],
|
|
'file' => ['required', 'file', 'max:10240'], // 10MB
|
|
]);
|
|
|
|
return ApiResponse::handle(function () use ($request) {
|
|
return $this->service->uploadDocument(
|
|
(int) $request->input('template_id'),
|
|
$request->input('sub_item_id'),
|
|
$request->file('file')
|
|
);
|
|
}, __('message.created'));
|
|
}
|
|
|
|
/**
|
|
* 파일 삭제
|
|
*/
|
|
public function deleteDocument(int $id, Request $request)
|
|
{
|
|
return ApiResponse::handle(function () use ($id, $request) {
|
|
$replace = filter_var($request->query('replace', false), FILTER_VALIDATE_BOOLEAN);
|
|
$this->service->deleteDocument($id, $replace);
|
|
|
|
return 'success';
|
|
}, __('message.deleted'));
|
|
}
|
|
}
|