From a2d13dbfa8286594b0d5a3115284f08b8566fbd6 Mon Sep 17 00:00:00 2001 From: jiaosong <jiaosong6760@dingtalk.com> Date: 星期一, 16 十月 2023 16:44:13 +0800 Subject: [PATCH] #获取可退款信息 --- server/services/src/main/java/com/doumee/service/business/impl/PricingDetailServiceImpl.java | 60 +++++++++++++++++++++++++++++++++++++++++++----------------- 1 files changed, 43 insertions(+), 17 deletions(-) diff --git a/server/services/src/main/java/com/doumee/service/business/impl/PricingDetailServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/PricingDetailServiceImpl.java index 882678f..e22580f 100644 --- a/server/services/src/main/java/com/doumee/service/business/impl/PricingDetailServiceImpl.java +++ b/server/services/src/main/java/com/doumee/service/business/impl/PricingDetailServiceImpl.java @@ -7,10 +7,12 @@ import com.doumee.core.model.PageData; import com.doumee.core.model.PageWrap; import com.doumee.core.utils.Utils; +import com.doumee.dao.business.BaseParamMapper; 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.BaseParamService; import com.doumee.service.business.PricingDetailService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; @@ -18,15 +20,17 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.github.yulichang.wrapper.MPJLambdaWrapper; +import org.apache.commons.collections.MapUtils; +import org.apache.commons.lang3.StringUtils; import org.apache.shiro.SecurityUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; +import sun.text.resources.et.CollationData_et; import java.math.BigDecimal; -import java.util.Date; -import java.util.List; -import java.util.Objects; +import java.util.*; +import java.util.stream.Collectors; /** * 瀹氫环鏂规鏄庣粏閰嶇疆Service瀹炵幇 @@ -41,6 +45,10 @@ @Autowired PricingDetailJoinMapper pricingDetailJoinMapper; + + @Autowired + BaseParamMapper baseParamMapper; + @Override public String create(PricingDetail pricingDetail) { @@ -180,21 +188,39 @@ @Override public List<PricingDetail> findList(PricingDetail pricingDetail) { MPJLambdaWrapper<PricingDetail> wrapper = new MPJLambdaWrapper<>(); - wrapper.leftJoin(BaseParam.class,BaseParam::getId,PricingDetail::getBikeTypeId) - .eq(PricingDetail::getPricePramId,pricingDetail.getPricePramId()) - .eq(BaseParam::getType,Constants.THREE); - wrapper.selectAll(PricingDetail.class) - .selectAs(BaseParam::getName,PricingDetail::getBikeTypeName); - List<PricingDetail> result = pricingDetailJoinMapper.selectJoinList(PricingDetail.class,wrapper); - if(result!=null){ - for(PricingDetail model :result){ - model.setBasePrice(Constants.translateMoney(model.getBasePrice())); - model.setHolidayBasePrice(Constants.translateMoney(model.getHolidayBasePrice())); - model.setUnitPrice(Constants.translateMoney(model.getUnitPrice())); - model.setHolidayUnitPrice(Constants.translateMoney(model.getHolidayUnitPrice())); - } + wrapper.eq(PricingDetail::getPricePramId,pricingDetail.getPricePramId()) + .eq(PricingDetail::getIsdeleted,Constants.ZERO); + wrapper.selectAll(PricingDetail.class); + List<PricingDetail> result = pricingDetailMapper.selectList(wrapper); + + Map<String, PricingDetail> stringPricingDetailMap = Optional.ofNullable(result) + .map(s -> s.stream().collect(Collectors.toMap(p -> p.getBikeTypeId(), p -> p))) + .orElse(new HashMap<>()); + QueryWrapper<BaseParam> baseParamQuery = new QueryWrapper(); + baseParamQuery.lambda() + .eq(BaseParam::getIsdeleted,Constants.ZERO) + .eq(BaseParam::getType,Constants.THREE) + .orderByAsc(BaseParam::getSortnum); + List<BaseParam> list = baseParamMapper.selectList(baseParamQuery); + if (CollectionUtils.isEmpty(list)){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鍐呯疆鏁版嵁纭疄"); } - return result; + + List<PricingDetail> collect = list.stream().map(s -> { + PricingDetail put = stringPricingDetailMap.getOrDefault(s.getId(), new PricingDetail()); + put.setBikeTypeId(s.getId()); + put.setBikeTypeName(s.getName()); + return put; + }).collect(Collectors.toList()); +// if(result!=null){ +// for(PricingDetail model :result){ +// model.setBasePrice(Constants.translateMoney(model.getBasePrice())); +// model.setHolidayBasePrice(Constants.translateMoney(model.getHolidayBasePrice())); +// model.setUnitPrice(Constants.translateMoney(model.getUnitPrice())); +// model.setHolidayUnitPrice(Constants.translateMoney(model.getHolidayUnitPrice())); +// } +// } + return collect; } @Override -- Gitblit v1.9.3