siontion 10 months ago
commit 40acba466b

@ -20,13 +20,17 @@ public enum CodeEnum {
* Wt+
* Cus+
* Sup+
* Prs+
* St+
* */
FACTORY("工厂", "Fa", 4),
DEPT("部门", "De", 4),
WORKSHOP("车间", "Ce", 4),
CLASSES("班组", "Wt", 4),
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;
import lombok.*;
import java.util.*;
import io.swagger.v3.oas.annotations.media.Schema;
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 java.math.BigDecimal;
import java.time.LocalDateTime;
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 = "规格")
private String spec;
@Schema(description = "物料分类 零件|半成品|模具 1 2 3", example = "2")
private String materialType;
@Schema(description = "主要单位")
private String unit;
@Schema(description = "尺寸信息")
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")
private Integer traceType;
@Schema(description = "虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之")
private String virsualPart;
@Schema(description = "物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工")
private Integer mainFrom;
@Schema(description = "默认保存的仓库对应仓库表中的Id")
private Long dftStoreWh;
@ -66,9 +48,6 @@ public class MaterialPageReqVO extends PageParam {
@Schema(description = "默认工艺路线对应工艺路线表中的Id")
private Long dftRoute;
@Schema(description = "默认包装方式对应包装方式表中的Id")
private Long dftPack;
@Schema(description = "物料描述", example = "你说的对")
private String description;
@ -79,4 +58,43 @@ public class MaterialPageReqVO extends PageParam {
@Schema(description = "状态,1表示正常2表示禁用", example = "1")
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;
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 lombok.*;
import java.util.*;
import java.util.*;
import org.springframework.format.annotation.DateTimeFormat;
import lombok.Data;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import com.alibaba.excel.annotation.*;
@Schema(description = "管理后台 - 物料 Response VO")
@Data
@ -33,42 +35,14 @@ public class MaterialRespVO {
@ExcelProperty("规格")
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 = "尺寸信息")
@ExcelProperty("尺寸信息")
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")
@ExcelProperty("管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理")
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")
@ExcelProperty("默认保存的仓库对应仓库表中的Id")
private Long dftStoreWh;
@ -85,10 +59,6 @@ public class MaterialRespVO {
@ExcelProperty("默认工艺路线对应工艺路线表中的Id")
private Long dftRoute;
@Schema(description = "默认包装方式对应包装方式表中的Id")
@ExcelProperty("默认包装方式对应包装方式表中的Id")
private Long dftPack;
@Schema(description = "物料描述", example = "你说的对")
@ExcelProperty("物料描述")
private String description;
@ -98,7 +68,67 @@ public class MaterialRespVO {
private LocalDateTime createTime;
@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;
}
@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;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import javax.validation.constraints.*;
import java.util.*;
@Schema(description = "管理后台 - 物料新增/修改 Request VO")
@Data
public class MaterialSaveReqVO {
@Schema(description = "自增字段,唯一", requiredMode = Schema.RequiredMode.REQUIRED, example = "11225")
private Long id;
@Schema(description = "物料编码", requiredMode = Schema.RequiredMode.REQUIRED)
@NotEmpty(message = "物料编码不能为空")
private String code;
@Schema(description = "物料名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "李四")
@NotEmpty(message = "物料名称不能为空")
private String name;
@Schema(description = "品牌")
private String brand;
@Schema(description = "规格")
private String spec;
@Schema(description = "物料分类 零件|半成品|模具 1 2 3", requiredMode = Schema.RequiredMode.REQUIRED, example = "2")
@NotEmpty(message = "物料分类 零件|半成品|模具 1 2 3不能为空")
private String materialType;
@Schema(description = "主要单位")
private String unit;
@Schema(description = "尺寸信息")
private String sizeInfo;
@Schema(description = "材质id", requiredMode = Schema.RequiredMode.REQUIRED, example = "17489")
@NotNull(message = "材质id不能为空")
private Long compositionId;
@Schema(description = "库存预警上限")
private Long invUpperLimit;
@Schema(description = "库存预警下限")
private Long invLowerLimit;
@Schema(description = "管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理", example = "2")
private Integer traceType;
@Schema(description = "虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之")
private String virsualPart;
@Schema(description = "物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工")
private Integer mainFrom;
@Schema(description = "默认保存的仓库对应仓库表中的Id")
private Long dftStoreWh;
@Schema(description = "默认保存的库区对应库区表中的Id")
private Long dftStoreRg;
@Schema(description = "默认保存的库位对应库位表中的Id")
private Long dftStorePn;
@Schema(description = "默认工艺路线对应工艺路线表中的Id")
private Long dftRoute;
@Schema(description = "默认包装方式对应包装方式表中的Id")
private Long dftPack;
@Schema(description = "物料描述", example = "你说的对")
private String description;
@Schema(description = "状态,1表示正常2表示禁用", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@NotNull(message = "状态,1表示正常2表示禁用不能为空")
private Integer status;
}
package com.chanko.yunxi.mes.module.heli.controller.admin.material.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull;
import java.math.BigDecimal;
@Schema(description = "管理后台 - 物料新增/修改 Request VO")
@Data
public class MaterialSaveReqVO {
@Schema(description = "自增字段,唯一", requiredMode = Schema.RequiredMode.REQUIRED, example = "11225")
private Long id;
@Schema(description = "物料编码", requiredMode = Schema.RequiredMode.REQUIRED)
@NotEmpty(message = "物料编码不能为空")
private String code;
@Schema(description = "物料名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "李四")
@NotEmpty(message = "物料名称不能为空")
private String name;
@Schema(description = "品牌")
private String brand;
@Schema(description = "规格")
private String spec;
@Schema(description = "尺寸信息")
private String sizeInfo;
@Schema(description = "管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理", example = "2")
private Integer traceType;
@Schema(description = "默认保存的仓库对应仓库表中的Id")
private Long dftStoreWh;
@Schema(description = "默认保存的库区对应库区表中的Id")
private Long dftStoreRg;
@Schema(description = "默认保存的库位对应库位表中的Id")
private Long dftStorePn;
@Schema(description = "默认工艺路线对应工艺路线表中的Id")
private Long dftRoute;
@Schema(description = "物料描述", example = "你说的对")
private String description;
@Schema(description = "状态,1表示正常2表示禁用", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@NotNull(message = "状态,1表示正常2表示禁用不能为空")
private Integer status;
@Schema(description = "物料简称", example = "赵六")
private String shortName;
@Schema(description = "物料类型", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
@NotEmpty(message = "物料类型不能为空")
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 = "主要单位", requiredMode = Schema.RequiredMode.REQUIRED)
@NotEmpty(message = "主要单位不能为空")
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;
}

@ -4,6 +4,10 @@ import lombok.*;
import java.util.*;
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.chanko.yunxi.mes.framework.mybatis.core.dataobject.BaseDO;
@ -44,68 +48,99 @@ public class MaterialDO extends BaseDO {
*/
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;
/**
* 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)
.select("u.nickname as leaderUserName", "w.name as workshopName")
.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())
.like(!StringUtils.isEmpty(reqVO.getName()), ClassesDO::getName, reqVO.getName())

@ -1,13 +1,13 @@
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.mybatis.core.query.LambdaQueryWrapperX;
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.supplier.SupplierDO;
import com.github.yulichang.wrapper.MPJLambdaWrapper;
import org.apache.ibatis.annotations.Mapper;
import com.chanko.yunxi.mes.module.heli.controller.admin.material.vo.*;
import org.springframework.util.StringUtils;
/**
* Mapper
@ -18,29 +18,18 @@ import com.chanko.yunxi.mes.module.heli.controller.admin.material.vo.*;
public interface MaterialMapper extends BaseMapperX<MaterialDO> {
default PageResult<MaterialDO> selectPage(MaterialPageReqVO reqVO) {
return selectPage(reqVO, new LambdaQueryWrapperX<MaterialDO>()
.eqIfPresent(MaterialDO::getCode, reqVO.getCode())
.likeIfPresent(MaterialDO::getName, reqVO.getName())
.eqIfPresent(MaterialDO::getBrand, reqVO.getBrand())
.eqIfPresent(MaterialDO::getSpec, reqVO.getSpec())
.eqIfPresent(MaterialDO::getMaterialType, reqVO.getMaterialType())
.eqIfPresent(MaterialDO::getUnit, reqVO.getUnit())
.eqIfPresent(MaterialDO::getSizeInfo, reqVO.getSizeInfo())
.eqIfPresent(MaterialDO::getCompositionId, reqVO.getCompositionId())
.eqIfPresent(MaterialDO::getInvUpperLimit, reqVO.getInvUpperLimit())
.eqIfPresent(MaterialDO::getInvLowerLimit, reqVO.getInvLowerLimit())
.eqIfPresent(MaterialDO::getTraceType, reqVO.getTraceType())
.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));
MPJLambdaWrapper<MaterialDO> query = new MPJLambdaWrapper<>();
query.selectAll(MaterialDO.class)
.select("s.name as mainSupplierName")
.leftJoin(SupplierDO.class, "s", SupplierDO::getId, MaterialDO::getMainSupplierId)
.disableSubLogicDel()
.orderByDesc(MaterialDO::getId);
query.like(!StringUtils.isEmpty(reqVO.getName()), MaterialDO::getName, reqVO.getName())
.like(!StringUtils.isEmpty(reqVO.getCode()), MaterialDO::getCode, reqVO.getCode())
.eq(!StringUtils.isEmpty(reqVO.getMaterialType()), MaterialDO::getMaterialType, reqVO.getMaterialType())
.eq(reqVO.getStatus() != null, MaterialDO::getStatus, reqVO.getStatus());
return selectPage(reqVO, query);
}
}
}

@ -23,7 +23,9 @@ public interface WorkshopMapper extends BaseMapperX<WorkshopDO> {
query.selectAll(WorkshopDO.class)
.select("u.nickname as leaderUserName", "d.name as deptName")
.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())
.like(!StringUtils.isEmpty(reqVO.getName()), WorkshopDO::getName, reqVO.getName())

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

@ -153,6 +153,8 @@ spring:
logging:
file:
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 文档

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

@ -1,55 +1,60 @@
import request from '@/config/axios'
export interface MaterialVO {
id: number
code: string
name: string
brand: string
spec: string
materialType: string
unit: string
sizeInfo: string
compositionId: number
invUpperLimit: number
invLowerLimit: number
traceType: number
virsualPart: string
mainFrom: number
dftStoreWh: number
dftStoreRg: number
dftStorePn: number
dftRoute: number
dftPack: number
description: string
status: number
}
// 查询物料分页
export const getMaterialPage = async (params) => {
return await request.get({ url: `/heli/material/page`, params })
}
// 查询物料详情
export const getMaterial = async (id: number) => {
return await request.get({ url: `/heli/material/get?id=` + id })
}
// 新增物料
export const createMaterial = async (data: MaterialVO) => {
return await request.post({ url: `/heli/material/create`, data })
}
// 修改物料
export const updateMaterial = async (data: MaterialVO) => {
return await request.put({ url: `/heli/material/update`, data })
}
// 删除物料
export const deleteMaterial = async (id: number) => {
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 })
}
import request from '@/config/axios'
export interface MaterialVO {
id: number
code: string
name: string
brand: string
spec: string
sizeInfo: string
traceType: number
dftStoreWh: number
dftStoreRg: number
dftStorePn: number
dftRoute: number
description: string
status: number
shortName: string
materialType: string
compositionId: number
outputInputTaxRate: number
mainSupplierId: number
mainFrom: number
unit: string
invSafe: number
invUpperLimit: number
invLowerLimit: number
barcode: string
virtualPart: string
logo: string
}
// 查询物料分页
export const getMaterialPage = async (params) => {
return await request.get({ url: `/heli/material/page`, params })
}
// 查询物料详情
export const getMaterial = async (id: number) => {
return await request.get({ url: `/heli/material/get?id=` + id })
}
// 新增物料
export const createMaterial = async (data: MaterialVO) => {
return await request.post({ url: `/heli/material/create`, data })
}
// 修改物料
export const updateMaterial = async (data: MaterialVO) => {
return await request.put({ url: `/heli/material/update`, data })
}
// 删除物料
export const deleteMaterial = async (id: number) => {
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_SUPPLIER_LEVEL = 'heli_supplier_level', //供应商级别
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"
:model="formData"
:rules="formRules"
label-width="100px"
label-width="150px"
v-loading="formLoading"
>
<el-form-item label="物料图片" prop="logo">
<UploadImg v-model="formData.logo" />
</el-form-item>
<el-form-item label="物料编码" prop="code">
<el-input v-model="formData.code" placeholder="请输入物料编码" />
</el-form-item>
<el-form-item label="物料名称" prop="name">
<el-input v-model="formData.name" placeholder="请输入物料名称" />
</el-form-item>
<el-form-item label="品牌" prop="brand">
<el-input v-model="formData.brand" placeholder="请输入品牌" />
</el-form-item>
<el-form-item label="规格" prop="spec">
<el-input v-model="formData.spec" placeholder="请输入规格" />
</el-form-item>
<el-form-item label="物料分类 零件|半成品|模具 1 2 3" prop="materialType">
<el-select v-model="formData.materialType" placeholder="请选择物料分类 零件|半成品|模具 1 2 3">
<el-option label="请选择字典生成" value="" />
<el-form-item label="物料类型" prop="materialType">
<el-select v-model="formData.materialType" placeholder="请选择物料类型">
<el-option
v-for="dict in getStrDictOptions(DICT_TYPE.HELI_MATERIAL_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="主要单位" prop="unit">
<el-input v-model="formData.unit" placeholder="请输入主要单位" />
</el-form-item>
<el-form-item label="尺寸信息" prop="sizeInfo">
<el-input v-model="formData.sizeInfo" placeholder="请输入尺寸信息" />
</el-form-item>
<el-form-item label="材质id" prop="compositionId">
<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-form-item label="系统单位" prop="unit">
<el-select v-model="formData.unit" placeholder="请选择系统单位">
<el-option
v-for="dict in getStrDictOptions(DICT_TYPE.HELI_MATERIAL_UNIT)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之" prop="virsualPart">
<el-input v-model="formData.virsualPart" placeholder="请输入虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之" />
<el-form-item label="物料简称" prop="shortName">
<el-input v-model="formData.shortName" placeholder="请输入物料简称" />
</el-form-item>
<el-form-item label="物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工" prop="mainFrom">
<el-input v-model="formData.mainFrom" placeholder="请输入物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工" />
<el-form-item label="规格/型号" prop="spec">
<el-input v-model="formData.spec" placeholder="请输入规格/型号" />
</el-form-item>
<el-form-item label="默认保存的仓库对应仓库表中的Id" prop="dftStoreWh">
<el-input v-model="formData.dftStoreWh" placeholder="请输入默认保存的仓库对应仓库表中的Id" />
</el-form-item>
<el-form-item label="默认保存的库区对应库区表中的Id" prop="dftStoreRg">
<el-input v-model="formData.dftStoreRg" placeholder="请输入默认保存的库区对应库区表中的Id" />
<el-form-item label="品牌" prop="brand">
<el-input v-model="formData.brand" placeholder="请输入品牌" />
</el-form-item>
<el-form-item label="默认保存的库位对应库位表中的Id" prop="dftStorePn">
<el-input v-model="formData.dftStorePn" placeholder="请输入默认保存的库位对应库位表中的Id" />
<el-form-item label="物料主要来源" prop="mainFrom">
<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 label="默认工艺路线对应工艺路线表中的Id" prop="dftRoute">
<el-input v-model="formData.dftRoute" placeholder="请输入默认工艺路线对应工艺路线表中的Id" />
<el-form-item label="首选供应商" prop="mainSupplierId">
<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 label="默认包装方式对应包装方式表中的Id" prop="dftPack">
<el-input v-model="formData.dftPack" placeholder="请输入默认包装方式对应包装方式表中的Id" />
<el-form-item label="销项税率/进项税率" prop="outputInputTaxRate">
<el-input v-model="formData.outputInputTaxRate" placeholder="请输入销项税率/进项税率" >
<template #append>%</template>
</el-input>
</el-form-item>
<el-form-item label="物料描述" prop="description">
<Editor v-model="formData.description" height="150px" />
<el-form-item label="备注" prop="description">
<el-input type="textarea" v-model="formData.description" height="150px" />
</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 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-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>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
@ -81,7 +106,9 @@
</Dialog>
</template>
<script setup lang="ts">
import { getIntDictOptions, getStrDictOptions, getBoolDictOptions, DICT_TYPE } from '@/utils/dict'
import * as MaterialApi from '@/api/heli/material'
import {getSupplierPage} from "@/api/heli/supplier";
const { t } = useI18n() //
const message = useMessage() //
@ -96,32 +123,54 @@ const formData = ref({
name: undefined,
brand: undefined,
spec: undefined,
materialType: undefined,
unit: undefined,
sizeInfo: undefined,
compositionId: undefined,
invUpperLimit: undefined,
invLowerLimit: undefined,
traceType: undefined,
virsualPart: undefined,
mainFrom: undefined,
dftStoreWh: undefined,
dftStoreRg: undefined,
dftStorePn: undefined,
dftRoute: undefined,
dftPack: 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({
code: [{ required: true, message: '物料编码不能为空', trigger: 'blur' }],
name: [{ required: true, message: '物料名称不能为空', trigger: 'blur' }],
materialType: [{ required: true, message: '物料分类 零件|半成品|模具 1 2 3不能为空', trigger: 'change' }],
compositionId: [{ required: true, message: '材质id不能为空', trigger: 'blur' }],
status: [{ required: true, message: '状态,1表示正常2表示禁用不能为空', trigger: 'blur' }],
status: [{ required: true, message: '启用状态不能为空', trigger: 'blur' }],
materialType: [{ required: true, message: '物料类型不能为空', trigger: 'change' }],
unit: [{ required: true, message: '系统单位不能为空', trigger: 'change' }],
})
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) => {
dialogVisible.value = true
@ -129,14 +178,22 @@ const open = async (type: string, id?: number) => {
formType.value = type
resetForm()
//
if (id) {
formLoading.value = true
try {
formLoading.value = true
try {
if (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
@ -172,23 +229,28 @@ const resetForm = () => {
name: undefined,
brand: undefined,
spec: undefined,
materialType: undefined,
unit: undefined,
sizeInfo: undefined,
compositionId: undefined,
invUpperLimit: undefined,
invLowerLimit: undefined,
traceType: undefined,
virsualPart: undefined,
mainFrom: undefined,
dftStoreWh: undefined,
dftStoreRg: undefined,
dftStorePn: undefined,
dftRoute: undefined,
dftPack: 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()
}
</script>
</script>

@ -26,171 +26,34 @@
class="!w-240px"
/>
</el-form-item>
<el-form-item label="品牌" prop="brand">
<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-form-item label="物料类型" prop="materialType">
<el-select
v-model="queryParams.materialType"
placeholder="请选择物料分类 零件|半成品|模具 1 2 3"
placeholder="请选择物料类型"
clearable
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-form-item>
<el-form-item label="主要单位" prop="unit">
<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-form-item label="启用状态" prop="status">
<el-select
v-model="queryParams.status"
placeholder="请选择状态,1表示正常2表示禁用"
placeholder="请选择启用状态"
clearable
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-form-item>
<el-form-item>
@ -204,7 +67,7 @@
>
<Icon icon="ep:plus" class="mr-5px" /> 新增
</el-button>
<el-button
<!-- <el-button
type="success"
plain
@click="handleExport"
@ -212,7 +75,7 @@
v-hasPermi="['heli:material:export']"
>
<Icon icon="ep:download" class="mr-5px" /> 导出
</el-button>
</el-button>-->
</el-form-item>
</el-form>
</ContentWrap>
@ -220,35 +83,34 @@
<!-- 列表 -->
<ContentWrap>
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="自增字段,唯一" align="center" prop="id" />
<el-table-column label="物料编码" align="center" prop="code" />
<el-table-column fixed label="序号" type="index" width="100" />
<el-table-column fixed label="物料编码" align="center" prop="code" />
<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="spec" />
<el-table-column label="物料分类 零件|半成品|模具 1 2 3" align="center" prop="materialType" />
<el-table-column label="主要单位" align="center" prop="unit" />
<el-table-column label="尺寸信息" align="center" prop="sizeInfo" />
<el-table-column label="材质id" align="center" prop="compositionId" />
<el-table-column label="库存预警上限" align="center" prop="invUpperLimit" />
<el-table-column label="库存预警下限" align="center" prop="invLowerLimit" />
<el-table-column label="管控方式,只有两种值分别是1和2,1表示单个管理2表示批次管理" align="center" prop="traceType" />
<el-table-column label="虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之" align="center" prop="virsualPart" />
<el-table-column label="物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工" align="center" prop="mainFrom" />
<el-table-column label="默认保存的仓库对应仓库表中的Id" align="center" prop="dftStoreWh" />
<el-table-column label="默认保存的库区对应库区表中的Id" align="center" prop="dftStoreRg" />
<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">
<el-table-column label="主要来源" align="center" prop="mainFrom">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HELI_MATERIAL_ORIGINAL" :value="scope.row.mainFrom" />
</template>
</el-table-column>
<el-table-column label="首选供应商" align="center" prop="mainSupplierName" />
<el-table-column label="启用状态" align="center" prop="status">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HELI_COMMON_STATUS" :value="scope.row.status" />
</template>
</el-table-column>
<el-table-column fixed="right" label="操作" align="center">
<template #default="scope">
<el-button
link
@ -258,14 +120,14 @@
>
编辑
</el-button>
<el-button
<!-- <el-button
link
type="danger"
@click="handleDelete(scope.row.id)"
v-hasPermi="['heli:material:delete']"
>
删除
</el-button>
</el-button>-->
</template>
</el-table-column>
</el-table>
@ -283,6 +145,7 @@
</template>
<script setup lang="ts">
import { getIntDictOptions, getStrDictOptions, getBoolDictOptions, DICT_TYPE } from '@/utils/dict'
import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import * as MaterialApi from '@/api/heli/material'
@ -303,23 +166,28 @@ const queryParams = reactive({
name: undefined,
brand: undefined,
spec: undefined,
materialType: undefined,
unit: undefined,
sizeInfo: undefined,
compositionId: undefined,
invUpperLimit: undefined,
invLowerLimit: undefined,
traceType: undefined,
virsualPart: undefined,
mainFrom: undefined,
dftStoreWh: undefined,
dftStoreRg: undefined,
dftStorePn: undefined,
dftRoute: undefined,
dftPack: undefined,
description: undefined,
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 exportLoading = ref(false) //
@ -386,4 +254,4 @@ const handleExport = async () => {
onMounted(() => {
getList()
})
</script>
</script>

@ -1,6 +1,6 @@
<template>
<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-tag>{{ formData.name }}</el-tag>
</el-form-item>

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

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

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

@ -148,24 +148,29 @@ DROP TABLE IF EXISTS `base_material`;
CREATE TABLE `base_material` (
`id` bigint(20) NOT NULL AUTO_INCREMENT 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 '品牌',
`spec` varchar(255) DEFAULT NULL COMMENT '规格',
`material_type` char(1) NOT NULL COMMENT '物料分类 零件|半成品|模具 1 2 3',
`unit` varchar(64) DEFAULT NULL COMMENT '主要单位',
`unit` varchar(64) NOT NULL COMMENT '主要单位',
`size_info` varchar(64) comment '尺寸信息',
`composition_id` bigint(20) not null comment '材质id',
`inv_upper_limit` bigint(20) DEFAULT NULL COMMENT '库存预警上限',
`inv_lower_limit` bigint(20) DEFAULT NULL COMMENT '库存预警下限',
`barcode` varchar(255) comment '物料条码',
`logo` varchar(255) comment '物料logo地址',
`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表示批次管理',
`virsual_part` char(1) DEFAULT NULL COMMENT '虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之',
`main_from` tinyint(4) DEFAULT NULL COMMENT '物料主要来源,只有三种值分别是123,其中1表示自制2表示外购3表示委外加工',
`virtual_part` char(1) DEFAULT NULL COMMENT '虚拟物料标识只能填写Y和NY表示虚拟物料N表示反之',
`dft_store_wh` 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_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表示禁用',
`creator` varchar(64) DEFAULT '' COMMENT '创建者',
`create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',

Loading…
Cancel
Save