|
@@ -0,0 +1,141 @@
|
|
|
|
+/*
|
|
|
|
+ * Copyright [2022] [https://www.baiduc.com]
|
|
|
|
+ *
|
|
|
|
+ * Snowy采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
|
|
|
|
+ *
|
|
|
|
+ * 1.请不要删除和修改根目录下的LICENSE文件。
|
|
|
|
+ * 2.请不要删除和修改Snowy源码头部的版权声明。
|
|
|
|
+ * 3.本项目代码可免费商业使用,商业使用请保留源码和相关描述文件的项目出处,作者声明等。
|
|
|
|
+ * 4.分发源码时候,请注明软件出处 https://www.baiduc.com
|
|
|
|
+ * 5.不可二次分发开源参与同类竞品,如有想法可联系团队xiaonuobase@qq.com商议合作。
|
|
|
|
+ * 6.若您的项目无法满足以上几点,需要更多功能代码,获取Snowy商业授权许可,请在官网购买授权,地址为 https://www.baiduc.com
|
|
|
|
+ */
|
|
|
|
+package vip.xiaonuo.quality.service.impl;
|
|
|
|
+
|
|
|
|
+import cn.hutool.core.bean.BeanUtil;
|
|
|
|
+import cn.hutool.core.collection.CollStreamUtil;
|
|
|
|
+import cn.hutool.core.util.ObjectUtil;
|
|
|
|
+import cn.hutool.core.util.StrUtil;
|
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
|
+import com.baomidou.mybatisplus.core.toolkit.StringUtils;
|
|
|
|
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
|
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
+import org.springframework.stereotype.Service;
|
|
|
|
+import org.springframework.transaction.annotation.Transactional;
|
|
|
|
+import vip.xiaonuo.common.enums.CommonSortOrderEnum;
|
|
|
|
+import vip.xiaonuo.common.exception.CommonException;
|
|
|
|
+import vip.xiaonuo.common.page.CommonPageRequest;
|
|
|
|
+import vip.xiaonuo.purchase.entity.PurchaseOrder;
|
|
|
|
+import vip.xiaonuo.purchase.param.PurchaseAllParam;
|
|
|
|
+import vip.xiaonuo.quality.entity.QualityFenxibaogao;
|
|
|
|
+import vip.xiaonuo.quality.mapper.QualityFenxibaogaoMapper;
|
|
|
|
+import vip.xiaonuo.quality.param.*;
|
|
|
|
+import vip.xiaonuo.quality.param.vo.ChengPinQuXianVo;
|
|
|
|
+import vip.xiaonuo.quality.service.QualityFenxibaogaoService;
|
|
|
|
+
|
|
|
|
+import java.util.List;
|
|
|
|
+
|
|
|
|
+/**
|
|
|
|
+ * 质量分析报表Service接口实现类
|
|
|
|
+ *
|
|
|
|
+ * @author 1
|
|
|
|
+ * @date 2025/02/26 16:25
|
|
|
|
+ **/
|
|
|
|
+@Service
|
|
|
|
+public class QualityFenxibaogaoServiceImpl extends ServiceImpl<QualityFenxibaogaoMapper, QualityFenxibaogao> implements QualityFenxibaogaoService {
|
|
|
|
+
|
|
|
|
+ @Autowired
|
|
|
|
+ private QualityFenxibaogaoMapper qualityFenxibaogaoMapper;
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public Page<QualityFenxibaogao> page(QualityFenxibaogaoPageParam qualityFenxibaogaoPageParam) {
|
|
|
|
+ QueryWrapper<QualityFenxibaogao> queryWrapper = new QueryWrapper<>();
|
|
|
|
+ if(ObjectUtil.isAllNotEmpty(qualityFenxibaogaoPageParam.getSortField(), qualityFenxibaogaoPageParam.getSortOrder())) {
|
|
|
|
+ CommonSortOrderEnum.validate(qualityFenxibaogaoPageParam.getSortOrder());
|
|
|
|
+ queryWrapper.orderBy(true, qualityFenxibaogaoPageParam.getSortOrder().equals(CommonSortOrderEnum.ASC.getValue()),
|
|
|
|
+ StrUtil.toUnderlineCase(qualityFenxibaogaoPageParam.getSortField()));
|
|
|
|
+ } else {
|
|
|
|
+ queryWrapper.lambda().orderByAsc(QualityFenxibaogao::getId);
|
|
|
|
+ }
|
|
|
|
+ String orgId = qualityFenxibaogaoPageParam.getOrgId();
|
|
|
|
+ queryWrapper.eq(StringUtils.isNotBlank(orgId),"org_id",orgId);
|
|
|
|
+
|
|
|
|
+ return this.page(CommonPageRequest.defaultPage(), queryWrapper);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
|
+ @Override
|
|
|
|
+ public void add(QualityFenxibaogaoAddParam qualityFenxibaogaoAddParam) {
|
|
|
|
+ String orgId = qualityFenxibaogaoAddParam.getOrgId();
|
|
|
|
+ if(StringUtils.isBlank(orgId)) {
|
|
|
|
+ throw new CommonException("请选择需要添加的公司");
|
|
|
|
+ }
|
|
|
|
+ QualityFenxibaogao qualityFenxibaogao = BeanUtil.toBean(qualityFenxibaogaoAddParam, QualityFenxibaogao.class);
|
|
|
|
+ this.save(qualityFenxibaogao);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
|
+ @Override
|
|
|
|
+ public void edit(QualityFenxibaogao qualityFenxibaogao) {
|
|
|
|
+ this.updateById(qualityFenxibaogao);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
|
+ @Override
|
|
|
|
+ public void delete(QualityFenxibaogaoIdParam qualityFenxibaogaoIdParamList) {
|
|
|
|
+ // 执行删除
|
|
|
|
+ this.removeById(qualityFenxibaogaoIdParamList.getId());
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public QualityFenxibaogao queryEntity(String id) {
|
|
|
|
+ QualityFenxibaogao qualityFenxibaogao = this.getById(id);
|
|
|
|
+ if(ObjectUtil.isEmpty(qualityFenxibaogao)) {
|
|
|
|
+ throw new CommonException("质量分析报表不存在,id值为:{}", id);
|
|
|
|
+ }
|
|
|
|
+ return qualityFenxibaogao;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public List<QualityFenxibaogao> getChengPin(ChengPingZhiParam chengPingZhiParam) {
|
|
|
|
+ QueryWrapper<QualityFenxibaogao> wrapper = new QueryWrapper<>();
|
|
|
|
+ wrapper.select("material_name , quality_type");
|
|
|
|
+ wrapper.groupBy("material_name");
|
|
|
|
+ wrapper.eq(StringUtils.isNotBlank(chengPingZhiParam.getOrgId()),"org_id",chengPingZhiParam.getOrgId());
|
|
|
|
+ return this.list(wrapper);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public List<ChengPinQuXianVo> getChengPinQuXian(ChengPingZhiParam chengPingZhiParam) {
|
|
|
|
+
|
|
|
|
+ String orgId = chengPingZhiParam.getOrgId();
|
|
|
|
+ Integer type = chengPingZhiParam.getDateType();
|
|
|
|
+
|
|
|
|
+ QueryWrapper<QualityFenxibaogao> wrapper = new QueryWrapper<>();
|
|
|
|
+
|
|
|
|
+ wrapper.eq( StringUtils.isNotBlank(orgId),"org_id", orgId)
|
|
|
|
+ .eq(StringUtils.isNotBlank(chengPingZhiParam.getCheJianName()),"che_jian_name",chengPingZhiParam.getCheJianName())
|
|
|
|
+ .eq(StringUtils.isNotBlank(chengPingZhiParam.getInspecItems()),"inspec_items",chengPingZhiParam.getInspecItems())
|
|
|
|
+ .eq(StringUtils.isNotBlank(chengPingZhiParam.getMaterialName()),"material_name",chengPingZhiParam.getMaterialName())
|
|
|
|
+ .eq("quality_type",chengPingZhiParam.getType())
|
|
|
|
+ .orderByAsc("ymonth").groupBy("ymonth");
|
|
|
|
+ List<ChengPinQuXianVo> busAllParams;
|
|
|
|
+ if (ObjectUtil.isEmpty(type) || 0 == type){
|
|
|
|
+ busAllParams= qualityFenxibaogaoMapper.getChengPinQuXianYear(wrapper);
|
|
|
|
+ }else {
|
|
|
|
+ busAllParams = qualityFenxibaogaoMapper.getChengPinQuXianMonth(wrapper);
|
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+ return busAllParams;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public List<QualityFenxibaogao> getJianCeXiangMu(ChengPingZhiParam chengPingZhiParam) {
|
|
|
|
+ QueryWrapper<QualityFenxibaogao> wrapper = new QueryWrapper<>();
|
|
|
|
+ wrapper.select("inspec_items, quality_type");
|
|
|
|
+ wrapper.groupBy("inspec_items");
|
|
|
|
+ wrapper.eq(StringUtils.isNotBlank(chengPingZhiParam.getOrgId()),"org_id",chengPingZhiParam.getOrgId());
|
|
|
|
+ return this.list(wrapper);
|
|
|
|
+ }
|
|
|
|
+}
|