Merge branch 'uat-temp-wj-chongqingdaqu-prod-temp-control-order-qty' into uat-temp-wj-chongqingdaqu-prod-temp-merge-chengdu

uat-temp-wj-chongqingdaqu-prod-temp-merge-all
王杰 3 months ago
commit b92a3052ec

@ -35,6 +35,9 @@ public interface IMesProdShiftRecordService {
@ApiOperation(value = "查询最新的开班记录") @ApiOperation(value = "查询最新的开班记录")
MesProdShiftRecord getProdShiftRecordOpenStatus(String organizeCode, String workCenterCode); MesProdShiftRecord getProdShiftRecordOpenStatus(String organizeCode, String workCenterCode);
@ApiOperation(value = "查询最新的开班记录")
MesProdShiftRecord getProdShiftRecordCdtDesc(String organizeCode, String workCenterCode);
@ApiOperation(value = "封装展示组件班组班次内容") @ApiOperation(value = "封装展示组件班组班次内容")
List<StationKvBean> getProdShiftData(MesProdShiftRecord record); List<StationKvBean> getProdShiftData(MesProdShiftRecord record);

@ -27,4 +27,13 @@ public interface IMesShiftService {
@ApiOperation(value = "获取当前班次时间日期") @ApiOperation(value = "获取当前班次时间日期")
Map<String,String> getShiftTimeMap(MesProdShiftRecord record); Map<String,String> getShiftTimeMap(MesProdShiftRecord record);
@ApiOperation(value = "根据当前时间计算实际整天班次的时间")
Map<String, String> calcAllDayShiftTimeMapByCurTime(String organizeCode, String workCenterCode);
@ApiOperation(value = "根据当前时间计算当前班次的时间")
Map<String, String> calcCurShiftTimeMapByCurTime(String organizeCode, String workCenterCode);
@ApiOperation(value = "计算天数")
String calcDay(String day, int amount);
} }

@ -55,18 +55,6 @@ public interface IMesProductionDispatchContextStepService {
@ApiOperation(value = "删除上下文发送允许加工指令执行结果") @ApiOperation(value = "删除上下文发送允许加工指令执行结果")
void removeSendProcessCmdContext(StationRequestBean reqBean); void removeSendProcessCmdContext(StationRequestBean reqBean);
@ApiOperation(value = "获取上下文产出零件号")
List<MesEquipVariableCollectContext> getProductionPartNoContext(StationRequestBean reqBean);
@ApiOperation(value = "验证上下文产出零件号是否存在")
Boolean checkProductionPartNoIsExistContext(StationRequestBean reqBean);
@ApiOperation(value = "保存上下文产出零件号", notes = "[JSON]List<MesEquipVariableCollectContext>")
Boolean dispatchProductionPartNoContext(StationRequestBean reqBean, List<MesEquipVariableCollectContext> productionPartNoList);
@ApiOperation(value = "删除上下文产出零件号")
void removeProductionPartNoContext(StationRequestBean reqBean);
@ApiOperation(value = "获取上下文头道模具号") @ApiOperation(value = "获取上下文头道模具号")
MesEquipVariableCollectContext getFirstMouldNoContext(StationRequestBean reqBean); MesEquipVariableCollectContext getFirstMouldNoContext(StationRequestBean reqBean);

@ -6,6 +6,7 @@ import cn.estsh.i3plus.pojo.mes.bean.MesWorkCell;
import cn.estsh.i3plus.pojo.mes.bean.MesWorkOrder; import cn.estsh.i3plus.pojo.mes.bean.MesWorkOrder;
import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiOperation;
import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -63,4 +64,9 @@ public interface IMesWorkOrderExtService {
@ApiOperation(value = "根据工单更新工单状态") @ApiOperation(value = "根据工单更新工单状态")
void updateMesWorkOrderOrderStatusShippingByWorkOrderNo(String organizeCode, List<String> workOrderNoList,String userName); void updateMesWorkOrderOrderStatusShippingByWorkOrderNo(String organizeCode, List<String> workOrderNoList,String userName);
@ApiOperation(value = "控制工单数量查询")
Map<String, Double> getControlOrderQtyMap(String organizeCode, String workCenterCode, List<String> partNoList, String startTime, String endTime);
@ApiOperation(value = "完成工单数量查询")
Map<String, Double> getCompleteOrderQtyMap(String organizeCode, String workCenterCode, List<String> partNoList, String lotNo);
} }

@ -225,12 +225,17 @@ public class MesProdShiftRecordServiceImpl implements IMesProdShiftRecordService
@Override @Override
public MesProdShiftRecord getProdShiftRecordOpenStatus(String organizeCode, String workCenterCode) { public MesProdShiftRecord getProdShiftRecordOpenStatus(String organizeCode, String workCenterCode) {
MesProdShiftRecord prodShiftRecord = getProdShiftRecordCdtDesc(organizeCode, workCenterCode);
if (prodShiftRecord != null && !StringUtils.isEmpty(prodShiftRecord.getWorkStatus()) && prodShiftRecord.getWorkStatus().compareTo(MesExtEnumUtil.WORK_STATUS.START.getValue()) == 0) return prodShiftRecord;
return null;
}
@Override
public MesProdShiftRecord getProdShiftRecordCdtDesc(String organizeCode, String workCenterCode) {
DdlPackBean packBean = DdlPackBean.getDdlPackBean(organizeCode); DdlPackBean packBean = DdlPackBean.getDdlPackBean(organizeCode);
DdlPreparedPack.getStringEqualPack(workCenterCode, "workCenterCode", packBean); DdlPreparedPack.getStringEqualPack(workCenterCode, "workCenterCode", packBean);
DdlPreparedPack.getOrderByPack(new Object[]{CommonEnumUtil.ASC_OR_DESC.DESC.getValue()}, new String[]{MesPcnExtConstWords.CREATE_DATE_TIME}, packBean); DdlPreparedPack.getOrderByPack(new Object[]{CommonEnumUtil.ASC_OR_DESC.DESC.getValue()}, new String[]{MesPcnExtConstWords.CREATE_DATE_TIME}, packBean);
MesProdShiftRecord prodShiftRecord = mesProdShiftRecordRDao.getByProperty(packBean); return mesProdShiftRecordRDao.getByProperty(packBean);
if (prodShiftRecord != null && !StringUtils.isEmpty(prodShiftRecord.getWorkStatus()) && prodShiftRecord.getWorkStatus().compareTo(MesExtEnumUtil.WORK_STATUS.START.getValue()) == 0) return prodShiftRecord;
return null;
} }
//封装展示组件班组班次内容 //封装展示组件班组班次内容

@ -2,7 +2,7 @@ package cn.estsh.i3plus.ext.mes.pcn.apiservice.serviceimpl.base;
import cn.estsh.i3plus.ext.mes.pcn.api.base.IMesShiftService; import cn.estsh.i3plus.ext.mes.pcn.api.base.IMesShiftService;
import cn.estsh.i3plus.ext.mes.pcn.pojo.util.MesPcnExtConstWords; import cn.estsh.i3plus.ext.mes.pcn.pojo.util.MesPcnExtConstWords;
import cn.estsh.i3plus.mes.pcn.util.DateUtil; import cn.estsh.i3plus.platform.common.exception.ImppExceptionEnum;
import cn.estsh.i3plus.platform.common.tool.TimeTool; import cn.estsh.i3plus.platform.common.tool.TimeTool;
import cn.estsh.i3plus.pojo.base.bean.DdlPackBean; import cn.estsh.i3plus.pojo.base.bean.DdlPackBean;
import cn.estsh.i3plus.pojo.base.bean.ListPager; import cn.estsh.i3plus.pojo.base.bean.ListPager;
@ -13,17 +13,17 @@ import cn.estsh.i3plus.pojo.base.tool.DdlPreparedPack;
import cn.estsh.i3plus.pojo.mes.bean.MesProdShiftRecord; import cn.estsh.i3plus.pojo.mes.bean.MesProdShiftRecord;
import cn.estsh.i3plus.pojo.mes.bean.MesShift; import cn.estsh.i3plus.pojo.mes.bean.MesShift;
import cn.estsh.i3plus.pojo.mes.repository.MesShiftRepository; import cn.estsh.i3plus.pojo.mes.repository.MesShiftRepository;
import cn.estsh.i3plus.pojo.mes.util.MesExtEnumUtil; import cn.estsh.impp.framework.boot.exception.ImppExceptionBuilder;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils; import org.springframework.util.CollectionUtils;
import org.springframework.util.StringUtils;
import java.util.HashMap; import java.text.DateFormat;
import java.util.List; import java.text.ParseException;
import java.util.Map; import java.text.SimpleDateFormat;
import java.util.Optional; import java.util.*;
/** /**
@ -55,31 +55,49 @@ public class MesShiftServiceImpl implements IMesShiftService {
@Override @Override
public List<MesShift> queryMesShift(String organizeCode, String workCenterCode) { public List<MesShift> queryMesShift(String organizeCode, String workCenterCode) {
if (StringUtils.isEmpty(organizeCode) || StringUtils.isEmpty(workCenterCode)) return null;
DdlPackBean packBean = DdlPackBean.getDdlPackBean(organizeCode); DdlPackBean packBean = DdlPackBean.getDdlPackBean(organizeCode);
DdlPreparedPack.getStringEqualPack(workCenterCode, "workCenterCode", packBean); DdlPreparedPack.getStringEqualPack(workCenterCode, "workCenterCode", packBean);
DdlPreparedPack.getOrderByPack(new Object[]{CommonEnumUtil.ASC_OR_DESC.ASC.getValue()}, new String[]{MesPcnExtConstWords.SHIFT_CODE}, packBean);
return mesShiftRepository.findByHqlWhere(packBean); return mesShiftRepository.findByHqlWhere(packBean);
} }
@Override @Override
public Map<String, String> getShiftTimeMap(MesProdShiftRecord record) { public Map<String, String> getShiftTimeMap(MesProdShiftRecord record) {
if (StringUtils.isEmpty(record.getStartTime())) return null;
List<MesShift> shiftList = queryMesShift(record.getOrganizeCode(), record.getWorkCenterCode()); List<MesShift> shiftList = queryMesShift(record.getOrganizeCode(), record.getWorkCenterCode());
if (CollectionUtils.isEmpty(shiftList)) { if (CollectionUtils.isEmpty(shiftList)) return null;
return null;
}
Optional<MesShift> shiftOptional = shiftList.stream().filter(t -> t.getShiftCode().equals(record.getShiftCode())).findFirst(); Optional<MesShift> shiftOptional = shiftList.stream().filter(t -> t.getShiftCode().equals(record.getShiftCode())).findFirst();
if (!shiftOptional.isPresent()) { if (null == shiftOptional || !shiftOptional.isPresent()) return null;
return null; if (StringUtils.isEmpty(shiftOptional.get().getStartTime()) || StringUtils.isEmpty(shiftOptional.get().getEndTime())) return null;
if (StringUtils.isEmpty(shiftList.get(0).getStartTime())) return null;
//当天
String today = TimeTool.getToday();
//当天早班的开始时间
String todayStartTime = today + MesPcnExtConstWords.ONE_SPACE + shiftList.get(0).getStartTime();
//实际开班时间 比 当天早班的开始时间 小的情况下, 代表的是前一天的班次
if (record.getStartTime().compareTo(todayStartTime) < 0) {
String yesterday = calcDay(today, -1);
return calcShiftTime(shiftOptional.get().getStartTime(), shiftOptional.get().getEndTime(), yesterday);
} else {
//当天的班次
return calcShiftTime(shiftOptional.get().getStartTime(), shiftOptional.get().getEndTime(), today);
} }
if (StringUtils.isEmpty(shiftOptional.get().getStartTime()) || StringUtils.isEmpty(shiftOptional.get().getEndTime()) || StringUtils.isEmpty(record.getStartTime())) {
return null;
} }
String startData = TimeTool.parseStringFormat(record.getStartTime(), DateUtil.BASE_FORMAT, DateUtil.SHORT_FORMAT);
//白班 //计算的实际班次开始与结束的时间
String startTime = startData + " " + shiftOptional.get().getStartTime(); private Map<String, String> calcShiftTime(String shiftStartTime, String shiftEndTime, String calcDay) {
String endTime = startData + " " + shiftOptional.get().getEndTime(); //待计算的实际班次开始与结束的时间
//晚班 String startTime, endTime;
if (MesExtEnumUtil.SHIFT_CODE.SHIFT_CODE_20.getValue().equals(record.getShiftCode())) { if (shiftStartTime.compareTo(shiftEndTime) < 0) {
endTime = TimeTool.getToday(DateUtil.addDays(record.getStartTime(), 1)) + " " + shiftOptional.get().getEndTime(); //不跨天
startTime = calcDay + MesPcnExtConstWords.ONE_SPACE + shiftStartTime;
endTime = calcDay + MesPcnExtConstWords.ONE_SPACE + shiftEndTime;
} else {
//跨天
startTime = calcDay + MesPcnExtConstWords.ONE_SPACE + shiftStartTime;
endTime = calcDay(calcDay, 1) + MesPcnExtConstWords.ONE_SPACE + shiftEndTime;
} }
Map<String, String> shiftTimeMap = new HashMap<>(2); Map<String, String> shiftTimeMap = new HashMap<>(2);
shiftTimeMap.put(MesPcnExtConstWords.START_TIME, startTime); shiftTimeMap.put(MesPcnExtConstWords.START_TIME, startTime);
@ -87,4 +105,75 @@ public class MesShiftServiceImpl implements IMesShiftService {
return shiftTimeMap; return shiftTimeMap;
} }
//计算天数
@Override
public String calcDay(String day, int amount) {
try {
DateFormat sdf = new SimpleDateFormat(MesPcnExtConstWords.DATE_FORMAT_SEPARATOR);
return TimeTool.timeCalc(sdf.parse(day), Calendar.DATE, amount, MesPcnExtConstWords.DATE_FORMAT_SEPARATOR);
} catch (ParseException e) {
throw ImppExceptionBuilder.newInstance()
.setSystemID(CommonEnumUtil.SOFT_TYPE.MES_PCN.getCode())
.setErrorCode(ImppExceptionEnum.VARIFY_EXCEPTION.getCode())
.setErrorDetail("时间计算失败")
.build();
}
}
//根据当前时间计算实际整天班次的时间
@Override
public Map<String, String> calcAllDayShiftTimeMapByCurTime(String organizeCode, String workCenterCode) {
//根据生产线查询关联的班次集合, 根据班次代码正序
List<MesShift> shiftList = queryMesShift(organizeCode, workCenterCode);
if (CollectionUtils.isEmpty(shiftList)) return null;
if (StringUtils.isEmpty(shiftList.get(0).getStartTime()) || StringUtils.isEmpty(shiftList.get(shiftList.size() - 1).getEndTime())) return null;
//当天
String today = TimeTool.getToday();
//当天早班的开始时间
String todayStartTime = today + MesPcnExtConstWords.ONE_SPACE + shiftList.get(0).getStartTime();
//当前时间 比 当天早班的开始时间 小的情况下, 代表的是前一天的班次
Map<String, String> shiftTimeMap;
if (TimeTool.getNowTime(true).compareTo(todayStartTime) < 0) {
String yesterday = calcDay(today, -1);
shiftTimeMap = calcShiftTime(shiftList.get(0).getStartTime(), shiftList.get(shiftList.size() - 1).getEndTime(), yesterday);
shiftTimeMap.put(MesPcnExtConstWords.LOT_NO, yesterday);
} else {
//当天的班次
shiftTimeMap = calcShiftTime(shiftList.get(0).getStartTime(), shiftList.get(shiftList.size() - 1).getEndTime(), today);
shiftTimeMap.put(MesPcnExtConstWords.LOT_NO, today);
}
return shiftTimeMap;
}
//根据当前时间计算当前班次的时间
@Override
public Map<String, String> calcCurShiftTimeMapByCurTime(String organizeCode, String workCenterCode) {
//根据生产线查询关联的班次集合, 根据班次代码正序
List<MesShift> shiftList = queryMesShift(organizeCode, workCenterCode);
if (CollectionUtils.isEmpty(shiftList)) return null;
String nowTime = TimeTool.getNowTime(true);
String today = nowTime.substring(0, 10);
String time = nowTime.substring(11);
Optional<MesShift> shiftOptional = shiftList.stream().filter(o -> (null != o
&& !StringUtils.isEmpty(o.getStartTime()) && !StringUtils.isEmpty(o.getEndTime()) && o.getStartTime().compareTo(time) <= 0 && o.getEndTime().compareTo(time) >= 0)).findFirst();
if (null == shiftOptional || !shiftOptional.isPresent()) return null;
//当天早班的开始时间
String todayStartTime = today + MesPcnExtConstWords.ONE_SPACE + shiftList.get(0).getStartTime();
//实际开班时间 比 当天早班的开始时间 小的情况下, 代表的是前一天的班次
if (nowTime.compareTo(todayStartTime) < 0) {
String yesterday = calcDay(today, -1);
return calcShiftTime(shiftOptional.get().getStartTime(), shiftOptional.get().getEndTime(), yesterday);
} else {
//当天的班次
return calcShiftTime(shiftOptional.get().getStartTime(), shiftOptional.get().getEndTime(), today);
}
}
} }

@ -5,15 +5,14 @@ import cn.estsh.i3plus.ext.mes.pcn.api.busi.IMesProduceSnExtService;
import cn.estsh.i3plus.ext.mes.pcn.api.busi.IMesWorkOrderExtService; import cn.estsh.i3plus.ext.mes.pcn.api.busi.IMesWorkOrderExtService;
import cn.estsh.i3plus.ext.mes.pcn.apiservice.aspect.MonitorLog; import cn.estsh.i3plus.ext.mes.pcn.apiservice.aspect.MonitorLog;
import cn.estsh.i3plus.ext.mes.pcn.pojo.util.MesPcnExtConstWords; import cn.estsh.i3plus.ext.mes.pcn.pojo.util.MesPcnExtConstWords;
import cn.estsh.i3plus.platform.common.tool.MathOperation;
import cn.estsh.i3plus.platform.common.tool.TimeTool; import cn.estsh.i3plus.platform.common.tool.TimeTool;
import cn.estsh.i3plus.pojo.base.bean.BaseBean; import cn.estsh.i3plus.pojo.base.bean.BaseBean;
import cn.estsh.i3plus.pojo.base.bean.DdlPackBean; import cn.estsh.i3plus.pojo.base.bean.DdlPackBean;
import cn.estsh.i3plus.pojo.base.enumutil.CommonEnumUtil; import cn.estsh.i3plus.pojo.base.enumutil.CommonEnumUtil;
import cn.estsh.i3plus.pojo.base.tool.DdlPreparedPack; import cn.estsh.i3plus.pojo.base.tool.DdlPreparedPack;
import cn.estsh.i3plus.pojo.mes.bean.MesProduceSn; import cn.estsh.i3plus.pojo.mes.bean.*;
import cn.estsh.i3plus.pojo.mes.bean.MesQueueOrder; import cn.estsh.i3plus.pojo.mes.repository.MesWorkOrderControlQtyRecordRepository;
import cn.estsh.i3plus.pojo.mes.bean.MesWorkCell;
import cn.estsh.i3plus.pojo.mes.bean.MesWorkOrder;
import cn.estsh.i3plus.pojo.mes.repository.MesWorkOrderRepository; import cn.estsh.i3plus.pojo.mes.repository.MesWorkOrderRepository;
import cn.estsh.i3plus.pojo.mes.util.MesExtEnumUtil; import cn.estsh.i3plus.pojo.mes.util.MesExtEnumUtil;
import cn.hutool.core.date.DateUtil; import cn.hutool.core.date.DateUtil;
@ -40,6 +39,9 @@ public class MesWorkOrderExtService implements IMesWorkOrderExtService {
@Autowired @Autowired
private IMesCustomerSnTransformService customerSnTransformService; private IMesCustomerSnTransformService customerSnTransformService;
@Autowired
private MesWorkOrderControlQtyRecordRepository workOrderControlQtyRecordRepository;
//根据生产工单号集合 查询生产工单数据 //根据生产工单号集合 查询生产工单数据
@Override @Override
public List<MesWorkOrder> getWorkOrderList(String organizeCode, List<String> workOrderNoList) { public List<MesWorkOrder> getWorkOrderList(String organizeCode, List<String> workOrderNoList) {
@ -267,4 +269,47 @@ public class MesWorkOrderExtService implements IMesWorkOrderExtService {
return produceSn; return produceSn;
} }
@Override
public Map<String, Double> getControlOrderQtyMap(String organizeCode, String workCenterCode, List<String> partNoList, String startTime, String endTime) {
if (StringUtils.isEmpty(organizeCode) || StringUtils.isEmpty(workCenterCode) ||
StringUtils.isEmpty(startTime) || StringUtils.isEmpty(endTime) || CollectionUtils.isEmpty(partNoList)) return null;
DdlPackBean packBean = DdlPackBean.getDdlPackBean(organizeCode);
DdlPreparedPack.timeBuilder(startTime, endTime, MesPcnExtConstWords.PLAN_START_TIME, packBean, false);
DdlPreparedPack.getStringEqualPack(workCenterCode, MesPcnExtConstWords.WORK_CENTER_CODE, packBean);
if (partNoList.size() == 1) DdlPreparedPack.getStringEqualPack(partNoList.get(0), MesPcnExtConstWords.PART_NO, packBean);
else DdlPreparedPack.getInPackList(partNoList, MesPcnExtConstWords.PART_NO, packBean);
List<MesWorkOrder> workOrderList = workOrderRepository.findByHqlWhere(packBean);
workOrderList = CollectionUtils.isEmpty(workOrderList) ? null :
workOrderList.stream().filter(o -> (null != o && !StringUtils.isEmpty(o.getPartNo()) && !StringUtils.isEmpty(o.getWorkOrderStatus()) && !StringUtils.isEmpty(o.getOrderFlag())
&& o.getWorkOrderStatus().compareTo(MesExtEnumUtil.ORDER_STATUS.CREATE.getValue()) != 0 && !o.getOrderFlag().equals(MesExtEnumUtil.ORDER_TYPE_IDENTIFICATION.P.getValue()))).collect(Collectors.toList());
if (CollectionUtils.isEmpty(workOrderList)) return null;
Map<String, List<MesWorkOrder>> workOrderMap = workOrderList.stream().filter(o -> null != o).collect(Collectors.groupingBy(o -> o.getPartNo().toUpperCase()));
Map<String, Double> controlOrderQtyMap = new HashMap<>();
Double qty;
for (Map.Entry<String, List<MesWorkOrder>> entry : workOrderMap.entrySet()) {
if (null == entry) continue;
qty = new Double(MesPcnExtConstWords.ZERO);
for (MesWorkOrder workOrder : entry.getValue()) {
if (null == workOrder) continue;
qty = MathOperation.add(qty, workOrder.getWorkOrderStatus().compareTo(MesExtEnumUtil.ORDER_STATUS.CLOSE.getValue()) >= 0 ? workOrder.getCompleteQty() : workOrder.getQty());
}
controlOrderQtyMap.put(entry.getKey(), qty);
}
return controlOrderQtyMap;
}
@Override
public Map<String, Double> getCompleteOrderQtyMap(String organizeCode, String workCenterCode, List<String> partNoList, String lotNo) {
if (StringUtils.isEmpty(organizeCode) || StringUtils.isEmpty(workCenterCode) || StringUtils.isEmpty(lotNo) || CollectionUtils.isEmpty(partNoList)) return null;
DdlPackBean packBean = DdlPackBean.getDdlPackBean(organizeCode);
DdlPreparedPack.getStringEqualPack(lotNo, MesPcnExtConstWords.LOT_NO, packBean);
DdlPreparedPack.getStringEqualPack(workCenterCode, MesPcnExtConstWords.WORK_CENTER_CODE, packBean);
if (partNoList.size() == 1) DdlPreparedPack.getStringEqualPack(partNoList.get(0), MesPcnExtConstWords.PART_NO, packBean);
else DdlPreparedPack.getInPackList(partNoList, MesPcnExtConstWords.PART_NO, packBean);
List<MesWorkOrderControlQtyRecord> workOrderControlQtyRecordList = workOrderControlQtyRecordRepository.findByHqlWhere(packBean);
return CollectionUtils.isEmpty(workOrderControlQtyRecordList) ? null :
workOrderControlQtyRecordList.stream().filter(o -> null != o).collect(Collectors.groupingBy(o -> o.getPartNo().toUpperCase(), Collectors.summingDouble(MesWorkOrderControlQtyRecord::getQty)));
}
} }

@ -0,0 +1,193 @@
package cn.estsh.i3plus.ext.mes.pcn.apiservice.serviceimpl.station.function;
import cn.estsh.i3plus.ext.mes.pcn.api.base.IMesProdShiftRecordService;
import cn.estsh.i3plus.ext.mes.pcn.api.base.IMesShiftService;
import cn.estsh.i3plus.ext.mes.pcn.api.busi.IMesProductionCustomContextStepService;
import cn.estsh.i3plus.ext.mes.pcn.pojo.model.MesProductionPartSheetModel;
import cn.estsh.i3plus.ext.mes.pcn.pojo.util.MesPcnExtConstWords;
import cn.estsh.i3plus.mes.pcn.serviceimpl.fsm.BaseSwsService;
import cn.estsh.i3plus.mes.pcn.serviceimpl.fsm.function.IFsmModuleFunctionService;
import cn.estsh.i3plus.platform.common.tool.TimeTool;
import cn.estsh.i3plus.pojo.base.bean.DdlPackBean;
import cn.estsh.i3plus.pojo.base.tool.DdlPreparedPack;
import cn.estsh.i3plus.pojo.mes.bean.MesProductionRecord;
import cn.estsh.i3plus.pojo.mes.model.ButtonDynamicModel;
import cn.estsh.i3plus.pojo.mes.model.StationRequestBean;
import cn.estsh.i3plus.pojo.mes.model.StationResultBean;
import cn.estsh.i3plus.pojo.mes.repository.MesProductionRecordRepository;
import cn.estsh.i3plus.pojo.mes.util.MesExtEnumUtil;
import com.alibaba.fastjson.JSONObject;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
import org.springframework.util.StringUtils;
import java.text.ParseException;
import java.util.*;
import java.util.stream.Collectors;
/**
* @Description : Sheet
**/
@Service
public class MesFunctionProductionPartSheetService extends BaseSwsService implements IFsmModuleFunctionService {
@Autowired
private IMesProductionCustomContextStepService productionCustomContextStepService;
@Autowired
private IMesShiftService shiftService;
@Autowired
private IMesProdShiftRecordService prodShiftRecordService;
@Autowired
private MesProductionRecordRepository productionRecordRepository;
@Override
public Object doCustomApiDispatch(StationRequestBean reqBean, StationResultBean resultBean, ButtonDynamicModel buttonDynamicModel) {
//页面渲染数据集
Map<String, Object> resultMap = new HashMap<>();
//验证参数
Map<String, String> paramMap = null;
try {
paramMap = StringUtils.isEmpty(buttonDynamicModel.getFunctionValue()) ? null : JSONObject.parseObject(buttonDynamicModel.getFunctionValue(), Map.class);
} catch (Exception e) {
}
//返回客户端作为查询条件
Map<Integer, String> reportStatusMap = new HashMap<>();
reportStatusMap.put(REPORT_STATUS.REPORT.getValue(), REPORT_STATUS.REPORT.getDescription());
reportStatusMap.put(REPORT_STATUS.UN_REPORT.getValue(), REPORT_STATUS.UN_REPORT.getDescription());
resultMap.put(MesPcnExtConstWords.REPORT_STATUS, reportStatusMap);
String startTime = !CollectionUtils.isEmpty(paramMap) && !StringUtils.isEmpty(paramMap.get(MesPcnExtConstWords.START_TIME)) ? paramMap.get(MesPcnExtConstWords.START_TIME) : null;
String endTime = !CollectionUtils.isEmpty(paramMap) && !StringUtils.isEmpty(paramMap.get(MesPcnExtConstWords.END_TIME)) ? paramMap.get(MesPcnExtConstWords.END_TIME) : null;
if (StringUtils.isEmpty(startTime) || StringUtils.isEmpty(endTime)) {
//根据当前时间计算当前班次的时间
Map<String, String> shiftTimeMap = shiftService.calcCurShiftTimeMapByCurTime(reqBean.getOrganizeCode(), reqBean.getWorkCenterCode());
if (!CollectionUtils.isEmpty(shiftTimeMap)) {
startTime = shiftTimeMap.get(MesPcnExtConstWords.START_TIME);
endTime = shiftTimeMap.get(MesPcnExtConstWords.END_TIME);
} else {
String today = TimeTool.getToday();
startTime = today + MesPcnExtConstWords.DATE_FORMAT_APPEND_0;
endTime = shiftService.calcDay(today, 1) + MesPcnExtConstWords.DATE_FORMAT_APPEND_0;
}
//返回客户端作为默认条件
resultMap.put(MesPcnExtConstWords.START_TIME, startTime);
resultMap.put(MesPcnExtConstWords.END_TIME, endTime);
//客户端默认开窗时不查询数据
return resultMap;
}
Boolean checkTime;
try {
checkTime = TimeTool.getSecoundsBetweenTime(1, startTime, endTime) <= 86400;
} catch (ParseException e) {
checkTime = false;
}
if (!checkTime) return packResultMap(resultMap, "时间查询条件限制一天!");
String partNo = !CollectionUtils.isEmpty(paramMap) && !StringUtils.isEmpty(paramMap.get(MesPcnExtConstWords.PART_NO)) ? paramMap.get(MesPcnExtConstWords.PART_NO) : null;
//查询加工记录数据
DdlPackBean packBean = DdlPackBean.getDdlPackBean(reqBean.getOrganizeCode());
DdlPreparedPack.timeBuilder(startTime, endTime, MesPcnExtConstWords.COMPLETE_DATE_TIME, packBean, false);
DdlPreparedPack.getStringEqualPack(reqBean.getWorkCenterCode(), MesPcnExtConstWords.WORK_CENTER_CODE, packBean);
DdlPreparedPack.getStringEqualPack(reqBean.getWorkCellCode(), MesPcnExtConstWords.WORK_CELL_CODE, packBean);
DdlPreparedPack.getStringEqualPack(partNo, MesPcnExtConstWords.PART_NO, packBean);
List<MesProductionRecord> productionRecordList = productionRecordRepository.findByHqlWhere(packBean);
if (CollectionUtils.isEmpty(productionRecordList)) return resultMap;
Integer reportStatus = !CollectionUtils.isEmpty(paramMap) && !StringUtils.isEmpty(paramMap.get(MesPcnExtConstWords.REPORT_STATUS)) ? Integer.valueOf(paramMap.get(MesPcnExtConstWords.REPORT_STATUS)) : null;
//搜集需要汇报的加工记录
List<MesProductionRecord> productionRecordList2Report = (StringUtils.isEmpty(reportStatus) || reportStatus.compareTo(REPORT_STATUS.REPORT.getValue()) == 0)
? productionRecordList.stream().filter(o -> (null != o && !StringUtils.isEmpty(o.getPartNo()) && o.getReportStatus().compareTo(MesExtEnumUtil.REPORT_STATUS.REPORT_STATUS_30.getValue()) != 0)).collect(Collectors.toList()) : null;
//搜集无需汇报的加工记录
List<MesProductionRecord> productionRecordList2NoReport = (StringUtils.isEmpty(reportStatus) || reportStatus.compareTo(REPORT_STATUS.UN_REPORT.getValue()) == 0)
? productionRecordList.stream().filter(o -> (null != o && !StringUtils.isEmpty(o.getPartNo()) && o.getReportStatus().compareTo(MesExtEnumUtil.REPORT_STATUS.REPORT_STATUS_30.getValue()) == 0)).collect(Collectors.toList()) : null;
List<MesProductionPartSheetModel> resultList = new ArrayList<>();
if (!CollectionUtils.isEmpty(productionRecordList2Report)) backResultList(resultList, productionRecordList2Report, REPORT_STATUS.REPORT);
if (!CollectionUtils.isEmpty(productionRecordList2NoReport)) backResultList(resultList, productionRecordList2NoReport, REPORT_STATUS.UN_REPORT);
if (!CollectionUtils.isEmpty(resultList)) {
resultList = resultList.stream().filter(o -> null != o).sorted(Comparator.comparing(MesProductionPartSheetModel::getPartNo).thenComparing(MesProductionPartSheetModel::getReportSatus)).collect(Collectors.toList());
resultMap.put(MesPcnExtConstWords.DATA, resultList);
}
return resultMap;
}
private void backResultList(List<MesProductionPartSheetModel> resultList, List<MesProductionRecord> productionRecordList, REPORT_STATUS reportStatus) {
Map<String, List<MesProductionRecord>> prMap = productionRecordList.stream().filter(o -> null != o).collect(Collectors.groupingBy(MesProductionRecord::getPartNo));
for (Map.Entry<String, List<MesProductionRecord>> entry : prMap.entrySet()) {
if (null == entry) continue;
MesProductionRecord item = entry.getValue().get(0);
MesProductionPartSheetModel result = new MesProductionPartSheetModel();
result.setWorkCenterCode(item.getWorkCenterCode());
result.setWorkCellCode(item.getWorkCellCode());
result.setPartNo(item.getPartNo());
result.setPartName(item.getPartName());
result.setQty(new Double(entry.getValue().size()));
result.setReportSatus(reportStatus.getValue());
result.setReportSatusName(reportStatus.getDescription());
resultList.add(result);
}
}
//返回提示信息
private Map<String, Object> packResultMap(Map<String, Object> resultMap, String message) {
resultMap.put(MesPcnExtConstWords.MESSAGE, message);
return resultMap;
}
//业务操作
enum REPORT_STATUS {
REPORT(20, "需要汇报"),
UN_REPORT(30, "无需汇报");
private int value;
private String description;
REPORT_STATUS(int value, String description) {
this.value = value;
this.description = description;
}
public int getValue() {
return value;
}
public String getDescription() {
return description;
}
public static String valueOfDescription(int val) {
if (StringUtils.isEmpty(val)) return null;
String tmp = null;
for (int i = 0; i < values().length; i++) {
if (val == values()[i].value) {
tmp = values()[i].description;
}
}
return tmp;
}
}
}

@ -0,0 +1,239 @@
package cn.estsh.i3plus.ext.mes.pcn.apiservice.serviceimpl.step;
import cn.estsh.i3plus.ext.mes.pcn.api.base.IMesShiftService;
import cn.estsh.i3plus.ext.mes.pcn.api.busi.IMesProductionDispatchContextStepService;
import cn.estsh.i3plus.ext.mes.pcn.api.busi.IMesProductionProcessContextStepService;
import cn.estsh.i3plus.ext.mes.pcn.api.busi.IMesProductionRecordService;
import cn.estsh.i3plus.ext.mes.pcn.api.busi.IMesWorkOrderExtService;
import cn.estsh.i3plus.ext.mes.pcn.pojo.context.*;
import cn.estsh.i3plus.ext.mes.pcn.pojo.util.MesPcnExtConstWords;
import cn.estsh.i3plus.mes.pcn.serviceimpl.fsm.BaseStepService;
import cn.estsh.i3plus.mes.pcn.serviceimpl.fsm.IStepService;
import cn.estsh.i3plus.mes.pcn.util.StringUtil;
import cn.estsh.i3plus.platform.common.convert.ConvertBean;
import cn.estsh.i3plus.platform.common.tool.MathOperation;
import cn.estsh.i3plus.pojo.base.enumutil.CommonEnumUtil;
import cn.estsh.i3plus.pojo.mes.bean.MesProductionRecord;
import cn.estsh.i3plus.pojo.mes.bean.MesWorkOrderControlQtyRecord;
import cn.estsh.i3plus.pojo.mes.model.StationRequestBean;
import cn.estsh.i3plus.pojo.mes.model.StationResultBean;
import cn.estsh.i3plus.pojo.mes.model.StepResult;
import cn.estsh.i3plus.pojo.mes.repository.MesWorkOrderControlQtyRecordRepository;
import cn.estsh.i3plus.pojo.mes.util.MesExtEnumUtil;
import cn.estsh.impp.framework.boot.util.SpringContextsUtil;
import com.alibaba.fastjson.JSONObject;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
import org.springframework.util.StringUtils;
import java.util.*;
import java.util.stream.Collectors;
/**
* @Description :
* @Author : wangjie
**/
@Slf4j
@Service("mesProductionDataSaveBeforeControlOrderStepService")
public class MesProductionDataSaveBeforeControlOrderStepService extends BaseStepService {
@Autowired
private IMesProductionProcessContextStepService productionProcessContextStepService;
@Autowired
private IMesProductionDispatchContextStepService productionDispatchContextStepService;
@Autowired
private IMesProductionRecordService productionRecordService;
@Autowired
private IMesShiftService shiftService;
@Autowired
private IMesWorkOrderExtService workOrderExtService;
@Autowired
private MesWorkOrderControlQtyRecordRepository workOrderControlQtyRecordRepository;
@Override
public StepResult execute(StationRequestBean reqBean) {
StepResult stepResult = StepResult.getSuccessComplete();
StationResultBean resultBean = new StationResultBean();
//获取上下文信息: 处理加工不可用规则
MesProductionProcessContext productionProcessContext = productionProcessContextStepService.dispatchProdRuleIgnoreCfgContext(reqBean);
//配置错误 抛出异常
if (!productionProcessContext.getSuccess()) stepExpSendMsgAndThrowEx(reqBean, resultBean.writeDbLog(), productionProcessContext.getMessage());
//存储生产过程上下文对象
productionProcessContextStepService.dispatchProductionProcessContext(reqBean, productionProcessContext);
//获取上下文产品加工规则数据信息集合
List<MesProdRuleContext> prodRuleContextList = productionDispatchContextStepService.getProdRuleDataContext(reqBean);
Map<Integer, MesProdRuleContext> prMap = CollectionUtils.isEmpty(prodRuleContextList) ? null : prodRuleContextList.stream().filter(o -> (null != o && !StringUtils.isEmpty(o.getForeignKey()))).collect(Collectors.toMap(MesProdRuleContext::getForeignKey, o -> o));
//获取上下文产出条码数据信息集合
List<MesProductionPsOutContext> productionPsOutContextList = productionDispatchContextStepService.getProductionPsOutContext(reqBean);
if (CollectionUtils.isEmpty(prMap) || CollectionUtils.isEmpty(productionPsOutContextList)) stepExpSendMsgAndThrowEx(reqBean, resultBean.writeDbLog(), "当前不存在非排序加工规则数据,请重置工序!");
//获取进料主条码数据信息
List<MesProductionPsInContext> productionPsInContextList = productionDispatchContextStepService.getProductionPsInContext(reqBean);
Map<Integer, MesProductionPsInContext> psiMap = CollectionUtils.isEmpty(productionPsInContextList) ? null : productionPsInContextList.stream().filter(o -> (null != o && !StringUtils.isEmpty(o.getForeignKey()))).collect(Collectors.toMap(MesProductionPsInContext::getForeignKey, o -> o));
//获取上下文产出零件信息
List<MesProductionPartContext> productionPartContextList = productionDispatchContextStepService.getProductionPartContext(reqBean);
//当前不能生产的零件号
List<String> unProductionPartNoList = null;
Loop:
synchronized (new StringJoiner(MesPcnExtConstWords.COLON).add(reqBean.getOrganizeCode()).add(reqBean.getWorkCenterCode()).add(MesPcnExtConstWords.WORK_ORDER_COMPLETE_CONTEXT).toString().intern()) {
//验证是否需要汇报
productionPsOutContextList.stream().filter(o -> null != o).forEach(o -> checkProductionRecordIsReport(reqBean, o, prMap.get(o.getForeignKey()), CollectionUtils.isEmpty(psiMap) ? null : psiMap.get(o.getForeignKey())));
Map<String, List<MesProductionPsOutContext>> reportPsMap = productionPsOutContextList.stream().filter(o -> (null != o && o.getIsCalcCompleteQty().compareTo(CommonEnumUtil.TRUE_OR_FALSE.TRUE.getValue()) == 0)).collect(Collectors.groupingBy(o -> o.getPartNo().toUpperCase()));
if (CollectionUtils.isEmpty(reportPsMap)) break Loop;
//需要汇报的零件号
List<String> partNoList = new ArrayList<>(reportPsMap.keySet());
//根据当前时间计算实际整天班次的时间
Map<String, String> shiftTimeMap = shiftService.calcAllDayShiftTimeMapByCurTime(reqBean.getOrganizeCode(), reqBean.getWorkCenterCode());
//控制工单数量查询
Map<String, Double> controlOrderQtyMap = workOrderExtService.getControlOrderQtyMap(reqBean.getOrganizeCode(), reqBean.getWorkCenterCode(),
partNoList, shiftTimeMap.get(MesPcnExtConstWords.START_TIME), shiftTimeMap.get(MesPcnExtConstWords.END_TIME));
//存在工单的零件号
List<String> existOrderPartNoList = CollectionUtils.isEmpty(controlOrderQtyMap) ? null : new ArrayList<>(controlOrderQtyMap.keySet());
//查询存在工单的零件号对应的完成工单数量
Map<String, Double> completeOrderQtyMap = workOrderExtService.getCompleteOrderQtyMap(
reqBean.getOrganizeCode(), reqBean.getWorkCenterCode(), existOrderPartNoList, shiftTimeMap.get(MesPcnExtConstWords.LOT_NO));
Double planQty, completeQty;
for (Map.Entry<String, List<MesProductionPsOutContext>> entry : reportPsMap.entrySet()) {
if (null == entry) continue;
planQty = (!CollectionUtils.isEmpty(controlOrderQtyMap) && controlOrderQtyMap.containsKey(entry.getKey())) ? controlOrderQtyMap.get(entry.getKey()) : new Double(MesPcnExtConstWords.ZERO);
completeQty = (!CollectionUtils.isEmpty(completeOrderQtyMap) && completeOrderQtyMap.containsKey(entry.getKey())) ? completeOrderQtyMap.get(entry.getKey()) : new Double(MesPcnExtConstWords.ZERO);
if (MathOperation.compareTo(MathOperation.add(completeQty, new Double(entry.getValue().size())), planQty) <= 0) continue;
if (CollectionUtils.isEmpty(unProductionPartNoList)) unProductionPartNoList = new ArrayList<>();
unProductionPartNoList.add(entry.getKey());
}
if (!CollectionUtils.isEmpty(unProductionPartNoList)) break Loop;
//非排序线 保存加工结果工步 execute 方法 使用的是 新事务
stepResult = ((IStepService) SpringContextsUtil.getBean("mesProductionDataSaveStepService")).execute(reqBean);
//保存加工结果事务提交之后, 保存工单计数
if (stepResult.isCompleted() && !StringUtils.isEmpty(stepResult.getStepAfterState())) {
IStepService stepService = ((IStepService) SpringContextsUtil.getBean(stepResult.getStepAfterState()));
stepResult.stepAfterState(null);
stepService.executeStepAfterExecute(reqBean, stepResult);
}
if (stepResult.isCompleted()) insertWorkOrderControlQtyRecord(reqBean, reportPsMap, shiftTimeMap.get(MesPcnExtConstWords.LOT_NO));
return stepResult;
}
//非排序线 保存加工结果工步 execute 方法 使用的是 新事务
if (CollectionUtils.isEmpty(unProductionPartNoList))
return ((IStepService) SpringContextsUtil.getBean("mesProductionDataSaveStepService")).execute(reqBean);
stepNonCompleteAndSendMsg(reqBean, resultBean.writeDbLog(), stepResult, String.format("控制加工单数量验证零件号%s当前无法继续生产!", unProductionPartNoList.toString()));
stepResult.nextTriggerEvent(MesPcnExtConstWords.NEXT_TRIGGER_EVENT_ASSEMBLY);
if (!CollectionUtils.isEmpty(productionPsInContextList)) {
productionDispatchContextStepService.removeProductionPsInContext(reqBean);
stepResult.nextTriggerEvent(MesPcnExtConstWords.NEXT_TRIGGER_EVENT_PRODUCT_SN);
}
if (!CollectionUtils.isEmpty(productionPartContextList)) {
productionDispatchContextStepService.removeProductionPartContext(reqBean);
productionProcessContextStepService.removeFunctionChooseCavityOrderContext(reqBean);
productionProcessContextStepService.removeFunctionChooseCavityPartContext(reqBean);
stepResult.nextTriggerEvent(MesPcnExtConstWords.NEXT_TRIGGER_EVENT_PART_NO);
}
productionDispatchContextStepService.removeProdRuleDataContext(reqBean);
if (productionDispatchContextStepService.checkFirstMouldNoIsExistContext(reqBean)) {
//存在头道模具号场景下 必须抛出异常 因为头道模具号的接口逻辑会配置非常变值,也就是每次返回回去都会拿到头道模具号 就会出现死循环线程
productionDispatchContextStepService.removeFirstMouldNoContext(reqBean);
foundExThrowNoShowMsg();
}
return stepResult;
}
private void checkProductionRecordIsReport(StationRequestBean reqBean, MesProductionPsOutContext productionPsOutContext, MesProdRuleContext prodRuleContext, MesProductionPsInContext productionPsInContext) {
Integer reportType = (null != prodRuleContext && !StringUtils.isEmpty(prodRuleContext.getReportType()) && prodRuleContext.getReportType().compareTo(MesPcnExtConstWords.ZERO) != 0) ? prodRuleContext.getReportType() : MesExtEnumUtil.NOSORT_REPORT_TYPE.NO_REPORT.getValue();
Integer reportStatus = reportType.compareTo(MesExtEnumUtil.NOSORT_REPORT_TYPE.NO_REPORT.getValue()) != 0 ? MesExtEnumUtil.REPORT_STATUS.REPORT_STATUS_10.getValue() : MesExtEnumUtil.REPORT_STATUS.REPORT_STATUS_30.getValue();
if (reportStatus.compareTo(MesExtEnumUtil.REPORT_STATUS.REPORT_STATUS_10.getValue()) == 0 && isSamePart(productionPsInContext, productionPsOutContext) &&
checkPsIsReported(reqBean.getOrganizeCode(), productionPsOutContext.getProductSn(), productionPsOutContext.getPartNo())) reportStatus = MesExtEnumUtil.REPORT_STATUS.REPORT_STATUS_30.getValue();
if (reportStatus.compareTo(MesExtEnumUtil.REPORT_STATUS.REPORT_STATUS_10.getValue()) == 0) productionPsOutContext.setIsCalcCompleteQty(CommonEnumUtil.TRUE_OR_FALSE.TRUE.getValue());
log.info("工厂{}生产线{}工位{}:FSM STATE DISPATCHER --- DO STEP --- {} EXEC --- MesProductionPsOutContext:{}",
reqBean.getOrganizeCode(), reqBean.getWorkCenterCode(), reqBean.getWorkCellCode(), StringUtil.toLowerCaseFirst(this.getClass().getSimpleName()), JSONObject.toJSONString(productionPsOutContext));
}
//加工规则中进料零件与产出零件是否一致
private Boolean isSamePart(MesProductionPsInContext productionPsInContext, MesProductionPsOutContext productionPsOutContext) {
if (null == productionPsInContext) return false;
if (StringUtils.isEmpty(productionPsInContext.getPartNo())) return false;
if (null == productionPsOutContext) return false;
if (!productionPsInContext.getPartNo().toUpperCase().equals(productionPsOutContext.getPartNo().toUpperCase())) return false;
return true;
}
//验证是否存在产出零件条码+零件编码已经汇报的场景
private Boolean checkPsIsReported(String organizeCode, String productSn, String partNo) {
List<MesProductionRecord> productionRecordList = productionRecordService.findProductionRecordList(organizeCode, productSn, partNo);
if (CollectionUtils.isEmpty(productionRecordList)) return false;
Optional<MesProductionRecord> optional = productionRecordList.stream().filter(o -> (null != o && o.getReportStatus().compareTo(MesExtEnumUtil.REPORT_STATUS.REPORT_STATUS_30.getValue()) != 0)).findFirst();
return (null != optional && optional.isPresent()) ? true : false;
}
private void insertWorkOrderControlQtyRecord(StationRequestBean reqBean, Map<String, List<MesProductionPsOutContext>> reportPsMap, String lotNo) {
if (CollectionUtils.isEmpty(reportPsMap)) return;
//获取上下文产品加工规则数据信息集合
List<MesProdRuleContext> prodRuleContextList = productionDispatchContextStepService.getProdRuleDataContext(reqBean);
//加工规则根据数据关联键分组
Map<Integer, MesProdRuleContext> prodRuleContextMap = CollectionUtils.isEmpty(prodRuleContextList) ? null :
prodRuleContextList.stream().filter(o -> null != o).collect(Collectors.toMap(MesProdRuleContext::getForeignKey, o -> o));
//获取上下文工位扫描监控信息
MesScanMonitorContext scanMonitorContext = productionProcessContextStepService.getScanMonitorContext(reqBean.getOrganizeCode(), reqBean.getWorkCenterCode(), reqBean.getWorkCellCode());
for (Map.Entry<String, List<MesProductionPsOutContext>> entry : reportPsMap.entrySet()) {
if (null == entry) continue;
for (MesProductionPsOutContext productionPsOutContext : entry.getValue()) {
if (null == productionPsOutContext) continue;
MesWorkOrderControlQtyRecord workOrderControlQtyRecord = new MesWorkOrderControlQtyRecord();
workOrderControlQtyRecord.setOrganizeCode(reqBean.getOrganizeCode());
workOrderControlQtyRecord.setWorkCenterCode(reqBean.getWorkCenterCode());
workOrderControlQtyRecord.setWorkCellCode(reqBean.getWorkCellCode());
workOrderControlQtyRecord.setProductSn(productionPsOutContext.getProductSn());
workOrderControlQtyRecord.setQty(productionPsOutContext.getQty());
workOrderControlQtyRecord.setPartNo(productionPsOutContext.getPartNo());
workOrderControlQtyRecord.setLotNo(lotNo);
workOrderControlQtyRecord.setShiftCode(productionPsOutContext.getShiftCode());
workOrderControlQtyRecord.setShiftGroup(productionPsOutContext.getShiftGroup());
workOrderControlQtyRecord.setPid(productionPsOutContext.getId());
if (null != scanMonitorContext) workOrderControlQtyRecord.setMouldRecordId(scanMonitorContext.getMouldRecordId());
if (!CollectionUtils.isEmpty(prodRuleContextMap) && prodRuleContextMap.containsKey(productionPsOutContext.getForeignKey())) {
workOrderControlQtyRecord.setProductionRecordId(prodRuleContextMap.get(productionPsOutContext.getForeignKey()).getProductionRecordId());
}
ConvertBean.serviceModelInitialize(workOrderControlQtyRecord, reqBean.getUserInfo());
workOrderControlQtyRecordRepository.insert(workOrderControlQtyRecord);
}
}
}
}

@ -101,7 +101,7 @@ public class MesShippingRfidSeresFindStepService extends BaseStepService {
} }
// public static void main(String[] args) { // public static void main(String[] args) {
// String rfid = "01234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567"; // String rfid = "227S187103LM8F7J3B4SC028108002000466426#LRHA62726CC55####20##2##31122#66241H1H2########4###66###################################";
// System.out.println(rfid.length()); // System.out.println(rfid.length());
// System.out.println(rfid); // System.out.println(rfid);
// System.out.println(rfid.substring(0, 96) + "##################326312JSG1DJ05" + rfid.substring(128)); // System.out.println(rfid.substring(0, 96) + "##################326312JSG1DJ05" + rfid.substring(128));

@ -125,33 +125,6 @@ public class MesProductionDispatchContextStepService extends BaseStepService imp
removeFsmBusiData(reqBean.getOrganizeCode(), getContextKey(reqBean), MesPcnExtConstWords.SEND_PROCESS_CMD_CONTEXT); removeFsmBusiData(reqBean.getOrganizeCode(), getContextKey(reqBean), MesPcnExtConstWords.SEND_PROCESS_CMD_CONTEXT);
} }
//获取上下文产出零件号
@Override
public List<MesEquipVariableCollectContext> getProductionPartNoContext(StationRequestBean reqBean) {
String productionPartNoJson = getFsmBusiData(reqBean.getOrganizeCode(), getContextKey(reqBean), MesPcnExtConstWords.FIRST_MOULD_NO_CONTEXT);
return !StringUtils.isEmpty(productionPartNoJson) ? JSONObject.parseArray(productionPartNoJson, MesEquipVariableCollectContext.class) : null;
}
//验证上下文产出零件号是否存在
@Override
public Boolean checkProductionPartNoIsExistContext(StationRequestBean reqBean) {
String firstMouldNo = getFsmBusiData(reqBean.getOrganizeCode(), getContextKey(reqBean), MesPcnExtConstWords.FIRST_MOULD_NO_CONTEXT);
return !StringUtils.isEmpty(firstMouldNo) ? true : false;
}
//保存上下文产出零件号 [JSON]List<MesEquipVariableCollectContext>
@Override
public Boolean dispatchProductionPartNoContext(StationRequestBean reqBean, List<MesEquipVariableCollectContext> productionPartNoList) {
if (CollectionUtils.isEmpty(productionPartNoList)) return false;
return dispatchFsmBusiData(reqBean.getOrganizeCode(), getContextKey(reqBean), MesPcnExtConstWords.FIRST_MOULD_NO_CONTEXT, JSONObject.toJSONString(productionPartNoList));
}
//删除上下文产出零件号
@Override
public void removeProductionPartNoContext(StationRequestBean reqBean) {
removeFsmBusiData(reqBean.getOrganizeCode(), getContextKey(reqBean), MesPcnExtConstWords.FIRST_MOULD_NO_CONTEXT);
}
//获取上下文头道模具号 //获取上下文头道模具号
@Override @Override
public MesEquipVariableCollectContext getFirstMouldNoContext(StationRequestBean reqBean) { public MesEquipVariableCollectContext getFirstMouldNoContext(StationRequestBean reqBean) {

@ -0,0 +1,34 @@
package cn.estsh.i3plus.ext.mes.pcn.pojo.model;
import io.swagger.annotations.ApiParam;
import lombok.Data;
import java.io.Serializable;
@Data
public class MesProductionPartSheetModel implements Serializable {
private static final long serialVersionUID = -1692026621022774956L;
@ApiParam("生产线代码")
private String workCenterCode;
@ApiParam("工位代码")
private String workCellCode;
@ApiParam("零件号")
private String partNo;
@ApiParam("零件名称")
private String partName;
@ApiParam("加工数量")
private Double qty;
@ApiParam("汇报状态(reportSatus!=30[需要汇报],reportSatus=30[无需汇报])")
private Integer reportSatus;
@ApiParam("汇报状态")
private String reportSatusName;
}

@ -381,6 +381,8 @@ public class MesPcnExtConstWords {
public static final String PAGE_SIZE = "pageSize"; public static final String PAGE_SIZE = "pageSize";
//枚举代码 //枚举代码
public static final String ENUM_CODE = "enumCode"; public static final String ENUM_CODE = "enumCode";
//计划开始时间
public static final String PLAN_START_TIME = "planStartTime";
//BaseBean字段不包含工厂, 用于对象复制剔除属性BeanUtils.copyProperties(Object source, Object target, String... ignoreProperties) //BaseBean字段不包含工厂, 用于对象复制剔除属性BeanUtils.copyProperties(Object source, Object target, String... ignoreProperties)
@ -566,6 +568,8 @@ public class MesPcnExtConstWords {
public static final Integer FIVE_HUNDRED = 500; public static final Integer FIVE_HUNDRED = 500;
// 中括号 // 中括号
public static final String SQUARE_BRACKETS = "[]"; public static final String SQUARE_BRACKETS = "[]";
//空格
public static final String ONE_SPACE = " ";
// & // &
public static final String AND = "&"; public static final String AND = "&";
// 空 // 空

Loading…
Cancel
Save