| | |
| | | package org.jeecg.modules.mes.service.impl; |
| | | |
| | | import cn.hutool.core.collection.CollectionUtil; |
| | | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import org.jeecg.common.constant.CommonConstant; |
| | | import org.jeecg.common.exception.JeecgBootException; |
| | | import org.jeecg.modules.mes.entity.MesProductionOrder; |
| | | import org.jeecg.modules.mes.mapper.MesProductionOrderMapper; |
| | | import org.jeecg.modules.mes.service.IMesProductionOrderService; |
| | | import org.jeecg.modules.sap.dto.ProductionOrderDTO; |
| | | import org.jeecg.modules.sap.request.ProductionOrderSyncRequest; |
| | | import org.jeecg.modules.sap.service.ProductionOrderSync; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.beans.factory.annotation.Value; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | |
| | | /** |
| | | * @Description: SAP生产订单 |
| | | * @Author: jeecg-boot |
| | | * @Date: 2025-07-04 |
| | | * @Date: 2025-07-04 |
| | | * @Version: V1.0 |
| | | */ |
| | | @Service |
| | | public class MesProductionOrderServiceImpl extends ServiceImpl<MesProductionOrderMapper, MesProductionOrder> implements IMesProductionOrderService { |
| | | //工厂编码(新火炬 2301) |
| | | @Value("${xhj.factoryCode:2301}") |
| | | private String FACTORY_CODE; |
| | | |
| | | @Autowired |
| | | private ProductionOrderSync productionOrderSync; |
| | | |
| | | @Override |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public Map<String, MesProductionOrder> saveOrUpdateProductionOrder(List<ProductionOrderDTO> productionOrderDTOList) { |
| | | Map<String, MesProductionOrder> resultMap = new HashMap<>(); |
| | | for (ProductionOrderDTO productionOrderDTO : productionOrderDTOList) { |
| | | MesProductionOrder updated = getByOrderCode(productionOrderDTO.getAUFNR()); |
| | | if (updated == null) { |
| | | updated = new MesProductionOrder(productionOrderDTO); |
| | | resultMap.put(updated.getOrderCode(), updated); |
| | | this.getBaseMapper().insert(updated); |
| | | } else { |
| | | updated.updateEntity(productionOrderDTO); |
| | | resultMap.put(updated.getOrderCode(), updated); |
| | | this.getBaseMapper().updateById(updated); |
| | | } |
| | | } |
| | | return resultMap; |
| | | } |
| | | |
| | | @Override |
| | | public MesProductionOrder getByOrderCode(String orderCode) { |
| | | LambdaQueryWrapper<MesProductionOrder> queryWrapper = new LambdaQueryWrapper<>(); |
| | | queryWrapper.eq(MesProductionOrder::getOrderCode, orderCode); |
| | | queryWrapper.eq(MesProductionOrder::getDelFlag, CommonConstant.DEL_FLAG_0); |
| | | List<MesProductionOrder> list = super.list(queryWrapper); |
| | | if (CollectionUtil.isNotEmpty(list)) { |
| | | return list.get(0); |
| | | } |
| | | return null; |
| | | } |
| | | |
| | | @Override |
| | | public String getLastSyncCreateDate() { |
| | | String lastSyncDate = this.getBaseMapper().getLastSyncCreateDate(); |
| | | if (lastSyncDate == null) { |
| | | return null; |
| | | } |
| | | return lastSyncDate.replaceAll("-", ""); |
| | | } |
| | | |
| | | @Override |
| | | public String getLastSyncUpdateDate() { |
| | | String lastSyncDate = this.getBaseMapper().getLastSyncUpdateDate(); |
| | | if (lastSyncDate == null) { |
| | | return null; |
| | | } |
| | | return lastSyncDate.replaceAll("-", ""); |
| | | } |
| | | |
| | | @Override |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public boolean syncSapProductionOrder(String id) { |
| | | MesProductionOrder entity = super.getById(id); |
| | | if (entity == null) { |
| | | throw new JeecgBootException("生产订单不存在,请刷新重置!"); |
| | | } |
| | | ProductionOrderSyncRequest request = new ProductionOrderSyncRequest(); |
| | | request.setOrderCode(entity.getOrderCode()); |
| | | request.setFactoryCode(FACTORY_CODE); |
| | | try { |
| | | Map<String, Object> resultMap = productionOrderSync.syncProductionOrder(request); |
| | | if (resultMap == null) { |
| | | throw new JeecgBootException("响应结果为空!"); |
| | | } |
| | | if (!CommonConstant.SAP_SUCCESS_CODE.equals(resultMap.get("ztype"))) { |
| | | throw new JeecgBootException(resultMap.get("zmess").toString()); |
| | | } |
| | | //调用成功,获取返回数据 |
| | | Object result = resultMap.get("result"); |
| | | boolean b = result instanceof List; |
| | | if (!b) { |
| | | throw new JeecgBootException("返回结果格式错误!"); |
| | | } |
| | | List<ProductionOrderDTO> productionOrderDTOList = (List<ProductionOrderDTO>) result; |
| | | if (CollectionUtil.isEmpty(productionOrderDTOList)) { |
| | | throw new JeecgBootException("SAP未查询到生成订单!"); |
| | | } |
| | | ProductionOrderDTO dto = productionOrderDTOList.get(0); |
| | | entity.updateEntity(dto); |
| | | super.updateById(entity); |
| | | } catch (Exception e) { |
| | | throw new JeecgBootException("请求SAP失败:" + e.getMessage()); |
| | | } |
| | | return true; |
| | | } |
| | | } |