dolibarr/htdocs/translate.class.php

316 lines
11 KiB
PHP
Raw Normal View History

2003-05-02 12:33:06 +02:00
<?php
/* ***************************************************************************
2005-01-02 17:57:37 +01:00
* Copyright (C) 2001 Eric Seigne <erics@rycks.com>
* Copyright (C) 2004-2005 Destailleur Laurent <eldy@users.sourceforge.net>
2003-05-02 12:33:06 +02:00
*
* 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
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
* ************************************************************************* */
2005-01-02 17:57:37 +01:00
/**
\file htdocs/translate.class.php
\brief Fichier de la classe de traduction
\author Laurent Destailleur
\version $Revision$
*/
2005-01-02 17:57:37 +01:00
/**
\class Translate
\brief Classe permettant de g<EFBFBD>rer les traductions
*/
class Translate {
var $dir;
var $defaultlang;
var $tab_loaded=array();
var $tab_translate=array();
2004-07-13 23:25:53 +02:00
2003-05-02 12:33:06 +02:00
/**
2005-01-02 17:57:37 +01:00
* \brief Constructeur de la classe
2005-10-30 01:42:54 +02:00
* \param dir Repertoire racine des fichiers de traduction
*/
function Translate($dir = "")
2005-10-30 01:42:54 +02:00
{
2004-07-13 23:25:53 +02:00
$this->dir=$dir;
2005-10-30 02:07:00 +01:00
}
/**
* \brief Accesseur de this->defaultlang
* \param defaultlang Langue par defaut <EFBFBD> utiliser
*/
function setDefaultLang($defaultlang)
{
2005-10-30 01:42:54 +02:00
if ($defaultlang == 'auto')
{
2005-10-30 02:07:00 +01:00
$langpref=$_SERVER['HTTP_ACCEPT_LANGUAGE'];
$langpref=eregi_replace(";[^,]*","",$langpref);
$langpref=eregi_replace("-","_",$langpref);
2005-10-30 02:52:48 +01:00
$langlist=split("[;,]",$langpref);
$langpart=split("_",$langlist[0]);
if (isset($langpart[1])) $defaultlang=strtolower($langpart[0])."_".strtoupper($langpart[1]);
else $defaultlang=strtolower($langpart[0])."_".strtoupper($langpart[0]);
2005-10-30 01:42:54 +02:00
}
2005-10-30 02:07:00 +01:00
2005-10-30 03:00:03 +01:00
$this->defaultlang=$defaultlang;
2004-07-13 23:25:53 +02:00
}
2003-05-02 12:33:06 +02:00
2005-10-30 02:07:00 +01:00
/**
* \brief Accesseur de this->defaultlang
* \return string Langue utilis<EFBFBD>e
*/
function getDefaultLang()
{
return $this->defaultlang;
}
/**
\brief Positionne environnement PHP en fonction du langage
\remarks Le code langue long (fr_FR, en_US, ...) doit <EFBFBD>tre positionn<EFBFBD>
\return int >0 si ok, <0 so ko
*/
function setPhpLang()
{
//dolibarr_syslog("Translate::set_php_lang: code_lang=$code_lang code_lang_tirer=$code_lang_tiret");
$code_lang_tiret=ereg_replace('_','-',$this->defaultlang);
setlocale(LC_ALL, $this->defaultlang); // Compenser pb de locale avec windows
setlocale(LC_ALL, $code_lang_tiret);
if (defined("MAIN_FORCE_SETLOCALE_LC_ALL") && MAIN_FORCE_SETLOCALE_LC_ALL) setlocale(LC_ALL, MAIN_FORCE_SETLOCALE_LC_ALL);
if (defined("MAIN_FORCE_SETLOCALE_LC_TIME") && MAIN_FORCE_SETLOCALE_LC_TIME) setlocale(LC_TIME, MAIN_FORCE_SETLOCALE_LC_TIME);
if (defined("MAIN_FORCE_SETLOCALE_LC_NUMERIC") && MAIN_FORCE_SETLOCALE_LC_NUMERIC) setlocale(LC_NUMERIC, MAIN_FORCE_SETLOCALE_LC_NUMERIC);
if (defined("MAIN_FORCE_SETLOCALE_LC_MONETARY") && MAIN_FORCE_SETLOCALE_LC_MONETARY) setlocale(LC_MONETARY, MAIN_FORCE_SETLOCALE_LC_MONETARY);
return 1;
}
2005-01-02 17:57:37 +01:00
/**
* \brief Charge en m<EFBFBD>moire le tableau de traduction pour un domaine particulier
* Si le domaine est deja charg<EFBFBD>, la fonction ne fait rien
* \param domain Nom du domain (fichier lang) <EFBFBD> charger
2005-10-30 01:42:54 +02:00
* \param alt Utilise le fichier alternatif meme si fichier dans la langue est trouv<EFBFBD>e
2005-01-02 17:57:37 +01:00
*/
function Load($domain,$alt=0)
{
if (isset($this->tab_loaded[$domain]) && $this->tab_loaded[$domain]) { return; } // Le fichier de ce domaine est deja charg<72>
// Repertoire de traduction
$scandir = $this->dir."/".$this->defaultlang;
2004-07-13 23:25:53 +02:00
$file_lang = $scandir . "/$domain.lang";
2005-10-30 01:42:54 +02:00
$filelangexists=is_file($file_lang);
2005-10-30 01:42:54 +02:00
if ($alt || ! $filelangexists)
{
// Repertoire de la langue alternative
if ($this->defaultlang != "en_US") $scandiralt = $this->dir."/en_US";
else $scandiralt = $this->dir."/fr_FR";
2004-07-13 23:25:53 +02:00
$file_lang = $scandiralt . "/$domain.lang";
2005-10-30 01:42:54 +02:00
$filelangexists=is_file($file_lang);
$alt=1;
2004-07-13 23:25:53 +02:00
}
2005-10-30 01:42:54 +02:00
if ($filelangexists)
{
if($fp = @fopen($file_lang,"rt"))
{
$finded = 0;
2005-10-30 01:42:54 +02:00
while (($ligne = fgets($fp,4096)) && ($finded == 0))
{
if ($ligne[0] != "\n" && $ligne[0] != " " && $ligne[0] != "#")
{
$tab=split('=',$ligne,2);
//print "Domain=$domain, found a string for $tab[0] with value $tab[1]<br>";
2005-10-30 01:42:54 +02:00
if (! isset($this->tab_translate[$tab[0]])) $this->tab_translate[$tab[0]]=trim(isset($tab[1])?$tab[1]:'');
}
}
fclose($fp);
2003-05-02 12:33:06 +02:00
// Pour les langues aux fichiers parfois incomplets, on charge la langue alternative
2005-10-30 01:42:54 +02:00
if (! $alt && $this->defaultlang != "fr_FR" && $this->defaultlang != "en_US")
{
dolibarr_syslog("translate::load loading alternate translation file");
$this->load($domain,1);
}
2003-05-02 12:33:06 +02:00
$this->tab_loaded[$domain]=1; // Marque ce fichier comme charg<72>
}
}
2005-10-30 02:07:00 +01:00
}
2003-05-02 12:33:06 +02:00
2005-01-02 17:57:37 +01:00
/**
* \brief Retourne la liste des domaines charg<EFBFBD>es en memoire
* \return array Tableau des domaines charg<EFBFBD>es
*/
2005-10-30 01:42:54 +02:00
function list_domainloaded()
{
return join(",",array_keys($this->tab_loaded));
}
/**
* \brief Retourne la version traduite du texte pass<EFBFBD> en param<EFBFBD>tre
* Si il n'y a pas de correspondance pour ce texte, on cherche dans fichier alternatif
* et si toujours pas trouv<EFBFBD>, il est retourn<EFBFBD> tel quel
* \param str chaine a traduire
* \param param1 chaine de param1
* \param param2 chaine de param1
* \param param3 chaine de param1
2005-01-09 19:08:32 +01:00
* \return string chaine traduite
*/
2005-10-30 01:42:54 +02:00
function trans($str, $param1='', $param2='', $param3='')
{
return $this->transnoentities($str,htmlentities($param1),htmlentities($param2),htmlentities($param3));
}
2005-10-30 02:07:00 +01:00
/**
* \brief Retourne la version traduite du texte pass<EFBFBD> en param<EFBFBD>tre
* Si il n'y a pas de correspondance pour ce texte, on cherche dans fichier alternatif
* et si toujours pas trouv<EFBFBD>, il est retourn<EFBFBD> tel quel
* \param str chaine a traduire
* \param param1 chaine de param1
* \param param2 chaine de param1
* \param param3 chaine de param1
* \return string chaine traduite
*/
2005-10-30 02:07:00 +01:00
function transnoentities($str, $param1='', $param2='', $param3='')
{
if (isset($this->tab_translate[$str]) && $this->tab_translate[$str])
{
// Si la traduction est disponible
return sprintf($this->tab_translate[$str],$param1,$param2,$param3);
}
return $str;
}
2004-07-13 23:25:53 +02:00
2005-10-30 02:07:00 +01:00
/**
* \brief Retourne la version traduite du texte pass<EFBFBD> en param<EFBFBD>tre compl<EFBFBD>t<EFBFBD> du code pays
* \param str chaine a traduire
2005-03-01 22:44:32 +01:00
* \param countrycode code pays (FR, ...)
* \return string chaine traduite
*/
2005-10-30 02:07:00 +01:00
function transcountry($str, $countrycode)
{
if ($this->tab_translate["$str$countrycode"]) return $this->trans("$str$countrycode");
else return $this->trans("$str");
}
/**
2005-01-02 17:57:37 +01:00
* \brief Retourne la liste des langues disponibles
* \return array list of languages
*/
function get_available_languages($langdir=DOL_DOCUMENT_ROOT)
{
// On parcour le r<>pertoire langs pour d<>tecter les langues disponibles
$handle=opendir($langdir ."/langs");
$langs_available=array();
while ($file = trim(readdir($handle)))
{
if (eregi('^[a-z]+_[A-Z]+',$file))
{
array_push($langs_available,$file);
}
}
return $langs_available;
2003-05-02 12:33:06 +02:00
}
/**
2005-01-02 17:57:37 +01:00
* \brief Exp<EFBFBD>die le header correct et retourne le d<EFBFBD>but de la page html
* [en] Send header and return a string of html start page
* \return string html header avec charset
*/
function lang_header()
2003-05-02 12:33:06 +02:00
{
$this->load("main");
$charset=$this->trans("charset");
if (! $charset) $charset="iso-8859-1";
//header("Content-Type: text/html; charset=$charset");
$texte = "<head>\n<meta http-equiv=\"Content-Type\" content=\"text/html; charset=$charset\">\n";
return $texte;
}
2003-05-02 12:33:06 +02:00
/**
* \brief Renvoi si le fichier $filename existe dans la version de la langue courante ou alternative
* \param filename nom du fichier <EFBFBD> rechercher
* \param searchalt cherche aussi dans langue alternative
* \return boolean true si existe, false sinon
*/
2005-10-30 02:07:00 +01:00
function file_exists($filename,$searchalt=0)
{
// Test si fichier dans r<>pertoire de la langue
$htmlfile=$this->dir."/".$this->defaultlang."/".$filename;
if (is_readable($htmlfile)) return true;
if ($searchalt) {
// Test si fichier dans r<>pertoire de la langue alternative
if ($this->defaultlang != "en_US") $htmlfilealt = $this->dir."/en_US/".$filename;
else $htmlfilealt = $this->dir."/fr_FR/".$filename;
if (is_readable($htmlfilealt)) return true;
}
return false;
}
/**
* \brief Renvoi le fichier $filename dans la version de la langue courante, sinon alternative
* \param filename nom du fichier <EFBFBD> rechercher
* \param searchalt cherche aussi dans langue alternative
*/
2005-10-30 02:07:00 +01:00
function print_file($filename,$searchalt=0)
{
// Test si fichier dans r<>pertoire de la langue
$htmlfile=$this->dir."/".$this->defaultlang."/".$filename;
2005-10-30 02:07:00 +01:00
if (is_readable($htmlfile))
{
include $htmlfile;
return true;
}
if ($searchalt) {
// Test si fichier dans r<>pertoire de la langue alternative
if ($this->defaultlang != "en_US") $htmlfilealt = $this->dir."/en_US/".$filename;
else $htmlfilealt = $this->dir."/fr_FR/".$filename;
2005-10-30 02:07:00 +01:00
if (is_readable($htmlfilealt))
{
include $htmlfilealt;
return true;
}
}
return false;
}
2003-05-02 12:33:06 +02:00
}
?>