From 99e92a155a1b21a8386b482e7aab6fef649aeffa Mon Sep 17 00:00:00 2001
From: rk <94314517@qq.com>
Date: 星期四, 28 八月 2025 17:47:03 +0800
Subject: [PATCH] 111

---
 server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java |  133 ++++++++++++++++++++++++++++---------------
 1 files changed, 86 insertions(+), 47 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 0041ca0..e1599db 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
@@ -33,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;
@@ -54,6 +55,7 @@
  * @author 姹熻箘韫�
  * @date 2025/07/09 12:00
  */
+@Slf4j
 @Service
 public class OrdersServiceImpl implements OrdersService {
 
@@ -297,6 +299,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);
@@ -310,9 +318,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()));
@@ -474,9 +495,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()));
                 }
             }
@@ -651,15 +672,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(),"鎮ㄨ繕鏈敞鍐岃鏈嶅姟锛岃鍓嶅線涓汉淇℃伅涓彁浜ょ敵璇枫��");
             }
         }
 
@@ -685,14 +706,20 @@
                 .eq(IdentityInfo::getAuditStatus,Constants.TWO)
                 .last("limit 1")
         );
+        Member releaseMember = memberMapper.selectById(orders.getReleaseMemberId());
 
-        if(org.apache.commons.lang3.StringUtils.isNotBlank(member.getOpenid())&&Objects.nonNull(wokerIdentityInfo)){
-            //鍙戦�佸井淇¢�氱煡
-            sendWxMessage.acceptMessage(member.getOpenid(),orders,wokerIdentityInfo.getLinkName(),wokerIdentityInfo.getTelephone());
+        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);
+            }
         }
-        //鐭俊閫氱煡
-        aliSmsService.businessSendSms(Constants.smsContent.accept.getKey(),member.getTelephone(),orders,null,
-                wokerIdentityInfo,categoryMapper);
+
 
 
     }
@@ -775,20 +802,25 @@
                 ordersLog.getInfo(),orders.getMember().getId(),null);
 
         //閫氱煡鎺ュ崟浜� 璁㈠崟鍙戠敓鍙樻洿
-        Member member = memberMapper.selectById(orders.getAcceptMemberId());
-        //鍙戦�佸井淇¢�氱煡
-        sendWxMessage.orderUpdMessage(member.getOpenid(),orders);
-
-        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);
+        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);
+            }
         }
 
     }
@@ -812,7 +844,8 @@
                 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();
     }
 
 
@@ -911,13 +944,13 @@
                 .eq(Orders::getReleaseMemberId,member.getId()));
         //鏌ヨ鍙栨秷娆℃暟
         if(totalCancelTimes<=cancelTimes){
-            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"浠婃棩璁㈠崟涓诲姩鍙栨秷娆℃暟宸茶秴鍑�"+totalCancelTimes+"娆�,鏃犳硶鍙栨秷璁㈠崟,濡傞渶澶勭悊璇疯仈绯诲鏈�");
+            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+"灏忔椂,鏃犳硶鍙栨秷璁㈠崟锛屽闇�澶勭悊璇疯仈绯诲鏈�");
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璺濈璁㈠崟寮�濮嬫椂闂翠笉瓒�"+cancelTimeHour+"灏忔椂,鏃犳硶鍙栨秷璁㈠崟");
         }
         return  "浠婃棩杩樺彲涓诲姩鍙栨秷"+(totalCancelTimes-cancelTimes)+"娆★紝鏄惁纭鍙栨秷";
 
@@ -1275,6 +1308,7 @@
                 );
         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);
         }
@@ -1670,6 +1704,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())){
@@ -1762,7 +1800,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")
@@ -1771,19 +1809,20 @@
             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;
             }
@@ -1791,7 +1830,7 @@
             Member member = memberList.get(Constants.ZERO);
             Member releaseMember = memberMapper.selectById(orders.getReleaseMemberId());
             //鑷姩娲惧崟
-            Orders model = ordersMapper.selectById(orders.getStatus());
+            Orders model = ordersMapper.selectById(orders.getId());
             if(!Constants.equalsInteger(model.getStatus(),Constants.ONE)){
                 continue;
             }
@@ -1804,7 +1843,7 @@
             );
 
             //鏇存柊鎺ュ崟閲�
-            memberMapper.update(new UpdateWrapper<Member>().lambda().setSql(" publish_num = (ifnull(publish_num,0) + 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;
@@ -1826,8 +1865,8 @@
             //閫氱煡鎺ュ崟鏂�
             sendWxMessage.autoDispatchMessage(member.getOpenid(),orders,GeoUtils.haversineDistance(
                     orders.getLgt().doubleValue(), orders.getLat().doubleValue(),
-                    member.getDriverIdentityModel().getLgt().doubleValue(),
-                    member.getDriverIdentityModel().getLat().doubleValue()
+                    wokerIdentityInfo.getLgt().doubleValue(),
+                    wokerIdentityInfo.getLat().doubleValue()
             ));
              
             aliSmsService.businessSendSms(Constants.smsContent.dispatch.getKey(),orders.getLinkPhone(),orders,null,

--
Gitblit v1.9.3