<?php
// +-------------------------------------------------+
// © 2002-2004 PMB Services / www.sigb.net pmb@sigb.net et contributeurs (voir www.sigb.net)
// +-------------------------------------------------+
// $Id: docs_statut.class.php,v 1.7 2015-04-03 11:16:20 jpermanne Exp $

if (stristr($_SERVER['REQUEST_URI'], ".class.php")) die("no access");

// définition de la classe de gestion des 'docs_statut'

if ( ! defined( 'DOCSSTATUT_CLASS' ) ) {
  define( 'DOCSSTATUT_CLASS', 1 );

class docs_statut {

/* ---------------------------------------------------------------
		propriétés de la classe
   --------------------------------------------------------------- */

var $id=0;
var $libelle='';
var $pret_flag='';
var $statusdoc_codage_import="";
var $statusdoc_owner=0;

/* ---------------------------------------------------------------
		docs_statut($id) : constructeur
   --------------------------------------------------------------- */
function docs_statut($id=0) {
	if($id) {
		/* on cherche à atteindre un statut existant */
		$this->id = $id;
		$this->getData();
		} else {
			$this->id = 0;
			$this->getData();
			}
	}

/* ---------------------------------------------------------------
		getData() : récupération des propriétés
   --------------------------------------------------------------- */
function getData() {
	global $dbh;

	if(!$this->id) return;

	/* récupération des informations du statut */

	$requete = 'SELECT * FROM docs_statut WHERE idstatut='.$this->id.' LIMIT 1;';
	$result = @pmb_mysql_query($requete, $dbh);
	if(!pmb_mysql_num_rows($result)) return;
		
	$data = pmb_mysql_fetch_object($result);
	$this->id = $data->idstatut;		
	$this->libelle = $data->statut_libelle;
	$this->pret_flag = $data->pret_flag;
	$this->statusdoc_codage_import = $data->statusdoc_codage_import;
	$this->statusdoc_owner = $data->statusdoc_owner;
	}

// ---------------------------------------------------------------
//		import() : import d'un statut de document
// ---------------------------------------------------------------
function import($data) {

	// cette méthode prend en entrée un tableau constitué des informations suivantes :
	//	$data['statut_libelle'] 	
	//	$data['pret_flag']
	//	$data['statusdoc_codage_import']
	//	$data['statusdoc_owner']

	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 = pmb_mysql_field_len(pmb_mysql_query("SELECT statut_libelle FROM docs_statut limit 1"),0);
	$data['statut_libelle'] = rtrim(substr(preg_replace('/\[|\]/', '', rtrim(ltrim($data['statut_libelle']))),0,$long_maxi));
	$long_maxi = pmb_mysql_field_len(pmb_mysql_query("SELECT statusdoc_codage_import FROM docs_statut limit 1"),0);
	$data['statusdoc_codage_import'] = rtrim(substr(preg_replace('/\[|\]/', '', rtrim(ltrim($data['statusdoc_codage_import']))),0,$long_maxi));

	if($data['statusdoc_owner']=="") $data['statusdoc_owner'] = 0;
	if($data['statut_libelle']=="") return 0;
	/* statusdoc_codage_import est obligatoire si statusdoc_owner != 0 */
	if(($data['statusdoc_owner']!=0) && ($data['statusdoc_codage_import']=="")) return 0;
	
	// préparation de la requête
	$key0 = addslashes($data['statut_libelle']);
	$key1 = addslashes($data['statusdoc_codage_import']);
	$key2 = $data['statusdoc_owner'];
	
	/* vérification que le statut existe */
	$query = "SELECT idstatut FROM docs_statut WHERE statusdoc_codage_import='${key1}' and statusdoc_owner = '${key2}' LIMIT 1 ";
	$result = @pmb_mysql_query($query, $dbh);
	if(!$result) die("can't SELECT docs_statut ".$query);
	$docs_statut  = pmb_mysql_fetch_object($result);

	/* le statut de doc existe, on retourne l'ID */
	if($docs_statut->idstatut) return $docs_statut->idstatut;

	// id non-récupérée, il faut créer la forme.
	/* une petite valeur par défaut */
	if ($data['pret_flag']=="") $data['pret_flag']=1;
	
	$query  = "INSERT INTO docs_statut SET ";
	$query .= "statut_libelle='".$key0."', ";
	$query .= "pret_flag='".$data['pret_flag']."', ";
	$query .= "statusdoc_codage_import='".$key1."', ";
	$query .= "statusdoc_owner='".$key2."' ";
	$result = @pmb_mysql_query($query, $dbh);
	if(!$result) die("can't INSERT into docs_statut ".$query);

	return pmb_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 */

static function gen_combo_box ( $selected ) {

	global $msg;

	$requete="select idstatut, statut_libelle from docs_statut order by statut_libelle ";
	$champ_code="idstatut";
	$champ_info="statut_libelle";
	$nom="book_statut_id";
	$on_change="";
	$liste_vide_code="0";
	$liste_vide_info=$msg['class_statut'];
	$option_premier_code="";
	$option_premier_info="";
	$gen_liste_str="";
	$resultat_liste=pmb_mysql_query($requete);
	$gen_liste_str = "<select name=\"$nom\" onChange=\"$on_change\">\n" ;
	$nb_liste=pmb_mysql_num_rows($resultat_liste);
	if ($nb_liste==0) {
		$gen_liste_str.="<option value=\"$liste_vide_code\">$liste_vide_info</option>\n" ;
		} else {
			if ($option_premier_info!="") {	
				$gen_liste_str.="<option value=\"".$option_premier_code."\" ";
				if ($selected==$option_premier_code) $gen_liste_str.="selected" ;
				$gen_liste_str.=">".$option_premier_info."\n";
				}
			$i=0;
			while ($i<$nb_liste) {
				$gen_liste_str.="<option value=\"".pmb_mysql_result($resultat_liste,$i,$champ_code)."\" " ;
				if ($selected==pmb_mysql_result($resultat_liste,$i,$champ_code)) {
					$gen_liste_str.="selected" ;
					}
				$gen_liste_str.=">".pmb_mysql_result($resultat_liste,$i,$champ_info)."</option>\n" ;
				$i++;
				}
			}
	$gen_liste_str.="</select>\n" ;
	return $gen_liste_str ;
	} /* fin gen_combo_box */



} /* fin de définition de la classe */

} /* fin de délaration */


