package com.ruoyi.admin.controller; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.ruoyi.admin.entity.MasterWorker; import com.ruoyi.admin.entity.Prize; import com.ruoyi.admin.service.MasterWorkerService; import com.ruoyi.admin.service.PrizeService; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.security.annotation.RequiresPermissions; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; import java.util.Arrays; import java.util.List; import java.util.stream.Collectors; /** *

* 奖品管理 前端控制器 *

* * @author hjl * @since 2024-05-29 */ @RestController @RequestMapping("/prize") @Api(tags = {"后台-系统设置-奖品管理"}) public class PrizeController { @Resource private PrizeService prizeService; @Resource private MasterWorkerService masterWorkerService; /** * 奖品分页列表 * * @param pageNum 页码 * @param pageSize 每页显示条数 */ @RequiresPermissions("prize_list") @ApiOperation(value = "奖品分页查询列表", tags = {"后台-系统设置-奖品管理"}) @GetMapping(value = "/page") @ApiImplicitParams({ @ApiImplicitParam(value = "页码", name = "pageNum", dataType = "Integer", required = true), @ApiImplicitParam(value = "每页条数", name = "pageSize", dataType = "Integer", required = true) }) public R> queryPageList(@RequestParam(name = "pageNum", defaultValue = "1") Integer pageNum, @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) { return R.ok(prizeService.lambdaQuery().eq(Prize::getIsDelete, 0) .orderByDesc(Prize::getCreateTime).page(Page.of(pageNum, pageSize))); } /** * 奖品详情 * * @param id 奖品id */ @RequiresPermissions("prize_detail") @ApiOperation(value = "奖品详情", tags = {"后台-系统设置-奖品管理"}) @GetMapping(value = "/detail") @ApiImplicitParams({ @ApiImplicitParam(value = "奖品id", name = "id", dataType = "Integer", required = true) }) public R detail(@RequestParam Integer id) { return R.ok(prizeService.getById(id)); } /** * 新增奖品 * * @param prize 奖品信息 */ @RequiresPermissions("prize_save") @ApiOperation(value = "新增奖品", tags = {"后台-系统设置-奖品管理"}) @PostMapping(value = "/save") public R save(@RequestBody Prize prize) { return prizeService.save(prize) ? R.ok() : R.fail(); } /** * 编辑奖品 * * @param prize 奖品信息 */ @RequiresPermissions("prize_update") @ApiOperation(value = "编辑奖品", tags = {"后台-系统设置-奖品管理"}) @PostMapping(value = "/update") public R update(@RequestBody Prize prize) { return prizeService.updateById(prize) ? R.ok() : R.fail(); } /** * 根据id批量删除奖品 * * @param ids 奖品id拼接 */ @RequiresPermissions("prize_delete") @ApiOperation(value = "批量删除奖品", tags = {"后台-系统设置-奖品管理"}) @GetMapping(value = "/batchDelete") @ApiImplicitParams({ @ApiImplicitParam(value = "多条奖品id ',' 拼接", name = "ids", dataType = "String", required = true) }) public R batchDelete(@RequestParam String ids) { List idList = Arrays.stream(ids.split(",")).collect(Collectors.toList()); List list = prizeService.lambdaQuery().in(Prize::getId, idList).list(); list.forEach(data -> data.setIsDelete(1)); return prizeService.updateBatchById(list) ? R.ok() : R.fail(); } /** * 奖品列表 -- 远程调用 */ @GetMapping(value = "/prizeList") public R> prizeList() { return R.ok(prizeService.lambdaQuery().eq(Prize::getIsDelete, 0) .orderByDesc(Prize::getCreateTime).list()); } /** * 奖品详情 -- 远程调用 */ @GetMapping(value = "/prizeDetail") public R prizeDetail(@RequestParam("id") String id) { return R.ok(prizeService.lambdaQuery().eq(Prize::getIsDelete, 0) .eq(Prize::getId, id).one()); } }