|
@@ -2,13 +2,22 @@ package com.mooctest.crowd.domain.repository;
|
|
|
|
|
|
import com.mooctest.crowd.domain.dao.ApplicationTypeDao;
|
|
|
import com.mooctest.crowd.domain.domainobject.ApplicationType;
|
|
|
+import com.mooctest.crowd.domain.model.ApplicationTypePO;
|
|
|
import com.mooctest.crowd.domain.util.Converter;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
+import org.apache.commons.lang3.StringUtils;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.data.domain.Page;
|
|
|
import org.springframework.data.domain.Pageable;
|
|
|
+import org.springframework.data.jpa.domain.Specification;
|
|
|
+import org.springframework.data.jpa.domain.Specifications;
|
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
+import javax.persistence.criteria.CriteriaBuilder;
|
|
|
+import javax.persistence.criteria.CriteriaQuery;
|
|
|
+import javax.persistence.criteria.Predicate;
|
|
|
+import javax.persistence.criteria.Root;
|
|
|
+
|
|
|
|
|
|
@Slf4j
|
|
|
@Component
|
|
@@ -19,7 +28,22 @@ public class ApplicationTypeRepo implements IApplicationTypeRepo{
|
|
|
private ApplicationTypeDao applicationTypeDao;
|
|
|
|
|
|
@Override
|
|
|
- public Page<ApplicationType> getHotTesting(Pageable pageable) {
|
|
|
- return applicationTypeDao.findAll(pageable).map(ApplicationTypePO->Converter.convert(ApplicationType.class, ApplicationTypePO));
|
|
|
+ public Page<ApplicationType> getHotTesting(Pageable pageable,String keyword) {
|
|
|
+ Specifications<ApplicationTypePO> where = Specifications.where(getArticlesByIsNotDeleted(keyword));
|
|
|
+ return applicationTypeDao.findAll(where,pageable).map(ApplicationTypePO->Converter.convert(ApplicationType.class, ApplicationTypePO));
|
|
|
+ }
|
|
|
+ private Specification<ApplicationTypePO> getArticlesByIsNotDeleted(String keyword) {
|
|
|
+ return new Specification<ApplicationTypePO>() {
|
|
|
+ @Override
|
|
|
+ public Predicate toPredicate(Root<ApplicationTypePO> a, CriteriaQuery<?> q, CriteriaBuilder cb) {
|
|
|
+ Predicate predicate = cb.conjunction();
|
|
|
+ if(keyword != null) {
|
|
|
+ predicate.getExpressions().add(
|
|
|
+ cb.like(a.<String>get("name"), "%" + StringUtils.trim(keyword) + "%")
|
|
|
+ );
|
|
|
+ }
|
|
|
+ return predicate;
|
|
|
+ }
|
|
|
+ };
|
|
|
}
|
|
|
}
|