From 9d08284d59437b0d9eaa3b224cd335570d7caf20 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vojt=C4=9Bch=20Barto=C5=A1?= Date: Thu, 13 Oct 2016 23:01:24 +0200 Subject: [PATCH 1/2] =?UTF-8?q?Str=C3=A1nkov=C3=A1n=C3=AD=20bez=20OFFSET.?= =?UTF-8?q?=20Odkaz=20na=20n=C3=A1sleduj=C3=ADc=C3=AD=20str=C3=A1nku=20obs?= =?UTF-8?q?ahuje=20id=20posledn=C3=ADho=20z=C3=A1znamu=20na=20aktu=C3=A1ln?= =?UTF-8?q?=C3=AD=20str=C3=A1nce.=20Sta=C4=8D=C3=AD=20pak=20vyfiltrovat=20?= =?UTF-8?q?n=C3=A1sleduj=C3=ADc=C3=ADch=20X=20z=C3=A1znam=C5=AF=20s=20v?= =?UTF-8?q?=C4=9Bt=C5=A1=C3=ADm=20id=20a=20to=20je=20n=C3=A1sleduj=C3=ADc?= =?UTF-8?q?=C3=AD=20str=C3=A1nka.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/Resources/views/category/detail.html.twig | 3 + .../views/components/paginator.html.twig | 18 ++++++ .../Controller/CategoryController.php | 49 +++++++++++---- .../Repository/ProductRepository.php | 59 +++++++++++++++++-- 4 files changed, 112 insertions(+), 17 deletions(-) create mode 100644 app/Resources/views/components/paginator.html.twig diff --git a/app/Resources/views/category/detail.html.twig b/app/Resources/views/category/detail.html.twig index 13b9283..eef375a 100644 --- a/app/Resources/views/category/detail.html.twig +++ b/app/Resources/views/category/detail.html.twig @@ -4,5 +4,8 @@
{% include 'components/list.html.twig' %}
+ + + {% include ':components:paginator.html.twig' %} {% endblock %} diff --git a/app/Resources/views/components/paginator.html.twig b/app/Resources/views/components/paginator.html.twig new file mode 100644 index 0000000..0e97218 --- /dev/null +++ b/app/Resources/views/components/paginator.html.twig @@ -0,0 +1,18 @@ + \ No newline at end of file diff --git a/src/AppBundle/Controller/CategoryController.php b/src/AppBundle/Controller/CategoryController.php index 6e6a457..9461cf1 100644 --- a/src/AppBundle/Controller/CategoryController.php +++ b/src/AppBundle/Controller/CategoryController.php @@ -3,6 +3,7 @@ use AppBundle\Entity\Category; use AppBundle\Entity\Product; +use AppBundle\Repository\ProductRepository; use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template; use Symfony\Bundle\FrameworkBundle\Controller\Controller; @@ -14,25 +15,52 @@ */ class CategoryController extends Controller { - /** - * @Route("/vyber/{slug}", name="category_detail") - * @Template("category/detail.html.twig") - * - * @param Request $request - * @return array - */ - public function categoryDetail(Request $request) + const DIRECTION_NEXT = 'next'; + const DIRECTION_PREV = 'prev'; + + /** + * @Route("/vyber/{slug}/{last}/{direction}", name="category_detail", requirements={"last": "\d+"}) + * @Template("category/detail.html.twig") + * + * @param string $slug + * @param int $last + * @param string $direction + * @return array + * @internal param Request $request + */ + public function categoryDetail($slug, $last = 0, $direction = self::DIRECTION_NEXT) { $category = $this->getDoctrine()->getRepository(Category::class)->findOneBy([ - "slug" => $request->attributes->get("slug"), + "slug" => $slug, ]); if (!$category) { throw new NotFoundHttpException("Kategorie neexistuje"); } + if ($direction === self::DIRECTION_NEXT) { + $products = $this->getDoctrine()->getRepository(Product::class)->findNextByCategory($category, $last); + } else { + $products = $this->getDoctrine()->getRepository(Product::class)->findPrevByCategory($category, $last); + } + + if (current($products)->getId() !== 1) { + $prev = current($products)->getId(); + } else { + $prev = null; + } + + if (isset($products[ProductRepository::PAGE_SIZE])) { + unset($products[ProductRepository::PAGE_SIZE]); + $next = end($products)->getId(); + } else { + $next = null; + } + return [ - "products" => $this->getDoctrine()->getRepository(Product::class)->findByCategory($category), + "products" => $products, + "prev" => $prev, + "next" => $next, "categories" => $this->getDoctrine()->getRepository(Category::class)->findBy( [ "parentCategory" => $category, @@ -44,5 +72,4 @@ public function categoryDetail(Request $request) "category" => $category, ]; } - } diff --git a/src/AppBundle/Repository/ProductRepository.php b/src/AppBundle/Repository/ProductRepository.php index ac70f55..4004b43 100644 --- a/src/AppBundle/Repository/ProductRepository.php +++ b/src/AppBundle/Repository/ProductRepository.php @@ -8,23 +8,70 @@ class ProductRepository extends EntityRepository { + const PAGE_SIZE = 3; - /** - * @param Category $category - * @return Product[] - */ - public function findByCategory(Category $category) + /** + * @param Category $category + * @param int $last + * @return Product[] + */ + public function findPrevByCategory(Category $category, $last = 0) + { + return $this->inverseResult($this->_em->createQuery('SELECT p + FROM AppBundle\Entity\Product p + JOIN AppBundle\Entity\ProductCategory pc WITH p = pc.product + JOIN AppBundle\Entity\Category c WITH pc.category = c + WHERE c.left >= :lft and c.right <= :rgt + AND p.id <= :last + GROUP BY p + ORDER BY p.id DESC + ') + ->setParameter("lft", $category->getLeft()) + ->setParameter("rgt", $category->getRight()) + ->setParameter("last", $last) + ->setMaxResults(self::PAGE_SIZE + 1) + ->getResult()); + } + + + /** + * @param array $entities + * @return array + */ + protected function inverseResult(array $entities) + { + $result = []; + + $max = count($entities) - 1; + $min = 0; + for ($i = $max; $i >= $min; $i--) { + $result[] = $entities[$i]; + } + + return $result; + } + + /** + * @param Category $category + * @param int $last + * @return Product[] + */ + public function findNextByCategory(Category $category, $last = 0) { return $this->_em->createQuery('SELECT p FROM AppBundle\Entity\Product p JOIN AppBundle\Entity\ProductCategory pc WITH p = pc.product JOIN AppBundle\Entity\Category c WITH pc.category = c WHERE c.left >= :lft and c.right <= :rgt + AND p.id > :last GROUP BY p + ORDER BY p.id ASC ') ->setParameter("lft", $category->getLeft()) ->setParameter("rgt", $category->getRight()) - ->getResult(); + ->setParameter("last", $last) + ->setMaxResults(self::PAGE_SIZE + 1) + ->getResult(); } } From 3d79241c684ad823036a77693390298bc55e17d5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vojt=C4=9Bch=20Barto=C5=A1?= Date: Fri, 14 Oct 2016 19:01:42 +0200 Subject: [PATCH 2/2] Breadcrumb menu --- app/Resources/views/category/detail.html.twig | 2 ++ app/Resources/views/components/breadcrumb.html.twig | 12 ++++++++++++ src/AppBundle/Controller/CategoryController.php | 1 + src/AppBundle/Repository/CategoryRepository.php | 13 +++++++++++++ 4 files changed, 28 insertions(+) create mode 100644 app/Resources/views/components/breadcrumb.html.twig diff --git a/app/Resources/views/category/detail.html.twig b/app/Resources/views/category/detail.html.twig index eef375a..8cf3245 100644 --- a/app/Resources/views/category/detail.html.twig +++ b/app/Resources/views/category/detail.html.twig @@ -1,6 +1,8 @@ {% extends 'base.html.twig' %} {% block body %} + {% include 'components/breadcrumb.html.twig' %} +
{% include 'components/list.html.twig' %}
diff --git a/app/Resources/views/components/breadcrumb.html.twig b/app/Resources/views/components/breadcrumb.html.twig new file mode 100644 index 0000000..c61b41f --- /dev/null +++ b/app/Resources/views/components/breadcrumb.html.twig @@ -0,0 +1,12 @@ + \ No newline at end of file diff --git a/src/AppBundle/Controller/CategoryController.php b/src/AppBundle/Controller/CategoryController.php index 9461cf1..90017dd 100644 --- a/src/AppBundle/Controller/CategoryController.php +++ b/src/AppBundle/Controller/CategoryController.php @@ -70,6 +70,7 @@ public function categoryDetail($slug, $last = 0, $direction = self::DIRECTION_NE ] ), "category" => $category, + "breadcrumb" => $this->getDoctrine()->getRepository(Category::class)->getParents($category) ]; } } diff --git a/src/AppBundle/Repository/CategoryRepository.php b/src/AppBundle/Repository/CategoryRepository.php index f9b2633..edbcd73 100644 --- a/src/AppBundle/Repository/CategoryRepository.php +++ b/src/AppBundle/Repository/CategoryRepository.php @@ -3,6 +3,7 @@ namespace AppBundle\Repository; use Doctrine\ORM\EntityRepository; +use AppBundle\Entity\Category; /** * CategoryRepository @@ -12,4 +13,16 @@ */ class CategoryRepository extends EntityRepository { + public function getParents(Category $category) + { + return $this->_em->createQuery(" + SELECT ancestor + FROM AppBundle\Entity\Category child, AppBundle\Entity\Category ancestor + WHERE child.left >= ancestor.left + AND child.left <= ancestor.right + AND child.id = :current + ORDER BY ancestor.left") + ->setParameter("current", $category->getId()) + ->getResult(); + } }