getUniqueID(self::TABLENAME); } /** * Initialize Language Schema * @access private */ static function __initSchema() { $hastable = Vtiger_Utils::CheckTable(self::TABLENAME); if(!$hastable) { Vtiger_Utils::CreateTable( self::TABLENAME, '(id INT NOT NULL PRIMARY KEY, name VARCHAR(50), prefix VARCHAR(10), label VARCHAR(30), lastupdated DATETIME, sequence INT, isdefault INT(1), active INT(1))', true ); global $languages, $adb; foreach($languages as $langkey=>$langlabel) { $uniqueid = self::__getUniqueId(); $adb->pquery('INSERT INTO '.self::TABLENAME.'(id,name,prefix,label,lastupdated,active) VALUES(?,?,?,?,?,?)', Array($uniqueid, $langlabel,$langkey,$langlabel,date('Y-m-d H:i:s',time()), 1)); } } } /** * Register language pack information. */ static function register($prefix, $label, $name='', $isdefault=false, $isactive=true, $overrideCore=false) { self::__initSchema(); $prefix = trim($prefix); // We will not allow registering core language unless forced if(strtolower($prefix) == 'en_us' && $overrideCore == false) return; $useisdefault = ($isdefault)? 1 : 0; $useisactive = ($isactive)? 1 : 0; global $adb; $checkres = $adb->pquery('SELECT * FROM '.self::TABLENAME.' WHERE prefix=?', Array($prefix)); $datetime = date('Y-m-d H:i:s'); if($adb->num_rows($checkres)) { $id = $adb->query_result($checkres, 0, 'id'); $adb->pquery('UPDATE '.self::TABLENAME.' set label=?, name=?, lastupdated=?, isdefault=?, active=? WHERE id=?', Array($label, $name, $datetime, $useisdefault, $useisactive, $id)); } else { $uniqueid = self::__getUniqueId(); $adb->pquery('INSERT INTO '.self::TABLENAME.' (id,name,prefix,label,lastupdated,isdefault,active) VALUES(?,?,?,?,?,?,?)', Array($uniqueid, $name, $prefix, $label, $datetime, $useisdefault, $useisactive)); } self::log("Registering Language $label [$prefix] ... DONE"); } /** * De-Register language pack information * @param String Language prefix like (de_de) etc */ static function deregister($prefix) { $prefix = trim($prefix); // We will not allow deregistering core language if(strtolower($prefix) == 'en_us') return; self::__initSchema(); global $adb; $checkres = $adb->pquery('DELETE FROM '.self::TABLENAME.' WHERE prefix=?', Array($prefix)); self::log("Deregistering Language $prefix ... DONE"); } /** * Get all the language information * @param Boolean true to include in-active languages also, false (default) */ static function getAll($includeInActive=false) { global $adb; $hastable = Vtiger_Utils::CheckTable(self::TABLENAME); $languageinfo = Array(); if($hastable) { if($includeInActive) $result = $adb->query('SELECT * FROM '.self::TABLENAME); else $result = $adb->query('SELECT * FROM '.self::TABLENAME . ' WHERE active=1'); for($index = 0; $index < $adb->num_rows($result); ++$index) { $resultrow = $adb->fetch_array($result); $prefix = $resultrow['prefix']; $label = $resultrow['label']; $languageinfo[$prefix] = $label; } } else { global $languages; foreach($languages as $prefix=>$label) { $languageinfo[$prefix] = $label; } } return $languageinfo; } } ?>