From 2d3b7304911a393e73ec0dd48712f22ddfa8053a Mon Sep 17 00:00:00 2001 From: zhibing.pu <393733352@qq.com> Date: 星期五, 19 四月 2024 17:55:11 +0800 Subject: [PATCH] 新增加功能 --- UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/controller/OrderLogisticsController.java | 115 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 113 insertions(+), 2 deletions(-) diff --git a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/controller/OrderLogisticsController.java b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/controller/OrderLogisticsController.java index 0e15cb3..214e75f 100644 --- a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/controller/OrderLogisticsController.java +++ b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/smallLogistics/controller/OrderLogisticsController.java @@ -1,11 +1,18 @@ package com.stylefeng.guns.modular.smallLogistics.controller; +import com.stylefeng.guns.modular.smallLogistics.model.OrderLogistics; import com.stylefeng.guns.modular.smallLogistics.server.IOrderLogisticsService; +import com.stylefeng.guns.modular.specialTrain.model.OrderPrivateCar; import com.stylefeng.guns.modular.system.model.Region; +import com.stylefeng.guns.modular.system.model.UserRedPacketRecord; import com.stylefeng.guns.modular.system.service.IUserInfoService; +import com.stylefeng.guns.modular.system.util.GoogleMap.DistancematrixVo; +import com.stylefeng.guns.modular.system.util.GoogleMap.GoogleMapUtil; +import com.stylefeng.guns.modular.system.util.PushUtil; import com.stylefeng.guns.modular.system.util.ResultUtil; import com.stylefeng.guns.modular.system.warpper.BaseWarpper; +import com.stylefeng.guns.modular.system.warpper.OrderTimeInfo; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; @@ -17,6 +24,9 @@ import org.springframework.web.bind.annotation.RestController; import javax.servlet.http.HttpServletRequest; +import java.math.BigDecimal; +import java.text.SimpleDateFormat; +import java.util.Calendar; import java.util.Date; import java.util.List; import java.util.Map; @@ -31,9 +41,10 @@ @Autowired private IOrderLogisticsService orderLogisticsService; - @Autowired private IUserInfoService userInfoService; + @Autowired + private PushUtil pushUtil; /** @@ -161,6 +172,48 @@ return ResultUtil.runErr(); } } + + + + + @ResponseBody + @PostMapping("/api/orderLogistics/placeOrderPackage") + @ApiOperation(value = "小件物流下单操作【2.0】", tags = {"用户端-小件物流"}, notes = "") + @ApiImplicitParams({ + @ApiImplicitParam(value = "备注", name = "remark", required = false, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "下单点经度", name = "placementLon", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "下单点纬度", name = "placementLat", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "起点经度", name = "startLon", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "起点纬度", name = "startLat", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "起点详细地址", name = "startAddress", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "收货人姓名", name = "recipient", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "收货人电话", name = "recipientPhone", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "终点经度", name = "endLon", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "终点纬度", name = "endLat", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "收货详细地址", name = "endAddress", required = true, paramType = "query", dataType = "string"), + @ApiImplicitParam(value = "车型id", name = "serverCarModelId", required = true, paramType = "query", dataType = "int"), + @ApiImplicitParam(value = "司机id", name = "driverId", required = false, paramType = "query", dataType = "int"), + @ApiImplicitParam(value = "下单方式(1:APP下单,2:扫码下单,3:小程序下单,4:司机下单,5:调度下单)", name = "orderSource", required = true, paramType = "query", dataType = "int"), + @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....") + }) + public ResultUtil<BaseWarpper> placeOrderPackage(String remark, String placementLon, String placementLat, String startLon, String startLat, String startAddress, + String recipient, String recipientPhone, String endLon, String endLat, String endAddress, Integer serverCarModelId, + Integer driverId, Integer orderSource, Integer language, HttpServletRequest request){ + try { + Integer uid = userInfoService.getUserIdFormRedis(request); + if(null == uid){ + return ResultUtil.tokenErr(); + } + return orderLogisticsService.placeOrderPackage(remark, placementLon, placementLat, startLon, startLat, startAddress, + recipient, recipientPhone, endLon, endLat, endAddress, serverCarModelId, driverId, orderSource, uid, language); + }catch (Exception e){ + e.printStackTrace(); + return ResultUtil.runErr(); + } + } + + + @ResponseBody @PostMapping("/api/orderLogistics/queryLogisticsNumber") @@ -242,5 +295,63 @@ return ResultUtil.runErr(); } } - + + + @ResponseBody + @PostMapping("/api/orderLogistics/queryTimeInfo") + @ApiOperation(value = "获取订单详情中的时间信息内容【2.0】", tags = {"用户端-小件物流"}, notes = "") + @ApiImplicitParams({ + @ApiImplicitParam(value = "订单id", name = "orderId", required = true, dataType = "int"), + @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....") + }) + public ResultUtil<OrderTimeInfo> queryTimeInfo(Integer orderId, Integer language){ + try { + OrderLogistics orderLogistics = orderLogisticsService.selectById(orderId); + OrderTimeInfo orderTimeInfo = new OrderTimeInfo(); + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + if(null != orderLogistics.getSnatchOrderTime()){ + orderTimeInfo.setSnatchOrderTime(sdf.format(orderLogistics.getSnatchOrderTime())); + } + if(null != orderLogistics.getStartServiceTime()){ + orderTimeInfo.setStartServiceTime(sdf.format(orderLogistics.getStartServiceTime())); + } + long time = System.currentTimeMillis() - orderLogistics.getSnatchOrderTime().getTime() / 60000; + //TODO 待翻译 + orderTimeInfo.setUsedTime(Double.valueOf(time / 60).intValue() + "小时" + time % 60 + "分钟"); + if(null != orderLogistics.getEndServiceTime()){ + orderTimeInfo.setEndServiceTime(sdf.format(orderLogistics.getEndServiceTime())); + } + DistancematrixVo distancematrix = GoogleMapUtil.getDistancematrix(orderLogistics.getStartLat(), orderLogistics.getStartLon(), orderLogistics.getEndLat(), orderLogistics.getEndLon()); + Long distance = distancematrix.getDistance(); + orderTimeInfo.setAllMileage(Double.valueOf(distance / 1000)); + orderTimeInfo.setMileage(orderLogistics.getMileage() / 1000); + return ResultUtil.success(orderTimeInfo); + }catch (Exception e){ + e.printStackTrace(); + return ResultUtil.runErr(); + } + } + + + + @ResponseBody + @PostMapping("/api/orderLogistics/confirmDifferencePrice") + @ApiOperation(value = "确认补差价【2.0】", tags = {"用户端-小件物流"}, notes = "") + @ApiImplicitParams({ + @ApiImplicitParam(value = "订单id", name = "orderId", required = true, dataType = "int"), + @ApiImplicitParam(value = "差价金额", name = "difference", required = true, dataType = "double"), + @ApiImplicitParam(value = "状态(2=同意,3=拒绝)", name = "status", required = true, dataType = "int"), + @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....") + }) + public ResultUtil confirmDifferencePrice(Integer orderId, Double difference, Integer status){ + OrderLogistics orderLogistics = orderLogisticsService.selectById(orderId); + if(1 == status){ + orderLogistics.setPriceDifference(difference); + orderLogisticsService.updateById(orderLogistics); + } + pushUtil.pushPayDifference(2, orderLogistics.getDriverId(), orderId, 4, difference, status); + return ResultUtil.success(); + } + + } -- Gitblit v1.7.1