package com.ycl.service.impl; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ycl.common.base.Result; import com.ycl.domain.entity.ProjectInfo; import com.ycl.domain.form.ProjectInfoForm; import com.ycl.domain.query.ProjectInfoQuery; import com.ycl.domain.vo.*; import com.ycl.framework.utils.PageUtil; import com.ycl.mapper.ProjectInfoMapper; import com.ycl.service.ProjectInfoService; import lombok.RequiredArgsConstructor; import org.springframework.beans.BeanUtils; import org.springframework.stereotype.Service; import org.springframework.util.Assert; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.stream.Collectors; /** * 项目管理基础信息表 服务实现类 * * @author flq * @since 2024-11-22 */ @Service @RequiredArgsConstructor public class ProjectInfoServiceImpl extends ServiceImpl implements ProjectInfoService { private final ProjectInfoMapper projectInfoMapper; /** * 添加 * * @param form * @return */ @Override public Result add(ProjectInfoForm form) { ProjectInfo entity = ProjectInfoForm.getEntityByForm(form, null); baseMapper.insert(entity); return Result.ok("添加成功"); } /** * 修改 * * @param form * @return */ @Override public Result update(ProjectInfoForm form) { ProjectInfo entity = baseMapper.selectById(form.getId()); // 为空抛IllegalArgumentException,做全局异常处理 Assert.notNull(entity, "记录不存在"); BeanUtils.copyProperties(form, entity); baseMapper.updateById(entity); return Result.ok("修改成功"); } /** * 批量删除 * * @param ids * @return */ @Override public Result remove(List ids) { baseMapper.deleteBatchIds(ids); return Result.ok("删除成功"); } /** * id删除 * * @param id * @return */ @Override public Result removeById(String id) { baseMapper.deleteById(id); return Result.ok("删除成功"); } /** * 分页查询 * * @param query * @return */ @Override public Result page(ProjectInfoQuery query) { IPage page = PageUtil.getPage(query, ProjectInfoVO.class); baseMapper.getPage(page, query); return Result.ok().data(page.getRecords()).total(page.getTotal()); } /** * 根据id查找 * * @param id * @return */ @Override public Result detail(Integer id) { ProjectInfoVO vo = baseMapper.getById(id); Assert.notNull(vo, "记录不存在"); return Result.ok().data(vo); } /** * 列表 * * @return */ @Override public Result all() { List entities = baseMapper.selectList(null); List vos = entities.stream() .map(entity -> ProjectInfoVO.getVoByEntity(entity, null)) .collect(Collectors.toList()); return Result.ok().data(vos); } @Override public IndexCountVO getIndexCount(IndexDTO indexDTO) { // {"proPhaseCountVO":[{"type":"储备规划阶段","count":0,"amount":"0.00","text":"储"}, // {"type":"项目前期阶段","count":0,"amount":"0.00","text":"新"}, // {"type":"实施阶段","count":0,"amount":"0.00","text":"建"},{"type":"竣工投用阶段","count":0,"amount":"0.00","text":"竣"}], // "impTypeCountVO":[{"type":"一般项目","count":0,"amount":"0.00","text":"普"}, // {"type":"县重点项目","count":0,"amount":"0.00","text":"县"},{"type":"市重点项目","count":0,"amount":"0.00","text":"市"}, // {"type":"省重点项目","count":0,"amount":"0.00","text":"省"}]}} IndexCountVO indexCountVO = new IndexCountVO(); List proPhaseCountVO = new ArrayList<>(); proPhaseCountVO.add(new IndexProPhaseCountVO("储备规划阶段", 0, "0.00", "储")); proPhaseCountVO.add(new IndexProPhaseCountVO("项目前期阶段", 0, "0.00", "新")); proPhaseCountVO.add(new IndexProPhaseCountVO("实施阶段", 0, "0.00", "建")); proPhaseCountVO.add(new IndexProPhaseCountVO("竣工投用阶段", 0, "0.00", "竣")); List impTypeCountVO = new ArrayList<>(); impTypeCountVO.add(new IndexImpTypeCountVO("一般项目", 0, "0.00", "普")); impTypeCountVO.add(new IndexImpTypeCountVO("县重点项目", 0, "0.00", "县")); impTypeCountVO.add(new IndexImpTypeCountVO("市重点项目", 0, "0.00", "市")); impTypeCountVO.add(new IndexImpTypeCountVO("省重点项目", 0, "0.00", "省")); indexCountVO.setImpTypeCountVO(impTypeCountVO); indexCountVO.setProPhaseCountVO(proPhaseCountVO); return indexCountVO; } @Override public Map countExceptionProject(IndexDTO indexDTO) { Map map = new HashMap<>(); map.put("processExceptionProject", 0); return map; } }