|  |  |  | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.enums.WaveRuleType; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.service.*; | 
|---|
|  |  |  | import com.vincent.rsf.server.manager.enums.LocStsType; | 
|---|
|  |  |  | import org.apache.commons.lang3.StringUtils; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.swing.*; | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | 
|---|
|  |  |  | public static String getTargetLoc(Long areaId) { | 
|---|
|  |  |  | //TODO 库位策略后续排期 | 
|---|
|  |  |  | LocService locService = SpringUtils.getBean(LocService.class); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>() | 
|---|
|  |  |  | .eq(Loc::getAreaId, areaId) | 
|---|
|  |  |  | .orderByAsc(Loc::getLev) | 
|---|
|  |  |  | 
|---|
|  |  |  | public static List<LocItem> getEfficiencyFirstItemList(String matnrCode, String splrBatch, Double anfme) { | 
|---|
|  |  |  | LambdaQueryWrapper<LocItem> locItemQueryWrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | locItemQueryWrapper.eq(LocItem::getMatnrCode, matnrCode); | 
|---|
|  |  |  | locItemQueryWrapper.eq(LocItem::getBatch, splrBatch); | 
|---|
|  |  |  | locItemQueryWrapper.eq(StringUtils.isNotBlank(splrBatch), LocItem::getBatch, splrBatch); | 
|---|
|  |  |  | String applySql = String.format( | 
|---|
|  |  |  | "EXISTS (SELECT 1 FROM man_loc ml " + | 
|---|
|  |  |  | "WHERE ml.use_status = '%s'" + | 
|---|
|  |  |  | 
|---|
|  |  |  | public static List<LocItem> getFirstInFirstOutItemList(String matnrCode, String splrBatch, Double anfme) { | 
|---|
|  |  |  | LambdaQueryWrapper<LocItem> locItemQueryWrapper = new LambdaQueryWrapper<>(); | 
|---|
|  |  |  | locItemQueryWrapper.eq(LocItem::getMatnrCode, matnrCode); | 
|---|
|  |  |  | locItemQueryWrapper.eq(LocItem::getBatch, splrBatch); | 
|---|
|  |  |  | locItemQueryWrapper.eq(StringUtils.isNotEmpty(splrBatch), LocItem::getBatch, splrBatch); | 
|---|
|  |  |  | locItemQueryWrapper.orderByAsc(LocItem::getCreateTime); | 
|---|
|  |  |  | String applySql = String.format( | 
|---|
|  |  |  | "EXISTS (SELECT 1 FROM man_loc ml " + | 
|---|
|  |  |  | 
|---|
|  |  |  | orderOutItemDto.setLocItem(locItem); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<DeviceSite> deviceSites = deviceSiteService.list(new LambdaQueryWrapper<DeviceSite>() | 
|---|
|  |  |  | .eq(DeviceSite::getChannel, loc.getChannel()) | 
|---|
|  |  |  | .eq(!Objects.isNull(loc.getChannel()), DeviceSite::getChannel, loc.getChannel()) | 
|---|
|  |  |  | .eq(DeviceSite::getType, issued.doubleValue() >= locItem.getAnfme() && itemList.size() == 1 ? TaskType.TASK_TYPE_OUT.type : TaskType.TASK_TYPE_PICK_AGAIN_OUT.type) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | orderOutItemDto.setSiteNo(deviceSite.getSite()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | orderOutItemDto.setSource(item.getItemId()).setSourceId(item.getWaveId()); | 
|---|
|  |  |  | orderOutItemDto.setSource(item.getItemId()) | 
|---|
|  |  |  | .setSourceId(item.getWaveId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | list.add(orderOutItemDto); | 
|---|
|  |  |  |  | 
|---|