From 017a7fabcdd2211a85025b2e56dffcd1759c25a2 Mon Sep 17 00:00:00 2001 From: Laurent Destailleur Date: Thu, 29 Nov 2007 01:19:23 +0000 Subject: [PATCH] Fix: Fonction de conversion des accents plus propre --- htdocs/lib/functions.inc.php | 499 +++++++++++---------- htdocs/user/modules/login.anakin.class.php | 209 ++++----- 2 files changed, 366 insertions(+), 342 deletions(-) diff --git a/htdocs/lib/functions.inc.php b/htdocs/lib/functions.inc.php index c7879f879ab..0b0d8e43b37 100644 --- a/htdocs/lib/functions.inc.php +++ b/htdocs/lib/functions.inc.php @@ -38,7 +38,7 @@ Ensemble de fonctions de base de dolibarr sous forme d'include */ -// Pour compatibilit� lors de l'upgrade +// Pour compatibilité lors de l'upgrade if (! defined('DOL_DOCUMENT_ROOT')) { define('DOL_DOCUMENT_ROOT', '..'); @@ -114,7 +114,7 @@ function ValidEmail($address) } /** - \brief Renvoi vrai si l'email a un nom de domaine qui r�soud via dns + \brief Renvoi vrai si l'email a un nom de domaine qui résoud via dns \param mail adresse email (Ex: "toto@titi.com", "John Do ") \return boolean true si email valide, false sinon */ @@ -132,22 +132,36 @@ function check_mail ($mail) } /** - \brief Nettoie chaine de caract�re des accents - \param str Chaine a nettoyer - \return string Chaine nettoy� + \brief Nettoie chaine de caractere iso des accents + \param str Chaine a nettoyer + \return string Chaine nettoyee */ -function unaccent($str) +function unaccent_isostring($str) { - $acc = array("�","�","�","�","�","�","�","�","�","�","�","'"); - $uac = array("a","a","e","e","e","i","i","o","o","u","u",""); + $translation = array( + "\xE0" => "a", + "\xE1" => "a", + "\xE2" => "a", + "\xE8" => "e", + "\xE9" => "e", + "\xEA" => "e", + "\xEB" => "e", + "\xEE" => "i", + "\xEF" => "i", + "\xF4" => "o", + "\xF6" => "o", + "\xFB" => "u", + "\xFC" => "u" + ); - return str_replace($acc, $uac, $str); + return str_replace(array_keys($translation), array_values($translation), $str); } /** - \brief Nettoie chaine de caract�re de caract�res sp�ciaux + \brief Nettoie chaine de caractere de caracteres speciaux + \remarks Fonction appelee par exemple pour definir un nom de fichier depuis un identifiant chaine libre \param str Chaine a nettoyer - \return string Chaine nettoy� + \return string Chaine nettoyee (A-Z_) */ function sanitize_string($str) { @@ -160,15 +174,15 @@ function sanitize_string($str) /** \brief Envoi des messages dolibarr dans un fichier ou dans syslog - Pour fichier: fichier d�fini par SYSLOG_FILE - Pour syslog: facility d�fini par SYSLOG_FACILITY + Pour fichier: fichier défini par SYSLOG_FILE + Pour syslog: facility défini par SYSLOG_FACILITY \param message Message a tracer. Ne doit pas etre traduit si level = LOG_ERR \param level Niveau de l'erreur - \remarks Cette fonction n'a un effet que si le module syslog est activ�. - Warning, les fonctions syslog sont buggu�s sous Windows et g�n�rent des - fautes de protection m�moire. Pour r�soudre, utiliser le loggage fichier, + \remarks Cette fonction n'a un effet que si le module syslog est activé. + Warning, les fonctions syslog sont buggués sous Windows et générent des + fautes de protection mémoire. Pour résoudre, utiliser le loggage fichier, au lieu du loggage syslog (configuration du module). - Si SYSLOG_FILE_NO_ERROR d�fini, on ne g�re pas erreur ecriture log + Si SYSLOG_FILE_NO_ERROR défini, on ne gére pas erreur ecriture log \remarks On Windows LOG_ERR=4, LOG_WARNING=5, LOG_NOTICE=LOG_INFO=LOG_DEBUG=6 On Linux LOG_ERR=3, LOG_WARNING=4, LOG_INFO=6, LOG_DEBUG=7 */ @@ -222,7 +236,7 @@ function dolibarr_syslog($message, $level=LOG_INFO) } else { - //define_syslog_variables(); d�j� d�finit dans master.inc.php + //define_syslog_variables(); déja définit dans master.inc.php if (defined("MAIN_SYSLOG_FACILITY") && MAIN_SYSLOG_FACILITY) { $facility = MAIN_SYSLOG_FACILITY; @@ -304,9 +318,9 @@ function dolibarr_fiche_head($links, $active='0', $title='', $notab=0) } /** - \brief R�cup�re une constante depuis la base de donn�es. + \brief Récupére une constante depuis la base de données. \see dolibarr_del_const, dolibarr_set_const - \param db Handler d'acc�s base + \param db Handler d'accés base \param name Nom de la constante \return string Valeur de la constante */ @@ -328,13 +342,13 @@ function dolibarr_get_const($db, $name) /** - \brief Insertion d'une constante dans la base de donn�es. + \brief Insertion d'une constante dans la base de données. \see dolibarr_del_const, dolibarr_get_const - \param db Handler d'acc�s base + \param db Handler d'accés base \param name Nom de la constante \param value Valeur de la constante - \param type Type de constante (chaine par d�faut) - \param visible La constante est elle visible (0 par d�faut) + \param type Type de constante (chaine par défaut) + \param visible La constante est elle visible (0 par défaut) \param note Explication de la constante \return int <0 si ko, >0 si ok */ @@ -372,9 +386,9 @@ function dolibarr_set_const($db, $name, $value, $type='chaine', $visible=0, $not } /** - \brief Effacement d'une constante dans la base de donn�es + \brief Effacement d'une constante dans la base de données \see dolibarr_get_const, dolibarr_sel_const - \param db Handler d'acc�s base + \param db Handler d'accés base \param name Nom ou rowid de la constante \return int <0 si ko, >0 si ok */ @@ -399,11 +413,11 @@ function dolibarr_del_const($db, $name) /** \brief Sauvegarde parametrage personnel - \param db Handler d'acc�s base + \param db Handler d'accés base \param user Objet utilisateur - \param url Si defini, on sauve parametre du tableau tab dont cl� = (url avec sortfield, sortorder, begin et page) + \param url Si defini, on sauve parametre du tableau tab dont clé = (url avec sortfield, sortorder, begin et page) Si non defini on sauve tous parametres du tableau tab - \param tab Tableau (cl�=>valeur) des param�tres � sauvegarder + \param tab Tableau (clé=>valeur) des paramétres a sauvegarder \return int <0 si ko, >0 si ok */ function dolibarr_set_user_page_param($db, &$user, $url='', $tab) @@ -413,7 +427,7 @@ function dolibarr_set_user_page_param($db, &$user, $url='', $tab) $db->begin(); - // On efface anciens param�tres pour toutes les cl� dans $tab + // On efface anciens paramétres pour toutes les clé dans $tab $sql = "DELETE FROM ".MAIN_DB_PREFIX."user_param"; $sql.= " WHERE fk_user = ".$user->id; if ($url) $sql.=" AND page='".$url."'"; @@ -439,7 +453,7 @@ function dolibarr_set_user_page_param($db, &$user, $url='', $tab) foreach ($tab as $key => $value) { - // On positionne nouveaux param�tres + // On positionne nouveaux paramétres if ($value && (! $url || in_array($key,array('sortfield','sortorder','begin','page')))) { $sql = "INSERT INTO ".MAIN_DB_PREFIX."user_param(fk_user,page,param,value)"; @@ -469,7 +483,7 @@ function dolibarr_set_user_page_param($db, &$user, $url='', $tab) /** \brief Formattage des nombres \param ca valeur a formater - \return int valeur format�e + \return int valeur formatée */ function dolibarr_print_ca($ca) { @@ -497,10 +511,10 @@ function dolibarr_print_ca($ca) /** - \brief Effectue un d�calage de date par rapport � une dur�e + \brief Effectue un décalage de date par rapport a une durée \param time Date timestamp ou au format YYYY-MM-DD - \param duration_value Valeur de la dur�e � ajouter - \param duration_unit Unit� de la dur�e � ajouter (d, m, y) + \param duration_value Valeur de la durée a ajouter + \param duration_unit Unité de la durée a ajouter (d, m, y) \return int Nouveau timestamp */ function dolibarr_time_plus_duree($time,$duration_value,$duration_unit) @@ -523,13 +537,13 @@ function dolibarr_time_plus_duree($time,$duration_value,$duration_unit) "%d/%m/%Y %H:%M", "%d/%m/%Y %H:%M:%S", "day", "daytext", "dayhour", "dayhourldap", "dayhourtext" - \return string Date format�e ou '' si time null + \return string Date formatée ou '' si time null */ function dolibarr_print_date($time,$format='') { global $conf; - // Si format non d�fini, on prend $conf->format_date_text_short sinon %Y-%m-%d %H:%M:%S + // Si format non défini, on prend $conf->format_date_text_short sinon %Y-%m-%d %H:%M:%S if (! $format) $format=(isset($conf->format_date_text_short) ? $conf->format_date_text_short : '%Y-%m-%d %H:%M:%S'); if ($format == 'day') $format=$conf->format_date_short; @@ -564,8 +578,8 @@ function dolibarr_print_date($time,$format='') /** - \brief Retourne une date fabriqu�e depuis une chaine - \param string Date format�e en chaine + \brief Retourne une date fabriquée depuis une chaine + \param string Date formatée en chaine YYYYMMDD YYYYMMDDHHMMSS DD/MM/YY ou DD/MM/YYYY @@ -644,14 +658,14 @@ function dolibarr_getdate($timestamp,$fast=false) } /** - \brief Retourne une date fabriqu�e depuis infos. - Remplace la fonction mktime non impl�ment�e sous Windows si ann�e < 1970 + \brief Retourne une date fabriquée depuis infos. + Remplace la fonction mktime non implémentée sous Windows si année < 1970 \param hour Heure \param minute Minute \param second Seconde \param month Mois \param day Jour - \param year Ann�e + \param year Année \return timestamp Date en timestamp, '' if error \remarks PHP mktime is restricted to the years 1901-2038 on Unix and 1970-2038 on Windows */ @@ -674,7 +688,7 @@ function dolibarr_mktime($hour,$minute,$second,$month,$day,$year,$gm=0) { /* // On peut utiliser strtotime pour obtenir la traduction. - // strtotime is ok for range: Vendredi 13 D�cembre 1901 20:45:54 GMT au Mardi 19 Janvier 2038 03:14:07 GMT. + // strtotime is ok for range: Vendredi 13 Décembre 1901 20:45:54 GMT au Mardi 19 Janvier 2038 03:14:07 GMT. $montharray=array(1=>'january',2=>'february',3=>'march',4=>'april',5=>'may',6=>'june', 7=>'july',8=>'august',9=>'september',10=>'october',11=>'november',12=>'december'); $string=$day." ".$montharray[0+$month]." ".$year." ".$hour.":".$minute.":".$second." GMT"; @@ -758,10 +772,10 @@ function dolibarr_print_object_info($object) } /** - \brief Formatage des num�ros de telephone en fonction du format d'un pays - \param phone Num�ro de telephone � formater + \brief Formatage des numéros de telephone en fonction du format d'un pays + \param phone Numéro de telephone a formater \param country Pays selon lequel formatter - \return string Num�ro de t�l�phone format� + \return string Numéro de téléphone formaté */ function dolibarr_print_phone($phone,$country="FR") { @@ -794,7 +808,7 @@ function dolibarr_print_phone($phone,$country="FR") } /** - \brief Tronque une chaine � une taille donn�e en ajoutant les points de suspension si cela d�passe + \brief Tronque une chaine a une taille donnée en ajoutant les points de suspension si cela dépasse \param string String to truncate \param size Max string size. 0 for no limit. \param trunc Where to trunc: right, left, middle @@ -816,9 +830,14 @@ function dolibarr_trunc($string,$size=40,$trunc='right') } if ($trunc == 'middle') { - // \TODO A developper. - - return $string; + if (strlen($string) > 2 && strlen($string) > $size) + { + $size1=round($size/2); + $size2=round($size/2); + return substr($string,0,$size1).'...'.substr($string,strlen($string) - $size2,$size2); + } + else + return $string; } if ($trunc == 'left') { @@ -835,12 +854,12 @@ function dolibarr_trunc($string,$size=40,$trunc='right') } /** - \brief Compl�te une chaine � une taille donn�e par des espaces - \param string Chaine � compl�ter + \brief Compléte une chaine a une taille donnée par des espaces + \param string Chaine a compléter \param size Longueur de la chaine. - \param side 0=Compl�tion � droite, 1=Compl�tion � gauche - \param char Chaine de compl�tion - \return string Chaine compl�t�e + \param side 0=Complétion a droite, 1=Complétion a gauche + \param char Chaine de complétion + \return string Chaine complétée */ function dolibarr_pad($string,$size,$side,$char=' ') { @@ -856,7 +875,7 @@ function dolibarr_pad($string,$size,$side,$char=' ') } /** - \brief Affiche picto propre � une notion/module (fonction g�n�rique) + \brief Affiche picto propre a une notion/module (fonction générique) \param alt Texte sur le alt de l'image \param object Objet pour lequel il faut afficher le logo (exemple: user, group, action, bill, contract, propal, product, ...) \return string Retourne tag img @@ -868,10 +887,10 @@ function img_object($alt, $object) } /** - \brief Affiche picto (fonction g�n�rique) + \brief Affiche picto (fonction générique) \param alt Texte sur le alt de l'image \param picto Nom de l'image a afficher (Si pas d'extension, on met '.png') - \param options Attribut suppl�mentaire a la balise img + \param options Attribut supplémentaire a la balise img \return string Retourne tag img */ function img_picto($alt, $picto, $options='') @@ -1026,7 +1045,7 @@ function img_delete($alt = "default") } /** - \brief Affiche logo d�sactiver + \brief Affiche logo désactiver \param alt Texte sur le alt de l'image \return string Retourne tag img */ @@ -1129,7 +1148,7 @@ function img_alerte($alt = "default") } /** - \brief Affiche logo t�l�phone in + \brief Affiche logo téléphone in \param alt Texte sur le alt de l'image \return string Retourne tag img */ @@ -1141,7 +1160,7 @@ function img_phone_in($alt = "default") } /** - \brief Affiche logo t�l�phone out + \brief Affiche logo téléphone out \param alt Texte sur le alt de l'image \return string Retourne tag img */ @@ -1167,7 +1186,7 @@ function img_next($alt = "default") } /** - \brief Affiche logo pr�c�dent + \brief Affiche logo précédent \param alt Texte sur le alt de l'image \return string Retourne tag img */ @@ -1386,7 +1405,7 @@ function dol_loginfunction($notused,$pearstatus) print ''; if (file_exists(DOL_DOCUMENT_ROOT.'/logo.png')) { - // Cas qui ne devrait pas arriver (pour compatibilit�) + // Cas qui ne devrait pas arriver (pour compatibilité) print ''; } @@ -1435,7 +1454,7 @@ function dol_loginfunction($notused,$pearstatus) print ''."\n"; - // Code de s�curit� + // Code de sécurité if ($conf->global->MAIN_SECURITY_ENABLECAPTCHA) { //print "Info session: ".session_name().session_id();print_r($_SESSION); @@ -1489,12 +1508,12 @@ function dol_loginfunction($notused,$pearstatus) } /* - * \brief V�rifie les droits de l'utilisateur + * \brief Vérifie les droits de l'utilisateur * \param user Utilisateur courant - * \param module Module � v�rifier + * \param module Module a vérifier * \param objectid ID du document * \param dbtable Table de la base correspondant au module (optionnel) - * \param list D�fini si la page sert de liste et donc ne fonctionne pas avec un id + * \param list Défini si la page sert de liste et donc ne fonctionne pas avec un id */ function restrictedArea($user, $modulename, $objectid='', $dbtablename='', $list=0) { @@ -1512,7 +1531,7 @@ function dol_loginfunction($notused,$pearstatus) $socid = 0; $nocreate = 0; - //si dbtable non d�fini, m�me nom que le module + //si dbtable non défini, méme nom que le module if (!$dbtablename) $dbtablename = $modulename; if (!$user->rights->$modulename->lire) @@ -1610,12 +1629,12 @@ function accessforbidden($message='',$printheader=1) /** - \brief Affiche message erreur system avec toutes les informations pour faciliter le diagnostic et la remont�e des bugs. - On doit appeler cette fonction quand une erreur technique bloquante est rencontr�e. + \brief Affiche message erreur system avec toutes les informations pour faciliter le diagnostic et la remontée des bugs. + On doit appeler cette fonction quand une erreur technique bloquante est rencontrée. Toutefois, il faut essayer de ne l'appeler qu'au sein de pages php, les classes devant - renvoyer leur erreur par l'interm�diaire de leur propri�t� "error". - \param db Handler de base utilis� - \param error Chaine erreur ou tableau de chaines erreur compl�mentaires � afficher + renvoyer leur erreur par l'intermédiaire de leur propriété "error". + \param db Handler de base utilisé + \param error Chaine erreur ou tableau de chaines erreur complémentaires a afficher */ function dolibarr_print_error($db='',$error='') { @@ -1696,7 +1715,7 @@ function dolibarr_print_error($db='',$error='') /** - \brief Deplacer les fichiers telecharg�s, apres quelques controles divers + \brief Deplacer les fichiers telechargés, apres quelques controles divers \param src_file fichier source \param dest_file fichier de destination \return int true=Deplacement OK, false=Pas de deplacement ou KO @@ -1723,7 +1742,7 @@ function doliMoveFileUpload($src_file, $dest_file) } // Security: - // On interdit les remont�es de repertoire ainsi que les pipe dans + // On interdit les remontées de repertoire ainsi que les pipe dans // les noms de fichiers. if (eregi('\.\.',$src_file) || eregi('[<>|]',$src_file)) { @@ -1732,7 +1751,7 @@ function doliMoveFileUpload($src_file, $dest_file) } // Security: - // On interdit les remont�es de repertoire ainsi que les pipe dans + // On interdit les remontées de repertoire ainsi que les pipe dans // les noms de fichiers. if (eregi('\.\.',$dest_file) || eregi('[<>|]',$dest_file)) { @@ -1750,22 +1769,22 @@ function doliMoveFileUpload($src_file, $dest_file) \brief Transcodage de francs en euros \param zonein zone de depart \param devise type de devise - \return r resultat transcod� + \return r resultat transcodé */ function transcoS2L($zonein,$devise) { // Open source offert par alainfloch@free.fr 28/10/2001, sans garantie. - // d�but de la fonction de transcodification de somme en toutes lettres + // début de la fonction de transcodification de somme en toutes lettres /* $zonein = "123,56"; - * $devise = "E"; // pr�ciser F si francs , sinon ce sera de l'euro + * $devise = "E"; // préciser F si francs , sinon ce sera de l'euro * $r = transcoS2L($zonein,$devise); // appeler la fonction - * echo "r�sultat vaut $r
"; - * $zonelettresM = strtoupper($r); // si vous voulez la m�me zone mais tout en majuscules - * echo "r�sultat en Majuscules vaut $zonelettresM
"; + * echo "résultat vaut $r
"; + * $zonelettresM = strtoupper($r); // si vous voulez la méme zone mais tout en majuscules + * echo "résultat en Majuscules vaut $zonelettresM
"; * $zonein = "1,01"; * $r = transcoS2L($zonein,$devise); - * echo "r�sultat vaut $r
"; + * echo "résultat vaut $r
"; */ @@ -1782,7 +1801,7 @@ function transcoS2L($zonein,$devise) $cent_singulier = " centime"; } - $arr1_99 = array("z�ro","un","deux","trois", + $arr1_99 = array("zéro","un","deux","trois", "quatre","cinq","six","sept", "huit","neuf","dix","onze","douze", "treize","quatorze","quinze","seize", @@ -1820,24 +1839,24 @@ function transcoS2L($zonein,$devise) $arr1_99[$j] = "quatre-vingt-".$arr1_99[$i]; $i++; } // fin initialise la table (fin) - // echo "Pour une valeur en entr�e = $zonein
"; //pour ceux qui ne croient que ce qu'ils voient ! + // echo "Pour une valeur en entrée = $zonein
"; //pour ceux qui ne croient que ce qu'ils voient ! // quelques petits controles s'imposent !! - $valid = "[a-zA-Z\&\�\"\'\(\-\�\_\�\�\)\=\;\:\!\*\$\^\<\>]"; + $valid = "[a-zA-Z\&\é\"\'\(\-\é\_\é\é\)\=\;\:\!\*\$\^\<\>]"; if (ereg($valid,$zonein)) { - $r = "la cha�ne ".$zonein." n'est pas valide"; + $r = "la chaéne ".$zonein." n'est pas valide"; return($r); } - $zone = explode(" ",$zonein); // supprimer les blancs s�parateurs - $zonein = implode("",$zone); // reconcat�ne la zone input - $zone = explode(".",$zonein); // supprimer les points s�parateurs - $zonein = implode("",$zone); // reconcat�ne la zone input, �a c'est fort ! merci PHP - $virg = strpos($zonein,",",1); // � la poursuite de la virgule + $zone = explode(" ",$zonein); // supprimer les blancs séparateurs + $zonein = implode("",$zone); // reconcaténe la zone input + $zone = explode(".",$zonein); // supprimer les points séparateurs + $zonein = implode("",$zone); // reconcaténe la zone input, éa c'est fort ! merci PHP + $virg = strpos($zonein,",",1); // a la poursuite de la virgule $i = strlen($zonein); // et de la longueur de la zone input if ($virg == 0) { // ya pas de virgule if ($i > 7) { - $r = "la cha�ne ".$zonein." est trop longue (maxi = 9 millions)"; + $r = "la chaéne ".$zonein." est trop longue (maxi = 9 millions)"; return($r); } $deb = 7 - $i; @@ -1845,12 +1864,12 @@ function transcoS2L($zonein,$devise) } else { //ya une virgule - $ti = explode(",",$zonein); // mettre de c�t� ce qu'il y a devant la virgule + $ti = explode(",",$zonein); // mettre de cété ce qu'il y a devant la virgule $i = strlen($ti[0]); // en controler la longueur $zonechiffres = "0000000,00"; if ($i > 7) { - $r = "la cha�ne ".$zonein." est trop longue (maxi = 9 millions,00)"; + $r = "la chaéne ".$zonein." est trop longue (maxi = 9 millions,00)"; return($r); } $deb = 7 - $i; @@ -1881,7 +1900,7 @@ function transcoS2L($zonein,$devise) } } // fin du else ya des centaines de mille $MM= substr($zoneanaly,2,2); - if (substr($zoneanaly,2,1)==0){ $MM = substr($zoneanaly,3,1);} // enlever le z�ro des milliers cause indexation + if (substr($zoneanaly,2,1)==0){ $MM = substr($zoneanaly,3,1);} // enlever le zéro des milliers cause indexation if ($MM ==0 && $CM > 0) { $r = $r."mille "; @@ -1909,7 +1928,7 @@ function transcoS2L($zonein,$devise) } } $C2= substr($zoneanaly,5,2); - if (substr($zoneanaly,5,1)==0){ $C2 = substr($zoneanaly,6,1);} // enlever le z�ro des centaines cause indexation + if (substr($zoneanaly,5,1)==0){ $C2 = substr($zoneanaly,6,1);} // enlever le zéro des centaines cause indexation $C1= substr($zoneanaly,4,1); if ($C2 ==0 && $C1 > 1) { @@ -1939,13 +1958,13 @@ function transcoS2L($zonein,$devise) if ($UN != "00") { $cts = $UN; - if (substr($UN,0,1)==0){ $cts = substr($UN,1,1);} // enlever le z�ro des centimes cause indexation + if (substr($UN,0,1)==0){ $cts = substr($UN,1,1);} // enlever le zéro des centimes cause indexation $r = $r." et ". $arr1_99[$cts].$cent_singulier; if ($UN > 1) $r =$r."s"; // accorde au pluriel } - $r1 = ltrim($r); // enleve quelques blancs possibles en d�but de zone - $r = ucfirst($r1); // met le 1er caract�re en Majuscule, c'est + zoli - return($r); // retourne le r�sultat + $r1 = ltrim($r); // enleve quelques blancs possibles en début de zone + $r = ucfirst($r1); // met le 1er caractére en Majuscule, c'est + zoli + return($r); // retourne le résultat } // fin fonction transcoS2L @@ -1957,7 +1976,7 @@ function transcoS2L($zonein,$devise) \param begin ("" par defaut) \param options ("" par defaut) \param td options de l'attribut td ("" par defaut) - \param sortfield nom du champ sur lequel est effectu� le tri du tableau + \param sortfield nom du champ sur lequel est effectué le tri du tableau \param sortorder ordre du tri */ function print_liste_field_titre($name, $file, $field, $begin="", $options="", $td="", $sortfield="", $sortorder="") @@ -1965,7 +1984,7 @@ function print_liste_field_titre($name, $file, $field, $begin="", $options="", $ global $conf; //print "$name, $file, $field, $begin, $options, $td, $sortfield, $sortorder
\n"; - // Le champ de tri est mis en �vidence. + // Le champ de tri est mis en évidence. // Exemple si (sortfield,field)=("nom","xxx.nom") ou (sortfield,field)=("nom","nom") if ($sortfield == $field || $sortfield == ereg_replace("^[^\.]+\.","",$field)) { @@ -2013,9 +2032,9 @@ function print_titre($titre) } /** - \brief Affichage d'un titre d'une fiche, align� a gauche + \brief Affichage d'un titre d'une fiche, aligné a gauche \param titre Le titre a afficher - \param mesg Message supl�mentaire � afficher � droite + \param mesg Message suplémentaire a afficher a droite \param picto Picto pour ligne de titre */ function print_fiche_titre($titre, $mesg='', $picto='') @@ -2051,8 +2070,8 @@ function dol_delete_file($file) } /** - \brief Effacement d'un r�pertoire - \param file R�pertoire a effacer + \brief Effacement d'un répertoire + \param file Répertoire a effacer */ function dol_delete_dir($dir) { @@ -2060,10 +2079,10 @@ function dol_delete_dir($dir) } /** - \brief Effacement d'un r�pertoire $dir et de son arborescence - \param file R�pertoire a effacer - \param count Compteur pour comptage nb elements supprim�s - \return int Nombre de fichier+rep�rtoires supprim�s + \brief Effacement d'un répertoire $dir et de son arborescence + \param file Répertoire a effacer + \param count Compteur pour comptage nb elements supprimés + \return int Nombre de fichier+repértoires supprimés */ function dol_delete_dir_recursive($dir,$count=0) { @@ -2098,7 +2117,7 @@ function dol_delete_dir_recursive($dir,$count=0) /** \brief Scan les fichiers avec un anti-virus \param file Fichier a scanner - \return malware Nom du virus si infect� sinon retourne "null" + \return malware Nom du virus si infecté sinon retourne "null" */ function dol_avscan_file($file) { @@ -2123,13 +2142,13 @@ function dol_avscan_file($file) /** \brief Fonction print_barre_liste \param titre titre de la page - \param page num�ro de la page + \param page numéro de la page \param file lien \param options parametres complementaires lien ('' par defaut) \param sortfield champ de tri ('' par defaut) \param sortorder ordre de tri ('' par defaut) \param center chaine du centre ('' par defaut) - \param num nombre d'�l�ment total + \param num nombre d'élément total */ function print_barre_liste($titre, $page, $file, $options='', $sortfield='', $sortorder='', $center='', $num=-1) { @@ -2174,7 +2193,7 @@ function print_barre_liste($titre, $page, $file, $options='', $sortfield='', $so /** \brief Fonction servant a afficher les fleches de navigation dans les pages de listes - \param page num�ro de la page + \param page numéro de la page \param file lien \param options autres parametres d'url a propager dans les liens ("" par defaut) \param nextpage faut-il une page suivante @@ -2195,10 +2214,10 @@ function print_fleche_navigation($page,$file,$options='',$nextpage) /** -* \brief Fonction qui retourne un taux de tva format� pour visualisation -* \remarks Fonction utilis�e dans les pdf et les pages html +* \brief Fonction qui retourne un taux de tva formaté pour visualisation +* \remarks Fonction utilisée dans les pdf et les pages html * \param rate Taux a formater (19.6 19,6 19.6% 19,6%...) -* \return string Chaine avec montant format� (19,6 ou 19,6%) +* \return string Chaine avec montant formaté (19,6 ou 19,6%) */ function vatrate($rate) { @@ -2213,14 +2232,14 @@ function vatrate($rate) /** -* \brief Fonction qui retourne un montant mon�taire format� pour visualisation -* \remarks Fonction utilis�e dans les pdf et les pages html +* \brief Fonction qui retourne un montant monétaire formaté pour visualisation +* \remarks Fonction utilisée dans les pdf et les pages html * \param amount Montant a formater * \param html Formatage html ou pas (0 par defaut) * \param outlangs Objet langs pour formatage text -* \param trunc 1=Tronque affichage si trop de d�cimales,0=Force le non troncage +* \param trunc 1=Tronque affichage si trop de décimales,0=Force le non troncage * \param nbdecimal Nbre decimals minimum. -* \return string Chaine avec montant format� +* \return string Chaine avec montant formaté * \seealso price2num Fonction inverse de price */ function price($amount, $html=0, $outlangs='', $trunc=1, $nbdecimal=2) @@ -2242,11 +2261,11 @@ function price($amount, $html=0, $outlangs='', $trunc=1, $nbdecimal=2) //print $amount."-"; $datas = split('\.',$amount); $decpart = $datas[1]; - $decpart = eregi_replace('0+$','',$decpart); // Supprime les 0 de fin de partie d�cimale + $decpart = eregi_replace('0+$','',$decpart); // Supprime les 0 de fin de partie décimale //print "decpart=".$decpart."
"; $end=''; - // On augmente au besoin si il y a plus de 2 d�cimales + // On augmente au besoin si il y a plus de 2 décimales if (strlen($decpart) > $nbdecimal) $nbdecimal=strlen($decpart); // Si on depasse max if ($trunc && $nbdecimal > $conf->global->MAIN_MAX_DECIMALS_SHOWN) @@ -2254,7 +2273,7 @@ function price($amount, $html=0, $outlangs='', $trunc=1, $nbdecimal=2) $nbdecimal=$conf->global->MAIN_MAX_DECIMALS_SHOWN; if (eregi('\.\.\.',$conf->global->MAIN_MAX_DECIMALS_SHOWN)) { - // Si un affichage est tronqu�, on montre des ... + // Si un affichage est tronqué, on montre des ... $end='...'; } } @@ -2274,15 +2293,15 @@ function price($amount, $html=0, $outlangs='', $trunc=1, $nbdecimal=2) } /** - \brief Fonction qui retourne un num�rique conforme PHP et SQL, depuis un montant au + \brief Fonction qui retourne un numérique conforme PHP et SQL, depuis un montant au format utilisateur. - \remarks Fonction � appeler sur montants saisis avant un insert en base + \remarks Fonction a appeler sur montants saisis avant un insert en base \param amount Montant a formater \param rounding 'MU'=Round to Max unit price (MAIN_MAX_DECIMALS_UNIT) 'MT'=Round to Max with Tax (MAIN_MAX_DECIMALS_TOT) 'MS'=Round to Max Shown (MAIN_MAX_DECIMALS_SHOWN) ''=No rounding - \return string Montant au format num�rique PHP et SQL (Exemple: '99.99999') + \return string Montant au format numérique PHP et SQL (Exemple: '99.99999') \seealso price Fonction inverse de price2num */ function price2num($amount,$rounding='') @@ -2308,16 +2327,16 @@ function price2num($amount,$rounding='') /** \brief Fonction qui renvoie la tva d'une ligne (en fonction du vendeur, acheteur et taux du produit) - \remarks Si vendeur non assujeti � TVA, TVA par d�faut=0. Fin de r�gle. - Si le (pays vendeur = pays acheteur) alors TVA par d�faut=TVA du produit vendu. Fin de r�gle. - Si (vendeur et acheteur dans Communaut� europ�enne) et (bien vendu = moyen de transports neuf comme auto, bateau, avion) alors TVA par d�faut=0 (La TVA doit �tre pay� par acheteur au centre d'impots de son pays et non au vendeur). Fin de r�gle. - Si (vendeur et acheteur dans Communaut� europ�enne) et (acheteur = particulier ou entreprise sans num TVA intra) alors TVA par d�faut=TVA du produit vendu. Fin de r�gle. - Si (vendeur et acheteur dans Communaut� europ�enne) et (acheteur = entreprise avec num TVA) intra alors TVA par d�faut=0. Fin de r�gle. - Sinon TVA propos�e par d�faut=0. Fin de r�gle. - \param societe_vendeuse Objet soci�t� vendeuse - \param societe_acheteuse Objet soci�t� acheteuse + \remarks Si vendeur non assujeti a TVA, TVA par défaut=0. Fin de régle. + Si le (pays vendeur = pays acheteur) alors TVA par défaut=TVA du produit vendu. Fin de régle. + Si (vendeur et acheteur dans Communauté européenne) et (bien vendu = moyen de transports neuf comme auto, bateau, avion) alors TVA par défaut=0 (La TVA doit étre payé par acheteur au centre d'impots de son pays et non au vendeur). Fin de régle. + Si (vendeur et acheteur dans Communauté européenne) et (acheteur = particulier ou entreprise sans num TVA intra) alors TVA par défaut=TVA du produit vendu. Fin de régle. + Si (vendeur et acheteur dans Communauté européenne) et (acheteur = entreprise avec num TVA) intra alors TVA par défaut=0. Fin de régle. + Sinon TVA proposée par défaut=0. Fin de régle. + \param societe_vendeuse Objet société vendeuse + \param societe_acheteuse Objet société acheteuse \param taux_produit Taux par defaut du produit vendu - \return float Taux de tva � appliquer, -1 si ne peut etre d�termin� + \return float Taux de tva a appliquer, -1 si ne peut etre déterminé */ function get_default_tva($societe_vendeuse, $societe_acheteuse, $taux_produit) { @@ -2326,37 +2345,37 @@ function get_default_tva($societe_vendeuse, $societe_acheteuse, $taux_produit) if (!is_object($societe_vendeuse)) return -1; if (!is_object($societe_acheteuse)) return -1; - // Si vendeur non assujeti � TVA (tva_assuj vaut 0/1 ou franchise/reel) + // Si vendeur non assujeti a TVA (tva_assuj vaut 0/1 ou franchise/reel) if (is_numeric($societe_vendeuse->tva_assuj) && ! $societe_vendeuse->tva_assuj) return 0; if (! is_numeric($societe_vendeuse->tva_assuj) && $societe_vendeuse->tva_assuj=='franchise') return 0; - // Si le (pays vendeur = pays acheteur) alors la TVA par d�faut=TVA du produit vendu. Fin de r�gle. + // Si le (pays vendeur = pays acheteur) alors la TVA par défaut=TVA du produit vendu. Fin de régle. //if (is_object($societe_acheteuse) && ($societe_vendeuse->pays_id == $societe_acheteuse->pays_id) && ($societe_acheteuse->tva_assuj == 1 || $societe_acheteuse->tva_assuj == 'reel')) - // Le test ci-dessus ne devrait pas etre necessaire. Me signaler l'exemple du cas juridique concercn� si le test suivant n'est pas suffisant. + // Le test ci-dessus ne devrait pas etre necessaire. Me signaler l'exemple du cas juridique concercné si le test suivant n'est pas suffisant. if ($societe_vendeuse->pays_id == $societe_acheteuse->pays_id) { - if (strlen($taux_produit) == 0) return -1; // Si taux produit = '', on ne peut d�terminer taux tva + if (strlen($taux_produit) == 0) return -1; // Si taux produit = '', on ne peut déterminer taux tva return $taux_produit; } - // Si (vendeur et acheteur dans Communaut� europ�enne) et (bien vendu = moyen de transports neuf comme auto, bateau, avion) alors TVA par d�faut=0 (La TVA doit �tre pay� par l'acheteur au centre d'impots de son pays et non au vendeur). Fin de r�gle. - // Non g�r� + // Si (vendeur et acheteur dans Communauté européenne) et (bien vendu = moyen de transports neuf comme auto, bateau, avion) alors TVA par défaut=0 (La TVA doit étre payé par l'acheteur au centre d'impots de son pays et non au vendeur). Fin de régle. + // Non géré - // Si (vendeur et acheteur dans Communaut� europ�enne) et (acheteur = particulier ou entreprise sans num TVA intra) alors TVA par d�faut=TVA du produit vendu. Fin de r�gle. + // Si (vendeur et acheteur dans Communauté européenne) et (acheteur = particulier ou entreprise sans num TVA intra) alors TVA par défaut=TVA du produit vendu. Fin de régle. if (($societe_vendeuse->isInEEC() && $societe_acheteuse->isInEEC()) && ! $societe_acheteuse->tva_intra) { - if (strlen($taux_produit) == 0) return -1; // Si taux produit = '', on ne peut d�terminer taux tva + if (strlen($taux_produit) == 0) return -1; // Si taux produit = '', on ne peut déterminer taux tva return $taux_produit; } - // Si (vendeur et acheteur dans Communaut� europ�enne) et (acheteur = entreprise avec num TVA intra) alors TVA par d�faut=0. Fin de r�gle. + // Si (vendeur et acheteur dans Communauté européenne) et (acheteur = entreprise avec num TVA intra) alors TVA par défaut=0. Fin de régle. if (($societe_vendeuse->isInEEC() && $societe_acheteuse->isInEEC()) && $societe_acheteuse->tva_intra) { return 0; } - // Sinon la TVA propos�e par d�faut=0. Fin de r�gle. - // Rem: Cela signifie qu'au moins un des 2 est hors Communaut� europ�enne et que le pays diff�re + // Sinon la TVA proposée par défaut=0. Fin de régle. + // Rem: Cela signifie qu'au moins un des 2 est hors Communauté européenne et que le pays différe return 0; } @@ -2390,7 +2409,7 @@ function makesalt($type=CRYPT_SALT_LENGTH) { case 12: // 8 + 4 $saltlen=8; $saltprefix='$1$'; $saltsuffix='$'; break; - case 8: // 8 + 4 (Pour compatibilite, ne devrait pas etre utilis�) + case 8: // 8 + 4 (Pour compatibilite, ne devrait pas etre utilisé) $saltlen=8; $saltprefix='$1$'; $saltsuffix='$'; break; case 2: // 2 default: // by default, fall back on Standard DES (should work everywhere) @@ -2405,8 +2424,8 @@ function makesalt($type=CRYPT_SALT_LENGTH) } /** \brief Fonction pour qui retourne le rowid d'un departement par son code - \param db handler d'acc�s base - \param code Code r�gion + \param db handler d'accés base + \param code Code région \param pays_id Id du pays */ function departement_rowid($db,$code, $pays_id) @@ -2437,9 +2456,9 @@ function departement_rowid($db,$code, $pays_id) } /** - \brief Renvoi un chemin de classement r�pertoire en fonction d'un id + \brief Renvoi un chemin de classement répertoire en fonction d'un id \remarks Examples: 1->"0/0/1/", 15->"0/1/5/" - \param $num Id � d�composer + \param $num Id a décomposer \param $level Niveau de decoupage (1, 2 ou 3 niveaux) */ function get_exdir($num,$level=3) @@ -2453,9 +2472,9 @@ function get_exdir($num,$level=3) } /** - \brief Cr�ation de r�pertoire recursive - \param $dir R�pertoire � cr�er - \return int < 0 si erreur, >= 0 si succ�s + \brief Création de répertoire recursive + \param $dir Répertoire a créer + \return int < 0 si erreur, >= 0 si succés */ function create_exdir($dir) { @@ -2474,7 +2493,7 @@ function create_exdir($dir) else $ccdir = $cdir[$i]; if (eregi("^.:$",$ccdir,$regs)) continue; // Si chemin Windows incomplet, on poursuit par rep suivant - // Attention, le is_dir() peut �chouer bien que le rep existe. + // Attention, le is_dir() peut échouer bien que le rep existe. // (ex selon config de open_basedir) if ($ccdir) { @@ -2485,20 +2504,20 @@ function create_exdir($dir) umask(0); if (! @mkdir($ccdir, 0755)) { - // Si le is_dir a renvoy� une fausse info, alors on passe ici. + // Si le is_dir a renvoyé une fausse info, alors on passe ici. dolibarr_syslog("functions.inc.php::create_exdir: Fails to create directory '".$ccdir."' or directory already exists.",LOG_WARNING); $nberr++; } else { dolibarr_syslog("functions.inc.php::create_exdir: Directory '".$ccdir."' created",LOG_DEBUG); - $nberr=0; // On remet � z�ro car si on arrive ici, cela veut dire que les �checs pr�c�dents peuvent etre ignor�s + $nberr=0; // On remet a zéro car si on arrive ici, cela veut dire que les échecs précédents peuvent etre ignorés $nbcreated++; } } else { - $nberr=0; // On remet � z�ro car si on arrive ici, cela veut dire que les �checs pr�c�dents peuvent etre ignor�s + $nberr=0; // On remet a zéro car si on arrive ici, cela veut dire que les échecs précédents peuvent etre ignorés } } } @@ -2595,9 +2614,9 @@ function dolibarr_dir_list($path, $types="all", $recursive=0, $filter="", $exclu } } /** - \brief Retourne le num�ro de la semaine par rapport a une date + \brief Retourne le numéro de la semaine par rapport a une date \param time Date au format 'timestamp' - \return int Num�ro de semaine + \return int Numéro de semaine */ function numero_semaine($time) { @@ -2613,12 +2632,12 @@ function numero_semaine($time) /* * Norme ISO-8601: - * - La semaine 1 de toute ann�e est celle qui contient le 4 janvier ou que la semaine 1 de toute ann�e est celle qui contient le 1er jeudi de janvier. - * - La majorit� des ann�es ont 52 semaines mais les ann�es qui commence un jeudi et les ann�es bissextiles commen�ant un mercredi en poss�de 53. + * - La semaine 1 de toute année est celle qui contient le 4 janvier ou que la semaine 1 de toute année est celle qui contient le 1er jeudi de janvier. + * - La majorité des années ont 52 semaines mais les années qui commence un jeudi et les années bissextiles commenéant un mercredi en posséde 53. * - Le 1er jour de la semaine est le Lundi */ - // D�finition du Jeudi de la semaine + // Définition du Jeudi de la semaine if (date("w",mktime(12,0,0,$mois,$jour,$annee))==0) // Dimanche $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)-3*24*60*60; else if (date("w",mktime(12,0,0,$mois,$jour,$annee))<4) // du Lundi au Mercredi @@ -2628,7 +2647,7 @@ function numero_semaine($time) else // Jeudi $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee); - // D�finition du premier Jeudi de l'ann�e + // Définition du premier Jeudi de l'année if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==0) // Dimanche { $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+4*24*60*60; @@ -2646,7 +2665,7 @@ function numero_semaine($time) $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine)); } - // D�finition du num�ro de semaine: nb de jours entre "premier Jeudi de l'ann�e" et "Jeudi de la semaine"; + // Définition du numéro de semaine: nb de jours entre "premier Jeudi de l'année" et "Jeudi de la semaine"; $numeroSemaine = ( ( date("z",mktime(12,0,0,date("m",$jeudiSemaine),date("d",$jeudiSemaine),date("Y",$jeudiSemaine))) @@ -2658,7 +2677,7 @@ function numero_semaine($time) // Cas particulier de la semaine 53 if ($numeroSemaine==53) { - // Les ann�es qui commence un Jeudi et les ann�es bissextiles commen�ant un Mercredi en poss�de 53 + // Les années qui commence un Jeudi et les années bissextiles commenéant un Mercredi en posséde 53 if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==4 || (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==3 && date("z",mktime(12,0,0,12,31,date("Y",$jeudiSemaine)))==365)) { $numeroSemaine = 53; @@ -2719,13 +2738,13 @@ function weight_convert($weight,&$from_unit,$to_unit) \param int Unit \param measuring_style Le style de mesure : weight, volume,... \return string Unite - \todo gerer les autres unit�s de mesure comme la livre, le gallon, le litre, ... + \todo gerer les autres unités de mesure comme la livre, le gallon, le litre, ... */ function measuring_units_string($unit,$measuring_style='') { /* Note Rodo aux dev :) - * Ne pas ins�rer dans la base de donn�es ces valeurs - * cela surchagerait inutilement d'une requete suppl�mentaire + * Ne pas insérer dans la base de données ces valeurs + * cela surchagerait inutilement d'une requete supplémentaire * pour quelque chose qui est somme toute peu variable */ @@ -2814,7 +2833,7 @@ function clean_html($StringHtml) } /** - \brief Convertir du binaire en h�xad�cimal + \brief Convertir du binaire en héxadécimal \param string bin \return string x */ @@ -2828,7 +2847,7 @@ function binhex($bin, $pad=false, $upper=false){ } /** - \brief Convertir de l'h�xad�cimal en binaire + \brief Convertir de l'héxadécimal en binaire \param string hexa \return string bin */ @@ -2842,12 +2861,12 @@ function hexbin($hexa){ } /* -* \brief Cette fonction est appel�e pour coder ou non une chaine en html. +* \brief Cette fonction est appelée pour coder ou non une chaine en html. * \param stringtoencode String to encode * \param htmlinfo 1=String IS already html, 0=String IS NOT html, -1=Unknown need autodetection * \remarks Selon qu'on compte l'afficher dans le PDF avec: -* writeHTMLCell -> a besoin d'etre encod� en HTML -* MultiCell -> ne doit pas etre encod� en HTML +* writeHTMLCell -> a besoin d'etre encodé en HTML +* MultiCell -> ne doit pas etre encodé en HTML */ function dol_htmlentities($stringtoencode,$htmlinfo=-1) { @@ -2862,8 +2881,8 @@ function dol_htmlentities($stringtoencode,$htmlinfo=-1) } /** - \brief Encode\decode le mot de passe de la base de donn�es dans le fichier de conf - \param level niveau d'encodage : 0 non encod�, 1 encod� + \brief Encode\decode le mot de passe de la base de données dans le fichier de conf + \param level niveau d'encodage : 0 non encodé, 1 encodé */ function encodedecode_dbpassconf($level=0) { @@ -2914,9 +2933,9 @@ function encodedecode_dbpassconf($level=0) } /** - \brief Encode une chaine de caract�re - \param chain chaine de caract�res � encoder - \return string_coded chaine de caract�res encod�e + \brief Encode une chaine de caractére + \param chain chaine de caractéres a encoder + \return string_coded chaine de caractéres encodée */ function dolibarr_encode($chain) { @@ -2930,9 +2949,9 @@ function dolibarr_encode($chain) } /** - \brief Decode une chaine de caract�re - \param chain chaine de caract�res � decoder - \return string_coded chaine de caract�res decod�e + \brief Decode une chaine de caractére + \param chain chaine de caractéres a decoder + \return string_coded chaine de caractéres decodée */ function dolibarr_decode($chain) { @@ -3047,7 +3066,7 @@ function num_public_holiday($timestampStart, $timestampEnd, $countrycode='FR') /** \brief Fonction retournant le nombre de jour entre deux dates - \param timestampStart Timestamp de d�but + \param timestampStart Timestamp de début \param timestampEnd Timestamp de fin \param lastday On prend en compte le dernier jour, 0: non, 1:oui \return nbjours Nombre de jours @@ -3070,8 +3089,8 @@ function num_between_day($timestampStart, $timestampEnd, $lastday=0) } /** - \brief Fonction retournant le nombre de jour entre deux dates sans les jours f�ri�s (jours ouvr�s) - \param timestampStart Timestamp de d�but + \brief Fonction retournant le nombre de jour entre deux dates sans les jours fériés (jours ouvrés) + \param timestampStart Timestamp de début \param timestampEnd Timestamp de fin \param inhour 0: sort le nombre de jour , 1: sort le nombre d'heure \param lastday On prend en compte le dernier jour, 0: non, 1:oui @@ -3096,7 +3115,7 @@ function num_open_day($timestampStart, $timestampEnd,$inhour=0,$lastday=0) } /** - \brief Fonction retournant le nombre de lignes dans un texte format� + \brief Fonction retournant le nombre de lignes dans un texte formaté \param texte Texte \return nblines Nombre de lignes */ @@ -3117,11 +3136,11 @@ function ajax_indicator($htmlname,$indicator='working') } /** - \brief R�cup�re la valeur d'un champ, effectue un traitement Ajax et affiche le r�sultat + \brief Récupére la valeur d'un champ, effectue un traitement Ajax et affiche le résultat \param htmlname nom et id du champ - \param keysearch nom et id compl�mentaire du champ de collecte - \param url chemin du fichier de r�ponse : /chemin/fichier.php - \param option champ suppl�mentaire de recherche dans les param�tres + \param keysearch nom et id complémentaire du champ de collecte + \param url chemin du fichier de réponse : /chemin/fichier.php + \param option champ supplémentaire de recherche dans les paramétres \param indicator Nom de l'image gif sans l'extension \return script script complet */ @@ -3160,12 +3179,12 @@ function ajax_updater($htmlname,$keysearch,$url,$option='',$indicator='working') } /** - \brief R�cup�re la valeur d'un champ, effectue un traitement Ajax et affiche le r�sultat + \brief Récupére la valeur d'un champ, effectue un traitement Ajax et affiche le résultat \param htmlname nom et id du champ - \param keysearch nom et id compl�mentaire du champ de collecte - \param id ID du champ � modifier - \param url chemin du fichier de r�ponse : /chemin/fichier.php - \param option champ suppl�mentaire de recherche dans les param�tres + \param keysearch nom et id complémentaire du champ de collecte + \param id ID du champ a modifier + \param url chemin du fichier de réponse : /chemin/fichier.php + \param option champ supplémentaire de recherche dans les paramétres \param indicator Nom de l'image gif sans l'extension \return script script complet */ @@ -3202,9 +3221,9 @@ function ajax_updaterWithID($htmlname,$keysearch,$id,$url,$option='',$indicator= } /** - \brief R�cup�re la valeur d'un champ, effectue un traitement Ajax et affiche le r�sultat + \brief Récupére la valeur d'un champ, effectue un traitement Ajax et affiche le résultat \param htmlname nom et id du champ - \param url chemin du fichier de r�ponse : /chemin/fichier.php + \param url chemin du fichier de réponse : /chemin/fichier.php \param indicator nom de l'image gif sans l'extension \return script script complet */ @@ -3227,7 +3246,7 @@ function ajax_autocompleter($selected='',$htmlname,$url,$indicator='working') } /** -* \brief Fonction simple identique � microtime de PHP 5 mais compatible PHP 4 +* \brief Fonction simple identique a microtime de PHP 5 mais compatible PHP 4 * \return float Time en millisecondes avec decimal pour microsecondes */ function dol_microtime_float() @@ -3266,10 +3285,10 @@ function dol_textishtml($msg,$option=0) } /* - * \brief Effectue les substitutions des mots cl�s par les donn�es en fonction du tableau + * \brief Effectue les substitutions des mots clés par les données en fonction du tableau * \param chaine Chaine dans laquelle faire les substitutions - * \param substitutionarray Tableau cl� substitution => valeur a mettre - * \return string Chaine avec les substitutions effectu�es + * \param substitutionarray Tableau clé substitution => valeur a mettre + * \return string Chaine avec les substitutions effectuées */ function make_substitutions($chaine,$substitutionarray) { @@ -3312,14 +3331,14 @@ function make_substitutions($chaine,$substitutionarray) $result = "\"" . addslashes(stripslashes($var)) . "\""; return $result; } - // autres cas: objets, on ne les g�re pas + // autres cas: objets, on ne les gére pas $result = FALSE; return $result; } /* - * \brief Formate l'affichage de date de d�but et de fin - * \param date_start date de d�but + * \brief Formate l'affichage de date de début et de fin + * \param date_start date de début * \param date_end date de fin */ function print_date_range($date_start,$date_end) @@ -3341,13 +3360,13 @@ function print_date_range($date_start,$date_end) } /* - * \brief Cr�ation de 2 vignettes � partir d'un fichier image (une small et un mini) + * \brief Création de 2 vignettes a partir d'un fichier image (une small et un mini) * \brief Les extension prise en compte sont jpg et png - * \param file Chemin du fichier image � redimensionner - * \param maxWidth Largeur maximum que dois faire la miniature (160 par d�faut) - * \param maxHeight Hauteur maximum que dois faire l'image (120 par d�faut) - * \param extName Extension pour diff�rencier le nom de la vignette - * \param quality Qualit� de compression (0=worst, 100=best) + * \param file Chemin du fichier image a redimensionner + * \param maxWidth Largeur maximum que dois faire la miniature (160 par défaut) + * \param maxHeight Hauteur maximum que dois faire l'image (120 par défaut) + * \param extName Extension pour différencier le nom de la vignette + * \param quality Qualité de compression (0=worst, 100=best) * \return string Chemin de la vignette */ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $quality=50) @@ -3359,15 +3378,15 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ // Nettoyage parametres $file=trim($file); - // V�rification des param�tres + // Vérification des paramétres if (! $file) { - // Si le fichier n'a pas �t� indiqu� + // Si le fichier n'a pas été indiqué return 'Bad parameter file'; } elseif (! file_exists($file)) { - // Si le fichier pass� en param�tre n'existe pas + // Si le fichier passé en paramétre n'existe pas return $langs->trans("ErrorFileNotFound",$file); } elseif(image_format_supported($file) < 0) @@ -3375,11 +3394,11 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ return 'This file '.$file.' does not seem to be an image format file name.'; } elseif(!is_numeric($maxWidth) || empty($maxWidth) || $maxWidth < 0){ - // Si la largeur max est incorrecte (n'est pas num�rique, est vide, ou est inf�rieure � 0) + // Si la largeur max est incorrecte (n'est pas numérique, est vide, ou est inférieure a 0) return 'Valeur de la largeur incorrecte.'; } elseif(!is_numeric($maxHeight) || empty($maxHeight) || $maxHeight < 0){ - // Si la hauteur max est incorrecte (n'est pas num�rique, est vide, ou est inf�rieure � 0) + // Si la hauteur max est incorrecte (n'est pas numérique, est vide, ou est inférieure a 0) return 'Valeur de la hauteur incorrecte.'; } @@ -3387,16 +3406,16 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ $dir = dirname($file).'/'; // Chemin du dossier contenant l'image $dirthumb = $dir.'thumbs/'; // Chemin du dossier contenant les vignettes - $infoImg = getimagesize($fichier); // R�cup�ration des infos de l'image + $infoImg = getimagesize($fichier); // Récupération des infos de l'image $imgWidth = $infoImg[0]; // Largeur de l'image $imgHeight = $infoImg[1]; // Hauteur de l'image - // Si l'image est plus petite que la largeur et la hauteur max, on ne cr�e pas de vignette + // Si l'image est plus petite que la largeur et la hauteur max, on ne crée pas de vignette if ($infoImg[0] < $maxWidth && $infoImg[1] < $maxHeight) { // On cree toujours les vignettes dolibarr_syslog("File size is smaller than thumb size",LOG_DEBUG); - //return 'Le fichier '.$file.' ne n�cessite pas de cr�ation de vignette'; + //return 'Le fichier '.$file.' ne nécessite pas de création de vignette'; } $imgfonction=''; @@ -3424,7 +3443,7 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ } } - // On cr�e le r�pertoire contenant les vignettes + // On crée le répertoire contenant les vignettes if (! file_exists($dirthumb)) { create_exdir($dirthumb); @@ -3456,7 +3475,7 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ break; } - // Initialisation des dimensions de la vignette si elles sont sup�rieures � l'original + // Initialisation des dimensions de la vignette si elles sont supérieures a l'original if($maxWidth > $imgWidth){ $maxWidth = $imgWidth; } if($maxHeight > $imgHeight){ $maxHeight = $imgHeight; } @@ -3465,11 +3484,11 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ // Fixe les dimensions de la vignette if($whFact < $imgWhFact){ - // Si largeur d�terminante + // Si largeur déterminante $thumbWidth = $maxWidth; $thumbHeight = $thumbWidth / $imgWhFact; } else { - // Si hauteur d�terminante + // Si hauteur déterminante $thumbHeight = $maxHeight; $thumbWidth = $thumbHeight * $imgWhFact; } @@ -3479,7 +3498,7 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ // Create empty image if ($infoImg[2] == 1) { - // Compatibilit� image GIF + // Compatibilité image GIF $imgThumb = imagecreate($thumbWidth, $thumbHeight); } else @@ -3503,14 +3522,14 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ switch($infoImg[2]) { case 1: // Gif - $trans_colour = imagecolorallocate($imgThumb, 255, 255, 255); // On proc�de autrement pour le format GIF + $trans_colour = imagecolorallocate($imgThumb, 255, 255, 255); // On procéde autrement pour le format GIF imagecolortransparent($imgThumb,$trans_colour); break; case 2: // Jpg $trans_colour = imagecolorallocatealpha($imgThumb, 255, 255, 255, 0); break; case 3: // Png - imagealphablending($imgThumb,false); // Pour compatibilit� sur certain syst�me + imagealphablending($imgThumb,false); // Pour compatibilité sur certain systéme $trans_colour = imagecolorallocatealpha($imgThumb, 255, 255, 255, 127); // Keep transparent channel break; case 4: // Bmp @@ -3520,8 +3539,8 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ if (function_exists("imagefill")) imagefill($imgThumb, 0, 0, $trans_colour); dolibarr_syslog("vignette: convert image from ($imgWidth x $imgHeight) to ($thumbWidth x $thumbHeight) as $extImg, newquality=$newquality"); - //imagecopyresized($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Ins�re l'image de base redimensionn�e - imagecopyresampled($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Ins�re l'image de base redimensionn�e + //imagecopyresized($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Insére l'image de base redimensionnée + imagecopyresampled($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Insére l'image de base redimensionnée $fileName = eregi_replace('(\.gif|\.jpeg|\.jpg|\.png|\.bmp)$','',$file); // On enleve extension quelquesoit la casse $fileName = basename($fileName); @@ -3571,7 +3590,7 @@ function ConvertTime2Seconds($iHours=0,$iMinutes=0,$iSeconds=0) * \brief Converti les secondes en heures et minutes * \param iSecond Nombre de secondes * \param format Choix de l'affichage (all:affichage complet, hour: n'affiche que les heures, min: n'affiche que les minutes) - * \return sTime Temps format� + * \return sTime Temps formaté */ function ConvertSecondToTime($iSecond,$format='all'){ if ($format == 'all'){ @@ -3604,8 +3623,8 @@ function make_alpha_from_numbers($number) /* * \brief Affiche le contenu d'un fichier CSV sous forme de tableau - * \param file_to_include Fichier CSV � afficher - * \param max_rows Nombre max de lignes � afficher (0 = illimit�) + * \param file_to_include Fichier CSV a afficher + * \param max_rows Nombre max de lignes a afficher (0 = illimité) */ function viewCsvFileContent($file_to_include='',$max_rows=0) { @@ -3629,9 +3648,9 @@ function viewCsvFileContent($file_to_include='',$max_rows=0) /* * \brief Affiche le contenu d'un fichier Excel (avec les feuilles de calcul) sous forme de tableau - * \param file_to_include Fichier Excel � afficher - * \param max_rows Nombre max de lignes � afficher (0 = illimit�) - * \param max_cols Nombre max de colonnes � afficher (0 = illimit�) + * \param file_to_include Fichier Excel a afficher + * \param max_rows Nombre max de lignes a afficher (0 = illimité) + * \param max_cols Nombre max de colonnes a afficher (0 = illimité) */ function viewExcelFileContent($file_to_include='',$max_rows=0,$max_cols=0) { @@ -3761,10 +3780,10 @@ function viewExcelFileContent($file_to_include='',$max_rows=0,$max_cols=0) } /** - \brief G�n�rateur de codes barres - \param $code Valeur num�rique � coder + \brief Générateur de codes barres + \param $code Valeur numérique a coder \param $encoding Mode de codage - \param $generator G�n�rateur utilis� (1=php-barcode, 2=pi_barcode) + \param $generator Générateur utilisé (1=php-barcode, 2=pi_barcode) \param $readable Code lisible \return url */ @@ -3787,8 +3806,8 @@ function dol_genbarcode($code,$encoding,$generator=1,$readable='Y') } /** - \brief Retourne un tableau des mois ou le mois s�lectionn� - \param Mois s�lectionn� + \brief Retourne un tableau des mois ou le mois sélectionné + \param Mois sélectionné \return month */ function monthArrayOrSelected($selected=0) diff --git a/htdocs/user/modules/login.anakin.class.php b/htdocs/user/modules/login.anakin.class.php index eac524a1928..474758439bd 100644 --- a/htdocs/user/modules/login.anakin.class.php +++ b/htdocs/user/modules/login.anakin.class.php @@ -4,7 +4,7 @@ * Copyright (c) 2004-2005 Laurent Destailleur * Copyright (C) 2004 Sebastien Di Cintio * Copyright (C) 2004 Benoit Mortier - * + * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or @@ -20,136 +20,141 @@ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * $Id$ - * $Source$ */ /** - \file htdocs/user/modules/login.anakin.class.php - \brief Fichier de la classe de génération de login anakin - \author Rodolphe Qiedeville - \version $Revision$ -*/ + \file htdocs/user/modules/login.anakin.class.php + \brief Fichier de la classe de generation de login anakin + \author Rodolphe Qiedeville + \version $Revision$ + */ /** - \class LoginAnakin - \brief Classe permettant la génération de login anakin -*/ - + \class LoginAnakin + \brief Classe permettant la generation de login anakin + */ class LoginAnakin { - var $db; - var $user; + var $error; + var $db; + var $user; - /** - * \brief Constructeur de la classe - * \param $DB Handler accès base de données - * \param $user Objet de l'utilisateur - */ - function LoginAnakin($DB, $user) - { - $this->db = $DB; - $this->user = $user; + var $login; - return 0; - } + + /** + * \brief Constructeur de la classe + * \param $DB Handler acces base de donnees + * \param $user Objet de l'utilisateur + */ + function LoginAnakin($DB, $user) + { + $this->db = $DB; + $this->user = $user; + + return 0; + } - function generate_login() - { - $ok = 0; - $step = 1; - $this->else_step = 1; + /** + * \brief Verifie la disponibilite du login + * \return 1 si le login n'existe pas dans la base, 1 sinon + */ + function dispo() + { + $sql = "SELECT login FROM ".MAIN_DB_PREFIX."user WHERE login ='".$this->login."';"; - while ($ok == 0) - { - $func = 'generate_login_'.$step; + $resql=$this->db->query($sql); - if (method_exists($this, $func)) - { - $this->$func(); - } - else - { - $this->generate_login_else(); - $this->else_step++; - } + if ($resql) + { + $num = $this->db->num_rows($resql); + } - $ok = $this->dispo(); - $step++; - } - - return 0; + if ($num == 0) + { + return 1; + } + else + { + return 0; + } - } + } - /** - * \brief Vérifie la disponibilité du login - * \return 1 si le login n'existe pas dans la base, 1 sinon - */ - function dispo() - { - $sql = "SELECT login FROM ".MAIN_DB_PREFIX."user WHERE login ='".$this->login."';"; + /** + * \brief Genere un login depuis nom + * Ce login est stocke dans ->login + */ + function generate_login() + { + $ok = 0; + $step = 1; + $this->else_step = 1; - $resql=$this->db->query($sql); + while ($ok == 0) + { + $func = 'generate_login_'.$step; - if ($resql) - { - $num = $this->db->num_rows($resql); - } + if (method_exists($this, $func)) + { + $this->$func(); + } + else + { + $this->generate_login_else(); + $this->else_step++; + } - if ($num == 0) - { - return 1; - } - else - { - return 0; - } + $ok = $this->dispo(); + $step++; + } - } + return 0; + } + + + // Regle primaire + // 8 premieres lettre desaccentuees du nom en minuscule + function generate_login_1() + { + $nom = strtolower(unaccent_isostring(sanitize_string($this->user->nom))); + + $this->login = substr($nom, 0, 8); + } - // Règle primaire - // 8 premières lettre désaccentuées du nom en minuscule - function generate_login_1() - { - $nom = unaccent(strtolower($this->user->nom)); - - $this->login = substr($nom, 0, 8); - } + // Regle de defaut + function generate_login_else() + { + $login = strtolower(unaccent_isostring(sanitize_string($this->user->nom))); + + $le = strlen($this->else_step); + + $this->login = substr($login, 0, (8-$le)) . $this->else_step; + } - // Règle de défaut - function generate_login_else() - { - $login = unaccent(strtolower($this->user->nom)); + // Regles annexes + // premiere lettre du prenom + 7 premieres lettres du nom, desaccentuees en minuscule + function generate_login_2() + { + $nom = strtolower(unaccent_isostring(sanitize_string($this->user->nom))); + $prenom = strtolower(unaccent_isostring(sanitize_string($this->user->prenom))); - $le = strlen($this->else_step); - - $this->login = substr($login, 0, (8-$le)) . $this->else_step; - } + $this->login = substr($prenom, 0, 1) . substr($nom, 0, 7); + } - // Règles annexes - // première lettre du prénom + 7 premières lettres du nom, désaccentuées en minuscule - function generate_login_2() - { - $nom = unaccent(strtolower($this->user->nom)); - $prenom = unaccent(strtolower($this->user->prenom)); - - $this->login = substr($prenom, 0, 1) . substr($nom, 0, 7); - } + // 2 premieres lettres du prenom + 6 premieres lettres du nom, desaccentuees en minuscule + function generate_login_3() + { + $nom = strtolower(unaccent_isostring(sanitize_string($this->user->nom))); + $prenom = strtolower(unaccent_isostring(sanitize_string($this->user->prenom))); - - // 2 premières lettres du prénom + 6 premières lettres du nom, désaccentuées en minuscule - function generate_login_3() - { - $nom = unaccent(strtolower($this->user->nom)); - $prenom = unaccent(strtolower($this->user->prenom)); - - $this->login = substr($prenom, 0, 2) . substr($nom, 0, 6); - } + $this->login = substr($prenom, 0, 2) . substr($nom, 0, 6); + } } ?>
'; print '