X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=src%2FWallabag%2FCoreBundle%2FEntity%2FTag.php;h=4b480ff1cdc4f2c4ebc2b7e4bf4b558edb95eb9a;hb=5ecdfcd041767c9e3244a92bb0a6cc3c3f80fea3;hp=963f32b1ef20df88b334a3c6a658c55ea926d97e;hpb=2691cf04384239c546e141af6cc3c22b210dae58;p=github%2Fwallabag%2Fwallabag.git diff --git a/src/Wallabag/CoreBundle/Entity/Tag.php b/src/Wallabag/CoreBundle/Entity/Tag.php index 963f32b1..4b480ff1 100644 --- a/src/Wallabag/CoreBundle/Entity/Tag.php +++ b/src/Wallabag/CoreBundle/Entity/Tag.php @@ -2,19 +2,27 @@ namespace Wallabag\CoreBundle\Entity; +use Doctrine\Common\Collections\ArrayCollection; use Doctrine\ORM\Mapping as ORM; +use JMS\Serializer\Annotation\ExclusionPolicy; +use JMS\Serializer\Annotation\Expose; +use Gedmo\Mapping\Annotation as Gedmo; +use JMS\Serializer\Annotation\XmlRoot; /** - * Tag + * Tag. * - * @ORM\Table(name="tag") - * @ORM\Entity + * @XmlRoot("tag") + * @ORM\Table(name="`tag`") + * @ORM\Entity(repositoryClass="Wallabag\CoreBundle\Repository\TagRepository") + * @ExclusionPolicy("all") */ class Tag { /** - * @var integer + * @var int * + * @Expose * @ORM\Column(name="id", type="integer") * @ORM\Id * @ORM\GeneratedValue(strategy="AUTO") @@ -24,14 +32,37 @@ class Tag /** * @var string * + * @Expose * @ORM\Column(name="label", type="text") */ private $label; /** - * Get id + * @Expose + * @Gedmo\Slug(fields={"label"}) + * @ORM\Column(length=128, unique=true) + */ + private $slug; + + /** + * @ORM\ManyToMany(targetEntity="Entry", mappedBy="tags", cascade={"persist"}) + */ + private $entries; + + public function __construct() + { + $this->entries = new ArrayCollection(); + } + + public function __toString() + { + return $this->label; + } + + /** + * Get id. * - * @return integer + * @return int */ public function getId() { @@ -39,9 +70,10 @@ class Tag } /** - * Set label + * Set label. + * + * @param string $label * - * @param string $label * @return Tag */ public function setLabel($label) @@ -52,7 +84,7 @@ class Tag } /** - * Get label + * Get label. * * @return string */ @@ -60,4 +92,62 @@ class Tag { return $this->label; } + + public function getSlug() + { + return $this->slug; + } + + /** + * @param Entry $entry + */ + public function addEntry(Entry $entry) + { + if ($this->entries->contains($entry)) { + return; + } + + $this->entries->add($entry); + $entry->addTag($this); + } + + /** + * @param Entry $entry + */ + public function removeEntry(Entry $entry) + { + if (!$this->entries->contains($entry)) { + return; + } + + $this->entries->removeElement($entry); + $entry->removeTag($this); + } + + public function hasEntry($entry) + { + return $this->entries->contains($entry); + } + + /** + * Get entries for this tag. + * + * @return ArrayCollection + */ + public function getEntries() + { + return $this->entries; + } + + public function getEntriesByUserId($userId) + { + $filteredEntries = new ArrayCollection(); + foreach ($this->entries as $entry) { + if ($entry->getUser()->getId() === $userId) { + $filteredEntries->add($entry); + } + } + + return $filteredEntries; + } }