From ce531d3bb32f5221b35f9e24d027ef83450ebbc6 Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期二, 21 十月 2025 16:58:34 +0800
Subject: [PATCH] 修改bug

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TCrmClinicServiceImpl.java |  144 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 144 insertions(+), 0 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TCrmClinicServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TCrmClinicServiceImpl.java
index d1d9916..973635f 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TCrmClinicServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TCrmClinicServiceImpl.java
@@ -1,10 +1,34 @@
 package com.ruoyi.system.service.impl;
 
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.domain.entity.SysUser;
+import com.ruoyi.common.utils.SecurityUtils;
+import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.system.dto.TCrmClinicDTO;
+import com.ruoyi.system.export.TCrmClinicAuditExport;
+import com.ruoyi.system.export.TCrmClinicListExport;
 import com.ruoyi.system.mapper.TCrmClinicMapper;
 import com.ruoyi.system.model.TCrmClinic;
+import com.ruoyi.system.model.TErpProcurement;
+import com.ruoyi.system.query.TCrmClinicQuery;
+import com.ruoyi.system.service.ISysUserService;
 import com.ruoyi.system.service.TCrmClinicService;
+import com.ruoyi.system.service.TErpProcurementService;
+import com.ruoyi.system.vo.TCrmClinicVO;
+import com.ruoyi.system.vo.TCrmSupplierVO;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.util.CollectionUtils;
+
+import java.math.BigDecimal;
+import java.time.LocalDate;
+import java.util.Arrays;
+import java.util.List;
+import java.util.Objects;
+import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -17,4 +41,124 @@
 @Service
 public class TCrmClinicServiceImpl extends ServiceImpl<TCrmClinicMapper, TCrmClinic> implements TCrmClinicService {
 
+    @Autowired
+    private ISysUserService sysUserService;
+    @Autowired
+    private TErpProcurementService erpProcurementService;
+
+    @Override
+    public PageInfo<TCrmClinicVO> pageList(TCrmClinicQuery query) {
+        query.setCreateTime(LocalDate.now());
+        PageInfo<TCrmClinicVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        List<TCrmClinicVO> list = this.baseMapper.pageList(query,pageInfo);
+        if(CollectionUtils.isEmpty(list)){
+            return pageInfo;
+        }
+
+        List<String> clinicIds = list.stream().map(TCrmClinicVO::getId).collect(Collectors.toList());
+        List<TErpProcurement> procurements = erpProcurementService.list(Wrappers.lambdaQuery(TErpProcurement.class)
+                .in(TErpProcurement::getClinicId, clinicIds)
+                .in(TErpProcurement::getStatus, Arrays.asList(3,4,5))
+                .likeRight(TErpProcurement::getCreateTime, LocalDate.now()));
+        for (TCrmClinicVO tCrmClinicVO : list) {
+            List<TErpProcurement> procurementList = procurements.stream().filter(procurement -> procurement.getClinicId().equals(tCrmClinicVO.getId())).collect(Collectors.toList());
+            if(!CollectionUtils.isEmpty(procurementList)){
+                tCrmClinicVO.setMonthPurchaseAmount(procurementList.stream().map(TErpProcurement::getPayMoney).reduce(BigDecimal.ZERO, BigDecimal::add));
+            }
+
+            if(Objects.nonNull(tCrmClinicVO.getMonthPurchaseAmount()) && tCrmClinicVO.getMonthPurchaseAmount().compareTo(tCrmClinicVO.getLowProcurementMoney())>0){
+                tCrmClinicVO.setPerformanceStatus(2);
+            }
+
+        }
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
+
+    @Override
+    public PageInfo<TCrmClinicVO> pageAuditList(TCrmClinicQuery query) {
+        PageInfo<TCrmClinicVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        List<TCrmClinicVO> list = this.baseMapper.pageAuditList(query,pageInfo);
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
+
+    @Override
+    public R<Boolean> addClinic(TCrmClinicDTO dto) {
+        // 判断账号是否已存在
+        SysUser sysUser = sysUserService.selectUserByUserName(dto.getPhone());
+        if(Objects.nonNull(sysUser)){
+            return R.fail(dto.getPhone()+"-账号已存在");
+        }
+        this.save(dto);
+        // 添加账号
+        SysUser user = new SysUser();
+        user.setUserName(dto.getPhone());
+        user.setPhonenumber(dto.getPhone());
+        user.setNickName(dto.getClinicName());
+        user.setPassword(SecurityUtils.encryptPassword(dto.getPassword()));
+        user.setStatus("0");
+        user.setDelFlag("2");
+        user.setRoleType(5);
+        user.setRoleId(5L);
+        sysUserService.insertUser(user);
+        dto.setUserId(user.getUserId());
+        this.updateById(dto);
+        return R.ok();
+    }
+
+    @Override
+    public R<Boolean> updateClinic(TCrmClinicDTO dto) {
+        // 判断账号是否已存在
+        SysUser sysUser1 = sysUserService.selectUserByUserName(dto.getPhone());
+        if(Objects.nonNull(sysUser1) && !sysUser1.getUserId().equals(dto.getUserId())){
+            return R.fail(dto.getPhone()+"-账号已存在");
+        }
+        this.updateById(dto);
+        SysUser user = sysUserService.selectUserById(dto.getUserId());
+        if(Objects.nonNull(user)){
+            // 修改账号
+            user.setPhonenumber(dto.getPhone());
+            user.setUserName(dto.getPhone());
+            user.setNickName(dto.getClinicName());
+            if(StringUtils.isNotEmpty(dto.getPassword())){
+                user.setPassword(SecurityUtils.encryptPassword(dto.getPassword()));
+            }
+            sysUserService.updateUser(user);
+        }
+        return R.ok();
+    }
+
+    @Override
+    public List<TCrmClinicAuditExport> exportAudit(TCrmClinicQuery query) {
+        List<TCrmClinicAuditExport> list = this.baseMapper.exportAudit(query);
+        return list;
+    }
+
+    @Override
+    public List<TCrmClinicListExport> exportList(TCrmClinicQuery query) {
+        query.setCreateTime(LocalDate.now());
+        List<TCrmClinicListExport> list = this.baseMapper.exportList(query);
+        if(CollectionUtils.isEmpty(list)){
+            return list;
+        }
+
+        List<String> clinicIds = list.stream().map(TCrmClinicListExport::getId).collect(Collectors.toList());
+        List<TErpProcurement> procurements = erpProcurementService.list(Wrappers.lambdaQuery(TErpProcurement.class)
+                .in(TErpProcurement::getClinicId, clinicIds)
+                .in(TErpProcurement::getStatus, Arrays.asList(3,4,5))
+                .likeRight(TErpProcurement::getCreateTime, LocalDate.now()));
+        for (TCrmClinicListExport crmClinicListExport : list) {
+            List<TErpProcurement> procurementList = procurements.stream().filter(procurement -> procurement.getClinicId().equals(crmClinicListExport.getId())).collect(Collectors.toList());
+            if(!CollectionUtils.isEmpty(procurementList)){
+                crmClinicListExport.setMonthPurchaseAmount(procurementList.stream().map(TErpProcurement::getPayMoney).reduce(BigDecimal.ZERO, BigDecimal::add));
+            }
+
+            if(Objects.nonNull(crmClinicListExport.getMonthPurchaseAmount()) && crmClinicListExport.getMonthPurchaseAmount().compareTo(crmClinicListExport.getLowProcurementMoney())>0){
+                crmClinicListExport.setPerformanceStatus(2);
+            }
+
+        }
+        return list;
+    }
 }

--
Gitblit v1.7.1