From 48f9a9632d2823be38883628ddfe62344cc282b1 Mon Sep 17 00:00:00 2001 From: Kevin Decherf Date: Wed, 15 Apr 2020 22:41:03 +0200 Subject: TagController: support merging labels when renaming one with label of another Signed-off-by: Kevin Decherf --- .../CoreBundle/Controller/TagController.php | 27 +++++++++++++--------- 1 file changed, 16 insertions(+), 11 deletions(-) (limited to 'src') diff --git a/src/Wallabag/CoreBundle/Controller/TagController.php b/src/Wallabag/CoreBundle/Controller/TagController.php index f7b78f5d..16ded948 100644 --- a/src/Wallabag/CoreBundle/Controller/TagController.php +++ b/src/Wallabag/CoreBundle/Controller/TagController.php @@ -151,13 +151,21 @@ class TagController extends Controller $form = $this->createForm(RenameTagType::class, new Tag()); $form->handleRequest($request); - if ($form->isSubmitted() - && $form->isValid() - && $form->get('label')->getData() !== $tag->getLabel() - ) { - $newTagLabel = $form->get('label')->getData(); + $redirectUrl = $this->get('wallabag_core.helper.redirect')->to($request->headers->get('referer'), '', true); + + if ($form->isSubmitted() && $form->isValid()) { $newTag = new Tag(); - $newTag->setLabel($newTagLabel); + $newTag->setLabel($form->get('label')->getData()); + + if ($newTag->getLabel() === $tag->getLabel()) { + return $this->redirect($redirectUrl); + } + + $tagFromRepo = $this->get('wallabag_core.tag_repository')->findOneByLabel($newTag->getLabel()); + + if (null !== $tagFromRepo) { + $newTag = $tagFromRepo; + } $entries = $this->get('wallabag_core.entry_repository')->findAllByTagId( $this->getUser()->getId(), @@ -166,14 +174,13 @@ class TagController extends Controller foreach ($entries as $entry) { $this->get('wallabag_core.tags_assigner')->assignTagsToEntry( $entry, - $newTagLabel, + $newTag->getLabel(), [$newTag] ); $entry->removeTag($tag); } - $em = $this->getDoctrine()->getManager(); - $em->flush(); + $this->getDoctrine()->getManager()->flush(); $this->get('session')->getFlashBag()->add( 'notice', @@ -181,8 +188,6 @@ class TagController extends Controller ); } - $redirectUrl = $this->get('wallabag_core.helper.redirect')->to($request->headers->get('referer'), '', true); - return $this->redirect($redirectUrl); } } -- cgit v1.2.3