| | |
| | | package com.zy.asrs.service.impl; |
| | | |
| | | import com.alibaba.fastjson.JSON; |
| | | import com.alibaba.fastjson.JSONArray; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.baomidou.mybatisplus.mapper.EntityWrapper; |
| | |
| | | import com.zy.asrs.entity.*; |
| | | import com.zy.asrs.entity.param.*; |
| | | import com.zy.asrs.entity.result.InOutCountDto; |
| | | import com.zy.asrs.entity.result.OpenOrderCompeteResult; |
| | | import com.zy.asrs.entity.result.StockVo; |
| | | import com.zy.asrs.mapper.ReportQueryMapper; |
| | | import com.zy.asrs.mapper.TagMapper; |
| | | import com.zy.asrs.service.*; |
| | | import com.zy.asrs.utils.MatUtils; |
| | | import com.zy.asrs.utils.Utils; |
| | | import com.zy.common.model.DetlDto; |
| | | import com.zy.common.utils.HttpHandler; |
| | | import com.zy.common.utils.NodeUtils; |
| | | import com.zy.common.utils.Synchro; |
| | | import com.zy.system.entity.User; |
| | | import com.zy.system.service.UserService; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | 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.text.ParseException; |
| | | import java.util.ArrayList; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | import java.util.concurrent.TimeUnit; |
| | | |
| | | /** |
| | | * Created by vincent on 2022/4/9 |
| | | */ |
| | | @Slf4j |
| | | @Service |
| | | @Service("OpenService") |
| | | public class OpenServiceImpl implements OpenService { |
| | | |
| | | @Value("${u8.url}") |
| | | private String url; |
| | | |
| | | @Value("${u8.path}") |
| | | private String orderReportPath; |
| | | |
| | | |
| | | @Autowired |
| | | private OrderService orderService; |
| | | @Autowired |
| | | private OrderLogService orderLogService; |
| | | @Autowired |
| | | private OrderDetlService orderDetlService; |
| | | @Autowired |
| | |
| | | private ManPakOutService manPakOutService; |
| | | @Autowired |
| | | private LocOwnerService locOwnerService; |
| | | @Autowired |
| | | private ReportQueryMapper reportQueryMapper; |
| | | @Autowired |
| | | private UserService userService; |
| | | @Autowired |
| | | private PlaService plaService; |
| | | @Autowired |
| | | private ApiLogService apiLogService; |
| | | |
| | | @Override |
| | | @Transactional |
| | |
| | | throw new CoolException(param.getOrderNo() + "单据已存在,请勿重复提交"); |
| | | } |
| | | |
| | | for (DetlDto detlDto : param.getOrderDetails()){ |
| | | if (Cools.isEmpty(detlDto) || Cools.isEmpty(detlDto.getOwnerName(),detlDto.getPayment())){ |
| | | for (DetlDto detlDto : param.getOrderDetails()) { |
| | | if (Cools.isEmpty(detlDto) || Cools.isEmpty(detlDto.getOwnerName(), detlDto.getPayment())) { |
| | | throw new CoolException(param.getOrderNo() + "缺少货主或货物形态"); |
| | | }else { |
| | | } else { |
| | | LocOwner locOwner = locOwnerService.selectOne(new EntityWrapper<LocOwner>().eq("owner", detlDto.getOwnerName())); |
| | | if (Cools.isEmpty(locOwner)){ |
| | | if (Cools.isEmpty(locOwner)) { |
| | | LocOwner locOwner1 = new LocOwner(); |
| | | locOwner1.setOwner(detlDto.getOwnerName()); |
| | | locOwnerService.insert(locOwner1); |
| | | } |
| | | } |
| | | } |
| | |
| | | List<DetlDto> list = new ArrayList<>(); |
| | | List<DetlDto> orderDetails = param.getOrderDetails(); |
| | | for (DetlDto detail : orderDetails) { |
| | | DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(), detail.getAnfme()); |
| | | DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(), detail.getAnfme(), detail.getOwnerName(), detail.getPayment()); |
| | | if (DetlDto.has(list, dto)) { |
| | | DetlDto detlDto = DetlDto.find(list, dto.getMatnr(), dto.getBatch()); |
| | | assert detlDto != null; |
| | |
| | | orderDetl.setUpdateBy(9527L); |
| | | orderDetl.setUpdateTime(now); |
| | | LocOwner locOwner = locOwnerService.selectOne(new EntityWrapper<LocOwner>().eq("owner", detlDto.getOwnerName())); |
| | | if (Cools.isEmpty(locOwner)){ |
| | | if (Cools.isEmpty(locOwner)) { |
| | | throw new CoolException("生成单据明细失败,请联系管理员"); |
| | | }else { |
| | | } else { |
| | | orderDetl.setOwner(locOwner.getId().intValue()); |
| | | } |
| | | orderDetl.setPayment(detlDto.getPayment()); |
| | |
| | | @Override |
| | | @Transactional |
| | | public void pakoutOrderCreate(OpenOrderPakoutParam param) { |
| | | Order order = orderService.selectByNo(param.getOrderNo()); |
| | | Order order = orderService.selectByNo(param.getCCode()); |
| | | // 如果单据不存在则添加;如果单据存在,作业中无法修改,反之则修改单据 |
| | | if (!Cools.isEmpty(order)) { |
| | | if (order.getSettle() > 1L) { |
| | | throw new CoolException(param.getOrderNo() + "正在出库,无法修改单据"); |
| | | throw new CoolException(param.getCCode() + "正在出库,无法修改单据"); |
| | | } |
| | | orderService.remove(order.getId()); |
| | | } |
| | | DocType docType = docTypeService.selectOrAdd(param.getOrderType(), Boolean.FALSE); |
| | | OrderLog orderLog = orderLogService.selectByNo(param.getCCode()); |
| | | if (!Cools.isEmpty(orderLog)) { |
| | | throw new CoolException(param.getCCode() + "单据已经完成,不需要再传递"); |
| | | } |
| | | |
| | | DocType docType = docTypeService.selectOrAdd(param.getType(), Boolean.FALSE); |
| | | Date now = new Date(); |
| | | |
| | | //查找做单用户 |
| | | User user = userService.selectOne(new EntityWrapper<User>().eq("username", param.getCMaker())); |
| | | if (Cools.isEmpty(user)) { |
| | | throw new CoolException("未查询到该用户"); |
| | | } |
| | | |
| | | // 单据主档 |
| | | order = new Order( |
| | | String.valueOf(snowflakeIdWorker.nextId()), // 编号[非空] |
| | | param.getOrderNo(), // 订单编号 |
| | | param.getCCode(), // 订单编号 |
| | | DateUtils.convert(now), // 单据日期 |
| | | docType.getDocId(), // 单据类型 |
| | | null, // 项目编号 |
| | | 1L, // 项目编号 |
| | | null, // |
| | | null, // 调拨项目编号 |
| | | null, // 初始票据号 |
| | | null, // 票据号 |
| | | param.getCAccount(), // 主体 |
| | | null, // 客户编号 |
| | | null, // 客户 |
| | | param.getCCusName(), // 客户 |
| | | null, // 联系方式 |
| | | null, // 操作人员 |
| | | param.getCMaker(), // 操作人员 |
| | | null, // 合计金额 |
| | | null, // 优惠率 |
| | | null, // 优惠金额 |
| | |
| | | null, // 物流单号 |
| | | 1L, // 订单状态 |
| | | 1, // 状态 |
| | | 9527L, // 添加人员 |
| | | user.getId(), // 添加人员 |
| | | now, // 添加时间 |
| | | 9527L, // 修改人员 |
| | | now, // 修改时间 |
| | |
| | | throw new CoolException("生成单据主档失败,请联系管理员"); |
| | | } |
| | | // 单据明细档 |
| | | List<DetlDto> list = new ArrayList<>(); |
| | | List<DetlDto> orderDetails = param.getOrderDetails(); |
| | | for (DetlDto detail : orderDetails) { |
| | | DetlDto dto = new DetlDto(detail.getMatnr(), detail.getBatch(), detail.getAnfme()); |
| | | if (DetlDto.has(list, dto)) { |
| | | DetlDto detlDto = DetlDto.find(list, dto.getMatnr(), dto.getBatch()); |
| | | assert detlDto != null; |
| | | detlDto.setAnfme(detlDto.getAnfme() + detail.getAnfme()); |
| | | } else { |
| | | list.add(dto); |
| | | } |
| | | dto.setWeight(detail.getWeight()); |
| | | } |
| | | for (DetlDto detlDto : list) { |
| | | Mat mat = matService.selectByMatnr(detlDto.getMatnr()); |
| | | for (OpenOrderPakoutParam.Body body : param.getADDBody()) { |
| | | Mat mat = matService.selectByMatnr(body.getCInvCode()); |
| | | if (Cools.isEmpty(mat)) { |
| | | throw new CoolException(detlDto.getMatnr() + "编号商品检索失败,请先添加商品"); |
| | | throw new CoolException(body.getCInvCode() + "编号商品检索失败,请先添加商品"); |
| | | } |
| | | OrderDetl orderDetl = new OrderDetl(); |
| | | orderDetl.sync(mat); |
| | | orderDetl.setBatch(detlDto.getBatch() == null ? "" : detlDto.getBatch()); |
| | | orderDetl.setAnfme(detlDto.getAnfme()); |
| | | orderDetl.setAnfme(body.getIQuantity()); |
| | | orderDetl.setQty(0.0D); |
| | | orderDetl.setWorkQty(0.0D); |
| | | orderDetl.setStatus(1); |
| | | orderDetl.setOrderId(order.getId()); |
| | | orderDetl.setOrderNo(order.getOrderNo()); |
| | | orderDetl.setCreateBy(9527L); |
| | | orderDetl.setCreateBy(user.getId()); |
| | | orderDetl.setCreateTime(now); |
| | | orderDetl.setUpdateBy(9527L); |
| | | orderDetl.setUpdateBy(user.getId()); |
| | | orderDetl.setUpdateTime(now); |
| | | orderDetl.setStatus(1); |
| | | orderDetl.setQty(0.0D); |
| | | orderDetl.setWeight(detlDto.getWeight()); |
| | | orderDetl.setUuid(String.valueOf(System.currentTimeMillis())); |
| | | if (!orderDetlService.insert(orderDetl)) { |
| | | throw new CoolException("生成单据明细失败,请联系管理员"); |
| | | } |
| | |
| | | @Override |
| | | @Transactional |
| | | public void syncMat(MatSyncParam param) { |
| | | |
| | | if (Cools.isEmpty(param.getMatDetails()) || param.getMatDetails().size() <= 0) { |
| | | throw new CoolException("商品数据为空"); |
| | | } |
| | | |
| | | //删除存货档案 |
| | | if (param.deleteFlag == 1) { |
| | | for (MatSyncParam.MatParam matParam : param.getMatDetails()) { |
| | | matService.delete(new EntityWrapper<Mat>().eq("matnr", matParam.getMatnr())); |
| | | } |
| | | |
| | | return; |
| | | } |
| | | |
| | | for (MatSyncParam.MatParam matParam : param.getMatDetails()) { |
| | |
| | | } |
| | | if (!matService.insert(mat)) { |
| | | throw new CoolException("服务器内部错误,请联系管理员"); |
| | | } else { |
| | | log.info("同步新物料[商品编号:{}]", mat.getMatnr()); |
| | | } |
| | | log.info("同步新物料[商品编号:{}]", mat.getMatnr()); |
| | | } else { |
| | | mat.sync(param); |
| | | //mat.sync(param); |
| | | mat.setMaktx(matParam.getMaktx()); |
| | | if (!matService.update(mat, new EntityWrapper<Mat>().eq("matnr", matParam.getMatnr()))) { |
| | | throw new CoolException("更新已存在商品信息失败,请联系管理员"); |
| | | } |
| | | log.info("同步更新物料[商品编号:{}]", mat.getMatnr()); |
| | | } |
| | | } |
| | | |
| | |
| | | return R.ok().add(top100); |
| | | } |
| | | |
| | | /* |
| | | * 速腾数字孪生调用接口 |
| | | * */ |
| | | @Override |
| | | public DigitalTwin inventoryQuantity() { |
| | | DigitalTwin digitalTwin = new DigitalTwin(); |
| | | LocChartPie locUseRate = reportQueryMapper.getLocUseRate(); |
| | | LocChartPie locUseRateL = reportQueryMapper.getLocUseRateL(); |
| | | LocChartPie locUseRateP = reportQueryMapper.getLocUseRateP(); |
| | | if (locUseRate != null) { |
| | | digitalTwin.setCount(locUseRate.getOqty() + locUseRate.getFqty() + locUseRate.getUqty() + locUseRate.getXqty()); |
| | | digitalTwin.setOqty(locUseRate.getOqty()); |
| | | digitalTwin.setFqty(locUseRate.getFqty()); |
| | | digitalTwin.setUqty(locUseRate.getUqty()); |
| | | digitalTwin.setXqty(locUseRate.getXqty()); |
| | | } |
| | | if (locUseRateL != null) { |
| | | digitalTwin.setCountL(locUseRateL.getOqty() + locUseRateL.getFqty() + locUseRateL.getUqty() + locUseRateL.getXqty()); |
| | | digitalTwin.setOqtyL(locUseRateL.getOqty()); |
| | | digitalTwin.setFqtyL(locUseRateL.getFqty()); |
| | | digitalTwin.setUqtyL(locUseRateL.getUqty()); |
| | | digitalTwin.setXqtyL(locUseRateL.getXqty()); |
| | | } |
| | | if (locUseRateP != null) { |
| | | digitalTwin.setCountP(locUseRateP.getOqty() + locUseRateP.getFqty() + locUseRateP.getUqty() + locUseRateP.getXqty()); |
| | | digitalTwin.setOqtyP(locUseRateP.getOqty()); |
| | | digitalTwin.setFqtyP(locUseRateP.getFqty()); |
| | | digitalTwin.setUqtyP(locUseRateP.getUqty()); |
| | | digitalTwin.setXqtyP(locUseRateP.getXqty()); |
| | | } |
| | | return digitalTwin; |
| | | } |
| | | |
| | | @Override |
| | | public int pakinReportErp(JSONObject json) throws ParseException { |
| | | JSONArray jsonArray = JSONArray.parseArray(json.getJSONArray("pla").toJSONString()); |
| | | |
| | | List<OpenOrderPakoutParam> list = new ArrayList<>(); |
| | | |
| | | for (Object o : jsonArray) { |
| | | JSONObject jsonObject = (JSONObject) o; |
| | | String brand = jsonObject.get("brand").toString(); |
| | | String batch = jsonObject.get("batch").toString(); |
| | | Integer packageNo = Integer.parseInt(jsonObject.get("packageNo").toString()); |
| | | |
| | | Pla pla = plaService.selectByBatchAndPackageNo(batch, packageNo, brand); |
| | | Mat mat = matService.selectByMaktx(pla.getBrand()); |
| | | //当生产单号不一致时,需要新建一个param |
| | | if (list.isEmpty() || (!Cools.isEmpty(pla.getProOrderNo()) && checkOrder(list, pla.getProOrderNo()) == null)) { |
| | | OpenOrderPakoutParam param = new OpenOrderPakoutParam(); |
| | | param.setcMaker(json.get("user").toString()); |
| | | String type = Cools.isEmpty(pla.getProOrderNo()) ? "调拨入库单" : "产成品入库"; |
| | | param.setcCode(Cools.isEmpty(pla.getProOrderNo()) ? (new Date().getTime()) + "" : pla.getProOrderNo()); |
| | | param.setcAccount(pla.getWorkshop()); |
| | | param.setdDate(Utils.getDateStr(new Date())); |
| | | param.setType(type); |
| | | |
| | | List<OpenOrderPakoutParam.Body> bodyList = new ArrayList<>(); |
| | | OpenOrderPakoutParam.Body body = new OpenOrderPakoutParam.Body(); |
| | | body.setcInvCode(mat.getMatnr()); |
| | | body.setiQuantity(pla.getWeightAnfme()); |
| | | body.setcBatch(pla.getBatch()); |
| | | body.setCPackage(pla.getPackageNo()+""); |
| | | body.setCbMemo(pla.getMemo()); |
| | | bodyList.add(body); |
| | | |
| | | param.setaDDBody(bodyList); |
| | | |
| | | list.add(param); |
| | | } else { |
| | | OpenOrderPakoutParam param = checkOrder(list, pla.getProOrderNo()); |
| | | List<OpenOrderPakoutParam.Body> bodyList = param.getADDBody(); |
| | | OpenOrderPakoutParam.Body body = checkOrderDetl(bodyList, mat.getMatnr()); |
| | | //有新的牌号则添加新的orderDetl,否则累加 |
| | | if (body == null) { |
| | | body = new OpenOrderPakoutParam.Body(); |
| | | body.setcInvCode(mat.getMatnr()); |
| | | body.setiQuantity(pla.getWeightAnfme()); |
| | | body.setcBatch(pla.getBatch()); |
| | | body.setCPackage(pla.getPackageNo()+""); |
| | | body.setCbMemo(pla.getMemo()); |
| | | bodyList.add(body); |
| | | } else { |
| | | body.setiQuantity(body.getIQuantity() + pla.getWeightAnfme()); |
| | | body.setcBatch(pla.getBatch()); |
| | | body.setCPackage(pla.getPackageNo()+""); |
| | | } |
| | | } |
| | | } |
| | | |
| | | for (OpenOrderPakoutParam param : list) { |
| | | doHttpRequest(param, "入库单上报", url, orderReportPath, null, "127.0.0.1"); |
| | | |
| | | } |
| | | return 200; |
| | | //return doHttpRequest(list, "入库单上报", url, orderReportPath, null, "127.0.0.1"); |
| | | } |
| | | |
| | | |
| | | |
| | | @Override |
| | | public List<Order> selectOrderInformation(Map<String, String> param) { |
| | | List<Order> list = new ArrayList<>(); |
| | | String name = param.get("name"); |
| | | User user = userService.selectOne(new EntityWrapper<User>().eq("username", name)); |
| | | if (Cools.isEmpty(user)) { |
| | | return list; |
| | | } |
| | | List<Order> orderList = orderService.selectList(new EntityWrapper<Order>().eq("create_by", user.getId())); |
| | | if (Cools.isEmpty(orderList)) { |
| | | return list; |
| | | } |
| | | for (Order order : orderList) { |
| | | if (order.getSettle() == 1 || order.getSettle() == 2) { |
| | | List<OrderDetl> detlList = orderDetlService.selectByOrderId(order.getId()); |
| | | order.setOrderDetls(detlList); |
| | | list.add(order); |
| | | } |
| | | } |
| | | |
| | | return list; |
| | | } |
| | | |
| | | private OpenOrderPakoutParam checkOrder(List<OpenOrderPakoutParam> list, String orderNo) { |
| | | |
| | | for (OpenOrderPakoutParam param : list) { |
| | | |
| | | if (Cools.eq("调拨入库单", param.getType()) && Cools.isEmpty(orderNo)) { |
| | | return param; |
| | | } |
| | | |
| | | //判断是否包含重复的订单号 |
| | | if (Cools.eq(param.getCCode(), orderNo)) { |
| | | return param; |
| | | } |
| | | } |
| | | |
| | | return null; |
| | | |
| | | } |
| | | |
| | | private OpenOrderPakoutParam.Body checkOrderDetl(List<OpenOrderPakoutParam.Body> bodyList, String matnr) { |
| | | |
| | | for (OpenOrderPakoutParam.Body param : bodyList) { |
| | | //判断是否包含重复的订单号 |
| | | if (Cools.eq(param.getCInvCode(), matnr)) { |
| | | return param; |
| | | } |
| | | } |
| | | |
| | | return null; |
| | | |
| | | } |
| | | |
| | | private int doHttpRequest(Object requestParam, String namespace, String url, String path, String appkey, String ip) { |
| | | String response = ""; |
| | | boolean success = false; |
| | | |
| | | try { |
| | | log.info("请求参数:{}", requestParam); |
| | | response = new HttpHandler.Builder() |
| | | .setUri(url) |
| | | .setTimeout(30, TimeUnit.SECONDS) |
| | | .setPath(path) |
| | | .setJson(JSONObject.toJSONString(requestParam)) |
| | | .build() |
| | | .doPost(); |
| | | log.info("入库单上报请求返回报文:{}", response); |
| | | |
| | | JSONObject jsonObject = JSON.parseObject(response); |
| | | if (Cools.isEmpty(jsonObject.get("ErrorCode"))) { |
| | | throw new CoolException(jsonObject.get("ErrorMsg").toString()); |
| | | } |
| | | |
| | | int code = Integer.parseInt(jsonObject.get("ErrorCode").toString()); |
| | | if (code == 0) { |
| | | throw new CoolException(jsonObject.get("ErrorMsg").toString()); |
| | | } |
| | | success = true; |
| | | return code; |
| | | } catch (Exception e) { |
| | | log.error(e.getMessage()); |
| | | throw new CoolException(e.getMessage()); |
| | | } finally { |
| | | apiLogService.save( |
| | | namespace, |
| | | url + path, |
| | | appkey, |
| | | ip, |
| | | JSON.toJSONString(JSONObject.toJSONString(requestParam)), |
| | | response, |
| | | success |
| | | ); |
| | | } |
| | | |
| | | } |
| | | |
| | | |
| | | } |