Compare commits
	
		
			2 Commits
		
	
	
		
			92e6cac8a1
			...
			cdbc9919f3
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | cdbc9919f3 | ||
|   | a9fe1187de | 
| @ -0,0 +1,21 @@ | |||||||
|  | package cn.iocoder.yudao.common; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * 字典编码常量类 | ||||||
|  |  * @author PQZ | ||||||
|  |  * @date 16:20 2024/8/1 | ||||||
|  | **/ | ||||||
|  | public class DictBaseConstants { | ||||||
|  |     /**客户类型字典编码*/ | ||||||
|  |     public static final String DICT_CUS_TYPE = "cus_type"; | ||||||
|  |     /**客户初始来源字典编码*/ | ||||||
|  |     public static final String DICT_CUS_DATA_FROM = "cus_data_from"; | ||||||
|  |     /**业务分类字典编码*/ | ||||||
|  |     public static final String DICT_CUS_BUSI_TYPE = "cus_busi_type"; | ||||||
|  |     /**客户注册方式字典编码*/ | ||||||
|  |     public static final String DICT_SIGN_TYPE = "cus_sign_type"; | ||||||
|  |     /**性别*/ | ||||||
|  |     public static final String DICT_SYS_USER_SEX = "system_user_sex"; | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @ -1,4 +0,0 @@ | |||||||
| package cn.iocoder.yudao.common; |  | ||||||
| 
 |  | ||||||
| public interface TestCommon { |  | ||||||
| } |  | ||||||
| @ -1,15 +1,6 @@ | |||||||
| package cn.iocoder.yudao.module.custom.controller.admin; | package cn.iocoder.yudao.module.custom.controller.admin; | ||||||
| 
 | 
 | ||||||
| import cn.iocoder.yudao.framework.apilog.core.annotation.ApiAccessLog; |  | ||||||
| import cn.iocoder.yudao.framework.common.pojo.CommonResult; | import cn.iocoder.yudao.framework.common.pojo.CommonResult; | ||||||
| import cn.iocoder.yudao.framework.common.pojo.PageParam; |  | ||||||
| import cn.iocoder.yudao.framework.common.pojo.PageResult; |  | ||||||
| import cn.iocoder.yudao.framework.common.util.object.BeanUtils; |  | ||||||
| import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils; |  | ||||||
| import cn.iocoder.yudao.module.company.entity.DlCompany; |  | ||||||
| import cn.iocoder.yudao.module.company.service.DlCompanyService; |  | ||||||
| import cn.iocoder.yudao.module.company.vo.CompanyReqVO; |  | ||||||
| import cn.iocoder.yudao.module.custom.entity.CustomerMain; |  | ||||||
| import cn.iocoder.yudao.module.custom.service.CustomerMainService; | import cn.iocoder.yudao.module.custom.service.CustomerMainService; | ||||||
| import cn.iocoder.yudao.module.custom.vo.CustomerMainPageReqVO; | import cn.iocoder.yudao.module.custom.vo.CustomerMainPageReqVO; | ||||||
| import cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO; | import cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO; | ||||||
| @ -24,17 +15,13 @@ import org.springframework.security.access.prepost.PreAuthorize; | |||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| import org.springframework.web.bind.annotation.*; | import org.springframework.web.bind.annotation.*; | ||||||
| 
 | 
 | ||||||
| import javax.servlet.http.HttpServletResponse; |  | ||||||
| import javax.validation.Valid; | import javax.validation.Valid; | ||||||
| 
 | 
 | ||||||
| import java.io.IOException; |  | ||||||
| import java.util.List; |  | ||||||
| 
 |  | ||||||
| import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.EXPORT; |  | ||||||
| import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 客户管理(每个租户的下属客户信息) |  * 客户管理(每个租户的下的客户信息) | ||||||
|  |  * | ||||||
|  * @author : http://www.chiner.pro |  * @author : http://www.chiner.pro | ||||||
|  * @date : 2024-7-31 |  * @date : 2024-7-31 | ||||||
|  */ |  */ | ||||||
| @ -43,20 +30,67 @@ import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success; | |||||||
| @Tag(name = "管理后台 - BASE 企业管理") | @Tag(name = "管理后台 - BASE 企业管理") | ||||||
| @Validated | @Validated | ||||||
| public class CustomerMainController { | public class CustomerMainController { | ||||||
|  |     @Autowired | ||||||
|  |     private CustomerMainService customerMainService; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 客户管理分页列表查询 | ||||||
|  |      * | ||||||
|  |      * @param pageReqVO 客户管理查询条件封装实体 | ||||||
|  |      * @param pageNo    分页参数 | ||||||
|  |      * @param pageSize  分页参数 | ||||||
|  |      * @return cn.iocoder.yudao.framework.common.pojo.CommonResult<com.baomidou.mybatisplus.core.metadata.IPage < ?>> | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 14:56 2024/8/1 | ||||||
|  |      **/ | ||||||
|  |     @GetMapping("/page") | ||||||
|  |     @Operation(summary = "获得客户管理分页") | ||||||
|  |     @PreAuthorize("@ss.hasPermission('base:customer-main:query')") | ||||||
|  |     public CommonResult<IPage<?>> getCustomerMainPage(CustomerMainPageReqVO pageReqVO, | ||||||
|  |                                                       @RequestParam(name = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|  |                                                       @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) { | ||||||
|  |         Page<CustomerMainRespVO> page = new Page<>(pageNo, pageSize); | ||||||
|  |         return success(customerMainService.queryListPage(pageReqVO, page)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 新增客户 | ||||||
|  |      * | ||||||
|  |      * @param saveReqVO 保存客户信息扩展实体 | ||||||
|  |      * @return cn.iocoder.yudao.framework.common.pojo.CommonResult<java.lang.Boolean> | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 15:42 2024/8/1 | ||||||
|  |      **/ | ||||||
|     @PostMapping("/create") |     @PostMapping("/create") | ||||||
|     @Operation(summary = "创建客户管理") |     @Operation(summary = "创建客户管理") | ||||||
|     @PreAuthorize("@ss.hasPermission('base:customer-main:create')") |     @PreAuthorize("@ss.hasPermission('base:customer-main:create')") | ||||||
|     public CommonResult<Boolean> createCustomerMain(@Valid @RequestBody CustomerMainSaveReqVO createReqVO) { |     public CommonResult<Boolean> createCustomerMain(@Valid @RequestBody CustomerMainSaveReqVO saveReqVO) { | ||||||
|         return success(true); |         return success(true); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 编辑客户 | ||||||
|  |      * | ||||||
|  |      * @param saveReqVO 保存客户信息扩展实体 | ||||||
|  |      * @return cn.iocoder.yudao.framework.common.pojo.CommonResult<java.lang.Boolean> | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 15:44 2024/8/1 | ||||||
|  |      **/ | ||||||
|     @PutMapping("/update") |     @PutMapping("/update") | ||||||
|     @Operation(summary = "更新客户管理") |     @Operation(summary = "更新客户管理") | ||||||
|     @PreAuthorize("@ss.hasPermission('base:customer-main:update')") |     @PreAuthorize("@ss.hasPermission('base:customer-main:update')") | ||||||
|     public CommonResult<Boolean> updateCustomerMain(@Valid @RequestBody CustomerMainSaveReqVO updateReqVO) { |     public CommonResult<Boolean> updateCustomerMain(@Valid @RequestBody CustomerMainSaveReqVO saveReqVO) { | ||||||
|         return success(true); |         return success(true); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 删除客户 | ||||||
|  |      * | ||||||
|  |      * @param id 保存客户信息扩展实体 | ||||||
|  |      * @return cn.iocoder.yudao.framework.common.pojo.CommonResult<java.lang.Boolean> | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 15:44 2024/8/1 | ||||||
|  |      **/ | ||||||
|     @DeleteMapping("/delete") |     @DeleteMapping("/delete") | ||||||
|     @Operation(summary = "删除客户管理") |     @Operation(summary = "删除客户管理") | ||||||
|     @Parameter(name = "id", description = "编号", required = true) |     @Parameter(name = "id", description = "编号", required = true) | ||||||
| @ -65,6 +99,14 @@ public class CustomerMainController { | |||||||
|         return success(true); |         return success(true); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 通过客户id查询客户信息 | ||||||
|  |      * | ||||||
|  |      * @param id 客户id | ||||||
|  |      * @return cn.iocoder.yudao.framework.common.pojo.CommonResult<java.lang.Boolean> | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 15:44 2024/8/1 | ||||||
|  |      **/ | ||||||
|     @GetMapping("/get") |     @GetMapping("/get") | ||||||
|     @Operation(summary = "获得客户管理") |     @Operation(summary = "获得客户管理") | ||||||
|     @Parameter(name = "id", description = "编号", required = true, example = "1024") |     @Parameter(name = "id", description = "编号", required = true, example = "1024") | ||||||
| @ -73,23 +115,4 @@ public class CustomerMainController { | |||||||
|         return success(true); |         return success(true); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @GetMapping("/page") |  | ||||||
|     @Operation(summary = "获得客户管理分页") |  | ||||||
|     @PreAuthorize("@ss.hasPermission('base:customer-main:query')") |  | ||||||
|     public CommonResult<Boolean> getCustomerMainPage(@Valid CustomerMainPageReqVO pageReqVO) { |  | ||||||
|         return success(true); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @GetMapping("/export-excel") |  | ||||||
|     @Operation(summary = "导出客户管理 Excel") |  | ||||||
|     @PreAuthorize("@ss.hasPermission('base:customer-main:export')") |  | ||||||
|     @ApiAccessLog(operateType = EXPORT) |  | ||||||
|     public void exportCustomerMainExcel(@Valid CustomerMainPageReqVO pageReqVO, |  | ||||||
|                                         HttpServletResponse response) throws IOException { |  | ||||||
|         pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE); |  | ||||||
| //        List<CustomerMain> list = customerMainService.getCustomerMainPage(pageReqVO).getList(); |  | ||||||
| //        // 导出 Excel |  | ||||||
| //        ExcelUtils.write(response, "客户管理.xls", "数据", CustomerMainRespVO.class, |  | ||||||
| //                BeanUtils.toBean(list, CustomerMainRespVO.class)); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| @ -1,11 +1,15 @@ | |||||||
| package cn.iocoder.yudao.module.custom.entity; | package cn.iocoder.yudao.module.custom.entity; | ||||||
| 
 | 
 | ||||||
|  | import cn.iocoder.yudao.framework.excel.core.annotations.DictFormat; | ||||||
| import cn.iocoder.yudao.framework.tenant.core.db.TenantBaseDO; | import cn.iocoder.yudao.framework.tenant.core.db.TenantBaseDO; | ||||||
|  | import com.baomidou.mybatisplus.annotation.IdType; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableId; | ||||||
|  | import com.baomidou.mybatisplus.annotation.TableName; | ||||||
| import lombok.*; | import lombok.*; | ||||||
| 
 | 
 | ||||||
| import java.time.LocalDateTime; | import java.util.Date; | ||||||
| 
 | 
 | ||||||
| import com.baomidou.mybatisplus.annotation.*; | import static cn.iocoder.yudao.common.DictBaseConstants.*; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 客户管理 DO |  * 客户管理 DO | ||||||
| @ -13,7 +17,6 @@ import com.baomidou.mybatisplus.annotation.*; | |||||||
|  * @author pqz |  * @author pqz | ||||||
|  */ |  */ | ||||||
| @TableName("base_customer_main") | @TableName("base_customer_main") | ||||||
| @KeySequence("base_customer_main_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。 |  | ||||||
| @Data | @Data | ||||||
| @EqualsAndHashCode(callSuper = true) | @EqualsAndHashCode(callSuper = true) | ||||||
| @ToString(callSuper = true) | @ToString(callSuper = true) | ||||||
| @ -25,7 +28,7 @@ public class CustomerMain extends TenantBaseDO { | |||||||
|     /** |     /** | ||||||
|      * uuid |      * uuid | ||||||
|      */ |      */ | ||||||
|     @TableId(type = IdType.INPUT) |     @TableId(type = IdType.ASSIGN_UUID) | ||||||
|     private String id; |     private String id; | ||||||
|     /** |     /** | ||||||
|      * sys_user表id |      * sys_user表id | ||||||
| @ -34,6 +37,7 @@ public class CustomerMain extends TenantBaseDO { | |||||||
|     /** |     /** | ||||||
|      * 用户类型 |      * 用户类型 | ||||||
|      */ |      */ | ||||||
|  |     @DictFormat(DICT_CUS_TYPE) | ||||||
|     private String typeCode; |     private String typeCode; | ||||||
|     /** |     /** | ||||||
|      * 所属企业code(部门表code) |      * 所属企业code(部门表code) | ||||||
| @ -50,7 +54,7 @@ public class CustomerMain extends TenantBaseDO { | |||||||
|     /** |     /** | ||||||
|      * 生日 |      * 生日 | ||||||
|      */ |      */ | ||||||
|     private LocalDateTime birthday; |     private Date birthday; | ||||||
|     /** |     /** | ||||||
|      * 住址 |      * 住址 | ||||||
|      */ |      */ | ||||||
| @ -58,6 +62,7 @@ public class CustomerMain extends TenantBaseDO { | |||||||
|     /** |     /** | ||||||
|      * 性别 |      * 性别 | ||||||
|      */ |      */ | ||||||
|  |     @DictFormat(DICT_SYS_USER_SEX) | ||||||
|     private String sex; |     private String sex; | ||||||
|     /** |     /** | ||||||
|      * 身份证号 |      * 身份证号 | ||||||
| @ -70,14 +75,16 @@ public class CustomerMain extends TenantBaseDO { | |||||||
|     /** |     /** | ||||||
|      * 客户初始来源 |      * 客户初始来源 | ||||||
|      */ |      */ | ||||||
|  |     @DictFormat(DICT_CUS_DATA_FROM) | ||||||
|     private String dataFrom; |     private String dataFrom; | ||||||
|     /** |     /** | ||||||
|      * 最近业务办理时间 |      * 最近业务办理时间 | ||||||
|      */ |      */ | ||||||
|     private LocalDateTime nearDoTime; |     private Date nearDoTime; | ||||||
|     /** |     /** | ||||||
|      * 最近办理业务(数据字典业务标识) |      * 最近办理业务(数据字典业务标识) | ||||||
|      */ |      */ | ||||||
|  |     @DictFormat(DICT_CUS_BUSI_TYPE) | ||||||
|     private String nearDoContent; |     private String nearDoContent; | ||||||
|     /** |     /** | ||||||
|      * 邀请者user_id |      * 邀请者user_id | ||||||
| @ -86,6 +93,7 @@ public class CustomerMain extends TenantBaseDO { | |||||||
|     /** |     /** | ||||||
|      * 邀请者类型 |      * 邀请者类型 | ||||||
|      */ |      */ | ||||||
|  |     @DictFormat(DICT_SIGN_TYPE) | ||||||
|     private String inviterType; |     private String inviterType; | ||||||
|     /** |     /** | ||||||
|      * 客户状态 |      * 客户状态 | ||||||
|  | |||||||
| @ -1,8 +1,15 @@ | |||||||
| package cn.iocoder.yudao.module.custom.mapper; | package cn.iocoder.yudao.module.custom.mapper; | ||||||
| 
 | 
 | ||||||
|  | import cn.iocoder.yudao.module.company.entity.DlCompany; | ||||||
|  | import cn.iocoder.yudao.module.company.vo.CompanyReqVO; | ||||||
| import cn.iocoder.yudao.module.custom.entity.CustomerMain; | import cn.iocoder.yudao.module.custom.entity.CustomerMain; | ||||||
|  | import cn.iocoder.yudao.module.custom.vo.CustomerMainPageReqVO; | ||||||
|  | import cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO; | ||||||
| import com.baomidou.mybatisplus.core.mapper.BaseMapper; | import com.baomidou.mybatisplus.core.mapper.BaseMapper; | ||||||
|  | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import org.apache.ibatis.annotations.Mapper; | import org.apache.ibatis.annotations.Mapper; | ||||||
|  | import org.apache.ibatis.annotations.Param; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 客户管理 Mapper |  * 客户管理 Mapper | ||||||
| @ -12,5 +19,16 @@ import org.apache.ibatis.annotations.Mapper; | |||||||
| @Mapper | @Mapper | ||||||
| public interface CustomerMainMapper extends BaseMapper<CustomerMain> { | public interface CustomerMainMapper extends BaseMapper<CustomerMain> { | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 客户管理分页列表查询 | ||||||
|  |      * | ||||||
|  |      * @param pageReqVO 客户管理查询条件封装实体 | ||||||
|  |      * @param page      分页参数 | ||||||
|  |      * @return com.baomidou.mybatisplus.core.metadata.IPage<cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO> | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 15:01 2024/8/1 | ||||||
|  |      **/ | ||||||
|  |     IPage<CustomerMainRespVO> selectListPage(@Param("entity") CustomerMainPageReqVO pageReqVO, Page<CustomerMainRespVO> page); | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| @ -1,7 +1,13 @@ | |||||||
| package cn.iocoder.yudao.module.custom.service; | package cn.iocoder.yudao.module.custom.service; | ||||||
| 
 | 
 | ||||||
| import cn.iocoder.yudao.module.company.entity.DlCompany; | import cn.iocoder.yudao.module.company.entity.DlCompany; | ||||||
|  | import cn.iocoder.yudao.module.company.vo.CompanyReqVO; | ||||||
| import cn.iocoder.yudao.module.custom.entity.CustomerMain; | import cn.iocoder.yudao.module.custom.entity.CustomerMain; | ||||||
|  | import cn.iocoder.yudao.module.custom.vo.CustomerMainPageReqVO; | ||||||
|  | import cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO; | ||||||
|  | import cn.iocoder.yudao.module.custom.vo.CustomerMainSaveReqVO; | ||||||
|  | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.baomidou.mybatisplus.extension.service.IService; | import com.baomidou.mybatisplus.extension.service.IService; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
| @ -11,6 +17,25 @@ import com.baomidou.mybatisplus.extension.service.IService; | |||||||
|  */ |  */ | ||||||
| public interface CustomerMainService extends IService<CustomerMain> { | public interface CustomerMainService extends IService<CustomerMain> { | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 客户管理分页列表查询 | ||||||
|  |      * | ||||||
|  |      * @param pageReqVO 客户管理查询条件封装实体 | ||||||
|  |      * @param page      分页参数 | ||||||
|  |      * @return com.baomidou.mybatisplus.core.metadata.IPage<cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO> | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 14:57 2024/8/1 | ||||||
|  |      **/ | ||||||
|  |     IPage<CustomerMainRespVO> queryListPage(CustomerMainPageReqVO pageReqVO, Page<CustomerMainRespVO> page); | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 保存客户信息 | ||||||
|  |      * | ||||||
|  |      * @param saveReqVO 保存客户信息扩展实体 | ||||||
|  |      * @return void | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 15:46 2024/8/1 | ||||||
|  |      **/ | ||||||
|  |     void saveCustomer(CustomerMainSaveReqVO saveReqVO); | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| @ -1,9 +1,16 @@ | |||||||
| package cn.iocoder.yudao.module.custom.service.impl; | package cn.iocoder.yudao.module.custom.service.impl; | ||||||
| 
 | 
 | ||||||
|  | import cn.hutool.json.JSONUtil; | ||||||
| import cn.iocoder.yudao.module.custom.entity.CustomerMain; | import cn.iocoder.yudao.module.custom.entity.CustomerMain; | ||||||
| import cn.iocoder.yudao.module.custom.mapper.CustomerMainMapper; | import cn.iocoder.yudao.module.custom.mapper.CustomerMainMapper; | ||||||
| import cn.iocoder.yudao.module.custom.service.CustomerMainService; | import cn.iocoder.yudao.module.custom.service.CustomerMainService; | ||||||
|  | import cn.iocoder.yudao.module.custom.vo.CustomerMainPageReqVO; | ||||||
|  | import cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO; | ||||||
|  | import cn.iocoder.yudao.module.custom.vo.CustomerMainSaveReqVO; | ||||||
|  | import com.baomidou.mybatisplus.core.metadata.IPage; | ||||||
|  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | ||||||
|  | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Service; | import org.springframework.stereotype.Service; | ||||||
| import org.springframework.validation.annotation.Validated; | import org.springframework.validation.annotation.Validated; | ||||||
| 
 | 
 | ||||||
| @ -16,4 +23,34 @@ import org.springframework.validation.annotation.Validated; | |||||||
| @Validated | @Validated | ||||||
| public class CustomerMainServiceImpl extends ServiceImpl<CustomerMainMapper, CustomerMain> implements CustomerMainService { | public class CustomerMainServiceImpl extends ServiceImpl<CustomerMainMapper, CustomerMain> implements CustomerMainService { | ||||||
| 
 | 
 | ||||||
|  |     @Autowired | ||||||
|  |     private CustomerMainMapper customerMainMapper; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 客户管理分页列表查询 | ||||||
|  |      * | ||||||
|  |      * @param pageReqVO 客户管理查询条件封装实体 | ||||||
|  |      * @param page      分页参数 | ||||||
|  |      * @return com.baomidou.mybatisplus.core.metadata.IPage<cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO> | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 14:57 2024/8/1 | ||||||
|  |      **/ | ||||||
|  |     @Override | ||||||
|  |     public IPage<CustomerMainRespVO> queryListPage(CustomerMainPageReqVO pageReqVO, Page<CustomerMainRespVO> page) { | ||||||
|  |         return customerMainMapper.selectListPage(pageReqVO,page); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 保存客户信息 | ||||||
|  |      * | ||||||
|  |      * @param saveReqVO 保存客户信息扩展实体 | ||||||
|  |      * @return void | ||||||
|  |      * @author PQZ | ||||||
|  |      * @date 15:46 2024/8/1 | ||||||
|  |      **/ | ||||||
|  |     @Override | ||||||
|  |     public void saveCustomer(CustomerMainSaveReqVO saveReqVO) { | ||||||
|  |         CustomerMain main = JSONUtil.toBean(JSONUtil.parseObj(saveReqVO).toJSONString(0), CustomerMain.class); | ||||||
|  |         this.saveOrUpdate(main); | ||||||
|  |     } | ||||||
| } | } | ||||||
| @ -1,71 +1,17 @@ | |||||||
| package cn.iocoder.yudao.module.custom.vo; | package cn.iocoder.yudao.module.custom.vo; | ||||||
| 
 | 
 | ||||||
| import lombok.*; | import cn.iocoder.yudao.module.custom.entity.CustomerMain; | ||||||
| import java.util.*; |  | ||||||
| import io.swagger.v3.oas.annotations.media.Schema; | import io.swagger.v3.oas.annotations.media.Schema; | ||||||
| import cn.iocoder.yudao.framework.common.pojo.PageParam; | import lombok.Data; | ||||||
| import org.springframework.format.annotation.DateTimeFormat; | import lombok.EqualsAndHashCode; | ||||||
| import java.time.LocalDateTime; | import lombok.ToString; | ||||||
| 
 |  | ||||||
| import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND; |  | ||||||
| 
 | 
 | ||||||
| @Schema(description = "管理后台 - 客户管理分页 Request VO") | @Schema(description = "管理后台 - 客户管理分页 Request VO") | ||||||
| @Data | @Data | ||||||
| @EqualsAndHashCode(callSuper = true) | @EqualsAndHashCode(callSuper = true) | ||||||
| @ToString(callSuper = true) | @ToString(callSuper = true) | ||||||
| public class CustomerMainPageReqVO extends PageParam { | public class CustomerMainPageReqVO extends CustomerMain { | ||||||
| 
 |     /**系统标识*/ | ||||||
|     @Schema(description = "sys_user表id", example = "17679") |     private String systemCode; | ||||||
|     private String userId; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "用户类型") |  | ||||||
|     private String typeCode; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "所属企业code(部门表code)") |  | ||||||
|     private String deptCode; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "客户名称(政企客户填企业名称)", example = "赵六") |  | ||||||
|     private String cusName; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "联系方式") |  | ||||||
|     private String phoneNumber; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "生日") |  | ||||||
|     private LocalDateTime birthday; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "住址") |  | ||||||
|     private String address; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "性别") |  | ||||||
|     private String sex; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "身份证号") |  | ||||||
|     private String idCard; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "身份证照片") |  | ||||||
|     private String idCardImage; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "客户初始来源") |  | ||||||
|     private String dataFrom; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "最近业务办理时间") |  | ||||||
|     @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) |  | ||||||
|     private LocalDateTime[] nearDoTime; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "最近办理业务(数据字典业务标识)") |  | ||||||
|     private String nearDoContent; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "邀请者user_id") |  | ||||||
|     private String inviter; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "邀请者类型", example = "2") |  | ||||||
|     private String inviterType; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "客户状态", example = "1") |  | ||||||
|     private String status; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "创建时间") |  | ||||||
|     @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) |  | ||||||
|     private LocalDateTime[] createTime; |  | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| @ -1,5 +1,6 @@ | |||||||
| package cn.iocoder.yudao.module.custom.vo; | package cn.iocoder.yudao.module.custom.vo; | ||||||
| 
 | 
 | ||||||
|  | import cn.iocoder.yudao.module.custom.entity.CustomerMain; | ||||||
| import io.swagger.v3.oas.annotations.media.Schema; | import io.swagger.v3.oas.annotations.media.Schema; | ||||||
| import lombok.*; | import lombok.*; | ||||||
| import java.util.*; | import java.util.*; | ||||||
| @ -10,78 +11,19 @@ import com.alibaba.excel.annotation.*; | |||||||
| @Schema(description = "管理后台 - 客户管理 Response VO") | @Schema(description = "管理后台 - 客户管理 Response VO") | ||||||
| @Data | @Data | ||||||
| @ExcelIgnoreUnannotated | @ExcelIgnoreUnannotated | ||||||
| public class CustomerMainRespVO { | public class CustomerMainRespVO extends CustomerMain { | ||||||
| 
 |     /**客户管理子表id*/ | ||||||
|     @Schema(description = "uuid", requiredMode = Schema.RequiredMode.REQUIRED, example = "29951") |     private String itemId; | ||||||
|     @ExcelProperty("uuid") |     /**系统标识*/ | ||||||
|     private String id; |     private String systemCode; | ||||||
| 
 |     /**用户等级*/ | ||||||
|     @Schema(description = "sys_user表id", example = "17679") |     private String userLevel; | ||||||
|     @ExcelProperty("sys_user表id") |     /**服务内容*/ | ||||||
|     private String userId; |     private String serContent; | ||||||
| 
 |     /**服务开始时间*/ | ||||||
|     @Schema(description = "用户类型") |     private Date serTimeStart; | ||||||
|     @ExcelProperty("用户类型") |     /**服务结束时间*/ | ||||||
|     private String typeCode; |     private Date serTimeEnd; | ||||||
| 
 |     /**大json*/ | ||||||
|     @Schema(description = "所属企业code(部门表code)") |     private String bigJson; | ||||||
|     @ExcelProperty("所属企业code(部门表code)") |  | ||||||
|     private String deptCode; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "客户名称(政企客户填企业名称)", example = "赵六") |  | ||||||
|     @ExcelProperty("客户名称(政企客户填企业名称)") |  | ||||||
|     private String cusName; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "联系方式") |  | ||||||
|     @ExcelProperty("联系方式") |  | ||||||
|     private String phoneNumber; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "生日") |  | ||||||
|     @ExcelProperty("生日") |  | ||||||
|     private LocalDateTime birthday; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "住址") |  | ||||||
|     @ExcelProperty("住址") |  | ||||||
|     private String address; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "性别") |  | ||||||
|     @ExcelProperty("性别") |  | ||||||
|     private String sex; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "身份证号") |  | ||||||
|     @ExcelProperty("身份证号") |  | ||||||
|     private String idCard; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "身份证照片") |  | ||||||
|     @ExcelProperty("身份证照片") |  | ||||||
|     private String idCardImage; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "客户初始来源") |  | ||||||
|     @ExcelProperty("客户初始来源") |  | ||||||
|     private String dataFrom; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "最近业务办理时间") |  | ||||||
|     @ExcelProperty("最近业务办理时间") |  | ||||||
|     private LocalDateTime nearDoTime; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "最近办理业务(数据字典业务标识)") |  | ||||||
|     @ExcelProperty("最近办理业务(数据字典业务标识)") |  | ||||||
|     private String nearDoContent; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "邀请者user_id") |  | ||||||
|     @ExcelProperty("邀请者user_id") |  | ||||||
|     private String inviter; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "邀请者类型", example = "2") |  | ||||||
|     @ExcelProperty("邀请者类型") |  | ||||||
|     private String inviterType; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "客户状态", example = "1") |  | ||||||
|     @ExcelProperty("客户状态") |  | ||||||
|     private String status; |  | ||||||
| 
 |  | ||||||
|     @Schema(description = "创建时间") |  | ||||||
|     @ExcelProperty("创建时间") |  | ||||||
|     private LocalDateTime createTime; |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
| @ -2,11 +2,54 @@ | |||||||
| <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||||||
| <mapper namespace="cn.iocoder.yudao.module.custom.mapper.CustomerMainMapper"> | <mapper namespace="cn.iocoder.yudao.module.custom.mapper.CustomerMainMapper"> | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|     <!-- |     <!-- | ||||||
|         一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。 |         一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。 | ||||||
|         无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。 |         无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。 | ||||||
|         代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。 |         代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。 | ||||||
|         文档可见:https://www.iocoder.cn/MyBatis/x-plugins/ |         文档可见:https://www.iocoder.cn/MyBatis/x-plugins/ | ||||||
|      --> |      --> | ||||||
| 
 |     <select id="selectListPage" resultType="cn.iocoder.yudao.module.custom.vo.CustomerMainRespVO"> | ||||||
|  |         SELECT | ||||||
|  |         main.id AS id, | ||||||
|  |         main.user_id AS userId, | ||||||
|  |         main.type_code AS typeCode, | ||||||
|  |         main.dept_code AS deptCode, | ||||||
|  |         main.cus_name AS cusName, | ||||||
|  |         main.phone_number AS phoneNumber, | ||||||
|  |         main.birthday AS birthday, | ||||||
|  |         main.address AS address, | ||||||
|  |         main.sex AS sex, | ||||||
|  |         main.id_card AS idCard, | ||||||
|  |         main.id_card_image AS idCardImage, | ||||||
|  |         main.data_from AS dataFrom, | ||||||
|  |         main.near_do_time AS nearDoTime, | ||||||
|  |         main.near_do_content AS nearDoContent, | ||||||
|  |         main.inviter AS inviter, | ||||||
|  |         main.inviter_type AS inviterType, | ||||||
|  |         main.status AS status, | ||||||
|  |         item.id AS itemId, | ||||||
|  |         item.system_code AS systemCode, | ||||||
|  |         item.user_level AS userLevel, | ||||||
|  |         item.ser_content AS serContent, | ||||||
|  |         item.ser_time_start AS serTimeStart, | ||||||
|  |         item.ser_time_end AS serTimeEnd, | ||||||
|  |         item.big_json AS bigJson | ||||||
|  |         FROM | ||||||
|  |         base_customer_main main | ||||||
|  |         LEFT JOIN base_customer_item item ON main.id = item.cus_id | ||||||
|  |         <where> | ||||||
|  |             main.deleted = 0 | ||||||
|  |             <if test="entity.cusName != null and entity.cusName != ''"> | ||||||
|  |                 AND main.cus_name LIKE concat('%',#{entity.cusName},'%') | ||||||
|  |             </if> | ||||||
|  |             <if test="entity.typeCode != null and entity.typeCode != ''"> | ||||||
|  |                 AND main.type_code = #{entity.typeCode} | ||||||
|  |             </if> | ||||||
|  |             <if test="entity.systemCode != null and entity.systemCode != ''"> | ||||||
|  |                 AND item.system_code = #{entity.systemCode} | ||||||
|  |             </if> | ||||||
|  |         </where> | ||||||
|  |         ORDER BY main.create_time DESC | ||||||
|  |     </select> | ||||||
| </mapper> | </mapper> | ||||||
| @ -175,7 +175,8 @@ logging: | |||||||
|     cn.iocoder.yudao.module.crm.dal.mysql: debug |     cn.iocoder.yudao.module.crm.dal.mysql: debug | ||||||
|     cn.iocoder.yudao.module.erp.dal.mysql: debug |     cn.iocoder.yudao.module.erp.dal.mysql: debug | ||||||
|     org.springframework.context.support.PostProcessorRegistrationDelegate: ERROR # TODO 芋艿:先禁用,Spring Boot 3.X 存在部分错误的 WARN 提示 |     org.springframework.context.support.PostProcessorRegistrationDelegate: ERROR # TODO 芋艿:先禁用,Spring Boot 3.X 存在部分错误的 WARN 提示 | ||||||
|     cn.iocoder.yudao.module.custom.mapper.DlCompanyMapper: debug # |     cn.iocoder.yudao.module.custom.mapper: debug # | ||||||
|  |     cn.iocoder.yudao.module.company.mapper: debug # | ||||||
| 
 | 
 | ||||||
| debug: false | debug: false | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user