ProjectServiceImpl.java 8.5 KB

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