package com.inspur.source.controller; import cn.dev33.satoken.annotation.SaCheckPermission; import com.inspur.source.domain.bo.SmsbItemProgramBo; import com.inspur.source.domain.vo.SmsbItemProgramVo; import com.inspur.source.service.ISmsbItemProgramService; import jakarta.servlet.http.HttpServletResponse; import jakarta.validation.constraints.NotEmpty; import jakarta.validation.constraints.NotNull; import lombok.RequiredArgsConstructor; import org.dromara.common.core.domain.R; import org.dromara.common.core.validate.AddGroup; import org.dromara.common.core.validate.EditGroup; import org.dromara.common.excel.utils.ExcelUtil; import org.dromara.common.idempotent.annotation.RepeatSubmit; import org.dromara.common.log.annotation.Log; import org.dromara.common.log.enums.BusinessType; import org.dromara.common.mybatis.core.page.PageQuery; import org.dromara.common.mybatis.core.page.TableDataInfo; import org.dromara.common.web.core.BaseController; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; import java.util.List; /** * 节目信息 * * @author Lion Li * @date 2025-05-13 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/system/itemProgram") public class SmsbItemProgramController extends BaseController { private final ISmsbItemProgramService smsbItemProgramService; /** * 查询节目信息列表 */ @SaCheckPermission("system:itemProgram:list") @GetMapping("/list") public TableDataInfo list(SmsbItemProgramBo bo, PageQuery pageQuery) { return smsbItemProgramService.queryPageList(bo, pageQuery); } /** * 导出节目信息列表 */ @SaCheckPermission("system:itemProgram:export") @Log(title = "节目信息", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(SmsbItemProgramBo bo, HttpServletResponse response) { List list = smsbItemProgramService.queryList(bo); ExcelUtil.exportExcel(list, "节目信息", SmsbItemProgramVo.class, response); } /** * 获取节目信息详细信息 * * @param id 主键 */ @SaCheckPermission("system:itemProgram:query") @GetMapping("/{id}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable Long id) { return R.ok(smsbItemProgramService.queryById(id)); } /** * 新增节目信息 */ @SaCheckPermission("system:itemProgram:add") @Log(title = "节目信息", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R add(@Validated(AddGroup.class) @RequestBody SmsbItemProgramBo bo) { return toAjax(smsbItemProgramService.insertByBo(bo)); } /** * 修改节目信息 */ @SaCheckPermission("system:itemProgram:edit") @Log(title = "节目信息", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody SmsbItemProgramBo bo) { return toAjax(smsbItemProgramService.updateByBo(bo)); } /** * 修改节目名称 */ @SaCheckPermission("system:itemProgram:edit") @Log(title = "节目信息", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping("/editName") public R editName(@Validated(EditGroup.class) @RequestParam Long id, @RequestParam String name) { return toAjax(smsbItemProgramService.updateNameById(id, name)); } /** * 删除节目信息 * * @param ids 主键串 */ @SaCheckPermission("system:itemProgram:remove") @Log(title = "节目信息", businessType = BusinessType.DELETE) @DeleteMapping("/{ids}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable Long[] ids) { return toAjax(smsbItemProgramService.deleteWithValidByIds(List.of(ids), true)); } }