package org.jeecg.modules.eam.controller; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import cn.hutool.core.util.StrUtil; import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.parser.Feature; import com.fasterxml.jackson.databind.ObjectMapper; import org.apache.commons.lang3.StringUtils; import org.apache.shiro.SecurityUtils; import org.jeecg.common.api.vo.Result; import org.jeecg.common.aspect.annotation.AutoLog; import org.jeecg.common.system.vo.LoginUser; import org.jeecg.common.util.TranslateDictTextUtils; import org.jeecg.modules.eam.constant.BusinessCodeConst; import org.jeecg.modules.eam.dto.EamRepairOrderDto; import org.jeecg.modules.eam.dto.EamRepairOrderExport; import org.jeecg.modules.eam.entity.EamRepairOrder; import org.jeecg.modules.eam.request.EamRepairOrderQuery; import org.jeecg.modules.eam.request.EamRepairOrderRequest; import org.jeecg.modules.eam.request.EamRepairOrderResponse; import org.jeecg.modules.eam.request.EamReportRepairQuery; import org.jeecg.modules.eam.service.IEamRepairOrderService; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import lombok.extern.slf4j.Slf4j; import org.jeecg.common.system.base.controller.JeecgController; import org.jeecg.modules.system.entity.SysUser; import org.jeecg.modules.system.service.ISysUserService; import org.jeecgframework.poi.excel.def.NormalExcelConstants; import org.jeecgframework.poi.excel.entity.ExportParams; import org.jeecgframework.poi.excel.view.JeecgEntityExcelView; import org.springframework.web.bind.annotation.*; import org.springframework.web.servlet.ModelAndView; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import java.util.Date; import java.util.List; /** * @Description: 维修工单 * @Author: Lius * @Date: 2025-04-03 */ @Slf4j @Api(tags = "维修工单") @RestController @RequestMapping("/eam/eamRepairOrder") public class EamRepairOrderController extends JeecgController { @Resource private IEamRepairOrderService eamRepairOrderService; @Resource private ObjectMapper objectMapper; @Resource private TranslateDictTextUtils translateDictTextUtils; @Resource private ISysUserService sysUserService; /** * 分页列表查询 * * @param eamRepairOrderQuery * @param pageNo * @param pageSize * @return */ @ApiOperation(value = "维修工单-分页列表查询", notes = "维修工单-分页列表查询") @GetMapping(value = "/list") public Result queryPageList(EamRepairOrderQuery eamRepairOrderQuery, @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) { Page page = new Page(pageNo, pageSize); IPage pageList = eamRepairOrderService.pageList(page, eamRepairOrderQuery); return Result.OK(pageList); } /** * 领取 * @param id * @return */ @AutoLog(value = "维修工单-领取") @ApiOperation(value = "维修工单-领取", notes = "维修工单-领取") @GetMapping(value = "/claim") public Result claim(String id) { // 校验领取权限 LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal(); if (!BusinessCodeConst.PCR0002.equals(user.getPost())) { return Result.error("领取失败,没有领取权限!,需维修工领取"); } EamRepairOrder eamRepairOrder=eamRepairOrderService.getById(id); if (eamRepairOrder==null) { return Result.error("维修工单不存在"); }else { if ("1".equals(eamRepairOrder.getClaimStatus())) { return Result.error("该维修工单已被领取"); } } eamRepairOrder.setClaimStatus("1"); eamRepairOrder.setActualStartTime(new Date()); eamRepairOrderService.updateById(eamRepairOrder); return Result.OK("领取成功"); } /** * 提交 * @param id * @return */ @AutoLog(value = "维修工单-提交") @ApiOperation(value = "维修工单-提交", notes = "维修工单-提交") @GetMapping(value = "/submit") public Result submit(String id) { // 校验领取权限 LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal(); if (!BusinessCodeConst.PCR0002.equals(user.getPost())) { return Result.error("提交失败,没有提交权限!,需维修工提交"); } eamRepairOrderService.saveRepairOrder(id); return Result.OK("提交成功!"); } /** * 我的待办 执行/审批 * * @param request * @return */ @AutoLog(value = "维修工单-执行/审批") @ApiOperation(value = "维修工单-执行/审批", notes = "维修工单-执行/审批") @PostMapping(value = "/perform") public Result perform(@RequestBody EamRepairOrderRequest request) { if (request == null) { return Result.error("审批的对象不能为空!"); } // 检查请求参数 if (StrUtil.isBlank(request.getTaskId()) || StrUtil.isBlank(request.getDataId()) || StrUtil.isBlank(request.getInstanceId())) { return Result.error("审批任务错误或不存在!"); } EamRepairOrder b = eamRepairOrderService.perform(request); if(b == null) { return Result.error("操作失败!"); } return Result.OK("操作成功!"); } /** * 填报详情 * @param id */ @AutoLog(value = "维修工单-填报详情") @ApiOperation(value = "维修工单-填报详情", notes = "维修工单-填报详情") @GetMapping(value = "/queryByReportId") public Result queryByReportId(@RequestParam(name = "id", required = true) String id) { return Result.ok(eamRepairOrderService.queryByReportId(id)); } /** * 填报维修工单 * @param eamRepairOrderDto */ @ApiOperation(value = "维修工单-填报维修工单", notes = "维修工单-填报维修工单") @PostMapping(value = "/report") public Result report(@RequestBody EamRepairOrderDto eamRepairOrderDto) { // 校验领取权限 LoginUser user = (LoginUser) SecurityUtils.getSubject().getPrincipal(); if (!BusinessCodeConst.PCR0002.equals(user.getPost())) { return Result.error("填报失败,没有填报权限!,需维修工提交"); } if (eamRepairOrderDto == null) { return Result.error("填报的对象不能为空!"); }else { boolean b = eamRepairOrderService.report(eamRepairOrderDto); if(!b) { return Result.error("填报失败,请重试"); }else { return Result.OK("填报成功"); } } } /** * 通过id查询 * * @param id * @return */ @AutoLog(value = "维修工单-通过id查询") @ApiOperation(value = "维修工单-通过id查询", notes = "维修工单-通过id查询") @GetMapping(value = "/queryById") public Result queryById(@RequestParam(name = "id", required = true) String id) { EamRepairOrderResponse eamRepairOrder = eamRepairOrderService.findById(id); if (eamRepairOrder == null) { return Result.error("未找到对应数据!"); } try { String json = objectMapper.writeValueAsString(eamRepairOrder); JSONObject item = JSONObject.parseObject(json, Feature.OrderedField); translateDictTextUtils.translateField("createBy", eamRepairOrder.getCreateBy(), item, "sys_user,realname,username"); translateDictTextUtils.translateField("breakdownFlag", eamRepairOrder.getBreakdownFlag(), item, "breakdown_flag"); translateDictTextUtils.translateField("faultType", eamRepairOrder.getFaultType(), item, "fault_reason_category"); translateDictTextUtils.translateField("reportStatus", eamRepairOrder.getReportStatus(), item, "report_repair_status"); translateDictTextUtils.translateField("equipmentId", eamRepairOrder.getEquipmentId(), item, "eam_equipment,id,equipment_code"); translateDictTextUtils.translateField("repairStatus", eamRepairOrder.getRepairStatus(), item, "report_repair_status"); return Result.OK(item); } catch (Exception e) { return Result.error("数据转译失败!"); } } /** * 导出excel * * @param request * @param eamRepairOrderQuery */ @RequestMapping(value = "/exportXls") public ModelAndView exportXls(HttpServletRequest request, EamRepairOrderQuery eamRepairOrderQuery) { LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal(); List eamRepairOrderExports=eamRepairOrderService.exportList(eamRepairOrderQuery); ModelAndView mv = new ModelAndView(new JeecgEntityExcelView()); mv.addObject(NormalExcelConstants.FILE_NAME, "维修工单台账"); //此处设置的filename无效 ,前端会重更新设置一下 mv.addObject(NormalExcelConstants.CLASS, EamRepairOrderExport.class); mv.addObject(NormalExcelConstants.PARAMS, new ExportParams("维修工单台账" + "报表", "导出人:" + sysUser.getRealname(), "维修工单台账")); mv.addObject(NormalExcelConstants.DATA_LIST, eamRepairOrderExports); return mv; } }