Compare commits
	
		
			3 Commits
		
	
	
		
			5432392a39
			...
			838127c200
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 838127c200 | ||
|   | ab67214d92 | ||
|   | a718b7537c | 
| @ -0,0 +1,19 @@ | |||||||
|  | package cn.iocoder.yudao.common; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * 维修相关字典枚举 | ||||||
|  |  * | ||||||
|  |  * @author 小李 | ||||||
|  |  * @date 15:48 2024/11/29 | ||||||
|  | **/ | ||||||
|  | public interface RepairDictConstants { | ||||||
|  | 
 | ||||||
|  |     /** 单位 */ | ||||||
|  |     String REPAIR_UNIT = "repair_unit"; | ||||||
|  | 
 | ||||||
|  |     /** 配件来源 */ | ||||||
|  |     String WARES_DATA_FORM = "repair_data_form"; | ||||||
|  | 
 | ||||||
|  |     /** 配件属性 */ | ||||||
|  |     String WARES_ATTRIBUTE = "repair_attribute"; | ||||||
|  | } | ||||||
| @ -1,22 +1,29 @@ | |||||||
| package cn.iocoder.yudao.module.project.controller.admin; | package cn.iocoder.yudao.module.project.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
|  | import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; | ||||||
| import cn.iocoder.yudao.module.project.entity.RepairWares; | import cn.iocoder.yudao.module.project.entity.RepairWares; | ||||||
| import cn.iocoder.yudao.module.project.service.RepairWaresService; | import cn.iocoder.yudao.module.project.service.RepairWaresService; | ||||||
| import cn.iocoder.yudao.module.project.vo.RepairWaresPageReqVO; | import cn.iocoder.yudao.module.project.vo.*; | ||||||
| import cn.iocoder.yudao.module.project.vo.RepairWaresRespVO; |  | ||||||
| import cn.iocoder.yudao.module.project.vo.RepairWaresSaveReqVO; |  | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import io.swagger.v3.oas.annotations.Operation; | import io.swagger.v3.oas.annotations.Operation; | ||||||
| import io.swagger.v3.oas.annotations.Parameter; | import io.swagger.v3.oas.annotations.Parameter; | ||||||
|  | import io.swagger.v3.oas.annotations.Parameters; | ||||||
| import io.swagger.v3.oas.annotations.tags.Tag; | import io.swagger.v3.oas.annotations.tags.Tag; | ||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
|  | import org.springframework.web.multipart.MultipartFile; | ||||||
| 
 | 
 | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
|  | import javax.servlet.http.HttpServletResponse; | ||||||
| import javax.validation.Valid; | import javax.validation.Valid; | ||||||
| 
 | 
 | ||||||
|  | import java.math.BigDecimal; | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.Collections; | ||||||
|  | import java.util.List; | ||||||
|  | 
 | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| @Tag(name = "管理后台 - 配件库") | @Tag(name = "管理后台 - 配件库") | ||||||
| @ -135,4 +142,56 @@ public class RepairWaresController { | |||||||
|         return success(waresService.getAllTypeList()); |         return success(waresService.getAllTypeList()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 下载配件导入模板 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 15:35 2024/11/29 | ||||||
|  |     **/ | ||||||
|  |     @GetMapping("/get-import-template") | ||||||
|  |     @Operation(summary = "下载配件导入模板") | ||||||
|  |     public void getImportTemplate(HttpServletResponse response) throws Exception { | ||||||
|  |         List<RepairWaresExcelVO> list = Collections.singletonList( | ||||||
|  |                 RepairWaresExcelVO | ||||||
|  |                         .builder() | ||||||
|  |                         .barCode("123") | ||||||
|  |                         .code("123") | ||||||
|  |                         .name("模板数据") | ||||||
|  |                         .model("123") | ||||||
|  |                         .price(new BigDecimal("100")) | ||||||
|  |                         .purPrice(new BigDecimal("100")) | ||||||
|  |                         .type("模板分类") | ||||||
|  |                         .unit("01") | ||||||
|  |                         .warehouse("模板仓库") | ||||||
|  |                         .miniStock(new BigDecimal("0")) | ||||||
|  |                         .maxStock(new BigDecimal("10")) | ||||||
|  |                         .stock(new BigDecimal("5")) | ||||||
|  | //                        .attribute("yc") | ||||||
|  |                         .carModel("模板车型") | ||||||
|  | //                        .dataForm("bd") | ||||||
|  |                         .remark("模板") | ||||||
|  |                         .build() | ||||||
|  |         ); | ||||||
|  |         ExcelUtils.write(response, "配件导入模板.xls", "配件信息", RepairWaresExcelVO.class, list); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 导入配件数据 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 16:20 2024/11/29 | ||||||
|  |      * @param file Excel 文件 | ||||||
|  |      * @param updateSupport 是否支持更新 | ||||||
|  |     **/ | ||||||
|  |     @PostMapping("/import-data") | ||||||
|  |     @Operation(summary = "导入配件数据") | ||||||
|  |     @Parameters({ | ||||||
|  |             @Parameter(name = "file", description = "Excel 文件", required = true), | ||||||
|  |             @Parameter(name = "updateSupport", description = "是否支持更新,默认为 false", example = "true") | ||||||
|  |     }) | ||||||
|  |     public CommonResult<RepairWaresExcelRespVO> importData(@RequestParam("file") MultipartFile file, | ||||||
|  |                                                            @RequestParam(value = "updateSupport", required = false, defaultValue = "false") Boolean updateSupport) throws Exception{ | ||||||
|  |         List<RepairWaresExcelVO> list = ExcelUtils.read(file, RepairWaresExcelVO.class); | ||||||
|  |         return success(waresService.importData(list, updateSupport)); | ||||||
|  |     } | ||||||
| } | } | ||||||
| @ -1,9 +1,7 @@ | |||||||
| package cn.iocoder.yudao.module.project.service; | package cn.iocoder.yudao.module.project.service; | ||||||
| 
 | 
 | ||||||
| import cn.iocoder.yudao.module.project.entity.RepairWares; | import cn.iocoder.yudao.module.project.entity.RepairWares; | ||||||
| import cn.iocoder.yudao.module.project.vo.RepairWaresPageReqVO; | import cn.iocoder.yudao.module.project.vo.*; | ||||||
| import cn.iocoder.yudao.module.project.vo.RepairWaresRespVO; |  | ||||||
| import cn.iocoder.yudao.module.project.vo.RepairWaresSaveReqVO; |  | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.baomidou.mybatisplus.extension.service.IService; | import com.baomidou.mybatisplus.extension.service.IService; | ||||||
| @ -80,4 +78,12 @@ public interface RepairWaresService extends IService<RepairWares> { | |||||||
|      * @return java.util.List<cn.iocoder.yudao.module.project.entity.RepairWares> |      * @return java.util.List<cn.iocoder.yudao.module.project.entity.RepairWares> | ||||||
|     **/ |     **/ | ||||||
|     List<RepairWares> listByIds(List<String> idList); |     List<RepairWares> listByIds(List<String> idList); | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 导入配件数据 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 16:20 2024/11/29 | ||||||
|  |      **/ | ||||||
|  |     RepairWaresExcelRespVO importData(List<RepairWaresExcelVO> list, Boolean updateSupport); | ||||||
| } | } | ||||||
| @ -1,23 +1,31 @@ | |||||||
| package cn.iocoder.yudao.module.project.service.impl; | package cn.iocoder.yudao.module.project.service.impl; | ||||||
| 
 | 
 | ||||||
|  | import cn.hutool.core.collection.CollUtil; | ||||||
|  | import cn.hutool.core.util.ObjectUtil; | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | import cn.iocoder.yudao.framework.common.util.object.BeanUtils; | ||||||
|  | import cn.iocoder.yudao.module.conf.entity.BaseType; | ||||||
|  | import cn.iocoder.yudao.module.conf.entity.BaseWarehouse; | ||||||
|  | import cn.iocoder.yudao.module.conf.service.BaseTypeService; | ||||||
|  | import cn.iocoder.yudao.module.conf.service.BaseWarehouseService; | ||||||
| import cn.iocoder.yudao.module.project.entity.RepairWares; | import cn.iocoder.yudao.module.project.entity.RepairWares; | ||||||
| import cn.iocoder.yudao.module.project.mapper.RepairWaresMapper; | import cn.iocoder.yudao.module.project.mapper.RepairWaresMapper; | ||||||
| import cn.iocoder.yudao.module.project.service.RepairWaresService; | import cn.iocoder.yudao.module.project.service.RepairWaresService; | ||||||
| import cn.iocoder.yudao.module.project.vo.RepairWaresPageReqVO; | import cn.iocoder.yudao.module.project.vo.*; | ||||||
| import cn.iocoder.yudao.module.project.vo.RepairWaresRespVO; | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import cn.iocoder.yudao.module.project.vo.RepairWaresSaveReqVO; |  | ||||||
| import com.baomidou.mybatisplus.core.metadata.IPage; | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
| import org.apache.commons.lang3.StringUtils; | import org.apache.commons.lang3.StringUtils; | ||||||
|  | import org.springframework.context.annotation.Lazy; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
|  | import org.springframework.transaction.annotation.Transactional; | ||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| 
 | 
 | ||||||
| import javax.annotation.Resource; | import javax.annotation.Resource; | ||||||
| import java.util.Arrays; | import java.util.*; | ||||||
| import java.util.List; | import java.util.stream.Collectors; | ||||||
| import java.util.Map; | 
 | ||||||
|  | import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception0; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 配件库 Service 实现类 |  * 配件库 Service 实现类 | ||||||
| @ -31,6 +39,14 @@ public class RepairWaresServiceImpl extends ServiceImpl<RepairWaresMapper, Repai | |||||||
|     @Resource |     @Resource | ||||||
|     private RepairWaresMapper waresMapper; |     private RepairWaresMapper waresMapper; | ||||||
| 
 | 
 | ||||||
|  |     @Resource | ||||||
|  |     @Lazy | ||||||
|  |     private BaseWarehouseService warehouseService; | ||||||
|  | 
 | ||||||
|  |     @Resource | ||||||
|  |     @Lazy | ||||||
|  |     private BaseTypeService typeService; | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|      * 保存配件库 |      * 保存配件库 | ||||||
| @ -127,4 +143,72 @@ public class RepairWaresServiceImpl extends ServiceImpl<RepairWaresMapper, Repai | |||||||
|         return baseMapper.selectBatchIds(idList); |         return baseMapper.selectBatchIds(idList); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 导入配件数据 | ||||||
|  |      * | ||||||
|  |      * @author 小李 | ||||||
|  |      * @date 16:20 2024/11/29 | ||||||
|  |      **/ | ||||||
|  |     @Override | ||||||
|  |     @Transactional(rollbackFor = Exception.class) | ||||||
|  |     public RepairWaresExcelRespVO importData(List<RepairWaresExcelVO> list, Boolean updateSupport) { | ||||||
|  |         // 参数校验 | ||||||
|  |         if (CollUtil.isEmpty(list)) { | ||||||
|  |             throw exception0(500, "导入配件数据不能为空!"); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // 取所有的仓库变成map,key是名称,value是id | ||||||
|  |         List<BaseWarehouse> warehouses = warehouseService.list(); | ||||||
|  |         Map<String, String> warehousesMap = warehouses.stream().collect(Collectors.toMap(BaseWarehouse::getName, BaseWarehouse::getId)); | ||||||
|  | 
 | ||||||
|  |         // 取所有的配件类型变成map,key是名称,value是id | ||||||
|  |         List<BaseType> types = typeService.list(new LambdaQueryWrapper<BaseType>().eq(BaseType::getType, "02")); | ||||||
|  |         Map<String, String> typesMap = types.stream().collect(Collectors.toMap(BaseType::getName, BaseType::getId)); | ||||||
|  | 
 | ||||||
|  |         // 遍历,逐个创建 or 更新 | ||||||
|  |         RepairWaresExcelRespVO result = RepairWaresExcelRespVO.builder().createNames(new ArrayList<>()) | ||||||
|  |                 .updateNames(new ArrayList<>()).failureNames(new LinkedHashMap<>()).build(); | ||||||
|  |         list.forEach(item -> { | ||||||
|  |             // 验证是否存在,用selectList防止本来就有多个导致的报错 | ||||||
|  |             List<RepairWares> repairWares = baseMapper.selectList(new LambdaQueryWrapper<RepairWares>().eq(RepairWares::getName, item.getName())); | ||||||
|  |             if (CollUtil.isEmpty(repairWares)) { | ||||||
|  |                 RepairWares wares = BeanUtils.toBean(item, RepairWares.class); | ||||||
|  |                 if (ObjectUtil.isNotEmpty(item.getType()) && ObjectUtil.isNotEmpty(typesMap.get(item.getType()))) { | ||||||
|  |                     wares.setType(typesMap.get(item.getType())); | ||||||
|  |                 } | ||||||
|  |                 if (ObjectUtil.isNotEmpty(item.getWarehouse()) && ObjectUtil.isNotEmpty(warehousesMap.get(item.getWarehouse()))) { | ||||||
|  |                     wares.setWarehouse(warehousesMap.get(item.getWarehouse())); | ||||||
|  |                 } | ||||||
|  |                 wares.setStatus("01"); | ||||||
|  |                 baseMapper.insert(wares); | ||||||
|  |                 result.getCreateNames().add(item.getName()); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             // 存在看是否可以修改 | ||||||
|  |             if (!updateSupport) { | ||||||
|  |                 result.getFailureNames().put(item.getName(), "不允许修改!"); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             // 可以修改,看是否有多个相同名称的配件 | ||||||
|  |             if (repairWares.size() > 1) { | ||||||
|  |                 result.getFailureNames().put(item.getName(), "存在多个相同名称的配件!"); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             // 更新 | ||||||
|  |             RepairWares wares = repairWares.get(0); | ||||||
|  |             RepairWares updateWares = BeanUtils.toBean(item, RepairWares.class); | ||||||
|  |             updateWares.setId(wares.getId()); | ||||||
|  |             if (ObjectUtil.isNotEmpty(item.getType()) && ObjectUtil.isNotEmpty(typesMap.get(item.getType()))) { | ||||||
|  |                 updateWares.setType(typesMap.get(item.getType())); | ||||||
|  |             } | ||||||
|  |             if (ObjectUtil.isNotEmpty(item.getWarehouse()) && ObjectUtil.isNotEmpty(warehousesMap.get(item.getWarehouse()))) { | ||||||
|  |                 updateWares.setWarehouse(warehousesMap.get(item.getWarehouse())); | ||||||
|  |             } | ||||||
|  |             updateWares.setStatus(wares.getStatus()); | ||||||
|  |             baseMapper.updateById(updateWares); | ||||||
|  |             result.getUpdateNames().add(item.getName()); | ||||||
|  |         }); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
| @ -0,0 +1,29 @@ | |||||||
|  | package cn.iocoder.yudao.module.project.vo; | ||||||
|  | 
 | ||||||
|  | import lombok.Builder; | ||||||
|  | import lombok.Data; | ||||||
|  | 
 | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.Map; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * 导入配件数据后的响应 | ||||||
|  |  * | ||||||
|  |  * @author 小李 | ||||||
|  |  * @date 16:22 2024/11/29 | ||||||
|  | **/ | ||||||
|  | @Data | ||||||
|  | @Builder | ||||||
|  | public class RepairWaresExcelRespVO { | ||||||
|  | 
 | ||||||
|  |     /** 导入成功的配件名称集合 */ | ||||||
|  |     private List<String> createNames; | ||||||
|  | 
 | ||||||
|  |     /** 更新成功的配件名称集合 */ | ||||||
|  |     private List<String> updateNames; | ||||||
|  | 
 | ||||||
|  |     /** 导入失败的配件信息,key是配件名称,value是失败原因  */ | ||||||
|  |     private Map<String, String> failureNames; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -0,0 +1,80 @@ | |||||||
|  | package cn.iocoder.yudao.module.project.vo; | ||||||
|  | 
 | ||||||
|  | import cn.iocoder.yudao.common.RepairDictConstants; | ||||||
|  | import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat; | ||||||
|  | import cn.iocoder.yudao.framework.excel.core.convert.DictConvert; | ||||||
|  | import com.alibaba.excel.annotation.ExcelProperty; | ||||||
|  | import lombok.AllArgsConstructor; | ||||||
|  | import lombok.Builder; | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.NoArgsConstructor; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  | 
 | ||||||
|  | import java.math.BigDecimal; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * 导入、导出excel用的配件VO | ||||||
|  |  * | ||||||
|  |  * @author 小李 | ||||||
|  |  * @date 15:38 2024/11/29 | ||||||
|  | **/ | ||||||
|  | @Data | ||||||
|  | @Builder | ||||||
|  | @AllArgsConstructor | ||||||
|  | @NoArgsConstructor | ||||||
|  | @Accessors(chain = false) | ||||||
|  | public class RepairWaresExcelVO { | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("条形码") | ||||||
|  |     private String barCode; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("商品编码") | ||||||
|  |     private String code; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("商品名称") | ||||||
|  |     private String name; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("规格型号") | ||||||
|  |     private String model; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("售价") | ||||||
|  |     private BigDecimal price; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("进价") | ||||||
|  |     private BigDecimal purPrice; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("所属分类") | ||||||
|  |     private String type; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty(value = "计量单位", converter = DictConvert.class) | ||||||
|  |     @DictFormat(RepairDictConstants.REPAIR_UNIT) | ||||||
|  |     private String unit; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("默认仓库") | ||||||
|  |     private String warehouse; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("最低库存") | ||||||
|  |     private BigDecimal miniStock; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("最高库存") | ||||||
|  |     private BigDecimal maxStock; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("当前库存") | ||||||
|  |     private BigDecimal stock; | ||||||
|  | 
 | ||||||
|  |     /** 好像找不到这个字典 */ | ||||||
|  | //    @ExcelProperty(value = "配件属性", converter = DictConvert.class) | ||||||
|  | //    @DictFormat(RepairDictConstants.WARES_ATTRIBUTE) | ||||||
|  | //    private String attribute; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("适用车型") | ||||||
|  |     private String carModel; | ||||||
|  | 
 | ||||||
|  |     /** 好像找不到这个字典 */ | ||||||
|  | //    @ExcelProperty(value = "配件来源", converter = DictConvert.class) | ||||||
|  | //    @DictFormat(RepairDictConstants.WARES_DATA_FORM) | ||||||
|  | //    private String dataForm; | ||||||
|  | 
 | ||||||
|  |     @ExcelProperty("备注") | ||||||
|  |     private String remark; | ||||||
|  | } | ||||||
| @ -5,6 +5,7 @@ import cn.hutool.core.collection.CollectionUtil; | |||||||
| import cn.hutool.core.util.ObjectUtil; | import cn.hutool.core.util.ObjectUtil; | ||||||
| import cn.iocoder.yudao.common.RecordTypeEnum; | import cn.iocoder.yudao.common.RecordTypeEnum; | ||||||
| import cn.iocoder.yudao.common.RepairErrorCodeConstants; | import cn.iocoder.yudao.common.RepairErrorCodeConstants; | ||||||
|  | import cn.iocoder.yudao.common.RepairRoleEnum; | ||||||
| import cn.iocoder.yudao.common.SoStatusEnum; | import cn.iocoder.yudao.common.SoStatusEnum; | ||||||
| import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils; | import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils; | ||||||
| import cn.iocoder.yudao.module.base.service.RepairRecordsService; | import cn.iocoder.yudao.module.base.service.RepairRecordsService; | ||||||
| @ -144,6 +145,12 @@ public class DlRepairSoServiceImpl extends ServiceImpl<DlRepairSoMapper, DlRepai | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         // 如果没有选择操作的人就取当前操作人 | ||||||
|  |         if (ObjectUtil.isEmpty(repairSoRespVO.getUserId())) { | ||||||
|  |             repairSoRespVO.setUserId(SecurityFrameworkUtils.getLoginUserId()); | ||||||
|  |             repairSoRespVO.setUserName(SecurityFrameworkUtils.getLoginUserNickname()); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         // 新增主表 |         // 新增主表 | ||||||
|         // 如果是采购单,就把状态变为部分入库 |         // 如果是采购单,就把状态变为部分入库 | ||||||
|         if (repairSoRespVO.getSoType() != null && repairSoRespVO.getSoType().equals("01")) { |         if (repairSoRespVO.getSoType() != null && repairSoRespVO.getSoType().equals("01")) { | ||||||
| @ -187,14 +194,20 @@ public class DlRepairSoServiceImpl extends ServiceImpl<DlRepairSoMapper, DlRepai | |||||||
|     @Override |     @Override | ||||||
|     @DSTransactional |     @DSTransactional | ||||||
|     public void voidRepairSo(DlRepairSoReqVO repairSoReqVO) { |     public void voidRepairSo(DlRepairSoReqVO repairSoReqVO) { | ||||||
|         int update = baseMapper.update(new LambdaUpdateWrapper<DlRepairSo>() |         LambdaUpdateWrapper<DlRepairSo> wrapper = new LambdaUpdateWrapper<>(); | ||||||
|                 .set(DlRepairSo::getSoStatus, SoStatusEnum.DEPRECATED.getCode()) |         wrapper.set(DlRepairSo::getSoStatus, SoStatusEnum.DEPRECATED.getCode()); | ||||||
|                 .and(i -> |         String userRole = ticketsService.getUserRole(); | ||||||
|  |         if (RepairRoleEnum.WAREHOUSE.getCode().equals(userRole)) { | ||||||
|  |             wrapper.eq(DlRepairSo::getId, repairSoReqVO.getId()); | ||||||
|  |         } else { | ||||||
|  |             wrapper.and(i -> | ||||||
|                     i.eq(DlRepairSo::getId, repairSoReqVO.getId()) |                     i.eq(DlRepairSo::getId, repairSoReqVO.getId()) | ||||||
|                             .ne(DlRepairSo::getSoStatus, SoStatusEnum.DEPRECATED.getCode()) |                             .ne(DlRepairSo::getSoStatus, SoStatusEnum.DEPRECATED.getCode()) | ||||||
|                             .ne(DlRepairSo::getSoStatus, SoStatusEnum.PICKED.getCode()) |                             .ne(DlRepairSo::getSoStatus, SoStatusEnum.PICKED.getCode()) | ||||||
|                             .ne(DlRepairSo::getSoStatus, SoStatusEnum.RETURNED.getCode()) |                             .ne(DlRepairSo::getSoStatus, SoStatusEnum.RETURNED.getCode()) | ||||||
|                 )); |             ); | ||||||
|  |         } | ||||||
|  |         int update = baseMapper.update(wrapper); | ||||||
|         if (update == 0) { |         if (update == 0) { | ||||||
|             throw exception0(500, "该单据已有其他人操作"); |             throw exception0(500, "该单据已有其他人操作"); | ||||||
|         } |         } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user