package com.ruoyi.basic.service.impl;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
import com.ruoyi.basic.mapper.CustomerMapper;
|
import com.ruoyi.basic.pojo.Customer;
|
import com.ruoyi.basic.service.ICustomerService;
|
import com.ruoyi.common.utils.SecurityUtils;
|
import com.ruoyi.common.utils.StringUtils;
|
import com.ruoyi.framework.security.LoginUser;
|
import lombok.AllArgsConstructor;
|
import lombok.extern.slf4j.Slf4j;
|
import org.springframework.stereotype.Service;
|
|
import java.util.Arrays;
|
import java.util.List;
|
import java.util.Map;
|
import java.util.stream.Collectors;
|
|
|
/**
|
* 客户档案Service业务层处理
|
*
|
* @author ruoyi
|
* @date 2025-05-07
|
*/
|
@Service
|
@AllArgsConstructor
|
@Slf4j
|
public class CustomerServiceImpl extends ServiceImpl<CustomerMapper, Customer> implements ICustomerService {
|
private CustomerMapper customerMapper;
|
|
/**
|
* 查询客户档案
|
*
|
* @param id 客户档案主键
|
* @return 客户档案
|
*/
|
@Override
|
public Customer selectCustomerById(Long id) {
|
return customerMapper.selectById(id);
|
}
|
|
/**
|
* 查询客户档案列表
|
*
|
* @param customer 客户档案
|
* @return 客户档案
|
*/
|
@Override
|
public List<Customer> selectCustomerList(Customer customer) {
|
LambdaQueryWrapper<Customer> queryWrapper = new LambdaQueryWrapper<>();
|
|
if (StringUtils.isNotBlank(customer.getCustomerName())) {
|
queryWrapper.eq(Customer::getCustomerName, customer.getCustomerName());
|
}
|
|
List<Customer> customerList = customerMapper.selectList(queryWrapper);
|
|
// 使用 Stream 修改每个 Customer 的 addressPhone 字段
|
return customerList.stream().peek(c ->
|
c.setAddressPhone(c.getCompanyAddress() + "( " + c.getCompanyPhone() + " )")
|
).collect(Collectors.toList());
|
}
|
|
/**
|
* 新增客户档案
|
*
|
* @param customer 客户档案
|
* @return 结果
|
*/
|
@Override
|
public int insertCustomer(Customer customer) {
|
LoginUser loginUser = SecurityUtils.getLoginUser();
|
Integer tenantId = loginUser.getTenantId();
|
customer.setTenantId(Long.valueOf(tenantId));
|
return customerMapper.insert(customer);
|
}
|
|
/**
|
* 修改客户档案
|
*
|
* @param customer 客户档案
|
* @return 结果
|
*/
|
@Override
|
public int updateCustomer(Customer customer) {
|
LoginUser loginUser = SecurityUtils.getLoginUser();
|
Integer tenantId = loginUser.getTenantId();
|
customer.setTenantId(Long.valueOf(tenantId));
|
return customerMapper.updateById(customer);
|
}
|
|
/**
|
* 批量删除客户档案
|
*
|
* @param ids 需要删除的客户档案主键
|
* @return 结果
|
*/
|
@Override
|
public int deleteCustomerByIds(Long[] ids) {
|
List<Long> idList = Arrays.asList(ids);
|
return customerMapper.deleteBatchIds(idList);
|
}
|
|
@Override
|
public List<Customer> selectCustomerListByIds(Long[] ids) {
|
LambdaQueryWrapper<Customer> queryWrapper = new LambdaQueryWrapper<>();
|
queryWrapper.in(Customer::getId, Arrays.asList(ids));
|
return customerMapper.selectList(queryWrapper);
|
}
|
|
@Override
|
public List<Map<String, Object>> customerList(Customer customer) {
|
LambdaQueryWrapper<Customer> queryWrapper = Wrappers.lambdaQuery();
|
queryWrapper.select(Customer::getId, Customer::getCustomerName,Customer::getTaxpayerIdentificationNumber);
|
|
// 获取原始查询结果
|
List<Map<String, Object>> result = customerMapper.selectMaps(queryWrapper);
|
|
// 将下划线命名转换为驼峰命名
|
return result.stream().map(map -> map.entrySet().stream()
|
.collect(Collectors.toMap(
|
entry -> underlineToCamel(entry.getKey()),
|
Map.Entry::getValue))
|
).collect(Collectors.toList());
|
}
|
|
/**
|
* 下划线命名转驼峰命名
|
*/
|
private String underlineToCamel(String param) {
|
if (param == null || "".equals(param.trim())) {
|
return "";
|
}
|
int len = param.length();
|
StringBuilder sb = new StringBuilder(len);
|
for (int i = 0; i < len; i++) {
|
char c = param.charAt(i);
|
if (c == '_') {
|
if (++i < len) {
|
sb.append(Character.toUpperCase(param.charAt(i)));
|
}
|
} else {
|
sb.append(Character.toLowerCase(c));
|
}
|
}
|
return sb.toString();
|
}
|
}
|