Subversion Repositories Applications.gtt

Compare Revisions

Ignore whitespace Rev 4 → Rev 5

/trunk/classes_metier/gtt_preference.class.php
26,77 → 26,63
 
class Preference
{
var $_utilisateur=null;
var $_projet =null;
/**
*constructeur
*/
function Preference($u,$p)
{
$this->_utilisateur=$u;
$this->_projet=$p;
}
/**
*enregistrer une preference dans la base de donnees
*@return 1 si ok
*@return 0 si aucun enregistrement effectue
*@return -1 si erreur
*/
function enregistrerPreference()
{
$table=GEST_PREFERENCES;
$champs =array(
GEST_CHAMPS_ID_UTILISATEUR =>$this->_utilisateur,
GEST_CHAMPS_ID_PROJET =>$this->_projet);
private $table = 'gestion_preferences';
private $id_utilisateur = null;
private $id_projet = null;
/*** Constructeur */
function Preference($u, $p)
{
$this->_utilisateur = $u;
$this->_projet = $p;
}
/**
* Ajouter une préférence dans la base de données.
*@return true si ok, false si aucun enregistrement effectué
*/
function ajouter()
{
$requete = 'INSERT INTO gestion_preferences (gp_id_utilisateur, gp_id_projet) '.
'VALUES ('.$this->id_utilisateur.', '.$this->id_projet.')';
$resultat = $GLOBALS['db']->query($requete);
$resultat = $GLOBALS['db']->autoExecute($table,$champs,DB_AUTOQUERY_INSERT);
if (DB::isError($resultat)) {
die($resultat->getMessage());
}
$j=$GLOBALS['db']->affectedRows();
if ($j==1)
{
return 1;
}elseif($j==0){
return 0;
}else{
return -1;
}
}
/**
*recuperer la liste de preferences d'un utilisateur
*@param identifiant utilisateur
*/
function recupererTableauPreferences()
{
$table=array();
$requete="SELECT P.".GEST_CHAMPS_ID_PROJET.", P.".GEST_CHAMPS_NOM_PROJET." ,C.".GEST_CHAMPS_ID_CATEGORIE.",C.".GEST_CHAMPS_LIBELLE_CATEGORIE.
" FROM ".GEST_PREFERENCES." F, ".GEST_PROJET." P,".GEST_CATEGORIE." C".
" WHERE ".GEST_CHAMPS_ID_UTILISATEUR. " = $this->_utilisateur".
" AND F.".GEST_CHAMPS_ID_PROJET." = P.".GEST_CHAMPS_ID_PROJET.
" AND P.".GEST_CHAMPS_ID_CATEGORIE." = C.".GEST_CHAMPS_ID_CATEGORIE.
" ORDER BY ".GEST_CHAMPS_LIBELLE_CATEGORIE;
$resultat = $GLOBALS['db']->query($requete);
(DB::isError($resultat)) ? die (BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '' ;
if (DB::isError($resultat)) {
die($resultat->getMessage());
}
$nbre_enregistrement_ajoute = $GLOBALS['db']->affectedRows();
if ($nbre_enregistrement_ajoute == 1) {
return true;
} elseif ($nbre_enregistrement_ajoute == 0) {
return false;
}
}
 
/**
* Récupérer la liste de préférences d'un utilisateur.
*@param identifiant utilisateur.
*/
function recupererTableauPreferences()
{
$table = array();
$requete = "SELECT P.".GEST_CHAMPS_ID_PROJET.", P.".GEST_CHAMPS_NOM_PROJET." ,C.".GEST_CHAMPS_ID_CATEGORIE.",C.".GEST_CHAMPS_LIBELLE_CATEGORIE.
" FROM ".GEST_PREFERENCES." F, ".GEST_PROJET." P,".GEST_CATEGORIE." C".
" WHERE ".GEST_CHAMPS_ID_UTILISATEUR. " = $this->_utilisateur".
" AND F.".GEST_CHAMPS_ID_PROJET." = P.".GEST_CHAMPS_ID_PROJET.
" AND P.".GEST_CHAMPS_ID_CATEGORIE." = C.".GEST_CHAMPS_ID_CATEGORIE.
" ORDER BY ".GEST_CHAMPS_LIBELLE_CATEGORIE;
$resultat = $GLOBALS['db']->query($requete);
(DB::isError($resultat)) ? die (BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '' ;
while ( $ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) {
$case = array('id_proj' => $ligne[GEST_CHAMPS_ID_PROJET], 'nom_proj' => $ligne[GEST_CHAMPS_NOM_PROJET],'id_cat' => $ligne[GEST_CHAMPS_ID_CATEGORIE], 'libelle_cat' => $ligne[GEST_CHAMPS_LIBELLE_CATEGORIE]);
array_push($table, $case);
}
return $table;
}
while($ligne=$resultat->fetchRow(DB_FETCHMODE_ASSOC))
{
$case=array('id_proj'=>$ligne[GEST_CHAMPS_ID_PROJET],'nom_proj'=>$ligne[GEST_CHAMPS_NOM_PROJET],'id_cat'=>$ligne[GEST_CHAMPS_ID_CATEGORIE],'libelle_cat'=>$ligne[GEST_CHAMPS_LIBELLE_CATEGORIE]);
array_push($table,$case);
}
return $table;
}
/**
*supprimer liste de preferences
*pour un utilisateur donne
103,54 → 89,45
*@param identifiant d'un utilisateur
*/
function supprimerPreferences($id)
{
$requete="DELETE FROM ".GEST_PREFERENCES.
" WHERE ".GEST_CHAMPS_ID_UTILISATEUR. " =$id ";
$resultat = $GLOBALS['db']->query($requete);
$j=$GLOBALS['db']->affectedRows();
return $j;
}
/**
*fonction renvoyant vrai si un projet est dans la liste de preference d'un utilisateur
*$id : identifiant du projet a chercher
@return true : si existe
@return false si n'existe pas
*/
function isInPreferences($id)
{
$tab=$this->recupererTableauPreferences();
$res=false;
for ($r=0; $r<count($tab);$r++)
function supprimerPreferences($id)
{
$t=$tab[$r];
if ($t['id_proj']==$id)
{
$res=true;
}
}
return $res;
}
/**
*afficher preferences
*/
function afficherPreference()
{
echo "<br /> preferences <br />";
$u= array($this->_utilisateur,$this->_projet);
foreach ($u as $p)
{
echo "$p , ";
}
echo "<br /> ";
}
$requete = 'DELETE FROM '.GEST_PREFERENCES.' '.
'WHERE '.GEST_CHAMPS_ID_UTILISATEUR.' = '.$id;
$resultat = $GLOBALS['db']->query($requete);
return $GLOBALS['db']->affectedRows();
}
/**
* Méthode renvoyant vrai si un projet est dans la liste de préférence d'un utilisateur.
*$id : identifiant du projet a chercher
*@return true : si existe
*@return false si n'existe pas
*/
function isInPreferences($id)
{
$tab = $this->recupererTableauPreferences();
$res = false;
for ($r = 0; $r < count($tab); $r++) {
$t = $tab[$r];
if ($t['id_proj'] == $id) {
$res = true;
}
}
return $res;
}
/**
* Afficher préférences
*/
function afficherPreference()
{
echo "<br /> preferences <br />";
$u= array($this->_utilisateur,$this->_projet);
foreach ($u as $p) {
echo "$p , ";
}
echo "<br /> ";
}
}
?>