| | |
| | | import java.math.BigDecimal; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | import com.vincent.rsf.server.manager.enums.WaveRuleType; |
| | | |
| | | /** |
| | | * @author Ryan |
| | |
| | | throw new CoolException("未找到当前策略"); |
| | | } |
| | | List<OrderOutItemDto> locItems = null; |
| | | switch (waveRule.getType()) { |
| | | case 1: |
| | | locItems = efficiencyFirst(param.getOrderId()); |
| | | break; |
| | | if (WaveRuleType.Efficiency_First.type.equals(waveRule.getType())) { |
| | | locItems = efficiencyFirst(param.getOrderId()); |
| | | } else if (WaveRuleType.First_In_First_Out.type.equals(waveRule.getType())) { |
| | | |
| | | } |
| | | return R.ok(locItems); |
| | | } |
| | |
| | | private List<LocItem> getEfficiencyFirstItemList(AsnOrderItem asnOrderItem){ |
| | | QueryWrapper<LocItem> locItemQueryWrapper = new QueryWrapper<>(); |
| | | locItemQueryWrapper.eq("matnr_code", asnOrderItem.getMatnrCode()); |
| | | locItemQueryWrapper.eq("batch", asnOrderItem.getBatch()); |
| | | locItemQueryWrapper.eq("batch", asnOrderItem.getSplrBatch()); |
| | | String applySql = String.format( |
| | | "EXISTS (SELECT 1 FROM man_loc ml " + |
| | | "WHERE ml.use_status = '%s'" + |
| | |
| | | ); |
| | | locItemQueryWrapper.apply(applySql); |
| | | List<LocItem> locItems = locItemService.list(locItemQueryWrapper); |
| | | locItems.sort((s1,s2)->{ |
| | | return LocUtils.isShallowLoc(s1.getLocCode())?1:0; |
| | | }); |
| | | locItems.sort((s1,s2)-> LocUtils.isShallowLoc(s1.getLocCode())?-1:0); |
| | | return locItems; |
| | | } |
| | | |