From 77b52c06afdb843ee67c6e938afab0458143d76f Mon Sep 17 00:00:00 2001 From: doum <doum> Date: 星期五, 05 九月 2025 10:48:48 +0800 Subject: [PATCH] 前端 --- server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java | 412 +++++++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 363 insertions(+), 49 deletions(-) diff --git a/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java index 86b0e61..f015f0c 100644 --- a/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java +++ b/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java @@ -3,6 +3,7 @@ import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.doumee.biz.system.SystemDictDataBiz; +import com.doumee.config.wx.SendWxMessage; import com.doumee.config.wx.WxMiniConfig; import com.doumee.config.wx.WxMiniUtilService; import com.doumee.core.constants.Constants; @@ -18,6 +19,7 @@ import com.doumee.dao.business.model.*; import com.doumee.dao.dto.*; import com.doumee.dao.vo.OrderReleaseVO; +import com.doumee.service.business.AliSmsService; import com.doumee.service.business.OrdersService; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; @@ -31,6 +33,7 @@ import com.wechat.pay.java.service.refund.model.RefundNotification; import jodd.util.StringUtil; import lombok.With; +import lombok.extern.slf4j.Slf4j; import nonapi.io.github.classgraph.json.Id; import org.apache.poi.sl.image.ImageHeaderEMF; import org.checkerframework.checker.units.qual.A; @@ -43,14 +46,17 @@ import javax.annotation.Resource; import java.math.BigDecimal; +import java.math.RoundingMode; import java.util.*; import java.util.concurrent.TimeUnit; +import java.util.stream.Collectors; /** * 璁㈠崟淇℃伅璁板綍Service瀹炵幇 * @author 姹熻箘韫� * @date 2025/07/09 12:00 */ +@Slf4j @Service public class OrdersServiceImpl implements OrdersService { @@ -87,6 +93,12 @@ @Autowired private WxMiniUtilService wxMiniUtilService; + @Autowired + private SendWxMessage sendWxMessage; + + @Autowired + private AliSmsService aliSmsService; + @Resource private RedisTemplate<String,Object> redisTemplate; @@ -96,6 +108,11 @@ OrderReleaseVO orderReleaseVO = new OrderReleaseVO(); Object objects = null; this.initVerification(orders); + Member member = memberMapper.selectById(orders.getMember().getId()); + if(Objects.isNull(member)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鐢ㄦ埛淇℃伅寮傚父"); + } + orders.setCreateTime(new Date()); orders.setUpdateTime(orders.getUpdateTime()); orders.setPayStatus(Constants.ZERO); @@ -120,16 +137,23 @@ } //鐢ㄩ璁㈠崟 if(Constants.equalsInteger(orders.getType(),Constants.TWO)){ + orders.setPayAccount(orders.getEstimatedAccount()); + Long tcje = Long.valueOf(new BigDecimal(orders.getPayAccount().toString()).multiply(orders.getPlatformRata()).intValue()); + orders.setReceiveAccount(orders.getPayAccount() - tcje); orders.setStatus(Constants.ordersStatus.waitPay.getKey()); orders.setOutTradeNo(UUID.randomUUID().toString().replace("-","")); - orders.setPayAccount(orders.getEstimatedAccount()); //鍞よ捣鏀粯涓氬姟 - objects = this.getWxPayResponse(orders,orders.getMember().getOpenid()); + objects = this.getWxPayResponse(orders,member.getOpenid()); orderReleaseVO.setObject(objects); }else{ orders.setStatus(Constants.ordersStatus.wait.getKey()); } + orders.setOriginPriceNum1(orders.getPriceNum1()); + orders.setOriginPriceNum2(orders.getPriceNum2()); + orders.setOriginEstimatedAccount(orders.getOriginEstimatedAccount()); + orders.setConfirmOtherFee(0l); ordersMapper.insert(orders); + orderReleaseVO.setId(orders.getId()); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(orders.getMultifileList())){ List<Multifile> multifileList = orders.getMultifileList(); @@ -147,7 +171,7 @@ multifileMapper.insert(multifileList); } //鏇存柊鐢ㄦ埛鍙戝崟閲� - memberMapper.update(new UpdateWrapper<Member>().lambda().setSql(" receive_num = ( receive_num + 1 )").eq(Member::getId,orders.getMember().getId())); + memberMapper.update(new UpdateWrapper<Member>().lambda().setSql(" PUBLISH_NUM = ( ifnull(PUBLISH_NUM,0) + 1 )").eq(Member::getId,orders.getMember().getId())); //鍒涘缓鎿嶄綔鏃ュ織 Constants.OrdersLog ordersLog = Constants.OrdersLog.UPLOAD; @@ -178,6 +202,7 @@ request.setSpAppid(WxMiniConfig.wxProperties.getAppId()); request.setSubMchid(WxMiniConfig.wxProperties.getSubMchId()); request.setSubAppid(WxMiniConfig.wxProperties.getSubAppId()); + Payer payer = new Payer(); payer.setSubOpenid(openid); request.setPayer(payer); @@ -236,9 +261,12 @@ ){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } - if( (Constants.equalsInteger(orders.getType(),Constants.ZERO) && Constants.equalsInteger(orders.getWorkType(),Constants.TWO) && - ( Constants.equalsInteger(orders.getCarType(),Constants.ZERO) || Constants.equalsInteger(orders.getCarType(),Constants.ONE) )) - || (Constants.equalsInteger(orders.getType(),Constants.ZERO) && Constants.equalsInteger(orders.getWorkType(),Constants.ONE)) + if( (Constants.equalsInteger(orders.getType(),Constants.ZERO) + && Constants.equalsInteger(orders.getWorkType(),Constants.TWO) && + ( Constants.equalsInteger(orders.getCarType(),Constants.ZERO) + || Constants.equalsInteger(orders.getCarType(),Constants.ONE) )) + || (Constants.equalsInteger(orders.getType(),Constants.ZERO) + && Constants.equalsInteger(orders.getWorkType(),Constants.ONE)) ){ if(Objects.isNull(orders.getPriceNum2())){ throw new BusinessException(ResponseStatus.BAD_REQUEST); @@ -279,6 +307,12 @@ } orders.setWayInfo(JSONObject.toJSONString(orders.getWayInfoDTOList())); }else{ + List<Category> categoryList = categoryMapper.selectList(new QueryWrapper<Category>().lambda().eq(Category::getDeleted,Constants.ZERO) + .eq(Category::getType,Constants.TWO) + ); + if(CollectionUtils.isEmpty(categoryList)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"椁愭爣淇℃伅閿欒"); + } //鐢ㄩ璁㈠崟 if(CollectionUtils.isEmpty(orders.getCateringDTOList())){ throw new BusinessException(ResponseStatus.BAD_REQUEST); @@ -292,9 +326,22 @@ ){ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鐢ㄩ鏍囧噯鏁版嵁閿欒"); } + //椁愭爣淇℃伅 + List<Category> categories = categoryList.stream().filter(i->Constants.equalsInteger(i.getId(),cateringDTO.getId())).collect(Collectors.toList()); + if(CollectionUtils.isEmpty(categories)){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鐢ㄩ鏍囧噯鏁版嵁閿欒锛岃鍒锋柊閲嶈瘯"); + } + Category category = categories.get(Constants.ZERO); + List<String> priceList = JSONArray.parseArray(category.getDetail(),String.class ); + if(CollectionUtils.isEmpty(priceList)){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鐢ㄩ鏍囧噯鏁版嵁閿欒锛岃鍒锋柊閲嶈瘯"); + } + if(priceList.stream().filter(i->((Long.valueOf(i)*100)+"").equals((cateringDTO.getPrice()+""))).collect(Collectors.toList()).size()==Constants.ZERO){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鐢ㄩ鏍囧噯鏁版嵁閿欒锛岃鍒锋柊閲嶈瘯"); + } sumPrice = sumPrice + (cateringDTO.getPrice() * cateringDTO.getNum()) ; } - if(!sumPrice.equals(orders.getPrice())){ + if(new BigDecimal(sumPrice.toString()).compareTo(orders.getPrice())!=Constants.ZERO){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鍗曚环璁$畻閿欒"); } orders.setWayInfo(JSONObject.toJSONString(orders.getCateringDTOList())); @@ -343,7 +390,8 @@ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟宸蹭慨鏀癸紝寰呮帴鍗曟柟纭锛屾棤娉曡繘琛岃鎿嶄綔"); } if(!Constants.equalsInteger(model.getType(),Constants.TWO)){ - if(Constants.equalsInteger(model.getStatus(),Constants.ZERO)||Constants.equalsInteger(model.getStatus(),Constants.ONE)){ + if(Constants.equalsInteger(model.getStatus(),Constants.ZERO) + ||Constants.equalsInteger(model.getStatus(),Constants.ONE)){ this.updateById(orders); }else if(Constants.equalsInteger(model.getStatus(),Constants.TWO)){ this.updOrderData(orders,model); @@ -400,6 +448,10 @@ } multifileMapper.insert(multifileList); } + orders.setOriginPriceNum1(orders.getPriceNum1()); + orders.setOriginPriceNum2(orders.getPriceNum2()); + orders.setOriginEstimatedAccount(orders.getOriginEstimatedAccount()); + orders.setConfirmOtherFee(0l); ordersMapper.updateById(orders); } @@ -456,9 +508,9 @@ ); if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(orderLogList)){ for (OrderLog orderLog:orderLogList) { - if(Constants.equalsInteger(orderLog.getOptUserType(),Constants.ZERO)){ + if(Constants.equalsInteger(orderLog.getOptUserType(),Constants.ZERO)&& org.apache.commons.lang3.StringUtils.isNotBlank(orders.getReleaseName())){ orderLog.setLogInfo(orderLog.getLogInfo().replace("{userName}",orders.getReleaseName())); - }else if(Constants.equalsInteger(orderLog.getOptUserType(),Constants.ONE)){ + }else if(Constants.equalsInteger(orderLog.getOptUserType(),Constants.ONE)&& org.apache.commons.lang3.StringUtils.isNotBlank(orders.getAcceptName())){ orderLog.setLogInfo(orderLog.getLogInfo().replace("{userName}",orders.getAcceptName())); } } @@ -536,7 +588,7 @@ queryWrapper.eq(Objects.nonNull(model.getReleaseMemberId()),Orders::getReleaseMemberId, model.getReleaseMemberId()); queryWrapper.eq(Objects.nonNull(model.getAcceptMemberId()),Orders::getAcceptMemberId, model.getAcceptMemberId()); queryWrapper.eq(Objects.nonNull(model.getAcceptType()),Orders::getAcceptType, model.getAcceptType()); - queryWrapper.apply(org.apache.commons.lang3.StringUtils.isNotBlank(model.getReleaseName()),"m1.name", model.getReleaseName()); + queryWrapper.apply(org.apache.commons.lang3.StringUtils.isNotBlank(model.getReleaseName()),"m1.name like '%"+model.getReleaseName()+"%' or m1.TELEPHONE like '%"+model.getReleaseName()+"%' "); queryWrapper.apply(org.apache.commons.lang3.StringUtils.isNotBlank(model.getAcceptName()),"( i.LINK_NAME like '%"+model.getAcceptName()+"%' or i.company_name like '%"+model.getAcceptName()+"%' or i.TELEPHONE like '%"+model.getAcceptName()+"%' ) "); IPage<Orders> iPage = ordersMapper.selectJoinPage(page,Orders.class,queryWrapper); for (Orders orders:iPage.getRecords()) { @@ -633,15 +685,15 @@ //鏌ヨ鐢ㄦ埛鏄惁鏈夊搴旇韩浠� if(Constants.equalsInteger(orders.getType(),Constants.ZERO)){ if(!Constants.equalsInteger(member.getWorkerIdentity(),Constants.TWO)){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"韬唤淇℃伅寮傚父锛岃鍓嶅線涓汉涓績杩涜韬唤璁よ瘉!"); + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鎮ㄨ繕鏈敞鍐岃鏈嶅姟锛岃鍓嶅線涓汉淇℃伅涓彁浜ょ敵璇枫��"); } }else if(Constants.equalsInteger(orders.getType(),Constants.ONE)){ if(!Constants.equalsInteger(member.getDriverIdentity(),Constants.TWO)){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"韬唤淇℃伅寮傚父锛岃鍓嶅線涓汉涓績杩涜韬唤璁よ瘉!"); + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鎮ㄨ繕鏈敞鍐岃鏈嶅姟锛岃鍓嶅線涓汉淇℃伅涓彁浜ょ敵璇枫��"); } }else{ if(!Constants.equalsInteger(member.getChefIdentity(),Constants.TWO)){ - throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"韬唤淇℃伅寮傚父锛岃鍓嶅線涓汉涓績杩涜韬唤璁よ瘉!"); + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鎮ㄨ繕鏈敞鍐岃鏈嶅姟锛岃鍓嶅線涓汉淇℃伅涓彁浜ょ敵璇枫��"); } } @@ -653,17 +705,33 @@ .set(Orders::getStatus,Constants.ordersStatus.accept.getKey()) ); - - //鏇存柊鎺ュ崟閲� - memberMapper.update(new UpdateWrapper<Member>().lambda().setSql(" publish_num = (publish_num + 1 )").eq(Member::getId,member.getId())); + memberMapper.update(new UpdateWrapper<Member>().lambda().setSql(" RECEIVE_NUM = (ifnull(RECEIVE_NUM,0) + 1 )").eq(Member::getId,member.getId())); //鍒涘缓鎿嶄綔鏃ュ織 Constants.OrdersLog ordersLog = Constants.OrdersLog.RECEIVE; this.saveOrderLog(orders,ordersLog, ordersLog.getInfo(),member.getId(),null); - //TODO 寰俊鍏紬鍙锋彁閱� 宸叉帴鍗曟彁閱� + IdentityInfo wokerIdentityInfo = identityInfoMapper.selectOne(new QueryWrapper<IdentityInfo>().lambda() + .eq(IdentityInfo::getMemberId,member.getId()) + .eq(IdentityInfo::getType,orders.getType()) + .eq(IdentityInfo::getAuditStatus,Constants.TWO) + .last("limit 1") + ); + Member releaseMember = memberMapper.selectById(orders.getReleaseMemberId()); + + if(Objects.nonNull(releaseMember)){ + if(org.apache.commons.lang3.StringUtils.isNotBlank(releaseMember.getOpenid())&&Objects.nonNull(wokerIdentityInfo)){ + //鍙戦�佸井淇¢�氱煡 + sendWxMessage.acceptMessage(releaseMember.getOpenid(),orders,wokerIdentityInfo.getLinkName(),wokerIdentityInfo.getTelephone()); + } + if(org.apache.commons.lang3.StringUtils.isNotBlank(orders.getLinkPhone())){ + //鐭俊閫氱煡 + aliSmsService.businessSendSms(Constants.smsContent.accept.getKey(),orders.getLinkPhone(),orders,null, + wokerIdentityInfo,categoryMapper); + } + } @@ -739,6 +807,7 @@ .set(Orders::getIsUpdateTime,new Date()) .set(Orders::getUpdateTime,new Date()) .set(Orders::getEstimatedAccount,total) + .set(Orders::getOriginEstimatedAccount,total) .eq(Orders::getId,orders.getId()) ); //鍒涘缓鎿嶄綔鏃ュ織 @@ -746,7 +815,28 @@ this.saveOrderLog(model,ordersLog, ordersLog.getInfo(),orders.getMember().getId(),null); - //TODO 閫氱煡鎺ュ崟浜� 璁㈠崟鍙戠敓鍙樻洿 + //閫氱煡鎺ュ崟浜� 璁㈠崟鍙戠敓鍙樻洿 + Member member = memberMapper.selectById(model.getAcceptMemberId()); + if(Objects.nonNull(member)){ + if(org.apache.commons.lang3.StringUtils.isNotBlank(member.getOpenid())){ + model.setStartDate(orders.getStartDate()); + model.setEndDate(orders.getEndDate()); + //鍙戦�佸井淇¢�氱煡 + sendWxMessage.orderUpdMessage(member.getOpenid(),model); + } + IdentityInfo wokerIdentityInfo = identityInfoMapper.selectOne(new QueryWrapper<IdentityInfo>().lambda() + .eq(IdentityInfo::getMemberId,member.getId()) + .eq(IdentityInfo::getType,orders.getType()) + .eq(IdentityInfo::getAuditStatus,Constants.TWO) + .last("limit 1") + ); + if(Objects.nonNull(wokerIdentityInfo)){ + //鐭俊閫氱煡 + aliSmsService.businessSendSms(Constants.smsContent.orderUpd.getKey(),wokerIdentityInfo.getTelephone(),orders,null, + null,categoryMapper); + } + } + } @@ -758,8 +848,9 @@ throw new BusinessException(ResponseStatus.BAD_REQUEST); } if( - (Constants.equalsInteger(orders.getType(),Constants.ZERO) && Constants.equalsInteger(orders.getWorkType(),Constants.ZERO )) - || Constants.equalsInteger(orders.getType(),Constants.ONE) + (Constants.equalsInteger(orders.getType(),Constants.ZERO) + && Constants.equalsInteger(orders.getWorkType(),Constants.ZERO )) + || Constants.equalsInteger(orders.getType(),Constants.ONE) || Constants.equalsInteger(orders.getType(),Constants.TWO) ){ orders.setPriceNum2(Constants.ONE); @@ -768,9 +859,79 @@ throw new BusinessException(ResponseStatus.BAD_REQUEST); } } - return orders.getPrice() * orders.getPriceNum1() * orders.getPriceNum2(); + BigDecimal bigDecimalPrice = orders.getPrice(). + multiply(new BigDecimal(orders.getPriceNum1().toString())) + .multiply(new BigDecimal(orders.getPriceNum2().toString())); + return bigDecimalPrice.divide(new BigDecimal("1"),0,BigDecimal.ROUND_HALF_UP).longValue();//orders.getPrice() * orders.getPriceNum1() * orders.getPriceNum2(); } + + /** + * 鎺ュ崟鏂圭‘璁よ鍗曡垂鐢� + */ + @Override + @Transactional(rollbackFor = {BusinessException.class,Exception.class}) + public void confirmFee(ConfirmFeeOrderDTO confirmUpdOrderDTO){ + if(Objects.isNull(confirmUpdOrderDTO) + || Objects.isNull(confirmUpdOrderDTO.getOrderId()) + || Objects.isNull(confirmUpdOrderDTO.getPriceNum1())){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + Orders orders = ordersMapper.selectById(confirmUpdOrderDTO.getOrderId()); + if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + if(!Constants.equalsInteger(orders.getAcceptMemberId(),confirmUpdOrderDTO.getMember().getId())){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炴偍鐨勮鍗曟棤娉曡繘琛岃鎿嶄綔"); + } + if(!Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.doing.getKey())){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜璇ユ搷浣�"); + } + //绫诲瀷:0=鐢ㄥ伐锛�1=杩愯揣锛�2=璁㈤ + if(Constants.equalsInteger(orders.getType(),Constants.ZERO)){ + //鐢ㄥ伐绫诲瀷:0=閲囨憳宸ワ紱1=鍒嗘嫞宸ワ紱2=鍖呰宸ワ紱锛堢敤宸ヨ鍗曪級 + if(Constants.equalsInteger(orders.getWorkType(),Constants.ONE)){ + //1=鍒嗘嫞宸� + if( Objects.isNull(confirmUpdOrderDTO.getPriceNum2())){//蹇呴』鏈夌敤宸ユ暟閲忥紙浜猴級 + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + }else if(Constants.equalsInteger(orders.getWorkType(),Constants.TWO)){ + //鍖呰宸� 鐢ㄨ溅绫诲瀷(鐢ㄥ伐鍖呰/杩愯揣浣跨敤):0=澶�;1=娆�/灏忔椂;2=閲嶉噺 + if( !Constants.equalsInteger(orders.getCarType(),Constants.TWO) + && Objects.isNull(confirmUpdOrderDTO.getPriceNum2())){ + //涓嶆槸鎸夐噸閲忚璐圭殑锛屽繀椤绘湁鐢ㄥ伐鏁伴噺锛堜汉锛� + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + } + }else if(Constants.equalsInteger(orders.getType(),Constants.ONE)){ + //杩愯揣璁㈠崟 + + }else{ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璇ヨ鍗曚笉鏀寔璇ユ搷浣滐紝璇疯繑鍥炲埛鏂伴噸璇曪紒"); + } + orders.setPriceNum1(confirmUpdOrderDTO.getPriceNum1()); + orders.setPriceNum2(confirmUpdOrderDTO.getPriceNum2()); + Long totalFee = this.getTotal(orders);//閲嶆柊璁$畻璐圭敤 + Long payFee = totalFee+Constants.formatLongNum(confirmUpdOrderDTO.getConfirmOtherFee());//閲嶆柊璁$畻璐圭敤 + BigDecimal recFee = new BigDecimal(payFee).multiply((new BigDecimal(1).subtract(Constants.formatBigDecimal(orders.getPlatformRata())))).setScale(0, RoundingMode.HALF_UP) ; + ordersMapper.update(new UpdateWrapper<Orders>().lambda() + .set(Orders::getPriceNum1,confirmUpdOrderDTO.getPriceNum1()) + .set(Orders::getPriceNum2,confirmUpdOrderDTO.getPriceNum2()) + .set(Orders::getConfirmFeeRemark,confirmUpdOrderDTO.getConfirmFeeRemark()) + .set(Orders::getConfirmOtherFee,confirmUpdOrderDTO.getConfirmOtherFee()) + .set(Orders::getEstimatedAccount,totalFee) + .set(Orders::getStatus,Constants.ordersStatus.feeconfirm.getKey()) + .set(Orders::getPayAccount,payFee) + .set(Orders::getReceiveAccount,recFee.longValue()) + .set(Orders::getUpdateTime,new Date()) + .eq(Orders::getId,orders.getId()) + ); + //璁板綍鍚屾剰淇敼鐨勬棩蹇� + Constants.OrdersLog ordersLog = Constants.OrdersLog.FEE_CONFIRM; + this.saveOrderLog(orders,ordersLog, + ordersLog.getInfo(),confirmUpdOrderDTO.getMember().getId(),null); + + } /** * 鎺ュ崟鏂瑰鐞嗚鍗曚慨鏀� @@ -826,8 +987,12 @@ Constants.OrdersLog ordersLog = Constants.OrdersLog.UPD_DISAGREE; this.saveOrderLog(orders,ordersLog, ordersLog.getInfo(),confirmUpdOrderDTO.getMember().getId(),null); - //TODO 鍙戦�佷笉鍚屾剰鍙樻洿閫氱煡 } + //鐭俊閫氱煡 + aliSmsService.businessSendSms(!Constants.equalsInteger(confirmUpdOrderDTO.getStatus(),Constants.ONE)? + Constants.smsContent.agreeUpd.getKey():Constants.smsContent.disAgreeUpd.getKey() + ,orders.getLinkPhone(),null,null, + null,categoryMapper); } @@ -845,9 +1010,35 @@ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炴偍鐨勮鍗曟棤娉曡繘琛岃鎿嶄綔"); } + } + @Override + public String cancelTips(Integer orderId,Member member){ + Orders orders = ordersMapper.selectById(orderId); + if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){ + throw new BusinessException(ResponseStatus.DATA_EMPTY); + } + + Integer totalCancelTimes = Integer.valueOf(systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.RELEASE_CANCEL_TIMES).getCode()); + Long cancelTimes = ordersMapper.selectCount(new QueryWrapper<Orders>().lambda() + .apply(" DATE(cancel_time) = DATE(NOW()) ") + .eq(Orders::getStatus,Constants.ordersStatus.cancel.getKey()) + .eq(Orders::getReleaseMemberId,member.getId())); + //鏌ヨ鍙栨秷娆℃暟 + if(totalCancelTimes<=cancelTimes){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"浠婃棩璁㈠崟涓诲姩鍙栨秷娆℃暟宸茶秴鍑�"+totalCancelTimes+"娆�,鏃犳硶鍙栨秷璁㈠崟"); + } + + Integer cancelTimeHour = Integer.valueOf(systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.RELEASE_CANCEL_TIME).getCode()); + Long hours = DateUtil.getBetweenHours(new Date(),orders.getStartDate()); + if(hours < cancelTimeHour){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璺濈璁㈠崟寮�濮嬫椂闂翠笉瓒�"+cancelTimeHour+"灏忔椂,鏃犳硶鍙栨秷璁㈠崟"); + } + return "浠婃棩杩樺彲涓诲姩鍙栨秷"+(totalCancelTimes-cancelTimes)+"娆★紝鏄惁纭鍙栨秷"; + + } /** * 鍙戝崟鏂瑰彇娑堣鍗� @@ -870,6 +1061,7 @@ //閫�娆句笟鍔� WithdrawalOrders withdrawalOrders = new WithdrawalOrders(); withdrawalOrders.setCreateTime(new Date()); + withdrawalOrders.setDeleted(Constants.ZERO); withdrawalOrders.setMemberId(orders.getReleaseMemberId()); withdrawalOrders.setAmount(orders.getPayAccount()); withdrawalOrders.setStatus(Constants.ZERO); @@ -923,8 +1115,6 @@ .set(Orders::getCancelType,Constants.ONE) .eq(Orders::getId,orders.getId()) ); - //TODO 鍙戝崟鏂瑰彇娑堣鍗曢�氱煡鎺ュ崟鏂� - //鍑忓皯鎺ュ崟閲� memberMapper.update(new UpdateWrapper<Member>().lambda().setSql("receive_num = (receive_num - 1) ").eq(Member::getId,orders.getAcceptMemberId())); } @@ -935,6 +1125,27 @@ Constants.OrdersLog ordersLog = Constants.OrdersLog.RELEASE_CANCEL; this.saveOrderLog(orders,ordersLog, ordersLog.getInfo(),member.getId(),null); + + List<Member> members = memberMapper.selectList(new QueryWrapper<Member>().lambda() + .and(i->i.eq(Member::getId,orders.getReleaseMemberId()).or().eq(Member::getId,orders.getAcceptMemberId())) + ); + if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(members)){ + List<String> openIdList = members.stream().map(i->i.getOpenid()).collect(Collectors.toList()); + //鍙戦�佸井淇¢�氱煡 + sendWxMessage.cancelMessage(openIdList,orders,Constants.ONE); + } + + IdentityInfo wokerIdentityInfo = identityInfoMapper.selectOne(new QueryWrapper<IdentityInfo>().lambda() + .eq(IdentityInfo::getMemberId,orders.getAcceptMemberId()) + .eq(IdentityInfo::getType,orders.getType()) + .eq(IdentityInfo::getAuditStatus,Constants.TWO) + .last("limit 1") + ); + if(Objects.nonNull(wokerIdentityInfo)){ + //鐭俊閫氱煡 + aliSmsService.businessSendSms(Constants.smsContent.releaseCancel.getKey(),wokerIdentityInfo.getTelephone(),orders,null, + null,categoryMapper); + } } @@ -981,8 +1192,18 @@ this.saveOrderLog(orders,ordersLog, ordersLog.getInfo(),member.getId(),null); - //TODO 鎺ュ崟鏂瑰彇娑堣鍗曢�氱煡 + List<Member> members = memberMapper.selectList(new QueryWrapper<Member>().lambda() + .and(i->i.eq(Member::getId,orders.getReleaseMemberId()).or().eq(Member::getId,orders.getAcceptMemberId())) + ); + if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(members)){ + List<String> openIdList = members.stream().map(i->i.getOpenid()).collect(Collectors.toList()); + //鍙戦�佸井淇¢�氱煡 + sendWxMessage.cancelMessage(openIdList,orders,Constants.TWO); + } + //鐭俊閫氱煡 + aliSmsService.businessSendSms(Constants.smsContent.receiveCancel.getKey(),member.getTelephone(),orders,null, + null,categoryMapper); } @@ -1009,6 +1230,11 @@ if(!Constants.equalsInteger(orders.getReleaseMemberId(),doneOrderDTO.getMember().getId())){ throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炴偍鐨勮鍗曟棤娉曡繘琛岃鎿嶄綔"); } + Member payMember = memberMapper.selectById(doneOrderDTO.getMember().getId()); + if(Objects.isNull(payMember)){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鐢ㄦ埛淇℃伅寮傚父"); + } + OrderReleaseVO orderReleaseVO = new OrderReleaseVO(); orderReleaseVO.setId(orders.getId()); Object object = null; @@ -1016,12 +1242,12 @@ if(!Constants.equalsInteger(orders.getType(),Constants.TWO)){ orders.setPayAccount(doneOrderDTO.getAmount()); //鎻愭垚閲戦 - Long tcje = Long.valueOf(new BigDecimal(orders.getPayAccount().toString()).multiply(orders.getPlatformRata()).intValue()); + Long tcje = (new BigDecimal(orders.getPayAccount().toString()).multiply(Constants.formatBigDecimal(orders.getPlatformRata())).setScale(0,RoundingMode.HALF_UP).longValue()); orders.setReceiveAccount(orders.getPayAccount() - tcje); orders.setOutTradeNo(UUID.randomUUID().toString().replace("-","")); ordersMapper.updateById(orders); //鍞よ捣鏀粯涓氬姟 - object = this.getWxPayResponse(orders,doneOrderDTO.getMember().getOpenid()); + object = this.getWxPayResponse(orders,payMember.getOpenid()); orderReleaseVO.setObject(object); }else{ orders.setStatus(Constants.ordersStatus.done.getKey()); @@ -1054,6 +1280,22 @@ Constants.OrdersLog ordersLog = Constants.OrdersLog.DONE; this.saveOrderLog(orders,ordersLog, ordersLog.getInfo(),doneOrderDTO.getMember().getId(),null); + + sendWxMessage.revenueMessage(member.getOpenid(),orders); + + //鐭俊閫氱煡鎺ュ崟鏂� + if(Objects.nonNull(orders.getAcceptMemberId())){ + IdentityInfo wokerIdentityInfo = identityInfoMapper.selectOne(new QueryWrapper<IdentityInfo>().lambda() + .eq(IdentityInfo::getMemberId,orders.getAcceptMemberId()) + .eq(IdentityInfo::getType,orders.getType()) + .eq(IdentityInfo::getAuditStatus,Constants.TWO) + .last("limit 1") + ); + if(Objects.nonNull(wokerIdentityInfo)){ + aliSmsService.businessSendSms(Constants.smsContent.pay.getKey(),wokerIdentityInfo.getTelephone(),orders,null, + null,categoryMapper); + } + } } return orderReleaseVO; } @@ -1144,6 +1386,33 @@ Constants.OrdersLog ordersLog = Constants.OrdersLog.SYSTEM_CANCEL; this.saveOrderLog(orders,ordersLog, ordersLog.getInfo(),null,loginUserInfo.getId()); + + List<Member> members = memberMapper.selectList(new QueryWrapper<Member>().lambda() + .and(i->i.eq(Member::getId,orders.getReleaseMemberId()).or().eq(Member::getId,orders.getAcceptMemberId())) + ); + if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(members)){ + List<String> openIdList = members.stream().map(i->i.getOpenid()).collect(Collectors.toList()); + orders.setCancelTime(new Date()); + //鍙戦�佸井淇¢�氱煡 + sendWxMessage.cancelMessage(openIdList,orders,Constants.ZERO); + } + //鐭俊閫氱煡鍙戝崟鏂� + aliSmsService.businessSendSms(Constants.smsContent.platformCancel.getKey(),orders.getLinkPhone(),orders,null, + null,categoryMapper); + //鐭俊閫氱煡鎺ュ崟鏂� + if(Objects.nonNull(orders.getAcceptMemberId())){ + IdentityInfo wokerIdentityInfo = identityInfoMapper.selectOne(new QueryWrapper<IdentityInfo>().lambda() + .eq(IdentityInfo::getMemberId,orders.getAcceptMemberId()) + .eq(IdentityInfo::getType,orders.getType()) + .eq(IdentityInfo::getAuditStatus,Constants.TWO) + .last("limit 1") + ); + if(Objects.nonNull(wokerIdentityInfo)){ + aliSmsService.businessSendSms(Constants.smsContent.platformCancel2.getKey(),wokerIdentityInfo.getTelephone(),orders,null, + null,categoryMapper); + } + } + } @@ -1179,9 +1448,10 @@ .eq(Orders::getId,orders.getId()) ); memberMapper.update(new UpdateWrapper<Member>().lambda() - .setSql(" score = ( total_score +" + commentDTO.getLevel() + " ) / (score_order_num + 1 )") - .setSql(" total_score = total_score +" + commentDTO.getLevel()) - .setSql(" score_order_num = score_order_num + 1 " ).eq(Member::getId,orders.getAcceptMemberId()) + .setSql(" score = ( ifnull(total_score,0) +" + commentDTO.getLevel() + " ) / (ifnull(score_order_num,0) + 1 )") + .setSql(" total_score = ifnull(total_score,0) +" + commentDTO.getLevel()) + .setSql(" score_order_num = ifnull(score_order_num,0) + 1 " ) + .eq(Member::getId,orders.getAcceptMemberId()) ); //鏃ュ織瀛樺偍 Constants.OrdersLog ordersLog = Constants.OrdersLog.COMMENT; @@ -1273,7 +1543,22 @@ this.saveOrderLog(orders,ordersLog, ordersLog.getInfo(),orders.getReleaseMemberId(),null); - //TODO 閫氱煡鎺ュ崟鏂� 娆鹃」宸插埌璐� + // 閫氱煡鎺ュ崟鏂� 娆鹃」宸插埌璐� + sendWxMessage.revenueMessage(member.getOpenid(),orders); + + //鐭俊閫氱煡鎺ュ崟鏂� + if(Objects.nonNull(orders.getAcceptMemberId())){ + IdentityInfo wokerIdentityInfo = identityInfoMapper.selectOne(new QueryWrapper<IdentityInfo>().lambda() + .eq(IdentityInfo::getMemberId,orders.getAcceptMemberId()) + .eq(IdentityInfo::getType,orders.getType()) + .eq(IdentityInfo::getAuditStatus,Constants.TWO) + .last("limit 1") + ); + if(Objects.nonNull(wokerIdentityInfo)){ + aliSmsService.businessSendSms(Constants.smsContent.pay.getKey(),wokerIdentityInfo.getTelephone(),orders,null, + null,categoryMapper); + } + } } } @@ -1503,6 +1788,10 @@ } orders.setStatusName(Constants.ordersStatus.getName(orders.getStatus())); orders.setCancelStatus(Constants.ZERO); + if(Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.accept.getKey())&&Constants.equalsInteger(orders.getIsUpdate(),Constants.ONE)){ + orders.setConfirmCountdown(DateUtil.getXMinuteAfterDate(orders.getIsUpdateTime(),60).getTime() - System.currentTimeMillis()); + } + this.getPriceUnit(orders); if(orders.getStatus() <= Constants.ordersStatus.accept.getKey()){ if(Constants.equalsInteger(orders.getReleaseMemberId(),member.getId())){ @@ -1595,7 +1884,7 @@ @Override public void autoGrabOrders(){ String autoConfirmTime = systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.AUTO_DISPATCH).getCode(); - List<Orders> ordersList = ordersMapper.selectList(new QueryWrapper<Orders>().lambda() + List<Orders> ordersList = ordersMapper.selectList(new QueryWrapper<Orders>().lambda().eq(Orders::getDeleted,Constants.ZERO) .eq(Orders::getStatus,Constants.ONE).eq(Orders::getCommentStatus,Constants.ZERO) .apply(" DATE_ADD(create_time, INTERVAL "+autoConfirmTime+" MINUTE) < now() ") .last("limit 100") @@ -1604,26 +1893,30 @@ BigDecimal lat = orders.getLat(); BigDecimal lgt = orders.getLgt(); //鏌ヨ鑼冨洿鍐呯殑浼氬憳 - List<Member> memberList = memberMapper.selectList(new MPJLambdaWrapper<Member>().selectAll(Member.class) - .select(" ifnull((select r.level from receive_weight r where r.RECEIVE_MAX > t.RECEIVE_NUM and t.RECEIVE_NUM > r.RECEIVE_MIN limit 1 ),0) " ,Member::getLevel) - .select( " ifnull( (select CONVERT( ST_Distance_Sphere ( POINT ( ii.lgt, ii.lat ), POINT ( "+lgt+", "+lat+" )) /1000,DECIMAL(15,2)) from identity_info ii where ii.AUDIT_STATUS = 2 and type = 0 and ii.member_id = t.ID limit 1 ),0) ",Member::getDistance ) - - .apply(" id in (" + - " select ii.member_id from identity_info ii where ii.AUDIT_STATUS = 2 and type = '"+orders.getType()+"' " + - " and ( CONVERT( ST_Distance_Sphere ( POINT ( ii.lgt, ii.lat ), POINT ( "+lgt+", "+lat+" )) /1000,DECIMAL(15,2))) < 100 " + - ") ") - .orderByDesc(Member::getLevel) - .orderByDesc(Member::getScore) - .orderByAsc(Member::getDistance) - .last(" limit 1 ") - ); + List<Member> memberList = memberMapper.getList(lgt,lat,orders.getType()); +// memberMapper.selectList(new MPJLambdaWrapper<Member>() +// .select(Member::getId,Member::getScore) +// .select(" ifnull((select r.level from receive_weight r where r.RECEIVE_MAX > RECEIVE_NUM and RECEIVE_NUM > r.RECEIVE_MIN limit 1 ),0) " ,Member::getLevel) +// .select( " ifnull( (select CONVERT( ST_Distance_Sphere ( POINT ( ii.lgt, ii.lat ), POINT ( "+lgt+", "+lat+" )) /1000,DECIMAL(15,2)) from identity_info ii where ii.AUDIT_STATUS = 2 and type = 0 and ii.member_id = ID limit 1 ),0) ",Member::getDistance ) +//// +// .apply(" id in (" + +// " select ii.member_id from identity_info ii where ii.AUDIT_STATUS = 2 and type = '"+orders.getType()+"' " + +// " and ( CONVERT( ST_Distance_Sphere ( POINT ( ii.lgt, ii.lat ), POINT ( "+lgt+", "+lat+" )) /1000,DECIMAL(15,2))) < 100 " + +// ") ") +// .orderByDesc(" level , score ") +// .orderByAsc(Member::getDistance) +// .last(" limit 1 ") +// ); if(CollectionUtils.isEmpty(memberList)){ continue; } + Member member = memberList.get(Constants.ZERO); + Member releaseMember = memberMapper.selectById(orders.getReleaseMemberId()); //鑷姩娲惧崟 - Orders model = ordersMapper.selectById(orders.getStatus()); - if(!Constants.equalsInteger(model.getStatus(),Constants.ONE)){ + Orders model = ordersMapper.selectById(orders.getId()); + if(!Constants.equalsInteger(model.getStatus(),Constants.ONE) || Constants.equalsInteger(model.getId(),model.getReleaseMemberId())){ + //濡傛灉璁㈠崟宸插垹闄� 骞朵笖闈炲彂甯冩柟 continue; } ordersMapper.update(new UpdateWrapper<Orders>().lambda().eq(Orders::getId,model.getId()) @@ -1635,13 +1928,34 @@ ); //鏇存柊鎺ュ崟閲� - memberMapper.update(new UpdateWrapper<Member>().lambda().setSql(" publish_num = (publish_num + 1 )").eq(Member::getId,member.getId())); + memberMapper.update(new UpdateWrapper<Member>().lambda().setSql(" RECEIVE_NUM = (ifnull(RECEIVE_NUM,0) + 1 )").eq(Member::getId,member.getId())); //鍒涘缓鎿嶄綔鏃ュ織 Constants.OrdersLog ordersLog = Constants.OrdersLog.AUTO; this.saveOrderLog(orders,ordersLog, ordersLog.getInfo(),member.getId(),null); + IdentityInfo wokerIdentityInfo = identityInfoMapper.selectOne(new QueryWrapper<IdentityInfo>().lambda() + .eq(IdentityInfo::getMemberId,member.getId()) + .eq(IdentityInfo::getType,orders.getType()) + .eq(IdentityInfo::getAuditStatus,Constants.TWO) + .last("limit 1") + ); + //閫氱煡鍙戝崟鏂� + if(org.apache.commons.lang3.StringUtils.isNotBlank(releaseMember.getOpenid())&&Objects.nonNull(wokerIdentityInfo)){ + //鍙戦�佸井淇¢�氱煡 + sendWxMessage.acceptMessage(releaseMember.getOpenid(),orders,wokerIdentityInfo.getLinkName(),wokerIdentityInfo.getTelephone()); + } + + //閫氱煡鎺ュ崟鏂� + sendWxMessage.autoDispatchMessage(member.getOpenid(),orders,GeoUtils.haversineDistance( + orders.getLgt().doubleValue(), orders.getLat().doubleValue(), + wokerIdentityInfo.getLgt().doubleValue(), + wokerIdentityInfo.getLat().doubleValue() + )); + + aliSmsService.businessSendSms(Constants.smsContent.dispatch.getKey(),orders.getLinkPhone(),orders,null, + null,categoryMapper); } } -- Gitblit v1.9.3