2019-11-06 14:35:07 +01:00
|
|
|
<?php
|
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
namespace App\Entity;
|
|
|
|
|
2021-04-27 10:30:45 +02:00
|
|
|
use App\Traits\TimeStampableTrait;
|
2021-04-27 10:22:16 +02:00
|
|
|
use DateTime;
|
|
|
|
use DateTimeInterface;
|
|
|
|
use Doctrine\Common\Collections\ArrayCollection;
|
|
|
|
use Doctrine\Common\Collections\Collection;
|
|
|
|
use Doctrine\ORM\Mapping as ORM;
|
|
|
|
use JMS\Serializer\Annotation as Serializer;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* one poll choice, could be a text or a date
|
|
|
|
* @ORM\Entity(repositoryClass="App\Repository\ChoiceRepository")
|
|
|
|
* @Serializer\ExclusionPolicy("all")
|
|
|
|
*/
|
|
|
|
class Choice {
|
2021-04-27 10:30:45 +02:00
|
|
|
|
|
|
|
use TimeStampableTrait;
|
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
/**
|
|
|
|
* @ORM\Id()
|
|
|
|
* @ORM\GeneratedValue()
|
|
|
|
* @ORM\Column(type="integer")
|
|
|
|
* @Serializer\Expose()
|
|
|
|
*/
|
|
|
|
public $id;
|
2019-11-06 14:35:07 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
/**
|
|
|
|
* @ORM\Column(type="string", length=255, nullable=true)
|
|
|
|
* @Serializer\Type("string")
|
|
|
|
* @Serializer\Expose()
|
|
|
|
*/
|
|
|
|
public $name;
|
|
|
|
/**
|
|
|
|
* @ORM\Column(type="string", length=1024, nullable=true)
|
|
|
|
* @Serializer\Type("string")
|
|
|
|
* @Serializer\Expose()
|
|
|
|
*/
|
|
|
|
public $url;
|
2019-11-06 14:35:07 +01:00
|
|
|
|
2021-04-27 10:30:45 +02:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
/**
|
|
|
|
* @ORM\OneToMany(targetEntity="App\Entity\Vote", mappedBy="choice", cascade={"persist"})
|
|
|
|
* @Serializer\Type("App\Entity\Vote")
|
|
|
|
*/
|
|
|
|
public $votes;
|
|
|
|
/**
|
|
|
|
* @ORM\ManyToOne(targetEntity="App\Entity\Poll", inversedBy="choices", cascade={"persist"})
|
|
|
|
* @Serializer\Type("App\Entity\Poll")
|
|
|
|
*/
|
|
|
|
private $poll;
|
|
|
|
|
|
|
|
public function __construct( $optionalName = null ) {
|
2021-04-27 12:51:21 +02:00
|
|
|
$this->setCreatedAt( new DateTime() );
|
2021-04-27 10:22:16 +02:00
|
|
|
$this->poll = new ArrayCollection();
|
|
|
|
$this->votes = new ArrayCollection();
|
|
|
|
$this->setDateTime( new DateTime() );
|
|
|
|
if ( $optionalName ) {
|
|
|
|
$this->setName( $optionalName );
|
2020-01-22 10:22:36 +01:00
|
|
|
}
|
2021-04-27 10:22:16 +02:00
|
|
|
}
|
2019-11-06 14:35:07 +01:00
|
|
|
|
2021-04-27 10:30:45 +02:00
|
|
|
public function setDateTime( ?DateTimeInterface $dateTime ): self {
|
|
|
|
$this->dateTime = $dateTime;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
2020-01-21 11:10:18 +01:00
|
|
|
|
2021-04-27 11:26:54 +02:00
|
|
|
public function display( $kind = 'text' ) {
|
|
|
|
$fields = [
|
2021-04-27 10:30:45 +02:00
|
|
|
'id' => $this->getId(),
|
|
|
|
'created_at' => $this->getCreatedAtAsString(),
|
|
|
|
'name' => $this->getName(),
|
|
|
|
'url' => $this->getUrl(),
|
2021-04-27 10:22:16 +02:00
|
|
|
];
|
2021-04-27 11:26:54 +02:00
|
|
|
if ( $kind === 'date' ) {
|
|
|
|
$date = new DateTime( $this->getName() );
|
|
|
|
$fields[ 'name' ] = $date->format( 'c' );
|
|
|
|
}
|
|
|
|
|
|
|
|
return $fields;
|
2021-04-27 10:22:16 +02:00
|
|
|
}
|
2019-11-28 14:16:56 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
public function getId(): ?int {
|
|
|
|
return $this->id;
|
|
|
|
}
|
2019-11-28 14:16:56 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
public function getName(): ?string {
|
|
|
|
return $this->name;
|
|
|
|
}
|
2019-11-28 14:16:56 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
public function setName( ?string $name ): self {
|
|
|
|
$this->name = $name;
|
2019-11-28 14:16:56 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
return $this;
|
|
|
|
}
|
2019-11-28 14:16:56 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
public function getUrl(): ?string {
|
|
|
|
return $this->url;
|
|
|
|
}
|
2019-11-28 11:51:25 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
public function setUrl( ?string $url ): self {
|
|
|
|
$this->url = $url;
|
2019-11-28 14:16:56 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
return $this;
|
|
|
|
}
|
2019-11-28 11:51:25 +01:00
|
|
|
|
2021-04-27 10:30:45 +02:00
|
|
|
public function getDateTime(): ?DateTimeInterface {
|
|
|
|
return $this->dateTime;
|
|
|
|
}
|
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
public function getPoll(): ?Poll {
|
|
|
|
return $this->poll;
|
|
|
|
}
|
2020-01-28 20:43:16 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
public function setPoll( ?Poll $poll ): self {
|
|
|
|
$this->poll = $poll;
|
2019-11-28 14:16:56 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
return $this;
|
|
|
|
}
|
2020-01-22 10:22:36 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
/**
|
|
|
|
* @return Collection|Vote[]
|
|
|
|
*/
|
|
|
|
public function getVotes(): Collection {
|
|
|
|
return $this->votes;
|
|
|
|
}
|
2020-01-22 10:22:36 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
public function addVote( Vote $vote ): self {
|
|
|
|
if ( ! $this->votes->contains( $vote ) ) {
|
|
|
|
$this->votes[] = $vote;
|
|
|
|
$vote->setChoice( $this );
|
2020-01-28 20:43:16 +01:00
|
|
|
}
|
2020-01-22 10:22:36 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
return $this;
|
|
|
|
}
|
2020-01-28 20:43:16 +01:00
|
|
|
|
2021-04-27 10:22:16 +02:00
|
|
|
public function removeVote( Vote $vote ): self {
|
|
|
|
if ( $this->votes->contains( $vote ) ) {
|
|
|
|
$this->votes->removeElement( $vote );
|
|
|
|
// set the owning side to null (unless already changed)
|
|
|
|
if ( $vote->getChoice() === $this ) {
|
|
|
|
$vote->setChoice( null );
|
|
|
|
}
|
2020-01-28 20:43:16 +01:00
|
|
|
}
|
2021-04-27 10:22:16 +02:00
|
|
|
|
|
|
|
return $this;
|
2020-01-22 10:22:36 +01:00
|
|
|
}
|
2021-04-27 10:22:16 +02:00
|
|
|
}
|