Compare commits
	
		
			2 Commits
		
	
	
		
			fc918ff41c
			...
			f4b57db744
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | f4b57db744 | ||
|   | 51fad285f6 | 
| @ -16,4 +16,6 @@ public class RepairConstants { | |||||||
| 
 | 
 | ||||||
|     public static final String REPAIR_STAFF = "维修工"; |     public static final String REPAIR_STAFF = "维修工"; | ||||||
| 
 | 
 | ||||||
|  |     public static final String REPAIR_WAREHOUSE = "维修仓库管理员"; | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -87,5 +87,33 @@ public class DlTicketWaresController { | |||||||
|         dlTicketWaresService.auditTicketWares(respVO); |         dlTicketWaresService.auditTicketWares(respVO); | ||||||
|         return CommonResult.ok(); |         return CommonResult.ok(); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 仓库通知领料 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 20:45 2024/10/16 | ||||||
|  |      * @param respVO 请求对象 | ||||||
|  |     **/ | ||||||
|  |     @PostMapping("/pass") | ||||||
|  |     @Operation(summary = "仓库通知领料") | ||||||
|  |     public CommonResult<?> passTicketWares(@RequestBody DlTicketWaresRespVO respVO){ | ||||||
|  |         dlTicketWaresService.passTicketWares(respVO); | ||||||
|  |         return CommonResult.ok(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 员工确认领料 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 22:07 2024/10/16 | ||||||
|  |      * @param respVO 请求对象 | ||||||
|  |     **/ | ||||||
|  |     @PostMapping("/repairPass") | ||||||
|  |     @Operation(summary = "员工确认领料") | ||||||
|  |     public CommonResult<?> repairPassTicketWares(@RequestBody DlTicketWaresRespVO respVO){ | ||||||
|  |         dlTicketWaresService.repairPassTicketWares(respVO); | ||||||
|  |         return CommonResult.ok(); | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -50,4 +50,22 @@ public interface DlTicketWaresService extends IService<DlTicketWares> { | |||||||
|      * @param respVO 请求对象 |      * @param respVO 请求对象 | ||||||
|      **/ |      **/ | ||||||
|     void auditTicketWares(DlTicketWaresRespVO respVO); |     void auditTicketWares(DlTicketWaresRespVO respVO); | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 仓库通知领料 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 20:45 2024/10/16 | ||||||
|  |      * @param respVO 请求对象 | ||||||
|  |      **/ | ||||||
|  |     void passTicketWares(DlTicketWaresRespVO respVO); | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 员工确认领料 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 22:07 2024/10/16 | ||||||
|  |      * @param respVO 请求对象 | ||||||
|  |      **/ | ||||||
|  |     void repairPassTicketWares(DlTicketWaresRespVO respVO); | ||||||
| } | } | ||||||
|  | |||||||
| @ -452,6 +452,10 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe | |||||||
|         if (names.contains(RepairConstants.REPAIR_STAFF)){ |         if (names.contains(RepairConstants.REPAIR_STAFF)){ | ||||||
|             return 4; |             return 4; | ||||||
|         } |         } | ||||||
|  |         // 维修仓库管理员 | ||||||
|  |         if(names.contains(RepairConstants.REPAIR_WAREHOUSE)){ | ||||||
|  |             return 5; | ||||||
|  |         } | ||||||
|         // 啥也不是 |         // 啥也不是 | ||||||
|         return -1; |         return -1; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -7,6 +7,9 @@ import cn.iocoder.yudao.module.base.entity.RepairWorker; | |||||||
| import cn.iocoder.yudao.module.base.service.RepairWorkerService; | import cn.iocoder.yudao.module.base.service.RepairWorkerService; | ||||||
| import cn.iocoder.yudao.module.project.entity.RepairWares; | import cn.iocoder.yudao.module.project.entity.RepairWares; | ||||||
| import cn.iocoder.yudao.module.project.service.RepairWaresService; | import cn.iocoder.yudao.module.project.service.RepairWaresService; | ||||||
|  | import cn.iocoder.yudao.module.stockOperate.entity.DlRepairSoi; | ||||||
|  | import cn.iocoder.yudao.module.stockOperate.service.DlRepairSoService; | ||||||
|  | import cn.iocoder.yudao.module.stockOperate.service.DlRepairSoiService; | ||||||
| import cn.iocoder.yudao.module.tickets.entity.DlRepairTickets; | import cn.iocoder.yudao.module.tickets.entity.DlRepairTickets; | ||||||
| import cn.iocoder.yudao.module.tickets.entity.DlRepairTitem; | import cn.iocoder.yudao.module.tickets.entity.DlRepairTitem; | ||||||
| import cn.iocoder.yudao.module.tickets.entity.DlTicketWares; | import cn.iocoder.yudao.module.tickets.entity.DlTicketWares; | ||||||
| @ -61,6 +64,14 @@ public class DlTicketWaresServiceImpl extends ServiceImpl<DlTicketWaresMapper, D | |||||||
|     @Lazy |     @Lazy | ||||||
|     private DlRepairTitemService repairTitemService; |     private DlRepairTitemService repairTitemService; | ||||||
| 
 | 
 | ||||||
|  |     @Resource | ||||||
|  |     @Lazy | ||||||
|  |     private DlRepairSoService repairSoService; | ||||||
|  | 
 | ||||||
|  |     @Resource | ||||||
|  |     @Lazy | ||||||
|  |     private DlRepairSoiService repairSoiService; | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * 分页查询 |      * 分页查询 | ||||||
|      * |      * | ||||||
| @ -95,6 +106,11 @@ public class DlTicketWaresServiceImpl extends ServiceImpl<DlTicketWaresMapper, D | |||||||
|             case 4: |             case 4: | ||||||
|                 reqVO.setUserIds(Collections.singletonList(SecurityFrameworkUtils.getLoginUserId())); |                 reqVO.setUserIds(Collections.singletonList(SecurityFrameworkUtils.getLoginUserId())); | ||||||
|                 break; |                 break; | ||||||
|  |             // 维修仓库管理员 | ||||||
|  |             case 5: | ||||||
|  |                 reqVO.setStatus(null); | ||||||
|  |                 reqVO.setUserRole(5); | ||||||
|  |                 break; | ||||||
|         } |         } | ||||||
|         return baseMapper.getPage(reqVO, page); |         return baseMapper.getPage(reqVO, page); | ||||||
|     } |     } | ||||||
| @ -186,6 +202,60 @@ public class DlTicketWaresServiceImpl extends ServiceImpl<DlTicketWaresMapper, D | |||||||
|             repairTitemService.saveBatch(respVO.getWares()); |             repairTitemService.saveBatch(respVO.getWares()); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 仓库通知领料 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 20:45 2024/10/16 | ||||||
|  |      * @param respVO 请求对象 | ||||||
|  |      **/ | ||||||
|  |     @Override | ||||||
|  |     @DSTransactional | ||||||
|  |     public void passTicketWares(DlTicketWaresRespVO respVO){ | ||||||
|  |         // 查工单子表中的配件信息 | ||||||
|  |         List<DlRepairTitem> list = repairTitemService.list(new LambdaQueryWrapper<DlRepairTitem>() | ||||||
|  |                 .eq(DlRepairTitem::getTicketId, respVO.getTicketId()) | ||||||
|  |                 .in(DlRepairTitem::getPartId, respVO.getRepairSois() | ||||||
|  |                         .stream() | ||||||
|  |                         .map(DlRepairSoi::getGoodsId) | ||||||
|  |                         .collect(Collectors.toList()))); | ||||||
|  |         // 计算总价 | ||||||
|  |         BigDecimal reduce = list.stream().map(DlRepairTitem::getItemMoney).reduce(BigDecimal.ZERO, BigDecimal::add); | ||||||
|  |         respVO.getRepairSo().setItemCount(list.size()); | ||||||
|  |         respVO.getRepairSo().setTotalPrice(reduce); | ||||||
|  |         // 生成领料单 | ||||||
|  |         repairSoService.save(respVO.getRepairSo()); | ||||||
|  |         // 生成领料单子表 | ||||||
|  |         respVO.getRepairSois().forEach(item -> { | ||||||
|  |             item.setSoId(respVO.getRepairSo().getId()); | ||||||
|  |             DlRepairTitem titem = list.stream().filter(i -> i.getPartId().equals(item.getGoodsId())).collect(Collectors.toList()).get(0); | ||||||
|  |             item.setGoodsPrice(titem.getItemPrice()); | ||||||
|  |         }); | ||||||
|  |         repairSoiService.saveBatch(respVO.getRepairSois()); | ||||||
|  |         // 更新领料申请子表 | ||||||
|  |         twItemService.updateBatchById(respVO.getItems()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 员工确认领料 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 22:07 2024/10/16 | ||||||
|  |      * @param respVO 请求对象 | ||||||
|  |      **/ | ||||||
|  |     @Override | ||||||
|  |     @DSTransactional | ||||||
|  |     public void repairPassTicketWares(DlTicketWaresRespVO respVO){ | ||||||
|  |         // 更新领料申请子表 | ||||||
|  |         twItemService.updateBatchById(respVO.getItems()); | ||||||
|  |         // 更新领料申请表 | ||||||
|  |         // 判断是全部完成完成部分完成 | ||||||
|  |         List<DlTwItem> list = twItemService.list(new LambdaQueryWrapper<DlTwItem>().eq(DlTwItem::getTwId, respVO.getId())); | ||||||
|  |         List<DlTwItem> list1 = list.stream().filter(item -> item.getWaresStatus().equals("01")).collect(Collectors.toList()); | ||||||
|  |         respVO.setStatus(list1.size() == list.size() ? "03" : "04"); | ||||||
|  |         baseMapper.updateById(respVO); | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -19,4 +19,7 @@ public class DlTicketWaresReqVO extends DlTicketWares { | |||||||
| 
 | 
 | ||||||
|     /** 查询的时候用,班组长和维修工 */ |     /** 查询的时候用,班组长和维修工 */ | ||||||
|     private List<Long> userIds; |     private List<Long> userIds; | ||||||
|  | 
 | ||||||
|  |     /** 角色 */ | ||||||
|  |     private Integer userRole; | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,5 +1,7 @@ | |||||||
| package cn.iocoder.yudao.module.tickets.vo; | package cn.iocoder.yudao.module.tickets.vo; | ||||||
| 
 | 
 | ||||||
|  | import cn.iocoder.yudao.module.stockOperate.entity.DlRepairSo; | ||||||
|  | import cn.iocoder.yudao.module.stockOperate.entity.DlRepairSoi; | ||||||
| import cn.iocoder.yudao.module.tickets.entity.DlRepairTitem; | import cn.iocoder.yudao.module.tickets.entity.DlRepairTitem; | ||||||
| import cn.iocoder.yudao.module.tickets.entity.DlTicketWares; | import cn.iocoder.yudao.module.tickets.entity.DlTicketWares; | ||||||
| import cn.iocoder.yudao.module.tickets.entity.DlTwItem; | import cn.iocoder.yudao.module.tickets.entity.DlTwItem; | ||||||
| @ -21,4 +23,10 @@ public class DlTicketWaresRespVO extends DlTicketWares { | |||||||
| 
 | 
 | ||||||
|     /** 工单子表需要的记录 */ |     /** 工单子表需要的记录 */ | ||||||
|     private List<DlRepairTitem> wares; |     private List<DlRepairTitem> wares; | ||||||
|  | 
 | ||||||
|  |     /** 领料、采购单 */ | ||||||
|  |     private DlRepairSo repairSo; | ||||||
|  | 
 | ||||||
|  |     /** 领料、采购单子表 */ | ||||||
|  |     private List<DlRepairSoi> repairSois; | ||||||
| } | } | ||||||
|  | |||||||
| @ -56,6 +56,15 @@ | |||||||
|                 </foreach> |                 </foreach> | ||||||
|             ) |             ) | ||||||
|         </if> |         </if> | ||||||
|  |         <if test="map.userRole != null"> | ||||||
|  |             and ( | ||||||
|  |                 <choose> | ||||||
|  |                     <when test="map.userRole == 5"> | ||||||
|  |                         dtw.status not in ('01', '05', '03') | ||||||
|  |                     </when> | ||||||
|  |                 </choose> | ||||||
|  |             ) | ||||||
|  |         </if> | ||||||
|         <if test="map.adviserId != null and map.adviserId != ''"> |         <if test="map.adviserId != null and map.adviserId != ''"> | ||||||
|             and (dtw.adviser_id = #{map.adviserId}) |             and (dtw.adviser_id = #{map.adviserId}) | ||||||
|         </if> |         </if> | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user