orinot_id = $id; $this->getData(); } else { $this->orinot_id = 0; $this->getData(); } } /* --------------------------------------------------------------- getData() : récupération des propriétés --------------------------------------------------------------- */ function getData() { global $dbh; if(!$this->orinot_id) return; /* récupération des informations du statut */ $requete = 'SELECT orinot_id, orinot_nom, orinot_pays, orinot_diffusion FROM origine_notice WHERE orinot_id='.$this->orinot_id.' '; $result = @mysql_query($requete, $dbh); if(!mysql_num_rows($result)) return; $data = mysql_fetch_object($result); $this->orinot_nom = $data->orinot_nom; $this->orinot_pays = $data->orinot_pays; $this->orinot_diffusion = $data->orinot_diffusion; } // --------------------------------------------------------------- // import() : import d'un statut de document // --------------------------------------------------------------- function import($data) { // cette méthode prend en entrée un tableau constitué des informations suivantes : // $data['nom'] // $data['pays'] // $data['diffusion'] global $dbh; // check sur le type de la variable passée en paramètre if(!sizeof($data) || !is_array($data)) { // si ce n'est pas un tableau ou un tableau vide, on retourne 0 return 0; } // check sur les éléments du tableau $long_maxi = mysql_field_len(mysql_query("SELECT orinot_nom FROM origine_notice "),0); $data['nom'] = rtrim(substr(preg_replace('/\[|\]/', '', rtrim(ltrim($data['nom']))),0,$long_maxi)); $long_maxi = mysql_field_len(mysql_query("SELECT orinot_pays FROM origine_notice "),0); $data['pays'] = rtrim(substr(preg_replace('/\[|\]/', '', rtrim(ltrim($data['pays']))),0,$long_maxi)); if($data['diffusion']=="") $data['diffusion'] = 1; if($data['nom']=="") return 0; // préparation de la requête $key0 = addslashes($data['nom']); $key1 = addslashes($data['pays']); $key2 = $data['diffusion']; /* vérification que le statut existe */ $query = "SELECT orinot_id FROM origine_notice WHERE orinot_nom='${key0}' and orinot_pays = '${key1}' LIMIT 1 "; $result = @mysql_query($query, $dbh); if(!$result) die("can't SELECT origine_notice ".$query); $origine_notice = mysql_fetch_object($result); /* le statut de doc existe, on retourne l'ID */ if($origine_notice->orinot_id) return $origine_notice->orinot_id; // id non-récupérée, il faut créer la forme. $query = "INSERT INTO origine_notice SET "; $query .= "orinot_nom='".$key0."', "; $query .= "orinot_pays='".$key1."', "; $query .= "orinot_diffusion='".$key2."' "; $result = @mysql_query($query, $dbh); if(!$result) die("can't INSERT into origine_notice ".$query); return mysql_insert_id($dbh); } /* fin méthode import */ /* une fonction pour générer des combo Box paramêtres : $selected : l'élément sélectioné le cas échéant retourne une chaine de caractères contenant l'objet complet */ function gen_combo_box ( $selected ) { $requete="select orinot_id, orinot_nom, orinot_pays from origine_notice order by orinot_nom, orinot_pays "; $champ_code="orinot_id"; $champ_info="orinot_nom"; $nom="orinot_id"; $on_change=""; $liste_vide_code=""; $liste_vide_info=""; $option_premier_code=""; $option_premier_info=""; $gen_liste_str=""; $resultat_liste=mysql_query($requete); $gen_liste_str = "\n" ; return $gen_liste_str ; } /* fin gen_combo_box */ } /* fin de définition de la classe */ } /* fin de délaration */