From ebdfa825c07189b5f8e89f147d96d1bc612589db Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期二, 15 七月 2025 08:32:17 +0800 Subject: [PATCH] 代码优化 --- rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java | 129 ++++++++++++++++++++++++++++++------------- 1 files changed, 90 insertions(+), 39 deletions(-) diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java index 0b65aca..26996e9 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/AsnOrderItemController.java @@ -1,39 +1,36 @@ package com.vincent.rsf.server.manager.controller; -import com.alibaba.fastjson.JSON; + +import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.vincent.rsf.framework.common.Cools; import com.vincent.rsf.framework.common.R; import com.vincent.rsf.framework.exception.CoolException; -import com.vincent.rsf.server.common.utils.CommonUtil; import com.vincent.rsf.server.common.utils.ExcelUtil; import com.vincent.rsf.server.common.annotation.OperationLog; import com.vincent.rsf.server.common.domain.BaseParam; import com.vincent.rsf.server.common.domain.KeyValVo; import com.vincent.rsf.server.common.domain.PageParam; -import com.vincent.rsf.server.manager.controller.params.AsnOrderItemParams; -import com.vincent.rsf.server.manager.entity.AsnOrderItem; +import com.vincent.rsf.server.common.utils.FieldsUtils; +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.service.AsnOrderItemService; +import com.vincent.rsf.server.manager.service.CompanysService; import com.vincent.rsf.server.system.controller.BaseController; -import com.vincent.rsf.server.system.entity.Fields; -import com.vincent.rsf.server.system.entity.FieldsItem; -import com.vincent.rsf.server.system.service.FieldsItemService; -import com.vincent.rsf.server.system.service.FieldsService; -import com.vincent.rsf.server.system.utils.SerialRuleUtils; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; +import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; -import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.*; -import java.util.stream.Collectors; @Api(tags = "ASN鍗曟槑缁�") @RestController @@ -42,12 +39,26 @@ @Autowired private AsnOrderItemService asnOrderItemService; + @Autowired + private CompanysService companysService; + @PreAuthorize("hasAuthority('manager:asnOrderItem:list')") + @ApiOperation("鍒嗛〉鑾峰彇鍒楄〃") @PostMapping("/asnOrderItem/page") public R page(@RequestBody Map<String, Object> map) { BaseParam baseParam = buildParam(map, BaseParam.class); - PageParam<AsnOrderItem, BaseParam> pageParam = new PageParam<>(baseParam, AsnOrderItem.class); - return R.ok().add(asnOrderItemService.page(pageParam, pageParam.buildWrapper(true))); + 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) { + 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:asnOrderItem:list')") @@ -76,28 +87,33 @@ throw new CoolException("淇℃伅涓嶈兘涓虹┖锛侊紒"); } params.put("createBy", getLoginUserId()); - params.put("updateBy", getLoginUser()); + params.put("updateBy", getLoginUserId()); - if (!asnOrderItemService.fieldsSave(params)) { + if (!asnOrderItemService.fieldsSave(params, getLoginUserId())) { return R.error("Save Fail"); } return R.ok("Save Success"); - - - - } + @PreAuthorize("hasAuthority('manager:asnOrderItem:update')") @OperationLog("Update ASN鍗曟嵁") @PostMapping("/asnOrderItem/update") - public R update(@RequestBody AsnOrderItem asnOrderItem) { - asnOrderItem.setUpdateBy(getLoginUserId()); - asnOrderItem.setUpdateTime(new Date()); - if (!asnOrderItemService.updateById(asnOrderItem)) { + public R update(@RequestBody WkOrderItem wkOrderItem) { + wkOrderItem.setUpdateBy(getLoginUserId()); + 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::getId, wkOrderItem.getSplrName())); + if (!Objects.isNull(companys)) { + wkOrderItem.setSplrCode(companys.getCode()).setSplrName(companys.getName()); + } + } + if (!asnOrderItemService.updateById(wkOrderItem)) { return R.error("Update Fail"); } - return R.ok("Update Success").add(asnOrderItem); + return R.ok("Update Success").add(wkOrderItem); } @PreAuthorize("hasAuthority('manager:asnOrderItem:remove')") @@ -114,9 +130,9 @@ @PostMapping("/asnOrderItem/query") public R query(@RequestParam(required = false) String condition) { List<KeyValVo> vos = new ArrayList<>(); - LambdaQueryWrapper<AsnOrderItem> wrapper = new LambdaQueryWrapper<>(); + LambdaQueryWrapper<WkOrderItem> wrapper = new LambdaQueryWrapper<>(); if (!Cools.isEmpty(condition)) { - wrapper.like(AsnOrderItem::getId, condition); + wrapper.like(WkOrderItem::getId, condition); } asnOrderItemService.page(new Page<>(1, 30), wrapper).getRecords().forEach( item -> vos.add(new KeyValVo(item.getId(), item.getId())) @@ -126,12 +142,34 @@ @PreAuthorize("hasAuthority('manager:asnOrderItem:list')") @PostMapping("/asnOrderItem/export") - @ApiOperation("鏀惰揣閫氱煡鍗曟槑缁�") + @ApiOperation("瀵煎嚭鏀惰揣閫氱煡鍗曟槑缁�") public void export(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception { - AsnOrderTemplate template = ExcelUtil.mockData(AsnOrderTemplate.class); - List<AsnOrderTemplate> list = new ArrayList<>(); - list.add(template); - ExcelUtil.build(ExcelUtil.create(list, AsnOrderTemplate.class, true), response); + List<WkOrderItem> orderItems = new ArrayList<>(); + if (!Objects.isNull(map.get("ids"))) { + List<Long> ids = JSONArray.parseArray(JSONObject.toJSONString(map.get("ids")), Long.class); + if (!ids.isEmpty()) { + orderItems = asnOrderItemService.list(new LambdaQueryWrapper<WkOrderItem>() + .in(WkOrderItem::getId, ids) + .eq(WkOrderItem::getStatus, 1)); + } else { + orderItems = asnOrderItemService.list(new LambdaQueryWrapper<>()); + } + } else { + orderItems = asnOrderItemService.list(new LambdaQueryWrapper<>()); + } + + ExcelUtil.build(ExcelUtil.create(orderItems, WkOrderItem.class, true), response); + } + + + @PostMapping("/asnOrderItem/generate/barcode") + @ApiOperation("鐢熸垚ASN鏍囩") + @PreAuthorize("hasAuthority('manager:asnOrder:list')") + public R generateBarcode(@RequestBody List<Long> orders) { + if (orders.isEmpty()) { + return R.error("鍗曟嵁涓嶈兘涓虹┖!!"); + } + return asnOrderItemService.generateBarcode(orders); } /** @@ -139,18 +177,31 @@ * @param file * @return */ - @PostMapping("/asnOrder/import") + @PostMapping("/asnOrderItem/import") @ApiOperation("ASN瀵煎叆鎺ュ彛") - @PreAuthorize("hasAuthority('manager:asnOrder:update')") - public R importExcel(@RequestParam(value = "file") MultipartFile file, @RequestParam String asnId) throws Exception { + @PreAuthorize("hasAuthority('manager:asnOrderItem:update')") + public R importExcel(@RequestParam(value = "file") MultipartFile file) throws Exception { if (Objects.isNull(file)) { - throw new CoolException("鏂囦欢涓嶈兘涓虹┖锛侊紒"); + return R.error("鏂囦欢涓嶈兘涓虹┖锛侊紒"); } HashMap<String, Object> hashMap = new HashMap<>(); - if (!Objects.isNull(asnId)) { - hashMap.put("asnId", asnId); - } - return asnOrderItemService.excelImport(file, hashMap); + return asnOrderItemService.excelImport(file, hashMap, getLoginUserId()); + } + + /** + * @author Ryan + * @description 涓嬭浇妯℃澘 + * @param + * @return + * @time 2025/4/18 08:17 + */ + @PostMapping("/asnOrderItem/template/download") + @ApiOperation("涓嬭浇鏀惰揣鍗曟ā鏉�") + @PreAuthorize("hasAuthority('manager:asnOrderItem: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); + ExcelUtil.build(ExcelUtil.create(list, AsnOrderTemplate.class, true), response); } } -- Gitblit v1.9.1