<h: form> dentro de <ui: repeat> não totalmente funcional, somente o último <h: form> é processado
Eu gostaria de editar uma lista de itens na mesma página. Cada item deve ser editado usando um formulário separado. Estou criando um h: form dentro de ui: repeat. Somente quando o último formulário é enviado, a entrada do usuário é aplicada ao bean gerenciado. Para todos os outros formulários, a entrada do usuário não é aplicada ao modelo.
@ManagedBean
public class Controller {
Logger logger = Logger.getLogger("TestWeb");
private List<Customer> customerList;
public List<Customer> getCustomerList() {
if (customerList == null) {
customerList = new ArrayList<Customer>();
customerList.add(new Customer("Daffy Duck", "[email protected]"));
customerList.add(new Customer("Bugs Bunny", "[email protected]"));
customerList.add(new Customer("Samity Sam", "[email protected]"));
}
return customerList;
}
public String updateCustomer(Customer c) {
logger.info("Updating: " + c.getName());
return null;
}
}
Na visão, eu tenho
<ui:repeat var="c" value="#{controller.customerList}">
<h:form>
<h3>Edit Customer</h3>
Name: <h:inputText value="#{c.name}"/><br/>
E-mail: <h:inputText value="#{c.email}"/><br/>
<h:commandButton value="Update"
action="#{controller.updateCustomer(c)}"/>
</h:form>
</ui:repeat>
Eu procuro por horas sem qualquer solução. Qual será a maneira correta de fazer isso? Eu posso hackeá-lo usando uma única forma e usando um ui: repita dentro dele. Mas há muitos problemas com isso e prefiro não seguir esse caminho. Obrigado.