PrimeFaces DataTable Сортировка и фильтрация не работают с JSF DataModel - PullRequest
1 голос
/ 26 июня 2011

У меня есть 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.Это ошибка?

  • В приложении B:

Код:

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()));
            }
        }
    }

Заранее благодарим за помощь.

1 Ответ

1 голос
/ 26 июня 2011

Это может быть ошибка PrimeFaces.Я видел некоторое обсуждение проблем с сортировкой DataTable при использовании модели данных.Вот ссылка на один из дефектов PrimeFaces в их трекере .

...