У меня есть 3 тестовых веб-приложения, использующих одну и ту же модель и контроллеры. Разница заключается в компонентах, управляемых сеансом JSF.
Приложения A и C использовать JSF DataModel для извлечения элементов: набор результатов запроса JPA возвращает Java-LIST, который затем переносится в ListDataModel.Значение этого последнего - элементы, отображаемые PrimeFaces dataTable .
Приложение B использует Java LIST для извлечения элементов: набор результатов JPA Query возвращает список Java, который является значением элементов, отображаемых в PrimeFaces 2.2.1 dataTable.
Сортировка и фильтрация в приложении B полностью функциональны ибыстро, в то время как в приложениях A и C они смертельно опасны.
Я просто хочу упомянуть, что фильтрация в сортировке других библиотек, таких как Richfaces, OpenFaces, работает из коробки с использованием этого же кода.
Проблема также остается в PrimeFaces 3.0.0.Это ошибка?
Код:
private List<Customer> items = null;
// remainder of code here
public List<Customer> getCustomerItems() {
if (customerItems == null) {
getPagingInfo();
customerItems = jpaController.findCustomerEntities(pagingInfo.getBatchSize(), pagingInfo.getFirstItem());
}
return customerItems;
}
В приложении A:
Код:
private DataModel items = null;
public PaginationHelper getPagination() {
if (pagination == null) {
pagination = new PaginationHelper(999999) {
@Override
public int getItemsCount() {
return getJpaController().getChimioCount();
}
@Override // The list of Customers is wrapped in a JSF ListDataModel
public DataModel createPageDataModel() {
return new ListDataModel(getJpaController().findCustomerEntities(getPageSize(), getPageFirstItem()));
}
};
}
return pagination;
}
/**
* this goes for the value attribute in a datatable to list all the Customer items
*/
public DataModel getItems() {
if (items == null) {
items = getPagination().createPageDataModel();
}
return items;
}
В приложении C:
Код:
private DataModel<Project> items;
// remainder of code here
/**
*The ListDataModel is initialized here
*/
public void init() {
try {
setProjectList(doInTransaction(new PersistenceAction<List<Project>>() {
public List<Project> execute(EntityManager em) {
Query query = em.createNamedQuery("project.getAll");
return (List<Project>) query.getResultList();
}
}));
} catch (ManagerException ex) {
Logger.getLogger(ProjectManager.class.getName()).log(Level.SEVERE, null, ex);
}
projectItems = new LinkedList<SelectItem>();
projectItems.add(new SelectItem(new Project(), "-- Select one project --"));
if (getProjectList() != null) {
projects = new ListDataModel<Project>(getProjectList());
for (Project p : getProjectList()) {
projectItems.add(new SelectItem(p, p.getName()));
}
}
}
Заранее благодарим за помощь.