tangoman / relationship-bundle
Symfony Relationship Bundle
Installs: 74
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=5.3.0
This package is auto-updated.
Last update: 2025-03-27 05:09:37 UTC
README
TangoMan Relationship Bundle provides magic methods for OneToOne, OneToMany, ManyToOne, ManyToMany, relationships.
Installation
Step 1: Download the Bundle
Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:
$ composer require tangoman/relationship-bundle
This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.
Step 2: Enable the Bundle
Then, enable the bundle by adding it to the list of registered bundles
in the app/AppKernel.php
file of your project:
<?php // app/AppKernel.php // ... class AppKernel extends Kernel { // ... public function registerBundles() { $bundles = array( // ... new TangoMan\FrontBundle\TangoManRelationshipBundle(), ); // ... } }
Step 3: Update your entities
Use TangoMan\RelationshipBundle\Traits\HasRelationships
trait inside your entities,
and define properties with appropriate doctrine annotations.
Step 4: Update your database schema
Open a command console, enter your project directory and execute the following command to update your database schema:
$ php bin/console schema:update
Usage
Entities
- Both entities must use
HasRelationships
trait. - Both entities must define properties with appropriate doctrine annotations.
cascade={"persist"}
annotation is MANDATORY (will allow bidirectional linking between entities).@method
annotation will allow for correct autocomplete in your IDE (optional).- NOTE:
inversedBy
is always on the owning side of the relationship (but I believe you know that already.)
OneToOne relationships
cascade={"remove"}
will avoid orphanItem
onOwner
deletion (optional).
<?php // src\AppBundle\Entity\Owner.php namespace AppBundle\Entity; use Doctrine\ORM\Mapping as ORM; use TangoMan\RelationshipBundle\Traits\HasRelationships; /** * Class Owner * @ORM\Table(name="owner") * @ORM\Entity(repositoryClass="AppBundle\Repository\OwnerRepository") * * @package AppBundle\Entity * * @method $this setItem(Item $item) * @method Item getItems() */ class Owner { use HasRelationships; // ... /** * @var Item * @ORM\OneToOne(targetEntity="AppBundle\Entity\Item", inversedBy="owner", cascade={"persist", "remove"}) */ private $item; // ...
<?php // src\AppBundle\Entity\Item.php namespace AppBundle\Entity; use Doctrine\ORM\Mapping as ORM; use TangoMan\RelationshipBundle\Traits\HasRelationships; /** * Class Item * @ORM\Table(name="item") * @ORM\Entity(repositoryClass="AppBundle\Repository\ItemRepository") * * @package AppBundle\Entity * * @method $this setOwner(Owner $owner) * @method Owner getOwner() */ class Item { use HasRelationships; // ... /** * @var Owner * @ORM\OneToOne(targetEntity="AppBundle\Entity\Owner", mappedBy="item", cascade={"persist"}) */ private $owner; // ...
ManyToMany relationships
Entity properties
- Property must own
@var ArrayCollection
- Property name MUST use plural form (as it represents several entities)
@ORM\OrderBy({"name"="ASC"})
will allow to define custom orderBy when fetchingitems
(optional).
<?php // src\AppBundle\Entity\Owner.php namespace AppBundle\Entity; use Doctrine\Common\Collections\ArrayCollection; use Doctrine\ORM\Mapping as ORM; use TangoMan\RelationshipBundle\Traits\HasRelationships; /** * Class Owner * @ORM\Table(name="owner") * @ORM\Entity(repositoryClass="AppBundle\Repository\OwnerRepository") * * @package AppBundle\Entity * * @method $this setItems(Item[] $items) * @method Item getItems() */ class Owner { use HasRelationships; // ... /** * @var ArrayCollection|Item[] * @ORM\ManyToMany(targetEntity="AppBundle\Entity\Item", inversedBy="owners", cascade={"persist", "remove"}) * @ORM\OrderBy({"name"="ASC"}) */ private $items; // ...
<?php // src\AppBundle\Entity\Item.php namespace AppBundle\Entity; use Doctrine\Common\Collections\ArrayCollection; use Doctrine\ORM\Mapping as ORM; use TangoMan\RelationshipBundle\Traits\HasRelationships; /** * Class Item * @ORM\Table(name="item") * @ORM\Entity(repositoryClass="AppBundle\Repository\ItemRepository") * * @package AppBundle\Entity * * @method $this setOwners(Owner[] $owners) * @method Owner getOwners() */ class Item { use HasRelationships; // ... /** * @var ArrayCollection|Owner[] * @ORM\ManyToMany(targetEntity="AppBundle\Entity\Owner", mappedBy="items", cascade={"persist"}) * @ORM\OrderBy({"name"="ASC"}) */ private $owners; // ...
Entity constructor
Constructors MUST initialize properties with ArrayCollection
<?php // src\AppBundle\Entity\Owner.php namespace AppBundle\Entity; use Doctrine\Common\Collections\ArrayCollection; use Doctrine\ORM\Mapping as ORM; use TangoMan\RelationshipBundle\Traits\HasRelationships; // ... /** * Owner constructor. */ public function __construct() { // ... $this->Items = new ArrayCollection(); }
FormTypes
Your formTypes elements from the INVERSE side of relationships MUST own 'by_reference' => false,
attribute
to force use of appropriate setters and getters (i.e. add
and remove
methods).
<?php // src\AppBundle\Form\ItemType.php // ... /** * @param FormBuilderInterface $builder * @param array $options */ public function buildForm(FormBuilderInterface $builder, array $options) { $builder // ... ->add( 'owner', EntityType::class, [ 'label' => 'Owner', 'placeholder' => 'Select owner', 'class' => 'AppBundle:Owner', 'by_reference' => false, 'multiple' => true, 'expanded' => false, 'required' => false, 'query_builder' => function (EntityRepository $em) { return $em->createQueryBuilder('o') ->orderBy('o.name'); }, ] ); }
Note
If you find any bug please report here : Issues
License
Copyright (c) 2018 Matthias Morin
Distributed under the MIT license.
If you like TangoMan Relationship Bundle please star! And follow me on GitHub: TangoMan75 ... And check my other cool projects.