X-Git-Url: http://git.roojs.org/?p=Pman.Core;a=blobdiff_plain;f=I18n.php;h=8367964c9ef63a8bb91a933936131919a577046c;hp=8ede23cc15b7c59c9e225c441068025cea89057f;hb=refs%2Fheads%2Fwip_alan_T5884_add_photo_to_report;hpb=a871e016763afcdfed4e09c30170bdd75ff97894 diff --git a/I18n.php b/I18n.php index 8ede23cc..8367964c 100644 --- a/I18n.php +++ b/I18n.php @@ -47,7 +47,7 @@ */ require_once 'Pman.php'; -class Pman_Core_I18N extends Pman +class Pman_Core_I18n extends Pman { @@ -69,9 +69,10 @@ class Pman_Core_I18N extends Pman $ff= HTML_FlexyFramework::get(); - $opts = empty($ff->Pman_Core_I18N) ? (empty($ff->Pman_I18N) ? array() : $ff->Pman_I18N) : $ff->Pman_Core_I18N; + $opts = empty($ff->Pman_Core_I18N) ? + (empty($ff->Pman_I18N) ? array() : $ff->Pman_I18N) + : $ff->Pman_Core_I18N; - $i = DB_DataObject::Factory('I18n'); @@ -80,13 +81,105 @@ class Pman_Core_I18N extends Pman } - - function get($s ='') + function guessUsersLanguage() { + $this->sessionState(0); + + $lang = !$this->authUser || empty($this->authUser->lang ) ? 'en' : $this->authUser->lang; + /// verify the selected language.. $i = DB_DataObject::Factory('I18n'); - $i->buildDb(); + $i->ltype = 'l'; // string(1) not_null multiple_key + $i->lkey = $lang; // string(8) not_null + if (!$i->count()) { + $i = DB_DataObject::Factory('I18n'); + $i->buildDb(); + + $i = DB_DataObject::Factory('I18n'); + $i->ltype = 'l'; // string(1) not_null multiple_key + $i->lkey = $lang; + if (!$i->count()) { + $this->jerr('invalid lang configured: ' . $lang); + } + } + + + return explode('_', $lang); + } + + function get($s ='', $opts=array()) + { + $this->sessionState(0); + $lbits = $this->guessUsersLanguage(); + + if ($this->authUser && !empty($_REQUEST['_debug'])) { + DB_DataObject::debugLevel(1); + } + + + + $i = DB_DataObject::Factory('I18n'); + $i->is_active = 1; + switch($s) { + case 'Lang': + + + $i->ltype = 'l'; + $i->applyFilters($_REQUEST, $this->authUser, $this); + $this->jdata($i->toTransList('l', implode('_',$lbits))); + break; + + case 'Country': + $i->ltype = 'c'; + $i->applyFilters($_REQUEST, $this->authUser, $this); + $this->jdata($i->toTransList('c', implode('_',$lbits))); + + break; + + case 'Currency': + $i->ltype = 'm'; + $i->applyFilters($_REQUEST, $this->authUser, $this); + $this->jdata($i->toTransList('m', implode('_',$lbits))); + break; + + case 'Timezone': + $ar = DateTimeZone::listAbbreviations(); + $ret = array(); + $tza = array(); + foreach($ar as $tl => $sar) { + foreach($sar as $tz) { + $tza[] = $tz['timezone_id']; + + } + } + $tza= array_unique($tza); + sort($tza); + foreach($tza as $tz) { + //filtering.. + if (empty($_REQUEST['q']) || + 0 === strcasecmp( + substr($tz,0, strlen($_REQUEST['q'])), + $_REQUEST['q']) + ) { + $ret[] = array('tz' => $tz); + } + + } + $this->jdata($ret); + + + + + + } + if (!empty($_REQUEST['debug'])) { + DB_DataObject::debugLevel(1); + } + + $i = DB_DataObject::Factory('I18n'); + $i->buildDB(); + $i = DB_DataObject::Factory('I18n'); $cfg = $i->cfg(); @@ -95,16 +188,21 @@ class Pman_Core_I18N extends Pman $ar = array(); foreach($langs as $lang) { - $rlang = array_shift(explode('_', strtoupper($lang))); + //$rlang = array_shift(explode('_', strtoupper($lang))); + $ll = explode('_', $lang); + $rlang = array_shift($ll); - $ar[$lang] = array( - 'l' => $i->toTransList('l', $rlang), - 'c' => $i->toTransList('c', $rlang), - 'm' => $i->toTransList('m', $rlang), - ); + $ar[$lang] = array(); + $i = DB_DataObject::Factory('I18n'); + $ar[$lang]['l'] = $i->toTransList('l', $rlang); + $i = DB_DataObject::Factory('I18n'); + $ar[$lang]['c'] = $i->toTransList('c', $rlang); + $i = DB_DataObject::Factory('I18n'); + $ar[$lang]['m'] = $i->toTransList('m', $rlang); } //echo '
';print_r($ar); header('Content-type: text/javascript'); + echo "Roo.namespace('Pman.I18n');"; echo 'Pman.I18n.Data = ' . json_encode($ar); exit; @@ -117,7 +215,7 @@ class Pman_Core_I18N extends Pman /** * translate (used by database building); * usage : - * require_once 'Pman/Core/I18N.php'; + * require_once 'Pman/Core/I18n.php'; * $x = new Pman_Core_I18N(); * $x->translate($this->authuser, 'c', 'US'); * @param au - auth User @@ -145,6 +243,54 @@ class Pman_Core_I18N extends Pman } + /** + * translate a list of items + * @param Pman_Core_DataObjects_Person $au Authenticated user + * @param String $type c/l/m + * @param String $k 'comma' seperated list of keys to translate + */ + + function translateList($au, $type, $k) + { + $ar = explode(',', $k); + $ret = array(); + foreach($ar as $kk) { + $ret[] = $this->translate($au, $type, $kk); + } + return implode(', ', $ret); + } + /** + * DO NOT USE THIS -- see core_curr_rates dataobject. + */ + + + function convertCurrency($val, $from, $to) + { + + return DB_DAtaObject::Factory('core_curr_rate')->convert($val,$from,$to); + + } + /** + * DO NOT USE THIS -- see core_curr_rates dataobject. + * + */ + + + + function loadRates() + { + static $rates = array(); + + if (!empty($rates)) { + $this->rates = $rates; + return; + } + + $this->rates = $rates = DB_DAtaObject::Factory('core_curr_rate')->currentRates(); + + } + + } \ No newline at end of file