ZarshLocationService.java 4.41 KB
package com.huaheng.pc.sap.service;

import javax.annotation.Resource;

import org.springframework.stereotype.Service;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.huaheng.api.utils.SAPUtils;
import com.huaheng.common.constant.QuantityConstant;
import com.huaheng.framework.web.domain.AjaxResult;
import com.huaheng.framework.web.service.ConfigService;
import com.huaheng.pc.config.location.domain.Location;
import com.huaheng.pc.config.location.service.LocationService;
import com.huaheng.pc.sap.domain.Zarsh;
import com.huaheng.pc.sap.mapper.ZarshMapper;
import com.huaheng.pc.task.taskHeader.domain.TaskHeader;
import com.huaheng.pc.task.taskHeader.service.TaskHeaderService;

/**
 * Created by Enzo Cotter on 2022/5/11.
 * @author zhouhong
 */
@Service
public class ZarshLocationService extends ServiceImpl<ZarshMapper, Zarsh> {
    @Resource
    private ZarsiService zarsiService;
    @Resource
    private TaskHeaderService taskHeaderService;
    @Resource
    private LocationService locationService;
    @Resource
    private ConfigService configService;

    /**
     * 配料仓中间仓查询任务表有几个未分配库位,库位表有无库位,预留2个库位
     * 成品仓有方向标的查询任务表有几个未分配库位,库位表有无库位
     * @param  zarsh
     * @param  area
     * @return
     */
    public AjaxResult checkEmptyLocationCount(Zarsh zarsh, String area) {

        // TODO 校验库位是否足够。
        // TODO 换站任务校验跨站库区的库位数量。
        // P4004通道堵塞 TRUE为堵塞 FALSE为正常
        boolean isBlock = false;
        // SAP入库站台编码
        String fromPos = zarsh.getFromPos();
        // 0 空托 1 有料
        Integer inKind = zarsh.getInKind();
        // 单独判断2E07和2E09这两个站台的空托盘入库
        String zoneCode = SAPUtils.getZoneCode(zarsh);
        if(inKind == 0){
            switch (fromPos) {
                case "2E07":
                case "2E09":
                    LambdaQueryWrapper<TaskHeader> query = Wrappers.lambdaQuery();
                    query.eq(TaskHeader::getTaskType, QuantityConstant.TASK_TYPE_EMPTYRECEIPT)
                            .eq(TaskHeader::getZoneCode, "D")
                            .eq(TaskHeader::getPort, "P4004")
                            .lt(TaskHeader::getStatus, QuantityConstant.TASK_STATUS_COMPLETED);
                    int count = taskHeaderService.count(query);
                    if (count >= 4){
                        isBlock = true;
                        area = "5";
                        zoneCode = "E";
                    }else{
                        area = "4";
                        zoneCode = "D";
                    }
                    break;
                default:
            }
        }
        switch (zoneCode){
            case "DX":
                return AjaxResult.success();
            default:
        }
        LambdaQueryWrapper<TaskHeader> lambdaQuery = Wrappers.lambdaQuery();
        lambdaQuery.eq(TaskHeader::getZoneCode, zoneCode)
                .eq(TaskHeader::getInternalTaskType, QuantityConstant.TASK_INTENERTYPE_RECEIPT)
                .eq(TaskHeader::getToLocation, "")
                .lt(TaskHeader::getStatus, QuantityConstant.TASK_STATUS_COMPLETED);
        // 查询未分配库位的任务数量
        Integer noLocationTaskCount = taskHeaderService.count(lambdaQuery);

        LambdaQueryWrapper<Location> localLambdaQuery = Wrappers.lambdaQuery();
        localLambdaQuery.eq(Location::getZoneCode, zoneCode)
                    .eq(Location::getStatus, QuantityConstant.STATUS_LOCATION_EMPTY)
                    .eq(Location::getContainerCode, "");
        Integer emptyLocationCount = locationService.count(localLambdaQuery);
        // 空闲库位数量减去未分配的任务数量,如果空闲库位数量小于2,任务下发失败。
        if ((emptyLocationCount.intValue() - noLocationTaskCount.intValue()) <= 2) {
            if(isBlock){
                return AjaxResult.error("配料仓空闲库位不够两个并且P4004通道堵塞,请等待通道恢复。");
            }
            return AjaxResult.error(zoneCode.concat("库区排除未分配库位的入库任务,剩余空闲库位小于2个。"));
        }
        return AjaxResult.success();
    }

}