From e0921e578658cc5181bcb9ff76f61ba47e6f0d76 Mon Sep 17 00:00:00 2001
From: 1 <1@123>
Date: 星期六, 24 一月 2026 08:25:49 +0800
Subject: [PATCH] lsh#
---
rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WkOrderItemController.java | 113 ++++++++++++++++++++++++++++++++++++++++++++++----------
1 files changed, 93 insertions(+), 20 deletions(-)
diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WkOrderItemController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WkOrderItemController.java
index 5f22c54..ec1d805 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WkOrderItemController.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WkOrderItemController.java
@@ -1,9 +1,9 @@
package com.vincent.rsf.server.manager.controller;
-
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.vincent.rsf.framework.common.Cools;
import com.vincent.rsf.framework.common.R;
@@ -14,11 +14,14 @@
import com.vincent.rsf.server.common.domain.KeyValVo;
import com.vincent.rsf.server.common.domain.PageParam;
import com.vincent.rsf.server.common.utils.FieldsUtils;
+import com.vincent.rsf.server.manager.entity.WkOrder;
import com.vincent.rsf.server.manager.entity.WkOrderItem;
import com.vincent.rsf.server.manager.entity.Companys;
import com.vincent.rsf.server.manager.entity.excel.AsnOrderTemplate;
import com.vincent.rsf.server.manager.enums.CompanysType;
+import com.vincent.rsf.server.manager.enums.OrderType;
import com.vincent.rsf.server.manager.service.AsnOrderItemService;
+import com.vincent.rsf.server.manager.service.AsnOrderService;
import com.vincent.rsf.server.manager.service.CompanysService;
import com.vincent.rsf.server.system.controller.BaseController;
import io.swagger.annotations.Api;
@@ -31,6 +34,7 @@
import javax.servlet.http.HttpServletResponse;
import java.util.*;
+import java.util.stream.Collectors;
@Api(tags = "ASN鍗曟槑缁�")
@RestController
@@ -40,15 +44,18 @@
private AsnOrderItemService asnOrderItemService;
@Autowired
+ private AsnOrderService asnOrderService;
+
+ @Autowired
private CompanysService companysService;
- @PreAuthorize("hasAuthority('manager:asnOrderItem:list')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:list')")
@ApiOperation("鍒嗛〉鑾峰彇鍒楄〃")
@PostMapping("/asnOrderItem/page")
public R page(@RequestBody Map<String, Object> map) {
BaseParam baseParam = buildParam(map, BaseParam.class);
PageParam<WkOrderItem, BaseParam> pageParam = new PageParam<>(baseParam, WkOrderItem.class);
- /**鎷兼帴鎵╁睍瀛楁*/
+ /** 鎷兼帴鎵╁睍瀛楁 */
PageParam<WkOrderItem, BaseParam> page = asnOrderItemService.page(pageParam, pageParam.buildWrapper(true));
List<WkOrderItem> records = page.getRecords();
for (WkOrderItem record : records) {
@@ -61,25 +68,93 @@
return R.ok(page);
}
- @PreAuthorize("hasAuthority('manager:asnOrderItem:list')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:list')")
+ @ApiOperation("鍒嗛〉鑾峰彇鍒楄〃")
+ @PostMapping("/asnOrderItem/in/page")
+ public R pageIn(@RequestBody Map<String, Object> map) {
+ BaseParam baseParam = buildParam(map, BaseParam.class);
+ PageParam<WkOrderItem, BaseParam> pageParam = new PageParam<>(baseParam, WkOrderItem.class);
+ // 鏌ヨtype涓�"in"鐨勮鍗旾D鍒楄〃
+ List<Long> orderIds = asnOrderService.list(new LambdaQueryWrapper<WkOrder>()
+ .eq(WkOrder::getType, OrderType.ORDER_IN.type)
+ .select(WkOrder::getId))
+ .stream()
+ .map(WkOrder::getId)
+ .collect(Collectors.toList());
+ // 鏋勫缓鏌ヨ鏉′欢锛屽叧鑱攁snOrder琛ㄧ瓫閫塼ype涓篿n鐨勬暟鎹�
+ QueryWrapper<WkOrderItem> wrapper = pageParam.buildWrapper(true);
+ if (!orderIds.isEmpty()) {
+ wrapper.in("order_id", orderIds);
+ } else {
+ // 濡傛灉娌℃湁绗﹀悎鏉′欢鐨勮鍗曪紝杩斿洖绌虹粨鏋�
+ wrapper.eq("1", "0");
+ }
+ /** 鎷兼帴鎵╁睍瀛楁 */
+ PageParam<WkOrderItem, BaseParam> page = asnOrderItemService.page(pageParam, wrapper);
+ List<WkOrderItem> records = page.getRecords();
+ for (WkOrderItem record : records) {
+ if (!Objects.isNull(record.getFieldsIndex())) {
+ Map<String, String> fields = FieldsUtils.getFields(record.getFieldsIndex());
+ record.setExtendFields(fields);
+ }
+ }
+ page.setRecords(records);
+ return R.ok(page);
+ }
+
+ @PreAuthorize("hasAuthority('manager:asnOrder:list')")
+ @ApiOperation("鍒嗛〉鑾峰彇鍒楄〃")
+ @PostMapping("/asnOrderItem/out/page")
+ public R pageOut(@RequestBody Map<String, Object> map) {
+ BaseParam baseParam = buildParam(map, BaseParam.class);
+ PageParam<WkOrderItem, BaseParam> pageParam = new PageParam<>(baseParam, WkOrderItem.class);
+ // 鏌ヨtype涓�"in"鐨勮鍗旾D鍒楄〃
+ List<Long> orderIds = asnOrderService.list(new LambdaQueryWrapper<WkOrder>()
+ .eq(WkOrder::getType, OrderType.ORDER_OUT.type)
+ .select(WkOrder::getId))
+ .stream()
+ .map(WkOrder::getId)
+ .collect(Collectors.toList());
+ // 鏋勫缓鏌ヨ鏉′欢锛屽叧鑱攁snOrder琛ㄧ瓫閫塼ype涓篿n鐨勬暟鎹�
+ QueryWrapper<WkOrderItem> wrapper = pageParam.buildWrapper(true);
+ if (!orderIds.isEmpty()) {
+ wrapper.in("order_id", orderIds);
+ } else {
+ // 濡傛灉娌℃湁绗﹀悎鏉′欢鐨勮鍗曪紝杩斿洖绌虹粨鏋�
+ wrapper.eq("1", "0");
+ }
+ /** 鎷兼帴鎵╁睍瀛楁 */
+ PageParam<WkOrderItem, BaseParam> page = asnOrderItemService.page(pageParam, wrapper);
+ List<WkOrderItem> records = page.getRecords();
+ for (WkOrderItem record : records) {
+ if (!Objects.isNull(record.getFieldsIndex())) {
+ Map<String, String> fields = FieldsUtils.getFields(record.getFieldsIndex());
+ record.setExtendFields(fields);
+ }
+ }
+ page.setRecords(records);
+ return R.ok(page);
+ }
+
+ @PreAuthorize("hasAuthority('manager:asnOrder:list')")
@PostMapping("/asnOrderItem/list")
public R list(@RequestBody Map<String, Object> map) {
return R.ok().add(asnOrderItemService.list());
}
- @PreAuthorize("hasAuthority('manager:asnOrderItem:list')")
- @PostMapping({"/asnOrderItem/many/{ids}", "/asnOrderItems/many/{ids}"})
+ @PreAuthorize("hasAuthority('manager:asnOrder:list')")
+ @PostMapping({ "/asnOrderItem/many/{ids}", "/asnOrderItems/many/{ids}" })
public R many(@PathVariable Long[] ids) {
return R.ok().add(asnOrderItemService.listByIds(Arrays.asList(ids)));
}
- @PreAuthorize("hasAuthority('manager:asnOrderItem:list')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:list')")
@GetMapping("/asnOrderItem/{id}")
public R get(@PathVariable("id") Long id) {
return R.ok().add(asnOrderItemService.getById(id));
}
- @PreAuthorize("hasAuthority('manager:asnOrderItem:save')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:save')")
@OperationLog("Create ASN鍗曟嵁")
@PostMapping("/asnOrderItem/save")
public R save(@RequestBody Map<String, Object> params) {
@@ -95,8 +170,7 @@
return R.ok("Save Success");
}
-
- @PreAuthorize("hasAuthority('manager:asnOrderItem:update')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:update')")
@OperationLog("Update ASN鍗曟嵁")
@PostMapping("/asnOrderItem/update")
public R update(@RequestBody WkOrderItem wkOrderItem) {
@@ -104,7 +178,7 @@
wkOrderItem.setUpdateTime(new Date());
if (!Objects.isNull(wkOrderItem.getSplrName()) && StringUtils.isNotBlank(wkOrderItem.getSplrName())) {
Companys companys = companysService.getOne(new LambdaQueryWrapper<Companys>()
- .eq(Companys::getType, CompanysType.COMPANYS_TYPE_SUPPLIER.val)
+ .eq(Companys::getType, CompanysType.COMPANYS_TYPE_SUPPLIER.val)
.eq(Companys::getId, wkOrderItem.getSplrName()));
if (!Objects.isNull(companys)) {
wkOrderItem.setSplrCode(companys.getCode()).setSplrName(companys.getName());
@@ -116,7 +190,7 @@
return R.ok("Update Success").add(wkOrderItem);
}
- @PreAuthorize("hasAuthority('manager:asnOrderItem:remove')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:remove')")
@OperationLog("Delete ASN鍗曟嵁")
@PostMapping("/asnOrderItem/remove/{ids}")
public R remove(@PathVariable Long[] ids) {
@@ -126,7 +200,7 @@
return R.ok("Delete Success").add(ids);
}
- @PreAuthorize("hasAuthority('manager:asnOrderItem:list')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:list')")
@PostMapping("/asnOrderItem/query")
public R query(@RequestParam(required = false) String condition) {
List<KeyValVo> vos = new ArrayList<>();
@@ -135,12 +209,11 @@
wrapper.like(WkOrderItem::getId, condition);
}
asnOrderItemService.page(new Page<>(1, 30), wrapper).getRecords().forEach(
- item -> vos.add(new KeyValVo(item.getId(), item.getId()))
- );
+ item -> vos.add(new KeyValVo(item.getId(), item.getId())));
return R.ok().add(vos);
}
- @PreAuthorize("hasAuthority('manager:asnOrderItem:list')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:list')")
@PostMapping("/asnOrderItem/export")
@ApiOperation("瀵煎嚭鏀惰揣閫氱煡鍗曟槑缁�")
public void export(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception {
@@ -161,7 +234,6 @@
ExcelUtil.build(ExcelUtil.create(orderItems, WkOrderItem.class, true), response);
}
-
@PostMapping("/asnOrderItem/generate/barcode")
@ApiOperation("鐢熸垚ASN鏍囩")
@PreAuthorize("hasAuthority('manager:asnOrder:list')")
@@ -174,15 +246,16 @@
/**
* ASN鍗曟嵁鏄庣粏瀵煎叆
+ *
* @param file
* @return
*/
@PostMapping("/asnOrderItem/import")
@ApiOperation("ASN瀵煎叆鎺ュ彛")
- @PreAuthorize("hasAuthority('manager:asnOrderItem:update')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:update')")
public R importExcel(@RequestParam(value = "file") MultipartFile file) throws Exception {
if (Objects.isNull(file)) {
- return R.error("鏂囦欢涓嶈兘涓虹┖锛侊紒");
+ return R.error("鏂囦欢涓嶈兘涓虹┖锛侊紒");
}
HashMap<String, Object> hashMap = new HashMap<>();
return asnOrderItemService.excelImport(file, hashMap, getLoginUserId());
@@ -197,7 +270,7 @@
*/
@PostMapping("/asnOrderItem/template/download")
@ApiOperation("涓嬭浇鏀惰揣鍗曟ā鏉�")
- @PreAuthorize("hasAuthority('manager:asnOrderItem:update')")
+ @PreAuthorize("hasAuthority('manager:asnOrder:update')")
public void downloadTemplate(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception {
AsnOrderTemplate template = ExcelUtil.mockData(AsnOrderTemplate.class);
List<AsnOrderTemplate> list = Arrays.asList(template);
--
Gitblit v1.9.1