|
@@ -2,6 +2,13 @@ package cn.iocoder.yudao.module.promotion.controller.app.activity;
|
|
|
|
|
|
import cn.iocoder.yudao.framework.common.pojo.CommonResult;
|
|
|
import cn.iocoder.yudao.module.promotion.controller.app.activity.vo.AppActivityRespVO;
|
|
|
+import cn.iocoder.yudao.module.promotion.dal.dataobject.bargain.BargainActivityDO;
|
|
|
+import cn.iocoder.yudao.module.promotion.dal.dataobject.combination.CombinationActivityDO;
|
|
|
+import cn.iocoder.yudao.module.promotion.dal.dataobject.seckill.SeckillActivityDO;
|
|
|
+import cn.iocoder.yudao.module.promotion.enums.common.PromotionTypeEnum;
|
|
|
+import cn.iocoder.yudao.module.promotion.service.bargain.BargainActivityService;
|
|
|
+import cn.iocoder.yudao.module.promotion.service.combination.CombinationActivityService;
|
|
|
+import cn.iocoder.yudao.module.promotion.service.seckill.SeckillActivityService;
|
|
|
import io.swagger.v3.oas.annotations.Operation;
|
|
|
import io.swagger.v3.oas.annotations.Parameter;
|
|
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
@@ -11,6 +18,7 @@ import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
import org.springframework.web.bind.annotation.RequestParam;
|
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
|
|
+import javax.annotation.Resource;
|
|
|
import java.time.LocalDateTime;
|
|
|
import java.util.*;
|
|
|
|
|
@@ -22,24 +30,46 @@ import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
|
|
@Validated
|
|
|
public class AppActivityController {
|
|
|
|
|
|
- // TODO @puhui999:可以实现下
|
|
|
+ @Resource
|
|
|
+ private CombinationActivityService combinationActivityService;
|
|
|
+ @Resource
|
|
|
+ private SeckillActivityService seckillActivityService;
|
|
|
+ @Resource
|
|
|
+ private BargainActivityService bargainActivityService;
|
|
|
+
|
|
|
@GetMapping("/list-by-spu-id")
|
|
|
@Operation(summary = "获得单个商品,近期参与的每个活动") // 每种活动,只返回一个
|
|
|
@Parameter(name = "spuId", description = "商品编号", required = true)
|
|
|
public CommonResult<List<AppActivityRespVO>> getActivityListBySpuId(@RequestParam("spuId") Long spuId) {
|
|
|
- // TODO 芋艿,实现
|
|
|
- List<AppActivityRespVO> randomList = new ArrayList<>();
|
|
|
- Random random = new Random();
|
|
|
- for (int i = 0; i < 3; i++) { // 生成5个随机对象
|
|
|
- AppActivityRespVO vo = new AppActivityRespVO();
|
|
|
- vo.setId(random.nextLong()); // 随机生成一个长整型 ID
|
|
|
- vo.setType(i + 1); // 随机生成一个介于0到2之间的整数,对应枚举类型的三种类型之一
|
|
|
- vo.setName(String.format("活动%d", random.nextInt(100))); // 随机生成一个类似于“活动XX”的活动名称,XX为0到99之间的随机整数
|
|
|
- vo.setStartTime(LocalDateTime.now()); // 随机生成一个在过去的一年内的开始时间(以毫秒为单位)
|
|
|
- vo.setEndTime(LocalDateTime.now()); // 随机生成一个在未来的一年内的结束时间(以毫秒为单位)
|
|
|
- randomList.add(vo);
|
|
|
+ List<AppActivityRespVO> respList = new ArrayList<>();
|
|
|
+ CombinationActivityDO combination = combinationActivityService.getCombinationActivityBySpuId(spuId);
|
|
|
+ if (combination != null) {
|
|
|
+ respList.add(new AppActivityRespVO()
|
|
|
+ .setId(combination.getId())
|
|
|
+ .setType(PromotionTypeEnum.COMBINATION_ACTIVITY.getType())
|
|
|
+ .setName(combination.getName())
|
|
|
+ .setStartTime(combination.getStartTime())
|
|
|
+ .setEndTime(combination.getEndTime()));
|
|
|
+ }
|
|
|
+ SeckillActivityDO seckill = seckillActivityService.getSeckillActivityBySpuId(spuId);
|
|
|
+ if (seckill != null) {
|
|
|
+ respList.add(new AppActivityRespVO()
|
|
|
+ .setId(seckill.getId())
|
|
|
+ .setType(PromotionTypeEnum.SECKILL_ACTIVITY.getType())
|
|
|
+ .setName(seckill.getName())
|
|
|
+ .setStartTime(seckill.getStartTime())
|
|
|
+ .setEndTime(seckill.getEndTime()));
|
|
|
+ }
|
|
|
+ BargainActivityDO bargain = bargainActivityService.getBargainActivityBySpuId(spuId);
|
|
|
+ if (bargain != null) {
|
|
|
+ respList.add(new AppActivityRespVO()
|
|
|
+ .setId(bargain.getId())
|
|
|
+ .setType(PromotionTypeEnum.BARGAIN_ACTIVITY.getType())
|
|
|
+ .setName(bargain.getName())
|
|
|
+ .setStartTime(bargain.getStartTime())
|
|
|
+ .setEndTime(bargain.getEndTime()));
|
|
|
}
|
|
|
- return success(randomList);
|
|
|
+ return success(respList);
|
|
|
}
|
|
|
|
|
|
// TODO @puhui999:可以实现下
|