From a8d2cb07f6440dc54dc4005b0b06d5a47cb1517d Mon Sep 17 00:00:00 2001 From: luodangjia <luodangjia> Date: 星期一, 16 十二月 2024 13:34:03 +0800 Subject: [PATCH] 12.16 --- ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/SeckillActivityInfoController.java | 72 ++++++++++++++++++++++++++++++++++- 1 files changed, 69 insertions(+), 3 deletions(-) diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/SeckillActivityInfoController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/SeckillActivityInfoController.java index fa4f8ff..4d6fd43 100644 --- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/SeckillActivityInfoController.java +++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/SeckillActivityInfoController.java @@ -1,8 +1,25 @@ package com.ruoyi.other.controller; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RestController; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.core.web.controller.BaseController; +import com.ruoyi.common.core.web.page.TableDataInfo; +import com.ruoyi.other.api.domain.Goods; +import com.ruoyi.other.api.domain.GoodsSeckill; +import com.ruoyi.other.api.domain.SeckillActivityInfo; +import com.ruoyi.other.api.vo.GetSeckillActivityInfo; +import com.ruoyi.other.service.GoodsSeckillService; +import com.ruoyi.other.service.SeckillActivityInfoService; +import com.ruoyi.other.vo.SeckillActivityDetailVO; +import com.ruoyi.other.vo.SeckillActivityVO; +import io.swagger.annotations.Api; +import io.swagger.annotations.ApiOperation; +import org.springframework.web.bind.annotation.*; + +import javax.annotation.Resource; +import java.time.ZoneOffset; +import java.util.List; /** * <p> @@ -12,9 +29,58 @@ * @author luodangjia * @since 2024-11-20 */ +@Api("秒杀活动信息") @RestController @RequestMapping("/seckill-activity-info") -public class SeckillActivityInfoController { +public class SeckillActivityInfoController extends BaseController { + @Resource + private SeckillActivityInfoService seckillActivityInfoService; + + @Resource + private GoodsSeckillService goodsSeckillService; + + + + + /** + * 秒杀活动列表 + */ + @GetMapping("/list") + @ApiOperation(value = "秒杀活动列表",tags = {"小程序-商城-首页"}) + public R<TableDataInfo> list(Goods goods) + { + startPage(); + return R.ok(getDataTable(seckillActivityInfoService.listSeckillActivity(goods))); + } + + /** + * 秒杀活动详情 + */ + @GetMapping("/detail/{id}") + @ApiOperation(value = "秒杀活动详情", tags = {"小程序-商城-首页"}) + public R<SeckillActivityDetailVO> detail(@PathVariable("id") Integer id) + { + return R.ok(seckillActivityInfoService.detail(id)); + } + + + /** + * 根据商品id和会员等级获取对应的秒杀活动 + */ + @PostMapping("/getSeckillActivityInfo") + public R<GoodsSeckill> getSeckillActivityInfo(@RequestBody GetSeckillActivityInfo info){ + SeckillActivityInfo one = seckillActivityInfoService.getOne(new LambdaQueryWrapper<SeckillActivityInfo>().eq(SeckillActivityInfo::getGoodId, info.getGoodsId()) + .eq(SeckillActivityInfo::getDelFlag, 0).last(" and now() between start_time and end_time order by create_time limit 0,1")); + if(null == one){ + return R.ok(); + } + GoodsSeckill goodsSeckill = goodsSeckillService.getOne(new LambdaQueryWrapper<GoodsSeckill>().eq(GoodsSeckill::getSeckillActivityInfoId, one.getGoodId()).eq(GoodsSeckill::getVip, info.getVip())); + if(null != goodsSeckill){ + goodsSeckill.setEndTime(one.getEndTime().toEpochSecond(ZoneOffset.UTC) * 1000); + } + return R.ok(goodsSeckill); + } + } -- Gitblit v1.7.1