]> git.immae.eu Git - github/wallabag/wallabag.git/commitdiff
Merge pull request #3574 from shulard/feature/rename-tags
authorJérémy Benoist <j0k3r@users.noreply.github.com>
Mon, 15 Oct 2018 08:32:59 +0000 (08:32 +0000)
committerGitHub <noreply@github.com>
Mon, 15 Oct 2018 08:32:59 +0000 (08:32 +0000)
Allow to rename tags from the web interface.

1  2 
src/Wallabag/CoreBundle/Controller/TagController.php

index 15f06ff522b6adeca5667a99b6a843cf995aca0b,a041510d0b4777acb99dcd574b35f8c51c9c55bb..d0155c6018bde6877786e1817a637deee6b18604
@@@ -5,12 -5,13 +5,13 @@@ namespace Wallabag\CoreBundle\Controlle
  use Pagerfanta\Adapter\ArrayAdapter;
  use Pagerfanta\Exception\OutOfRangeCurrentPageException;
  use Sensio\Bundle\FrameworkExtraBundle\Configuration\ParamConverter;
 -use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
  use Symfony\Bundle\FrameworkBundle\Controller\Controller;
  use Symfony\Component\HttpFoundation\Request;
 +use Symfony\Component\Routing\Annotation\Route;
  use Wallabag\CoreBundle\Entity\Entry;
  use Wallabag\CoreBundle\Entity\Tag;
  use Wallabag\CoreBundle\Form\Type\NewTagType;
+ use Wallabag\CoreBundle\Form\Type\RenameTagType;
  
  class TagController extends Controller
  {
          $tags = $this->get('wallabag_core.tag_repository')
              ->findAllFlatTagsWithNbEntries($this->getUser()->getId());
  
+         $renameForms = [];
+         foreach ($tags as $tag) {
+             $renameForms[$tag['id']] = $this->createForm(RenameTagType::class, new Tag())->createView();
+         }
          return $this->render('WallabagCoreBundle:Tag:tags.html.twig', [
              'tags' => $tags,
+             'renameForms' => $renameForms,
          ]);
      }
  
              'tag' => $tag,
          ]);
      }
+     /**
+      * Rename a given tag with a new label
+      * Create a new tag with the new name and drop the old one.
+      *
+      * @param Tag     $tag
+      * @param Request $request
+      *
+      * @Route("/tag/rename/{slug}", name="tag_rename")
+      * @ParamConverter("tag", options={"mapping": {"slug": "slug"}})
+      *
+      * @return \Symfony\Component\HttpFoundation\Response
+      */
+     public function renameTagAction(Tag $tag, Request $request)
+     {
+         $form = $this->createForm(RenameTagType::class, new Tag());
+         $form->handleRequest($request);
+         if ($form->isSubmitted() && $form->isValid()) {
+             $entries = $this->get('wallabag_core.entry_repository')->findAllByTagId(
+                 $this->getUser()->getId(),
+                 $tag->getId()
+             );
+             foreach ($entries as $entry) {
+                 $this->get('wallabag_core.tags_assigner')->assignTagsToEntry(
+                     $entry,
+                     $form->get('label')->getData()
+                 );
+                 $entry->removeTag($tag);
+             }
+             $em = $this->getDoctrine()->getManager();
+             $em->flush();
+         }
+         $this->get('session')->getFlashBag()->add(
+             'notice',
+             'flashes.tag.notice.tag_renamed'
+         );
+         $redirectUrl = $this->get('wallabag_core.helper.redirect')->to($request->headers->get('referer'), '', true);
+         return $this->redirect($redirectUrl);
+     }
  }