
org.springframework.data.jpa.support.DataTablesUtils Maven / Gradle / Ivy
package org.springframework.data.jpa.support;
import java.util.ArrayList;
import java.util.List;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;
import org.springframework.data.domain.Sort.Direction;
import org.springframework.data.domain.Sort.Order;
public class DataTablesUtils {
public final static String OR_SEPARATOR = "+";
public final static String ESCAPED_OR_SEPARATOR = "\\+";
public final static String ATTRIBUTE_SEPARATOR = ".";
public final static String ESCAPED_ATTRIBUTE_SEPARATOR = "\\.";
public final static char ESCAPE_CHAR = '\\';
public final static String NULL = "NULL";
public final static String ESCAPED_NULL = "\\NULL";
/**
* Creates a 'LIMIT .. OFFSET .. ORDER BY ..' clause for the given
* {@link DataTablesInput}.
*
* @param input the {@link DataTablesInput} mapped from the Ajax request
* @return a {@link Pageable}, must not be {@literal null}.
*/
public static Pageable getPageable(DataTablesInput input) {
List orders = new ArrayList();
for (org.springframework.data.jpa.support.Order order : input.getOrder()) {
Column column = input.getColumns().get(order.getColumn());
if (column.getOrderable()) {
String sortColumn = column.getData();
Direction sortDirection = Direction.fromString(order.getDir());
orders.add(new Order(sortDirection, sortColumn));
}
}
Sort sort = orders.isEmpty() ? null : new Sort(orders);
if (input.getLength() == -1) {
input.setStart(0);
input.setLength(Integer.MAX_VALUE);
}
return new DataTablesPageRequest(input.getStart(), input.getLength(), sort);
}
public static boolean isBoolean(String filterValue) {
return "TRUE".equalsIgnoreCase(filterValue) || "FALSE".equalsIgnoreCase(filterValue);
}
public static String getLikeFilterValue(String filterValue) {
return "%" + filterValue.toLowerCase().replaceAll("%", "\\\\" + "%").replaceAll("_", "\\\\" + "_") + "%";
}
private static class DataTablesPageRequest implements Pageable {
private final int offset;
private final int pageSize;
private final Sort sort;
public DataTablesPageRequest(int offset, int pageSize, Sort sort) {
this.offset = offset;
this.pageSize = pageSize;
this.sort = sort;
}
@Override
public int getOffset() {
return offset;
}
@Override
public int getPageSize() {
return pageSize;
}
@Override
public Sort getSort() {
return sort;
}
@Override
public Pageable next() {
throw new UnsupportedOperationException();
}
@Override
public Pageable previousOrFirst() {
throw new UnsupportedOperationException();
}
@Override
public Pageable first() {
throw new UnsupportedOperationException();
}
@Override
public boolean hasPrevious() {
throw new UnsupportedOperationException();
}
@Override
public int getPageNumber() {
throw new UnsupportedOperationException();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy