From b2d360d9113b6955287108ca9e90d76a1f3c1419 Mon Sep 17 00:00:00 2001
From: liukangdong <898885815@qq.com>
Date: 星期日, 29 九月 2024 15:05:11 +0800
Subject: [PATCH] Merge branch 'master' of http://139.186.142.91:10010/r/productDev/zbomyoujia

---
 server/service/src/main/java/com/doumee/service/business/impl/CustomerServiceImpl.java |   60 ++++++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 42 insertions(+), 18 deletions(-)

diff --git a/server/service/src/main/java/com/doumee/service/business/impl/CustomerServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/CustomerServiceImpl.java
index 2e84db3..d75b23e 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/CustomerServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/CustomerServiceImpl.java
@@ -9,10 +9,9 @@
 import com.doumee.core.utils.Utils;
 import com.doumee.dao.business.CustomerLogMapper;
 import com.doumee.dao.business.CustomerMapper;
+import com.doumee.dao.business.CustomerUserMapper;
 import com.doumee.dao.business.MemberMapper;
-import com.doumee.dao.business.model.Customer;
-import com.doumee.dao.business.model.CustomerLog;
-import com.doumee.dao.business.model.Member;
+import com.doumee.dao.business.model.*;
 import com.doumee.dao.web.reqeust.FreeCustomizationDTO;
 import com.doumee.dao.web.reqeust.RenovationCalculatorDTO;
 import com.doumee.dao.web.reqeust.TestTrimStyleDTO;
@@ -22,6 +21,8 @@
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.doumee.service.business.CustomerUserService;
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
 import org.checkerframework.checker.units.qual.A;
 import org.checkerframework.checker.units.qual.C;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -47,6 +48,8 @@
 
     @Autowired
     private CustomerLogMapper customerLogMapper;
+    @Autowired
+    private CustomerUserMapper customerUserMapper;
 
     @Autowired
     private MemberMapper memberMapper;
@@ -191,13 +194,7 @@
         if (pageWrap.getModel().getAreaCode() != null) {
             queryWrapper.lambda().eq(Customer::getAreaCode, pageWrap.getModel().getAreaCode());
         }
-        for(PageWrap.SortData sortData: pageWrap.getSorts()) {
-            if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
-                queryWrapper.orderByDesc(sortData.getProperty());
-            } else {
-                queryWrapper.orderByAsc(sortData.getProperty());
-            }
-        }
+        queryWrapper.lambda().orderByDesc(Customer::getCreateDate );
         return PageData.from(customerMapper.selectPage(page, queryWrapper));
     }
 
@@ -207,11 +204,8 @@
         return customerMapper.selectCount(wrapper);
     }
 
-
-
-
     @Override
-    public void saveRenovationCalculator(RenovationCalculatorDTO renovationCalculatorDTO){
+    public CustomerLog saveRenovationCalculator(RenovationCalculatorDTO renovationCalculatorDTO){
         if(Objects.isNull(renovationCalculatorDTO)
             || Objects.isNull(renovationCalculatorDTO.getMemberId())
             || Objects.isNull(renovationCalculatorDTO.getHouseStatus())
@@ -248,6 +242,7 @@
         customerLog.setIsdeleted(Constants.ZERO);
         customerLog.setType(Constants.TWO);
         customerLog.setCrmStatus(Constants.ZERO);
+        customerLog.setName(StringUtils.isEmpty(member.getName())?member.getNickname():member.getName());
         customerLog.setPhone(customer.getPhone());
         customerLog.setBudget(renovationCalculatorDTO.getBudget().multiply(new BigDecimal(10000)).toString());
         customerLog.setHouseStatus(renovationCalculatorDTO.getHouseStatus());
@@ -255,11 +250,13 @@
         customerLog.setHouseType(renovationCalculatorDTO.getHouseType());
         customerLog.setCostomerId(customer.getId().toString());
         customerLogMapper.insert(customerLog);
+        customerLog.setOpenid(member.getOpenid());
+        return  customerLog;
     }
 
 
     @Override
-    public void saveFreeCustomizationApply(FreeCustomizationDTO freeCustomizationDTO){
+    public CustomerLog saveFreeCustomizationApply(FreeCustomizationDTO freeCustomizationDTO){
         if(Objects.isNull(freeCustomizationDTO)
                 || Objects.isNull(freeCustomizationDTO.getMemberId())
                 || StringUtils.isEmpty(freeCustomizationDTO.getName())
@@ -278,7 +275,8 @@
             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鐢ㄦ埛淇℃伅");
         }
         if(StringUtils.isEmpty(member.getPhone())){
-            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈巿鏉冩墜鏈哄彿");
+            member.setPhone(freeCustomizationDTO.getPhone());
+            memberMapper.updateById(member);
         }
         Customer customer = customerMapper.selectOne(new QueryWrapper<Customer>().lambda()
                 .eq(Customer::getPhone,freeCustomizationDTO.getPhone()).eq(Customer::getIsdeleted, Constants.ZERO).last("limit 1"));
@@ -293,7 +291,6 @@
         customer.setOpenid(member.getOpenid());
         customer.setMemberId(member.getId());
         customer.setName(freeCustomizationDTO.getName());
-
         customer.setProName(freeCustomizationDTO.getProvinceName());
         customer.setCityName(freeCustomizationDTO.getCityName());
         customer.setAreaName(freeCustomizationDTO.getAreaName());
@@ -319,11 +316,36 @@
         customerLog.setAreaCode(freeCustomizationDTO.getAreaCode());
         customerLog.setName(freeCustomizationDTO.getName());
         customerLog.setPhone(freeCustomizationDTO.getPhone());
+        customerLog.setUsernames(freeCustomizationDTO.getUsername());
+        if(org.apache.commons.lang3.StringUtils.isBlank(freeCustomizationDTO.getUsername())){
+            //濡傛灉瀵艰喘淇℃伅涓虹┖锛屾煡璇㈣瀹㈡埛宸茬粦瀹氱殑瀵艰喘淇℃伅锛屼紶閫掔粰CRM浣跨敤
+            List<CustomerUser> userList = customerUserMapper.selectJoinList(CustomerUser.class,
+                    new MPJLambdaWrapper<CustomerUser>()
+                    .selectAs(Users::getIamUsername,CustomerUser::getUsername)
+                    .leftJoin(Users.class, Users::getId,CustomerUser::getUserId)
+                    .eq(CustomerUser::getIsdeleted,Constants.ZERO)
+                    .eq(CustomerUser::getCustomerPhone,customerLog.getPhone())
+                    .groupBy(Users::getIamUsername));
+            if(userList!=null && userList.size()>0){
+                String names = "";
+                for(CustomerUser cu : userList){
+                    if(!names.equals("")){
+                        names += ",";
+                    }
+                    names += cu.getUsername();
+                }
+                if(!names.equals("")){
+                   customerLog.setUsernames(names);
+                }
+            }
+        }
         customerLogMapper.insert(customerLog);
+        customerLog.setOpenid(member.getOpenid());
+        return  customerLog;
     }
 
     @Override
-    public void saveTestTrimStyle(TestTrimStyleDTO testTrimStyleDTO){
+    public CustomerLog saveTestTrimStyle(TestTrimStyleDTO testTrimStyleDTO){
         if(Objects.isNull(testTrimStyleDTO)
                 || Objects.isNull(testTrimStyleDTO.getMemberId())
 
@@ -388,6 +410,8 @@
         customerLog.setAgeInfo(testTrimStyleDTO.getAgeInfo());
         customerLog.setPhone(testTrimStyleDTO.getPhone());
         customerLogMapper.insert(customerLog);
+        customerLog.setOpenid(member.getOpenid());
+        return  customerLog;
     }
 
 

--
Gitblit v1.9.3