如何通过远程命令执行方法以重置数据表过滤器?

时间:2018-06-26 21:21:29

标签: jquery ajax primefaces filtering

在下面的index.xhtml页面中,我有3个命令按钮,当单击它们时,它们将重定向到包含数据表的另一个.xhtml页面,并且完整对其进行过滤:

<ui:composition>
  <h:form id="kpiForm">
     <p:panel id="kpiPanel" >
        <p:commandButton value="filter 1" action="/app/index" oncomplete=" $('#MyFormID\\:MyDatatableID\\:BoxID\\:1').click(); PF('wv').filter();" onclick="rc()" />
        <p:commandButton value="filter 2" action="/app/index" oncomplete=" $('#MyFormID\\:MyDatatableID\\:BoxID\\:2').click(); PF('wv').filter();" onclick="rc()" />
        <p:commandButton value="filter 3" action="/app/index" oncomplete=" $('#MyFormID\\:MyDatatableID\\:BoxID\\:3').click(); PF('wv').filter();" onclick="rc()" />
     </p:panel>
     <p:remoteCommand name="rc" actionListener="#{datatableController.clearAllFilters}" />
  </h:form>
</ui:composition>

在another.xhtml中有一个按钮,当单击该按钮时,将清除应用于数据表的所有过滤器:

<!-- some code ommited -->
<ui:composition [...]>
  <h:form id="OutsideFormID">
    <p:panel id="MyPanelID" header="Some Title">

      <p:commandButton value="Reset Table" onclick="PF('wv').clearFilters()" actionListener="#{datatableController.clearAllFilters}" update="MyDatatableID">
        <p:resetInput target="MyDatatableID" />
      </p:commandButton>

        <p:dataTable id="MyDatatableID"
        value="#{datatableController.items}"
        rowKey="#{item.id}"
        var="item"
        selection="#{datatableController.selected}"
        filteredValue="#{datatableController.filteredDemandas}"
        widgetVar="wv">

            <p:column id="MyColumnID" sortBy="#{item.status.statusName}" filterBy="#{item.status.statusName}" filterMatchMode="in" >
            <f:facet name="header">
                <h:outputText value="STATUS"/>
            </f:facet>
            <f:facet name="filter">
                <p:selectCheckboxMenu id="BoxID" widgetVar="BoxWV" label="status" onchange="PF('wv').filter()">
                    <f:selectItems id="ComboID" value="#{datatableController.statusListCombo}" />
                </p:selectCheckboxMenu>
            </f:facet>
            <h:outputText value="#{item.status.statusName}"/>
            </p:column>
        </p:dataTable>
    </p:panel>
  </h:form>
</ui:composition>

当我单击过滤器3 按钮时,将加载包含数据表的another.xhtml,并且完成后,将按预期过滤数据表。但是,如果我点击另一个过滤器按钮(例如过滤器2 ),以前应用的过滤器将保持活动状态,从而导致不必要的过滤;如果再次单击相应的过滤器按钮,则此先前应用的过滤器被禁用。

我尝试使用remote command调用clearAllFilters方法,但没有成功。

public void clearAllFilters() {
  DataTable dataTable = (DataTable) FacesContext.getCurrentInstance().getViewRoot().findComponent("OutsideFormID:MyDatatableID");

  if (!dataTable.getFilters().isEmpty()) {
  dataTable.reset();

  RequestContext requestContext = RequestContext.getCurrentInstance();
  requestContext.update("OutsideFormID:MyDatatableID");
  }
}

我如何调用每次单击任何过滤器按钮(在kpiForm中)时要执行的clearAllFilters方法,并且完成后,数据表将被过滤?

在此先感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

我认为有一种更清洁,更轻松的方法:

您的过滤器按钮的操作应调用一个托管bean方法,该方法清除过滤器,然后重定向到another.xhtml。像这样:

    <p:commandButton value="filter 1" 
                     action="#{datatableController.pressedFilter1}" 
                     oncomplete=" $('#MyFormID\\:MyDatatableID\\:BoxID\\:1').click(); PF('wv').filter();" 
                     />

在托管bean中:

 public String pressedFilter1(){
      this.clearAllFilters();
      return "/app/index.xhtml";
 }

这将在加载页面之前清除过滤器。