From a2d13dbfa8286594b0d5a3115284f08b8566fbd6 Mon Sep 17 00:00:00 2001
From: jiaosong <jiaosong6760@dingtalk.com>
Date: 星期一, 16 十月 2023 16:44:13 +0800
Subject: [PATCH] #获取可退款信息
---
server/platform/src/main/java/com/doumee/api/business/PricingDetailController.java | 4 ++
server/services/src/main/java/com/doumee/service/business/impl/PricingDetailServiceImpl.java | 60 +++++++++++++++++++++--------
2 files changed, 47 insertions(+), 17 deletions(-)
diff --git a/server/platform/src/main/java/com/doumee/api/business/PricingDetailController.java b/server/platform/src/main/java/com/doumee/api/business/PricingDetailController.java
index c06e0d4..e74719a 100644
--- a/server/platform/src/main/java/com/doumee/api/business/PricingDetailController.java
+++ b/server/platform/src/main/java/com/doumee/api/business/PricingDetailController.java
@@ -11,6 +11,7 @@
import com.doumee.service.business.PricingDetailService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
+import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
@@ -65,6 +66,9 @@
@PostMapping("/updateById")
@RequiresPermissions("business:pricingdetail:update")
public ApiResponse updateById(@RequestBody PricingDetail pricingDetail) {
+ if (StringUtils.isEmpty(pricingDetail.getId())){
+ pricingDetailService.create(pricingDetail);
+ }
pricingDetailService.updateById(pricingDetail);
return ApiResponse.success(null);
}
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