Pman.Tab.AdminTranslations.bjs
[Pman.Admin] / Pman.Tab.AdminTranslations.bjs
1 {
2     "id": "roo-file-11",
3     "name": "Pman.Tab.AdminTranslations",
4     "parent": "Pman.Tab.Admin",
5     "title": "Admin - Translations",
6     "path": "/home/alan/gitlive/Pman.Admin/Pman.Tab.AdminTranslations.bjs",
7     "items": [
8         {
9             "listeners": {
10                 "|activate": "function() {\n    _this.panel = this;\n    if (_this.grid) {\n       _this.grid.getDataSource().reload(); \n    }\n}"
11             },
12             "background": true,
13             "fitContainer": true,
14             "fitToframe": true,
15             "title": "Translate App",
16             "xtype": "GridPanel",
17             "|xns": "Roo",
18             "items": [
19                 {
20                     "*prop": "grid",
21                     "xtype": "EditorGrid",
22                     "autoExpandColumn": "txt",
23                     "loadMask": true,
24                     "listeners": {
25                         "|render": "function() { \n    _this.grid = this; \n    //_this.dialog = Pman.Dialog.FILL_IN\n    if (_this.panel.active) {\n      _this.grid.getDataSource().reload(); \n    }\n}",
26                         "|beforeedit": "function(e) {\n    console.log('beforeedit');\n    //if (e.record.get('origtxt').indexOf('<') > -1) {\n                       // console.log(\"HTML EDITOR!!\");\n                     \n                    //    return false;\n                    //}\n                    if (e.record.get('txt').replace(/\\s+/, '').length) {\n                        return true;\n                    }\n                    if (e.record.get('suggest').length) {\n                        e.record.set('txt', e.record.get('suggest'));\n                    //    _this.saveRec(e.record);\n                        return;\n                    }\n                    \n                    \n                    \n                   \n                    var tl = e.record.get('id').split('/')[0];\n                  \n                    tl = (tl == 'zh_HK') ? 'zh-TW' : tl; \n                    tl = tl.replace('_', '-');\n                    var rec = e.record;\n                    \n                    \n                    \n                    Pman.gtranslate(e.record.get('origtxt'), 'en', tl, function(result) { \n                        if (typeof(result) == 'object') { //error\n                            return; \n                           }\n                        \n                        if (_this.grid.activeEditor) {\n                            _this.grid.activeEditor.setValue(result);\n                        } else {\n                            rec.set('txt',result);\n                            //_this.saveRec(rec);\n                        }\n\n                        //\n                        \n                        \n                        //console.log(result.translation);\n                    });\n                    \n                   \n                    \n                    return true;\n                } ",
27                         "|afteredit": "function (e)\n{\n    var saveRec  = function(rec)\n    {\n        var g = _this.grid;\n\n        //g.getView().el.mask('Saving');\n        Ext.Ajax.request({\n            url : baseURL + '/Admin/Translations.php',\n            method: 'POST',\n            params : {\n                id : rec.get('id'),\n                txt : rec.get('txt'),\n                lang :  _this.langCombo.getValue(),\n                module :  _this.modCombo.getValue()\n            },\n            success : function()\n            {\n                //g.getView().el.unmask();\n                //g.getDataSource().reload();\n            },\n            failure : function()\n            {\n                Ext.Msg.alert(\"Error\", \"There was a problem saving the data - try reloading\");\n               // g.getView().el.unmask();\n            }\n            \n    });\n        };\n    \n    saveRec.defer(1000, _this, [ e.record ]);\n}"
28                     },
29                     "clicksToEdit": 1,
30                     "|xns": "Roo.grid",
31                     "items": [
32                         {
33                             "*prop": "dataSource",
34                             "xtype": "Store",
35                             "|reader": "Pman.Readers.Category",
36                             "listeners": {
37                                 "|beforeload": "function (_self, opts)\n{\n\n                        if (!_this.langCombo || !_this.langCombo.getValue().length) {\n                            return false;\n                        }\n                        if (!_this.modCombo || !_this.modCombo.getValue().length) {\n                            return false;\n                        }\n                        opts.params = {\n                            lang :  _this.langCombo.getValue(),\n                            module :  _this.modCombo.getValue()\n                        };\n}"
38                             },
39                             "|xns": "Roo.data",
40                             "items": [
41                                 {
42                                     "*prop": "proxy",
43                                     "xtype": "HttpProxy",
44                                     "method": "GET",
45                                     "|url": "baseURL + '/Admin/Translations.php'",
46                                     "listeners": {},
47                                     "|xns": "Roo.data"
48                                 },
49                                 {
50                                     "xtype": "JsonReader",
51                                     "|xns": "Roo.data",
52                                     "*prop": "reader",
53                                     "root": "data",
54                                     "totalProperty": "total",
55                                     "id": "id",
56                                     "|fields": "[                    'id',             'tablename',             'tableid',             'colname',             'txt',             'lang',             { name:'updated', type:'date', dateFormat: 'Y-m-d H:i:s' },             { name:'origupdated', type:'date', dateFormat: 'Y-m-d H:i:s' },             'origtxt',             'msum',             'suggest'                  ]",
57                                     "listeners": {}
58                                 }
59                             ]
60                         },
61                         {
62                             "*prop": "toolbar",
63                             "xtype": "Toolbar",
64                             "listeners": {},
65                             "|xns": "Roo",
66                             "items": [
67                                 {
68                                     "xtype": "ComboBox",
69                                     "listeners": {
70                                         "|render": "function (_self)\n{\n  _this.modCombo = _self;\n}",
71                                         "|select": "function (combo, record, index)\n{\n  _this.grid.getDataSource().reload(); \n}"
72                                     },
73                                     "valueField": "module",
74                                     "displayField": "module",
75                                     "width": 200,
76                                     "typeAhead": false,
77                                     "editable": false,
78                                     "mode": "local",
79                                     "triggerAction": "all",
80                                     "emptyText": "Select Module",
81                                     "selectOnFocus": true,
82                                     "|xns": "Roo.form",
83                                     "items": [
84                                         {
85                                             "xtype": "SimpleStore",
86                                             "|xns": "Roo.data",
87                                             "*prop": "store",
88                                             "listeners": {},
89                                             "|fields": "['module']",
90                                             "|data": "(function() {             var modlist = [];             Roo.each( AppModules.split(','), function(mod) {            \n         modlist.push( [ mod ] );             });             return modlist;         })()"
91                                         }
92                                     ]
93                                 },
94                                 {
95                                     "xtype": "ComboBox",
96                                     "listeners": {
97                                         "|select": "function (combo, record, index)\n{\n  _this.grid.getDataSource().reload(); \n}",
98                                         "|render": "function (_self)\n{\n  _this.langCombo=_self;\n}"
99                                     },
100                                     "valueField": "lang",
101                                     "displayField": "ldisp",
102                                     "width": 200,
103                                     "typeAhead": false,
104                                     "editable": false,
105                                     "mode": "local",
106                                     "triggerAction": "all",
107                                     "emptyText": "Select Language",
108                                     "selectOnFocus": true,
109                                     "|xns": "Roo.form",
110                                     "items": [
111                                         {
112                                             "xtype": "SimpleStore",
113                                             "|xns": "Roo.data",
114                                             "*prop": "store",
115                                             "listeners": {},
116                                             "|fields": "['lang', 'ldisp']",
117                                             "|data": "[                                                [ 'zh_HK' , '\\u7E41\\u4E2D - Trad. Chin. (HK)' ],                         [ 'zh_CN', '\\u7C21\\u4E2D - Simp. Chin.' ]                     ]"
118                                         }
119                                     ]
120                                 }
121                             ]
122                         },
123                         {
124                             "xtype": "ColumnModel",
125                             "header": "Name",
126                             "width": 150,
127                             "dataIndex": "colname",
128                             "|renderer": "function(v,x,r) {                         var c = '#666';                         if (r.get('updated') < r.get('origupdated')) {                             c = 'red';                         }                                                  return '<div style=\"color:'+c+'\";>' +r.get('tableid')+ ':' + v + '</div>';                                              }",
129                             "listeners": {},
130                             "|xns": "Roo.grid",
131                             "*prop": "colModel[]"
132                         },
133                         {
134                             "xtype": "ColumnModel",
135                             "header": "Original",
136                             "width": 300,
137                             "dataIndex": "origtxt",
138                             "|renderer": "function(v,x,r) {                         var c = '#666';                         if (r.get('updated') < r.get('origupdated')) {                             c = 'red';                         }                         return '<div style=\"color:' + c+ '\">' +                                  Ext.util.Format.htmlEncode(v) + '</div>';                                              }",
139                             "listeners": {},
140                             "|xns": "Roo.grid",
141                             "*prop": "colModel[]"
142                         },
143                         {
144                             "xtype": "ColumnModel",
145                             "header": "Translated (Click to Edit)",
146                             "width": 150,
147                             "dataIndex": "txt",
148                             "|renderer": "function(v,x,r) {                                                   var c = '#666';                         if (r.get('updated') < r.get('origupdated')) {                             c = 'red';                         }                                                  return '<div style=\"color:' + c+ '\">' + Ext.util.Format.htmlEncode(v) + '</div>';                     }",
149                             "listeners": {},
150                             "|xns": "Roo.grid",
151                             "*prop": "colModel[]",
152                             "items": [
153                                 {
154                                     "xtype": "GridEditor",
155                                     "*prop": "editor",
156                                     "|xns": "Roo.grid",
157                                     "listeners": {},
158                                     "items": [
159                                         {
160                                             "xtype": "TextField",
161                                             "*prop": "field",
162                                             "|xns": "Roo.form",
163                                             "listeners": {}
164                                         }
165                                     ]
166                                 }
167                             ]
168                         }
169                     ]
170                 }
171             ]
172         }
173     ],
174     "permname": "",
175     "modOrder": "950"
176 }