package com.zy.asrs.controller;
|
|
import com.alibaba.excel.EasyExcel;
|
import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy;
|
import com.alibaba.fastjson.JSONObject;
|
import com.baomidou.mybatisplus.mapper.EntityWrapper;
|
import com.baomidou.mybatisplus.mapper.Wrapper;
|
import com.baomidou.mybatisplus.plugins.Page;
|
import com.core.annotations.ManagerAuth;
|
import com.core.common.BaseRes;
|
import com.core.common.Cools;
|
import com.core.common.DateUtils;
|
import com.core.common.R;
|
import com.zy.asrs.entity.*;
|
import com.zy.asrs.entity.param.OrderDomainParam;
|
import com.zy.asrs.entity.result.PakoutVo;
|
import com.zy.asrs.service.*;
|
import com.zy.common.web.BaseController;
|
import com.zy.system.entity.User;
|
import org.springframework.beans.BeanUtils;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.web.bind.annotation.*;
|
|
import javax.servlet.http.HttpServletResponse;
|
import java.io.IOException;
|
import java.net.URLEncoder;
|
import java.util.*;
|
|
@RestController
|
public class PakoutController extends BaseController {
|
|
@Autowired
|
private PakoutService pakoutService;
|
@Autowired
|
private OrderService orderService;
|
@Autowired
|
private OrderDetlService orderDetlService;
|
@Autowired
|
private ManLocDetlService manLocDetlService;
|
@Autowired
|
private PlaService plaService;
|
|
@RequestMapping(value = "/pakout/{id}/auth")
|
@ManagerAuth
|
public R get(@PathVariable("id") String id) {
|
return R.ok(pakoutService.selectById(String.valueOf(id)));
|
}
|
|
@RequestMapping(value = "/pakout/list/auth")
|
@ManagerAuth
|
public R list(@RequestParam(defaultValue = "1")Integer curr,
|
@RequestParam(defaultValue = "10")Integer limit,
|
@RequestParam(required = false)String orderByField,
|
@RequestParam(required = false)String orderByType,
|
@RequestParam Map<String, Object> param){
|
EntityWrapper<Pakout> wrapper = new EntityWrapper<>();
|
excludeTrash(param);
|
convert(param, wrapper);
|
|
User user = getUser();
|
if (user.getRoleId() != 2 || user.getRoleId() != 24) {
|
wrapper.eq("create_by", user.getId());
|
}
|
|
if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));}
|
return R.ok(pakoutService.selectPage(new Page<>(curr, limit), wrapper));
|
}
|
|
private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){
|
for (Map.Entry<String, Object> entry : map.entrySet()){
|
String val = String.valueOf(entry.getValue());
|
if (val.contains(RANGE_TIME_LINK)){
|
String[] dates = val.split(RANGE_TIME_LINK);
|
wrapper.ge(entry.getKey(), DateUtils.convert(dates[0]));
|
wrapper.le(entry.getKey(), DateUtils.convert(dates[1]));
|
} else {
|
wrapper.eq(entry.getKey(), val);
|
}
|
}
|
}
|
|
@RequestMapping(value = "/pakout/add/auth")
|
@ManagerAuth
|
public R add(@RequestBody OrderDomainParam param) {
|
if (Cools.isEmpty(param)){
|
return R.error("数据异常");
|
}
|
if (!Cools.isEmpty(param.getOrderNo())){
|
Order order = orderService.selectOne(new EntityWrapper<Order>()
|
.eq("order_no", param.getOrderNo())
|
);
|
if (Cools.isEmpty(order)){
|
return R.error("单据不存在");
|
}
|
List<OrderDetl> orderDetls =orderDetlService.selectList(new EntityWrapper<OrderDetl>()
|
.eq("order_no", param.getOrderNo())
|
);
|
if (Cools.isEmpty(orderDetls)){
|
return R.error("单据明细为空");
|
}
|
for (OrderDetl orderDetl : orderDetls){
|
List<ManLocDetl> manLocDetls=null;
|
try{
|
if (Cools.isEmpty(orderDetl.getBatch())){
|
manLocDetls = manLocDetlService.selectList(new EntityWrapper<ManLocDetl>()
|
.eq("matnr",orderDetl.getMatnr())
|
);
|
}else {
|
manLocDetls = manLocDetlService.selectList(new EntityWrapper<ManLocDetl>()
|
.eq("matnr",orderDetl.getMatnr())
|
.eq("batch",orderDetl.getBatch())
|
);
|
}
|
}catch (Exception e){
|
return R.error("添加拣货单失败");
|
}
|
|
if (!Cools.isEmpty(manLocDetls)){
|
for (ManLocDetl manLocDetl:manLocDetls){
|
Double statusAnfme = 0.0;
|
if (Cools.isEmpty(manLocDetl.getStatus())){
|
manLocDetl.setStatus(1);
|
}
|
try{
|
if (manLocDetl.getStatus$().equals("禁用")){
|
if (Cools.isEmpty(manLocDetl.getBatch())){
|
List<Pakout> manPakOuts = pakoutService.selectList(new EntityWrapper<Pakout>()
|
.eq("loc_no", manLocDetl.getLocNo())
|
.eq("matnr", manLocDetl.getMatnr())
|
.eq("status",0)
|
);
|
if (!Cools.isEmpty(manPakOuts)){
|
for (Pakout manPakOut:manPakOuts){
|
statusAnfme=statusAnfme+manPakOut.getAnfme();
|
}
|
}
|
}else {
|
List<Pakout> manPakOuts = pakoutService.selectList(new EntityWrapper<Pakout>()
|
.eq("loc_no", manLocDetl.getLocNo())
|
.eq("matnr", manLocDetl.getMatnr())
|
.eq("batch",manLocDetl.getBatch())
|
.eq("status",0)
|
);
|
if (!Cools.isEmpty(manPakOuts)){
|
for (Pakout manPakOut:manPakOuts){
|
statusAnfme=statusAnfme+manPakOut.getAnfme();
|
}
|
}
|
}
|
}
|
}catch (Exception e){
|
return R.error("查询库存禁用数量失败");
|
}
|
Wrapper<ManLocDetl> wrapper = new EntityWrapper<ManLocDetl>()
|
.eq("loc_no", manLocDetl.getLocNo())
|
.eq("matnr", manLocDetl.getMatnr());
|
if (orderDetl.getAnfme() > manLocDetl.getAnfme()-statusAnfme){
|
if (addPakOUT(manLocDetl,param.getOrderNo()).equals(R.ok())){
|
manLocDetl.setStatus(0);
|
try{
|
if (Cools.isEmpty(manLocDetl.getBatch())){
|
manLocDetlService.update(manLocDetl,wrapper.eq("modi_time",manLocDetl.getModiTime()));
|
}else {
|
manLocDetlService.update(manLocDetl,wrapper.eq("batch",manLocDetl.getBatch()));
|
}
|
}catch (Exception e){
|
return R.error("更新库存失败");
|
}
|
orderDetl.setAnfme(orderDetl.getAnfme()-manLocDetl.getAnfme());
|
}else {
|
return R.error("添加拣货单失败");
|
}
|
}else if (orderDetl.getAnfme()-manLocDetl.getAnfme()-statusAnfme==0){
|
if (addPakOUT(manLocDetl,param.getOrderNo()).equals(R.ok())){
|
manLocDetl.setStatus(0);
|
try{
|
if (Cools.isEmpty(manLocDetl.getBatch())){
|
manLocDetlService.update(manLocDetl,wrapper.eq("modi_time",manLocDetl.getModiTime()));
|
}else {
|
manLocDetlService.update(manLocDetl,wrapper.eq("batch",manLocDetl.getBatch()));
|
}
|
}catch (Exception e){
|
return R.error("更新库存失败");
|
}
|
orderDetl.setAnfme(orderDetl.getAnfme()-manLocDetl.getAnfme());
|
}else {
|
return R.error("添加拣货单失败");
|
}
|
}else if (orderDetl.getAnfme()<manLocDetl.getAnfme()-statusAnfme){
|
Double a=manLocDetl.getAnfme();
|
manLocDetl.setAnfme(orderDetl.getAnfme());
|
if (addPakOUT(manLocDetl,param.getOrderNo()).equals(R.ok())){
|
orderDetl.setAnfme(orderDetl.getAnfme()-manLocDetl.getAnfme());
|
manLocDetl.setStatus(0);
|
manLocDetl.setAnfme(a);
|
try{
|
if (Cools.isEmpty(manLocDetl.getBatch())){
|
manLocDetlService.update(manLocDetl,wrapper.eq("modi_time",manLocDetl.getModiTime()));
|
}else {
|
manLocDetlService.update(manLocDetl,wrapper.eq("batch",manLocDetl.getBatch()));
|
}
|
}catch (Exception e){
|
return R.error("更新库存失败");
|
}
|
|
}else {
|
return R.error("添加拣货单失败");
|
}
|
}else {
|
return R.error("系统出错,请联系管理员");
|
}
|
if (orderDetl.getAnfme()==0){
|
break;
|
}
|
}
|
if (orderDetl.getAnfme()!=0){
|
ManLocDetl manLocDetl=new ManLocDetl();
|
manLocDetl.setAnfme(0.0);
|
manLocDetl.setMatnr(orderDetl.getMatnr());
|
manLocDetl.setMaktx(orderDetl.getMaktx());
|
manLocDetl.setMemo(orderDetl.getMemo()+"库存不足");
|
if (addPakOUT(manLocDetl,param.getOrderNo()).equals(R.ok())){
|
continue;
|
}else {
|
return R.error("添加拣货单失败");
|
}
|
}
|
}else {
|
ManLocDetl manLocDetl=new ManLocDetl();
|
manLocDetl.setAnfme(0.0);
|
manLocDetl.setMatnr(orderDetl.getMatnr());
|
manLocDetl.setMaktx(orderDetl.getMaktx());
|
manLocDetl.setMemo(orderDetl.getMemo()+"无库存");
|
if (addPakOUT(manLocDetl,param.getOrderNo()).equals(R.ok())){
|
continue;
|
}else {
|
return R.error("添加拣货单失败");
|
}
|
}
|
|
|
}
|
orderService.updateSettle(order.getId(),(long)2,null);
|
}else {
|
return R.error("单据编号异常");
|
}
|
return R.ok("拣货单添加成功");
|
}
|
|
private R addPakOUT(ManLocDetl manLocDetl,String OrderNo){
|
Pakout manPakOut=new Pakout();
|
manPakOut.setWrkNo(OrderNo+"-"+System.currentTimeMillis());
|
manPakOut.setWrkSts((long)1);
|
manPakOut.setAnfme(manLocDetl.getAnfme());
|
manPakOut.setLocNo(manLocDetl.getLocNo());
|
manPakOut.setNodeId(manLocDetl.getNodeId());
|
manPakOut.setMatnr(manLocDetl.getMatnr());
|
manPakOut.setMaktx(manLocDetl.getMaktx());
|
manPakOut.setSpecs(manLocDetl.getSpecs());
|
manPakOut.setUnit(manLocDetl.getUnit());
|
manPakOut.setBarcode(manLocDetl.getBarcode());
|
manPakOut.setDocNum(OrderNo);
|
manPakOut.setStatus(0);
|
manPakOut.setCreateTime(new Date());
|
if (!Cools.isEmpty(manLocDetl.getBatch())){
|
manPakOut.setBatch(manLocDetl.getBatch());
|
manPakOut.setUpdateTime(new Date());
|
}else {
|
manPakOut.setUpdateTime(manLocDetl.getModiTime());//用于识别货物
|
}
|
|
manPakOut.setMemo(manLocDetl.getMemo());
|
if (Cools.isEmpty(pakoutService.selectOne(new EntityWrapper<Pakout>().eq("doc_num",OrderNo)))){
|
manPakOut.setName(manLocDetl.getMaktx());
|
}
|
try{
|
if (!pakoutService.insert(manPakOut)){
|
return R.error("添加拣货明细失败,请联系管理员");
|
}
|
}catch (Exception e){
|
return R.error("添加拣货明细失败,请联系管理员");
|
}
|
return R.ok();
|
|
}
|
|
@RequestMapping(value = "/pakout/update/auth")
|
@ManagerAuth
|
public R update(Pakout pakout){
|
if (Cools.isEmpty(pakout) || null==pakout.getMatnr()){
|
return R.error();
|
}
|
pakoutService.updateById(pakout);
|
return R.ok();
|
}
|
|
@RequestMapping(value = "/pakout/delete/auth")
|
@ManagerAuth(memo = "手动删除订单")
|
public R delete(@RequestParam String docNum){
|
try{
|
pakoutService.deletePakout(docNum);
|
}catch (Exception e){
|
return R.error(e+"");
|
}
|
return R.ok("拣货单删除成功");
|
}
|
|
@RequestMapping(value = "/pakout/deleteDetl/auth")
|
@ManagerAuth(memo = "手动删除订单")
|
public R deleteDetl(@RequestParam String wrkNo){
|
try{
|
pakoutService.deletePakoutByWrkNo(wrkNo);
|
}catch (Exception e){
|
return R.error(e+"");
|
}
|
return R.ok("拣货单删除成功");
|
}
|
|
@RequestMapping(value = "/pakout/export/auth")
|
@ManagerAuth
|
public R export(@RequestBody JSONObject param){
|
EntityWrapper<Pakout> wrapper = new EntityWrapper<>();
|
List<String> fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class);
|
Map<String, Object> map = excludeTrash(param.getJSONObject("pakout"));
|
convert(map, wrapper);
|
List<Pakout> list = pakoutService.selectList(wrapper);
|
return R.ok(exportSupport(list, fields));
|
}
|
|
@RequestMapping(value = "/pakoutQuery/auth")
|
@ManagerAuth
|
public R query(String condition) {
|
EntityWrapper<Pakout> wrapper = new EntityWrapper<>();
|
wrapper.like("id", condition);
|
Page<Pakout> page = pakoutService.selectPage(new Page<>(0, 10), wrapper);
|
List<Map<String, Object>> result = new ArrayList<>();
|
for (Pakout pakout : page.getRecords()){
|
Map<String, Object> map = new HashMap<>();
|
map.put("id", pakout.getMatnr());
|
map.put("value", pakout.getMatnr());
|
result.add(map);
|
}
|
return R.ok(result);
|
}
|
|
@RequestMapping(value = "/pakout/check/column/auth")
|
@ManagerAuth
|
public R query(@RequestBody JSONObject param) {
|
Wrapper<Pakout> wrapper = new EntityWrapper<Pakout>().eq(humpToLine(String.valueOf(param.get("key"))), param.get("val"));
|
if (null != pakoutService.selectOne(wrapper)){
|
return R.parse(BaseRes.REPEAT).add(getComment(Pakout.class, String.valueOf(param.get("key"))));
|
}
|
return R.ok();
|
}
|
|
@RequestMapping(value = "/pakout/printExport/auth")
|
// @ManagerAuth(memo = "盘点单导出")
|
public void export(HttpServletResponse response, @RequestParam String orderNo) throws IOException {
|
//从数据库查询数据
|
EntityWrapper<Pakout> locCheckEntityWrapper = new EntityWrapper<>();
|
locCheckEntityWrapper.eq("doc_num",orderNo);
|
List<Pakout> list = pakoutService.selectList(locCheckEntityWrapper);
|
List<PakoutVo> pakoutVos=new ArrayList<>();
|
|
for (Pakout pakout: list) {
|
PakoutVo pakoutVo = new PakoutVo();
|
Pla pla = plaService.selectOne(new EntityWrapper<Pla>()
|
.eq("batch", pakout.getBatch())
|
.eq("package_no", pakout.getBarcode())
|
.eq("brand", pakout.getMaktx()));
|
BeanUtils.copyProperties(pla,pakoutVo);
|
BeanUtils.copyProperties(pakout,pakoutVo);
|
pakoutVos.add(pakoutVo);
|
}
|
response.setContentType("application/vnd.ms-excel");
|
response.setCharacterEncoding("utf-8");
|
String fileName = URLEncoder.encode("拣货单", "UTF-8");
|
response.setHeader("Content-disposition", "attachment;filename=" + fileName+ orderNo + ".xlsx");
|
EasyExcel.write(response.getOutputStream(), PakoutVo.class)
|
.registerWriteHandler(new LongestMatchColumnWidthStyleStrategy())
|
.sheet("表1")
|
.doWrite(pakoutVos);
|
}
|
|
}
|