Spaces:
Running
Running
| <html lang="fr"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
| <title>Calendrier - EduCollab</title> | |
| <script src="https://cdn.tailwindcss.com"></script> | |
| <link href="https://unpkg.com/aos@2.3.1/dist/aos.css" rel="stylesheet"> | |
| <script src="https://unpkg.com/aos@2.3.1/dist/aos.js"></script> | |
| <script src="https://cdn.jsdelivr.net/npm/feather-icons/dist/feather.min.js"></script> | |
| <script src="https://cdn.jsdelivr.net/npm/animejs/lib/anime.iife.min.js"></script> | |
| <script src="https://unpkg.com/feather-icons"></script> | |
| <style> | |
| @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap'); | |
| body { | |
| font-family: 'Inter', sans-serif; | |
| background-color: #f8fafc; | |
| } | |
| .calendar-day:hover { | |
| background-color: #f1f5f9; | |
| transform: scale(1.05); | |
| } | |
| .calendar-day.today { | |
| background-color: #6366f1; | |
| color: white; | |
| } | |
| .event-dot { | |
| width: 8px; | |
| height: 8px; | |
| border-radius: 50%; | |
| display: inline-block; | |
| margin-right: 2px; | |
| } | |
| .milestone { | |
| border-left: 4px solid #6366f1; | |
| } | |
| .animate-pulse-slow { | |
| animation: pulse 3s cubic-bezier(0.4, 0, 0.6, 1) infinite; | |
| } | |
| @keyframes pulse { | |
| 0%, 100% { opacity: 1; } | |
| 50% { opacity: .7; } | |
| } | |
| </style> | |
| </head> | |
| <body class="text-gray-800"> | |
| <!-- Navigation --> | |
| <nav class="bg-white shadow-sm"> | |
| <div class="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8"> | |
| <div class="flex justify-between h-16"> | |
| <div class="flex items-center"> | |
| <a href="index.html" class="flex-shrink-0 flex items-center"> | |
| <i data-feather="users" class="text-indigo-600"></i> | |
| <span class="ml-2 text-xl font-bold text-indigo-600">EduCollab</span> | |
| </a> | |
| </div> | |
| <div class="hidden md:ml-6 md:flex md:items-center md:space-x-8"> | |
| <a href="index.html" class="text-gray-500 hover:text-indigo-600 px-3 py-2 text-sm font-medium">Accueil</a> | |
| <a href="projets.html" class="text-gray-500 hover:text-indigo-600 px-3 py-2 text-sm font-medium">Projets</a> | |
| <a href="calendrier.html" class="text-indigo-600 px-3 py-2 text-sm font-medium">Calendrier</a> | |
| <a href="evaluation.html" class="text-gray-500 hover:text-indigo-600 px-3 py-2 text-sm font-medium">Évaluation</a> | |
| </div> | |
| <div class="flex items-center"> | |
| <button class="bg-indigo-600 text-white px-4 py-2 rounded-md text-sm font-medium hover:bg-indigo-700"> | |
| Mon compte | |
| </button> | |
| </div> | |
| </div> | |
| </div> | |
| </nav> | |
| <!-- Header --> | |
| <div class="bg-white shadow"> | |
| <div class="max-w-7xl mx-auto py-6 px-4 sm:px-6 lg:px-8"> | |
| <div class="flex justify-between items-center"> | |
| <h1 class="text-2xl font-bold text-gray-900">Calendrier interactif</h1> | |
| <button class="bg-indigo-600 text-white px-4 py-2 rounded-md text-sm font-medium hover:bg-indigo-700 flex items-center"> | |
| <i data-feather="plus" class="w-4 h-4 mr-2"></i> | |
| Nouvel événement | |
| </button> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Main Content --> | |
| <div class="max-w-7xl mx-auto py-6 sm:px-6 lg:px-8"> | |
| <div class="px-4 py-6 sm:px-0"> | |
| <!-- Calendar Navigation --> | |
| <div class="bg-white rounded-lg shadow-sm p-6 mb-6"> | |
| <div class="flex items-center justify-between mb-6"> | |
| <div class="flex items-center space-x-4"> | |
| <button class="p-2 rounded-md hover:bg-gray-100"> | |
| <i data-feather="chevron-left" class="w-5 h-5"></i> | |
| </button> | |
| <h2 class="text-xl font-semibold text-gray-900">Décembre 2023</h2> | |
| <button class="p-2 rounded-md hover:bg-gray-100"> | |
| <i data-feather="chevron-right" class="w-5 h-5"></i> | |
| </button> | |
| </div> | |
| <div class="flex space-x-2"> | |
| <button class="px-4 py-2 bg-indigo-600 text-white rounded-md text-sm font-medium">Mois</button> | |
| <button class="px-4 py-2 bg-white text-gray-700 rounded-md text-sm font-medium border border-gray-300">Semaine</button> | |
| <button class="px-4 py-2 bg-white text-gray-700 rounded-md text-sm font-medium border border-gray-300">Jour</button> | |
| </div> | |
| </div> | |
| <!-- Calendar Grid --> | |
| <div class="grid grid-cols-7 gap-2 mb-2"> | |
| <div class="text-center text-sm font-medium text-gray-500 py-2">Lun</div> | |
| <div class="text-center text-sm font-medium text-gray-500 py-2">Mar</div> | |
| <div class="text-center text-sm font-medium text-gray-500 py-2">Mer</div> | |
| <div class="text-center text-sm font-medium text-gray-500 py-2">Jeu</div> | |
| <div class="text-center text-sm font-medium text-gray-500 py-2">Ven</div> | |
| <div class="text-center text-sm font-medium text-gray-500 py-2">Sam</div> | |
| <div class="text-center text-sm font-medium text-gray-500 py-2">Dim</div> | |
| </div> | |
| <div class="grid grid-cols-7 gap-2"> | |
| <!-- Calendar Days --> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">27</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">28</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">29</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">30</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">1</div> | |
| <div class="mt-1 space-y-1"> | |
| <div class="text-xs bg-blue-100 text-blue-800 p-1 rounded">Réunion équipe</div> | |
| </div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">2</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">3</div> | |
| </div> | |
| <!-- Week 2 --> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">4</div> | |
| <div class="mt-1 space-y-1"> | |
| <div class="text-xs bg-purple-100 text-purple-800 p-1 rounded">Échéance partielle</div> | |
| </div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">5</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">6</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">7</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">8</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">9</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">10</div> | |
| </div> | |
| <!-- Week 3 --> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">11</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">12</div> | |
| <div class="mt-1 space-y-1"> | |
| <div class="text-xs bg-red-100 text-red-800 p-1 rounded">Présentation</div> | |
| </div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">13</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">14</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">15</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">16</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">17</div> | |
| </div> | |
| <!-- Week 4 --> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">18</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">19</div> | |
| </div> | |
| <div class="calendar-day today h-24 p-2 border border-indigo-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">20</div> | |
| <div class="mt-1 space-y-1"> | |
| <div class="text-xs bg-green-100 text-green-800 p-1 rounded">Aujourd'hui</div> | |
| <div class="text-xs bg-yellow-100 text-yellow-800 p-1 rounded">Révision</div> | |
| </div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">21</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">22</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">23</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">24</div> | |
| </div> | |
| <!-- Week 5 --> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">25</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">26</div> | |
| <div class="mt-1 space-y-1"> | |
| <div class="text-xs bg-indigo-100 text-indigo-800 p-1 rounded">Échéance finale</div> | |
| </div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">27</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">28</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">29</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">30</div> | |
| </div> | |
| <div class="calendar-day h-24 p-2 border border-gray-200 rounded-md cursor-pointer transition-all"> | |
| <div class="text-right text-sm">31</div> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Upcoming Events --> | |
| <div class="grid grid-cols-1 lg:grid-cols-3 gap-6"> | |
| <!-- Upcoming Milestones --> | |
| <div class="bg-white rounded-lg shadow-sm p-6"> | |
| <h3 class="text-lg font-semibold text-gray-900 mb-4">Jalons à venir</h3> | |
| <div class="space-y-4"> | |
| <div class="milestone pl-4 py-2"> | |
| <div class="flex justify-between items-start"> | |
| <div> | |
| <h4 class="font-medium text-gray-900">Soumission intermédiaire</h4> | |
| <p class="text-sm text-gray-500">Projet IA & Machine Learning</p> | |
| </div> | |
| <span class="text-sm text-indigo-600">Dans 3 jours</span> | |
| </div> | |
| </div> | |
| <div class="milestone pl-4 py-2"> | |
| <div class="flex justify-between items-start"> | |
| <div> | |
| <h4 class="font-medium text-gray-900">Présentation finale</h4> | |
| <p class="text-sm text-gray-500">Application Mobile Éducative</p> | |
| </div> | |
| <span class="text-sm text-indigo-600">Dans 12 jours</span> | |
| </div> | |
| </div> | |
| <div class="milestone pl-4 py-2"> | |
| <div class="flex justify-between items-start"> | |
| <div> | |
| <h4 class="font-medium text-gray-900">Révision de code</h4> | |
| <p class="text-sm text-gray-500">Analyse de Données Éducatives</p> | |
| </div> | |
| <span class="text-sm text-indigo-600">Demain</span> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Recent Activity --> | |
| <div class="bg-white rounded-lg shadow-sm p-6 lg:col-span-2"> | |
| <h3 class="text-lg font-semibold text-gray-900 mb-4">Activité récente</h3> | |
| <div class="space-y-4"> | |
| <div class="flex items-start"> | |
| <div class="flex-shrink-0"> | |
| <img class="h-10 w-10 rounded-full" src="https://randomuser.me/api/portraits/women/32.jpg" alt=""> | |
| </div> | |
| <div class="ml-4"> | |
| <p class="text-sm text-gray-900"><span class="font-medium">Sophie Martin</span> a terminé la tâche "Interface utilisateur"</p> | |
| <p class="text-xs text-gray-500">Il y a 2 heures</p> | |
| </div> | |
| </div> | |
| <div class="flex items-start"> | |
| <div class="flex-shrink-0"> | |
| <img class="h-10 w-10 rounded-full" src="https://randomuser.me/api/portraits/men/41.jpg" alt=""> | |
| </div> | |
| <div class="ml-4"> | |
| <p class="text-sm text-gray-900"><span class="font-medium">Thomas Leroy</span> a commenté le document de spécifications</p> | |
| <p class="text-xs text-gray-500">Il y a 5 heures</p> | |
| </div> | |
| </div> | |
| <div class="flex items-start"> | |
| <div class="flex-shrink-0"> | |
| <img class="h-10 w-10 rounded-full" src="https://randomuser.me/api/portraits/women/68.jpg" alt=""> | |
| </div> | |
| <div class="ml-4"> | |
| <p class="text-sm text-gray-900"><span class="font-medium">Camille Dubois</span> a uploadé de nouveaux assets design</p> | |
| <p class="text-xs text-gray-500">Hier à 14:32</p> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <script> | |
| AOS.init({ | |
| duration: 800, | |
| easing: 'ease-in-out', | |
| once: true | |
| }); | |
| feather.replace(); | |
| // Highlight today's date | |
| document.querySelectorAll('.calendar-day').forEach(day => { | |
| day.addEventListener('click', function() { | |
| document.querySelectorAll('.calendar-day').forEach(d => { | |
| d.classList.remove('today'); | |
| d.classList.remove('border-indigo-200'); | |
| }); | |
| this.classList.add('today'); | |
| this.classList.add('border-indigo-200'); | |
| }); | |
| }); | |
| </script> | |
| </body> | |
| </html> |