package com.doumee.service.business.impl; import com.doumee.core.constants.Constants; import com.doumee.core.constants.ResponseStatus; import com.doumee.core.exception.BusinessException; import com.doumee.core.model.LoginUserInfo; import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Utils; import com.doumee.dao.business.PricingDetailMapper; import com.doumee.dao.business.join.PricingDetailJoinMapper; import com.doumee.dao.business.model.BaseParam; import com.doumee.dao.business.model.PricingDetail; import com.doumee.service.business.PricingDetailService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.github.yulichang.wrapper.MPJLambdaWrapper; import org.apache.shiro.SecurityUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.util.Date; import java.util.List; import java.util.Objects; /** * 定价方案明细配置Service实现 * @author 江蹄蹄 * @date 2023/09/27 18:06 */ @Service public class PricingDetailServiceImpl implements PricingDetailService { @Autowired private PricingDetailMapper pricingDetailMapper; @Autowired PricingDetailJoinMapper pricingDetailJoinMapper; @Override public String create(PricingDetail pricingDetail) { if ((pricingDetail.getBaseTime() < 0) && Objects.isNull(pricingDetail.getBasePrice())){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"一口价价格不可为空"); } if ((pricingDetail.getBaseTime() > 0) && (Objects.isNull(pricingDetail.getBasePrice()) || Objects.isNull(pricingDetail.getUnitTime()) || Objects.isNull(pricingDetail.getUnitPrice()))){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"阶梯定价参数不可为空"); } if ((pricingDetail.getHolidayBasePrice() < 0) && Objects.isNull(pricingDetail.getBasePrice()) ){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"节假一口价价格不可为空"); } if ((pricingDetail.getHolidayBasePrice() > 0) && (Objects.isNull(pricingDetail.getHolidayBasePrice()) || Objects.isNull(pricingDetail.getHolidayBasePrice()) || Objects.isNull(pricingDetail.getHolidayBasePrice()))){ throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"节假阶梯定价参数不可为空"); } LoginUserInfo principal = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); PricingDetail insert = new PricingDetail(); insert.setCreateDate(new Date()); insert.setCreator(principal.getId()); insert.setEditDate(new Date()); insert.setEditor(principal.getId()); insert.setIsdeleted(Constants.ZERO); insert.setPricePramId(pricingDetail.getPricePramId()); insert.setBikeTypeId(pricingDetail.getBikeTypeId()); insert.setBaseTime(pricingDetail.getBaseTime()); insert.setBasePrice(pricingDetail.getBasePrice()); insert.setUnitTime(pricingDetail.getUnitTime()); insert.setUnitPrice(pricingDetail.getUnitPrice()); insert.setHolidayBaseTime(pricingDetail.getHolidayBaseTime()); insert.setHolidayBasePrice(pricingDetail.getHolidayBasePrice()); insert.setHolidayUnitTime(pricingDetail.getHolidayUnitTime()); insert.setHolidayUnitPrice(pricingDetail.getHolidayUnitPrice()); insert.setInfo(pricingDetail.getInfo()); insert.setTitle(pricingDetail.getTitle()); pricingDetailMapper.insert(pricingDetail); return pricingDetail.getId(); } @Override public void deleteById(String id) { pricingDetailMapper.deleteById(id); } @Override public void delete(PricingDetail pricingDetail) { UpdateWrapper deleteWrapper = new UpdateWrapper<>(pricingDetail); pricingDetailMapper.delete(deleteWrapper); } @Override public void deleteByIdInBatch(List ids) { if (CollectionUtils.isEmpty(ids)) { return; } pricingDetailMapper.deleteBatchIds(ids); } @Override public void updateById(PricingDetail pricingDetail) { pricingDetailMapper.updateById(pricingDetail); } @Override public void updateByIdInBatch(List pricingDetails) { if (CollectionUtils.isEmpty(pricingDetails)) { return; } for (PricingDetail pricingDetail: pricingDetails) { this.updateById(pricingDetail); } } @Override public PricingDetail findById(String id) { return pricingDetailMapper.selectById(id); } @Override public PricingDetail findOne(PricingDetail pricingDetail) { QueryWrapper wrapper = new QueryWrapper<>(pricingDetail); return pricingDetailMapper.selectOne(wrapper.last(" limit 1")); } @Override public List findList(PricingDetail pricingDetail) { MPJLambdaWrapper wrapper = new MPJLambdaWrapper<>(); wrapper.leftJoin(BaseParam.class,BaseParam::getId,PricingDetail::getBikeTypeId) .eq(BaseParam::getType,Constants.THREE); wrapper.selectAll(PricingDetail.class) .selectAs(BaseParam::getName,PricingDetail::getBikeTypeName); return pricingDetailJoinMapper.selectJoinList(PricingDetail.class,wrapper); } @Override public PageData findPage(PageWrap pageWrap) { IPage page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); QueryWrapper queryWrapper = new QueryWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); if (pageWrap.getModel().getId() != null) { queryWrapper.lambda().eq(PricingDetail::getId, pageWrap.getModel().getId()); } if (pageWrap.getModel().getCreateDate() != null) { queryWrapper.lambda().ge(PricingDetail::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate())); queryWrapper.lambda().le(PricingDetail::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate())); } if (pageWrap.getModel().getCreator() != null) { queryWrapper.lambda().eq(PricingDetail::getCreator, pageWrap.getModel().getCreator()); } if (pageWrap.getModel().getEditDate() != null) { queryWrapper.lambda().ge(PricingDetail::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate())); queryWrapper.lambda().le(PricingDetail::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate())); } if (pageWrap.getModel().getEditor() != null) { queryWrapper.lambda().eq(PricingDetail::getEditor, pageWrap.getModel().getEditor()); } if (pageWrap.getModel().getIsdeleted() != null) { queryWrapper.lambda().eq(PricingDetail::getIsdeleted, pageWrap.getModel().getIsdeleted()); } if (pageWrap.getModel().getPricePramId() != null) { queryWrapper.lambda().eq(PricingDetail::getPricePramId, pageWrap.getModel().getPricePramId()); } if (pageWrap.getModel().getBikeTypeId() != null) { queryWrapper.lambda().eq(PricingDetail::getBikeTypeId, pageWrap.getModel().getBikeTypeId()); } if (pageWrap.getModel().getBaseTime() != null) { queryWrapper.lambda().eq(PricingDetail::getBaseTime, pageWrap.getModel().getBaseTime()); } if (pageWrap.getModel().getBasePrice() != null) { queryWrapper.lambda().eq(PricingDetail::getBasePrice, pageWrap.getModel().getBasePrice()); } if (pageWrap.getModel().getUnitTime() != null) { queryWrapper.lambda().eq(PricingDetail::getUnitTime, pageWrap.getModel().getUnitTime()); } if (pageWrap.getModel().getUnitPrice() != null) { queryWrapper.lambda().eq(PricingDetail::getUnitPrice, pageWrap.getModel().getUnitPrice()); } if (pageWrap.getModel().getHolidayBaseTime() != null) { queryWrapper.lambda().eq(PricingDetail::getHolidayBaseTime, pageWrap.getModel().getHolidayBaseTime()); } if (pageWrap.getModel().getHolidayBasePrice() != null) { queryWrapper.lambda().eq(PricingDetail::getHolidayBasePrice, pageWrap.getModel().getHolidayBasePrice()); } if (pageWrap.getModel().getHolidayUnitTime() != null) { queryWrapper.lambda().eq(PricingDetail::getHolidayUnitTime, pageWrap.getModel().getHolidayUnitTime()); } if (pageWrap.getModel().getHolidayUnitPrice() != null) { queryWrapper.lambda().eq(PricingDetail::getHolidayUnitPrice, pageWrap.getModel().getHolidayUnitPrice()); } if (pageWrap.getModel().getInfo() != null) { queryWrapper.lambda().eq(PricingDetail::getInfo, pageWrap.getModel().getInfo()); } if (pageWrap.getModel().getTitle() != null) { queryWrapper.lambda().eq(PricingDetail::getTitle, pageWrap.getModel().getTitle()); } for(PageWrap.SortData sortData: pageWrap.getSorts()) { if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { queryWrapper.orderByDesc(sortData.getProperty()); } else { queryWrapper.orderByAsc(sortData.getProperty()); } } return PageData.from(pricingDetailMapper.selectPage(page, queryWrapper)); } @Override public long count(PricingDetail pricingDetail) { QueryWrapper wrapper = new QueryWrapper<>(pricingDetail); return pricingDetailMapper.selectCount(wrapper); } }