<?php
namespace App\Entity;
use App\Repository\FaqSubjectRepository;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\Common\Collections\Collection;
use Doctrine\ORM\Mapping as ORM;
use JMS\Serializer\Annotation as Serializer;
/**
* @ORM\Entity(repositoryClass=FaqSubjectRepository::class)
* @Serializer\ExclusionPolicy("ALL")
*/
class FaqSubject extends BaseEntity
{
/**
* @ORM\Id
* @ORM\GeneratedValue
* @ORM\Column(type="integer")
* @Serializer\Expose
*/
private $id;
/**
* @ORM\Column(type="string", length=255)
* @Serializer\Expose
*/
private $subject;
/**
* @ORM\ManyToMany(targetEntity=FaqQuestion::class, inversedBy="faqSubjects", cascade={"persist", "remove"})
*/
private $questions;
public function __construct()
{
$this->questions = new ArrayCollection();
}
public function getId(): ?int
{
return $this->id;
}
public function getSubject(): ?string
{
return $this->subject;
}
public function setSubject(string $subject): self
{
$this->subject = $subject;
return $this;
}
/**
* @return Collection<int, FaqQuestion>
*/
public function getQuestions(): Collection
{
return $this->questions;
}
public function addQuestion(FaqQuestion $question): self
{
if (!$this->questions->contains($question)) {
$this->questions[] = $question;
}
return $this;
}
public function removeQuestion(FaqQuestion $question): self
{
$this->questions->removeElement($question);
return $this;
}
}