Class JpaGridDataSource<E>

java.lang.Object
org.apache.tapestry5.jpa.JpaGridDataSource<E>
All Implemented Interfaces:
GridDataSource

public class JpaGridDataSource<E> extends Object implements GridDataSource
A simple implementation of GridDataSource based on a EntityManager and a known entity class. This implementation does support multiple sort constraints. This class is not thread-safe; it maintains internal state. Typically, an instance of this object is created fresh as needed (that is, it is not stored between requests).
Since:
5.3
  • Constructor Details

    • JpaGridDataSource

      public JpaGridDataSource(javax.persistence.EntityManager entityManager, Class<E> entityType)
  • Method Details

    • getAvailableRows

      public int getAvailableRows()
      Returns the number of rows available in the data source.
      Specified by:
      getAvailableRows in interface GridDataSource
    • prepare

      public void prepare(int startIndex, int endIndex, List<SortConstraint> sortConstraints)
      Invoked to allow the source to prepare to present values. This gives the source a chance to pre-fetch data (when appropriate) and informs the source of the desired sort order. Sorting comes first, then extraction by range.
      Specified by:
      prepare in interface GridDataSource
      Parameters:
      startIndex - the starting index to be retrieved
      endIndex - the ending index to be retrieved
      sortConstraints - identify how data is to be sorted
    • applyAdditionalConstraints

      protected void applyAdditionalConstraints(javax.persistence.criteria.CriteriaQuery<?> criteria, javax.persistence.criteria.Root<E> root, javax.persistence.criteria.CriteriaBuilder builder)
    • getRowValue

      public Object getRowValue(int index)
      Returns the row value at the provided index. This method will be invoked in sequential order. In rare instances, GridDataSource.getAvailableRows() may return a different number of rows than are actually available (i.e., the database was changed between calls to GridDataSource.getAvailableRows() and the call to GridDataSource.prepare(int, int, java.util.List)). In that case, this method should return null for any out-of-range indexes.
      Specified by:
      getRowValue in interface GridDataSource
    • getRowType

      public Class<E> getRowType()
      Returns the type of value in the rows, or null if not known. This value is used to create a default BeanModel when no such model is explicitly provided.
      Specified by:
      getRowType in interface GridDataSource
      Returns:
      the row type, or null