Symfony could only improve plural-to-just one transformation (e.g. about labels possessions into addTag() method) to own English conditions. Code printed in any kind of words would not work as requested.
To keep the https://datingranking.net/cs/our-teen-network-recenze/ brand new labels with Doctrine, you need to envision several a whole lot more something. Basic, if you do not iterate over-all of the this new Mark items and you may call $entityManager->persist($tag) on each, you are getting an error away from Doctrine:
To fix that it, you might “cascade” the fresh persist operation instantly regarding Task target to virtually any relevant labels. To do so, are the cascade option to your own ManyToMany metadata:
- Annotations
- YAML
- XML
Another potential situation deals with the brand new Managing Front and you can Inverse Side of Dple, when your “owning” section of the relationship are “Task”, after that dedication will work fine since labels was properly additional to your Activity. Yet not, should your purchasing front side is on “Tag”, then you’ll definitely should do a bit more work to make sure the best region of the relationship are changed.
The trick is to make certain that the newest solitary “Task” is set for each “Tag”. One way to do that is to try to then add even more logic to addTag() , to create by means particular given that by the_site is decided so you can false :
Enabling Tags to be Got rid of
The next thing is to allow the fresh deletion from a certain product on range. The answer is much like making it possible for labels as additional.
Layout Adjustment
The brand new ensure it is_delete alternative ensures that in the event that an item of a profile isn’t really delivered to your submission, new related data is taken from new range into the machine. So that which to work inside the a keen HTML form, you must take away the DOM feature on the collection product so you can come off, in advance of submitting the design.
When a label means is completely removed throughout the DOM and you may submitted, new eliminated Mark target will never be within the collection introduced so you’re able to setTags() . According to the perseverance level, this may or is almost certainly not enough to in fact take away the relationship between your removed Mark and you may Activity object.
Whenever deleting stuff similar to this, you might have to do some a bit more try to make sure the relationships involving the Task therefore the removed Mark was safely eliminated.
Usually in this instance you will have a lots of-to-you to dating therefore the erased tags will go away and persevere precisely (including new labels along with performs easily).
But when you possess a single-to-of a lot relationships or a plenty-to-of numerous reference to a mappedBy into the Activity entity (meaning Activity ‘s the “inverse” side), you’ll want to would a whole lot more work with the latest got rid of tags so you’re able to persevere correctly.
In this situation, you could modify the controller to eliminate the partnership towards eliminated level. This assumes on which you have specific change() step that’s handling the “update” of your Task:
Clearly, including and you will deleting the elements truthfully is difficult. If you don’t has a lot of-to-of several relationships where Task ‘s the “owning” front side, you’ll need to perform extra strive to make certain that brand new relationship try properly updated (regardless if you are adding the newest labels otherwise deleting established tags) on each Level target in itself.
The brand new Symfony people has created certain JavaScript bundles that give the latest abilities must include, edit and you will remove parts of the latest collection. Look at the /symfony-range plan to own modern internet explorer plus the symfony-range package considering jQuery for the remainder of web browsers.
You have to would both addTag() and removeTag() measures, if you don’t the form often however have fun with setTag() though because of the_source is incorrect . You’ll find out more and more brand new removeTag() strategy afterwards in this article.