ProjectServiceImpl.java 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  1. package com.ylx.project.service.impl;
  2. import cn.hutool.core.bean.BeanUtil;
  3. import cn.hutool.core.collection.CollUtil;
  4. import cn.hutool.core.collection.CollectionUtil;
  5. import cn.hutool.core.util.ObjectUtil;
  6. import cn.hutool.core.util.StrUtil;
  7. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  8. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  9. import com.baomidou.mybatisplus.core.metadata.IPage;
  10. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  11. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  12. import com.ylx.common.core.domain.entity.SysDictData;
  13. import com.ylx.common.exception.ServiceException;
  14. import com.ylx.common.utils.DateUtils;
  15. import com.ylx.common.utils.SecurityUtils;
  16. import com.ylx.massage.domain.dto.OptionDTO;
  17. import com.ylx.massage.domain.dto.ServiceOptionDTO;
  18. import com.ylx.massage.domain.vo.ProductOptionVO;
  19. import com.ylx.massage.domain.vo.ProductServiceOptionVO;
  20. import com.ylx.massage.service.IMaProjectService;
  21. import com.ylx.project.domain.Project;
  22. import com.ylx.project.domain.bookMerchant.dto.BookMerchantDTO;
  23. import com.ylx.project.domain.bookMerchant.vo.BookMerchantVO;
  24. import com.ylx.project.domain.bookMerchant.vo.BookProjectDetailVO;
  25. import com.ylx.project.domain.bookMerchant.vo.ProjectInfoVO;
  26. import com.ylx.project.domain.dto.ProjectAddDTO;
  27. import com.ylx.project.domain.dto.ProjectSearchDTO;
  28. import com.ylx.project.domain.dto.ProjectUpdateDTO;
  29. import com.ylx.project.domain.vo.ProjectBaseVo;
  30. import com.ylx.project.domain.vo.ProjectDetailVo;
  31. import com.ylx.project.domain.vo.ProjectPageVo;
  32. import com.ylx.project.enums.ProjectStatusEnum;
  33. import com.ylx.project.mapper.ProjectMapper;
  34. import com.ylx.project.service.ProjectService;
  35. import com.ylx.servicecategory.domain.ServiceCategory;
  36. import com.ylx.servicecategory.service.ServiceCategoryService;
  37. import com.ylx.system.service.ISysDictDataService;
  38. import lombok.extern.slf4j.Slf4j;
  39. import org.apache.commons.lang3.StringUtils;
  40. import org.springframework.stereotype.Service;
  41. import org.springframework.transaction.annotation.Transactional;
  42. import javax.annotation.Resource;
  43. import java.math.BigDecimal;
  44. import java.util.Arrays;
  45. import java.util.List;
  46. import java.util.stream.Collectors;
  47. @Slf4j
  48. @Service
  49. public class ProjectServiceImpl extends ServiceImpl<ProjectMapper, Project> implements ProjectService {
  50. @Resource
  51. private ServiceCategoryService serviceCategoryService;
  52. @Resource
  53. private ISysDictDataService sysDictDataService;
  54. @Resource
  55. private IMaProjectService maProjectService;
  56. @Override
  57. public Page<ProjectPageVo> list(Page<Project> page, ProjectSearchDTO dto) {
  58. LambdaQueryWrapper<Project> queryWrapper = new LambdaQueryWrapper<>();
  59. // 项目标题
  60. if (StringUtils.isNotBlank(dto.getTitle())) {
  61. queryWrapper.like(Project::getTitle, dto.getTitle());
  62. }
  63. // 状态
  64. if (ObjectUtil.isNotEmpty(dto.getStatus())) {
  65. queryWrapper.eq(Project::getStatus, dto.getStatus());
  66. }
  67. // 服务类目ID
  68. if (ObjectUtil.isNotEmpty(dto.getCategoryId())) {
  69. queryWrapper.eq(Project::getCategoryId, dto.getCategoryId());
  70. }
  71. queryWrapper.orderByDesc(Project::getCreateTime).orderByDesc(Project::getSortOrder);
  72. Page<ProjectPageVo> pageData = new Page<>();
  73. pageData.setCurrent(page.getCurrent());
  74. pageData.setSize(page.getSize());
  75. Page<Project> projectPage = this.baseMapper.selectPage(page, queryWrapper);
  76. if (ObjectUtil.isNotNull(projectPage) && CollectionUtil.isNotEmpty(projectPage.getRecords())) {
  77. List<ProjectPageVo> voList = projectPage.getRecords().stream()
  78. .map(this::convertToVo) // 抽取转换方法
  79. .collect(Collectors.toList());
  80. pageData.setRecords(voList);
  81. pageData.setTotal(projectPage.getTotal());
  82. pageData.setPages(projectPage.getPages());
  83. }
  84. return pageData;
  85. }
  86. @Override
  87. @Transactional(rollbackFor = Exception.class)
  88. public void edit(ProjectUpdateDTO dto) {
  89. Long id = dto.getId();
  90. Project entity = this.getById(id);
  91. if (ObjectUtil.isNull(entity)) {
  92. throw new IllegalArgumentException("参数有误,项目不存在");
  93. }
  94. BeanUtil.copyProperties(dto, entity);
  95. entity.setUpdateBy(SecurityUtils.getUsername());
  96. entity.setUpdateTime(DateUtils.getNowDate());
  97. // 根据项目亮点ID集合获取项目亮点
  98. String highlightNames = this.buildHighlightNames(dto.getHighlightIds());
  99. if (StrUtil.isNotEmpty(highlightNames)) {
  100. entity.setHighlight(highlightNames);
  101. }
  102. boolean updateResult = this.updateById(entity);
  103. if (!updateResult) {
  104. throw new ServiceException("更新项目失败");
  105. }
  106. }
  107. @Override
  108. @Transactional(rollbackFor = Exception.class)
  109. public void add(ProjectAddDTO dto) {
  110. Project entity = new Project();
  111. ServiceCategory serviceCategoryDetail = this.serviceCategoryService.getServiceCategoryDetail(dto.getCategoryId());
  112. if (ObjectUtil.isNull(serviceCategoryDetail)) {
  113. throw new ServiceException("服务类目不存在");
  114. }
  115. BeanUtil.copyProperties(dto, entity);
  116. entity.setType(serviceCategoryDetail.getServiceTag());
  117. entity.setCreateBy(SecurityUtils.getUsername());
  118. entity.setCreateTime(DateUtils.getNowDate());
  119. // 根据项目亮点ID集合获取项目亮点
  120. String highlightNames = this.buildHighlightNames(dto.getHighlightIds());
  121. if (StrUtil.isNotEmpty(highlightNames)) {
  122. entity.setHighlight(highlightNames);
  123. }
  124. boolean saveResult = this.save(entity);
  125. if (!saveResult) {
  126. throw new ServiceException("添加项目失败");
  127. }
  128. }
  129. @Override
  130. public ProjectDetailVo getDetailsInfo(Long id) {
  131. if (ObjectUtil.isNull(id)) {
  132. throw new ServiceException("项目ID不能为空");
  133. }
  134. ProjectDetailVo detailVo = this.baseMapper.selectProjectDetailById(id);
  135. if (ObjectUtil.isNull(detailVo)) {
  136. throw new ServiceException("项目不存在");
  137. }
  138. return detailVo;
  139. }
  140. @Override
  141. @Transactional(rollbackFor = Exception.class)
  142. public void deleteProjectById(Long id) {
  143. if (ObjectUtil.isNull(id)) {
  144. throw new ServiceException("项目ID不能为空");
  145. }
  146. if (id <= 0) {
  147. throw new ServiceException("项目ID不正确");
  148. }
  149. log.info("根据主键ID删除项目,ID:{}", id);
  150. int deleteResult = this.baseMapper.deleteProjectById(id);
  151. if (deleteResult <= 0) {
  152. throw new ServiceException("项目不存在或已删除");
  153. }
  154. }
  155. @Override
  156. public IPage<ProductOptionVO> selectOptionUnionPage(Page page, OptionDTO dto) {
  157. return baseMapper.selectOptionUnionPage(page, dto);
  158. }
  159. @Override
  160. public Page<ProductServiceOptionVO> selectServiceOptionsPage(Page page, ServiceOptionDTO dto) {
  161. return baseMapper.selectServiceOptionsPage(page, dto);
  162. }
  163. @Override
  164. public List<ProjectBaseVo> getProjectTabListByCategoryId(Integer categoryId) {
  165. LambdaQueryWrapper<Project> wrapper = new LambdaQueryWrapper<>();
  166. wrapper.eq(Project::getCategoryId, categoryId)
  167. .eq(Project::getStatus, ProjectStatusEnum.ON_SHELF.getCode());
  168. List<Project> projects = this.baseMapper.selectList(wrapper);
  169. return BeanUtil.copyToList(projects, ProjectBaseVo.class);
  170. }
  171. @Override
  172. public BookProjectDetailVO getBookingProjectDetail(BookMerchantDTO dto) {
  173. BookProjectDetailVO vo = new BookProjectDetailVO();
  174. Long projectId = dto.getProjectId();
  175. // 1. 查询项目基础信息
  176. Project project = this.baseMapper.selectById(projectId);
  177. if (ObjectUtil.isNull(project)) {
  178. throw new ServiceException("项目不存在");
  179. }
  180. if (ObjectUtil.equals(project.getStatus(), ProjectStatusEnum.OFF_SHELF.getCode())) {
  181. throw new ServiceException("项目已下架");
  182. }
  183. ProjectInfoVO projectInfo = new ProjectInfoVO();
  184. BeanUtil.copyProperties(project, projectInfo);
  185. vo.setProjectInfo(projectInfo);
  186. // 2. 查询商户列表
  187. Page<BookMerchantVO> page = maProjectService.selectMerchantList(new Page<>(dto.getCurrent(), dto.getSize()), dto);
  188. // 3.判断数据中的currentPrice为null就设置为projectInfo的price
  189. if (ObjectUtil.isNotNull(page) && CollUtil.isNotEmpty(page.getRecords())) {
  190. for (BookMerchantVO merchantVO : page.getRecords()) {
  191. BigDecimal price = merchantVO.getCurrentPrice();
  192. // 为空 或者 等于0,统一赋值项目原价
  193. if (ObjectUtil.isNull(price) || price.compareTo(BigDecimal.ZERO) == 0) {
  194. merchantVO.setCurrentPrice(projectInfo.getPrice());
  195. }
  196. }
  197. }
  198. vo.setMerchantList(page);
  199. return vo;
  200. }
  201. private ProjectPageVo convertToVo(Project entity) {
  202. ProjectPageVo vo = new ProjectPageVo();
  203. // 属性拷贝(推荐)
  204. BeanUtil.copyProperties(entity, vo);
  205. return vo;
  206. }
  207. /**
  208. * 根据亮点ID集合构建高亮名称字符串
  209. *
  210. * @param highlightIds 逗号分隔的ID字符串或单个ID
  211. * @return 拼接好的名称字符串,如 "技术领先,市场广阔"
  212. */
  213. private String buildHighlightNames(String highlightIds) {
  214. // 1. 基础校验:如果ID为空,直接返回空字符串,避免后续查库
  215. if (StringUtils.isBlank(highlightIds)) {
  216. return "";
  217. }
  218. // 2. 解析ID列表 (兼容逗号分隔的情况)
  219. List<String> idList = Arrays.asList(highlightIds.split(","));
  220. // 3. 批量查询字典表
  221. List<SysDictData> dictList = this.sysDictDataService.list(
  222. new QueryWrapper<SysDictData>()
  223. .in("dict_code", idList)
  224. .select("dict_label") // 【性能优化】只查询需要的字段,减少IO开销
  225. );
  226. // 4. 提取名称并拼接
  227. return dictList.stream()
  228. .map(SysDictData::getDictLabel)
  229. .filter(StringUtils::isNotBlank) // 过滤掉可能为空的标签
  230. .collect(Collectors.joining(","));
  231. }
  232. }