From 914a092bc4c21d69641f94b68fecf61b25ddaca1 Mon Sep 17 00:00:00 2001
From: zjj <3272660260@qq.com>
Date: 星期三, 06 九月 2023 13:11:38 +0800
Subject: [PATCH] #拣货单完成、上架规则

---
 src/main/java/com/zy/asrs/controller/ReportQueryController.java |   98 +++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 91 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/ReportQueryController.java b/src/main/java/com/zy/asrs/controller/ReportQueryController.java
index 4ed072d..2871f11 100644
--- a/src/main/java/com/zy/asrs/controller/ReportQueryController.java
+++ b/src/main/java/com/zy/asrs/controller/ReportQueryController.java
@@ -2,13 +2,18 @@
 
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.plugins.Page;
+import com.core.annotations.ManagerAuth;
+import com.core.common.Cools;
+import com.core.common.R;
 import com.zy.asrs.entity.*;
 import com.zy.asrs.mapper.ReportQueryMapper;
+import com.zy.asrs.service.LocDetlService;
 import com.zy.common.web.BaseController;
-import com.core.annotations.ManagerAuth;
-import com.core.common.R;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.*;
+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 java.util.ArrayList;
 import java.util.HashMap;
@@ -24,6 +29,8 @@
 @RequestMapping("/report")
 public class ReportQueryController extends BaseController {
 
+	@Autowired
+	private LocDetlService locDetlService;
 	@Autowired
 	private ReportQueryMapper reportQueryMapper;
 
@@ -60,6 +67,10 @@
 		ViewStayTimeBean bean = new ViewStayTimeBean();
 		bean.setPageSize(limit);
 		bean.setPageNumber(curr);
+		String locNo = String.valueOf(param.get("loc_no"));
+		if (!Cools.isEmpty(locNo) && !locNo.equals("null")) {
+			bean.setLoc_no(locNo);
+		}
 		List<ViewStayTimeBean> list = reportQueryMapper.queryViewStayTimeList(bean);
 		int count = reportQueryMapper.getViewStayTimeCount(bean);
 		Page<ViewStayTimeBean> page = new Page<>();
@@ -93,14 +104,26 @@
 		// 琛ㄦ牸琛岋細灞� ====>> 鍊掑簭
 		List<String> levs = reportQueryMapper.getViewLocLevCount(row);
 		List<Map<String, Object>> body = new ArrayList<>();
-		for (String lev : levs){
+		int maxBay=0;
+		for (String lev : levs) {
 			// 鑾峰彇灞傜骇鏁版嵁
 			List<ViewLocMapDto> dtos = reportQueryMapper.getViewLocBays(row, Integer.parseInt(lev));
 			// 锛佽〃鏍肩涓�鍒楁斁灞傜骇鏁�
-			dtos.add(0, new ViewLocMapDto(null ,null, lev));
+			dtos.add(0, new ViewLocMapDto(null, null, lev));
 			Map<String, Object> map = new HashMap<>();
 			map.put("loc", dtos);
 			body.add(map);
+			if (row == 100) {
+				if (maxBay < locDetlService.queryStockViewMergeCount(row, Integer.parseInt(lev))) {
+					maxBay = locDetlService.queryStockViewMergeCount(row, Integer.parseInt(lev));
+				}
+			}
+		}
+
+		if (row==100){
+			for (int i =bays.size()-1;i>maxBay;i--){
+				bays.remove(i);
+			}
 		}
 		Map<String, Object> result = new HashMap<>();
 		result.put("title", bays);
@@ -145,12 +168,70 @@
 		return R.ok(page);
 	}
 
+	/**
+	 * 鏃ュ叆搴撴眹鎬绘煡璇�
+	 * @return
+	 */
+	@RequestMapping("/viewWorkCountInList.action")
+	public R viewWorkCountInList(@RequestParam(defaultValue = "1")Integer curr,
+								 @RequestParam(defaultValue = "10")Integer limit,
+								 @RequestParam Map<String, Object> param){
+		String startTime = "1970.1.2";
+		String endTime = "2099.1.2";
+		if (!Cools.isEmpty(param.get("query_date"))) {
+			String  queryDate = (String) param.get("query_date");
+			String[] split = queryDate.split(" - ");
+			startTime= split[0].split(" ")[0].replace("-",".");
+			endTime = split[1].split(" ")[0].replace("-",".");
+		}
+		List<ViewWorkCountInView> allCountIn = reportQueryMapper.selectWorkCountIn(Integer.valueOf((String) param.get("pageNumber")), Integer.valueOf((String) param.get("pageSize")), (String) param.get("matnr"), startTime,endTime);
+		Integer total = reportQueryMapper.selectWorkCountInTotal((String) param.get("matnr"), startTime,endTime);
+		Page<ViewWorkCountInView> page = new Page<>();
+		page.setRecords(allCountIn);
+		page.setTotal(total);
+		Integer sum = reportQueryMapper.selectWorkCountInSum((String) param.get("matnr"), startTime,endTime);
+		HashMap<String, Object> result = new HashMap<>();
+		result.put("page",page);
+		result.put("sum",sum);
+		return R.ok(result);
+	}
+
+	/**
+	 * 鏃ュ嚭搴撴眹鎬�
+	 */
+	@RequestMapping("/viewWorkCountOutList.action")
+	public R viewWorkCountOutList(@RequestParam(defaultValue = "1")Integer curr,
+								  @RequestParam(defaultValue = "10")Integer limit,
+								  @RequestParam Map<String, Object> param){
+		String startTime = "1970.1.2";
+		String endTime = "2099.1.2";
+		if (!Cools.isEmpty(param.get("query_date"))) {
+			String  queryDate = (String) param.get("query_date");
+			String[] split = queryDate.split(" - ");
+			startTime= split[0].split(" ")[0].replace("-",".");
+			endTime = split[1].split(" ")[0].replace("-",".");
+		}
+		List<ViewWorkCountInView> allCountIn = reportQueryMapper.selectWorkCountOut(Integer.valueOf((String) param.get("pageNumber")), Integer.valueOf((String) param.get("pageSize")), (String) param.get("matnr"), startTime,endTime);
+		Integer total = reportQueryMapper.selectWorkCountOutTotal((String) param.get("matnr"), startTime,endTime);
+		Page<ViewWorkCountInView> page = new Page<>();
+		page.setRecords(allCountIn);
+		page.setTotal(total);
+		Integer sum = reportQueryMapper.selectWorkCountOutSum((String) param.get("matnr"), startTime,endTime);
+		HashMap<String, Object> result = new HashMap<>();
+		result.put("page",page);
+		result.put("sum",sum);
+		return R.ok(result);
+	}
+
 	//excel瀵煎嚭
 	@RequestMapping("/viewWorkInExport.action")
 	@ManagerAuth(memo = "鏃ュ叆搴撴槑缁嗙粺璁″鍑�")
 	public R viewWorkInExport(@RequestBody JSONObject param){
 		List<String> fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class);
-		List<ViewWorkInBean> list = reportQueryMapper.getViewWorkInAll(new ViewWorkInBean());
+		@SuppressWarnings("unchecked")
+		ViewWorkInBean bean = Cools.conver((Map<? extends String, ?>) param.get("exportData"), ViewWorkInBean.class);
+		bean.setQuery_date(bean.getQuery_date());
+		List<ViewWorkInBean> list = reportQueryMapper.getViewWorkInAll(bean);
 		return R.ok(exportSupport(list, fields));
 	}
 
@@ -170,7 +251,10 @@
 	@ManagerAuth(memo = "鏃ュ嚭搴撴槑缁嗙粺璁″鍑�")
 	public R viewWorkOutExport(@RequestBody JSONObject param){
 		List<String> fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class);
-		List<ViewWorkInBean> list = reportQueryMapper.getViewWorkOutAll(new ViewWorkInBean());
+		@SuppressWarnings("unchecked")
+		ViewWorkInBean bean = Cools.conver((Map<? extends String, ?>) param.get("exportData"), ViewWorkInBean.class);
+		bean.setQuery_date(bean.getQuery_date());
+		List<ViewWorkInBean> list = reportQueryMapper.getViewWorkOutAll(bean);
 		return R.ok(exportSupport(list, fields));
 	}
 

--
Gitblit v1.9.1