From 8059e9b991c15edbac508e6b658a0d9571d11b1c Mon Sep 17 00:00:00 2001
From: huliguo <2023611923@qq.com>
Date: 星期五, 01 八月 2025 12:46:00 +0800
Subject: [PATCH] bug修改

---
 ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/miniapp/AppLotteryEventController.java |  142 ++++++++++++++++++++++++++++++++---------------
 1 files changed, 97 insertions(+), 45 deletions(-)

diff --git a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/miniapp/AppLotteryEventController.java b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/miniapp/AppLotteryEventController.java
index aaec304..b2a3931 100644
--- a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/miniapp/AppLotteryEventController.java
+++ b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/controller/miniapp/AppLotteryEventController.java
@@ -25,6 +25,7 @@
 import javax.annotation.Resource;
 import java.math.BigDecimal;
 import java.time.LocalDateTime;
+import java.time.ZoneOffset;
 import java.time.format.DateTimeFormatter;
 import java.util.HashMap;
 import java.util.List;
@@ -55,32 +56,42 @@
 	private IUserLotteryEventQuestionsAnswersService userLotteryEventQuestionsAnswersService;
 	
 	@Resource
-	private ILotteryEventQuestionsService lotteryEventServiceQuestionsService;
+	private ILotteryEventQuestionsService lotteryEventQuestionsService;
 	
 	@Resource
 	private ILotteryEventQuestionsAnswersService lotteryEventQuestionsAnswersService;
 	
 	
 	@ResponseBody
-	@PostMapping("/getLotteryEvent/{id}")
+	@PostMapping("/getLotteryEvent/{id}/{orderId}")
 	@ApiOperation(value = "获取抽奖页详情【2.0】", tags = "抽奖活动")
 	@ApiImplicitParams({
 			@ApiImplicitParam(name = "id", value = "抽奖活动id", required = true, dataType = "String", paramType = "path")
 	})
-	public R<LotteryEventVo> getLotteryEvent(@PathVariable("id") String id) {
-		LotteryEventVo lotteryEvent = lotteryEventService.getLotteryEvent(id);
+	public R<LotteryEventVo> getLotteryEvent(@PathVariable("id") String id, @PathVariable("orderId") String orderId) {
+		LotteryEventVo lotteryEvent = lotteryEventService.getLotteryEvent(id, orderId);
+		TLotteryEvent event = lotteryEventService.getById(id);
+		if (LocalDateTime.now().isBefore(event.getStartTime())) {
+			lotteryEvent.setStatus(1);
+		}
+		if (LocalDateTime.now().isAfter(event.getEndTime())) {
+			lotteryEvent.setStatus(3);
+		}
+		if (LocalDateTime.now().isAfter(event.getStartTime()) && LocalDateTime.now().isBefore(event.getEndTime())) {
+			lotteryEvent.setStatus(2);
+		}
 		return R.ok(lotteryEvent);
 	}
 	
 	
 	@ResponseBody
-	@PostMapping("/lotteryDraw/{id}")
+	@PostMapping("/lotteryDraw/{id}/{orderId}")
 	@ApiOperation(value = "抽奖操作【2.0】", tags = "抽奖活动", notes = "返回奖品ID")
 	@ApiImplicitParams({
 			@ApiImplicitParam(name = "id", value = "抽奖活动id", required = true, dataType = "String", paramType = "path")
 	})
-	public R lotteryDraw(@PathVariable("id") String id) {
-		return lotteryEventService.lotteryDraw(id);
+	public R<TLotteryEventPrize> lotteryDraw(@PathVariable("id") String id, @PathVariable("orderId") String orderId) {
+		return lotteryEventService.lotteryDraw(id, orderId);
 	}
 	
 	
@@ -92,7 +103,20 @@
 		Page<AppLotteryEventPageVo> page = new Page<>();
 		page.setSize(dto.getPageSize());
 		page.setCurrent(dto.getPageNum());
-		List<AppLotteryEventPageVo> activityPageVoList = lotteryEventService.pageAppLotteryEvent(page,userId);
+		List<AppLotteryEventPageVo> activityPageVoList = lotteryEventService.pageAppLotteryEvent(page, userId);
+		activityPageVoList.forEach(vo -> {
+			String startTime = vo.getStartTime();
+			String endTime = vo.getEndTime();
+			if (LocalDateTime.now().isBefore(LocalDateTime.parse(startTime, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")))) {
+				vo.setStatus(1);
+			}
+			if (LocalDateTime.now().isAfter(LocalDateTime.parse(endTime, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")))) {
+				vo.setStatus(3);
+			}
+			if (LocalDateTime.now().isAfter(LocalDateTime.parse(startTime, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"))) && LocalDateTime.now().isBefore(LocalDateTime.parse(endTime, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")))) {
+				vo.setStatus(2);
+			}
+		});
 		return R.ok(page.setRecords(activityPageVoList));
 	}
 	
@@ -105,21 +129,28 @@
 	})
 	public R<LotteryEventInfoVo> getLotteryEventInfo(@PathVariable("id") String id){
 		Long userId = SecurityUtils.getUserId();
-		LotteryEvent lotteryEvent = lotteryEventService.getById(id);
+		TLotteryEvent lotteryEvent = lotteryEventService.getById(id);
 		LotteryEventInfoVo vo = new LotteryEventInfoVo();
 		vo.setId(lotteryEvent.getId());
 		vo.setName(lotteryEvent.getName());
 		vo.setActivityProfile(lotteryEvent.getActivityProfile());
 		vo.setStartTime(lotteryEvent.getStartTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+		vo.setEndTime(lotteryEvent.getEndTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
 		vo.setActivityContent(lotteryEvent.getActivityContent());
-		int count = userLotteryEventService.count(new QueryWrapper<UserLotteryEvent>().eq("lottery_event_id", id).eq("user_id", userId));
+		int count = userLotteryEventService.count(new QueryWrapper<TUserLotteryEvent>().eq("lottery_event_id", id).eq("user_id", userId));
 		vo.setParticipation(count > 0);
 		//答题抽奖需要判断是否答题完成
 		if (5 == lotteryEvent.getActivityType()) {
-			UserLotteryEventQuestions questionsServiceOne = userLotteryEventQuestionsService.getOne(new QueryWrapper<UserLotteryEventQuestions>().eq("lottery_event_id", id).eq("user_id", userId));
+			TUserLotteryEventQuestions questionsServiceOne = userLotteryEventQuestionsService.getOne(new QueryWrapper<TUserLotteryEventQuestions>().eq("lottery_event_id", id).eq("user_id", userId));
 			vo.setContinueAnswer(null != questionsServiceOne ? questionsServiceOne.getStatus() : 0);
 			vo.setAnswerStartTime(null != questionsServiceOne ? questionsServiceOne.getCreateTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")) : null);
 			vo.setAnswerTimeLimit(lotteryEvent.getAnsweringTime());
+			if (vo.getContinueAnswer() == 1) {
+				long remainingTime = (lotteryEvent.getAnsweringTime() * 60) - (LocalDateTime.now().toEpochSecond(ZoneOffset.of("+8")) - questionsServiceOne.getCreateTime().toEpochSecond(ZoneOffset.of("+8")));
+				int count1 = userLotteryEventQuestionsAnswersService.count(new QueryWrapper<TUserLotteryEventQuestionsAnswers>().eq("lottery_event_id", id).eq("user_id", userId));
+				vo.setRemainingTime(remainingTime);
+				vo.setCurrent(count1 - 1);
+			}
 		}
 		return R.ok(vo);
 	}
@@ -129,24 +160,25 @@
 	@ApiOperation(value = "获取答题题目【2.0】", tags = "抽奖活动")
 	public R<LotteryEventQuestionsVo> getLotteryEventQuestions(@RequestBody LotteryEventQuestionsDto dto) {
 		Long userId = SecurityUtils.getUserId();
-		UserLotteryEventQuestions questionsServiceOne = userLotteryEventQuestionsService.getOne(new QueryWrapper<UserLotteryEventQuestions>().eq("lottery_event_id", dto.getId()).eq("user_id", userId));
+		TUserLotteryEventQuestions questionsServiceOne = userLotteryEventQuestionsService.getOne(new QueryWrapper<TUserLotteryEventQuestions>().eq("lottery_event_id", dto.getId()).eq("user_id", userId));
 		LotteryEventQuestionsVo vo = new LotteryEventQuestionsVo();
-		int count = lotteryEventServiceQuestionsService.count(new QueryWrapper<LotteryEventQuestions>().eq("lottery_event_id", dto.getId()));
+		vo.setId(dto.getId());
+		int count = lotteryEventQuestionsService.count(new QueryWrapper<TLotteryEventQuestions>().eq("lottery_event_id", dto.getId()));
 		vo.setTotal(count);
 		//没有答题,直接从第一题开始
 		if (null == questionsServiceOne) {
 			if (-1 == dto.getStepOrDown()) {
 				return R.fail("操作失败");
 			}
-			LotteryEventQuestions questions = lotteryEventServiceQuestionsService.getOne(new QueryWrapper<LotteryEventQuestions>().eq("lottery_event_id", dto.getId()).orderByAsc("sort"));
-			vo.setCurrent(1);
+			TLotteryEventQuestions questions = lotteryEventQuestionsService.getOne(new QueryWrapper<TLotteryEventQuestions>().eq("lottery_event_id", dto.getId()).orderByAsc("sort").last(" limit 1"));
+			vo.setCurrent(0);
 			vo.setName(questions.getName());
-			List<LotteryEventQuestionsAnswers> list = lotteryEventQuestionsAnswersService.list(new QueryWrapper<LotteryEventQuestionsAnswers>().eq("lottery_event_questions_id", questions.getId()));
+			List<TLotteryEventQuestionsAnswers> list = lotteryEventQuestionsAnswersService.list(new QueryWrapper<TLotteryEventQuestionsAnswers>().eq("lottery_event_questions_id", questions.getId()));
 			//封装答题
 			List<Map<String, String>> options = list.stream().map(item -> {
 				Map<String, String> map = new HashMap<>();
 				map.put("id", item.getId());
-				map.put("name", item.getAnswer());
+				map.put("name", item.getAnswers());
 				return map;
 			}).collect(Collectors.toList());
 			vo.setOptions(options);
@@ -154,35 +186,41 @@
 			//上一题
 			Integer current = dto.getCurrent();
 			if (-1 == dto.getStepOrDown()) {
-				if (current - 1 <= 0) {
-					return R.fail("操作失败");
+				if (current - 1 < 0) {
+					current = 0;
 				}
 				current--;
 			} else {
 				//下一题
-				if (current >= count) {
-					return R.fail("操作失败");
-				}
 				current++;
+				if (current >= count) {
+					current = count - 1;
+				}
 			}
-			List<LotteryEventQuestions> list = lotteryEventServiceQuestionsService.list(new QueryWrapper<LotteryEventQuestions>().eq("lottery_event_id", dto.getId()).orderByAsc("sort"));
-			LotteryEventQuestions lotteryEventQuestions = list.get(current);
+			List<TLotteryEventQuestions> list = lotteryEventQuestionsService.list(new QueryWrapper<TLotteryEventQuestions>().eq("lottery_event_id", dto.getId()).orderByAsc("sort"));
+			TLotteryEventQuestions lotteryEventQuestions = list.get(current);
 			vo.setCurrent(current);
 			vo.setName(lotteryEventQuestions.getName());
-			List<LotteryEventQuestionsAnswers> list1 = lotteryEventQuestionsAnswersService.list(new QueryWrapper<LotteryEventQuestionsAnswers>().eq("lottery_event_questions_id", lotteryEventQuestions.getId()));
+			List<TLotteryEventQuestionsAnswers> list1 = lotteryEventQuestionsAnswersService.list(new QueryWrapper<TLotteryEventQuestionsAnswers>().eq("lottery_event_questions_id", lotteryEventQuestions.getId()));
 			//封装答题
 			List<Map<String, String>> options = list1.stream().map(item -> {
 				Map<String, String> map = new HashMap<>();
 				map.put("id", item.getId());
-				map.put("name", item.getAnswer());
+				map.put("name", item.getAnswers());
 				return map;
 			}).collect(Collectors.toList());
-			if (-1 == dto.getStepOrDown()) {
-				UserLotteryEventQuestionsAnswers one = userLotteryEventQuestionsAnswersService.getOne(new QueryWrapper<UserLotteryEventQuestionsAnswers>().eq("lottery_event_id", dto.getId()).eq("user_id", userId).orderByDesc("create_time").last(" limit 0, 1"));
-				if (null != one) {
-					vo.setAnswer(lotteryEventQuestionsAnswersService.getById(one.getLotteryEventQuestionsAnswersId()).getAnswer());
-				}
+
+			TUserLotteryEventQuestionsAnswers one = userLotteryEventQuestionsAnswersService.getOne(new QueryWrapper<TUserLotteryEventQuestionsAnswers>().eq("lottery_event_question_id", lotteryEventQuestions.getId()).eq("user_id", userId).orderByDesc("create_time").last(" limit 0, 1"));
+			if (null != one) {
+				vo.setAnswer(lotteryEventQuestionsAnswersService.getById(one.getLotteryEventQuestionsAnswersId()).getAnswers());
 			}
+
+//			if (-1 == dto.getStepOrDown() || current == list.size() - 1) {
+//				TUserLotteryEventQuestionsAnswers one = userLotteryEventQuestionsAnswersService.getOne(new QueryWrapper<TUserLotteryEventQuestionsAnswers>().eq("lottery_event_question_id", lotteryEventQuestions.getId()).eq("user_id", userId).orderByDesc("create_time").last(" limit 0, 1"));
+//				if (null != one) {
+//					vo.setAnswer(lotteryEventQuestionsAnswersService.getById(one.getLotteryEventQuestionsAnswersId()).getAnswers());
+//				}
+//			}
 			vo.setOptions(options);
 		}
 		return R.ok(vo);
@@ -192,15 +230,15 @@
 	@PostMapping("/answerQuestion")
 	@ApiOperation(value = "答题操作【2.0】", tags = "抽奖活动")
 	public R answerQuestion(@RequestBody AnswerQuestionDto dto) {
-		List<LotteryEventQuestions> list = lotteryEventServiceQuestionsService.list(new QueryWrapper<LotteryEventQuestions>().eq("lottery_event_id", dto.getId()).orderByAsc("sort"));
-		LotteryEventQuestions lotteryEventQuestions = list.get(dto.getCurrent());
-		List<LotteryEventQuestionsAnswers> list1 = lotteryEventQuestionsAnswersService.list(new QueryWrapper<LotteryEventQuestionsAnswers>().eq("lottery_event_questions_id", lotteryEventQuestions.getId()));
-		LotteryEventQuestionsAnswers lotteryEventQuestionsAnswers = list1.stream().filter(item -> item.getAnswer().equals(dto.getAnswer())).findAny().orElse(null);
+		List<TLotteryEventQuestions> list = lotteryEventQuestionsService.list(new QueryWrapper<TLotteryEventQuestions>().eq("lottery_event_id", dto.getId()).orderByAsc("sort"));
+		TLotteryEventQuestions lotteryEventQuestions = list.get(dto.getCurrent());
+		List<TLotteryEventQuestionsAnswers> list1 = lotteryEventQuestionsAnswersService.list(new QueryWrapper<TLotteryEventQuestionsAnswers>().eq("lottery_event_questions_id", lotteryEventQuestions.getId()));
+		TLotteryEventQuestionsAnswers lotteryEventQuestionsAnswers = list1.stream().filter(item -> item.getAnswers().equals(dto.getAnswer())).findAny().orElse(null);
 		//构建答题数据
 		Long userId = SecurityUtils.getUserId();
-		UserLotteryEventQuestions questionsServiceOne = userLotteryEventQuestionsService.getOne(new QueryWrapper<UserLotteryEventQuestions>().eq("lottery_event_id", dto.getId()).eq("user_id", userId));
+		TUserLotteryEventQuestions questionsServiceOne = userLotteryEventQuestionsService.getOne(new QueryWrapper<TUserLotteryEventQuestions>().eq("lottery_event_id", dto.getId()).eq("user_id", userId));
 		if (null == questionsServiceOne) {
-			questionsServiceOne = new UserLotteryEventQuestions();
+			questionsServiceOne = new TUserLotteryEventQuestions();
 			questionsServiceOne.setId(IdUtils.simpleUUID());
 			questionsServiceOne.setUserId(userId);
 			questionsServiceOne.setLotteryEventId(dto.getId());
@@ -209,15 +247,17 @@
 			userLotteryEventQuestionsService.save(questionsServiceOne);
 		}
 		//构建或者修改答题数据
-		UserLotteryEventQuestionsAnswers one = userLotteryEventQuestionsAnswersService.getOne(new QueryWrapper<UserLotteryEventQuestionsAnswers>().eq("lottery_event_question_id", lotteryEventQuestions.getId()).eq("user_id", userId));
+		TUserLotteryEventQuestionsAnswers one = userLotteryEventQuestionsAnswersService.getOne(new QueryWrapper<TUserLotteryEventQuestionsAnswers>().eq("lottery_event_question_id", lotteryEventQuestions.getId()).eq("user_id", userId));
 		if (null == one) {
-			one = new UserLotteryEventQuestionsAnswers();
+			one = new TUserLotteryEventQuestionsAnswers();
 			one.setId(IdUtils.simpleUUID());
 			one.setLotteryEventId(dto.getId());
 			one.setUserId(userId);
 			one.setLotteryEventQuestionId(lotteryEventQuestions.getId());
 			one.setLotteryEventQuestionsAnswersId(lotteryEventQuestionsAnswers.getId());
 			one.setCreateTime(LocalDateTime.now());
+		}else{
+			one.setLotteryEventQuestionsAnswersId(lotteryEventQuestionsAnswers.getId());
 		}
 		one.setIsCorrect(0);
 		//答案正确
@@ -225,6 +265,8 @@
 			one.setIsCorrect(1);
 		}
 		userLotteryEventQuestionsAnswersService.saveOrUpdate(one);
+		//判断
+
 		return R.ok();
 	}
 	
@@ -236,17 +278,27 @@
 	})
 	public R<Boolean> endAnswerQuestion(@PathVariable("id") String id) {
 		Long userId = SecurityUtils.getUserId();
-		LotteryEvent lotteryEvent = lotteryEventService.getById(id);
-		UserLotteryEventQuestions questionsServiceOne = userLotteryEventQuestionsService.getOne(new QueryWrapper<UserLotteryEventQuestions>().eq("lottery_event_id", id).eq("user_id", userId));
+		TLotteryEvent lotteryEvent = lotteryEventService.getById(id);
+		if(null == lotteryEvent){
+			return R.fail("无效的抽奖活动id");
+		}
+		TUserLotteryEventQuestions questionsServiceOne = userLotteryEventQuestionsService.getOne(new QueryWrapper<TUserLotteryEventQuestions>().eq("lottery_event_id", id).eq("user_id", userId));
+		if (null == questionsServiceOne) {
+			questionsServiceOne = new TUserLotteryEventQuestions();
+			questionsServiceOne.setId(IdUtils.simpleUUID());
+			questionsServiceOne.setUserId(userId);
+			questionsServiceOne.setLotteryEventId(id);
+			questionsServiceOne.setStatus(1);
+			questionsServiceOne.setCreateTime(LocalDateTime.now());
+		}
 		questionsServiceOne.setStatus(2);
 		questionsServiceOne.setEndTime(LocalDateTime.now());
 		//计算正确率
-		List<UserLotteryEventQuestionsAnswers> list = userLotteryEventQuestionsAnswersService.list(new QueryWrapper<UserLotteryEventQuestionsAnswers>().eq("lottery_event_id", id).eq("user_id", userId));
-		int count = list.size();
-		int right = list.stream().filter(item -> 1 == item.getIsCorrect()).collect(Collectors.toList()).size();
+		int count = lotteryEventQuestionsService.count(new QueryWrapper<TLotteryEventQuestions>().eq("lottery_event_id", id));
+		int right = userLotteryEventQuestionsAnswersService.count(new QueryWrapper<TUserLotteryEventQuestionsAnswers>().eq("lottery_event_id", id).eq("user_id", userId).eq("is_correct", 1));
 		BigDecimal multiply = new BigDecimal(right).divide(new BigDecimal(count), 4, BigDecimal.ROUND_HALF_UP).setScale(4, BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal(100));
 		questionsServiceOne.setCorrectAnswerRate(multiply);
-		userLotteryEventQuestionsService.updateById(questionsServiceOne);
+		userLotteryEventQuestionsService.saveOrUpdate(questionsServiceOne);
 		if (multiply.compareTo(lotteryEvent.getAccuracy()) >= 0) {
 			return R.ok(true);
 		}

--
Gitblit v1.7.1