Files
notytex/templates/classes.html

156 lines
7.4 KiB
HTML

{% extends "base.html" %}
{% from 'components/common/macros.html' import hero_section %}
{% from 'components/class/class_card.html' import class_card %}
{% block title %}Classes - Gestion Scolaire{% endblock %}
{% block content %}
<div class="space-y-8">
{# Hero Section avec composant réutilisable #}
{% set meta_info = [
{
'icon': '<svg class="w-4 h-4 mr-2" fill="currentColor" viewBox="0 0 20 20"><path d="M9 12l2 2 4-4m6 2a9 9 0 11-18 0 9 9 0 0118 0z"/></svg>',
'text': classes|length ~ ' classes actives'
},
{
'icon': '<svg class="w-4 h-4 mr-2" fill="currentColor" viewBox="0 0 20 20"><path fill-rule="evenodd" d="M6 2a1 1 0 00-1 1v1H4a2 2 0 00-2 2v10a2 2 0 002 2h12a2 2 0 002-2V6a2 2 0 00-2-2h-1V3a1 1 0 10-2 0v1H7V3a1 1 0 00-1-1zm0 5a1 1 0 000 2h8a1 1 0 100-2H6z" clip-rule="evenodd"/></svg>',
'text': 'Année scolaire 2024-2025'
}
] %}
{% set primary_action = {
'url': url_for('classes.new'),
'text': 'Nouvelle classe',
'icon': '<svg class="w-5 h-5 mr-2" fill="currentColor" viewBox="0 0 20 20"><path fill-rule="evenodd" d="M10 3a1 1 0 011 1v5h5a1 1 0 110 2h-5v5a1 1 0 11-2 0v-5H4a1 1 0 110-2h5V4a1 1 0 011-1z" clip-rule="evenodd"/></svg>'
} %}
{{ hero_section(
title="Mes Classes 🏫",
subtitle="Gérez et organisez toutes vos classes",
meta_info=meta_info,
primary_action=primary_action,
gradient_class="from-blue-600 to-green-600"
) }}
{% if classes %}
<!-- Grille de classes avec composants -->
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6">
{% for class in classes %}
{{ class_card(class) }}
{% endfor %}
</div>
{% else %}
<!-- État vide moderne -->
<div class="bg-white rounded-xl shadow-lg p-12 text-center">
<div class="w-24 h-24 bg-gradient-to-br from-blue-100 to-green-100 rounded-full flex items-center justify-center mx-auto mb-6">
<svg class="w-12 h-12 text-blue-600" fill="currentColor" viewBox="0 0 20 20">
<path d="M9 12l2 2 4-4m6 2a9 9 0 11-18 0 9 9 0 0118 0z"/>
</svg>
</div>
<h3 class="text-xl font-bold text-gray-900 mb-2">Aucune classe créée</h3>
<p class="text-gray-600 mb-6 max-w-md mx-auto">
Commencez votre gestion scolaire en créant votre première classe.
Vous pourrez ensuite y ajouter des élèves et créer des évaluations.
</p>
<div class="space-y-4">
<a href="{{ url_for('classes.new') }}" class="inline-flex items-center bg-gradient-to-r from-blue-500 to-green-500 hover:from-blue-600 hover:to-green-600 text-white px-6 py-3 rounded-xl transition-all duration-300 font-semibold shadow-lg hover:shadow-xl transform hover:scale-105">
<svg class="w-5 h-5 mr-2" fill="currentColor" viewBox="0 0 20 20">
<path fill-rule="evenodd" d="M10 3a1 1 0 011 1v5h5a1 1 0 110 2h-5v5a1 1 0 11-2 0v-5H4a1 1 0 110-2h5V4a1 1 0 011-1z" clip-rule="evenodd"/>
</svg>
Créer ma première classe
</a>
<div class="text-sm text-gray-500">
<p>💡 <strong>Astuce :</strong> Une classe peut contenir plusieurs élèves et être utilisée pour de nombreuses évaluations</p>
</div>
</div>
</div>
{% endif %}
</div>
<!-- Modal de confirmation de suppression -->
<div id="deleteModal" class="fixed inset-0 bg-gray-600 bg-opacity-50 hidden z-50">
<div class="flex items-center justify-center min-h-screen p-4">
<div class="bg-white rounded-xl shadow-xl max-w-md w-full">
<div class="p-6">
<div class="flex items-center">
<div class="flex-shrink-0">
<svg class="w-12 h-12 text-red-600" fill="currentColor" viewBox="0 0 20 20">
<path fill-rule="evenodd" d="M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z" clip-rule="evenodd"/>
</svg>
</div>
<div class="ml-4">
<h3 class="text-lg font-medium text-gray-900">Supprimer la classe</h3>
<p class="mt-1 text-sm text-gray-600" id="deleteMessage">
Êtes-vous sûr de vouloir supprimer cette classe ?
</p>
</div>
</div>
<div class="mt-6 flex justify-end space-x-3">
<button onclick="closeDeleteModal()" class="bg-white hover:bg-gray-50 border border-gray-300 text-gray-700 px-4 py-2 rounded-lg font-medium transition-colors">
Annuler
</button>
<form id="deleteForm" method="POST" class="inline">
<button type="submit" class="bg-red-600 hover:bg-red-700 text-white px-4 py-2 rounded-lg font-medium transition-colors">
Supprimer définitivement
</button>
</form>
</div>
</div>
</div>
</div>
</div>
<script>
function confirmDeleteClass(classId, className, studentsCount, assessmentsCount) {
const modal = document.getElementById('deleteModal');
const message = document.getElementById('deleteMessage');
const form = document.getElementById('deleteForm');
// Configuration du message selon le contenu de la classe
if (studentsCount > 0 || assessmentsCount > 0) {
message.innerHTML = `
<strong>Impossible de supprimer la classe "${className}".</strong><br>
Elle contient <strong>${studentsCount} élève(s)</strong> et <strong>${assessmentsCount} évaluation(s)</strong>.<br>
Supprimez d'abord ces éléments pour pouvoir supprimer la classe.
`;
// Masquer le bouton de suppression et changer le titre
document.querySelector('#deleteForm button').style.display = 'none';
document.querySelector('#deleteModal h3').textContent = 'Suppression impossible';
} else {
message.innerHTML = `
Êtes-vous sûr de vouloir supprimer la classe <strong>"${className}"</strong> ?<br>
<span class="text-red-600">Cette action est irréversible.</span>
`;
// Réafficher le bouton de suppression et restaurer le titre
document.querySelector('#deleteForm button').style.display = 'inline';
document.querySelector('#deleteModal h3').textContent = 'Supprimer la classe';
}
// Configuration de l'action du formulaire
form.action = `/classes/${classId}/delete`;
// Afficher le modal
modal.classList.remove('hidden');
}
function closeDeleteModal() {
document.getElementById('deleteModal').classList.add('hidden');
}
// Fermeture au clic sur le fond
document.getElementById('deleteModal').addEventListener('click', function(e) {
if (e.target === this) {
closeDeleteModal();
}
});
// Fermeture avec la touche Échap
document.addEventListener('keydown', function(e) {
if (e.key === 'Escape') {
closeDeleteModal();
}
});
</script>
{% endblock %}