|  |  |  | 
|---|
|  |  |  | package com.zy.asrs.controller; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson.JSON; | 
|---|
|  |  |  | import com.alibaba.fastjson.JSONObject; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
|---|
|  |  |  | import com.core.annotations.ManagerAuth; | 
|---|
|  |  |  | import com.core.common.BaseRes; | 
|---|
|  |  |  | import com.core.common.Cools; | 
|---|
|  |  |  | import com.core.common.R; | 
|---|
|  |  |  | import com.core.exception.CoolException; | 
|---|
|  |  |  | import com.zy.asrs.entity.*; | 
|---|
|  |  |  | import com.zy.asrs.entity.param.CombParam; | 
|---|
|  |  |  | import com.zy.asrs.entity.param.ForwardAGVTaskParam; | 
|---|
|  |  |  | import com.zy.asrs.entity.param.GDYKConfirmGoodsParam; | 
|---|
|  |  |  | import com.zy.asrs.entity.param.MobileAdjustParam; | 
|---|
|  |  |  | import com.zy.asrs.entity.result.MobileAdjustResult; | 
|---|
|  |  |  | import com.zy.asrs.service.*; | 
|---|
|  |  |  | import com.zy.common.model.MobileLocDetlVo; | 
|---|
|  |  |  | import com.zy.common.model.WrkDto; | 
|---|
|  |  |  | import com.zy.common.service.CommonService; | 
|---|
|  |  |  | import com.zy.common.utils.HttpHandler; | 
|---|
|  |  |  | import com.zy.common.web.BaseController; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RequestBody; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RequestMapping; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RequestParam; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RestController; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.text.DecimalFormat; | 
|---|
|  |  |  | import java.text.SimpleDateFormat; | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 移动端接口控制器 | 
|---|
|  |  |  | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @RestController | 
|---|
|  |  |  | @RequestMapping("mobile") | 
|---|
|  |  |  | public class MobileController extends BaseController  { | 
|---|
|  |  |  | @Slf4j | 
|---|
|  |  |  | public class MobileController extends BaseController { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private MobileService mobileService; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private LocDetlService locDetlService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderService orderService; | 
|---|
|  |  |  | private OrderPakoutService orderPakoutService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderPakinService orderPakinService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderDetlPakoutService orderDetlPakoutService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private OrderDetlPakinService orderDetlPakinService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private DocTypeService docTypeService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkMastService wrkMastService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkDetlService wrkDetlService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasDevpService basDevpService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkDetlLogService wrkDetlLogService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private CommonService commonService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 根据单号检索单据数据 | 
|---|
|  |  |  | * http://localhost:8081/jkwms/mobile/order/serach/orderNo/auth?orderNo=123123 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @RequestMapping("/order/search/orderNo/auth") | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/agv/start") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R orderSearchByBarcode(@RequestParam String orderNo){ | 
|---|
|  |  |  | Order order = orderService.selectByNo(orderNo); | 
|---|
|  |  |  | if (order == null) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | public R pdaAgvStart(@RequestBody Map<String, Object> map) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (Cools.isEmpty(map.get("sta"))) { | 
|---|
|  |  |  | return R.parse("暂存位不能为空"); | 
|---|
|  |  |  | } else if (Cools.isEmpty(map.get("inSta"))) { | 
|---|
|  |  |  | return R.parse("入库站点不能为空"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | DocType docType = docTypeService.selectById(order.getDocType()); | 
|---|
|  |  |  | if (docType.getPakin() == null || docType.getPakin() != 1) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (order.getSettle() > 2) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<OrderDetl> orderDetls = orderService.selectWorkingDetls(order.getId()); | 
|---|
|  |  |  | if (Cools.isEmpty(orderDetls)) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok().add(orderDetls); | 
|---|
|  |  |  | String sta = (String) map.get("sta"); // 暂存位 | 
|---|
|  |  |  | String inSta = String.valueOf(map.get("inSta")); // 入库站点 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return mobileService.inLocCallAgv(sta, inSta); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/agv/unbind") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R pdaAgvUnbind(@RequestBody Map<String, Object> map) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String site = (String) map.get("site"); // 暂存位 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (Cools.isEmpty(site)) { | 
|---|
|  |  |  | return R.parse("暂存位不能为空"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return mobileService.unbind(site); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private void getAgvTaskParam(ForwardAGVTaskParam agvTaskCreateParam, String agv, String sta) { | 
|---|
|  |  |  | List<ForwardAGVTaskParam.PositionCodePaths> agvTaskParamList = Arrays.asList( | 
|---|
|  |  |  | //起始位 | 
|---|
|  |  |  | new ForwardAGVTaskParam.PositionCodePaths(agv, "05"), | 
|---|
|  |  |  | //目标位 | 
|---|
|  |  |  | new ForwardAGVTaskParam.PositionCodePaths(sta, "05") | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | Date date = new Date(); | 
|---|
|  |  |  | DecimalFormat df = new DecimalFormat("0000"); | 
|---|
|  |  |  | String wrkNo = "Crn" + date.getTime() / 1000; | 
|---|
|  |  |  | agvTaskCreateParam.setReqCode(wrkNo); | 
|---|
|  |  |  | agvTaskCreateParam.setReqTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date())); | 
|---|
|  |  |  | agvTaskCreateParam.setTaskTyp("GT1"); | 
|---|
|  |  |  | agvTaskCreateParam.setCtnrCode("00000000"); | 
|---|
|  |  |  | agvTaskCreateParam.setPositionCodePath(agvTaskParamList); | 
|---|
|  |  |  | agvTaskCreateParam.setCtnrTyp("1"); | 
|---|
|  |  |  | agvTaskCreateParam.setTaskCode(wrkNo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private String forwardAGVHttpRequest(Object requestParam, String url, String path) { | 
|---|
|  |  |  | String response = ""; | 
|---|
|  |  |  | String success = "error"; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | response = new HttpHandler.Builder() | 
|---|
|  |  |  | .setUri(url) | 
|---|
|  |  |  | //                    .setHttps(true) | 
|---|
|  |  |  | .setPath(path) | 
|---|
|  |  |  | .setJson(JSONObject.toJSONString(requestParam)) | 
|---|
|  |  |  | .build() | 
|---|
|  |  |  | .doPost(); | 
|---|
|  |  |  | JSONObject jsonObject = JSON.parseObject(response); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String message = jsonObject.get("code").toString(); | 
|---|
|  |  |  | if (("0").equals(message) || ("请求编号已存在").contains(message)) { | 
|---|
|  |  |  | success = "SUCCESS"; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | success = message; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.info("转发agv任务:请求体:" + JSONObject.toJSONString(requestParam) + ",返回值:" + jsonObject); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return success; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/select/workDetl/barcode") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R selectWorkDetlBarcode(@RequestBody Map<String, Object> map) { | 
|---|
|  |  |  | String barcode = map.get("barcode").toString(); | 
|---|
|  |  |  | if (Cools.isEmpty(barcode)) { | 
|---|
|  |  |  | return R.error("条码为空"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>().eq("barcode", barcode)); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)) { | 
|---|
|  |  |  | return R.error("未找到任务"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (wrkMast.getWrkSts() != 14 && wrkMast.getIoType() != 103) { | 
|---|
|  |  |  | return R.error("任务状态有误"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkDetls)) { | 
|---|
|  |  |  | return R.error("工作明细有误"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(wrkDetls); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/leftovers/out") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R leftoversOut(@RequestBody Map<String, Object> map) { | 
|---|
|  |  |  | mobileService.leftoversOut(map, getUserId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/order/search/orderNo/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R orderSearchByBarcode(@RequestParam String orderNo) { | 
|---|
|  |  |  | if (Cools.isEmpty(orderNo)) { | 
|---|
|  |  |  | orderNo = null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<OrderPakin> orders = orderPakinService.selectorderNoL(orderNo); | 
|---|
|  |  |  | if (Cools.isEmpty(orders)) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | LinkedList<CombParam> combParams = new LinkedList<>(); | 
|---|
|  |  |  | if (!Cools.isEmpty(orders)) { | 
|---|
|  |  |  | for (OrderPakin order : orders) { | 
|---|
|  |  |  | CombParam combParam = new CombParam(); | 
|---|
|  |  |  | if (order == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | DocType docType = docTypeService.selectById(order.getDocType()); | 
|---|
|  |  |  | if (docType.getPakin() == null || docType.getPakin() != 1) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (order.getSettle() > 2) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<OrderDetlPakin> orderDetlPakouts = orderPakinService.selectWorkingDetls(order.getId()); | 
|---|
|  |  |  | if (!Cools.isEmpty(orderDetlPakouts)) { | 
|---|
|  |  |  | LinkedList<CombParam.CombMat> combMats = new LinkedList<>(); | 
|---|
|  |  |  | for (OrderDetlPakin orderDetlPakout : orderDetlPakouts) { | 
|---|
|  |  |  | CombParam.CombMat combMat = new CombParam.CombMat(); | 
|---|
|  |  |  | combMat.setMatnr(orderDetlPakout.getMatnr()); | 
|---|
|  |  |  | combMat.setBatch(orderDetlPakout.getBatch()); | 
|---|
|  |  |  | combMat.setAnfme(orderDetlPakout.getAnfme() - orderDetlPakout.getWorkQty()); | 
|---|
|  |  |  | combMat.setMaktx(orderDetlPakout.getMaktx()); | 
|---|
|  |  |  | combMat.setSpecs(orderDetlPakout.getSpecs()); | 
|---|
|  |  |  | combMats.add(combMat); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | combParam.setCombMats(combMats); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | combParam.setOrderNo(order.getOrderNo()); | 
|---|
|  |  |  | combParams.add(combParam); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok().add(combParams); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/comb/auth") | 
|---|
|  |  |  | @ManagerAuth(memo = "组托") | 
|---|
|  |  |  | public R comb(@RequestBody CombParam combParam){ | 
|---|
|  |  |  | mobileService.comb(combParam, getUserId()); | 
|---|
|  |  |  | return R.ok("组托成功"); | 
|---|
|  |  |  | public R comb(@RequestBody CombParam combParam) { | 
|---|
|  |  |  | log.info("组托:" + JSONObject.toJSONString(combParam)); | 
|---|
|  |  |  | if (Cools.isEmpty(combParam.getBarcode(), combParam.getCombMats())) { | 
|---|
|  |  |  | throw new CoolException(BaseRes.PARAM); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>() | 
|---|
|  |  |  | .eq("barcode", combParam.getBarcode()) | 
|---|
|  |  |  | .eq("io_type", 104) | 
|---|
|  |  |  | .in("wrk_sts", 14, 105)); | 
|---|
|  |  |  | if (Cools.isEmpty(wrkMast)) { | 
|---|
|  |  |  | mobileService.comb(combParam, getUserId()); | 
|---|
|  |  |  | return R.ok("组托成功"); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | mobileService.mergeComb(combParam, getUserId()); | 
|---|
|  |  |  | return R.ok("并板成功"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 出库 --------------------------------------------------------------------------------------------------- | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/pakout/query/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | @Deprecated | 
|---|
|  |  |  | public R pakoutQuery(@RequestParam(required = false) String barcode, | 
|---|
|  |  |  | @RequestParam(required = false) Integer staNo, | 
|---|
|  |  |  | @RequestParam(required = false) String matnr) { | 
|---|
|  |  |  | if (Cools.isEmpty(barcode) && Cools.isEmpty(matnr)) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!Cools.isEmpty(barcode)) { | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectList(new EntityWrapper<WrkDetl>().eq("zpallet", barcode)); | 
|---|
|  |  |  | return R.ok().add(wrkDetls); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!Cools.isEmpty(matnr)) { | 
|---|
|  |  |  | if (!Cools.isEmpty(staNo)) { | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectPakoutQuery(staNo, matnr); | 
|---|
|  |  |  | return R.ok().add(wrkDetls); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 出库确认 - 扫托盘码 | 
|---|
|  |  |  | * 1.全板 返回 101 | 
|---|
|  |  |  | * 2.拣料 返回 103 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @RequestMapping("/pakout/confirm/barcode/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R pakoutQueryByBarcode(@RequestParam(required = false) String barcode) { | 
|---|
|  |  |  | if (Cools.isEmpty(barcode)) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectByBarcode(barcode); | 
|---|
|  |  |  | if (wrkMast != null) { | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); | 
|---|
|  |  |  | // 去除已出库确认的明细 | 
|---|
|  |  |  | wrkDetls.removeIf(wrkDetl -> wrkDetl.getInspect() != null && wrkDetl.getInspect() != 0); | 
|---|
|  |  |  | return R.ok().add(Cools.add("wrkNo", wrkMast.getWrkNo()).add("ioType", wrkMast.getIoType()).add("list", wrkDetls)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 出库确认 - 扫货物  广德宜科版 | 
|---|
|  |  |  | * 1.全板 返回 101 | 
|---|
|  |  |  | * 2.拣料 返回 103 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @RequestMapping("/pakout/confirm/goods/auth")       //待完善  原因(客户未给出详细信息) | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R pakoutQueryByGoods(@RequestBody GDYKConfirmGoodsParam combParam) { | 
|---|
|  |  |  | if (Cools.isEmpty(combParam)) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        List<Order> orders = orderService.selectorderNoL(batch); | 
|---|
|  |  |  | OrderDetlPakout orderDetlPakout = orderDetlPakoutService.selectOne(new EntityWrapper<OrderDetlPakout>().eq("matnr", combParam.getMatnr()).eq("batch", combParam.getBatch()).eq("order_no", combParam.getOrderNo())); | 
|---|
|  |  |  | if (Cools.isEmpty(orderDetlPakout)) { | 
|---|
|  |  |  | return R.error("未查到数据"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!orderDetlPakout.getQty$().equals("已完成")) { | 
|---|
|  |  |  | return R.error("任务未完成"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //复核数 | 
|---|
|  |  |  | orderDetlPakout.setSource(1); | 
|---|
|  |  |  | orderDetlPakoutService.updateById(orderDetlPakout); | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | *  根据库位号查找库存明细 | 
|---|
|  |  |  | * 出库确认 - 拣料出库 - 选择具体条码商品 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @RequestMapping("/locDetl") | 
|---|
|  |  |  | @RequestMapping("/pakout/confirm/pick/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R getLocDetl(@RequestParam(required = false)String locNo, | 
|---|
|  |  |  | @RequestParam(required = false)String matNo){ | 
|---|
|  |  |  | if (!Cools.isEmpty(locNo)) { | 
|---|
|  |  |  | LocMast locMast = locMastService.selectById(locNo); | 
|---|
|  |  |  | if (null == locMast || !"F".equals(locMast.getLocSts())) { | 
|---|
|  |  |  | return R.parse(BaseRes.EMPTY); | 
|---|
|  |  |  | public R pakoutQueryByBarcode(@RequestParam(required = false) Integer wrkNo | 
|---|
|  |  |  | , @RequestParam(required = false) String matnr) { | 
|---|
|  |  |  | if (Cools.isEmpty(wrkNo)) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (Cools.isEmpty(matnr)) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(wrkNo); | 
|---|
|  |  |  | if (wrkMast == null) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | String orderNo = null; | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); | 
|---|
|  |  |  | for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | if (Cools.isEmpty(orderNo)) { | 
|---|
|  |  |  | orderNo = wrkDetl.getOrderNo(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>() | 
|---|
|  |  |  | .eq("loc_no", locNo).orderBy("appe_time", false)); | 
|---|
|  |  |  | List<MobileLocDetlVo> res = new ArrayList<>(); | 
|---|
|  |  |  | locDetls.forEach(locDetl -> { | 
|---|
|  |  |  | MobileLocDetlVo vo = new MobileLocDetlVo(); | 
|---|
|  |  |  | vo.setLocNo(locDetl.getLocNo()); | 
|---|
|  |  |  | vo.setMatnr(locDetl.getMatnr()); | 
|---|
|  |  |  | vo.setMaktx(locDetl.getMaktx()); | 
|---|
|  |  |  | vo.setCount(locDetl.getAnfme()); | 
|---|
|  |  |  | res.add(vo); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | return R.ok().add(res); | 
|---|
|  |  |  | if ((wrkDetl.getMatnr() + "-" + wrkDetl.getBatch()).equals(matnr)) { | 
|---|
|  |  |  | return R.ok().add(wrkDetl); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (!Cools.isEmpty(matNo)) { | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>() | 
|---|
|  |  |  | .eq("matnr", matNo).orderBy("appe_time", false)); | 
|---|
|  |  |  | List<MobileLocDetlVo> res = new ArrayList<>(); | 
|---|
|  |  |  | locDetls.forEach(locDetl -> { | 
|---|
|  |  |  | MobileLocDetlVo vo = new MobileLocDetlVo(); | 
|---|
|  |  |  | vo.setLocNo(locDetl.getLocNo()); | 
|---|
|  |  |  | vo.setMatnr(locDetl.getMatnr()); | 
|---|
|  |  |  | vo.setMaktx(locDetl.getMaktx()); | 
|---|
|  |  |  | vo.setCount(locDetl.getAnfme()); | 
|---|
|  |  |  | res.add(vo); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | return R.ok().add(res); | 
|---|
|  |  |  | // 替换 明细 | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", wrkMast.getSourceLocNo())); | 
|---|
|  |  |  | for (LocDetl locDetl : locDetls) { | 
|---|
|  |  |  | if ((locDetl.getMatnr() + "-" + locDetl.getBatch()).equals(matnr)) { | 
|---|
|  |  |  | WrkDetl wrkDetl = new WrkDetl(); | 
|---|
|  |  |  | wrkDetl.sync(locDetl); | 
|---|
|  |  |  | wrkDetl.setOrderNo(orderNo); | 
|---|
|  |  |  | wrkDetl.setIoTime(wrkMast.getIoTime()); | 
|---|
|  |  |  | wrkDetl.setWrkNo(wrkNo); | 
|---|
|  |  |  | return R.ok().add(wrkDetl); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.parse(BaseRes.PARAM); | 
|---|
|  |  |  | return R.error("系统错误,条码不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/pakout/confirm/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | @Transactional | 
|---|
|  |  |  | public R pakoutConfirm(@RequestBody List<WrkDetl> list) { | 
|---|
|  |  |  | if (Cools.isEmpty(list)) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Set<Integer> wrkNos = new HashSet<>(); | 
|---|
|  |  |  | List<WrkDto> dtos = new ArrayList<>(); | 
|---|
|  |  |  | for (WrkDetl wrkDetl : list) { | 
|---|
|  |  |  | if (wrkNos.contains(wrkDetl.getWrkNo())) { | 
|---|
|  |  |  | for (WrkDto dto : dtos) { | 
|---|
|  |  |  | if (dto.getWrkNo().equals(wrkDetl.getWrkNo())) { | 
|---|
|  |  |  | dto.getWrkDetls().add(wrkDetl); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | wrkNos.add(wrkDetl.getWrkNo()); | 
|---|
|  |  |  | dtos.add(new WrkDto(wrkDetl.getWrkNo(), wrkDetl)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (WrkDto dto : dtos) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(dto.getWrkNo()); | 
|---|
|  |  |  | if (wrkMast != null) { | 
|---|
|  |  |  | // 101 | 
|---|
|  |  |  | if (wrkMast.getIoType() == 101) { | 
|---|
|  |  |  | for (WrkDetl wrkDetl : dto.getWrkDetls()) { | 
|---|
|  |  |  | wrkDetlService.updateInspect(wrkDetl.getWrkNo(), wrkDetl.getMatnr(), wrkDetl.getBatch()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 103 | 
|---|
|  |  |  | if (wrkMast.getIoType() == 103) { | 
|---|
|  |  |  | if (!wrkDetlService.delete(new EntityWrapper<WrkDetl>().eq("wrk_no", wrkMast.getWrkNo()))) { | 
|---|
|  |  |  | throw new CoolException("拣料出库确认失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (WrkDetl wrkDetl : dto.getWrkDetls()) { | 
|---|
|  |  |  | wrkDetl.setInspect(1); | 
|---|
|  |  |  | if (!wrkDetlService.insert(wrkDetl)) { | 
|---|
|  |  |  | throw new CoolException("拣料出库确认失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (Integer wrkNo : wrkNos) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(wrkNo); | 
|---|
|  |  |  | if (wrkMast.getWrkSts() == 14 && (Cools.isEmpty(wrkMast.getInvWh()) || wrkMast.getInvWh().equals("N"))) { | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkNo); | 
|---|
|  |  |  | boolean complete = true; | 
|---|
|  |  |  | for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | if (wrkDetl.getInspect() == null || wrkDetl.getInspect() == 0) { | 
|---|
|  |  |  | complete = false; | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (complete) { | 
|---|
|  |  |  | wrkMast.setInvWh("Y"); | 
|---|
|  |  |  | wrkMast.setModiTime(new Date()); | 
|---|
|  |  |  | if (!wrkMastService.updateById(wrkMast)) { | 
|---|
|  |  |  | throw new CoolException("修改工作档" + wrkNo + "失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok("完成确认"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 盘点 ---------------------------------------------------------------------------------------------------- | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/checkDetl/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R getCheckDetl(@RequestParam(required = false) Integer staNo) { | 
|---|
|  |  |  | if (null == staNo || staNo == 0) { | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | BasDevp basDevp = basDevpService.selectById(staNo); | 
|---|
|  |  |  | if (null != basDevp && basDevp.getWrkNo() != null) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(basDevp.getWrkNo()); | 
|---|
|  |  |  | if (wrkMast != null && wrkMast.getIoType() == 107) { | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); | 
|---|
|  |  |  | if (!Cools.isEmpty(wrkDetls)) { | 
|---|
|  |  |  | MobileAdjustResult result = new MobileAdjustResult(); | 
|---|
|  |  |  | result.setStaNo(staNo); | 
|---|
|  |  |  | result.setWrkNo(wrkMast.getWrkNo()); | 
|---|
|  |  |  | result.setWrkDetls(wrkDetls); | 
|---|
|  |  |  | return R.ok().add(result); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/adjust/auth") | 
|---|
|  |  |  | @ManagerAuth(memo = "盘点") | 
|---|
|  |  |  | public R adjust(@RequestBody MobileAdjustParam combParam) { | 
|---|
|  |  |  | mobileService.adjust(combParam, getUserId()); | 
|---|
|  |  |  | return R.ok("盘点成功"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/order/out/pakout/auth") | 
|---|
|  |  |  | @ManagerAuth(memo = "订单出库") | 
|---|
|  |  |  | public synchronized R pakoutByOrder(@RequestBody JSONObject param) { | 
|---|
|  |  |  | if (!param.containsKey("staNo") || !param.containsKey("orderNo")) { | 
|---|
|  |  |  | return R.parse(BaseRes.PARAM); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | mobileService.pakoutByOrder(param, getUserId()); | 
|---|
|  |  |  | return R.ok("出库成功"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping("/ddd/ddd") | 
|---|
|  |  |  | @ManagerAuth() | 
|---|
|  |  |  | public R ddd() { | 
|---|
|  |  |  | int w = 99999; | 
|---|
|  |  |  | for (int i = 17; i <= 37; i++) { | 
|---|
|  |  |  | for (int j = 8; j <= 14; j++) { | 
|---|
|  |  |  | LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", i).eq("bay1", j).eq("lev1", 1)); | 
|---|
|  |  |  | LocMast locMast2 = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", i).eq("bay1", j).eq("lev1", 2)); | 
|---|
|  |  |  | LocMast locMast3 = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", i).eq("bay1", j).eq("lev1", 3)); | 
|---|
|  |  |  | //            LocMast locMast4 = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", 26).eq("bay1", i).eq("lev1", 1)); | 
|---|
|  |  |  | if (locMast.getGro1() == 999) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //            locMast.setGro1(w); | 
|---|
|  |  |  | //            locMast.setGro1(locMast.getGro1()+1000); | 
|---|
|  |  |  | locMast2.setGro1(locMast.getGro1() + 1000); | 
|---|
|  |  |  | locMast3.setGro1(locMast.getGro1() + 2000); | 
|---|
|  |  |  | //            locMast4.setGro1(w); | 
|---|
|  |  |  | //            locMastService.updateById(locMast); | 
|---|
|  |  |  | locMastService.updateById(locMast2); | 
|---|
|  |  |  | locMastService.updateById(locMast3); | 
|---|
|  |  |  | //            locMastService.updateById(locMast4); | 
|---|
|  |  |  | w++; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        for (int i = 17; i <=37; i++) { | 
|---|
|  |  |  | //            LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", i).eq("bay1", 3).eq("lev1", 1)); | 
|---|
|  |  |  | //            LocMast locMast2 = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", i).eq("bay1", 8).eq("lev1", 1)); | 
|---|
|  |  |  | //            LocMast locMast3 = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", i).eq("bay1", 13).eq("lev1", 1)); | 
|---|
|  |  |  | ////            LocMast locMast4 = locMastService.selectOne(new EntityWrapper<LocMast>().eq("row1", i).eq("bay1", 12).eq("lev1", 1)); | 
|---|
|  |  |  | //            if (!Cools.isEmpty(locMast)) { | 
|---|
|  |  |  | //                locMast.setGro1(w); | 
|---|
|  |  |  | //                locMastService.updateById(locMast); | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //            locMast2.setGro1(w); | 
|---|
|  |  |  | //            locMast3.setGro1(w); | 
|---|
|  |  |  | ////            locMast4.setGro1(w); | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //            locMastService.updateById(locMast2); | 
|---|
|  |  |  | //            locMastService.updateById(locMast3); | 
|---|
|  |  |  | ////            locMastService.updateById(locMast4); | 
|---|
|  |  |  | ////            w++; | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|