- PhpSpreadsheet 기반 PerformanceReportExcelService 신규 생성 - 건기원 양식(품질인정자재등의 판매실적 대장) 엑셀 생성 - 카테고리별 배경색, 셀 병합, 회사정보 섹션 포함 - GET /api/v1/quality/performance-reports/export-excel 엔드포인트 추가 - 미확정 4개 필드(인정품목/내화성능시간/사용부위/로트번호) 빈값 처리
68 lines
2.1 KiB
PHP
68 lines
2.1 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\V1;
|
|
|
|
use App\Helpers\ApiResponse;
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\Quality\PerformanceReportConfirmRequest;
|
|
use App\Http\Requests\Quality\PerformanceReportMemoRequest;
|
|
use App\Services\PerformanceReportService;
|
|
use Illuminate\Http\Request;
|
|
|
|
class PerformanceReportController extends Controller
|
|
{
|
|
public function __construct(private PerformanceReportService $service) {}
|
|
|
|
public function index(Request $request)
|
|
{
|
|
return ApiResponse::handle(function () use ($request) {
|
|
return $this->service->index($request->all());
|
|
}, __('message.fetched'));
|
|
}
|
|
|
|
public function stats(Request $request)
|
|
{
|
|
return ApiResponse::handle(function () use ($request) {
|
|
return $this->service->stats($request->all());
|
|
}, __('message.fetched'));
|
|
}
|
|
|
|
public function confirm(PerformanceReportConfirmRequest $request)
|
|
{
|
|
return ApiResponse::handle(function () use ($request) {
|
|
return $this->service->confirm($request->validated()['ids']);
|
|
}, __('message.updated'));
|
|
}
|
|
|
|
public function unconfirm(PerformanceReportConfirmRequest $request)
|
|
{
|
|
return ApiResponse::handle(function () use ($request) {
|
|
return $this->service->unconfirm($request->validated()['ids']);
|
|
}, __('message.updated'));
|
|
}
|
|
|
|
public function updateMemo(PerformanceReportMemoRequest $request)
|
|
{
|
|
return ApiResponse::handle(function () use ($request) {
|
|
$data = $request->validated();
|
|
|
|
return $this->service->updateMemo($data['ids'], $data['memo']);
|
|
}, __('message.updated'));
|
|
}
|
|
|
|
public function missing(Request $request)
|
|
{
|
|
return ApiResponse::handle(function () use ($request) {
|
|
return $this->service->missing($request->all());
|
|
}, __('message.fetched'));
|
|
}
|
|
|
|
public function exportExcel(Request $request)
|
|
{
|
|
$year = (int) $request->input('year', now()->year);
|
|
$quarter = (int) $request->input('quarter', ceil(now()->month / 3));
|
|
|
|
return $this->service->exportConfirmed($year, $quarter);
|
|
}
|
|
}
|