package com.pz.web.controller.system; import java.util.List; import java.util.Arrays; import lombok.RequiredArgsConstructor; import javax.servlet.http.HttpServletResponse; import javax.validation.constraints.*; import cn.dev33.satoken.annotation.SaCheckPermission; import org.springframework.web.bind.annotation.*; import org.springframework.validation.annotation.Validated; import com.pz.common.annotation.RepeatSubmit; import com.pz.common.annotation.Log; import com.pz.common.core.controller.BaseController; import com.pz.common.core.domain.PageQuery; import com.pz.common.core.domain.R; import com.pz.common.core.validate.AddGroup; import com.pz.common.core.validate.EditGroup; import com.pz.common.enums.BusinessType; import com.pz.common.utils.poi.ExcelUtil; import com.pz.system.domain.vo.DepartmentVo; import com.pz.system.domain.bo.DepartmentBo; import com.pz.system.service.IDepartmentService; import com.pz.common.core.page.TableDataInfo; /** * 科室 * * @author ruoyi * @date 2023-09-07 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/system/department") public class DepartmentController extends BaseController { private final IDepartmentService iDepartmentService; /** * 查询科室列表 */ @SaCheckPermission("system:department:list") @GetMapping("/list") public R<List<DepartmentVo>> list(DepartmentBo bo) { return R.ok(iDepartmentService.queryPageList(bo)); } /** * 导出科室列表 */ @SaCheckPermission("system:department:export") @Log(title = "科室", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(DepartmentBo bo, HttpServletResponse response) { List<DepartmentVo> list = iDepartmentService.queryList(bo); ExcelUtil.exportExcel(list, "科室", DepartmentVo.class, response); } /** * 获取科室详细信息 * * @param id 主键 */ @SaCheckPermission("system:department:query") @GetMapping("/{id}") public R<DepartmentVo> getInfo(@NotNull(message = "主键不能为空") @PathVariable Integer id) { return R.ok(iDepartmentService.queryById(id)); } /** * 新增科室 */ @SaCheckPermission("system:department:add") @Log(title = "科室", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping() public R<Void> add(@Validated(AddGroup.class) @RequestBody DepartmentBo bo) { return toAjax(iDepartmentService.insertByBo(bo)); } /** * 修改科室 */ @SaCheckPermission("system:department:edit") @Log(title = "科室", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R<Void> edit(@Validated(EditGroup.class) @RequestBody DepartmentBo bo) { return toAjax(iDepartmentService.updateByBo(bo)); } /** * 删除科室 * * @param ids 主键串 */ @SaCheckPermission("system:department:remove") @Log(title = "科室", businessType = BusinessType.DELETE) @DeleteMapping("/{ids}") public R<Void> remove(@NotEmpty(message = "主键不能为空") @PathVariable Integer[] ids) { return toAjax(iDepartmentService.deleteWithValidByIds(Arrays.asList(ids), true)); } }