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