* * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ namespace Chill\ActivityBundle\Entity; use Doctrine\ORM\Mapping as ORM; use Chill\ActivityBundle\Entity\ActivityReasonCategory; /** * Class ActivityReason * * @package Chill\ActivityBundle\Entity * @ORM\Entity() * @ORM\Table(name="activityreason") * @ORM\HasLifecycleCallbacks() */ class ActivityReason { /** * @var integer * * @ORM\Id * @ORM\Column(name="id", type="integer") * @ORM\GeneratedValue(strategy="AUTO") */ private $id; /** * @var array * @ORM\Column(type="json_array") */ private $name; /** * @var ActivityReasonCategory * @ORM\ManyToOne( * targetEntity="Chill\ActivityBundle\Entity\ActivityReasonCategory", * inversedBy="reasons") */ private $category; /** * @var boolean * @ORM\Column(type="boolean") */ private $active = true; /** * Get id * * @return integer */ public function getId() { return $this->id; } /** * Set name * * @param array $name * @return ActivityReason */ public function setName($name) { $this->name = $name; return $this; } /** * Get name * * @return array | string */ public function getName($locale = null) { if ($locale) { if (isset($this->name[$locale])) { return $this->name[$locale]; } else { foreach ($this->name as $name) { if (!empty($name)) { return $name; } } } return ''; } else { return $this->name; } } /** * Set category of the reason. If you set to the reason an inactive * category, the reason will become inactive * * @param ActivityReasonCategory $category * @return ActivityReason */ public function setCategory(ActivityReasonCategory $category) { if($this->category !== $category && ! $category->getActive()) { $this->setActive(False); } $this->category = $category; return $this; } /** * Get category * * @return ActivityReasonCategory */ public function getCategory() { return $this->category; } /** * Set active * * @param boolean $active * @return ActivityReason */ public function setActive($active) { $this->active = $active; return $this; } /** * Get active * * @return boolean */ public function getActive() { return $this->active; } }