2012-08-02 2 views
9

Vorrei aggiungere un suggerimento per ogni elemento in un p:selectManyCheckBox. Tuttavia non riesco a trovare una soluzione.Primeti tooltip per p: selectManyCheckbox

Ho una classe Role che ha 3 proprietà, "id" (Long), "name" (String) e "description" (String). Il nome viene visualizzato e mi piacerebbe avere la descrizione come suggerimento.

Questo è un pezzo di lavoro di codice:

<p:selectManyCheckbox layout="pageDirection" value="#{roleBean.selectedRoles}" converter="roleConverter"> 
    <f:selectItems value="#{roleBean.roles}" var="role" itemLabel="#{role.name}" itemValue="#{role}"/> 
</p:selectManyCheckbox> 

Il roleConverter è un FacesConverter che converte il Role ad un id e viceversa.

sono arrivato fino a questo:

<p:selectManyCheckbox layout="pageDirection" value="#{roleBean.selectedRoles}" converter="roleConverter"> 
    <c:forEach var="role" items="#{roleBean.roles}"> 
     <f:selectItem id="role#{role.id}" itemLabel="#{role.name}" itemValue="#{role}" /> 
     <p:tooltip for="role#{role.id}" value="#{role.description}"/> 
    </c:forEach> 
</p:selectManyCheckbox> 

Ma purtroppo non funziona.

risposta

15

È possibile raggiungere questo obiettivo (ab) utilizzando il inutilizzato SelectItem#getDescription() proprietà come di seguito (!):

<p:selectManyCheckbox layout="pageDirection" value="#{roleBean.selectedRoles}" converter="roleConverter"> 
    <f:selectItems value="#{roleBean.roles}" var="role" 
     itemValue="#{role}" itemLabel="#{role.name}" itemDescription="#{role.description}" /> 
</p:selectManyCheckbox> 

E ignorando le primefaces SelectManyCheckboxRenderer#encodeOptionLabel() come di seguito per riconoscere e renderlo:

public class YourSelectManyCheckboxRenderer extends SelectManyCheckboxRenderer { 

    @Override 
    protected void encodeOptionLabel(FacesContext context, SelectManyCheckbox checkbox, String containerClientId, SelectItem option, boolean disabled) throws IOException { 
     ResponseWriter writer = context.getResponseWriter(); 
     writer.startElement("label", null); 
     writer.writeAttribute("for", containerClientId, null); 

     if (option.getDescription() != null) { 
      writer.writeAttribute("title", option.getDescription(), null); 
     } 

     if (disabled) { 
      writer.writeAttribute("class", "ui-state-disabled", null); 
     } 

     if (option.isEscape()) { 
      writer.writeText(option.getLabel(), null); 
     } else { 
      writer.write(option.getLabel()); 
     } 

     writer.endElement("label"); 
    } 

} 

Che è registrato come segue in faces-config.xml:

<render-kit> 
    <renderer> 
     <component-family>org.primefaces.component</component-family> 
     <renderer-type>org.primefaces.component.SelectManyCheckboxRenderer</renderer-type> 
     <renderer-class>com.example.YourSelectManyCheckboxRenderer</renderer-class> 
    </renderer> 
</render-kit> 

Potrebbe valere la pena di inviare una richiesta di miglioramento ai ragazzi di PF per includere la descrizione dell'oggetto. Non è stato utilizzato da nessuna parte nei loro componenti UISelectOne/UISelectMany.