1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162
| /* On récupère si elle existe la valeur de la catégorie envoyée par le formulaire */
$serveur = "localhost";
$admin = "root";
$mdp = "";
$facevspile = "facevspile";
$idr = isset($_POST['libelle'])?$_POST['libelle']:null;
$ids = isset($_POST['libel'])?$_POST['libel']:null;
?>
<?php
if(isset($_POST['ok']) && isset($_POST['libel']) && $_POST['libel'] != "" && isset($_POST['lib']) && $_POST['lib'] != "")
{
$region_selectionnee = $_POST['libelle'];
$dept_selectionne = $_POST['libel'];
$ter_selectionne = $_POST['lib'];
?>
<p>Vous avez sélectionné la catégorie tertiaire <?php echo($ter_selectionne) ?> dans la catégorie secondaire <?php echo($dept_selectionne); ?> dans la catégorie principale <?php echo($region_selectionnee); ?></p>
<?php
}
?>
<?php
/* On établit la connexion à MySQL avec mysql_pconnect() plutôt qu'avec mysql_connect()
* car on aura besoin de la connexion un peu plus loin dans le script */
$connexion = mysql_pconnect($serveur, $admin, $mdp);
if($connexion != false)
{
$choixbase = mysql_select_db($database_facevspile, $connexion);
$sql1 = "SELECT `id`, `libelle`".
" FROM `shop_categories`".
" ORDER BY `id`";
$rech_regions = mysql_query($sql1);
$code_region = array();
$region = array();
/* On active un compteur pour les régions */
$nb_regions = 0;
if($rech_regions != false)
{
while($ligne = mysql_fetch_assoc($rech_regions))
{
array_push($code_region, $ligne['id']);
array_push($region, $ligne['libelle']);
/* On incrémente de compteur */
$nb_regions++;
}
}
?>
<form action="<?php echo htmlspecialchars($_SERVER['PHP_SELF']); ?>" method="post" id="chgdept">
<fieldset style="border: 3px double #333399">
<legend>Sélectionnez une catégorie</legend>
<select name="libelle" id="libelle" onchange="document.forms['chgdept'].submit();">
<option value="-1">- - - Choisissez une catégorie - - -</option>
<?php
for($i = 0; $i < $nb_regions; $i++)
{
?>
<option value="<?php echo($code_region[$i]); ?>"<?php echo((isset($idr) && $idr == $code_region[$i])?" selected=\"selected\"":null); ?>><?php echo($region[$i]); ?></option>
<?php
}
?>
</select>
<?php
mysql_free_result($rech_regions);
/* On commence par vérifier si on a envoyé un numéro de catégorie et le cas échéant s'il est différent de -1 */
if(isset($idr) && $idr != -1)
{
/* Création de la requête pour avoir la catégorie secondaire de cette catégorie */
$sql2 = "SELECT `id`, `libel`".
" FROM `shop_s_categorie`".
" WHERE `grandpere` = ". $idr ."".
" ORDER BY `id`;";
if($connexion != false)
{
$rech_dept = mysql_query($sql2, $connexion);
/* Un petit compteur pour les départements */
$nd = 0;
/* On crée deux tableaux pour les numéros et les noms des départements */
$code_dept = array();
$nom_dept = array();
/* On va mettre les numéros et noms des départements dans les deux tableaux */
while($ligne_dept = mysql_fetch_assoc($rech_dept))
{
array_push($code_dept, $ligne_dept['id']);
array_push($nom_dept, $ligne_dept['libel']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<form action="<?php echo htmlspecialchars($_SERVER['PHP_SELF']); ?>" method="post" id="ter"> <select name="libel" id="libel" onchange="document.forms['ter'].submit();">
<option value="-1">- - - Choisissez une catégorie - - -</option>
<?php
for($d = 0; $d<$nd; $d++)
{
?>
<option value="<?php echo($code_dept[$d]); ?>"<?php echo((isset($ids) && $ids == $code_dept[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_dept[$d]); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_dept);
/* On commence par vérifier si on a envoyé un numéro de catégorie et le cas échéant s'il est différent de -1 */
if(isset($ids) && $ids != -1)
{
/* Création de la requête pour avoir la catégorie secondaire de cette catégorie */
$sql3 = "SELECT `id`, `lib`".
" FROM `shop_ss_categorie`".
" WHERE `pere` = ". $ids ."".
" ORDER BY `id`;";
if($connexion != false)
{
$rech_ter = mysql_query($sql3, $connexion);
/* Un petit compteur pour les départements */
$ne = 0;
/* On crée deux tableaux pour les numéros et les noms des départements */
$code_ter = array();
$nom_ter = array();
/* On va mettre les numéros et noms des départements dans les deux tableaux */
while($ligne_ter = mysql_fetch_assoc($rech_ter))
{
array_push($code_ter, $ligne_ter['id']);
array_push($nom_ter, $ligne_ter['lib']);
$ne++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="lib" id="lib">
<?php
for($e = 0; $e<$ne; $e++)
{
?>
<option value="<?php echo($code_ter[$e]); ?>"<?php echo((isset($ter_selectionne) && $ter_selectionne == $code_ter[$e])?" selected=\"selected\"":null); ?>><?php echo($nom_ter[$e]." (". $code_ter[$e] .")"); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_ter);
}
?>
<br /><input type="submit" name="ok" id="ok" value="Envoyer" />
</fieldset>
</form>
<?php
/* Terminé, on ferme la connexion */
mysql_close($connexion);
}
else
{
/* Si on arrive là, c'est pas bon signe, il faut vérifier les
* paramètres de connexion, mot de passe, serveur pas démarré etc... */
?>
<p>Un incident s'est produit lors de la connexion à la base de données, veuillez essayer à nouveau ultérieurement.</p>
<?php
}
?> |
Partager