自动化立体仓库 - WMS系统
1
zhang
9 天以前 570300c26ff3c562c03ac24e4896f72d33fa4369
src/main/java/com/zy/asrs/controller/OpenController.java
@@ -7,8 +7,10 @@
import com.core.common.Cools;
import com.core.common.R;
import com.core.exception.CoolException;
import com.zy.asrs.entity.LocDetl;
import com.zy.asrs.entity.LocMast;
import com.zy.asrs.entity.param.*;
import com.zy.asrs.service.LocDetlService;
import com.zy.asrs.service.LocMastService;
import com.zy.asrs.service.OpenService;
import com.zy.common.web.BaseController;
@@ -23,6 +25,7 @@
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@@ -47,6 +50,9 @@
    @Autowired
    private LocMastService locMastService;
    @Autowired
    private LocDetlService locDetlService;
    @Deprecated
    @PostMapping("/grouping")
@@ -241,6 +247,43 @@
    }
    @Synchronized
    @PostMapping("/stock/used/v3")
    public R getRate2(@RequestHeader(required = false) String appkey,
                      @RequestBody(required = false) LocMast param,
                      HttpServletRequest request) {
        auth(appkey, param, request);
        if (param.getRow1() != null) {
            int i = locMastService.selectCount(new EntityWrapper<LocMast>().in("loc_sts", "O").eq("row1", param.getRow1()));
            int i2 = locMastService.selectCount(new EntityWrapper<LocMast>().eq("row1", param.getRow1()));
            // 在库率=(总数-空库位数)/总数
            BigDecimal quotient = BigDecimal.valueOf(i2 - i)
                    .divide(BigDecimal.valueOf(i2), 4, RoundingMode.HALF_UP);
            return R.ok().add(quotient);
        } else {
            int i = locMastService.selectCount(new EntityWrapper<LocMast>().in("loc_sts", "O"));
            int i2 = locMastService.selectCount(new EntityWrapper<LocMast>());
            // 在库率=(总数-空库位数)/总数
            BigDecimal quotient = BigDecimal.valueOf(i2 - i)
                    .divide(BigDecimal.valueOf(i2), 4, RoundingMode.HALF_UP);
            return R.ok().add(quotient);
        }
    }
    @PostMapping(value = "/loc/info")
    @Synchronized
    public R list(@RequestHeader(required = false) String appkey, @RequestBody(required = false) LocMast param) {
        auth(appkey, param, request);
        LocMast locMast = locMastService.selectById(param.getLocNo());
        List<LocDetl> locDetls = locDetlService.selectList(new EntityWrapper<LocDetl>().eq("loc_no", locMast.getLocNo()));
        HashMap<String, Object> map = new HashMap<>();
        map.put("status", locMast.getLocSts());
        map.put("data", locDetls);
        return R.ok(map);
    }
    private void auth(String appkey, Object obj, HttpServletRequest request) {
        log.info("{}接口被访问;appkey:{};请求数据:{}", "open/sensorType/list/auth/v1", appkey, JSON.toJSONString(obj));
        request.setAttribute("cache", obj);
@@ -255,43 +298,5 @@
        }
    }
//    public static void main(String[] args) {
//        // 1
//        System.out.println("======================================");
//        OpenOrderPakinParam param = new OpenOrderPakinParam();
//        param.setOrderNo(String.valueOf(new SnowflakeIdWorker().nextId()));
//        param.setOrderType("打包上线单");
//        param.setOrderTime(DateUtils.convert(new Date()));
//        List<DetlDto> orderDetails = new ArrayList<>();
//        param.setOrderDetails(orderDetails);
//        for (int i = 0; i < 3; i++) {
//            DetlDto detlDto = new DetlDto(locDto);
//            switch (i) {
//                case 0:
//                    detlDto.setMatnr("MDH020030530");
//                    detlDto.setBatch("500");
//                    detlDto.setAnfme(18.0);
//                    break;
//                case 1:
//                    detlDto.setMatnr("MDH020016416");
//                    detlDto.setBatch("500");
//                    detlDto.setAnfme(32.0);
//                    break;
//                case 2:
//                    detlDto.setMatnr("LSH90152025");
//                    detlDto.setAnfme(50.0);
//                    break;
//                default:
//                    break;
//            }
//            orderDetails.add(detlDto);
//        }
//        System.out.println(JSON.toJSONString(param));
//        // 2
//        System.out.println("======================================");
//        OpenOrderCompleteParam param1 = new OpenOrderCompleteParam();
//        param1.setOrderNo("963001846497017856");
//        System.out.println(JSON.toJSONString(param1));
//    }
}