UserCollectQuestionService.java 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. package com.qxgmat.service;
  2. import com.github.pagehelper.Page;
  3. import com.nuliji.tools.AbstractService;
  4. import com.nuliji.tools.PageResult;
  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.QuestionType;
  10. import com.qxgmat.data.constants.enums.module.QuestionModule;
  11. import com.qxgmat.data.constants.enums.status.DirectionStatus;
  12. import com.qxgmat.data.dao.UserCollectQuestionMapper;
  13. import com.qxgmat.data.dao.entity.Question;
  14. import com.qxgmat.data.dao.entity.QuestionNo;
  15. import com.qxgmat.data.dao.entity.UserCollectQuestion;
  16. import com.qxgmat.data.relation.UserCollectQuestionRelationMapper;
  17. import com.qxgmat.data.relation.entity.UserCollectQuestionRelation;
  18. import com.qxgmat.service.inline.QuestionNoService;
  19. import com.qxgmat.service.inline.QuestionService;
  20. import org.slf4j.Logger;
  21. import org.slf4j.LoggerFactory;
  22. import org.springframework.stereotype.Service;
  23. import org.springframework.transaction.annotation.Transactional;
  24. import javax.annotation.Resource;
  25. import java.util.Collection;
  26. import java.util.List;
  27. @Service
  28. public class UserCollectQuestionService extends AbstractService {
  29. private static final Logger logger = LoggerFactory.getLogger(UserCollectQuestionService.class);
  30. @Resource
  31. private UserCollectQuestionMapper userCollectQuestionMapper;
  32. @Resource
  33. private UserCollectQuestionRelationMapper userCollectQuestionRelationMapper;
  34. @Resource
  35. private QuestionNoService questionNoService;
  36. @Resource
  37. private QuestionService questionService;
  38. /**
  39. * 获取用户题目收藏列表
  40. * @param page
  41. * @param size
  42. * @param userId
  43. * @param type
  44. * @return
  45. */
  46. public PageResult<UserCollectQuestionRelation> listQuestion(int page, int size, Integer userId, QuestionModule module, QuestionType type, String startTime, String endTime, String order, DirectionStatus direction){
  47. String moduleKey = module == null ? null : module.key;
  48. String typeKey = type == null ? null : type.key;
  49. Page<UserCollectQuestion> p = page(()->{
  50. userCollectQuestionRelationMapper.list(userId, moduleKey, typeKey, startTime, endTime, order, direction.key);
  51. }, page, size);
  52. Collection ids = Transform.getIds(p, UserCollectQuestion.class, "id");
  53. // 获取详细数据
  54. List<UserCollectQuestion> list = select(ids);
  55. List<UserCollectQuestionRelation> pr = Transform.convert(list, UserCollectQuestionRelation.class);
  56. // 获取题目信息
  57. Collection questionIds = Transform.getIds(pr, UserCollectQuestionRelation.class, "questionId");
  58. List<Question> questionList = questionService.select(questionIds);
  59. Transform.combine(pr, questionList, UserCollectQuestionRelation.class, "questionId", "question", Question.class, "id");
  60. // 获取题目编号信息
  61. Collection questionNoIds = Transform.getIds(pr, UserCollectQuestionRelation.class, "questionNoId");
  62. List<QuestionNo> questionNoList = questionNoService.select(questionNoIds);
  63. Transform.combine(pr, questionNoList, UserCollectQuestionRelation.class, "questionNoId", "questionNo", Question.class, "id");
  64. return new PageResult<>(pr, p.getTotal());
  65. }
  66. @Transactional
  67. public UserCollectQuestion addQuestion(Integer userId, Integer questionNoId){
  68. Example example = new Example(UserCollectQuestion.class);
  69. example.and(
  70. example.createCriteria()
  71. .andEqualTo("userId", userId)
  72. .andEqualTo("questionNoId", questionNoId)
  73. );
  74. UserCollectQuestion in = one(userCollectQuestionMapper, example);
  75. if (in != null){
  76. return in;
  77. }
  78. QuestionNo no = questionNoService.get(questionNoId);
  79. UserCollectQuestion collect = add(UserCollectQuestion.builder()
  80. .userId(userId)
  81. .questionNoId(questionNoId)
  82. .questionId(no.getQuestionId()).build());
  83. int result = insert(userCollectQuestionMapper, collect);
  84. return collect;
  85. }
  86. @Transactional
  87. public boolean deleteQuestion(Integer userId, Integer questionNoId){
  88. Example example = new Example(UserCollectQuestion.class);
  89. example.and(
  90. example.createCriteria()
  91. .andEqualTo("userId", userId)
  92. .andEqualTo("questionNoId", questionNoId)
  93. );
  94. UserCollectQuestion in = one(userCollectQuestionMapper, example);
  95. if (in == null){
  96. return true;
  97. }
  98. int result = delete(userCollectQuestionMapper, example);
  99. return result > 0;
  100. }
  101. public UserCollectQuestion add(UserCollectQuestion collect){
  102. int result = insert(userCollectQuestionMapper, collect);
  103. collect = one(userCollectQuestionMapper, collect.getId());
  104. if(collect == null){
  105. throw new SystemException("收藏添加失败");
  106. }
  107. return collect;
  108. }
  109. public UserCollectQuestion edit(UserCollectQuestion collect){
  110. UserCollectQuestion in = one(userCollectQuestionMapper, collect.getId());
  111. if(in == null){
  112. throw new ParameterException("收藏不存在");
  113. }
  114. int result = update(userCollectQuestionMapper, collect);
  115. return collect;
  116. }
  117. public boolean delete(Number id){
  118. UserCollectQuestion in = one(userCollectQuestionMapper, id);
  119. if(in == null){
  120. throw new ParameterException("收藏不存在");
  121. }
  122. int result = delete(userCollectQuestionMapper, id);
  123. return result > 0;
  124. }
  125. public UserCollectQuestion get(Number id){
  126. UserCollectQuestion in = one(userCollectQuestionMapper, id);
  127. if(in == null){
  128. throw new ParameterException("收藏不存在");
  129. }
  130. return in;
  131. }
  132. public Page<UserCollectQuestion> select(int page, int pageSize){
  133. return select(userCollectQuestionMapper, page, pageSize);
  134. }
  135. public List<UserCollectQuestion> select(Collection ids){
  136. return select(userCollectQuestionMapper, ids);
  137. }
  138. }