I am trying to implement a "select all checkboxes" checkbox in a rich:dataTable header without using JavaScript.
XHTML:
<rich:column styleClass="center-aligned-text">
<f:facet name="header">
<h:selectBooleanCheckbox id="selectAll" title="selectAll" valueChangeListener="#{workspace.selectAllComponents}">
<a4j:support event="onclick" reRender="listcomponents"/>
</h:selectBooleanCheckbox>
</f:facet>
<h:selectBooleanCheckbox id="selectComponent" value="#{workspace.selectedComponentIds[componentInfo.id]}" />
</rich:column>
Backing bean:
public void selectAllComponents(ValueChangeEvent event) {
if (!selectAll) {
changeMap(selectedComponentIds,true);
setSelectAll(true);
} else {
changeMap(selectedComponentIds,false);
setSelectAll(false);
}
}
public void changeMap(Map<Long,Boolean> selectedComponentMap, Boolean blnValue) {
if(selectedComponentMap != null) {
Iterator<Long> itr = selectedComponentMap.keySet().iterator();
while(itr.hasNext()) {
selectedComponentMap.put(itr.next(), blnValue);
}
setSelectedComponentIds(selectedComponentMap);
}
}
An answer which I found here:
if (event.getPhase() != PhaseId.INVOKE_APPLICATION) {
event.setPhase(PhaseId.INVOKE_APPLICATON);
event.queue();
} else {
//do your stuff here
}
doesn't add up, because the getPhase()
is not available in the ValueChangeEvent
event. I see the just the getPhaseId()
which contains the INVOKE_APPLICATION
option, so my question is, how can I achieve my functional requirement with the above answer? Or is there any alternative?