mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
322 lines
8.0 KiB
PHP
322 lines
8.0 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Chill is a software for social workers
|
|
*
|
|
* For the full copyright and license information, please view
|
|
* the LICENSE file that was distributed with this source code.
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Chill\PersonBundle\Entity\SocialWork;
|
|
|
|
use DateTimeInterface;
|
|
use Doctrine\Common\Collections\ArrayCollection;
|
|
use Doctrine\Common\Collections\Collection;
|
|
use Doctrine\ORM\Mapping as ORM;
|
|
use Symfony\Component\Serializer\Annotation\DiscriminatorMap;
|
|
use Symfony\Component\Serializer\Annotation\Groups;
|
|
|
|
/**
|
|
* @ORM\Entity
|
|
* @ORM\Table(name="chill_person_social_issue")
|
|
* @DiscriminatorMap(typeProperty="type", mapping={
|
|
* "social_issue": SocialIssue::class
|
|
* })
|
|
*/
|
|
class SocialIssue
|
|
{
|
|
/**
|
|
* @ORM\OneToMany(targetEntity=SocialIssue::class, mappedBy="parent")
|
|
*/
|
|
private $children;
|
|
|
|
/**
|
|
* @ORM\Column(type="datetime", nullable=true)
|
|
*/
|
|
private $desactivationDate;
|
|
|
|
/**
|
|
* @ORM\Id
|
|
* @ORM\GeneratedValue
|
|
* @ORM\Column(type="integer")
|
|
*/
|
|
private $id;
|
|
|
|
/**
|
|
* @ORM\ManyToOne(targetEntity=SocialIssue::class, inversedBy="children")
|
|
*/
|
|
private $parent;
|
|
|
|
/**
|
|
* @ORM\OneToMany(targetEntity=SocialAction::class, mappedBy="issue")
|
|
*/
|
|
private $socialActions;
|
|
|
|
/**
|
|
* @ORM\Column(type="json")
|
|
* @Groups({"read"})
|
|
*/
|
|
private $title = [];
|
|
|
|
public function __construct()
|
|
{
|
|
$this->children = new ArrayCollection();
|
|
$this->socialActions = new ArrayCollection();
|
|
}
|
|
|
|
public function addChild(self $child): self
|
|
{
|
|
if (!$this->children->contains($child)) {
|
|
$this->children[] = $child;
|
|
$child->setParent($this);
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function addSocialAction(SocialAction $socialAction): self
|
|
{
|
|
if (!$this->socialActions->contains($socialAction)) {
|
|
$this->socialActions[] = $socialAction;
|
|
$socialAction->setSocialIssue($this);
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* In a SocialIssues's collection, find the elements which are an ancestor of
|
|
* other elements.
|
|
*
|
|
* Removing those elements of the Collection (which is not done by this method)
|
|
* will ensure that only the most descendent elements are present in the collection,
|
|
* (any ancestor of another element are present).
|
|
*
|
|
* @param Collection|SocialIssue[] $socialIssues
|
|
*
|
|
* @return Collection|SocialIssue[]
|
|
*/
|
|
public static function findAncestorSocialIssues(Collection $socialIssues): Collection
|
|
{
|
|
$ancestors = new ArrayCollection();
|
|
|
|
foreach ($socialIssues as $candidateChild) {
|
|
if ($ancestors->contains($candidateChild)) {
|
|
continue;
|
|
}
|
|
|
|
foreach ($socialIssues as $candidateParent) {
|
|
if ($ancestors->contains($candidateParent)) {
|
|
continue;
|
|
}
|
|
|
|
if ($candidateChild->isDescendantOf($candidateParent)) {
|
|
$ancestors->add($candidateParent);
|
|
}
|
|
}
|
|
}
|
|
|
|
return $ancestors;
|
|
}
|
|
|
|
/**
|
|
* get all the ancestors of the social issue.
|
|
*
|
|
* @param bool $includeThis if the array in the result must include the present SocialIssue
|
|
*/
|
|
public function getAncestors(bool $includeThis = true): array
|
|
{
|
|
$ancestors = [];
|
|
|
|
if ($includeThis) {
|
|
$ancestors[] = $this;
|
|
}
|
|
|
|
$current = $this;
|
|
|
|
while ($current->hasParent()) {
|
|
$ancestors[] = $current = $current->getParent();
|
|
}
|
|
|
|
return $ancestors;
|
|
}
|
|
|
|
/**
|
|
* @return Collection|self[]
|
|
*/
|
|
public function getChildren(): Collection
|
|
{
|
|
return $this->children;
|
|
}
|
|
|
|
public function getDesactivationDate(): ?DateTimeInterface
|
|
{
|
|
return $this->desactivationDate;
|
|
}
|
|
|
|
/**
|
|
* @return Collection|self[] All the descendants (children, children of children, ...)
|
|
*/
|
|
public function getDescendants(): Collection
|
|
{
|
|
$descendants = new ArrayCollection();
|
|
|
|
foreach ($this->getChildren() as $child) {
|
|
if (!$descendants->contains($child)) {
|
|
$descendants->add($child);
|
|
|
|
foreach ($child->getDescendants() as $descendantsOfChild) {
|
|
if (!$descendants->contains($descendantsOfChild)) {
|
|
$descendants->add($descendantsOfChild);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return $descendants;
|
|
}
|
|
|
|
/**
|
|
* @return Collection|SocialAction[] All the descendant social actions of the entity
|
|
*/
|
|
public function getDescendantsSocialActions(): Collection
|
|
{
|
|
$descendantsSocialActions = new ArrayCollection();
|
|
|
|
foreach ($this->getSocialActions() as $socialAction) {
|
|
foreach ($socialAction->getDescendantsWithThis() as $descendant) {
|
|
if (!$descendantsSocialActions->contains($descendant)) {
|
|
$descendantsSocialActions->add($descendant);
|
|
}
|
|
}
|
|
}
|
|
|
|
return $descendantsSocialActions;
|
|
}
|
|
|
|
/**
|
|
* @return Collection|self[] All the descendants with the current entity (this)
|
|
*/
|
|
public function getDescendantsWithThis(): Collection
|
|
{
|
|
$descendants = $this->getDescendants();
|
|
|
|
if (!$descendants->contains($this)) {
|
|
$descendants->add($this);
|
|
}
|
|
|
|
return $descendants;
|
|
}
|
|
|
|
public function getId(): ?int
|
|
{
|
|
return $this->id;
|
|
}
|
|
|
|
public function getParent(): ?self
|
|
{
|
|
return $this->parent;
|
|
}
|
|
|
|
/**
|
|
* @return Collection|SocialAction[] All the descendant social actions of all
|
|
* the descendants of the entity
|
|
*/
|
|
public function getRecursiveSocialActions(): Collection
|
|
{
|
|
$recursiveSocialActions = new ArrayCollection();
|
|
|
|
foreach ($this->getDescendantsWithThis() as $socialIssue) {
|
|
foreach ($socialIssue->getDescendantsSocialActions() as $descendant) {
|
|
if (!$recursiveSocialActions->contains($descendant)) {
|
|
$recursiveSocialActions->add($descendant);
|
|
}
|
|
}
|
|
}
|
|
|
|
return $recursiveSocialActions;
|
|
}
|
|
|
|
/**
|
|
* @return Collection|SocialAction[]
|
|
*/
|
|
public function getSocialActions(): Collection
|
|
{
|
|
return $this->socialActions;
|
|
}
|
|
|
|
public function getTitle(): array
|
|
{
|
|
return $this->title;
|
|
}
|
|
|
|
public function hasParent(): bool
|
|
{
|
|
return null !== $this->parent;
|
|
}
|
|
|
|
/**
|
|
* Recursive method which return true if the current $issue is a descendant
|
|
* of the $issue given in parameter.
|
|
*/
|
|
public function isDescendantOf(SocialIssue $issue): bool
|
|
{
|
|
if (!$this->hasParent()) {
|
|
return false;
|
|
}
|
|
|
|
if ($this->getParent() === $issue) {
|
|
return true;
|
|
}
|
|
|
|
return $this->getParent()->isDescendantOf($issue);
|
|
}
|
|
|
|
public function removeChild(self $child): self
|
|
{
|
|
if ($this->children->removeElement($child)) {
|
|
// set the owning side to null (unless already changed)
|
|
if ($child->getParent() === $this) {
|
|
$child->setParent(null);
|
|
}
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function removeSocialAction(SocialAction $socialAction): self
|
|
{
|
|
if ($this->socialActions->removeElement($socialAction)) {
|
|
// set the owning side to null (unless already changed)
|
|
if ($socialAction->getSocialIssue() === $this) {
|
|
$socialAction->setSocialIssue(null);
|
|
}
|
|
}
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function setDesactivationDate(?DateTimeInterface $desactivationDate): self
|
|
{
|
|
$this->desactivationDate = $desactivationDate;
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function setParent(?self $parent): self
|
|
{
|
|
$this->parent = $parent;
|
|
|
|
return $this;
|
|
}
|
|
|
|
public function setTitle(array $title): self
|
|
{
|
|
$this->title = $title;
|
|
|
|
return $this;
|
|
}
|
|
}
|