Compare commits
1 Commits
Author | SHA1 | Date |
---|---|---|
LI-CCONG\李聪聪 | bc4f2e1df8 | 1 year ago |
@ -0,0 +1,24 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<parent>
|
||||
<artifactId>yunxi</artifactId>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<version>${revision}</version>
|
||||
</parent>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<artifactId>yunxi-module-demo2</artifactId>
|
||||
<packaging>pom</packaging>
|
||||
|
||||
<name>${project.artifactId}</name>
|
||||
<description>
|
||||
demo2 模块,主要实现 XXX、YYY、ZZZ 等功能。
|
||||
</description>
|
||||
<modules>
|
||||
<module>yunxi-module-demo2-api</module>
|
||||
<module>yunxi-module-demo2-biz</module>
|
||||
</modules>
|
||||
|
||||
</project>
|
@ -0,0 +1,18 @@
|
||||
package com.yunxi.scm.module.demo2.enums;
|
||||
|
||||
/**
|
||||
* System 字典类型的枚举类
|
||||
*
|
||||
* @author 芋道源码
|
||||
*/
|
||||
public interface DictTypeConstants {
|
||||
|
||||
String USER_TYPE = "user_type"; // 用户类型
|
||||
String COMMON_STATUS = "common_status"; // 系统状态
|
||||
|
||||
String MATERIAL_STATUS = "material_status"; // 物料状态
|
||||
|
||||
// ========== SYSTEM 模块 ==========
|
||||
String TRADE_ORDER_TYPE = "trade_order_type"; // 订单交易类型
|
||||
|
||||
}
|
@ -0,0 +1,72 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<parent>
|
||||
<artifactId>yunxi-module-demo2</artifactId>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<version>${revision}</version>
|
||||
</parent>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<packaging>jar</packaging>
|
||||
|
||||
<artifactId>yunxi-module-demo2-biz</artifactId>
|
||||
|
||||
<name>${project.artifactId}</name>
|
||||
<description>
|
||||
demo 模块,主要实现 XXX、YYY、ZZZ 等功能。
|
||||
</description>
|
||||
|
||||
<!-- 新增依赖,这里引入的都是比较常用的业务组件、技术组件 -->
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<artifactId>yunxi-module-demo2-api</artifactId>
|
||||
<version>${revision}</version>
|
||||
</dependency>
|
||||
|
||||
<!-- 业务组件 -->
|
||||
<dependency>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<artifactId>yunxi-spring-boot-starter-biz-operatelog</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Web 相关 -->
|
||||
<dependency>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<artifactId>yunxi-spring-boot-starter-web</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- 功能权限 相关 -->
|
||||
<dependency>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<artifactId>yunxi-spring-boot-starter-security</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- 数据权限 相关 -->
|
||||
<dependency>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<artifactId>yunxi-spring-boot-starter-biz-data-permission</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- DB 相关 -->
|
||||
<dependency>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<artifactId>yunxi-spring-boot-starter-mybatis</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Test 测试相关 -->
|
||||
<dependency>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<artifactId>yunxi-spring-boot-starter-test</artifactId>
|
||||
</dependency>
|
||||
|
||||
<!-- Excel 相关 -->
|
||||
<dependency>
|
||||
<groupId>com.yunxi.scm</groupId>
|
||||
<artifactId>yunxi-spring-boot-starter-excel</artifactId>
|
||||
</dependency>
|
||||
|
||||
</dependencies>
|
||||
|
||||
</project>
|
@ -0,0 +1,119 @@
|
||||
package com.yunxi.scm.module.demo2.controller.admin;
|
||||
|
||||
import com.yunxi.scm.framework.common.pojo.CommonResult;
|
||||
import com.yunxi.scm.framework.excel.core.util.ExcelUtils;
|
||||
import com.yunxi.scm.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
import com.yunxi.scm.framework.operatelog.core.annotations.OperateLog;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialExportTestVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialImportTestVO;
|
||||
import com.yunxi.scm.module.demo2.convert.pmaterial.PMaterialXConvert;
|
||||
import com.yunxi.scm.module.demo2.dal.dataobject.pmaterial.PMaterialXDO;
|
||||
import com.yunxi.scm.module.demo2.dal.mysql.pmaterial.PMaterialXMapper;
|
||||
import com.yunxi.scm.module.demo2.enums.pmaterial.CategoryEnum;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
import io.swagger.v3.oas.annotations.Parameter;
|
||||
import io.swagger.v3.oas.annotations.Parameters;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import org.springframework.web.multipart.MultipartFile;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import javax.annotation.security.PermitAll;
|
||||
import javax.servlet.http.HttpServletResponse;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
import java.util.stream.Stream;
|
||||
|
||||
import static com.yunxi.scm.framework.common.pojo.CommonResult.success;
|
||||
import static com.yunxi.scm.framework.operatelog.core.enums.OperateTypeEnum.EXPORT;
|
||||
import static com.yunxi.scm.framework.operatelog.core.enums.OperateTypeEnum.IMPORT;
|
||||
|
||||
@Tag(name = "管理后台 - Test2")
|
||||
@RestController
|
||||
@RequestMapping("/demo2/test")
|
||||
@Validated
|
||||
public class DemoTest88Controller {
|
||||
|
||||
@GetMapping("/get")
|
||||
@Operation(summary = "获取 test 信息")
|
||||
@PermitAll // 无需认证即可访问
|
||||
public CommonResult<String> get() {
|
||||
return success("无需认证即可访问的后台接口");
|
||||
}
|
||||
|
||||
|
||||
@GetMapping("/test_export")
|
||||
@Operation(summary = "测试导出和字典转化")
|
||||
@PermitAll
|
||||
@OperateLog(type = EXPORT)
|
||||
public void testExport(HttpServletResponse response) throws IOException {
|
||||
PMaterialXDO xdo1 = new PMaterialXDO(1L,"80inu5yxl3",Arrays.asList("1","2"));
|
||||
PMaterialXDO xdo2 = new PMaterialXDO(2L,"Q2ZY1I9cCBf0YKvDUlzCbw==",Arrays.asList("1","3"));
|
||||
List<PMaterialXDO> xdos = new ArrayList<>();
|
||||
xdos.add(xdo1);
|
||||
xdos.add(xdo2);
|
||||
List<PMaterialExportTestVO> datas = PMaterialXConvert.INSTANCE.convertList03(xdos);
|
||||
ExcelUtils.write(response, "测试导出.xls", "数据", PMaterialExportTestVO.class, datas);
|
||||
}
|
||||
|
||||
|
||||
@PostMapping("/test_import")
|
||||
@Operation(summary = "测试导入和转化为字典")
|
||||
@PermitAll
|
||||
@OperateLog(type = IMPORT)
|
||||
@Parameters({
|
||||
@Parameter(name = "file", description = "Excel 文件", required = true),
|
||||
@Parameter(name = "updateSupport", description = "是否支持更新,默认为 false", example = "true")
|
||||
})
|
||||
public CommonResult<List<PMaterialImportTestVO>> testImport(@RequestParam("file") MultipartFile file,
|
||||
@RequestParam(value = "updateSupport", required = false, defaultValue = "false") Boolean updateSupport) throws IOException {
|
||||
List<PMaterialImportTestVO> list = ExcelUtils.read(file, PMaterialImportTestVO.class);
|
||||
return success(list);
|
||||
}
|
||||
|
||||
|
||||
@GetMapping("/get-import-template")
|
||||
@PermitAll
|
||||
@Operation(summary = "获得导入模板")
|
||||
public void importTemplate(HttpServletResponse response) throws IOException {
|
||||
List<String> values = Stream.of(CategoryEnum.COMMON.getCode(),CategoryEnum.KANJIA.getCode())
|
||||
.map(String::valueOf).collect(Collectors.toList());
|
||||
// 手动创建导出 demo
|
||||
List<PMaterialImportTestVO> list = Arrays.asList(
|
||||
PMaterialImportTestVO.builder().category(values).build()
|
||||
);
|
||||
// 输出
|
||||
ExcelUtils.write(response, "导入模板.xls", "物料标准模版", PMaterialImportTestVO.class, list);
|
||||
}
|
||||
|
||||
@Resource
|
||||
PMaterialXMapper materialXMapper;
|
||||
|
||||
@GetMapping("/test_encrypt")
|
||||
@Operation(summary = "测试字段加密")
|
||||
@PermitAll
|
||||
public CommonResult<String> testEncrypt() {
|
||||
PMaterialXDO xdo1 = new PMaterialXDO(1L,"80inu5yxl3",Arrays.asList("1","2"));
|
||||
PMaterialXDO xdo2 = new PMaterialXDO(2L,"80inu5yxl3",Arrays.asList("1","3"));
|
||||
List<PMaterialXDO> xdos = new ArrayList<>();
|
||||
xdos.add(xdo1);
|
||||
xdos.add(xdo2);
|
||||
materialXMapper.insertBatch(xdos);
|
||||
return success("ok");
|
||||
}
|
||||
|
||||
@GetMapping("/test_decrypt")
|
||||
@Operation(summary = "测试字段解密")
|
||||
@PermitAll
|
||||
public CommonResult<PMaterialExportTestVO> testDecrypt() {
|
||||
LambdaQueryWrapperX<PMaterialXDO> wrapperX = new LambdaQueryWrapperX<>();
|
||||
wrapperX.eq(PMaterialXDO::getId, 1);
|
||||
PMaterialXDO xdo = materialXMapper.selectOne(wrapperX);
|
||||
return success(PMaterialXConvert.INSTANCE.convert(xdo));
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,12 @@
|
||||
package com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo;
|
||||
|
||||
import lombok.*;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
|
||||
@Schema(description = "管理后台 - 物料管理创建 Request VO")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
public class PMaterialCreateReqVO extends PMaterialBaseVO {
|
||||
|
||||
}
|
@ -0,0 +1,56 @@
|
||||
package com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo;
|
||||
|
||||
import com.alibaba.excel.annotation.ExcelProperty;
|
||||
import com.yunxi.scm.framework.excel.core.annotations.DictFormat;
|
||||
import com.yunxi.scm.framework.excel.core.convert.DictConvert;
|
||||
import com.yunxi.scm.framework.excel.core.convert.JsonConvert;
|
||||
import com.yunxi.scm.module.demo2.enums.DictTypeConstants;
|
||||
import lombok.Data;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.time.LocalDateTime;
|
||||
import java.util.List;
|
||||
|
||||
|
||||
/**
|
||||
* 物料管理 Excel VO
|
||||
*
|
||||
* @author ccongli
|
||||
*/
|
||||
@Data
|
||||
public class PMaterialExcelVO {
|
||||
|
||||
@ExcelProperty("编号")
|
||||
private Long id;
|
||||
|
||||
@ExcelProperty("名称")
|
||||
private String name;
|
||||
|
||||
@ExcelProperty(value = "状态", converter = DictConvert.class)
|
||||
@DictFormat(DictTypeConstants.MATERIAL_STATUS)
|
||||
private Byte status;
|
||||
|
||||
@ExcelProperty(value = "类型", converter = DictConvert.class)
|
||||
@DictFormat(DictTypeConstants.TRADE_ORDER_TYPE)
|
||||
private Byte type;
|
||||
|
||||
@ExcelProperty(value = "分类", converter = JsonConvert.class)
|
||||
private List<String> categories;
|
||||
|
||||
|
||||
@ExcelProperty("图片")
|
||||
private String imgurl;
|
||||
|
||||
@ExcelProperty("库存数量")
|
||||
private Integer stock;
|
||||
|
||||
@ExcelProperty("单价")
|
||||
private BigDecimal price;
|
||||
|
||||
@ExcelProperty("备注")
|
||||
private String remark;
|
||||
|
||||
@ExcelProperty("创建时间")
|
||||
private LocalDateTime createTime;
|
||||
|
||||
}
|
@ -0,0 +1,21 @@
|
||||
package com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo;
|
||||
|
||||
import com.alibaba.excel.annotation.ExcelProperty;
|
||||
import com.yunxi.scm.framework.excel.core.annotations.DictFormat;
|
||||
import com.yunxi.scm.framework.excel.core.convert.MutilDictConvert;
|
||||
import com.yunxi.scm.module.demo2.enums.DictTypeConstants;
|
||||
import lombok.Data;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
// 测试转换
|
||||
@Data
|
||||
public class PMaterialExportTestVO {
|
||||
|
||||
@ExcelProperty(value = "密码")
|
||||
private String password;
|
||||
|
||||
@ExcelProperty(value = "分类测试", converter = MutilDictConvert.class)
|
||||
@DictFormat(DictTypeConstants.TRADE_ORDER_TYPE)
|
||||
private List<String> category;
|
||||
}
|
@ -0,0 +1,36 @@
|
||||
package com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo;
|
||||
|
||||
import com.yunxi.scm.framework.common.pojo.PageParam;
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import lombok.ToString;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
import static com.yunxi.scm.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
|
||||
|
||||
@Schema(description = "管理后台 - 物料管理分页 Request VO")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
public class PMaterialPageReqVO extends PageParam {
|
||||
|
||||
@Schema(description = "名称", example = "李四")
|
||||
private String name;
|
||||
|
||||
@Schema(description = "状态", example = "1")
|
||||
private Byte status;
|
||||
|
||||
@Schema(description = "类型", example = "2")
|
||||
private Byte type;
|
||||
|
||||
@Schema(description = "分类", example = "2")
|
||||
private String category;
|
||||
|
||||
@Schema(description = "创建时间")
|
||||
@DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
|
||||
private LocalDateTime[] createTime;
|
||||
|
||||
}
|
@ -0,0 +1,19 @@
|
||||
package com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
@Schema(description = "管理后台 - 物料管理 Response VO")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
public class PMaterialRespVO extends PMaterialBaseVO {
|
||||
|
||||
@Schema(description = "ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "14541")
|
||||
private Long id;
|
||||
|
||||
@Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||
private LocalDateTime createTime;
|
||||
|
||||
}
|
@ -0,0 +1,18 @@
|
||||
package com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo;
|
||||
|
||||
import io.swagger.v3.oas.annotations.media.Schema;
|
||||
import lombok.*;
|
||||
|
||||
import javax.validation.constraints.*;
|
||||
|
||||
@Schema(description = "管理后台 - 物料管理更新 Request VO")
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
public class PMaterialUpdateReqVO extends PMaterialBaseVO {
|
||||
|
||||
@Schema(description = "ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "14541")
|
||||
@NotNull(message = "ID不能为空")
|
||||
private Long id;
|
||||
|
||||
}
|
@ -0,0 +1,37 @@
|
||||
package com.yunxi.scm.module.demo2.convert.pmaterial;
|
||||
|
||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.*;
|
||||
import com.yunxi.scm.module.demo2.dal.dataobject.pmaterial.PMaterialDO;
|
||||
import com.yunxi.scm.module.demo2.dal.dataobject.pmaterial.PMaterialXDO;
|
||||
import org.mapstruct.Mapper;
|
||||
import org.mapstruct.factory.Mappers;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 物料管理 Convert
|
||||
*
|
||||
* @author ccongli
|
||||
*/
|
||||
@Mapper
|
||||
public interface PMaterialConvert {
|
||||
|
||||
PMaterialConvert INSTANCE = Mappers.getMapper(PMaterialConvert.class);
|
||||
|
||||
PMaterialDO convert(PMaterialCreateReqVO bean);
|
||||
|
||||
PMaterialDO convert(PMaterialUpdateReqVO bean);
|
||||
|
||||
PMaterialRespVO convert(PMaterialDO bean);
|
||||
|
||||
List<PMaterialRespVO> convertList(List<PMaterialDO> list);
|
||||
|
||||
PageResult<PMaterialRespVO> convertPage(PageResult<PMaterialDO> page);
|
||||
|
||||
List<PMaterialExcelVO> convertList02(List<PMaterialDO> list);
|
||||
|
||||
|
||||
List<PMaterialExportTestVO> convertList03(List<PMaterialXDO> list);
|
||||
|
||||
}
|
@ -0,0 +1,24 @@
|
||||
package com.yunxi.scm.module.demo2.convert.pmaterial;
|
||||
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialExportTestVO;
|
||||
import com.yunxi.scm.module.demo2.dal.dataobject.pmaterial.PMaterialXDO;
|
||||
import org.mapstruct.Mapper;
|
||||
import org.mapstruct.factory.Mappers;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 物料管理 Convert
|
||||
*
|
||||
* @author ccongli
|
||||
*/
|
||||
@Mapper
|
||||
public interface PMaterialXConvert {
|
||||
|
||||
PMaterialXConvert INSTANCE = Mappers.getMapper(PMaterialXConvert.class);
|
||||
|
||||
PMaterialExportTestVO convert(PMaterialXDO xdo);
|
||||
|
||||
List<PMaterialExportTestVO> convertList03(List<PMaterialXDO> list);
|
||||
|
||||
}
|
@ -0,0 +1,73 @@
|
||||
package com.yunxi.scm.module.demo2.dal.dataobject.pmaterial;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.KeySequence;
|
||||
import com.baomidou.mybatisplus.annotation.TableField;
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import com.yunxi.scm.framework.mybatis.core.dataobject.BaseDO;
|
||||
import com.yunxi.scm.framework.mybatis.core.type.StringListTypeHandler;
|
||||
import lombok.*;
|
||||
import org.apache.ibatis.type.Alias;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 物料管理 DO
|
||||
*
|
||||
* @author ccongli
|
||||
*/
|
||||
@TableName(value = "demo_material",autoResultMap = true)
|
||||
@KeySequence("demo_material_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ToString(callSuper = true)
|
||||
@Builder
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
@Alias("PMaterialDO2") // 解决实体类名重复映射问题
|
||||
public class PMaterialDO extends BaseDO {
|
||||
|
||||
/**
|
||||
* ID
|
||||
*/
|
||||
@TableId
|
||||
private Long id;
|
||||
/**
|
||||
* 名称
|
||||
*/
|
||||
private String name;
|
||||
/**
|
||||
* 状态
|
||||
*
|
||||
* 枚举 {@link TODO material_status 对应的类}
|
||||
*/
|
||||
private Byte status;
|
||||
/**
|
||||
* 类型
|
||||
*/
|
||||
private Byte type;
|
||||
/**
|
||||
* 分类
|
||||
*/
|
||||
// @TableField(typeHandler = JacksonTypeHandler.class)
|
||||
@TableField(typeHandler = StringListTypeHandler.class)
|
||||
private List<String> categories;
|
||||
/**
|
||||
* 图片
|
||||
*/
|
||||
private String imgurl;
|
||||
/**
|
||||
* 库存数量
|
||||
*/
|
||||
private Integer stock;
|
||||
/**
|
||||
* 单价
|
||||
*/
|
||||
private BigDecimal price;
|
||||
/**
|
||||
* 备注
|
||||
*/
|
||||
private String remark;
|
||||
|
||||
}
|
@ -0,0 +1,32 @@
|
||||
package com.yunxi.scm.module.demo2.dal.dataobject.pmaterial;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.TableField;
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import com.yunxi.scm.framework.mybatis.core.type.EncryptTypeHandler;
|
||||
import com.yunxi.scm.framework.mybatis.core.type.StringListTypeHandler;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Data;
|
||||
import lombok.NoArgsConstructor;
|
||||
import org.apache.ibatis.type.Alias;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.util.List;
|
||||
|
||||
@Data
|
||||
@NoArgsConstructor
|
||||
@AllArgsConstructor
|
||||
@TableName(value = "demo_xxx", autoResultMap = true)
|
||||
@Alias("PMaterialXDO2")
|
||||
public class PMaterialXDO implements Serializable {
|
||||
|
||||
@TableId
|
||||
private Long id;
|
||||
|
||||
// 字段加密注解
|
||||
@TableField(typeHandler = EncryptTypeHandler.class)
|
||||
private String password;
|
||||
|
||||
@TableField(typeHandler = StringListTypeHandler.class)
|
||||
private List<String> category;
|
||||
}
|
@ -0,0 +1,43 @@
|
||||
package com.yunxi.scm.module.demo2.dal.mysql.pmaterial;
|
||||
|
||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
||||
import com.yunxi.scm.framework.mybatis.core.mapper.BaseMapperX;
|
||||
import com.yunxi.scm.framework.mybatis.core.query.LambdaQueryWrapperX;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialExportReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialPageReqVO;
|
||||
import com.yunxi.scm.module.demo2.dal.dataobject.pmaterial.PMaterialDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
import org.springframework.stereotype.Repository;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 物料管理 Mapper
|
||||
*
|
||||
* @author ccongli
|
||||
*/
|
||||
@Mapper // 启动类加了MapperScan注解扫描之后可以不用再写Mapper注解
|
||||
@Repository("PMaterialMapper2")
|
||||
public interface PMaterialMapper extends BaseMapperX<PMaterialDO> {
|
||||
|
||||
default PageResult<PMaterialDO> selectPage(PMaterialPageReqVO reqVO) {
|
||||
return selectPage(reqVO, new LambdaQueryWrapperX<PMaterialDO>()
|
||||
.likeIfPresent(PMaterialDO::getName, reqVO.getName())
|
||||
.eqIfPresent(PMaterialDO::getStatus, reqVO.getStatus())
|
||||
.eqIfPresent(PMaterialDO::getType, reqVO.getType())
|
||||
.likeIfPresent(PMaterialDO::getCategories, reqVO.getCategory())
|
||||
.betweenIfPresent(PMaterialDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(PMaterialDO::getId));
|
||||
}
|
||||
|
||||
default List<PMaterialDO> selectList(PMaterialExportReqVO reqVO) {
|
||||
return selectList(new LambdaQueryWrapperX<PMaterialDO>()
|
||||
.likeIfPresent(PMaterialDO::getName, reqVO.getName())
|
||||
.eqIfPresent(PMaterialDO::getStatus, reqVO.getStatus())
|
||||
.eqIfPresent(PMaterialDO::getType, reqVO.getType())
|
||||
.likeIfPresent(PMaterialDO::getCategories, reqVO.getCategory())
|
||||
.betweenIfPresent(PMaterialDO::getCreateTime, reqVO.getCreateTime())
|
||||
.orderByDesc(PMaterialDO::getId));
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,17 @@
|
||||
package com.yunxi.scm.module.demo2.dal.mysql.pmaterial;
|
||||
|
||||
import com.yunxi.scm.framework.mybatis.core.mapper.BaseMapperX;
|
||||
import com.yunxi.scm.module.demo2.dal.dataobject.pmaterial.PMaterialXDO;
|
||||
import org.apache.ibatis.annotations.Mapper;
|
||||
import org.springframework.stereotype.Repository;
|
||||
|
||||
/**
|
||||
* 测试专用 Mapper
|
||||
*
|
||||
* @author ccongli
|
||||
*/
|
||||
@Mapper
|
||||
@Repository("PMaterialXMapper2")
|
||||
public interface PMaterialXMapper extends BaseMapperX<PMaterialXDO> {
|
||||
|
||||
}
|
@ -0,0 +1,34 @@
|
||||
package com.yunxi.scm.module.demo2.enums.pmaterial;
|
||||
|
||||
import com.yunxi.scm.framework.common.core.IntArrayValuable;
|
||||
import lombok.AllArgsConstructor;
|
||||
import lombok.Getter;
|
||||
|
||||
import java.util.Arrays;
|
||||
|
||||
@Getter
|
||||
@AllArgsConstructor
|
||||
public enum CategoryEnum implements IntArrayValuable {
|
||||
COMMON(0, "普通"),
|
||||
MIAOSHA(1, "秒杀"),
|
||||
|
||||
PINTUAN(2,"拼团"),
|
||||
|
||||
KANJIA(3, "砍价");
|
||||
|
||||
public static final int[] ARRAYS = Arrays.stream(values()).mapToInt(CategoryEnum::getCode).toArray();
|
||||
|
||||
/**
|
||||
* 状态值
|
||||
*/
|
||||
private final Integer code;
|
||||
/**
|
||||
* 状态名
|
||||
*/
|
||||
private final String name;
|
||||
|
||||
@Override
|
||||
public int[] array() {
|
||||
return ARRAYS;
|
||||
}
|
||||
}
|
@ -0,0 +1,73 @@
|
||||
package com.yunxi.scm.module.demo2.service.pmaterial;
|
||||
|
||||
import java.util.*;
|
||||
import javax.validation.*;
|
||||
import com.yunxi.scm.module.demo2.dal.dataobject.pmaterial.PMaterialDO;
|
||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialCreateReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialExportReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialPageReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialUpdateReqVO;
|
||||
|
||||
/**
|
||||
* 物料管理 Service 接口
|
||||
*
|
||||
* @author ccongli
|
||||
*/
|
||||
public interface PMaterialService {
|
||||
|
||||
/**
|
||||
* 创建物料管理
|
||||
*
|
||||
* @param createReqVO 创建信息
|
||||
* @return 编号
|
||||
*/
|
||||
Long createMaterial(@Valid PMaterialCreateReqVO createReqVO);
|
||||
|
||||
/**
|
||||
* 更新物料管理
|
||||
*
|
||||
* @param updateReqVO 更新信息
|
||||
*/
|
||||
void updateMaterial(@Valid PMaterialUpdateReqVO updateReqVO);
|
||||
|
||||
/**
|
||||
* 删除物料管理
|
||||
*
|
||||
* @param id 编号
|
||||
*/
|
||||
void deleteMaterial(Long id);
|
||||
|
||||
/**
|
||||
* 获得物料管理
|
||||
*
|
||||
* @param id 编号
|
||||
* @return 物料管理
|
||||
*/
|
||||
PMaterialDO getMaterial(Long id);
|
||||
|
||||
/**
|
||||
* 获得物料管理列表
|
||||
*
|
||||
* @param ids 编号
|
||||
* @return 物料管理列表
|
||||
*/
|
||||
List<PMaterialDO> getMaterialList(Collection<Long> ids);
|
||||
|
||||
/**
|
||||
* 获得物料管理分页
|
||||
*
|
||||
* @param pageReqVO 分页查询
|
||||
* @return 物料管理分页
|
||||
*/
|
||||
PageResult<PMaterialDO> getMaterialPage(PMaterialPageReqVO pageReqVO);
|
||||
|
||||
/**
|
||||
* 获得物料管理列表, 用于 Excel 导出
|
||||
*
|
||||
* @param exportReqVO 查询条件
|
||||
* @return 物料管理列表
|
||||
*/
|
||||
List<PMaterialDO> getMaterialList(PMaterialExportReqVO exportReqVO);
|
||||
|
||||
}
|
@ -0,0 +1,85 @@
|
||||
package com.yunxi.scm.module.demo2.service.pmaterial;
|
||||
|
||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialCreateReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialExportReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialPageReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialUpdateReqVO;
|
||||
import com.yunxi.scm.module.demo2.convert.pmaterial.PMaterialConvert;
|
||||
import com.yunxi.scm.module.demo2.dal.dataobject.pmaterial.PMaterialDO;
|
||||
import com.yunxi.scm.module.demo2.dal.mysql.pmaterial.PMaterialMapper;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
import static com.yunxi.scm.framework.common.exception.util.ServiceExceptionUtil.exception;
|
||||
import static com.yunxi.scm.module.demo2.enums.ErrorCodeConstants.MATERIAL_NOT_EXISTS;
|
||||
|
||||
/**
|
||||
* 物料管理 Service 实现类
|
||||
*
|
||||
* @author ccongli
|
||||
*/
|
||||
@Service("PMaterialServiceImpl2")
|
||||
@Validated
|
||||
public class PMaterialServiceImpl implements PMaterialService {
|
||||
|
||||
@Resource
|
||||
private PMaterialMapper pMaterialMapper;
|
||||
|
||||
@Override
|
||||
public Long createMaterial(PMaterialCreateReqVO createReqVO) {
|
||||
// 插入
|
||||
PMaterialDO material = PMaterialConvert.INSTANCE.convert(createReqVO);
|
||||
pMaterialMapper.insert(material);
|
||||
// 返回
|
||||
return material.getId();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateMaterial(PMaterialUpdateReqVO updateReqVO) {
|
||||
// 校验存在
|
||||
validateMaterialExists(updateReqVO.getId());
|
||||
// 更新
|
||||
PMaterialDO updateObj = PMaterialConvert.INSTANCE.convert(updateReqVO);
|
||||
pMaterialMapper.updateById(updateObj);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteMaterial(Long id) {
|
||||
// 校验存在
|
||||
validateMaterialExists(id);
|
||||
// 删除
|
||||
pMaterialMapper.deleteById(id);
|
||||
}
|
||||
|
||||
private void validateMaterialExists(Long id) {
|
||||
if (pMaterialMapper.selectById(id) == null) {
|
||||
throw exception(MATERIAL_NOT_EXISTS);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public PMaterialDO getMaterial(Long id) {
|
||||
return pMaterialMapper.selectById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<PMaterialDO> getMaterialList(Collection<Long> ids) {
|
||||
return pMaterialMapper.selectBatchIds(ids);
|
||||
}
|
||||
|
||||
@Override
|
||||
public PageResult<PMaterialDO> getMaterialPage(PMaterialPageReqVO pageReqVO) {
|
||||
return pMaterialMapper.selectPage(pageReqVO);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<PMaterialDO> getMaterialList(PMaterialExportReqVO exportReqVO) {
|
||||
return pMaterialMapper.selectList(exportReqVO);
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,179 @@
|
||||
package com.yunxi.scm.module.demo2.service.pmaterial;
|
||||
|
||||
import com.yunxi.scm.framework.common.pojo.PageResult;
|
||||
import com.yunxi.scm.framework.test.core.ut.BaseDbUnitTest;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialCreateReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialExportReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialPageReqVO;
|
||||
import com.yunxi.scm.module.demo2.controller.admin.pmaterial.vo.PMaterialUpdateReqVO;
|
||||
import com.yunxi.scm.module.demo2.dal.dataobject.pmaterial.PMaterialDO;
|
||||
import com.yunxi.scm.module.demo2.dal.mysql.pmaterial.PMaterialMapper;
|
||||
import org.junit.jupiter.api.Disabled;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.springframework.context.annotation.Import;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.util.List;
|
||||
|
||||
import static com.yunxi.scm.framework.common.util.date.LocalDateTimeUtils.buildBetweenTime;
|
||||
import static com.yunxi.scm.framework.common.util.object.ObjectUtils.cloneIgnoreId;
|
||||
import static com.yunxi.scm.framework.test.core.util.AssertUtils.assertPojoEquals;
|
||||
import static com.yunxi.scm.framework.test.core.util.AssertUtils.assertServiceException;
|
||||
import static com.yunxi.scm.framework.test.core.util.RandomUtils.randomLongId;
|
||||
import static com.yunxi.scm.framework.test.core.util.RandomUtils.randomPojo;
|
||||
import static com.yunxi.scm.module.demo2.enums.ErrorCodeConstants.MATERIAL_NOT_EXISTS;
|
||||
import static org.junit.jupiter.api.Assertions.*;
|
||||
|
||||
/**
|
||||
* {@link PMaterialServiceImpl} 的单元测试类
|
||||
*
|
||||
* @author ccongli
|
||||
*/
|
||||
@Import(PMaterialServiceImpl.class)
|
||||
public class MaterialServiceImplTest extends BaseDbUnitTest {
|
||||
|
||||
@Resource
|
||||
private PMaterialServiceImpl materialService;
|
||||
|
||||
@Resource
|
||||
private PMaterialMapper materialMapper;
|
||||
|
||||
@Test
|
||||
public void testCreateMaterial_success() {
|
||||
// 准备参数
|
||||
PMaterialCreateReqVO reqVO = randomPojo(PMaterialCreateReqVO.class);
|
||||
|
||||
// 调用
|
||||
Long materialId = materialService.createMaterial(reqVO);
|
||||
// 断言
|
||||
assertNotNull(materialId);
|
||||
// 校验记录的属性是否正确
|
||||
PMaterialDO material = materialMapper.selectById(materialId);
|
||||
assertPojoEquals(reqVO, material);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testUpdateMaterial_success() {
|
||||
// mock 数据
|
||||
PMaterialDO dbMaterial = randomPojo(PMaterialDO.class);
|
||||
materialMapper.insert(dbMaterial);// @Sql: 先插入出一条存在的数据
|
||||
// 准备参数
|
||||
PMaterialUpdateReqVO reqVO = randomPojo(PMaterialUpdateReqVO.class, o -> {
|
||||
o.setId(dbMaterial.getId()); // 设置更新的 ID
|
||||
});
|
||||
|
||||
// 调用
|
||||
materialService.updateMaterial(reqVO);
|
||||
// 校验是否更新正确
|
||||
PMaterialDO material = materialMapper.selectById(reqVO.getId()); // 获取最新的
|
||||
assertPojoEquals(reqVO, material);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testUpdateMaterial_notExists() {
|
||||
// 准备参数
|
||||
PMaterialUpdateReqVO reqVO = randomPojo(PMaterialUpdateReqVO.class);
|
||||
|
||||
// 调用, 并断言异常
|
||||
assertServiceException(() -> materialService.updateMaterial(reqVO), MATERIAL_NOT_EXISTS);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testDeleteMaterial_success() {
|
||||
// mock 数据
|
||||
PMaterialDO dbMaterial = randomPojo(PMaterialDO.class);
|
||||
materialMapper.insert(dbMaterial);// @Sql: 先插入出一条存在的数据
|
||||
// 准备参数
|
||||
Long id = dbMaterial.getId();
|
||||
|
||||
// 调用
|
||||
materialService.deleteMaterial(id);
|
||||
// 校验数据不存在了
|
||||
assertNull(materialMapper.selectById(id));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testDeleteMaterial_notExists() {
|
||||
// 准备参数
|
||||
Long id = randomLongId();
|
||||
|
||||
// 调用, 并断言异常
|
||||
assertServiceException(() -> materialService.deleteMaterial(id), MATERIAL_NOT_EXISTS);
|
||||
}
|
||||
|
||||
@Test
|
||||
@Disabled // TODO 请修改 null 为需要的值,然后删除 @Disabled 注解
|
||||
public void testGetMaterialPage() {
|
||||
// mock 数据
|
||||
PMaterialDO dbMaterial = randomPojo(PMaterialDO.class, o -> { // 等会查询到
|
||||
o.setName(null);
|
||||
o.setStatus(null);
|
||||
o.setType(null);
|
||||
o.setCategories(null);
|
||||
o.setCreateTime(null);
|
||||
});
|
||||
materialMapper.insert(dbMaterial);
|
||||
// 测试 name 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setName(null)));
|
||||
// 测试 status 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setStatus(null)));
|
||||
// 测试 type 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setType(null)));
|
||||
// 测试 category 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setCategories(null)));
|
||||
// 测试 createTime 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setCreateTime(null)));
|
||||
// 准备参数
|
||||
PMaterialPageReqVO reqVO = new PMaterialPageReqVO();
|
||||
reqVO.setName(null);
|
||||
reqVO.setStatus(null);
|
||||
reqVO.setType(null);
|
||||
reqVO.setCategory(null);
|
||||
reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
||||
|
||||
// 调用
|
||||
PageResult<PMaterialDO> pageResult = materialService.getMaterialPage(reqVO);
|
||||
// 断言
|
||||
assertEquals(1, pageResult.getTotal());
|
||||
assertEquals(1, pageResult.getList().size());
|
||||
assertPojoEquals(dbMaterial, pageResult.getList().get(0));
|
||||
}
|
||||
|
||||
@Test
|
||||
@Disabled // TODO 请修改 null 为需要的值,然后删除 @Disabled 注解
|
||||
public void testGetMaterialList() {
|
||||
// mock 数据
|
||||
PMaterialDO dbMaterial = randomPojo(PMaterialDO.class, o -> { // 等会查询到
|
||||
o.setName(null);
|
||||
o.setStatus(null);
|
||||
o.setType(null);
|
||||
o.setCategories(null);
|
||||
o.setCreateTime(null);
|
||||
});
|
||||
materialMapper.insert(dbMaterial);
|
||||
// 测试 name 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setName(null)));
|
||||
// 测试 status 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setStatus(null)));
|
||||
// 测试 type 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setType(null)));
|
||||
// 测试 category 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setCategories(null)));
|
||||
// 测试 createTime 不匹配
|
||||
materialMapper.insert(cloneIgnoreId(dbMaterial, o -> o.setCreateTime(null)));
|
||||
// 准备参数
|
||||
PMaterialExportReqVO reqVO = new PMaterialExportReqVO();
|
||||
reqVO.setName(null);
|
||||
reqVO.setStatus(null);
|
||||
reqVO.setType(null);
|
||||
reqVO.setCategory(null);
|
||||
reqVO.setCreateTime(buildBetweenTime(2023, 2, 1, 2023, 2, 28));
|
||||
|
||||
// 调用
|
||||
List<PMaterialDO> list = materialService.getMaterialList(reqVO);
|
||||
// 断言
|
||||
assertEquals(1, list.size());
|
||||
assertPojoEquals(dbMaterial, list.get(0));
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in new issue