* wip * wip * wip * wip * fix * wip * wip * fix * fix * cs fix * #116 - fix * #116 - changed home-office icon * Apply suggestions from code review Co-authored-by: Krzysztof Rewak <krzysztof.rewak@gmail.com> * #116 - cr fix * #116 - cs fix * #116 - cs fix * Apply suggestions from code review Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com> * #5 - bump codestyle Co-authored-by: EwelinaLasowy <ewelina.lasowy@blumilk.pl> Co-authored-by: Krzysztof Rewak <krzysztof.rewak@gmail.com> Co-authored-by: Ewelina Lasowy <56546832+EwelinaLasowy@users.noreply.github.com>
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| declare(strict_types=1);
 | |
| 
 | |
| namespace Toby\Infrastructure\Http\Controllers;
 | |
| 
 | |
| use Illuminate\Support\Carbon;
 | |
| use Maatwebsite\Excel\Facades\Excel;
 | |
| use Symfony\Component\HttpFoundation\BinaryFileResponse;
 | |
| use Toby\Domain\Enums\EmploymentForm;
 | |
| use Toby\Domain\Enums\Month;
 | |
| use Toby\Domain\Enums\VacationType;
 | |
| use Toby\Domain\TimesheetExport;
 | |
| use Toby\Domain\VacationTypeConfigRetriever;
 | |
| use Toby\Eloquent\Helpers\YearPeriodRetriever;
 | |
| use Toby\Eloquent\Models\User;
 | |
| 
 | |
| class TimesheetController extends Controller
 | |
| {
 | |
|     public function __invoke(
 | |
|         Month $month,
 | |
|         YearPeriodRetriever $yearPeriodRetriever,
 | |
|         VacationTypeConfigRetriever $configRetriever,
 | |
|     ): BinaryFileResponse {
 | |
|         $this->authorize("generateTimesheet");
 | |
| 
 | |
|         $yearPeriod = $yearPeriodRetriever->selected();
 | |
|         $carbonMonth = Carbon::create($yearPeriod->year, $month->toCarbonNumber());
 | |
| 
 | |
|         $users = User::query()
 | |
|             ->whereRelation("profile", "employment_form", EmploymentForm::EmploymentContract)
 | |
|             ->orderByProfileField("last_name")
 | |
|             ->orderByProfileField("first_name")
 | |
|             ->get();
 | |
| 
 | |
|         $types = VacationType::all()
 | |
|             ->filter(
 | |
|                 fn(VacationType $type): bool => $configRetriever->isAvailableFor(
 | |
|                     $type,
 | |
|                     EmploymentForm::EmploymentContract,
 | |
|                 ) && $configRetriever->isVacation($type),
 | |
|             );
 | |
| 
 | |
|         $filename = "{$carbonMonth->translatedFormat("F Y")}.xlsx";
 | |
| 
 | |
|         $timesheet = (new TimesheetExport())
 | |
|             ->forMonth($carbonMonth)
 | |
|             ->forUsers($users)
 | |
|             ->forVacationTypes($types);
 | |
| 
 | |
|         return Excel::download($timesheet, $filename);
 | |
|     }
 | |
| }
 |