Atualizar ListDataModel após clicar em commandbutton

0 respostas
V

Olá pessoal,

Baseando-me neste exemplo do site do primefaces: http://www.primefaces.org/showcase/ui/datatableRowSelectionInstant.jsf , não obtive sucesso em fazer com que o mediumCarsModel fosse atualizado após o clicar do commandbutton, ao invés de ser carregado de imediato no construtor do Bean.

Além disto, mantendo a carga realizada no construtor e adicionando nova carga em mediumCarsModel pelo método atrelado ao commandbutton, a seleção não funciona para estes novos registros oriundos do clicar do commandbutton.

Resumindo: como fazer com no código abaixo para que o mediumCarsModel só seja alimentado via commandbutton e que a cada clicar de um commandbutton ocorra novas adições de elementos no mediumCarsModel ?

<h:form id="form">  
  
    <p:growl id="growl" showDetail="true"/>  
  
    <p:dataTable id="cars" var="car" value="#{tableBean.mediumCarsModel}" paginator="true" rows="10"  
                 selection="#{tableBean.selectedCar}" selectionMode="single">  
  
        <p:ajax event="rowSelect" listener="#{tableBean.onRowSelect}"   
                    update=":form:display :form:growl" oncomplete="carDialog.show()" />  
        <p:ajax event="rowUnselect" listener="#{tableBean.onRowUnselect}" update=":form:growl"/>  
  
        <f:facet name="header">  
            Select a row to display a message  
        </f:facet>  
  
        <p:column headerText="Model">  
            #{car.model}  
        </p:column>  
  
        <p:column headerText="Year">  
            #{car.year}  
        </p:column>  
  
        <p:column headerText="Manufacturer" >  
            #{car.manufacturer}  
        </p:column>  
  
        <p:column headerText="Color">  
            #{car.color}  
        </p:column>  
    </p:dataTable>  
  
    <p:dialog id="dialog" header="Car Detail" widgetVar="carDialog" resizable="false"  
                showEffect="explode" hideEffect="explode">  
  
        <h:panelGrid id="display" columns="2" cellpadding="4">  
  
            <f:facet name="header">  
                <p:graphicImage value="/images/cars/#{tableBean.selectedCar.manufacturer}.jpg"/>  
            </f:facet>  
  
            <h:outputText value="Model:" />  
            <h:outputText value="#{tableBean.selectedCar.model}" />  
  
            <h:outputText value="Year:" />  
            <h:outputText value="#{tableBean.selectedCar.year}" />  
  
            <h:outputText value="Manufacturer:" />  
            <h:outputText value="#{tableBean.selectedCar.manufacturer}" />  
  
            <h:outputText value="Color:" />  
            <h:outputText value="#{tableBean.selectedCar.color}" />  
        </h:panelGrid>  
    </p:dialog>    
</h:form>
package org.primefaces.examples.view;  
  
import java.io.Serializable;  
import java.util.ArrayList;  
import java.util.Date;  
import java.util.List;  
import java.util.UUID;  
  
import org.primefaces.event.SelectEvent;  
import org.primefaces.event.UnselectEvent;  
  
import org.primefaces.examples.domain.Car;  
import org.primefaces.examples.view.CarDataModel;  
  
public class TableBean {  
  
    static {  
        colors = new String[10];  
        colors[0] = "Black";  
        colors[1] = "White";  
        colors[2] = "Green";  
        colors[3] = "Red";  
        colors[4] = "Blue";  
        colors[5] = "Orange";  
        colors[6] = "Silver";  
        colors[7] = "Yellow";  
        colors[8] = "Brown";  
        colors[9] = "Maroon";  
  
        manufacturers = new String[10];  
        manufacturers[0] = "Mercedes";  
        manufacturers[1] = "BMW";  
        manufacturers[2] = "Volvo";  
        manufacturers[3] = "Audi";  
        manufacturers[4] = "Renault";  
        manufacturers[5] = "Opel";  
        manufacturers[6] = "Volkswagen";  
        manufacturers[7] = "Chrysler";  
        manufacturers[8] = "Ferrari";  
        manufacturers[9] = "Ford";  
    }  
  
    private final static String[] colors;  
  
    private final static String[] manufacturers;  
  
    private List<Car> carsSmall;  
      
    private Car selectedCar;  
  
    private CarDataModel mediumCarsModel;  
  
    public TableBean() {  
        carsSmall = new ArrayList<Car>();  
          
        populateRandomCars(carsSmall, 50);  
  
        mediumCarsModel = new CarDataModel(carsSmall);  
    }  
  
    private void populateRandomCars(List<Car> list, int size) {  
        for(int i = 0 ; i < size ; i++)  
            list.add(new Car(getRandomModel(), getRandomYear(), getRandomManufacturer(), getRandomColor()));  
    }  
  
    public Car getSelectedCar() {  
        return selectedCar;  
    }  
    public void setSelectedCar(Car selectedCar) {  
        this.selectedCar = selectedCar;  
    }  
  
    public CarDataModel getMediumCarsModel() {  
        return mediumCarsModel;  
    }  
}
package org.primefaces.examples.view;  
  
import java.util.List;  
import javax.faces.model.ListDataModel;  
import org.primefaces.examples.domain.Car;  
import org.primefaces.model.SelectableDataModel;  
  
public class CarDataModel extends ListDataModel<Car> implements SelectableDataModel<Car> {    
  
    public CarDataModel() {  
    }  
  
    public CarDataModel(List<Car> data) {  
        super(data);  
    }  
      
    @Override  
    public Car getRowData(String rowKey) {  
        //In a real app, a more efficient way like a query by rowKey should be implemented to deal with huge data  
          
        List<Car> cars = (List<Car>) getWrappedData();  
          
        for(Car car : cars) {  
            if(car.getModel().equals(rowKey))  
                return car;  
        }  
          
        return null;  
    }  
  
    @Override  
    public Object getRowKey(Car car) {  
        return car.getModel();  
    }  
}
Criado 13 de fevereiro de 2012
Respostas 0
Participantes 1