From 242725f795b4cca830421c07f714a3ec36af0add Mon Sep 17 00:00:00 2001
From: hjl <1657978663@qq.com>
Date: 星期二, 02 七月 2024 13:59:39 +0800
Subject: [PATCH] feat: 代码初始化、腾讯云短信SDK

---
 ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java |   62 ++++++++++++++++++++++++------
 1 files changed, 49 insertions(+), 13 deletions(-)

diff --git a/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java b/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java
index 60451f8..2ed177b 100644
--- a/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java
+++ b/ruoyi-service/ruoyi-worker/src/main/java/com/ruoyi/worker/controller/OrderController.java
@@ -1,14 +1,13 @@
 package com.ruoyi.worker.controller;
 
 
-import com.ruoyi.admin.api.entity.ExchangeDispatch;
+import com.ruoyi.admin.api.entity.ChangeDispatch;
 import com.ruoyi.admin.api.feignClient.AdminClient;
 import com.ruoyi.common.core.constant.Constants;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.exception.GlobalException;
 import com.ruoyi.common.core.utils.DateUtils;
 import com.ruoyi.common.security.service.TokenService;
-import com.ruoyi.system.api.model.LoginUser;
 import com.ruoyi.system.api.model.LoginUserInfo;
 import com.ruoyi.worker.entity.Evaluate;
 import com.ruoyi.worker.entity.MasterWorker;
@@ -90,24 +89,28 @@
         if (null == loginWorker) {
             return R.loginExpire("登录失效!");
         }
+        ChangeDispatch data = adminClient.changeDispatchOne(orderId).getData();
+        if (null != data) {
+            return R.fail("当前订单已提交改派申请!");
+        }
         MasterWorker masterWorker = masterWorkerService.getById(loginWorker.getUserid());
         // 订单改派信息
-        ExchangeDispatch exchangeDispatch = new ExchangeDispatch();
-        exchangeDispatch.setWorkerId(masterWorker.getId());
-        exchangeDispatch.setWorkerName(masterWorker.getRealName());
-        exchangeDispatch.setApplyReason(reason);
-        exchangeDispatch.setApplyTime(DateUtils.getNowDate());
-        exchangeDispatch.setState(0);
+        ChangeDispatch changeDispatch = new ChangeDispatch();
+        changeDispatch.setWorkerId(masterWorker.getId());
+        changeDispatch.setWorkerName(masterWorker.getRealName());
+        changeDispatch.setApplyReason(reason);
+        changeDispatch.setApplyTime(DateUtils.getNowDate());
+        changeDispatch.setState(0);
         Order order = orderService.lambdaQuery().eq(Order::getId, orderId).eq(Order::getIsDelete, 0).one();
         if (null == order) {
             throw new GlobalException("订单信息异常!");
         }
-        exchangeDispatch.setOrderId(orderId);
-        exchangeDispatch.setOrderNumber(order.getOrderNumber());
-        exchangeDispatch.setUserId(order.getUserId());
-        exchangeDispatch.setUserName(order.getReservationName());
+        changeDispatch.setOrderId(orderId);
+        changeDispatch.setOrderNumber(order.getOrderNumber());
+        changeDispatch.setUserId(order.getUserId());
+        changeDispatch.setUserName(order.getReservationName());
         // 添加改派信息
-        Boolean save = adminClient.changeDispatchSave(exchangeDispatch).getData();
+        Boolean save = adminClient.changeDispatchSave(changeDispatch).getData();
         return save ? R.ok() : R.fail();
     }
 
@@ -116,6 +119,39 @@
      *
      * @param orderId 订单id
      */
+    @ApiOperation(value = "订单路线导航", tags = {"师傅端-首页"})
+    @GetMapping(value = "/orderNavigation")
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "订单id", name = "orderId", dataType = "Integer", required = true),
+            @ApiImplicitParam(value = "师傅所在经度", name = "longitude", dataType = "String", required = true),
+            @ApiImplicitParam(value = "师傅所在纬度", name = "latitude", dataType = "String", required = true)
+    })
+    public R<Object> orderNavigation(@RequestParam Integer orderId, @RequestParam String longitude,
+                                     @RequestParam String latitude) {
+        LoginUserInfo loginWorker = tokenService.getLoginUserByWorker();
+        if (null == loginWorker) {
+            return R.loginExpire("登录失效!");
+        }
+        Order order = orderService.lambdaQuery().eq(Order::getId, orderId)
+                .eq(Order::getServerId, loginWorker.getUserid())
+                .eq(Order::getIsDelete, 0).one();
+        if (null == order) {
+            throw new GlobalException("请确认当前订单所派单师傅是否是您!");
+        }
+        // 用户下单经纬度
+        Double userLongitude = order.getLongitude();
+        Double userLatitude = order.getLatitude();
+        String userPosition = userLongitude + "," + userLatitude;
+        // 师傅当前位置 经纬度
+        String workerPosition = longitude + "," + latitude;
+        return R.ok(orderService.orderNavigation(userPosition, workerPosition));
+    }
+
+    /**
+     * 师傅端-已到达预约地点
+     *
+     * @param orderId 订单id
+     */
     @ApiOperation(value = "已到达预约地点", tags = {"师傅端-订单列表"})
     @GetMapping(value = "/reachPosition")
     @ApiImplicitParams({

--
Gitblit v1.7.1