2012-08-02 98 views
9

我想爲p:selectManyCheckBox中的每個元素添加一個工具提示。但是我無法想出一個解決方案。Primefaces tooltip for p:selectManyCheckbox

我有一個類Role有3個屬性,「ID」(長),「名稱」(字符串)和「描述」(字符串)。顯示名稱,我希望將描述作爲工具提示。

這是一個工作一段代碼:

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

roleConverterFacesConverter一種轉換Role到一個id,反之亦然。

我想出了這一點:

<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> 

不過遺憾的是它不工作。 (!):

<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> 

和壓倒一切的PrimeFaces SelectManyCheckboxRenderer#encodeOptionLabel()如下認識,並使其:

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"); 
    } 

} 

使用未使用SelectItem#getDescription()如下特性

回答

15

您可以通過(AB)實現這一目標其中註冊如下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> 

向PF員發佈增強請求以包含項目描述可能是值得的。它們在UISelectOne/UISelectMany組件中的任何地方都沒有使用過。