<?php
/*
* This file is part of Sulu.
*
* (c) Sulu GmbH
*
* This source file is subject to the MIT license that is bundled
* with this source code in the file LICENSE.
*/
namespace Sulu\Bundle\ContactBundle\Entity;
use JMS\Serializer\Annotation\Exclude;
use JMS\Serializer\Annotation\Groups;
/**
* PhoneType.
*/
class PhoneType implements \JsonSerializable
{
/**
* @var string
* @Groups({"fullAccount", "fullContact", "frontend"})
*/
private $name;
/**
* @var int
* @Groups({"fullAccount", "fullContact", "frontend"})
*/
private $id;
/**
* @var \Doctrine\Common\Collections\Collection
* @Exclude
*/
private $phones;
/**
* Constructor.
*/
public function __construct()
{
$this->phones = new \Doctrine\Common\Collections\ArrayCollection();
}
/**
* To force id = 1 in load fixtures.
*
* @param int $id
*/
public function setId($id)
{
$this->id = $id;
}
/**
* Set name.
*
* @param string $name
*
* @return PhoneType
*/
public function setName($name)
{
$this->name = $name;
return $this;
}
/**
* Get name.
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* Get id.
*
* @return int
*/
public function getId()
{
return $this->id;
}
/**
* Add phones.
*
* @return PhoneType
*/
public function addPhone(Phone $phones)
{
$this->phones[] = $phones;
return $this;
}
/**
* Remove phones.
*/
public function removePhone(Phone $phones)
{
$this->phones->removeElement($phones);
}
/**
* Get phones.
*
* @return \Doctrine\Common\Collections\Collection
*/
public function getPhones()
{
return $this->phones;
}
/**
* (PHP 5 >= 5.4.0)<br/>
* Specify data which should be serialized to JSON.
*
* @see http://php.net/manual/en/jsonserializable.jsonserialize.php
*
* @return mixed data which can be serialized by <b>json_encode</b>,
* which is a value of any type other than a resource
*/
#[\ReturnTypeWillChange]
public function jsonSerialize()
{
return [
'id' => $this->getId(),
'name' => $this->getName(),
];
}
}