L'administration a besoin de construire et maintenir les emplois du temps hebdomadaires pour chaque classe, en s'assurant que les enseignants ne sont pas en conflit (même créneau, classes différentes) et que les affectations enseignant-matière-classe sont respectées. Cette implémentation couvre le CRUD complet des créneaux (ScheduleSlot), la détection de conflits (classe, enseignant, salle) avec possibilité de forcer, la validation des affectations côté serveur (AC2), l'intégration calendrier pour les jours bloqués, une vue mobile-first avec onglets jour par jour, et le drag-and-drop pour réorganiser les créneaux sur desktop.
42 lines
1.0 KiB
PHP
42 lines
1.0 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Scolarite\Infrastructure\Api\Resource;
|
|
|
|
use ApiPlatform\Metadata\ApiProperty;
|
|
use ApiPlatform\Metadata\ApiResource;
|
|
use ApiPlatform\Metadata\GetCollection;
|
|
use App\Scolarite\Application\Query\GetBlockedDates\BlockedDateDto;
|
|
use App\Scolarite\Infrastructure\Api\Provider\BlockedDateCollectionProvider;
|
|
|
|
#[ApiResource(
|
|
shortName: 'BlockedDate',
|
|
operations: [
|
|
new GetCollection(
|
|
uriTemplate: '/schedule/blocked-dates',
|
|
provider: BlockedDateCollectionProvider::class,
|
|
name: 'get_blocked_dates',
|
|
),
|
|
],
|
|
)]
|
|
final class BlockedDateResource
|
|
{
|
|
#[ApiProperty(identifier: true)]
|
|
public ?string $date = null;
|
|
|
|
public ?string $reason = null;
|
|
|
|
public ?string $type = null;
|
|
|
|
public static function fromDto(BlockedDateDto $dto): self
|
|
{
|
|
$resource = new self();
|
|
$resource->date = $dto->date;
|
|
$resource->reason = $dto->reason;
|
|
$resource->type = $dto->type;
|
|
|
|
return $resource;
|
|
}
|
|
}
|