siontion 10 months ago
commit 40acba466b

@ -20,13 +20,17 @@ public enum CodeEnum {
* Wt+ * Wt+
* Cus+ * Cus+
* Sup+ * Sup+
* Prs+
* St+
* */ * */
FACTORY("工厂", "Fa", 4), FACTORY("工厂", "Fa", 4),
DEPT("部门", "De", 4), DEPT("部门", "De", 4),
WORKSHOP("车间", "Ce", 4), WORKSHOP("车间", "Ce", 4),
CLASSES("班组", "Wt", 4), CLASSES("班组", "Wt", 4),
CUSTOMER("客户", "Cus", 6), CUSTOMER("客户", "Cus", 6),
SUPPLIER("供应商", "Sup", 6) SUPPLIER("供应商", "Sup", 6),
PROCEDURE("工序", "Prs", 6),
WAREHOUSE("仓库", "St", 4),
; ;

@ -1,10 +1,13 @@
package com.chanko.yunxi.mes.module.heli.controller.admin.material.vo; package com.chanko.yunxi.mes.module.heli.controller.admin.material.vo;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
import com.chanko.yunxi.mes.framework.common.pojo.PageParam; import com.chanko.yunxi.mes.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 org.springframework.format.annotation.DateTimeFormat;
import java.math.BigDecimal;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import static com.chanko.yunxi.mes.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND; import static com.chanko.yunxi.mes.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
@ -27,33 +30,12 @@ public class MaterialPageReqVO extends PageParam {
@Schema(description = "规格") @Schema(description = "规格")
private String spec; private String spec;
@Schema(description = "物料分类 零件|半成品|模具 1 2 3", example = "2")
private String materialType;
@Schema(description = "主要单位")
private String unit;
@Schema(description = "尺寸信息") @Schema(description = "尺寸信息")
private String sizeInfo; private String sizeInfo;
@Schema(description = "材质id", example = "17489")
private Long compositionId;
@Schema(description = "库存预警上限")
private Long invUpperLimit;
@Schema(description = "库存预警下限")
private Long invLowerLimit;
@Schema(description = "管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理", example = "2") @Schema(description = "管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理", example = "2")
private Integer traceType; private Integer traceType;
@Schema(description = "虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之")
private String virsualPart;
@Schema(description = "物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工")
private Integer mainFrom;
@Schema(description = "默认保存的仓库对应仓库表中的Id") @Schema(description = "默认保存的仓库对应仓库表中的Id")
private Long dftStoreWh; private Long dftStoreWh;
@ -66,9 +48,6 @@ public class MaterialPageReqVO extends PageParam {
@Schema(description = "默认工艺路线对应工艺路线表中的Id") @Schema(description = "默认工艺路线对应工艺路线表中的Id")
private Long dftRoute; private Long dftRoute;
@Schema(description = "默认包装方式对应包装方式表中的Id")
private Long dftPack;
@Schema(description = "物料描述", example = "你说的对") @Schema(description = "物料描述", example = "你说的对")
private String description; private String description;
@ -79,4 +58,43 @@ public class MaterialPageReqVO extends PageParam {
@Schema(description = "状态,1表示正常2表示禁用", example = "1") @Schema(description = "状态,1表示正常2表示禁用", example = "1")
private Integer status; private Integer status;
} @Schema(description = "物料简称", example = "赵六")
private String shortName;
@Schema(description = "物料类型", example = "1")
private String materialType;
@Schema(description = "材质id", example = "6704")
private Long compositionId;
@Schema(description = "销项税率或进项税率 (%)")
private BigDecimal outputInputTaxRate;
@Schema(description = "首选供应商", example = "15535")
private Long mainSupplierId;
@Schema(description = "物料主要来源")
private Integer mainFrom;
@Schema(description = "主要单位")
private String unit;
@Schema(description = "安全库存")
private BigDecimal invSafe;
@Schema(description = "库存预警上限")
private BigDecimal invUpperLimit;
@Schema(description = "库存预警下限")
private BigDecimal invLowerLimit;
@Schema(description = "物料条码")
private String barcode;
@Schema(description = "虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之")
private String virtualPart;
@Schema(description = "物料logo地址")
private String logo;
}

@ -1,12 +1,14 @@
package com.chanko.yunxi.mes.module.heli.controller.admin.material.vo; package com.chanko.yunxi.mes.module.heli.controller.admin.material.vo;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import com.chanko.yunxi.mes.framework.excel.core.annotations.DictFormat;
import com.chanko.yunxi.mes.framework.excel.core.convert.DictConvert;
import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*; import lombok.Data;
import java.util.*;
import java.util.*; import java.math.BigDecimal;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import com.alibaba.excel.annotation.*;
@Schema(description = "管理后台 - 物料 Response VO") @Schema(description = "管理后台 - 物料 Response VO")
@Data @Data
@ -33,42 +35,14 @@ public class MaterialRespVO {
@ExcelProperty("规格") @ExcelProperty("规格")
private String spec; private String spec;
@Schema(description = "物料分类 零件|半成品|模具 1 2 3", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@ExcelProperty("物料分类 零件|半成品|模具 1 2 3")
private String materialType;
@Schema(description = "主要单位")
@ExcelProperty("主要单位")
private String unit;
@Schema(description = "尺寸信息") @Schema(description = "尺寸信息")
@ExcelProperty("尺寸信息") @ExcelProperty("尺寸信息")
private String sizeInfo; private String sizeInfo;
@Schema(description = "材质id", requiredMode = Schema.RequiredMode.REQUIRED, example = "17489")
@ExcelProperty("材质id")
private Long compositionId;
@Schema(description = "库存预警上限")
@ExcelProperty("库存预警上限")
private Long invUpperLimit;
@Schema(description = "库存预警下限")
@ExcelProperty("库存预警下限")
private Long invLowerLimit;
@Schema(description = "管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理", example = "2") @Schema(description = "管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理", example = "2")
@ExcelProperty("管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理") @ExcelProperty("管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理")
private Integer traceType; private Integer traceType;
@Schema(description = "虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之")
@ExcelProperty("虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之")
private String virsualPart;
@Schema(description = "物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工")
@ExcelProperty("物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工")
private Integer mainFrom;
@Schema(description = "默认保存的仓库对应仓库表中的Id") @Schema(description = "默认保存的仓库对应仓库表中的Id")
@ExcelProperty("默认保存的仓库对应仓库表中的Id") @ExcelProperty("默认保存的仓库对应仓库表中的Id")
private Long dftStoreWh; private Long dftStoreWh;
@ -85,10 +59,6 @@ public class MaterialRespVO {
@ExcelProperty("默认工艺路线对应工艺路线表中的Id") @ExcelProperty("默认工艺路线对应工艺路线表中的Id")
private Long dftRoute; private Long dftRoute;
@Schema(description = "默认包装方式对应包装方式表中的Id")
@ExcelProperty("默认包装方式对应包装方式表中的Id")
private Long dftPack;
@Schema(description = "物料描述", example = "你说的对") @Schema(description = "物料描述", example = "你说的对")
@ExcelProperty("物料描述") @ExcelProperty("物料描述")
private String description; private String description;
@ -98,7 +68,67 @@ public class MaterialRespVO {
private LocalDateTime createTime; private LocalDateTime createTime;
@Schema(description = "状态,1表示正常2表示禁用", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") @Schema(description = "状态,1表示正常2表示禁用", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@ExcelProperty("状态,1表示正常2表示禁用") @ExcelProperty(value = "状态,1表示正常2表示禁用", converter = DictConvert.class)
@DictFormat("heli_common_status") // TODO 代码优化:建议设置到对应的 DictTypeConstants 枚举类中
private Integer status; private Integer status;
} @Schema(description = "物料简称", example = "赵六")
@ExcelProperty("物料简称")
private String shortName;
@Schema(description = "物料类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@ExcelProperty(value = "物料类型", converter = DictConvert.class)
@DictFormat("heli_material_type") // TODO 代码优化:建议设置到对应的 DictTypeConstants 枚举类中
private String materialType;
@Schema(description = "材质id", example = "6704")
@ExcelProperty("材质id")
private Long compositionId;
@Schema(description = "销项税率或进项税率 (%)")
@ExcelProperty("销项税率或进项税率 (%)")
private BigDecimal outputInputTaxRate;
@Schema(description = "首选供应商", example = "15535")
@ExcelProperty("首选供应商")
private Long mainSupplierId;
@Schema(description = "物料主要来源")
@ExcelProperty(value = "物料主要来源", converter = DictConvert.class)
@DictFormat("heli_material_original") // TODO 代码优化:建议设置到对应的 DictTypeConstants 枚举类中
private Integer mainFrom;
@Schema(description = "主要单位", requiredMode = Schema.RequiredMode.REQUIRED)
@ExcelProperty(value = "主要单位", converter = DictConvert.class)
@DictFormat("heli_material_unit") // TODO 代码优化:建议设置到对应的 DictTypeConstants 枚举类中
private String unit;
@Schema(description = "安全库存")
@ExcelProperty("安全库存")
private BigDecimal invSafe;
@Schema(description = "库存预警上限")
@ExcelProperty("库存预警上限")
private BigDecimal invUpperLimit;
@Schema(description = "库存预警下限")
@ExcelProperty("库存预警下限")
private BigDecimal invLowerLimit;
@Schema(description = "物料条码")
@ExcelProperty("物料条码")
private String barcode;
@Schema(description = "虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之")
@ExcelProperty("虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之")
private String virtualPart;
@Schema(description = "物料logo地址")
@ExcelProperty("物料logo地址")
private String logo;
@Schema(description = "首选供应商名称", example = "15535")
@ExcelProperty("首选供应商名称")
private String mainSupplierName;
}

@ -1,81 +1,97 @@
package com.chanko.yunxi.mes.module.heli.controller.admin.material.vo; package com.chanko.yunxi.mes.module.heli.controller.admin.material.vo;
import io.swagger.v3.oas.annotations.media.Schema; import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*; import lombok.Data;
import java.util.*;
import javax.validation.constraints.*; import javax.validation.constraints.NotEmpty;
import java.util.*; import javax.validation.constraints.NotNull;
import java.math.BigDecimal;
@Schema(description = "管理后台 - 物料新增/修改 Request VO")
@Data @Schema(description = "管理后台 - 物料新增/修改 Request VO")
public class MaterialSaveReqVO { @Data
public class MaterialSaveReqVO {
@Schema(description = "自增字段,唯一", requiredMode = Schema.RequiredMode.REQUIRED, example = "11225")
private Long id; @Schema(description = "自增字段,唯一", requiredMode = Schema.RequiredMode.REQUIRED, example = "11225")
private Long id;
@Schema(description = "物料编码", requiredMode = Schema.RequiredMode.REQUIRED)
@NotEmpty(message = "物料编码不能为空") @Schema(description = "物料编码", requiredMode = Schema.RequiredMode.REQUIRED)
private String code; @NotEmpty(message = "物料编码不能为空")
private String code;
@Schema(description = "物料名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "李四")
@NotEmpty(message = "物料名称不能为空") @Schema(description = "物料名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "李四")
private String name; @NotEmpty(message = "物料名称不能为空")
private String name;
@Schema(description = "品牌")
private String brand; @Schema(description = "品牌")
private String brand;
@Schema(description = "规格")
private String spec; @Schema(description = "规格")
private String spec;
@Schema(description = "物料分类 零件|半成品|模具 1 2 3", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@NotEmpty(message = "物料分类 零件|半成品|模具 1 2 3不能为空") @Schema(description = "尺寸信息")
private String materialType; private String sizeInfo;
@Schema(description = "主要单位") @Schema(description = "管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理", example = "2")
private String unit; private Integer traceType;
@Schema(description = "尺寸信息") @Schema(description = "默认保存的仓库对应仓库表中的Id")
private String sizeInfo; private Long dftStoreWh;
@Schema(description = "材质id", requiredMode = Schema.RequiredMode.REQUIRED, example = "17489") @Schema(description = "默认保存的库区对应库区表中的Id")
@NotNull(message = "材质id不能为空") private Long dftStoreRg;
private Long compositionId;
@Schema(description = "默认保存的库位对应库位表中的Id")
@Schema(description = "库存预警上限") private Long dftStorePn;
private Long invUpperLimit;
@Schema(description = "默认工艺路线对应工艺路线表中的Id")
@Schema(description = "库存预警下限") private Long dftRoute;
private Long invLowerLimit;
@Schema(description = "物料描述", example = "你说的对")
@Schema(description = "管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理", example = "2") private String description;
private Integer traceType;
@Schema(description = "状态,1表示正常2表示禁用", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@Schema(description = "虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之") @NotNull(message = "状态,1表示正常2表示禁用不能为空")
private String virsualPart; private Integer status;
@Schema(description = "物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工") @Schema(description = "物料简称", example = "赵六")
private Integer mainFrom; private String shortName;
@Schema(description = "默认保存的仓库对应仓库表中的Id") @Schema(description = "物料类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
private Long dftStoreWh; @NotEmpty(message = "物料类型不能为空")
private String materialType;
@Schema(description = "默认保存的库区对应库区表中的Id")
private Long dftStoreRg; @Schema(description = "材质id", example = "6704")
private Long compositionId;
@Schema(description = "默认保存的库位对应库位表中的Id")
private Long dftStorePn; @Schema(description = "销项税率或进项税率 (%)")
private BigDecimal outputInputTaxRate;
@Schema(description = "默认工艺路线对应工艺路线表中的Id")
private Long dftRoute; @Schema(description = "首选供应商", example = "15535")
private Long mainSupplierId;
@Schema(description = "默认包装方式对应包装方式表中的Id")
private Long dftPack; @Schema(description = "物料主要来源")
private Integer mainFrom;
@Schema(description = "物料描述", example = "你说的对")
private String description; @Schema(description = "主要单位", requiredMode = Schema.RequiredMode.REQUIRED)
@NotEmpty(message = "主要单位不能为空")
@Schema(description = "状态,1表示正常2表示禁用", requiredMode = Schema.RequiredMode.REQUIRED, example = "1") private String unit;
@NotNull(message = "状态,1表示正常2表示禁用不能为空")
private Integer status; @Schema(description = "安全库存")
private BigDecimal invSafe;
}
@Schema(description = "库存预警上限")
private BigDecimal invUpperLimit;
@Schema(description = "库存预警下限")
private BigDecimal invLowerLimit;
@Schema(description = "物料条码")
private String barcode;
@Schema(description = "虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之")
private String virtualPart;
@Schema(description = "物料logo地址")
private String logo;
}

@ -4,6 +4,10 @@ import lombok.*;
import java.util.*; import java.util.*;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.math.BigDecimal;
import java.math.BigDecimal;
import java.math.BigDecimal;
import java.math.BigDecimal;
import com.baomidou.mybatisplus.annotation.*; import com.baomidou.mybatisplus.annotation.*;
import com.chanko.yunxi.mes.framework.mybatis.core.dataobject.BaseDO; import com.chanko.yunxi.mes.framework.mybatis.core.dataobject.BaseDO;
@ -44,68 +48,99 @@ public class MaterialDO extends BaseDO {
*/ */
private String spec; private String spec;
/** /**
* || 1 2 3 *
*/ */
private String materialType; private String sizeInfo;
/** /**
* * ,12,12
*/ */
private String unit; private Integer traceType;
/** /**
* * Id
*/ */
private String sizeInfo; private Long dftStoreWh;
/** /**
* id * Id
*/ */
private Long compositionId; private Long dftStoreRg;
/** /**
* * Id
*/ */
private Long invUpperLimit; private Long dftStorePn;
/** /**
* * 线线Id
*/ */
private Long invLowerLimit; private Long dftRoute;
/** /**
* ,12,12 *
*/ */
private Integer traceType; private String description;
/** /**
* YNYN * ,12
*
* {@link TODO heli_common_status }
*/
private Integer status;
/**
*
*/ */
private String virsualPart; private String shortName;
/** /**
* ,123,123 *
*
* {@link TODO heli_material_type }
*/
private String materialType;
/**
* id
*/
private Long compositionId;
/**
* (%)
*/
private BigDecimal outputInputTaxRate;
/**
*
*/
private Long mainSupplierId;
/**
*
*
* {@link TODO heli_material_original }
*/ */
private Integer mainFrom; private Integer mainFrom;
/** /**
* Id *
*
* {@link TODO heli_material_unit }
*/ */
private Long dftStoreWh; private String unit;
/** /**
* Id *
*/ */
private Long dftStoreRg; private BigDecimal invSafe;
/** /**
* Id *
*/ */
private Long dftStorePn; private BigDecimal invUpperLimit;
/** /**
* 线线Id *
*/ */
private Long dftRoute; private BigDecimal invLowerLimit;
/** /**
* Id *
*/ */
private Long dftPack; private String barcode;
/** /**
* * YNYN
*/ */
private String description; private String virtualPart;
/** /**
* ,12 * logo
*/ */
private Integer status; private String logo;
@TableField(exist = false)
private String mainSupplierName;
} }

@ -23,7 +23,9 @@ public interface ClassesMapper extends BaseMapperX<ClassesDO> {
query.selectAll(ClassesDO.class) query.selectAll(ClassesDO.class)
.select("u.nickname as leaderUserName", "w.name as workshopName") .select("u.nickname as leaderUserName", "w.name as workshopName")
.leftJoin(AdminUserDO.class, "u", AdminUserDO::getId, ClassesDO::getLeaderUserId) .leftJoin(AdminUserDO.class, "u", AdminUserDO::getId, ClassesDO::getLeaderUserId)
.leftJoin(WorkshopDO.class, "w", WorkshopDO::getId, ClassesDO::getWorkshopId); .leftJoin(WorkshopDO.class, "w", WorkshopDO::getId, ClassesDO::getWorkshopId)
.disableSubLogicDel()
.orderByDesc(ClassesDO::getId);
query.like(!StringUtils.isEmpty(reqVO.getCode()), ClassesDO::getCode, reqVO.getCode()) query.like(!StringUtils.isEmpty(reqVO.getCode()), ClassesDO::getCode, reqVO.getCode())
.like(!StringUtils.isEmpty(reqVO.getName()), ClassesDO::getName, reqVO.getName()) .like(!StringUtils.isEmpty(reqVO.getName()), ClassesDO::getName, reqVO.getName())

@ -1,13 +1,13 @@
package com.chanko.yunxi.mes.module.heli.dal.mysql.material; package com.chanko.yunxi.mes.module.heli.dal.mysql.material;
import java.util.*;
import com.chanko.yunxi.mes.framework.common.pojo.PageResult; import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
import com.chanko.yunxi.mes.framework.mybatis.core.query.LambdaQueryWrapperX;
import com.chanko.yunxi.mes.framework.mybatis.core.mapper.BaseMapperX; import com.chanko.yunxi.mes.framework.mybatis.core.mapper.BaseMapperX;
import com.chanko.yunxi.mes.module.heli.controller.admin.material.vo.MaterialPageReqVO;
import com.chanko.yunxi.mes.module.heli.dal.dataobject.material.MaterialDO; import com.chanko.yunxi.mes.module.heli.dal.dataobject.material.MaterialDO;
import com.chanko.yunxi.mes.module.heli.dal.dataobject.supplier.SupplierDO;
import com.github.yulichang.wrapper.MPJLambdaWrapper;
import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Mapper;
import com.chanko.yunxi.mes.module.heli.controller.admin.material.vo.*; import org.springframework.util.StringUtils;
/** /**
* Mapper * Mapper
@ -18,29 +18,18 @@ import com.chanko.yunxi.mes.module.heli.controller.admin.material.vo.*;
public interface MaterialMapper extends BaseMapperX<MaterialDO> { public interface MaterialMapper extends BaseMapperX<MaterialDO> {
default PageResult<MaterialDO> selectPage(MaterialPageReqVO reqVO) { default PageResult<MaterialDO> selectPage(MaterialPageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<MaterialDO>() MPJLambdaWrapper<MaterialDO> query = new MPJLambdaWrapper<>();
.eqIfPresent(MaterialDO::getCode, reqVO.getCode()) query.selectAll(MaterialDO.class)
.likeIfPresent(MaterialDO::getName, reqVO.getName()) .select("s.name as mainSupplierName")
.eqIfPresent(MaterialDO::getBrand, reqVO.getBrand()) .leftJoin(SupplierDO.class, "s", SupplierDO::getId, MaterialDO::getMainSupplierId)
.eqIfPresent(MaterialDO::getSpec, reqVO.getSpec()) .disableSubLogicDel()
.eqIfPresent(MaterialDO::getMaterialType, reqVO.getMaterialType()) .orderByDesc(MaterialDO::getId);
.eqIfPresent(MaterialDO::getUnit, reqVO.getUnit()) query.like(!StringUtils.isEmpty(reqVO.getName()), MaterialDO::getName, reqVO.getName())
.eqIfPresent(MaterialDO::getSizeInfo, reqVO.getSizeInfo()) .like(!StringUtils.isEmpty(reqVO.getCode()), MaterialDO::getCode, reqVO.getCode())
.eqIfPresent(MaterialDO::getCompositionId, reqVO.getCompositionId()) .eq(!StringUtils.isEmpty(reqVO.getMaterialType()), MaterialDO::getMaterialType, reqVO.getMaterialType())
.eqIfPresent(MaterialDO::getInvUpperLimit, reqVO.getInvUpperLimit()) .eq(reqVO.getStatus() != null, MaterialDO::getStatus, reqVO.getStatus());
.eqIfPresent(MaterialDO::getInvLowerLimit, reqVO.getInvLowerLimit())
.eqIfPresent(MaterialDO::getTraceType, reqVO.getTraceType()) return selectPage(reqVO, query);
.eqIfPresent(MaterialDO::getVirsualPart, reqVO.getVirsualPart())
.eqIfPresent(MaterialDO::getMainFrom, reqVO.getMainFrom())
.eqIfPresent(MaterialDO::getDftStoreWh, reqVO.getDftStoreWh())
.eqIfPresent(MaterialDO::getDftStoreRg, reqVO.getDftStoreRg())
.eqIfPresent(MaterialDO::getDftStorePn, reqVO.getDftStorePn())
.eqIfPresent(MaterialDO::getDftRoute, reqVO.getDftRoute())
.eqIfPresent(MaterialDO::getDftPack, reqVO.getDftPack())
.eqIfPresent(MaterialDO::getDescription, reqVO.getDescription())
.betweenIfPresent(MaterialDO::getCreateTime, reqVO.getCreateTime())
.eqIfPresent(MaterialDO::getStatus, reqVO.getStatus())
.orderByDesc(MaterialDO::getId));
} }
} }

@ -23,7 +23,9 @@ public interface WorkshopMapper extends BaseMapperX<WorkshopDO> {
query.selectAll(WorkshopDO.class) query.selectAll(WorkshopDO.class)
.select("u.nickname as leaderUserName", "d.name as deptName") .select("u.nickname as leaderUserName", "d.name as deptName")
.leftJoin(AdminUserDO.class, "u", AdminUserDO::getId, WorkshopDO::getLeaderUserId) .leftJoin(AdminUserDO.class, "u", AdminUserDO::getId, WorkshopDO::getLeaderUserId)
.leftJoin(DeptDO.class, "d", DeptDO::getId, WorkshopDO::getDeptId); .leftJoin(DeptDO.class, "d", DeptDO::getId, WorkshopDO::getDeptId)
.disableSubLogicDel()
.orderByDesc(WorkshopDO::getId);
query.like(!StringUtils.isEmpty(reqVO.getCode()), WorkshopDO::getCode, reqVO.getCode()) query.like(!StringUtils.isEmpty(reqVO.getCode()), WorkshopDO::getCode, reqVO.getCode())
.like(!StringUtils.isEmpty(reqVO.getName()), WorkshopDO::getName, reqVO.getName()) .like(!StringUtils.isEmpty(reqVO.getName()), WorkshopDO::getName, reqVO.getName())

@ -1,74 +1,71 @@
package com.chanko.yunxi.mes.module.heli.service.material; package com.chanko.yunxi.mes.module.heli.service.material;
import org.springframework.stereotype.Service; import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
import javax.annotation.Resource; import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
import org.springframework.validation.annotation.Validated; import com.chanko.yunxi.mes.module.heli.controller.admin.material.vo.MaterialPageReqVO;
import org.springframework.transaction.annotation.Transactional; import com.chanko.yunxi.mes.module.heli.controller.admin.material.vo.MaterialSaveReqVO;
import com.chanko.yunxi.mes.module.heli.dal.dataobject.material.MaterialDO;
import java.util.*; import com.chanko.yunxi.mes.module.heli.dal.mysql.material.MaterialMapper;
import com.chanko.yunxi.mes.module.heli.controller.admin.material.vo.*; import org.springframework.stereotype.Service;
import com.chanko.yunxi.mes.module.heli.dal.dataobject.material.MaterialDO; import org.springframework.validation.annotation.Validated;
import com.chanko.yunxi.mes.framework.common.pojo.PageResult;
import com.chanko.yunxi.mes.framework.common.pojo.PageParam; import javax.annotation.Resource;
import com.chanko.yunxi.mes.framework.common.util.object.BeanUtils;
import static com.chanko.yunxi.mes.framework.common.exception.util.ServiceExceptionUtil.exception;
import com.chanko.yunxi.mes.module.heli.dal.mysql.material.MaterialMapper; import static com.chanko.yunxi.mes.module.heli.enums.ErrorCodeConstants.MATERIAL_NOT_EXISTS;
import static com.chanko.yunxi.mes.framework.common.exception.util.ServiceExceptionUtil.exception; /**
import static com.chanko.yunxi.mes.module.heli.enums.ErrorCodeConstants.*; * Service
*
/** * @author
* Service */
* @Service
* @author @Validated
*/ public class MaterialServiceImpl implements MaterialService {
@Service
@Validated @Resource
public class MaterialServiceImpl implements MaterialService { private MaterialMapper materialMapper;
@Resource @Override
private MaterialMapper materialMapper; public Long createMaterial(MaterialSaveReqVO createReqVO) {
// 插入
@Override MaterialDO material = BeanUtils.toBean(createReqVO, MaterialDO.class);
public Long createMaterial(MaterialSaveReqVO createReqVO) { materialMapper.insert(material);
// 插入 // 返回
MaterialDO material = BeanUtils.toBean(createReqVO, MaterialDO.class); return material.getId();
materialMapper.insert(material); }
// 返回
return material.getId(); @Override
} public void updateMaterial(MaterialSaveReqVO updateReqVO) {
// 校验存在
@Override validateMaterialExists(updateReqVO.getId());
public void updateMaterial(MaterialSaveReqVO updateReqVO) { // 更新
// 校验存在 MaterialDO updateObj = BeanUtils.toBean(updateReqVO, MaterialDO.class);
validateMaterialExists(updateReqVO.getId()); materialMapper.updateById(updateObj);
// 更新 }
MaterialDO updateObj = BeanUtils.toBean(updateReqVO, MaterialDO.class);
materialMapper.updateById(updateObj); @Override
} public void deleteMaterial(Long id) {
// 校验存在
@Override validateMaterialExists(id);
public void deleteMaterial(Long id) { // 删除
// 校验存在 materialMapper.deleteById(id);
validateMaterialExists(id); }
// 删除
materialMapper.deleteById(id); private void validateMaterialExists(Long id) {
} if (materialMapper.selectById(id) == null) {
throw exception(MATERIAL_NOT_EXISTS);
private void validateMaterialExists(Long id) { }
if (materialMapper.selectById(id) == null) { }
throw exception(MATERIAL_NOT_EXISTS);
} @Override
} public MaterialDO getMaterial(Long id) {
return materialMapper.selectById(id);
@Override }
public MaterialDO getMaterial(Long id) {
return materialMapper.selectById(id); @Override
} public PageResult<MaterialDO> getMaterialPage(MaterialPageReqVO pageReqVO) {
return materialMapper.selectPage(pageReqVO);
@Override }
public PageResult<MaterialDO> getMaterialPage(MaterialPageReqVO pageReqVO) {
return materialMapper.selectPage(pageReqVO); }
}
}

@ -153,6 +153,8 @@ spring:
logging: logging:
file: file:
name: ${user.home}/logs/${spring.application.name}.log # 日志文件名,全路径 name: ${user.home}/logs/${spring.application.name}.log # 日志文件名,全路径
level:
com.chanko.yunxi.mes.module.heli: debug
--- #################### 微信公众号相关配置 #################### --- #################### 微信公众号相关配置 ####################
wx: # 参见 https://github.com/Wechat-Group/WxJava/blob/develop/spring-boot-starters/wx-java-mp-spring-boot-starter/README.md 文档 wx: # 参见 https://github.com/Wechat-Group/WxJava/blob/develop/spring-boot-starters/wx-java-mp-spring-boot-starter/README.md 文档

@ -60,8 +60,8 @@
<springProfile name="local"> <springProfile name="local">
<root level="INFO"> <root level="INFO">
<appender-ref ref="STDOUT"/> <appender-ref ref="STDOUT"/>
<appender-ref ref="GRPC"/> <!-- 本地环境下,如果不想接入 SkyWalking 日志服务,可以注释掉本行 --> <!--<appender-ref ref="GRPC"/> 本地环境下,如果不想接入 SkyWalking 日志服务,可以注释掉本行 -->
<appender-ref ref="ASYNC"/> <!-- 本地环境下,如果不想打印日志,可以注释掉本行 --> <!-- <appender-ref ref="ASYNC"/> 本地环境下,如果不想打印日志,可以注释掉本行 -->
</root> </root>
</springProfile> </springProfile>
<!-- 其它环境 --> <!-- 其它环境 -->

@ -1,55 +1,60 @@
import request from '@/config/axios' import request from '@/config/axios'
export interface MaterialVO { export interface MaterialVO {
id: number id: number
code: string code: string
name: string name: string
brand: string brand: string
spec: string spec: string
materialType: string sizeInfo: string
unit: string traceType: number
sizeInfo: string dftStoreWh: number
compositionId: number dftStoreRg: number
invUpperLimit: number dftStorePn: number
invLowerLimit: number dftRoute: number
traceType: number description: string
virsualPart: string status: number
mainFrom: number shortName: string
dftStoreWh: number materialType: string
dftStoreRg: number compositionId: number
dftStorePn: number outputInputTaxRate: number
dftRoute: number mainSupplierId: number
dftPack: number mainFrom: number
description: string unit: string
status: number invSafe: number
} invUpperLimit: number
invLowerLimit: number
// 查询物料分页 barcode: string
export const getMaterialPage = async (params) => { virtualPart: string
return await request.get({ url: `/heli/material/page`, params }) logo: string
} }
// 查询物料详情 // 查询物料分页
export const getMaterial = async (id: number) => { export const getMaterialPage = async (params) => {
return await request.get({ url: `/heli/material/get?id=` + id }) return await request.get({ url: `/heli/material/page`, params })
} }
// 新增物料 // 查询物料详情
export const createMaterial = async (data: MaterialVO) => { export const getMaterial = async (id: number) => {
return await request.post({ url: `/heli/material/create`, data }) return await request.get({ url: `/heli/material/get?id=` + id })
} }
// 修改物料 // 新增物料
export const updateMaterial = async (data: MaterialVO) => { export const createMaterial = async (data: MaterialVO) => {
return await request.put({ url: `/heli/material/update`, data }) return await request.post({ url: `/heli/material/create`, data })
} }
// 删除物料 // 修改物料
export const deleteMaterial = async (id: number) => { export const updateMaterial = async (data: MaterialVO) => {
return await request.delete({ url: `/heli/material/delete?id=` + id }) return await request.put({ url: `/heli/material/update`, data })
} }
// 导出物料 Excel // 删除物料
export const exportMaterial = async (params) => { export const deleteMaterial = async (id: number) => {
return await request.download({ url: `/heli/material/export-excel`, params }) return await request.delete({ url: `/heli/material/delete?id=` + id })
} }
// 导出物料 Excel
export const exportMaterial = async (params) => {
return await request.download({ url: `/heli/material/export-excel`, params })
}

@ -212,5 +212,9 @@ export enum DICT_TYPE {
HELI_COMPOSITION_ORIGINAL = 'heli_composition_original', // 材质主要来源 HELI_COMPOSITION_ORIGINAL = 'heli_composition_original', // 材质主要来源
HELI_SUPPLIER_LEVEL = 'heli_supplier_level', //供应商级别 HELI_SUPPLIER_LEVEL = 'heli_supplier_level', //供应商级别
HELI_SUPPLIER_CATEGORY = 'heli_supplier_category', //供应商分类 HELI_SUPPLIER_CATEGORY = 'heli_supplier_category', //供应商分类
HELI_MATERIAL_TYPE = 'heli_material_type', // 物料类型
HELI_MATERIAL_UNIT = 'heli_material_unit', // 物料单位
HELI_MATERIAL_ORIGINAL = 'heli_material_original', // 物料主要来源
} }

@ -4,75 +4,100 @@
ref="formRef" ref="formRef"
:model="formData" :model="formData"
:rules="formRules" :rules="formRules"
label-width="100px" label-width="150px"
v-loading="formLoading" v-loading="formLoading"
> >
<el-form-item label="物料图片" prop="logo">
<UploadImg v-model="formData.logo" />
</el-form-item>
<el-form-item label="物料编码" prop="code"> <el-form-item label="物料编码" prop="code">
<el-input v-model="formData.code" placeholder="请输入物料编码" /> <el-input v-model="formData.code" placeholder="请输入物料编码" />
</el-form-item> </el-form-item>
<el-form-item label="物料名称" prop="name"> <el-form-item label="物料名称" prop="name">
<el-input v-model="formData.name" placeholder="请输入物料名称" /> <el-input v-model="formData.name" placeholder="请输入物料名称" />
</el-form-item> </el-form-item>
<el-form-item label="品牌" prop="brand"> <el-form-item label="物料类型" prop="materialType">
<el-input v-model="formData.brand" placeholder="请输入品牌" /> <el-select v-model="formData.materialType" placeholder="请选择物料类型">
</el-form-item> <el-option
<el-form-item label="规格" prop="spec"> v-for="dict in getStrDictOptions(DICT_TYPE.HELI_MATERIAL_TYPE)"
<el-input v-model="formData.spec" placeholder="请输入规格" /> :key="dict.value"
</el-form-item> :label="dict.label"
<el-form-item label="物料分类 零件|半成品|模具 1 2 3" prop="materialType"> :value="dict.value"
<el-select v-model="formData.materialType" placeholder="请选择物料分类 零件|半成品|模具 1 2 3"> />
<el-option label="请选择字典生成" value="" />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="主要单位" prop="unit"> <el-form-item label="系统单位" prop="unit">
<el-input v-model="formData.unit" placeholder="请输入主要单位" /> <el-select v-model="formData.unit" placeholder="请选择系统单位">
</el-form-item> <el-option
<el-form-item label="尺寸信息" prop="sizeInfo"> v-for="dict in getStrDictOptions(DICT_TYPE.HELI_MATERIAL_UNIT)"
<el-input v-model="formData.sizeInfo" placeholder="请输入尺寸信息" /> :key="dict.value"
</el-form-item> :label="dict.label"
<el-form-item label="材质id" prop="compositionId"> :value="dict.value"
<el-input v-model="formData.compositionId" placeholder="请输入材质id" /> />
</el-form-item>
<el-form-item label="库存预警上限" prop="invUpperLimit">
<el-input v-model="formData.invUpperLimit" placeholder="请输入库存预警上限" />
</el-form-item>
<el-form-item label="库存预警下限" prop="invLowerLimit">
<el-input v-model="formData.invLowerLimit" placeholder="请输入库存预警下限" />
</el-form-item>
<el-form-item label="管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理" prop="traceType">
<el-select v-model="formData.traceType" placeholder="请选择管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理">
<el-option label="请选择字典生成" value="" />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之" prop="virsualPart"> <el-form-item label="物料简称" prop="shortName">
<el-input v-model="formData.virsualPart" placeholder="请输入虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之" /> <el-input v-model="formData.shortName" placeholder="请输入物料简称" />
</el-form-item> </el-form-item>
<el-form-item label="物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工" prop="mainFrom"> <el-form-item label="规格/型号" prop="spec">
<el-input v-model="formData.mainFrom" placeholder="请输入物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工" /> <el-input v-model="formData.spec" placeholder="请输入规格/型号" />
</el-form-item> </el-form-item>
<el-form-item label="默认保存的仓库对应仓库表中的Id" prop="dftStoreWh"> <el-form-item label="品牌" prop="brand">
<el-input v-model="formData.dftStoreWh" placeholder="请输入默认保存的仓库对应仓库表中的Id" /> <el-input v-model="formData.brand" placeholder="请输入品牌" />
</el-form-item>
<el-form-item label="默认保存的库区对应库区表中的Id" prop="dftStoreRg">
<el-input v-model="formData.dftStoreRg" placeholder="请输入默认保存的库区对应库区表中的Id" />
</el-form-item> </el-form-item>
<el-form-item label="默认保存的库位对应库位表中的Id" prop="dftStorePn"> <el-form-item label="物料主要来源" prop="mainFrom">
<el-input v-model="formData.dftStorePn" placeholder="请输入默认保存的库位对应库位表中的Id" /> <el-select v-model="formData.mainFrom" placeholder="请选择物料主要来源">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HELI_MATERIAL_ORIGINAL)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item> </el-form-item>
<el-form-item label="默认工艺路线对应工艺路线表中的Id" prop="dftRoute"> <el-form-item label="首选供应商" prop="mainSupplierId">
<el-input v-model="formData.dftRoute" placeholder="请输入默认工艺路线对应工艺路线表中的Id" /> <el-select v-model="formData.mainSupplierId"
placeholder="请输入首选供应商"
:remote-method="remoteSupplierSearch"
remote-show-suffix
remote
reserve-keyword
filterable
:loading="supplierSelectLoading"
>
<el-option
v-for="item in supplierSelectList"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item> </el-form-item>
<el-form-item label="默认包装方式对应包装方式表中的Id" prop="dftPack"> <el-form-item label="销项税率/进项税率" prop="outputInputTaxRate">
<el-input v-model="formData.dftPack" placeholder="请输入默认包装方式对应包装方式表中的Id" /> <el-input v-model="formData.outputInputTaxRate" placeholder="请输入销项税率/进项税率" >
<template #append>%</template>
</el-input>
</el-form-item> </el-form-item>
<el-form-item label="物料描述" prop="description"> <el-form-item label="备注" prop="description">
<Editor v-model="formData.description" height="150px" /> <el-input type="textarea" v-model="formData.description" height="150px" />
</el-form-item> </el-form-item>
<el-form-item label="状态,1表示正常2表示禁用" prop="status"> <el-form-item label="启用状态" prop="status">
<el-radio-group v-model="formData.status"> <el-radio-group v-model="formData.status">
<el-radio label="1">请选择字典生成</el-radio> <el-radio
v-for="dict in getIntDictOptions(DICT_TYPE.HELI_COMMON_STATUS)"
:key="dict.value"
:label="dict.value"
>
{{ dict.label }}
</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item label="安全库存" prop="invSafe">
<el-input v-model="formData.invSafe" placeholder="请输入安全库存" />
</el-form-item>
<el-form-item label="物料条码" prop="barcode">
<el-input v-model="formData.barcode" placeholder="请输入物料条码" />
</el-form-item>
</el-form> </el-form>
<template #footer> <template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button> <el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
@ -81,7 +106,9 @@
</Dialog> </Dialog>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { getIntDictOptions, getStrDictOptions, getBoolDictOptions, DICT_TYPE } from '@/utils/dict'
import * as MaterialApi from '@/api/heli/material' import * as MaterialApi from '@/api/heli/material'
import {getSupplierPage} from "@/api/heli/supplier";
const { t } = useI18n() // const { t } = useI18n() //
const message = useMessage() // const message = useMessage() //
@ -96,32 +123,54 @@ const formData = ref({
name: undefined, name: undefined,
brand: undefined, brand: undefined,
spec: undefined, spec: undefined,
materialType: undefined,
unit: undefined,
sizeInfo: undefined, sizeInfo: undefined,
compositionId: undefined,
invUpperLimit: undefined,
invLowerLimit: undefined,
traceType: undefined, traceType: undefined,
virsualPart: undefined,
mainFrom: undefined,
dftStoreWh: undefined, dftStoreWh: undefined,
dftStoreRg: undefined, dftStoreRg: undefined,
dftStorePn: undefined, dftStorePn: undefined,
dftRoute: undefined, dftRoute: undefined,
dftPack: undefined,
description: undefined, description: undefined,
status: undefined, status: 1,
shortName: undefined,
materialType: undefined,
compositionId: undefined,
outputInputTaxRate: undefined,
mainSupplierId: undefined,
mainFrom: undefined,
unit: undefined,
invSafe: undefined,
invUpperLimit: undefined,
invLowerLimit: undefined,
barcode: undefined,
virtualPart: undefined,
logo: undefined,
}) })
const formRules = reactive({ const formRules = reactive({
code: [{ required: true, message: '物料编码不能为空', trigger: 'blur' }], code: [{ required: true, message: '物料编码不能为空', trigger: 'blur' }],
name: [{ required: true, message: '物料名称不能为空', trigger: 'blur' }], name: [{ required: true, message: '物料名称不能为空', trigger: 'blur' }],
materialType: [{ required: true, message: '物料分类 零件|半成品|模具 1 2 3不能为空', trigger: 'change' }], status: [{ required: true, message: '启用状态不能为空', trigger: 'blur' }],
compositionId: [{ required: true, message: '材质id不能为空', trigger: 'blur' }], materialType: [{ required: true, message: '物料类型不能为空', trigger: 'change' }],
status: [{ required: true, message: '状态,1表示正常2表示禁用不能为空', trigger: 'blur' }], unit: [{ required: true, message: '系统单位不能为空', trigger: 'change' }],
}) })
const formRef = ref() // Ref const formRef = ref() // Ref
const supplierList = ref<any[]>([]) //
const supplierSelectList = ref<any[]>([])
const supplierSelectLoading = ref(false);
const remoteSupplierSearch = (query: string) => {
if (query) {
supplierSelectLoading.value = true
setTimeout(() => {
supplierSelectLoading.value = false
supplierSelectList.value = supplierList.value.filter((item) => {
return item.name.toLowerCase().includes(query.toLowerCase())
})
}, 200)
} else {
supplierSelectList.value = []
}
}
/** 打开弹窗 */ /** 打开弹窗 */
const open = async (type: string, id?: number) => { const open = async (type: string, id?: number) => {
dialogVisible.value = true dialogVisible.value = true
@ -129,14 +178,22 @@ const open = async (type: string, id?: number) => {
formType.value = type formType.value = type
resetForm() resetForm()
// //
if (id) { formLoading.value = true
formLoading.value = true try {
try { if (id) {
formData.value = await MaterialApi.getMaterial(id) formData.value = await MaterialApi.getMaterial(id)
} finally {
formLoading.value = false
} }
let params = {
pageNo: 1,
pageSize: 99
};
const supplierData = await getSupplierPage(params);
supplierList.value = supplierData.list;
supplierSelectList.value = supplierData.list;
} finally {
formLoading.value = false
} }
} }
defineExpose({ open }) // open defineExpose({ open }) // open
@ -172,23 +229,28 @@ const resetForm = () => {
name: undefined, name: undefined,
brand: undefined, brand: undefined,
spec: undefined, spec: undefined,
materialType: undefined,
unit: undefined,
sizeInfo: undefined, sizeInfo: undefined,
compositionId: undefined,
invUpperLimit: undefined,
invLowerLimit: undefined,
traceType: undefined, traceType: undefined,
virsualPart: undefined,
mainFrom: undefined,
dftStoreWh: undefined, dftStoreWh: undefined,
dftStoreRg: undefined, dftStoreRg: undefined,
dftStorePn: undefined, dftStorePn: undefined,
dftRoute: undefined, dftRoute: undefined,
dftPack: undefined,
description: undefined, description: undefined,
status: undefined, status: 1,
shortName: undefined,
materialType: undefined,
compositionId: undefined,
outputInputTaxRate: undefined,
mainSupplierId: undefined,
mainFrom: undefined,
unit: undefined,
invSafe: undefined,
invUpperLimit: undefined,
invLowerLimit: undefined,
barcode: undefined,
virtualPart: undefined,
logo: undefined,
} }
formRef.value?.resetFields() formRef.value?.resetFields()
} }
</script> </script>

@ -26,171 +26,34 @@
class="!w-240px" class="!w-240px"
/> />
</el-form-item> </el-form-item>
<el-form-item label="品牌" prop="brand"> <el-form-item label="物料类型" prop="materialType">
<el-input
v-model="queryParams.brand"
placeholder="请输入品牌"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="规格" prop="spec">
<el-input
v-model="queryParams.spec"
placeholder="请输入规格"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="物料分类 零件|半成品|模具 1 2 3" prop="materialType">
<el-select <el-select
v-model="queryParams.materialType" v-model="queryParams.materialType"
placeholder="请选择物料分类 零件|半成品|模具 1 2 3" placeholder="请选择物料类型"
clearable clearable
class="!w-240px" class="!w-240px"
> >
<el-option label="请选择字典生成" value="" /> <el-option
v-for="dict in getStrDictOptions(DICT_TYPE.HELI_MATERIAL_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="主要单位" prop="unit"> <el-form-item label="启用状态" prop="status">
<el-input
v-model="queryParams.unit"
placeholder="请输入主要单位"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="尺寸信息" prop="sizeInfo">
<el-input
v-model="queryParams.sizeInfo"
placeholder="请输入尺寸信息"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="材质id" prop="compositionId">
<el-input
v-model="queryParams.compositionId"
placeholder="请输入材质id"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="库存预警上限" prop="invUpperLimit">
<el-input
v-model="queryParams.invUpperLimit"
placeholder="请输入库存预警上限"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="库存预警下限" prop="invLowerLimit">
<el-input
v-model="queryParams.invLowerLimit"
placeholder="请输入库存预警下限"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理" prop="traceType">
<el-select
v-model="queryParams.traceType"
placeholder="请选择管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理"
clearable
class="!w-240px"
>
<el-option label="请选择字典生成" value="" />
</el-select>
</el-form-item>
<el-form-item label="虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之" prop="virsualPart">
<el-input
v-model="queryParams.virsualPart"
placeholder="请输入虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工" prop="mainFrom">
<el-input
v-model="queryParams.mainFrom"
placeholder="请输入物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="默认保存的仓库对应仓库表中的Id" prop="dftStoreWh">
<el-input
v-model="queryParams.dftStoreWh"
placeholder="请输入默认保存的仓库对应仓库表中的Id"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="默认保存的库区对应库区表中的Id" prop="dftStoreRg">
<el-input
v-model="queryParams.dftStoreRg"
placeholder="请输入默认保存的库区对应库区表中的Id"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="默认保存的库位对应库位表中的Id" prop="dftStorePn">
<el-input
v-model="queryParams.dftStorePn"
placeholder="请输入默认保存的库位对应库位表中的Id"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="默认工艺路线对应工艺路线表中的Id" prop="dftRoute">
<el-input
v-model="queryParams.dftRoute"
placeholder="请输入默认工艺路线对应工艺路线表中的Id"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="默认包装方式对应包装方式表中的Id" prop="dftPack">
<el-input
v-model="queryParams.dftPack"
placeholder="请输入默认包装方式对应包装方式表中的Id"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="创建时间" prop="createTime">
<el-date-picker
v-model="queryParams.createTime"
value-format="YYYY-MM-DD HH:mm:ss"
type="daterange"
start-placeholder="开始日期"
end-placeholder="结束日期"
:default-time="[new Date('1 00:00:00'), new Date('1 23:59:59')]"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="状态,1表示正常2表示禁用" prop="status">
<el-select <el-select
v-model="queryParams.status" v-model="queryParams.status"
placeholder="请选择状态,1表示正常2表示禁用" placeholder="请选择启用状态"
clearable clearable
class="!w-240px" class="!w-240px"
> >
<el-option label="请选择字典生成" value="" /> <el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HELI_COMMON_STATUS)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
@ -204,7 +67,7 @@
> >
<Icon icon="ep:plus" class="mr-5px" /> 新增 <Icon icon="ep:plus" class="mr-5px" /> 新增
</el-button> </el-button>
<el-button <!-- <el-button
type="success" type="success"
plain plain
@click="handleExport" @click="handleExport"
@ -212,7 +75,7 @@
v-hasPermi="['heli:material:export']" v-hasPermi="['heli:material:export']"
> >
<Icon icon="ep:download" class="mr-5px" /> 导出 <Icon icon="ep:download" class="mr-5px" /> 导出
</el-button> </el-button>-->
</el-form-item> </el-form-item>
</el-form> </el-form>
</ContentWrap> </ContentWrap>
@ -220,35 +83,34 @@
<!-- 列表 --> <!-- 列表 -->
<ContentWrap> <ContentWrap>
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true"> <el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="自增字段,唯一" align="center" prop="id" /> <el-table-column fixed label="序号" type="index" width="100" />
<el-table-column label="物料编码" align="center" prop="code" /> <el-table-column fixed label="物料编码" align="center" prop="code" />
<el-table-column label="物料名称" align="center" prop="name" /> <el-table-column label="物料名称" align="center" prop="name" />
<el-table-column label="物料类型" align="center" prop="materialType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HELI_MATERIAL_TYPE" :value="scope.row.materialType" />
</template>
</el-table-column>
<el-table-column label="系统单位" align="center" prop="unit">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HELI_MATERIAL_UNIT" :value="scope.row.unit" />
</template>
</el-table-column>
<el-table-column label="物料简称" align="center" prop="shortName" />
<el-table-column label="规格/型号" align="center" prop="spec" />
<el-table-column label="品牌" align="center" prop="brand" /> <el-table-column label="品牌" align="center" prop="brand" />
<el-table-column label="规格" align="center" prop="spec" /> <el-table-column label="主要来源" align="center" prop="mainFrom">
<el-table-column label="物料分类 零件|半成品|模具 1 2 3" align="center" prop="materialType" /> <template #default="scope">
<el-table-column label="主要单位" align="center" prop="unit" /> <dict-tag :type="DICT_TYPE.HELI_MATERIAL_ORIGINAL" :value="scope.row.mainFrom" />
<el-table-column label="尺寸信息" align="center" prop="sizeInfo" /> </template>
<el-table-column label="材质id" align="center" prop="compositionId" /> </el-table-column>
<el-table-column label="库存预警上限" align="center" prop="invUpperLimit" /> <el-table-column label="首选供应商" align="center" prop="mainSupplierName" />
<el-table-column label="库存预警下限" align="center" prop="invLowerLimit" /> <el-table-column label="启用状态" align="center" prop="status">
<el-table-column label="管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理" align="center" prop="traceType" /> <template #default="scope">
<el-table-column label="虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之" align="center" prop="virsualPart" /> <dict-tag :type="DICT_TYPE.HELI_COMMON_STATUS" :value="scope.row.status" />
<el-table-column label="物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工" align="center" prop="mainFrom" /> </template>
<el-table-column label="默认保存的仓库对应仓库表中的Id" align="center" prop="dftStoreWh" /> </el-table-column>
<el-table-column label="默认保存的库区对应库区表中的Id" align="center" prop="dftStoreRg" /> <el-table-column fixed="right" label="操作" align="center">
<el-table-column label="默认保存的库位对应库位表中的Id" align="center" prop="dftStorePn" />
<el-table-column label="默认工艺路线对应工艺路线表中的Id" align="center" prop="dftRoute" />
<el-table-column label="默认包装方式对应包装方式表中的Id" align="center" prop="dftPack" />
<el-table-column label="物料描述" align="center" prop="description" />
<el-table-column
label="创建时间"
align="center"
prop="createTime"
:formatter="dateFormatter"
width="180px"
/>
<el-table-column label="状态,1表示正常2表示禁用" align="center" prop="status" />
<el-table-column label="操作" align="center">
<template #default="scope"> <template #default="scope">
<el-button <el-button
link link
@ -258,14 +120,14 @@
> >
编辑 编辑
</el-button> </el-button>
<el-button <!-- <el-button
link link
type="danger" type="danger"
@click="handleDelete(scope.row.id)" @click="handleDelete(scope.row.id)"
v-hasPermi="['heli:material:delete']" v-hasPermi="['heli:material:delete']"
> >
删除 删除
</el-button> </el-button>-->
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
@ -283,6 +145,7 @@
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { getIntDictOptions, getStrDictOptions, getBoolDictOptions, DICT_TYPE } from '@/utils/dict'
import { dateFormatter } from '@/utils/formatTime' import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download' import download from '@/utils/download'
import * as MaterialApi from '@/api/heli/material' import * as MaterialApi from '@/api/heli/material'
@ -303,23 +166,28 @@ const queryParams = reactive({
name: undefined, name: undefined,
brand: undefined, brand: undefined,
spec: undefined, spec: undefined,
materialType: undefined,
unit: undefined,
sizeInfo: undefined, sizeInfo: undefined,
compositionId: undefined,
invUpperLimit: undefined,
invLowerLimit: undefined,
traceType: undefined, traceType: undefined,
virsualPart: undefined,
mainFrom: undefined,
dftStoreWh: undefined, dftStoreWh: undefined,
dftStoreRg: undefined, dftStoreRg: undefined,
dftStorePn: undefined, dftStorePn: undefined,
dftRoute: undefined, dftRoute: undefined,
dftPack: undefined,
description: undefined, description: undefined,
createTime: [], createTime: [],
status: undefined, status: 1,
shortName: undefined,
materialType: undefined,
compositionId: undefined,
outputInputTaxRate: undefined,
mainSupplierId: undefined,
mainFrom: undefined,
unit: undefined,
invSafe: undefined,
invUpperLimit: undefined,
invLowerLimit: undefined,
barcode: undefined,
virtualPart: undefined,
logo: undefined,
}) })
const queryFormRef = ref() // const queryFormRef = ref() //
const exportLoading = ref(false) // const exportLoading = ref(false) //
@ -386,4 +254,4 @@ const handleExport = async () => {
onMounted(() => { onMounted(() => {
getList() getList()
}) })
</script> </script>

@ -1,6 +1,6 @@
<template> <template>
<Dialog v-model="dialogVisible" title="菜单权限"> <Dialog v-model="dialogVisible" title="菜单权限">
<el-form ref="formRef" v-loading="formLoading" :model="formData" label-width="80px"> <el-form ref="formRef" v-loading="formLoading" :model="formData" label-width="108px">
<el-form-item label="角色名称"> <el-form-item label="角色名称">
<el-tag>{{ formData.name }}</el-tag> <el-tag>{{ formData.name }}</el-tag>
</el-form-item> </el-form-item>

@ -1,6 +1,6 @@
<template> <template>
<Dialog v-model="dialogVisible" title="菜单权限" width="800"> <Dialog v-model="dialogVisible" title="数据权限" width="800">
<el-form ref="formRef" v-loading="formLoading" :model="formData" label-width="80px"> <el-form ref="formRef" v-loading="formLoading" :model="formData" label-width="108px">
<el-form-item label="角色名称"> <el-form-item label="角色名称">
<el-tag>{{ formData.name }}</el-tag> <el-tag>{{ formData.name }}</el-tag>
</el-form-item> </el-form-item>

@ -5,7 +5,7 @@
v-loading="formLoading" v-loading="formLoading"
:model="formData" :model="formData"
:rules="formRules" :rules="formRules"
label-width="80px" label-width="108px"
> >
<el-form-item label="角色名称" prop="name"> <el-form-item label="角色名称" prop="name">
<el-input v-model="formData.name" placeholder="请输入角色名称" /> <el-input v-model="formData.name" placeholder="请输入角色名称" />

@ -1,12 +1,16 @@
<template> <template>
<ContentWrap> <el-card class="hl-card">
<template #header>
<span>角色信息</span>
</template>
<ContentWrap class="borderxx">
<!-- 搜索工作栏 --> <!-- 搜索工作栏 -->
<el-form <el-form
ref="queryFormRef" ref="queryFormRef"
:inline="true" :inline="true"
:model="queryParams" :model="queryParams"
class="-mb-15px" class="-mb-15px"
label-width="68px" label-width="108px"
> >
<el-form-item label="角色名称" prop="name"> <el-form-item label="角色名称" prop="name">
<el-input <el-input
@ -37,7 +41,7 @@
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button @click="handleQuery"> <el-button @click="handleQuery" type="primary">
<Icon class="mr-5px" icon="ep:search" /> <Icon class="mr-5px" icon="ep:search" />
搜索 搜索
</el-button> </el-button>
@ -70,7 +74,7 @@
<!-- 列表 --> <!-- 列表 -->
<ContentWrap> <ContentWrap>
<el-table v-loading="loading" :data="list"> <el-table v-loading="loading" :data="list" class="hl-table">
<el-table-column label="序号" type="index" width="100" /> <el-table-column label="序号" type="index" width="100" />
<el-table-column align="center" label="角色名称" prop="name" /> <el-table-column align="center" label="角色名称" prop="name" />
<!-- <el-table-column align="center" label="角色类型" prop="type" />--> <!-- <el-table-column align="center" label="角色类型" prop="type" />-->
@ -87,9 +91,9 @@
align="center" align="center"
label="创建时间" label="创建时间"
prop="createTime" prop="createTime"
width="180" width="230"
/> />
<el-table-column :width="300" align="center" label="操作"> <el-table-column width="300" align="center" label="操作">
<template #default="scope"> <template #default="scope">
<el-button <el-button
v-hasPermi="['system:role:update']" v-hasPermi="['system:role:update']"
@ -139,6 +143,7 @@
/> />
</ContentWrap> </ContentWrap>
</el-card>
<!-- 表单弹窗添加/修改 --> <!-- 表单弹窗添加/修改 -->
<RoleForm ref="formRef" @success="getList" /> <RoleForm ref="formRef" @success="getList" />
<!-- 表单弹窗菜单权限 --> <!-- 表单弹窗菜单权限 -->

@ -148,24 +148,29 @@ DROP TABLE IF EXISTS `base_material`;
CREATE TABLE `base_material` ( CREATE TABLE `base_material` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '自增字段,唯一', `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '自增字段,唯一',
`code` varchar(64) NOT NULL COMMENT '物料编码', `code` varchar(64) NOT NULL COMMENT '物料编码',
`name` varchar(80) NOT NULL COMMENT '物料名称', `name` varchar(64) NOT NULL COMMENT '物料名称',
`short_name` varchar(32) COMMENT '物料简称',
`material_type` char(1) NOT NULL COMMENT '物料类型',
`composition_id` bigint(20) comment '材质id',
`output_input_tax_rate` DECIMAL(20,6) COMMENT '销项税率或进项税率 (%)',
`main_supplier_id` bigint(20) comment '首选供应商',
`main_from` tinyint(1) DEFAULT NULL COMMENT '物料主要来源',
`brand` varchar(255) COMMENT '品牌', `brand` varchar(255) COMMENT '品牌',
`spec` varchar(255) DEFAULT NULL COMMENT '规格', `spec` varchar(255) DEFAULT NULL COMMENT '规格',
`material_type` char(1) NOT NULL COMMENT '物料分类 零件|半成品|模具 1 2 3', `unit` varchar(64) NOT NULL COMMENT '主要单位',
`unit` varchar(64) DEFAULT NULL COMMENT '主要单位',
`size_info` varchar(64) comment '尺寸信息', `size_info` varchar(64) comment '尺寸信息',
`composition_id` bigint(20) not null comment '材质id', `barcode` varchar(255) comment '物料条码',
`inv_upper_limit` bigint(20) DEFAULT NULL COMMENT '库存预警上限', `logo` varchar(255) comment '物料logo地址',
`inv_lower_limit` bigint(20) DEFAULT NULL COMMENT '库存预警下限', `description` varchar(255) DEFAULT NULL COMMENT '物料描述',
`inv_safe` DECIMAL(20,6) COMMENT '安全库存',
`inv_upper_limit` DECIMAL(20,6) DEFAULT NULL COMMENT '库存预警上限',
`inv_lower_limit` DECIMAL(20,6) DEFAULT NULL COMMENT '库存预警下限',
`trace_type` tinyint(4) DEFAULT NULL COMMENT '管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理', `trace_type` tinyint(4) DEFAULT NULL COMMENT '管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理',
`virsual_part` char(1) DEFAULT NULL COMMENT '虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之', `virtual_part` char(1) DEFAULT NULL COMMENT '虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之',
`main_from` tinyint(4) DEFAULT NULL COMMENT '物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工',
`dft_store_wh` bigint(20) DEFAULT NULL COMMENT '默认保存的仓库对应仓库表中的Id', `dft_store_wh` bigint(20) DEFAULT NULL COMMENT '默认保存的仓库对应仓库表中的Id',
`dft_store_rg` bigint(20) DEFAULT NULL COMMENT '默认保存的库区对应库区表中的Id', `dft_store_rg` bigint(20) DEFAULT NULL COMMENT '默认保存的库区对应库区表中的Id',
`dft_store_pn` bigint(20) DEFAULT NULL COMMENT '默认保存的库位对应库位表中的Id', `dft_store_pn` bigint(20) DEFAULT NULL COMMENT '默认保存的库位对应库位表中的Id',
`dft_route` bigint(20) DEFAULT NULL COMMENT '默认工艺路线对应工艺路线表中的Id', `dft_route` bigint(20) DEFAULT NULL COMMENT '默认工艺路线对应工艺路线表中的Id',
`dft_pack` bigint(20) DEFAULT NULL COMMENT '默认包装方式对应包装方式表中的Id',
`description` varchar(255) DEFAULT NULL COMMENT '物料描述',
`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态,1表示正常2表示禁用', `status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态,1表示正常2表示禁用',
`creator` varchar(64) DEFAULT '' COMMENT '创建者', `creator` varchar(64) DEFAULT '' COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',

Loading…
Cancel
Save