crm:code review 客户的公海领取和分配

This commit is contained in:
YunaiV 2023-11-24 23:11:58 +08:00
parent 9a5f6f13b4
commit 1842549634
4 changed files with 40 additions and 44 deletions

View File

@ -1,12 +1,10 @@
package cn.iocoder.yudao.module.crm.controller.admin.customer; package cn.iocoder.yudao.module.crm.controller.admin.customer;
import cn.hutool.core.collection.CollUtil; import cn.hutool.core.collection.CollUtil;
import cn.iocoder.yudao.framework.common.exception.enums.GlobalErrorCodeConstants;
import cn.iocoder.yudao.framework.common.pojo.CommonResult; import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog; import cn.iocoder.yudao.framework.operatelog.core.annotations.OperateLog;
import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils;
import cn.iocoder.yudao.module.crm.controller.admin.customer.vo.*; import cn.iocoder.yudao.module.crm.controller.admin.customer.vo.*;
import cn.iocoder.yudao.module.crm.convert.customer.CrmCustomerConvert; import cn.iocoder.yudao.module.crm.convert.customer.CrmCustomerConvert;
import cn.iocoder.yudao.module.crm.dal.dataobject.customer.CrmCustomerDO; import cn.iocoder.yudao.module.crm.dal.dataobject.customer.CrmCustomerDO;
@ -24,7 +22,6 @@ import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.Parameters; import io.swagger.v3.oas.annotations.Parameters;
import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.util.CollectionUtils;
import org.springframework.validation.annotation.Validated; import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
@ -37,7 +34,6 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.error;
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertMap; import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertMap;
import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertSet; import static cn.iocoder.yudao.framework.common.util.collection.CollectionUtils.convertSet;
@ -185,19 +181,18 @@ public class CrmCustomerController {
@PutMapping("/receive") @PutMapping("/receive")
@Operation(summary = "领取公海客户") @Operation(summary = "领取公海客户")
@Parameter(name = "ids", description = "批量领取公海的客户id集合", required = true,example = "1,2,3") @Parameter(name = "ids", description = "编号数组", required = true,example = "1,2,3")
@PreAuthorize("@ss.hasPermission('crm:customer:receive')") @PreAuthorize("@ss.hasPermission('crm:customer:receive')")
public CommonResult<Boolean> receiveCustomer(@RequestParam(value = "ids") List<Long> ids){ public CommonResult<Boolean> receiveCustomer(@RequestParam(value = "ids") List<Long> ids){
// 领取公海任务 customerService.receiveCustomer(ids, getLoginUserId());
customerService.receiveCustomer(ids, SecurityFrameworkUtils.getLoginUserId());
return success(true); return success(true);
} }
@PutMapping("/distributeByIds") @PutMapping("/distribute")
@Operation(summary = "分配公海给对应负责人") @Operation(summary = "分配公海给对应负责人")
@Parameters({ @Parameters({
@Parameter(name = "ownerUserId", description = "分配的负责人id", required = true,example = "12345"), @Parameter(name = "ownerUserId", description = "分配的负责人编号", required = true, example = "12345"),
@Parameter(name = "ids", description = "批量分配的公海的客户id集合", required = true,example = "1,2,3") @Parameter(name = "ids", description = "客户编号数组", required = true, example = "1,2,3")
}) })
@PreAuthorize("@ss.hasPermission('crm:customer:distribute')") @PreAuthorize("@ss.hasPermission('crm:customer:distribute')")
public CommonResult<Boolean> distributeCustomer(@RequestParam(value = "ownerUserId") Long ownerUserId, public CommonResult<Boolean> distributeCustomer(@RequestParam(value = "ownerUserId") Long ownerUserId,

View File

@ -28,10 +28,10 @@ public interface CrmCustomerMapper extends BaseMapperX<CrmCustomerDO> {
.eqIfPresent(CrmCustomerDO::getSource, pageReqVO.getSource())); .eqIfPresent(CrmCustomerDO::getSource, pageReqVO.getSource()));
} }
default void updateCustomerOwnerUser(Long id,CrmCustomerDO customerDO){ default void updateCustomerByOwnerUserIdIsNull(Long id, CrmCustomerDO updateObj) {
update(customerDO,new LambdaUpdateWrapper <CrmCustomerDO>() update(updateObj, new LambdaUpdateWrapper<CrmCustomerDO>()
.eq(CrmCustomerDO::getId, id) .eq(CrmCustomerDO::getId, id)
.isNull(CrmCustomerDO::getOwnerUserId) .isNull(CrmCustomerDO::getOwnerUserId));
);
} }
} }

View File

@ -88,15 +88,15 @@ public interface CrmCustomerService {
/** /**
* 领取公海客户 * 领取公海客户
* *
* @param ids 要领取的客户 id * @param ids 要领取的客户编号数组
*/ */
void receiveCustomer(List<Long>ids, Long ownerUserId); void receiveCustomer(List<Long>ids, Long ownerUserId);
/** /**
* 分配公海客户 * 分配公海客户
* *
* @param ids 要分配的客户 id * @param ids 要分配的客户编号数组
* @param ownerUserId 分配的负责人id * @param ownerUserId 分配的负责人编号
* @author xiaqing * @author xiaqing
*/ */
void distributeCustomer(List<Long>ids, Long ownerUserId); void distributeCustomer(List<Long>ids, Long ownerUserId);

View File

@ -4,7 +4,6 @@ import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.ObjUtil; import cn.hutool.core.util.ObjUtil;
import cn.iocoder.yudao.framework.common.pojo.PageResult; import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils; import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
import cn.iocoder.yudao.framework.security.core.util.SecurityFrameworkUtils;
import cn.iocoder.yudao.module.crm.controller.admin.customer.vo.*; import cn.iocoder.yudao.module.crm.controller.admin.customer.vo.*;
import cn.iocoder.yudao.module.crm.convert.customer.CrmCustomerConvert; import cn.iocoder.yudao.module.crm.convert.customer.CrmCustomerConvert;
import cn.iocoder.yudao.module.crm.dal.dataobject.customer.CrmCustomerDO; import cn.iocoder.yudao.module.crm.dal.dataobject.customer.CrmCustomerDO;
@ -83,11 +82,6 @@ public class CrmCustomerServiceImpl implements CrmCustomerService {
throw exception(CUSTOMER_NOT_EXISTS); throw exception(CUSTOMER_NOT_EXISTS);
} }
} }
private void validateCustomerExists(CrmCustomerDO customerDO){
if (customerDO == null) {
throw exception(CUSTOMER_NOT_EXISTS);
}
}
@Override @Override
@CrmPermission(bizType = CrmBizTypeEnum.CRM_CUSTOMER, bizId = "#id", level = CrmPermissionLevelEnum.READ) @CrmPermission(bizType = CrmBizTypeEnum.CRM_CUSTOMER, bizId = "#id", level = CrmPermissionLevelEnum.READ)
@ -172,47 +166,54 @@ public class CrmCustomerServiceImpl implements CrmCustomerService {
} }
@Override @Override
@Transactional(rollbackFor = Exception.class)
public void distributeCustomer(List <Long> ids, Long ownerUserId) { public void distributeCustomer(List <Long> ids, Long ownerUserId) {
transferCustomerOwner(ids, ownerUserId); transferCustomerOwner(ids, ownerUserId);
} }
/**
* 转移客户负责人
*
* @param ids 客户编号数组
* @param ownerUserId 负责人编号
*/
private void transferCustomerOwner(List <Long> ids, Long ownerUserId) { private void transferCustomerOwner(List <Long> ids, Long ownerUserId) {
// 先一次性加载所有数据校验客户是否可用 // 先一次性加载所有数据校验客户是否可用
List <CrmCustomerDO> customerDOList = customerMapper.selectBatchIds(ids); List <CrmCustomerDO> customers = customerMapper.selectBatchIds(ids);
for (CrmCustomerDO customerDO : customerDOList) { for (CrmCustomerDO customer : customers) {
// 校验客户是否存在
validateCustomerExists(customerDO);
// 校验是否已有负责人 // 校验是否已有负责人
validCustomerOwnerExist(customerDO); validateCustomerOwnerExists(customer);
// 校验是否锁定 // 校验是否锁定
validCustomerIsLocked(customerDO); validateCustomerIsLocked(customer);
// 校验成交状态 // 校验成交状态
validCustomerDeal(customerDO); validateCustomerDeal(customer);
} }
// TODO @QingX这里是不是改成一次性更新不然如果有 20 个客户就要执行 20 SQL
// 统一修改状态 // 统一修改状态
CrmCustomerDO updateDo = new CrmCustomerDO(); CrmCustomerDO updateDo = new CrmCustomerDO();
updateDo.setOwnerUserId(ownerUserId); updateDo.setOwnerUserId(ownerUserId);
// TODO @QingX如果更新的数量不对则应该抛出异常回滚并错误提示
for (Long id : ids) { for (Long id : ids) {
customerMapper.updateCustomerOwnerUser(id,updateDo); customerMapper.updateCustomerByOwnerUserIdIsNull(id,updateDo);
}
} }
} // TODO @QingX错误提示里面可以把客户的名字带上哈不然不知道是谁
private void validateCustomerOwnerExists(CrmCustomerDO customer) {
private void validCustomerOwnerExist(CrmCustomerDO customerDO) { if (customer.getOwnerUserId() != null) {
if (customerDO.getOwnerUserId()!=null) {
throw exception(CUSTOMER_OWNER_EXISTS); throw exception(CUSTOMER_OWNER_EXISTS);
} }
} }
private void validCustomerIsLocked(CrmCustomerDO customerDO) { private void validateCustomerIsLocked(CrmCustomerDO customer) {
if (customerDO.getLockStatus() ==true) { if (customer.getLockStatus()) {
throw exception(CUSTOMER_LOCKED); throw exception(CUSTOMER_LOCKED);
} }
} }
private void validCustomerDeal(CrmCustomerDO customerDO) { private void validateCustomerDeal(CrmCustomerDO customer) {
if (customerDO.getDealStatus() ==true) { if (customer.getDealStatus()) {
throw exception(CUSTOMER_ALREADY_DEAL); throw exception(CUSTOMER_ALREADY_DEAL);
} }
} }