Pman.Gnumeric.js
[Pman.Core] / Pman.I18n.js
index bd47d24..eefef4d 100644 (file)
 * includes standard pulldowns.
 */
 
+
+
 Pman.I18n = {
     
+    
+    
     /**
      * turn zh_HK,en  => into Chinese(HK) , English
      * @arg type type (c = country, l = lang)
@@ -43,14 +47,29 @@ Pman.I18n = {
     toName: function(type, code) 
     {
         var ret = code;
-        var lang = Pman.Login.authUser.lang || 'en'
-        Roo.each(Pman.I18N.Data[lang], function(d) {
+        
+        var lang = 'en';
+        
+        if(typeof(Pman.Login) != 'undefined' && typeof(Pman.Login.authUser.lang) == 'undefined'){
+            lang = Pman.Login.authUser.lang;
+        }
+        
+        if (code.indexOf('_') > -1) {
+            var clang = code.split('_').shift();
+            var cc = code.split('_').pop();
+            return this.toName('l', clang.toLowerCase()) + ' (' +  this.toName('c', cc.toUpperCase()) + ')';
+        }
+        
+        
+        Roo.each(Pman.I18n.Data[lang][type], function(d) {
             if (d.code == code) {
                 ret = d.title;
-                return false;
+                return false; // stop!
             }
+            return true;
         });
         return ret;
+        
     },
     /**
      * List to Objects
@@ -87,14 +106,84 @@ Pman.I18n = {
             'title'
         ]
        },
-    // DEPRECIATED...
+    
+    
+    
+    /**
+     * dataToProxy
+     * return proxy data for a pulldown.
+     * @param {String} type  eg. l,c,m (lang/country/money)
+     *    
+     * usage:
+     {
+      xtype: 'Store',
+      xns: Roo.data,
+      reader : Pman.I18n.reader,
+      proxy : {
+         xtype : 'MemoryProxy',
+         xns : Roo.data,
+         data : Pman.I18n.dataToProxy('l'), // eg. language
+         remoteSort : false,
+         sortInfo : { field : 'title' , direction : 'ASC' } 
+      }
+         * 
+         *}
+     * 
+     * 
+     */
+    
+    dataToProxy : function(type)
+    {
+        var lang = Pman.Login.authUser.lang || 'en';
+        return Pman.I18n.Data[lang][type];
+    },
+    
+    /**
+     * simpleStoreData:
+     * return a simplestore to be used by country/language combos
+     * eg.
+     * store: (function() {
+            return Pman.I18n.simpleStoreData('c');
+        })(),
+     *
+     * @param {Char} type (c,l,m)
+     * @param {function} (optional) filter language list
+     *     called with object { code: xxx , title: xxx }
+     *     if it exists then returning false will hide the entry.
+     */
+    
+    simpleStoreData : function(type, filter)
+    {
+        filter = typeof(filter) == 'undefined' ? false : filter;
+        var lang =  'en';
+        try {
+            lang = Pman.Login.authUser.lang;
+        } catch (E) {};
+        lang = lang || 'en';
+        var ret = [];
+        Roo.each(Pman.I18n.Data[lang][type], function (o) {
+            if (filter !== false && filter(o) === false) {
+                return;
+            }
+            ret.push([ o.code, o.title ]);
+        });
+        
+         ret = ret.sort(function(a,b) {
+            if (a[0] == '**') { return 1; } // other always at end..
+            if (b[0] == '**') { return -1; } // other always at end..
+            return a[1]  > b[1] ? 1 : -1;
+        });
+        
+        return ret;
+    },
+    // DEPRECIATED... -- see dataToProxy
     countryStore : function() { return {
         
         // load using HTTP
         xtype: 'Store',
         proxy: {
             xtype: 'HttpProxy',
-            url: baseURL + '/I18N/Country.html',
+            url: baseURL + '/Core/I18n/Country.html',
             method: 'GET'
         },
         
@@ -116,7 +205,7 @@ Pman.I18n = {
         xtype: 'Store',
         proxy: {
             xtype: 'HttpProxy',
-            url: baseURL + '/I18N/Lang.html',
+            url: baseURL + '/Core/I18n/Lang.html',
             method: 'GET'
         },
         
@@ -137,7 +226,7 @@ Pman.I18n = {
         xtype: 'Store',
         proxy: {
             xtype: 'HttpProxy',
-            url: baseURL + '/I18N/Currency.html',
+            url: baseURL + '/Core/I18n/Currency.html',
             method: 'GET'
         },
         
@@ -378,5 +467,4 @@ Pman.I18n = {
      
     
 };
-
-