package org.dromara.eims.controller; import java.util.List; import lombok.RequiredArgsConstructor; import jakarta.servlet.http.HttpServletResponse; import jakarta.validation.constraints.*; import cn.dev33.satoken.annotation.SaCheckPermission; import org.springframework.web.bind.annotation.*; import org.springframework.validation.annotation.Validated; import org.dromara.common.idempotent.annotation.RepeatSubmit; import org.dromara.common.log.annotation.Log; import org.dromara.common.web.core.BaseController; import org.dromara.common.mybatis.core.page.PageQuery; 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.log.enums.BusinessType; import org.dromara.common.excel.utils.ExcelUtil; import org.dromara.eims.domain.vo.EimsRepairResVo; import org.dromara.eims.domain.bo.EimsRepairResBo; import org.dromara.eims.service.IEimsRepairResService; import org.dromara.common.mybatis.core.page.TableDataInfo; /** * 维修工单 * * @author zhuguifei * @date 2025-02-25 */ @Validated @RequiredArgsConstructor @RestController @RequestMapping("/eims/repairRes") public class EimsRepairResController extends BaseController { private final IEimsRepairResService eimsRepairResService; /** * 查询维修工单列表 */ @SaCheckPermission("eims:repairRes:list") @GetMapping("/list") public TableDataInfo list(EimsRepairResBo bo, PageQuery pageQuery) { //return eimsRepairResService.queryPageList(bo, pageQuery); return eimsRepairResService.queryPageListCustom(bo, pageQuery); } /** * 查询未完成的维修工单数量 * */ @SaCheckPermission("eims:repairRes:list") @GetMapping("/list/unfinished") public R listUnfinished(String status) { Integer num = eimsRepairResService.listUnfinished(status); return R.ok("操作成功", num); } /** * 导出维修工单列表 */ @SaCheckPermission("eims:repairRes:export") @Log(title = "维修工单", businessType = BusinessType.EXPORT) @PostMapping("/export") public void export(EimsRepairResBo bo, HttpServletResponse response) { List list = eimsRepairResService.queryList(bo); ExcelUtil.exportExcel(list, "维修工单", EimsRepairResVo.class, response); } /** * 获取维修工单详细信息 * * @param id 主键 */ @SaCheckPermission("eims:repairRes:query") @GetMapping("/{id}") public R getInfo(@NotNull(message = "主键不能为空") @PathVariable Long id) { return R.ok(eimsRepairResService.queryById(id)); } /** * 新增维修工单 */ @SaCheckPermission("eims:repairRes:add") @Log(title = "维修工单", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping("add") public R add(@Validated(AddGroup.class) @RequestBody EimsRepairResBo bo) { return toAjax(eimsRepairResService.insertByBo(bo)); } @SaCheckPermission("eims:repairRes:add") @Log(title = "维修工单-批量", businessType = BusinessType.INSERT) @RepeatSubmit() @PostMapping("addBatch") public R addBatch(@RequestBody EimsRepairResBo bo) { return toAjax(eimsRepairResService.insertBatchByBo(bo)); } /** * 修改维修工单 */ @SaCheckPermission("eims:repairRes:edit") @Log(title = "维修工单", businessType = BusinessType.UPDATE) @RepeatSubmit() @PutMapping() public R edit(@Validated(EditGroup.class) @RequestBody EimsRepairResBo bo) { return toAjax(eimsRepairResService.updateByBo(bo)); } /** * 删除维修工单 * * @param ids 主键串 */ @SaCheckPermission("eims:repairRes:remove") @Log(title = "维修工单", businessType = BusinessType.DELETE) @DeleteMapping("/{ids}") public R remove(@NotEmpty(message = "主键不能为空") @PathVariable Long[] ids) { return toAjax(eimsRepairResService.deleteWithValidByIds(List.of(ids), true)); } }