From a4cdd4d37761c06ad89d9c42a00402f63f811f35 Mon Sep 17 00:00:00 2001
From: LSH
Date: 星期二, 18 七月 2023 13:07:52 +0800
Subject: [PATCH] #货主转换搜索无数据优化

---
 src/main/java/com/zy/asrs/controller/ReportQueryController.java |   52 ++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 44 insertions(+), 8 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/ReportQueryController.java b/src/main/java/com/zy/asrs/controller/ReportQueryController.java
index f2ecc1e..2871f11 100644
--- a/src/main/java/com/zy/asrs/controller/ReportQueryController.java
+++ b/src/main/java/com/zy/asrs/controller/ReportQueryController.java
@@ -104,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);
@@ -164,12 +176,24 @@
 	public R viewWorkCountInList(@RequestParam(defaultValue = "1")Integer curr,
 								 @RequestParam(defaultValue = "10")Integer limit,
 								 @RequestParam Map<String, Object> param){
-		List<ViewWorkCountInView> allCountIn = reportQueryMapper.selectWorkCountIn(Integer.valueOf((String) param.get("pageNumber")), Integer.valueOf((String) param.get("pageSize")));
-		Integer total = reportQueryMapper.selectWorkCountInTotal();
+		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);
-		return R.ok(page);
+		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);
 	}
 
 	/**
@@ -179,12 +203,24 @@
 	public R viewWorkCountOutList(@RequestParam(defaultValue = "1")Integer curr,
 								  @RequestParam(defaultValue = "10")Integer limit,
 								  @RequestParam Map<String, Object> param){
-		List<ViewWorkCountInView> allCountIn = reportQueryMapper.selectWorkCountOut(Integer.valueOf((String) param.get("pageNumber")), Integer.valueOf((String) param.get("pageSize")));
-		Integer total = reportQueryMapper.selectWorkCountOutTotal();
+		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);
-		return R.ok(page);
+		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瀵煎嚭

--
Gitblit v1.9.1