From f1843f0cd53ab6dd749ad71db8e18590ceff98d8 Mon Sep 17 00:00:00 2001
From: jiaosong <jiaosong6760@dingtalk.com>
Date: 星期二, 17 十月 2023 10:43:16 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into dev

---
 server/services/src/main/java/com/doumee/service/business/impl/PricingDetailServiceImpl.java |   89 ++++++++++++++++++++++++++------------------
 1 files changed, 52 insertions(+), 37 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 559d288..85a1fb7 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
@@ -53,13 +53,23 @@
     @Override
     public String create(PricingDetail pricingDetail) {
 
+        //鏍¢獙鍙傛暟鍚堟硶鎬�
         checkPricingDetail(pricingDetail);
+
         LoginUserInfo principal = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+        UpdateWrapper<PricingDetail> wrapper = new UpdateWrapper<>();
+        wrapper.lambda()
+                .set(PricingDetail::getIsdeleted,Constants.ONE)
+                .set(PricingDetail::getEditDate,new Date())
+                .set(PricingDetail::getEditor,principal.getId())
+                .eq(PricingDetail::getBikeTypeId,pricingDetail.getBikeTypeId())
+                .eq(PricingDetail::getPricePramId,pricingDetail.getPricePramId());
+        pricingDetailMapper.update(null, wrapper);//鍒犻櫎鑰佺殑閰嶇疆
+
         PricingDetail insert = new PricingDetail();
+        insert.setId(Constants.getUUID());
         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());
@@ -72,49 +82,54 @@
         insert.setHolidayBasePrice(Constants.formatDecimalNum(pricingDetail.getHolidayBasePrice()).multiply(new BigDecimal(100)));
         insert.setHolidayUnitPrice(Constants.formatDecimalNum(pricingDetail.getHolidayUnitPrice()).multiply(new BigDecimal(100)));
         insert.setInfo(pricingDetail.getInfo());
-        insert.setTitle(pricingDetail.getTitle());
+        String title = getRoleNameByParam(pricingDetail.getBasePrice(),pricingDetail.getBaseTime(),pricingDetail.getUnitPrice(),pricingDetail.getUnitTime());
+        String info = getRoleNameByParam(pricingDetail.getHolidayBasePrice(),pricingDetail.getHolidayBaseTime(),pricingDetail.getHolidayUnitPrice(),pricingDetail.getHolidayUnitTime());;
+        insert.setTitle(title);//宸ヤ綔鏃ヨ浠烽厤缃鍒�
+        insert.setInfo(info);//鑺傚亣鏃ヨ浠烽厤缃鍒�
         pricingDetailMapper.insert(insert);
         return pricingDetail.getId();
     }
 
+    private  String getRoleNameByParam(BigDecimal basePrice, Integer baseTime, BigDecimal unitPrice, Integer unitTime) {
+        String title = "";
+        if(baseTime < 0){
+            title = "瑙勫垯锛�"+Constants.translateMoney(basePrice).doubleValue()+"鍏冪晠楠戜竴鏁村ぉ";
+        }else {
+            title = "瑙勫垯锛氳捣姝�";
+            int time = baseTime / 60;
+            int min = baseTime % 60;
+            if(time > 0){
+                title += time+"灏忔椂";
+            }
+            if(min >0){
+                title += min+"鍒嗛挓";
+            }
+            title = Constants.translateMoney(unitPrice).doubleValue()
+                    +"鍏冿紝瓒呰繃鍚�"+Constants.translateMoney(basePrice).doubleValue()+"鍏�/"
+                    +unitTime+"鍒嗛挓";
+        }
+        return  title;
+    }
+
     private void checkPricingDetail(PricingDetail pricingDetail){
-        if ((Objects.nonNull(pricingDetail.getBaseTime()) &&  pricingDetail.getBaseTime() < 0) &&
-                Objects.isNull(pricingDetail.getBasePrice())){
-            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"涓�鍙d环浠锋牸涓嶅彲涓虹┖");
+        if(StringUtils.isBlank(pricingDetail.getPricePramId())
+                ||StringUtils.isBlank(pricingDetail.getBikeTypeId())
+                ||pricingDetail.getBaseTime() == null
+                ||pricingDetail.getBaseTime()==0
+                ||Constants.formatDecimalNum(pricingDetail.getBasePrice() ).doubleValue()<0
+                ||Constants.formatDecimalNum(pricingDetail.getHolidayBasePrice() ).doubleValue()<0
+                ||pricingDetail.getHolidayBaseTime() == null
+                || pricingDetail.getHolidayBaseTime()==0){
+            //鍙傛暟閿欒
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
         }
-
-        if ((Objects.nonNull(pricingDetail.getBaseTime()) && pricingDetail.getBaseTime() > 0) &&
-                (Objects.isNull(pricingDetail.getBasePrice())
-                        || Objects.isNull(pricingDetail.getUnitTime())
-                        || Objects.isNull(pricingDetail.getUnitPrice()))){
-            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"闃舵瀹氫环鍙傛暟涓嶅彲涓虹┖");
+        if (  pricingDetail.getBaseTime() < 0){
+            pricingDetail.setBaseTime(-1);
         }
-
-        if ( (Objects.nonNull(pricingDetail.getHolidayBaseTime()) && pricingDetail.getHolidayBaseTime() < 0)
-                && ( Objects.isNull(pricingDetail.getHolidayBasePrice()))
-        ){
-            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鑺傚亣涓�鍙d环浠锋牸涓嶅彲涓虹┖");
+        if (  pricingDetail.getHolidayBaseTime() < 0){
+            pricingDetail.setHolidayBaseTime(-1);
         }
-
-        if (((Objects.nonNull(pricingDetail.getHolidayBaseTime()) && pricingDetail.getHolidayBaseTime() > 0))
-                && (Objects.isNull(pricingDetail.getHolidayBasePrice())
-                || Objects.isNull(pricingDetail.getHolidayUnitTime())
-                || Objects.isNull(pricingDetail.getHolidayUnitPrice()))){
-
-            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鑺傚亣闃舵瀹氫环鍙傛暟涓嶅彲涓虹┖");
-        }
-
-        QueryWrapper<PricingDetail> wrapper = new QueryWrapper<>();
-        wrapper.lambda()
-                .eq(PricingDetail::getIsdeleted,Constants.ZERO)
-                .eq(PricingDetail::getBikeTypeId,pricingDetail.getBikeTypeId())
-                .eq(PricingDetail::getPricePramId,pricingDetail.getPricePramId())
-                .last("limit 1");
-        PricingDetail exitCount = pricingDetailMapper.selectOne(wrapper);
-
-        if (Objects.nonNull(exitCount) && !Objects.equals(exitCount.getId(),pricingDetail.getId())){
-            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"璇ヨ溅鍨嬪凡閰嶇疆");
-        }
+//        PricingDetail exitCount = pricingDetailMapper.selectOne(wrapper);
 
     }
 

--
Gitblit v1.9.3