templates/magazines/list.html.twig line 1

Open in your IDE?
  1. {% extends 'base.html.twig' %}
  2. {% block title %}Liste des Magazines{% endblock %}
  3. {% block body %}
  4. <div class="container mt-4">
  5. <div class="d-flex justify-content-between align-items-center mb-4">
  6. <h1>Magazines</h1>
  7. <div>
  8. <a href="{{ path('magazines_search') }}" class="btn btn-outline-secondary mr-2">
  9. <i class="fas fa-search"></i> Rechercher
  10. </a>
  11. {% if is_granted('IS_AUTHENTICATED_FULLY') %}
  12. <a href="{{ path('magazine_new') }}" class="btn btn-primary">
  13. <i class="fas fa-plus"></i> Nouveau magazine
  14. </a>
  15. {% endif %}
  16. </div>
  17. </div>
  18. {% for message in app.flashes('success') %}
  19. <div class="alert alert-success">{{ message }}</div>
  20. {% endfor %}
  21. {% if magazines|length > 0 %}
  22. <div class="row">
  23. {% for magazine in magazines %}
  24. <div class="col-md-4 col-lg-3 mb-4">
  25. <div class="card h-100">
  26. {% if images[magazine.id] is defined %}
  27. <img src="data:image/jpeg;base64,{{ images[magazine.id] }}"
  28. class="card-img-top"
  29. alt="{{ magazine.nom }}"
  30. style="height: 200px; object-fit: cover;">
  31. {% else %}
  32. <div class="card-img-top bg-secondary d-flex align-items-center justify-content-center"
  33. style="height: 200px;">
  34. <i class="fas fa-book fa-3x text-white"></i>
  35. </div>
  36. {% endif %}
  37. <div class="card-body">
  38. <h5 class="card-title">{{ magazine.nom }}</h5>
  39. {% if magazine.editeur %}
  40. <p class="card-text text-muted small">{{ magazine.editeur }}</p>
  41. {% endif %}
  42. <p class="card-text">
  43. <span class="badge badge-info">{{ magazine.nbnum }} numéro(s)</span>
  44. {% if magazine.statut %}
  45. <span class="badge badge-success">En cours</span>
  46. {% else %}
  47. <span class="badge badge-secondary">Terminé</span>
  48. {% endif %}
  49. </p>
  50. </div>
  51. <div class="card-footer">
  52. <a href="{{ path('magazine_detail', {id: magazine.id}) }}" class="btn btn-sm btn-outline-primary">
  53. Voir les numéros
  54. </a>
  55. </div>
  56. </div>
  57. </div>
  58. {% endfor %}
  59. </div>
  60. <div class="d-flex justify-content-center mt-4">
  61. {{ knp_pagination_render(pagination, '@KnpPaginator/Pagination/twitter_bootstrap_v4_pagination.html.twig') }}
  62. </div>
  63. {% else %}
  64. <div class="alert alert-info">
  65. Aucun magazine enregistré pour le moment.
  66. {% if is_granted('IS_AUTHENTICATED_FULLY') %}
  67. <a href="{{ path('magazine_new') }}">Créer le premier magazine</a>
  68. {% endif %}
  69. </div>
  70. {% endif %}
  71. </div>
  72. {% endblock %}