Pman.Tab.AdminEnum.bjs
[Pman.Admin] / Translations.php
index b21981e..a9ce759 100644 (file)
@@ -2,11 +2,18 @@
 
 
 /**
- * Translation
- * - 
- * 
+ * Pman_Admin_Translation:
+ * - the latest version of this....
+ *
+ * Files:
+ *   output / current state:    ROOT/_translations_/MODULE.js
+ *   input:       Pman::moduleJavascriptFilesInfo($MODULE)->translation_data
  * 
  * 
+ * see:
+ * Pman->modulesList()
+ *
+ * Note: at present the front end does not query this to get a list of modules..
  * 
  */
 
@@ -19,6 +26,8 @@ class Pman_Admin_Translations extends Pman
     var $fn = '';
     var $data = array();
     
+    var $original = array() ; // filename => array( orig_string > orig_string)
+    var $originalKeys = array() ; // md5(filename-orig_string) => filename
     
     function getAuth()
     {
@@ -31,8 +40,36 @@ class Pman_Admin_Translations extends Pman
         return true;
     }
     
-    function get()
+    
+    function get($module, $opts = Array())
     {
+        
+        if (!empty($module)) {
+            $this->init();
+            //DB_DataObject::debugLevel(1);
+            require_once 'Services/JSON.php';
+            $d = DB_DataObject::factory('translations');
+            $d->module = $module;
+            $d->selectAdd();
+            $d->selectAdd('distinct(tlang) as tlang');
+            header('Content-type: text/javascript');
+            $langs= $d->fetchAll('tlang');
+            foreach($langs as $lang) {
+                // output the translations strings file..
+                
+                    
+                $this->loadOriginalStrings($module);
+                
+                $data = $this->loadTranslateDB($lang,$module);
+                
+                $j = new Services_JSON();
+                echo "_T.{$lang}= Roo.apply( _T.{$lang} || { }, " .  $j->stringify($data, null, 4) . ");\n";
+                
+            }
+            exit;
+            
+        }
+        
         // load and parse json file containing all translations...
         if (isset($_REQUEST['id'])) {
             return $this->post();
@@ -40,32 +77,35 @@ class Pman_Admin_Translations extends Pman
         if (empty($_REQUEST['lang']) || !preg_match('/^[A-Z_]+$/i', $_REQUEST['lang'])) {
             $this->jerr("NO LANG / INVALID LANG");
         }
-        $fm = HTML_FlexyFramework::get();
-        $enable = explode(',', $fm->enable);
+         
+        $enable = $this->modulesList();
+        
         if (empty($_REQUEST['module']) || !in_array($_REQUEST['module'], $enable)) {
             $this->jerr("NO MODULE / INVALID MODULE");
         }
         
+        
         $lang = $_REQUEST['lang'];
         $module = $_REQUEST['module'];
         
         
-        $data = $this->loadOriginalStrings($lang,$module); // what needs translating..
+         $this->loadOriginalStrings($module); // what needs translating..
         
-        $translated_data = $this->loadTranslate($lang, $module); // the 'database!'
+        $ff = $this->bootLoader;
+        if (empty($ff->Pman['public_cache_dir'])) {
+            $this->jerr("public_cache_dir has not been set up");
+        }
         
         
         
-        // overlay translated..
-        if (empty($translated_data)) {
-            // try using old data!!!!
-            $translated_data = $this->loadOld($lang,$data); // phase out???
-                    
-        }
+        $translated_data = $this->loadTranslateDB($lang, $module); // the 'database!'
+        
+        
+       // echo '<PRE>';print_R($data);exit;
         // covert data ready to send back..
         
         $ret = array();
-        foreach($data as $k=>$ar) {
+        foreach($this->original as $k=>$ar) {
             foreach($ar as $tr=>$trv) {
                 // $hint = isset($hints[$tr]) ? $hints[$tr] : '';
                 $key = md5($k.'-'.$tr);
@@ -89,12 +129,12 @@ class Pman_Admin_Translations extends Pman
         
     }
     
-      function post(
+    function post($v
     {
          
-        $fm = HTML_FlexyFramework::get();
-        $enable = explode(',',   $fm->enable);
-        if (empty($_REQUEST['module']) || !in_array($_REQUEST['module'], $enable)) {
+         
+        
+        if (empty($_REQUEST['module']) || !in_array($_REQUEST['module'], $this->modulesList())) {
             $this->jerr("NO MODULE / INVALID MODULE");
         }
         
@@ -102,15 +142,21 @@ class Pman_Admin_Translations extends Pman
         //txt  é \85ç\9b®
         list($lang,$id) = explode('/', $_REQUEST['id']);
         
+        $this->loadOriginalStrings($_REQUEST['module']);
+        
+        $data = $this->loadTranslateDB($lang,$_REQUEST['module']);
         
-        $data = $this->loadTranslate($lang,$_REQUEST['module']);
-        if (empty($data)) {
-            // try using old data!!!!
-            $data = $this->loadOld($lang,$data); // phase out???
-                    
-        }
         $data[$id] = $_REQUEST['txt'];
         
+        if (!isset($this->originalKeys[$id])) {
+            
+            
+            $this->jerr("invalid key ?");
+        }
+        
+        $this->saveTranslateDB($lang,$_REQUEST['module'],$this->originalKeys[$id], $id, $_REQUEST['txt']);
+        
+        
         
         $this->writeTransMod($lang,$_REQUEST['module'], $data);
         // write merged file..
@@ -123,64 +169,104 @@ class Pman_Admin_Translations extends Pman
      * load strings that need translating..
      */
     
-    function loadOriginalStrings($lang, $module)
+    function loadOriginalStrings($module)
     {
         // since this can handle errors better.!!?
+        $info = $this->moduleJavascriptFilesInfo($module);
+        //print_r($info);
+        $tfile =$info->basedir . '/'. $info->translation_data;
+         //var_dump($tfile);
+        if (empty($tfile) || !file_exists($tfile)) {
+            return array();
+        }
+        
+        
         require_once 'Services/JSON.php';
         $j = new Services_JSON();
+        $this->original = (array) $j->decode('{'. file_get_contents($tfile).'}');
+        ksort($this->original);
+
+        $this->originalKeys = array();
         
-        $ff = HTML_FlexyFramework::get();
-        $trans = file_get_contents(
-            $ff->rootDir . '/Pman/' . $module. "/compiled/_translation_.js");
-        
+        // 
+        foreach($this->original as $k=>$ar) {
+            foreach($ar as $tr=>$trv) {
+                $key = md5($k.'-'.$tr);
+                $this->originalKeys[$key] = $k;
+            }
+        }
         
-        return (array) $j->decode('{'. $trans .'}');
     }
     
      
     
     
-    /**
-     * 
-     * Load the user translated strings.
-     * 
+   
+    /***
+     *
+     * loadTranslateDB -
+     *
+     *
+     * @return key=>value list of translation_id=>tranlation.
+     *
+     *
      */
-    function loadTranslate($lang, $module)
+    
+    function loadTranslateDB($lang, $module)
     {
-         
-        $fn = $this->getTransFilename($lang,$module);
         
-         
+        //DB_DataObject::debugLevel(1);
+        $d = DB_DataObject::factory('translations');
+        $d->module = $module;
+        $d->tlang = $lang;
+        $d->whereAdd('LENGTH(tval) > 0');
+        $ret = array();
+        
+        if ($d->count()) {
+            // since key includes file 
+            $ret = $d->fetchAll('tkey','tval'); /// shoudl we include updates
+        }
+        // no data is contained in the database, we should initialize it, if we can
+        $info  = $this->moduleJavascriptFilesInfo($module);
+        $fn = $info->module_dir.'/_translations_/'.$lang.'.js';
+        
+       
         if (!file_exists($fn)) {
-            return array();
+            ///Die($fn ." does not exist?");
+            return $ret;
         }
         
-        return (array) json_decode(file_get_contents($fn));
-        //$this->data = (array) $j->decode(substr(file_get_contents($this->fn), strlen($this->prefix), -1));
-    }
-    
-    
-    function loadTranslateDB($lang, $module)
-    {
-        $d = DB_DataObject('translations');
-        $d->module = $module;
-        $d->lang = $lang;
-        $d->find();
-        while ($d->fetch()) {
-            if (!isset($ret[$d->tfile])) {
-                $ret[$d->tfile] = array( $d->tkey => $d->tval );
+        
+        $default = (array) json_decode(file_get_contents($fn));
+        //echo '<PRE>';print_r($default); print_r($this->originalKeys);exit;
+        
+        
+        
+        foreach($default as $k=>$v) {
+            if (isset($ret[$k])) {
+                continue; // skip database already holds a version of this translation.
+            }
+            // is it relivant anymore..
+            if (!isset($this->originalKeys[$k])) {
                 continue;
             }
-            $ret[$d->tfile][$d->tkey] = $d->tval;
+            
+            // it's current..
+            $this->saveTranslateDB($lang, $module, $this->originalKeys[$k], $k, $v);
+            $ret[$k] = $v;
+            
+            
         }
         return $ret;
+        
+         
     }
     
     function saveTranslateDB($lang, $module, $tfile, $tkey, $tval)
     {
-        $d = DB_DataObject('translations');
+        $d = DB_DataObject::factory('translations');
         $d->module = $module;
-        $d->lang = $lang;
+        $d->tlang = $lang;
         $d->tfile = $tfile;
         $d->tkey = $tkey;
         if ($d->find(true)) {
@@ -215,49 +301,27 @@ class Pman_Admin_Translations extends Pman
         return $fn;
     }
     
-    
-  
-    function loadOld($lang,$data)
-    {
-        // need the old for hinting..
-        
-        // this is ok - as it's inside this module.
-        $old = (array) json_decode(file_get_contents(dirname(__FILE__).'/data/oldeng.js'));
-        //print_r($old);
-        // contains key/value of data..
-        $prefix = '_T["'.$lang .'"]=';
-        $trans = (array) json_decode(substr(file_get_contents(
-            dirname(__FILE__).'/data/lang.' . $lang . '.js'
-        ), strlen($prefix), -1));
-        
-       // echo '<PRE>';print_r($trans);
-        
-        $hints = array();
-        foreach($old as $k=>$v) {
-            if (isset($trans[$k]) && empty($hints[$v])) {
-                $hints[$v] = $trans[$k];
-            }
-        }
-        $translated_data = array();
-        foreach($data as $k=>$ar) {
-                foreach($ar as $tr=>$trv) {
-                $key = md5($k.'-'.$tr);
-                if (isset($hints[$tr])) {
-                    $translated_data[$key] = $hints[$tr];
-                }
-            }
-        }
-        // $this->writeTransMod($lang, $module, $translated_data);
-        //echo '<PRE>';print_r($hints);
-        return $translated_data;
-        
-    }
+     
+    /**
+     * Writes a file MODULE.js inside of _translations_
+     *
+     * this should contain all contents from all the language directroris for this
+     * module
+     *
+     */
     
     function writeTransMod($lang, $module, $data)
     {
+        //print_R($data);
+        
+        
         $fn = $this->getTransFilename($lang, $module);
-        file_put_contents($fn, json_encode($data));
-         $ff = HTML_FlexyFramework::get();
+        require_once 'Services/JSON.php';
+        $j = new Services_JSON();
+        
+        file_put_contents($fn, $j->stringify($data, null, 4));
+        
+        $ff = HTML_FlexyFramework::get();
         $base = $ff->rootDir.'/_translations_' ;
         $out = '';
         foreach(scandir($base) as $l) {
@@ -265,8 +329,9 @@ class Pman_Admin_Translations extends Pman
             if (!strlen($l) || $l[0] == '.' || !is_dir("$base/$l") || !file_exists("$base/$l/$module.json")) {
                 continue;
             }
-              
-            $out .= "_T.$l= Roo.apply( _T.$l || { }, " . file_get_contents("$base/$l/$module.json") . ");\n";
+            // decode as our temp files contain spaces..
+            $jdata = json_decode(file_get_contents("$base/$l/$module.json") );
+            $out .= "_T.$l= Roo.apply( _T.$l || { }, " . json_encode($jdata) . ");\n";
         }
         //var_dump($out);
         if (strlen($out)) {
@@ -275,6 +340,6 @@ class Pman_Admin_Translations extends Pman
         //$this->writeTrans($lang);
     }
      
-    
+     
     
 }
\ No newline at end of file