<?php
namespace App\Entity;
use ApiPlatform\Core\Annotation\ApiFilter;
use ApiPlatform\Core\Annotation\ApiResource;
use ApiPlatform\Core\Bridge\Doctrine\Orm\Filter\DateFilter;
use ApiPlatform\Core\Bridge\Doctrine\Orm\Filter\SearchFilter;
use App\Controller\ControllerAnnulerReservation;
use App\Controller\ControllerDeleteReservationAbonnement;
use App\Dto\AbonnementInput;
use App\Dto\ReservationAbonnementInputUpdate;
use App\Dto\ReservationInput;
use App\Dto\ReservationInputUpdate;
use App\Repository\ReservationRepository;
use DateTimeImmutable;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\Common\Collections\Collection;
use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Serializer\Annotation\Groups;
use Symfony\Component\Validator\Constraints as Assert;
#[ORM\Entity(repositoryClass: ReservationRepository::class)]
#[ApiResource(
attributes:["fetchEager"=> false],
denormalizationContext:[
'groups'=>['reservation:write']
],
normalizationContext:[
'groups'=>['reservation:read']
],
order: ["id" => "DESC"],
collectionOperations: [
"get",
"post" => [
"method" => "POST",
"input" => ReservationInput::class,
],
"abonnement" => [
'path' => '/reservations/abonnement',
"method" => "POST",
"input" => AbonnementInput::class,
]
],
itemOperations:[
'get',
'annuler'=>[
'method' => "GET",
'path' => "/reservations/annuler/{reference}",
'controller' => ControllerAnnulerReservation::class,
'read' => false,
'status' => 204,
'deserialize' => false,
],
'delete_abnn' => [
'method' => "DELETE",
'path' => "/reservations/abonnement/{reference}",
'controller' => ControllerDeleteReservationAbonnement::class,
'read' => false,
'status' => 204,
'deserialize' => false,
],
'put_reservation_ponctuel'=>[
"method" => "PUT",
'path' => '/reservations/ponctuel/{id}',
"input"=>ReservationInputUpdate::class
],
'put_reservation_abonnement'=>[
"method" => "PUT",
'path' => '/reservations/abonnement/{id}',
"input"=>ReservationAbonnementInputUpdate::class
],
'put'
]
)]
#[ApiFilter(SearchFilter::class, properties: ['statut' => 'partial','customer' => 'exact',
'typeReservation'=>'exact','reference'=>'exact','pitchDisponibilities.houre'=>'exact','pitch'=>'exact'])]
#[ApiFilter(DateFilter::class, properties: ['date'])]
class Reservation
{
public const STATUT_NOUVEL = 'En cour';
public const STATUT_TERMINER = 'Terminer';
public const STATUT_ANNULER = 'Annuler';
#[ORM\Id]
#[ORM\GeneratedValue]
#[ORM\Column(type: 'integer')]
#[Groups(['reservation:write','reservation:read','payement:read','user:read'])]
private $id;
#[ORM\Column(type: 'datetime')]
#[Assert\NotBlank]
#[Assert\NotNull]
#[Groups(['reservation:write','reservation:read','payement:read','user:read'])]
private $date;
#[ORM\ManyToOne(targetEntity: Pitch::class, inversedBy: 'reservations')]
#[ORM\JoinColumn(nullable: false)]
#[Assert\NotBlank]
#[Assert\NotNull]
#[Groups(['reservation:write','reservation:read'])]
private $pitch;
#[ORM\Column(type: 'string', length: 10)]
private $statut;
#[ORM\Column(type: 'string', length: 10, nullable: true)]
#[Groups(['reservation:read'])]
private $reference;
#[ORM\Column(type: 'datetime')]
#[Groups(['reservation:read'])]
private $dateCreate;
#[ORM\ManyToOne(targetEntity: User::class, inversedBy: 'reservations')]
#[ORM\JoinColumn(nullable: true, onDelete: 'SET NULL')]
#[Groups(['reservation:write','reservation:read','payement:read'])]
private $customer;
#[ORM\OneToMany(mappedBy: 'reservation', targetEntity: Payment::class, cascade:['persist','remove'])]
#[Groups(['reservation:write','reservation:read'])]
private $payements;
#[ORM\Column(type: 'boolean', nullable: true)]
#[Groups(['reservation:read'])]
private $isSold = false;
#[Groups(['reservation:read'])]
public $urlPayement = null;
#[ORM\Column(type: 'string', length: 100, nullable: true)]
private $canal = 'place';
#[ORM\OneToMany(mappedBy: 'reservation', targetEntity: PitchDisponibility::class, cascade:["persist","remove"])]
#[Groups(['reservation:read'])]
private $pitchDisponibilities;
#[ORM\ManyToOne(targetEntity: Formule::class, inversedBy: 'reservations')]
#[Groups(['reservation:write','reservation:read'])]
private $formule;
#[ORM\Column(type: 'boolean', nullable: true)]
#[Groups(['reservation:read'])]
private $isPrincipale;
#[ORM\ManyToOne(targetEntity: Price::class, inversedBy: 'reservations')]
#[Groups(['reservation:write','reservation:read'])]
private $price;
#[ORM\Column(type: 'integer', nullable: true)]
#[Groups(['reservation:write','reservation:read'])]
private $quantityTime;
#[ORM\Column(type: 'boolean', nullable: true)]
#[Groups(['reservation:write','reservation:read'])]
private $isIndisponible = false;
public function __construct()
{
$this->dateCreate = new DateTimeImmutable();
$this->statut = Reservation::STATUT_NOUVEL;
$this->payements = new ArrayCollection();
$this->pitchDisponibilities = new ArrayCollection();
$this->isPrincipale = true;
$this->quantityTime = 1;
}
public function getId(): ?int
{
return $this->id;
}
public function getDate(): ?\DateTimeInterface
{
return $this->date;
}
public function setDate(\DateTimeInterface $date): self
{
$this->date = $date;
return $this;
}
public function getPitch(): ?Pitch
{
return $this->pitch;
}
public function setPitch(?Pitch $pitch): self
{
$this->pitch = $pitch;
return $this;
}
public function getStatut(): ?string
{
return $this->statut;
}
public function setStatut(string $statut): self
{
$this->statut = $statut;
return $this;
}
public function getReference(): ?string
{
return $this->reference;
}
public function setReference(?string $reference): self
{
$this->reference = $reference;
return $this;
}
public function getDateCreate(): ?\DateTimeInterface
{
return $this->dateCreate;
}
public function setDateCreate(\DateTimeInterface $dateCreate): self
{
$this->dateCreate = $dateCreate;
return $this;
}
public function getCustomer(): ?User
{
return $this->customer;
}
public function setCustomer(?User $customer): self
{
$this->customer = $customer;
return $this;
}
/**
* @return Collection<int, Payment>
*/
public function getPayements(): Collection
{
return $this->payements;
}
public function addPayement(Payment $payement): self
{
if (!$this->payements->contains($payement)) {
$this->payements[] = $payement;
$payement->setReservation($this);
}
return $this;
}
public function removePayement(Payment $payement): self
{
if ($this->payements->removeElement($payement)) {
// set the owning side to null (unless already changed)
if ($payement->getReservation() === $this) {
$payement->setReservation(null);
}
}
return $this;
}
public function isIsSold(): ?bool
{
return $this->isSold;
}
public function setIsSold(?bool $isSold): self
{
$this->isSold = $isSold;
return $this;
}
public function getCanal(): ?string
{
return $this->canal;
}
public function setCanal(?string $canal): self
{
$this->canal = $canal;
return $this;
}
/**
* @return Collection<int, PitchDisponibility>
*/
public function getPitchDisponibilities(): Collection
{
return $this->pitchDisponibilities;
}
public function addPitchDisponibility(PitchDisponibility $pitchDisponibility): self
{
if (!$this->pitchDisponibilities->contains($pitchDisponibility)) {
$this->pitchDisponibilities[] = $pitchDisponibility;
$pitchDisponibility->setReservation($this);
}
return $this;
}
public function removePitchDisponibility(PitchDisponibility $pitchDisponibility): self
{
if ($this->pitchDisponibilities->removeElement($pitchDisponibility)) {
// set the owning side to null (unless already changed)
if ($pitchDisponibility->getReservation() === $this) {
$pitchDisponibility->setReservation(null);
}
}
return $this;
}
public function getFormule(): ?Formule
{
return $this->formule;
}
public function setFormule(?Formule $formule): self
{
$this->formule = $formule;
return $this;
}
public function isIsPrincipale(): ?bool
{
return $this->isPrincipale;
}
public function setIsPrincipale(?bool $isPrincipale): self
{
$this->isPrincipale = $isPrincipale;
return $this;
}
public function getPrice(): ?Price
{
return $this->price;
}
public function setPrice(?Price $price): self
{
$this->price = $price;
return $this;
}
public function getQuantityTime(): ?int
{
return $this->quantityTime;
}
public function setQuantityTime(?int $quantityTime): self
{
$this->quantityTime = $quantityTime;
return $this;
}
public function isIsIndisponible(): ?bool
{
return $this->isIndisponible;
}
public function setIsIndisponible(?bool $isIndisponible): self
{
$this->isIndisponible = $isIndisponible;
return $this;
}
}