CourseExperienceService.java 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. package com.qxgmat.service.inline;
  2. import com.github.pagehelper.Page;
  3. import com.nuliji.tools.AbstractService;
  4. import com.nuliji.tools.Tools;
  5. import com.nuliji.tools.Transform;
  6. import com.nuliji.tools.exception.ParameterException;
  7. import com.nuliji.tools.exception.SystemException;
  8. import com.nuliji.tools.mybatis.Example;
  9. import com.qxgmat.data.constants.enums.ExperienceDayRange;
  10. import com.qxgmat.data.constants.enums.ExperienceScoreRange;
  11. import com.qxgmat.data.constants.enums.status.DirectionStatus;
  12. import com.qxgmat.data.constants.enums.user.DataType;
  13. import com.qxgmat.data.dao.CourseDataMapper;
  14. import com.qxgmat.data.dao.CourseExperienceMapper;
  15. import com.qxgmat.data.dao.entity.CourseData;
  16. import com.qxgmat.data.dao.entity.CourseExperience;
  17. import com.qxgmat.data.dao.entity.User;
  18. import com.qxgmat.data.relation.CourseExperienceRelationMapper;
  19. import org.slf4j.Logger;
  20. import org.slf4j.LoggerFactory;
  21. import org.springframework.stereotype.Service;
  22. import javax.annotation.Resource;
  23. import java.util.Collection;
  24. import java.util.HashMap;
  25. import java.util.List;
  26. import java.util.Map;
  27. @Service
  28. public class CourseExperienceService extends AbstractService {
  29. private static final Logger logger = LoggerFactory.getLogger(CourseExperienceService.class);
  30. @Resource
  31. private CourseExperienceMapper courseExperienceMapper;
  32. @Resource
  33. private CourseExperienceRelationMapper courseExperienceRelationMapper;
  34. private Map<String, String> adminMap = new HashMap<String, String>(){{
  35. put("", "ce");
  36. }};
  37. public Page<CourseExperience> listWithUser(int page, int size, Integer userId, String startTime, String endTime, String order, DirectionStatus direction){
  38. if(order == null || order.isEmpty()){
  39. order = "id";
  40. }
  41. if(adminMap.containsKey(order)){
  42. order = adminMap.get(order)+".`"+Tools.underscoreName(order)+"`";
  43. }else{
  44. order = adminMap.get("")+".`"+Tools.underscoreName(order)+"`";
  45. }
  46. if (direction == null){
  47. direction = DirectionStatus.DESC;
  48. }
  49. String finalOrder = order;
  50. DirectionStatus finalDirection = direction;
  51. Page<CourseExperience> p = page(
  52. ()-> courseExperienceRelationMapper.listWithUser(userId, startTime, endTime, finalOrder, finalDirection.key)
  53. , page, size);
  54. Collection ids = Transform.getIds(p, CourseExperience.class, "id");
  55. Transform.replace(p, select(ids), CourseExperience.class, "id");
  56. return p;
  57. }
  58. public Page<CourseExperience> listAdmin(int page, int size, Integer userId, String keyword, String prepareStatus, ExperienceScoreRange experienceScore, ExperienceDayRange experienceDay, String experiencePercent, String order, DirectionStatus direction){
  59. Example example = new Example(CourseExperience.class);
  60. if(userId != null){
  61. example.and(
  62. example.createCriteria()
  63. .andEqualTo("userId", userId)
  64. );
  65. }
  66. if(keyword != null){
  67. example.and(
  68. example.createCriteria()
  69. .orLike("title", "%"+keyword+"%")
  70. .orLike("content", "%"+keyword+"%")
  71. );
  72. }
  73. if (prepareStatus != null){
  74. example.and(
  75. example.createCriteria()
  76. .andEqualTo("prepareStatus", prepareStatus)
  77. );
  78. }
  79. if (experienceScore != null){
  80. example.and(
  81. example.createCriteria()
  82. .andGreaterThanOrEqualTo("experienceScore", experienceScore.min)
  83. .andLessThan("experienceScore", experienceScore.max)
  84. );
  85. }
  86. if (experienceDay != null){
  87. example.and(
  88. example.createCriteria()
  89. .andGreaterThanOrEqualTo("experienceDay", experienceDay.min)
  90. .andLessThan("experienceDay", experienceDay.max)
  91. );
  92. }
  93. if (experiencePercent != null){
  94. example.and(
  95. example.createCriteria()
  96. .andEqualTo("experiencePercent", experiencePercent)
  97. );
  98. }
  99. if(order == null || order.isEmpty()) order = "id";
  100. switch(direction){
  101. case ASC:
  102. example.orderBy(order).asc();
  103. break;
  104. case DESC:
  105. default:
  106. example.orderBy(order).desc();
  107. }
  108. return select(courseExperienceMapper, example, page, size);
  109. }
  110. public Page<CourseExperience> list(int page, int size,String prepareStatus, ExperienceScoreRange experienceScore, ExperienceDayRange experienceDay, String experiencePercent, String order, DirectionStatus direction){
  111. Example example = new Example(CourseExperience.class);
  112. if(prepareStatus != null){
  113. example.and(
  114. example.createCriteria()
  115. .andEqualTo("prepareStatus", prepareStatus)
  116. );
  117. }
  118. if(experienceDay != null){
  119. example.and(
  120. example.createCriteria()
  121. .andGreaterThanOrEqualTo("experienceDay", experienceDay.min)
  122. .andLessThan("experienceDay", experienceDay.max)
  123. );
  124. }
  125. if(experienceScore != null){
  126. example.and(
  127. example.createCriteria()
  128. .andGreaterThanOrEqualTo("experienceScore", experienceScore.min)
  129. .andLessThan("experienceScore", experienceScore.max)
  130. );
  131. }
  132. if(experiencePercent != null){
  133. example.and(
  134. example.createCriteria()
  135. .andEqualTo("experiencePercent", experiencePercent)
  136. );
  137. }
  138. if(order == null || order.isEmpty()) order = "id";
  139. switch(direction){
  140. case ASC:
  141. example.orderBy(order).asc();
  142. break;
  143. case DESC:
  144. default:
  145. example.orderBy(order).desc();
  146. }
  147. return select(courseExperienceMapper, example, page, size);
  148. }
  149. /**
  150. * 累加收藏记录,访问记录
  151. * @param view
  152. * @param collect
  153. */
  154. public void accumulation(Integer experienceId, int view, int collect){
  155. courseExperienceRelationMapper.accumulation(experienceId, view, collect);
  156. }
  157. /**
  158. * 替换comment的用户信息为真实用户信息
  159. * @param experiences
  160. * @param users
  161. */
  162. public void replaceUser(List<CourseExperience> experiences, List<User> users){
  163. Map userMap = Transform.getMap(users, User.class, "id");
  164. for(CourseExperience experience : experiences){
  165. if (experience.getUserId() == 0) {
  166. continue;
  167. }
  168. User user = (User)userMap.get(experience.getUserId());
  169. if (user == null){
  170. continue;
  171. }
  172. experience.setNickname(user.getNickname());
  173. }
  174. }
  175. public CourseExperience add(CourseExperience courseData){
  176. int result = insert(courseExperienceMapper, courseData);
  177. courseData = one(courseExperienceMapper, courseData.getId());
  178. if(courseData == null){
  179. throw new SystemException("心经添加失败");
  180. }
  181. return courseData;
  182. }
  183. public CourseExperience edit(CourseExperience courseData){
  184. CourseExperience in = one(courseExperienceMapper, courseData.getId());
  185. if(in == null){
  186. throw new ParameterException("心经不存在");
  187. }
  188. int result = update(courseExperienceMapper, courseData);
  189. return courseData;
  190. }
  191. public boolean delete(Number id){
  192. CourseExperience in = one(courseExperienceMapper, id);
  193. if(in == null){
  194. throw new ParameterException("心经不存在");
  195. }
  196. int result = delete(courseExperienceMapper, id);
  197. return result > 0;
  198. }
  199. public CourseExperience get(Number id){
  200. CourseExperience in = one(courseExperienceMapper, id);
  201. if(in == null){
  202. throw new ParameterException("心经不存在");
  203. }
  204. return in;
  205. }
  206. public Page<CourseExperience> select(int page, int pageSize){
  207. return select(courseExperienceMapper, page, pageSize);
  208. }
  209. public Page<CourseExperience> select(Integer[] ids){
  210. return page(()->select(courseExperienceMapper, ids), 1, ids.length);
  211. }
  212. public List<CourseExperience> select(Collection ids){
  213. return select(courseExperienceMapper, ids);
  214. }
  215. }