Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
File Manager
/
ONSEMI
/
Dev tableau
:
tmp0012.php
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
<?php function getWorkingDays($startDate, $endDate, $holidays = []) { $start = strtotime($startDate); $end = strtotime($endDate); $workingDays = []; // Définir le locale en français setlocale(LC_TIME, 'fr_FR.UTF-8'); // Générer toutes les dates entre startDate et endDate for ($currentDate = $start; $currentDate <= $end; $currentDate = strtotime("+1 day", $currentDate)) { $dayOfWeek = date("N", $currentDate); // Numéro du jour de la semaine (1 = lundi, 7 = dimanche) // Vérifier si ce jour est un week-end ou un jour férié if ($dayOfWeek < 6 && !in_array(date("Y-m-d", $currentDate), $holidays)) { $day = date("d", $currentDate); // Numéro du jour du mois $dayOfWeekName = strftime("%A", $currentDate); // Nom complet du jour en français $dayOfWeekInitial = strtoupper($dayOfWeekName[0]); // Initial du jour en français (première lettre) $weekNumber = date("W", $currentDate); // Numéro de la semaine // Ajouter un tableau avec ces trois informations dans $workingDays $workingDays[] = [ 'day' => $day, 'day_of_week_initial' => $dayOfWeekInitial, 'week_number' => $weekNumber ]; } } return $workingDays; } // a utiliser /* function getWorkingDays($startDate, $endDate, $holidays = []) { $start = strtotime($startDate); $end = strtotime($endDate); $workingDays = []; // Définir le locale en français pour les noms de mois et jours setlocale(LC_TIME, 'fr_FR.UTF-8'); // Générer toutes les dates entre startDate et endDate for ($currentDate = $start; $currentDate <= $end; $currentDate = strtotime("+1 day", $currentDate)) { $dayOfWeek = date("N", $currentDate); // Numéro du jour de la semaine (1 = lundi, 7 = dimanche) // Vérifier si ce jour est un week-end ou un jour férié if ($dayOfWeek < 6 && !in_array(date("Y-m-d", $currentDate), $holidays)) { $day = date("d", $currentDate); // Numéro du jour du mois $monthName = strftime("%B", $currentDate); // Nom du mois en français $dayOfWeekName = strftime("%A", $currentDate); // Nom complet du jour en français $dayOfWeekInitial = strtoupper($dayOfWeekName[0]); // Initial du jour en français (première lettre) $weekNumber = date("W", $currentDate); // Numéro de la semaine $formattedDate = date("d-m-Y", $currentDate); // Date sous le format jour-mois-année // Ajouter un tableau avec ces informations dans $workingDays $workingDays[] = [ 'day' => $day, 'month_name' => $monthName, 'day_of_week_initial' => $dayOfWeekInitial, 'week_number' => $weekNumber, 'formatted_date' => $formattedDate ]; } } return $workingDays; } */ // Liste des jours fériés et fêtes religieuses à exclure (exemple pour la France, à compléter avec d'autres fêtes) $holidays = [ "2025-01-01", // Jour de l'An "2025-04-14", // Lundi de Pâques "2025-05-01", // Fête du Travail "2025-05-08", // Victoire 1945 "2025-07-14", // Bastille "2025-08-15", // Assomption "2025-11-01", // Toussaint "2025-12-25", // Noël "2026-01-01", // Jour de l'An "2026-04-06", // Lundi de Pâques // Ajouter d'autres jours fériés ici... ]; // Définir la période de début et de fin $startDate = "2025-01-10"; $endDate = "2026-02-14"; // Appeler la fonction pour obtenir les jours ouvrés entre les deux dates $workingDays = getWorkingDays($startDate, $endDate, $holidays); ?> <!DOCTYPE html> <html lang="fr"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Tableau Sticky - 3 Lignes Fixes</title> <style> <style> .table-wrapper { width: 100%; max-height: 400px; overflow: auto; border: 1px solid #ccc; position: relative; } table { border-collapse: collapse; width: max-content; table-layout: fixed; } th, td { padding: 10px; text-align: center; height: 40px; border: 1px solid #ccc; white-space: nowrap; min-width: 120px; position: relative; background-color: white; box-sizing: border-box; } /* ✅ Fixation des cellules d'en-tête */ th { background-color: #f2f2f2; position: sticky; top: 0; z-index: 100; /* Hauteur élevée pour éviter les chevauchements */ } /* ✅ Colonnes sticky */ th:first-child, td:first-child { position: sticky; left: 0; z-index: 101; /* Priorité plus haute */ background-color: white; } th:nth-child(2), td:nth-child(2) { position: sticky; left: 120px; z-index: 100; background-color: white; } th:nth-child(3), td:nth-child(3) { position: sticky; left: 240px; z-index: 99; background-color: white; } /* ✅ Bordures droites persistantes */ th:first-child::after, td:first-child::after, th:nth-child(2)::after, td:nth-child(2)::after, th:nth-child(3)::after, td:nth-child(3)::after { content: ""; position: absolute; right: 0; top: 0; width: 2px; height: 100%; background-color: #ccc; z-index: 102; } /* ✅ Alternance des couleurs */ tbody tr:nth-child(odd) { background-color: #f9f9f9; } /* ✅ Largeur fixe des autres colonnes */ th:nth-child(n+4), td:nth-child(n+4) { min-width: 150px; } /* ✅ Deuxième ligne d'en-tête sticky */ .second-header th { background-color: #f2f2f2; position: sticky; top: 40px; z-index: 99; } /* ✅ Troisième ligne d'en-tête sticky */ .third-header th { background-color: #f2f2f2; position: sticky; top: 80px; z-index: 98; } /* ✅ Correction du positionnement des 3 premières colonnes de la deuxième et troisième ligne */ .second-header th:first-child, .third-header th:first-child { left: 0; z-index: 101; background-color: white; } .second-header th:nth-child(2), .third-header th:nth-child(2) { left: 120px; z-index: 100; background-color: white; } .second-header th:nth-child(3), .third-header th:nth-child(3) { left: 240px; z-index: 99; background-color: white; } /* ✅ Réajustement des z-index pour garantir l'ordre correct */ thead tr:first-child th:first-child, thead tr:first-child th:nth-child(2), thead tr:first-child th:nth-child(3) { z-index: 105; background-color: #ddd; } .second-header th:first-child, .second-header th:nth-child(2), .second-header th:nth-child(3) { z-index: 104; } .third-header th:first-child, .third-header th:nth-child(2), .third-header th:nth-child(3) { z-index: 103; } /* ✅ Bordures inférieures fixes sans chevauchement */ thead tr:first-child th, .second-header th, .third-header th { box-shadow: inset 0 -2px #aaa; background-clip: padding-box; padding-bottom: 2px; /* Réduction du chevauchement */ margin-bottom: -2px; /* Évite que les bordures ne recouvrent les autres cellules */ z-index: 100; /* Priorité élevée */ } /* Ajout d'un petit espace entre les lignes sticky pour éviter le chevauchement */ .second-header th { top: calc(40px + 2px); /* Décale légèrement les lignes sticky vers le bas */ margin-top: 2px; /* Donne un petit espace entre les lignes */ } .third-header th { top: calc(80px + 2px); /* Décale la troisième ligne un peu plus bas */ margin-top: 2px; /* Donne un petit espace entre les lignes */ } </style> </style> </head> <body> <div class="table-wrapper"> <table> <thead> <tr> <th></th> <th>plouf</th> <th>cretin</th> <?php foreach ($workingDays as $dateData): ?> <th> <?php echo $dateData['day']; ?> <br> </th> <?php endforeach; ?> </tr> <!-- ✅ Deuxième ligne d'en-tête sticky --> <tr class="second-header"> <th></th> <th>Valeur 1</th> <th>Valeur 2</th> <?php foreach ($workingDays as $dateData): ?> <th> <?php echo $dateData['day_of_week_initial']; ?></th> <?php endforeach; ?> </tr> <!-- ✅ Troisième ligne d'en-tête sticky --> <tr class="third-header"> <th></th> <th>Info 1</th> <th>Info 2</th> <?php foreach ($workingDays as $dateData): ?> <th> <?php echo $dateData['week_number']; ?></th> <?php endforeach; ?> </tr> </thead> <tbody> <?php for ($i = 1; $i <= 50; $i++): ?> <tr> <td>Row <?php echo $i; ?></td> <td>Data <?php echo $i . "-2"; ?></td> <td>cretin <?php echo $i; ?></td> <?php foreach ($workingDays as $dateData): ?> <td>Data <?php echo $i . "-" . $dateData['week_number']; ?></td> <?php endforeach; ?> </tr> <?php endfor; ?> </tbody> </table> </div> </body> </html>