2010-02-25 5 views
2

De this previously asked question, je l'ai remarqué que lorsque je déplace un rich:panelMenu (qui fonctionne très bien quand dans une page index.jsp) dans another.jsp puis inclure dans index.jsp en utilisant une balise a4j:include, la fonctionnalité rich:panelMenu cesse de fonctionner.richfaces riche: arrête panelMenu travailler quand a4j: include'd

Est-ce un bug?

EDIT 1

En réponse au code et après quelques tests d'isolement, le problème semble provenir d'une coexistence d'un rich:dataTable dans un autre onglet d'un rich:tabPanel du panelMenu.

Si mon index.jsp contient un simple défaut panelMenu en utilisant le code de démonstration (inc dans le haricot) fonctionne comme prévu:

<f:view> 
    <rich:page pageTitle="title" markupType="xhtml"> 
     <h:outputText id="setup" value="#{MyBacking.setup}" /> 
     <rich:toolBar height="35" itemSeparator="line"> 
      <rich:toolBarGroup location="left"> 
       <a4j:form> 
        <a4j:outputPanel id="panel"> 
         <h:outputText style="text-align: center" value="Node Select " /> 
         <h:selectOneMenu id="nodes" value="#{MyBacking.chosenNode}"> 
          <f:selectItems value="#{MyBacking.nodes}" /> 
         </h:selectOneMenu> 
         <a4j:commandButton value="Retrieve" 
          reRender="panel,contentPanel" 
          onclick="this.disabled=true" oncomplete="this.disabled=false" /> 
        </a4j:outputPanel> 
       </a4j:form> 
      </rich:toolBarGroup> 
     </rich:toolBar> 
<!-- added start --> 
     <h:form id="form"> 
      <h:panelGrid columns="2" width="100%"> 
       <rich:panelMenu style="width:200px" mode="ajax" 
        iconExpandedGroup="disc" iconCollapsedGroup="disc" 
        iconExpandedTopGroup="chevronUp" iconGroupTopPosition="right" 
        iconCollapsedTopGroup="chevronDown"> 
        <rich:panelMenuGroup label="Group 1"> 
         <rich:panelMenuItem label="Item 1.1" 
          action="#{PanelMenu.updateCurrent}"> 
          <f:param name="current" value="Item 1.1" /> 
         </rich:panelMenuItem> 
        </rich:panelMenuGroup> 
       </rich:panelMenu> 
       <rich:panel bodyClass="rich-laguna-panel-no-header"> 
        <a4j:outputPanel ajaxRendered="true"> 
         <h:outputText value="||#{PanelMenu.current}|| selected" 
          id="current" /> 
        </a4j:outputPanel> 
       </rich:panel> 
      </h:panelGrid> 
     </h:form> 
<!-- added end --> 
     <rich:panel> 
      <h:panelGroup layout="block" id="contentPanel"> 
       <a4j:include viewId="#{MyBacking.viewId}"> 
        <f:param name="targetIdParam" value="content" /> 
       </a4j:include> 
      </h:panelGroup> 
     </rich:panel> 
    </rich:page> 
</f:view> 

Mais si je retire la valeur ajoutée panelMenu de ce fichier et le coller dans un onglet séparé dans tabPanel dans une page jsp externe qui est alors a4j:include d dans le index.jsp ci-dessus, quand il est chargé, le panelMenu refuse de travailler (ne rien afficher dans le journal ou la console) tandis que dans l'autre onglet dans mon jeu d'onglets il y a un rich:dataTable. Avec exactement le même code, mais avec le dataTable retiré du deuxième onglet, tout recommence à fonctionner.

Voici le fichier a4j:include d rompu avec panelMenu:

<h:panelGrid columns="1" border="0" style="width: 100%"> 
    <rich:tabPanel switchType="client" rendered="true"> 
     <rich:tab styleClass="tab" label="Node Logs"> 
      <h:panelGrid columns="2" border="0"> 
       <h:graphicImage value="/btn50.png" width="30" height="30" 
        alt="Logs" /> 
       <h:outputText value="log: #{MyBacking.chosenNode}" 
        styleClass="pageTitle" /> 
      </h:panelGrid> 

      <h:form id="form"> 
       <h:panelGrid columns="2" width="100%"> 
        <rich:panelMenu style="width:200px" mode="ajax" 
         iconExpandedGroup="disc" iconCollapsedGroup="disc" 
         iconExpandedTopGroup="chevronUp" iconGroupTopPosition="right" 
         iconCollapsedTopGroup="chevronDown"> 
         <rich:panelMenuGroup label="Group 1"> 
          <rich:panelMenuItem label="Item 1.1" 
           action="#{PanelMenu.updateCurrent}"> 
           <f:param name="current" value="Item 1.1" /> 
          </rich:panelMenuItem> 
         </rich:panelMenuGroup> 
        </rich:panelMenu> 
        <rich:panel bodyClass="rich-laguna-panel-no-header"> 
         <a4j:outputPanel ajaxRendered="true"> 
          <h:outputText value="||#{PanelMenu.current}|| selected" 
           id="current" /> 
         </a4j:outputPanel> 
        </rich:panel> 
       </h:panelGrid> 
      </h:form> 

     </rich:tab> 

     <rich:tab styleClass="tab" label="Docs"> 
      <rich:dataTable value="#{MyBacking.MyData}"> 
       <rich:column style="text-align:center" width="150px"> 
       </rich:column> 
      </rich:dataTable> 
     </rich:tab> 
    </rich:tabPanel> 
</h:panelGrid> 

Merci

+0

probablement pas un bug. Donnez-nous plus de code, et vérifiez votre console javascript sur les détails. – Bozho

+0

@Bozho, voir code ajouté et diag. – volvox

Répondre

1

Ce problème a disparu quand je Refonte les déclarations taglib comme

<ui:composition xmlns="http://www.w3.org/1999/xhtml" 
    xmlns:ui="http://java.sun.com/jsf/facelets" 
    xmlns:h="http://java.sun.com/jsf/html" 
    xmlns:f="http://java.sun.com/jsf/core" 
    xmlns:a4j="http://richfaces.org/a4j" 
    xmlns:rich="http://richfaces.org/rich"> 

au lieu d'utiliser <% %> tags (qui ne sont pas utilisés avec facettes de toute façon)

et installé jsf-facelets-1.1.14.jar. Aucun pot de facettes n'a été installé jusqu'à ce point!

Questions connexes