'm' => array(
'USD', 'HKD', 'GBP', 'CNY', 'SGD', 'JPY'
),
- 'add_l'=> array(), // additional languages...
+ 'add_l'=> array(), // key -> value additional languages...
'add_c'=> array(), // additional countries...(eg. '-R' => 'Regional' )
'add_m'=> array(), // additional currencies...
function applyFilters($q, $au)
{
-
- DB_DataObject::debugLevel(1);
+ $this->buildDB();
+ //DB_DataObject::debugLevel(1);
if (!empty($q['query']['_with_en'])) {
$this->buildDB(); // ensure we have the full database...
}
}
-
function translate($inlang,$ltype,$kval)
{
$x = DB_DataObject::factory('i18n');
$x->ltype = $ltype;
- $x->inlang= $inlang;
$x->lkey = $kval;
- $x->limit(1);
- $x->find(true);
- return $x->lval;
+ $x->inlang= $inlang;
+ $fallback = clone($x);
+ $x->limit(1);
+ if ($x->find(true) && !empty($x->lval)) {
+ return $x->lval;
+ }
+ $fallback->inlang = 'en';
+ if ($fallback->find(true) && !empty($fallback->lval)) {
+ return $fallback->lval;
+ }
+ return $kval;
}
if (!empty($cfg['add_c'])) {
$ret = array_merge($ret, array_keys($cfg['add_c']));
}
+
+
+
$ret[] = '**';
break;
require_once 'I18Nv2/Language.php';
$c = new I18Nv2_Language('en');
$ret = array_keys($c->codes); // we need to make sure these are lowercase!!!
-// print_r($cfg['add_l']);exit;
-// $tolang = explode('_', array_keys($cfg['add_l']));
-// $tolang[0] = strtolower($tolang[0]);
-// implode('_', $tolang);
+
+
foreach ($cfg['add_l'] as $k=>$v){
+ // make sure that add_l is formated correctly.. (lower_UPPER?)
$tolang = explode('_', $k);
$tolang[0] = strtolower($tolang[0]);
$tolang = implode('_', $tolang);
+
+ unset($cfg['add_l'][$k]); // if they match..unset first.. then set
+
$cfg['add_l'][$tolang] = $v;
- unset($cfg['add_l'][$k]);
}
if (!empty($cfg['add_l'])) {
$ret = array_merge($ret, array_keys($cfg['add_l']));
$ret[] = '**';
break;
}
-
- foreach ($ret as $k=>$v) {
- $ret[$k] = ($t=='l') ? $ret[$k] : strtoupper($v);
- if($t=='l') echo '<PRE>'.print_r($ret);
+ if (!empty($cfg[$t]) && is_array($cfg[$t])) {
+ // then there is a filter. - we should include all of them, even if they are not relivatn??
+ return $cfg[$t]; //array_intersect($cfg[$t], $ret);
+
}
+
+ // why upper case everyting?!?!?
+
+ //foreach ($ret as $k=>$v) {
+ // $ret[$k] = ($t=='l') ? $ret[$k] : strtoupper($v);
+ //}
return $ret;
}
$complete = $x->fetchAll('lkey');
$list = $this->availableCodes($ltype);
-
+ //echo '<PRE>'; print_r($list);
foreach($list as $lkey) {
// skip ones we know we have done...
if (in_array($lkey, $complete)) {
continue;
}
+ if (empty($lkey)) { // not sure why we get empty values here.
+ continue;
+ }
$x = DB_DataObject::factory('I18n');
$x->ltype = $ltype;
$x->lkey = $lkey;
{
static $cache;
+
+
$cfg = $this->cfg();
if (empty($k)) {
return '??';
//$lbits = explode('_', strtoupper($lang));
$lbits = explode('_', $lang);
-
+ $orig_lang = $lang;
$lang = $lbits[0];
if (!isset($cache[$lang])) {
if ($k == '**') {
return 'Other / Unknown';
}
- $ret = $cache[$lang][$type]->getName($k);
- if ($type == 'l') {
+
+ // for languages if we get zh_HK then we write out Chinese ( HK )
+
+
+ if ($type == 'l' && strpos($k, '_') > -1) {
$tolang = explode('_', $k);
- $tolang[0] = strtolower($tolang[0]);
- print_r($tolang);
- $ret = $cache[$lang][$type]->getName($tolang[0]);
- if (count($tolang) > 1) {
- $ret.= '('.$tolang[1].')';
- }
+ $ret = $cache[$lang][$type]->getName(strtolower($tolang[0])) . '('.$tolang[1].')';
+
+ } else {
+ $ret = $cache[$lang][$type]->getName($k);
}
+
+ if ($orig_lang == 'zh_HK' || $orig_lang == 'zh_TW' ) {
+ // then translation is by default in simplified.
+ //print_r($ret);
+ $ret = @iconv("UTF-8", "GB2312//IGNORE", $ret);
+ //print_r($ret);
+ $ret = @iconv("GB2312", "BIG5//IGNORE", $ret);
+ //print_r($ret);
+
+ $ret = @iconv("BIG5", "UTF-8//IGNORE", $ret);
+ //print_r($ret);
+ }
+
+
+
// our wierd countries/langs etc..
if (isset($cfg['add_' . $type][$k])) {
return $cfg['add_' . $type][$k];