|  |  |  | 
|---|
|  |  |  | </dependencies> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <build> | 
|---|
|  |  |  | <finalName>phpswms</finalName> | 
|---|
|  |  |  | <finalName>pswms</finalName> | 
|---|
|  |  |  | <plugins> | 
|---|
|  |  |  | <plugin> | 
|---|
|  |  |  | <groupId>org.springframework.boot</groupId> | 
|---|
|  |  |  | 
|---|
|  |  |  | Set<String> exist = new HashSet<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (OrderDetl orderDetl : orderDetls) { | 
|---|
|  |  |  | double issued = Optional.of(orderDetl.getAnfme() - orderDetl.getQty()).orElse(0.0D); | 
|---|
|  |  |  | double issued = Optional.of(orderDetl.getAnfme() - orderDetl.getWorkQty()).orElse(0.0D); | 
|---|
|  |  |  | if (issued <= 0.0D) { continue; } | 
|---|
|  |  |  | List<LocDetl> locDetls = locDetlService.queryStock(orderDetl.getMatnr(), orderDetl.getBatch(), null, exist); | 
|---|
|  |  |  | for (LocDetl locDetl : locDetls) { | 
|---|
|  |  |  | 
|---|
|  |  |  | assert one != null; | 
|---|
|  |  |  | one.setAnfme(one.getAnfme() + detlDto.getAnfme()); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | detlDtos.add(detlDto); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (DetlDto detlDto : detlDtos) { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | orderDetl.setQty(orderDetl.getQty() + jsonOrderDetl.getAnfme()); | 
|---|
|  |  |  | orderDetl.setWorkQty(orderDetl.getWorkQty() + jsonOrderDetl.getAnfme()); | 
|---|
|  |  |  | orderDetl.setUpdateTime(date); | 
|---|
|  |  |  | orderDetlService.updateById(orderDetl); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | if (Cools.isEmpty(orderDetl)) { | 
|---|
|  |  |  | return R.error("单据明细有误,请检查"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (jsonOrderDetl.getAnfme() > (orderDetl.getAnfme() - orderDetl.getQty())) { | 
|---|
|  |  |  | if (jsonOrderDetl.getAnfme() > (orderDetl.getAnfme() - orderDetl.getWorkQty())) { | 
|---|
|  |  |  | return R.error("出库数量大于单据可出数量"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ManLocDetl manLocDetl = manLocDetlService.selectOne(new EntityWrapper<ManLocDetl>() | 
|---|
|  |  |  | 
|---|
|  |  |  | .eq("matnr", orderDetl.getMatnr())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | orderDetl.setQty(orderDetl.getQty() + jsonOrderDetl.getAnfme()); | 
|---|
|  |  |  | orderDetl.setWorkQty(orderDetl.getWorkQty() + jsonOrderDetl.getAnfme()); | 
|---|
|  |  |  | orderDetl.setUpdateTime(date); | 
|---|
|  |  |  | orderDetlService.updateById(orderDetl); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | // 订单关联 | 
|---|
|  |  |  | List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); | 
|---|
|  |  |  | for (WrkDetl wrkDetl : wrkDetls) { | 
|---|
|  |  |  | 
|---|
|  |  |  | // 生成新的出库作业 | 
|---|
|  |  |  | //                        stockOutRe(wrkMast, wrkDetls); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //修改订单主表状态,没有作业数量时才可以修改 | 
|---|
|  |  |  | boolean flag = true; | 
|---|
|  |  |  | List<OrderDetl> orderDetls = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no",wrkDetl.getOrderNo())); | 
|---|
|  |  |  | for(OrderDetl orderDetl : orderDetls){ | 
|---|
|  |  |  | if(orderDetl.getWorkQty() > 0){ | 
|---|
|  |  |  | flag = false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(flag){ | 
|---|
|  |  |  | Order order = orderService.selectOne(new EntityWrapper<Order>().eq("order_no",wrkDetl.getOrderNo())); | 
|---|
|  |  |  | if(!Cools.isEmpty(order) && order.getSettle()==2){ | 
|---|
|  |  |  | order.setSettle(1L); | 
|---|
|  |  |  | order.setUpdateBy(userId); | 
|---|
|  |  |  | order.setUpdateTime(now); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(!orderService.update(order,new EntityWrapper<Order>().eq("order_no",wrkDetl.getOrderNo()))){ | 
|---|
|  |  |  | throw new CoolException("修改订单状态失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 取消操作人员记录 | 
|---|
|  |  |  | wrkMast.setManuType("手动取消"); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 获取目标站 | 
|---|
|  |  |  | Wrapper<StaDesc> wrapper = new EntityWrapper<StaDesc>() | 
|---|
|  |  |  | .eq("type_no", wrkMast.getIoType() - 50) | 
|---|
|  |  |  | //速腾特有捡料, 11站是出库站, 然后手动走到15站进行再入库 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .eq("stn_no", 15) // 作业站点 = 拣料出库的目标站 | 
|---|
|  |  |  | .eq("type_no", wrkMast.getIoType()) | 
|---|
|  |  |  | .eq("stn_no", wrkMast.getStaNo()) // 作业站点 = 拣料出库的目标站 | 
|---|
|  |  |  | .eq("crn_no", wrkMast.getCrnNo()); // 堆垛机号 | 
|---|
|  |  |  | StaDesc staDesc = staDescService.selectOne(wrapper); | 
|---|
|  |  |  | if (Cools.isEmpty(staDesc)) { | 
|---|
|  |  |  | 
|---|
|  |  |  | enabled: false | 
|---|
|  |  |  | datasource: | 
|---|
|  |  |  | driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriver | 
|---|
|  |  |  | #    url: jdbc:sqlserver://10.10.10.100:1433;databasename=stasrs | 
|---|
|  |  |  | url: jdbc:sqlserver://192.168.4.15:1433;databasename=phpsasrs | 
|---|
|  |  |  | username: sa | 
|---|
|  |  |  | password: sa@123 | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <update id="increase"> | 
|---|
|  |  |  | update man_order_detl | 
|---|
|  |  |  | set qty = qty + #{qty} | 
|---|
|  |  |  | set work_qty = work_qty + #{qty} | 
|---|
|  |  |  | where 1=1 | 
|---|
|  |  |  | and order_id = #{orderId} | 
|---|
|  |  |  | and matnr = #{matnr} | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <update id="decrease"> | 
|---|
|  |  |  | update man_order_detl | 
|---|
|  |  |  | set qty = qty - #{qty} | 
|---|
|  |  |  | set work_qty = work_qty - #{qty} | 
|---|
|  |  |  | where 1=1 | 
|---|
|  |  |  | and order_no = #{orderNo} | 
|---|
|  |  |  | and matnr = #{matnr} | 
|---|
|  |  |  | 
|---|
|  |  |  | var baseUrl = "/phpswms"; | 
|---|
|  |  |  | var baseUrl = "/pswms"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 详情窗口-高度 | 
|---|
|  |  |  | var detailHeight = '80%'; | 
|---|
|  |  |  | 
|---|
|  |  |  | {field: 'maktx', title: '商品名称', width: 160}, | 
|---|
|  |  |  | {field: 'batch', title: '批号'}, | 
|---|
|  |  |  | {field: 'anfme', title: '数量'}, | 
|---|
|  |  |  | // {field: 'workQty', title: '作业数量'}, | 
|---|
|  |  |  | {field: 'workQty', title: '作业数量'}, | 
|---|
|  |  |  | {field: 'qty', title: '完成数量', style: 'font-weight: bold'}, | 
|---|
|  |  |  | // {field: 'unit', title: '单位'}, | 
|---|
|  |  |  | // { | 
|---|
|  |  |  | 
|---|
|  |  |  | ,{field: 'batch', align: 'center',title: '序列码'} | 
|---|
|  |  |  | ,{field: 'specs', align: 'center',title: '规格'} | 
|---|
|  |  |  | // ,{field: 'anfme', align: 'center',title: '数量'} | 
|---|
|  |  |  | // ,{field: 'qty', align: 'center',title: '作业数量', style: 'font-weight: bold'} | 
|---|
|  |  |  | ,{field: 'anfme', align: 'center',title: '总数量', style: 'font-weight: bold'} | 
|---|
|  |  |  | ,{field: 'workQty', align: 'center',title: '作业数量', style: 'font-weight: bold'} | 
|---|
|  |  |  | // ,{field: 'name', align: 'center',title: '名称'} | 
|---|
|  |  |  | // ,{field: 'model', align: 'center',title: '型号'} | 
|---|
|  |  |  | ,{field: 'unit', align: 'center',title: '单位', hide: true} | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!-- 行工具栏 --> | 
|---|
|  |  |  | <script type="text/html" id="operate"> | 
|---|
|  |  |  | {{#if (d.anfme > d.qty){ }} | 
|---|
|  |  |  | {{#if (d.anfme > d.workQty){ }} | 
|---|
|  |  |  | <a class="layui-btn layui-btn-xs layui-btn-danger btn-pakoutPreview" lay-event="pakoutPreview"><i class="layui-icon layui-icon-prev-circle"></i>出库</a> | 
|---|
|  |  |  | {{# } }} | 
|---|
|  |  |  | </script> | 
|---|