Ver Mensaje Individual
  #1 (permalink)  
Antiguo 14/07/2016, 22:02
sesebas
 
Fecha de Ingreso: enero-2009
Mensajes: 173
Antigüedad: 16 años
Puntos: 1
Tabs anidados en aplicación web: EXT JS

Hola amigos(as),

Tengo una serie de indicadores que se listan en un grid entre los que el usario puede elegir uno, todos o sólo algunos. Cada indicador tiene tres archivos asociados uno para datos, uno para gráfico y uno para mapa. El funcionamiento es el siguiente: si el usuario eligió sólo un indicador…

1. cargo –con autoLoad- la tabla de datos : var main = new Ext.Panel({… }
2. cargo –con html- el gráfico : var mainGraph = new Ext.Panel({…}
3. cargo –con html- el mapa : var mainMap = new Ext.Panel({…}
4. Cargo los tres paneles anteriores en uno solo (en title capturo el nombre del
indicador):
allTabs = new Ext.tab.Panel({…
items:[main,mainGraph,mainMap],
}
5. Cargo el tabpanel “allTabs” en un nuevo tab.panel para mostrar en su title una referencia geográfica o de país al que pertenece(n) el(los) indicador(es) seleccionados.

Este es el tab principal:

tabs = new Ext.tab.Panel({…
items:[ allTabs];
}
6. Muestro todo en una ventana:
win = Ext.create("Ext.window.Window",{
items:[tabs];
)};
win.show();
Esto se ejecuta cuando se ha seleccionado un solo indicador, o solo para el primero en caso de haber dos o más indicadores elegidos.

Para el segundo y otros de orden superior que se haya elegido hago lo siguiente:
Código Javascript:
Ver original
  1. // Se ha seleccionado más de un indicador en el grid.Panel...
  2.  
  3.  for(var i=1;i<numRecords;i++){
  4.  
  5.    var tabSecond = new Ext.panel.Panel({
  6.      title: miArray[i - 1],
  7.      id:[i - 1],
  8.      closable: true,
  9.      iconCls: 'app-icon',
  10.       tbar:[
  11.     {iconCls:'save-icon',
  12.         id:'SaveIcon' + '_' + [i]
  13.     },
  14.     {iconCls:'send-icon',
  15.         id:'SendIcon' + '_' + [i]
  16.     },
  17.     {iconCls:'home-icon',
  18.         id:'HomeIcon' + '_' + [i
  19.         }
  20.      ],
  21.            autoScroll:true,
  22.        border: false,
  23.            autoLoad:{url:rows[i],scripts:true},
  24.            height: alto – 60
  25.   }); // Termina configuración del panel en "var tabSecond"
  26.  
  27.            tabs.add(tabSecond); // que se agrega como nuevo tab a la salida final
  28.  
  29. } // Termina el for

Esto funciona bien, pero cada nuevo tabulado agregado al tab principal (tab) contiene solo el tabulado y no he podido conseguir repetir, dentro del for, lo que he hecho en el tab.panel que tengo en el punto 4:

allTabs = new Ext.tab.Panel({…

items:[main,mainGraph,mainMap],
}
Ningún intento me ha funcionado, por lo que he venido al foro a pedir su ayuda… de verdad necesito salir de este paso y agradeceré mucho si me ayudan a conseguirlo.

Gracias.

El código más completo:

Código Javascript:
Ver original
  1. for(var i=0;i<numRecords;i++){
  2.    
  3.             var test_i = [i]; console.log("[i] me entrega: ", test_i);
  4.  
  5.             //console.log("Se instancia un panel en var main... linea 466");
  6.         var main = new Ext.Panel({
  7.          
  8.               title: 'Tabulado',
  9.               width:450,
  10.               itemID: "PanelOut",
  11.               id:[i],
  12.               autoLoad:{url:rows[i],scripts:true},
  13.               maximized: true,
  14.                 iconCls: 'app-icon',
  15.                          tbar:[
  16.                                 {iconCls:'save-icon',id:'SaveIcon_' + [i],
  17.                                         text:'Descargar',
  18.                                         listeners:{click:{element: 'el',fn: function(){functSave()}}}
  19.                                 },
  20.                                 {iconCls:'send-icon',id:'SendIcon_' + [i],
  21.                                         text:'Compartir',
  22.                                         listeners:{click:{element: 'el',fn: function(){functSend()}}}
  23.                                 },
  24.                                 {iconCls:'home-icon',id:'HomeIcon_' + [i],
  25.                                         text:'Inicio',
  26.                                         listeners:{
  27.                                                 click:{element: 'el',fn: function(){functHome()}},
  28.                                                 mouseover:{element: 'el',fn: function(){functMover()}}}
  29.                             }],
  30.                             closable: true,
  31.                             border: false,
  32.                             autoScroll:true,
  33.                 height: '50%',
  34.         }); //Termina "var main"
  35.                                
  36.                     var sebas_gif = rows_gif[i].split(".");
  37.                     var sebas_jpg = rows_jpg[i].split(".");
  38.        
  39.                         var gifShow = "'<center><img src=" + rows_gif[i] + "  id=graph border=0 width=50%></center>'" ;
  40.                         var jpgShow = "'<center><img src=" + rows_jpg[i] + "  id=map border=0 width=50%></center>'" ;
  41.        
  42.         var mainGraph = new Ext.Panel({
  43.          
  44.               title: 'Gráfico',
  45.               layout: 'fit',
  46.               width:450,
  47.               itemID: "PanelGraph",
  48.               id:'1',
  49.               html:  gifShow,
  50.               maximized: true,
  51.                 iconCls: 'app-icon',
  52.                          tbar:[
  53.                                 {iconCls:'save-icon',id:'SaveIcon_' + [i],xtype: 'tbspacer'},
  54.                                 {iconCls:'send-icon',id:'SendIcon_' + [i],xtype: 'tbspacer'},
  55.                                 {iconCls:'home-icon',id:'HomeIcon_' + [i],xtype: 'tbspacer'},
  56.                             ],
  57.                             closable: true,
  58.                             border: false,
  59.                             autoScroll:true,
  60.                 height: '50%',
  61.         });
  62.  
  63.         var mainMap = new Ext.Panel({
  64.                 title: 'Mapa',
  65.               width:'50%',
  66.               itemID: "PanelMap",
  67.               id:'2',
  68.               html:jpgShow,
  69.               maximized: true,
  70.                 iconCls: 'app-icon',
  71.                          tbar:[
  72.                          
  73.                                 {iconCls:'save-icon',id:'SaveIcon_' + [i],xtype: 'tbspacer'},
  74.                                 {iconCls:'send-icon',id:'SendIcon_' + [i],xtype: 'tbspacer'},
  75.                                 {iconCls:'home-icon',id:'HomeIcon_' + [i],xtype: 'tbspacer'},
  76.                             ],
  77.                         closable: true,
  78.                         border: false,
  79.                         autoScroll:true,
  80.               height: '50%',
  81.         });
  82.  
  83.             allTabs = new Ext.tab.Panel({
  84.           title: miArray[i],   
  85.           layout: 'fit',
  86.                 width:450,
  87.                 activeTab: 0,
  88.                 frame:true,
  89.                 defaults:{autoHeight: true},
  90.                 items:[main,mainGraph,mainMap],
  91.             });
  92.            
  93.           tabs = new Ext.tab.Panel({
  94.                 border: false,
  95.                 activeTab:[i], // El primer tab seleccionado -aunque haya sólo uno- será el activo (con index cero)
  96.                 itemId:'sebas_tabsMain',
  97.                 autoScroll:true,   
  98.                                                      
  99.                   items:[allTabs], //Agrego el tab según el indicador que se quiere revisar (su index es == 0)
  100.          
  101.                     layout: 'fit',             
  102.                     layoutOnTabChange: true,
  103.                     deferredRender: false,
  104.            
  105.           });  // Termina "var tabs"
  106.                
  107.     // Aquí se reciben los tabs...
  108.         win = Ext.create("Ext.window.Window",{
  109.                     title :'Tabulados para ' + a + '-' + b,
  110.                     width : 100,
  111.                     height: 100 ,
  112.                     loadMask: true,
  113.                     bodyStyle:{"background-color":"white"},
  114.                     layout:'fit',
  115.                     maximized: true,
  116.                
  117.                     items: tabs // Como "items de win"
  118.          }); // termina la configuración de "var win"
  119.  
  120.  
  121.         win.show(); //console.log("Se despliega una ventana... linea 879");
  122.  
  123.  
  124.         var alto  = win.getHeight();
  125.         var ancho = win.getWidth();
  126.  
  127.  
  128.     // Se ha seleccionado más de un indicador en el grid.Panel...
  129.         for(var i=1;i<numRecords;i++){
  130.        
  131.                     // Se instancia un nuevo panel
  132.                     var tabSecond = new Ext.panel.Panel({
  133.                         title: miArray[i],
  134.                         id:[i],
  135.                         closable: true,
  136.                         iconCls: 'app-icon',
  137.                             tbar:[
  138.                                     {iconCls:'save-icon',
  139.                             id:'SaveIcon' + '_' + [i]
  140.                                     },
  141.                
  142.                                     {iconCls:'send-icon',
  143.                                         id:'SendIcon' + '_' + [i]
  144.                                     },
  145.                                                      
  146.                                     {iconCls:'home-icon',
  147.                                         id:'HomeIcon' + '_' + [i]
  148.                                     }                                                                
  149.                
  150.                                 ],   
  151.                
  152.                
  153.                         autoScroll:true,
  154.                         border: false,
  155.                         autoLoad:{url:rows[i],scripts:true},
  156.                   height: alto - 60
  157.                                                            
  158.               }); // Termina configuración del panel en "var tabseba"
  159.        
  160.                     tabs.add(tabSecond); // que se agrega como tab a la salida final
  161.        
  162.         } // Termina el for