From ef69d3bad0c7f03da11cb1c1e46a84bcebe02bc4 Mon Sep 17 00:00:00 2001 From: skyouc Date: 星期二, 25 三月 2025 10:44:48 +0800 Subject: [PATCH] 修改 # 物料分组编码规则优化 --- rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrGroupController.java | 14 +++++++ rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocServiceImpl.java | 7 ++- rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/params/LocMastInitParam.java | 3 + rsf-server/src/main/java/com/vincent/rsf/server/manager/entity/MatnrGroup.java | 8 +++ rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrController.java | 7 --- rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocController.java | 22 ++++++----- rsf-server/src/main/resources/application-dev.yml | 8 ++-- 7 files changed, 44 insertions(+), 25 deletions(-) diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocController.java index 2c900a8..79d69c6 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocController.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/LocController.java @@ -177,33 +177,35 @@ @PostMapping("/loc/init") public R initLocInfo(@Valid @RequestBody LocMastInitParam param) { if (Objects.isNull(param)) { - throw new CoolException("鍒濆鍖栦俊鎭笉鑳戒负绌猴紒锛�"); + return R.error("鍒濆鍖栦俊鎭笉鑳戒负绌猴紒锛�"); + } + if (Objects.isNull(param.getTypeIds()) && param.getTypeIds().isEmpty()) { + return R.error("搴撲綅绫诲瀷涓嶈兘涓虹┖锛侊紒"); } if (Objects.isNull(param.getWarehouseId())) { - throw new CoolException("浠撳簱ID涓嶈兘涓虹┖锛侊紒"); + return R.error("浠撳簱ID涓嶈兘涓虹┖锛侊紒"); } if (Objects.isNull(param.getAreaId())) { - throw new CoolException("搴撳尯ID涓嶈兘涓虹┖锛侊紒"); + return R.error("搴撳尯ID涓嶈兘涓虹┖锛侊紒"); } if (Objects.isNull(param.getStartRow())) { - throw new CoolException("璧峰鎺掍笉鑳戒负绌猴紒锛�"); + return R.error("璧峰鎺掍笉鑳戒负绌猴紒锛�"); } if (Objects.isNull(param.getEndRow())) { - throw new CoolException("缁堟鎺掍笉鑳戒负绌猴紒锛�"); + return R.error("缁堟鎺掍笉鑳戒负绌猴紒锛�"); } if (Objects.isNull(param.getStartBay())) { - throw new CoolException("璧峰鍒椾笉鑳戒负绌猴紒锛�"); + return R.error("璧峰鍒椾笉鑳戒负绌猴紒锛�"); } if (Objects.isNull(param.getEndBay())) { - throw new CoolException("缁堟鍒椾笉鑳戒负绌猴紒锛�"); + return R.error("缁堟鍒椾笉鑳戒负绌猴紒锛�"); } if (Objects.isNull(param.getStartLev())) { - throw new CoolException("璧峰灞備笉鑳戒负绌猴紒锛�"); + return R.error("璧峰灞備笉鑳戒负绌猴紒锛�"); } if (Objects.isNull(param.getEndLev())) { - throw new CoolException("缁堟灞備笉鑳戒负绌猴紒锛�"); + return R.error("缁堟灞備笉鑳戒负绌猴紒锛�"); } - return locService.initLocs(param); } diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrController.java index ad4c485..d9adc02 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrController.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrController.java @@ -7,7 +7,6 @@ import com.vincent.rsf.framework.common.R; import com.vincent.rsf.framework.exception.CoolException; import com.vincent.rsf.server.common.domain.PageResult; -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; @@ -18,22 +17,16 @@ import com.vincent.rsf.server.manager.entity.Matnr; import com.vincent.rsf.server.manager.entity.excel.MatnrsTemplate; import com.vincent.rsf.server.manager.service.MatnrService; -import com.vincent.rsf.server.system.constant.SerialRuleCode; import com.vincent.rsf.server.system.controller.BaseController; -import com.vincent.rsf.server.system.utils.SerialRuleUtils; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; -import io.swagger.v3.oas.annotations.security.SecurityRequirement; import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.http.HttpHeaders; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletResponse; -import javax.validation.Valid; -import javax.validation.constraints.NotNull; import java.util.*; @RestController diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrGroupController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrGroupController.java index 2b745ee..90d9286 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrGroupController.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatnrGroupController.java @@ -17,6 +17,7 @@ import com.vincent.rsf.server.manager.service.MatnrGroupService; import com.vincent.rsf.server.system.controller.BaseController; import io.swagger.annotations.Api; +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.*; @@ -72,8 +73,12 @@ if (Objects.isNull(matnrGroup.getCode())) { throw new CoolException("鍒嗙粍缂栫爜涓嶈兘涓虹┖锛侊紒"); } + if (Objects.isNull(matnrGroup.getParCode())) { + throw new CoolException("涓婄骇缂栫爜涓嶈兘涓虹┖锛�!"); + } matnrGroup.setCreateBy(getLoginUserId()); matnrGroup.setUpdateBy(getLoginUserId()); + List<MatnrGroup> list = matnrGroupService.list(new LambdaQueryWrapper<MatnrGroup>() .eq(MatnrGroup::getCode, matnrGroup.getCode())); if (!list.isEmpty()) { @@ -83,6 +88,10 @@ .eq(MatnrGroup::getName, matnrGroup.getName())); if (!groups.isEmpty()) { throw new CoolException("鍒嗙粍宸插瓨鍦紝璇峰嬁閲嶅娣诲姞锛侊紒"); + } + //鍒ゆ柇涓婄骇缂栫爜鏄惁涓虹┖ + if (!Objects.isNull(matnrGroup.getParCode()) && !StringUtils.isBlank(matnrGroup.getParCode())) { + matnrGroup.setParCode(matnrGroup.getParCode() + matnrGroup.getCode()); } if (!matnrGroupService.save(matnrGroup)) { return R.error("Save Fail"); @@ -109,6 +118,11 @@ } } + //鍒ゆ柇涓婄骇缂栫爜鏄惁涓虹┖ + if (!Objects.isNull(matnrGroup.getParCode()) && !StringUtils.isBlank(matnrGroup.getParCode())) { + matnrGroup.setCode(matnrGroup.getParCode() + matnrGroup.getCode()); + } + if (!matnrGroupService.updateById(matnrGroup)) { return R.error("Update Fail"); } diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/params/LocMastInitParam.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/params/LocMastInitParam.java index 0014dea..d66cae0 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/params/LocMastInitParam.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/params/LocMastInitParam.java @@ -7,6 +7,7 @@ import javax.validation.constraints.NotBlank; import javax.validation.constraints.NotEmpty; import java.io.Serializable; +import java.util.List; /** * Created by vincent on 2020/6/13 @@ -47,7 +48,7 @@ @ApiModelProperty("搴撲綅绫诲瀷") @NotBlank(message = "搴撲綅绫诲瀷") - private String type; + private List<Long> typeIds; } diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/entity/MatnrGroup.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/entity/MatnrGroup.java index 30f8dad..ee49c83 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/entity/MatnrGroup.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/entity/MatnrGroup.java @@ -41,9 +41,15 @@ private String name; /** + * 鍒嗙粍缂栫爜 + */ + @ApiModelProperty("涓婄骇鍒嗙粍缂栫爜") + private String parCode; + + /** * 鐗╂枡缂栫爜 */ - @ApiModelProperty(value= "鐗╂枡缂栫爜") + @ApiModelProperty(value= "鍒嗙粍缂栫爜") private String code; /** diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocServiceImpl.java index eb7a072..63d4d69 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/LocServiceImpl.java @@ -12,6 +12,7 @@ import com.vincent.rsf.server.manager.mapper.LocTypeRelaMapper; import com.vincent.rsf.server.manager.service.*; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -84,6 +85,8 @@ if (Objects.isNull(warehouseAreas)) { throw new CoolException("搴撳尯涓嶅瓨鍦紒锛�"); } + String join = StringUtils.join(param.getTypeIds(), ","); + List<Loc> list = new ArrayList<>(); for (int r = param.getStartRow(); r <= param.getEndRow(); r++) { for (int b = param.getStartBay(); b <= param.getEndBay(); b++) { @@ -96,9 +99,9 @@ .setRow(r) .setCol(b) .setLev(l) + .setType(join) .setAreaId(param.getAreaId()) - .setWarehouseId(warehouseAreas.getWarehouseId()) - .setType(param.getType()); + .setWarehouseId(warehouseAreas.getWarehouseId()); list.add(loc); } } diff --git a/rsf-server/src/main/resources/application-dev.yml b/rsf-server/src/main/resources/application-dev.yml index ce13aca..3f84f94 100644 --- a/rsf-server/src/main/resources/application-dev.yml +++ b/rsf-server/src/main/resources/application-dev.yml @@ -12,10 +12,10 @@ matching-strategy: ANT_PATH_MATCHER datasource: driver-class-name: com.mysql.jdbc.Driver -# url: jdbc:mysql://192.168.4.24:3306/rsf?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai -# username: root - url: jdbc:mysql://47.76.147.249:3306/rsf?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai - username: rsf + url: jdbc:mysql://192.168.4.24:3306/rsf?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai + username: root +# url: jdbc:mysql://47.76.147.249:3306/rsf?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai +# username: rsf password: 34821015 type: com.alibaba.druid.pool.DruidDataSource druid: -- Gitblit v1.9.1