- this.panel = parentLayout.addxtype({
- xtype: 'NestedLayoutPanel',
- xns: Roo,
- region : 'center',
- title : "Translate App",
- layout : {
- xtype: 'BorderLayout',
- xns: Roo,
- items : [
- {
- xtype: 'GridPanel',
- xns: Roo,
- listeners : {
- activate : function() {
- _this.panel = this;
- if (_this.grid) {
- _this.grid.getDataSource().reload();
- }
- }
- },
- background : true,
- fitContainer : true,
- fitToframe : true,
- region : 'center',
- title : "Text in interface",
- grid : {
- xtype: 'EditorGrid',
- xns: Roo.grid,
- listeners : {
- render : function() {
- _this.grid = this;
- //_this.dialog = Pman.Dialog.FILL_IN
- if (_this.panel.active) {
- _this.grid.getDataSource().reload();
- }
- },
- beforeedit : function(e) {
- console.log('beforeedit');
- //if (e.record.get('origtxt').indexOf('<') > -1) {
- // console.log("HTML EDITOR!!");
-
- // return false;
- //}
- if (e.record.get('txt').replace(/\s+/, '').length) {
- return true;
- }
- if (e.record.get('suggest').length) {
- e.record.set('txt', e.record.get('suggest'));
- // _this.saveRec(e.record);
- return;
- }
-
-
-
-
- var tl = e.record.get('id').split('/')[0];
-
- tl = (tl == 'zh_HK') ? 'zh-TW' : tl;
- tl = tl.replace('_', '-');
- var rec = e.record;
-
-
-
- Pman.gtranslate(e.record.get('origtxt'), 'en', tl, function(result) {
- if (typeof(result) == 'object') { //error
- return;
- }
-
- if (_this.grid.activeEditor) {
- _this.grid.activeEditor.setValue(result);
- } else {
- rec.set('txt',result);
- //_this.saveRec(rec);
- }
-
- //
-
-
- //console.log(result.translation);
- });
-
-
-
- return true;
- },
- afteredit : function (e)
- {
- var saveRec = function(rec)
- {
- var g = _this.grid;
-
- //g.getView().el.mask('Saving');
- Ext.Ajax.request({
- url : baseURL + '/Admin/Translations.php',
- method: 'POST',
- params : {
- id : rec.get('id'),
- txt : rec.get('txt'),
- lang : _this.langCombo.getValue(),
- module : _this.modCombo.getValue()
- },
- success : function()
- {
- //g.getView().el.unmask();
- //g.getDataSource().reload();
- },
- failure : function()
- {
- Ext.Msg.alert("Error", "There was a problem saving the data - try reloading");
- // g.getView().el.unmask();
- }
-
- });
- };
-
- saveRec.defer(1000, _this, [ e.record ]);
- }
- },
- autoExpandColumn : 'txt',
- clicksToEdit : 1,
- loadMask : true,
- dataSource : {
- xtype: 'Store',
- xns: Roo.data,
- reader : Pman.Readers.Category,
- listeners : {
- beforeload : function (_self, opts)
- {
-
- if (!_this.langCombo || !_this.langCombo.getValue().length) {
- return false;
- }
- if (!_this.modCombo || !_this.modCombo.getValue().length) {
- return false;
- }
- opts.params = {
- lang : _this.langCombo.getValue(),
- module : _this.modCombo.getValue()
- };
- }
- },
- proxy : {
- xtype: 'HttpProxy',
- xns: Roo.data,
- method : 'GET',
- url : baseURL + '/Admin/Translations.php'
- },
- reader : {
- xtype: 'JsonReader',
- xns: Roo.data,
- root : 'data',
- totalProperty : 'total',
- id : 'id',
- 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' ]
- }
- },
- toolbar : {
- xtype: 'Toolbar',
- xns: Roo,
- items : [
- {
- xtype: 'ComboBox',
- xns: Roo.form,
- listeners : {
- render : function (_self)
- {
- _this.modCombo = _self;
- },
- select : function (combo, record, index)
- {
- _this.grid.getDataSource().reload();
- }
- },
- valueField : 'module',
- displayField : 'module',
- width : 200,
- typeAhead : false,
- editable : false,
- mode : 'local',
- triggerAction : 'all',
- emptyText : "Select Module",
- selectOnFocus : true,
- store : {
- xtype: 'SimpleStore',
- xns: Roo.data,
- data : (function() {
- var modlist = [];
- AppModules = typeof(AppModules) == 'undefined' ? '' : AppModules;
- Roo.each( AppModules.split(','), function(mod) {
- modlist.push( [ mod ] );
- });
- return modlist;
- })(),
- fields : ['module']
- }
- },
- {
- xtype: 'ComboBox',
- xns: Roo.form,
- listeners : {
- select : function (combo, record, index)
- {
- _this.grid.getDataSource().reload();
- },
- render : function (_self)
- {
- _this.langCombo=_self;
- }
- },
- valueField : 'lang',
- displayField : 'ldisp',
- width : 200,
- typeAhead : false,
- editable : false,
- mode : 'local',
- triggerAction : 'all',
- emptyText : "Select Language",
- selectOnFocus : true,
- store : {
- xtype: 'SimpleStore',
- xns: Roo.data,
- fields : ['lang', 'ldisp'],
- data : [ [ 'zh_HK' , '\u7E41\u4E2D - Trad. Chin. (HK)' ], [ 'zh_CN', '\u7C21\u4E2D - Simp. Chin.' ] ]
- }
- }
- ]
- },
- colModel : [
- {
- xtype: 'ColumnModel',
- xns: Roo.grid,
- header : 'Name',
- width : 150,
- dataIndex : 'colname',
- 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>'; }
- },
- {
- xtype: 'ColumnModel',
- xns: Roo.grid,
- header : 'Original',
- width : 300,
- dataIndex : 'origtxt',
- 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>'; }
- },
- {
- xtype: 'ColumnModel',
- xns: Roo.grid,
- dataIndex : 'txt',
- header : 'Translated (Click to Edit)',
- width : 150,
- 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>'; },
- editor : {
- xtype: 'GridEditor',
- xns: Roo.grid,
- field : {
- xtype: 'TextField',
- xns: Roo.form
- }
- }
- }
- ]
- }
- },
- {
- xtype: 'GridPanel',
- xns: Roo,
- listeners : {
- activate : function() {
- _this.langpanel = this;
- if (_this.langgrid) {
- _this.langgrid.ds.load({});
- }
- }
- },
- background : true,
- fitContainer : true,
- fitToframe : true,
- region : 'center',
- tableName : 'i18n',
- title : "i18n",
- grid : {
- xtype: 'EditorGrid',
- xns: Roo.grid,
- listeners : {
- render : function()
- {
- _this.langgrid = this;
- //_this.dialog = Pman.Dialog.FILL_IN
- if (_this.langpanel.active) {
- this.ds.load({});
- }
- },
- afteredit : function (e)
- {
- var saveRec = function(rec)
- {
- var g = _this.grid;
-
- //g.getView().el.mask('Saving');
- Ext.Ajax.request({
- url : baseURL + '/Roo/I18n.php',
- method: 'POST',
- params : {
- id : rec.get('id'),
- lval : rec.get('lval')
- },
- success : function()
- {
- //g.getView().el.unmask();
- //g.getDataSource().reload();
- },
- failure : function()
- {
- Ext.Msg.alert("Error", "There was a problem saving the data - try reloading");
- // g.getView().el.unmask();
- }
-
- });
- };
-
- saveRec.defer(1000, _this, [ e.record ]);
- },
- beforeedit : function(e) {
- console.log('beforeedit');
- //if (e.record.get('origtxt').indexOf('<') > -1) {
- // console.log("HTML EDITOR!!");
-
- // return false;
- //}
- if (e.record.get('lval').replace(/\s+/, '').length) {
- return true;
- }
-
-
- var tl = _this.langgridCombo.getValue();
-
- tl = (tl == 'zh_HK') ? 'zh-TW' : tl;
- tl = tl.replace('_', '-');
- var rec = e.record;
-
-
-
- Pman.gtranslate(e.record.get('lval_en'), 'en', tl, function(result) {
- if (typeof(result) == 'object') { //error
- return;
- }
-
- if (_this.grid.activeEditor) {
- _this.grid.activeEditor.setValue(result);
- } else {
- rec.set('lval',result);
- //_this.saveRec(rec);
- }
-
- //
-
-
- //console.log(result.translation);
- });
-
-
-
- return true;
- }
- },
- autoExpandColumn : 'lval',
- clicksToEdit : 1,
- loadMask : true,
- dataSource : {
- xtype: 'Store',
- xns: Roo.data,
- listeners : {
- beforeload : function (_self, options)
- {
- options =options || {};
- options.params =options.params|| {};
- options.params.ltype = _this.langtypeCombo.getValue();
- options.params.inlang = _this.langgridCombo.getValue();
- options.params['query[_with_en]'] = 1;
- if (!options.params.ltype.length || !options.params.inlang.length) {
- return false;
- }
-
- options.params.limit = 9999;
-
- }
- },
- remoteSort : true,
- sortInfo : { field : 'lkey', direction: 'ASC' },
- proxy : {
- xtype: 'HttpProxy',
- xns: Roo.data,
- method : 'GET',
- url : baseURL + '/Roo/i18n.php'
- },
- reader : {
- xtype: 'JsonReader',
- xns: Roo.data,
- totalProperty : 'total',
- root : 'data',
- id : 'id',
- fields : [
- {
- 'name': 'id',
- 'type': 'int'
- },
- {
- 'name': 'ltype',
- 'type': 'string'
- },
- {
- 'name': 'lkey',
- 'type': 'string'
- },
- {
- 'name': 'inlang',
- 'type': 'string'
- },
- {
- 'name': 'lval',
- 'type': 'string'
- }
- ]
- }
- },
- toolbar : {
- xtype: 'Toolbar',
- xns: Roo,
- items : [
- {
- xtype: 'ComboBox',
- xns: Roo.form,
- listeners : {
- render : function (_self)
- {
- _this.langtypeCombo = _self;
- },
- select : function (combo, record, index)
- {
- _this.langgrid.getDataSource().reload();
- }
- },
- displayField : 'lval',
- editable : false,
- emptyText : "Select Translation of",
- mode : 'local',
- selectOnFocus : true,
- triggerAction : 'all',
- typeAhead : false,
- valueField : 'lkey',
- width : 200,
- store : {
- xtype: 'SimpleStore',
- xns: Roo.data,
- data : [
- [ 'l', 'Language Names' ],
- [ 'c', 'Country Names' ],
- [ 'm', 'Currency Names' ]
- ],
- fields : ['lkey','lval']
- }
- },
- {
- xtype: 'ComboBox',
- xns: Roo.form,
- listeners : {
- select : function (combo, record, index)
- {
- _this.langgrid.getDataSource().reload();
- },
- render : function (_self)
- {
- _this.langgridCombo=_self;
- }
- },
- displayField : 'ldisp',
- editable : false,
- emptyText : "Select Language",
- mode : 'local',
- selectOnFocus : true,
- triggerAction : 'all',
- typeAhead : false,
- valueField : 'lang',
- width : 200,
- store : {
- xtype: 'SimpleStore',
- xns: Roo.data,
- fields : ['lang', 'ldisp'],
- data : [ [ 'zh_HK' , '\u7E41\u4E2D - Trad. Chin. (HK)' ], [ 'zh_CN', '\u7C21\u4E2D - Simp. Chin.' ] ]
- }
- }
- ]
- },
- colModel : [
- {
- xtype: 'ColumnModel',
- xns: Roo.grid,
- dataIndex : 'lkey',
- header : 'Code',
- width : 50,
- renderer : function(v) { return String.format('{0}', v); }
- },
- {
- xtype: 'ColumnModel',
- xns: Roo.grid,
- dataIndex : 'lval_en',
- header : 'English',
- width : 150,
- renderer : function(v) { return String.format('{0}', v); }
- },
- {
- xtype: 'ColumnModel',
- xns: Roo.grid,
- dataIndex : 'lval',
- header : 'Translation',
- width : 200,
- renderer : function(v) { return String.format('{0}', v); },
- editor : {
- xtype: 'GridEditor',
- xns: Roo.grid,
- field : {
- xtype: 'TextField',
- xns: Roo.form
- }
- }
- }
- ]
- }
- }
- ],
- center : {
- xtype: 'LayoutRegion',
- xns: Roo,
- alwaysShowTabs : true,
- tabPosition : 'top'
- }
+ part : ["Admin", "Translations" ],
+ order : '950-Pman.Tab.AdminTranslations',
+ region : 'center',
+ parent : 'Pman.Tab.AdminTranslationsInt',
+ name : "Admin - Translations",
+ disabled : false,
+ permname : 'Admin.Translations',
+ _tree : function(_data)
+ {
+ var _this = this;
+ var MODULE = this;
+ return {
+ xtype : 'NestedLayoutPanel',
+ region : 'center',
+ title : _this._strings['07a1d316d1065473f290c3c2b72a80f3'] /* Application Words */,
+ xns : Roo,
+ '|xns' : 'Roo',
+ layout : {
+ xtype : 'BorderLayout',
+ xns : Roo,
+ '|xns' : 'Roo',
+ center : {
+ xtype : 'LayoutRegion',
+ xns : Roo,
+ '|xns' : 'Roo'
+ },
+ west : {
+ xtype : 'LayoutRegion',
+ split : true,
+ width : 450,
+ xns : Roo,
+ '|xns' : 'Roo'
+ },
+ items : [
+ {
+ xtype : 'TreePanel',
+ region : 'west',
+ listeners : {
+ render : function (_self)
+ {
+ _this.treepanel = _self;
+ }
+ },
+ xns : Roo,
+ '|xns' : 'Roo',
+ toolbar : {
+ xtype : 'Toolbar',
+ xns : Roo,
+ '|xns' : 'Roo',
+ items : [
+ {
+ xtype : 'Button',
+ text : _this._strings['03c2e7e41ffc181a4e84080b4710e81e'] /* New */,
+ listeners : {
+ click : function (_self, e)
+ {
+ Pman.Dialog.AdminLanguagePick.show( { }, function(lang) {
+
+ new Pman.Request({
+ url : baseURL + '/Roo/core_templatestr',
+ method : 'POST',
+ params : {
+ _rescan : lang
+ },
+ success : function()
+ {
+ _this.treepanel.tree.getRootNode().reload();
+ }
+ });
+
+ });
+
+ }
+ },
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Separator',
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Button',
+ text : _this._strings['f2a6c498fb90ee345d997f888fce3b18'] /* Delete */,
+ listeners : {
+ click : function (_self, e)
+ {
+ var tree = _this.treepanel.tree;
+ var sn = tree.getSelectionModel().getSelectedNode();
+
+ if (!sn || typeof(sn.attributes.language) == 'undefined' || !sn.attributes.language) {
+ Roo.MessageBox.alert("Error", "Select a language");
+ return;
+ }
+
+ Roo.MessageBox.confirm("Confirm", "Are sure you want to delete the language", function (v){
+ if (v != 'yes') {
+ return;
+ }
+ Roo.MessageBox.alert("Not yet", "not done yet");
+ return;
+
+
+
+
+ });
+ }
+ },
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Separator',
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Button',
+ text : _this._strings['cd6ae20e52d83f601c5fa12b66f0f6d0'] /* Rescan */,
+ listeners : {
+ click : function (_self, e)
+ {
+ var tree = _this.treepanel.tree;
+ Roo.log(tree);
+ var sn = tree.getSelectionModel().getSelectedNode();
+
+ if (!sn) {
+ Roo.MessageBox.alert("Error", "Select a node");
+ return;
+ }
+
+
+ var steps = [
+ 'scanProjectBJS',
+ 'scanPmanBJS',
+ 'scanPmanTemplates',
+ 'scanTables',
+ 'syncLanguage'
+ ];
+
+
+ var syncTemplate = function(){
+
+ var step = steps.shift();
+ Roo.MessageBox.updateProgress( (5.0 - steps.length) / 5.0, "Running " + step);
+
+ new Pman.Request({
+ url : baseURL + '/Admin/UpdateBjsTemplates/' + step,
+ method : 'GET',
+ //mask : 'Processing...',
+ timeout : 9000000,
+ success : function()
+ {
+ if (steps.length > 0 ) {
+ syncTemplate();
+ return;
+ }
+ Roo.MessageBox.hide();
+ _this.treepanel.tree.getRootNode().reload();
+ }
+ });
+
+ };
+
+
+ var syncLanguage = function(){
+ new Pman.Request({
+ url : baseURL + '/Roo/Core_templatestr',
+ method : 'POST',
+ mask : 'Processing...',
+ params : {
+ _rescan : sn.attributes.id.split(':')[1]
+ },
+ success : function()
+ {
+ _this.treepanel.tree.getRootNode().reload();
+ }
+ });
+ };
+
+ var syncSingleTemplate = function(id){
+ new Pman.Request({
+ url : baseURL + '/Roo/Core_template',
+ method : 'POST',
+ mask : 'Processing...',
+ params : {
+ id : id,
+ _rescan : 1
+ },
+ success : function()
+ {
+ (function() {
+ _this.grid.footer.onClick('first');
+ }).defer(100);
+ }
+ });
+ };
+
+
+ if(typeof(sn.isRoot) != 'undefined' && sn.isRoot){
+ Roo.MessageBox.progress("Syncing templates", "Starting");
+ syncTemplate();
+ return;
+ }
+
+ if(typeof(sn.attributes.language) != 'undefined' && sn.attributes.language){
+ syncLanguage();
+ return;
+ }
+
+ if(typeof(sn.attributes.id) != 'undefined' && sn.attributes.id * 1> 0){
+ syncSingleTemplate(sn.attributes.id);
+ return;
+ }
+
+
+
+
+ }
+ },
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Fill',
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Button',
+ text : _this._strings['91412465ea9169dfd901dd5e7c96dd99'] /* Upload */,
+ listeners : {
+ click : function (_self, e)
+ {
+
+
+ Pman.Dialog.Image.show({
+ _url : baseURL + '/Admin/Import/Core_templatestr'
+
+ }, function() {
+ _this.treepanel.tree.getRootNode().reload();
+ });
+
+
+
+ }
+ },
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Fill',
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Button',
+ text : _this._strings['801ab24683a4a8c433c6eb40c48bcd9d'] /* Download */,
+ listeners : {
+ click : function (_self, e)
+ {
+ var tree = _this.treepanel.tree;
+
+ var sn = tree.getSelectionModel().getSelectedNode();
+
+ p = {
+ csvCols : 'src_id_mdsum,template_id_view_name,template_id_template,src_id_txt,lang,txt',
+ csvTitles : 'Code,Module,Template,Original,Language,Translation',
+ limit : 9999,
+ sort: 'template_id_view_name,template_id_template,on_table,on_col,src_id_txt',
+ dir: 'ASC',
+ active : 1
+ };
+ if (!sn || sn.id == 'transtree') {
+ Roo.MessageBox.alert("Error", "Select language, module or page");
+ return;
+ }
+ if (typeof(sn.id) == 'number') {
+ p.template_id = sn.id;
+
+ }
+
+
+ if (typeof(sn.id) == 'string' && sn.id.match(/^table:/)) {
+ var sns = sn.id.split(':');
+ p.lang = sns[1];
+ p.on_table = sns[2];
+ p.csvCols = 'src_id_mdsum,on_table,on_id,on_col,src_id_txt,lang,txt';
+ p.csvTitles = 'Code,Table,Table id,Column,Original,Language,Translation';
+ }
+
+ if (typeof(sn.id) == 'string' && sn.id.match(/^view:/)) {
+ var sns = sn.id.split(':');
+ p.lang = sns[1];
+ p.template_id_view_name = sns[2];
+
+ }
+ if (typeof(sn.id) == 'string' && sn.id.match(/^lang:/)) {
+ var sns = sn.id.split(':');
+ p.lang = sns[1];
+
+ }
+ // transtree
+ // view: {lang} : {view_name}
+ // lang:
+
+ new Pman.Download({
+ url : baseURL + '/Roo/Core_templatestr',
+ params : p,
+ method : 'GET'
+ });
+
+
+
+
+
+ }
+ },
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Separator',
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ },
+ {
+ xtype : 'Button',
+ text : _this._strings['4d1c8263ba1036754f8db14a98f9f006'] /* Reload */,
+ listeners : {
+ click : function (_self, e)
+ {
+ _this.treepanel.tree.getRootNode().reload();
+
+ }
+ },
+ xns : Roo.Toolbar,
+ '|xns' : 'Roo.Toolbar'
+ }
+ ]
+ },
+ tree : {
+ xtype : 'TreePanel',
+ containerScroll : false,
+ rootVisible : true,
+ xns : Roo.tree,
+ '|xns' : 'Roo.tree',
+ root : {
+ xtype : 'AsyncTreeNode',
+ id : 'transtree',
+ text : _this._strings['69fd71b6f79260924a32a45850a13ab7'] /* Translations (rescan this to update strings) */,
+ xns : Roo.tree,
+ '|xns' : 'Roo.tree'
+ },
+ selModel : {
+ xtype : 'DefaultSelectionModel',
+ listeners : {
+ selectionchange : function (_self, node)
+ {
+ Roo.log(node);
+
+ //if (node.id.split('/').length < 2) {
+ // return;
+ // }
+ (function() {
+ _this.grid.footer.onClick('first');
+ }).defer(100);
+
+ }
+ },
+ xns : Roo.tree,
+ '|xns' : 'Roo.tree'
+ },
+ loader : {
+ xtype : 'TreeLoader',
+ baseParams : { _tree : 1 },
+ dataUrl : baseURL + '/Roo/Core_templatestr',
+ requestMethod : 'GET',
+ listeners : {
+ beforeload : function (This, node, callback)
+ {
+ // set some params.
+ Roo.log(node);
+ this.baseParams._tree = 1;
+
+ //this.baseParams.category = node.attributes.category;
+ },
+ loadexception : function (This, node, response)
+ {
+ Roo.MessageBox.alert("Error", "Problem loading tree");
+ }
+ },
+ xns : Roo.tree,
+ '|xns' : 'Roo.tree'
+ }
+ }
+ },
+ {
+ xtype : 'GridPanel',
+ background : false,
+ fitContainer : true,
+ fitToframe : true,
+ region : 'center',
+ tableName : 'Page',
+ title : _this._strings['193cfc9be3b995831c6af2fea6650e60'] /* Page */,
+ listeners : {
+ activate : function() {
+ _this.panel = this;
+ if (_this.grid) {
+ _this.grid.footer.onClick('first');