|  |  |  | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | 
|---|
|  |  |  | 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实现 | 
|---|
|  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | PricingDetailJoinMapper pricingDetailJoinMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | BaseParamMapper baseParamMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @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()); | 
|---|
|  |  |  | 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.setBasePrice(Constants.formatDecimalNum(pricingDetail.getBasePrice()).multiply(new BigDecimal(100))); | 
|---|
|  |  |  | insert.setUnitPrice(Constants.formatDecimalNum(pricingDetail.getUnitPrice()).multiply(new BigDecimal(100))); | 
|---|
|  |  |  | 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()); | 
|---|
|  |  |  | pricingDetailMapper.insert(pricingDetail); | 
|---|
|  |  |  | 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(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public static  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(),"一口价价格不可为空"); | 
|---|
|  |  |  | 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(),"节假一口价价格不可为空"); | 
|---|
|  |  |  | 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()); | 
|---|
|  |  |  | Integer exitCount = pricingDetailMapper.selectCount(wrapper); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (exitCount > Constants.ZERO){ | 
|---|
|  |  |  | throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"该车型已配置"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        PricingDetail exitCount = pricingDetailMapper.selectOne(wrapper); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | LoginUserInfo principal = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); | 
|---|
|  |  |  | pricingDetail.setEditDate(new Date()); | 
|---|
|  |  |  | pricingDetail.setEditor(principal.getId()); | 
|---|
|  |  |  | pricingDetail.setBasePrice(Constants.formatDecimalNum(pricingDetail.getBasePrice()).multiply(new BigDecimal(100))); | 
|---|
|  |  |  | pricingDetail.setUnitPrice(Constants.formatDecimalNum(pricingDetail.getUnitPrice()).multiply(new BigDecimal(100))); | 
|---|
|  |  |  | pricingDetail.setHolidayBasePrice(Constants.formatDecimalNum(pricingDetail.getHolidayBasePrice()).multiply(new BigDecimal(100))); | 
|---|
|  |  |  | pricingDetail.setHolidayUnitPrice(Constants.formatDecimalNum(pricingDetail.getHolidayUnitPrice()).multiply(new BigDecimal(100))); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | pricingDetailMapper.updateById(pricingDetail); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PricingDetail findById(String id) { | 
|---|
|  |  |  | return pricingDetailMapper.selectById(id); | 
|---|
|  |  |  | PricingDetail model =  pricingDetailMapper.selectById(id); | 
|---|
|  |  |  | if(model !=null ){ | 
|---|
|  |  |  | 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 model; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PricingDetail findOne(PricingDetail pricingDetail) { | 
|---|
|  |  |  | QueryWrapper<PricingDetail> wrapper = new QueryWrapper<>(pricingDetail); | 
|---|
|  |  |  | return pricingDetailMapper.selectOne(wrapper.last(" limit 1")); | 
|---|
|  |  |  | PricingDetail model =  pricingDetailMapper.selectOne(wrapper.last(" limit 1")); | 
|---|
|  |  |  | if(model !=null ){ | 
|---|
|  |  |  | 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 model; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @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.eq(PricingDetail::getPricePramId,pricingDetail.getPricePramId()) | 
|---|
|  |  |  | .eq(PricingDetail::getIsdeleted,Constants.ZERO); | 
|---|
|  |  |  | wrapper.rightJoin(BaseParam.class,BaseParam::getId,PricingDetail::getBikeTypeId); | 
|---|
|  |  |  | wrapper.selectAll(PricingDetail.class) | 
|---|
|  |  |  | .selectAs(BaseParam::getId,PricingDetail::getBikeTypeId) | 
|---|
|  |  |  | .selectAs(BaseParam::getName,PricingDetail::getBikeTypeName); | 
|---|
|  |  |  | return pricingDetailJoinMapper.selectJoinList(PricingDetail.class,wrapper); | 
|---|
|  |  |  | List<PricingDetail> result = pricingDetailJoinMapper.selectJoinList(PricingDetail.class,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(),"内置数据确实"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<PricingDetail> collect = list.stream().map(s -> { | 
|---|
|  |  |  | PricingDetail put = stringPricingDetailMap.getOrDefault(s.getId(), new PricingDetail()); | 
|---|
|  |  |  | put.setBikeTypeId(s.getId()); | 
|---|
|  |  |  | put.setPricePramId(pricingDetail.getPricePramId()); | 
|---|
|  |  |  | put.setBikeTypeName(s.getName()); | 
|---|
|  |  |  | put.setSortnum(s.getSortnum()); | 
|---|
|  |  |  | put.setBasePrice(Objects.nonNull(put.getBasePrice()) ? Constants.translateMoney(put.getBasePrice()) : null); | 
|---|
|  |  |  | put.setHolidayBasePrice(Objects.nonNull(put.getHolidayBasePrice()) ? Constants.translateMoney(put.getHolidayBasePrice()):null); | 
|---|
|  |  |  | put.setUnitPrice(Objects.nonNull(put.getUnitPrice()) ? Constants.translateMoney(put.getUnitPrice()):null); | 
|---|
|  |  |  | put.setHolidayUnitPrice(Objects.nonNull(put.getHolidayUnitPrice())  ? Constants.translateMoney(put.getHolidayUnitPrice()):null); | 
|---|
|  |  |  | 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 | 
|---|
|  |  |  | 
|---|
|  |  |  | queryWrapper.orderByAsc(sortData.getProperty()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return PageData.from(pricingDetailMapper.selectPage(page, queryWrapper)); | 
|---|
|  |  |  | IPage<PricingDetail> result =pricingDetailMapper.selectPage(page, queryWrapper); | 
|---|
|  |  |  | if(result.getRecords()!= null ){ | 
|---|
|  |  |  | for(PricingDetail model : result.getRecords()){ | 
|---|
|  |  |  | 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 PageData.from(result); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|