<?
include("../edt/fonctions_edt.php3");
include("../BarreDeMenu.php3");
include("../Session/security.php");
// Entete
buildHeader("Emploi du temps des salles");
// Verification de la session
$autorisation_list[0]=0; // Administrateur
$autorisation_list[1]=3; // Gestionnaire
$user_type = validateSession($id_session);
if ($user_type == -1 || !security($id_session,$autorisation_list)) print("Accès refusé");
else
{
// Barre de menu
buildMenuBar($id_session,$user_type,"index.php3",false);
// Ouverture de la connexion avec la base de donnees
$connection = openConnection($databaseName);
// *************** DECLARATION DES CONSTANTES **************
$first_time = "08:00:00";
$last_time = "20:00:00";
$first_time2 = 8;
$last_time2 = 20;
$jour_de_la_semaine = array("Lundi","Mardi","Mercredi","Jeudi","Vendredi","Samedi","Dimanche");
// *************** VERIFICATION DES DONNEES ***************
$request = "SELECT salle.numero, typesalle.libelle FROM salle,typesalle WHERE salle.id_salle = $id_salle AND typesalle.id_type_salle = salle.id_type_salle";
$result = mysql_query($request);
// *************** AUCUNE SALLE NE CORRESPOND AUX CRITERES DU FORMULAIRE ***************
if (mysql_num_rows($result) == 0)
print("<H3>Aucun étudiant ne correspond à ces critères</H3>\n");
// *************** L'ENSEIGNANT EXISTE ***************
else
{
$une_salle = mysql_fetch_row($result);
// Bouton pour acceder a l'emploi du temps de la semaine suivante et precedente + Titre
print("<FORM name=form1 ACTION=\"EmploiSalle.php3\">\n");
print(" <input type=\"hidden\" name=\"login\" value=\"$login\">\n");
print(" <input type=\"hidden\" name=\"id_session\" value=\"$id_session\">\n");
print(" <input type=\"hidden\" name=\"user_type\" value=\"$user_type\">\n");
print(" <input type=\"hidden\" name=\"user_id\" value=\"$user_id\">\n");
print(" <input type=\"hidden\" name=\"display\" value=\"$display\">\n");
print(" <input type=\"hidden\" name=\"ma_semaine\">\n");
print(" <input type=\"hidden\" name=\"id_salle\" value=$id_salle>\n");
print(" <table border=0 cellspacing=1 cellpading=0 align=center>\n");
print(" <tr valign=middle align=center>\n");
print(" <td width=40><input type=\"image\" border=0 src=\"../img/PreviousButton.gif\" alt=\"Précédent\" OnClick=\"ma_semaine.value=".($ma_semaine==1?52:$ma_semaine-1)."; submit();\"></td>\n");
print(" <td valign=middle><H3><I>$une_salle[1] $une_salle[0] - Semaine $ma_semaine</I></H3></td>\n");
print(" <td width=40><input type=\"image\" border=0 src=\"../img/NextButton.gif\" alt=\"Suivant\" OnClick=\"ma_semaine.value=".($ma_semaine==52?1:$ma_semaine+1)."; submit();\"></td>\n");
print(" </tr>\n");
print(" </table>\n");
print("</FORM>\n");
// *************** ASSOCIATION D'UNE COULEUR A CHAQUE MATIERE ***************
$color = array("00","66","99","FF");
$color_number = count($color);
$red=0;$blue=0;$green=0;
while ($une_matiere = mysql_fetch_row($result) )
{
$couleur_matiere[$une_matiere[0]] = $color[$red].$color[$green].$color[$blue];
if ($blue < $color_number - 1) $blue++;
else {
if ($green < $color_number - 1 ) {
$green++;
$blue = 0;
}
else {
if ($red < $color_number - 1) {
$red++;
$blue = 0;
$green = 0;
}
}
}
}
// *************** INFORMATION SUR LA DATE ***************
if ($ma_semaine<36) $result = mysql_query("SELECT TO_DAYS('2001-01-01')");
else $result = mysql_query("SELECT TO_DAYS('2000-01-01')");
$a_record = mysql_fetch_row($result);
$jour_ref = $a_record[0];
if ($ma_semaine<36) $result = mysql_query("SELECT DAYOFWEEK('2001-01-01')");
else $result = mysql_query("SELECT DAYOFWEEK('2000-01-01')");
$a_record = mysql_fetch_row($result);
$sem_actu = $jour_ref+($ma_semaine-1)*7+($a_record[0]>2?9-$a_record[0]:2-$a_record[0]);
// *************** DEBUT DE L'EMPLOI DU TEMPS ***************
print("<TABLE ALIGN=\"center\" CELLSPACING=\"0\" class=\"emploi\">\n");
// *************** INSERTION DE LA BARRE DES HEURES DU DEBUT ***************
barre_des_heures($first_time2,$last_time2,7.0);
barre_du_bas($first_time2,$last_time2,5.0);
// *************** PARCOURS DES DIFFERENTS JOURS DE LA SEMAINE ***************
for ($index = 0;$index < 6;$index++)
{
// *************** INSERTION DE LA BARRE DES HEURES INTERMEDIAIRE ***************
if ($index == 2 || $index == 4)
{
barre_du_haut($first_time2,$last_time2,5.0);
barre_des_heures($first_time2,$last_time2,7.0);
barre_du_bas($first_time2,$last_time2,5.0);
}
// *************** MISE A JOUR DE LA FIN DU COURS PRECEDENT ***************
$fin_cours_precedent = $first_time;
// *************** INSERTION DES INFORMATIONS DANS LA PREMIERE CELLULE ***************
$premier = mysql_query("SELECT FROM_DAYS($sem_actu)",$connection);
$result_prem = mysql_fetch_row($premier);
$essai = transformation_date($sem_actu);
print("<TR ALIGN=\"CENTER\" class=\"emploi\"");
print("<TD COLSPAN=\"2\" class=\"joursemaine\">\n");
print("$jour_de_la_semaine[$index] $essai");
print("</TD>\n");
// *************** REQUETE SUR LA BASE ***************
$request = "SELECT distinct(p.id_planifie), p.jour_semaine, p.heure_debut, p.heure_fin, p.id_matiere, m.nom, t.type, p.id_professeur, pr.sigle
FROM planifie p, matiere m, typeseance t, suiviparpromotion sp, suivipargroupe sg, associer a,promotion pr
WHERE
p.jour_semaine = ".($index+1)." AND p.semaine = $ma_semaine
AND p.id_salle = $id_salle
AND m.id_matiere = p.id_matiere
AND
((sp.id_matiere = p.id_matiere
AND pr.id_promotion = sp.id_promotion)
OR
(sg.id_matiere = p.id_matiere
AND a.id_groupe = sg.id_groupe
AND pr.id_promotion = a.id_promotion))
AND (t.id_type_seance = p.id_type_seance OR p.id_type_seance = -1)
ORDER BY p.heure_debut";
$result = mysql_query($request);
// Nombre de cours programmes dans la journee
$nb = mysql_num_rows($result);
// Y a-t-il des cours de programmer dans la journee ?
if ($nb == 0)
{
$found = false;
$requete_jours_feries = mysql_query("SELECT * FROM joursferies");
// *************** ON PARCOURT LA LISTE DES JOURS FERIES ***************
while($un_jour = mysql_fetch_row($requete_jours_feries))
{
$req_jour_debut=mysql_query("SELECT to_days(\"$un_jour[0]\")");
$req_jour_fin=mysql_query("SELECT to_days(\"$un_jour[1]\")");
$trans1=mysql_fetch_row($req_jour_debut);
$trans2=mysql_fetch_row($req_jour_fin);
if($sem_actu>=$trans1[0] && $sem_actu<=$trans2[0])
{
print("<TD COLSPAN=48 ALIGN=CENTER STYLE='font-family=\"verdana\";height:$hauteur_cellule pt;border:solid windowtext 1.0 ;padding:0cm 3.5pt 0cm 3.5pt'><B>$un_jour[2]</B></TD>");
$found = true;
break;
}
}
// *************** CE N'EST PAS UN JOUR FERIE ***************
if ($found) print("<TD ALIGN=CENTER COLSPAN=48 STYLE='height:$hauteur_cellule pt'></td>");
}
// *************** IL Y A AU MOINS UN COURS ***************
else
{
$fin_cours_precedent = $first_time;
// *************** PARCOURS DE LA LISTE DES COURS ***************
while ($un_cours = mysql_fetch_row($result))
{
// *************** HEURE ET MINUTE DU DEBUT DU PROCHAIN COURS ***************
$h = explode(":",$un_cours[2]);
$debut_cours_heure = $h[0];
$debut_cours_minute = $h[1];
// *************** HEURE ET MINUTE DE LA FIN DU PROCHAIN COURS ***************
$h = explode(":",$un_cours[3]);
$fin_cours_heure=$h[0];
$fin_cours_minute=$h[1];
// *************** HEURE ET MINUTE DE LA FIN DU COURS PRECEDENT ***************
$h = explode(":",$fin_cours_precedent);
$fin_cours_precedent_heure = $h[0];
$fin_cours_precedent_minute = $h[1];
// *************** MISE A JOUR DE LA FIN DU COURS PRECEDENT ***************
$fin_cours_precedent = $un_cours[3];
// *************** LE PROCHAIN COURS NE COINCIDE PAS AVEC LA FIN DU PRECEDENT ***************
if ($debut_cours_heure != $fin_cours_precedent_heure || $debut_cours_minute != $fin_cours_precedent_minute)
{
$intervalle_heure = $debut_cours_heure - $fin_cours_precedent_heure;
$intervalle_minute = $debut_cours_minute - $fin_cours_precedent_minute;
$taille_cellule_vide = $intervalle_heure*4 + $intervalle_minute / 15;
print("<TD COLSPAN=$taille_cellule_vide></TD>\n");
}
// *************** DETERMINATION DE LA TAILLE DE LA CELLULE DU COURS ***************
$taille_cellule = ($fin_cours_heure-$debut_cours_heure)*4+($fin_cours_minute-$debut_cours_minute)/60*4;
// *************** DETERMINATION DE LA COULEUR DE LA MATIERE ***************
$color = $couleur_matiere[$un_cours[4]];
// *************** INSCRIPTION DES INFORMATIONS DU COURS DANS LA CELLULE ***************
if ($un_cours[6] == "Examen") print("<TD COLSPAN=$taille_cellule BGCOLOR=\"#FF6666\" STYLE='color=\"#$color\" ; border:solid windowtext 1.0'>");
else print("<TD COLSPAN=$taille_cellule STYLE='color=\"#$color\" ; border:solid windowtext 1.0'>");
print("$un_cours[5] - $un_cours[6]<BR>$un_cours[8]");
// Un professeur est associe a ce cours
/* if ($un_cours[7] != -1)
{
$request = "SELECT initiales FROM professeur WHERE id_professeur = ".$un_cours[7];
$result_professeur = mysql_query($request);
$un_prof = mysql_fetch_row($result_professeur);
print("<BR>$un_prof[0]");
} */
print("</TD>\n");
}
}
// *************** ON PASSE AU JOUR SUIVANT ***************
$sem_actu++;
print("</TR>\n");
}
// *************** INSERTION DE LA BARRE DES HEURES DE LA FIN ***************
barre_du_haut($first_time2,$last_time2,5.0);
barre_des_heures($first_time2,$last_time2,7.0);
}
print("</TABLE>\n");
}
buildEndOfPage();
?>