diff --git a/src/Controller/PostController.php b/src/Controller/PostController.php index 0df3016..8fc7cf7 100644 --- a/src/Controller/PostController.php +++ b/src/Controller/PostController.php @@ -6,15 +6,22 @@ use App\Repository\PostRepository; use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\Routing\Attribute\Route; +use Symfony\Component\HttpFoundation\Request; class PostController extends AbstractController { + private const POSTS_PER_PAGE = 10; + #[Route('/', name: 'app_posts')] - public function index(PostRepository $repository): Response + public function index(PostRepository $repository, Request $request): Response { - $posts = $repository->findAll(); + $page = $request->query->getInt('page', 1); + $posts = $repository->findPaginatedPosts($page, self::POSTS_PER_PAGE); + $maxPage = ceil($posts->count() / self::POSTS_PER_PAGE); return $this->render('post/index.html.twig', [ 'posts' => $posts, + 'maxPage' => $maxPage, + 'page' => $page, ]); } } diff --git a/src/Repository/PostRepository.php b/src/Repository/PostRepository.php index 93adbe9..2082982 100644 --- a/src/Repository/PostRepository.php +++ b/src/Repository/PostRepository.php @@ -5,6 +5,7 @@ namespace App\Repository; use App\Entity\Post; use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository; use Doctrine\Persistence\ManagerRegistry; +use Doctrine\ORM\Tools\Pagination\Paginator; /** * @extends ServiceEntityRepository @@ -16,6 +17,20 @@ class PostRepository extends ServiceEntityRepository parent::__construct($registry, Post::class); } + /** + * @param int $page + * @param int $limit + * @return Paginator + */ + public function findPaginatedPosts(int $page, int $limit): Paginator + { + $query = $this->createQueryBuilder('p') + ->setFirstResult(($page - 1) * $limit) + ->setMaxResults($limit); + + return new Paginator($query, fetchJoinCollection: false); + } + // /** // * @return Post[] Returns an array of Post objects // */ diff --git a/templates/_pagination.html.twig b/templates/_pagination.html.twig new file mode 100644 index 0000000..1c4cc35 --- /dev/null +++ b/templates/_pagination.html.twig @@ -0,0 +1,24 @@ +{% set route = app.request.attributes.get('_route') %} + diff --git a/templates/base.html.twig b/templates/base.html.twig index bbf16f1..ec9dcfd 100644 --- a/templates/base.html.twig +++ b/templates/base.html.twig @@ -5,6 +5,7 @@ {% block title %}Welcome to Herbarium!{% endblock %} {% block stylesheets %} + {% endblock %} {% block javascripts %} diff --git a/templates/post/index.html.twig b/templates/post/index.html.twig index 94f3756..82e3d39 100644 --- a/templates/post/index.html.twig +++ b/templates/post/index.html.twig @@ -1,11 +1,20 @@ {% extends 'base.html.twig' %} - {% block title %}Posts!{% endblock %} {% block body %} -{% for post in posts %} -
- #{{ post.id }} trouvé le {{ post.foundDate | date("d/m/Y \\à H \\h") }} +{% for post in posts.iterator %} +
+
+
{{ post.species ? post.species.vernacularName : 'Post' }}
+
{{ post.foundDate | date("d/m/Y \\à H \\h") }}
+

{{ post.latitude }}, {{ post.longitude }}, {{ post.altitude }}m

+

{{ post.commentary }}

+
+
{% endfor %} +{% include '_pagination.html.twig' %} {% endblock %}